@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.
Files changed (136) hide show
  1. package/README.md +8 -7
  2. package/assets/i18n/en.json +5 -1
  3. package/assets/i18n/sl.json +5 -1
  4. package/dev-scripts/version-info.js +13 -6
  5. package/esm2022/index.mjs +3 -1
  6. package/esm2022/lib/api/utils/object-serializer.util.mjs +11 -4
  7. package/esm2022/lib/components/action/action.component.mjs +18 -6
  8. package/esm2022/lib/components/action/editor/action-editor.component.mjs +83 -18
  9. package/esm2022/lib/components/action/models/action-execution.model.mjs +14 -37
  10. package/esm2022/lib/components/action/route/action-route.component.mjs +9 -2
  11. package/esm2022/lib/components/form/autocomplete/autocomplete.component.mjs +18 -5
  12. package/esm2022/lib/components/form/dropdown/dropdown.component.mjs +21 -8
  13. package/esm2022/lib/components/form/editor/form-editor.component.mjs +9 -8
  14. package/esm2022/lib/components/form/formly/fields/formly-field-action/formly-field-action.component.mjs +22 -4
  15. package/esm2022/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.mjs +43 -15
  16. package/esm2022/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +11 -4
  17. package/esm2022/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +8 -6
  18. package/esm2022/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +16 -7
  19. package/esm2022/lib/components/form/models/field-action-context.model.mjs +1 -1
  20. package/esm2022/lib/components/form/models/index.mjs +2 -1
  21. package/esm2022/lib/components/tableview/table/table.component.mjs +57 -55
  22. package/esm2022/lib/descriptors/action/action-button.descriptor.mjs +10 -2
  23. package/esm2022/lib/descriptors/action/action.descriptor.mjs +19 -8
  24. package/esm2022/lib/descriptors/editor/editor.descriptor.mjs +3 -3
  25. package/esm2022/lib/descriptors/editor/field.descriptor.mjs +13 -4
  26. package/esm2022/lib/descriptors/filter/filter.descriptor.mjs +7 -6
  27. package/esm2022/lib/descriptors/table/column.descriptor.mjs +3 -3
  28. package/esm2022/lib/descriptors/table/table.descriptor.mjs +35 -4
  29. package/esm2022/lib/descriptors/tableview/tableview.descriptor.mjs +3 -3
  30. package/esm2022/lib/error/error.handler.mjs +20 -0
  31. package/esm2022/lib/error/index.mjs +2 -0
  32. package/esm2022/lib/guards/index.mjs +2 -0
  33. package/esm2022/lib/guards/unsaved-changes.guard.mjs +4 -0
  34. package/esm2022/lib/models/action-editor.model.mjs +2 -0
  35. package/esm2022/lib/models/can-component-deactivate.model.mjs +2 -0
  36. package/esm2022/lib/models/config.model.mjs +1 -1
  37. package/esm2022/lib/models/error.model.mjs +44 -2
  38. package/esm2022/lib/models/index.mjs +4 -2
  39. package/esm2022/lib/models/log.model.mjs +10 -0
  40. package/esm2022/lib/models/version.model.mjs +1 -1
  41. package/esm2022/lib/pipes/json-path.pipe.mjs +8 -4
  42. package/esm2022/lib/provide-commons.mjs +22 -16
  43. package/esm2022/lib/router/route-builder.mjs +4 -4
  44. package/esm2022/lib/router/routes-builder.mjs +3 -3
  45. package/esm2022/lib/router/tableview-route-builder.mjs +4 -1
  46. package/esm2022/lib/security/authorization.service.mjs +5 -4
  47. package/esm2022/lib/security/authorization.util.mjs +3 -3
  48. package/esm2022/lib/services/action-error-mapper.service.mjs +20 -0
  49. package/esm2022/lib/services/action-executor.service.mjs +97 -57
  50. package/esm2022/lib/services/commons.service.mjs +16 -25
  51. package/esm2022/lib/services/configuration.service.mjs +56 -32
  52. package/esm2022/lib/services/index.mjs +4 -2
  53. package/esm2022/lib/services/internal/commons-init.service.mjs +49 -23
  54. package/esm2022/lib/services/log-publisher-console.service.mjs +40 -0
  55. package/esm2022/lib/services/logger.service.mjs +130 -0
  56. package/esm2022/lib/services/providers/index.mjs +1 -2
  57. package/esm2022/lib/services/router.service.mjs +106 -25
  58. package/esm2022/lib/services/tokens/index.mjs +2 -1
  59. package/esm2022/lib/services/tokens/log-publisher.token.mjs +3 -0
  60. package/esm2022/lib/services/version.service.mjs +7 -2
  61. package/esm2022/lib/utils/action-data-provider.util.mjs +7 -7
  62. package/esm2022/lib/utils/editor-formly.util.mjs +2 -1
  63. package/esm2022/lib/utils/error.util.mjs +247 -0
  64. package/esm2022/lib/utils/i18n.util.mjs +7 -9
  65. package/esm2022/lib/utils/index.mjs +2 -1
  66. package/esm2022/lib/utils/notification.util.mjs +3 -2
  67. package/esm2022/lib/utils/object.util.mjs +32 -5
  68. package/esm2022/lib/utils/route.util.mjs +3 -3
  69. package/esm2022/lib/utils/string.util.mjs +33 -2
  70. package/esm2022/lib/utils/tableview.util.mjs +3 -3
  71. package/esm2022/lib/utils/type.util.mjs +5 -5
  72. package/fesm2022/mediusinc-mng-commons.mjs +4352 -3484
  73. package/fesm2022/mediusinc-mng-commons.mjs.map +1 -1
  74. package/index.d.ts +1 -0
  75. package/lib/api/utils/object-serializer.util.d.ts +1 -0
  76. package/lib/components/action/action.component.d.ts +1 -0
  77. package/lib/components/action/editor/action-editor.component.d.ts +17 -6
  78. package/lib/components/action/models/action-execution.model.d.ts +6 -4
  79. package/lib/components/action/route/action-route.component.d.ts +4 -1
  80. package/lib/components/form/autocomplete/autocomplete.component.d.ts +1 -0
  81. package/lib/components/form/dropdown/dropdown.component.d.ts +1 -0
  82. package/lib/components/form/editor/form-editor.component.d.ts +1 -0
  83. package/lib/components/form/formly/fields/formly-field-action/formly-field-action.component.d.ts +3 -0
  84. package/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.d.ts +2 -0
  85. package/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.d.ts +1 -0
  86. package/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.d.ts +1 -0
  87. package/lib/components/form/models/field-action-context.model.d.ts +7 -0
  88. package/lib/components/form/models/index.d.ts +1 -0
  89. package/lib/components/tableview/table/table.component.d.ts +2 -0
  90. package/lib/descriptors/action/action-button.descriptor.d.ts +4 -1
  91. package/lib/descriptors/action/action.descriptor.d.ts +3 -0
  92. package/lib/descriptors/editor/field.descriptor.d.ts +10 -8
  93. package/lib/descriptors/table/column.descriptor.d.ts +1 -1
  94. package/lib/descriptors/table/table.descriptor.d.ts +26 -3
  95. package/lib/error/error.handler.d.ts +6 -0
  96. package/lib/error/index.d.ts +1 -0
  97. package/lib/guards/index.d.ts +1 -0
  98. package/lib/guards/unsaved-changes.guard.d.ts +3 -0
  99. package/lib/models/action-editor.model.d.ts +4 -0
  100. package/lib/models/can-component-deactivate.model.d.ts +4 -0
  101. package/lib/models/config.model.d.ts +2 -1
  102. package/lib/models/error.model.d.ts +44 -8
  103. package/lib/models/index.d.ts +3 -1
  104. package/lib/models/log.model.d.ts +40 -0
  105. package/lib/models/version.model.d.ts +1 -1
  106. package/lib/pipes/json-path.pipe.d.ts +1 -0
  107. package/lib/security/authorization.service.d.ts +1 -0
  108. package/lib/services/action-error-mapper.service.d.ts +18 -0
  109. package/lib/services/action-executor.service.d.ts +12 -6
  110. package/lib/services/commons.service.d.ts +9 -14
  111. package/lib/services/configuration.service.d.ts +13 -5
  112. package/lib/services/index.d.ts +3 -1
  113. package/lib/services/internal/commons-init.service.d.ts +8 -8
  114. package/lib/services/log-publisher-console.service.d.ts +4 -0
  115. package/lib/services/logger.service.d.ts +33 -0
  116. package/lib/services/providers/index.d.ts +0 -1
  117. package/lib/services/router.service.d.ts +17 -2
  118. package/lib/services/tokens/index.d.ts +1 -0
  119. package/lib/services/tokens/log-publisher.token.d.ts +3 -0
  120. package/lib/services/version.service.d.ts +1 -0
  121. package/lib/utils/error.util.d.ts +116 -0
  122. package/lib/utils/i18n.util.d.ts +3 -3
  123. package/lib/utils/index.d.ts +1 -0
  124. package/lib/utils/notification.util.d.ts +2 -2
  125. package/lib/utils/object.util.d.ts +6 -4
  126. package/lib/utils/string.util.d.ts +5 -0
  127. package/package.json +4 -1
  128. package/scss/common/theme/designer/_components.scss +1 -1
  129. package/scss/mng-overrides/_theme_dialog.scss +7 -0
  130. package/scss/mng-overrides/_theme_tableview.scss +15 -0
  131. package/esm2022/lib/models/error-internal.model.mjs +0 -27
  132. package/esm2022/lib/services/error-mapper.service.mjs +0 -14
  133. package/esm2022/lib/services/providers/config-service.provider.mjs +0 -31
  134. package/lib/models/error-internal.model.d.ts +0 -29
  135. package/lib/services/error-mapper.service.d.ts +0 -7
  136. package/lib/services/providers/config-service.provider.d.ts +0 -6
@@ -1,37 +1,68 @@
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_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(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.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
- return this.configurationService.loadJsonConfigurations().pipe(mergeMap(() => {
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(() => this.mngCommons.reset()));
32
- this.isInitialized = true;
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: [{ token: i1.TranslateService }, { token: i2.MngConfigurationService }, { token: i2.MngCommonsService }, { token: i2.MngRouterService }, { token: MNG_COMMONS_INITIALIZER_IT, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
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
- }], 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
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":"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","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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL3Byb3ZpZGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbmZpZy1zZXJ2aWNlLnByb3ZpZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vZm9ybWx5LWNvbmZpZy5wcm92aWRlcic7XG4iXX0=
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.currentNavigationConfigModule = undefined;
37
- this.currentNavigationConfigLoaded = undefined;
40
+ this.currentNavigationModuleKeys = [];
38
41
  }
39
42
  finishNavigation() {
40
- if (this.currentNavigationConfigLoaded && this.currentNavigationConfigModule) {
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
- if (!this.currentNavigationConfigModule) {
51
- let moduleKey = routePath;
52
- const currentNavigationPathRoutePathIdx = this.currentNavigationPath?.indexOf(routePath) ?? -1;
53
- if (this.currentNavigationPath && currentNavigationPathRoutePathIdx >= 0) {
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
- const config = this.getOrCreateRouteForModule(this.currentNavigationConfigModule);
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
- this.getLoadedRoutesFromRoute();
61
+ if (isEnd) {
62
+ this.getLoadedRoutesFromRoute(moduleKey);
63
+ }
62
64
  }
63
- getLoadedRoutesFromRoute() {
64
- if (!this.currentNavigationConfigModule ||
65
- !this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule]?.route ||
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
- this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes =
70
- this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].route['_loadedRoutes'];
71
- if (typeof this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes !== 'undefined') {
72
- this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutesSubject.next(this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutes);
73
- this.lazyLoadedRoutesConfig[this.currentNavigationConfigModule].loadedRoutesSubject.complete();
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL3Rva2Vucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9icm93c2VyLXN0b3JhZ2UudG9rZW4nO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tb25zLWluaXQudG9rZW4nO1xuZXhwb3J0ICogZnJvbSAnLi9kZWZhdWx0LXNldHRpbmcudG9rZW4nO1xuZXhwb3J0ICogZnJvbSAnLi9tb2R1bGUtY29uZmlnLnRva2VuJztcbiJdfQ==
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=