@impartner/design-components 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (315) hide show
  1. package/LICENSE.txt +11 -0
  2. package/README.md +22 -0
  3. package/constants/fontawesome-icons.d.ts +6 -0
  4. package/constants/index.d.ts +1 -0
  5. package/esm2020/constants/fontawesome-icons.mjs +3012 -0
  6. package/esm2020/constants/index.mjs +2 -0
  7. package/esm2020/impartner-design-components.mjs +5 -0
  8. package/esm2020/lib/alert/alert.component.mjs +57 -0
  9. package/esm2020/lib/alert/alert.module.mjs +18 -0
  10. package/esm2020/lib/alert/index.mjs +4 -0
  11. package/esm2020/lib/alert/theme/alert-theme.mjs +2 -0
  12. package/esm2020/lib/alert/theme/index.mjs +2 -0
  13. package/esm2020/lib/avatar/avatar.component.mjs +47 -0
  14. package/esm2020/lib/avatar/avatar.module.mjs +18 -0
  15. package/esm2020/lib/avatar/index.mjs +3 -0
  16. package/esm2020/lib/avatar-group/avatar-group.component.mjs +16 -0
  17. package/esm2020/lib/avatar-group/avatar-group.module.mjs +19 -0
  18. package/esm2020/lib/avatar-group/index.mjs +3 -0
  19. package/esm2020/lib/backdrop/backdrop.component.mjs +34 -0
  20. package/esm2020/lib/backdrop/backdrop.module.mjs +19 -0
  21. package/esm2020/lib/backdrop/index.mjs +3 -0
  22. package/esm2020/lib/badge/badge.component.mjs +98 -0
  23. package/esm2020/lib/badge/badge.module.mjs +19 -0
  24. package/esm2020/lib/badge/index.mjs +4 -0
  25. package/esm2020/lib/badge/types/badge-icon.mjs +2 -0
  26. package/esm2020/lib/badge/types/badge-size.mjs +7 -0
  27. package/esm2020/lib/badge/types/index.mjs +2 -0
  28. package/esm2020/lib/branding/branded.directive.mjs +19 -0
  29. package/esm2020/lib/branding/branding.module.mjs +19 -0
  30. package/esm2020/lib/branding/index.mjs +3 -0
  31. package/esm2020/lib/breadcrumb/breadcrumb-item.component.mjs +25 -0
  32. package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +33 -0
  33. package/esm2020/lib/breadcrumb/breadcrumb.module.mjs +19 -0
  34. package/esm2020/lib/breadcrumb/index.mjs +4 -0
  35. package/esm2020/lib/button/button.component.mjs +116 -0
  36. package/esm2020/lib/button/button.module.mjs +21 -0
  37. package/esm2020/lib/button/index.mjs +4 -0
  38. package/esm2020/lib/button/themes/button-theme.mjs +2 -0
  39. package/esm2020/lib/button/themes/index.mjs +2 -0
  40. package/esm2020/lib/button-group/button-group.component.mjs +52 -0
  41. package/esm2020/lib/button-group/button-group.module.mjs +20 -0
  42. package/esm2020/lib/button-group/index.mjs +3 -0
  43. package/esm2020/lib/card-heading/card-heading.component.mjs +30 -0
  44. package/esm2020/lib/card-heading/card-heading.module.mjs +19 -0
  45. package/esm2020/lib/card-heading/index.mjs +3 -0
  46. package/esm2020/lib/design-components.module.mjs +119 -0
  47. package/esm2020/lib/dropdown/components/dropdown-item/dropdown-item.component.mjs +22 -0
  48. package/esm2020/lib/dropdown/components/index.mjs +2 -0
  49. package/esm2020/lib/dropdown/dropdown.component.mjs +140 -0
  50. package/esm2020/lib/dropdown/dropdown.module.mjs +21 -0
  51. package/esm2020/lib/dropdown/index.mjs +5 -0
  52. package/esm2020/lib/dropdown/types/dropdown-position.mjs +2 -0
  53. package/esm2020/lib/dropdown/types/index.mjs +2 -0
  54. package/esm2020/lib/file-upload/directives/file-drop.directive.mjs +50 -0
  55. package/esm2020/lib/file-upload/directives/index.mjs +2 -0
  56. package/esm2020/lib/file-upload/file-upload.component.mjs +334 -0
  57. package/esm2020/lib/file-upload/file-upload.module.mjs +29 -0
  58. package/esm2020/lib/file-upload/index.mjs +5 -0
  59. package/esm2020/lib/file-upload/pipes/human-readable-byte-size.pipe.mjs +23 -0
  60. package/esm2020/lib/file-upload/pipes/index.mjs +2 -0
  61. package/esm2020/lib/form-field/controls/checkbox/checkbox.component.mjs +337 -0
  62. package/esm2020/lib/form-field/controls/checkbox/checkbox.module.mjs +19 -0
  63. package/esm2020/lib/form-field/controls/checkbox/index.mjs +3 -0
  64. package/esm2020/lib/form-field/controls/index.mjs +5 -0
  65. package/esm2020/lib/form-field/controls/input/index.mjs +2 -0
  66. package/esm2020/lib/form-field/controls/input/input.directive.mjs +233 -0
  67. package/esm2020/lib/form-field/controls/radio/index.mjs +6 -0
  68. package/esm2020/lib/form-field/controls/radio/injection-tokens.mjs +4 -0
  69. package/esm2020/lib/form-field/controls/radio/interfaces/index.mjs +4 -0
  70. package/esm2020/lib/form-field/controls/radio/interfaces/radio-button.interface.mjs +2 -0
  71. package/esm2020/lib/form-field/controls/radio/interfaces/radio-change-event.interface.mjs +11 -0
  72. package/esm2020/lib/form-field/controls/radio/interfaces/radio-group.interface.mjs +2 -0
  73. package/esm2020/lib/form-field/controls/radio/radio-button/radio-button.component.mjs +260 -0
  74. package/esm2020/lib/form-field/controls/radio/radio-group/radio-group.directive.mjs +288 -0
  75. package/esm2020/lib/form-field/controls/radio/radio.module.mjs +20 -0
  76. package/esm2020/lib/form-field/controls/select/index.mjs +6 -0
  77. package/esm2020/lib/form-field/controls/select/option/index.mjs +2 -0
  78. package/esm2020/lib/form-field/controls/select/option/select-option.component.mjs +138 -0
  79. package/esm2020/lib/form-field/controls/select/option-parent.mjs +3 -0
  80. package/esm2020/lib/form-field/controls/select/select-model.mjs +149 -0
  81. package/esm2020/lib/form-field/controls/select/select.component.mjs +522 -0
  82. package/esm2020/lib/form-field/controls/select/select.module.mjs +20 -0
  83. package/esm2020/lib/form-field/controls/shared/index.mjs +2 -0
  84. package/esm2020/lib/form-field/controls/shared/toggle/components/index.mjs +2 -0
  85. package/esm2020/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.mjs +17 -0
  86. package/esm2020/lib/form-field/controls/shared/toggle/index.mjs +4 -0
  87. package/esm2020/lib/form-field/controls/shared/toggle/toggle.component.mjs +96 -0
  88. package/esm2020/lib/form-field/controls/shared/toggle/toggle.module.mjs +20 -0
  89. package/esm2020/lib/form-field/directives/corner-hint.directive.mjs +14 -0
  90. package/esm2020/lib/form-field/directives/error.directive.mjs +26 -0
  91. package/esm2020/lib/form-field/directives/form-root.directive.mjs +91 -0
  92. package/esm2020/lib/form-field/directives/hint.directive.mjs +24 -0
  93. package/esm2020/lib/form-field/directives/index.mjs +8 -0
  94. package/esm2020/lib/form-field/directives/label.directive.mjs +14 -0
  95. package/esm2020/lib/form-field/directives/prefix.directive.mjs +24 -0
  96. package/esm2020/lib/form-field/directives/suffix.directive.mjs +24 -0
  97. package/esm2020/lib/form-field/form-field-errors.mjs +5 -0
  98. package/esm2020/lib/form-field/form-field.component.mjs +132 -0
  99. package/esm2020/lib/form-field/impdc-forms.mjs +8 -0
  100. package/esm2020/lib/form-field/impdc-forms.module.mjs +68 -0
  101. package/esm2020/lib/form-field/index.mjs +2 -0
  102. package/esm2020/lib/form-field/services/error-state-matcher.service.mjs +28 -0
  103. package/esm2020/lib/form-field/services/index.mjs +3 -0
  104. package/esm2020/lib/form-field/services/unique-selection-dispatcher.service.mjs +48 -0
  105. package/esm2020/lib/form-field/shared/constructors.type.mjs +2 -0
  106. package/esm2020/lib/form-field/shared/disabled.mixin.mjs +15 -0
  107. package/esm2020/lib/form-field/shared/error-state.mixin.mjs +24 -0
  108. package/esm2020/lib/form-field/shared/form-field-control.mjs +10 -0
  109. package/esm2020/lib/form-field/shared/index.mjs +5 -0
  110. package/esm2020/lib/form-field/shared/tab-index.mixin.mjs +19 -0
  111. package/esm2020/lib/icon/icon.component.mjs +70 -0
  112. package/esm2020/lib/icon/icon.module.mjs +19 -0
  113. package/esm2020/lib/icon/index.mjs +3 -0
  114. package/esm2020/lib/index.mjs +26 -0
  115. package/esm2020/lib/modal/index.mjs +4 -0
  116. package/esm2020/lib/modal/modal.component.mjs +141 -0
  117. package/esm2020/lib/modal/modal.module.mjs +37 -0
  118. package/esm2020/lib/modal/types/index.mjs +3 -0
  119. package/esm2020/lib/modal/types/modal-component-sizes.mjs +9 -0
  120. package/esm2020/lib/modal/types/modal-theme.mjs +12 -0
  121. package/esm2020/lib/pagination/index.mjs +3 -0
  122. package/esm2020/lib/pagination/pagination.component.mjs +134 -0
  123. package/esm2020/lib/pagination/pagination.module.mjs +21 -0
  124. package/esm2020/lib/progress-bar/index.mjs +3 -0
  125. package/esm2020/lib/progress-bar/progress-bar.component.mjs +35 -0
  126. package/esm2020/lib/progress-bar/progress-bar.module.mjs +18 -0
  127. package/esm2020/lib/scrollable/index.mjs +3 -0
  128. package/esm2020/lib/scrollable/scrollable.component.mjs +193 -0
  129. package/esm2020/lib/scrollable/scrollable.module.mjs +21 -0
  130. package/esm2020/lib/select-icon/index.mjs +3 -0
  131. package/esm2020/lib/select-icon/select-icon.component.mjs +307 -0
  132. package/esm2020/lib/select-icon/select-icon.module.mjs +35 -0
  133. package/esm2020/lib/size-detection/directive/element-size.interface.mjs +2 -0
  134. package/esm2020/lib/size-detection/directive/index.mjs +3 -0
  135. package/esm2020/lib/size-detection/directive/size-detector.directive.mjs +43 -0
  136. package/esm2020/lib/size-detection/index.mjs +3 -0
  137. package/esm2020/lib/size-detection/size-detection.module.mjs +18 -0
  138. package/esm2020/lib/spinner/index.mjs +3 -0
  139. package/esm2020/lib/spinner/spinner.component.mjs +24 -0
  140. package/esm2020/lib/spinner/spinner.module.mjs +18 -0
  141. package/esm2020/lib/table/index.mjs +3 -0
  142. package/esm2020/lib/table/table.component.mjs +33 -0
  143. package/esm2020/lib/table/table.module.mjs +19 -0
  144. package/esm2020/lib/text-highlight/index.mjs +3 -0
  145. package/esm2020/lib/text-highlight/text-highlight.component.mjs +81 -0
  146. package/esm2020/lib/text-highlight/text-highlight.module.mjs +19 -0
  147. package/esm2020/public-api.mjs +9 -0
  148. package/esm2020/services/index.mjs +2 -0
  149. package/esm2020/services/interaction.service.mjs +54 -0
  150. package/esm2020/types/component-size.mjs +12 -0
  151. package/esm2020/types/component-theme.mjs +22 -0
  152. package/esm2020/types/index.mjs +3 -0
  153. package/esm2020/utilities/boolean-props.mjs +7 -0
  154. package/esm2020/utilities/dc.mjs +9 -0
  155. package/esm2020/utilities/index.mjs +6 -0
  156. package/esm2020/utilities/lc.mjs +9 -0
  157. package/esm2020/utilities/number-props.mjs +18 -0
  158. package/esm2020/utilities/sanitize.mjs +7 -0
  159. package/fesm2015/impartner-design-components.mjs +8295 -0
  160. package/fesm2015/impartner-design-components.mjs.map +1 -0
  161. package/fesm2020/impartner-design-components.mjs +8264 -0
  162. package/fesm2020/impartner-design-components.mjs.map +1 -0
  163. package/index.d.ts +5 -0
  164. package/lib/alert/alert.component.d.ts +29 -0
  165. package/lib/alert/alert.module.d.ts +8 -0
  166. package/lib/alert/index.d.ts +3 -0
  167. package/lib/alert/theme/alert-theme.d.ts +1 -0
  168. package/lib/alert/theme/index.d.ts +1 -0
  169. package/lib/avatar/avatar.component.d.ts +28 -0
  170. package/lib/avatar/avatar.module.d.ts +8 -0
  171. package/lib/avatar/index.d.ts +2 -0
  172. package/lib/avatar-group/avatar-group.component.d.ts +10 -0
  173. package/lib/avatar-group/avatar-group.module.d.ts +9 -0
  174. package/lib/avatar-group/index.d.ts +2 -0
  175. package/lib/backdrop/backdrop.component.d.ts +19 -0
  176. package/lib/backdrop/backdrop.module.d.ts +9 -0
  177. package/lib/backdrop/index.d.ts +2 -0
  178. package/lib/badge/badge.component.d.ts +48 -0
  179. package/lib/badge/badge.module.d.ts +9 -0
  180. package/lib/badge/index.d.ts +3 -0
  181. package/lib/badge/types/badge-icon.d.ts +1 -0
  182. package/lib/badge/types/badge-size.d.ts +6 -0
  183. package/lib/badge/types/index.d.ts +2 -0
  184. package/lib/branding/branded.directive.d.ts +6 -0
  185. package/lib/branding/branding.module.d.ts +9 -0
  186. package/lib/branding/index.d.ts +2 -0
  187. package/lib/breadcrumb/breadcrumb-item.component.d.ts +7 -0
  188. package/lib/breadcrumb/breadcrumb.component.d.ts +18 -0
  189. package/lib/breadcrumb/breadcrumb.module.d.ts +9 -0
  190. package/lib/breadcrumb/index.d.ts +3 -0
  191. package/lib/button/button.component.d.ts +47 -0
  192. package/lib/button/button.module.d.ts +11 -0
  193. package/lib/button/index.d.ts +3 -0
  194. package/lib/button/themes/button-theme.d.ts +1 -0
  195. package/lib/button/themes/index.d.ts +1 -0
  196. package/lib/button-group/button-group.component.d.ts +22 -0
  197. package/lib/button-group/button-group.module.d.ts +10 -0
  198. package/lib/button-group/index.d.ts +2 -0
  199. package/lib/card-heading/card-heading.component.d.ts +18 -0
  200. package/lib/card-heading/card-heading.module.d.ts +9 -0
  201. package/lib/card-heading/index.d.ts +2 -0
  202. package/lib/design-components.module.d.ts +22 -0
  203. package/lib/dropdown/components/dropdown-item/dropdown-item.component.d.ts +11 -0
  204. package/lib/dropdown/components/index.d.ts +1 -0
  205. package/lib/dropdown/dropdown.component.d.ts +65 -0
  206. package/lib/dropdown/dropdown.module.d.ts +11 -0
  207. package/lib/dropdown/index.d.ts +4 -0
  208. package/lib/dropdown/types/dropdown-position.d.ts +1 -0
  209. package/lib/dropdown/types/index.d.ts +1 -0
  210. package/lib/file-upload/directives/file-drop.directive.d.ts +11 -0
  211. package/lib/file-upload/directives/index.d.ts +1 -0
  212. package/lib/file-upload/file-upload.component.d.ts +105 -0
  213. package/lib/file-upload/file-upload.module.d.ts +13 -0
  214. package/lib/file-upload/index.d.ts +4 -0
  215. package/lib/file-upload/pipes/human-readable-byte-size.pipe.d.ts +7 -0
  216. package/lib/file-upload/pipes/index.d.ts +1 -0
  217. package/lib/form-field/controls/checkbox/checkbox.component.d.ts +133 -0
  218. package/lib/form-field/controls/checkbox/checkbox.module.d.ts +9 -0
  219. package/lib/form-field/controls/checkbox/index.d.ts +2 -0
  220. package/lib/form-field/controls/index.d.ts +4 -0
  221. package/lib/form-field/controls/input/index.d.ts +1 -0
  222. package/lib/form-field/controls/input/input.directive.d.ts +84 -0
  223. package/lib/form-field/controls/radio/index.d.ts +5 -0
  224. package/lib/form-field/controls/radio/injection-tokens.d.ts +4 -0
  225. package/lib/form-field/controls/radio/interfaces/index.d.ts +3 -0
  226. package/lib/form-field/controls/radio/interfaces/radio-button.interface.d.ts +6 -0
  227. package/lib/form-field/controls/radio/interfaces/radio-change-event.interface.d.ts +12 -0
  228. package/lib/form-field/controls/radio/interfaces/radio-group.interface.d.ts +13 -0
  229. package/lib/form-field/controls/radio/radio-button/radio-button.component.d.ts +98 -0
  230. package/lib/form-field/controls/radio/radio-group/radio-group.directive.d.ts +104 -0
  231. package/lib/form-field/controls/radio/radio.module.d.ts +10 -0
  232. package/lib/form-field/controls/select/index.d.ts +5 -0
  233. package/lib/form-field/controls/select/option/index.d.ts +1 -0
  234. package/lib/form-field/controls/select/option/select-option.component.d.ts +60 -0
  235. package/lib/form-field/controls/select/option-parent.d.ts +5 -0
  236. package/lib/form-field/controls/select/select-model.d.ts +36 -0
  237. package/lib/form-field/controls/select/select.component.d.ts +170 -0
  238. package/lib/form-field/controls/select/select.module.d.ts +10 -0
  239. package/lib/form-field/controls/shared/index.d.ts +1 -0
  240. package/lib/form-field/controls/shared/toggle/components/index.d.ts +1 -0
  241. package/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.d.ts +6 -0
  242. package/lib/form-field/controls/shared/toggle/index.d.ts +3 -0
  243. package/lib/form-field/controls/shared/toggle/toggle.component.d.ts +26 -0
  244. package/lib/form-field/controls/shared/toggle/toggle.module.d.ts +10 -0
  245. package/lib/form-field/directives/corner-hint.directive.d.ts +5 -0
  246. package/lib/form-field/directives/error.directive.d.ts +8 -0
  247. package/lib/form-field/directives/form-root.directive.d.ts +26 -0
  248. package/lib/form-field/directives/hint.directive.d.ts +6 -0
  249. package/lib/form-field/directives/index.d.ts +7 -0
  250. package/lib/form-field/directives/label.directive.d.ts +5 -0
  251. package/lib/form-field/directives/prefix.directive.d.ts +9 -0
  252. package/lib/form-field/directives/suffix.directive.d.ts +9 -0
  253. package/lib/form-field/form-field-errors.d.ts +2 -0
  254. package/lib/form-field/form-field.component.d.ts +39 -0
  255. package/lib/form-field/impdc-forms.d.ts +7 -0
  256. package/lib/form-field/impdc-forms.module.d.ts +19 -0
  257. package/lib/form-field/index.d.ts +1 -0
  258. package/lib/form-field/services/error-state-matcher.service.d.ts +12 -0
  259. package/lib/form-field/services/index.d.ts +2 -0
  260. package/lib/form-field/services/unique-selection-dispatcher.service.d.ts +29 -0
  261. package/lib/form-field/shared/constructors.type.d.ts +7 -0
  262. package/lib/form-field/shared/disabled.mixin.d.ts +10 -0
  263. package/lib/form-field/shared/error-state.mixin.d.ts +31 -0
  264. package/lib/form-field/shared/form-field-control.d.ts +24 -0
  265. package/lib/form-field/shared/index.d.ts +5 -0
  266. package/lib/form-field/shared/tab-index.mixin.d.ts +13 -0
  267. package/lib/icon/icon.component.d.ts +30 -0
  268. package/lib/icon/icon.module.d.ts +9 -0
  269. package/lib/icon/index.d.ts +2 -0
  270. package/lib/index.d.ts +25 -0
  271. package/lib/modal/index.d.ts +3 -0
  272. package/lib/modal/modal.component.d.ts +80 -0
  273. package/lib/modal/modal.module.d.ts +13 -0
  274. package/lib/modal/types/index.d.ts +2 -0
  275. package/lib/modal/types/modal-component-sizes.d.ts +3 -0
  276. package/lib/modal/types/modal-theme.d.ts +7 -0
  277. package/lib/pagination/index.d.ts +2 -0
  278. package/lib/pagination/pagination.component.d.ts +41 -0
  279. package/lib/pagination/pagination.module.d.ts +11 -0
  280. package/lib/progress-bar/index.d.ts +2 -0
  281. package/lib/progress-bar/progress-bar.component.d.ts +22 -0
  282. package/lib/progress-bar/progress-bar.module.d.ts +8 -0
  283. package/lib/scrollable/index.d.ts +2 -0
  284. package/lib/scrollable/scrollable.component.d.ts +39 -0
  285. package/lib/scrollable/scrollable.module.d.ts +11 -0
  286. package/lib/select-icon/index.d.ts +2 -0
  287. package/lib/select-icon/select-icon.component.d.ts +123 -0
  288. package/lib/select-icon/select-icon.module.d.ts +11 -0
  289. package/lib/size-detection/directive/element-size.interface.d.ts +4 -0
  290. package/lib/size-detection/directive/index.d.ts +2 -0
  291. package/lib/size-detection/directive/size-detector.directive.d.ts +14 -0
  292. package/lib/size-detection/index.d.ts +3 -0
  293. package/lib/size-detection/size-detection.module.d.ts +8 -0
  294. package/lib/spinner/index.d.ts +2 -0
  295. package/lib/spinner/spinner.component.d.ts +13 -0
  296. package/lib/spinner/spinner.module.d.ts +8 -0
  297. package/lib/table/index.d.ts +2 -0
  298. package/lib/table/table.component.d.ts +15 -0
  299. package/lib/table/table.module.d.ts +9 -0
  300. package/lib/text-highlight/index.d.ts +2 -0
  301. package/lib/text-highlight/text-highlight.component.d.ts +31 -0
  302. package/lib/text-highlight/text-highlight.module.d.ts +9 -0
  303. package/package.json +51 -0
  304. package/public-api.d.ts +4 -0
  305. package/services/index.d.ts +1 -0
  306. package/services/interaction.service.d.ts +14 -0
  307. package/types/component-size.d.ts +12 -0
  308. package/types/component-theme.d.ts +12 -0
  309. package/types/index.d.ts +2 -0
  310. package/utilities/boolean-props.d.ts +8 -0
  311. package/utilities/dc.d.ts +6 -0
  312. package/utilities/index.d.ts +5 -0
  313. package/utilities/lc.d.ts +6 -0
  314. package/utilities/number-props.d.ts +15 -0
  315. package/utilities/sanitize.d.ts +1 -0
@@ -0,0 +1,193 @@
1
+ import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewChild } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
4
+ import * as i2 from "../size-detection/directive/size-detector.directive";
5
+ /**
6
+ * The `ScrollableComponent` (`<impdc-scrollable` or `<div impdc-scrollable`) is a container that hides items that wouldn't fit
7
+ * with arrows on the left and right to slide between them.
8
+ * To use, import `ScrollableModule` or another module that imports and exports that module from `@impartner/design-components`.
9
+ * `ScrollableModule` also imports and exports [BrandingModule](./?path=/docs/design-components-directives-impdcbranded).
10
+ */
11
+ export class ScrollableComponent {
12
+ constructor(_cd) {
13
+ this._cd = _cd;
14
+ /**
15
+ * The base amount to scroll.
16
+ */
17
+ this.scrollUnit = 20;
18
+ /**
19
+ * Used in combination with `scrollUnit` to determine how far the Scrollable scrolls when directional arrows are clicked.
20
+ */
21
+ this.clickScrollMultiplier = 5;
22
+ this._scrollableBgColor = null;
23
+ this._width = 0;
24
+ }
25
+ get canScrollLeft() {
26
+ if (!this._contentElement) {
27
+ return false;
28
+ }
29
+ return Math.floor(this._contentElement.scrollLeft) > 0;
30
+ }
31
+ get canScrollRight() {
32
+ if (!this._contentElement) {
33
+ return false;
34
+ }
35
+ return (Math.ceil(this._contentElement.scrollLeft + this._width) <
36
+ this._contentElement.scrollWidth);
37
+ }
38
+ get _containerElement() {
39
+ if (!this.containerRef) {
40
+ return null;
41
+ }
42
+ return this.containerRef.nativeElement;
43
+ }
44
+ get _contentElement() {
45
+ if (!this.contentRef) {
46
+ return null;
47
+ }
48
+ return this.contentRef.nativeElement;
49
+ }
50
+ ngOnChanges(changes) {
51
+ if (changes['scrollUnit'] || changes['clickScrollMultiplier']) {
52
+ if (this._containerElement) {
53
+ this._width = this._containerElement?.clientWidth;
54
+ this._cd.detectChanges();
55
+ }
56
+ }
57
+ this._getBackgroundColorForButtons();
58
+ }
59
+ ngAfterViewInit() {
60
+ this._width = this.contentRef?.nativeElement.width;
61
+ this._getBackgroundColorForButtons();
62
+ this._cd.detectChanges();
63
+ }
64
+ async scroll(direction) {
65
+ if (!this._contentElement) {
66
+ return;
67
+ }
68
+ let pixels = direction * this.scrollUnit * this.clickScrollMultiplier;
69
+ let position = 0;
70
+ if (!pixels) {
71
+ if (direction === 1) {
72
+ position = this._contentElement.scrollWidth;
73
+ }
74
+ }
75
+ else {
76
+ position = this._contentElement.scrollLeft + pixels;
77
+ }
78
+ await this._scrollToPosition(this._contentElement, position);
79
+ this._cd.detectChanges();
80
+ }
81
+ widthChanged(elementSize) {
82
+ if (!elementSize || !elementSize.width) {
83
+ return;
84
+ }
85
+ this._width = elementSize.width;
86
+ this._cd.detectChanges();
87
+ }
88
+ async _scrollToPosition(container, position) {
89
+ position = Math.round(position);
90
+ if (container.scrollLeft === position) {
91
+ return;
92
+ }
93
+ let resolveFn;
94
+ let scrollListener;
95
+ let timeoutId;
96
+ const promise = new Promise(resolve => {
97
+ resolveFn = resolve;
98
+ });
99
+ const finished = () => {
100
+ container.removeEventListener('scroll', scrollListener);
101
+ resolveFn(null);
102
+ };
103
+ scrollListener = () => {
104
+ clearTimeout(timeoutId);
105
+ // scroll is finished when either the position has been reached, or 100ms have elapsed since the last scroll event
106
+ if (container.scrollLeft === position) {
107
+ finished();
108
+ }
109
+ else {
110
+ timeoutId = setTimeout(finished, 100);
111
+ }
112
+ };
113
+ container.addEventListener('scroll', scrollListener);
114
+ container.scrollTo({
115
+ left: position,
116
+ behavior: 'smooth'
117
+ });
118
+ return promise;
119
+ }
120
+ _getBackgroundColorForButtons() {
121
+ if (!this.contentRef) {
122
+ return;
123
+ }
124
+ const projectedElementCollection = this.contentRef.nativeElement.children;
125
+ if (!projectedElementCollection || !projectedElementCollection.length) {
126
+ return;
127
+ }
128
+ const firstElement = projectedElementCollection[0];
129
+ let backgroundColor = this._getBackGroundColor(firstElement);
130
+ if (!backgroundColor) {
131
+ backgroundColor = this._getAncestorBackgroundColor();
132
+ }
133
+ this._scrollableBgColor = backgroundColor;
134
+ }
135
+ _getAncestorBackgroundColor() {
136
+ if (!this.contentRef) {
137
+ return null;
138
+ }
139
+ let result = {
140
+ parent: this.contentRef.nativeElement.parentElement,
141
+ backgroundColor: null
142
+ };
143
+ let count = 6;
144
+ function getParentBackgroundColor(currentContext, getBackgroundColor) {
145
+ const result = { parent: null, backgroundColor: null };
146
+ if (currentContext && currentContext.parent) {
147
+ result.backgroundColor = getBackgroundColor(currentContext.parent);
148
+ if (!result.backgroundColor) {
149
+ result.parent = currentContext.parent.parentElement;
150
+ }
151
+ }
152
+ return result;
153
+ }
154
+ while (count > 0) {
155
+ if (result.backgroundColor) {
156
+ break;
157
+ }
158
+ result = getParentBackgroundColor(result, this._getBackGroundColor);
159
+ if (!result.parent) {
160
+ break;
161
+ }
162
+ count = count - 1;
163
+ }
164
+ return result.backgroundColor;
165
+ }
166
+ _getBackGroundColor(element) {
167
+ const computedBackgroundColor = getComputedStyle(element)['backgroundColor'];
168
+ if (computedBackgroundColor !== 'rgba(0, 0, 0, 0)') {
169
+ return computedBackgroundColor;
170
+ }
171
+ return element.style.backgroundColor;
172
+ }
173
+ }
174
+ ScrollableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ScrollableComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
175
+ ScrollableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ScrollableComponent, selector: "impdc-scrollable, div[impdc-scrollable]", inputs: { scrollUnit: "scrollUnit", clickScrollMultiplier: "clickScrollMultiplier" }, host: { properties: { "style.--impdc-scrollable-bg": "this._scrollableBgColor" } }, viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }, { propertyName: "contentRef", first: true, predicate: ["content"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n class=\"impdc-scrollable\"\n #container\n impdcSizeDetector\n (resized)=\"widthChanged($event)\">\n <a class=\"impdc-scrollable-left\" (click)=\"scroll(-1)\" *ngIf=\"canScrollLeft\">\n <i class=\"fas fa-chevron-left default\"></i>\n </a>\n <div #content class=\"content-container\">\n <ng-content></ng-content>\n </div>\n <a class=\"impdc-scrollable-right\" (click)=\"scroll(1)\" *ngIf=\"canScrollRight\">\n <i class=\"fas fa-chevron-right default\"></i>\n </a>\n</div>\n", styles: [".impdc-scrollable{position:relative;overflow-y:hidden}.impdc-scrollable .impdc-scrollable-base,.impdc-scrollable .impdc-scrollable-right,.impdc-scrollable .impdc-scrollable-left{position:absolute;top:0px;bottom:0px;display:flex;align-items:center;text-align:center;width:6.9rem;z-index:1;color:var(--impd-color-motion-blue-600, #01606d)}.impdc-scrollable .impdc-scrollable-left{justify-content:left;padding-left:1.5rem;background-image:linear-gradient(to right,var(--impdc-scrollable-bg, #fff) 50%,rgba(255,255,255,.0001) 86.46%)}.impdc-scrollable .impdc-scrollable-right{right:0;padding-right:1.5rem;justify-content:right;background-image:linear-gradient(to left,var(--impdc-scrollable-bg, #fff) 50%,rgba(255,255,255,.0001) 86.46%)}.impdc-scrollable .content-container{overflow-x:hidden;-webkit-overflow-scrolling:touch;white-space:nowrap}:host(.branded) .impdc-scrollable .impdc-scrollable-left,:host(.branded) .impdc-scrollable .impdc-scrollable-right{color:var(--px-primary-color, var(--impd-color-motion-blue-600, #01606d))}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.SizeDetectorDirective, selector: "[impdcSizeDetector]", outputs: ["resized"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
176
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ScrollableComponent, decorators: [{
177
+ type: Component,
178
+ args: [{ selector: 'impdc-scrollable, div[impdc-scrollable]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"impdc-scrollable\"\n #container\n impdcSizeDetector\n (resized)=\"widthChanged($event)\">\n <a class=\"impdc-scrollable-left\" (click)=\"scroll(-1)\" *ngIf=\"canScrollLeft\">\n <i class=\"fas fa-chevron-left default\"></i>\n </a>\n <div #content class=\"content-container\">\n <ng-content></ng-content>\n </div>\n <a class=\"impdc-scrollable-right\" (click)=\"scroll(1)\" *ngIf=\"canScrollRight\">\n <i class=\"fas fa-chevron-right default\"></i>\n </a>\n</div>\n", styles: [".impdc-scrollable{position:relative;overflow-y:hidden}.impdc-scrollable .impdc-scrollable-base,.impdc-scrollable .impdc-scrollable-right,.impdc-scrollable .impdc-scrollable-left{position:absolute;top:0px;bottom:0px;display:flex;align-items:center;text-align:center;width:6.9rem;z-index:1;color:var(--impd-color-motion-blue-600, #01606d)}.impdc-scrollable .impdc-scrollable-left{justify-content:left;padding-left:1.5rem;background-image:linear-gradient(to right,var(--impdc-scrollable-bg, #fff) 50%,rgba(255,255,255,.0001) 86.46%)}.impdc-scrollable .impdc-scrollable-right{right:0;padding-right:1.5rem;justify-content:right;background-image:linear-gradient(to left,var(--impdc-scrollable-bg, #fff) 50%,rgba(255,255,255,.0001) 86.46%)}.impdc-scrollable .content-container{overflow-x:hidden;-webkit-overflow-scrolling:touch;white-space:nowrap}:host(.branded) .impdc-scrollable .impdc-scrollable-left,:host(.branded) .impdc-scrollable .impdc-scrollable-right{color:var(--px-primary-color, var(--impd-color-motion-blue-600, #01606d))}\n"] }]
179
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { scrollUnit: [{
180
+ type: Input
181
+ }], clickScrollMultiplier: [{
182
+ type: Input
183
+ }], _scrollableBgColor: [{
184
+ type: HostBinding,
185
+ args: ['style.--impdc-scrollable-bg']
186
+ }], containerRef: [{
187
+ type: ViewChild,
188
+ args: ['container', { static: false }]
189
+ }], contentRef: [{
190
+ type: ViewChild,
191
+ args: ['content', { static: false }]
192
+ }] } });
193
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/scrollable/scrollable.component.ts","../../../../../../projects/design-components/src/lib/scrollable/scrollable.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnChanges,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { IElementSize } from '../size-detection';\n\n/**\n * The `ScrollableComponent` (`<impdc-scrollable` or `<div impdc-scrollable`) is a container that hides items that wouldn't fit\n * with arrows on the left and right to slide between them.\n * To use, import `ScrollableModule` or another module that imports and exports that module from `@impartner/design-components`.\n * `ScrollableModule` also imports and exports [BrandingModule](./?path=/docs/design-components-directives-impdcbranded).\n */\n@Component({\n  selector: 'impdc-scrollable, div[impdc-scrollable]',\n  templateUrl: './scrollable.component.html',\n  styleUrls: ['./scrollable.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ScrollableComponent implements OnChanges, AfterViewInit {\n  /**\n   * The base amount to scroll.\n   */\n  @Input()\n  public scrollUnit: number = 20;\n\n  /**\n   * Used in combination with `scrollUnit` to determine how far the Scrollable scrolls when directional arrows are clicked.\n   */\n  @Input()\n  public clickScrollMultiplier = 5;\n\n  @HostBinding('style.--impdc-scrollable-bg')\n  private _scrollableBgColor: string | null = null;\n\n  public get canScrollLeft(): boolean {\n    if (!this._contentElement) {\n      return false;\n    }\n\n    return Math.floor(this._contentElement.scrollLeft) > 0;\n  }\n\n  public get canScrollRight(): boolean {\n    if (!this._contentElement) {\n      return false;\n    }\n\n    return (\n      Math.ceil(this._contentElement.scrollLeft + this._width) <\n      this._contentElement.scrollWidth\n    );\n  }\n\n  private _width: number = 0;\n\n  @ViewChild('container', { static: false })\n  public containerRef: ElementRef | undefined;\n\n  private get _containerElement(): HTMLDivElement | null {\n    if (!this.containerRef) {\n      return null;\n    }\n\n    return this.containerRef.nativeElement;\n  }\n\n  @ViewChild('content', { static: false })\n  public contentRef: ElementRef | undefined;\n\n  private get _contentElement(): HTMLDivElement | null {\n    if (!this.contentRef) {\n      return null;\n    }\n\n    return this.contentRef.nativeElement;\n  }\n\n  constructor(private _cd: ChangeDetectorRef) {}\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes['scrollUnit'] || changes['clickScrollMultiplier']) {\n      if (this._containerElement) {\n        this._width = this._containerElement?.clientWidth;\n        this._cd.detectChanges();\n      }\n    }\n    this._getBackgroundColorForButtons();\n  }\n\n  public ngAfterViewInit(): void {\n    this._width = this.contentRef?.nativeElement.width;\n    this._getBackgroundColorForButtons();\n    this._cd.detectChanges();\n  }\n\n  public async scroll(direction: number): Promise<void> {\n    if (!this._contentElement) {\n      return;\n    }\n\n    let pixels = direction * this.scrollUnit * this.clickScrollMultiplier;\n    let position = 0;\n\n    if (!pixels) {\n      if (direction === 1) {\n        position = this._contentElement.scrollWidth;\n      }\n    } else {\n      position = this._contentElement.scrollLeft + pixels;\n    }\n\n    await this._scrollToPosition(this._contentElement, position);\n\n    this._cd.detectChanges();\n  }\n\n  public widthChanged(elementSize: IElementSize): void {\n    if (!elementSize || !elementSize.width) {\n      return;\n    }\n    this._width = elementSize.width;\n    this._cd.detectChanges();\n  }\n\n  private async _scrollToPosition(container: HTMLDivElement, position: number) {\n    position = Math.round(position);\n\n    if (container.scrollLeft === position) {\n      return;\n    }\n\n    let resolveFn: (value: unknown) => void;\n    let scrollListener: () => void;\n    let timeoutId: any;\n\n    const promise = new Promise(resolve => {\n      resolveFn = resolve;\n    });\n\n    const finished = () => {\n      container.removeEventListener('scroll', scrollListener);\n      resolveFn(null);\n    };\n\n    scrollListener = () => {\n      clearTimeout(timeoutId);\n\n      // scroll is finished when either the position has been reached, or 100ms have elapsed since the last scroll event\n      if (container.scrollLeft === position) {\n        finished();\n      } else {\n        timeoutId = setTimeout(finished, 100);\n      }\n    };\n\n    container.addEventListener('scroll', scrollListener);\n\n    container.scrollTo({\n      left: position,\n      behavior: 'smooth'\n    });\n\n    return promise;\n  }\n\n  private _getBackgroundColorForButtons(): void {\n    if (!this.contentRef) {\n      return;\n    }\n\n    const projectedElementCollection: HTMLCollection =\n      this.contentRef.nativeElement.children;\n\n    if (!projectedElementCollection || !projectedElementCollection.length) {\n      return;\n    }\n\n    const firstElement = projectedElementCollection[0] as HTMLElement;\n    let backgroundColor: string | null = this._getBackGroundColor(firstElement);\n\n    if (!backgroundColor) {\n      backgroundColor = this._getAncestorBackgroundColor();\n    }\n\n    this._scrollableBgColor = backgroundColor;\n  }\n\n  private _getAncestorBackgroundColor(): string | null {\n    if (!this.contentRef) {\n      return null;\n    }\n\n    type parentBgResult = {\n      parent: HTMLElement | null;\n      backgroundColor: string | null;\n    };\n\n    let result: parentBgResult = {\n      parent: (this.contentRef.nativeElement as HTMLElement).parentElement,\n      backgroundColor: null\n    };\n\n    let count = 6;\n\n    function getParentBackgroundColor(\n      currentContext: parentBgResult,\n      getBackgroundColor: (element: HTMLElement) => string | null\n    ): parentBgResult {\n      const result: parentBgResult = { parent: null, backgroundColor: null };\n      if (currentContext && currentContext.parent) {\n        result.backgroundColor = getBackgroundColor(currentContext.parent);\n\n        if (!result.backgroundColor) {\n          result.parent = currentContext.parent.parentElement;\n        }\n      }\n\n      return result;\n    }\n\n    while (count > 0) {\n      if (result.backgroundColor) {\n        break;\n      }\n      result = getParentBackgroundColor(result, this._getBackGroundColor);\n\n      if (!result.parent) {\n        break;\n      }\n      count = count - 1;\n    }\n\n    return result.backgroundColor;\n  }\n\n  private _getBackGroundColor(element: HTMLElement): string | null {\n    const computedBackgroundColor =\n      getComputedStyle(element)['backgroundColor'];\n\n    if (computedBackgroundColor !== 'rgba(0, 0, 0, 0)') {\n      return computedBackgroundColor;\n    }\n\n    return element.style.backgroundColor;\n  }\n}\n","<div\n  class=\"impdc-scrollable\"\n  #container\n  impdcSizeDetector\n  (resized)=\"widthChanged($event)\">\n  <a class=\"impdc-scrollable-left\" (click)=\"scroll(-1)\" *ngIf=\"canScrollLeft\">\n    <i class=\"fas fa-chevron-left default\"></i>\n  </a>\n  <div #content class=\"content-container\">\n    <ng-content></ng-content>\n  </div>\n  <a class=\"impdc-scrollable-right\" (click)=\"scroll(1)\" *ngIf=\"canScrollRight\">\n    <i class=\"fas fa-chevron-right default\"></i>\n  </a>\n</div>\n"]}
@@ -0,0 +1,21 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { BrandingModule } from '../branding';
4
+ import { SizeDetectionModule } from '../size-detection';
5
+ import { ScrollableComponent } from './scrollable.component';
6
+ import * as i0 from "@angular/core";
7
+ export class ScrollableModule {
8
+ constructor() { }
9
+ }
10
+ ScrollableModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ScrollableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
11
+ ScrollableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: ScrollableModule, declarations: [ScrollableComponent], imports: [CommonModule, SizeDetectionModule, BrandingModule], exports: [ScrollableComponent, BrandingModule] });
12
+ ScrollableModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ScrollableModule, imports: [CommonModule, SizeDetectionModule, BrandingModule, BrandingModule] });
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ScrollableModule, decorators: [{
14
+ type: NgModule,
15
+ args: [{
16
+ imports: [CommonModule, SizeDetectionModule, BrandingModule],
17
+ declarations: [ScrollableComponent],
18
+ exports: [ScrollableComponent, BrandingModule]
19
+ }]
20
+ }], ctorParameters: function () { return []; } });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsYWJsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL3Njcm9sbGFibGUvc2Nyb2xsYWJsZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM3QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFPN0QsTUFBTSxPQUFPLGdCQUFnQjtJQUMzQixnQkFBZSxDQUFDOzs4R0FETCxnQkFBZ0I7K0dBQWhCLGdCQUFnQixpQkFIWixtQkFBbUIsYUFEeEIsWUFBWSxFQUFFLG1CQUFtQixFQUFFLGNBQWMsYUFFakQsbUJBQW1CLEVBQUUsY0FBYzsrR0FFbEMsZ0JBQWdCLFlBSmpCLFlBQVksRUFBRSxtQkFBbUIsRUFBRSxjQUFjLEVBRTVCLGNBQWM7NEZBRWxDLGdCQUFnQjtrQkFMNUIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsbUJBQW1CLEVBQUUsY0FBYyxDQUFDO29CQUM1RCxZQUFZLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztvQkFDbkMsT0FBTyxFQUFFLENBQUMsbUJBQW1CLEVBQUUsY0FBYyxDQUFDO2lCQUMvQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQnJhbmRpbmdNb2R1bGUgfSBmcm9tICcuLi9icmFuZGluZyc7XG5pbXBvcnQgeyBTaXplRGV0ZWN0aW9uTW9kdWxlIH0gZnJvbSAnLi4vc2l6ZS1kZXRlY3Rpb24nO1xuaW1wb3J0IHsgU2Nyb2xsYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vc2Nyb2xsYWJsZS5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBTaXplRGV0ZWN0aW9uTW9kdWxlLCBCcmFuZGluZ01vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogW1Njcm9sbGFibGVDb21wb25lbnRdLFxuICBleHBvcnRzOiBbU2Nyb2xsYWJsZUNvbXBvbmVudCwgQnJhbmRpbmdNb2R1bGVdXG59KVxuZXhwb3J0IGNsYXNzIFNjcm9sbGFibGVNb2R1bGUge1xuICBjb25zdHJ1Y3RvcigpIHt9XG59XG4iXX0=
@@ -0,0 +1,3 @@
1
+ export * from './select-icon.component';
2
+ export * from './select-icon.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL3NlbGVjdC1pY29uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxzQkFBc0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2VsZWN0LWljb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0LWljb24ubW9kdWxlJztcbiJdfQ==
@@ -0,0 +1,307 @@
1
+ /* eslint-disable @angular-eslint/no-conflicting-lifecycle */
2
+ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Inject, Input, Optional, Output, Self, ViewChild } from '@angular/core';
3
+ import { FormControl, Validators } from '@angular/forms';
4
+ import { nanoid } from 'nanoid';
5
+ import { BehaviorSubject, combineLatest, debounceTime, distinctUntilChanged, map, startWith, Subject } from 'rxjs';
6
+ import { FontAwesomeIcons } from '../../constants';
7
+ import { coerceBooleanPropertyValue } from '../../utilities';
8
+ import { ImpdcFormFieldControl, IMPDC_FORM_ROOT, mixinDisabled, mixinErrorState, mixinTabIndex } from '../form-field';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../form-field";
11
+ import * as i2 from "@angular/forms";
12
+ import * as i3 from "@angular/common";
13
+ import * as i4 from "@ng-bootstrap/ng-bootstrap";
14
+ import * as i5 from "../form-field/form-field.component";
15
+ import * as i6 from "../form-field/controls/input/input.directive";
16
+ import * as i7 from "../form-field/directives/prefix.directive";
17
+ export class ImpdcSelectIconChange {
18
+ constructor(source, value) {
19
+ this.source = source;
20
+ this.value = value;
21
+ }
22
+ }
23
+ const _SelectIconComponentBase = mixinTabIndex(mixinDisabled(mixinErrorState(class {
24
+ constructor(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl) {
25
+ this._defaultErrorStateMatcher = _defaultErrorStateMatcher;
26
+ this._formRoot = _formRoot;
27
+ this._parentForm = _parentForm;
28
+ this._parentFormGroup = _parentFormGroup;
29
+ this.ngControl = ngControl;
30
+ this.stateChanges = new Subject();
31
+ }
32
+ })));
33
+ /**
34
+ * The `SelectIconComponent` (`<impdc-select-icon`) is a select dropdown with search that shows all standard icons from Bootstrap 5.
35
+ * To use, import `SelectIconModule` or another module that imports and exports that module from `@impartner/design-components`.
36
+ */
37
+ export class SelectIconComponent extends _SelectIconComponentBase {
38
+ constructor(_changeDetector, _defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl) {
39
+ super(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl);
40
+ this._changeDetector = _changeDetector;
41
+ this.searchControl = new FormControl('');
42
+ this._uid = `impdc-select-icon-${nanoid()}`;
43
+ this._dropdownOpen = false;
44
+ this._iconOptionsSubject = new BehaviorSubject(FontAwesomeIcons);
45
+ this._cvaOnChange = () => { };
46
+ this._cvaOnTouched = () => { };
47
+ this._placeholder = '- Select -';
48
+ /** Events fire when selection has been changed by the user. */
49
+ this.selectionChange = new EventEmitter();
50
+ /**
51
+ * Events fire when raw value of select changes. Mainly exists to handle
52
+ * two-way binding of `value` input property.
53
+ * @ignore
54
+ */
55
+ this.valueChange = new EventEmitter();
56
+ this._value = null;
57
+ this._focused = false;
58
+ this.controlType = 'impdc-select-icon';
59
+ this.supportsAffixes = true;
60
+ this.allowSearch = false;
61
+ this.showText = true;
62
+ this.showSelectedText = true;
63
+ const debouncedSearchValues = this.searchControl.valueChanges.pipe(startWith(''), debounceTime(200), distinctUntilChanged());
64
+ this.filteredOptions$ = combineLatest([
65
+ debouncedSearchValues,
66
+ this._iconOptionsSubject.asObservable()
67
+ ]).pipe(map(([searchTerm, iconOptions]) => {
68
+ if (!searchTerm) {
69
+ return [...iconOptions];
70
+ }
71
+ const searchTermLowerCase = searchTerm.toLowerCase();
72
+ return iconOptions.filter(option => option.toLowerCase().indexOf(searchTermLowerCase) > -1);
73
+ }));
74
+ if (this.ngControl) {
75
+ this.ngControl.valueAccessor = this;
76
+ }
77
+ this.id = this.id;
78
+ }
79
+ get iconOptions() {
80
+ return [...this._iconOptionsSubject.value];
81
+ }
82
+ /**
83
+ * Set to override the default set of FontAwesome icon options.
84
+ */
85
+ set iconOptions(iconOptions) {
86
+ if (iconOptions) {
87
+ this._iconOptionsSubject.next([...iconOptions]);
88
+ }
89
+ }
90
+ /**
91
+ * The placeholder text that will be displayed when no selection has been made.
92
+ *
93
+ * @default \- Select -
94
+ */
95
+ get placeholder() {
96
+ return this._placeholder;
97
+ }
98
+ set placeholder(value) {
99
+ this._placeholder = value;
100
+ this.stateChanges.next();
101
+ }
102
+ get empty() {
103
+ return !this.value;
104
+ }
105
+ /** @ignore */
106
+ focus(options) {
107
+ this._toggleButtonRef.nativeElement.focus(options);
108
+ }
109
+ /* Lifecycle Hooks */
110
+ /** @ignore */
111
+ ngDoCheck() {
112
+ const ngControl = this.ngControl;
113
+ if (!ngControl) {
114
+ return;
115
+ }
116
+ if (this._previousControl !== ngControl.control) {
117
+ if (this._previousControl !== undefined &&
118
+ ngControl.disabled !== null &&
119
+ ngControl.disabled !== this.disabled) {
120
+ this.disabled = ngControl?.disabled;
121
+ }
122
+ this._previousControl = ngControl.control;
123
+ }
124
+ this.updateErrorState();
125
+ }
126
+ /** @ignore */
127
+ ngOnChanges(changes) {
128
+ // Managing disabled state is handled via the `mixinDisabled` mixin/generator, but we still need to signal
129
+ // to the parent form field so it can run change detection when disabled state is changed.
130
+ if (changes['disabled']) {
131
+ this.stateChanges.next();
132
+ }
133
+ }
134
+ /** @ignore */
135
+ ngOnDestroy() {
136
+ this.stateChanges.complete();
137
+ }
138
+ /* ControlValueAccessor */
139
+ /** @ignore */
140
+ writeValue(value) {
141
+ this.value = value;
142
+ this._changeDetector.markForCheck();
143
+ }
144
+ /** @ignore */
145
+ registerOnChange(fn) {
146
+ this._cvaOnChange = fn;
147
+ }
148
+ /** @ignore */
149
+ registerOnTouched(fn) {
150
+ this._cvaOnTouched = fn;
151
+ }
152
+ /** @ignore */
153
+ setDisabledState(isDisabled) {
154
+ this.disabled = isDisabled;
155
+ this._changeDetector.markForCheck();
156
+ }
157
+ /* ImpdcFormFieldControl */
158
+ get value() {
159
+ return this._value;
160
+ }
161
+ set value(value) {
162
+ const newValue = (value && this.iconOptions.find(opt => opt === value)) || null;
163
+ if (newValue !== this._value) {
164
+ this._value = newValue;
165
+ this.stateChanges.next();
166
+ }
167
+ }
168
+ get id() {
169
+ return this._id;
170
+ }
171
+ set id(value) {
172
+ this._id = value || this._uid;
173
+ this.stateChanges.next();
174
+ }
175
+ /**
176
+ * Used to set requiredness of control in a template-based manner;
177
+ * not necessary when using the Angular reactive forms API and `required` validator.
178
+ *
179
+ * @default false
180
+ */
181
+ get required() {
182
+ return (this._required ??
183
+ this.ngControl?.control?.hasValidator(Validators.required) ??
184
+ false);
185
+ }
186
+ set required(value) {
187
+ this._required = coerceBooleanPropertyValue(value);
188
+ this.stateChanges.next();
189
+ }
190
+ get focused() {
191
+ return this._focused || this._dropdownOpen;
192
+ }
193
+ /* Internals */
194
+ handleOpenChange(isOpen) {
195
+ this._dropdownOpen = isOpen;
196
+ this.searchControl.reset();
197
+ if (isOpen) {
198
+ this._onFocus();
199
+ }
200
+ else {
201
+ this._onBlur();
202
+ }
203
+ this.stateChanges.next();
204
+ }
205
+ selectIcon(iconName) {
206
+ if (iconName !== this.value) {
207
+ this.value = iconName;
208
+ this.valueChange.emit(this.value);
209
+ this._cvaOnChange(this.value);
210
+ this.selectionChange.emit(this._buildChangeEvent(this.value));
211
+ this._changeDetector.markForCheck();
212
+ }
213
+ if (this._dropdownOpen) {
214
+ this.focus();
215
+ }
216
+ }
217
+ _onFocus() {
218
+ if (!this.disabled) {
219
+ this._focused = true;
220
+ this.stateChanges.next();
221
+ }
222
+ }
223
+ /**
224
+ * Calls the CVA touched callback only if the dropdown is closed.
225
+ */
226
+ _onBlur() {
227
+ this._focused = false;
228
+ if (!this.disabled && !this._dropdownOpen) {
229
+ this._cvaOnTouched();
230
+ this._changeDetector.markForCheck();
231
+ this.stateChanges.next();
232
+ }
233
+ }
234
+ _buildChangeEvent(value) {
235
+ return new ImpdcSelectIconChange(this, value);
236
+ }
237
+ }
238
+ SelectIconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SelectIconComponent, 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.Component });
239
+ SelectIconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: SelectIconComponent, selector: "impdc-select-icon", inputs: { disabled: "disabled", tabIndex: "tabIndex", allowSearch: "allowSearch", iconOptions: "iconOptions", showText: "showText", showSelectedText: "showSelectedText", placeholder: "placeholder", errorStateMatcher: "errorStateMatcher", value: "value", id: "id", required: "required" }, outputs: { selectionChange: "selectionChange", valueChange: "valueChange" }, host: { listeners: { "focus": "_onFocus(); focus()" }, properties: { "attr.id": "id", "attr.tabindex": "tabIndex", "attr.aria-required": "required.toString()", "attr.aria-disabled": "disabled.toString()", "attr.aria-invalid": "errorState", "class.form-select": "true", "class.is-invalid": "errorState", "class.impdc-form-field-control": "true", "class.impdc-select-icon--required": "required", "class.impdc-select-icon--disabled": "disabled", "class.impdc-select-icon--invalid": "errorState", "class.impdc-select-icon--empty": "empty" }, classAttribute: "impdc-select-icon" }, providers: [
240
+ {
241
+ provide: ImpdcFormFieldControl,
242
+ useExisting: SelectIconComponent
243
+ }
244
+ ], viewQueries: [{ propertyName: "_toggleButtonRef", first: true, predicate: ["toggleButton"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\n ngbDropdown\n autoClose=\"outside\"\n container=\"body\"\n dropdownClass=\"impartner-hex\"\n (openChange)=\"handleOpenChange($event)\"\n class=\"w-100\">\n <button\n #toggleButton\n class=\"impdc-select-icon--toggle btn border-0 text-start\"\n type=\"button\"\n role=\"combobox\"\n [disabled]=\"disabled\"\n ngbDropdownToggle>\n <ng-container [ngSwitch]=\"empty\">\n <span\n class=\"impdc-select-icon--text impdc-select-icon--placeholder\"\n *ngSwitchCase=\"true\">\n {{ placeholder }}\n </span>\n <div\n class=\"impdc-select-icon--text impdc-select-icon--value-text\"\n *ngSwitchCase=\"false\">\n <i class=\"fas fa-{{ value }}\"></i>\n <span *ngIf=\"showSelectedText\" class=\"ms-2\">{{ value }}</span>\n </div>\n </ng-container>\n </button>\n <div ngbDropdownMenu class=\"select-icon-dropdown-menu\" tabindex=\"-1\">\n <div *ngIf=\"allowSearch\" class=\"select-icon-search\">\n <impdc-form-field>\n <span impdcTextPrefix><i class=\"fas fa-search\"></i></span>\n <input\n impdcInput\n [formControl]=\"searchControl\"\n class=\"select-icon-search-input\"\n type=\"search\" />\n </impdc-form-field>\n </div>\n <div class=\"select-icon-grid\">\n <button\n *ngFor=\"let iconName of filteredOptions$ | async\"\n type=\"button\"\n (click)=\"selectIcon(iconName)\"\n class=\"icon-option\"\n [class.selected]=\"value === iconName\"\n [title]=\"iconName\"\n [attr.aria-labelledby]=\"showText ? id + '_' + iconName : null\">\n <div class=\"icon-container\">\n <i class=\"fs-2xl fas fa-{{ iconName }}\"></i>\n </div>\n <div\n id=\"{{ id }}_{{ iconName }}\"\n class=\"icon-label\"\n [class.sr-only]=\"!showText\">\n {{ iconName }}\n </div>\n </button>\n </div>\n </div>\n</div>\n", styles: [":host{padding:0!important;position:relative}:host.impdc-select-icon--disabled{background-color:var(--impd-color-gray-100)}.impdc-select-icon--toggle{font-weight:inherit;padding-right:3.6rem;-webkit-user-select:none;user-select:none;width:100%}:host-context(.is-invalid) .impdc-select-icon--toggle{padding-right:6.6rem}.impdc-select-icon--text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.select-icon-dropdown-menu{background-color:var(--impd-color-white);color:var(--impd-color-gray-600);max-width:51.2rem;min-width:32rem;overflow:hidden;width:100%}.select-icon-search{margin:var(--impd-size-2);font-size:var(--impd-font-size-sm)}.select-icon-grid{display:grid;align-items:start;grid-template-columns:repeat(auto-fit,minmax(4.8rem,1fr));gap:var(--impd-size-4);width:100%;max-height:var(--impd-size-40);overflow-y:auto;overflow-x:hidden;padding:var(--impd-size-4);-webkit-user-select:none;user-select:none}button[ngbDropdownToggle].dropdown-toggle:after{display:none}.icon-option{padding:0;background:unset;border:none}.icon-option:focus{outline:0}.icon-container{height:4rem;width:4rem;margin-left:auto;margin-right:auto;display:flex;align-items:center;justify-content:center;border-radius:50%;justify-items:center}.selected>.icon-container,:hover>.icon-container,:focus>.icon-container{background-color:var(--impartner-hex-primary);color:var(--impartner-hex-white)}.icon-label{text-align:center;font-size:1rem}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.NgbDropdown, selector: "[ngbDropdown]", inputs: ["autoClose", "dropdownClass", "open", "placement", "popperOptions", "container", "display"], outputs: ["openChange"], exportAs: ["ngbDropdown"] }, { kind: "directive", type: i4.NgbDropdownToggle, selector: "[ngbDropdownToggle]" }, { kind: "directive", type: i4.NgbDropdownMenu, selector: "[ngbDropdownMenu]" }, { kind: "component", type: i5.FormFieldComponent, selector: "impdc-form-field", exportAs: ["impdcFormField"] }, { kind: "directive", type: i6.InputDirective, selector: "input[impdcInput], textarea[impdcInput], select[impdcNativeSelect]", inputs: ["disabled", "id", "type", "required", "readonly", "errorStateMatcher", "value"], exportAs: ["impdcInput"] }, { kind: "directive", type: i7.PrefixDirective, selector: "[impdcPrefix], [impdcTextPrefix]", inputs: ["impdcTextPrefix"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
245
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SelectIconComponent, decorators: [{
246
+ type: Component,
247
+ args: [{ selector: 'impdc-select-icon', inputs: ['disabled', 'tabIndex'], changeDetection: ChangeDetectionStrategy.OnPush, host: {
248
+ class: 'impdc-select-icon',
249
+ '[attr.id]': 'id',
250
+ '[attr.tabindex]': 'tabIndex',
251
+ '[attr.aria-required]': 'required.toString()',
252
+ '[attr.aria-disabled]': 'disabled.toString()',
253
+ '[attr.aria-invalid]': 'errorState',
254
+ '[class.form-select]': 'true',
255
+ '[class.is-invalid]': 'errorState',
256
+ '[class.impdc-form-field-control]': 'true',
257
+ '[class.impdc-select-icon--required]': 'required',
258
+ '[class.impdc-select-icon--disabled]': 'disabled',
259
+ '[class.impdc-select-icon--invalid]': 'errorState',
260
+ '[class.impdc-select-icon--empty]': 'empty',
261
+ '(focus)': '_onFocus(); focus()'
262
+ }, providers: [
263
+ {
264
+ provide: ImpdcFormFieldControl,
265
+ useExisting: SelectIconComponent
266
+ }
267
+ ], template: "<div\n ngbDropdown\n autoClose=\"outside\"\n container=\"body\"\n dropdownClass=\"impartner-hex\"\n (openChange)=\"handleOpenChange($event)\"\n class=\"w-100\">\n <button\n #toggleButton\n class=\"impdc-select-icon--toggle btn border-0 text-start\"\n type=\"button\"\n role=\"combobox\"\n [disabled]=\"disabled\"\n ngbDropdownToggle>\n <ng-container [ngSwitch]=\"empty\">\n <span\n class=\"impdc-select-icon--text impdc-select-icon--placeholder\"\n *ngSwitchCase=\"true\">\n {{ placeholder }}\n </span>\n <div\n class=\"impdc-select-icon--text impdc-select-icon--value-text\"\n *ngSwitchCase=\"false\">\n <i class=\"fas fa-{{ value }}\"></i>\n <span *ngIf=\"showSelectedText\" class=\"ms-2\">{{ value }}</span>\n </div>\n </ng-container>\n </button>\n <div ngbDropdownMenu class=\"select-icon-dropdown-menu\" tabindex=\"-1\">\n <div *ngIf=\"allowSearch\" class=\"select-icon-search\">\n <impdc-form-field>\n <span impdcTextPrefix><i class=\"fas fa-search\"></i></span>\n <input\n impdcInput\n [formControl]=\"searchControl\"\n class=\"select-icon-search-input\"\n type=\"search\" />\n </impdc-form-field>\n </div>\n <div class=\"select-icon-grid\">\n <button\n *ngFor=\"let iconName of filteredOptions$ | async\"\n type=\"button\"\n (click)=\"selectIcon(iconName)\"\n class=\"icon-option\"\n [class.selected]=\"value === iconName\"\n [title]=\"iconName\"\n [attr.aria-labelledby]=\"showText ? id + '_' + iconName : null\">\n <div class=\"icon-container\">\n <i class=\"fs-2xl fas fa-{{ iconName }}\"></i>\n </div>\n <div\n id=\"{{ id }}_{{ iconName }}\"\n class=\"icon-label\"\n [class.sr-only]=\"!showText\">\n {{ iconName }}\n </div>\n </button>\n </div>\n </div>\n</div>\n", styles: [":host{padding:0!important;position:relative}:host.impdc-select-icon--disabled{background-color:var(--impd-color-gray-100)}.impdc-select-icon--toggle{font-weight:inherit;padding-right:3.6rem;-webkit-user-select:none;user-select:none;width:100%}:host-context(.is-invalid) .impdc-select-icon--toggle{padding-right:6.6rem}.impdc-select-icon--text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.select-icon-dropdown-menu{background-color:var(--impd-color-white);color:var(--impd-color-gray-600);max-width:51.2rem;min-width:32rem;overflow:hidden;width:100%}.select-icon-search{margin:var(--impd-size-2);font-size:var(--impd-font-size-sm)}.select-icon-grid{display:grid;align-items:start;grid-template-columns:repeat(auto-fit,minmax(4.8rem,1fr));gap:var(--impd-size-4);width:100%;max-height:var(--impd-size-40);overflow-y:auto;overflow-x:hidden;padding:var(--impd-size-4);-webkit-user-select:none;user-select:none}button[ngbDropdownToggle].dropdown-toggle:after{display:none}.icon-option{padding:0;background:unset;border:none}.icon-option:focus{outline:0}.icon-container{height:4rem;width:4rem;margin-left:auto;margin-right:auto;display:flex;align-items:center;justify-content:center;border-radius:50%;justify-items:center}.selected>.icon-container,:hover>.icon-container,:focus>.icon-container{background-color:var(--impartner-hex-primary);color:var(--impartner-hex-white)}.icon-label{text-align:center;font-size:1rem}\n"] }]
268
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.ErrorStateMatcher }, { type: undefined, decorators: [{
269
+ type: Optional
270
+ }, {
271
+ type: Inject,
272
+ args: [IMPDC_FORM_ROOT]
273
+ }] }, { type: i2.NgForm, decorators: [{
274
+ type: Optional
275
+ }] }, { type: i2.FormGroupDirective, decorators: [{
276
+ type: Optional
277
+ }] }, { type: i2.NgControl, decorators: [{
278
+ type: Self
279
+ }, {
280
+ type: Optional
281
+ }] }]; }, propDecorators: { _toggleButtonRef: [{
282
+ type: ViewChild,
283
+ args: ['toggleButton', { static: true, read: ElementRef }]
284
+ }], allowSearch: [{
285
+ type: Input
286
+ }], iconOptions: [{
287
+ type: Input
288
+ }], showText: [{
289
+ type: Input
290
+ }], showSelectedText: [{
291
+ type: Input
292
+ }], placeholder: [{
293
+ type: Input
294
+ }], errorStateMatcher: [{
295
+ type: Input
296
+ }], selectionChange: [{
297
+ type: Output
298
+ }], valueChange: [{
299
+ type: Output
300
+ }], value: [{
301
+ type: Input
302
+ }], id: [{
303
+ type: Input
304
+ }], required: [{
305
+ type: Input
306
+ }] } });
307
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-icon.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/select-icon/select-icon.component.ts","../../../../../../projects/design-components/src/lib/select-icon/select-icon.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/no-conflicting-lifecycle */\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Output,\n  Self,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  FormGroupDirective,\n  NgControl,\n  NgForm,\n  Validators\n} from '@angular/forms';\nimport { nanoid } from 'nanoid';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  debounceTime,\n  distinctUntilChanged,\n  map,\n  Observable,\n  startWith,\n  Subject\n} from 'rxjs';\nimport { FontAwesomeIcons } from '../../constants';\nimport { BooleanInput, coerceBooleanPropertyValue } from '../../utilities';\nimport {\n  ErrorStateMatcher,\n  ICanUpdateErrorState,\n  IHasErrorState,\n  ImpdcFormFieldControl,\n  ImpdcFormRoot,\n  IMPDC_FORM_ROOT,\n  mixinDisabled,\n  mixinErrorState,\n  mixinTabIndex\n} from '../form-field';\n\nexport class ImpdcSelectIconChange {\n  constructor(public source: SelectIconComponent, public value: any) {}\n}\n\nconst _SelectIconComponentBase = mixinTabIndex(\n  mixinDisabled(\n    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\n/**\n * The `SelectIconComponent` (`<impdc-select-icon`) is a select dropdown with search that shows all standard icons from Bootstrap 5.\n * To use, import `SelectIconModule` or another module that imports and exports that module from `@impartner/design-components`.\n */\n@Component({\n  selector: 'impdc-select-icon',\n  templateUrl: './select-icon.component.html',\n  styleUrls: ['./select-icon.component.scss'],\n  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property\n  inputs: ['disabled', 'tabIndex'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    class: 'impdc-select-icon',\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'tabIndex',\n    '[attr.aria-required]': 'required.toString()',\n    '[attr.aria-disabled]': 'disabled.toString()',\n    '[attr.aria-invalid]': 'errorState',\n    '[class.form-select]': 'true',\n    '[class.is-invalid]': 'errorState',\n    '[class.impdc-form-field-control]': 'true',\n    '[class.impdc-select-icon--required]': 'required',\n    '[class.impdc-select-icon--disabled]': 'disabled',\n    '[class.impdc-select-icon--invalid]': 'errorState',\n    '[class.impdc-select-icon--empty]': 'empty',\n    '(focus)': '_onFocus(); focus()'\n  },\n  providers: [\n    {\n      provide: ImpdcFormFieldControl,\n      useExisting: SelectIconComponent\n    }\n  ]\n})\nexport class SelectIconComponent\n  extends _SelectIconComponentBase\n  implements\n    ControlValueAccessor,\n    ImpdcFormFieldControl<string | null>,\n    ICanUpdateErrorState,\n    IHasErrorState,\n    DoCheck,\n    OnChanges,\n    OnDestroy\n{\n  @ViewChild('toggleButton', { static: true, read: ElementRef })\n  protected _toggleButtonRef!: ElementRef<HTMLButtonElement>;\n\n  protected readonly filteredOptions$: Observable<string[]>;\n  protected readonly searchControl = new FormControl<string>('');\n  protected readonly _uid = `impdc-select-icon-${nanoid()}`;\n  protected _dropdownOpen = false;\n\n  private readonly _iconOptionsSubject = new BehaviorSubject<readonly string[]>(\n    FontAwesomeIcons\n  );\n  private _previousControl?: AbstractControl | null;\n  private _cvaOnChange: (value: any) => void = () => {};\n  private _cvaOnTouched = () => {};\n\n  /**\n   * Set whether or not an input field will appear for searching and\n   * filtering icon options.\n   * @default true\n   */\n  @Input()\n  public allowSearch: boolean;\n\n  public get iconOptions(): string[] {\n    return [...this._iconOptionsSubject.value];\n  }\n\n  /**\n   * Set to override the default set of FontAwesome icon options.\n   */\n  @Input()\n  public set iconOptions(iconOptions: string[]) {\n    if (iconOptions) {\n      this._iconOptionsSubject.next([...iconOptions]);\n    }\n  }\n\n  /**\n   * Set whether or not to show the icon names as labels for icon options.\n   * @default true\n   */\n  @Input()\n  public showText: boolean;\n\n  /**\n   * Set whether or not to show the name of the selected icon inside the control.\n   * @default true\n   */\n  @Input()\n  public showSelectedText: boolean;\n\n  /**\n   * The placeholder text that will be displayed when no selection has been made.\n   *\n   * @default \\- Select -\n   */\n  @Input()\n  public get placeholder(): string {\n    return this._placeholder;\n  }\n  public set placeholder(value: string) {\n    this._placeholder = value;\n    this.stateChanges.next();\n  }\n  private _placeholder: string = '- Select -';\n\n  @Input()\n  public override errorStateMatcher!: ErrorStateMatcher;\n\n  /** Events fire when selection has been changed by the user. */\n  @Output()\n  public readonly selectionChange: EventEmitter<ImpdcSelectIconChange> = new EventEmitter<ImpdcSelectIconChange>();\n\n  /**\n   * Events fire when raw value of select changes. Mainly exists to handle\n   * two-way binding of `value` input property.\n   * @ignore\n   */\n  @Output()\n  public readonly valueChange = new EventEmitter<string | null>();\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\n  ) {\n    super(\n      _defaultErrorStateMatcher,\n      _formRoot,\n      _parentForm,\n      _parentFormGroup,\n      ngControl\n    );\n\n    this.allowSearch = false;\n    this.showText = true;\n    this.showSelectedText = true;\n\n    const debouncedSearchValues = this.searchControl.valueChanges.pipe(\n      startWith(''),\n      debounceTime(200),\n      distinctUntilChanged()\n    );\n    this.filteredOptions$ = combineLatest([\n      debouncedSearchValues,\n      this._iconOptionsSubject.asObservable()\n    ]).pipe(\n      map(([searchTerm, iconOptions]) => {\n        if (!searchTerm) {\n          return [...iconOptions];\n        }\n\n        const searchTermLowerCase = searchTerm.toLowerCase();\n        return iconOptions.filter(\n          option => option.toLowerCase().indexOf(searchTermLowerCase) > -1\n        );\n      })\n    );\n\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    this.id = this.id;\n  }\n\n  public get empty(): boolean {\n    return !this.value;\n  }\n\n  /** @ignore */\n  public focus(options?: FocusOptions): void {\n    this._toggleButtonRef.nativeElement.focus(options);\n  }\n\n  /* Lifecycle Hooks */\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  }\n\n  /** @ignore */\n  public ngOnChanges(changes: SimpleChanges): void {\n    // Managing disabled state is handled via the `mixinDisabled` mixin/generator, but we still need to signal\n    // to the parent form field so it can run change detection when disabled state is changed.\n    if (changes['disabled']) {\n      this.stateChanges.next();\n    }\n  }\n\n  /** @ignore */\n  public ngOnDestroy(): void {\n    this.stateChanges.complete();\n  }\n\n  /* ControlValueAccessor */\n\n  /** @ignore */\n  public writeValue(value: string): 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  /* ImpdcFormFieldControl */\n\n  @Input()\n  public get value(): string | null {\n    return this._value;\n  }\n  public set value(value: string | null) {\n    const newValue =\n      (value && this.iconOptions.find(opt => opt === value)) || null;\n\n    if (newValue !== this._value) {\n      this._value = newValue;\n      this.stateChanges.next();\n    }\n  }\n  private _value: string | null = null;\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  /**\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   * @default false\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 get focused(): boolean {\n    return this._focused || this._dropdownOpen;\n  }\n  protected _focused = false;\n\n  public readonly controlType: string = 'impdc-select-icon';\n  public readonly supportsAffixes: boolean = true;\n\n  /* Internals */\n\n  protected handleOpenChange(isOpen: boolean): void {\n    this._dropdownOpen = isOpen;\n    this.searchControl.reset();\n\n    if (isOpen) {\n      this._onFocus();\n    } else {\n      this._onBlur();\n    }\n\n    this.stateChanges.next();\n  }\n\n  protected selectIcon(iconName: string): void {\n    if (iconName !== this.value) {\n      this.value = iconName;\n      this.valueChange.emit(this.value);\n      this._cvaOnChange(this.value);\n      this.selectionChange.emit(this._buildChangeEvent(this.value));\n      this._changeDetector.markForCheck();\n    }\n\n    if (this._dropdownOpen) {\n      this.focus();\n    }\n  }\n\n  protected _onFocus(): void {\n    if (!this.disabled) {\n      this._focused = true;\n      this.stateChanges.next();\n    }\n  }\n\n  /**\n   * Calls the CVA touched callback only if the dropdown is closed.\n   */\n  protected _onBlur(): void {\n    this._focused = false;\n\n    if (!this.disabled && !this._dropdownOpen) {\n      this._cvaOnTouched();\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    }\n  }\n\n  private _buildChangeEvent(value: string | null): ImpdcSelectIconChange {\n    return new ImpdcSelectIconChange(this, value);\n  }\n}\n","<div\n  ngbDropdown\n  autoClose=\"outside\"\n  container=\"body\"\n  dropdownClass=\"impartner-hex\"\n  (openChange)=\"handleOpenChange($event)\"\n  class=\"w-100\">\n  <button\n    #toggleButton\n    class=\"impdc-select-icon--toggle btn border-0 text-start\"\n    type=\"button\"\n    role=\"combobox\"\n    [disabled]=\"disabled\"\n    ngbDropdownToggle>\n    <ng-container [ngSwitch]=\"empty\">\n      <span\n        class=\"impdc-select-icon--text impdc-select-icon--placeholder\"\n        *ngSwitchCase=\"true\">\n        {{ placeholder }}\n      </span>\n      <div\n        class=\"impdc-select-icon--text impdc-select-icon--value-text\"\n        *ngSwitchCase=\"false\">\n        <i class=\"fas fa-{{ value }}\"></i>\n        <span *ngIf=\"showSelectedText\" class=\"ms-2\">{{ value }}</span>\n      </div>\n    </ng-container>\n  </button>\n  <div ngbDropdownMenu class=\"select-icon-dropdown-menu\" tabindex=\"-1\">\n    <div *ngIf=\"allowSearch\" class=\"select-icon-search\">\n      <impdc-form-field>\n        <span impdcTextPrefix><i class=\"fas fa-search\"></i></span>\n        <input\n          impdcInput\n          [formControl]=\"searchControl\"\n          class=\"select-icon-search-input\"\n          type=\"search\" />\n      </impdc-form-field>\n    </div>\n    <div class=\"select-icon-grid\">\n      <button\n        *ngFor=\"let iconName of filteredOptions$ | async\"\n        type=\"button\"\n        (click)=\"selectIcon(iconName)\"\n        class=\"icon-option\"\n        [class.selected]=\"value === iconName\"\n        [title]=\"iconName\"\n        [attr.aria-labelledby]=\"showText ? id + '_' + iconName : null\">\n        <div class=\"icon-container\">\n          <i class=\"fs-2xl fas fa-{{ iconName }}\"></i>\n        </div>\n        <div\n          id=\"{{ id }}_{{ iconName }}\"\n          class=\"icon-label\"\n          [class.sr-only]=\"!showText\">\n          {{ iconName }}\n        </div>\n      </button>\n    </div>\n  </div>\n</div>\n"]}