Newer
Older
SpaceIntegration_front / src / components / drawer / copyerDrawer.vue
dutingting on 6 Dec 2022 2 KB 处理eslint语法问题
<!-- 抄送人设置 -->
<script setup>
import { computed, ref, watch } from 'vue'
import employeesRoleDialog from '../dialog/employeesRoleDialog.vue'
import $func from '@/plugins/preload'
import useWorkFlowStore from '@/store/modules/workFlow'
const workFlowStore = useWorkFlowStore()
const copyerConfig = ref({})
const ccSelfSelectFlag = ref([])
const copyerVisible = ref(false)
const checkedList = ref([])
// const { copyerDrawer, copyerConfig1 } = workFlowStore
const { setCopyerConfig, setCopyer } = workFlowStore

const closeDrawer = () => {
  setCopyer(false)
}
const visible = computed({
  get() {
    console.log('3')

    return workFlowStore.copyerDrawer
  },
  set() {
    closeDrawer()
  },
})
watch(workFlowStore.copyerConfig1, (val) => {
  copyerConfig.value = val.value
  ccSelfSelectFlag.value = copyerConfig.value.ccSelfSelectFlag == 0 ? [] : [copyerConfig.value.ccSelfSelectFlag]
})

const addCopyer = () => {
  copyerVisible.value = true
  checkedList.value = copyerConfig.value.nodeUserList
}
const sureCopyer = (data) => {
  copyerConfig.value.nodeUserList = data
  copyerVisible.value = false
}
const saveCopyer = () => {
  copyerConfig.value.ccSelfSelectFlag = ccSelfSelectFlag.value.length == 0 ? 0 : 1
  copyerConfig.value.error = !$func.copyerStr(copyerConfig.value)
  setCopyerConfig({
    value: copyerConfig.value,
    flag: true,
    id: workFlowStore.copyerConfig1.value.id,
  })
  closeDrawer()
}
</script>

<template>
  <el-drawer v-model="visible" :append-to-body="true" title="抄送人设置" direction="rtl" custom-class="set_copyer" size="550px" :before-close="saveCopyer">
    <div class="demo-drawer__content">
      <div class="copyer_content drawer_content">
        <el-button type="primary" @click="addCopyer">
          添加成员
        </el-button>
        <p class="selected_list">
          <span v-for="(item, index) in copyerConfig.nodeUserList" :key="index">{{ item.name }}
            <img src="@/assets/images/add-close1.png" @click="$func.removeEle(copyerConfig.nodeUserList, item, 'targetId')">
          </span>
          <a v-if="copyerConfig.nodeUserList && copyerConfig.nodeUserList.length !== 0" @click="copyerConfig.nodeUserList = []">清除</a>
        </p>
        <el-checkbox-group v-model="ccSelfSelectFlag" class="clear">
          <el-checkbox :label="1">
            允许发起人自选抄送人
          </el-checkbox>
        </el-checkbox-group>
      </div>
      <div class="demo-drawer__footer clear">
        <el-button type="primary" @click="saveCopyer">
          确 定
        </el-button>
        <el-button @click="closeDrawer">
          取 消
        </el-button>
      </div>
      <employees-role-dialog
        v-model:visible="copyerVisible"
        v-model:data="checkedList"
        @change="sureCopyer"
      />
    </div>
  </el-drawer>
</template>

<style lang="scss">
.set_copyer {
  .copyer_content {
    padding: 20px 20px 0;

    .el-button {
      margin-bottom: 20px;
    }

    .el-checkbox {
      margin-bottom: 20px;
    }
  }
}
</style>