干燥机配套车间生产管理系统/云平台服务端
baoshiwei
2024-05-27 fa3ac93010bea3805438ee3ab0a182bfbf7423da
src/views/system/role/components/RolePermissionDrawer.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,205 @@
<template>
  <BasicDrawer v-bind="$attrs"
               @register="registerDrawer"
               width="650px"
               destroyOnClose
               showFooter>
    <template #title>
      è§’色权限配置
      <a-dropdown>
        <Icon icon="ant-design:more-outlined" class="more-icon" />
        <template #overlay>
          <a-menu @click="treeMenuClick">
            <a-menu-item key="checkAll">选择全部</a-menu-item>
            <a-menu-item key="cancelCheck">取消选择</a-menu-item>
            <div class="line"></div>
            <a-menu-item key="openAll">展开全部</a-menu-item>
            <a-menu-item key="closeAll">折叠全部</a-menu-item>
            <div class="line"></div>
            <a-menu-item key="relation">层级关联</a-menu-item>
            <a-menu-item key="standAlone">层级独立</a-menu-item>
          </a-menu>
        </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">
      <template #title="{ slotTitle, ruleFlag }">
        {{ slotTitle }}
        <Icon v-if="ruleFlag" icon="ant-design:align-left-outlined" style="margin-left: 5px; color: red"></Icon>
      </template>
    </BasicTree>
    <!--右下角按钮-->
    <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(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)
//展开折叠的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
  }
  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!')
  }
  return tree
}
/**
 * æäº¤
 */
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
  }
}
// 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:抽屉弹窗标题图标下拉样式------------
</style>