@impartner/design-components 1.2.0 → 2.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (291) hide show
  1. package/README.md +5 -4
  2. package/constants/fontawesome-icons.d.ts +2 -2
  3. package/{esm2020 → esm2022}/constants/fontawesome-icons.mjs +1 -1
  4. package/{esm2020 → esm2022}/lib/alert/alert.component.mjs +4 -4
  5. package/{esm2020 → esm2022}/lib/alert/alert.module.mjs +5 -5
  6. package/{esm2020 → esm2022}/lib/avatar/avatar.component.mjs +4 -4
  7. package/{esm2020 → esm2022}/lib/avatar/avatar.module.mjs +5 -5
  8. package/{esm2020 → esm2022}/lib/avatar-group/avatar-group.component.mjs +4 -4
  9. package/{esm2020 → esm2022}/lib/avatar-group/avatar-group.module.mjs +5 -5
  10. package/esm2022/lib/backdrop/backdrop.component.mjs +52 -0
  11. package/{esm2020 → esm2022}/lib/backdrop/backdrop.module.mjs +6 -6
  12. package/esm2022/lib/badge/badge.component.mjs +105 -0
  13. package/{esm2020 → esm2022}/lib/badge/badge.module.mjs +6 -6
  14. package/{esm2020 → esm2022}/lib/badge/types/badge-size.mjs +1 -1
  15. package/{esm2020 → esm2022}/lib/branding/branded.directive.mjs +4 -4
  16. package/{esm2020 → esm2022}/lib/branding/branding.module.mjs +6 -6
  17. package/{esm2020 → esm2022}/lib/breadcrumb/breadcrumb-item.component.mjs +6 -6
  18. package/{esm2020 → esm2022}/lib/breadcrumb/breadcrumb.component.mjs +5 -5
  19. package/{esm2020 → esm2022}/lib/breadcrumb/breadcrumb.module.mjs +5 -5
  20. package/{esm2020 → esm2022}/lib/button/button.component.mjs +4 -4
  21. package/{esm2020 → esm2022}/lib/button/button.module.mjs +6 -6
  22. package/{esm2020 → esm2022}/lib/button-group/button-group.component.mjs +4 -4
  23. package/{esm2020 → esm2022}/lib/button-group/button-group.module.mjs +6 -6
  24. package/{esm2020 → esm2022}/lib/card-heading/card-heading.component.mjs +5 -5
  25. package/{esm2020 → esm2022}/lib/card-heading/card-heading.module.mjs +6 -6
  26. package/esm2022/lib/data-card/data-card.component.mjs +123 -0
  27. package/esm2022/lib/data-card/data-card.module.mjs +21 -0
  28. package/{esm2020 → esm2022}/lib/design-components.module.mjs +61 -61
  29. package/{esm2020 → esm2022}/lib/dropdown/components/dropdown-item/dropdown-item.component.mjs +4 -4
  30. package/esm2022/lib/dropdown/dropdown.component.mjs +143 -0
  31. package/{esm2020 → esm2022}/lib/dropdown/dropdown.module.mjs +6 -6
  32. package/{esm2020 → esm2022}/lib/file-upload/directives/file-drop.directive.mjs +4 -4
  33. package/{esm2020 → esm2022}/lib/file-upload/file-upload.component.mjs +30 -30
  34. package/{esm2020 → esm2022}/lib/file-upload/file-upload.module.mjs +8 -8
  35. package/{esm2020 → esm2022}/lib/file-upload/pipes/human-readable-byte-size.pipe.mjs +4 -4
  36. package/{esm2020 → esm2022}/lib/form-field/controls/checkbox/checkbox.component.mjs +49 -49
  37. package/{esm2020 → esm2022}/lib/form-field/controls/checkbox/checkbox.module.mjs +5 -5
  38. package/esm2022/lib/form-field/controls/input/input.directive.mjs +233 -0
  39. package/esm2022/lib/form-field/controls/radio/radio-button/radio-button.component.mjs +260 -0
  40. package/esm2022/lib/form-field/controls/radio/radio-group/radio-group.directive.mjs +289 -0
  41. package/{esm2020 → esm2022}/lib/form-field/controls/radio/radio.module.mjs +5 -5
  42. package/esm2022/lib/form-field/controls/select/option/select-option.component.mjs +139 -0
  43. package/esm2022/lib/form-field/controls/select/select-model.mjs +150 -0
  44. package/esm2022/lib/form-field/controls/select/select.component.mjs +522 -0
  45. package/{esm2020 → esm2022}/lib/form-field/controls/select/select.module.mjs +9 -9
  46. package/{esm2020 → esm2022}/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.mjs +4 -4
  47. package/esm2022/lib/form-field/controls/shared/toggle/toggle.component.mjs +96 -0
  48. package/{esm2020 → esm2022}/lib/form-field/controls/shared/toggle/toggle.module.mjs +6 -6
  49. package/{esm2020 → esm2022}/lib/form-field/directives/corner-hint.directive.mjs +4 -4
  50. package/{esm2020 → esm2022}/lib/form-field/directives/error.directive.mjs +4 -4
  51. package/esm2022/lib/form-field/directives/form-root.directive.mjs +91 -0
  52. package/{esm2020 → esm2022}/lib/form-field/directives/hint.directive.mjs +4 -4
  53. package/{esm2020 → esm2022}/lib/form-field/directives/label.directive.mjs +4 -4
  54. package/{esm2020 → esm2022}/lib/form-field/directives/prefix.directive.mjs +4 -4
  55. package/{esm2020 → esm2022}/lib/form-field/directives/suffix.directive.mjs +4 -4
  56. package/{esm2020 → esm2022}/lib/form-field/form-field.component.mjs +11 -11
  57. package/{esm2020 → esm2022}/lib/form-field/impdc-forms.module.mjs +28 -28
  58. package/{esm2020 → esm2022}/lib/form-field/services/error-state-matcher.service.mjs +7 -7
  59. package/{esm2020 → esm2022}/lib/form-field/services/unique-selection-dispatcher.service.mjs +4 -4
  60. package/{esm2020 → esm2022}/lib/form-field/shared/disabled.mixin.mjs +5 -5
  61. package/esm2022/lib/form-field/shared/error-state.mixin.mjs +24 -0
  62. package/{esm2020 → esm2022}/lib/form-field/shared/form-field-control.mjs +4 -4
  63. package/{esm2020 → esm2022}/lib/form-field/shared/tab-index.mixin.mjs +6 -6
  64. package/{esm2020 → esm2022}/lib/icon/icon.component.mjs +5 -5
  65. package/{esm2020 → esm2022}/lib/icon/icon.module.mjs +6 -6
  66. package/esm2022/lib/modal/modal.component.mjs +260 -0
  67. package/{esm2020 → esm2022}/lib/modal/modal.module.mjs +14 -14
  68. package/{esm2020 → esm2022}/lib/modal/types/modal-component-sizes.mjs +1 -1
  69. package/{esm2020 → esm2022}/lib/modal/types/modal-theme.mjs +1 -1
  70. package/esm2022/lib/pagination/pagination.component.mjs +176 -0
  71. package/{esm2020 → esm2022}/lib/pagination/pagination.module.mjs +16 -16
  72. package/{esm2020 → esm2022}/lib/progress-bar/progress-bar.component.mjs +5 -5
  73. package/{esm2020 → esm2022}/lib/progress-bar/progress-bar.module.mjs +5 -5
  74. package/esm2022/lib/scrollable/scrollable.component.mjs +186 -0
  75. package/{esm2020 → esm2022}/lib/scrollable/scrollable.module.mjs +6 -6
  76. package/esm2022/lib/select-icon/select-icon.component.mjs +308 -0
  77. package/{esm2020 → esm2022}/lib/select-icon/select-icon.module.mjs +13 -13
  78. package/{esm2020 → esm2022}/lib/size-detection/directive/size-detector.directive.mjs +5 -5
  79. package/{esm2020 → esm2022}/lib/size-detection/size-detection.module.mjs +5 -5
  80. package/{esm2020 → esm2022}/lib/spinner/spinner.component.mjs +4 -4
  81. package/{esm2020 → esm2022}/lib/spinner/spinner.module.mjs +5 -5
  82. package/{esm2020 → esm2022}/lib/table/components/bulk-actions/bulk-actions.component.mjs +4 -4
  83. package/{esm2020 → esm2022}/lib/table/components/column-heading/column-heading.component.mjs +4 -4
  84. package/{esm2020 → esm2022}/lib/table/components/index.mjs +2 -1
  85. package/esm2022/lib/table/components/row-actions/row-actions.component.mjs +61 -0
  86. package/esm2022/lib/table/containers/table.component.mjs +403 -0
  87. package/esm2022/lib/table/directives/table-inject-component.directive.mjs +46 -0
  88. package/{esm2020 → esm2022}/lib/table/directives/table.directive.mjs +4 -4
  89. package/{esm2020 → esm2022}/lib/table/enumerations/table-column-type.mjs +2 -1
  90. package/{esm2020 → esm2022}/lib/table/helpers/table-theme.helper.mjs +3 -3
  91. package/esm2022/lib/table/interfaces/index.mjs +11 -0
  92. package/esm2022/lib/table/interfaces/table-column-defs.type.mjs +2 -0
  93. package/esm2022/lib/table/interfaces/table-row-action-payload.interface.mjs +2 -0
  94. package/esm2022/lib/table/interfaces/table-row-action.interface.mjs +2 -0
  95. package/esm2022/lib/table/table.module.mjs +96 -0
  96. package/{esm2020 → esm2022}/lib/text-highlight/text-highlight.component.mjs +6 -6
  97. package/{esm2020 → esm2022}/lib/text-highlight/text-highlight.module.mjs +6 -6
  98. package/{esm2020 → esm2022}/services/index.mjs +1 -1
  99. package/esm2022/services/interaction.service.mjs +88 -0
  100. package/{esm2020 → esm2022}/types/component-theme.mjs +1 -1
  101. package/{fesm2020 → fesm2022}/impartner-design-components.mjs +1197 -1032
  102. package/fesm2022/impartner-design-components.mjs.map +1 -0
  103. package/lib/alert/alert.component.d.ts +1 -1
  104. package/lib/alert/theme/alert-theme.d.ts +1 -1
  105. package/lib/avatar/avatar.component.d.ts +1 -1
  106. package/lib/avatar-group/avatar-group.component.d.ts +1 -1
  107. package/lib/backdrop/backdrop.component.d.ts +9 -6
  108. package/lib/badge/badge.component.d.ts +3 -2
  109. package/lib/badge/types/badge-icon.d.ts +1 -1
  110. package/lib/badge/types/badge-size.d.ts +1 -1
  111. package/lib/branding/branded.directive.d.ts +1 -1
  112. package/lib/breadcrumb/breadcrumb-item.component.d.ts +1 -1
  113. package/lib/breadcrumb/breadcrumb.component.d.ts +1 -1
  114. package/lib/button/button.component.d.ts +1 -1
  115. package/lib/button/themes/button-theme.d.ts +1 -1
  116. package/lib/button-group/button-group.component.d.ts +1 -1
  117. package/lib/card-heading/card-heading.component.d.ts +1 -1
  118. package/lib/data-card/data-card.component.d.ts +14 -18
  119. package/lib/data-card/data-card.module.d.ts +2 -1
  120. package/lib/dropdown/components/dropdown-item/dropdown-item.component.d.ts +1 -1
  121. package/lib/dropdown/dropdown.component.d.ts +6 -5
  122. package/lib/dropdown/types/dropdown-position.d.ts +1 -1
  123. package/lib/file-upload/directives/file-drop.directive.d.ts +1 -1
  124. package/lib/file-upload/file-upload.component.d.ts +1 -1
  125. package/lib/form-field/controls/checkbox/checkbox.component.d.ts +1 -1
  126. package/lib/form-field/controls/input/input.directive.d.ts +1 -1
  127. package/lib/form-field/controls/radio/radio-button/radio-button.component.d.ts +1 -1
  128. package/lib/form-field/controls/radio/radio-group/radio-group.directive.d.ts +1 -1
  129. package/lib/form-field/controls/select/option/select-option.component.d.ts +4 -4
  130. package/lib/form-field/controls/select/select.component.d.ts +1 -1
  131. package/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.d.ts +1 -1
  132. package/lib/form-field/controls/shared/toggle/toggle.component.d.ts +1 -1
  133. package/lib/form-field/directives/corner-hint.directive.d.ts +1 -1
  134. package/lib/form-field/directives/error.directive.d.ts +1 -1
  135. package/lib/form-field/directives/form-root.directive.d.ts +2 -2
  136. package/lib/form-field/directives/hint.directive.d.ts +1 -1
  137. package/lib/form-field/directives/label.directive.d.ts +1 -1
  138. package/lib/form-field/directives/prefix.directive.d.ts +1 -1
  139. package/lib/form-field/directives/suffix.directive.d.ts +1 -1
  140. package/lib/form-field/form-field.component.d.ts +1 -1
  141. package/lib/form-field/services/unique-selection-dispatcher.service.d.ts +1 -1
  142. package/lib/form-field/shared/constructors.type.d.ts +2 -2
  143. package/lib/form-field/shared/disabled.mixin.d.ts +1 -1
  144. package/lib/form-field/shared/error-state.mixin.d.ts +1 -1
  145. package/lib/form-field/shared/form-field-control.d.ts +1 -1
  146. package/lib/form-field/shared/tab-index.mixin.d.ts +1 -1
  147. package/lib/icon/icon.component.d.ts +1 -1
  148. package/lib/modal/modal.component.d.ts +17 -10
  149. package/lib/modal/types/modal-component-sizes.d.ts +1 -1
  150. package/lib/modal/types/modal-theme.d.ts +1 -1
  151. package/lib/pagination/pagination.component.d.ts +1 -1
  152. package/lib/progress-bar/progress-bar.component.d.ts +1 -1
  153. package/lib/scrollable/scrollable.component.d.ts +1 -1
  154. package/lib/select-icon/select-icon.component.d.ts +1 -1
  155. package/lib/size-detection/directive/size-detector.directive.d.ts +1 -1
  156. package/lib/spinner/spinner.component.d.ts +1 -1
  157. package/lib/table/components/bulk-actions/bulk-actions.component.d.ts +1 -1
  158. package/lib/table/components/column-heading/column-heading.component.d.ts +1 -1
  159. package/lib/table/components/index.d.ts +1 -0
  160. package/lib/table/components/row-actions/row-actions.component.d.ts +21 -0
  161. package/lib/table/containers/table.component.d.ts +12 -6
  162. package/lib/table/directives/table-inject-component.directive.d.ts +3 -3
  163. package/lib/table/directives/table.directive.d.ts +1 -1
  164. package/lib/table/enumerations/table-column-type.d.ts +2 -1
  165. package/lib/table/helpers/table-theme.helper.d.ts +4 -4
  166. package/lib/table/interfaces/custom-cell-renderer-components.type.d.ts +1 -1
  167. package/lib/table/interfaces/index.d.ts +3 -1
  168. package/lib/table/interfaces/{table-column-def.interface.d.ts → table-column-defs.type.d.ts} +8 -1
  169. package/lib/table/interfaces/table-row-action-payload.interface.d.ts +6 -0
  170. package/lib/table/interfaces/table-row-action.interface.d.ts +9 -0
  171. package/lib/table/interfaces/table-row-item.interface.d.ts +3 -3
  172. package/lib/table/table.module.d.ts +12 -10
  173. package/lib/text-highlight/text-highlight.component.d.ts +1 -1
  174. package/package.json +16 -22
  175. package/services/index.d.ts +1 -1
  176. package/services/interaction.service.d.ts +20 -10
  177. package/types/component-size.d.ts +2 -2
  178. package/types/component-theme.d.ts +1 -1
  179. package/utilities/boolean-props.d.ts +1 -1
  180. package/utilities/number-props.d.ts +1 -1
  181. package/esm2020/lib/backdrop/backdrop.component.mjs +0 -40
  182. package/esm2020/lib/badge/badge.component.mjs +0 -99
  183. package/esm2020/lib/data-card/data-card.component.mjs +0 -128
  184. package/esm2020/lib/data-card/data-card.module.mjs +0 -20
  185. package/esm2020/lib/dropdown/dropdown.component.mjs +0 -142
  186. package/esm2020/lib/form-field/controls/input/input.directive.mjs +0 -233
  187. package/esm2020/lib/form-field/controls/radio/radio-button/radio-button.component.mjs +0 -260
  188. package/esm2020/lib/form-field/controls/radio/radio-group/radio-group.directive.mjs +0 -289
  189. package/esm2020/lib/form-field/controls/select/option/select-option.component.mjs +0 -139
  190. package/esm2020/lib/form-field/controls/select/select-model.mjs +0 -150
  191. package/esm2020/lib/form-field/controls/select/select.component.mjs +0 -522
  192. package/esm2020/lib/form-field/controls/shared/toggle/toggle.component.mjs +0 -96
  193. package/esm2020/lib/form-field/directives/form-root.directive.mjs +0 -91
  194. package/esm2020/lib/form-field/shared/error-state.mixin.mjs +0 -24
  195. package/esm2020/lib/modal/modal.component.mjs +0 -187
  196. package/esm2020/lib/pagination/pagination.component.mjs +0 -176
  197. package/esm2020/lib/scrollable/scrollable.component.mjs +0 -186
  198. package/esm2020/lib/select-icon/select-icon.component.mjs +0 -308
  199. package/esm2020/lib/table/containers/table.component.mjs +0 -386
  200. package/esm2020/lib/table/directives/table-inject-component.directive.mjs +0 -46
  201. package/esm2020/lib/table/interfaces/index.mjs +0 -9
  202. package/esm2020/lib/table/interfaces/table-column-def.interface.mjs +0 -2
  203. package/esm2020/lib/table/table.module.mjs +0 -88
  204. package/esm2020/services/interaction.service.mjs +0 -81
  205. package/fesm2015/impartner-design-components.mjs +0 -9214
  206. package/fesm2015/impartner-design-components.mjs.map +0 -1
  207. package/fesm2020/impartner-design-components.mjs.map +0 -1
  208. /package/{esm2020 → esm2022}/constants/index.mjs +0 -0
  209. /package/{esm2020 → esm2022}/impartner-design-components.mjs +0 -0
  210. /package/{esm2020 → esm2022}/lib/alert/index.mjs +0 -0
  211. /package/{esm2020 → esm2022}/lib/alert/theme/alert-theme.mjs +0 -0
  212. /package/{esm2020 → esm2022}/lib/alert/theme/index.mjs +0 -0
  213. /package/{esm2020 → esm2022}/lib/avatar/index.mjs +0 -0
  214. /package/{esm2020 → esm2022}/lib/avatar-group/index.mjs +0 -0
  215. /package/{esm2020 → esm2022}/lib/backdrop/index.mjs +0 -0
  216. /package/{esm2020 → esm2022}/lib/badge/index.mjs +0 -0
  217. /package/{esm2020 → esm2022}/lib/badge/types/badge-icon.mjs +0 -0
  218. /package/{esm2020 → esm2022}/lib/badge/types/index.mjs +0 -0
  219. /package/{esm2020 → esm2022}/lib/branding/index.mjs +0 -0
  220. /package/{esm2020 → esm2022}/lib/breadcrumb/index.mjs +0 -0
  221. /package/{esm2020 → esm2022}/lib/button/index.mjs +0 -0
  222. /package/{esm2020 → esm2022}/lib/button/themes/button-theme.mjs +0 -0
  223. /package/{esm2020 → esm2022}/lib/button/themes/index.mjs +0 -0
  224. /package/{esm2020 → esm2022}/lib/button-group/index.mjs +0 -0
  225. /package/{esm2020 → esm2022}/lib/card-heading/index.mjs +0 -0
  226. /package/{esm2020 → esm2022}/lib/data-card/index.mjs +0 -0
  227. /package/{esm2020 → esm2022}/lib/dropdown/components/index.mjs +0 -0
  228. /package/{esm2020 → esm2022}/lib/dropdown/index.mjs +0 -0
  229. /package/{esm2020 → esm2022}/lib/dropdown/types/dropdown-position.mjs +0 -0
  230. /package/{esm2020 → esm2022}/lib/dropdown/types/index.mjs +0 -0
  231. /package/{esm2020 → esm2022}/lib/file-upload/directives/index.mjs +0 -0
  232. /package/{esm2020 → esm2022}/lib/file-upload/index.mjs +0 -0
  233. /package/{esm2020 → esm2022}/lib/file-upload/pipes/index.mjs +0 -0
  234. /package/{esm2020 → esm2022}/lib/form-field/controls/checkbox/index.mjs +0 -0
  235. /package/{esm2020 → esm2022}/lib/form-field/controls/index.mjs +0 -0
  236. /package/{esm2020 → esm2022}/lib/form-field/controls/input/index.mjs +0 -0
  237. /package/{esm2020 → esm2022}/lib/form-field/controls/radio/index.mjs +0 -0
  238. /package/{esm2020 → esm2022}/lib/form-field/controls/radio/injection-tokens.mjs +0 -0
  239. /package/{esm2020 → esm2022}/lib/form-field/controls/radio/interfaces/index.mjs +0 -0
  240. /package/{esm2020 → esm2022}/lib/form-field/controls/radio/interfaces/radio-button.interface.mjs +0 -0
  241. /package/{esm2020 → esm2022}/lib/form-field/controls/radio/interfaces/radio-change-event.interface.mjs +0 -0
  242. /package/{esm2020 → esm2022}/lib/form-field/controls/radio/interfaces/radio-group.interface.mjs +0 -0
  243. /package/{esm2020 → esm2022}/lib/form-field/controls/select/index.mjs +0 -0
  244. /package/{esm2020 → esm2022}/lib/form-field/controls/select/option/index.mjs +0 -0
  245. /package/{esm2020 → esm2022}/lib/form-field/controls/select/option-parent.mjs +0 -0
  246. /package/{esm2020 → esm2022}/lib/form-field/controls/shared/index.mjs +0 -0
  247. /package/{esm2020 → esm2022}/lib/form-field/controls/shared/toggle/components/index.mjs +0 -0
  248. /package/{esm2020 → esm2022}/lib/form-field/controls/shared/toggle/index.mjs +0 -0
  249. /package/{esm2020 → esm2022}/lib/form-field/directives/index.mjs +0 -0
  250. /package/{esm2020 → esm2022}/lib/form-field/form-field-errors.mjs +0 -0
  251. /package/{esm2020 → esm2022}/lib/form-field/impdc-forms.mjs +0 -0
  252. /package/{esm2020 → esm2022}/lib/form-field/index.mjs +0 -0
  253. /package/{esm2020 → esm2022}/lib/form-field/services/index.mjs +0 -0
  254. /package/{esm2020 → esm2022}/lib/form-field/shared/constructors.type.mjs +0 -0
  255. /package/{esm2020 → esm2022}/lib/form-field/shared/index.mjs +0 -0
  256. /package/{esm2020 → esm2022}/lib/icon/index.mjs +0 -0
  257. /package/{esm2020 → esm2022}/lib/index.mjs +0 -0
  258. /package/{esm2020 → esm2022}/lib/modal/index.mjs +0 -0
  259. /package/{esm2020 → esm2022}/lib/modal/types/index.mjs +0 -0
  260. /package/{esm2020 → esm2022}/lib/pagination/index.mjs +0 -0
  261. /package/{esm2020 → esm2022}/lib/progress-bar/index.mjs +0 -0
  262. /package/{esm2020 → esm2022}/lib/scrollable/index.mjs +0 -0
  263. /package/{esm2020 → esm2022}/lib/select-icon/index.mjs +0 -0
  264. /package/{esm2020 → esm2022}/lib/size-detection/directive/element-size.interface.mjs +0 -0
  265. /package/{esm2020 → esm2022}/lib/size-detection/directive/index.mjs +0 -0
  266. /package/{esm2020 → esm2022}/lib/size-detection/index.mjs +0 -0
  267. /package/{esm2020 → esm2022}/lib/spinner/index.mjs +0 -0
  268. /package/{esm2020 → esm2022}/lib/table/constants/index.mjs +0 -0
  269. /package/{esm2020 → esm2022}/lib/table/constants/public-table.constants.mjs +0 -0
  270. /package/{esm2020 → esm2022}/lib/table/constants/table.constants.mjs +0 -0
  271. /package/{esm2020 → esm2022}/lib/table/containers/index.mjs +0 -0
  272. /package/{esm2020 → esm2022}/lib/table/directives/index.mjs +0 -0
  273. /package/{esm2020 → esm2022}/lib/table/enumerations/index.mjs +0 -0
  274. /package/{esm2020 → esm2022}/lib/table/helpers/index.mjs +0 -0
  275. /package/{esm2020 → esm2022}/lib/table/index.mjs +0 -0
  276. /package/{esm2020 → esm2022}/lib/table/interfaces/cell-renderer.interface.mjs +0 -0
  277. /package/{esm2020 → esm2022}/lib/table/interfaces/custom-cell-renderer-components.type.mjs +0 -0
  278. /package/{esm2020 → esm2022}/lib/table/interfaces/sort-by-payload.interface.mjs +0 -0
  279. /package/{esm2020 → esm2022}/lib/table/interfaces/table-cell-option.interface.mjs +0 -0
  280. /package/{esm2020 → esm2022}/lib/table/interfaces/table-event-payload.interface.mjs +0 -0
  281. /package/{esm2020 → esm2022}/lib/table/interfaces/table-row-item.interface.mjs +0 -0
  282. /package/{esm2020 → esm2022}/lib/text-highlight/index.mjs +0 -0
  283. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
  284. /package/{esm2020 → esm2022}/types/component-size.mjs +0 -0
  285. /package/{esm2020 → esm2022}/types/index.mjs +0 -0
  286. /package/{esm2020 → esm2022}/utilities/boolean-props.mjs +0 -0
  287. /package/{esm2020 → esm2022}/utilities/dc.mjs +0 -0
  288. /package/{esm2020 → esm2022}/utilities/index.mjs +0 -0
  289. /package/{esm2020 → esm2022}/utilities/lc.mjs +0 -0
  290. /package/{esm2020 → esm2022}/utilities/number-props.mjs +0 -0
  291. /package/{esm2020 → esm2022}/utilities/sanitize.mjs +0 -0
@@ -0,0 +1,403 @@
1
+ import { Component, ContentChild, EventEmitter, Host, Input, Optional, Output } from '@angular/core';
2
+ import { get as getNestedValue, set as setNestedValue } from 'lodash';
3
+ import { debounceTime } from 'rxjs/operators';
4
+ import { DEBOUNCE_TIME, SORT_COLUMN_INDEX } from '../constants/index';
5
+ import { TableColumnType } from '../enumerations/index';
6
+ import { TableThemeHelper } from '../helpers';
7
+ import { ComponentTheme } from '../../../types';
8
+ import { PaginationComponent } from '../../pagination';
9
+ import { TableBulkActionsComponent } from '../components';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "@angular/common";
12
+ import * as i2 from "../../branding";
13
+ import * as i3 from "../../branding/branded.directive";
14
+ import * as i4 from "../../icon/icon.component";
15
+ import * as i5 from "../../form-field/controls/checkbox/checkbox.component";
16
+ import * as i6 from "../../form-field/controls/select/option/select-option.component";
17
+ import * as i7 from "../../form-field/controls/select/select.component";
18
+ import * as i8 from "../../form-field/controls/input/input.directive";
19
+ import * as i9 from "@angular/forms";
20
+ import * as i10 from "../../spinner/spinner.component";
21
+ import * as i11 from "../../badge/badge.component";
22
+ import * as i12 from "../directives/table.directive";
23
+ import * as i13 from "../components/column-heading/column-heading.component";
24
+ import * as i14 from "../directives/table-inject-component.directive";
25
+ import * as i15 from "../components/row-actions/row-actions.component";
26
+ /**
27
+ * The `TableComponent` (`<impdc-table`) is a data table component.
28
+ * To use, import `TableModule` from `@impartner/design-components`.
29
+ */
30
+ export class TableComponent {
31
+ /**
32
+ * Whether individual rows can be selected. Will be `true` if explicitly set to `true` or `canSelectAllRows` is `true`.
33
+ */
34
+ set canSelectRows(value) {
35
+ this._canSelectRows = value;
36
+ }
37
+ get canSelectRows() {
38
+ return this.canSelectAllRows || this._canSelectRows || !!this.bulkActions;
39
+ }
40
+ /**
41
+ * Whether all rows can be selected at once. Will be `true` if explicitly set to `true` or if `TableBulkActionsComponent` is content projected.
42
+ */
43
+ set canSelectAllRows(value) {
44
+ this._canSelectAllRows = value;
45
+ }
46
+ get canSelectAllRows() {
47
+ return this._canSelectAllRows || !!this.bulkActions;
48
+ }
49
+ /**
50
+ * An array of currently selected IDs from the `tableData` input. Array must be of type `(string | number)[]`.
51
+ */
52
+ set selectedRowIds(value) {
53
+ this._selectedRowIds = [...value];
54
+ }
55
+ get selectedRowIds() {
56
+ return [...this._selectedRowIds];
57
+ }
58
+ /** @ignore */
59
+ get someSelected() {
60
+ return (!!this._selectedRowIds &&
61
+ this._selectedRowIds.length > 0 &&
62
+ !!this.tableData &&
63
+ this.tableData.length > 0 &&
64
+ this._selectedRowIds.length < this.tableData.length);
65
+ }
66
+ /** @ignore */
67
+ get tableSpan() {
68
+ return this.canSelectRows
69
+ ? this.columnDefs.length + 1
70
+ : this.columnDefs.length;
71
+ }
72
+ constructor(_datePipe, _percentPipe, _decmialPipe, _changeDetectorRef, _branded) {
73
+ this._datePipe = _datePipe;
74
+ this._percentPipe = _percentPipe;
75
+ this._decmialPipe = _decmialPipe;
76
+ this._changeDetectorRef = _changeDetectorRef;
77
+ this._branded = _branded;
78
+ /**
79
+ * Whether the table data is currently being loaded. The `<impdc-spinner>` will show if data is loading.
80
+ */
81
+ this.loading = false;
82
+ /**
83
+ * The visible columns of the table. Each `ITableColumnDef` defines properties regarding the display, formatting and interaction of the column's cells.
84
+ * Column/cell color precedence is:
85
+ * 1) `fieldColor` - allows an `ITableColumnDef` to delegate the responsibility of cell color to an `ITableRowItem` property.
86
+ * 2) `colorGetter`- allows an `ITableColumnDef` to delegate the responsibility of cell color to a function of the `ITableRowItem` determined by the developer.
87
+ * 3) `color` - a property of an `ITableColumnDef`.
88
+ */
89
+ this.columnDefs = [];
90
+ /**
91
+ * Whether the table is striped.
92
+ */
93
+ this.striped = true;
94
+ /**
95
+ * The placeholder text and empty value display text for `<impdc-select>` instances in cells with a `ITableColumnDef` `columnType` = `SingleSelect` or `MultiSelect`.
96
+ */
97
+ this.selectPlaceholder = '';
98
+ /**
99
+ * The `columnDefs` index of the currently sorted column.
100
+ */
101
+ this.sortColumnIndex = SORT_COLUMN_INDEX;
102
+ /**
103
+ * The direction of the currently sorted column.
104
+ */
105
+ this.sortDirection = 'asc';
106
+ /**
107
+ * The table row data as an array of `ITableRowItem`.
108
+ */
109
+ this.tableData = [];
110
+ /**
111
+ * Event emitted when one or multiple rows are selected. Emits `(string | number)[]` payload.
112
+ */
113
+ this.rowSelect = new EventEmitter();
114
+ /**
115
+ * Event emitted when a column is sorted. Emits `ISortByPayload` payload.
116
+ */
117
+ this.sortBy = new EventEmitter();
118
+ /**
119
+ * Event emitted when a row link is clicked. Emits `ITableEventPayload` payload.
120
+ */
121
+ this.linkClick = new EventEmitter();
122
+ /**
123
+ * Event emitted when a row action is clicked. Emits an `ITableRowActionPayload` payload.
124
+ */
125
+ this.rowActionClick = new EventEmitter();
126
+ /** @ignore */
127
+ this.paginationComponent = undefined;
128
+ /** @ignore */
129
+ this.bulkActions = undefined;
130
+ /**
131
+ * Event emitted when a row input value is changed. Emitted cells of `columnType` `SinglSelect`, `MultiSelect`, `Input`, `Boolean` or `Icon`.
132
+ * Not emitted if column definition property `disabled` = `true`. Emits `ITableEventPayload` payload.
133
+ */
134
+ this.inputChange = new EventEmitter();
135
+ /** @ignore */
136
+ this.cellType = TableColumnType;
137
+ /** @ignore */
138
+ this.allSelected = true;
139
+ /** @ignore */
140
+ this.branded = false;
141
+ this._canSelectRows = false;
142
+ this._canSelectAllRows = false;
143
+ this._selectedRowIds = [];
144
+ this._inputChange = new EventEmitter();
145
+ this.branded = _branded ? true : false;
146
+ this._inputChange
147
+ .pipe(debounceTime(DEBOUNCE_TIME))
148
+ .subscribe(this.inputChange);
149
+ }
150
+ ngOnChanges(changes) {
151
+ if (changes['selectedRowIds'] || changes['tableData']) {
152
+ if (!this.tableData ||
153
+ !this.tableData.length ||
154
+ !this.selectedRowIds ||
155
+ !this.selectedRowIds.length) {
156
+ this.allSelected = false;
157
+ }
158
+ else {
159
+ this.allSelected = this.selectedRowIds.length >= this.tableData.length;
160
+ }
161
+ }
162
+ }
163
+ getMailToValue(columnIndex, currentRow) {
164
+ const { columnType, truncated: truncated } = this._getColumnDefByIndex(columnIndex);
165
+ let value = this._getValue(columnIndex, currentRow);
166
+ if (columnType !== TableColumnType.Email) {
167
+ return String(value);
168
+ }
169
+ value = value ? `mailto:${value}` : value;
170
+ return String(value);
171
+ }
172
+ getStringValue(columnIndex, currentRow) {
173
+ const value = this.getValue(columnIndex, currentRow);
174
+ if (Array.isArray(value)) {
175
+ return value.join(';');
176
+ }
177
+ return String(value);
178
+ }
179
+ getValue(columnIndex, currentRow) {
180
+ const { columnType, truncated: truncated } = this._getColumnDefByIndex(columnIndex);
181
+ let value = this._getValue(columnIndex, currentRow);
182
+ switch (columnType) {
183
+ case TableColumnType.Decimal: {
184
+ value = this._decmialPipe.transform(Number(value) || 0) || '';
185
+ break;
186
+ }
187
+ case TableColumnType.Date: {
188
+ const date = new Date(String(value));
189
+ const validDate = date instanceof Date && !isNaN(date.getTime());
190
+ value = validDate
191
+ ? this._datePipe.transform(date, 'MM/dd/yyyy') || ''
192
+ : String(value);
193
+ break;
194
+ }
195
+ case TableColumnType.DateTime: {
196
+ const dateTime = new Date(String(value));
197
+ const validDateTime = dateTime instanceof Date && !isNaN(dateTime.getTime());
198
+ value = validDateTime
199
+ ? this._datePipe.transform(dateTime, 'MM/dd/yyyy h:mm:ss a') || ''
200
+ : String(value);
201
+ break;
202
+ }
203
+ case TableColumnType.Link: {
204
+ value = String(value).replace(/(^\w+:|^)\/\//, '');
205
+ break;
206
+ }
207
+ case TableColumnType.Percentage: {
208
+ value = this._percentPipe.transform(Number(value) || 0) || '';
209
+ break;
210
+ }
211
+ case TableColumnType.Url: {
212
+ if (!/(http(s?)):\/\//i.test(String(value))) {
213
+ value = `https://${value}`;
214
+ }
215
+ break;
216
+ }
217
+ case TableColumnType.Text: {
218
+ if (Array.isArray(value)) {
219
+ value = value.join('; ');
220
+ }
221
+ if (!truncated) {
222
+ return value;
223
+ }
224
+ const truncateString = (string = '', maxLength = truncated) => string.length > maxLength
225
+ ? `${string.substring(0, maxLength)}…`
226
+ : string;
227
+ !!truncated
228
+ ? (value = truncateString(String(value), truncated))
229
+ : value;
230
+ break;
231
+ }
232
+ case TableColumnType.MultiSelect:
233
+ if (typeof value === 'string') {
234
+ value = value.split(';')?.map(v => v.trim()) || [];
235
+ }
236
+ return value;
237
+ }
238
+ return String(value);
239
+ }
240
+ getRawValue(columnIndex, currentRow) {
241
+ const { field } = this._getColumnDefByIndex(columnIndex);
242
+ if (!field) {
243
+ return '';
244
+ }
245
+ return currentRow[field] || '';
246
+ }
247
+ getCellColor(columnDefinition, item) {
248
+ return TableThemeHelper.getCellColor(columnDefinition, item);
249
+ }
250
+ getTheme(columnDefinition, item) {
251
+ return (TableThemeHelper.getTheme(columnDefinition, item) ||
252
+ ComponentTheme.Primary);
253
+ }
254
+ isSortedColumn(columnIndex) {
255
+ return columnIndex === this.sortColumnIndex;
256
+ }
257
+ isRowSelected(id) {
258
+ return this.selectedRowIds.includes(id);
259
+ }
260
+ handleSelectAll(event) {
261
+ if (!this.canSelectAllRows || !this.tableData) {
262
+ return;
263
+ }
264
+ if (event.checked) {
265
+ this._selectedRowIds = this.tableData?.map(row => row.id) || [];
266
+ }
267
+ else {
268
+ this._selectedRowIds = [];
269
+ }
270
+ this._selectedRowIds.sort();
271
+ this.allSelected = this.selectedRowIds.length >= this.tableData.length;
272
+ this.rowSelect.emit(this.selectedRowIds);
273
+ }
274
+ handleSort(columnIndex) {
275
+ if (columnIndex === this.sortColumnIndex) {
276
+ this.sortDirection = this.sortDirection === 'asc' ? 'desc' : 'asc';
277
+ }
278
+ else {
279
+ this.sortColumnIndex = columnIndex;
280
+ this.sortDirection = 'asc';
281
+ }
282
+ const field = this._getColumnDefByIndex(columnIndex).field || '';
283
+ this.sortBy.emit({
284
+ columnIndex,
285
+ field,
286
+ direction: this.sortDirection
287
+ });
288
+ }
289
+ handleRowSelect(event, rowId) {
290
+ if (!this.canSelectRows) {
291
+ return;
292
+ }
293
+ if (event.checked && !this._selectedRowIds.includes(rowId)) {
294
+ this._selectedRowIds.push(rowId);
295
+ }
296
+ else if (!event.checked && this._selectedRowIds.includes(rowId)) {
297
+ const idx = this._selectedRowIds.indexOf(rowId);
298
+ if (idx > -1) {
299
+ this._selectedRowIds.splice(idx, 1);
300
+ }
301
+ }
302
+ if (this._selectedRowIds.length) {
303
+ this._selectedRowIds.sort();
304
+ }
305
+ this.allSelected = this.selectedRowIds.length >= this.tableData.length;
306
+ this.rowSelect.emit(this.selectedRowIds);
307
+ }
308
+ handleCellValueChange(columnIndex, rowIndex, value) {
309
+ const { field, columnType } = this._getColumnDefByIndex(columnIndex);
310
+ let currentValue = value;
311
+ if (columnType !== TableColumnType.Boolean && !Array.isArray(value)) {
312
+ currentValue = isNaN(Number(value)) ? value : Number(value);
313
+ }
314
+ const item = this.tableData[rowIndex];
315
+ setNestedValue(item, String(field), currentValue);
316
+ this._inputChange.emit({
317
+ columnIndex,
318
+ item,
319
+ value: currentValue
320
+ });
321
+ this._changeDetectorRef.detectChanges();
322
+ }
323
+ handleLinkClick(columnIndex, item) {
324
+ this.linkClick.emit({
325
+ item,
326
+ columnIndex
327
+ });
328
+ }
329
+ handleActionClick(columnIndex, item, actionApiName) {
330
+ this.rowActionClick.emit({
331
+ item,
332
+ columnIndex,
333
+ actionApiName
334
+ });
335
+ }
336
+ columnDefIsActions(columnDef) {
337
+ return columnDef.columnType === TableColumnType.Actions;
338
+ }
339
+ _getColumnDefByIndex(columnIndex) {
340
+ return this.columnDefs[columnIndex];
341
+ }
342
+ _getValue(columnIndex, currentRow) {
343
+ try {
344
+ const { field, valueGetter } = this._getColumnDefByIndex(columnIndex);
345
+ const value = valueGetter
346
+ ? valueGetter(currentRow)
347
+ : getNestedValue(currentRow, String(field), '');
348
+ return value || '';
349
+ }
350
+ catch (e) {
351
+ return '';
352
+ }
353
+ }
354
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: TableComponent, deps: [{ token: i1.DatePipe }, { token: i1.PercentPipe }, { token: i1.DecimalPipe }, { token: i0.ChangeDetectorRef }, { token: i2.BrandedDirective, host: true, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
355
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.1", type: TableComponent, selector: "impdc-table", inputs: { loading: "loading", columnDefs: "columnDefs", striped: "striped", canSelectRows: "canSelectRows", canSelectAllRows: "canSelectAllRows", selectPlaceholder: "selectPlaceholder", sortColumnIndex: "sortColumnIndex", sortDirection: "sortDirection", tableData: "tableData", selectedRowIds: "selectedRowIds", customCellComponents: "customCellComponents" }, outputs: { rowSelect: "rowSelect", sortBy: "sortBy", linkClick: "linkClick", rowActionClick: "rowActionClick", inputChange: "inputChange" }, queries: [{ propertyName: "paginationComponent", first: true, predicate: PaginationComponent, descendants: true }, { propertyName: "bulkActions", first: true, predicate: TableBulkActionsComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "@if (tableData) {\n<table impdcTable [striped]=\"striped\">\n <thead>\n @if (!!bulkActions) {\n <tr>\n <th [attr.colspan]=\"tableSpan\" scope=\"col\" class=\"bulk-action-column\">\n <ng-content select=\"impdc-table-bulk-actions\"></ng-content>\n <ng-content select=\"[impdcTableBulkActions]\"></ng-content>\n </th>\n </tr>\n }\n <tr>\n @if (canSelectRows) {\n <th\n scope=\"col\"\n [ngClass]=\"{\n 'heading-below-bulk-actions': !!bulkActions\n }\">\n @if (canSelectAllRows) {\n <div>\n <impdc-checkbox\n ngModel\n [checked]=\"allSelected\"\n [indeterminate]=\"someSelected\"\n (change)=\"handleSelectAll($event)\"></impdc-checkbox>\n </div>\n }\n </th>\n } @for (columnDef of columnDefs; track columnDef; let columnIndex =\n $index) {\n <th\n scope=\"col\"\n [ngClass]=\"{\n 'sorted-column': isSortedColumn(columnIndex),\n 'sortable-column': columnDef.sorted,\n 'heading-below-bulk-actions': !!bulkActions\n }\"\n (click)=\"handleSort(columnIndex)\">\n <impdc-column-heading\n [isSortable]=\"columnDef.sorted || false\"\n [columnIndex]=\"columnIndex\"\n [sortColumnIndex]=\"sortColumnIndex\"\n [direction]=\"sortDirection\"\n [text]=\"columnDef.title\"\n (sort)=\"handleSort($event)\">\n </impdc-column-heading>\n </th>\n }\n </tr>\n </thead>\n <tbody>\n @if (loading) {\n <tr>\n <td [attr.colspan]=\"tableSpan\" class=\"data-loading\">\n <impdc-spinner></impdc-spinner>\n </td>\n </tr>\n } @else { @for (row of tableData; track row; let rowIndex = $index) {\n <tr>\n @if (canSelectRows) {\n <td>\n <div class=\"select-column\">\n <impdc-checkbox\n [ngModel]=\"isRowSelected(row.id)\"\n (change)=\"handleRowSelect($event, row.id)\"></impdc-checkbox>\n </div>\n </td>\n }\n <td\n *ngFor=\"let columnDef of columnDefs; index as colIndex; last as isLast\"\n [ngClass]=\"{\n 'col-no-padding': !!columnDef.noPadding,\n 'actions-column': columnDef.columnType === cellType.Actions\n }\">\n <div>\n @switch (columnDef.columnType) { @case (cellType.Badge) {\n <span>\n <impdc-badge\n [text]=\"getStringValue(colIndex, row)\"\n [theme]=\"getTheme(columnDef, row)\">\n </impdc-badge>\n </span>\n } @case (cellType.Link) {\n <span (click)=\"handleLinkClick(colIndex, row)\">\n @if (!branded) {\n <a>\n {{ getValue(colIndex, row) }}\n </a>\n } @else {\n <a impdcBranded>\n {{ getValue(colIndex, row) }}\n </a>\n }\n </span>\n } @case (cellType.Url) {\n <span>\n @if (!branded) {\n <a target=\"_blank\" [attr.href]=\"getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n } @else {\n <a\n impdcBranded\n target=\"_blank\"\n [attr.href]=\"getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n }\n </span>\n } @case (cellType.Email) {\n <span>\n @if (!branded) {\n <a\n target=\"_blank\"\n [attr.href]=\"'mailto:' + getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n } @else {\n <a impdcBranded [attr.href]=\"getMailToValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n }\n </span>\n } @case (cellType.Input) {\n <span>\n <input\n impdcInput\n type=\"text\"\n class=\"{{ getCellColor(columnDef, row) }}\"\n [ngModel]=\"getValue(colIndex, row)\"\n (ngModelChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event)\n \" />\n </span>\n } @case (cellType.Boolean) {\n <span>\n @if (columnDef.disabled && getValue(colIndex, row) === 'true') {\n <span\n impdc-icon\n name=\"check\"\n class=\"{{ getCellColor(columnDef, row) }}\"></span>\n } @else if (!columnDef.disabled) {\n <impdc-checkbox\n [checked]=\"getValue(colIndex, row) === 'true'\"\n [isSwitch]=\"true\"\n (change)=\"\n handleCellValueChange(colIndex, rowIndex, $event.checked)\n \"></impdc-checkbox>\n }\n </span>\n } @case (cellType.SingleSelect) {\n <span>\n <impdc-select\n [ngModel]=\"getValue(colIndex, row)\"\n [disabled]=\"columnDef.disabled || false\"\n [placeholder]=\"selectPlaceholder\"\n (selectionChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event.value)\n \">\n @if (selectPlaceholder) {\n <impdc-select-option value [label]=\"selectPlaceholder\">\n </impdc-select-option>\n } @for (value of (columnDef.values || []); track value) {\n <impdc-select-option\n [value]=\"value.value\"\n [label]=\"value.label\"></impdc-select-option>\n }\n </impdc-select>\n </span>\n } @case (cellType.MultiSelect) {\n <span>\n <impdc-select\n [ngModel]=\"getValue(colIndex, row)\"\n [disabled]=\"columnDef.disabled || false\"\n [placeholder]=\"selectPlaceholder\"\n multiple=\"true\"\n (selectionChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event.value)\n \">\n @for (value of (columnDef.values || []); track value) {\n <impdc-select-option\n [value]=\"value.value\"\n [label]=\"value.label\"></impdc-select-option>\n }\n </impdc-select>\n </span>\n } @case (cellType.CellRender) {\n <span class=\"{{ getCellColor(columnDef, row) }}\">\n <ng-template\n impdcTableInjectComponent\n [columnDef]=\"columnDef\"\n [rowItem]=\"row\"\n [customCellComponents]=\"customCellComponents || {}\"\n [value]=\"getRawValue(colIndex, row)\"></ng-template>\n </span>\n } @case (cellType.Icon) {\n <span>\n <span\n impdc-icon\n [name]=\"columnDef.iconName\"\n class=\"{{ getCellColor(columnDef, row) }}\"></span>\n </span>\n } @case (cellType.Actions) {\n <span>\n <!-- will always return 'true', but needed to satisfy the type engine -->\n @if (columnDefIsActions(columnDef)) {\n <impdc-row-actions\n [columnDef]=\"columnDef\"\n [rowItem]=\"row\"\n [lastColumn]=\"isLast\"\n (actionClick)=\"\n handleActionClick(colIndex, row, $event)\n \"></impdc-row-actions>\n }\n </span>\n } @default {\n <span class=\"{{ getCellColor(columnDef, row) }}\">\n {{ getValue(colIndex, row) }}\n </span>\n } }\n </div>\n </td>\n </tr>\n } @empty {\n <tr>\n <td [attr.colspan]=\"tableSpan\" class=\"no-data\">\n <ng-content select=\"[noData]\"></ng-content>\n </td>\n </tr>\n } }\n </tbody>\n <tfoot>\n @if (paginationComponent) {\n <tr>\n <td [attr.colspan]=\"tableSpan\">\n <ng-content\n select=\"impdc-pagination, div[impdc-pagination]\"></ng-content>\n </td>\n </tr>\n }\n </tfoot>\n</table>\n}\n", styles: [".bulk-action-container{display:flex;flex-direction:row;border:1px solid var(--impd-color-gray-200);border-top-left-radius:.6rem;border-top-right-radius:.6rem;border-bottom:0px}.bulk-action-container .bulk-action-checkbox{padding:1.6rem 2rem}.bulk-action-container .bulk-actions{display:flex;flex-direction:row;gap:.4rem}.col-no-padding{padding:0!important}.data-loading{height:var(--impd-size-80);vertical-align:middle;text-align:center}.no-data{vertical-align:middle;text-align:center}.select-row{display:flex;height:var(--impd-size-4);align-items:center;justify-items:end;border-radius:var(--impd-border-radius-default)}.heading-with-checkbox{padding-left:5px;padding-right:10px}.actions-column{width:.1%;white-space:nowrap}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.BrandedDirective, selector: "[impdcBranded]" }, { kind: "component", type: i4.IconComponent, selector: "impdc-icon, [impdc-icon]", inputs: ["name", "theme", "size"] }, { kind: "component", type: i5.CheckboxComponent, selector: "impdc-checkbox", inputs: ["tabIndex", "id", "label", "description", "isSwitch", "switchIcons", "inline", "checked", "indeterminate", "disabled", "errorStateMatcher", "required"], outputs: ["change", "indeterminateChange"], exportAs: ["impdcCheckControl"] }, { kind: "component", type: i6.SelectOptionComponent, selector: "impdc-select-option", inputs: ["value", "label", "id", "disabled"], outputs: ["onSelectionChange"] }, { kind: "component", type: i7.SelectComponent, selector: "impdc-select", inputs: ["disabled", "tabIndex", "placeholder", "required", "multiple", "compareWith", "errorStateMatcher", "value", "id"], outputs: ["selectionChange", "valueChange"], exportAs: ["impdcSelect"] }, { kind: "directive", type: i8.InputDirective, selector: "input[impdcInput], textarea[impdcInput], select[impdcNativeSelect]", inputs: ["disabled", "id", "type", "required", "readonly", "errorStateMatcher", "value"], exportAs: ["impdcInput"] }, { kind: "directive", type: i9.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: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i10.SpinnerComponent, selector: "impdc-spinner, div[impdc-spinner]", inputs: ["accessibilityText"] }, { kind: "component", type: i11.BadgeComponent, selector: "impdc-badge, [impdc-badge]", inputs: ["text", "icon", "theme", "size", "hideBg", "rounded", "dismissable"], outputs: ["dismiss"] }, { kind: "directive", type: i12.TableDirective, selector: "table[impdcTable]", inputs: ["striped"] }, { kind: "component", type: i13.ColumnHeadingComponent, selector: "impdc-column-heading", inputs: ["isSortable", "columnIndex", "sortColumnIndex", "direction", "text"], outputs: ["sort"] }, { kind: "directive", type: i14.TableInjectComponentDirective, selector: "[impdcTableInjectComponent]", inputs: ["columnDef", "value", "rowItem", "customCellComponents"] }, { kind: "component", type: i15.RowActionsComponent, selector: "impdc-row-actions", inputs: ["columnDef", "rowItem", "lastColumn"], outputs: ["actionClick"] }] }); }
356
+ }
357
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: TableComponent, decorators: [{
358
+ type: Component,
359
+ args: [{ selector: 'impdc-table', template: "@if (tableData) {\n<table impdcTable [striped]=\"striped\">\n <thead>\n @if (!!bulkActions) {\n <tr>\n <th [attr.colspan]=\"tableSpan\" scope=\"col\" class=\"bulk-action-column\">\n <ng-content select=\"impdc-table-bulk-actions\"></ng-content>\n <ng-content select=\"[impdcTableBulkActions]\"></ng-content>\n </th>\n </tr>\n }\n <tr>\n @if (canSelectRows) {\n <th\n scope=\"col\"\n [ngClass]=\"{\n 'heading-below-bulk-actions': !!bulkActions\n }\">\n @if (canSelectAllRows) {\n <div>\n <impdc-checkbox\n ngModel\n [checked]=\"allSelected\"\n [indeterminate]=\"someSelected\"\n (change)=\"handleSelectAll($event)\"></impdc-checkbox>\n </div>\n }\n </th>\n } @for (columnDef of columnDefs; track columnDef; let columnIndex =\n $index) {\n <th\n scope=\"col\"\n [ngClass]=\"{\n 'sorted-column': isSortedColumn(columnIndex),\n 'sortable-column': columnDef.sorted,\n 'heading-below-bulk-actions': !!bulkActions\n }\"\n (click)=\"handleSort(columnIndex)\">\n <impdc-column-heading\n [isSortable]=\"columnDef.sorted || false\"\n [columnIndex]=\"columnIndex\"\n [sortColumnIndex]=\"sortColumnIndex\"\n [direction]=\"sortDirection\"\n [text]=\"columnDef.title\"\n (sort)=\"handleSort($event)\">\n </impdc-column-heading>\n </th>\n }\n </tr>\n </thead>\n <tbody>\n @if (loading) {\n <tr>\n <td [attr.colspan]=\"tableSpan\" class=\"data-loading\">\n <impdc-spinner></impdc-spinner>\n </td>\n </tr>\n } @else { @for (row of tableData; track row; let rowIndex = $index) {\n <tr>\n @if (canSelectRows) {\n <td>\n <div class=\"select-column\">\n <impdc-checkbox\n [ngModel]=\"isRowSelected(row.id)\"\n (change)=\"handleRowSelect($event, row.id)\"></impdc-checkbox>\n </div>\n </td>\n }\n <td\n *ngFor=\"let columnDef of columnDefs; index as colIndex; last as isLast\"\n [ngClass]=\"{\n 'col-no-padding': !!columnDef.noPadding,\n 'actions-column': columnDef.columnType === cellType.Actions\n }\">\n <div>\n @switch (columnDef.columnType) { @case (cellType.Badge) {\n <span>\n <impdc-badge\n [text]=\"getStringValue(colIndex, row)\"\n [theme]=\"getTheme(columnDef, row)\">\n </impdc-badge>\n </span>\n } @case (cellType.Link) {\n <span (click)=\"handleLinkClick(colIndex, row)\">\n @if (!branded) {\n <a>\n {{ getValue(colIndex, row) }}\n </a>\n } @else {\n <a impdcBranded>\n {{ getValue(colIndex, row) }}\n </a>\n }\n </span>\n } @case (cellType.Url) {\n <span>\n @if (!branded) {\n <a target=\"_blank\" [attr.href]=\"getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n } @else {\n <a\n impdcBranded\n target=\"_blank\"\n [attr.href]=\"getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n }\n </span>\n } @case (cellType.Email) {\n <span>\n @if (!branded) {\n <a\n target=\"_blank\"\n [attr.href]=\"'mailto:' + getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n } @else {\n <a impdcBranded [attr.href]=\"getMailToValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n }\n </span>\n } @case (cellType.Input) {\n <span>\n <input\n impdcInput\n type=\"text\"\n class=\"{{ getCellColor(columnDef, row) }}\"\n [ngModel]=\"getValue(colIndex, row)\"\n (ngModelChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event)\n \" />\n </span>\n } @case (cellType.Boolean) {\n <span>\n @if (columnDef.disabled && getValue(colIndex, row) === 'true') {\n <span\n impdc-icon\n name=\"check\"\n class=\"{{ getCellColor(columnDef, row) }}\"></span>\n } @else if (!columnDef.disabled) {\n <impdc-checkbox\n [checked]=\"getValue(colIndex, row) === 'true'\"\n [isSwitch]=\"true\"\n (change)=\"\n handleCellValueChange(colIndex, rowIndex, $event.checked)\n \"></impdc-checkbox>\n }\n </span>\n } @case (cellType.SingleSelect) {\n <span>\n <impdc-select\n [ngModel]=\"getValue(colIndex, row)\"\n [disabled]=\"columnDef.disabled || false\"\n [placeholder]=\"selectPlaceholder\"\n (selectionChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event.value)\n \">\n @if (selectPlaceholder) {\n <impdc-select-option value [label]=\"selectPlaceholder\">\n </impdc-select-option>\n } @for (value of (columnDef.values || []); track value) {\n <impdc-select-option\n [value]=\"value.value\"\n [label]=\"value.label\"></impdc-select-option>\n }\n </impdc-select>\n </span>\n } @case (cellType.MultiSelect) {\n <span>\n <impdc-select\n [ngModel]=\"getValue(colIndex, row)\"\n [disabled]=\"columnDef.disabled || false\"\n [placeholder]=\"selectPlaceholder\"\n multiple=\"true\"\n (selectionChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event.value)\n \">\n @for (value of (columnDef.values || []); track value) {\n <impdc-select-option\n [value]=\"value.value\"\n [label]=\"value.label\"></impdc-select-option>\n }\n </impdc-select>\n </span>\n } @case (cellType.CellRender) {\n <span class=\"{{ getCellColor(columnDef, row) }}\">\n <ng-template\n impdcTableInjectComponent\n [columnDef]=\"columnDef\"\n [rowItem]=\"row\"\n [customCellComponents]=\"customCellComponents || {}\"\n [value]=\"getRawValue(colIndex, row)\"></ng-template>\n </span>\n } @case (cellType.Icon) {\n <span>\n <span\n impdc-icon\n [name]=\"columnDef.iconName\"\n class=\"{{ getCellColor(columnDef, row) }}\"></span>\n </span>\n } @case (cellType.Actions) {\n <span>\n <!-- will always return 'true', but needed to satisfy the type engine -->\n @if (columnDefIsActions(columnDef)) {\n <impdc-row-actions\n [columnDef]=\"columnDef\"\n [rowItem]=\"row\"\n [lastColumn]=\"isLast\"\n (actionClick)=\"\n handleActionClick(colIndex, row, $event)\n \"></impdc-row-actions>\n }\n </span>\n } @default {\n <span class=\"{{ getCellColor(columnDef, row) }}\">\n {{ getValue(colIndex, row) }}\n </span>\n } }\n </div>\n </td>\n </tr>\n } @empty {\n <tr>\n <td [attr.colspan]=\"tableSpan\" class=\"no-data\">\n <ng-content select=\"[noData]\"></ng-content>\n </td>\n </tr>\n } }\n </tbody>\n <tfoot>\n @if (paginationComponent) {\n <tr>\n <td [attr.colspan]=\"tableSpan\">\n <ng-content\n select=\"impdc-pagination, div[impdc-pagination]\"></ng-content>\n </td>\n </tr>\n }\n </tfoot>\n</table>\n}\n", styles: [".bulk-action-container{display:flex;flex-direction:row;border:1px solid var(--impd-color-gray-200);border-top-left-radius:.6rem;border-top-right-radius:.6rem;border-bottom:0px}.bulk-action-container .bulk-action-checkbox{padding:1.6rem 2rem}.bulk-action-container .bulk-actions{display:flex;flex-direction:row;gap:.4rem}.col-no-padding{padding:0!important}.data-loading{height:var(--impd-size-80);vertical-align:middle;text-align:center}.no-data{vertical-align:middle;text-align:center}.select-row{display:flex;height:var(--impd-size-4);align-items:center;justify-items:end;border-radius:var(--impd-border-radius-default)}.heading-with-checkbox{padding-left:5px;padding-right:10px}.actions-column{width:.1%;white-space:nowrap}\n"] }]
360
+ }], ctorParameters: () => [{ type: i1.DatePipe }, { type: i1.PercentPipe }, { type: i1.DecimalPipe }, { type: i0.ChangeDetectorRef }, { type: i2.BrandedDirective, decorators: [{
361
+ type: Optional
362
+ }, {
363
+ type: Host
364
+ }] }], propDecorators: { loading: [{
365
+ type: Input
366
+ }], columnDefs: [{
367
+ type: Input
368
+ }], striped: [{
369
+ type: Input
370
+ }], canSelectRows: [{
371
+ type: Input
372
+ }], canSelectAllRows: [{
373
+ type: Input
374
+ }], selectPlaceholder: [{
375
+ type: Input
376
+ }], sortColumnIndex: [{
377
+ type: Input
378
+ }], sortDirection: [{
379
+ type: Input
380
+ }], tableData: [{
381
+ type: Input
382
+ }], selectedRowIds: [{
383
+ type: Input
384
+ }], customCellComponents: [{
385
+ type: Input
386
+ }], rowSelect: [{
387
+ type: Output
388
+ }], sortBy: [{
389
+ type: Output
390
+ }], linkClick: [{
391
+ type: Output
392
+ }], rowActionClick: [{
393
+ type: Output
394
+ }], paginationComponent: [{
395
+ type: ContentChild,
396
+ args: [PaginationComponent]
397
+ }], bulkActions: [{
398
+ type: ContentChild,
399
+ args: [TableBulkActionsComponent]
400
+ }], inputChange: [{
401
+ type: Output
402
+ }] } });
403
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-components/src/lib/table/containers/table.component.ts","../../../../../../../projects/design-components/src/lib/table/containers/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe, DecimalPipe, PercentPipe } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Host,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { get as getNestedValue, set as setNestedValue } from 'lodash';\nimport { debounceTime } from 'rxjs/operators';\n\nimport { DEBOUNCE_TIME, SORT_COLUMN_INDEX } from '../constants/index';\nimport { TableColumnType } from '../enumerations/index';\nimport {\n  ICustomCellRendererComponents,\n  ISortByPayload,\n  ITableActionsColumnDef,\n  ITableEventPayload,\n  ITableRowActionPayload,\n  ITableRowItem,\n  ITableRowItemValue,\n  ITableRowItemValueTypes,\n  TableColumnDef\n} from '../interfaces/index';\nimport { CheckboxChangeEvent } from '../../form-field';\nimport { TableThemeHelper } from '../helpers';\nimport { ComponentTheme } from '../../../types';\nimport { BrandedDirective } from '../../branding';\nimport { PaginationComponent } from '../../pagination';\nimport { TableBulkActionsComponent } from '../components';\n\n/**\n * The `TableComponent` (`<impdc-table`) is a data table component.\n * To use, import `TableModule` from `@impartner/design-components`.\n */\n@Component({\n  selector: 'impdc-table',\n  styleUrls: ['./table.component.scss'],\n  templateUrl: './table.component.html'\n})\nexport class TableComponent implements OnChanges {\n  /**\n   * Whether the table data is currently being loaded. The `<impdc-spinner>` will show if data is loading.\n   */\n  @Input() public loading = false;\n\n  /**\n   * The visible columns of the table.  Each `ITableColumnDef` defines properties regarding the display, formatting and interaction of the column's cells.\n   * Column/cell color precedence is:\n   * 1) `fieldColor` - allows an `ITableColumnDef` to delegate the responsibility of cell color to an `ITableRowItem` property.\n   * 2) `colorGetter`- allows an `ITableColumnDef` to delegate the responsibility of cell color to a function of the `ITableRowItem` determined by the developer.\n   * 3) `color` - a property of an `ITableColumnDef`.\n   */\n  @Input() public columnDefs: TableColumnDef[] = [];\n\n  /**\n   * Whether the table is striped.\n   */\n  @Input() public striped = true;\n\n  /**\n   * Whether individual rows can be selected. Will be `true` if explicitly set to `true` or `canSelectAllRows` is `true`.\n   */\n  @Input() public set canSelectRows(value: boolean) {\n    this._canSelectRows = value;\n  }\n  public get canSelectRows(): boolean {\n    return this.canSelectAllRows || this._canSelectRows || !!this.bulkActions;\n  }\n\n  /**\n   * Whether all rows can be selected at once. Will be `true` if explicitly set to `true` or if `TableBulkActionsComponent` is content projected.\n   */\n  @Input()\n  public set canSelectAllRows(value: boolean) {\n    this._canSelectAllRows = value;\n  }\n\n  public get canSelectAllRows(): boolean {\n    return this._canSelectAllRows || !!this.bulkActions;\n  }\n\n  /**\n   * The placeholder text and empty value display text for `<impdc-select>` instances in cells with a `ITableColumnDef` `columnType` = `SingleSelect` or `MultiSelect`.\n   */\n  @Input() public selectPlaceholder = '';\n\n  /**\n   * The `columnDefs` index of the currently sorted column.\n   */\n  @Input() public sortColumnIndex = SORT_COLUMN_INDEX;\n\n  /**\n   * The direction of the currently sorted column.\n   */\n  @Input() public sortDirection: 'asc' | 'desc' = 'asc';\n\n  /**\n   * The table row data as an array of `ITableRowItem`.\n   */\n  @Input() public tableData: ITableRowItem[] = [];\n\n  /**\n   * An array of currently selected IDs from the `tableData` input.  Array must be of type `(string | number)[]`.\n   */\n  @Input()\n  public set selectedRowIds(value: (string | number)[]) {\n    this._selectedRowIds = [...value];\n  }\n  public get selectedRowIds(): (string | number)[] {\n    return [...this._selectedRowIds];\n  }\n\n  /**\n   * The registered custom cell renderer components available to be used in the table instance.\n   * For a given `ITableColumnDef` in the `columnDefs` input, the `cellRendererComponent` property should be set to the key of the registered component in this input.\n   */\n  @Input() public customCellComponents?: ICustomCellRendererComponents;\n\n  /**\n   * Event emitted when one or multiple rows are selected. Emits `(string | number)[]` payload.\n   */\n  @Output() public readonly rowSelect = new EventEmitter<(string | number)[]>();\n\n  /**\n   * Event emitted when a column is sorted. Emits `ISortByPayload` payload.\n   */\n  @Output() public readonly sortBy = new EventEmitter<ISortByPayload>();\n\n  /**\n   * Event emitted when a row link is clicked. Emits `ITableEventPayload` payload.\n   */\n  @Output() public readonly linkClick = new EventEmitter<ITableEventPayload>();\n\n  /**\n   * Event emitted when a row action is clicked. Emits an `ITableRowActionPayload` payload.\n   */\n  @Output() public readonly rowActionClick =\n    new EventEmitter<ITableRowActionPayload>();\n\n  /** @ignore */\n  @ContentChild(PaginationComponent)\n  public paginationComponent?: PaginationComponent = undefined;\n\n  /** @ignore */\n  @ContentChild(TableBulkActionsComponent)\n  public bulkActions?: TableBulkActionsComponent = undefined;\n\n  /**\n   * Event emitted when a row input value is changed. Emitted cells of `columnType` `SinglSelect`, `MultiSelect`, `Input`, `Boolean` or `Icon`.\n   * Not emitted if column definition property `disabled` = `true`. Emits `ITableEventPayload` payload.\n   */\n  @Output() public readonly inputChange =\n    new EventEmitter<ITableEventPayload>();\n\n  /** @ignore */\n  public readonly cellType = TableColumnType;\n  /** @ignore */\n  public allSelected = true;\n  /** @ignore */\n  public get someSelected(): boolean {\n    return (\n      !!this._selectedRowIds &&\n      this._selectedRowIds.length > 0 &&\n      !!this.tableData &&\n      this.tableData.length > 0 &&\n      this._selectedRowIds.length < this.tableData.length\n    );\n  }\n  /** @ignore */\n  public readonly branded: boolean = false;\n\n  /** @ignore */\n  public get tableSpan(): number {\n    return this.canSelectRows\n      ? this.columnDefs.length + 1\n      : this.columnDefs.length;\n  }\n\n  private _canSelectRows = false;\n  private _canSelectAllRows = false;\n  private _selectedRowIds: (string | number)[] = [];\n  private readonly _inputChange = new EventEmitter<ITableEventPayload>();\n\n  constructor(\n    private readonly _datePipe: DatePipe,\n    private readonly _percentPipe: PercentPipe,\n    private readonly _decmialPipe: DecimalPipe,\n    private readonly _changeDetectorRef: ChangeDetectorRef,\n    @Optional() @Host() private _branded: BrandedDirective\n  ) {\n    this.branded = _branded ? true : false;\n    this._inputChange\n      .pipe(debounceTime(DEBOUNCE_TIME))\n      .subscribe(this.inputChange);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['selectedRowIds'] || changes['tableData']) {\n      if (\n        !this.tableData ||\n        !this.tableData.length ||\n        !this.selectedRowIds ||\n        !this.selectedRowIds.length\n      ) {\n        this.allSelected = false;\n      } else {\n        this.allSelected = this.selectedRowIds.length >= this.tableData.length;\n      }\n    }\n  }\n\n  public getMailToValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): string {\n    const { columnType, truncated: truncated } =\n      this._getColumnDefByIndex(columnIndex);\n    let value = this._getValue(columnIndex, currentRow);\n\n    if (columnType !== TableColumnType.Email) {\n      return String(value);\n    }\n    value = value ? `mailto:${value}` : value;\n\n    return String(value);\n  }\n\n  public getStringValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): string {\n    const value = this.getValue(columnIndex, currentRow);\n\n    if (Array.isArray(value)) {\n      return value.join(';');\n    }\n\n    return String(value);\n  }\n\n  public getValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): string | string[] {\n    const { columnType, truncated: truncated } =\n      this._getColumnDefByIndex(columnIndex);\n    let value = this._getValue(columnIndex, currentRow);\n\n    switch (columnType) {\n      case TableColumnType.Decimal: {\n        value = this._decmialPipe.transform(Number(value) || 0) || '';\n        break;\n      }\n      case TableColumnType.Date: {\n        const date = new Date(String(value));\n        const validDate = date instanceof Date && !isNaN(date.getTime());\n        value = validDate\n          ? this._datePipe.transform(date, 'MM/dd/yyyy') || ''\n          : String(value);\n        break;\n      }\n      case TableColumnType.DateTime: {\n        const dateTime = new Date(String(value));\n        const validDateTime =\n          dateTime instanceof Date && !isNaN(dateTime.getTime());\n        value = validDateTime\n          ? this._datePipe.transform(dateTime, 'MM/dd/yyyy h:mm:ss a') || ''\n          : String(value);\n        break;\n      }\n      case TableColumnType.Link: {\n        value = String(value).replace(/(^\\w+:|^)\\/\\//, '');\n        break;\n      }\n      case TableColumnType.Percentage: {\n        value = this._percentPipe.transform(Number(value) || 0) || '';\n        break;\n      }\n      case TableColumnType.Url: {\n        if (!/(http(s?)):\\/\\//i.test(String(value))) {\n          value = `https://${value}`;\n        }\n        break;\n      }\n      case TableColumnType.Text: {\n        if (Array.isArray(value)) {\n          value = value.join('; ');\n        }\n\n        if (!truncated) {\n          return value;\n        }\n\n        const truncateString = (string = '', maxLength = truncated) =>\n          string.length > maxLength\n            ? `${string.substring(0, maxLength)}…`\n            : string;\n\n        !!truncated\n          ? (value = truncateString(String(value), truncated))\n          : value;\n        break;\n      }\n      case TableColumnType.MultiSelect:\n        if (typeof value === 'string') {\n          value = value.split(';')?.map(v => v.trim()) || [];\n        }\n        return value;\n    }\n\n    return String(value);\n  }\n\n  public getRawValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): ITableRowItemValueTypes<ITableRowItemValue> {\n    const { field } = this._getColumnDefByIndex(columnIndex);\n\n    if (!field) {\n      return '';\n    }\n\n    return currentRow[field] || '';\n  }\n\n  public getCellColor(\n    columnDefinition: TableColumnDef,\n    item: ITableRowItem\n  ): string {\n    return TableThemeHelper.getCellColor(columnDefinition, item);\n  }\n\n  public getTheme(\n    columnDefinition: TableColumnDef,\n    item: ITableRowItem\n  ): ComponentTheme {\n    return (\n      TableThemeHelper.getTheme(columnDefinition, item) ||\n      ComponentTheme.Primary\n    );\n  }\n\n  public isSortedColumn(columnIndex: number): boolean {\n    return columnIndex === this.sortColumnIndex;\n  }\n\n  public isRowSelected(id: string | number): boolean {\n    return this.selectedRowIds.includes(id);\n  }\n\n  public handleSelectAll(event: CheckboxChangeEvent): void {\n    if (!this.canSelectAllRows || !this.tableData) {\n      return;\n    }\n\n    if (event.checked) {\n      this._selectedRowIds = this.tableData?.map(row => row.id) || [];\n    } else {\n      this._selectedRowIds = [];\n    }\n\n    this._selectedRowIds.sort();\n    this.allSelected = this.selectedRowIds.length >= this.tableData.length;\n\n    this.rowSelect.emit(this.selectedRowIds);\n  }\n\n  public handleSort(columnIndex: number): void {\n    if (columnIndex === this.sortColumnIndex) {\n      this.sortDirection = this.sortDirection === 'asc' ? 'desc' : 'asc';\n    } else {\n      this.sortColumnIndex = columnIndex;\n      this.sortDirection = 'asc';\n    }\n\n    const field = this._getColumnDefByIndex(columnIndex).field || '';\n\n    this.sortBy.emit({\n      columnIndex,\n      field,\n      direction: this.sortDirection\n    });\n  }\n\n  public handleRowSelect(\n    event: CheckboxChangeEvent,\n    rowId: number | string\n  ): void {\n    if (!this.canSelectRows) {\n      return;\n    }\n\n    if (event.checked && !this._selectedRowIds.includes(rowId)) {\n      this._selectedRowIds.push(rowId);\n    } else if (!event.checked && this._selectedRowIds.includes(rowId)) {\n      const idx = this._selectedRowIds.indexOf(rowId);\n      if (idx > -1) {\n        this._selectedRowIds.splice(idx, 1);\n      }\n    }\n\n    if (this._selectedRowIds.length) {\n      this._selectedRowIds.sort();\n    }\n\n    this.allSelected = this.selectedRowIds.length >= this.tableData.length;\n    this.rowSelect.emit(this.selectedRowIds);\n  }\n\n  public handleCellValueChange(\n    columnIndex: number,\n    rowIndex: number,\n    value: string | number | boolean | string[]\n  ): void {\n    const { field, columnType } = this._getColumnDefByIndex(columnIndex);\n    let currentValue: string | number | boolean | string[] = value;\n\n    if (columnType !== TableColumnType.Boolean && !Array.isArray(value)) {\n      currentValue = isNaN(Number(value)) ? value : Number(value);\n    }\n    const item = this.tableData[rowIndex];\n\n    setNestedValue(item, String(field), currentValue);\n\n    this._inputChange.emit({\n      columnIndex,\n      item,\n      value: currentValue\n    });\n\n    this._changeDetectorRef.detectChanges();\n  }\n\n  public handleLinkClick(columnIndex: number, item: ITableRowItem): void {\n    this.linkClick.emit({\n      item,\n      columnIndex\n    });\n  }\n\n  public handleActionClick(\n    columnIndex: number,\n    item: ITableRowItem,\n    actionApiName: string\n  ) {\n    this.rowActionClick.emit({\n      item,\n      columnIndex,\n      actionApiName\n    });\n  }\n\n  protected columnDefIsActions(\n    columnDef: TableColumnDef<any>\n  ): columnDef is ITableActionsColumnDef<any> {\n    return columnDef.columnType === TableColumnType.Actions;\n  }\n\n  private _getColumnDefByIndex(columnIndex: number): TableColumnDef {\n    return this.columnDefs[columnIndex];\n  }\n\n  private _getValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): string | string[] {\n    try {\n      const { field, valueGetter } = this._getColumnDefByIndex(columnIndex);\n\n      const value: string | string[] = valueGetter\n        ? valueGetter(currentRow)\n        : (getNestedValue(currentRow, String(field), '') as string | string[]);\n\n      return value || '';\n    } catch (e) {\n      return '';\n    }\n  }\n}\n","@if (tableData) {\n<table impdcTable [striped]=\"striped\">\n  <thead>\n    @if (!!bulkActions) {\n    <tr>\n      <th [attr.colspan]=\"tableSpan\" scope=\"col\" class=\"bulk-action-column\">\n        <ng-content select=\"impdc-table-bulk-actions\"></ng-content>\n        <ng-content select=\"[impdcTableBulkActions]\"></ng-content>\n      </th>\n    </tr>\n    }\n    <tr>\n      @if (canSelectRows) {\n      <th\n        scope=\"col\"\n        [ngClass]=\"{\n          'heading-below-bulk-actions': !!bulkActions\n        }\">\n        @if (canSelectAllRows) {\n        <div>\n          <impdc-checkbox\n            ngModel\n            [checked]=\"allSelected\"\n            [indeterminate]=\"someSelected\"\n            (change)=\"handleSelectAll($event)\"></impdc-checkbox>\n        </div>\n        }\n      </th>\n      } @for (columnDef of columnDefs; track columnDef; let columnIndex =\n      $index) {\n      <th\n        scope=\"col\"\n        [ngClass]=\"{\n          'sorted-column': isSortedColumn(columnIndex),\n          'sortable-column': columnDef.sorted,\n          'heading-below-bulk-actions': !!bulkActions\n        }\"\n        (click)=\"handleSort(columnIndex)\">\n        <impdc-column-heading\n          [isSortable]=\"columnDef.sorted || false\"\n          [columnIndex]=\"columnIndex\"\n          [sortColumnIndex]=\"sortColumnIndex\"\n          [direction]=\"sortDirection\"\n          [text]=\"columnDef.title\"\n          (sort)=\"handleSort($event)\">\n        </impdc-column-heading>\n      </th>\n      }\n    </tr>\n  </thead>\n  <tbody>\n    @if (loading) {\n    <tr>\n      <td [attr.colspan]=\"tableSpan\" class=\"data-loading\">\n        <impdc-spinner></impdc-spinner>\n      </td>\n    </tr>\n    } @else { @for (row of tableData; track row; let rowIndex = $index) {\n    <tr>\n      @if (canSelectRows) {\n      <td>\n        <div class=\"select-column\">\n          <impdc-checkbox\n            [ngModel]=\"isRowSelected(row.id)\"\n            (change)=\"handleRowSelect($event, row.id)\"></impdc-checkbox>\n        </div>\n      </td>\n      }\n      <td\n        *ngFor=\"let columnDef of columnDefs; index as colIndex; last as isLast\"\n        [ngClass]=\"{\n          'col-no-padding': !!columnDef.noPadding,\n          'actions-column': columnDef.columnType === cellType.Actions\n        }\">\n        <div>\n          @switch (columnDef.columnType) { @case (cellType.Badge) {\n          <span>\n            <impdc-badge\n              [text]=\"getStringValue(colIndex, row)\"\n              [theme]=\"getTheme(columnDef, row)\">\n            </impdc-badge>\n          </span>\n          } @case (cellType.Link) {\n          <span (click)=\"handleLinkClick(colIndex, row)\">\n            @if (!branded) {\n            <a>\n              {{ getValue(colIndex, row) }}\n            </a>\n            } @else {\n            <a impdcBranded>\n              {{ getValue(colIndex, row) }}\n            </a>\n            }\n          </span>\n          } @case (cellType.Url) {\n          <span>\n            @if (!branded) {\n            <a target=\"_blank\" [attr.href]=\"getValue(colIndex, row)\">\n              {{ getValue(colIndex, row) }}\n            </a>\n            } @else {\n            <a\n              impdcBranded\n              target=\"_blank\"\n              [attr.href]=\"getValue(colIndex, row)\">\n              {{ getValue(colIndex, row) }}\n            </a>\n            }\n          </span>\n          } @case (cellType.Email) {\n          <span>\n            @if (!branded) {\n            <a\n              target=\"_blank\"\n              [attr.href]=\"'mailto:' + getValue(colIndex, row)\">\n              {{ getValue(colIndex, row) }}\n            </a>\n            } @else {\n            <a impdcBranded [attr.href]=\"getMailToValue(colIndex, row)\">\n              {{ getValue(colIndex, row) }}\n            </a>\n            }\n          </span>\n          } @case (cellType.Input) {\n          <span>\n            <input\n              impdcInput\n              type=\"text\"\n              class=\"{{ getCellColor(columnDef, row) }}\"\n              [ngModel]=\"getValue(colIndex, row)\"\n              (ngModelChange)=\"\n                handleCellValueChange(colIndex, rowIndex, $event)\n              \" />\n          </span>\n          } @case (cellType.Boolean) {\n          <span>\n            @if (columnDef.disabled && getValue(colIndex, row) === 'true') {\n            <span\n              impdc-icon\n              name=\"check\"\n              class=\"{{ getCellColor(columnDef, row) }}\"></span>\n            } @else if (!columnDef.disabled) {\n            <impdc-checkbox\n              [checked]=\"getValue(colIndex, row) === 'true'\"\n              [isSwitch]=\"true\"\n              (change)=\"\n                handleCellValueChange(colIndex, rowIndex, $event.checked)\n              \"></impdc-checkbox>\n            }\n          </span>\n          } @case (cellType.SingleSelect) {\n          <span>\n            <impdc-select\n              [ngModel]=\"getValue(colIndex, row)\"\n              [disabled]=\"columnDef.disabled || false\"\n              [placeholder]=\"selectPlaceholder\"\n              (selectionChange)=\"\n                handleCellValueChange(colIndex, rowIndex, $event.value)\n              \">\n              @if (selectPlaceholder) {\n              <impdc-select-option value [label]=\"selectPlaceholder\">\n              </impdc-select-option>\n              } @for (value of (columnDef.values || []); track value) {\n              <impdc-select-option\n                [value]=\"value.value\"\n                [label]=\"value.label\"></impdc-select-option>\n              }\n            </impdc-select>\n          </span>\n          } @case (cellType.MultiSelect) {\n          <span>\n            <impdc-select\n              [ngModel]=\"getValue(colIndex, row)\"\n              [disabled]=\"columnDef.disabled || false\"\n              [placeholder]=\"selectPlaceholder\"\n              multiple=\"true\"\n              (selectionChange)=\"\n                handleCellValueChange(colIndex, rowIndex, $event.value)\n              \">\n              @for (value of (columnDef.values || []); track value) {\n              <impdc-select-option\n                [value]=\"value.value\"\n                [label]=\"value.label\"></impdc-select-option>\n              }\n            </impdc-select>\n          </span>\n          } @case (cellType.CellRender) {\n          <span class=\"{{ getCellColor(columnDef, row) }}\">\n            <ng-template\n              impdcTableInjectComponent\n              [columnDef]=\"columnDef\"\n              [rowItem]=\"row\"\n              [customCellComponents]=\"customCellComponents || {}\"\n              [value]=\"getRawValue(colIndex, row)\"></ng-template>\n          </span>\n          } @case (cellType.Icon) {\n          <span>\n            <span\n              impdc-icon\n              [name]=\"columnDef.iconName\"\n              class=\"{{ getCellColor(columnDef, row) }}\"></span>\n          </span>\n          } @case (cellType.Actions) {\n          <span>\n            <!-- will always return 'true', but needed to satisfy the type engine -->\n            @if (columnDefIsActions(columnDef)) {\n            <impdc-row-actions\n              [columnDef]=\"columnDef\"\n              [rowItem]=\"row\"\n              [lastColumn]=\"isLast\"\n              (actionClick)=\"\n                handleActionClick(colIndex, row, $event)\n              \"></impdc-row-actions>\n            }\n          </span>\n          } @default {\n          <span class=\"{{ getCellColor(columnDef, row) }}\">\n            {{ getValue(colIndex, row) }}\n          </span>\n          } }\n        </div>\n      </td>\n    </tr>\n    } @empty {\n    <tr>\n      <td [attr.colspan]=\"tableSpan\" class=\"no-data\">\n        <ng-content select=\"[noData]\"></ng-content>\n      </td>\n    </tr>\n    } }\n  </tbody>\n  <tfoot>\n    @if (paginationComponent) {\n    <tr>\n      <td [attr.colspan]=\"tableSpan\">\n        <ng-content\n          select=\"impdc-pagination, div[impdc-pagination]\"></ng-content>\n      </td>\n    </tr>\n    }\n  </tfoot>\n</table>\n}\n"]}
@@ -0,0 +1,46 @@
1
+ import { Directive, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class TableInjectComponentDirective {
4
+ constructor(_viewContainerRef, _componentFactoryResolver) {
5
+ this._viewContainerRef = _viewContainerRef;
6
+ this._componentFactoryResolver = _componentFactoryResolver;
7
+ this.value = '';
8
+ this.rowItem = { id: 0 };
9
+ this.customCellComponents = {};
10
+ }
11
+ ngOnInit() {
12
+ this._renderCustomCell();
13
+ }
14
+ _renderCustomCell() {
15
+ const { cellRendererComponent, cellRendererParams } = this.columnDef;
16
+ if (!cellRendererComponent) {
17
+ return;
18
+ }
19
+ const item = this.rowItem;
20
+ const customCellComponent = this.customCellComponents[cellRendererComponent];
21
+ this._viewContainerRef.clear();
22
+ const componentFactory = this._componentFactoryResolver.resolveComponentFactory(customCellComponent);
23
+ const componentRef = this._viewContainerRef.createComponent(componentFactory);
24
+ componentRef.instance.value = this.value;
25
+ componentRef.instance.rowItem = item;
26
+ componentRef.instance.params = cellRendererParams;
27
+ }
28
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: TableInjectComponentDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive }); }
29
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.1", type: TableInjectComponentDirective, selector: "[impdcTableInjectComponent]", inputs: { columnDef: "columnDef", value: "value", rowItem: "rowItem", customCellComponents: "customCellComponents" }, ngImport: i0 }); }
30
+ }
31
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: TableInjectComponentDirective, decorators: [{
32
+ type: Directive,
33
+ args: [{
34
+ selector: '[impdcTableInjectComponent]'
35
+ }]
36
+ }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }], propDecorators: { columnDef: [{
37
+ type: Input,
38
+ args: [{ required: true }]
39
+ }], value: [{
40
+ type: Input
41
+ }], rowItem: [{
42
+ type: Input
43
+ }], customCellComponents: [{
44
+ type: Input
45
+ }] } });
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtaW5qZWN0LWNvbXBvbmVudC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL3RhYmxlL2RpcmVjdGl2ZXMvdGFibGUtaW5qZWN0LWNvbXBvbmVudC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFDVCxLQUFLLEVBR04sTUFBTSxlQUFlLENBQUM7O0FBY3ZCLE1BQU0sT0FBTyw2QkFBNkI7SUFNeEMsWUFDbUIsaUJBQW1DLEVBQ25DLHlCQUFtRDtRQURuRCxzQkFBaUIsR0FBakIsaUJBQWlCLENBQWtCO1FBQ25DLDhCQUF5QixHQUF6Qix5QkFBeUIsQ0FBMEI7UUFOdEQsVUFBSyxHQUFnRCxFQUFFLENBQUM7UUFDeEQsWUFBTyxHQUFrQixFQUFFLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQztRQUNuQyx5QkFBb0IsR0FBa0MsRUFBRSxDQUFDO0lBS3RFLENBQUM7SUFFRyxRQUFRO1FBQ2IsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVPLGlCQUFpQjtRQUN2QixNQUFNLEVBQUUscUJBQXFCLEVBQUUsa0JBQWtCLEVBQUUsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQ3JFLElBQUksQ0FBQyxxQkFBcUIsRUFBRTtZQUMxQixPQUFPO1NBQ1I7UUFFRCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDO1FBQzFCLE1BQU0sbUJBQW1CLEdBQ3ZCLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBRW5ELElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUUvQixNQUFNLGdCQUFnQixHQUNwQixJQUFJLENBQUMseUJBQXlCLENBQUMsdUJBQXVCLENBQ3BELG1CQUFtQixDQUNwQixDQUFDO1FBQ0osTUFBTSxZQUFZLEdBQ2hCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxlQUFlLENBQWdCLGdCQUFnQixDQUFDLENBQUM7UUFFMUUsWUFBWSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQztRQUN6QyxZQUFZLENBQUMsUUFBUSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDckMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsa0JBQWtCLENBQUM7SUFDcEQsQ0FBQzs4R0FyQ1UsNkJBQTZCO2tHQUE3Qiw2QkFBNkI7OzJGQUE3Qiw2QkFBNkI7a0JBSHpDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDZCQUE2QjtpQkFDeEM7NEhBRW1DLFNBQVM7c0JBQTFDLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO2dCQUNULEtBQUs7c0JBQXBCLEtBQUs7Z0JBQ1UsT0FBTztzQkFBdEIsS0FBSztnQkFDVSxvQkFBb0I7c0JBQW5DLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsXG4gIERpcmVjdGl2ZSxcbiAgSW5wdXQsXG4gIE9uSW5pdCxcbiAgVmlld0NvbnRhaW5lclJlZlxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtcbiAgSUNlbGxSZW5kZXJlcixcbiAgSUN1c3RvbUNlbGxSZW5kZXJlckNvbXBvbmVudHMsXG4gIElUYWJsZVJvd0l0ZW0sXG4gIElUYWJsZVJvd0l0ZW1WYWx1ZSxcbiAgSVRhYmxlUm93SXRlbVZhbHVlVHlwZXMsXG4gIFRhYmxlQ29sdW1uRGVmXG59IGZyb20gJy4uL2ludGVyZmFjZXMvaW5kZXgnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbaW1wZGNUYWJsZUluamVjdENvbXBvbmVudF0nXG59KVxuZXhwb3J0IGNsYXNzIFRhYmxlSW5qZWN0Q29tcG9uZW50RGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KHsgcmVxdWlyZWQ6IHRydWUgfSkgcHVibGljIGNvbHVtbkRlZiE6IFRhYmxlQ29sdW1uRGVmO1xuICBASW5wdXQoKSBwdWJsaWMgdmFsdWU6IElUYWJsZVJvd0l0ZW1WYWx1ZVR5cGVzPElUYWJsZVJvd0l0ZW1WYWx1ZT4gPSAnJztcbiAgQElucHV0KCkgcHVibGljIHJvd0l0ZW06IElUYWJsZVJvd0l0ZW0gPSB7IGlkOiAwIH07XG4gIEBJbnB1dCgpIHB1YmxpYyBjdXN0b21DZWxsQ29tcG9uZW50czogSUN1c3RvbUNlbGxSZW5kZXJlckNvbXBvbmVudHMgPSB7fTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IF92aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgX2NvbXBvbmVudEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyXG4gICkge31cblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5fcmVuZGVyQ3VzdG9tQ2VsbCgpO1xuICB9XG5cbiAgcHJpdmF0ZSBfcmVuZGVyQ3VzdG9tQ2VsbCgpOiB2b2lkIHtcbiAgICBjb25zdCB7IGNlbGxSZW5kZXJlckNvbXBvbmVudCwgY2VsbFJlbmRlcmVyUGFyYW1zIH0gPSB0aGlzLmNvbHVtbkRlZjtcbiAgICBpZiAoIWNlbGxSZW5kZXJlckNvbXBvbmVudCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IGl0ZW0gPSB0aGlzLnJvd0l0ZW07XG4gICAgY29uc3QgY3VzdG9tQ2VsbENvbXBvbmVudCA9XG4gICAgICB0aGlzLmN1c3RvbUNlbGxDb21wb25lbnRzW2NlbGxSZW5kZXJlckNvbXBvbmVudF07XG5cbiAgICB0aGlzLl92aWV3Q29udGFpbmVyUmVmLmNsZWFyKCk7XG5cbiAgICBjb25zdCBjb21wb25lbnRGYWN0b3J5ID1cbiAgICAgIHRoaXMuX2NvbXBvbmVudEZhY3RvcnlSZXNvbHZlci5yZXNvbHZlQ29tcG9uZW50RmFjdG9yeTxJQ2VsbFJlbmRlcmVyPihcbiAgICAgICAgY3VzdG9tQ2VsbENvbXBvbmVudFxuICAgICAgKTtcbiAgICBjb25zdCBjb21wb25lbnRSZWYgPVxuICAgICAgdGhpcy5fdmlld0NvbnRhaW5lclJlZi5jcmVhdGVDb21wb25lbnQ8SUNlbGxSZW5kZXJlcj4oY29tcG9uZW50RmFjdG9yeSk7XG5cbiAgICBjb21wb25lbnRSZWYuaW5zdGFuY2UudmFsdWUgPSB0aGlzLnZhbHVlO1xuICAgIGNvbXBvbmVudFJlZi5pbnN0YW5jZS5yb3dJdGVtID0gaXRlbTtcbiAgICBjb21wb25lbnRSZWYuaW5zdGFuY2UucGFyYW1zID0gY2VsbFJlbmRlcmVyUGFyYW1zO1xuICB9XG59XG4iXX0=
@@ -15,10 +15,10 @@ export class TableDirective {
15
15
  get classTableStriped() {
16
16
  return this.striped;
17
17
  }
18
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: TableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
19
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.1", type: TableDirective, selector: "table[impdcTable]", inputs: { striped: "striped" }, host: { properties: { "class.table": "this.classTable", "class.table-striped": "this.classTableStriped" } }, ngImport: i0 }); }
18
20
  }
19
- TableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
20
- TableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: TableDirective, selector: "table[impdcTable]", inputs: { striped: "striped" }, host: { properties: { "class.table": "this.classTable", "class.table-striped": "this.classTableStriped" } }, ngImport: i0 });
21
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableDirective, decorators: [{
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: TableDirective, decorators: [{
22
22
  type: Directive,
23
23
  args: [{
24
24
  selector: 'table[impdcTable]'
@@ -32,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
32
32
  type: HostBinding,
33
33
  args: ['class.table-striped']
34
34
  }] } });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWNvbXBvbmVudHMvc3JjL2xpYi90YWJsZS9kaXJlY3RpdmVzL3RhYmxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTlEOzs7R0FHRztBQUlILE1BQU0sT0FBTyxjQUFjO0lBSDNCO1FBSUU7O1dBRUc7UUFFSCxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBRW9CLGVBQVUsR0FBRyxJQUFJLENBQUM7S0FLdkQ7SUFIQyxJQUFnRCxpQkFBaUI7UUFDL0QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7OzRHQVhVLGNBQWM7Z0dBQWQsY0FBYzs0RkFBZCxjQUFjO2tCQUgxQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxtQkFBbUI7aUJBQzlCOzhCQU1DLE9BQU87c0JBRE4sS0FBSztnQkFHOEIsVUFBVTtzQkFBN0MsV0FBVzt1QkFBQyxhQUFhO2dCQUVzQixpQkFBaUI7c0JBQWhFLFdBQVc7dUJBQUMscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0QmluZGluZywgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBUaGUgYFRhYmxlRGlyZWN0aXZlYCAoYDx0YWJsZSBpbXBkY1RhYmxlYCkgdGhhdCBhZGRzIEhleCBzdHlsaW5nIHRvIGEgYHRhYmxlYCBlbGVtZW50LlxuICogVG8gdXNlLCBpbXBvcnQgYFRhYmxlTW9kdWxlYCBvciBhbm90aGVyIG1vZHVsZSB0aGF0IGltcG9ydHMgYW5kIGV4cG9ydHMgdGhhdCBtb2R1bGUgZnJvbSBgQGltcGFydG5lci9kZXNpZ24tY29tcG9uZW50c2AuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ3RhYmxlW2ltcGRjVGFibGVdJ1xufSlcbmV4cG9ydCBjbGFzcyBUYWJsZURpcmVjdGl2ZSB7XG4gIC8qKlxuICAgKiBTdHJpcGVzIGV2ZXJ5IG90aGVyIHJvdyBpbiBhIHNsaWdodGx5IGRhcmtlciBiYWNrZ3JvdW5kIGNvbG9yLlxuICAgKi9cbiAgQElucHV0KClcbiAgc3RyaXBlZCA9IGZhbHNlO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MudGFibGUnKSBwcml2YXRlIGNsYXNzVGFibGUgPSB0cnVlO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MudGFibGUtc3RyaXBlZCcpIHByaXZhdGUgZ2V0IGNsYXNzVGFibGVTdHJpcGVkKCkge1xuICAgIHJldHVybiB0aGlzLnN0cmlwZWQ7XG4gIH1cbn1cbiJdfQ==
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWNvbXBvbmVudHMvc3JjL2xpYi90YWJsZS9kaXJlY3RpdmVzL3RhYmxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTlEOzs7R0FHRztBQUlILE1BQU0sT0FBTyxjQUFjO0lBSDNCO1FBSUU7O1dBRUc7UUFFSCxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBRW9CLGVBQVUsR0FBRyxJQUFJLENBQUM7S0FLdkQ7SUFIQyxJQUFnRCxpQkFBaUI7UUFDL0QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7OEdBWFUsY0FBYztrR0FBZCxjQUFjOzsyRkFBZCxjQUFjO2tCQUgxQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxtQkFBbUI7aUJBQzlCOzhCQU1DLE9BQU87c0JBRE4sS0FBSztnQkFHOEIsVUFBVTtzQkFBN0MsV0FBVzt1QkFBQyxhQUFhO2dCQUVzQixpQkFBaUI7c0JBQWhFLFdBQVc7dUJBQUMscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0QmluZGluZywgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBUaGUgYFRhYmxlRGlyZWN0aXZlYCAoYDx0YWJsZSBpbXBkY1RhYmxlYCkgdGhhdCBhZGRzIEhleCBzdHlsaW5nIHRvIGEgYHRhYmxlYCBlbGVtZW50LlxuICogVG8gdXNlLCBpbXBvcnQgYFRhYmxlTW9kdWxlYCBvciBhbm90aGVyIG1vZHVsZSB0aGF0IGltcG9ydHMgYW5kIGV4cG9ydHMgdGhhdCBtb2R1bGUgZnJvbSBgQGltcGFydG5lci9kZXNpZ24tY29tcG9uZW50c2AuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ3RhYmxlW2ltcGRjVGFibGVdJ1xufSlcbmV4cG9ydCBjbGFzcyBUYWJsZURpcmVjdGl2ZSB7XG4gIC8qKlxuICAgKiBTdHJpcGVzIGV2ZXJ5IG90aGVyIHJvdyBpbiBhIHNsaWdodGx5IGRhcmtlciBiYWNrZ3JvdW5kIGNvbG9yLlxuICAgKi9cbiAgQElucHV0KClcbiAgc3RyaXBlZCA9IGZhbHNlO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MudGFibGUnKSBwcml2YXRlIGNsYXNzVGFibGUgPSB0cnVlO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MudGFibGUtc3RyaXBlZCcpIHByaXZhdGUgZ2V0IGNsYXNzVGFibGVTdHJpcGVkKCkge1xuICAgIHJldHVybiB0aGlzLnN0cmlwZWQ7XG4gIH1cbn1cbiJdfQ==