@next-core/easyops-runtime 0.1.0 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/auth.js +57 -0
- package/dist/cjs/auth.js.map +1 -0
- package/dist/cjs/checkPermissions.js +101 -0
- package/dist/cjs/checkPermissions.js.map +1 -0
- package/dist/cjs/index.js +14 -8
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/menu/computeMenuData.js +36 -0
- package/dist/cjs/menu/computeMenuData.js.map +1 -0
- package/dist/cjs/menu/constants.js +13 -0
- package/dist/cjs/menu/constants.js.map +1 -0
- package/dist/cjs/menu/fetchMenuById.js +102 -0
- package/dist/cjs/menu/fetchMenuById.js.map +1 -0
- package/dist/cjs/menu/fetchMenuTitle.js +37 -0
- package/dist/cjs/menu/fetchMenuTitle.js.map +1 -0
- package/dist/cjs/menu/getMenusOfStandaloneApp.js +26 -0
- package/dist/cjs/menu/getMenusOfStandaloneApp.js.map +1 -0
- package/dist/cjs/menu/index.js +19 -0
- package/dist/cjs/menu/index.js.map +1 -0
- package/dist/cjs/menu/interfaces.js +4 -0
- package/dist/cjs/menu/interfaces.js.map +1 -0
- package/dist/cjs/menu/loadDynamicMenuItems.js +27 -0
- package/dist/cjs/menu/loadDynamicMenuItems.js.map +1 -0
- package/dist/cjs/menu/mergeMenu.js +73 -0
- package/dist/cjs/menu/mergeMenu.js.map +1 -0
- package/dist/cjs/menu/reorderMenuItems.js +20 -0
- package/dist/cjs/menu/reorderMenuItems.js.map +1 -0
- package/dist/esm/auth.js +47 -0
- package/dist/esm/auth.js.map +1 -0
- package/dist/esm/checkPermissions.js +106 -0
- package/dist/esm/checkPermissions.js.map +1 -0
- package/dist/esm/index.js +11 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/menu/computeMenuData.js +37 -0
- package/dist/esm/menu/computeMenuData.js.map +1 -0
- package/dist/esm/menu/constants.js +4 -0
- package/dist/esm/menu/constants.js.map +1 -0
- package/dist/esm/menu/fetchMenuById.js +104 -0
- package/dist/esm/menu/fetchMenuById.js.map +1 -0
- package/dist/esm/menu/fetchMenuTitle.js +38 -0
- package/dist/esm/menu/fetchMenuTitle.js.map +1 -0
- package/dist/esm/menu/getMenusOfStandaloneApp.js +18 -0
- package/dist/esm/menu/getMenusOfStandaloneApp.js.map +1 -0
- package/dist/esm/menu/index.js +2 -0
- package/dist/esm/menu/index.js.map +1 -0
- package/dist/esm/menu/interfaces.js +8 -0
- package/dist/esm/menu/interfaces.js.map +1 -0
- package/dist/esm/menu/loadDynamicMenuItems.js +27 -0
- package/dist/esm/menu/loadDynamicMenuItems.js.map +1 -0
- package/dist/esm/menu/mergeMenu.js +77 -0
- package/dist/esm/menu/mergeMenu.js.map +1 -0
- package/dist/esm/menu/reorderMenuItems.js +14 -0
- package/dist/esm/menu/reorderMenuItems.js.map +1 -0
- package/dist/types/auth.d.ts +19 -0
- package/dist/types/checkPermissions.d.ts +16 -0
- package/dist/types/index.d.ts +8 -1
- package/dist/types/menu/computeMenuData.d.ts +6 -0
- package/dist/types/menu/constants.d.ts +3 -0
- package/dist/types/menu/fetchMenuById.d.ts +3 -0
- package/dist/types/menu/fetchMenuTitle.d.ts +2 -0
- package/dist/types/menu/getMenusOfStandaloneApp.d.ts +2 -0
- package/dist/types/menu/index.d.ts +1 -0
- package/dist/types/menu/interfaces.d.ts +77 -0
- package/dist/types/menu/loadDynamicMenuItems.d.ts +2 -0
- package/dist/types/menu/mergeMenu.d.ts +2 -0
- package/dist/types/menu/reorderMenuItems.d.ts +2 -0
- package/package.json +5 -4
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mergeMenu.js","names":["_i18n","require","_constants","_loadDynamicMenuItems","mergeMenu","menuList","runtimeContext","helpers","mainMenu","find","menu","type","undefined","validMenuList","injectWithMenus","Map","menuWithI18n","WeakMap","i18n","menuI18nNamespace","menuId","app","appId","instanceId","Object","entries","forEach","lang","resources","addResourceBundle","set","Promise","all","map","loadDynamicMenuItems","_menu$items","items","length","injectMenuGroupId","injectingMenus","get","push","flatMap","processGroupInject","symbolMenuI18nNamespace","symbolOverrideApp","overrideApp","item","_processGroupInject","foundInjectingMenus","groupId","delete","children","concat","injectingMenu","symbolAppId"],"sources":["../../../src/menu/mergeMenu.ts"],"sourcesContent":["import { i18n } from \"@next-core/i18n\";\nimport {\n symbolAppId,\n symbolMenuI18nNamespace,\n symbolOverrideApp,\n} from \"./constants.js\";\nimport type {\n RuntimeContext,\n MenuItemRawData,\n MenuRawData,\n RuntimeMenuItemRawData,\n RuntimeMenuRawData,\n RuntimeHelpers,\n} from \"./interfaces.js\";\nimport { loadDynamicMenuItems } from \"./loadDynamicMenuItems.js\";\n\nexport async function mergeMenu(\n menuList: MenuRawData[],\n runtimeContext: RuntimeContext,\n helpers: RuntimeHelpers\n): Promise<RuntimeMenuRawData | undefined> {\n const mainMenu = menuList.find((menu) => menu.type !== \"inject\");\n if (!mainMenu) {\n return undefined;\n }\n const validMenuList: MenuRawData[] = [];\n const injectWithMenus = new Map<string, MenuRawData[]>();\n const menuWithI18n = new WeakMap<MenuRawData, string>();\n\n for (const menu of menuList) {\n if (menu.i18n) {\n const menuI18nNamespace = `menu/${menu.menuId}~${menu.app[0].appId}+${\n (menu as { instanceId?: string }).instanceId\n }`;\n // Support any language in `menu.i18n`.\n Object.entries(menu.i18n).forEach(([lang, resources]) => {\n i18n.addResourceBundle(lang, menuI18nNamespace, resources);\n });\n menuWithI18n.set(menu, menuI18nNamespace);\n }\n }\n\n await Promise.all(\n menuList.map((menu) =>\n loadDynamicMenuItems(menu, runtimeContext, menuWithI18n, helpers)\n )\n );\n\n for (const menu of menuList) {\n if (menu.items?.length) {\n if (menu.type === \"inject\" && menu.injectMenuGroupId) {\n let injectingMenus = injectWithMenus.get(menu.injectMenuGroupId);\n if (!injectingMenus) {\n injectingMenus = [];\n injectWithMenus.set(menu.injectMenuGroupId, injectingMenus);\n }\n injectingMenus.push(menu);\n } else {\n validMenuList.push(menu);\n }\n }\n }\n\n return {\n ...mainMenu,\n items: validMenuList.flatMap(\n (menu) =>\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n processGroupInject(menu.items, menu, injectWithMenus, menuWithI18n)!\n ),\n [symbolMenuI18nNamespace]: menuWithI18n.get(mainMenu),\n [symbolOverrideApp]: mainMenu.overrideApp,\n };\n}\n\nfunction processGroupInject(\n items: MenuItemRawData[] | undefined,\n menu: MenuRawData,\n injectWithMenus: Map<string, MenuRawData[]>,\n menuWithI18n: WeakMap<MenuRawData, string>\n): RuntimeMenuItemRawData[] | undefined {\n return items?.map((item) => {\n const foundInjectingMenus =\n item.groupId && injectWithMenus.get(item.groupId);\n if (foundInjectingMenus) {\n // Each menu to be injected with should be injected only once.\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n injectWithMenus.delete(item.groupId!);\n }\n return {\n ...item,\n children: (\n processGroupInject(\n item.children,\n menu,\n injectWithMenus,\n menuWithI18n\n ) ?? ([] as RuntimeMenuItemRawData[])\n ).concat(\n foundInjectingMenus\n ? foundInjectingMenus.flatMap(\n (injectingMenu) =>\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n processGroupInject(\n injectingMenu.items,\n injectingMenu,\n injectWithMenus,\n menuWithI18n\n )!\n )\n : ([] as RuntimeMenuItemRawData[])\n ),\n [symbolAppId]: menu.app[0].appId,\n [symbolMenuI18nNamespace]: menuWithI18n.get(menu),\n [symbolOverrideApp]: menu.overrideApp,\n };\n });\n}\n"],"mappings":";;;;;;AAAA,IAAAA,KAAA,GAAAC,OAAA;AACA,IAAAC,UAAA,GAAAD,OAAA;AAaA,IAAAE,qBAAA,GAAAF,OAAA;AAEO,eAAeG,SAASA,CAC7BC,QAAuB,EACvBC,cAA8B,EAC9BC,OAAuB,EACkB;EACzC,MAAMC,QAAQ,GAAGH,QAAQ,CAACI,IAAI,CAAEC,IAAI,IAAKA,IAAI,CAACC,IAAI,KAAK,QAAQ,CAAC;EAChE,IAAI,CAACH,QAAQ,EAAE;IACb,OAAOI,SAAS;EAClB;EACA,MAAMC,aAA4B,GAAG,EAAE;EACvC,MAAMC,eAAe,GAAG,IAAIC,GAAG,EAAyB;EACxD,MAAMC,YAAY,GAAG,IAAIC,OAAO,EAAuB;EAEvD,KAAK,MAAMP,IAAI,IAAIL,QAAQ,EAAE;IAC3B,IAAIK,IAAI,CAACQ,IAAI,EAAE;MACb,MAAMC,iBAAiB,GAAI,QAAOT,IAAI,CAACU,MAAO,IAAGV,IAAI,CAACW,GAAG,CAAC,CAAC,CAAC,CAACC,KAAM,IAChEZ,IAAI,CAA6Ba,UACnC,EAAC;MACF;MACAC,MAAM,CAACC,OAAO,CAACf,IAAI,CAACQ,IAAI,CAAC,CAACQ,OAAO,CAAC,CAAC,CAACC,IAAI,EAAEC,SAAS,CAAC,KAAK;QACvDV,UAAI,CAACW,iBAAiB,CAACF,IAAI,EAAER,iBAAiB,EAAES,SAAS,CAAC;MAC5D,CAAC,CAAC;MACFZ,YAAY,CAACc,GAAG,CAACpB,IAAI,EAAES,iBAAiB,CAAC;IAC3C;EACF;EAEA,MAAMY,OAAO,CAACC,GAAG,CACf3B,QAAQ,CAAC4B,GAAG,CAAEvB,IAAI,IAChB,IAAAwB,0CAAoB,EAACxB,IAAI,EAAEJ,cAAc,EAAEU,YAAY,EAAET,OAAO,CAAC,CAClE,CACF;EAED,KAAK,MAAMG,IAAI,IAAIL,QAAQ,EAAE;IAAA,IAAA8B,WAAA;IAC3B,KAAAA,WAAA,GAAIzB,IAAI,CAAC0B,KAAK,cAAAD,WAAA,eAAVA,WAAA,CAAYE,MAAM,EAAE;MACtB,IAAI3B,IAAI,CAACC,IAAI,KAAK,QAAQ,IAAID,IAAI,CAAC4B,iBAAiB,EAAE;QACpD,IAAIC,cAAc,GAAGzB,eAAe,CAAC0B,GAAG,CAAC9B,IAAI,CAAC4B,iBAAiB,CAAC;QAChE,IAAI,CAACC,cAAc,EAAE;UACnBA,cAAc,GAAG,EAAE;UACnBzB,eAAe,CAACgB,GAAG,CAACpB,IAAI,CAAC4B,iBAAiB,EAAEC,cAAc,CAAC;QAC7D;QACAA,cAAc,CAACE,IAAI,CAAC/B,IAAI,CAAC;MAC3B,CAAC,MAAM;QACLG,aAAa,CAAC4B,IAAI,CAAC/B,IAAI,CAAC;MAC1B;IACF;EACF;EAEA,OAAO;IACL,GAAGF,QAAQ;IACX4B,KAAK,EAAEvB,aAAa,CAAC6B,OAAO,CACzBhC,IAAI;IACH;IACAiC,kBAAkB,CAACjC,IAAI,CAAC0B,KAAK,EAAE1B,IAAI,EAAEI,eAAe,EAAEE,YAAY,CAAE,CACvE;IACD,CAAC4B,kCAAuB,GAAG5B,YAAY,CAACwB,GAAG,CAAChC,QAAQ,CAAC;IACrD,CAACqC,4BAAiB,GAAGrC,QAAQ,CAACsC;EAChC,CAAC;AACH;AAEA,SAASH,kBAAkBA,CACzBP,KAAoC,EACpC1B,IAAiB,EACjBI,eAA2C,EAC3CE,YAA0C,EACJ;EACtC,OAAOoB,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEH,GAAG,CAAEc,IAAI,IAAK;IAAA,IAAAC,mBAAA;IAC1B,MAAMC,mBAAmB,GACvBF,IAAI,CAACG,OAAO,IAAIpC,eAAe,CAAC0B,GAAG,CAACO,IAAI,CAACG,OAAO,CAAC;IACnD,IAAID,mBAAmB,EAAE;MACvB;MACA;MACAnC,eAAe,CAACqC,MAAM,CAACJ,IAAI,CAACG,OAAO,CAAE;IACvC;IACA,OAAO;MACL,GAAGH,IAAI;MACPK,QAAQ,EAAE,EAAAJ,mBAAA,GACRL,kBAAkB,CAChBI,IAAI,CAACK,QAAQ,EACb1C,IAAI,EACJI,eAAe,EACfE,YAAY,CACb,cAAAgC,mBAAA,cAAAA,mBAAA,GAAK,EAAE,EACRK,MAAM,CACNJ,mBAAmB,GACfA,mBAAmB,CAACP,OAAO,CACxBY,aAAa;MACZ;MACAX,kBAAkB,CAChBW,aAAa,CAAClB,KAAK,EACnBkB,aAAa,EACbxC,eAAe,EACfE,YAAY,CACZ,CACL,GACA,EAA+B,CACrC;MACD,CAACuC,sBAAW,GAAG7C,IAAI,CAACW,GAAG,CAAC,CAAC,CAAC,CAACC,KAAK;MAChC,CAACsB,kCAAuB,GAAG5B,YAAY,CAACwB,GAAG,CAAC9B,IAAI,CAAC;MACjD,CAACmC,4BAAiB,GAAGnC,IAAI,CAACoC;IAC5B,CAAC;EACH,CAAC,CAAC;AACJ"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.reorderMenuItems = reorderMenuItems;
|
|
7
|
+
var _lodash = require("lodash");
|
|
8
|
+
function reorderMenuItems(menuData) {
|
|
9
|
+
menuData.items = sortMenuItems(menuData.items).map(item => ({
|
|
10
|
+
...item,
|
|
11
|
+
children: sortMenuItems(item.children)
|
|
12
|
+
}));
|
|
13
|
+
}
|
|
14
|
+
function sortMenuItems(list) {
|
|
15
|
+
return (0, _lodash.sortBy)(list, item => {
|
|
16
|
+
var _item$sort;
|
|
17
|
+
return (_item$sort = item.sort) !== null && _item$sort !== void 0 ? _item$sort : -Infinity;
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=reorderMenuItems.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reorderMenuItems.js","names":["_lodash","require","reorderMenuItems","menuData","items","sortMenuItems","map","item","children","list","sortBy","_item$sort","sort","Infinity"],"sources":["../../../src/menu/reorderMenuItems.ts"],"sourcesContent":["import { sortBy } from \"lodash\";\nimport { MenuItemRawData, MenuRawData } from \"./interfaces.js\";\n\nexport function reorderMenuItems(menuData: MenuRawData): void {\n menuData.items = sortMenuItems(menuData.items).map((item) => ({\n ...item,\n children: sortMenuItems(item.children) as MenuItemRawData[],\n }));\n}\n\nfunction sortMenuItems(list: MenuItemRawData[] | undefined): MenuItemRawData[] {\n return sortBy(list, (item) => item.sort ?? -Infinity);\n}\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AAGO,SAASC,gBAAgBA,CAACC,QAAqB,EAAQ;EAC5DA,QAAQ,CAACC,KAAK,GAAGC,aAAa,CAACF,QAAQ,CAACC,KAAK,CAAC,CAACE,GAAG,CAAEC,IAAI,KAAM;IAC5D,GAAGA,IAAI;IACPC,QAAQ,EAAEH,aAAa,CAACE,IAAI,CAACC,QAAQ;EACvC,CAAC,CAAC,CAAC;AACL;AAEA,SAASH,aAAaA,CAACI,IAAmC,EAAqB;EAC7E,OAAO,IAAAC,cAAM,EAACD,IAAI,EAAGF,IAAI;IAAA,IAAAI,UAAA;IAAA,QAAAA,UAAA,GAAKJ,IAAI,CAACK,IAAI,cAAAD,UAAA,cAAAA,UAAA,GAAI,CAACE,QAAQ;EAAA,EAAC;AACvD"}
|
package/dist/esm/auth.js
ADDED
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
|
|
2
|
+
import { resetPermissionPreChecks } from "./checkPermissions.js";
|
|
3
|
+
var auth = {};
|
|
4
|
+
|
|
5
|
+
/** @internal */
|
|
6
|
+
|
|
7
|
+
/** @internal */
|
|
8
|
+
export function authenticate(newAuth) {
|
|
9
|
+
Object.assign(auth, {
|
|
10
|
+
org: newAuth.org,
|
|
11
|
+
username: newAuth.username,
|
|
12
|
+
userInstanceId: newAuth.userInstanceId,
|
|
13
|
+
loginFrom: newAuth.loginFrom,
|
|
14
|
+
accessRule: newAuth.accessRule,
|
|
15
|
+
isAdmin: newAuth.isAdmin,
|
|
16
|
+
csrfToken: newAuth.csrfToken,
|
|
17
|
+
license: newAuth.license,
|
|
18
|
+
userShowValue: newAuth.userShowValue
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* 获取当前登录认证信息。
|
|
24
|
+
*
|
|
25
|
+
* @returns 当前登录认证信息。
|
|
26
|
+
*/
|
|
27
|
+
export function getAuth() {
|
|
28
|
+
return _objectSpread({}, auth);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
/** @internal */
|
|
32
|
+
export function logout() {
|
|
33
|
+
for (var key of Object.keys(auth)) {
|
|
34
|
+
auth[key] = undefined;
|
|
35
|
+
}
|
|
36
|
+
resetPermissionPreChecks();
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* 查看当前是否已登录。
|
|
41
|
+
*
|
|
42
|
+
* @returns 当前是否已登录。
|
|
43
|
+
*/
|
|
44
|
+
export function isLoggedIn() {
|
|
45
|
+
return auth.username !== undefined;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.js","names":["resetPermissionPreChecks","auth","authenticate","newAuth","Object","assign","org","username","userInstanceId","loginFrom","accessRule","isAdmin","csrfToken","license","userShowValue","getAuth","_objectSpread","logout","key","keys","undefined","isLoggedIn"],"sources":["../../src/auth.ts"],"sourcesContent":["import type { AuthApi_CheckLoginResponseBody } from \"@next-api-sdk/api-gateway-sdk\";\nimport { resetPermissionPreChecks } from \"./checkPermissions.js\";\n\nconst auth: AuthInfo = {};\n\n/** @internal */\nexport type AuthInfo = Omit<AuthApi_CheckLoginResponseBody, \"loggedIn\">;\n\n/** @internal */\nexport function authenticate(newAuth: AuthInfo): void {\n Object.assign(auth, {\n org: newAuth.org,\n username: newAuth.username,\n userInstanceId: newAuth.userInstanceId,\n loginFrom: newAuth.loginFrom,\n accessRule: newAuth.accessRule,\n isAdmin: newAuth.isAdmin,\n csrfToken: newAuth.csrfToken,\n license: newAuth.license,\n userShowValue: newAuth.userShowValue,\n });\n}\n\n/**\n * 获取当前登录认证信息。\n *\n * @returns 当前登录认证信息。\n */\nexport function getAuth(): AuthInfo {\n return {\n ...auth,\n };\n}\n\n/** @internal */\nexport function logout(): void {\n for (const key of Object.keys(auth) as (keyof AuthInfo)[]) {\n auth[key] = undefined;\n }\n resetPermissionPreChecks();\n}\n\n/**\n * 查看当前是否已登录。\n *\n * @returns 当前是否已登录。\n */\nexport function isLoggedIn(): boolean {\n return auth.username !== undefined;\n}\n"],"mappings":";AACA,SAASA,wBAAwB,QAAQ,uBAAuB;AAEhE,IAAMC,IAAc,GAAG,CAAC,CAAC;;AAEzB;;AAGA;AACA,OAAO,SAASC,YAAYA,CAACC,OAAiB,EAAQ;EACpDC,MAAM,CAACC,MAAM,CAACJ,IAAI,EAAE;IAClBK,GAAG,EAAEH,OAAO,CAACG,GAAG;IAChBC,QAAQ,EAAEJ,OAAO,CAACI,QAAQ;IAC1BC,cAAc,EAAEL,OAAO,CAACK,cAAc;IACtCC,SAAS,EAAEN,OAAO,CAACM,SAAS;IAC5BC,UAAU,EAAEP,OAAO,CAACO,UAAU;IAC9BC,OAAO,EAAER,OAAO,CAACQ,OAAO;IACxBC,SAAS,EAAET,OAAO,CAACS,SAAS;IAC5BC,OAAO,EAAEV,OAAO,CAACU,OAAO;IACxBC,aAAa,EAAEX,OAAO,CAACW;EACzB,CAAC,CAAC;AACJ;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,OAAOA,CAAA,EAAa;EAClC,OAAAC,aAAA,KACKf,IAAI;AAEX;;AAEA;AACA,OAAO,SAASgB,MAAMA,CAAA,EAAS;EAC7B,KAAK,IAAMC,GAAG,IAAId,MAAM,CAACe,IAAI,CAAClB,IAAI,CAAC,EAAwB;IACzDA,IAAI,CAACiB,GAAG,CAAC,GAAGE,SAAS;EACvB;EACApB,wBAAwB,EAAE;AAC5B;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASqB,UAAUA,CAAA,EAAY;EACpC,OAAOpB,IAAI,CAACM,QAAQ,KAAKa,SAAS;AACpC"}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
2
|
+
import { difference } from "lodash";
|
|
3
|
+
import { scanPermissionActionsInAny, scanPermissionActionsInStoryboard } from "@next-core/utils/storyboard";
|
|
4
|
+
import { PermissionApi_validatePermissions } from "@next-api-sdk/micro-app-sdk";
|
|
5
|
+
import { getAuth, isLoggedIn } from "./auth.js";
|
|
6
|
+
var checkedPermissions = [];
|
|
7
|
+
var permissionMap = new Map();
|
|
8
|
+
export function preCheckPermissions(storyboard) {
|
|
9
|
+
if (isLoggedIn() && !getAuth().isAdmin) {
|
|
10
|
+
var usedActions = scanPermissionActionsInStoryboard(storyboard);
|
|
11
|
+
return validatePermissions(usedActions);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export function preCheckPermissionsForBrickOrRoute(_x, _x2) {
|
|
15
|
+
return _preCheckPermissionsForBrickOrRoute.apply(this, arguments);
|
|
16
|
+
}
|
|
17
|
+
function _preCheckPermissionsForBrickOrRoute() {
|
|
18
|
+
_preCheckPermissionsForBrickOrRoute = _asyncToGenerator(function* (container, asyncComputeRealValue) {
|
|
19
|
+
if (isLoggedIn() && !getAuth().isAdmin && Array.isArray(container.permissionsPreCheck)) {
|
|
20
|
+
var actions = yield asyncComputeRealValue(container.permissionsPreCheck);
|
|
21
|
+
return validatePermissions(actions);
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
return _preCheckPermissionsForBrickOrRoute.apply(this, arguments);
|
|
25
|
+
}
|
|
26
|
+
export function preCheckPermissionsForAny(data) {
|
|
27
|
+
if (isLoggedIn() && !getAuth().isAdmin) {
|
|
28
|
+
var usedActions = scanPermissionActionsInAny(data);
|
|
29
|
+
return validatePermissions(usedActions);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
export function validatePermissions(_x3) {
|
|
33
|
+
return _validatePermissions.apply(this, arguments);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* Check the current logged-in user whether to have all
|
|
38
|
+
* permissions of actions passed to it.
|
|
39
|
+
*
|
|
40
|
+
* @param actions - Required permission actions.
|
|
41
|
+
*/
|
|
42
|
+
function _validatePermissions() {
|
|
43
|
+
_validatePermissions = _asyncToGenerator(function* (usedActions) {
|
|
44
|
+
// Do not request known actions.
|
|
45
|
+
var actions = difference(usedActions, [...checkedPermissions]);
|
|
46
|
+
if (actions.length === 0) {
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
checkedPermissions.push(...actions);
|
|
50
|
+
try {
|
|
51
|
+
var result = yield PermissionApi_validatePermissions({
|
|
52
|
+
actions
|
|
53
|
+
});
|
|
54
|
+
for (var item of result.actions) {
|
|
55
|
+
permissionMap.set(item.action, item.authorizationStatus);
|
|
56
|
+
if (item.authorizationStatus === "undefined") {
|
|
57
|
+
// eslint-disable-next-line no-console
|
|
58
|
+
console.error("Undefined permission action: \"".concat(item.action, "\""));
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
} catch (error) {
|
|
62
|
+
// Allow pre-check to fail, and
|
|
63
|
+
// make it not crash when the backend service is not updated.
|
|
64
|
+
// eslint-disable-next-line no-console
|
|
65
|
+
console.error("Pre-check permissions failed", error);
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
return _validatePermissions.apply(this, arguments);
|
|
69
|
+
}
|
|
70
|
+
export function checkPermissions() {
|
|
71
|
+
if (!isLoggedIn()) {
|
|
72
|
+
return false;
|
|
73
|
+
}
|
|
74
|
+
if (getAuth().isAdmin) {
|
|
75
|
+
return true;
|
|
76
|
+
}
|
|
77
|
+
for (var _len = arguments.length, actions = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
78
|
+
actions[_key] = arguments[_key];
|
|
79
|
+
}
|
|
80
|
+
for (var action of actions) {
|
|
81
|
+
// Only **exclusively authorized** permissions are ok.
|
|
82
|
+
// Those scenarios below will fail:
|
|
83
|
+
// - unauthorized actions (pre-check results)
|
|
84
|
+
// - undefined actions (pre-check results)
|
|
85
|
+
// - Un-pre-checked or pre-check failed
|
|
86
|
+
switch (permissionMap.get(action)) {
|
|
87
|
+
case "unauthorized":
|
|
88
|
+
case "undefined":
|
|
89
|
+
return false;
|
|
90
|
+
case undefined:
|
|
91
|
+
// eslint-disable-next-line no-console
|
|
92
|
+
console.error("Un-checked permission action: \"".concat(action, "\", please make sure the permission to check is defined in permissionsPreCheck."));
|
|
93
|
+
return false;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
return true;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
/**
|
|
100
|
+
* Reset permission pre-checks after logged-out.
|
|
101
|
+
*/
|
|
102
|
+
export function resetPermissionPreChecks() {
|
|
103
|
+
checkedPermissions.length = 0;
|
|
104
|
+
permissionMap.clear();
|
|
105
|
+
}
|
|
106
|
+
//# sourceMappingURL=checkPermissions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkPermissions.js","names":["difference","scanPermissionActionsInAny","scanPermissionActionsInStoryboard","PermissionApi_validatePermissions","getAuth","isLoggedIn","checkedPermissions","permissionMap","Map","preCheckPermissions","storyboard","isAdmin","usedActions","validatePermissions","preCheckPermissionsForBrickOrRoute","_x","_x2","_preCheckPermissionsForBrickOrRoute","apply","arguments","_asyncToGenerator","container","asyncComputeRealValue","Array","isArray","permissionsPreCheck","actions","preCheckPermissionsForAny","data","_x3","_validatePermissions","length","push","result","item","set","action","authorizationStatus","console","error","concat","checkPermissions","_len","_key","get","undefined","resetPermissionPreChecks","clear"],"sources":["../../src/checkPermissions.ts"],"sourcesContent":["import { difference } from \"lodash\";\nimport {\n scanPermissionActionsInAny,\n scanPermissionActionsInStoryboard,\n} from \"@next-core/utils/storyboard\";\nimport type { BrickConf, RouteConf, Storyboard } from \"@next-core/types\";\nimport { PermissionApi_validatePermissions } from \"@next-api-sdk/micro-app-sdk\";\nimport { getAuth, isLoggedIn } from \"./auth.js\";\n\ntype PermissionStatus = \"authorized\" | \"unauthorized\" | \"undefined\";\n\nconst checkedPermissions: string[] = [];\nconst permissionMap = new Map<string, PermissionStatus>();\n\nexport function preCheckPermissions(\n storyboard: Storyboard\n): Promise<void> | undefined {\n if (isLoggedIn() && !getAuth().isAdmin) {\n const usedActions = scanPermissionActionsInStoryboard(storyboard);\n return validatePermissions(usedActions);\n }\n}\n\nexport async function preCheckPermissionsForBrickOrRoute(\n container: BrickConf | RouteConf,\n asyncComputeRealValue: (value: unknown) => Promise<unknown>\n) {\n if (\n isLoggedIn() &&\n !getAuth().isAdmin &&\n Array.isArray(container.permissionsPreCheck)\n ) {\n const actions = (await asyncComputeRealValue(\n container.permissionsPreCheck\n )) as string[];\n return validatePermissions(actions);\n }\n}\n\nexport function preCheckPermissionsForAny(\n data: unknown\n): Promise<void> | undefined {\n if (isLoggedIn() && !getAuth().isAdmin) {\n const usedActions = scanPermissionActionsInAny(data);\n return validatePermissions(usedActions);\n }\n}\n\nexport async function validatePermissions(\n usedActions: string[]\n): Promise<void> {\n // Do not request known actions.\n const actions = difference(usedActions, [...checkedPermissions]);\n if (actions.length === 0) {\n return;\n }\n checkedPermissions.push(...actions);\n try {\n const result = await PermissionApi_validatePermissions({ actions });\n for (const item of result.actions!) {\n permissionMap.set(item.action!, item.authorizationStatus!);\n if (item.authorizationStatus === \"undefined\") {\n // eslint-disable-next-line no-console\n console.error(`Undefined permission action: \"${item.action}\"`);\n }\n }\n } catch (error) {\n // Allow pre-check to fail, and\n // make it not crash when the backend service is not updated.\n // eslint-disable-next-line no-console\n console.error(\"Pre-check permissions failed\", error);\n }\n}\n\n/**\n * Check the current logged-in user whether to have all\n * permissions of actions passed to it.\n *\n * @param actions - Required permission actions.\n */\nexport function checkPermissions(...actions: string[]): boolean {\n if (!isLoggedIn()) {\n return false;\n }\n\n if (getAuth().isAdmin) {\n return true;\n }\n\n for (const action of actions) {\n // Only **exclusively authorized** permissions are ok.\n // Those scenarios below will fail:\n // - unauthorized actions (pre-check results)\n // - undefined actions (pre-check results)\n // - Un-pre-checked or pre-check failed\n switch (permissionMap.get(action)) {\n case \"unauthorized\":\n case \"undefined\":\n return false;\n case undefined:\n // eslint-disable-next-line no-console\n console.error(\n `Un-checked permission action: \"${action}\", please make sure the permission to check is defined in permissionsPreCheck.`\n );\n return false;\n }\n }\n return true;\n}\n\n/**\n * Reset permission pre-checks after logged-out.\n */\nexport function resetPermissionPreChecks(): void {\n checkedPermissions.length = 0;\n permissionMap.clear();\n}\n"],"mappings":"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"}
|
package/dist/esm/index.js
CHANGED
|
@@ -1,6 +1,16 @@
|
|
|
1
|
-
|
|
1
|
+
// istanbul ignore file
|
|
2
|
+
import { checkPermissions as _checkPermissions, preCheckPermissions, preCheckPermissionsForBrickOrRoute } from "./checkPermissions.js";
|
|
2
3
|
import * as _checkInstalledApps from "./checkInstalledApps.js";
|
|
3
4
|
export { _checkInstalledApps as checkInstalledApps };
|
|
4
5
|
import * as _flowApi from "./flowApi/index.js";
|
|
5
6
|
export { _flowApi as flowApi };
|
|
7
|
+
import * as _auth from "./auth.js";
|
|
8
|
+
export { _auth as auth };
|
|
9
|
+
import * as _menu from "./menu/index.js";
|
|
10
|
+
export { _menu as menu };
|
|
11
|
+
export var checkPermissions = Object.freeze({
|
|
12
|
+
checkPermissions: _checkPermissions,
|
|
13
|
+
preCheckPermissions,
|
|
14
|
+
preCheckPermissionsForBrickOrRoute
|
|
15
|
+
});
|
|
6
16
|
//# sourceMappingURL=index.js.map
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["
|
|
1
|
+
{"version":3,"file":"index.js","names":["checkPermissions","_checkPermissions","preCheckPermissions","preCheckPermissionsForBrickOrRoute","_checkInstalledApps","checkInstalledApps","_flowApi","flowApi","_auth","auth","_menu","menu","Object","freeze"],"sources":["../../src/index.ts"],"sourcesContent":["// istanbul ignore file\nimport {\n checkPermissions as _checkPermissions,\n preCheckPermissions,\n preCheckPermissionsForBrickOrRoute,\n} from \"./checkPermissions.js\";\n\nexport * as checkInstalledApps from \"./checkInstalledApps.js\";\nexport * as flowApi from \"./flowApi/index.js\";\nexport * as auth from \"./auth.js\";\nexport * as menu from \"./menu/index.js\";\n\nexport const checkPermissions = Object.freeze({\n checkPermissions: _checkPermissions,\n preCheckPermissions,\n preCheckPermissionsForBrickOrRoute,\n});\n"],"mappings":"AAAA;AACA,SACEA,gBAAgB,IAAIC,iBAAiB,EACrCC,mBAAmB,EACnBC,kCAAkC,QAC7B,uBAAuB;AAAC,YAAAC,mBAAA,MAEK,yBAAyB;AAAA,SAAAA,mBAAA,IAAjDC,kBAAkB;AAAA,YAAAC,QAAA,MACL,oBAAoB;AAAA,SAAAA,QAAA,IAAjCC,OAAO;AAAA,YAAAC,KAAA,MACG,WAAW;AAAA,SAAAA,KAAA,IAArBC,IAAI;AAAA,YAAAC,KAAA,MACM,iBAAiB;AAAA,SAAAA,KAAA,IAA3BC,IAAI;AAEhB,OAAO,IAAMX,gBAAgB,GAAGY,MAAM,CAACC,MAAM,CAAC;EAC5Cb,gBAAgB,EAAEC,iBAAiB;EACnCC,mBAAmB;EACnBC;AACF,CAAC,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
|
|
2
|
+
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
3
|
+
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
|
|
4
|
+
var _excluded = ["children"];
|
|
5
|
+
import { symbolAppId, symbolMenuI18nNamespace, symbolOverrideApp } from "./constants.js";
|
|
6
|
+
export function computeMenuData(data, overrideAppId, runtimeContext, helpers) {
|
|
7
|
+
var newRuntimeContext = runtimeContext;
|
|
8
|
+
if (overrideAppId !== runtimeContext.app.id) {
|
|
9
|
+
var _helpers$getStoryboar;
|
|
10
|
+
var overrideApp = window.STANDALONE_MICRO_APPS ? data[symbolOverrideApp] : (_helpers$getStoryboar = helpers.getStoryboardByAppId(overrideAppId)) === null || _helpers$getStoryboar === void 0 ? void 0 : _helpers$getStoryboar.app;
|
|
11
|
+
newRuntimeContext = _objectSpread(_objectSpread({}, runtimeContext), {}, {
|
|
12
|
+
overrideApp,
|
|
13
|
+
appendI18nNamespace: data[symbolMenuI18nNamespace]
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
return helpers.asyncComputeRealValue(data, newRuntimeContext, {
|
|
17
|
+
ignoreSymbols: true
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
export function computeMenuItems(items, runtimeContext, helpers) {
|
|
21
|
+
return Promise.all(items.map( /*#__PURE__*/function () {
|
|
22
|
+
var _ref2 = _asyncToGenerator(function* (_ref) {
|
|
23
|
+
var {
|
|
24
|
+
children
|
|
25
|
+
} = _ref,
|
|
26
|
+
rest = _objectWithoutProperties(_ref, _excluded);
|
|
27
|
+
var [computedRest, computedChildren] = yield Promise.all([computeMenuData(rest, rest[symbolAppId], runtimeContext, helpers), children && (yield computeMenuItems(children, runtimeContext, helpers))]);
|
|
28
|
+
return _objectSpread(_objectSpread({}, computedRest), {}, {
|
|
29
|
+
children: computedChildren
|
|
30
|
+
});
|
|
31
|
+
});
|
|
32
|
+
return function (_x) {
|
|
33
|
+
return _ref2.apply(this, arguments);
|
|
34
|
+
};
|
|
35
|
+
}()));
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=computeMenuData.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"computeMenuData.js","names":["symbolAppId","symbolMenuI18nNamespace","symbolOverrideApp","computeMenuData","data","overrideAppId","runtimeContext","helpers","newRuntimeContext","app","id","_helpers$getStoryboar","overrideApp","window","STANDALONE_MICRO_APPS","getStoryboardByAppId","_objectSpread","appendI18nNamespace","asyncComputeRealValue","ignoreSymbols","computeMenuItems","items","Promise","all","map","_ref2","_asyncToGenerator","_ref","children","rest","_objectWithoutProperties","_excluded","computedRest","computedChildren","_x","apply","arguments"],"sources":["../../../src/menu/computeMenuData.ts"],"sourcesContent":["import type {\n RuntimeContext,\n RuntimeHelpers,\n RuntimeMenuItemRawData,\n RuntimeMenuRawData,\n} from \"./interfaces.js\";\nimport {\n symbolAppId,\n symbolMenuI18nNamespace,\n symbolOverrideApp,\n} from \"./constants.js\";\n\ntype RuntimeMenuRestRawData = Omit<RuntimeMenuRawData, \"app\" | \"items\">;\ntype RuntimeMenuItemRestRawData = Omit<RuntimeMenuItemRawData, \"children\">;\n\nexport function computeMenuData<\n T extends RuntimeMenuRestRawData | RuntimeMenuItemRestRawData\n>(\n data: T,\n overrideAppId: string,\n runtimeContext: RuntimeContext,\n helpers: RuntimeHelpers\n): Promise<T> {\n let newRuntimeContext = runtimeContext;\n if (overrideAppId !== runtimeContext.app.id) {\n const overrideApp = window.STANDALONE_MICRO_APPS\n ? data[symbolOverrideApp]\n : helpers.getStoryboardByAppId(overrideAppId)?.app;\n newRuntimeContext = {\n ...runtimeContext,\n overrideApp,\n appendI18nNamespace: data[symbolMenuI18nNamespace],\n };\n }\n return helpers.asyncComputeRealValue(data, newRuntimeContext, {\n ignoreSymbols: true,\n }) as Promise<T>;\n}\n\nexport function computeMenuItems(\n items: RuntimeMenuItemRawData[],\n runtimeContext: RuntimeContext,\n helpers: RuntimeHelpers\n): Promise<RuntimeMenuItemRawData[]> {\n return Promise.all(\n items.map(async ({ children, ...rest }) => {\n const [computedRest, computedChildren] = await Promise.all([\n computeMenuData(rest, rest[symbolAppId], runtimeContext, helpers),\n children && (await computeMenuItems(children, runtimeContext, helpers)),\n ]);\n return {\n ...computedRest,\n children: computedChildren,\n };\n })\n );\n}\n"],"mappings":";;;;AAMA,SACEA,WAAW,EACXC,uBAAuB,EACvBC,iBAAiB,QACZ,gBAAgB;AAKvB,OAAO,SAASC,eAAeA,CAG7BC,IAAO,EACPC,aAAqB,EACrBC,cAA8B,EAC9BC,OAAuB,EACX;EACZ,IAAIC,iBAAiB,GAAGF,cAAc;EACtC,IAAID,aAAa,KAAKC,cAAc,CAACG,GAAG,CAACC,EAAE,EAAE;IAAA,IAAAC,qBAAA;IAC3C,IAAMC,WAAW,GAAGC,MAAM,CAACC,qBAAqB,GAC5CV,IAAI,CAACF,iBAAiB,CAAC,IAAAS,qBAAA,GACvBJ,OAAO,CAACQ,oBAAoB,CAACV,aAAa,CAAC,cAAAM,qBAAA,uBAA3CA,qBAAA,CAA6CF,GAAG;IACpDD,iBAAiB,GAAAQ,aAAA,CAAAA,aAAA,KACZV,cAAc;MACjBM,WAAW;MACXK,mBAAmB,EAAEb,IAAI,CAACH,uBAAuB;IAAC,EACnD;EACH;EACA,OAAOM,OAAO,CAACW,qBAAqB,CAACd,IAAI,EAAEI,iBAAiB,EAAE;IAC5DW,aAAa,EAAE;EACjB,CAAC,CAAC;AACJ;AAEA,OAAO,SAASC,gBAAgBA,CAC9BC,KAA+B,EAC/Bf,cAA8B,EAC9BC,OAAuB,EACY;EACnC,OAAOe,OAAO,CAACC,GAAG,CAChBF,KAAK,CAACG,GAAG;IAAA,IAAAC,KAAA,GAAAC,iBAAA,CAAC,WAAAC,IAAA,EAAiC;MAAA,IAA1B;UAAEC;QAAkB,CAAC,GAAAD,IAAA;QAANE,IAAI,GAAAC,wBAAA,CAAAH,IAAA,EAAAI,SAAA;MAClC,IAAM,CAACC,YAAY,EAAEC,gBAAgB,CAAC,SAASX,OAAO,CAACC,GAAG,CAAC,CACzDpB,eAAe,CAAC0B,IAAI,EAAEA,IAAI,CAAC7B,WAAW,CAAC,EAAEM,cAAc,EAAEC,OAAO,CAAC,EACjEqB,QAAQ,WAAWR,gBAAgB,CAACQ,QAAQ,EAAEtB,cAAc,EAAEC,OAAO,CAAC,CAAC,CACxE,CAAC;MACF,OAAAS,aAAA,CAAAA,aAAA,KACKgB,YAAY;QACfJ,QAAQ,EAAEK;MAAgB;IAE9B,CAAC;IAAA,iBAAAC,EAAA;MAAA,OAAAT,KAAA,CAAAU,KAAA,OAAAC,SAAA;IAAA;EAAA,IAAC,CACH;AACH"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","names":["symbolAppId","Symbol","symbolMenuI18nNamespace","symbolOverrideApp"],"sources":["../../../src/menu/constants.ts"],"sourcesContent":["export const symbolAppId = Symbol(\"appId\");\nexport const symbolMenuI18nNamespace = Symbol(\"menuI18nNamespace\");\nexport const symbolOverrideApp = Symbol(\"overrideApp\");\n"],"mappings":"AAAA,OAAO,IAAMA,WAAW,GAAGC,MAAM,CAAC,OAAO,CAAC;AAC1C,OAAO,IAAMC,uBAAuB,GAAGD,MAAM,CAAC,mBAAmB,CAAC;AAClE,OAAO,IAAME,iBAAiB,GAAGF,MAAM,CAAC,aAAa,CAAC"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
|
|
2
|
+
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
|
|
3
|
+
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
4
|
+
var _excluded = ["items", "app"];
|
|
5
|
+
import { InstanceApi_postSearch } from "@next-api-sdk/cmdb-sdk";
|
|
6
|
+
import { pick } from "lodash";
|
|
7
|
+
import { checkIfOfComputed } from "@next-core/runtime";
|
|
8
|
+
import { mergeMenu } from "./mergeMenu.js";
|
|
9
|
+
import { reorderMenuItems } from "./reorderMenuItems.js";
|
|
10
|
+
import { computeMenuItems, computeMenuData } from "./computeMenuData.js";
|
|
11
|
+
import { fetchMenuTitle } from "./fetchMenuTitle.js";
|
|
12
|
+
import { getMenusOfStandaloneApp } from "./getMenusOfStandaloneApp.js";
|
|
13
|
+
import { preCheckPermissionsForAny } from "../checkPermissions.js";
|
|
14
|
+
var menuPromises = new Map();
|
|
15
|
+
var menuCache = new Map();
|
|
16
|
+
export function getMenuById(menuId) {
|
|
17
|
+
return menuCache.get(menuId);
|
|
18
|
+
}
|
|
19
|
+
export function fetchMenuById(menuId, runtimeContext, helpers) {
|
|
20
|
+
var promise = menuPromises.get(menuId);
|
|
21
|
+
if (!promise) {
|
|
22
|
+
promise = _fetchMenuById(menuId, runtimeContext, helpers);
|
|
23
|
+
}
|
|
24
|
+
return promise;
|
|
25
|
+
}
|
|
26
|
+
function _fetchMenuById(_x, _x2, _x3) {
|
|
27
|
+
return _fetchMenuById2.apply(this, arguments);
|
|
28
|
+
}
|
|
29
|
+
function _fetchMenuById2() {
|
|
30
|
+
_fetchMenuById2 = _asyncToGenerator(function* (menuId, runtimeContext, helpers) {
|
|
31
|
+
var menuList = window.STANDALONE_MICRO_APPS ? getMenusOfStandaloneApp(menuId, runtimeContext.app.id, helpers) : (yield InstanceApi_postSearch("EASYOPS_STORYBOARD_MENU", {
|
|
32
|
+
page: 1,
|
|
33
|
+
page_size: 200,
|
|
34
|
+
fields: {
|
|
35
|
+
menuId: true,
|
|
36
|
+
title: true,
|
|
37
|
+
icon: true,
|
|
38
|
+
link: true,
|
|
39
|
+
titleDataSource: true,
|
|
40
|
+
defaultCollapsed: true,
|
|
41
|
+
defaultCollapsedBreakpoint: true,
|
|
42
|
+
type: true,
|
|
43
|
+
injectMenuGroupId: true,
|
|
44
|
+
dynamicItems: true,
|
|
45
|
+
itemsResolve: true,
|
|
46
|
+
items: true,
|
|
47
|
+
i18n: true,
|
|
48
|
+
"items.children": true,
|
|
49
|
+
"app.appId": true
|
|
50
|
+
},
|
|
51
|
+
query: {
|
|
52
|
+
menuId: {
|
|
53
|
+
$eq: menuId
|
|
54
|
+
},
|
|
55
|
+
app: {
|
|
56
|
+
$size: {
|
|
57
|
+
$gt: 0
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
})).list;
|
|
62
|
+
var menuData = yield mergeMenu(menuList, runtimeContext, helpers);
|
|
63
|
+
if (!menuData) {
|
|
64
|
+
throw new Error("Menu not found: ".concat(menuId));
|
|
65
|
+
}
|
|
66
|
+
reorderMenuItems(menuData);
|
|
67
|
+
var {
|
|
68
|
+
items,
|
|
69
|
+
app
|
|
70
|
+
} = menuData,
|
|
71
|
+
restMenuData = _objectWithoutProperties(menuData, _excluded);
|
|
72
|
+
var newRuntimeContext = _objectSpread(_objectSpread({}, runtimeContext), {}, {
|
|
73
|
+
pendingPermissionsPreCheck: [...runtimeContext.pendingPermissionsPreCheck, preCheckPermissionsForAny([items, restMenuData])]
|
|
74
|
+
});
|
|
75
|
+
delete newRuntimeContext.tplStateStoreId;
|
|
76
|
+
delete newRuntimeContext.forEachItem;
|
|
77
|
+
var rootAppId = app[0].appId;
|
|
78
|
+
var [computedMenuData, computedMenuItems] = yield Promise.all([computeMenuData(restMenuData, rootAppId, newRuntimeContext, helpers), computeMenuItems(items, newRuntimeContext, helpers)]);
|
|
79
|
+
var finalMenuData = _objectSpread(_objectSpread({
|
|
80
|
+
title: yield fetchMenuTitle(computedMenuData)
|
|
81
|
+
}, pick(computedMenuData, ["icon", "link", "defaultCollapsed", "defaultCollapsedBreakpoint"])), {}, {
|
|
82
|
+
menuItems: computedMenuItems.filter(checkIfOfComputed).map(item => {
|
|
83
|
+
var _item$children;
|
|
84
|
+
var children = (_item$children = item.children) === null || _item$children === void 0 ? void 0 : _item$children.filter(checkIfOfComputed);
|
|
85
|
+
return item.type === "group" ? {
|
|
86
|
+
type: "group",
|
|
87
|
+
title: item.text,
|
|
88
|
+
items: children
|
|
89
|
+
} : children !== null && children !== void 0 && children.length ? {
|
|
90
|
+
type: "subMenu",
|
|
91
|
+
title: item.text,
|
|
92
|
+
icon: item.icon,
|
|
93
|
+
items: children,
|
|
94
|
+
defaultExpanded: item.defaultExpanded
|
|
95
|
+
} : item;
|
|
96
|
+
})
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
// Todo(steve): reconsider the menu cache strategy
|
|
100
|
+
menuCache.set(menuId, finalMenuData);
|
|
101
|
+
});
|
|
102
|
+
return _fetchMenuById2.apply(this, arguments);
|
|
103
|
+
}
|
|
104
|
+
//# sourceMappingURL=fetchMenuById.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetchMenuById.js","names":["InstanceApi_postSearch","pick","checkIfOfComputed","mergeMenu","reorderMenuItems","computeMenuItems","computeMenuData","fetchMenuTitle","getMenusOfStandaloneApp","preCheckPermissionsForAny","menuPromises","Map","menuCache","getMenuById","menuId","get","fetchMenuById","runtimeContext","helpers","promise","_fetchMenuById","_x","_x2","_x3","_fetchMenuById2","apply","arguments","_asyncToGenerator","menuList","window","STANDALONE_MICRO_APPS","app","id","page","page_size","fields","title","icon","link","titleDataSource","defaultCollapsed","defaultCollapsedBreakpoint","type","injectMenuGroupId","dynamicItems","itemsResolve","items","i18n","query","$eq","$size","$gt","list","menuData","Error","concat","restMenuData","_objectWithoutProperties","_excluded","newRuntimeContext","_objectSpread","pendingPermissionsPreCheck","tplStateStoreId","forEachItem","rootAppId","appId","computedMenuData","computedMenuItems","Promise","all","finalMenuData","menuItems","filter","map","item","_item$children","children","text","length","defaultExpanded","set"],"sources":["../../../src/menu/fetchMenuById.ts"],"sourcesContent":["import { InstanceApi_postSearch } from \"@next-api-sdk/cmdb-sdk\";\nimport { pick } from \"lodash\";\nimport { checkIfOfComputed } from \"@next-core/runtime\";\nimport { mergeMenu } from \"./mergeMenu.js\";\nimport { reorderMenuItems } from \"./reorderMenuItems.js\";\nimport type {\n MenuRawData,\n RuntimeContext,\n RuntimeHelpers,\n} from \"./interfaces.js\";\nimport { computeMenuItems, computeMenuData } from \"./computeMenuData.js\";\nimport { fetchMenuTitle } from \"./fetchMenuTitle.js\";\nimport { getMenusOfStandaloneApp } from \"./getMenusOfStandaloneApp.js\";\nimport { preCheckPermissionsForAny } from \"../checkPermissions.js\";\n\nconst menuPromises = new Map<string, Promise<void>>();\n\nconst menuCache = new Map<string, unknown>();\n\nexport function getMenuById(menuId: string) {\n return menuCache.get(menuId);\n}\n\nexport function fetchMenuById(\n menuId: string,\n runtimeContext: RuntimeContext,\n helpers: RuntimeHelpers\n) {\n let promise = menuPromises.get(menuId);\n if (!promise) {\n promise = _fetchMenuById(menuId, runtimeContext, helpers);\n }\n return promise;\n}\n\nasync function _fetchMenuById(\n menuId: string,\n runtimeContext: RuntimeContext,\n helpers: RuntimeHelpers\n) {\n const menuList = window.STANDALONE_MICRO_APPS\n ? getMenusOfStandaloneApp(menuId, runtimeContext.app.id, helpers)\n : ((\n await InstanceApi_postSearch(\"EASYOPS_STORYBOARD_MENU\", {\n page: 1,\n page_size: 200,\n fields: {\n menuId: true,\n title: true,\n icon: true,\n link: true,\n titleDataSource: true,\n defaultCollapsed: true,\n defaultCollapsedBreakpoint: true,\n type: true,\n injectMenuGroupId: true,\n dynamicItems: true,\n itemsResolve: true,\n items: true,\n i18n: true,\n \"items.children\": true,\n \"app.appId\": true,\n },\n query: {\n menuId: {\n $eq: menuId,\n },\n app: {\n $size: {\n $gt: 0,\n },\n },\n },\n })\n ).list as MenuRawData[]);\n\n const menuData = await mergeMenu(menuList, runtimeContext, helpers);\n if (!menuData) {\n throw new Error(`Menu not found: ${menuId}`);\n }\n\n reorderMenuItems(menuData);\n\n const { items, app, ...restMenuData } = menuData;\n const newRuntimeContext: RuntimeContext = {\n ...runtimeContext,\n pendingPermissionsPreCheck: [\n ...runtimeContext.pendingPermissionsPreCheck,\n preCheckPermissionsForAny([items, restMenuData]),\n ],\n };\n delete newRuntimeContext.tplStateStoreId;\n delete newRuntimeContext.forEachItem;\n const rootAppId = app[0].appId;\n\n const [computedMenuData, computedMenuItems] = await Promise.all([\n computeMenuData(restMenuData, rootAppId, newRuntimeContext, helpers),\n computeMenuItems(items, newRuntimeContext, helpers),\n ]);\n\n const finalMenuData = {\n title: await fetchMenuTitle(computedMenuData),\n ...pick(computedMenuData, [\n \"icon\",\n \"link\",\n \"defaultCollapsed\",\n \"defaultCollapsedBreakpoint\",\n ]),\n menuItems: computedMenuItems.filter(checkIfOfComputed).map((item) => {\n const children = item.children?.filter(checkIfOfComputed);\n return item.type === \"group\"\n ? {\n type: \"group\",\n title: item.text,\n items: children,\n }\n : children?.length\n ? {\n type: \"subMenu\",\n title: item.text,\n icon: item.icon,\n items: children,\n defaultExpanded: item.defaultExpanded,\n }\n : item;\n }),\n };\n\n // Todo(steve): reconsider the menu cache strategy\n menuCache.set(menuId, finalMenuData);\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
2
|
+
import { isEmpty } from "lodash";
|
|
3
|
+
import { InstanceApi_getDetail } from "@next-api-sdk/cmdb-sdk";
|
|
4
|
+
var menuTitleCache = new Map();
|
|
5
|
+
export function fetchMenuTitle(_x) {
|
|
6
|
+
return _fetchMenuTitle.apply(this, arguments);
|
|
7
|
+
}
|
|
8
|
+
function _fetchMenuTitle() {
|
|
9
|
+
_fetchMenuTitle = _asyncToGenerator(function* (menuData) {
|
|
10
|
+
if (menuData.title || isEmpty(menuData.titleDataSource)) {
|
|
11
|
+
return menuData.title;
|
|
12
|
+
}
|
|
13
|
+
var cacheKey = JSON.stringify(menuData.titleDataSource);
|
|
14
|
+
if (menuTitleCache.has(cacheKey)) {
|
|
15
|
+
return menuTitleCache.get(cacheKey);
|
|
16
|
+
}
|
|
17
|
+
var {
|
|
18
|
+
objectId,
|
|
19
|
+
instanceId,
|
|
20
|
+
attributeId
|
|
21
|
+
} = menuData.titleDataSource;
|
|
22
|
+
var attr = attributeId !== null && attributeId !== void 0 ? attributeId : "name";
|
|
23
|
+
var instanceData = yield InstanceApi_getDetail(objectId, instanceId, {
|
|
24
|
+
fields: attr
|
|
25
|
+
});
|
|
26
|
+
var title;
|
|
27
|
+
if (attributeId === "#showKey" && Array.isArray(instanceData[attr])) {
|
|
28
|
+
var [primary, ...rest] = instanceData[attr];
|
|
29
|
+
title = rest.length > 0 ? "".concat(primary, "(").concat(rest.join(","), ")") : String(primary);
|
|
30
|
+
} else {
|
|
31
|
+
title = String(instanceData[attr]);
|
|
32
|
+
}
|
|
33
|
+
menuTitleCache.set(cacheKey, title);
|
|
34
|
+
return title;
|
|
35
|
+
});
|
|
36
|
+
return _fetchMenuTitle.apply(this, arguments);
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=fetchMenuTitle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetchMenuTitle.js","names":["isEmpty","InstanceApi_getDetail","menuTitleCache","Map","fetchMenuTitle","_x","_fetchMenuTitle","apply","arguments","_asyncToGenerator","menuData","title","titleDataSource","cacheKey","JSON","stringify","has","get","objectId","instanceId","attributeId","attr","instanceData","fields","Array","isArray","primary","rest","length","concat","join","String","set"],"sources":["../../../src/menu/fetchMenuTitle.ts"],"sourcesContent":["import { isEmpty } from \"lodash\";\nimport { InstanceApi_getDetail } from \"@next-api-sdk/cmdb-sdk\";\nimport type { MenuRawData } from \"./interfaces.js\";\n\nconst menuTitleCache = new Map<string, string>();\n\nexport async function fetchMenuTitle(\n menuData: Pick<MenuRawData, \"title\" | \"titleDataSource\">\n) {\n if (menuData.title || isEmpty(menuData.titleDataSource)) {\n return menuData.title;\n }\n const cacheKey = JSON.stringify(menuData.titleDataSource);\n if (menuTitleCache.has(cacheKey)) {\n return menuTitleCache.get(cacheKey);\n }\n const { objectId, instanceId, attributeId } = menuData.titleDataSource;\n const attr = attributeId ?? \"name\";\n const instanceData = await InstanceApi_getDetail(objectId, instanceId, {\n fields: attr,\n });\n let title: string;\n if (attributeId === \"#showKey\" && Array.isArray(instanceData[attr])) {\n const [primary, ...rest] = instanceData[attr];\n title = rest.length > 0 ? `${primary}(${rest.join(\",\")})` : String(primary);\n } else {\n title = String(instanceData[attr]);\n }\n menuTitleCache.set(cacheKey, title);\n return title;\n}\n"],"mappings":";AAAA,SAASA,OAAO,QAAQ,QAAQ;AAChC,SAASC,qBAAqB,QAAQ,wBAAwB;AAG9D,IAAMC,cAAc,GAAG,IAAIC,GAAG,EAAkB;AAEhD,gBAAsBC,cAAcA,CAAAC,EAAA;EAAA,OAAAC,eAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA;AAwBnC,SAAAF,gBAAA;EAAAA,eAAA,GAAAG,iBAAA,CAxBM,WACLC,QAAwD,EACxD;IACA,IAAIA,QAAQ,CAACC,KAAK,IAAIX,OAAO,CAACU,QAAQ,CAACE,eAAe,CAAC,EAAE;MACvD,OAAOF,QAAQ,CAACC,KAAK;IACvB;IACA,IAAME,QAAQ,GAAGC,IAAI,CAACC,SAAS,CAACL,QAAQ,CAACE,eAAe,CAAC;IACzD,IAAIV,cAAc,CAACc,GAAG,CAACH,QAAQ,CAAC,EAAE;MAChC,OAAOX,cAAc,CAACe,GAAG,CAACJ,QAAQ,CAAC;IACrC;IACA,IAAM;MAAEK,QAAQ;MAAEC,UAAU;MAAEC;IAAY,CAAC,GAAGV,QAAQ,CAACE,eAAe;IACtE,IAAMS,IAAI,GAAGD,WAAW,aAAXA,WAAW,cAAXA,WAAW,GAAI,MAAM;IAClC,IAAME,YAAY,SAASrB,qBAAqB,CAACiB,QAAQ,EAAEC,UAAU,EAAE;MACrEI,MAAM,EAAEF;IACV,CAAC,CAAC;IACF,IAAIV,KAAa;IACjB,IAAIS,WAAW,KAAK,UAAU,IAAII,KAAK,CAACC,OAAO,CAACH,YAAY,CAACD,IAAI,CAAC,CAAC,EAAE;MACnE,IAAM,CAACK,OAAO,EAAE,GAAGC,IAAI,CAAC,GAAGL,YAAY,CAACD,IAAI,CAAC;MAC7CV,KAAK,GAAGgB,IAAI,CAACC,MAAM,GAAG,CAAC,MAAAC,MAAA,CAAMH,OAAO,OAAAG,MAAA,CAAIF,IAAI,CAACG,IAAI,CAAC,GAAG,CAAC,SAAMC,MAAM,CAACL,OAAO,CAAC;IAC7E,CAAC,MAAM;MACLf,KAAK,GAAGoB,MAAM,CAACT,YAAY,CAACD,IAAI,CAAC,CAAC;IACpC;IACAnB,cAAc,CAAC8B,GAAG,CAACnB,QAAQ,EAAEF,KAAK,CAAC;IACnC,OAAOA,KAAK;EACd,CAAC;EAAA,OAAAL,eAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
|
|
2
|
+
export function getMenusOfStandaloneApp(menuId, appId, helpers) {
|
|
3
|
+
var _ref, _storyboard$meta$inje, _storyboard$meta, _storyboard$meta2;
|
|
4
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
5
|
+
var storyboard = helpers.getStoryboardByAppId(appId);
|
|
6
|
+
var menus = (_ref = (_storyboard$meta$inje = (_storyboard$meta = storyboard.meta) === null || _storyboard$meta === void 0 ? void 0 : _storyboard$meta.injectMenus) !== null && _storyboard$meta$inje !== void 0 ? _storyboard$meta$inje : (_storyboard$meta2 = storyboard.meta) === null || _storyboard$meta2 === void 0 ? void 0 : _storyboard$meta2.menus) !== null && _ref !== void 0 ? _ref : [];
|
|
7
|
+
return menus.filter(menu => menu.menuId === menuId).map(menu => {
|
|
8
|
+
var _menu$app, _menu$app$;
|
|
9
|
+
return _objectSpread(_objectSpread({}, menu), (_menu$app = menu.app) !== null && _menu$app !== void 0 && (_menu$app$ = _menu$app[0]) !== null && _menu$app$ !== void 0 && _menu$app$.appId ? {} : {
|
|
10
|
+
app: [{
|
|
11
|
+
appId
|
|
12
|
+
}]
|
|
13
|
+
});
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
// Todo: maybe: fetch menus from STANDALONE_MENU@EASYOPS
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=getMenusOfStandaloneApp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getMenusOfStandaloneApp.js","names":["getMenusOfStandaloneApp","menuId","appId","helpers","_ref","_storyboard$meta$inje","_storyboard$meta","_storyboard$meta2","storyboard","getStoryboardByAppId","menus","meta","injectMenus","filter","menu","map","_menu$app","_menu$app$","_objectSpread","app"],"sources":["../../../src/menu/getMenusOfStandaloneApp.ts"],"sourcesContent":["import { MenuRawData, RuntimeHelpers } from \"./interfaces.js\";\n\nexport function getMenusOfStandaloneApp(\n menuId: string,\n appId: string,\n helpers: RuntimeHelpers\n): MenuRawData[] {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const storyboard = helpers.getStoryboardByAppId(appId)!;\n const menus = (storyboard.meta?.injectMenus ??\n storyboard.meta?.menus ??\n []) as MenuRawData[];\n\n return menus\n .filter((menu) => menu.menuId === menuId)\n .map((menu) => ({\n ...menu,\n ...(menu.app?.[0]?.appId ? {} : { app: [{ appId }] }),\n }));\n\n // Todo: maybe: fetch menus from STANDALONE_MENU@EASYOPS\n}\n"],"mappings":";AAEA,OAAO,SAASA,uBAAuBA,CACrCC,MAAc,EACdC,KAAa,EACbC,OAAuB,EACR;EAAA,IAAAC,IAAA,EAAAC,qBAAA,EAAAC,gBAAA,EAAAC,iBAAA;EACf;EACA,IAAMC,UAAU,GAAGL,OAAO,CAACM,oBAAoB,CAACP,KAAK,CAAE;EACvD,IAAMQ,KAAK,IAAAN,IAAA,IAAAC,qBAAA,IAAAC,gBAAA,GAAIE,UAAU,CAACG,IAAI,cAAAL,gBAAA,uBAAfA,gBAAA,CAAiBM,WAAW,cAAAP,qBAAA,cAAAA,qBAAA,IAAAE,iBAAA,GACzCC,UAAU,CAACG,IAAI,cAAAJ,iBAAA,uBAAfA,iBAAA,CAAiBG,KAAK,cAAAN,IAAA,cAAAA,IAAA,GACtB,EAAoB;EAEtB,OAAOM,KAAK,CACTG,MAAM,CAAEC,IAAI,IAAKA,IAAI,CAACb,MAAM,KAAKA,MAAM,CAAC,CACxCc,GAAG,CAAED,IAAI;IAAA,IAAAE,SAAA,EAAAC,UAAA;IAAA,OAAAC,aAAA,CAAAA,aAAA,KACLJ,IAAI,GACH,CAAAE,SAAA,GAAAF,IAAI,CAACK,GAAG,cAAAH,SAAA,gBAAAC,UAAA,GAARD,SAAA,CAAW,CAAC,CAAC,cAAAC,UAAA,eAAbA,UAAA,CAAef,KAAK,GAAG,CAAC,CAAC,GAAG;MAAEiB,GAAG,EAAE,CAAC;QAAEjB;MAAM,CAAC;IAAE,CAAC;EAAA,CACpD,CAAC;;EAEL;AACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","names":["getMenuById","fetchMenuById"],"sources":["../../../src/menu/index.ts"],"sourcesContent":["export { getMenuById, fetchMenuById } from \"./fetchMenuById.js\";\n"],"mappings":"AAAA,SAASA,WAAW,EAAEC,aAAa,QAAQ,oBAAoB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interfaces.js","names":["symbolAppId","symbolMenuI18nNamespace","symbolOverrideApp"],"sources":["../../../src/menu/interfaces.ts"],"sourcesContent":["import type { MetaI18n, MicroApp, ResolveConf } from \"@next-core/types\";\nimport type {\n RuntimeHooksMenuHelpers,\n __secret_internals,\n} from \"@next-core/runtime\";\nimport {\n symbolAppId,\n symbolMenuI18nNamespace,\n symbolOverrideApp,\n} from \"./constants.js\";\n\nexport type RuntimeContext = __secret_internals.RuntimeContext;\n\nexport type RuntimeHelpers = RuntimeHooksMenuHelpers;\n\n/** 原始菜单数据。 */\nexport interface MenuRawData {\n menuId: string;\n title: string;\n app: [\n {\n appId: string;\n }\n ];\n icon?: unknown;\n link?: string;\n titleDataSource?: TitleDataSource;\n items?: MenuItemRawData[];\n type?: \"main\" | \"inject\";\n injectMenuGroupId?: string;\n defaultCollapsed?: boolean;\n defaultCollapsedBreakpoint?: number;\n dynamicItems?: boolean;\n itemsResolve?: ResolveConf;\n i18n?: MetaI18n;\n overrideApp?: MicroApp;\n}\n\n/** 原始菜单项数据。 */\nexport type MenuItemRawData = Omit<SidebarMenuSimpleItem, \"type\"> & {\n children?: MenuItemRawData[];\n type?: \"default\" | \"group\";\n sort?: number;\n if?: string | boolean;\n defaultExpanded?: boolean;\n groupId?: string;\n};\n\ninterface TitleDataSource {\n objectId: string;\n instanceId: string;\n attributeId?: string;\n}\n\n/** 侧边栏基本菜单项的配置。 */\nexport interface SidebarMenuSimpleItem {\n /** 菜单项文本。 */\n text: string;\n\n /** 菜单项对应的系统内地址。 */\n // to?: LocationDescriptor;\n to?: unknown;\n\n /** 菜单项对应的外部链接地址。 */\n href?: string;\n\n /** 菜单项的图标。 */\n // icon?: MenuIcon;\n icon?: unknown;\n\n /** 菜单项链接打开的目标。 */\n target?: string;\n\n type?: \"default\";\n\n /** 高亮菜单项时是否使用精确匹配来对比当前地址和菜单项地址。 */\n exact?: boolean;\n\n /** 设置额外包含的匹配高亮菜单项的地址列表。 */\n activeIncludes?: string[];\n\n /** 设置需要被排除的匹配高亮菜单项的地址列表。 */\n activeExcludes?: string[];\n\n /** 设置匹配高亮菜单项时是否还对 search 参数进行比较。 */\n activeMatchSearch?: boolean;\n\n /** @internal */\n key?: string;\n}\n\nexport interface RuntimeMenuItemRawData extends MenuItemRawData {\n children?: RuntimeMenuItemRawData[];\n [symbolAppId]: string;\n [symbolMenuI18nNamespace]?: string;\n [symbolOverrideApp]?: MicroApp;\n}\n\nexport interface RuntimeMenuRawData extends MenuRawData {\n items: RuntimeMenuItemRawData[];\n // [symbolShouldCache]?: boolean;\n [symbolMenuI18nNamespace]?: string;\n [symbolOverrideApp]?: MicroApp;\n}\n"],"mappings":"AAKA,SACEA,WAAW,EACXC,uBAAuB,EACvBC,iBAAiB,QACZ,gBAAgB;;AAMvB;;AAuBA;;AAgBA"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
|
|
2
|
+
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
3
|
+
export function loadDynamicMenuItems(_x, _x2, _x3, _x4) {
|
|
4
|
+
return _loadDynamicMenuItems.apply(this, arguments);
|
|
5
|
+
}
|
|
6
|
+
function _loadDynamicMenuItems() {
|
|
7
|
+
_loadDynamicMenuItems = _asyncToGenerator(function* (menu, runtimeContext, menuWithI18n, helpers) {
|
|
8
|
+
if (menu.dynamicItems && menu.itemsResolve) {
|
|
9
|
+
var overrideAppId = menu.app[0].appId;
|
|
10
|
+
var newRuntimeContext = runtimeContext;
|
|
11
|
+
if (overrideAppId !== runtimeContext.app.id) {
|
|
12
|
+
var _helpers$getStoryboar;
|
|
13
|
+
var overrideApp = window.STANDALONE_MICRO_APPS ? menu.overrideApp : (_helpers$getStoryboar = helpers.getStoryboardByAppId(overrideAppId)) === null || _helpers$getStoryboar === void 0 ? void 0 : _helpers$getStoryboar.app;
|
|
14
|
+
newRuntimeContext = _objectSpread(_objectSpread({}, runtimeContext), {}, {
|
|
15
|
+
overrideApp,
|
|
16
|
+
appendI18nNamespace: menuWithI18n.get(menu)
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
var resolved = yield helpers.resolveData(_objectSpread({
|
|
20
|
+
transform: "items"
|
|
21
|
+
}, menu.itemsResolve), newRuntimeContext);
|
|
22
|
+
menu.items = resolved.items;
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
return _loadDynamicMenuItems.apply(this, arguments);
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=loadDynamicMenuItems.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loadDynamicMenuItems.js","names":["loadDynamicMenuItems","_x","_x2","_x3","_x4","_loadDynamicMenuItems","apply","arguments","_asyncToGenerator","menu","runtimeContext","menuWithI18n","helpers","dynamicItems","itemsResolve","overrideAppId","app","appId","newRuntimeContext","id","_helpers$getStoryboar","overrideApp","window","STANDALONE_MICRO_APPS","getStoryboardByAppId","_objectSpread","appendI18nNamespace","get","resolved","resolveData","transform","items"],"sources":["../../../src/menu/loadDynamicMenuItems.ts"],"sourcesContent":["import type {\n RuntimeContext,\n MenuItemRawData,\n MenuRawData,\n RuntimeHelpers,\n} from \"./interfaces.js\";\n\nexport async function loadDynamicMenuItems(\n menu: MenuRawData,\n runtimeContext: RuntimeContext,\n menuWithI18n: WeakMap<MenuRawData, string>,\n helpers: RuntimeHelpers\n): Promise<void> {\n if (menu.dynamicItems && menu.itemsResolve) {\n const overrideAppId = menu.app[0].appId;\n let newRuntimeContext = runtimeContext;\n if (overrideAppId !== runtimeContext.app.id) {\n const overrideApp = window.STANDALONE_MICRO_APPS\n ? menu.overrideApp\n : helpers.getStoryboardByAppId(overrideAppId)?.app;\n newRuntimeContext = {\n ...runtimeContext,\n overrideApp,\n appendI18nNamespace: menuWithI18n.get(menu),\n };\n }\n const resolved = (await helpers.resolveData(\n {\n transform: \"items\",\n ...menu.itemsResolve,\n },\n newRuntimeContext\n )) as { items: MenuItemRawData[] };\n menu.items = resolved.items;\n }\n}\n"],"mappings":";;AAOA,gBAAsBA,oBAAoBA,CAAAC,EAAA,EAAAC,GAAA,EAAAC,GAAA,EAAAC,GAAA;EAAA,OAAAC,qBAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA;AA4BzC,SAAAF,sBAAA;EAAAA,qBAAA,GAAAG,iBAAA,CA5BM,WACLC,IAAiB,EACjBC,cAA8B,EAC9BC,YAA0C,EAC1CC,OAAuB,EACR;IACf,IAAIH,IAAI,CAACI,YAAY,IAAIJ,IAAI,CAACK,YAAY,EAAE;MAC1C,IAAMC,aAAa,GAAGN,IAAI,CAACO,GAAG,CAAC,CAAC,CAAC,CAACC,KAAK;MACvC,IAAIC,iBAAiB,GAAGR,cAAc;MACtC,IAAIK,aAAa,KAAKL,cAAc,CAACM,GAAG,CAACG,EAAE,EAAE;QAAA,IAAAC,qBAAA;QAC3C,IAAMC,WAAW,GAAGC,MAAM,CAACC,qBAAqB,GAC5Cd,IAAI,CAACY,WAAW,IAAAD,qBAAA,GAChBR,OAAO,CAACY,oBAAoB,CAACT,aAAa,CAAC,cAAAK,qBAAA,uBAA3CA,qBAAA,CAA6CJ,GAAG;QACpDE,iBAAiB,GAAAO,aAAA,CAAAA,aAAA,KACZf,cAAc;UACjBW,WAAW;UACXK,mBAAmB,EAAEf,YAAY,CAACgB,GAAG,CAAClB,IAAI;QAAC,EAC5C;MACH;MACA,IAAMmB,QAAQ,SAAUhB,OAAO,CAACiB,WAAW,CAAAJ,aAAA;QAEvCK,SAAS,EAAE;MAAO,GACfrB,IAAI,CAACK,YAAY,GAEtBI,iBAAiB,CACe;MAClCT,IAAI,CAACsB,KAAK,GAAGH,QAAQ,CAACG,KAAK;IAC7B;EACF,CAAC;EAAA,OAAA1B,qBAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA"}
|