@ardium-ui/ui 1.0.2 → 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 (390) hide show
  1. package/esm2022/lib/_internal/boolean-component.mjs +28 -42
  2. package/esm2022/lib/_internal/clear-button/clear-button.component.mjs +5 -5
  3. package/esm2022/lib/_internal/clear-button/clear-button.module.mjs +4 -4
  4. package/esm2022/lib/_internal/disablable-component.mjs +24 -22
  5. package/esm2022/lib/_internal/focusable-component.mjs +12 -25
  6. package/esm2022/lib/_internal/item-storages/dropdown-item-storage.mjs +172 -169
  7. package/esm2022/lib/_internal/item-storages/simple-item-storage.mjs +115 -120
  8. package/esm2022/lib/_internal/item-storages/simplest-item-storage.mjs +56 -53
  9. package/esm2022/lib/_internal/models/pagination.model.mjs +72 -106
  10. package/esm2022/lib/_internal/ngmodel-component.mjs +5 -5
  11. package/esm2022/lib/_internal/queue.mjs +1 -1
  12. package/esm2022/lib/_internal/selectable-list-component.mjs +74 -98
  13. package/esm2022/lib/badge/badge.directive.mjs +70 -99
  14. package/esm2022/lib/badge/badge.module.mjs +4 -4
  15. package/esm2022/lib/badge/index.mjs +4 -0
  16. package/esm2022/lib/buttons/_button-base.mjs +13 -35
  17. package/esm2022/lib/buttons/button/button.component.mjs +22 -37
  18. package/esm2022/lib/buttons/button/button.module.mjs +4 -4
  19. package/esm2022/lib/buttons/button/index.mjs +3 -0
  20. package/esm2022/lib/buttons/fab/fab.component.mjs +16 -28
  21. package/esm2022/lib/buttons/fab/fab.module.mjs +4 -4
  22. package/esm2022/lib/buttons/fab/index.mjs +3 -0
  23. package/esm2022/lib/buttons/icon-button/icon-button.component.mjs +17 -25
  24. package/esm2022/lib/buttons/icon-button/icon-button.module.mjs +4 -4
  25. package/esm2022/lib/buttons/icon-button/index.mjs +3 -0
  26. package/esm2022/lib/card/card.children.mjs +32 -33
  27. package/esm2022/lib/card/card.component.mjs +14 -17
  28. package/esm2022/lib/card/card.module.mjs +4 -4
  29. package/esm2022/lib/card/index.mjs +5 -0
  30. package/esm2022/lib/checkbox/checkbox.component.mjs +33 -46
  31. package/esm2022/lib/checkbox/checkbox.module.mjs +4 -4
  32. package/esm2022/lib/checkbox/index.mjs +4 -0
  33. package/esm2022/lib/checkbox-list/checkbox-list.component.mjs +31 -57
  34. package/esm2022/lib/checkbox-list/checkbox-list.module.mjs +4 -4
  35. package/esm2022/lib/checkbox-list/index.mjs +4 -0
  36. package/esm2022/lib/chip/chip.component.mjs +22 -42
  37. package/esm2022/lib/chip/chip.module.mjs +4 -4
  38. package/esm2022/lib/chip/deletable-chip/deletable-chip.component.mjs +28 -53
  39. package/esm2022/lib/chip/index.mjs +5 -0
  40. package/esm2022/lib/chip/selectable-chip/selectable-chip.component.mjs +25 -49
  41. package/esm2022/lib/color/color-display/color-display.component.mjs +15 -32
  42. package/esm2022/lib/color/color-display/color-display.module.mjs +4 -4
  43. package/esm2022/lib/color/color-display/index.mjs +4 -0
  44. package/esm2022/lib/color/color-picker/color-picker.types.mjs +1 -1
  45. package/esm2022/lib/dialog/dialog.component.mjs +54 -130
  46. package/esm2022/lib/dialog/dialog.directives.mjs +3 -3
  47. package/esm2022/lib/dialog/dialog.module.mjs +4 -4
  48. package/esm2022/lib/dialog/dialog.types.mjs +1 -1
  49. package/esm2022/lib/dialog/index.mjs +5 -0
  50. package/esm2022/lib/divider/divider.component.mjs +9 -14
  51. package/esm2022/lib/divider/divider.module.mjs +4 -4
  52. package/esm2022/lib/divider/index.mjs +3 -0
  53. package/esm2022/lib/dropdown-panel/dropdown-panel.component.mjs +40 -59
  54. package/esm2022/lib/dropdown-panel/dropdown-panel.module.mjs +4 -4
  55. package/esm2022/lib/dropdown-panel/index.mjs +4 -0
  56. package/esm2022/lib/file-inputs/file-drop-area/file-drop-area.component.mjs +12 -17
  57. package/esm2022/lib/file-inputs/file-drop-area/file-drop-area.directives.mjs +9 -9
  58. package/esm2022/lib/file-inputs/file-drop-area/file-drop-area.module.mjs +6 -6
  59. package/esm2022/lib/file-inputs/file-drop-area/index.mjs +4 -0
  60. package/esm2022/lib/file-inputs/file-input/file-input.component.mjs +24 -50
  61. package/esm2022/lib/file-inputs/file-input/file-input.directives.mjs +18 -18
  62. package/esm2022/lib/file-inputs/file-input/file-input.module.mjs +4 -4
  63. package/esm2022/lib/file-inputs/file-input/index.mjs +4 -0
  64. package/esm2022/lib/file-inputs/file-input-base.mjs +38 -72
  65. package/esm2022/lib/form-field-frame/form-field-frame.component.mjs +20 -47
  66. package/esm2022/lib/form-field-frame/form-field-frame.directives.mjs +6 -6
  67. package/esm2022/lib/form-field-frame/form-field-frame.module.mjs +4 -4
  68. package/esm2022/lib/form-field-frame/index.mjs +4 -0
  69. package/esm2022/lib/icon/icon.component.mjs +32 -67
  70. package/esm2022/lib/icon/icon.module.mjs +4 -4
  71. package/esm2022/lib/icon/icon.pipe.mjs +3 -3
  72. package/esm2022/lib/icon/index.mjs +4 -0
  73. package/esm2022/lib/inputs/color-input/color-input.directives.mjs +24 -24
  74. package/esm2022/lib/inputs/color-input/color-input.types.mjs +1 -1
  75. package/esm2022/lib/inputs/digit-input/digit-input.component.mjs +65 -115
  76. package/esm2022/lib/inputs/digit-input/digit-input.model.mjs +83 -92
  77. package/esm2022/lib/inputs/digit-input/digit-input.module.mjs +4 -4
  78. package/esm2022/lib/inputs/digit-input/digit-input.types.mjs +1 -1
  79. package/esm2022/lib/inputs/digit-input/digit-input.utils.mjs +1 -1
  80. package/esm2022/lib/inputs/digit-input/index.mjs +4 -0
  81. package/esm2022/lib/inputs/hex-input/hex-input.component.mjs +59 -122
  82. package/esm2022/lib/inputs/hex-input/hex-input.directives.mjs +9 -9
  83. package/esm2022/lib/inputs/hex-input/hex-input.module.mjs +24 -8
  84. package/esm2022/lib/inputs/hex-input/index.mjs +4 -0
  85. package/esm2022/lib/inputs/hex-input.model.mjs +24 -33
  86. package/esm2022/lib/inputs/input/index.mjs +4 -0
  87. package/esm2022/lib/inputs/input/input.component.mjs +95 -154
  88. package/esm2022/lib/inputs/input/input.directives.mjs +16 -16
  89. package/esm2022/lib/inputs/input/input.module.mjs +21 -7
  90. package/esm2022/lib/inputs/input-transformers.mjs +6 -6
  91. package/esm2022/lib/inputs/input-utils.mjs +75 -94
  92. package/esm2022/lib/inputs/number-input/index.mjs +4 -0
  93. package/esm2022/lib/inputs/number-input/number-input.component.mjs +106 -170
  94. package/esm2022/lib/inputs/number-input/number-input.directives.mjs +3 -3
  95. package/esm2022/lib/inputs/number-input/number-input.module.mjs +4 -4
  96. package/esm2022/lib/inputs/password-input/index.mjs +5 -0
  97. package/esm2022/lib/inputs/password-input/password-input.component.mjs +74 -144
  98. package/esm2022/lib/inputs/password-input/password-input.directives.mjs +12 -12
  99. package/esm2022/lib/inputs/password-input/password-input.module.mjs +4 -4
  100. package/esm2022/lib/inputs/password-input/password-input.types.mjs +1 -1
  101. package/esm2022/lib/inputs/simple-input/index.mjs +4 -0
  102. package/esm2022/lib/inputs/simple-input/simple-input.component.mjs +57 -110
  103. package/esm2022/lib/inputs/simple-input/simple-input.directives.mjs +9 -9
  104. package/esm2022/lib/inputs/simple-input/simple-input.module.mjs +4 -4
  105. package/esm2022/lib/kbd/index.mjs +4 -0
  106. package/esm2022/lib/kbd/kbd.component.mjs +15 -29
  107. package/esm2022/lib/kbd/kbd.module.mjs +4 -4
  108. package/esm2022/lib/kbd/kbd.pipe.mjs +3 -3
  109. package/esm2022/lib/kbd-shortcut/index.mjs +3 -0
  110. package/esm2022/lib/kbd-shortcut/kbd-shortcut.component.mjs +23 -40
  111. package/esm2022/lib/kbd-shortcut/kbd-shortcut.module.mjs +4 -4
  112. package/esm2022/lib/modal/index.mjs +3 -0
  113. package/esm2022/lib/modal/modal.component.mjs +42 -83
  114. package/esm2022/lib/modal/modal.module.mjs +4 -4
  115. package/esm2022/lib/option/index.mjs +3 -0
  116. package/esm2022/lib/option/option.component.mjs +24 -46
  117. package/esm2022/lib/option/option.module.mjs +4 -4
  118. package/esm2022/lib/progress-bar/index.mjs +5 -0
  119. package/esm2022/lib/progress-bar/progress-bar.component.mjs +43 -81
  120. package/esm2022/lib/progress-bar/progress-bar.directive.mjs +3 -3
  121. package/esm2022/lib/progress-bar/progress-bar.module.mjs +4 -4
  122. package/esm2022/lib/progress-bar/progress-bar.types.mjs +1 -1
  123. package/esm2022/lib/progress-circle/index.mjs +5 -0
  124. package/esm2022/lib/progress-circle/progress-circle.component.mjs +33 -78
  125. package/esm2022/lib/progress-circle/progress-circle.directive.mjs +3 -3
  126. package/esm2022/lib/progress-circle/progress-circle.module.mjs +4 -4
  127. package/esm2022/lib/progress-circle/progress-circle.types.mjs +1 -1
  128. package/esm2022/lib/radio/index.mjs +4 -0
  129. package/esm2022/lib/radio/radio/radio.component.mjs +16 -25
  130. package/esm2022/lib/radio/radio-group.component.mjs +71 -85
  131. package/esm2022/lib/radio/radio.module.mjs +4 -4
  132. package/esm2022/lib/search-functions.mjs +7 -7
  133. package/esm2022/lib/segment/index.mjs +5 -0
  134. package/esm2022/lib/segment/segment.component.mjs +70 -137
  135. package/esm2022/lib/segment/segment.directives.mjs +4 -4
  136. package/esm2022/lib/segment/segment.module.mjs +4 -4
  137. package/esm2022/lib/select/index.mjs +5 -0
  138. package/esm2022/lib/select/select.component.mjs +348 -655
  139. package/esm2022/lib/select/select.directive.mjs +46 -46
  140. package/esm2022/lib/select/select.module.mjs +4 -4
  141. package/esm2022/lib/select/select.types.mjs +1 -1
  142. package/esm2022/lib/slide-toggle/index.mjs +4 -0
  143. package/esm2022/lib/slide-toggle/slide-toggle.component.mjs +19 -24
  144. package/esm2022/lib/slide-toggle/slide-toggle.module.mjs +4 -4
  145. package/esm2022/lib/slide-toggle/slide-toggle.types.mjs +5 -0
  146. package/esm2022/lib/slider/abstract-slider.mjs +111 -200
  147. package/esm2022/lib/slider/index.mjs +7 -0
  148. package/esm2022/lib/slider/range-slider/range-slider.component.mjs +26 -23
  149. package/esm2022/lib/slider/range-slider/range-slider.module.mjs +4 -4
  150. package/esm2022/lib/slider/slider.component.mjs +13 -10
  151. package/esm2022/lib/slider/slider.directive.mjs +3 -3
  152. package/esm2022/lib/slider/slider.module.mjs +7 -7
  153. package/esm2022/lib/slider/slider.types.mjs +1 -1
  154. package/esm2022/lib/snackbar/snackbar-ref.mjs +1 -1
  155. package/esm2022/lib/snackbar/snackbar.component.mjs +8 -8
  156. package/esm2022/lib/snackbar/snackbar.service.mjs +13 -12
  157. package/esm2022/lib/snackbar/snackbar.types.mjs +1 -1
  158. package/esm2022/lib/spinner/index.mjs +3 -0
  159. package/esm2022/lib/spinner/spinner.component.mjs +9 -13
  160. package/esm2022/lib/spinner/spinner.module.mjs +4 -4
  161. package/esm2022/lib/star/index.mjs +4 -0
  162. package/esm2022/lib/star/star-button/index.mjs +3 -0
  163. package/esm2022/lib/star/star-button/star-button.component.mjs +17 -26
  164. package/esm2022/lib/star/star-button/star-button.module.mjs +4 -4
  165. package/esm2022/lib/star/star-display/index.mjs +3 -0
  166. package/esm2022/lib/star/star-display/star-display.component.mjs +48 -55
  167. package/esm2022/lib/star/star-display/star-display.module.mjs +4 -4
  168. package/esm2022/lib/star/star-input/index.mjs +3 -0
  169. package/esm2022/lib/star/star-input/star-input.component.mjs +70 -106
  170. package/esm2022/lib/star/star-input/star-input.module.mjs +4 -4
  171. package/esm2022/lib/star/star.component.mjs +12 -20
  172. package/esm2022/lib/star/star.module.mjs +4 -4
  173. package/esm2022/lib/statebox/index.mjs +3 -0
  174. package/esm2022/lib/statebox/statebox.component.mjs +64 -102
  175. package/esm2022/lib/statebox/statebox.module.mjs +4 -4
  176. package/esm2022/lib/statebox/statebox.types.mjs +1 -1
  177. package/esm2022/lib/tabber/index.mjs +4 -0
  178. package/esm2022/lib/tabber/tab/tab.component.mjs +42 -0
  179. package/esm2022/lib/tabber/tabber.component.mjs +83 -0
  180. package/esm2022/lib/tabber/tabber.module.mjs +19 -0
  181. package/esm2022/lib/table/index.mjs +5 -0
  182. package/esm2022/lib/table/table-item-storage.mjs +204 -200
  183. package/esm2022/lib/table/table.component.mjs +184 -304
  184. package/esm2022/lib/table/table.directives.mjs +19 -21
  185. package/esm2022/lib/table/table.module.mjs +4 -4
  186. package/esm2022/lib/table/utils.mjs +1 -1
  187. package/esm2022/lib/table-from-csv/index.mjs +3 -0
  188. package/esm2022/lib/table-from-csv/table-from-csv.component.mjs +85 -29
  189. package/esm2022/lib/table-from-csv/table-from-csv.module.mjs +4 -4
  190. package/esm2022/lib/table-pagination/index.mjs +4 -0
  191. package/esm2022/lib/table-pagination/table-pagination.component.mjs +46 -114
  192. package/esm2022/lib/table-pagination/table-pagination.module.mjs +4 -4
  193. package/esm2022/lib/types/item-storage.types.mjs +1 -1
  194. package/esm2022/lib/types/utility.types.mjs +2 -2
  195. package/esm2022/public-api.mjs +58 -182
  196. package/fesm2022/ardium-ui-ui.mjs +7847 -11692
  197. package/fesm2022/ardium-ui-ui.mjs.map +1 -1
  198. package/lib/_internal/boolean-component.d.ts +8 -9
  199. package/lib/_internal/clear-button/clear-button.component.d.ts +1 -1
  200. package/lib/_internal/disablable-component.d.ts +12 -7
  201. package/lib/_internal/focusable-component.d.ts +5 -7
  202. package/lib/_internal/item-storages/dropdown-item-storage.d.ts +43 -41
  203. package/lib/_internal/item-storages/simple-item-storage.d.ts +28 -25
  204. package/lib/_internal/item-storages/simplest-item-storage.d.ts +14 -9
  205. package/lib/_internal/models/pagination.model.d.ts +38 -42
  206. package/lib/_internal/ngmodel-component.d.ts +1 -1
  207. package/lib/_internal/selectable-list-component.d.ts +30 -30
  208. package/lib/badge/badge.directive.d.ts +15 -20
  209. package/lib/badge/index.d.ts +3 -0
  210. package/lib/buttons/_button-base.d.ts +9 -12
  211. package/lib/buttons/button/button.component.d.ts +6 -8
  212. package/lib/buttons/button/index.d.ts +2 -0
  213. package/lib/buttons/fab/fab.component.d.ts +4 -6
  214. package/lib/buttons/fab/index.d.ts +2 -0
  215. package/lib/buttons/icon-button/icon-button.component.d.ts +6 -7
  216. package/lib/buttons/icon-button/index.d.ts +2 -0
  217. package/lib/card/card.children.d.ts +4 -3
  218. package/lib/card/card.component.d.ts +5 -4
  219. package/lib/card/index.d.ts +4 -0
  220. package/lib/checkbox/checkbox.component.d.ts +8 -12
  221. package/lib/checkbox/index.d.ts +3 -0
  222. package/lib/checkbox-list/checkbox-list.component.d.ts +22 -21
  223. package/lib/checkbox-list/index.d.ts +3 -0
  224. package/lib/chip/chip.component.d.ts +8 -10
  225. package/lib/chip/deletable-chip/deletable-chip.component.d.ts +11 -14
  226. package/lib/chip/index.d.ts +4 -0
  227. package/lib/chip/selectable-chip/selectable-chip.component.d.ts +10 -12
  228. package/lib/color/color-display/color-display.component.d.ts +6 -9
  229. package/lib/color/color-display/index.d.ts +3 -0
  230. package/lib/color/color-picker/color-picker.types.d.ts +4 -4
  231. package/lib/dialog/dialog.component.d.ts +25 -35
  232. package/lib/dialog/dialog.types.d.ts +2 -2
  233. package/lib/dialog/index.d.ts +4 -0
  234. package/lib/divider/divider.component.d.ts +3 -4
  235. package/lib/divider/index.d.ts +2 -0
  236. package/lib/dropdown-panel/dropdown-panel.component.d.ts +17 -20
  237. package/lib/dropdown-panel/index.d.ts +3 -0
  238. package/lib/file-inputs/file-drop-area/file-drop-area.component.d.ts +5 -4
  239. package/lib/file-inputs/file-drop-area/index.d.ts +3 -0
  240. package/lib/file-inputs/file-input/file-input.component.d.ts +13 -17
  241. package/lib/file-inputs/file-input/index.d.ts +3 -0
  242. package/lib/file-inputs/file-input-base.d.ts +13 -18
  243. package/lib/form-field-frame/form-field-frame.component.d.ts +12 -16
  244. package/lib/form-field-frame/index.d.ts +3 -0
  245. package/lib/icon/icon.component.d.ts +10 -19
  246. package/lib/icon/index.d.ts +3 -0
  247. package/lib/inputs/color-input/color-input.types.d.ts +2 -2
  248. package/lib/inputs/digit-input/digit-input.component.d.ts +22 -30
  249. package/lib/inputs/digit-input/digit-input.model.d.ts +8 -12
  250. package/lib/inputs/digit-input/digit-input.types.d.ts +4 -4
  251. package/lib/inputs/digit-input/digit-input.utils.d.ts +4 -5
  252. package/lib/inputs/digit-input/index.d.ts +3 -0
  253. package/lib/inputs/hex-input/hex-input.component.d.ts +32 -38
  254. package/lib/inputs/hex-input/index.d.ts +3 -0
  255. package/lib/inputs/hex-input.model.d.ts +10 -11
  256. package/lib/inputs/input/index.d.ts +3 -0
  257. package/lib/inputs/input/input.component.d.ts +34 -40
  258. package/lib/inputs/input/input.directives.d.ts +3 -3
  259. package/lib/inputs/input-utils.d.ts +24 -27
  260. package/lib/inputs/number-input/index.d.ts +3 -0
  261. package/lib/inputs/number-input/number-input.component.d.ts +38 -48
  262. package/lib/inputs/password-input/index.d.ts +4 -0
  263. package/lib/inputs/password-input/password-input.component.d.ts +28 -40
  264. package/lib/inputs/password-input/password-input.types.d.ts +2 -2
  265. package/lib/inputs/simple-input/index.d.ts +3 -0
  266. package/lib/inputs/simple-input/simple-input.component.d.ts +30 -35
  267. package/lib/kbd/index.d.ts +3 -0
  268. package/lib/kbd/kbd.component.d.ts +6 -8
  269. package/lib/kbd-shortcut/index.d.ts +2 -0
  270. package/lib/kbd-shortcut/kbd-shortcut.component.d.ts +7 -10
  271. package/lib/modal/index.d.ts +2 -0
  272. package/lib/modal/modal.component.d.ts +22 -30
  273. package/lib/option/index.d.ts +2 -0
  274. package/lib/option/option.component.d.ts +11 -16
  275. package/lib/progress-bar/index.d.ts +4 -0
  276. package/lib/progress-bar/progress-bar.component.d.ts +14 -20
  277. package/lib/progress-bar/progress-bar.types.d.ts +2 -2
  278. package/lib/progress-circle/index.d.ts +4 -0
  279. package/lib/progress-circle/progress-circle.component.d.ts +12 -20
  280. package/lib/progress-circle/progress-circle.types.d.ts +2 -2
  281. package/lib/radio/index.d.ts +3 -0
  282. package/lib/radio/radio/radio.component.d.ts +7 -8
  283. package/lib/radio/radio-group.component.d.ts +13 -16
  284. package/lib/segment/index.d.ts +4 -0
  285. package/lib/segment/segment.component.d.ts +22 -34
  286. package/lib/segment/segment.directives.d.ts +2 -3
  287. package/lib/select/index.d.ts +4 -0
  288. package/lib/select/select.component.d.ts +114 -160
  289. package/lib/select/select.directive.d.ts +3 -3
  290. package/lib/select/select.types.d.ts +2 -76
  291. package/lib/slide-toggle/index.d.ts +3 -0
  292. package/lib/slide-toggle/slide-toggle.component.d.ts +9 -7
  293. package/lib/slide-toggle/slide-toggle.types.d.ts +5 -0
  294. package/lib/slider/abstract-slider.d.ts +38 -55
  295. package/lib/slider/index.d.ts +6 -0
  296. package/lib/slider/range-slider/range-slider.component.d.ts +3 -1
  297. package/lib/slider/slider.component.d.ts +2 -0
  298. package/lib/slider/slider.types.d.ts +8 -8
  299. package/lib/snackbar/snackbar-ref.d.ts +1 -2
  300. package/lib/snackbar/snackbar.component.d.ts +3 -3
  301. package/lib/snackbar/snackbar.service.d.ts +2 -2
  302. package/lib/snackbar/snackbar.types.d.ts +4 -4
  303. package/lib/spinner/index.d.ts +2 -0
  304. package/lib/spinner/spinner.component.d.ts +3 -3
  305. package/lib/star/index.d.ts +3 -0
  306. package/lib/star/star-button/index.d.ts +2 -0
  307. package/lib/star/star-button/star-button.component.d.ts +7 -7
  308. package/lib/star/star-display/index.d.ts +2 -0
  309. package/lib/star/star-display/star-display.component.d.ts +8 -12
  310. package/lib/star/star-input/index.d.ts +2 -0
  311. package/lib/star/star-input/star-input.component.d.ts +17 -22
  312. package/lib/star/star.component.d.ts +5 -5
  313. package/lib/statebox/index.d.ts +3 -0
  314. package/lib/statebox/statebox.component.d.ts +15 -21
  315. package/lib/statebox/statebox.types.d.ts +12 -8
  316. package/lib/tabber/index.d.ts +3 -0
  317. package/lib/tabber/tab/tab.component.d.ts +18 -0
  318. package/lib/tabber/tabber.component.d.ts +25 -0
  319. package/lib/tabber/tabber.module.d.ts +9 -0
  320. package/lib/table/index.d.ts +4 -0
  321. package/lib/table/table-item-storage.d.ts +70 -58
  322. package/lib/table/table.component.d.ts +59 -78
  323. package/lib/table/table.directives.d.ts +4 -3
  324. package/lib/table-from-csv/index.d.ts +2 -0
  325. package/lib/table-from-csv/table-from-csv.component.d.ts +46 -9
  326. package/lib/table-pagination/index.d.ts +3 -0
  327. package/lib/table-pagination/table-pagination.component.d.ts +21 -30
  328. package/lib/types/item-storage.types.d.ts +19 -18
  329. package/lib/types/utility.types.d.ts +2 -1
  330. package/package.json +8 -9
  331. package/prebuilt-themes/default/badge.css +5 -5
  332. package/prebuilt-themes/default/buttons/fab.css +4 -3
  333. package/prebuilt-themes/default/buttons/fab.css.map +1 -1
  334. package/prebuilt-themes/default/card.css +7 -7
  335. package/prebuilt-themes/default/chips.css +3 -8
  336. package/prebuilt-themes/default/chips.css.map +1 -1
  337. package/prebuilt-themes/default/core.css +6 -3
  338. package/prebuilt-themes/default/core.css.map +1 -1
  339. package/prebuilt-themes/default/inputs/color-input.css +1 -1
  340. package/prebuilt-themes/default/inputs/digit-input.css +1 -1
  341. package/prebuilt-themes/default/inputs/file-input.css +139 -2
  342. package/prebuilt-themes/default/inputs/file-input.css.map +1 -1
  343. package/prebuilt-themes/default/inputs/hex-input.css +2 -2
  344. package/prebuilt-themes/default/inputs/input.css +1 -1
  345. package/prebuilt-themes/default/inputs/search-bar.css +1 -1
  346. package/prebuilt-themes/default/inputs/simple-input.css +1 -1
  347. package/prebuilt-themes/default/modal.css +1 -1
  348. package/prebuilt-themes/default/segment.css +2 -2
  349. package/prebuilt-themes/default/segment.css.map +1 -1
  350. package/prebuilt-themes/default/select.css +5 -3
  351. package/prebuilt-themes/default/select.css.map +1 -1
  352. package/prebuilt-themes/default/snackbar.css +0 -1
  353. package/prebuilt-themes/default/snackbar.css.map +1 -1
  354. package/prebuilt-themes/default/tabber.css +207 -0
  355. package/prebuilt-themes/default/tabber.css.map +1 -0
  356. package/public-api.d.ts +43 -136
  357. package/themes/default/_clear-button.scss +1 -1
  358. package/themes/default/badge.scss +5 -5
  359. package/themes/default/buttons/fab.scss +5 -3
  360. package/themes/default/card.scss +7 -7
  361. package/themes/default/chips.scss +2 -8
  362. package/themes/default/core.scss +6 -3
  363. package/themes/default/inputs/digit-input.scss +1 -1
  364. package/themes/default/inputs/file-input.scss +8 -1
  365. package/themes/default/inputs/hex-input.scss +1 -1
  366. package/themes/default/modal.scss +1 -1
  367. package/themes/default/segment.scss +2 -1
  368. package/themes/default/select.scss +4 -2
  369. package/themes/default/snackbar.scss +0 -2
  370. package/themes/default/tabber.scss +86 -0
  371. package/esm2022/lib/calendar/calendar.component.mjs +0 -979
  372. package/esm2022/lib/calendar/calendar.directives.mjs +0 -107
  373. package/esm2022/lib/calendar/calendar.helpers.mjs +0 -47
  374. package/esm2022/lib/calendar/calendar.module.mjs +0 -21
  375. package/esm2022/lib/calendar/calendar.types.mjs +0 -11
  376. package/esm2022/lib/color/color-picker/color-picker.component.mjs +0 -484
  377. package/esm2022/lib/color/color-picker/color-picker.directives.mjs +0 -55
  378. package/esm2022/lib/color/color-picker/color-picker.module.mjs +0 -43
  379. package/esm2022/lib/inputs/color-input/color-input.component.mjs +0 -421
  380. package/esm2022/lib/inputs/color-input/color-input.module.mjs +0 -85
  381. package/lib/calendar/calendar.component.d.ts +0 -155
  382. package/lib/calendar/calendar.directives.d.ts +0 -51
  383. package/lib/calendar/calendar.helpers.d.ts +0 -15
  384. package/lib/calendar/calendar.module.d.ts +0 -11
  385. package/lib/calendar/calendar.types.d.ts +0 -80
  386. package/lib/color/color-picker/color-picker.component.d.ts +0 -125
  387. package/lib/color/color-picker/color-picker.directives.d.ts +0 -27
  388. package/lib/color/color-picker/color-picker.module.d.ts +0 -13
  389. package/lib/inputs/color-input/color-input.component.d.ts +0 -147
  390. package/lib/inputs/color-input/color-input.module.d.ts +0 -16
@@ -1,11 +1,11 @@
1
- import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, EventEmitter, Input, Output, TemplateRef, ViewEncapsulation, } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, Input, TemplateRef, ViewEncapsulation, computed, contentChild, contentChildren, input, model, output, } from '@angular/core';
2
2
  import { coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';
3
- import { isDefined } from 'simple-bool';
3
+ import { isDefined, isNumber } from 'simple-bool';
4
4
  import { _FocusableComponentBase } from '../_internal/focusable-component';
5
5
  import { CheckboxState } from '../checkbox/checkbox.types';
6
6
  import { PaginationAlign } from '../table-pagination/table-pagination.types';
7
7
  import { ComponentColor, SimpleComponentColor } from '../types/colors.types';
8
- import { TableItemStorage } from './table-item-storage';
8
+ import { ArdTableRow, TableItemStorage } from './table-item-storage';
9
9
  import { ArdiumTableCaptionTemplateDirective, ArdiumTableCheckboxTemplateDirective, ArdiumTableHeaderCheckboxTemplateDirective, ArdiumTableTemplateDirective, } from './table.directives';
10
10
  import { TableAlignType, TableAppearance, TablePaginationStrategy, TableVariant, } from './table.types';
11
11
  import { isTableSubheader } from './utils';
@@ -22,159 +22,139 @@ export class ArdiumTableComponent extends _FocusableComponentBase {
22
22
  rowDisabledFrom: 'disabled',
23
23
  rowBoldFrom: 'bold',
24
24
  };
25
- this._invertRowDisabled = false;
26
- this._invertRowBold = false;
27
- this._selectableRows = false;
25
+ this.rowDisabledFrom = input(undefined);
26
+ this.rowBoldFrom = input(undefined);
27
+ this.invertRowDisabled = input(false, { transform: v => coerceBooleanProperty(v) });
28
+ this.invertRowBold = input(false, { transform: v => coerceBooleanProperty(v) });
29
+ this.selectableRows = input(false, { transform: v => coerceBooleanProperty(v) });
30
+ this.maxSelectedItems = input(undefined, { transform: v => coerceNumberProperty(v, undefined) });
31
+ this.clickableRows = input(false, { transform: v => coerceBooleanProperty(v) });
32
+ this.caption = input(undefined);
33
+ this.isLoading = input(false, { transform: v => coerceBooleanProperty(v) });
34
+ this.loadingProgress = input(0, { transform: v => coerceNumberProperty(v, 0) }); //TODO add progress bar
28
35
  //! appearance
29
- this.appearance = TableAppearance.Strong;
30
- this.variant = TableVariant.Rounded;
31
- this.color = ComponentColor.Primary;
32
- this.align = TableAlignType.CenterLeft;
33
- this.headerAlign = TableAlignType.CenterLeft;
34
- this._compact = false;
35
- this._zebra = false;
36
- this._stickyHeader = false;
36
+ this.appearance = input(TableAppearance.Strong);
37
+ this.variant = input(TableVariant.Rounded);
38
+ this.color = input(ComponentColor.Primary);
39
+ this.align = input(TableAlignType.CenterLeft);
40
+ this.headerAlign = input(TableAlignType.CenterLeft);
41
+ this.compact = input(false, { transform: v => coerceBooleanProperty(v) });
42
+ this.zebra = input(false, { transform: v => coerceBooleanProperty(v) });
43
+ this.stickyHeader = input(false, { transform: v => coerceBooleanProperty(v) });
44
+ this.ngClasses = computed(() => [
45
+ `ard-appearance-${this.appearance()}`,
46
+ `ard-variant-${this.variant()}`,
47
+ `ard-color-${this.color()}`,
48
+ `ard-align-${this.align()}`,
49
+ `ard-header-align-${this.headerAlign()}`,
50
+ this.compact() ? 'ard-compact' : '',
51
+ this.zebra() ? 'ard-zebra-table' : '',
52
+ this.selectableRows() ? 'ard-selectable-rows' : '',
53
+ this.stickyHeader() ? 'ard-sticky-header' : '',
54
+ this.isLoading() ? 'ard-table-loading' : '',
55
+ ].join(' '));
37
56
  //! pagination
38
- this._paginated = false;
39
- this.paginationStrategy = TablePaginationStrategy.Noop;
40
- this.paginationOptions = [10, 25, 50];
41
- this.paginationColor = ComponentColor.None;
42
- this.paginationAlign = PaginationAlign.Split;
43
- this.itemsPerPageText = 'Items per page:';
44
- this.currentItemsFormatFn = ({ currentItemsFirst, currentItemsLast, totalItems }) => {
45
- return `${currentItemsFirst} ${currentItemsLast} of ${totalItems}`;
46
- };
47
- this._pageFillRemaining = false;
48
- this._paginationDisabled = false;
49
- this._useFirstLastButtons = false;
50
- this._itemsPerPage = 50;
51
- this.itemsPerPageChange = new EventEmitter();
52
- this._page = 1;
53
- this.pageChange = new EventEmitter();
57
+ this.paginated = input(false, { transform: v => coerceBooleanProperty(v) });
58
+ this.paginationStrategy = input(TablePaginationStrategy.Noop);
59
+ this.paginationOptions = input([10, 25, 50], {
60
+ transform: v => {
61
+ return v.filter(el => {
62
+ const opt = isNumber(el) ? el : el.value;
63
+ if (opt <= 0 || opt % 1 !== 0) {
64
+ console.error(new Error(`ARD-NF5052: each item of <ard-table>'s [paginationOptions] must be a positive integer. The "${opt}" option will be ignored.`));
65
+ return false;
66
+ }
67
+ return true;
68
+ });
69
+ },
70
+ });
71
+ this.totalItems = input(undefined, { transform: v => coerceNumberProperty(v, undefined) });
72
+ this.paginationColor = input(ComponentColor.None);
73
+ this.paginationAlign = input(PaginationAlign.Split);
74
+ this.itemsPerPageText = input('Items per page:');
75
+ this.currentItemsFormatFn = input(({ currentItemsFirst, currentItemsLast, totalItems }) => `${currentItemsFirst} – ${currentItemsLast} of ${totalItems}`);
76
+ this.pageFillRemaining = input(false, { transform: v => coerceBooleanProperty(v) });
77
+ this.paginationDisabled = input(false, { transform: v => coerceBooleanProperty(v) });
78
+ this.useFirstLastButtons = input(false, { transform: v => coerceBooleanProperty(v) });
79
+ this.itemsPerPage = model(50);
80
+ this.page = model(1);
81
+ this.isDefinedTotalItems = computed(() => this.paginationStrategy() !== TablePaginationStrategy.Noop || isDefined(this.totalItems()));
82
+ this.canDisplayPagination = computed(() => this.paginated() && this.isDefinedTotalItems());
83
+ //! item storage getters
84
+ this.headerCells = computed(() => this._itemStorage.headerCells());
85
+ this.dataRows = computed(() => {
86
+ const items = this._itemStorage.paginatedItems();
87
+ if (!this.pageFillRemaining())
88
+ return items;
89
+ if (!this.isDefinedTotalItems()) {
90
+ throw new Error('ARD-FT5050: <ard-table> requires [totalItems] to be defined when using "slice" pagination strategy.');
91
+ }
92
+ if (this.page() === 1)
93
+ return items;
94
+ const ipp = this.itemsPerPage();
95
+ for (let i = items.length; i < ipp; i++) {
96
+ items.push(ArdTableRow.newEmptyCell(i));
97
+ }
98
+ return items;
99
+ });
54
100
  this._data = [];
55
- this._treatDataSourceAsString = false;
101
+ this.treatDataSourceAsString = input(false, { transform: v => coerceBooleanProperty(v) });
102
+ this._suppressErrors = input(false);
103
+ //! templates
104
+ this.checkboxTemplate = contentChild(ArdiumTableCheckboxTemplateDirective, {
105
+ read: (TemplateRef),
106
+ });
107
+ this.headerCheckboxTemplate = contentChild(ArdiumTableHeaderCheckboxTemplateDirective, {
108
+ read: (TemplateRef),
109
+ });
110
+ this.captionTemplate = contentChild(ArdiumTableCaptionTemplateDirective, {
111
+ read: (TemplateRef),
112
+ });
56
113
  this._itemTemplates = {};
57
- this.selectedRowsChangeEvent = new EventEmitter();
58
- this.failedSelectRowEvent = new EventEmitter();
59
- this.selectRowEvent = new EventEmitter();
60
- this.unselectRowEvent = new EventEmitter();
61
- }
62
- get invertRowDisabled() {
63
- return this._invertRowDisabled;
64
- }
65
- set invertRowDisabled(v) {
66
- this._invertRowDisabled = coerceBooleanProperty(v);
67
- }
68
- get invertRowBold() {
69
- return this._invertRowBold;
70
- }
71
- set invertRowBold(v) {
72
- this._invertRowBold = coerceBooleanProperty(v);
73
- }
74
- get selectableRows() {
75
- return this._selectableRows;
76
- }
77
- set selectableRows(v) {
78
- this._selectableRows = coerceBooleanProperty(v);
79
- }
80
- get compact() {
81
- return this._compact;
82
- }
83
- set compact(v) {
84
- this._compact = coerceBooleanProperty(v);
85
- }
86
- get zebra() {
87
- return this._zebra;
88
- }
89
- set zebra(v) {
90
- this._zebra = coerceBooleanProperty(v);
91
- }
92
- get stickyHeader() {
93
- return this._stickyHeader;
94
- }
95
- set stickyHeader(v) {
96
- this._stickyHeader = coerceBooleanProperty(v);
97
- }
98
- get ngClasses() {
99
- return [
100
- `ard-appearance-${this.appearance}`,
101
- `ard-variant-${this.variant}`,
102
- `ard-color-${this.color}`,
103
- `ard-align-${this.align}`,
104
- `ard-header-align-${this.headerAlign}`,
105
- this.compact ? 'ard-compact' : '',
106
- this.zebra ? 'ard-zebra-table' : '',
107
- this.selectableRows ? 'ard-selectable-rows' : '',
108
- this.stickyHeader ? 'ard-sticky-header' : '',
109
- this.isLoading ? 'ard-table-loading' : '',
110
- ].join(' ');
111
- }
112
- get paginated() {
113
- return this._paginated;
114
- }
115
- set paginated(v) {
116
- this._paginated = coerceBooleanProperty(v);
117
- }
118
- get pageFillRemaining() {
119
- return this._pageFillRemaining;
120
- }
121
- set pageFillRemaining(v) {
122
- this._pageFillRemaining = coerceBooleanProperty(v);
123
- }
124
- get paginationDisabled() {
125
- return this._paginationDisabled;
126
- }
127
- set paginationDisabled(v) {
128
- this._paginationDisabled = coerceBooleanProperty(v);
129
- }
130
- get useFirstLastButtons() {
131
- return this._useFirstLastButtons;
132
- }
133
- set useFirstLastButtons(v) {
134
- this._useFirstLastButtons = coerceBooleanProperty(v);
135
- }
136
- get itemsPerPage() {
137
- return this._itemsPerPage;
138
- }
139
- set itemsPerPage(v) {
140
- this._itemsPerPage = coerceNumberProperty(v);
141
- }
142
- get page() {
143
- return this._page;
144
- }
145
- set page(v) {
146
- this._page = coerceNumberProperty(v);
147
- }
148
- get isDefinedTotalItems() {
149
- return (this.paginationStrategy == TablePaginationStrategy.Noop && isDefined(this.totalItems)) || this.paginationStrategy != TablePaginationStrategy.Noop;
150
- }
151
- get canDisplayPagination() {
152
- //prettier-ignore
153
- return this.paginated && this.isDefinedTotalItems;
154
- }
155
- //! item storage getters
156
- get headerCells() {
157
- return this._itemStorage.headerCells;
158
- }
159
- get dataRows() {
160
- const items = this._itemStorage.paginatedItems;
161
- if (!this.pageFillRemaining)
162
- return items;
163
- if (!this.isDefinedTotalItems) {
164
- throw new Error('<ard-table> requires [totalItems] to be defined.');
114
+ this.templateChildren = contentChildren(ArdiumTableTemplateDirective);
115
+ this.selectedRowsChangeEvent = output({ alias: 'selectedRowsChange' });
116
+ this.failedSelectRowEvent = output({ alias: 'failedSelectRow' });
117
+ this.selectRowEvent = output({ alias: 'selectRow' });
118
+ this.unselectRowEvent = output({ alias: 'unselectRow' });
119
+ this.clickRowEvent = output({ alias: 'clickRow' });
120
+ this.getHeaderCheckboxContext = computed(() => {
121
+ let state = CheckboxState.Unselected;
122
+ if (this._itemStorage.isAnyItemSelected()) {
123
+ state = CheckboxState.Indeterminate;
124
+ if (this._itemStorage.areAllSelected()) {
125
+ state = CheckboxState.Selected;
126
+ }
127
+ }
128
+ return {
129
+ $implicit: state,
130
+ state,
131
+ onChange: () => {
132
+ this.toggleAllRowsSelected();
133
+ },
134
+ };
135
+ });
136
+ }
137
+ //! print errors if needed
138
+ ngOnChanges(changes) {
139
+ if (changes['itemsPerPage']) {
140
+ const ipp = changes['itemsPerPage'].currentValue;
141
+ const options = changes['paginationOptions']?.currentValue ||
142
+ this.paginationOptions();
143
+ if (!options.find(v => (typeof v === 'number' ? v === ipp : v.value === ipp))) {
144
+ console.error(new Error(`ARD-NF5051: value of "${ipp}" in <ard-table>'s [itemsPerPage] does not appear in [paginationOptions] array [${options
145
+ .map(v => (typeof v === 'number' ? v : v.value))
146
+ .join(', ')}]`));
147
+ }
165
148
  }
166
- if (this.page == 1)
167
- return items;
168
- for (let i = items.length; i < this.itemsPerPage; i++) {
169
- items.push({
170
- itemData: null,
171
- index: i,
172
- data: [],
173
- dataColumns: [],
174
- isEmpty: true,
175
- });
149
+ if (changes['page']) {
150
+ const page = changes['page'].currentValue;
151
+ if (page === 0) {
152
+ throw new Error(`ARD-FT5053a: <ard-table>'s [page] uses 1-indexed numbering system. The value 0 is not accepted.`);
153
+ }
154
+ else if (page < 0 || page % 1 !== 0) {
155
+ throw new Error(`ARD-FT5053b: value of <ard-table>'s [page] must be a positive integer, got "${page}".`);
156
+ }
176
157
  }
177
- return items;
178
158
  }
179
159
  //! columns/data setters
180
160
  set columns(v) {
@@ -187,31 +167,26 @@ export class ArdiumTableComponent extends _FocusableComponentBase {
187
167
  get data() {
188
168
  return this._data;
189
169
  }
190
- get treatDataSourceAsString() {
191
- return this._treatDataSourceAsString;
192
- }
193
- set treatDataSourceAsString(v) {
194
- this._treatDataSourceAsString = coerceBooleanProperty(v);
195
- }
196
170
  ngAfterContentInit() {
197
- const templates = Array.from(this.templateChildren);
171
+ const templates = Array.from(this.templateChildren());
198
172
  for (const instance of templates) {
199
- if (!instance.name) {
200
- console.error(new Error('[ard-table-tmp] requires a value to be specified.'));
173
+ const name = instance.name();
174
+ if (!name) {
175
+ console.error(new Error('ARD-FT5054: [ard-table-tmp] requires a value to be specified.'));
201
176
  continue;
202
177
  }
203
- this._itemTemplates[instance.name] = instance.template;
178
+ this._itemTemplates[name] = instance.template;
204
179
  }
205
180
  }
206
181
  getHeaderTemplate(tmp) {
207
- if (typeof tmp == 'string')
182
+ if (typeof tmp === 'string')
208
183
  return undefined;
209
184
  return this.getCellTemplate(tmp.template);
210
185
  }
211
186
  getHeaderCheckboxColor() {
212
- if (this.appearance == TableAppearance.Strong)
187
+ if (this.appearance() === TableAppearance.Strong)
213
188
  return SimpleComponentColor.CurrentColor;
214
- return this.color;
189
+ return this.color();
215
190
  }
216
191
  getCellTemplate(tmp) {
217
192
  //return undefined
@@ -222,7 +197,7 @@ export class ArdiumTableComponent extends _FocusableComponentBase {
222
197
  return tmp;
223
198
  //check if the name can be found
224
199
  if (!(tmp in this._itemTemplates)) {
225
- console.error(new Error(`<ard-table> error: cannot find template named "${tmp}"`));
200
+ console.error(new Error(`ARD-NF5055: <ard-table> error: cannot find template named "${tmp}"`));
226
201
  return undefined;
227
202
  }
228
203
  //return the template
@@ -231,31 +206,37 @@ export class ArdiumTableComponent extends _FocusableComponentBase {
231
206
  getCellStyle(cell) {
232
207
  if (isTableSubheader(cell))
233
208
  return 'width:unset;min-width:unset';
234
- const width = typeof cell.width == 'number' ? `${cell.width}px` : cell.width;
235
- const minWidth = typeof cell.minWidth == 'number' ? `${cell.minWidth}px` : cell.minWidth;
209
+ const width = typeof cell.width === 'number' ? `${cell.width}px` : cell.width;
210
+ const minWidth = typeof cell.minWidth === 'number' ? `${cell.minWidth}px` : cell.minWidth;
236
211
  return [`width:${width ?? 'unset'}`, `min-width:${minWidth ?? 'unset'}`].join(';');
237
212
  }
238
213
  //! click & hover handlers
239
214
  onCheckboxClick(index) {
240
215
  this.toggleRowSelected(index);
241
216
  }
242
- onRowClick(index, event) {
243
- if (!this.selectableRows)
217
+ onRowClick(row, event) {
218
+ if (this.clickableRows()) {
219
+ event.stopPropagation();
220
+ this.clickRowEvent.emit(row.itemData());
244
221
  return;
245
- event.stopPropagation();
246
- this.toggleRowSelected(index);
222
+ }
223
+ if (this.selectableRows()) {
224
+ event.stopPropagation();
225
+ this.toggleRowSelected(row.index());
226
+ return;
227
+ }
247
228
  }
248
229
  onRowMouseOver(event) {
249
230
  event.stopPropagation();
250
231
  }
251
232
  onRowMouseEnter(index, event) {
252
- if (!this.selectableRows)
233
+ if (!this.selectableRows() && !this.clickableRows())
253
234
  return;
254
235
  event.stopPropagation();
255
236
  this._itemStorage.highlightSingleItem(index);
256
237
  }
257
238
  onRowMouseLeave(index, event) {
258
- if (!this.selectableRows)
239
+ if (!this.selectableRows() && !this.clickableRows())
259
240
  return;
260
241
  event.stopPropagation();
261
242
  this._itemStorage.unhighlightItem(index);
@@ -269,12 +250,15 @@ export class ArdiumTableComponent extends _FocusableComponentBase {
269
250
  toggleRowSelected(index) {
270
251
  if (this._itemStorage.isItemSelected(index)) {
271
252
  const unselected = this._itemStorage.unselectItem(index);
272
- this.unselectRowEvent.emit(unselected);
253
+ if (unselected.length)
254
+ this.unselectRowEvent.emit(unselected);
273
255
  }
274
256
  else {
275
257
  const [selected, failed] = this._itemStorage.selectItem(index);
276
- this.selectRowEvent.emit(selected);
277
- this.failedSelectRowEvent.emit(failed);
258
+ if (selected.length)
259
+ this.selectRowEvent.emit(selected);
260
+ if (failed.length)
261
+ this.failedSelectRowEvent.emit(failed);
278
262
  }
279
263
  this._emitSelect();
280
264
  }
@@ -282,40 +266,43 @@ export class ArdiumTableComponent extends _FocusableComponentBase {
282
266
  * Toggles the selection state of all rows in the table.
283
267
  */
284
268
  toggleAllRowsSelected() {
285
- if (this._itemStorage.areAllSelected) {
269
+ if (this._itemStorage.areAllSelected()) {
286
270
  const unselected = this._itemStorage.unselectAll();
287
- this.unselectRowEvent.emit(unselected);
271
+ if (unselected.length)
272
+ this.unselectRowEvent.emit(unselected);
288
273
  }
289
274
  else {
290
275
  const [selected, failed] = this._itemStorage.selectAll();
291
- this.selectRowEvent.emit(selected);
292
- this.failedSelectRowEvent.emit(failed);
276
+ if (selected.length)
277
+ this.selectRowEvent.emit(selected);
278
+ if (failed.length)
279
+ this.failedSelectRowEvent.emit(failed);
293
280
  }
294
281
  this._emitSelect();
295
282
  }
296
283
  _emitSelect() {
297
- const v = this._itemStorage.value;
284
+ const v = this._itemStorage.value();
298
285
  this.selectedRowsChangeEvent.emit(v);
299
286
  }
300
287
  isCellCheckbox(cell) {
301
- return typeof cell == 'object' && '_ardCheckbox' in cell && 'index' in cell;
288
+ return typeof cell === 'object' && '_ardCheckbox' in cell && 'index' in cell;
302
289
  }
303
290
  isHeaderCellCheckbox(cell) {
304
- const dataCell = cell.cell;
291
+ const dataCell = cell.cell();
305
292
  if (isTableSubheader(dataCell))
306
293
  return false;
307
- if (typeof dataCell.dataSource == 'string')
294
+ if (typeof dataCell.dataSource === 'string')
308
295
  return false;
309
- return dataCell.dataSource.type == 'checkbox';
296
+ return dataCell.dataSource.type === 'checkbox';
310
297
  }
311
298
  isHeaderCellSortable(cell) {
312
- const dataCell = cell.cell;
299
+ const dataCell = cell.cell();
313
300
  if (isTableSubheader(dataCell))
314
301
  return false;
315
302
  return dataCell.sortable ?? false;
316
303
  }
317
304
  getHeaderContext(cell, index) {
318
- if (typeof cell.header != 'string')
305
+ if (typeof cell.header !== 'string')
319
306
  return null;
320
307
  if (isTableSubheader(cell))
321
308
  return {
@@ -327,7 +314,7 @@ export class ArdiumTableComponent extends _FocusableComponentBase {
327
314
  header: cell.header,
328
315
  sortable: cell.sortable ?? false,
329
316
  sortType: this._itemStorage.getColumnSortType(index),
330
- onTriggerSort: (event) => this._itemStorage.toggleCurrentSortColumn(index),
317
+ onTriggerSort: () => this._itemStorage.toggleCurrentSortColumn(index),
331
318
  onTriggerResetSort: (event) => {
332
319
  this._itemStorage.resetSort();
333
320
  event?.preventDefault();
@@ -335,134 +322,27 @@ export class ArdiumTableComponent extends _FocusableComponentBase {
335
322
  },
336
323
  };
337
324
  }
338
- getHeaderCheckboxContext() {
339
- let state = CheckboxState.Unselected;
340
- if (this._itemStorage.isAnyItemSelected) {
341
- state = CheckboxState.Indeterminate;
342
- if (this._itemStorage.areAllSelected) {
343
- state = CheckboxState.Selected;
344
- }
345
- }
346
- return {
347
- $implicit: state,
348
- state,
349
- onChange: () => {
350
- this.toggleAllRowsSelected();
351
- },
352
- };
353
- }
354
325
  getCheckboxContext(index) {
355
- const item = this._itemStorage.items.find(v => v.index == index);
356
- const selected = item.selected ?? false;
357
- const disabled = item.disabled ?? false;
326
+ const item = this._itemStorage.items().find(v => v.index() === index);
327
+ const selected = item.selected();
358
328
  return {
359
329
  $implicit: selected,
360
- selected,
361
- disabled,
330
+ selected: selected,
331
+ disabled: item.disabled(),
362
332
  onChange: () => {
363
333
  this.onCheckboxClick(index);
364
334
  },
365
335
  };
366
336
  }
367
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ArdiumTableComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
368
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.7", type: ArdiumTableComponent, selector: "ard-table", inputs: { rowDisabledFrom: "rowDisabledFrom", rowBoldFrom: "rowBoldFrom", invertRowDisabled: "invertRowDisabled", invertRowBold: "invertRowBold", selectableRows: "selectableRows", caption: "caption", isLoading: "isLoading", loadingProgress: "loadingProgress", appearance: "appearance", variant: "variant", color: "color", align: "align", headerAlign: "headerAlign", compact: "compact", zebra: "zebra", stickyHeader: "stickyHeader", paginated: "paginated", paginationStrategy: "paginationStrategy", paginationOptions: "paginationOptions", totalItems: "totalItems", paginationColor: "paginationColor", paginationAlign: "paginationAlign", itemsPerPageText: "itemsPerPageText", currentItemsFormatFn: "currentItemsFormatFn", pageFillRemaining: "pageFillRemaining", paginationDisabled: "paginationDisabled", useFirstLastButtons: "useFirstLastButtons", itemsPerPage: "itemsPerPage", page: "page", columns: "columns", data: "data", treatDataSourceAsString: "treatDataSourceAsString" }, outputs: { itemsPerPageChange: "itemsPerPageChange", pageChange: "pageChange", selectedRowsChangeEvent: "selectedRowsChange", failedSelectRowEvent: "failedSelectRow", selectRowEvent: "selectRow", unselectRowEvent: "unselectRow" }, queries: [{ propertyName: "checkboxTemplate", first: true, predicate: ArdiumTableCheckboxTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "headerCheckboxTemplate", first: true, predicate: ArdiumTableHeaderCheckboxTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "captionTemplate", first: true, predicate: ArdiumTableCaptionTemplateDirective, descendants: true, read: TemplateRef }, { propertyName: "templateChildren", predicate: ArdiumTableTemplateDirective }], usesInheritance: true, ngImport: i0, template: "<table class=\"ard-table\" [ngClass]=\"ngClasses\">\r\n <caption\r\n *ngIf=\"caption\"\r\n class=\"ard-table__caption\"\r\n >\r\n <div class=\"ard-table__caption-container\">\r\n <ng-template #defaultCaptionTemplate let-captionText>\r\n {{ captionText }}\r\n </ng-template>\r\n \r\n <ng-template\r\n [ngTemplateOutlet]=\"captionTemplate ?? defaultCaptionTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: caption }\"\r\n />\r\n </div>\r\n </caption>\r\n <thead class=\"ard-table__header\">\r\n <tr class=\"ard-table__header-row\" *ngFor=\"let row of headerCells\">\r\n <th\r\n *ngFor=\"let cell of row; let index = index\"\r\n class=\"ard-table__header-cell\"\r\n [ngClass]=\"cell.cell.cellClass\"\r\n [class.ard-table__checkbox-cell]=\"isHeaderCellCheckbox(cell)\"\r\n [attr.colspan]=\"cell.colspan\"\r\n [attr.rowspan]=\"cell.rowspan\"\r\n [scope]=\"cell.colspan > 1 ? 'colgroup' : 'col'\"\r\n >\r\n <div\r\n class=\"ard-table__cell-container\"\r\n [class.ard-table__sortable]=\"isHeaderCellSortable(cell)\"\r\n [style.width]=\"cell.width\"\r\n [style.minWidth]=\"cell.minWidth\"\r\n >\r\n <ng-container *ngIf=\"isHeaderCellCheckbox(cell)\">\r\n <ng-template #defaultHeaderCheckboxTemplate let-state let-onChange=\"onChange\">\r\n <ard-checkbox [tabIndex]=\"isLoading ? -1 : tabIndex\" [state]=\"state\" [color]=\"getHeaderCheckboxColor()\" unselectedColor=\"currentColor\" (change)=\"onChange()\" />\r\n </ng-template>\r\n \r\n <ng-template\r\n [ngTemplateOutlet]=\"headerCheckboxTemplate ?? defaultHeaderCheckboxTemplate\"\r\n [ngTemplateOutletContext]=\"getHeaderCheckboxContext()\"\r\n />\r\n </ng-container>\r\n <ng-container *ngIf=\"!isHeaderCellCheckbox(cell)\">\r\n <ng-template\r\n #defaultHeaderCellTemplate\r\n let-content\r\n let-sortable=\"sortable\"\r\n let-sortType=\"sortType\"\r\n let-onTriggerSort=\"onTriggerSort\"\r\n let-onTriggerResetSort=\"onTriggerResetSort\"\r\n >\r\n <div\r\n class=\"ard-table__header-template-container\"\r\n [class.ard-sortable]=\"sortable\"\r\n [class.ard-nonsortable]=\"!sortable\"\r\n >\r\n <button\r\n class=\"ard-table__header-content-container\"\r\n *ngIf=\"sortable\"\r\n (click)=\"onTriggerSort($event)\"\r\n [tabindex]=\"tabIndex\"\r\n (keydown.Esc)=\"onTriggerResetSort($event)\"\r\n >\r\n <div class=\"ard-table__header-content\">{{ content }}</div>\r\n <div class=\"ard-table__header-sort-icon\" *ngIf=\"sortType != null\">\r\n <ard-icon *ngIf=\"sortType == 'ascending'\">south</ard-icon>\r\n <ard-icon *ngIf=\"sortType == 'descending'\">north</ard-icon>\r\n </div>\r\n </button>\r\n <div\r\n class=\"ard-table__header-content-container\"\r\n *ngIf=\"!sortable\"\r\n >\r\n <div class=\"ard-table__header-content\">{{ content }}</div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n \r\n <ng-template \r\n [ngTemplateOutlet]=\"getHeaderTemplate(cell.cell.header) ?? defaultHeaderCellTemplate\"\r\n [ngTemplateOutletContext]=\"getHeaderContext(cell.cell, index)\"\r\n />\r\n </ng-container>\r\n </div>\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody class=\"ard-table__body\">\r\n <ng-container *ngFor=\"let row of dataRows; let rowIndex = index;\">\r\n <tr *ngIf=\"row.isEmpty\" class=\"ard-table__empty-row\">\r\n <td class=\"ard-table__empty-cell\" colspan=\"9999\"></td>\r\n </tr>\r\n <tr\r\n *ngIf=\"!row.isEmpty\"\r\n class=\"ard-table__body-row\"\r\n [class.ard-table__selected-row]=\"row.selected\"\r\n [class.ard-table__highlighted-row]=\"row.highlighted\"\r\n [class.ard-table__disabled-row]=\"row.disabled\"\r\n [class.ard-table__bold-row]=\"row.bold\"\r\n (click)=\"onRowClick(rowIndex, $event)\"\r\n (mouseover)=\"onRowMouseOver($event)\"\r\n (mouseenter)=\"onRowMouseEnter(rowIndex, $event)\"\r\n (mouseleave)=\"onRowMouseLeave(rowIndex, $event)\"\r\n >\r\n <ng-container *ngFor=\"let cell of row.data; let cellIndex = index\">\r\n <ng-template #cellTmp>\r\n <div\r\n class=\"ard-table__cell-container\"\r\n [style]=\"getCellStyle(row.dataColumns[cellIndex])\"\r\n >\r\n <ng-container *ngIf=\"isCellCheckbox(cell)\">\r\n <ng-template #defaultCheckboxTemplate let-isChecked let-onChange=\"onChange\" let-disabled=\"disabled\">\r\n <ard-checkbox [tabIndex]=\"isLoading ? -1 : tabIndex\" [selected]=\"isChecked\" [color]=\"color\" [disabled]=\"disabled\" (change)=\"onChange()\" (click)=\"$event.stopPropagation()\" />\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"checkboxTemplate ?? defaultCheckboxTemplate\"\r\n [ngTemplateOutletContext]=\"getCheckboxContext(rowIndex)\"\r\n />\r\n </ng-container>\r\n <ng-container *ngIf=\"!isCellCheckbox(cell)\">\r\n <ng-template #defaultCellTemplate let-content>\r\n {{ content }}\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"getCellTemplate(row.dataColumns[cellIndex].template) ?? defaultCellTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: cell }\"\r\n />\r\n </ng-container>\r\n </div>\r\n </ng-template>\r\n <td\r\n *ngIf=\"!row.dataColumns[cellIndex].isRowHeader\"\r\n class=\"ard-table__body-cell\"\r\n [ngClass]=\"row.dataColumns[cellIndex].cellClass\"\r\n [class.ard-table__checkbox-cell]=\"isCellCheckbox(cell)\"\r\n >\r\n <ng-template [ngTemplateOutlet]=\"cellTmp\"></ng-template>\r\n </td>\r\n <th\r\n *ngIf=\"row.dataColumns[cellIndex].isRowHeader\"\r\n class=\"ard-table__body-cell ard-table__row-header\"\r\n scope=\"row\"\r\n [ngClass]=\"row.dataColumns[cellIndex].cellClass\"\r\n [class.ard-table__checkbox-cell]=\"isCellCheckbox(cell)\"\r\n >\r\n <ng-template [ngTemplateOutlet]=\"cellTmp\"></ng-template>\r\n </th>\r\n </ng-container>\r\n </tr>\r\n </ng-container>\r\n </tbody>\r\n <tfoot class=\"ard-table__foot\" *ngIf=\"canDisplayPagination\">\r\n <tr class=\"ard-table__foot-row\">\r\n <td class=\"ard-table__pagination-cell\" colspan=\"9999\">\r\n <ard-table-pagination\r\n [options]=\"paginationOptions\"\r\n [(page)]=\"page\"\r\n [totalItems]=\"totalItems\"\r\n [disabled]=\"paginationDisabled\"\r\n [(itemsPerPage)]=\"itemsPerPage\"\r\n [align]=\"paginationAlign\"\r\n [isLoading]=\"isLoading\"\r\n [itemsPerPageText]=\"itemsPerPageText\"\r\n [currentItemsFormatFn]=\"currentItemsFormatFn\"\r\n (itemsPerPageChange)=\"itemsPerPageChange.emit($event)\"\r\n (pageChange)=\"pageChange.emit($event)\"\r\n ></ard-table-pagination>\r\n </td>\r\n </tr>\r\n </tfoot>\r\n</table>", styles: [".ard-table__cell-container,.ard-table__header-template-container{width:100%;height:100%}\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: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.ArdiumCheckboxComponent, selector: "ard-checkbox", inputs: ["wrapperClasses", "htmlId", "color", "unselectedColor", "state"], outputs: ["stateChange"] }, { kind: "component", type: i3.ArdiumTablePaginationComponent, selector: "ard-table-pagination", inputs: ["options", "itemsPerPage", "page", "totalItems", "color", "align", "compact", "useFirstLastButtons", "isLoading", "itemsPerPageText", "currentItemsFormatFn"], outputs: ["itemsPerPageChange", "pageChange"] }, { kind: "component", type: i4.ArdiumIconComponent, selector: "ard-icon", inputs: ["ariaLabel", "icon", "filled", "weight", "grade", "opticalSize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
337
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: ArdiumTableComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
338
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.2", type: ArdiumTableComponent, selector: "ard-table", inputs: { rowDisabledFrom: { classPropertyName: "rowDisabledFrom", publicName: "rowDisabledFrom", isSignal: true, isRequired: false, transformFunction: null }, rowBoldFrom: { classPropertyName: "rowBoldFrom", publicName: "rowBoldFrom", isSignal: true, isRequired: false, transformFunction: null }, invertRowDisabled: { classPropertyName: "invertRowDisabled", publicName: "invertRowDisabled", isSignal: true, isRequired: false, transformFunction: null }, invertRowBold: { classPropertyName: "invertRowBold", publicName: "invertRowBold", isSignal: true, isRequired: false, transformFunction: null }, selectableRows: { classPropertyName: "selectableRows", publicName: "selectableRows", isSignal: true, isRequired: false, transformFunction: null }, maxSelectedItems: { classPropertyName: "maxSelectedItems", publicName: "maxSelectedItems", isSignal: true, isRequired: false, transformFunction: null }, clickableRows: { classPropertyName: "clickableRows", publicName: "clickableRows", isSignal: true, isRequired: false, transformFunction: null }, caption: { classPropertyName: "caption", publicName: "caption", isSignal: true, isRequired: false, transformFunction: null }, isLoading: { classPropertyName: "isLoading", publicName: "isLoading", isSignal: true, isRequired: false, transformFunction: null }, loadingProgress: { classPropertyName: "loadingProgress", publicName: "loadingProgress", isSignal: true, isRequired: false, transformFunction: null }, appearance: { classPropertyName: "appearance", publicName: "appearance", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, align: { classPropertyName: "align", publicName: "align", isSignal: true, isRequired: false, transformFunction: null }, headerAlign: { classPropertyName: "headerAlign", publicName: "headerAlign", isSignal: true, isRequired: false, transformFunction: null }, compact: { classPropertyName: "compact", publicName: "compact", isSignal: true, isRequired: false, transformFunction: null }, zebra: { classPropertyName: "zebra", publicName: "zebra", isSignal: true, isRequired: false, transformFunction: null }, stickyHeader: { classPropertyName: "stickyHeader", publicName: "stickyHeader", isSignal: true, isRequired: false, transformFunction: null }, paginated: { classPropertyName: "paginated", publicName: "paginated", isSignal: true, isRequired: false, transformFunction: null }, paginationStrategy: { classPropertyName: "paginationStrategy", publicName: "paginationStrategy", isSignal: true, isRequired: false, transformFunction: null }, paginationOptions: { classPropertyName: "paginationOptions", publicName: "paginationOptions", isSignal: true, isRequired: false, transformFunction: null }, totalItems: { classPropertyName: "totalItems", publicName: "totalItems", isSignal: true, isRequired: false, transformFunction: null }, paginationColor: { classPropertyName: "paginationColor", publicName: "paginationColor", isSignal: true, isRequired: false, transformFunction: null }, paginationAlign: { classPropertyName: "paginationAlign", publicName: "paginationAlign", isSignal: true, isRequired: false, transformFunction: null }, itemsPerPageText: { classPropertyName: "itemsPerPageText", publicName: "itemsPerPageText", isSignal: true, isRequired: false, transformFunction: null }, currentItemsFormatFn: { classPropertyName: "currentItemsFormatFn", publicName: "currentItemsFormatFn", isSignal: true, isRequired: false, transformFunction: null }, pageFillRemaining: { classPropertyName: "pageFillRemaining", publicName: "pageFillRemaining", isSignal: true, isRequired: false, transformFunction: null }, paginationDisabled: { classPropertyName: "paginationDisabled", publicName: "paginationDisabled", isSignal: true, isRequired: false, transformFunction: null }, useFirstLastButtons: { classPropertyName: "useFirstLastButtons", publicName: "useFirstLastButtons", isSignal: true, isRequired: false, transformFunction: null }, itemsPerPage: { classPropertyName: "itemsPerPage", publicName: "itemsPerPage", isSignal: true, isRequired: false, transformFunction: null }, page: { classPropertyName: "page", publicName: "page", isSignal: true, isRequired: false, transformFunction: null }, columns: { classPropertyName: "columns", publicName: "columns", isSignal: false, isRequired: false, transformFunction: null }, data: { classPropertyName: "data", publicName: "data", isSignal: false, isRequired: false, transformFunction: null }, treatDataSourceAsString: { classPropertyName: "treatDataSourceAsString", publicName: "treatDataSourceAsString", isSignal: true, isRequired: false, transformFunction: null }, _suppressErrors: { classPropertyName: "_suppressErrors", publicName: "_suppressErrors", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { itemsPerPage: "itemsPerPageChange", page: "pageChange", selectedRowsChangeEvent: "selectedRowsChange", failedSelectRowEvent: "failedSelectRow", selectRowEvent: "selectRow", unselectRowEvent: "unselectRow", clickRowEvent: "clickRow" }, queries: [{ propertyName: "checkboxTemplate", first: true, predicate: ArdiumTableCheckboxTemplateDirective, descendants: true, read: TemplateRef, isSignal: true }, { propertyName: "headerCheckboxTemplate", first: true, predicate: ArdiumTableHeaderCheckboxTemplateDirective, descendants: true, read: TemplateRef, isSignal: true }, { propertyName: "captionTemplate", first: true, predicate: ArdiumTableCaptionTemplateDirective, descendants: true, read: TemplateRef, isSignal: true }, { propertyName: "templateChildren", predicate: ArdiumTableTemplateDirective, isSignal: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<table\n class=\"ard-table\"\n [ngClass]=\"ngClasses()\"\n>\n @if (caption()) {\n <caption class=\"ard-table__caption\">\n <div class=\"ard-table__caption-container\">\n <ng-template\n #defaultCaptionTemplate\n let-captionText\n >\n {{ captionText }}\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"captionTemplate() ?? defaultCaptionTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: caption() }\"\n />\n </div>\n </caption>\n }\n <thead class=\"ard-table__header\">\n @for (row of headerCells(); track $index) {\n <tr class=\"ard-table__header-row\">\n @for (cell of row; track $index) {\n <th\n class=\"ard-table__header-cell\"\n [ngClass]=\"cell.cell().cellClass\"\n [class.ard-table__checkbox-cell]=\"isHeaderCellCheckbox(cell)\"\n [attr.colspan]=\"cell.colspan()\"\n [attr.rowspan]=\"cell.rowspan()\"\n [scope]=\"cell.colspan() > 1 ? 'colgroup' : 'col'\"\n >\n <div\n class=\"ard-table__cell-container\"\n [class.ard-table__sortable]=\"isHeaderCellSortable(cell)\"\n [style.width]=\"cell.width\"\n [style.minWidth]=\"cell.minWidth\"\n >\n @if (isHeaderCellCheckbox(cell)) {\n <ng-template\n #defaultHeaderCheckboxTemplate\n let-state\n let-onChange=\"onChange\"\n >\n <ard-checkbox\n [tabIndex]=\"isLoading() ? -1 : tabIndex()\"\n [state]=\"state\"\n [color]=\"getHeaderCheckboxColor()\"\n unselectedColor=\"currentColor\"\n (change)=\"onChange()\"\n />\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"headerCheckboxTemplate() ?? defaultHeaderCheckboxTemplate\"\n [ngTemplateOutletContext]=\"getHeaderCheckboxContext()\"\n />\n } @else {\n <ng-template\n #defaultHeaderCellTemplate\n let-content\n let-sortable=\"sortable\"\n let-sortType=\"sortType\"\n let-onTriggerSort=\"onTriggerSort\"\n let-onTriggerResetSort=\"onTriggerResetSort\"\n >\n <div\n class=\"ard-table__header-template-container\"\n [class.ard-sortable]=\"sortable\"\n [class.ard-nonsortable]=\"!sortable\"\n >\n @if (sortable) {\n <button\n class=\"ard-table__header-content-container\"\n (click)=\"onTriggerSort($event)\"\n [tabindex]=\"tabIndex()\"\n (keydown.Esc)=\"onTriggerResetSort($event)\"\n >\n <div class=\"ard-table__header-content\">{{ content }}</div>\n @if (sortType !== null) {\n <div class=\"ard-table__header-sort-icon\">\n @if (sortType === 'ascending') {\n <ard-icon>south</ard-icon>\n } @else if (sortType === 'descending') {\n <ard-icon>north</ard-icon>\n }\n </div>\n }\n </button>\n } @else {\n <div class=\"ard-table__header-content-container\">\n <div class=\"ard-table__header-content\">{{ content }}</div>\n </div>\n }\n </div>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"getHeaderTemplate(cell.cell().header) ?? defaultHeaderCellTemplate\"\n [ngTemplateOutletContext]=\"getHeaderContext(cell.cell(), $index)\"\n />\n }\n </div>\n </th>\n }\n </tr>\n }\n </thead>\n <tbody class=\"ard-table__body\">\n @for (row of dataRows(); track $index) {\n @if (row.isEmpty()) {\n <tr class=\"ard-table__empty-row\">\n <td\n class=\"ard-table__empty-cell\"\n colspan=\"9999\"\n ></td>\n </tr>\n } @else {\n <tr\n class=\"ard-table__body-row\"\n [class.ard-table__selected-row]=\"row.selected()\"\n [class.ard-table__highlighted-row]=\"row.highlighted()\"\n [class.ard-table__disabled-row]=\"row.disabled()\"\n [class.ard-table__bold-row]=\"row.bold()\"\n (click)=\"onRowClick(row, $event)\"\n (mouseover)=\"onRowMouseOver($event)\"\n (mouseenter)=\"onRowMouseEnter(row.index(), $event)\"\n (mouseleave)=\"onRowMouseLeave(row.index(), $event)\"\n >\n @for (cell of row.data(); track $index) {\n <ng-template #cellTmp>\n <div\n class=\"ard-table__cell-container\"\n [style]=\"getCellStyle(row.dataColumns()[$index])\"\n >\n @if (isCellCheckbox(cell)) {\n <ng-template\n #defaultCheckboxTemplate\n let-isChecked\n let-onChange=\"onChange\"\n let-disabled=\"disabled\"\n >\n <ard-checkbox\n [tabIndex]=\"isLoading() ? -1 : tabIndex()\"\n [selected]=\"isChecked\"\n [color]=\"color()\"\n [disabled]=\"disabled\"\n (change)=\"onChange()\"\n (click)=\"$event.stopPropagation()\"\n />\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"checkboxTemplate() ?? defaultCheckboxTemplate\"\n [ngTemplateOutletContext]=\"getCheckboxContext(row.index())\"\n />\n } @else {\n <ng-template\n #defaultCellTemplate\n let-content\n >\n {{ content }}\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"getCellTemplate(row.dataColumns()[$index].template) ?? defaultCellTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: cell }\"\n />\n }\n </div>\n </ng-template>\n @if (!row.dataColumns()[$index].isRowHeader) {\n <td\n class=\"ard-table__body-cell\"\n [ngClass]=\"row.dataColumns()[$index].cellClass\"\n [class.ard-table__checkbox-cell]=\"isCellCheckbox(cell)\"\n >\n <ng-template [ngTemplateOutlet]=\"cellTmp\"></ng-template>\n </td>\n } @else {\n <th\n class=\"ard-table__body-cell ard-table__row-header\"\n scope=\"row\"\n [ngClass]=\"row.dataColumns()[$index].cellClass\"\n [class.ard-table__checkbox-cell]=\"isCellCheckbox(cell)\"\n >\n <ng-template [ngTemplateOutlet]=\"cellTmp\"></ng-template>\n </th>\n }\n }\n </tr>\n }\n }\n </tbody>\n @if (canDisplayPagination()) {\n <tfoot class=\"ard-table__foot\">\n <tr class=\"ard-table__foot-row\">\n <td\n class=\"ard-table__pagination-cell\"\n colspan=\"9999\"\n >\n <ard-table-pagination\n [options]=\"paginationOptions()\"\n [totalItems]=\"totalItems()!\"\n [disabled]=\"paginationDisabled()\"\n [(itemsPerPage)]=\"itemsPerPage\"\n [(page)]=\"page\"\n [align]=\"paginationAlign()\"\n [isLoading]=\"isLoading()\"\n [itemsPerPageText]=\"itemsPerPageText()\"\n [currentItemsFormatFn]=\"currentItemsFormatFn()\"\n />\n </td>\n </tr>\n </tfoot>\n }\n</table>\n", styles: [".ard-table__cell-container,.ard-table__header-template-container{width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.ArdiumCheckboxComponent, selector: "ard-checkbox", inputs: ["wrapperClasses", "htmlId", "color", "unselectedColor", "state"], outputs: ["stateChange"] }, { kind: "component", type: i3.ArdiumTablePaginationComponent, selector: "ard-table-pagination", inputs: ["totalItems", "options", "itemsPerPage", "page", "color", "align", "compact", "useFirstLastButtons", "isLoading", "itemsPerPageText", "currentItemsFormatFn"], outputs: ["itemsPerPageChange", "pageChange"] }, { kind: "component", type: i4.ArdiumIconComponent, selector: "ard-icon", inputs: ["ariaLabel", "icon", "filled", "weight", "grade", "opticalSize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
369
339
  }
370
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ArdiumTableComponent, decorators: [{
340
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: ArdiumTableComponent, decorators: [{
371
341
  type: Component,
372
- args: [{ selector: 'ard-table', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<table class=\"ard-table\" [ngClass]=\"ngClasses\">\r\n <caption\r\n *ngIf=\"caption\"\r\n class=\"ard-table__caption\"\r\n >\r\n <div class=\"ard-table__caption-container\">\r\n <ng-template #defaultCaptionTemplate let-captionText>\r\n {{ captionText }}\r\n </ng-template>\r\n \r\n <ng-template\r\n [ngTemplateOutlet]=\"captionTemplate ?? defaultCaptionTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: caption }\"\r\n />\r\n </div>\r\n </caption>\r\n <thead class=\"ard-table__header\">\r\n <tr class=\"ard-table__header-row\" *ngFor=\"let row of headerCells\">\r\n <th\r\n *ngFor=\"let cell of row; let index = index\"\r\n class=\"ard-table__header-cell\"\r\n [ngClass]=\"cell.cell.cellClass\"\r\n [class.ard-table__checkbox-cell]=\"isHeaderCellCheckbox(cell)\"\r\n [attr.colspan]=\"cell.colspan\"\r\n [attr.rowspan]=\"cell.rowspan\"\r\n [scope]=\"cell.colspan > 1 ? 'colgroup' : 'col'\"\r\n >\r\n <div\r\n class=\"ard-table__cell-container\"\r\n [class.ard-table__sortable]=\"isHeaderCellSortable(cell)\"\r\n [style.width]=\"cell.width\"\r\n [style.minWidth]=\"cell.minWidth\"\r\n >\r\n <ng-container *ngIf=\"isHeaderCellCheckbox(cell)\">\r\n <ng-template #defaultHeaderCheckboxTemplate let-state let-onChange=\"onChange\">\r\n <ard-checkbox [tabIndex]=\"isLoading ? -1 : tabIndex\" [state]=\"state\" [color]=\"getHeaderCheckboxColor()\" unselectedColor=\"currentColor\" (change)=\"onChange()\" />\r\n </ng-template>\r\n \r\n <ng-template\r\n [ngTemplateOutlet]=\"headerCheckboxTemplate ?? defaultHeaderCheckboxTemplate\"\r\n [ngTemplateOutletContext]=\"getHeaderCheckboxContext()\"\r\n />\r\n </ng-container>\r\n <ng-container *ngIf=\"!isHeaderCellCheckbox(cell)\">\r\n <ng-template\r\n #defaultHeaderCellTemplate\r\n let-content\r\n let-sortable=\"sortable\"\r\n let-sortType=\"sortType\"\r\n let-onTriggerSort=\"onTriggerSort\"\r\n let-onTriggerResetSort=\"onTriggerResetSort\"\r\n >\r\n <div\r\n class=\"ard-table__header-template-container\"\r\n [class.ard-sortable]=\"sortable\"\r\n [class.ard-nonsortable]=\"!sortable\"\r\n >\r\n <button\r\n class=\"ard-table__header-content-container\"\r\n *ngIf=\"sortable\"\r\n (click)=\"onTriggerSort($event)\"\r\n [tabindex]=\"tabIndex\"\r\n (keydown.Esc)=\"onTriggerResetSort($event)\"\r\n >\r\n <div class=\"ard-table__header-content\">{{ content }}</div>\r\n <div class=\"ard-table__header-sort-icon\" *ngIf=\"sortType != null\">\r\n <ard-icon *ngIf=\"sortType == 'ascending'\">south</ard-icon>\r\n <ard-icon *ngIf=\"sortType == 'descending'\">north</ard-icon>\r\n </div>\r\n </button>\r\n <div\r\n class=\"ard-table__header-content-container\"\r\n *ngIf=\"!sortable\"\r\n >\r\n <div class=\"ard-table__header-content\">{{ content }}</div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n \r\n <ng-template \r\n [ngTemplateOutlet]=\"getHeaderTemplate(cell.cell.header) ?? defaultHeaderCellTemplate\"\r\n [ngTemplateOutletContext]=\"getHeaderContext(cell.cell, index)\"\r\n />\r\n </ng-container>\r\n </div>\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody class=\"ard-table__body\">\r\n <ng-container *ngFor=\"let row of dataRows; let rowIndex = index;\">\r\n <tr *ngIf=\"row.isEmpty\" class=\"ard-table__empty-row\">\r\n <td class=\"ard-table__empty-cell\" colspan=\"9999\"></td>\r\n </tr>\r\n <tr\r\n *ngIf=\"!row.isEmpty\"\r\n class=\"ard-table__body-row\"\r\n [class.ard-table__selected-row]=\"row.selected\"\r\n [class.ard-table__highlighted-row]=\"row.highlighted\"\r\n [class.ard-table__disabled-row]=\"row.disabled\"\r\n [class.ard-table__bold-row]=\"row.bold\"\r\n (click)=\"onRowClick(rowIndex, $event)\"\r\n (mouseover)=\"onRowMouseOver($event)\"\r\n (mouseenter)=\"onRowMouseEnter(rowIndex, $event)\"\r\n (mouseleave)=\"onRowMouseLeave(rowIndex, $event)\"\r\n >\r\n <ng-container *ngFor=\"let cell of row.data; let cellIndex = index\">\r\n <ng-template #cellTmp>\r\n <div\r\n class=\"ard-table__cell-container\"\r\n [style]=\"getCellStyle(row.dataColumns[cellIndex])\"\r\n >\r\n <ng-container *ngIf=\"isCellCheckbox(cell)\">\r\n <ng-template #defaultCheckboxTemplate let-isChecked let-onChange=\"onChange\" let-disabled=\"disabled\">\r\n <ard-checkbox [tabIndex]=\"isLoading ? -1 : tabIndex\" [selected]=\"isChecked\" [color]=\"color\" [disabled]=\"disabled\" (change)=\"onChange()\" (click)=\"$event.stopPropagation()\" />\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"checkboxTemplate ?? defaultCheckboxTemplate\"\r\n [ngTemplateOutletContext]=\"getCheckboxContext(rowIndex)\"\r\n />\r\n </ng-container>\r\n <ng-container *ngIf=\"!isCellCheckbox(cell)\">\r\n <ng-template #defaultCellTemplate let-content>\r\n {{ content }}\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"getCellTemplate(row.dataColumns[cellIndex].template) ?? defaultCellTemplate\"\r\n [ngTemplateOutletContext]=\"{ $implicit: cell }\"\r\n />\r\n </ng-container>\r\n </div>\r\n </ng-template>\r\n <td\r\n *ngIf=\"!row.dataColumns[cellIndex].isRowHeader\"\r\n class=\"ard-table__body-cell\"\r\n [ngClass]=\"row.dataColumns[cellIndex].cellClass\"\r\n [class.ard-table__checkbox-cell]=\"isCellCheckbox(cell)\"\r\n >\r\n <ng-template [ngTemplateOutlet]=\"cellTmp\"></ng-template>\r\n </td>\r\n <th\r\n *ngIf=\"row.dataColumns[cellIndex].isRowHeader\"\r\n class=\"ard-table__body-cell ard-table__row-header\"\r\n scope=\"row\"\r\n [ngClass]=\"row.dataColumns[cellIndex].cellClass\"\r\n [class.ard-table__checkbox-cell]=\"isCellCheckbox(cell)\"\r\n >\r\n <ng-template [ngTemplateOutlet]=\"cellTmp\"></ng-template>\r\n </th>\r\n </ng-container>\r\n </tr>\r\n </ng-container>\r\n </tbody>\r\n <tfoot class=\"ard-table__foot\" *ngIf=\"canDisplayPagination\">\r\n <tr class=\"ard-table__foot-row\">\r\n <td class=\"ard-table__pagination-cell\" colspan=\"9999\">\r\n <ard-table-pagination\r\n [options]=\"paginationOptions\"\r\n [(page)]=\"page\"\r\n [totalItems]=\"totalItems\"\r\n [disabled]=\"paginationDisabled\"\r\n [(itemsPerPage)]=\"itemsPerPage\"\r\n [align]=\"paginationAlign\"\r\n [isLoading]=\"isLoading\"\r\n [itemsPerPageText]=\"itemsPerPageText\"\r\n [currentItemsFormatFn]=\"currentItemsFormatFn\"\r\n (itemsPerPageChange)=\"itemsPerPageChange.emit($event)\"\r\n (pageChange)=\"pageChange.emit($event)\"\r\n ></ard-table-pagination>\r\n </td>\r\n </tr>\r\n </tfoot>\r\n</table>", styles: [".ard-table__cell-container,.ard-table__header-template-container{width:100%;height:100%}\n"] }]
373
- }], propDecorators: { rowDisabledFrom: [{
374
- type: Input
375
- }], rowBoldFrom: [{
376
- type: Input
377
- }], invertRowDisabled: [{
378
- type: Input
379
- }], invertRowBold: [{
380
- type: Input
381
- }], selectableRows: [{
382
- type: Input
383
- }], caption: [{
384
- type: Input
385
- }], isLoading: [{
386
- type: Input
387
- }], loadingProgress: [{
388
- type: Input
389
- }], appearance: [{
390
- type: Input
391
- }], variant: [{
392
- type: Input
393
- }], color: [{
394
- type: Input
395
- }], align: [{
396
- type: Input
397
- }], headerAlign: [{
398
- type: Input
399
- }], compact: [{
400
- type: Input
401
- }], zebra: [{
402
- type: Input
403
- }], stickyHeader: [{
404
- type: Input
405
- }], paginated: [{
406
- type: Input
407
- }], paginationStrategy: [{
408
- type: Input
409
- }], paginationOptions: [{
410
- type: Input
411
- }], totalItems: [{
412
- type: Input
413
- }], paginationColor: [{
414
- type: Input
415
- }], paginationAlign: [{
416
- type: Input
417
- }], itemsPerPageText: [{
418
- type: Input
419
- }], currentItemsFormatFn: [{
420
- type: Input
421
- }], pageFillRemaining: [{
422
- type: Input
423
- }], paginationDisabled: [{
424
- type: Input
425
- }], useFirstLastButtons: [{
426
- type: Input
427
- }], itemsPerPage: [{
428
- type: Input
429
- }], itemsPerPageChange: [{
430
- type: Output
431
- }], page: [{
432
- type: Input
433
- }], pageChange: [{
434
- type: Output
435
- }], columns: [{
342
+ args: [{ selector: 'ard-table', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<table\n class=\"ard-table\"\n [ngClass]=\"ngClasses()\"\n>\n @if (caption()) {\n <caption class=\"ard-table__caption\">\n <div class=\"ard-table__caption-container\">\n <ng-template\n #defaultCaptionTemplate\n let-captionText\n >\n {{ captionText }}\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"captionTemplate() ?? defaultCaptionTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: caption() }\"\n />\n </div>\n </caption>\n }\n <thead class=\"ard-table__header\">\n @for (row of headerCells(); track $index) {\n <tr class=\"ard-table__header-row\">\n @for (cell of row; track $index) {\n <th\n class=\"ard-table__header-cell\"\n [ngClass]=\"cell.cell().cellClass\"\n [class.ard-table__checkbox-cell]=\"isHeaderCellCheckbox(cell)\"\n [attr.colspan]=\"cell.colspan()\"\n [attr.rowspan]=\"cell.rowspan()\"\n [scope]=\"cell.colspan() > 1 ? 'colgroup' : 'col'\"\n >\n <div\n class=\"ard-table__cell-container\"\n [class.ard-table__sortable]=\"isHeaderCellSortable(cell)\"\n [style.width]=\"cell.width\"\n [style.minWidth]=\"cell.minWidth\"\n >\n @if (isHeaderCellCheckbox(cell)) {\n <ng-template\n #defaultHeaderCheckboxTemplate\n let-state\n let-onChange=\"onChange\"\n >\n <ard-checkbox\n [tabIndex]=\"isLoading() ? -1 : tabIndex()\"\n [state]=\"state\"\n [color]=\"getHeaderCheckboxColor()\"\n unselectedColor=\"currentColor\"\n (change)=\"onChange()\"\n />\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"headerCheckboxTemplate() ?? defaultHeaderCheckboxTemplate\"\n [ngTemplateOutletContext]=\"getHeaderCheckboxContext()\"\n />\n } @else {\n <ng-template\n #defaultHeaderCellTemplate\n let-content\n let-sortable=\"sortable\"\n let-sortType=\"sortType\"\n let-onTriggerSort=\"onTriggerSort\"\n let-onTriggerResetSort=\"onTriggerResetSort\"\n >\n <div\n class=\"ard-table__header-template-container\"\n [class.ard-sortable]=\"sortable\"\n [class.ard-nonsortable]=\"!sortable\"\n >\n @if (sortable) {\n <button\n class=\"ard-table__header-content-container\"\n (click)=\"onTriggerSort($event)\"\n [tabindex]=\"tabIndex()\"\n (keydown.Esc)=\"onTriggerResetSort($event)\"\n >\n <div class=\"ard-table__header-content\">{{ content }}</div>\n @if (sortType !== null) {\n <div class=\"ard-table__header-sort-icon\">\n @if (sortType === 'ascending') {\n <ard-icon>south</ard-icon>\n } @else if (sortType === 'descending') {\n <ard-icon>north</ard-icon>\n }\n </div>\n }\n </button>\n } @else {\n <div class=\"ard-table__header-content-container\">\n <div class=\"ard-table__header-content\">{{ content }}</div>\n </div>\n }\n </div>\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"getHeaderTemplate(cell.cell().header) ?? defaultHeaderCellTemplate\"\n [ngTemplateOutletContext]=\"getHeaderContext(cell.cell(), $index)\"\n />\n }\n </div>\n </th>\n }\n </tr>\n }\n </thead>\n <tbody class=\"ard-table__body\">\n @for (row of dataRows(); track $index) {\n @if (row.isEmpty()) {\n <tr class=\"ard-table__empty-row\">\n <td\n class=\"ard-table__empty-cell\"\n colspan=\"9999\"\n ></td>\n </tr>\n } @else {\n <tr\n class=\"ard-table__body-row\"\n [class.ard-table__selected-row]=\"row.selected()\"\n [class.ard-table__highlighted-row]=\"row.highlighted()\"\n [class.ard-table__disabled-row]=\"row.disabled()\"\n [class.ard-table__bold-row]=\"row.bold()\"\n (click)=\"onRowClick(row, $event)\"\n (mouseover)=\"onRowMouseOver($event)\"\n (mouseenter)=\"onRowMouseEnter(row.index(), $event)\"\n (mouseleave)=\"onRowMouseLeave(row.index(), $event)\"\n >\n @for (cell of row.data(); track $index) {\n <ng-template #cellTmp>\n <div\n class=\"ard-table__cell-container\"\n [style]=\"getCellStyle(row.dataColumns()[$index])\"\n >\n @if (isCellCheckbox(cell)) {\n <ng-template\n #defaultCheckboxTemplate\n let-isChecked\n let-onChange=\"onChange\"\n let-disabled=\"disabled\"\n >\n <ard-checkbox\n [tabIndex]=\"isLoading() ? -1 : tabIndex()\"\n [selected]=\"isChecked\"\n [color]=\"color()\"\n [disabled]=\"disabled\"\n (change)=\"onChange()\"\n (click)=\"$event.stopPropagation()\"\n />\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"checkboxTemplate() ?? defaultCheckboxTemplate\"\n [ngTemplateOutletContext]=\"getCheckboxContext(row.index())\"\n />\n } @else {\n <ng-template\n #defaultCellTemplate\n let-content\n >\n {{ content }}\n </ng-template>\n\n <ng-template\n [ngTemplateOutlet]=\"getCellTemplate(row.dataColumns()[$index].template) ?? defaultCellTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: cell }\"\n />\n }\n </div>\n </ng-template>\n @if (!row.dataColumns()[$index].isRowHeader) {\n <td\n class=\"ard-table__body-cell\"\n [ngClass]=\"row.dataColumns()[$index].cellClass\"\n [class.ard-table__checkbox-cell]=\"isCellCheckbox(cell)\"\n >\n <ng-template [ngTemplateOutlet]=\"cellTmp\"></ng-template>\n </td>\n } @else {\n <th\n class=\"ard-table__body-cell ard-table__row-header\"\n scope=\"row\"\n [ngClass]=\"row.dataColumns()[$index].cellClass\"\n [class.ard-table__checkbox-cell]=\"isCellCheckbox(cell)\"\n >\n <ng-template [ngTemplateOutlet]=\"cellTmp\"></ng-template>\n </th>\n }\n }\n </tr>\n }\n }\n </tbody>\n @if (canDisplayPagination()) {\n <tfoot class=\"ard-table__foot\">\n <tr class=\"ard-table__foot-row\">\n <td\n class=\"ard-table__pagination-cell\"\n colspan=\"9999\"\n >\n <ard-table-pagination\n [options]=\"paginationOptions()\"\n [totalItems]=\"totalItems()!\"\n [disabled]=\"paginationDisabled()\"\n [(itemsPerPage)]=\"itemsPerPage\"\n [(page)]=\"page\"\n [align]=\"paginationAlign()\"\n [isLoading]=\"isLoading()\"\n [itemsPerPageText]=\"itemsPerPageText()\"\n [currentItemsFormatFn]=\"currentItemsFormatFn()\"\n />\n </td>\n </tr>\n </tfoot>\n }\n</table>\n", styles: [".ard-table__cell-container,.ard-table__header-template-container{width:100%;height:100%}\n"] }]
343
+ }], propDecorators: { columns: [{
436
344
  type: Input
437
345
  }], data: [{
438
346
  type: Input
439
- }], treatDataSourceAsString: [{
440
- type: Input
441
- }], checkboxTemplate: [{
442
- type: ContentChild,
443
- args: [ArdiumTableCheckboxTemplateDirective, { read: TemplateRef }]
444
- }], headerCheckboxTemplate: [{
445
- type: ContentChild,
446
- args: [ArdiumTableHeaderCheckboxTemplateDirective, {
447
- read: TemplateRef,
448
- }]
449
- }], captionTemplate: [{
450
- type: ContentChild,
451
- args: [ArdiumTableCaptionTemplateDirective, { read: TemplateRef }]
452
- }], templateChildren: [{
453
- type: ContentChildren,
454
- args: [ArdiumTableTemplateDirective]
455
- }], selectedRowsChangeEvent: [{
456
- type: Output,
457
- args: ['selectedRowsChange']
458
- }], failedSelectRowEvent: [{
459
- type: Output,
460
- args: ['failedSelectRow']
461
- }], selectRowEvent: [{
462
- type: Output,
463
- args: ['selectRow']
464
- }], unselectRowEvent: [{
465
- type: Output,
466
- args: ['unselectRow']
467
347
  }] } });
468
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/table/table.component.ts","../../../../../projects/ui/src/lib/table/table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,eAAe,EACf,YAAY,EACZ,KAAK,EACL,MAAM,EAEN,WAAW,EACX,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAwB,eAAe,EAAE,MAAM,4CAA4C,CAAC;AACnG,OAAO,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAC7E,OAAO,EAA2B,gBAAgB,EAAwB,MAAM,sBAAsB,CAAC;AACvG,OAAO,EACL,mCAAmC,EACnC,oCAAoC,EACpC,0CAA0C,EAC1C,4BAA4B,GAC7B,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAEL,cAAc,EACd,eAAe,EAMf,uBAAuB,EAEvB,YAAY,GAEb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;;;;;;AAS3C,MAAM,OAAO,oBAAqB,SAAQ,uBAAuB;IAPjE;;QAQmB,iBAAY,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAElD,aAAQ,GAAG;YAClB,eAAe,EAAE,UAAU;YAC3B,WAAW,EAAE,MAAM;SACpB,CAAC;QAKM,uBAAkB,GAAY,KAAK,CAAC;QASpC,mBAAc,GAAY,KAAK,CAAC;QAShC,oBAAe,GAAY,KAAK,CAAC;QAczC,cAAc;QACL,eAAU,GAAoB,eAAe,CAAC,MAAM,CAAC;QACrD,YAAO,GAAiB,YAAY,CAAC,OAAO,CAAC;QAC7C,UAAK,GAAmB,cAAc,CAAC,OAAO,CAAC;QAC/C,UAAK,GAAmB,cAAc,CAAC,UAAU,CAAC;QAClD,gBAAW,GAAmB,cAAc,CAAC,UAAU,CAAC;QAEzD,aAAQ,GAAY,KAAK,CAAC;QAS1B,WAAM,GAAY,KAAK,CAAC;QASxB,kBAAa,GAAY,KAAK,CAAC;QAwBvC,cAAc;QACN,eAAU,GAAY,KAAK,CAAC;QAS3B,uBAAkB,GAA4B,uBAAuB,CAAC,IAAI,CAAC;QAE3E,sBAAiB,GAAkD,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAEhF,oBAAe,GAAmB,cAAc,CAAC,IAAI,CAAC;QACtD,oBAAe,GAAoB,eAAe,CAAC,KAAK,CAAC;QACzD,qBAAgB,GAAW,iBAAiB,CAAC;QAC7C,yBAAoB,GAAyB,CAAC,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,UAAU,EAAE,EAAE,EAAE;YAC5G,OAAO,GAAG,iBAAiB,MAAM,gBAAgB,OAAO,UAAU,EAAE,CAAC;QACvE,CAAC,CAAC;QAEM,uBAAkB,GAAY,KAAK,CAAC;QASpC,wBAAmB,GAAY,KAAK,CAAC;QASrC,yBAAoB,GAAY,KAAK,CAAC;QAStC,kBAAa,GAAW,EAAE,CAAC;QAQzB,uBAAkB,GAAG,IAAI,YAAY,EAAU,CAAC;QAElD,UAAK,GAAW,CAAC,CAAC;QAQhB,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QAuC1C,UAAK,GAAU,EAAE,CAAC;QAUlB,6BAAwB,GAAY,KAAK,CAAC;QAmB1C,mBAAc,GAAwC,EAAE,CAAC;QAoHnC,4BAAuB,GAAG,IAAI,YAAY,EAAS,CAAC;QACvD,yBAAoB,GAAG,IAAI,YAAY,EAAS,CAAC;QACvD,mBAAc,GAAG,IAAI,YAAY,EAAS,CAAC;QACzC,qBAAgB,GAAG,IAAI,YAAY,EAAS,CAAC;KAuDrE;IApYC,IACI,iBAAiB;QACnB,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACjC,CAAC;IACD,IAAI,iBAAiB,CAAC,CAAM;QAC1B,IAAI,CAAC,kBAAkB,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IACrD,CAAC;IAGD,IACI,aAAa;QACf,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IACD,IAAI,aAAa,CAAC,CAAM;QACtB,IAAI,CAAC,cAAc,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IACjD,CAAC;IAGD,IACI,cAAc;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IACD,IAAI,cAAc,CAAC,CAAM;QACvB,IAAI,CAAC,eAAe,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAClD,CAAC;IAeD,IACI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IACD,IAAI,OAAO,CAAC,CAAM;QAChB,IAAI,CAAC,QAAQ,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAC3C,CAAC;IAGD,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IACD,IAAI,KAAK,CAAC,CAAM;QACd,IAAI,CAAC,MAAM,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IACzC,CAAC;IAGD,IACI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACD,IAAI,YAAY,CAAC,CAAM;QACrB,IAAI,CAAC,aAAa,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAChD,CAAC;IAED,IAAI,SAAS;QACX,OAAO;YACL,kBAAkB,IAAI,CAAC,UAAU,EAAE;YACnC,eAAe,IAAI,CAAC,OAAO,EAAE;YAC7B,aAAa,IAAI,CAAC,KAAK,EAAE;YACzB,aAAa,IAAI,CAAC,KAAK,EAAE;YACzB,oBAAoB,IAAI,CAAC,WAAW,EAAE;YACtC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;YACjC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE;YACnC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE;YAChD,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE;YAC5C,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE;SAC1C,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACd,CAAC;IAID,IACI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IACD,IAAI,SAAS,CAAC,CAAM;QAClB,IAAI,CAAC,UAAU,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAC7C,CAAC;IAcD,IACI,iBAAiB;QACnB,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACjC,CAAC;IACD,IAAI,iBAAiB,CAAC,CAAM;QAC1B,IAAI,CAAC,kBAAkB,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IACrD,CAAC;IAGD,IACI,kBAAkB;QACpB,OAAO,IAAI,CAAC,mBAAmB,CAAC;IAClC,CAAC;IACD,IAAI,kBAAkB,CAAC,CAAM;QAC3B,IAAI,CAAC,mBAAmB,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IACtD,CAAC;IAGD,IACI,mBAAmB;QACrB,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACnC,CAAC;IACD,IAAI,mBAAmB,CAAC,CAAM;QAC5B,IAAI,CAAC,oBAAoB,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IACvD,CAAC;IAGD,IACI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACD,IAAI,YAAY,CAAC,CAAM;QACrB,IAAI,CAAC,aAAa,GAAG,oBAAoB,CAAC,CAAC,CAAC,CAAC;IAC/C,CAAC;IAID,IACI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IACD,IAAI,IAAI,CAAC,CAAM;QACb,IAAI,CAAC,KAAK,GAAG,oBAAoB,CAAC,CAAC,CAAC,CAAC;IACvC,CAAC;IAGD,IAAI,mBAAmB;QACrB,OAAO,CAAC,IAAI,CAAC,kBAAkB,IAAI,uBAAuB,CAAC,IAAI,IAAI,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,IAAI,CAAC,kBAAkB,IAAI,uBAAuB,CAAC,IAAI,CAAC;IAC5J,CAAC;IACD,IAAI,oBAAoB;QACtB,iBAAiB;QACjB,OAAO,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,mBAAmB,CAAC;IACpD,CAAC;IAED,wBAAwB;IACxB,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC;IACvC,CAAC;IACD,IAAI,QAAQ;QACV,MAAM,KAAK,GAAkB,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC;QAE9D,IAAI,CAAC,IAAI,CAAC,iBAAiB;YAAE,OAAO,KAAK,CAAC;QAC1C,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;SACrE;QACD,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC;YAAE,OAAO,KAAK,CAAC;QACjC,KAAK,IAAI,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC,EAAE,EAAE;YACrD,KAAK,CAAC,IAAI,CAAC;gBACT,QAAQ,EAAE,IAAI;gBACd,KAAK,EAAE,CAAC;gBACR,IAAI,EAAE,EAAE;gBACR,WAAW,EAAE,EAAE;gBACf,OAAO,EAAE,IAAI;aACd,CAAC,CAAC;SACJ;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,wBAAwB;IACxB,IACI,OAAO,CAAC,CAAuC;QACjD,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IAClC,CAAC;IAED,IACI,IAAI,CAAC,CAAQ;QACf,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IAChC,CAAC;IACD,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAGD,IACI,uBAAuB;QACzB,OAAO,IAAI,CAAC,wBAAwB,CAAC;IACvC,CAAC;IACD,IAAI,uBAAuB,CAAC,CAAM;QAChC,IAAI,CAAC,wBAAwB,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAC3D,CAAC;IAgBD,kBAAkB;QAChB,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACpD,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;YAChC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE;gBAClB,OAAO,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC,CAAC;gBAC9E,SAAS;aACV;YACD,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC;SACxD;IACH,CAAC;IAED,iBAAiB,CAAC,GAAqD;QACrE,IAAI,OAAO,GAAG,IAAI,QAAQ;YAAE,OAAO,SAAS,CAAC;QAC7C,OAAO,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAC5C,CAAC;IACD,sBAAsB;QACpB,IAAI,IAAI,CAAC,UAAU,IAAI,eAAe,CAAC,MAAM;YAAE,OAAO,oBAAoB,CAAC,YAAY,CAAC;QACxF,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IACD,eAAe,CAAC,GAA+B;QAC7C,kBAAkB;QAClB,IAAI,CAAC,GAAG;YAAE,OAAO,SAAS,CAAC;QAC3B,+BAA+B;QAC/B,IAAI,GAAG,YAAY,WAAW;YAAE,OAAO,GAAG,CAAC;QAC3C,gCAAgC;QAChC,IAAI,CAAC,CAAC,GAAG,IAAI,IAAI,CAAC,cAAc,CAAC,EAAE;YACjC,OAAO,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,kDAAkD,GAAG,GAAG,CAAC,CAAC,CAAC;YACnF,OAAO,SAAS,CAAC;SAClB;QACD,qBAAqB;QACrB,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;IAClC,CAAC;IACD,YAAY,CAAC,IAAsC;QACjD,IAAI,gBAAgB,CAAC,IAAI,CAAC;YAAE,OAAO,6BAA6B,CAAC;QACjE,MAAM,KAAK,GAAG,OAAO,IAAI,CAAC,KAAK,IAAI,QAAQ,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;QAC7E,MAAM,QAAQ,GAAG,OAAO,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;QACzF,OAAO,CAAC,SAAS,KAAK,IAAI,OAAO,EAAE,EAAE,aAAa,QAAQ,IAAI,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrF,CAAC;IAED,0BAA0B;IAC1B,eAAe,CAAC,KAAa;QAC3B,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IACD,UAAU,CAAC,KAAa,EAAE,KAAiB;QACzC,IAAI,CAAC,IAAI,CAAC,cAAc;YAAE,OAAO;QACjC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IACD,cAAc,CAAC,KAAiB;QAC9B,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;IACD,eAAe,CAAC,KAAa,EAAE,KAAiB;QAC9C,IAAI,CAAC,IAAI,CAAC,cAAc;YAAE,OAAO;QACjC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC;IACD,eAAe,CAAC,KAAa,EAAE,KAAiB;QAC9C,IAAI,CAAC,IAAI,CAAC,cAAc;YAAE,OAAO;QACjC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;IAC3C,CAAC;IAED,mBAAmB;IACnB;;;;OAIG;IACH,iBAAiB,CAAC,KAAa;QAC7B,IAAI,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,KAAK,CAAC,EAAE;YAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YACzD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACxC;aAAM;YACL,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;YAC/D,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACnC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACxC;QACD,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IACD;;OAEG;IACH,qBAAqB;QACnB,IAAI,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE;YACpC,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;YACnD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACxC;aAAM;YACL,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;YACzD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACnC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACxC;QACD,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IACO,WAAW;QACjB,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;QAClC,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACvC,CAAC;IACD,cAAc,CAAC,IAAS;QACtB,OAAO,OAAO,IAAI,IAAI,QAAQ,IAAI,cAAc,IAAI,IAAI,IAAI,OAAO,IAAI,IAAI,CAAC;IAC9E,CAAC;IACD,oBAAoB,CAAC,IAAgB;QACnC,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC;QAC3B,IAAI,gBAAgB,CAAC,QAAQ,CAAC;YAAE,OAAO,KAAK,CAAC;QAC7C,IAAI,OAAO,QAAQ,CAAC,UAAU,IAAI,QAAQ;YAAE,OAAO,KAAK,CAAC;QACzD,OAAO,QAAQ,CAAC,UAAU,CAAC,IAAI,IAAI,UAAU,CAAC;IAChD,CAAC;IACD,oBAAoB,CAAC,IAAgB;QACnC,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC;QAC3B,IAAI,gBAAgB,CAAC,QAAQ,CAAC;YAAE,OAAO,KAAK,CAAC;QAC7C,OAAO,QAAQ,CAAC,QAAQ,IAAI,KAAK,CAAC;IACpC,CAAC;IAWD,gBAAgB,CAAC,IAAsC,EAAE,KAAa;QACpE,IAAI,OAAO,IAAI,CAAC,MAAM,IAAI,QAAQ;YAAE,OAAO,IAAI,CAAC;QAChD,IAAI,gBAAgB,CAAC,IAAI,CAAC;YACxB,OAAO;gBACL,SAAS,EAAE,IAAI,CAAC,MAAM;gBACtB,MAAM,EAAE,IAAI,CAAC,MAAM;aACpB,CAAC;QACJ,OAAO;YACL,SAAS,EAAE,IAAI,CAAC,MAAM;YACtB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;YAChC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,KAAK,CAAC;YACpD,aAAa,EAAE,CAAC,KAAa,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC,KAAK,CAAC;YAClF,kBAAkB,EAAE,CAAC,KAAa,EAAE,EAAE;gBACpC,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;gBAC9B,KAAK,EAAE,cAAc,EAAE,CAAC;gBACxB,KAAK,EAAE,eAAe,EAAE,CAAC;YAC3B,CAAC;SACF,CAAC;IACJ,CAAC;IACD,wBAAwB;QACtB,IAAI,KAAK,GAAkB,aAAa,CAAC,UAAU,CAAC;QACpD,IAAI,IAAI,CAAC,YAAY,CAAC,iBAAiB,EAAE;YACvC,KAAK,GAAG,aAAa,CAAC,aAAa,CAAC;YACpC,IAAI,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE;gBACpC,KAAK,GAAG,aAAa,CAAC,QAAQ,CAAC;aAChC;SACF;QACD,OAAO;YACL,SAAS,EAAE,KAAK;YAChB,KAAK;YACL,QAAQ,EAAE,GAAG,EAAE;gBACb,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC/B,CAAC;SACF,CAAC;IACJ,CAAC;IACD,kBAAkB,CAAC,KAAa;QAC9B,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,KAAK,CAAE,CAAC;QAClE,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,KAAK,CAAC;QACxC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,KAAK,CAAC;QACxC,OAAO;YACL,SAAS,EAAE,QAAQ;YACnB,QAAQ;YACR,QAAQ;YACR,QAAQ,EAAE,GAAG,EAAE;gBACb,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;YAC9B,CAAC;SACF,CAAC;IACJ,CAAC;8GA/YU,oBAAoB;kGAApB,oBAAoB,wxCAyNjB,oCAAoC,2BAAU,WAAW,sEAEzD,0CAA0C,2BAChD,WAAW,+DAGL,mCAAmC,2BAAU,WAAW,mDAIrD,4BAA4B,oDCpR/C,qhTA6KQ;;2FD5HK,oBAAoB;kBAPhC,SAAS;+BACE,WAAW,iBAGN,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;8BAUtC,eAAe;sBAAvB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAIF,iBAAiB;sBADpB,KAAK;gBAUF,aAAa;sBADhB,KAAK;gBAUF,cAAc;sBADjB,KAAK;gBAQG,OAAO;sBAAf,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAIF,OAAO;sBADV,KAAK;gBAUF,KAAK;sBADR,KAAK;gBAUF,YAAY;sBADf,KAAK;gBA0BF,SAAS;sBADZ,KAAK;gBAQG,kBAAkB;sBAA1B,KAAK;gBAEG,iBAAiB;sBAAzB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBAMF,iBAAiB;sBADpB,KAAK;gBAUF,kBAAkB;sBADrB,KAAK;gBAUF,mBAAmB;sBADtB,KAAK;gBAUF,YAAY;sBADf,KAAK;gBAOI,kBAAkB;sBAA3B,MAAM;gBAIH,IAAI;sBADP,KAAK;gBAOI,UAAU;sBAAnB,MAAM;gBAoCH,OAAO;sBADV,KAAK;gBAMF,IAAI;sBADP,KAAK;gBAWF,uBAAuB;sBAD1B,KAAK;gBAUN,gBAAgB;sBADf,YAAY;uBAAC,oCAAoC,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;gBAKzE,sBAAsB;sBAHrB,YAAY;uBAAC,0CAA0C,EAAE;wBACxD,IAAI,EAAE,WAAW;qBAClB;gBAGD,eAAe;sBADd,YAAY;uBAAC,mCAAmC,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;gBAKxE,gBAAgB;sBADf,eAAe;uBAAC,4BAA4B;gBAmHf,uBAAuB;sBAApD,MAAM;uBAAC,oBAAoB;gBACD,oBAAoB;sBAA9C,MAAM;uBAAC,iBAAiB;gBACJ,cAAc;sBAAlC,MAAM;uBAAC,WAAW;gBACI,gBAAgB;sBAAtC,MAAM;uBAAC,aAAa","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\nimport { isDefined } from 'simple-bool';\nimport { _FocusableComponentBase } from '../_internal/focusable-component';\nimport { CheckboxState } from '../checkbox/checkbox.types';\nimport { CurrentItemsFormatFn, PaginationAlign } from '../table-pagination/table-pagination.types';\nimport { ComponentColor, SimpleComponentColor } from '../types/colors.types';\nimport { ArdTableRow, HeaderCell, TableItemStorage, TableItemStorageHost } from './table-item-storage';\nimport {\n  ArdiumTableCaptionTemplateDirective,\n  ArdiumTableCheckboxTemplateDirective,\n  ArdiumTableHeaderCheckboxTemplateDirective,\n  ArdiumTableTemplateDirective,\n} from './table.directives';\nimport {\n  SortType,\n  TableAlignType,\n  TableAppearance,\n  TableCaptionContext,\n  TableCheckboxContext,\n  TableDataColumn,\n  TableHeaderCheckboxContext,\n  TableHeaderContext,\n  TablePaginationStrategy,\n  TableSubheader,\n  TableVariant,\n  TableSubheaderContext,\n} from './table.types';\nimport { isTableSubheader } from './utils';\n\n@Component({\n  selector: 'ard-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ArdiumTableComponent extends _FocusableComponentBase implements TableItemStorageHost, AfterContentInit {\n  private readonly _itemStorage = new TableItemStorage(this);\n\n  readonly DEFAULTS = {\n    rowDisabledFrom: 'disabled',\n    rowBoldFrom: 'bold',\n  };\n\n  @Input() rowDisabledFrom?: string;\n  @Input() rowBoldFrom?: string;\n\n  private _invertRowDisabled: boolean = false;\n  @Input()\n  get invertRowDisabled(): boolean {\n    return this._invertRowDisabled;\n  }\n  set invertRowDisabled(v: any) {\n    this._invertRowDisabled = coerceBooleanProperty(v);\n  }\n\n  private _invertRowBold: boolean = false;\n  @Input()\n  get invertRowBold(): boolean {\n    return this._invertRowBold;\n  }\n  set invertRowBold(v: any) {\n    this._invertRowBold = coerceBooleanProperty(v);\n  }\n\n  private _selectableRows: boolean = false;\n  @Input()\n  get selectableRows(): boolean {\n    return this._selectableRows;\n  }\n  set selectableRows(v: any) {\n    this._selectableRows = coerceBooleanProperty(v);\n  }\n\n  @Input() caption?: string;\n\n  @Input() isLoading?: boolean;\n  @Input() loadingProgress?: number; //TODO add progress bar\n\n  //! appearance\n  @Input() appearance: TableAppearance = TableAppearance.Strong;\n  @Input() variant: TableVariant = TableVariant.Rounded;\n  @Input() color: ComponentColor = ComponentColor.Primary;\n  @Input() align: TableAlignType = TableAlignType.CenterLeft;\n  @Input() headerAlign: TableAlignType = TableAlignType.CenterLeft;\n\n  private _compact: boolean = false;\n  @Input()\n  get compact(): boolean {\n    return this._compact;\n  }\n  set compact(v: any) {\n    this._compact = coerceBooleanProperty(v);\n  }\n\n  private _zebra: boolean = false;\n  @Input()\n  get zebra(): boolean {\n    return this._zebra;\n  }\n  set zebra(v: any) {\n    this._zebra = coerceBooleanProperty(v);\n  }\n\n  private _stickyHeader: boolean = false;\n  @Input()\n  get stickyHeader(): boolean {\n    return this._stickyHeader;\n  }\n  set stickyHeader(v: any) {\n    this._stickyHeader = coerceBooleanProperty(v);\n  }\n\n  get ngClasses(): string {\n    return [\n      `ard-appearance-${this.appearance}`,\n      `ard-variant-${this.variant}`,\n      `ard-color-${this.color}`,\n      `ard-align-${this.align}`,\n      `ard-header-align-${this.headerAlign}`,\n      this.compact ? 'ard-compact' : '',\n      this.zebra ? 'ard-zebra-table' : '',\n      this.selectableRows ? 'ard-selectable-rows' : '',\n      this.stickyHeader ? 'ard-sticky-header' : '',\n      this.isLoading ? 'ard-table-loading' : '',\n    ].join(' ');\n  }\n\n  //! pagination\n  private _paginated: boolean = false;\n  @Input()\n  get paginated(): boolean {\n    return this._paginated;\n  }\n  set paginated(v: any) {\n    this._paginated = coerceBooleanProperty(v);\n  }\n\n  @Input() paginationStrategy: TablePaginationStrategy = TablePaginationStrategy.Noop;\n\n  @Input() paginationOptions: number[] | { value: number; label: string }[] = [10, 25, 50];\n  @Input() totalItems?: number;\n  @Input() paginationColor: ComponentColor = ComponentColor.None;\n  @Input() paginationAlign: PaginationAlign = PaginationAlign.Split;\n  @Input() itemsPerPageText: string = 'Items per page:';\n  @Input() currentItemsFormatFn: CurrentItemsFormatFn = ({ currentItemsFirst, currentItemsLast, totalItems }) => {\n    return `${currentItemsFirst} – ${currentItemsLast} of ${totalItems}`;\n  };\n\n  private _pageFillRemaining: boolean = false;\n  @Input()\n  get pageFillRemaining(): boolean {\n    return this._pageFillRemaining;\n  }\n  set pageFillRemaining(v: any) {\n    this._pageFillRemaining = coerceBooleanProperty(v);\n  }\n\n  private _paginationDisabled: boolean = false;\n  @Input()\n  get paginationDisabled(): boolean {\n    return this._paginationDisabled;\n  }\n  set paginationDisabled(v: any) {\n    this._paginationDisabled = coerceBooleanProperty(v);\n  }\n\n  private _useFirstLastButtons: boolean = false;\n  @Input()\n  get useFirstLastButtons(): boolean {\n    return this._useFirstLastButtons;\n  }\n  set useFirstLastButtons(v: any) {\n    this._useFirstLastButtons = coerceBooleanProperty(v);\n  }\n\n  private _itemsPerPage: number = 50;\n  @Input()\n  get itemsPerPage(): number {\n    return this._itemsPerPage;\n  }\n  set itemsPerPage(v: any) {\n    this._itemsPerPage = coerceNumberProperty(v);\n  }\n  @Output() itemsPerPageChange = new EventEmitter<number>();\n\n  private _page: number = 1;\n  @Input()\n  get page(): number {\n    return this._page;\n  }\n  set page(v: any) {\n    this._page = coerceNumberProperty(v);\n  }\n  @Output() pageChange = new EventEmitter<number>();\n\n  get isDefinedTotalItems(): boolean {\n    return (this.paginationStrategy == TablePaginationStrategy.Noop && isDefined(this.totalItems)) || this.paginationStrategy != TablePaginationStrategy.Noop;\n  }\n  get canDisplayPagination(): boolean {\n    //prettier-ignore\n    return this.paginated && this.isDefinedTotalItems;\n  }\n\n  //! item storage getters\n  get headerCells(): HeaderCell[][] {\n    return this._itemStorage.headerCells;\n  }\n  get dataRows(): ArdTableRow[] {\n    const items: ArdTableRow[] = this._itemStorage.paginatedItems;\n\n    if (!this.pageFillRemaining) return items;\n    if (!this.isDefinedTotalItems) {\n      throw new Error('<ard-table> requires [totalItems] to be defined.');\n    }\n    if (this.page == 1) return items;\n    for (let i = items.length; i < this.itemsPerPage; i++) {\n      items.push({\n        itemData: null,\n        index: i,\n        data: [],\n        dataColumns: [],\n        isEmpty: true,\n      });\n    }\n    return items;\n  }\n\n  //! columns/data setters\n  @Input()\n  set columns(v: (TableDataColumn | TableSubheader)[]) {\n    this._itemStorage.setColumns(v);\n  }\n  private _data: any[] = [];\n  @Input()\n  set data(v: any[]) {\n    this._data = v;\n    this._itemStorage.setItems(v);\n  }\n  get data(): any[] {\n    return this._data;\n  }\n\n  private _treatDataSourceAsString: boolean = false;\n  @Input()\n  get treatDataSourceAsString(): boolean {\n    return this._treatDataSourceAsString;\n  }\n  set treatDataSourceAsString(v: any) {\n    this._treatDataSourceAsString = coerceBooleanProperty(v);\n  }\n\n  //! templates\n  @ContentChild(ArdiumTableCheckboxTemplateDirective, { read: TemplateRef })\n  checkboxTemplate?: TemplateRef<TableCheckboxContext>;\n  @ContentChild(ArdiumTableHeaderCheckboxTemplateDirective, {\n    read: TemplateRef,\n  })\n  headerCheckboxTemplate?: TemplateRef<TableHeaderCheckboxContext>;\n  @ContentChild(ArdiumTableCaptionTemplateDirective, { read: TemplateRef })\n  captionTemplate?: TemplateRef<TableCaptionContext>;\n\n  private _itemTemplates: { [key: string]: TemplateRef<any> } = {};\n  @ContentChildren(ArdiumTableTemplateDirective)\n  templateChildren!: QueryList<ArdiumTableTemplateDirective>;\n\n  ngAfterContentInit(): void {\n    const templates = Array.from(this.templateChildren);\n    for (const instance of templates) {\n      if (!instance.name) {\n        console.error(new Error('[ard-table-tmp] requires a value to be specified.'));\n        continue;\n      }\n      this._itemTemplates[instance.name] = instance.template;\n    }\n  }\n\n  getHeaderTemplate(tmp: string | { template: string | TemplateRef<any> }): TemplateRef<any> | undefined {\n    if (typeof tmp == 'string') return undefined;\n    return this.getCellTemplate(tmp.template);\n  }\n  getHeaderCheckboxColor(): SimpleComponentColor {\n    if (this.appearance == TableAppearance.Strong) return SimpleComponentColor.CurrentColor;\n    return this.color;\n  }\n  getCellTemplate(tmp?: string | TemplateRef<any>): TemplateRef<any> | undefined {\n    //return undefined\n    if (!tmp) return undefined;\n    //return template, if it is one\n    if (tmp instanceof TemplateRef) return tmp;\n    //check if the name can be found\n    if (!(tmp in this._itemTemplates)) {\n      console.error(new Error(`<ard-table> error: cannot find template named \"${tmp}\"`));\n      return undefined;\n    }\n    //return the template\n    return this._itemTemplates[tmp];\n  }\n  getCellStyle(cell: TableDataColumn | TableSubheader): string {\n    if (isTableSubheader(cell)) return 'width:unset;min-width:unset';\n    const width = typeof cell.width == 'number' ? `${cell.width}px` : cell.width;\n    const minWidth = typeof cell.minWidth == 'number' ? `${cell.minWidth}px` : cell.minWidth;\n    return [`width:${width ?? 'unset'}`, `min-width:${minWidth ?? 'unset'}`].join(';');\n  }\n\n  //! click & hover handlers\n  onCheckboxClick(index: number): void {\n    this.toggleRowSelected(index);\n  }\n  onRowClick(index: number, event: MouseEvent): void {\n    if (!this.selectableRows) return;\n    event.stopPropagation();\n    this.toggleRowSelected(index);\n  }\n  onRowMouseOver(event: MouseEvent): void {\n    event.stopPropagation();\n  }\n  onRowMouseEnter(index: number, event: MouseEvent): void {\n    if (!this.selectableRows) return;\n    event.stopPropagation();\n    this._itemStorage.highlightSingleItem(index);\n  }\n  onRowMouseLeave(index: number, event: MouseEvent): void {\n    if (!this.selectableRows) return;\n    event.stopPropagation();\n    this._itemStorage.unhighlightItem(index);\n  }\n\n  //! select handlers\n  /**\n   * Toggles the selection state of a row in the table.\n   * @param selected a boolean value indicating if the row is currently selected.\n   * @param index the index of the row in the table.\n   */\n  toggleRowSelected(index: number): void {\n    if (this._itemStorage.isItemSelected(index)) {\n      const unselected = this._itemStorage.unselectItem(index);\n      this.unselectRowEvent.emit(unselected);\n    } else {\n      const [selected, failed] = this._itemStorage.selectItem(index);\n      this.selectRowEvent.emit(selected);\n      this.failedSelectRowEvent.emit(failed);\n    }\n    this._emitSelect();\n  }\n  /**\n   * Toggles the selection state of all rows in the table.\n   */\n  toggleAllRowsSelected(): void {\n    if (this._itemStorage.areAllSelected) {\n      const unselected = this._itemStorage.unselectAll();\n      this.unselectRowEvent.emit(unselected);\n    } else {\n      const [selected, failed] = this._itemStorage.selectAll();\n      this.selectRowEvent.emit(selected);\n      this.failedSelectRowEvent.emit(failed);\n    }\n    this._emitSelect();\n  }\n  private _emitSelect(): void {\n    const v = this._itemStorage.value;\n    this.selectedRowsChangeEvent.emit(v);\n  }\n  isCellCheckbox(cell: any): boolean {\n    return typeof cell == 'object' && '_ardCheckbox' in cell && 'index' in cell;\n  }\n  isHeaderCellCheckbox(cell: HeaderCell): boolean {\n    const dataCell = cell.cell;\n    if (isTableSubheader(dataCell)) return false;\n    if (typeof dataCell.dataSource == 'string') return false;\n    return dataCell.dataSource.type == 'checkbox';\n  }\n  isHeaderCellSortable(cell: HeaderCell): boolean {\n    const dataCell = cell.cell;\n    if (isTableSubheader(dataCell)) return false;\n    return dataCell.sortable ?? false;\n  }\n\n  @Output('selectedRowsChange') selectedRowsChangeEvent = new EventEmitter<any[]>();\n  @Output('failedSelectRow') failedSelectRowEvent = new EventEmitter<any[]>();\n  @Output('selectRow') selectRowEvent = new EventEmitter<any[]>();\n  @Output('unselectRow') unselectRowEvent = new EventEmitter<any[]>();\n\n  //! contexts\n  getHeaderContext(cell: TableDataColumn, index: number): TableHeaderContext | null;\n  getHeaderContext(cell: TableSubheader, index: number): TableSubheaderContext | null;\n  getHeaderContext(cell: TableDataColumn | TableSubheader, index: number): TableHeaderContext | TableSubheaderContext | null;\n  getHeaderContext(cell: TableDataColumn | TableSubheader, index: number): TableHeaderContext | TableSubheaderContext | null {\n    if (typeof cell.header != 'string') return null;\n    if (isTableSubheader(cell))\n      return {\n        $implicit: cell.header,\n        header: cell.header,\n      };\n    return {\n      $implicit: cell.header,\n      header: cell.header,\n      sortable: cell.sortable ?? false,\n      sortType: this._itemStorage.getColumnSortType(index),\n      onTriggerSort: (event?: Event) => this._itemStorage.toggleCurrentSortColumn(index),\n      onTriggerResetSort: (event?: Event) => {\n        this._itemStorage.resetSort();\n        event?.preventDefault();\n        event?.stopPropagation();\n      },\n    };\n  }\n  getHeaderCheckboxContext(): TableHeaderCheckboxContext {\n    let state: CheckboxState = CheckboxState.Unselected;\n    if (this._itemStorage.isAnyItemSelected) {\n      state = CheckboxState.Indeterminate;\n      if (this._itemStorage.areAllSelected) {\n        state = CheckboxState.Selected;\n      }\n    }\n    return {\n      $implicit: state,\n      state,\n      onChange: () => {\n        this.toggleAllRowsSelected();\n      },\n    };\n  }\n  getCheckboxContext(index: number): TableCheckboxContext {\n    const item = this._itemStorage.items.find(v => v.index == index)!;\n    const selected = item.selected ?? false;\n    const disabled = item.disabled ?? false;\n    return {\n      $implicit: selected,\n      selected,\n      disabled,\n      onChange: () => {\n        this.onCheckboxClick(index);\n      },\n    };\n  }\n}\n","<table class=\"ard-table\" [ngClass]=\"ngClasses\">\r\n    <caption\r\n        *ngIf=\"caption\"\r\n        class=\"ard-table__caption\"\r\n    >\r\n        <div class=\"ard-table__caption-container\">\r\n            <ng-template #defaultCaptionTemplate let-captionText>\r\n                {{ captionText }}\r\n            </ng-template>\r\n        \r\n            <ng-template\r\n                [ngTemplateOutlet]=\"captionTemplate ?? defaultCaptionTemplate\"\r\n                [ngTemplateOutletContext]=\"{ $implicit: caption }\"\r\n            />\r\n        </div>\r\n    </caption>\r\n    <thead class=\"ard-table__header\">\r\n        <tr class=\"ard-table__header-row\" *ngFor=\"let row of headerCells\">\r\n            <th\r\n                *ngFor=\"let cell of row; let index = index\"\r\n                class=\"ard-table__header-cell\"\r\n                [ngClass]=\"cell.cell.cellClass\"\r\n                [class.ard-table__checkbox-cell]=\"isHeaderCellCheckbox(cell)\"\r\n                [attr.colspan]=\"cell.colspan\"\r\n                [attr.rowspan]=\"cell.rowspan\"\r\n                [scope]=\"cell.colspan > 1 ? 'colgroup' : 'col'\"\r\n            >\r\n                <div\r\n                    class=\"ard-table__cell-container\"\r\n                    [class.ard-table__sortable]=\"isHeaderCellSortable(cell)\"\r\n                    [style.width]=\"cell.width\"\r\n                    [style.minWidth]=\"cell.minWidth\"\r\n                >\r\n                    <ng-container *ngIf=\"isHeaderCellCheckbox(cell)\">\r\n                        <ng-template #defaultHeaderCheckboxTemplate let-state let-onChange=\"onChange\">\r\n                            <ard-checkbox [tabIndex]=\"isLoading ? -1 : tabIndex\" [state]=\"state\" [color]=\"getHeaderCheckboxColor()\" unselectedColor=\"currentColor\" (change)=\"onChange()\" />\r\n                        </ng-template>\r\n                    \r\n                        <ng-template\r\n                            [ngTemplateOutlet]=\"headerCheckboxTemplate ?? defaultHeaderCheckboxTemplate\"\r\n                            [ngTemplateOutletContext]=\"getHeaderCheckboxContext()\"\r\n                        />\r\n                    </ng-container>\r\n                    <ng-container *ngIf=\"!isHeaderCellCheckbox(cell)\">\r\n                        <ng-template\r\n                            #defaultHeaderCellTemplate\r\n                            let-content\r\n                            let-sortable=\"sortable\"\r\n                            let-sortType=\"sortType\"\r\n                            let-onTriggerSort=\"onTriggerSort\"\r\n                            let-onTriggerResetSort=\"onTriggerResetSort\"\r\n                        >\r\n                            <div\r\n                                class=\"ard-table__header-template-container\"\r\n                                [class.ard-sortable]=\"sortable\"\r\n                                [class.ard-nonsortable]=\"!sortable\"\r\n                            >\r\n                                <button\r\n                                    class=\"ard-table__header-content-container\"\r\n                                    *ngIf=\"sortable\"\r\n                                    (click)=\"onTriggerSort($event)\"\r\n                                    [tabindex]=\"tabIndex\"\r\n                                    (keydown.Esc)=\"onTriggerResetSort($event)\"\r\n                                >\r\n                                    <div class=\"ard-table__header-content\">{{ content }}</div>\r\n                                    <div class=\"ard-table__header-sort-icon\" *ngIf=\"sortType != null\">\r\n                                        <ard-icon *ngIf=\"sortType == 'ascending'\">south</ard-icon>\r\n                                        <ard-icon *ngIf=\"sortType == 'descending'\">north</ard-icon>\r\n                                    </div>\r\n                                </button>\r\n                                <div\r\n                                    class=\"ard-table__header-content-container\"\r\n                                    *ngIf=\"!sortable\"\r\n                                >\r\n                                    <div class=\"ard-table__header-content\">{{ content }}</div>\r\n                                </div>\r\n                            </div>\r\n                        </ng-template>\r\n                    \r\n                        <ng-template \r\n                            [ngTemplateOutlet]=\"getHeaderTemplate(cell.cell.header) ?? defaultHeaderCellTemplate\"\r\n                            [ngTemplateOutletContext]=\"getHeaderContext(cell.cell, index)\"\r\n                        />\r\n                    </ng-container>\r\n                </div>\r\n            </th>\r\n        </tr>\r\n    </thead>\r\n    <tbody class=\"ard-table__body\">\r\n        <ng-container *ngFor=\"let row of dataRows; let rowIndex = index;\">\r\n            <tr *ngIf=\"row.isEmpty\" class=\"ard-table__empty-row\">\r\n                <td class=\"ard-table__empty-cell\" colspan=\"9999\"></td>\r\n            </tr>\r\n            <tr\r\n                *ngIf=\"!row.isEmpty\"\r\n                class=\"ard-table__body-row\"\r\n                [class.ard-table__selected-row]=\"row.selected\"\r\n                [class.ard-table__highlighted-row]=\"row.highlighted\"\r\n                [class.ard-table__disabled-row]=\"row.disabled\"\r\n                [class.ard-table__bold-row]=\"row.bold\"\r\n                (click)=\"onRowClick(rowIndex, $event)\"\r\n                (mouseover)=\"onRowMouseOver($event)\"\r\n                (mouseenter)=\"onRowMouseEnter(rowIndex, $event)\"\r\n                (mouseleave)=\"onRowMouseLeave(rowIndex, $event)\"\r\n            >\r\n                <ng-container *ngFor=\"let cell of row.data; let cellIndex = index\">\r\n                    <ng-template #cellTmp>\r\n                        <div\r\n                            class=\"ard-table__cell-container\"\r\n                            [style]=\"getCellStyle(row.dataColumns[cellIndex])\"\r\n                        >\r\n                            <ng-container *ngIf=\"isCellCheckbox(cell)\">\r\n                                <ng-template #defaultCheckboxTemplate let-isChecked let-onChange=\"onChange\" let-disabled=\"disabled\">\r\n                                    <ard-checkbox [tabIndex]=\"isLoading ? -1 : tabIndex\" [selected]=\"isChecked\" [color]=\"color\" [disabled]=\"disabled\" (change)=\"onChange()\" (click)=\"$event.stopPropagation()\" />\r\n                                </ng-template>\r\n\r\n                                <ng-template\r\n                                    [ngTemplateOutlet]=\"checkboxTemplate ?? defaultCheckboxTemplate\"\r\n                                    [ngTemplateOutletContext]=\"getCheckboxContext(rowIndex)\"\r\n                                />\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"!isCellCheckbox(cell)\">\r\n                                <ng-template #defaultCellTemplate let-content>\r\n                                    {{ content }}\r\n                                </ng-template>\r\n\r\n                                <ng-template\r\n                                    [ngTemplateOutlet]=\"getCellTemplate(row.dataColumns[cellIndex].template) ?? defaultCellTemplate\"\r\n                                    [ngTemplateOutletContext]=\"{ $implicit: cell }\"\r\n                                />\r\n                            </ng-container>\r\n                        </div>\r\n                    </ng-template>\r\n                    <td\r\n                        *ngIf=\"!row.dataColumns[cellIndex].isRowHeader\"\r\n                        class=\"ard-table__body-cell\"\r\n                        [ngClass]=\"row.dataColumns[cellIndex].cellClass\"\r\n                        [class.ard-table__checkbox-cell]=\"isCellCheckbox(cell)\"\r\n                    >\r\n                        <ng-template [ngTemplateOutlet]=\"cellTmp\"></ng-template>\r\n                    </td>\r\n                    <th\r\n                        *ngIf=\"row.dataColumns[cellIndex].isRowHeader\"\r\n                        class=\"ard-table__body-cell ard-table__row-header\"\r\n                        scope=\"row\"\r\n                        [ngClass]=\"row.dataColumns[cellIndex].cellClass\"\r\n                        [class.ard-table__checkbox-cell]=\"isCellCheckbox(cell)\"\r\n                    >\r\n                        <ng-template [ngTemplateOutlet]=\"cellTmp\"></ng-template>\r\n                    </th>\r\n                </ng-container>\r\n            </tr>\r\n        </ng-container>\r\n    </tbody>\r\n    <tfoot class=\"ard-table__foot\" *ngIf=\"canDisplayPagination\">\r\n        <tr class=\"ard-table__foot-row\">\r\n            <td class=\"ard-table__pagination-cell\" colspan=\"9999\">\r\n                <ard-table-pagination\r\n                    [options]=\"paginationOptions\"\r\n                    [(page)]=\"page\"\r\n                    [totalItems]=\"totalItems\"\r\n                    [disabled]=\"paginationDisabled\"\r\n                    [(itemsPerPage)]=\"itemsPerPage\"\r\n                    [align]=\"paginationAlign\"\r\n                    [isLoading]=\"isLoading\"\r\n                    [itemsPerPageText]=\"itemsPerPageText\"\r\n                    [currentItemsFormatFn]=\"currentItemsFormatFn\"\r\n                    (itemsPerPageChange)=\"itemsPerPageChange.emit($event)\"\r\n                    (pageChange)=\"pageChange.emit($event)\"\r\n                ></ard-table-pagination>\r\n            </td>\r\n        </tr>\r\n    </tfoot>\r\n</table>"]}
348
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/table/table.component.ts","../../../../../projects/ui/src/lib/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  SimpleChanges,\n  TemplateRef,\n  ViewEncapsulation,\n  computed,\n  contentChild,\n  contentChildren,\n  input,\n  model,\n  output,\n  OnChanges,\n} from '@angular/core';\nimport { coerceBooleanProperty, coerceNumberProperty } from '@ardium-ui/devkit';\nimport { isDefined, isNumber } from 'simple-bool';\nimport { _FocusableComponentBase } from '../_internal/focusable-component';\nimport { CheckboxState } from '../checkbox/checkbox.types';\nimport { CurrentItemsFormatFn, PaginationAlign } from '../table-pagination/table-pagination.types';\nimport { ComponentColor, SimpleComponentColor } from '../types/colors.types';\nimport { Nullable } from '../types/utility.types';\nimport { ArdTableRow, HeaderCell, TableItemStorage, TableItemStorageHost } from './table-item-storage';\nimport {\n  ArdiumTableCaptionTemplateDirective,\n  ArdiumTableCheckboxTemplateDirective,\n  ArdiumTableHeaderCheckboxTemplateDirective,\n  ArdiumTableTemplateDirective,\n} from './table.directives';\nimport {\n  TableAlignType,\n  TableAppearance,\n  TableCaptionContext,\n  TableCheckboxContext,\n  TableDataColumn,\n  TableHeaderCheckboxContext,\n  TableHeaderContext,\n  TablePaginationStrategy,\n  TableSubheader,\n  TableSubheaderContext,\n  TableVariant,\n} from './table.types';\nimport { isTableSubheader } from './utils';\n\n@Component({\n  selector: 'ard-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ArdiumTableComponent extends _FocusableComponentBase implements TableItemStorageHost, AfterContentInit, OnChanges {\n  private readonly _itemStorage = new TableItemStorage(this);\n\n  readonly DEFAULTS = {\n    rowDisabledFrom: 'disabled',\n    rowBoldFrom: 'bold',\n  };\n\n  readonly rowDisabledFrom = input<Nullable<string>>(undefined);\n  readonly rowBoldFrom = input<Nullable<string>>(undefined);\n  readonly invertRowDisabled = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n  readonly invertRowBold = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n\n  readonly selectableRows = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n  readonly maxSelectedItems = input<Nullable<number>, any>(undefined, { transform: v => coerceNumberProperty(v, undefined) });\n\n  readonly clickableRows = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n\n  readonly caption = input<Nullable<string>>(undefined);\n\n  readonly isLoading = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n  readonly loadingProgress = input<number, any>(0, { transform: v => coerceNumberProperty(v, 0) }); //TODO add progress bar\n\n  //! appearance\n  readonly appearance = input<TableAppearance>(TableAppearance.Strong);\n  readonly variant = input<TableVariant>(TableVariant.Rounded);\n  readonly color = input<ComponentColor>(ComponentColor.Primary);\n  readonly align = input<TableAlignType>(TableAlignType.CenterLeft);\n  readonly headerAlign = input<TableAlignType>(TableAlignType.CenterLeft);\n\n  readonly compact = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n  readonly zebra = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n  readonly stickyHeader = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n\n  readonly ngClasses = computed(() =>\n    [\n      `ard-appearance-${this.appearance()}`,\n      `ard-variant-${this.variant()}`,\n      `ard-color-${this.color()}`,\n      `ard-align-${this.align()}`,\n      `ard-header-align-${this.headerAlign()}`,\n      this.compact() ? 'ard-compact' : '',\n      this.zebra() ? 'ard-zebra-table' : '',\n      this.selectableRows() ? 'ard-selectable-rows' : '',\n      this.stickyHeader() ? 'ard-sticky-header' : '',\n      this.isLoading() ? 'ard-table-loading' : '',\n    ].join(' ')\n  );\n\n  //! pagination\n  readonly paginated = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n  readonly paginationStrategy = input<TablePaginationStrategy>(TablePaginationStrategy.Noop);\n  readonly paginationOptions = input<\n    number[] | { value: number; label: string }[],\n    number[] | { value: number; label: string }[]\n  >([10, 25, 50], {\n    transform: v => {\n      return v.filter(el => {\n        const opt = isNumber(el) ? el : el.value;\n        if (opt <= 0 || opt % 1 !== 0) {\n          console.error(\n            new Error(\n              `ARD-NF5052: each item of <ard-table>'s [paginationOptions] must be a positive integer. The \"${opt}\" option will be ignored.`\n            )\n          );\n          return false;\n        }\n        return true;\n      }) as number[] | { value: number; label: string }[];\n    },\n  });\n  readonly totalItems = input<Nullable<number>, any>(undefined, { transform: v => coerceNumberProperty(v, undefined) });\n  readonly paginationColor = input<ComponentColor>(ComponentColor.None);\n  readonly paginationAlign = input<PaginationAlign>(PaginationAlign.Split);\n  readonly itemsPerPageText = input<string>('Items per page:');\n  readonly currentItemsFormatFn = input<CurrentItemsFormatFn>(\n    ({ currentItemsFirst, currentItemsLast, totalItems }) => `${currentItemsFirst} – ${currentItemsLast} of ${totalItems}`\n  );\n\n  readonly pageFillRemaining = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n  readonly paginationDisabled = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n  readonly useFirstLastButtons = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n\n  readonly itemsPerPage = model<number>(50);\n  readonly page = model<number>(1);\n\n  readonly isDefinedTotalItems = computed(\n    () => this.paginationStrategy() !== TablePaginationStrategy.Noop || isDefined(this.totalItems())\n  );\n  readonly canDisplayPagination = computed(() => this.paginated() && this.isDefinedTotalItems());\n\n  //! print errors if needed\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['itemsPerPage']) {\n      const ipp = changes['itemsPerPage'].currentValue;\n      const options =\n        (changes['paginationOptions']?.currentValue as number[] | { value: number; label: string }[]) ||\n        (this.paginationOptions() as number[] | { value: number; label: string }[]);\n      if (!options.find(v => (typeof v === 'number' ? v === ipp : v.value === ipp))) {\n        console.error(\n          new Error(\n            `ARD-NF5051: value of \"${ipp}\" in <ard-table>'s [itemsPerPage] does not appear in [paginationOptions] array [${options\n              .map(v => (typeof v === 'number' ? v : v.value))\n              .join(', ')}]`\n          )\n        );\n      }\n    }\n    if (changes['page']) {\n      const page = changes['page'].currentValue as number;\n      if (page === 0) {\n        throw new Error(`ARD-FT5053a: <ard-table>'s [page] uses 1-indexed numbering system. The value 0 is not accepted.`);\n      } else if (page < 0 || page % 1 !== 0) {\n        throw new Error(`ARD-FT5053b: value of <ard-table>'s [page] must be a positive integer, got \"${page}\".`);\n      }\n    }\n  }\n\n  //! item storage getters\n  readonly headerCells = computed(() => this._itemStorage.headerCells());\n\n  readonly dataRows = computed(() => {\n    const items: ArdTableRow[] = this._itemStorage.paginatedItems();\n\n    if (!this.pageFillRemaining()) return items;\n    if (!this.isDefinedTotalItems()) {\n      throw new Error('ARD-FT5050: <ard-table> requires [totalItems] to be defined when using \"slice\" pagination strategy.');\n    }\n    if (this.page() === 1) return items;\n\n    const ipp = this.itemsPerPage();\n    for (let i = items.length; i < ipp; i++) {\n      items.push(ArdTableRow.newEmptyCell(i));\n    }\n    return items;\n  });\n\n  //! columns/data setters\n  @Input()\n  set columns(v: (TableDataColumn | TableSubheader)[]) {\n    this._itemStorage.setColumns(v);\n  }\n  private _data: any[] = [];\n  @Input()\n  set data(v: any[]) {\n    this._data = v;\n    this._itemStorage.setItems(v);\n  }\n  get data(): any[] {\n    return this._data;\n  }\n\n  readonly treatDataSourceAsString = input<boolean, any>(false, { transform: v => coerceBooleanProperty(v) });\n  readonly _suppressErrors = input<boolean>(false);\n\n  //! templates\n  readonly checkboxTemplate = contentChild<ArdiumTableCheckboxTemplateDirective, TemplateRef<TableCheckboxContext>>(\n    ArdiumTableCheckboxTemplateDirective,\n    {\n      read: TemplateRef<TableCheckboxContext>,\n    }\n  );\n  readonly headerCheckboxTemplate = contentChild<\n    ArdiumTableHeaderCheckboxTemplateDirective,\n    TemplateRef<TableHeaderCheckboxContext>\n  >(ArdiumTableHeaderCheckboxTemplateDirective, {\n    read: TemplateRef<TableHeaderCheckboxContext>,\n  });\n  readonly captionTemplate = contentChild<ArdiumTableCaptionTemplateDirective, TemplateRef<TableCaptionContext>>(\n    ArdiumTableCaptionTemplateDirective,\n    {\n      read: TemplateRef<TableCaptionContext>,\n    }\n  );\n\n  private _itemTemplates: Record<string, TemplateRef<any>> = {};\n  readonly templateChildren = contentChildren<ArdiumTableTemplateDirective>(ArdiumTableTemplateDirective);\n\n  ngAfterContentInit(): void {\n    const templates = Array.from(this.templateChildren());\n    for (const instance of templates) {\n      const name = instance.name();\n      if (!name) {\n        console.error(new Error('ARD-FT5054: [ard-table-tmp] requires a value to be specified.'));\n        continue;\n      }\n      this._itemTemplates[name] = instance.template;\n    }\n  }\n\n  getHeaderTemplate(tmp: string | { template: string | TemplateRef<any> }): TemplateRef<any> | undefined {\n    if (typeof tmp === 'string') return undefined;\n    return this.getCellTemplate(tmp.template);\n  }\n  getHeaderCheckboxColor(): SimpleComponentColor {\n    if (this.appearance() === TableAppearance.Strong) return SimpleComponentColor.CurrentColor;\n    return this.color();\n  }\n  getCellTemplate(tmp?: string | TemplateRef<any>): TemplateRef<any> | undefined {\n    //return undefined\n    if (!tmp) return undefined;\n    //return template, if it is one\n    if (tmp instanceof TemplateRef) return tmp;\n    //check if the name can be found\n    if (!(tmp in this._itemTemplates)) {\n      console.error(new Error(`ARD-NF5055: <ard-table> error: cannot find template named \"${tmp}\"`));\n      return undefined;\n    }\n    //return the template\n    return this._itemTemplates[tmp];\n  }\n  getCellStyle(cell: TableDataColumn | TableSubheader): string {\n    if (isTableSubheader(cell)) return 'width:unset;min-width:unset';\n    const width = typeof cell.width === 'number' ? `${cell.width}px` : cell.width;\n    const minWidth = typeof cell.minWidth === 'number' ? `${cell.minWidth}px` : cell.minWidth;\n    return [`width:${width ?? 'unset'}`, `min-width:${minWidth ?? 'unset'}`].join(';');\n  }\n\n  //! click & hover handlers\n  onCheckboxClick(index: number): void {\n    this.toggleRowSelected(index);\n  }\n  onRowClick(row: ArdTableRow, event: MouseEvent): void {\n    if (this.clickableRows()) {\n      event.stopPropagation();\n      this.clickRowEvent.emit(row.itemData());\n      return;\n    }\n    if (this.selectableRows()) {\n      event.stopPropagation();\n      this.toggleRowSelected(row.index());\n      return;\n    }\n  }\n  onRowMouseOver(event: MouseEvent): void {\n    event.stopPropagation();\n  }\n  onRowMouseEnter(index: number, event: MouseEvent): void {\n    if (!this.selectableRows() && !this.clickableRows()) return;\n    event.stopPropagation();\n    this._itemStorage.highlightSingleItem(index);\n  }\n  onRowMouseLeave(index: number, event: MouseEvent): void {\n    if (!this.selectableRows() && !this.clickableRows()) return;\n    event.stopPropagation();\n    this._itemStorage.unhighlightItem(index);\n  }\n\n  //! select handlers\n  /**\n   * Toggles the selection state of a row in the table.\n   * @param selected a boolean value indicating if the row is currently selected.\n   * @param index the index of the row in the table.\n   */\n  toggleRowSelected(index: number): void {\n    if (this._itemStorage.isItemSelected(index)) {\n      const unselected = this._itemStorage.unselectItem(index);\n      if (unselected.length) this.unselectRowEvent.emit(unselected);\n    } else {\n      const [selected, failed] = this._itemStorage.selectItem(index);\n      if (selected.length) this.selectRowEvent.emit(selected);\n      if (failed.length) this.failedSelectRowEvent.emit(failed);\n    }\n    this._emitSelect();\n  }\n  /**\n   * Toggles the selection state of all rows in the table.\n   */\n  toggleAllRowsSelected(): void {\n    if (this._itemStorage.areAllSelected()) {\n      const unselected = this._itemStorage.unselectAll();\n      if (unselected.length) this.unselectRowEvent.emit(unselected);\n    } else {\n      const [selected, failed] = this._itemStorage.selectAll();\n      if (selected.length) this.selectRowEvent.emit(selected);\n      if (failed.length) this.failedSelectRowEvent.emit(failed);\n    }\n    this._emitSelect();\n  }\n  private _emitSelect(): void {\n    const v = this._itemStorage.value();\n    this.selectedRowsChangeEvent.emit(v);\n  }\n  isCellCheckbox(cell: any): boolean {\n    return typeof cell === 'object' && '_ardCheckbox' in cell && 'index' in cell;\n  }\n  isHeaderCellCheckbox(cell: HeaderCell): boolean {\n    const dataCell = cell.cell();\n    if (isTableSubheader(dataCell)) return false;\n    if (typeof dataCell.dataSource === 'string') return false;\n    return dataCell.dataSource.type === 'checkbox';\n  }\n  isHeaderCellSortable(cell: HeaderCell): boolean {\n    const dataCell = cell.cell();\n    if (isTableSubheader(dataCell)) return false;\n    return dataCell.sortable ?? false;\n  }\n\n  readonly selectedRowsChangeEvent = output<any[]>({ alias: 'selectedRowsChange' });\n  readonly failedSelectRowEvent = output<any[]>({ alias: 'failedSelectRow' });\n  readonly selectRowEvent = output<any[]>({ alias: 'selectRow' });\n  readonly unselectRowEvent = output<any[]>({ alias: 'unselectRow' });\n  readonly clickRowEvent = output<any>({ alias: 'clickRow' });\n\n  //! contexts\n  getHeaderContext(cell: TableDataColumn, index: number): TableHeaderContext | null;\n  getHeaderContext(cell: TableSubheader, index: number): TableSubheaderContext | null;\n  getHeaderContext(cell: TableDataColumn | TableSubheader, index: number): TableHeaderContext | TableSubheaderContext | null;\n  getHeaderContext(cell: TableDataColumn | TableSubheader, index: number): TableHeaderContext | TableSubheaderContext | null {\n    if (typeof cell.header !== 'string') return null;\n    if (isTableSubheader(cell))\n      return {\n        $implicit: cell.header,\n        header: cell.header,\n      };\n    return {\n      $implicit: cell.header,\n      header: cell.header,\n      sortable: cell.sortable ?? false,\n      sortType: this._itemStorage.getColumnSortType(index),\n      onTriggerSort: () => this._itemStorage.toggleCurrentSortColumn(index),\n      onTriggerResetSort: (event?: Event) => {\n        this._itemStorage.resetSort();\n        event?.preventDefault();\n        event?.stopPropagation();\n      },\n    };\n  }\n  readonly getHeaderCheckboxContext = computed<TableHeaderCheckboxContext>(() => {\n    let state: CheckboxState = CheckboxState.Unselected;\n    if (this._itemStorage.isAnyItemSelected()) {\n      state = CheckboxState.Indeterminate;\n      if (this._itemStorage.areAllSelected()) {\n        state = CheckboxState.Selected;\n      }\n    }\n    return {\n      $implicit: state,\n      state,\n      onChange: () => {\n        this.toggleAllRowsSelected();\n      },\n    };\n  });\n  getCheckboxContext(index: number): TableCheckboxContext {\n    const item = this._itemStorage.items().find(v => v.index() === index)!;\n    const selected = item.selected();\n    return {\n      $implicit: selected,\n      selected: selected,\n      disabled: item.disabled(),\n      onChange: () => {\n        this.onCheckboxClick(index);\n      },\n    };\n  }\n}\n","<table\n  class=\"ard-table\"\n  [ngClass]=\"ngClasses()\"\n>\n  @if (caption()) {\n    <caption class=\"ard-table__caption\">\n      <div class=\"ard-table__caption-container\">\n        <ng-template\n          #defaultCaptionTemplate\n          let-captionText\n        >\n          {{ captionText }}\n        </ng-template>\n\n        <ng-template\n          [ngTemplateOutlet]=\"captionTemplate() ?? defaultCaptionTemplate\"\n          [ngTemplateOutletContext]=\"{ $implicit: caption() }\"\n        />\n      </div>\n    </caption>\n  }\n  <thead class=\"ard-table__header\">\n    @for (row of headerCells(); track $index) {\n      <tr class=\"ard-table__header-row\">\n        @for (cell of row; track $index) {\n          <th\n            class=\"ard-table__header-cell\"\n            [ngClass]=\"cell.cell().cellClass\"\n            [class.ard-table__checkbox-cell]=\"isHeaderCellCheckbox(cell)\"\n            [attr.colspan]=\"cell.colspan()\"\n            [attr.rowspan]=\"cell.rowspan()\"\n            [scope]=\"cell.colspan() > 1 ? 'colgroup' : 'col'\"\n          >\n            <div\n              class=\"ard-table__cell-container\"\n              [class.ard-table__sortable]=\"isHeaderCellSortable(cell)\"\n              [style.width]=\"cell.width\"\n              [style.minWidth]=\"cell.minWidth\"\n            >\n              @if (isHeaderCellCheckbox(cell)) {\n                <ng-template\n                  #defaultHeaderCheckboxTemplate\n                  let-state\n                  let-onChange=\"onChange\"\n                >\n                  <ard-checkbox\n                    [tabIndex]=\"isLoading() ? -1 : tabIndex()\"\n                    [state]=\"state\"\n                    [color]=\"getHeaderCheckboxColor()\"\n                    unselectedColor=\"currentColor\"\n                    (change)=\"onChange()\"\n                  />\n                </ng-template>\n\n                <ng-template\n                  [ngTemplateOutlet]=\"headerCheckboxTemplate() ?? defaultHeaderCheckboxTemplate\"\n                  [ngTemplateOutletContext]=\"getHeaderCheckboxContext()\"\n                />\n              } @else {\n                <ng-template\n                  #defaultHeaderCellTemplate\n                  let-content\n                  let-sortable=\"sortable\"\n                  let-sortType=\"sortType\"\n                  let-onTriggerSort=\"onTriggerSort\"\n                  let-onTriggerResetSort=\"onTriggerResetSort\"\n                >\n                  <div\n                    class=\"ard-table__header-template-container\"\n                    [class.ard-sortable]=\"sortable\"\n                    [class.ard-nonsortable]=\"!sortable\"\n                  >\n                    @if (sortable) {\n                      <button\n                        class=\"ard-table__header-content-container\"\n                        (click)=\"onTriggerSort($event)\"\n                        [tabindex]=\"tabIndex()\"\n                        (keydown.Esc)=\"onTriggerResetSort($event)\"\n                      >\n                        <div class=\"ard-table__header-content\">{{ content }}</div>\n                        @if (sortType !== null) {\n                          <div class=\"ard-table__header-sort-icon\">\n                            @if (sortType === 'ascending') {\n                              <ard-icon>south</ard-icon>\n                            } @else if (sortType === 'descending') {\n                              <ard-icon>north</ard-icon>\n                            }\n                          </div>\n                        }\n                      </button>\n                    } @else {\n                      <div class=\"ard-table__header-content-container\">\n                        <div class=\"ard-table__header-content\">{{ content }}</div>\n                      </div>\n                    }\n                  </div>\n                </ng-template>\n\n                <ng-template\n                  [ngTemplateOutlet]=\"getHeaderTemplate(cell.cell().header) ?? defaultHeaderCellTemplate\"\n                  [ngTemplateOutletContext]=\"getHeaderContext(cell.cell(), $index)\"\n                />\n              }\n            </div>\n          </th>\n        }\n      </tr>\n    }\n  </thead>\n  <tbody class=\"ard-table__body\">\n    @for (row of dataRows(); track $index) {\n      @if (row.isEmpty()) {\n        <tr class=\"ard-table__empty-row\">\n          <td\n            class=\"ard-table__empty-cell\"\n            colspan=\"9999\"\n          ></td>\n        </tr>\n      } @else {\n        <tr\n          class=\"ard-table__body-row\"\n          [class.ard-table__selected-row]=\"row.selected()\"\n          [class.ard-table__highlighted-row]=\"row.highlighted()\"\n          [class.ard-table__disabled-row]=\"row.disabled()\"\n          [class.ard-table__bold-row]=\"row.bold()\"\n          (click)=\"onRowClick(row, $event)\"\n          (mouseover)=\"onRowMouseOver($event)\"\n          (mouseenter)=\"onRowMouseEnter(row.index(), $event)\"\n          (mouseleave)=\"onRowMouseLeave(row.index(), $event)\"\n        >\n          @for (cell of row.data(); track $index) {\n            <ng-template #cellTmp>\n              <div\n                class=\"ard-table__cell-container\"\n                [style]=\"getCellStyle(row.dataColumns()[$index])\"\n              >\n                @if (isCellCheckbox(cell)) {\n                  <ng-template\n                    #defaultCheckboxTemplate\n                    let-isChecked\n                    let-onChange=\"onChange\"\n                    let-disabled=\"disabled\"\n                  >\n                    <ard-checkbox\n                      [tabIndex]=\"isLoading() ? -1 : tabIndex()\"\n                      [selected]=\"isChecked\"\n                      [color]=\"color()\"\n                      [disabled]=\"disabled\"\n                      (change)=\"onChange()\"\n                      (click)=\"$event.stopPropagation()\"\n                    />\n                  </ng-template>\n\n                  <ng-template\n                    [ngTemplateOutlet]=\"checkboxTemplate() ?? defaultCheckboxTemplate\"\n                    [ngTemplateOutletContext]=\"getCheckboxContext(row.index())\"\n                  />\n                } @else {\n                  <ng-template\n                    #defaultCellTemplate\n                    let-content\n                  >\n                    {{ content }}\n                  </ng-template>\n\n                  <ng-template\n                    [ngTemplateOutlet]=\"getCellTemplate(row.dataColumns()[$index].template) ?? defaultCellTemplate\"\n                    [ngTemplateOutletContext]=\"{ $implicit: cell }\"\n                  />\n                }\n              </div>\n            </ng-template>\n            @if (!row.dataColumns()[$index].isRowHeader) {\n              <td\n                class=\"ard-table__body-cell\"\n                [ngClass]=\"row.dataColumns()[$index].cellClass\"\n                [class.ard-table__checkbox-cell]=\"isCellCheckbox(cell)\"\n              >\n                <ng-template [ngTemplateOutlet]=\"cellTmp\"></ng-template>\n              </td>\n            } @else {\n              <th\n                class=\"ard-table__body-cell ard-table__row-header\"\n                scope=\"row\"\n                [ngClass]=\"row.dataColumns()[$index].cellClass\"\n                [class.ard-table__checkbox-cell]=\"isCellCheckbox(cell)\"\n              >\n                <ng-template [ngTemplateOutlet]=\"cellTmp\"></ng-template>\n              </th>\n            }\n          }\n        </tr>\n      }\n    }\n  </tbody>\n  @if (canDisplayPagination()) {\n    <tfoot class=\"ard-table__foot\">\n      <tr class=\"ard-table__foot-row\">\n        <td\n          class=\"ard-table__pagination-cell\"\n          colspan=\"9999\"\n        >\n          <ard-table-pagination\n            [options]=\"paginationOptions()\"\n            [totalItems]=\"totalItems()!\"\n            [disabled]=\"paginationDisabled()\"\n            [(itemsPerPage)]=\"itemsPerPage\"\n            [(page)]=\"page\"\n            [align]=\"paginationAlign()\"\n            [isLoading]=\"isLoading()\"\n            [itemsPerPageText]=\"itemsPerPageText()\"\n            [currentItemsFormatFn]=\"currentItemsFormatFn()\"\n          />\n        </td>\n      </tr>\n    </tfoot>\n  }\n</table>\n"]}