@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
@@ -37,6 +37,44 @@ const _CheckboxComponentMixinBase = mixinTabIndex(mixinErrorState(CheckboxCompon
37
37
  * To use, import `CheckboxModule` or another module that imports and exports that module from `@impartner/design-components`.
38
38
  */
39
39
  export class CheckboxComponent extends _CheckboxComponentMixinBase {
40
+ /**
41
+ * Whether or not the checkbox input is checked.
42
+ */
43
+ get checked() {
44
+ return this.value;
45
+ }
46
+ set checked(value) {
47
+ this.value = value;
48
+ this._cvaOnChange(this.value);
49
+ }
50
+ /**
51
+ * Whether or not the checkbox input is in an `indeterminate` state.
52
+ */
53
+ get indeterminate() {
54
+ return this._indeterminate;
55
+ }
56
+ set indeterminate(value) {
57
+ const coercedValue = coerceBooleanPropertyValue(value);
58
+ const isChange = coercedValue !== this._indeterminate;
59
+ this._indeterminate = coercedValue;
60
+ if (isChange) {
61
+ this.indeterminateChange.emit(this._indeterminate);
62
+ }
63
+ }
64
+ get disabled() {
65
+ return this._disabled;
66
+ }
67
+ set disabled(value) {
68
+ const newDisabledState = coerceBooleanPropertyValue(value);
69
+ if (newDisabledState !== this._disabled) {
70
+ this._disabled = newDisabledState;
71
+ this._changeDetector.markForCheck();
72
+ this.stateChanges.next();
73
+ }
74
+ }
75
+ get inputId() {
76
+ return `${this.id || this._uid}-input`;
77
+ }
40
78
  constructor(_changeDetector, tabIndex, defaultErrorStateMatcher, formRoot, parentForm, parentFormGroup, ngControl) {
41
79
  super(defaultErrorStateMatcher, formRoot, parentForm, parentFormGroup, ngControl);
42
80
  this._changeDetector = _changeDetector;
@@ -86,44 +124,6 @@ export class CheckboxComponent extends _CheckboxComponentMixinBase {
86
124
  });
87
125
  }
88
126
  }
89
- /**
90
- * Whether or not the checkbox input is checked.
91
- */
92
- get checked() {
93
- return this.value;
94
- }
95
- set checked(value) {
96
- this.value = value;
97
- this._cvaOnChange(this.value);
98
- }
99
- /**
100
- * Whether or not the checkbox input is in an `indeterminate` state.
101
- */
102
- get indeterminate() {
103
- return this._indeterminate;
104
- }
105
- set indeterminate(value) {
106
- const coercedValue = coerceBooleanPropertyValue(value);
107
- const isChange = coercedValue !== this._indeterminate;
108
- this._indeterminate = coercedValue;
109
- if (isChange) {
110
- this.indeterminateChange.emit(this._indeterminate);
111
- }
112
- }
113
- get disabled() {
114
- return this._disabled;
115
- }
116
- set disabled(value) {
117
- const newDisabledState = coerceBooleanPropertyValue(value);
118
- if (newDisabledState !== this._disabled) {
119
- this._disabled = newDisabledState;
120
- this._changeDetector.markForCheck();
121
- this.stateChanges.next();
122
- }
123
- }
124
- get inputId() {
125
- return `${this.id || this._uid}-input`;
126
- }
127
127
  /** @ignore */
128
128
  ngDoCheck() {
129
129
  const ngControl = this.ngControl;
@@ -264,15 +264,15 @@ export class CheckboxComponent extends _CheckboxComponentMixinBase {
264
264
  event.stopPropagation();
265
265
  }
266
266
  }
267
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: CheckboxComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: 'tabindex', attribute: true }, { 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.Component }); }
268
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.1", type: CheckboxComponent, selector: "impdc-checkbox", inputs: { tabIndex: "tabIndex", id: "id", label: "label", description: "description", isSwitch: "isSwitch", switchIcons: "switchIcons", inline: "inline", checked: "checked", indeterminate: "indeterminate", disabled: "disabled", errorStateMatcher: "errorStateMatcher", required: "required" }, outputs: { change: "change", indeterminateChange: "indeterminateChange" }, host: { properties: { "attr.id": "id", "attr.tabindex": "null", "class.impdc-checkbox--required": "required", "class.impdc-checkbox--disabled": "disabled", "class.impdc-checkbox--invalid": "errorState", "class.impdc-checkbox--inline": "inline" }, classAttribute: "impdc-checkbox" }, providers: [
269
+ {
270
+ provide: ImpdcFormFieldControl,
271
+ useExisting: CheckboxComponent
272
+ }
273
+ ], viewQueries: [{ propertyName: "_inputElement", first: true, predicate: ["nativeInput"], descendants: true, read: ElementRef }], exportAs: ["impdcCheckControl"], usesInheritance: true, ngImport: i0, template: "<impdc-toggle\n [label]=\"label\"\n [description]=\"description\"\n [isSwitch]=\"isSwitch\"\n [switchIcons]=\"switchIcons\"\n [inline]=\"inline\"\n (click)=\"_preventBubblingFromLabel($event)\">\n <input\n #nativeInput\n impdc-toggle-input\n type=\"checkbox\"\n class=\"impdc-checkbox__native-control\"\n [class.is-invalid]=\"errorState\"\n [id]=\"inputId\"\n [attr.aria-checked]=\"_getAriaChecked()\"\n [attr.aria-required]=\"required\"\n [attr.tabindex]=\"tabIndex\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [indeterminate]=\"indeterminate\"\n (change)=\"_onInteractionEvent($event)\"\n (click)=\"_handleCheckClick()\"\n (blur)=\"_onBlur()\"\n (focus)=\"_onFocus()\" />\n</impdc-toggle>\n", styles: [":host{display:block;opacity:var(--impartner-hex-input-opacity, 1)}:host.impdc-checkbox--inline{display:inline-block}:host.impdc-checkbox--inline:not(:last-of-type){margin-right:4rem}:host:not(.impdc-checkbox--inline):not(:last-of-type){margin-bottom:1.6rem}:host.impdc-checkbox--disabled{--impartner-hex-input-opacity: .5}:host.impdc-checkbox--invalid ::ng-deep .form-check-label{color:var(--impd-color-red-600)}\n"], dependencies: [{ kind: "component", type: i3.ToggleComponent, selector: "impdc-toggle", inputs: ["isSwitch", "label", "description", "inline", "switchIcons"] }, { kind: "component", type: i4.ToggleInputComponent, selector: "input[impdc-toggle-input]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
267
274
  }
268
- CheckboxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CheckboxComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: 'tabindex', attribute: true }, { 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.Component });
269
- CheckboxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: CheckboxComponent, selector: "impdc-checkbox", inputs: { tabIndex: "tabIndex", id: "id", label: "label", description: "description", isSwitch: "isSwitch", switchIcons: "switchIcons", inline: "inline", checked: "checked", indeterminate: "indeterminate", disabled: "disabled", errorStateMatcher: "errorStateMatcher", required: "required" }, outputs: { change: "change", indeterminateChange: "indeterminateChange" }, host: { properties: { "attr.id": "id", "attr.tabindex": "null", "class.impdc-checkbox--required": "required", "class.impdc-checkbox--disabled": "disabled", "class.impdc-checkbox--invalid": "errorState", "class.impdc-checkbox--inline": "inline" }, classAttribute: "impdc-checkbox" }, providers: [
270
- {
271
- provide: ImpdcFormFieldControl,
272
- useExisting: CheckboxComponent
273
- }
274
- ], viewQueries: [{ propertyName: "_inputElement", first: true, predicate: ["nativeInput"], descendants: true, read: ElementRef }], exportAs: ["impdcCheckControl"], usesInheritance: true, ngImport: i0, template: "<impdc-toggle\n [label]=\"label\"\n [description]=\"description\"\n [isSwitch]=\"isSwitch\"\n [switchIcons]=\"switchIcons\"\n [inline]=\"inline\"\n (click)=\"_preventBubblingFromLabel($event)\">\n <input\n #nativeInput\n impdc-toggle-input\n type=\"checkbox\"\n class=\"impdc-checkbox__native-control\"\n [class.is-invalid]=\"errorState\"\n [id]=\"inputId\"\n [attr.aria-checked]=\"_getAriaChecked()\"\n [attr.aria-required]=\"required\"\n [attr.tabindex]=\"tabIndex\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [indeterminate]=\"indeterminate\"\n (change)=\"_onInteractionEvent($event)\"\n (click)=\"_handleCheckClick()\"\n (blur)=\"_onBlur()\"\n (focus)=\"_onFocus()\" />\n</impdc-toggle>\n", styles: [":host{display:block;opacity:var(--impartner-hex-input-opacity, 1)}:host.impdc-checkbox--inline{display:inline-block}:host.impdc-checkbox--inline:not(:last-of-type){margin-right:4rem}:host:not(.impdc-checkbox--inline):not(:last-of-type){margin-bottom:1.6rem}:host.impdc-checkbox--disabled{--impartner-hex-input-opacity: .5}:host.impdc-checkbox--invalid ::ng-deep .form-check-label{color:var(--impd-color-red-600)}\n"], dependencies: [{ kind: "component", type: i3.ToggleComponent, selector: "impdc-toggle", inputs: ["isSwitch", "label", "description", "inline", "switchIcons"] }, { kind: "component", type: i4.ToggleInputComponent, selector: "input[impdc-toggle-input]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
275
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CheckboxComponent, decorators: [{
275
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: CheckboxComponent, decorators: [{
276
276
  type: Component,
277
277
  args: [{ selector: 'impdc-checkbox', host: {
278
278
  class: 'impdc-checkbox',
@@ -288,7 +288,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
288
288
  useExisting: CheckboxComponent
289
289
  }
290
290
  ], template: "<impdc-toggle\n [label]=\"label\"\n [description]=\"description\"\n [isSwitch]=\"isSwitch\"\n [switchIcons]=\"switchIcons\"\n [inline]=\"inline\"\n (click)=\"_preventBubblingFromLabel($event)\">\n <input\n #nativeInput\n impdc-toggle-input\n type=\"checkbox\"\n class=\"impdc-checkbox__native-control\"\n [class.is-invalid]=\"errorState\"\n [id]=\"inputId\"\n [attr.aria-checked]=\"_getAriaChecked()\"\n [attr.aria-required]=\"required\"\n [attr.tabindex]=\"tabIndex\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [indeterminate]=\"indeterminate\"\n (change)=\"_onInteractionEvent($event)\"\n (click)=\"_handleCheckClick()\"\n (blur)=\"_onBlur()\"\n (focus)=\"_onFocus()\" />\n</impdc-toggle>\n", styles: [":host{display:block;opacity:var(--impartner-hex-input-opacity, 1)}:host.impdc-checkbox--inline{display:inline-block}:host.impdc-checkbox--inline:not(:last-of-type){margin-right:4rem}:host:not(.impdc-checkbox--inline):not(:last-of-type){margin-bottom:1.6rem}:host.impdc-checkbox--disabled{--impartner-hex-input-opacity: .5}:host.impdc-checkbox--invalid ::ng-deep .form-check-label{color:var(--impd-color-red-600)}\n"] }]
291
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
291
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
292
292
  type: Attribute,
293
293
  args: ['tabindex']
294
294
  }] }, { type: i1.ErrorStateMatcher }, { type: undefined, decorators: [{
@@ -304,7 +304,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
304
304
  type: Self
305
305
  }, {
306
306
  type: Optional
307
- }] }]; }, propDecorators: { _inputElement: [{
307
+ }] }], propDecorators: { _inputElement: [{
308
308
  type: ViewChild,
309
309
  args: ['nativeInput', { read: ElementRef }]
310
310
  }], id: [{
@@ -334,4 +334,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
334
334
  }], required: [{
335
335
  type: Input
336
336
  }] } });
337
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../../../../projects/design-components/src/lib/form-field/controls/checkbox/checkbox.component.ts","../../../../../../../../projects/design-components/src/lib/form-field/controls/checkbox/checkbox.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,uBAAuB,EAEvB,SAAS,EAET,UAAU,EACV,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,QAAQ,EACR,MAAM,EACN,IAAI,EACJ,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAOL,UAAU,EACX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAEL,0BAA0B,EAC3B,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAiB,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAElE,OAAO,EAIL,qBAAqB,EACrB,eAAe,EACf,aAAa,EACd,MAAM,cAAc,CAAC;;;;;;AAEtB,MAAM,OAAO,mBAAmB;IAC9B;IACE,0CAA0C;IAC1B,MAAyB;IACzC,sFAAsF;IACtE,OAAgB;QAFhB,WAAM,GAAN,MAAM,CAAmB;QAEzB,YAAO,GAAP,OAAO,CAAS;IAC/B,CAAC;CACL;AAED,MAAe,qBAAqB;IAKlC,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;QATpB,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;IAUhD,CAAC;CACL;AAED,MAAM,2BAA2B,GAAG,aAAa,CAC/C,eAAe,CAAC,qBAAqB,CAAC,CACvC,CAAC;AAEF;;;;GAIG;AA0BH,MAAM,OAAO,iBACX,SAAQ,2BAA2B;IAoHnC,YACmB,eAAkC,EAC5B,QAAgB,EACvC,wBAA2C,EACN,QAAuB,EAChD,UAAkB,EAClB,eAAmC,EAC3B,SAA2B;QAE/C,KAAK,CACH,wBAAwB,EACxB,QAAQ,EACR,UAAU,EACV,eAAe,EACf,SAAS,CACV,CAAC;QAde,oBAAe,GAAf,eAAe,CAAmB;QA1GpC,SAAI,GAAW,kBAAkB,MAAM,EAAE,EAAE,CAAC;QACrD,iBAAY,GAAyB,GAAG,EAAE,GAAE,CAAC,CAAC;QAC9C,kBAAa,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QAM1B,OAAE,GAAW,IAAI,CAAC,IAAI,CAAC;QAE9B;;WAEG;QAEI,UAAK,GAAG,EAAE,CAAC;QAElB;;WAEG;QAEI,gBAAW,GAAG,EAAE,CAAC;QAExB;;WAEG;QAEI,aAAQ,GAAG,KAAK,CAAC;QAExB;;WAEG;QAEI,gBAAW,GAAG,KAAK,CAAC;QAE3B;;WAEG;QAEI,WAAM,GAAG,KAAK,CAAC;QA8Bd,mBAAc,GAAG,KAAK,CAAC;QAerB,cAAS,GAAG,KAAK,CAAC;QAK5B;;WAEG;QAGa,WAAM,GAAsC,IAAI,YAAY,EAAuB,CAAC;QAEpG;;WAEG;QAEa,wBAAmB,GAA0B,IAAI,YAAY,EAAW,CAAC;QA+DjF,WAAM,GAAG,KAAK,CAAC;QAKf,aAAQ,GAAG,KAAK,CAAC;QA4BT,gBAAW,GAAW,aAAa,CAAC;QACpC,oBAAe,GAAY,KAAK,CAAC;QA1E/C,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAExC,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,IAAI,CAAC;YACpC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,aAAa,CAAC,GAAG,EAAE;gBACzC,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;YACzB,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IA1FD;;OAEG;IACH,IACW,OAAO;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IACD,IAAW,OAAO,CAAC,KAAmB;QACpC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED;;OAEG;IACH,IACW,aAAa;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IACD,IAAW,aAAa,CAAC,KAAmB;QAC1C,MAAM,YAAY,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;QACvD,MAAM,QAAQ,GAAG,YAAY,KAAK,IAAI,CAAC,cAAc,CAAC;QACtD,IAAI,CAAC,cAAc,GAAG,YAAY,CAAC;QAEnC,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACpD;IACH,CAAC;IAGD,IACW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAW,QAAQ,CAAC,KAAmB;QACrC,MAAM,gBAAgB,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;QAE3D,IAAI,gBAAgB,KAAK,IAAI,CAAC,SAAS,EAAE;YACvC,IAAI,CAAC,SAAS,GAAG,gBAAgB,CAAC;YAClC,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;YACpC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;SAC1B;IACH,CAAC;IAmBD,IAAW,OAAO;QAChB,OAAO,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,IAAI,QAAQ,CAAC;IACzC,CAAC;IA6BD,cAAc;IACP,SAAS;QACd,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QAEjC,IAAI,CAAC,SAAS,EAAE;YACd,OAAO;SACR;QAED,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,cAAc;IACP,WAAW;QAChB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED,2BAA2B;IAE3B,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IACD,IAAW,KAAK,CAAC,KAAmB;QAClC,MAAM,QAAQ,GAAG,0BAA0B,CAAC,KAAK,CAAC,CAAC;QAEnD,IAAI,QAAQ,KAAK,IAAI,CAAC,MAAM,EAAE;YAC5B,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC;YACvB,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;YACpC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;SAC1B;IACH,CAAC;IAGD,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAGD;;;OAGG;IACH,IACW,QAAQ;QACjB,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE;YAChC,OAAO,IAAI,CAAC,SAAS,CAAC;SACvB;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC;QACxC,IAAI,OAAO,EAAE;YACX,MAAM,WAAW,GAAG,OAAO,CAAC,YAAY,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YAC9D,MAAM,eAAe,GAAG,OAAO,CAAC,YAAY,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;YAEtE,OAAO,WAAW,IAAI,eAAe,CAAC;SACvC;QAED,OAAO,KAAK,CAAC;IACf,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;IAMD,0BAA0B;IAE1B,cAAc;IACP,UAAU,CAAC,KAAU;QAC1B,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC;QACrB,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;IACtC,CAAC;IAED,cAAc;IACP,gBAAgB,CAAC,EAAwB;QAC9C,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IACzB,CAAC;IAED,cAAc;IACP,iBAAiB,CAAC,EAAY;QACnC,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC1B,CAAC;IAED,cAAc;IACP,gBAAgB,CAAC,UAAmB;QACzC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;IACtC,CAAC;IAED,eAAe;IAEf,cAAc;IACP,QAAQ;QACb,OAAO,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,KAAK;YACnD,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;YACpB,CAAC,CAAC,IAAI,CAAC;IACX,CAAC;IAED,eAAe;IACL,eAAe;QACvB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,OAAO,MAAM,CAAC;SACf;QAED,OAAO,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC;IAChD,CAAC;IAES,OAAO;QACf,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,yFAAyF;QACzF,2FAA2F;QAC3F,oFAAoF;QACpF,qFAAqF;QACrF,oEAAoE;QACpE,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YAC1B,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;YACpC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;IACL,CAAC;IAES,QAAQ;QAChB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACrB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;SAC1B;IACH,CAAC;IAES,iBAAiB;QACzB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,IAAI,CAAC,aAAa,EAAE;gBACtB,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;oBAC1B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;oBAC3B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;gBACrD,CAAC,CAAC,CAAC;aACJ;YAED,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC;YAE7B,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;IACH,CAAC;IAES,mBAAmB,CAAC,KAAY;QACxC,0DAA0D;QAC1D,yEAAyE;QACzE,gDAAgD;QAChD,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAChC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,mBAAmB,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;QAE9D,mFAAmF;QACnF,qFAAqF;QACrF,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;SACzD;IACH,CAAC;IAED;;;;;;OAMG;IACO,yBAAyB,CAAC,KAAiB;QACnD,IACE,CAAC,CAAC,KAAK,CAAC,MAAM;YACd,CAAC,CAAC,IAAI,CAAC,aAAa;YACpB,CAAE,KAAK,CAAC,MAAsB,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,EACzE;YACA,KAAK,CAAC,eAAe,EAAE,CAAC;SACzB;IACH,CAAC;;+GAjUU,iBAAiB,mDAuHf,UAAU,+DAED,eAAe;mGAzH1B,iBAAiB,mrBAPjB;QACT;YACE,OAAO,EAAE,qBAAqB;YAC9B,WAAW,EAAE,iBAAiB;SAC/B;KACF,mHAkBiC,UAAU,qFCnH9C,mxBA0BA;4FDyEa,iBAAiB;kBAzB7B,SAAS;+BACE,gBAAgB,QAIpB;wBACJ,KAAK,EAAE,gBAAgB;wBACvB,WAAW,EAAE,IAAI;wBACjB,iBAAiB,EAAE,MAAM;wBACzB,kCAAkC,EAAE,UAAU;wBAC9C,kCAAkC,EAAE,UAAU;wBAC9C,iCAAiC,EAAE,YAAY;wBAC/C,gCAAgC,EAAE,QAAQ;qBAC3C,UAEO,CAAC,UAAU,CAAC,YACV,mBAAmB,mBACZ,uBAAuB,CAAC,MAAM,aACpC;wBACT;4BACE,OAAO,EAAE,qBAAqB;4BAC9B,WAAW,mBAAmB;yBAC/B;qBACF;;0BAyHE,SAAS;2BAAC,UAAU;;0BAEpB,QAAQ;;0BAAI,MAAM;2BAAC,eAAe;;0BAClC,QAAQ;;0BACR,QAAQ;;0BACR,IAAI;;0BAAI,QAAQ;4CA3GT,aAAa;sBADtB,SAAS;uBAAC,aAAa,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAIvC,EAAE;sBADR,KAAK;gBAOC,KAAK;sBADX,KAAK;gBAOC,WAAW;sBADjB,KAAK;gBAOC,QAAQ;sBADd,KAAK;gBAOC,WAAW;sBADjB,KAAK;gBAOC,MAAM;sBADZ,KAAK;gBAOK,OAAO;sBADjB,KAAK;gBAaK,aAAa;sBADvB,KAAK;gBAgBK,QAAQ;sBADlB,KAAK;gBAgBU,iBAAiB;sBADhC,KAAK;gBAQU,MAAM;sBAFrB,MAAM;gBAQS,mBAAmB;sBADlC,MAAM;gBA4EI,QAAQ;sBADlB,KAAK","sourcesContent":["import {\n  Attribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormGroupDirective,\n  NgControl,\n  NgForm,\n  ValidationErrors,\n  Validator,\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  HasTabIndex,\n  ICanUpdateErrorState,\n  IHasErrorState,\n  ImpdcFormFieldControl,\n  mixinErrorState,\n  mixinTabIndex\n} from '../../shared';\n\nexport class CheckboxChangeEvent {\n  constructor(\n    /** The specific checkbox that changed. */\n    public readonly source: CheckboxComponent,\n    /** Whether the changed checkbox was checked or unchecked at the time of the event. */\n    public readonly checked: boolean\n  ) {}\n}\n\nabstract class CheckboxComponentBase {\n  public readonly stateChanges = new Subject<void>();\n\n  abstract disabled: boolean;\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\nconst _CheckboxComponentMixinBase = mixinTabIndex(\n  mixinErrorState(CheckboxComponentBase)\n);\n\n/**\n * The `CheckboxComponent` (`<impdc-checkbox`) is an input with a simple boolean value as a checkbox or toggle switch.\n * This component can be used within a `FormFieldComponent` (`<impdc-form-field`).\n * To use, import `CheckboxModule` or another module that imports and exports that module from `@impartner/design-components`.\n */\n@Component({\n  selector: 'impdc-checkbox',\n  templateUrl: './checkbox.component.html',\n  styleUrls: ['./checkbox.component.scss'],\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    class: 'impdc-checkbox',\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'null',\n    '[class.impdc-checkbox--required]': 'required',\n    '[class.impdc-checkbox--disabled]': 'disabled',\n    '[class.impdc-checkbox--invalid]': 'errorState',\n    '[class.impdc-checkbox--inline]': 'inline'\n  },\n  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property\n  inputs: ['tabIndex'],\n  exportAs: 'impdcCheckControl',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: ImpdcFormFieldControl,\n      useExisting: CheckboxComponent\n    }\n  ]\n})\nexport class CheckboxComponent\n  extends _CheckboxComponentMixinBase\n  implements\n    DoCheck,\n    OnDestroy,\n    ControlValueAccessor,\n    Validator,\n    HasTabIndex,\n    ImpdcFormFieldControl<boolean>,\n    ICanUpdateErrorState,\n    IHasErrorState\n{\n  private readonly _uid: string = `impdc-checkbox-${nanoid()}`;\n  private _cvaOnChange: (value: any) => void = () => {};\n  private _cvaOnTouched = () => {};\n\n  @ViewChild('nativeInput', { read: ElementRef })\n  protected _inputElement?: ElementRef<HTMLInputElement>;\n\n  @Input()\n  public id: string = this._uid;\n\n  /**\n   * The primary label text for the checkbox control.\n   */\n  @Input()\n  public label = '';\n\n  /**\n   * Text to provide additional description or context for the checkbox control. Does not display when `inline` is `true`.\n   */\n  @Input()\n  public description = '';\n\n  /**\n   * Whether or not the input displays as a toggle switch.\n   */\n  @Input()\n  public isSwitch = false;\n\n  /**\n   * When `isSwitch` is `true`, sets whether or not the toggle switch uses icons.\n   */\n  @Input()\n  public switchIcons = false;\n\n  /**\n   * Whether or not the checkbox displays inline.\n   */\n  @Input()\n  public inline = false;\n\n  /**\n   * Whether or not the checkbox input is checked.\n   */\n  @Input()\n  public get checked(): boolean {\n    return this.value;\n  }\n  public set checked(value: BooleanInput) {\n    this.value = value;\n    this._cvaOnChange(this.value);\n  }\n\n  /**\n   * Whether or not the checkbox input is in an `indeterminate` state.\n   */\n  @Input()\n  public get indeterminate(): boolean {\n    return this._indeterminate;\n  }\n  public set indeterminate(value: BooleanInput) {\n    const coercedValue = coerceBooleanPropertyValue(value);\n    const isChange = coercedValue !== this._indeterminate;\n    this._indeterminate = coercedValue;\n\n    if (isChange) {\n      this.indeterminateChange.emit(this._indeterminate);\n    }\n  }\n  private _indeterminate = false;\n\n  @Input()\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n  public set disabled(value: BooleanInput) {\n    const newDisabledState = coerceBooleanPropertyValue(value);\n\n    if (newDisabledState !== this._disabled) {\n      this._disabled = newDisabledState;\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    }\n  }\n  protected _disabled = false;\n\n  @Input()\n  public override errorStateMatcher!: ErrorStateMatcher;\n\n  /**\n   * Event emitted whenever the checkedness of the input changes.\n   */\n  @Output()\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  public readonly change: EventEmitter<CheckboxChangeEvent> = new EventEmitter<CheckboxChangeEvent>();\n\n  /**\n   * Event emitted whenever the control enters or leaves an `indeterminate` state.\n   */\n  @Output()\n  public readonly indeterminateChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n  public get inputId(): string {\n    return `${this.id || this._uid}-input`;\n  }\n\n  constructor(\n    private readonly _changeDetector: ChangeDetectorRef,\n    @Attribute('tabindex') tabIndex: string,\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    this.tabIndex = parseInt(tabIndex) || 0;\n\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n      this.ngControl.control?.addValidators(() => {\n        return this.validate();\n      });\n    }\n  }\n\n  /** @ignore */\n  public ngDoCheck(): void {\n    const ngControl = this.ngControl;\n\n    if (!ngControl) {\n      return;\n    }\n\n    this.updateErrorState();\n  }\n\n  /** @ignore */\n  public ngOnDestroy(): void {\n    this.stateChanges.complete();\n  }\n\n  /* ImpdcFormFieldControl */\n\n  public get value(): boolean {\n    return this._value;\n  }\n  public set value(value: BooleanInput) {\n    const newValue = coerceBooleanPropertyValue(value);\n\n    if (newValue !== this._value) {\n      this._value = newValue;\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    }\n  }\n  private _value = false;\n\n  public get focused(): boolean {\n    return this._focused;\n  }\n  private _focused = false;\n\n  /**\n   * Used to set requiredness of control in a template-based manner; not necessary when using the\n   * Angular reactive forms API and 'required' or `requiredTrue` validators.\n   */\n  @Input()\n  public get required(): boolean {\n    if (this._required !== undefined) {\n      return this._required;\n    }\n\n    const control = this.ngControl?.control;\n    if (control) {\n      const hasRequired = control.hasValidator(Validators.required);\n      const hasRequiredTrue = control.hasValidator(Validators.requiredTrue);\n\n      return hasRequired || hasRequiredTrue;\n    }\n\n    return false;\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: string = 'impdc-check';\n  public readonly supportsAffixes: boolean = false;\n\n  /* ControlValueAccessor */\n\n  /** @ignore */\n  public writeValue(value: any): void {\n    this.value = !!value;\n    this._changeDetector.markForCheck();\n  }\n\n  /** @ignore */\n  public registerOnChange(fn: (value: any) => void): void {\n    this._cvaOnChange = fn;\n  }\n\n  /** @ignore */\n  public registerOnTouched(fn: () => {}): void {\n    this._cvaOnTouched = fn;\n  }\n\n  /** @ignore */\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this._changeDetector.markForCheck();\n  }\n\n  /* Validator */\n\n  /** @ignore */\n  public validate(): ValidationErrors | null {\n    return !this.disabled && this.required && !this.value\n      ? { required: true }\n      : null;\n  }\n\n  /* Internals */\n  protected _getAriaChecked(): 'true' | 'false' | 'mixed' {\n    if (this.checked) {\n      return 'true';\n    }\n\n    return this.indeterminate ? 'mixed' : 'false';\n  }\n\n  protected _onBlur(): void {\n    this._focused = false;\n    // When a focused element becomes disabled, the browser *immediately* fires a blur event.\n    // Angular does not expect events to be raised during change detection, so any state change\n    // (such as a form control's 'ng-touched') will cause a changed-after-checked error.\n    // See https://github.com/angular/angular/issues/17793. To work around this, we defer\n    // telling the form control it has been touched until the next tick.\n    Promise.resolve().then(() => {\n      this._cvaOnTouched();\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    });\n  }\n\n  protected _onFocus(): void {\n    if (!this.disabled) {\n      this._focused = true;\n      this.stateChanges.next();\n    }\n  }\n\n  protected _handleCheckClick(): void {\n    if (!this.disabled) {\n      if (this.indeterminate) {\n        Promise.resolve().then(() => {\n          this.indeterminate = false;\n          this.indeterminateChange.emit(this._indeterminate);\n        });\n      }\n\n      this.checked = !this.checked;\n\n      this._emitChangeEvents();\n    }\n  }\n\n  protected _onInteractionEvent(event: Event) {\n    // We always have to stop propagation on the change event.\n    // Otherwise the change event, from the input element, will bubble up and\n    // emit its event object to the `change` output.\n    event.stopPropagation();\n  }\n\n  private _emitChangeEvents(): void {\n    this._cvaOnChange(this.checked);\n    this.change.emit(new CheckboxChangeEvent(this, this.checked));\n\n    // Assigning the value again here is redundant, but we have to do it in case it was\n    // changed inside the `change` listener which will cause the input to be out of sync.\n    if (this._inputElement) {\n      this._inputElement.nativeElement.checked = this.checked;\n    }\n  }\n\n  /**\n   *  Prevent click events that come from the `<label/>` element from bubbling. This prevents the\n   *  click handler on the host from triggering twice when clicking on the `<label/>` element. After\n   *  the click event on the `<label/>` propagates, the browsers dispatches click on the associated\n   *  `<input/>`. By preventing clicks on the label by bubbling, we ensure only one click event\n   *  bubbles when the label is clicked.\n   */\n  protected _preventBubblingFromLabel(event: MouseEvent) {\n    if (\n      !!event.target &&\n      !!this._inputElement &&\n      !(event.target as HTMLElement).contains(this._inputElement.nativeElement)\n    ) {\n      event.stopPropagation();\n    }\n  }\n}\n","<impdc-toggle\n  [label]=\"label\"\n  [description]=\"description\"\n  [isSwitch]=\"isSwitch\"\n  [switchIcons]=\"switchIcons\"\n  [inline]=\"inline\"\n  (click)=\"_preventBubblingFromLabel($event)\">\n  <input\n    #nativeInput\n    impdc-toggle-input\n    type=\"checkbox\"\n    class=\"impdc-checkbox__native-control\"\n    [class.is-invalid]=\"errorState\"\n    [id]=\"inputId\"\n    [attr.aria-checked]=\"_getAriaChecked()\"\n    [attr.aria-required]=\"required\"\n    [attr.tabindex]=\"tabIndex\"\n    [checked]=\"checked\"\n    [disabled]=\"disabled\"\n    [required]=\"required\"\n    [indeterminate]=\"indeterminate\"\n    (change)=\"_onInteractionEvent($event)\"\n    (click)=\"_handleCheckClick()\"\n    (blur)=\"_onBlur()\"\n    (focus)=\"_onFocus()\" />\n</impdc-toggle>\n"]}
337
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../../../../projects/design-components/src/lib/form-field/controls/checkbox/checkbox.component.ts","../../../../../../../../projects/design-components/src/lib/form-field/controls/checkbox/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Attribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormGroupDirective,\n  NgControl,\n  NgForm,\n  ValidationErrors,\n  Validator,\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  HasTabIndex,\n  ICanUpdateErrorState,\n  IHasErrorState,\n  ImpdcFormFieldControl,\n  mixinErrorState,\n  mixinTabIndex\n} from '../../shared';\n\nexport class CheckboxChangeEvent {\n  constructor(\n    /** The specific checkbox that changed. */\n    public readonly source: CheckboxComponent,\n    /** Whether the changed checkbox was checked or unchecked at the time of the event. */\n    public readonly checked: boolean\n  ) {}\n}\n\nabstract class CheckboxComponentBase {\n  public readonly stateChanges = new Subject<void>();\n\n  abstract disabled: boolean;\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\nconst _CheckboxComponentMixinBase = mixinTabIndex(\n  mixinErrorState(CheckboxComponentBase)\n);\n\n/**\n * The `CheckboxComponent` (`<impdc-checkbox`) is an input with a simple boolean value as a checkbox or toggle switch.\n * This component can be used within a `FormFieldComponent` (`<impdc-form-field`).\n * To use, import `CheckboxModule` or another module that imports and exports that module from `@impartner/design-components`.\n */\n@Component({\n  selector: 'impdc-checkbox',\n  templateUrl: './checkbox.component.html',\n  styleUrls: ['./checkbox.component.scss'],\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    class: 'impdc-checkbox',\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'null',\n    '[class.impdc-checkbox--required]': 'required',\n    '[class.impdc-checkbox--disabled]': 'disabled',\n    '[class.impdc-checkbox--invalid]': 'errorState',\n    '[class.impdc-checkbox--inline]': 'inline'\n  },\n  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property\n  inputs: ['tabIndex'],\n  exportAs: 'impdcCheckControl',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: ImpdcFormFieldControl,\n      useExisting: CheckboxComponent\n    }\n  ]\n})\nexport class CheckboxComponent\n  extends _CheckboxComponentMixinBase\n  implements\n    DoCheck,\n    OnDestroy,\n    ControlValueAccessor,\n    Validator,\n    HasTabIndex,\n    ImpdcFormFieldControl<boolean>,\n    ICanUpdateErrorState,\n    IHasErrorState\n{\n  private readonly _uid: string = `impdc-checkbox-${nanoid()}`;\n  private _cvaOnChange: (value: any) => void = () => {};\n  private _cvaOnTouched = () => {};\n\n  @ViewChild('nativeInput', { read: ElementRef })\n  protected _inputElement?: ElementRef<HTMLInputElement>;\n\n  @Input()\n  public id: string = this._uid;\n\n  /**\n   * The primary label text for the checkbox control.\n   */\n  @Input()\n  public label = '';\n\n  /**\n   * Text to provide additional description or context for the checkbox control. Does not display when `inline` is `true`.\n   */\n  @Input()\n  public description = '';\n\n  /**\n   * Whether or not the input displays as a toggle switch.\n   */\n  @Input()\n  public isSwitch = false;\n\n  /**\n   * When `isSwitch` is `true`, sets whether or not the toggle switch uses icons.\n   */\n  @Input()\n  public switchIcons = false;\n\n  /**\n   * Whether or not the checkbox displays inline.\n   */\n  @Input()\n  public inline = false;\n\n  /**\n   * Whether or not the checkbox input is checked.\n   */\n  @Input()\n  public get checked(): boolean {\n    return this.value;\n  }\n  public set checked(value: BooleanInput) {\n    this.value = value;\n    this._cvaOnChange(this.value);\n  }\n\n  /**\n   * Whether or not the checkbox input is in an `indeterminate` state.\n   */\n  @Input()\n  public get indeterminate(): boolean {\n    return this._indeterminate;\n  }\n  public set indeterminate(value: BooleanInput) {\n    const coercedValue = coerceBooleanPropertyValue(value);\n    const isChange = coercedValue !== this._indeterminate;\n    this._indeterminate = coercedValue;\n\n    if (isChange) {\n      this.indeterminateChange.emit(this._indeterminate);\n    }\n  }\n  private _indeterminate = false;\n\n  @Input()\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n  public set disabled(value: BooleanInput) {\n    const newDisabledState = coerceBooleanPropertyValue(value);\n\n    if (newDisabledState !== this._disabled) {\n      this._disabled = newDisabledState;\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    }\n  }\n  protected _disabled = false;\n\n  @Input()\n  public override errorStateMatcher!: ErrorStateMatcher;\n\n  /**\n   * Event emitted whenever the checkedness of the input changes.\n   */\n  @Output()\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  public readonly change: EventEmitter<CheckboxChangeEvent> =\n    new EventEmitter<CheckboxChangeEvent>();\n\n  /**\n   * Event emitted whenever the control enters or leaves an `indeterminate` state.\n   */\n  @Output()\n  public readonly indeterminateChange: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n\n  public get inputId(): string {\n    return `${this.id || this._uid}-input`;\n  }\n\n  constructor(\n    private readonly _changeDetector: ChangeDetectorRef,\n    @Attribute('tabindex') tabIndex: string,\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    this.tabIndex = parseInt(tabIndex) || 0;\n\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n      this.ngControl.control?.addValidators(() => {\n        return this.validate();\n      });\n    }\n  }\n\n  /** @ignore */\n  public ngDoCheck(): void {\n    const ngControl = this.ngControl;\n\n    if (!ngControl) {\n      return;\n    }\n\n    this.updateErrorState();\n  }\n\n  /** @ignore */\n  public ngOnDestroy(): void {\n    this.stateChanges.complete();\n  }\n\n  /* ImpdcFormFieldControl */\n\n  public get value(): boolean {\n    return this._value;\n  }\n  public set value(value: BooleanInput) {\n    const newValue = coerceBooleanPropertyValue(value);\n\n    if (newValue !== this._value) {\n      this._value = newValue;\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    }\n  }\n  private _value = false;\n\n  public get focused(): boolean {\n    return this._focused;\n  }\n  private _focused = false;\n\n  /**\n   * Used to set requiredness of control in a template-based manner; not necessary when using the\n   * Angular reactive forms API and 'required' or `requiredTrue` validators.\n   */\n  @Input()\n  public get required(): boolean {\n    if (this._required !== undefined) {\n      return this._required;\n    }\n\n    const control = this.ngControl?.control;\n    if (control) {\n      const hasRequired = control.hasValidator(Validators.required);\n      const hasRequiredTrue = control.hasValidator(Validators.requiredTrue);\n\n      return hasRequired || hasRequiredTrue;\n    }\n\n    return false;\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: string = 'impdc-check';\n  public readonly supportsAffixes: boolean = false;\n\n  /* ControlValueAccessor */\n\n  /** @ignore */\n  public writeValue(value: any): void {\n    this.value = !!value;\n    this._changeDetector.markForCheck();\n  }\n\n  /** @ignore */\n  public registerOnChange(fn: (value: any) => void): void {\n    this._cvaOnChange = fn;\n  }\n\n  /** @ignore */\n  public registerOnTouched(fn: () => {}): void {\n    this._cvaOnTouched = fn;\n  }\n\n  /** @ignore */\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this._changeDetector.markForCheck();\n  }\n\n  /* Validator */\n\n  /** @ignore */\n  public validate(): ValidationErrors | null {\n    return !this.disabled && this.required && !this.value\n      ? { required: true }\n      : null;\n  }\n\n  /* Internals */\n  protected _getAriaChecked(): 'true' | 'false' | 'mixed' {\n    if (this.checked) {\n      return 'true';\n    }\n\n    return this.indeterminate ? 'mixed' : 'false';\n  }\n\n  protected _onBlur(): void {\n    this._focused = false;\n    // When a focused element becomes disabled, the browser *immediately* fires a blur event.\n    // Angular does not expect events to be raised during change detection, so any state change\n    // (such as a form control's 'ng-touched') will cause a changed-after-checked error.\n    // See https://github.com/angular/angular/issues/17793. To work around this, we defer\n    // telling the form control it has been touched until the next tick.\n    Promise.resolve().then(() => {\n      this._cvaOnTouched();\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    });\n  }\n\n  protected _onFocus(): void {\n    if (!this.disabled) {\n      this._focused = true;\n      this.stateChanges.next();\n    }\n  }\n\n  protected _handleCheckClick(): void {\n    if (!this.disabled) {\n      if (this.indeterminate) {\n        Promise.resolve().then(() => {\n          this.indeterminate = false;\n          this.indeterminateChange.emit(this._indeterminate);\n        });\n      }\n\n      this.checked = !this.checked;\n\n      this._emitChangeEvents();\n    }\n  }\n\n  protected _onInteractionEvent(event: Event) {\n    // We always have to stop propagation on the change event.\n    // Otherwise the change event, from the input element, will bubble up and\n    // emit its event object to the `change` output.\n    event.stopPropagation();\n  }\n\n  private _emitChangeEvents(): void {\n    this._cvaOnChange(this.checked);\n    this.change.emit(new CheckboxChangeEvent(this, this.checked));\n\n    // Assigning the value again here is redundant, but we have to do it in case it was\n    // changed inside the `change` listener which will cause the input to be out of sync.\n    if (this._inputElement) {\n      this._inputElement.nativeElement.checked = this.checked;\n    }\n  }\n\n  /**\n   *  Prevent click events that come from the `<label/>` element from bubbling. This prevents the\n   *  click handler on the host from triggering twice when clicking on the `<label/>` element. After\n   *  the click event on the `<label/>` propagates, the browsers dispatches click on the associated\n   *  `<input/>`. By preventing clicks on the label by bubbling, we ensure only one click event\n   *  bubbles when the label is clicked.\n   */\n  protected _preventBubblingFromLabel(event: MouseEvent) {\n    if (\n      !!event.target &&\n      !!this._inputElement &&\n      !(event.target as HTMLElement).contains(this._inputElement.nativeElement)\n    ) {\n      event.stopPropagation();\n    }\n  }\n}\n","<impdc-toggle\n  [label]=\"label\"\n  [description]=\"description\"\n  [isSwitch]=\"isSwitch\"\n  [switchIcons]=\"switchIcons\"\n  [inline]=\"inline\"\n  (click)=\"_preventBubblingFromLabel($event)\">\n  <input\n    #nativeInput\n    impdc-toggle-input\n    type=\"checkbox\"\n    class=\"impdc-checkbox__native-control\"\n    [class.is-invalid]=\"errorState\"\n    [id]=\"inputId\"\n    [attr.aria-checked]=\"_getAriaChecked()\"\n    [attr.aria-required]=\"required\"\n    [attr.tabindex]=\"tabIndex\"\n    [checked]=\"checked\"\n    [disabled]=\"disabled\"\n    [required]=\"required\"\n    [indeterminate]=\"indeterminate\"\n    (change)=\"_onInteractionEvent($event)\"\n    (click)=\"_handleCheckClick()\"\n    (blur)=\"_onBlur()\"\n    (focus)=\"_onFocus()\" />\n</impdc-toggle>\n"]}
@@ -4,11 +4,11 @@ import { ToggleModule } from '../shared';
4
4
  import { CheckboxComponent } from './checkbox.component';
5
5
  import * as i0 from "@angular/core";
6
6
  export class CheckboxModule {
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: CheckboxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
8
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.1", ngImport: i0, type: CheckboxModule, declarations: [CheckboxComponent], imports: [CommonModule, ToggleModule], exports: [CheckboxComponent] }); }
9
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: CheckboxModule, imports: [CommonModule, ToggleModule] }); }
7
10
  }
8
- CheckboxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CheckboxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
- CheckboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: CheckboxModule, declarations: [CheckboxComponent], imports: [CommonModule, ToggleModule], exports: [CheckboxComponent] });
10
- CheckboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CheckboxModule, imports: [CommonModule, ToggleModule] });
11
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CheckboxModule, decorators: [{
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: CheckboxModule, decorators: [{
12
12
  type: NgModule,
13
13
  args: [{
14
14
  declarations: [CheckboxComponent],
@@ -16,4 +16,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
16
16
  exports: [CheckboxComponent]
17
17
  }]
18
18
  }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWNvbXBvbmVudHMvc3JjL2xpYi9mb3JtLWZpZWxkL2NvbnRyb2xzL2NoZWNrYm94L2NoZWNrYm94Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDOztBQU96RCxNQUFNLE9BQU8sY0FBYzs7NEdBQWQsY0FBYzs2R0FBZCxjQUFjLGlCQUpWLGlCQUFpQixhQUN0QixZQUFZLEVBQUUsWUFBWSxhQUMxQixpQkFBaUI7NkdBRWhCLGNBQWMsWUFIZixZQUFZLEVBQUUsWUFBWTs0RkFHekIsY0FBYztrQkFMMUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztvQkFDakMsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFlBQVksQ0FBQztvQkFDckMsT0FBTyxFQUFFLENBQUMsaUJBQWlCLENBQUM7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUb2dnbGVNb2R1bGUgfSBmcm9tICcuLi9zaGFyZWQnO1xuaW1wb3J0IHsgQ2hlY2tib3hDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrYm94LmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0NoZWNrYm94Q29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgVG9nZ2xlTW9kdWxlXSxcbiAgZXhwb3J0czogW0NoZWNrYm94Q29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBDaGVja2JveE1vZHVsZSB7fVxuIl19
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWNvbXBvbmVudHMvc3JjL2xpYi9mb3JtLWZpZWxkL2NvbnRyb2xzL2NoZWNrYm94L2NoZWNrYm94Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDOztBQU96RCxNQUFNLE9BQU8sY0FBYzs4R0FBZCxjQUFjOytHQUFkLGNBQWMsaUJBSlYsaUJBQWlCLGFBQ3RCLFlBQVksRUFBRSxZQUFZLGFBQzFCLGlCQUFpQjsrR0FFaEIsY0FBYyxZQUhmLFlBQVksRUFBRSxZQUFZOzsyRkFHekIsY0FBYztrQkFMMUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztvQkFDakMsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFlBQVksQ0FBQztvQkFDckMsT0FBTyxFQUFFLENBQUMsaUJBQWlCLENBQUM7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUb2dnbGVNb2R1bGUgfSBmcm9tICcuLi9zaGFyZWQnO1xuaW1wb3J0IHsgQ2hlY2tib3hDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrYm94LmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0NoZWNrYm94Q29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgVG9nZ2xlTW9kdWxlXSxcbiAgZXhwb3J0czogW0NoZWNrYm94Q29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBDaGVja2JveE1vZHVsZSB7fVxuIl19
@@ -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
+ get disabled() {
45
+ return this._disabled;
46
+ }
47
+ set disabled(value) {
48
+ this._disabled = coerceBooleanPropertyValue(value);
49
+ if (this.focused) {
50
+ this.focused = false;
51
+ this.stateChanges.next();
52
+ }
53
+ }
54
+ get id() {
55
+ return this._id;
56
+ }
57
+ set id(value) {
58
+ this._id = value || this._uid;
59
+ }
60
+ /**
61
+ * Supports most standard `<input [type]>` attribute values. Does not support `button`, `checkbox`,
62
+ * `file`, `hidden`, `image`, `radio`, `range`, `reset`, or `button`, and does not apply to
63
+ * `<textarea>` or `<select>` elements.
64
+ *
65
+ * @default text
66
+ */
67
+ get type() {
68
+ return this._type;
69
+ }
70
+ set type(value) {
71
+ if (!this._typeIsValid(value)) {
72
+ throw getInputUnsupportedTypeError(value);
73
+ }
74
+ this._type = value || 'text';
75
+ // Sync with native input element.
76
+ if (!this._isTextarea) {
77
+ this._elementRef.nativeElement.type = this._type;
78
+ }
79
+ }
80
+ /**
81
+ * Used to set requiredness of control in a template-based manner;
82
+ * not necessary when using the Angular reactive forms API and `required` validator.
83
+ */
84
+ get required() {
85
+ return (this._required ??
86
+ this.ngControl?.control?.hasValidator(Validators.required) ??
87
+ false);
88
+ }
89
+ set required(value) {
90
+ this._required = coerceBooleanPropertyValue(value);
91
+ this.stateChanges.next();
92
+ }
93
+ /**
94
+ * Used to put the control in a non-interactive readonly state; only supports `<input>` and
95
+ * `<textarea>` elements.
96
+ *
97
+ * To see the difference between `readonly` and `disabled`, refer to [MDN's documentation](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/readonly).
98
+ */
99
+ get readonly() {
100
+ return this._readonly;
101
+ }
102
+ set readonly(value) {
103
+ this._readonly = coerceBooleanPropertyValue(value);
104
+ }
105
+ get value() {
106
+ return this._inputValueAccessor.value;
107
+ }
108
+ set value(value) {
109
+ if (value !== this.value) {
110
+ this._inputValueAccessor.value = value;
111
+ this.stateChanges.next();
112
+ }
113
+ }
114
+ constructor(_elementRef, ngControl, _formRoot, _parentForm, _parentFormGroup, _defaultErrorStateMatcher) {
115
+ super(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl);
116
+ this._elementRef = _elementRef;
117
+ this._uid = `impdc-input-${nanoid()}`;
118
+ this.focused = false;
119
+ this.controlType = 'impdc-input';
120
+ this.supportsAffixes = true;
121
+ this._disabled = false;
122
+ this._type = 'text';
123
+ this._readonly = false;
124
+ const { nativeElement } = this._elementRef;
125
+ const nodeName = nativeElement.nodeName.toLowerCase();
126
+ this._inputValueAccessor = nativeElement;
127
+ this.id = this.id;
128
+ this._isSelect = nodeName === 'select';
129
+ this._isTextarea = nodeName === 'textarea';
130
+ if (this._isSelect) {
131
+ this.controlType = nativeElement.multiple
132
+ ? 'impdc-native-select-multiple'
133
+ : 'impdc-native-select';
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
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", 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 }); }
173
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.1", 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 }); }
174
+ }
175
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", 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: () => [{ 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 = 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"]}