@ecodev/natural 55.9.0 → 56.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 (151) hide show
  1. package/esm2022/lib/classes/abstract-controller.mjs +3 -3
  2. package/esm2022/lib/classes/abstract-detail.mjs +5 -5
  3. package/esm2022/lib/classes/abstract-editable-list.mjs +4 -4
  4. package/esm2022/lib/classes/abstract-list.mjs +5 -5
  5. package/esm2022/lib/classes/abstract-navigable-list.mjs +12 -12
  6. package/esm2022/lib/classes/apollo-utils.mjs +3 -2
  7. package/esm2022/lib/classes/data-source.mjs +1 -1
  8. package/esm2022/lib/classes/query-variable-manager-utils.mjs +1 -1
  9. package/esm2022/lib/classes/query-variable-manager.mjs +3 -3
  10. package/esm2022/lib/classes/signing.mjs +1 -1
  11. package/esm2022/lib/classes/utility.mjs +1 -1
  12. package/esm2022/lib/classes/validators.mjs +2 -2
  13. package/esm2022/lib/directives/http-prefix.directive.mjs +5 -5
  14. package/esm2022/lib/modules/alert/alert.service.mjs +5 -5
  15. package/esm2022/lib/modules/alert/confirm.component.mjs +6 -6
  16. package/esm2022/lib/modules/avatar/component/avatar.component.mjs +39 -43
  17. package/esm2022/lib/modules/avatar/service/avatar.service.mjs +4 -4
  18. package/esm2022/lib/modules/avatar/service/md5.mjs +1 -1
  19. package/esm2022/lib/modules/avatar/sources/gravatar.mjs +1 -1
  20. package/esm2022/lib/modules/avatar/sources/initials.mjs +1 -1
  21. package/esm2022/lib/modules/columns-picker/columns-picker.component.mjs +10 -10
  22. package/esm2022/lib/modules/common/directives/linkable-tab.directive.mjs +6 -6
  23. package/esm2022/lib/modules/common/directives/src-density.directive.mjs +5 -5
  24. package/esm2022/lib/modules/common/pipes/capitalize.pipe.mjs +4 -4
  25. package/esm2022/lib/modules/common/pipes/ellipsis.pipe.mjs +3 -3
  26. package/esm2022/lib/modules/common/pipes/enum.pipe.mjs +4 -4
  27. package/esm2022/lib/modules/common/pipes/swiss-date.pipe.mjs +3 -3
  28. package/esm2022/lib/modules/common/pipes/time-ago.pipe.mjs +6 -6
  29. package/esm2022/lib/modules/common/services/memory-storage.mjs +4 -4
  30. package/esm2022/lib/modules/common/services/seo.service.mjs +7 -7
  31. package/esm2022/lib/modules/detail-header/detail-header.component.mjs +7 -9
  32. package/esm2022/lib/modules/dialog-trigger/dialog-trigger.component.mjs +5 -5
  33. package/esm2022/lib/modules/dropdown-components/abstract-association-select-component.directive.mjs +6 -6
  34. package/esm2022/lib/modules/dropdown-components/type-boolean/type-boolean.component.mjs +8 -9
  35. package/esm2022/lib/modules/dropdown-components/type-date/type-date.component.mjs +10 -13
  36. package/esm2022/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs +7 -9
  37. package/esm2022/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.mjs +6 -8
  38. package/esm2022/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.mjs +5 -8
  39. package/esm2022/lib/modules/dropdown-components/type-number/type-number.component.mjs +8 -18
  40. package/esm2022/lib/modules/dropdown-components/type-options/type-options.component.mjs +8 -10
  41. package/esm2022/lib/modules/dropdown-components/type-select/type-select.component.mjs +11 -21
  42. package/esm2022/lib/modules/dropdown-components/type-text/type-text.component.mjs +8 -10
  43. package/esm2022/lib/modules/dropdown-components/types.mjs +1 -1
  44. package/esm2022/lib/modules/dropdown-components/utils.mjs +1 -1
  45. package/esm2022/lib/modules/file/abstract-file.mjs +6 -6
  46. package/esm2022/lib/modules/file/component/file.component.mjs +10 -10
  47. package/esm2022/lib/modules/file/file-drop.directive.mjs +4 -4
  48. package/esm2022/lib/modules/file/file-select.directive.mjs +3 -3
  49. package/esm2022/lib/modules/file/file.service.mjs +6 -6
  50. package/esm2022/lib/modules/file/utils.mjs +1 -1
  51. package/esm2022/lib/modules/fixed-button/fixed-button.component.mjs +5 -5
  52. package/esm2022/lib/modules/fixed-button-detail/fixed-button-detail.component.mjs +7 -9
  53. package/esm2022/lib/modules/hierarchic-selector/classes/flat-node.mjs +1 -1
  54. package/esm2022/lib/modules/hierarchic-selector/classes/hierarchic-configuration.mjs +1 -1
  55. package/esm2022/lib/modules/hierarchic-selector/classes/hierarchic-filters-configuration.mjs +1 -1
  56. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.mjs +17 -17
  57. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.mjs +5 -5
  58. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.mjs +7 -7
  59. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.mjs +4 -4
  60. package/esm2022/lib/modules/icon/icon.directive.mjs +6 -6
  61. package/esm2022/lib/modules/logger/error-handler.mjs +6 -6
  62. package/esm2022/lib/modules/logger/error.module.mjs +1 -1
  63. package/esm2022/lib/modules/matomo/matomo.service.mjs +6 -6
  64. package/esm2022/lib/modules/panels/abstract-panel.mjs +5 -5
  65. package/esm2022/lib/modules/panels/fallback-if-no-opened-panels.urlmatcher.mjs +1 -1
  66. package/esm2022/lib/modules/panels/panels.component.mjs +5 -5
  67. package/esm2022/lib/modules/panels/panels.service.mjs +7 -7
  68. package/esm2022/lib/modules/panels/panels.urlmatcher.mjs +2 -2
  69. package/esm2022/lib/modules/panels/types.mjs +1 -1
  70. package/esm2022/lib/modules/relations/relations.component.mjs +16 -16
  71. package/esm2022/lib/modules/search/classes/graphql-doctrine.mjs +2 -2
  72. package/esm2022/lib/modules/search/classes/graphql-doctrine.types.mjs +1 -1
  73. package/esm2022/lib/modules/search/classes/transformers.mjs +1 -1
  74. package/esm2022/lib/modules/search/classes/url.mjs +9 -9
  75. package/esm2022/lib/modules/search/classes/utils.mjs +1 -1
  76. package/esm2022/lib/modules/search/dropdown-container/dropdown-container.component.mjs +8 -10
  77. package/esm2022/lib/modules/search/dropdown-container/dropdown.service.mjs +5 -5
  78. package/esm2022/lib/modules/search/facet-selector/facet-selector.component.mjs +8 -10
  79. package/esm2022/lib/modules/search/group/group.component.mjs +5 -7
  80. package/esm2022/lib/modules/search/input/input.component.mjs +34 -37
  81. package/esm2022/lib/modules/search/search/search.component.mjs +7 -7
  82. package/esm2022/lib/modules/search/types/dropdown-component.mjs +1 -1
  83. package/esm2022/lib/modules/search/types/facet.mjs +1 -1
  84. package/esm2022/lib/modules/search/types/values.mjs +1 -1
  85. package/esm2022/lib/modules/select/abstract-select.component.mjs +6 -6
  86. package/esm2022/lib/modules/select/select/select.component.mjs +12 -10
  87. package/esm2022/lib/modules/select/select-enum/select-enum.component.mjs +7 -7
  88. package/esm2022/lib/modules/select/select-hierarchic/select-hierarchic.component.mjs +11 -14
  89. package/esm2022/lib/modules/sidenav/sidenav/sidenav.component.mjs +5 -5
  90. package/esm2022/lib/modules/sidenav/sidenav-container/sidenav-container.component.mjs +6 -6
  91. package/esm2022/lib/modules/sidenav/sidenav-content/sidenav-content.component.mjs +5 -5
  92. package/esm2022/lib/modules/sidenav/sidenav-stack.service.mjs +4 -4
  93. package/esm2022/lib/modules/sidenav/sidenav.service.mjs +6 -6
  94. package/esm2022/lib/modules/stamp/stamp.component.mjs +5 -7
  95. package/esm2022/lib/modules/table-button/table-button.component.mjs +7 -9
  96. package/esm2022/lib/services/abstract-model.service.mjs +4 -4
  97. package/esm2022/lib/services/debounce.service.mjs +29 -10
  98. package/esm2022/lib/services/enum.service.mjs +6 -6
  99. package/esm2022/lib/services/link-mutation.service.mjs +6 -6
  100. package/esm2022/lib/services/persistence.service.mjs +10 -6
  101. package/esm2022/lib/services/swiss-parsing-date-adapter.service.mjs +4 -4
  102. package/esm2022/lib/types/types.mjs +1 -1
  103. package/esm2022/public-api.mjs +2 -3
  104. package/fesm2022/ecodev-natural.mjs +499 -495
  105. package/fesm2022/ecodev-natural.mjs.map +1 -1
  106. package/lib/classes/abstract-editable-list.d.ts +1 -1
  107. package/lib/classes/abstract-list.d.ts +2 -2
  108. package/lib/classes/data-source.d.ts +2 -2
  109. package/lib/classes/query-variable-manager.d.ts +7 -7
  110. package/lib/classes/utility.d.ts +1 -1
  111. package/lib/modules/alert/confirm.component.d.ts +2 -2
  112. package/lib/modules/columns-picker/columns-picker.component.d.ts +1 -1
  113. package/lib/modules/common/services/seo.service.d.ts +4 -4
  114. package/lib/modules/dialog-trigger/dialog-trigger.component.d.ts +2 -2
  115. package/lib/modules/dropdown-components/type-boolean/type-boolean.component.d.ts +2 -2
  116. package/lib/modules/dropdown-components/type-date/type-date.component.d.ts +2 -2
  117. package/lib/modules/dropdown-components/type-date-range/type-date-range.component.d.ts +2 -2
  118. package/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.d.ts +6 -6
  119. package/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.d.ts +2 -2
  120. package/lib/modules/dropdown-components/type-number/type-number.component.d.ts +2 -2
  121. package/lib/modules/dropdown-components/type-options/type-options.component.d.ts +4 -4
  122. package/lib/modules/dropdown-components/type-select/type-select.component.d.ts +2 -2
  123. package/lib/modules/dropdown-components/types.d.ts +4 -4
  124. package/lib/modules/file/abstract-file.d.ts +4 -4
  125. package/lib/modules/file/component/file.component.d.ts +1 -1
  126. package/lib/modules/hierarchic-selector/classes/hierarchic-configuration.d.ts +4 -4
  127. package/lib/modules/hierarchic-selector/classes/hierarchic-filters-configuration.d.ts +3 -3
  128. package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.d.ts +4 -4
  129. package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.d.ts +1 -3
  130. package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.d.ts +4 -4
  131. package/lib/modules/icon/icon.directive.d.ts +3 -5
  132. package/lib/modules/logger/error-handler.d.ts +4 -4
  133. package/lib/modules/panels/types.d.ts +14 -16
  134. package/lib/modules/relations/relations.component.d.ts +1 -1
  135. package/lib/modules/search/classes/graphql-doctrine.types.d.ts +37 -41
  136. package/lib/modules/search/dropdown-container/dropdown-container.component.d.ts +2 -2
  137. package/lib/modules/search/dropdown-container/dropdown.service.d.ts +2 -2
  138. package/lib/modules/search/facet-selector/facet-selector.component.d.ts +2 -2
  139. package/lib/modules/search/input/input.component.d.ts +1 -1
  140. package/lib/modules/search/types/dropdown-component.d.ts +2 -2
  141. package/lib/modules/search/types/facet.d.ts +7 -7
  142. package/lib/modules/search/types/values.d.ts +6 -6
  143. package/lib/modules/select/select/select.component.d.ts +1 -1
  144. package/lib/services/abstract-model.service.d.ts +7 -13
  145. package/lib/services/debounce.service.d.ts +10 -2
  146. package/lib/services/enum.service.d.ts +2 -2
  147. package/lib/services/link-mutation.service.d.ts +2 -2
  148. package/lib/types/types.d.ts +1 -3
  149. package/package.json +10 -10
  150. package/public-api.d.ts +0 -1
  151. package/src/lib/_natural.theme.scss +5 -2
@@ -81,13 +81,13 @@ export class NaturalDropdownService {
81
81
  },
82
82
  ]);
83
83
  }
84
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalDropdownService, deps: [{ token: i1.Overlay }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable }); }
85
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalDropdownService, providedIn: 'root' }); }
84
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NaturalDropdownService, deps: [{ token: i1.Overlay }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable }); }
85
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NaturalDropdownService, providedIn: 'root' }); }
86
86
  }
87
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalDropdownService, decorators: [{
87
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NaturalDropdownService, decorators: [{
88
88
  type: Injectable,
89
89
  args: [{
90
90
  providedIn: 'root',
91
91
  }]
92
- }], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.Injector }]; } });
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.service.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/search/dropdown-container/dropdown.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {FlexibleConnectedPositionStrategy, Overlay, OverlayConfig} from '@angular/cdk/overlay';\nimport {ComponentPortal, ComponentType} from '@angular/cdk/portal';\nimport {ComponentRef, ElementRef, Injectable, InjectionToken, Injector, StaticProvider} from '@angular/core';\nimport {takeUntil} from 'rxjs/operators';\nimport {FilterGroupConditionField} from '../classes/graphql-doctrine.types';\nimport {\n    NATURAL_DROPDOWN_CONTAINER_DATA,\n    NaturalDropdownContainerComponent,\n    NaturalDropdownContainerData,\n} from './dropdown-container.component';\nimport {NaturalDropdownRef} from './dropdown-ref';\nimport {DropdownComponent} from '../types/dropdown-component';\n\nexport interface NaturalDropdownData<C = any> {\n    condition: FilterGroupConditionField | null;\n    configuration: C;\n    title?: string;\n}\n\nexport const NATURAL_DROPDOWN_DATA = new InjectionToken<NaturalDropdownData>('NaturalDropdownData');\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class NaturalDropdownService {\n    public constructor(private readonly overlay: Overlay, private readonly injector: Injector) {}\n\n    public open(\n        component: ComponentType<DropdownComponent>,\n        connectedElement: ElementRef<HTMLElement>,\n        customProviders: StaticProvider[],\n        showValidateButton: boolean,\n    ): NaturalDropdownRef {\n        // Container data\n        const containerData: NaturalDropdownContainerData = {\n            showValidateButton: showValidateButton,\n        };\n\n        const injectionTokens: StaticProvider[] = [\n            {\n                provide: NATURAL_DROPDOWN_CONTAINER_DATA,\n                useValue: containerData,\n            },\n        ];\n\n        const containerInjector = Injector.create({providers: injectionTokens, parent: this.injector});\n\n        // Container\n        const overlayRef = this.overlay.create(this.getOverlayConfig(connectedElement));\n        const containerPortal = new ComponentPortal(NaturalDropdownContainerComponent, undefined, containerInjector);\n        const containerRef: ComponentRef<NaturalDropdownContainerComponent> = overlayRef.attach(containerPortal);\n\n        const dropdownContainer = containerRef.instance;\n        const dropdownRef = new NaturalDropdownRef(\n            dropdownContainer,\n            component,\n            customProviders,\n            this.injector,\n            containerRef,\n        );\n\n        // Start animation that shows menu\n        dropdownContainer.startAnimation();\n\n        const close = (): void => {\n            if (dropdownRef.componentInstance.isValid() && dropdownRef.componentInstance.isDirty()) {\n                dropdownRef.close({\n                    condition: dropdownRef.componentInstance.getCondition(),\n                });\n            } else {\n                dropdownRef.close();\n            }\n        };\n\n        // When parent closes, remove overlay from dom and update \"return\" valu\n        dropdownContainer.closed.subscribe(() => {\n            overlayRef.dispose();\n            close();\n        });\n\n        // When click on backdrop, validate result.. ?\n        overlayRef\n            .backdropClick()\n            .pipe(takeUntil(dropdownContainer.closed))\n            .subscribe(() => dropdownContainer.close());\n\n        return dropdownRef;\n    }\n\n    /**\n     * This method builds the configuration object needed to create the overlay, the OverlayState.\n     */\n    private getOverlayConfig(element: ElementRef<HTMLElement>): OverlayConfig {\n        return new OverlayConfig({\n            positionStrategy: this.getPosition(element),\n            hasBackdrop: true,\n            backdropClass: 'cdk-overlay-transparent-backdrop',\n        });\n    }\n\n    private getPosition(element: ElementRef<HTMLElement>): FlexibleConnectedPositionStrategy {\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(element)\n            .withFlexibleDimensions(true)\n            .withViewportMargin(30)\n            .withPush(false)\n            .withPositions([\n                {\n                    originX: 'start',\n                    originY: 'bottom',\n                    overlayX: 'start',\n                    overlayY: 'top',\n                    offsetY: 10,\n                },\n            ]);\n    }\n}\n"]}
92
+ }], ctorParameters: () => [{ type: i1.Overlay }, { type: i0.Injector }] });
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.service.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/search/dropdown-container/dropdown.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAA6C,aAAa,EAAC,MAAM,sBAAsB,CAAC;AAC/F,OAAO,EAAC,eAAe,EAAgB,MAAM,qBAAqB,CAAC;AACnE,OAAO,EAA2B,UAAU,EAAE,cAAc,EAAE,QAAQ,EAAiB,MAAM,eAAe,CAAC;AAC7G,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAEzC,OAAO,EACH,+BAA+B,EAC/B,iCAAiC,GAEpC,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAC,kBAAkB,EAAC,MAAM,gBAAgB,CAAC;;;AASlD,MAAM,CAAC,MAAM,qBAAqB,GAAG,IAAI,cAAc,CAAsB,qBAAqB,CAAC,CAAC;AAKpG,MAAM,OAAO,sBAAsB;IAC/B,YACqB,OAAgB,EAChB,QAAkB;QADlB,YAAO,GAAP,OAAO,CAAS;QAChB,aAAQ,GAAR,QAAQ,CAAU;IACpC,CAAC;IAEG,IAAI,CACP,SAA2C,EAC3C,gBAAyC,EACzC,eAAiC,EACjC,kBAA2B;QAE3B,iBAAiB;QACjB,MAAM,aAAa,GAAiC;YAChD,kBAAkB,EAAE,kBAAkB;SACzC,CAAC;QAEF,MAAM,eAAe,GAAqB;YACtC;gBACI,OAAO,EAAE,+BAA+B;gBACxC,QAAQ,EAAE,aAAa;aAC1B;SACJ,CAAC;QAEF,MAAM,iBAAiB,GAAG,QAAQ,CAAC,MAAM,CAAC,EAAC,SAAS,EAAE,eAAe,EAAE,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAC,CAAC,CAAC;QAE/F,YAAY;QACZ,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAChF,MAAM,eAAe,GAAG,IAAI,eAAe,CAAC,iCAAiC,EAAE,SAAS,EAAE,iBAAiB,CAAC,CAAC;QAC7G,MAAM,YAAY,GAAoD,UAAU,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;QAEzG,MAAM,iBAAiB,GAAG,YAAY,CAAC,QAAQ,CAAC;QAChD,MAAM,WAAW,GAAG,IAAI,kBAAkB,CACtC,iBAAiB,EACjB,SAAS,EACT,eAAe,EACf,IAAI,CAAC,QAAQ,EACb,YAAY,CACf,CAAC;QAEF,kCAAkC;QAClC,iBAAiB,CAAC,cAAc,EAAE,CAAC;QAEnC,MAAM,KAAK,GAAG,GAAS,EAAE;YACrB,IAAI,WAAW,CAAC,iBAAiB,CAAC,OAAO,EAAE,IAAI,WAAW,CAAC,iBAAiB,CAAC,OAAO,EAAE,EAAE,CAAC;gBACrF,WAAW,CAAC,KAAK,CAAC;oBACd,SAAS,EAAE,WAAW,CAAC,iBAAiB,CAAC,YAAY,EAAE;iBAC1D,CAAC,CAAC;YACP,CAAC;iBAAM,CAAC;gBACJ,WAAW,CAAC,KAAK,EAAE,CAAC;YACxB,CAAC;QACL,CAAC,CAAC;QAEF,uEAAuE;QACvE,iBAAiB,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE;YACpC,UAAU,CAAC,OAAO,EAAE,CAAC;YACrB,KAAK,EAAE,CAAC;QACZ,CAAC,CAAC,CAAC;QAEH,8CAA8C;QAC9C,UAAU;aACL,aAAa,EAAE;aACf,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;aACzC,SAAS,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC,CAAC;QAEhD,OAAO,WAAW,CAAC;IACvB,CAAC;IAED;;OAEG;IACK,gBAAgB,CAAC,OAAgC;QACrD,OAAO,IAAI,aAAa,CAAC;YACrB,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;YAC3C,WAAW,EAAE,IAAI;YACjB,aAAa,EAAE,kCAAkC;SACpD,CAAC,CAAC;IACP,CAAC;IAEO,WAAW,CAAC,OAAgC;QAChD,OAAO,IAAI,CAAC,OAAO;aACd,QAAQ,EAAE;aACV,mBAAmB,CAAC,OAAO,CAAC;aAC5B,sBAAsB,CAAC,IAAI,CAAC;aAC5B,kBAAkB,CAAC,EAAE,CAAC;aACtB,QAAQ,CAAC,KAAK,CAAC;aACf,aAAa,CAAC;YACX;gBACI,OAAO,EAAE,OAAO;gBAChB,OAAO,EAAE,QAAQ;gBACjB,QAAQ,EAAE,OAAO;gBACjB,QAAQ,EAAE,KAAK;gBACf,OAAO,EAAE,EAAE;aACd;SACJ,CAAC,CAAC;IACX,CAAC;8GA/FQ,sBAAsB;kHAAtB,sBAAsB,cAFnB,MAAM;;2FAET,sBAAsB;kBAHlC,UAAU;mBAAC;oBACR,UAAU,EAAE,MAAM;iBACrB","sourcesContent":["import {FlexibleConnectedPositionStrategy, Overlay, OverlayConfig} from '@angular/cdk/overlay';\nimport {ComponentPortal, ComponentType} from '@angular/cdk/portal';\nimport {ComponentRef, ElementRef, Injectable, InjectionToken, Injector, StaticProvider} from '@angular/core';\nimport {takeUntil} from 'rxjs/operators';\nimport {FilterGroupConditionField} from '../classes/graphql-doctrine.types';\nimport {\n    NATURAL_DROPDOWN_CONTAINER_DATA,\n    NaturalDropdownContainerComponent,\n    NaturalDropdownContainerData,\n} from './dropdown-container.component';\nimport {NaturalDropdownRef} from './dropdown-ref';\nimport {DropdownComponent} from '../types/dropdown-component';\n\nexport type NaturalDropdownData<C = any> = {\n    condition: FilterGroupConditionField | null;\n    configuration: C;\n    title?: string;\n};\n\nexport const NATURAL_DROPDOWN_DATA = new InjectionToken<NaturalDropdownData>('NaturalDropdownData');\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class NaturalDropdownService {\n    public constructor(\n        private readonly overlay: Overlay,\n        private readonly injector: Injector,\n    ) {}\n\n    public open(\n        component: ComponentType<DropdownComponent>,\n        connectedElement: ElementRef<HTMLElement>,\n        customProviders: StaticProvider[],\n        showValidateButton: boolean,\n    ): NaturalDropdownRef {\n        // Container data\n        const containerData: NaturalDropdownContainerData = {\n            showValidateButton: showValidateButton,\n        };\n\n        const injectionTokens: StaticProvider[] = [\n            {\n                provide: NATURAL_DROPDOWN_CONTAINER_DATA,\n                useValue: containerData,\n            },\n        ];\n\n        const containerInjector = Injector.create({providers: injectionTokens, parent: this.injector});\n\n        // Container\n        const overlayRef = this.overlay.create(this.getOverlayConfig(connectedElement));\n        const containerPortal = new ComponentPortal(NaturalDropdownContainerComponent, undefined, containerInjector);\n        const containerRef: ComponentRef<NaturalDropdownContainerComponent> = overlayRef.attach(containerPortal);\n\n        const dropdownContainer = containerRef.instance;\n        const dropdownRef = new NaturalDropdownRef(\n            dropdownContainer,\n            component,\n            customProviders,\n            this.injector,\n            containerRef,\n        );\n\n        // Start animation that shows menu\n        dropdownContainer.startAnimation();\n\n        const close = (): void => {\n            if (dropdownRef.componentInstance.isValid() && dropdownRef.componentInstance.isDirty()) {\n                dropdownRef.close({\n                    condition: dropdownRef.componentInstance.getCondition(),\n                });\n            } else {\n                dropdownRef.close();\n            }\n        };\n\n        // When parent closes, remove overlay from dom and update \"return\" valu\n        dropdownContainer.closed.subscribe(() => {\n            overlayRef.dispose();\n            close();\n        });\n\n        // When click on backdrop, validate result.. ?\n        overlayRef\n            .backdropClick()\n            .pipe(takeUntil(dropdownContainer.closed))\n            .subscribe(() => dropdownContainer.close());\n\n        return dropdownRef;\n    }\n\n    /**\n     * This method builds the configuration object needed to create the overlay, the OverlayState.\n     */\n    private getOverlayConfig(element: ElementRef<HTMLElement>): OverlayConfig {\n        return new OverlayConfig({\n            positionStrategy: this.getPosition(element),\n            hasBackdrop: true,\n            backdropClass: 'cdk-overlay-transparent-backdrop',\n        });\n    }\n\n    private getPosition(element: ElementRef<HTMLElement>): FlexibleConnectedPositionStrategy {\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(element)\n            .withFlexibleDimensions(true)\n            .withViewportMargin(30)\n            .withPush(false)\n            .withPositions([\n                {\n                    originX: 'start',\n                    originY: 'bottom',\n                    overlayX: 'start',\n                    overlayY: 'top',\n                    offsetY: 10,\n                },\n            ]);\n    }\n}\n"]}
@@ -2,11 +2,9 @@ import { Component, Inject } from '@angular/core';
2
2
  import { BehaviorSubject } from 'rxjs';
3
3
  import { NATURAL_DROPDOWN_DATA } from '../../search/dropdown-container/dropdown.service';
4
4
  import { MatListModule } from '@angular/material/list';
5
- import { CommonModule } from '@angular/common';
6
5
  import * as i0 from "@angular/core";
7
6
  import * as i1 from "../../search/dropdown-container/dropdown-ref";
8
- import * as i2 from "@angular/common";
9
- import * as i3 from "@angular/material/list";
7
+ import * as i2 from "@angular/material/list";
10
8
  export class FacetSelectorComponent {
11
9
  constructor(data, dropdownRef) {
12
10
  this.data = data;
@@ -39,14 +37,14 @@ export class FacetSelectorComponent {
39
37
  isDirty() {
40
38
  return true;
41
39
  }
42
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: FacetSelectorComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }, { token: i1.NaturalDropdownRef }], target: i0.ɵɵFactoryTarget.Component }); }
43
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", type: FacetSelectorComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<div class=\"dropdown-title mat-body-2\" *ngIf=\"data.title\">{{ data.title }}</div>\n<mat-nav-list>\n <mat-list-item (click)=\"selection = facet; close()\" *ngFor=\"let facet of facets\">\n <a>{{ facet.display }}</a>\n </mat-list-item>\n</mat-nav-list>\n", styles: [".mat-nav-list{padding:0}.dropdown-title{padding:5px;font-variant:all-small-caps;font-size:18px;opacity:.7}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatListModule }, { kind: "component", type: i3.MatNavList, selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "component", type: i3.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }] }); }
40
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", 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: "17.2.2", 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 facet) {\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{padding:5px;font-variant:all-small-caps;font-size:18px;opacity:.7}\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"] }] }); }
44
42
  }
45
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: FacetSelectorComponent, decorators: [{
43
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: FacetSelectorComponent, decorators: [{
46
44
  type: Component,
47
- args: [{ standalone: true, imports: [CommonModule, MatListModule, CommonModule], template: "<div class=\"dropdown-title mat-body-2\" *ngIf=\"data.title\">{{ data.title }}</div>\n<mat-nav-list>\n <mat-list-item (click)=\"selection = facet; close()\" *ngFor=\"let facet of facets\">\n <a>{{ facet.display }}</a>\n </mat-list-item>\n</mat-nav-list>\n", styles: [".mat-nav-list{padding:0}.dropdown-title{padding:5px;font-variant:all-small-caps;font-size:18px;opacity:.7}\n"] }]
48
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
45
+ 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 facet) {\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{padding:5px;font-variant:all-small-caps;font-size:18px;opacity:.7}\n"] }]
46
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
49
47
  type: Inject,
50
48
  args: [NATURAL_DROPDOWN_DATA]
51
- }] }, { type: i1.NaturalDropdownRef }]; } });
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFjZXQtc2VsZWN0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2VhcmNoL2ZhY2V0LXNlbGVjdG9yL2ZhY2V0LXNlbGVjdG9yLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9mYWNldC1zZWxlY3Rvci9mYWNldC1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBR3JDLE9BQU8sRUFBQyxxQkFBcUIsRUFBc0IsTUFBTSxrREFBa0QsQ0FBQztBQUc1RyxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDckQsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDOzs7OztBQWU3QyxNQUFNLE9BQU8sc0JBQXNCO0lBTS9CLFlBQzBDLElBQXFELEVBQ2pGLFdBQStCO1FBREgsU0FBSSxHQUFKLElBQUksQ0FBaUQ7UUFDakYsZ0JBQVcsR0FBWCxXQUFXLENBQW9CO1FBUDdDLHlCQUF5QjtRQUNULGtCQUFhLEdBQUcsSUFBSSxlQUFlLENBQVMsRUFBRSxDQUFDLENBQUM7UUFFekQsY0FBUyxHQUFpQixJQUFJLENBQUM7UUFNbEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQztJQUM1QyxDQUFDO0lBRUQ7O09BRUc7SUFDSSxZQUFZO1FBQ2YsT0FBTyxFQUFFLENBQUM7SUFDZCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxLQUFLO1FBQ1IsSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ2hCLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDO2dCQUNuQixTQUFTLEVBQUUsRUFBRTtnQkFDYixLQUFLLEVBQUUsSUFBSSxDQUFDLFNBQVM7YUFDeEIsQ0FBQyxDQUFDO1NBQ047SUFDTCxDQUFDO0lBRU0sT0FBTztRQUNWLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDNUIsQ0FBQztJQUVNLE9BQU87UUFDVixPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDOzhHQXRDUSxzQkFBc0Isa0JBT25CLHFCQUFxQjtrR0FQeEIsc0JBQXNCLHdFQ3ZCbkMsOFFBTUEscUtEZWMsWUFBWSwrUEFBRSxhQUFhOzsyRkFFNUIsc0JBQXNCO2tCQU5sQyxTQUFTO2lDQUdNLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxhQUFhLEVBQUUsWUFBWSxDQUFDOzswQkFTL0MsTUFBTTsyQkFBQyxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5qZWN0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7QmVoYXZpb3JTdWJqZWN0fSBmcm9tICdyeGpzJztcbmltcG9ydCB7RmlsdGVyR3JvdXBDb25kaXRpb25GaWVsZH0gZnJvbSAnLi4vLi4vc2VhcmNoL2NsYXNzZXMvZ3JhcGhxbC1kb2N0cmluZS50eXBlcyc7XG5pbXBvcnQge05hdHVyYWxEcm9wZG93blJlZn0gZnJvbSAnLi4vLi4vc2VhcmNoL2Ryb3Bkb3duLWNvbnRhaW5lci9kcm9wZG93bi1yZWYnO1xuaW1wb3J0IHtOQVRVUkFMX0RST1BET1dOX0RBVEEsIE5hdHVyYWxEcm9wZG93bkRhdGF9IGZyb20gJy4uLy4uL3NlYXJjaC9kcm9wZG93bi1jb250YWluZXIvZHJvcGRvd24uc2VydmljZSc7XG5pbXBvcnQge0Ryb3Bkb3duQ29tcG9uZW50fSBmcm9tICcuLi90eXBlcy9kcm9wZG93bi1jb21wb25lbnQnO1xuaW1wb3J0IHtGYWNldCwgTmF0dXJhbFNlYXJjaEZhY2V0c30gZnJvbSAnLi4vdHlwZXMvZmFjZXQnO1xuaW1wb3J0IHtNYXRMaXN0TW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9saXN0JztcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG4vKipcbiAqIENvbmZpZ3VyYXRpb24gZm9yIGZhY2V0IHNlbGVjdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIEZhY2V0U2VsZWN0b3JDb25maWd1cmF0aW9uIHtcbiAgICBmYWNldHM6IE5hdHVyYWxTZWFyY2hGYWNldHM7XG59XG5cbkBDb21wb25lbnQoe1xuICAgIHRlbXBsYXRlVXJsOiAnLi9mYWNldC1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZmFjZXQtc2VsZWN0b3IuY29tcG9uZW50LnNjc3MnXSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE1hdExpc3RNb2R1bGUsIENvbW1vbk1vZHVsZV0sXG59KVxuZXhwb3J0IGNsYXNzIEZhY2V0U2VsZWN0b3JDb21wb25lbnQgaW1wbGVtZW50cyBEcm9wZG93bkNvbXBvbmVudCB7XG4gICAgLy8gTmV2ZXIgaGFzIGEgcmVhbCB2YWx1ZVxuICAgIHB1YmxpYyByZWFkb25seSByZW5kZXJlZFZhbHVlID0gbmV3IEJlaGF2aW9yU3ViamVjdDxzdHJpbmc+KCcnKTtcbiAgICBwdWJsaWMgZmFjZXRzOiBOYXR1cmFsU2VhcmNoRmFjZXRzO1xuICAgIHB1YmxpYyBzZWxlY3Rpb246IEZhY2V0IHwgbnVsbCA9IG51bGw7XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgICAgIEBJbmplY3QoTkFUVVJBTF9EUk9QRE9XTl9EQVRBKSBwdWJsaWMgZGF0YTogTmF0dXJhbERyb3Bkb3duRGF0YTxGYWNldFNlbGVjdG9yQ29uZmlndXJhdGlvbj4sXG4gICAgICAgIHByb3RlY3RlZCBkcm9wZG93blJlZjogTmF0dXJhbERyb3Bkb3duUmVmLFxuICAgICkge1xuICAgICAgICB0aGlzLmZhY2V0cyA9IGRhdGEuY29uZmlndXJhdGlvbi5mYWNldHM7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogR2V0IHZhbHVlLCBpbmNsdWRpbmcgcmljaCBvYmplY3QgdHlwZXNcbiAgICAgKi9cbiAgICBwdWJsaWMgZ2V0Q29uZGl0aW9uKCk6IEZpbHRlckdyb3VwQ29uZGl0aW9uRmllbGQge1xuICAgICAgICByZXR1cm4ge307XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQWxsb3cgdG8gY2xvc2UgdGhlIGRyb3Bkb3duIHdpdGggYSB2YWxpZCB2YWx1ZVxuICAgICAqL1xuICAgIHB1YmxpYyBjbG9zZSgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuc2VsZWN0aW9uKSB7XG4gICAgICAgICAgICB0aGlzLmRyb3Bkb3duUmVmLmNsb3NlKHtcbiAgICAgICAgICAgICAgICBjb25kaXRpb246IHt9LFxuICAgICAgICAgICAgICAgIGZhY2V0OiB0aGlzLnNlbGVjdGlvbixcbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIGlzVmFsaWQoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiAhIXRoaXMuc2VsZWN0aW9uO1xuICAgIH1cblxuICAgIHB1YmxpYyBpc0RpcnR5KCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZHJvcGRvd24tdGl0bGUgbWF0LWJvZHktMlwiICpuZ0lmPVwiZGF0YS50aXRsZVwiPnt7IGRhdGEudGl0bGUgfX08L2Rpdj5cbjxtYXQtbmF2LWxpc3Q+XG4gICAgPG1hdC1saXN0LWl0ZW0gKGNsaWNrKT1cInNlbGVjdGlvbiA9IGZhY2V0OyBjbG9zZSgpXCIgKm5nRm9yPVwibGV0IGZhY2V0IG9mIGZhY2V0c1wiPlxuICAgICAgICA8YT57eyBmYWNldC5kaXNwbGF5IH19PC9hPlxuICAgIDwvbWF0LWxpc3QtaXRlbT5cbjwvbWF0LW5hdi1saXN0PlxuIl19
49
+ }] }, { type: i1.NaturalDropdownRef }] });
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFjZXQtc2VsZWN0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2VhcmNoL2ZhY2V0LXNlbGVjdG9yL2ZhY2V0LXNlbGVjdG9yLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9mYWNldC1zZWxlY3Rvci9mYWNldC1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBR3JDLE9BQU8sRUFBQyxxQkFBcUIsRUFBc0IsTUFBTSxrREFBa0QsQ0FBQztBQUc1RyxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7Ozs7QUFlckQsTUFBTSxPQUFPLHNCQUFzQjtJQU0vQixZQUMwQyxJQUFxRCxFQUNqRixXQUErQjtRQURILFNBQUksR0FBSixJQUFJLENBQWlEO1FBQ2pGLGdCQUFXLEdBQVgsV0FBVyxDQUFvQjtRQVA3Qyx5QkFBeUI7UUFDVCxrQkFBYSxHQUFHLElBQUksZUFBZSxDQUFTLEVBQUUsQ0FBQyxDQUFDO1FBRXpELGNBQVMsR0FBaUIsSUFBSSxDQUFDO1FBTWxDLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUM7SUFDNUMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksWUFBWTtRQUNmLE9BQU8sRUFBRSxDQUFDO0lBQ2QsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSztRQUNSLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ2pCLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDO2dCQUNuQixTQUFTLEVBQUUsRUFBRTtnQkFDYixLQUFLLEVBQUUsSUFBSSxDQUFDLFNBQVM7YUFDeEIsQ0FBQyxDQUFDO1FBQ1AsQ0FBQztJQUNMLENBQUM7SUFFTSxPQUFPO1FBQ1YsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUM1QixDQUFDO0lBRU0sT0FBTztRQUNWLE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7OEdBdENRLHNCQUFzQixrQkFPbkIscUJBQXFCO2tHQVB4QixzQkFBc0Isd0VDdEJuQyxtVEFVQSxxS0RVYyxhQUFhOzsyRkFFZCxzQkFBc0I7a0JBTmxDLFNBQVM7aUNBR00sSUFBSSxXQUNQLENBQUMsYUFBYSxDQUFDOzswQkFTbkIsTUFBTTsyQkFBQyxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5qZWN0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7QmVoYXZpb3JTdWJqZWN0fSBmcm9tICdyeGpzJztcbmltcG9ydCB7RmlsdGVyR3JvdXBDb25kaXRpb25GaWVsZH0gZnJvbSAnLi4vLi4vc2VhcmNoL2NsYXNzZXMvZ3JhcGhxbC1kb2N0cmluZS50eXBlcyc7XG5pbXBvcnQge05hdHVyYWxEcm9wZG93blJlZn0gZnJvbSAnLi4vLi4vc2VhcmNoL2Ryb3Bkb3duLWNvbnRhaW5lci9kcm9wZG93bi1yZWYnO1xuaW1wb3J0IHtOQVRVUkFMX0RST1BET1dOX0RBVEEsIE5hdHVyYWxEcm9wZG93bkRhdGF9IGZyb20gJy4uLy4uL3NlYXJjaC9kcm9wZG93bi1jb250YWluZXIvZHJvcGRvd24uc2VydmljZSc7XG5pbXBvcnQge0Ryb3Bkb3duQ29tcG9uZW50fSBmcm9tICcuLi90eXBlcy9kcm9wZG93bi1jb21wb25lbnQnO1xuaW1wb3J0IHtGYWNldCwgTmF0dXJhbFNlYXJjaEZhY2V0c30gZnJvbSAnLi4vdHlwZXMvZmFjZXQnO1xuaW1wb3J0IHtNYXRMaXN0TW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9saXN0JztcblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIGZvciBmYWNldCBzZWxlY3Rpb25cbiAqL1xuZXhwb3J0IHR5cGUgRmFjZXRTZWxlY3RvckNvbmZpZ3VyYXRpb24gPSB7XG4gICAgZmFjZXRzOiBOYXR1cmFsU2VhcmNoRmFjZXRzO1xufTtcblxuQENvbXBvbmVudCh7XG4gICAgdGVtcGxhdGVVcmw6ICcuL2ZhY2V0LXNlbGVjdG9yLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9mYWNldC1zZWxlY3Rvci5jb21wb25lbnQuc2NzcyddLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW01hdExpc3RNb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBGYWNldFNlbGVjdG9yQ29tcG9uZW50IGltcGxlbWVudHMgRHJvcGRvd25Db21wb25lbnQge1xuICAgIC8vIE5ldmVyIGhhcyBhIHJlYWwgdmFsdWVcbiAgICBwdWJsaWMgcmVhZG9ubHkgcmVuZGVyZWRWYWx1ZSA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPignJyk7XG4gICAgcHVibGljIGZhY2V0czogTmF0dXJhbFNlYXJjaEZhY2V0cztcbiAgICBwdWJsaWMgc2VsZWN0aW9uOiBGYWNldCB8IG51bGwgPSBudWxsO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KE5BVFVSQUxfRFJPUERPV05fREFUQSkgcHVibGljIGRhdGE6IE5hdHVyYWxEcm9wZG93bkRhdGE8RmFjZXRTZWxlY3RvckNvbmZpZ3VyYXRpb24+LFxuICAgICAgICBwcm90ZWN0ZWQgZHJvcGRvd25SZWY6IE5hdHVyYWxEcm9wZG93blJlZixcbiAgICApIHtcbiAgICAgICAgdGhpcy5mYWNldHMgPSBkYXRhLmNvbmZpZ3VyYXRpb24uZmFjZXRzO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEdldCB2YWx1ZSwgaW5jbHVkaW5nIHJpY2ggb2JqZWN0IHR5cGVzXG4gICAgICovXG4gICAgcHVibGljIGdldENvbmRpdGlvbigpOiBGaWx0ZXJHcm91cENvbmRpdGlvbkZpZWxkIHtcbiAgICAgICAgcmV0dXJuIHt9O1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEFsbG93IHRvIGNsb3NlIHRoZSBkcm9wZG93biB3aXRoIGEgdmFsaWQgdmFsdWVcbiAgICAgKi9cbiAgICBwdWJsaWMgY2xvc2UoKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLnNlbGVjdGlvbikge1xuICAgICAgICAgICAgdGhpcy5kcm9wZG93blJlZi5jbG9zZSh7XG4gICAgICAgICAgICAgICAgY29uZGl0aW9uOiB7fSxcbiAgICAgICAgICAgICAgICBmYWNldDogdGhpcy5zZWxlY3Rpb24sXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHB1YmxpYyBpc1ZhbGlkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gISF0aGlzLnNlbGVjdGlvbjtcbiAgICB9XG5cbiAgICBwdWJsaWMgaXNEaXJ0eSgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxufVxuIiwiQGlmIChkYXRhLnRpdGxlKSB7XG4gICAgPGRpdiBjbGFzcz1cImRyb3Bkb3duLXRpdGxlIG1hdC1ib2R5LTJcIj57eyBkYXRhLnRpdGxlIH19PC9kaXY+XG59XG48bWF0LW5hdi1saXN0PlxuICAgIEBmb3IgKGZhY2V0IG9mIGZhY2V0czsgdHJhY2sgZmFjZXQpIHtcbiAgICAgICAgPG1hdC1saXN0LWl0ZW0gKGNsaWNrKT1cInNlbGVjdGlvbiA9IGZhY2V0OyBjbG9zZSgpXCI+XG4gICAgICAgICAgICA8YT57eyBmYWNldC5kaXNwbGF5IH19PC9hPlxuICAgICAgICA8L21hdC1saXN0LWl0ZW0+XG4gICAgfVxuPC9tYXQtbmF2LWxpc3Q+XG4iXX0=
@@ -1,9 +1,7 @@
1
1
  import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
2
  import { deepClone } from '../classes/utils';
3
3
  import { NaturalInputComponent } from '../input/input.component';
4
- import { CommonModule } from '@angular/common';
5
4
  import * as i0 from "@angular/core";
6
- import * as i1 from "@angular/common";
7
5
  export class NaturalGroupComponent {
8
6
  constructor() {
9
7
  /**
@@ -29,12 +27,12 @@ export class NaturalGroupComponent {
29
27
  this.innerSelections.splice(index, 1);
30
28
  this.selectionChange.emit(this.innerSelections);
31
29
  }
32
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
33
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", 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: "<natural-input\n (cleared)=\"removeInput(i)\"\n (selectionChange)=\"updateInput($event, i)\"\n *ngFor=\"let selection of innerSelections; let i = index\"\n [facets]=\"facets\"\n [selection]=\"selection\"\n></natural-input>\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></natural-input>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:wrap}:host natural-input{flex:auto;display:inline-flex;margin-right:10px;margin-bottom:10px}:host natural-input:last-of-type{flex:1;min-width:250px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: NaturalInputComponent, selector: "natural-input", inputs: ["placeholder", "searchFieldName", "selection", "facets", "dropdownTitle"], outputs: ["selectionChange", "cleared"] }] }); }
30
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NaturalGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
31
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.2", 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 selection) {\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{flex:auto;display:inline-flex;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"] }] }); }
34
32
  }
35
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalGroupComponent, decorators: [{
33
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NaturalGroupComponent, decorators: [{
36
34
  type: Component,
37
- args: [{ selector: 'natural-group', standalone: true, imports: [CommonModule, NaturalInputComponent], template: "<natural-input\n (cleared)=\"removeInput(i)\"\n (selectionChange)=\"updateInput($event, i)\"\n *ngFor=\"let selection of innerSelections; let i = index\"\n [facets]=\"facets\"\n [selection]=\"selection\"\n></natural-input>\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></natural-input>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:wrap}:host natural-input{flex:auto;display:inline-flex;margin-right:10px;margin-bottom:10px}:host natural-input:last-of-type{flex:1;min-width:250px}\n"] }]
35
+ args: [{ selector: 'natural-group', standalone: true, imports: [NaturalInputComponent], template: "@for (selection of innerSelections; track selection) {\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{flex:auto;display:inline-flex;margin-right:10px;margin-bottom:10px}:host natural-input:last-of-type{flex:1;min-width:250px}\n"] }]
38
36
  }], propDecorators: { newValueInput: [{
39
37
  type: ViewChild,
40
38
  args: ['newValueInput']
@@ -51,4 +49,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImpor
51
49
  }], selections: [{
52
50
  type: Input
53
51
  }] } });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2VhcmNoL2dyb3VwL2dyb3VwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9ncm91cC9ncm91cC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRixPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDM0MsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFHL0QsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDOzs7QUFTN0MsTUFBTSxPQUFPLHFCQUFxQjtJQVBsQztRQVVJOztXQUVHO1FBQ2Esa0JBQWEsR0FBRyxFQUFFLENBQUM7UUFHVCxvQkFBZSxHQUFHLElBQUksWUFBWSxFQUFtQixDQUFDO1FBQ3pFLG9CQUFlLEdBQW9CLEVBQUUsQ0FBQztLQXFCaEQ7SUFuQkcsSUFBb0IsVUFBVSxDQUFDLFNBQTBCO1FBQ3JELElBQUksQ0FBQyxlQUFlLEdBQUcsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFFTSxXQUFXLENBQUMsU0FBaUMsRUFBRSxLQUFhO1FBQy9ELElBQUksQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLEdBQUcsU0FBUyxDQUFDO1FBQ3hDLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRU0sUUFBUSxDQUFDLFNBQWlDO1FBQzdDLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDM0IsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDckMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFTSxXQUFXLENBQUMsS0FBYTtRQUM1QixJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDdEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQ3BELENBQUM7OEdBOUJRLHFCQUFxQjtrR0FBckIscUJBQXFCLDhWQ2RsQyxtZUFpQkEsK1BETGMsWUFBWSw0SkFBRSxxQkFBcUI7OzJGQUVwQyxxQkFBcUI7a0JBUGpDLFNBQVM7K0JBQ0ksZUFBZSxjQUdiLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxxQkFBcUIsQ0FBQzs4QkFHWCxhQUFhO3NCQUEvQyxTQUFTO3VCQUFDLGVBQWU7Z0JBS1YsYUFBYTtzQkFBNUIsS0FBSztnQkFDMEIsV0FBVztzQkFBMUMsS0FBSzt1QkFBQyxFQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUM7Z0JBQ1MsTUFBTTtzQkFBckMsS0FBSzt1QkFBQyxFQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUM7Z0JBQ0csZUFBZTtzQkFBeEMsTUFBTTtnQkFHYSxVQUFVO3NCQUE3QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCwgVmlld0NoaWxkfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7ZGVlcENsb25lfSBmcm9tICcuLi9jbGFzc2VzL3V0aWxzJztcbmltcG9ydCB7TmF0dXJhbElucHV0Q29tcG9uZW50fSBmcm9tICcuLi9pbnB1dC9pbnB1dC5jb21wb25lbnQnO1xuaW1wb3J0IHtOYXR1cmFsU2VhcmNoRmFjZXRzfSBmcm9tICcuLi90eXBlcy9mYWNldCc7XG5pbXBvcnQge0dyb3VwU2VsZWN0aW9ucywgTmF0dXJhbFNlYXJjaFNlbGVjdGlvbn0gZnJvbSAnLi4vdHlwZXMvdmFsdWVzJztcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ25hdHVyYWwtZ3JvdXAnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9ncm91cC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZ3JvdXAuY29tcG9uZW50LnNjc3MnXSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE5hdHVyYWxJbnB1dENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxHcm91cENvbXBvbmVudCB7XG4gICAgQFZpZXdDaGlsZCgnbmV3VmFsdWVJbnB1dCcpIHB1YmxpYyBuZXdWYWx1ZUlucHV0ITogTmF0dXJhbElucHV0Q29tcG9uZW50O1xuXG4gICAgLyoqXG4gICAgICogVGV4dCBkaXNwbGF5IGluIHRoZSBkcm9wZG93biB0byBzZWxlY3QgdGhlIGZhY2V0XG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIGRyb3Bkb3duVGl0bGUgPSAnJztcbiAgICBASW5wdXQoe3JlcXVpcmVkOiB0cnVlfSkgcHVibGljIHBsYWNlaG9sZGVyITogc3RyaW5nO1xuICAgIEBJbnB1dCh7cmVxdWlyZWQ6IHRydWV9KSBwdWJsaWMgZmFjZXRzITogTmF0dXJhbFNlYXJjaEZhY2V0cztcbiAgICBAT3V0cHV0KCkgcHVibGljIHJlYWRvbmx5IHNlbGVjdGlvbkNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8R3JvdXBTZWxlY3Rpb25zPigpO1xuICAgIHB1YmxpYyBpbm5lclNlbGVjdGlvbnM6IEdyb3VwU2VsZWN0aW9ucyA9IFtdO1xuXG4gICAgQElucHV0KCkgcHVibGljIHNldCBzZWxlY3Rpb25zKHNlbGVjdGlvbjogR3JvdXBTZWxlY3Rpb25zKSB7XG4gICAgICAgIHRoaXMuaW5uZXJTZWxlY3Rpb25zID0gZGVlcENsb25lKHNlbGVjdGlvbik7XG4gICAgfVxuXG4gICAgcHVibGljIHVwZGF0ZUlucHV0KHNlbGVjdGlvbjogTmF0dXJhbFNlYXJjaFNlbGVjdGlvbiwgaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgICAgICB0aGlzLmlubmVyU2VsZWN0aW9uc1tpbmRleF0gPSBzZWxlY3Rpb247XG4gICAgICAgIHRoaXMuc2VsZWN0aW9uQ2hhbmdlLmVtaXQodGhpcy5pbm5lclNlbGVjdGlvbnMpO1xuICAgIH1cblxuICAgIHB1YmxpYyBhZGRJbnB1dChzZWxlY3Rpb246IE5hdHVyYWxTZWFyY2hTZWxlY3Rpb24pOiB2b2lkIHtcbiAgICAgICAgdGhpcy5uZXdWYWx1ZUlucHV0LmNsZWFyKCk7XG4gICAgICAgIHRoaXMuaW5uZXJTZWxlY3Rpb25zLnB1c2goc2VsZWN0aW9uKTtcbiAgICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh0aGlzLmlubmVyU2VsZWN0aW9ucyk7XG4gICAgfVxuXG4gICAgcHVibGljIHJlbW92ZUlucHV0KGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pbm5lclNlbGVjdGlvbnMuc3BsaWNlKGluZGV4LCAxKTtcbiAgICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh0aGlzLmlubmVyU2VsZWN0aW9ucyk7XG4gICAgfVxufVxuIiwiPG5hdHVyYWwtaW5wdXRcbiAgICAoY2xlYXJlZCk9XCJyZW1vdmVJbnB1dChpKVwiXG4gICAgKHNlbGVjdGlvbkNoYW5nZSk9XCJ1cGRhdGVJbnB1dCgkZXZlbnQsIGkpXCJcbiAgICAqbmdGb3I9XCJsZXQgc2VsZWN0aW9uIG9mIGlubmVyU2VsZWN0aW9uczsgbGV0IGkgPSBpbmRleFwiXG4gICAgW2ZhY2V0c109XCJmYWNldHNcIlxuICAgIFtzZWxlY3Rpb25dPVwic2VsZWN0aW9uXCJcbj48L25hdHVyYWwtaW5wdXQ+XG5cbjxuYXR1cmFsLWlucHV0XG4gICAgI25ld1ZhbHVlSW5wdXRcbiAgICAoc2VsZWN0aW9uQ2hhbmdlKT1cImFkZElucHV0KCRldmVudClcIlxuICAgIFtmYWNldHNdPVwiZmFjZXRzXCJcbiAgICBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIlxuICAgIHRhYkluZGV4PVwiMTBcIlxuICAgIGNka0ZvY3VzSW5pdGlhbFxuICAgIFtkcm9wZG93blRpdGxlXT1cImRyb3Bkb3duVGl0bGVcIlxuPjwvbmF0dXJhbC1pbnB1dD5cbiJdfQ==
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2VhcmNoL2dyb3VwL2dyb3VwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9ncm91cC9ncm91cC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRixPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDM0MsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7O0FBVy9ELE1BQU0sT0FBTyxxQkFBcUI7SUFQbEM7UUFVSTs7V0FFRztRQUNhLGtCQUFhLEdBQUcsRUFBRSxDQUFDO1FBR1Qsb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBbUIsQ0FBQztRQUN6RSxvQkFBZSxHQUFvQixFQUFFLENBQUM7S0FxQmhEO0lBbkJHLElBQW9CLFVBQVUsQ0FBQyxTQUEwQjtRQUNyRCxJQUFJLENBQUMsZUFBZSxHQUFHLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNoRCxDQUFDO0lBRU0sV0FBVyxDQUFDLFNBQWlDLEVBQUUsS0FBYTtRQUMvRCxJQUFJLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxHQUFHLFNBQVMsQ0FBQztRQUN4QyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVNLFFBQVEsQ0FBQyxTQUFpQztRQUM3QyxJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzNCLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRU0sV0FBVyxDQUFDLEtBQWE7UUFDNUIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUNwRCxDQUFDOzhHQTlCUSxxQkFBcUI7a0dBQXJCLHFCQUFxQiw4VkNibEMsa2VBa0JBLGdRRFBjLHFCQUFxQjs7MkZBRXRCLHFCQUFxQjtrQkFQakMsU0FBUzsrQkFDSSxlQUFlLGNBR2IsSUFBSSxXQUNQLENBQUMscUJBQXFCLENBQUM7OEJBR0csYUFBYTtzQkFBL0MsU0FBUzt1QkFBQyxlQUFlO2dCQUtWLGFBQWE7c0JBQTVCLEtBQUs7Z0JBQzBCLFdBQVc7c0JBQTFDLEtBQUs7dUJBQUMsRUFBQyxRQUFRLEVBQUUsSUFBSSxFQUFDO2dCQUNTLE1BQU07c0JBQXJDLEtBQUs7dUJBQUMsRUFBQyxRQUFRLEVBQUUsSUFBSSxFQUFDO2dCQUNHLGVBQWU7c0JBQXhDLE1BQU07Z0JBR2EsVUFBVTtzQkFBN0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQsIFZpZXdDaGlsZH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge2RlZXBDbG9uZX0gZnJvbSAnLi4vY2xhc3Nlcy91dGlscyc7XG5pbXBvcnQge05hdHVyYWxJbnB1dENvbXBvbmVudH0gZnJvbSAnLi4vaW5wdXQvaW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7TmF0dXJhbFNlYXJjaEZhY2V0c30gZnJvbSAnLi4vdHlwZXMvZmFjZXQnO1xuaW1wb3J0IHtHcm91cFNlbGVjdGlvbnMsIE5hdHVyYWxTZWFyY2hTZWxlY3Rpb259IGZyb20gJy4uL3R5cGVzL3ZhbHVlcyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbmF0dXJhbC1ncm91cCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2dyb3VwLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ncm91cC5jb21wb25lbnQuc2NzcyddLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW05hdHVyYWxJbnB1dENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxHcm91cENvbXBvbmVudCB7XG4gICAgQFZpZXdDaGlsZCgnbmV3VmFsdWVJbnB1dCcpIHB1YmxpYyBuZXdWYWx1ZUlucHV0ITogTmF0dXJhbElucHV0Q29tcG9uZW50O1xuXG4gICAgLyoqXG4gICAgICogVGV4dCBkaXNwbGF5IGluIHRoZSBkcm9wZG93biB0byBzZWxlY3QgdGhlIGZhY2V0XG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIGRyb3Bkb3duVGl0bGUgPSAnJztcbiAgICBASW5wdXQoe3JlcXVpcmVkOiB0cnVlfSkgcHVibGljIHBsYWNlaG9sZGVyITogc3RyaW5nO1xuICAgIEBJbnB1dCh7cmVxdWlyZWQ6IHRydWV9KSBwdWJsaWMgZmFjZXRzITogTmF0dXJhbFNlYXJjaEZhY2V0cztcbiAgICBAT3V0cHV0KCkgcHVibGljIHJlYWRvbmx5IHNlbGVjdGlvbkNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8R3JvdXBTZWxlY3Rpb25zPigpO1xuICAgIHB1YmxpYyBpbm5lclNlbGVjdGlvbnM6IEdyb3VwU2VsZWN0aW9ucyA9IFtdO1xuXG4gICAgQElucHV0KCkgcHVibGljIHNldCBzZWxlY3Rpb25zKHNlbGVjdGlvbjogR3JvdXBTZWxlY3Rpb25zKSB7XG4gICAgICAgIHRoaXMuaW5uZXJTZWxlY3Rpb25zID0gZGVlcENsb25lKHNlbGVjdGlvbik7XG4gICAgfVxuXG4gICAgcHVibGljIHVwZGF0ZUlucHV0KHNlbGVjdGlvbjogTmF0dXJhbFNlYXJjaFNlbGVjdGlvbiwgaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgICAgICB0aGlzLmlubmVyU2VsZWN0aW9uc1tpbmRleF0gPSBzZWxlY3Rpb247XG4gICAgICAgIHRoaXMuc2VsZWN0aW9uQ2hhbmdlLmVtaXQodGhpcy5pbm5lclNlbGVjdGlvbnMpO1xuICAgIH1cblxuICAgIHB1YmxpYyBhZGRJbnB1dChzZWxlY3Rpb246IE5hdHVyYWxTZWFyY2hTZWxlY3Rpb24pOiB2b2lkIHtcbiAgICAgICAgdGhpcy5uZXdWYWx1ZUlucHV0LmNsZWFyKCk7XG4gICAgICAgIHRoaXMuaW5uZXJTZWxlY3Rpb25zLnB1c2goc2VsZWN0aW9uKTtcbiAgICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh0aGlzLmlubmVyU2VsZWN0aW9ucyk7XG4gICAgfVxuXG4gICAgcHVibGljIHJlbW92ZUlucHV0KGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pbm5lclNlbGVjdGlvbnMuc3BsaWNlKGluZGV4LCAxKTtcbiAgICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh0aGlzLmlubmVyU2VsZWN0aW9ucyk7XG4gICAgfVxufVxuIiwiQGZvciAoc2VsZWN0aW9uIG9mIGlubmVyU2VsZWN0aW9uczsgdHJhY2sgc2VsZWN0aW9uKSB7XG4gICAgPG5hdHVyYWwtaW5wdXRcbiAgICAgICAgKGNsZWFyZWQpPVwicmVtb3ZlSW5wdXQoJGluZGV4KVwiXG4gICAgICAgIChzZWxlY3Rpb25DaGFuZ2UpPVwidXBkYXRlSW5wdXQoJGV2ZW50LCAkaW5kZXgpXCJcbiAgICAgICAgW2ZhY2V0c109XCJmYWNldHNcIlxuICAgICAgICBbc2VsZWN0aW9uXT1cInNlbGVjdGlvblwiXG4gICAgLz5cbn1cblxuPG5hdHVyYWwtaW5wdXRcbiAgICAjbmV3VmFsdWVJbnB1dFxuICAgIChzZWxlY3Rpb25DaGFuZ2UpPVwiYWRkSW5wdXQoJGV2ZW50KVwiXG4gICAgW2ZhY2V0c109XCJmYWNldHNcIlxuICAgIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiXG4gICAgdGFiSW5kZXg9XCIxMFwiXG4gICAgY2RrRm9jdXNJbml0aWFsXG4gICAgW2Ryb3Bkb3duVGl0bGVdPVwiZHJvcGRvd25UaXRsZVwiXG4vPlxuIl19
@@ -9,17 +9,15 @@ import { MatButtonModule } from '@angular/material/button';
9
9
  import { NaturalIconDirective } from '../../icon/icon.directive';
10
10
  import { MatIconModule } from '@angular/material/icon';
11
11
  import { MatInputModule } from '@angular/material/input';
12
- import { CommonModule } from '@angular/common';
13
12
  import { MatFormFieldModule } from '@angular/material/form-field';
14
13
  import * as i0 from "@angular/core";
15
14
  import * as i1 from "../dropdown-container/dropdown.service";
16
15
  import * as i2 from "@angular/material/form-field";
17
16
  import * as i3 from "@angular/material/core";
18
- import * as i4 from "@angular/common";
19
- import * as i5 from "@angular/material/input";
20
- import * as i6 from "@angular/forms";
21
- import * as i7 from "@angular/material/icon";
22
- import * as i8 from "@angular/material/button";
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";
23
21
  // Required to check invalid fields when initializing natural-search
24
22
  class AlwaysErrorStateMatcher {
25
23
  isErrorState(control) {
@@ -105,29 +103,6 @@ export class NaturalInputComponent {
105
103
  */
106
104
  this.neutralizeDropdownOpening = false;
107
105
  }
108
- ngOnInit() {
109
- this.input.nativeElement.addEventListener('focus', () => {
110
- this.openDropdown();
111
- });
112
- this.input.nativeElement.addEventListener('keyup', () => {
113
- if (!this.dropdownRef) {
114
- return;
115
- }
116
- if (this.formCtrl.value !== '') {
117
- this.dropdownRef.close();
118
- }
119
- });
120
- if (!this.placeholder) {
121
- this.placeholder = $localize `Recherche`;
122
- }
123
- const placeholderSize = (this.facet ? this.facet.display.length : this.placeholder.length) * 0.66;
124
- this.length = Math.max(this.minLength, Math.ceil(placeholderSize));
125
- }
126
- ngOnDestroy() {
127
- if (this.dropdownComponentRef) {
128
- this.dropdownComponentRef.destroy();
129
- }
130
- }
131
106
  ngOnChanges() {
132
107
  if (!this.facets && this.selection) {
133
108
  setTimeout(() => this.clear());
@@ -156,6 +131,29 @@ export class NaturalInputComponent {
156
131
  }
157
132
  }
158
133
  }
134
+ ngOnInit() {
135
+ this.input.nativeElement.addEventListener('focus', () => {
136
+ this.openDropdown();
137
+ });
138
+ this.input.nativeElement.addEventListener('keyup', () => {
139
+ if (!this.dropdownRef) {
140
+ return;
141
+ }
142
+ if (this.formCtrl.value !== '') {
143
+ this.dropdownRef.close();
144
+ }
145
+ });
146
+ if (!this.placeholder) {
147
+ this.placeholder = $localize `Recherche`;
148
+ }
149
+ const placeholderSize = (this.facet ? this.facet.display.length : this.placeholder.length) * 0.66;
150
+ this.length = Math.max(this.minLength, Math.ceil(placeholderSize));
151
+ }
152
+ ngOnDestroy() {
153
+ if (this.dropdownComponentRef) {
154
+ this.dropdownComponentRef.destroy();
155
+ }
156
+ }
159
157
  search(event) {
160
158
  event.stopPropagation();
161
159
  event.preventDefault();
@@ -303,28 +301,27 @@ export class NaturalInputComponent {
303
301
  field: this.facet ? this.facet.field : this.searchFieldName,
304
302
  condition: condition,
305
303
  };
306
- if (this.facet && this.facet.name) {
304
+ if (this.facet?.name) {
307
305
  selection.name = this.facet.name;
308
306
  }
309
307
  return selection;
310
308
  }
311
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalInputComponent, deps: [{ token: i0.ElementRef }, { token: i1.NaturalDropdownService }, { token: i0.EnvironmentInjector }], target: i0.ɵɵFactoryTarget.Component }); }
312
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", 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 <mat-label *ngIf=\"facet\">{{ facet.display }}</mat-label>\n <mat-label *ngIf=\"!facet\">{{ placeholder }}</mat-label>\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 <mat-icon *ngIf=\"!facet && !selection\" naturalIcon=\"search\" matIconPrefix></mat-icon>\n\n <button (click)=\"clear()\" *ngIf=\"selection\" mat-icon-button matIconSuffix>\n <mat-icon naturalIcon=\"close\"></mat-icon>\n </button>\n\n <button (click)=\"clear()\" *ngIf=\"facet && !selection\" mat-icon-button matIconSuffix>\n <mat-icon naturalIcon=\"undo\"></mat-icon>\n </button>\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n", styles: [":host{position:relative;overflow:hidden;border-top-left-radius:4px;border-top-right-radius:4px;display:flex;flex-direction:column}:host .hide{color:transparent;height:0;margin:0 50px 0 10px;font-size:inherit;white-space:nowrap;font-family:Roboto,Helvetica Neue,sans-serif}\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: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i5.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: i6.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: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i6.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i7.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: i8.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }] }); }
309
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NaturalInputComponent, deps: [{ token: i0.ElementRef }, { token: i1.NaturalDropdownService }, { token: i0.EnvironmentInjector }], target: i0.ɵɵFactoryTarget.Component }); }
310
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.2", 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{position:relative;overflow:hidden;border-top-left-radius:4px;border-top-right-radius:4px;display:flex;flex-direction:column}:host .hide{color:transparent;height:0;margin:0 50px 0 10px;font-size:inherit;white-space:nowrap;font-family:Roboto,Helvetica Neue,sans-serif}\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"] }] }); }
313
311
  }
314
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalInputComponent, decorators: [{
312
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NaturalInputComponent, decorators: [{
315
313
  type: Component,
316
314
  args: [{ selector: 'natural-input', standalone: true, imports: [
317
315
  MatFormFieldModule,
318
316
  MatRippleModule,
319
- CommonModule,
320
317
  MatInputModule,
321
318
  FormsModule,
322
319
  ReactiveFormsModule,
323
320
  MatIconModule,
324
321
  NaturalIconDirective,
325
322
  MatButtonModule,
326
- ], 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 <mat-label *ngIf=\"facet\">{{ facet.display }}</mat-label>\n <mat-label *ngIf=\"!facet\">{{ placeholder }}</mat-label>\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 <mat-icon *ngIf=\"!facet && !selection\" naturalIcon=\"search\" matIconPrefix></mat-icon>\n\n <button (click)=\"clear()\" *ngIf=\"selection\" mat-icon-button matIconSuffix>\n <mat-icon naturalIcon=\"close\"></mat-icon>\n </button>\n\n <button (click)=\"clear()\" *ngIf=\"facet && !selection\" mat-icon-button matIconSuffix>\n <mat-icon naturalIcon=\"undo\"></mat-icon>\n </button>\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n", styles: [":host{position:relative;overflow:hidden;border-top-left-radius:4px;border-top-right-radius:4px;display:flex;flex-direction:column}:host .hide{color:transparent;height:0;margin:0 50px 0 10px;font-size:inherit;white-space:nowrap;font-family:Roboto,Helvetica Neue,sans-serif}\n"] }]
327
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.NaturalDropdownService }, { type: i0.EnvironmentInjector }]; }, propDecorators: { ripple: [{
323
+ ], 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{position:relative;overflow:hidden;border-top-left-radius:4px;border-top-right-radius:4px;display:flex;flex-direction:column}:host .hide{color:transparent;height:0;margin:0 50px 0 10px;font-size:inherit;white-space:nowrap;font-family:Roboto,Helvetica Neue,sans-serif}\n"] }]
324
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.NaturalDropdownService }, { type: i0.EnvironmentInjector }], propDecorators: { ripple: [{
328
325
  type: ViewChild,
329
326
  args: [MatRipple, { static: true }]
330
327
  }], input: [{
@@ -349,4 +346,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImpor
349
346
  type: HostListener,
350
347
  args: ['focus']
351
348
  }] } });
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":"AAAA,OAAO,EACH,SAAS,EAET,eAAe,EACf,yBAAyB,EAGzB,YAAY,EACZ,YAAY,EACZ,KAAK,EAIL,MAAM,EAEN,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,WAAW,EAAiC,WAAW,EAAE,mBAAmB,EAAC,MAAM,gBAAgB,CAAC;AAC5G,OAAO,EAAoB,SAAS,EAAE,eAAe,EAAC,MAAM,wBAAwB,CAAC;AAErF,OAAO,EAAC,qBAAqB,EAAC,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAC,kBAAkB,EAAC,MAAM,oCAAoC,CAAC;AACtE,OAAO,EACH,qBAAqB,GAGxB,MAAM,wCAAwC,CAAC;AAChD,OAAO,EAAC,sBAAsB,EAA6B,MAAM,4CAA4C,CAAC;AAI9G,OAAO,EAAC,eAAe,EAAC,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAC,oBAAoB,EAAC,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAC,aAAa,EAAC,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAC,cAAc,EAAC,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAC,kBAAkB,EAAC,MAAM,8BAA8B,CAAC;;;;;;;;;;AAEhE,oEAAoE;AACpE,MAAM,uBAAuB;IAClB,YAAY,CAAC,OAAoC;QACpD,OAAO,CAAC,CAAC,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC;IACxC,CAAC;CACJ;AAED,SAAS,gBAAgB,CAAC,SAA4B;IAClD,OAAO,GAA4B,EAAE;QACjC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE;YACtB,OAAO,EAAC,SAAS,EAAE,IAAI,EAAC,CAAC;SAC5B;QAED,OAAO,IAAI,CAAC;IAChB,CAAC,CAAC;AACN,CAAC;AAmBD,MAAM,OAAO,qBAAqB;IAyF9B;;;;OAIG;IAEI,KAAK;QACR,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC;QACtC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QACjC,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC;IAC3C,CAAC;IAED,YACqB,OAAgC,EAChC,eAAuC,EACvC,QAA6B;QAF7B,YAAO,GAAP,OAAO,CAAyB;QAChC,oBAAe,GAAf,eAAe,CAAwB;QACvC,aAAQ,GAAR,QAAQ,CAAqB;QAxFlD;;WAEG;QACa,oBAAe,GAAG,QAAQ,CAAC;QAE3C;;WAEG;QACa,cAAS,GAAkC,IAAI,CAAC;QAOhE;;WAEG;QACa,kBAAa,GAAG,EAAE,CAAC;QAEnC;;WAEG;QACuB,oBAAe,GAAG,IAAI,YAAY,EAA0B,CAAC;QAEvF;;WAEG;QACuB,YAAO,GAAG,IAAI,YAAY,EAAyB,CAAC;QAE9E;;WAEG;QACI,UAAK,GAAiB,IAAI,CAAC;QAElC;;WAEG;QACa,aAAQ,GAAG,IAAI,WAAW,CAAgB,IAAI,CAAC,CAAC;QAEhE;;WAEG;QACa,iBAAY,GAAG,IAAI,uBAAuB,EAAE,CAAC;QAE7D;;WAEG;QACK,gBAAW,GAA8B,IAAI,CAAC;QAEtD;;WAEG;QACK,yBAAoB,GAA2C,IAAI,CAAC;QAE5E;;;WAGG;QACc,cAAS,GAAG,CAAC,CAAC;QAE/B;;;WAGG;QACI,WAAM,GAAG,IAAI,CAAC,SAAS,CAAC;QAE/B;;;WAGG;QACK,8BAAyB,GAAG,KAAK,CAAC;IAkBvC,CAAC;IAEG,QAAQ;QACX,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;YACpD,IAAI,CAAC,YAAY,EAAE,CAAC;QACxB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;YACpD,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;gBACnB,OAAO;aACV;YAED,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,KAAK,EAAE,EAAE;gBAC5B,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;aAC5B;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACnB,IAAI,CAAC,WAAW,GAAG,SAAS,CAAA,WAAW,CAAC;SAC3C;QAED,MAAM,eAAe,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC;QAClG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC;IACvE,CAAC;IAEM,WAAW;QACd,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC3B,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,CAAC;SACvC;IACL,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,EAAE;YAChC,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;SAClC;aAAM,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,EAAE;YACtC,IAAI,CAAC,KAAK,GAAG,qBAAqB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;YAEhE,IAAI,IAAI,CAAC,UAAU,EAAE,EAAE;gBACnB,MAAM,iBAAiB,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAkD,CAAC,CAAC;gBACxG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;gBACnE,iBAAiB,CAAC,aAAa,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;oBAC9C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBAClC,CAAC,CAAC,CAAC;aACN;iBAAM,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;gBACtB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;aAC9B;iBAAM,IACH,IAAI,CAAC,SAAS;gBACd,IAAI,CAAC,SAAS,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe;gBAC7C,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,EAC/B;gBACE,qBAAqB;gBACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACpE;iBAAM;gBACH,sGAAsG;gBACtG,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;aAClC;SACJ;IACL,CAAC;IAEM,MAAM,CAAC,KAAY;QACtB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE;YACtB,OAAO;SACV;QAED,IAAI,IAAI,CAAC,UAAU,EAAE,EAAE;YACnB,OAAO;SACV;QAED,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE;YAC5C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,EAAC,IAAI,EAAE,EAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAC,EAAC,CAAC,CAAC,CAAC;SACtF;IACL,CAAC;IAEM,KAAK;QACR,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC7B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAEM,YAAY;QACf,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,yBAAyB,EAAE;YACpD,sCAAsC;YACtC,8FAA8F;YAC9F,iDAAiD;YACjD,OAAO;SACV;QAED,IAAI,CAAC,YAAY,EAAE,CAAC;QAEpB,2EAA2E;QAC3E,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE;YACrC,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACtD;aAAM;YACH,2DAA2D;YAC3D,IAAI,CAAC,gBAAgB,EAAE,CAAC;SAC3B;IACL,CAAC;IAEM,UAAU;QACb,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,IAAK,IAAI,CAAC,KAAgC,CAAC,SAAS,CAAC,CAAC;IAC9E,CAAC;IAEM,MAAM;QACT,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,IAAK,IAAI,CAAC,KAA8C,CAAC,SAAS,CAAC,CAAC;IAC5F,CAAC;IAEO,eAAe,CAAC,KAA6B;QACjD,wCAAwC;QACxC,gEAAgE;QAChE,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC3B,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,CAAC;SACvC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAE,IAAI,CAAC,SAAS,CAAC,SAAuC,CAAC,CAAC,CAAC,IAAI,CAAC;QAClG,MAAM,IAAI,GAAwB;YAC9B,SAAS,EAAE,SAAS;YACpB,aAAa,EAAE,KAAK,CAAC,aAAa;SACrC,CAAC;QAEF,MAAM,QAAQ,GAAG,yBAAyB,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtF,IAAI,CAAC,oBAAoB,GAAG,eAAe,CAAC,KAAK,CAAC,SAAS,EAAE;YACzD,mBAAmB,EAAE,QAAQ;SAChC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC;IAC9C,CAAC;IAEO,eAAe,CAAC,IAAyB;QAC7C,iFAAiF;QACjF,OAAO;YACH;gBACI,OAAO,EAAE,kBAAkB;gBAC3B,QAAQ,EAAE,IAAI;aACjB;YACD;gBACI,OAAO,EAAE,qBAAqB;gBAC9B,QAAQ,EAAE,IAAI;aACjB;SACJ,CAAC;IACN,CAAC;IAEO,YAAY;QAChB,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;YACjC,UAAU,EAAE,IAAI;YAChB,QAAQ,EAAE,IAAI;SACjB,CAAC,CAAC;QAEH,SAAS,CAAC,OAAO,EAAE,CAAC;IACxB,CAAC;IAEO,yBAAyB,CAAC,KAAyB;QACvD,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE;YACtD,OAAO;SACV;QAED,MAAM,IAAI,GAAoD;YAC1D,SAAS,EAAE,EAAE;YACb,KAAK,EAAE,KAAK;YACZ,aAAa,EAAE;gBACX,MAAM,EAAE,IAAI,CAAC,MAAM;aACtB;SACJ,CAAC;QAEF,MAAM,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAClD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,sBAAsB,EAAE,IAAI,CAAC,OAAO,EAAE,cAAc,EAAE,KAAK,CAAC,CAAC;QAC1G,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACvC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,MAAM,KAAK,SAAS,EAAE;gBACtB,IAAI,MAAM,CAAC,KAAK,EAAE;oBACd,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;iBAC/B;qBAAM,IAAI,MAAM,CAAC,SAAS,EAAE;oBACzB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;iBACzB;aACJ;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,gBAAgB;QACpB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE;YACpB,OAAO;SACV;QAED,MAAM,aAAa,GAAG,IAAI,CAAC,KAA+B,CAAC;QAE3D,MAAM,IAAI,GAAwB;YAC9B,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI;YAC3D,aAAa,EAAE,aAAa,CAAC,aAAa;SAC7C,CAAC;QAEF,MAAM,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAClD,MAAM,SAAS,GAAG,aAAa,CAAC,SAAS,CAAC;QAC1C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CACxC,SAAS,EACT,IAAI,CAAC,OAAO,EACZ,cAAc,EACd,aAAa,CAAC,kBAAkB,KAAK,SAAS,CAAC,CAAC,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAC3F,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACvC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,MAAM,KAAK,SAAS,EAAE;gBACtB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;aACzB;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,QAAQ,CAAC,KAAY;QACzB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,IAAI,CAAC,UAAU,EAAE,EAAE;YACnB,IAAI,CAAC,gBAAgB,EAAE,CAAC;SAC3B;aAAM,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;YACtB,IAAI,CAAC,QAAQ,CAAC;gBACV,SAAS,EAAG,KAA8C,CAAC,SAAS;aACvE,CAAC,CAAC;SACN;aAAM;YACH,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACpC;IACL,CAAC;IAEO,QAAQ,CAAC,MAAsB;QACnC,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;SAClE;IACL,CAAC;IAEO,YAAY,CAAC,SAA8C;QAC/D,MAAM,SAAS,GAA2B;YACtC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe;YAC3D,SAAS,EAAE,SAAS;SACvB,CAAC;QAEF,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE;YAC/B,SAAS,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;SACpC;QAED,OAAO,SAAS,CAAC;IACrB,CAAC;8GA1VQ,qBAAqB;kGAArB,qBAAqB,yXAInB,SAAS,kLC5ExB,utCA6BA,2UDgCQ,kBAAkB,4iBAClB,eAAe,kSACf,YAAY,kIACZ,cAAc,0WACd,WAAW,sZACX,mBAAmB,iNACnB,aAAa,oLACb,oBAAoB,kGACpB,eAAe;;2FAGV,qBAAqB;kBAjBjC,SAAS;+BACI,eAAe,cAGb,IAAI,WACP;wBACL,kBAAkB;wBAClB,eAAe;wBACf,YAAY;wBACZ,cAAc;wBACd,WAAW;wBACX,mBAAmB;wBACnB,aAAa;wBACb,oBAAoB;wBACpB,eAAe;qBAClB;wKAM4C,MAAM;sBAAlD,SAAS;uBAAC,SAAS,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAKO,KAAK;sBAA/C,SAAS;uBAAC,OAAO,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAKlB,WAAW;sBAA1B,KAAK;gBAKU,eAAe;sBAA9B,KAAK;gBAKU,SAAS;sBAAxB,KAAK;gBAK0B,MAAM;sBAArC,KAAK;uBAAC,EAAC,QAAQ,EAAE,IAAI,EAAC;gBAKP,aAAa;sBAA5B,KAAK;gBAKoB,eAAe;sBAAxC,MAAM;gBAKmB,OAAO;sBAAhC,MAAM;gBAmDA,KAAK;sBADX,YAAY;uBAAC,OAAO","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, ValidationErrors, ValidatorFn, FormsModule, ReactiveFormsModule} 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 {CommonModule} from '@angular/common';\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    styleUrls: ['./input.component.scss'],\n    standalone: true,\n    imports: [\n        MatFormFieldModule,\n        MatRippleModule,\n        CommonModule,\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 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 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 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        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 as FilterGroupConditionField) : 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 && 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    <mat-label *ngIf=\"facet\">{{ facet.display }}</mat-label>\n    <mat-label *ngIf=\"!facet\">{{ placeholder }}</mat-label>\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    <mat-icon *ngIf=\"!facet && !selection\" naturalIcon=\"search\" matIconPrefix></mat-icon>\n\n    <button (click)=\"clear()\" *ngIf=\"selection\" mat-icon-button matIconSuffix>\n        <mat-icon naturalIcon=\"close\"></mat-icon>\n    </button>\n\n    <button (click)=\"clear()\" *ngIf=\"facet && !selection\" mat-icon-button matIconSuffix>\n        <mat-icon naturalIcon=\"undo\"></mat-icon>\n    </button>\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n"]}
349
+ //# 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    styleUrls: ['./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        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"]}