@impartner/design-components 1.2.0 → 2.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 (291) hide show
  1. package/README.md +5 -4
  2. package/constants/fontawesome-icons.d.ts +2 -2
  3. package/{esm2020 → esm2022}/constants/fontawesome-icons.mjs +1 -1
  4. package/{esm2020 → esm2022}/lib/alert/alert.component.mjs +4 -4
  5. package/{esm2020 → esm2022}/lib/alert/alert.module.mjs +5 -5
  6. package/{esm2020 → esm2022}/lib/avatar/avatar.component.mjs +4 -4
  7. package/{esm2020 → esm2022}/lib/avatar/avatar.module.mjs +5 -5
  8. package/{esm2020 → esm2022}/lib/avatar-group/avatar-group.component.mjs +4 -4
  9. package/{esm2020 → esm2022}/lib/avatar-group/avatar-group.module.mjs +5 -5
  10. package/esm2022/lib/backdrop/backdrop.component.mjs +52 -0
  11. package/{esm2020 → esm2022}/lib/backdrop/backdrop.module.mjs +6 -6
  12. package/esm2022/lib/badge/badge.component.mjs +105 -0
  13. package/{esm2020 → esm2022}/lib/badge/badge.module.mjs +6 -6
  14. package/{esm2020 → esm2022}/lib/badge/types/badge-size.mjs +1 -1
  15. package/{esm2020 → esm2022}/lib/branding/branded.directive.mjs +4 -4
  16. package/{esm2020 → esm2022}/lib/branding/branding.module.mjs +6 -6
  17. package/{esm2020 → esm2022}/lib/breadcrumb/breadcrumb-item.component.mjs +6 -6
  18. package/{esm2020 → esm2022}/lib/breadcrumb/breadcrumb.component.mjs +5 -5
  19. package/{esm2020 → esm2022}/lib/breadcrumb/breadcrumb.module.mjs +5 -5
  20. package/{esm2020 → esm2022}/lib/button/button.component.mjs +4 -4
  21. package/{esm2020 → esm2022}/lib/button/button.module.mjs +6 -6
  22. package/{esm2020 → esm2022}/lib/button-group/button-group.component.mjs +4 -4
  23. package/{esm2020 → esm2022}/lib/button-group/button-group.module.mjs +6 -6
  24. package/{esm2020 → esm2022}/lib/card-heading/card-heading.component.mjs +5 -5
  25. package/{esm2020 → esm2022}/lib/card-heading/card-heading.module.mjs +6 -6
  26. package/esm2022/lib/data-card/data-card.component.mjs +123 -0
  27. package/esm2022/lib/data-card/data-card.module.mjs +21 -0
  28. package/{esm2020 → esm2022}/lib/design-components.module.mjs +61 -61
  29. package/{esm2020 → esm2022}/lib/dropdown/components/dropdown-item/dropdown-item.component.mjs +4 -4
  30. package/esm2022/lib/dropdown/dropdown.component.mjs +143 -0
  31. package/{esm2020 → esm2022}/lib/dropdown/dropdown.module.mjs +6 -6
  32. package/{esm2020 → esm2022}/lib/file-upload/directives/file-drop.directive.mjs +4 -4
  33. package/{esm2020 → esm2022}/lib/file-upload/file-upload.component.mjs +30 -30
  34. package/{esm2020 → esm2022}/lib/file-upload/file-upload.module.mjs +8 -8
  35. package/{esm2020 → esm2022}/lib/file-upload/pipes/human-readable-byte-size.pipe.mjs +4 -4
  36. package/{esm2020 → esm2022}/lib/form-field/controls/checkbox/checkbox.component.mjs +49 -49
  37. package/{esm2020 → esm2022}/lib/form-field/controls/checkbox/checkbox.module.mjs +5 -5
  38. package/esm2022/lib/form-field/controls/input/input.directive.mjs +233 -0
  39. package/esm2022/lib/form-field/controls/radio/radio-button/radio-button.component.mjs +260 -0
  40. package/esm2022/lib/form-field/controls/radio/radio-group/radio-group.directive.mjs +289 -0
  41. package/{esm2020 → esm2022}/lib/form-field/controls/radio/radio.module.mjs +5 -5
  42. package/esm2022/lib/form-field/controls/select/option/select-option.component.mjs +139 -0
  43. package/esm2022/lib/form-field/controls/select/select-model.mjs +150 -0
  44. package/esm2022/lib/form-field/controls/select/select.component.mjs +522 -0
  45. package/{esm2020 → esm2022}/lib/form-field/controls/select/select.module.mjs +9 -9
  46. package/{esm2020 → esm2022}/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.mjs +4 -4
  47. package/esm2022/lib/form-field/controls/shared/toggle/toggle.component.mjs +96 -0
  48. package/{esm2020 → esm2022}/lib/form-field/controls/shared/toggle/toggle.module.mjs +6 -6
  49. package/{esm2020 → esm2022}/lib/form-field/directives/corner-hint.directive.mjs +4 -4
  50. package/{esm2020 → esm2022}/lib/form-field/directives/error.directive.mjs +4 -4
  51. package/esm2022/lib/form-field/directives/form-root.directive.mjs +91 -0
  52. package/{esm2020 → esm2022}/lib/form-field/directives/hint.directive.mjs +4 -4
  53. package/{esm2020 → esm2022}/lib/form-field/directives/label.directive.mjs +4 -4
  54. package/{esm2020 → esm2022}/lib/form-field/directives/prefix.directive.mjs +4 -4
  55. package/{esm2020 → esm2022}/lib/form-field/directives/suffix.directive.mjs +4 -4
  56. package/{esm2020 → esm2022}/lib/form-field/form-field.component.mjs +11 -11
  57. package/{esm2020 → esm2022}/lib/form-field/impdc-forms.module.mjs +28 -28
  58. package/{esm2020 → esm2022}/lib/form-field/services/error-state-matcher.service.mjs +7 -7
  59. package/{esm2020 → esm2022}/lib/form-field/services/unique-selection-dispatcher.service.mjs +4 -4
  60. package/{esm2020 → esm2022}/lib/form-field/shared/disabled.mixin.mjs +5 -5
  61. package/esm2022/lib/form-field/shared/error-state.mixin.mjs +24 -0
  62. package/{esm2020 → esm2022}/lib/form-field/shared/form-field-control.mjs +4 -4
  63. package/{esm2020 → esm2022}/lib/form-field/shared/tab-index.mixin.mjs +6 -6
  64. package/{esm2020 → esm2022}/lib/icon/icon.component.mjs +5 -5
  65. package/{esm2020 → esm2022}/lib/icon/icon.module.mjs +6 -6
  66. package/esm2022/lib/modal/modal.component.mjs +260 -0
  67. package/{esm2020 → esm2022}/lib/modal/modal.module.mjs +14 -14
  68. package/{esm2020 → esm2022}/lib/modal/types/modal-component-sizes.mjs +1 -1
  69. package/{esm2020 → esm2022}/lib/modal/types/modal-theme.mjs +1 -1
  70. package/esm2022/lib/pagination/pagination.component.mjs +176 -0
  71. package/{esm2020 → esm2022}/lib/pagination/pagination.module.mjs +16 -16
  72. package/{esm2020 → esm2022}/lib/progress-bar/progress-bar.component.mjs +5 -5
  73. package/{esm2020 → esm2022}/lib/progress-bar/progress-bar.module.mjs +5 -5
  74. package/esm2022/lib/scrollable/scrollable.component.mjs +186 -0
  75. package/{esm2020 → esm2022}/lib/scrollable/scrollable.module.mjs +6 -6
  76. package/esm2022/lib/select-icon/select-icon.component.mjs +308 -0
  77. package/{esm2020 → esm2022}/lib/select-icon/select-icon.module.mjs +13 -13
  78. package/{esm2020 → esm2022}/lib/size-detection/directive/size-detector.directive.mjs +5 -5
  79. package/{esm2020 → esm2022}/lib/size-detection/size-detection.module.mjs +5 -5
  80. package/{esm2020 → esm2022}/lib/spinner/spinner.component.mjs +4 -4
  81. package/{esm2020 → esm2022}/lib/spinner/spinner.module.mjs +5 -5
  82. package/{esm2020 → esm2022}/lib/table/components/bulk-actions/bulk-actions.component.mjs +4 -4
  83. package/{esm2020 → esm2022}/lib/table/components/column-heading/column-heading.component.mjs +4 -4
  84. package/{esm2020 → esm2022}/lib/table/components/index.mjs +2 -1
  85. package/esm2022/lib/table/components/row-actions/row-actions.component.mjs +61 -0
  86. package/esm2022/lib/table/containers/table.component.mjs +403 -0
  87. package/esm2022/lib/table/directives/table-inject-component.directive.mjs +46 -0
  88. package/{esm2020 → esm2022}/lib/table/directives/table.directive.mjs +4 -4
  89. package/{esm2020 → esm2022}/lib/table/enumerations/table-column-type.mjs +2 -1
  90. package/{esm2020 → esm2022}/lib/table/helpers/table-theme.helper.mjs +3 -3
  91. package/esm2022/lib/table/interfaces/index.mjs +11 -0
  92. package/esm2022/lib/table/interfaces/table-column-defs.type.mjs +2 -0
  93. package/esm2022/lib/table/interfaces/table-row-action-payload.interface.mjs +2 -0
  94. package/esm2022/lib/table/interfaces/table-row-action.interface.mjs +2 -0
  95. package/esm2022/lib/table/table.module.mjs +96 -0
  96. package/{esm2020 → esm2022}/lib/text-highlight/text-highlight.component.mjs +6 -6
  97. package/{esm2020 → esm2022}/lib/text-highlight/text-highlight.module.mjs +6 -6
  98. package/{esm2020 → esm2022}/services/index.mjs +1 -1
  99. package/esm2022/services/interaction.service.mjs +88 -0
  100. package/{esm2020 → esm2022}/types/component-theme.mjs +1 -1
  101. package/{fesm2020 → fesm2022}/impartner-design-components.mjs +1197 -1032
  102. package/fesm2022/impartner-design-components.mjs.map +1 -0
  103. package/lib/alert/alert.component.d.ts +1 -1
  104. package/lib/alert/theme/alert-theme.d.ts +1 -1
  105. package/lib/avatar/avatar.component.d.ts +1 -1
  106. package/lib/avatar-group/avatar-group.component.d.ts +1 -1
  107. package/lib/backdrop/backdrop.component.d.ts +9 -6
  108. package/lib/badge/badge.component.d.ts +3 -2
  109. package/lib/badge/types/badge-icon.d.ts +1 -1
  110. package/lib/badge/types/badge-size.d.ts +1 -1
  111. package/lib/branding/branded.directive.d.ts +1 -1
  112. package/lib/breadcrumb/breadcrumb-item.component.d.ts +1 -1
  113. package/lib/breadcrumb/breadcrumb.component.d.ts +1 -1
  114. package/lib/button/button.component.d.ts +1 -1
  115. package/lib/button/themes/button-theme.d.ts +1 -1
  116. package/lib/button-group/button-group.component.d.ts +1 -1
  117. package/lib/card-heading/card-heading.component.d.ts +1 -1
  118. package/lib/data-card/data-card.component.d.ts +14 -18
  119. package/lib/data-card/data-card.module.d.ts +2 -1
  120. package/lib/dropdown/components/dropdown-item/dropdown-item.component.d.ts +1 -1
  121. package/lib/dropdown/dropdown.component.d.ts +6 -5
  122. package/lib/dropdown/types/dropdown-position.d.ts +1 -1
  123. package/lib/file-upload/directives/file-drop.directive.d.ts +1 -1
  124. package/lib/file-upload/file-upload.component.d.ts +1 -1
  125. package/lib/form-field/controls/checkbox/checkbox.component.d.ts +1 -1
  126. package/lib/form-field/controls/input/input.directive.d.ts +1 -1
  127. package/lib/form-field/controls/radio/radio-button/radio-button.component.d.ts +1 -1
  128. package/lib/form-field/controls/radio/radio-group/radio-group.directive.d.ts +1 -1
  129. package/lib/form-field/controls/select/option/select-option.component.d.ts +4 -4
  130. package/lib/form-field/controls/select/select.component.d.ts +1 -1
  131. package/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.d.ts +1 -1
  132. package/lib/form-field/controls/shared/toggle/toggle.component.d.ts +1 -1
  133. package/lib/form-field/directives/corner-hint.directive.d.ts +1 -1
  134. package/lib/form-field/directives/error.directive.d.ts +1 -1
  135. package/lib/form-field/directives/form-root.directive.d.ts +2 -2
  136. package/lib/form-field/directives/hint.directive.d.ts +1 -1
  137. package/lib/form-field/directives/label.directive.d.ts +1 -1
  138. package/lib/form-field/directives/prefix.directive.d.ts +1 -1
  139. package/lib/form-field/directives/suffix.directive.d.ts +1 -1
  140. package/lib/form-field/form-field.component.d.ts +1 -1
  141. package/lib/form-field/services/unique-selection-dispatcher.service.d.ts +1 -1
  142. package/lib/form-field/shared/constructors.type.d.ts +2 -2
  143. package/lib/form-field/shared/disabled.mixin.d.ts +1 -1
  144. package/lib/form-field/shared/error-state.mixin.d.ts +1 -1
  145. package/lib/form-field/shared/form-field-control.d.ts +1 -1
  146. package/lib/form-field/shared/tab-index.mixin.d.ts +1 -1
  147. package/lib/icon/icon.component.d.ts +1 -1
  148. package/lib/modal/modal.component.d.ts +17 -10
  149. package/lib/modal/types/modal-component-sizes.d.ts +1 -1
  150. package/lib/modal/types/modal-theme.d.ts +1 -1
  151. package/lib/pagination/pagination.component.d.ts +1 -1
  152. package/lib/progress-bar/progress-bar.component.d.ts +1 -1
  153. package/lib/scrollable/scrollable.component.d.ts +1 -1
  154. package/lib/select-icon/select-icon.component.d.ts +1 -1
  155. package/lib/size-detection/directive/size-detector.directive.d.ts +1 -1
  156. package/lib/spinner/spinner.component.d.ts +1 -1
  157. package/lib/table/components/bulk-actions/bulk-actions.component.d.ts +1 -1
  158. package/lib/table/components/column-heading/column-heading.component.d.ts +1 -1
  159. package/lib/table/components/index.d.ts +1 -0
  160. package/lib/table/components/row-actions/row-actions.component.d.ts +21 -0
  161. package/lib/table/containers/table.component.d.ts +12 -6
  162. package/lib/table/directives/table-inject-component.directive.d.ts +3 -3
  163. package/lib/table/directives/table.directive.d.ts +1 -1
  164. package/lib/table/enumerations/table-column-type.d.ts +2 -1
  165. package/lib/table/helpers/table-theme.helper.d.ts +4 -4
  166. package/lib/table/interfaces/custom-cell-renderer-components.type.d.ts +1 -1
  167. package/lib/table/interfaces/index.d.ts +3 -1
  168. package/lib/table/interfaces/{table-column-def.interface.d.ts → table-column-defs.type.d.ts} +8 -1
  169. package/lib/table/interfaces/table-row-action-payload.interface.d.ts +6 -0
  170. package/lib/table/interfaces/table-row-action.interface.d.ts +9 -0
  171. package/lib/table/interfaces/table-row-item.interface.d.ts +3 -3
  172. package/lib/table/table.module.d.ts +12 -10
  173. package/lib/text-highlight/text-highlight.component.d.ts +1 -1
  174. package/package.json +16 -22
  175. package/services/index.d.ts +1 -1
  176. package/services/interaction.service.d.ts +20 -10
  177. package/types/component-size.d.ts +2 -2
  178. package/types/component-theme.d.ts +1 -1
  179. package/utilities/boolean-props.d.ts +1 -1
  180. package/utilities/number-props.d.ts +1 -1
  181. package/esm2020/lib/backdrop/backdrop.component.mjs +0 -40
  182. package/esm2020/lib/badge/badge.component.mjs +0 -99
  183. package/esm2020/lib/data-card/data-card.component.mjs +0 -128
  184. package/esm2020/lib/data-card/data-card.module.mjs +0 -20
  185. package/esm2020/lib/dropdown/dropdown.component.mjs +0 -142
  186. package/esm2020/lib/form-field/controls/input/input.directive.mjs +0 -233
  187. package/esm2020/lib/form-field/controls/radio/radio-button/radio-button.component.mjs +0 -260
  188. package/esm2020/lib/form-field/controls/radio/radio-group/radio-group.directive.mjs +0 -289
  189. package/esm2020/lib/form-field/controls/select/option/select-option.component.mjs +0 -139
  190. package/esm2020/lib/form-field/controls/select/select-model.mjs +0 -150
  191. package/esm2020/lib/form-field/controls/select/select.component.mjs +0 -522
  192. package/esm2020/lib/form-field/controls/shared/toggle/toggle.component.mjs +0 -96
  193. package/esm2020/lib/form-field/directives/form-root.directive.mjs +0 -91
  194. package/esm2020/lib/form-field/shared/error-state.mixin.mjs +0 -24
  195. package/esm2020/lib/modal/modal.component.mjs +0 -187
  196. package/esm2020/lib/pagination/pagination.component.mjs +0 -176
  197. package/esm2020/lib/scrollable/scrollable.component.mjs +0 -186
  198. package/esm2020/lib/select-icon/select-icon.component.mjs +0 -308
  199. package/esm2020/lib/table/containers/table.component.mjs +0 -386
  200. package/esm2020/lib/table/directives/table-inject-component.directive.mjs +0 -46
  201. package/esm2020/lib/table/interfaces/index.mjs +0 -9
  202. package/esm2020/lib/table/interfaces/table-column-def.interface.mjs +0 -2
  203. package/esm2020/lib/table/table.module.mjs +0 -88
  204. package/esm2020/services/interaction.service.mjs +0 -81
  205. package/fesm2015/impartner-design-components.mjs +0 -9214
  206. package/fesm2015/impartner-design-components.mjs.map +0 -1
  207. package/fesm2020/impartner-design-components.mjs.map +0 -1
  208. /package/{esm2020 → esm2022}/constants/index.mjs +0 -0
  209. /package/{esm2020 → esm2022}/impartner-design-components.mjs +0 -0
  210. /package/{esm2020 → esm2022}/lib/alert/index.mjs +0 -0
  211. /package/{esm2020 → esm2022}/lib/alert/theme/alert-theme.mjs +0 -0
  212. /package/{esm2020 → esm2022}/lib/alert/theme/index.mjs +0 -0
  213. /package/{esm2020 → esm2022}/lib/avatar/index.mjs +0 -0
  214. /package/{esm2020 → esm2022}/lib/avatar-group/index.mjs +0 -0
  215. /package/{esm2020 → esm2022}/lib/backdrop/index.mjs +0 -0
  216. /package/{esm2020 → esm2022}/lib/badge/index.mjs +0 -0
  217. /package/{esm2020 → esm2022}/lib/badge/types/badge-icon.mjs +0 -0
  218. /package/{esm2020 → esm2022}/lib/badge/types/index.mjs +0 -0
  219. /package/{esm2020 → esm2022}/lib/branding/index.mjs +0 -0
  220. /package/{esm2020 → esm2022}/lib/breadcrumb/index.mjs +0 -0
  221. /package/{esm2020 → esm2022}/lib/button/index.mjs +0 -0
  222. /package/{esm2020 → esm2022}/lib/button/themes/button-theme.mjs +0 -0
  223. /package/{esm2020 → esm2022}/lib/button/themes/index.mjs +0 -0
  224. /package/{esm2020 → esm2022}/lib/button-group/index.mjs +0 -0
  225. /package/{esm2020 → esm2022}/lib/card-heading/index.mjs +0 -0
  226. /package/{esm2020 → esm2022}/lib/data-card/index.mjs +0 -0
  227. /package/{esm2020 → esm2022}/lib/dropdown/components/index.mjs +0 -0
  228. /package/{esm2020 → esm2022}/lib/dropdown/index.mjs +0 -0
  229. /package/{esm2020 → esm2022}/lib/dropdown/types/dropdown-position.mjs +0 -0
  230. /package/{esm2020 → esm2022}/lib/dropdown/types/index.mjs +0 -0
  231. /package/{esm2020 → esm2022}/lib/file-upload/directives/index.mjs +0 -0
  232. /package/{esm2020 → esm2022}/lib/file-upload/index.mjs +0 -0
  233. /package/{esm2020 → esm2022}/lib/file-upload/pipes/index.mjs +0 -0
  234. /package/{esm2020 → esm2022}/lib/form-field/controls/checkbox/index.mjs +0 -0
  235. /package/{esm2020 → esm2022}/lib/form-field/controls/index.mjs +0 -0
  236. /package/{esm2020 → esm2022}/lib/form-field/controls/input/index.mjs +0 -0
  237. /package/{esm2020 → esm2022}/lib/form-field/controls/radio/index.mjs +0 -0
  238. /package/{esm2020 → esm2022}/lib/form-field/controls/radio/injection-tokens.mjs +0 -0
  239. /package/{esm2020 → esm2022}/lib/form-field/controls/radio/interfaces/index.mjs +0 -0
  240. /package/{esm2020 → esm2022}/lib/form-field/controls/radio/interfaces/radio-button.interface.mjs +0 -0
  241. /package/{esm2020 → esm2022}/lib/form-field/controls/radio/interfaces/radio-change-event.interface.mjs +0 -0
  242. /package/{esm2020 → esm2022}/lib/form-field/controls/radio/interfaces/radio-group.interface.mjs +0 -0
  243. /package/{esm2020 → esm2022}/lib/form-field/controls/select/index.mjs +0 -0
  244. /package/{esm2020 → esm2022}/lib/form-field/controls/select/option/index.mjs +0 -0
  245. /package/{esm2020 → esm2022}/lib/form-field/controls/select/option-parent.mjs +0 -0
  246. /package/{esm2020 → esm2022}/lib/form-field/controls/shared/index.mjs +0 -0
  247. /package/{esm2020 → esm2022}/lib/form-field/controls/shared/toggle/components/index.mjs +0 -0
  248. /package/{esm2020 → esm2022}/lib/form-field/controls/shared/toggle/index.mjs +0 -0
  249. /package/{esm2020 → esm2022}/lib/form-field/directives/index.mjs +0 -0
  250. /package/{esm2020 → esm2022}/lib/form-field/form-field-errors.mjs +0 -0
  251. /package/{esm2020 → esm2022}/lib/form-field/impdc-forms.mjs +0 -0
  252. /package/{esm2020 → esm2022}/lib/form-field/index.mjs +0 -0
  253. /package/{esm2020 → esm2022}/lib/form-field/services/index.mjs +0 -0
  254. /package/{esm2020 → esm2022}/lib/form-field/shared/constructors.type.mjs +0 -0
  255. /package/{esm2020 → esm2022}/lib/form-field/shared/index.mjs +0 -0
  256. /package/{esm2020 → esm2022}/lib/icon/index.mjs +0 -0
  257. /package/{esm2020 → esm2022}/lib/index.mjs +0 -0
  258. /package/{esm2020 → esm2022}/lib/modal/index.mjs +0 -0
  259. /package/{esm2020 → esm2022}/lib/modal/types/index.mjs +0 -0
  260. /package/{esm2020 → esm2022}/lib/pagination/index.mjs +0 -0
  261. /package/{esm2020 → esm2022}/lib/progress-bar/index.mjs +0 -0
  262. /package/{esm2020 → esm2022}/lib/scrollable/index.mjs +0 -0
  263. /package/{esm2020 → esm2022}/lib/select-icon/index.mjs +0 -0
  264. /package/{esm2020 → esm2022}/lib/size-detection/directive/element-size.interface.mjs +0 -0
  265. /package/{esm2020 → esm2022}/lib/size-detection/directive/index.mjs +0 -0
  266. /package/{esm2020 → esm2022}/lib/size-detection/index.mjs +0 -0
  267. /package/{esm2020 → esm2022}/lib/spinner/index.mjs +0 -0
  268. /package/{esm2020 → esm2022}/lib/table/constants/index.mjs +0 -0
  269. /package/{esm2020 → esm2022}/lib/table/constants/public-table.constants.mjs +0 -0
  270. /package/{esm2020 → esm2022}/lib/table/constants/table.constants.mjs +0 -0
  271. /package/{esm2020 → esm2022}/lib/table/containers/index.mjs +0 -0
  272. /package/{esm2020 → esm2022}/lib/table/directives/index.mjs +0 -0
  273. /package/{esm2020 → esm2022}/lib/table/enumerations/index.mjs +0 -0
  274. /package/{esm2020 → esm2022}/lib/table/helpers/index.mjs +0 -0
  275. /package/{esm2020 → esm2022}/lib/table/index.mjs +0 -0
  276. /package/{esm2020 → esm2022}/lib/table/interfaces/cell-renderer.interface.mjs +0 -0
  277. /package/{esm2020 → esm2022}/lib/table/interfaces/custom-cell-renderer-components.type.mjs +0 -0
  278. /package/{esm2020 → esm2022}/lib/table/interfaces/sort-by-payload.interface.mjs +0 -0
  279. /package/{esm2020 → esm2022}/lib/table/interfaces/table-cell-option.interface.mjs +0 -0
  280. /package/{esm2020 → esm2022}/lib/table/interfaces/table-event-payload.interface.mjs +0 -0
  281. /package/{esm2020 → esm2022}/lib/table/interfaces/table-row-item.interface.mjs +0 -0
  282. /package/{esm2020 → esm2022}/lib/text-highlight/index.mjs +0 -0
  283. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
  284. /package/{esm2020 → esm2022}/types/component-size.mjs +0 -0
  285. /package/{esm2020 → esm2022}/types/index.mjs +0 -0
  286. /package/{esm2020 → esm2022}/utilities/boolean-props.mjs +0 -0
  287. /package/{esm2020 → esm2022}/utilities/dc.mjs +0 -0
  288. /package/{esm2020 → esm2022}/utilities/index.mjs +0 -0
  289. /package/{esm2020 → esm2022}/utilities/lc.mjs +0 -0
  290. /package/{esm2020 → esm2022}/utilities/number-props.mjs +0 -0
  291. /package/{esm2020 → esm2022}/utilities/sanitize.mjs +0 -0
@@ -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
+ /**
16
+ * Whether or not the radio input is checked/selected.
17
+ */
18
+ get checked() {
19
+ return this._checked;
20
+ }
21
+ set checked(value) {
22
+ const newCheckedValue = coerceBooleanPropertyValue(value);
23
+ if (this._checked !== newCheckedValue) {
24
+ this._checked = newCheckedValue;
25
+ if (newCheckedValue &&
26
+ this._radioGroup &&
27
+ this._radioGroup.value !== this.value) {
28
+ this._radioGroup.selected = this;
29
+ }
30
+ else if (!newCheckedValue &&
31
+ this._radioGroup &&
32
+ this._radioGroup.value === this.value) {
33
+ this._radioGroup.selected = null;
34
+ }
35
+ if (newCheckedValue) {
36
+ this._radioDispatcher.notify(this.id, this.name);
37
+ }
38
+ this._changeDetector.markForCheck();
39
+ }
40
+ }
41
+ /**
42
+ * The specific value represented by the radio button.
43
+ */
44
+ get value() {
45
+ return this._value;
46
+ }
47
+ set value(value) {
48
+ if (this._value !== value) {
49
+ this._value = value;
50
+ if (this._radioGroup) {
51
+ if (!this.checked) {
52
+ this.checked = this._radioGroup.value === value;
53
+ }
54
+ if (this.checked) {
55
+ this._radioGroup.selected = this;
56
+ }
57
+ }
58
+ }
59
+ }
60
+ /**
61
+ * Whether or not the radio button displays inline; Inherited from the parent `RadioGroupDirective` when available.
62
+ */
63
+ get inline() {
64
+ return (this._inline || (this._radioGroup && this._radioGroup.inline) || false);
65
+ }
66
+ set inline(value) {
67
+ this._inline = coerceBooleanPropertyValue(value);
68
+ }
69
+ /**
70
+ * Used to enable or disable the radio button, but will always return `true` when the parent
71
+ * `RadioGroupDirective` is already disabled.
72
+ */
73
+ get disabled() {
74
+ return (this._disabled || (this._radioGroup != null && this._radioGroup.disabled));
75
+ }
76
+ set disabled(value) {
77
+ const newDisabledState = coerceBooleanPropertyValue(value);
78
+ if (this._disabled !== newDisabledState) {
79
+ this._disabled = newDisabledState;
80
+ this._changeDetector.markForCheck();
81
+ }
82
+ }
83
+ /** @ignore */
84
+ get required() {
85
+ return (this._required || (this._radioGroup != null && this._radioGroup.required));
86
+ }
87
+ set required(value) {
88
+ this._required = coerceBooleanPropertyValue(value);
89
+ }
90
+ get _errorState() {
91
+ return this._radioGroup ? this._radioGroup.errorState : false;
92
+ }
93
+ constructor(_changeDetector, _radioDispatcher, tabIndex, _radioGroup) {
94
+ super();
95
+ this._changeDetector = _changeDetector;
96
+ this._radioDispatcher = _radioDispatcher;
97
+ this._radioGroup = _radioGroup;
98
+ this._uid = `impdc-radio-button-${nanoid()}`;
99
+ this._removeUniqueSelectionListener = () => { };
100
+ this.id = this._uid;
101
+ this._checked = false;
102
+ this._value = null;
103
+ this._disabled = false;
104
+ this._required = false;
105
+ /**
106
+ * The primary label text for the radio button.
107
+ */
108
+ this.label = '';
109
+ /**
110
+ * Text to provide additional description or context for the radio button. Does
111
+ * not display if `inline` is `true`.
112
+ */
113
+ this.description = '';
114
+ /**
115
+ * Event emitted when the radio button becomes selected/checked.
116
+ */
117
+ this.change = new EventEmitter();
118
+ if (tabIndex) {
119
+ this.tabIndex = coerceNumberPropertyValue(tabIndex, 0);
120
+ }
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
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", 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 }); }
193
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.1", 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: [
194
+ {
195
+ provide: IMPDC_RADIO_BUTTON,
196
+ useExisting: RadioButtonComponent
197
+ }
198
+ ], 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 }); }
199
+ }
200
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", 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: () => [{ 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":"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","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 = 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 = 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 = false;\n\n  /**\n   * The primary label text for the radio button.\n   */\n  @Input()\n  public label = '';\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 = '';\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"]}
@@ -0,0 +1,289 @@
1
+ import { ContentChildren, Directive, EventEmitter, Inject, Input, Optional, Output, Self } from '@angular/core';
2
+ import { Validators } from '@angular/forms';
3
+ import { nanoid } from 'nanoid';
4
+ import { coerceBooleanPropertyValue } from '../../../../../utilities';
5
+ import { Subject } from 'rxjs';
6
+ import { IMPDC_FORM_ROOT } from '../../../directives';
7
+ import { ImpdcFormFieldControl, mixinErrorState } from '../../../shared';
8
+ import { IMPDC_RADIO_BUTTON, IMPDC_RADIO_GROUP } from '../injection-tokens';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../../../services";
11
+ import * as i2 from "@angular/forms";
12
+ const _RadioGroupDirectiveBase = mixinErrorState(class {
13
+ constructor(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl) {
14
+ this._defaultErrorStateMatcher = _defaultErrorStateMatcher;
15
+ this._formRoot = _formRoot;
16
+ this._parentForm = _parentForm;
17
+ this._parentFormGroup = _parentFormGroup;
18
+ this.ngControl = ngControl;
19
+ this.stateChanges = new Subject();
20
+ }
21
+ });
22
+ /**
23
+ * The `RadioGroupDirective` (`<impdc-radio-group`) is a container for `RadioButtonComponent` (`<impdc-radio-button`).
24
+ * This directive/component can be used within a `FormFieldComponent` (`<impdc-form-field`).
25
+ * To use, import `RadioModule` or another module that imports and exports that module from `@impartner/design-components`.
26
+ */
27
+ export class RadioGroupDirective extends _RadioGroupDirectiveBase {
28
+ /**
29
+ * The unique name for the group of radio options; Autogenerated by default.
30
+ */
31
+ get name() {
32
+ return this._name;
33
+ }
34
+ set name(value) {
35
+ this._name = value || this._uid;
36
+ this._updateRadioOptionNames();
37
+ }
38
+ /**
39
+ * Whether or not the nested radio options should display inline.
40
+ */
41
+ get inline() {
42
+ return this._inline;
43
+ }
44
+ set inline(value) {
45
+ this._inline = coerceBooleanPropertyValue(value);
46
+ this._markRadioOptionsForCheck();
47
+ }
48
+ /**
49
+ * A reference to the currently selected radio button component (eg. `<impdc-radio-button>`).
50
+ */
51
+ get selected() {
52
+ return this._selected;
53
+ }
54
+ set selected(selected) {
55
+ this._selected = selected;
56
+ this.value = selected ? selected.value : null;
57
+ this._checkSelectedRadioOption();
58
+ }
59
+ constructor(_changeDetector, _defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl) {
60
+ super(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl);
61
+ this._changeDetector = _changeDetector;
62
+ this._uid = `impdc-radio-group-${nanoid()}`;
63
+ this._initialized = false;
64
+ this._cvaOnChange = () => { };
65
+ this._cvaOnTouched = () => { };
66
+ this._name = this._uid;
67
+ this._inline = false;
68
+ this._selected = null;
69
+ /**
70
+ * Event emitted whenever a new radio option is selected.
71
+ */
72
+ this.change = new EventEmitter();
73
+ this._focused = false;
74
+ this._disabled = false;
75
+ this.controlType = 'impdc-radio-group';
76
+ this.supportsAffixes = false;
77
+ if (this.ngControl) {
78
+ this.ngControl.valueAccessor = this;
79
+ }
80
+ }
81
+ /** @ignore */
82
+ ngAfterContentInit() {
83
+ this._initialized = true;
84
+ }
85
+ /** @ignore */
86
+ ngDoCheck() {
87
+ const ngControl = this.ngControl;
88
+ if (!ngControl) {
89
+ return;
90
+ }
91
+ if (this._previousControl !== ngControl.control) {
92
+ if (this._previousControl !== undefined &&
93
+ ngControl.disabled !== null &&
94
+ ngControl.disabled !== this.disabled) {
95
+ this.disabled = ngControl?.disabled;
96
+ }
97
+ this._previousControl = ngControl.control;
98
+ }
99
+ this.updateErrorState();
100
+ this._markRadioOptionsForCheck();
101
+ }
102
+ /** @ignore */
103
+ ngOnDestroy() {
104
+ this.stateChanges.complete();
105
+ }
106
+ /* ImpdcFormFieldControl */
107
+ get value() {
108
+ return this._value;
109
+ }
110
+ set value(value) {
111
+ if (this._value !== value) {
112
+ this._value = value;
113
+ this._updateSelectedRadioOptionFromValue();
114
+ this._checkSelectedRadioOption();
115
+ this.stateChanges.next();
116
+ }
117
+ }
118
+ get id() {
119
+ return this._id;
120
+ }
121
+ set id(value) {
122
+ this._id = value || this._uid;
123
+ this.stateChanges.next();
124
+ }
125
+ get focused() {
126
+ return this._focused;
127
+ }
128
+ get disabled() {
129
+ return this._disabled;
130
+ }
131
+ set disabled(value) {
132
+ this._disabled = coerceBooleanPropertyValue(value);
133
+ this._markRadioOptionsForCheck();
134
+ this.stateChanges.next();
135
+ }
136
+ /**
137
+ * Used to set requiredness of control in a template-based manner;
138
+ * not necessary when using the Angular reactive forms API and `required` validator.
139
+ */
140
+ get required() {
141
+ return (this._required ??
142
+ this.ngControl?.control?.hasValidator(Validators.required) ??
143
+ false);
144
+ }
145
+ set required(value) {
146
+ this._required = coerceBooleanPropertyValue(value);
147
+ this.stateChanges.next();
148
+ }
149
+ /* ControlValueAccessor */
150
+ /** @ignore */
151
+ writeValue(value) {
152
+ this.value = value;
153
+ this._changeDetector.markForCheck();
154
+ }
155
+ /** @ignore */
156
+ registerOnChange(fn) {
157
+ this._cvaOnChange = fn;
158
+ }
159
+ /** @ignore */
160
+ registerOnTouched(fn) {
161
+ this._cvaOnTouched = fn;
162
+ }
163
+ /** @ignore */
164
+ setDisabledState(isDisabled) {
165
+ this.disabled = isDisabled;
166
+ this._changeDetector.markForCheck();
167
+ }
168
+ /* Internals */
169
+ /** @ignore */
170
+ emitChangesEvent() {
171
+ if (this._initialized) {
172
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
173
+ this.change.emit({ source: this._selected, value: this._value });
174
+ }
175
+ }
176
+ /** @ignore */
177
+ onChangeFn(value) {
178
+ this._cvaOnChange(value);
179
+ }
180
+ /** @ignore */
181
+ touch() {
182
+ if (this._cvaOnTouched) {
183
+ this._cvaOnTouched();
184
+ }
185
+ }
186
+ _checkSelectedRadioOption() {
187
+ if (this._selected && !this._selected.checked) {
188
+ this._selected.checked = true;
189
+ }
190
+ }
191
+ _markRadioOptionsForCheck() {
192
+ if (this._radioOptions) {
193
+ this._radioOptions.forEach(option => option.markForCheck());
194
+ }
195
+ }
196
+ _updateRadioOptionNames() {
197
+ if (this._radioOptions) {
198
+ this._radioOptions.forEach(option => {
199
+ option.name = this.name;
200
+ option.markForCheck();
201
+ });
202
+ }
203
+ }
204
+ _updateSelectedRadioOptionFromValue() {
205
+ const isAlreadySelected = this._selected !== null && this._selected.value === this._value;
206
+ if (this._radioOptions && !isAlreadySelected) {
207
+ this._selected = null;
208
+ this._radioOptions.forEach(option => {
209
+ option.checked = this.value === option.value;
210
+ if (option.checked) {
211
+ this._selected = option;
212
+ }
213
+ });
214
+ }
215
+ }
216
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: RadioGroupDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.ErrorStateMatcher }, { token: IMPDC_FORM_ROOT, optional: true }, { token: i2.NgForm, optional: true }, { token: i2.FormGroupDirective, optional: true }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Directive }); }
217
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.1", type: RadioGroupDirective, selector: "impdc-radio-group", inputs: { name: "name", inline: "inline", selected: "selected", errorStateMatcher: "errorStateMatcher", value: "value", id: "id", disabled: "disabled", required: "required" }, outputs: { change: "change" }, host: { attributes: { "role": "radiogroup" }, properties: { "class.impdc-radio-group--required": "required", "class.impdc-radio-group--disabled": "disabled", "class.impdc-radio-group--invalid": "errorState", "class.impdc-radio-group--inline": "inline" }, classAttribute: "impdc-radio-group" }, providers: [
218
+ {
219
+ provide: ImpdcFormFieldControl,
220
+ useExisting: RadioGroupDirective
221
+ },
222
+ {
223
+ provide: IMPDC_RADIO_GROUP,
224
+ useExisting: RadioGroupDirective
225
+ }
226
+ ], queries: [{ propertyName: "_radioOptions", predicate: IMPDC_RADIO_BUTTON, descendants: true }], exportAs: ["impdcRadioGroup"], usesInheritance: true, ngImport: i0 }); }
227
+ }
228
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: RadioGroupDirective, decorators: [{
229
+ type: Directive,
230
+ args: [{
231
+ // eslint-disable-next-line @angular-eslint/directive-selector
232
+ selector: 'impdc-radio-group',
233
+ exportAs: 'impdcRadioGroup',
234
+ providers: [
235
+ {
236
+ provide: ImpdcFormFieldControl,
237
+ useExisting: RadioGroupDirective
238
+ },
239
+ {
240
+ provide: IMPDC_RADIO_GROUP,
241
+ useExisting: RadioGroupDirective
242
+ }
243
+ ],
244
+ // eslint-disable-next-line @angular-eslint/no-host-metadata-property
245
+ host: {
246
+ role: 'radiogroup',
247
+ class: 'impdc-radio-group',
248
+ '[class.impdc-radio-group--required]': 'required',
249
+ '[class.impdc-radio-group--disabled]': 'disabled',
250
+ '[class.impdc-radio-group--invalid]': 'errorState',
251
+ '[class.impdc-radio-group--inline]': 'inline'
252
+ }
253
+ }]
254
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.ErrorStateMatcher }, { type: undefined, decorators: [{
255
+ type: Optional
256
+ }, {
257
+ type: Inject,
258
+ args: [IMPDC_FORM_ROOT]
259
+ }] }, { type: i2.NgForm, decorators: [{
260
+ type: Optional
261
+ }] }, { type: i2.FormGroupDirective, decorators: [{
262
+ type: Optional
263
+ }] }, { type: i2.NgControl, decorators: [{
264
+ type: Self
265
+ }, {
266
+ type: Optional
267
+ }] }], propDecorators: { _radioOptions: [{
268
+ type: ContentChildren,
269
+ args: [IMPDC_RADIO_BUTTON, { descendants: true }]
270
+ }], name: [{
271
+ type: Input
272
+ }], inline: [{
273
+ type: Input
274
+ }], selected: [{
275
+ type: Input
276
+ }], errorStateMatcher: [{
277
+ type: Input
278
+ }], change: [{
279
+ type: Output
280
+ }], value: [{
281
+ type: Input
282
+ }], id: [{
283
+ type: Input
284
+ }], disabled: [{
285
+ type: Input
286
+ }], required: [{
287
+ type: Input
288
+ }] } });
289
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.directive.js","sourceRoot":"","sources":["../../../../../../../../../projects/design-components/src/lib/form-field/controls/radio/radio-group/radio-group.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,eAAe,EACf,SAAS,EAET,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,QAAQ,EACR,MAAM,EAEN,IAAI,EACL,MAAM,eAAe,CAAC;AACvB,OAAO,EAML,UAAU,EACX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EAEL,0BAA0B,EAC3B,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAiB,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAErE,OAAO,EAEL,qBAAqB,EACrB,eAAe,EAChB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;;;;AAG5E,MAAM,wBAAwB,GAAG,eAAe,CAC9C;IAGE,YACS,yBAA4C,EAC5C,SAAwB,EACxB,WAAmB,EACnB,gBAAoC,EACpC,SAA2B;QAJ3B,8BAAyB,GAAzB,yBAAyB,CAAmB;QAC5C,cAAS,GAAT,SAAS,CAAe;QACxB,gBAAW,GAAX,WAAW,CAAQ;QACnB,qBAAgB,GAAhB,gBAAgB,CAAoB;QACpC,cAAS,GAAT,SAAS,CAAkB;QAPpB,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;IAQhD,CAAC;CACL,CACF,CAAC;AAEF;;;;GAIG;AAyBH,MAAM,OAAO,mBAGX,SAAQ,wBAAwB;IAoBhC;;OAEG;IACH,IACW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IACD,IAAW,IAAI,CAAC,KAAa;QAC3B,IAAI,CAAC,KAAK,GAAG,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC;QAChC,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAGD;;OAEG;IACH,IACW,MAAM;QACf,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IACD,IAAW,MAAM,CAAC,KAAmB;QACnC,IAAI,CAAC,OAAO,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;QACjD,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACnC,CAAC;IAGD;;OAEG;IACH,IACW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAW,QAAQ,CAAC,QAA6B;QAC/C,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;QAC9C,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACnC,CAAC;IAcD,YACmB,eAAkC,EACnD,yBAA4C,EACP,SAAwB,EACjD,WAAmB,EACnB,gBAAoC,EAC5B,SAA2B;QAE/C,KAAK,CACH,yBAAyB,EACzB,SAAS,EACT,WAAW,EACX,gBAAgB,EAChB,SAAS,CACV,CAAC;QAbe,oBAAe,GAAf,eAAe,CAAmB;QA3DlC,SAAI,GAAG,qBAAqB,MAAM,EAAE,EAAE,CAAC;QAChD,iBAAY,GAAG,KAAK,CAAC;QAGvB,iBAAY,GAAyB,GAAG,EAAE,GAAE,CAAC,CAAC;QAC9C,kBAAa,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QAavB,UAAK,GAAW,IAAI,CAAC,IAAI,CAAC;QAa1B,YAAO,GAAG,KAAK,CAAC;QAchB,cAAS,GAAwB,IAAI,CAAC;QAKhD;;WAEG;QAGa,WAAM,GACpB,IAAI,YAAY,EAAoB,CAAC;QAsF7B,aAAQ,GAAG,KAAK,CAAC;QAWjB,cAAS,GAAG,KAAK,CAAC;QAoBZ,gBAAW,GAAG,mBAAmB,CAAC;QAElC,oBAAe,GAAY,KAAK,CAAC;QArG/C,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,IAAI,CAAC;SACrC;IACH,CAAC;IAED,cAAc;IACP,kBAAkB;QACvB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IAED,cAAc;IACP,SAAS;QACd,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QAEjC,IAAI,CAAC,SAAS,EAAE;YACd,OAAO;SACR;QAED,IAAI,IAAI,CAAC,gBAAgB,KAAK,SAAS,CAAC,OAAO,EAAE;YAC/C,IACE,IAAI,CAAC,gBAAgB,KAAK,SAAS;gBACnC,SAAS,CAAC,QAAQ,KAAK,IAAI;gBAC3B,SAAS,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,EACpC;gBACA,IAAI,CAAC,QAAQ,GAAG,SAAS,EAAE,QAAQ,CAAC;aACrC;YAED,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAC,OAAO,CAAC;SAC3C;QAED,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACnC,CAAC;IAED,cAAc;IACP,WAAW;QAChB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED,2BAA2B;IAC3B,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,CAAC,mCAAmC,EAAE,CAAC;YAC3C,IAAI,CAAC,yBAAyB,EAAE,CAAC;YACjC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;SAC1B;IACH,CAAC;IAGD,IACW,EAAE;QACX,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IACD,IAAW,EAAE,CAAC,KAAa;QACzB,IAAI,CAAC,GAAG,GAAG,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC;QAC9B,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAGD,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAGD,IACW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAW,QAAQ,CAAC,KAAmB;QACrC,IAAI,CAAC,SAAS,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;QACnD,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACjC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAGD;;;OAGG;IACH,IACW,QAAQ;QACjB,OAAO,CACL,IAAI,CAAC,SAAS;YACd,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,YAAY,CAAC,UAAU,CAAC,QAAQ,CAAC;YAC1D,KAAK,CACN,CAAC;IACJ,CAAC;IACD,IAAW,QAAQ,CAAC,KAAmB;QACrC,IAAI,CAAC,SAAS,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;QACnD,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAOD,0BAA0B;IAC1B,cAAc;IACd,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;IACtC,CAAC;IAED,cAAc;IACd,gBAAgB,CAAC,EAAwB;QACvC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IACzB,CAAC;IAED,cAAc;IACd,iBAAiB,CAAC,EAAY;QAC5B,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC1B,CAAC;IAED,cAAc;IACd,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;IACtC,CAAC;IAED,eAAe;IAEf,cAAc;IACP,gBAAgB;QACrB,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,oEAAoE;YACpE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,SAAU,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;SACnE;IACH,CAAC;IAED,cAAc;IACP,UAAU,CAAC,KAAU;QAC1B,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED,cAAc;IACP,KAAK;QACV,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;IACH,CAAC;IAES,yBAAyB;QACjC,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE;YAC7C,IAAI,CAAC,SAAS,CAAC,OAAO,GAAG,IAAI,CAAC;SAC/B;IACH,CAAC;IAES,yBAAyB;QACjC,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;SAC7D;IACH,CAAC;IAES,uBAAuB;QAC/B,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBAClC,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;gBACxB,MAAM,CAAC,YAAY,EAAE,CAAC;YACxB,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAES,mCAAmC;QAC3C,MAAM,iBAAiB,GACrB,IAAI,CAAC,SAAS,KAAK,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,CAAC;QAElE,IAAI,IAAI,CAAC,aAAa,IAAI,CAAC,iBAAiB,EAAE;YAC5C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBAClC,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,KAAK,MAAM,CAAC,KAAK,CAAC;gBAE7C,IAAI,MAAM,CAAC,OAAO,EAAE;oBAClB,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;iBACzB;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;8GAjRU,mBAAmB,oFA6ER,eAAe;kGA7E1B,mBAAmB,iiBApBnB;YACT;gBACE,OAAO,EAAE,qBAAqB;gBAC9B,WAAW,EAAE,mBAAmB;aACjC;YACD;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,mBAAmB;aACjC;SACF,wDAwBgB,kBAAkB;;2FAbxB,mBAAmB;kBAxB/B,SAAS;mBAAC;oBACT,8DAA8D;oBAC9D,QAAQ,EAAE,mBAAmB;oBAC7B,QAAQ,EAAE,iBAAiB;oBAC3B,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,qBAAqB;4BAC9B,WAAW,qBAAqB;yBACjC;wBACD;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,qBAAqB;yBACjC;qBACF;oBACD,qEAAqE;oBACrE,IAAI,EAAE;wBACJ,IAAI,EAAE,YAAY;wBAClB,KAAK,EAAE,mBAAmB;wBAC1B,qCAAqC,EAAE,UAAU;wBACjD,qCAAqC,EAAE,UAAU;wBACjD,oCAAoC,EAAE,YAAY;wBAClD,mCAAmC,EAAE,QAAQ;qBAC9C;iBACF;;0BA8EI,QAAQ;;0BAAI,MAAM;2BAAC,eAAe;;0BAClC,QAAQ;;0BACR,QAAQ;;0BACR,IAAI;;0BAAI,QAAQ;yCAlET,aAAa;sBADtB,eAAe;uBAAC,kBAAkB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAc/C,IAAI;sBADd,KAAK;gBAcK,MAAM;sBADhB,KAAK;gBAcK,QAAQ;sBADlB,KAAK;gBAYU,iBAAiB;sBADhC,KAAK;gBAQU,MAAM;sBAFrB,MAAM;gBA8DI,KAAK;sBADf,KAAK;gBAgBK,EAAE;sBADZ,KAAK;gBAgBK,QAAQ;sBADlB,KAAK;gBAgBK,QAAQ;sBADlB,KAAK","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  ContentChildren,\n  Directive,\n  DoCheck,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  QueryList,\n  Self\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormGroupDirective,\n  NgControl,\n  NgForm,\n  Validators\n} from '@angular/forms';\nimport { nanoid } from 'nanoid';\nimport {\n  BooleanInput,\n  coerceBooleanPropertyValue\n} from '../../../../../utilities';\nimport { Subject } from 'rxjs';\nimport { ImpdcFormRoot, IMPDC_FORM_ROOT } from '../../../directives';\nimport { ErrorStateMatcher } from '../../../services';\nimport {\n  IHasErrorState,\n  ImpdcFormFieldControl,\n  mixinErrorState\n} from '../../../shared';\nimport { IMPDC_RADIO_BUTTON, IMPDC_RADIO_GROUP } from '../injection-tokens';\nimport { RadioChangeEvent, IRadioButton, IRadioGroup } from '../interfaces';\n\nconst _RadioGroupDirectiveBase = 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 `RadioGroupDirective` (`<impdc-radio-group`) is a container for `RadioButtonComponent` (`<impdc-radio-button`).\n * This directive/component can be used within a `FormFieldComponent` (`<impdc-form-field`).\n * To use, import `RadioModule` or another module that imports and exports that module from `@impartner/design-components`.\n */\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: 'impdc-radio-group',\n  exportAs: 'impdcRadioGroup',\n  providers: [\n    {\n      provide: ImpdcFormFieldControl,\n      useExisting: RadioGroupDirective\n    },\n    {\n      provide: IMPDC_RADIO_GROUP,\n      useExisting: RadioGroupDirective\n    }\n  ],\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    role: 'radiogroup',\n    class: 'impdc-radio-group',\n    '[class.impdc-radio-group--required]': 'required',\n    '[class.impdc-radio-group--disabled]': 'disabled',\n    '[class.impdc-radio-group--invalid]': 'errorState',\n    '[class.impdc-radio-group--inline]': 'inline'\n  }\n})\nexport class RadioGroupDirective<\n    TRadioButton extends IRadioButton = IRadioButton\n  >\n  extends _RadioGroupDirectiveBase\n  implements\n    IRadioGroup,\n    ControlValueAccessor,\n    ImpdcFormFieldControl<any>,\n    AfterContentInit,\n    DoCheck,\n    OnDestroy,\n    IHasErrorState\n{\n  @ContentChildren(IMPDC_RADIO_BUTTON, { descendants: true })\n  protected _radioOptions!: QueryList<TRadioButton>;\n\n  protected readonly _uid = `impdc-radio-group-${nanoid()}`;\n  protected _initialized = false;\n\n  private _previousControl?: AbstractControl | null;\n  private _cvaOnChange: (value: any) => void = () => {};\n  private _cvaOnTouched = () => {};\n\n  /**\n   * The unique name for the group of radio options; Autogenerated by default.\n   */\n  @Input()\n  public get name(): string {\n    return this._name;\n  }\n  public set name(value: string) {\n    this._name = value || this._uid;\n    this._updateRadioOptionNames();\n  }\n  protected _name: string = this._uid;\n\n  /**\n   * Whether or not the nested radio options should display inline.\n   */\n  @Input()\n  public get inline(): boolean {\n    return this._inline;\n  }\n  public set inline(value: BooleanInput) {\n    this._inline = coerceBooleanPropertyValue(value);\n    this._markRadioOptionsForCheck();\n  }\n  protected _inline = false;\n\n  /**\n   * A reference to the currently selected radio button component (eg. `<impdc-radio-button>`).\n   */\n  @Input()\n  public get selected() {\n    return this._selected;\n  }\n  public set selected(selected: TRadioButton | null) {\n    this._selected = selected;\n    this.value = selected ? selected.value : null;\n    this._checkSelectedRadioOption();\n  }\n  protected _selected: TRadioButton | null = null;\n\n  @Input()\n  public override errorStateMatcher!: ErrorStateMatcher;\n\n  /**\n   * Event emitted whenever a new radio option is selected.\n   */\n  @Output()\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  public readonly change: EventEmitter<RadioChangeEvent> =\n    new EventEmitter<RadioChangeEvent>();\n\n  constructor(\n    private readonly _changeDetector: ChangeDetectorRef,\n    _defaultErrorStateMatcher: ErrorStateMatcher,\n    @Optional() @Inject(IMPDC_FORM_ROOT) _formRoot: ImpdcFormRoot,\n    @Optional() _parentForm: NgForm,\n    @Optional() _parentFormGroup: FormGroupDirective,\n    @Self() @Optional() ngControl: NgControl | null\n  ) {\n    super(\n      _defaultErrorStateMatcher,\n      _formRoot,\n      _parentForm,\n      _parentFormGroup,\n      ngControl\n    );\n\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  /** @ignore */\n  public ngAfterContentInit(): void {\n    this._initialized = true;\n  }\n\n  /** @ignore */\n  public ngDoCheck(): void {\n    const ngControl = this.ngControl;\n\n    if (!ngControl) {\n      return;\n    }\n\n    if (this._previousControl !== ngControl.control) {\n      if (\n        this._previousControl !== undefined &&\n        ngControl.disabled !== null &&\n        ngControl.disabled !== this.disabled\n      ) {\n        this.disabled = ngControl?.disabled;\n      }\n\n      this._previousControl = ngControl.control;\n    }\n\n    this.updateErrorState();\n    this._markRadioOptionsForCheck();\n  }\n\n  /** @ignore */\n  public ngOnDestroy(): void {\n    this.stateChanges.complete();\n  }\n\n  /* ImpdcFormFieldControl */\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      this._updateSelectedRadioOptionFromValue();\n      this._checkSelectedRadioOption();\n      this.stateChanges.next();\n    }\n  }\n  protected _value: any;\n\n  @Input()\n  public get id(): string {\n    return this._id;\n  }\n  public set id(value: string) {\n    this._id = value || this._uid;\n    this.stateChanges.next();\n  }\n  protected _id!: string;\n\n  public get focused(): boolean {\n    return this._focused;\n  }\n  protected _focused = false;\n\n  @Input()\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n  public set disabled(value: BooleanInput) {\n    this._disabled = coerceBooleanPropertyValue(value);\n    this._markRadioOptionsForCheck();\n    this.stateChanges.next();\n  }\n  protected _disabled = false;\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  public readonly controlType = 'impdc-radio-group';\n\n  public readonly supportsAffixes: boolean = false;\n\n  /* ControlValueAccessor */\n  /** @ignore */\n  writeValue(value: any): void {\n    this.value = value;\n    this._changeDetector.markForCheck();\n  }\n\n  /** @ignore */\n  registerOnChange(fn: (value: any) => void): void {\n    this._cvaOnChange = fn;\n  }\n\n  /** @ignore */\n  registerOnTouched(fn: () => {}): void {\n    this._cvaOnTouched = fn;\n  }\n\n  /** @ignore */\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this._changeDetector.markForCheck();\n  }\n\n  /* Internals */\n\n  /** @ignore */\n  public emitChangesEvent(): void {\n    if (this._initialized) {\n      // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n      this.change.emit({ source: this._selected!, value: this._value });\n    }\n  }\n\n  /** @ignore */\n  public onChangeFn(value: any): void {\n    this._cvaOnChange(value);\n  }\n\n  /** @ignore */\n  public touch(): void {\n    if (this._cvaOnTouched) {\n      this._cvaOnTouched();\n    }\n  }\n\n  protected _checkSelectedRadioOption(): void {\n    if (this._selected && !this._selected.checked) {\n      this._selected.checked = true;\n    }\n  }\n\n  protected _markRadioOptionsForCheck(): void {\n    if (this._radioOptions) {\n      this._radioOptions.forEach(option => option.markForCheck());\n    }\n  }\n\n  protected _updateRadioOptionNames(): void {\n    if (this._radioOptions) {\n      this._radioOptions.forEach(option => {\n        option.name = this.name;\n        option.markForCheck();\n      });\n    }\n  }\n\n  protected _updateSelectedRadioOptionFromValue(): void {\n    const isAlreadySelected =\n      this._selected !== null && this._selected.value === this._value;\n\n    if (this._radioOptions && !isAlreadySelected) {\n      this._selected = null;\n      this._radioOptions.forEach(option => {\n        option.checked = this.value === option.value;\n\n        if (option.checked) {\n          this._selected = option;\n        }\n      });\n    }\n  }\n}\n"]}