design-angular-kit 0.12.0 → 1.0.0-0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (201) hide show
  1. package/README.md +61 -31
  2. package/esm2020/design-angular-kit.mjs +5 -0
  3. package/esm2020/lib/badge/badge.directive.mjs +83 -0
  4. package/esm2020/lib/breadcrumb/breadcrumb-item.component.mjs +66 -0
  5. package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +89 -0
  6. package/esm2020/lib/button/button.directive.mjs +185 -0
  7. package/esm2020/lib/button/button.module.mjs +18 -0
  8. package/esm2020/lib/checkbox/checkbox.component.mjs +138 -0
  9. package/esm2020/lib/collapse/collapse-group.component.mjs +57 -0
  10. package/esm2020/lib/collapse/collapse-item.component.mjs +79 -0
  11. package/esm2020/lib/collapse/collapse.config.mjs +12 -0
  12. package/esm2020/lib/collapse/collapse.directive.mjs +55 -0
  13. package/esm2020/lib/collapse/collapse.module.mjs +22 -0
  14. package/esm2020/lib/design-angular-kit.module.mjs +142 -0
  15. package/esm2020/lib/dropdown/dropdown-divider.component.mjs +11 -0
  16. package/esm2020/lib/dropdown/dropdown-item.component.mjs +97 -0
  17. package/esm2020/lib/dropdown/dropdown.component.mjs +143 -0
  18. package/esm2020/lib/dropdown/dropdown.config.mjs +12 -0
  19. package/esm2020/lib/dropdown/dropdown.directive.mjs +156 -0
  20. package/esm2020/lib/dropdown/dropdown.module.mjs +25 -0
  21. package/esm2020/lib/enums/icons.enum.mjs +27 -0
  22. package/esm2020/lib/form-input/form-input-password.utils.mjs +154 -0
  23. package/esm2020/lib/form-input/form-input.component.mjs +495 -0
  24. package/esm2020/lib/form-input/it-prefix.directive.mjs +13 -0
  25. package/esm2020/lib/form-input/it-suffix.directive.mjs +13 -0
  26. package/esm2020/lib/form-input/it-text-prefix.directive.mjs +13 -0
  27. package/esm2020/lib/form-input/it-text-suffix.directive.mjs +13 -0
  28. package/esm2020/lib/form-input/mark-matching-text.pipe.mjs +36 -0
  29. package/esm2020/lib/icon/icon.component.mjs +87 -0
  30. package/esm2020/lib/icon/icon.module.mjs +18 -0
  31. package/esm2020/lib/models/Alignment.mjs +15 -0
  32. package/esm2020/lib/models/ButtonSize.mjs +15 -0
  33. package/esm2020/lib/models/InputType.mjs +44 -0
  34. package/esm2020/lib/models/ThemeColor.mjs +30 -0
  35. package/esm2020/lib/popover/popover.config.mjs +17 -0
  36. package/esm2020/lib/popover/popover.directive.mjs +33 -0
  37. package/esm2020/lib/popover/popover.module.mjs +19 -0
  38. package/esm2020/lib/progress-bar/progress-bar.component.mjs +98 -0
  39. package/esm2020/lib/radio/radio.component.mjs +287 -0
  40. package/esm2020/lib/radio/unique-selection-dispatcher.mjs +55 -0
  41. package/esm2020/lib/tabs/tab-group.component.mjs +177 -0
  42. package/esm2020/lib/tabs/tab.component.mjs +73 -0
  43. package/esm2020/lib/tabs/tabs.module.mjs +20 -0
  44. package/esm2020/lib/toggle/toggle.component.mjs +86 -0
  45. package/esm2020/lib/tooltip/tooltip.config.mjs +17 -0
  46. package/esm2020/lib/tooltip/tooltip.directive.mjs +43 -0
  47. package/esm2020/lib/tooltip/tooltip.module.mjs +19 -0
  48. package/esm2020/lib/util/focus-mouse.directive.mjs +32 -0
  49. package/esm2020/lib/util/util.mjs +12 -0
  50. package/esm2020/lib/util/utils.module.mjs +16 -0
  51. package/esm2020/public_api.mjs +40 -0
  52. package/fesm2015/design-angular-kit.mjs +3181 -0
  53. package/fesm2015/design-angular-kit.mjs.map +1 -0
  54. package/fesm2020/design-angular-kit.mjs +3160 -0
  55. package/fesm2020/design-angular-kit.mjs.map +1 -0
  56. package/index.d.ts +5 -0
  57. package/lib/badge/badge.directive.d.ts +11 -5
  58. package/lib/breadcrumb/breadcrumb-item.component.d.ts +16 -5
  59. package/lib/breadcrumb/breadcrumb.component.d.ts +12 -5
  60. package/lib/button/button.directive.d.ts +72 -0
  61. package/lib/button/button.module.d.ts +8 -0
  62. package/lib/checkbox/checkbox.component.d.ts +25 -5
  63. package/lib/collapse/collapse-group.component.d.ts +16 -0
  64. package/lib/collapse/collapse-item.component.d.ts +46 -0
  65. package/lib/collapse/collapse.config.d.ts +6 -0
  66. package/lib/collapse/collapse.directive.d.ts +25 -0
  67. package/lib/collapse/collapse.module.d.ts +12 -0
  68. package/lib/design-angular-kit.module.d.ts +27 -0
  69. package/lib/dropdown/dropdown-divider.component.d.ts +3 -0
  70. package/lib/dropdown/dropdown-item.component.d.ts +22 -8
  71. package/lib/dropdown/dropdown.component.d.ts +34 -26
  72. package/lib/dropdown/dropdown.config.d.ts +6 -0
  73. package/lib/dropdown/dropdown.directive.d.ts +77 -0
  74. package/lib/dropdown/dropdown.module.d.ts +15 -0
  75. package/lib/enums/icons.enum.d.ts +23 -0
  76. package/lib/form-input/form-input-password.utils.d.ts +45 -0
  77. package/lib/form-input/form-input.component.d.ts +202 -20
  78. package/lib/form-input/it-prefix.directive.d.ts +5 -0
  79. package/lib/form-input/it-suffix.directive.d.ts +5 -0
  80. package/lib/form-input/it-text-prefix.directive.d.ts +5 -0
  81. package/lib/form-input/it-text-suffix.directive.d.ts +5 -0
  82. package/lib/form-input/mark-matching-text.pipe.d.ts +10 -0
  83. package/lib/icon/icon.component.d.ts +34 -0
  84. package/lib/icon/icon.module.d.ts +8 -0
  85. package/lib/models/Alignment.d.ts +12 -0
  86. package/lib/models/ButtonSize.d.ts +1 -1
  87. package/lib/models/InputType.d.ts +22 -1
  88. package/lib/models/ThemeColor.d.ts +1 -1
  89. package/lib/popover/popover.config.d.ts +5 -6
  90. package/lib/popover/popover.directive.d.ts +13 -108
  91. package/lib/popover/popover.module.d.ts +9 -0
  92. package/lib/progress-bar/progress-bar.component.d.ts +25 -19
  93. package/lib/radio/radio.component.d.ts +22 -10
  94. package/lib/radio/unique-selection-dispatcher.d.ts +3 -0
  95. package/lib/tabs/tab-group.component.d.ts +17 -11
  96. package/lib/tabs/tab.component.d.ts +6 -2
  97. package/lib/tabs/tabs.module.d.ts +10 -0
  98. package/lib/toggle/toggle.component.d.ts +9 -4
  99. package/lib/tooltip/tooltip.config.d.ts +7 -7
  100. package/lib/tooltip/tooltip.directive.d.ts +12 -92
  101. package/lib/tooltip/tooltip.module.d.ts +9 -0
  102. package/lib/util/focus-mouse.directive.d.ts +13 -0
  103. package/lib/util/utils.module.d.ts +7 -0
  104. package/package.json +34 -20
  105. package/public_api.d.ts +19 -2
  106. package/bundles/design-angular-kit.umd.js +0 -5829
  107. package/bundles/design-angular-kit.umd.js.map +0 -1
  108. package/bundles/design-angular-kit.umd.min.js +0 -31
  109. package/bundles/design-angular-kit.umd.min.js.map +0 -1
  110. package/design-angular-kit.d.ts +0 -8
  111. package/design-angular-kit.metadata.json +0 -1
  112. package/esm2015/design-angular-kit.js +0 -14
  113. package/esm2015/lib/badge/badge.directive.js +0 -116
  114. package/esm2015/lib/breadcrumb/breadcrumb-item.component.js +0 -117
  115. package/esm2015/lib/breadcrumb/breadcrumb.component.js +0 -128
  116. package/esm2015/lib/button/button.component.js +0 -165
  117. package/esm2015/lib/checkbox/checkbox.component.js +0 -170
  118. package/esm2015/lib/design-angular-kit.module.js +0 -81
  119. package/esm2015/lib/dropdown/dropdown-divider.component.js +0 -18
  120. package/esm2015/lib/dropdown/dropdown-header.component.js +0 -29
  121. package/esm2015/lib/dropdown/dropdown-item.component.js +0 -157
  122. package/esm2015/lib/dropdown/dropdown.component.js +0 -248
  123. package/esm2015/lib/form-input/form-input.component.js +0 -489
  124. package/esm2015/lib/models/ButtonSize.js +0 -25
  125. package/esm2015/lib/models/IconPosition.js +0 -21
  126. package/esm2015/lib/models/InputType.js +0 -33
  127. package/esm2015/lib/models/InteractionTrigger.js +0 -35
  128. package/esm2015/lib/models/ThemeColor.js +0 -45
  129. package/esm2015/lib/popover/popover.component.js +0 -134
  130. package/esm2015/lib/popover/popover.config.js +0 -35
  131. package/esm2015/lib/popover/popover.directive.js +0 -433
  132. package/esm2015/lib/popover/popup.js +0 -105
  133. package/esm2015/lib/popover/positioning.js +0 -349
  134. package/esm2015/lib/popover/triggers.js +0 -99
  135. package/esm2015/lib/progress-bar/progress-bar.component.js +0 -170
  136. package/esm2015/lib/radio/radio.component.js +0 -526
  137. package/esm2015/lib/radio/unique-selection-dispatcher.js +0 -70
  138. package/esm2015/lib/tabs/tab-group.component.js +0 -339
  139. package/esm2015/lib/tabs/tab.component.js +0 -143
  140. package/esm2015/lib/toggle/toggle.component.js +0 -173
  141. package/esm2015/lib/tooltip/popup.js +0 -105
  142. package/esm2015/lib/tooltip/positioning.js +0 -349
  143. package/esm2015/lib/tooltip/tooltip.component.js +0 -77
  144. package/esm2015/lib/tooltip/tooltip.config.js +0 -31
  145. package/esm2015/lib/tooltip/tooltip.directive.js +0 -384
  146. package/esm2015/lib/tooltip/triggers.js +0 -99
  147. package/esm2015/lib/util/util.js +0 -30
  148. package/esm2015/public_api.js +0 -28
  149. package/esm5/design-angular-kit.js +0 -14
  150. package/esm5/lib/badge/badge.directive.js +0 -145
  151. package/esm5/lib/breadcrumb/breadcrumb-item.component.js +0 -135
  152. package/esm5/lib/breadcrumb/breadcrumb.component.js +0 -164
  153. package/esm5/lib/button/button.component.js +0 -221
  154. package/esm5/lib/checkbox/checkbox.component.js +0 -200
  155. package/esm5/lib/design-angular-kit.module.js +0 -85
  156. package/esm5/lib/dropdown/dropdown-divider.component.js +0 -20
  157. package/esm5/lib/dropdown/dropdown-header.component.js +0 -27
  158. package/esm5/lib/dropdown/dropdown-item.component.js +0 -197
  159. package/esm5/lib/dropdown/dropdown.component.js +0 -309
  160. package/esm5/lib/form-input/form-input.component.js +0 -582
  161. package/esm5/lib/models/ButtonSize.js +0 -25
  162. package/esm5/lib/models/IconPosition.js +0 -21
  163. package/esm5/lib/models/InputType.js +0 -33
  164. package/esm5/lib/models/InteractionTrigger.js +0 -35
  165. package/esm5/lib/models/ThemeColor.js +0 -45
  166. package/esm5/lib/popover/popover.component.js +0 -144
  167. package/esm5/lib/popover/popover.config.js +0 -37
  168. package/esm5/lib/popover/popover.directive.js +0 -573
  169. package/esm5/lib/popover/popup.js +0 -116
  170. package/esm5/lib/popover/positioning.js +0 -446
  171. package/esm5/lib/popover/triggers.js +0 -115
  172. package/esm5/lib/progress-bar/progress-bar.component.js +0 -218
  173. package/esm5/lib/radio/radio.component.js +0 -610
  174. package/esm5/lib/radio/unique-selection-dispatcher.js +0 -108
  175. package/esm5/lib/tabs/tab-group.component.js +0 -401
  176. package/esm5/lib/tabs/tab.component.js +0 -156
  177. package/esm5/lib/toggle/toggle.component.js +0 -200
  178. package/esm5/lib/tooltip/popup.js +0 -116
  179. package/esm5/lib/tooltip/positioning.js +0 -446
  180. package/esm5/lib/tooltip/tooltip.component.js +0 -80
  181. package/esm5/lib/tooltip/tooltip.config.js +0 -33
  182. package/esm5/lib/tooltip/tooltip.directive.js +0 -516
  183. package/esm5/lib/tooltip/triggers.js +0 -115
  184. package/esm5/lib/util/util.js +0 -48
  185. package/esm5/public_api.js +0 -28
  186. package/fesm2015/design-angular-kit.js +0 -4751
  187. package/fesm2015/design-angular-kit.js.map +0 -1
  188. package/fesm5/design-angular-kit.js +0 -5867
  189. package/fesm5/design-angular-kit.js.map +0 -1
  190. package/lib/button/button.component.d.ts +0 -50
  191. package/lib/dropdown/dropdown-header.component.d.ts +0 -3
  192. package/lib/models/IconPosition.d.ts +0 -9
  193. package/lib/models/InteractionTrigger.d.ts +0 -19
  194. package/lib/popover/popover.component.d.ts +0 -25
  195. package/lib/popover/popup.d.ts +0 -27
  196. package/lib/popover/positioning.d.ts +0 -32
  197. package/lib/popover/triggers.d.ts +0 -18
  198. package/lib/tooltip/popup.d.ts +0 -27
  199. package/lib/tooltip/positioning.d.ts +0 -32
  200. package/lib/tooltip/tooltip.component.d.ts +0 -20
  201. package/lib/tooltip/triggers.d.ts +0 -18
@@ -0,0 +1,495 @@
1
+ import { Component, Input, ChangeDetectionStrategy, forwardRef, Output, EventEmitter, ViewChild, ContentChildren, HostListener } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { merge } from 'rxjs';
4
+ import { InputType, INPUT_TYPES } from '../models/InputType';
5
+ import { Util } from '../util/util';
6
+ import { FormInputPasswordUtils } from './form-input-password.utils';
7
+ import { ItPrefixDirective } from './it-prefix.directive';
8
+ import { ItSuffixDirective } from './it-suffix.directive';
9
+ import { ItTextPrefixDirective } from './it-text-prefix.directive';
10
+ import { ItTextSuffixDirective } from './it-text-suffix.directive';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@angular/common";
13
+ import * as i2 from "../util/focus-mouse.directive";
14
+ import * as i3 from "../icon/icon.component";
15
+ import * as i4 from "./mark-matching-text.pipe";
16
+ let identifier = 0;
17
+ export class FormInputChange {
18
+ constructor(source, value) {
19
+ this.source = source;
20
+ this.value = value;
21
+ }
22
+ }
23
+ /**
24
+ * Elementi e stili per la creazione di input accessibili e responsivi.
25
+ */
26
+ export class FormInputComponent {
27
+ constructor(_changeDetector) {
28
+ this._changeDetector = _changeDetector;
29
+ this.INPUT_TYPES = INPUT_TYPES;
30
+ this._readonlyPlainText = false;
31
+ this._enablePasswordStrengthMeter = false;
32
+ /**
33
+ * Punteggio di sicurezza calcolato in base alla password immessa se enablePasswordStrengthMeter ha valore true
34
+ */
35
+ this.passwordScore = 0;
36
+ /**
37
+ * Dimensione dell'input di autocomplete. Di default ha dimensione standard.
38
+ */
39
+ this.autocompleteWrapperSize = 'default';
40
+ this._passwordStrengthMeterConfig = FormInputPasswordUtils.DEFAULT_CONFIG;
41
+ this._id = `form-input-${identifier++}`;
42
+ this._type = INPUT_TYPES.TEXT;
43
+ this._labelVisuallyHidden = false;
44
+ this._step = 1;
45
+ this._disabled = false;
46
+ this._currency = false;
47
+ this._percentage = false;
48
+ this._adaptive = false;
49
+ this._readonly = false;
50
+ /**
51
+ * Evento emesso quando il valore dell'input cambia.
52
+ * Gli eventi di change sono emessi soltanto quando il valore cambia a causa dell'interazione dell'utente
53
+ * con il campo d'input.
54
+ */
55
+ this.change = new EventEmitter();
56
+ this._disableCapsLockAlert = false;
57
+ /**
58
+ * Indica se è attivo il CAPS LOCK
59
+ */
60
+ this.isCapsLockActive = false;
61
+ /**
62
+ * La label da mostrare in caso sia attivo il CAPS LOCK
63
+ */
64
+ this.capsLockActiveLabel = 'CAPS LOCK inserito';
65
+ this._isPasswordMode = false;
66
+ this._isPasswordVisible = false;
67
+ this.showAutocompletion = false;
68
+ this._isInitialized = false;
69
+ this._controlValueAccessorChangeFn = () => { };
70
+ this._onTouched = () => { };
71
+ /** Indica se è stato effettuato il focus sul campo di input */
72
+ this.focus = false;
73
+ }
74
+ /**
75
+ * Opzionale. Indica se mostrare gli input readonly nella forma stilizzata come testo normale
76
+ */
77
+ get readonlyPlainText() { return this._readonlyPlainText; }
78
+ set readonlyPlainText(value) { this._readonlyPlainText = Util.coerceBooleanProperty(value); }
79
+ /**
80
+ * Opzionale. Indica se abilitare il controllo sulla sicurezza della password
81
+ */
82
+ get enablePasswordStrengthMeter() { return this._enablePasswordStrengthMeter; }
83
+ set enablePasswordStrengthMeter(value) { this._enablePasswordStrengthMeter = Util.coerceBooleanProperty(value); }
84
+ set passwordStrengthMeterConfig(newConfig) {
85
+ this._passwordStrengthMeterConfig = { ...this._passwordStrengthMeterConfig, ...newConfig };
86
+ }
87
+ get passwordStrengthMeterConfig() {
88
+ return this._passwordStrengthMeterConfig;
89
+ }
90
+ /**
91
+ * Indica l'id dell'elemento HTML
92
+ */
93
+ get id() {
94
+ return this._id;
95
+ }
96
+ set id(value) {
97
+ this._id = value;
98
+ }
99
+ /**
100
+ * Indica l'attributo name del componente HTML
101
+ */
102
+ get name() {
103
+ return this._name;
104
+ }
105
+ set name(value) {
106
+ this._name = value;
107
+ }
108
+ /**
109
+ * Indica il tipo di campo. Puo' assumere i valori text, email, password e number
110
+ */
111
+ get type() {
112
+ return this._type;
113
+ }
114
+ set type(value) {
115
+ if (InputType.is(value)) {
116
+ if (value === INPUT_TYPES.NUMBER) {
117
+ if (isNaN(Number(this.value))) {
118
+ this.value = '';
119
+ this.onChange();
120
+ }
121
+ }
122
+ this._type = value;
123
+ }
124
+ else {
125
+ this._type = INPUT_TYPES.TEXT;
126
+ }
127
+ this._isPasswordMode = this._type === INPUT_TYPES.PASSWORD;
128
+ this._isPasswordVisible = false;
129
+ this.showAutocompletion = false;
130
+ }
131
+ /**
132
+ * Indica il valore della label da visualizzare
133
+ */
134
+ get label() { return this._label; }
135
+ set label(value) { this._label = value; }
136
+ /**
137
+ * Indica se la label dell'input deve essere visualizzata dall'utente o solamente visibile per lo screen reader
138
+ */
139
+ get labelVisuallyHidden() { return this._labelVisuallyHidden; }
140
+ set labelVisuallyHidden(value) { this._labelVisuallyHidden = value; }
141
+ /**
142
+ * Indica il valore che avrà l'attributo HTML "min" per l'input di tipo number
143
+ */
144
+ get min() { return this._min; }
145
+ set min(value) { this._min = Util.coerceNumberProperty(value); }
146
+ /**
147
+ * Indica il valore che avrà l'attributo HTML "max" per l'input di tipo number
148
+ */
149
+ get max() { return this._max; }
150
+ set max(value) { this._max = Util.coerceNumberProperty(value); }
151
+ /**
152
+ * Indica il valore che avrà l'attributo HTML "step" per l'input di tipo number
153
+ */
154
+ get step() { return this._step; }
155
+ set step(value) { this._step = Util.coerceNumberProperty(value); }
156
+ /**
157
+ * Indica il testo di aiuto sotto la input
158
+ */
159
+ get note() { return this._note; }
160
+ set note(value) { this._note = value; }
161
+ /**
162
+ * Indica il testo presente nel campo vuoto. Nel caso sia già presente la label, il placeholder non verrà mostrato
163
+ */
164
+ get placeholder() {
165
+ return this._placeholder || '';
166
+ }
167
+ set placeholder(value) { this._placeholder = value; }
168
+ /**
169
+ * Indica l'icona da visualizzare a sinistra del campo di input
170
+ */
171
+ get icon() { return this._icon; }
172
+ set icon(value) { this._icon = value; }
173
+ /**
174
+ * Opzionale.
175
+ * Indica se il campo in questione è disabilitato.
176
+ * Accetta una espressione booleana o può essere usato come attributo senza valore
177
+ */
178
+ get disabled() { return this._disabled; }
179
+ set disabled(value) { this._disabled = Util.coerceBooleanProperty(value); }
180
+ /**
181
+ * Opzionale.
182
+ * Nel caso di input numerico, indica se il campo è una valuta.
183
+ * Accetta una espressione booleana o può essere usato come attributo senza valore
184
+ */
185
+ get currency() { return this._currency; }
186
+ set currency(value) { this._currency = Util.coerceBooleanProperty(value); }
187
+ /**
188
+ * Opzionale.
189
+ * Nel caso di input numerico, indica se il campo è una percentuale.
190
+ * Accetta una espressione booleana o può essere usato come attributo senza valore
191
+ */
192
+ get percentage() { return this._percentage; }
193
+ set percentage(value) { this._percentage = Util.coerceBooleanProperty(value); }
194
+ /**
195
+ * Opzionale.
196
+ * Nel caso di input numerico, indica se il campo si deve ridimensionare automaticamente a seconda del valore contenuto in esso.
197
+ * Accetta una espressione booleana o può essere usato come attributo senza valore
198
+ */
199
+ get adaptive() { return this._adaptive; }
200
+ set adaptive(value) { this._adaptive = Util.coerceBooleanProperty(value); }
201
+ /**
202
+ * Opzionale.
203
+ * Indica se il campo in questione è di sola lettura.
204
+ * Accetta una espressione booleana o può essere usato come attributo senza valore
205
+ */
206
+ get readonly() { return this._readonly; }
207
+ set readonly(value) { this._readonly = Util.coerceBooleanProperty(value); }
208
+ get value() { return this._inputElement?.nativeElement?.value; }
209
+ set value(value) {
210
+ if (this._inputElement) {
211
+ this._inputElement.nativeElement.value = value;
212
+ }
213
+ }
214
+ /**
215
+ * Opzionale.
216
+ * Disponibile solo se il type è search.
217
+ * Indica la lista di elementi ricercabili su cui basare il sistema di autocompletamento della input
218
+ */
219
+ get autoCompleteData() { return this._autoCompleteData; }
220
+ set autoCompleteData(value) { this._autoCompleteData = value; }
221
+ /**
222
+ * Opzionale.
223
+ * Indica se disabilitare l'avviso di CAPS LOCK attivo
224
+ * Accetta una espressione booleana o può essere usato come attributo senza valore
225
+ */
226
+ get disableCapsLockAlert() { return this._disableCapsLockAlert; }
227
+ set disableCapsLockAlert(value) { this._disableCapsLockAlert = Util.coerceBooleanProperty(value); }
228
+ get isLabelActive() {
229
+ return this._isLabelActive;
230
+ }
231
+ set isLabelActive(value) {
232
+ const newValue = Util.coerceBooleanProperty(value);
233
+ // In alcuni casi la label deve essere sempre posizionata sopra l'input per evitare sovrapposizioni
234
+ // di testo, come in caso di presenza del placeholder o per l'input di tipo "date" o "time"
235
+ if (newValue || (!this.value && !this.placeholder && this.type !== INPUT_TYPES.TIME &&
236
+ this.type !== INPUT_TYPES.DATE && this.type !== INPUT_TYPES.NUMBER)) {
237
+ this._isLabelActive = newValue;
238
+ }
239
+ else {
240
+ this._isLabelActive = true;
241
+ }
242
+ }
243
+ get isPasswordMode() {
244
+ return this._isPasswordMode;
245
+ }
246
+ set isPasswordMode(value) {
247
+ this._isPasswordMode = Util.coerceBooleanProperty(value);
248
+ }
249
+ get isPasswordVisible() {
250
+ return this._isPasswordVisible;
251
+ }
252
+ set isPasswordVisible(value) {
253
+ this._isPasswordVisible = Util.coerceBooleanProperty(value);
254
+ this._type = this._isPasswordVisible ? INPUT_TYPES.TEXT : INPUT_TYPES.PASSWORD;
255
+ }
256
+ _emitChangeEvent() {
257
+ if (this._isInitialized) {
258
+ this.change.emit(new FormInputChange(this, this.value));
259
+ }
260
+ }
261
+ ngOnInit() {
262
+ this.isLabelActive = false;
263
+ this._formInputPasswordUtils = new FormInputPasswordUtils(this.passwordStrengthMeterConfig);
264
+ }
265
+ writeValue(value) {
266
+ this.value = value;
267
+ if (this.value) {
268
+ this.isLabelActive = true;
269
+ }
270
+ this.onChange();
271
+ if (this._isInitialized) {
272
+ this._changeDetector.detectChanges();
273
+ }
274
+ }
275
+ registerOnChange(fn) {
276
+ this._controlValueAccessorChangeFn = fn;
277
+ }
278
+ registerOnTouched(fn) {
279
+ this._onTouched = fn;
280
+ }
281
+ ngAfterContentInit() {
282
+ this._isInitialized = true;
283
+ // Run change detection if the suffix or prefix changes.
284
+ merge(this._prefixChildren.changes, this._suffixChildren.changes, this._textPrefixChildren.changes, this._textSuffixChildren.changes).subscribe(() => {
285
+ this._changeDetector.markForCheck();
286
+ });
287
+ }
288
+ onChange() {
289
+ this._emitChangeEvent();
290
+ this._controlValueAccessorChangeFn(this.value);
291
+ }
292
+ onInput() {
293
+ if (this.isPasswordMode && this._enablePasswordStrengthMeter) {
294
+ this.recalculatePasswordStrength();
295
+ }
296
+ this.showAutocompletion = this._type === INPUT_TYPES.SEARCH && this.isAutocompletable() && this.value;
297
+ this._emitChangeEvent();
298
+ this._controlValueAccessorChangeFn(this.value);
299
+ }
300
+ onFocus() {
301
+ this.focus = true;
302
+ this.isLabelActive = true;
303
+ }
304
+ onBlur() {
305
+ this.focus = false;
306
+ const inputValue = this.value;
307
+ if (!inputValue || inputValue.length === 0) {
308
+ this.isLabelActive = false;
309
+ if (this.type === INPUT_TYPES.NUMBER) {
310
+ this.value = '';
311
+ }
312
+ }
313
+ }
314
+ get noteId() {
315
+ return `${this.id}-note`;
316
+ }
317
+ getRelatedEntries() {
318
+ if (this.value) {
319
+ const lowercaseValue = this.value.toLowerCase();
320
+ const lowercaseData = this._autoCompleteData.filter((item) => item.value).map(item => {
321
+ return { ...item, original: item.value, lowercase: item.value.toLowerCase() };
322
+ });
323
+ const relatedEntries = [];
324
+ lowercaseData.forEach(lowercaseEntry => {
325
+ const matching = (lowercaseEntry.lowercase).includes(lowercaseValue);
326
+ if (matching) {
327
+ relatedEntries.push(lowercaseEntry);
328
+ }
329
+ });
330
+ return relatedEntries;
331
+ }
332
+ else {
333
+ return [];
334
+ }
335
+ }
336
+ isAutocompletable() {
337
+ if (this._autoCompleteData && this._type === INPUT_TYPES.SEARCH) {
338
+ return this._autoCompleteData.length > 0;
339
+ }
340
+ else {
341
+ return false;
342
+ }
343
+ }
344
+ onEntryClick(entry, event) {
345
+ // Se non è stato definito un link associato all'elemento dell'autocomplete, probabilmente il desiderata
346
+ // non è effettuare la navigazione al default '#', pertanto in tal caso meglio annullare la navigazione.
347
+ if (!entry.link) {
348
+ event.preventDefault();
349
+ }
350
+ this.value = entry.value;
351
+ this.showAutocompletion = false;
352
+ this.onChange();
353
+ }
354
+ /**
355
+ * indica se il campo di input è composto da altri elementi accessori come
356
+ * icone o bottoni da posizionare adiacenti al campo di input
357
+ */
358
+ get isInputGroup() {
359
+ return this._textPrefixChildren.length > 0 || this._prefixChildren.length > 0 || !!this.icon
360
+ || this._suffixChildren.length > 0 || this._textSuffixChildren.length > 0;
361
+ }
362
+ /**
363
+ * Ricalcola il punteggio di sicurezza in base al valore corrente
364
+ */
365
+ recalculatePasswordStrength() {
366
+ this.passwordScore = this._formInputPasswordUtils.calculateScore(this.value);
367
+ }
368
+ get passwordScoreText() {
369
+ return this._formInputPasswordUtils.scoreText(this.passwordScore);
370
+ }
371
+ get passwordScoreColor() {
372
+ return this._formInputPasswordUtils.scoreColor(this.passwordScore);
373
+ }
374
+ get valueLength() {
375
+ if (!this.value) {
376
+ return 0;
377
+ }
378
+ return this.value.toString().length;
379
+ }
380
+ onKeyUp(event) {
381
+ this.isCapsLockActive = event.getModifierState && event.getModifierState('CapsLock');
382
+ }
383
+ autocompleteItemTrackByValueFn(index, item) {
384
+ return item.value;
385
+ }
386
+ /**
387
+ * Incrementa il valore dell'input numerico di tanto quanto vale lo step
388
+ */
389
+ incrementNumberValue() {
390
+ if (this.type === INPUT_TYPES.NUMBER) {
391
+ const tempValue = +this.value + this.step;
392
+ if (this.max === undefined || tempValue <= this.max) {
393
+ this.value = tempValue;
394
+ }
395
+ }
396
+ }
397
+ /**
398
+ * Decrementa il valore dell'input numerico di tanto quanto vale lo step
399
+ */
400
+ decrementNumberValue() {
401
+ if (this.type === INPUT_TYPES.NUMBER) {
402
+ const tempValue = +this.value - this.step;
403
+ if (this.min === undefined || tempValue >= this.min) {
404
+ this.value = tempValue;
405
+ }
406
+ }
407
+ }
408
+ }
409
+ FormInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: FormInputComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
410
+ FormInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.11", type: FormInputComponent, selector: "it-input", inputs: { readonlyPlainText: "readonlyPlainText", enablePasswordStrengthMeter: "enablePasswordStrengthMeter", autocompleteWrapperSize: "autocompleteWrapperSize", passwordStrengthMeterConfig: "passwordStrengthMeterConfig", id: "id", name: "name", type: "type", label: "label", labelVisuallyHidden: "labelVisuallyHidden", min: "min", max: "max", step: "step", note: "note", placeholder: "placeholder", icon: "icon", disabled: "disabled", currency: "currency", percentage: "percentage", adaptive: "adaptive", readonly: "readonly", autoCompleteData: "autoCompleteData", disableCapsLockAlert: "disableCapsLockAlert", capsLockActiveLabel: "capsLockActiveLabel" }, outputs: { change: "change" }, host: { listeners: { "window:click": "onKeyUp($event)", "window:keydown": "onKeyUp($event)", "window:keyup": "onKeyUp($event)" } }, providers: [{
411
+ provide: NG_VALUE_ACCESSOR,
412
+ useExisting: forwardRef(() => FormInputComponent),
413
+ multi: true
414
+ }], queries: [{ propertyName: "_prefixChildren", predicate: ItPrefixDirective, descendants: true }, { propertyName: "_textPrefixChildren", predicate: ItTextPrefixDirective, descendants: true }, { propertyName: "_suffixChildren", predicate: ItSuffixDirective, descendants: true }, { propertyName: "_textSuffixChildren", predicate: ItTextSuffixDirective, descendants: true }], viewQueries: [{ propertyName: "_inputElement", first: true, predicate: ["inputElement"], descendants: true }], ngImport: i0, template: "<div class=\"form-group\" [class.autocomplete-wrapper-big]=\"autocompleteWrapperSize === 'big'\">\n <div class=\"input-group\" *ngIf = \"isInputGroup; else formInputWithLabel\">\n <ng-container *ngIf=\"_textPrefixChildren.length || _prefixChildren.length || icon\">\n <div class=\"input-group-prepend\">\n\n <!-- Gli elementi figli di \"it-input\" con la direttiva \"itTextPrefix\" -->\n <ng-container *ngIf=\"_textPrefixChildren.length || icon\">\n\n <div class=\"input-group-text\" >\n <ng-container *ngIf=\"icon\">\n <it-icon [icon] = \"icon\" size=\"icon-sm\"></it-icon>\n </ng-container>\n\n <ng-container *ngIf=\"_textPrefixChildren.length\">\n <ng-content select = \"[itTextPrefix]\"></ng-content>\n </ng-container>\n </div>\n </ng-container>\n \n <ng-container *ngIf=\"_prefixChildren.length\">\n <!-- Gli elementi figli di \"it-input\" con la direttiva \"itPrefix\" -->\n <ng-content select = \"[itPrefix]\"></ng-content>\n </ng-container>\n </div>\n </ng-container>\n\n <ng-container [ngTemplateOutlet]=\"formInputWithLabel\"></ng-container>\n\n <ng-container *ngIf=\"_suffixChildren.length || _textSuffixChildren.length\">\n <div class=\"input-group-append\">\n <!-- Gli elementi figli di \"it-input\" con la direttiva \"itTextSuffix\" -->\n <ng-container *ngIf=\"_textSuffixChildren.length\">\n <div class=\"input-group-text\" >\n <ng-content select = \"[itTextSuffix]\"></ng-content>\n </div>\n </ng-container>\n \n <ng-container *ngIf=\"_suffixChildren.length\">\n <!-- Gli elementi figli di \"it-input\" con la direttiva \"itSuffix\" -->\n <ng-content select = \"[itSuffix]\"></ng-content>\n </ng-container>\n </div>\n </ng-container>\n \n \n </div>\n\n\n\n <ng-template #formInput>\n <input #inputElement\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n (change)=\"onChange()\"\n (input)=\"onInput()\"\n [type]=\"type\"\n [id]=\"id\"\n [min]=\"min\"\n [max]=\"max\"\n [step]=\"step\"\n [class.focus--mouse]=\"focus\"\n [class.input-password]=\"isPasswordMode\"\n [attr.name]=\"name\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [placeholder]=\"placeholder\"\n [style.width]=\"adaptive && valueLength ? 'calc(44px + ' + valueLength + 'ch)' : null\"\n [ngClass]=\"{\n 'form-control' : (!readonly || !readonlyPlainText) && type !== INPUT_TYPES.NUMBER,\n 'form-control-plaintext' : readonly && readonlyPlainText,\n 'autocomplete' : isAutocompletable()\n }\"\n [attr.aria-describedby]=\"note ? noteId : undefined\"/> \n </ng-template>\n\n\n\n <ng-template #formInputWithLabel>\n <label [attr.for]=\"id\" *ngIf=\"label\" \n [class.visually-hidden]=\"labelVisuallyHidden\"\n [class.input-number-label]=\"type === INPUT_TYPES.NUMBER\"\n [class.active] = \"isLabelActive && !labelVisuallyHidden\" >\n {{label}}\n </label>\n \n <!-- INIZIO gestione input di tipo NUMBER -->\n\n <ng-container *ngIf=\"type === INPUT_TYPES.NUMBER; else formInput\">\n <span class=\"input-number\" \n [class.input-number-adaptive]=\"adaptive\"\n [class.input-number-currency]=\"currency\" \n [class.input-number-percentage]=\"percentage\">\n\n <ng-container [ngTemplateOutlet]=\"formInput\"></ng-container>\n\n <button class=\"input-number-add\" (click)=\"incrementNumberValue()\" focusMouse>\n <span class=\"visually-hidden\">Aumenta valore di {{step}} Euro</span>\n </button>\n <button class=\"input-number-sub\" (click)=\"decrementNumberValue()\" focusMouse>\n <span class=\"visually-hidden\">Diminuisci valore di {{step}} Euro</span>\n </button>\n </span>\n </ng-container>\n\n <!-- FINE gestione input di tipo NUMBER -->\n\n </ng-template>\n\n <small [id]=\"noteId\" class=\"form-text\" *ngIf=\"note\">\n {{note}}\n </small>\n\n\n <!-- INIZIO gestione input di tipo PASSWORD -->\n\n <ng-container *ngIf=\"isPasswordMode\">\n <!-- Icona dell'occhio per la vedere/nascondere la password -->\n <span \n class = \"password-icon\"\n aria-hidden=\"true\"\n (click)=\"isPasswordVisible = !isPasswordVisible\">\n <it-icon [icon]=\"'it-password-' + (isPasswordVisible ? 'invisible' : 'visible')\" size=\"icon-sm\" color=\"default\"></it-icon>\n </span>\n\n <!-- Indicatore di sicurezza della password -->\n <div class=\"password-strength-meter\" *ngIf=\"isPasswordMode && enablePasswordStrengthMeter\">\n <small class=\"form-text\" \n [ngClass] = \"['text-' + passwordScoreColor]\"\n *ngIf = \"passwordStrengthMeterConfig.showText\">{{ passwordScoreText }}\n </small>\n <div class=\"password-meter progress rounded-0 position-absolute\">\n <div class=\"row position-absolute w-100 m-0\">\n <div class=\"col-3 border-start border-end border-white\"></div>\n <div class=\"col-3 border-start border-end border-white\"></div>\n <div class=\"col-3 border-start border-end border-white\"></div>\n <div class=\"col-3 border-start border-end border-white\"></div>\n </div>\n\n <div class=\"progress-bar\" \n [class]=\"['bg-' + passwordScoreColor]\"\n role=\"progressbar\" [attr.aria-valuenow]=\"passwordScore >= 0 ? passwordScore : 0\" aria-valuemin=\"0\" aria-valuemax=\"100\" [style.width.%]=\"passwordScore >= 0 ? passwordScore : 0\">\n </div>\n </div>\n </div>\n\n </ng-container>\n\n <!-- FINE gestione input di tipo PASSWORD -->\n\n\n\n\n <!-- Avviso CAPS LOCK Attivo -->\n <small *ngIf=\"isCapsLockActive && !disableCapsLockAlert && type !== INPUT_TYPES.NUMBER\" class=\"password-caps form-text text-warning position-absolute bg-white w-100\">{{capsLockActiveLabel}}</small>\n\n\n\n <!-- INIZIO gestione AUTOCOMPLETAMENTO -->\n\n\n <!-- Icona lente per autocompletamento -->\n <span class=\"autocomplete-icon\" aria-hidden=\"true\" *ngIf=\"isAutocompletable()\">\n <it-icon icon = \"it-search\" size=\"icon-sm\" color=\"default\"></it-icon>\n </span>\n\n\n <!-- Lista di autocompletamento -->\n <ul class=\"autocomplete-list\" *ngIf=\"isAutocompletable()\" [class.autocomplete-list-show]=\"showAutocompletion\">\n <li *ngFor=\"let entry of getRelatedEntries(); trackBy: autocompleteItemTrackByValueFn\" (click)=\"onEntryClick(entry, $event)\">\n <a [href]=\"entry.link\" >\n <ng-container *ngTemplateOutlet=\"autocompleteItemTemplate\"></ng-container>\n </a>\n <ng-template #autocompleteItemTemplate>\n <div class=\"avatar size-sm\" *ngIf=\"entry.avatarSrcPath\">\n <img [src]=\"entry.avatarSrcPath\" [alt]=\"entry.avatarAltText\">\n </div>\n <it-icon *ngIf=\"entry.icon\" [icon]=\"entry.icon\" size=\"icon-sm\"></it-icon>\n <span class=\"autocomplete-list-text\">\n <span [innerHTML] = \"entry.original | markMatchingText: value\"></span>\n <em *ngIf=\"entry.label\">{{entry.label}}</em>\n </span>\n </ng-template>\n </li>\n </ul>\n\n</div>\n\n <!-- FINE gestione AUTOCOMPLETAMENTO -->", styles: ["label{pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.FocusMouseDirective, selector: "[focusMouse]", exportAs: ["focusMouse"] }, { kind: "component", type: i3.IconComponent, selector: "it-icon", inputs: ["rounded", "roundedColor", "icon", "wai", "size", "color", "bgColor", "padded", "expand", "position", "verticalAlign"] }, { kind: "pipe", type: i4.MarkMatchingTextPipe, name: "markMatchingText" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
415
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: FormInputComponent, decorators: [{
416
+ type: Component,
417
+ args: [{ selector: 'it-input', changeDetection: ChangeDetectionStrategy.OnPush, providers: [{
418
+ provide: NG_VALUE_ACCESSOR,
419
+ useExisting: forwardRef(() => FormInputComponent),
420
+ multi: true
421
+ }], template: "<div class=\"form-group\" [class.autocomplete-wrapper-big]=\"autocompleteWrapperSize === 'big'\">\n <div class=\"input-group\" *ngIf = \"isInputGroup; else formInputWithLabel\">\n <ng-container *ngIf=\"_textPrefixChildren.length || _prefixChildren.length || icon\">\n <div class=\"input-group-prepend\">\n\n <!-- Gli elementi figli di \"it-input\" con la direttiva \"itTextPrefix\" -->\n <ng-container *ngIf=\"_textPrefixChildren.length || icon\">\n\n <div class=\"input-group-text\" >\n <ng-container *ngIf=\"icon\">\n <it-icon [icon] = \"icon\" size=\"icon-sm\"></it-icon>\n </ng-container>\n\n <ng-container *ngIf=\"_textPrefixChildren.length\">\n <ng-content select = \"[itTextPrefix]\"></ng-content>\n </ng-container>\n </div>\n </ng-container>\n \n <ng-container *ngIf=\"_prefixChildren.length\">\n <!-- Gli elementi figli di \"it-input\" con la direttiva \"itPrefix\" -->\n <ng-content select = \"[itPrefix]\"></ng-content>\n </ng-container>\n </div>\n </ng-container>\n\n <ng-container [ngTemplateOutlet]=\"formInputWithLabel\"></ng-container>\n\n <ng-container *ngIf=\"_suffixChildren.length || _textSuffixChildren.length\">\n <div class=\"input-group-append\">\n <!-- Gli elementi figli di \"it-input\" con la direttiva \"itTextSuffix\" -->\n <ng-container *ngIf=\"_textSuffixChildren.length\">\n <div class=\"input-group-text\" >\n <ng-content select = \"[itTextSuffix]\"></ng-content>\n </div>\n </ng-container>\n \n <ng-container *ngIf=\"_suffixChildren.length\">\n <!-- Gli elementi figli di \"it-input\" con la direttiva \"itSuffix\" -->\n <ng-content select = \"[itSuffix]\"></ng-content>\n </ng-container>\n </div>\n </ng-container>\n \n \n </div>\n\n\n\n <ng-template #formInput>\n <input #inputElement\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n (change)=\"onChange()\"\n (input)=\"onInput()\"\n [type]=\"type\"\n [id]=\"id\"\n [min]=\"min\"\n [max]=\"max\"\n [step]=\"step\"\n [class.focus--mouse]=\"focus\"\n [class.input-password]=\"isPasswordMode\"\n [attr.name]=\"name\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [placeholder]=\"placeholder\"\n [style.width]=\"adaptive && valueLength ? 'calc(44px + ' + valueLength + 'ch)' : null\"\n [ngClass]=\"{\n 'form-control' : (!readonly || !readonlyPlainText) && type !== INPUT_TYPES.NUMBER,\n 'form-control-plaintext' : readonly && readonlyPlainText,\n 'autocomplete' : isAutocompletable()\n }\"\n [attr.aria-describedby]=\"note ? noteId : undefined\"/> \n </ng-template>\n\n\n\n <ng-template #formInputWithLabel>\n <label [attr.for]=\"id\" *ngIf=\"label\" \n [class.visually-hidden]=\"labelVisuallyHidden\"\n [class.input-number-label]=\"type === INPUT_TYPES.NUMBER\"\n [class.active] = \"isLabelActive && !labelVisuallyHidden\" >\n {{label}}\n </label>\n \n <!-- INIZIO gestione input di tipo NUMBER -->\n\n <ng-container *ngIf=\"type === INPUT_TYPES.NUMBER; else formInput\">\n <span class=\"input-number\" \n [class.input-number-adaptive]=\"adaptive\"\n [class.input-number-currency]=\"currency\" \n [class.input-number-percentage]=\"percentage\">\n\n <ng-container [ngTemplateOutlet]=\"formInput\"></ng-container>\n\n <button class=\"input-number-add\" (click)=\"incrementNumberValue()\" focusMouse>\n <span class=\"visually-hidden\">Aumenta valore di {{step}} Euro</span>\n </button>\n <button class=\"input-number-sub\" (click)=\"decrementNumberValue()\" focusMouse>\n <span class=\"visually-hidden\">Diminuisci valore di {{step}} Euro</span>\n </button>\n </span>\n </ng-container>\n\n <!-- FINE gestione input di tipo NUMBER -->\n\n </ng-template>\n\n <small [id]=\"noteId\" class=\"form-text\" *ngIf=\"note\">\n {{note}}\n </small>\n\n\n <!-- INIZIO gestione input di tipo PASSWORD -->\n\n <ng-container *ngIf=\"isPasswordMode\">\n <!-- Icona dell'occhio per la vedere/nascondere la password -->\n <span \n class = \"password-icon\"\n aria-hidden=\"true\"\n (click)=\"isPasswordVisible = !isPasswordVisible\">\n <it-icon [icon]=\"'it-password-' + (isPasswordVisible ? 'invisible' : 'visible')\" size=\"icon-sm\" color=\"default\"></it-icon>\n </span>\n\n <!-- Indicatore di sicurezza della password -->\n <div class=\"password-strength-meter\" *ngIf=\"isPasswordMode && enablePasswordStrengthMeter\">\n <small class=\"form-text\" \n [ngClass] = \"['text-' + passwordScoreColor]\"\n *ngIf = \"passwordStrengthMeterConfig.showText\">{{ passwordScoreText }}\n </small>\n <div class=\"password-meter progress rounded-0 position-absolute\">\n <div class=\"row position-absolute w-100 m-0\">\n <div class=\"col-3 border-start border-end border-white\"></div>\n <div class=\"col-3 border-start border-end border-white\"></div>\n <div class=\"col-3 border-start border-end border-white\"></div>\n <div class=\"col-3 border-start border-end border-white\"></div>\n </div>\n\n <div class=\"progress-bar\" \n [class]=\"['bg-' + passwordScoreColor]\"\n role=\"progressbar\" [attr.aria-valuenow]=\"passwordScore >= 0 ? passwordScore : 0\" aria-valuemin=\"0\" aria-valuemax=\"100\" [style.width.%]=\"passwordScore >= 0 ? passwordScore : 0\">\n </div>\n </div>\n </div>\n\n </ng-container>\n\n <!-- FINE gestione input di tipo PASSWORD -->\n\n\n\n\n <!-- Avviso CAPS LOCK Attivo -->\n <small *ngIf=\"isCapsLockActive && !disableCapsLockAlert && type !== INPUT_TYPES.NUMBER\" class=\"password-caps form-text text-warning position-absolute bg-white w-100\">{{capsLockActiveLabel}}</small>\n\n\n\n <!-- INIZIO gestione AUTOCOMPLETAMENTO -->\n\n\n <!-- Icona lente per autocompletamento -->\n <span class=\"autocomplete-icon\" aria-hidden=\"true\" *ngIf=\"isAutocompletable()\">\n <it-icon icon = \"it-search\" size=\"icon-sm\" color=\"default\"></it-icon>\n </span>\n\n\n <!-- Lista di autocompletamento -->\n <ul class=\"autocomplete-list\" *ngIf=\"isAutocompletable()\" [class.autocomplete-list-show]=\"showAutocompletion\">\n <li *ngFor=\"let entry of getRelatedEntries(); trackBy: autocompleteItemTrackByValueFn\" (click)=\"onEntryClick(entry, $event)\">\n <a [href]=\"entry.link\" >\n <ng-container *ngTemplateOutlet=\"autocompleteItemTemplate\"></ng-container>\n </a>\n <ng-template #autocompleteItemTemplate>\n <div class=\"avatar size-sm\" *ngIf=\"entry.avatarSrcPath\">\n <img [src]=\"entry.avatarSrcPath\" [alt]=\"entry.avatarAltText\">\n </div>\n <it-icon *ngIf=\"entry.icon\" [icon]=\"entry.icon\" size=\"icon-sm\"></it-icon>\n <span class=\"autocomplete-list-text\">\n <span [innerHTML] = \"entry.original | markMatchingText: value\"></span>\n <em *ngIf=\"entry.label\">{{entry.label}}</em>\n </span>\n </ng-template>\n </li>\n </ul>\n\n</div>\n\n <!-- FINE gestione AUTOCOMPLETAMENTO -->", styles: ["label{pointer-events:none}\n"] }]
422
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { _prefixChildren: [{
423
+ type: ContentChildren,
424
+ args: [ItPrefixDirective, { descendants: true }]
425
+ }], _textPrefixChildren: [{
426
+ type: ContentChildren,
427
+ args: [ItTextPrefixDirective, { descendants: true }]
428
+ }], _suffixChildren: [{
429
+ type: ContentChildren,
430
+ args: [ItSuffixDirective, { descendants: true }]
431
+ }], _textSuffixChildren: [{
432
+ type: ContentChildren,
433
+ args: [ItTextSuffixDirective, { descendants: true }]
434
+ }], _inputElement: [{
435
+ type: ViewChild,
436
+ args: ['inputElement', { static: false }]
437
+ }], readonlyPlainText: [{
438
+ type: Input
439
+ }], enablePasswordStrengthMeter: [{
440
+ type: Input
441
+ }], autocompleteWrapperSize: [{
442
+ type: Input
443
+ }], passwordStrengthMeterConfig: [{
444
+ type: Input
445
+ }], id: [{
446
+ type: Input
447
+ }], name: [{
448
+ type: Input
449
+ }], type: [{
450
+ type: Input
451
+ }], label: [{
452
+ type: Input
453
+ }], labelVisuallyHidden: [{
454
+ type: Input
455
+ }], min: [{
456
+ type: Input
457
+ }], max: [{
458
+ type: Input
459
+ }], step: [{
460
+ type: Input
461
+ }], note: [{
462
+ type: Input
463
+ }], placeholder: [{
464
+ type: Input
465
+ }], icon: [{
466
+ type: Input
467
+ }], disabled: [{
468
+ type: Input
469
+ }], currency: [{
470
+ type: Input
471
+ }], percentage: [{
472
+ type: Input
473
+ }], adaptive: [{
474
+ type: Input
475
+ }], readonly: [{
476
+ type: Input
477
+ }], autoCompleteData: [{
478
+ type: Input
479
+ }], change: [{
480
+ type: Output
481
+ }], disableCapsLockAlert: [{
482
+ type: Input
483
+ }], capsLockActiveLabel: [{
484
+ type: Input
485
+ }], onKeyUp: [{
486
+ type: HostListener,
487
+ args: ['window:click', ['$event']]
488
+ }, {
489
+ type: HostListener,
490
+ args: ['window:keydown', ['$event']]
491
+ }, {
492
+ type: HostListener,
493
+ args: ['window:keyup', ['$event']]
494
+ }] } });
495
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input.component.js","sourceRoot":"","sources":["../../../../../projects/design-angular-kit/src/lib/form-input/form-input.component.ts","../../../../../projects/design-angular-kit/src/lib/form-input/form-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, Input, ChangeDetectionStrategy, forwardRef,\n  AfterContentInit, Output, EventEmitter, ChangeDetectorRef, ViewChild, ElementRef, ContentChildren, QueryList, AfterContentChecked, OnInit, HostListener\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\nimport { merge } from 'rxjs';\nimport { InputType, INPUT_TYPES } from '../models/InputType';\nimport { Util } from '../util/util';\nimport { FormInputPasswordUtils } from './form-input-password.utils';\nimport { ItPrefixDirective } from './it-prefix.directive';\nimport { ItSuffixDirective } from './it-suffix.directive';\nimport { ItTextPrefixDirective } from './it-text-prefix.directive';\nimport { ItTextSuffixDirective } from './it-text-suffix.directive';\n\nlet identifier = 0;\n\nexport class FormInputChange {\n  constructor(\n    public source: FormInputComponent,\n    public value: any\n  ) { }\n}\n\nexport interface PasswordStrengthMeterConfig {\n  /** Testo per il punteggio di forza della password minimo */\n  shortPass: string,\n  /** Testo per punteggio di forza della password basso\t */\n  badPass: string,\n  /** Testo per punteggio di forza della password buono\t */\n  goodPass: string,\n  /** Testo per il punteggio di forza della password massimo\t */\n  strongPass: string,\n  /** Testo di aiuto */\n  enterPass: string,\n  /** Testo per avvertire che il CAPS LOCK è inserito\t */\n  alertCaps: string,\n  /** Lunghezza minima per il calcolo della forza della password (soglia password molto debole)\t */\n  showText: boolean,\n  /** Attiva/disattiva la visibilità dei messaggi di errore\t */\n  minimumLength: number,\n}\n\n\n/**\n * Elemento disponibile per l'autocompletamento del it-form-input\n */\nexport interface AutoCompleteItem {\n  /** Valore voce di autocompletamento */\n  value: string;\n  /** Opzionale. Path in cui ricercare l'immagine dell'avatar da posizionare a sinistra della voce di autocompletamento */\n  avatarSrcPath?: string;\n  /** Opzionale. Testo in alternativa dell'avatar per accessibilità */\n  avatarAltText?: string;\n  /** Opzionale. Icona posizionata a sinistra della voce di autocompletamento */\n  icon?: string;\n  /** Opzionale. Label posizionata a destra della voce di autocompletamento */\n  label?: string;\n  /** Opzionale. Link relativo all'elemento */\n  link?: string\n}\n\n/**\n * Elementi e stili per la creazione di input accessibili e responsivi.\n */\n@Component({\n  selector: 'it-input',\n  templateUrl: './form-input.component.html',\n  styleUrls: ['./form-input.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => FormInputComponent),\n    multi: true\n  }]\n})\nexport class FormInputComponent implements OnInit, AfterContentInit, ControlValueAccessor {\n\n  private _formInputPasswordUtils: FormInputPasswordUtils;\n\n  @ContentChildren(ItPrefixDirective, {descendants: true}) _prefixChildren: QueryList<ItPrefixDirective>;\n  @ContentChildren(ItTextPrefixDirective, {descendants: true}) _textPrefixChildren: QueryList<ItTextPrefixDirective>;\n\n  @ContentChildren(ItSuffixDirective, {descendants: true}) _suffixChildren: QueryList<ItSuffixDirective>;\n  @ContentChildren(ItTextSuffixDirective, {descendants: true}) _textSuffixChildren: QueryList<ItTextSuffixDirective>;\n\n  INPUT_TYPES = INPUT_TYPES;\n\n  @ViewChild('inputElement', { static: false })\n  private _inputElement: ElementRef;\n\n  /**\n   * Opzionale. Indica se mostrare gli input readonly nella forma stilizzata come testo normale\n   */\n  @Input()\n  get readonlyPlainText(): boolean { return this._readonlyPlainText; }\n  set readonlyPlainText(value: boolean) { this._readonlyPlainText = Util.coerceBooleanProperty(value); }\n  private _readonlyPlainText: boolean = false;\n\n\n  /**\n   * Opzionale. Indica se abilitare il controllo sulla sicurezza della password\n   */\n  @Input()\n  get enablePasswordStrengthMeter(): boolean { return this._enablePasswordStrengthMeter; }\n  set enablePasswordStrengthMeter(value: boolean) { this._enablePasswordStrengthMeter = Util.coerceBooleanProperty(value); }\n  private _enablePasswordStrengthMeter: boolean = false;\n\n  /**\n   * Punteggio di sicurezza calcolato in base alla password immessa se enablePasswordStrengthMeter ha valore true\n   */\n  passwordScore: number = 0;\n\n  /**\n   * Dimensione dell'input di autocomplete. Di default ha dimensione standard.\n   */\n  @Input() autocompleteWrapperSize: 'big' | 'default' = 'default';\n\n  private _passwordStrengthMeterConfig: PasswordStrengthMeterConfig = FormInputPasswordUtils.DEFAULT_CONFIG;\n\n  @Input() set passwordStrengthMeterConfig(newConfig: PasswordStrengthMeterConfig) {\n    this._passwordStrengthMeterConfig = {...this._passwordStrengthMeterConfig, ...newConfig};\n  }\n\n  get passwordStrengthMeterConfig(): PasswordStrengthMeterConfig {\n    return this._passwordStrengthMeterConfig;\n  }\n\n  /**\n   * Indica l'id dell'elemento HTML\n   */\n  @Input()\n  get id(): string {\n    return this._id;\n  }\n  set id(value: string) {\n    this._id = value;\n  }\n  private _id = `form-input-${identifier++}`;\n\n  /**\n   * Indica l'attributo name del componente HTML\n   */\n  @Input()\n  get name(): string {\n    return this._name;\n  }\n  set name(value: string) {\n    this._name = value;\n  }\n  private _name: string;\n\n  /**\n   * Indica il tipo di campo. Puo' assumere i valori text, email, password e number\n   */\n  @Input()\n  get type(): string {\n    return this._type;\n  }\n  set type(value: string) {\n    if (InputType.is(value)) {\n      if (value === INPUT_TYPES.NUMBER) {\n        if (isNaN(Number(this.value))) {\n          this.value = '';\n          this.onChange();\n        }\n      }\n      this._type = value;\n    } else {\n      this._type = INPUT_TYPES.TEXT;\n    }\n\n    this._isPasswordMode = this._type === INPUT_TYPES.PASSWORD;\n    this._isPasswordVisible = false;\n    this.showAutocompletion = false;\n  }\n  private _type = INPUT_TYPES.TEXT;\n\n  /**\n   * Indica il valore della label da visualizzare\n   */\n  @Input()\n  get label(): string { return this._label; }\n  set label(value: string) { this._label = value; }\n  private _label: string;\n\n  /**\n   * Indica se la label dell'input deve essere visualizzata dall'utente o solamente visibile per lo screen reader\n   */\n  @Input()\n  get labelVisuallyHidden(): boolean { return this._labelVisuallyHidden; }\n  set labelVisuallyHidden(value: boolean) { this._labelVisuallyHidden = value; }\n  private _labelVisuallyHidden: boolean = false;\n\n\n  /**\n   * Indica il valore che avrà l'attributo HTML \"min\" per l'input di tipo number\n   */\n  @Input()\n  get min(): number { return this._min; }\n  set min(value: number) { this._min = Util.coerceNumberProperty(value); }\n  private _min: number;\n   \n  /**\n   * Indica il valore che avrà l'attributo HTML \"max\" per l'input di tipo number\n   */\n  @Input()\n  get max(): number { return this._max; }\n  set max(value: number) { this._max = Util.coerceNumberProperty(value); }\n  private _max: number;\n\n  /**\n   * Indica il valore che avrà l'attributo HTML \"step\" per l'input di tipo number\n   */\n  @Input()\n  get step(): number { return this._step; }\n  set step(value: number) { this._step = Util.coerceNumberProperty(value); }\n  private _step: number = 1;\n\n\n  /**\n   * Indica il testo di aiuto sotto la input\n   */\n  @Input()\n  get note(): string { return this._note; }\n  set note(value: string) { this._note = value; }\n  private _note: string;\n\n  /**\n   * Indica il testo presente nel campo vuoto. Nel caso sia già presente la label, il placeholder non verrà mostrato\n   */\n  @Input()\n  get placeholder(): string {\n    return this._placeholder || '';\n  }\n  set placeholder(value: string) { this._placeholder = value; }\n  private _placeholder: string;\n\n  /**\n   * Indica l'icona da visualizzare a sinistra del campo di input\n   */\n  @Input()\n  get icon(): string { return this._icon; }\n  set icon(value: string) { this._icon = value; }\n  private _icon: string;\n\n  /**\n   * Opzionale.\n   * Indica se il campo in questione è disabilitato.\n   * Accetta una espressione booleana o può essere usato come attributo senza valore\n   */\n  @Input()\n  get disabled(): boolean { return this._disabled; }\n  set disabled(value: boolean) { this._disabled = Util.coerceBooleanProperty(value); }\n  private _disabled = false;\n\n   /**\n   * Opzionale.\n   * Nel caso di input numerico, indica se il campo è una valuta.\n   * Accetta una espressione booleana o può essere usato come attributo senza valore\n   */\n  @Input()\n  get currency(): boolean { return this._currency; }\n  set currency(value: boolean) { this._currency = Util.coerceBooleanProperty(value); }\n  private _currency = false;\n\n   /**\n   * Opzionale.\n   * Nel caso di input numerico, indica se il campo è una percentuale.\n   * Accetta una espressione booleana o può essere usato come attributo senza valore\n   */\n  @Input()\n  get percentage(): boolean { return this._percentage; }\n  set percentage(value: boolean) { this._percentage = Util.coerceBooleanProperty(value); }\n  private _percentage = false;\n\n  /**\n   * Opzionale.\n   * Nel caso di input numerico, indica se il campo si deve ridimensionare automaticamente a seconda del valore contenuto in esso.\n   * Accetta una espressione booleana o può essere usato come attributo senza valore\n   */\n  @Input()\n  get adaptive(): boolean { return this._adaptive; }\n  set adaptive(value: boolean) { this._adaptive = Util.coerceBooleanProperty(value); }\n  private _adaptive = false;\n\n  /**\n   * Opzionale.\n   * Indica se il campo in questione è di sola lettura.\n   * Accetta una espressione booleana o può essere usato come attributo senza valore\n   */\n  @Input()\n  get readonly(): boolean { return this._readonly; }\n  set readonly(value: boolean) { this._readonly = Util.coerceBooleanProperty(value); }\n  private _readonly = false;\n\n  get value(): any { return this._inputElement?.nativeElement?.value; }\n  set value(value: any) { \n    if(this._inputElement) {\n      this._inputElement.nativeElement.value = value;\n    } \n  }\n\n  /**\n   * Opzionale.\n   * Disponibile solo se il type è search.\n   * Indica la lista di elementi ricercabili su cui basare il sistema di autocompletamento della input\n   */\n  @Input()\n  get autoCompleteData(): Array<AutoCompleteItem> { return this._autoCompleteData; }\n  set autoCompleteData(value: Array<AutoCompleteItem>) { this._autoCompleteData = value; }\n  private _autoCompleteData: Array<AutoCompleteItem>;\n\n  /**\n   * Evento emesso quando il valore dell'input cambia.\n   * Gli eventi di change sono emessi soltanto quando il valore cambia a causa dell'interazione dell'utente\n   * con il campo d'input.\n   */\n  @Output()\n  readonly change: EventEmitter<FormInputChange> = new EventEmitter<FormInputChange>();\n\n  /**\n   * Opzionale.\n   * Indica se disabilitare l'avviso di CAPS LOCK attivo\n   * Accetta una espressione booleana o può essere usato come attributo senza valore\n   */\n  @Input()\n  get disableCapsLockAlert(): boolean { return this._disableCapsLockAlert; }\n  set disableCapsLockAlert(value: boolean) { this._disableCapsLockAlert = Util.coerceBooleanProperty(value); }\n  private _disableCapsLockAlert = false;\n\n  /**\n   * Indica se è attivo il CAPS LOCK\n   */\n  isCapsLockActive = false;\n\n  /**\n   * La label da mostrare in caso sia attivo il CAPS LOCK\n   */\n  @Input() capsLockActiveLabel = 'CAPS LOCK inserito';\n\n  get isLabelActive() {\n    return this._isLabelActive;\n  }\n  set isLabelActive(value: boolean) {\n    const newValue = Util.coerceBooleanProperty(value);\n   \n    // In alcuni casi la label deve essere sempre posizionata sopra l'input per evitare sovrapposizioni \n    // di testo, come in caso di presenza del placeholder o per l'input di tipo \"date\" o \"time\"\n    if(newValue || (!this.value && !this.placeholder && this.type !== INPUT_TYPES.TIME && \n                    this.type !== INPUT_TYPES.DATE && this.type !== INPUT_TYPES.NUMBER)) {\n      this._isLabelActive = newValue;\n    } else {\n      this._isLabelActive = true;\n    }\n  }\n  private _isLabelActive: boolean;\n\n\n  get isPasswordMode() {\n    return this._isPasswordMode;\n  }\n  set isPasswordMode(value: boolean) {\n    this._isPasswordMode = Util.coerceBooleanProperty(value);\n  }\n  private _isPasswordMode = false;\n\n  get isPasswordVisible() {\n    return this._isPasswordVisible;\n  }\n  set isPasswordVisible(value: boolean) {\n    this._isPasswordVisible = Util.coerceBooleanProperty(value);\n    this._type = this._isPasswordVisible ? INPUT_TYPES.TEXT : INPUT_TYPES.PASSWORD;\n  }\n  private _isPasswordVisible = false;\n\n  showAutocompletion = false;\n  private _isInitialized = false;\n  private _controlValueAccessorChangeFn: (value: any) => void = () => { };\n  private _onTouched: () => any = () => { };\n\n  /** Indica se è stato effettuato il focus sul campo di input */\n  focus: boolean = false;\n\n  private _emitChangeEvent(): void {\n    if (this._isInitialized) {\n      this.change.emit(new FormInputChange(this, this.value));\n    }\n  }\n\n  ngOnInit(): void {\n    this.isLabelActive = false;\n    this._formInputPasswordUtils = new FormInputPasswordUtils(this.passwordStrengthMeterConfig);\n  }\n\n\n  writeValue(value: any): void {\n    this.value = value;\n    if (this.value) {\n      this.isLabelActive = true;\n    }\n\n    this.onChange();\n    if (this._isInitialized) {\n      this._changeDetector.detectChanges();\n    }\n  }\n\n  registerOnChange(fn: (value: any) => void): void {\n    this._controlValueAccessorChangeFn = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouched = fn;\n  }\n\n  constructor(private _changeDetector: ChangeDetectorRef) { }\n\n\n  ngAfterContentInit(): void {\n    this._isInitialized = true;\n\n    // Run change detection if the suffix or prefix changes.\n    merge(this._prefixChildren.changes, this._suffixChildren.changes,\n          this._textPrefixChildren.changes, this._textSuffixChildren.changes\n    ).subscribe(() => {\n      this._changeDetector.markForCheck();\n    });\n    \n  }\n\n  onChange() {\n    this._emitChangeEvent();\n    this._controlValueAccessorChangeFn(this.value);\n  }\n\n  onInput() {\n    if(this.isPasswordMode && this._enablePasswordStrengthMeter) {\n      this.recalculatePasswordStrength();\n    }\n\n    this.showAutocompletion = this._type === INPUT_TYPES.SEARCH && this.isAutocompletable() && this.value;\n   \n    this._emitChangeEvent();\n    this._controlValueAccessorChangeFn(this.value);\n  }\n\n  onFocus() {\n    this.focus = true;\n    this.isLabelActive = true;\n  }\n\n  onBlur() {\n    this.focus = false;\n    const inputValue: string = this.value;\n    if (!inputValue || inputValue.length === 0) {\n     \n      this.isLabelActive = false;\n      \n      if (this.type === INPUT_TYPES.NUMBER) {\n        this.value = '';\n      }\n    }\n  }\n\n  get noteId() {\n    return `${this.id}-note`;\n  }\n\n  getRelatedEntries() {\n    if (this.value) {\n      const lowercaseValue = this.value.toLowerCase();\n      const lowercaseData = this._autoCompleteData.filter((item) => item.value).map(item => {\n        return { ...item, original : item.value, lowercase : item.value.toLowerCase() };\n      });\n\n      const relatedEntries = [];\n      lowercaseData.forEach(lowercaseEntry => {\n        const matching = (lowercaseEntry.lowercase).includes(lowercaseValue);\n        if (matching) {\n          relatedEntries.push(lowercaseEntry);\n        }\n      });\n\n      return relatedEntries;\n    } else {\n      return [];\n    }\n  }\n\n  isAutocompletable() {\n    if (this._autoCompleteData && this._type === INPUT_TYPES.SEARCH) {\n      return this._autoCompleteData.length > 0;\n    } else {\n      return false;\n    }\n  }\n\n  onEntryClick(entry: AutoCompleteItem, event: Event) {\n    // Se non è stato definito un link associato all'elemento dell'autocomplete, probabilmente il desiderata \n    // non è effettuare la navigazione al default '#', pertanto in tal caso meglio annullare la navigazione.\n    if(!entry.link) {\n      event.preventDefault();\n    }\n    this.value = entry.value;\n    this.showAutocompletion = false;\n    this.onChange();\n  }\n\n  /**\n   * indica se il campo di input è composto da altri elementi accessori come \n   * icone o bottoni da posizionare adiacenti al campo di input\n   */\n  get isInputGroup(): boolean {\n    return  this._textPrefixChildren.length > 0 || this._prefixChildren.length > 0 || !!this.icon \n            || this._suffixChildren.length > 0 || this._textSuffixChildren.length > 0;\n  }\n\n\n  /**\n   * Ricalcola il punteggio di sicurezza in base al valore corrente\n   */\n  recalculatePasswordStrength(): void {\n    this.passwordScore = this._formInputPasswordUtils.calculateScore(this.value);\n  }\n  \n\n  get passwordScoreText(): string {\n    return this._formInputPasswordUtils.scoreText(this.passwordScore);\n  }\n\n  get passwordScoreColor(): string {\n    return this._formInputPasswordUtils.scoreColor(this.passwordScore);\n  }\n\n  get valueLength(): number {\n    if(!this.value) {\n      return 0;\n    }\n    return (this.value as string | number).toString().length;\n  }\n \n\n  @HostListener('window:click', ['$event'])\n  @HostListener('window:keydown', ['$event'])\n  @HostListener('window:keyup', ['$event'])\n  onKeyUp(event: KeyboardEvent): void {\n    this.isCapsLockActive = event.getModifierState && event.getModifierState('CapsLock');\n  }\n\n\n  autocompleteItemTrackByValueFn(index: number, item: AutoCompleteItem) {\n    return item.value;\n  }\n\n\n  /**\n   * Incrementa il valore dell'input numerico di tanto quanto vale lo step\n   */\n  incrementNumberValue(): void {\n    if(this.type === INPUT_TYPES.NUMBER) {\n      const tempValue = +this.value + this.step;\n      if(this.max === undefined || tempValue <= this.max) {\n        this.value = tempValue;\n      }\n    }\n  }\n\n  /**\n   * Decrementa il valore dell'input numerico di tanto quanto vale lo step\n   */\n  decrementNumberValue(): void {\n    if(this.type === INPUT_TYPES.NUMBER ) {\n      const tempValue = +this.value - this.step;\n      if(this.min === undefined || tempValue >= this.min) {\n        this.value = tempValue;\n      }\n    }\n  }\n}\n\n","<div class=\"form-group\" [class.autocomplete-wrapper-big]=\"autocompleteWrapperSize === 'big'\">\n  <div class=\"input-group\" *ngIf = \"isInputGroup; else formInputWithLabel\">\n      <ng-container *ngIf=\"_textPrefixChildren.length || _prefixChildren.length || icon\">\n        <div class=\"input-group-prepend\">\n\n          <!-- Gli elementi figli di \"it-input\" con la direttiva \"itTextPrefix\"  -->\n          <ng-container *ngIf=\"_textPrefixChildren.length || icon\">\n\n            <div class=\"input-group-text\" >\n              <ng-container *ngIf=\"icon\">\n                <it-icon [icon] = \"icon\" size=\"icon-sm\"></it-icon>\n              </ng-container>\n\n              <ng-container *ngIf=\"_textPrefixChildren.length\">\n                <ng-content select = \"[itTextPrefix]\"></ng-content>\n              </ng-container>\n            </div>\n          </ng-container>\n         \n          <ng-container *ngIf=\"_prefixChildren.length\">\n            <!-- Gli elementi figli di \"it-input\" con la direttiva \"itPrefix\"  -->\n            <ng-content select = \"[itPrefix]\"></ng-content>\n          </ng-container>\n        </div>\n      </ng-container>\n\n      <ng-container [ngTemplateOutlet]=\"formInputWithLabel\"></ng-container>\n\n      <ng-container *ngIf=\"_suffixChildren.length || _textSuffixChildren.length\">\n        <div  class=\"input-group-append\">\n          <!-- Gli elementi figli di \"it-input\" con la direttiva \"itTextSuffix\"  -->\n          <ng-container *ngIf=\"_textSuffixChildren.length\">\n            <div class=\"input-group-text\" >\n              <ng-content select = \"[itTextSuffix]\"></ng-content>\n            </div>\n          </ng-container>\n         \n          <ng-container *ngIf=\"_suffixChildren.length\">\n            <!-- Gli elementi figli di \"it-input\" con la direttiva \"itSuffix\"  -->\n            <ng-content select = \"[itSuffix]\"></ng-content>\n          </ng-container>\n        </div>\n      </ng-container>\n      \n    \n  </div>\n\n\n\n  <ng-template #formInput>\n      <input #inputElement\n        (focus)=\"onFocus()\"\n        (blur)=\"onBlur()\"\n        (change)=\"onChange()\"\n        (input)=\"onInput()\"\n        [type]=\"type\"\n        [id]=\"id\"\n        [min]=\"min\"\n        [max]=\"max\"\n        [step]=\"step\"\n        [class.focus--mouse]=\"focus\"\n        [class.input-password]=\"isPasswordMode\"\n        [attr.name]=\"name\"\n        [disabled]=\"disabled\"\n        [readonly]=\"readonly\"\n        [placeholder]=\"placeholder\"\n        [style.width]=\"adaptive && valueLength ? 'calc(44px + ' + valueLength + 'ch)' : null\"\n        [ngClass]=\"{\n          'form-control' : (!readonly || !readonlyPlainText) && type !== INPUT_TYPES.NUMBER,\n          'form-control-plaintext' : readonly && readonlyPlainText,\n          'autocomplete' : isAutocompletable()\n        }\"\n      [attr.aria-describedby]=\"note ? noteId : undefined\"/>  \n  </ng-template>\n\n\n\n  <ng-template #formInputWithLabel>\n      <label  [attr.for]=\"id\" *ngIf=\"label\" \n              [class.visually-hidden]=\"labelVisuallyHidden\"\n              [class.input-number-label]=\"type === INPUT_TYPES.NUMBER\"\n              [class.active] = \"isLabelActive && !labelVisuallyHidden\" >\n        {{label}}\n      </label>\n    \n      <!-- INIZIO gestione input di tipo NUMBER -->\n\n      <ng-container *ngIf=\"type === INPUT_TYPES.NUMBER; else formInput\">\n        <span class=\"input-number\" \n              [class.input-number-adaptive]=\"adaptive\"\n              [class.input-number-currency]=\"currency\" \n              [class.input-number-percentage]=\"percentage\">\n\n          <ng-container [ngTemplateOutlet]=\"formInput\"></ng-container>\n\n          <button class=\"input-number-add\" (click)=\"incrementNumberValue()\" focusMouse>\n            <span class=\"visually-hidden\">Aumenta valore di {{step}} Euro</span>\n          </button>\n          <button class=\"input-number-sub\" (click)=\"decrementNumberValue()\" focusMouse>\n            <span class=\"visually-hidden\">Diminuisci valore di {{step}} Euro</span>\n          </button>\n        </span>\n      </ng-container>\n\n    <!-- FINE gestione input di tipo NUMBER -->\n\n  </ng-template>\n\n  <small [id]=\"noteId\" class=\"form-text\" *ngIf=\"note\">\n    {{note}}\n  </small>\n\n\n  <!-- INIZIO gestione input di tipo PASSWORD -->\n\n  <ng-container *ngIf=\"isPasswordMode\">\n    <!-- Icona dell'occhio per la vedere/nascondere la password -->\n    <span \n      class = \"password-icon\"\n      aria-hidden=\"true\"\n      (click)=\"isPasswordVisible = !isPasswordVisible\">\n      <it-icon [icon]=\"'it-password-' + (isPasswordVisible ? 'invisible' : 'visible')\" size=\"icon-sm\" color=\"default\"></it-icon>\n    </span>\n\n    <!-- Indicatore di sicurezza della password -->\n    <div class=\"password-strength-meter\" *ngIf=\"isPasswordMode && enablePasswordStrengthMeter\">\n      <small class=\"form-text\" \n        [ngClass] = \"['text-' + passwordScoreColor]\"\n        *ngIf = \"passwordStrengthMeterConfig.showText\">{{ passwordScoreText }}\n      </small>\n      <div class=\"password-meter progress rounded-0 position-absolute\">\n        <div class=\"row position-absolute w-100 m-0\">\n          <div class=\"col-3 border-start border-end border-white\"></div>\n          <div class=\"col-3 border-start border-end border-white\"></div>\n          <div class=\"col-3 border-start border-end border-white\"></div>\n          <div class=\"col-3 border-start border-end border-white\"></div>\n        </div>\n\n        <div class=\"progress-bar\" \n          [class]=\"['bg-' + passwordScoreColor]\"\n          role=\"progressbar\" [attr.aria-valuenow]=\"passwordScore >= 0 ? passwordScore : 0\" aria-valuemin=\"0\" aria-valuemax=\"100\" [style.width.%]=\"passwordScore >= 0 ? passwordScore : 0\">\n        </div>\n      </div>\n    </div>\n\n  </ng-container>\n\n <!-- FINE gestione input di tipo PASSWORD -->\n\n\n\n\n  <!-- Avviso CAPS LOCK Attivo -->\n  <small *ngIf=\"isCapsLockActive && !disableCapsLockAlert && type !== INPUT_TYPES.NUMBER\" class=\"password-caps form-text text-warning position-absolute bg-white w-100\">{{capsLockActiveLabel}}</small>\n\n\n\n  <!-- INIZIO gestione AUTOCOMPLETAMENTO -->\n\n\n  <!-- Icona lente per autocompletamento -->\n  <span class=\"autocomplete-icon\" aria-hidden=\"true\" *ngIf=\"isAutocompletable()\">\n    <it-icon icon = \"it-search\" size=\"icon-sm\" color=\"default\"></it-icon>\n  </span>\n\n\n  <!-- Lista di autocompletamento -->\n  <ul class=\"autocomplete-list\" *ngIf=\"isAutocompletable()\"  [class.autocomplete-list-show]=\"showAutocompletion\">\n    <li *ngFor=\"let entry of getRelatedEntries(); trackBy: autocompleteItemTrackByValueFn\" (click)=\"onEntryClick(entry, $event)\">\n      <a [href]=\"entry.link\" >\n        <ng-container *ngTemplateOutlet=\"autocompleteItemTemplate\"></ng-container>\n      </a>\n      <ng-template #autocompleteItemTemplate>\n        <div class=\"avatar size-sm\" *ngIf=\"entry.avatarSrcPath\">\n          <img [src]=\"entry.avatarSrcPath\" [alt]=\"entry.avatarAltText\">\n        </div>\n        <it-icon *ngIf=\"entry.icon\" [icon]=\"entry.icon\" size=\"icon-sm\"></it-icon>\n        <span class=\"autocomplete-list-text\">\n          <span [innerHTML] = \"entry.original | markMatchingText: value\"></span>\n          <em *ngIf=\"entry.label\">{{entry.label}}</em>\n        </span>\n      </ng-template>\n    </li>\n  </ul>\n\n</div>\n\n  <!-- FINE gestione AUTOCOMPLETAMENTO -->"]}