- 新增产品管理相关路由和页面(dashboard、list、requirement、setting) - 实现产品基础信息编辑弹窗组件(base-info-dialog.vue) - 添加运行时字典功能(dict-select、dict-text、dict-tag组件) - 集成字典管理store和API调用 - 规范ID类型定义为string避免精度丢失问题 - 完善国际化资源文件支持中英文对照 - 新增对象上下文业务域入口页导航实现说明 - 添加Vue DevTools浮动入口注释说明 - 统一权限控制支持全局和对象作用域区分 - 规范分页查询参数类型定义与使用方式
31 lines
790 B
TypeScript
31 lines
790 B
TypeScript
import { useAuthStore } from '@/store/modules/auth';
|
|
import { useObjectContextStore } from '@/store/modules/object-context';
|
|
|
|
export function useAuth() {
|
|
const authStore = useAuthStore();
|
|
const objectContextStore = useObjectContextStore();
|
|
|
|
function hasAuth(codes: string | string[]) {
|
|
if (!authStore.isLogin) {
|
|
return false;
|
|
}
|
|
|
|
if (typeof codes === 'string') {
|
|
return authStore.userInfo.buttons.includes(codes);
|
|
}
|
|
|
|
return codes.some(code => authStore.userInfo.buttons.includes(code));
|
|
}
|
|
|
|
function hasObjectAuth(codes: string | string[]) {
|
|
const targetCodes = typeof codes === 'string' ? [codes] : codes;
|
|
|
|
return targetCodes.some(code => objectContextStore.buttonCodes.includes(code));
|
|
}
|
|
|
|
return {
|
|
hasAuth,
|
|
hasObjectAuth
|
|
};
|
|
}
|