@dotglitch/ngx-common 1.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -0
- package/components/dynamic-html/dynamic-html.component.d.ts +15 -0
- package/components/dynamic-html/dynamic-html.module.d.ts +10 -0
- package/components/dynamic-html/dynamic-html.service.d.ts +18 -0
- package/components/dynamic-html/types.d.ts +12 -0
- package/components/lazy-loader/lazy-loader.component.d.ts +146 -0
- package/components/lazy-loader/lazy-loader.module.d.ts +10 -0
- package/components/lazy-loader/lazy-loader.service.d.ts +71 -0
- package/components/lazy-loader/types.d.ts +142 -0
- package/components/menu/menu.component.d.ts +52 -0
- package/components/tooltip/tooltip.component.d.ts +35 -0
- package/directives/menu.directive.d.ts +27 -0
- package/directives/tooltip.directive.d.ts +26 -0
- package/directives/utils.d.ts +8 -0
- package/esm2020/components/dynamic-html/dynamic-html.component.mjs +43 -0
- package/esm2020/components/dynamic-html/dynamic-html.module.mjs +27 -0
- package/esm2020/components/dynamic-html/dynamic-html.service.mjs +66 -0
- package/esm2020/components/dynamic-html/types.mjs +7 -0
- package/esm2020/components/lazy-loader/lazy-loader.component.mjs +360 -0
- package/esm2020/components/lazy-loader/lazy-loader.module.mjs +29 -0
- package/esm2020/components/lazy-loader/lazy-loader.service.mjs +215 -0
- package/esm2020/components/lazy-loader/types.mjs +26 -0
- package/esm2020/components/menu/menu.component.mjs +316 -0
- package/esm2020/components/tooltip/tooltip.component.mjs +135 -0
- package/esm2020/directives/menu.directive.mjs +112 -0
- package/esm2020/directives/tooltip.directive.mjs +92 -0
- package/esm2020/directives/utils.mjs +120 -0
- package/esm2020/dotglitch-ngx-common.mjs +5 -0
- package/esm2020/pipes/html-bypass.pipe.mjs +27 -0
- package/esm2020/pipes/resource-bypass.pipe.mjs +27 -0
- package/esm2020/pipes/script-bypass.pipe.mjs +27 -0
- package/esm2020/pipes/style-bypass.pipe.mjs +27 -0
- package/esm2020/pipes/url-bypass.pipe.mjs +27 -0
- package/esm2020/public-api.mjs +39 -0
- package/esm2020/services/dependency.service.mjs +55 -0
- package/esm2020/services/dialog.service.mjs +66 -0
- package/esm2020/services/fetch.service.mjs +71 -0
- package/esm2020/services/keyboard.service.mjs +128 -0
- package/esm2020/types/menu.mjs +2 -0
- package/esm2020/types/popup.mjs +2 -0
- package/esm2020/utils/index.mjs +39 -0
- package/fesm2015/dotglitch-ngx-common.mjs +1997 -0
- package/fesm2015/dotglitch-ngx-common.mjs.map +1 -0
- package/fesm2020/dotglitch-ngx-common.mjs +1977 -0
- package/fesm2020/dotglitch-ngx-common.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/package.json +60 -0
- package/pipes/html-bypass.pipe.d.ts +16 -0
- package/pipes/resource-bypass.pipe.d.ts +16 -0
- package/pipes/script-bypass.pipe.d.ts +16 -0
- package/pipes/style-bypass.pipe.d.ts +16 -0
- package/pipes/url-bypass.pipe.d.ts +16 -0
- package/public-api.d.ts +34 -0
- package/services/dependency.service.d.ts +19 -0
- package/services/dialog.service.d.ts +41 -0
- package/services/fetch.service.d.ts +28 -0
- package/services/keyboard.service.d.ts +79 -0
- package/types/menu.d.ts +90 -0
- package/types/popup.d.ts +27 -0
- package/utils/index.d.ts +19 -0
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { DynamicHTMLComponent } from './dynamic-html.component';
|
|
3
|
+
import { NGX_DYNAMIC_CONFIG } from './types';
|
|
4
|
+
import { DynamicHTMLRenderer } from './dynamic-html.service';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class NgxDynamicHTMLModule {
|
|
7
|
+
static forRoot(config) {
|
|
8
|
+
return {
|
|
9
|
+
ngModule: NgxDynamicHTMLModule,
|
|
10
|
+
providers: [
|
|
11
|
+
DynamicHTMLRenderer,
|
|
12
|
+
{ provide: NGX_DYNAMIC_CONFIG, useValue: config }
|
|
13
|
+
],
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
NgxDynamicHTMLModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NgxDynamicHTMLModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
18
|
+
NgxDynamicHTMLModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: NgxDynamicHTMLModule, imports: [DynamicHTMLComponent], exports: [DynamicHTMLComponent] });
|
|
19
|
+
NgxDynamicHTMLModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NgxDynamicHTMLModule, imports: [DynamicHTMLComponent] });
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NgxDynamicHTMLModule, decorators: [{
|
|
21
|
+
type: NgModule,
|
|
22
|
+
args: [{
|
|
23
|
+
imports: [DynamicHTMLComponent],
|
|
24
|
+
exports: [DynamicHTMLComponent],
|
|
25
|
+
}]
|
|
26
|
+
}] });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1odG1sLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbW1vbi9zcmMvY29tcG9uZW50cy9keW5hbWljLWh0bWwvZHluYW1pYy1odG1sLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUF1QixNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQXNCLGtCQUFrQixFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQU03RCxNQUFNLE9BQU8sb0JBQW9CO0lBQ3RCLE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBMEI7UUFDNUMsT0FBTztZQUNILFFBQVEsRUFBRSxvQkFBb0I7WUFDOUIsU0FBUyxFQUFFO2dCQUNQLG1CQUFtQjtnQkFDbkIsRUFBRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRTthQUNwRDtTQUNKLENBQUM7SUFDTixDQUFDOztpSEFUUSxvQkFBb0I7a0hBQXBCLG9CQUFvQixZQUhuQixvQkFBb0IsYUFDcEIsb0JBQW9CO2tIQUVyQixvQkFBb0IsWUFIbkIsb0JBQW9COzJGQUdyQixvQkFBb0I7a0JBSmhDLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFLENBQUMsb0JBQW9CLENBQUM7b0JBQy9CLE9BQU8sRUFBRSxDQUFDLG9CQUFvQixDQUFDO2lCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlLCBNb2R1bGVXaXRoUHJvdmlkZXJzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEeW5hbWljSFRNTENvbXBvbmVudCB9IGZyb20gJy4vZHluYW1pYy1odG1sLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEeW5hbWljSFRNTE9wdGlvbnMsIE5HWF9EWU5BTUlDX0NPTkZJRyB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgRHluYW1pY0hUTUxSZW5kZXJlciB9IGZyb20gJy4vZHluYW1pYy1odG1sLnNlcnZpY2UnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtEeW5hbWljSFRNTENvbXBvbmVudF0sXG4gICAgZXhwb3J0czogW0R5bmFtaWNIVE1MQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTmd4RHluYW1pY0hUTUxNb2R1bGUge1xuICAgIHB1YmxpYyBzdGF0aWMgZm9yUm9vdChjb25maWc6IER5bmFtaWNIVE1MT3B0aW9ucyk6IE1vZHVsZVdpdGhQcm92aWRlcnM8Tmd4RHluYW1pY0hUTUxNb2R1bGU+IHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIG5nTW9kdWxlOiBOZ3hEeW5hbWljSFRNTE1vZHVsZSxcbiAgICAgICAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAgICAgICAgIER5bmFtaWNIVE1MUmVuZGVyZXIsXG4gICAgICAgICAgICAgICAgeyBwcm92aWRlOiBOR1hfRFlOQU1JQ19DT05GSUcsIHVzZVZhbHVlOiBjb25maWcgfVxuICAgICAgICAgICAgXSxcbiAgICAgICAgfTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { Injectable, Inject } from '@angular/core';
|
|
2
|
+
import { NGX_DYNAMIC_CONFIG } from './types';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "./types";
|
|
5
|
+
function isBrowserPlatform() {
|
|
6
|
+
return window != null && window.document != null;
|
|
7
|
+
}
|
|
8
|
+
export class DynamicHTMLRenderer {
|
|
9
|
+
constructor(config, cfr, injector) {
|
|
10
|
+
this.config = config;
|
|
11
|
+
this.cfr = cfr;
|
|
12
|
+
this.injector = injector;
|
|
13
|
+
this.componentFactories = new Map();
|
|
14
|
+
this.componentRefs = new Map();
|
|
15
|
+
this.config.components.forEach(({ selector, component }) => {
|
|
16
|
+
let cf;
|
|
17
|
+
cf = this.cfr.resolveComponentFactory(component);
|
|
18
|
+
this.componentFactories.set(selector, cf);
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
renderInnerHTML(elementRef, html) {
|
|
22
|
+
if (!isBrowserPlatform()) {
|
|
23
|
+
return {
|
|
24
|
+
check: () => { },
|
|
25
|
+
destroy: () => { },
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
elementRef.nativeElement.innerHTML = html;
|
|
29
|
+
const componentRefs = [];
|
|
30
|
+
this.config.components.forEach(({ selector }) => {
|
|
31
|
+
const elements = elementRef.nativeElement.querySelectorAll(selector);
|
|
32
|
+
Array.prototype.forEach.call(elements, (el) => {
|
|
33
|
+
const content = el.innerHTML;
|
|
34
|
+
const cmpRef = this.componentFactories.get(selector).create(this.injector, [], el);
|
|
35
|
+
el.removeAttribute('ng-version');
|
|
36
|
+
if (cmpRef.instance.dynamicOnMount) {
|
|
37
|
+
const attrsMap = new Map();
|
|
38
|
+
if (el.hasAttributes()) {
|
|
39
|
+
Array.prototype.forEach.call(el.attributes, (attr) => {
|
|
40
|
+
attrsMap.set(attr.name, attr.value);
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
cmpRef.instance.dynamicOnMount(attrsMap, content, el);
|
|
44
|
+
}
|
|
45
|
+
componentRefs.push(cmpRef);
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
this.componentRefs.set(elementRef, componentRefs);
|
|
49
|
+
return {
|
|
50
|
+
check: () => componentRefs.forEach(ref => ref.changeDetectorRef.detectChanges()),
|
|
51
|
+
destroy: () => {
|
|
52
|
+
componentRefs.forEach(ref => ref.destroy());
|
|
53
|
+
this.componentRefs.delete(elementRef);
|
|
54
|
+
},
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
DynamicHTMLRenderer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DynamicHTMLRenderer, deps: [{ token: NGX_DYNAMIC_CONFIG }, { token: i0.ComponentFactoryResolver }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
59
|
+
DynamicHTMLRenderer.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DynamicHTMLRenderer });
|
|
60
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DynamicHTMLRenderer, decorators: [{
|
|
61
|
+
type: Injectable
|
|
62
|
+
}], ctorParameters: function () { return [{ type: i1.DynamicHTMLOptions, decorators: [{
|
|
63
|
+
type: Inject,
|
|
64
|
+
args: [NGX_DYNAMIC_CONFIG]
|
|
65
|
+
}] }, { type: i0.ComponentFactoryResolver }, { type: i0.Injector }]; } });
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1odG1sLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21tb24vc3JjL2NvbXBvbmVudHMvZHluYW1pYy1odG1sL2R5bmFtaWMtaHRtbC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQWtGLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuSSxPQUFPLEVBQXNCLGtCQUFrQixFQUFXLE1BQU0sU0FBUyxDQUFDOzs7QUFPMUUsU0FBUyxpQkFBaUI7SUFDdEIsT0FBTyxNQUFNLElBQUksSUFBSSxJQUFJLE1BQU0sQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDO0FBQ3JELENBQUM7QUFHRCxNQUFNLE9BQU8sbUJBQW1CO0lBTTVCLFlBQWdELE1BQTBCLEVBQVUsR0FBNkIsRUFBVSxRQUFrQjtRQUE3RixXQUFNLEdBQU4sTUFBTSxDQUFvQjtRQUFVLFFBQUcsR0FBSCxHQUFHLENBQTBCO1FBQVUsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUpySSx1QkFBa0IsR0FBRyxJQUFJLEdBQUcsRUFBaUMsQ0FBQztRQUU5RCxrQkFBYSxHQUFHLElBQUksR0FBRyxFQUFpQyxDQUFDO1FBRzdELElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxFQUFFLEVBQUU7WUFDdkQsSUFBSSxFQUF5QixDQUFDO1lBQzlCLEVBQUUsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLHVCQUF1QixDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ2pELElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQzlDLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELGVBQWUsQ0FBQyxVQUFzQixFQUFFLElBQVk7UUFDaEQsSUFBSSxDQUFDLGlCQUFpQixFQUFFLEVBQUU7WUFDdEIsT0FBTztnQkFDSCxLQUFLLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQztnQkFDaEIsT0FBTyxFQUFFLEdBQUcsRUFBRSxHQUFHLENBQUM7YUFDckIsQ0FBQztTQUNMO1FBQ0QsVUFBVSxDQUFDLGFBQWEsQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1FBRTFDLE1BQU0sYUFBYSxHQUE2QixFQUFFLENBQUM7UUFDbkQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFO1lBQzVDLE1BQU0sUUFBUSxHQUFJLFVBQVUsQ0FBQyxhQUF5QixDQUFDLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ2xGLEtBQUssQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxFQUFXLEVBQUUsRUFBRTtnQkFDbkQsTUFBTSxPQUFPLEdBQUcsRUFBRSxDQUFDLFNBQVMsQ0FBQztnQkFDN0IsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7Z0JBRW5GLEVBQUUsQ0FBQyxlQUFlLENBQUMsWUFBWSxDQUFDLENBQUM7Z0JBRWpDLElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQyxjQUFjLEVBQUU7b0JBQ2hDLE1BQU0sUUFBUSxHQUFHLElBQUksR0FBRyxFQUFrQixDQUFDO29CQUMzQyxJQUFJLEVBQUUsQ0FBQyxhQUFhLEVBQUUsRUFBRTt3QkFDcEIsS0FBSyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxVQUFVLEVBQUUsQ0FBQyxJQUFVLEVBQUUsRUFBRTs0QkFDdkQsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQzt3QkFDeEMsQ0FBQyxDQUFDLENBQUM7cUJBQ047b0JBQ0EsTUFBTSxDQUFDLFFBQW9CLENBQUMsY0FBYyxDQUFDLFFBQVEsRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUM7aUJBQ3RFO2dCQUVELGFBQWEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDL0IsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLFVBQVUsRUFBRSxhQUFhLENBQUMsQ0FBQztRQUVsRCxPQUFPO1lBQ0gsS0FBSyxFQUFFLEdBQUcsRUFBRSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDaEYsT0FBTyxFQUFFLEdBQUcsRUFBRTtnQkFDVixhQUFhLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7Z0JBQzVDLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQzFDLENBQUM7U0FDSixDQUFDO0lBQ04sQ0FBQzs7Z0hBdERRLG1CQUFtQixrQkFNUixrQkFBa0I7b0hBTjdCLG1CQUFtQjsyRkFBbkIsbUJBQW1CO2tCQUQvQixVQUFVOzswQkFPTSxNQUFNOzJCQUFDLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIEluamVjdG9yLCBFbGVtZW50UmVmLCBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIENvbXBvbmVudEZhY3RvcnksIENvbXBvbmVudFJlZiwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEeW5hbWljSFRNTE9wdGlvbnMsIE5HWF9EWU5BTUlDX0NPTkZJRywgT25Nb3VudCB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIER5bmFtaWNIVE1MUmVmIHtcbiAgICBjaGVjazogKCkgPT4gdm9pZDtcbiAgICBkZXN0cm95OiAoKSA9PiB2b2lkO1xufVxuXG5mdW5jdGlvbiBpc0Jyb3dzZXJQbGF0Zm9ybSgpIHtcbiAgICByZXR1cm4gd2luZG93ICE9IG51bGwgJiYgd2luZG93LmRvY3VtZW50ICE9IG51bGw7XG59XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBEeW5hbWljSFRNTFJlbmRlcmVyIHtcblxuICAgIHByaXZhdGUgY29tcG9uZW50RmFjdG9yaWVzID0gbmV3IE1hcDxzdHJpbmcsIENvbXBvbmVudEZhY3Rvcnk8YW55Pj4oKTtcblxuICAgIHByaXZhdGUgY29tcG9uZW50UmVmcyA9IG5ldyBNYXA8YW55LCBBcnJheTxDb21wb25lbnRSZWY8YW55Pj4+KCk7XG5cbiAgICBjb25zdHJ1Y3RvcihASW5qZWN0KE5HWF9EWU5BTUlDX0NPTkZJRykgcHJpdmF0ZSBjb25maWc6IER5bmFtaWNIVE1MT3B0aW9ucywgcHJpdmF0ZSBjZnI6IENvbXBvbmVudEZhY3RvcnlSZXNvbHZlciwgcHJpdmF0ZSBpbmplY3RvcjogSW5qZWN0b3IpIHtcbiAgICAgICAgdGhpcy5jb25maWcuY29tcG9uZW50cy5mb3JFYWNoKCh7IHNlbGVjdG9yLCBjb21wb25lbnQgfSkgPT4ge1xuICAgICAgICAgICAgbGV0IGNmOiBDb21wb25lbnRGYWN0b3J5PGFueT47XG4gICAgICAgICAgICBjZiA9IHRoaXMuY2ZyLnJlc29sdmVDb21wb25lbnRGYWN0b3J5KGNvbXBvbmVudCk7XG4gICAgICAgICAgICB0aGlzLmNvbXBvbmVudEZhY3Rvcmllcy5zZXQoc2VsZWN0b3IsIGNmKTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcmVuZGVySW5uZXJIVE1MKGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsIGh0bWw6IHN0cmluZyk6IER5bmFtaWNIVE1MUmVmIHtcbiAgICAgICAgaWYgKCFpc0Jyb3dzZXJQbGF0Zm9ybSgpKSB7XG4gICAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgICAgIGNoZWNrOiAoKSA9PiB7IH0sXG4gICAgICAgICAgICAgICAgZGVzdHJveTogKCkgPT4geyB9LFxuICAgICAgICAgICAgfTtcbiAgICAgICAgfVxuICAgICAgICBlbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuaW5uZXJIVE1MID0gaHRtbDtcblxuICAgICAgICBjb25zdCBjb21wb25lbnRSZWZzOiBBcnJheTxDb21wb25lbnRSZWY8YW55Pj4gPSBbXTtcbiAgICAgICAgdGhpcy5jb25maWcuY29tcG9uZW50cy5mb3JFYWNoKCh7IHNlbGVjdG9yIH0pID0+IHtcbiAgICAgICAgICAgIGNvbnN0IGVsZW1lbnRzID0gKGVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCBhcyBFbGVtZW50KS5xdWVyeVNlbGVjdG9yQWxsKHNlbGVjdG9yKTtcbiAgICAgICAgICAgIEFycmF5LnByb3RvdHlwZS5mb3JFYWNoLmNhbGwoZWxlbWVudHMsIChlbDogRWxlbWVudCkgPT4ge1xuICAgICAgICAgICAgICAgIGNvbnN0IGNvbnRlbnQgPSBlbC5pbm5lckhUTUw7XG4gICAgICAgICAgICAgICAgY29uc3QgY21wUmVmID0gdGhpcy5jb21wb25lbnRGYWN0b3JpZXMuZ2V0KHNlbGVjdG9yKS5jcmVhdGUodGhpcy5pbmplY3RvciwgW10sIGVsKTtcblxuICAgICAgICAgICAgICAgIGVsLnJlbW92ZUF0dHJpYnV0ZSgnbmctdmVyc2lvbicpO1xuXG4gICAgICAgICAgICAgICAgaWYgKGNtcFJlZi5pbnN0YW5jZS5keW5hbWljT25Nb3VudCkge1xuICAgICAgICAgICAgICAgICAgICBjb25zdCBhdHRyc01hcCA9IG5ldyBNYXA8c3RyaW5nLCBzdHJpbmc+KCk7XG4gICAgICAgICAgICAgICAgICAgIGlmIChlbC5oYXNBdHRyaWJ1dGVzKCkpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIEFycmF5LnByb3RvdHlwZS5mb3JFYWNoLmNhbGwoZWwuYXR0cmlidXRlcywgKGF0dHI6IEF0dHIpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBhdHRyc01hcC5zZXQoYXR0ci5uYW1lLCBhdHRyLnZhbHVlKTtcbiAgICAgICAgICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIChjbXBSZWYuaW5zdGFuY2UgYXMgT25Nb3VudCkuZHluYW1pY09uTW91bnQoYXR0cnNNYXAsIGNvbnRlbnQsIGVsKTtcbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICBjb21wb25lbnRSZWZzLnB1c2goY21wUmVmKTtcbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9KTtcbiAgICAgICAgdGhpcy5jb21wb25lbnRSZWZzLnNldChlbGVtZW50UmVmLCBjb21wb25lbnRSZWZzKTtcblxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgY2hlY2s6ICgpID0+IGNvbXBvbmVudFJlZnMuZm9yRWFjaChyZWYgPT4gcmVmLmNoYW5nZURldGVjdG9yUmVmLmRldGVjdENoYW5nZXMoKSksXG4gICAgICAgICAgICBkZXN0cm95OiAoKSA9PiB7XG4gICAgICAgICAgICAgICAgY29tcG9uZW50UmVmcy5mb3JFYWNoKHJlZiA9PiByZWYuZGVzdHJveSgpKTtcbiAgICAgICAgICAgICAgICB0aGlzLmNvbXBvbmVudFJlZnMuZGVsZXRlKGVsZW1lbnRSZWYpO1xuICAgICAgICAgICAgfSxcbiAgICAgICAgfTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
export class OnMount {
|
|
3
|
+
}
|
|
4
|
+
export class DynamicHTMLOptions {
|
|
5
|
+
}
|
|
6
|
+
export const NGX_DYNAMIC_CONFIG = new InjectionToken('config');
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21tb24vc3JjL2NvbXBvbmVudHMvZHluYW1pYy1odG1sL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQVEsTUFBTSxlQUFlLENBQUM7QUFFckQsTUFBTSxPQUFnQixPQUFPO0NBRTVCO0FBTUQsTUFBTSxPQUFPLGtCQUFrQjtDQUU5QjtBQUVELE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksY0FBYyxDQUFxQixRQUFRLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuLCBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBPbk1vdW50IHtcbiAgICBhYnN0cmFjdCBkeW5hbWljT25Nb3VudChhdHRycz86IE1hcDxzdHJpbmcsIHN0cmluZz4sIGNvbnRlbnQ/OiBzdHJpbmcsIGVsZW1lbnQ/OiBFbGVtZW50KTogdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb21wb25lbnRXaXRoU2VsZWN0b3Ige1xuICAgIHNlbGVjdG9yOiBzdHJpbmc7XG4gICAgY29tcG9uZW50OiBUeXBlPGFueT47XG59XG5leHBvcnQgY2xhc3MgRHluYW1pY0hUTUxPcHRpb25zIHtcbiAgICBjb21wb25lbnRzOiBBcnJheTxDb21wb25lbnRXaXRoU2VsZWN0b3I+O1xufVxuXG5leHBvcnQgY29uc3QgTkdYX0RZTkFNSUNfQ09ORklHID0gbmV3IEluamVjdGlvblRva2VuPER5bmFtaWNIVE1MT3B0aW9ucz4oJ2NvbmZpZycpO1xuXG4iXX0=
|
|
@@ -0,0 +1,360 @@
|
|
|
1
|
+
import { Input, ViewContainerRef, isDevMode, EventEmitter, Optional, ViewChild, Component, Inject, Output } from '@angular/core';
|
|
2
|
+
import { NgComponentOutlet, NgIf, NgTemplateOutlet } from '@angular/common';
|
|
3
|
+
import { MAT_DIALOG_DATA, } from '@angular/material/dialog';
|
|
4
|
+
import { debounceTime } from 'rxjs';
|
|
5
|
+
import { LazyLoaderService } from './lazy-loader.service';
|
|
6
|
+
import { stringToSlug } from '../../utils';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "./lazy-loader.service";
|
|
9
|
+
import * as i2 from "@angular/cdk/dialog";
|
|
10
|
+
export class LazyLoaderComponent {
|
|
11
|
+
/**
|
|
12
|
+
* The id of the component that will be lazy loaded
|
|
13
|
+
*/
|
|
14
|
+
set id(data) {
|
|
15
|
+
const id = stringToSlug(data);
|
|
16
|
+
// Check if there is a change to the loaded component's id
|
|
17
|
+
// if it's updated, we destroy and rehydrate the entire container
|
|
18
|
+
if (this.initialized && this._id != id) {
|
|
19
|
+
this._id = id;
|
|
20
|
+
this.ngAfterViewInit();
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
this._id = id;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
;
|
|
27
|
+
set group(data) {
|
|
28
|
+
const group = stringToSlug(data);
|
|
29
|
+
if (typeof group != "string" || !group)
|
|
30
|
+
return;
|
|
31
|
+
// If the group was updated, retry to bootstrap something into the container.
|
|
32
|
+
if (this.initialized && this._group != group) {
|
|
33
|
+
this._group = group;
|
|
34
|
+
this.ngAfterViewInit();
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
this._group = group;
|
|
38
|
+
}
|
|
39
|
+
get group() { return this._group; }
|
|
40
|
+
/**
|
|
41
|
+
* A map of inputs to bind to the child.
|
|
42
|
+
* Supports change detection. (May fail on deep JSON changes)
|
|
43
|
+
*
|
|
44
|
+
* ```html
|
|
45
|
+
* <lazy-loader component="MyLazyComponent"
|
|
46
|
+
* [inputs]="{
|
|
47
|
+
* prop1: true,
|
|
48
|
+
* prop2: false,
|
|
49
|
+
* complex: {
|
|
50
|
+
* a: true,
|
|
51
|
+
* b: 0
|
|
52
|
+
* }
|
|
53
|
+
* }"
|
|
54
|
+
* >
|
|
55
|
+
* </lazy-loader>
|
|
56
|
+
* ```
|
|
57
|
+
*/
|
|
58
|
+
set inputs(data) {
|
|
59
|
+
if (data == undefined)
|
|
60
|
+
return;
|
|
61
|
+
let previous = this._inputs;
|
|
62
|
+
this._inputs = data;
|
|
63
|
+
if (data == undefined)
|
|
64
|
+
console.trace(data);
|
|
65
|
+
if (this.targetComponentFactory) {
|
|
66
|
+
const { inputs } = this.targetComponentFactory.ɵcmp;
|
|
67
|
+
const currentKeys = Object.keys(inputs);
|
|
68
|
+
const oldKeys = Object.keys(previous).filter(key => currentKeys.includes(key));
|
|
69
|
+
const newKeys = Object.keys(data).filter(key => currentKeys.includes(key));
|
|
70
|
+
const removed = oldKeys.filter(key => !newKeys.includes(key));
|
|
71
|
+
// ? perhaps set to null or undefined instead
|
|
72
|
+
removed.forEach(k => this.targetComponentInstance[k] = null);
|
|
73
|
+
this.bindInputs();
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* A map of outputs to bind from the child.
|
|
78
|
+
* Should support change detection.
|
|
79
|
+
* ```html
|
|
80
|
+
* <lazy-loader component="MyLazyComponent"
|
|
81
|
+
* [outputs]="{
|
|
82
|
+
* prop3: onOutputFire
|
|
83
|
+
* }"
|
|
84
|
+
* >
|
|
85
|
+
* </lazy-loader>
|
|
86
|
+
* ```
|
|
87
|
+
*/
|
|
88
|
+
set outputs(data) {
|
|
89
|
+
let previous = this._outputs;
|
|
90
|
+
this._outputs = data;
|
|
91
|
+
if (this.targetComponentFactory) {
|
|
92
|
+
const { inputs } = this.targetComponentFactory.ɵcmp;
|
|
93
|
+
const currentKeys = Object.keys(inputs);
|
|
94
|
+
const removed = Object.keys(previous).filter(key => !currentKeys.includes(key));
|
|
95
|
+
removed.forEach(k => {
|
|
96
|
+
// Unsubscribe from observable
|
|
97
|
+
this.outputSubscriptions[k]?.unsubscribe();
|
|
98
|
+
delete this.targetComponentInstance[k];
|
|
99
|
+
});
|
|
100
|
+
this.bindOutputs();
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
constructor(service, viewContainerRef, dialog, dialogArguments) {
|
|
104
|
+
this.service = service;
|
|
105
|
+
this.viewContainerRef = viewContainerRef;
|
|
106
|
+
this.dialog = dialog;
|
|
107
|
+
this.dialogArguments = dialogArguments;
|
|
108
|
+
this._group = "default";
|
|
109
|
+
this.outputSubscriptions = {};
|
|
110
|
+
/**
|
|
111
|
+
* Emits errors encountered when loading components
|
|
112
|
+
*/
|
|
113
|
+
this.componentLoadError = new EventEmitter();
|
|
114
|
+
/**
|
|
115
|
+
* Emits when the component is fully constructed
|
|
116
|
+
* and had it's inputs and outputs bound
|
|
117
|
+
* > before `OnInit`
|
|
118
|
+
*
|
|
119
|
+
* Returns the active class instance of the lazy-loaded component
|
|
120
|
+
*/
|
|
121
|
+
this.componentLoaded = new EventEmitter();
|
|
122
|
+
// Force 500ms delay before revealing the spinner
|
|
123
|
+
this.loaderEmitter = new EventEmitter();
|
|
124
|
+
this.clearLoader$ = this.loaderEmitter.pipe(debounceTime(300));
|
|
125
|
+
this.showLoader = true; // whether we render the DOM for the spinner
|
|
126
|
+
this.isClearingLoader = false; // should the spinner start fading out
|
|
127
|
+
this.initialized = false;
|
|
128
|
+
this.config = LazyLoaderService.config;
|
|
129
|
+
this.err = LazyLoaderService.config.logger.err;
|
|
130
|
+
this.warn = LazyLoaderService.config.logger.warn;
|
|
131
|
+
this.log = LazyLoaderService.config.logger.log;
|
|
132
|
+
// First, check for dialog arguments
|
|
133
|
+
if (this.dialogArguments) {
|
|
134
|
+
this.inputs = this.dialogArguments.inputs || this.dialogArguments.data;
|
|
135
|
+
this.outputs = this.dialogArguments.outputs;
|
|
136
|
+
this.id = this.dialogArguments.id;
|
|
137
|
+
this.group = this.dialogArguments.group;
|
|
138
|
+
}
|
|
139
|
+
this.loaderSub = this.clearLoader$.subscribe(() => {
|
|
140
|
+
this.showLoader = false;
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
async ngAfterViewInit() {
|
|
144
|
+
this.ngOnDestroy(false);
|
|
145
|
+
this.isClearingLoader = false;
|
|
146
|
+
this.showLoader = true;
|
|
147
|
+
this.initialized = true;
|
|
148
|
+
if (!this._id) {
|
|
149
|
+
this.warn("No component was specified!");
|
|
150
|
+
return this.loadDefault();
|
|
151
|
+
}
|
|
152
|
+
try {
|
|
153
|
+
const _entry = this.service.resolveRegistrationEntry(this._id, this._group);
|
|
154
|
+
if (!_entry || !_entry.entry) {
|
|
155
|
+
this.err(`Failed to find Component '${this._id}' in group '${this._group}' in registry!`);
|
|
156
|
+
return this.loadDefault();
|
|
157
|
+
}
|
|
158
|
+
const { entry, matchGroups } = _entry;
|
|
159
|
+
this._matchGroups = matchGroups;
|
|
160
|
+
// Download the "module" (the standalone component)
|
|
161
|
+
const bundle = this.targetModule = await entry.load();
|
|
162
|
+
// Check if there is some corruption on the bundle.
|
|
163
|
+
if (!bundle || typeof bundle != 'object' || bundle['__esModule'] !== true || bundle.toString() != "[object Module]") {
|
|
164
|
+
this.err(`Failed to load component/module for '${this._id}'! Parsed resource is invalid.`);
|
|
165
|
+
return this.loadError();
|
|
166
|
+
}
|
|
167
|
+
const modules = Object.keys(bundle)
|
|
168
|
+
.map(k => {
|
|
169
|
+
const entry = bundle[k];
|
|
170
|
+
// Strictly check for exported modules or standalone components
|
|
171
|
+
if (typeof entry == "function" && typeof entry["ɵfac"] == "function")
|
|
172
|
+
return entry;
|
|
173
|
+
return null;
|
|
174
|
+
})
|
|
175
|
+
.filter(e => e != null)
|
|
176
|
+
.filter(entry => {
|
|
177
|
+
entry['_isModule'] = !!entry['ɵmod']; // module
|
|
178
|
+
entry['_isComponent'] = !!entry['ɵcmp']; // component
|
|
179
|
+
return (entry['_isModule'] || entry['_isComponent']);
|
|
180
|
+
});
|
|
181
|
+
if (modules.length == 0) {
|
|
182
|
+
this.err(`Component/Module loaded for '${this._id}' has no exported components or modules!`);
|
|
183
|
+
return this.loadError();
|
|
184
|
+
}
|
|
185
|
+
const component = this.targetComponentFactory = this.service.resolveComponent(this._id, "default", modules);
|
|
186
|
+
if (!component) {
|
|
187
|
+
this.err(`Component '${this._id}' is invalid or corrupted!`);
|
|
188
|
+
return this.loadError();
|
|
189
|
+
}
|
|
190
|
+
// Bootstrap the component into the container
|
|
191
|
+
const componentRef = this.targetComponentContainerRef = this.targetContainer.createComponent(component);
|
|
192
|
+
this.targetRef = this.targetContainer.insert(this.targetComponentContainerRef.hostView);
|
|
193
|
+
const instance = this.targetComponentInstance = componentRef['instance'];
|
|
194
|
+
this.bindInputs();
|
|
195
|
+
this.bindOutputs();
|
|
196
|
+
this.componentLoaded.next(instance);
|
|
197
|
+
this.instance = instance;
|
|
198
|
+
// Look for an observable called isLoading$ that will make us show/hide
|
|
199
|
+
// the same distractor that is used on basic loading
|
|
200
|
+
const isLoading$ = instance['ngxShowDistractor$'];
|
|
201
|
+
if (isLoading$ && typeof isLoading$.subscribe == "function") {
|
|
202
|
+
this.distractorSubscription = isLoading$.subscribe(loading => {
|
|
203
|
+
if (!loading) {
|
|
204
|
+
this.isClearingLoader = true;
|
|
205
|
+
this.loaderEmitter.emit();
|
|
206
|
+
}
|
|
207
|
+
else {
|
|
208
|
+
this.showLoader = true;
|
|
209
|
+
this.isClearingLoader = false;
|
|
210
|
+
}
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
else {
|
|
214
|
+
this.isClearingLoader = true;
|
|
215
|
+
}
|
|
216
|
+
const name = Object.keys(bundle)[0];
|
|
217
|
+
this.log(`Loaded '${name}'`);
|
|
218
|
+
this.loaderEmitter.emit();
|
|
219
|
+
return componentRef;
|
|
220
|
+
}
|
|
221
|
+
catch (ex) {
|
|
222
|
+
if (isDevMode()) {
|
|
223
|
+
console.warn("Component " + this._id + " threw an error on mount!");
|
|
224
|
+
console.warn("This will cause you to see a 404 panel.");
|
|
225
|
+
console.error(ex);
|
|
226
|
+
}
|
|
227
|
+
// Network errors throw a toast and return an error component
|
|
228
|
+
if (ex && !isDevMode()) {
|
|
229
|
+
console.error("Uncaught error when loading component");
|
|
230
|
+
throw ex;
|
|
231
|
+
}
|
|
232
|
+
return this.loadDefault();
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
ngOnDestroy(clearAll = true) {
|
|
236
|
+
// unsubscribe from all subscriptions
|
|
237
|
+
Object.entries(this.outputSubscriptions).forEach(([key, sub]) => {
|
|
238
|
+
sub.unsubscribe();
|
|
239
|
+
});
|
|
240
|
+
this.outputSubscriptions = {};
|
|
241
|
+
// Clear all things
|
|
242
|
+
if (clearAll) {
|
|
243
|
+
this.loaderSub?.unsubscribe();
|
|
244
|
+
}
|
|
245
|
+
this.distractorSubscription?.unsubscribe();
|
|
246
|
+
// Clear target container
|
|
247
|
+
this.targetRef?.destroy();
|
|
248
|
+
this.targetComponentContainerRef?.destroy();
|
|
249
|
+
this.targetContainer?.clear();
|
|
250
|
+
// Wipe the rest of the state clean
|
|
251
|
+
this.targetRef = null;
|
|
252
|
+
this.targetComponentContainerRef = null;
|
|
253
|
+
}
|
|
254
|
+
/**
|
|
255
|
+
* Bind the input values to the child component.
|
|
256
|
+
*/
|
|
257
|
+
bindInputs() {
|
|
258
|
+
if (!this._inputs || !this.targetComponentInstance)
|
|
259
|
+
return;
|
|
260
|
+
// Merge match groups
|
|
261
|
+
if (typeof this._matchGroups == "object") {
|
|
262
|
+
Object.entries(this._matchGroups).forEach(([key, val]) => {
|
|
263
|
+
if (typeof this._inputs[key] == 'undefined')
|
|
264
|
+
this._inputs[key] = val;
|
|
265
|
+
});
|
|
266
|
+
}
|
|
267
|
+
// forward-bind inputs
|
|
268
|
+
const { inputs } = this.targetComponentFactory.ɵcmp;
|
|
269
|
+
// Returns a list of entries that need to be set
|
|
270
|
+
// This makes it so that unnecessary setters are not invoked.
|
|
271
|
+
const updated = Object.entries(inputs).filter(([parentKey, childKey]) => {
|
|
272
|
+
return this.targetComponentInstance[childKey] != this._inputs[parentKey];
|
|
273
|
+
});
|
|
274
|
+
updated.forEach(([parentKey, childKey]) => {
|
|
275
|
+
if (this._inputs.hasOwnProperty(parentKey))
|
|
276
|
+
this.targetComponentInstance[childKey] = this._inputs[parentKey];
|
|
277
|
+
});
|
|
278
|
+
}
|
|
279
|
+
/**
|
|
280
|
+
* Bind the output handlers to the loaded child component
|
|
281
|
+
*/
|
|
282
|
+
bindOutputs() {
|
|
283
|
+
if (!this._outputs || !this.targetComponentInstance)
|
|
284
|
+
return;
|
|
285
|
+
const { outputs } = this.targetComponentFactory.ɵcmp;
|
|
286
|
+
// Get a list of unregistered outputs
|
|
287
|
+
const newOutputs = Object.entries(outputs).filter(([parentKey, childKey]) => {
|
|
288
|
+
return !this.outputSubscriptions[parentKey];
|
|
289
|
+
});
|
|
290
|
+
// Reverse bind via subscription
|
|
291
|
+
newOutputs.forEach(([parentKey, childKey]) => {
|
|
292
|
+
if (this._outputs.hasOwnProperty(parentKey)) {
|
|
293
|
+
const target = this.targetComponentInstance[childKey];
|
|
294
|
+
const outputs = this._outputs;
|
|
295
|
+
// Angular folks, stop making this so difficult.
|
|
296
|
+
const ctx = this.viewContainerRef['_hostLView'][8];
|
|
297
|
+
const sub = target.subscribe(outputs[parentKey].bind(ctx)); // Subscription
|
|
298
|
+
this.outputSubscriptions[parentKey] = sub;
|
|
299
|
+
}
|
|
300
|
+
});
|
|
301
|
+
}
|
|
302
|
+
/**
|
|
303
|
+
* Load the "Default" component (404) screen normally.
|
|
304
|
+
* This is shown when the component id isn't in the
|
|
305
|
+
* registry or otherwise doesn't match
|
|
306
|
+
*
|
|
307
|
+
* This
|
|
308
|
+
*/
|
|
309
|
+
loadDefault() {
|
|
310
|
+
if (this.config.notFoundComponent)
|
|
311
|
+
this.targetContainer.createComponent(this.config.notFoundComponent);
|
|
312
|
+
this.showLoader = false;
|
|
313
|
+
}
|
|
314
|
+
/**
|
|
315
|
+
* Load the "Error" component.
|
|
316
|
+
* This is shown when we are able to resolve the component
|
|
317
|
+
* in the registry, but have some issue boostrapping the
|
|
318
|
+
* component into the viewContainer
|
|
319
|
+
*/
|
|
320
|
+
loadError() {
|
|
321
|
+
if (this.config.errorComponent)
|
|
322
|
+
this.targetContainer.createComponent(this.config.errorComponent);
|
|
323
|
+
this.showLoader = false;
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
LazyLoaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: LazyLoaderComponent, deps: [{ token: i1.LazyLoaderService }, { token: i0.ViewContainerRef, optional: true }, { token: i2.DialogRef, optional: true }, { token: MAT_DIALOG_DATA, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
327
|
+
LazyLoaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: LazyLoaderComponent, isStandalone: true, selector: "ngx-lazy-loader", inputs: { id: ["component", "id"], group: "group", inputs: "inputs", outputs: "outputs" }, outputs: { componentLoadError: "componentLoadError", componentLoaded: "componentLoaded" }, viewQueries: [{ propertyName: "targetContainer", first: true, predicate: ["content"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<ng-container #content></ng-container>\n\n<div class=\"ngx-lazy-loader-distractor\" [class.destroying]=\"isClearingLoader\">\n <ng-container *ngIf=\"config.loaderDistractorComponent\" [ngComponentOutlet]=\"config.loaderDistractorComponent\"></ng-container>\n <ng-container *ngIf=\"config.loaderDistractorTemplate\" [ngTemplateOutlet]=\"config.loaderDistractorTemplate\" [ngTemplateOutletContext]=\"{ '$implicit': inputs }\"></ng-container>\n</div>\n", styles: [":host{display:contents;contain:content;z-index:1;position:relative}.ngx-lazy-loader-distractor{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;background-color:var(--background-color, #212121);opacity:1;transition:opacity .3s ease;z-index:999999}.ngx-lazy-loader-distractor.destroying{opacity:0;pointer-events:none}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] });
|
|
328
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: LazyLoaderComponent, decorators: [{
|
|
329
|
+
type: Component,
|
|
330
|
+
args: [{ selector: 'ngx-lazy-loader', imports: [NgIf, NgComponentOutlet, NgTemplateOutlet], standalone: true, template: "<ng-container #content></ng-container>\n\n<div class=\"ngx-lazy-loader-distractor\" [class.destroying]=\"isClearingLoader\">\n <ng-container *ngIf=\"config.loaderDistractorComponent\" [ngComponentOutlet]=\"config.loaderDistractorComponent\"></ng-container>\n <ng-container *ngIf=\"config.loaderDistractorTemplate\" [ngTemplateOutlet]=\"config.loaderDistractorTemplate\" [ngTemplateOutletContext]=\"{ '$implicit': inputs }\"></ng-container>\n</div>\n", styles: [":host{display:contents;contain:content;z-index:1;position:relative}.ngx-lazy-loader-distractor{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;background-color:var(--background-color, #212121);opacity:1;transition:opacity .3s ease;z-index:999999}.ngx-lazy-loader-distractor.destroying{opacity:0;pointer-events:none}\n"] }]
|
|
331
|
+
}], ctorParameters: function () { return [{ type: i1.LazyLoaderService }, { type: i0.ViewContainerRef, decorators: [{
|
|
332
|
+
type: Optional
|
|
333
|
+
}] }, { type: i2.DialogRef, decorators: [{
|
|
334
|
+
type: Optional
|
|
335
|
+
}] }, { type: undefined, decorators: [{
|
|
336
|
+
type: Optional
|
|
337
|
+
}, {
|
|
338
|
+
type: Inject,
|
|
339
|
+
args: [MAT_DIALOG_DATA]
|
|
340
|
+
}] }]; }, propDecorators: { targetContainer: [{
|
|
341
|
+
type: ViewChild,
|
|
342
|
+
args: ["content", { read: ViewContainerRef }]
|
|
343
|
+
}], id: [{
|
|
344
|
+
type: Input,
|
|
345
|
+
args: ["component"]
|
|
346
|
+
}], group: [{
|
|
347
|
+
type: Input,
|
|
348
|
+
args: ["group"]
|
|
349
|
+
}], inputs: [{
|
|
350
|
+
type: Input,
|
|
351
|
+
args: ["inputs"]
|
|
352
|
+
}], outputs: [{
|
|
353
|
+
type: Input,
|
|
354
|
+
args: ["outputs"]
|
|
355
|
+
}], componentLoadError: [{
|
|
356
|
+
type: Output
|
|
357
|
+
}], componentLoaded: [{
|
|
358
|
+
type: Output
|
|
359
|
+
}] } });
|
|
360
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-loader.component.js","sourceRoot":"","sources":["../../../../../packages/common/src/components/lazy-loader/lazy-loader.component.ts","../../../../../packages/common/src/components/lazy-loader/lazy-loader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Input, ViewContainerRef, isDevMode, ComponentRef, EventEmitter, Optional, ViewChild, Component, Inject, Output, NgModule, AfterViewInit, OnInit } from '@angular/core';\nimport { NgComponentOutlet, NgIf, NgTemplateOutlet } from '@angular/common';\nimport { MAT_DIALOG_DATA, } from '@angular/material/dialog';\nimport { DialogRef } from '@angular/cdk/dialog';\nimport { BehaviorSubject, debounceTime, Subscription } from 'rxjs';\nimport { LazyLoaderService } from './lazy-loader.service';\nimport { stringToSlug } from '../../utils';\nimport { CompiledBundle, NgxLazyLoaderConfig } from './types';\n\n\n@Component({\n    selector: 'ngx-lazy-loader',\n    templateUrl: './lazy-loader.component.html',\n    styleUrls: [ './lazy-loader.component.scss' ],\n    imports: [ NgIf, NgComponentOutlet, NgTemplateOutlet ],\n    standalone: true\n})\nexport class LazyLoaderComponent implements AfterViewInit {\n    @ViewChild(\"content\", { read: ViewContainerRef }) targetContainer: ViewContainerRef;\n\n    /**\n     * ! Here be dragons.\n     * Only the bravest of Adventurers can survive the battles below,\n     * and they must be trained and ready for the gruelling journey ahead.\n     * Many a soul has tried to best these Dragons, yet only one has\n     * succeeded since our founding.\n     *\n     * TL;DR -- Don't mess with this unless you know what you're doing.\n     *     This is central to a ton of moving parts -- breaking it will\n     *     cause more collateral damage than you may realize.\n     */\n\n    private _id: string;\n    /**\n     * The id of the component that will be lazy loaded\n     */\n    @Input(\"component\") set id(data: string) {\n        const id = stringToSlug(data);\n\n        // Check if there is a change to the loaded component's id\n        // if it's updated, we destroy and rehydrate the entire container\n        if (this.initialized && this._id != id) {\n            this._id = id;\n            this.ngAfterViewInit();\n        }\n        else {\n            this._id = id;\n        }\n    };\n\n\n    private _group = \"default\";\n    @Input(\"group\") set group(data: string) {\n        const group = stringToSlug(data);\n\n        if (typeof group != \"string\" || !group) return;\n\n        // If the group was updated, retry to bootstrap something into the container.\n        if (this.initialized && this._group != group) {\n            this._group = group;\n\n            this.ngAfterViewInit();\n            return;\n        }\n\n        this._group = group;\n    }\n    get group() { return this._group }\n\n    private _matchGroups: { [key: string]: string };\n    private _inputs: { [key: string]: any; };\n    /**\n     * A map of inputs to bind to the child.\n     * Supports change detection. (May fail on deep JSON changes)\n     *\n     * ```html\n     * <lazy-loader component=\"MyLazyComponent\"\n     *       [inputs]=\"{\n     *          prop1: true,\n     *          prop2: false,\n     *          complex: {\n     *              a: true,\n     *              b: 0\n     *          }\n     *       }\"\n     * >\n     * </lazy-loader>\n     * ```\n     */\n    @Input(\"inputs\") set inputs(data: { [key: string]: any; }) {\n        if (data == undefined) return;\n\n        let previous = this._inputs;\n        this._inputs = data;\n        if (data == undefined)\n            console.trace(data);\n\n        if (this.targetComponentFactory) {\n            const { inputs } = this.targetComponentFactory.ɵcmp;\n\n            const currentKeys = Object.keys(inputs);\n\n            const oldKeys = Object.keys(previous).filter(key => currentKeys.includes(key));\n            const newKeys = Object.keys(data).filter(key => currentKeys.includes(key));\n\n            const removed = oldKeys.filter(key => !newKeys.includes(key));\n\n            // ? perhaps set to null or undefined instead\n            removed.forEach(k => this.targetComponentInstance[k] = null);\n\n            this.bindInputs();\n        }\n    }\n\n\n    private outputSubscriptions: { [key: string]: Subscription; } = {};\n    private _outputs: { [key: string]: Function; };\n    /**\n     * A map of outputs to bind from the child.\n     * Should support change detection.\n     * ```html\n     * <lazy-loader component=\"MyLazyComponent\"\n     *       [outputs]=\"{\n     *           prop3: onOutputFire\n     *       }\"\n     * >\n     * </lazy-loader>\n     * ```\n     */\n    @Input(\"outputs\") set outputs(data: { [key: string]: Function; }) {\n        let previous = this._outputs;\n        this._outputs = data;\n\n        if (this.targetComponentFactory) {\n            const { inputs } = this.targetComponentFactory.ɵcmp;\n\n            const currentKeys = Object.keys(inputs);\n            const removed = Object.keys(previous).filter(key => !currentKeys.includes(key));\n\n            removed.forEach(k => {\n                // Unsubscribe from observable\n                this.outputSubscriptions[k]?.unsubscribe();\n                delete this.targetComponentInstance[k];\n            });\n\n            this.bindOutputs();\n        }\n    }\n\n    /**\n     * Emits errors encountered when loading components\n     */\n    @Output() componentLoadError = new EventEmitter();\n\n    /**\n     * Emits when the component is fully constructed\n     * and had it's inputs and outputs bound\n     * > before `OnInit`\n     *\n     * Returns the active class instance of the lazy-loaded component\n     */\n    @Output() componentLoaded = new EventEmitter();\n\n\n    /**\n     * This is an instance of the component that is currently loaded.\n     */\n    public instance: any;\n\n\n    /**\n     * Container that provides the component data\n     */\n    private targetModule: CompiledBundle;\n\n    /**\n     * Component definition\n     */\n    private targetComponentFactory: any;\n\n    /**\n     * Active component container reference\n     */\n    private targetComponentContainerRef: ComponentRef<any>;\n    private targetRef: any;\n    /**\n     * Reference to the component class instance\n     */\n    private targetComponentInstance: any;\n\n    /**\n     * Subscription with true/false state on whether the distractor should be\n     */\n    private distractorSubscription: Subscription;\n\n    public config: NgxLazyLoaderConfig;\n    private err;\n    private warn;\n    private log;\n\n    // Force 500ms delay before revealing the spinner\n    private loaderEmitter = new EventEmitter();\n    private clearLoader$ = this.loaderEmitter.pipe(debounceTime(300));\n    private loaderSub: Subscription;\n    showLoader = true; // whether we render the DOM for the spinner\n    isClearingLoader = false; // should the spinner start fading out\n\n    constructor(\n        private service: LazyLoaderService,\n        @Optional() private viewContainerRef: ViewContainerRef,\n        @Optional() public dialog: DialogRef,\n        @Optional() @Inject(MAT_DIALOG_DATA) public dialogArguments\n    ) {\n        this.config = LazyLoaderService.config;\n        this.err = LazyLoaderService.config.logger.err;\n        this.warn = LazyLoaderService.config.logger.warn;\n        this.log = LazyLoaderService.config.logger.log;\n\n        // First, check for dialog arguments\n        if (this.dialogArguments) {\n            this.inputs = this.dialogArguments.inputs || this.dialogArguments.data;\n            this.outputs = this.dialogArguments.outputs;\n            this.id = this.dialogArguments.id;\n            this.group = this.dialogArguments.group;\n        }\n\n        this.loaderSub = this.clearLoader$.subscribe(() => {\n            this.showLoader = false;\n        });\n    }\n\n    private initialized = false;\n    async ngAfterViewInit() {\n        this.ngOnDestroy(false);\n        this.isClearingLoader = false;\n        this.showLoader = true;\n\n        this.initialized = true;\n\n        if (!this._id) {\n            this.warn(\"No component was specified!\");\n            return this.loadDefault();\n        }\n\n        try {\n            const _entry = this.service.resolveRegistrationEntry(this._id, this._group);\n            if (!_entry || !_entry.entry) {\n                this.err(`Failed to find Component '${this._id}' in group '${this._group}' in registry!`);\n                return this.loadDefault();\n            }\n\n            const { entry, matchGroups } = _entry;\n            this._matchGroups = matchGroups;\n\n            // Download the \"module\" (the standalone component)\n            const bundle: CompiledBundle = this.targetModule = await entry.load();\n\n\n            // Check if there is some corruption on the bundle.\n            if (!bundle || typeof bundle != 'object' || bundle['__esModule'] as any !== true || bundle.toString() != \"[object Module]\") {\n                this.err(`Failed to load component/module for '${this._id}'! Parsed resource is invalid.`);\n                return this.loadError();\n            }\n\n            const modules = Object.keys(bundle)\n                .map(k => {\n                    const entry = bundle[k];\n\n                    // Strictly check for exported modules or standalone components\n                    if (typeof entry == \"function\" && typeof entry[\"ɵfac\"] == \"function\")\n                        return entry;\n                    return null;\n                })\n                .filter(e => e != null)\n                .filter(entry => {\n                    entry['_isModule'] = !!entry['ɵmod']; // module\n                    entry['_isComponent'] = !!entry['ɵcmp']; // component\n\n                    return (entry['_isModule'] || entry['_isComponent']);\n                });\n\n            if (modules.length == 0) {\n                this.err(`Component/Module loaded for '${this._id}' has no exported components or modules!`);\n                return this.loadError();\n            }\n\n            const component = this.targetComponentFactory = this.service.resolveComponent(this._id, \"default\", modules);\n\n            if (!component) {\n                this.err(`Component '${this._id}' is invalid or corrupted!`);\n                return this.loadError();\n            }\n\n\n            // Bootstrap the component into the container\n            const componentRef = this.targetComponentContainerRef = this.targetContainer.createComponent(component as any);\n            this.targetRef = this.targetContainer.insert(this.targetComponentContainerRef.hostView);\n\n            const instance: any = this.targetComponentInstance = componentRef['instance'];\n\n            this.bindInputs();\n            this.bindOutputs();\n\n            this.componentLoaded.next(instance);\n            this.instance = instance;\n\n            // Look for an observable called isLoading$ that will make us show/hide\n            // the same distractor that is used on basic loading\n            const isLoading$ = instance['ngxShowDistractor$'] as BehaviorSubject<boolean>;\n\n            if (isLoading$ && typeof isLoading$.subscribe == \"function\") {\n                this.distractorSubscription = isLoading$.subscribe(loading => {\n                    if (!loading) {\n                        this.isClearingLoader = true;\n                        this.loaderEmitter.emit();\n                    }\n                    else {\n                        this.showLoader = true;\n                        this.isClearingLoader = false;\n                    }\n                });\n            }\n            else {\n                this.isClearingLoader = true;\n            }\n\n            const name = Object.keys(bundle)[0];\n            this.log(`Loaded '${name}'`);\n            this.loaderEmitter.emit();\n\n            return componentRef;\n        }\n        catch (ex) {\n\n            if (isDevMode()) {\n                console.warn(\"Component \" + this._id + \" threw an error on mount!\");\n                console.warn(\"This will cause you to see a 404 panel.\");\n                console.error(ex);\n            }\n\n            // Network errors throw a toast and return an error component\n            if (ex && !isDevMode()) {\n                console.error(\"Uncaught error when loading component\");\n                throw ex;\n            }\n\n            return this.loadDefault();\n        }\n    }\n\n    ngOnDestroy(clearAll = true) {\n        // unsubscribe from all subscriptions\n        Object.entries(this.outputSubscriptions).forEach(([key, sub]) => {\n            sub.unsubscribe();\n        });\n        this.outputSubscriptions = {};\n\n        // Clear all things\n        if (clearAll) {\n            this.loaderSub?.unsubscribe();\n        }\n\n        this.distractorSubscription?.unsubscribe();\n\n        // Clear target container\n        this.targetRef?.destroy();\n        this.targetComponentContainerRef?.destroy();\n        this.targetContainer?.clear();\n\n        // Wipe the rest of the state clean\n        this.targetRef = null;\n        this.targetComponentContainerRef = null;\n    }\n\n    /**\n     * Bind the input values to the child component.\n     */\n    private bindInputs() {\n        if (!this._inputs || !this.targetComponentInstance) return;\n\n        // Merge match groups\n        if (typeof this._matchGroups == \"object\") {\n            Object.entries(this._matchGroups).forEach(([key, val]) => {\n                if (typeof this._inputs[key] == 'undefined')\n                    this._inputs[key] = val;\n            });\n        }\n\n        // forward-bind inputs\n        const { inputs } = this.targetComponentFactory.ɵcmp;\n\n        // Returns a list of entries that need to be set\n        // This makes it so that unnecessary setters are not invoked.\n        const updated = Object.entries(inputs).filter(([parentKey, childKey]: [string, string]) => {\n            return this.targetComponentInstance[childKey] != this._inputs[parentKey];\n        });\n\n        updated.forEach(([parentKey, childKey]: [string, string]) => {\n            if (this._inputs.hasOwnProperty(parentKey))\n                this.targetComponentInstance[childKey] = this._inputs[parentKey];\n        });\n    }\n\n    /**\n     * Bind the output handlers to the loaded child component\n     */\n    private bindOutputs() {\n        if (!this._outputs || !this.targetComponentInstance) return;\n\n        const { outputs } = this.targetComponentFactory.ɵcmp;\n\n        // Get a list of unregistered outputs\n        const newOutputs = Object.entries(outputs).filter(([parentKey, childKey]: [string, string]) => {\n            return !this.outputSubscriptions[parentKey];\n        });\n\n        // Reverse bind via subscription\n        newOutputs.forEach(([parentKey, childKey]: [string, string]) => {\n            if (this._outputs.hasOwnProperty(parentKey)) {\n                const target: EventEmitter<unknown> = this.targetComponentInstance[childKey];\n                const outputs = this._outputs;\n\n                // Angular folks, stop making this so difficult.\n                const ctx = this.viewContainerRef['_hostLView'][8];\n                const sub = target.subscribe(outputs[parentKey].bind(ctx)); // Subscription\n\n                this.outputSubscriptions[parentKey] = sub;\n            }\n        });\n    }\n\n    /**\n     * Load the \"Default\" component (404) screen normally.\n     * This is shown when the component id isn't in the\n     * registry or otherwise doesn't match\n     *\n     * This\n     */\n    private loadDefault() {\n        if (this.config.notFoundComponent)\n            this.targetContainer.createComponent(this.config.notFoundComponent);\n\n        this.showLoader = false;\n    }\n\n    /**\n     * Load the \"Error\" component.\n     * This is shown when we are able to resolve the component\n     * in the registry, but have some issue boostrapping the\n     * component into the viewContainer\n     */\n    private loadError() {\n        if (this.config.errorComponent)\n            this.targetContainer.createComponent(this.config.errorComponent);\n\n        this.showLoader = false;\n    }\n}\n","<ng-container #content></ng-container>\n\n<div class=\"ngx-lazy-loader-distractor\" [class.destroying]=\"isClearingLoader\">\n    <ng-container *ngIf=\"config.loaderDistractorComponent\" [ngComponentOutlet]=\"config.loaderDistractorComponent\"></ng-container>\n    <ng-container *ngIf=\"config.loaderDistractorTemplate\" [ngTemplateOutlet]=\"config.loaderDistractorTemplate\" [ngTemplateOutletContext]=\"{ '$implicit': inputs }\"></ng-container>\n</div>\n"]}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { LazyLoaderComponent } from './lazy-loader.component';
|
|
3
|
+
import { LazyLoaderService, NGX_LAZY_LOADER_CONFIG } from './lazy-loader.service';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class LazyLoaderModule {
|
|
6
|
+
static forRoot(config) {
|
|
7
|
+
return ({
|
|
8
|
+
ngModule: LazyLoaderModule,
|
|
9
|
+
providers: [
|
|
10
|
+
LazyLoaderService,
|
|
11
|
+
{
|
|
12
|
+
provide: NGX_LAZY_LOADER_CONFIG,
|
|
13
|
+
useValue: config
|
|
14
|
+
}
|
|
15
|
+
]
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
LazyLoaderModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: LazyLoaderModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
20
|
+
LazyLoaderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: LazyLoaderModule, imports: [LazyLoaderComponent], exports: [LazyLoaderComponent] });
|
|
21
|
+
LazyLoaderModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: LazyLoaderModule, imports: [LazyLoaderComponent] });
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: LazyLoaderModule, decorators: [{
|
|
23
|
+
type: NgModule,
|
|
24
|
+
args: [{
|
|
25
|
+
imports: [LazyLoaderComponent],
|
|
26
|
+
exports: [LazyLoaderComponent]
|
|
27
|
+
}]
|
|
28
|
+
}] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1sb2FkZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tbW9uL3NyYy9jb21wb25lbnRzL2xhenktbG9hZGVyL2xhenktbG9hZGVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXVCLFFBQVEsRUFBc0IsTUFBTSxlQUFlLENBQUM7QUFFbEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDOUQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLHNCQUFzQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBTWxGLE1BQU0sT0FBTyxnQkFBZ0I7SUFDbEIsTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUEyQjtRQUM3QyxPQUFPLENBQUM7WUFDSixRQUFRLEVBQUUsZ0JBQWdCO1lBQzFCLFNBQVMsRUFBRTtnQkFDUCxpQkFBaUI7Z0JBQ2pCO29CQUNJLE9BQU8sRUFBRSxzQkFBc0I7b0JBQy9CLFFBQVEsRUFBRSxNQUFNO2lCQUNuQjthQUNKO1NBQ0osQ0FBQyxDQUFDO0lBQ1AsQ0FBQzs7NkdBWlEsZ0JBQWdCOzhHQUFoQixnQkFBZ0IsWUFIZixtQkFBbUIsYUFDbkIsbUJBQW1COzhHQUVwQixnQkFBZ0IsWUFIZixtQkFBbUI7MkZBR3BCLGdCQUFnQjtrQkFKNUIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztvQkFDOUIsT0FBTyxFQUFFLENBQUMsbUJBQW1CLENBQUM7aUJBQ2pDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGUsIE9wdGlvbmFsLCBTa2lwU2VsZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmd4TGF6eUxvYWRlckNvbmZpZyB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgTGF6eUxvYWRlckNvbXBvbmVudCB9IGZyb20gJy4vbGF6eS1sb2FkZXIuY29tcG9uZW50JztcbmltcG9ydCB7IExhenlMb2FkZXJTZXJ2aWNlLCBOR1hfTEFaWV9MT0FERVJfQ09ORklHIH0gZnJvbSAnLi9sYXp5LWxvYWRlci5zZXJ2aWNlJztcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbTGF6eUxvYWRlckNvbXBvbmVudF0sXG4gICAgZXhwb3J0czogW0xhenlMb2FkZXJDb21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIExhenlMb2FkZXJNb2R1bGUge1xuICAgIHB1YmxpYyBzdGF0aWMgZm9yUm9vdChjb25maWc6IE5neExhenlMb2FkZXJDb25maWcpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPExhenlMb2FkZXJNb2R1bGU+IHtcbiAgICAgICAgcmV0dXJuICh7XG4gICAgICAgICAgICBuZ01vZHVsZTogTGF6eUxvYWRlck1vZHVsZSxcbiAgICAgICAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAgICAgICAgIExhenlMb2FkZXJTZXJ2aWNlLFxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgcHJvdmlkZTogTkdYX0xBWllfTE9BREVSX0NPTkZJRyxcbiAgICAgICAgICAgICAgICAgICAgdXNlVmFsdWU6IGNvbmZpZ1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIF1cbiAgICAgICAgfSk7XG4gICAgfVxufVxuIl19
|