Newer
Older
smart-metering-front / src / components / drawer / approverDrawer.vue
dutingting on 6 Dec 2022 9 KB 处理eslint语法问题
<!-- 审批设置 -->
<script setup>
import { computed, ref, watch } from 'vue'
import employeesDialog from '../dialog/employeesDialog.vue'
import roleDialog from '../dialog/roleDialog.vue'
import $func from '@/plugins/preload.js'
import useWorkFlowStore from '@/store/modules/workFlow'
const props = defineProps({
  directorMaxLevel: {
    type: Number,
    default: 0,
  },
})

const emits = defineEmits(['update:nodeConfig'])

const workFlowStore = useWorkFlowStore()

const approverConfig = ref({})
const approverVisible = ref(false)
const approverRoleVisible = ref(false)
const checkedRoleList = ref([])
const checkedList = ref([])
// const { approverConfig1, approverDrawer } = workFlowStore
const { setApproverConfig, setApprover } = workFlowStore

const closeDrawer = () => {
  setApprover(false)
}
const visible = computed({
  get() {
    console.log('1')
    return workFlowStore.approverDrawer
  },
  set() {
    closeDrawer()
  },
})
watch(workFlowStore.approverConfig1, (val) => {
  approverConfig.value = val.value
})
const changeRange = () => {
  approverConfig.value.nodeUserList = []
}
const changeType = (val) => {
  approverConfig.value.nodeUserList = []
  approverConfig.value.examineMode = 1
  approverConfig.value.noHanderAction = 2
  if (val === 2) {
    approverConfig.value.directorLevel = 1
  }
  else if (val === 4) {
    approverConfig.value.selectMode = 1
    approverConfig.value.selectRange = 1
  }
  else if (val === 7) {
    approverConfig.value.examineEndDirectorLevel = 1
  }
}
const addApprover = () => {
  approverVisible.value = true
  checkedList.value = approverConfig.value.nodeUserList
}
const addRoleApprover = () => {
  approverRoleVisible.value = true
  checkedRoleList.value = approverConfig.value.nodeUserList
}
const sureApprover = (data) => {
  approverConfig.value.nodeUserList = data
  approverVisible.value = false
}
const sureRoleApprover = (data) => {
  approverConfig.value.nodeUserList = data
  approverRoleVisible.value = false
}

const saveApprover = () => {
  approverConfig.value.error = !$func.setApproverStr(approverConfig.value)
  setApproverConfig({
    value: approverConfig.value,
    flag: true,
    id: workFlowStore.approverConfig1.value.id,
  })
  emits('update:nodeConfig', approverConfig.value)
  closeDrawer()
}
</script>

<template>
  <el-drawer v-model="visible" :append-to-body="true" title="审批人设置" direction="rtl" custom-class="set_promoter" size="550px" :before-close="saveApprover">
    <div class="demo-drawer__content">
      <div class="drawer_content">
        <div class="approver_content">
          <el-radio-group v-model="approverConfig.settype" class="clear" @change="changeType">
            <el-radio :label="1">
              指定成员
            </el-radio>
            <el-radio :label="2">
              主管
            </el-radio>
            <el-radio :label="4">
              发起人自选
            </el-radio>
            <el-radio :label="5">
              发起人自己
            </el-radio>
            <el-radio :label="7">
              连续多级主管
            </el-radio>
          </el-radio-group>
          <el-button v-if="approverConfig.settype === 1" type="primary" @click="addApprover">
            添加/修改成员
          </el-button>
          <p v-if="approverConfig.settype === 1" class="selected_list">
            <span v-for="(item, index) in approverConfig.nodeUserList" :key="index">{{ item.name }}
              <img src="@/assets/images/add-close1.png" @click="$func.removeEle(approverConfig.nodeUserList, item, 'targetId')">
            </span>
            <a v-if="approverConfig.nodeUserList.length !== 0" @click="approverConfig.nodeUserList = []">清除</a>
          </p>
        </div>
        <div v-if="approverConfig.settype === 2" class="approver_manager">
          <p>
            <span>发起人的:</span>
            <select v-model="approverConfig.directorLevel">
              <option v-for="item in directorMaxLevel" :key="item" :value="item">
                {{ item === 1 ? '直接' : `第${item}级` }}主管
              </option>
            </select>
          </p>
          <p class="tip">
            找不到主管时,由上级主管代审批
          </p>
        </div>
        <div v-if="approverConfig.settype === 5" class="approver_self">
          <p>该审批节点设置“发起人自己”后,审批人默认为发起人</p>
        </div>
        <div v-show="approverConfig.settype === 4" class="approver_self_select">
          <el-radio-group v-model="approverConfig.selectMode" style="width: 100%;">
            <el-radio :label="1">
              选一个人
            </el-radio>
            <el-radio :label="2">
              选多个人
            </el-radio>
          </el-radio-group>
          <h3>选择范围</h3>
          <el-radio-group v-model="approverConfig.selectRange" style="width: 100%;" @change="changeRange">
            <el-radio :label="1">
              全公司
            </el-radio>
            <el-radio :label="2">
              指定成员
            </el-radio>
            <el-radio :label="3">
              指定角色
            </el-radio>
          </el-radio-group>
          <el-button v-if="approverConfig.selectRange === 2" type="primary" @click="addApprover">
            添加/修改成员
          </el-button>
          <el-button v-if="approverConfig.selectRange === 3" type="primary" @click="addRoleApprover">
            添加/修改角色
          </el-button>
          <p v-if="approverConfig.selectRange === 2 || approverConfig.selectRange === 3" class="selected_list">
            <span v-for="(item, index) in approverConfig.nodeUserList" :key="index">{{ item.name }}
              <img src="@/assets/images/add-close1.png" @click="$func.removeEle(approverConfig.nodeUserList, item, 'targetId')">
            </span>
            <a v-if="approverConfig.nodeUserList.length !== 0 && approverConfig.selectRange !== 1" @click="approverConfig.nodeUserList = []">清除</a>
          </p>
        </div>
        <div v-if="approverConfig.settype === 7" class="approver_manager">
          <p>审批终点</p>
          <p style="padding-bottom: 20px;">
            <span>发起人的:</span>
            <select v-model="approverConfig.examineEndDirectorLevel">
              <option v-for="item in directorMaxLevel" :key="item" :value="item">
                {{ item === 1 ? '最高' : `第${item}` }}层级主管
              </option>
            </select>
          </p>
        </div>
        <div v-if="(approverConfig.settype === 1 && approverConfig.nodeUserList.length > 1) || approverConfig.settype === 2 || (approverConfig.settype === 4 && approverConfig.selectMode === 2)" class="approver_some">
          <p>多人审批时采用的审批方式</p>
          <el-radio-group v-model="approverConfig.examineMode" class="clear">
            <el-radio :label="1">
              依次审批
            </el-radio>
            <br>
            <el-radio v-if="approverConfig.settype !== 2" :label="2">
              会签(须所有审批人同意)
            </el-radio>
          </el-radio-group>
        </div>
        <div v-if="approverConfig.settype === 2 || approverConfig.settype === 7" class="approver_some">
          <p>审批人为空时</p>
          <el-radio-group v-model="approverConfig.noHanderAction" class="clear">
            <el-radio :label="1">
              自动审批通过/不允许发起
            </el-radio>
            <br>
            <el-radio :label="2">
              转交给审核管理员
            </el-radio>
          </el-radio-group>
        </div>
      </div>
      <div class="demo-drawer__footer clear">
        <el-button type="primary" @click="saveApprover">
          确 定
        </el-button>
        <el-button @click="closeDrawer">
          取 消
        </el-button>
      </div>
      <employees-dialog
        v-model:visible="approverVisible"
        v-model:data="checkedList"
        @change="sureApprover"
      />
      <role-dialog
        v-model:visible="approverRoleVisible"
        v-model:data="checkedRoleList"
        @change="sureRoleApprover"
      />
    </div>
  </el-drawer>
</template>

<style lang="scss">
.set_promoter {
  .approver_content {
    padding-bottom: 10px;
    border-bottom: 1px solid #f2f2f2;
  }

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

  .approver_content,
  .approver_some,
  .approver_self_select {
    .el-radio-group {
      display: unset;
    }

    .el-radio {
      width: 27%;
      margin-bottom: 20px;
      height: 16px;
    }
  }

  .approver_manager p {
    line-height: 32px;
  }

  .approver_manager select {
    width: 420px;
    height: 32px;
    background: rgb(255 255 255 / 100%);
    border-radius: 4px;
    border: 1px solid rgb(217 217 217 / 100%);
  }

  .approver_manager p.tip {
    margin: 10px 0 22px;
    font-size: 12px;
    line-height: 16px;
    color: #f8642d;
  }

  .approver_self {
    padding: 28px 20px;
  }

  .approver_self_select,
  .approver_manager,
  .approver_content,
  .approver_some {
    padding: 20px 20px 0;
  }

  .approver_manager p:first-of-type,
  .approver_some p {
    line-height: 19px;
    font-size: 14px;
    margin-bottom: 14px;
  }

  .approver_self_select h3 {
    margin: 5px 0 20px;
    font-size: 14px;
    font-weight: bold;
    line-height: 19px;
  }
}
</style>