@mediusinc/mng-commons 3.0.0-rc.4 → 3.0.0-rc.7

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.
Files changed (82) hide show
  1. package/esm2022/index.mjs +3 -1
  2. package/esm2022/lib/api/utils/object-serializer.util.mjs +11 -4
  3. package/esm2022/lib/components/action/editor/action-editor.component.mjs +8 -7
  4. package/esm2022/lib/components/action/models/action-execution.model.mjs +14 -37
  5. package/esm2022/lib/components/form/autocomplete/autocomplete.component.mjs +7 -5
  6. package/esm2022/lib/components/form/dropdown/dropdown.component.mjs +7 -5
  7. package/esm2022/lib/components/form/editor/form-editor.component.mjs +9 -8
  8. package/esm2022/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +3 -3
  9. package/esm2022/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +6 -6
  10. package/esm2022/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +3 -3
  11. package/esm2022/lib/components/tableview/table/table.component.mjs +3 -3
  12. package/esm2022/lib/descriptors/action/action.descriptor.mjs +9 -8
  13. package/esm2022/lib/descriptors/editor/editor.descriptor.mjs +3 -3
  14. package/esm2022/lib/descriptors/filter/filter.descriptor.mjs +7 -6
  15. package/esm2022/lib/descriptors/table/column.descriptor.mjs +3 -3
  16. package/esm2022/lib/descriptors/table/table.descriptor.mjs +9 -1
  17. package/esm2022/lib/descriptors/tableview/tableview.descriptor.mjs +3 -3
  18. package/esm2022/lib/error/error.handler.mjs +23 -0
  19. package/esm2022/lib/error/index.mjs +2 -0
  20. package/esm2022/lib/models/config.model.mjs +1 -1
  21. package/esm2022/lib/models/error.model.mjs +1 -1
  22. package/esm2022/lib/models/index.mjs +3 -2
  23. package/esm2022/lib/models/internal-error.model.mjs +30 -0
  24. package/esm2022/lib/models/log.model.mjs +10 -0
  25. package/esm2022/lib/pipes/json-path.pipe.mjs +8 -4
  26. package/esm2022/lib/provide-commons.mjs +16 -15
  27. package/esm2022/lib/router/route-builder.mjs +4 -4
  28. package/esm2022/lib/router/routes-builder.mjs +3 -3
  29. package/esm2022/lib/security/authorization.service.mjs +5 -4
  30. package/esm2022/lib/security/authorization.util.mjs +3 -3
  31. package/esm2022/lib/services/action-error-mapper.service.mjs +19 -0
  32. package/esm2022/lib/services/action-executor.service.mjs +23 -27
  33. package/esm2022/lib/services/commons.service.mjs +16 -25
  34. package/esm2022/lib/services/configuration.service.mjs +60 -30
  35. package/esm2022/lib/services/index.mjs +3 -2
  36. package/esm2022/lib/services/internal/commons-init.service.mjs +48 -23
  37. package/esm2022/lib/services/logger.service.mjs +123 -0
  38. package/esm2022/lib/services/providers/index.mjs +1 -2
  39. package/esm2022/lib/services/router.service.mjs +91 -5
  40. package/esm2022/lib/utils/action-data-provider.util.mjs +7 -7
  41. package/esm2022/lib/utils/notification.util.mjs +3 -2
  42. package/esm2022/lib/utils/object.util.mjs +32 -5
  43. package/esm2022/lib/utils/route.util.mjs +3 -3
  44. package/esm2022/lib/utils/string.util.mjs +2 -2
  45. package/esm2022/lib/utils/tableview.util.mjs +3 -3
  46. package/esm2022/lib/utils/type.util.mjs +5 -5
  47. package/fesm2022/mediusinc-mng-commons.mjs +2554 -2271
  48. package/fesm2022/mediusinc-mng-commons.mjs.map +1 -1
  49. package/index.d.ts +1 -0
  50. package/lib/api/utils/object-serializer.util.d.ts +1 -0
  51. package/lib/components/action/editor/action-editor.component.d.ts +1 -0
  52. package/lib/components/action/models/action-execution.model.d.ts +3 -2
  53. package/lib/components/form/autocomplete/autocomplete.component.d.ts +1 -0
  54. package/lib/components/form/dropdown/dropdown.component.d.ts +1 -0
  55. package/lib/components/form/editor/form-editor.component.d.ts +1 -0
  56. package/lib/descriptors/editor/field.descriptor.d.ts +2 -2
  57. package/lib/descriptors/table/table.descriptor.d.ts +3 -0
  58. package/lib/error/error.handler.d.ts +6 -0
  59. package/lib/error/index.d.ts +1 -0
  60. package/lib/models/config.model.d.ts +2 -1
  61. package/lib/models/error.model.d.ts +2 -1
  62. package/lib/models/index.d.ts +2 -1
  63. package/lib/models/{error-internal.model.d.ts → internal-error.model.d.ts} +3 -6
  64. package/lib/models/log.model.d.ts +34 -0
  65. package/lib/pipes/json-path.pipe.d.ts +1 -0
  66. package/lib/security/authorization.service.d.ts +1 -0
  67. package/lib/services/action-error-mapper.service.d.ts +11 -0
  68. package/lib/services/action-executor.service.d.ts +3 -3
  69. package/lib/services/commons.service.d.ts +9 -14
  70. package/lib/services/configuration.service.d.ts +13 -5
  71. package/lib/services/index.d.ts +2 -1
  72. package/lib/services/internal/commons-init.service.d.ts +7 -8
  73. package/lib/services/logger.service.d.ts +30 -0
  74. package/lib/services/providers/index.d.ts +0 -1
  75. package/lib/services/router.service.d.ts +16 -0
  76. package/lib/utils/object.util.d.ts +6 -4
  77. package/package.json +1 -1
  78. package/esm2022/lib/models/error-internal.model.mjs +0 -27
  79. package/esm2022/lib/services/error-mapper.service.mjs +0 -14
  80. package/esm2022/lib/services/providers/config-service.provider.mjs +0 -31
  81. package/lib/services/error-mapper.service.d.ts +0 -7
  82. package/lib/services/providers/config-service.provider.d.ts +0 -6
@@ -1,37 +1,67 @@
1
- import { Inject, Injectable, Optional } from '@angular/core';
2
- import { TranslateService } from '@ngx-translate/core';
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_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(translate, configurationService, mngCommons, mngRouter, commonsInitializers) {
12
- this.translate = translate;
13
- this.configurationService = configurationService;
14
- this.mngCommons = mngCommons;
15
- this.mngRouter = mngRouter;
16
- this.commonsInitializers = commonsInitializers;
9
+ constructor() {
10
+ this.httpClient = inject(HttpClient);
11
+ this.logger = inject(MngLoggerService);
12
+ this.config = inject(MngConfigurationService);
13
+ this.mngCommons = inject(MngCommonsService);
14
+ this.mngRouter = inject(MngRouterService);
15
+ this.moduleConfig = inject(MNG_MODULE_CONFIG_IT, { optional: true });
16
+ this.commonsInitializers = inject(MNG_COMMONS_INITIALIZER_IT, { optional: true });
17
17
  this.isInitialized = false;
18
18
  }
19
19
  initialize() {
20
20
  if (this.isInitialized) {
21
21
  return of(void 0);
22
22
  }
23
+ this.isInitialized = true;
24
+ MngLoggerService.configure({ timestampFormat: this.moduleConfig?.log?.timestampFormat });
25
+ const ctxLogger = this.logger.create('MngCommonsInitService');
26
+ ctxLogger.debug('Commons initialization is starting');
27
+ // init router
23
28
  this.mngRouter.initialize();
24
- return this.configurationService.loadJsonConfigurations().pipe(mergeMap(() => {
29
+ // init configurations with settings from module config
30
+ this.config.init(this.httpClient, this.logger);
31
+ this.config.addModuleConfigSource(this.moduleConfig ?? undefined);
32
+ if (this.moduleConfig?.configuration?.projectEnvironment) {
33
+ this.config.addEnvironmentSource(this.moduleConfig.configuration.projectEnvironment);
34
+ }
35
+ // init configurations with settings from module config for json source
36
+ if (!(this.moduleConfig?.configuration?.skipJsonSourceInit ?? false)) {
37
+ const jsonSourceEnableEnvProd = this.moduleConfig?.configuration?.jsonSourceEnableEnvProd ?? false;
38
+ const jsonSource = this.moduleConfig?.configuration?.jsonSource;
39
+ if (!jsonSource) {
40
+ this.config.addJsonSource({ enableEnvProd: jsonSourceEnableEnvProd });
41
+ }
42
+ else if (Array.isArray(jsonSource)) {
43
+ jsonSource.forEach(source => this.config.addJsonSource({ url: source, enableEnvProd: jsonSourceEnableEnvProd }));
44
+ }
45
+ else {
46
+ this.config.addJsonSource({ url: jsonSource, enableEnvProd: jsonSourceEnableEnvProd });
47
+ }
48
+ }
49
+ return this.config.loadJsonConfigurations().pipe(mergeMap(() => {
50
+ // init logger
51
+ MngLoggerService.init(this.config);
25
52
  if (this.commonsInitializers) {
53
+ ctxLogger.debug('Project initializers are being initialized');
26
54
  return combineLatest(this.commonsInitializers.map(ci => ci())).pipe(map(res => res));
27
55
  }
28
56
  else {
29
57
  return of(true);
30
58
  }
31
- }), map(() => this.mngCommons.reset()));
32
- this.isInitialized = true;
59
+ }), map(() => {
60
+ ctxLogger.debug('Commons initialization is finished');
61
+ return this.mngCommons.reset();
62
+ }));
33
63
  }
34
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: MngCommonsInitService, deps: [{ token: i1.TranslateService }, { token: i2.MngConfigurationService }, { token: i2.MngCommonsService }, { token: i2.MngRouterService }, { token: MNG_COMMONS_INITIALIZER_IT, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
64
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: MngCommonsInitService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
35
65
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: MngCommonsInitService, providedIn: 'root' }); }
36
66
  }
37
67
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: MngCommonsInitService, decorators: [{
@@ -39,10 +69,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
39
69
  args: [{
40
70
  providedIn: 'root'
41
71
  }]
42
- }], ctorParameters: function () { return [{ type: i1.TranslateService }, { type: i2.MngConfigurationService }, { type: i2.MngCommonsService }, { type: i2.MngRouterService }, { type: undefined, decorators: [{
43
- type: Inject,
44
- args: [MNG_COMMONS_INITIALIZER_IT]
45
- }, {
46
- type: Optional
47
- }] }]; } });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9ucy1pbml0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL2ludGVybmFsL2NvbW1vbnMtaW5pdC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxNQUFNLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUUzRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUNyRCxPQUFPLEVBQWEsYUFBYSxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUMsTUFBTSxNQUFNLENBQUM7QUFDN0QsT0FBTyxFQUFDLEdBQUcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBRW5DLE9BQU8sRUFBQyxpQkFBaUIsRUFBRSx1QkFBdUIsRUFBRSxnQkFBZ0IsRUFBQyxNQUFNLEtBQUssQ0FBQztBQUNqRixPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSxXQUFXLENBQUM7Ozs7QUFLckQsTUFBTSxPQUFPLHFCQUFxQjtJQUc5QixZQUNZLFNBQTJCLEVBQzNCLG9CQUE2QyxFQUM3QyxVQUE2QixFQUM3QixTQUEyQixFQUM4QixtQkFBNkQ7UUFKdEgsY0FBUyxHQUFULFNBQVMsQ0FBa0I7UUFDM0IseUJBQW9CLEdBQXBCLG9CQUFvQixDQUF5QjtRQUM3QyxlQUFVLEdBQVYsVUFBVSxDQUFtQjtRQUM3QixjQUFTLEdBQVQsU0FBUyxDQUFrQjtRQUM4Qix3QkFBbUIsR0FBbkIsbUJBQW1CLENBQTBDO1FBUDFILGtCQUFhLEdBQUcsS0FBSyxDQUFDO0lBUTNCLENBQUM7SUFFRyxVQUFVO1FBQ2IsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3BCLE9BQU8sRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDckI7UUFFRCxJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBRTVCLE9BQU8sSUFBSSxDQUFDLG9CQUFvQixDQUFDLHNCQUFzQixFQUFFLENBQUMsSUFBSSxDQUMxRCxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ1YsSUFBSSxJQUFJLENBQUMsbUJBQW1CLEVBQUU7Z0JBQzFCLE9BQU8sYUFBYSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7YUFDeEY7aUJBQU07Z0JBQ0gsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUM7YUFDbkI7UUFDTCxDQUFDLENBQUMsRUFDRixHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUNyQyxDQUFDO1FBRUYsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUM7SUFDOUIsQ0FBQzs4R0E5QlEscUJBQXFCLDBKQVFsQiwwQkFBMEI7a0hBUjdCLHFCQUFxQixjQUZsQixNQUFNOzsyRkFFVCxxQkFBcUI7a0JBSGpDLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCOzswQkFTUSxNQUFNOzJCQUFDLDBCQUEwQjs7MEJBQUcsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0LCBJbmplY3RhYmxlLCBPcHRpb25hbH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7VHJhbnNsYXRlU2VydmljZX0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQge09ic2VydmFibGUsIGNvbWJpbmVMYXRlc3QsIG1lcmdlTWFwLCBvZn0gZnJvbSAncnhqcyc7XG5pbXBvcnQge21hcH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQge01uZ0NvbW1vbnNTZXJ2aWNlLCBNbmdDb25maWd1cmF0aW9uU2VydmljZSwgTW5nUm91dGVyU2VydmljZX0gZnJvbSAnLi4vJztcbmltcG9ydCB7TU5HX0NPTU1PTlNfSU5JVElBTElaRVJfSVR9IGZyb20gJy4uL3Rva2Vucyc7XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgTW5nQ29tbW9uc0luaXRTZXJ2aWNlIHtcbiAgICBwcml2YXRlIGlzSW5pdGlhbGl6ZWQgPSBmYWxzZTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIHRyYW5zbGF0ZTogVHJhbnNsYXRlU2VydmljZSxcbiAgICAgICAgcHJpdmF0ZSBjb25maWd1cmF0aW9uU2VydmljZTogTW5nQ29uZmlndXJhdGlvblNlcnZpY2UsXG4gICAgICAgIHByaXZhdGUgbW5nQ29tbW9uczogTW5nQ29tbW9uc1NlcnZpY2UsXG4gICAgICAgIHByaXZhdGUgbW5nUm91dGVyOiBNbmdSb3V0ZXJTZXJ2aWNlLFxuICAgICAgICBASW5qZWN0KE1OR19DT01NT05TX0lOSVRJQUxJWkVSX0lUKSBAT3B0aW9uYWwoKSBwcml2YXRlIHJlYWRvbmx5IGNvbW1vbnNJbml0aWFsaXplcnM6IFJlYWRvbmx5QXJyYXk8KCkgPT4gT2JzZXJ2YWJsZTx1bmtub3duPj5cbiAgICApIHt9XG5cbiAgICBwdWJsaWMgaW5pdGlhbGl6ZSgpOiBPYnNlcnZhYmxlPHZvaWQ+IHtcbiAgICAgICAgaWYgKHRoaXMuaXNJbml0aWFsaXplZCkge1xuICAgICAgICAgICAgcmV0dXJuIG9mKHZvaWQgMCk7XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLm1uZ1JvdXRlci5pbml0aWFsaXplKCk7XG5cbiAgICAgICAgcmV0dXJuIHRoaXMuY29uZmlndXJhdGlvblNlcnZpY2UubG9hZEpzb25Db25maWd1cmF0aW9ucygpLnBpcGUoXG4gICAgICAgICAgICBtZXJnZU1hcCgoKSA9PiB7XG4gICAgICAgICAgICAgICAgaWYgKHRoaXMuY29tbW9uc0luaXRpYWxpemVycykge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4gY29tYmluZUxhdGVzdCh0aGlzLmNvbW1vbnNJbml0aWFsaXplcnMubWFwKGNpID0+IGNpKCkpKS5waXBlKG1hcChyZXMgPT4gcmVzKSk7XG4gICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIG9mKHRydWUpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgbWFwKCgpID0+IHRoaXMubW5nQ29tbW9ucy5yZXNldCgpKVxuICAgICAgICApO1xuXG4gICAgICAgIHRoaXMuaXNJbml0aWFsaXplZCA9IHRydWU7XG4gICAgfVxufVxuIl19
72
+ }] });
73
+ //# 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_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 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);\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,123 @@
1
+ /* eslint-disable no-console */
2
+ import { DatePipe } from '@angular/common';
3
+ import { LogLevelEnum, MngInternalError } from '../models';
4
+ export class MngLoggerService {
5
+ static { this._instance = new MngLoggerService(); }
6
+ static { this._isInit = false; }
7
+ static { this._entriesBuffer = []; }
8
+ static { this._categoryInstances = {}; }
9
+ static { this._timestampFormat = 'yyyy-MM-dd HH:mm:ss.SSS'; }
10
+ constructor() {
11
+ // Temporary settings that cover logging calls before initialisation
12
+ this.defaultLogLevel = LogLevelEnum.Info;
13
+ this.datePipe = new DatePipe('en-US');
14
+ // empty
15
+ }
16
+ static get() {
17
+ return MngLoggerService._instance;
18
+ }
19
+ static configure(config) {
20
+ if (config.timestampFormat) {
21
+ MngLoggerService._timestampFormat = config.timestampFormat;
22
+ }
23
+ }
24
+ static init(configurationService) {
25
+ if (MngLoggerService._isInit) {
26
+ return;
27
+ }
28
+ MngLoggerService._configurationService = configurationService;
29
+ MngLoggerService._isInit = true;
30
+ MngLoggerService._flushBuffer();
31
+ }
32
+ static _flushBuffer() {
33
+ MngLoggerService._entriesBuffer.forEach(e => this._instance._log(e));
34
+ MngLoggerService._entriesBuffer = [];
35
+ }
36
+ static create(category) {
37
+ return MngLoggerService._instance.create(category);
38
+ }
39
+ create(category) {
40
+ if (this.category) {
41
+ throw new MngInternalError(`Cannot create logger with category inside another category (${this.category}). Must create logger on root.`);
42
+ }
43
+ if (MngLoggerService._categoryInstances[category]) {
44
+ return MngLoggerService._categoryInstances[category];
45
+ }
46
+ const logger = new MngLoggerService();
47
+ logger.category = category;
48
+ MngLoggerService._categoryInstances[category] = logger;
49
+ return logger;
50
+ }
51
+ _processLog(msg, logLevel, category = this.category, data) {
52
+ const timestamp = new Date();
53
+ const timestampFormatted = this.datePipe.transform(timestamp, MngLoggerService._timestampFormat);
54
+ const log = {
55
+ level: logLevel,
56
+ message: msg,
57
+ data: data,
58
+ category: category,
59
+ timestamp: timestamp,
60
+ timestampFormatted: timestampFormatted ?? undefined
61
+ };
62
+ if (!MngLoggerService._isInit) {
63
+ // add to buffer
64
+ MngLoggerService._entriesBuffer.push(log);
65
+ }
66
+ else {
67
+ this._log(log);
68
+ }
69
+ }
70
+ _log(log) {
71
+ const logConfig = (MngLoggerService._configurationService?.getConfigValue)?.('log');
72
+ if ((this.category && log.level < (logConfig?.category?.[this.category]?.level ?? logConfig?.level ?? this.defaultLogLevel)) ||
73
+ (!this.category && log.level < (logConfig?.level ?? this.defaultLogLevel))) {
74
+ return;
75
+ }
76
+ if (logConfig?.timestampFormat) {
77
+ log.timestampFormatted = this.datePipe.transform(log.timestamp, logConfig.timestampFormat) ?? undefined;
78
+ }
79
+ let prefix = `${log.timestampFormatted}`;
80
+ if (log.category)
81
+ prefix += ` [${log.category}]`;
82
+ prefix += ':';
83
+ switch (log.level) {
84
+ case LogLevelEnum.Trace:
85
+ console.trace(prefix, log.message, ...log.data);
86
+ break;
87
+ case LogLevelEnum.Debug:
88
+ console.debug(prefix, log.message, ...log.data);
89
+ break;
90
+ case LogLevelEnum.Log:
91
+ console.log(prefix, log.message, ...log.data);
92
+ break;
93
+ case LogLevelEnum.Info:
94
+ console.info(prefix, log.message, ...log.data);
95
+ break;
96
+ case LogLevelEnum.Warning:
97
+ console.warn(prefix, log.message, ...log.data);
98
+ break;
99
+ case LogLevelEnum.Error:
100
+ console.error(prefix, log.message, ...log.data);
101
+ break;
102
+ }
103
+ }
104
+ trace(msg, ...data) {
105
+ this._processLog(msg, LogLevelEnum.Trace, undefined, data);
106
+ }
107
+ debug(msg, ...data) {
108
+ this._processLog(msg, LogLevelEnum.Debug, undefined, data);
109
+ }
110
+ log(msg, logLevel = LogLevelEnum.Log, category = undefined, ...data) {
111
+ this._processLog(msg, logLevel, category, data);
112
+ }
113
+ info(msg, ...data) {
114
+ this._processLog(msg, LogLevelEnum.Info, undefined, data);
115
+ }
116
+ warn(msg, ...data) {
117
+ this._processLog(msg, LogLevelEnum.Warning, undefined, data);
118
+ }
119
+ error(msg, ...data) {
120
+ this._processLog(msg, LogLevelEnum.Error, undefined, data);
121
+ }
122
+ }
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.service.js","sourceRoot":"","sources":["../../../../src/lib/services/logger.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-console */\nimport {DatePipe} from '@angular/common';\n\nimport {IMngLoggerService, LogLevelEnum, MngInternalError, MngLogConfig, MngLogEntry} from '../models';\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 _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) {\n        if (MngLoggerService._isInit) {\n            return;\n        }\n\n        MngLoggerService._configurationService = configurationService;\n\n        MngLoggerService._isInit = true;\n        MngLoggerService._flushBuffer();\n    }\n\n    private static _flushBuffer() {\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(msg: string, logLevel: LogLevelEnum, category = this.category, data: any[]) {\n        const timestamp = new Date();\n        const timestampFormatted = this.datePipe.transform(timestamp, MngLoggerService._timestampFormat);\n        const log = <MngLogEntry>{\n            level: logLevel,\n            message: msg,\n            data: data,\n            category: category,\n            timestamp: timestamp,\n            timestampFormatted: timestampFormatted ?? undefined\n        };\n\n        if (!MngLoggerService._isInit) {\n            // add to buffer\n            MngLoggerService._entriesBuffer.push(log);\n        } else {\n            this._log(log);\n        }\n    }\n\n    private _log(log: MngLogEntry) {\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        let prefix = `${log.timestampFormatted}`;\n        if (log.category) prefix += ` [${log.category}]`;\n        prefix += ':';\n\n        switch (log.level) {\n            case LogLevelEnum.Trace:\n                console.trace(prefix, log.message, ...log.data);\n                break;\n            case LogLevelEnum.Debug:\n                console.debug(prefix, log.message, ...log.data);\n                break;\n            case LogLevelEnum.Log:\n                console.log(prefix, log.message, ...log.data);\n                break;\n            case LogLevelEnum.Info:\n                console.info(prefix, log.message, ...log.data);\n                break;\n            case LogLevelEnum.Warning:\n                console.warn(prefix, log.message, ...log.data);\n                break;\n            case LogLevelEnum.Error:\n                console.error(prefix, log.message, ...log.data);\n                break;\n        }\n    }\n\n    public trace(msg: string, ...data: any[]) {\n        this._processLog(msg, LogLevelEnum.Trace, undefined, data);\n    }\n\n    public debug(msg: string, ...data: any[]) {\n        this._processLog(msg, LogLevelEnum.Debug, undefined, data);\n    }\n\n    public log(msg: string, logLevel: LogLevelEnum = LogLevelEnum.Log, category: string | undefined = undefined, ...data: any[]) {\n        this._processLog(msg, logLevel, category, data);\n    }\n\n    public info(msg: string, ...data: any[]) {\n        this._processLog(msg, LogLevelEnum.Info, undefined, data);\n    }\n\n    public warn(msg: string, ...data: any[]) {\n        this._processLog(msg, LogLevelEnum.Warning, undefined, data);\n    }\n\n    public error(msg: string, ...data: any[]) {\n        this._processLog(msg, 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL3Byb3ZpZGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbmZpZy1zZXJ2aWNlLnByb3ZpZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vZm9ybWx5LWNvbmZpZy5wcm92aWRlcic7XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL3Byb3ZpZGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9mb3JtbHktY29uZmlnLnByb3ZpZGVyJztcbiJdfQ==
@@ -1,12 +1,15 @@
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';
10
13
  this.lazyLoadedRoutesConfig = {};
11
14
  }
12
15
  getRouteLoadedChildren(path) {
@@ -38,7 +41,7 @@ export class MngRouterService {
38
41
  }
39
42
  finishNavigation() {
40
43
  if (this.currentNavigationConfigLoaded && this.currentNavigationConfigModule) {
41
- this.getLoadedRoutesFromRoute();
44
+ this.getLoadedRoutesFromRoute(true);
42
45
  }
43
46
  this.currentNavigationPath = undefined;
44
47
  }
@@ -55,23 +58,106 @@ export class MngRouterService {
55
58
  }
56
59
  this.currentNavigationConfigModule = moduleKey;
57
60
  }
61
+ this.logger.trace(`Config load ${isEnd ? 'end' : 'start'} for ${this.currentNavigationConfigModule}`);
58
62
  const config = this.getOrCreateRouteForModule(this.currentNavigationConfigModule);
59
63
  config.route = route;
60
64
  config.isLoadEnd = isEnd;
61
65
  this.getLoadedRoutesFromRoute();
62
66
  }
63
- getLoadedRoutesFromRoute() {
67
+ getLoadedRoutesFromRoute(isFinish = false) {
64
68
  if (!this.currentNavigationConfigModule ||
65
69
  !this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule]?.route ||
66
70
  Array.isArray(this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes)) {
67
71
  return;
68
72
  }
69
73
  this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes =
70
- this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].route['_loadedRoutes'];
74
+ this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].route[this.routesLoadedPropKey];
75
+ if (!Array.isArray(this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes) && isFinish) {
76
+ // if is called from finish and no lazy loaded routes are matched from router events, try finding in route config, it should be there!
77
+ this.logger.trace(`Route loadedRoutes for ${this.currentNavigationConfigModule} not found, searching in router config now`);
78
+ const route = this.findRouteInRouteConfig(this.currentNavigationConfigModule);
79
+ if (route) {
80
+ this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].route = route;
81
+ this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes =
82
+ this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].route[this.routesLoadedPropKey];
83
+ }
84
+ else {
85
+ this.logger.warn(`Route loadedRoutes for ${this.currentNavigationConfigModule} were not found in router config`);
86
+ }
87
+ }
71
88
  if (typeof this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes !== 'undefined') {
72
89
  this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutesSubject.next(this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes);
73
90
  this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutesSubject.complete();
91
+ this.logger.trace(`Config load for ${this.currentNavigationConfigModule} is complete`, this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule]);
92
+ }
93
+ }
94
+ /**
95
+ * Search for route config by module path by recursive scanning of router config tree.
96
+ * @param modulePath Path of module that is searched.
97
+ * @param routes Routes to be scanned. If not provided, it starts on root router config.
98
+ * @private
99
+ */
100
+ findRouteInRouteConfig(modulePath, routes = this.router.config) {
101
+ if (modulePath.startsWith('/')) {
102
+ modulePath = modulePath.substring(1);
103
+ }
104
+ for (const route of routes) {
105
+ if (typeof route.path === 'undefined') {
106
+ continue;
107
+ }
108
+ let routePath = route.path;
109
+ if (routePath.startsWith('/')) {
110
+ routePath = routePath.substring(1);
111
+ }
112
+ const longestPathMatch = this.findLongestPathMatch(modulePath, routePath);
113
+ if (longestPathMatch === null) {
114
+ continue;
115
+ }
116
+ // there is a partial or full match
117
+ if (route.loadChildren && modulePath === longestPathMatch) {
118
+ // it's a hit!
119
+ return route;
120
+ }
121
+ else if (route.loadChildren && Array.isArray(route[this.routesLoadedPropKey])) {
122
+ const result = this.findRouteInRouteConfig(modulePath.substring(longestPathMatch.length, modulePath.length), route[this.routesLoadedPropKey]);
123
+ if (result) {
124
+ return result;
125
+ }
126
+ }
127
+ else if (route.children) {
128
+ const result = this.findRouteInRouteConfig(modulePath.substring(longestPathMatch.length, modulePath.length), route.children);
129
+ if (result) {
130
+ return result;
131
+ }
132
+ }
133
+ }
134
+ return null;
135
+ }
136
+ /**
137
+ * Finds longest path match of source to match string. If match is '', it is considered as a match in Angular routing.
138
+ * @param source Source string from on which comparison is based.
139
+ * @param match Match string to which the source is matched to.
140
+ * @private
141
+ */
142
+ findLongestPathMatch(source, match) {
143
+ const sourceSegments = source.split('/');
144
+ const matchSegments = match.split('/');
145
+ if (matchSegments.length === 1 && matchSegments[0] === '') {
146
+ // it's a hit, because empty route must always be processed (kind of a "abstract" route)
147
+ return '';
148
+ }
149
+ if (sourceSegments[0] === matchSegments[0]) {
150
+ // there is a match, find how long it is
151
+ for (let i = 1; i < sourceSegments.length; i++) {
152
+ if (sourceSegments[i] !== matchSegments[i]) {
153
+ // end of match
154
+ return sourceSegments.slice(0, i).join('/');
155
+ }
156
+ }
157
+ // there is full match
158
+ return sourceSegments.join('/');
74
159
  }
160
+ return null;
75
161
  }
76
162
  getOrCreateRouteForModule(moduleKey) {
77
163
  if (!this.lazyLoadedRoutesConfig[moduleKey]) {
@@ -94,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
94
180
  providedIn: 'root'
95
181
  }]
96
182
  }], 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"]}
183
+ //# 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 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(true);\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        this.logger.trace(`Config load ${isEnd ? 'end' : 'start'} for ${this.currentNavigationConfigModule}`);\n\n        const config = this.getOrCreateRouteForModule(this.currentNavigationConfigModule);\n        config.route = route;\n        config.isLoadEnd = isEnd;\n        this.getLoadedRoutesFromRoute();\n    }\n\n    private getLoadedRoutesFromRoute(isFinish = false) {\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![this.routesLoadedPropKey as keyof object];\n\n        if (!Array.isArray(this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].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 ${this.currentNavigationConfigModule} not found, searching in router config now`);\n            const route = this.findRouteInRouteConfig(this.currentNavigationConfigModule);\n            if (route) {\n                this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].route = route;\n                this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes =\n                    this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].route![this.routesLoadedPropKey as keyof object];\n            } else {\n                this.logger.warn(`Route loadedRoutes for ${this.currentNavigationConfigModule} were not found in router config`);\n            }\n        }\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            this.logger.trace(`Config load for ${this.currentNavigationConfigModule} is complete`, this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule]);\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"]}