@acorex/core 3.0.31 → 3.0.35
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/acorex-core.metadata.json +1 -1
- package/bundles/acorex-core.umd.js +59 -42
- package/bundles/acorex-core.umd.js.map +1 -1
- package/bundles/acorex-core.umd.min.js +1 -1
- package/bundles/acorex-core.umd.min.js.map +1 -1
- package/esm2015/lib/utils/render/render.service.js +38 -31
- package/esm5/lib/utils/render/render.service.js +62 -45
- package/fesm2015/acorex-core.js +37 -30
- package/fesm2015/acorex-core.js.map +1 -1
- package/fesm5/acorex-core.js +61 -44
- package/fesm5/acorex-core.js.map +1 -1
- package/lib/utils/render/render.service.d.ts +3 -2
- package/package.json +1 -1
|
@@ -1,15 +1,16 @@
|
|
|
1
|
-
import { __decorate, __metadata } from "tslib";
|
|
2
|
-
import { ApplicationRef, ComponentFactoryResolver, ComponentRef, Injectable, Injector, EmbeddedViewRef, Type } from '@angular/core';
|
|
1
|
+
import { __awaiter, __decorate, __metadata } from "tslib";
|
|
2
|
+
import { ApplicationRef, ComponentFactoryResolver, ComponentRef, Injectable, Injector, EmbeddedViewRef, Type, Compiler, NgModuleFactory } from '@angular/core';
|
|
3
3
|
import { Router, Route } from '@angular/router';
|
|
4
4
|
import { AXOnDemandPreloadService } from './on-demand-preload-strategy.service';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/router";
|
|
7
7
|
import * as i2 from "./on-demand-preload-strategy.service";
|
|
8
8
|
let AXRenderService = class AXRenderService {
|
|
9
|
-
constructor(appRef, router, componentFactoryResolver, modulePreloadService, injector) {
|
|
9
|
+
constructor(appRef, router, componentFactoryResolver, compiler, modulePreloadService, injector) {
|
|
10
10
|
this.appRef = appRef;
|
|
11
11
|
this.router = router;
|
|
12
12
|
this.componentFactoryResolver = componentFactoryResolver;
|
|
13
|
+
this.compiler = compiler;
|
|
13
14
|
this.modulePreloadService = modulePreloadService;
|
|
14
15
|
this.injector = injector;
|
|
15
16
|
}
|
|
@@ -41,8 +42,8 @@ let AXRenderService = class AXRenderService {
|
|
|
41
42
|
let found = null;
|
|
42
43
|
let preload = false;
|
|
43
44
|
const theLoop = (i) => {
|
|
44
|
-
setTimeout(() => {
|
|
45
|
-
found = this._findLoadedComponentByRoute(path);
|
|
45
|
+
setTimeout(() => __awaiter(this, void 0, void 0, function* () {
|
|
46
|
+
found = yield this._findLoadedComponentByRoute(path);
|
|
46
47
|
if (--i && found == null) {
|
|
47
48
|
if (!preload) {
|
|
48
49
|
this.modulePreloadService.startPreload(path);
|
|
@@ -56,57 +57,63 @@ let AXRenderService = class AXRenderService {
|
|
|
56
57
|
else {
|
|
57
58
|
reject();
|
|
58
59
|
}
|
|
59
|
-
}, delay);
|
|
60
|
+
}), delay);
|
|
60
61
|
};
|
|
61
62
|
theLoop(loop);
|
|
62
63
|
});
|
|
63
64
|
}
|
|
64
65
|
_findLoadedComponentByRoute(search) {
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
66
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
67
|
+
let found = null;
|
|
68
|
+
const f = (children, parentPath) => {
|
|
69
|
+
for (const p in children) {
|
|
70
|
+
if (children.hasOwnProperty(p)) {
|
|
71
|
+
const route = children[p];
|
|
72
|
+
const pp = (route.path != '' && route.path != null) ? parentPath + '/' + route.path : parentPath;
|
|
73
|
+
if (pp == search && !route._loadedConfig && route.component) {
|
|
74
|
+
found = route;
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
else if (route._loadedConfig || route.children) {
|
|
78
|
+
f(route.children || route._loadedConfig.routes, pp);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
for (const p in this.router.config) {
|
|
84
|
+
if (this.router.config.hasOwnProperty(p)) {
|
|
85
|
+
const route = this.router.config[p];
|
|
86
|
+
if (route.path === search && route.component) {
|
|
72
87
|
found = route;
|
|
73
|
-
break;
|
|
74
88
|
}
|
|
75
|
-
else if (route.
|
|
76
|
-
f(route._loadedConfig.routes,
|
|
89
|
+
else if (route['_loadedConfig'] || route.children) {
|
|
90
|
+
f(route.children || route['_loadedConfig'].routes, route.path);
|
|
77
91
|
}
|
|
92
|
+
if (found)
|
|
93
|
+
break;
|
|
78
94
|
}
|
|
79
95
|
}
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
if (this.router.config.hasOwnProperty(p)) {
|
|
83
|
-
const route = this.router.config[p];
|
|
84
|
-
if (route.path === search && route.component) {
|
|
85
|
-
found = route;
|
|
86
|
-
}
|
|
87
|
-
else if (route['_loadedConfig']) {
|
|
88
|
-
f(route['_loadedConfig'].routes, route.path);
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
return found;
|
|
96
|
+
return found;
|
|
97
|
+
});
|
|
93
98
|
}
|
|
94
99
|
};
|
|
95
100
|
AXRenderService.ctorParameters = () => [
|
|
96
101
|
{ type: ApplicationRef },
|
|
97
102
|
{ type: Router },
|
|
98
103
|
{ type: ComponentFactoryResolver },
|
|
104
|
+
{ type: Compiler },
|
|
99
105
|
{ type: AXOnDemandPreloadService },
|
|
100
106
|
{ type: Injector }
|
|
101
107
|
];
|
|
102
|
-
AXRenderService.ɵprov = i0.ɵɵdefineInjectable({ factory: function AXRenderService_Factory() { return new AXRenderService(i0.ɵɵinject(i0.ApplicationRef), i0.ɵɵinject(i1.Router), i0.ɵɵinject(i0.ComponentFactoryResolver), i0.ɵɵinject(i2.AXOnDemandPreloadService), i0.ɵɵinject(i0.INJECTOR)); }, token: AXRenderService, providedIn: "root" });
|
|
108
|
+
AXRenderService.ɵprov = i0.ɵɵdefineInjectable({ factory: function AXRenderService_Factory() { return new AXRenderService(i0.ɵɵinject(i0.ApplicationRef), i0.ɵɵinject(i1.Router), i0.ɵɵinject(i0.ComponentFactoryResolver), i0.ɵɵinject(i0.Compiler), i0.ɵɵinject(i2.AXOnDemandPreloadService), i0.ɵɵinject(i0.INJECTOR)); }, token: AXRenderService, providedIn: "root" });
|
|
103
109
|
AXRenderService = __decorate([
|
|
104
110
|
Injectable({ providedIn: 'root' }),
|
|
105
111
|
__metadata("design:paramtypes", [ApplicationRef,
|
|
106
112
|
Router,
|
|
107
113
|
ComponentFactoryResolver,
|
|
114
|
+
Compiler,
|
|
108
115
|
AXOnDemandPreloadService,
|
|
109
116
|
Injector])
|
|
110
117
|
], AXRenderService);
|
|
111
118
|
export { AXRenderService };
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"render.service.js","sourceRoot":"ng://@acorex/core/","sources":["lib/utils/render/render.service.ts"],"names":[],"mappings":";AAAA,OAAO,EACH,cAAc,EAAE,wBAAwB,EAAE,YAAY,EAAE,UAAU,EAClE,QAAQ,EAAE,eAAe,EAAE,IAAI,EAClC,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,wBAAwB,EAAE,MAAM,sCAAsC,CAAC;;;;AAKhF,IAAa,eAAe,GAA5B,MAAa,eAAe;IACxB,YACY,MAAsB,EACtB,MAAc,EACd,wBAAkD,EAClD,oBAA8C,EAC9C,QAAkB;QAJlB,WAAM,GAAN,MAAM,CAAgB;QACtB,WAAM,GAAN,MAAM,CAAQ;QACd,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,yBAAoB,GAApB,oBAAoB,CAA0B;QAC9C,aAAQ,GAAR,QAAQ,CAAU;IAC9B,CAAC;IAID,eAAe,CACX,cAAuB,EACvB,UAAe,EAAE,EACjB,QAAkB;QAElB,MAAM,gBAAgB,GAAG,IAAI,CAAC,wBAAwB,CAAC,uBAAuB,CAAC,cAAc,CAAC,CAAC;QAC/F,MAAM,YAAY,GAAG,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5D,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC9C,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QAC9C,EAAE;QACF,MAAM,OAAO,GAAI,YAAY,CAAC,QAAiC,CAAC,SAAS,CAAC,CAAC,CAAgB,CAAC;QAC5F,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;YACxB,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;QACH,IAAI,QAAQ,EAAE;YACV,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;SACjC;aAAM;YACH,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;SACtC;QACD,UAAU,CAAC,GAAG,EAAE;YACZ,YAAY,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;QACnD,CAAC,EAAE,CAAC,CAAC,CAAC;QACN,OAAO,YAAY,CAAC;IACxB,CAAC;IAED,0BAA0B,CAAC,IAAY,EAAE,cAAsB,EAAE;QAC7D,MAAM,KAAK,GAAG,GAAG,CAAC;QAClB,MAAM,IAAI,GAAG,WAAW,GAAG,IAAI,GAAG,KAAK,CAAC;QACxC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACnC,IAAI,KAAK,GAAU,IAAI,CAAC;YACxB,IAAI,OAAO,GAAY,KAAK,CAAC;YAC7B,MAAM,OAAO,GAAG,CAAC,CAAC,EAAE,EAAE;gBAClB,UAAU,CAAC,GAAG,EAAE;oBACZ,KAAK,GAAG,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,CAAC;oBAC/C,IAAI,EAAE,CAAC,IAAI,KAAK,IAAI,IAAI,EAAE;wBACtB,IAAI,CAAC,OAAO,EAAE;4BACV,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;4BAC7C,OAAO,GAAG,IAAI,CAAC;yBAClB;wBACD,OAAO,CAAC,CAAC,CAAC,CAAC;qBACd;yBACI,IAAI,KAAK,EAAE;wBACZ,OAAO,CAAC,KAAK,CAAC,CAAC;qBAClB;yBACI;wBACD,MAAM,EAAE,CAAC;qBACZ;gBACL,CAAC,EAAE,KAAK,CAAC,CAAC;YACd,CAAC,CAAC;YACF,OAAO,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,2BAA2B,CAAC,MAAM;QACtC,IAAI,KAAK,GAAU,IAAI,CAAC;QACxB,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE;YACrB,KAAK,MAAM,CAAC,IAAI,IAAI,EAAE;gBAClB,IAAI,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE;oBACxB,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;oBACtB,MAAM,EAAE,GAAG,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,GAAG,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;oBACrF,IAAI,EAAE,IAAI,MAAM,IAAI,CAAC,KAAK,CAAC,aAAa,IAAI,KAAK,CAAC,SAAS,EAAE;wBACzD,KAAK,GAAG,KAAK,CAAC;wBACd,MAAM;qBACT;yBAAM,IAAI,KAAK,CAAC,aAAa,EAAE;wBAC5B,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;qBACrC;iBACJ;aACJ;QACL,CAAC,CAAC;QAEF,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;YAChC,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE;gBACtC,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;gBACpC,IAAI,KAAK,CAAC,IAAI,KAAK,MAAM,IAAI,KAAK,CAAC,SAAS,EAAE;oBAC1C,KAAK,GAAG,KAAK,CAAC;iBACjB;qBACI,IAAI,KAAK,CAAC,eAAe,CAAC,EAAE;oBAC7B,CAAC,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;iBAChD;aAEJ;SACJ;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;CAEJ,CAAA;;YA9FuB,cAAc;YACd,MAAM;YACY,wBAAwB;YAC5B,wBAAwB;YACpC,QAAQ;;;AANrB,eAAe;IAD3B,UAAU,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC;qCAGX,cAAc;QACd,MAAM;QACY,wBAAwB;QAC5B,wBAAwB;QACpC,QAAQ;GANrB,eAAe,CAgG3B;SAhGY,eAAe","sourcesContent":["import {\r\n    ApplicationRef, ComponentFactoryResolver, ComponentRef, Injectable,\r\n    Injector, EmbeddedViewRef, Type\r\n} from '@angular/core';\r\nimport { Router, Route } from '@angular/router';\r\nimport { AXOnDemandPreloadService } from './on-demand-preload-strategy.service';\r\n\r\n\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class AXRenderService {\r\n    constructor(\r\n        private appRef: ApplicationRef,\r\n        private router: Router,\r\n        private componentFactoryResolver: ComponentFactoryResolver,\r\n        private modulePreloadService: AXOnDemandPreloadService,\r\n        private injector: Injector) {\r\n    }\r\n\r\n\r\n\r\n    appendComponent<T>(\r\n        componentClass: Type<T>,\r\n        options: any = {},\r\n        location?: Element): ComponentRef<any> {\r\n\r\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(componentClass);\r\n        const componentRef = componentFactory.create(this.injector);\r\n        this.appRef.attachView(componentRef.hostView);\r\n        Object.assign(componentRef.instance, options);\r\n        //\r\n        const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\r\n        componentRef.onDestroy(() => {\r\n            this.appRef.detachView(componentRef.hostView);\r\n        });\r\n        if (location) {\r\n            location.appendChild(domElem);\r\n        } else {\r\n            document.body.appendChild(domElem);\r\n        }\r\n        setTimeout(() => {\r\n            componentRef.changeDetectorRef.detectChanges();\r\n        }, 0);\r\n        return componentRef;\r\n    }\r\n\r\n    findLoadedComponentByRoute(path: string, timeoutTime: number = 10): Promise<Route> {\r\n        const delay = 200;\r\n        const loop = timeoutTime * 1000 / delay;\r\n        return new Promise((resolve, reject) => {\r\n            let found: Route = null;\r\n            let preload: boolean = false;\r\n            const theLoop = (i) => {\r\n                setTimeout(() => {\r\n                    found = this._findLoadedComponentByRoute(path);\r\n                    if (--i && found == null) {\r\n                        if (!preload) {\r\n                            this.modulePreloadService.startPreload(path);\r\n                            preload = true;\r\n                        }\r\n                        theLoop(i);\r\n                    }\r\n                    else if (found) {\r\n                        resolve(found);\r\n                    }\r\n                    else {\r\n                        reject();\r\n                    }\r\n                }, delay);\r\n            };\r\n            theLoop(loop);\r\n        });\r\n    }\r\n\r\n    private _findLoadedComponentByRoute(search) {\r\n        let found: Route = null;\r\n        const f = (list, path) => {\r\n            for (const p in list) {\r\n                if (list.hasOwnProperty(p)) {\r\n                    const route = list[p];\r\n                    const pp = (route.path != '' && route.path != null) ? path + '/' + route.path : path;\r\n                    if (pp == search && !route._loadedConfig && route.component) {\r\n                        found = route;\r\n                        break;\r\n                    } else if (route._loadedConfig) {\r\n                        f(route._loadedConfig.routes, pp);\r\n                    }\r\n                }\r\n            }\r\n        };\r\n\r\n        for (const p in this.router.config) {\r\n            if (this.router.config.hasOwnProperty(p)) {\r\n                const route = this.router.config[p];\r\n                if (route.path === search && route.component) {\r\n                    found = route;\r\n                }\r\n                else if (route['_loadedConfig']) {\r\n                    f(route['_loadedConfig'].routes, route.path);\r\n                }\r\n\r\n            }\r\n        }\r\n        return found;\r\n    }\r\n\r\n}\r\n"]}
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"render.service.js","sourceRoot":"ng://@acorex/core/","sources":["lib/utils/render/render.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ApplicationRef, ComponentFactoryResolver, ComponentRef, Injectable,\r\n    Injector, EmbeddedViewRef, Type, Compiler, NgModuleFactory\r\n} from '@angular/core';\r\nimport { Router, Route } from '@angular/router';\r\nimport { AXOnDemandPreloadService } from './on-demand-preload-strategy.service';\r\n\r\n\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class AXRenderService {\r\n    constructor(\r\n        private appRef: ApplicationRef,\r\n        private router: Router,\r\n        private componentFactoryResolver: ComponentFactoryResolver,\r\n        private compiler: Compiler,\r\n        private modulePreloadService: AXOnDemandPreloadService,\r\n        private injector: Injector) {\r\n    }\r\n\r\n\r\n\r\n    appendComponent<T>(\r\n        componentClass: Type<T>,\r\n        options: any = {},\r\n        location?: Element): ComponentRef<any> {\r\n\r\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(componentClass);\r\n        const componentRef = componentFactory.create(this.injector);\r\n        this.appRef.attachView(componentRef.hostView);\r\n        Object.assign(componentRef.instance, options);\r\n        //\r\n        const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\r\n        componentRef.onDestroy(() => {\r\n            this.appRef.detachView(componentRef.hostView);\r\n        });\r\n        if (location) {\r\n            location.appendChild(domElem);\r\n        } else {\r\n            document.body.appendChild(domElem);\r\n        }\r\n        setTimeout(() => {\r\n            componentRef.changeDetectorRef.detectChanges();\r\n        }, 0);\r\n        return componentRef;\r\n    }\r\n\r\n    findLoadedComponentByRoute(path: string, timeoutTime: number = 10): Promise<Route> {\r\n        const delay = 200;\r\n        const loop = timeoutTime * 1000 / delay;\r\n        return new Promise((resolve, reject) => {\r\n            let found: Route = null;\r\n            let preload: boolean = false;\r\n            const theLoop = (i) => {\r\n                setTimeout(async () => {\r\n                    found = await this._findLoadedComponentByRoute(path);\r\n                    if (--i && found == null) {\r\n                        if (!preload) {\r\n                            this.modulePreloadService.startPreload(path);\r\n                            preload = true;\r\n                        }\r\n                        theLoop(i);\r\n                    }\r\n                    else if (found) {\r\n                        resolve(found);\r\n                    }\r\n                    else {\r\n                        reject();\r\n                    }\r\n                }, delay);\r\n            };\r\n            theLoop(loop);\r\n        });\r\n    }\r\n\r\n    private async _findLoadedComponentByRoute(search) {\r\n\r\n        let found: Route = null;\r\n        const f = (children, parentPath) => {\r\n            for (const p in children) {\r\n                if (children.hasOwnProperty(p)) {\r\n                    const route = children[p];\r\n                    const pp = (route.path != '' && route.path != null) ? parentPath + '/' + route.path : parentPath;\r\n                    if (pp == search && !route._loadedConfig && route.component) {\r\n                        found = route;\r\n                        return;\r\n                    } else if (route._loadedConfig || route.children) {\r\n                        f(route.children || route._loadedConfig.routes, pp);\r\n                    }\r\n                }\r\n            }\r\n        };\r\n\r\n        for (const p in this.router.config) {\r\n            if (this.router.config.hasOwnProperty(p)) {\r\n                const route = this.router.config[p];\r\n                if (route.path === search && route.component) {\r\n                    found = route;\r\n                }\r\n                else if (route['_loadedConfig'] || route.children) {\r\n                    f(route.children || route['_loadedConfig'].routes, route.path);\r\n                }\r\n                if (found)\r\n                    break;\r\n            }\r\n        }\r\n        return found;\r\n    }\r\n\r\n}\r\n"]}
|
|
@@ -1,15 +1,16 @@
|
|
|
1
|
-
import { __decorate, __metadata } from "tslib";
|
|
2
|
-
import { ApplicationRef, ComponentFactoryResolver, ComponentRef, Injectable, Injector, EmbeddedViewRef, Type } from '@angular/core';
|
|
1
|
+
import { __awaiter, __decorate, __generator, __metadata } from "tslib";
|
|
2
|
+
import { ApplicationRef, ComponentFactoryResolver, ComponentRef, Injectable, Injector, EmbeddedViewRef, Type, Compiler, NgModuleFactory } from '@angular/core';
|
|
3
3
|
import { Router, Route } from '@angular/router';
|
|
4
4
|
import { AXOnDemandPreloadService } from './on-demand-preload-strategy.service';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/router";
|
|
7
7
|
import * as i2 from "./on-demand-preload-strategy.service";
|
|
8
8
|
var AXRenderService = /** @class */ (function () {
|
|
9
|
-
function AXRenderService(appRef, router, componentFactoryResolver, modulePreloadService, injector) {
|
|
9
|
+
function AXRenderService(appRef, router, componentFactoryResolver, compiler, modulePreloadService, injector) {
|
|
10
10
|
this.appRef = appRef;
|
|
11
11
|
this.router = router;
|
|
12
12
|
this.componentFactoryResolver = componentFactoryResolver;
|
|
13
|
+
this.compiler = compiler;
|
|
13
14
|
this.modulePreloadService = modulePreloadService;
|
|
14
15
|
this.injector = injector;
|
|
15
16
|
}
|
|
@@ -45,73 +46,89 @@ var AXRenderService = /** @class */ (function () {
|
|
|
45
46
|
var found = null;
|
|
46
47
|
var preload = false;
|
|
47
48
|
var theLoop = function (i) {
|
|
48
|
-
setTimeout(function () {
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
49
|
+
setTimeout(function () { return __awaiter(_this, void 0, void 0, function () {
|
|
50
|
+
return __generator(this, function (_a) {
|
|
51
|
+
switch (_a.label) {
|
|
52
|
+
case 0: return [4 /*yield*/, this._findLoadedComponentByRoute(path)];
|
|
53
|
+
case 1:
|
|
54
|
+
found = _a.sent();
|
|
55
|
+
if (--i && found == null) {
|
|
56
|
+
if (!preload) {
|
|
57
|
+
this.modulePreloadService.startPreload(path);
|
|
58
|
+
preload = true;
|
|
59
|
+
}
|
|
60
|
+
theLoop(i);
|
|
61
|
+
}
|
|
62
|
+
else if (found) {
|
|
63
|
+
resolve(found);
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
reject();
|
|
67
|
+
}
|
|
68
|
+
return [2 /*return*/];
|
|
54
69
|
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
else if (found) {
|
|
58
|
-
resolve(found);
|
|
59
|
-
}
|
|
60
|
-
else {
|
|
61
|
-
reject();
|
|
62
|
-
}
|
|
63
|
-
}, delay);
|
|
70
|
+
});
|
|
71
|
+
}); }, delay);
|
|
64
72
|
};
|
|
65
73
|
theLoop(loop);
|
|
66
74
|
});
|
|
67
75
|
};
|
|
68
76
|
AXRenderService.prototype._findLoadedComponentByRoute = function (search) {
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
77
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
78
|
+
var found, f, p, route;
|
|
79
|
+
return __generator(this, function (_a) {
|
|
80
|
+
found = null;
|
|
81
|
+
f = function (children, parentPath) {
|
|
82
|
+
for (var p in children) {
|
|
83
|
+
if (children.hasOwnProperty(p)) {
|
|
84
|
+
var route = children[p];
|
|
85
|
+
var pp = (route.path != '' && route.path != null) ? parentPath + '/' + route.path : parentPath;
|
|
86
|
+
if (pp == search && !route._loadedConfig && route.component) {
|
|
87
|
+
found = route;
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
else if (route._loadedConfig || route.children) {
|
|
91
|
+
f(route.children || route._loadedConfig.routes, pp);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
78
94
|
}
|
|
79
|
-
|
|
80
|
-
|
|
95
|
+
};
|
|
96
|
+
for (p in this.router.config) {
|
|
97
|
+
if (this.router.config.hasOwnProperty(p)) {
|
|
98
|
+
route = this.router.config[p];
|
|
99
|
+
if (route.path === search && route.component) {
|
|
100
|
+
found = route;
|
|
101
|
+
}
|
|
102
|
+
else if (route['_loadedConfig'] || route.children) {
|
|
103
|
+
f(route.children || route['_loadedConfig'].routes, route.path);
|
|
104
|
+
}
|
|
105
|
+
if (found)
|
|
106
|
+
break;
|
|
81
107
|
}
|
|
82
108
|
}
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
if (this.router.config.hasOwnProperty(p)) {
|
|
87
|
-
var route = this.router.config[p];
|
|
88
|
-
if (route.path === search && route.component) {
|
|
89
|
-
found = route;
|
|
90
|
-
}
|
|
91
|
-
else if (route['_loadedConfig']) {
|
|
92
|
-
f(route['_loadedConfig'].routes, route.path);
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
return found;
|
|
109
|
+
return [2 /*return*/, found];
|
|
110
|
+
});
|
|
111
|
+
});
|
|
97
112
|
};
|
|
98
113
|
AXRenderService.ctorParameters = function () { return [
|
|
99
114
|
{ type: ApplicationRef },
|
|
100
115
|
{ type: Router },
|
|
101
116
|
{ type: ComponentFactoryResolver },
|
|
117
|
+
{ type: Compiler },
|
|
102
118
|
{ type: AXOnDemandPreloadService },
|
|
103
119
|
{ type: Injector }
|
|
104
120
|
]; };
|
|
105
|
-
AXRenderService.ɵprov = i0.ɵɵdefineInjectable({ factory: function AXRenderService_Factory() { return new AXRenderService(i0.ɵɵinject(i0.ApplicationRef), i0.ɵɵinject(i1.Router), i0.ɵɵinject(i0.ComponentFactoryResolver), i0.ɵɵinject(i2.AXOnDemandPreloadService), i0.ɵɵinject(i0.INJECTOR)); }, token: AXRenderService, providedIn: "root" });
|
|
121
|
+
AXRenderService.ɵprov = i0.ɵɵdefineInjectable({ factory: function AXRenderService_Factory() { return new AXRenderService(i0.ɵɵinject(i0.ApplicationRef), i0.ɵɵinject(i1.Router), i0.ɵɵinject(i0.ComponentFactoryResolver), i0.ɵɵinject(i0.Compiler), i0.ɵɵinject(i2.AXOnDemandPreloadService), i0.ɵɵinject(i0.INJECTOR)); }, token: AXRenderService, providedIn: "root" });
|
|
106
122
|
AXRenderService = __decorate([
|
|
107
123
|
Injectable({ providedIn: 'root' }),
|
|
108
124
|
__metadata("design:paramtypes", [ApplicationRef,
|
|
109
125
|
Router,
|
|
110
126
|
ComponentFactoryResolver,
|
|
127
|
+
Compiler,
|
|
111
128
|
AXOnDemandPreloadService,
|
|
112
129
|
Injector])
|
|
113
130
|
], AXRenderService);
|
|
114
131
|
return AXRenderService;
|
|
115
132
|
}());
|
|
116
133
|
export { AXRenderService };
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"render.service.js","sourceRoot":"ng://@acorex/core/","sources":["lib/utils/render/render.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ApplicationRef, ComponentFactoryResolver, ComponentRef, Injectable,\r\n    Injector, EmbeddedViewRef, Type\r\n} from '@angular/core';\r\nimport { Router, Route } from '@angular/router';\r\nimport { AXOnDemandPreloadService } from './on-demand-preload-strategy.service';\r\n\r\n\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class AXRenderService {\r\n    constructor(\r\n        private appRef: ApplicationRef,\r\n        private router: Router,\r\n        private componentFactoryResolver: ComponentFactoryResolver,\r\n        private modulePreloadService: AXOnDemandPreloadService,\r\n        private injector: Injector) {\r\n    }\r\n\r\n\r\n\r\n    appendComponent<T>(\r\n        componentClass: Type<T>,\r\n        options: any = {},\r\n        location?: Element): ComponentRef<any> {\r\n\r\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(componentClass);\r\n        const componentRef = componentFactory.create(this.injector);\r\n        this.appRef.attachView(componentRef.hostView);\r\n        Object.assign(componentRef.instance, options);\r\n        //\r\n        const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\r\n        componentRef.onDestroy(() => {\r\n            this.appRef.detachView(componentRef.hostView);\r\n        });\r\n        if (location) {\r\n            location.appendChild(domElem);\r\n        } else {\r\n            document.body.appendChild(domElem);\r\n        }\r\n        setTimeout(() => {\r\n            componentRef.changeDetectorRef.detectChanges();\r\n        }, 0);\r\n        return componentRef;\r\n    }\r\n\r\n    findLoadedComponentByRoute(path: string, timeoutTime: number = 10): Promise<Route> {\r\n        const delay = 200;\r\n        const loop = timeoutTime * 1000 / delay;\r\n        return new Promise((resolve, reject) => {\r\n            let found: Route = null;\r\n            let preload: boolean = false;\r\n            const theLoop = (i) => {\r\n                setTimeout(() => {\r\n                    found = this._findLoadedComponentByRoute(path);\r\n                    if (--i && found == null) {\r\n                        if (!preload) {\r\n                            this.modulePreloadService.startPreload(path);\r\n                            preload = true;\r\n                        }\r\n                        theLoop(i);\r\n                    }\r\n                    else if (found) {\r\n                        resolve(found);\r\n                    }\r\n                    else {\r\n                        reject();\r\n                    }\r\n                }, delay);\r\n            };\r\n            theLoop(loop);\r\n        });\r\n    }\r\n\r\n    private _findLoadedComponentByRoute(search) {\r\n        let found: Route = null;\r\n        const f = (list, path) => {\r\n            for (const p in list) {\r\n                if (list.hasOwnProperty(p)) {\r\n                    const route = list[p];\r\n                    const pp = (route.path != '' && route.path != null) ? path + '/' + route.path : path;\r\n                    if (pp == search && !route._loadedConfig && route.component) {\r\n                        found = route;\r\n                        break;\r\n                    } else if (route._loadedConfig) {\r\n                        f(route._loadedConfig.routes, pp);\r\n                    }\r\n                }\r\n            }\r\n        };\r\n\r\n        for (const p in this.router.config) {\r\n            if (this.router.config.hasOwnProperty(p)) {\r\n                const route = this.router.config[p];\r\n                if (route.path === search && route.component) {\r\n                    found = route;\r\n                }\r\n                else if (route['_loadedConfig']) {\r\n                    f(route['_loadedConfig'].routes, route.path);\r\n                }\r\n\r\n            }\r\n        }\r\n        return found;\r\n    }\r\n\r\n}\r\n"]}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"render.service.js","sourceRoot":"ng://@acorex/core/","sources":["lib/utils/render/render.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ApplicationRef, ComponentFactoryResolver, ComponentRef, Injectable,\r\n    Injector, EmbeddedViewRef, Type, Compiler, NgModuleFactory\r\n} from '@angular/core';\r\nimport { Router, Route } from '@angular/router';\r\nimport { AXOnDemandPreloadService } from './on-demand-preload-strategy.service';\r\n\r\n\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class AXRenderService {\r\n    constructor(\r\n        private appRef: ApplicationRef,\r\n        private router: Router,\r\n        private componentFactoryResolver: ComponentFactoryResolver,\r\n        private compiler: Compiler,\r\n        private modulePreloadService: AXOnDemandPreloadService,\r\n        private injector: Injector) {\r\n    }\r\n\r\n\r\n\r\n    appendComponent<T>(\r\n        componentClass: Type<T>,\r\n        options: any = {},\r\n        location?: Element): ComponentRef<any> {\r\n\r\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(componentClass);\r\n        const componentRef = componentFactory.create(this.injector);\r\n        this.appRef.attachView(componentRef.hostView);\r\n        Object.assign(componentRef.instance, options);\r\n        //\r\n        const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\r\n        componentRef.onDestroy(() => {\r\n            this.appRef.detachView(componentRef.hostView);\r\n        });\r\n        if (location) {\r\n            location.appendChild(domElem);\r\n        } else {\r\n            document.body.appendChild(domElem);\r\n        }\r\n        setTimeout(() => {\r\n            componentRef.changeDetectorRef.detectChanges();\r\n        }, 0);\r\n        return componentRef;\r\n    }\r\n\r\n    findLoadedComponentByRoute(path: string, timeoutTime: number = 10): Promise<Route> {\r\n        const delay = 200;\r\n        const loop = timeoutTime * 1000 / delay;\r\n        return new Promise((resolve, reject) => {\r\n            let found: Route = null;\r\n            let preload: boolean = false;\r\n            const theLoop = (i) => {\r\n                setTimeout(async () => {\r\n                    found = await this._findLoadedComponentByRoute(path);\r\n                    if (--i && found == null) {\r\n                        if (!preload) {\r\n                            this.modulePreloadService.startPreload(path);\r\n                            preload = true;\r\n                        }\r\n                        theLoop(i);\r\n                    }\r\n                    else if (found) {\r\n                        resolve(found);\r\n                    }\r\n                    else {\r\n                        reject();\r\n                    }\r\n                }, delay);\r\n            };\r\n            theLoop(loop);\r\n        });\r\n    }\r\n\r\n    private async _findLoadedComponentByRoute(search) {\r\n\r\n        let found: Route = null;\r\n        const f = (children, parentPath) => {\r\n            for (const p in children) {\r\n                if (children.hasOwnProperty(p)) {\r\n                    const route = children[p];\r\n                    const pp = (route.path != '' && route.path != null) ? parentPath + '/' + route.path : parentPath;\r\n                    if (pp == search && !route._loadedConfig && route.component) {\r\n                        found = route;\r\n                        return;\r\n                    } else if (route._loadedConfig || route.children) {\r\n                        f(route.children || route._loadedConfig.routes, pp);\r\n                    }\r\n                }\r\n            }\r\n        };\r\n\r\n        for (const p in this.router.config) {\r\n            if (this.router.config.hasOwnProperty(p)) {\r\n                const route = this.router.config[p];\r\n                if (route.path === search && route.component) {\r\n                    found = route;\r\n                }\r\n                else if (route['_loadedConfig'] || route.children) {\r\n                    f(route.children || route['_loadedConfig'].routes, route.path);\r\n                }\r\n                if (found)\r\n                    break;\r\n            }\r\n        }\r\n        return found;\r\n    }\r\n\r\n}\r\n"]}
|
package/fesm2015/acorex-core.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as moment_ from 'jalali-moment';
|
|
2
2
|
import { Subject } from 'rxjs';
|
|
3
|
-
import { EventEmitter, InjectionToken, Injector, ɵɵdefineInjectable, ɵɵinject, INJECTOR, Injectable, NgModule, Pipe, ApplicationRef, ComponentFactoryResolver, ElementRef, Input, HostListener, Directive } from '@angular/core';
|
|
4
|
-
import { __decorate, __metadata } from 'tslib';
|
|
3
|
+
import { EventEmitter, InjectionToken, Injector, ɵɵdefineInjectable, ɵɵinject, INJECTOR, Injectable, NgModule, Pipe, ApplicationRef, ComponentFactoryResolver, Compiler, ElementRef, Input, HostListener, Directive } from '@angular/core';
|
|
4
|
+
import { __decorate, __metadata, __awaiter } from 'tslib';
|
|
5
5
|
import { CommonModule } from '@angular/common';
|
|
6
6
|
import { HttpHeaders, HttpParams, HttpClient, HttpClientModule } from '@angular/common/http';
|
|
7
7
|
import merge from 'lodash-es/merge';
|
|
@@ -1810,10 +1810,11 @@ AXOnDemandPreloadService = __decorate([
|
|
|
1810
1810
|
], AXOnDemandPreloadService);
|
|
1811
1811
|
|
|
1812
1812
|
let AXRenderService = class AXRenderService {
|
|
1813
|
-
constructor(appRef, router, componentFactoryResolver, modulePreloadService, injector) {
|
|
1813
|
+
constructor(appRef, router, componentFactoryResolver, compiler, modulePreloadService, injector) {
|
|
1814
1814
|
this.appRef = appRef;
|
|
1815
1815
|
this.router = router;
|
|
1816
1816
|
this.componentFactoryResolver = componentFactoryResolver;
|
|
1817
|
+
this.compiler = compiler;
|
|
1817
1818
|
this.modulePreloadService = modulePreloadService;
|
|
1818
1819
|
this.injector = injector;
|
|
1819
1820
|
}
|
|
@@ -1845,8 +1846,8 @@ let AXRenderService = class AXRenderService {
|
|
|
1845
1846
|
let found = null;
|
|
1846
1847
|
let preload = false;
|
|
1847
1848
|
const theLoop = (i) => {
|
|
1848
|
-
setTimeout(() => {
|
|
1849
|
-
found = this._findLoadedComponentByRoute(path);
|
|
1849
|
+
setTimeout(() => __awaiter(this, void 0, void 0, function* () {
|
|
1850
|
+
found = yield this._findLoadedComponentByRoute(path);
|
|
1850
1851
|
if (--i && found == null) {
|
|
1851
1852
|
if (!preload) {
|
|
1852
1853
|
this.modulePreloadService.startPreload(path);
|
|
@@ -1860,55 +1861,61 @@ let AXRenderService = class AXRenderService {
|
|
|
1860
1861
|
else {
|
|
1861
1862
|
reject();
|
|
1862
1863
|
}
|
|
1863
|
-
}, delay);
|
|
1864
|
+
}), delay);
|
|
1864
1865
|
};
|
|
1865
1866
|
theLoop(loop);
|
|
1866
1867
|
});
|
|
1867
1868
|
}
|
|
1868
1869
|
_findLoadedComponentByRoute(search) {
|
|
1869
|
-
|
|
1870
|
-
|
|
1871
|
-
|
|
1872
|
-
|
|
1873
|
-
|
|
1874
|
-
|
|
1875
|
-
|
|
1870
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
1871
|
+
let found = null;
|
|
1872
|
+
const f = (children, parentPath) => {
|
|
1873
|
+
for (const p in children) {
|
|
1874
|
+
if (children.hasOwnProperty(p)) {
|
|
1875
|
+
const route = children[p];
|
|
1876
|
+
const pp = (route.path != '' && route.path != null) ? parentPath + '/' + route.path : parentPath;
|
|
1877
|
+
if (pp == search && !route._loadedConfig && route.component) {
|
|
1878
|
+
found = route;
|
|
1879
|
+
return;
|
|
1880
|
+
}
|
|
1881
|
+
else if (route._loadedConfig || route.children) {
|
|
1882
|
+
f(route.children || route._loadedConfig.routes, pp);
|
|
1883
|
+
}
|
|
1884
|
+
}
|
|
1885
|
+
}
|
|
1886
|
+
};
|
|
1887
|
+
for (const p in this.router.config) {
|
|
1888
|
+
if (this.router.config.hasOwnProperty(p)) {
|
|
1889
|
+
const route = this.router.config[p];
|
|
1890
|
+
if (route.path === search && route.component) {
|
|
1876
1891
|
found = route;
|
|
1877
|
-
break;
|
|
1878
1892
|
}
|
|
1879
|
-
else if (route.
|
|
1880
|
-
f(route._loadedConfig.routes,
|
|
1893
|
+
else if (route['_loadedConfig'] || route.children) {
|
|
1894
|
+
f(route.children || route['_loadedConfig'].routes, route.path);
|
|
1881
1895
|
}
|
|
1896
|
+
if (found)
|
|
1897
|
+
break;
|
|
1882
1898
|
}
|
|
1883
1899
|
}
|
|
1884
|
-
|
|
1885
|
-
|
|
1886
|
-
if (this.router.config.hasOwnProperty(p)) {
|
|
1887
|
-
const route = this.router.config[p];
|
|
1888
|
-
if (route.path === search && route.component) {
|
|
1889
|
-
found = route;
|
|
1890
|
-
}
|
|
1891
|
-
else if (route['_loadedConfig']) {
|
|
1892
|
-
f(route['_loadedConfig'].routes, route.path);
|
|
1893
|
-
}
|
|
1894
|
-
}
|
|
1895
|
-
}
|
|
1896
|
-
return found;
|
|
1900
|
+
return found;
|
|
1901
|
+
});
|
|
1897
1902
|
}
|
|
1898
1903
|
};
|
|
1899
1904
|
AXRenderService.ctorParameters = () => [
|
|
1900
1905
|
{ type: ApplicationRef },
|
|
1901
1906
|
{ type: Router },
|
|
1902
1907
|
{ type: ComponentFactoryResolver },
|
|
1908
|
+
{ type: Compiler },
|
|
1903
1909
|
{ type: AXOnDemandPreloadService },
|
|
1904
1910
|
{ type: Injector }
|
|
1905
1911
|
];
|
|
1906
|
-
AXRenderService.ɵprov = ɵɵdefineInjectable({ factory: function AXRenderService_Factory() { return new AXRenderService(ɵɵinject(ApplicationRef), ɵɵinject(Router), ɵɵinject(ComponentFactoryResolver), ɵɵinject(AXOnDemandPreloadService), ɵɵinject(INJECTOR)); }, token: AXRenderService, providedIn: "root" });
|
|
1912
|
+
AXRenderService.ɵprov = ɵɵdefineInjectable({ factory: function AXRenderService_Factory() { return new AXRenderService(ɵɵinject(ApplicationRef), ɵɵinject(Router), ɵɵinject(ComponentFactoryResolver), ɵɵinject(Compiler), ɵɵinject(AXOnDemandPreloadService), ɵɵinject(INJECTOR)); }, token: AXRenderService, providedIn: "root" });
|
|
1907
1913
|
AXRenderService = __decorate([
|
|
1908
1914
|
Injectable({ providedIn: 'root' }),
|
|
1909
1915
|
__metadata("design:paramtypes", [ApplicationRef,
|
|
1910
1916
|
Router,
|
|
1911
1917
|
ComponentFactoryResolver,
|
|
1918
|
+
Compiler,
|
|
1912
1919
|
AXOnDemandPreloadService,
|
|
1913
1920
|
Injector])
|
|
1914
1921
|
], AXRenderService);
|