@pepperi-addons/ngx-lib 0.4.0-angular14.50 → 0.4.0-angular14.51

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.
@@ -2,9 +2,9 @@ import { Component, Input, Output, EventEmitter, TemplateRef, ViewChild } from '
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "./remote-loader.service";
4
4
  import * as i2 from "@angular/common";
5
- import * as i3 from "@angular-architects/module-federation-tools";
6
- import * as i4 from "@pepperi-addons/ngx-lib/dialog";
7
- import * as i5 from "./remote-loader.component";
5
+ import * as i3 from "@pepperi-addons/ngx-lib/dialog";
6
+ import * as i4 from "./remote-loader.component";
7
+ import * as i5 from "./remote-loader-element.component";
8
8
  export class PepAddonBlockLoaderComponent {
9
9
  constructor(remoteLoaderService) {
10
10
  this.remoteLoaderService = remoteLoaderService;
@@ -17,7 +17,7 @@ export class PepAddonBlockLoaderComponent {
17
17
  this.blockLoad = new EventEmitter();
18
18
  this.inDialog = false;
19
19
  this.remotePathOptions = null;
20
- this.webComponentWrapperOptions = null;
20
+ this.loadElement = false;
21
21
  this.onHostEventsCallback = (event) => {
22
22
  this.onHostEvents(event.detail);
23
23
  };
@@ -43,12 +43,8 @@ export class PepAddonBlockLoaderComponent {
43
43
  }
44
44
  ngOnInit() {
45
45
  this.remoteLoaderService.getBlockRemoteLoaderOptions(this.name, this.blockType, this.remoteEntry).then((options) => {
46
- if (options.elementName?.length > 0) {
47
- this.webComponentWrapperOptions = options;
48
- }
49
- else {
50
- this.remotePathOptions = options;
51
- }
46
+ this.loadElement = options.elementName?.length > 0;
47
+ this.remotePathOptions = options;
52
48
  });
53
49
  }
54
50
  ngOnDestroy() {
@@ -56,7 +52,6 @@ export class PepAddonBlockLoaderComponent {
56
52
  this.dialogRef = null;
57
53
  }
58
54
  this.remotePathOptions = null;
59
- this.webComponentWrapperOptions = null;
60
55
  }
61
56
  onBlockLoad() {
62
57
  this.blockLoad.emit();
@@ -69,10 +64,10 @@ export class PepAddonBlockLoaderComponent {
69
64
  }
70
65
  }
71
66
  PepAddonBlockLoaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepAddonBlockLoaderComponent, deps: [{ token: i1.PepRemoteLoaderService }], target: i0.ɵɵFactoryTarget.Component });
72
- PepAddonBlockLoaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: PepAddonBlockLoaderComponent, selector: "pep-addon-block-loader", inputs: { remoteEntry: "remoteEntry", blockType: "blockType", name: "name", hostObject: "hostObject", dialogRef: "dialogRef" }, outputs: { hostEvents: "hostEvents", blockLoad: "blockLoad" }, viewQueries: [{ propertyName: "dialogTemplate", first: true, predicate: ["dialogTemplate"], descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: "<ng-container *ngIf=\"!inDialog\">\n <ng-container *ngTemplateOutlet=\"remoteLoaderTemplate\"></ng-container>\n</ng-container>\n\n<ng-template #dialogTemplate let-data>\n <pep-dialog [showClose]=\"data?.showClose\" [showHeader]=\"data?.showHeader\" [showFooter]=\"data?.showFooter\" [title]=\"data?.title\" (close)=\"closeDialog($event)\">\n <ng-container pep-dialog-content>\n <ng-container *ngTemplateOutlet=\"remoteLoaderTemplate\"></ng-container>\n </ng-container>\n </pep-dialog>\n</ng-template>\n\n<ng-template #remoteLoaderTemplate>\n <pep-remote-loader *ngIf=\"remotePathOptions\"\n [options]=\"remotePathOptions\"\n [hostObject]=\"hostObject\"\n (hostEvents)=\"onHostEvents($event);\"\n (load)=\"onBlockLoad()\">\n </pep-remote-loader>\n\n <mft-wc-wrapper *ngIf=\"webComponentWrapperOptions\" [options]=\"webComponentWrapperOptions\" [props]=\"{ hostObject: hostObject }\" [events]=\"{ hostEvents: onHostEventsCallback }\"></mft-wc-wrapper>\n\n</ng-template>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.WebComponentWrapper, selector: "mft-wc-wrapper", inputs: ["options", "props", "events"] }, { kind: "component", type: i4.PepDialogComponent, selector: "pep-dialog", inputs: ["title", "showClose", "showHeader", "showFooter"], outputs: ["close"] }, { kind: "component", type: i5.PepRemoteLoaderComponent, selector: "pep-remote-loader", inputs: ["options", "hostObject"], outputs: ["hostEvents", "load"] }] });
67
+ PepAddonBlockLoaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: PepAddonBlockLoaderComponent, selector: "pep-addon-block-loader", inputs: { remoteEntry: "remoteEntry", blockType: "blockType", name: "name", hostObject: "hostObject", dialogRef: "dialogRef" }, outputs: { hostEvents: "hostEvents", blockLoad: "blockLoad" }, viewQueries: [{ propertyName: "dialogTemplate", first: true, predicate: ["dialogTemplate"], descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: "<ng-container *ngIf=\"!inDialog\">\n <ng-container *ngTemplateOutlet=\"remoteLoaderTemplate\"></ng-container>\n</ng-container>\n\n<ng-template #dialogTemplate let-data>\n <pep-dialog [showClose]=\"data?.showClose\" [showHeader]=\"data?.showHeader\" [showFooter]=\"data?.showFooter\" [title]=\"data?.title\" (close)=\"closeDialog($event)\">\n <ng-container pep-dialog-content>\n <ng-container *ngTemplateOutlet=\"remoteLoaderTemplate\"></ng-container>\n </ng-container>\n </pep-dialog>\n</ng-template>\n\n<ng-template #remoteLoaderTemplate>\n <pep-remote-loader *ngIf=\"remotePathOptions && !loadElement\"\n [options]=\"remotePathOptions\"\n [hostObject]=\"hostObject\"\n (hostEvents)=\"onHostEvents($event);\"\n (load)=\"onBlockLoad()\">\n </pep-remote-loader>\n\n <pep-remote-loader-element *ngIf=\"remotePathOptions && loadElement\" \n [options]=\"remotePathOptions\"\n [props]=\"{ hostObject: hostObject }\"\n [events]=\"{ hostEvents: onHostEventsCallback }\"\n (load)=\"onBlockLoad()\">\n </pep-remote-loader-element>\n\n</ng-template>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.PepDialogComponent, selector: "pep-dialog", inputs: ["title", "showClose", "showHeader", "showFooter"], outputs: ["close"] }, { kind: "component", type: i4.PepRemoteLoaderComponent, selector: "pep-remote-loader", inputs: ["options", "hostObject"], outputs: ["hostEvents", "load"] }, { kind: "component", type: i5.PepRemoteLoaderElementComponent, selector: "pep-remote-loader-element", inputs: ["options", "props", "events"], outputs: ["load"] }] });
73
68
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepAddonBlockLoaderComponent, decorators: [{
74
69
  type: Component,
75
- args: [{ selector: 'pep-addon-block-loader', template: "<ng-container *ngIf=\"!inDialog\">\n <ng-container *ngTemplateOutlet=\"remoteLoaderTemplate\"></ng-container>\n</ng-container>\n\n<ng-template #dialogTemplate let-data>\n <pep-dialog [showClose]=\"data?.showClose\" [showHeader]=\"data?.showHeader\" [showFooter]=\"data?.showFooter\" [title]=\"data?.title\" (close)=\"closeDialog($event)\">\n <ng-container pep-dialog-content>\n <ng-container *ngTemplateOutlet=\"remoteLoaderTemplate\"></ng-container>\n </ng-container>\n </pep-dialog>\n</ng-template>\n\n<ng-template #remoteLoaderTemplate>\n <pep-remote-loader *ngIf=\"remotePathOptions\"\n [options]=\"remotePathOptions\"\n [hostObject]=\"hostObject\"\n (hostEvents)=\"onHostEvents($event);\"\n (load)=\"onBlockLoad()\">\n </pep-remote-loader>\n\n <mft-wc-wrapper *ngIf=\"webComponentWrapperOptions\" [options]=\"webComponentWrapperOptions\" [props]=\"{ hostObject: hostObject }\" [events]=\"{ hostEvents: onHostEventsCallback }\"></mft-wc-wrapper>\n\n</ng-template>" }]
70
+ args: [{ selector: 'pep-addon-block-loader', template: "<ng-container *ngIf=\"!inDialog\">\n <ng-container *ngTemplateOutlet=\"remoteLoaderTemplate\"></ng-container>\n</ng-container>\n\n<ng-template #dialogTemplate let-data>\n <pep-dialog [showClose]=\"data?.showClose\" [showHeader]=\"data?.showHeader\" [showFooter]=\"data?.showFooter\" [title]=\"data?.title\" (close)=\"closeDialog($event)\">\n <ng-container pep-dialog-content>\n <ng-container *ngTemplateOutlet=\"remoteLoaderTemplate\"></ng-container>\n </ng-container>\n </pep-dialog>\n</ng-template>\n\n<ng-template #remoteLoaderTemplate>\n <pep-remote-loader *ngIf=\"remotePathOptions && !loadElement\"\n [options]=\"remotePathOptions\"\n [hostObject]=\"hostObject\"\n (hostEvents)=\"onHostEvents($event);\"\n (load)=\"onBlockLoad()\">\n </pep-remote-loader>\n\n <pep-remote-loader-element *ngIf=\"remotePathOptions && loadElement\" \n [options]=\"remotePathOptions\"\n [props]=\"{ hostObject: hostObject }\"\n [events]=\"{ hostEvents: onHostEventsCallback }\"\n (load)=\"onBlockLoad()\">\n </pep-remote-loader-element>\n\n</ng-template>" }]
76
71
  }], ctorParameters: function () { return [{ type: i1.PepRemoteLoaderService }]; }, propDecorators: { dialogTemplate: [{
77
72
  type: ViewChild,
78
73
  args: ['dialogTemplate', { static: true, read: TemplateRef }]
@@ -91,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
91
86
  }], blockLoad: [{
92
87
  type: Output
93
88
  }] } });
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"addon-block-loader.component.js","sourceRoot":"","sources":["../../../../projects/ngx-lib/remote-loader/addon-block-loader.component.ts","../../../../projects/ngx-lib/remote-loader/addon-block-loader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { WebComponentWrapperOptions } from '@angular-architects/module-federation-tools';\nimport { Component, OnInit, Input, Output, EventEmitter, TemplateRef, ViewChild, OnDestroy } from '@angular/core';\nimport { MatDialogRef } from '@angular/material/dialog';\nimport { PepBlockDataType, PepRemoteLoaderOptions } from './remote-loader.model';\nimport { PepRemoteLoaderService } from './remote-loader.service';\n\n@Component({\n    selector: 'pep-addon-block-loader',\n    templateUrl: './addon-block-loader.component.html',\n    styleUrls: ['./addon-block-loader.component.scss']\n})\nexport class PepAddonBlockLoaderComponent implements OnInit, OnDestroy {\n    @ViewChild('dialogTemplate', { static: true, read: TemplateRef }) dialogTemplate!: TemplateRef<any>;\n    \n    @Input() remoteEntry: string = '';\n\n    private _blockType: PepBlockDataType = 'AddonBlock';\n    @Input() \n    set blockType(value: PepBlockDataType) {\n        this._blockType = value;\n    }\n    get blockType(): PepBlockDataType {\n        return this._blockType;\n    }\n\n    private _name = '';\n    @Input() \n    set name(value: string) {\n        this._name = value;\n    }\n    get name(): string {\n        return this._name;\n    }\n\n    @Input() hostObject = null;\n    \n    private _dialogRef: MatDialogRef<any> = null;\n    @Input()\n    set dialogRef(value: MatDialogRef<any>) {\n        this._dialogRef = value;\n        this.inDialog = this._dialogRef != null;\n    }\n    get dialogRef(): MatDialogRef<any> {\n        return this._dialogRef;\n    }\n    \n    @Output() hostEvents: EventEmitter<any> = new EventEmitter<any>();\n    @Output() blockLoad: EventEmitter<void> = new EventEmitter<void>();\n    \n    protected inDialog = false;\n    protected remotePathOptions: PepRemoteLoaderOptions = null;\n    protected webComponentWrapperOptions: WebComponentWrapperOptions = null;\n    \n    protected onHostEventsCallback: (event: CustomEvent) => void;\n\n    constructor(private remoteLoaderService: PepRemoteLoaderService) {\n        this.onHostEventsCallback = (event: CustomEvent) => {\n            this.onHostEvents(event.detail);\n        }\n    }\n    \n    ngOnInit() {\n        this.remoteLoaderService.getBlockRemoteLoaderOptions(this.name, this.blockType, this.remoteEntry).then((options: PepRemoteLoaderOptions) => {\n            if (options.elementName?.length > 0) {\n                this.webComponentWrapperOptions = options as WebComponentWrapperOptions;\n            } else {\n                this.remotePathOptions = options;\n            }\n        });\n    }\n\n    ngOnDestroy(): void {\n        if (this.dialogRef) {\n            this.dialogRef = null;\n        }\n\n        this.remotePathOptions = null;\n        this.webComponentWrapperOptions = null;\n    }\n\n    onBlockLoad() {\n        this.blockLoad.emit();\n    }\n\n    onHostEvents(event: any) {\n        this.hostEvents.emit(event);\n    }\n\n    closeDialog(event) {\n        this.dialogRef?.close(event);\n    }\n}","<ng-container *ngIf=\"!inDialog\">\n    <ng-container *ngTemplateOutlet=\"remoteLoaderTemplate\"></ng-container>\n</ng-container>\n\n<ng-template #dialogTemplate let-data>\n    <pep-dialog [showClose]=\"data?.showClose\" [showHeader]=\"data?.showHeader\" [showFooter]=\"data?.showFooter\" [title]=\"data?.title\" (close)=\"closeDialog($event)\">\n        <ng-container pep-dialog-content>\n            <ng-container *ngTemplateOutlet=\"remoteLoaderTemplate\"></ng-container>\n        </ng-container>\n    </pep-dialog>\n</ng-template>\n\n<ng-template #remoteLoaderTemplate>\n    <pep-remote-loader *ngIf=\"remotePathOptions\"\n        [options]=\"remotePathOptions\"\n        [hostObject]=\"hostObject\"\n        (hostEvents)=\"onHostEvents($event);\"\n        (load)=\"onBlockLoad()\">\n    </pep-remote-loader>\n\n    <mft-wc-wrapper *ngIf=\"webComponentWrapperOptions\" [options]=\"webComponentWrapperOptions\" [props]=\"{ hostObject: hostObject }\" [events]=\"{ hostEvents: onHostEventsCallback }\"></mft-wc-wrapper>\n\n</ng-template>"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"addon-block-loader.component.js","sourceRoot":"","sources":["../../../../projects/ngx-lib/remote-loader/addon-block-loader.component.ts","../../../../projects/ngx-lib/remote-loader/addon-block-loader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { WebComponentWrapperOptions } from '@angular-architects/module-federation-tools';\nimport { Component, OnInit, Input, Output, EventEmitter, TemplateRef, ViewChild, OnDestroy } from '@angular/core';\nimport { MatDialogRef } from '@angular/material/dialog';\nimport { PepBlockDataType, PepRemoteLoaderOptions } from './remote-loader.model';\nimport { PepRemoteLoaderService } from './remote-loader.service';\n\n@Component({\n    selector: 'pep-addon-block-loader',\n    templateUrl: './addon-block-loader.component.html',\n    styleUrls: ['./addon-block-loader.component.scss']\n})\nexport class PepAddonBlockLoaderComponent implements OnInit, OnDestroy {\n    @ViewChild('dialogTemplate', { static: true, read: TemplateRef }) dialogTemplate!: TemplateRef<any>;\n    \n    @Input() remoteEntry: string = '';\n\n    private _blockType: PepBlockDataType = 'AddonBlock';\n    @Input() \n    set blockType(value: PepBlockDataType) {\n        this._blockType = value;\n    }\n    get blockType(): PepBlockDataType {\n        return this._blockType;\n    }\n\n    private _name = '';\n    @Input() \n    set name(value: string) {\n        this._name = value;\n    }\n    get name(): string {\n        return this._name;\n    }\n\n    @Input() hostObject = null;\n    \n    private _dialogRef: MatDialogRef<any> = null;\n    @Input()\n    set dialogRef(value: MatDialogRef<any>) {\n        this._dialogRef = value;\n        this.inDialog = this._dialogRef != null;\n    }\n    get dialogRef(): MatDialogRef<any> {\n        return this._dialogRef;\n    }\n    \n    @Output() hostEvents: EventEmitter<any> = new EventEmitter<any>();\n    @Output() blockLoad: EventEmitter<void> = new EventEmitter<void>();\n    \n    protected inDialog = false;\n    protected remotePathOptions: PepRemoteLoaderOptions = null;\n    protected loadElement: boolean = false;\n\n    protected onHostEventsCallback: (event: CustomEvent) => void;\n\n    constructor(private remoteLoaderService: PepRemoteLoaderService) {\n        this.onHostEventsCallback = (event: CustomEvent) => {\n            this.onHostEvents(event.detail);\n        }\n    }\n    \n    ngOnInit() {\n        this.remoteLoaderService.getBlockRemoteLoaderOptions(this.name, this.blockType, this.remoteEntry).then((options: PepRemoteLoaderOptions) => {\n            this.loadElement = options.elementName?.length > 0;\n            this.remotePathOptions = options;\n        });\n    }\n\n    ngOnDestroy(): void {\n        if (this.dialogRef) {\n            this.dialogRef = null;\n        }\n\n        this.remotePathOptions = null;\n    }\n\n    onBlockLoad() {\n        this.blockLoad.emit();\n    }\n\n    onHostEvents(event: any) {\n        this.hostEvents.emit(event);\n    }\n\n    closeDialog(event) {\n        this.dialogRef?.close(event);\n    }\n}","<ng-container *ngIf=\"!inDialog\">\n    <ng-container *ngTemplateOutlet=\"remoteLoaderTemplate\"></ng-container>\n</ng-container>\n\n<ng-template #dialogTemplate let-data>\n    <pep-dialog [showClose]=\"data?.showClose\" [showHeader]=\"data?.showHeader\" [showFooter]=\"data?.showFooter\" [title]=\"data?.title\" (close)=\"closeDialog($event)\">\n        <ng-container pep-dialog-content>\n            <ng-container *ngTemplateOutlet=\"remoteLoaderTemplate\"></ng-container>\n        </ng-container>\n    </pep-dialog>\n</ng-template>\n\n<ng-template #remoteLoaderTemplate>\n    <pep-remote-loader *ngIf=\"remotePathOptions && !loadElement\"\n        [options]=\"remotePathOptions\"\n        [hostObject]=\"hostObject\"\n        (hostEvents)=\"onHostEvents($event);\"\n        (load)=\"onBlockLoad()\">\n    </pep-remote-loader>\n\n    <pep-remote-loader-element *ngIf=\"remotePathOptions && loadElement\" \n        [options]=\"remotePathOptions\"\n        [props]=\"{ hostObject: hostObject }\"\n        [events]=\"{ hostEvents: onHostEventsCallback }\"\n        (load)=\"onBlockLoad()\">\n    </pep-remote-loader-element>\n\n</ng-template>"]}
@@ -4,7 +4,8 @@
4
4
  export * from './addon-block-loader.component';
5
5
  export * from './addon-block-loader.service';
6
6
  export * from './remote-loader.component';
7
+ export * from './remote-loader-element.component';
7
8
  export * from './remote-loader.module';
8
9
  export * from './remote-loader.model';
9
10
  export * from './remote-loader.service';
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1saWIvcmVtb3RlLWxvYWRlci9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMseUJBQXlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHJlbW90ZS1sb2FkZXJcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9hZGRvbi1ibG9jay1sb2FkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vYWRkb24tYmxvY2stbG9hZGVyLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9yZW1vdGUtbG9hZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JlbW90ZS1sb2FkZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vcmVtb3RlLWxvYWRlci5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL3JlbW90ZS1sb2FkZXIuc2VydmljZSc7XG4iXX0=
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1saWIvcmVtb3RlLWxvYWRlci9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx5QkFBeUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgcmVtb3RlLWxvYWRlclxuICovXG5leHBvcnQgKiBmcm9tICcuL2FkZG9uLWJsb2NrLWxvYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9hZGRvbi1ibG9jay1sb2FkZXIuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL3JlbW90ZS1sb2FkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcmVtb3RlLWxvYWRlci1lbGVtZW50LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JlbW90ZS1sb2FkZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vcmVtb3RlLWxvYWRlci5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL3JlbW90ZS1sb2FkZXIuc2VydmljZSc7XG4iXX0=
@@ -0,0 +1,70 @@
1
+ import { Component, EventEmitter, Input, Optional, Output } from '@angular/core';
2
+ import { loadRemoteModule } from '@angular-architects/module-federation';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/router";
5
+ export class PepRemoteLoaderElementComponent {
6
+ constructor(renderer, el, route) {
7
+ this.renderer = renderer;
8
+ this.el = el;
9
+ this.route = route;
10
+ this.load = new EventEmitter();
11
+ this.element = null;
12
+ }
13
+ ngOnChanges() {
14
+ if (!this.element)
15
+ return;
16
+ this.populateProps();
17
+ }
18
+ populateProps() {
19
+ for (const prop in this.props) {
20
+ this.element[prop] = this.props[prop];
21
+ }
22
+ }
23
+ setupEvents() {
24
+ for (const event in this.events) {
25
+ this.element.addEventListener(event, this.events[event]);
26
+ }
27
+ }
28
+ async ngAfterContentInit() {
29
+ try {
30
+ const t0 = performance.now();
31
+ // When this implemented in ngAfterContentInit function this code is unnecessary.
32
+ // if (this.element) {
33
+ // this.renderer.removeChild(this.el.nativeElement, this.element);
34
+ // }
35
+ const options = this.options ?? this.route.snapshot.data;
36
+ await loadRemoteModule(options);
37
+ this.element = this.renderer.createElement(options.elementName);
38
+ this.populateProps();
39
+ this.setupEvents();
40
+ this.renderer.appendChild(this.el.nativeElement, this.element);
41
+ const t1 = performance.now();
42
+ console.log('remote module wc load performance: ' + (t1 - t0) / 1000);
43
+ this.load.emit();
44
+ }
45
+ catch (error) {
46
+ console.error(error);
47
+ }
48
+ }
49
+ }
50
+ PepRemoteLoaderElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderElementComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.ActivatedRoute, optional: true }], target: i0.ɵɵFactoryTarget.Component });
51
+ PepRemoteLoaderElementComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: PepRemoteLoaderElementComponent, selector: "pep-remote-loader-element", inputs: { options: "options", props: "props", events: "events" }, outputs: { load: "load" }, usesOnChanges: true, ngImport: i0, template: `
52
+ <!--<div #vc style="height: inherit;"></div>-->
53
+ `, isInline: true, styles: [":host{width:100%;height:inherit}:host::ng-deep>*{height:inherit}\n"] });
54
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderElementComponent, decorators: [{
55
+ type: Component,
56
+ args: [{ selector: 'pep-remote-loader-element', template: `
57
+ <!--<div #vc style="height: inherit;"></div>-->
58
+ `, styles: [":host{width:100%;height:inherit}:host::ng-deep>*{height:inherit}\n"] }]
59
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.ActivatedRoute, decorators: [{
60
+ type: Optional
61
+ }] }]; }, propDecorators: { options: [{
62
+ type: Input
63
+ }], props: [{
64
+ type: Input
65
+ }], events: [{
66
+ type: Input
67
+ }], load: [{
68
+ type: Output
69
+ }] } });
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVtb3RlLWxvYWRlci1lbGVtZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1saWIvcmVtb3RlLWxvYWRlci9yZW1vdGUtbG9hZGVyLWVsZW1lbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBb0IsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQWEsUUFBUSxFQUFFLE1BQU0sRUFBMEMsTUFBTSxlQUFlLENBQUM7QUFFbEssT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7OztBQWV6RSxNQUFNLE9BQU8sK0JBQStCO0lBU3hDLFlBQ1ksUUFBbUIsRUFDbkIsRUFBYSxFQUNELEtBQXFCO1FBRmpDLGFBQVEsR0FBUixRQUFRLENBQVc7UUFDbkIsT0FBRSxHQUFGLEVBQUUsQ0FBVztRQUNELFVBQUssR0FBTCxLQUFLLENBQWdCO1FBUG5DLFNBQUksR0FBdUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUV4RCxZQUFPLEdBQWdCLElBQUksQ0FBQztJQVE1QixDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTztZQUFFLE9BQU87UUFFMUIsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFTyxhQUFhO1FBQ2pCLEtBQUssTUFBTSxJQUFJLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUMzQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDekM7SUFDTCxDQUFDO0lBRU8sV0FBVztRQUNmLEtBQUssTUFBTSxLQUFLLElBQUksSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUM3QixJQUFJLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDNUQ7SUFDTCxDQUFDO0lBRUQsS0FBSyxDQUFDLGtCQUFrQjtRQUNwQixJQUFJO1lBQ0EsTUFBTSxFQUFFLEdBQUcsV0FBVyxDQUFDLEdBQUcsRUFBRSxDQUFDO1lBRTdCLGlGQUFpRjtZQUNqRixzQkFBc0I7WUFDdEIsc0VBQXNFO1lBQ3RFLElBQUk7WUFFSixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQThCLENBQUM7WUFFbkYsTUFBTSxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUVoQyxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQztZQUNoRSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDckIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBRW5CLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUUvRCxNQUFNLEVBQUUsR0FBRyxXQUFXLENBQUMsR0FBRyxFQUFFLENBQUM7WUFDN0IsT0FBTyxDQUFDLEdBQUcsQ0FBQyxxQ0FBcUMsR0FBRyxDQUFDLEVBQUUsR0FBQyxFQUFFLENBQUMsR0FBQyxJQUFJLENBQUMsQ0FBQztZQUVsRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1NBQ3BCO1FBQ0QsT0FBTSxLQUFLLEVBQUU7WUFDVCxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3hCO0lBQ0wsQ0FBQzs7NEhBOURRLCtCQUErQjtnSEFBL0IsK0JBQStCLG1MQVY5Qjs7S0FFVDsyRkFRUSwrQkFBK0I7a0JBWjNDLFNBQVM7K0JBQ0ksMkJBQTJCLFlBQzNCOztLQUVUOzswQkFvQkksUUFBUTs0Q0FYSixPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFFSSxJQUFJO3NCQUFiLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlckNvbnRlbnRJbml0LCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uQ2hhbmdlcywgT3B0aW9uYWwsIE91dHB1dCwgUmVuZGVyZXIyLCBWaWV3Q2hpbGQsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFjdGl2YXRlZFJvdXRlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IGxvYWRSZW1vdGVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci1hcmNoaXRlY3RzL21vZHVsZS1mZWRlcmF0aW9uJztcbmltcG9ydCB7IFBlcFJlbW90ZUxvYWRlck9wdGlvbnMgfSBmcm9tICcuL3JlbW90ZS1sb2FkZXIubW9kZWwnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3BlcC1yZW1vdGUtbG9hZGVyLWVsZW1lbnQnLFxuICAgIHRlbXBsYXRlOiBgXG4gICAgICAgIDwhLS08ZGl2ICN2YyBzdHlsZT1cImhlaWdodDogaW5oZXJpdDtcIj48L2Rpdj4tLT5cbiAgICBgLFxuICAgIHN0eWxlczogW2BcbiAgICAgICAgOmhvc3QgeyB3aWR0aDoxMDAlOyBoZWlnaHQ6IGluaGVyaXQgfVxuICAgICAgICA6aG9zdDo6bmctZGVlcCA+ICoge1xuICAgICAgICAgICAgaGVpZ2h0OiBpbmhlcml0O1xuICAgICAgICB9XG4gICAgYF0sXG59KVxuZXhwb3J0IGNsYXNzIFBlcFJlbW90ZUxvYWRlckVsZW1lbnRDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlckNvbnRlbnRJbml0LCBPbkNoYW5nZXMge1xuICAgIEBJbnB1dCgpIG9wdGlvbnM6IFBlcFJlbW90ZUxvYWRlck9wdGlvbnM7XG4gICAgQElucHV0KCkgcHJvcHM6IHsgW3Byb3A6IHN0cmluZ106IHVua25vd24gfTtcbiAgICBASW5wdXQoKSBldmVudHM6IHsgW2V2ZW50OiBzdHJpbmddOiAoZXZlbnQ6IEV2ZW50KSA9PiB2b2lkIH07XG5cbiAgICBAT3V0cHV0KCkgbG9hZDogRXZlbnRFbWl0dGVyPGFueT4gPSAgbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gICAgZWxlbWVudDogSFRNTEVsZW1lbnQgPSBudWxsO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgcmVuZGVyZXI6IFJlbmRlcmVyMixcbiAgICAgICAgcHJpdmF0ZSBlbDpFbGVtZW50UmVmLFxuICAgICAgICBAT3B0aW9uYWwoKSBwcml2YXRlIHJvdXRlOiBBY3RpdmF0ZWRSb3V0ZVxuICAgICkgeyBcblxuICAgIH1cblxuICAgIG5nT25DaGFuZ2VzKCk6IHZvaWQge1xuICAgICAgICBpZiAoIXRoaXMuZWxlbWVudCkgcmV0dXJuO1xuXG4gICAgICAgIHRoaXMucG9wdWxhdGVQcm9wcygpO1xuICAgIH1cblxuICAgIHByaXZhdGUgcG9wdWxhdGVQcm9wcygpIHtcbiAgICAgICAgZm9yIChjb25zdCBwcm9wIGluIHRoaXMucHJvcHMpIHtcbiAgICAgICAgICAgIHRoaXMuZWxlbWVudFtwcm9wXSA9IHRoaXMucHJvcHNbcHJvcF07XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwcml2YXRlIHNldHVwRXZlbnRzKCkge1xuICAgICAgICBmb3IgKGNvbnN0IGV2ZW50IGluIHRoaXMuZXZlbnRzKSB7XG4gICAgICAgICAgICB0aGlzLmVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcihldmVudCwgdGhpcy5ldmVudHNbZXZlbnRdKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGFzeW5jIG5nQWZ0ZXJDb250ZW50SW5pdCgpIHtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGNvbnN0IHQwID0gcGVyZm9ybWFuY2Uubm93KCk7XG4gICAgICAgICAgICBcbiAgICAgICAgICAgIC8vIFdoZW4gdGhpcyBpbXBsZW1lbnRlZCBpbiBuZ0FmdGVyQ29udGVudEluaXQgZnVuY3Rpb24gdGhpcyBjb2RlIGlzIHVubmVjZXNzYXJ5LlxuICAgICAgICAgICAgLy8gaWYgKHRoaXMuZWxlbWVudCkge1xuICAgICAgICAgICAgLy8gICAgIHRoaXMucmVuZGVyZXIucmVtb3ZlQ2hpbGQodGhpcy5lbC5uYXRpdmVFbGVtZW50LCB0aGlzLmVsZW1lbnQpO1xuICAgICAgICAgICAgLy8gfVxuXG4gICAgICAgICAgICBjb25zdCBvcHRpb25zID0gdGhpcy5vcHRpb25zID8/IHRoaXMucm91dGUuc25hcHNob3QuZGF0YSBhcyBQZXBSZW1vdGVMb2FkZXJPcHRpb25zO1xuXG4gICAgICAgICAgICBhd2FpdCBsb2FkUmVtb3RlTW9kdWxlKG9wdGlvbnMpO1xuXG4gICAgICAgICAgICB0aGlzLmVsZW1lbnQgPSB0aGlzLnJlbmRlcmVyLmNyZWF0ZUVsZW1lbnQob3B0aW9ucy5lbGVtZW50TmFtZSk7XG4gICAgICAgICAgICB0aGlzLnBvcHVsYXRlUHJvcHMoKTtcbiAgICAgICAgICAgIHRoaXMuc2V0dXBFdmVudHMoKTtcblxuICAgICAgICAgICAgdGhpcy5yZW5kZXJlci5hcHBlbmRDaGlsZCh0aGlzLmVsLm5hdGl2ZUVsZW1lbnQsIHRoaXMuZWxlbWVudCk7XG5cbiAgICAgICAgICAgIGNvbnN0IHQxID0gcGVyZm9ybWFuY2Uubm93KCk7XG4gICAgICAgICAgICBjb25zb2xlLmxvZygncmVtb3RlIG1vZHVsZSB3YyBsb2FkIHBlcmZvcm1hbmNlOiAnICsgKHQxLXQwKS8xMDAwKTtcblxuICAgICAgICAgICAgdGhpcy5sb2FkLmVtaXQoKTtcbiAgICAgICAgfVxuICAgICAgICBjYXRjaChlcnJvcikge1xuICAgICAgICAgICAgY29uc29sZS5lcnJvcihlcnJvcik7XG4gICAgICAgIH1cbiAgICB9XG59Il19
@@ -32,26 +32,21 @@ export class PepRemoteLoaderComponent {
32
32
  if (this.hostObject && this.compRef?.instance) {
33
33
  this.compRef.instance.hostObject = this.hostObject;
34
34
  // TODO: Check if this is needed?? if not remove this.
35
- if (this.compRef?.instance?.ngOnChanges) {
36
- this.compRef.instance.ngOnChanges(this.hostObject);
37
- }
35
+ // if (this.compRef?.instance?.ngOnChanges) {
36
+ // this.compRef.instance.ngOnChanges(this.hostObject);
37
+ // }
38
38
  }
39
39
  }
40
- async ngOnChanges(changes) {
40
+ ngOnChanges(changes) {
41
41
  // if (changes?.options?.currentValue) {
42
42
  // this.loadModule(changes?.options?.currentValue);
43
43
  // }
44
44
  }
45
45
  async loadModule() {
46
- const t0 = performance.now();
47
- // Check if only need update
48
- if (!this.options?.update) {
46
+ try {
47
+ const t0 = performance.now();
49
48
  this.viewContainer?.clear();
50
- if (this.options?.noModule) { // Load Component
51
- const componentType = await loadRemoteModule(this.options).then(m => m[this.options.componentName]);
52
- this.compRef = this.viewContainer.createComponent(componentType, { injector: this.injector });
53
- }
54
- else { // Load Module
49
+ if (this.options.exposedModule?.length > 0) { // Load module
55
50
  if (this.options?.addonId && (this.options.type === 'module' || this.options.type === 'script')) {
56
51
  const lastSlashIndex = this.options.remoteEntry?.lastIndexOf('/') || -1;
57
52
  if (lastSlashIndex > 0) {
@@ -65,17 +60,25 @@ export class PepRemoteLoaderComponent {
65
60
  const t1 = performance.now();
66
61
  console.log('remote module load performance: ' + (t1 - t0) / 1000);
67
62
  }
63
+ // Check if this is in use??? (comment out in Angular 14 version)
64
+ // else { // Load Component
65
+ // const componentType = await loadRemoteModule(this.options).then(m => m[this.options.componentName]);
66
+ // this.compRef = this.viewContainer.createComponent(componentType, { injector: this.injector });
67
+ // }
68
68
  this.load.emit();
69
+ if (this.compRef) {
70
+ this.setHostComponentIntoComponentRef();
71
+ this.compRef?.instance['hostEvents']?.subscribe(e => {
72
+ // switch(e.action){
73
+ // case 'addon-loaded':
74
+ // this.showSpinner = false;
75
+ // }
76
+ this.hostEvents.emit(e);
77
+ });
78
+ }
69
79
  }
70
- if (this.compRef) {
71
- this.setHostComponentIntoComponentRef();
72
- this.compRef?.instance['hostEvents']?.subscribe(e => {
73
- // switch(e.action){
74
- // case 'addon-loaded':
75
- // this.showSpinner = false;
76
- // }
77
- this.hostEvents.emit(e);
78
- });
80
+ catch (error) {
81
+ console.error(error);
79
82
  }
80
83
  }
81
84
  ngOnDestroy() {
@@ -109,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
109
112
  }], load: [{
110
113
  type: Output
111
114
  }] } });
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"remote-loader.component.js","sourceRoot":"","sources":["../../../../projects/ngx-lib/remote-loader/remote-loader.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { PepAddonService } from '@pepperi-addons/ngx-lib';\nimport { Component, Input, OnChanges, ViewChild, ViewContainerRef, Injector, EventEmitter, Output, ComponentRef, SimpleChanges, createNgModuleRef } from '@angular/core';\nimport { loadRemoteModule } from '@angular-architects/module-federation';\nimport { PepRemoteLoaderOptions } from './remote-loader.model';\n\n@Component({\n    selector: 'pep-remote-loader',\n    template: `\n        <!-- <mat-spinner *ngIf=\"showSpinner; else placeHolder\"></mat-spinner> -->\n        <ng-template #placeHolder></ng-template>\n    `\n})\nexport class PepRemoteLoaderComponent implements OnChanges {\n    @ViewChild('placeHolder', { read: ViewContainerRef, static: true }) viewContainer: ViewContainerRef;\n    \n    private _options: PepRemoteLoaderOptions = null;\n    @Input()\n    set options(value: PepRemoteLoaderOptions) {\n        this._options = value;\n        if (value) {\n            this.loadModule();\n        }\n    }\n    get options(): PepRemoteLoaderOptions {\n        return this._options;\n    }\n    \n    // This is the data passed by the API Design documentation.\n    private _hostObject: any = null;\n    @Input()\n    set hostObject(value: any) { \n        this._hostObject = value;\n        this.setHostComponentIntoComponentRef();\n    }\n    get hostObject(): any {\n        return this._hostObject;\n    }\n\n    @Output() hostEvents: EventEmitter<any> =  new EventEmitter();\n    @Output() load: EventEmitter<any> =  new EventEmitter();\n    // showSpinner = true;\n    \n    private compRef: ComponentRef<any>;\n\n    constructor(\n        private injector: Injector,\n        private pepAddonService: PepAddonService\n    ) { }\n\n    private setHostComponentIntoComponentRef() {\n        if (this.hostObject && this.compRef?.instance) {\n            this.compRef.instance.hostObject = this.hostObject;\n\n            // TODO: Check if this is needed?? if not remove this.\n            if (this.compRef?.instance?.ngOnChanges) {\n                this.compRef.instance.ngOnChanges(this.hostObject);\n            }\n        }\n    }\n\n    async ngOnChanges(changes: SimpleChanges) {\n        // if (changes?.options?.currentValue) {\n        //     this.loadModule(changes?.options?.currentValue);\n        // }\n    }\n\n    private async loadModule() {\n        const t0 = performance.now();\n        \n        // Check if only need update\n        if (!this.options?.update) {\n            this.viewContainer?.clear();\n            \n            if (this.options?.noModule) { // Load Component\n                const componentType = await loadRemoteModule(this.options).then(m => m[this.options.componentName]);\n                this.compRef = this.viewContainer.createComponent(componentType, { injector: this.injector });\n            } else { // Load Module\n                if (this.options?.addonId && (this.options.type === 'module' || this.options.type === 'script')) {\n                    const lastSlashIndex = this.options.remoteEntry?.lastIndexOf('/') || -1;\n                    \n                    if (lastSlashIndex > 0) {\n                        const publicPath = this.options.remoteEntry.substring(0, lastSlashIndex + 1);\n                        this.pepAddonService.setAddonStaticFolder(publicPath, this.options.addonId);\n                    }\n                }\n\n                const module =  await loadRemoteModule(this.options).then(m => m);\n                const moduleRef = createNgModuleRef(module[this.options.exposedModule.replace('./','')], this.injector);\n                this.compRef = this.viewContainer.createComponent(module[this.options.componentName], { injector: this.injector, ngModuleRef: moduleRef });\n\n                const t1 = performance.now();\n                console.log('remote module load performance: ' + (t1-t0)/1000);\n            }\n\n            this.load.emit();\n        }\n\n        if (this.compRef) {\n            this.setHostComponentIntoComponentRef();\n            \n            this.compRef?.instance['hostEvents']?.subscribe(e => {\n                // switch(e.action){\n                //     case 'addon-loaded':\n                //         this.showSpinner = false;\n                // }\n                this.hostEvents.emit(e)\n            });\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.compRef?.destroy();\n        this.viewContainer?.clear();\n    }\n}\n\n"]}
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"remote-loader.component.js","sourceRoot":"","sources":["../../../../projects/ngx-lib/remote-loader/remote-loader.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { PepAddonService } from '@pepperi-addons/ngx-lib';\nimport { Component, Input, OnChanges, ViewChild, ViewContainerRef, Injector, EventEmitter, Output, ComponentRef, SimpleChanges, createNgModuleRef } from '@angular/core';\nimport { loadRemoteModule } from '@angular-architects/module-federation';\nimport { PepRemoteLoaderOptions } from './remote-loader.model';\n\n@Component({\n    selector: 'pep-remote-loader',\n    template: `\n        <!-- <mat-spinner *ngIf=\"showSpinner; else placeHolder\"></mat-spinner> -->\n        <ng-template #placeHolder></ng-template>\n    `\n})\nexport class PepRemoteLoaderComponent implements OnChanges {\n    @ViewChild('placeHolder', { read: ViewContainerRef, static: true }) viewContainer: ViewContainerRef;\n    \n    private _options: PepRemoteLoaderOptions = null;\n    @Input()\n    set options(value: PepRemoteLoaderOptions) {\n        this._options = value;\n        if (value) {\n            this.loadModule();\n        }\n    }\n    get options(): PepRemoteLoaderOptions {\n        return this._options;\n    }\n    \n    // This is the data passed by the API Design documentation.\n    private _hostObject: any = null;\n    @Input()\n    set hostObject(value: any) { \n        this._hostObject = value;\n        this.setHostComponentIntoComponentRef();\n    }\n    get hostObject(): any {\n        return this._hostObject;\n    }\n\n    @Output() hostEvents: EventEmitter<any> =  new EventEmitter();\n    @Output() load: EventEmitter<any> =  new EventEmitter();\n    // showSpinner = true;\n    \n    private compRef: ComponentRef<any>;\n\n    constructor(\n        private injector: Injector,\n        private pepAddonService: PepAddonService\n    ) { }\n\n    private setHostComponentIntoComponentRef() {\n        if (this.hostObject && this.compRef?.instance) {\n            this.compRef.instance.hostObject = this.hostObject;\n\n            // TODO: Check if this is needed?? if not remove this.\n            // if (this.compRef?.instance?.ngOnChanges) {\n            //     this.compRef.instance.ngOnChanges(this.hostObject);\n            // }\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        // if (changes?.options?.currentValue) {\n        //     this.loadModule(changes?.options?.currentValue);\n        // }\n    }\n\n    private async loadModule() {\n        try {\n            const t0 = performance.now();\n        \n            this.viewContainer?.clear();\n            \n            if (this.options.exposedModule?.length > 0) { // Load module\n                if (this.options?.addonId && (this.options.type === 'module' || this.options.type === 'script')) {\n                    const lastSlashIndex = this.options.remoteEntry?.lastIndexOf('/') || -1;\n                    \n                    if (lastSlashIndex > 0) {\n                        const publicPath = this.options.remoteEntry.substring(0, lastSlashIndex + 1);\n                        this.pepAddonService.setAddonStaticFolder(publicPath, this.options.addonId);\n                    }\n                }\n\n                const module =  await loadRemoteModule(this.options).then(m => m);\n                const moduleRef = createNgModuleRef(module[this.options.exposedModule.replace('./','')], this.injector);\n                this.compRef = this.viewContainer.createComponent(module[this.options.componentName], { injector: this.injector, ngModuleRef: moduleRef });\n\n                const t1 = performance.now();\n                console.log('remote module load performance: ' + (t1-t0)/1000);\n            } \n            // Check if this is in use??? (comment out in Angular 14 version)\n            // else { // Load Component\n            //     const componentType = await loadRemoteModule(this.options).then(m => m[this.options.componentName]);\n            //     this.compRef = this.viewContainer.createComponent(componentType, { injector: this.injector });\n            // }\n\n            this.load.emit();\n\n            if (this.compRef) {\n                this.setHostComponentIntoComponentRef();\n                \n                this.compRef?.instance['hostEvents']?.subscribe(e => {\n                    // switch(e.action){\n                    //     case 'addon-loaded':\n                    //         this.showSpinner = false;\n                    // }\n                    this.hostEvents.emit(e)\n                });\n            }\n        } catch(error) {\n            console.error(error);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.compRef?.destroy();\n        this.viewContainer?.clear();\n    }\n}\n\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVtb3RlLWxvYWRlci5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1saWIvcmVtb3RlLWxvYWRlci9yZW1vdGUtbG9hZGVyLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMb2FkUmVtb3RlTW9kdWxlT3B0aW9ucyB9IGZyb20gXCJAYW5ndWxhci1hcmNoaXRlY3RzL21vZHVsZS1mZWRlcmF0aW9uXCI7XG5pbXBvcnQgeyBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE1hdERpYWxvZ0NvbmZpZyB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2dcIjtcbmltcG9ydCB7IFBlcERpYWxvZ1NpemVUeXBlIH0gZnJvbSBcIkBwZXBwZXJpLWFkZG9ucy9uZ3gtbGliL2RpYWxvZ1wiO1xuaW1wb3J0IHsgTmdDb21wb25lbnRSZWxhdGlvbiB9IGZyb20gXCJAcGVwcGVyaS1hZGRvbnMvcGFwaS1zZGtcIjtcblxudHlwZSBQZXBSZW1vdGVMb2FkZXJEYXRhID0ge1xuICAgIGFkZG9uSWQ/OiBzdHJpbmc7XG4gICAgZGlzcGxheU5hbWU/OiBzdHJpbmc7XG4gICAgY29tcG9uZW50TmFtZT86IHN0cmluZztcbiAgICAvLyBNYXliZSB0aG9zZSBwcm9wZXJ0aWVzIGFyZSBub3QgaW4gdXNlIHNvIHdlIG5lZWQgdG8gcmVtb3ZlIHRoZW0uXG4gICAgdXBkYXRlPzogYm9vbGVhbjtcbiAgICBub01vZHVsZT86IGJvb2xlYW47XG4gICAgLy8gRm9yIHdlYiBjb21wb25lbnRzXG4gICAgZWxlbWVudE5hbWU/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCB0eXBlIFBlcFJlbW90ZUxvYWRlck9wdGlvbnMgPSBQZXBSZW1vdGVMb2FkZXJEYXRhICYgTG9hZFJlbW90ZU1vZHVsZU9wdGlvbnM7XG5cbmV4cG9ydCB0eXBlIFBlcEJsb2NrRGF0YVR5cGUgPSAnU2V0dGluZ3NCbG9jaycgfCAnQWRkb25CbG9jaycgfCAnUGFnZUJsb2NrJztcblxuZXhwb3J0IGludGVyZmFjZSBJQmxvY2tMb2FkZXJEYXRhIHtcbiAgICByZWxhdGlvbjogTmdDb21wb25lbnRSZWxhdGlvbiwgXG4gICAgYWRkb25QdWJsaWNCYXNlVVJMOiBzdHJpbmdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQWRkb25CbG9ja0xvYWRlck9wdGlvbnMge1xuICAgIGNvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZjtcbiAgICBibG9ja1R5cGU/OiBQZXBCbG9ja0RhdGFUeXBlO1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBob3N0T2JqZWN0PzogYW55O1xuICAgIGhvc3RFdmVudHNDYWxsYmFjaz86IChldmVudDogYW55KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElBZGRvbkJsb2NrTG9hZGVyRGlhbG9nT3B0aW9ucyBleHRlbmRzIElBZGRvbkJsb2NrTG9hZGVyT3B0aW9ucyB7XG4gICAgZGF0YT86IElBZGRvbkJsb2NrTG9hZGVyRGlhbG9nRGF0YU9wdGlvbnM7XG4gICAgY29uZmlnPzogTWF0RGlhbG9nQ29uZmlnO1xuICAgIHNpemU/OiBQZXBEaWFsb2dTaXplVHlwZTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQWRkb25CbG9ja0xvYWRlckRpYWxvZ0RhdGFPcHRpb25zIHtcbiAgICB0aXRsZT86IHN0cmluZztcbiAgICBzaG93Q2xvc2U/OiBib29sZWFuO1xuICAgIHNob3dIZWFkZXI/OiBib29sZWFuO1xuICAgIHNob3dGb290ZXI/OiBib29sZWFuO1xufSJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVtb3RlLWxvYWRlci5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1saWIvcmVtb3RlLWxvYWRlci9yZW1vdGUtbG9hZGVyLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMb2FkUmVtb3RlTW9kdWxlT3B0aW9ucyB9IGZyb20gXCJAYW5ndWxhci1hcmNoaXRlY3RzL21vZHVsZS1mZWRlcmF0aW9uXCI7XG5pbXBvcnQgeyBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE1hdERpYWxvZ0NvbmZpZyB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2dcIjtcbmltcG9ydCB7IFBlcERpYWxvZ1NpemVUeXBlIH0gZnJvbSBcIkBwZXBwZXJpLWFkZG9ucy9uZ3gtbGliL2RpYWxvZ1wiO1xuaW1wb3J0IHsgTmdDb21wb25lbnRSZWxhdGlvbiB9IGZyb20gXCJAcGVwcGVyaS1hZGRvbnMvcGFwaS1zZGtcIjtcblxudHlwZSBQZXBSZW1vdGVMb2FkZXJEYXRhID0ge1xuICAgIGFkZG9uSWQ/OiBzdHJpbmc7XG4gICAgY29tcG9uZW50TmFtZT86IHN0cmluZztcbiAgICAvLyBGb3Igd2ViIGNvbXBvbmVudHNcbiAgICBlbGVtZW50TmFtZT86IHN0cmluZztcbiAgICBcbiAgICAvLyBkaXNwbGF5TmFtZT86IHN0cmluZztcbiAgICAvLyBNYXliZSB0aG9zZSBwcm9wZXJ0aWVzIGFyZSBub3QgaW4gdXNlIHNvIHdlIG5lZWQgdG8gcmVtb3ZlIHRoZW0uXG4gICAgLy8gdXBkYXRlPzogYm9vbGVhbjtcbiAgICAvLyBub01vZHVsZT86IGJvb2xlYW47XG59XG5cbmV4cG9ydCB0eXBlIFBlcFJlbW90ZUxvYWRlck9wdGlvbnMgPSBQZXBSZW1vdGVMb2FkZXJEYXRhICYgTG9hZFJlbW90ZU1vZHVsZU9wdGlvbnM7XG5cbmV4cG9ydCB0eXBlIFBlcEJsb2NrRGF0YVR5cGUgPSAnU2V0dGluZ3NCbG9jaycgfCAnQWRkb25CbG9jaycgfCAnUGFnZUJsb2NrJztcblxuZXhwb3J0IGludGVyZmFjZSBJQmxvY2tMb2FkZXJEYXRhIHtcbiAgICByZWxhdGlvbjogTmdDb21wb25lbnRSZWxhdGlvbiwgXG4gICAgYWRkb25QdWJsaWNCYXNlVVJMOiBzdHJpbmdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQWRkb25CbG9ja0xvYWRlck9wdGlvbnMge1xuICAgIGNvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZjtcbiAgICBibG9ja1R5cGU/OiBQZXBCbG9ja0RhdGFUeXBlO1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBob3N0T2JqZWN0PzogYW55O1xuICAgIGhvc3RFdmVudHNDYWxsYmFjaz86IChldmVudDogYW55KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElBZGRvbkJsb2NrTG9hZGVyRGlhbG9nT3B0aW9ucyBleHRlbmRzIElBZGRvbkJsb2NrTG9hZGVyT3B0aW9ucyB7XG4gICAgZGF0YT86IElBZGRvbkJsb2NrTG9hZGVyRGlhbG9nRGF0YU9wdGlvbnM7XG4gICAgY29uZmlnPzogTWF0RGlhbG9nQ29uZmlnO1xuICAgIHNpemU/OiBQZXBEaWFsb2dTaXplVHlwZTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQWRkb25CbG9ja0xvYWRlckRpYWxvZ0RhdGFPcHRpb25zIHtcbiAgICB0aXRsZT86IHN0cmluZztcbiAgICBzaG93Q2xvc2U/OiBib29sZWFuO1xuICAgIHNob3dIZWFkZXI/OiBib29sZWFuO1xuICAgIHNob3dGb290ZXI/OiBib29sZWFuO1xufSJdfQ==
@@ -9,12 +9,14 @@ import { PepAddonBlockLoaderComponent } from './addon-block-loader.component';
9
9
  import { PepAddonBlockLoaderService } from './addon-block-loader.service';
10
10
  import { PepRemoteLoaderComponent } from './remote-loader.component';
11
11
  import { PepRemoteLoaderService } from './remote-loader.service';
12
+ import { PepRemoteLoaderElementComponent } from './remote-loader-element.component';
12
13
  import * as i0 from "@angular/core";
13
14
  export class PepRemoteLoaderModule {
14
15
  }
15
16
  PepRemoteLoaderModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
16
17
  PepRemoteLoaderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderModule, declarations: [PepAddonBlockLoaderComponent,
17
- PepRemoteLoaderComponent], imports: [CommonModule,
18
+ PepRemoteLoaderComponent,
19
+ PepRemoteLoaderElementComponent], imports: [CommonModule,
18
20
  HttpClientModule,
19
21
  ModuleFederationToolsModule,
20
22
  // Material modules,
@@ -22,7 +24,8 @@ PepRemoteLoaderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", v
22
24
  // ngx-lib modules
23
25
  PepNgxLibModule,
24
26
  PepDialogModule], exports: [PepAddonBlockLoaderComponent,
25
- PepRemoteLoaderComponent] });
27
+ PepRemoteLoaderComponent,
28
+ PepRemoteLoaderElementComponent] });
26
29
  PepRemoteLoaderModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepRemoteLoaderModule, providers: [
27
30
  PepAddonBlockLoaderService,
28
31
  PepRemoteLoaderService
@@ -40,6 +43,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
40
43
  declarations: [
41
44
  PepAddonBlockLoaderComponent,
42
45
  PepRemoteLoaderComponent,
46
+ PepRemoteLoaderElementComponent,
43
47
  ],
44
48
  imports: [
45
49
  CommonModule,
@@ -54,6 +58,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
54
58
  exports: [
55
59
  PepAddonBlockLoaderComponent,
56
60
  PepRemoteLoaderComponent,
61
+ PepRemoteLoaderElementComponent
57
62
  ],
58
63
  providers: [
59
64
  PepAddonBlockLoaderService,
@@ -61,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
61
66
  ]
62
67
  }]
63
68
  }] });
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVtb3RlLWxvYWRlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbGliL3JlbW90ZS1sb2FkZXIvcmVtb3RlLWxvYWRlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRTNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakUsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFFMUYsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDOUUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFFMUUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDckUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBMEJqRSxNQUFNLE9BQU8scUJBQXFCOztrSEFBckIscUJBQXFCO21IQUFyQixxQkFBcUIsaUJBdEIxQiw0QkFBNEI7UUFDNUIsd0JBQXdCLGFBR3hCLFlBQVk7UUFDWixnQkFBZ0I7UUFDaEIsMkJBQTJCO1FBQzNCLG9CQUFvQjtRQUNwQixlQUFlO1FBQ2Ysa0JBQWtCO1FBQ2xCLGVBQWU7UUFDZixlQUFlLGFBR2YsNEJBQTRCO1FBQzVCLHdCQUF3QjttSEFPbkIscUJBQXFCLGFBTG5CO1FBQ1AsMEJBQTBCO1FBQzFCLHNCQUFzQjtLQUN6QixZQWhCRyxZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLDJCQUEyQjtRQUMzQixvQkFBb0I7UUFDcEIsZUFBZTtRQUNmLGtCQUFrQjtRQUNsQixlQUFlO1FBQ2YsZUFBZTsyRkFXVixxQkFBcUI7a0JBeEJqQyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRTt3QkFDViw0QkFBNEI7d0JBQzVCLHdCQUF3QjtxQkFDM0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osZ0JBQWdCO3dCQUNoQiwyQkFBMkI7d0JBQzNCLG9CQUFvQjt3QkFDcEIsZUFBZTt3QkFDZixrQkFBa0I7d0JBQ2xCLGVBQWU7d0JBQ2YsZUFBZTtxQkFDbEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLDRCQUE0Qjt3QkFDNUIsd0JBQXdCO3FCQUMzQjtvQkFDRCxTQUFTLEVBQUU7d0JBQ1AsMEJBQTBCO3dCQUMxQixzQkFBc0I7cUJBQ3pCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuXG5pbXBvcnQgeyBQZXBOZ3hMaWJNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYic7XG5pbXBvcnQgeyBQZXBEaWFsb2dNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9kaWFsb2cnO1xuaW1wb3J0IHsgTW9kdWxlRmVkZXJhdGlvblRvb2xzTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXItYXJjaGl0ZWN0cy9tb2R1bGUtZmVkZXJhdGlvbi10b29scyc7XG5cbmltcG9ydCB7IFBlcEFkZG9uQmxvY2tMb2FkZXJDb21wb25lbnQgfSBmcm9tICcuL2FkZG9uLWJsb2NrLWxvYWRlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgUGVwQWRkb25CbG9ja0xvYWRlclNlcnZpY2UgfSBmcm9tICcuL2FkZG9uLWJsb2NrLWxvYWRlci5zZXJ2aWNlJztcblxuaW1wb3J0IHsgUGVwUmVtb3RlTG9hZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9yZW1vdGUtbG9hZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQZXBSZW1vdGVMb2FkZXJTZXJ2aWNlIH0gZnJvbSAnLi9yZW1vdGUtbG9hZGVyLnNlcnZpY2UnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW1xuICAgICAgICBQZXBBZGRvbkJsb2NrTG9hZGVyQ29tcG9uZW50LFxuICAgICAgICBQZXBSZW1vdGVMb2FkZXJDb21wb25lbnQsXG4gICAgXSxcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgSHR0cENsaWVudE1vZHVsZSxcbiAgICAgICAgTW9kdWxlRmVkZXJhdGlvblRvb2xzTW9kdWxlLFxuICAgICAgICAvLyBNYXRlcmlhbCBtb2R1bGVzLFxuICAgICAgICBNYXREaWFsb2dNb2R1bGUsXG4gICAgICAgIC8vIG5neC1saWIgbW9kdWxlc1xuICAgICAgICBQZXBOZ3hMaWJNb2R1bGUsXG4gICAgICAgIFBlcERpYWxvZ01vZHVsZSxcbiAgICBdLFxuICAgIGV4cG9ydHM6IFtcbiAgICAgICAgUGVwQWRkb25CbG9ja0xvYWRlckNvbXBvbmVudCxcbiAgICAgICAgUGVwUmVtb3RlTG9hZGVyQ29tcG9uZW50LFxuICAgIF0sXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIFBlcEFkZG9uQmxvY2tMb2FkZXJTZXJ2aWNlLFxuICAgICAgICBQZXBSZW1vdGVMb2FkZXJTZXJ2aWNlXG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBQZXBSZW1vdGVMb2FkZXJNb2R1bGUge1xuXG5cbn1cbiJdfQ==
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVtb3RlLWxvYWRlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbGliL3JlbW90ZS1sb2FkZXIvcmVtb3RlLWxvYWRlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRTNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakUsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFFMUYsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDOUUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFFMUUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDckUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDakUsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBNEJwRixNQUFNLE9BQU8scUJBQXFCOztrSEFBckIscUJBQXFCO21IQUFyQixxQkFBcUIsaUJBeEIxQiw0QkFBNEI7UUFDNUIsd0JBQXdCO1FBQ3hCLCtCQUErQixhQUcvQixZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLDJCQUEyQjtRQUMzQixvQkFBb0I7UUFDcEIsZUFBZTtRQUNmLGtCQUFrQjtRQUNsQixlQUFlO1FBQ2YsZUFBZSxhQUdmLDRCQUE0QjtRQUM1Qix3QkFBd0I7UUFDeEIsK0JBQStCO21IQU8xQixxQkFBcUIsYUFMbkI7UUFDUCwwQkFBMEI7UUFDMUIsc0JBQXNCO0tBQ3pCLFlBakJHLFlBQVk7UUFDWixnQkFBZ0I7UUFDaEIsMkJBQTJCO1FBQzNCLG9CQUFvQjtRQUNwQixlQUFlO1FBQ2Ysa0JBQWtCO1FBQ2xCLGVBQWU7UUFDZixlQUFlOzJGQVlWLHFCQUFxQjtrQkExQmpDLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFO3dCQUNWLDRCQUE0Qjt3QkFDNUIsd0JBQXdCO3dCQUN4QiwrQkFBK0I7cUJBQ2xDO29CQUNELE9BQU8sRUFBRTt3QkFDTCxZQUFZO3dCQUNaLGdCQUFnQjt3QkFDaEIsMkJBQTJCO3dCQUMzQixvQkFBb0I7d0JBQ3BCLGVBQWU7d0JBQ2Ysa0JBQWtCO3dCQUNsQixlQUFlO3dCQUNmLGVBQWU7cUJBQ2xCO29CQUNELE9BQU8sRUFBRTt3QkFDTCw0QkFBNEI7d0JBQzVCLHdCQUF3Qjt3QkFDeEIsK0JBQStCO3FCQUNsQztvQkFDRCxTQUFTLEVBQUU7d0JBQ1AsMEJBQTBCO3dCQUMxQixzQkFBc0I7cUJBQ3pCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuXG5pbXBvcnQgeyBQZXBOZ3hMaWJNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYic7XG5pbXBvcnQgeyBQZXBEaWFsb2dNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9kaWFsb2cnO1xuaW1wb3J0IHsgTW9kdWxlRmVkZXJhdGlvblRvb2xzTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXItYXJjaGl0ZWN0cy9tb2R1bGUtZmVkZXJhdGlvbi10b29scyc7XG5cbmltcG9ydCB7IFBlcEFkZG9uQmxvY2tMb2FkZXJDb21wb25lbnQgfSBmcm9tICcuL2FkZG9uLWJsb2NrLWxvYWRlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgUGVwQWRkb25CbG9ja0xvYWRlclNlcnZpY2UgfSBmcm9tICcuL2FkZG9uLWJsb2NrLWxvYWRlci5zZXJ2aWNlJztcblxuaW1wb3J0IHsgUGVwUmVtb3RlTG9hZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9yZW1vdGUtbG9hZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQZXBSZW1vdGVMb2FkZXJTZXJ2aWNlIH0gZnJvbSAnLi9yZW1vdGUtbG9hZGVyLnNlcnZpY2UnO1xuaW1wb3J0IHsgUGVwUmVtb3RlTG9hZGVyRWxlbWVudENvbXBvbmVudCB9IGZyb20gJy4vcmVtb3RlLWxvYWRlci1lbGVtZW50LmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIFBlcEFkZG9uQmxvY2tMb2FkZXJDb21wb25lbnQsXG4gICAgICAgIFBlcFJlbW90ZUxvYWRlckNvbXBvbmVudCxcbiAgICAgICAgUGVwUmVtb3RlTG9hZGVyRWxlbWVudENvbXBvbmVudCxcbiAgICBdLFxuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBIdHRwQ2xpZW50TW9kdWxlLFxuICAgICAgICBNb2R1bGVGZWRlcmF0aW9uVG9vbHNNb2R1bGUsXG4gICAgICAgIC8vIE1hdGVyaWFsIG1vZHVsZXMsXG4gICAgICAgIE1hdERpYWxvZ01vZHVsZSxcbiAgICAgICAgLy8gbmd4LWxpYiBtb2R1bGVzXG4gICAgICAgIFBlcE5neExpYk1vZHVsZSxcbiAgICAgICAgUGVwRGlhbG9nTW9kdWxlLFxuICAgIF0sXG4gICAgZXhwb3J0czogW1xuICAgICAgICBQZXBBZGRvbkJsb2NrTG9hZGVyQ29tcG9uZW50LFxuICAgICAgICBQZXBSZW1vdGVMb2FkZXJDb21wb25lbnQsXG4gICAgICAgIFBlcFJlbW90ZUxvYWRlckVsZW1lbnRDb21wb25lbnRcbiAgICBdLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICBQZXBBZGRvbkJsb2NrTG9hZGVyU2VydmljZSxcbiAgICAgICAgUGVwUmVtb3RlTG9hZGVyU2VydmljZVxuICAgIF1cbn0pXG5leHBvcnQgY2xhc3MgUGVwUmVtb3RlTG9hZGVyTW9kdWxlIHtcblxuXG59XG4iXX0=