- 新增产品管理相关路由和页面(dashboard、list、requirement、setting) - 实现产品基础信息编辑弹窗组件(base-info-dialog.vue) - 添加运行时字典功能(dict-select、dict-text、dict-tag组件) - 集成字典管理store和API调用 - 规范ID类型定义为string避免精度丢失问题 - 完善国际化资源文件支持中英文对照 - 新增对象上下文业务域入口页导航实现说明 - 添加Vue DevTools浮动入口注释说明 - 统一权限控制支持全局和对象作用域区分 - 规范分页查询参数类型定义与使用方式
60 lines
1.9 KiB
TypeScript
60 lines
1.9 KiB
TypeScript
import { WEB_SERVICE_PREFIX } from './service';
|
|
|
|
export const OBJECT_CONTEXT_QUERY_KEY = 'objectId' as const;
|
|
|
|
export const objectContextDomainConfigs: App.ObjectContext.DomainConfig[] = [
|
|
{
|
|
domainKey: 'project',
|
|
mode: 'object-context',
|
|
objectType: 'project',
|
|
routePathPrefixes: ['/project'],
|
|
entryRouteKey: 'project_list',
|
|
entryRoutePath: '/project/list',
|
|
fallbackDefaultRouteKey: 'project_dashboard',
|
|
fallbackDefaultRoutePath: '/project/dashboard',
|
|
contextApiPath: `${WEB_SERVICE_PREFIX}/project/context`,
|
|
contextApiObjectIdParamKey: 'projectId',
|
|
contextApiObjectIdPlacement: 'query',
|
|
objectIdQueryKey: OBJECT_CONTEXT_QUERY_KEY
|
|
},
|
|
{
|
|
domainKey: 'product',
|
|
mode: 'object-context',
|
|
objectType: 'product',
|
|
routePathPrefixes: ['/product'],
|
|
entryRouteKey: 'product_list',
|
|
entryRoutePath: '/product/list',
|
|
fallbackDefaultRouteKey: 'product_dashboard',
|
|
fallbackDefaultRoutePath: '/product/dashboard',
|
|
contextApiPath: `${WEB_SERVICE_PREFIX}/project/product/{id}/context`,
|
|
contextApiObjectIdParamKey: 'id',
|
|
contextApiObjectIdPlacement: 'path',
|
|
objectIdQueryKey: OBJECT_CONTEXT_QUERY_KEY
|
|
}
|
|
];
|
|
|
|
function normalizePath(path: string) {
|
|
if (!path) {
|
|
return '/';
|
|
}
|
|
|
|
return path.endsWith('/') && path !== '/' ? path.slice(0, -1) : path;
|
|
}
|
|
|
|
function isPathMatchedByPrefix(path: string, prefix: string) {
|
|
const normalizedPath = normalizePath(path);
|
|
const normalizedPrefix = normalizePath(prefix);
|
|
|
|
return normalizedPath === normalizedPrefix || normalizedPath.startsWith(`${normalizedPrefix}/`);
|
|
}
|
|
|
|
export function getObjectContextDomainConfigByPath(path: string) {
|
|
return objectContextDomainConfigs.find(config =>
|
|
config.routePathPrefixes.some(prefix => isPathMatchedByPrefix(path, prefix))
|
|
);
|
|
}
|
|
|
|
export function isObjectContextEntryPath(path: string, config: App.ObjectContext.DomainConfig) {
|
|
return normalizePath(path) === normalizePath(config.entryRoutePath);
|
|
}
|