干燥机配套车间生产管理系统/云平台服务端
baoshiwei
2023-05-24 beca65f4d01ca07c358102a35b949c2a4f277afe
src/views/system/departUser/components/DepartRoleAuthDrawer.vue
@@ -1,144 +1,158 @@
<template>
  <BasicDrawer title="部门角色权限配置"
               :width="650"
               :loading="loading"
               showFooter
               okText="保存并关闭"
               @ok="onSubmit(true)"
    @close="onClose" @register="registerDrawer">
    <div>
      <a-spin :spinning="loading">
        <template v-if="treeData.length > 0">
          <BasicTree title="所拥有的部门权限" toolbar checkable :treeData="treeData" :checkedKeys="checkedKeys"
            :selectedKeys="selectedKeys" :expandedKeys="expandedKeys" :checkStrictly="checkStrictly"
            :clickRowToExpand="false" @check="onCheck" @expand="onExpand" @select="onSelect">
            <template #title="{ slotTitle, ruleFlag }">
              <span>{{ slotTitle }}</span>
              <Icon v-if="ruleFlag" icon="ant-design:align-left-outlined" style="margin-left: 5px; color: red" />
            </template>
          </BasicTree>
        </template>
        <a-empty v-else description="无可配置部门权限" />
      </a-spin>
    </div>
   <BasicDrawer
      title="部门角色权限配置"
      :width="650"
      :loading="loading"
      showFooter
      okText="保存并关闭"
      @ok="onSubmit(true)"
      @close="onClose"
      @register="registerDrawer"
   >
      <div>
         <a-spin :spinning="loading">
            <template v-if="treeData.length > 0">
               <BasicTree
                  title="所拥有的部门权限"
                  toolbar
                  checkable
                  :treeData="treeData"
                  :checkedKeys="checkedKeys"
                  :selectedKeys="selectedKeys"
                  :expandedKeys="expandedKeys"
                  :checkStrictly="checkStrictly"
                  :clickRowToExpand="false"
                  @check="onCheck"
                  @expand="onExpand"
                  @select="onSelect"
               >
                  <template #title="{ slotTitle, ruleFlag }">
                     <span>{{ slotTitle }}</span>
                     <Icon v-if="ruleFlag" icon="ant-design:align-left-outlined" style="margin-left: 5px; color: red" />
                  </template>
               </BasicTree>
            </template>
            <a-empty v-else description="无可配置部门权限" />
         </a-spin>
      </div>
    <template #centerFooter>
      <a-button type="primary" :loading="loading" ghost @click="onSubmit(false)">仅保存</a-button>
    </template>
  </BasicDrawer>
  <DepartRoleDataRuleDrawer @register="registerDataRuleDrawer" />
      <template #centerFooter>
         <a-button type="primary" :loading="loading" ghost @click="onSubmit(false)">仅保存</a-button>
      </template>
   </BasicDrawer>
   <DepartRoleDataRuleDrawer @register="registerDataRuleDrawer" />
</template>
<script lang="ts" setup>
import { ref } from 'vue';
   import { ref } from 'vue'
import { BasicTree } from '/@/components/Tree/index';
import { BasicDrawer, useDrawer, useDrawerInner } from '/@/components/Drawer';
import { useMessage } from '/@/hooks/web/useMessage';
   import { BasicDrawer, useDrawer, useDrawerInner } from '/@/components/Drawer'
   import { BasicTree } from '/@/components/Tree/index'
   import { useMessage } from '/@/hooks/web/useMessage'
import DepartRoleDataRuleDrawer from './DepartRoleDataRuleDrawer.vue';
import { queryTreeListForDeptRole, queryDeptRolePermission, saveDeptRolePermission } from '../depart.user.api';
   import { queryDeptRolePermission, queryTreeListForDeptRole, saveDeptRolePermission } from '../depart.user.api'
   import DepartRoleDataRuleDrawer from './DepartRoleDataRuleDrawer.vue'
defineEmits(['register']);
const { createMessage } = useMessage();
const loading = ref(false);
const departId = ref('');
const roleId = ref('');
const treeData = ref<Array<any>>([]);
const checkedKeys = ref<Array<any>>([]);
const lastCheckedKeys = ref<Array<any>>([]);
const expandedKeys = ref<Array<any>>([]);
const selectedKeys = ref<Array<any>>([]);
const allTreeKeys = ref<Array<any>>([]);
const checkStrictly = ref(true);
   defineEmits(['register'])
   const { createMessage } = useMessage()
   const loading = ref(false)
   const departId = ref('')
   const roleId = ref('')
   const treeData = ref<Array<any>>([])
   const checkedKeys = ref<Array<any>>([])
   const lastCheckedKeys = ref<Array<any>>([])
   const expandedKeys = ref<Array<any>>([])
   const selectedKeys = ref<Array<any>>([])
   const allTreeKeys = ref<Array<any>>([])
   const checkStrictly = ref(true)
// 注册抽屉组件
const [registerDrawer, { closeDrawer }] = useDrawerInner((data) => {
  roleId.value = data.record.id;
  departId.value = data.record.departId;
  loadData();
});
// 注册数据规则授权弹窗抽屉
const [registerDataRuleDrawer, dataRuleDrawer] = useDrawer();
   // 注册抽屉组件
   const [registerDrawer, { closeDrawer }] = useDrawerInner((data) => {
      roleId.value = data.record.id
      departId.value = data.record.departId
      loadData()
   })
   // 注册数据规则授权弹窗抽屉
   const [registerDataRuleDrawer, dataRuleDrawer] = useDrawer()
async function loadData() {
  try {
    loading.value = true;
    // 用户角色授权功能,查询菜单权限树
    const { ids, treeList } = await queryTreeListForDeptRole({ departId: departId.value });
    if (ids.length > 0) {
      allTreeKeys.value = ids;
      expandedKeys.value = ids;
      treeData.value = treeList;
      // 查询角色授权
      checkedKeys.value = await queryDeptRolePermission({ roleId: roleId.value });
      lastCheckedKeys.value = [checkedKeys.value];
    } else {
      reset();
    }
  } finally {
    loading.value = false;
  }
}
   async function loadData() {
      try {
         loading.value = true
         // 用户角色授权功能,查询菜单权限树
         const { ids, treeList } = await queryTreeListForDeptRole({ departId: departId.value })
         if (ids.length > 0) {
            allTreeKeys.value = ids
            expandedKeys.value = ids
            treeData.value = treeList
            // 查询角色授权
            checkedKeys.value = await queryDeptRolePermission({ roleId: roleId.value })
            lastCheckedKeys.value = [checkedKeys.value]
         } else {
            reset()
         }
      } finally {
         loading.value = false
      }
   }
// 重置页面
function reset() {
  treeData.value = [];
  expandedKeys.value = [];
  checkedKeys.value = [];
  lastCheckedKeys.value = [];
  loading.value = false;
}
   // 重置页面
   function reset() {
      treeData.value = []
      expandedKeys.value = []
      checkedKeys.value = []
      lastCheckedKeys.value = []
      loading.value = false
   }
// tree勾选复选框事件
function onCheck(event) {
  if (checkStrictly.value) {
    checkedKeys.value = event.checked;
  } else {
    checkedKeys.value = event;
  }
}
   // tree勾选复选框事件
   function onCheck(event) {
      if (checkStrictly.value) {
         checkedKeys.value = event.checked
      } else {
         checkedKeys.value = event
      }
   }
// tree展开事件
function onExpand($expandedKeys) {
  expandedKeys.value = $expandedKeys;
}
   // tree展开事件
   function onExpand($expandedKeys) {
      expandedKeys.value = $expandedKeys
   }
// tree选中事件
function onSelect($selectedKeys, { selectedNodes }) {
  if (selectedNodes[0]?.ruleFlag) {
    let functionId = $selectedKeys[0];
    dataRuleDrawer.openDrawer(true, { roleId, departId, functionId });
  }
  selectedKeys.value = [];
}
   // tree选中事件
   function onSelect($selectedKeys, { selectedNodes }) {
      if (selectedNodes[0]?.ruleFlag) {
         let functionId = $selectedKeys[0]
         dataRuleDrawer.openDrawer(true, { roleId, departId, functionId })
      }
      selectedKeys.value = []
   }
function doClose() {
  reset();
  closeDrawer();
}
   function doClose() {
      reset()
      closeDrawer()
   }
function onClose() {
  reset();
}
   function onClose() {
      reset()
   }
async function onSubmit(exit) {
  try {
    loading.value = true;
    let params = {
      roleId: roleId.value,
      permissionIds: checkedKeys.value.join(','),
      lastpermissionIds: lastCheckedKeys.value.join(','),
    };
    await saveDeptRolePermission(params);
    if (exit) {
      doClose();
    }
  } finally {
    loading.value = false;
    if (!exit) {
      loadData();
    }
  }
}
   async function onSubmit(exit) {
      try {
         loading.value = true
         let params = {
            roleId: roleId.value,
            permissionIds: checkedKeys.value.join(','),
            lastpermissionIds: lastCheckedKeys.value.join(','),
         }
         await saveDeptRolePermission(params)
         if (exit) {
            doClose()
         }
      } finally {
         loading.value = false
         if (!exit) {
            loadData()
         }
      }
   }
</script>