@elderbyte/ngx-starter 14.11.0 → 14.12.0-beta

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 (158) hide show
  1. package/_index.scss +2 -0
  2. package/esm2020/lib/components/access-denied/elder-access-denied.component.mjs +3 -4
  3. package/esm2020/lib/components/access-denied/elder-access-denied.module.mjs +4 -8
  4. package/esm2020/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +9 -13
  5. package/esm2020/lib/components/auditing/elder-audit.module.mjs +1 -5
  6. package/esm2020/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +3 -4
  7. package/esm2020/lib/components/button-group/elder-button-group.module.mjs +4 -8
  8. package/esm2020/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +4 -5
  9. package/esm2020/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +5 -6
  10. package/esm2020/lib/components/card-organizer/elder-card-organizer.module.mjs +4 -5
  11. package/esm2020/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +3 -5
  12. package/esm2020/lib/components/cards/elder-card/elder-card.component.mjs +3 -5
  13. package/esm2020/lib/components/cards/elder-card/elder-card.module.mjs +4 -5
  14. package/esm2020/lib/components/connectivity/elder-connectivity.module.mjs +4 -5
  15. package/esm2020/lib/components/containers/elder-containers.module.mjs +4 -8
  16. package/esm2020/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +3 -4
  17. package/esm2020/lib/components/data-transfer/elder-data-transfer.module.mjs +4 -5
  18. package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +3 -4
  19. package/esm2020/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +4 -5
  20. package/esm2020/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +6 -7
  21. package/esm2020/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +5 -6
  22. package/esm2020/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +4 -5
  23. package/esm2020/lib/components/data-view/common/elder-data-common.module.mjs +4 -5
  24. package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +3 -4
  25. package/esm2020/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +4 -5
  26. package/esm2020/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +3 -4
  27. package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +39 -26
  28. package/esm2020/lib/components/data-view/grid/elder-grid.module.mjs +1 -5
  29. package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +4 -5
  30. package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +8 -9
  31. package/esm2020/lib/components/data-view/table/elder-table.module.mjs +4 -5
  32. package/esm2020/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +4 -5
  33. package/esm2020/lib/components/dialogs/elder-dialog.module.mjs +4 -5
  34. package/esm2020/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +4 -5
  35. package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +4 -5
  36. package/esm2020/lib/components/errors/elder-error.module.mjs +4 -8
  37. package/esm2020/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +3 -4
  38. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +4 -5
  39. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +4 -5
  40. package/esm2020/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +3 -4
  41. package/esm2020/lib/components/files/elder-file.module.mjs +4 -5
  42. package/esm2020/lib/components/files/file-upload/file-upload.component.mjs +11 -12
  43. package/esm2020/lib/components/forms/search/elder-search.module.mjs +4 -5
  44. package/esm2020/lib/components/forms/search/search-box/elder-search-box.component.mjs +5 -6
  45. package/esm2020/lib/components/global-search/elder-global-search.component.mjs +4 -5
  46. package/esm2020/lib/components/global-search/elder-global-search.module.mjs +4 -5
  47. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +3 -11
  48. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +4 -8
  49. package/esm2020/lib/components/headers/elder-header/elder-header.component.mjs +4 -5
  50. package/esm2020/lib/components/headers/elder-header.module.mjs +4 -5
  51. package/esm2020/lib/components/i18n/entities/elder-i18n-entities.module.mjs +1 -5
  52. package/esm2020/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +10 -11
  53. package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +8 -9
  54. package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +14 -15
  55. package/esm2020/lib/components/i18n/language/elder-language.module.mjs +1 -5
  56. package/esm2020/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +5 -6
  57. package/esm2020/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs +4 -5
  58. package/esm2020/lib/components/iframes/elder-iframe.module.mjs +1 -5
  59. package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +4 -5
  60. package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +6 -7
  61. package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +4 -5
  62. package/esm2020/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +4 -5
  63. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.module.mjs +1 -5
  64. package/esm2020/lib/components/measures/dimensions-input/elder-dimensions-input.component.mjs +5 -16
  65. package/esm2020/lib/components/measures/elder-measures.module.mjs +1 -5
  66. package/esm2020/lib/components/measures/quantity-input/elder-quantity-input.component.mjs +12 -13
  67. package/esm2020/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +12 -13
  68. package/esm2020/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +4 -5
  69. package/esm2020/lib/components/navigation/nav/elder-nav.module.mjs +4 -5
  70. package/esm2020/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +3 -4
  71. package/esm2020/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +4 -5
  72. package/esm2020/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +3 -5
  73. package/esm2020/lib/components/navigation/toolbar/elder-toolbar.module.mjs +4 -5
  74. package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +6 -7
  75. package/esm2020/lib/components/overlays/elder-overlay-origin.directive.mjs +2 -2
  76. package/esm2020/lib/components/overlays/elder-overlay-trigger.directive.mjs +2 -2
  77. package/esm2020/lib/components/overlays/elder-overlay.component.mjs +2 -2
  78. package/esm2020/lib/components/panels/card-panel/elder-card-panel.component.mjs +3 -4
  79. package/esm2020/lib/components/panels/elder-dialog-panel/elder-dialog-panel.component.mjs +3 -4
  80. package/esm2020/lib/components/panels/elder-panel.module.mjs +3 -7
  81. package/esm2020/lib/components/select/elder-select.module.mjs +4 -5
  82. package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +9 -10
  83. package/esm2020/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +5 -6
  84. package/esm2020/lib/components/select/single/elder-select/elder-select.component.mjs +8 -9
  85. package/esm2020/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +4 -6
  86. package/esm2020/lib/components/select-chip-list/elder-chip-list-select.module.mjs +4 -5
  87. package/esm2020/lib/components/select-list/elder-select-list.module.mjs +4 -5
  88. package/esm2020/lib/components/select-list/select-list/elder-select-list.component.mjs +3 -4
  89. package/esm2020/lib/components/select-list/select-list-item/elder-select-list-item.component.mjs +3 -4
  90. package/esm2020/lib/components/shell/elder-shell.module.mjs +4 -5
  91. package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +4 -5
  92. package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +4 -5
  93. package/esm2020/lib/components/tabs/elder-tab.module.mjs +4 -8
  94. package/esm2020/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +7 -8
  95. package/esm2020/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +9 -10
  96. package/esm2020/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +7 -8
  97. package/esm2020/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +7 -8
  98. package/esm2020/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +12 -13
  99. package/esm2020/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +9 -10
  100. package/esm2020/lib/components/time/elder-time.module.mjs +1 -11
  101. package/esm2020/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +7 -8
  102. package/esm2020/lib/components/toasts/elder-toast.module.mjs +4 -5
  103. package/esm2020/lib/components/toasts/standard-toast/standard-toast.component.mjs +5 -6
  104. package/esm2020/lib/components/url-fragment/elder-url-fragment.module.mjs +1 -5
  105. package/esm2020/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +4 -5
  106. package/fesm2015/elderbyte-ngx-starter.mjs +383 -447
  107. package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
  108. package/fesm2020/elderbyte-ngx-starter.mjs +383 -447
  109. package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
  110. package/lib/components/access-denied/elder-access-denied.module.d.ts +1 -2
  111. package/lib/components/auditing/audited-entity/elder-audited-entity.component.d.ts +1 -2
  112. package/lib/components/auditing/elder-audit.module.d.ts +5 -6
  113. package/lib/components/button-group/elder-button-group.module.d.ts +1 -2
  114. package/lib/components/card-organizer/elder-card-organizer.module.d.ts +3 -4
  115. package/lib/components/cards/elder-card/elder-card.module.d.ts +2 -3
  116. package/lib/components/connectivity/elder-connectivity.module.d.ts +6 -7
  117. package/lib/components/containers/elder-containers.module.d.ts +1 -2
  118. package/lib/components/data-transfer/elder-data-transfer.module.d.ts +4 -5
  119. package/lib/components/data-view/common/elder-data-common.module.d.ts +1 -2
  120. package/lib/components/data-view/grid/elder-grid/elder-grid.component.d.ts +4 -3
  121. package/lib/components/data-view/grid/elder-grid.module.d.ts +6 -7
  122. package/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.d.ts +4 -5
  123. package/lib/components/data-view/table/elder-table.module.d.ts +4 -5
  124. package/lib/components/dialogs/elder-dialog.module.d.ts +2 -3
  125. package/lib/components/errors/elder-error.module.d.ts +1 -2
  126. package/lib/components/expand-toggle-button/elder-expand-toggle-button.module.d.ts +1 -2
  127. package/lib/components/files/elder-file.module.d.ts +6 -7
  128. package/lib/components/forms/search/elder-search.module.d.ts +2 -3
  129. package/lib/components/global-search/elder-global-search.module.d.ts +2 -3
  130. package/lib/components/graph/elder-progress-bar/elder-progress-bar.component.d.ts +1 -8
  131. package/lib/components/graph/elder-progress-bar/elder-progress-bar.module.d.ts +1 -2
  132. package/lib/components/headers/elder-header.module.d.ts +2 -3
  133. package/lib/components/i18n/entities/elder-i18n-entities.module.d.ts +15 -16
  134. package/lib/components/i18n/language/elder-language.module.d.ts +2 -3
  135. package/lib/components/iframes/elder-iframe.module.d.ts +5 -6
  136. package/lib/components/input/autocomplete/elder-autocomplete.module.d.ts +2 -3
  137. package/lib/components/measures/dimensions-input/elder-dimensions-input.component.d.ts +1 -3
  138. package/lib/components/measures/elder-measures.module.d.ts +5 -6
  139. package/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.d.ts +8 -9
  140. package/lib/components/navigation/nav/elder-nav.module.d.ts +1 -2
  141. package/lib/components/navigation/nav/nav-list/elder-nav-list.component.d.ts +1 -3
  142. package/lib/components/navigation/toolbar/elder-toolbar.module.d.ts +8 -9
  143. package/lib/components/panels/elder-panel.module.d.ts +1 -2
  144. package/lib/components/select/elder-select.module.d.ts +10 -11
  145. package/lib/components/select-chip-list/elder-chip-list-select.module.d.ts +3 -4
  146. package/lib/components/select-list/elder-select-list.module.d.ts +1 -2
  147. package/lib/components/shell/elder-shell.module.d.ts +4 -5
  148. package/lib/components/tabs/elder-tab.module.d.ts +1 -2
  149. package/lib/components/time/elder-time.module.d.ts +9 -10
  150. package/lib/components/toasts/elder-toast.module.d.ts +3 -4
  151. package/lib/components/url-fragment/elder-url-fragment.module.d.ts +2 -3
  152. package/package.json +1 -2
  153. package/src/lib/components/graph/elder-progress-bar/elder-progress-bar.component.scss +5 -0
  154. package/src/lib/components/navigation/nav/nav-list/elder-nav-list.component.scss +5 -6
  155. package/src/lib/components/select/single/elder-select/elder-select.component.scss +1 -4
  156. package/theming/_elder-common.scss +32 -0
  157. package/theming/_elder-flex-layout.scss +562 -0
  158. package/theming/_elder-style-fixes.scss +3 -0
@@ -6,9 +6,8 @@ import { map } from 'rxjs/operators';
6
6
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@angular/forms";
9
- import * as i2 from "@angular/flex-layout/flex";
10
- import * as i3 from "../quantity-input/elder-quantity-input.component";
11
- import * as i4 from "@ngx-translate/core";
9
+ import * as i2 from "../quantity-input/elder-quantity-input.component";
10
+ import * as i3 from "@ngx-translate/core";
12
11
  export class ElderDimensionsInputComponent extends TemplateCompositeControl {
13
12
  /***************************************************************************
14
13
  * *
@@ -27,7 +26,6 @@ export class ElderDimensionsInputComponent extends TemplateCompositeControl {
27
26
  this._requiredLength = false;
28
27
  this._requiredWidth = false;
29
28
  this._requiredHeight = false;
30
- this.fxLayout = 'row';
31
29
  /**
32
30
  * Whether the label should always float ('always'), never float ('never')
33
31
  * or float as the user types ('auto'). Defaults to 'auto'.
@@ -60,13 +58,6 @@ export class ElderDimensionsInputComponent extends TemplateCompositeControl {
60
58
  * Properties *
61
59
  * *
62
60
  **************************************************************************/
63
- get fxLayoutGapInternal() {
64
- return this.fxLayoutGap
65
- ? this.fxLayoutGap
66
- : this.fxLayout === 'row'
67
- ? '12px'
68
- : '0px';
69
- }
70
61
  set requiredLength(value) {
71
62
  this._requiredLength = coerceBooleanProperty(value);
72
63
  }
@@ -180,10 +171,10 @@ export class ElderDimensionsInputComponent extends TemplateCompositeControl {
180
171
  }
181
172
  }
182
173
  ElderDimensionsInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderDimensionsInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
183
- ElderDimensionsInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderDimensionsInputComponent, selector: "elder-dimensions-input", inputs: { name: "name", appearance: "appearance", color: "color", placeholderLength: "placeholderLength", placeholderWidth: "placeholderWidth", placeholderHeight: "placeholderHeight", fxLayout: "fxLayout", fxLayoutGap: "fxLayoutGap", floatLabel: "floatLabel", min: "min", max: "max", requiredIgnoreZero: "requiredIgnoreZero", multipleOf: "multipleOf", displayFormat: "displayFormat", requiredLength: "requiredLength", requiredWidth: "requiredWidth", requiredHeight: "requiredHeight", readonly: "readonly", unit: "unit", lengthValue: "lengthValue", widthValue: "widthValue", heightValue: "heightValue" }, outputs: { unitChange: "unitChange", lengthValueChange: "lengthValueChange", widthValueChange: "widthValueChange", heightValueChange: "heightValueChange" }, providers: buildFormIntegrationProviders(ElderDimensionsInputComponent), usesInheritance: true, ngImport: i0, template: "\n<form #form=\"ngForm\" fxFlex\n [fxLayout]=\"fxLayout\"\n [fxLayoutGap]=\"fxLayoutGapInternal\">\n\n <elder-quantity-input fxFlex\n [name]=\"name + '-length'\"\n [quantityValue]=\"lengthValue\"\n (quantityValueChange)=\"onLengthValueChanged($event)\"\n [unit]=\"unit\"\n class=\"elder-form-field-small\"\n [displayFormat]=\"displayFormat\"\n [placeholder]=\"(placeholderLength ? placeholderLength : 'dimensions.length') | translate\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n [requiredIgnoreZero]=\"requiredIgnoreZero\"\n [multipleOf]=\"multipleOf\"\n [min]=\"min\"\n [max]=\"max\"\n [required]=\"requiredLength\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n >\n </elder-quantity-input>\n\n <elder-quantity-input fxFlex\n [name]=\"name + '-width'\"\n [quantityValue]=\"widthValue\"\n (quantityValueChange)=\"onWidthValueChanged($event)\"\n [unit]=\"unit\"\n class=\"elder-form-field-small\"\n [displayFormat]=\"displayFormat\"\n [placeholder]=\"(placeholderWidth ? placeholderWidth : 'dimensions.width') | translate\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n [requiredIgnoreZero]=\"requiredIgnoreZero\"\n [multipleOf]=\"multipleOf\"\n [min]=\"min\"\n [max]=\"max\"\n [required]=\"requiredWidth\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n >\n </elder-quantity-input>\n\n <elder-quantity-input fxFlex\n [name]=\"name + '-height'\"\n [quantityValue]=\"heightValue\"\n (quantityValueChange)=\"onHeightValueChanged($event)\"\n [unit]=\"unit\"\n class=\"elder-form-field-small\"\n [displayFormat]=\"displayFormat\"\n [placeholder]=\"(placeholderHeight ? placeholderHeight : 'dimensions.height') | translate\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n [requiredIgnoreZero]=\"requiredIgnoreZero\"\n [multipleOf]=\"multipleOf\"\n [min]=\"min\"\n [max]=\"max\"\n [required]=\"requiredHeight\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n >\n </elder-quantity-input>\n\n</form>\n\n\n", styles: [""], dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i2.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "directive", type: i2.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "component", type: i3.ElderQuantityInputComponent, selector: "elder-quantity-input", inputs: ["multipleOf", "displayFormat", "requiredIgnoreZero", "quantityNumber", "quantityValue", "unit"], outputs: ["quantityNumberChange", "quantityValueChange", "unitChange"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
174
+ ElderDimensionsInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderDimensionsInputComponent, selector: "elder-dimensions-input", inputs: { name: "name", appearance: "appearance", color: "color", placeholderLength: "placeholderLength", placeholderWidth: "placeholderWidth", placeholderHeight: "placeholderHeight", fxLayoutGap: "fxLayoutGap", floatLabel: "floatLabel", min: "min", max: "max", requiredIgnoreZero: "requiredIgnoreZero", multipleOf: "multipleOf", displayFormat: "displayFormat", requiredLength: "requiredLength", requiredWidth: "requiredWidth", requiredHeight: "requiredHeight", readonly: "readonly", unit: "unit", lengthValue: "lengthValue", widthValue: "widthValue", heightValue: "heightValue" }, outputs: { unitChange: "unitChange", lengthValueChange: "lengthValueChange", widthValueChange: "widthValueChange", heightValueChange: "heightValueChange" }, providers: buildFormIntegrationProviders(ElderDimensionsInputComponent), usesInheritance: true, ngImport: i0, template: "<form #form=\"ngForm\" class=\"layout-row g-md full\">\n <elder-quantity-input [name]=\"name + '-length'\"\n [quantityValue]=\"lengthValue\"\n (quantityValueChange)=\"onLengthValueChanged($event)\"\n [unit]=\"unit\"\n class=\"flex elder-form-field-small\"\n [displayFormat]=\"displayFormat\"\n [placeholder]=\"(placeholderLength ? placeholderLength : 'dimensions.length') | translate\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n [requiredIgnoreZero]=\"requiredIgnoreZero\"\n [multipleOf]=\"multipleOf\"\n [min]=\"min\"\n [max]=\"max\"\n [required]=\"requiredLength\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n >\n </elder-quantity-input>\n\n <elder-quantity-input [name]=\"name + '-width'\"\n [quantityValue]=\"widthValue\"\n (quantityValueChange)=\"onWidthValueChanged($event)\"\n [unit]=\"unit\"\n class=\"flex elder-form-field-small\"\n [displayFormat]=\"displayFormat\"\n [placeholder]=\"(placeholderWidth ? placeholderWidth : 'dimensions.width') | translate\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n [requiredIgnoreZero]=\"requiredIgnoreZero\"\n [multipleOf]=\"multipleOf\"\n [min]=\"min\"\n [max]=\"max\"\n [required]=\"requiredWidth\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n >\n </elder-quantity-input>\n\n <elder-quantity-input [name]=\"name + '-height'\"\n [quantityValue]=\"heightValue\"\n (quantityValueChange)=\"onHeightValueChanged($event)\"\n [unit]=\"unit\"\n class=\"flex elder-form-field-small\"\n [displayFormat]=\"displayFormat\"\n [placeholder]=\"(placeholderHeight ? placeholderHeight : 'dimensions.height') | translate\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n [requiredIgnoreZero]=\"requiredIgnoreZero\"\n [multipleOf]=\"multipleOf\"\n [min]=\"min\"\n [max]=\"max\"\n [required]=\"requiredHeight\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n >\n </elder-quantity-input>\n\n</form>\n\n\n", styles: [""], dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i2.ElderQuantityInputComponent, selector: "elder-quantity-input", inputs: ["multipleOf", "displayFormat", "requiredIgnoreZero", "quantityNumber", "quantityValue", "unit"], outputs: ["quantityNumberChange", "quantityValueChange", "unitChange"] }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
184
175
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderDimensionsInputComponent, decorators: [{
185
176
  type: Component,
186
- args: [{ selector: 'elder-dimensions-input', providers: buildFormIntegrationProviders(ElderDimensionsInputComponent), changeDetection: ChangeDetectionStrategy.OnPush, template: "\n<form #form=\"ngForm\" fxFlex\n [fxLayout]=\"fxLayout\"\n [fxLayoutGap]=\"fxLayoutGapInternal\">\n\n <elder-quantity-input fxFlex\n [name]=\"name + '-length'\"\n [quantityValue]=\"lengthValue\"\n (quantityValueChange)=\"onLengthValueChanged($event)\"\n [unit]=\"unit\"\n class=\"elder-form-field-small\"\n [displayFormat]=\"displayFormat\"\n [placeholder]=\"(placeholderLength ? placeholderLength : 'dimensions.length') | translate\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n [requiredIgnoreZero]=\"requiredIgnoreZero\"\n [multipleOf]=\"multipleOf\"\n [min]=\"min\"\n [max]=\"max\"\n [required]=\"requiredLength\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n >\n </elder-quantity-input>\n\n <elder-quantity-input fxFlex\n [name]=\"name + '-width'\"\n [quantityValue]=\"widthValue\"\n (quantityValueChange)=\"onWidthValueChanged($event)\"\n [unit]=\"unit\"\n class=\"elder-form-field-small\"\n [displayFormat]=\"displayFormat\"\n [placeholder]=\"(placeholderWidth ? placeholderWidth : 'dimensions.width') | translate\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n [requiredIgnoreZero]=\"requiredIgnoreZero\"\n [multipleOf]=\"multipleOf\"\n [min]=\"min\"\n [max]=\"max\"\n [required]=\"requiredWidth\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n >\n </elder-quantity-input>\n\n <elder-quantity-input fxFlex\n [name]=\"name + '-height'\"\n [quantityValue]=\"heightValue\"\n (quantityValueChange)=\"onHeightValueChanged($event)\"\n [unit]=\"unit\"\n class=\"elder-form-field-small\"\n [displayFormat]=\"displayFormat\"\n [placeholder]=\"(placeholderHeight ? placeholderHeight : 'dimensions.height') | translate\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n [requiredIgnoreZero]=\"requiredIgnoreZero\"\n [multipleOf]=\"multipleOf\"\n [min]=\"min\"\n [max]=\"max\"\n [required]=\"requiredHeight\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n >\n </elder-quantity-input>\n\n</form>\n\n\n" }]
177
+ args: [{ selector: 'elder-dimensions-input', providers: buildFormIntegrationProviders(ElderDimensionsInputComponent), changeDetection: ChangeDetectionStrategy.OnPush, template: "<form #form=\"ngForm\" class=\"layout-row g-md full\">\n <elder-quantity-input [name]=\"name + '-length'\"\n [quantityValue]=\"lengthValue\"\n (quantityValueChange)=\"onLengthValueChanged($event)\"\n [unit]=\"unit\"\n class=\"flex elder-form-field-small\"\n [displayFormat]=\"displayFormat\"\n [placeholder]=\"(placeholderLength ? placeholderLength : 'dimensions.length') | translate\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n [requiredIgnoreZero]=\"requiredIgnoreZero\"\n [multipleOf]=\"multipleOf\"\n [min]=\"min\"\n [max]=\"max\"\n [required]=\"requiredLength\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n >\n </elder-quantity-input>\n\n <elder-quantity-input [name]=\"name + '-width'\"\n [quantityValue]=\"widthValue\"\n (quantityValueChange)=\"onWidthValueChanged($event)\"\n [unit]=\"unit\"\n class=\"flex elder-form-field-small\"\n [displayFormat]=\"displayFormat\"\n [placeholder]=\"(placeholderWidth ? placeholderWidth : 'dimensions.width') | translate\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n [requiredIgnoreZero]=\"requiredIgnoreZero\"\n [multipleOf]=\"multipleOf\"\n [min]=\"min\"\n [max]=\"max\"\n [required]=\"requiredWidth\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n >\n </elder-quantity-input>\n\n <elder-quantity-input [name]=\"name + '-height'\"\n [quantityValue]=\"heightValue\"\n (quantityValueChange)=\"onHeightValueChanged($event)\"\n [unit]=\"unit\"\n class=\"flex elder-form-field-small\"\n [displayFormat]=\"displayFormat\"\n [placeholder]=\"(placeholderHeight ? placeholderHeight : 'dimensions.height') | translate\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n [requiredIgnoreZero]=\"requiredIgnoreZero\"\n [multipleOf]=\"multipleOf\"\n [min]=\"min\"\n [max]=\"max\"\n [required]=\"requiredHeight\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n >\n </elder-quantity-input>\n\n</form>\n\n\n" }]
187
178
  }], ctorParameters: function () { return []; }, propDecorators: { name: [{
188
179
  type: Input
189
180
  }], appearance: [{
@@ -196,8 +187,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
196
187
  type: Input
197
188
  }], placeholderHeight: [{
198
189
  type: Input
199
- }], fxLayout: [{
200
- type: Input
201
190
  }], fxLayoutGap: [{
202
191
  type: Input
203
192
  }], floatLabel: [{
@@ -237,4 +226,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
237
226
  }], heightValue: [{
238
227
  type: Input
239
228
  }] } });
240
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-dimensions-input.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/measures/dimensions-input/elder-dimensions-input.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/measures/dimensions-input/elder-dimensions-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, Input, OnInit, Output} from '@angular/core';\nimport {buildFormIntegrationProviders, TemplateCompositeControl} from '../../../common/forms/template-composite-control';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {FloatLabelType, MatFormFieldAppearance} from '@angular/material/form-field';\nimport {Dimensions} from '../model/dimensions';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {Unit} from '../model/unit';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {ThemePalette} from '@angular/material/core';\n\n@Component({\n  selector: 'elder-dimensions-input',\n  templateUrl: './elder-dimensions-input.component.html',\n  styleUrls: ['./elder-dimensions-input.component.scss'],\n  providers: buildFormIntegrationProviders(ElderDimensionsInputComponent),\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderDimensionsInputComponent extends TemplateCompositeControl<Dimensions> implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private _readonly = false;\n  private _requiredLength = false;\n  private _requiredWidth = false;\n  private _requiredHeight = false;\n\n  @Input()\n  public name: string;\n\n  @Input()\n  public appearance: MatFormFieldAppearance;\n\n  @Input()\n  public color: ThemePalette;\n\n  @Input()\n  public placeholderLength: string;\n\n  @Input()\n  public placeholderWidth: string;\n\n  @Input()\n  public placeholderHeight: string;\n\n  @Input()\n  public fxLayout: 'column' | 'row' = 'row';\n\n  @Input()\n  public fxLayoutGap: string;\n\n  /**\n   * Whether the label should always float ('always'), never float ('never')\n   * or float as the user types ('auto'). Defaults to 'auto'.\n   */\n  @Input()\n  public floatLabel: FloatLabelType = 'auto';\n\n  @Input()\n  public min: string | number;\n\n  @Input()\n  public max: string | number;\n\n  /**\n   * Weather the number 0 should result in valid 'required' validation or not.\n   * If true, the number 0 will be ignored as input when the 'required' directive is active.\n   */\n  @Input()\n  public requiredIgnoreZero = false;\n\n  /**\n   * Only allow a multiple of the given number to be a valid quantity.\n   */\n  @Input()\n  public multipleOf: number | number[] = null;\n\n  /**\n   * Display format for the quantity value:\n   * {minIntegerDigits}.{minFractionDigits}-{maxFractionDigits}\n   */\n  @Input()\n  public displayFormat: string = null;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    super();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  ngOnInit(): void {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get fxLayoutGapInternal(): string {\n    return this.fxLayoutGap\n      ? this.fxLayoutGap\n      : this.fxLayout === 'row'\n        ? '12px'\n        : '0px';\n  }\n\n  @Input()\n  public set requiredLength(value: boolean) {\n    this._requiredLength = coerceBooleanProperty(value);\n  }\n\n  public get requiredLength(): boolean {\n    return this._requiredLength;\n  }\n\n  @Input()\n  public set requiredWidth(value: boolean) {\n    this._requiredWidth = coerceBooleanProperty(value);\n  }\n\n  public get requiredWidth(): boolean {\n    return this._requiredWidth;\n  }\n\n  @Input()\n  public set requiredHeight(value: boolean) {\n    this._requiredHeight = coerceBooleanProperty(value);\n  }\n\n  public get requiredHeight(): boolean {\n    return this._requiredHeight;\n  }\n\n  @Input()\n  public set readonly(value: boolean) {\n    this._readonly = coerceBooleanProperty(value);\n  }\n\n  public get readonly(): boolean {\n    return this._readonly;\n  }\n\n  @Output()\n  public get unitChange(): Observable<Unit | null> {\n    return this.valueChange.pipe(\n      map(d => d?.unit)\n    );\n  }\n\n  public get unit(): Unit {\n    return this.value?.unit;\n  }\n\n  @Input()\n  public set unit(unit: Unit) {\n    this.value = Dimensions.from(\n      unit,\n      this.value?.length,\n      this.value?.width,\n      this.value?.height\n    );\n  }\n\n  @Output()\n  public get lengthValueChange(): Observable<number | null> {\n    return this.valueChange.pipe(\n      map(d => d?.length)\n    );\n  }\n\n  public get lengthValue(): number | null {\n    return this.value?.length;\n  }\n\n  @Input()\n  public set lengthValue(lengthValue: number | null) {\n    if (lengthValue === null) {\n      this.value = undefined;\n    }\n    this.value = this.dimensionsOfLength(lengthValue);\n  }\n\n  @Output()\n  public get widthValueChange(): Observable<number | null> {\n    return this.valueChange.pipe(\n      map(d => d?.width)\n    );\n  }\n\n  public get widthValue(): number | null {\n    return this.value?.width;\n  }\n\n  @Input()\n  public set widthValue(widthValue: number | null) {\n    if (widthValue === null) {\n      this.value = undefined;\n    }\n    this.value = this.dimensionsOfWidth(widthValue);\n  }\n\n  @Output()\n  public get heightValueChange(): Observable<number | null> {\n    return this.valueChange.pipe(\n      map(d => d?.height)\n    );\n  }\n\n  public get heightValue(): number | null {\n    return this.value?.height;\n  }\n\n  @Input()\n  public set heightValue(heightValue: number | null) {\n    if (heightValue === null) {\n      this.value = undefined;\n    }\n    this.value = this.dimensionsOfHeight(heightValue);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onLengthValueChanged(value: number): void {\n    this.updateValue(this.dimensionsOfLength(value));\n  }\n\n  public onWidthValueChanged(value: number): void {\n    this.updateValue(this.dimensionsOfWidth(value));\n  }\n\n  public onHeightValueChanged(value: number): void {\n    this.updateValue(this.dimensionsOfHeight(value));\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Protected                                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  protected valuesEquals(a: Dimensions, b: Dimensions): boolean {\n    if (a === b) {\n      return true;\n    }\n    return a?.length === b?.length\n      && a?.width === b?.width\n      && a?.height === b?.height\n      && a?.unit === b?.unit;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private dimensionsOfLength(value: number) {\n    return Dimensions.from(\n      this.unit,\n      value,\n      this.widthValue,\n      this.heightValue\n    );\n  }\n\n  private dimensionsOfWidth(value: number) {\n    return Dimensions.from(\n      this.unit,\n      this.lengthValue,\n      value,\n      this.heightValue\n    );\n  }\n\n  private dimensionsOfHeight(value: number) {\n    return Dimensions.from(\n      this.unit,\n      this.lengthValue,\n      this.widthValue,\n      value\n    );\n  }\n\n\n\n}\n","\n<form #form=\"ngForm\" fxFlex\n      [fxLayout]=\"fxLayout\"\n      [fxLayoutGap]=\"fxLayoutGapInternal\">\n\n    <elder-quantity-input fxFlex\n                          [name]=\"name + '-length'\"\n                          [quantityValue]=\"lengthValue\"\n                          (quantityValueChange)=\"onLengthValueChanged($event)\"\n                          [unit]=\"unit\"\n                          class=\"elder-form-field-small\"\n                          [displayFormat]=\"displayFormat\"\n                          [placeholder]=\"(placeholderLength ? placeholderLength : 'dimensions.length') | translate\"\n                          [floatLabel]=\"floatLabel\"\n                          [appearance]=\"appearance\"\n                          [color]=\"color\"\n                          [requiredIgnoreZero]=\"requiredIgnoreZero\"\n                          [multipleOf]=\"multipleOf\"\n                          [min]=\"min\"\n                          [max]=\"max\"\n                          [required]=\"requiredLength\"\n                          [readonly]=\"readonly\"\n                          [disabled]=\"disabled\"\n    >\n    </elder-quantity-input>\n\n    <elder-quantity-input fxFlex\n                          [name]=\"name + '-width'\"\n                          [quantityValue]=\"widthValue\"\n                          (quantityValueChange)=\"onWidthValueChanged($event)\"\n                          [unit]=\"unit\"\n                          class=\"elder-form-field-small\"\n                          [displayFormat]=\"displayFormat\"\n                          [placeholder]=\"(placeholderWidth ? placeholderWidth : 'dimensions.width') | translate\"\n                          [floatLabel]=\"floatLabel\"\n                          [appearance]=\"appearance\"\n                          [color]=\"color\"\n                          [requiredIgnoreZero]=\"requiredIgnoreZero\"\n                          [multipleOf]=\"multipleOf\"\n                          [min]=\"min\"\n                          [max]=\"max\"\n                          [required]=\"requiredWidth\"\n                          [readonly]=\"readonly\"\n                          [disabled]=\"disabled\"\n    >\n    </elder-quantity-input>\n\n    <elder-quantity-input fxFlex\n                          [name]=\"name + '-height'\"\n                          [quantityValue]=\"heightValue\"\n                          (quantityValueChange)=\"onHeightValueChanged($event)\"\n                          [unit]=\"unit\"\n                          class=\"elder-form-field-small\"\n                          [displayFormat]=\"displayFormat\"\n                          [placeholder]=\"(placeholderHeight ? placeholderHeight : 'dimensions.height') | translate\"\n                          [floatLabel]=\"floatLabel\"\n                          [appearance]=\"appearance\"\n                          [color]=\"color\"\n                          [requiredIgnoreZero]=\"requiredIgnoreZero\"\n                          [multipleOf]=\"multipleOf\"\n                          [min]=\"min\"\n                          [max]=\"max\"\n                          [required]=\"requiredHeight\"\n                          [readonly]=\"readonly\"\n                          [disabled]=\"disabled\"\n    >\n    </elder-quantity-input>\n\n</form>\n\n\n"]}
229
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-dimensions-input.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/measures/dimensions-input/elder-dimensions-input.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/measures/dimensions-input/elder-dimensions-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, Input, OnInit, Output} from '@angular/core';\nimport {buildFormIntegrationProviders, TemplateCompositeControl} from '../../../common/forms/template-composite-control';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {FloatLabelType, MatFormFieldAppearance} from '@angular/material/form-field';\nimport {Dimensions} from '../model/dimensions';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {Unit} from '../model/unit';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {ThemePalette} from '@angular/material/core';\n\n@Component({\n  selector: 'elder-dimensions-input',\n  templateUrl: './elder-dimensions-input.component.html',\n  styleUrls: ['./elder-dimensions-input.component.scss'],\n  providers: buildFormIntegrationProviders(ElderDimensionsInputComponent),\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderDimensionsInputComponent extends TemplateCompositeControl<Dimensions> implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private _readonly = false;\n  private _requiredLength = false;\n  private _requiredWidth = false;\n  private _requiredHeight = false;\n\n  @Input()\n  public name: string;\n\n  @Input()\n  public appearance: MatFormFieldAppearance;\n\n  @Input()\n  public color: ThemePalette;\n\n  @Input()\n  public placeholderLength: string;\n\n  @Input()\n  public placeholderWidth: string;\n\n  @Input()\n  public placeholderHeight: string;\n\n  @Input()\n  public fxLayoutGap: string;\n\n  /**\n   * Whether the label should always float ('always'), never float ('never')\n   * or float as the user types ('auto'). Defaults to 'auto'.\n   */\n  @Input()\n  public floatLabel: FloatLabelType = 'auto';\n\n  @Input()\n  public min: string | number;\n\n  @Input()\n  public max: string | number;\n\n  /**\n   * Weather the number 0 should result in valid 'required' validation or not.\n   * If true, the number 0 will be ignored as input when the 'required' directive is active.\n   */\n  @Input()\n  public requiredIgnoreZero = false;\n\n  /**\n   * Only allow a multiple of the given number to be a valid quantity.\n   */\n  @Input()\n  public multipleOf: number | number[] = null;\n\n  /**\n   * Display format for the quantity value:\n   * {minIntegerDigits}.{minFractionDigits}-{maxFractionDigits}\n   */\n  @Input()\n  public displayFormat: string = null;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    super();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  ngOnInit(): void {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set requiredLength(value: boolean) {\n    this._requiredLength = coerceBooleanProperty(value);\n  }\n\n  public get requiredLength(): boolean {\n    return this._requiredLength;\n  }\n\n  @Input()\n  public set requiredWidth(value: boolean) {\n    this._requiredWidth = coerceBooleanProperty(value);\n  }\n\n  public get requiredWidth(): boolean {\n    return this._requiredWidth;\n  }\n\n  @Input()\n  public set requiredHeight(value: boolean) {\n    this._requiredHeight = coerceBooleanProperty(value);\n  }\n\n  public get requiredHeight(): boolean {\n    return this._requiredHeight;\n  }\n\n  @Input()\n  public set readonly(value: boolean) {\n    this._readonly = coerceBooleanProperty(value);\n  }\n\n  public get readonly(): boolean {\n    return this._readonly;\n  }\n\n  @Output()\n  public get unitChange(): Observable<Unit | null> {\n    return this.valueChange.pipe(\n      map(d => d?.unit)\n    );\n  }\n\n  public get unit(): Unit {\n    return this.value?.unit;\n  }\n\n  @Input()\n  public set unit(unit: Unit) {\n    this.value = Dimensions.from(\n      unit,\n      this.value?.length,\n      this.value?.width,\n      this.value?.height\n    );\n  }\n\n  @Output()\n  public get lengthValueChange(): Observable<number | null> {\n    return this.valueChange.pipe(\n      map(d => d?.length)\n    );\n  }\n\n  public get lengthValue(): number | null {\n    return this.value?.length;\n  }\n\n  @Input()\n  public set lengthValue(lengthValue: number | null) {\n    if (lengthValue === null) {\n      this.value = undefined;\n    }\n    this.value = this.dimensionsOfLength(lengthValue);\n  }\n\n  @Output()\n  public get widthValueChange(): Observable<number | null> {\n    return this.valueChange.pipe(\n      map(d => d?.width)\n    );\n  }\n\n  public get widthValue(): number | null {\n    return this.value?.width;\n  }\n\n  @Input()\n  public set widthValue(widthValue: number | null) {\n    if (widthValue === null) {\n      this.value = undefined;\n    }\n    this.value = this.dimensionsOfWidth(widthValue);\n  }\n\n  @Output()\n  public get heightValueChange(): Observable<number | null> {\n    return this.valueChange.pipe(\n      map(d => d?.height)\n    );\n  }\n\n  public get heightValue(): number | null {\n    return this.value?.height;\n  }\n\n  @Input()\n  public set heightValue(heightValue: number | null) {\n    if (heightValue === null) {\n      this.value = undefined;\n    }\n    this.value = this.dimensionsOfHeight(heightValue);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onLengthValueChanged(value: number): void {\n    this.updateValue(this.dimensionsOfLength(value));\n  }\n\n  public onWidthValueChanged(value: number): void {\n    this.updateValue(this.dimensionsOfWidth(value));\n  }\n\n  public onHeightValueChanged(value: number): void {\n    this.updateValue(this.dimensionsOfHeight(value));\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Protected                                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  protected valuesEquals(a: Dimensions, b: Dimensions): boolean {\n    if (a === b) {\n      return true;\n    }\n    return a?.length === b?.length\n      && a?.width === b?.width\n      && a?.height === b?.height\n      && a?.unit === b?.unit;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private dimensionsOfLength(value: number) {\n    return Dimensions.from(\n      this.unit,\n      value,\n      this.widthValue,\n      this.heightValue\n    );\n  }\n\n  private dimensionsOfWidth(value: number) {\n    return Dimensions.from(\n      this.unit,\n      this.lengthValue,\n      value,\n      this.heightValue\n    );\n  }\n\n  private dimensionsOfHeight(value: number) {\n    return Dimensions.from(\n      this.unit,\n      this.lengthValue,\n      this.widthValue,\n      value\n    );\n  }\n}\n","<form #form=\"ngForm\" class=\"layout-row g-md full\">\n    <elder-quantity-input [name]=\"name + '-length'\"\n                          [quantityValue]=\"lengthValue\"\n                          (quantityValueChange)=\"onLengthValueChanged($event)\"\n                          [unit]=\"unit\"\n                          class=\"flex elder-form-field-small\"\n                          [displayFormat]=\"displayFormat\"\n                          [placeholder]=\"(placeholderLength ? placeholderLength : 'dimensions.length') | translate\"\n                          [floatLabel]=\"floatLabel\"\n                          [appearance]=\"appearance\"\n                          [color]=\"color\"\n                          [requiredIgnoreZero]=\"requiredIgnoreZero\"\n                          [multipleOf]=\"multipleOf\"\n                          [min]=\"min\"\n                          [max]=\"max\"\n                          [required]=\"requiredLength\"\n                          [readonly]=\"readonly\"\n                          [disabled]=\"disabled\"\n    >\n    </elder-quantity-input>\n\n    <elder-quantity-input [name]=\"name + '-width'\"\n                          [quantityValue]=\"widthValue\"\n                          (quantityValueChange)=\"onWidthValueChanged($event)\"\n                          [unit]=\"unit\"\n                          class=\"flex elder-form-field-small\"\n                          [displayFormat]=\"displayFormat\"\n                          [placeholder]=\"(placeholderWidth ? placeholderWidth : 'dimensions.width') | translate\"\n                          [floatLabel]=\"floatLabel\"\n                          [appearance]=\"appearance\"\n                          [color]=\"color\"\n                          [requiredIgnoreZero]=\"requiredIgnoreZero\"\n                          [multipleOf]=\"multipleOf\"\n                          [min]=\"min\"\n                          [max]=\"max\"\n                          [required]=\"requiredWidth\"\n                          [readonly]=\"readonly\"\n                          [disabled]=\"disabled\"\n    >\n    </elder-quantity-input>\n\n    <elder-quantity-input [name]=\"name + '-height'\"\n                          [quantityValue]=\"heightValue\"\n                          (quantityValueChange)=\"onHeightValueChanged($event)\"\n                          [unit]=\"unit\"\n                          class=\"flex elder-form-field-small\"\n                          [displayFormat]=\"displayFormat\"\n                          [placeholder]=\"(placeholderHeight ? placeholderHeight : 'dimensions.height') | translate\"\n                          [floatLabel]=\"floatLabel\"\n                          [appearance]=\"appearance\"\n                          [color]=\"color\"\n                          [requiredIgnoreZero]=\"requiredIgnoreZero\"\n                          [multipleOf]=\"multipleOf\"\n                          [min]=\"min\"\n                          [max]=\"max\"\n                          [required]=\"requiredHeight\"\n                          [readonly]=\"readonly\"\n                          [disabled]=\"disabled\"\n    >\n    </elder-quantity-input>\n\n</form>\n\n\n"]}
@@ -2,7 +2,6 @@ import { NgModule } from '@angular/core';
2
2
  import { CommonModule, DecimalPipe } from '@angular/common';
3
3
  import { MatIconModule } from '@angular/material/icon';
4
4
  import { MatInputModule } from '@angular/material/input';
5
- import { FlexLayoutModule } from '@angular/flex-layout';
6
5
  import { FormsModule } from '@angular/forms';
7
6
  import { RouterModule } from '@angular/router';
8
7
  import { TranslateModule } from '@ngx-translate/core';
@@ -32,7 +31,6 @@ ElderMeasuresModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", ver
32
31
  RouterModule,
33
32
  FormsModule,
34
33
  // Third Party
35
- FlexLayoutModule,
36
34
  TranslateModule,
37
35
  // Angular Material
38
36
  MatIconModule,
@@ -53,7 +51,6 @@ ElderMeasuresModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", ver
53
51
  RouterModule,
54
52
  FormsModule,
55
53
  // Third Party
56
- FlexLayoutModule,
57
54
  TranslateModule,
58
55
  // Angular Material
59
56
  MatIconModule,
@@ -69,7 +66,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
69
66
  RouterModule,
70
67
  FormsModule,
71
68
  // Third Party
72
- FlexLayoutModule,
73
69
  TranslateModule,
74
70
  // Angular Material
75
71
  MatIconModule,
@@ -117,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
117
113
  ],
118
114
  }]
119
115
  }] });
120
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItbWVhc3VyZXMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9tZWFzdXJlcy9lbGRlci1tZWFzdXJlcy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUMsWUFBWSxFQUFFLFdBQVcsRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzFELE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDcEQsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0saURBQWlELENBQUM7QUFDNUYsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFDeEQsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0sbURBQW1ELENBQUM7QUFDN0YsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDM0UsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDbEYsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0scURBQXFELENBQUM7O0FBRXBHLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLHFEQUFxRCxDQUFDO0FBMENwRSxNQUFNLE9BQU8sbUJBQW1COztpSEFBbkIsbUJBQW1CO2tIQUFuQixtQkFBbUIsaUJBbkI1QiwyQkFBMkI7UUFDM0IsaUJBQWlCO1FBQ2pCLDBCQUEwQjtRQUMxQix3QkFBd0I7UUFDeEIsNkJBQTZCO1FBdEI3QixVQUFVO1FBQ1YsWUFBWTtRQUNaLFlBQVk7UUFDWixXQUFXO1FBRVgsY0FBYztRQUNkLGdCQUFnQjtRQUNoQixlQUFlO1FBRWYsbUJBQW1CO1FBQ25CLGFBQWE7UUFDYixjQUFjO1FBRWQsWUFBWTtRQUNaLDBCQUEwQixhQVcxQiwyQkFBMkI7UUFDM0IsaUJBQWlCO1FBQ2pCLDBCQUEwQjtRQUMxQix3QkFBd0I7UUFDeEIsNkJBQTZCO2tIQVFwQixtQkFBbUIsYUFObkI7UUFDVCxXQUFXO1FBQ1gsaUJBQWlCO1FBQ2pCLDBCQUEwQjtLQUMzQjtRQW5DQyxVQUFVO1FBQ1YsWUFBWTtRQUNaLFlBQVk7UUFDWixXQUFXO1FBRVgsY0FBYztRQUNkLGdCQUFnQjtRQUNoQixlQUFlO1FBRWYsbUJBQW1CO1FBQ25CLGFBQWE7UUFDYixjQUFjO1FBRWQsWUFBWTtRQUNaLDBCQUEwQjs0RkF1QmpCLG1CQUFtQjtrQkF4Qy9CLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUVQLFVBQVU7d0JBQ1YsWUFBWTt3QkFDWixZQUFZO3dCQUNaLFdBQVc7d0JBRVgsY0FBYzt3QkFDZCxnQkFBZ0I7d0JBQ2hCLGVBQWU7d0JBRWYsbUJBQW1CO3dCQUNuQixhQUFhO3dCQUNiLGNBQWM7d0JBRWQsWUFBWTt3QkFDWiwwQkFBMEI7cUJBRTNCO29CQUNELFlBQVksRUFBRTt3QkFDWiwyQkFBMkI7d0JBQzNCLGlCQUFpQjt3QkFDakIsMEJBQTBCO3dCQUMxQix3QkFBd0I7d0JBQ3hCLDZCQUE2QjtxQkFDOUI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLDJCQUEyQjt3QkFDM0IsaUJBQWlCO3dCQUNqQiwwQkFBMEI7d0JBQzFCLHdCQUF3Qjt3QkFDeEIsNkJBQTZCO3FCQUM5QjtvQkFDRCxTQUFTLEVBQUU7d0JBQ1QsV0FBVzt3QkFDWCxpQkFBaUI7d0JBQ2pCLDBCQUEwQjtxQkFDM0I7aUJBQ0Y7O0FBSUQ7O0dBRUc7QUFTSCxNQUFNLE9BQU8sbUJBQW1COztpSEFBbkIsbUJBQW1CO2tIQUFuQixtQkFBbUIsWUFkbkIsbUJBQW1CLGFBQW5CLG1CQUFtQjtrSEFjbkIsbUJBQW1CLFlBTjVCLG1CQUFtQixFQVJWLG1CQUFtQjs0RkFjbkIsbUJBQW1CO2tCQVIvQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxtQkFBbUI7cUJBQ3BCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxtQkFBbUI7cUJBQ3BCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbW1vbk1vZHVsZSwgRGVjaW1hbFBpcGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge01hdEljb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHtNYXRJbnB1dE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xuaW1wb3J0IHtGbGV4TGF5b3V0TW9kdWxlfSBmcm9tICdAYW5ndWxhci9mbGV4LWxheW91dCc7XG5pbXBvcnQge0Zvcm1zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge1JvdXRlck1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7VHJhbnNsYXRlTW9kdWxlfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7RWxkZXJRdWFudGl0eUlucHV0Q29tcG9uZW50fSBmcm9tICcuL3F1YW50aXR5LWlucHV0L2VsZGVyLXF1YW50aXR5LWlucHV0LmNvbXBvbmVudCc7XG5pbXBvcnQge0VsZGVyUXVhbnRpdHlQaXBlfSBmcm9tICcuL2VsZGVyLXF1YW50aXR5LnBpcGUnO1xuaW1wb3J0IHtFbGRlckZvcm1zRGlyZWN0aXZlc01vZHVsZX0gZnJvbSAnLi4vZm9ybXMvZGlyZWN0aXZlcy9lbGRlci1mb3Jtcy1kaXJlY3RpdmVzLm1vZHVsZSc7XG5pbXBvcnQge0VsZGVyUXVhbnRpdHlUcmFuc2Zvcm1QaXBlfSBmcm9tICcuL2VsZGVyLXF1YW50aXR5LXRyYW5zZm9ybS5waXBlJztcbmltcG9ydCB7RWxkZXJVbml0U2VsZWN0RGlyZWN0aXZlfSBmcm9tICcuL2RpcmVjdGl2ZXMvZWxkZXItdW5pdC1zZWxlY3QuZGlyZWN0aXZlJztcbmltcG9ydCB7IEVsZGVyRGltZW5zaW9uc0lucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9kaW1lbnNpb25zLWlucHV0L2VsZGVyLWRpbWVuc2lvbnMtaW5wdXQuY29tcG9uZW50JztcblxuZXhwb3J0ICogZnJvbSAnLi9lbGRlci1xdWFudGl0eS5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItcXVhbnRpdHktdHJhbnNmb3JtLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9xdWFudGl0eS1pbnB1dC9lbGRlci1xdWFudGl0eS1pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGRlci11bml0LnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL2VsZGVyLXVuaXQtc2VsZWN0LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2RpbWVuc2lvbnMtaW5wdXQvZWxkZXItZGltZW5zaW9ucy1pbnB1dC5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG5cbiAgICAvLyBBbmd1bGFyXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIFJvdXRlck1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcblxuICAgIC8vIFRoaXJkIFBhcnR5XG4gICAgRmxleExheW91dE1vZHVsZSxcbiAgICBUcmFuc2xhdGVNb2R1bGUsXG5cbiAgICAvLyBBbmd1bGFyIE1hdGVyaWFsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgICBNYXRJbnB1dE1vZHVsZSxcblxuICAgIC8vIEVsZGVyQnl0ZVxuICAgIEVsZGVyRm9ybXNEaXJlY3RpdmVzTW9kdWxlXG5cbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgRWxkZXJRdWFudGl0eUlucHV0Q29tcG9uZW50LFxuICAgIEVsZGVyUXVhbnRpdHlQaXBlLFxuICAgIEVsZGVyUXVhbnRpdHlUcmFuc2Zvcm1QaXBlLFxuICAgIEVsZGVyVW5pdFNlbGVjdERpcmVjdGl2ZSxcbiAgICBFbGRlckRpbWVuc2lvbnNJbnB1dENvbXBvbmVudFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgRWxkZXJRdWFudGl0eUlucHV0Q29tcG9uZW50LFxuICAgIEVsZGVyUXVhbnRpdHlQaXBlLFxuICAgIEVsZGVyUXVhbnRpdHlUcmFuc2Zvcm1QaXBlLFxuICAgIEVsZGVyVW5pdFNlbGVjdERpcmVjdGl2ZSxcbiAgICBFbGRlckRpbWVuc2lvbnNJbnB1dENvbXBvbmVudFxuICBdLFxuICBwcm92aWRlcnM6IFtcbiAgICBEZWNpbWFsUGlwZSxcbiAgICBFbGRlclF1YW50aXR5UGlwZSxcbiAgICBFbGRlclF1YW50aXR5VHJhbnNmb3JtUGlwZVxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBFbGRlck1lYXN1cmVzTW9kdWxlIHtcbn1cblxuLyoqXG4gKiBAZGVwcmVjYXRlZCBQbGVhc2Ugc3dpdGNoIHRvIHRoZSBFbGRlck1lYXN1cmVzTW9kdWxlXG4gKi9cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBFbGRlck1lYXN1cmVzTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBFbGRlck1lYXN1cmVzTW9kdWxlXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyUXVhbnRpdHlNb2R1bGUge1xufVxuIl19
116
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItbWVhc3VyZXMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9tZWFzdXJlcy9lbGRlci1tZWFzdXJlcy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUMsWUFBWSxFQUFFLFdBQVcsRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzFELE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDcEQsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0saURBQWlELENBQUM7QUFDNUYsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFDeEQsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0sbURBQW1ELENBQUM7QUFDN0YsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDM0UsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDbEYsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0scURBQXFELENBQUM7O0FBRXBHLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLHFEQUFxRCxDQUFDO0FBeUNwRSxNQUFNLE9BQU8sbUJBQW1COztpSEFBbkIsbUJBQW1CO2tIQUFuQixtQkFBbUIsaUJBbkI1QiwyQkFBMkI7UUFDM0IsaUJBQWlCO1FBQ2pCLDBCQUEwQjtRQUMxQix3QkFBd0I7UUFDeEIsNkJBQTZCO1FBckI3QixVQUFVO1FBQ1YsWUFBWTtRQUNaLFlBQVk7UUFDWixXQUFXO1FBRVgsY0FBYztRQUNkLGVBQWU7UUFFZixtQkFBbUI7UUFDbkIsYUFBYTtRQUNiLGNBQWM7UUFFZCxZQUFZO1FBQ1osMEJBQTBCLGFBVzFCLDJCQUEyQjtRQUMzQixpQkFBaUI7UUFDakIsMEJBQTBCO1FBQzFCLHdCQUF3QjtRQUN4Qiw2QkFBNkI7a0hBUXBCLG1CQUFtQixhQU5uQjtRQUNULFdBQVc7UUFDWCxpQkFBaUI7UUFDakIsMEJBQTBCO0tBQzNCO1FBbENDLFVBQVU7UUFDVixZQUFZO1FBQ1osWUFBWTtRQUNaLFdBQVc7UUFFWCxjQUFjO1FBQ2QsZUFBZTtRQUVmLG1CQUFtQjtRQUNuQixhQUFhO1FBQ2IsY0FBYztRQUVkLFlBQVk7UUFDWiwwQkFBMEI7NEZBdUJqQixtQkFBbUI7a0JBdkMvQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFFUCxVQUFVO3dCQUNWLFlBQVk7d0JBQ1osWUFBWTt3QkFDWixXQUFXO3dCQUVYLGNBQWM7d0JBQ2QsZUFBZTt3QkFFZixtQkFBbUI7d0JBQ25CLGFBQWE7d0JBQ2IsY0FBYzt3QkFFZCxZQUFZO3dCQUNaLDBCQUEwQjtxQkFFM0I7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLDJCQUEyQjt3QkFDM0IsaUJBQWlCO3dCQUNqQiwwQkFBMEI7d0JBQzFCLHdCQUF3Qjt3QkFDeEIsNkJBQTZCO3FCQUM5QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsMkJBQTJCO3dCQUMzQixpQkFBaUI7d0JBQ2pCLDBCQUEwQjt3QkFDMUIsd0JBQXdCO3dCQUN4Qiw2QkFBNkI7cUJBQzlCO29CQUNELFNBQVMsRUFBRTt3QkFDVCxXQUFXO3dCQUNYLGlCQUFpQjt3QkFDakIsMEJBQTBCO3FCQUMzQjtpQkFDRjs7QUFJRDs7R0FFRztBQVNILE1BQU0sT0FBTyxtQkFBbUI7O2lIQUFuQixtQkFBbUI7a0hBQW5CLG1CQUFtQixZQWRuQixtQkFBbUIsYUFBbkIsbUJBQW1CO2tIQWNuQixtQkFBbUIsWUFONUIsbUJBQW1CLEVBUlYsbUJBQW1COzRGQWNuQixtQkFBbUI7a0JBUi9CLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLG1CQUFtQjtxQkFDcEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Q29tbW9uTW9kdWxlLCBEZWNpbWFsUGlwZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7TWF0SWNvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQge01hdElucHV0TW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQge0Zvcm1zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge1JvdXRlck1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7VHJhbnNsYXRlTW9kdWxlfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7RWxkZXJRdWFudGl0eUlucHV0Q29tcG9uZW50fSBmcm9tICcuL3F1YW50aXR5LWlucHV0L2VsZGVyLXF1YW50aXR5LWlucHV0LmNvbXBvbmVudCc7XG5pbXBvcnQge0VsZGVyUXVhbnRpdHlQaXBlfSBmcm9tICcuL2VsZGVyLXF1YW50aXR5LnBpcGUnO1xuaW1wb3J0IHtFbGRlckZvcm1zRGlyZWN0aXZlc01vZHVsZX0gZnJvbSAnLi4vZm9ybXMvZGlyZWN0aXZlcy9lbGRlci1mb3Jtcy1kaXJlY3RpdmVzLm1vZHVsZSc7XG5pbXBvcnQge0VsZGVyUXVhbnRpdHlUcmFuc2Zvcm1QaXBlfSBmcm9tICcuL2VsZGVyLXF1YW50aXR5LXRyYW5zZm9ybS5waXBlJztcbmltcG9ydCB7RWxkZXJVbml0U2VsZWN0RGlyZWN0aXZlfSBmcm9tICcuL2RpcmVjdGl2ZXMvZWxkZXItdW5pdC1zZWxlY3QuZGlyZWN0aXZlJztcbmltcG9ydCB7IEVsZGVyRGltZW5zaW9uc0lucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9kaW1lbnNpb25zLWlucHV0L2VsZGVyLWRpbWVuc2lvbnMtaW5wdXQuY29tcG9uZW50JztcblxuZXhwb3J0ICogZnJvbSAnLi9lbGRlci1xdWFudGl0eS5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItcXVhbnRpdHktdHJhbnNmb3JtLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9xdWFudGl0eS1pbnB1dC9lbGRlci1xdWFudGl0eS1pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGRlci11bml0LnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL2VsZGVyLXVuaXQtc2VsZWN0LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2RpbWVuc2lvbnMtaW5wdXQvZWxkZXItZGltZW5zaW9ucy1pbnB1dC5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG5cbiAgICAvLyBBbmd1bGFyXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIFJvdXRlck1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcblxuICAgIC8vIFRoaXJkIFBhcnR5XG4gICAgVHJhbnNsYXRlTW9kdWxlLFxuXG4gICAgLy8gQW5ndWxhciBNYXRlcmlhbFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgTWF0SW5wdXRNb2R1bGUsXG5cbiAgICAvLyBFbGRlckJ5dGVcbiAgICBFbGRlckZvcm1zRGlyZWN0aXZlc01vZHVsZVxuXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEVsZGVyUXVhbnRpdHlJbnB1dENvbXBvbmVudCxcbiAgICBFbGRlclF1YW50aXR5UGlwZSxcbiAgICBFbGRlclF1YW50aXR5VHJhbnNmb3JtUGlwZSxcbiAgICBFbGRlclVuaXRTZWxlY3REaXJlY3RpdmUsXG4gICAgRWxkZXJEaW1lbnNpb25zSW5wdXRDb21wb25lbnRcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEVsZGVyUXVhbnRpdHlJbnB1dENvbXBvbmVudCxcbiAgICBFbGRlclF1YW50aXR5UGlwZSxcbiAgICBFbGRlclF1YW50aXR5VHJhbnNmb3JtUGlwZSxcbiAgICBFbGRlclVuaXRTZWxlY3REaXJlY3RpdmUsXG4gICAgRWxkZXJEaW1lbnNpb25zSW5wdXRDb21wb25lbnRcbiAgXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAgRGVjaW1hbFBpcGUsXG4gICAgRWxkZXJRdWFudGl0eVBpcGUsXG4gICAgRWxkZXJRdWFudGl0eVRyYW5zZm9ybVBpcGVcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJNZWFzdXJlc01vZHVsZSB7XG59XG5cbi8qKlxuICogQGRlcHJlY2F0ZWQgUGxlYXNlIHN3aXRjaCB0byB0aGUgRWxkZXJNZWFzdXJlc01vZHVsZVxuICovXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgRWxkZXJNZWFzdXJlc01vZHVsZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgRWxkZXJNZWFzdXJlc01vZHVsZVxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBFbGRlclF1YW50aXR5TW9kdWxlIHtcbn1cbiJdfQ==
@@ -11,16 +11,15 @@ import * as i0 from "@angular/core";
11
11
  import * as i1 from "../elder-unit.service";
12
12
  import * as i2 from "@angular/common";
13
13
  import * as i3 from "@angular/forms";
14
- import * as i4 from "@angular/flex-layout/flex";
15
- import * as i5 from "@angular/material/icon";
16
- import * as i6 from "@angular/material/form-field";
17
- import * as i7 from "@angular/material/input";
18
- import * as i8 from "../../forms/directives/elder-min.directive";
19
- import * as i9 from "../../forms/directives/elder-max.directive";
20
- import * as i10 from "../../forms/directives/elder-form-field-no-spinner.directive";
21
- import * as i11 from "../../forms/directives/validation/elder-required-ignore-zero.validator";
22
- import * as i12 from "../../forms/directives/validation/elder-multiple-of.validator";
23
- import * as i13 from "@ngx-translate/core";
14
+ import * as i4 from "@angular/material/icon";
15
+ import * as i5 from "@angular/material/form-field";
16
+ import * as i6 from "@angular/material/input";
17
+ import * as i7 from "../../forms/directives/elder-min.directive";
18
+ import * as i8 from "../../forms/directives/elder-max.directive";
19
+ import * as i9 from "../../forms/directives/elder-form-field-no-spinner.directive";
20
+ import * as i10 from "../../forms/directives/validation/elder-required-ignore-zero.validator";
21
+ import * as i11 from "../../forms/directives/validation/elder-multiple-of.validator";
22
+ import * as i12 from "@ngx-translate/core";
24
23
  export class ElderQuantityInputComponent extends FormFieldBaseComponent {
25
24
  /***************************************************************************
26
25
  * *
@@ -161,10 +160,10 @@ export class ElderQuantityInputComponent extends FormFieldBaseComponent {
161
160
  }
162
161
  }
163
162
  ElderQuantityInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderQuantityInputComponent, deps: [{ token: i1.ElderUnitService }, { token: i2.DecimalPipe }], target: i0.ɵɵFactoryTarget.Component });
164
- ElderQuantityInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderQuantityInputComponent, selector: "elder-quantity-input", inputs: { multipleOf: "multipleOf", displayFormat: "displayFormat", requiredIgnoreZero: "requiredIgnoreZero", quantityNumber: "quantityNumber", quantityValue: "quantityValue", unit: "unit" }, outputs: { quantityNumberChange: "quantityNumberChange", quantityValueChange: "quantityValueChange", unitChange: "unitChange" }, providers: buildFormIntegrationProviders(ElderQuantityInputComponent), viewQueries: [{ propertyName: "quantityInput", first: true, predicate: ["quantityInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "\n<mat-form-field fxFlex\n class=\"elder-std-form-field\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n <input matInput fxFlex elderNoSpinner class=\"elder-quantity-input\"\n type=\"number\"\n #quantityInput=\"matInput\"\n\n [name]=\"name + '-inner'\"\n [ngModel]=\"formattedValue$ | async\" #myModel=\"ngModel\"\n (ngModelChange)=\"onQuantityValueChanged($event)\"\n\n [elderRequiredIgnoreZeroValidator]=\"requiredIgnoreZero\"\n [elderMultipleOf]=\"multipleOf\"\n [placeholder]=\"(placeholder ? placeholder : 'context.quantity') | translate\"\n [min]=\"min\" [max]=\"max\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n\n >\n\n <span matPrefix *ngIf=\"showIcon && icon\">\n <mat-icon [inline]=\"true\">{{icon}}</mat-icon>\n </span>\n\n <span matSuffix>&nbsp;\n <span>{{unitSymbol$ | async}}</span>\n </span>\n\n <mat-hint *ngIf=\"showHint\" align=\"end\">\n <span *ngIf=\"hint\">{{hint}}</span>\n </mat-hint>\n\n <mat-error *ngIf=\"myModel.errors?.required\">\n {{ 'validations.required' | translate }}\n </mat-error>\n\n <mat-error *ngIf=\"myModel.errors?.min || myModel.errors?.max\">\n <span *ngIf=\"min && max\">\n >= {{min}} & <= {{max}}\n </span>\n\n <span *ngIf=\"min && !max\">\n >= {{min}}\n </span>\n\n <span *ngIf=\"!min && max\">\n <= {{max}}\n </span>\n </mat-error>\n\n <mat-error *ngIf=\"myModel.errors?.forbiddenMultiple as forbiddenMultiple\">\n {{ 'validations.multipleOf' | translate:{ multiples: forbiddenMultiple.allowed } }}\n </mat-error>\n\n</mat-form-field>\n", styles: [".elder-quantity-input{text-align:right}\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.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.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i3.MaxValidator, selector: "input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]", inputs: ["max"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i6.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i6.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i6.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatPrefix, selector: "[matPrefix]" }, { kind: "directive", type: i6.MatSuffix, selector: "[matSuffix]" }, { kind: "directive", type: i7.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: i8.ElderMinDirective, selector: "[min][formControlName],[min][formControl],[min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i9.ElderMaxDirective, selector: "[max][formControlName],[max][formControl],[max][ngModel]", inputs: ["max"] }, { kind: "directive", type: i10.ElderFormFieldNoSpinnerDirective, selector: "input[elderNoSpinner]", inputs: ["elderNoSpinner"] }, { kind: "directive", type: i11.ElderRequiredIgnoreZeroValidator, selector: "[elderRequiredIgnoreZeroValidator][ngModel]", inputs: ["elderRequiredIgnoreZeroValidator", "required"] }, { kind: "directive", type: i12.ElderMultipleOfValidator, selector: "[elderMultipleOf][formControlName],[elderMultipleOf][formControl],[elderMultipleOf][ngModel]", inputs: ["elderMultipleOf"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i13.TranslatePipe, name: "translate" }], viewProviders: [ViewProviders.ParentControlContainer], changeDetection: i0.ChangeDetectionStrategy.OnPush });
163
+ ElderQuantityInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderQuantityInputComponent, selector: "elder-quantity-input", inputs: { multipleOf: "multipleOf", displayFormat: "displayFormat", requiredIgnoreZero: "requiredIgnoreZero", quantityNumber: "quantityNumber", quantityValue: "quantityValue", unit: "unit" }, outputs: { quantityNumberChange: "quantityNumberChange", quantityValueChange: "quantityValueChange", unitChange: "unitChange" }, providers: buildFormIntegrationProviders(ElderQuantityInputComponent), viewQueries: [{ propertyName: "quantityInput", first: true, predicate: ["quantityInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "\n<mat-form-field class=\"elder-flex-control\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n <input matInput elderNoSpinner class=\"elder-quantity-input flex\"\n type=\"number\"\n #quantityInput=\"matInput\"\n\n [name]=\"name + '-inner'\"\n [ngModel]=\"formattedValue$ | async\" #myModel=\"ngModel\"\n (ngModelChange)=\"onQuantityValueChanged($event)\"\n\n [elderRequiredIgnoreZeroValidator]=\"requiredIgnoreZero\"\n [elderMultipleOf]=\"multipleOf\"\n [placeholder]=\"(placeholder ? placeholder : 'context.quantity') | translate\"\n [min]=\"min\" [max]=\"max\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n\n >\n\n <span matPrefix *ngIf=\"showIcon && icon\">\n <mat-icon [inline]=\"true\">{{icon}}</mat-icon>\n </span>\n\n <span matSuffix>&nbsp;\n <span>{{unitSymbol$ | async}}</span>\n </span>\n\n <mat-hint *ngIf=\"showHint\" align=\"end\">\n <span *ngIf=\"hint\">{{hint}}</span>\n </mat-hint>\n\n <mat-error *ngIf=\"myModel.errors?.required\">\n {{ 'validations.required' | translate }}\n </mat-error>\n\n <mat-error *ngIf=\"myModel.errors?.min || myModel.errors?.max\">\n <span *ngIf=\"min && max\">\n >= {{min}} & <= {{max}}\n </span>\n\n <span *ngIf=\"min && !max\">\n >= {{min}}\n </span>\n\n <span *ngIf=\"!min && max\">\n <= {{max}}\n </span>\n </mat-error>\n\n <mat-error *ngIf=\"myModel.errors?.forbiddenMultiple as forbiddenMultiple\">\n {{ 'validations.multipleOf' | translate:{ multiples: forbiddenMultiple.allowed } }}\n </mat-error>\n\n</mat-form-field>\n", styles: [".elder-quantity-input{text-align:right}\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.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.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i3.MaxValidator, selector: "input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]", inputs: ["max"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatPrefix, selector: "[matPrefix]" }, { kind: "directive", type: i5.MatSuffix, selector: "[matSuffix]" }, { 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: i7.ElderMinDirective, selector: "[min][formControlName],[min][formControl],[min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i8.ElderMaxDirective, selector: "[max][formControlName],[max][formControl],[max][ngModel]", inputs: ["max"] }, { kind: "directive", type: i9.ElderFormFieldNoSpinnerDirective, selector: "input[elderNoSpinner]", inputs: ["elderNoSpinner"] }, { kind: "directive", type: i10.ElderRequiredIgnoreZeroValidator, selector: "[elderRequiredIgnoreZeroValidator][ngModel]", inputs: ["elderRequiredIgnoreZeroValidator", "required"] }, { kind: "directive", type: i11.ElderMultipleOfValidator, selector: "[elderMultipleOf][formControlName],[elderMultipleOf][formControl],[elderMultipleOf][ngModel]", inputs: ["elderMultipleOf"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i12.TranslatePipe, name: "translate" }], viewProviders: [ViewProviders.ParentControlContainer], changeDetection: i0.ChangeDetectionStrategy.OnPush });
165
164
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderQuantityInputComponent, decorators: [{
166
165
  type: Component,
167
- args: [{ selector: 'elder-quantity-input', providers: buildFormIntegrationProviders(ElderQuantityInputComponent), changeDetection: ChangeDetectionStrategy.OnPush, viewProviders: [ViewProviders.ParentControlContainer], template: "\n<mat-form-field fxFlex\n class=\"elder-std-form-field\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n <input matInput fxFlex elderNoSpinner class=\"elder-quantity-input\"\n type=\"number\"\n #quantityInput=\"matInput\"\n\n [name]=\"name + '-inner'\"\n [ngModel]=\"formattedValue$ | async\" #myModel=\"ngModel\"\n (ngModelChange)=\"onQuantityValueChanged($event)\"\n\n [elderRequiredIgnoreZeroValidator]=\"requiredIgnoreZero\"\n [elderMultipleOf]=\"multipleOf\"\n [placeholder]=\"(placeholder ? placeholder : 'context.quantity') | translate\"\n [min]=\"min\" [max]=\"max\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n\n >\n\n <span matPrefix *ngIf=\"showIcon && icon\">\n <mat-icon [inline]=\"true\">{{icon}}</mat-icon>\n </span>\n\n <span matSuffix>&nbsp;\n <span>{{unitSymbol$ | async}}</span>\n </span>\n\n <mat-hint *ngIf=\"showHint\" align=\"end\">\n <span *ngIf=\"hint\">{{hint}}</span>\n </mat-hint>\n\n <mat-error *ngIf=\"myModel.errors?.required\">\n {{ 'validations.required' | translate }}\n </mat-error>\n\n <mat-error *ngIf=\"myModel.errors?.min || myModel.errors?.max\">\n <span *ngIf=\"min && max\">\n >= {{min}} & <= {{max}}\n </span>\n\n <span *ngIf=\"min && !max\">\n >= {{min}}\n </span>\n\n <span *ngIf=\"!min && max\">\n <= {{max}}\n </span>\n </mat-error>\n\n <mat-error *ngIf=\"myModel.errors?.forbiddenMultiple as forbiddenMultiple\">\n {{ 'validations.multipleOf' | translate:{ multiples: forbiddenMultiple.allowed } }}\n </mat-error>\n\n</mat-form-field>\n", styles: [".elder-quantity-input{text-align:right}\n"] }]
166
+ args: [{ selector: 'elder-quantity-input', providers: buildFormIntegrationProviders(ElderQuantityInputComponent), changeDetection: ChangeDetectionStrategy.OnPush, viewProviders: [ViewProviders.ParentControlContainer], template: "\n<mat-form-field class=\"elder-flex-control\"\n [floatLabel]=\"floatLabel\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n <input matInput elderNoSpinner class=\"elder-quantity-input flex\"\n type=\"number\"\n #quantityInput=\"matInput\"\n\n [name]=\"name + '-inner'\"\n [ngModel]=\"formattedValue$ | async\" #myModel=\"ngModel\"\n (ngModelChange)=\"onQuantityValueChanged($event)\"\n\n [elderRequiredIgnoreZeroValidator]=\"requiredIgnoreZero\"\n [elderMultipleOf]=\"multipleOf\"\n [placeholder]=\"(placeholder ? placeholder : 'context.quantity') | translate\"\n [min]=\"min\" [max]=\"max\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n\n >\n\n <span matPrefix *ngIf=\"showIcon && icon\">\n <mat-icon [inline]=\"true\">{{icon}}</mat-icon>\n </span>\n\n <span matSuffix>&nbsp;\n <span>{{unitSymbol$ | async}}</span>\n </span>\n\n <mat-hint *ngIf=\"showHint\" align=\"end\">\n <span *ngIf=\"hint\">{{hint}}</span>\n </mat-hint>\n\n <mat-error *ngIf=\"myModel.errors?.required\">\n {{ 'validations.required' | translate }}\n </mat-error>\n\n <mat-error *ngIf=\"myModel.errors?.min || myModel.errors?.max\">\n <span *ngIf=\"min && max\">\n >= {{min}} & <= {{max}}\n </span>\n\n <span *ngIf=\"min && !max\">\n >= {{min}}\n </span>\n\n <span *ngIf=\"!min && max\">\n <= {{max}}\n </span>\n </mat-error>\n\n <mat-error *ngIf=\"myModel.errors?.forbiddenMultiple as forbiddenMultiple\">\n {{ 'validations.multipleOf' | translate:{ multiples: forbiddenMultiple.allowed } }}\n </mat-error>\n\n</mat-form-field>\n", styles: [".elder-quantity-input{text-align:right}\n"] }]
168
167
  }], ctorParameters: function () { return [{ type: i1.ElderUnitService }, { type: i2.DecimalPipe }]; }, propDecorators: { multipleOf: [{
169
168
  type: Input
170
169
  }], displayFormat: [{
@@ -187,4 +186,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
187
186
  }], unitChange: [{
188
187
  type: Output
189
188
  }] } });
190
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-quantity-input.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/measures/quantity-input/elder-quantity-input.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/measures/quantity-input/elder-quantity-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, Input, OnInit, Output, ViewChild} from '@angular/core';\nimport {Quantity} from '../model/quantity';\nimport {buildFormIntegrationProviders} from '../../../common/forms/template-composite-control';\nimport {Unit} from '../model/unit';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {filter, map, tap} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {FormFieldBaseComponent} from '../../../common/forms/form-field-base.component';\nimport {ViewProviders} from '../../../common/forms/view-providers';\nimport {ElderUnitService} from '../elder-unit.service';\nimport {FloatLabelType} from '@angular/material/form-field';\nimport {DecimalPipe} from '@angular/common';\nimport {MatInput} from '@angular/material/input';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\n\n@Component({\n  selector: 'elder-quantity-input',\n  templateUrl: './elder-quantity-input.component.html',\n  styleUrls: ['./elder-quantity-input.component.scss'],\n  providers: buildFormIntegrationProviders(ElderQuantityInputComponent),\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  viewProviders: [ViewProviders.ParentControlContainer]\n})\nexport class ElderQuantityInputComponent extends FormFieldBaseComponent<Quantity> implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  /**\n   * Weather the number 0 should result in valid 'required' validation or not.\n   * If true, the number 0 will be ignored as input when the 'required' directive is active.\n   */\n  private _requiredIgnoreZero = false;\n\n  /**\n   * Only allow a multiple of the given number to be a valid quantity.\n   */\n  @Input()\n  public multipleOf: number | number[] = null;\n\n  /**\n   * Display format for the quantity value:\n   * {minIntegerDigits}.{minFractionDigits}-{maxFractionDigits}\n   */\n  @Input()\n  public displayFormat: string = null;\n\n  public readonly quantityInput$ = new BehaviorSubject<MatInput>(null);\n\n  public readonly unitSymbol$: Observable<string>;\n\n  public readonly formattedValue$: Observable<string | number>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly unitService: ElderUnitService,\n    private readonly decimalPipe: DecimalPipe\n  ) {\n    super();\n\n    this.floatLabel = 'auto';\n\n    this.value = Quantity.from(null, null);\n\n\n    this.unitSymbol$ = this.value$.pipe(\n      map(v => v?.unit),\n      map(unit => {\n        if (unit) {\n          return this.unitService.getUnitSymbol(unit);\n        } else {\n          return '';\n        }\n      })\n    );\n\n    this.formattedValue$ = combineLatest(\n      [\n        this.quantityInput$.pipe(filter(input => !!input)),\n        this.value$\n      ]\n    ).pipe(\n      map(([input, quantity]) => {\n        const quantityNumber = quantity?.value;\n        if (!input?.focused && this.displayFormat && quantityNumber) {\n          return this.decimalPipe.transform(quantityNumber, this.displayFormat, 'en')\n            .replace('\\'', '')\n            .replace('’', '')\n            .replace(',', '');\n        } else {\n          return quantityNumber;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @ViewChild('quantityInput')\n  public set quantityInput(input: MatInput) {\n    this.quantityInput$.next(input);\n  }\n\n  @Input()\n  public set requiredIgnoreZero(ignore: boolean) {\n    this._requiredIgnoreZero = coerceBooleanProperty(ignore);\n  }\n\n  public get requiredIgnoreZero(): boolean {\n    return this._requiredIgnoreZero;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Deprecated Properties                                                   *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * @deprecated\n   */\n  @Output()\n  public get quantityNumberChange(): Observable<number | null> {\n    return this.quantityValueChange;\n  }\n\n  /**\n   * @deprecated\n   */\n  @Input()\n  public set quantityNumber(quantityValue: number) {\n    this.quantityValue = quantityValue;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n\n  @Output()\n  public get quantityValueChange(): Observable<number | null> {\n    return this.valueChange.pipe(\n      map(q => q?.value)\n    );\n  }\n\n  public get quantityValue(): number {\n    return this.value?.value;\n  }\n\n  @Input()\n  public set quantityValue(quantityValue: number) {\n    this.value = Quantity.from(this.value?.unit, quantityValue);\n  }\n\n  @Input()\n  public set unit(unit: Unit) {\n    this.value = Quantity.from(unit, this.value?.value);\n  }\n\n  @Output()\n  public get unitChange(): Observable<Unit | null> {\n    return this.valueChange.pipe(\n      map(q => q?.unit)\n    );\n  }\n\n  public get unit(): Unit {\n    return this.value?.unit;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onQuantityValueChanged(value: number): void {\n    this.updateValue(Quantity.from(this.value?.unit, value));\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  protected valuesEquals(a: Quantity, b: Quantity): boolean {\n    if (a === b) {\n      return true;\n    }\n    return a?.value === b?.value\n      && a?.unit === b?.unit;\n  }\n\n}\n","\n<mat-form-field fxFlex\n                class=\"elder-std-form-field\"\n                [floatLabel]=\"floatLabel\"\n                [appearance]=\"appearance\"\n                [color]=\"color\"\n\n>\n\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n  <input matInput fxFlex elderNoSpinner class=\"elder-quantity-input\"\n         type=\"number\"\n         #quantityInput=\"matInput\"\n\n         [name]=\"name + '-inner'\"\n         [ngModel]=\"formattedValue$ | async\" #myModel=\"ngModel\"\n         (ngModelChange)=\"onQuantityValueChanged($event)\"\n\n         [elderRequiredIgnoreZeroValidator]=\"requiredIgnoreZero\"\n         [elderMultipleOf]=\"multipleOf\"\n         [placeholder]=\"(placeholder ? placeholder : 'context.quantity') | translate\"\n         [min]=\"min\" [max]=\"max\"\n         [required]=\"required\"\n         [readonly]=\"readonly\"\n         [disabled]=\"disabled\"\n\n  >\n\n  <span matPrefix *ngIf=\"showIcon && icon\">\n      <mat-icon [inline]=\"true\">{{icon}}</mat-icon>\n  </span>\n\n  <span matSuffix>&nbsp;\n      <span>{{unitSymbol$ | async}}</span>\n  </span>\n\n  <mat-hint *ngIf=\"showHint\" align=\"end\">\n    <span *ngIf=\"hint\">{{hint}}</span>\n  </mat-hint>\n\n  <mat-error *ngIf=\"myModel.errors?.required\">\n      {{ 'validations.required' | translate }}\n  </mat-error>\n\n  <mat-error *ngIf=\"myModel.errors?.min || myModel.errors?.max\">\n      <span *ngIf=\"min && max\">\n          >= {{min}} & <= {{max}}\n      </span>\n\n      <span *ngIf=\"min && !max\">\n          >= {{min}}\n      </span>\n\n      <span *ngIf=\"!min && max\">\n          <= {{max}}\n      </span>\n  </mat-error>\n\n  <mat-error *ngIf=\"myModel.errors?.forbiddenMultiple as forbiddenMultiple\">\n      {{ 'validations.multipleOf' | translate:{ multiples: forbiddenMultiple.allowed } }}\n  </mat-error>\n\n</mat-form-field>\n"]}
189
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-quantity-input.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/measures/quantity-input/elder-quantity-input.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/measures/quantity-input/elder-quantity-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, Input, OnInit, Output, ViewChild} from '@angular/core';\nimport {Quantity} from '../model/quantity';\nimport {buildFormIntegrationProviders} from '../../../common/forms/template-composite-control';\nimport {Unit} from '../model/unit';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {filter, map, tap} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {FormFieldBaseComponent} from '../../../common/forms/form-field-base.component';\nimport {ViewProviders} from '../../../common/forms/view-providers';\nimport {ElderUnitService} from '../elder-unit.service';\nimport {FloatLabelType} from '@angular/material/form-field';\nimport {DecimalPipe} from '@angular/common';\nimport {MatInput} from '@angular/material/input';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\n\n@Component({\n  selector: 'elder-quantity-input',\n  templateUrl: './elder-quantity-input.component.html',\n  styleUrls: ['./elder-quantity-input.component.scss'],\n  providers: buildFormIntegrationProviders(ElderQuantityInputComponent),\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  viewProviders: [ViewProviders.ParentControlContainer]\n})\nexport class ElderQuantityInputComponent extends FormFieldBaseComponent<Quantity> implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  /**\n   * Weather the number 0 should result in valid 'required' validation or not.\n   * If true, the number 0 will be ignored as input when the 'required' directive is active.\n   */\n  private _requiredIgnoreZero = false;\n\n  /**\n   * Only allow a multiple of the given number to be a valid quantity.\n   */\n  @Input()\n  public multipleOf: number | number[] = null;\n\n  /**\n   * Display format for the quantity value:\n   * {minIntegerDigits}.{minFractionDigits}-{maxFractionDigits}\n   */\n  @Input()\n  public displayFormat: string = null;\n\n  public readonly quantityInput$ = new BehaviorSubject<MatInput>(null);\n\n  public readonly unitSymbol$: Observable<string>;\n\n  public readonly formattedValue$: Observable<string | number>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly unitService: ElderUnitService,\n    private readonly decimalPipe: DecimalPipe\n  ) {\n    super();\n\n    this.floatLabel = 'auto';\n\n    this.value = Quantity.from(null, null);\n\n\n    this.unitSymbol$ = this.value$.pipe(\n      map(v => v?.unit),\n      map(unit => {\n        if (unit) {\n          return this.unitService.getUnitSymbol(unit);\n        } else {\n          return '';\n        }\n      })\n    );\n\n    this.formattedValue$ = combineLatest(\n      [\n        this.quantityInput$.pipe(filter(input => !!input)),\n        this.value$\n      ]\n    ).pipe(\n      map(([input, quantity]) => {\n        const quantityNumber = quantity?.value;\n        if (!input?.focused && this.displayFormat && quantityNumber) {\n          return this.decimalPipe.transform(quantityNumber, this.displayFormat, 'en')\n            .replace('\\'', '')\n            .replace('’', '')\n            .replace(',', '');\n        } else {\n          return quantityNumber;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @ViewChild('quantityInput')\n  public set quantityInput(input: MatInput) {\n    this.quantityInput$.next(input);\n  }\n\n  @Input()\n  public set requiredIgnoreZero(ignore: boolean) {\n    this._requiredIgnoreZero = coerceBooleanProperty(ignore);\n  }\n\n  public get requiredIgnoreZero(): boolean {\n    return this._requiredIgnoreZero;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Deprecated Properties                                                   *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * @deprecated\n   */\n  @Output()\n  public get quantityNumberChange(): Observable<number | null> {\n    return this.quantityValueChange;\n  }\n\n  /**\n   * @deprecated\n   */\n  @Input()\n  public set quantityNumber(quantityValue: number) {\n    this.quantityValue = quantityValue;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n\n  @Output()\n  public get quantityValueChange(): Observable<number | null> {\n    return this.valueChange.pipe(\n      map(q => q?.value)\n    );\n  }\n\n  public get quantityValue(): number {\n    return this.value?.value;\n  }\n\n  @Input()\n  public set quantityValue(quantityValue: number) {\n    this.value = Quantity.from(this.value?.unit, quantityValue);\n  }\n\n  @Input()\n  public set unit(unit: Unit) {\n    this.value = Quantity.from(unit, this.value?.value);\n  }\n\n  @Output()\n  public get unitChange(): Observable<Unit | null> {\n    return this.valueChange.pipe(\n      map(q => q?.unit)\n    );\n  }\n\n  public get unit(): Unit {\n    return this.value?.unit;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onQuantityValueChanged(value: number): void {\n    this.updateValue(Quantity.from(this.value?.unit, value));\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  protected valuesEquals(a: Quantity, b: Quantity): boolean {\n    if (a === b) {\n      return true;\n    }\n    return a?.value === b?.value\n      && a?.unit === b?.unit;\n  }\n\n}\n","\n<mat-form-field class=\"elder-flex-control\"\n                [floatLabel]=\"floatLabel\"\n                [appearance]=\"appearance\"\n                [color]=\"color\"\n\n>\n\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n  <input matInput elderNoSpinner class=\"elder-quantity-input flex\"\n         type=\"number\"\n         #quantityInput=\"matInput\"\n\n         [name]=\"name + '-inner'\"\n         [ngModel]=\"formattedValue$ | async\" #myModel=\"ngModel\"\n         (ngModelChange)=\"onQuantityValueChanged($event)\"\n\n         [elderRequiredIgnoreZeroValidator]=\"requiredIgnoreZero\"\n         [elderMultipleOf]=\"multipleOf\"\n         [placeholder]=\"(placeholder ? placeholder : 'context.quantity') | translate\"\n         [min]=\"min\" [max]=\"max\"\n         [required]=\"required\"\n         [readonly]=\"readonly\"\n         [disabled]=\"disabled\"\n\n  >\n\n  <span matPrefix *ngIf=\"showIcon && icon\">\n      <mat-icon [inline]=\"true\">{{icon}}</mat-icon>\n  </span>\n\n  <span matSuffix>&nbsp;\n      <span>{{unitSymbol$ | async}}</span>\n  </span>\n\n  <mat-hint *ngIf=\"showHint\" align=\"end\">\n    <span *ngIf=\"hint\">{{hint}}</span>\n  </mat-hint>\n\n  <mat-error *ngIf=\"myModel.errors?.required\">\n      {{ 'validations.required' | translate }}\n  </mat-error>\n\n  <mat-error *ngIf=\"myModel.errors?.min || myModel.errors?.max\">\n      <span *ngIf=\"min && max\">\n          >= {{min}} & <= {{max}}\n      </span>\n\n      <span *ngIf=\"min && !max\">\n          >= {{min}}\n      </span>\n\n      <span *ngIf=\"!min && max\">\n          <= {{max}}\n      </span>\n  </mat-error>\n\n  <mat-error *ngIf=\"myModel.errors?.forbiddenMultiple as forbiddenMultiple\">\n      {{ 'validations.multipleOf' | translate:{ multiples: forbiddenMultiple.allowed } }}\n  </mat-error>\n\n</mat-form-field>\n"]}