123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162 |
- <template>
- <el-dialog :title="title" v-model="isShowDialog" width="1100px">
- <div class="mb-4 tr">
- <el-dropdown>
- <el-button plain class="mr-3">
- 操作<el-icon>
- <ele-ArrowDown />
- </el-icon>
- </el-button>
- <template #dropdown>
- <el-dropdown-menu>
- <el-dropdown-item @click.native="checkAll(true)">全部勾选</el-dropdown-item>
- <el-dropdown-item @click.native="checkAll(false)">取消全选</el-dropdown-item>
- <el-dropdown-item @click.native="expand(true)">展开所有</el-dropdown-item>
- <el-dropdown-item @click.native="expand(false)">折叠所有</el-dropdown-item>
- </el-dropdown-menu>
- </template>
- </el-dropdown>
- <el-button :disabled="step <= 0" @click="prev">上一步</el-button>
- <el-button :disabled="step >= 3" @click="next">下一步</el-button>
- <el-button type="primary" :loading="btnLoading" :disabled="step < 3" @click="submit">确定</el-button>
- <el-button @click="cancel">取消</el-button>
- </div>
- <el-steps :active="step" simple>
- <el-step name title="菜单权限" />
- <el-step title="按钮权限" />
- <el-step title="列表权限" />
- <el-step title="接口权限" />
- </el-steps>
- <div class="scroll-part mt-3">
- <el-tree ref="treeRef" :data="treeData" show-checkbox default-expand-all node-key="id" highlight-current :props="defaultProps" check-on-click-node :expand-on-click-node="false" @check-change="checkChange" />
- </div>
- </el-dialog>
- </template>
- <script lang="ts" setup>
- import { ref } from 'vue';
- import api from '/@/api/system';
- import { ElMessage } from 'element-plus';
- const isShowDialog = ref(false);
- const btnLoading = ref(false);
- const step = ref(0);
- const treeRef = ref();
- const title = ref('角色权限设置');
- const roleId = ref(0);
- const treeData = ref([]);
- const menuData = ref([]);
- const buttonData = ref([]);
- const listData = ref([]);
- const apiData = ref([]);
- const menuIds = ref([]);
- const buttonIds = ref([]);
- const columnIds = ref([]);
- const apiIds = ref([]);
- const typeList = ['menu', 'button', 'column', 'api'];
- const idsList = [menuIds, buttonIds, columnIds, apiIds];
- const treeDataList = [menuData, buttonData, listData, apiData];
- const defaultProps = {
- children: 'children',
- label: 'title',
- };
- const openDialog = async (row: any) => {
- title.value = '角色权限设置 - ' + row.name;
- roleId.value = row.id;
- isShowDialog.value = true;
- let res = await api.role.auth.getList(typeList[step.value]);
- // console.log(res);
- treeData.value = res;
- menuData.value = res;
- };
- const cancel = () => {
- isShowDialog.value = false;
- };
- const expand = (expand: boolean) => {
- const nodes = treeRef.value.store.nodesMap;
- for (let i in nodes) {
- nodes[i].expanded = expand;
- }
- };
- const prev = async () => {
- const currentStep = step.value;
- const prevStep = step.value - 1;
- // 获取选中id
- const val = treeRef.value.getCheckedKeys(currentStep === 0 ? false : true);
- idsList[currentStep].value = val;
- treeData.value = treeDataList[prevStep].value;
- treeRef.value.setCheckedKeys(idsList[prevStep].value);
- step.value = prevStep;
- };
- const next = async () => {
- const nextStep = step.value + 1;
- let res = await api.role.auth.getList(typeList[nextStep], menuIds.value);
- // console.log(res);
- treeData.value = res;
- treeDataList[nextStep].value = res;
- treeRef.value.setCheckedKeys(idsList[nextStep].value);
- step.value = nextStep;
- };
- // 选中状态变化
- const checkChange = () => {
- idsList[step.value].value = treeRef.value.getCheckedKeys(step.value === 0 ? false : true);
- };
- // 全选取消全选
- const checkAll = (all: boolean) => {
- if (!all) {
- treeRef.value.setCheckedKeys([]);
- } else {
- const ids = deepTree(treeDataList[step.value].value, []);
- treeRef.value.setCheckedKeys(ids);
- }
- };
- const submit = async () => {
- const data = {
- menuIds: menuIds.value,
- buttonIds: buttonIds.value,
- columnIds: columnIds.value,
- apiIds: apiIds.value,
- roleId: roleId.value,
- };
- // console.log(data);
- btnLoading.value = true;
- api.role.auth
- .set(data)
- .then(() => {
- ElMessage.success('权限设置成功');
- })
- .finally(() => {
- btnLoading.value = false;
- isShowDialog.value = false;
- });
- };
- function deepTree(tree: any[], arr: number[]) {
- for (let item of tree) {
- arr.push(item.id);
- if (item.children?.length) deepTree(item.children, arr);
- }
- return arr;
- }
- // openDialog({ name: '超级管理员', id: 3 });
- defineExpose({ openDialog });
- </script>
- <style scoped lang="scss">
- .scroll-part {
- height: calc(80vh - 200px);
- overflow-x: hidden;
- overflow-y: auto;
- }
- </style>
|