- 新增产品管理相关路由和页面(dashboard、list、requirement、setting) - 实现产品基础信息编辑弹窗组件(base-info-dialog.vue) - 添加运行时字典功能(dict-select、dict-text、dict-tag组件) - 集成字典管理store和API调用 - 规范ID类型定义为string避免精度丢失问题 - 完善国际化资源文件支持中英文对照 - 新增对象上下文业务域入口页导航实现说明 - 添加Vue DevTools浮动入口注释说明 - 统一权限控制支持全局和对象作用域区分 - 规范分页查询参数类型定义与使用方式
47 lines
1.2 KiB
TypeScript
47 lines
1.2 KiB
TypeScript
export type AuthSource = 'global' | 'object' | 'both';
|
|
|
|
export interface AuthDirectiveBindingValue {
|
|
code: string | string[];
|
|
source?: AuthSource;
|
|
}
|
|
|
|
export interface AuthDirectiveCodeSource {
|
|
globalButtonCodes: string[];
|
|
objectButtonCodes: string[];
|
|
}
|
|
|
|
function normalizeCodes(codes: string | string[]) {
|
|
return Array.isArray(codes) ? codes : [codes];
|
|
}
|
|
|
|
function includesAny(sourceCodes: string[], targetCodes: string[]) {
|
|
return targetCodes.some(code => sourceCodes.includes(code));
|
|
}
|
|
|
|
export function resolveAuthVisible(
|
|
bindingValue: string | AuthDirectiveBindingValue,
|
|
codeSource: AuthDirectiveCodeSource
|
|
) {
|
|
const resolvedBinding =
|
|
typeof bindingValue === 'string'
|
|
? {
|
|
code: bindingValue,
|
|
source: 'global' as const
|
|
}
|
|
: bindingValue;
|
|
|
|
const targetCodes = normalizeCodes(resolvedBinding.code);
|
|
const hasGlobal = includesAny(codeSource.globalButtonCodes, targetCodes);
|
|
const hasObject = includesAny(codeSource.objectButtonCodes, targetCodes);
|
|
|
|
if (resolvedBinding.source === 'object') {
|
|
return hasObject;
|
|
}
|
|
|
|
if (resolvedBinding.source === 'both') {
|
|
return hasGlobal || hasObject;
|
|
}
|
|
|
|
return hasGlobal;
|
|
}
|