@mediusinc/mng-commons 3.0.0-rc.1 → 3.0.0-rc.10
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 +8 -7
- package/assets/i18n/en.json +5 -1
- package/assets/i18n/sl.json +5 -1
- package/dev-scripts/version-info.js +13 -6
- package/esm2022/index.mjs +3 -1
- package/esm2022/lib/api/utils/object-serializer.util.mjs +11 -4
- package/esm2022/lib/components/action/action.component.mjs +18 -6
- package/esm2022/lib/components/action/editor/action-editor.component.mjs +83 -18
- package/esm2022/lib/components/action/models/action-execution.model.mjs +14 -37
- package/esm2022/lib/components/action/route/action-route.component.mjs +9 -2
- package/esm2022/lib/components/form/autocomplete/autocomplete.component.mjs +18 -5
- package/esm2022/lib/components/form/dropdown/dropdown.component.mjs +21 -8
- package/esm2022/lib/components/form/editor/form-editor.component.mjs +9 -8
- package/esm2022/lib/components/form/formly/fields/formly-field-action/formly-field-action.component.mjs +22 -4
- package/esm2022/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.mjs +43 -15
- package/esm2022/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +11 -4
- package/esm2022/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +8 -6
- package/esm2022/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +16 -7
- package/esm2022/lib/components/form/models/field-action-context.model.mjs +1 -1
- package/esm2022/lib/components/form/models/index.mjs +2 -1
- package/esm2022/lib/components/tableview/table/table.component.mjs +57 -55
- package/esm2022/lib/descriptors/action/action-button.descriptor.mjs +10 -2
- package/esm2022/lib/descriptors/action/action.descriptor.mjs +19 -8
- package/esm2022/lib/descriptors/editor/editor.descriptor.mjs +3 -3
- package/esm2022/lib/descriptors/editor/field.descriptor.mjs +13 -4
- package/esm2022/lib/descriptors/filter/filter.descriptor.mjs +7 -6
- package/esm2022/lib/descriptors/table/column.descriptor.mjs +3 -3
- package/esm2022/lib/descriptors/table/table.descriptor.mjs +35 -4
- package/esm2022/lib/descriptors/tableview/tableview.descriptor.mjs +3 -3
- package/esm2022/lib/error/error.handler.mjs +20 -0
- package/esm2022/lib/error/index.mjs +2 -0
- package/esm2022/lib/guards/index.mjs +2 -0
- package/esm2022/lib/guards/unsaved-changes.guard.mjs +4 -0
- package/esm2022/lib/models/action-editor.model.mjs +2 -0
- package/esm2022/lib/models/can-component-deactivate.model.mjs +2 -0
- package/esm2022/lib/models/config.model.mjs +1 -1
- package/esm2022/lib/models/error.model.mjs +44 -2
- package/esm2022/lib/models/index.mjs +4 -2
- package/esm2022/lib/models/log.model.mjs +10 -0
- package/esm2022/lib/models/version.model.mjs +1 -1
- package/esm2022/lib/pipes/json-path.pipe.mjs +8 -4
- package/esm2022/lib/provide-commons.mjs +22 -16
- package/esm2022/lib/router/route-builder.mjs +4 -4
- package/esm2022/lib/router/routes-builder.mjs +3 -3
- package/esm2022/lib/router/tableview-route-builder.mjs +4 -1
- package/esm2022/lib/security/authorization.service.mjs +5 -4
- package/esm2022/lib/security/authorization.util.mjs +3 -3
- package/esm2022/lib/services/action-error-mapper.service.mjs +20 -0
- package/esm2022/lib/services/action-executor.service.mjs +97 -57
- package/esm2022/lib/services/commons.service.mjs +16 -25
- package/esm2022/lib/services/configuration.service.mjs +56 -32
- package/esm2022/lib/services/index.mjs +4 -2
- package/esm2022/lib/services/internal/commons-init.service.mjs +49 -23
- package/esm2022/lib/services/log-publisher-console.service.mjs +40 -0
- package/esm2022/lib/services/logger.service.mjs +130 -0
- package/esm2022/lib/services/providers/index.mjs +1 -2
- package/esm2022/lib/services/router.service.mjs +106 -25
- package/esm2022/lib/services/tokens/index.mjs +2 -1
- package/esm2022/lib/services/tokens/log-publisher.token.mjs +3 -0
- package/esm2022/lib/services/version.service.mjs +7 -2
- package/esm2022/lib/utils/action-data-provider.util.mjs +7 -7
- package/esm2022/lib/utils/editor-formly.util.mjs +2 -1
- package/esm2022/lib/utils/error.util.mjs +247 -0
- package/esm2022/lib/utils/i18n.util.mjs +7 -9
- package/esm2022/lib/utils/index.mjs +2 -1
- package/esm2022/lib/utils/notification.util.mjs +3 -2
- package/esm2022/lib/utils/object.util.mjs +32 -5
- package/esm2022/lib/utils/route.util.mjs +3 -3
- package/esm2022/lib/utils/string.util.mjs +33 -2
- package/esm2022/lib/utils/tableview.util.mjs +3 -3
- package/esm2022/lib/utils/type.util.mjs +5 -5
- package/fesm2022/mediusinc-mng-commons.mjs +4352 -3484
- package/fesm2022/mediusinc-mng-commons.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/lib/api/utils/object-serializer.util.d.ts +1 -0
- package/lib/components/action/action.component.d.ts +1 -0
- package/lib/components/action/editor/action-editor.component.d.ts +17 -6
- package/lib/components/action/models/action-execution.model.d.ts +6 -4
- package/lib/components/action/route/action-route.component.d.ts +4 -1
- package/lib/components/form/autocomplete/autocomplete.component.d.ts +1 -0
- package/lib/components/form/dropdown/dropdown.component.d.ts +1 -0
- package/lib/components/form/editor/form-editor.component.d.ts +1 -0
- package/lib/components/form/formly/fields/formly-field-action/formly-field-action.component.d.ts +3 -0
- package/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.d.ts +2 -0
- package/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.d.ts +1 -0
- package/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.d.ts +1 -0
- package/lib/components/form/models/field-action-context.model.d.ts +7 -0
- package/lib/components/form/models/index.d.ts +1 -0
- package/lib/components/tableview/table/table.component.d.ts +2 -0
- package/lib/descriptors/action/action-button.descriptor.d.ts +4 -1
- package/lib/descriptors/action/action.descriptor.d.ts +3 -0
- package/lib/descriptors/editor/field.descriptor.d.ts +10 -8
- package/lib/descriptors/table/column.descriptor.d.ts +1 -1
- package/lib/descriptors/table/table.descriptor.d.ts +26 -3
- package/lib/error/error.handler.d.ts +6 -0
- package/lib/error/index.d.ts +1 -0
- package/lib/guards/index.d.ts +1 -0
- package/lib/guards/unsaved-changes.guard.d.ts +3 -0
- package/lib/models/action-editor.model.d.ts +4 -0
- package/lib/models/can-component-deactivate.model.d.ts +4 -0
- package/lib/models/config.model.d.ts +2 -1
- package/lib/models/error.model.d.ts +44 -8
- package/lib/models/index.d.ts +3 -1
- package/lib/models/log.model.d.ts +40 -0
- package/lib/models/version.model.d.ts +1 -1
- package/lib/pipes/json-path.pipe.d.ts +1 -0
- package/lib/security/authorization.service.d.ts +1 -0
- package/lib/services/action-error-mapper.service.d.ts +18 -0
- package/lib/services/action-executor.service.d.ts +12 -6
- package/lib/services/commons.service.d.ts +9 -14
- package/lib/services/configuration.service.d.ts +13 -5
- package/lib/services/index.d.ts +3 -1
- package/lib/services/internal/commons-init.service.d.ts +8 -8
- package/lib/services/log-publisher-console.service.d.ts +4 -0
- package/lib/services/logger.service.d.ts +33 -0
- package/lib/services/providers/index.d.ts +0 -1
- package/lib/services/router.service.d.ts +17 -2
- package/lib/services/tokens/index.d.ts +1 -0
- package/lib/services/tokens/log-publisher.token.d.ts +3 -0
- package/lib/services/version.service.d.ts +1 -0
- package/lib/utils/error.util.d.ts +116 -0
- package/lib/utils/i18n.util.d.ts +3 -3
- package/lib/utils/index.d.ts +1 -0
- package/lib/utils/notification.util.d.ts +2 -2
- package/lib/utils/object.util.d.ts +6 -4
- package/lib/utils/string.util.d.ts +5 -0
- package/package.json +4 -1
- package/scss/common/theme/designer/_components.scss +1 -1
- package/scss/mng-overrides/_theme_dialog.scss +7 -0
- package/scss/mng-overrides/_theme_tableview.scss +15 -0
- package/esm2022/lib/models/error-internal.model.mjs +0 -27
- package/esm2022/lib/services/error-mapper.service.mjs +0 -14
- package/esm2022/lib/services/providers/config-service.provider.mjs +0 -31
- package/lib/models/error-internal.model.d.ts +0 -29
- package/lib/services/error-mapper.service.d.ts +0 -7
- package/lib/services/providers/config-service.provider.d.ts +0 -6
|
@@ -1,37 +1,68 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { HttpClient } from '@angular/common/http';
|
|
2
|
+
import { Injectable, inject } from '@angular/core';
|
|
3
3
|
import { combineLatest, mergeMap, of } from 'rxjs';
|
|
4
4
|
import { map } from 'rxjs/operators';
|
|
5
|
-
import { MngCommonsService, MngConfigurationService, MngRouterService } from '../';
|
|
6
|
-
import { MNG_COMMONS_INITIALIZER_IT } from '../tokens';
|
|
5
|
+
import { MngCommonsService, MngConfigurationService, MngLoggerService, MngRouterService } from '../';
|
|
6
|
+
import { MNG_COMMONS_INITIALIZER_IT, MNG_LOG_PUBLISHERS, MNG_MODULE_CONFIG_IT } from '../tokens';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "@ngx-translate/core";
|
|
9
|
-
import * as i2 from "../";
|
|
10
8
|
export class MngCommonsInitService {
|
|
11
|
-
constructor(
|
|
12
|
-
this.
|
|
13
|
-
this.
|
|
14
|
-
this.
|
|
15
|
-
this.
|
|
16
|
-
this.
|
|
9
|
+
constructor() {
|
|
10
|
+
this.httpClient = inject(HttpClient);
|
|
11
|
+
this.logger = inject(MngLoggerService);
|
|
12
|
+
this.logPublishers = inject(MNG_LOG_PUBLISHERS, { optional: true });
|
|
13
|
+
this.config = inject(MngConfigurationService);
|
|
14
|
+
this.mngCommons = inject(MngCommonsService);
|
|
15
|
+
this.mngRouter = inject(MngRouterService);
|
|
16
|
+
this.moduleConfig = inject(MNG_MODULE_CONFIG_IT, { optional: true });
|
|
17
|
+
this.commonsInitializers = inject(MNG_COMMONS_INITIALIZER_IT, { optional: true });
|
|
17
18
|
this.isInitialized = false;
|
|
18
19
|
}
|
|
19
20
|
initialize() {
|
|
20
21
|
if (this.isInitialized) {
|
|
21
22
|
return of(void 0);
|
|
22
23
|
}
|
|
24
|
+
this.isInitialized = true;
|
|
25
|
+
MngLoggerService.configure({ timestampFormat: this.moduleConfig?.log?.timestampFormat });
|
|
26
|
+
const ctxLogger = this.logger.create('MngCommonsInitService');
|
|
27
|
+
ctxLogger.debug('Commons initialization is starting');
|
|
28
|
+
// init router
|
|
23
29
|
this.mngRouter.initialize();
|
|
24
|
-
|
|
30
|
+
// init configurations with settings from module config
|
|
31
|
+
this.config.init(this.httpClient, this.logger);
|
|
32
|
+
this.config.addModuleConfigSource(this.moduleConfig ?? undefined);
|
|
33
|
+
if (this.moduleConfig?.configuration?.projectEnvironment) {
|
|
34
|
+
this.config.addEnvironmentSource(this.moduleConfig.configuration.projectEnvironment);
|
|
35
|
+
}
|
|
36
|
+
// init configurations with settings from module config for json source
|
|
37
|
+
if (!(this.moduleConfig?.configuration?.skipJsonSourceInit ?? false)) {
|
|
38
|
+
const jsonSourceEnableEnvProd = this.moduleConfig?.configuration?.jsonSourceEnableEnvProd ?? false;
|
|
39
|
+
const jsonSource = this.moduleConfig?.configuration?.jsonSource;
|
|
40
|
+
if (!jsonSource) {
|
|
41
|
+
this.config.addJsonSource({ enableEnvProd: jsonSourceEnableEnvProd });
|
|
42
|
+
}
|
|
43
|
+
else if (Array.isArray(jsonSource)) {
|
|
44
|
+
jsonSource.forEach(source => this.config.addJsonSource({ url: source, enableEnvProd: jsonSourceEnableEnvProd }));
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
this.config.addJsonSource({ url: jsonSource, enableEnvProd: jsonSourceEnableEnvProd });
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return this.config.loadJsonConfigurations().pipe(mergeMap(() => {
|
|
51
|
+
// init logger
|
|
52
|
+
MngLoggerService.init(this.config, this.logPublishers ?? []);
|
|
25
53
|
if (this.commonsInitializers) {
|
|
54
|
+
ctxLogger.debug('Project initializers are being initialized');
|
|
26
55
|
return combineLatest(this.commonsInitializers.map(ci => ci())).pipe(map(res => res));
|
|
27
56
|
}
|
|
28
57
|
else {
|
|
29
58
|
return of(true);
|
|
30
59
|
}
|
|
31
|
-
}), map(() =>
|
|
32
|
-
|
|
60
|
+
}), map(() => {
|
|
61
|
+
ctxLogger.debug('Commons initialization is finished');
|
|
62
|
+
return this.mngCommons.reset();
|
|
63
|
+
}));
|
|
33
64
|
}
|
|
34
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: MngCommonsInitService, deps: [
|
|
65
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: MngCommonsInitService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
35
66
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: MngCommonsInitService, providedIn: 'root' }); }
|
|
36
67
|
}
|
|
37
68
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: MngCommonsInitService, decorators: [{
|
|
@@ -39,10 +70,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
|
|
|
39
70
|
args: [{
|
|
40
71
|
providedIn: 'root'
|
|
41
72
|
}]
|
|
42
|
-
}]
|
|
43
|
-
|
|
44
|
-
args: [MNG_COMMONS_INITIALIZER_IT]
|
|
45
|
-
}, {
|
|
46
|
-
type: Optional
|
|
47
|
-
}] }]; } });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9ucy1pbml0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL2ludGVybmFsL2NvbW1vbnMtaW5pdC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxNQUFNLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUUzRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUNyRCxPQUFPLEVBQWEsYUFBYSxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUMsTUFBTSxNQUFNLENBQUM7QUFDN0QsT0FBTyxFQUFDLEdBQUcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBRW5DLE9BQU8sRUFBQyxpQkFBaUIsRUFBRSx1QkFBdUIsRUFBRSxnQkFBZ0IsRUFBQyxNQUFNLEtBQUssQ0FBQztBQUNqRixPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSxXQUFXLENBQUM7Ozs7QUFLckQsTUFBTSxPQUFPLHFCQUFxQjtJQUc5QixZQUNZLFNBQTJCLEVBQzNCLG9CQUE2QyxFQUM3QyxVQUE2QixFQUM3QixTQUEyQixFQUM4QixtQkFBNkQ7UUFKdEgsY0FBUyxHQUFULFNBQVMsQ0FBa0I7UUFDM0IseUJBQW9CLEdBQXBCLG9CQUFvQixDQUF5QjtRQUM3QyxlQUFVLEdBQVYsVUFBVSxDQUFtQjtRQUM3QixjQUFTLEdBQVQsU0FBUyxDQUFrQjtRQUM4Qix3QkFBbUIsR0FBbkIsbUJBQW1CLENBQTBDO1FBUDFILGtCQUFhLEdBQUcsS0FBSyxDQUFDO0lBUTNCLENBQUM7SUFFRyxVQUFVO1FBQ2IsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3BCLE9BQU8sRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDckI7UUFFRCxJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBRTVCLE9BQU8sSUFBSSxDQUFDLG9CQUFvQixDQUFDLHNCQUFzQixFQUFFLENBQUMsSUFBSSxDQUMxRCxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ1YsSUFBSSxJQUFJLENBQUMsbUJBQW1CLEVBQUU7Z0JBQzFCLE9BQU8sYUFBYSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7YUFDeEY7aUJBQU07Z0JBQ0gsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUM7YUFDbkI7UUFDTCxDQUFDLENBQUMsRUFDRixHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUNyQyxDQUFDO1FBRUYsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUM7SUFDOUIsQ0FBQzs4R0E5QlEscUJBQXFCLDBKQVFsQiwwQkFBMEI7a0hBUjdCLHFCQUFxQixjQUZsQixNQUFNOzsyRkFFVCxxQkFBcUI7a0JBSGpDLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCOzswQkFTUSxNQUFNOzJCQUFDLDBCQUEwQjs7MEJBQUcsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0LCBJbmplY3RhYmxlLCBPcHRpb25hbH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7VHJhbnNsYXRlU2VydmljZX0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQge09ic2VydmFibGUsIGNvbWJpbmVMYXRlc3QsIG1lcmdlTWFwLCBvZn0gZnJvbSAncnhqcyc7XG5pbXBvcnQge21hcH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQge01uZ0NvbW1vbnNTZXJ2aWNlLCBNbmdDb25maWd1cmF0aW9uU2VydmljZSwgTW5nUm91dGVyU2VydmljZX0gZnJvbSAnLi4vJztcbmltcG9ydCB7TU5HX0NPTU1PTlNfSU5JVElBTElaRVJfSVR9IGZyb20gJy4uL3Rva2Vucyc7XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgTW5nQ29tbW9uc0luaXRTZXJ2aWNlIHtcbiAgICBwcml2YXRlIGlzSW5pdGlhbGl6ZWQgPSBmYWxzZTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIHRyYW5zbGF0ZTogVHJhbnNsYXRlU2VydmljZSxcbiAgICAgICAgcHJpdmF0ZSBjb25maWd1cmF0aW9uU2VydmljZTogTW5nQ29uZmlndXJhdGlvblNlcnZpY2UsXG4gICAgICAgIHByaXZhdGUgbW5nQ29tbW9uczogTW5nQ29tbW9uc1NlcnZpY2UsXG4gICAgICAgIHByaXZhdGUgbW5nUm91dGVyOiBNbmdSb3V0ZXJTZXJ2aWNlLFxuICAgICAgICBASW5qZWN0KE1OR19DT01NT05TX0lOSVRJQUxJWkVSX0lUKSBAT3B0aW9uYWwoKSBwcml2YXRlIHJlYWRvbmx5IGNvbW1vbnNJbml0aWFsaXplcnM6IFJlYWRvbmx5QXJyYXk8KCkgPT4gT2JzZXJ2YWJsZTx1bmtub3duPj5cbiAgICApIHt9XG5cbiAgICBwdWJsaWMgaW5pdGlhbGl6ZSgpOiBPYnNlcnZhYmxlPHZvaWQ+IHtcbiAgICAgICAgaWYgKHRoaXMuaXNJbml0aWFsaXplZCkge1xuICAgICAgICAgICAgcmV0dXJuIG9mKHZvaWQgMCk7XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLm1uZ1JvdXRlci5pbml0aWFsaXplKCk7XG5cbiAgICAgICAgcmV0dXJuIHRoaXMuY29uZmlndXJhdGlvblNlcnZpY2UubG9hZEpzb25Db25maWd1cmF0aW9ucygpLnBpcGUoXG4gICAgICAgICAgICBtZXJnZU1hcCgoKSA9PiB7XG4gICAgICAgICAgICAgICAgaWYgKHRoaXMuY29tbW9uc0luaXRpYWxpemVycykge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4gY29tYmluZUxhdGVzdCh0aGlzLmNvbW1vbnNJbml0aWFsaXplcnMubWFwKGNpID0+IGNpKCkpKS5waXBlKG1hcChyZXMgPT4gcmVzKSk7XG4gICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIG9mKHRydWUpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgbWFwKCgpID0+IHRoaXMubW5nQ29tbW9ucy5yZXNldCgpKVxuICAgICAgICApO1xuXG4gICAgICAgIHRoaXMuaXNJbml0aWFsaXplZCA9IHRydWU7XG4gICAgfVxufVxuIl19
|
|
73
|
+
}] });
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commons-init.service.js","sourceRoot":"","sources":["../../../../../src/lib/services/internal/commons-init.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {HttpClient} from '@angular/common/http';\nimport {Injectable, inject} from '@angular/core';\n\nimport {Observable, combineLatest, mergeMap, of} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {MngCommonsService, MngConfigurationService, MngLoggerService, MngRouterService} from '../';\nimport {MNG_COMMONS_INITIALIZER_IT, MNG_LOG_PUBLISHERS, MNG_MODULE_CONFIG_IT} from '../tokens';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class MngCommonsInitService {\n    private readonly httpClient = inject(HttpClient);\n    private readonly logger = inject(MngLoggerService);\n    private readonly logPublishers = inject(MNG_LOG_PUBLISHERS, {optional: true});\n    private readonly config = inject(MngConfigurationService);\n    private readonly mngCommons = inject(MngCommonsService);\n    private readonly mngRouter = inject(MngRouterService);\n    private readonly moduleConfig = inject(MNG_MODULE_CONFIG_IT, {optional: true});\n    private readonly commonsInitializers = inject(MNG_COMMONS_INITIALIZER_IT, {optional: true});\n\n    private isInitialized = false;\n\n    public initialize(): Observable<void> {\n        if (this.isInitialized) {\n            return of(void 0);\n        }\n        this.isInitialized = true;\n\n        MngLoggerService.configure({timestampFormat: this.moduleConfig?.log?.timestampFormat});\n\n        const ctxLogger = this.logger.create('MngCommonsInitService');\n        ctxLogger.debug('Commons initialization is starting');\n\n        // init router\n        this.mngRouter.initialize();\n\n        // init configurations with settings from module config\n        this.config.init(this.httpClient, this.logger);\n        this.config.addModuleConfigSource(this.moduleConfig ?? undefined);\n        if (this.moduleConfig?.configuration?.projectEnvironment) {\n            this.config.addEnvironmentSource(this.moduleConfig.configuration.projectEnvironment);\n        }\n\n        // init configurations with settings from module config for json source\n        if (!(this.moduleConfig?.configuration?.skipJsonSourceInit ?? false)) {\n            const jsonSourceEnableEnvProd = this.moduleConfig?.configuration?.jsonSourceEnableEnvProd ?? false;\n            const jsonSource = this.moduleConfig?.configuration?.jsonSource;\n            if (!jsonSource) {\n                this.config.addJsonSource({enableEnvProd: jsonSourceEnableEnvProd});\n            } else if (Array.isArray(jsonSource)) {\n                jsonSource.forEach(source => this.config.addJsonSource({url: source, enableEnvProd: jsonSourceEnableEnvProd}));\n            } else {\n                this.config.addJsonSource({url: jsonSource, enableEnvProd: jsonSourceEnableEnvProd});\n            }\n        }\n\n        return this.config.loadJsonConfigurations().pipe(\n            mergeMap(() => {\n                // init logger\n                MngLoggerService.init(this.config, this.logPublishers ?? []);\n\n                if (this.commonsInitializers) {\n                    ctxLogger.debug('Project initializers are being initialized');\n                    return combineLatest(this.commonsInitializers.map(ci => ci())).pipe(map(res => res));\n                } else {\n                    return of(true);\n                }\n            }),\n            map(() => {\n                ctxLogger.debug('Commons initialization is finished');\n                return this.mngCommons.reset();\n            })\n        );\n    }\n}\n"]}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/* eslint-disable no-console */
|
|
2
|
+
import { LogLevelEnum } from '../models';
|
|
3
|
+
import { ErrorUtil } from '../utils';
|
|
4
|
+
export class MngLogPublisherConsoleService {
|
|
5
|
+
addEntry(entry) {
|
|
6
|
+
let prefix = `${entry.timestampFormatted}`;
|
|
7
|
+
if (entry.category)
|
|
8
|
+
prefix += ` [${entry.category}]`;
|
|
9
|
+
prefix += ':';
|
|
10
|
+
const message = `${entry.message}${entry.messageDetails ? `\n${entry.messageDetails}` : ''}`;
|
|
11
|
+
const logParams = [prefix, message];
|
|
12
|
+
if (entry.error) {
|
|
13
|
+
logParams.push(`\n${ErrorUtil.getErrorName(entry.error)}:`, entry.error);
|
|
14
|
+
}
|
|
15
|
+
if (entry.data?.length) {
|
|
16
|
+
logParams.push(`\nData:\n`, ...entry.data);
|
|
17
|
+
}
|
|
18
|
+
switch (entry.level) {
|
|
19
|
+
case LogLevelEnum.Trace:
|
|
20
|
+
console.trace(...logParams);
|
|
21
|
+
break;
|
|
22
|
+
case LogLevelEnum.Debug:
|
|
23
|
+
console.debug(...logParams);
|
|
24
|
+
break;
|
|
25
|
+
case LogLevelEnum.Log:
|
|
26
|
+
console.log(...logParams);
|
|
27
|
+
break;
|
|
28
|
+
case LogLevelEnum.Info:
|
|
29
|
+
console.info(...logParams);
|
|
30
|
+
break;
|
|
31
|
+
case LogLevelEnum.Warning:
|
|
32
|
+
console.warn(...logParams);
|
|
33
|
+
break;
|
|
34
|
+
case LogLevelEnum.Error:
|
|
35
|
+
console.error(...logParams);
|
|
36
|
+
break;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nLXB1Ymxpc2hlci1jb25zb2xlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL2xvZy1wdWJsaXNoZXItY29uc29sZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLCtCQUErQjtBQUMvQixPQUFPLEVBQW1CLFlBQVksRUFBYyxNQUFNLFdBQVcsQ0FBQztBQUN0RSxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sVUFBVSxDQUFDO0FBRW5DLE1BQU0sT0FBTyw2QkFBNkI7SUFDdEMsUUFBUSxDQUFDLEtBQWtCO1FBQ3ZCLElBQUksTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLGtCQUFrQixFQUFFLENBQUM7UUFDM0MsSUFBSSxLQUFLLENBQUMsUUFBUTtZQUFFLE1BQU0sSUFBSSxLQUFLLEtBQUssQ0FBQyxRQUFRLEdBQUcsQ0FBQztRQUNyRCxNQUFNLElBQUksR0FBRyxDQUFDO1FBRWQsTUFBTSxPQUFPLEdBQUcsR0FBRyxLQUFLLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLEtBQUssS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUM3RixNQUFNLFNBQVMsR0FBVSxDQUFDLE1BQU0sRUFBRSxPQUFPLENBQUMsQ0FBQztRQUMzQyxJQUFJLEtBQUssQ0FBQyxLQUFLLEVBQUU7WUFDYixTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssU0FBUyxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDNUU7UUFDRCxJQUFJLEtBQUssQ0FBQyxJQUFJLEVBQUUsTUFBTSxFQUFFO1lBQ3BCLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQzlDO1FBRUQsUUFBUSxLQUFLLENBQUMsS0FBSyxFQUFFO1lBQ2pCLEtBQUssWUFBWSxDQUFDLEtBQUs7Z0JBQ25CLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxTQUFTLENBQUMsQ0FBQztnQkFDNUIsTUFBTTtZQUNWLEtBQUssWUFBWSxDQUFDLEtBQUs7Z0JBQ25CLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxTQUFTLENBQUMsQ0FBQztnQkFDNUIsTUFBTTtZQUNWLEtBQUssWUFBWSxDQUFDLEdBQUc7Z0JBQ2pCLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxTQUFTLENBQUMsQ0FBQztnQkFDMUIsTUFBTTtZQUNWLEtBQUssWUFBWSxDQUFDLElBQUk7Z0JBQ2xCLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxTQUFTLENBQUMsQ0FBQztnQkFDM0IsTUFBTTtZQUNWLEtBQUssWUFBWSxDQUFDLE9BQU87Z0JBQ3JCLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxTQUFTLENBQUMsQ0FBQztnQkFDM0IsTUFBTTtZQUNWLEtBQUssWUFBWSxDQUFDLEtBQUs7Z0JBQ25CLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxTQUFTLENBQUMsQ0FBQztnQkFDNUIsTUFBTTtTQUNiO0lBQ0wsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tY29uc29sZSAqL1xuaW1wb3J0IHtJTW5nTG9nUHVibGlzaGVyLCBMb2dMZXZlbEVudW0sIE1uZ0xvZ0VudHJ5fSBmcm9tICcuLi9tb2RlbHMnO1xuaW1wb3J0IHtFcnJvclV0aWx9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGNsYXNzIE1uZ0xvZ1B1Ymxpc2hlckNvbnNvbGVTZXJ2aWNlIGltcGxlbWVudHMgSU1uZ0xvZ1B1Ymxpc2hlciB7XG4gICAgYWRkRW50cnkoZW50cnk6IE1uZ0xvZ0VudHJ5KTogdm9pZCB7XG4gICAgICAgIGxldCBwcmVmaXggPSBgJHtlbnRyeS50aW1lc3RhbXBGb3JtYXR0ZWR9YDtcbiAgICAgICAgaWYgKGVudHJ5LmNhdGVnb3J5KSBwcmVmaXggKz0gYCBbJHtlbnRyeS5jYXRlZ29yeX1dYDtcbiAgICAgICAgcHJlZml4ICs9ICc6JztcblxuICAgICAgICBjb25zdCBtZXNzYWdlID0gYCR7ZW50cnkubWVzc2FnZX0ke2VudHJ5Lm1lc3NhZ2VEZXRhaWxzID8gYFxcbiR7ZW50cnkubWVzc2FnZURldGFpbHN9YCA6ICcnfWA7XG4gICAgICAgIGNvbnN0IGxvZ1BhcmFtczogYW55W10gPSBbcHJlZml4LCBtZXNzYWdlXTtcbiAgICAgICAgaWYgKGVudHJ5LmVycm9yKSB7XG4gICAgICAgICAgICBsb2dQYXJhbXMucHVzaChgXFxuJHtFcnJvclV0aWwuZ2V0RXJyb3JOYW1lKGVudHJ5LmVycm9yKX06YCwgZW50cnkuZXJyb3IpO1xuICAgICAgICB9XG4gICAgICAgIGlmIChlbnRyeS5kYXRhPy5sZW5ndGgpIHtcbiAgICAgICAgICAgIGxvZ1BhcmFtcy5wdXNoKGBcXG5EYXRhOlxcbmAsIC4uLmVudHJ5LmRhdGEpO1xuICAgICAgICB9XG5cbiAgICAgICAgc3dpdGNoIChlbnRyeS5sZXZlbCkge1xuICAgICAgICAgICAgY2FzZSBMb2dMZXZlbEVudW0uVHJhY2U6XG4gICAgICAgICAgICAgICAgY29uc29sZS50cmFjZSguLi5sb2dQYXJhbXMpO1xuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgY2FzZSBMb2dMZXZlbEVudW0uRGVidWc6XG4gICAgICAgICAgICAgICAgY29uc29sZS5kZWJ1ZyguLi5sb2dQYXJhbXMpO1xuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgY2FzZSBMb2dMZXZlbEVudW0uTG9nOlxuICAgICAgICAgICAgICAgIGNvbnNvbGUubG9nKC4uLmxvZ1BhcmFtcyk7XG4gICAgICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgICAgICBjYXNlIExvZ0xldmVsRW51bS5JbmZvOlxuICAgICAgICAgICAgICAgIGNvbnNvbGUuaW5mbyguLi5sb2dQYXJhbXMpO1xuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgY2FzZSBMb2dMZXZlbEVudW0uV2FybmluZzpcbiAgICAgICAgICAgICAgICBjb25zb2xlLndhcm4oLi4ubG9nUGFyYW1zKTtcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIGNhc2UgTG9nTGV2ZWxFbnVtLkVycm9yOlxuICAgICAgICAgICAgICAgIGNvbnNvbGUuZXJyb3IoLi4ubG9nUGFyYW1zKTtcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { DatePipe } from '@angular/common';
|
|
2
|
+
import { LogLevelEnum, MngInternalError } from '../models';
|
|
3
|
+
import { DateUtil } from '../utils';
|
|
4
|
+
export class MngLoggerService {
|
|
5
|
+
static { this._instance = new MngLoggerService(); }
|
|
6
|
+
static { this._isInit = false; }
|
|
7
|
+
static { this._publishers = []; }
|
|
8
|
+
static { this._entriesBuffer = []; }
|
|
9
|
+
static { this._categoryInstances = {}; }
|
|
10
|
+
static { this._timestampFormat = 'yyyy-MM-dd HH:mm:ss.SSS'; }
|
|
11
|
+
constructor() {
|
|
12
|
+
// Temporary settings that cover logging calls before initialisation
|
|
13
|
+
this.defaultLogLevel = LogLevelEnum.Info;
|
|
14
|
+
this.datePipe = new DatePipe('en-US');
|
|
15
|
+
// empty
|
|
16
|
+
}
|
|
17
|
+
static get() {
|
|
18
|
+
return MngLoggerService._instance;
|
|
19
|
+
}
|
|
20
|
+
static configure(config) {
|
|
21
|
+
if (config.timestampFormat) {
|
|
22
|
+
MngLoggerService._timestampFormat = config.timestampFormat;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
static init(configurationService, publishers) {
|
|
26
|
+
if (MngLoggerService._isInit) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
MngLoggerService._configurationService = configurationService;
|
|
30
|
+
MngLoggerService._publishers = publishers;
|
|
31
|
+
MngLoggerService._isInit = true;
|
|
32
|
+
MngLoggerService._flushBuffer();
|
|
33
|
+
}
|
|
34
|
+
static _flushBuffer() {
|
|
35
|
+
if (!MngLoggerService._isInit) {
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
MngLoggerService._entriesBuffer.forEach(e => this._instance._log(e));
|
|
39
|
+
MngLoggerService._entriesBuffer = [];
|
|
40
|
+
}
|
|
41
|
+
static create(category) {
|
|
42
|
+
return MngLoggerService._instance.create(category);
|
|
43
|
+
}
|
|
44
|
+
create(category) {
|
|
45
|
+
if (this.category) {
|
|
46
|
+
throw new MngInternalError(`Cannot create logger with category inside another category (${this.category}). Must create logger on root.`);
|
|
47
|
+
}
|
|
48
|
+
if (MngLoggerService._categoryInstances[category]) {
|
|
49
|
+
return MngLoggerService._categoryInstances[category];
|
|
50
|
+
}
|
|
51
|
+
const logger = new MngLoggerService();
|
|
52
|
+
logger.category = category;
|
|
53
|
+
MngLoggerService._categoryInstances[category] = logger;
|
|
54
|
+
return logger;
|
|
55
|
+
}
|
|
56
|
+
_processLog(msgOrError, logLevel, category = undefined, data) {
|
|
57
|
+
const [timestamp, timestampFormatted] = [...this._getTimestamps()];
|
|
58
|
+
const logEntry = {
|
|
59
|
+
level: logLevel,
|
|
60
|
+
message: typeof msgOrError === 'string' ? msgOrError : msgOrError.message,
|
|
61
|
+
data: data,
|
|
62
|
+
category: this.category ?? category,
|
|
63
|
+
timestamp: timestamp,
|
|
64
|
+
timestampFormatted: timestampFormatted ?? undefined
|
|
65
|
+
};
|
|
66
|
+
if (msgOrError instanceof Error) {
|
|
67
|
+
// set error from message param
|
|
68
|
+
logEntry.error = msgOrError;
|
|
69
|
+
}
|
|
70
|
+
else if (data?.length && data[0] instanceof Error) {
|
|
71
|
+
// if first data is error, also consider as error
|
|
72
|
+
logEntry.error = data[0];
|
|
73
|
+
logEntry.data = data.splice(1);
|
|
74
|
+
}
|
|
75
|
+
this._log(logEntry);
|
|
76
|
+
}
|
|
77
|
+
_getTimestamps() {
|
|
78
|
+
const timestamp = new Date();
|
|
79
|
+
const timestampFormatted = this.datePipe.transform(timestamp, MngLoggerService._timestampFormat) ?? DateUtil.toIsoString(timestamp, false, true, true);
|
|
80
|
+
return [timestamp, timestampFormatted];
|
|
81
|
+
}
|
|
82
|
+
_log(log) {
|
|
83
|
+
if (!MngLoggerService._isInit) {
|
|
84
|
+
// add to buffer
|
|
85
|
+
MngLoggerService._entriesBuffer.push(log);
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
const logConfig = (MngLoggerService._configurationService?.getConfigValue)?.('log');
|
|
89
|
+
if ((this.category && log.level < (logConfig?.category?.[this.category]?.level ?? logConfig?.level ?? this.defaultLogLevel)) ||
|
|
90
|
+
(!this.category && log.level < (logConfig?.level ?? this.defaultLogLevel))) {
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
if (logConfig?.timestampFormat) {
|
|
94
|
+
log.timestampFormatted = this.datePipe.transform(log.timestamp, logConfig.timestampFormat) ?? undefined;
|
|
95
|
+
}
|
|
96
|
+
MngLoggerService._publishers.forEach(p => p.addEntry(log));
|
|
97
|
+
}
|
|
98
|
+
trace(msgOrError, ...data) {
|
|
99
|
+
this._processLog(msgOrError, LogLevelEnum.Trace, undefined, data);
|
|
100
|
+
}
|
|
101
|
+
debug(msgOrError, ...data) {
|
|
102
|
+
this._processLog(msgOrError, LogLevelEnum.Debug, undefined, data);
|
|
103
|
+
}
|
|
104
|
+
log(msgOrError, logLevel = LogLevelEnum.Log, category = undefined, ...data) {
|
|
105
|
+
this._processLog(msgOrError, logLevel, category, data);
|
|
106
|
+
}
|
|
107
|
+
logEntry(logEntry) {
|
|
108
|
+
const [timestamp, timestampFormatted] = [...this._getTimestamps()];
|
|
109
|
+
const logEntryFinal = {
|
|
110
|
+
timestamp: timestamp,
|
|
111
|
+
timestampFormatted: timestampFormatted ?? undefined,
|
|
112
|
+
category: this.category ?? logEntry.category,
|
|
113
|
+
message: '',
|
|
114
|
+
messageDetails: logEntry.messageDetails,
|
|
115
|
+
level: LogLevelEnum.Log,
|
|
116
|
+
...logEntry
|
|
117
|
+
};
|
|
118
|
+
this._log(logEntryFinal);
|
|
119
|
+
}
|
|
120
|
+
info(msgOrError, ...data) {
|
|
121
|
+
this._processLog(msgOrError, LogLevelEnum.Info, undefined, data);
|
|
122
|
+
}
|
|
123
|
+
warn(msgOrError, ...data) {
|
|
124
|
+
this._processLog(msgOrError, LogLevelEnum.Warning, undefined, data);
|
|
125
|
+
}
|
|
126
|
+
error(msgOrError, ...data) {
|
|
127
|
+
this._processLog(msgOrError, LogLevelEnum.Error, undefined, data);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.service.js","sourceRoot":"","sources":["../../../../src/lib/services/logger.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AAEzC,OAAO,EAAsC,YAAY,EAAE,gBAAgB,EAA4B,MAAM,WAAW,CAAC;AACzH,OAAO,EAAC,QAAQ,EAAC,MAAM,UAAU,CAAC;AAGlC,MAAM,OAAO,gBAAgB;aACV,cAAS,GAAqB,IAAI,gBAAgB,EAAE,AAA3C,CAA4C;aACrD,YAAO,GAAG,KAAK,AAAR,CAAS;aAEhB,gBAAW,GAAuB,EAAE,AAAzB,CAA0B;aACrC,mBAAc,GAAkB,EAAE,AAApB,CAAqB;aACnC,uBAAkB,GAAqC,EAAE,AAAvC,CAAwC;aAC1D,qBAAgB,GAAG,yBAAyB,AAA5B,CAA6B;IAQ5D;QAJA,oEAAoE;QACnD,oBAAe,GAAiB,YAAY,CAAC,IAAI,CAAC;QAC3D,aAAQ,GAAG,IAAI,QAAQ,CAAC,OAAO,CAAC,CAAC;QAGrC,QAAQ;IACZ,CAAC;IAEM,MAAM,CAAC,GAAG;QACb,OAAO,gBAAgB,CAAC,SAAS,CAAC;IACtC,CAAC;IAEM,MAAM,CAAC,SAAS,CAAC,MAAkC;QACtD,IAAI,MAAM,CAAC,eAAe,EAAE;YACxB,gBAAgB,CAAC,gBAAgB,GAAG,MAAM,CAAC,eAAe,CAAC;SAC9D;IACL,CAAC;IAEM,MAAM,CAAC,IAAI,CAAC,oBAA6C,EAAE,UAA8B;QAC5F,IAAI,gBAAgB,CAAC,OAAO,EAAE;YAC1B,OAAO;SACV;QAED,gBAAgB,CAAC,qBAAqB,GAAG,oBAAoB,CAAC;QAC9D,gBAAgB,CAAC,WAAW,GAAG,UAAU,CAAC;QAE1C,gBAAgB,CAAC,OAAO,GAAG,IAAI,CAAC;QAChC,gBAAgB,CAAC,YAAY,EAAE,CAAC;IACpC,CAAC;IAEO,MAAM,CAAC,YAAY;QACvB,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE;YAC3B,OAAO;SACV;QACD,gBAAgB,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACrE,gBAAgB,CAAC,cAAc,GAAG,EAAE,CAAC;IACzC,CAAC;IAEM,MAAM,CAAC,MAAM,CAAC,QAAgB;QACjC,OAAO,gBAAgB,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACvD,CAAC;IAEM,MAAM,CAAC,QAAgB;QAC1B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,MAAM,IAAI,gBAAgB,CAAC,+DAA+D,IAAI,CAAC,QAAQ,gCAAgC,CAAC,CAAC;SAC5I;QACD,IAAI,gBAAgB,CAAC,kBAAkB,CAAC,QAAQ,CAAC,EAAE;YAC/C,OAAO,gBAAgB,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;SACxD;QAED,MAAM,MAAM,GAAG,IAAI,gBAAgB,EAAE,CAAC;QACtC,MAAM,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAE3B,gBAAgB,CAAC,kBAAkB,CAAC,QAAQ,CAAC,GAAG,MAAM,CAAC;QAEvD,OAAO,MAAM,CAAC;IAClB,CAAC;IAEO,WAAW,CAAC,UAA0B,EAAE,QAAsB,EAAE,WAA+B,SAAS,EAAE,IAAY;QAC1H,MAAM,CAAC,SAAS,EAAE,kBAAkB,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;QAEnE,MAAM,QAAQ,GAAgB;YAC1B,KAAK,EAAE,QAAQ;YACf,OAAO,EAAE,OAAO,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,OAAO;YACzE,IAAI,EAAE,IAAI;YACV,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,QAAQ;YACnC,SAAS,EAAE,SAAS;YACpB,kBAAkB,EAAE,kBAAkB,IAAI,SAAS;SACtD,CAAC;QAEF,IAAI,UAAU,YAAY,KAAK,EAAE;YAC7B,+BAA+B;YAC/B,QAAQ,CAAC,KAAK,GAAG,UAAU,CAAC;SAC/B;aAAM,IAAI,IAAI,EAAE,MAAM,IAAI,IAAI,CAAC,CAAC,CAAC,YAAY,KAAK,EAAE;YACjD,iDAAiD;YACjD,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YACzB,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;SAClC;QAED,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACxB,CAAC;IAEO,cAAc;QAClB,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC;QAC7B,MAAM,kBAAkB,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,SAAS,EAAE,gBAAgB,CAAC,gBAAgB,CAAC,IAAI,QAAQ,CAAC,WAAW,CAAC,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QACvJ,OAAO,CAAC,SAAS,EAAE,kBAAkB,CAAC,CAAC;IAC3C,CAAC;IAEO,IAAI,CAAC,GAAgB;QACzB,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE;YAC3B,gBAAgB;YAChB,gBAAgB,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC1C,OAAO;SACV;QAED,MAAM,SAAS,GAAG,CAAA,gBAAgB,CAAC,qBAAqB,EAAE,cAAc,CAAc,EAAE,CAAC,KAAK,CAAC,CAAC;QAChG,IACI,CAAC,IAAI,CAAC,QAAQ,IAAI,GAAG,CAAC,KAAK,GAAG,CAAC,SAAS,EAAE,QAAQ,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,KAAK,IAAI,SAAS,EAAE,KAAK,IAAI,IAAI,CAAC,eAAe,CAAC,CAAC;YACxH,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,GAAG,CAAC,KAAK,GAAG,CAAC,SAAS,EAAE,KAAK,IAAI,IAAI,CAAC,eAAe,CAAC,CAAC,EAC5E;YACE,OAAO;SACV;QAED,IAAI,SAAS,EAAE,eAAe,EAAE;YAC5B,GAAG,CAAC,kBAAkB,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,eAAe,CAAC,IAAI,SAAS,CAAC;SAC3G;QAED,gBAAgB,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;IAC/D,CAAC;IAEM,KAAK,CAAC,UAA0B,EAAE,GAAG,IAAW;QACnD,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,YAAY,CAAC,KAAK,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;IACtE,CAAC;IAEM,KAAK,CAAC,UAA0B,EAAE,GAAG,IAAW;QACnD,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,YAAY,CAAC,KAAK,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;IACtE,CAAC;IAEM,GAAG,CAAC,UAA0B,EAAE,WAAyB,YAAY,CAAC,GAAG,EAAE,WAA+B,SAAS,EAAE,GAAG,IAAW;QACtI,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC3D,CAAC;IAEM,QAAQ,CAAiC,QAAW;QACvD,MAAM,CAAC,SAAS,EAAE,kBAAkB,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;QACnE,MAAM,aAAa,GAAgB;YAC/B,SAAS,EAAE,SAAS;YACpB,kBAAkB,EAAE,kBAAkB,IAAI,SAAS;YACnD,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,QAAQ;YAC5C,OAAO,EAAE,EAAE;YACX,cAAc,EAAE,QAAQ,CAAC,cAAc;YACvC,KAAK,EAAE,YAAY,CAAC,GAAG;YACvB,GAAG,QAAQ;SACd,CAAC;QACF,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC7B,CAAC;IAEM,IAAI,CAAC,UAA0B,EAAE,GAAG,IAAW;QAClD,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,YAAY,CAAC,IAAI,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;IACrE,CAAC;IAEM,IAAI,CAAC,UAA0B,EAAE,GAAG,IAAW;QAClD,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,YAAY,CAAC,OAAO,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;IACxE,CAAC;IAEM,KAAK,CAAC,UAA0B,EAAE,GAAG,IAAW;QACnD,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,YAAY,CAAC,KAAK,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;IACtE,CAAC","sourcesContent":["import {DatePipe} from '@angular/common';\n\nimport {IMngLogPublisher, IMngLoggerService, LogLevelEnum, MngInternalError, MngLogConfig, MngLogEntry} from '../models';\nimport {DateUtil} from '../utils';\nimport {MngConfigurationService} from './configuration.service';\n\nexport class MngLoggerService implements IMngLoggerService {\n    private static _instance: MngLoggerService = new MngLoggerService();\n    private static _isInit = false;\n    private static _configurationService?: MngConfigurationService;\n    private static _publishers: IMngLogPublisher[] = [];\n    private static _entriesBuffer: MngLogEntry[] = [];\n    private static _categoryInstances: Record<string, MngLoggerService> = {};\n    private static _timestampFormat = 'yyyy-MM-dd HH:mm:ss.SSS';\n\n    private category?: string;\n\n    // Temporary settings that cover logging calls before initialisation\n    private readonly defaultLogLevel: LogLevelEnum = LogLevelEnum.Info;\n    private datePipe = new DatePipe('en-US');\n\n    private constructor() {\n        // empty\n    }\n\n    public static get() {\n        return MngLoggerService._instance;\n    }\n\n    public static configure(config: {timestampFormat?: string}) {\n        if (config.timestampFormat) {\n            MngLoggerService._timestampFormat = config.timestampFormat;\n        }\n    }\n\n    public static init(configurationService: MngConfigurationService, publishers: IMngLogPublisher[]) {\n        if (MngLoggerService._isInit) {\n            return;\n        }\n\n        MngLoggerService._configurationService = configurationService;\n        MngLoggerService._publishers = publishers;\n\n        MngLoggerService._isInit = true;\n        MngLoggerService._flushBuffer();\n    }\n\n    private static _flushBuffer() {\n        if (!MngLoggerService._isInit) {\n            return;\n        }\n        MngLoggerService._entriesBuffer.forEach(e => this._instance._log(e));\n        MngLoggerService._entriesBuffer = [];\n    }\n\n    public static create(category: string): MngLoggerService {\n        return MngLoggerService._instance.create(category);\n    }\n\n    public create(category: string): MngLoggerService {\n        if (this.category) {\n            throw new MngInternalError(`Cannot create logger with category inside another category (${this.category}). Must create logger on root.`);\n        }\n        if (MngLoggerService._categoryInstances[category]) {\n            return MngLoggerService._categoryInstances[category];\n        }\n\n        const logger = new MngLoggerService();\n        logger.category = category;\n\n        MngLoggerService._categoryInstances[category] = logger;\n\n        return logger;\n    }\n\n    private _processLog(msgOrError: string | Error, logLevel: LogLevelEnum, category: string | undefined = undefined, data?: any[]) {\n        const [timestamp, timestampFormatted] = [...this._getTimestamps()];\n\n        const logEntry = <MngLogEntry>{\n            level: logLevel,\n            message: typeof msgOrError === 'string' ? msgOrError : msgOrError.message,\n            data: data,\n            category: this.category ?? category,\n            timestamp: timestamp,\n            timestampFormatted: timestampFormatted ?? undefined\n        };\n\n        if (msgOrError instanceof Error) {\n            // set error from message param\n            logEntry.error = msgOrError;\n        } else if (data?.length && data[0] instanceof Error) {\n            // if first data is error, also consider as error\n            logEntry.error = data[0];\n            logEntry.data = data.splice(1);\n        }\n\n        this._log(logEntry);\n    }\n\n    private _getTimestamps(): [Date, string | null] {\n        const timestamp = new Date();\n        const timestampFormatted = this.datePipe.transform(timestamp, MngLoggerService._timestampFormat) ?? DateUtil.toIsoString(timestamp, false, true, true);\n        return [timestamp, timestampFormatted];\n    }\n\n    private _log(log: MngLogEntry) {\n        if (!MngLoggerService._isInit) {\n            // add to buffer\n            MngLoggerService._entriesBuffer.push(log);\n            return;\n        }\n\n        const logConfig = MngLoggerService._configurationService?.getConfigValue<MngLogConfig>?.('log');\n        if (\n            (this.category && log.level < (logConfig?.category?.[this.category]?.level ?? logConfig?.level ?? this.defaultLogLevel)) ||\n            (!this.category && log.level < (logConfig?.level ?? this.defaultLogLevel))\n        ) {\n            return;\n        }\n\n        if (logConfig?.timestampFormat) {\n            log.timestampFormatted = this.datePipe.transform(log.timestamp, logConfig.timestampFormat) ?? undefined;\n        }\n\n        MngLoggerService._publishers.forEach(p => p.addEntry(log));\n    }\n\n    public trace(msgOrError: string | Error, ...data: any[]) {\n        this._processLog(msgOrError, LogLevelEnum.Trace, undefined, data);\n    }\n\n    public debug(msgOrError: string | Error, ...data: any[]) {\n        this._processLog(msgOrError, LogLevelEnum.Debug, undefined, data);\n    }\n\n    public log(msgOrError: string | Error, logLevel: LogLevelEnum = LogLevelEnum.Log, category: string | undefined = undefined, ...data: any[]) {\n        this._processLog(msgOrError, logLevel, category, data);\n    }\n\n    public logEntry<E extends Partial<MngLogEntry>>(logEntry: E) {\n        const [timestamp, timestampFormatted] = [...this._getTimestamps()];\n        const logEntryFinal: MngLogEntry = {\n            timestamp: timestamp,\n            timestampFormatted: timestampFormatted ?? undefined,\n            category: this.category ?? logEntry.category,\n            message: '',\n            messageDetails: logEntry.messageDetails,\n            level: LogLevelEnum.Log,\n            ...logEntry\n        };\n        this._log(logEntryFinal);\n    }\n\n    public info(msgOrError: string | Error, ...data: any[]) {\n        this._processLog(msgOrError, LogLevelEnum.Info, undefined, data);\n    }\n\n    public warn(msgOrError: string | Error, ...data: any[]) {\n        this._processLog(msgOrError, LogLevelEnum.Warning, undefined, data);\n    }\n\n    public error(msgOrError: string | Error, ...data: any[]) {\n        this._processLog(msgOrError, LogLevelEnum.Error, undefined, data);\n    }\n}\n"]}
|
|
@@ -1,3 +1,2 @@
|
|
|
1
|
-
export * from './config-service.provider';
|
|
2
1
|
export * from './formly-config.provider';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL3Byb3ZpZGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9mb3JtbHktY29uZmlnLnByb3ZpZGVyJztcbiJdfQ==
|
|
@@ -1,12 +1,16 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
1
|
+
import { Injectable, inject } from '@angular/core';
|
|
2
2
|
import { NavigationCancel, NavigationEnd, NavigationError, NavigationStart, RouteConfigLoadEnd, RouteConfigLoadStart, Router } from '@angular/router';
|
|
3
3
|
import { ReplaySubject } from 'rxjs';
|
|
4
4
|
import { first } from 'rxjs/operators';
|
|
5
|
+
import { MngLoggerService } from './logger.service';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "@angular/router";
|
|
7
8
|
export class MngRouterService {
|
|
8
9
|
constructor(router) {
|
|
9
10
|
this.router = router;
|
|
11
|
+
this.logger = inject(MngLoggerService).create('MngRouterService');
|
|
12
|
+
this.routesLoadedPropKey = '_loadedRoutes';
|
|
13
|
+
this.currentNavigationModuleKeys = [];
|
|
10
14
|
this.lazyLoadedRoutesConfig = {};
|
|
11
15
|
}
|
|
12
16
|
getRouteLoadedChildren(path) {
|
|
@@ -33,45 +37,122 @@ export class MngRouterService {
|
|
|
33
37
|
}
|
|
34
38
|
startNavigation(url) {
|
|
35
39
|
this.currentNavigationPath = url.split('?')[0].split('#')[0];
|
|
36
|
-
this.
|
|
37
|
-
this.currentNavigationConfigLoaded = undefined;
|
|
40
|
+
this.currentNavigationModuleKeys = [];
|
|
38
41
|
}
|
|
39
42
|
finishNavigation() {
|
|
40
|
-
if (this.
|
|
41
|
-
this.getLoadedRoutesFromRoute();
|
|
43
|
+
if (this.currentNavigationModuleKeys.length) {
|
|
44
|
+
this.currentNavigationModuleKeys.forEach(k => this.getLoadedRoutesFromRoute(k, true));
|
|
42
45
|
}
|
|
43
46
|
this.currentNavigationPath = undefined;
|
|
44
47
|
}
|
|
45
48
|
markNavigationConfigLoad(route, isEnd = false) {
|
|
46
|
-
this.currentNavigationConfigLoaded = isEnd;
|
|
47
49
|
let routePath = route.path ?? '';
|
|
48
50
|
if (!routePath.startsWith('/'))
|
|
49
51
|
routePath = `/${routePath}`;
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
moduleKey = this.currentNavigationPath.substring(0, currentNavigationPathRoutePathIdx + routePath.length);
|
|
55
|
-
}
|
|
56
|
-
this.currentNavigationConfigModule = moduleKey;
|
|
52
|
+
const currentNavigationPathRoutePathIdx = this.currentNavigationPath?.indexOf(routePath) ?? -1;
|
|
53
|
+
const moduleKey = this.currentNavigationPath?.substring(0, currentNavigationPathRoutePathIdx + routePath.length) ?? routePath;
|
|
54
|
+
if (!isEnd && this.currentNavigationModuleKeys.indexOf(moduleKey) < 0) {
|
|
55
|
+
this.currentNavigationModuleKeys.push(moduleKey);
|
|
57
56
|
}
|
|
58
|
-
|
|
57
|
+
this.logger.trace(`Config load ${isEnd ? 'end' : 'start'} for ${moduleKey} (routePath: ${routePath}; navigationUrl: ${this.currentNavigationPath})`);
|
|
58
|
+
const config = this.getOrCreateRouteForModule(moduleKey);
|
|
59
59
|
config.route = route;
|
|
60
60
|
config.isLoadEnd = isEnd;
|
|
61
|
-
|
|
61
|
+
if (isEnd) {
|
|
62
|
+
this.getLoadedRoutesFromRoute(moduleKey);
|
|
63
|
+
}
|
|
62
64
|
}
|
|
63
|
-
getLoadedRoutesFromRoute() {
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
Array.isArray(this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes)) {
|
|
65
|
+
getLoadedRoutesFromRoute(moduleKey, isFinish = false) {
|
|
66
|
+
const moduleConfig = this.lazyLoadedRoutesConfig[moduleKey];
|
|
67
|
+
if (!moduleConfig?.route || Array.isArray(moduleConfig.loadedRoutes)) {
|
|
67
68
|
return;
|
|
68
69
|
}
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
this.
|
|
73
|
-
this.
|
|
70
|
+
moduleConfig.loadedRoutes = moduleConfig.route[this.routesLoadedPropKey];
|
|
71
|
+
if (!Array.isArray(moduleConfig.loadedRoutes) && isFinish) {
|
|
72
|
+
// if is called from finish and no lazy loaded routes are matched from router events, try finding in route config, it should be there!
|
|
73
|
+
this.logger.trace(`Route loadedRoutes for ${moduleKey} not found, searching in router config now`);
|
|
74
|
+
const route = this.findRouteInRouteConfig(moduleKey);
|
|
75
|
+
if (route) {
|
|
76
|
+
moduleConfig.route = route;
|
|
77
|
+
moduleConfig.loadedRoutes = moduleConfig.route[this.routesLoadedPropKey];
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
this.logger.warn(`Route loadedRoutes for ${moduleKey} were not found in router config`);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
if (typeof moduleConfig.loadedRoutes !== 'undefined') {
|
|
84
|
+
moduleConfig.loadedRoutesSubject.next(moduleConfig.loadedRoutes);
|
|
85
|
+
moduleConfig.loadedRoutesSubject.complete();
|
|
86
|
+
this.logger.trace(`Config load for ${moduleKey} is complete`, moduleConfig);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Search for route config by module path by recursive scanning of router config tree.
|
|
91
|
+
* @param modulePath Path of module that is searched.
|
|
92
|
+
* @param routes Routes to be scanned. If not provided, it starts on root router config.
|
|
93
|
+
* @private
|
|
94
|
+
*/
|
|
95
|
+
findRouteInRouteConfig(modulePath, routes = this.router.config) {
|
|
96
|
+
if (modulePath.startsWith('/')) {
|
|
97
|
+
modulePath = modulePath.substring(1);
|
|
98
|
+
}
|
|
99
|
+
for (const route of routes) {
|
|
100
|
+
if (typeof route.path === 'undefined') {
|
|
101
|
+
continue;
|
|
102
|
+
}
|
|
103
|
+
let routePath = route.path;
|
|
104
|
+
if (routePath.startsWith('/')) {
|
|
105
|
+
routePath = routePath.substring(1);
|
|
106
|
+
}
|
|
107
|
+
const longestPathMatch = this.findLongestPathMatch(modulePath, routePath);
|
|
108
|
+
if (longestPathMatch === null) {
|
|
109
|
+
continue;
|
|
110
|
+
}
|
|
111
|
+
// there is a partial or full match
|
|
112
|
+
if (route.loadChildren && modulePath === longestPathMatch) {
|
|
113
|
+
// it's a hit!
|
|
114
|
+
return route;
|
|
115
|
+
}
|
|
116
|
+
else if (route.loadChildren && Array.isArray(route[this.routesLoadedPropKey])) {
|
|
117
|
+
const result = this.findRouteInRouteConfig(modulePath.substring(longestPathMatch.length, modulePath.length), route[this.routesLoadedPropKey]);
|
|
118
|
+
if (result) {
|
|
119
|
+
return result;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
else if (route.children) {
|
|
123
|
+
const result = this.findRouteInRouteConfig(modulePath.substring(longestPathMatch.length, modulePath.length), route.children);
|
|
124
|
+
if (result) {
|
|
125
|
+
return result;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
return null;
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Finds longest path match of source to match string. If match is '', it is considered as a match in Angular routing.
|
|
133
|
+
* @param source Source string from on which comparison is based.
|
|
134
|
+
* @param match Match string to which the source is matched to.
|
|
135
|
+
* @private
|
|
136
|
+
*/
|
|
137
|
+
findLongestPathMatch(source, match) {
|
|
138
|
+
const sourceSegments = source.split('/');
|
|
139
|
+
const matchSegments = match.split('/');
|
|
140
|
+
if (matchSegments.length === 1 && matchSegments[0] === '') {
|
|
141
|
+
// it's a hit, because empty route must always be processed (kind of a "abstract" route)
|
|
142
|
+
return '';
|
|
143
|
+
}
|
|
144
|
+
if (sourceSegments[0] === matchSegments[0]) {
|
|
145
|
+
// there is a match, find how long it is
|
|
146
|
+
for (let i = 1; i < sourceSegments.length; i++) {
|
|
147
|
+
if (sourceSegments[i] !== matchSegments[i]) {
|
|
148
|
+
// end of match
|
|
149
|
+
return sourceSegments.slice(0, i).join('/');
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
// there is full match
|
|
153
|
+
return sourceSegments.join('/');
|
|
74
154
|
}
|
|
155
|
+
return null;
|
|
75
156
|
}
|
|
76
157
|
getOrCreateRouteForModule(moduleKey) {
|
|
77
158
|
if (!this.lazyLoadedRoutesConfig[moduleKey]) {
|
|
@@ -94,4 +175,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
|
|
|
94
175
|
providedIn: 'root'
|
|
95
176
|
}]
|
|
96
177
|
}], ctorParameters: function () { return [{ type: i1.Router }]; } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router.service.js","sourceRoot":"","sources":["../../../../src/lib/services/router.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\nimport {NavigationCancel, NavigationEnd, NavigationError, NavigationStart, Route, RouteConfigLoadEnd, RouteConfigLoadStart, Router, Routes} from '@angular/router';\n\nimport {Observable, ReplaySubject, Subject} from 'rxjs';\nimport {first} from 'rxjs/operators';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class MngRouterService {\n    private currentNavigationPath?: string;\n    private currentNavigationConfigModule?: string;\n    private currentNavigationConfigLoaded?: boolean;\n\n    private lazyLoadedRoutesConfig: {\n        [path: string]: {\n            route?: Route;\n            isLoadEnd: boolean;\n            loadedRoutes?: Routes;\n            loadedRoutesSubject: Subject<Routes>;\n        };\n    } = {};\n\n    constructor(private router: Router) {}\n\n    public getRouteLoadedChildren(path: string | Array<string>): Routes | undefined {\n        return this.getOrCreateRouteForModule(this.getModulePathFromRouterLink(path)).loadedRoutes;\n    }\n\n    public getRouteLoadedChildren$(path: string | Array<string>): Observable<Routes> {\n        return this.getOrCreateRouteForModule(this.getModulePathFromRouterLink(path)).loadedRoutesSubject.asObservable().pipe(first());\n    }\n\n    public initialize() {\n        this.router.events.subscribe(event => {\n            if (event instanceof NavigationStart) {\n                this.startNavigation(event.url);\n            } else if (event instanceof RouteConfigLoadStart) {\n                this.markNavigationConfigLoad(event.route);\n            } else if (event instanceof RouteConfigLoadEnd) {\n                this.markNavigationConfigLoad(event.route, true);\n            } else if (event instanceof NavigationEnd || event instanceof NavigationCancel || event instanceof NavigationError) {\n                this.finishNavigation();\n            }\n        });\n    }\n\n    private startNavigation(url: string) {\n        this.currentNavigationPath = url.split('?')[0].split('#')[0];\n        this.currentNavigationConfigModule = undefined;\n        this.currentNavigationConfigLoaded = undefined;\n    }\n\n    private finishNavigation() {\n        if (this.currentNavigationConfigLoaded && this.currentNavigationConfigModule) {\n            this.getLoadedRoutesFromRoute();\n        }\n        this.currentNavigationPath = undefined;\n    }\n\n    private markNavigationConfigLoad(route: Route, isEnd = false) {\n        this.currentNavigationConfigLoaded = isEnd;\n        let routePath = route.path ?? '';\n        if (!routePath.startsWith('/')) routePath = `/${routePath}`;\n\n        if (!this.currentNavigationConfigModule) {\n            let moduleKey = routePath;\n            const currentNavigationPathRoutePathIdx = this.currentNavigationPath?.indexOf(routePath) ?? -1;\n            if (this.currentNavigationPath && currentNavigationPathRoutePathIdx >= 0) {\n                moduleKey = this.currentNavigationPath.substring(0, currentNavigationPathRoutePathIdx + routePath.length);\n            }\n            this.currentNavigationConfigModule = moduleKey;\n        }\n\n        const config = this.getOrCreateRouteForModule(this.currentNavigationConfigModule);\n        config.route = route;\n        config.isLoadEnd = isEnd;\n        this.getLoadedRoutesFromRoute();\n    }\n\n    private getLoadedRoutesFromRoute() {\n        if (\n            !this.currentNavigationConfigModule ||\n            !this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule]?.route ||\n            Array.isArray(this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes)\n        ) {\n            return;\n        }\n\n        this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes =\n            this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].route!['_loadedRoutes' as keyof object];\n\n        if (typeof this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes !== 'undefined') {\n            this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutesSubject.next(this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes!);\n            this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutesSubject.complete();\n        }\n    }\n\n    private getOrCreateRouteForModule(moduleKey: string) {\n        if (!this.lazyLoadedRoutesConfig[moduleKey]) {\n            this.lazyLoadedRoutesConfig[moduleKey] = {\n                loadedRoutesSubject: new ReplaySubject<Routes>(1),\n                isLoadEnd: false\n            };\n        }\n\n        return this.lazyLoadedRoutesConfig[moduleKey];\n    }\n\n    private getModulePathFromRouterLink(path: string | Array<string>) {\n        return ('/' + (Array.isArray(path) ? path.join('/') : path)).replace(/\\/\\//g, '/');\n    }\n}\n"]}
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router.service.js","sourceRoot":"","sources":["../../../../src/lib/services/router.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable, inject} from '@angular/core';\nimport {NavigationCancel, NavigationEnd, NavigationError, NavigationStart, Route, RouteConfigLoadEnd, RouteConfigLoadStart, Router, Routes} from '@angular/router';\n\nimport {Observable, ReplaySubject, Subject} from 'rxjs';\nimport {first} from 'rxjs/operators';\n\nimport {MngLoggerService} from './logger.service';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class MngRouterService {\n    private readonly logger = inject(MngLoggerService).create('MngRouterService');\n    private readonly routesLoadedPropKey = '_loadedRoutes';\n\n    private currentNavigationPath?: string;\n    private currentNavigationModuleKeys: string[] = [];\n\n    private lazyLoadedRoutesConfig: {\n        [path: string]: {\n            route?: Route;\n            isLoadEnd: boolean;\n            loadedRoutes?: Routes;\n            loadedRoutesSubject: Subject<Routes>;\n        };\n    } = {};\n\n    constructor(private router: Router) {}\n\n    public getRouteLoadedChildren(path: string | Array<string>): Routes | undefined {\n        return this.getOrCreateRouteForModule(this.getModulePathFromRouterLink(path)).loadedRoutes;\n    }\n\n    public getRouteLoadedChildren$(path: string | Array<string>): Observable<Routes> {\n        return this.getOrCreateRouteForModule(this.getModulePathFromRouterLink(path)).loadedRoutesSubject.asObservable().pipe(first());\n    }\n\n    public initialize() {\n        this.router.events.subscribe(event => {\n            if (event instanceof NavigationStart) {\n                this.startNavigation(event.url);\n            } else if (event instanceof RouteConfigLoadStart) {\n                this.markNavigationConfigLoad(event.route);\n            } else if (event instanceof RouteConfigLoadEnd) {\n                this.markNavigationConfigLoad(event.route, true);\n            } else if (event instanceof NavigationEnd || event instanceof NavigationCancel || event instanceof NavigationError) {\n                this.finishNavigation();\n            }\n        });\n    }\n\n    private startNavigation(url: string) {\n        this.currentNavigationPath = url.split('?')[0].split('#')[0];\n        this.currentNavigationModuleKeys = [];\n    }\n\n    private finishNavigation() {\n        if (this.currentNavigationModuleKeys.length) {\n            this.currentNavigationModuleKeys.forEach(k => this.getLoadedRoutesFromRoute(k, true));\n        }\n        this.currentNavigationPath = undefined;\n    }\n\n    private markNavigationConfigLoad(route: Route, isEnd = false) {\n        let routePath = route.path ?? '';\n        if (!routePath.startsWith('/')) routePath = `/${routePath}`;\n\n        const currentNavigationPathRoutePathIdx = this.currentNavigationPath?.indexOf(routePath) ?? -1;\n        const moduleKey = this.currentNavigationPath?.substring(0, currentNavigationPathRoutePathIdx + routePath.length) ?? routePath;\n        if (!isEnd && this.currentNavigationModuleKeys.indexOf(moduleKey) < 0) {\n            this.currentNavigationModuleKeys.push(moduleKey);\n        }\n\n        this.logger.trace(`Config load ${isEnd ? 'end' : 'start'} for ${moduleKey} (routePath: ${routePath}; navigationUrl: ${this.currentNavigationPath})`);\n\n        const config = this.getOrCreateRouteForModule(moduleKey);\n        config.route = route;\n        config.isLoadEnd = isEnd;\n\n        if (isEnd) {\n            this.getLoadedRoutesFromRoute(moduleKey);\n        }\n    }\n\n    private getLoadedRoutesFromRoute(moduleKey: string, isFinish = false) {\n        const moduleConfig = this.lazyLoadedRoutesConfig[moduleKey];\n        if (!moduleConfig?.route || Array.isArray(moduleConfig.loadedRoutes)) {\n            return;\n        }\n\n        moduleConfig.loadedRoutes = moduleConfig.route![this.routesLoadedPropKey as keyof object];\n\n        if (!Array.isArray(moduleConfig.loadedRoutes) && isFinish) {\n            // if is called from finish and no lazy loaded routes are matched from router events, try finding in route config, it should be there!\n            this.logger.trace(`Route loadedRoutes for ${moduleKey} not found, searching in router config now`);\n            const route = this.findRouteInRouteConfig(moduleKey);\n            if (route) {\n                moduleConfig.route = route;\n                moduleConfig.loadedRoutes = moduleConfig.route![this.routesLoadedPropKey as keyof object];\n            } else {\n                this.logger.warn(`Route loadedRoutes for ${moduleKey} were not found in router config`);\n            }\n        }\n\n        if (typeof moduleConfig.loadedRoutes !== 'undefined') {\n            moduleConfig.loadedRoutesSubject.next(moduleConfig.loadedRoutes!);\n            moduleConfig.loadedRoutesSubject.complete();\n\n            this.logger.trace(`Config load for ${moduleKey} is complete`, moduleConfig);\n        }\n    }\n\n    /**\n     * Search for route config by module path by recursive scanning of router config tree.\n     * @param modulePath Path of module that is searched.\n     * @param routes Routes to be scanned. If not provided, it starts on root router config.\n     * @private\n     */\n    private findRouteInRouteConfig(modulePath: string, routes: Routes = this.router.config): Route | null {\n        if (modulePath.startsWith('/')) {\n            modulePath = modulePath.substring(1);\n        }\n\n        for (const route of routes) {\n            if (typeof route.path === 'undefined') {\n                continue;\n            }\n            let routePath = route.path;\n            if (routePath.startsWith('/')) {\n                routePath = routePath.substring(1);\n            }\n\n            const longestPathMatch = this.findLongestPathMatch(modulePath, routePath);\n            if (longestPathMatch === null) {\n                continue;\n            }\n\n            // there is a partial or full match\n            if (route.loadChildren && modulePath === longestPathMatch) {\n                // it's a hit!\n                return route;\n            } else if (route.loadChildren && Array.isArray(route[this.routesLoadedPropKey as keyof object])) {\n                const result = this.findRouteInRouteConfig(modulePath.substring(longestPathMatch.length, modulePath.length), route[this.routesLoadedPropKey as keyof object]);\n                if (result) {\n                    return result;\n                }\n            } else if (route.children) {\n                const result = this.findRouteInRouteConfig(modulePath.substring(longestPathMatch.length, modulePath.length), route.children);\n                if (result) {\n                    return result;\n                }\n            }\n        }\n\n        return null;\n    }\n\n    /**\n     * Finds longest path match of source to match string. If match is '', it is considered as a match in Angular routing.\n     * @param source Source string from on which comparison is based.\n     * @param match Match string to which the source is matched to.\n     * @private\n     */\n    private findLongestPathMatch(source: string, match: string): string | null {\n        const sourceSegments = source.split('/');\n        const matchSegments = match.split('/');\n\n        if (matchSegments.length === 1 && matchSegments[0] === '') {\n            // it's a hit, because empty route must always be processed (kind of a \"abstract\" route)\n            return '';\n        }\n\n        if (sourceSegments[0] === matchSegments[0]) {\n            // there is a match, find how long it is\n            for (let i = 1; i < sourceSegments.length; i++) {\n                if (sourceSegments[i] !== matchSegments[i]) {\n                    // end of match\n                    return sourceSegments.slice(0, i).join('/');\n                }\n            }\n\n            // there is full match\n            return sourceSegments.join('/');\n        }\n\n        return null;\n    }\n\n    private getOrCreateRouteForModule(moduleKey: string) {\n        if (!this.lazyLoadedRoutesConfig[moduleKey]) {\n            this.lazyLoadedRoutesConfig[moduleKey] = {\n                loadedRoutesSubject: new ReplaySubject<Routes>(1),\n                isLoadEnd: false\n            };\n        }\n\n        return this.lazyLoadedRoutesConfig[moduleKey];\n    }\n\n    private getModulePathFromRouterLink(path: string | Array<string>) {\n        return ('/' + (Array.isArray(path) ? path.join('/') : path)).replace(/\\/\\//g, '/');\n    }\n}\n"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
export * from './browser-storage.token';
|
|
2
2
|
export * from './commons-init.token';
|
|
3
3
|
export * from './default-setting.token';
|
|
4
|
+
export * from './log-publisher.token';
|
|
4
5
|
export * from './module-config.token';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL3Rva2Vucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Jyb3dzZXItc3RvcmFnZS50b2tlbic7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1vbnMtaW5pdC50b2tlbic7XG5leHBvcnQgKiBmcm9tICcuL2RlZmF1bHQtc2V0dGluZy50b2tlbic7XG5leHBvcnQgKiBmcm9tICcuL2xvZy1wdWJsaXNoZXIudG9rZW4nO1xuZXhwb3J0ICogZnJvbSAnLi9tb2R1bGUtY29uZmlnLnRva2VuJztcbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
export const MNG_LOG_PUBLISHERS = new InjectionToken('MNG_LOG_PUBLISHERS');
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nLXB1Ymxpc2hlci50b2tlbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvc2VydmljZXMvdG9rZW5zL2xvZy1wdWJsaXNoZXIudG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUk3QyxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLGNBQWMsQ0FBcUIsb0JBQW9CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0aW9uVG9rZW59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge0lNbmdMb2dQdWJsaXNoZXJ9IGZyb20gJy4uLy4uL21vZGVscyc7XG5cbmV4cG9ydCBjb25zdCBNTkdfTE9HX1BVQkxJU0hFUlMgPSBuZXcgSW5qZWN0aW9uVG9rZW48SU1uZ0xvZ1B1Ymxpc2hlcltdPignTU5HX0xPR19QVUJMSVNIRVJTJyk7XG4iXX0=
|