@alauda-fe/plugin-sdk 0.0.17 → 0.0.19-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -43,5 +43,5 @@ export class RemoteComponentOutletComponent {
43
43
  type: Component,
44
44
  args: [{ selector: 'plg-remote-component-outlet', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgComponentOutlet], template: "@if (component()) {\n <ng-container\n *ngComponentOutlet=\"\n component();\n inputs: inputs();\n injector: injector();\n content: content()\n \"\n ></ng-container>\n} @else {\n <ng-content></ng-content>\n}\n" }]
45
45
  }], () => [], null); })();
46
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RemoteComponentOutletComponent, { className: "RemoteComponentOutletComponent", filePath: "lib/components/remote-component-outlet/component.ts", lineNumber: 21 }); })();
46
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RemoteComponentOutletComponent, { className: "RemoteComponentOutletComponent" }); })();
47
47
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9wbHVnaW4tc2RrL3NyYy9saWIvY29tcG9uZW50cy9yZW1vdGUtY29tcG9uZW50LW91dGxldC9jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3BsdWdpbi1zZGsvc3JjL2xpYi9jb21wb25lbnRzL3JlbW90ZS1jb21wb25lbnQtb3V0bGV0L3RlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDcEQsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsUUFBUSxFQUNSLE1BQU0sRUFDTixLQUFLLEVBQ0wsTUFBTSxHQUVQLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxhQUFhLENBQUM7Ozs7SUNWdkMsd0JBT2dCOzs7SUFQaEIsK0dBT0M7OztJQUZVLEFBREEsQUFEQSxBQUZSLHNEQUVRLDRDQUNBLGdEQUNBLDhDQUViOzs7SUFFRSxrQkFBeUI7O0FEVTNCLE1BQU0sT0FBTyw4QkFBOEI7SUFpQnpDO1FBaEJRLHFCQUFnQixHQUFHLE1BQU0sQ0FBa0MsRUFBRSxDQUFDLENBQUM7UUFFdkUsU0FBSSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQVUsQ0FBQztRQUVoQyxlQUFVLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBRXRDLFdBQU0sR0FBRyxLQUFLLEVBQVUsQ0FBQztRQUV6QixXQUFNLEdBQUcsS0FBSyxFQUFnRCxDQUFDO1FBRS9ELGFBQVEsR0FBRyxLQUFLLEVBQWtELENBQUM7UUFFbkUsWUFBTyxHQUFHLEtBQUssRUFBaUQsQ0FBQztRQUVqRSxjQUFTLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFHL0QsTUFBTSxDQUNKLEtBQUssSUFBSSxFQUFFO1lBQ1QsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQztnQkFDdEIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FDdkIsQ0FDRSxNQUFNLFVBQVUsQ0FDZCxJQUFJLENBQUMsVUFBVSxFQUFFLEVBQ2pCLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxjQUFjLENBQ2hDLENBQ0YsQ0FBQyxPQUFPLENBQ1YsQ0FBQztZQUNKLENBQUM7UUFDSCxDQUFDLEVBQ0QsRUFBRSxpQkFBaUIsRUFBRSxJQUFJLEVBQUUsQ0FDNUIsQ0FBQztJQUNKLENBQUM7K0ZBakNVLDhCQUE4QjtvRUFBOUIsOEJBQThCOztZQ1h6QyxBQVRGLDZGQUFtQixnRUFTVjs7WUFUVCx5Q0FXQzs0QkRPVyxpQkFBaUI7O2lGQUVoQiw4QkFBOEI7Y0FQMUMsU0FBUzsyQkFDRSw2QkFBNkIsbUJBRXRCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxXQUNQLENBQUMsaUJBQWlCLENBQUM7O2tGQUVqQiw4QkFBOEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ0NvbXBvbmVudE91dGxldCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBjb21wdXRlZCxcbiAgZWZmZWN0LFxuICBpbnB1dCxcbiAgc2lnbmFsLFxuICBUeXBlLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgbG9hZFJlbW90ZSB9IGZyb20gJy4uLy4uL3V0aWxzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncGxnLXJlbW90ZS1jb21wb25lbnQtb3V0bGV0JyxcbiAgdGVtcGxhdGVVcmw6ICd0ZW1wbGF0ZS5odG1sJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtOZ0NvbXBvbmVudE91dGxldF0sXG59KVxuZXhwb3J0IGNsYXNzIFJlbW90ZUNvbXBvbmVudE91dGxldENvbXBvbmVudCB7XG4gIHByaXZhdGUgcmVtb3RlQ29tcG9uZW50cyA9IHNpZ25hbDxSZWNvcmQ8c3RyaW5nLCBUeXBlPENvbXBvbmVudD4+Pih7fSk7XG5cbiAgbmFtZSA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcblxuICBlbnRyeXBvaW50ID0gaW5wdXQucmVxdWlyZWQ8c3RyaW5nPigpO1xuXG4gIGV4cG9zZSA9IGlucHV0PHN0cmluZz4oKTtcblxuICBpbnB1dHMgPSBpbnB1dDxOZ0NvbXBvbmVudE91dGxldFsnbmdDb21wb25lbnRPdXRsZXRJbnB1dHMnXT4oKTtcblxuICBpbmplY3RvciA9IGlucHV0PE5nQ29tcG9uZW50T3V0bGV0WyduZ0NvbXBvbmVudE91dGxldEluamVjdG9yJ10+KCk7XG5cbiAgY29udGVudCA9IGlucHV0PE5nQ29tcG9uZW50T3V0bGV0WyduZ0NvbXBvbmVudE91dGxldENvbnRlbnQnXT4oKTtcblxuICBjb21wb25lbnQgPSBjb21wdXRlZCgoKSA9PiB0aGlzLnJlbW90ZUNvbXBvbmVudHMoKVt0aGlzLm5hbWUoKV0pO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIGVmZmVjdChcbiAgICAgIGFzeW5jICgpID0+IHtcbiAgICAgICAgaWYgKHRoaXMuZW50cnlwb2ludCgpKSB7XG4gICAgICAgICAgdGhpcy5yZW1vdGVDb21wb25lbnRzLnNldChcbiAgICAgICAgICAgIChcbiAgICAgICAgICAgICAgYXdhaXQgbG9hZFJlbW90ZShcbiAgICAgICAgICAgICAgICB0aGlzLmVudHJ5cG9pbnQoKSxcbiAgICAgICAgICAgICAgICB0aGlzLmV4cG9zZSgpID8/ICcuL0NvbXBvbmVudHMnLFxuICAgICAgICAgICAgICApXG4gICAgICAgICAgICApLmRlZmF1bHQsXG4gICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIHsgYWxsb3dTaWduYWxXcml0ZXM6IHRydWUgfSxcbiAgICApO1xuICB9XG59XG4iLCJAaWYgKGNvbXBvbmVudCgpKSB7XG4gIDxuZy1jb250YWluZXJcbiAgICAqbmdDb21wb25lbnRPdXRsZXQ9XCJcbiAgICAgIGNvbXBvbmVudCgpO1xuICAgICAgaW5wdXRzOiBpbnB1dHMoKTtcbiAgICAgIGluamVjdG9yOiBpbmplY3RvcigpO1xuICAgICAgY29udGVudDogY29udGVudCgpXG4gICAgXCJcbiAgPjwvbmctY29udGFpbmVyPlxufSBAZWxzZSB7XG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbn1cbiJdfQ==
@@ -44,5 +44,5 @@ export class RemoteAccountMenuItemsComponent {
44
44
  imports: [RemoteComponentOutletComponent],
45
45
  }]
46
46
  }], null, null); })();
47
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RemoteAccountMenuItemsComponent, { className: "RemoteAccountMenuItemsComponent", filePath: "lib/extension-points/account-menu.ts", lineNumber: 39 }); })();
47
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RemoteAccountMenuItemsComponent, { className: "RemoteAccountMenuItemsComponent" }); })();
48
48
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3VudC1tZW51LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9wbHVnaW4tc2RrL3NyYy9saWIvZXh0ZW5zaW9uLXBvaW50cy9hY2NvdW50LW1lbnUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsS0FBSyxHQUVOLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3JELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0lBb0IzRCxpREFJK0I7OztJQUQ3QixBQURBLEFBREEsK0NBQThCLGtDQUNBLG1DQUNDOztBQWRyQyxNQUFNLFVBQVUsbUJBQW1CLENBQUMsS0FBYTtJQUMvQyxPQUFPLGdCQUFnQixDQUNyQixDQUFDLFdBQVcsQ0FBQztTQUNWLE1BQU0sQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFDO1NBQ25CLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyxnQ0FBZ0MsQ0FBQyxDQUMxRCxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7QUFDekQsQ0FBQztBQWVELE1BQU0sT0FBTywrQkFBK0I7SUFiNUM7UUFjRSxVQUFLLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFFeEIscUJBQWdCLEdBQWtELEVBQUUsQ0FBQztLQUt0RTtJQUhDLFFBQVE7UUFDTixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsbUJBQW1CLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDNUQsQ0FBQztnR0FQVSwrQkFBK0I7b0VBQS9CLCtCQUErQjtZQVgvQix5SUFNVjs7WUFOVSxtQ0FNVjs0QkFHUyw4QkFBOEI7O2lGQUU3QiwrQkFBK0I7Y0FiM0MsU0FBUztlQUFDO2dCQUNULFFBQVEsRUFBRSwrQkFBK0I7Z0JBQ3pDLFFBQVEsRUFBRTs7Ozs7O0lBTVI7Z0JBQ0YsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07Z0JBQy9DLFVBQVUsRUFBRSxJQUFJO2dCQUNoQixPQUFPLEVBQUUsQ0FBQyw4QkFBOEIsQ0FBQzthQUMxQzs7a0ZBQ1ksK0JBQStCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgaW5wdXQsXG4gIE9uSW5pdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IGdldEFwcEV4dGVuc2lvbnMgfSBmcm9tICcuLi9hcHAtZXh0ZW5zaW9ucyc7XG5pbXBvcnQgeyBSZW1vdGVDb21wb25lbnRPdXRsZXRDb21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzJztcbmltcG9ydCB7IEV4dGVuc2lvbiB9IGZyb20gJy4uL2V4dGVuc2lvbnMtbG9hZGVyJztcblxuZXhwb3J0IGludGVyZmFjZSBBY2NvdW50TWVudUl0ZW1QbHVnaW5PcHRpb24ge1xuICBpbmRleD86IG51bWJlcjtcbiAgZXhwb3NlPzogc3RyaW5nO1xuICBjb21wb25lbnQ6IHN0cmluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEFjY291bnRNZW51SXRlbXMoc2NvcGU6IHN0cmluZykge1xuICByZXR1cm4gZ2V0QXBwRXh0ZW5zaW9uczxBY2NvdW50TWVudUl0ZW1QbHVnaW5PcHRpb24+KFxuICAgIFsnY29uc29sZS0qJ11cbiAgICAgIC5jb25jYXQoc2NvcGUgfHwgW10pXG4gICAgICAubWFwKHNjb3BlID0+IGAke3Njb3BlfS9wYWdlL2hlYWRlci9hY2NvdW50LW1lbnUvaXRlbWApLFxuICApLnNvcnQoKGEsIGIpID0+IC0oYS5vcHRpb25zLmluZGV4IC0gYi5vcHRpb25zLmluZGV4KSk7XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3BsZy1yZW1vdGUtYWNjb3VudC1tZW51LWl0ZW1zJyxcbiAgdGVtcGxhdGU6IGBAZm9yIChpdGVtIG9mIGFjY291bnRNZW51SXRlbXM7IHRyYWNrICRpbmRleCkge1xuICAgIDxwbGctcmVtb3RlLWNvbXBvbmVudC1vdXRsZXRcbiAgICAgIFtlbnRyeXBvaW50XT1cIml0ZW0uZW50cnlwb2ludFwiXG4gICAgICBbZXhwb3NlXT1cIml0ZW0ub3B0aW9ucy5leHBvc2VcIlxuICAgICAgW25hbWVdPVwiaXRlbS5vcHRpb25zLmNvbXBvbmVudFwiXG4gICAgPjwvcGxnLXJlbW90ZS1jb21wb25lbnQtb3V0bGV0PlxuICB9YCxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtSZW1vdGVDb21wb25lbnRPdXRsZXRDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBSZW1vdGVBY2NvdW50TWVudUl0ZW1zQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgc2NvcGUgPSBpbnB1dDxzdHJpbmc+KCk7XG5cbiAgYWNjb3VudE1lbnVJdGVtczogQXJyYXk8RXh0ZW5zaW9uPEFjY291bnRNZW51SXRlbVBsdWdpbk9wdGlvbj4+ID0gW107XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5hY2NvdW50TWVudUl0ZW1zID0gZ2V0QWNjb3VudE1lbnVJdGVtcyh0aGlzLnNjb3BlKCkpO1xuICB9XG59XG4iXX0=
@@ -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" }); })();
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcGx1Z2luLXNkay9zcmMvbGliL2V4dGVuc2lvbi1wb2ludHMvZ2xvYmFsLWVudHJ5cG9pbnQvY29tcG9uZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxLQUFLLEdBRU4sTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDeEQsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sa0JBQWtCLENBQUM7OztJQXdCOUQsaURBSStCOzs7SUFEN0IsQUFEQSxBQURBLCtDQUE4QixrQ0FDQSxtQ0FDQzs7QUFqQnJDLE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxLQUFhLEVBQUUsUUFBZ0IsR0FBRztJQUNyRSxPQUFPLGdCQUFnQixDQUNyQixDQUFDLFdBQVcsQ0FBQztTQUNWLE1BQU0sQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFDO1NBQ25CLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyxtQ0FBbUMsQ0FBQyxDQUM3RCxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7QUFDekQsQ0FBQztBQWVELE1BQU0sT0FBTywrQkFBK0I7SUFiNUM7UUFjRSxVQUFLLEdBQUcsS0FBSyxFQUFVLENBQUM7S0FPekI7SUFIQyxRQUFRO1FBQ04sSUFBSSxDQUFDLFdBQVcsR0FBRyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUN4RCxDQUFDO2dHQVBVLCtCQUErQjtvRUFBL0IsK0JBQStCO1lBUi9CLHlJQU1WOztZQU5VLDhCQU1WOzRCQVBTLDhCQUE4Qjs7aUZBUzdCLCtCQUErQjtjQWIzQyxTQUFTO2VBQUM7Z0JBQ1QsUUFBUSxFQUFFLDhCQUE4QjtnQkFDeEMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07Z0JBQy9DLFVBQVUsRUFBRSxJQUFJO2dCQUNoQixPQUFPLEVBQUUsQ0FBQyw4QkFBOEIsQ0FBQztnQkFDekMsUUFBUSxFQUFFOzs7Ozs7SUFNUjthQUNIOztrRkFDWSwrQkFBK0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBpbnB1dCxcbiAgT25Jbml0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgZ2V0QXBwRXh0ZW5zaW9ucyB9IGZyb20gJy4uLy4uL2FwcC1leHRlbnNpb25zJztcbmltcG9ydCB7IFJlbW90ZUNvbXBvbmVudE91dGxldENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgRXh0ZW5zaW9uIH0gZnJvbSAnLi4vLi4vZXh0ZW5zaW9ucy1sb2FkZXInO1xuXG5leHBvcnQgaW50ZXJmYWNlIEdsb2JhbEVudHJ5UG9pbnRPcHRpb24ge1xuICBpbmRleD86IG51bWJlcjtcbiAgZXhwb3NlPzogc3RyaW5nO1xuICBjb21wb25lbnQ6IHN0cmluZztcbiAgcGx1Z2luTmFtZT86IHN0cmluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEdsb2JhbEVudHJ5UG9pbnRzKHNjb3BlOiBzdHJpbmcsIF9uYW1lOiBzdHJpbmcgPSAnKicpIHtcbiAgcmV0dXJuIGdldEFwcEV4dGVuc2lvbnM8R2xvYmFsRW50cnlQb2ludE9wdGlvbj4oXG4gICAgWydjb25zb2xlLSonXVxuICAgICAgLmNvbmNhdChzY29wZSB8fCBbXSlcbiAgICAgIC5tYXAoc2NvcGUgPT4gYCR7c2NvcGV9L3BhZ2UvYm9keS9nbG9iYWwtZW50cnlwb2ludC9pdGVtYCksXG4gICkuc29ydCgoYSwgYikgPT4gLShhLm9wdGlvbnMuaW5kZXggLSBiLm9wdGlvbnMuaW5kZXgpKTtcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncGxnLXJlbW90ZS1nbG9iYWwtZW50cnlwb2ludCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbUmVtb3RlQ29tcG9uZW50T3V0bGV0Q29tcG9uZW50XSxcbiAgdGVtcGxhdGU6IGBAZm9yIChpdGVtIG9mIGVudHJ5UG9pbnRzOyB0cmFjayAkaW5kZXgpIHtcbiAgICA8cGxnLXJlbW90ZS1jb21wb25lbnQtb3V0bGV0XG4gICAgICBbZW50cnlwb2ludF09XCJpdGVtLmVudHJ5cG9pbnRcIlxuICAgICAgW2V4cG9zZV09XCJpdGVtLm9wdGlvbnMuZXhwb3NlXCJcbiAgICAgIFtuYW1lXT1cIml0ZW0ub3B0aW9ucy5jb21wb25lbnRcIlxuICAgID48L3BsZy1yZW1vdGUtY29tcG9uZW50LW91dGxldD5cbiAgfWAsXG59KVxuZXhwb3J0IGNsYXNzIFJlbW90ZUdsb2JhbEVudHJ5UG9pbnRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBzY29wZSA9IGlucHV0PHN0cmluZz4oKTtcblxuICBlbnRyeVBvaW50czogQXJyYXk8RXh0ZW5zaW9uPEdsb2JhbEVudHJ5UG9pbnRPcHRpb24+PjtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmVudHJ5UG9pbnRzID0gZ2V0R2xvYmFsRW50cnlQb2ludHModGhpcy5zY29wZSgpKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,2 @@
1
+ export * from './components';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3BsdWdpbi1zZGsvc3JjL2xpYi9leHRlbnNpb24tcG9pbnRzL2dsb2JhbC1lbnRyeXBvaW50L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzJztcbiJdfQ==
@@ -26,23 +26,17 @@ export class RemoteHeaderActionsComponent {
26
26
  i0.ɵɵrepeaterCreate(0, RemoteHeaderActionsComponent_For_1_Template, 1, 3, "plg-remote-component-outlet", 0, i0.ɵɵrepeaterTrackByIndex);
27
27
  } if (rf & 2) {
28
28
  i0.ɵɵrepeater(ctx.headerActions);
29
- } }, dependencies: [RemoteComponentOutletComponent], encapsulation: 2, changeDetection: 0 }); }
29
+ } }, dependencies: [RemoteComponentOutletComponent], styles: ["[_nghost-%COMP%]{display:flex;align-items:center}[_nghost-%COMP%] .plg-header-icon-button{margin-right:8px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:16px;border-radius:2px;color:rgb(var(--aui-color-n-2));cursor:pointer}[_ngcontent-%COMP%]:is().isActive, [_ngcontent-%COMP%]:is():hover{background-color:rgb(var(--aui-color-primary));color:#fff}"], changeDetection: 0 }); }
30
30
  }
31
31
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RemoteHeaderActionsComponent, [{
32
32
  type: Component,
33
- args: [{
34
- selector: 'plg-remote-header-actions',
35
- template: `@for (item of headerActions; track $index) {
33
+ args: [{ selector: 'plg-remote-header-actions', template: `@for (item of headerActions; track $index) {
36
34
  <plg-remote-component-outlet
37
35
  [entrypoint]="item.entrypoint"
38
36
  [expose]="item.options.expose"
39
37
  [name]="item.options.component"
40
38
  ></plg-remote-component-outlet>
41
- }`,
42
- changeDetection: ChangeDetectionStrategy.OnPush,
43
- standalone: true,
44
- imports: [RemoteComponentOutletComponent],
45
- }]
39
+ }`, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [RemoteComponentOutletComponent], styles: [":host{display:flex;align-items:center}:host ::ng-deep .plg-header-icon-button{margin-right:8px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:16px;border-radius:2px;color:rgb(var(--aui-color-n-2));cursor:pointer}:is().isActive,:is():hover{background-color:rgb(var(--aui-color-primary));color:#fff}\n"] }]
46
40
  }], null, null); })();
47
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RemoteHeaderActionsComponent, { className: "RemoteHeaderActionsComponent", filePath: "lib/extension-points/header-actions.ts", lineNumber: 39 }); })();
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLWFjdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3BsdWdpbi1zZGsvc3JjL2xpYi9leHRlbnNpb24tcG9pbnRzL2hlYWRlci1hY3Rpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULEtBQUssR0FFTixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNyRCxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxlQUFlLENBQUM7OztJQW9CM0QsaURBSStCOzs7SUFEN0IsQUFEQSxBQURBLCtDQUE4QixrQ0FDQSxtQ0FDQzs7QUFkckMsTUFBTSxVQUFVLGdCQUFnQixDQUFDLEtBQWE7SUFDNUMsT0FBTyxnQkFBZ0IsQ0FDckIsQ0FBQyxXQUFXLENBQUM7U0FDVixNQUFNLENBQUMsS0FBSyxJQUFJLEVBQUUsQ0FBQztTQUNuQixHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEtBQUsscUJBQXFCLENBQUMsQ0FDL0MsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0FBQ3pELENBQUM7QUFlRCxNQUFNLE9BQU8sNEJBQTRCO0lBYnpDO1FBY0UsVUFBSyxHQUFHLEtBQUssRUFBVSxDQUFDO1FBRXhCLGtCQUFhLEdBQWdELEVBQUUsQ0FBQztLQUtqRTtJQUhDLFFBQVE7UUFDTixJQUFJLENBQUMsYUFBYSxHQUFHLGdCQUFnQixDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQ3RELENBQUM7NkZBUFUsNEJBQTRCO29FQUE1Qiw0QkFBNEI7WUFYNUIsc0lBTVY7O1lBTlUsZ0NBTVY7NEJBR1MsOEJBQThCOztpRkFFN0IsNEJBQTRCO2NBYnhDLFNBQVM7ZUFBQztnQkFDVCxRQUFRLEVBQUUsMkJBQTJCO2dCQUNyQyxRQUFRLEVBQUU7Ozs7OztJQU1SO2dCQUNGLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2dCQUMvQyxVQUFVLEVBQUUsSUFBSTtnQkFDaEIsT0FBTyxFQUFFLENBQUMsOEJBQThCLENBQUM7YUFDMUM7O2tGQUNZLDRCQUE0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIGlucHV0LFxuICBPbkluaXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBnZXRBcHBFeHRlbnNpb25zIH0gZnJvbSAnLi4vYXBwLWV4dGVuc2lvbnMnO1xuaW1wb3J0IHsgUmVtb3RlQ29tcG9uZW50T3V0bGV0Q29tcG9uZW50IH0gZnJvbSAnLi4vY29tcG9uZW50cyc7XG5pbXBvcnQgeyBFeHRlbnNpb24gfSBmcm9tICcuLi9leHRlbnNpb25zLWxvYWRlcic7XG5cbmludGVyZmFjZSBIZWFkZXJBY3Rpb25zUGx1Z2luT3B0aW9uIHtcbiAgaW5kZXg/OiBudW1iZXI7XG4gIGV4cG9zZT86IHN0cmluZztcbiAgY29tcG9uZW50OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRIZWFkZXJBY3Rpb25zKHNjb3BlOiBzdHJpbmcpIHtcbiAgcmV0dXJuIGdldEFwcEV4dGVuc2lvbnM8SGVhZGVyQWN0aW9uc1BsdWdpbk9wdGlvbj4oXG4gICAgWydjb25zb2xlLSonXVxuICAgICAgLmNvbmNhdChzY29wZSB8fCBbXSlcbiAgICAgIC5tYXAoc2NvcGUgPT4gYCR7c2NvcGV9L3BhZ2UvaGVhZGVyL2FjdGlvbmApLFxuICApLnNvcnQoKGEsIGIpID0+IC0oYS5vcHRpb25zLmluZGV4IC0gYi5vcHRpb25zLmluZGV4KSk7XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3BsZy1yZW1vdGUtaGVhZGVyLWFjdGlvbnMnLFxuICB0ZW1wbGF0ZTogYEBmb3IgKGl0ZW0gb2YgaGVhZGVyQWN0aW9uczsgdHJhY2sgJGluZGV4KSB7XG4gICAgPHBsZy1yZW1vdGUtY29tcG9uZW50LW91dGxldFxuICAgICAgW2VudHJ5cG9pbnRdPVwiaXRlbS5lbnRyeXBvaW50XCJcbiAgICAgIFtleHBvc2VdPVwiaXRlbS5vcHRpb25zLmV4cG9zZVwiXG4gICAgICBbbmFtZV09XCJpdGVtLm9wdGlvbnMuY29tcG9uZW50XCJcbiAgICA+PC9wbGctcmVtb3RlLWNvbXBvbmVudC1vdXRsZXQ+XG4gIH1gLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1JlbW90ZUNvbXBvbmVudE91dGxldENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFJlbW90ZUhlYWRlckFjdGlvbnNDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBzY29wZSA9IGlucHV0PHN0cmluZz4oKTtcblxuICBoZWFkZXJBY3Rpb25zOiBBcnJheTxFeHRlbnNpb248SGVhZGVyQWN0aW9uc1BsdWdpbk9wdGlvbj4+ID0gW107XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5oZWFkZXJBY3Rpb25zID0gZ2V0SGVhZGVyQWN0aW9ucyh0aGlzLnNjb3BlKCkpO1xuICB9XG59XG4iXX0=
41
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RemoteHeaderActionsComponent, { className: "RemoteHeaderActionsComponent" }); })();
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLWFjdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3BsdWdpbi1zZGsvc3JjL2xpYi9leHRlbnNpb24tcG9pbnRzL2hlYWRlci1hY3Rpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULEtBQUssR0FFTixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNyRCxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxlQUFlLENBQUM7OztJQW9CM0QsaURBSStCOzs7SUFEN0IsQUFEQSxBQURBLCtDQUE4QixrQ0FDQSxtQ0FDQzs7QUFkckMsTUFBTSxVQUFVLGdCQUFnQixDQUFDLEtBQWE7SUFDNUMsT0FBTyxnQkFBZ0IsQ0FDckIsQ0FBQyxXQUFXLENBQUM7U0FDVixNQUFNLENBQUMsS0FBSyxJQUFJLEVBQUUsQ0FBQztTQUNuQixHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEtBQUsscUJBQXFCLENBQUMsQ0FDL0MsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0FBQ3pELENBQUM7QUF3Q0QsTUFBTSxPQUFPLDRCQUE0QjtJQXRDekM7UUF1Q0UsVUFBSyxHQUFHLEtBQUssRUFBVSxDQUFDO1FBRXhCLGtCQUFhLEdBQWdELEVBQUUsQ0FBQztLQUtqRTtJQUhDLFFBQVE7UUFDTixJQUFJLENBQUMsYUFBYSxHQUFHLGdCQUFnQixDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQ3RELENBQUM7NkZBUFUsNEJBQTRCO29FQUE1Qiw0QkFBNEI7WUFwQzVCLHNJQU1WOztZQU5VLGdDQU1WOzRCQTRCUyw4QkFBOEI7O2lGQUU3Qiw0QkFBNEI7Y0F0Q3hDLFNBQVM7MkJBQ0UsMkJBQTJCLFlBQzNCOzs7Ozs7SUFNUixtQkEwQmUsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1AsQ0FBQyw4QkFBOEIsQ0FBQzs7a0ZBRTlCLDRCQUE0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIGlucHV0LFxuICBPbkluaXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBnZXRBcHBFeHRlbnNpb25zIH0gZnJvbSAnLi4vYXBwLWV4dGVuc2lvbnMnO1xuaW1wb3J0IHsgUmVtb3RlQ29tcG9uZW50T3V0bGV0Q29tcG9uZW50IH0gZnJvbSAnLi4vY29tcG9uZW50cyc7XG5pbXBvcnQgeyBFeHRlbnNpb24gfSBmcm9tICcuLi9leHRlbnNpb25zLWxvYWRlcic7XG5cbmludGVyZmFjZSBIZWFkZXJBY3Rpb25zUGx1Z2luT3B0aW9uIHtcbiAgaW5kZXg/OiBudW1iZXI7XG4gIGV4cG9zZT86IHN0cmluZztcbiAgY29tcG9uZW50OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRIZWFkZXJBY3Rpb25zKHNjb3BlOiBzdHJpbmcpIHtcbiAgcmV0dXJuIGdldEFwcEV4dGVuc2lvbnM8SGVhZGVyQWN0aW9uc1BsdWdpbk9wdGlvbj4oXG4gICAgWydjb25zb2xlLSonXVxuICAgICAgLmNvbmNhdChzY29wZSB8fCBbXSlcbiAgICAgIC5tYXAoc2NvcGUgPT4gYCR7c2NvcGV9L3BhZ2UvaGVhZGVyL2FjdGlvbmApLFxuICApLnNvcnQoKGEsIGIpID0+IC0oYS5vcHRpb25zLmluZGV4IC0gYi5vcHRpb25zLmluZGV4KSk7XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3BsZy1yZW1vdGUtaGVhZGVyLWFjdGlvbnMnLFxuICB0ZW1wbGF0ZTogYEBmb3IgKGl0ZW0gb2YgaGVhZGVyQWN0aW9uczsgdHJhY2sgJGluZGV4KSB7XG4gICAgPHBsZy1yZW1vdGUtY29tcG9uZW50LW91dGxldFxuICAgICAgW2VudHJ5cG9pbnRdPVwiaXRlbS5lbnRyeXBvaW50XCJcbiAgICAgIFtleHBvc2VdPVwiaXRlbS5vcHRpb25zLmV4cG9zZVwiXG4gICAgICBbbmFtZV09XCJpdGVtLm9wdGlvbnMuY29tcG9uZW50XCJcbiAgICA+PC9wbGctcmVtb3RlLWNvbXBvbmVudC1vdXRsZXQ+XG4gIH1gLFxuICBzdHlsZXM6IGBcbiAgICA6aG9zdCB7XG4gICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICB9XG5cbiAgICA6aG9zdCA6Om5nLWRlZXAgLnBsZy1oZWFkZXItaWNvbi1idXR0b24ge1xuICAgICAgbWFyZ2luLXJpZ2h0OiA4cHg7XG4gICAgICB3aWR0aDogMjhweDtcbiAgICAgIGhlaWdodDogMjhweDtcbiAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gICAgICBmb250LXNpemU6IDE2cHg7XG4gICAgICBib3JkZXItcmFkaXVzOiAycHg7XG4gICAgICBjb2xvcjogcmdiKHZhcigtLWF1aS1jb2xvci1uLTIpKTtcbiAgICAgIGN1cnNvcjogcG9pbnRlcjtcblxuICAgICAgJi5pc0FjdGl2ZSxcbiAgICAgICY6aG92ZXIge1xuICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiByZ2IodmFyKC0tYXVpLWNvbG9yLXByaW1hcnkpKTtcbiAgICAgICAgY29sb3I6IHdoaXRlO1xuICAgICAgfVxuICAgIH1cbiAgYCxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtSZW1vdGVDb21wb25lbnRPdXRsZXRDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBSZW1vdGVIZWFkZXJBY3Rpb25zQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgc2NvcGUgPSBpbnB1dDxzdHJpbmc+KCk7XG5cbiAgaGVhZGVyQWN0aW9uczogQXJyYXk8RXh0ZW5zaW9uPEhlYWRlckFjdGlvbnNQbHVnaW5PcHRpb24+PiA9IFtdO1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMuaGVhZGVyQWN0aW9ucyA9IGdldEhlYWRlckFjdGlvbnModGhpcy5zY29wZSgpKTtcbiAgfVxufVxuIl19
@@ -44,5 +44,5 @@ export class RemoteHelpMenuItemsComponent {
44
44
  imports: [RemoteComponentOutletComponent],
45
45
  }]
46
46
  }], null, null); })();
47
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RemoteHelpMenuItemsComponent, { className: "RemoteHelpMenuItemsComponent", filePath: "lib/extension-points/help-menu.ts", lineNumber: 39 }); })();
47
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RemoteHelpMenuItemsComponent, { className: "RemoteHelpMenuItemsComponent" }); })();
48
48
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC1tZW51LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9wbHVnaW4tc2RrL3NyYy9saWIvZXh0ZW5zaW9uLXBvaW50cy9oZWxwLW1lbnUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsS0FBSyxHQUVOLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3JELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0lBb0IzRCxpREFJK0I7OztJQUQ3QixBQURBLEFBREEsK0NBQThCLGtDQUNBLG1DQUNDOztBQWRyQyxNQUFNLFVBQVUsZ0JBQWdCLENBQUMsS0FBYTtJQUM1QyxPQUFPLGdCQUFnQixDQUNyQixDQUFDLFdBQVcsQ0FBQztTQUNWLE1BQU0sQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFDO1NBQ25CLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyw2QkFBNkIsQ0FBQyxDQUN2RCxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7QUFDekQsQ0FBQztBQWVELE1BQU0sT0FBTyw0QkFBNEI7SUFiekM7UUFjRSxVQUFLLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFFeEIsa0JBQWEsR0FBK0MsRUFBRSxDQUFDO0tBS2hFO0lBSEMsUUFBUTtRQUNOLElBQUksQ0FBQyxhQUFhLEdBQUcsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDdEQsQ0FBQzs2RkFQVSw0QkFBNEI7b0VBQTVCLDRCQUE0QjtZQVg1QixzSUFNVjs7WUFOVSxnQ0FNVjs0QkFHUyw4QkFBOEI7O2lGQUU3Qiw0QkFBNEI7Y0FieEMsU0FBUztlQUFDO2dCQUNULFFBQVEsRUFBRSw0QkFBNEI7Z0JBQ3RDLFFBQVEsRUFBRTs7Ozs7O0lBTVI7Z0JBQ0YsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07Z0JBQy9DLFVBQVUsRUFBRSxJQUFJO2dCQUNoQixPQUFPLEVBQUUsQ0FBQyw4QkFBOEIsQ0FBQzthQUMxQzs7a0ZBQ1ksNEJBQTRCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgaW5wdXQsXG4gIE9uSW5pdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IGdldEFwcEV4dGVuc2lvbnMgfSBmcm9tICcuLi9hcHAtZXh0ZW5zaW9ucyc7XG5pbXBvcnQgeyBSZW1vdGVDb21wb25lbnRPdXRsZXRDb21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzJztcbmltcG9ydCB7IEV4dGVuc2lvbiB9IGZyb20gJy4uL2V4dGVuc2lvbnMtbG9hZGVyJztcblxuaW50ZXJmYWNlIEhlbHBNZW51SXRlbVBsdWdpbk9wdGlvbiB7XG4gIGluZGV4PzogbnVtYmVyO1xuICBleHBvc2U/OiBzdHJpbmc7XG4gIGNvbXBvbmVudDogc3RyaW5nO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0SGVscE1lbnVJdGVtcyhzY29wZTogc3RyaW5nKSB7XG4gIHJldHVybiBnZXRBcHBFeHRlbnNpb25zPEhlbHBNZW51SXRlbVBsdWdpbk9wdGlvbj4oXG4gICAgWydjb25zb2xlLSonXVxuICAgICAgLmNvbmNhdChzY29wZSB8fCBbXSlcbiAgICAgIC5tYXAoc2NvcGUgPT4gYCR7c2NvcGV9L3BhZ2UvaGVhZGVyL2hlbHAtbWVudS9pdGVtYCksXG4gICkuc29ydCgoYSwgYikgPT4gLShhLm9wdGlvbnMuaW5kZXggLSBiLm9wdGlvbnMuaW5kZXgpKTtcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncGxnLXJlbW90ZS1oZWxwLW1lbnUtaXRlbXMnLFxuICB0ZW1wbGF0ZTogYEBmb3IgKGl0ZW0gb2YgaGVscE1lbnVJdGVtczsgdHJhY2sgJGluZGV4KSB7XG4gICAgPHBsZy1yZW1vdGUtY29tcG9uZW50LW91dGxldFxuICAgICAgW2VudHJ5cG9pbnRdPVwiaXRlbS5lbnRyeXBvaW50XCJcbiAgICAgIFtleHBvc2VdPVwiaXRlbS5vcHRpb25zLmV4cG9zZVwiXG4gICAgICBbbmFtZV09XCJpdGVtLm9wdGlvbnMuY29tcG9uZW50XCJcbiAgICA+PC9wbGctcmVtb3RlLWNvbXBvbmVudC1vdXRsZXQ+XG4gIH1gLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1JlbW90ZUNvbXBvbmVudE91dGxldENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFJlbW90ZUhlbHBNZW51SXRlbXNDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBzY29wZSA9IGlucHV0PHN0cmluZz4oKTtcblxuICBoZWxwTWVudUl0ZW1zOiBBcnJheTxFeHRlbnNpb248SGVscE1lbnVJdGVtUGx1Z2luT3B0aW9uPj4gPSBbXTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmhlbHBNZW51SXRlbXMgPSBnZXRIZWxwTWVudUl0ZW1zKHRoaXMuc2NvcGUoKSk7XG4gIH1cbn1cbiJdfQ==
@@ -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==
@@ -4,11 +4,16 @@ export async function loadExtensions(query = {}) {
4
4
  if (getBootMode() === 'safe') {
5
5
  return [];
6
6
  }
7
- return isLocalEnv()
8
- ? await loadDevExtensions(query)
9
- : await loadProdExtensions(query);
7
+ if (isLocalEnv()) {
8
+ const [prodExtensions, devExtensions] = await Promise.all([
9
+ loadProdExtensions(query),
10
+ loadDevExtensions(),
11
+ ]);
12
+ return [...prodExtensions, ...devExtensions];
13
+ }
14
+ return loadProdExtensions(query);
10
15
  }
11
- async function loadDevExtensions(query = {}) {
16
+ async function loadDevExtensions() {
12
17
  return await fetch(`/dev-plugin/console-plugin.json`)
13
18
  .then(res => {
14
19
  if (!res.ok) {
@@ -24,8 +29,7 @@ async function loadDevExtensions(query = {}) {
24
29
  entrypoint: '/dev-plugin',
25
30
  })))
26
31
  .catch(() => {
27
- console.warn('Failed to fetch local dev extensions, loading prod extensions');
28
- return loadProdExtensions(query);
32
+ return [];
29
33
  });
30
34
  }
31
35
  async function loadProdExtensions(query = {}) {
@@ -68,4 +72,4 @@ async function loadProdExtensions(query = {}) {
68
72
  return [];
69
73
  });
70
74
  }
71
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"extensions-loader.js","sourceRoot":"","sources":["../../../../../libs/plugin-sdk/src/lib/extensions-loader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAE9D,OAAO,EAAE,WAAW,EAAE,wBAAwB,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAE5E,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,QAAyB,EAAE;IAC9D,IAAI,WAAW,EAAE,KAAK,MAAM,EAAE,CAAC;QAC7B,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,OAAO,UAAU,EAAE;QACjB,CAAC,CAAC,MAAM,iBAAiB,CAAC,KAAK,CAAC;QAChC,CAAC,CAAC,MAAM,kBAAkB,CAAC,KAAK,CAAC,CAAC;AACtC,CAAC;AAED,KAAK,UAAU,iBAAiB,CAC9B,QAAyB,EAAE;IAE3B,OAAO,MAAM,KAAK,CAAC,iCAAiC,CAAC;SAClD,IAAI,CAAC,GAAG,CAAC,EAAE;QACV,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;YACZ,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;QAC1D,CAAC;QACD,OAAO,GAAG,CAAC,IAAI,EAAE,CAAC;IACpB,CAAC,CAAC;SACD,IAAI,CAAC,CAAC,MAAkB,EAAE,EAAE,CAC3B,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAC5B,GAAG,wBAAwB;QAC3B,GAAG,GAAG;QACN,YAAY,EAAE,MAAM,CAAC,YAAY,IAAI,EAAE;QACvC,WAAW,EAAE,MAAM,CAAC,WAAW;QAC/B,UAAU,EAAE,aAAa;KAC1B,CAAC,CAAC,CACJ;SACA,KAAK,CAAC,GAAG,EAAE;QACV,OAAO,CAAC,IAAI,CACV,+DAA+D,CAChE,CAAC;QACF,OAAO,kBAAkB,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;AACP,CAAC;AAED,KAAK,UAAU,kBAAkB,CAC/B,QAAyB,EAAE;IAE3B,MAAM,SAAS,GAAG,UAAU,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC;IACrD,MAAM,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC;SACtC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;SAClD,IAAI,CAAC,GAAG,CAAC,CAAC;IAEb,OAAO,MAAM,KAAK,CAChB,GAAG,SAAS,6CAA6C,WAAW,IAAI,UAAU,GAAG,kBAAkB,CAAC,WAAW,CAAC,EAAE,EACtH;QACE,OAAO,EAAE,yBAAyB,EAAE;KACrC,CACF;SACE,IAAI,CAAC,GAAG,CAAC,EAAE;QACV,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;YACZ,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAChD,CAAC;QACD,OAAO,GAAG,CAAC,IAAI,EAAE,CAAC;IACpB,CAAC,CAAC;SACD,IAAI,CAAC,CAAC,UAAsB,EAAE,EAAE,CAC/B,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,MAAM,CAC/B,CAAC,GAAG,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,EAAE,CAC1B,GAAG,CAAC,MAAM,CACR,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;QACvB,IAAI,CAAC;YACH,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAC3B,MAAM,CAAC,qBAAqB,CAAC,CAChB,CAAC;YAEhB,OAAO,UAAU,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBACvC,GAAG,GAAG;gBACN,OAAO;gBACP,UAAU,EAAE,MAAM,CAAC,IAAI;gBACvB,aAAa,EAAE,MAAM,CAAC,OAAO;gBAC7B,OAAO,EAAE,MAAM,CAAC,IAAI;qBACjB,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;qBACvC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC;gBACvB,UAAU,EAAE,GAAG,SAAS,qBAAqB,OAAO,GAAG,MAAM,CAAC,IAAI,EAAE;gBACpE,YAAY,EAAE,UAAU,CAAC,YAAY,IAAI,EAAE;gBAC3C,WAAW,EAAE,UAAU,CAAC,WAAW;aACpC,CAAC,CAAC,CAAC;QACN,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CACX,kDAAkD,MAAM,CAAC,IAAI,GAAG,EAChE,KAAK,CACN,CAAC;YACF,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC,CAAC,CACH,EACH,EAAiB,CAClB,CACF;SACA,KAAK,CAAC,GAAG,CAAC,EAAE;QACX,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACnB,OAAO,EAAE,CAAC;IACZ,CAAC,CAAC,CAAC;AACP,CAAC","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"]}
75
+ //# 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  if (isLocalEnv()) {\n    const [prodExtensions, devExtensions] = await Promise.all([\n      loadProdExtensions(query),\n      loadDevExtensions(),\n    ]);\n\n    return [...prodExtensions, ...devExtensions];\n  }\n  return loadProdExtensions(query);\n}\n\nasync function loadDevExtensions(): 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      return [];\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"]}
@@ -12,12 +12,12 @@ export function isStaticPluginPath(publicPath) {
12
12
  export const LOCAL_DEV_EXTENSION_INFO = {
13
13
  cluster: GLOBAL_CLUSTER,
14
14
  pluginName: 'local-dev',
15
- pluginVersion: 'v1.0.0',
15
+ pluginVersion: 'v99',
16
16
  appName: 'default',
17
17
  };
18
18
  export const STATIC_EXTENSION_INFO = {
19
19
  cluster: GLOBAL_CLUSTER,
20
- pluginVersion: 'v1.0.0',
20
+ pluginVersion: 'v99',
21
21
  appName: 'default',
22
22
  };
23
23
  export function getBootMode() {
@@ -74,4 +74,4 @@ export const translateScope = (extension, locale) => {
74
74
  export const translateScopeKey = (scope, key) => {
75
75
  return `${scope}.${key}`;
76
76
  };
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"]}
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: 'v99',\n  appName: 'default',\n};\n\nexport const STATIC_EXTENSION_INFO = {\n  cluster: GLOBAL_CLUSTER,\n  pluginVersion: 'v99',\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,13 +1,8 @@
1
- import { isStaticPluginPath, LOCAL_DEV_EXTENSION_INFO, STATIC_EXTENSION_INFO, isLocalEnv, } from '@alauda-fe/plugin-sdk';
1
+ import { GLOBAL_CLUSTER } from '@alauda-fe/common';
2
+ import { isStaticPluginPath, LOCAL_DEV_EXTENSION_INFO, STATIC_EXTENSION_INFO, } from '@alauda-fe/plugin-sdk';
2
3
  export const PUBLIC_PATH = __webpack_public_path__;
3
4
  export const RUNTIME = runtimeInfo();
4
5
  function runtimeInfo() {
5
- if (isLocalEnv()) {
6
- return {
7
- ...LOCAL_DEV_EXTENSION_INFO,
8
- publicPath: PUBLIC_PATH,
9
- };
10
- }
11
6
  const arr = PUBLIC_PATH.split('/');
12
7
  if (isStaticPluginPath(PUBLIC_PATH)) {
13
8
  const pluginIndex = arr.findIndex(item => item === '_plugins');
@@ -19,12 +14,18 @@ function runtimeInfo() {
19
14
  }
20
15
  const clusterIndex = arr.findIndex(item => item === 'clusters-rewrite') + 1;
21
16
  const pluginIndex = arr.findIndex(item => item === 'frontend-plugins') + 1;
17
+ if (clusterIndex > 0 || pluginIndex > 0) {
18
+ return {
19
+ publicPath: PUBLIC_PATH,
20
+ cluster: arr[clusterIndex] || GLOBAL_CLUSTER,
21
+ pluginName: arr[pluginIndex + 1],
22
+ pluginVersion: arr[pluginIndex + 2],
23
+ appName: arr.slice(pluginIndex + 3, arr.length - 1).join('-'),
24
+ };
25
+ }
22
26
  return {
27
+ ...LOCAL_DEV_EXTENSION_INFO,
23
28
  publicPath: PUBLIC_PATH,
24
- cluster: arr[clusterIndex],
25
- pluginName: arr[pluginIndex + 1],
26
- pluginVersion: arr[pluginIndex + 2],
27
- appName: arr.slice(pluginIndex + 3, arr.length - 1).join('-'),
28
29
  };
29
30
  }
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcGx1Z2luLXNkay9yZW1vdGUvbGliL3J1bnRpbWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLGtCQUFrQixFQUNsQix3QkFBd0IsRUFDeEIscUJBQXFCLEVBQ3JCLFVBQVUsR0FDWCxNQUFNLHVCQUF1QixDQUFDO0FBSS9CLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyx1QkFBdUIsQ0FBQztBQUVuRCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsV0FBVyxFQUFFLENBQUM7QUFFckMsU0FBUyxXQUFXO0lBQ2xCLElBQUksVUFBVSxFQUFFLEVBQUUsQ0FBQztRQUNqQixPQUFPO1lBQ0wsR0FBRyx3QkFBd0I7WUFDM0IsVUFBVSxFQUFFLFdBQVc7U0FDeEIsQ0FBQztJQUNKLENBQUM7SUFDRCxNQUFNLEdBQUcsR0FBRyxXQUFXLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRW5DLElBQUksa0JBQWtCLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztRQUNwQyxNQUFNLFdBQVcsR0FBRyxHQUFHLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxLQUFLLFVBQVUsQ0FBQyxDQUFDO1FBRS9ELE9BQU87WUFDTCxHQUFHLHFCQUFxQjtZQUN4QixVQUFVLEVBQUUsR0FBRyxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUM7WUFDaEMsVUFBVSxFQUFFLFdBQVc7U0FDeEIsQ0FBQztJQUNKLENBQUM7SUFFRCxNQUFNLFlBQVksR0FBRyxHQUFHLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxLQUFLLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRTVFLE1BQU0sV0FBVyxHQUFHLEdBQUcsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLEtBQUssa0JBQWtCLENBQUMsR0FBRyxDQUFDLENBQUM7SUFFM0UsT0FBTztRQUNMLFVBQVUsRUFBRSxXQUFXO1FBQ3ZCLE9BQU8sRUFBRSxHQUFHLENBQUMsWUFBWSxDQUFDO1FBQzFCLFVBQVUsRUFBRSxHQUFHLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQztRQUNoQyxhQUFhLEVBQUUsR0FBRyxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUM7UUFDbkMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxLQUFLLENBQUMsV0FBVyxHQUFHLENBQUMsRUFBRSxHQUFHLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7S0FDOUQsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBpc1N0YXRpY1BsdWdpblBhdGgsXG4gIExPQ0FMX0RFVl9FWFRFTlNJT05fSU5GTyxcbiAgU1RBVElDX0VYVEVOU0lPTl9JTkZPLFxuICBpc0xvY2FsRW52LFxufSBmcm9tICdAYWxhdWRhLWZlL3BsdWdpbi1zZGsnO1xuXG5kZWNsYXJlIGNvbnN0IF9fd2VicGFja19wdWJsaWNfcGF0aF9fOiBzdHJpbmc7XG5cbmV4cG9ydCBjb25zdCBQVUJMSUNfUEFUSCA9IF9fd2VicGFja19wdWJsaWNfcGF0aF9fO1xuXG5leHBvcnQgY29uc3QgUlVOVElNRSA9IHJ1bnRpbWVJbmZvKCk7XG5cbmZ1bmN0aW9uIHJ1bnRpbWVJbmZvKCk6IFJ1bnRpbWUge1xuICBpZiAoaXNMb2NhbEVudigpKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLkxPQ0FMX0RFVl9FWFRFTlNJT05fSU5GTyxcbiAgICAgIHB1YmxpY1BhdGg6IFBVQkxJQ19QQVRILFxuICAgIH07XG4gIH1cbiAgY29uc3QgYXJyID0gUFVCTElDX1BBVEguc3BsaXQoJy8nKTtcblxuICBpZiAoaXNTdGF0aWNQbHVnaW5QYXRoKFBVQkxJQ19QQVRIKSkge1xuICAgIGNvbnN0IHBsdWdpbkluZGV4ID0gYXJyLmZpbmRJbmRleChpdGVtID0+IGl0ZW0gPT09ICdfcGx1Z2lucycpO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLlNUQVRJQ19FWFRFTlNJT05fSU5GTyxcbiAgICAgIHBsdWdpbk5hbWU6IGFycltwbHVnaW5JbmRleCArIDFdLFxuICAgICAgcHVibGljUGF0aDogUFVCTElDX1BBVEgsXG4gICAgfTtcbiAgfVxuXG4gIGNvbnN0IGNsdXN0ZXJJbmRleCA9IGFyci5maW5kSW5kZXgoaXRlbSA9PiBpdGVtID09PSAnY2x1c3RlcnMtcmV3cml0ZScpICsgMTtcblxuICBjb25zdCBwbHVnaW5JbmRleCA9IGFyci5maW5kSW5kZXgoaXRlbSA9PiBpdGVtID09PSAnZnJvbnRlbmQtcGx1Z2lucycpICsgMTtcblxuICByZXR1cm4ge1xuICAgIHB1YmxpY1BhdGg6IFBVQkxJQ19QQVRILFxuICAgIGNsdXN0ZXI6IGFycltjbHVzdGVySW5kZXhdLFxuICAgIHBsdWdpbk5hbWU6IGFycltwbHVnaW5JbmRleCArIDFdLFxuICAgIHBsdWdpblZlcnNpb246IGFycltwbHVnaW5JbmRleCArIDJdLFxuICAgIGFwcE5hbWU6IGFyci5zbGljZShwbHVnaW5JbmRleCArIDMsIGFyci5sZW5ndGggLSAxKS5qb2luKCctJyksXG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUnVudGltZSB7XG4gIHB1YmxpY1BhdGg6IHN0cmluZztcbiAgY2x1c3Rlcjogc3RyaW5nO1xuICBwbHVnaW5OYW1lOiBzdHJpbmc7XG4gIHBsdWdpblZlcnNpb246IHN0cmluZztcbiAgYXBwTmFtZTogc3RyaW5nO1xufVxuIl19
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcGx1Z2luLXNkay9yZW1vdGUvbGliL3J1bnRpbWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ25ELE9BQU8sRUFDTCxrQkFBa0IsRUFDbEIsd0JBQXdCLEVBQ3hCLHFCQUFxQixHQUN0QixNQUFNLHVCQUF1QixDQUFDO0FBSS9CLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyx1QkFBdUIsQ0FBQztBQUVuRCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsV0FBVyxFQUFFLENBQUM7QUFFckMsU0FBUyxXQUFXO0lBQ2xCLE1BQU0sR0FBRyxHQUFHLFdBQVcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7SUFFbkMsSUFBSSxrQkFBa0IsQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDO1FBQ3BDLE1BQU0sV0FBVyxHQUFHLEdBQUcsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLEtBQUssVUFBVSxDQUFDLENBQUM7UUFFL0QsT0FBTztZQUNMLEdBQUcscUJBQXFCO1lBQ3hCLFVBQVUsRUFBRSxHQUFHLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQztZQUNoQyxVQUFVLEVBQUUsV0FBVztTQUN4QixDQUFDO0lBQ0osQ0FBQztJQUVELE1BQU0sWUFBWSxHQUFHLEdBQUcsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLEtBQUssa0JBQWtCLENBQUMsR0FBRyxDQUFDLENBQUM7SUFFNUUsTUFBTSxXQUFXLEdBQUcsR0FBRyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksS0FBSyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUUzRSxJQUFJLFlBQVksR0FBRyxDQUFDLElBQUksV0FBVyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ3hDLE9BQU87WUFDTCxVQUFVLEVBQUUsV0FBVztZQUN2QixPQUFPLEVBQUUsR0FBRyxDQUFDLFlBQVksQ0FBQyxJQUFJLGNBQWM7WUFDNUMsVUFBVSxFQUFFLEdBQUcsQ0FBQyxXQUFXLEdBQUcsQ0FBQyxDQUFDO1lBQ2hDLGFBQWEsRUFBRSxHQUFHLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQztZQUNuQyxPQUFPLEVBQUUsR0FBRyxDQUFDLEtBQUssQ0FBQyxXQUFXLEdBQUcsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQztTQUM5RCxDQUFDO0lBQ0osQ0FBQztJQUVELE9BQU87UUFDTCxHQUFHLHdCQUF3QjtRQUMzQixVQUFVLEVBQUUsV0FBVztLQUN4QixDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdMT0JBTF9DTFVTVEVSIH0gZnJvbSAnQGFsYXVkYS1mZS9jb21tb24nO1xuaW1wb3J0IHtcbiAgaXNTdGF0aWNQbHVnaW5QYXRoLFxuICBMT0NBTF9ERVZfRVhURU5TSU9OX0lORk8sXG4gIFNUQVRJQ19FWFRFTlNJT05fSU5GTyxcbn0gZnJvbSAnQGFsYXVkYS1mZS9wbHVnaW4tc2RrJztcblxuZGVjbGFyZSBjb25zdCBfX3dlYnBhY2tfcHVibGljX3BhdGhfXzogc3RyaW5nO1xuXG5leHBvcnQgY29uc3QgUFVCTElDX1BBVEggPSBfX3dlYnBhY2tfcHVibGljX3BhdGhfXztcblxuZXhwb3J0IGNvbnN0IFJVTlRJTUUgPSBydW50aW1lSW5mbygpO1xuXG5mdW5jdGlvbiBydW50aW1lSW5mbygpOiBSdW50aW1lIHtcbiAgY29uc3QgYXJyID0gUFVCTElDX1BBVEguc3BsaXQoJy8nKTtcblxuICBpZiAoaXNTdGF0aWNQbHVnaW5QYXRoKFBVQkxJQ19QQVRIKSkge1xuICAgIGNvbnN0IHBsdWdpbkluZGV4ID0gYXJyLmZpbmRJbmRleChpdGVtID0+IGl0ZW0gPT09ICdfcGx1Z2lucycpO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLlNUQVRJQ19FWFRFTlNJT05fSU5GTyxcbiAgICAgIHBsdWdpbk5hbWU6IGFycltwbHVnaW5JbmRleCArIDFdLFxuICAgICAgcHVibGljUGF0aDogUFVCTElDX1BBVEgsXG4gICAgfTtcbiAgfVxuXG4gIGNvbnN0IGNsdXN0ZXJJbmRleCA9IGFyci5maW5kSW5kZXgoaXRlbSA9PiBpdGVtID09PSAnY2x1c3RlcnMtcmV3cml0ZScpICsgMTtcblxuICBjb25zdCBwbHVnaW5JbmRleCA9IGFyci5maW5kSW5kZXgoaXRlbSA9PiBpdGVtID09PSAnZnJvbnRlbmQtcGx1Z2lucycpICsgMTtcblxuICBpZiAoY2x1c3RlckluZGV4ID4gMCB8fCBwbHVnaW5JbmRleCA+IDApIHtcbiAgICByZXR1cm4ge1xuICAgICAgcHVibGljUGF0aDogUFVCTElDX1BBVEgsXG4gICAgICBjbHVzdGVyOiBhcnJbY2x1c3RlckluZGV4XSB8fCBHTE9CQUxfQ0xVU1RFUixcbiAgICAgIHBsdWdpbk5hbWU6IGFycltwbHVnaW5JbmRleCArIDFdLFxuICAgICAgcGx1Z2luVmVyc2lvbjogYXJyW3BsdWdpbkluZGV4ICsgMl0sXG4gICAgICBhcHBOYW1lOiBhcnIuc2xpY2UocGx1Z2luSW5kZXggKyAzLCBhcnIubGVuZ3RoIC0gMSkuam9pbignLScpLFxuICAgIH07XG4gIH1cblxuICByZXR1cm4ge1xuICAgIC4uLkxPQ0FMX0RFVl9FWFRFTlNJT05fSU5GTyxcbiAgICBwdWJsaWNQYXRoOiBQVUJMSUNfUEFUSCxcbiAgfTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSdW50aW1lIHtcbiAgcHVibGljUGF0aDogc3RyaW5nO1xuICBjbHVzdGVyOiBzdHJpbmc7XG4gIHBsdWdpbk5hbWU6IHN0cmluZztcbiAgcGx1Z2luVmVyc2lvbjogc3RyaW5nO1xuICBhcHBOYW1lOiBzdHJpbmc7XG59XG4iXX0=
@@ -76,6 +76,9 @@ function fetchI18nFile(lang, scope) {
76
76
  return null;
77
77
  });
78
78
  }
79
+ /**
80
+ * @deprecated use `translateScope` function from plugin-sdk instead
81
+ */
79
82
  export const getTranslateScope = (locale) => {
80
83
  const cluster = isBuiltInLanguage(locale) ? RUNTIME.cluster : GLOBAL_CLUSTER;
81
84
  return `plugin__${cluster}~${RUNTIME.pluginName}~${RUNTIME.appName}`;
@@ -195,4 +198,4 @@ export class ScopedTranslateKeyPipe {
195
198
  name: 'scopedTranslateKey',
196
199
  }]
197
200
  }], null, null); })();
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"]}
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"]}
@@ -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';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alauda-fe/plugin-sdk",
3
- "version": "0.0.17",
3
+ "version": "0.0.19-beta.0",
4
4
  "peerDependencies": {
5
5
  "@nx/angular": "^16.10.0"
6
6
  },
@@ -1,6 +1,9 @@
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;