@ecodev/natural 61.0.0 → 61.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 (138) hide show
  1. package/esm2022/lib/classes/abstract-detail.mjs +36 -33
  2. package/esm2022/lib/classes/abstract-editable-list.mjs +8 -6
  3. package/esm2022/lib/classes/abstract-list.mjs +74 -55
  4. package/esm2022/lib/classes/abstract-navigable-list.mjs +9 -9
  5. package/esm2022/lib/classes/cumulative-changes.mjs +3 -5
  6. package/esm2022/lib/classes/data-source.mjs +3 -2
  7. package/esm2022/lib/classes/query-variable-manager.mjs +3 -3
  8. package/esm2022/lib/directives/http-prefix.directive.mjs +4 -6
  9. package/esm2022/lib/modules/alert/alert.service.mjs +9 -11
  10. package/esm2022/lib/modules/alert/confirm.component.mjs +6 -11
  11. package/esm2022/lib/modules/avatar/component/avatar.component.mjs +25 -23
  12. package/esm2022/lib/modules/avatar/service/avatar.service.mjs +22 -24
  13. package/esm2022/lib/modules/avatar/sources/source.mjs +2 -1
  14. package/esm2022/lib/modules/columns-picker/columns-picker.component.mjs +26 -28
  15. package/esm2022/lib/modules/columns-picker/public-api.mjs +1 -1
  16. package/esm2022/lib/modules/common/directives/background-density.directive.mjs +6 -8
  17. package/esm2022/lib/modules/common/directives/linkable-tab.directive.mjs +18 -19
  18. package/esm2022/lib/modules/common/directives/src-density.directive.mjs +6 -8
  19. package/esm2022/lib/modules/common/pipes/capitalize.pipe.mjs +3 -3
  20. package/esm2022/lib/modules/common/pipes/ellipsis.pipe.mjs +3 -3
  21. package/esm2022/lib/modules/common/pipes/enum.pipe.mjs +7 -9
  22. package/esm2022/lib/modules/common/pipes/time-ago.pipe.mjs +4 -3
  23. package/esm2022/lib/modules/common/public-api.mjs +2 -2
  24. package/esm2022/lib/modules/common/services/memory-storage.mjs +4 -6
  25. package/esm2022/lib/modules/common/services/seo.service.mjs +18 -26
  26. package/esm2022/lib/modules/detail-header/detail-header.component.mjs +38 -33
  27. package/esm2022/lib/modules/dialog-trigger/dialog-trigger.component.mjs +13 -11
  28. package/esm2022/lib/modules/dropdown-components/abstract-association-select-component.directive.mjs +13 -12
  29. package/esm2022/lib/modules/dropdown-components/public-api.mjs +3 -3
  30. package/esm2022/lib/modules/dropdown-components/type-boolean/type-boolean.component.mjs +10 -13
  31. package/esm2022/lib/modules/dropdown-components/type-date/type-date.component.mjs +29 -33
  32. package/esm2022/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs +27 -32
  33. package/esm2022/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.mjs +3 -3
  34. package/esm2022/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.mjs +3 -3
  35. package/esm2022/lib/modules/dropdown-components/type-number/type-number.component.mjs +29 -30
  36. package/esm2022/lib/modules/dropdown-components/type-options/type-options.component.mjs +17 -15
  37. package/esm2022/lib/modules/dropdown-components/type-select/type-select.component.mjs +25 -25
  38. package/esm2022/lib/modules/dropdown-components/type-text/type-text.component.mjs +15 -17
  39. package/esm2022/lib/modules/file/abstract-file.mjs +51 -47
  40. package/esm2022/lib/modules/file/component/file.component.mjs +51 -41
  41. package/esm2022/lib/modules/file/file-drop.directive.mjs +10 -13
  42. package/esm2022/lib/modules/file/file-select.directive.mjs +9 -12
  43. package/esm2022/lib/modules/file/file.service.mjs +15 -20
  44. package/esm2022/lib/modules/file/public-api.mjs +1 -1
  45. package/esm2022/lib/modules/fixed-button/fixed-button.component.mjs +7 -8
  46. package/esm2022/lib/modules/fixed-button-detail/fixed-button-detail.component.mjs +15 -12
  47. package/esm2022/lib/modules/hierarchic-selector/classes/flat-node.mjs +8 -2
  48. package/esm2022/lib/modules/hierarchic-selector/classes/model-node.mjs +4 -2
  49. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.mjs +71 -55
  50. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.mjs +18 -20
  51. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.mjs +17 -11
  52. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.mjs +7 -9
  53. package/esm2022/lib/modules/icon/icon.directive.mjs +15 -23
  54. package/esm2022/lib/modules/logger/error-handler.mjs +11 -25
  55. package/esm2022/lib/modules/logger/public-api.mjs +2 -2
  56. package/esm2022/lib/modules/matomo/matomo.service.mjs +15 -22
  57. package/esm2022/lib/modules/panels/abstract-panel.mjs +23 -19
  58. package/esm2022/lib/modules/panels/panels.component.mjs +10 -9
  59. package/esm2022/lib/modules/panels/panels.service.mjs +56 -52
  60. package/esm2022/lib/modules/relations/relations.component.mjs +74 -45
  61. package/esm2022/lib/modules/search/dropdown-container/dropdown-container.component.mjs +21 -22
  62. package/esm2022/lib/modules/search/dropdown-container/dropdown-ref.mjs +4 -2
  63. package/esm2022/lib/modules/search/dropdown-container/dropdown.service.mjs +8 -11
  64. package/esm2022/lib/modules/search/facet-selector/facet-selector.component.mjs +13 -18
  65. package/esm2022/lib/modules/search/group/group.component.mjs +12 -11
  66. package/esm2022/lib/modules/search/input/input.component.mjs +86 -73
  67. package/esm2022/lib/modules/search/public-api.mjs +1 -1
  68. package/esm2022/lib/modules/search/search/search.component.mjs +37 -40
  69. package/esm2022/lib/modules/select/abstract-select.component.mjs +66 -39
  70. package/esm2022/lib/modules/select/select/select.component.mjs +51 -48
  71. package/esm2022/lib/modules/select/select-enum/select-enum.component.mjs +32 -22
  72. package/esm2022/lib/modules/select/select-hierarchic/select-hierarchic.component.mjs +39 -34
  73. package/esm2022/lib/modules/sidenav/sidenav/sidenav.component.mjs +3 -3
  74. package/esm2022/lib/modules/sidenav/sidenav-container/sidenav-container.component.mjs +34 -29
  75. package/esm2022/lib/modules/sidenav/sidenav-content/sidenav-content.component.mjs +3 -3
  76. package/esm2022/lib/modules/sidenav/sidenav-stack.service.mjs +13 -15
  77. package/esm2022/lib/modules/sidenav/sidenav.service.mjs +47 -54
  78. package/esm2022/lib/modules/stamp/stamp.component.mjs +4 -3
  79. package/esm2022/lib/modules/table-button/table-button.component.mjs +16 -13
  80. package/esm2022/lib/services/abstract-model.service.mjs +17 -7
  81. package/esm2022/lib/services/debounce.service.mjs +7 -9
  82. package/esm2022/lib/services/enum.service.mjs +7 -10
  83. package/esm2022/lib/services/link-mutation.service.mjs +11 -10
  84. package/esm2022/lib/services/persistence.service.mjs +9 -21
  85. package/esm2022/lib/services/swiss-parsing-date-adapter.service.mjs +3 -3
  86. package/esm2022/public-api.mjs +2 -2
  87. package/fesm2022/ecodev-natural.mjs +1357 -1270
  88. package/fesm2022/ecodev-natural.mjs.map +1 -1
  89. package/lib/modules/alert/alert.service.d.ts +1 -3
  90. package/lib/modules/alert/confirm.component.d.ts +1 -2
  91. package/lib/modules/avatar/component/avatar.component.d.ts +0 -2
  92. package/lib/modules/columns-picker/columns-picker.component.d.ts +1 -3
  93. package/lib/modules/columns-picker/public-api.d.ts +1 -1
  94. package/lib/modules/common/directives/background-density.directive.d.ts +0 -2
  95. package/lib/modules/common/directives/linkable-tab.directive.d.ts +2 -4
  96. package/lib/modules/common/directives/src-density.directive.d.ts +0 -2
  97. package/lib/modules/common/pipes/enum.pipe.d.ts +0 -2
  98. package/lib/modules/common/public-api.d.ts +2 -1
  99. package/lib/modules/common/services/seo.service.d.ts +2 -3
  100. package/lib/modules/dialog-trigger/dialog-trigger.component.d.ts +3 -3
  101. package/lib/modules/dropdown-components/public-api.d.ts +9 -9
  102. package/lib/modules/dropdown-components/type-boolean/type-boolean.component.d.ts +1 -3
  103. package/lib/modules/dropdown-components/type-date/type-date.component.d.ts +1 -3
  104. package/lib/modules/dropdown-components/type-date-range/type-date-range.component.d.ts +2 -3
  105. package/lib/modules/dropdown-components/type-number/type-number.component.d.ts +1 -2
  106. package/lib/modules/dropdown-components/type-options/type-options.component.d.ts +3 -3
  107. package/lib/modules/dropdown-components/type-select/type-select.component.d.ts +1 -2
  108. package/lib/modules/dropdown-components/type-text/type-text.component.d.ts +1 -2
  109. package/lib/modules/file/component/file.component.d.ts +0 -3
  110. package/lib/modules/file/file.service.d.ts +0 -1
  111. package/lib/modules/file/public-api.d.ts +1 -1
  112. package/lib/modules/fixed-button-detail/fixed-button-detail.component.d.ts +1 -2
  113. package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.d.ts +2 -3
  114. package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.d.ts +0 -2
  115. package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.d.ts +1 -2
  116. package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.d.ts +1 -2
  117. package/lib/modules/icon/icon.directive.d.ts +3 -5
  118. package/lib/modules/logger/error-handler.d.ts +3 -4
  119. package/lib/modules/logger/public-api.d.ts +2 -1
  120. package/lib/modules/matomo/matomo.service.d.ts +2 -5
  121. package/lib/modules/panels/panels.component.d.ts +1 -3
  122. package/lib/modules/panels/panels.service.d.ts +2 -6
  123. package/lib/modules/relations/relations.component.d.ts +3 -5
  124. package/lib/modules/search/dropdown-container/dropdown-container.component.d.ts +3 -4
  125. package/lib/modules/search/dropdown-container/dropdown.service.d.ts +1 -3
  126. package/lib/modules/search/facet-selector/facet-selector.component.d.ts +1 -2
  127. package/lib/modules/search/input/input.component.d.ts +1 -3
  128. package/lib/modules/search/public-api.d.ts +5 -5
  129. package/lib/modules/search/search/search.component.d.ts +0 -2
  130. package/lib/modules/select/select-enum/select-enum.component.d.ts +4 -4
  131. package/lib/modules/select/select-hierarchic/select-hierarchic.component.d.ts +4 -4
  132. package/lib/modules/sidenav/sidenav-container/sidenav-container.component.d.ts +0 -1
  133. package/lib/modules/sidenav/sidenav.service.d.ts +2 -7
  134. package/lib/services/enum.service.d.ts +0 -2
  135. package/lib/services/link-mutation.service.d.ts +0 -2
  136. package/lib/services/persistence.service.d.ts +2 -4
  137. package/package.json +1 -1
  138. package/public-api.d.ts +3 -2
@@ -1,19 +1,17 @@
1
- import { Component, Inject } from '@angular/core';
1
+ import { Component, inject } from '@angular/core';
2
2
  import { BehaviorSubject } from 'rxjs';
3
+ import { NaturalDropdownRef } from '../../search/dropdown-container/dropdown-ref';
3
4
  import { NATURAL_DROPDOWN_DATA } from '../../search/dropdown-container/dropdown.service';
4
5
  import { MatListModule } from '@angular/material/list';
5
6
  import * as i0 from "@angular/core";
6
- import * as i1 from "../../search/dropdown-container/dropdown-ref";
7
- import * as i2 from "@angular/material/list";
7
+ import * as i1 from "@angular/material/list";
8
8
  export class FacetSelectorComponent {
9
- constructor(data, dropdownRef) {
10
- this.data = data;
11
- this.dropdownRef = dropdownRef;
12
- // Never has a real value
13
- this.renderedValue = new BehaviorSubject('');
14
- this.selection = null;
15
- this.facets = data.configuration.facets;
16
- }
9
+ data = inject(NATURAL_DROPDOWN_DATA);
10
+ dropdownRef = inject(NaturalDropdownRef);
11
+ // Never has a real value
12
+ renderedValue = new BehaviorSubject('');
13
+ facets = this.data.configuration.facets;
14
+ selection = null;
17
15
  /**
18
16
  * Get value, including rich object types
19
17
  */
@@ -37,14 +35,11 @@ export class FacetSelectorComponent {
37
35
  isDirty() {
38
36
  return true;
39
37
  }
40
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: FacetSelectorComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }, { token: i1.NaturalDropdownRef }], target: i0.ɵɵFactoryTarget.Component }); }
41
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: FacetSelectorComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "@if (data.title) {\n <div class=\"dropdown-title mat-body-2\">{{ data.title }}</div>\n}\n<mat-nav-list>\n @for (facet of facets; track $index) {\n <mat-list-item (click)=\"selection = facet; close()\">\n <a>{{ facet.display }}</a>\n </mat-list-item>\n }\n</mat-nav-list>\n", styles: [".mat-nav-list{padding:0}.dropdown-title{opacity:.7;padding:5px;font-variant:all-small-caps;font-size:18px}\n"], dependencies: [{ kind: "ngmodule", type: MatListModule }, { kind: "component", type: i2.MatNavList, selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "component", type: i2.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }] }); }
38
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: FacetSelectorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
39
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: FacetSelectorComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "@if (data.title) {\n <div class=\"dropdown-title mat-body-2\">{{ data.title }}</div>\n}\n<mat-nav-list>\n @for (facet of facets; track $index) {\n <mat-list-item (click)=\"selection = facet; close()\">\n <a>{{ facet.display }}</a>\n </mat-list-item>\n }\n</mat-nav-list>\n", styles: [".mat-nav-list{padding:0}.dropdown-title{opacity:.7;padding:5px;font-variant:all-small-caps;font-size:18px}\n"], dependencies: [{ kind: "ngmodule", type: MatListModule }, { kind: "component", type: i1.MatNavList, selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "component", type: i1.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }] });
42
40
  }
43
41
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: FacetSelectorComponent, decorators: [{
44
42
  type: Component,
45
43
  args: [{ standalone: true, imports: [MatListModule], template: "@if (data.title) {\n <div class=\"dropdown-title mat-body-2\">{{ data.title }}</div>\n}\n<mat-nav-list>\n @for (facet of facets; track $index) {\n <mat-list-item (click)=\"selection = facet; close()\">\n <a>{{ facet.display }}</a>\n </mat-list-item>\n }\n</mat-nav-list>\n", styles: [".mat-nav-list{padding:0}.dropdown-title{opacity:.7;padding:5px;font-variant:all-small-caps;font-size:18px}\n"] }]
46
- }], ctorParameters: () => [{ type: undefined, decorators: [{
47
- type: Inject,
48
- args: [NATURAL_DROPDOWN_DATA]
49
- }] }, { type: i1.NaturalDropdownRef }] });
50
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFjZXQtc2VsZWN0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2VhcmNoL2ZhY2V0LXNlbGVjdG9yL2ZhY2V0LXNlbGVjdG9yLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9mYWNldC1zZWxlY3Rvci9mYWNldC1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBR3JDLE9BQU8sRUFBQyxxQkFBcUIsRUFBc0IsTUFBTSxrREFBa0QsQ0FBQztBQUc1RyxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7Ozs7QUFlckQsTUFBTSxPQUFPLHNCQUFzQjtJQU0vQixZQUMwQyxJQUFxRCxFQUNqRixXQUErQjtRQURILFNBQUksR0FBSixJQUFJLENBQWlEO1FBQ2pGLGdCQUFXLEdBQVgsV0FBVyxDQUFvQjtRQVA3Qyx5QkFBeUI7UUFDVCxrQkFBYSxHQUFHLElBQUksZUFBZSxDQUFTLEVBQUUsQ0FBQyxDQUFDO1FBRXpELGNBQVMsR0FBaUIsSUFBSSxDQUFDO1FBTWxDLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUM7SUFDNUMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksWUFBWTtRQUNmLE9BQU8sRUFBRSxDQUFDO0lBQ2QsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSztRQUNSLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ2pCLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDO2dCQUNuQixTQUFTLEVBQUUsRUFBRTtnQkFDYixLQUFLLEVBQUUsSUFBSSxDQUFDLFNBQVM7YUFDeEIsQ0FBQyxDQUFDO1FBQ1AsQ0FBQztJQUNMLENBQUM7SUFFTSxPQUFPO1FBQ1YsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUM1QixDQUFDO0lBRU0sT0FBTztRQUNWLE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7OEdBdENRLHNCQUFzQixrQkFPbkIscUJBQXFCO2tHQVB4QixzQkFBc0Isd0VDdEJuQyxvVEFVQSxxS0RVYyxhQUFhOzsyRkFFZCxzQkFBc0I7a0JBTmxDLFNBQVM7aUNBR00sSUFBSSxXQUNQLENBQUMsYUFBYSxDQUFDOzswQkFTbkIsTUFBTTsyQkFBQyxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5qZWN0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7QmVoYXZpb3JTdWJqZWN0fSBmcm9tICdyeGpzJztcbmltcG9ydCB7RmlsdGVyR3JvdXBDb25kaXRpb25GaWVsZH0gZnJvbSAnLi4vLi4vc2VhcmNoL2NsYXNzZXMvZ3JhcGhxbC1kb2N0cmluZS50eXBlcyc7XG5pbXBvcnQge05hdHVyYWxEcm9wZG93blJlZn0gZnJvbSAnLi4vLi4vc2VhcmNoL2Ryb3Bkb3duLWNvbnRhaW5lci9kcm9wZG93bi1yZWYnO1xuaW1wb3J0IHtOQVRVUkFMX0RST1BET1dOX0RBVEEsIE5hdHVyYWxEcm9wZG93bkRhdGF9IGZyb20gJy4uLy4uL3NlYXJjaC9kcm9wZG93bi1jb250YWluZXIvZHJvcGRvd24uc2VydmljZSc7XG5pbXBvcnQge0Ryb3Bkb3duQ29tcG9uZW50fSBmcm9tICcuLi90eXBlcy9kcm9wZG93bi1jb21wb25lbnQnO1xuaW1wb3J0IHtGYWNldCwgTmF0dXJhbFNlYXJjaEZhY2V0c30gZnJvbSAnLi4vdHlwZXMvZmFjZXQnO1xuaW1wb3J0IHtNYXRMaXN0TW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9saXN0JztcblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIGZvciBmYWNldCBzZWxlY3Rpb25cbiAqL1xuZXhwb3J0IHR5cGUgRmFjZXRTZWxlY3RvckNvbmZpZ3VyYXRpb24gPSB7XG4gICAgZmFjZXRzOiBOYXR1cmFsU2VhcmNoRmFjZXRzO1xufTtcblxuQENvbXBvbmVudCh7XG4gICAgdGVtcGxhdGVVcmw6ICcuL2ZhY2V0LXNlbGVjdG9yLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybDogJy4vZmFjZXQtc2VsZWN0b3IuY29tcG9uZW50LnNjc3MnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW01hdExpc3RNb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBGYWNldFNlbGVjdG9yQ29tcG9uZW50IGltcGxlbWVudHMgRHJvcGRvd25Db21wb25lbnQge1xuICAgIC8vIE5ldmVyIGhhcyBhIHJlYWwgdmFsdWVcbiAgICBwdWJsaWMgcmVhZG9ubHkgcmVuZGVyZWRWYWx1ZSA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPignJyk7XG4gICAgcHVibGljIGZhY2V0czogTmF0dXJhbFNlYXJjaEZhY2V0cztcbiAgICBwdWJsaWMgc2VsZWN0aW9uOiBGYWNldCB8IG51bGwgPSBudWxsO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KE5BVFVSQUxfRFJPUERPV05fREFUQSkgcHVibGljIGRhdGE6IE5hdHVyYWxEcm9wZG93bkRhdGE8RmFjZXRTZWxlY3RvckNvbmZpZ3VyYXRpb24+LFxuICAgICAgICBwcm90ZWN0ZWQgZHJvcGRvd25SZWY6IE5hdHVyYWxEcm9wZG93blJlZixcbiAgICApIHtcbiAgICAgICAgdGhpcy5mYWNldHMgPSBkYXRhLmNvbmZpZ3VyYXRpb24uZmFjZXRzO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEdldCB2YWx1ZSwgaW5jbHVkaW5nIHJpY2ggb2JqZWN0IHR5cGVzXG4gICAgICovXG4gICAgcHVibGljIGdldENvbmRpdGlvbigpOiBGaWx0ZXJHcm91cENvbmRpdGlvbkZpZWxkIHtcbiAgICAgICAgcmV0dXJuIHt9O1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEFsbG93IHRvIGNsb3NlIHRoZSBkcm9wZG93biB3aXRoIGEgdmFsaWQgdmFsdWVcbiAgICAgKi9cbiAgICBwdWJsaWMgY2xvc2UoKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLnNlbGVjdGlvbikge1xuICAgICAgICAgICAgdGhpcy5kcm9wZG93blJlZi5jbG9zZSh7XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uOiB7fSxcbiAgICAgICAgICAgICAgICBmYWNldDogdGhpcy5zZWxlY3Rpb24sXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHB1YmxpYyBpc1ZhbGlkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gISF0aGlzLnNlbGVjdGlvbjtcbiAgICB9XG5cbiAgICBwdWJsaWMgaXNEaXJ0eSgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxufVxuIiwiQGlmIChkYXRhLnRpdGxlKSB7XG4gICAgPGRpdiBjbGFzcz1cImRyb3Bkb3duLXRpdGxlIG1hdC1ib2R5LTJcIj57eyBkYXRhLnRpdGxlIH19PC9kaXY+XG59XG48bWF0LW5hdi1saXN0PlxuICAgIEBmb3IgKGZhY2V0IG9mIGZhY2V0czsgdHJhY2sgJGluZGV4KSB7XG4gICAgICAgIDxtYXQtbGlzdC1pdGVtIChjbGljayk9XCJzZWxlY3Rpb24gPSBmYWNldDsgY2xvc2UoKVwiPlxuICAgICAgICAgICAgPGE+e3sgZmFjZXQuZGlzcGxheSB9fTwvYT5cbiAgICAgICAgPC9tYXQtbGlzdC1pdGVtPlxuICAgIH1cbjwvbWF0LW5hdi1saXN0PlxuIl19
44
+ }] });
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFjZXQtc2VsZWN0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2VhcmNoL2ZhY2V0LXNlbGVjdG9yL2ZhY2V0LXNlbGVjdG9yLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9mYWNldC1zZWxlY3Rvci9mYWNldC1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBRXJDLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDhDQUE4QyxDQUFDO0FBQ2hGLE9BQU8sRUFBQyxxQkFBcUIsRUFBc0IsTUFBTSxrREFBa0QsQ0FBQztBQUc1RyxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7OztBQWVyRCxNQUFNLE9BQU8sc0JBQXNCO0lBQ2YsSUFBSSxHQUFHLE1BQU0sQ0FBa0QscUJBQXFCLENBQUMsQ0FBQztJQUM1RixXQUFXLEdBQUcsTUFBTSxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFFbkQseUJBQXlCO0lBQ1QsYUFBYSxHQUFHLElBQUksZUFBZSxDQUFTLEVBQUUsQ0FBQyxDQUFDO0lBQ3pELE1BQU0sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUM7SUFDeEMsU0FBUyxHQUFpQixJQUFJLENBQUM7SUFFdEM7O09BRUc7SUFDSSxZQUFZO1FBQ2YsT0FBTyxFQUFFLENBQUM7SUFDZCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxLQUFLO1FBQ1IsSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDakIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUM7Z0JBQ25CLFNBQVMsRUFBRSxFQUFFO2dCQUNiLEtBQUssRUFBRSxJQUFJLENBQUMsU0FBUzthQUN4QixDQUFDLENBQUM7UUFDUCxDQUFDO0lBQ0wsQ0FBQztJQUVNLE9BQU87UUFDVixPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzVCLENBQUM7SUFFTSxPQUFPO1FBQ1YsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQzt1R0FsQ1Esc0JBQXNCOzJGQUF0QixzQkFBc0Isd0VDdEJuQyxvVEFVQSxxS0RVYyxhQUFhOzsyRkFFZCxzQkFBc0I7a0JBTmxDLFNBQVM7aUNBR00sSUFBSSxXQUNQLENBQUMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIGluamVjdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdH0gZnJvbSAncnhqcyc7XG5pbXBvcnQge0ZpbHRlckdyb3VwQ29uZGl0aW9uRmllbGR9IGZyb20gJy4uLy4uL3NlYXJjaC9jbGFzc2VzL2dyYXBocWwtZG9jdHJpbmUudHlwZXMnO1xuaW1wb3J0IHtOYXR1cmFsRHJvcGRvd25SZWZ9IGZyb20gJy4uLy4uL3NlYXJjaC9kcm9wZG93bi1jb250YWluZXIvZHJvcGRvd24tcmVmJztcbmltcG9ydCB7TkFUVVJBTF9EUk9QRE9XTl9EQVRBLCBOYXR1cmFsRHJvcGRvd25EYXRhfSBmcm9tICcuLi8uLi9zZWFyY2gvZHJvcGRvd24tY29udGFpbmVyL2Ryb3Bkb3duLnNlcnZpY2UnO1xuaW1wb3J0IHtEcm9wZG93bkNvbXBvbmVudH0gZnJvbSAnLi4vdHlwZXMvZHJvcGRvd24tY29tcG9uZW50JztcbmltcG9ydCB7RmFjZXQsIE5hdHVyYWxTZWFyY2hGYWNldHN9IGZyb20gJy4uL3R5cGVzL2ZhY2V0JztcbmltcG9ydCB7TWF0TGlzdE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbGlzdCc7XG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBmb3IgZmFjZXQgc2VsZWN0aW9uXG4gKi9cbmV4cG9ydCB0eXBlIEZhY2V0U2VsZWN0b3JDb25maWd1cmF0aW9uID0ge1xuICAgIGZhY2V0czogTmF0dXJhbFNlYXJjaEZhY2V0cztcbn07XG5cbkBDb21wb25lbnQoe1xuICAgIHRlbXBsYXRlVXJsOiAnLi9mYWNldC1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL2ZhY2V0LXNlbGVjdG9yLmNvbXBvbmVudC5zY3NzJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtNYXRMaXN0TW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgRmFjZXRTZWxlY3RvckNvbXBvbmVudCBpbXBsZW1lbnRzIERyb3Bkb3duQ29tcG9uZW50IHtcbiAgICBwdWJsaWMgcmVhZG9ubHkgZGF0YSA9IGluamVjdDxOYXR1cmFsRHJvcGRvd25EYXRhPEZhY2V0U2VsZWN0b3JDb25maWd1cmF0aW9uPj4oTkFUVVJBTF9EUk9QRE9XTl9EQVRBKTtcbiAgICBwcm90ZWN0ZWQgZHJvcGRvd25SZWYgPSBpbmplY3QoTmF0dXJhbERyb3Bkb3duUmVmKTtcblxuICAgIC8vIE5ldmVyIGhhcyBhIHJlYWwgdmFsdWVcbiAgICBwdWJsaWMgcmVhZG9ubHkgcmVuZGVyZWRWYWx1ZSA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPignJyk7XG4gICAgcHVibGljIGZhY2V0cyA9IHRoaXMuZGF0YS5jb25maWd1cmF0aW9uLmZhY2V0cztcbiAgICBwdWJsaWMgc2VsZWN0aW9uOiBGYWNldCB8IG51bGwgPSBudWxsO1xuXG4gICAgLyoqXG4gICAgICogR2V0IHZhbHVlLCBpbmNsdWRpbmcgcmljaCBvYmplY3QgdHlwZXNcbiAgICAgKi9cbiAgICBwdWJsaWMgZ2V0Q29uZGl0aW9uKCk6IEZpbHRlckdyb3VwQ29uZGl0aW9uRmllbGQge1xuICAgICAgICByZXR1cm4ge307XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQWxsb3cgdG8gY2xvc2UgdGhlIGRyb3Bkb3duIHdpdGggYSB2YWxpZCB2YWx1ZVxuICAgICAqL1xuICAgIHB1YmxpYyBjbG9zZSgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuc2VsZWN0aW9uKSB7XG4gICAgICAgICAgICB0aGlzLmRyb3Bkb3duUmVmLmNsb3NlKHtcbiAgICAgICAgICAgICAgICBjb25kaXRpb246IHt9LFxuICAgICAgICAgICAgICAgIGZhY2V0OiB0aGlzLnNlbGVjdGlvbixcbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIGlzVmFsaWQoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiAhIXRoaXMuc2VsZWN0aW9uO1xuICAgIH1cblxuICAgIHB1YmxpYyBpc0RpcnR5KCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG59XG4iLCJAaWYgKGRhdGEudGl0bGUpIHtcbiAgICA8ZGl2IGNsYXNzPVwiZHJvcGRvd24tdGl0bGUgbWF0LWJvZHktMlwiPnt7IGRhdGEudGl0bGUgfX08L2Rpdj5cbn1cbjxtYXQtbmF2LWxpc3Q+XG4gICAgQGZvciAoZmFjZXQgb2YgZmFjZXRzOyB0cmFjayAkaW5kZXgpIHtcbiAgICAgICAgPG1hdC1saXN0LWl0ZW0gKGNsaWNrKT1cInNlbGVjdGlvbiA9IGZhY2V0OyBjbG9zZSgpXCI+XG4gICAgICAgICAgICA8YT57eyBmYWNldC5kaXNwbGF5IH19PC9hPlxuICAgICAgICA8L21hdC1saXN0LWl0ZW0+XG4gICAgfVxuPC9tYXQtbmF2LWxpc3Q+XG4iXX0=
@@ -3,14 +3,15 @@ import { deepClone } from '../classes/utils';
3
3
  import { NaturalInputComponent } from '../input/input.component';
4
4
  import * as i0 from "@angular/core";
5
5
  export class NaturalGroupComponent {
6
- constructor() {
7
- /**
8
- * Text display in the dropdown to select the facet
9
- */
10
- this.dropdownTitle = '';
11
- this.selectionChange = new EventEmitter();
12
- this.innerSelections = [];
13
- }
6
+ newValueInput;
7
+ /**
8
+ * Text display in the dropdown to select the facet
9
+ */
10
+ dropdownTitle = '';
11
+ placeholder;
12
+ facets;
13
+ selectionChange = new EventEmitter();
14
+ innerSelections = [];
14
15
  set selections(selection) {
15
16
  this.innerSelections = deepClone(selection);
16
17
  }
@@ -27,8 +28,8 @@ export class NaturalGroupComponent {
27
28
  this.innerSelections.splice(index, 1);
28
29
  this.selectionChange.emit(this.innerSelections);
29
30
  }
30
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
31
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: NaturalGroupComponent, isStandalone: true, selector: "natural-group", inputs: { dropdownTitle: "dropdownTitle", placeholder: "placeholder", facets: "facets", selections: "selections" }, outputs: { selectionChange: "selectionChange" }, viewQueries: [{ propertyName: "newValueInput", first: true, predicate: ["newValueInput"], descendants: true }], ngImport: i0, template: "@for (selection of innerSelections; track $index) {\n <natural-input\n (cleared)=\"removeInput($index)\"\n (selectionChange)=\"updateInput($event, $index)\"\n [facets]=\"facets\"\n [selection]=\"selection\"\n />\n}\n\n<natural-input\n #newValueInput\n (selectionChange)=\"addInput($event)\"\n [facets]=\"facets\"\n [placeholder]=\"placeholder\"\n tabIndex=\"10\"\n cdkFocusInitial\n [dropdownTitle]=\"dropdownTitle\"\n/>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:wrap}:host natural-input{display:inline-flex;flex:auto;margin-right:10px;margin-bottom:10px}:host natural-input:last-of-type{flex:1;min-width:250px}\n"], dependencies: [{ kind: "component", type: NaturalInputComponent, selector: "natural-input", inputs: ["placeholder", "searchFieldName", "selection", "facets", "dropdownTitle"], outputs: ["selectionChange", "cleared"] }] }); }
31
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
32
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: NaturalGroupComponent, isStandalone: true, selector: "natural-group", inputs: { dropdownTitle: "dropdownTitle", placeholder: "placeholder", facets: "facets", selections: "selections" }, outputs: { selectionChange: "selectionChange" }, viewQueries: [{ propertyName: "newValueInput", first: true, predicate: ["newValueInput"], descendants: true }], ngImport: i0, template: "@for (selection of innerSelections; track $index) {\n <natural-input\n (cleared)=\"removeInput($index)\"\n (selectionChange)=\"updateInput($event, $index)\"\n [facets]=\"facets\"\n [selection]=\"selection\"\n />\n}\n\n<natural-input\n #newValueInput\n (selectionChange)=\"addInput($event)\"\n [facets]=\"facets\"\n [placeholder]=\"placeholder\"\n tabIndex=\"10\"\n cdkFocusInitial\n [dropdownTitle]=\"dropdownTitle\"\n/>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:wrap}:host natural-input{display:inline-flex;flex:auto;margin-right:10px;margin-bottom:10px}:host natural-input:last-of-type{flex:1;min-width:250px}\n"], dependencies: [{ kind: "component", type: NaturalInputComponent, selector: "natural-input", inputs: ["placeholder", "searchFieldName", "selection", "facets", "dropdownTitle"], outputs: ["selectionChange", "cleared"] }] });
32
33
  }
33
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalGroupComponent, decorators: [{
34
35
  type: Component,
@@ -49,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
49
50
  }], selections: [{
50
51
  type: Input
51
52
  }] } });
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2VhcmNoL2dyb3VwL2dyb3VwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9ncm91cC9ncm91cC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRixPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDM0MsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7O0FBVy9ELE1BQU0sT0FBTyxxQkFBcUI7SUFQbEM7UUFVSTs7V0FFRztRQUNhLGtCQUFhLEdBQUcsRUFBRSxDQUFDO1FBR1Qsb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBbUIsQ0FBQztRQUN6RSxvQkFBZSxHQUFvQixFQUFFLENBQUM7S0FxQmhEO0lBbkJHLElBQW9CLFVBQVUsQ0FBQyxTQUEwQjtRQUNyRCxJQUFJLENBQUMsZUFBZSxHQUFHLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNoRCxDQUFDO0lBRU0sV0FBVyxDQUFDLFNBQWlDLEVBQUUsS0FBYTtRQUMvRCxJQUFJLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxHQUFHLFNBQVMsQ0FBQztRQUN4QyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVNLFFBQVEsQ0FBQyxTQUFpQztRQUM3QyxJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzNCLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRU0sV0FBVyxDQUFDLEtBQWE7UUFDNUIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUNwRCxDQUFDOzhHQTlCUSxxQkFBcUI7a0dBQXJCLHFCQUFxQiw4VkNibEMsK2RBa0JBLGdRRFBjLHFCQUFxQjs7MkZBRXRCLHFCQUFxQjtrQkFQakMsU0FBUzsrQkFDSSxlQUFlLGNBR2IsSUFBSSxXQUNQLENBQUMscUJBQXFCLENBQUM7OEJBR0csYUFBYTtzQkFBL0MsU0FBUzt1QkFBQyxlQUFlO2dCQUtWLGFBQWE7c0JBQTVCLEtBQUs7Z0JBQzBCLFdBQVc7c0JBQTFDLEtBQUs7dUJBQUMsRUFBQyxRQUFRLEVBQUUsSUFBSSxFQUFDO2dCQUNTLE1BQU07c0JBQXJDLEtBQUs7dUJBQUMsRUFBQyxRQUFRLEVBQUUsSUFBSSxFQUFDO2dCQUNHLGVBQWU7c0JBQXhDLE1BQU07Z0JBR2EsVUFBVTtzQkFBN0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQsIFZpZXdDaGlsZH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge2RlZXBDbG9uZX0gZnJvbSAnLi4vY2xhc3Nlcy91dGlscyc7XG5pbXBvcnQge05hdHVyYWxJbnB1dENvbXBvbmVudH0gZnJvbSAnLi4vaW5wdXQvaW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7TmF0dXJhbFNlYXJjaEZhY2V0c30gZnJvbSAnLi4vdHlwZXMvZmFjZXQnO1xuaW1wb3J0IHtHcm91cFNlbGVjdGlvbnMsIE5hdHVyYWxTZWFyY2hTZWxlY3Rpb259IGZyb20gJy4uL3R5cGVzL3ZhbHVlcyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbmF0dXJhbC1ncm91cCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2dyb3VwLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybDogJy4vZ3JvdXAuY29tcG9uZW50LnNjc3MnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW05hdHVyYWxJbnB1dENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxHcm91cENvbXBvbmVudCB7XG4gICAgQFZpZXdDaGlsZCgnbmV3VmFsdWVJbnB1dCcpIHB1YmxpYyBuZXdWYWx1ZUlucHV0ITogTmF0dXJhbElucHV0Q29tcG9uZW50O1xuXG4gICAgLyoqXG4gICAgICogVGV4dCBkaXNwbGF5IGluIHRoZSBkcm9wZG93biB0byBzZWxlY3QgdGhlIGZhY2V0XG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIGRyb3Bkb3duVGl0bGUgPSAnJztcbiAgICBASW5wdXQoe3JlcXVpcmVkOiB0cnVlfSkgcHVibGljIHBsYWNlaG9sZGVyITogc3RyaW5nO1xuICAgIEBJbnB1dCh7cmVxdWlyZWQ6IHRydWV9KSBwdWJsaWMgZmFjZXRzITogTmF0dXJhbFNlYXJjaEZhY2V0cztcbiAgICBAT3V0cHV0KCkgcHVibGljIHJlYWRvbmx5IHNlbGVjdGlvbkNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8R3JvdXBTZWxlY3Rpb25zPigpO1xuICAgIHB1YmxpYyBpbm5lclNlbGVjdGlvbnM6IEdyb3VwU2VsZWN0aW9ucyA9IFtdO1xuXG4gICAgQElucHV0KCkgcHVibGljIHNldCBzZWxlY3Rpb25zKHNlbGVjdGlvbjogR3JvdXBTZWxlY3Rpb25zKSB7XG4gICAgICAgIHRoaXMuaW5uZXJTZWxlY3Rpb25zID0gZGVlcENsb25lKHNlbGVjdGlvbik7XG4gICAgfVxuXG4gICAgcHVibGljIHVwZGF0ZUlucHV0KHNlbGVjdGlvbjogTmF0dXJhbFNlYXJjaFNlbGVjdGlvbiwgaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgICAgICB0aGlzLmlubmVyU2VsZWN0aW9uc1tpbmRleF0gPSBzZWxlY3Rpb247XG4gICAgICAgIHRoaXMuc2VsZWN0aW9uQ2hhbmdlLmVtaXQodGhpcy5pbm5lclNlbGVjdGlvbnMpO1xuICAgIH1cblxuICAgIHB1YmxpYyBhZGRJbnB1dChzZWxlY3Rpb246IE5hdHVyYWxTZWFyY2hTZWxlY3Rpb24pOiB2b2lkIHtcbiAgICAgICAgdGhpcy5uZXdWYWx1ZUlucHV0LmNsZWFyKCk7XG4gICAgICAgIHRoaXMuaW5uZXJTZWxlY3Rpb25zLnB1c2goc2VsZWN0aW9uKTtcbiAgICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh0aGlzLmlubmVyU2VsZWN0aW9ucyk7XG4gICAgfVxuXG4gICAgcHVibGljIHJlbW92ZUlucHV0KGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pbm5lclNlbGVjdGlvbnMuc3BsaWNlKGluZGV4LCAxKTtcbiAgICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh0aGlzLmlubmVyU2VsZWN0aW9ucyk7XG4gICAgfVxufVxuIiwiQGZvciAoc2VsZWN0aW9uIG9mIGlubmVyU2VsZWN0aW9uczsgdHJhY2sgJGluZGV4KSB7XG4gICAgPG5hdHVyYWwtaW5wdXRcbiAgICAgICAgKGNsZWFyZWQpPVwicmVtb3ZlSW5wdXQoJGluZGV4KVwiXG4gICAgICAgIChzZWxlY3Rpb25DaGFuZ2UpPVwidXBkYXRlSW5wdXQoJGV2ZW50LCAkaW5kZXgpXCJcbiAgICAgICAgW2ZhY2V0c109XCJmYWNldHNcIlxuICAgICAgICBbc2VsZWN0aW9uXT1cInNlbGVjdGlvblwiXG4gICAgLz5cbn1cblxuPG5hdHVyYWwtaW5wdXRcbiAgICAjbmV3VmFsdWVJbnB1dFxuICAgIChzZWxlY3Rpb25DaGFuZ2UpPVwiYWRkSW5wdXQoJGV2ZW50KVwiXG4gICAgW2ZhY2V0c109XCJmYWNldHNcIlxuICAgIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiXG4gICAgdGFiSW5kZXg9XCIxMFwiXG4gICAgY2RrRm9jdXNJbml0aWFsXG4gICAgW2Ryb3Bkb3duVGl0bGVdPVwiZHJvcGRvd25UaXRsZVwiXG4vPlxuIl19
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2VhcmNoL2dyb3VwL2dyb3VwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9ncm91cC9ncm91cC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRixPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDM0MsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7O0FBVy9ELE1BQU0sT0FBTyxxQkFBcUI7SUFDSyxhQUFhLENBQXlCO0lBRXpFOztPQUVHO0lBQ2EsYUFBYSxHQUFHLEVBQUUsQ0FBQztJQUNILFdBQVcsQ0FBVTtJQUNyQixNQUFNLENBQXVCO0lBQ25DLGVBQWUsR0FBRyxJQUFJLFlBQVksRUFBbUIsQ0FBQztJQUN6RSxlQUFlLEdBQW9CLEVBQUUsQ0FBQztJQUU3QyxJQUFvQixVQUFVLENBQUMsU0FBMEI7UUFDckQsSUFBSSxDQUFDLGVBQWUsR0FBRyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDaEQsQ0FBQztJQUVNLFdBQVcsQ0FBQyxTQUFpQyxFQUFFLEtBQWE7UUFDL0QsSUFBSSxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsR0FBRyxTQUFTLENBQUM7UUFDeEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFTSxRQUFRLENBQUMsU0FBaUM7UUFDN0MsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUMzQixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNyQyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVNLFdBQVcsQ0FBQyxLQUFhO1FBQzVCLElBQUksQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztRQUN0QyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDcEQsQ0FBQzt1R0E5QlEscUJBQXFCOzJGQUFyQixxQkFBcUIsOFZDYmxDLCtkQWtCQSxnUURQYyxxQkFBcUI7OzJGQUV0QixxQkFBcUI7a0JBUGpDLFNBQVM7K0JBQ0ksZUFBZSxjQUdiLElBQUksV0FDUCxDQUFDLHFCQUFxQixDQUFDOzhCQUdHLGFBQWE7c0JBQS9DLFNBQVM7dUJBQUMsZUFBZTtnQkFLVixhQUFhO3NCQUE1QixLQUFLO2dCQUMwQixXQUFXO3NCQUExQyxLQUFLO3VCQUFDLEVBQUMsUUFBUSxFQUFFLElBQUksRUFBQztnQkFDUyxNQUFNO3NCQUFyQyxLQUFLO3VCQUFDLEVBQUMsUUFBUSxFQUFFLElBQUksRUFBQztnQkFDRyxlQUFlO3NCQUF4QyxNQUFNO2dCQUdhLFVBQVU7c0JBQTdCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBWaWV3Q2hpbGR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtkZWVwQ2xvbmV9IGZyb20gJy4uL2NsYXNzZXMvdXRpbHMnO1xuaW1wb3J0IHtOYXR1cmFsSW5wdXRDb21wb25lbnR9IGZyb20gJy4uL2lucHV0L2lucHV0LmNvbXBvbmVudCc7XG5pbXBvcnQge05hdHVyYWxTZWFyY2hGYWNldHN9IGZyb20gJy4uL3R5cGVzL2ZhY2V0JztcbmltcG9ydCB7R3JvdXBTZWxlY3Rpb25zLCBOYXR1cmFsU2VhcmNoU2VsZWN0aW9ufSBmcm9tICcuLi90eXBlcy92YWx1ZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ25hdHVyYWwtZ3JvdXAnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9ncm91cC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL2dyb3VwLmNvbXBvbmVudC5zY3NzJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtOYXR1cmFsSW5wdXRDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBOYXR1cmFsR3JvdXBDb21wb25lbnQge1xuICAgIEBWaWV3Q2hpbGQoJ25ld1ZhbHVlSW5wdXQnKSBwdWJsaWMgbmV3VmFsdWVJbnB1dCE6IE5hdHVyYWxJbnB1dENvbXBvbmVudDtcblxuICAgIC8qKlxuICAgICAqIFRleHQgZGlzcGxheSBpbiB0aGUgZHJvcGRvd24gdG8gc2VsZWN0IHRoZSBmYWNldFxuICAgICAqL1xuICAgIEBJbnB1dCgpIHB1YmxpYyBkcm9wZG93blRpdGxlID0gJyc7XG4gICAgQElucHV0KHtyZXF1aXJlZDogdHJ1ZX0pIHB1YmxpYyBwbGFjZWhvbGRlciE6IHN0cmluZztcbiAgICBASW5wdXQoe3JlcXVpcmVkOiB0cnVlfSkgcHVibGljIGZhY2V0cyE6IE5hdHVyYWxTZWFyY2hGYWNldHM7XG4gICAgQE91dHB1dCgpIHB1YmxpYyByZWFkb25seSBzZWxlY3Rpb25DaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPEdyb3VwU2VsZWN0aW9ucz4oKTtcbiAgICBwdWJsaWMgaW5uZXJTZWxlY3Rpb25zOiBHcm91cFNlbGVjdGlvbnMgPSBbXTtcblxuICAgIEBJbnB1dCgpIHB1YmxpYyBzZXQgc2VsZWN0aW9ucyhzZWxlY3Rpb246IEdyb3VwU2VsZWN0aW9ucykge1xuICAgICAgICB0aGlzLmlubmVyU2VsZWN0aW9ucyA9IGRlZXBDbG9uZShzZWxlY3Rpb24pO1xuICAgIH1cblxuICAgIHB1YmxpYyB1cGRhdGVJbnB1dChzZWxlY3Rpb246IE5hdHVyYWxTZWFyY2hTZWxlY3Rpb24sIGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pbm5lclNlbGVjdGlvbnNbaW5kZXhdID0gc2VsZWN0aW9uO1xuICAgICAgICB0aGlzLnNlbGVjdGlvbkNoYW5nZS5lbWl0KHRoaXMuaW5uZXJTZWxlY3Rpb25zKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgYWRkSW5wdXQoc2VsZWN0aW9uOiBOYXR1cmFsU2VhcmNoU2VsZWN0aW9uKTogdm9pZCB7XG4gICAgICAgIHRoaXMubmV3VmFsdWVJbnB1dC5jbGVhcigpO1xuICAgICAgICB0aGlzLmlubmVyU2VsZWN0aW9ucy5wdXNoKHNlbGVjdGlvbik7XG4gICAgICAgIHRoaXMuc2VsZWN0aW9uQ2hhbmdlLmVtaXQodGhpcy5pbm5lclNlbGVjdGlvbnMpO1xuICAgIH1cblxuICAgIHB1YmxpYyByZW1vdmVJbnB1dChpbmRleDogbnVtYmVyKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaW5uZXJTZWxlY3Rpb25zLnNwbGljZShpbmRleCwgMSk7XG4gICAgICAgIHRoaXMuc2VsZWN0aW9uQ2hhbmdlLmVtaXQodGhpcy5pbm5lclNlbGVjdGlvbnMpO1xuICAgIH1cbn1cbiIsIkBmb3IgKHNlbGVjdGlvbiBvZiBpbm5lclNlbGVjdGlvbnM7IHRyYWNrICRpbmRleCkge1xuICAgIDxuYXR1cmFsLWlucHV0XG4gICAgICAgIChjbGVhcmVkKT1cInJlbW92ZUlucHV0KCRpbmRleClcIlxuICAgICAgICAoc2VsZWN0aW9uQ2hhbmdlKT1cInVwZGF0ZUlucHV0KCRldmVudCwgJGluZGV4KVwiXG4gICAgICAgIFtmYWNldHNdPVwiZmFjZXRzXCJcbiAgICAgICAgW3NlbGVjdGlvbl09XCJzZWxlY3Rpb25cIlxuICAgIC8+XG59XG5cbjxuYXR1cmFsLWlucHV0XG4gICAgI25ld1ZhbHVlSW5wdXRcbiAgICAoc2VsZWN0aW9uQ2hhbmdlKT1cImFkZElucHV0KCRldmVudClcIlxuICAgIFtmYWNldHNdPVwiZmFjZXRzXCJcbiAgICBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIlxuICAgIHRhYkluZGV4PVwiMTBcIlxuICAgIGNka0ZvY3VzSW5pdGlhbFxuICAgIFtkcm9wZG93blRpdGxlXT1cImRyb3Bkb3duVGl0bGVcIlxuLz5cbiJdfQ==
@@ -1,9 +1,9 @@
1
- import { Component, createComponent, createEnvironmentInjector, EventEmitter, HostListener, Input, Output, ViewChild, } from '@angular/core';
1
+ import { Component, createComponent, createEnvironmentInjector, ElementRef, EnvironmentInjector, EventEmitter, HostListener, Input, Output, ViewChild, inject, } from '@angular/core';
2
2
  import { FormControl, FormsModule, ReactiveFormsModule } from '@angular/forms';
3
3
  import { MatRipple, MatRippleModule } from '@angular/material/core';
4
4
  import { getFacetFromSelection } from '../classes/utils';
5
5
  import { NaturalDropdownRef } from '../dropdown-container/dropdown-ref';
6
- import { NATURAL_DROPDOWN_DATA, } from '../dropdown-container/dropdown.service';
6
+ import { NATURAL_DROPDOWN_DATA, NaturalDropdownService, } from '../dropdown-container/dropdown.service';
7
7
  import { FacetSelectorComponent } from '../facet-selector/facet-selector.component';
8
8
  import { MatButtonModule } from '@angular/material/button';
9
9
  import { NaturalIconDirective } from '../../icon/icon.directive';
@@ -11,13 +11,12 @@ import { MatIconModule } from '@angular/material/icon';
11
11
  import { MatInputModule } from '@angular/material/input';
12
12
  import { MatFormFieldModule } from '@angular/material/form-field';
13
13
  import * as i0 from "@angular/core";
14
- import * as i1 from "../dropdown-container/dropdown.service";
15
- import * as i2 from "@angular/material/form-field";
16
- import * as i3 from "@angular/material/core";
17
- import * as i4 from "@angular/material/input";
18
- import * as i5 from "@angular/forms";
19
- import * as i6 from "@angular/material/icon";
20
- import * as i7 from "@angular/material/button";
14
+ import * as i1 from "@angular/material/form-field";
15
+ import * as i2 from "@angular/material/core";
16
+ import * as i3 from "@angular/material/input";
17
+ import * as i4 from "@angular/forms";
18
+ import * as i5 from "@angular/material/icon";
19
+ import * as i6 from "@angular/material/button";
21
20
  // Required to check invalid fields when initializing natural-search
22
21
  class AlwaysErrorStateMatcher {
23
22
  isErrorState(control) {
@@ -33,6 +32,80 @@ function isComponentValid(component) {
33
32
  };
34
33
  }
35
34
  export class NaturalInputComponent {
35
+ element = inject(ElementRef);
36
+ dropdownService = inject(NaturalDropdownService);
37
+ injector = inject(EnvironmentInjector);
38
+ /**
39
+ * Controls the ripple effect, used when opening a dropdown
40
+ */
41
+ ripple;
42
+ /**
43
+ * Native element ref for <input> related to this <natural-input> component
44
+ */
45
+ input;
46
+ /**
47
+ * Label for this field
48
+ */
49
+ placeholder;
50
+ /**
51
+ * Name of the field on which do a global search (without facet)
52
+ */
53
+ searchFieldName = 'search';
54
+ /**
55
+ * Selected setted for this component
56
+ */
57
+ selection = null;
58
+ /**
59
+ * Available facets, allows the user to pick one, than generated then a selection
60
+ */
61
+ facets;
62
+ /**
63
+ * Text display in the dropdown to select the facet
64
+ */
65
+ dropdownTitle = '';
66
+ /**
67
+ * Emits when user a added/updated/deleted a search (from global context or from facet)
68
+ */
69
+ selectionChange = new EventEmitter();
70
+ /**
71
+ * Emits when user removes the search by pressing the cross icon
72
+ */
73
+ cleared = new EventEmitter();
74
+ /**
75
+ * Selected facet from the list of available facets
76
+ */
77
+ facet = null;
78
+ /**
79
+ * Controller for the input field
80
+ */
81
+ formCtrl = new FormControl(null);
82
+ /**
83
+ * Customer error matcher that should validate on each change (including initialisation)
84
+ */
85
+ errorMatcher = new AlwaysErrorStateMatcher();
86
+ /**
87
+ * Reference of the opened dropdown container
88
+ */
89
+ dropdownRef = null;
90
+ /**
91
+ * Reference of the component inside the dropdown container
92
+ */
93
+ dropdownComponentRef = null;
94
+ /**
95
+ * Minimum input length (number of chars)
96
+ * See length attribute
97
+ */
98
+ minLength = 5;
99
+ /**
100
+ * Size of the input (number of chars)
101
+ * Match the input.size attribute
102
+ */
103
+ length = this.minLength;
104
+ /**
105
+ * Flag, that, if marked as yes, prevents the opening of the dropdown
106
+ * Is used to prevent dropdown opening when natural-search takes the focus from parent context (like on modal opening)
107
+ */
108
+ neutralizeDropdownOpening = false;
36
109
  /**
37
110
  * Custom management for taking the focus from parent context
38
111
  * When focusing manually on the <input>, a dropdown is opened
@@ -43,66 +116,6 @@ export class NaturalInputComponent {
43
116
  this.input.nativeElement.focus();
44
117
  this.neutralizeDropdownOpening = false;
45
118
  }
46
- constructor(element, dropdownService, injector) {
47
- this.element = element;
48
- this.dropdownService = dropdownService;
49
- this.injector = injector;
50
- /**
51
- * Name of the field on which do a global search (without facet)
52
- */
53
- this.searchFieldName = 'search';
54
- /**
55
- * Selected setted for this component
56
- */
57
- this.selection = null;
58
- /**
59
- * Text display in the dropdown to select the facet
60
- */
61
- this.dropdownTitle = '';
62
- /**
63
- * Emits when user a added/updated/deleted a search (from global context or from facet)
64
- */
65
- this.selectionChange = new EventEmitter();
66
- /**
67
- * Emits when user removes the search by pressing the cross icon
68
- */
69
- this.cleared = new EventEmitter();
70
- /**
71
- * Selected facet from the list of available facets
72
- */
73
- this.facet = null;
74
- /**
75
- * Controller for the input field
76
- */
77
- this.formCtrl = new FormControl(null);
78
- /**
79
- * Customer error matcher that should validate on each change (including initialisation)
80
- */
81
- this.errorMatcher = new AlwaysErrorStateMatcher();
82
- /**
83
- * Reference of the opened dropdown container
84
- */
85
- this.dropdownRef = null;
86
- /**
87
- * Reference of the component inside the dropdown container
88
- */
89
- this.dropdownComponentRef = null;
90
- /**
91
- * Minimum input length (number of chars)
92
- * See length attribute
93
- */
94
- this.minLength = 5;
95
- /**
96
- * Size of the input (number of chars)
97
- * Match the input.size attribute
98
- */
99
- this.length = this.minLength;
100
- /**
101
- * Flag, that, if marked as yes, prevents the opening of the dropdown
102
- * Is used to prevent dropdown opening when natural-search takes the focus from parent context (like on modal opening)
103
- */
104
- this.neutralizeDropdownOpening = false;
105
- }
106
119
  ngOnChanges() {
107
120
  if (!this.facets && this.selection) {
108
121
  setTimeout(() => this.clear());
@@ -309,8 +322,8 @@ export class NaturalInputComponent {
309
322
  }
310
323
  return selection;
311
324
  }
312
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalInputComponent, deps: [{ token: i0.ElementRef }, { token: i1.NaturalDropdownService }, { token: i0.EnvironmentInjector }], target: i0.ɵɵFactoryTarget.Component }); }
313
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: NaturalInputComponent, isStandalone: true, selector: "natural-input", inputs: { placeholder: "placeholder", searchFieldName: "searchFieldName", selection: "selection", facets: "facets", dropdownTitle: "dropdownTitle" }, outputs: { selectionChange: "selectionChange", cleared: "cleared" }, host: { listeners: { "focus": "focus()" } }, viewQueries: [{ propertyName: "ripple", first: true, predicate: MatRipple, descendants: true, static: true }, { propertyName: "input", first: true, predicate: ["input"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<!-- click condition should match to allow click action only when no other button is visible -->\n<mat-form-field #field matRipple (click)=\"!selection && !(facet && !selection) ? openDropdown() : null\">\n @if (facet) {\n <mat-label>{{ facet.display }}</mat-label>\n }\n @if (!facet) {\n <mat-label>{{ placeholder }}</mat-label>\n }\n\n <input\n #input\n (blur)=\"search($event)\"\n (keydown.enter)=\"search($event)\"\n [attr.size]=\"length\"\n [errorStateMatcher]=\"errorMatcher\"\n [formControl]=\"formCtrl\"\n [readonly]=\"(isDropdown() && !!selection) || isFlag()\"\n autocomplete=\"off\"\n matInput\n type=\"text\"\n />\n\n @if (!facet && !selection) {\n <mat-icon naturalIcon=\"search\" matIconPrefix />\n }\n\n @if (selection) {\n <button (click)=\"clear()\" mat-icon-button matIconSuffix>\n <mat-icon naturalIcon=\"close\" />\n </button>\n }\n\n @if (facet && !selection) {\n <button (click)=\"clear()\" mat-icon-button matIconSuffix>\n <mat-icon naturalIcon=\"undo\" />\n </button>\n }\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n", styles: [":host{display:flex;position:relative;flex-direction:column;border-top-right-radius:4px;border-top-left-radius:4px;overflow:hidden}:host .hide{margin:0 50px 0 10px;height:0;color:transparent;font-size:inherit;font-family:Roboto,Helvetica Neue,sans-serif;white-space:nowrap}\n"], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatRippleModule }, { kind: "directive", type: i3.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NaturalIconDirective, selector: "mat-icon[naturalIcon]", inputs: ["naturalIcon", "size"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i7.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }] }); }
325
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
326
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: NaturalInputComponent, isStandalone: true, selector: "natural-input", inputs: { placeholder: "placeholder", searchFieldName: "searchFieldName", selection: "selection", facets: "facets", dropdownTitle: "dropdownTitle" }, outputs: { selectionChange: "selectionChange", cleared: "cleared" }, host: { listeners: { "focus": "focus()" } }, viewQueries: [{ propertyName: "ripple", first: true, predicate: MatRipple, descendants: true, static: true }, { propertyName: "input", first: true, predicate: ["input"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<!-- click condition should match to allow click action only when no other button is visible -->\n<mat-form-field #field matRipple (click)=\"!selection && !(facet && !selection) ? openDropdown() : null\">\n @if (facet) {\n <mat-label>{{ facet.display }}</mat-label>\n }\n @if (!facet) {\n <mat-label>{{ placeholder }}</mat-label>\n }\n\n <input\n #input\n (blur)=\"search($event)\"\n (keydown.enter)=\"search($event)\"\n [attr.size]=\"length\"\n [errorStateMatcher]=\"errorMatcher\"\n [formControl]=\"formCtrl\"\n [readonly]=\"(isDropdown() && !!selection) || isFlag()\"\n autocomplete=\"off\"\n matInput\n type=\"text\"\n />\n\n @if (!facet && !selection) {\n <mat-icon naturalIcon=\"search\" matIconPrefix />\n }\n\n @if (selection) {\n <button (click)=\"clear()\" mat-icon-button matIconSuffix>\n <mat-icon naturalIcon=\"close\" />\n </button>\n }\n\n @if (facet && !selection) {\n <button (click)=\"clear()\" mat-icon-button matIconSuffix>\n <mat-icon naturalIcon=\"undo\" />\n </button>\n }\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n", styles: [":host{display:flex;position:relative;flex-direction:column;border-top-right-radius:4px;border-top-left-radius:4px;overflow:hidden}:host .hide{margin:0 50px 0 10px;height:0;color:transparent;font-size:inherit;font-family:Roboto,Helvetica Neue,sans-serif;white-space:nowrap}\n"], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { kind: "directive", type: i1.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "directive", type: i1.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatRippleModule }, { kind: "directive", type: i2.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NaturalIconDirective, selector: "mat-icon[naturalIcon]", inputs: ["naturalIcon", "size"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i6.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }] });
314
327
  }
315
328
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalInputComponent, decorators: [{
316
329
  type: Component,
@@ -324,7 +337,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
324
337
  NaturalIconDirective,
325
338
  MatButtonModule,
326
339
  ], template: "<!-- click condition should match to allow click action only when no other button is visible -->\n<mat-form-field #field matRipple (click)=\"!selection && !(facet && !selection) ? openDropdown() : null\">\n @if (facet) {\n <mat-label>{{ facet.display }}</mat-label>\n }\n @if (!facet) {\n <mat-label>{{ placeholder }}</mat-label>\n }\n\n <input\n #input\n (blur)=\"search($event)\"\n (keydown.enter)=\"search($event)\"\n [attr.size]=\"length\"\n [errorStateMatcher]=\"errorMatcher\"\n [formControl]=\"formCtrl\"\n [readonly]=\"(isDropdown() && !!selection) || isFlag()\"\n autocomplete=\"off\"\n matInput\n type=\"text\"\n />\n\n @if (!facet && !selection) {\n <mat-icon naturalIcon=\"search\" matIconPrefix />\n }\n\n @if (selection) {\n <button (click)=\"clear()\" mat-icon-button matIconSuffix>\n <mat-icon naturalIcon=\"close\" />\n </button>\n }\n\n @if (facet && !selection) {\n <button (click)=\"clear()\" mat-icon-button matIconSuffix>\n <mat-icon naturalIcon=\"undo\" />\n </button>\n }\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n", styles: [":host{display:flex;position:relative;flex-direction:column;border-top-right-radius:4px;border-top-left-radius:4px;overflow:hidden}:host .hide{margin:0 50px 0 10px;height:0;color:transparent;font-size:inherit;font-family:Roboto,Helvetica Neue,sans-serif;white-space:nowrap}\n"] }]
327
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.NaturalDropdownService }, { type: i0.EnvironmentInjector }], propDecorators: { ripple: [{
340
+ }], propDecorators: { ripple: [{
328
341
  type: ViewChild,
329
342
  args: [MatRipple, { static: true }]
330
343
  }], input: [{
@@ -349,4 +362,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
349
362
  type: HostListener,
350
363
  args: ['focus']
351
364
  }] } });
352
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/search/input/input.component.ts","../../../../../../../projects/natural/src/lib/modules/search/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ComponentRef,\n    createComponent,\n    createEnvironmentInjector,\n    ElementRef,\n    EnvironmentInjector,\n    EventEmitter,\n    HostListener,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    StaticProvider,\n    ViewChild,\n} from '@angular/core';\nimport {FormControl, FormsModule, ReactiveFormsModule, ValidationErrors, ValidatorFn} from '@angular/forms';\nimport {ErrorStateMatcher, MatRipple, MatRippleModule} from '@angular/material/core';\nimport {FilterGroupConditionField} from '../classes/graphql-doctrine.types';\nimport {getFacetFromSelection} from '../classes/utils';\nimport {NaturalDropdownRef} from '../dropdown-container/dropdown-ref';\nimport {\n    NATURAL_DROPDOWN_DATA,\n    NaturalDropdownData,\n    NaturalDropdownService,\n} from '../dropdown-container/dropdown.service';\nimport {FacetSelectorComponent, FacetSelectorConfiguration} from '../facet-selector/facet-selector.component';\nimport {DropdownComponent} from '../types/dropdown-component';\nimport {DropdownFacet, Facet, FlagFacet, NaturalSearchFacets} from '../types/facet';\nimport {DropdownResult, NaturalSearchSelection} from '../types/values';\nimport {MatButtonModule} from '@angular/material/button';\nimport {NaturalIconDirective} from '../../icon/icon.directive';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatFormFieldModule} from '@angular/material/form-field';\n\n// Required to check invalid fields when initializing natural-search\nclass AlwaysErrorStateMatcher implements ErrorStateMatcher {\n    public isErrorState(control: FormControl<unknown> | null): boolean {\n        return !!control && control.invalid;\n    }\n}\n\nfunction isComponentValid(component: DropdownComponent): ValidatorFn {\n    return (): ValidationErrors | null => {\n        if (!component.isValid()) {\n            return {component: true};\n        }\n\n        return null;\n    };\n}\n\n@Component({\n    selector: 'natural-input',\n    templateUrl: './input.component.html',\n    styleUrl: './input.component.scss',\n    standalone: true,\n    imports: [\n        MatFormFieldModule,\n        MatRippleModule,\n        MatInputModule,\n        FormsModule,\n        ReactiveFormsModule,\n        MatIconModule,\n        NaturalIconDirective,\n        MatButtonModule,\n    ],\n})\nexport class NaturalInputComponent implements OnInit, OnChanges, OnDestroy {\n    /**\n     * Controls the ripple effect, used when opening a dropdown\n     */\n    @ViewChild(MatRipple, {static: true}) public ripple!: MatRipple;\n\n    /**\n     * Native element ref for <input> related to this <natural-input> component\n     */\n    @ViewChild('input', {static: true}) public input!: ElementRef<HTMLInputElement>;\n\n    /**\n     * Label for this field\n     */\n    @Input() public placeholder?: string;\n\n    /**\n     * Name of the field on which do a global search (without facet)\n     */\n    @Input() public searchFieldName = 'search';\n\n    /**\n     * Selected setted for this component\n     */\n    @Input() public selection: NaturalSearchSelection | null = null;\n\n    /**\n     * Available facets, allows the user to pick one, than generated then a selection\n     */\n    @Input({required: true}) public facets!: NaturalSearchFacets;\n\n    /**\n     * Text display in the dropdown to select the facet\n     */\n    @Input() public dropdownTitle = '';\n\n    /**\n     * Emits when user a added/updated/deleted a search (from global context or from facet)\n     */\n    @Output() public readonly selectionChange = new EventEmitter<NaturalSearchSelection>();\n\n    /**\n     * Emits when user removes the search by pressing the cross icon\n     */\n    @Output() public readonly cleared = new EventEmitter<NaturalInputComponent>();\n\n    /**\n     * Selected facet from the list of available facets\n     */\n    public facet: Facet | null = null;\n\n    /**\n     * Controller for the input field\n     */\n    public readonly formCtrl = new FormControl<string | null>(null);\n\n    /**\n     * Customer error matcher that should validate on each change (including initialisation)\n     */\n    public readonly errorMatcher = new AlwaysErrorStateMatcher();\n\n    /**\n     * Reference of the opened dropdown container\n     */\n    private dropdownRef: NaturalDropdownRef | null = null;\n\n    /**\n     * Reference of the component inside the dropdown container\n     */\n    private dropdownComponentRef: ComponentRef<DropdownComponent> | null = null;\n\n    /**\n     *  Minimum input length (number of chars)\n     *  See length attribute\n     */\n    private readonly minLength = 5;\n\n    /**\n     * Size of the input (number of chars)\n     * Match the input.size attribute\n     */\n    public length = this.minLength;\n\n    /**\n     * Flag, that, if marked as yes, prevents the opening of the dropdown\n     * Is used to prevent dropdown opening when natural-search takes the focus from parent context (like on modal opening)\n     */\n    private neutralizeDropdownOpening = false;\n\n    /**\n     * Custom management for taking the focus from parent context\n     * When focusing manually on the <input>, a dropdown is opened\n     * But when the focus is given from angular in a parent context (like a dialog) the dropdown would open and we don't want it.\n     */\n    @HostListener('focus')\n    public focus(): void {\n        this.neutralizeDropdownOpening = true;\n        this.input.nativeElement.focus();\n        this.neutralizeDropdownOpening = false;\n    }\n\n    public constructor(\n        private readonly element: ElementRef<HTMLElement>,\n        private readonly dropdownService: NaturalDropdownService,\n        private readonly injector: EnvironmentInjector,\n    ) {}\n\n    public ngOnChanges(): void {\n        if (!this.facets && this.selection) {\n            setTimeout(() => this.clear());\n        } else if (this.facets && this.selection) {\n            this.facet = getFacetFromSelection(this.facets, this.selection);\n\n            if (this.isDropdown()) {\n                const dropdownComponent = this.createComponent(this.facet as DropdownFacet<FacetSelectorConfiguration>);\n                this.formCtrl.setValidators([isComponentValid(dropdownComponent)]);\n                dropdownComponent.renderedValue.subscribe(value => {\n                    this.formCtrl.setValue(value);\n                });\n            } else if (this.isFlag()) {\n                this.formCtrl.setValue('');\n            } else if (\n                this.selection &&\n                this.selection.field === this.searchFieldName &&\n                this.selection.condition.like\n            ) {\n                // global search mode\n                this.formCtrl.setValue('' + this.selection.condition.like.value);\n            } else {\n                // If component is invalid (no facet and not a global search), clear from result and destroy component\n                setTimeout(() => this.clear());\n            }\n        }\n    }\n\n    public ngOnInit(): void {\n        this.input.nativeElement.addEventListener('focus', () => {\n            this.openDropdown();\n        });\n\n        this.input.nativeElement.addEventListener('keyup', () => {\n            if (!this.dropdownRef) {\n                return;\n            }\n\n            if (this.formCtrl.value !== '') {\n                this.dropdownRef.close();\n            }\n        });\n\n        if (!this.placeholder) {\n            this.placeholder = $localize`Recherche`;\n        }\n\n        const placeholderSize = (this.facet ? this.facet.display.length : this.placeholder.length) * 0.66;\n        this.length = Math.max(this.minLength, Math.ceil(placeholderSize));\n    }\n\n    public ngOnDestroy(): void {\n        if (this.dropdownComponentRef) {\n            this.dropdownComponentRef.destroy();\n        }\n    }\n\n    public search(event: Event): void {\n        event.stopPropagation();\n        event.preventDefault();\n\n        if (!this.formCtrl.value) {\n            return;\n        }\n\n        if (this.isDropdown()) {\n            return;\n        }\n\n        if (this.formCtrl.valid && this.formCtrl.dirty) {\n            this.selectionChange.emit(this.getSelection({like: {value: this.formCtrl.value}}));\n        }\n    }\n\n    public clear(): void {\n        // Prevent opening the facets list when we are removing a facet\n        this.neutralizeDropdownOpening = true;\n        setTimeout(() => (this.neutralizeDropdownOpening = false));\n\n        this.facet = null;\n        this.selection = null;\n        this.formCtrl.setValue(null);\n        this.cleared.emit(this);\n    }\n\n    public openDropdown(): void {\n        if (this.dropdownRef || this.neutralizeDropdownOpening) {\n            // Prevent to open multiple dropdowns.\n            // Happens as we open on \"focus\", and alt+tab re-activate focus on an element that already had\n            // focus when leaving window with another alt+tab\n            return;\n        }\n\n        this.launchRipple();\n\n        // If there is no facet and no string typed, show panel to select the facet\n        if (!this.facet && !this.formCtrl.value) {\n            this.openFacetSelectorDropdown(this.dropdownTitle);\n        } else {\n            // If a facet is selected, open specific component dropdown\n            this.openTypeDropdown();\n        }\n    }\n\n    public isDropdown(): boolean {\n        return !!(this.facet && (this.facet as DropdownFacet<unknown>).component);\n    }\n\n    public isFlag(): boolean {\n        return !!(this.facet && (this.facet as FlagFacet<FilterGroupConditionField>).condition);\n    }\n\n    private createComponent(facet: DropdownFacet<unknown>): DropdownComponent {\n        // Always destroy and recreate component\n        // Todo : test if facet has changed, if not re-use the component\n        if (this.dropdownComponentRef) {\n            this.dropdownComponentRef.destroy();\n        }\n\n        const condition = this.selection ? this.selection.condition : null;\n        const data: NaturalDropdownData = {\n            condition: condition,\n            configuration: facet.configuration,\n        };\n\n        const injector = createEnvironmentInjector(this.createProviders(data), this.injector);\n        this.dropdownComponentRef = createComponent(facet.component, {\n            environmentInjector: injector,\n        });\n\n        return this.dropdownComponentRef.instance;\n    }\n\n    private createProviders(data: NaturalDropdownData): StaticProvider[] {\n        // Customize injector to allow data and dropdown reference injection in component\n        return [\n            {\n                provide: NaturalDropdownRef,\n                useValue: null,\n            },\n            {\n                provide: NATURAL_DROPDOWN_DATA,\n                useValue: data,\n            },\n        ];\n    }\n\n    private launchRipple(): void {\n        const rippleRef = this.ripple.launch({\n            persistent: true,\n            centered: true,\n        });\n\n        rippleRef.fadeOut();\n    }\n\n    private openFacetSelectorDropdown(title: string | undefined): void {\n        if (!this.facets || (this.facets && !this.facets.length)) {\n            return;\n        }\n\n        const data: NaturalDropdownData<FacetSelectorConfiguration> = {\n            condition: {},\n            title: title,\n            configuration: {\n                facets: this.facets,\n            },\n        };\n\n        const injectorTokens = this.createProviders(data);\n        this.dropdownRef = this.dropdownService.open(FacetSelectorComponent, this.element, injectorTokens, false);\n        this.dropdownRef.closed.subscribe(result => {\n            this.dropdownRef = null;\n            if (result !== undefined) {\n                if (result.facet) {\n                    this.setFacet(result.facet);\n                } else if (result.condition) {\n                    this.setValue(result);\n                }\n            }\n        });\n    }\n\n    private openTypeDropdown(): void {\n        if (!this.isDropdown()) {\n            return;\n        }\n\n        const dropdownFacet = this.facet as DropdownFacet<unknown>;\n\n        const data: NaturalDropdownData = {\n            condition: this.selection ? this.selection.condition : null,\n            configuration: dropdownFacet.configuration,\n        };\n\n        const injectorTokens = this.createProviders(data);\n        const component = dropdownFacet.component;\n        this.dropdownRef = this.dropdownService.open(\n            component,\n            this.element,\n            injectorTokens,\n            dropdownFacet.showValidateButton !== undefined ? dropdownFacet.showValidateButton : true,\n        );\n\n        this.dropdownRef.closed.subscribe(result => {\n            this.dropdownRef = null;\n            if (result !== undefined) {\n                this.setValue(result);\n            }\n        });\n    }\n\n    private setFacet(facet: Facet): void {\n        this.facet = facet;\n\n        if (this.isDropdown()) {\n            this.openTypeDropdown();\n        } else if (this.isFlag()) {\n            this.setValue({\n                condition: (facet as FlagFacet<FilterGroupConditionField>).condition,\n            });\n        } else {\n            this.input.nativeElement.focus();\n        }\n    }\n\n    private setValue(result: DropdownResult): void {\n        if (this.facet) {\n            this.selectionChange.emit(this.getSelection(result.condition));\n        }\n    }\n\n    private getSelection(condition: NaturalSearchSelection['condition']): NaturalSearchSelection {\n        const selection: NaturalSearchSelection = {\n            field: this.facet ? this.facet.field : this.searchFieldName,\n            condition: condition,\n        };\n\n        if (this.facet?.name) {\n            selection.name = this.facet.name;\n        }\n\n        return selection;\n    }\n}\n","<!-- click condition should match to allow click action only when no other button is visible -->\n<mat-form-field #field matRipple (click)=\"!selection && !(facet && !selection) ? openDropdown() : null\">\n    @if (facet) {\n        <mat-label>{{ facet.display }}</mat-label>\n    }\n    @if (!facet) {\n        <mat-label>{{ placeholder }}</mat-label>\n    }\n\n    <input\n        #input\n        (blur)=\"search($event)\"\n        (keydown.enter)=\"search($event)\"\n        [attr.size]=\"length\"\n        [errorStateMatcher]=\"errorMatcher\"\n        [formControl]=\"formCtrl\"\n        [readonly]=\"(isDropdown() && !!selection) || isFlag()\"\n        autocomplete=\"off\"\n        matInput\n        type=\"text\"\n    />\n\n    @if (!facet && !selection) {\n        <mat-icon naturalIcon=\"search\" matIconPrefix />\n    }\n\n    @if (selection) {\n        <button (click)=\"clear()\" mat-icon-button matIconSuffix>\n            <mat-icon naturalIcon=\"close\" />\n        </button>\n    }\n\n    @if (facet && !selection) {\n        <button (click)=\"clear()\" mat-icon-button matIconSuffix>\n            <mat-icon naturalIcon=\"undo\" />\n        </button>\n    }\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n"]}
365
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/search/input/input.component.ts","../../../../../../../projects/natural/src/lib/modules/search/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ComponentRef,\n    createComponent,\n    createEnvironmentInjector,\n    ElementRef,\n    EnvironmentInjector,\n    EventEmitter,\n    HostListener,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    StaticProvider,\n    ViewChild,\n    inject,\n} from '@angular/core';\nimport {FormControl, FormsModule, ReactiveFormsModule, ValidationErrors, ValidatorFn} from '@angular/forms';\nimport {ErrorStateMatcher, MatRipple, MatRippleModule} from '@angular/material/core';\nimport {FilterGroupConditionField} from '../classes/graphql-doctrine.types';\nimport {getFacetFromSelection} from '../classes/utils';\nimport {NaturalDropdownRef} from '../dropdown-container/dropdown-ref';\nimport {\n    NATURAL_DROPDOWN_DATA,\n    NaturalDropdownData,\n    NaturalDropdownService,\n} from '../dropdown-container/dropdown.service';\nimport {FacetSelectorComponent, FacetSelectorConfiguration} from '../facet-selector/facet-selector.component';\nimport {DropdownComponent} from '../types/dropdown-component';\nimport {DropdownFacet, Facet, FlagFacet, NaturalSearchFacets} from '../types/facet';\nimport {DropdownResult, NaturalSearchSelection} from '../types/values';\nimport {MatButtonModule} from '@angular/material/button';\nimport {NaturalIconDirective} from '../../icon/icon.directive';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatFormFieldModule} from '@angular/material/form-field';\n\n// Required to check invalid fields when initializing natural-search\nclass AlwaysErrorStateMatcher implements ErrorStateMatcher {\n    public isErrorState(control: FormControl<unknown> | null): boolean {\n        return !!control && control.invalid;\n    }\n}\n\nfunction isComponentValid(component: DropdownComponent): ValidatorFn {\n    return (): ValidationErrors | null => {\n        if (!component.isValid()) {\n            return {component: true};\n        }\n\n        return null;\n    };\n}\n\n@Component({\n    selector: 'natural-input',\n    templateUrl: './input.component.html',\n    styleUrl: './input.component.scss',\n    standalone: true,\n    imports: [\n        MatFormFieldModule,\n        MatRippleModule,\n        MatInputModule,\n        FormsModule,\n        ReactiveFormsModule,\n        MatIconModule,\n        NaturalIconDirective,\n        MatButtonModule,\n    ],\n})\nexport class NaturalInputComponent implements OnInit, OnChanges, OnDestroy {\n    private readonly element = inject<ElementRef<HTMLElement>>(ElementRef);\n    private readonly dropdownService = inject(NaturalDropdownService);\n    private readonly injector = inject(EnvironmentInjector);\n\n    /**\n     * Controls the ripple effect, used when opening a dropdown\n     */\n    @ViewChild(MatRipple, {static: true}) public ripple!: MatRipple;\n\n    /**\n     * Native element ref for <input> related to this <natural-input> component\n     */\n    @ViewChild('input', {static: true}) public input!: ElementRef<HTMLInputElement>;\n\n    /**\n     * Label for this field\n     */\n    @Input() public placeholder?: string;\n\n    /**\n     * Name of the field on which do a global search (without facet)\n     */\n    @Input() public searchFieldName = 'search';\n\n    /**\n     * Selected setted for this component\n     */\n    @Input() public selection: NaturalSearchSelection | null = null;\n\n    /**\n     * Available facets, allows the user to pick one, than generated then a selection\n     */\n    @Input({required: true}) public facets!: NaturalSearchFacets;\n\n    /**\n     * Text display in the dropdown to select the facet\n     */\n    @Input() public dropdownTitle = '';\n\n    /**\n     * Emits when user a added/updated/deleted a search (from global context or from facet)\n     */\n    @Output() public readonly selectionChange = new EventEmitter<NaturalSearchSelection>();\n\n    /**\n     * Emits when user removes the search by pressing the cross icon\n     */\n    @Output() public readonly cleared = new EventEmitter<NaturalInputComponent>();\n\n    /**\n     * Selected facet from the list of available facets\n     */\n    public facet: Facet | null = null;\n\n    /**\n     * Controller for the input field\n     */\n    public readonly formCtrl = new FormControl<string | null>(null);\n\n    /**\n     * Customer error matcher that should validate on each change (including initialisation)\n     */\n    public readonly errorMatcher = new AlwaysErrorStateMatcher();\n\n    /**\n     * Reference of the opened dropdown container\n     */\n    private dropdownRef: NaturalDropdownRef | null = null;\n\n    /**\n     * Reference of the component inside the dropdown container\n     */\n    private dropdownComponentRef: ComponentRef<DropdownComponent> | null = null;\n\n    /**\n     *  Minimum input length (number of chars)\n     *  See length attribute\n     */\n    private readonly minLength = 5;\n\n    /**\n     * Size of the input (number of chars)\n     * Match the input.size attribute\n     */\n    public length = this.minLength;\n\n    /**\n     * Flag, that, if marked as yes, prevents the opening of the dropdown\n     * Is used to prevent dropdown opening when natural-search takes the focus from parent context (like on modal opening)\n     */\n    private neutralizeDropdownOpening = false;\n\n    /**\n     * Custom management for taking the focus from parent context\n     * When focusing manually on the <input>, a dropdown is opened\n     * But when the focus is given from angular in a parent context (like a dialog) the dropdown would open and we don't want it.\n     */\n    @HostListener('focus')\n    public focus(): void {\n        this.neutralizeDropdownOpening = true;\n        this.input.nativeElement.focus();\n        this.neutralizeDropdownOpening = false;\n    }\n\n    public ngOnChanges(): void {\n        if (!this.facets && this.selection) {\n            setTimeout(() => this.clear());\n        } else if (this.facets && this.selection) {\n            this.facet = getFacetFromSelection(this.facets, this.selection);\n\n            if (this.isDropdown()) {\n                const dropdownComponent = this.createComponent(this.facet as DropdownFacet<FacetSelectorConfiguration>);\n                this.formCtrl.setValidators([isComponentValid(dropdownComponent)]);\n                dropdownComponent.renderedValue.subscribe(value => {\n                    this.formCtrl.setValue(value);\n                });\n            } else if (this.isFlag()) {\n                this.formCtrl.setValue('');\n            } else if (\n                this.selection &&\n                this.selection.field === this.searchFieldName &&\n                this.selection.condition.like\n            ) {\n                // global search mode\n                this.formCtrl.setValue('' + this.selection.condition.like.value);\n            } else {\n                // If component is invalid (no facet and not a global search), clear from result and destroy component\n                setTimeout(() => this.clear());\n            }\n        }\n    }\n\n    public ngOnInit(): void {\n        this.input.nativeElement.addEventListener('focus', () => {\n            this.openDropdown();\n        });\n\n        this.input.nativeElement.addEventListener('keyup', () => {\n            if (!this.dropdownRef) {\n                return;\n            }\n\n            if (this.formCtrl.value !== '') {\n                this.dropdownRef.close();\n            }\n        });\n\n        if (!this.placeholder) {\n            this.placeholder = $localize`Recherche`;\n        }\n\n        const placeholderSize = (this.facet ? this.facet.display.length : this.placeholder.length) * 0.66;\n        this.length = Math.max(this.minLength, Math.ceil(placeholderSize));\n    }\n\n    public ngOnDestroy(): void {\n        if (this.dropdownComponentRef) {\n            this.dropdownComponentRef.destroy();\n        }\n    }\n\n    public search(event: Event): void {\n        event.stopPropagation();\n        event.preventDefault();\n\n        if (!this.formCtrl.value) {\n            return;\n        }\n\n        if (this.isDropdown()) {\n            return;\n        }\n\n        if (this.formCtrl.valid && this.formCtrl.dirty) {\n            this.selectionChange.emit(this.getSelection({like: {value: this.formCtrl.value}}));\n        }\n    }\n\n    public clear(): void {\n        // Prevent opening the facets list when we are removing a facet\n        this.neutralizeDropdownOpening = true;\n        setTimeout(() => (this.neutralizeDropdownOpening = false));\n\n        this.facet = null;\n        this.selection = null;\n        this.formCtrl.setValue(null);\n        this.cleared.emit(this);\n    }\n\n    public openDropdown(): void {\n        if (this.dropdownRef || this.neutralizeDropdownOpening) {\n            // Prevent to open multiple dropdowns.\n            // Happens as we open on \"focus\", and alt+tab re-activate focus on an element that already had\n            // focus when leaving window with another alt+tab\n            return;\n        }\n\n        this.launchRipple();\n\n        // If there is no facet and no string typed, show panel to select the facet\n        if (!this.facet && !this.formCtrl.value) {\n            this.openFacetSelectorDropdown(this.dropdownTitle);\n        } else {\n            // If a facet is selected, open specific component dropdown\n            this.openTypeDropdown();\n        }\n    }\n\n    public isDropdown(): boolean {\n        return !!(this.facet && (this.facet as DropdownFacet<unknown>).component);\n    }\n\n    public isFlag(): boolean {\n        return !!(this.facet && (this.facet as FlagFacet<FilterGroupConditionField>).condition);\n    }\n\n    private createComponent(facet: DropdownFacet<unknown>): DropdownComponent {\n        // Always destroy and recreate component\n        // Todo : test if facet has changed, if not re-use the component\n        if (this.dropdownComponentRef) {\n            this.dropdownComponentRef.destroy();\n        }\n\n        const condition = this.selection ? this.selection.condition : null;\n        const data: NaturalDropdownData = {\n            condition: condition,\n            configuration: facet.configuration,\n        };\n\n        const injector = createEnvironmentInjector(this.createProviders(data), this.injector);\n        this.dropdownComponentRef = createComponent(facet.component, {\n            environmentInjector: injector,\n        });\n\n        return this.dropdownComponentRef.instance;\n    }\n\n    private createProviders(data: NaturalDropdownData): StaticProvider[] {\n        // Customize injector to allow data and dropdown reference injection in component\n        return [\n            {\n                provide: NaturalDropdownRef,\n                useValue: null,\n            },\n            {\n                provide: NATURAL_DROPDOWN_DATA,\n                useValue: data,\n            },\n        ];\n    }\n\n    private launchRipple(): void {\n        const rippleRef = this.ripple.launch({\n            persistent: true,\n            centered: true,\n        });\n\n        rippleRef.fadeOut();\n    }\n\n    private openFacetSelectorDropdown(title: string | undefined): void {\n        if (!this.facets || (this.facets && !this.facets.length)) {\n            return;\n        }\n\n        const data: NaturalDropdownData<FacetSelectorConfiguration> = {\n            condition: {},\n            title: title,\n            configuration: {\n                facets: this.facets,\n            },\n        };\n\n        const injectorTokens = this.createProviders(data);\n        this.dropdownRef = this.dropdownService.open(FacetSelectorComponent, this.element, injectorTokens, false);\n        this.dropdownRef.closed.subscribe(result => {\n            this.dropdownRef = null;\n            if (result !== undefined) {\n                if (result.facet) {\n                    this.setFacet(result.facet);\n                } else if (result.condition) {\n                    this.setValue(result);\n                }\n            }\n        });\n    }\n\n    private openTypeDropdown(): void {\n        if (!this.isDropdown()) {\n            return;\n        }\n\n        const dropdownFacet = this.facet as DropdownFacet<unknown>;\n\n        const data: NaturalDropdownData = {\n            condition: this.selection ? this.selection.condition : null,\n            configuration: dropdownFacet.configuration,\n        };\n\n        const injectorTokens = this.createProviders(data);\n        const component = dropdownFacet.component;\n        this.dropdownRef = this.dropdownService.open(\n            component,\n            this.element,\n            injectorTokens,\n            dropdownFacet.showValidateButton !== undefined ? dropdownFacet.showValidateButton : true,\n        );\n\n        this.dropdownRef.closed.subscribe(result => {\n            this.dropdownRef = null;\n            if (result !== undefined) {\n                this.setValue(result);\n            }\n        });\n    }\n\n    private setFacet(facet: Facet): void {\n        this.facet = facet;\n\n        if (this.isDropdown()) {\n            this.openTypeDropdown();\n        } else if (this.isFlag()) {\n            this.setValue({\n                condition: (facet as FlagFacet<FilterGroupConditionField>).condition,\n            });\n        } else {\n            this.input.nativeElement.focus();\n        }\n    }\n\n    private setValue(result: DropdownResult): void {\n        if (this.facet) {\n            this.selectionChange.emit(this.getSelection(result.condition));\n        }\n    }\n\n    private getSelection(condition: NaturalSearchSelection['condition']): NaturalSearchSelection {\n        const selection: NaturalSearchSelection = {\n            field: this.facet ? this.facet.field : this.searchFieldName,\n            condition: condition,\n        };\n\n        if (this.facet?.name) {\n            selection.name = this.facet.name;\n        }\n\n        return selection;\n    }\n}\n","<!-- click condition should match to allow click action only when no other button is visible -->\n<mat-form-field #field matRipple (click)=\"!selection && !(facet && !selection) ? openDropdown() : null\">\n    @if (facet) {\n        <mat-label>{{ facet.display }}</mat-label>\n    }\n    @if (!facet) {\n        <mat-label>{{ placeholder }}</mat-label>\n    }\n\n    <input\n        #input\n        (blur)=\"search($event)\"\n        (keydown.enter)=\"search($event)\"\n        [attr.size]=\"length\"\n        [errorStateMatcher]=\"errorMatcher\"\n        [formControl]=\"formCtrl\"\n        [readonly]=\"(isDropdown() && !!selection) || isFlag()\"\n        autocomplete=\"off\"\n        matInput\n        type=\"text\"\n    />\n\n    @if (!facet && !selection) {\n        <mat-icon naturalIcon=\"search\" matIconPrefix />\n    }\n\n    @if (selection) {\n        <button (click)=\"clear()\" mat-icon-button matIconSuffix>\n            <mat-icon naturalIcon=\"close\" />\n        </button>\n    }\n\n    @if (facet && !selection) {\n        <button (click)=\"clear()\" mat-icon-button matIconSuffix>\n            <mat-icon naturalIcon=\"undo\" />\n        </button>\n    }\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n"]}
@@ -4,4 +4,4 @@ export { toGraphQLDoctrineFilter } from './classes/graphql-doctrine';
4
4
  export { fromUrl, toUrl, toNavigationParameters } from './classes/url';
5
5
  export { replaceOperatorByName, wrapLike, wrapPrefix, wrapSuffix, replaceOperatorByField } from './classes/transformers';
6
6
  export { NaturalSearchComponent } from './search/search.component';
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFBLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQ3JFLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzVFLE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLDRCQUE0QixDQUFDO0FBQ25FLE9BQU8sRUFBQyxPQUFPLEVBQUUsS0FBSyxFQUFFLHNCQUFzQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3JFLE9BQU8sRUFBQyxxQkFBcUIsRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxzQkFBc0IsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZILE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBuYXR1cmFsLXNlYXJjaFxuICovXG5leHBvcnQge05hdHVyYWxEcm9wZG93bkRhdGF9IGZyb20gJy4vZHJvcGRvd24tY29udGFpbmVyL2Ryb3Bkb3duLnNlcnZpY2UnO1xuZXhwb3J0IHtGaWx0ZXJHcm91cENvbmRpdGlvbkZpZWxkLCBGaWx0ZXJ9IGZyb20gJy4vY2xhc3Nlcy9ncmFwaHFsLWRvY3RyaW5lLnR5cGVzJztcbmV4cG9ydCB7RHJvcGRvd25Db21wb25lbnR9IGZyb20gJy4vdHlwZXMvZHJvcGRvd24tY29tcG9uZW50JztcbmV4cG9ydCB7RmxhZ0ZhY2V0LCBEcm9wZG93bkZhY2V0LCBGYWNldCwgTmF0dXJhbFNlYXJjaEZhY2V0c30gZnJvbSAnLi90eXBlcy9mYWNldCc7XG5leHBvcnQge05hdHVyYWxTZWFyY2hTZWxlY3Rpb25zLCBOYXR1cmFsU2VhcmNoU2VsZWN0aW9ufSBmcm9tICcuL3R5cGVzL3ZhbHVlcyc7XG5leHBvcnQge05hdHVyYWxEcm9wZG93blJlZn0gZnJvbSAnLi9kcm9wZG93bi1jb250YWluZXIvZHJvcGRvd24tcmVmJztcbmV4cG9ydCB7TkFUVVJBTF9EUk9QRE9XTl9EQVRBfSBmcm9tICcuL2Ryb3Bkb3duLWNvbnRhaW5lci9kcm9wZG93bi5zZXJ2aWNlJztcbmV4cG9ydCB7dG9HcmFwaFFMRG9jdHJpbmVGaWx0ZXJ9IGZyb20gJy4vY2xhc3Nlcy9ncmFwaHFsLWRvY3RyaW5lJztcbmV4cG9ydCB7ZnJvbVVybCwgdG9VcmwsIHRvTmF2aWdhdGlvblBhcmFtZXRlcnN9IGZyb20gJy4vY2xhc3Nlcy91cmwnO1xuZXhwb3J0IHtyZXBsYWNlT3BlcmF0b3JCeU5hbWUsIHdyYXBMaWtlLCB3cmFwUHJlZml4LCB3cmFwU3VmZml4LCByZXBsYWNlT3BlcmF0b3JCeUZpZWxkfSBmcm9tICcuL2NsYXNzZXMvdHJhbnNmb3JtZXJzJztcbmV4cG9ydCB7TmF0dXJhbFNlYXJjaENvbXBvbmVudH0gZnJvbSAnLi9zZWFyY2gvc2VhcmNoLmNvbXBvbmVudCc7XG4iXX0=
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFBLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQ3JFLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzVFLE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLDRCQUE0QixDQUFDO0FBQ25FLE9BQU8sRUFBQyxPQUFPLEVBQUUsS0FBSyxFQUFFLHNCQUFzQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3JFLE9BQU8sRUFBQyxxQkFBcUIsRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxzQkFBc0IsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZILE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBuYXR1cmFsLXNlYXJjaFxuICovXG5leHBvcnQgdHlwZSB7TmF0dXJhbERyb3Bkb3duRGF0YX0gZnJvbSAnLi9kcm9wZG93bi1jb250YWluZXIvZHJvcGRvd24uc2VydmljZSc7XG5leHBvcnQgdHlwZSB7RmlsdGVyR3JvdXBDb25kaXRpb25GaWVsZCwgRmlsdGVyfSBmcm9tICcuL2NsYXNzZXMvZ3JhcGhxbC1kb2N0cmluZS50eXBlcyc7XG5leHBvcnQgdHlwZSB7RHJvcGRvd25Db21wb25lbnR9IGZyb20gJy4vdHlwZXMvZHJvcGRvd24tY29tcG9uZW50JztcbmV4cG9ydCB0eXBlIHtGbGFnRmFjZXQsIERyb3Bkb3duRmFjZXQsIEZhY2V0LCBOYXR1cmFsU2VhcmNoRmFjZXRzfSBmcm9tICcuL3R5cGVzL2ZhY2V0JztcbmV4cG9ydCB0eXBlIHtOYXR1cmFsU2VhcmNoU2VsZWN0aW9ucywgTmF0dXJhbFNlYXJjaFNlbGVjdGlvbn0gZnJvbSAnLi90eXBlcy92YWx1ZXMnO1xuZXhwb3J0IHtOYXR1cmFsRHJvcGRvd25SZWZ9IGZyb20gJy4vZHJvcGRvd24tY29udGFpbmVyL2Ryb3Bkb3duLXJlZic7XG5leHBvcnQge05BVFVSQUxfRFJPUERPV05fREFUQX0gZnJvbSAnLi9kcm9wZG93bi1jb250YWluZXIvZHJvcGRvd24uc2VydmljZSc7XG5leHBvcnQge3RvR3JhcGhRTERvY3RyaW5lRmlsdGVyfSBmcm9tICcuL2NsYXNzZXMvZ3JhcGhxbC1kb2N0cmluZSc7XG5leHBvcnQge2Zyb21VcmwsIHRvVXJsLCB0b05hdmlnYXRpb25QYXJhbWV0ZXJzfSBmcm9tICcuL2NsYXNzZXMvdXJsJztcbmV4cG9ydCB7cmVwbGFjZU9wZXJhdG9yQnlOYW1lLCB3cmFwTGlrZSwgd3JhcFByZWZpeCwgd3JhcFN1ZmZpeCwgcmVwbGFjZU9wZXJhdG9yQnlGaWVsZH0gZnJvbSAnLi9jbGFzc2VzL3RyYW5zZm9ybWVycyc7XG5leHBvcnQge05hdHVyYWxTZWFyY2hDb21wb25lbnR9IGZyb20gJy4vc2VhcmNoL3NlYXJjaC5jb21wb25lbnQnO1xuIl19