干燥机配套车间生产管理系统/云平台服务端
baoshiwei
2023-03-27 3bd0ac27a231a1a2b5b7ae2f44501fea69c4ab1f
src/views/system/role/components/RolePermissionDrawer.vue
@@ -1,5 +1,9 @@
<template>
  <BasicDrawer v-bind="$attrs" @register="registerDrawer" width="650px" destroyOnClose showFooter>
  <BasicDrawer v-bind="$attrs"
               @register="registerDrawer"
               width="650px"
               destroyOnClose
               showFooter>
    <template #title>
      角色权限配置
      <a-dropdown>
@@ -18,19 +22,9 @@
        </template>
      </a-dropdown>
    </template>
    <BasicTree
      ref="treeRef"
      checkable
      :treeData="treeData"
      :checkedKeys="checkedKeys"
      :expandedKeys="expandedKeys"
      :selectedKeys="selectedKeys"
      :checkStrictly="checkStrictly"
      :clickRowToExpand="false"
      title="所拥有的的权限"
      @check="onCheck"
      @select="onTreeNodeSelect"
    >
    <BasicTree ref="treeRef" checkable :treeData="treeData" :checkedKeys="checkedKeys" :expandedKeys="expandedKeys"
      :selectedKeys="selectedKeys" :checkStrictly="checkStrictly" :clickRowToExpand="false" title="所拥有的的权限"
      @check="onCheck" @select="onTreeNodeSelect">
      <template #title="{ slotTitle, ruleFlag }">
        {{ slotTitle }}
        <Icon v-if="ruleFlag" icon="ant-design:align-left-outlined" style="margin-left: 5px; color: red"></Icon>
@@ -39,168 +33,173 @@
    <!--右下角按钮-->
    <template #footer>
      <PopConfirmButton title="确定放弃编辑?" @confirm="closeDrawer" okText="确定" cancelText="取消">取消</PopConfirmButton>
      <a-button @click="handleSubmit(false)" type="primary" :loading="loading" ghost style="margin-right: 0.8rem">仅保存</a-button>
      <a-button @click="handleSubmit(false)" type="primary" :loading="loading" ghost
        style="margin-right: 0.8rem">仅保存</a-button>
      <a-button @click="handleSubmit(true)" type="primary" :loading="loading">保存并关闭</a-button>
    </template>
    <RoleDataRuleDrawer @register="registerDrawer1" />
  </BasicDrawer>
</template>
<script lang="ts" setup>
  import { ref, computed, unref, onMounted } from 'vue';
  import { BasicDrawer, useDrawer, useDrawerInner } from '/src/components/Drawer';
  import { BasicTree, TreeItem } from '/src/components/Tree';
  import { PopConfirmButton } from '/@/components/Button';
  import RoleDataRuleDrawer from './RoleDataRuleDrawer.vue';
  import { queryTreeListForRole, queryRolePermission, saveRolePermission } from '../role.api';
  const emit = defineEmits(['register']);
  //树的信息
  const treeData = ref<TreeItem[]>([]);
  //树的全部节点信息
  const allTreeKeys = ref([]);
  //树的选择节点信息
  const checkedKeys = ref([]);
  const defaultCheckedKeys = ref([]);
  //树的选中的节点信息
  const selectedKeys = ref([]);
  const roleId = ref('');
  //树的实例
  const treeRef = ref(null);
  const loading = ref(false);
import { ref, computed, unref, onMounted } from 'vue'
import { BasicDrawer, useDrawer, useDrawerInner } from '/src/components/Drawer'
import { BasicTree, TreeItem } from '/src/components/Tree'
import { PopConfirmButton } from '/@/components/Button'
import RoleDataRuleDrawer from './RoleDataRuleDrawer.vue'
import { queryTreeListForRole, queryRolePermission, saveRolePermission } from '../role.api'
const emit = defineEmits(['register'])
//树的信息
const treeData = ref<TreeItem[]>([])
//树的全部节点信息
const allTreeKeys = ref([])
//树的选择节点信息
const checkedKeys = ref([])
const defaultCheckedKeys = ref([])
//树的选中的节点信息
const selectedKeys = ref([])
const roleId = ref('')
//树的实例
const treeRef = ref(null)
const loading = ref(false)
  //展开折叠的key
  const expandedKeys = ref<any>([]);
  //父子节点选中状态是否关联
  const checkStrictly = ref<boolean>(true);
  const [registerDrawer1, { openDrawer: openDataRuleDrawer }] = useDrawer();
  const [registerDrawer, { setDrawerProps, closeDrawer }] = useDrawerInner(async (data) => {
    await reset();
    setDrawerProps({ confirmLoading: false, loading: true });
    roleId.value = data.roleId;
    //初始化数据
    const roleResult = await queryTreeListForRole();
    treeData.value = roleResult.treeList;
    allTreeKeys.value = roleResult.ids;
    expandedKeys.value = roleResult.ids;
    //初始化角色菜单数据
    const permResult = await queryRolePermission({ roleId: unref(roleId) });
    checkedKeys.value = permResult;
    defaultCheckedKeys.value = permResult;
    setDrawerProps({ loading: false });
  });
  /**
   * 点击选中
   */
  function onCheck(o) {
    checkedKeys.value = o.checked ? o.checked : o;
//展开折叠的key
const expandedKeys = ref<any>([])
//父子节点选中状态是否关联
const checkStrictly = ref<boolean>(true)
const [registerDrawer1, { openDrawer: openDataRuleDrawer }] = useDrawer()
const [registerDrawer, { setDrawerProps, closeDrawer }] = useDrawerInner(async (data) => {
  await reset()
  setDrawerProps({ confirmLoading: false, loading: true })
  roleId.value = data.roleId
  //初始化数据
  const roleResult = await queryTreeListForRole()
  treeData.value = roleResult.treeList
  allTreeKeys.value = roleResult.ids
  expandedKeys.value = roleResult.ids
  //初始化角色菜单数据
  const permResult = await queryRolePermission({ roleId: unref(roleId) })
  checkedKeys.value = permResult
  defaultCheckedKeys.value = permResult
  setDrawerProps({ loading: false })
})
/**
 * 点击选中
 */
function onCheck(o) {
  checkedKeys.value = o.checked ? o.checked : o
}
/**
 * 选中节点,打开数据权限抽屉
 */
function onTreeNodeSelect(key) {
  if (key && key.length > 0) {
    selectedKeys.value = key
  }
  /**
   * 选中节点,打开数据权限抽屉
   */
  function onTreeNodeSelect(key) {
    if (key && key.length > 0) {
      selectedKeys.value = key;
    }
    openDataRuleDrawer(true, { functionId: unref(selectedKeys)[0], roleId: unref(roleId) });
  openDataRuleDrawer(true, { functionId: unref(selectedKeys)[0], roleId: unref(roleId) })
}
/**
 * 数据重置
 */
function reset() {
  treeData.value = []
  allTreeKeys.value = []
  checkedKeys.value = []
  defaultCheckedKeys.value = []
  selectedKeys.value = []
  roleId.value = ''
}
/**
 * 获取tree实例
 */
function getTree() {
  const tree = unref(treeRef)
  if (!tree) {
    throw new Error('tree is null!')
  }
  /**
   * 数据重置
   */
  function reset() {
    treeData.value = [];
    allTreeKeys.value = [];
    checkedKeys.value = [];
    defaultCheckedKeys.value = [];
    selectedKeys.value = [];
    roleId.value = '';
  return tree
}
/**
 * 提交
 */
async function handleSubmit(exit) {
  let params = {
    roleId: unref(roleId),
    permissionIds: unref(getTree().getCheckedKeys()).join(','),
    lastpermissionIds: unref(defaultCheckedKeys).join(','),
  }
  /**
   * 获取tree实例
   */
  function getTree() {
    const tree = unref(treeRef);
    if (!tree) {
      throw new Error('tree is null!');
    }
    return tree;
  //update-begin-author:taoyan date:2023-2-11 for: issues/352 VUE角色授权重复保存
  if (loading.value === false) {
    await doSave(params)
  } else {
    console.log('请等待上次执行完毕!')
  }
  /**
   * 提交
   */
  async function handleSubmit(exit) {
    let params = {
      roleId: unref(roleId),
      permissionIds: unref(getTree().getCheckedKeys()).join(','),
      lastpermissionIds: unref(defaultCheckedKeys).join(','),
    };
    //update-begin-author:taoyan date:2023-2-11 for: issues/352 VUE角色授权重复保存
    if(loading.value===false){
      await doSave(params)
    }else{
      console.log('请等待上次执行完毕!');
    }
    if(exit){
      // 如果关闭
      closeDrawer();
    }else{
      // 没有关闭需要重新获取选中数据
      const permResult = await queryRolePermission({ roleId: unref(roleId) });
      defaultCheckedKeys.value = permResult;
    }
  if (exit) {
    // 如果关闭
    closeDrawer()
  } else {
    // 没有关闭需要重新获取选中数据
    const permResult = await queryRolePermission({ roleId: unref(roleId) })
    defaultCheckedKeys.value = permResult
  }
  // VUE角色授权重复保存 #352
  async function doSave(params) {
    loading.value = true;
    await saveRolePermission(params);
    setTimeout(()=>{
      loading.value = false;
    }, 500)
  }
  //update-end-author:taoyan date:2023-2-11 for: issues/352 VUE角色授权重复保存
}
  /**
   * 树菜单选择
   * @param key
   */
  function treeMenuClick({ key }) {
    if (key === 'checkAll') {
      checkedKeys.value = allTreeKeys.value;
    } else if (key === 'cancelCheck') {
      checkedKeys.value = [];
    } else if (key === 'openAll') {
      expandedKeys.value = allTreeKeys.value;
    } else if (key === 'closeAll') {
      expandedKeys.value = [];
    } else if (key === 'relation') {
      checkStrictly.value = false;
    } else {
      checkStrictly.value = true;
    }
// VUE角色授权重复保存 #352
async function doSave(params) {
  loading.value = true
  await saveRolePermission(params)
  setTimeout(() => {
    loading.value = false
  }, 500)
}
//update-end-author:taoyan date:2023-2-11 for: issues/352 VUE角色授权重复保存
/**
 * 树菜单选择
 * @param key
 */
function treeMenuClick({ key }) {
  if (key === 'checkAll') {
    checkedKeys.value = allTreeKeys.value
  } else if (key === 'cancelCheck') {
    checkedKeys.value = []
  } else if (key === 'openAll') {
    expandedKeys.value = allTreeKeys.value
  } else if (key === 'closeAll') {
    expandedKeys.value = []
  } else if (key === 'relation') {
    checkStrictly.value = false
  } else {
    checkStrictly.value = true
  }
}
</script>
<style lang="less" scoped>
  /** 固定操作按钮 */
  .jeecg-basic-tree {
    position: absolute;
    width: 618px;
  }
  //update-begin---author:wangshuai ---date:20230202  for:抽屉弹窗标题图标下拉样式------------
  .line {
    height: 1px;
    width: 100%;
    border-bottom: 1px solid #f0f0f0;
  }
  .more-icon {
    font-size: 20px !important;
    color: black;
    display: inline-flex;
    float: right;
    margin-right: 2px;
    cursor: pointer;
  }
  :deep(.jeecg-tree-header){
    border-bottom: none;
  }
  //update-end---author:wangshuai ---date:20230202  for:抽屉弹窗标题图标下拉样式------------
/** 固定操作按钮 */
.jeecg-basic-tree {
  position: absolute;
  width: 618px;
}
//update-begin---author:wangshuai ---date:20230202  for:抽屉弹窗标题图标下拉样式------------
.line {
  height: 1px;
  width: 100%;
  border-bottom: 1px solid #f0f0f0;
}
.more-icon {
  font-size: 20px !important;
  color: black;
  display: inline-flex;
  float: right;
  margin-right: 2px;
  cursor: pointer;
}
:deep(.jeecg-tree-header) {
  border-bottom: none;
}
//update-end---author:wangshuai ---date:20230202  for:抽屉弹窗标题图标下拉样式------------
</style>