@alauda-fe/plugin-sdk 0.0.16 → 0.0.18

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"]}
@@ -0,0 +1,47 @@
1
+ import { ChangeDetectionStrategy, Component, input, } from '@angular/core';
2
+ import { getAppExtensions } from '../../app-extensions';
3
+ import { RemoteComponentOutletComponent } from '../../components';
4
+ import * as i0 from "@angular/core";
5
+ function RemoteGlobalEntryPointComponent_For_1_Template(rf, ctx) { if (rf & 1) {
6
+ i0.ɵɵelement(0, "plg-remote-component-outlet", 0);
7
+ } if (rf & 2) {
8
+ const item_r1 = ctx.$implicit;
9
+ i0.ɵɵproperty("entrypoint", item_r1.entrypoint)("expose", item_r1.options.expose)("name", item_r1.options.component);
10
+ } }
11
+ export function getGlobalEntryPoints(scope, _name = '*') {
12
+ return getAppExtensions(['console-*']
13
+ .concat(scope || [])
14
+ .map(scope => `${scope}/page/body/global-entrypoint/item`)).sort((a, b) => -(a.options.index - b.options.index));
15
+ }
16
+ export class RemoteGlobalEntryPointComponent {
17
+ constructor() {
18
+ this.scope = input();
19
+ }
20
+ ngOnInit() {
21
+ this.entryPoints = getGlobalEntryPoints(this.scope());
22
+ }
23
+ static { this.ɵfac = function RemoteGlobalEntryPointComponent_Factory(t) { return new (t || RemoteGlobalEntryPointComponent)(); }; }
24
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: RemoteGlobalEntryPointComponent, selectors: [["plg-remote-global-entrypoint"]], inputs: { scope: [1, "scope"] }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 0, consts: [[3, "entrypoint", "expose", "name"]], template: function RemoteGlobalEntryPointComponent_Template(rf, ctx) { if (rf & 1) {
25
+ i0.ɵɵrepeaterCreate(0, RemoteGlobalEntryPointComponent_For_1_Template, 1, 3, "plg-remote-component-outlet", 0, i0.ɵɵrepeaterTrackByIndex);
26
+ } if (rf & 2) {
27
+ i0.ɵɵrepeater(ctx.entryPoints);
28
+ } }, dependencies: [RemoteComponentOutletComponent], encapsulation: 2, changeDetection: 0 }); }
29
+ }
30
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RemoteGlobalEntryPointComponent, [{
31
+ type: Component,
32
+ args: [{
33
+ selector: 'plg-remote-global-entrypoint',
34
+ changeDetection: ChangeDetectionStrategy.OnPush,
35
+ standalone: true,
36
+ imports: [RemoteComponentOutletComponent],
37
+ template: `@for (item of entryPoints; track $index) {
38
+ <plg-remote-component-outlet
39
+ [entrypoint]="item.entrypoint"
40
+ [expose]="item.options.expose"
41
+ [name]="item.options.component"
42
+ ></plg-remote-component-outlet>
43
+ }`,
44
+ }]
45
+ }], null, null); })();
46
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RemoteGlobalEntryPointComponent, { className: "RemoteGlobalEntryPointComponent", filePath: "lib/extension-points/global-entrypoint/components.ts", lineNumber: 40 }); })();
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcGx1Z2luLXNkay9zcmMvbGliL2V4dGVuc2lvbi1wb2ludHMvZ2xvYmFsLWVudHJ5cG9pbnQvY29tcG9uZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxLQUFLLEdBRU4sTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDeEQsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sa0JBQWtCLENBQUM7OztJQXdCOUQsaURBSStCOzs7SUFEN0IsQUFEQSxBQURBLCtDQUE4QixrQ0FDQSxtQ0FDQzs7QUFqQnJDLE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxLQUFhLEVBQUUsUUFBZ0IsR0FBRztJQUNyRSxPQUFPLGdCQUFnQixDQUNyQixDQUFDLFdBQVcsQ0FBQztTQUNWLE1BQU0sQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFDO1NBQ25CLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyxtQ0FBbUMsQ0FBQyxDQUM3RCxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7QUFDekQsQ0FBQztBQWVELE1BQU0sT0FBTywrQkFBK0I7SUFiNUM7UUFjRSxVQUFLLEdBQUcsS0FBSyxFQUFVLENBQUM7S0FPekI7SUFIQyxRQUFRO1FBQ04sSUFBSSxDQUFDLFdBQVcsR0FBRyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUN4RCxDQUFDO2dHQVBVLCtCQUErQjtvRUFBL0IsK0JBQStCO1lBUi9CLHlJQU1WOztZQU5VLDhCQU1WOzRCQVBTLDhCQUE4Qjs7aUZBUzdCLCtCQUErQjtjQWIzQyxTQUFTO2VBQUM7Z0JBQ1QsUUFBUSxFQUFFLDhCQUE4QjtnQkFDeEMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07Z0JBQy9DLFVBQVUsRUFBRSxJQUFJO2dCQUNoQixPQUFPLEVBQUUsQ0FBQyw4QkFBOEIsQ0FBQztnQkFDekMsUUFBUSxFQUFFOzs7Ozs7SUFNUjthQUNIOztrRkFDWSwrQkFBK0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBpbnB1dCxcbiAgT25Jbml0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgZ2V0QXBwRXh0ZW5zaW9ucyB9IGZyb20gJy4uLy4uL2FwcC1leHRlbnNpb25zJztcbmltcG9ydCB7IFJlbW90ZUNvbXBvbmVudE91dGxldENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgRXh0ZW5zaW9uIH0gZnJvbSAnLi4vLi4vZXh0ZW5zaW9ucy1sb2FkZXInO1xuXG5leHBvcnQgaW50ZXJmYWNlIEdsb2JhbEVudHJ5UG9pbnRPcHRpb24ge1xuICBpbmRleD86IG51bWJlcjtcbiAgZXhwb3NlPzogc3RyaW5nO1xuICBjb21wb25lbnQ6IHN0cmluZztcbiAgcGx1Z2luTmFtZT86IHN0cmluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEdsb2JhbEVudHJ5UG9pbnRzKHNjb3BlOiBzdHJpbmcsIF9uYW1lOiBzdHJpbmcgPSAnKicpIHtcbiAgcmV0dXJuIGdldEFwcEV4dGVuc2lvbnM8R2xvYmFsRW50cnlQb2ludE9wdGlvbj4oXG4gICAgWydjb25zb2xlLSonXVxuICAgICAgLmNvbmNhdChzY29wZSB8fCBbXSlcbiAgICAgIC5tYXAoc2NvcGUgPT4gYCR7c2NvcGV9L3BhZ2UvYm9keS9nbG9iYWwtZW50cnlwb2ludC9pdGVtYCksXG4gICkuc29ydCgoYSwgYikgPT4gLShhLm9wdGlvbnMuaW5kZXggLSBiLm9wdGlvbnMuaW5kZXgpKTtcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncGxnLXJlbW90ZS1nbG9iYWwtZW50cnlwb2ludCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbUmVtb3RlQ29tcG9uZW50T3V0bGV0Q29tcG9uZW50XSxcbiAgdGVtcGxhdGU6IGBAZm9yIChpdGVtIG9mIGVudHJ5UG9pbnRzOyB0cmFjayAkaW5kZXgpIHtcbiAgICA8cGxnLXJlbW90ZS1jb21wb25lbnQtb3V0bGV0XG4gICAgICBbZW50cnlwb2ludF09XCJpdGVtLmVudHJ5cG9pbnRcIlxuICAgICAgW2V4cG9zZV09XCJpdGVtLm9wdGlvbnMuZXhwb3NlXCJcbiAgICAgIFtuYW1lXT1cIml0ZW0ub3B0aW9ucy5jb21wb25lbnRcIlxuICAgID48L3BsZy1yZW1vdGUtY29tcG9uZW50LW91dGxldD5cbiAgfWAsXG59KVxuZXhwb3J0IGNsYXNzIFJlbW90ZUdsb2JhbEVudHJ5UG9pbnRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBzY29wZSA9IGlucHV0PHN0cmluZz4oKTtcblxuICBlbnRyeVBvaW50czogQXJyYXk8RXh0ZW5zaW9uPEdsb2JhbEVudHJ5UG9pbnRPcHRpb24+PjtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmVudHJ5UG9pbnRzID0gZ2V0R2xvYmFsRW50cnlQb2ludHModGhpcy5zY29wZSgpKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,2 @@
1
+ export * from './components';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3BsdWdpbi1zZGsvc3JjL2xpYi9leHRlbnNpb24tcG9pbnRzL2dsb2JhbC1lbnRyeXBvaW50L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzJztcbiJdfQ==
@@ -1,6 +1,7 @@
1
1
  export * from './account-menu';
2
+ export * from './global-entrypoint';
2
3
  export * from './header-actions';
3
4
  export * from './help-menu';
4
5
  export * from './navigation';
5
6
  export * from './route';
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3BsdWdpbi1zZGsvc3JjL2xpYi9leHRlbnNpb24tcG9pbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYWNjb3VudC1tZW51JztcbmV4cG9ydCAqIGZyb20gJy4vaGVhZGVyLWFjdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9oZWxwLW1lbnUnO1xuZXhwb3J0ICogZnJvbSAnLi9uYXZpZ2F0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vcm91dGUnO1xuIl19
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3BsdWdpbi1zZGsvc3JjL2xpYi9leHRlbnNpb24tcG9pbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hY2NvdW50LW1lbnUnO1xuZXhwb3J0ICogZnJvbSAnLi9nbG9iYWwtZW50cnlwb2ludCc7XG5leHBvcnQgKiBmcm9tICcuL2hlYWRlci1hY3Rpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vaGVscC1tZW51JztcbmV4cG9ydCAqIGZyb20gJy4vbmF2aWdhdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3JvdXRlJztcbiJdfQ==
@@ -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(';');
@@ -54,10 +55,11 @@ async function loadProdExtensions(query = {}) {
54
55
  .replaceAll('/', '-'),
55
56
  entrypoint: `${reqPrefix}/clusters-rewrite/${cluster}${plugin.path}`,
56
57
  dependencies: pluginJson.dependencies || {},
58
+ i18nVersion: pluginJson.i18nVersion,
57
59
  }));
58
60
  }
59
61
  catch (error) {
60
- console.warn(`Failed to parse console-plugin.json for plugin ${plugin.name}:`, error);
62
+ console.error(`Failed to parse console-plugin.json for plugin ${plugin.name}:`, error);
61
63
  return [];
62
64
  }
63
65
  })), []))
@@ -66,4 +68,4 @@ async function loadProdExtensions(query = {}) {
66
68
  return [];
67
69
  });
68
70
  }
69
- //# 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              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                }));\n              } catch (error) {\n                console.warn(\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}\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,84 @@
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
+ }
79
+ /**
80
+ * @deprecated use `translateScope` function from plugin-sdk instead
81
+ */
6
82
  export const getTranslateScope = (locale) => {
7
83
  const cluster = isBuiltInLanguage(locale) ? RUNTIME.cluster : GLOBAL_CLUSTER;
8
84
  return `plugin__${cluster}~${RUNTIME.pluginName}~${RUNTIME.appName}`;
@@ -10,51 +86,58 @@ export const getTranslateScope = (locale) => {
10
86
  export class TranslateScopeService {
11
87
  constructor() {
12
88
  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])) {
89
+ this.notification = inject(NotificationService);
90
+ this.scope = translateScope({
91
+ ...RUNTIME,
92
+ i18nVersion: getCurrentPluginI18nVersion(),
93
+ }, this.translate.locale);
94
+ const fallbackLangI18nLoaded = this.translate.translationsList.find(item => item?.[FALLBACK_LANGUAGE]?.[this.scope]);
95
+ if (!fallbackLangI18nLoaded) {
96
+ // 基座未预加载插件翻译文件时自行加载
16
97
  this.setupI18nAssets();
17
98
  }
99
+ else if (!isBuiltInLanguage(this.translate.locale)) {
100
+ this.checkTranslationAvailability();
101
+ }
18
102
  }
19
103
  getScopedKey(key) {
20
104
  return translateScopeKey(this.scope, key);
21
105
  }
106
+ checkTranslationAvailability() {
107
+ const currentLang = this.translate.locale;
108
+ const hasTranslation = this.translate.translationsList.find(item => item?.[currentLang]?.[this.scope]);
109
+ if (!hasTranslation) {
110
+ const fileName = `${this.scope}.json`;
111
+ this.notification.warning({
112
+ title: this.translate.get('translation_file_missing_warning'),
113
+ content: this.translate.get('plugin_missing_translation_file', {
114
+ pluginName: RUNTIME.pluginName,
115
+ appName: RUNTIME.appName,
116
+ lang: currentLang,
117
+ fileName,
118
+ }),
119
+ duration: 5000,
120
+ });
121
+ }
122
+ }
22
123
  async setupI18nAssets() {
23
124
  const lang = this.translate.locale;
24
125
  if (isBuiltInLanguage(lang)) {
25
126
  this.translate.addTranslations({
26
- [lang]: { [this.scope]: await this.loadTranslations(lang) },
127
+ [lang]: { [this.scope]: await fetchI18nFile(lang, this.scope) },
27
128
  });
28
129
  }
29
130
  else {
30
131
  const [en, other] = await Promise.all([
31
- this.loadTranslations('en'),
32
- this.loadTranslations(lang),
132
+ fetchI18nFile(this.translate.options.fallbackLocale, this.scope),
133
+ fetchI18nFile(lang, this.scope),
33
134
  ]);
34
135
  this.translate.addTranslations({
35
- [lang]: { [this.scope]: Object.assign(en, other) },
136
+ [FALLBACK_LANGUAGE]: { [this.scope]: en },
137
+ [lang]: { [this.scope]: other },
36
138
  });
37
139
  }
38
140
  }
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
141
  static { this.ɵfac = function TranslateScopeService_Factory(t) { return new (t || TranslateScopeService)(); }; }
59
142
  static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: TranslateScopeService, factory: TranslateScopeService.ɵfac, providedIn: 'root' }); }
60
143
  }
@@ -115,4 +198,4 @@ export class ScopedTranslateKeyPipe {
115
198
  name: 'scopedTranslateKey',
116
199
  }]
117
200
  }], 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"]}
201
+ //# 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\n/**\n * @deprecated use `translateScope` function from plugin-sdk instead\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>[]>;
@@ -0,0 +1,17 @@
1
+ import { OnInit } from '@angular/core';
2
+ import { Extension } from '../../extensions-loader';
3
+ import * as i0 from "@angular/core";
4
+ export interface GlobalEntryPointOption {
5
+ index?: number;
6
+ expose?: string;
7
+ component: string;
8
+ pluginName?: string;
9
+ }
10
+ export declare function getGlobalEntryPoints(scope: string, _name?: string): Extension<GlobalEntryPointOption>[];
11
+ export declare class RemoteGlobalEntryPointComponent implements OnInit {
12
+ scope: import("@angular/core").InputSignal<string>;
13
+ entryPoints: Array<Extension<GlobalEntryPointOption>>;
14
+ ngOnInit(): void;
15
+ static ɵfac: i0.ɵɵFactoryDeclaration<RemoteGlobalEntryPointComponent, never>;
16
+ static ɵcmp: i0.ɵɵComponentDeclaration<RemoteGlobalEntryPointComponent, "plg-remote-global-entrypoint", never, { "scope": { "alias": "scope"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
17
+ }
@@ -0,0 +1 @@
1
+ export * from './components';
@@ -1,4 +1,5 @@
1
1
  export * from './account-menu';
2
+ export * from './global-entrypoint';
2
3
  export * from './header-actions';
3
4
  export * from './help-menu';
4
5
  export * from './navigation';
@@ -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.16",
3
+ "version": "0.0.18",
4
4
  "peerDependencies": {
5
5
  "@nx/angular": "^16.10.0"
6
6
  },
@@ -1,16 +1,18 @@
1
1
  import { TranslateKey, TranslatePipe } from '@alauda-fe/common';
2
2
  import { PipeTransform } from '@angular/core';
3
3
  import * as i0 from "@angular/core";
4
+ /**
5
+ * @deprecated use `translateScope` function from plugin-sdk instead
6
+ */
4
7
  export declare const getTranslateScope: (locale: string) => string;
5
8
  export declare class TranslateScopeService {
6
9
  private translate;
7
- private loadedLang;
10
+ private notification;
8
11
  readonly scope: string;
9
12
  constructor();
10
13
  getScopedKey(key: string): string;
14
+ private checkTranslationAvailability;
11
15
  private setupI18nAssets;
12
- private loadTranslations;
13
- private fetchI18nFile;
14
16
  static ɵfac: i0.ɵɵFactoryDeclaration<TranslateScopeService, never>;
15
17
  static ɵprov: i0.ɵɵInjectableDeclaration<TranslateScopeService>;
16
18
  }