@ecodev/natural 52.0.0 → 53.2.0

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 (187) hide show
  1. package/esm2022/lib/classes/providers.mjs +13 -0
  2. package/esm2022/lib/directives/http-prefix.directive.mjs +3 -2
  3. package/esm2022/lib/modules/alert/confirm.component.mjs +5 -4
  4. package/esm2022/lib/modules/alert/public-api.mjs +1 -2
  5. package/esm2022/lib/modules/avatar/component/avatar.component.mjs +8 -8
  6. package/esm2022/lib/modules/avatar/public-api.mjs +1 -2
  7. package/esm2022/lib/modules/avatar/service/avatar.service.mjs +1 -1
  8. package/esm2022/lib/modules/columns-picker/columns-picker.component.mjs +29 -11
  9. package/esm2022/lib/modules/columns-picker/public-api.mjs +1 -2
  10. package/esm2022/lib/modules/common/directives/linkable-tab.directive.mjs +3 -2
  11. package/esm2022/lib/modules/common/directives/src-density.directive.mjs +3 -2
  12. package/esm2022/lib/modules/common/pipes/capitalize.pipe.mjs +6 -3
  13. package/esm2022/lib/modules/common/pipes/ellipsis.pipe.mjs +6 -3
  14. package/esm2022/lib/modules/common/pipes/enum.pipe.mjs +3 -2
  15. package/esm2022/lib/modules/common/pipes/swiss-date.pipe.mjs +3 -2
  16. package/esm2022/lib/modules/common/pipes/time-ago.pipe.mjs +3 -2
  17. package/esm2022/lib/modules/common/public-api.mjs +2 -2
  18. package/esm2022/lib/modules/common/services/seo.provider.mjs +23 -0
  19. package/esm2022/lib/modules/detail-header/detail-header.component.mjs +10 -8
  20. package/esm2022/lib/modules/detail-header/public-api.mjs +1 -2
  21. package/esm2022/lib/modules/dialog-trigger/dialog-trigger.component.mjs +3 -2
  22. package/esm2022/lib/modules/dialog-trigger/public-api.mjs +1 -2
  23. package/esm2022/lib/modules/dropdown-components/public-api.mjs +2 -2
  24. package/esm2022/lib/modules/dropdown-components/type-boolean/type-boolean.component.mjs +59 -0
  25. package/esm2022/lib/modules/dropdown-components/type-date/type-date.component.mjs +27 -11
  26. package/esm2022/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs +12 -9
  27. package/esm2022/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.mjs +22 -9
  28. package/esm2022/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.mjs +22 -9
  29. package/esm2022/lib/modules/dropdown-components/type-number/type-number.component.mjs +23 -10
  30. package/esm2022/lib/modules/dropdown-components/type-select/type-select.component.mjs +23 -11
  31. package/esm2022/lib/modules/dropdown-components/type-text/type-text.component.mjs +10 -8
  32. package/esm2022/lib/modules/file/component/file.component.mjs +22 -13
  33. package/esm2022/lib/modules/file/file-drop.directive.mjs +3 -2
  34. package/esm2022/lib/modules/file/file-select.directive.mjs +3 -2
  35. package/esm2022/lib/modules/file/public-api.mjs +1 -2
  36. package/esm2022/lib/modules/fixed-button/fixed-button.component.mjs +9 -7
  37. package/esm2022/lib/modules/fixed-button/public-api.mjs +1 -2
  38. package/esm2022/lib/modules/fixed-button-detail/fixed-button-detail.component.mjs +7 -6
  39. package/esm2022/lib/modules/fixed-button-detail/public-api.mjs +1 -2
  40. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.mjs +29 -12
  41. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.mjs +4 -3
  42. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.mjs +6 -5
  43. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.mjs +4 -3
  44. package/esm2022/lib/modules/hierarchic-selector/public-api.mjs +1 -2
  45. package/esm2022/lib/modules/icon/icon.directive.mjs +9 -6
  46. package/esm2022/lib/modules/icon/icon.module.mjs +31 -41
  47. package/esm2022/lib/modules/icon/public-api.mjs +2 -2
  48. package/esm2022/lib/modules/logger/error-handler.mjs +3 -3
  49. package/esm2022/lib/modules/logger/error.module.mjs +14 -28
  50. package/esm2022/lib/modules/logger/public-api.mjs +2 -2
  51. package/esm2022/lib/modules/matomo/public-api.mjs +1 -2
  52. package/esm2022/lib/modules/panels/panels.component.mjs +3 -3
  53. package/esm2022/lib/modules/panels/panels.module.mjs +8 -31
  54. package/esm2022/lib/modules/panels/public-api.mjs +2 -2
  55. package/esm2022/lib/modules/relations/public-api.mjs +1 -2
  56. package/esm2022/lib/modules/relations/relations.component.mjs +27 -11
  57. package/esm2022/lib/modules/search/dropdown-container/dropdown-container.component.mjs +7 -6
  58. package/esm2022/lib/modules/search/facet-selector/facet-selector.component.mjs +6 -5
  59. package/esm2022/lib/modules/search/group/group.component.mjs +5 -5
  60. package/esm2022/lib/modules/search/input/input.component.mjs +27 -13
  61. package/esm2022/lib/modules/search/public-api.mjs +1 -2
  62. package/esm2022/lib/modules/search/search/search.component.mjs +23 -8
  63. package/esm2022/lib/modules/select/public-api.mjs +1 -2
  64. package/esm2022/lib/modules/select/select/select.component.mjs +40 -15
  65. package/esm2022/lib/modules/select/select-enum/select-enum.component.mjs +22 -8
  66. package/esm2022/lib/modules/select/select-hierarchic/select-hierarchic.component.mjs +27 -10
  67. package/esm2022/lib/modules/sidenav/public-api.mjs +1 -2
  68. package/esm2022/lib/modules/sidenav/sidenav/sidenav.component.mjs +3 -2
  69. package/esm2022/lib/modules/sidenav/sidenav-container/sidenav-container.component.mjs +6 -6
  70. package/esm2022/lib/modules/sidenav/sidenav-content/sidenav-content.component.mjs +3 -3
  71. package/esm2022/lib/modules/stamp/public-api.mjs +1 -2
  72. package/esm2022/lib/modules/stamp/stamp.component.mjs +6 -6
  73. package/esm2022/lib/modules/table-button/public-api.mjs +1 -2
  74. package/esm2022/lib/modules/table-button/table-button.component.mjs +10 -8
  75. package/esm2022/public-api.mjs +2 -1
  76. package/fesm2022/ecodev-natural.mjs +813 -1127
  77. package/fesm2022/ecodev-natural.mjs.map +1 -1
  78. package/lib/classes/providers.d.ts +5 -0
  79. package/lib/directives/http-prefix.directive.d.ts +1 -1
  80. package/lib/modules/alert/confirm.component.d.ts +1 -1
  81. package/lib/modules/alert/public-api.d.ts +0 -1
  82. package/lib/modules/avatar/component/avatar.component.d.ts +3 -3
  83. package/lib/modules/avatar/public-api.d.ts +0 -1
  84. package/lib/modules/avatar/service/avatar.service.d.ts +2 -2
  85. package/lib/modules/columns-picker/columns-picker.component.d.ts +1 -1
  86. package/lib/modules/columns-picker/public-api.d.ts +0 -1
  87. package/lib/modules/common/directives/linkable-tab.directive.d.ts +1 -1
  88. package/lib/modules/common/directives/src-density.directive.d.ts +1 -1
  89. package/lib/modules/common/pipes/capitalize.pipe.d.ts +1 -1
  90. package/lib/modules/common/pipes/ellipsis.pipe.d.ts +1 -1
  91. package/lib/modules/common/pipes/enum.pipe.d.ts +1 -1
  92. package/lib/modules/common/pipes/swiss-date.pipe.d.ts +1 -1
  93. package/lib/modules/common/pipes/time-ago.pipe.d.ts +1 -1
  94. package/lib/modules/common/public-api.d.ts +1 -1
  95. package/lib/modules/common/services/seo.provider.d.ts +6 -0
  96. package/lib/modules/detail-header/detail-header.component.d.ts +1 -1
  97. package/lib/modules/detail-header/public-api.d.ts +0 -1
  98. package/lib/modules/dialog-trigger/dialog-trigger.component.d.ts +1 -1
  99. package/lib/modules/dialog-trigger/public-api.d.ts +0 -1
  100. package/lib/modules/dropdown-components/public-api.d.ts +1 -1
  101. package/lib/modules/dropdown-components/type-boolean/type-boolean.component.d.ts +32 -0
  102. package/lib/modules/dropdown-components/type-date/type-date.component.d.ts +1 -1
  103. package/lib/modules/dropdown-components/type-date-range/type-date-range.component.d.ts +1 -1
  104. package/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.d.ts +1 -1
  105. package/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.d.ts +1 -1
  106. package/lib/modules/dropdown-components/type-number/type-number.component.d.ts +1 -1
  107. package/lib/modules/dropdown-components/type-select/type-select.component.d.ts +1 -1
  108. package/lib/modules/dropdown-components/type-text/type-text.component.d.ts +1 -1
  109. package/lib/modules/file/component/file.component.d.ts +3 -3
  110. package/lib/modules/file/file-drop.directive.d.ts +1 -1
  111. package/lib/modules/file/file-select.directive.d.ts +1 -1
  112. package/lib/modules/file/public-api.d.ts +0 -1
  113. package/lib/modules/fixed-button/fixed-button.component.d.ts +1 -1
  114. package/lib/modules/fixed-button/public-api.d.ts +0 -1
  115. package/lib/modules/fixed-button-detail/fixed-button-detail.component.d.ts +1 -1
  116. package/lib/modules/fixed-button-detail/public-api.d.ts +0 -1
  117. package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.d.ts +1 -1
  118. package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.d.ts +1 -1
  119. package/lib/modules/hierarchic-selector/public-api.d.ts +0 -1
  120. package/lib/modules/icon/icon.directive.d.ts +3 -3
  121. package/lib/modules/icon/icon.module.d.ts +5 -13
  122. package/lib/modules/icon/public-api.d.ts +1 -1
  123. package/lib/modules/logger/error-handler.d.ts +2 -2
  124. package/lib/modules/logger/error.module.d.ts +2 -9
  125. package/lib/modules/logger/public-api.d.ts +1 -1
  126. package/lib/modules/matomo/public-api.d.ts +0 -1
  127. package/lib/modules/panels/panels.component.d.ts +1 -2
  128. package/lib/modules/panels/panels.module.d.ts +2 -12
  129. package/lib/modules/panels/public-api.d.ts +1 -1
  130. package/lib/modules/relations/public-api.d.ts +0 -1
  131. package/lib/modules/relations/relations.component.d.ts +1 -1
  132. package/lib/modules/search/dropdown-container/dropdown-container.component.d.ts +1 -1
  133. package/lib/modules/search/facet-selector/facet-selector.component.d.ts +1 -1
  134. package/lib/modules/search/group/group.component.d.ts +1 -1
  135. package/lib/modules/search/input/input.component.d.ts +1 -1
  136. package/lib/modules/search/public-api.d.ts +0 -1
  137. package/lib/modules/search/search/search.component.d.ts +1 -1
  138. package/lib/modules/select/public-api.d.ts +0 -1
  139. package/lib/modules/select/select/select.component.d.ts +1 -1
  140. package/lib/modules/select/select-enum/select-enum.component.d.ts +1 -1
  141. package/lib/modules/select/select-hierarchic/select-hierarchic.component.d.ts +1 -1
  142. package/lib/modules/sidenav/public-api.d.ts +0 -1
  143. package/lib/modules/sidenav/sidenav/sidenav.component.d.ts +1 -1
  144. package/lib/modules/sidenav/sidenav-container/sidenav-container.component.d.ts +1 -1
  145. package/lib/modules/sidenav/sidenav-content/sidenav-content.component.d.ts +1 -1
  146. package/lib/modules/stamp/public-api.d.ts +0 -1
  147. package/lib/modules/stamp/stamp.component.d.ts +1 -1
  148. package/lib/modules/table-button/public-api.d.ts +0 -1
  149. package/lib/modules/table-button/table-button.component.d.ts +1 -1
  150. package/package.json +1 -1
  151. package/public-api.d.ts +1 -0
  152. package/esm2022/lib/modules/alert/alert.module.mjs +0 -20
  153. package/esm2022/lib/modules/avatar/avatar.module.mjs +0 -19
  154. package/esm2022/lib/modules/columns-picker/columns-picker.module.mjs +0 -48
  155. package/esm2022/lib/modules/common/common-module.mjs +0 -54
  156. package/esm2022/lib/modules/detail-header/detail-header.module.mjs +0 -22
  157. package/esm2022/lib/modules/dialog-trigger/dialog-trigger.module.mjs +0 -19
  158. package/esm2022/lib/modules/dropdown-components/natural-dropdown-components.module.mjs +0 -90
  159. package/esm2022/lib/modules/file/file.module.mjs +0 -25
  160. package/esm2022/lib/modules/fixed-button/fixed-button.module.mjs +0 -22
  161. package/esm2022/lib/modules/fixed-button-detail/fixed-button-detail.module.mjs +0 -20
  162. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector.module.mjs +0 -79
  163. package/esm2022/lib/modules/matomo/matomo-module.module.mjs +0 -12
  164. package/esm2022/lib/modules/relations/relations.module.mjs +0 -60
  165. package/esm2022/lib/modules/search/search.module.mjs +0 -90
  166. package/esm2022/lib/modules/select/select.module.mjs +0 -70
  167. package/esm2022/lib/modules/sidenav/sidenav.module.mjs +0 -25
  168. package/esm2022/lib/modules/stamp/stamp-module.module.mjs +0 -20
  169. package/esm2022/lib/modules/table-button/table-button.module.mjs +0 -22
  170. package/lib/modules/alert/alert.module.d.ts +0 -11
  171. package/lib/modules/avatar/avatar.module.d.ts +0 -8
  172. package/lib/modules/columns-picker/columns-picker.module.d.ts +0 -15
  173. package/lib/modules/common/common-module.d.ts +0 -18
  174. package/lib/modules/detail-header/detail-header.module.d.ts +0 -12
  175. package/lib/modules/dialog-trigger/dialog-trigger.module.d.ts +0 -9
  176. package/lib/modules/dropdown-components/natural-dropdown-components.module.d.ts +0 -24
  177. package/lib/modules/file/file.module.d.ts +0 -14
  178. package/lib/modules/fixed-button/fixed-button.module.d.ts +0 -12
  179. package/lib/modules/fixed-button-detail/fixed-button-detail.module.d.ts +0 -10
  180. package/lib/modules/hierarchic-selector/hierarchic-selector.module.d.ts +0 -23
  181. package/lib/modules/matomo/matomo-module.module.d.ts +0 -6
  182. package/lib/modules/relations/relations.module.d.ts +0 -18
  183. package/lib/modules/search/search.module.d.ts +0 -23
  184. package/lib/modules/select/select.module.d.ts +0 -22
  185. package/lib/modules/sidenav/sidenav.module.d.ts +0 -13
  186. package/lib/modules/stamp/stamp-module.module.d.ts +0 -9
  187. package/lib/modules/table-button/table-button.module.d.ts +0 -12
@@ -1,18 +1,22 @@
1
1
  import { Component, Inject } from '@angular/core';
2
- import { FormControl, FormGroup, Validators } from '@angular/forms';
2
+ import { FormControl, FormGroup, Validators, FormsModule, ReactiveFormsModule } from '@angular/forms';
3
3
  import { BehaviorSubject, merge } from 'rxjs';
4
4
  import { NATURAL_DROPDOWN_DATA } from '../../search/dropdown-container/dropdown.service';
5
5
  import { possibleComparableOperators } from '../types';
6
6
  import { InvalidWithValueStateMatcher } from '../type-text/type-text.component';
7
7
  import { decimal } from '../../../classes/validators';
8
+ import { MatInputModule } from '@angular/material/input';
9
+ import { MatOptionModule } from '@angular/material/core';
10
+ import { NgFor, NgIf } from '@angular/common';
11
+ import { MatSelectModule } from '@angular/material/select';
12
+ import { MatFormFieldModule } from '@angular/material/form-field';
8
13
  import * as i0 from "@angular/core";
9
14
  import * as i1 from "../../search/dropdown-container/dropdown-ref";
10
- import * as i2 from "@angular/common";
11
- import * as i3 from "@angular/forms";
12
- import * as i4 from "@angular/material/form-field";
13
- import * as i5 from "@angular/material/input";
14
- import * as i6 from "@angular/material/select";
15
- import * as i7 from "@angular/material/core";
15
+ import * as i2 from "@angular/forms";
16
+ import * as i3 from "@angular/material/form-field";
17
+ import * as i4 from "@angular/material/select";
18
+ import * as i5 from "@angular/material/core";
19
+ import * as i6 from "@angular/material/input";
16
20
  export class TypeNumberComponent {
17
21
  constructor(data, dropdownRef) {
18
22
  this.dropdownRef = dropdownRef;
@@ -96,13 +100,22 @@ export class TypeNumberComponent {
96
100
  }
97
101
  }
98
102
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: TypeNumberComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }, { token: i1.NaturalDropdownRef }], target: i0.ɵɵFactoryTarget.Component }); }
99
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", type: TypeNumberComponent, selector: "ng-component", ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-form-field>\n <mat-label i18n>Valeur</mat-label>\n <input\n (keydown.enter)=\"close()\"\n [errorStateMatcher]=\"matcher\"\n [formControl]=\"valueCtrl\"\n [attr.max]=\"configuration.max\"\n [attr.min]=\"configuration.min\"\n [required]=\"true\"\n [step]=\"configuration.step\"\n matInput\n type=\"number\"\n />\n <mat-error *ngIf=\"valueCtrl.hasError('min')\">< {{ configuration.min }}</mat-error>\n <mat-error *ngIf=\"valueCtrl.hasError('max')\">> {{ configuration.max }}</mat-error>\n </mat-form-field>\n</form>\n", styles: [":host input::-webkit-outer-spin-button,:host input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.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: i3.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { 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: "component", type: i6.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i7.MatOption, selector: "mat-option", exportAs: ["matOption"] }] }); }
103
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", type: TypeNumberComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-form-field>\n <mat-label i18n>Valeur</mat-label>\n <input\n (keydown.enter)=\"close()\"\n [errorStateMatcher]=\"matcher\"\n [formControl]=\"valueCtrl\"\n [attr.max]=\"configuration.max\"\n [attr.min]=\"configuration.min\"\n [required]=\"true\"\n [step]=\"configuration.step\"\n matInput\n type=\"number\"\n />\n <mat-error *ngIf=\"valueCtrl.hasError('min')\">< {{ configuration.min }}</mat-error>\n <mat-error *ngIf=\"valueCtrl.hasError('max')\">> {{ configuration.max }}</mat-error>\n </mat-form-field>\n</form>\n", styles: [":host input::-webkit-outer-spin-button,:host input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.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: i2.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: MatOptionModule }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i6.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: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
100
104
  }
101
105
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: TypeNumberComponent, decorators: [{
102
106
  type: Component,
103
- args: [{ template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-form-field>\n <mat-label i18n>Valeur</mat-label>\n <input\n (keydown.enter)=\"close()\"\n [errorStateMatcher]=\"matcher\"\n [formControl]=\"valueCtrl\"\n [attr.max]=\"configuration.max\"\n [attr.min]=\"configuration.min\"\n [required]=\"true\"\n [step]=\"configuration.step\"\n matInput\n type=\"number\"\n />\n <mat-error *ngIf=\"valueCtrl.hasError('min')\">< {{ configuration.min }}</mat-error>\n <mat-error *ngIf=\"valueCtrl.hasError('max')\">> {{ configuration.max }}</mat-error>\n </mat-form-field>\n</form>\n", styles: [":host input::-webkit-outer-spin-button,:host input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}\n"] }]
107
+ args: [{ standalone: true, imports: [
108
+ FormsModule,
109
+ ReactiveFormsModule,
110
+ MatFormFieldModule,
111
+ MatSelectModule,
112
+ NgFor,
113
+ MatOptionModule,
114
+ MatInputModule,
115
+ NgIf,
116
+ ], template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-form-field>\n <mat-label i18n>Valeur</mat-label>\n <input\n (keydown.enter)=\"close()\"\n [errorStateMatcher]=\"matcher\"\n [formControl]=\"valueCtrl\"\n [attr.max]=\"configuration.max\"\n [attr.min]=\"configuration.min\"\n [required]=\"true\"\n [step]=\"configuration.step\"\n matInput\n type=\"number\"\n />\n <mat-error *ngIf=\"valueCtrl.hasError('min')\">< {{ configuration.min }}</mat-error>\n <mat-error *ngIf=\"valueCtrl.hasError('max')\">> {{ configuration.max }}</mat-error>\n </mat-form-field>\n</form>\n", styles: [":host input::-webkit-outer-spin-button,:host input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}\n"] }]
104
117
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
105
118
  type: Inject,
106
119
  args: [NATURAL_DROPDOWN_DATA]
107
120
  }] }, { type: i1.NaturalDropdownRef }]; } });
108
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-number.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-number/type-number.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-number/type-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {FormControl, FormGroup, ValidatorFn, Validators} from '@angular/forms';\nimport {BehaviorSubject, merge} from 'rxjs';\nimport {FilterGroupConditionField} from '../../search/classes/graphql-doctrine.types';\nimport {NaturalDropdownRef} from '../../search/dropdown-container/dropdown-ref';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {possibleComparableOperators, PossibleComparableOpertorKeys} from '../types';\nimport {InvalidWithValueStateMatcher} from '../type-text/type-text.component';\nimport {decimal} from '../../../classes/validators';\n\nexport interface TypeNumberConfiguration {\n    min?: number | null;\n    max?: number | null;\n    step?: number | null;\n}\n\n@Component({\n    templateUrl: './type-number.component.html',\n    styleUrls: ['./type-number.component.scss'],\n})\nexport class TypeNumberComponent implements DropdownComponent {\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    public readonly configuration: Required<TypeNumberConfiguration>;\n    public readonly operatorCtrl = new FormControl<PossibleComparableOpertorKeys>('equal', {nonNullable: true});\n    public readonly valueCtrl = new FormControl();\n    public readonly matcher = new InvalidWithValueStateMatcher();\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n    public readonly operators = possibleComparableOperators;\n\n    private readonly defaults: Required<TypeNumberConfiguration> = {\n        min: null,\n        max: null,\n        step: null,\n    };\n\n    public constructor(\n        @Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeNumberConfiguration>,\n        protected dropdownRef: NaturalDropdownRef,\n    ) {\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            const rendered = this.getRenderedValue();\n            this.renderedValue.next(rendered);\n        });\n\n        this.initValidators();\n        this.reloadCondition(data.condition);\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        const condition: FilterGroupConditionField = {};\n        condition[this.operatorCtrl.value] = {\n            value: this.valueCtrl.value,\n        };\n\n        return condition;\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    public close(): void {\n        if (this.isValid()) {\n            this.dropdownRef.close({condition: this.getCondition()});\n        } else {\n            this.dropdownRef.close(); // undefined value, discard changes / prevent to add a condition (on new fields\n        }\n    }\n\n    private initValidators(): void {\n        const validators: ValidatorFn[] = [Validators.required];\n        if (this.configuration.min) {\n            validators.push(Validators.min(this.configuration.min));\n        }\n\n        if (this.configuration.max) {\n            validators.push(Validators.max(this.configuration.max));\n        }\n\n        if (this.configuration.step) {\n            const decimals = ('' + this.configuration.step).match(/\\.(\\d+)$/)?.[1] ?? '';\n            const decimalCount = decimals.length;\n            validators.push(decimal(decimalCount));\n        }\n\n        this.valueCtrl.setValidators(validators);\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        for (const operator of this.operators) {\n            const reloadedCondition = condition[operator.key];\n            if (reloadedCondition) {\n                this.operatorCtrl.setValue(operator.key);\n                this.valueCtrl.setValue(reloadedCondition.value);\n            }\n        }\n    }\n\n    private getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (this.valueCtrl.value === null || !operator) {\n            return '';\n        } else {\n            return operator.label + ' ' + this.valueCtrl.value;\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n        <mat-label i18n=\"Mathematical operator < > =\">Opérateur</mat-label>\n        <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n            <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n                {{ item.label }}\n            </mat-option>\n        </mat-select>\n    </mat-form-field>\n\n    <mat-form-field>\n        <mat-label i18n>Valeur</mat-label>\n        <input\n            (keydown.enter)=\"close()\"\n            [errorStateMatcher]=\"matcher\"\n            [formControl]=\"valueCtrl\"\n            [attr.max]=\"configuration.max\"\n            [attr.min]=\"configuration.min\"\n            [required]=\"true\"\n            [step]=\"configuration.step\"\n            matInput\n            type=\"number\"\n        />\n        <mat-error *ngIf=\"valueCtrl.hasError('min')\">< {{ configuration.min }}</mat-error>\n        <mat-error *ngIf=\"valueCtrl.hasError('max')\">> {{ configuration.max }}</mat-error>\n    </mat-form-field>\n</form>\n"]}
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-number.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-number/type-number.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-number/type-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {FormControl, FormGroup, ValidatorFn, Validators, FormsModule, ReactiveFormsModule} from '@angular/forms';\nimport {BehaviorSubject, merge} from 'rxjs';\nimport {FilterGroupConditionField} from '../../search/classes/graphql-doctrine.types';\nimport {NaturalDropdownRef} from '../../search/dropdown-container/dropdown-ref';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {possibleComparableOperators, PossibleComparableOpertorKeys} from '../types';\nimport {InvalidWithValueStateMatcher} from '../type-text/type-text.component';\nimport {decimal} from '../../../classes/validators';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatOptionModule} from '@angular/material/core';\nimport {NgFor, NgIf} from '@angular/common';\nimport {MatSelectModule} from '@angular/material/select';\nimport {MatFormFieldModule} from '@angular/material/form-field';\n\nexport interface TypeNumberConfiguration {\n    min?: number | null;\n    max?: number | null;\n    step?: number | null;\n}\n\n@Component({\n    templateUrl: './type-number.component.html',\n    styleUrls: ['./type-number.component.scss'],\n    standalone: true,\n    imports: [\n        FormsModule,\n        ReactiveFormsModule,\n        MatFormFieldModule,\n        MatSelectModule,\n        NgFor,\n        MatOptionModule,\n        MatInputModule,\n        NgIf,\n    ],\n})\nexport class TypeNumberComponent implements DropdownComponent {\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    public readonly configuration: Required<TypeNumberConfiguration>;\n    public readonly operatorCtrl = new FormControl<PossibleComparableOpertorKeys>('equal', {nonNullable: true});\n    public readonly valueCtrl = new FormControl();\n    public readonly matcher = new InvalidWithValueStateMatcher();\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n    public readonly operators = possibleComparableOperators;\n\n    private readonly defaults: Required<TypeNumberConfiguration> = {\n        min: null,\n        max: null,\n        step: null,\n    };\n\n    public constructor(\n        @Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeNumberConfiguration>,\n        protected dropdownRef: NaturalDropdownRef,\n    ) {\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            const rendered = this.getRenderedValue();\n            this.renderedValue.next(rendered);\n        });\n\n        this.initValidators();\n        this.reloadCondition(data.condition);\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        const condition: FilterGroupConditionField = {};\n        condition[this.operatorCtrl.value] = {\n            value: this.valueCtrl.value,\n        };\n\n        return condition;\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    public close(): void {\n        if (this.isValid()) {\n            this.dropdownRef.close({condition: this.getCondition()});\n        } else {\n            this.dropdownRef.close(); // undefined value, discard changes / prevent to add a condition (on new fields\n        }\n    }\n\n    private initValidators(): void {\n        const validators: ValidatorFn[] = [Validators.required];\n        if (this.configuration.min) {\n            validators.push(Validators.min(this.configuration.min));\n        }\n\n        if (this.configuration.max) {\n            validators.push(Validators.max(this.configuration.max));\n        }\n\n        if (this.configuration.step) {\n            const decimals = ('' + this.configuration.step).match(/\\.(\\d+)$/)?.[1] ?? '';\n            const decimalCount = decimals.length;\n            validators.push(decimal(decimalCount));\n        }\n\n        this.valueCtrl.setValidators(validators);\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        for (const operator of this.operators) {\n            const reloadedCondition = condition[operator.key];\n            if (reloadedCondition) {\n                this.operatorCtrl.setValue(operator.key);\n                this.valueCtrl.setValue(reloadedCondition.value);\n            }\n        }\n    }\n\n    private getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (this.valueCtrl.value === null || !operator) {\n            return '';\n        } else {\n            return operator.label + ' ' + this.valueCtrl.value;\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n        <mat-label i18n=\"Mathematical operator < > =\">Opérateur</mat-label>\n        <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n            <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n                {{ item.label }}\n            </mat-option>\n        </mat-select>\n    </mat-form-field>\n\n    <mat-form-field>\n        <mat-label i18n>Valeur</mat-label>\n        <input\n            (keydown.enter)=\"close()\"\n            [errorStateMatcher]=\"matcher\"\n            [formControl]=\"valueCtrl\"\n            [attr.max]=\"configuration.max\"\n            [attr.min]=\"configuration.min\"\n            [required]=\"true\"\n            [step]=\"configuration.step\"\n            matInput\n            type=\"number\"\n        />\n        <mat-error *ngIf=\"valueCtrl.hasError('min')\">< {{ configuration.min }}</mat-error>\n        <mat-error *ngIf=\"valueCtrl.hasError('max')\">> {{ configuration.max }}</mat-error>\n    </mat-form-field>\n</form>\n"]}
@@ -1,18 +1,21 @@
1
1
  import { Component, Inject, ViewChild } from '@angular/core';
2
- import { MatSelectionList } from '@angular/material/list';
2
+ import { MatSelectionList, MatListModule } from '@angular/material/list';
3
3
  import { BehaviorSubject, merge, of } from 'rxjs';
4
4
  import { NATURAL_DROPDOWN_DATA } from '../../search/dropdown-container/dropdown.service';
5
- import { FormControl, FormGroup, Validators } from '@angular/forms';
5
+ import { FormControl, FormGroup, Validators, FormsModule, ReactiveFormsModule } from '@angular/forms';
6
6
  import { NaturalAbstractController } from '../../../classes/abstract-controller';
7
7
  import { map, startWith, takeUntil } from 'rxjs/operators';
8
8
  import { possibleDiscreteOperators } from '../types';
9
+ import { MatOptionModule } from '@angular/material/core';
10
+ import { MatSelectModule } from '@angular/material/select';
11
+ import { MatFormFieldModule } from '@angular/material/form-field';
12
+ import { NgIf, NgFor } from '@angular/common';
9
13
  import * as i0 from "@angular/core";
10
- import * as i1 from "@angular/common";
11
- import * as i2 from "@angular/forms";
12
- import * as i3 from "@angular/material/form-field";
13
- import * as i4 from "@angular/material/list";
14
- import * as i5 from "@angular/material/select";
15
- import * as i6 from "@angular/material/core";
14
+ import * as i1 from "@angular/forms";
15
+ import * as i2 from "@angular/material/form-field";
16
+ import * as i3 from "@angular/material/select";
17
+ import * as i4 from "@angular/material/core";
18
+ import * as i5 from "@angular/material/list";
16
19
  export class TypeSelectComponent extends NaturalAbstractController {
17
20
  constructor(data) {
18
21
  super();
@@ -158,11 +161,20 @@ export class TypeSelectComponent extends NaturalAbstractController {
158
161
  }
159
162
  }
160
163
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: TypeSelectComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
161
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", type: TypeSelectComponent, selector: "ng-component", viewQueries: [{ propertyName: "list", first: true, predicate: MatSelectionList, descendants: true }], usesInheritance: true, ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 7em; margin-right: 1em\" *ngIf=\"configuration.operators\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-selection-list *ngIf=\"requireValueCtrl\" [formControl]=\"valueCtrl\">\n <mat-list-option *ngFor=\"let item of items\" [value]=\"getId(item)\" checkboxPosition=\"before\">\n {{ getDisplay(item) }}\n </mat-list-option>\n </mat-selection-list>\n</form>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i4.MatSelectionList, selector: "mat-selection-list", inputs: ["color", "compareWith", "multiple", "hideSingleSelectionIndicator", "disabled"], outputs: ["selectionChange"], exportAs: ["matSelectionList"] }, { kind: "component", type: i4.MatListOption, selector: "mat-list-option", inputs: ["togglePosition", "checkboxPosition", "color", "value", "selected"], outputs: ["selectedChange"], exportAs: ["matListOption"] }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", exportAs: ["matOption"] }] }); }
164
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", type: TypeSelectComponent, isStandalone: true, selector: "ng-component", viewQueries: [{ propertyName: "list", first: true, predicate: MatSelectionList, descendants: true }], usesInheritance: true, ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 7em; margin-right: 1em\" *ngIf=\"configuration.operators\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-selection-list *ngIf=\"requireValueCtrl\" [formControl]=\"valueCtrl\">\n <mat-list-option *ngFor=\"let item of items\" [value]=\"getId(item)\" checkboxPosition=\"before\">\n {{ getDisplay(item) }}\n </mat-list-option>\n </mat-selection-list>\n</form>\n", dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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: "ngmodule", type: MatSelectModule }, { kind: "component", type: i3.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i4.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: MatOptionModule }, { kind: "ngmodule", type: MatListModule }, { kind: "component", type: i5.MatSelectionList, selector: "mat-selection-list", inputs: ["color", "compareWith", "multiple", "hideSingleSelectionIndicator", "disabled"], outputs: ["selectionChange"], exportAs: ["matSelectionList"] }, { kind: "component", type: i5.MatListOption, selector: "mat-list-option", inputs: ["togglePosition", "checkboxPosition", "color", "value", "selected"], outputs: ["selectedChange"], exportAs: ["matListOption"] }] }); }
162
165
  }
163
166
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: TypeSelectComponent, decorators: [{
164
167
  type: Component,
165
- args: [{ template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 7em; margin-right: 1em\" *ngIf=\"configuration.operators\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-selection-list *ngIf=\"requireValueCtrl\" [formControl]=\"valueCtrl\">\n <mat-list-option *ngFor=\"let item of items\" [value]=\"getId(item)\" checkboxPosition=\"before\">\n {{ getDisplay(item) }}\n </mat-list-option>\n </mat-selection-list>\n</form>\n" }]
168
+ args: [{ standalone: true, imports: [
169
+ FormsModule,
170
+ ReactiveFormsModule,
171
+ NgIf,
172
+ MatFormFieldModule,
173
+ MatSelectModule,
174
+ NgFor,
175
+ MatOptionModule,
176
+ MatListModule,
177
+ ], template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 7em; margin-right: 1em\" *ngIf=\"configuration.operators\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-selection-list *ngIf=\"requireValueCtrl\" [formControl]=\"valueCtrl\">\n <mat-list-option *ngFor=\"let item of items\" [value]=\"getId(item)\" checkboxPosition=\"before\">\n {{ getDisplay(item) }}\n </mat-list-option>\n </mat-selection-list>\n</form>\n" }]
166
178
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
167
179
  type: Inject,
168
180
  args: [NATURAL_DROPDOWN_DATA]
@@ -170,4 +182,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImpor
170
182
  type: ViewChild,
171
183
  args: [MatSelectionList, { static: false }]
172
184
  }] } });
173
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-select/type-select.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-select/type-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, Inject, OnDestroy, ViewChild} from '@angular/core';\nimport {MatSelectionList} from '@angular/material/list';\nimport {BehaviorSubject, merge, Observable, of} from 'rxjs';\nimport {FilterGroupConditionField, Scalar} from '../../search/classes/graphql-doctrine.types';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {FormControl, FormGroup, ValidatorFn, Validators} from '@angular/forms';\nimport {NaturalAbstractController} from '../../../classes/abstract-controller';\nimport {map, startWith, takeUntil} from 'rxjs/operators';\nimport {PossibleDiscreteOperatorKeys, possibleDiscreteOperators} from '../types';\n\nexport type TypeSelectItem =\n    | Scalar\n    | {\n          id: Scalar;\n          name: Scalar;\n      }\n    | {\n          value: Scalar;\n          name: Scalar;\n      };\n\nexport interface TypeSelectConfiguration {\n    items: TypeSelectItem[] | Observable<TypeSelectItem[]>;\n    multiple?: boolean;\n    /**\n     * If true (default) a selectbox allows to choose an operator. Otherwise, the selectbox is hidden and the operator will always be `is`.\n     */\n    operators?: boolean;\n}\n\n@Component({\n    templateUrl: './type-select.component.html',\n})\nexport class TypeSelectComponent\n    extends NaturalAbstractController\n    implements DropdownComponent, AfterViewInit, OnDestroy\n{\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    @ViewChild(MatSelectionList, {static: false}) public list!: MatSelectionList;\n    public requireValueCtrl = false;\n    public readonly operators = possibleDiscreteOperators;\n    public readonly operatorCtrl = new FormControl<PossibleDiscreteOperatorKeys>('is', {nonNullable: true});\n    public readonly valueCtrl = new FormControl();\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n\n    public items: TypeSelectItem[] = [];\n    public readonly configuration: Required<TypeSelectConfiguration>;\n\n    private readonly defaults: Required<TypeSelectConfiguration> = {\n        items: [],\n        multiple: true,\n        operators: true,\n    };\n\n    public constructor(@Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeSelectConfiguration>) {\n        super();\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        // Immediately initValidators and everytime the operator change later\n        this.operatorCtrl.valueChanges.pipe(startWith(null)).subscribe(() => this.initValidators());\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            const rendered = this.getRenderedValue();\n            this.renderedValue.next(rendered);\n        });\n\n        this.reloadCondition(data.condition);\n    }\n\n    public ngAfterViewInit(): void {\n        if (!this.isMultiple() && this.list) {\n            (this.list.selectedOptions as any)._multiple = false;\n        }\n    }\n\n    public getId(item: TypeSelectItem): Scalar {\n        if (typeof item === 'object' && item) {\n            return (item as any).id || (item as any).value;\n        }\n\n        return item as Scalar;\n    }\n\n    public getDisplay(item: TypeSelectItem): Scalar {\n        if (typeof item === 'object' && item && item.name) {\n            return item.name;\n        }\n\n        return item as Scalar;\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        if (!this.isValid()) {\n            return {};\n        }\n\n        const values = this.valueCtrl.value;\n        return this.operatorKeyToCondition(this.operatorCtrl.value, values);\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    private initValidators(): void {\n        const whitelist: PossibleDiscreteOperatorKeys[] = ['is', 'isnot'];\n        this.requireValueCtrl = whitelist.includes(this.operatorCtrl.value);\n        const validators: ValidatorFn[] = this.requireValueCtrl ? [Validators.required] : [];\n\n        this.valueCtrl.setValidators(validators);\n        this.valueCtrl.updateValueAndValidity();\n    }\n\n    private isMultiple(): boolean {\n        return this.configuration.multiple;\n    }\n\n    private getItemById(id: Scalar): TypeSelectItem | undefined {\n        return this.items.find(item => this.getId(item) === id);\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (condition) {\n            const operatorKey = this.conditionToOperatorKey(condition);\n            this.operatorCtrl.setValue(operatorKey);\n        }\n\n        // Always reload value, even without condition because we need to load list of available items in all cases\n        this.reloadValue(condition).subscribe(value => {\n            this.valueCtrl.setValue(value);\n            this.renderedValue.next(this.getRenderedValue());\n        });\n    }\n\n    /**\n     * Reload the value from API (`operatorCtrl` should not be touched)\n     */\n    private reloadValue(condition: FilterGroupConditionField | null): Observable<Scalar[]> {\n        const wantedIds = condition?.in?.values ?? [];\n\n        const items$ = Array.isArray(this.configuration.items)\n            ? of(this.configuration.items)\n            : this.configuration.items;\n\n        return items$.pipe(\n            takeUntil(this.ngUnsubscribe),\n            map(items => {\n                this.items = items;\n\n                // Reload selection, according to possible values from configuration\n                const possibleIds = this.items.map(item => this.getId(item));\n                const wantedAndPossibleIds = wantedIds.filter(id => possibleIds.some(i => i === id));\n\n                return wantedAndPossibleIds;\n            }),\n        );\n    }\n\n    private getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (!operator || !this.isValid()) {\n            return '';\n        }\n\n        const selection =\n            this.valueCtrl.value\n                ?.map((id: Scalar) => {\n                    const item = this.getItemById(id);\n                    if (item) {\n                        return this.getDisplay(item);\n                    }\n                })\n                .join(', ') ?? null;\n\n        return [operator.label, selection].filter(v => v).join(' ');\n    }\n\n    private conditionToOperatorKey(condition: FilterGroupConditionField): PossibleDiscreteOperatorKeys {\n        if (!this.configuration.operators) {\n            return 'is';\n        }\n\n        if (condition.in && !condition.in.not) {\n            return 'is';\n        } else if (condition.in && condition.in.not) {\n            return 'isnot';\n        } else if (condition.null && condition.null.not) {\n            return 'any';\n        } else if (condition.null && !condition.null.not) {\n            return 'none';\n        }\n\n        return 'is';\n    }\n\n    private operatorKeyToCondition(key: PossibleDiscreteOperatorKeys, values: Scalar[]): FilterGroupConditionField {\n        switch (key) {\n            case 'is':\n                return {in: {values: values}};\n            case 'isnot':\n                return {in: {values: values, not: true}};\n            case 'any':\n                return {null: {not: true}};\n            case 'none':\n                return {null: {not: false}};\n            default:\n                throw new Error('Unsupported operator key: ' + key);\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field style=\"max-width: 7em; margin-right: 1em\" *ngIf=\"configuration.operators\">\n        <mat-label i18n=\"Mathematical operator < > =\">Opérateur</mat-label>\n        <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n            <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n                {{ item.label }}\n            </mat-option>\n        </mat-select>\n    </mat-form-field>\n\n    <mat-selection-list *ngIf=\"requireValueCtrl\" [formControl]=\"valueCtrl\">\n        <mat-list-option *ngFor=\"let item of items\" [value]=\"getId(item)\" checkboxPosition=\"before\">\n            {{ getDisplay(item) }}\n        </mat-list-option>\n    </mat-selection-list>\n</form>\n"]}
185
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-select/type-select.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-select/type-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, Inject, OnDestroy, ViewChild} from '@angular/core';\nimport {MatSelectionList, MatListModule} from '@angular/material/list';\nimport {BehaviorSubject, merge, Observable, of} from 'rxjs';\nimport {FilterGroupConditionField, Scalar} from '../../search/classes/graphql-doctrine.types';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {FormControl, FormGroup, ValidatorFn, Validators, FormsModule, ReactiveFormsModule} from '@angular/forms';\nimport {NaturalAbstractController} from '../../../classes/abstract-controller';\nimport {map, startWith, takeUntil} from 'rxjs/operators';\nimport {PossibleDiscreteOperatorKeys, possibleDiscreteOperators} from '../types';\nimport {MatOptionModule} from '@angular/material/core';\nimport {MatSelectModule} from '@angular/material/select';\nimport {MatFormFieldModule} from '@angular/material/form-field';\nimport {NgIf, NgFor} from '@angular/common';\n\nexport type TypeSelectItem =\n    | Scalar\n    | {\n          id: Scalar;\n          name: Scalar;\n      }\n    | {\n          value: Scalar;\n          name: Scalar;\n      };\n\nexport interface TypeSelectConfiguration {\n    items: TypeSelectItem[] | Observable<TypeSelectItem[]>;\n    multiple?: boolean;\n    /**\n     * If true (default) a selectbox allows to choose an operator. Otherwise, the selectbox is hidden and the operator will always be `is`.\n     */\n    operators?: boolean;\n}\n\n@Component({\n    templateUrl: './type-select.component.html',\n    standalone: true,\n    imports: [\n        FormsModule,\n        ReactiveFormsModule,\n        NgIf,\n        MatFormFieldModule,\n        MatSelectModule,\n        NgFor,\n        MatOptionModule,\n        MatListModule,\n    ],\n})\nexport class TypeSelectComponent\n    extends NaturalAbstractController\n    implements DropdownComponent, AfterViewInit, OnDestroy\n{\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    @ViewChild(MatSelectionList, {static: false}) public list!: MatSelectionList;\n    public requireValueCtrl = false;\n    public readonly operators = possibleDiscreteOperators;\n    public readonly operatorCtrl = new FormControl<PossibleDiscreteOperatorKeys>('is', {nonNullable: true});\n    public readonly valueCtrl = new FormControl();\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n\n    public items: TypeSelectItem[] = [];\n    public readonly configuration: Required<TypeSelectConfiguration>;\n\n    private readonly defaults: Required<TypeSelectConfiguration> = {\n        items: [],\n        multiple: true,\n        operators: true,\n    };\n\n    public constructor(@Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeSelectConfiguration>) {\n        super();\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        // Immediately initValidators and everytime the operator change later\n        this.operatorCtrl.valueChanges.pipe(startWith(null)).subscribe(() => this.initValidators());\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            const rendered = this.getRenderedValue();\n            this.renderedValue.next(rendered);\n        });\n\n        this.reloadCondition(data.condition);\n    }\n\n    public ngAfterViewInit(): void {\n        if (!this.isMultiple() && this.list) {\n            (this.list.selectedOptions as any)._multiple = false;\n        }\n    }\n\n    public getId(item: TypeSelectItem): Scalar {\n        if (typeof item === 'object' && item) {\n            return (item as any).id || (item as any).value;\n        }\n\n        return item as Scalar;\n    }\n\n    public getDisplay(item: TypeSelectItem): Scalar {\n        if (typeof item === 'object' && item && item.name) {\n            return item.name;\n        }\n\n        return item as Scalar;\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        if (!this.isValid()) {\n            return {};\n        }\n\n        const values = this.valueCtrl.value;\n        return this.operatorKeyToCondition(this.operatorCtrl.value, values);\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    private initValidators(): void {\n        const whitelist: PossibleDiscreteOperatorKeys[] = ['is', 'isnot'];\n        this.requireValueCtrl = whitelist.includes(this.operatorCtrl.value);\n        const validators: ValidatorFn[] = this.requireValueCtrl ? [Validators.required] : [];\n\n        this.valueCtrl.setValidators(validators);\n        this.valueCtrl.updateValueAndValidity();\n    }\n\n    private isMultiple(): boolean {\n        return this.configuration.multiple;\n    }\n\n    private getItemById(id: Scalar): TypeSelectItem | undefined {\n        return this.items.find(item => this.getId(item) === id);\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (condition) {\n            const operatorKey = this.conditionToOperatorKey(condition);\n            this.operatorCtrl.setValue(operatorKey);\n        }\n\n        // Always reload value, even without condition because we need to load list of available items in all cases\n        this.reloadValue(condition).subscribe(value => {\n            this.valueCtrl.setValue(value);\n            this.renderedValue.next(this.getRenderedValue());\n        });\n    }\n\n    /**\n     * Reload the value from API (`operatorCtrl` should not be touched)\n     */\n    private reloadValue(condition: FilterGroupConditionField | null): Observable<Scalar[]> {\n        const wantedIds = condition?.in?.values ?? [];\n\n        const items$ = Array.isArray(this.configuration.items)\n            ? of(this.configuration.items)\n            : this.configuration.items;\n\n        return items$.pipe(\n            takeUntil(this.ngUnsubscribe),\n            map(items => {\n                this.items = items;\n\n                // Reload selection, according to possible values from configuration\n                const possibleIds = this.items.map(item => this.getId(item));\n                const wantedAndPossibleIds = wantedIds.filter(id => possibleIds.some(i => i === id));\n\n                return wantedAndPossibleIds;\n            }),\n        );\n    }\n\n    private getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (!operator || !this.isValid()) {\n            return '';\n        }\n\n        const selection =\n            this.valueCtrl.value\n                ?.map((id: Scalar) => {\n                    const item = this.getItemById(id);\n                    if (item) {\n                        return this.getDisplay(item);\n                    }\n                })\n                .join(', ') ?? null;\n\n        return [operator.label, selection].filter(v => v).join(' ');\n    }\n\n    private conditionToOperatorKey(condition: FilterGroupConditionField): PossibleDiscreteOperatorKeys {\n        if (!this.configuration.operators) {\n            return 'is';\n        }\n\n        if (condition.in && !condition.in.not) {\n            return 'is';\n        } else if (condition.in && condition.in.not) {\n            return 'isnot';\n        } else if (condition.null && condition.null.not) {\n            return 'any';\n        } else if (condition.null && !condition.null.not) {\n            return 'none';\n        }\n\n        return 'is';\n    }\n\n    private operatorKeyToCondition(key: PossibleDiscreteOperatorKeys, values: Scalar[]): FilterGroupConditionField {\n        switch (key) {\n            case 'is':\n                return {in: {values: values}};\n            case 'isnot':\n                return {in: {values: values, not: true}};\n            case 'any':\n                return {null: {not: true}};\n            case 'none':\n                return {null: {not: false}};\n            default:\n                throw new Error('Unsupported operator key: ' + key);\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field style=\"max-width: 7em; margin-right: 1em\" *ngIf=\"configuration.operators\">\n        <mat-label i18n=\"Mathematical operator < > =\">Opérateur</mat-label>\n        <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n            <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n                {{ item.label }}\n            </mat-option>\n        </mat-select>\n    </mat-form-field>\n\n    <mat-selection-list *ngIf=\"requireValueCtrl\" [formControl]=\"valueCtrl\">\n        <mat-list-option *ngFor=\"let item of items\" [value]=\"getId(item)\" checkboxPosition=\"before\">\n            {{ getDisplay(item) }}\n        </mat-list-option>\n    </mat-selection-list>\n</form>\n"]}
@@ -1,13 +1,15 @@
1
1
  import { Component, Inject } from '@angular/core';
2
- import { FormControl, Validators } from '@angular/forms';
2
+ import { FormControl, Validators, FormsModule, ReactiveFormsModule } from '@angular/forms';
3
3
  import { BehaviorSubject } from 'rxjs';
4
4
  import { NATURAL_DROPDOWN_DATA } from '../../search/dropdown-container/dropdown.service';
5
+ import { NgIf } from '@angular/common';
6
+ import { MatInputModule } from '@angular/material/input';
7
+ import { MatFormFieldModule } from '@angular/material/form-field';
5
8
  import * as i0 from "@angular/core";
6
9
  import * as i1 from "../../search/dropdown-container/dropdown-ref";
7
- import * as i2 from "@angular/common";
8
- import * as i3 from "@angular/forms";
9
- import * as i4 from "@angular/material/form-field";
10
- import * as i5 from "@angular/material/input";
10
+ import * as i2 from "@angular/material/form-field";
11
+ import * as i3 from "@angular/material/input";
12
+ import * as i4 from "@angular/forms";
11
13
  export class InvalidWithValueStateMatcher {
12
14
  isErrorState(control) {
13
15
  return control && control.invalid && control.value;
@@ -48,13 +50,13 @@ export class TypeTextComponent {
48
50
  }
49
51
  }
50
52
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: TypeTextComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }, { token: i1.NaturalDropdownRef }], target: i0.ɵɵFactoryTarget.Component }); }
51
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", type: TypeTextComponent, selector: "ng-component", ngImport: i0, template: "<mat-form-field>\n <mat-label i18n>Valeur</mat-label>\n <input\n (keydown.enter)=\"close()\"\n [errorStateMatcher]=\"matcher\"\n [formControl]=\"formCtrl\"\n [required]=\"true\"\n matInput\n type=\"text\"\n />\n <mat-error *ngIf=\"formCtrl.hasError('required')\">*</mat-error>\n</mat-form-field>\n", styles: [":host input::-webkit-outer-spin-button,:host input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { 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"] }] }); }
53
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", type: TypeTextComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<mat-form-field>\n <mat-label i18n>Valeur</mat-label>\n <input\n (keydown.enter)=\"close()\"\n [errorStateMatcher]=\"matcher\"\n [formControl]=\"formCtrl\"\n [required]=\"true\"\n matInput\n type=\"text\"\n />\n <mat-error *ngIf=\"formCtrl.hasError('required')\">*</mat-error>\n</mat-form-field>\n", styles: [":host input::-webkit-outer-spin-button,:host input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}\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.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
52
54
  }
53
55
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: TypeTextComponent, decorators: [{
54
56
  type: Component,
55
- args: [{ template: "<mat-form-field>\n <mat-label i18n>Valeur</mat-label>\n <input\n (keydown.enter)=\"close()\"\n [errorStateMatcher]=\"matcher\"\n [formControl]=\"formCtrl\"\n [required]=\"true\"\n matInput\n type=\"text\"\n />\n <mat-error *ngIf=\"formCtrl.hasError('required')\">*</mat-error>\n</mat-form-field>\n", styles: [":host input::-webkit-outer-spin-button,:host input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}\n"] }]
57
+ args: [{ standalone: true, imports: [MatFormFieldModule, MatInputModule, FormsModule, ReactiveFormsModule, NgIf], template: "<mat-form-field>\n <mat-label i18n>Valeur</mat-label>\n <input\n (keydown.enter)=\"close()\"\n [errorStateMatcher]=\"matcher\"\n [formControl]=\"formCtrl\"\n [required]=\"true\"\n matInput\n type=\"text\"\n />\n <mat-error *ngIf=\"formCtrl.hasError('required')\">*</mat-error>\n</mat-form-field>\n", styles: [":host input::-webkit-outer-spin-button,:host input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}\n"] }]
56
58
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
57
59
  type: Inject,
58
60
  args: [NATURAL_DROPDOWN_DATA]
59
61
  }] }, { type: i1.NaturalDropdownRef }]; } });
60
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZS10ZXh0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2Ryb3Bkb3duLWNvbXBvbmVudHMvdHlwZS10ZXh0L3R5cGUtdGV4dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9kcm9wZG93bi1jb21wb25lbnRzL3R5cGUtdGV4dC90eXBlLXRleHQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDaEQsT0FBTyxFQUFDLFdBQVcsRUFBRSxVQUFVLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUV2RCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBR3JDLE9BQU8sRUFBQyxxQkFBcUIsRUFBc0IsTUFBTSxrREFBa0QsQ0FBQzs7Ozs7OztBQUc1RyxNQUFNLE9BQU8sNEJBQTRCO0lBQzlCLFlBQVksQ0FBQyxPQUEyQjtRQUMzQyxPQUFPLE9BQU8sSUFBSSxPQUFPLENBQUMsT0FBTyxJQUFJLE9BQU8sQ0FBQyxLQUFLLENBQUM7SUFDdkQsQ0FBQztDQUNKO0FBTUQsTUFBTSxPQUFPLGlCQUFpQjtJQUsxQixZQUNtQyxJQUFnQyxFQUNyRCxXQUErQjtRQUEvQixnQkFBVyxHQUFYLFdBQVcsQ0FBb0I7UUFON0Isa0JBQWEsR0FBRyxJQUFJLGVBQWUsQ0FBUyxFQUFFLENBQUMsQ0FBQztRQUNoRCxhQUFRLEdBQUcsSUFBSSxXQUFXLENBQUMsRUFBRSxFQUFFLEVBQUMsV0FBVyxFQUFFLElBQUksRUFBQyxDQUFDLENBQUM7UUFDcEQsWUFBTyxHQUFHLElBQUksNEJBQTRCLEVBQUUsQ0FBQztRQU16RCxJQUFJLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDekMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssR0FBRyxFQUFFLENBQUMsQ0FBQztRQUM1RSxDQUFDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7UUFFbkQsSUFBSSxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFO1lBQ3ZDLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLEVBQUUsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUMxRDtJQUNMLENBQUM7SUFFTSxZQUFZO1FBQ2YsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFO1lBQ3RCLE9BQU8sRUFBRSxDQUFDO1NBQ2I7UUFFRCxPQUFPLEVBQUMsSUFBSSxFQUFFLEVBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFDLEVBQUMsQ0FBQztJQUNoRCxDQUFDO0lBRU0sT0FBTztRQUNWLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUM7SUFDL0IsQ0FBQztJQUVNLE9BQU87UUFDVixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDO0lBQy9CLENBQUM7SUFFTSxLQUFLO1FBQ1IsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDaEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsRUFBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFlBQVksRUFBRSxFQUFDLENBQUMsQ0FBQztTQUM1RDthQUFNO1lBQ0gsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLCtFQUErRTtTQUM1RztJQUNMLENBQUM7OEdBMUNRLGlCQUFpQixrQkFNZCxxQkFBcUI7a0dBTnhCLGlCQUFpQixvRENuQjlCLGlXQVlBOzsyRkRPYSxpQkFBaUI7a0JBSjdCLFNBQVM7OzswQkFVRCxNQUFNOzJCQUFDLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtGb3JtQ29udHJvbCwgVmFsaWRhdG9yc30gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHtFcnJvclN0YXRlTWF0Y2hlcn0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdH0gZnJvbSAncnhqcyc7XG5pbXBvcnQge0ZpbHRlckdyb3VwQ29uZGl0aW9uRmllbGR9IGZyb20gJy4uLy4uL3NlYXJjaC9jbGFzc2VzL2dyYXBocWwtZG9jdHJpbmUudHlwZXMnO1xuaW1wb3J0IHtOYXR1cmFsRHJvcGRvd25SZWZ9IGZyb20gJy4uLy4uL3NlYXJjaC9kcm9wZG93bi1jb250YWluZXIvZHJvcGRvd24tcmVmJztcbmltcG9ydCB7TkFUVVJBTF9EUk9QRE9XTl9EQVRBLCBOYXR1cmFsRHJvcGRvd25EYXRhfSBmcm9tICcuLi8uLi9zZWFyY2gvZHJvcGRvd24tY29udGFpbmVyL2Ryb3Bkb3duLnNlcnZpY2UnO1xuaW1wb3J0IHtEcm9wZG93bkNvbXBvbmVudH0gZnJvbSAnLi4vLi4vc2VhcmNoL3R5cGVzL2Ryb3Bkb3duLWNvbXBvbmVudCc7XG5cbmV4cG9ydCBjbGFzcyBJbnZhbGlkV2l0aFZhbHVlU3RhdGVNYXRjaGVyIGltcGxlbWVudHMgRXJyb3JTdGF0ZU1hdGNoZXIge1xuICAgIHB1YmxpYyBpc0Vycm9yU3RhdGUoY29udHJvbDogRm9ybUNvbnRyb2wgfCBudWxsKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiBjb250cm9sICYmIGNvbnRyb2wuaW52YWxpZCAmJiBjb250cm9sLnZhbHVlO1xuICAgIH1cbn1cblxuQENvbXBvbmVudCh7XG4gICAgdGVtcGxhdGVVcmw6ICcuL3R5cGUtdGV4dC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vdHlwZS10ZXh0LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFR5cGVUZXh0Q29tcG9uZW50IGltcGxlbWVudHMgRHJvcGRvd25Db21wb25lbnQge1xuICAgIHB1YmxpYyByZWFkb25seSByZW5kZXJlZFZhbHVlID0gbmV3IEJlaGF2aW9yU3ViamVjdDxzdHJpbmc+KCcnKTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgZm9ybUN0cmwgPSBuZXcgRm9ybUNvbnRyb2woJycsIHtub25OdWxsYWJsZTogdHJ1ZX0pO1xuICAgIHB1YmxpYyByZWFkb25seSBtYXRjaGVyID0gbmV3IEludmFsaWRXaXRoVmFsdWVTdGF0ZU1hdGNoZXIoKTtcblxuICAgIHB1YmxpYyBjb25zdHJ1Y3RvcihcbiAgICAgICAgQEluamVjdChOQVRVUkFMX0RST1BET1dOX0RBVEEpIGRhdGE6IE5hdHVyYWxEcm9wZG93bkRhdGE8bmV2ZXI+LFxuICAgICAgICBwcm90ZWN0ZWQgZHJvcGRvd25SZWY6IE5hdHVyYWxEcm9wZG93blJlZixcbiAgICApIHtcbiAgICAgICAgdGhpcy5mb3JtQ3RybC52YWx1ZUNoYW5nZXMuc3Vic2NyaWJlKHZhbHVlID0+IHtcbiAgICAgICAgICAgIHRoaXMucmVuZGVyZWRWYWx1ZS5uZXh0KHZhbHVlID09PSBudWxsID8gJycgOiB0aGlzLmZvcm1DdHJsLnZhbHVlICsgJycpO1xuICAgICAgICB9KTtcblxuICAgICAgICB0aGlzLmZvcm1DdHJsLnNldFZhbGlkYXRvcnMoW1ZhbGlkYXRvcnMucmVxdWlyZWRdKTtcblxuICAgICAgICBpZiAoZGF0YS5jb25kaXRpb24gJiYgZGF0YS5jb25kaXRpb24ubGlrZSkge1xuICAgICAgICAgICAgdGhpcy5mb3JtQ3RybC5zZXRWYWx1ZSgnJyArIGRhdGEuY29uZGl0aW9uLmxpa2UudmFsdWUpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIGdldENvbmRpdGlvbigpOiBGaWx0ZXJHcm91cENvbmRpdGlvbkZpZWxkIHtcbiAgICAgICAgaWYgKCF0aGlzLmZvcm1DdHJsLnZhbHVlKSB7XG4gICAgICAgICAgICByZXR1cm4ge307XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4ge2xpa2U6IHt2YWx1ZTogdGhpcy5mb3JtQ3RybC52YWx1ZX19O1xuICAgIH1cblxuICAgIHB1YmxpYyBpc1ZhbGlkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5mb3JtQ3RybC52YWxpZDtcbiAgICB9XG5cbiAgICBwdWJsaWMgaXNEaXJ0eSgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZm9ybUN0cmwuZGlydHk7XG4gICAgfVxuXG4gICAgcHVibGljIGNsb3NlKCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5pc1ZhbGlkKCkpIHtcbiAgICAgICAgICAgIHRoaXMuZHJvcGRvd25SZWYuY2xvc2Uoe2NvbmRpdGlvbjogdGhpcy5nZXRDb25kaXRpb24oKX0pO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5kcm9wZG93blJlZi5jbG9zZSgpOyAvLyB1bmRlZmluZWQgdmFsdWUsIGRpc2NhcmQgY2hhbmdlcyAvIHByZXZlbnQgdG8gYWRkIGEgY29uZGl0aW9uIChvbiBuZXcgZmllbGRzXG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8bWF0LWZvcm0tZmllbGQ+XG4gICAgPG1hdC1sYWJlbCBpMThuPlZhbGV1cjwvbWF0LWxhYmVsPlxuICAgIDxpbnB1dFxuICAgICAgICAoa2V5ZG93bi5lbnRlcik9XCJjbG9zZSgpXCJcbiAgICAgICAgW2Vycm9yU3RhdGVNYXRjaGVyXT1cIm1hdGNoZXJcIlxuICAgICAgICBbZm9ybUNvbnRyb2xdPVwiZm9ybUN0cmxcIlxuICAgICAgICBbcmVxdWlyZWRdPVwidHJ1ZVwiXG4gICAgICAgIG1hdElucHV0XG4gICAgICAgIHR5cGU9XCJ0ZXh0XCJcbiAgICAvPlxuICAgIDxtYXQtZXJyb3IgKm5nSWY9XCJmb3JtQ3RybC5oYXNFcnJvcigncmVxdWlyZWQnKVwiPio8L21hdC1lcnJvcj5cbjwvbWF0LWZvcm0tZmllbGQ+XG4iXX0=
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZS10ZXh0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2Ryb3Bkb3duLWNvbXBvbmVudHMvdHlwZS10ZXh0L3R5cGUtdGV4dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9kcm9wZG93bi1jb21wb25lbnRzL3R5cGUtdGV4dC90eXBlLXRleHQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDaEQsT0FBTyxFQUFDLFdBQVcsRUFBRSxVQUFVLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFekYsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUdyQyxPQUFPLEVBQUMscUJBQXFCLEVBQXNCLE1BQU0sa0RBQWtELENBQUM7QUFFNUcsT0FBTyxFQUFDLElBQUksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQ3JDLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUN2RCxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQzs7Ozs7O0FBRWhFLE1BQU0sT0FBTyw0QkFBNEI7SUFDOUIsWUFBWSxDQUFDLE9BQTJCO1FBQzNDLE9BQU8sT0FBTyxJQUFJLE9BQU8sQ0FBQyxPQUFPLElBQUksT0FBTyxDQUFDLEtBQUssQ0FBQztJQUN2RCxDQUFDO0NBQ0o7QUFRRCxNQUFNLE9BQU8saUJBQWlCO0lBSzFCLFlBQ21DLElBQWdDLEVBQ3JELFdBQStCO1FBQS9CLGdCQUFXLEdBQVgsV0FBVyxDQUFvQjtRQU43QixrQkFBYSxHQUFHLElBQUksZUFBZSxDQUFTLEVBQUUsQ0FBQyxDQUFDO1FBQ2hELGFBQVEsR0FBRyxJQUFJLFdBQVcsQ0FBQyxFQUFFLEVBQUUsRUFBQyxXQUFXLEVBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQztRQUNwRCxZQUFPLEdBQUcsSUFBSSw0QkFBNEIsRUFBRSxDQUFDO1FBTXpELElBQUksQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUN6QyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxLQUFLLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQzVFLENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztRQUVuRCxJQUFJLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUU7WUFDdkMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQzFEO0lBQ0wsQ0FBQztJQUVNLFlBQVk7UUFDZixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUU7WUFDdEIsT0FBTyxFQUFFLENBQUM7U0FDYjtRQUVELE9BQU8sRUFBQyxJQUFJLEVBQUUsRUFBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUMsRUFBQyxDQUFDO0lBQ2hELENBQUM7SUFFTSxPQUFPO1FBQ1YsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQztJQUMvQixDQUFDO0lBRU0sT0FBTztRQUNWLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUM7SUFDL0IsQ0FBQztJQUVNLEtBQUs7UUFDUixJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUUsRUFBRTtZQUNoQixJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxFQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsWUFBWSxFQUFFLEVBQUMsQ0FBQyxDQUFDO1NBQzVEO2FBQU07WUFDSCxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsK0VBQStFO1NBQzVHO0lBQ0wsQ0FBQzs4R0ExQ1EsaUJBQWlCLGtCQU1kLHFCQUFxQjtrR0FOeEIsaUJBQWlCLHdFQ3hCOUIsaVdBWUEsMEtEVWMsa0JBQWtCLHVZQUFFLGNBQWMsMFdBQUUsV0FBVyxtbkJBQUUsbUJBQW1CLGtOQUFFLElBQUk7OzJGQUUzRSxpQkFBaUI7a0JBTjdCLFNBQVM7aUNBR00sSUFBSSxXQUNQLENBQUMsa0JBQWtCLEVBQUUsY0FBYyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxJQUFJLENBQUM7OzBCQVFoRixNQUFNOzJCQUFDLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtGb3JtQ29udHJvbCwgVmFsaWRhdG9ycywgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7RXJyb3JTdGF0ZU1hdGNoZXJ9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHtCZWhhdmlvclN1YmplY3R9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtGaWx0ZXJHcm91cENvbmRpdGlvbkZpZWxkfSBmcm9tICcuLi8uLi9zZWFyY2gvY2xhc3Nlcy9ncmFwaHFsLWRvY3RyaW5lLnR5cGVzJztcbmltcG9ydCB7TmF0dXJhbERyb3Bkb3duUmVmfSBmcm9tICcuLi8uLi9zZWFyY2gvZHJvcGRvd24tY29udGFpbmVyL2Ryb3Bkb3duLXJlZic7XG5pbXBvcnQge05BVFVSQUxfRFJPUERPV05fREFUQSwgTmF0dXJhbERyb3Bkb3duRGF0YX0gZnJvbSAnLi4vLi4vc2VhcmNoL2Ryb3Bkb3duLWNvbnRhaW5lci9kcm9wZG93bi5zZXJ2aWNlJztcbmltcG9ydCB7RHJvcGRvd25Db21wb25lbnR9IGZyb20gJy4uLy4uL3NlYXJjaC90eXBlcy9kcm9wZG93bi1jb21wb25lbnQnO1xuaW1wb3J0IHtOZ0lmfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtNYXRJbnB1dE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xuaW1wb3J0IHtNYXRGb3JtRmllbGRNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuXG5leHBvcnQgY2xhc3MgSW52YWxpZFdpdGhWYWx1ZVN0YXRlTWF0Y2hlciBpbXBsZW1lbnRzIEVycm9yU3RhdGVNYXRjaGVyIHtcbiAgICBwdWJsaWMgaXNFcnJvclN0YXRlKGNvbnRyb2w6IEZvcm1Db250cm9sIHwgbnVsbCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gY29udHJvbCAmJiBjb250cm9sLmludmFsaWQgJiYgY29udHJvbC52YWx1ZTtcbiAgICB9XG59XG5cbkBDb21wb25lbnQoe1xuICAgIHRlbXBsYXRlVXJsOiAnLi90eXBlLXRleHQuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL3R5cGUtdGV4dC5jb21wb25lbnQuc2NzcyddLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW01hdEZvcm1GaWVsZE1vZHVsZSwgTWF0SW5wdXRNb2R1bGUsIEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlLCBOZ0lmXSxcbn0pXG5leHBvcnQgY2xhc3MgVHlwZVRleHRDb21wb25lbnQgaW1wbGVtZW50cyBEcm9wZG93bkNvbXBvbmVudCB7XG4gICAgcHVibGljIHJlYWRvbmx5IHJlbmRlcmVkVmFsdWUgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PHN0cmluZz4oJycpO1xuICAgIHB1YmxpYyByZWFkb25seSBmb3JtQ3RybCA9IG5ldyBGb3JtQ29udHJvbCgnJywge25vbk51bGxhYmxlOiB0cnVlfSk7XG4gICAgcHVibGljIHJlYWRvbmx5IG1hdGNoZXIgPSBuZXcgSW52YWxpZFdpdGhWYWx1ZVN0YXRlTWF0Y2hlcigpO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KE5BVFVSQUxfRFJPUERPV05fREFUQSkgZGF0YTogTmF0dXJhbERyb3Bkb3duRGF0YTxuZXZlcj4sXG4gICAgICAgIHByb3RlY3RlZCBkcm9wZG93blJlZjogTmF0dXJhbERyb3Bkb3duUmVmLFxuICAgICkge1xuICAgICAgICB0aGlzLmZvcm1DdHJsLnZhbHVlQ2hhbmdlcy5zdWJzY3JpYmUodmFsdWUgPT4ge1xuICAgICAgICAgICAgdGhpcy5yZW5kZXJlZFZhbHVlLm5leHQodmFsdWUgPT09IG51bGwgPyAnJyA6IHRoaXMuZm9ybUN0cmwudmFsdWUgKyAnJyk7XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRoaXMuZm9ybUN0cmwuc2V0VmFsaWRhdG9ycyhbVmFsaWRhdG9ycy5yZXF1aXJlZF0pO1xuXG4gICAgICAgIGlmIChkYXRhLmNvbmRpdGlvbiAmJiBkYXRhLmNvbmRpdGlvbi5saWtlKSB7XG4gICAgICAgICAgICB0aGlzLmZvcm1DdHJsLnNldFZhbHVlKCcnICsgZGF0YS5jb25kaXRpb24ubGlrZS52YWx1ZSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0Q29uZGl0aW9uKCk6IEZpbHRlckdyb3VwQ29uZGl0aW9uRmllbGQge1xuICAgICAgICBpZiAoIXRoaXMuZm9ybUN0cmwudmFsdWUpIHtcbiAgICAgICAgICAgIHJldHVybiB7fTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB7bGlrZToge3ZhbHVlOiB0aGlzLmZvcm1DdHJsLnZhbHVlfX07XG4gICAgfVxuXG4gICAgcHVibGljIGlzVmFsaWQoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLmZvcm1DdHJsLnZhbGlkO1xuICAgIH1cblxuICAgIHB1YmxpYyBpc0RpcnR5KCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5mb3JtQ3RybC5kaXJ0eTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY2xvc2UoKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLmlzVmFsaWQoKSkge1xuICAgICAgICAgICAgdGhpcy5kcm9wZG93blJlZi5jbG9zZSh7Y29uZGl0aW9uOiB0aGlzLmdldENvbmRpdGlvbigpfSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLmRyb3Bkb3duUmVmLmNsb3NlKCk7IC8vIHVuZGVmaW5lZCB2YWx1ZSwgZGlzY2FyZCBjaGFuZ2VzIC8gcHJldmVudCB0byBhZGQgYSBjb25kaXRpb24gKG9uIG5ldyBmaWVsZHNcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxtYXQtZm9ybS1maWVsZD5cbiAgICA8bWF0LWxhYmVsIGkxOG4+VmFsZXVyPC9tYXQtbGFiZWw+XG4gICAgPGlucHV0XG4gICAgICAgIChrZXlkb3duLmVudGVyKT1cImNsb3NlKClcIlxuICAgICAgICBbZXJyb3JTdGF0ZU1hdGNoZXJdPVwibWF0Y2hlclwiXG4gICAgICAgIFtmb3JtQ29udHJvbF09XCJmb3JtQ3RybFwiXG4gICAgICAgIFtyZXF1aXJlZF09XCJ0cnVlXCJcbiAgICAgICAgbWF0SW5wdXRcbiAgICAgICAgdHlwZT1cInRleHRcIlxuICAgIC8+XG4gICAgPG1hdC1lcnJvciAqbmdJZj1cImZvcm1DdHJsLmhhc0Vycm9yKCdyZXF1aXJlZCcpXCI+KjwvbWF0LWVycm9yPlxuPC9tYXQtZm9ybS1maWVsZD5cbiJdfQ==
@@ -1,18 +1,19 @@
1
1
  import { Component, EventEmitter, HostBinding, Inject, Input, Output, } from '@angular/core';
2
2
  import { of, Subject, tap } from 'rxjs';
3
- import { DOCUMENT } from '@angular/common';
3
+ import { DOCUMENT, NgIf, UpperCasePipe } from '@angular/common';
4
+ import { NaturalCapitalizePipe } from '../../common/pipes/capitalize.pipe';
5
+ import { NaturalIconDirective } from '../../icon/icon.directive';
6
+ import { MatIconModule } from '@angular/material/icon';
7
+ import { MatRippleModule } from '@angular/material/core';
8
+ import { NaturalFileDropDirective } from '../file-drop.directive';
4
9
  import * as i0 from "@angular/core";
5
10
  import * as i1 from "../file.service";
6
11
  import * as i2 from "../../alert/alert.service";
7
12
  import * as i3 from "@angular/platform-browser";
8
- import * as i4 from "@angular/common";
9
- import * as i5 from "../../icon/icon.directive";
10
- import * as i6 from "@angular/material/core";
11
- import * as i7 from "@angular/material/icon";
12
- import * as i8 from "../file-drop.directive";
13
- import * as i9 from "../../common/pipes/capitalize.pipe";
13
+ import * as i4 from "@angular/material/core";
14
+ import * as i5 from "@angular/material/icon";
14
15
  // @dynamic
15
- export class FileComponent {
16
+ export class NaturalFileComponent {
16
17
  constructor(naturalFileService, alertService, sanitizer, document) {
17
18
  this.naturalFileService = naturalFileService;
18
19
  this.alertService = alertService;
@@ -120,12 +121,20 @@ export class FileComponent {
120
121
  reader.readAsBinaryString(file);
121
122
  return subject.asObservable();
122
123
  }
123
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: FileComponent, deps: [{ token: i1.NaturalFileService }, { token: i2.NaturalAlertService }, { token: i3.DomSanitizer }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
124
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", type: FileComponent, selector: "natural-file", inputs: { height: "height", action: "action", backgroundSize: "backgroundSize", accept: "accept", uploader: "uploader", model: "model", formCtrl: "formCtrl" }, outputs: { modelChange: "modelChange" }, host: { properties: { "style.height.px": "this.height" } }, usesOnChanges: true, ngImport: i0, template: "<a\n (fileChange)=\"upload($event)\"\n naturalFileDrop\n [selectable]=\"true\"\n [accept]=\"accept\"\n [attr.href]=\"getDownloadLink()\"\n [class.has-action]=\"!!action\"\n [class.suggest-upload]=\"!model && action === 'upload'\"\n [fileSelectionDisabled]=\"action !== 'upload'\"\n [matRippleDisabled]=\"!action\"\n [style.backgroundImage]=\"imagePreview\"\n [style.backgroundSize]=\"backgroundSize\"\n matRipple\n target=\"_blank\"\n>\n <div *ngIf=\"filePreview\" class=\"file-preview\">\n <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\"></mat-icon>\n {{ filePreview | uppercase }}\n </div>\n\n <div class=\"action-overlay\">\n <mat-icon *ngIf=\"action === 'upload'\" [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\"></mat-icon>\n <mat-icon *ngIf=\"action === 'download'\" [size]=\"height * 0.66\" naturalIcon=\"get_app\"></mat-icon>\n {{ action | capitalize }}\n </div>\n</a>\n", styles: [":host{display:flex;flex-direction:row;overflow:hidden;position:relative}:host>a{position:relative;flex:1;background-position:center;background-repeat:no-repeat}:host>a.has-action{cursor:pointer}:host>a.has-action.suggest-upload .action-overlay{opacity:.66}:host>a.has-action:hover .action-overlay,:host>a.has-action.natural-file-over .action-overlay{opacity:1}:host .action-overlay,:host .file-preview{display:flex;flex-direction:column;position:absolute;inset:0;justify-content:center;align-items:center;font-size:36px;line-height:1.3em;text-align:center}:host .action-overlay{opacity:0}:host .action-overlay>div{opacity:0;position:absolute;inset:0;display:flex;justify-content:center;align-items:center}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NaturalIconDirective, selector: "mat-icon[naturalIcon]", inputs: ["naturalIcon", "size"] }, { kind: "directive", type: i6.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i8.NaturalFileDropDirective, selector: ":not([naturalFileSelect])[naturalFileDrop]", outputs: ["fileOver"] }, { kind: "pipe", type: i4.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i9.NaturalCapitalizePipe, name: "capitalize" }] }); }
124
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalFileComponent, deps: [{ token: i1.NaturalFileService }, { token: i2.NaturalAlertService }, { token: i3.DomSanitizer }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
125
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.2", type: NaturalFileComponent, isStandalone: true, selector: "natural-file", inputs: { height: "height", action: "action", backgroundSize: "backgroundSize", accept: "accept", uploader: "uploader", model: "model", formCtrl: "formCtrl" }, outputs: { modelChange: "modelChange" }, host: { properties: { "style.height.px": "this.height" } }, usesOnChanges: true, ngImport: i0, template: "<a\n (fileChange)=\"upload($event)\"\n naturalFileDrop\n [selectable]=\"true\"\n [accept]=\"accept\"\n [attr.href]=\"getDownloadLink()\"\n [class.has-action]=\"!!action\"\n [class.suggest-upload]=\"!model && action === 'upload'\"\n [fileSelectionDisabled]=\"action !== 'upload'\"\n [matRippleDisabled]=\"!action\"\n [style.backgroundImage]=\"imagePreview\"\n [style.backgroundSize]=\"backgroundSize\"\n matRipple\n target=\"_blank\"\n>\n <div *ngIf=\"filePreview\" class=\"file-preview\">\n <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\"></mat-icon>\n {{ filePreview | uppercase }}\n </div>\n\n <div class=\"action-overlay\">\n <mat-icon *ngIf=\"action === 'upload'\" [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\"></mat-icon>\n <mat-icon *ngIf=\"action === 'download'\" [size]=\"height * 0.66\" naturalIcon=\"get_app\"></mat-icon>\n {{ action | capitalize }}\n </div>\n</a>\n", styles: [":host{display:flex;flex-direction:row;overflow:hidden;position:relative}:host>a{position:relative;flex:1;background-position:center;background-repeat:no-repeat}:host>a.has-action{cursor:pointer}:host>a.has-action.suggest-upload .action-overlay{opacity:.66}:host>a.has-action:hover .action-overlay,:host>a.has-action.natural-file-over .action-overlay{opacity:1}:host .action-overlay,:host .file-preview{display:flex;flex-direction:column;position:absolute;inset:0;justify-content:center;align-items:center;font-size:36px;line-height:1.3em;text-align:center}:host .action-overlay{opacity:0}:host .action-overlay>div{opacity:0;position:absolute;inset:0;display:flex;justify-content:center;align-items:center}\n"], dependencies: [{ kind: "directive", type: NaturalFileDropDirective, selector: ":not([naturalFileSelect])[naturalFileDrop]", outputs: ["fileOver"] }, { kind: "ngmodule", type: MatRippleModule }, { kind: "directive", type: i4.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NaturalIconDirective, selector: "mat-icon[naturalIcon]", inputs: ["naturalIcon", "size"] }, { kind: "pipe", type: UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: NaturalCapitalizePipe, name: "capitalize" }] }); }
125
126
  }
126
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: FileComponent, decorators: [{
127
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalFileComponent, decorators: [{
127
128
  type: Component,
128
- args: [{ selector: 'natural-file', template: "<a\n (fileChange)=\"upload($event)\"\n naturalFileDrop\n [selectable]=\"true\"\n [accept]=\"accept\"\n [attr.href]=\"getDownloadLink()\"\n [class.has-action]=\"!!action\"\n [class.suggest-upload]=\"!model && action === 'upload'\"\n [fileSelectionDisabled]=\"action !== 'upload'\"\n [matRippleDisabled]=\"!action\"\n [style.backgroundImage]=\"imagePreview\"\n [style.backgroundSize]=\"backgroundSize\"\n matRipple\n target=\"_blank\"\n>\n <div *ngIf=\"filePreview\" class=\"file-preview\">\n <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\"></mat-icon>\n {{ filePreview | uppercase }}\n </div>\n\n <div class=\"action-overlay\">\n <mat-icon *ngIf=\"action === 'upload'\" [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\"></mat-icon>\n <mat-icon *ngIf=\"action === 'download'\" [size]=\"height * 0.66\" naturalIcon=\"get_app\"></mat-icon>\n {{ action | capitalize }}\n </div>\n</a>\n", styles: [":host{display:flex;flex-direction:row;overflow:hidden;position:relative}:host>a{position:relative;flex:1;background-position:center;background-repeat:no-repeat}:host>a.has-action{cursor:pointer}:host>a.has-action.suggest-upload .action-overlay{opacity:.66}:host>a.has-action:hover .action-overlay,:host>a.has-action.natural-file-over .action-overlay{opacity:1}:host .action-overlay,:host .file-preview{display:flex;flex-direction:column;position:absolute;inset:0;justify-content:center;align-items:center;font-size:36px;line-height:1.3em;text-align:center}:host .action-overlay{opacity:0}:host .action-overlay>div{opacity:0;position:absolute;inset:0;display:flex;justify-content:center;align-items:center}\n"] }]
129
+ args: [{ selector: 'natural-file', standalone: true, imports: [
130
+ NaturalFileDropDirective,
131
+ MatRippleModule,
132
+ NgIf,
133
+ MatIconModule,
134
+ NaturalIconDirective,
135
+ UpperCasePipe,
136
+ NaturalCapitalizePipe,
137
+ ], template: "<a\n (fileChange)=\"upload($event)\"\n naturalFileDrop\n [selectable]=\"true\"\n [accept]=\"accept\"\n [attr.href]=\"getDownloadLink()\"\n [class.has-action]=\"!!action\"\n [class.suggest-upload]=\"!model && action === 'upload'\"\n [fileSelectionDisabled]=\"action !== 'upload'\"\n [matRippleDisabled]=\"!action\"\n [style.backgroundImage]=\"imagePreview\"\n [style.backgroundSize]=\"backgroundSize\"\n matRipple\n target=\"_blank\"\n>\n <div *ngIf=\"filePreview\" class=\"file-preview\">\n <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\"></mat-icon>\n {{ filePreview | uppercase }}\n </div>\n\n <div class=\"action-overlay\">\n <mat-icon *ngIf=\"action === 'upload'\" [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\"></mat-icon>\n <mat-icon *ngIf=\"action === 'download'\" [size]=\"height * 0.66\" naturalIcon=\"get_app\"></mat-icon>\n {{ action | capitalize }}\n </div>\n</a>\n", styles: [":host{display:flex;flex-direction:row;overflow:hidden;position:relative}:host>a{position:relative;flex:1;background-position:center;background-repeat:no-repeat}:host>a.has-action{cursor:pointer}:host>a.has-action.suggest-upload .action-overlay{opacity:.66}:host>a.has-action:hover .action-overlay,:host>a.has-action.natural-file-over .action-overlay{opacity:1}:host .action-overlay,:host .file-preview{display:flex;flex-direction:column;position:absolute;inset:0;justify-content:center;align-items:center;font-size:36px;line-height:1.3em;text-align:center}:host .action-overlay{opacity:0}:host .action-overlay>div{opacity:0;position:absolute;inset:0;display:flex;justify-content:center;align-items:center}\n"] }]
129
138
  }], ctorParameters: function () { return [{ type: i1.NaturalFileService }, { type: i2.NaturalAlertService }, { type: i3.DomSanitizer }, { type: Document, decorators: [{
130
139
  type: Inject,
131
140
  args: [DOCUMENT]
@@ -149,4 +158,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImpor
149
158
  }], modelChange: [{
150
159
  type: Output
151
160
  }] } });
152
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/file/component/file.component.ts","../../../../../../../projects/natural/src/lib/modules/file/component/file.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,YAAY,EACZ,WAAW,EACX,MAAM,EACN,KAAK,EAGL,MAAM,GAET,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAa,EAAE,EAAE,OAAO,EAAE,GAAG,EAAC,MAAM,MAAM,CAAC;AAElD,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;;;;;;;;;;;AAIzC,WAAW;AAMX,MAAM,OAAO,aAAa;IAgDtB,YACqB,kBAAsC,EACtC,YAAiC,EACjC,SAAuB,EACL,QAAkB;QAHpC,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,iBAAY,GAAZ,YAAY,CAAqB;QACjC,cAAS,GAAT,SAAS,CAAc;QACL,aAAQ,GAAR,QAAQ,CAAU;QAnDT,WAAM,GAAG,GAAG,CAAC;QAE7C,WAAM,GAAiC,IAAI,CAAC;QAE5C,mBAAc,GAAG,SAAS,CAAC;QAE3C;;;;;WAKG;QACa,WAAM,GAAG,yFAAyF,CAAC;QAkBnG,UAAK,GAAqB,IAAI,CAAC;QAE/C;;;WAGG;QACa,aAAQ,GAAuC,IAAI,CAAC;QAEpE;;;WAGG;QACuB,gBAAW,GAAG,IAAI,YAAY,EAAa,CAAC;QAE/D,iBAAY,GAAqB,IAAI,CAAC;QACtC,gBAAW,GAAkB,IAAI,CAAC;IAOtC,CAAC;IAEG,QAAQ;QACX,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEM,WAAW,CAAC,OAAsB;QACrC,IAAI,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC,aAAa,KAAK,OAAO,CAAC,KAAK,CAAC,YAAY,EAAE;YAC7E,IAAI,CAAC,WAAW,EAAE,CAAC;SACtB;IACL,CAAC;IAEM,MAAM,CAAC,IAAU;QACpB,IAAI,CAAC,KAAK,GAAG,EAAC,IAAI,EAAE,IAAI,EAAC,CAAC;QAC1B,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACtC;QAED,MAAM,UAAU,GACZ,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAA,YAAY,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE3G,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YAC1B,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;YACpB,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACf,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACtC;YAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,eAAe;QAClB,IAAI,IAAI,CAAC,MAAM,KAAK,UAAU,EAAE;YAC5B,OAAO,IAAI,CAAC;SACf;QAED,OAAO,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/D,CAAC;IAEO,WAAW;QACf,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACb,OAAO;SACV;QAED,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;YAC1C,oCAAoC;YACpC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;gBAC/C,MAAM,OAAO,GAAG,WAAW,GAAG,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,GAAG,UAAU,GAAG,MAAM,GAAG,GAAG,CAAC;gBACjF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAAC,OAAO,CAAC,CAAC;YACzE,CAAC,CAAC,CAAC;SACN;aAAM,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE;YACxB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;SACzD;aAAM,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,KAAK,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE;YAC3D,gEAAgE;YAChE,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC;YACzC,IAAI,CAAC,MAAM,EAAE;gBACT,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;aACjF;YAED,MAAM,GAAG,GAAG,MAAM,CAAC,QAAQ,CAAC;YAC5B,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;YAEpD,iEAAiE;YACjE,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,GAAG,IAAI,GAAG,GAAG,CAAC,QAAQ,GAAG,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,MAAM,CAAC;YAC1F,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAAC,MAAM,GAAG,KAAK,GAAG,GAAG,CAAC,CAAC;SACrF;aAAM,IAAI,IAAI,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,oBAAoB,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,IAAI,EAAE,CAAC,EAAE;YACjG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;SACpD;aAAM,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE;YACvB,eAAe;YACf,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;SAC9F;IACL,CAAC;IAEO,SAAS,CAAC,IAAiB;QAC/B,IAAI,CAAC,IAAI,EAAE;YACP,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;SACjB;QAED,MAAM,OAAO,GAAG,IAAI,OAAO,EAAU,CAAC;QAEtC,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAChC,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC,EAAO,EAAE,EAAE;YACxC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;YACrC,OAAO,CAAC,QAAQ,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAEhC,OAAO,OAAO,CAAC,YAAY,EAAE,CAAC;IAClC,CAAC;8GAjJQ,aAAa,mHAoDV,QAAQ;kGApDX,aAAa,8UCzB1B,09BA0BA;;2FDDa,aAAa;kBALzB,SAAS;+BACI,cAAc;;0BAwDnB,MAAM;2BAAC,QAAQ;4CAnD4B,MAAM;sBAArD,WAAW;uBAAC,iBAAiB;;sBAAG,KAAK;gBAEtB,MAAM;sBAArB,KAAK;gBAEU,cAAc;sBAA7B,KAAK;gBAQU,MAAM;sBAArB,KAAK;gBAgBU,QAAQ;sBAAvB,KAAK;gBAEU,KAAK;sBAApB,KAAK;gBAMU,QAAQ;sBAAvB,KAAK;gBAMoB,WAAW;sBAApC,MAAM","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    HostBinding,\n    Inject,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n} from '@angular/core';\nimport {AbstractControl} from '@angular/forms';\nimport {DomSanitizer, SafeStyle} from '@angular/platform-browser';\nimport {Observable, of, Subject, tap} from 'rxjs';\nimport {NaturalFileService} from '../file.service';\nimport {DOCUMENT} from '@angular/common';\nimport {FileModel} from '../types';\nimport {NaturalAlertService} from '../../alert/alert.service';\n\n// @dynamic\n@Component({\n    selector: 'natural-file',\n    templateUrl: './file.component.html',\n    styleUrls: ['./file.component.scss'],\n})\nexport class FileComponent implements OnInit, OnChanges {\n    @HostBinding('style.height.px') @Input() public height = 250;\n\n    @Input() public action: 'upload' | 'download' | null = null;\n\n    @Input() public backgroundSize = 'contain';\n\n    /**\n     * Comma-separated list of unique file type specifiers. Like the native element\n     * it can be a mix of mime-type and file extensions.\n     *\n     * See https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file#accept\n     */\n    @Input() public accept = 'image/bmp,image/gif,image/jpeg,image/pjpeg,image/png,image/svg+xml,image/svg,image/webp';\n\n    /**\n     * If given it will be called when a new file is selected. The callback should typically upload the file\n     * to the server and link the newly uploaded file to the existing related object.\n     *\n     * The callback **must** be able to run even if the calling component has been destroyed. That means in most\n     * cases you **must** `bind()` the callback explicitly, like so:\n     *\n     * ```html\n     * <natural-file [uploader]=\"myCallback.bind(this)\"></natural-file>\n     * ```\n     *\n     * Also, you probably **should** set a `[formCtrl]` so that the form is updated automatically, instead of doing\n     * it manually within the callback.\n     */\n    @Input() public uploader?: (file: File) => Observable<FileModel>;\n\n    @Input() public model: FileModel | null = null;\n\n    /**\n     * If provided, its value will get updated when the model changes.\n     * But its value is never read, so if you want to set a value use `[model]` instead.\n     */\n    @Input() public formCtrl: AbstractControl | null | undefined = null;\n\n    /**\n     * This **must not** be used to mutate the server, because it is very likely it will never be called if the\n     * human navigates away from the page before the upload is finished. Instead, you should use `[uploader]`.\n     */\n    @Output() public readonly modelChange = new EventEmitter<FileModel>();\n\n    public imagePreview: SafeStyle | null = null;\n    public filePreview: string | null = null;\n\n    public constructor(\n        private readonly naturalFileService: NaturalFileService,\n        private readonly alertService: NaturalAlertService,\n        private readonly sanitizer: DomSanitizer,\n        @Inject(DOCUMENT) private readonly document: Document,\n    ) {}\n\n    public ngOnInit(): void {\n        this.updateImage();\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes.model && changes.model.previousValue !== changes.model.currentValue) {\n            this.updateImage();\n        }\n    }\n\n    public upload(file: File): void {\n        this.model = {file: file};\n        this.updateImage();\n\n        if (this.formCtrl) {\n            this.formCtrl.setValue(this.model);\n        }\n\n        const observable =\n            this.uploader?.(file).pipe(tap(() => this.alertService.info($localize`Mis à jour`))) ?? of(this.model);\n\n        observable.subscribe(result => {\n            this.model = result;\n            if (this.formCtrl) {\n                this.formCtrl.setValue(this.model);\n            }\n\n            this.modelChange.emit(this.model);\n        });\n    }\n\n    public getDownloadLink(): null | string {\n        if (this.action !== 'download') {\n            return null;\n        }\n\n        return this.naturalFileService.getDownloadLink(this.model);\n    }\n\n    private updateImage(): void {\n        this.imagePreview = null;\n        this.filePreview = null;\n        if (!this.model) {\n            return;\n        }\n\n        if (this.model.file?.type.includes('image/')) {\n            // Model from upload (before saving)\n            this.getBase64(this.model.file).subscribe(result => {\n                const content = 'url(data:' + this.model?.file?.type + ';base64,' + result + ')';\n                this.imagePreview = this.sanitizer.bypassSecurityTrustStyle(content);\n            });\n        } else if (this.model.file) {\n            this.filePreview = this.model.file.type.split('/')[1];\n        } else if (this.model.__typename === 'Image' && this.model.id) {\n            // Model image with id, use specific API to render image by size\n            const window = this.document.defaultView;\n            if (!window) {\n                throw new Error('Could not show image preview because `window` is undefined');\n            }\n\n            const loc = window.location;\n            const height = this.height ? '/' + this.height : '';\n\n            // create image url without port to stay compatible with dev mode\n            const image = loc.protocol + '//' + loc.hostname + '/api/image/' + this.model.id + height;\n            this.imagePreview = this.sanitizer.bypassSecurityTrustStyle('url(' + image + ')');\n        } else if (this.model?.mime && ['File', 'AccountingDocument'].includes(this.model.__typename || '')) {\n            this.filePreview = this.model.mime.split('/')[1];\n        } else if (this.model.src) {\n            // external url\n            this.imagePreview = this.sanitizer.bypassSecurityTrustStyle('url(' + this.model.src + ')');\n        }\n    }\n\n    private getBase64(file: File | null): Observable<string> {\n        if (!file) {\n            return of('');\n        }\n\n        const subject = new Subject<string>();\n\n        const reader = new FileReader();\n        reader.addEventListener('load', (ev: any) => {\n            subject.next(btoa(ev.target.result));\n            subject.complete();\n        });\n        reader.readAsBinaryString(file);\n\n        return subject.asObservable();\n    }\n}\n","<a\n    (fileChange)=\"upload($event)\"\n    naturalFileDrop\n    [selectable]=\"true\"\n    [accept]=\"accept\"\n    [attr.href]=\"getDownloadLink()\"\n    [class.has-action]=\"!!action\"\n    [class.suggest-upload]=\"!model && action === 'upload'\"\n    [fileSelectionDisabled]=\"action !== 'upload'\"\n    [matRippleDisabled]=\"!action\"\n    [style.backgroundImage]=\"imagePreview\"\n    [style.backgroundSize]=\"backgroundSize\"\n    matRipple\n    target=\"_blank\"\n>\n    <div *ngIf=\"filePreview\" class=\"file-preview\">\n        <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\"></mat-icon>\n        {{ filePreview | uppercase }}\n    </div>\n\n    <div class=\"action-overlay\">\n        <mat-icon *ngIf=\"action === 'upload'\" [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\"></mat-icon>\n        <mat-icon *ngIf=\"action === 'download'\" [size]=\"height * 0.66\" naturalIcon=\"get_app\"></mat-icon>\n        {{ action | capitalize }}\n    </div>\n</a>\n"]}
161
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/file/component/file.component.ts","../../../../../../../projects/natural/src/lib/modules/file/component/file.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    HostBinding,\n    Inject,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n} from '@angular/core';\nimport {AbstractControl} from '@angular/forms';\nimport {DomSanitizer, SafeStyle} from '@angular/platform-browser';\nimport {Observable, of, Subject, tap} from 'rxjs';\nimport {NaturalFileService} from '../file.service';\nimport {DOCUMENT, NgIf, UpperCasePipe} from '@angular/common';\nimport {FileModel} from '../types';\nimport {NaturalAlertService} from '../../alert/alert.service';\nimport {NaturalCapitalizePipe} from '../../common/pipes/capitalize.pipe';\nimport {NaturalIconDirective} from '../../icon/icon.directive';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatRippleModule} from '@angular/material/core';\nimport {NaturalFileDropDirective} from '../file-drop.directive';\n\n// @dynamic\n@Component({\n    selector: 'natural-file',\n    templateUrl: './file.component.html',\n    styleUrls: ['./file.component.scss'],\n    standalone: true,\n    imports: [\n        NaturalFileDropDirective,\n        MatRippleModule,\n        NgIf,\n        MatIconModule,\n        NaturalIconDirective,\n        UpperCasePipe,\n        NaturalCapitalizePipe,\n    ],\n})\nexport class NaturalFileComponent implements OnInit, OnChanges {\n    @HostBinding('style.height.px') @Input() public height = 250;\n\n    @Input() public action: 'upload' | 'download' | null = null;\n\n    @Input() public backgroundSize = 'contain';\n\n    /**\n     * Comma-separated list of unique file type specifiers. Like the native element\n     * it can be a mix of mime-type and file extensions.\n     *\n     * See https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file#accept\n     */\n    @Input() public accept = 'image/bmp,image/gif,image/jpeg,image/pjpeg,image/png,image/svg+xml,image/svg,image/webp';\n\n    /**\n     * If given it will be called when a new file is selected. The callback should typically upload the file\n     * to the server and link the newly uploaded file to the existing related object.\n     *\n     * The callback **must** be able to run even if the calling component has been destroyed. That means in most\n     * cases you **must** `bind()` the callback explicitly, like so:\n     *\n     * ```html\n     * <natural-file [uploader]=\"myCallback.bind(this)\"></natural-file>\n     * ```\n     *\n     * Also, you probably **should** set a `[formCtrl]` so that the form is updated automatically, instead of doing\n     * it manually within the callback.\n     */\n    @Input() public uploader?: (file: File) => Observable<FileModel>;\n\n    @Input() public model: FileModel | null = null;\n\n    /**\n     * If provided, its value will get updated when the model changes.\n     * But its value is never read, so if you want to set a value use `[model]` instead.\n     */\n    @Input() public formCtrl: AbstractControl | null | undefined = null;\n\n    /**\n     * This **must not** be used to mutate the server, because it is very likely it will never be called if the\n     * human navigates away from the page before the upload is finished. Instead, you should use `[uploader]`.\n     */\n    @Output() public readonly modelChange = new EventEmitter<FileModel>();\n\n    public imagePreview: SafeStyle | null = null;\n    public filePreview: string | null = null;\n\n    public constructor(\n        private readonly naturalFileService: NaturalFileService,\n        private readonly alertService: NaturalAlertService,\n        private readonly sanitizer: DomSanitizer,\n        @Inject(DOCUMENT) private readonly document: Document,\n    ) {}\n\n    public ngOnInit(): void {\n        this.updateImage();\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes.model && changes.model.previousValue !== changes.model.currentValue) {\n            this.updateImage();\n        }\n    }\n\n    public upload(file: File): void {\n        this.model = {file: file};\n        this.updateImage();\n\n        if (this.formCtrl) {\n            this.formCtrl.setValue(this.model);\n        }\n\n        const observable =\n            this.uploader?.(file).pipe(tap(() => this.alertService.info($localize`Mis à jour`))) ?? of(this.model);\n\n        observable.subscribe(result => {\n            this.model = result;\n            if (this.formCtrl) {\n                this.formCtrl.setValue(this.model);\n            }\n\n            this.modelChange.emit(this.model);\n        });\n    }\n\n    public getDownloadLink(): null | string {\n        if (this.action !== 'download') {\n            return null;\n        }\n\n        return this.naturalFileService.getDownloadLink(this.model);\n    }\n\n    private updateImage(): void {\n        this.imagePreview = null;\n        this.filePreview = null;\n        if (!this.model) {\n            return;\n        }\n\n        if (this.model.file?.type.includes('image/')) {\n            // Model from upload (before saving)\n            this.getBase64(this.model.file).subscribe(result => {\n                const content = 'url(data:' + this.model?.file?.type + ';base64,' + result + ')';\n                this.imagePreview = this.sanitizer.bypassSecurityTrustStyle(content);\n            });\n        } else if (this.model.file) {\n            this.filePreview = this.model.file.type.split('/')[1];\n        } else if (this.model.__typename === 'Image' && this.model.id) {\n            // Model image with id, use specific API to render image by size\n            const window = this.document.defaultView;\n            if (!window) {\n                throw new Error('Could not show image preview because `window` is undefined');\n            }\n\n            const loc = window.location;\n            const height = this.height ? '/' + this.height : '';\n\n            // create image url without port to stay compatible with dev mode\n            const image = loc.protocol + '//' + loc.hostname + '/api/image/' + this.model.id + height;\n            this.imagePreview = this.sanitizer.bypassSecurityTrustStyle('url(' + image + ')');\n        } else if (this.model?.mime && ['File', 'AccountingDocument'].includes(this.model.__typename || '')) {\n            this.filePreview = this.model.mime.split('/')[1];\n        } else if (this.model.src) {\n            // external url\n            this.imagePreview = this.sanitizer.bypassSecurityTrustStyle('url(' + this.model.src + ')');\n        }\n    }\n\n    private getBase64(file: File | null): Observable<string> {\n        if (!file) {\n            return of('');\n        }\n\n        const subject = new Subject<string>();\n\n        const reader = new FileReader();\n        reader.addEventListener('load', (ev: any) => {\n            subject.next(btoa(ev.target.result));\n            subject.complete();\n        });\n        reader.readAsBinaryString(file);\n\n        return subject.asObservable();\n    }\n}\n","<a\n    (fileChange)=\"upload($event)\"\n    naturalFileDrop\n    [selectable]=\"true\"\n    [accept]=\"accept\"\n    [attr.href]=\"getDownloadLink()\"\n    [class.has-action]=\"!!action\"\n    [class.suggest-upload]=\"!model && action === 'upload'\"\n    [fileSelectionDisabled]=\"action !== 'upload'\"\n    [matRippleDisabled]=\"!action\"\n    [style.backgroundImage]=\"imagePreview\"\n    [style.backgroundSize]=\"backgroundSize\"\n    matRipple\n    target=\"_blank\"\n>\n    <div *ngIf=\"filePreview\" class=\"file-preview\">\n        <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\"></mat-icon>\n        {{ filePreview | uppercase }}\n    </div>\n\n    <div class=\"action-overlay\">\n        <mat-icon *ngIf=\"action === 'upload'\" [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\"></mat-icon>\n        <mat-icon *ngIf=\"action === 'download'\" [size]=\"height * 0.66\" naturalIcon=\"get_app\"></mat-icon>\n        {{ action | capitalize }}\n    </div>\n</a>\n"]}