@alauda-fe/plugin-sdk 0.0.15 → 0.0.17

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.
@@ -1,15 +1,18 @@
1
- import { getUserLanguage, isBuiltInLanguage, } from '@alauda-fe/common';
1
+ import { FALLBACK_LANGUAGE, getUserLanguage, isBuiltInLanguage, } from '@alauda-fe/common';
2
2
  import { satisfies } from 'compare-versions';
3
3
  import { loadExtensions } from './extensions-loader';
4
4
  import { translateScope } from './utils';
5
- let extensions;
5
+ let _extensions;
6
6
  let extensionTranslations;
7
+ export function getAllExtensions() {
8
+ return _extensions || [];
9
+ }
7
10
  export function getAppExtensions(type, cluster) {
8
11
  const types = Array.isArray(type) ? type : [type];
9
- if (!extensions) {
12
+ if (!_extensions) {
10
13
  throw new Error('Extensions not loaded');
11
14
  }
12
- return extensions.filter(ext => {
15
+ return _extensions.filter(ext => {
13
16
  if (ext.cluster && cluster && ext.cluster !== cluster) {
14
17
  return false;
15
18
  }
@@ -20,7 +23,8 @@ export function getAppExtensionTranslations() {
20
23
  return extensionTranslations;
21
24
  }
22
25
  export async function setupAppExtensions(host, hostVersion) {
23
- extensions = (await loadExtensions()).filter(ext => {
26
+ const allExtensions = await loadExtensions();
27
+ _extensions = allExtensions.filter(ext => {
24
28
  if (!ext.type.startsWith('console-*/') &&
25
29
  !ext.type.startsWith(host + '/')) {
26
30
  return false;
@@ -34,13 +38,14 @@ export async function setupAppExtensions(host, hostVersion) {
34
38
  }
35
39
  return isVersionMatch;
36
40
  });
37
- window.__alauda_extensions = extensions;
41
+ // for debug
42
+ window.__alauda_extensions = _extensions;
38
43
  extensionTranslations = await loadTranslations();
39
- return extensions;
44
+ return _extensions;
40
45
  }
41
46
  async function loadTranslations() {
42
47
  const lang = getUserLanguage();
43
- const entrypoints = extensions.reduce((acc, curr) => {
48
+ const entrypoints = _extensions.reduce((acc, curr) => {
44
49
  acc[curr.entrypoint] = {
45
50
  scope: translateScope(curr, lang),
46
51
  };
@@ -55,21 +60,27 @@ async function loadTranslations() {
55
60
  }));
56
61
  }
57
62
  return await Promise.all(Object.entries(entrypoints).map(([entrypoint, { scope }]) => Promise.all([
58
- fetchI18nFile(`${entrypoint}/assets/i18n/en.json`),
63
+ fetchI18nFile(`${entrypoint}/assets/i18n/${FALLBACK_LANGUAGE}.json`),
59
64
  fetchI18nFile(`/console-i18n/${lang}/${scope}.json`),
60
65
  ]).then(([en, other]) => ({
66
+ [FALLBACK_LANGUAGE]: { [scope]: en },
61
67
  [lang]: {
62
- [scope]: Object.assign(en, other),
68
+ [scope]: other,
63
69
  },
64
70
  }))));
65
71
  }
66
72
  function fetchI18nFile(path) {
67
73
  return fetch(path)
68
- .then(res => res.json())
74
+ .then(res => {
75
+ if (!res.ok) {
76
+ throw new Error(`HTTP ${res.status}: ${res.statusText}`);
77
+ }
78
+ return res.json();
79
+ })
69
80
  .catch(err => {
70
81
  console.error(`Failed to load plugin i18n file, ${path}`);
71
82
  console.error(err);
72
- return {};
83
+ return null;
73
84
  });
74
85
  }
75
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app-extensions.js","sourceRoot":"","sources":["../../../../../libs/plugin-sdk/src/lib/app-extensions.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  getUserLanguage,\n  isBuiltInLanguage,\n  Translations,\n} from '@alauda-fe/common';\nimport { satisfies } from 'compare-versions';\n\nimport { Extension, loadExtensions } from './extensions-loader';\nimport { translateScope } from './utils';\n\nlet extensions: Extension[];\n\nlet extensionTranslations: Translations[];\n\nexport function getAppExtensions<T = any>(\n  type: string | string[],\n  cluster?: string,\n) {\n  const types = Array.isArray(type) ? type : [type];\n  if (!extensions) {\n    throw new Error('Extensions not loaded');\n  }\n  return extensions.filter(ext => {\n    if (ext.cluster && cluster && ext.cluster !== cluster) {\n      return false;\n    }\n\n    return types.includes(ext.type);\n  }) as Array<Extension<T>>;\n}\n\nexport function getAppExtensionTranslations() {\n  return extensionTranslations;\n}\n\nexport async function setupAppExtensions(host: string, hostVersion?: string) {\n  extensions = (await loadExtensions()).filter(ext => {\n    if (\n      !ext.type.startsWith('console-*/') &&\n      !ext.type.startsWith(host + '/')\n    ) {\n      return false;\n    }\n\n    const requiredVersion =\n      ext.dependencies?.[host] || ext.dependencies?.['console-*'];\n\n    const isVersionMatch =\n      hostVersion && requiredVersion\n        ? satisfies(hostVersion, requiredVersion)\n        : true;\n\n    if (!isVersionMatch) {\n      console.warn(\n        `Extension \"${ext.pluginName}~${ext.appName}\" (cluster: ${ext.cluster || 'default'}) host version mismatch: required ${requiredVersion}, current host version ${hostVersion}`,\n      );\n    }\n\n    return isVersionMatch;\n  });\n\n  (window as any).__alauda_extensions = extensions;\n\n  extensionTranslations = await loadTranslations();\n\n  return extensions;\n}\n\nasync function loadTranslations(): Promise<\n  Array<{ [lang: string]: Translations }>\n> {\n  const lang = getUserLanguage();\n\n  const entrypoints = extensions.reduce(\n    (acc, curr) => {\n      acc[curr.entrypoint] = {\n        scope: translateScope(curr, lang),\n      };\n      return acc;\n    },\n    {} as Record<string, { scope: string }>,\n  );\n\n  if (isBuiltInLanguage(lang)) {\n    return await Promise.all(\n      Object.entries(entrypoints).map(([entrypoint, { scope }]) => {\n        const path = `${entrypoint}/assets/i18n/${lang}.json`;\n        return fetchI18nFile(path).then(translations => ({\n          [lang]: { [scope]: translations },\n        }));\n      }),\n    );\n  }\n\n  return await Promise.all(\n    Object.entries(entrypoints).map(([entrypoint, { scope }]) =>\n      Promise.all([\n        fetchI18nFile(`${entrypoint}/assets/i18n/en.json`),\n        fetchI18nFile(`/console-i18n/${lang}/${scope}.json`),\n      ]).then(([en, other]) => ({\n        [lang]: {\n          [scope]: Object.assign(en, other),\n        },\n      })),\n    ),\n  );\n}\n\nfunction fetchI18nFile(path: string): Promise<Translations> {\n  return fetch(path)\n    .then(res => res.json())\n    .catch(err => {\n      console.error(`Failed to load plugin i18n file, ${path}`);\n      console.error(err);\n      return {};\n    });\n}\n"]}
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app-extensions.js","sourceRoot":"","sources":["../../../../../libs/plugin-sdk/src/lib/app-extensions.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  FALLBACK_LANGUAGE,\n  getUserLanguage,\n  isBuiltInLanguage,\n  Translations,\n} from '@alauda-fe/common';\nimport { satisfies } from 'compare-versions';\n\nimport { Extension, loadExtensions } from './extensions-loader';\nimport { translateScope } from './utils';\n\nlet _extensions: Extension[];\n\nlet extensionTranslations: Translations[];\n\nexport function getAllExtensions(): Extension[] {\n  return _extensions || [];\n}\n\nexport function getAppExtensions<T = any>(\n  type: string | string[],\n  cluster?: string,\n) {\n  const types = Array.isArray(type) ? type : [type];\n  if (!_extensions) {\n    throw new Error('Extensions not loaded');\n  }\n  return _extensions.filter(ext => {\n    if (ext.cluster && cluster && ext.cluster !== cluster) {\n      return false;\n    }\n\n    return types.includes(ext.type);\n  }) as Array<Extension<T>>;\n}\n\nexport function getAppExtensionTranslations() {\n  return extensionTranslations;\n}\n\nexport async function setupAppExtensions(host: string, hostVersion?: string) {\n  const allExtensions = await loadExtensions();\n\n  _extensions = allExtensions.filter(ext => {\n    if (\n      !ext.type.startsWith('console-*/') &&\n      !ext.type.startsWith(host + '/')\n    ) {\n      return false;\n    }\n\n    const requiredVersion =\n      ext.dependencies?.[host] || ext.dependencies?.['console-*'];\n\n    const isVersionMatch =\n      hostVersion && requiredVersion\n        ? satisfies(hostVersion, requiredVersion)\n        : true;\n\n    if (!isVersionMatch) {\n      console.warn(\n        `Extension \"${ext.pluginName}~${ext.appName}\" (cluster: ${ext.cluster || 'default'}) host version mismatch: required ${requiredVersion}, current host version ${hostVersion}`,\n      );\n    }\n\n    return isVersionMatch;\n  });\n\n  // for debug\n  (window as any).__alauda_extensions = _extensions;\n\n  extensionTranslations = await loadTranslations();\n\n  return _extensions;\n}\n\nasync function loadTranslations(): Promise<\n  Array<{ [lang: string]: Translations }>\n> {\n  const lang = getUserLanguage();\n\n  const entrypoints = _extensions.reduce(\n    (acc, curr) => {\n      acc[curr.entrypoint] = {\n        scope: translateScope(curr, lang),\n      };\n      return acc;\n    },\n    {} as Record<string, { scope: string }>,\n  );\n\n  if (isBuiltInLanguage(lang)) {\n    return await Promise.all(\n      Object.entries(entrypoints).map(([entrypoint, { scope }]) => {\n        const path = `${entrypoint}/assets/i18n/${lang}.json`;\n        return fetchI18nFile(path).then(translations => ({\n          [lang]: { [scope]: translations },\n        }));\n      }),\n    );\n  }\n\n  return await Promise.all(\n    Object.entries(entrypoints).map(([entrypoint, { scope }]) =>\n      Promise.all([\n        fetchI18nFile(`${entrypoint}/assets/i18n/${FALLBACK_LANGUAGE}.json`),\n        fetchI18nFile(`/console-i18n/${lang}/${scope}.json`),\n      ]).then(([en, other]) => ({\n        [FALLBACK_LANGUAGE]: { [scope]: en },\n        [lang]: {\n          [scope]: other,\n        },\n      })),\n    ),\n  );\n}\n\nfunction fetchI18nFile(path: string): Promise<Translations> {\n  return fetch(path)\n    .then(res => {\n      if (!res.ok) {\n        throw new Error(`HTTP ${res.status}: ${res.statusText}`);\n      }\n      return res.json();\n    })\n    .catch(err => {\n      console.error(`Failed to load plugin i18n file, ${path}`);\n      console.error(err);\n      return null;\n    });\n}\n"]}
@@ -1,16 +1,17 @@
1
+ import { GLOBAL_CLUSTER, } from '@alauda-fe/common';
1
2
  import { getAppExtensions } from '../app-extensions';
2
3
  import { filterLatestVersion, translateScope, translateScopeKey, } from '../utils';
3
- export function getRemoteNavigations(scope, translate) {
4
+ export function getRemoteNavigations(scope, translate, cluster) {
4
5
  if (!scope) {
5
6
  return [];
6
7
  }
7
- return filterItems(translate, scope + '/navigation');
8
+ return filterItems(translate, scope + '/navigation', cluster);
8
9
  }
9
- export function getRemoteNavigationGroups(scope, translate) {
10
+ export function getRemoteNavigationGroups(scope, translate, cluster) {
10
11
  if (!scope) {
11
12
  return [];
12
13
  }
13
- return filterItems(translate, scope + '/navigation/group');
14
+ return filterItems(translate, scope + '/navigation/group', cluster);
14
15
  }
15
16
  export function insertNavItem(source, remotes) {
16
17
  remotes.forEach(remote => {
@@ -39,12 +40,26 @@ export function insertNavGroupItem(source, remotes) {
39
40
  return { ...group, items: insertNavItem(group.items, groupRemotes) };
40
41
  });
41
42
  }
42
- function filterItems(translate, type) {
43
+ function filterItems(translate, type, cluster) {
43
44
  const exts = getAppExtensions(type);
44
- return filterLatestVersion((options) => options.name)(exts).map(ext => {
45
- const options = translateLabels(translate, ext);
46
- return fillIconPath(ext.entrypoint, options);
47
- });
45
+ const grouped = Object.values(exts.reduce((acc, ext) => {
46
+ acc[ext.options.name] = (acc[ext.options.name] || []).concat(ext);
47
+ return acc;
48
+ }, {}));
49
+ return grouped
50
+ .flatMap(items => {
51
+ let ext = filterLatestVersion((option) => option.name)(items)[0];
52
+ const mainOption = (items.find(ext => ext.cluster === GLOBAL_CLUSTER) || ext).options;
53
+ if (mainOption.clusterStrategy === 'strict' && cluster) {
54
+ ext = items.find(item => item.cluster === cluster);
55
+ }
56
+ if (ext) {
57
+ const options = translateLabels(translate, ext);
58
+ return fillIconPath(ext.entrypoint, options);
59
+ }
60
+ return null;
61
+ })
62
+ .filter(Boolean);
48
63
  }
49
64
  function translateLabels(translate, ext) {
50
65
  const transScope = translateScope(ext, translate.locale);
@@ -133,4 +148,4 @@ function genItemKey(item, parentKey = '') {
133
148
  children: item.children?.map(c => genItemKey(c, key)),
134
149
  };
135
150
  }
136
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation.js","sourceRoot":"","sources":["../../../../../../libs/plugin-sdk/src/lib/extension-points/navigation.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  NavGroupConfig,\n  NavItemConfig,\n  TranslateService,\n} from '@alauda-fe/common';\n\nimport { getAppExtensions } from '../app-extensions';\nimport { Extension } from '../extensions-loader';\nimport {\n  filterLatestVersion,\n  translateScope,\n  translateScopeKey,\n} from '../utils';\n\nexport function getRemoteNavigations(\n  scope: string,\n  translate: TranslateService,\n): RemoteNavigationItemRoot[] {\n  if (!scope) {\n    return [];\n  }\n\n  return filterItems(translate, scope + '/navigation');\n}\n\nexport function getRemoteNavigationGroups(\n  scope: string,\n  translate: TranslateService,\n): RemoteNavigationItemRoot[] {\n  if (!scope) {\n    return [];\n  }\n\n  return filterItems(translate, scope + '/navigation/group');\n}\n\nexport function insertNavItem(\n  source: NavItemConfig[],\n  remotes: RemoteNavigationItemRoot[],\n): NavItemConfig[] {\n  remotes.forEach(remote => {\n    remote = genItemKey(remote);\n\n    if (remote.insertAfter) {\n      const r = insert('after', remote.insertAfter, [], source, remote);\n      if (r.matched) {\n        source = r.result;\n        return;\n      }\n    }\n\n    if (remote.insertBefore) {\n      const r = insert('before', remote.insertBefore, [], source, remote);\n      if (r.matched) {\n        source = r.result;\n        return;\n      }\n    }\n\n    source = source.concat(remote);\n  });\n\n  return source;\n}\n\nexport function insertNavGroupItem(\n  source: NavGroupConfig[],\n  remotes: RemoteNavigationItemRoot[],\n): NavGroupConfig[] {\n  return source.map(group => {\n    const groupRemotes = remotes.filter(remote => remote.group === group.name);\n    return { ...group, items: insertNavItem(group.items, groupRemotes) };\n  });\n}\n\nexport interface RemoteNavigationItem extends NavItemConfig {\n  group?: string;\n  displayName: string | Record<string, string>;\n  displayNameKey: string;\n  children?: RemoteNavigationItem[];\n}\n\nexport interface RemoteNavigationItemRoot extends RemoteNavigationItem {\n  insertAfter?: string | string[];\n  insertBefore?: string | string[];\n}\n\nfunction filterItems(translate: TranslateService, type: string) {\n  const exts = getAppExtensions(type);\n  return filterLatestVersion((options: { name: string }) => options.name)(\n    exts,\n  ).map(ext => {\n    const options = translateLabels(translate, ext);\n    return fillIconPath(ext.entrypoint, options);\n  });\n}\n\nfunction translateLabels(translate: TranslateService, ext: Extension) {\n  const transScope = translateScope(ext, translate.locale);\n  const trans = (item: RemoteNavigationItem): RemoteNavigationItem => {\n    let label = '';\n    if (item.displayNameKey) {\n      label = translate.get(translateScopeKey(transScope, item.displayNameKey));\n    } else if (typeof item.displayName === 'string') {\n      label = item.displayName;\n    } else if (item.displayName[translate.locale]) {\n      label = item.displayName[translate.locale];\n    } else {\n      const key = 'PLUGIN_NAV_DISPLAY_NAME__' + item.displayName['en'];\n      const value = translate.get(key);\n      label = value === key ? item.displayName['en'] : value;\n    }\n\n    return {\n      ...item,\n      label,\n      children: item.children ? item.children.map(c => trans(c)) : null,\n    };\n  };\n\n  return trans(ext.options);\n}\n\nfunction fillIconPath(entrypoint: string, item: RemoteNavigationItem) {\n  return Object.entries(item).reduce((acc, [key, value]) => {\n    if (key === 'iconImgSrc' || key === 'iconLottieJson') {\n      acc[key] = value.replace('<entrypoint>', entrypoint);\n    } else if (key === 'children') {\n      acc[key] = item.children\n        ? item.children.map(c => fillIconPath(entrypoint, c))\n        : null;\n    } else {\n      acc[key] = value;\n    }\n    return acc;\n  }, {} as RemoteNavigationItem);\n}\n\nfunction insert(\n  position: 'before' | 'after',\n  anchor: string | string[],\n  namePath: string[],\n  target: NavItemConfig[],\n  item: RemoteNavigationItemRoot,\n): { result: NavItemConfig[]; matched: boolean } {\n  const offset = position === 'before' ? 0 : 1;\n  anchor = Array.isArray(anchor) ? anchor : [anchor];\n\n  for (const currentAnchor of anchor) {\n    for (let i = 0; i < target.length; i++) {\n      if (target[i].name === currentAnchor) {\n        return {\n          result: [\n            ...target.slice(0, i + offset),\n            { ...item, key: namePath.join('/') + '/' + item.name },\n            ...target.slice(i + offset),\n          ],\n          matched: true,\n        };\n      }\n\n      if (target[i].children) {\n        const { result, matched } = insert(\n          position,\n          currentAnchor,\n          namePath.concat(target[i].name),\n          target[i].children,\n          item,\n        );\n        if (matched) {\n          return {\n            result: target.map((item, index) =>\n              index === i\n                ? {\n                    ...item,\n                    children: result,\n                  }\n                : item,\n            ),\n            matched: true,\n          };\n        }\n      }\n    }\n  }\n\n  return {\n    result: target,\n    matched: false,\n  };\n}\n\nfunction genItemKey(\n  item: RemoteNavigationItem,\n  parentKey: string = '',\n): RemoteNavigationItem {\n  const currentKey = item.key ?? item.name;\n  const key = parentKey ? parentKey + '/' + currentKey : currentKey;\n  return {\n    ...item,\n    key,\n    children: item.children?.map(c => genItemKey(c, key)),\n  };\n}\n"]}
151
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation.js","sourceRoot":"","sources":["../../../../../../libs/plugin-sdk/src/lib/extension-points/navigation.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  GLOBAL_CLUSTER,\n  NavGroupConfig,\n  NavItemConfig,\n  TranslateService,\n} from '@alauda-fe/common';\n\nimport { getAppExtensions } from '../app-extensions';\nimport { Extension } from '../extensions-loader';\nimport {\n  filterLatestVersion,\n  translateScope,\n  translateScopeKey,\n} from '../utils';\n\nexport function getRemoteNavigations(\n  scope: string,\n  translate: TranslateService,\n  cluster?: string,\n): RemoteNavigationItemRoot[] {\n  if (!scope) {\n    return [];\n  }\n\n  return filterItems(translate, scope + '/navigation', cluster);\n}\n\nexport function getRemoteNavigationGroups(\n  scope: string,\n  translate: TranslateService,\n  cluster?: string,\n): RemoteNavigationItemRoot[] {\n  if (!scope) {\n    return [];\n  }\n\n  return filterItems(translate, scope + '/navigation/group', cluster);\n}\n\nexport function insertNavItem(\n  source: NavItemConfig[],\n  remotes: RemoteNavigationItemRoot[],\n): NavItemConfig[] {\n  remotes.forEach(remote => {\n    remote = genItemKey(remote);\n\n    if (remote.insertAfter) {\n      const r = insert('after', remote.insertAfter, [], source, remote);\n      if (r.matched) {\n        source = r.result;\n        return;\n      }\n    }\n\n    if (remote.insertBefore) {\n      const r = insert('before', remote.insertBefore, [], source, remote);\n      if (r.matched) {\n        source = r.result;\n        return;\n      }\n    }\n\n    source = source.concat(remote);\n  });\n\n  return source;\n}\n\nexport function insertNavGroupItem(\n  source: NavGroupConfig[],\n  remotes: RemoteNavigationItemRoot[],\n): NavGroupConfig[] {\n  return source.map(group => {\n    const groupRemotes = remotes.filter(remote => remote.group === group.name);\n    return { ...group, items: insertNavItem(group.items, groupRemotes) };\n  });\n}\n\nexport interface RemoteNavigationItem extends NavItemConfig {\n  group?: string;\n  displayName: string | Record<string, string>;\n  displayNameKey: string;\n  children?: RemoteNavigationItem[];\n}\n\nexport interface RemoteNavigationItemRoot extends RemoteNavigationItem {\n  insertAfter?: string | string[];\n  insertBefore?: string | string[];\n  clusterStrategy?: 'latest' | 'strict';\n}\n\nfunction filterItems(\n  translate: TranslateService,\n  type: string,\n  cluster?: string,\n) {\n  const exts = getAppExtensions<RemoteNavigationItemRoot>(type);\n\n  const grouped = Object.values(\n    exts.reduce(\n      (acc, ext) => {\n        acc[ext.options.name] = (acc[ext.options.name] || []).concat(ext);\n        return acc;\n      },\n      {} as Record<string, Array<Extension<RemoteNavigationItemRoot>>>,\n    ),\n  );\n  return grouped\n    .flatMap(items => {\n      let ext = filterLatestVersion(\n        (option: RemoteNavigationItemRoot) => option.name,\n      )(items)[0];\n      const mainOption = (\n        items.find(ext => ext.cluster === GLOBAL_CLUSTER) || ext\n      ).options;\n\n      if (mainOption.clusterStrategy === 'strict' && cluster) {\n        ext = items.find(item => item.cluster === cluster);\n      }\n      if (ext) {\n        const options = translateLabels(translate, ext);\n        return fillIconPath(ext.entrypoint, options);\n      }\n      return null;\n    })\n    .filter(Boolean);\n}\n\nfunction translateLabels(translate: TranslateService, ext: Extension) {\n  const transScope = translateScope(ext, translate.locale);\n  const trans = (item: RemoteNavigationItem): RemoteNavigationItem => {\n    let label = '';\n    if (item.displayNameKey) {\n      label = translate.get(translateScopeKey(transScope, item.displayNameKey));\n    } else if (typeof item.displayName === 'string') {\n      label = item.displayName;\n    } else if (item.displayName[translate.locale]) {\n      label = item.displayName[translate.locale];\n    } else {\n      const key = 'PLUGIN_NAV_DISPLAY_NAME__' + item.displayName['en'];\n      const value = translate.get(key);\n      label = value === key ? item.displayName['en'] : value;\n    }\n\n    return {\n      ...item,\n      label,\n      children: item.children ? item.children.map(c => trans(c)) : null,\n    };\n  };\n\n  return trans(ext.options);\n}\n\nfunction fillIconPath(entrypoint: string, item: RemoteNavigationItem) {\n  return Object.entries(item).reduce((acc, [key, value]) => {\n    if (key === 'iconImgSrc' || key === 'iconLottieJson') {\n      acc[key] = value.replace('<entrypoint>', entrypoint);\n    } else if (key === 'children') {\n      acc[key] = item.children\n        ? item.children.map(c => fillIconPath(entrypoint, c))\n        : null;\n    } else {\n      acc[key] = value;\n    }\n    return acc;\n  }, {} as RemoteNavigationItem);\n}\n\nfunction insert(\n  position: 'before' | 'after',\n  anchor: string | string[],\n  namePath: string[],\n  target: NavItemConfig[],\n  item: RemoteNavigationItemRoot,\n): { result: NavItemConfig[]; matched: boolean } {\n  const offset = position === 'before' ? 0 : 1;\n  anchor = Array.isArray(anchor) ? anchor : [anchor];\n\n  for (const currentAnchor of anchor) {\n    for (let i = 0; i < target.length; i++) {\n      if (target[i].name === currentAnchor) {\n        return {\n          result: [\n            ...target.slice(0, i + offset),\n            { ...item, key: namePath.join('/') + '/' + item.name },\n            ...target.slice(i + offset),\n          ],\n          matched: true,\n        };\n      }\n\n      if (target[i].children) {\n        const { result, matched } = insert(\n          position,\n          currentAnchor,\n          namePath.concat(target[i].name),\n          target[i].children,\n          item,\n        );\n        if (matched) {\n          return {\n            result: target.map((item, index) =>\n              index === i\n                ? {\n                    ...item,\n                    children: result,\n                  }\n                : item,\n            ),\n            matched: true,\n          };\n        }\n      }\n    }\n  }\n\n  return {\n    result: target,\n    matched: false,\n  };\n}\n\nfunction genItemKey(\n  item: RemoteNavigationItem,\n  parentKey: string = '',\n): RemoteNavigationItem {\n  const currentKey = item.key ?? item.name;\n  const key = parentKey ? parentKey + '/' + currentKey : currentKey;\n  return {\n    ...item,\n    key,\n    children: item.children?.map(c => genItemKey(c, key)),\n  };\n}\n"]}
@@ -1,10 +1,10 @@
1
- import { attachAuthorizationHeader, isLocalDev } from '@alauda-fe/common';
2
- import { getBootMode, LOCAL_DEV_EXTENSION_INFO } from './utils';
1
+ import { attachAuthorizationHeader } from '@alauda-fe/common';
2
+ import { getBootMode, LOCAL_DEV_EXTENSION_INFO, isLocalEnv } from './utils';
3
3
  export async function loadExtensions(query = {}) {
4
4
  if (getBootMode() === 'safe') {
5
5
  return [];
6
6
  }
7
- return isLocalDev()
7
+ return isLocalEnv()
8
8
  ? await loadDevExtensions(query)
9
9
  : await loadProdExtensions(query);
10
10
  }
@@ -20,6 +20,7 @@ async function loadDevExtensions(query = {}) {
20
20
  ...LOCAL_DEV_EXTENSION_INFO,
21
21
  ...ext,
22
22
  dependencies: plugin.dependencies || {},
23
+ i18nVersion: plugin.i18nVersion,
23
24
  entrypoint: '/dev-plugin',
24
25
  })))
25
26
  .catch(() => {
@@ -28,7 +29,7 @@ async function loadDevExtensions(query = {}) {
28
29
  });
29
30
  }
30
31
  async function loadProdExtensions(query = {}) {
31
- const reqPrefix = isLocalDev() ? '/api-gateway' : '';
32
+ const reqPrefix = isLocalEnv() ? '/api-gateway' : '';
32
33
  const queryString = Object.entries(query)
33
34
  .map(([key, value]) => `${key}=${value.join(',')}`)
34
35
  .join(';');
@@ -42,22 +43,29 @@ async function loadProdExtensions(query = {}) {
42
43
  return res.json();
43
44
  })
44
45
  .then((rawPlugins) => Object.entries(rawPlugins).reduce((acc, [cluster, plugins]) => acc.concat(plugins.flatMap(plugin => {
45
- const pluginJson = JSON.parse(plugin['console-plugin.json']);
46
- return pluginJson.extensions.map(ext => ({
47
- ...ext,
48
- cluster,
49
- pluginName: plugin.name,
50
- pluginVersion: plugin.version,
51
- appName: plugin.path
52
- .slice(plugin.path.lastIndexOf('/') + 1)
53
- .replaceAll('/', '-'),
54
- entrypoint: `${reqPrefix}/clusters-rewrite/${cluster}${plugin.path}`,
55
- dependencies: pluginJson.dependencies || {},
56
- }));
46
+ try {
47
+ const pluginJson = JSON.parse(plugin['console-plugin.json']);
48
+ return pluginJson.extensions.map(ext => ({
49
+ ...ext,
50
+ cluster,
51
+ pluginName: plugin.name,
52
+ pluginVersion: plugin.version,
53
+ appName: plugin.path
54
+ .slice(plugin.path.lastIndexOf('/') + 1)
55
+ .replaceAll('/', '-'),
56
+ entrypoint: `${reqPrefix}/clusters-rewrite/${cluster}${plugin.path}`,
57
+ dependencies: pluginJson.dependencies || {},
58
+ i18nVersion: pluginJson.i18nVersion,
59
+ }));
60
+ }
61
+ catch (error) {
62
+ console.error(`Failed to parse console-plugin.json for plugin ${plugin.name}:`, error);
63
+ return [];
64
+ }
57
65
  })), []))
58
66
  .catch(err => {
59
67
  console.error(err);
60
68
  return [];
61
69
  });
62
70
  }
63
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"extensions-loader.js","sourceRoot":"","sources":["../../../../../libs/plugin-sdk/src/lib/extensions-loader.ts"],"names":[],"mappings":"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","sourcesContent":["import { attachAuthorizationHeader, isLocalDev } from '@alauda-fe/common';\n\nimport { getBootMode, LOCAL_DEV_EXTENSION_INFO } from './utils';\n\nexport async function loadExtensions(query: ExtensionsQuery = {}) {\n  if (getBootMode() === 'safe') {\n    return [];\n  }\n  return isLocalDev()\n    ? await loadDevExtensions(query)\n    : await loadProdExtensions(query);\n}\n\nasync function loadDevExtensions(\n  query: ExtensionsQuery = {},\n): Promise<Extension[]> {\n  return await fetch(`/dev-plugin/console-plugin.json`)\n    .then(res => {\n      if (!res.ok) {\n        throw new Error('Failed to fetch local dev extensions');\n      }\n      return res.json();\n    })\n    .then((plugin: PluginJSON) =>\n      plugin.extensions.map(ext => ({\n        ...LOCAL_DEV_EXTENSION_INFO,\n        ...ext,\n        dependencies: plugin.dependencies || {},\n        entrypoint: '/dev-plugin',\n      })),\n    )\n    .catch(() => {\n      console.warn(\n        'Failed to fetch local dev extensions, loading prod extensions',\n      );\n      return loadProdExtensions(query);\n    });\n}\n\nasync function loadProdExtensions(\n  query: ExtensionsQuery = {},\n): Promise<Extension[]> {\n  const reqPrefix = isLocalDev() ? '/api-gateway' : '';\n  const queryString = Object.entries(query)\n    .map(([key, value]) => `${key}=${value.join(',')}`)\n    .join(';');\n\n  return await fetch(\n    `${reqPrefix}/frontend-plugins/clusters/console-plugins${queryString && '?filter=' + encodeURIComponent(queryString)}`,\n    {\n      headers: attachAuthorizationHeader(),\n    },\n  )\n    .then(res => {\n      if (!res.ok) {\n        throw new Error('Failed to fetch extensions');\n      }\n      return res.json();\n    })\n    .then((rawPlugins: RawPlugins) =>\n      Object.entries(rawPlugins).reduce(\n        (acc, [cluster, plugins]) =>\n          acc.concat(\n            plugins.flatMap(plugin => {\n              const pluginJson = JSON.parse(\n                plugin['console-plugin.json'],\n              ) as PluginJSON;\n\n              return pluginJson.extensions.map(ext => ({\n                ...ext,\n                cluster,\n                pluginName: plugin.name,\n                pluginVersion: plugin.version,\n                appName: plugin.path\n                  .slice(plugin.path.lastIndexOf('/') + 1)\n                  .replaceAll('/', '-'),\n                entrypoint: `${reqPrefix}/clusters-rewrite/${cluster}${plugin.path}`,\n                dependencies: pluginJson.dependencies || {},\n              }));\n            }),\n          ),\n        [] as Extension[],\n      ),\n    )\n    .catch(err => {\n      console.error(err);\n      return [];\n    });\n}\n\nexport interface ExtensionsQuery {\n  types?: string[];\n  clusters?: string[];\n  operators?: string[];\n  channels?: string[];\n}\n\nexport interface Extension<T = any> extends RawExtension<T> {\n  cluster: string;\n  pluginName: string;\n  pluginVersion: string;\n  appName: string;\n  entrypoint: string;\n  dependencies: Record<string, string>;\n}\n\ninterface RawPlugins {\n  [cluster: string]: Array<{\n    operator: string;\n    name: string;\n    version: string;\n    path: string;\n    'console-plugin.json': string;\n  }>;\n}\n\ninterface PluginJSON {\n  extensions: RawExtension[];\n  dependencies?: Record<string, string>;\n}\n\ninterface RawExtension<T = any> {\n  type: string;\n  options: T;\n}\n"]}
71
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"extensions-loader.js","sourceRoot":"","sources":["../../../../../libs/plugin-sdk/src/lib/extensions-loader.ts"],"names":[],"mappings":"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","sourcesContent":["import { attachAuthorizationHeader } from '@alauda-fe/common';\n\nimport { getBootMode, LOCAL_DEV_EXTENSION_INFO, isLocalEnv } from './utils';\n\nexport async function loadExtensions(query: ExtensionsQuery = {}) {\n  if (getBootMode() === 'safe') {\n    return [];\n  }\n  return isLocalEnv()\n    ? await loadDevExtensions(query)\n    : await loadProdExtensions(query);\n}\n\nasync function loadDevExtensions(\n  query: ExtensionsQuery = {},\n): Promise<Extension[]> {\n  return await fetch(`/dev-plugin/console-plugin.json`)\n    .then(res => {\n      if (!res.ok) {\n        throw new Error('Failed to fetch local dev extensions');\n      }\n      return res.json();\n    })\n    .then((plugin: PluginJSON) =>\n      plugin.extensions.map(ext => ({\n        ...LOCAL_DEV_EXTENSION_INFO,\n        ...ext,\n        dependencies: plugin.dependencies || {},\n        i18nVersion: plugin.i18nVersion,\n        entrypoint: '/dev-plugin',\n      })),\n    )\n    .catch(() => {\n      console.warn(\n        'Failed to fetch local dev extensions, loading prod extensions',\n      );\n      return loadProdExtensions(query);\n    });\n}\n\nasync function loadProdExtensions(\n  query: ExtensionsQuery = {},\n): Promise<Extension[]> {\n  const reqPrefix = isLocalEnv() ? '/api-gateway' : '';\n  const queryString = Object.entries(query)\n    .map(([key, value]) => `${key}=${value.join(',')}`)\n    .join(';');\n\n  return await fetch(\n    `${reqPrefix}/frontend-plugins/clusters/console-plugins${queryString && '?filter=' + encodeURIComponent(queryString)}`,\n    {\n      headers: attachAuthorizationHeader(),\n    },\n  )\n    .then(res => {\n      if (!res.ok) {\n        throw new Error('Failed to fetch extensions');\n      }\n      return res.json();\n    })\n    .then((rawPlugins: RawPlugins) =>\n      Object.entries(rawPlugins).reduce(\n        (acc, [cluster, plugins]) =>\n          acc.concat(\n            plugins.flatMap(plugin => {\n              try {\n                const pluginJson = JSON.parse(\n                  plugin['console-plugin.json'],\n                ) as PluginJSON;\n\n                return pluginJson.extensions.map(ext => ({\n                  ...ext,\n                  cluster,\n                  pluginName: plugin.name,\n                  pluginVersion: plugin.version,\n                  appName: plugin.path\n                    .slice(plugin.path.lastIndexOf('/') + 1)\n                    .replaceAll('/', '-'),\n                  entrypoint: `${reqPrefix}/clusters-rewrite/${cluster}${plugin.path}`,\n                  dependencies: pluginJson.dependencies || {},\n                  i18nVersion: pluginJson.i18nVersion,\n                }));\n              } catch (error) {\n                console.error(\n                  `Failed to parse console-plugin.json for plugin ${plugin.name}:`,\n                  error,\n                );\n                return [];\n              }\n            }),\n          ),\n        [] as Extension[],\n      ),\n    )\n    .catch(err => {\n      console.error(err);\n      return [];\n    });\n}\n\nexport interface ExtensionsQuery {\n  types?: string[];\n  clusters?: string[];\n  operators?: string[];\n  channels?: string[];\n}\n\nexport interface Extension<T = any> extends RawExtension<T> {\n  cluster: string;\n  pluginName: string;\n  pluginVersion: string;\n  appName: string;\n  entrypoint: string;\n  dependencies: Record<string, string>;\n  i18nVersion?: string;\n}\n\ninterface RawPlugins {\n  [cluster: string]: Array<{\n    name: string;\n    version: string;\n    path: string;\n    'console-plugin.json': string;\n  }>;\n}\n\ninterface PluginJSON {\n  extensions: RawExtension[];\n  dependencies?: Record<string, string>;\n  i18nVersion?: string;\n}\n\ninterface RawExtension<T = any> {\n  type: string;\n  options: T;\n}\n"]}
@@ -3,9 +3,6 @@ import { loadRemoteModule, setRemoteDefinitions } from '@nx/angular/mf';
3
3
  import { compare } from 'compare-versions';
4
4
  const remoteRecord = new Set();
5
5
  const BOOT_MODE_KEY = '__boot_mode__';
6
- /**
7
- * @deprecated Use isLocalDev from @alauda-fe/common instead
8
- */
9
6
  export function isLocalEnv() {
10
7
  return location.hostname === 'localhost';
11
8
  }
@@ -65,10 +62,16 @@ export function filterLatestVersion(identity) {
65
62
  return acc;
66
63
  }, []);
67
64
  }
68
- export const translateScope = ({ cluster, pluginName, appName, }, locale) => isBuiltInLanguage(locale)
69
- ? `plugin__${cluster}~${pluginName}~${appName}`
70
- : `plugin__${pluginName}~${appName}`;
65
+ export const translateScope = (extension, locale) => {
66
+ if (isBuiltInLanguage(locale)) {
67
+ return `plugin__${extension.cluster}~${extension.pluginName}~${extension.appName}`;
68
+ }
69
+ const baseScope = `plugin__${extension.pluginName}~${extension.appName}`;
70
+ return extension.i18nVersion
71
+ ? `${baseScope}~${extension.i18nVersion}`
72
+ : baseScope;
73
+ };
71
74
  export const translateScopeKey = (scope, key) => {
72
75
  return `${scope}.${key}`;
73
76
  };
74
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3BsdWdpbi1zZGsvc3JjL2xpYi91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDdEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBSTNDLE1BQU0sWUFBWSxHQUFHLElBQUksR0FBRyxFQUFVLENBQUM7QUFFdkMsTUFBTSxhQUFhLEdBQUcsZUFBZSxDQUFDO0FBRXRDOztHQUVHO0FBQ0gsTUFBTSxVQUFVLFVBQVU7SUFDeEIsT0FBTyxRQUFRLENBQUMsUUFBUSxLQUFLLFdBQVcsQ0FBQztBQUMzQyxDQUFDO0FBRUQsTUFBTSxVQUFVLGtCQUFrQixDQUFDLFVBQWtCO0lBQ25ELE9BQU8sVUFBVSxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsQ0FBQztBQUMzQyxDQUFDO0FBRUQsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUc7SUFDdEMsT0FBTyxFQUFFLGNBQWM7SUFDdkIsVUFBVSxFQUFFLFdBQVc7SUFDdkIsYUFBYSxFQUFFLFFBQVE7SUFDdkIsT0FBTyxFQUFFLFNBQVM7Q0FDbkIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHO0lBQ25DLE9BQU8sRUFBRSxjQUFjO0lBQ3ZCLGFBQWEsRUFBRSxRQUFRO0lBQ3ZCLE9BQU8sRUFBRSxTQUFTO0NBQ25CLENBQUM7QUFFRixNQUFNLFVBQVUsV0FBVztJQUN6QixNQUFNLEtBQUssR0FBRyxRQUFRLENBQUMsTUFBTTtTQUMxQixLQUFLLENBQUMsQ0FBQyxDQUFDO1NBQ1IsS0FBSyxDQUFDLEdBQUcsQ0FBQztTQUNWLE1BQU0sQ0FDTCxDQUFDLEdBQUcsRUFB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RUFBRSxHQUFXLEVBQUUsRUFBRTtJQUM5RCxPQUFPLEdBQUcsS0FBSyxJQUFJLEdBQUcsRUFBRSxDQUFDO0FBQzNCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdMT0JBTF9DTFVTVEVSLCBpc0J1aWx0SW5MYW5ndWFnZSB9IGZyb20gJ0BhbGF1ZGEtZmUvY29tbW9uJztcbmltcG9ydCB7IGxvYWRSZW1vdGVNb2R1bGUsIHNldFJlbW90ZURlZmluaXRpb25zIH0gZnJvbSAnQG54L2FuZ3VsYXIvbWYnO1xuaW1wb3J0IHsgY29tcGFyZSB9IGZyb20gJ2NvbXBhcmUtdmVyc2lvbnMnO1xuXG5pbXBvcnQgeyBFeHRlbnNpb24gfSBmcm9tICcuL2V4dGVuc2lvbnMtbG9hZGVyJztcblxuY29uc3QgcmVtb3RlUmVjb3JkID0gbmV3IFNldDxzdHJpbmc+KCk7XG5cbmNvbnN0IEJPT1RfTU9ERV9LRVkgPSAnX19ib290X21vZGVfXyc7XG5cbi8qKlxuICogQGRlcHJlY2F0ZWQgVXNlIGlzTG9jYWxEZXYgZnJvbSBAYWxhdWRhLWZlL2NvbW1vbiBpbnN0ZWFkXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc0xvY2FsRW52KCkge1xuICByZXR1cm4gbG9jYXRpb24uaG9zdG5hbWUgPT09ICdsb2NhbGhvc3QnO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNTdGF0aWNQbHVnaW5QYXRoKHB1YmxpY1BhdGg6IHN0cmluZykge1xuICByZXR1cm4gcHVibGljUGF0aC5pbmNsdWRlcygnL19wbHVnaW5zLycpO1xufVxuXG5leHBvcnQgY29uc3QgTE9DQUxfREVWX0VYVEVOU0lPTl9JTkZPID0ge1xuICBjbHVzdGVyOiBHTE9CQUxfQ0xVU1RFUixcbiAgcGx1Z2luTmFtZTogJ2xvY2FsLWRldicsXG4gIHBsdWdpblZlcnNpb246ICd2MS4wLjAnLFxuICBhcHBOYW1lOiAnZGVmYXVsdCcsXG59O1xuXG5leHBvcnQgY29uc3QgU1RBVElDX0VYVEVOU0lPTl9JTkZPID0ge1xuICBjbHVzdGVyOiBHTE9CQUxfQ0xVU1RFUixcbiAgcGx1Z2luVmVyc2lvbjogJ3YxLjAuMCcsXG4gIGFwcE5hbWU6ICdkZWZhdWx0Jyxcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRCb290TW9kZSgpOiAnc3RhbmRhcmQnIHwgJ3NhZmUnIHtcbiAgY29uc3QgcXVlcnkgPSBsb2NhdGlvbi5zZWFyY2hcbiAgICAuc2xpY2UoMSlcbiAgICAuc3BsaXQoJyYnKVxuICAgIC5yZWR1Y2UoXG4gICAgICAoYWNjLCBjdXIpID0+IHtcbiAgICAgICAgY29uc3QgW2tleSwgdmFsdWVdID0gY3VyLnNwbGl0KCc9Jyk7XG4gICAgICAgIGFjY1trZXldID0gdmFsdWU7XG4gICAgICAgIHJldHVybiBhY2M7XG4gICAgICB9LFxuICAgICAge30gYXMgUmVjb3JkPHN0cmluZywgc3RyaW5nPixcbiAgICApO1xuICBjb25zdCBtb2RlID0gKHF1ZXJ5W0JPT1RfTU9ERV9LRVldIHx8XG4gICAgc2Vzc2lvblN0b3JhZ2UuZ2V0SXRlbShCT09UX01PREVfS0VZKSB8fFxuICAgICdzdGFuZGFyZCcpIGFzICdzdGFuZGFyZCcgfCAnc2FmZSc7XG5cbiAgc2Vzc2lvblN0b3JhZ2Uuc2V0SXRlbShCT09UX01PREVfS0VZLCBtb2RlKTtcblxuICByZXR1cm4gbW9kZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGxvYWRSZW1vdGUocmVtb3RlOiBzdHJpbmcsIG1vZHVsZTogc3RyaW5nKSB7XG4gIGlmICghcmVtb3RlUmVjb3JkLmhhcyhyZW1vdGUpKSB7XG4gICAgcmVtb3RlUmVjb3JkLmFkZChyZW1vdGUpO1xuICAgIHNldFJlbW90ZURlZmluaXRpb25zKHsgW3JlbW90ZV06IHJlbW90ZSB9KTtcbiAgfVxuXG4gIHJldHVybiBsb2FkUmVtb3RlTW9kdWxlKHJlbW90ZSwgbW9kdWxlKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZpbHRlckxhdGVzdFZlcnNpb248TyA9IGFueT4oXG4gIGlkZW50aXR5OiAoZXh0OiBPKSA9PiB1bmtub3duLFxuKTogKGV4dHM6IEFycmF5PEV4dGVuc2lvbjxPPj4pID0+IEFycmF5PEV4dGVuc2lvbjxPPj4ge1xuICByZXR1cm4gKGV4dHM6IEFycmF5PEV4dGVuc2lvbjxPPj4pID0+XG4gICAgZXh0cy5yZWR1Y2UoXG4gICAgICAoYWNjLCBleHQpID0+IHtcbiAgICAgICAgY29uc3QgZXhpc3RlZEluZGV4ID0gYWNjLmZpbmRJbmRleChcbiAgICAgICAgICBhID0+XG4gICAgICAgICAgICBhLnBsdWdpbk5hbWUgPT09IGV4dC5wbHVnaW5OYW1lICYmXG4gICAgICAgICAgICBpZGVudGl0eShhLm9wdGlvbnMpID09PSBpZGVudGl0eShleHQub3B0aW9ucyksXG4gICAgICAgICk7XG4gICAgICAgIGlmIChleGlzdGVkSW5kZXggPT09IC0xKSB7XG4gICAgICAgICAgYWNjLnB1c2goZXh0KTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgYWNjW2V4aXN0ZWRJbmRleF0gPSBjb21wYXJlKFxuICAgICAgICAgICAgICBhY2NbZXhpc3RlZEluZGV4XS5wbHVnaW5WZXJzaW9uLFxuICAgICAgICAgICAgICBleHQucGx1Z2luVmVyc2lvbixcbiAgICAgICAgICAgICAgJz49JyxcbiAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgPyBhY2NbZXhpc3RlZEluZGV4XVxuICAgICAgICAgICAgICA6IGV4dDtcbiAgICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICAgICAgICAgIGBFcnJvciB3aGVuIGNvbXBhcmluZyBvcGVyYXRvciAoJHthY2NbZXhpc3RlZEluZGV4XS5wbHVnaW5OYW1lfSkgdmVyc2lvbnMgKCR7YWNjW2V4aXN0ZWRJbmRleF0ucGx1Z2luVmVyc2lvbn0sICR7ZXh0LnBsdWdpblZlcnNpb259KS4gVXNpbmcgJHthY2NbZXhpc3RlZEluZGV4XS5wbHVnaW5WZXJzaW9ufSBmcm9tIGNsdXN0ZXIgJHthY2NbZXhpc3RlZEluZGV4XS5jbHVzdGVyfWAsXG4gICAgICAgICAgICApO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gYWNjO1xuICAgICAgfSxcbiAgICAgIFtdIGFzIEFycmF5PEV4dGVuc2lvbjxPPj4sXG4gICAgKTtcbn1cblxuZXhwb3J0IGNvbnN0IHRyYW5zbGF0ZVNjb3BlID0gKFxuICB7XG4gICAgY2x1c3RlcixcbiAgICBwbHVnaW5OYW1lLFxuICAgIGFwcE5hbWUsXG4gIH06IHtcbiAgICBjbHVzdGVyOiBzdHJpbmc7XG4gICAgcGx1Z2luTmFtZTogc3RyaW5nO1xuICAgIGFwcE5hbWU6IHN0cmluZztcbiAgfSxcbiAgbG9jYWxlOiBzdHJpbmcsXG4pID0+XG4gIGlzQnVpbHRJbkxhbmd1YWdlKGxvY2FsZSlcbiAgICA/IGBwbHVnaW5fXyR7Y2x1c3Rlcn1+JHtwbHVnaW5OYW1lfX4ke2FwcE5hbWV9YFxuICAgIDogYHBsdWdpbl9fJHtwbHVnaW5OYW1lfX4ke2FwcE5hbWV9YDtcblxuZXhwb3J0IGNvbnN0IHRyYW5zbGF0ZVNjb3BlS2V5ID0gKHNjb3BlOiBzdHJpbmcsIGtleTogc3RyaW5nKSA9PiB7XG4gIHJldHVybiBgJHtzY29wZX0uJHtrZXl9YDtcbn07XG4iXX0=
77
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../libs/plugin-sdk/src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { GLOBAL_CLUSTER, isBuiltInLanguage } from '@alauda-fe/common';\nimport { loadRemoteModule, setRemoteDefinitions } from '@nx/angular/mf';\nimport { compare } from 'compare-versions';\n\nimport { Extension } from './extensions-loader';\n\nconst remoteRecord = new Set<string>();\n\nconst BOOT_MODE_KEY = '__boot_mode__';\n\nexport function isLocalEnv() {\n  return location.hostname === 'localhost';\n}\n\nexport function isStaticPluginPath(publicPath: string) {\n  return publicPath.includes('/_plugins/');\n}\n\nexport const LOCAL_DEV_EXTENSION_INFO = {\n  cluster: GLOBAL_CLUSTER,\n  pluginName: 'local-dev',\n  pluginVersion: 'v1.0.0',\n  appName: 'default',\n};\n\nexport const STATIC_EXTENSION_INFO = {\n  cluster: GLOBAL_CLUSTER,\n  pluginVersion: 'v1.0.0',\n  appName: 'default',\n};\n\nexport function getBootMode(): 'standard' | 'safe' {\n  const query = location.search\n    .slice(1)\n    .split('&')\n    .reduce(\n      (acc, cur) => {\n        const [key, value] = cur.split('=');\n        acc[key] = value;\n        return acc;\n      },\n      {} as Record<string, string>,\n    );\n  const mode = (query[BOOT_MODE_KEY] ||\n    sessionStorage.getItem(BOOT_MODE_KEY) ||\n    'standard') as 'standard' | 'safe';\n\n  sessionStorage.setItem(BOOT_MODE_KEY, mode);\n\n  return mode;\n}\n\nexport function loadRemote(remote: string, module: string) {\n  if (!remoteRecord.has(remote)) {\n    remoteRecord.add(remote);\n    setRemoteDefinitions({ [remote]: remote });\n  }\n\n  return loadRemoteModule(remote, module);\n}\n\nexport function filterLatestVersion<O = any>(\n  identity: (ext: O) => unknown,\n): (exts: Array<Extension<O>>) => Array<Extension<O>> {\n  return (exts: Array<Extension<O>>) =>\n    exts.reduce(\n      (acc, ext) => {\n        const existedIndex = acc.findIndex(\n          a =>\n            a.pluginName === ext.pluginName &&\n            identity(a.options) === identity(ext.options),\n        );\n        if (existedIndex === -1) {\n          acc.push(ext);\n        } else {\n          try {\n            acc[existedIndex] = compare(\n              acc[existedIndex].pluginVersion,\n              ext.pluginVersion,\n              '>=',\n            )\n              ? acc[existedIndex]\n              : ext;\n          } catch {\n            console.error(\n              `Error when comparing operator (${acc[existedIndex].pluginName}) versions (${acc[existedIndex].pluginVersion}, ${ext.pluginVersion}). Using ${acc[existedIndex].pluginVersion} from cluster ${acc[existedIndex].cluster}`,\n            );\n          }\n        }\n        return acc;\n      },\n      [] as Array<Extension<O>>,\n    );\n}\n\nexport const translateScope = (\n  extension: {\n    cluster: string;\n    pluginName: string;\n    appName: string;\n    i18nVersion?: string;\n  },\n  locale: string,\n) => {\n  if (isBuiltInLanguage(locale)) {\n    return `plugin__${extension.cluster}~${extension.pluginName}~${extension.appName}`;\n  }\n\n  const baseScope = `plugin__${extension.pluginName}~${extension.appName}`;\n\n  return extension.i18nVersion\n    ? `${baseScope}~${extension.i18nVersion}`\n    : baseScope;\n};\n\nexport const translateScopeKey = (scope: string, key: string) => {\n  return `${scope}.${key}`;\n};\n"]}
@@ -1,9 +1,8 @@
1
- import { isLocalDev } from '@alauda-fe/common';
2
- import { isStaticPluginPath, LOCAL_DEV_EXTENSION_INFO, STATIC_EXTENSION_INFO, } from '@alauda-fe/plugin-sdk';
1
+ import { isStaticPluginPath, LOCAL_DEV_EXTENSION_INFO, STATIC_EXTENSION_INFO, isLocalEnv, } from '@alauda-fe/plugin-sdk';
3
2
  export const PUBLIC_PATH = __webpack_public_path__;
4
3
  export const RUNTIME = runtimeInfo();
5
4
  function runtimeInfo() {
6
- if (isLocalDev()) {
5
+ if (isLocalEnv()) {
7
6
  return {
8
7
  ...LOCAL_DEV_EXTENSION_INFO,
9
8
  publicPath: PUBLIC_PATH,
@@ -28,4 +27,4 @@ function runtimeInfo() {
28
27
  appName: arr.slice(pluginIndex + 3, arr.length - 1).join('-'),
29
28
  };
30
29
  }
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcGx1Z2luLXNkay9yZW1vdGUvbGliL3J1bnRpbWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRS9DLE9BQU8sRUFDTCxrQkFBa0IsRUFDbEIsd0JBQXdCLEVBQ3hCLHFCQUFxQixHQUN0QixNQUFNLHVCQUF1QixDQUFDO0FBSS9CLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyx1QkFBdUIsQ0FBQztBQUVuRCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsV0FBVyxFQUFFLENBQUM7QUFFckMsU0FBUyxXQUFXO0lBQ2xCLElBQUksVUFBVSxFQUFFLEVBQUUsQ0FBQztRQUNqQixPQUFPO1lBQ0wsR0FBRyx3QkFBd0I7WUFDM0IsVUFBVSxFQUFFLFdBQVc7U0FDeEIsQ0FBQztJQUNKLENBQUM7SUFDRCxNQUFNLEdBQUcsR0FBRyxXQUFXLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRW5DLElBQUksa0JBQWtCLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztRQUNwQyxNQUFNLFdBQVcsR0FBRyxHQUFHLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxLQUFLLFVBQVUsQ0FBQyxDQUFDO1FBRS9ELE9BQU87WUFDTCxHQUFHLHFCQUFxQjtZQUN4QixVQUFVLEVBQUUsR0FBRyxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUM7WUFDaEMsVUFBVSxFQUFFLFdBQVc7U0FDeEIsQ0FBQztJQUNKLENBQUM7SUFFRCxNQUFNLFlBQVksR0FBRyxHQUFHLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxLQUFLLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRTVFLE1BQU0sV0FBVyxHQUFHLEdBQUcsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLEtBQUssa0JBQWtCLENBQUMsR0FBRyxDQUFDLENBQUM7SUFFM0UsT0FBTztRQUNMLFVBQVUsRUFBRSxXQUFXO1FBQ3ZCLE9BQU8sRUFBRSxHQUFHLENBQUMsWUFBWSxDQUFDO1FBQzFCLFVBQVUsRUFBRSxHQUFHLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQztRQUNoQyxhQUFhLEVBQUUsR0FBRyxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUM7UUFDbkMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxLQUFLLENBQUMsV0FBVyxHQUFHLENBQUMsRUFBRSxHQUFHLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7S0FDOUQsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc0xvY2FsRGV2IH0gZnJvbSAnQGFsYXVkYS1mZS9jb21tb24nO1xuXG5pbXBvcnQge1xuICBpc1N0YXRpY1BsdWdpblBhdGgsXG4gIExPQ0FMX0RFVl9FWFRFTlNJT05fSU5GTyxcbiAgU1RBVElDX0VYVEVOU0lPTl9JTkZPLFxufSBmcm9tICdAYWxhdWRhLWZlL3BsdWdpbi1zZGsnO1xuXG5kZWNsYXJlIGNvbnN0IF9fd2VicGFja19wdWJsaWNfcGF0aF9fOiBzdHJpbmc7XG5cbmV4cG9ydCBjb25zdCBQVUJMSUNfUEFUSCA9IF9fd2VicGFja19wdWJsaWNfcGF0aF9fO1xuXG5leHBvcnQgY29uc3QgUlVOVElNRSA9IHJ1bnRpbWVJbmZvKCk7XG5cbmZ1bmN0aW9uIHJ1bnRpbWVJbmZvKCk6IFJ1bnRpbWUge1xuICBpZiAoaXNMb2NhbERldigpKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLkxPQ0FMX0RFVl9FWFRFTlNJT05fSU5GTyxcbiAgICAgIHB1YmxpY1BhdGg6IFBVQkxJQ19QQVRILFxuICAgIH07XG4gIH1cbiAgY29uc3QgYXJyID0gUFVCTElDX1BBVEguc3BsaXQoJy8nKTtcblxuICBpZiAoaXNTdGF0aWNQbHVnaW5QYXRoKFBVQkxJQ19QQVRIKSkge1xuICAgIGNvbnN0IHBsdWdpbkluZGV4ID0gYXJyLmZpbmRJbmRleChpdGVtID0+IGl0ZW0gPT09ICdfcGx1Z2lucycpO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLlNUQVRJQ19FWFRFTlNJT05fSU5GTyxcbiAgICAgIHBsdWdpbk5hbWU6IGFycltwbHVnaW5JbmRleCArIDFdLFxuICAgICAgcHVibGljUGF0aDogUFVCTElDX1BBVEgsXG4gICAgfTtcbiAgfVxuXG4gIGNvbnN0IGNsdXN0ZXJJbmRleCA9IGFyci5maW5kSW5kZXgoaXRlbSA9PiBpdGVtID09PSAnY2x1c3RlcnMtcmV3cml0ZScpICsgMTtcblxuICBjb25zdCBwbHVnaW5JbmRleCA9IGFyci5maW5kSW5kZXgoaXRlbSA9PiBpdGVtID09PSAnZnJvbnRlbmQtcGx1Z2lucycpICsgMTtcblxuICByZXR1cm4ge1xuICAgIHB1YmxpY1BhdGg6IFBVQkxJQ19QQVRILFxuICAgIGNsdXN0ZXI6IGFycltjbHVzdGVySW5kZXhdLFxuICAgIHBsdWdpbk5hbWU6IGFycltwbHVnaW5JbmRleCArIDFdLFxuICAgIHBsdWdpblZlcnNpb246IGFycltwbHVnaW5JbmRleCArIDJdLFxuICAgIGFwcE5hbWU6IGFyci5zbGljZShwbHVnaW5JbmRleCArIDMsIGFyci5sZW5ndGggLSAxKS5qb2luKCctJyksXG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUnVudGltZSB7XG4gIHB1YmxpY1BhdGg6IHN0cmluZztcbiAgY2x1c3Rlcjogc3RyaW5nO1xuICBwbHVnaW5OYW1lOiBzdHJpbmc7XG4gIHBsdWdpblZlcnNpb246IHN0cmluZztcbiAgYXBwTmFtZTogc3RyaW5nO1xufVxuIl19
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcGx1Z2luLXNkay9yZW1vdGUvbGliL3J1bnRpbWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLGtCQUFrQixFQUNsQix3QkFBd0IsRUFDeEIscUJBQXFCLEVBQ3JCLFVBQVUsR0FDWCxNQUFNLHVCQUF1QixDQUFDO0FBSS9CLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyx1QkFBdUIsQ0FBQztBQUVuRCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsV0FBVyxFQUFFLENBQUM7QUFFckMsU0FBUyxXQUFXO0lBQ2xCLElBQUksVUFBVSxFQUFFLEVBQUUsQ0FBQztRQUNqQixPQUFPO1lBQ0wsR0FBRyx3QkFBd0I7WUFDM0IsVUFBVSxFQUFFLFdBQVc7U0FDeEIsQ0FBQztJQUNKLENBQUM7SUFDRCxNQUFNLEdBQUcsR0FBRyxXQUFXLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRW5DLElBQUksa0JBQWtCLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztRQUNwQyxNQUFNLFdBQVcsR0FBRyxHQUFHLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxLQUFLLFVBQVUsQ0FBQyxDQUFDO1FBRS9ELE9BQU87WUFDTCxHQUFHLHFCQUFxQjtZQUN4QixVQUFVLEVBQUUsR0FBRyxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUM7WUFDaEMsVUFBVSxFQUFFLFdBQVc7U0FDeEIsQ0FBQztJQUNKLENBQUM7SUFFRCxNQUFNLFlBQVksR0FBRyxHQUFHLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxLQUFLLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRTVFLE1BQU0sV0FBVyxHQUFHLEdBQUcsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLEtBQUssa0JBQWtCLENBQUMsR0FBRyxDQUFDLENBQUM7SUFFM0UsT0FBTztRQUNMLFVBQVUsRUFBRSxXQUFXO1FBQ3ZCLE9BQU8sRUFBRSxHQUFHLENBQUMsWUFBWSxDQUFDO1FBQzFCLFVBQVUsRUFBRSxHQUFHLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQztRQUNoQyxhQUFhLEVBQUUsR0FBRyxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUM7UUFDbkMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxLQUFLLENBQUMsV0FBVyxHQUFHLENBQUMsRUFBRSxHQUFHLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7S0FDOUQsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBpc1N0YXRpY1BsdWdpblBhdGgsXG4gIExPQ0FMX0RFVl9FWFRFTlNJT05fSU5GTyxcbiAgU1RBVElDX0VYVEVOU0lPTl9JTkZPLFxuICBpc0xvY2FsRW52LFxufSBmcm9tICdAYWxhdWRhLWZlL3BsdWdpbi1zZGsnO1xuXG5kZWNsYXJlIGNvbnN0IF9fd2VicGFja19wdWJsaWNfcGF0aF9fOiBzdHJpbmc7XG5cbmV4cG9ydCBjb25zdCBQVUJMSUNfUEFUSCA9IF9fd2VicGFja19wdWJsaWNfcGF0aF9fO1xuXG5leHBvcnQgY29uc3QgUlVOVElNRSA9IHJ1bnRpbWVJbmZvKCk7XG5cbmZ1bmN0aW9uIHJ1bnRpbWVJbmZvKCk6IFJ1bnRpbWUge1xuICBpZiAoaXNMb2NhbEVudigpKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLkxPQ0FMX0RFVl9FWFRFTlNJT05fSU5GTyxcbiAgICAgIHB1YmxpY1BhdGg6IFBVQkxJQ19QQVRILFxuICAgIH07XG4gIH1cbiAgY29uc3QgYXJyID0gUFVCTElDX1BBVEguc3BsaXQoJy8nKTtcblxuICBpZiAoaXNTdGF0aWNQbHVnaW5QYXRoKFBVQkxJQ19QQVRIKSkge1xuICAgIGNvbnN0IHBsdWdpbkluZGV4ID0gYXJyLmZpbmRJbmRleChpdGVtID0+IGl0ZW0gPT09ICdfcGx1Z2lucycpO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLlNUQVRJQ19FWFRFTlNJT05fSU5GTyxcbiAgICAgIHBsdWdpbk5hbWU6IGFycltwbHVnaW5JbmRleCArIDFdLFxuICAgICAgcHVibGljUGF0aDogUFVCTElDX1BBVEgsXG4gICAgfTtcbiAgfVxuXG4gIGNvbnN0IGNsdXN0ZXJJbmRleCA9IGFyci5maW5kSW5kZXgoaXRlbSA9PiBpdGVtID09PSAnY2x1c3RlcnMtcmV3cml0ZScpICsgMTtcblxuICBjb25zdCBwbHVnaW5JbmRleCA9IGFyci5maW5kSW5kZXgoaXRlbSA9PiBpdGVtID09PSAnZnJvbnRlbmQtcGx1Z2lucycpICsgMTtcblxuICByZXR1cm4ge1xuICAgIHB1YmxpY1BhdGg6IFBVQkxJQ19QQVRILFxuICAgIGNsdXN0ZXI6IGFycltjbHVzdGVySW5kZXhdLFxuICAgIHBsdWdpbk5hbWU6IGFycltwbHVnaW5JbmRleCArIDFdLFxuICAgIHBsdWdpblZlcnNpb246IGFycltwbHVnaW5JbmRleCArIDJdLFxuICAgIGFwcE5hbWU6IGFyci5zbGljZShwbHVnaW5JbmRleCArIDMsIGFyci5sZW5ndGggLSAxKS5qb2luKCctJyksXG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUnVudGltZSB7XG4gIHB1YmxpY1BhdGg6IHN0cmluZztcbiAgY2x1c3Rlcjogc3RyaW5nO1xuICBwbHVnaW5OYW1lOiBzdHJpbmc7XG4gIHBsdWdpblZlcnNpb246IHN0cmluZztcbiAgYXBwTmFtZTogc3RyaW5nO1xufVxuIl19
@@ -1,8 +1,81 @@
1
- import { GLOBAL_CLUSTER, isBuiltInLanguage, TranslatePipe, TranslateService, } from '@alauda-fe/common';
1
+ import { NotificationService } from '@alauda/ui';
2
+ import { FALLBACK_LANGUAGE, GLOBAL_CLUSTER, isBuiltInLanguage, TranslatePipe, TranslateService, } from '@alauda-fe/common';
2
3
  import { inject, Injectable, Pipe } from '@angular/core';
3
4
  import { RUNTIME } from './runtime';
4
- import { translateScope, translateScopeKey } from '@alauda-fe/plugin-sdk';
5
+ import { translateScope, translateScopeKey, getAllExtensions, } from '@alauda-fe/plugin-sdk';
5
6
  import * as i0 from "@angular/core";
7
+ /**
8
+ * 获取扩展列表,支持新旧版本兼容(ACP <= v4.1)
9
+ * 优先使用新版 plugin-sdk 的 getAllExtensions 方法
10
+ * 回退到旧版本的全局变量 __alauda_extensions
11
+ */
12
+ function getExtensions() {
13
+ try {
14
+ // 尝试使用新版本的 getAllExtensions 方法
15
+ if (typeof getAllExtensions === 'function') {
16
+ return getAllExtensions();
17
+ }
18
+ }
19
+ catch (error) {
20
+ // getAllExtensions 不存在或调用失败时忽略错误
21
+ console.debug('getAllExtensions method not available or failed:', error);
22
+ }
23
+ // 回退到旧版本的全局变量
24
+ try {
25
+ const windowExtensions = window.__alauda_extensions;
26
+ if (Array.isArray(windowExtensions)) {
27
+ console.debug('Using fallback __alauda_extensions:', windowExtensions.length, 'extensions found');
28
+ return windowExtensions;
29
+ }
30
+ }
31
+ catch (error) {
32
+ console.debug('__alauda_extensions not available:', error);
33
+ }
34
+ // 两种方式都不可用时返回 null,功能将以降级模式运行
35
+ console.debug('No extension source available, running in fallback mode');
36
+ return null;
37
+ }
38
+ /**
39
+ * 获取当前插件的i18n版本号
40
+ * 如果无法获取扩展信息,返回 undefined,translateScope 将使用基础作用域
41
+ */
42
+ function getCurrentPluginI18nVersion() {
43
+ const extensions = getExtensions();
44
+ if (!extensions) {
45
+ console.debug('No extensions available, i18n will use base scope without version');
46
+ return undefined;
47
+ }
48
+ const currentExtension = extensions.find((ext) => ext.pluginName === RUNTIME.pluginName &&
49
+ ext.appName === RUNTIME.appName &&
50
+ ext.cluster === RUNTIME.cluster);
51
+ if (!currentExtension) {
52
+ console.debug('Current extension not found in extensions list, using base scope');
53
+ return undefined;
54
+ }
55
+ const version = currentExtension?.i18nVersion;
56
+ console.debug('Plugin i18n version:', version || 'not specified');
57
+ return version;
58
+ }
59
+ /**
60
+ * 获取i18n文件
61
+ */
62
+ function fetchI18nFile(lang, scope) {
63
+ const path = isBuiltInLanguage(lang)
64
+ ? RUNTIME.publicPath + 'assets/i18n/' + lang + '.json'
65
+ : `/console-i18n/${lang}/${scope}.json`;
66
+ return fetch(path)
67
+ .then(res => {
68
+ if (!res.ok) {
69
+ throw new Error(`HTTP ${res.status}: ${res.statusText}`);
70
+ }
71
+ return res.json();
72
+ })
73
+ .catch(err => {
74
+ console.error(`Failed to load i18n file for plugin ${RUNTIME.pluginName}~${RUNTIME.appName} and language ${lang}`);
75
+ console.error(err);
76
+ return null;
77
+ });
78
+ }
6
79
  export const getTranslateScope = (locale) => {
7
80
  const cluster = isBuiltInLanguage(locale) ? RUNTIME.cluster : GLOBAL_CLUSTER;
8
81
  return `plugin__${cluster}~${RUNTIME.pluginName}~${RUNTIME.appName}`;
@@ -10,51 +83,58 @@ export const getTranslateScope = (locale) => {
10
83
  export class TranslateScopeService {
11
84
  constructor() {
12
85
  this.translate = inject(TranslateService);
13
- this.loadedLang = new Set();
14
- this.scope = translateScope(RUNTIME, this.translate.locale);
15
- if (!this.translate.translationsList.find(item => item?.[this.translate.locale]?.[this.scope])) {
86
+ this.notification = inject(NotificationService);
87
+ this.scope = translateScope({
88
+ ...RUNTIME,
89
+ i18nVersion: getCurrentPluginI18nVersion(),
90
+ }, this.translate.locale);
91
+ const fallbackLangI18nLoaded = this.translate.translationsList.find(item => item?.[FALLBACK_LANGUAGE]?.[this.scope]);
92
+ if (!fallbackLangI18nLoaded) {
93
+ // 基座未预加载插件翻译文件时自行加载
16
94
  this.setupI18nAssets();
17
95
  }
96
+ else if (!isBuiltInLanguage(this.translate.locale)) {
97
+ this.checkTranslationAvailability();
98
+ }
18
99
  }
19
100
  getScopedKey(key) {
20
101
  return translateScopeKey(this.scope, key);
21
102
  }
103
+ checkTranslationAvailability() {
104
+ const currentLang = this.translate.locale;
105
+ const hasTranslation = this.translate.translationsList.find(item => item?.[currentLang]?.[this.scope]);
106
+ if (!hasTranslation) {
107
+ const fileName = `${this.scope}.json`;
108
+ this.notification.warning({
109
+ title: this.translate.get('translation_file_missing_warning'),
110
+ content: this.translate.get('plugin_missing_translation_file', {
111
+ pluginName: RUNTIME.pluginName,
112
+ appName: RUNTIME.appName,
113
+ lang: currentLang,
114
+ fileName,
115
+ }),
116
+ duration: 5000,
117
+ });
118
+ }
119
+ }
22
120
  async setupI18nAssets() {
23
121
  const lang = this.translate.locale;
24
122
  if (isBuiltInLanguage(lang)) {
25
123
  this.translate.addTranslations({
26
- [lang]: { [this.scope]: await this.loadTranslations(lang) },
124
+ [lang]: { [this.scope]: await fetchI18nFile(lang, this.scope) },
27
125
  });
28
126
  }
29
127
  else {
30
128
  const [en, other] = await Promise.all([
31
- this.loadTranslations('en'),
32
- this.loadTranslations(lang),
129
+ fetchI18nFile(this.translate.options.fallbackLocale, this.scope),
130
+ fetchI18nFile(lang, this.scope),
33
131
  ]);
34
132
  this.translate.addTranslations({
35
- [lang]: { [this.scope]: Object.assign(en, other) },
133
+ [FALLBACK_LANGUAGE]: { [this.scope]: en },
134
+ [lang]: { [this.scope]: other },
36
135
  });
37
136
  }
38
137
  }
39
- async loadTranslations(lang) {
40
- if (this.loadedLang.has(lang)) {
41
- return;
42
- }
43
- this.loadedLang.add(lang);
44
- return this.fetchI18nFile(lang);
45
- }
46
- fetchI18nFile(lang) {
47
- const path = isBuiltInLanguage(lang)
48
- ? RUNTIME.publicPath + 'assets/i18n/' + lang + '.json'
49
- : `/console-i18n/${lang}/plugin__${RUNTIME.pluginName}~${RUNTIME.appName}.json`;
50
- return fetch(path)
51
- .then(res => res.json())
52
- .catch(err => {
53
- console.error(`Failed to load i18n file for plugin ${RUNTIME.pluginName}~${RUNTIME.appName} and language ${lang}`);
54
- console.error(err);
55
- return {};
56
- });
57
- }
58
138
  static { this.ɵfac = function TranslateScopeService_Factory(t) { return new (t || TranslateScopeService)(); }; }
59
139
  static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: TranslateScopeService, factory: TranslateScopeService.ɵfac, providedIn: 'root' }); }
60
140
  }
@@ -115,4 +195,4 @@ export class ScopedTranslateKeyPipe {
115
195
  name: 'scopedTranslateKey',
116
196
  }]
117
197
  }], null, null); })();
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translate.js","sourceRoot":"","sources":["../../../../../../libs/plugin-sdk/remote/lib/translate.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  GLOBAL_CLUSTER,\n  isBuiltInLanguage,\n  TranslateKey,\n  TranslatePipe,\n  TranslateService,\n} from '@alauda-fe/common';\nimport { inject, Injectable, Pipe, PipeTransform } from '@angular/core';\n\nimport { RUNTIME } from './runtime';\n\nimport { translateScope, translateScopeKey } from '@alauda-fe/plugin-sdk';\n\nexport const getTranslateScope = (locale: string) => {\n  const cluster = isBuiltInLanguage(locale) ? RUNTIME.cluster : GLOBAL_CLUSTER;\n  return `plugin__${cluster}~${RUNTIME.pluginName}~${RUNTIME.appName}`;\n};\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class TranslateScopeService {\n  private translate = inject(TranslateService);\n  private loadedLang = new Set<string>();\n\n  readonly scope = translateScope(RUNTIME, this.translate.locale);\n\n  constructor() {\n    if (\n      !this.translate.translationsList.find(\n        item => item?.[this.translate.locale]?.[this.scope],\n      )\n    ) {\n      this.setupI18nAssets();\n    }\n  }\n\n  getScopedKey(key: string) {\n    return translateScopeKey(this.scope, key);\n  }\n\n  private async setupI18nAssets() {\n    const lang = this.translate.locale;\n    if (isBuiltInLanguage(lang)) {\n      this.translate.addTranslations({\n        [lang]: { [this.scope]: await this.loadTranslations(lang) },\n      });\n    } else {\n      const [en, other] = await Promise.all([\n        this.loadTranslations('en'),\n        this.loadTranslations(lang),\n      ]);\n\n      this.translate.addTranslations({\n        [lang]: { [this.scope]: Object.assign(en, other) },\n      });\n    }\n  }\n\n  private async loadTranslations(lang: string) {\n    if (this.loadedLang.has(lang)) {\n      return;\n    }\n\n    this.loadedLang.add(lang);\n\n    return this.fetchI18nFile(lang);\n  }\n\n  private fetchI18nFile(lang: string) {\n    const path = isBuiltInLanguage(lang)\n      ? RUNTIME.publicPath + 'assets/i18n/' + lang + '.json'\n      : `/console-i18n/${lang}/plugin__${RUNTIME.pluginName}~${RUNTIME.appName}.json`;\n    return fetch(path)\n      .then(res => res.json())\n      .catch(err => {\n        console.error(\n          `Failed to load i18n file for plugin ${RUNTIME.pluginName}~${RUNTIME.appName} and language ${lang}`,\n        );\n        console.error(err);\n        return {};\n      });\n  }\n}\n\n@Injectable({ providedIn: 'root' })\nexport class ScopedTranslateService {\n  private scope = inject(TranslateScopeService);\n  private translate = inject(TranslateService);\n\n  get(key: string, data?: unknown) {\n    return this.translate.get(this.scope.getScopedKey(key), data);\n  }\n}\n\n@Pipe({\n  standalone: true,\n  name: 'scopedTranslate',\n  pure: false,\n})\nexport class ScopedTranslatePipe\n  extends TranslatePipe\n  implements PipeTransform\n{\n  private scope = inject(TranslateScopeService);\n\n  override transform(key: TranslateKey | any, data?: unknown): string {\n    return super.transform(this.scope.getScopedKey(key), data);\n  }\n}\n\n@Pipe({\n  standalone: true,\n  name: 'scopedTranslateKey',\n})\nexport class ScopedTranslateKeyPipe implements PipeTransform {\n  private scope = inject(TranslateScopeService);\n\n  transform(key: string): string {\n    return this.scope.getScopedKey(key);\n  }\n}\n"]}
198
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translate.js","sourceRoot":"","sources":["../../../../../../libs/plugin-sdk/remote/lib/translate.ts"],"names":[],"mappings":"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","sourcesContent":["import { NotificationService } from '@alauda/ui';\nimport {\n  FALLBACK_LANGUAGE,\n  GLOBAL_CLUSTER,\n  isBuiltInLanguage,\n  TranslateKey,\n  TranslatePipe,\n  TranslateService,\n} from '@alauda-fe/common';\nimport { inject, Injectable, Pipe, PipeTransform } from '@angular/core';\n\nimport { RUNTIME } from './runtime';\n\nimport {\n  translateScope,\n  translateScopeKey,\n  getAllExtensions,\n} from '@alauda-fe/plugin-sdk';\n\n/**\n * 获取扩展列表，支持新旧版本兼容（ACP <= v4.1）\n * 优先使用新版 plugin-sdk 的 getAllExtensions 方法\n * 回退到旧版本的全局变量 __alauda_extensions\n */\nfunction getExtensions(): any[] | null {\n  try {\n    // 尝试使用新版本的 getAllExtensions 方法\n    if (typeof getAllExtensions === 'function') {\n      return getAllExtensions();\n    }\n  } catch (error) {\n    // getAllExtensions 不存在或调用失败时忽略错误\n    console.debug('getAllExtensions method not available or failed:', error);\n  }\n\n  // 回退到旧版本的全局变量\n  try {\n    const windowExtensions = (window as any).__alauda_extensions;\n    if (Array.isArray(windowExtensions)) {\n      console.debug(\n        'Using fallback __alauda_extensions:',\n        windowExtensions.length,\n        'extensions found',\n      );\n      return windowExtensions;\n    }\n  } catch (error) {\n    console.debug('__alauda_extensions not available:', error);\n  }\n\n  // 两种方式都不可用时返回 null，功能将以降级模式运行\n  console.debug('No extension source available, running in fallback mode');\n  return null;\n}\n\n/**\n * 获取当前插件的i18n版本号\n * 如果无法获取扩展信息，返回 undefined，translateScope 将使用基础作用域\n */\nfunction getCurrentPluginI18nVersion(): string | undefined {\n  const extensions = getExtensions();\n  if (!extensions) {\n    console.debug(\n      'No extensions available, i18n will use base scope without version',\n    );\n    return undefined;\n  }\n\n  const currentExtension = extensions.find(\n    (ext: any) =>\n      ext.pluginName === RUNTIME.pluginName &&\n      ext.appName === RUNTIME.appName &&\n      ext.cluster === RUNTIME.cluster,\n  );\n\n  if (!currentExtension) {\n    console.debug(\n      'Current extension not found in extensions list, using base scope',\n    );\n    return undefined;\n  }\n\n  const version = currentExtension?.i18nVersion;\n  console.debug('Plugin i18n version:', version || 'not specified');\n  return version;\n}\n\n/**\n * 获取i18n文件\n */\nfunction fetchI18nFile(lang: string, scope: string): Promise<any> {\n  const path = isBuiltInLanguage(lang)\n    ? RUNTIME.publicPath + 'assets/i18n/' + lang + '.json'\n    : `/console-i18n/${lang}/${scope}.json`;\n\n  return fetch(path)\n    .then(res => {\n      if (!res.ok) {\n        throw new Error(`HTTP ${res.status}: ${res.statusText}`);\n      }\n      return res.json();\n    })\n    .catch(err => {\n      console.error(\n        `Failed to load i18n file for plugin ${RUNTIME.pluginName}~${RUNTIME.appName} and language ${lang}`,\n      );\n      console.error(err);\n      return null;\n    });\n}\n\nexport const getTranslateScope = (locale: string) => {\n  const cluster = isBuiltInLanguage(locale) ? RUNTIME.cluster : GLOBAL_CLUSTER;\n  return `plugin__${cluster}~${RUNTIME.pluginName}~${RUNTIME.appName}`;\n};\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class TranslateScopeService {\n  private translate = inject(TranslateService);\n  private notification = inject(NotificationService);\n\n  readonly scope = translateScope(\n    {\n      ...RUNTIME,\n      i18nVersion: getCurrentPluginI18nVersion(),\n    },\n    this.translate.locale,\n  );\n\n  constructor() {\n    const fallbackLangI18nLoaded = this.translate.translationsList.find(\n      item => item?.[FALLBACK_LANGUAGE]?.[this.scope],\n    );\n\n    if (!fallbackLangI18nLoaded) {\n      // 基座未预加载插件翻译文件时自行加载\n      this.setupI18nAssets();\n    } else if (!isBuiltInLanguage(this.translate.locale)) {\n      this.checkTranslationAvailability();\n    }\n  }\n\n  getScopedKey(key: string) {\n    return translateScopeKey(this.scope, key);\n  }\n\n  private checkTranslationAvailability() {\n    const currentLang = this.translate.locale;\n\n    const hasTranslation = this.translate.translationsList.find(\n      item => item?.[currentLang]?.[this.scope],\n    );\n\n    if (!hasTranslation) {\n      const fileName = `${this.scope}.json`;\n\n      this.notification.warning({\n        title: this.translate.get('translation_file_missing_warning'),\n        content: this.translate.get('plugin_missing_translation_file', {\n          pluginName: RUNTIME.pluginName,\n          appName: RUNTIME.appName,\n          lang: currentLang,\n          fileName,\n        }),\n        duration: 5000,\n      });\n    }\n  }\n\n  private async setupI18nAssets() {\n    const lang = this.translate.locale;\n    if (isBuiltInLanguage(lang)) {\n      this.translate.addTranslations({\n        [lang]: { [this.scope]: await fetchI18nFile(lang, this.scope) },\n      });\n    } else {\n      const [en, other] = await Promise.all([\n        fetchI18nFile(this.translate.options.fallbackLocale, this.scope),\n        fetchI18nFile(lang, this.scope),\n      ]);\n\n      this.translate.addTranslations({\n        [FALLBACK_LANGUAGE]: { [this.scope]: en },\n        [lang]: { [this.scope]: other },\n      });\n    }\n  }\n}\n\n@Injectable({ providedIn: 'root' })\nexport class ScopedTranslateService {\n  private scope = inject(TranslateScopeService);\n  private translate = inject(TranslateService);\n\n  get(key: string, data?: unknown) {\n    return this.translate.get(this.scope.getScopedKey(key), data);\n  }\n}\n\n@Pipe({\n  standalone: true,\n  name: 'scopedTranslate',\n  pure: false,\n})\nexport class ScopedTranslatePipe\n  extends TranslatePipe\n  implements PipeTransform\n{\n  private scope = inject(TranslateScopeService);\n\n  override transform(key: TranslateKey | any, data?: unknown): string {\n    return super.transform(this.scope.getScopedKey(key), data);\n  }\n}\n\n@Pipe({\n  standalone: true,\n  name: 'scopedTranslateKey',\n})\nexport class ScopedTranslateKeyPipe implements PipeTransform {\n  private scope = inject(TranslateScopeService);\n\n  transform(key: string): string {\n    return this.scope.getScopedKey(key);\n  }\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  import { Translations } from '@alauda-fe/common';
2
2
  import { Extension } from './extensions-loader';
3
+ export declare function getAllExtensions(): Extension[];
3
4
  export declare function getAppExtensions<T = any>(type: string | string[], cluster?: string): Array<Extension<T>>;
4
5
  export declare function getAppExtensionTranslations(): Translations[];
5
6
  export declare function setupAppExtensions(host: string, hostVersion?: string): Promise<Extension<any>[]>;
@@ -1,6 +1,6 @@
1
1
  import { NavGroupConfig, NavItemConfig, TranslateService } from '@alauda-fe/common';
2
- export declare function getRemoteNavigations(scope: string, translate: TranslateService): RemoteNavigationItemRoot[];
3
- export declare function getRemoteNavigationGroups(scope: string, translate: TranslateService): RemoteNavigationItemRoot[];
2
+ export declare function getRemoteNavigations(scope: string, translate: TranslateService, cluster?: string): RemoteNavigationItemRoot[];
3
+ export declare function getRemoteNavigationGroups(scope: string, translate: TranslateService, cluster?: string): RemoteNavigationItemRoot[];
4
4
  export declare function insertNavItem(source: NavItemConfig[], remotes: RemoteNavigationItemRoot[]): NavItemConfig[];
5
5
  export declare function insertNavGroupItem(source: NavGroupConfig[], remotes: RemoteNavigationItemRoot[]): NavGroupConfig[];
6
6
  export interface RemoteNavigationItem extends NavItemConfig {
@@ -12,4 +12,5 @@ export interface RemoteNavigationItem extends NavItemConfig {
12
12
  export interface RemoteNavigationItemRoot extends RemoteNavigationItem {
13
13
  insertAfter?: string | string[];
14
14
  insertBefore?: string | string[];
15
+ clusterStrategy?: 'latest' | 'strict';
15
16
  }
@@ -12,6 +12,7 @@ export interface Extension<T = any> extends RawExtension<T> {
12
12
  appName: string;
13
13
  entrypoint: string;
14
14
  dependencies: Record<string, string>;
15
+ i18nVersion?: string;
15
16
  }
16
17
  interface RawExtension<T = any> {
17
18
  type: string;
package/lib/utils.d.ts CHANGED
@@ -1,7 +1,4 @@
1
1
  import { Extension } from './extensions-loader';
2
- /**
3
- * @deprecated Use isLocalDev from @alauda-fe/common instead
4
- */
5
2
  export declare function isLocalEnv(): boolean;
6
3
  export declare function isStaticPluginPath(publicPath: string): boolean;
7
4
  export declare const LOCAL_DEV_EXTENSION_INFO: {
@@ -18,9 +15,10 @@ export declare const STATIC_EXTENSION_INFO: {
18
15
  export declare function getBootMode(): 'standard' | 'safe';
19
16
  export declare function loadRemote(remote: string, module: string): Promise<any>;
20
17
  export declare function filterLatestVersion<O = any>(identity: (ext: O) => unknown): (exts: Array<Extension<O>>) => Array<Extension<O>>;
21
- export declare const translateScope: ({ cluster, pluginName, appName, }: {
18
+ export declare const translateScope: (extension: {
22
19
  cluster: string;
23
20
  pluginName: string;
24
21
  appName: string;
22
+ i18nVersion?: string;
25
23
  }, locale: string) => string;
26
24
  export declare const translateScopeKey: (scope: string, key: string) => string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alauda-fe/plugin-sdk",
3
- "version": "0.0.15",
3
+ "version": "0.0.17",
4
4
  "peerDependencies": {
5
5
  "@nx/angular": "^16.10.0"
6
6
  },
@@ -4,13 +4,12 @@ import * as i0 from "@angular/core";
4
4
  export declare const getTranslateScope: (locale: string) => string;
5
5
  export declare class TranslateScopeService {
6
6
  private translate;
7
- private loadedLang;
7
+ private notification;
8
8
  readonly scope: string;
9
9
  constructor();
10
10
  getScopedKey(key: string): string;
11
+ private checkTranslationAvailability;
11
12
  private setupI18nAssets;
12
- private loadTranslations;
13
- private fetchI18nFile;
14
13
  static ɵfac: i0.ɵɵFactoryDeclaration<TranslateScopeService, never>;
15
14
  static ɵprov: i0.ɵɵInjectableDeclaration<TranslateScopeService>;
16
15
  }