@ardium-ui/ui 1.0.3 → 2.0.2

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 (445) hide show
  1. package/README.md +25 -25
  2. package/esm2022/lib/_internal/boolean-component.mjs +28 -42
  3. package/esm2022/lib/_internal/clear-button/clear-button.component.mjs +5 -5
  4. package/esm2022/lib/_internal/clear-button/clear-button.module.mjs +5 -5
  5. package/esm2022/lib/_internal/disablable-component.mjs +24 -22
  6. package/esm2022/lib/_internal/focusable-component.mjs +12 -25
  7. package/esm2022/lib/_internal/item-storages/dropdown-item-storage.mjs +172 -169
  8. package/esm2022/lib/_internal/item-storages/simple-item-storage.mjs +115 -120
  9. package/esm2022/lib/_internal/item-storages/simplest-item-storage.mjs +56 -53
  10. package/esm2022/lib/_internal/models/pagination.model.mjs +72 -106
  11. package/esm2022/lib/_internal/ngmodel-component.mjs +5 -5
  12. package/esm2022/lib/_internal/queue.mjs +1 -1
  13. package/esm2022/lib/_internal/selectable-list-component.mjs +74 -98
  14. package/esm2022/lib/badge/badge.directive.mjs +70 -99
  15. package/esm2022/lib/badge/badge.module.mjs +5 -5
  16. package/esm2022/lib/badge/badge.types.mjs +1 -1
  17. package/esm2022/lib/badge/index.mjs +4 -0
  18. package/esm2022/lib/buttons/_button-base.mjs +13 -35
  19. package/esm2022/lib/buttons/button/button.component.mjs +22 -37
  20. package/esm2022/lib/buttons/button/button.module.mjs +5 -5
  21. package/esm2022/lib/buttons/button/index.mjs +3 -0
  22. package/esm2022/lib/buttons/fab/fab.component.mjs +16 -28
  23. package/esm2022/lib/buttons/fab/fab.module.mjs +5 -5
  24. package/esm2022/lib/buttons/fab/index.mjs +3 -0
  25. package/esm2022/lib/buttons/general-button.types.mjs +1 -1
  26. package/esm2022/lib/buttons/icon-button/icon-button.component.mjs +17 -25
  27. package/esm2022/lib/buttons/icon-button/icon-button.module.mjs +5 -5
  28. package/esm2022/lib/buttons/icon-button/index.mjs +3 -0
  29. package/esm2022/lib/card/card.children.mjs +32 -33
  30. package/esm2022/lib/card/card.component.mjs +14 -17
  31. package/esm2022/lib/card/card.module.mjs +5 -5
  32. package/esm2022/lib/card/card.types.mjs +1 -1
  33. package/esm2022/lib/card/index.mjs +5 -0
  34. package/esm2022/lib/checkbox/checkbox.component.mjs +33 -46
  35. package/esm2022/lib/checkbox/checkbox.module.mjs +5 -5
  36. package/esm2022/lib/checkbox/checkbox.types.mjs +1 -1
  37. package/esm2022/lib/checkbox/index.mjs +4 -0
  38. package/esm2022/lib/checkbox-list/checkbox-list.component.mjs +31 -57
  39. package/esm2022/lib/checkbox-list/checkbox-list.module.mjs +5 -5
  40. package/esm2022/lib/checkbox-list/checkbox-list.types.mjs +1 -1
  41. package/esm2022/lib/checkbox-list/index.mjs +4 -0
  42. package/esm2022/lib/chip/chip.component.mjs +22 -42
  43. package/esm2022/lib/chip/chip.module.mjs +5 -5
  44. package/esm2022/lib/chip/deletable-chip/deletable-chip.component.mjs +28 -53
  45. package/esm2022/lib/chip/index.mjs +5 -0
  46. package/esm2022/lib/chip/selectable-chip/selectable-chip.component.mjs +25 -49
  47. package/esm2022/lib/color/color-display/color-display.component.mjs +15 -32
  48. package/esm2022/lib/color/color-display/color-display.module.mjs +5 -5
  49. package/esm2022/lib/color/color-display/color-display.types.mjs +1 -1
  50. package/esm2022/lib/color/color-display/index.mjs +4 -0
  51. package/esm2022/lib/color/color-picker/color-picker.types.mjs +1 -1
  52. package/esm2022/lib/dialog/dialog.component.mjs +54 -130
  53. package/esm2022/lib/dialog/dialog.directives.mjs +4 -4
  54. package/esm2022/lib/dialog/dialog.module.mjs +5 -5
  55. package/esm2022/lib/dialog/dialog.types.mjs +1 -1
  56. package/esm2022/lib/dialog/index.mjs +5 -0
  57. package/esm2022/lib/divider/divider.component.mjs +9 -14
  58. package/esm2022/lib/divider/divider.module.mjs +5 -5
  59. package/esm2022/lib/divider/index.mjs +3 -0
  60. package/esm2022/lib/dropdown-panel/dropdown-panel.component.mjs +40 -59
  61. package/esm2022/lib/dropdown-panel/dropdown-panel.module.mjs +5 -5
  62. package/esm2022/lib/dropdown-panel/dropdown-panel.types.mjs +1 -1
  63. package/esm2022/lib/dropdown-panel/index.mjs +4 -0
  64. package/esm2022/lib/file-inputs/file-drop-area/file-drop-area.component.mjs +12 -17
  65. package/esm2022/lib/file-inputs/file-drop-area/file-drop-area.directives.mjs +10 -10
  66. package/esm2022/lib/file-inputs/file-drop-area/file-drop-area.module.mjs +6 -6
  67. package/esm2022/lib/file-inputs/file-drop-area/index.mjs +4 -0
  68. package/esm2022/lib/file-inputs/file-input/file-input.component.mjs +24 -50
  69. package/esm2022/lib/file-inputs/file-input/file-input.directives.mjs +19 -19
  70. package/esm2022/lib/file-inputs/file-input/file-input.module.mjs +5 -5
  71. package/esm2022/lib/file-inputs/file-input/index.mjs +4 -0
  72. package/esm2022/lib/file-inputs/file-input-base.mjs +38 -72
  73. package/esm2022/lib/file-inputs/file-input-types.mjs +1 -1
  74. package/esm2022/lib/form-field-frame/form-field-frame.component.mjs +20 -47
  75. package/esm2022/lib/form-field-frame/form-field-frame.directives.mjs +7 -7
  76. package/esm2022/lib/form-field-frame/form-field-frame.module.mjs +5 -5
  77. package/esm2022/lib/form-field-frame/index.mjs +4 -0
  78. package/esm2022/lib/icon/icon.component.mjs +32 -67
  79. package/esm2022/lib/icon/icon.module.mjs +5 -5
  80. package/esm2022/lib/icon/icon.pipe.mjs +4 -4
  81. package/esm2022/lib/icon/index.mjs +4 -0
  82. package/esm2022/lib/inputs/color-input/color-input.directives.mjs +25 -25
  83. package/esm2022/lib/inputs/color-input/color-input.types.mjs +1 -1
  84. package/esm2022/lib/inputs/digit-input/digit-input.component.mjs +65 -115
  85. package/esm2022/lib/inputs/digit-input/digit-input.model.mjs +83 -92
  86. package/esm2022/lib/inputs/digit-input/digit-input.module.mjs +5 -5
  87. package/esm2022/lib/inputs/digit-input/digit-input.types.mjs +1 -1
  88. package/esm2022/lib/inputs/digit-input/digit-input.utils.mjs +1 -1
  89. package/esm2022/lib/inputs/digit-input/index.mjs +4 -0
  90. package/esm2022/lib/inputs/hex-input/hex-input.component.mjs +59 -122
  91. package/esm2022/lib/inputs/hex-input/hex-input.directives.mjs +10 -10
  92. package/esm2022/lib/inputs/hex-input/hex-input.module.mjs +24 -8
  93. package/esm2022/lib/inputs/hex-input/index.mjs +4 -0
  94. package/esm2022/lib/inputs/hex-input.model.mjs +24 -33
  95. package/esm2022/lib/inputs/input/index.mjs +4 -0
  96. package/esm2022/lib/inputs/input/input.component.mjs +95 -154
  97. package/esm2022/lib/inputs/input/input.directives.mjs +16 -16
  98. package/esm2022/lib/inputs/input/input.module.mjs +21 -7
  99. package/esm2022/lib/inputs/input-transformers.mjs +6 -6
  100. package/esm2022/lib/inputs/input-types.mjs +1 -1
  101. package/esm2022/lib/inputs/input-utils.mjs +75 -94
  102. package/esm2022/lib/inputs/number-input/index.mjs +4 -0
  103. package/esm2022/lib/inputs/number-input/number-input.component.mjs +106 -170
  104. package/esm2022/lib/inputs/number-input/number-input.directives.mjs +4 -4
  105. package/esm2022/lib/inputs/number-input/number-input.module.mjs +5 -5
  106. package/esm2022/lib/inputs/password-input/index.mjs +5 -0
  107. package/esm2022/lib/inputs/password-input/password-input.component.mjs +74 -144
  108. package/esm2022/lib/inputs/password-input/password-input.directives.mjs +13 -13
  109. package/esm2022/lib/inputs/password-input/password-input.module.mjs +5 -5
  110. package/esm2022/lib/inputs/password-input/password-input.types.mjs +1 -1
  111. package/esm2022/lib/inputs/simple-input/index.mjs +4 -0
  112. package/esm2022/lib/inputs/simple-input/simple-input.component.mjs +57 -110
  113. package/esm2022/lib/inputs/simple-input/simple-input.directives.mjs +10 -10
  114. package/esm2022/lib/inputs/simple-input/simple-input.module.mjs +5 -5
  115. package/esm2022/lib/kbd/index.mjs +4 -0
  116. package/esm2022/lib/kbd/kbd.component.mjs +15 -29
  117. package/esm2022/lib/kbd/kbd.module.mjs +5 -5
  118. package/esm2022/lib/kbd/kbd.pipe.mjs +4 -4
  119. package/esm2022/lib/kbd-shortcut/index.mjs +3 -0
  120. package/esm2022/lib/kbd-shortcut/kbd-shortcut.component.mjs +23 -40
  121. package/esm2022/lib/kbd-shortcut/kbd-shortcut.module.mjs +5 -5
  122. package/esm2022/lib/modal/index.mjs +3 -0
  123. package/esm2022/lib/modal/modal.component.mjs +42 -83
  124. package/esm2022/lib/modal/modal.module.mjs +5 -5
  125. package/esm2022/lib/option/index.mjs +3 -0
  126. package/esm2022/lib/option/option.component.mjs +24 -46
  127. package/esm2022/lib/option/option.module.mjs +5 -5
  128. package/esm2022/lib/progress-bar/index.mjs +5 -0
  129. package/esm2022/lib/progress-bar/progress-bar.component.mjs +43 -81
  130. package/esm2022/lib/progress-bar/progress-bar.directive.mjs +4 -4
  131. package/esm2022/lib/progress-bar/progress-bar.module.mjs +5 -5
  132. package/esm2022/lib/progress-bar/progress-bar.types.mjs +1 -1
  133. package/esm2022/lib/progress-circle/index.mjs +5 -0
  134. package/esm2022/lib/progress-circle/progress-circle.component.mjs +33 -78
  135. package/esm2022/lib/progress-circle/progress-circle.directive.mjs +4 -4
  136. package/esm2022/lib/progress-circle/progress-circle.module.mjs +5 -5
  137. package/esm2022/lib/progress-circle/progress-circle.types.mjs +1 -1
  138. package/esm2022/lib/radio/index.mjs +4 -0
  139. package/esm2022/lib/radio/radio/radio.component.mjs +16 -25
  140. package/esm2022/lib/radio/radio-group.component.mjs +71 -85
  141. package/esm2022/lib/radio/radio.module.mjs +5 -5
  142. package/esm2022/lib/search-functions.mjs +7 -7
  143. package/esm2022/lib/segment/index.mjs +5 -0
  144. package/esm2022/lib/segment/segment.component.mjs +70 -137
  145. package/esm2022/lib/segment/segment.directives.mjs +4 -4
  146. package/esm2022/lib/segment/segment.module.mjs +5 -5
  147. package/esm2022/lib/segment/segment.types.mjs +1 -1
  148. package/esm2022/lib/select/index.mjs +5 -0
  149. package/esm2022/lib/select/select.component.mjs +348 -655
  150. package/esm2022/lib/select/select.directive.mjs +46 -46
  151. package/esm2022/lib/select/select.module.mjs +5 -5
  152. package/esm2022/lib/select/select.types.mjs +1 -1
  153. package/esm2022/lib/slide-toggle/index.mjs +4 -0
  154. package/esm2022/lib/slide-toggle/slide-toggle.component.mjs +19 -24
  155. package/esm2022/lib/slide-toggle/slide-toggle.module.mjs +5 -5
  156. package/esm2022/lib/slide-toggle/slide-toggle.types.mjs +5 -0
  157. package/esm2022/lib/slider/abstract-slider.mjs +111 -200
  158. package/esm2022/lib/slider/index.mjs +7 -0
  159. package/esm2022/lib/slider/range-slider/range-slider.component.mjs +26 -23
  160. package/esm2022/lib/slider/range-slider/range-slider.module.mjs +5 -5
  161. package/esm2022/lib/slider/slider.component.mjs +13 -10
  162. package/esm2022/lib/slider/slider.directive.mjs +4 -4
  163. package/esm2022/lib/slider/slider.module.mjs +7 -7
  164. package/esm2022/lib/slider/slider.types.mjs +1 -1
  165. package/esm2022/lib/snackbar/index.mjs +1 -1
  166. package/esm2022/lib/snackbar/snackbar-ref.mjs +1 -1
  167. package/esm2022/lib/snackbar/snackbar.component.mjs +8 -8
  168. package/esm2022/lib/snackbar/snackbar.service.mjs +13 -12
  169. package/esm2022/lib/snackbar/snackbar.token.mjs +1 -1
  170. package/esm2022/lib/snackbar/snackbar.types.mjs +1 -1
  171. package/esm2022/lib/spinner/index.mjs +3 -0
  172. package/esm2022/lib/spinner/spinner.component.mjs +9 -13
  173. package/esm2022/lib/spinner/spinner.module.mjs +5 -5
  174. package/esm2022/lib/star/index.mjs +4 -0
  175. package/esm2022/lib/star/star-button/index.mjs +3 -0
  176. package/esm2022/lib/star/star-button/star-button.component.mjs +17 -26
  177. package/esm2022/lib/star/star-button/star-button.module.mjs +5 -5
  178. package/esm2022/lib/star/star-display/index.mjs +3 -0
  179. package/esm2022/lib/star/star-display/star-display.component.mjs +48 -55
  180. package/esm2022/lib/star/star-display/star-display.module.mjs +5 -5
  181. package/esm2022/lib/star/star-input/index.mjs +3 -0
  182. package/esm2022/lib/star/star-input/star-input.component.mjs +70 -106
  183. package/esm2022/lib/star/star-input/star-input.module.mjs +5 -5
  184. package/esm2022/lib/star/star.component.mjs +12 -20
  185. package/esm2022/lib/star/star.module.mjs +5 -5
  186. package/esm2022/lib/star/star.types.mjs +1 -1
  187. package/esm2022/lib/statebox/index.mjs +3 -0
  188. package/esm2022/lib/statebox/statebox.component.mjs +64 -102
  189. package/esm2022/lib/statebox/statebox.module.mjs +5 -5
  190. package/esm2022/lib/statebox/statebox.types.mjs +1 -1
  191. package/esm2022/lib/tabber/index.mjs +4 -0
  192. package/esm2022/lib/tabber/tab/tab.component.mjs +42 -0
  193. package/esm2022/lib/tabber/tabber.component.mjs +83 -0
  194. package/esm2022/lib/tabber/tabber.module.mjs +19 -0
  195. package/esm2022/lib/table/index.mjs +5 -0
  196. package/esm2022/lib/table/table-item-storage.mjs +204 -200
  197. package/esm2022/lib/table/table.component.mjs +184 -304
  198. package/esm2022/lib/table/table.directives.mjs +19 -21
  199. package/esm2022/lib/table/table.module.mjs +5 -5
  200. package/esm2022/lib/table/table.types.mjs +1 -1
  201. package/esm2022/lib/table/utils.mjs +1 -1
  202. package/esm2022/lib/table-from-csv/index.mjs +3 -0
  203. package/esm2022/lib/table-from-csv/table-from-csv.component.mjs +85 -29
  204. package/esm2022/lib/table-from-csv/table-from-csv.module.mjs +5 -5
  205. package/esm2022/lib/table-pagination/index.mjs +4 -0
  206. package/esm2022/lib/table-pagination/table-pagination.component.mjs +46 -114
  207. package/esm2022/lib/table-pagination/table-pagination.module.mjs +5 -5
  208. package/esm2022/lib/table-pagination/table-pagination.types.mjs +1 -1
  209. package/esm2022/lib/types/alignment.types.mjs +1 -1
  210. package/esm2022/lib/types/colors.types.mjs +1 -1
  211. package/esm2022/lib/types/item-storage.types.mjs +1 -1
  212. package/esm2022/lib/types/theming.types.mjs +1 -1
  213. package/esm2022/lib/types/utility.types.mjs +2 -2
  214. package/esm2022/public-api.mjs +58 -182
  215. package/fesm2022/ardium-ui-ui.mjs +7847 -11692
  216. package/fesm2022/ardium-ui-ui.mjs.map +1 -1
  217. package/lib/_internal/boolean-component.d.ts +8 -9
  218. package/lib/_internal/clear-button/clear-button.component.d.ts +1 -1
  219. package/lib/_internal/disablable-component.d.ts +12 -7
  220. package/lib/_internal/focusable-component.d.ts +5 -7
  221. package/lib/_internal/item-storages/dropdown-item-storage.d.ts +43 -41
  222. package/lib/_internal/item-storages/simple-item-storage.d.ts +28 -25
  223. package/lib/_internal/item-storages/simplest-item-storage.d.ts +14 -9
  224. package/lib/_internal/models/pagination.model.d.ts +38 -42
  225. package/lib/_internal/ngmodel-component.d.ts +1 -1
  226. package/lib/_internal/selectable-list-component.d.ts +30 -30
  227. package/lib/badge/badge.directive.d.ts +15 -20
  228. package/lib/badge/index.d.ts +3 -0
  229. package/lib/buttons/_button-base.d.ts +9 -12
  230. package/lib/buttons/button/button.component.d.ts +6 -8
  231. package/lib/buttons/button/index.d.ts +2 -0
  232. package/lib/buttons/fab/fab.component.d.ts +4 -6
  233. package/lib/buttons/fab/index.d.ts +2 -0
  234. package/lib/buttons/icon-button/icon-button.component.d.ts +6 -7
  235. package/lib/buttons/icon-button/index.d.ts +2 -0
  236. package/lib/card/card.children.d.ts +4 -3
  237. package/lib/card/card.component.d.ts +5 -4
  238. package/lib/card/index.d.ts +4 -0
  239. package/lib/checkbox/checkbox.component.d.ts +8 -12
  240. package/lib/checkbox/index.d.ts +3 -0
  241. package/lib/checkbox-list/checkbox-list.component.d.ts +22 -21
  242. package/lib/checkbox-list/index.d.ts +3 -0
  243. package/lib/chip/chip.component.d.ts +8 -10
  244. package/lib/chip/deletable-chip/deletable-chip.component.d.ts +11 -14
  245. package/lib/chip/index.d.ts +4 -0
  246. package/lib/chip/selectable-chip/selectable-chip.component.d.ts +10 -12
  247. package/lib/color/color-display/color-display.component.d.ts +6 -9
  248. package/lib/color/color-display/index.d.ts +3 -0
  249. package/lib/color/color-picker/color-picker.types.d.ts +4 -4
  250. package/lib/dialog/dialog.component.d.ts +25 -35
  251. package/lib/dialog/dialog.types.d.ts +2 -2
  252. package/lib/dialog/index.d.ts +4 -0
  253. package/lib/divider/divider.component.d.ts +3 -4
  254. package/lib/divider/index.d.ts +2 -0
  255. package/lib/dropdown-panel/dropdown-panel.component.d.ts +17 -20
  256. package/lib/dropdown-panel/index.d.ts +3 -0
  257. package/lib/file-inputs/file-drop-area/file-drop-area.component.d.ts +5 -4
  258. package/lib/file-inputs/file-drop-area/index.d.ts +3 -0
  259. package/lib/file-inputs/file-input/file-input.component.d.ts +13 -17
  260. package/lib/file-inputs/file-input/index.d.ts +3 -0
  261. package/lib/file-inputs/file-input-base.d.ts +13 -18
  262. package/lib/form-field-frame/form-field-frame.component.d.ts +12 -16
  263. package/lib/form-field-frame/index.d.ts +3 -0
  264. package/lib/icon/icon.component.d.ts +10 -19
  265. package/lib/icon/index.d.ts +3 -0
  266. package/lib/inputs/color-input/color-input.types.d.ts +2 -2
  267. package/lib/inputs/digit-input/digit-input.component.d.ts +22 -30
  268. package/lib/inputs/digit-input/digit-input.model.d.ts +8 -12
  269. package/lib/inputs/digit-input/digit-input.types.d.ts +4 -4
  270. package/lib/inputs/digit-input/digit-input.utils.d.ts +4 -5
  271. package/lib/inputs/digit-input/index.d.ts +3 -0
  272. package/lib/inputs/hex-input/hex-input.component.d.ts +32 -38
  273. package/lib/inputs/hex-input/index.d.ts +3 -0
  274. package/lib/inputs/hex-input.model.d.ts +10 -11
  275. package/lib/inputs/input/index.d.ts +3 -0
  276. package/lib/inputs/input/input.component.d.ts +34 -40
  277. package/lib/inputs/input/input.directives.d.ts +3 -3
  278. package/lib/inputs/input-utils.d.ts +24 -27
  279. package/lib/inputs/number-input/index.d.ts +3 -0
  280. package/lib/inputs/number-input/number-input.component.d.ts +38 -48
  281. package/lib/inputs/password-input/index.d.ts +4 -0
  282. package/lib/inputs/password-input/password-input.component.d.ts +28 -40
  283. package/lib/inputs/password-input/password-input.types.d.ts +2 -2
  284. package/lib/inputs/simple-input/index.d.ts +3 -0
  285. package/lib/inputs/simple-input/simple-input.component.d.ts +30 -35
  286. package/lib/kbd/index.d.ts +3 -0
  287. package/lib/kbd/kbd.component.d.ts +6 -8
  288. package/lib/kbd-shortcut/index.d.ts +2 -0
  289. package/lib/kbd-shortcut/kbd-shortcut.component.d.ts +7 -10
  290. package/lib/modal/index.d.ts +2 -0
  291. package/lib/modal/modal.component.d.ts +22 -30
  292. package/lib/option/index.d.ts +2 -0
  293. package/lib/option/option.component.d.ts +11 -16
  294. package/lib/progress-bar/index.d.ts +4 -0
  295. package/lib/progress-bar/progress-bar.component.d.ts +14 -20
  296. package/lib/progress-bar/progress-bar.types.d.ts +2 -2
  297. package/lib/progress-circle/index.d.ts +4 -0
  298. package/lib/progress-circle/progress-circle.component.d.ts +12 -20
  299. package/lib/progress-circle/progress-circle.types.d.ts +2 -2
  300. package/lib/radio/index.d.ts +3 -0
  301. package/lib/radio/radio/radio.component.d.ts +7 -8
  302. package/lib/radio/radio-group.component.d.ts +13 -16
  303. package/lib/segment/index.d.ts +4 -0
  304. package/lib/segment/segment.component.d.ts +22 -34
  305. package/lib/segment/segment.directives.d.ts +2 -3
  306. package/lib/select/index.d.ts +4 -0
  307. package/lib/select/select.component.d.ts +114 -160
  308. package/lib/select/select.directive.d.ts +3 -3
  309. package/lib/select/select.types.d.ts +2 -76
  310. package/lib/slide-toggle/index.d.ts +3 -0
  311. package/lib/slide-toggle/slide-toggle.component.d.ts +9 -7
  312. package/lib/slide-toggle/slide-toggle.types.d.ts +5 -0
  313. package/lib/slider/abstract-slider.d.ts +38 -55
  314. package/lib/slider/index.d.ts +6 -0
  315. package/lib/slider/range-slider/range-slider.component.d.ts +3 -1
  316. package/lib/slider/slider.component.d.ts +2 -0
  317. package/lib/slider/slider.types.d.ts +8 -8
  318. package/lib/snackbar/snackbar-ref.d.ts +1 -2
  319. package/lib/snackbar/snackbar.component.d.ts +3 -3
  320. package/lib/snackbar/snackbar.service.d.ts +2 -2
  321. package/lib/snackbar/snackbar.types.d.ts +4 -4
  322. package/lib/spinner/index.d.ts +2 -0
  323. package/lib/spinner/spinner.component.d.ts +3 -3
  324. package/lib/star/index.d.ts +3 -0
  325. package/lib/star/star-button/index.d.ts +2 -0
  326. package/lib/star/star-button/star-button.component.d.ts +7 -7
  327. package/lib/star/star-display/index.d.ts +2 -0
  328. package/lib/star/star-display/star-display.component.d.ts +8 -12
  329. package/lib/star/star-input/index.d.ts +2 -0
  330. package/lib/star/star-input/star-input.component.d.ts +17 -22
  331. package/lib/star/star.component.d.ts +5 -5
  332. package/lib/statebox/index.d.ts +3 -0
  333. package/lib/statebox/statebox.component.d.ts +15 -21
  334. package/lib/statebox/statebox.types.d.ts +12 -8
  335. package/lib/tabber/index.d.ts +3 -0
  336. package/lib/tabber/tab/tab.component.d.ts +18 -0
  337. package/lib/tabber/tabber.component.d.ts +25 -0
  338. package/lib/tabber/tabber.module.d.ts +9 -0
  339. package/lib/table/index.d.ts +4 -0
  340. package/lib/table/table-item-storage.d.ts +70 -58
  341. package/lib/table/table.component.d.ts +59 -78
  342. package/lib/table/table.directives.d.ts +4 -3
  343. package/lib/table-from-csv/index.d.ts +2 -0
  344. package/lib/table-from-csv/table-from-csv.component.d.ts +46 -9
  345. package/lib/table-pagination/index.d.ts +3 -0
  346. package/lib/table-pagination/table-pagination.component.d.ts +21 -30
  347. package/lib/types/item-storage.types.d.ts +19 -18
  348. package/lib/types/utility.types.d.ts +2 -1
  349. package/package.json +8 -9
  350. package/prebuilt-themes/default/badge.css +5 -5
  351. package/prebuilt-themes/default/buttons/fab.css +4 -3
  352. package/prebuilt-themes/default/buttons/fab.css.map +1 -1
  353. package/prebuilt-themes/default/card.css +7 -7
  354. package/prebuilt-themes/default/chips.css +3 -8
  355. package/prebuilt-themes/default/chips.css.map +1 -1
  356. package/prebuilt-themes/default/core.css +6 -3
  357. package/prebuilt-themes/default/core.css.map +1 -1
  358. package/prebuilt-themes/default/inputs/color-input.css +1 -1
  359. package/prebuilt-themes/default/inputs/digit-input.css +1 -1
  360. package/prebuilt-themes/default/inputs/file-input.css +139 -2
  361. package/prebuilt-themes/default/inputs/file-input.css.map +1 -1
  362. package/prebuilt-themes/default/inputs/hex-input.css +2 -2
  363. package/prebuilt-themes/default/inputs/input.css +1 -1
  364. package/prebuilt-themes/default/inputs/search-bar.css +1 -1
  365. package/prebuilt-themes/default/inputs/simple-input.css +1 -1
  366. package/prebuilt-themes/default/modal.css +1 -1
  367. package/prebuilt-themes/default/segment.css +2 -2
  368. package/prebuilt-themes/default/segment.css.map +1 -1
  369. package/prebuilt-themes/default/select.css +5 -3
  370. package/prebuilt-themes/default/select.css.map +1 -1
  371. package/prebuilt-themes/default/snackbar.css +0 -1
  372. package/prebuilt-themes/default/snackbar.css.map +1 -1
  373. package/prebuilt-themes/default/tabber.css +207 -0
  374. package/prebuilt-themes/default/tabber.css.map +1 -0
  375. package/public-api.d.ts +43 -136
  376. package/themes/_variables.scss +121 -121
  377. package/themes/default/_clear-button.scss +73 -73
  378. package/themes/default/_coloring.scss +137 -137
  379. package/themes/default/_dropdown-arrow.scss +12 -12
  380. package/themes/default/_mixins.scss +70 -70
  381. package/themes/default/badge.scss +94 -94
  382. package/themes/default/buttons/_button-mixins.scss +144 -144
  383. package/themes/default/buttons/button.scss +62 -62
  384. package/themes/default/buttons/fab.scss +74 -72
  385. package/themes/default/buttons/icon-button.scss +59 -59
  386. package/themes/default/calendar.scss +182 -182
  387. package/themes/default/card.scss +126 -126
  388. package/themes/default/checkbox-list.scss +83 -83
  389. package/themes/default/checkbox.scss +109 -109
  390. package/themes/default/chips.scss +200 -206
  391. package/themes/default/color-display.scss +41 -41
  392. package/themes/default/color-picker.scss +111 -111
  393. package/themes/default/core.scss +99 -96
  394. package/themes/default/dialog.scss +16 -16
  395. package/themes/default/divider.scss +13 -13
  396. package/themes/default/dropdown-panel.scss +45 -45
  397. package/themes/default/file-drop-area.scss +162 -162
  398. package/themes/default/form-field-frame.scss +78 -78
  399. package/themes/default/inputs/_shared.scss +46 -46
  400. package/themes/default/inputs/color-input.scss +46 -46
  401. package/themes/default/inputs/digit-input.scss +56 -56
  402. package/themes/default/inputs/file-input.scss +85 -78
  403. package/themes/default/inputs/hex-input.scss +27 -27
  404. package/themes/default/inputs/input.scss +52 -52
  405. package/themes/default/inputs/number-input.scss +121 -121
  406. package/themes/default/inputs/password-input.scss +43 -43
  407. package/themes/default/inputs/search-bar.scss +19 -19
  408. package/themes/default/inputs/simple-input.scss +19 -19
  409. package/themes/default/kbd-shortcut.scss +13 -13
  410. package/themes/default/kbd.scss +20 -20
  411. package/themes/default/modal.scss +93 -93
  412. package/themes/default/progress-bar.scss +166 -166
  413. package/themes/default/progress-circle.scss +56 -56
  414. package/themes/default/radio.scss +112 -112
  415. package/themes/default/segment.scss +340 -339
  416. package/themes/default/select.scss +255 -253
  417. package/themes/default/slide-toggle.scss +151 -151
  418. package/themes/default/slider.scss +224 -224
  419. package/themes/default/snackbar.scss +58 -60
  420. package/themes/default/spinner.scss +21 -21
  421. package/themes/default/stars.scss +122 -122
  422. package/themes/default/statebox.scss +109 -109
  423. package/themes/default/tabber.scss +86 -0
  424. package/themes/default/table-pagination.scss +56 -56
  425. package/themes/default/table.scss +403 -403
  426. package/esm2022/lib/calendar/calendar.component.mjs +0 -979
  427. package/esm2022/lib/calendar/calendar.directives.mjs +0 -107
  428. package/esm2022/lib/calendar/calendar.helpers.mjs +0 -47
  429. package/esm2022/lib/calendar/calendar.module.mjs +0 -21
  430. package/esm2022/lib/calendar/calendar.types.mjs +0 -11
  431. package/esm2022/lib/color/color-picker/color-picker.component.mjs +0 -484
  432. package/esm2022/lib/color/color-picker/color-picker.directives.mjs +0 -55
  433. package/esm2022/lib/color/color-picker/color-picker.module.mjs +0 -43
  434. package/esm2022/lib/inputs/color-input/color-input.component.mjs +0 -421
  435. package/esm2022/lib/inputs/color-input/color-input.module.mjs +0 -85
  436. package/lib/calendar/calendar.component.d.ts +0 -155
  437. package/lib/calendar/calendar.directives.d.ts +0 -51
  438. package/lib/calendar/calendar.helpers.d.ts +0 -15
  439. package/lib/calendar/calendar.module.d.ts +0 -11
  440. package/lib/calendar/calendar.types.d.ts +0 -80
  441. package/lib/color/color-picker/color-picker.component.d.ts +0 -125
  442. package/lib/color/color-picker/color-picker.directives.d.ts +0 -27
  443. package/lib/color/color-picker/color-picker.module.d.ts +0 -13
  444. package/lib/inputs/color-input/color-input.component.d.ts +0 -147
  445. package/lib/inputs/color-input/color-input.module.d.ts +0 -16
@@ -1,138 +1,160 @@
1
+ import { computed, signal } from '@angular/core';
1
2
  import resolvePath from 'resolve-object-path';
2
3
  import { evaluate, isDefined, isNull } from 'simple-bool';
3
4
  import { SortType, TablePaginationStrategy } from './table.types';
4
5
  import { areAllDataColumns, isTableSubheader, merge2dArrays } from './utils';
6
+ export class ArdTableRow {
7
+ constructor(itemData, index, data, dataColumns, disabled, bold, isEmpty = false) {
8
+ this._itemData = signal(undefined);
9
+ this.itemData = this._itemData.asReadonly();
10
+ this._index = signal(-1);
11
+ this.index = this._index.asReadonly();
12
+ this._isEmpty = signal(false);
13
+ this.isEmpty = this._isEmpty.asReadonly();
14
+ this._data = signal([]);
15
+ this.data = this._data.asReadonly();
16
+ this._dataColumns = signal([]);
17
+ this.dataColumns = this._dataColumns.asReadonly();
18
+ this._class = signal('');
19
+ this.class = this._class.asReadonly();
20
+ this.disabled = signal(false);
21
+ this.bold = signal(false);
22
+ this.selected = signal(false);
23
+ this.highlighted = signal(false);
24
+ this._itemData.set(itemData);
25
+ this._index.set(index);
26
+ this._data.set(data);
27
+ this._dataColumns.set(dataColumns);
28
+ this.disabled.set(disabled);
29
+ this.bold.set(bold);
30
+ this._isEmpty.set(isEmpty);
31
+ }
32
+ static newEmptyCell(index) {
33
+ return new ArdTableRow(null, index, [], [], false, false, true);
34
+ }
35
+ }
5
36
  export class HeaderCell {
37
+ constructor(cell, colspan = 1, rowspan = 1) {
38
+ this.cell = signal(undefined);
39
+ this.colspan = signal(1);
40
+ this.rowspan = signal(1);
41
+ this.cell.set(cell);
42
+ this.colspan.set(colspan);
43
+ this.rowspan.set(rowspan);
44
+ }
6
45
  get width() {
7
- if (isTableSubheader(this.cell))
46
+ const cell = this.cell();
47
+ if (isTableSubheader(cell))
8
48
  return null;
9
- return this._getWidth(this.cell.width);
49
+ return this._getWidth(cell.width);
10
50
  }
11
51
  get minWidth() {
12
- if (isTableSubheader(this.cell))
52
+ const cell = this.cell();
53
+ if (isTableSubheader(cell))
13
54
  return null;
14
- return this._getWidth(this.cell.minWidth);
55
+ return this._getWidth(cell.minWidth);
15
56
  }
57
+ /**
58
+ * Thransforms a numeric width into a CSS string if needed. Pure function.
59
+ * @param width the width to be converted.
60
+ * @returns The width expressed as a CSS-compatible string or null.
61
+ */
16
62
  _getWidth(width) {
17
63
  if (!width)
18
64
  return null;
19
- if (typeof width == 'number')
65
+ if (typeof width === 'number')
20
66
  return `${width}px`;
21
67
  return width;
22
68
  }
23
- constructor(cell, colspan = 1, rowspan = 1) {
24
- this.cell = cell;
25
- this.colspan = colspan;
26
- this.rowspan = rowspan;
27
- }
28
69
  }
29
70
  export class TableItemStorage {
30
71
  constructor(_ardParentComp) {
31
72
  this._ardParentComp = _ardParentComp;
32
- this._items = [];
33
- this._sortedItems = [];
34
- this._highlightedItems = [];
35
- this._selectedItems = [];
36
- this._dataColumns = [];
37
- this._headerCells = [];
73
+ this._items = signal([]);
74
+ this._sortedItems = signal([]);
75
+ this._dataColumns = signal([]);
76
+ this._headerCells = signal([]);
77
+ /**
78
+ * Gets all items.
79
+ */
80
+ this.items = this._items.asReadonly();
81
+ this.sortedItems = this._sortedItems.asReadonly();
82
+ /**
83
+ * Gets items based on the current pagination state.
84
+ */
85
+ this.paginatedItems = computed(() => {
86
+ if (!this._ardParentComp.paginated() || this._ardParentComp.paginationStrategy() === TablePaginationStrategy.Noop) {
87
+ return this.sortedItems();
88
+ }
89
+ const page = this._ardParentComp.page();
90
+ const IPP = this._ardParentComp.itemsPerPage();
91
+ const itemsStart = (page - 1) * IPP;
92
+ const itemsEnd = page * IPP;
93
+ return this.sortedItems().slice(itemsStart, itemsEnd);
94
+ });
95
+ /**
96
+ * Gets all currently selected items.
97
+ */
98
+ this.selectedItems = computed(() => this.items().filter(item => item.selected()));
99
+ /**
100
+ * Gets all currently highlighted items.
101
+ */
102
+ this.highlightedItems = computed(() => this.items().filter(item => item.highlighted()));
103
+ /**
104
+ * Gets all highlightable items. An item is considered highlightable if it is **not** disabled.
105
+ */
106
+ this.highlightableItems = computed(() => this._items().filter(item => !item.disabled()));
107
+ /**
108
+ * Gets the values of the currently selected items.
109
+ */
110
+ this.value = computed(() => this._itemsToValue(this.selectedItems()));
111
+ /**
112
+ * Returns true if at least one item is highlighted, otherwise false.
113
+ */
114
+ this.isAnyItemHighlighted = computed(() => this.highlightedItems().length > 0);
115
+ /**
116
+ * Checks if any item in the table is selected.
117
+ * @returns A boolean value indicating if any item is selected.
118
+ */
119
+ this.isAnyItemSelected = computed(() => this.selectedItems().length > 0);
120
+ /**
121
+ * Checks if all items in the table are selected.
122
+ * @returns A boolean value indicating if all items are selected.
123
+ */
124
+ this.areAllSelected = computed(() => this.selectedItems().length === this._items().filter(item => !item.disabled()).length);
125
+ /**
126
+ * Returns true if the parent component defines the limit of concurrently selectable items and the amount of currently selected items matches that limit. Otherwise returns false.
127
+ *
128
+ * **TLDR**: true if `maxSelectedItems` is defined and the number of selected items matches that value.
129
+ */
130
+ this.isItemLimitReached = computed(() => {
131
+ const max = this._ardParentComp.maxSelectedItems();
132
+ if (!isDefined(max)) {
133
+ return false;
134
+ }
135
+ return max <= this.selectedItems().length;
136
+ });
137
+ /**
138
+ * Gets the header cells of the table.
139
+ * @returns a 2D array of header cells.
140
+ */
141
+ this.headerCells = this._headerCells.asReadonly();
142
+ /**
143
+ * Checks if the table has defined columns.
144
+ * @returns a boolean value indicating if the table has defined columns.
145
+ */
146
+ this.hasDefinedColumns = computed(() => this._dataColumns().length > 0);
38
147
  //! sorting
39
148
  this._currentSortColumn = null;
40
149
  this._currentSortType = null;
41
150
  }
42
- /**
43
- * Gets all items.
44
- */
45
- get items() {
46
- return this._items;
47
- }
48
- get sortedItems() {
49
- return this._sortedItems;
50
- }
51
- /**
52
- * Gets items based on the current pagination state.
53
- */
54
- get paginatedItems() {
55
- //prettier-ignore
56
- if (!this._ardParentComp.paginated
57
- || this._ardParentComp.paginationStrategy == TablePaginationStrategy.Noop) {
58
- return this.sortedItems;
59
- }
60
- const page = this._ardParentComp.page;
61
- const IPP = this._ardParentComp.itemsPerPage;
62
- const itemsStart = (page - 1) * IPP;
63
- const itemsEnd = page * IPP;
64
- return this.sortedItems.slice(itemsStart, itemsEnd);
65
- }
66
- /**
67
- * Gets all currently selected items.
68
- */
69
- get selectedItems() {
70
- return this._selectedItems;
71
- }
72
- /**
73
- * Gets all currently highlighted items.
74
- */
75
- get highlightedItems() {
76
- return this._highlightedItems;
77
- }
78
- /**
79
- * Gets the values of the currently selected items.
80
- */
81
- get value() {
82
- return this._itemsToValue(this.selectedItems);
83
- }
84
151
  /**
85
152
  * Maps an array of items into their values.
86
153
  * @param items The items to convert to value.
87
154
  * @returns An array of item values.
88
155
  */
89
156
  _itemsToValue(items) {
90
- return items.map(item => item.itemData);
91
- }
92
- /**
93
- * Returns true if at least one item is highlighted, otherwise false.
94
- */
95
- get isAnyItemHighlighted() {
96
- return this._highlightedItems.length > 0;
97
- }
98
- /**
99
- * Checks if any item in the table is selected.
100
- * @returns A boolean value indicating if any item is selected.
101
- */
102
- get isAnyItemSelected() {
103
- return this._selectedItems.length > 0;
104
- }
105
- /**
106
- * Checks if all items in the table are selected.
107
- * @returns A boolean value indicating if all items are selected.
108
- */
109
- get areAllSelected() {
110
- return this._selectedItems.length == this._items.filter(item => !item.disabled).length;
111
- }
112
- /**
113
- * Returns true if the parent component defines the limit of concurrently selectable items and the amount of currently selected items matches that limit. Otherwise returns false.
114
- *
115
- * **TLDR**: true if `maxSelectedItems` is defined and the number of selected items matches that value.
116
- */
117
- get isItemLimitReached() {
118
- if (!isDefined(this._ardParentComp.maxSelectedItems)) {
119
- return false;
120
- }
121
- return this._ardParentComp.maxSelectedItems <= this.selectedItems.length;
122
- }
123
- /**
124
- * Gets the header cells of the table.
125
- * @returns a 2D array of header cells.
126
- */
127
- get headerCells() {
128
- return this._headerCells;
129
- }
130
- /**
131
- * Checks if the table has defined columns.
132
- * @returns a boolean value indicating if the table has defined columns.
133
- */
134
- get hasDefinedColumns() {
135
- return this._dataColumns.length > 0;
157
+ return items.map(item => item.itemData());
136
158
  }
137
159
  //! setting columns
138
160
  /**
@@ -142,27 +164,27 @@ export class TableItemStorage {
142
164
  setColumns(cols) {
143
165
  const maxNestingLevel = this._getHeaderMaxNesting(cols);
144
166
  const headerCells = this._mapColumnsToArray(cols, maxNestingLevel, 0);
145
- this._headerCells = this._filterHeaderCells(headerCells);
146
- this._dataColumns = this._extractDataSources(cols);
167
+ this._headerCells.set(this._filterHeaderCells(headerCells));
168
+ this._dataColumns.set(this._extractDataSources(cols));
147
169
  }
148
170
  /**
149
- * Filters out null values from the header cells array.
171
+ * Filters out null values from the header cells array. Pure function.
150
172
  * @param cells a 2D array of header cells or null values.
151
173
  * @returns a 2D array of header cells without null values and empty arrays.
152
174
  */
153
175
  _filterHeaderCells(cells) {
154
176
  for (let i = 0; i < cells.length; i++) {
155
- cells[i] = cells[i].filter(v => v != null);
177
+ cells[i] = cells[i].filter(v => v !== null);
156
178
  }
157
179
  return cells.filter(row => row.length);
158
180
  }
159
181
  /**
160
- * Extracts the data sources from the columns array.
182
+ * Extracts the data sources from the columns array. Pure function.
161
183
  * @param cols an array of table data columns or table subheaders.
162
184
  * @returns an array of table data columns.
163
185
  */
164
186
  _extractDataSources(cols) {
165
- let dataColumns = [];
187
+ const dataColumns = [];
166
188
  for (const col of cols) {
167
189
  if (!isTableSubheader(col)) {
168
190
  dataColumns.push(col);
@@ -173,7 +195,7 @@ export class TableItemStorage {
173
195
  return dataColumns;
174
196
  }
175
197
  /**
176
- * Gets the maximum nesting level of the columns array.
198
+ * Gets the maximum nesting level of the columns array. Pure function.
177
199
  * @param cols an array of table data columns or table subheaders.
178
200
  * @returns the maximum nesting level as a number.
179
201
  */
@@ -189,7 +211,7 @@ export class TableItemStorage {
189
211
  return max;
190
212
  }
191
213
  /**
192
- * Maps the columns tree to a 2D array of header cells or null values.
214
+ * Maps the columns tree to a 2D array of header cells or null values. Pure function.
193
215
  * @param cols an array of table data columns or table subheaders.
194
216
  * @param maxNesting the maximum nesting level of the columns array.
195
217
  * @param currentNesting the current nesting level of the columns array.
@@ -225,12 +247,11 @@ export class TableItemStorage {
225
247
  * @param items An array of items to be set as the component's items.
226
248
  */
227
249
  setItems(items) {
228
- if (!this.hasDefinedColumns)
250
+ if (!this.hasDefinedColumns())
229
251
  return;
230
- this._items = items.map((item, index) => {
231
- return this._setItemsMapFn(item, index);
232
- });
233
- this._sortedItems = this._items;
252
+ const mappedItems = items.map((item, i) => this._setItemsMapFn(item, i));
253
+ this._items.set(mappedItems);
254
+ this._sortedItems.set(mappedItems);
234
255
  }
235
256
  /**
236
257
  * Maps raw item data to an {@link ArdTableRow} object.
@@ -244,26 +265,18 @@ export class TableItemStorage {
244
265
  //get data
245
266
  const [data, dataColumns] = this._getRowData(rawItemData, index);
246
267
  //get bold
247
- const rowBoldFromPath = this._ardParentComp.rowBoldFrom ?? this._ardParentComp.DEFAULTS.rowBoldFrom;
268
+ const rowBoldFromPath = this._ardParentComp.rowBoldFrom() ?? this._ardParentComp.DEFAULTS.rowBoldFrom;
248
269
  let bold = resolvePath(rawItemData, rowBoldFromPath);
249
- if (this._ardParentComp.invertRowBold) {
270
+ if (this._ardParentComp.invertRowBold()) {
250
271
  bold = !bold;
251
272
  }
252
273
  //get disabled
253
- const disabledPath = this._ardParentComp.rowDisabledFrom ?? this._ardParentComp.DEFAULTS.rowDisabledFrom;
274
+ const disabledPath = this._ardParentComp.rowDisabledFrom() ?? this._ardParentComp.DEFAULTS.rowDisabledFrom;
254
275
  let disabled = evaluate(resolvePath(rawItemData, disabledPath));
255
- if (this._ardParentComp.invertRowDisabled) {
276
+ if (this._ardParentComp.invertRowDisabled()) {
256
277
  disabled = !disabled;
257
278
  }
258
- //return
259
- return {
260
- itemData: rawItemData,
261
- index,
262
- data,
263
- dataColumns,
264
- disabled,
265
- bold,
266
- };
279
+ return new ArdTableRow(rawItemData, index, data, dataColumns, disabled, bold);
267
280
  }
268
281
  /**
269
282
  * Retrieves data for a row based on data columns configuration.
@@ -274,29 +287,31 @@ export class TableItemStorage {
274
287
  * @private
275
288
  */
276
289
  _getRowData(rawItemData, index) {
277
- let data = [];
278
- for (const dataColumn of this._dataColumns) {
290
+ const data = [];
291
+ const _cols = this._dataColumns();
292
+ for (let i = 0; i < _cols.length; i++) {
293
+ const dataColumn = _cols[i];
279
294
  const sourcePath = dataColumn.dataSource;
280
- if (typeof sourcePath == 'string') {
281
- if (this._ardParentComp.treatDataSourceAsString) {
295
+ if (typeof sourcePath === 'string') {
296
+ if (this._ardParentComp.treatDataSourceAsString()) {
282
297
  data.push(rawItemData[sourcePath]);
283
298
  continue;
284
299
  }
285
300
  data.push(resolvePath(rawItemData, sourcePath));
286
301
  continue;
287
302
  }
288
- if (sourcePath.type == 'autocount') {
303
+ if (sourcePath.type === 'autocount') {
289
304
  data.push(index + 1);
290
305
  continue;
291
306
  }
292
- if (sourcePath.type == 'checkbox') {
307
+ if (sourcePath.type === 'checkbox') {
293
308
  data.push({ _ardCheckbox: true, index });
294
309
  continue;
295
310
  }
296
- const sourceString = typeof sourcePath == 'object' ? JSON.stringify(sourcePath) : sourcePath;
297
- console.error(new Error(`Unexpected data source "${sourceString}".`));
311
+ const sourceString = typeof sourcePath === 'object' ? JSON.stringify(sourcePath) : sourcePath;
312
+ throw new Error(`ARD-FT5052: Unexpected data source "${sourceString}" at index ${i}.`);
298
313
  }
299
- return [data, this._dataColumns];
314
+ return [data, this._dataColumns()];
300
315
  }
301
316
  /**
302
317
  * Writes a new value to the item storage. Selects the correct items based on the provided values, warning the user if the value is not found.
@@ -314,7 +329,7 @@ export class TableItemStorage {
314
329
  * @returns {boolean} _true_ if the item is selected, otherwise _false_.
315
330
  */
316
331
  isItemSelected(index) {
317
- return this._selectedItems.some(item => item.index == index);
332
+ return this.selectedItems().some(item => item.index() === index);
318
333
  }
319
334
  /**
320
335
  * Selects all items.
@@ -325,7 +340,7 @@ export class TableItemStorage {
325
340
  * * An array of items failed to select.
326
341
  */
327
342
  selectAll() {
328
- return this.selectItem(...this._items.map(v => v.index));
343
+ return this.selectItem(...this._items().map(v => v.index()));
329
344
  }
330
345
  /**
331
346
  * Unselects all selected items.
@@ -334,24 +349,22 @@ export class TableItemStorage {
334
349
  * @returns An array of items cleared, mapped to only their values.
335
350
  */
336
351
  unselectAll() {
337
- for (const item of this._selectedItems) {
338
- item.selected = false;
352
+ const selected = this.selectedItems();
353
+ for (const item of selected) {
354
+ item.selected.set(false);
339
355
  }
340
- const ret = this._itemsToValue(this._selectedItems);
341
- this._selectedItems = [];
342
- return ret;
356
+ return this._itemsToValue(selected);
343
357
  }
344
358
  /**
345
359
  * Unselects all selected items, no matter what the component settings are.
346
360
  * @returns An array of items cleared, mapped to only their values.
347
361
  */
348
362
  _forceUnselectAll() {
349
- for (const item of this._selectedItems) {
350
- item.selected = false;
363
+ const selected = this.selectedItems();
364
+ for (const item of selected) {
365
+ item.selected.set(false);
351
366
  }
352
- const ret = this._itemsToValue(this._selectedItems);
353
- this._selectedItems = [];
354
- return ret;
367
+ return this._itemsToValue(selected);
355
368
  }
356
369
  /**
357
370
  * Selects one or multiple items.
@@ -360,25 +373,26 @@ export class TableItemStorage {
360
373
  *
361
374
  * @param indexes A rest operator array of item indexes to be selected.
362
375
  * @returns a tuple containing two arrays:
363
- * * An array of items selected.
364
- * * An array of items failed to select.
376
+ * - An array of items selected.
377
+ * - An array of items failed to select.
365
378
  */
366
379
  selectItem(...indexes) {
367
- const itemsToBeSelected = this._items.filter(item => !item.disabled && indexes.includes(item.index));
368
- if (this.isItemLimitReached) {
380
+ const itemsToBeSelected = this._items().filter(item => !item.disabled() && indexes.includes(item.index()));
381
+ if (this.isItemLimitReached()) {
369
382
  return [[], this._itemsToValue(itemsToBeSelected)];
370
383
  }
371
384
  let itemsSelectedCount = 0;
372
385
  const itemsSelected = [];
386
+ let itemsLeftUntilLimit = (this._ardParentComp.maxSelectedItems() ?? Infinity) - this.selectedItems().length;
373
387
  for (const item of itemsToBeSelected) {
374
388
  itemsSelectedCount++;
375
- if (item.selected)
389
+ if (item.selected())
376
390
  continue;
377
- if (this.isItemLimitReached) {
391
+ if (itemsLeftUntilLimit <= 0) {
378
392
  break;
379
393
  }
380
- item.selected = true;
381
- this._selectedItems.push(item);
394
+ itemsLeftUntilLimit--;
395
+ item.selected.set(true);
382
396
  itemsSelected.push(item);
383
397
  }
384
398
  const itemsFailedToSelect = itemsToBeSelected.slice(itemsSelectedCount - 1);
@@ -390,22 +404,21 @@ export class TableItemStorage {
390
404
  * @returns An array of items unselected, mapped to only their values.
391
405
  */
392
406
  unselectItem(...indexes) {
393
- const itemsToBeSelected = this._items.filter(item => indexes.includes(item.index));
394
- for (const item of itemsToBeSelected) {
395
- item.selected = false;
407
+ const itemsToBeUnselected = this._items().filter(item => indexes.includes(item.index()));
408
+ for (const item of itemsToBeUnselected) {
409
+ item.selected.set(false);
396
410
  }
397
- this._selectedItems = this._selectedItems.filter(v => v.selected);
398
- return this._itemsToValue(itemsToBeSelected);
411
+ return this._itemsToValue(itemsToBeUnselected);
399
412
  }
400
413
  //! highlighting items
401
414
  /**
402
415
  * Unhighlights all currently highlighted items.
403
416
  */
404
417
  unhighlightAll() {
405
- for (const item of this._highlightedItems) {
406
- item.highlighted = false;
418
+ const highlighted = this.highlightedItems();
419
+ for (const item of highlighted) {
420
+ item.highlighted.set(false);
407
421
  }
408
- this._highlightedItems = [];
409
422
  }
410
423
  /**
411
424
  * Highlights the given item, while unhighlighting all other items. Does nothing when the item is disabled.
@@ -422,11 +435,10 @@ export class TableItemStorage {
422
435
  * @returns The last highlighted item.
423
436
  */
424
437
  highlightItem(...indexes) {
425
- const items = this._items.filter(item => indexes.includes(item.index));
438
+ const items = this._items().filter(item => indexes.includes(item.index()));
426
439
  for (const item of items) {
427
- item.highlighted = true;
440
+ item.highlighted.set(true);
428
441
  }
429
- this._highlightedItems.push(...items);
430
442
  return items.last();
431
443
  }
432
444
  /**
@@ -434,13 +446,12 @@ export class TableItemStorage {
434
446
  * @param items A rest operator array of item indexes to be unhighlighted.
435
447
  */
436
448
  unhighlightItem(...indexes) {
437
- const items = this._items.filter(item => indexes.includes(item.index));
449
+ const items = this._items().filter(item => indexes.includes(item.index()));
438
450
  for (const item of items) {
439
- if (!item || !item.highlighted)
451
+ if (!item || !item.highlighted())
440
452
  return;
441
- item.highlighted = false;
453
+ item.highlighted.set(false);
442
454
  }
443
- this._highlightedItems = this._highlightedItems.filter(v => v.highlighted);
444
455
  }
445
456
  /**
446
457
  * Highlights the first item out of all items.
@@ -448,7 +459,7 @@ export class TableItemStorage {
448
459
  */
449
460
  highlightFirstItem() {
450
461
  this.unhighlightAll();
451
- let itemToHighlight = this._getHiglightableItems().first().index;
462
+ const itemToHighlight = this.highlightableItems().first().index();
452
463
  return this.highlightItem(itemToHighlight);
453
464
  }
454
465
  /**
@@ -457,14 +468,14 @@ export class TableItemStorage {
457
468
  */
458
469
  highlightLastItem() {
459
470
  this.unhighlightAll();
460
- let itemToHighlight = this._getHiglightableItems().last().index;
471
+ const itemToHighlight = this.highlightableItems().last().index();
461
472
  return this.highlightItem(itemToHighlight);
462
473
  }
463
474
  /**
464
475
  * Highlights all non-disabled items.
465
476
  */
466
477
  highlightAllItems() {
467
- let itemsToHighlight = this._getHiglightableItems().map(v => v.index);
478
+ const itemsToHighlight = this.highlightableItems().map(v => v.index());
468
479
  this.highlightItem(...itemsToHighlight);
469
480
  }
470
481
  /**
@@ -476,12 +487,12 @@ export class TableItemStorage {
476
487
  * @returns The item highlighted.
477
488
  */
478
489
  highlightNextItem(offset, hasShift) {
479
- if (!this.isAnyItemHighlighted) {
490
+ if (!this.isAnyItemHighlighted()) {
480
491
  return this.highlightFirstItem();
481
492
  }
482
- const currentItem = this.highlightedItems.last();
483
- const itemsWithoutDisabled = this._items.filter(item => !item.disabled && (!this.isItemLimitReached || item.selected));
484
- const currentIndexInItems = itemsWithoutDisabled.findIndex(item => item.index == currentItem.index);
493
+ const currentItem = this.highlightedItems().last();
494
+ const itemsWithoutDisabled = this._items().filter(item => !item.disabled() && (!this.isItemLimitReached() || item.selected()));
495
+ const currentIndexInItems = itemsWithoutDisabled.findIndex(item => item.index() === currentItem.index());
485
496
  let nextItemIndex = currentIndexInItems + offset;
486
497
  if (nextItemIndex >= itemsWithoutDisabled.length) {
487
498
  nextItemIndex -= itemsWithoutDisabled.length;
@@ -491,23 +502,16 @@ export class TableItemStorage {
491
502
  }
492
503
  const itemToHighlight = itemsWithoutDisabled[nextItemIndex];
493
504
  if (hasShift) {
494
- if (itemToHighlight.highlighted) {
505
+ if (itemToHighlight.highlighted()) {
495
506
  this.unhighlightItem(nextItemIndex);
496
507
  }
497
508
  return this.highlightItem(nextItemIndex);
498
509
  }
499
510
  return this.highlightSingleItem(nextItemIndex);
500
511
  }
501
- /**
502
- * Finds all highlightable items. An item is considered highlightable if it is **not** disabled.
503
- * @returns An array of all highlightable items.
504
- */
505
- _getHiglightableItems() {
506
- return this._items.filter(item => !item.disabled);
507
- }
508
512
  toggleCurrentSortColumn(column) {
509
- if (this._currentSortColumn == column) {
510
- if (this._currentSortType == SortType.Ascending) {
513
+ if (this._currentSortColumn === column) {
514
+ if (this._currentSortType === SortType.Ascending) {
511
515
  this._currentSortType = SortType.Descending;
512
516
  }
513
517
  else {
@@ -523,29 +527,29 @@ export class TableItemStorage {
523
527
  resetSort() {
524
528
  this._currentSortColumn = null;
525
529
  this._currentSortType = null;
526
- this._sortedItems = [...this.items];
530
+ this._sortedItems.set([...this.items()]);
527
531
  }
528
532
  getColumnSortType(column) {
529
- if (this._currentSortColumn == column) {
533
+ if (this._currentSortColumn === column) {
530
534
  return this._currentSortType;
531
535
  }
532
536
  return null;
533
537
  }
534
538
  _generateSortedRows(justReverse) {
535
539
  if (justReverse) {
536
- this._sortedItems.reverse();
540
+ this._sortedItems().reverse();
537
541
  return;
538
542
  }
539
543
  const sortColumnIndex = this._currentSortColumn;
540
544
  if (isNull(sortColumnIndex) || !this._currentSortType) {
541
- this._sortedItems = this.items;
545
+ this._sortedItems.set(this.items());
542
546
  return;
543
547
  }
544
- const sortColumn = this._dataColumns[sortColumnIndex];
548
+ const sortColumn = this._dataColumns()[sortColumnIndex];
545
549
  if (!sortColumn) {
546
- throw new Error(`Encountered an issue in <ard-table>: could not find the column with index ${sortColumnIndex}. This is most likely an Ardium bug, please report it on GitHub.`);
550
+ throw new Error(`ARD-IS5059: Encountered an issue in <ard-table>: could not find the column with index ${sortColumnIndex}. This is most likely an Ardium UI bug, please report it to the creators.`);
547
551
  }
548
- const direction = this._currentSortType == SortType.Ascending ? 1 : -1;
552
+ const direction = this._currentSortType === SortType.Ascending ? 1 : -1;
549
553
  const sortFn = sortColumn.sortFn ??
550
554
  ((a, b) => {
551
555
  if (a > b)
@@ -554,7 +558,7 @@ export class TableItemStorage {
554
558
  return -1 * direction;
555
559
  return 0;
556
560
  });
557
- this._sortedItems = [...this.items].sort((a, b) => sortFn(a.data[sortColumnIndex], b.data[sortColumnIndex]));
561
+ this._sortedItems.set([...this.items()].sort((a, b) => sortFn(a.data()[sortColumnIndex], b.data()[sortColumnIndex])));
558
562
  }
559
563
  }
560
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-item-storage.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/table/table-item-storage.ts"],"names":[],"mappings":"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","sourcesContent":["import resolvePath from 'resolve-object-path';\r\nimport { evaluate, isDefined, isNull } from 'simple-bool';\r\nimport { CompareWithFn } from '../types/item-storage.types';\r\nimport { SortType, TableDataColumn, TablePaginationStrategy, TableSubheader } from './table.types';\r\nimport { areAllDataColumns, isTableSubheader, merge2dArrays } from './utils';\r\n\r\nexport interface ArdTableRow {\r\n  readonly itemData: any;\r\n  readonly index: number;\r\n  readonly isEmpty?: boolean;\r\n  data: any[];\r\n  dataColumns: TableDataColumn[];\r\n  class?: string;\r\n  disabled?: boolean;\r\n  bold?: boolean;\r\n  selected?: boolean;\r\n  highlighted?: boolean;\r\n}\r\nexport interface TableItemStorageHostDefaults {\r\n  rowDisabledFrom: string;\r\n  rowBoldFrom: string;\r\n}\r\nexport interface TableItemStorageHost {\r\n  rowDisabledFrom?: string;\r\n  rowBoldFrom?: string;\r\n  invertRowDisabled?: boolean;\r\n  invertRowBold?: boolean;\r\n  data?: any[];\r\n  readonly DEFAULTS: TableItemStorageHostDefaults;\r\n  maxSelectedItems?: number;\r\n  treatDataSourceAsString?: boolean;\r\n\r\n  paginated: boolean;\r\n  paginationStrategy: TablePaginationStrategy;\r\n  itemsPerPage: number;\r\n  page: number;\r\n}\r\nexport class HeaderCell {\r\n  colspan!: number;\r\n  rowspan!: number;\r\n  cell!: TableDataColumn | TableSubheader;\r\n\r\n  get width(): string | null {\r\n    if (isTableSubheader(this.cell)) return null;\r\n    return this._getWidth(this.cell.width);\r\n  }\r\n  get minWidth(): string | null {\r\n    if (isTableSubheader(this.cell)) return null;\r\n    return this._getWidth(this.cell.minWidth);\r\n  }\r\n  private _getWidth(width: string | number | undefined): string | null {\r\n    if (!width) return null;\r\n    if (typeof width == 'number') return `${width}px`;\r\n    return width;\r\n  }\r\n\r\n  constructor(cell: TableDataColumn | TableSubheader, colspan: number = 1, rowspan: number = 1) {\r\n    this.cell = cell;\r\n    this.colspan = colspan;\r\n    this.rowspan = rowspan;\r\n  }\r\n}\r\n\r\nexport class TableItemStorage {\r\n  private _items: ArdTableRow[] = [];\r\n  private _sortedItems: ArdTableRow[] = [];\r\n  private _highlightedItems: ArdTableRow[] = [];\r\n  private _selectedItems: ArdTableRow[] = [];\r\n\r\n  private _dataColumns: TableDataColumn[] = [];\r\n  private _headerCells: HeaderCell[][] = [];\r\n\r\n  constructor(private _ardParentComp: TableItemStorageHost) {}\r\n\r\n  /**\r\n   * Gets all items.\r\n   */\r\n  get items(): ArdTableRow[] {\r\n    return this._items;\r\n  }\r\n  get sortedItems(): ArdTableRow[] {\r\n    return this._sortedItems;\r\n  }\r\n  /**\r\n   * Gets items based on the current pagination state.\r\n   */\r\n  get paginatedItems(): ArdTableRow[] {\r\n    //prettier-ignore\r\n    if (\r\n            !this._ardParentComp.paginated\r\n            || this._ardParentComp.paginationStrategy == TablePaginationStrategy.Noop\r\n        ) {\r\n            return this.sortedItems;\r\n        }\r\n    const page = this._ardParentComp.page;\r\n    const IPP = this._ardParentComp.itemsPerPage;\r\n    const itemsStart = (page - 1) * IPP;\r\n    const itemsEnd = page * IPP;\r\n    return this.sortedItems.slice(itemsStart, itemsEnd);\r\n  }\r\n  /**\r\n   * Gets all currently selected items.\r\n   */\r\n  get selectedItems(): ArdTableRow[] {\r\n    return this._selectedItems;\r\n  }\r\n  /**\r\n   * Gets all currently highlighted items.\r\n   */\r\n  get highlightedItems(): ArdTableRow[] {\r\n    return this._highlightedItems;\r\n  }\r\n  /**\r\n   * Gets the values of the currently selected items.\r\n   */\r\n  get value(): any[] {\r\n    return this._itemsToValue(this.selectedItems);\r\n  }\r\n  /**\r\n   * Maps an array of items into their values.\r\n   * @param items The items to convert to value.\r\n   * @returns An array of item values.\r\n   */\r\n  private _itemsToValue(items: ArdTableRow[]): any[] {\r\n    return items.map(item => item.itemData);\r\n  }\r\n\r\n  /**\r\n   * Returns true if at least one item is highlighted, otherwise false.\r\n   */\r\n  get isAnyItemHighlighted(): boolean {\r\n    return this._highlightedItems.length > 0;\r\n  }\r\n  /**\r\n   * Checks if any item in the table is selected.\r\n   * @returns A boolean value indicating if any item is selected.\r\n   */\r\n  get isAnyItemSelected(): boolean {\r\n    return this._selectedItems.length > 0;\r\n  }\r\n  /**\r\n   * Checks if all items in the table are selected.\r\n   * @returns A boolean value indicating if all items are selected.\r\n   */\r\n  get areAllSelected(): boolean {\r\n    return this._selectedItems.length == this._items.filter(item => !item.disabled).length;\r\n  }\r\n  /**\r\n   * Returns true if the parent component defines the limit of concurrently selectable items and the amount of currently selected items matches that limit. Otherwise returns false.\r\n   *\r\n   * **TLDR**: true if `maxSelectedItems` is defined and the number of selected items matches that value.\r\n   */\r\n  get isItemLimitReached(): boolean {\r\n    if (!isDefined(this._ardParentComp.maxSelectedItems)) {\r\n      return false;\r\n    }\r\n    return this._ardParentComp.maxSelectedItems <= this.selectedItems.length;\r\n  }\r\n\r\n  /**\r\n   * Gets the header cells of the table.\r\n   * @returns a 2D array of header cells.\r\n   */\r\n  get headerCells(): HeaderCell[][] {\r\n    return this._headerCells;\r\n  }\r\n  /**\r\n   * Checks if the table has defined columns.\r\n   * @returns a boolean value indicating if the table has defined columns.\r\n   */\r\n  get hasDefinedColumns(): boolean {\r\n    return this._dataColumns.length > 0;\r\n  }\r\n\r\n  //! setting columns\r\n  /**\r\n   * Sets the columns of the table.\r\n   * @param cols an array of table data columns or table subheaders.\r\n   */\r\n  setColumns(cols: (TableDataColumn | TableSubheader)[]): void {\r\n    const maxNestingLevel = this._getHeaderMaxNesting(cols);\r\n    const headerCells = this._mapColumnsToArray(cols, maxNestingLevel, 0);\r\n    this._headerCells = this._filterHeaderCells(headerCells);\r\n    this._dataColumns = this._extractDataSources(cols);\r\n  }\r\n  /**\r\n   * Filters out null values from the header cells array.\r\n   * @param cells a 2D array of header cells or null values.\r\n   * @returns a 2D array of header cells without null values and empty arrays.\r\n   */\r\n  private _filterHeaderCells(cells: (HeaderCell | null)[][]): HeaderCell[][] {\r\n    for (let i = 0; i < cells.length; i++) {\r\n      cells[i] = cells[i].filter(v => v != null);\r\n    }\r\n    return cells.filter(row => row.length) as HeaderCell[][];\r\n  }\r\n  /**\r\n   * Extracts the data sources from the columns array.\r\n   * @param cols an array of table data columns or table subheaders.\r\n   * @returns an array of table data columns.\r\n   */\r\n  private _extractDataSources(cols: (TableDataColumn | TableSubheader)[]): TableDataColumn[] {\r\n    let dataColumns: TableDataColumn[] = [];\r\n\r\n    for (const col of cols) {\r\n      if (!isTableSubheader(col)) {\r\n        dataColumns.push(col);\r\n        continue;\r\n      }\r\n      dataColumns.push(...this._extractDataSources(col.children));\r\n    }\r\n\r\n    return dataColumns;\r\n  }\r\n  /**\r\n   * Gets the maximum nesting level of the columns array.\r\n   * @param cols an array of table data columns or table subheaders.\r\n   * @returns the maximum nesting level as a number.\r\n   */\r\n  private _getHeaderMaxNesting(cols: (TableDataColumn | TableSubheader)[]): number {\r\n    if (areAllDataColumns(cols)) return 1;\r\n    let max = 1;\r\n    for (const col of cols.filter(v => isTableSubheader(v)) as TableSubheader[]) {\r\n      const height = 1 + this._getHeaderMaxNesting(col.children);\r\n      if (height > max) max = height;\r\n    }\r\n    return max;\r\n  }\r\n  /**\r\n   * Maps the columns tree to a 2D array of header cells or null values.\r\n   * @param cols an array of table data columns or table subheaders.\r\n   * @param maxNesting the maximum nesting level of the columns array.\r\n   * @param currentNesting the current nesting level of the columns array.\r\n   * @returns a 2D array of header cells or null values.\r\n   */\r\n  private _mapColumnsToArray(cols: (TableDataColumn | TableSubheader)[], maxNesting: number, currentNesting: number): (HeaderCell | null)[][] {\r\n    if (areAllDataColumns(cols)) {\r\n      return [cols.map(col => new HeaderCell(col, 1, maxNesting - currentNesting))];\r\n    }\r\n    const headerCells: (HeaderCell | null)[][] = [[]];\r\n    for (const col of cols) {\r\n      if (!isTableSubheader(col)) {\r\n        headerCells[0].push(new HeaderCell(col, 1, maxNesting - currentNesting));\r\n        continue;\r\n      }\r\n      const childCells: (HeaderCell | null)[][] = [[], ...this._mapColumnsToArray(col.children, maxNesting, currentNesting + 1)];\r\n      const height = childCells.length - 1;\r\n      const width = childCells[1].length;\r\n      for (let i = 0; i < height; i++) {\r\n        headerCells.push([null]);\r\n      }\r\n      headerCells[0].push(new HeaderCell(col, width, 1));\r\n      for (let i = 0; i < width - 1; i++) {\r\n        headerCells[0].push(null);\r\n      }\r\n      merge2dArrays(headerCells, childCells);\r\n    }\r\n    return headerCells;\r\n  }\r\n\r\n  //! setting items\r\n  /**\r\n   * Sets the component's items. Takes into account the values defined by the parent component for `rowDisabledFrom`, `rowBoldFrom`, and `rowHighlightedFrom`.\r\n   * @param items An array of items to be set as the component's items.\r\n   */\r\n  setItems(items: any[]): void {\r\n    if (!this.hasDefinedColumns) return;\r\n\r\n    this._items = items.map((item, index) => {\r\n      return this._setItemsMapFn(item, index);\r\n    });\r\n    this._sortedItems = this._items;\r\n  }\r\n  /**\r\n   * Maps raw item data to an {@link ArdTableRow} object.\r\n   *\r\n   * @param {any} rawItemData - The raw data of the item.\r\n   * @param {number} index - The index of the item.\r\n   * @returns {ArdTableRow} Returns an ArdTableRow object with mapped properties.\r\n   * @private\r\n   */\r\n  private _setItemsMapFn(rawItemData: any, index: number): ArdTableRow {\r\n    //get data\r\n    const [data, dataColumns] = this._getRowData(rawItemData, index);\r\n\r\n    //get bold\r\n    const rowBoldFromPath = this._ardParentComp.rowBoldFrom ?? this._ardParentComp.DEFAULTS.rowBoldFrom;\r\n    let bold = resolvePath(rawItemData, rowBoldFromPath);\r\n    if (this._ardParentComp.invertRowBold) {\r\n      bold = !bold;\r\n    }\r\n\r\n    //get disabled\r\n    const disabledPath = this._ardParentComp.rowDisabledFrom ?? this._ardParentComp.DEFAULTS.rowDisabledFrom;\r\n    let disabled = evaluate(resolvePath(rawItemData, disabledPath));\r\n    if (this._ardParentComp.invertRowDisabled) {\r\n      disabled = !disabled;\r\n    }\r\n\r\n    //return\r\n    return {\r\n      itemData: rawItemData,\r\n      index,\r\n      data,\r\n      dataColumns,\r\n      disabled,\r\n      bold,\r\n    };\r\n  }\r\n  /**\r\n   * Retrieves data for a row based on data columns configuration.\r\n   *\r\n   * @param {any} rawItemData - The raw data of the item.\r\n   * @param {number} index - The index of the item.\r\n   * @returns {any[]} Returns an array containing the row data.\r\n   * @private\r\n   */\r\n  private _getRowData(rawItemData: any, index: number): [any[], TableDataColumn[]] {\r\n    let data: any[] = [];\r\n    for (const dataColumn of this._dataColumns) {\r\n      const sourcePath = dataColumn.dataSource;\r\n\r\n      if (typeof sourcePath == 'string') {\r\n        if (this._ardParentComp.treatDataSourceAsString) {\r\n          data.push(rawItemData[sourcePath]);\r\n          continue;\r\n        }\r\n        data.push(resolvePath(rawItemData, sourcePath));\r\n        continue;\r\n      }\r\n      if (sourcePath.type == 'autocount') {\r\n        data.push(index + 1);\r\n        continue;\r\n      }\r\n      if (sourcePath.type == 'checkbox') {\r\n        data.push({ _ardCheckbox: true, index });\r\n        continue;\r\n      }\r\n      const sourceString = typeof sourcePath == 'object' ? JSON.stringify(sourcePath) : sourcePath;\r\n      console.error(new Error(`Unexpected data source \"${sourceString}\".`));\r\n    }\r\n    return [data, this._dataColumns];\r\n  }\r\n  /**\r\n   * Writes a new value to the item storage. Selects the correct items based on the provided values, warning the user if the value is not found.\r\n   * @param indexes The value of the ngModel to set.\r\n   */\r\n  writeValue(indexes: number[]): void {\r\n    this._forceUnselectAll();\r\n    this.selectItem(...indexes);\r\n  }\r\n\r\n  //! selecting items\r\n  /**\r\n   * Checks if an item with the given index is selected.\r\n   *\r\n   * @param {number} index The index of the item to check.\r\n   * @returns {boolean} _true_ if the item is selected, otherwise _false_.\r\n   */\r\n  isItemSelected(index: number): boolean {\r\n    return this._selectedItems.some(item => item.index == index);\r\n  }\r\n  /**\r\n   * Selects all items.\r\n   *\r\n   * Accounts for the limit of concurrently selected items defined by the parent component.\r\n   * @returns a tuple containing two arrays:\r\n   * * An array of items selected.\r\n   * * An array of items failed to select.\r\n   */\r\n  selectAll(): [any[], any[]] {\r\n    return this.selectItem(...this._items.map(v => v.index));\r\n  }\r\n  /**\r\n   * Unselects all selected items.\r\n   *\r\n   * If the parent component requires at least one value to be selected at all times, the first selected items is left selected.\r\n   * @returns An array of items cleared, mapped to only their values.\r\n   */\r\n  unselectAll(): any[] {\r\n    for (const item of this._selectedItems) {\r\n      item.selected = false;\r\n    }\r\n\r\n    const ret = this._itemsToValue(this._selectedItems);\r\n\r\n    this._selectedItems = [];\r\n\r\n    return ret;\r\n  }\r\n  /**\r\n   * Unselects all selected items, no matter what the component settings are.\r\n   * @returns An array of items cleared, mapped to only their values.\r\n   */\r\n  private _forceUnselectAll(): any[] {\r\n    for (const item of this._selectedItems) {\r\n      item.selected = false;\r\n    }\r\n\r\n    const ret = this._itemsToValue(this._selectedItems);\r\n\r\n    this._selectedItems = [];\r\n\r\n    return ret;\r\n  }\r\n  /**\r\n   * Selects one or multiple items.\r\n   *\r\n   * Accounts for the limit of concurrently selected items defined by the parent component.\r\n   *\r\n   * @param indexes A rest operator array of item indexes to be selected.\r\n   * @returns a tuple containing two arrays:\r\n   * * An array of items selected.\r\n   * * An array of items failed to select.\r\n   */\r\n  selectItem(...indexes: number[]): [any[], any[]] {\r\n    const itemsToBeSelected = this._items.filter(item => !item.disabled && indexes.includes(item.index));\r\n    if (this.isItemLimitReached) {\r\n      return [[], this._itemsToValue(itemsToBeSelected)];\r\n    }\r\n\r\n    let itemsSelectedCount = 0;\r\n    const itemsSelected = [];\r\n    for (const item of itemsToBeSelected) {\r\n      itemsSelectedCount++;\r\n      if (item.selected) continue;\r\n      if (this.isItemLimitReached) {\r\n        break;\r\n      }\r\n      item.selected = true;\r\n      this._selectedItems.push(item);\r\n      itemsSelected.push(item);\r\n    }\r\n\r\n    const itemsFailedToSelect = itemsToBeSelected.slice(itemsSelectedCount - 1);\r\n    return [this._itemsToValue(itemsSelected), this._itemsToValue(itemsFailedToSelect)];\r\n  }\r\n  /**\r\n   * Unselects one or multiple items.\r\n   * @param items A rest operator array of item indexes to be unselected.\r\n   * @returns An array of items unselected, mapped to only their values.\r\n   */\r\n  unselectItem(...indexes: number[]): any[] {\r\n    const itemsToBeSelected = this._items.filter(item => indexes.includes(item.index));\r\n    for (const item of itemsToBeSelected) {\r\n      item.selected = false;\r\n    }\r\n    this._selectedItems = this._selectedItems.filter(v => v.selected);\r\n\r\n    return this._itemsToValue(itemsToBeSelected);\r\n  }\r\n\r\n  //! highlighting items\r\n  /**\r\n   * Unhighlights all currently highlighted items.\r\n   */\r\n  unhighlightAll(): void {\r\n    for (const item of this._highlightedItems) {\r\n      item.highlighted = false;\r\n    }\r\n    this._highlightedItems = [];\r\n  }\r\n  /**\r\n   * Highlights the given item, while unhighlighting all other items. Does nothing when the item is disabled.\r\n   * @param item The index of the item to be highlighted.\r\n   * @returns The highlighted item.\r\n   */\r\n  highlightSingleItem(index: number): ArdTableRow | null {\r\n    this.unhighlightAll();\r\n    return this.highlightItem(index);\r\n  }\r\n  /**\r\n   * Highlights all given items.\r\n   * @param items A rest operator array of item indexes to be highlighted.\r\n   * @returns The last highlighted item.\r\n   */\r\n  highlightItem(...indexes: number[]): ArdTableRow {\r\n    const items = this._items.filter(item => indexes.includes(item.index));\r\n    for (const item of items) {\r\n      item.highlighted = true;\r\n    }\r\n    this._highlightedItems.push(...items);\r\n    return items.last();\r\n  }\r\n  /**\r\n   * Unhighlights all given items.\r\n   * @param items A rest operator array of item indexes to be unhighlighted.\r\n   */\r\n  unhighlightItem(...indexes: number[]): void {\r\n    const items = this._items.filter(item => indexes.includes(item.index));\r\n    for (const item of items) {\r\n      if (!item || !item.highlighted) return;\r\n\r\n      item.highlighted = false;\r\n    }\r\n    this._highlightedItems = this._highlightedItems.filter(v => v.highlighted);\r\n  }\r\n  /**\r\n   * Highlights the first item out of all items.\r\n   * @returns The highlighted item.\r\n   */\r\n  highlightFirstItem(): ArdTableRow | null {\r\n    this.unhighlightAll();\r\n\r\n    let itemToHighlight = this._getHiglightableItems().first().index;\r\n    return this.highlightItem(itemToHighlight);\r\n  }\r\n  /**\r\n   * Highlights the last item out of all items.\r\n   * @returns The highlighted item.\r\n   */\r\n  highlightLastItem(): ArdTableRow | null {\r\n    this.unhighlightAll();\r\n\r\n    let itemToHighlight = this._getHiglightableItems().last().index;\r\n    return this.highlightItem(itemToHighlight);\r\n  }\r\n  /**\r\n   * Highlights all non-disabled items.\r\n   */\r\n  highlightAllItems(): void {\r\n    let itemsToHighlight = this._getHiglightableItems().map(v => v.index);\r\n\r\n    this.highlightItem(...itemsToHighlight);\r\n  }\r\n  /**\r\n   * Highlights the next non-disabled item defined by the offset amount.\r\n   *\r\n   * If `hasShift` is set to true, all originally highlighted items are kept. Otherwise, all original items are unselected.\r\n   * @param offset The amount of items to offset the highlight by.\r\n   * @param hasShift Whether the user has the shift key pressed.\r\n   * @returns The item highlighted.\r\n   */\r\n  highlightNextItem(offset: number, hasShift?: boolean): ArdTableRow | null {\r\n    if (!this.isAnyItemHighlighted) {\r\n      return this.highlightFirstItem();\r\n    }\r\n    const currentItem = this.highlightedItems.last();\r\n    const itemsWithoutDisabled = this._items.filter(item => !item.disabled && (!this.isItemLimitReached || item.selected));\r\n    const currentIndexInItems = itemsWithoutDisabled.findIndex(item => item.index == currentItem.index);\r\n\r\n    let nextItemIndex = currentIndexInItems + offset;\r\n    if (nextItemIndex >= itemsWithoutDisabled.length) {\r\n      nextItemIndex -= itemsWithoutDisabled.length;\r\n    }\r\n    if (nextItemIndex < 0) {\r\n      nextItemIndex += itemsWithoutDisabled.length;\r\n    }\r\n    const itemToHighlight = itemsWithoutDisabled[nextItemIndex];\r\n\r\n    if (hasShift) {\r\n      if (itemToHighlight.highlighted) {\r\n        this.unhighlightItem(nextItemIndex);\r\n      }\r\n      return this.highlightItem(nextItemIndex);\r\n    }\r\n    return this.highlightSingleItem(nextItemIndex);\r\n  }\r\n  /**\r\n   * Finds all highlightable items. An item is considered highlightable if it is **not** disabled.\r\n   * @returns An array of all highlightable items.\r\n   */\r\n  private _getHiglightableItems(): ArdTableRow[] {\r\n    return this._items.filter(item => !item.disabled);\r\n  }\r\n\r\n  //! sorting\r\n  private _currentSortColumn: number | null = null;\r\n  private _currentSortType: SortType | null = null;\r\n\r\n  toggleCurrentSortColumn(column: number): void {\r\n    if (this._currentSortColumn == column) {\r\n      if (this._currentSortType == SortType.Ascending) {\r\n        this._currentSortType = SortType.Descending;\r\n      } else {\r\n        this._currentSortType = SortType.Ascending;\r\n      }\r\n      this._generateSortedRows(true);\r\n      return;\r\n    }\r\n    this._currentSortColumn = column;\r\n    this._currentSortType = SortType.Ascending;\r\n    this._generateSortedRows();\r\n  }\r\n  resetSort(): void {\r\n    this._currentSortColumn = null;\r\n    this._currentSortType = null;\r\n    this._sortedItems = [...this.items];\r\n  }\r\n  getColumnSortType(column: number): SortType | null {\r\n    if (this._currentSortColumn == column) {\r\n      return this._currentSortType;\r\n    }\r\n    return null;\r\n  }\r\n  private _generateSortedRows(justReverse?: boolean): void {\r\n    if (justReverse) {\r\n      this._sortedItems.reverse();\r\n      return;\r\n    }\r\n    const sortColumnIndex = this._currentSortColumn;\r\n    if (isNull(sortColumnIndex) || !this._currentSortType) {\r\n      this._sortedItems = this.items;\r\n      return;\r\n    }\r\n    const sortColumn = this._dataColumns[sortColumnIndex];\r\n    if (!sortColumn) {\r\n      throw new Error(\r\n        `Encountered an issue in <ard-table>: could not find the column with index ${sortColumnIndex}. This is most likely an Ardium bug, please report it on GitHub.`\r\n      );\r\n    }\r\n\r\n    const direction = this._currentSortType == SortType.Ascending ? 1 : -1;\r\n    const sortFn =\r\n      sortColumn.sortFn ??\r\n      ((a, b) => {\r\n        if (a > b) return direction;\r\n        if (a < b) return -1 * direction;\r\n        return 0;\r\n      });\r\n\r\n    this._sortedItems = [...this.items].sort((a, b) => sortFn(a.data[sortColumnIndex], b.data[sortColumnIndex]));\r\n  }\r\n}\r\n"]}
564
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-item-storage.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/table/table-item-storage.ts"],"names":[],"mappings":"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","sourcesContent":["import { Signal, computed, signal } from '@angular/core';\nimport resolvePath from 'resolve-object-path';\nimport { evaluate, isDefined, isNull } from 'simple-bool';\nimport { Nullable } from '../types/utility.types';\nimport { SortType, TableDataColumn, TablePaginationStrategy, TableSubheader } from './table.types';\nimport { areAllDataColumns, isTableSubheader, merge2dArrays } from './utils';\n\nexport class ArdTableRow {\n  private readonly _itemData = signal<any>(undefined);\n  readonly itemData = this._itemData.asReadonly();\n\n  private readonly _index = signal<number>(-1);\n  readonly index = this._index.asReadonly();\n\n  private readonly _isEmpty = signal<boolean>(false);\n  readonly isEmpty = this._isEmpty.asReadonly();\n\n  private readonly _data = signal<any[]>([]);\n  readonly data = this._data.asReadonly();\n\n  private readonly _dataColumns = signal<TableDataColumn[]>([]);\n  readonly dataColumns = this._dataColumns.asReadonly();\n\n  private readonly _class = signal<string>('');\n  readonly class = this._class.asReadonly();\n\n  readonly disabled = signal<boolean>(false);\n  readonly bold = signal<boolean>(false);\n  readonly selected = signal<boolean>(false);\n  readonly highlighted = signal<boolean>(false);\n\n  constructor(\n    itemData: any,\n    index: number,\n    data: any[],\n    dataColumns: TableDataColumn[],\n    disabled: boolean,\n    bold: boolean,\n    isEmpty = false\n  ) {\n    this._itemData.set(itemData);\n    this._index.set(index);\n    this._data.set(data);\n    this._dataColumns.set(dataColumns);\n    this.disabled.set(disabled);\n    this.bold.set(bold);\n    this._isEmpty.set(isEmpty);\n  }\n  static newEmptyCell(index: number) {\n    return new ArdTableRow(null, index, [], [], false, false, true);\n  }\n}\nexport interface TableItemStorageHostDefaults {\n  readonly rowDisabledFrom: string;\n  readonly rowBoldFrom: string;\n}\nexport interface TableItemStorageHost {\n  readonly rowDisabledFrom: Signal<Nullable<string>>;\n  readonly rowBoldFrom: Signal<Nullable<string>>;\n  readonly invertRowDisabled: Signal<Nullable<boolean>>;\n  readonly invertRowBold: Signal<Nullable<boolean>>;\n  readonly data: Signal<Nullable<any>>[];\n  readonly DEFAULTS: TableItemStorageHostDefaults;\n  readonly maxSelectedItems: Signal<Nullable<number>>;\n  readonly treatDataSourceAsString: Signal<Nullable<boolean>>;\n\n  readonly paginated: Signal<boolean>;\n  readonly paginationStrategy: Signal<TablePaginationStrategy>;\n  readonly itemsPerPage: Signal<number>;\n  readonly page: Signal<number>;\n}\nexport class HeaderCell {\n  readonly cell = signal<TableDataColumn | TableSubheader>(undefined as any);\n  readonly colspan = signal<number>(1);\n  readonly rowspan = signal<number>(1);\n\n  constructor(cell: TableDataColumn | TableSubheader, colspan = 1, rowspan = 1) {\n    this.cell.set(cell);\n    this.colspan.set(colspan);\n    this.rowspan.set(rowspan);\n  }\n\n  get width(): string | null {\n    const cell = this.cell();\n    if (isTableSubheader(cell)) return null;\n    return this._getWidth(cell.width);\n  }\n  get minWidth(): string | null {\n    const cell = this.cell();\n    if (isTableSubheader(cell)) return null;\n    return this._getWidth(cell.minWidth);\n  }\n  /**\n   * Thransforms a numeric width into a CSS string if needed. Pure function.\n   * @param width the width to be converted.\n   * @returns The width expressed as a CSS-compatible string or null.\n   */\n  private _getWidth(width: string | number | undefined): string | null {\n    if (!width) return null;\n    if (typeof width === 'number') return `${width}px`;\n    return width;\n  }\n}\n\nexport class TableItemStorage {\n  private readonly _items = signal<ArdTableRow[]>([]);\n  private readonly _sortedItems = signal<ArdTableRow[]>([]);\n\n  private readonly _dataColumns = signal<TableDataColumn[]>([]);\n  private readonly _headerCells = signal<HeaderCell[][]>([]);\n\n  constructor(private readonly _ardParentComp: TableItemStorageHost) {}\n\n  /**\n   * Gets all items.\n   */\n  readonly items = this._items.asReadonly();\n  readonly sortedItems = this._sortedItems.asReadonly();\n  /**\n   * Gets items based on the current pagination state.\n   */\n  readonly paginatedItems = computed(() => {\n    if (!this._ardParentComp.paginated() || this._ardParentComp.paginationStrategy() === TablePaginationStrategy.Noop) {\n      return this.sortedItems();\n    }\n    const page = this._ardParentComp.page();\n    const IPP = this._ardParentComp.itemsPerPage();\n    const itemsStart = (page - 1) * IPP;\n    const itemsEnd = page * IPP;\n    return this.sortedItems().slice(itemsStart, itemsEnd);\n  });\n  /**\n   * Gets all currently selected items.\n   */\n  readonly selectedItems = computed<ArdTableRow[]>(() => this.items().filter(item => item.selected()));\n  /**\n   * Gets all currently highlighted items.\n   */\n  readonly highlightedItems = computed<ArdTableRow[]>(() => this.items().filter(item => item.highlighted()));\n  /**\n   * Gets all highlightable items. An item is considered highlightable if it is **not** disabled.\n   */\n  readonly highlightableItems = computed<ArdTableRow[]>(() => this._items().filter(item => !item.disabled()));\n  /**\n   * Gets the values of the currently selected items.\n   */\n  readonly value = computed(() => this._itemsToValue(this.selectedItems()));\n  /**\n   * Maps an array of items into their values.\n   * @param items The items to convert to value.\n   * @returns An array of item values.\n   */\n  private _itemsToValue(items: ArdTableRow[]): any[] {\n    return items.map(item => item.itemData());\n  }\n\n  /**\n   * Returns true if at least one item is highlighted, otherwise false.\n   */\n  readonly isAnyItemHighlighted = computed(() => this.highlightedItems().length > 0);\n  /**\n   * Checks if any item in the table is selected.\n   * @returns A boolean value indicating if any item is selected.\n   */\n  readonly isAnyItemSelected = computed(() => this.selectedItems().length > 0);\n  /**\n   * Checks if all items in the table are selected.\n   * @returns A boolean value indicating if all items are selected.\n   */\n  readonly areAllSelected = computed(() => this.selectedItems().length === this._items().filter(item => !item.disabled()).length);\n  /**\n   * Returns true if the parent component defines the limit of concurrently selectable items and the amount of currently selected items matches that limit. Otherwise returns false.\n   *\n   * **TLDR**: true if `maxSelectedItems` is defined and the number of selected items matches that value.\n   */\n  readonly isItemLimitReached = computed(() => {\n    const max = this._ardParentComp.maxSelectedItems();\n    if (!isDefined(max)) {\n      return false;\n    }\n    return max <= this.selectedItems().length;\n  });\n\n  /**\n   * Gets the header cells of the table.\n   * @returns a 2D array of header cells.\n   */\n  readonly headerCells = this._headerCells.asReadonly();\n  /**\n   * Checks if the table has defined columns.\n   * @returns a boolean value indicating if the table has defined columns.\n   */\n  readonly hasDefinedColumns = computed(() => this._dataColumns().length > 0);\n\n  //! setting columns\n  /**\n   * Sets the columns of the table.\n   * @param cols an array of table data columns or table subheaders.\n   */\n  setColumns(cols: (TableDataColumn | TableSubheader)[]): void {\n    const maxNestingLevel = this._getHeaderMaxNesting(cols);\n    const headerCells = this._mapColumnsToArray(cols, maxNestingLevel, 0);\n    this._headerCells.set(this._filterHeaderCells(headerCells));\n    this._dataColumns.set(this._extractDataSources(cols));\n  }\n  /**\n   * Filters out null values from the header cells array. Pure function.\n   * @param cells a 2D array of header cells or null values.\n   * @returns a 2D array of header cells without null values and empty arrays.\n   */\n  private _filterHeaderCells(cells: (HeaderCell | null)[][]): HeaderCell[][] {\n    for (let i = 0; i < cells.length; i++) {\n      cells[i] = cells[i].filter(v => v !== null);\n    }\n    return cells.filter(row => row.length) as HeaderCell[][];\n  }\n  /**\n   * Extracts the data sources from the columns array. Pure function.\n   * @param cols an array of table data columns or table subheaders.\n   * @returns an array of table data columns.\n   */\n  private _extractDataSources(cols: (TableDataColumn | TableSubheader)[]): TableDataColumn[] {\n    const dataColumns: TableDataColumn[] = [];\n\n    for (const col of cols) {\n      if (!isTableSubheader(col)) {\n        dataColumns.push(col);\n        continue;\n      }\n      dataColumns.push(...this._extractDataSources(col.children));\n    }\n\n    return dataColumns;\n  }\n  /**\n   * Gets the maximum nesting level of the columns array. Pure function.\n   * @param cols an array of table data columns or table subheaders.\n   * @returns the maximum nesting level as a number.\n   */\n  private _getHeaderMaxNesting(cols: (TableDataColumn | TableSubheader)[]): number {\n    if (areAllDataColumns(cols)) return 1;\n    let max = 1;\n    for (const col of cols.filter(v => isTableSubheader(v)) as TableSubheader[]) {\n      const height = 1 + this._getHeaderMaxNesting(col.children);\n      if (height > max) max = height;\n    }\n    return max;\n  }\n  /**\n   * Maps the columns tree to a 2D array of header cells or null values. Pure function.\n   * @param cols an array of table data columns or table subheaders.\n   * @param maxNesting the maximum nesting level of the columns array.\n   * @param currentNesting the current nesting level of the columns array.\n   * @returns a 2D array of header cells or null values.\n   */\n  private _mapColumnsToArray(\n    cols: (TableDataColumn | TableSubheader)[],\n    maxNesting: number,\n    currentNesting: number\n  ): (HeaderCell | null)[][] {\n    if (areAllDataColumns(cols)) {\n      return [cols.map(col => new HeaderCell(col, 1, maxNesting - currentNesting))];\n    }\n    const headerCells: (HeaderCell | null)[][] = [[]];\n    for (const col of cols) {\n      if (!isTableSubheader(col)) {\n        headerCells[0].push(new HeaderCell(col, 1, maxNesting - currentNesting));\n        continue;\n      }\n      const childCells: (HeaderCell | null)[][] = [[], ...this._mapColumnsToArray(col.children, maxNesting, currentNesting + 1)];\n      const height = childCells.length - 1;\n      const width = childCells[1].length;\n      for (let i = 0; i < height; i++) {\n        headerCells.push([null]);\n      }\n      headerCells[0].push(new HeaderCell(col, width, 1));\n      for (let i = 0; i < width - 1; i++) {\n        headerCells[0].push(null);\n      }\n      merge2dArrays(headerCells, childCells);\n    }\n    return headerCells;\n  }\n\n  //! setting items\n  /**\n   * Sets the component's items. Takes into account the values defined by the parent component for `rowDisabledFrom`, `rowBoldFrom`, and `rowHighlightedFrom`.\n   * @param items An array of items to be set as the component's items.\n   */\n  setItems(items: any[]): void {\n    if (!this.hasDefinedColumns()) return;\n\n    const mappedItems = items.map((item, i) => this._setItemsMapFn(item, i));\n    this._items.set(mappedItems);\n    this._sortedItems.set(mappedItems);\n  }\n  /**\n   * Maps raw item data to an {@link ArdTableRow} object.\n   *\n   * @param {any} rawItemData - The raw data of the item.\n   * @param {number} index - The index of the item.\n   * @returns {ArdTableRow} Returns an ArdTableRow object with mapped properties.\n   * @private\n   */\n  private _setItemsMapFn(rawItemData: any, index: number): ArdTableRow {\n    //get data\n    const [data, dataColumns] = this._getRowData(rawItemData, index);\n\n    //get bold\n    const rowBoldFromPath = this._ardParentComp.rowBoldFrom() ?? this._ardParentComp.DEFAULTS.rowBoldFrom;\n    let bold = resolvePath(rawItemData, rowBoldFromPath);\n    if (this._ardParentComp.invertRowBold()) {\n      bold = !bold;\n    }\n\n    //get disabled\n    const disabledPath = this._ardParentComp.rowDisabledFrom() ?? this._ardParentComp.DEFAULTS.rowDisabledFrom;\n    let disabled = evaluate(resolvePath(rawItemData, disabledPath));\n    if (this._ardParentComp.invertRowDisabled()) {\n      disabled = !disabled;\n    }\n\n    return new ArdTableRow(rawItemData, index, data, dataColumns, disabled, bold);\n  }\n  /**\n   * Retrieves data for a row based on data columns configuration.\n   *\n   * @param {any} rawItemData - The raw data of the item.\n   * @param {number} index - The index of the item.\n   * @returns {any[]} Returns an array containing the row data.\n   * @private\n   */\n  private _getRowData(rawItemData: any, index: number): [any[], TableDataColumn[]] {\n    const data: any[] = [];\n    const _cols = this._dataColumns();\n    for (let i = 0; i < _cols.length; i++) {\n      const dataColumn = _cols[i];\n      const sourcePath = dataColumn.dataSource;\n\n      if (typeof sourcePath === 'string') {\n        if (this._ardParentComp.treatDataSourceAsString()) {\n          data.push(rawItemData[sourcePath]);\n          continue;\n        }\n        data.push(resolvePath(rawItemData, sourcePath));\n        continue;\n      }\n      if (sourcePath.type === 'autocount') {\n        data.push(index + 1);\n        continue;\n      }\n      if (sourcePath.type === 'checkbox') {\n        data.push({ _ardCheckbox: true, index });\n        continue;\n      }\n      const sourceString = typeof sourcePath === 'object' ? JSON.stringify(sourcePath) : sourcePath;\n      throw new Error(`ARD-FT5052: Unexpected data source \"${sourceString}\" at index ${i}.`);\n    }\n    return [data, this._dataColumns()];\n  }\n  /**\n   * Writes a new value to the item storage. Selects the correct items based on the provided values, warning the user if the value is not found.\n   * @param indexes The value of the ngModel to set.\n   */\n  writeValue(indexes: number[]): void {\n    this._forceUnselectAll();\n    this.selectItem(...indexes);\n  }\n\n  //! selecting items\n  /**\n   * Checks if an item with the given index is selected.\n   *\n   * @param {number} index The index of the item to check.\n   * @returns {boolean} _true_ if the item is selected, otherwise _false_.\n   */\n  isItemSelected(index: number): boolean {\n    return this.selectedItems().some(item => item.index() === index);\n  }\n  /**\n   * Selects all items.\n   *\n   * Accounts for the limit of concurrently selected items defined by the parent component.\n   * @returns a tuple containing two arrays:\n   * * An array of items selected.\n   * * An array of items failed to select.\n   */\n  selectAll(): [any[], any[]] {\n    return this.selectItem(...this._items().map(v => v.index()));\n  }\n  /**\n   * Unselects all selected items.\n   *\n   * If the parent component requires at least one value to be selected at all times, the first selected items is left selected.\n   * @returns An array of items cleared, mapped to only their values.\n   */\n  unselectAll(): any[] {\n    const selected = this.selectedItems();\n    for (const item of selected) {\n      item.selected.set(false);\n    }\n\n    return this._itemsToValue(selected);\n  }\n  /**\n   * Unselects all selected items, no matter what the component settings are.\n   * @returns An array of items cleared, mapped to only their values.\n   */\n  private _forceUnselectAll(): any[] {\n    const selected = this.selectedItems();\n    for (const item of selected) {\n      item.selected.set(false);\n    }\n\n    return this._itemsToValue(selected);\n  }\n  /**\n   * Selects one or multiple items.\n   *\n   * Accounts for the limit of concurrently selected items defined by the parent component.\n   *\n   * @param indexes A rest operator array of item indexes to be selected.\n   * @returns a tuple containing two arrays:\n   * - An array of items selected.\n   * - An array of items failed to select.\n   */\n  selectItem(...indexes: number[]): [any[], any[]] {\n    const itemsToBeSelected = this._items().filter(item => !item.disabled() && indexes.includes(item.index()));\n    if (this.isItemLimitReached()) {\n      return [[], this._itemsToValue(itemsToBeSelected)];\n    }\n\n    let itemsSelectedCount = 0;\n    const itemsSelected = [];\n    let itemsLeftUntilLimit = (this._ardParentComp.maxSelectedItems() ?? Infinity) - this.selectedItems().length;\n    for (const item of itemsToBeSelected) {\n      itemsSelectedCount++;\n      if (item.selected()) continue;\n      if (itemsLeftUntilLimit <= 0) {\n        break;\n      }\n      itemsLeftUntilLimit--;\n      item.selected.set(true);\n      itemsSelected.push(item);\n    }\n\n    const itemsFailedToSelect = itemsToBeSelected.slice(itemsSelectedCount - 1);\n    return [this._itemsToValue(itemsSelected), this._itemsToValue(itemsFailedToSelect)];\n  }\n  /**\n   * Unselects one or multiple items.\n   * @param items A rest operator array of item indexes to be unselected.\n   * @returns An array of items unselected, mapped to only their values.\n   */\n  unselectItem(...indexes: number[]): any[] {\n    const itemsToBeUnselected = this._items().filter(item => indexes.includes(item.index()));\n    for (const item of itemsToBeUnselected) {\n      item.selected.set(false);\n    }\n\n    return this._itemsToValue(itemsToBeUnselected);\n  }\n\n  //! highlighting items\n  /**\n   * Unhighlights all currently highlighted items.\n   */\n  unhighlightAll(): void {\n    const highlighted = this.highlightedItems();\n    for (const item of highlighted) {\n      item.highlighted.set(false);\n    }\n  }\n  /**\n   * Highlights the given item, while unhighlighting all other items. Does nothing when the item is disabled.\n   * @param item The index of the item to be highlighted.\n   * @returns The highlighted item.\n   */\n  highlightSingleItem(index: number): ArdTableRow | null {\n    this.unhighlightAll();\n    return this.highlightItem(index);\n  }\n  /**\n   * Highlights all given items.\n   * @param items A rest operator array of item indexes to be highlighted.\n   * @returns The last highlighted item.\n   */\n  highlightItem(...indexes: number[]): ArdTableRow {\n    const items = this._items().filter(item => indexes.includes(item.index()));\n    for (const item of items) {\n      item.highlighted.set(true);\n    }\n    return items.last();\n  }\n  /**\n   * Unhighlights all given items.\n   * @param items A rest operator array of item indexes to be unhighlighted.\n   */\n  unhighlightItem(...indexes: number[]): void {\n    const items = this._items().filter(item => indexes.includes(item.index()));\n    for (const item of items) {\n      if (!item || !item.highlighted()) return;\n\n      item.highlighted.set(false);\n    }\n  }\n  /**\n   * Highlights the first item out of all items.\n   * @returns The highlighted item.\n   */\n  highlightFirstItem(): ArdTableRow | null {\n    this.unhighlightAll();\n\n    const itemToHighlight = this.highlightableItems().first().index();\n    return this.highlightItem(itemToHighlight);\n  }\n  /**\n   * Highlights the last item out of all items.\n   * @returns The highlighted item.\n   */\n  highlightLastItem(): ArdTableRow | null {\n    this.unhighlightAll();\n\n    const itemToHighlight = this.highlightableItems().last().index();\n    return this.highlightItem(itemToHighlight);\n  }\n  /**\n   * Highlights all non-disabled items.\n   */\n  highlightAllItems(): void {\n    const itemsToHighlight = this.highlightableItems().map(v => v.index());\n    this.highlightItem(...itemsToHighlight);\n  }\n  /**\n   * Highlights the next non-disabled item defined by the offset amount.\n   *\n   * If `hasShift` is set to true, all originally highlighted items are kept. Otherwise, all original items are unselected.\n   * @param offset The amount of items to offset the highlight by.\n   * @param hasShift Whether the user has the shift key pressed.\n   * @returns The item highlighted.\n   */\n  highlightNextItem(offset: number, hasShift?: boolean): ArdTableRow | null {\n    if (!this.isAnyItemHighlighted()) {\n      return this.highlightFirstItem();\n    }\n    const currentItem = this.highlightedItems().last();\n    const itemsWithoutDisabled = this._items().filter(\n      item => !item.disabled() && (!this.isItemLimitReached() || item.selected())\n    );\n    const currentIndexInItems = itemsWithoutDisabled.findIndex(item => item.index() === currentItem.index());\n\n    let nextItemIndex = currentIndexInItems + offset;\n    if (nextItemIndex >= itemsWithoutDisabled.length) {\n      nextItemIndex -= itemsWithoutDisabled.length;\n    }\n    if (nextItemIndex < 0) {\n      nextItemIndex += itemsWithoutDisabled.length;\n    }\n    const itemToHighlight = itemsWithoutDisabled[nextItemIndex];\n\n    if (hasShift) {\n      if (itemToHighlight.highlighted()) {\n        this.unhighlightItem(nextItemIndex);\n      }\n      return this.highlightItem(nextItemIndex);\n    }\n    return this.highlightSingleItem(nextItemIndex);\n  }\n\n  //! sorting\n  private _currentSortColumn: number | null = null;\n  private _currentSortType: SortType | null = null;\n\n  toggleCurrentSortColumn(column: number): void {\n    if (this._currentSortColumn === column) {\n      if (this._currentSortType === SortType.Ascending) {\n        this._currentSortType = SortType.Descending;\n      } else {\n        this._currentSortType = SortType.Ascending;\n      }\n      this._generateSortedRows(true);\n      return;\n    }\n    this._currentSortColumn = column;\n    this._currentSortType = SortType.Ascending;\n    this._generateSortedRows();\n  }\n  resetSort(): void {\n    this._currentSortColumn = null;\n    this._currentSortType = null;\n    this._sortedItems.set([...this.items()]);\n  }\n  getColumnSortType(column: number): SortType | null {\n    if (this._currentSortColumn === column) {\n      return this._currentSortType;\n    }\n    return null;\n  }\n  private _generateSortedRows(justReverse?: boolean): void {\n    if (justReverse) {\n      this._sortedItems().reverse();\n      return;\n    }\n    const sortColumnIndex = this._currentSortColumn;\n    if (isNull(sortColumnIndex) || !this._currentSortType) {\n      this._sortedItems.set(this.items());\n      return;\n    }\n    const sortColumn = this._dataColumns()[sortColumnIndex];\n    if (!sortColumn) {\n      throw new Error(\n        `ARD-IS5059: Encountered an issue in <ard-table>: could not find the column with index ${sortColumnIndex}. This is most likely an Ardium UI bug, please report it to the creators.`\n      );\n    }\n\n    const direction = this._currentSortType === SortType.Ascending ? 1 : -1;\n    const sortFn =\n      sortColumn.sortFn ??\n      ((a, b) => {\n        if (a > b) return direction;\n        if (a < b) return -1 * direction;\n        return 0;\n      });\n\n    this._sortedItems.set([...this.items()].sort((a, b) => sortFn(a.data()[sortColumnIndex], b.data()[sortColumnIndex])));\n  }\n}\n"]}