@ecodev/natural 43.0.0 → 44.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (154) hide show
  1. package/esm2020/lib/classes/abstract-controller.mjs +3 -3
  2. package/esm2020/lib/classes/abstract-detail.mjs +6 -6
  3. package/esm2020/lib/classes/abstract-editable-list.mjs +7 -7
  4. package/esm2020/lib/classes/abstract-list.mjs +3 -3
  5. package/esm2020/lib/classes/abstract-navigable-list.mjs +3 -3
  6. package/esm2020/lib/classes/validators.mjs +1 -1
  7. package/esm2020/lib/directives/http-prefix.directive.mjs +3 -3
  8. package/esm2020/lib/modules/alert/alert.module.mjs +5 -5
  9. package/esm2020/lib/modules/alert/alert.service.mjs +3 -3
  10. package/esm2020/lib/modules/alert/confirm.component.mjs +5 -5
  11. package/esm2020/lib/modules/avatar/avatar.module.mjs +5 -5
  12. package/esm2020/lib/modules/avatar/component/avatar.component.mjs +7 -17
  13. package/esm2020/lib/modules/avatar/service/avatar.service.mjs +3 -3
  14. package/esm2020/lib/modules/columns-picker/columns-picker-column.directive.mjs +3 -3
  15. package/esm2020/lib/modules/columns-picker/columns-picker.component.mjs +9 -9
  16. package/esm2020/lib/modules/columns-picker/columns-picker.module.mjs +11 -13
  17. package/esm2020/lib/modules/common/common-module.mjs +5 -5
  18. package/esm2020/lib/modules/common/directives/linkable-tab.directive.mjs +3 -3
  19. package/esm2020/lib/modules/common/directives/src-density.directive.mjs +3 -3
  20. package/esm2020/lib/modules/common/pipes/capitalize.pipe.mjs +3 -3
  21. package/esm2020/lib/modules/common/pipes/ellipsis.pipe.mjs +3 -3
  22. package/esm2020/lib/modules/common/pipes/enum.pipe.mjs +3 -3
  23. package/esm2020/lib/modules/common/pipes/swiss-date.pipe.mjs +3 -3
  24. package/esm2020/lib/modules/common/services/memory-storage.mjs +3 -3
  25. package/esm2020/lib/modules/common/services/seo.service.mjs +3 -3
  26. package/esm2020/lib/modules/detail-header/detail-header.component.mjs +9 -9
  27. package/esm2020/lib/modules/detail-header/detail-header.module.mjs +5 -5
  28. package/esm2020/lib/modules/dialog-trigger/dialog-trigger.component.mjs +3 -3
  29. package/esm2020/lib/modules/dialog-trigger/dialog-trigger.module.mjs +5 -5
  30. package/esm2020/lib/modules/dropdown-components/abstract-association-select-component.directive.mjs +6 -6
  31. package/esm2020/lib/modules/dropdown-components/natural-dropdown-components.module.mjs +16 -18
  32. package/esm2020/lib/modules/dropdown-components/type-date/type-date.component.mjs +16 -16
  33. package/esm2020/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs +14 -14
  34. package/esm2020/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.mjs +9 -9
  35. package/esm2020/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.mjs +9 -9
  36. package/esm2020/lib/modules/dropdown-components/type-number/type-number.component.mjs +13 -13
  37. package/esm2020/lib/modules/dropdown-components/type-select/type-select.component.mjs +11 -11
  38. package/esm2020/lib/modules/dropdown-components/type-text/type-text.component.mjs +13 -10
  39. package/esm2020/lib/modules/dropdown-components/types.mjs +1 -1
  40. package/esm2020/lib/modules/file/abstract-file.mjs +3 -3
  41. package/esm2020/lib/modules/file/component/file.component.mjs +6 -6
  42. package/esm2020/lib/modules/file/file-drop.directive.mjs +3 -3
  43. package/esm2020/lib/modules/file/file-select.directive.mjs +3 -3
  44. package/esm2020/lib/modules/file/file.module.mjs +5 -5
  45. package/esm2020/lib/modules/file/file.service.mjs +3 -3
  46. package/esm2020/lib/modules/fixed-button/fixed-button.component.mjs +6 -6
  47. package/esm2020/lib/modules/fixed-button/fixed-button.module.mjs +5 -5
  48. package/esm2020/lib/modules/fixed-button-detail/fixed-button-detail.component.mjs +6 -6
  49. package/esm2020/lib/modules/fixed-button-detail/fixed-button-detail.module.mjs +5 -5
  50. package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.mjs +10 -10
  51. package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.mjs +3 -3
  52. package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.mjs +5 -5
  53. package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.mjs +3 -3
  54. package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector.module.mjs +19 -21
  55. package/esm2020/lib/modules/icon/icon.component.mjs +5 -5
  56. package/esm2020/lib/modules/icon/icon.module.mjs +5 -5
  57. package/esm2020/lib/modules/logger/error-handler.mjs +3 -3
  58. package/esm2020/lib/modules/logger/error.module.mjs +5 -5
  59. package/esm2020/lib/modules/matomo/matomo-module.module.mjs +4 -4
  60. package/esm2020/lib/modules/matomo/matomo.service.mjs +3 -3
  61. package/esm2020/lib/modules/panels/abstract-panel.mjs +3 -3
  62. package/esm2020/lib/modules/panels/panels.component.mjs +3 -3
  63. package/esm2020/lib/modules/panels/panels.module.mjs +5 -5
  64. package/esm2020/lib/modules/panels/panels.service.mjs +3 -3
  65. package/esm2020/lib/modules/relations/relations.component.mjs +8 -8
  66. package/esm2020/lib/modules/relations/relations.module.mjs +14 -16
  67. package/esm2020/lib/modules/search/dropdown-container/dropdown-container.component.mjs +7 -7
  68. package/esm2020/lib/modules/search/dropdown-container/dropdown.service.mjs +3 -3
  69. package/esm2020/lib/modules/search/facet-selector/facet-selector.component.mjs +5 -5
  70. package/esm2020/lib/modules/search/group/group.component.mjs +5 -5
  71. package/esm2020/lib/modules/search/input/input.component.mjs +20 -22
  72. package/esm2020/lib/modules/search/search/search.component.mjs +5 -5
  73. package/esm2020/lib/modules/search/search.module.mjs +15 -17
  74. package/esm2020/lib/modules/select/abstract-select.component.mjs +6 -6
  75. package/esm2020/lib/modules/select/select/select.component.mjs +16 -16
  76. package/esm2020/lib/modules/select/select-enum/select-enum.component.mjs +8 -8
  77. package/esm2020/lib/modules/select/select-hierarchic/select-hierarchic.component.mjs +10 -10
  78. package/esm2020/lib/modules/select/select.module.mjs +16 -18
  79. package/esm2020/lib/modules/sidenav/sidenav/sidenav.component.mjs +3 -3
  80. package/esm2020/lib/modules/sidenav/sidenav-container/sidenav-container.component.mjs +5 -5
  81. package/esm2020/lib/modules/sidenav/sidenav-content/sidenav-content.component.mjs +3 -3
  82. package/esm2020/lib/modules/sidenav/sidenav-stack.service.mjs +3 -3
  83. package/esm2020/lib/modules/sidenav/sidenav.module.mjs +5 -5
  84. package/esm2020/lib/modules/sidenav/sidenav.service.mjs +3 -3
  85. package/esm2020/lib/modules/stamp/stamp-module.module.mjs +5 -5
  86. package/esm2020/lib/modules/stamp/stamp.component.mjs +5 -5
  87. package/esm2020/lib/modules/table-button/table-button.component.mjs +7 -7
  88. package/esm2020/lib/modules/table-button/table-button.module.mjs +5 -5
  89. package/esm2020/lib/services/abstract-model.service.mjs +7 -7
  90. package/esm2020/lib/services/enum.service.mjs +3 -3
  91. package/esm2020/lib/services/link-mutation.service.mjs +3 -3
  92. package/esm2020/lib/services/persistence.service.mjs +3 -3
  93. package/esm2020/lib/services/swiss-parsing-date-adapter.service.mjs +3 -3
  94. package/fesm2015/ecodev-natural.mjs +452 -473
  95. package/fesm2015/ecodev-natural.mjs.map +1 -1
  96. package/fesm2020/ecodev-natural.mjs +452 -473
  97. package/fesm2020/ecodev-natural.mjs.map +1 -1
  98. package/{ecodev-natural.d.ts → index.d.ts} +0 -0
  99. package/lib/classes/abstract-controller.d.ts +1 -1
  100. package/lib/classes/abstract-detail.d.ts +3 -3
  101. package/lib/classes/abstract-editable-list.d.ts +5 -5
  102. package/lib/classes/abstract-list.d.ts +1 -1
  103. package/lib/classes/abstract-navigable-list.d.ts +1 -1
  104. package/lib/classes/validators.d.ts +2 -2
  105. package/lib/directives/http-prefix.directive.d.ts +1 -1
  106. package/lib/modules/alert/confirm.component.d.ts +1 -1
  107. package/lib/modules/avatar/component/avatar.component.d.ts +1 -1
  108. package/lib/modules/columns-picker/columns-picker-column.directive.d.ts +1 -1
  109. package/lib/modules/columns-picker/columns-picker.component.d.ts +1 -1
  110. package/lib/modules/common/directives/linkable-tab.directive.d.ts +1 -1
  111. package/lib/modules/common/directives/src-density.directive.d.ts +1 -1
  112. package/lib/modules/common/pipes/capitalize.pipe.d.ts +1 -1
  113. package/lib/modules/common/pipes/ellipsis.pipe.d.ts +1 -1
  114. package/lib/modules/common/pipes/enum.pipe.d.ts +1 -1
  115. package/lib/modules/common/pipes/swiss-date.pipe.d.ts +1 -1
  116. package/lib/modules/detail-header/detail-header.component.d.ts +1 -1
  117. package/lib/modules/dialog-trigger/dialog-trigger.component.d.ts +1 -1
  118. package/lib/modules/dropdown-components/abstract-association-select-component.directive.d.ts +11 -8
  119. package/lib/modules/dropdown-components/type-date/type-date.component.d.ts +9 -6
  120. package/lib/modules/dropdown-components/type-date-range/type-date-range.component.d.ts +11 -8
  121. package/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.d.ts +1 -1
  122. package/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.d.ts +1 -1
  123. package/lib/modules/dropdown-components/type-number/type-number.component.d.ts +10 -7
  124. package/lib/modules/dropdown-components/type-select/type-select.component.d.ts +8 -5
  125. package/lib/modules/dropdown-components/type-text/type-text.component.d.ts +4 -4
  126. package/lib/modules/dropdown-components/types.d.ts +4 -2
  127. package/lib/modules/file/abstract-file.d.ts +1 -1
  128. package/lib/modules/file/component/file.component.d.ts +1 -1
  129. package/lib/modules/file/file-drop.directive.d.ts +1 -1
  130. package/lib/modules/file/file-select.directive.d.ts +1 -1
  131. package/lib/modules/fixed-button/fixed-button.component.d.ts +1 -1
  132. package/lib/modules/fixed-button-detail/fixed-button-detail.component.d.ts +1 -1
  133. package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.d.ts +1 -1
  134. package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.d.ts +1 -1
  135. package/lib/modules/icon/icon.component.d.ts +1 -1
  136. package/lib/modules/panels/abstract-panel.d.ts +1 -1
  137. package/lib/modules/panels/panels.component.d.ts +1 -1
  138. package/lib/modules/relations/relations.component.d.ts +1 -1
  139. package/lib/modules/search/dropdown-container/dropdown-container.component.d.ts +1 -1
  140. package/lib/modules/search/facet-selector/facet-selector.component.d.ts +1 -1
  141. package/lib/modules/search/group/group.component.d.ts +1 -1
  142. package/lib/modules/search/input/input.component.d.ts +6 -7
  143. package/lib/modules/search/search/search.component.d.ts +1 -1
  144. package/lib/modules/select/abstract-select.component.d.ts +9 -9
  145. package/lib/modules/select/select/select.component.d.ts +7 -5
  146. package/lib/modules/select/select-enum/select-enum.component.d.ts +5 -3
  147. package/lib/modules/select/select-hierarchic/select-hierarchic.component.d.ts +3 -3
  148. package/lib/modules/sidenav/sidenav/sidenav.component.d.ts +1 -1
  149. package/lib/modules/sidenav/sidenav-container/sidenav-container.component.d.ts +1 -1
  150. package/lib/modules/sidenav/sidenav-content/sidenav-content.component.d.ts +1 -1
  151. package/lib/modules/stamp/stamp.component.d.ts +1 -1
  152. package/lib/modules/table-button/table-button.component.d.ts +1 -1
  153. package/lib/services/abstract-model.service.d.ts +2 -2
  154. package/package.json +15 -8
@@ -22,9 +22,9 @@ export class NaturalAbstractController {
22
22
  window.history.back();
23
23
  }
24
24
  }
25
- NaturalAbstractController.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAbstractController, deps: [], target: i0.ɵɵFactoryTarget.Directive });
26
- NaturalAbstractController.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.0", type: NaturalAbstractController, ngImport: i0 });
27
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAbstractController, decorators: [{
25
+ NaturalAbstractController.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAbstractController, deps: [], target: i0.ɵɵFactoryTarget.Directive });
26
+ NaturalAbstractController.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.1", type: NaturalAbstractController, ngImport: i0 });
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAbstractController, decorators: [{
28
28
  type: Directive
29
29
  }], ctorParameters: function () { return []; } });
30
30
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QtY29udHJvbGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9jbGFzc2VzL2Fic3RyYWN0LWNvbnRyb2xsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBb0IsTUFBTSxlQUFlLENBQUM7QUFDM0QsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLE1BQU0sQ0FBQzs7QUFFN0I7Ozs7R0FJRztBQUVILE1BQU0sT0FBTyx5QkFBeUI7SUFHbEM7UUFGbUIsa0JBQWEsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO0lBRWpDLENBQUM7SUFFaEIsV0FBVztRQUNkLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyx3QkFBd0I7UUFDbkQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLHdEQUF3RDtJQUMzRixDQUFDO0lBRU0sSUFBSTtRQUNQLHlFQUF5RTtRQUN6RSw2RUFBNkU7UUFDN0UsNENBQTRDO1FBQzVDLGlEQUFpRDtRQUNqRCxNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzFCLENBQUM7O3NIQWhCUSx5QkFBeUI7MEdBQXpCLHlCQUF5QjsyRkFBekIseUJBQXlCO2tCQURyQyxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIEluamVjdCwgT25EZXN0cm95fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7U3ViamVjdH0gZnJvbSAncnhqcyc7XG5cbi8qKlxuICogVXNlXG4gKiBpbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG4gKiAucGlwZSh0YWtlVW50aWwodGhpcy5uZ1Vuc3Vic2NyaWJlKSkgYXMgZmlyc3QgcGlwZSBvbiBvYnNlcnZhYmxlcyB0aGF0IHNob3VsZCBiZSBkZXN0cm95ZWQgb24gY29tcG9uZW50IGRlc3Ryb3lcbiAqL1xuQERpcmVjdGl2ZSgpXG5leHBvcnQgY2xhc3MgTmF0dXJhbEFic3RyYWN0Q29udHJvbGxlciBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IG5nVW5zdWJzY3JpYmUgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKCkge31cblxuICAgIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5uZ1Vuc3Vic2NyaWJlLm5leHQoKTsgLy8gdW5zdWJzY3JpYmUgZXZlcnlib2R5XG4gICAgICAgIHRoaXMubmdVbnN1YnNjcmliZS5jb21wbGV0ZSgpOyAvLyBjb21wbGV0ZSB0aGUgc3RyZWFtLCBiZWNhdXNlIHdlIHdpbGwgbmV2ZXIgZW1pdCBhZ2FpblxuICAgIH1cblxuICAgIHB1YmxpYyBiYWNrKCk6IHZvaWQge1xuICAgICAgICAvLyBUaGlzIGlzIGJhZCwgYnV0IHdlIGRvbid0IHdhbnQgdG8gZm9yY2UgdGhlIGluamVjdGlvbiBvZiBkb2N1bWVudCBpbiAsXG4gICAgICAgIC8vIGFsbCBvdXIgY2hpbGQgY2xhc3Nlcy4gQW5kIGhvcGVmdWxseSB0aGlzIHBhcnRpY3VsYXIgbWV0aG9kIGlzIG9ubHkgY2FsbGVkXG4gICAgICAgIC8vIGJ5IGEgdXNlci1pbnRlcmFjdGlvbiwgc28gbm90IHVzZWQgaW4gU1NSXG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1yZXN0cmljdGVkLWdsb2JhbHNcbiAgICAgICAgd2luZG93Lmhpc3RvcnkuYmFjaygpO1xuICAgIH1cbn1cbiJdfQ==
@@ -1,5 +1,5 @@
1
1
  import { Directive } from '@angular/core';
2
- import { FormGroup } from '@angular/forms';
2
+ import { UntypedFormGroup } from '@angular/forms';
3
3
  import { ActivatedRoute, Router } from '@angular/router';
4
4
  import { kebabCase, merge, mergeWith, omit } from 'lodash-es';
5
5
  import { NaturalAlertService } from '../modules/alert/alert.service';
@@ -25,7 +25,7 @@ export class NaturalAbstractDetail extends NaturalAbstractPanel {
25
25
  /**
26
26
  * Form that manages the data from the controller
27
27
  */
28
- this.form = new FormGroup({});
28
+ this.form = new UntypedFormGroup({});
29
29
  /**
30
30
  * Show / hides the bottom fab button (mostly to hide it when we are on other tabs where semantic of button can conflict with ...
31
31
  * semantic of data on other tab, like relations that list other objects)
@@ -144,9 +144,9 @@ export class NaturalAbstractDetail extends NaturalAbstractPanel {
144
144
  mergeWith(this.data.model, this.form.value, mergeOverrideArray);
145
145
  }
146
146
  }
147
- NaturalAbstractDetail.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAbstractDetail, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
148
- NaturalAbstractDetail.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.0", type: NaturalAbstractDetail, usesInheritance: true, ngImport: i0 });
149
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAbstractDetail, decorators: [{
147
+ NaturalAbstractDetail.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAbstractDetail, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
148
+ NaturalAbstractDetail.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.1", type: NaturalAbstractDetail, usesInheritance: true, ngImport: i0 });
149
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAbstractDetail, decorators: [{
150
150
  type: Directive
151
151
  }], ctorParameters: function () { return [{ type: undefined }, { type: undefined }, { type: i0.Injector }]; } });
152
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-detail.js","sourceRoot":"","sources":["../../../../../projects/natural/src/lib/classes/abstract-detail.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Injector, OnInit} from '@angular/core';\nimport {FormGroup} from '@angular/forms';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {kebabCase, merge, mergeWith, omit} from 'lodash-es';\nimport {NaturalAlertService} from '../modules/alert/alert.service';\nimport {NaturalAbstractPanel} from '../modules/panels/abstract-panel';\nimport {NaturalAbstractModelService} from '../services/abstract-model.service';\nimport {ExtractTcreate, ExtractTone, ExtractTupdate, Literal} from '../types/types';\nimport {finalize} from 'rxjs/operators';\nimport {ifValid, validateAllFormControls} from './validators';\nimport {mergeOverrideArray} from './utility';\nimport {PaginatedData} from './data-source';\nimport {QueryVariables} from './query-variable-manager';\nimport {EMPTY, Observable} from 'rxjs';\n\n// @dynamic\n@Directive()\nexport class NaturalAbstractDetail<\n        TService extends NaturalAbstractModelService<\n            unknown,\n            any,\n            PaginatedData<Literal>,\n            QueryVariables,\n            any,\n            any,\n            any,\n            any,\n            unknown,\n            any\n        >,\n    >\n    extends NaturalAbstractPanel\n    implements OnInit\n{\n    /**\n     * Empty placeholder for data retrieved by the server\n     */\n    public data: any = {\n        model: {},\n    };\n\n    /**\n     * Form that manages the data from the controller\n     */\n    public form: FormGroup = new FormGroup({});\n\n    /**\n     * Show / hides the bottom fab button (mostly to hide it when we are on other tabs where semantic of button can conflict with ...\n     * semantic of data on other tab, like relations that list other objects)\n     */\n    public showFabButton = true;\n\n    /**\n     * Injected service\n     */\n    protected alertService: NaturalAlertService;\n\n    /**\n     * Injected service\n     */\n    protected router: Router;\n\n    /**\n     * Injected service\n     */\n    protected route: ActivatedRoute;\n\n    public constructor(\n        protected readonly key: string,\n        public readonly service: TService,\n        protected readonly injector: Injector,\n    ) {\n        super();\n\n        this.alertService = injector.get(NaturalAlertService);\n        this.router = injector.get(Router);\n        this.route = injector.get(ActivatedRoute);\n    }\n\n    public ngOnInit(): void {\n        if (!this.isPanel) {\n            this.route.data.subscribe(data => {\n                this.data = merge({model: this.service.getConsolidatedForClient()}, data[this.key]);\n                this.data = merge(this.data, omit(data, [this.key]));\n                this.initForm();\n            });\n        } else {\n            this.initForm();\n        }\n    }\n\n    public changeTab(index: number): void {\n        this.showFabButton = index === 0;\n    }\n\n    public update(now: boolean = false): void {\n        if (!this.data.model.id) {\n            return;\n        }\n\n        validateAllFormControls(this.form);\n\n        ifValid(this.form).subscribe(() => {\n            this.formToData();\n            const postUpdate = (model: ExtractTupdate<TService>): void => {\n                this.alertService.info($localize`Mis à jour`);\n                this.form.patchValue(model);\n                this.postUpdate(model);\n            };\n\n            if (now) {\n                this.service.updateNow(this.data.model).subscribe(postUpdate);\n            } else {\n                this.service.update(this.data.model).subscribe(postUpdate);\n            }\n        });\n    }\n\n    public create(redirect: boolean = true): void {\n        validateAllFormControls(this.form);\n\n        if (!this.form.valid) {\n            return;\n        }\n\n        this.formToData();\n        this.form.disable();\n\n        this.service\n            .create(this.data.model)\n            .pipe(finalize(() => this.form.enable()))\n            .subscribe(model => {\n                this.alertService.info($localize`Créé`);\n                this.form.patchValue(model);\n\n                this.postCreate(model).subscribe({\n                    complete: () => {\n                        if (redirect) {\n                            if (this.isPanel) {\n                                const oldUrl = this.router.url;\n                                const nextUrl = this.panelData?.config.params.nextRoute;\n                                const newUrl = oldUrl.replace('/new', '/' + model.id) + (nextUrl ? '/' + nextUrl : '');\n                                this.router.navigateByUrl(newUrl); // replace /new by /123\n                            } else {\n                                this.router.navigate(['..', model.id], {relativeTo: this.route});\n                            }\n                        }\n                    },\n                });\n            });\n    }\n\n    public delete(redirectionRoute?: unknown[]): void {\n        this.alertService\n            .confirm(\n                $localize`Suppression`,\n                $localize`Voulez-vous supprimer définitivement cet élément ?`,\n                $localize`Supprimer définitivement`,\n            )\n            .subscribe(confirmed => {\n                if (confirmed) {\n                    this.preDelete(this.data.model);\n                    this.form.disable();\n\n                    this.service\n                        .delete([this.data.model])\n                        .pipe(finalize(() => this.form.enable()))\n                        .subscribe(() => {\n                            this.alertService.info($localize`Supprimé`);\n\n                            if (!this.isPanel) {\n                                const defaultRoute = ['../../' + kebabCase(this.key)];\n                                this.router.navigate(redirectionRoute ? redirectionRoute : defaultRoute, {\n                                    relativeTo: this.route,\n                                });\n                            } else {\n                                this.panelService?.goToPenultimatePanel();\n                            }\n                        });\n                }\n            });\n    }\n\n    protected postUpdate(model: ExtractTupdate<TService>): void {}\n\n    /**\n     * Returns an observable that will be subscribed to immediately and the\n     * redirect navigation will only happen after the observable completes.\n     */\n    protected postCreate(model: ExtractTcreate<TService>): Observable<unknown> {\n        return EMPTY;\n    }\n\n    protected preDelete(model: ExtractTone<TService>): void {}\n\n    protected initForm(): void {\n        this.form = this.service.getFormGroup(this.data.model);\n    }\n\n    /**\n     * Merge values of form into `this.data.model`.\n     */\n    protected formToData(): void {\n        mergeWith(this.data.model, this.form.value, mergeOverrideArray);\n    }\n}\n"]}
152
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-detail.js","sourceRoot":"","sources":["../../../../../projects/natural/src/lib/classes/abstract-detail.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Injector, OnInit} from '@angular/core';\nimport {UntypedFormGroup} from '@angular/forms';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {kebabCase, merge, mergeWith, omit} from 'lodash-es';\nimport {NaturalAlertService} from '../modules/alert/alert.service';\nimport {NaturalAbstractPanel} from '../modules/panels/abstract-panel';\nimport {NaturalAbstractModelService} from '../services/abstract-model.service';\nimport {ExtractTcreate, ExtractTone, ExtractTupdate, Literal} from '../types/types';\nimport {finalize} from 'rxjs/operators';\nimport {ifValid, validateAllFormControls} from './validators';\nimport {mergeOverrideArray} from './utility';\nimport {PaginatedData} from './data-source';\nimport {QueryVariables} from './query-variable-manager';\nimport {EMPTY, Observable} from 'rxjs';\n\n// @dynamic\n@Directive()\nexport class NaturalAbstractDetail<\n        TService extends NaturalAbstractModelService<\n            unknown,\n            any,\n            PaginatedData<Literal>,\n            QueryVariables,\n            any,\n            any,\n            any,\n            any,\n            unknown,\n            any\n        >,\n    >\n    extends NaturalAbstractPanel\n    implements OnInit\n{\n    /**\n     * Empty placeholder for data retrieved by the server\n     */\n    public data: any = {\n        model: {},\n    };\n\n    /**\n     * Form that manages the data from the controller\n     */\n    public form: UntypedFormGroup = new UntypedFormGroup({});\n\n    /**\n     * Show / hides the bottom fab button (mostly to hide it when we are on other tabs where semantic of button can conflict with ...\n     * semantic of data on other tab, like relations that list other objects)\n     */\n    public showFabButton = true;\n\n    /**\n     * Injected service\n     */\n    protected alertService: NaturalAlertService;\n\n    /**\n     * Injected service\n     */\n    protected router: Router;\n\n    /**\n     * Injected service\n     */\n    protected route: ActivatedRoute;\n\n    public constructor(\n        protected readonly key: string,\n        public readonly service: TService,\n        protected readonly injector: Injector,\n    ) {\n        super();\n\n        this.alertService = injector.get(NaturalAlertService);\n        this.router = injector.get(Router);\n        this.route = injector.get(ActivatedRoute);\n    }\n\n    public ngOnInit(): void {\n        if (!this.isPanel) {\n            this.route.data.subscribe(data => {\n                this.data = merge({model: this.service.getConsolidatedForClient()}, data[this.key]);\n                this.data = merge(this.data, omit(data, [this.key]));\n                this.initForm();\n            });\n        } else {\n            this.initForm();\n        }\n    }\n\n    public changeTab(index: number): void {\n        this.showFabButton = index === 0;\n    }\n\n    public update(now: boolean = false): void {\n        if (!this.data.model.id) {\n            return;\n        }\n\n        validateAllFormControls(this.form);\n\n        ifValid(this.form).subscribe(() => {\n            this.formToData();\n            const postUpdate = (model: ExtractTupdate<TService>): void => {\n                this.alertService.info($localize`Mis à jour`);\n                this.form.patchValue(model);\n                this.postUpdate(model);\n            };\n\n            if (now) {\n                this.service.updateNow(this.data.model).subscribe(postUpdate);\n            } else {\n                this.service.update(this.data.model).subscribe(postUpdate);\n            }\n        });\n    }\n\n    public create(redirect: boolean = true): void {\n        validateAllFormControls(this.form);\n\n        if (!this.form.valid) {\n            return;\n        }\n\n        this.formToData();\n        this.form.disable();\n\n        this.service\n            .create(this.data.model)\n            .pipe(finalize(() => this.form.enable()))\n            .subscribe(model => {\n                this.alertService.info($localize`Créé`);\n                this.form.patchValue(model);\n\n                this.postCreate(model).subscribe({\n                    complete: () => {\n                        if (redirect) {\n                            if (this.isPanel) {\n                                const oldUrl = this.router.url;\n                                const nextUrl = this.panelData?.config.params.nextRoute;\n                                const newUrl = oldUrl.replace('/new', '/' + model.id) + (nextUrl ? '/' + nextUrl : '');\n                                this.router.navigateByUrl(newUrl); // replace /new by /123\n                            } else {\n                                this.router.navigate(['..', model.id], {relativeTo: this.route});\n                            }\n                        }\n                    },\n                });\n            });\n    }\n\n    public delete(redirectionRoute?: unknown[]): void {\n        this.alertService\n            .confirm(\n                $localize`Suppression`,\n                $localize`Voulez-vous supprimer définitivement cet élément ?`,\n                $localize`Supprimer définitivement`,\n            )\n            .subscribe(confirmed => {\n                if (confirmed) {\n                    this.preDelete(this.data.model);\n                    this.form.disable();\n\n                    this.service\n                        .delete([this.data.model])\n                        .pipe(finalize(() => this.form.enable()))\n                        .subscribe(() => {\n                            this.alertService.info($localize`Supprimé`);\n\n                            if (!this.isPanel) {\n                                const defaultRoute = ['../../' + kebabCase(this.key)];\n                                this.router.navigate(redirectionRoute ? redirectionRoute : defaultRoute, {\n                                    relativeTo: this.route,\n                                });\n                            } else {\n                                this.panelService?.goToPenultimatePanel();\n                            }\n                        });\n                }\n            });\n    }\n\n    protected postUpdate(model: ExtractTupdate<TService>): void {}\n\n    /**\n     * Returns an observable that will be subscribed to immediately and the\n     * redirect navigation will only happen after the observable completes.\n     */\n    protected postCreate(model: ExtractTcreate<TService>): Observable<unknown> {\n        return EMPTY;\n    }\n\n    protected preDelete(model: ExtractTone<TService>): void {}\n\n    protected initForm(): void {\n        this.form = this.service.getFormGroup(this.data.model);\n    }\n\n    /**\n     * Merge values of form into `this.data.model`.\n     */\n    protected formToData(): void {\n        mergeWith(this.data.model, this.form.value, mergeOverrideArray);\n    }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { FormArray, FormGroup } from '@angular/forms';
1
+ import { UntypedFormArray, UntypedFormGroup } from '@angular/forms';
2
2
  import { MatTableDataSource } from '@angular/material/table';
3
3
  import { merge } from 'lodash-es';
4
4
  import { NaturalAbstractController } from './abstract-controller';
@@ -30,11 +30,11 @@ export class NaturalAbstractEditableList extends NaturalAbstractController {
30
30
  constructor(service) {
31
31
  super();
32
32
  this.service = service;
33
- this.formArray = new FormArray([]);
33
+ this.formArray = new UntypedFormArray([]);
34
34
  this.variablesManager = new NaturalQueryVariablesManager();
35
35
  this.dataSource = new MatTableDataSource();
36
36
  // Create a form group with a line attributes that contain an array of formGroups (one by line = one by model)
37
- this.form = new FormGroup({ rows: this.formArray });
37
+ this.form = new UntypedFormGroup({ rows: this.formArray });
38
38
  this.dataSource.data = this.formArray.controls;
39
39
  this.variablesManager.set('pagination', { pagination: { pageSize: 999, pageIndex: 0 } });
40
40
  }
@@ -88,9 +88,9 @@ export class NaturalAbstractEditableList extends NaturalAbstractController {
88
88
  validateAllFormControls(this.form);
89
89
  }
90
90
  }
91
- NaturalAbstractEditableList.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAbstractEditableList, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
92
- NaturalAbstractEditableList.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.0", type: NaturalAbstractEditableList, usesInheritance: true, ngImport: i0 });
93
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAbstractEditableList, decorators: [{
91
+ NaturalAbstractEditableList.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAbstractEditableList, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
92
+ NaturalAbstractEditableList.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.1", type: NaturalAbstractEditableList, usesInheritance: true, ngImport: i0 });
93
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAbstractEditableList, decorators: [{
94
94
  type: Directive
95
95
  }], ctorParameters: function () { return [{ type: undefined }]; } });
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-editable-list.js","sourceRoot":"","sources":["../../../../../projects/natural/src/lib/classes/abstract-editable-list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,SAAS,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACrE,OAAO,EAAC,kBAAkB,EAAC,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAC,KAAK,EAAC,MAAM,WAAW,CAAC;AAEhC,OAAO,EAAC,yBAAyB,EAAC,MAAM,uBAAuB,CAAC;AAChE,OAAO,EAAC,4BAA4B,EAAiB,MAAM,0BAA0B,CAAC;AAEtF,OAAO,EAAC,uBAAuB,EAAC,MAAM,cAAc,CAAC;AACrD,OAAO,EAAC,SAAS,EAAC,MAAM,eAAe,CAAC;;AAGxC;;;;;;;;;;;;;;;;;;;GAmBG;AAEH,MAAM,OAAO,2BAgBX,SAAQ,yBAAyB;IAM/B,YAAsC,OAAiB;QACnD,KAAK,EAAE,CAAC;QAD0B,YAAO,GAAP,OAAO,CAAU;QAJvC,cAAS,GAAG,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;QAC9B,qBAAgB,GAAG,IAAI,4BAA4B,EAAyB,CAAC;QAC7E,eAAU,GAAG,IAAI,kBAAkB,EAAmB,CAAC;QAKnE,8GAA8G;QAC9G,IAAI,CAAC,IAAI,GAAG,IAAI,SAAS,CAAC,EAAC,IAAI,EAAE,IAAI,CAAC,SAAS,EAAC,CAAC,CAAC;QAClD,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;QAC/C,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,YAAY,EAAE,EAAC,UAAU,EAAE,EAAC,QAAQ,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,EAAC,EAA0B,CAAC,CAAC;IAClH,CAAC;IAED;;OAEG;IACI,QAAQ,CAAC,KAAU;QACtB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,aAAa;QACrC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAED;;;OAGG;IACI,QAAQ,CAAC,KAAU;QACtB,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACjB,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,wBAAwB,EAAE,EAAE,IAAI,CAAC,CAAC;YAC3E,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;YAC/D,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;IACnD,CAAC;IAEM,QAAQ,CAAC,KAAa;QACzB,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;IACnD,CAAC;IAED;;OAEG;IACI,QAAQ;QACX,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAO,CAAC,CAAC,CAAC;IAC7B,CAAC;IAED;;;;;;;;OAQG;IACI,QAAQ;QACX,OAAO,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;IACxC,CAAC;IAED;;;;OAIG;IACI,YAAY;QACf,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;;wHArFQ,2BAA2B;4GAA3B,2BAA2B;2FAA3B,2BAA2B;kBADvC,SAAS","sourcesContent":["import {AbstractControl, FormArray, FormGroup} from '@angular/forms';\nimport {MatTableDataSource} from '@angular/material/table';\nimport {merge} from 'lodash-es';\nimport {NaturalAbstractModelService} from '../services/abstract-model.service';\nimport {NaturalAbstractController} from './abstract-controller';\nimport {NaturalQueryVariablesManager, QueryVariables} from './query-variable-manager';\nimport {ExtractTallOne, ExtractVall, Literal} from '../types/types';\nimport {validateAllFormControls} from './validators';\nimport {Directive} from '@angular/core';\nimport {PaginatedData} from './data-source';\n\n/**\n * This class helps managing non-paginated rows of items that can be edited in-place, typically in a <mat-table>.\n * But it does **not** mutate anything to persist the edits on the server. It is up to the consuming component to implement\n * custom mutation mechanism.\n *\n * To access data of this component from a parent component, use:\n *\n * ```\n * @ViewChildren(ComponentType) cmp: ComponentType;\n * this.cmp.getItems();\n * ```\n *\n * To add empty line, call:\n *\n * ```\n * this.cmp.addEmpty();\n * ```\n *\n * @dynamic\n */\n@Directive()\nexport class NaturalAbstractEditableList<\n    TService extends NaturalAbstractModelService<\n        any,\n        any,\n        PaginatedData<Literal>,\n        QueryVariables,\n        any,\n        any,\n        any,\n        any,\n        any,\n        any\n    >,\n    // The Literal here is a bit too loose. Ideally we would like to express\n    // \"it must be a union and one of the type in the union must be ExtractTallOne<TService>\"\n    T extends Literal = ExtractTallOne<TService>,\n> extends NaturalAbstractController {\n    public readonly form: FormGroup;\n    public readonly formArray = new FormArray([]);\n    public readonly variablesManager = new NaturalQueryVariablesManager<ExtractVall<TService>>();\n    public readonly dataSource = new MatTableDataSource<AbstractControl>();\n\n    public constructor(protected readonly service: TService) {\n        super();\n\n        // Create a form group with a line attributes that contain an array of formGroups (one by line = one by model)\n        this.form = new FormGroup({rows: this.formArray});\n        this.dataSource.data = this.formArray.controls;\n        this.variablesManager.set('pagination', {pagination: {pageSize: 999, pageIndex: 0}} as ExtractVall<TService>);\n    }\n\n    /**\n     * Set the list of items (overwriting what may have existed)\n     */\n    public setItems(items: T[]): void {\n        this.formArray.clear(); // reset list\n        this.addItems(items);\n    }\n\n    /**\n     * Add given items to the list\n     * Reproduces the model data loading the same way as it would be on a detail page (via AbstractDetail controller) but without resolving\n     */\n    public addItems(items: T[]): void {\n        items.forEach(item => {\n            const completedItem = merge(this.service.getConsolidatedForClient(), item);\n            const lineFormGroup = this.service.getFormGroup(completedItem);\n            this.formArray.push(lineFormGroup);\n        });\n\n        this.dataSource.data = this.formArray.controls;\n    }\n\n    public removeAt(index: number): void {\n        this.formArray.removeAt(index);\n        this.dataSource.data = this.formArray.controls;\n    }\n\n    /**\n     * Add empty item at the end of the list\n     */\n    public addEmpty(): void {\n        this.addItems([{} as T]);\n    }\n\n    /**\n     * Return a list of models without any treatment.\n     *\n     * To mutate models, it would be required to map them using :\n     *  - AbstractModelService.getInput()\n     *  - AbstractModelService.getPartialVariablesForCreation()\n     *  - AbstractModelService.getPartialVariablesForUpdate()\n     *  - some other required treatment.\n     */\n    public getItems(): T[] {\n        return this.formArray.getRawValue();\n    }\n\n    /**\n     * Force the form validation.\n     *\n     * The valid state can then be read via `this.form.valid`\n     */\n    public validateForm(): void {\n        validateAllFormControls(this.form);\n    }\n}\n"]}
96
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-editable-list.js","sourceRoot":"","sources":["../../../../../projects/natural/src/lib/classes/abstract-editable-list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,gBAAgB,EAAE,gBAAgB,EAAC,MAAM,gBAAgB,CAAC;AACnF,OAAO,EAAC,kBAAkB,EAAC,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAC,KAAK,EAAC,MAAM,WAAW,CAAC;AAEhC,OAAO,EAAC,yBAAyB,EAAC,MAAM,uBAAuB,CAAC;AAChE,OAAO,EAAC,4BAA4B,EAAiB,MAAM,0BAA0B,CAAC;AAEtF,OAAO,EAAC,uBAAuB,EAAC,MAAM,cAAc,CAAC;AACrD,OAAO,EAAC,SAAS,EAAC,MAAM,eAAe,CAAC;;AAGxC;;;;;;;;;;;;;;;;;;;GAmBG;AAEH,MAAM,OAAO,2BAgBX,SAAQ,yBAAyB;IAM/B,YAAsC,OAAiB;QACnD,KAAK,EAAE,CAAC;QAD0B,YAAO,GAAP,OAAO,CAAU;QAJvC,cAAS,GAAG,IAAI,gBAAgB,CAAC,EAAE,CAAC,CAAC;QACrC,qBAAgB,GAAG,IAAI,4BAA4B,EAAyB,CAAC;QAC7E,eAAU,GAAG,IAAI,kBAAkB,EAAmB,CAAC;QAKnE,8GAA8G;QAC9G,IAAI,CAAC,IAAI,GAAG,IAAI,gBAAgB,CAAC,EAAC,IAAI,EAAE,IAAI,CAAC,SAAS,EAAC,CAAC,CAAC;QACzD,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;QAC/C,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,YAAY,EAAE,EAAC,UAAU,EAAE,EAAC,QAAQ,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,EAAC,EAA0B,CAAC,CAAC;IAClH,CAAC;IAED;;OAEG;IACI,QAAQ,CAAC,KAAU;QACtB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,aAAa;QACrC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAED;;;OAGG;IACI,QAAQ,CAAC,KAAU;QACtB,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACjB,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,wBAAwB,EAAE,EAAE,IAAI,CAAC,CAAC;YAC3E,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;YAC/D,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;IACnD,CAAC;IAEM,QAAQ,CAAC,KAAa;QACzB,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;IACnD,CAAC;IAED;;OAEG;IACI,QAAQ;QACX,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAO,CAAC,CAAC,CAAC;IAC7B,CAAC;IAED;;;;;;;;OAQG;IACI,QAAQ;QACX,OAAO,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;IACxC,CAAC;IAED;;;;OAIG;IACI,YAAY;QACf,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;;wHArFQ,2BAA2B;4GAA3B,2BAA2B;2FAA3B,2BAA2B;kBADvC,SAAS","sourcesContent":["import {AbstractControl, UntypedFormArray, UntypedFormGroup} from '@angular/forms';\nimport {MatTableDataSource} from '@angular/material/table';\nimport {merge} from 'lodash-es';\nimport {NaturalAbstractModelService} from '../services/abstract-model.service';\nimport {NaturalAbstractController} from './abstract-controller';\nimport {NaturalQueryVariablesManager, QueryVariables} from './query-variable-manager';\nimport {ExtractTallOne, ExtractVall, Literal} from '../types/types';\nimport {validateAllFormControls} from './validators';\nimport {Directive} from '@angular/core';\nimport {PaginatedData} from './data-source';\n\n/**\n * This class helps managing non-paginated rows of items that can be edited in-place, typically in a <mat-table>.\n * But it does **not** mutate anything to persist the edits on the server. It is up to the consuming component to implement\n * custom mutation mechanism.\n *\n * To access data of this component from a parent component, use:\n *\n * ```\n * @ViewChildren(ComponentType) cmp: ComponentType;\n * this.cmp.getItems();\n * ```\n *\n * To add empty line, call:\n *\n * ```\n * this.cmp.addEmpty();\n * ```\n *\n * @dynamic\n */\n@Directive()\nexport class NaturalAbstractEditableList<\n    TService extends NaturalAbstractModelService<\n        any,\n        any,\n        PaginatedData<Literal>,\n        QueryVariables,\n        any,\n        any,\n        any,\n        any,\n        any,\n        any\n    >,\n    // The Literal here is a bit too loose. Ideally we would like to express\n    // \"it must be a union and one of the type in the union must be ExtractTallOne<TService>\"\n    T extends Literal = ExtractTallOne<TService>,\n> extends NaturalAbstractController {\n    public readonly form: UntypedFormGroup;\n    public readonly formArray = new UntypedFormArray([]);\n    public readonly variablesManager = new NaturalQueryVariablesManager<ExtractVall<TService>>();\n    public readonly dataSource = new MatTableDataSource<AbstractControl>();\n\n    public constructor(protected readonly service: TService) {\n        super();\n\n        // Create a form group with a line attributes that contain an array of formGroups (one by line = one by model)\n        this.form = new UntypedFormGroup({rows: this.formArray});\n        this.dataSource.data = this.formArray.controls;\n        this.variablesManager.set('pagination', {pagination: {pageSize: 999, pageIndex: 0}} as ExtractVall<TService>);\n    }\n\n    /**\n     * Set the list of items (overwriting what may have existed)\n     */\n    public setItems(items: T[]): void {\n        this.formArray.clear(); // reset list\n        this.addItems(items);\n    }\n\n    /**\n     * Add given items to the list\n     * Reproduces the model data loading the same way as it would be on a detail page (via AbstractDetail controller) but without resolving\n     */\n    public addItems(items: T[]): void {\n        items.forEach(item => {\n            const completedItem = merge(this.service.getConsolidatedForClient(), item);\n            const lineFormGroup = this.service.getFormGroup(completedItem);\n            this.formArray.push(lineFormGroup);\n        });\n\n        this.dataSource.data = this.formArray.controls;\n    }\n\n    public removeAt(index: number): void {\n        this.formArray.removeAt(index);\n        this.dataSource.data = this.formArray.controls;\n    }\n\n    /**\n     * Add empty item at the end of the list\n     */\n    public addEmpty(): void {\n        this.addItems([{} as T]);\n    }\n\n    /**\n     * Return a list of models without any treatment.\n     *\n     * To mutate models, it would be required to map them using :\n     *  - AbstractModelService.getInput()\n     *  - AbstractModelService.getPartialVariablesForCreation()\n     *  - AbstractModelService.getPartialVariablesForUpdate()\n     *  - some other required treatment.\n     */\n    public getItems(): T[] {\n        return this.formArray.getRawValue();\n    }\n\n    /**\n     * Force the form validation.\n     *\n     * The valid state can then be read via `this.form.valid`\n     */\n    public validateForm(): void {\n        validateAllFormControls(this.form);\n    }\n}\n"]}
@@ -392,9 +392,9 @@ export class NaturalAbstractList extends NaturalAbstractPanel {
392
392
  }
393
393
  }
394
394
  }
395
- NaturalAbstractList.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAbstractList, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
396
- NaturalAbstractList.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.0", type: NaturalAbstractList, inputs: { persistSearch: "persistSearch", selectedColumns: "selectedColumns", forcedVariables: "forcedVariables" }, usesInheritance: true, ngImport: i0 });
397
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAbstractList, decorators: [{
395
+ NaturalAbstractList.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAbstractList, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
396
+ NaturalAbstractList.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.1", type: NaturalAbstractList, inputs: { persistSearch: "persistSearch", selectedColumns: "selectedColumns", forcedVariables: "forcedVariables" }, usesInheritance: true, ngImport: i0 });
397
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAbstractList, decorators: [{
398
398
  type: Directive
399
399
  }], ctorParameters: function () { return [{ type: undefined }, { type: i0.Injector }]; }, propDecorators: { persistSearch: [{
400
400
  type: Input
@@ -116,9 +116,9 @@ export class NaturalAbstractNavigableList extends NaturalAbstractList {
116
116
  return [item];
117
117
  }
118
118
  }
119
- NaturalAbstractNavigableList.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAbstractNavigableList, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
120
- NaturalAbstractNavigableList.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.0", type: NaturalAbstractNavigableList, inputs: { ancestorRelationName: "ancestorRelationName" }, usesInheritance: true, ngImport: i0 });
121
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAbstractNavigableList, decorators: [{
119
+ NaturalAbstractNavigableList.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAbstractNavigableList, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
120
+ NaturalAbstractNavigableList.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.1", type: NaturalAbstractNavigableList, inputs: { ancestorRelationName: "ancestorRelationName" }, usesInheritance: true, ngImport: i0 });
121
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAbstractNavigableList, decorators: [{
122
122
  type: Directive
123
123
  }], ctorParameters: function () { return [{ type: undefined }, { type: i0.Injector }]; }, propDecorators: { ancestorRelationName: [{
124
124
  type: Input
@@ -176,4 +176,4 @@ const twoDecimals = decimal(2);
176
176
  export function money(control) {
177
177
  return twoDecimals(control) ? { money: true } : null;
178
178
  }
179
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../../../../projects/natural/src/lib/classes/validators.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AbstractControl,\n    AsyncValidatorFn,\n    FormArray,\n    FormControlStatus,\n    FormGroup,\n    ValidationErrors,\n    ValidatorFn,\n    Validators,\n} from '@angular/forms';\nimport {Observable, of, timer} from 'rxjs';\nimport {filter, first, map, switchMap} from 'rxjs/operators';\nimport {NaturalAbstractModelService} from '../services/abstract-model.service';\nimport {NaturalQueryVariablesManager, QueryVariables} from './query-variable-manager';\nimport {validTlds} from './tld';\nimport {FilterGroupCondition} from '../modules/search/classes/graphql-doctrine.types';\n\n/**\n * Returns an async validator function that checks that the form control value is unique\n */\nexport function unique<TService extends NaturalAbstractModelService<any, any, any, any, any, any, any, any, any, any>>(\n    fieldName: string,\n    excludedId: string | null | undefined,\n    modelService: TService,\n): AsyncValidatorFn {\n    return (control: AbstractControl): Observable<ValidationErrors | null> => {\n        if (!control.value || !control.dirty) {\n            return of(null);\n        }\n\n        const condition: FilterGroupCondition = {};\n        condition[fieldName] = {equal: {value: control.value}};\n\n        if (excludedId) {\n            condition['id'] = {equal: {value: excludedId, not: true}};\n        }\n\n        const variables: QueryVariables = {\n            pagination: {pageIndex: 0, pageSize: 0},\n            filter: {groups: [{conditions: [condition]}]},\n        };\n\n        const qvm = new NaturalQueryVariablesManager();\n        qvm.set('variables', variables);\n\n        return timer(500).pipe(\n            switchMap(() => modelService.count(qvm).pipe(map(count => (count > 0 ? {duplicateValue: count} : null)))),\n        );\n    };\n}\n\n/**\n * Returns an async validator function that checks that the form control value is available\n *\n * Similar to `unique` validator, but allows to use a custom query for when the client does\n * not have permissions for `modelService.count()`.\n */\nexport function available(\n    getAvailableQuery: (value: string, excludedId: string | null) => Observable<boolean>,\n    excludedId: string | null = null,\n): AsyncValidatorFn {\n    return (control: AbstractControl): Observable<ValidationErrors | null> => {\n        if (!control.value || !control.dirty) {\n            return of(null);\n        }\n\n        return timer(500).pipe(\n            switchMap(() =>\n                getAvailableQuery(control.value, excludedId).pipe(\n                    map(isAvailable => (isAvailable ? null : {available: true})),\n                ),\n            ),\n        );\n    };\n}\n\n/**\n * Return all errors recursively for the given Form or control\n */\nexport function collectErrors(control: AbstractControl): ValidationErrors | null {\n    let errors: ValidationErrors | null = null;\n    if (control instanceof FormGroup || control instanceof FormArray) {\n        errors = Object.entries(control.controls).reduce((acc: ValidationErrors | null, [key, childControl]) => {\n            const childErrors = collectErrors(childControl);\n            if (childErrors) {\n                acc = {...acc, [key]: childErrors};\n            }\n            return acc;\n        }, null);\n    }\n\n    if (!errors) {\n        errors = control.errors;\n    }\n\n    return errors;\n}\n\n/**\n * Force validation of all form controls recursively.\n *\n * Recursively mark descending form tree as dirty and touched in order to show all invalid fields on demand.\n * Typically used when creating a new object and user clicked on create button but several fields were not\n * touched and are invalid.\n */\nexport function validateAllFormControls(control: AbstractControl): void {\n    control.markAsDirty({onlySelf: true});\n    control.markAsTouched({onlySelf: true});\n\n    if (control instanceof FormGroup || control instanceof FormArray) {\n        for (const [, child] of Object.entries(control.controls)) {\n            validateAllFormControls(child);\n        }\n    }\n}\n\nfunction isValid(status: FormControlStatus): status is 'VALID' {\n    return status === 'VALID';\n}\n\n/**\n * Emits exactly 0 or 1 time:\n *\n * - if the form is VALID, emits immediately\n * - if the form is PENDING emits if it changes from PENDING to VALID\n * - any other cases will **never** emit\n */\nexport function ifValid(control: AbstractControl): Observable<'VALID'> {\n    const observable = control.pending ? control.statusChanges.pipe(first()) : of(control.status);\n\n    return observable.pipe(filter(isValid));\n}\n\n// This is is an approximation of RFC_5322 where the hostname:\n//\n// - is too strict because it rejects IP address\n// - is too lax because it accepts pretty much anything else\n//\n// but the TLD will be validated against a whitelist so that should make the whole thing acceptable\nconst RFC_5322 = /^[a-zA-Z0-9.!#$%&'*+\\/=?^_`{|}~-]+@[^@ ]+\\.[^@]+$/u;\n\n/**\n * Validate an email address according to RFC, and also that it is publicly deliverable (not \"root@localhost\" or \"root@127.0.0.1\")\n *\n * This is meant to replace **all** usages of Angular too permissive `Validators.email`\n */\nexport function deliverableEmail(control: AbstractControl): ValidationErrors | null {\n    // don't validate empty values to allow optional controls\n    const value = control.value;\n    if (!value) {\n        return null;\n    }\n\n    const error = {email: true};\n    if (value.length > 254) {\n        return error;\n    }\n\n    if (!RFC_5322.test(value)) {\n        return error;\n    }\n\n    const tld = value.split('.').pop();\n    if (!validTlds.includes(tld)) {\n        return error;\n    }\n\n    return null;\n}\n\n/**\n * Naive URL validator for \"normal\" web links, that is a bit too permissive\n *\n * It enforces:\n *\n *     - http/https protocol\n *     - one domain\n *     - one tld\n *\n * It allows:\n *\n *     - any number of subdomains\n *     - any parameters\n *     - any fragments\n *     - any characters for any parts (does not conform to rfc1738)\n */\nexport const urlValidator = Validators.pattern(/^https?:\\/\\/(?:[^.\\s]+\\.)+[^.\\s]+$/);\n\n/**\n * Validates that the value is an integer (non-float)\n */\nexport function integer(control: AbstractControl): ValidationErrors | null {\n    // Don't validate empty values to allow optional controls\n    if (control.value === null || control.value === undefined || control.value === '') {\n        return null;\n    }\n\n    return Number.isInteger(parseFloat(control.value)) ? null : {integer: true};\n}\n\n/**\n * Validate that the value is a decimal number with up to `scale` digits\n *\n * The error contains the expected scale, so that the error message can explain\n * it to the end-user.\n */\nexport function decimal(scale: number): ValidatorFn {\n    const regExp = new RegExp(`^-?\\\\d+(\\\\.\\\\d{0,${scale}})?$`);\n    return control => {\n        // Don't validate empty values to allow optional controls\n        if (control.value === null || control.value === undefined || control.value === '') {\n            return null;\n        }\n\n        const value = '' + control.value;\n        if (value.match(regExp)) {\n            return null;\n        }\n\n        return {decimal: scale};\n    };\n}\n\n/**\n * For internal use to avoid re-creating regexp on each call of `money`\n */\nconst twoDecimals = decimal(2);\n\n/**\n * Validate that the value is an amount of money, meaning a number with at most 2 decimals\n */\nexport function money(control: AbstractControl): ValidationErrors | null {\n    return twoDecimals(control) ? {money: true} : null;\n}\n"]}
179
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../../../../projects/natural/src/lib/classes/validators.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AbstractControl,\n    AsyncValidatorFn,\n    FormArray,\n    FormControlStatus,\n    FormGroup,\n    ValidationErrors,\n    ValidatorFn,\n    Validators,\n} from '@angular/forms';\nimport {Observable, of, timer} from 'rxjs';\nimport {filter, first, map, switchMap} from 'rxjs/operators';\nimport {NaturalAbstractModelService} from '../services/abstract-model.service';\nimport {NaturalQueryVariablesManager, QueryVariables} from './query-variable-manager';\nimport {validTlds} from './tld';\nimport {FilterGroupCondition} from '../modules/search/classes/graphql-doctrine.types';\n\n/**\n * Returns an async validator function that checks that the form control value is unique\n */\nexport function unique<TService extends NaturalAbstractModelService<any, any, any, any, any, any, any, any, any, any>>(\n    fieldName: string,\n    excludedId: string | null | undefined,\n    modelService: TService,\n): AsyncValidatorFn {\n    return (control: AbstractControl): Observable<ValidationErrors | null> => {\n        if (!control.value || !control.dirty) {\n            return of(null);\n        }\n\n        const condition: FilterGroupCondition = {};\n        condition[fieldName] = {equal: {value: control.value}};\n\n        if (excludedId) {\n            condition['id'] = {equal: {value: excludedId, not: true}};\n        }\n\n        const variables: QueryVariables = {\n            pagination: {pageIndex: 0, pageSize: 0},\n            filter: {groups: [{conditions: [condition]}]},\n        };\n\n        const qvm = new NaturalQueryVariablesManager();\n        qvm.set('variables', variables);\n\n        return timer(500).pipe(\n            switchMap(() => modelService.count(qvm).pipe(map(count => (count > 0 ? {duplicateValue: count} : null)))),\n        );\n    };\n}\n\n/**\n * Returns an async validator function that checks that the form control value is available\n *\n * Similar to `unique` validator, but allows to use a custom query for when the client does\n * not have permissions for `modelService.count()`.\n */\nexport function available(\n    getAvailableQuery: (value: string, excludedId: string | null) => Observable<boolean>,\n    excludedId: string | null = null,\n): AsyncValidatorFn {\n    return (control: AbstractControl): Observable<ValidationErrors | null> => {\n        if (!control.value || !control.dirty) {\n            return of(null);\n        }\n\n        return timer(500).pipe(\n            switchMap(() =>\n                getAvailableQuery(control.value, excludedId).pipe(\n                    map(isAvailable => (isAvailable ? null : {available: true})),\n                ),\n            ),\n        );\n    };\n}\n\n/**\n * Return all errors recursively for the given Form or control\n */\nexport function collectErrors(control: AbstractControl<unknown>): ValidationErrors | null {\n    let errors: ValidationErrors | null = null;\n    if (control instanceof FormGroup || control instanceof FormArray) {\n        errors = Object.entries(control.controls).reduce((acc: ValidationErrors | null, [key, childControl]) => {\n            const childErrors = collectErrors(childControl);\n            if (childErrors) {\n                acc = {...acc, [key]: childErrors};\n            }\n            return acc;\n        }, null);\n    }\n\n    if (!errors) {\n        errors = control.errors;\n    }\n\n    return errors;\n}\n\n/**\n * Force validation of all form controls recursively.\n *\n * Recursively mark descending form tree as dirty and touched in order to show all invalid fields on demand.\n * Typically used when creating a new object and user clicked on create button but several fields were not\n * touched and are invalid.\n */\nexport function validateAllFormControls(control: AbstractControl<unknown>): void {\n    control.markAsDirty({onlySelf: true});\n    control.markAsTouched({onlySelf: true});\n\n    if (control instanceof FormGroup || control instanceof FormArray) {\n        for (const [, child] of Object.entries(control.controls)) {\n            validateAllFormControls(child);\n        }\n    }\n}\n\nfunction isValid(status: FormControlStatus): status is 'VALID' {\n    return status === 'VALID';\n}\n\n/**\n * Emits exactly 0 or 1 time:\n *\n * - if the form is VALID, emits immediately\n * - if the form is PENDING emits if it changes from PENDING to VALID\n * - any other cases will **never** emit\n */\nexport function ifValid(control: AbstractControl): Observable<'VALID'> {\n    const observable = control.pending ? control.statusChanges.pipe(first()) : of(control.status);\n\n    return observable.pipe(filter(isValid));\n}\n\n// This is is an approximation of RFC_5322 where the hostname:\n//\n// - is too strict because it rejects IP address\n// - is too lax because it accepts pretty much anything else\n//\n// but the TLD will be validated against a whitelist so that should make the whole thing acceptable\nconst RFC_5322 = /^[a-zA-Z0-9.!#$%&'*+\\/=?^_`{|}~-]+@[^@ ]+\\.[^@]+$/u;\n\n/**\n * Validate an email address according to RFC, and also that it is publicly deliverable (not \"root@localhost\" or \"root@127.0.0.1\")\n *\n * This is meant to replace **all** usages of Angular too permissive `Validators.email`\n */\nexport function deliverableEmail(control: AbstractControl): ValidationErrors | null {\n    // don't validate empty values to allow optional controls\n    const value = control.value;\n    if (!value) {\n        return null;\n    }\n\n    const error = {email: true};\n    if (value.length > 254) {\n        return error;\n    }\n\n    if (!RFC_5322.test(value)) {\n        return error;\n    }\n\n    const tld = value.split('.').pop();\n    if (!validTlds.includes(tld)) {\n        return error;\n    }\n\n    return null;\n}\n\n/**\n * Naive URL validator for \"normal\" web links, that is a bit too permissive\n *\n * It enforces:\n *\n *     - http/https protocol\n *     - one domain\n *     - one tld\n *\n * It allows:\n *\n *     - any number of subdomains\n *     - any parameters\n *     - any fragments\n *     - any characters for any parts (does not conform to rfc1738)\n */\nexport const urlValidator = Validators.pattern(/^https?:\\/\\/(?:[^.\\s]+\\.)+[^.\\s]+$/);\n\n/**\n * Validates that the value is an integer (non-float)\n */\nexport function integer(control: AbstractControl): ValidationErrors | null {\n    // Don't validate empty values to allow optional controls\n    if (control.value === null || control.value === undefined || control.value === '') {\n        return null;\n    }\n\n    return Number.isInteger(parseFloat(control.value)) ? null : {integer: true};\n}\n\n/**\n * Validate that the value is a decimal number with up to `scale` digits\n *\n * The error contains the expected scale, so that the error message can explain\n * it to the end-user.\n */\nexport function decimal(scale: number): ValidatorFn {\n    const regExp = new RegExp(`^-?\\\\d+(\\\\.\\\\d{0,${scale}})?$`);\n    return control => {\n        // Don't validate empty values to allow optional controls\n        if (control.value === null || control.value === undefined || control.value === '') {\n            return null;\n        }\n\n        const value = '' + control.value;\n        if (value.match(regExp)) {\n            return null;\n        }\n\n        return {decimal: scale};\n    };\n}\n\n/**\n * For internal use to avoid re-creating regexp on each call of `money`\n */\nconst twoDecimals = decimal(2);\n\n/**\n * Validate that the value is an amount of money, meaning a number with at most 2 decimals\n */\nexport function money(control: AbstractControl): ValidationErrors | null {\n    return twoDecimals(control) ? {money: true} : null;\n}\n"]}
@@ -34,9 +34,9 @@ export class NaturalHttpPrefixDirective extends NaturalAbstractController {
34
34
  }
35
35
  }
36
36
  }
37
- NaturalHttpPrefixDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalHttpPrefixDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
38
- NaturalHttpPrefixDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.0", type: NaturalHttpPrefixDirective, selector: "[naturalHttpPrefix]", inputs: { naturalHttpPrefix: "naturalHttpPrefix" }, host: { listeners: { "ngModelChange": "httpize($event)" } }, usesInheritance: true, ngImport: i0 });
39
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalHttpPrefixDirective, decorators: [{
37
+ NaturalHttpPrefixDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalHttpPrefixDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
38
+ NaturalHttpPrefixDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.1", type: NaturalHttpPrefixDirective, selector: "[naturalHttpPrefix]", inputs: { naturalHttpPrefix: "naturalHttpPrefix" }, host: { listeners: { "ngModelChange": "httpize($event)" } }, usesInheritance: true, ngImport: i0 });
39
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalHttpPrefixDirective, decorators: [{
40
40
  type: Directive,
41
41
  args: [{
42
42
  selector: '[naturalHttpPrefix]',
@@ -7,14 +7,14 @@ import { NaturalConfirmComponent } from './confirm.component';
7
7
  import * as i0 from "@angular/core";
8
8
  export class NaturalAlertModule {
9
9
  }
10
- NaturalAlertModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAlertModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
11
- NaturalAlertModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAlertModule, declarations: [NaturalConfirmComponent], imports: [CommonModule, MatDialogModule, MatSnackBarModule, MatButtonModule] });
12
- NaturalAlertModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAlertModule, imports: [[CommonModule, MatDialogModule, MatSnackBarModule, MatButtonModule]] });
13
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAlertModule, decorators: [{
10
+ NaturalAlertModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAlertModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
11
+ NaturalAlertModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.1", ngImport: i0, type: NaturalAlertModule, declarations: [NaturalConfirmComponent], imports: [CommonModule, MatDialogModule, MatSnackBarModule, MatButtonModule] });
12
+ NaturalAlertModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAlertModule, imports: [CommonModule, MatDialogModule, MatSnackBarModule, MatButtonModule] });
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAlertModule, decorators: [{
14
14
  type: NgModule,
15
15
  args: [{
16
16
  declarations: [NaturalConfirmComponent],
17
17
  imports: [CommonModule, MatDialogModule, MatSnackBarModule, MatButtonModule],
18
18
  }]
19
19
  }] });
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvYWxlcnQvYWxlcnQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDOUQsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0scUJBQXFCLENBQUM7O0FBTTVELE1BQU0sT0FBTyxrQkFBa0I7OytHQUFsQixrQkFBa0I7Z0hBQWxCLGtCQUFrQixpQkFIWix1QkFBdUIsYUFDNUIsWUFBWSxFQUFFLGVBQWUsRUFBRSxpQkFBaUIsRUFBRSxlQUFlO2dIQUVsRSxrQkFBa0IsWUFGbEIsQ0FBQyxZQUFZLEVBQUUsZUFBZSxFQUFFLGlCQUFpQixFQUFFLGVBQWUsQ0FBQzsyRkFFbkUsa0JBQWtCO2tCQUo5QixRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLHVCQUF1QixDQUFDO29CQUN2QyxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZUFBZSxFQUFFLGlCQUFpQixFQUFFLGVBQWUsQ0FBQztpQkFDL0UiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtNYXRCdXR0b25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQge01hdERpYWxvZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7TWF0U25hY2tCYXJNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NuYWNrLWJhcic7XG5pbXBvcnQge05hdHVyYWxDb25maXJtQ29tcG9uZW50fSBmcm9tICcuL2NvbmZpcm0uY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtOYXR1cmFsQ29uZmlybUNvbXBvbmVudF0sXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTWF0RGlhbG9nTW9kdWxlLCBNYXRTbmFja0Jhck1vZHVsZSwgTWF0QnV0dG9uTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbEFsZXJ0TW9kdWxlIHt9XG4iXX0=
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvYWxlcnQvYWxlcnQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDOUQsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0scUJBQXFCLENBQUM7O0FBTTVELE1BQU0sT0FBTyxrQkFBa0I7OytHQUFsQixrQkFBa0I7Z0hBQWxCLGtCQUFrQixpQkFIWix1QkFBdUIsYUFDNUIsWUFBWSxFQUFFLGVBQWUsRUFBRSxpQkFBaUIsRUFBRSxlQUFlO2dIQUVsRSxrQkFBa0IsWUFGakIsWUFBWSxFQUFFLGVBQWUsRUFBRSxpQkFBaUIsRUFBRSxlQUFlOzJGQUVsRSxrQkFBa0I7a0JBSjlCLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFLENBQUMsdUJBQXVCLENBQUM7b0JBQ3ZDLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxlQUFlLEVBQUUsaUJBQWlCLEVBQUUsZUFBZSxDQUFDO2lCQUMvRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge01hdEJ1dHRvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7TWF0RGlhbG9nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHtNYXRTbmFja0Jhck1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc25hY2stYmFyJztcbmltcG9ydCB7TmF0dXJhbENvbmZpcm1Db21wb25lbnR9IGZyb20gJy4vY29uZmlybS5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW05hdHVyYWxDb25maXJtQ29tcG9uZW50XSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBNYXREaWFsb2dNb2R1bGUsIE1hdFNuYWNrQmFyTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBOYXR1cmFsQWxlcnRNb2R1bGUge31cbiJdfQ==
@@ -44,9 +44,9 @@ export class NaturalAlertService {
44
44
  return dialog.afterClosed();
45
45
  }
46
46
  }
47
- NaturalAlertService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAlertService, deps: [{ token: i1.MatDialog }, { token: i2.MatSnackBar }], target: i0.ɵɵFactoryTarget.Injectable });
48
- NaturalAlertService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAlertService, providedIn: 'root' });
49
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAlertService, decorators: [{
47
+ NaturalAlertService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAlertService, deps: [{ token: i1.MatDialog }, { token: i2.MatSnackBar }], target: i0.ɵɵFactoryTarget.Injectable });
48
+ NaturalAlertService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAlertService, providedIn: 'root' });
49
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAlertService, decorators: [{
50
50
  type: Injectable,
51
51
  args: [{
52
52
  providedIn: 'root',
@@ -1,16 +1,16 @@
1
1
  import { Component, Inject } from '@angular/core';
2
2
  import { MAT_DIALOG_DATA } from '@angular/material/dialog';
3
3
  import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/material/button";
5
- import * as i2 from "@angular/material/dialog";
4
+ import * as i1 from "@angular/material/dialog";
5
+ import * as i2 from "@angular/material/button";
6
6
  export class NaturalConfirmComponent {
7
7
  constructor(data) {
8
8
  this.data = data;
9
9
  }
10
10
  }
11
- NaturalConfirmComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalConfirmComponent, deps: [{ token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
12
- NaturalConfirmComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.0", type: NaturalConfirmComponent, selector: "ng-component", ngImport: i0, template: "<h2 mat-dialog-title>{{ data.title }}</h2>\n<mat-dialog-content\n ><p class=\"mat-body\">{{ data.message }}</p></mat-dialog-content\n>\n<mat-dialog-actions>\n <button [mat-dialog-close]=\"false\" mat-button>{{ data.cancelText }}</button>\n <button [mat-dialog-close]=\"true\" mat-stroked-button cdkFocusInitial>{{ data.confirmText }}</button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-content{max-width:40em}mat-dialog-actions{display:flex;justify-content:flex-end}mat-dialog-actions>*{margin-left:10px}\n"], components: [{ type: i1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i2.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i2.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i2.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }] });
13
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalConfirmComponent, decorators: [{
11
+ NaturalConfirmComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalConfirmComponent, deps: [{ token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
12
+ NaturalConfirmComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.1", type: NaturalConfirmComponent, selector: "ng-component", ngImport: i0, template: "<h2 mat-dialog-title>{{ data.title }}</h2>\n<mat-dialog-content\n ><p class=\"mat-body\">{{ data.message }}</p></mat-dialog-content\n>\n<mat-dialog-actions>\n <button [mat-dialog-close]=\"false\" mat-button>{{ data.cancelText }}</button>\n <button [mat-dialog-close]=\"true\" mat-stroked-button cdkFocusInitial>{{ data.confirmText }}</button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-content{max-width:40em}mat-dialog-actions{display:flex;justify-content:flex-end}mat-dialog-actions>*{margin-left:10px}\n"], dependencies: [{ kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }] });
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalConfirmComponent, decorators: [{
14
14
  type: Component,
15
15
  args: [{ template: "<h2 mat-dialog-title>{{ data.title }}</h2>\n<mat-dialog-content\n ><p class=\"mat-body\">{{ data.message }}</p></mat-dialog-content\n>\n<mat-dialog-actions>\n <button [mat-dialog-close]=\"false\" mat-button>{{ data.cancelText }}</button>\n <button [mat-dialog-close]=\"true\" mat-stroked-button cdkFocusInitial>{{ data.confirmText }}</button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-content{max-width:40em}mat-dialog-actions{display:flex;justify-content:flex-end}mat-dialog-actions>*{margin-left:10px}\n"] }]
16
16
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
@@ -5,10 +5,10 @@ import * as i0 from "@angular/core";
5
5
  const declarations = [AvatarComponent];
6
6
  export class NaturalAvatarModule {
7
7
  }
8
- NaturalAvatarModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAvatarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
- NaturalAvatarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAvatarModule, declarations: [AvatarComponent], imports: [CommonModule], exports: [AvatarComponent] });
10
- NaturalAvatarModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAvatarModule, imports: [[CommonModule]] });
11
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalAvatarModule, decorators: [{
8
+ NaturalAvatarModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAvatarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
+ NaturalAvatarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.1", ngImport: i0, type: NaturalAvatarModule, declarations: [AvatarComponent], imports: [CommonModule], exports: [AvatarComponent] });
10
+ NaturalAvatarModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAvatarModule, imports: [CommonModule] });
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalAvatarModule, decorators: [{
12
12
  type: NgModule,
13
13
  args: [{
14
14
  imports: [CommonModule],
@@ -16,4 +16,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImpor
16
16
  exports: declarations,
17
17
  }]
18
18
  }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2F2YXRhci9hdmF0YXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQzs7QUFFN0QsTUFBTSxZQUFZLEdBQUcsQ0FBQyxlQUFlLENBQUMsQ0FBQztBQU92QyxNQUFNLE9BQU8sbUJBQW1COztnSEFBbkIsbUJBQW1CO2lIQUFuQixtQkFBbUIsaUJBUFYsZUFBZSxhQUd2QixZQUFZLGFBSEosZUFBZTtpSEFPeEIsbUJBQW1CLFlBSm5CLENBQUMsWUFBWSxDQUFDOzJGQUlkLG1CQUFtQjtrQkFML0IsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3ZCLFlBQVksRUFBRSxZQUFZO29CQUMxQixPQUFPLEVBQUUsWUFBWTtpQkFDeEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtBdmF0YXJDb21wb25lbnR9IGZyb20gJy4vY29tcG9uZW50L2F2YXRhci5jb21wb25lbnQnO1xuXG5jb25zdCBkZWNsYXJhdGlvbnMgPSBbQXZhdGFyQ29tcG9uZW50XTtcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgICBkZWNsYXJhdGlvbnM6IGRlY2xhcmF0aW9ucyxcbiAgICBleHBvcnRzOiBkZWNsYXJhdGlvbnMsXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxBdmF0YXJNb2R1bGUge31cbiJdfQ==
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2F2YXRhci9hdmF0YXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQzs7QUFFN0QsTUFBTSxZQUFZLEdBQUcsQ0FBQyxlQUFlLENBQUMsQ0FBQztBQU92QyxNQUFNLE9BQU8sbUJBQW1COztnSEFBbkIsbUJBQW1CO2lIQUFuQixtQkFBbUIsaUJBUFYsZUFBZSxhQUd2QixZQUFZLGFBSEosZUFBZTtpSEFPeEIsbUJBQW1CLFlBSmxCLFlBQVk7MkZBSWIsbUJBQW1CO2tCQUwvQixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsWUFBWSxFQUFFLFlBQVk7b0JBQzFCLE9BQU8sRUFBRSxZQUFZO2lCQUN4QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0F2YXRhckNvbXBvbmVudH0gZnJvbSAnLi9jb21wb25lbnQvYXZhdGFyLmNvbXBvbmVudCc7XG5cbmNvbnN0IGRlY2xhcmF0aW9ucyA9IFtBdmF0YXJDb21wb25lbnRdO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICAgIGRlY2xhcmF0aW9uczogZGVjbGFyYXRpb25zLFxuICAgIGV4cG9ydHM6IGRlY2xhcmF0aW9ucyxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbEF2YXRhck1vZHVsZSB7fVxuIl19
@@ -121,8 +121,8 @@ export class AvatarComponent {
121
121
  };
122
122
  }
123
123
  }
124
- AvatarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: AvatarComponent, deps: [{ token: i1.AvatarService }], target: i0.ɵɵFactoryTarget.Component });
125
- AvatarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.0", type: AvatarComponent, selector: "natural-avatar", inputs: { image: "image", initials: "initials", gravatar: "gravatar", size: "size", textSizeRatio: "textSizeRatio", bgColor: "bgColor", fgColor: "fgColor", borderRadius: "borderRadius", textMaximumLength: "textMaximumLength" }, usesOnChanges: true, ngImport: i0, template: `
124
+ AvatarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: AvatarComponent, deps: [{ token: i1.AvatarService }], target: i0.ɵɵFactoryTarget.Component });
125
+ AvatarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.1", type: AvatarComponent, selector: "natural-avatar", inputs: { image: "image", initials: "initials", gravatar: "gravatar", size: "size", textSizeRatio: "textSizeRatio", bgColor: "bgColor", fgColor: "fgColor", borderRadius: "borderRadius", textMaximumLength: "textMaximumLength" }, usesOnChanges: true, ngImport: i0, template: `
126
126
  <div class="avatar-container" [ngStyle]="hostStyle">
127
127
  <img
128
128
  *ngIf="avatarSrc"
@@ -138,19 +138,10 @@ AvatarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", versio
138
138
  {{ avatarText }}
139
139
  </div>
140
140
  </div>
141
- `, isInline: true, styles: [":host{border-radius:50%}\n"], directives: [{ type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
142
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: AvatarComponent, decorators: [{
141
+ `, isInline: true, styles: [":host{border-radius:50%}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
142
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: AvatarComponent, decorators: [{
143
143
  type: Component,
144
- args: [{
145
- selector: 'natural-avatar',
146
- styles: [
147
- `
148
- :host {
149
- border-radius: 50%;
150
- }
151
- `,
152
- ],
153
- template: `
144
+ args: [{ selector: 'natural-avatar', template: `
154
145
  <div class="avatar-container" [ngStyle]="hostStyle">
155
146
  <img
156
147
  *ngIf="avatarSrc"
@@ -166,8 +157,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImpor
166
157
  {{ avatarText }}
167
158
  </div>
168
159
  </div>
169
- `,
170
- }]
160
+ `, styles: [":host{border-radius:50%}\n"] }]
171
161
  }], ctorParameters: function () { return [{ type: i1.AvatarService }]; }, propDecorators: { image: [{
172
162
  type: Input
173
163
  }], initials: [{
@@ -187,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImpor
187
177
  }], textMaximumLength: [{
188
178
  type: Input
189
179
  }] } });
190
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/avatar/component/avatar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnChanges, SimpleChanges} from '@angular/core';\n\nimport {Source} from '../sources/source';\nimport {AvatarService} from '../service/avatar.service';\n\ntype Style = Partial<CSSStyleDeclaration>;\n\n/**\n * Show an avatar from different sources\n */\n@Component({\n    selector: 'natural-avatar',\n    styles: [\n        `\n            :host {\n                border-radius: 50%;\n            }\n        `,\n    ],\n    template: `\n        <div class=\"avatar-container\" [ngStyle]=\"hostStyle\">\n            <img\n                *ngIf=\"avatarSrc\"\n                [src]=\"avatarSrc\"\n                [width]=\"size\"\n                [height]=\"size\"\n                [ngStyle]=\"avatarStyle\"\n                (error)=\"tryNextSource()\"\n                class=\"avatar-content\"\n                loading=\"lazy\"\n            />\n            <div *ngIf=\"avatarText\" class=\"avatar-content\" [ngStyle]=\"avatarStyle\">\n                {{ avatarText }}\n            </div>\n        </div>\n    `,\n})\nexport class AvatarComponent implements OnChanges {\n    @Input() public image?: string | null;\n    @Input() public initials?: string | null;\n    @Input() public gravatar?: string | null;\n\n    @Input() public size = 50;\n    @Input() public textSizeRatio = 3;\n    @Input() public bgColor: string | undefined;\n    @Input() public fgColor = '#FFF';\n    @Input() public borderRadius = '';\n    @Input() public textMaximumLength = 0;\n\n    public avatarSrc: string | null = null;\n    public avatarText: string | null = null;\n    public avatarStyle: Style = {};\n    public hostStyle: Style = {};\n\n    private currentIndex = -1;\n    private sources: Source[] = [];\n\n    public constructor(private readonly avatarService: AvatarService) {}\n\n    /**\n     * Detect inputs change\n     */\n    public ngOnChanges(changes: SimpleChanges): void {\n        this.sources.length = 0;\n        for (const [propName, creator] of this.avatarService.getCreators()) {\n            if (!changes[propName]) {\n                continue;\n            }\n\n            const currentValue = changes[propName].currentValue;\n            if (currentValue && typeof currentValue === 'string') {\n                this.sources.push(new creator(currentValue));\n            }\n        }\n\n        // reinitialize the avatar component when a source property value has changed\n        // the fallback system must be re-invoked with the new values.\n        this.initializeAvatar();\n    }\n\n    /**\n     * Fetch avatar source\n     */\n    public tryNextSource(): void {\n        const previousSource = this.sources[this.currentIndex];\n        if (previousSource) {\n            this.avatarService.markSourceAsFailed(previousSource);\n        }\n\n        const source = this.findNextSource();\n        if (!source) {\n            this.clearAvatar();\n            return;\n        }\n\n        if (source.isTextual()) {\n            this.buildTextAvatar(source);\n        } else {\n            this.buildImageAvatar(source);\n        }\n    }\n\n    private findNextSource(): Source | null {\n        while (++this.currentIndex < this.sources.length) {\n            const source = this.sources[this.currentIndex];\n            if (source && !this.avatarService.sourceHasFailedBefore(source)) {\n                return source;\n            }\n        }\n\n        return null;\n    }\n\n    /**\n     * Initialize the avatar component and its fallback system\n     */\n    private initializeAvatar(): void {\n        this.currentIndex = -1;\n        if (this.sources.length > 0) {\n            this.tryNextSource();\n            this.hostStyle = {\n                width: this.size + 'px',\n                height: this.size + 'px',\n            };\n        }\n    }\n\n    private clearAvatar(): void {\n        this.avatarSrc = null;\n        this.avatarText = null;\n        this.avatarStyle = {};\n    }\n\n    private buildTextAvatar(avatarSource: Source): void {\n        this.clearAvatar();\n        this.avatarText = avatarSource.getAvatar(+this.textMaximumLength);\n        this.avatarStyle = this.getTextualStyle(avatarSource.getValue());\n    }\n\n    private buildImageAvatar(avatarSource: Source): void {\n        this.clearAvatar();\n        this.avatarSrc = avatarSource.getAvatar(+this.size);\n        this.avatarStyle = this.getImageStyle();\n    }\n\n    /**\n     * Returns initials style\n     */\n    private getTextualStyle(avatarValue: string): Style {\n        return {\n            textAlign: 'center',\n            borderRadius: this.borderRadius || '100%',\n            textTransform: 'uppercase',\n            color: this.fgColor,\n            backgroundColor: this.bgColor ? this.bgColor : this.avatarService.getRandomColor(avatarValue),\n            font: Math.floor(+this.size / this.textSizeRatio) + 'px Helvetica, Arial, sans-serif',\n            lineHeight: this.size + 'px',\n        };\n    }\n\n    /**\n     * Returns image style\n     */\n    private getImageStyle(): Style {\n        return {\n            maxWidth: '100%',\n            borderRadius: this.borderRadius || '100%',\n            width: this.size + 'px',\n            height: this.size + 'px',\n        };\n    }\n}\n"]}
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/avatar/component/avatar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnChanges, SimpleChanges} from '@angular/core';\n\nimport {Source} from '../sources/source';\nimport {AvatarService} from '../service/avatar.service';\n\ntype Style = Partial<CSSStyleDeclaration>;\n\n/**\n * Show an avatar from different sources\n */\n@Component({\n    selector: 'natural-avatar',\n    styles: [\n        `\n            :host {\n                border-radius: 50%;\n            }\n        `,\n    ],\n    template: `\n        <div class=\"avatar-container\" [ngStyle]=\"hostStyle\">\n            <img\n                *ngIf=\"avatarSrc\"\n                [src]=\"avatarSrc\"\n                [width]=\"size\"\n                [height]=\"size\"\n                [ngStyle]=\"avatarStyle\"\n                (error)=\"tryNextSource()\"\n                class=\"avatar-content\"\n                loading=\"lazy\"\n            />\n            <div *ngIf=\"avatarText\" class=\"avatar-content\" [ngStyle]=\"avatarStyle\">\n                {{ avatarText }}\n            </div>\n        </div>\n    `,\n})\nexport class AvatarComponent implements OnChanges {\n    @Input() public image?: string | null;\n    @Input() public initials?: string | null;\n    @Input() public gravatar?: string | null;\n\n    @Input() public size = 50;\n    @Input() public textSizeRatio = 3;\n    @Input() public bgColor: string | undefined;\n    @Input() public fgColor = '#FFF';\n    @Input() public borderRadius = '';\n    @Input() public textMaximumLength = 0;\n\n    public avatarSrc: string | null = null;\n    public avatarText: string | null = null;\n    public avatarStyle: Style = {};\n    public hostStyle: Style = {};\n\n    private currentIndex = -1;\n    private sources: Source[] = [];\n\n    public constructor(private readonly avatarService: AvatarService) {}\n\n    /**\n     * Detect inputs change\n     */\n    public ngOnChanges(changes: SimpleChanges): void {\n        this.sources.length = 0;\n        for (const [propName, creator] of this.avatarService.getCreators()) {\n            if (!changes[propName]) {\n                continue;\n            }\n\n            const currentValue = changes[propName].currentValue;\n            if (currentValue && typeof currentValue === 'string') {\n                this.sources.push(new creator(currentValue));\n            }\n        }\n\n        // reinitialize the avatar component when a source property value has changed\n        // the fallback system must be re-invoked with the new values.\n        this.initializeAvatar();\n    }\n\n    /**\n     * Fetch avatar source\n     */\n    public tryNextSource(): void {\n        const previousSource = this.sources[this.currentIndex];\n        if (previousSource) {\n            this.avatarService.markSourceAsFailed(previousSource);\n        }\n\n        const source = this.findNextSource();\n        if (!source) {\n            this.clearAvatar();\n            return;\n        }\n\n        if (source.isTextual()) {\n            this.buildTextAvatar(source);\n        } else {\n            this.buildImageAvatar(source);\n        }\n    }\n\n    private findNextSource(): Source | null {\n        while (++this.currentIndex < this.sources.length) {\n            const source = this.sources[this.currentIndex];\n            if (source && !this.avatarService.sourceHasFailedBefore(source)) {\n                return source;\n            }\n        }\n\n        return null;\n    }\n\n    /**\n     * Initialize the avatar component and its fallback system\n     */\n    private initializeAvatar(): void {\n        this.currentIndex = -1;\n        if (this.sources.length > 0) {\n            this.tryNextSource();\n            this.hostStyle = {\n                width: this.size + 'px',\n                height: this.size + 'px',\n            };\n        }\n    }\n\n    private clearAvatar(): void {\n        this.avatarSrc = null;\n        this.avatarText = null;\n        this.avatarStyle = {};\n    }\n\n    private buildTextAvatar(avatarSource: Source): void {\n        this.clearAvatar();\n        this.avatarText = avatarSource.getAvatar(+this.textMaximumLength);\n        this.avatarStyle = this.getTextualStyle(avatarSource.getValue());\n    }\n\n    private buildImageAvatar(avatarSource: Source): void {\n        this.clearAvatar();\n        this.avatarSrc = avatarSource.getAvatar(+this.size);\n        this.avatarStyle = this.getImageStyle();\n    }\n\n    /**\n     * Returns initials style\n     */\n    private getTextualStyle(avatarValue: string): Style {\n        return {\n            textAlign: 'center',\n            borderRadius: this.borderRadius || '100%',\n            textTransform: 'uppercase',\n            color: this.fgColor,\n            backgroundColor: this.bgColor ? this.bgColor : this.avatarService.getRandomColor(avatarValue),\n            font: Math.floor(+this.size / this.textSizeRatio) + 'px Helvetica, Arial, sans-serif',\n            lineHeight: this.size + 'px',\n        };\n    }\n\n    /**\n     * Returns image style\n     */\n    private getImageStyle(): Style {\n        return {\n            maxWidth: '100%',\n            borderRadius: this.borderRadius || '100%',\n            width: this.size + 'px',\n            height: this.size + 'px',\n        };\n    }\n}\n"]}
@@ -55,9 +55,9 @@ export class AvatarService {
55
55
  .reduce((previous, current) => previous + current);
56
56
  }
57
57
  }
58
- AvatarService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: AvatarService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
59
- AvatarService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: AvatarService, providedIn: 'root' });
60
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: AvatarService, decorators: [{
58
+ AvatarService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: AvatarService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
59
+ AvatarService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: AvatarService, providedIn: 'root' });
60
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: AvatarService, decorators: [{
61
61
  type: Injectable,
62
62
  args: [{
63
63
  providedIn: 'root',
@@ -30,9 +30,9 @@ export class NaturalColumnsPickerColumnDirective {
30
30
  this.label = this.elementRef.nativeElement.textContent ?? '';
31
31
  }
32
32
  }
33
- NaturalColumnsPickerColumnDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalColumnsPickerColumnDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
34
- NaturalColumnsPickerColumnDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.0", type: NaturalColumnsPickerColumnDirective, selector: "[naturalColumnsPickerColumn]", inputs: { checked: "checked", hidden: "hidden", naturalColumnsPickerColumn: "naturalColumnsPickerColumn" }, ngImport: i0 });
35
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalColumnsPickerColumnDirective, decorators: [{
33
+ NaturalColumnsPickerColumnDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalColumnsPickerColumnDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
34
+ NaturalColumnsPickerColumnDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.1", type: NaturalColumnsPickerColumnDirective, selector: "[naturalColumnsPickerColumn]", inputs: { checked: "checked", hidden: "hidden", naturalColumnsPickerColumn: "naturalColumnsPickerColumn" }, ngImport: i0 });
35
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalColumnsPickerColumnDirective, decorators: [{
36
36
  type: Directive,
37
37
  args: [{
38
38
  selector: '[naturalColumnsPickerColumn]',