design-angular-kit 0.13.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 (207) 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 +6 -2
  64. package/lib/collapse/collapse-item.component.d.ts +16 -8
  65. package/lib/collapse/collapse.config.d.ts +6 -0
  66. package/lib/collapse/collapse.directive.d.ts +13 -28
  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 +16 -2
  106. package/bundles/design-angular-kit.umd.js +0 -6258
  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/collapse/collapse-group.component.js +0 -87
  119. package/esm2015/lib/collapse/collapse-item.component.js +0 -148
  120. package/esm2015/lib/collapse/collapse.directive.js +0 -153
  121. package/esm2015/lib/design-angular-kit.module.js +0 -90
  122. package/esm2015/lib/dropdown/dropdown-divider.component.js +0 -18
  123. package/esm2015/lib/dropdown/dropdown-header.component.js +0 -29
  124. package/esm2015/lib/dropdown/dropdown-item.component.js +0 -157
  125. package/esm2015/lib/dropdown/dropdown.component.js +0 -248
  126. package/esm2015/lib/form-input/form-input.component.js +0 -489
  127. package/esm2015/lib/models/ButtonSize.js +0 -25
  128. package/esm2015/lib/models/IconPosition.js +0 -21
  129. package/esm2015/lib/models/InputType.js +0 -33
  130. package/esm2015/lib/models/InteractionTrigger.js +0 -35
  131. package/esm2015/lib/models/ThemeColor.js +0 -45
  132. package/esm2015/lib/popover/popover.component.js +0 -134
  133. package/esm2015/lib/popover/popover.config.js +0 -35
  134. package/esm2015/lib/popover/popover.directive.js +0 -433
  135. package/esm2015/lib/popover/popup.js +0 -105
  136. package/esm2015/lib/popover/positioning.js +0 -349
  137. package/esm2015/lib/popover/triggers.js +0 -99
  138. package/esm2015/lib/progress-bar/progress-bar.component.js +0 -170
  139. package/esm2015/lib/radio/radio.component.js +0 -526
  140. package/esm2015/lib/radio/unique-selection-dispatcher.js +0 -70
  141. package/esm2015/lib/tabs/tab-group.component.js +0 -339
  142. package/esm2015/lib/tabs/tab.component.js +0 -143
  143. package/esm2015/lib/toggle/toggle.component.js +0 -173
  144. package/esm2015/lib/tooltip/popup.js +0 -105
  145. package/esm2015/lib/tooltip/positioning.js +0 -349
  146. package/esm2015/lib/tooltip/tooltip.component.js +0 -77
  147. package/esm2015/lib/tooltip/tooltip.config.js +0 -31
  148. package/esm2015/lib/tooltip/tooltip.directive.js +0 -384
  149. package/esm2015/lib/tooltip/triggers.js +0 -99
  150. package/esm2015/lib/util/util.js +0 -30
  151. package/esm2015/public_api.js +0 -31
  152. package/esm5/design-angular-kit.js +0 -14
  153. package/esm5/lib/badge/badge.directive.js +0 -145
  154. package/esm5/lib/breadcrumb/breadcrumb-item.component.js +0 -135
  155. package/esm5/lib/breadcrumb/breadcrumb.component.js +0 -164
  156. package/esm5/lib/button/button.component.js +0 -221
  157. package/esm5/lib/checkbox/checkbox.component.js +0 -200
  158. package/esm5/lib/collapse/collapse-group.component.js +0 -102
  159. package/esm5/lib/collapse/collapse-item.component.js +0 -183
  160. package/esm5/lib/collapse/collapse.directive.js +0 -210
  161. package/esm5/lib/design-angular-kit.module.js +0 -94
  162. package/esm5/lib/dropdown/dropdown-divider.component.js +0 -20
  163. package/esm5/lib/dropdown/dropdown-header.component.js +0 -27
  164. package/esm5/lib/dropdown/dropdown-item.component.js +0 -197
  165. package/esm5/lib/dropdown/dropdown.component.js +0 -309
  166. package/esm5/lib/form-input/form-input.component.js +0 -582
  167. package/esm5/lib/models/ButtonSize.js +0 -25
  168. package/esm5/lib/models/IconPosition.js +0 -21
  169. package/esm5/lib/models/InputType.js +0 -33
  170. package/esm5/lib/models/InteractionTrigger.js +0 -35
  171. package/esm5/lib/models/ThemeColor.js +0 -45
  172. package/esm5/lib/popover/popover.component.js +0 -144
  173. package/esm5/lib/popover/popover.config.js +0 -37
  174. package/esm5/lib/popover/popover.directive.js +0 -573
  175. package/esm5/lib/popover/popup.js +0 -116
  176. package/esm5/lib/popover/positioning.js +0 -446
  177. package/esm5/lib/popover/triggers.js +0 -115
  178. package/esm5/lib/progress-bar/progress-bar.component.js +0 -218
  179. package/esm5/lib/radio/radio.component.js +0 -610
  180. package/esm5/lib/radio/unique-selection-dispatcher.js +0 -108
  181. package/esm5/lib/tabs/tab-group.component.js +0 -401
  182. package/esm5/lib/tabs/tab.component.js +0 -156
  183. package/esm5/lib/toggle/toggle.component.js +0 -200
  184. package/esm5/lib/tooltip/popup.js +0 -116
  185. package/esm5/lib/tooltip/positioning.js +0 -446
  186. package/esm5/lib/tooltip/tooltip.component.js +0 -80
  187. package/esm5/lib/tooltip/tooltip.config.js +0 -33
  188. package/esm5/lib/tooltip/tooltip.directive.js +0 -516
  189. package/esm5/lib/tooltip/triggers.js +0 -115
  190. package/esm5/lib/util/util.js +0 -48
  191. package/esm5/public_api.js +0 -31
  192. package/fesm2015/design-angular-kit.js +0 -5094
  193. package/fesm2015/design-angular-kit.js.map +0 -1
  194. package/fesm5/design-angular-kit.js +0 -6314
  195. package/fesm5/design-angular-kit.js.map +0 -1
  196. package/lib/button/button.component.d.ts +0 -50
  197. package/lib/dropdown/dropdown-header.component.d.ts +0 -3
  198. package/lib/models/IconPosition.d.ts +0 -9
  199. package/lib/models/InteractionTrigger.d.ts +0 -19
  200. package/lib/popover/popover.component.d.ts +0 -25
  201. package/lib/popover/popup.d.ts +0 -27
  202. package/lib/popover/positioning.d.ts +0 -32
  203. package/lib/popover/triggers.d.ts +0 -18
  204. package/lib/tooltip/popup.d.ts +0 -27
  205. package/lib/tooltip/positioning.d.ts +0 -32
  206. package/lib/tooltip/tooltip.component.d.ts +0 -20
  207. package/lib/tooltip/triggers.d.ts +0 -18
@@ -1,610 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
4
- */
5
- import { Component, Input, Output, EventEmitter, ChangeDetectorRef, forwardRef, ChangeDetectionStrategy, Directive, ContentChildren, QueryList, Optional, HostBinding } from '@angular/core';
6
- import { NG_VALUE_ACCESSOR } from '@angular/forms';
7
- import { UniqueSelectionDispatcher } from './unique-selection-dispatcher';
8
- /** @type {?} */
9
- var identifier = 0;
10
- /**
11
- * @param {?} value
12
- * @return {?}
13
- */
14
- function _coerceBooleanProperty(value) {
15
- return value != null && "" + value !== 'false';
16
- }
17
- var RadioChange = /** @class */ (function () {
18
- function RadioChange(source, value) {
19
- this.source = source;
20
- this.value = value;
21
- }
22
- return RadioChange;
23
- }());
24
- export { RadioChange };
25
- if (false) {
26
- /** @type {?} */
27
- RadioChange.prototype.source;
28
- /** @type {?} */
29
- RadioChange.prototype.value;
30
- }
31
- var RadioGroupDirective = /** @class */ (function () {
32
- function RadioGroupDirective(_changeDetector) {
33
- this._changeDetector = _changeDetector;
34
- this.role = 'radiogroup';
35
- /**
36
- * Il valore selezionato per il gruppo. Dovrebbe essere uguale al valore del radio button selezionato se
37
- * *esiste* un radio button con un valore corrispondente. Se *non esiste* un radio button corrispondente
38
- * questo valore persiste ed è applicato nel caso in cui un nuovo radio button viene aggiunto con il valore
39
- * corrispondente.
40
- */
41
- this._value = null;
42
- /**
43
- * L'attributo HTML name da applicare ai radio button in questo gruppo
44
- */
45
- this._name = "it-radio-group-" + identifier++;
46
- /**
47
- * Il radio button attualmente selezionato.
48
- */
49
- this._selected = null;
50
- /**
51
- * se `value` è stato settato al suo valore iniziale.
52
- */
53
- this._isInitialized = false;
54
- /**
55
- * Se il radio group è disabilitato.
56
- */
57
- this._disabled = false;
58
- /**
59
- * Evento emesso quando il valore del gruppo cambia.
60
- * Gli eventi di change sono emessi soltanto quando il valore cambia a causa dell'interazione dell'utente
61
- * con il radio button (stesso comportamento di `<input type-"radio">`).
62
- */
63
- this.change = new EventEmitter();
64
- /**
65
- * Il metodo da chiamare per aggiornare ngModel
66
- */
67
- this._controlValueAccessorChangeFn = function () { };
68
- this.onTouched = function () { };
69
- }
70
- Object.defineProperty(RadioGroupDirective.prototype, "name", {
71
- /** Nome del gruppo di radio button. Tutti i radio button all'interno del gruppo avranno questo nome. */
72
- get: /**
73
- * Nome del gruppo di radio button. Tutti i radio button all'interno del gruppo avranno questo nome.
74
- * @return {?}
75
- */
76
- function () { return this._name; },
77
- set: /**
78
- * @param {?} value
79
- * @return {?}
80
- */
81
- function (value) {
82
- this._name = value;
83
- this._updateRadioButtonNames();
84
- },
85
- enumerable: true,
86
- configurable: true
87
- });
88
- Object.defineProperty(RadioGroupDirective.prototype, "value", {
89
- /** Valore del radio button. */
90
- get: /**
91
- * Valore del radio button.
92
- * @return {?}
93
- */
94
- function () { return this._value; },
95
- set: /**
96
- * @param {?} newValue
97
- * @return {?}
98
- */
99
- function (newValue) {
100
- if (this._value !== newValue) {
101
- this._value = newValue;
102
- this._updateSelectedRadioFromValue();
103
- this._checkSelectedRadioButton();
104
- }
105
- },
106
- enumerable: true,
107
- configurable: true
108
- });
109
- /**
110
- * @return {?}
111
- */
112
- RadioGroupDirective.prototype._checkSelectedRadioButton = /**
113
- * @return {?}
114
- */
115
- function () {
116
- if (this._selected && !this._selected.checked) {
117
- this._selected.checked = true;
118
- }
119
- };
120
- Object.defineProperty(RadioGroupDirective.prototype, "selected", {
121
- /** Il radio button selezionato. */
122
- get: /**
123
- * Il radio button selezionato.
124
- * @return {?}
125
- */
126
- function () { return this._selected; },
127
- set: /**
128
- * @param {?} selected
129
- * @return {?}
130
- */
131
- function (selected) {
132
- this._selected = selected;
133
- this.value = selected ? selected.value : null;
134
- this._checkSelectedRadioButton();
135
- },
136
- enumerable: true,
137
- configurable: true
138
- });
139
- Object.defineProperty(RadioGroupDirective.prototype, "disabled", {
140
- /** Se il gruppo è disabled */
141
- get: /**
142
- * Se il gruppo è disabled
143
- * @return {?}
144
- */
145
- function () { return this._disabled; },
146
- set: /**
147
- * @param {?} value
148
- * @return {?}
149
- */
150
- function (value) {
151
- this._disabled = _coerceBooleanProperty(value);
152
- this._markRadiosForCheck();
153
- },
154
- enumerable: true,
155
- configurable: true
156
- });
157
- /**
158
- * Inizializza le proprietà quando il contenuto dei figliè disponibile.
159
- * Questo permette di propagare gli attributi rilevanti ai radio buttons associati.
160
- */
161
- /**
162
- * Inizializza le proprietà quando il contenuto dei figliè disponibile.
163
- * Questo permette di propagare gli attributi rilevanti ai radio buttons associati.
164
- * @return {?}
165
- */
166
- RadioGroupDirective.prototype.ngAfterContentInit = /**
167
- * Inizializza le proprietà quando il contenuto dei figliè disponibile.
168
- * Questo permette di propagare gli attributi rilevanti ai radio buttons associati.
169
- * @return {?}
170
- */
171
- function () {
172
- this._isInitialized = true;
173
- };
174
- /**
175
- * @return {?}
176
- */
177
- RadioGroupDirective.prototype._touch = /**
178
- * @return {?}
179
- */
180
- function () {
181
- if (this.onTouched) {
182
- this.onTouched();
183
- }
184
- };
185
- /**
186
- * @return {?}
187
- */
188
- RadioGroupDirective.prototype._updateRadioButtonNames = /**
189
- * @return {?}
190
- */
191
- function () {
192
- var _this = this;
193
- if (this._radios) {
194
- this._radios.forEach(function (radio) {
195
- radio.name = _this.name;
196
- });
197
- }
198
- };
199
- /**
200
- * Aggiorna il radio button `selected` a seconda del suo _value.
201
- * @return {?}
202
- */
203
- RadioGroupDirective.prototype._updateSelectedRadioFromValue = /**
204
- * Aggiorna il radio button `selected` a seconda del suo _value.
205
- * @return {?}
206
- */
207
- function () {
208
- var _this = this;
209
- this._selected = null;
210
- this._radios.forEach(function (radio) {
211
- radio.checked = _this.value === radio.value;
212
- if (radio.checked) {
213
- _this._selected = radio;
214
- }
215
- });
216
- };
217
- /** Invia l'evento change con la selezione corrente e il valore del gruppo. */
218
- /**
219
- * Invia l'evento change con la selezione corrente e il valore del gruppo.
220
- * @return {?}
221
- */
222
- RadioGroupDirective.prototype._emitChangeEvent = /**
223
- * Invia l'evento change con la selezione corrente e il valore del gruppo.
224
- * @return {?}
225
- */
226
- function () {
227
- if (this._isInitialized) {
228
- this.change.emit(new RadioChange(this._selected, this._value));
229
- }
230
- };
231
- /**
232
- * @return {?}
233
- */
234
- RadioGroupDirective.prototype._markRadiosForCheck = /**
235
- * @return {?}
236
- */
237
- function () {
238
- if (this._radios) {
239
- this._radios.forEach(function (radio) { return radio._markForCheck(); });
240
- }
241
- };
242
- /**
243
- * @param {?} value
244
- * @return {?}
245
- */
246
- RadioGroupDirective.prototype.writeValue = /**
247
- * @param {?} value
248
- * @return {?}
249
- */
250
- function (value) {
251
- this.value = value;
252
- this._changeDetector.markForCheck();
253
- };
254
- /**
255
- * @param {?} fn
256
- * @return {?}
257
- */
258
- RadioGroupDirective.prototype.registerOnChange = /**
259
- * @param {?} fn
260
- * @return {?}
261
- */
262
- function (fn) {
263
- this._controlValueAccessorChangeFn = fn;
264
- };
265
- /**
266
- * @param {?} fn
267
- * @return {?}
268
- */
269
- RadioGroupDirective.prototype.registerOnTouched = /**
270
- * @param {?} fn
271
- * @return {?}
272
- */
273
- function (fn) {
274
- this.onTouched = fn;
275
- };
276
- RadioGroupDirective.decorators = [
277
- { type: Directive, args: [{
278
- selector: 'it-radio-group',
279
- // tslint:disable-line
280
- exportAs: 'itRadioGroup',
281
- providers: [{
282
- provide: NG_VALUE_ACCESSOR,
283
- useExisting: forwardRef(function () { return RadioGroupDirective; }),
284
- multi: true
285
- }]
286
- },] },
287
- ];
288
- /** @nocollapse */
289
- RadioGroupDirective.ctorParameters = function () { return [
290
- { type: ChangeDetectorRef }
291
- ]; };
292
- RadioGroupDirective.propDecorators = {
293
- role: [{ type: HostBinding, args: ['attr.role',] }],
294
- change: [{ type: Output }],
295
- _radios: [{ type: ContentChildren, args: [forwardRef(function () { return RadioButtonComponent; }), { descendants: true },] }],
296
- name: [{ type: Input }],
297
- value: [{ type: Input }],
298
- selected: [{ type: Input }],
299
- disabled: [{ type: Input }]
300
- };
301
- return RadioGroupDirective;
302
- }());
303
- export { RadioGroupDirective };
304
- if (false) {
305
- /** @type {?} */
306
- RadioGroupDirective.prototype.role;
307
- /**
308
- * Il valore selezionato per il gruppo. Dovrebbe essere uguale al valore del radio button selezionato se
309
- * *esiste* un radio button con un valore corrispondente. Se *non esiste* un radio button corrispondente
310
- * questo valore persiste ed è applicato nel caso in cui un nuovo radio button viene aggiunto con il valore
311
- * corrispondente.
312
- * @type {?}
313
- */
314
- RadioGroupDirective.prototype._value;
315
- /**
316
- * L'attributo HTML name da applicare ai radio button in questo gruppo
317
- * @type {?}
318
- */
319
- RadioGroupDirective.prototype._name;
320
- /**
321
- * Il radio button attualmente selezionato.
322
- * @type {?}
323
- */
324
- RadioGroupDirective.prototype._selected;
325
- /**
326
- * se `value` è stato settato al suo valore iniziale.
327
- * @type {?}
328
- */
329
- RadioGroupDirective.prototype._isInitialized;
330
- /**
331
- * Se il radio group è disabilitato.
332
- * @type {?}
333
- */
334
- RadioGroupDirective.prototype._disabled;
335
- /**
336
- * Evento emesso quando il valore del gruppo cambia.
337
- * Gli eventi di change sono emessi soltanto quando il valore cambia a causa dell'interazione dell'utente
338
- * con il radio button (stesso comportamento di `<input type-"radio">`).
339
- * @type {?}
340
- */
341
- RadioGroupDirective.prototype.change;
342
- /**
343
- * radio buttons figli.
344
- * @type {?}
345
- */
346
- RadioGroupDirective.prototype._radios;
347
- /**
348
- * Il metodo da chiamare per aggiornare ngModel
349
- * @type {?}
350
- */
351
- RadioGroupDirective.prototype._controlValueAccessorChangeFn;
352
- /** @type {?} */
353
- RadioGroupDirective.prototype.onTouched;
354
- /** @type {?} */
355
- RadioGroupDirective.prototype._changeDetector;
356
- }
357
- /**
358
- * Un radio button con design bootstrap italia. Supporta tutte le funzionalità di una radio HTML5,
359
- * ed espone una API simile. Una `<it-radio-button>` può essere checked, unchecked, o disabled.
360
- */
361
- var RadioButtonComponent = /** @class */ (function () {
362
- function RadioButtonComponent(radioGroup, _changeDetector, _radioDispatcher) {
363
- var _this = this;
364
- this._changeDetector = _changeDetector;
365
- this._radioDispatcher = _radioDispatcher;
366
- this.id = "radio-" + identifier++;
367
- /**
368
- * Evento emesso quando il valore `checked` del radio button cambia.
369
- */
370
- this.change = new EventEmitter();
371
- /**
372
- * Se il radio button è checked.
373
- */
374
- this._checked = false;
375
- /**
376
- * il valore assegnato al radio button.
377
- */
378
- this._value = null;
379
- this._removeUniqueSelectionListener = function () { };
380
- this.radioGroup = radioGroup;
381
- this._removeUniqueSelectionListener =
382
- _radioDispatcher.listen(function (id, name) {
383
- if (id !== _this.id && name === _this.name) {
384
- _this.checked = false;
385
- }
386
- });
387
- }
388
- Object.defineProperty(RadioButtonComponent.prototype, "checked", {
389
- /** se il radio button è checked. */
390
- get: /**
391
- * se il radio button è checked.
392
- * @return {?}
393
- */
394
- function () { return this._checked; },
395
- set: /**
396
- * @param {?} value
397
- * @return {?}
398
- */
399
- function (value) {
400
- /** @type {?} */
401
- var newCheckedState = _coerceBooleanProperty(value);
402
- if (this._checked !== newCheckedState) {
403
- this._checked = newCheckedState;
404
- if (newCheckedState && this.radioGroup && this.radioGroup.value !== this.value) {
405
- this.radioGroup.selected = this;
406
- }
407
- else if (!newCheckedState && this.radioGroup && this.radioGroup.value === this.value) {
408
- this.radioGroup.selected = null;
409
- }
410
- if (newCheckedState) {
411
- this._radioDispatcher.notify(this.id, this.name);
412
- }
413
- this._changeDetector.markForCheck();
414
- }
415
- },
416
- enumerable: true,
417
- configurable: true
418
- });
419
- Object.defineProperty(RadioButtonComponent.prototype, "value", {
420
- /** Il valore di questo radio button. */
421
- get: /**
422
- * Il valore di questo radio button.
423
- * @return {?}
424
- */
425
- function () { return this._value; },
426
- set: /**
427
- * @param {?} value
428
- * @return {?}
429
- */
430
- function (value) {
431
- if (this._value !== value) {
432
- this._value = value;
433
- if (this.radioGroup !== null) {
434
- if (!this.checked) {
435
- this.checked = this.radioGroup.value === value;
436
- }
437
- if (this.checked) {
438
- this.radioGroup.selected = this;
439
- }
440
- }
441
- }
442
- },
443
- enumerable: true,
444
- configurable: true
445
- });
446
- Object.defineProperty(RadioButtonComponent.prototype, "disabled", {
447
- /** Se il radio button è disabled. */
448
- get: /**
449
- * Se il radio button è disabled.
450
- * @return {?}
451
- */
452
- function () {
453
- return this._disabled || (this.radioGroup !== null && this.radioGroup.disabled);
454
- },
455
- set: /**
456
- * @param {?} value
457
- * @return {?}
458
- */
459
- function (value) {
460
- /** @type {?} */
461
- var newDisabledState = !!value;
462
- if (this._disabled !== newDisabledState) {
463
- this._disabled = newDisabledState;
464
- this._changeDetector.markForCheck();
465
- }
466
- },
467
- enumerable: true,
468
- configurable: true
469
- });
470
- /**
471
- * Segna il radio button come da controllare per la change detection.
472
- */
473
- /**
474
- * Segna il radio button come da controllare per la change detection.
475
- * @return {?}
476
- */
477
- RadioButtonComponent.prototype._markForCheck = /**
478
- * Segna il radio button come da controllare per la change detection.
479
- * @return {?}
480
- */
481
- function () {
482
- this._changeDetector.markForCheck();
483
- };
484
- /**
485
- * @return {?}
486
- */
487
- RadioButtonComponent.prototype.ngOnInit = /**
488
- * @return {?}
489
- */
490
- function () {
491
- if (this.radioGroup) {
492
- // Se il radio button è all'interno di un gruppo, determina se deve essere selezionato
493
- this.checked = this.radioGroup.value === this._value;
494
- // Copia il `name` del radio group
495
- this.name = this.radioGroup.name;
496
- }
497
- };
498
- /**
499
- * @return {?}
500
- */
501
- RadioButtonComponent.prototype.ngOnDestroy = /**
502
- * @return {?}
503
- */
504
- function () {
505
- this._removeUniqueSelectionListener();
506
- };
507
- /**
508
- * @return {?}
509
- */
510
- RadioButtonComponent.prototype._emitChangeEvent = /**
511
- * @return {?}
512
- */
513
- function () {
514
- this.change.emit(new RadioChange(this, this._value));
515
- };
516
- /**
517
- * @param {?} event
518
- * @return {?}
519
- */
520
- RadioButtonComponent.prototype._onInputChange = /**
521
- * @param {?} event
522
- * @return {?}
523
- */
524
- function (event) {
525
- event.stopPropagation();
526
- /** @type {?} */
527
- var groupValueChanged = this.radioGroup && this.value !== this.radioGroup.value;
528
- this.checked = true;
529
- this._emitChangeEvent();
530
- if (this.radioGroup) {
531
- this.radioGroup._controlValueAccessorChangeFn(this.value);
532
- this.radioGroup._touch();
533
- if (groupValueChanged) {
534
- this.radioGroup._emitChangeEvent();
535
- }
536
- }
537
- };
538
- RadioButtonComponent.decorators = [
539
- { type: Component, args: [{
540
- selector: 'it-radio-button',
541
- template: "<div class=\"form-check\">\n <input type=\"radio\"\n [id]=\"id\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [attr.name]=\"name\"\n (change)=\"_onInputChange($event)\">\n <label\n [attr.for]=\"id\">{{label}}</label>\n</div>\n",
542
- styles: [""],
543
- exportAs: 'itRadioButton',
544
- changeDetection: ChangeDetectionStrategy.OnPush
545
- },] },
546
- ];
547
- /** @nocollapse */
548
- RadioButtonComponent.ctorParameters = function () { return [
549
- { type: RadioGroupDirective, decorators: [{ type: Optional }] },
550
- { type: ChangeDetectorRef },
551
- { type: UniqueSelectionDispatcher }
552
- ]; };
553
- RadioButtonComponent.propDecorators = {
554
- name: [{ type: Input }],
555
- label: [{ type: Input }],
556
- checked: [{ type: Input }],
557
- value: [{ type: Input }],
558
- disabled: [{ type: Input }],
559
- change: [{ type: Output }]
560
- };
561
- return RadioButtonComponent;
562
- }());
563
- export { RadioButtonComponent };
564
- if (false) {
565
- /** @type {?} */
566
- RadioButtonComponent.prototype.id;
567
- /**
568
- * Attributo 'name' usato per raggruppare i radio button per un'unica selezione.
569
- * @type {?}
570
- */
571
- RadioButtonComponent.prototype.name;
572
- /**
573
- * L'etichetta delradio button.
574
- * @type {?}
575
- */
576
- RadioButtonComponent.prototype.label;
577
- /**
578
- * Evento emesso quando il valore `checked` del radio button cambia.
579
- * @type {?}
580
- */
581
- RadioButtonComponent.prototype.change;
582
- /**
583
- * Il radio group padre. Può essere presente o meno.
584
- * @type {?}
585
- */
586
- RadioButtonComponent.prototype.radioGroup;
587
- /**
588
- * Se il radio button è checked.
589
- * @type {?}
590
- */
591
- RadioButtonComponent.prototype._checked;
592
- /**
593
- * Se il radio button è disabled.
594
- * @type {?}
595
- */
596
- RadioButtonComponent.prototype._disabled;
597
- /**
598
- * il valore assegnato al radio button.
599
- * @type {?}
600
- */
601
- RadioButtonComponent.prototype._value;
602
- /** @type {?} */
603
- RadioButtonComponent.prototype._removeUniqueSelectionListener;
604
- /** @type {?} */
605
- RadioButtonComponent.prototype._changeDetector;
606
- /** @type {?} */
607
- RadioButtonComponent.prototype._radioDispatcher;
608
- }
609
-
610
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.component.js","sourceRoot":"ng://design-angular-kit/","sources":["lib/radio/radio.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ChangeDetectorRef,\n  forwardRef,\n  ChangeDetectionStrategy,\n  AfterContentInit,\n  Directive,\n  ContentChildren,\n  QueryList,\n  OnInit,\n  OnDestroy,\n  Optional,\n  HostBinding\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\nimport { UniqueSelectionDispatcher } from './unique-selection-dispatcher';\n\nlet identifier = 0;\n\nfunction _coerceBooleanProperty(value: any): boolean {\n  return value != null && `${value}` !== 'false';\n}\n\nexport class RadioChange {\n  constructor(\n    public source: RadioButtonComponent,\n    public value: any\n  ) { }\n}\n\n@Directive({\n  selector: 'it-radio-group', // tslint:disable-line\n  exportAs: 'itRadioGroup',\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => RadioGroupDirective),\n    multi: true\n  }]\n})\nexport class RadioGroupDirective implements AfterContentInit, ControlValueAccessor {\n\n  @HostBinding('attr.role') role = 'radiogroup';\n\n  /**\n   * Il valore selezionato per il gruppo. Dovrebbe essere uguale al valore del radio button selezionato se\n   * *esiste* un radio button con un valore corrispondente. Se *non esiste* un radio button corrispondente\n   * questo valore persiste ed è applicato nel caso in cui un nuovo radio button viene aggiunto con il valore\n   * corrispondente.\n   */\n  private _value: any = null;\n\n  /** L'attributo HTML name da applicare ai radio button in questo gruppo */\n  private _name = `it-radio-group-${identifier++}`;\n\n  /** Il radio button attualmente selezionato. */\n  private _selected: RadioButtonComponent | null = null;\n\n  /** se `value` è stato settato al suo valore iniziale. */\n  private _isInitialized = false;\n\n  /** Se il radio group è disabilitato. */\n  private _disabled = false;\n\n\n\n  /**\n   * Evento emesso quando il valore del gruppo cambia.\n   * Gli eventi di change sono emessi soltanto quando il valore cambia a causa dell'interazione dell'utente\n   * con il radio button (stesso comportamento di `<input type-\"radio\">`).\n   */\n  @Output() readonly change: EventEmitter<RadioChange> = new EventEmitter<RadioChange>();\n\n  /** radio buttons figli. */\n  @ContentChildren(forwardRef(() => RadioButtonComponent), { descendants: true }) _radios: QueryList<RadioButtonComponent>; // tslint:disable-line\n\n  /** Il metodo da chiamare per aggiornare ngModel */\n  _controlValueAccessorChangeFn: (value: any) => void = () => { };\n\n  onTouched: () => any = () => { };\n\n  /** Nome del gruppo di radio button. Tutti i radio button all'interno del gruppo avranno questo nome. */\n  @Input()\n  get name(): string { return this._name; }\n  set name(value: string) {\n    this._name = value;\n    this._updateRadioButtonNames();\n  }\n\n  /** Valore del radio button. */\n  @Input()\n  get value(): any { return this._value; }\n  set value(newValue: any) {\n    if (this._value !== newValue) {\n      this._value = newValue;\n\n      this._updateSelectedRadioFromValue();\n      this._checkSelectedRadioButton();\n    }\n  }\n\n  _checkSelectedRadioButton() {\n    if (this._selected && !this._selected.checked) {\n      this._selected.checked = true;\n    }\n  }\n\n  /** Il radio button selezionato. */\n  @Input()\n  get selected() { return this._selected; }\n  set selected(selected: RadioButtonComponent | null) {\n    this._selected = selected;\n    this.value = selected ? selected.value : null;\n    this._checkSelectedRadioButton();\n  }\n\n  /** Se il gruppo è disabled */\n  @Input()\n  get disabled(): boolean { return this._disabled; }\n  set disabled(value) {\n    this._disabled = _coerceBooleanProperty(value);\n    this._markRadiosForCheck();\n  }\n\n  constructor(\n    private _changeDetector: ChangeDetectorRef\n  ) { }\n\n  /**\n   * Inizializza le proprietà quando il contenuto dei figliè disponibile.\n   * Questo permette di propagare gli attributi rilevanti ai radio buttons associati.\n   */\n  ngAfterContentInit(): void {\n    this._isInitialized = true;\n  }\n\n  _touch() {\n    if (this.onTouched) {\n      this.onTouched();\n    }\n  }\n\n  private _updateRadioButtonNames(): void {\n    if (this._radios) {\n      this._radios.forEach(radio => {\n        radio.name = this.name;\n      });\n    }\n  }\n\n  /** Aggiorna il radio button `selected` a seconda del suo _value. */\n  private _updateSelectedRadioFromValue(): void {\n    this._selected = null;\n    this._radios.forEach(radio => {\n      radio.checked = this.value === radio.value;\n      if (radio.checked) {\n        this._selected = radio;\n      }\n    });\n  }\n\n  /** Invia l'evento change con la selezione corrente e il valore del gruppo. */\n  _emitChangeEvent(): void {\n    if (this._isInitialized) {\n      this.change.emit(new RadioChange(this._selected, this._value));\n    }\n  }\n\n  _markRadiosForCheck() {\n    if (this._radios) {\n      this._radios.forEach(radio => radio._markForCheck());\n    }\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n    this._changeDetector.markForCheck();\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\n/**\n * Un radio button con design bootstrap italia. Supporta tutte le funzionalità di una radio HTML5,\n * ed espone una API simile. Una `<it-radio-button>` può essere checked, unchecked, o disabled.\n */\n@Component({\n  selector: 'it-radio-button',\n  template: `<div class=\"form-check\">\n  <input type=\"radio\"\n    [id]=\"id\"\n    [checked]=\"checked\"\n    [disabled]=\"disabled\"\n    [attr.name]=\"name\"\n    (change)=\"_onInputChange($event)\">\n  <label\n    [attr.for]=\"id\">{{label}}</label>\n</div>\n`,\n  styles: [``],\n  exportAs: 'itRadioButton',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class RadioButtonComponent implements OnInit, OnDestroy {\n\n  id = `radio-${identifier++}`;\n\n  /** Attributo 'name' usato per raggruppare i radio button per un'unica selezione. */\n  @Input() name: string;\n\n  /** L'etichetta delradio button. */\n  @Input()\n  label: string;\n\n  /** se il radio button è checked. */\n  @Input()\n  get checked(): boolean { return this._checked; }\n  set checked(value: boolean) {\n    const newCheckedState = _coerceBooleanProperty(value);\n    if (this._checked !== newCheckedState) {\n      this._checked = newCheckedState;\n      if (newCheckedState && this.radioGroup && this.radioGroup.value !== this.value) {\n        this.radioGroup.selected = this;\n      } else if (!newCheckedState && this.radioGroup && this.radioGroup.value === this.value) {\n        this.radioGroup.selected = null;\n      }\n\n      if (newCheckedState) {\n        this._radioDispatcher.notify(this.id, this.name);\n      }\n\n      this._changeDetector.markForCheck();\n    }\n  }\n\n  /** Il valore di questo radio button. */\n  @Input()\n  get value(): any { return this._value; }\n  set value(value: any) {\n    if (this._value !== value) {\n      this._value = value;\n      if (this.radioGroup !== null) {\n        if (!this.checked) {\n          this.checked = this.radioGroup.value === value;\n        }\n        if (this.checked) {\n          this.radioGroup.selected = this;\n        }\n      }\n    }\n  }\n\n  /** Se il radio button è disabled. */\n  @Input()\n  get disabled(): boolean {\n    return this._disabled || (this.radioGroup !== null && this.radioGroup.disabled);\n  }\n  set disabled(value: boolean) {\n    const newDisabledState = !!value;\n    if (this._disabled !== newDisabledState) {\n      this._disabled = newDisabledState;\n      this._changeDetector.markForCheck();\n    }\n  }\n\n  /**\n   * Evento emesso quando il valore `checked` del radio button cambia.\n   */\n  @Output() readonly change: EventEmitter<RadioChange> = new EventEmitter<RadioChange>();\n\n  /** Il radio group padre. Può essere presente o meno. */\n  radioGroup: RadioGroupDirective;\n\n  /** Se il radio button è checked. */\n  private _checked = false;\n\n  /** Se il radio button è disabled. */\n  private _disabled: boolean;\n\n  /** il valore assegnato al radio button. */\n  private _value: any = null;\n\n  private _removeUniqueSelectionListener: () => void = () => { };\n\n  constructor(\n    @Optional() radioGroup: RadioGroupDirective,\n    private _changeDetector: ChangeDetectorRef,\n    private _radioDispatcher: UniqueSelectionDispatcher\n  ) {\n    this.radioGroup = radioGroup;\n\n    this._removeUniqueSelectionListener =\n      _radioDispatcher.listen((id: string, name: string) => {\n        if (id !== this.id && name === this.name) {\n          this.checked = false;\n        }\n      });\n  }\n\n  /**\n   * Segna il radio button come da controllare per la change detection.\n   */\n  _markForCheck() {\n    this._changeDetector.markForCheck();\n  }\n\n  ngOnInit(): void {\n    if (this.radioGroup) {\n      // Se il radio button è all'interno di un gruppo, determina se deve essere selezionato\n      this.checked = this.radioGroup.value === this._value;\n      // Copia il `name` del radio group\n      this.name = this.radioGroup.name;\n    }\n  }\n\n  ngOnDestroy() {\n    this._removeUniqueSelectionListener();\n  }\n\n  private _emitChangeEvent(): void {\n    this.change.emit(new RadioChange(this, this._value));\n  }\n\n  _onInputChange(event: Event) {\n    event.stopPropagation();\n\n    const groupValueChanged = this.radioGroup && this.value !== this.radioGroup.value;\n    this.checked = true;\n    this._emitChangeEvent();\n\n    if (this.radioGroup) {\n      this.radioGroup._controlValueAccessorChangeFn(this.value);\n      this.radioGroup._touch();\n      if (groupValueChanged) {\n        this.radioGroup._emitChangeEvent();\n      }\n    }\n  }\n}\n"]}