mirror of
https://github.com/WeBankFinTech/fes.js.git
synced 2025-04-06 03:59:53 +08:00
fix: 修复accessApi.setAccess['/403']执行多次问题
This commit is contained in:
parent
270d116dfd
commit
86f5504c11
@ -3,8 +3,6 @@ import createDirective from "./createDirective";
|
||||
import createComponent from "./createComponent";
|
||||
import {isPlainObject} from "{{{ lodashPath }}}";
|
||||
|
||||
const accessKey = Symbol("plugin-access");
|
||||
|
||||
function isPromise(obj) {
|
||||
return (
|
||||
!!obj &&
|
||||
@ -132,14 +130,6 @@ const hasAccess = async (path) => {
|
||||
};
|
||||
|
||||
export const install = (app) => {
|
||||
const allowPageIds = computed(getAllowAccessIds);
|
||||
const useAccess = (path) => {
|
||||
const result = computed(() => {
|
||||
return match(unref(path), allowPageIds.value);
|
||||
});
|
||||
return result;
|
||||
};
|
||||
app.provide(accessKey, useAccess);
|
||||
app.directive("access", createDirective(useAccess));
|
||||
app.component("Access", createComponent(useAccess));
|
||||
};
|
||||
@ -153,6 +143,14 @@ export const access = {
|
||||
getAccess: getAllowAccessIds,
|
||||
};
|
||||
|
||||
export const hasAccessSync = (path) => {
|
||||
return match(unref(path), getAllowAccessIds());
|
||||
}
|
||||
|
||||
export const useAccess = (path) => {
|
||||
return inject(accessKey)(path);
|
||||
const allowPageIds = computed(getAllowAccessIds);
|
||||
const result = computed(() => {
|
||||
return match(unref(path), allowPageIds.value);
|
||||
});
|
||||
return result;
|
||||
};
|
||||
|
@ -1,32 +1,29 @@
|
||||
import { computed, ref } from 'vue';
|
||||
// eslint-disable-next-line
|
||||
import { useAccess } from '../../plugin-access/core';
|
||||
import { hasAccessSync } from '../../plugin-access/core';
|
||||
|
||||
if (!useAccess) {
|
||||
if (!hasAccessSync) {
|
||||
throw new Error('[plugin-layout]: pLugin-layout depends on plugin-access,please install plugin-access first!');
|
||||
}
|
||||
|
||||
export const hasAccessByMenuItem = (item) => {
|
||||
const hasChild = item.children && item.children.length;
|
||||
if (item.path && !hasChild) {
|
||||
return useAccess(item.path);
|
||||
return hasAccessSync(item.path);
|
||||
}
|
||||
if (hasChild) {
|
||||
return computed(() =>
|
||||
item.children.some((child) => {
|
||||
const rst = hasAccessByMenuItem(child);
|
||||
return rst && rst.value;
|
||||
}),
|
||||
);
|
||||
return item.children.some((child) => {
|
||||
const rst = hasAccessByMenuItem(child);
|
||||
return rst;
|
||||
});
|
||||
}
|
||||
return ref(true);
|
||||
return true;
|
||||
};
|
||||
|
||||
export const transform = (menus) =>
|
||||
menus
|
||||
.map((menu) => {
|
||||
const hasAccess = hasAccessByMenuItem(menu);
|
||||
if (!hasAccess.value) {
|
||||
if (!hasAccess) {
|
||||
return false;
|
||||
}
|
||||
if (menu.children) {
|
||||
|
@ -7,10 +7,11 @@ if (!accessApi) {
|
||||
throw new Error('[plugin-layout]: plugin-layout depends on plugin-access,please install plugin-access first!');
|
||||
}
|
||||
|
||||
const accessIds = accessApi.getAccess();
|
||||
accessApi.setAccess(accessIds.concat(['/403', '/404']));
|
||||
|
||||
export const access = (memo) => {
|
||||
const runtimeConfig = getConfig();
|
||||
const accessIds = accessApi.getAccess();
|
||||
accessApi.setAccess(accessIds.concat(['/403', '/404']));
|
||||
return {
|
||||
unAccessHandler({ router, to, from, next }) {
|
||||
if (runtimeConfig.unAccessHandler && typeof runtimeConfig.unAccessHandler === 'function') {
|
||||
|
Loading…
x
Reference in New Issue
Block a user