@impartner/design-components 1.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 (315) hide show
  1. package/LICENSE.txt +11 -0
  2. package/README.md +22 -0
  3. package/constants/fontawesome-icons.d.ts +6 -0
  4. package/constants/index.d.ts +1 -0
  5. package/esm2020/constants/fontawesome-icons.mjs +3012 -0
  6. package/esm2020/constants/index.mjs +2 -0
  7. package/esm2020/impartner-design-components.mjs +5 -0
  8. package/esm2020/lib/alert/alert.component.mjs +57 -0
  9. package/esm2020/lib/alert/alert.module.mjs +18 -0
  10. package/esm2020/lib/alert/index.mjs +4 -0
  11. package/esm2020/lib/alert/theme/alert-theme.mjs +2 -0
  12. package/esm2020/lib/alert/theme/index.mjs +2 -0
  13. package/esm2020/lib/avatar/avatar.component.mjs +47 -0
  14. package/esm2020/lib/avatar/avatar.module.mjs +18 -0
  15. package/esm2020/lib/avatar/index.mjs +3 -0
  16. package/esm2020/lib/avatar-group/avatar-group.component.mjs +16 -0
  17. package/esm2020/lib/avatar-group/avatar-group.module.mjs +19 -0
  18. package/esm2020/lib/avatar-group/index.mjs +3 -0
  19. package/esm2020/lib/backdrop/backdrop.component.mjs +34 -0
  20. package/esm2020/lib/backdrop/backdrop.module.mjs +19 -0
  21. package/esm2020/lib/backdrop/index.mjs +3 -0
  22. package/esm2020/lib/badge/badge.component.mjs +98 -0
  23. package/esm2020/lib/badge/badge.module.mjs +19 -0
  24. package/esm2020/lib/badge/index.mjs +4 -0
  25. package/esm2020/lib/badge/types/badge-icon.mjs +2 -0
  26. package/esm2020/lib/badge/types/badge-size.mjs +7 -0
  27. package/esm2020/lib/badge/types/index.mjs +2 -0
  28. package/esm2020/lib/branding/branded.directive.mjs +19 -0
  29. package/esm2020/lib/branding/branding.module.mjs +19 -0
  30. package/esm2020/lib/branding/index.mjs +3 -0
  31. package/esm2020/lib/breadcrumb/breadcrumb-item.component.mjs +25 -0
  32. package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +33 -0
  33. package/esm2020/lib/breadcrumb/breadcrumb.module.mjs +19 -0
  34. package/esm2020/lib/breadcrumb/index.mjs +4 -0
  35. package/esm2020/lib/button/button.component.mjs +116 -0
  36. package/esm2020/lib/button/button.module.mjs +21 -0
  37. package/esm2020/lib/button/index.mjs +4 -0
  38. package/esm2020/lib/button/themes/button-theme.mjs +2 -0
  39. package/esm2020/lib/button/themes/index.mjs +2 -0
  40. package/esm2020/lib/button-group/button-group.component.mjs +52 -0
  41. package/esm2020/lib/button-group/button-group.module.mjs +20 -0
  42. package/esm2020/lib/button-group/index.mjs +3 -0
  43. package/esm2020/lib/card-heading/card-heading.component.mjs +30 -0
  44. package/esm2020/lib/card-heading/card-heading.module.mjs +19 -0
  45. package/esm2020/lib/card-heading/index.mjs +3 -0
  46. package/esm2020/lib/design-components.module.mjs +119 -0
  47. package/esm2020/lib/dropdown/components/dropdown-item/dropdown-item.component.mjs +22 -0
  48. package/esm2020/lib/dropdown/components/index.mjs +2 -0
  49. package/esm2020/lib/dropdown/dropdown.component.mjs +140 -0
  50. package/esm2020/lib/dropdown/dropdown.module.mjs +21 -0
  51. package/esm2020/lib/dropdown/index.mjs +5 -0
  52. package/esm2020/lib/dropdown/types/dropdown-position.mjs +2 -0
  53. package/esm2020/lib/dropdown/types/index.mjs +2 -0
  54. package/esm2020/lib/file-upload/directives/file-drop.directive.mjs +50 -0
  55. package/esm2020/lib/file-upload/directives/index.mjs +2 -0
  56. package/esm2020/lib/file-upload/file-upload.component.mjs +334 -0
  57. package/esm2020/lib/file-upload/file-upload.module.mjs +29 -0
  58. package/esm2020/lib/file-upload/index.mjs +5 -0
  59. package/esm2020/lib/file-upload/pipes/human-readable-byte-size.pipe.mjs +23 -0
  60. package/esm2020/lib/file-upload/pipes/index.mjs +2 -0
  61. package/esm2020/lib/form-field/controls/checkbox/checkbox.component.mjs +337 -0
  62. package/esm2020/lib/form-field/controls/checkbox/checkbox.module.mjs +19 -0
  63. package/esm2020/lib/form-field/controls/checkbox/index.mjs +3 -0
  64. package/esm2020/lib/form-field/controls/index.mjs +5 -0
  65. package/esm2020/lib/form-field/controls/input/index.mjs +2 -0
  66. package/esm2020/lib/form-field/controls/input/input.directive.mjs +233 -0
  67. package/esm2020/lib/form-field/controls/radio/index.mjs +6 -0
  68. package/esm2020/lib/form-field/controls/radio/injection-tokens.mjs +4 -0
  69. package/esm2020/lib/form-field/controls/radio/interfaces/index.mjs +4 -0
  70. package/esm2020/lib/form-field/controls/radio/interfaces/radio-button.interface.mjs +2 -0
  71. package/esm2020/lib/form-field/controls/radio/interfaces/radio-change-event.interface.mjs +11 -0
  72. package/esm2020/lib/form-field/controls/radio/interfaces/radio-group.interface.mjs +2 -0
  73. package/esm2020/lib/form-field/controls/radio/radio-button/radio-button.component.mjs +260 -0
  74. package/esm2020/lib/form-field/controls/radio/radio-group/radio-group.directive.mjs +288 -0
  75. package/esm2020/lib/form-field/controls/radio/radio.module.mjs +20 -0
  76. package/esm2020/lib/form-field/controls/select/index.mjs +6 -0
  77. package/esm2020/lib/form-field/controls/select/option/index.mjs +2 -0
  78. package/esm2020/lib/form-field/controls/select/option/select-option.component.mjs +138 -0
  79. package/esm2020/lib/form-field/controls/select/option-parent.mjs +3 -0
  80. package/esm2020/lib/form-field/controls/select/select-model.mjs +149 -0
  81. package/esm2020/lib/form-field/controls/select/select.component.mjs +522 -0
  82. package/esm2020/lib/form-field/controls/select/select.module.mjs +20 -0
  83. package/esm2020/lib/form-field/controls/shared/index.mjs +2 -0
  84. package/esm2020/lib/form-field/controls/shared/toggle/components/index.mjs +2 -0
  85. package/esm2020/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.mjs +17 -0
  86. package/esm2020/lib/form-field/controls/shared/toggle/index.mjs +4 -0
  87. package/esm2020/lib/form-field/controls/shared/toggle/toggle.component.mjs +96 -0
  88. package/esm2020/lib/form-field/controls/shared/toggle/toggle.module.mjs +20 -0
  89. package/esm2020/lib/form-field/directives/corner-hint.directive.mjs +14 -0
  90. package/esm2020/lib/form-field/directives/error.directive.mjs +26 -0
  91. package/esm2020/lib/form-field/directives/form-root.directive.mjs +91 -0
  92. package/esm2020/lib/form-field/directives/hint.directive.mjs +24 -0
  93. package/esm2020/lib/form-field/directives/index.mjs +8 -0
  94. package/esm2020/lib/form-field/directives/label.directive.mjs +14 -0
  95. package/esm2020/lib/form-field/directives/prefix.directive.mjs +24 -0
  96. package/esm2020/lib/form-field/directives/suffix.directive.mjs +24 -0
  97. package/esm2020/lib/form-field/form-field-errors.mjs +5 -0
  98. package/esm2020/lib/form-field/form-field.component.mjs +132 -0
  99. package/esm2020/lib/form-field/impdc-forms.mjs +8 -0
  100. package/esm2020/lib/form-field/impdc-forms.module.mjs +68 -0
  101. package/esm2020/lib/form-field/index.mjs +2 -0
  102. package/esm2020/lib/form-field/services/error-state-matcher.service.mjs +28 -0
  103. package/esm2020/lib/form-field/services/index.mjs +3 -0
  104. package/esm2020/lib/form-field/services/unique-selection-dispatcher.service.mjs +48 -0
  105. package/esm2020/lib/form-field/shared/constructors.type.mjs +2 -0
  106. package/esm2020/lib/form-field/shared/disabled.mixin.mjs +15 -0
  107. package/esm2020/lib/form-field/shared/error-state.mixin.mjs +24 -0
  108. package/esm2020/lib/form-field/shared/form-field-control.mjs +10 -0
  109. package/esm2020/lib/form-field/shared/index.mjs +5 -0
  110. package/esm2020/lib/form-field/shared/tab-index.mixin.mjs +19 -0
  111. package/esm2020/lib/icon/icon.component.mjs +70 -0
  112. package/esm2020/lib/icon/icon.module.mjs +19 -0
  113. package/esm2020/lib/icon/index.mjs +3 -0
  114. package/esm2020/lib/index.mjs +26 -0
  115. package/esm2020/lib/modal/index.mjs +4 -0
  116. package/esm2020/lib/modal/modal.component.mjs +141 -0
  117. package/esm2020/lib/modal/modal.module.mjs +37 -0
  118. package/esm2020/lib/modal/types/index.mjs +3 -0
  119. package/esm2020/lib/modal/types/modal-component-sizes.mjs +9 -0
  120. package/esm2020/lib/modal/types/modal-theme.mjs +12 -0
  121. package/esm2020/lib/pagination/index.mjs +3 -0
  122. package/esm2020/lib/pagination/pagination.component.mjs +134 -0
  123. package/esm2020/lib/pagination/pagination.module.mjs +21 -0
  124. package/esm2020/lib/progress-bar/index.mjs +3 -0
  125. package/esm2020/lib/progress-bar/progress-bar.component.mjs +35 -0
  126. package/esm2020/lib/progress-bar/progress-bar.module.mjs +18 -0
  127. package/esm2020/lib/scrollable/index.mjs +3 -0
  128. package/esm2020/lib/scrollable/scrollable.component.mjs +193 -0
  129. package/esm2020/lib/scrollable/scrollable.module.mjs +21 -0
  130. package/esm2020/lib/select-icon/index.mjs +3 -0
  131. package/esm2020/lib/select-icon/select-icon.component.mjs +307 -0
  132. package/esm2020/lib/select-icon/select-icon.module.mjs +35 -0
  133. package/esm2020/lib/size-detection/directive/element-size.interface.mjs +2 -0
  134. package/esm2020/lib/size-detection/directive/index.mjs +3 -0
  135. package/esm2020/lib/size-detection/directive/size-detector.directive.mjs +43 -0
  136. package/esm2020/lib/size-detection/index.mjs +3 -0
  137. package/esm2020/lib/size-detection/size-detection.module.mjs +18 -0
  138. package/esm2020/lib/spinner/index.mjs +3 -0
  139. package/esm2020/lib/spinner/spinner.component.mjs +24 -0
  140. package/esm2020/lib/spinner/spinner.module.mjs +18 -0
  141. package/esm2020/lib/table/index.mjs +3 -0
  142. package/esm2020/lib/table/table.component.mjs +33 -0
  143. package/esm2020/lib/table/table.module.mjs +19 -0
  144. package/esm2020/lib/text-highlight/index.mjs +3 -0
  145. package/esm2020/lib/text-highlight/text-highlight.component.mjs +81 -0
  146. package/esm2020/lib/text-highlight/text-highlight.module.mjs +19 -0
  147. package/esm2020/public-api.mjs +9 -0
  148. package/esm2020/services/index.mjs +2 -0
  149. package/esm2020/services/interaction.service.mjs +54 -0
  150. package/esm2020/types/component-size.mjs +12 -0
  151. package/esm2020/types/component-theme.mjs +22 -0
  152. package/esm2020/types/index.mjs +3 -0
  153. package/esm2020/utilities/boolean-props.mjs +7 -0
  154. package/esm2020/utilities/dc.mjs +9 -0
  155. package/esm2020/utilities/index.mjs +6 -0
  156. package/esm2020/utilities/lc.mjs +9 -0
  157. package/esm2020/utilities/number-props.mjs +18 -0
  158. package/esm2020/utilities/sanitize.mjs +7 -0
  159. package/fesm2015/impartner-design-components.mjs +8295 -0
  160. package/fesm2015/impartner-design-components.mjs.map +1 -0
  161. package/fesm2020/impartner-design-components.mjs +8264 -0
  162. package/fesm2020/impartner-design-components.mjs.map +1 -0
  163. package/index.d.ts +5 -0
  164. package/lib/alert/alert.component.d.ts +29 -0
  165. package/lib/alert/alert.module.d.ts +8 -0
  166. package/lib/alert/index.d.ts +3 -0
  167. package/lib/alert/theme/alert-theme.d.ts +1 -0
  168. package/lib/alert/theme/index.d.ts +1 -0
  169. package/lib/avatar/avatar.component.d.ts +28 -0
  170. package/lib/avatar/avatar.module.d.ts +8 -0
  171. package/lib/avatar/index.d.ts +2 -0
  172. package/lib/avatar-group/avatar-group.component.d.ts +10 -0
  173. package/lib/avatar-group/avatar-group.module.d.ts +9 -0
  174. package/lib/avatar-group/index.d.ts +2 -0
  175. package/lib/backdrop/backdrop.component.d.ts +19 -0
  176. package/lib/backdrop/backdrop.module.d.ts +9 -0
  177. package/lib/backdrop/index.d.ts +2 -0
  178. package/lib/badge/badge.component.d.ts +48 -0
  179. package/lib/badge/badge.module.d.ts +9 -0
  180. package/lib/badge/index.d.ts +3 -0
  181. package/lib/badge/types/badge-icon.d.ts +1 -0
  182. package/lib/badge/types/badge-size.d.ts +6 -0
  183. package/lib/badge/types/index.d.ts +2 -0
  184. package/lib/branding/branded.directive.d.ts +6 -0
  185. package/lib/branding/branding.module.d.ts +9 -0
  186. package/lib/branding/index.d.ts +2 -0
  187. package/lib/breadcrumb/breadcrumb-item.component.d.ts +7 -0
  188. package/lib/breadcrumb/breadcrumb.component.d.ts +18 -0
  189. package/lib/breadcrumb/breadcrumb.module.d.ts +9 -0
  190. package/lib/breadcrumb/index.d.ts +3 -0
  191. package/lib/button/button.component.d.ts +47 -0
  192. package/lib/button/button.module.d.ts +11 -0
  193. package/lib/button/index.d.ts +3 -0
  194. package/lib/button/themes/button-theme.d.ts +1 -0
  195. package/lib/button/themes/index.d.ts +1 -0
  196. package/lib/button-group/button-group.component.d.ts +22 -0
  197. package/lib/button-group/button-group.module.d.ts +10 -0
  198. package/lib/button-group/index.d.ts +2 -0
  199. package/lib/card-heading/card-heading.component.d.ts +18 -0
  200. package/lib/card-heading/card-heading.module.d.ts +9 -0
  201. package/lib/card-heading/index.d.ts +2 -0
  202. package/lib/design-components.module.d.ts +22 -0
  203. package/lib/dropdown/components/dropdown-item/dropdown-item.component.d.ts +11 -0
  204. package/lib/dropdown/components/index.d.ts +1 -0
  205. package/lib/dropdown/dropdown.component.d.ts +65 -0
  206. package/lib/dropdown/dropdown.module.d.ts +11 -0
  207. package/lib/dropdown/index.d.ts +4 -0
  208. package/lib/dropdown/types/dropdown-position.d.ts +1 -0
  209. package/lib/dropdown/types/index.d.ts +1 -0
  210. package/lib/file-upload/directives/file-drop.directive.d.ts +11 -0
  211. package/lib/file-upload/directives/index.d.ts +1 -0
  212. package/lib/file-upload/file-upload.component.d.ts +105 -0
  213. package/lib/file-upload/file-upload.module.d.ts +13 -0
  214. package/lib/file-upload/index.d.ts +4 -0
  215. package/lib/file-upload/pipes/human-readable-byte-size.pipe.d.ts +7 -0
  216. package/lib/file-upload/pipes/index.d.ts +1 -0
  217. package/lib/form-field/controls/checkbox/checkbox.component.d.ts +133 -0
  218. package/lib/form-field/controls/checkbox/checkbox.module.d.ts +9 -0
  219. package/lib/form-field/controls/checkbox/index.d.ts +2 -0
  220. package/lib/form-field/controls/index.d.ts +4 -0
  221. package/lib/form-field/controls/input/index.d.ts +1 -0
  222. package/lib/form-field/controls/input/input.directive.d.ts +84 -0
  223. package/lib/form-field/controls/radio/index.d.ts +5 -0
  224. package/lib/form-field/controls/radio/injection-tokens.d.ts +4 -0
  225. package/lib/form-field/controls/radio/interfaces/index.d.ts +3 -0
  226. package/lib/form-field/controls/radio/interfaces/radio-button.interface.d.ts +6 -0
  227. package/lib/form-field/controls/radio/interfaces/radio-change-event.interface.d.ts +12 -0
  228. package/lib/form-field/controls/radio/interfaces/radio-group.interface.d.ts +13 -0
  229. package/lib/form-field/controls/radio/radio-button/radio-button.component.d.ts +98 -0
  230. package/lib/form-field/controls/radio/radio-group/radio-group.directive.d.ts +104 -0
  231. package/lib/form-field/controls/radio/radio.module.d.ts +10 -0
  232. package/lib/form-field/controls/select/index.d.ts +5 -0
  233. package/lib/form-field/controls/select/option/index.d.ts +1 -0
  234. package/lib/form-field/controls/select/option/select-option.component.d.ts +60 -0
  235. package/lib/form-field/controls/select/option-parent.d.ts +5 -0
  236. package/lib/form-field/controls/select/select-model.d.ts +36 -0
  237. package/lib/form-field/controls/select/select.component.d.ts +170 -0
  238. package/lib/form-field/controls/select/select.module.d.ts +10 -0
  239. package/lib/form-field/controls/shared/index.d.ts +1 -0
  240. package/lib/form-field/controls/shared/toggle/components/index.d.ts +1 -0
  241. package/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.d.ts +6 -0
  242. package/lib/form-field/controls/shared/toggle/index.d.ts +3 -0
  243. package/lib/form-field/controls/shared/toggle/toggle.component.d.ts +26 -0
  244. package/lib/form-field/controls/shared/toggle/toggle.module.d.ts +10 -0
  245. package/lib/form-field/directives/corner-hint.directive.d.ts +5 -0
  246. package/lib/form-field/directives/error.directive.d.ts +8 -0
  247. package/lib/form-field/directives/form-root.directive.d.ts +26 -0
  248. package/lib/form-field/directives/hint.directive.d.ts +6 -0
  249. package/lib/form-field/directives/index.d.ts +7 -0
  250. package/lib/form-field/directives/label.directive.d.ts +5 -0
  251. package/lib/form-field/directives/prefix.directive.d.ts +9 -0
  252. package/lib/form-field/directives/suffix.directive.d.ts +9 -0
  253. package/lib/form-field/form-field-errors.d.ts +2 -0
  254. package/lib/form-field/form-field.component.d.ts +39 -0
  255. package/lib/form-field/impdc-forms.d.ts +7 -0
  256. package/lib/form-field/impdc-forms.module.d.ts +19 -0
  257. package/lib/form-field/index.d.ts +1 -0
  258. package/lib/form-field/services/error-state-matcher.service.d.ts +12 -0
  259. package/lib/form-field/services/index.d.ts +2 -0
  260. package/lib/form-field/services/unique-selection-dispatcher.service.d.ts +29 -0
  261. package/lib/form-field/shared/constructors.type.d.ts +7 -0
  262. package/lib/form-field/shared/disabled.mixin.d.ts +10 -0
  263. package/lib/form-field/shared/error-state.mixin.d.ts +31 -0
  264. package/lib/form-field/shared/form-field-control.d.ts +24 -0
  265. package/lib/form-field/shared/index.d.ts +5 -0
  266. package/lib/form-field/shared/tab-index.mixin.d.ts +13 -0
  267. package/lib/icon/icon.component.d.ts +30 -0
  268. package/lib/icon/icon.module.d.ts +9 -0
  269. package/lib/icon/index.d.ts +2 -0
  270. package/lib/index.d.ts +25 -0
  271. package/lib/modal/index.d.ts +3 -0
  272. package/lib/modal/modal.component.d.ts +80 -0
  273. package/lib/modal/modal.module.d.ts +13 -0
  274. package/lib/modal/types/index.d.ts +2 -0
  275. package/lib/modal/types/modal-component-sizes.d.ts +3 -0
  276. package/lib/modal/types/modal-theme.d.ts +7 -0
  277. package/lib/pagination/index.d.ts +2 -0
  278. package/lib/pagination/pagination.component.d.ts +41 -0
  279. package/lib/pagination/pagination.module.d.ts +11 -0
  280. package/lib/progress-bar/index.d.ts +2 -0
  281. package/lib/progress-bar/progress-bar.component.d.ts +22 -0
  282. package/lib/progress-bar/progress-bar.module.d.ts +8 -0
  283. package/lib/scrollable/index.d.ts +2 -0
  284. package/lib/scrollable/scrollable.component.d.ts +39 -0
  285. package/lib/scrollable/scrollable.module.d.ts +11 -0
  286. package/lib/select-icon/index.d.ts +2 -0
  287. package/lib/select-icon/select-icon.component.d.ts +123 -0
  288. package/lib/select-icon/select-icon.module.d.ts +11 -0
  289. package/lib/size-detection/directive/element-size.interface.d.ts +4 -0
  290. package/lib/size-detection/directive/index.d.ts +2 -0
  291. package/lib/size-detection/directive/size-detector.directive.d.ts +14 -0
  292. package/lib/size-detection/index.d.ts +3 -0
  293. package/lib/size-detection/size-detection.module.d.ts +8 -0
  294. package/lib/spinner/index.d.ts +2 -0
  295. package/lib/spinner/spinner.component.d.ts +13 -0
  296. package/lib/spinner/spinner.module.d.ts +8 -0
  297. package/lib/table/index.d.ts +2 -0
  298. package/lib/table/table.component.d.ts +15 -0
  299. package/lib/table/table.module.d.ts +9 -0
  300. package/lib/text-highlight/index.d.ts +2 -0
  301. package/lib/text-highlight/text-highlight.component.d.ts +31 -0
  302. package/lib/text-highlight/text-highlight.module.d.ts +9 -0
  303. package/package.json +51 -0
  304. package/public-api.d.ts +4 -0
  305. package/services/index.d.ts +1 -0
  306. package/services/interaction.service.d.ts +14 -0
  307. package/types/component-size.d.ts +12 -0
  308. package/types/component-theme.d.ts +12 -0
  309. package/types/index.d.ts +2 -0
  310. package/utilities/boolean-props.d.ts +8 -0
  311. package/utilities/dc.d.ts +6 -0
  312. package/utilities/index.d.ts +5 -0
  313. package/utilities/lc.d.ts +6 -0
  314. package/utilities/number-props.d.ts +15 -0
  315. package/utilities/sanitize.d.ts +1 -0
@@ -0,0 +1,233 @@
1
+ /* eslint-disable @angular-eslint/no-conflicting-lifecycle */
2
+ import { Directive, Inject, Input, Optional, Self } from '@angular/core';
3
+ import { Validators } from '@angular/forms';
4
+ import { nanoid } from 'nanoid';
5
+ import { Subject } from 'rxjs';
6
+ import { coerceBooleanPropertyValue } from '../../../../utilities';
7
+ import { IMPDC_FORM_ROOT } from '../../directives';
8
+ import { mixinErrorState } from '../../shared';
9
+ import { ImpdcFormFieldControl } from '../../shared/form-field-control';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "@angular/forms";
12
+ import * as i2 from "../../services";
13
+ const IMPDC_INPUT_INVALID_TYPES = [
14
+ 'button',
15
+ 'checkbox',
16
+ 'file',
17
+ 'hidden',
18
+ 'image',
19
+ 'radio',
20
+ 'range',
21
+ 'reset',
22
+ 'submit'
23
+ ];
24
+ /** @docs-private */
25
+ export function getInputUnsupportedTypeError(type) {
26
+ return Error(`Input type "${type}" isn't supported by impdcInput.`);
27
+ }
28
+ const _InputDirectiveBase = mixinErrorState(class {
29
+ constructor(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl) {
30
+ this._defaultErrorStateMatcher = _defaultErrorStateMatcher;
31
+ this._formRoot = _formRoot;
32
+ this._parentForm = _parentForm;
33
+ this._parentFormGroup = _parentFormGroup;
34
+ this.ngControl = ngControl;
35
+ this.stateChanges = new Subject();
36
+ }
37
+ });
38
+ /**
39
+ * The `InputDirective` (`<input impdcInput`, `<textarea impdcInput` or `<select impdcInput`) is a directive for text inputs.
40
+ * With this directive, the input, textarea, and select can be used within a `FormFieldComponent` (`<impdc-form-field`).
41
+ * To use, import `ImpdcFormsModule` or another module that imports and exports that module from `@impartner/design-components`.
42
+ */
43
+ export class InputDirective extends _InputDirectiveBase {
44
+ constructor(_elementRef, ngControl, _formRoot, _parentForm, _parentFormGroup, _defaultErrorStateMatcher) {
45
+ super(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl);
46
+ this._elementRef = _elementRef;
47
+ this._uid = `impdc-input-${nanoid()}`;
48
+ this.focused = false;
49
+ this.controlType = 'impdc-input';
50
+ this.supportsAffixes = true;
51
+ this._disabled = false;
52
+ this._type = 'text';
53
+ this._readonly = false;
54
+ const { nativeElement } = this._elementRef;
55
+ const nodeName = nativeElement.nodeName.toLowerCase();
56
+ this._inputValueAccessor = nativeElement;
57
+ this.id = this.id;
58
+ this._isSelect = nodeName === 'select';
59
+ this._isTextarea = nodeName === 'textarea';
60
+ if (this._isSelect) {
61
+ this.controlType = nativeElement.multiple
62
+ ? 'impdc-native-select-multiple'
63
+ : 'impdc-native-select';
64
+ }
65
+ }
66
+ get disabled() {
67
+ return this._disabled;
68
+ }
69
+ set disabled(value) {
70
+ this._disabled = coerceBooleanPropertyValue(value);
71
+ if (this.focused) {
72
+ this.focused = false;
73
+ this.stateChanges.next();
74
+ }
75
+ }
76
+ get id() {
77
+ return this._id;
78
+ }
79
+ set id(value) {
80
+ this._id = value || this._uid;
81
+ }
82
+ /**
83
+ * Supports most standard `<input [type]>` attribute values. Does not support `button`, `checkbox`,
84
+ * `file`, `hidden`, `image`, `radio`, `range`, `reset`, or `button`, and does not apply to
85
+ * `<textarea>` or `<select>` elements.
86
+ *
87
+ * @default text
88
+ */
89
+ get type() {
90
+ return this._type;
91
+ }
92
+ set type(value) {
93
+ if (!this._typeIsValid(value)) {
94
+ throw getInputUnsupportedTypeError(value);
95
+ }
96
+ this._type = value || 'text';
97
+ // Sync with native input element.
98
+ if (!this._isTextarea) {
99
+ this._elementRef.nativeElement.type = this._type;
100
+ }
101
+ }
102
+ /**
103
+ * Used to set requiredness of control in a template-based manner;
104
+ * not necessary when using the Angular reactive forms API and `required` validator.
105
+ */
106
+ get required() {
107
+ return (this._required ??
108
+ this.ngControl?.control?.hasValidator(Validators.required) ??
109
+ false);
110
+ }
111
+ set required(value) {
112
+ this._required = coerceBooleanPropertyValue(value);
113
+ this.stateChanges.next();
114
+ }
115
+ /**
116
+ * Used to put the control in a non-interactive readonly state; only supports `<input>` and
117
+ * `<textarea>` elements.
118
+ *
119
+ * To see the difference between `readonly` and `disabled`, refer to [MDN's documentation](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/readonly).
120
+ */
121
+ get readonly() {
122
+ return this._readonly;
123
+ }
124
+ set readonly(value) {
125
+ this._readonly = coerceBooleanPropertyValue(value);
126
+ }
127
+ get value() {
128
+ return this._inputValueAccessor.value;
129
+ }
130
+ set value(value) {
131
+ if (value !== this.value) {
132
+ this._inputValueAccessor.value = value;
133
+ this.stateChanges.next();
134
+ }
135
+ }
136
+ /** @ignore */
137
+ ngDoCheck() {
138
+ if (this.ngControl) {
139
+ this.updateErrorState();
140
+ if (this.ngControl.disabled !== null &&
141
+ this.ngControl.disabled !== this.disabled) {
142
+ this.disabled = this.ngControl.disabled;
143
+ this.stateChanges.next();
144
+ }
145
+ }
146
+ }
147
+ /** @ignore */
148
+ ngOnChanges() {
149
+ this.stateChanges.next();
150
+ }
151
+ /** @ignore */
152
+ ngOnDestroy() {
153
+ this.stateChanges.complete();
154
+ }
155
+ _focusChanged(isFocused) {
156
+ if (isFocused !== this.focused) {
157
+ this.focused = isFocused;
158
+ this.stateChanges.next();
159
+ }
160
+ }
161
+ _typeIsValid(inputType) {
162
+ return IMPDC_INPUT_INVALID_TYPES.indexOf(inputType) === -1;
163
+ }
164
+ _onInput() {
165
+ // This is a noop function and is used to let Angular know whenever the value changes.
166
+ // Angular will run a new change detection each time the `input` event has been dispatched.
167
+ // It's necessary that Angular recognizes the value change, because when Angular forms
168
+ // aren't used, the placeholder won't recognize the value changes and will not disappear.
169
+ // Listening to the input event wouldn't be necessary when the input is using the
170
+ // FormsModule or ReactiveFormsModule, because Angular forms also listens to input events.
171
+ }
172
+ }
173
+ InputDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: InputDirective, deps: [{ token: i0.ElementRef }, { token: i1.NgControl, optional: true, self: true }, { token: IMPDC_FORM_ROOT, optional: true }, { token: i1.NgForm, optional: true }, { token: i1.FormGroupDirective, optional: true }, { token: i2.ErrorStateMatcher }], target: i0.ɵɵFactoryTarget.Directive });
174
+ InputDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: InputDirective, selector: "input[impdcInput], textarea[impdcInput], select[impdcNativeSelect]", inputs: { disabled: "disabled", id: "id", type: "type", required: "required", readonly: "readonly", errorStateMatcher: "errorStateMatcher", value: "value" }, host: { listeners: { "focus": "_focusChanged(true)", "blur": "_focusChanged(false)", "input": "_onInput()" }, properties: { "id": "id", "disabled": "disabled", "required": "required", "attr.id": "id", "attr.readonly": "readonly && !_isSelect || null", "attr.aria-required": "required.toString()", "attr.aria-disabled": "disabled.toString()", "attr.aria-invalid": "errorState", "class.form-control": "!_isSelect", "class.form-control-color": "type === \"color\"", "class.form-select": "_isSelect", "class.impdc-form-field-control": "true", "class.is-invalid": "errorState", "class.impdc-input--invalid": "errorState", "class.impdc-input--disabled": "disabled", "class.impdc-input--required": "required" }, classAttribute: "impdc-input" }, providers: [{ provide: ImpdcFormFieldControl, useExisting: InputDirective }], exportAs: ["impdcInput"], usesInheritance: true, usesOnChanges: true, ngImport: i0 });
175
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: InputDirective, decorators: [{
176
+ type: Directive,
177
+ args: [{
178
+ selector: 'input[impdcInput], textarea[impdcInput], select[impdcNativeSelect]',
179
+ exportAs: 'impdcInput',
180
+ // eslint-disable-next-line @angular-eslint/no-host-metadata-property
181
+ host: {
182
+ class: 'impdc-input',
183
+ '[id]': 'id',
184
+ '[disabled]': 'disabled',
185
+ '[required]': 'required',
186
+ '[attr.id]': 'id',
187
+ '[attr.readonly]': 'readonly && !_isSelect || null',
188
+ '[attr.aria-required]': 'required.toString()',
189
+ '[attr.aria-disabled]': 'disabled.toString()',
190
+ '[attr.aria-invalid]': 'errorState',
191
+ '[class.form-control]': '!_isSelect',
192
+ '[class.form-control-color]': 'type === "color"',
193
+ '[class.form-select]': '_isSelect',
194
+ '[class.impdc-form-field-control]': 'true',
195
+ '[class.is-invalid]': 'errorState',
196
+ '[class.impdc-input--invalid]': 'errorState',
197
+ '[class.impdc-input--disabled]': 'disabled',
198
+ '[class.impdc-input--required]': 'required',
199
+ '(focus)': '_focusChanged(true)',
200
+ '(blur)': '_focusChanged(false)',
201
+ '(input)': '_onInput()'
202
+ },
203
+ providers: [{ provide: ImpdcFormFieldControl, useExisting: InputDirective }]
204
+ }]
205
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.NgControl, decorators: [{
206
+ type: Optional
207
+ }, {
208
+ type: Self
209
+ }] }, { type: undefined, decorators: [{
210
+ type: Optional
211
+ }, {
212
+ type: Inject,
213
+ args: [IMPDC_FORM_ROOT]
214
+ }] }, { type: i1.NgForm, decorators: [{
215
+ type: Optional
216
+ }] }, { type: i1.FormGroupDirective, decorators: [{
217
+ type: Optional
218
+ }] }, { type: i2.ErrorStateMatcher }]; }, propDecorators: { disabled: [{
219
+ type: Input
220
+ }], id: [{
221
+ type: Input
222
+ }], type: [{
223
+ type: Input
224
+ }], required: [{
225
+ type: Input
226
+ }], readonly: [{
227
+ type: Input
228
+ }], errorStateMatcher: [{
229
+ type: Input
230
+ }], value: [{
231
+ type: Input
232
+ }] } });
233
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/design-components/src/lib/form-field/controls/input/input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/no-conflicting-lifecycle */\nimport {\n  Directive,\n  DoCheck,\n  ElementRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Self\n} from '@angular/core';\nimport {\n  FormGroupDirective,\n  NgControl,\n  NgForm,\n  Validators\n} from '@angular/forms';\nimport { nanoid } from 'nanoid';\nimport { Subject } from 'rxjs';\nimport {\n  BooleanInput,\n  coerceBooleanPropertyValue\n} from '../../../../utilities';\nimport { ImpdcFormRoot, IMPDC_FORM_ROOT } from '../../directives';\nimport { ErrorStateMatcher } from '../../services';\nimport {\n  ICanUpdateErrorState,\n  IHasErrorState,\n  mixinErrorState\n} from '../../shared';\nimport { ImpdcFormFieldControl } from '../../shared/form-field-control';\n\nconst IMPDC_INPUT_INVALID_TYPES = [\n  'button',\n  'checkbox',\n  'file',\n  'hidden',\n  'image',\n  'radio',\n  'range',\n  'reset',\n  'submit'\n];\n\n/** @docs-private */\nexport function getInputUnsupportedTypeError(type: string): Error {\n  return Error(`Input type \"${type}\" isn't supported by impdcInput.`);\n}\n\nconst _InputDirectiveBase = mixinErrorState(\n  class {\n    public readonly stateChanges = new Subject<void>();\n\n    constructor(\n      public _defaultErrorStateMatcher: ErrorStateMatcher,\n      public _formRoot: ImpdcFormRoot,\n      public _parentForm: NgForm,\n      public _parentFormGroup: FormGroupDirective,\n      public ngControl: NgControl | null\n    ) {}\n  }\n);\n\n/**\n * The `InputDirective` (`<input impdcInput`, `<textarea impdcInput` or `<select impdcInput`) is a directive for text inputs.\n * With this directive, the input, textarea, and select can be used within a `FormFieldComponent` (`<impdc-form-field`).\n * To use, import `ImpdcFormsModule` or another module that imports and exports that module from `@impartner/design-components`.\n */\n@Directive({\n  selector:\n    'input[impdcInput], textarea[impdcInput], select[impdcNativeSelect]',\n  exportAs: 'impdcInput',\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    class: 'impdc-input',\n    '[id]': 'id',\n    '[disabled]': 'disabled',\n    '[required]': 'required',\n    '[attr.id]': 'id',\n    '[attr.readonly]': 'readonly && !_isSelect || null',\n    '[attr.aria-required]': 'required.toString()',\n    '[attr.aria-disabled]': 'disabled.toString()',\n    '[attr.aria-invalid]': 'errorState',\n    '[class.form-control]': '!_isSelect',\n    '[class.form-control-color]': 'type === \"color\"',\n    '[class.form-select]': '_isSelect',\n    '[class.impdc-form-field-control]': 'true',\n    '[class.is-invalid]': 'errorState',\n    '[class.impdc-input--invalid]': 'errorState',\n    '[class.impdc-input--disabled]': 'disabled',\n    '[class.impdc-input--required]': 'required',\n    '(focus)': '_focusChanged(true)',\n    '(blur)': '_focusChanged(false)',\n    '(input)': '_onInput()'\n  },\n  providers: [{ provide: ImpdcFormFieldControl, useExisting: InputDirective }]\n})\nexport class InputDirective\n  extends _InputDirectiveBase\n  implements\n    ImpdcFormFieldControl<any>,\n    ICanUpdateErrorState,\n    IHasErrorState,\n    OnChanges,\n    OnDestroy,\n    DoCheck\n{\n  private _inputValueAccessor: { value: any };\n\n  protected _uid = `impdc-input-${nanoid()}`;\n  protected _isSelect: boolean;\n  protected _isTextarea: boolean;\n\n  public focused: boolean = false;\n\n  public readonly controlType?: string = 'impdc-input';\n  public readonly supportsAffixes: boolean = true;\n\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: BooleanInput) {\n    this._disabled = coerceBooleanPropertyValue(value);\n\n    if (this.focused) {\n      this.focused = false;\n      this.stateChanges.next();\n    }\n  }\n  protected _disabled = false;\n\n  @Input()\n  get id(): string {\n    return this._id;\n  }\n  set id(value: string) {\n    this._id = value || this._uid;\n  }\n  protected _id!: string;\n\n  /**\n   * Supports most standard `<input [type]>` attribute values. Does not support `button`, `checkbox`,\n   * `file`, `hidden`, `image`, `radio`, `range`, `reset`, or `button`, and does not apply to\n   * `<textarea>` or `<select>` elements.\n   *\n   * @default text\n   */\n  @Input()\n  get type(): string {\n    return this._type;\n  }\n  set type(value: string) {\n    if (!this._typeIsValid(value)) {\n      throw getInputUnsupportedTypeError(value);\n    }\n\n    this._type = value || 'text';\n\n    // Sync with native input element.\n    if (!this._isTextarea) {\n      (this._elementRef.nativeElement as HTMLInputElement).type = this._type;\n    }\n  }\n  protected _type = 'text';\n\n  /**\n   * Used to set requiredness of control in a template-based manner;\n   * not necessary when using the Angular reactive forms API and `required` validator.\n   */\n  @Input()\n  public get required(): boolean {\n    return (\n      this._required ??\n      this.ngControl?.control?.hasValidator(Validators.required) ??\n      false\n    );\n  }\n  public set required(value: BooleanInput) {\n    this._required = coerceBooleanPropertyValue(value);\n    this.stateChanges.next();\n  }\n  private _required: boolean | undefined;\n\n  /**\n   * Used to put the control in a non-interactive readonly state; only supports `<input>` and\n   * `<textarea>` elements.\n   *\n   * To see the difference between `readonly` and `disabled`, refer to [MDN's documentation](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/readonly).\n   */\n  @Input()\n  public get readonly(): boolean {\n    return this._readonly;\n  }\n  public set readonly(value: BooleanInput) {\n    this._readonly = coerceBooleanPropertyValue(value);\n  }\n  private _readonly = false;\n\n  @Input()\n  public override errorStateMatcher!: ErrorStateMatcher;\n\n  @Input()\n  get value(): string {\n    return this._inputValueAccessor.value;\n  }\n  set value(value: any) {\n    if (value !== this.value) {\n      this._inputValueAccessor.value = value;\n      this.stateChanges.next();\n    }\n  }\n\n  constructor(\n    protected _elementRef: ElementRef<\n      HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement\n    >,\n    @Optional() @Self() ngControl: NgControl,\n    @Optional() @Inject(IMPDC_FORM_ROOT) _formRoot: ImpdcFormRoot,\n    @Optional() _parentForm: NgForm,\n    @Optional() _parentFormGroup: FormGroupDirective,\n    _defaultErrorStateMatcher: ErrorStateMatcher\n  ) {\n    super(\n      _defaultErrorStateMatcher,\n      _formRoot,\n      _parentForm,\n      _parentFormGroup,\n      ngControl\n    );\n\n    const { nativeElement } = this._elementRef;\n    const nodeName = nativeElement.nodeName.toLowerCase();\n\n    this._inputValueAccessor = nativeElement;\n    this.id = this.id;\n    this._isSelect = nodeName === 'select';\n    this._isTextarea = nodeName === 'textarea';\n\n    if (this._isSelect) {\n      this.controlType = (nativeElement as HTMLSelectElement).multiple\n        ? 'impdc-native-select-multiple'\n        : 'impdc-native-select';\n    }\n  }\n\n  /** @ignore */\n  public ngDoCheck(): void {\n    if (this.ngControl) {\n      this.updateErrorState();\n\n      if (\n        this.ngControl.disabled !== null &&\n        this.ngControl.disabled !== this.disabled\n      ) {\n        this.disabled = this.ngControl.disabled;\n        this.stateChanges.next();\n      }\n    }\n  }\n\n  /** @ignore */\n  public ngOnChanges(): void {\n    this.stateChanges.next();\n  }\n\n  /** @ignore */\n  public ngOnDestroy(): void {\n    this.stateChanges.complete();\n  }\n\n  protected _focusChanged(isFocused: boolean): void {\n    if (isFocused !== this.focused) {\n      this.focused = isFocused;\n      this.stateChanges.next();\n    }\n  }\n\n  protected _typeIsValid(inputType: string): boolean {\n    return IMPDC_INPUT_INVALID_TYPES.indexOf(inputType) === -1;\n  }\n\n  protected _onInput() {\n    // This is a noop function and is used to let Angular know whenever the value changes.\n    // Angular will run a new change detection each time the `input` event has been dispatched.\n    // It's necessary that Angular recognizes the value change, because when Angular forms\n    // aren't used, the placeholder won't recognize the value changes and will not disappear.\n    // Listening to the input event wouldn't be necessary when the input is using the\n    // FormsModule or ReactiveFormsModule, because Angular forms also listens to input events.\n  }\n}\n"]}
@@ -0,0 +1,6 @@
1
+ export { RadioChangeEvent } from './interfaces';
2
+ export { RadioButtonComponent } from './radio-button/radio-button.component';
3
+ export { RadioGroupDirective } from './radio-group/radio-group.directive';
4
+ export { IMPDC_RADIO_GROUP, IMPDC_RADIO_BUTTON } from './injection-tokens';
5
+ export { RadioModule } from './radio.module';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL2Zvcm0tZmllbGQvY29udHJvbHMvcmFkaW8vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUE2QixNQUFNLGNBQWMsQ0FBQztBQUMzRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUMzRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBSYWRpb0NoYW5nZUV2ZW50LCBJUmFkaW9CdXR0b24sIElSYWRpb0dyb3VwIH0gZnJvbSAnLi9pbnRlcmZhY2VzJztcbmV4cG9ydCB7IFJhZGlvQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9yYWRpby1idXR0b24vcmFkaW8tYnV0dG9uLmNvbXBvbmVudCc7XG5leHBvcnQgeyBSYWRpb0dyb3VwRGlyZWN0aXZlIH0gZnJvbSAnLi9yYWRpby1ncm91cC9yYWRpby1ncm91cC5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgSU1QRENfUkFESU9fR1JPVVAsIElNUERDX1JBRElPX0JVVFRPTiB9IGZyb20gJy4vaW5qZWN0aW9uLXRva2Vucyc7XG5leHBvcnQgeyBSYWRpb01vZHVsZSB9IGZyb20gJy4vcmFkaW8ubW9kdWxlJztcbiJdfQ==
@@ -0,0 +1,4 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ export const IMPDC_RADIO_GROUP = new InjectionToken('ImpdcRadioGroup');
3
+ export const IMPDC_RADIO_BUTTON = new InjectionToken('ImpdcRadioButton');
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0aW9uLXRva2Vucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1jb21wb25lbnRzL3NyYy9saWIvZm9ybS1maWVsZC9jb250cm9scy9yYWRpby9pbmplY3Rpb24tdG9rZW5zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHL0MsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxjQUFjLENBQ2pELGlCQUFpQixDQUNsQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsSUFBSSxjQUFjLENBQ2xELGtCQUFrQixDQUNuQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElSYWRpb0J1dHRvbiwgSVJhZGlvR3JvdXAgfSBmcm9tICcuL2ludGVyZmFjZXMnO1xuXG5leHBvcnQgY29uc3QgSU1QRENfUkFESU9fR1JPVVAgPSBuZXcgSW5qZWN0aW9uVG9rZW48SVJhZGlvR3JvdXA+KFxuICAnSW1wZGNSYWRpb0dyb3VwJ1xuKTtcblxuZXhwb3J0IGNvbnN0IElNUERDX1JBRElPX0JVVFRPTiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxJUmFkaW9CdXR0b24+KFxuICAnSW1wZGNSYWRpb0J1dHRvbidcbik7XG4iXX0=
@@ -0,0 +1,4 @@
1
+ export * from './radio-change-event.interface';
2
+ export * from './radio-button.interface';
3
+ export * from './radio-group.interface';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL2Zvcm0tZmllbGQvY29udHJvbHMvcmFkaW8vaW50ZXJmYWNlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx5QkFBeUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcmFkaW8tY2hhbmdlLWV2ZW50LmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL3JhZGlvLWJ1dHRvbi5pbnRlcmZhY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9yYWRpby1ncm91cC5pbnRlcmZhY2UnO1xuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8tYnV0dG9uLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1jb21wb25lbnRzL3NyYy9saWIvZm9ybS1maWVsZC9jb250cm9scy9yYWRpby9pbnRlcmZhY2VzL3JhZGlvLWJ1dHRvbi5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSVJhZGlvQnV0dG9uIHtcbiAgY2hlY2tlZDogYm9vbGVhbjtcbiAgbmFtZTogc3RyaW5nO1xuICB2YWx1ZTogYW55O1xuXG4gIG1hcmtGb3JDaGVjaygpOiB2b2lkO1xufVxuIl19
@@ -0,0 +1,11 @@
1
+ export class RadioChangeEvent {
2
+ constructor(
3
+ /** The specific radio button that changed. */
4
+ source,
5
+ /** The selected value. */
6
+ value) {
7
+ this.source = source;
8
+ this.value = value;
9
+ }
10
+ }
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8tY2hhbmdlLWV2ZW50LmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1jb21wb25lbnRzL3NyYy9saWIvZm9ybS1maWVsZC9jb250cm9scy9yYWRpby9pbnRlcmZhY2VzL3JhZGlvLWNoYW5nZS1ldmVudC5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxPQUFPLGdCQUFnQjtJQUMzQjtJQUNFLDhDQUE4QztJQUM5QixNQUFvQjtJQUNwQywwQkFBMEI7SUFDVixLQUFVO1FBRlYsV0FBTSxHQUFOLE1BQU0sQ0FBYztRQUVwQixVQUFLLEdBQUwsS0FBSyxDQUFLO0lBQ3pCLENBQUM7Q0FDTCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElSYWRpb0J1dHRvbiB9IGZyb20gJy4vcmFkaW8tYnV0dG9uLmludGVyZmFjZSc7XG5cbmV4cG9ydCBjbGFzcyBSYWRpb0NoYW5nZUV2ZW50IHtcbiAgY29uc3RydWN0b3IoXG4gICAgLyoqIFRoZSBzcGVjaWZpYyByYWRpbyBidXR0b24gdGhhdCBjaGFuZ2VkLiAqL1xuICAgIHB1YmxpYyByZWFkb25seSBzb3VyY2U6IElSYWRpb0J1dHRvbixcbiAgICAvKiogVGhlIHNlbGVjdGVkIHZhbHVlLiAqL1xuICAgIHB1YmxpYyByZWFkb25seSB2YWx1ZTogYW55XG4gICkge31cbn1cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8tZ3JvdXAuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWNvbXBvbmVudHMvc3JjL2xpYi9mb3JtLWZpZWxkL2NvbnRyb2xzL3JhZGlvL2ludGVyZmFjZXMvcmFkaW8tZ3JvdXAuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJUmFkaW9CdXR0b24gfSBmcm9tICcuL3JhZGlvLWJ1dHRvbi5pbnRlcmZhY2UnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElSYWRpb0dyb3VwIHtcbiAgZ2V0IGRpc2FibGVkKCk6IGJvb2xlYW47XG4gIGdldCBlcnJvclN0YXRlKCk6IGJvb2xlYW47XG4gIGdldCBpbmxpbmUoKTogYm9vbGVhbjtcbiAgZ2V0IG5hbWUoKTogc3RyaW5nO1xuICBnZXQgcmVxdWlyZWQoKTogYm9vbGVhbjtcbiAgZ2V0IHZhbHVlKCk6IGFueTtcbiAgc2VsZWN0ZWQ6IElSYWRpb0J1dHRvbiB8IG51bGw7XG5cbiAgZW1pdENoYW5nZXNFdmVudCgpOiB2b2lkO1xuICBvbkNoYW5nZUZuKHZhbHVlOiBhbnkpOiB2b2lkO1xuICB0b3VjaCgpOiB2b2lkO1xufVxuIl19
@@ -0,0 +1,260 @@
1
+ import { Attribute, ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Inject, Input, Optional, Output, ViewChild } from '@angular/core';
2
+ import { nanoid } from 'nanoid';
3
+ import { coerceBooleanPropertyValue, coerceNumberPropertyValue } from '../../../../../utilities';
4
+ import { mixinTabIndex } from '../../../shared/tab-index.mixin';
5
+ import { IMPDC_RADIO_BUTTON, IMPDC_RADIO_GROUP } from '../injection-tokens';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../../services/unique-selection-dispatcher.service";
8
+ import * as i2 from "../../shared/toggle/toggle.component";
9
+ import * as i3 from "../../shared/toggle/components/toggle-input/toggle-input.component";
10
+ class RadioButtonComponentBase {
11
+ constructor() { }
12
+ }
13
+ const _RadioButtonComponentMixinBase = mixinTabIndex(RadioButtonComponentBase);
14
+ export class RadioButtonComponent extends _RadioButtonComponentMixinBase {
15
+ constructor(_changeDetector, _radioDispatcher, tabIndex, _radioGroup) {
16
+ super();
17
+ this._changeDetector = _changeDetector;
18
+ this._radioDispatcher = _radioDispatcher;
19
+ this._radioGroup = _radioGroup;
20
+ this._uid = `impdc-radio-button-${nanoid()}`;
21
+ this._removeUniqueSelectionListener = () => { };
22
+ this.id = this._uid;
23
+ this._checked = false;
24
+ this._value = null;
25
+ this._disabled = false;
26
+ this._required = false;
27
+ /**
28
+ * The primary label text for the radio button.
29
+ */
30
+ this.label = '';
31
+ /**
32
+ * Text to provide additional description or context for the radio button. Does
33
+ * not display if `inline` is `true`.
34
+ */
35
+ this.description = '';
36
+ /**
37
+ * Event emitted when the radio button becomes selected/checked.
38
+ */
39
+ this.change = new EventEmitter();
40
+ if (tabIndex) {
41
+ this.tabIndex = coerceNumberPropertyValue(tabIndex, 0);
42
+ }
43
+ }
44
+ /**
45
+ * Whether or not the radio input is checked/selected.
46
+ */
47
+ get checked() {
48
+ return this._checked;
49
+ }
50
+ set checked(value) {
51
+ const newCheckedValue = coerceBooleanPropertyValue(value);
52
+ if (this._checked !== newCheckedValue) {
53
+ this._checked = newCheckedValue;
54
+ if (newCheckedValue &&
55
+ this._radioGroup &&
56
+ this._radioGroup.value !== this.value) {
57
+ this._radioGroup.selected = this;
58
+ }
59
+ else if (!newCheckedValue &&
60
+ this._radioGroup &&
61
+ this._radioGroup.value === this.value) {
62
+ this._radioGroup.selected = null;
63
+ }
64
+ if (newCheckedValue) {
65
+ this._radioDispatcher.notify(this.id, this.name);
66
+ }
67
+ this._changeDetector.markForCheck();
68
+ }
69
+ }
70
+ /**
71
+ * The specific value represented by the radio button.
72
+ */
73
+ get value() {
74
+ return this._value;
75
+ }
76
+ set value(value) {
77
+ if (this._value !== value) {
78
+ this._value = value;
79
+ if (this._radioGroup) {
80
+ if (!this.checked) {
81
+ this.checked = this._radioGroup.value === value;
82
+ }
83
+ if (this.checked) {
84
+ this._radioGroup.selected = this;
85
+ }
86
+ }
87
+ }
88
+ }
89
+ /**
90
+ * Whether or not the radio button displays inline; Inherited from the parent `RadioGroupDirective` when available.
91
+ */
92
+ get inline() {
93
+ return (this._inline || (this._radioGroup && this._radioGroup.inline) || false);
94
+ }
95
+ set inline(value) {
96
+ this._inline = coerceBooleanPropertyValue(value);
97
+ }
98
+ /**
99
+ * Used to enable or disable the radio button, but will always return `true` when the parent
100
+ * `RadioGroupDirective` is already disabled.
101
+ */
102
+ get disabled() {
103
+ return (this._disabled || (this._radioGroup != null && this._radioGroup.disabled));
104
+ }
105
+ set disabled(value) {
106
+ const newDisabledState = coerceBooleanPropertyValue(value);
107
+ if (this._disabled !== newDisabledState) {
108
+ this._disabled = newDisabledState;
109
+ this._changeDetector.markForCheck();
110
+ }
111
+ }
112
+ /** @ignore */
113
+ get required() {
114
+ return (this._required || (this._radioGroup != null && this._radioGroup.required));
115
+ }
116
+ set required(value) {
117
+ this._required = coerceBooleanPropertyValue(value);
118
+ }
119
+ get _errorState() {
120
+ return this._radioGroup ? this._radioGroup.errorState : false;
121
+ }
122
+ /** @ignore */
123
+ ngOnInit() {
124
+ if (this._radioGroup) {
125
+ this.checked = this._radioGroup.value === this._value;
126
+ if (this.checked) {
127
+ this._radioGroup.selected = this;
128
+ }
129
+ this.name = this._radioGroup.name;
130
+ }
131
+ this._removeUniqueSelectionListener = this._radioDispatcher.listen((id, name) => {
132
+ if (id !== this.id && name === this.name) {
133
+ this.checked = false;
134
+ }
135
+ });
136
+ }
137
+ /** @ignore */
138
+ ngDoCheck() {
139
+ this._updateTabIndex();
140
+ }
141
+ /** @ignore */
142
+ ngAfterViewInit() {
143
+ this._updateTabIndex();
144
+ }
145
+ /** @ignore */
146
+ ngOnDestroy() {
147
+ this._removeUniqueSelectionListener();
148
+ }
149
+ /** @ignore */
150
+ markForCheck() {
151
+ this._changeDetector.markForCheck();
152
+ }
153
+ _emitChangesEvent() {
154
+ this.change.emit({ source: this, value: this._value });
155
+ }
156
+ _onBlur() {
157
+ if (this._radioGroup) {
158
+ this._radioGroup.touch();
159
+ }
160
+ }
161
+ _onInputChange(event) {
162
+ event.stopPropagation();
163
+ if (!this.checked && !this.disabled) {
164
+ const groupValueChanged = this._radioGroup && this.value !== this._radioGroup.value;
165
+ this.checked = true;
166
+ this._emitChangesEvent();
167
+ if (this._radioGroup) {
168
+ this._radioGroup.onChangeFn(this.value);
169
+ if (groupValueChanged) {
170
+ this._radioGroup.emitChangesEvent();
171
+ }
172
+ }
173
+ }
174
+ }
175
+ _updateTabIndex() {
176
+ const radioGroup = this._radioGroup;
177
+ let tabIndexValue;
178
+ if (!radioGroup || !radioGroup.selected || this.disabled) {
179
+ tabIndexValue = this.tabIndex;
180
+ }
181
+ else {
182
+ tabIndexValue = radioGroup.selected === this ? this.tabIndex : -1;
183
+ }
184
+ if (tabIndexValue !== this._previousTabIndex) {
185
+ const inputElt = this._inputElement?.nativeElement;
186
+ if (inputElt) {
187
+ inputElt.setAttribute('tabindex', tabIndexValue + '');
188
+ this._previousTabIndex = tabIndexValue;
189
+ }
190
+ }
191
+ }
192
+ }
193
+ RadioButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RadioButtonComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.UniqueSelectionDispatcher }, { token: 'tabindex', attribute: true }, { token: IMPDC_RADIO_GROUP, optional: true }], target: i0.ɵɵFactoryTarget.Component });
194
+ RadioButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: RadioButtonComponent, selector: "impdc-radio-button", inputs: { tabIndex: "tabIndex", id: "id", name: "name", ariaLabel: ["aria-label", "ariaLabel"], ariaLabelledby: ["aria-labelledby", "ariaLabelledby"], ariaDescribedby: ["aria-describedby", "ariaDescribedby"], checked: "checked", value: "value", inline: "inline", disabled: "disabled", required: "required", label: "label", description: "description" }, outputs: { change: "change" }, host: { properties: { "attr.id": "id", "attr.tabindex": "null", "attr.aria-label": "null", "attr.aria-labelledby": "null", "attr.aria-describedby": "null", "class.impdc-radio-button--required": "required", "class.impdc-radio-button--invalid": "_errorState", "class.impdc-radio-button--disabled": "disabled", "class.impdc-radio-button--inline": "inline" }, classAttribute: "impdc-radio-button" }, providers: [
195
+ {
196
+ provide: IMPDC_RADIO_BUTTON,
197
+ useExisting: RadioButtonComponent
198
+ }
199
+ ], viewQueries: [{ propertyName: "_inputElement", first: true, predicate: ["nativeInput"], descendants: true, read: ElementRef }], exportAs: ["impdcRadioButton"], usesInheritance: true, ngImport: i0, template: "<impdc-toggle [label]=\"label\" [description]=\"description\" [inline]=\"inline\">\n <input\n #nativeInput\n impdc-toggle-input\n type=\"radio\"\n class=\"impdc-radio-button__native-control\"\n [class.is-invalid]=\"_errorState\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [attr.name]=\"name\"\n [attr.value]=\"value\"\n [required]=\"required\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"ariaLabelledby\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n (change)=\"_onInputChange($event)\"\n (blur)=\"_onBlur()\" />\n</impdc-toggle>\n", styles: [":host{display:block;opacity:var(--impartner-hex-input-opacity, 1)}:host.impdc-radio-button--inline{display:inline-block}:host.impdc-radio-button--inline:not(:last-of-type){margin-right:4rem}:host:not(.impdc-radio-button--inline):not(:last-of-type){margin-bottom:1.6rem}:host.impdc-radio-button--disabled{--impartner-hex-input-opacity: .5}:host.impdc-radio-button--invalid ::ng-deep .form-check-label{color:var(--impd-color-red-600)}\n"], dependencies: [{ kind: "component", type: i2.ToggleComponent, selector: "impdc-toggle", inputs: ["isSwitch", "label", "description", "inline", "switchIcons"] }, { kind: "component", type: i3.ToggleInputComponent, selector: "input[impdc-toggle-input]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
200
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: RadioButtonComponent, decorators: [{
201
+ type: Component,
202
+ args: [{ selector: 'impdc-radio-button', host: {
203
+ class: 'impdc-radio-button',
204
+ '[attr.id]': 'id',
205
+ '[attr.tabindex]': 'null',
206
+ '[attr.aria-label]': 'null',
207
+ '[attr.aria-labelledby]': 'null',
208
+ '[attr.aria-describedby]': 'null',
209
+ '[class.impdc-radio-button--required]': 'required',
210
+ '[class.impdc-radio-button--invalid]': '_errorState',
211
+ '[class.impdc-radio-button--disabled]': 'disabled',
212
+ '[class.impdc-radio-button--inline]': 'inline'
213
+ }, inputs: ['tabIndex'], exportAs: 'impdcRadioButton', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
214
+ {
215
+ provide: IMPDC_RADIO_BUTTON,
216
+ useExisting: RadioButtonComponent
217
+ }
218
+ ], template: "<impdc-toggle [label]=\"label\" [description]=\"description\" [inline]=\"inline\">\n <input\n #nativeInput\n impdc-toggle-input\n type=\"radio\"\n class=\"impdc-radio-button__native-control\"\n [class.is-invalid]=\"_errorState\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [attr.name]=\"name\"\n [attr.value]=\"value\"\n [required]=\"required\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"ariaLabelledby\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n (change)=\"_onInputChange($event)\"\n (blur)=\"_onBlur()\" />\n</impdc-toggle>\n", styles: [":host{display:block;opacity:var(--impartner-hex-input-opacity, 1)}:host.impdc-radio-button--inline{display:inline-block}:host.impdc-radio-button--inline:not(:last-of-type){margin-right:4rem}:host:not(.impdc-radio-button--inline):not(:last-of-type){margin-bottom:1.6rem}:host.impdc-radio-button--disabled{--impartner-hex-input-opacity: .5}:host.impdc-radio-button--invalid ::ng-deep .form-check-label{color:var(--impd-color-red-600)}\n"] }]
219
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.UniqueSelectionDispatcher }, { type: undefined, decorators: [{
220
+ type: Attribute,
221
+ args: ['tabindex']
222
+ }] }, { type: undefined, decorators: [{
223
+ type: Inject,
224
+ args: [IMPDC_RADIO_GROUP]
225
+ }, {
226
+ type: Optional
227
+ }] }]; }, propDecorators: { _inputElement: [{
228
+ type: ViewChild,
229
+ args: ['nativeInput', { read: ElementRef }]
230
+ }], id: [{
231
+ type: Input
232
+ }], name: [{
233
+ type: Input
234
+ }], ariaLabel: [{
235
+ type: Input,
236
+ args: ['aria-label']
237
+ }], ariaLabelledby: [{
238
+ type: Input,
239
+ args: ['aria-labelledby']
240
+ }], ariaDescribedby: [{
241
+ type: Input,
242
+ args: ['aria-describedby']
243
+ }], checked: [{
244
+ type: Input
245
+ }], value: [{
246
+ type: Input
247
+ }], inline: [{
248
+ type: Input
249
+ }], disabled: [{
250
+ type: Input
251
+ }], required: [{
252
+ type: Input
253
+ }], label: [{
254
+ type: Input
255
+ }], description: [{
256
+ type: Input
257
+ }], change: [{
258
+ type: Output
259
+ }] } });
260
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-button.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/design-components/src/lib/form-field/controls/radio/radio-button/radio-button.component.ts","../../../../../../../../../projects/design-components/src/lib/form-field/controls/radio/radio-button/radio-button.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EACT,uBAAuB,EAEvB,SAAS,EAET,UAAU,EACV,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,QAAQ,EACR,MAAM,EACN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EAEL,0BAA0B,EAC1B,yBAAyB,EAC1B,MAAM,0BAA0B,CAAC;AAElC,OAAO,EAAe,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAC7E,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;;;;;AAG5E,MAAe,wBAAwB;IAErC,gBAAe,CAAC;CACjB;AAED,MAAM,8BAA8B,GAAG,aAAa,CAAC,wBAAwB,CAAC,CAAC;AA8B/E,MAAM,OAAO,oBACX,SAAQ,8BAA8B;IA6KtC,YACmB,eAAkC,EAC3C,gBAA2C,EAC5B,QAAiB,EACQ,WAAyB;QAEzE,KAAK,EAAE,CAAC;QALS,oBAAe,GAAf,eAAe,CAAmB;QAC3C,qBAAgB,GAAhB,gBAAgB,CAA2B;QAEH,gBAAW,GAAX,WAAW,CAAc;QAxK1D,SAAI,GAAW,sBAAsB,MAAM,EAAE,EAAE,CAAC;QACzD,mCAA8B,GAAe,GAAG,EAAE,GAAE,CAAC,CAAC;QAOvD,OAAE,GAAW,IAAI,CAAC,IAAI,CAAC;QA4DpB,aAAQ,GAAY,KAAK,CAAC;QAwB1B,WAAM,GAAQ,IAAI,CAAC;QAkCnB,cAAS,GAAY,KAAK,CAAC;QAY3B,cAAS,GAAY,KAAK,CAAC;QAErC;;WAEG;QAEI,UAAK,GAAW,EAAE,CAAC;QAE1B;;;WAGG;QAEI,gBAAW,GAAW,EAAE,CAAC;QAEhC;;WAEG;QAGa,WAAM,GAAG,IAAI,YAAY,EAAoB,CAAC;QAc5D,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,QAAQ,GAAG,yBAAyB,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;SACxD;IACH,CAAC;IA7ID;;OAEG;IACH,IACW,OAAO;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IACD,IAAW,OAAO,CAAC,KAAmB;QACpC,MAAM,eAAe,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;QAE1D,IAAI,IAAI,CAAC,QAAQ,KAAK,eAAe,EAAE;YACrC,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC;YAEhC,IACE,eAAe;gBACf,IAAI,CAAC,WAAW;gBAChB,IAAI,CAAC,WAAW,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,EACrC;gBACA,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,IAAI,CAAC;aAClC;iBAAM,IACL,CAAC,eAAe;gBAChB,IAAI,CAAC,WAAW;gBAChB,IAAI,CAAC,WAAW,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,EACrC;gBACA,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,IAAI,CAAC;aAClC;YAED,IAAI,eAAe,EAAE;gBACnB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;aAClD;YAED,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;SACrC;IACH,CAAC;IAGD;;OAEG;IACH,IACW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IACD,IAAW,KAAK,CAAC,KAAU;QACzB,IAAI,IAAI,CAAC,MAAM,KAAK,KAAK,EAAE;YACzB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YAEpB,IAAI,IAAI,CAAC,WAAW,EAAE;gBACpB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;oBACjB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,KAAK,KAAK,CAAC;iBACjD;gBAED,IAAI,IAAI,CAAC,OAAO,EAAE;oBAChB,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,IAAI,CAAC;iBAClC;aACF;SACF;IACH,CAAC;IAGD;;OAEG;IACH,IACW,MAAM;QACf,OAAO,CACL,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,KAAK,CACvE,CAAC;IACJ,CAAC;IACD,IAAW,MAAM,CAAC,KAAmB;QACnC,IAAI,CAAC,OAAO,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;IAGD;;;OAGG;IACH,IACW,QAAQ;QACjB,OAAO,CACL,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAC1E,CAAC;IACJ,CAAC;IACD,IAAW,QAAQ,CAAC,KAAmB;QACrC,MAAM,gBAAgB,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;QAE3D,IAAI,IAAI,CAAC,SAAS,KAAK,gBAAgB,EAAE;YACvC,IAAI,CAAC,SAAS,GAAG,gBAAgB,CAAC;YAClC,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;SACrC;IACH,CAAC;IAGD,cAAc;IACd,IACW,QAAQ;QACjB,OAAO,CACL,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAC1E,CAAC;IACJ,CAAC;IACD,IAAW,QAAQ,CAAC,KAAmB;QACrC,IAAI,CAAC,SAAS,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;IACrD,CAAC;IAuBD,IAAc,WAAW;QACvB,OAAO,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC;IAChE,CAAC;IAeD,cAAc;IACP,QAAQ;QACb,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,CAAC;YAEtD,IAAI,IAAI,CAAC,OAAO,EAAE;gBAChB,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,IAAI,CAAC;aAClC;YAED,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;SACnC;QAED,IAAI,CAAC,8BAA8B,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAChE,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YACX,IAAI,EAAE,KAAK,IAAI,CAAC,EAAE,IAAI,IAAI,KAAK,IAAI,CAAC,IAAI,EAAE;gBACxC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;QACH,CAAC,CACF,CAAC;IACJ,CAAC;IAED,cAAc;IACP,SAAS;QACd,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,cAAc;IACP,eAAe;QACpB,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,cAAc;IACP,WAAW;QAChB,IAAI,CAAC,8BAA8B,EAAE,CAAC;IACxC,CAAC;IAED,cAAc;IACP,YAAY;QACjB,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;IACtC,CAAC;IAES,iBAAiB;QACzB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IACzD,CAAC;IAES,OAAO;QACf,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;SAC1B;IACH,CAAC;IAES,cAAc,CAAC,KAAY;QACnC,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACnC,MAAM,iBAAiB,GACrB,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;YAC5D,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAEzB,IAAI,IAAI,CAAC,WAAW,EAAE;gBACpB,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAExC,IAAI,iBAAiB,EAAE;oBACrB,IAAI,CAAC,WAAW,CAAC,gBAAgB,EAAE,CAAC;iBACrC;aACF;SACF;IACH,CAAC;IAES,eAAe;QACvB,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC;QACpC,IAAI,aAAqB,CAAC;QAE1B,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,EAAE;YACxD,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC;SAC/B;aAAM;YACL,aAAa,GAAG,UAAU,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SACnE;QAED,IAAI,aAAa,KAAK,IAAI,CAAC,iBAAiB,EAAE;YAC5C,MAAM,QAAQ,GACZ,IAAI,CAAC,aAAa,EAAE,aAAa,CAAC;YAEpC,IAAI,QAAQ,EAAE;gBACZ,QAAQ,CAAC,YAAY,CAAC,UAAU,EAAE,aAAa,GAAG,EAAE,CAAC,CAAC;gBACtD,IAAI,CAAC,iBAAiB,GAAG,aAAa,CAAC;aACxC;SACF;IACH,CAAC;;kHApRU,oBAAoB,4FAiLlB,UAAU,8BACb,iBAAiB;sGAlLhB,oBAAoB,yzBAPpB;QACT;YACE,OAAO,EAAE,kBAAkB;YAC3B,WAAW,EAAE,oBAAoB;SAClC;KACF,mHAgBiC,UAAU,oFC7E9C,+lBAkBA;4FD6Ca,oBAAoB;kBA5BhC,SAAS;+BACE,oBAAoB,QAIxB;wBACJ,KAAK,EAAE,oBAAoB;wBAC3B,WAAW,EAAE,IAAI;wBACjB,iBAAiB,EAAE,MAAM;wBACzB,mBAAmB,EAAE,MAAM;wBAC3B,wBAAwB,EAAE,MAAM;wBAChC,yBAAyB,EAAE,MAAM;wBACjC,sCAAsC,EAAE,UAAU;wBAClD,qCAAqC,EAAE,aAAa;wBACpD,sCAAsC,EAAE,UAAU;wBAClD,oCAAoC,EAAE,QAAQ;qBAC/C,UAEO,CAAC,UAAU,CAAC,YACV,kBAAkB,mBACX,uBAAuB,CAAC,MAAM,aACpC;wBACT;4BACE,OAAO,EAAE,kBAAkB;4BAC3B,WAAW,sBAAsB;yBAClC;qBACF;;0BAmLE,SAAS;2BAAC,UAAU;;0BACpB,MAAM;2BAAC,iBAAiB;;0BAAG,QAAQ;4CAnK9B,aAAa;sBADpB,SAAS;uBAAC,aAAa,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAIvC,EAAE;sBADR,KAAK;gBAOC,IAAI;sBADV,KAAK;gBAOC,SAAS;sBADf,KAAK;uBAAC,YAAY;gBAOZ,cAAc;sBADpB,KAAK;uBAAC,iBAAiB;gBAOjB,eAAe;sBADrB,KAAK;uBAAC,kBAAkB;gBAOd,OAAO;sBADjB,KAAK;gBAqCK,KAAK;sBADf,KAAK;gBAyBK,MAAM;sBADhB,KAAK;gBAgBK,QAAQ;sBADlB,KAAK;gBAkBK,QAAQ;sBADlB,KAAK;gBAeC,KAAK;sBADX,KAAK;gBAQC,WAAW;sBADjB,KAAK;gBAQU,MAAM;sBAFrB,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  Attribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { nanoid } from 'nanoid';\nimport {\n  BooleanInput,\n  coerceBooleanPropertyValue,\n  coerceNumberPropertyValue\n} from '../../../../../utilities';\nimport { UniqueSelectionDispatcher } from '../../../services/unique-selection-dispatcher.service';\nimport { HasTabIndex, mixinTabIndex } from '../../../shared/tab-index.mixin';\nimport { IMPDC_RADIO_BUTTON, IMPDC_RADIO_GROUP } from '../injection-tokens';\nimport { RadioChangeEvent, IRadioButton, IRadioGroup } from '../interfaces';\n\nabstract class RadioButtonComponentBase {\n  abstract disabled: boolean;\n  constructor() {}\n}\n\nconst _RadioButtonComponentMixinBase = mixinTabIndex(RadioButtonComponentBase);\n\n@Component({\n  selector: 'impdc-radio-button',\n  templateUrl: './radio-button.component.html',\n  styleUrls: ['./radio-button.component.scss'],\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    class: 'impdc-radio-button',\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'null',\n    '[attr.aria-label]': 'null',\n    '[attr.aria-labelledby]': 'null',\n    '[attr.aria-describedby]': 'null',\n    '[class.impdc-radio-button--required]': 'required',\n    '[class.impdc-radio-button--invalid]': '_errorState',\n    '[class.impdc-radio-button--disabled]': 'disabled',\n    '[class.impdc-radio-button--inline]': 'inline'\n  },\n  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property\n  inputs: ['tabIndex'],\n  exportAs: 'impdcRadioButton',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: IMPDC_RADIO_BUTTON,\n      useExisting: RadioButtonComponent\n    }\n  ]\n})\nexport class RadioButtonComponent\n  extends _RadioButtonComponentMixinBase\n  implements\n    IRadioButton,\n    HasTabIndex,\n    OnInit,\n    OnDestroy,\n    DoCheck,\n    AfterViewInit\n{\n  private readonly _uid: string = `impdc-radio-button-${nanoid()}`;\n  private _removeUniqueSelectionListener: () => void = () => {};\n  private _previousTabIndex?: number;\n\n  @ViewChild('nativeInput', { read: ElementRef })\n  private _inputElement!: ElementRef<HTMLInputElement>;\n\n  @Input()\n  public id: string = this._uid;\n\n  /**\n   * The unique name for a group of radio options; Inherited from the parent `RadioGroupDirective` when available.\n   */\n  @Input()\n  public name!: string;\n\n  /**\n   * Property for setting ARIA \"label\" attribute.\n   */\n  @Input('aria-label')\n  public ariaLabel?: string;\n\n  /**\n   * Property for setting ARIA \"labelled by\" attribute.\n   */\n  @Input('aria-labelledby')\n  public ariaLabelledby?: string;\n\n  /**\n   * Property for setting ARIA \"described by\" attribute.\n   */\n  @Input('aria-describedby')\n  public ariaDescribedby?: string;\n\n  /**\n   * Whether or not the radio input is checked/selected.\n   */\n  @Input()\n  public get checked(): boolean {\n    return this._checked;\n  }\n  public set checked(value: BooleanInput) {\n    const newCheckedValue = coerceBooleanPropertyValue(value);\n\n    if (this._checked !== newCheckedValue) {\n      this._checked = newCheckedValue;\n\n      if (\n        newCheckedValue &&\n        this._radioGroup &&\n        this._radioGroup.value !== this.value\n      ) {\n        this._radioGroup.selected = this;\n      } else if (\n        !newCheckedValue &&\n        this._radioGroup &&\n        this._radioGroup.value === this.value\n      ) {\n        this._radioGroup.selected = null;\n      }\n\n      if (newCheckedValue) {\n        this._radioDispatcher.notify(this.id, this.name);\n      }\n\n      this._changeDetector.markForCheck();\n    }\n  }\n  protected _checked: boolean = false;\n\n  /**\n   * The specific value represented by the radio button.\n   */\n  @Input()\n  public get value(): any {\n    return this._value;\n  }\n  public set value(value: any) {\n    if (this._value !== value) {\n      this._value = value;\n\n      if (this._radioGroup) {\n        if (!this.checked) {\n          this.checked = this._radioGroup.value === value;\n        }\n\n        if (this.checked) {\n          this._radioGroup.selected = this;\n        }\n      }\n    }\n  }\n  protected _value: any = null;\n\n  /**\n   * Whether or not the radio button displays inline; Inherited from the parent `RadioGroupDirective` when available.\n   */\n  @Input()\n  public get inline(): boolean {\n    return (\n      this._inline || (this._radioGroup && this._radioGroup.inline) || false\n    );\n  }\n  public set inline(value: BooleanInput) {\n    this._inline = coerceBooleanPropertyValue(value);\n  }\n  protected _inline?: boolean;\n\n  /**\n   * Used to enable or disable the radio button, but will always return `true` when the parent\n   * `RadioGroupDirective` is already disabled.\n   */\n  @Input()\n  public get disabled(): boolean {\n    return (\n      this._disabled || (this._radioGroup != null && this._radioGroup.disabled)\n    );\n  }\n  public set disabled(value: BooleanInput) {\n    const newDisabledState = coerceBooleanPropertyValue(value);\n\n    if (this._disabled !== newDisabledState) {\n      this._disabled = newDisabledState;\n      this._changeDetector.markForCheck();\n    }\n  }\n  protected _disabled: boolean = false;\n\n  /** @ignore */\n  @Input()\n  public get required(): boolean {\n    return (\n      this._required || (this._radioGroup != null && this._radioGroup.required)\n    );\n  }\n  public set required(value: BooleanInput) {\n    this._required = coerceBooleanPropertyValue(value);\n  }\n  protected _required: boolean = false;\n\n  /**\n   * The primary label text for the radio button.\n   */\n  @Input()\n  public label: string = '';\n\n  /**\n   * Text to provide additional description or context for the radio button. Does\n   * not display if `inline` is `true`.\n   */\n  @Input()\n  public description: string = '';\n\n  /**\n   * Event emitted when the radio button becomes selected/checked.\n   */\n  @Output()\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  public readonly change = new EventEmitter<RadioChangeEvent>();\n\n  protected get _errorState(): boolean {\n    return this._radioGroup ? this._radioGroup.errorState : false;\n  }\n\n  constructor(\n    private readonly _changeDetector: ChangeDetectorRef,\n    private _radioDispatcher: UniqueSelectionDispatcher,\n    @Attribute('tabindex') tabIndex?: string,\n    @Inject(IMPDC_RADIO_GROUP) @Optional() readonly _radioGroup?: IRadioGroup\n  ) {\n    super();\n\n    if (tabIndex) {\n      this.tabIndex = coerceNumberPropertyValue(tabIndex, 0);\n    }\n  }\n\n  /** @ignore */\n  public ngOnInit(): void {\n    if (this._radioGroup) {\n      this.checked = this._radioGroup.value === this._value;\n\n      if (this.checked) {\n        this._radioGroup.selected = this;\n      }\n\n      this.name = this._radioGroup.name;\n    }\n\n    this._removeUniqueSelectionListener = this._radioDispatcher.listen(\n      (id, name) => {\n        if (id !== this.id && name === this.name) {\n          this.checked = false;\n        }\n      }\n    );\n  }\n\n  /** @ignore */\n  public ngDoCheck(): void {\n    this._updateTabIndex();\n  }\n\n  /** @ignore */\n  public ngAfterViewInit(): void {\n    this._updateTabIndex();\n  }\n\n  /** @ignore */\n  public ngOnDestroy(): void {\n    this._removeUniqueSelectionListener();\n  }\n\n  /** @ignore */\n  public markForCheck(): void {\n    this._changeDetector.markForCheck();\n  }\n\n  protected _emitChangesEvent(): void {\n    this.change.emit({ source: this, value: this._value });\n  }\n\n  protected _onBlur(): void {\n    if (this._radioGroup) {\n      this._radioGroup.touch();\n    }\n  }\n\n  protected _onInputChange(event: Event): void {\n    event.stopPropagation();\n\n    if (!this.checked && !this.disabled) {\n      const groupValueChanged =\n        this._radioGroup && this.value !== this._radioGroup.value;\n      this.checked = true;\n      this._emitChangesEvent();\n\n      if (this._radioGroup) {\n        this._radioGroup.onChangeFn(this.value);\n\n        if (groupValueChanged) {\n          this._radioGroup.emitChangesEvent();\n        }\n      }\n    }\n  }\n\n  protected _updateTabIndex(): void {\n    const radioGroup = this._radioGroup;\n    let tabIndexValue: number;\n\n    if (!radioGroup || !radioGroup.selected || this.disabled) {\n      tabIndexValue = this.tabIndex;\n    } else {\n      tabIndexValue = radioGroup.selected === this ? this.tabIndex : -1;\n    }\n\n    if (tabIndexValue !== this._previousTabIndex) {\n      const inputElt: HTMLInputElement | undefined =\n        this._inputElement?.nativeElement;\n\n      if (inputElt) {\n        inputElt.setAttribute('tabindex', tabIndexValue + '');\n        this._previousTabIndex = tabIndexValue;\n      }\n    }\n  }\n}\n","<impdc-toggle [label]=\"label\" [description]=\"description\" [inline]=\"inline\">\n  <input\n    #nativeInput\n    impdc-toggle-input\n    type=\"radio\"\n    class=\"impdc-radio-button__native-control\"\n    [class.is-invalid]=\"_errorState\"\n    [checked]=\"checked\"\n    [disabled]=\"disabled\"\n    [attr.name]=\"name\"\n    [attr.value]=\"value\"\n    [required]=\"required\"\n    [attr.aria-label]=\"ariaLabel\"\n    [attr.aria-labelledby]=\"ariaLabelledby\"\n    [attr.aria-describedby]=\"ariaDescribedby\"\n    (change)=\"_onInputChange($event)\"\n    (blur)=\"_onBlur()\" />\n</impdc-toggle>\n"]}