干燥机配套车间生产管理系统/云平台服务端
baoshiwei
2023-03-20 ec743754d4eec74005f64ed537989b5ba6af4e79
src/views/system/depart/components/DepartRuleTab.vue
@@ -1,20 +1,9 @@
<template>
  <a-spin :spinning="loading">
    <template v-if="treeData.length > 0">
      <BasicTree
        ref="basicTree"
        class="depart-rule-tree"
        checkable
        :treeData="treeData"
        :checkedKeys="checkedKeys"
        :selectedKeys="selectedKeys"
        :expandedKeys="expandedKeys"
        :checkStrictly="checkStrictly"
        style="height: 500px; overflow: auto"
        @check="onCheck"
        @expand="onExpand"
        @select="onSelect"
      >
      <BasicTree ref="basicTree" class="depart-rule-tree" checkable :treeData="treeData" :checkedKeys="checkedKeys"
        :selectedKeys="selectedKeys" :expandedKeys="expandedKeys" :checkStrictly="checkStrictly"
        style="height: 500px; overflow: auto" @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" />
@@ -28,6 +17,8 @@
        <a-dropdown :trigger="['click']" placement="top">
          <template #overlay>
            <a-menu>
              <a-menu-item key="1" @click="toggleCheckStrictly(false)">父子关联</a-menu-item>
              <a-menu-item key="2" @click="toggleCheckStrictly(true)">取消关联</a-menu-item>
              <a-menu-item key="3" @click="toggleCheckALL(true)">全部勾选</a-menu-item>
              <a-menu-item key="4" @click="toggleCheckALL(false)">取消全选</a-menu-item>
              <a-menu-item key="5" @click="toggleExpandAll(true)">展开所有</a-menu-item>
@@ -47,123 +38,123 @@
</template>
<script lang="ts" setup>
  import { watch, computed, inject, ref, nextTick } from 'vue';
  import { useDrawer } from '/@/components/Drawer';
  import { BasicTree } from '/@/components/Tree/index';
  import DepartDataRuleDrawer from './DepartDataRuleDrawer.vue';
  import { queryRoleTreeList, queryDepartPermission, saveDepartPermission } from '../depart.api';
import { computed, inject, nextTick, ref, watch } from 'vue'
import { queryDepartPermission, queryRoleTreeList, saveDepartPermission } from '../depart.api'
import DepartDataRuleDrawer from './DepartDataRuleDrawer.vue'
import { useDrawer } from '/@/components/Drawer'
import { BasicTree } from '/@/components/Tree/index'
  const props = defineProps({
    data: { type: Object, default: () => ({}) },
  });
  // 当前选中的部门ID,可能会为空,代表未选择部门
  const departId = computed(() => props.data?.id);
const props = defineProps({
  data: { type: Object, default: () => ({}) },
})
// 当前选中的部门ID,可能会为空,代表未选择部门
const departId = computed(() => props.data?.id)
  const prefixCls = inject('prefixCls');
  const basicTree = ref();
  const loading = ref<boolean>(false);
  const treeData = ref<any[]>([]);
  const expandedKeys = ref<Array<any>>([]);
  const selectedKeys = ref<Array<any>>([]);
  const checkedKeys = ref<Array<any>>([]);
  const lastCheckedKeys = ref<Array<any>>([]);
  const checkStrictly = ref(true);
const prefixCls = inject('prefixCls')
const basicTree = ref()
const loading = ref<boolean>(false)
const treeData = ref<any[]>([])
const expandedKeys = ref<Array<any>>([])
const selectedKeys = ref<Array<any>>([])
const checkedKeys = ref<Array<any>>([])
const lastCheckedKeys = ref<Array<any>>([])
const checkStrictly = ref(true)
  // 注册数据规则授权弹窗抽屉
  const [registerDataRuleDrawer, dataRuleDrawer] = useDrawer();
// 注册数据规则授权弹窗抽屉
const [registerDataRuleDrawer, dataRuleDrawer] = useDrawer()
  // onCreated
  loadData();
  watch(departId, () => loadDepartPermission(), { immediate: true });
// onCreated
loadData()
watch(departId, () => loadDepartPermission(), { immediate: true })
  async function loadData() {
async function loadData() {
  try {
    loading.value = true
    let { treeList } = await queryRoleTreeList()
    treeData.value = treeList
    await nextTick()
    toggleExpandAll(true)
  } finally {
    loading.value = false
  }
}
async function loadDepartPermission() {
  if (departId.value) {
    try {
      loading.value = true;
      let { treeList } = await queryRoleTreeList();
      treeData.value = treeList;
      await nextTick();
      toggleExpandAll(true);
      loading.value = true
      let keys = await queryDepartPermission({ departId: departId.value })
      checkedKeys.value = keys
      lastCheckedKeys.value = [...keys]
    } finally {
      loading.value = false;
      loading.value = false
    }
  }
}
  async function loadDepartPermission() {
    if (departId.value) {
      try {
        loading.value = true;
        let keys = await queryDepartPermission({ departId: departId.value });
        checkedKeys.value = keys;
        lastCheckedKeys.value = [...keys];
      } finally {
        loading.value = false;
      }
    }
async function onSubmit() {
  try {
    loading.value = true
    await saveDepartPermission({
      departId: departId.value,
      permissionIds: checkedKeys.value.join(','),
      lastpermissionIds: lastCheckedKeys.value.join(','),
    })
    await loadData()
    await loadDepartPermission()
  } finally {
    loading.value = false
  }
}
  async function onSubmit() {
    try {
      loading.value = true;
      await saveDepartPermission({
        departId: departId.value,
        permissionIds: checkedKeys.value.join(','),
        lastpermissionIds: lastCheckedKeys.value.join(','),
      });
      await loadData();
      await loadDepartPermission();
    } finally {
      loading.value = false;
    }
// tree勾选复选框事件
function onCheck(event) {
  if (!Array.isArray(event)) {
    checkedKeys.value = event.checked
  } else {
    checkedKeys.value = event
  }
}
  // tree勾选复选框事件
  function onCheck(event) {
    if (!Array.isArray(event)) {
      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, { departId, functionId })
  }
  selectedKeys.value = []
}
  // tree选中事件
  function onSelect($selectedKeys, { selectedNodes }) {
    if (selectedNodes[0]?.ruleFlag) {
      let functionId = $selectedKeys[0];
      dataRuleDrawer.openDrawer(true, { departId, functionId });
    }
    selectedKeys.value = [];
  }
// 切换父子关联
async function toggleCheckStrictly(flag) {
  checkStrictly.value = flag
  await nextTick()
  checkedKeys.value = basicTree.value.getCheckedKeys()
}
  // 切换父子关联
  async function toggleCheckStrictly(flag) {
    checkStrictly.value = flag;
    await nextTick();
    checkedKeys.value = basicTree.value.getCheckedKeys();
  }
// 切换展开收起
async function toggleExpandAll(flag) {
  basicTree.value.expandAll(flag)
  await nextTick()
  expandedKeys.value = basicTree.value.getExpandedKeys()
}
  // 切换展开收起
  async function toggleExpandAll(flag) {
    basicTree.value.expandAll(flag);
    await nextTick();
    expandedKeys.value = basicTree.value.getExpandedKeys();
  }
  // 切换全选
  async function toggleCheckALL(flag) {
    basicTree.value.checkAll(flag);
    await nextTick();
    checkedKeys.value = basicTree.value.getCheckedKeys();
  }
// 切换全选
async function toggleCheckALL(flag) {
  basicTree.value.checkAll(flag)
  await nextTick()
  checkedKeys.value = basicTree.value.getCheckedKeys()
}
</script>
<style lang="less" scoped>
  // 【VUEN-188】解决滚动条不灵敏的问题
  .depart-rule-tree :deep(.scrollbar__bar) {
    pointer-events: none;
  }
// 【VUEN-188】解决滚动条不灵敏的问题
.depart-rule-tree :deep(.scrollbar__bar) {
  pointer-events: none;
}
</style>