@acorex/components 18.5.16 → 18.6.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (332) hide show
  1. package/action-sheet/lib/action-sheet.component.d.ts +26 -0
  2. package/alert/lib/alert.component.d.ts +50 -2
  3. package/audio-wave/lib/audio-wave.component.d.ts +53 -0
  4. package/avatar/lib/avatar.component.d.ts +20 -1
  5. package/badge/lib/badge.component.d.ts +8 -0
  6. package/bottom-navigation/lib/bottom-navigation.component.d.ts +16 -0
  7. package/breadcrumbs/lib/breadcrumbs-item.component.d.ts +11 -0
  8. package/breadcrumbs/lib/breadcrumbs.component.d.ts +11 -0
  9. package/button/lib/button-item-list.component.d.ts +34 -0
  10. package/button/lib/button-item.component.d.ts +47 -0
  11. package/button/lib/button.component.d.ts +36 -0
  12. package/button-group/lib/button-group.component.d.ts +56 -0
  13. package/calendar/lib/calendar-range.component.d.ts +48 -0
  14. package/calendar/lib/calendar.component.d.ts +114 -0
  15. package/check-box/lib/check-box.component.d.ts +36 -0
  16. package/chips/lib/chips.component.d.ts +13 -0
  17. package/circular-progress/lib/circular-progress.component.d.ts +51 -21
  18. package/collapse/lib/collapse-group.component.d.ts +38 -0
  19. package/collapse/lib/collapse.component.d.ts +55 -0
  20. package/color-box/lib/color-box.component.d.ts +28 -1
  21. package/color-palette/lib/color-palette-input.component.d.ts +35 -0
  22. package/color-palette/lib/color-palette-picker.component.d.ts +53 -0
  23. package/color-palette/lib/color-palette-preview.component.d.ts +17 -0
  24. package/color-palette/lib/color-palette-swatches.component.d.ts +30 -0
  25. package/color-palette/lib/color-palette.component.d.ts +8 -0
  26. package/comment/lib/comment-container/comment-container.component.d.ts +5 -0
  27. package/comment/lib/comment-item/comment-item.component.d.ts +16 -2
  28. package/comment/lib/comment-like/comment-like.component.d.ts +8 -0
  29. package/comment/lib/comment-reply/comment-reply.component.d.ts +4 -0
  30. package/comment/lib/comment-view/comment-view.component.d.ts +4 -0
  31. package/common/lib/components/base-component.class.d.ts +8 -0
  32. package/common/lib/components/button-base-component.class.d.ts +21 -0
  33. package/common/lib/components/interactive-component.class.d.ts +15 -0
  34. package/conversation/lib/conversation-container/conversation-container.component.d.ts +4 -0
  35. package/conversation/lib/conversation-input/conversation-input.component.d.ts +79 -2
  36. package/conversation/lib/conversation-message/conversation-message.component.d.ts +41 -0
  37. package/conversation/lib/conversation-messages/conversation-message-audio/conversation-message-audio.component.d.ts +62 -0
  38. package/conversation/lib/conversation-messages/conversation-message-file/conversation-message-file.component.d.ts +34 -0
  39. package/conversation/lib/conversation-messages/conversation-message-image/conversation-message-image.component.d.ts +21 -0
  40. package/conversation/lib/conversation-messages/conversation-message-image-popup/conversation-message-image-popup.component.d.ts +11 -0
  41. package/conversation/lib/conversation-messages/conversation-message-text/conversation-message-text.component.d.ts +29 -0
  42. package/conversation/lib/conversation-messages/conversation-message-video/conversation-message-video.component.d.ts +11 -0
  43. package/conversation/lib/conversation-messages/conversation-message-voice/conversation-message-voice.component.d.ts +72 -0
  44. package/conversation/lib/conversation-view/conversation-view.component.d.ts +22 -0
  45. package/data-pager/lib/data-pager-base.component.d.ts +9 -0
  46. package/data-pager/lib/data-pager-info.component.d.ts +14 -0
  47. package/data-pager/lib/data-pager-input-selector.component.d.ts +17 -0
  48. package/data-pager/lib/data-pager-next-buttons.components.d.ts +20 -0
  49. package/data-pager/lib/data-pager-numeric-selector.component.d.ts +14 -0
  50. package/data-pager/lib/data-pager-pagesize-dropdown.component.d.ts +28 -0
  51. package/data-pager/lib/data-pager-prev-buttons.component.d.ts +20 -0
  52. package/data-pager/lib/data-pager.component.d.ts +111 -0
  53. package/data-table/lib/columns/data-text-column.component.d.ts +58 -0
  54. package/data-table/lib/columns/row-command-column.component.d.ts +83 -0
  55. package/data-table/lib/columns/row-index-column.component.d.ts +51 -0
  56. package/data-table/lib/columns/row-select-column.component.d.ts +47 -0
  57. package/data-table/lib/data-table/data-table.component.d.ts +200 -0
  58. package/data-table/lib/infinite-scroll-data-table/infinite-scroll-data-table.component.d.ts +185 -0
  59. package/datetime-box/lib/datetime-box.component.d.ts +59 -1
  60. package/datetime-input/lib/datetime-input.component.d.ts +133 -0
  61. package/datetime-picker/lib/datetime-picker.component.d.ts +95 -0
  62. package/decorators/lib/components/clear-button.component.d.ts +25 -0
  63. package/decorators/lib/components/close-button.component.d.ts +22 -0
  64. package/decorators/lib/components/generic-content.component.d.ts +4 -0
  65. package/decorators/lib/components/icon.component.d.ts +12 -0
  66. package/dialog/lib/dialog.component.d.ts +20 -0
  67. package/drawer/lib/drawer-container.component.d.ts +7 -0
  68. package/drawer/lib/drawer.component.d.ts +104 -0
  69. package/dropdown/lib/dropdown-box.component.d.ts +66 -0
  70. package/dropdown/lib/dropdown-panel.component.d.ts +85 -0
  71. package/dropdown-button/lib/dropdown-button.component.d.ts +38 -0
  72. package/esm2022/action-sheet/lib/action-sheet.component.mjs +21 -1
  73. package/esm2022/alert/lib/alert.component.mjs +48 -3
  74. package/esm2022/audio-wave/lib/audio-wave.component.mjs +48 -1
  75. package/esm2022/avatar/lib/avatar.component.mjs +21 -2
  76. package/esm2022/badge/lib/badge.component.mjs +9 -1
  77. package/esm2022/bottom-navigation/lib/bottom-navigation.component.mjs +14 -1
  78. package/esm2022/breadcrumbs/lib/breadcrumbs-item.component.mjs +9 -1
  79. package/esm2022/breadcrumbs/lib/breadcrumbs.component.mjs +6 -1
  80. package/esm2022/button/lib/button-item-list.component.mjs +35 -1
  81. package/esm2022/button/lib/button-item.component.mjs +36 -1
  82. package/esm2022/button/lib/button.component.mjs +37 -1
  83. package/esm2022/button-group/lib/button-group.component.mjs +51 -1
  84. package/esm2022/calendar/lib/calendar-range.component.mjs +46 -1
  85. package/esm2022/calendar/lib/calendar.component.mjs +112 -1
  86. package/esm2022/check-box/lib/check-box.component.mjs +34 -1
  87. package/esm2022/chips/lib/chips.component.mjs +14 -1
  88. package/esm2022/circular-progress/lib/circular-progress.component.mjs +73 -74
  89. package/esm2022/collapse/lib/collapse-group.component.mjs +39 -1
  90. package/esm2022/collapse/lib/collapse.component.mjs +53 -1
  91. package/esm2022/color-box/lib/color-box.component.mjs +23 -2
  92. package/esm2022/color-palette/lib/color-palette-input.component.mjs +36 -1
  93. package/esm2022/color-palette/lib/color-palette-picker.component.mjs +54 -1
  94. package/esm2022/color-palette/lib/color-palette-preview.component.mjs +18 -1
  95. package/esm2022/color-palette/lib/color-palette-swatches.component.mjs +28 -1
  96. package/esm2022/color-palette/lib/color-palette.component.mjs +9 -1
  97. package/esm2022/comment/lib/comment-container/comment-container.component.mjs +6 -1
  98. package/esm2022/comment/lib/comment-item/comment-item.component.mjs +15 -1
  99. package/esm2022/comment/lib/comment-like/comment-like.component.mjs +9 -1
  100. package/esm2022/comment/lib/comment-reply/comment-reply.component.mjs +5 -1
  101. package/esm2022/comment/lib/comment-view/comment-view.component.mjs +5 -1
  102. package/esm2022/common/lib/components/base-component.class.mjs +9 -1
  103. package/esm2022/common/lib/components/button-base-component.class.mjs +22 -1
  104. package/esm2022/common/lib/components/interactive-component.class.mjs +16 -1
  105. package/esm2022/conversation/lib/conversation-container/conversation-container.component.mjs +5 -1
  106. package/esm2022/conversation/lib/conversation-input/conversation-input.component.mjs +75 -1
  107. package/esm2022/conversation/lib/conversation-message/conversation-message.component.mjs +39 -1
  108. package/esm2022/conversation/lib/conversation-messages/conversation-message-audio/conversation-message-audio.component.mjs +63 -1
  109. package/esm2022/conversation/lib/conversation-messages/conversation-message-file/conversation-message-file.component.mjs +35 -1
  110. package/esm2022/conversation/lib/conversation-messages/conversation-message-image/conversation-message-image.component.mjs +22 -1
  111. package/esm2022/conversation/lib/conversation-messages/conversation-message-image-popup/conversation-message-image-popup.component.mjs +9 -1
  112. package/esm2022/conversation/lib/conversation-messages/conversation-message-text/conversation-message-text.component.mjs +30 -1
  113. package/esm2022/conversation/lib/conversation-messages/conversation-message-video/conversation-message-video.component.mjs +12 -1
  114. package/esm2022/conversation/lib/conversation-messages/conversation-message-voice/conversation-message-voice.component.mjs +70 -1
  115. package/esm2022/conversation/lib/conversation-view/conversation-view.component.mjs +23 -1
  116. package/esm2022/data-pager/lib/data-pager-base.component.mjs +7 -1
  117. package/esm2022/data-pager/lib/data-pager-info.component.mjs +9 -1
  118. package/esm2022/data-pager/lib/data-pager-input-selector.component.mjs +18 -1
  119. package/esm2022/data-pager/lib/data-pager-next-buttons.components.mjs +18 -1
  120. package/esm2022/data-pager/lib/data-pager-numeric-selector.component.mjs +15 -1
  121. package/esm2022/data-pager/lib/data-pager-pagesize-dropdown.component.mjs +23 -1
  122. package/esm2022/data-pager/lib/data-pager-prev-buttons.component.mjs +18 -1
  123. package/esm2022/data-pager/lib/data-pager.component.mjs +109 -1
  124. package/esm2022/data-table/lib/columns/data-text-column.component.mjs +32 -1
  125. package/esm2022/data-table/lib/columns/row-command-column.component.mjs +63 -1
  126. package/esm2022/data-table/lib/columns/row-index-column.component.mjs +40 -1
  127. package/esm2022/data-table/lib/columns/row-select-column.component.mjs +39 -1
  128. package/esm2022/data-table/lib/data-table/data-table.component.mjs +183 -1
  129. package/esm2022/data-table/lib/infinite-scroll-data-table/infinite-scroll-data-table.component.mjs +159 -1
  130. package/esm2022/datetime-box/lib/datetime-box.component.mjs +51 -2
  131. package/esm2022/datetime-input/lib/datetime-input.component.mjs +122 -1
  132. package/esm2022/datetime-picker/lib/datetime-picker.component.mjs +90 -1
  133. package/esm2022/decorators/lib/components/clear-button.component.mjs +26 -1
  134. package/esm2022/decorators/lib/components/close-button.component.mjs +23 -1
  135. package/esm2022/decorators/lib/components/generic-content.component.mjs +5 -1
  136. package/esm2022/decorators/lib/components/icon.component.mjs +13 -1
  137. package/esm2022/dialog/lib/dialog.component.mjs +18 -1
  138. package/esm2022/drawer/lib/drawer-container.component.mjs +8 -1
  139. package/esm2022/drawer/lib/drawer.component.mjs +102 -1
  140. package/esm2022/dropdown/lib/dropdown-box.component.mjs +58 -1
  141. package/esm2022/dropdown/lib/dropdown-panel.component.mjs +77 -1
  142. package/esm2022/dropdown-button/lib/dropdown-button.component.mjs +36 -1
  143. package/esm2022/form/lib/form-field.component.mjs +40 -1
  144. package/esm2022/form/lib/form.component.mjs +59 -1
  145. package/esm2022/form/lib/validation-summary.component.mjs +41 -1
  146. package/esm2022/image/lib/image.component.mjs +47 -1
  147. package/esm2022/label/lib/label.component.mjs +32 -1
  148. package/esm2022/list/lib/list.component.mjs +84 -1
  149. package/esm2022/loading/lib/loading-spinner.component.mjs +17 -1
  150. package/esm2022/loading/lib/loading.component.mjs +27 -1
  151. package/esm2022/popup/lib/popup.component.mjs +2 -2
  152. package/esm2022/progress-bar/lib/progress-bar.component.mjs +1 -1
  153. package/esm2022/scheduler/lib/scheduler-month-view.component.mjs +20 -1
  154. package/esm2022/scheduler/lib/scheduler-week-view.component.mjs +5 -1
  155. package/esm2022/scheduler/lib/scheduler.component.mjs +10 -1
  156. package/esm2022/search-box/lib/search-box.component.mjs +19 -2
  157. package/esm2022/select-box/lib/select-box.component.mjs +50 -2
  158. package/esm2022/selection-list/lib/selection-list.component.mjs +51 -1
  159. package/esm2022/side-menu/lib/side-menu.component.mjs +5 -1
  160. package/esm2022/skeleton/lib/skeleton.component.mjs +11 -1
  161. package/esm2022/slider/lib/slider.component.mjs +52 -2
  162. package/esm2022/step-wizard/lib/step-wizard.component.mjs +23 -1
  163. package/esm2022/switch/lib/switch-content.component.mjs +5 -1
  164. package/esm2022/switch/lib/switch.component.mjs +11 -1
  165. package/esm2022/tabs/lib/tab-item.component.mjs +24 -1
  166. package/esm2022/tabs/lib/tabs.component.mjs +36 -1
  167. package/esm2022/tag/lib/tag.component.mjs +2 -1
  168. package/esm2022/text-area/lib/text-area.component.mjs +8 -1
  169. package/esm2022/text-box/lib/text-box.component.mjs +13 -1
  170. package/esm2022/toast/lib/toast.component.mjs +6 -1
  171. package/esm2022/tooltip/lib/tooltip.component.mjs +5 -1
  172. package/esm2022/uploader/index.mjs +5 -5
  173. package/esm2022/uploader/lib/{uploader-dialog-container.component.mjs → uploader-dialog-container/uploader-dialog-container.component.mjs} +17 -2
  174. package/esm2022/uploader/lib/uploader-drop-zone/uploader-drop-zone.component.mjs +27 -0
  175. package/esm2022/uploader/lib/uploader-list/uploader-list.component.mjs +26 -0
  176. package/esm2022/uploader/lib/uploader-zone.directive.mjs +23 -16
  177. package/esm2022/uploader/lib/uploader.models.mjs +19 -1
  178. package/esm2022/uploader/lib/uploader.module.mjs +18 -13
  179. package/esm2022/uploader/lib/uploader.service.mjs +14 -7
  180. package/esm2022/wysiwyg/lib/wysiwyg/wysiwyg-container/wysiwyg-container.component.mjs +66 -9
  181. package/esm2022/wysiwyg/lib/wysiwyg/wysiwyg-toolbar/wysiwyg-toolbar.component.mjs +105 -43
  182. package/esm2022/wysiwyg/lib/wysiwyg/wysiwyg-view/wysiwyg-view.component.mjs +9 -1
  183. package/esm2022/wysiwyg/lib/wysiwyg/wysiwyg.service.mjs +4 -1
  184. package/fesm2022/acorex-components-action-sheet.mjs +20 -0
  185. package/fesm2022/acorex-components-action-sheet.mjs.map +1 -1
  186. package/fesm2022/acorex-components-alert.mjs +47 -2
  187. package/fesm2022/acorex-components-alert.mjs.map +1 -1
  188. package/fesm2022/acorex-components-audio-wave.mjs +47 -0
  189. package/fesm2022/acorex-components-audio-wave.mjs.map +1 -1
  190. package/fesm2022/acorex-components-avatar.mjs +20 -1
  191. package/fesm2022/acorex-components-avatar.mjs.map +1 -1
  192. package/fesm2022/acorex-components-badge.mjs +8 -0
  193. package/fesm2022/acorex-components-badge.mjs.map +1 -1
  194. package/fesm2022/acorex-components-bottom-navigation.mjs +13 -0
  195. package/fesm2022/acorex-components-bottom-navigation.mjs.map +1 -1
  196. package/fesm2022/acorex-components-breadcrumbs.mjs +13 -0
  197. package/fesm2022/acorex-components-breadcrumbs.mjs.map +1 -1
  198. package/fesm2022/acorex-components-button-group.mjs +50 -0
  199. package/fesm2022/acorex-components-button-group.mjs.map +1 -1
  200. package/fesm2022/acorex-components-button.mjs +105 -0
  201. package/fesm2022/acorex-components-button.mjs.map +1 -1
  202. package/fesm2022/acorex-components-calendar.mjs +156 -0
  203. package/fesm2022/acorex-components-calendar.mjs.map +1 -1
  204. package/fesm2022/acorex-components-check-box.mjs +33 -0
  205. package/fesm2022/acorex-components-check-box.mjs.map +1 -1
  206. package/fesm2022/acorex-components-chips.mjs +13 -0
  207. package/fesm2022/acorex-components-chips.mjs.map +1 -1
  208. package/fesm2022/acorex-components-circular-progress.mjs +72 -73
  209. package/fesm2022/acorex-components-circular-progress.mjs.map +1 -1
  210. package/fesm2022/acorex-components-collapse.mjs +90 -0
  211. package/fesm2022/acorex-components-collapse.mjs.map +1 -1
  212. package/fesm2022/acorex-components-color-box.mjs +22 -1
  213. package/fesm2022/acorex-components-color-box.mjs.map +1 -1
  214. package/fesm2022/acorex-components-color-palette.mjs +140 -0
  215. package/fesm2022/acorex-components-color-palette.mjs.map +1 -1
  216. package/fesm2022/acorex-components-comment.mjs +35 -0
  217. package/fesm2022/acorex-components-comment.mjs.map +1 -1
  218. package/fesm2022/acorex-components-common.mjs +44 -0
  219. package/fesm2022/acorex-components-common.mjs.map +1 -1
  220. package/fesm2022/acorex-components-conversation.mjs +372 -0
  221. package/fesm2022/acorex-components-conversation.mjs.map +1 -1
  222. package/fesm2022/acorex-components-data-pager.mjs +209 -0
  223. package/fesm2022/acorex-components-data-pager.mjs.map +1 -1
  224. package/fesm2022/acorex-components-data-table.mjs +510 -0
  225. package/fesm2022/acorex-components-data-table.mjs.map +1 -1
  226. package/fesm2022/acorex-components-datetime-box.mjs +50 -1
  227. package/fesm2022/acorex-components-datetime-box.mjs.map +1 -1
  228. package/fesm2022/acorex-components-datetime-input.mjs +121 -0
  229. package/fesm2022/acorex-components-datetime-input.mjs.map +1 -1
  230. package/fesm2022/acorex-components-datetime-picker.mjs +89 -0
  231. package/fesm2022/acorex-components-datetime-picker.mjs.map +1 -1
  232. package/fesm2022/acorex-components-decorators.mjs +63 -0
  233. package/fesm2022/acorex-components-decorators.mjs.map +1 -1
  234. package/fesm2022/acorex-components-dialog.mjs +17 -0
  235. package/fesm2022/acorex-components-dialog.mjs.map +1 -1
  236. package/fesm2022/acorex-components-drawer.mjs +108 -0
  237. package/fesm2022/acorex-components-drawer.mjs.map +1 -1
  238. package/fesm2022/acorex-components-dropdown-button.mjs +35 -0
  239. package/fesm2022/acorex-components-dropdown-button.mjs.map +1 -1
  240. package/fesm2022/acorex-components-dropdown.mjs +133 -0
  241. package/fesm2022/acorex-components-dropdown.mjs.map +1 -1
  242. package/fesm2022/acorex-components-form.mjs +137 -0
  243. package/fesm2022/acorex-components-form.mjs.map +1 -1
  244. package/fesm2022/acorex-components-image.mjs +46 -0
  245. package/fesm2022/acorex-components-image.mjs.map +1 -1
  246. package/fesm2022/acorex-components-label.mjs +31 -0
  247. package/fesm2022/acorex-components-label.mjs.map +1 -1
  248. package/fesm2022/acorex-components-list.mjs +83 -0
  249. package/fesm2022/acorex-components-list.mjs.map +1 -1
  250. package/fesm2022/acorex-components-loading.mjs +42 -0
  251. package/fesm2022/acorex-components-loading.mjs.map +1 -1
  252. package/fesm2022/acorex-components-popup.mjs +1 -1
  253. package/fesm2022/acorex-components-popup.mjs.map +1 -1
  254. package/fesm2022/acorex-components-progress-bar.mjs.map +1 -1
  255. package/fesm2022/acorex-components-scheduler.mjs +32 -0
  256. package/fesm2022/acorex-components-scheduler.mjs.map +1 -1
  257. package/fesm2022/acorex-components-search-box.mjs +18 -1
  258. package/fesm2022/acorex-components-search-box.mjs.map +1 -1
  259. package/fesm2022/acorex-components-select-box.mjs +49 -1
  260. package/fesm2022/acorex-components-select-box.mjs.map +1 -1
  261. package/fesm2022/acorex-components-selection-list.mjs +50 -0
  262. package/fesm2022/acorex-components-selection-list.mjs.map +1 -1
  263. package/fesm2022/acorex-components-side-menu.mjs +4 -0
  264. package/fesm2022/acorex-components-side-menu.mjs.map +1 -1
  265. package/fesm2022/acorex-components-skeleton.mjs +10 -0
  266. package/fesm2022/acorex-components-skeleton.mjs.map +1 -1
  267. package/fesm2022/acorex-components-slider.mjs +51 -1
  268. package/fesm2022/acorex-components-slider.mjs.map +1 -1
  269. package/fesm2022/acorex-components-step-wizard.mjs +22 -0
  270. package/fesm2022/acorex-components-step-wizard.mjs.map +1 -1
  271. package/fesm2022/acorex-components-switch.mjs +14 -0
  272. package/fesm2022/acorex-components-switch.mjs.map +1 -1
  273. package/fesm2022/acorex-components-tabs.mjs +58 -0
  274. package/fesm2022/acorex-components-tabs.mjs.map +1 -1
  275. package/fesm2022/acorex-components-tag.mjs +1 -0
  276. package/fesm2022/acorex-components-tag.mjs.map +1 -1
  277. package/fesm2022/acorex-components-text-area.mjs +7 -0
  278. package/fesm2022/acorex-components-text-area.mjs.map +1 -1
  279. package/fesm2022/acorex-components-text-box.mjs +12 -0
  280. package/fesm2022/acorex-components-text-box.mjs.map +1 -1
  281. package/fesm2022/acorex-components-toast.mjs +5 -0
  282. package/fesm2022/acorex-components-toast.mjs.map +1 -1
  283. package/fesm2022/acorex-components-tooltip.mjs +4 -0
  284. package/fesm2022/acorex-components-tooltip.mjs.map +1 -1
  285. package/fesm2022/acorex-components-uploader.mjs +100 -32
  286. package/fesm2022/acorex-components-uploader.mjs.map +1 -1
  287. package/fesm2022/acorex-components-wysiwyg.mjs +179 -50
  288. package/fesm2022/acorex-components-wysiwyg.mjs.map +1 -1
  289. package/form/lib/form-field.component.d.ts +45 -0
  290. package/form/lib/form.component.d.ts +58 -0
  291. package/form/lib/validation-summary.component.d.ts +49 -0
  292. package/image/lib/image.component.d.ts +61 -0
  293. package/label/lib/label.component.d.ts +34 -0
  294. package/list/lib/list.component.d.ts +98 -0
  295. package/loading/lib/loading-spinner.component.d.ts +20 -0
  296. package/loading/lib/loading.component.d.ts +35 -0
  297. package/package.json +58 -58
  298. package/progress-bar/lib/progress-bar.component.d.ts +0 -1
  299. package/scheduler/lib/scheduler-month-view.component.d.ts +20 -0
  300. package/scheduler/lib/scheduler-week-view.component.d.ts +4 -0
  301. package/scheduler/lib/scheduler.component.d.ts +10 -0
  302. package/search-box/lib/search-box.component.d.ts +19 -1
  303. package/select-box/lib/select-box.component.d.ts +78 -1
  304. package/selection-list/lib/selection-list.component.d.ts +55 -0
  305. package/side-menu/lib/side-menu.component.d.ts +4 -0
  306. package/skeleton/lib/skeleton.component.d.ts +10 -0
  307. package/slider/lib/slider.component.d.ts +51 -1
  308. package/step-wizard/lib/step-wizard.component.d.ts +23 -0
  309. package/switch/lib/switch-content.component.d.ts +4 -0
  310. package/switch/lib/switch.component.d.ts +14 -0
  311. package/tabs/lib/tab-item.component.d.ts +32 -0
  312. package/tabs/lib/tabs.component.d.ts +42 -0
  313. package/tag/lib/tag.component.d.ts +4 -0
  314. package/text-area/lib/text-area.component.d.ts +13 -0
  315. package/text-box/lib/text-box.component.d.ts +27 -0
  316. package/toast/lib/toast.component.d.ts +6 -0
  317. package/tooltip/lib/tooltip.component.d.ts +13 -0
  318. package/uploader/index.d.ts +4 -4
  319. package/uploader/lib/{uploader-dialog-container.component.d.ts → uploader-dialog-container/uploader-dialog-container.component.d.ts} +15 -0
  320. package/uploader/lib/uploader-drop-zone/uploader-drop-zone.component.d.ts +12 -0
  321. package/uploader/lib/{uploader-list.component.d.ts → uploader-list/uploader-list.component.d.ts} +6 -1
  322. package/uploader/lib/uploader-zone.directive.d.ts +1 -0
  323. package/uploader/lib/uploader.models.d.ts +9 -0
  324. package/uploader/lib/uploader.module.d.ts +4 -4
  325. package/uploader/lib/uploader.service.d.ts +2 -1
  326. package/wysiwyg/lib/wysiwyg/wysiwyg-container/wysiwyg-container.component.d.ts +35 -6
  327. package/wysiwyg/lib/wysiwyg/wysiwyg-toolbar/wysiwyg-toolbar.component.d.ts +61 -21
  328. package/wysiwyg/lib/wysiwyg/wysiwyg-view/wysiwyg-view.component.d.ts +4 -0
  329. package/wysiwyg/lib/wysiwyg/wysiwyg.service.d.ts +3 -0
  330. package/esm2022/uploader/lib/uploader-drop-zone.component.mjs +0 -14
  331. package/esm2022/uploader/lib/uploader-list.component.mjs +0 -21
  332. package/uploader/lib/uploader-drop-zone.component.d.ts +0 -6
@@ -13,19 +13,51 @@ import * as i4 from "@acorex/components/skeleton";
13
13
  import * as i5 from "@acorex/components/button";
14
14
  import * as i6 from "@acorex/components/data-pager";
15
15
  import * as i7 from "@angular/cdk/drag-drop";
16
+ /**
17
+ * Component for displaying and managing a data table with advanced features.
18
+ *
19
+ * @category Components
20
+ */
16
21
  export class AXDataTableComponent extends AXBaseDataTable {
17
22
  constructor() {
18
23
  super(...arguments);
19
24
  this._unsubscriber = inject(AXUnsubscriber);
20
25
  this._zone = inject(NgZone);
26
+ /**
27
+ * @ignore
28
+ */
21
29
  this.displayedRows = signal([]);
30
+ /**
31
+ * @ignore
32
+ */
22
33
  this.page = signal(0);
34
+ /**
35
+ * @ignore
36
+ */
23
37
  this.pageSize = signal(0);
38
+ /**
39
+ * @ignore
40
+ */
24
41
  this.isLoading = signal(true);
42
+ /**
43
+ * @ignore
44
+ */
25
45
  this.columnsList = signal([]);
46
+ /**
47
+ * @ignore
48
+ */
26
49
  this.endFixedColumnsList = computed(() => this.columnsList().filter((c) => c.fixed === 'end'));
50
+ /**
51
+ * @ignore
52
+ */
27
53
  this.startFixedColumnsList = computed(() => this.columnsList().filter((c) => c.fixed === 'start'));
54
+ /**
55
+ * @ignore
56
+ */
28
57
  this.normalColumnsList = computed(() => this.columnsList().filter((c) => c.fixed !== 'end' && c.fixed !== 'start'));
58
+ /**
59
+ * @ignore
60
+ */
29
61
  this.resizeColumnProp = {
30
62
  startX: 0,
31
63
  startWidth: 0,
@@ -33,35 +65,129 @@ export class AXDataTableComponent extends AXBaseDataTable {
33
65
  newColumnWidth: 0,
34
66
  thElement: null,
35
67
  };
68
+ /**
69
+ * @ignore
70
+ */
36
71
  this.hasItems = false;
72
+ /**
73
+ * @ignore
74
+ */
37
75
  this.totalRows = 0;
76
+ /**
77
+ * @ignore
78
+ */
38
79
  this.currentPage = 0;
80
+ /**
81
+ * @ignore
82
+ */
39
83
  this.totalPages = 0;
84
+ /**
85
+ * @ignore
86
+ */
40
87
  this.startRowIndex = 0;
88
+ /**
89
+ * Defines if alternative row styling should be applied.
90
+ *
91
+ * @defaultValue `true`
92
+ */
41
93
  this.alternative = true;
94
+ /**
95
+ * Indicates if the table header should be displayed.
96
+ *
97
+ * @defaultValue `true`
98
+ */
42
99
  this.showHeader = true;
100
+ /**
101
+ * Indicates if the table header should be fixed.
102
+ *
103
+ * @defaultValue `true`
104
+ */
43
105
  this.fixedHeader = true;
106
+ /**
107
+ * Indicates if the table footer should be displayed.
108
+ *
109
+ * @defaultValue `false`
110
+ */
44
111
  this.showFooter = false;
112
+ /**
113
+ * Indicates if the table footer should be fixed.
114
+ *
115
+ * @defaultValue `true`
116
+ */
45
117
  this.fixedFooter = true;
118
+ /**
119
+ * Specifies the height of each item in the table.
120
+ *
121
+ * @defaultValue `40`
122
+ */
46
123
  this.itemHeight = 40;
124
+ /**
125
+ * Enables or disables row reordering.
126
+ *
127
+ * @defaultValue `false`
128
+ */
47
129
  this.allowReordering = false;
130
+ /**
131
+ * Enables or disables paging.
132
+ *
133
+ * @defaultValue `true`
134
+ */
48
135
  this.paging = true;
136
+ /**
137
+ * Specifies how data should be fetched.
138
+ *
139
+ * @defaultValue `'auto'`
140
+ */
49
141
  this.fetchDataMode = 'auto';
142
+ /**
143
+ * Configuration for loading state.
144
+ *
145
+ * @defaultValue `{ enabled: true, animation: true }`
146
+ */
50
147
  this.loading = {
51
148
  enabled: true,
52
149
  animation: true,
53
150
  };
151
+ /**
152
+ * Emits when the focused row changes.
153
+ *
154
+ * @event
155
+ */
54
156
  this.focusedRowChange = new EventEmitter();
157
+ /**
158
+ * Emits when a row is clicked.
159
+ *
160
+ * @event onRowClick
161
+ */
55
162
  this.onRowClick = new EventEmitter();
163
+ /**
164
+ * Emits when a row is double-clicked.
165
+ *
166
+ * @event onRowDbClick
167
+ */
56
168
  this.onRowDbClick = new EventEmitter();
169
+ /**
170
+ * Emits when the order of columns changes.
171
+ *
172
+ * @event onColumnsOrderChanged
173
+ */
57
174
  this.onColumnsOrderChanged = new EventEmitter();
175
+ /**
176
+ * @ignore
177
+ */
58
178
  this.clickSubject = new Subject();
179
+ /**
180
+ * @ignore
181
+ */
59
182
  this.onResizeColumnMove = (event) => {
60
183
  const diffX = event.pageX - this.resizeColumnProp.startX;
61
184
  const newWidth = this.rtl ? this.resizeColumnProp.startWidth - diffX : this.resizeColumnProp.startWidth + diffX;
62
185
  this.resizeColumnProp.thElement.style.width = `${Math.max(100, newWidth)}px`;
63
186
  this.resizeColumnProp.thElement.setAttribute('new-width', `${newWidth}`);
64
187
  };
188
+ /**
189
+ * @ignore
190
+ */
65
191
  this.onResizeColumnEnd = () => {
66
192
  document.removeEventListener('mousemove', this.onResizeColumnMove);
67
193
  document.removeEventListener('mouseup', this.onResizeColumnEnd);
@@ -70,13 +196,24 @@ export class AXDataTableComponent extends AXBaseDataTable {
70
196
  this.resetResizingProcess();
71
197
  };
72
198
  }
199
+ /**
200
+ * Gets the currently focused row.
201
+ */
73
202
  get focusedRow() {
74
203
  return this._focusedRow;
75
204
  }
205
+ /**
206
+ * Sets the currently focused row and emits the change event.
207
+ *
208
+ * @param v - The row to be focused.
209
+ */
76
210
  set focusedRow(v) {
77
211
  this._focusedRow = v;
78
212
  this.focusedRowChange.emit(v);
79
213
  }
214
+ /**
215
+ * @ignore
216
+ */
80
217
  ngOnInit() {
81
218
  super.ngOnInit();
82
219
  this.rtl = AXHtmlUtil.isRtl(this.getHostElement());
@@ -102,6 +239,9 @@ export class AXDataTableComponent extends AXBaseDataTable {
102
239
  this.handleRowDoubleClick(clickArray[0].event, clickArray[0].item);
103
240
  });
104
241
  }
242
+ /**
243
+ * @ignore
244
+ */
105
245
  ngAfterViewInit() {
106
246
  this.calculateStickyColumnsPositions();
107
247
  this.columnsList.set(this.columns.toArray());
@@ -109,6 +249,9 @@ export class AXDataTableComponent extends AXBaseDataTable {
109
249
  this.columnsList.set(cols.toArray());
110
250
  });
111
251
  }
252
+ /**
253
+ * @ignore
254
+ */
112
255
  drop(event) {
113
256
  const clonedColumns = [...this.columnsList()];
114
257
  moveItemInArray(clonedColumns, event.previousIndex, event.currentIndex);
@@ -119,10 +262,16 @@ export class AXDataTableComponent extends AXBaseDataTable {
119
262
  isUserInteraction: true,
120
263
  });
121
264
  }
265
+ /**
266
+ * @ignore
267
+ */
122
268
  handleRowClick(event, item) {
123
269
  this.handleRowSingleClick(event, item);
124
270
  this.clickSubject.next({ event, item });
125
271
  }
272
+ /**
273
+ * @ignore
274
+ */
126
275
  handleRowSingleClick(event, item) {
127
276
  if (this.focusedRow == item) {
128
277
  this.focusedRow = null;
@@ -137,6 +286,9 @@ export class AXDataTableComponent extends AXBaseDataTable {
137
286
  isUserInteraction: true,
138
287
  });
139
288
  }
289
+ /**
290
+ * @ignore
291
+ */
140
292
  onPageChanged(event) {
141
293
  if (event.isUserInteraction) {
142
294
  const pageChanged = event.page - 1 != this.page();
@@ -155,6 +307,9 @@ export class AXDataTableComponent extends AXBaseDataTable {
155
307
  }
156
308
  }
157
309
  }
310
+ /**
311
+ * @ignore
312
+ */
158
313
  handleRowDoubleClick(e, item) {
159
314
  this.focusedRow = item;
160
315
  //
@@ -164,6 +319,14 @@ export class AXDataTableComponent extends AXBaseDataTable {
164
319
  isUserInteraction: true,
165
320
  });
166
321
  }
322
+ /**
323
+ * Handles the click event on a column header.
324
+ * Toggles the sorting direction or removes the sort if already sorted.
325
+ *
326
+ * @param e - The mouse event triggered by the click.
327
+ * @param column - The column that was clicked.
328
+ * @ignore
329
+ */
167
330
  handleColumnClick(e, column) {
168
331
  if (column instanceof AXDataTableTextColumnComponent) {
169
332
  const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);
@@ -184,6 +347,9 @@ export class AXDataTableComponent extends AXBaseDataTable {
184
347
  this.refresh();
185
348
  }
186
349
  }
350
+ /**
351
+ * @ignore
352
+ */
187
353
  getSort(column) {
188
354
  if (column instanceof AXDataTableTextColumnComponent) {
189
355
  const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);
@@ -191,15 +357,25 @@ export class AXDataTableComponent extends AXBaseDataTable {
191
357
  }
192
358
  return undefined;
193
359
  }
360
+ /**
361
+ * Refreshes the data in the data source and resets the data pager to the first page.
362
+ * @ignore
363
+ */
194
364
  refresh() {
195
365
  this.dataSource.refresh();
196
366
  if (this.dataPager) {
197
367
  this.dataPager.goFirstPage();
198
368
  }
199
369
  }
370
+ /**
371
+ * @ignore
372
+ */
200
373
  calculateRowIndex(index) {
201
374
  return this.dataSource.pageSize * this.page() + index;
202
375
  }
376
+ /**
377
+ * @ignore
378
+ */
203
379
  onResizeColumnStart(event, columnIndex) {
204
380
  event.preventDefault();
205
381
  event.stopPropagation();
@@ -212,6 +388,9 @@ export class AXDataTableComponent extends AXBaseDataTable {
212
388
  document.addEventListener('mouseup', this.onResizeColumnEnd);
213
389
  });
214
390
  }
391
+ /**
392
+ * @ignore
393
+ */
215
394
  resetResizingProcess() {
216
395
  this.resizeColumnProp.thElement.removeAttribute('new-width');
217
396
  this.resizeColumnProp = {
@@ -222,6 +401,9 @@ export class AXDataTableComponent extends AXBaseDataTable {
222
401
  thElement: null,
223
402
  };
224
403
  }
404
+ /**
405
+ * @ignore
406
+ */
225
407
  calculateStickyColumnsPositions() {
226
408
  let totalWidth = 0;
227
409
  let accumulatedWidthFromStart = 0;
@@ -319,4 +501,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
319
501
  type: ContentChildren,
320
502
  args: [AXDataTableColumnComponent]
321
503
  }] } });
322
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../../libs/components/data-table/src/lib/data-table/data-table.component.ts","../../../../../../../libs/components/data-table/src/lib/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXDataPagerChangedEvent } from '@acorex/components/data-pager';\nimport { AXHtmlUtil, AXUnsubscriber } from '@acorex/core/utils';\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnInit,\n  Output,\n  QueryList,\n  Signal,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  WritableSignal,\n  computed,\n  inject,\n  signal,\n} from '@angular/core';\nimport { Subject, buffer, debounceTime, filter } from 'rxjs';\nimport { AXBaseDataTable, AXColumnsOrderChangedEvent, AXDataTableRowClick, AXDataTableRowDbClick } from '../base-data-table.class';\nimport { AXDataTableColumnComponent } from '../columns/data-table-column';\nimport { AXDataTableTextColumnComponent } from '../columns/data-text-column.component';\n\n@Component({\n  selector: 'ax-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: { ngSkipHydration: 'true' },\n  inputs: ['dataSource'],\n  outputs: ['selectedRowsChange'],\n  providers: [\n    {\n      provide: AXBaseDataTable,\n      useExisting: AXDataTableComponent,\n    },\n    AXUnsubscriber,\n  ],\n})\nexport class AXDataTableComponent extends AXBaseDataTable implements OnInit, AfterViewInit {\n  private _unsubscriber = inject(AXUnsubscriber);\n  private _zone = inject(NgZone);\n\n  @ViewChild('dataPager') dataPager;\n\n  protected rtl!: boolean;\n\n  protected displayedRows: WritableSignal<any[]> = signal([]);\n  protected page: WritableSignal<number> = signal(0);\n  protected pageSize: WritableSignal<number> = signal(0);\n  protected isLoading: WritableSignal<boolean> = signal(true);\n\n  protected columnsList: WritableSignal<any[]> = signal([]);\n\n  protected endFixedColumnsList: Signal<any[]> = computed(() => this.columnsList().filter((c) => c.fixed === 'end'));\n  protected startFixedColumnsList: Signal<any[]> = computed(() => this.columnsList().filter((c) => c.fixed === 'start'));\n  protected normalColumnsList: Signal<any[]> = computed(() => this.columnsList().filter((c) => c.fixed !== 'end' && c.fixed !== 'start'));\n\n  protected resizeColumnProp = {\n    startX: 0,\n    startWidth: 0,\n    columnIndex: 0,\n    newColumnWidth: 0,\n    thElement: null,\n  };\n  protected hasItems = false;\n  protected totalRows = 0;\n  protected currentPage = 0;\n  protected totalPages = 0;\n  protected startRowIndex = 0;\n\n  @Input()\n  rowTemplate?: TemplateRef<unknown>;\n\n  @Input()\n  emptyTemplate?: TemplateRef<unknown>;\n\n  @Input()\n  alternative = true;\n\n  @Input()\n  showHeader = true;\n\n  @Input()\n  fixedHeader = true;\n\n  @Input()\n  showFooter = false;\n\n  @Input()\n  fixedFooter = true;\n\n  @Input()\n  itemHeight: number | 'auto' = 40;\n\n  @Input()\n  allowReordering = false;\n\n  @Input()\n  paging = true;\n\n  @Input()\n  fetchDataMode: 'auto' | 'manual' = 'auto';\n\n  @Input()\n  loading: {\n    enabled: boolean;\n    animation: boolean;\n    loadingTemplate?: TemplateRef<unknown>;\n  } = {\n    enabled: true,\n    animation: true,\n  };\n\n  private _focusedRow: unknown;\n  @Input()\n  public get focusedRow(): unknown {\n    return this._focusedRow;\n  }\n  public set focusedRow(v: unknown) {\n    this._focusedRow = v;\n    this.focusedRowChange.emit(v);\n  }\n\n  @Output()\n  focusedRowChange: EventEmitter<unknown> = new EventEmitter<unknown>();\n\n  @Output()\n  onRowClick: EventEmitter<AXDataTableRowClick> = new EventEmitter<AXDataTableRowClick>();\n\n  @Output()\n  onRowDbClick: EventEmitter<AXDataTableRowDbClick> = new EventEmitter<AXDataTableRowDbClick>();\n\n  @Output()\n  onColumnsOrderChanged: EventEmitter<AXColumnsOrderChangedEvent> = new EventEmitter<AXColumnsOrderChangedEvent>();\n\n  private clickSubject = new Subject<{ event: MouseEvent; item: any }>();\n\n  @ContentChildren(AXDataTableColumnComponent)\n  protected columns: QueryList<AXDataTableColumnComponent>;\n\n  override ngOnInit() {\n    super.ngOnInit();\n    this.rtl = AXHtmlUtil.isRtl(this.getHostElement());\n    this.dataSource.useCache = false;\n    if (this.fetchDataMode == 'auto') {\n      this.dataSource.setPage(0);\n    }\n    this.displayedRows.set(new Array(this.dataSource.pageSize));\n    this.totalRows = this.dataSource.items.length;\n    this.dataSource.onLoadingChanged.pipe(this._unsubscriber.takeUntilDestroy).subscribe((data) => {\n      this.isLoading.set(data);\n    });\n\n    this.dataSource.onChanged.pipe(this._unsubscriber.takeUntilDestroy).subscribe((data) => {\n      this.displayedRows.set(data.items);\n      this.totalRows = data.totalCount;\n      this.hasItems = data.totalCount > 0;\n    });\n\n    this.pageSize.set(this.dataSource.pageSize);\n\n    //\n    this.clickSubject\n      .pipe(\n        buffer(this.clickSubject.pipe(debounceTime(250))),\n        filter((clickArray) => clickArray.length === 2),\n      )\n      .subscribe((clickArray) => {\n        this.handleRowDoubleClick(clickArray[0].event, clickArray[0].item);\n      });\n  }\n\n  ngAfterViewInit(): void {\n    this.calculateStickyColumnsPositions();\n    this.columnsList.set(this.columns.toArray());\n    this.columns.changes.pipe(this._unsubscriber.takeUntilDestroy).subscribe((cols) => {\n      this.columnsList.set(cols.toArray());\n    });\n  }\n\n  protected drop(event: CdkDragDrop<any, any, any>) {\n    const clonedColumns = [...this.columnsList()];\n    moveItemInArray(clonedColumns, event.previousIndex, event.currentIndex);\n    this.columnsList.set(clonedColumns);\n\n    this.onColumnsOrderChanged.emit({\n      component: this,\n      data: { event },\n      isUserInteraction: true,\n    });\n  }\n\n  protected handleRowClick(event: MouseEvent, item: unknown) {\n    this.handleRowSingleClick(event, item);\n    this.clickSubject.next({ event, item });\n  }\n\n  private handleRowSingleClick(event: Event, item: any): void {\n    if (this.focusedRow == item) {\n      this.focusedRow = null;\n    } else {\n      this.focusedRow = item;\n    }\n    //\n    this.onRowClick.emit({\n      component: this,\n      data: item,\n      isUserInteraction: true,\n    });\n  }\n\n  protected onPageChanged(event: AXDataPagerChangedEvent) {\n    if (event.isUserInteraction) {\n      const pageChanged = event.page - 1 != this.page();\n      const pageSizeChanged = event.take != this.pageSize();\n\n      if (pageChanged || pageSizeChanged) {\n        if (pageChanged) {\n          this.page.set(event.page - 1);\n          this.dataSource.setPage(this.page());\n        }\n\n        if (pageSizeChanged) {\n          this.pageSize.set(event.take);\n          this.dataSource.setPageSize(this.pageSize());\n        }\n\n        // Update displayed rows and data source\n        this.displayedRows.set(new Array(this.pageSize()));\n      }\n    }\n  }\n\n  protected handleRowDoubleClick(e: MouseEvent, item: unknown) {\n    this.focusedRow = item;\n    //\n    this.onRowDbClick.emit({\n      component: this,\n      data: item,\n      isUserInteraction: true,\n    });\n  }\n\n  handleColumnClick(e: MouseEvent, column: AXDataTableColumnComponent) {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);\n      if (!sort) {\n        this.dataSource.query.sort.push({\n          field: column.dataField,\n          dir: 'asc',\n        });\n      } else {\n        if (sort.dir == 'asc') {\n          sort.dir = 'desc';\n        } else {\n          this.dataSource.query.sort = this.dataSource.query.sort.filter((c) => c != sort);\n        }\n      }\n      this.refresh();\n    }\n  }\n\n  protected getSort(column: AXDataTableColumnComponent): string | undefined {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);\n      return sort ? (sort.dir == 'asc' ? 'ax-icon-arrow-long-down' : 'ax-icon-arrow-long-up') : undefined;\n    }\n    return undefined;\n  }\n\n  public refresh() {\n    this.dataSource.refresh();\n    if (this.dataPager) {\n      this.dataPager.goFirstPage();\n    }\n  }\n\n  protected calculateRowIndex(index: number) {\n    return this.dataSource.pageSize * this.page() + index;\n  }\n\n  protected onResizeColumnStart(event: MouseEvent, columnIndex: number): void {\n    event.preventDefault();\n    event.stopPropagation();\n\n    this.resizeColumnProp.startX = event.pageX;\n    this.resizeColumnProp.thElement = (event.target as HTMLElement).parentElement;\n    this.resizeColumnProp.startWidth = parseInt(this.resizeColumnProp.thElement.style.width);\n    this.resizeColumnProp.columnIndex = columnIndex;\n    this._zone.runOutsideAngular(() => {\n      document.addEventListener('mousemove', this.onResizeColumnMove);\n      document.addEventListener('mouseup', this.onResizeColumnEnd);\n    });\n  }\n\n  private onResizeColumnMove = (event: MouseEvent): void => {\n    const diffX = event.pageX - this.resizeColumnProp.startX;\n    const newWidth = this.rtl ? this.resizeColumnProp.startWidth - diffX : this.resizeColumnProp.startWidth + diffX;\n    this.resizeColumnProp.thElement.style.width = `${Math.max(100, newWidth)}px`;\n    this.resizeColumnProp.thElement.setAttribute('new-width', `${newWidth}`);\n  };\n\n  private onResizeColumnEnd = (): void => {\n    document.removeEventListener('mousemove', this.onResizeColumnMove);\n    document.removeEventListener('mouseup', this.onResizeColumnEnd);\n\n    const newWidth = parseInt(this.resizeColumnProp.thElement.attributes.getNamedItem('new-width').value);\n    this.columns.get(this.resizeColumnProp.columnIndex).width = `${Math.max(100, newWidth)}px`;\n    this.resetResizingProcess();\n  };\n\n  private resetResizingProcess() {\n    this.resizeColumnProp.thElement.removeAttribute('new-width');\n    this.resizeColumnProp = {\n      startX: 0,\n      startWidth: 0,\n      columnIndex: 0,\n      newColumnWidth: 0,\n      thElement: null,\n    };\n  }\n\n  private calculateStickyColumnsPositions() {\n    let totalWidth = 0;\n    let accumulatedWidthFromStart = 0;\n    this.columns.forEach((column) => {\n      const width = parseInt(column.width as string);\n      if (!isNaN(width)) {\n        totalWidth += width;\n      }\n    });\n    let lastStartColumn: AXDataTableColumnComponent;\n\n    this.columns.forEach((column) => {\n      const width = parseInt(column.width as string);\n\n      if (column.fixed === 'start' && !isNaN(width)) {\n        column['stickyStart'] = accumulatedWidthFromStart + 'px';\n        lastStartColumn = column;\n      }\n\n      if (!isNaN(width)) {\n        accumulatedWidthFromStart += width;\n      }\n    });\n    if (lastStartColumn) lastStartColumn['isLastFixedColumn'] = true;\n\n    let accumulatedWidthFromEnd = 0;\n    let firstEndColumn: AXDataTableColumnComponent;\n\n    for (let i = this.columns.length - 1; i >= 0; i--) {\n      const column = this.columns.get(i);\n\n      const width = parseInt(column.width as string);\n\n      if (column.fixed === 'end' && !isNaN(width)) {\n        column['stickyEnd'] = accumulatedWidthFromEnd + 'px';\n        firstEndColumn = column;\n      }\n\n      if (!isNaN(width)) {\n        accumulatedWidthFromEnd += width;\n      }\n    }\n    if (firstEndColumn) firstEndColumn['isFirstFixedColumn'] = true;\n  }\n}\n","<ng-content select=\"ax-header\"> </ng-content>\n@if (!displayedRows().length) {\n  <div class=\"ax-data-table-empty-data\">\n    @if (emptyTemplate) {\n      <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n    } @else {\n      <span>No Record Found!</span>\n    }\n  </div>\n}\n<div class=\"ax-data-table-wrapper\">\n  <table>\n    @if (showHeader) {\n      <thead [ngClass]=\"{ 'ax-data-table-sticky-header': fixedHeader }\">\n        <tr\n          [cdkDropListDisabled]=\"!allowReordering\"\n          cdkDropList\n          cdkScrollable\n          cdkDropListOrientation=\"horizontal\"\n          (cdkDropListDropped)=\"drop($event)\"\n        >\n          @for (c of startFixedColumnsList(); track $index) {\n            <th\n              cdkDrag\n              [cdkDragDisabled]=\"true\"\n              cdkDragLockAxis=\"x\"\n              class=\"ax-data-table-head-cell sticky-start\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isLast]=\"c['isLastFixedColumn']\"\n              [style.--sticky-start]=\"c['stickyStart']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderHeaderTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </th>\n          }\n          @for (c of normalColumnsList(); track $index) {\n            <th\n              cdkDrag\n              cdkDragLockAxis=\"x\"\n              class=\"ax-data-table-head-cell\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderHeaderTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n              @if (c.allowResizing && !c.fixed) {\n                <div class=\"ax-resize-handle\" (mousedown)=\"onResizeColumnStart($event, this.startFixedColumnsList().length + $index)\"></div>\n              }\n            </th>\n          }\n          <th></th>\n          @for (c of endFixedColumnsList(); track $index) {\n            <th\n              cdkDrag\n              [cdkDragDisabled]=\"true\"\n              cdkDragLockAxis=\"x\"\n              class=\"ax-data-table-head-cell sticky-end\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isFirst]=\"c['isFirstFixedColumn']\"\n              [style.--sticky-end]=\"c['stickyEnd']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderHeaderTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </th>\n          }\n        </tr>\n      </thead>\n    }\n    <tbody [ngClass]=\"{ 'ax-data-table-row-alternative': alternative }\">\n      @for (row of displayedRows(); let rowIndex = $index; track rowIndex) {\n        @if (rowTemplate) {\n          <ng-container *ngTemplateOutlet=\"rowTemplate; context: { $implicit: { data: row, rowIndex: rowIndex } }\"> </ng-container>\n        } @else {\n          <tr\n            [class.ax-state-focused]=\"focusedRow && row === focusedRow\"\n            [attr.data-index]=\"rowIndex\"\n            [class.ax-state-selected]=\"selectedRows.includes(row)\"\n            style.height=\"{{ itemHeight }}px\"\n            style.max-height=\"{{ itemHeight }}px\"\n            (click)=\"handleRowClick($event, row)\"\n          >\n            @for (c of startFixedColumnsList(); track $index) {\n              <td\n                [style.width]=\"c.width\"\n                [class.ax-data-table-sticky-body-cell]=\"c.fixed && c.width\"\n                [class.sticky-start]=\"true\"\n                [class.isLast]=\"c['isLastFixedColumn']\"\n                [style.--sticky-start]=\"c['stickyStart']\"\n                [attr.data-label]=\"c.caption\"\n                tabindex=\"0\"\n                [class]=\"c.cssClass\"\n              >\n                @if (row && !isLoading()) {\n                  <ng-container\n                    *ngTemplateOutlet=\"c.renderCellTemplate; context: { $implicit: { data: row, rowIndex: calculateRowIndex(rowIndex) } }\"\n                  ></ng-container>\n                } @else {\n                  @if (c.loadingEnabled && loading.enabled) {\n                    @if (loading.loadingTemplate) {\n                      <ng-container *ngTemplateOutlet=\"loading.loadingTemplate\"></ng-container>\n                    } @else {\n                      <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                    }\n                  }\n                }\n              </td>\n            }\n            @for (c of normalColumnsList(); track $index) {\n              <td\n                [style.width]=\"c.width\"\n                [class.ax-data-table-sticky-body-cell]=\"c.fixed && c.width\"\n                [attr.data-label]=\"c.caption\"\n                tabindex=\"0\"\n                [class]=\"c.cssClass\"\n              >\n                @if (row && !isLoading()) {\n                  <ng-container\n                    *ngTemplateOutlet=\"c.renderCellTemplate; context: { $implicit: { data: row, rowIndex: calculateRowIndex(rowIndex) } }\"\n                  ></ng-container>\n                } @else {\n                  @if (c.loadingEnabled && loading.enabled) {\n                    @if (loading.loadingTemplate) {\n                      <ng-container *ngTemplateOutlet=\"loading.loadingTemplate\"></ng-container>\n                    } @else {\n                      <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                    }\n                  }\n                }\n              </td>\n            }\n            <td></td>\n            @for (c of endFixedColumnsList(); track $index) {\n              <td\n                [style.width]=\"c.width\"\n                [class.ax-data-table-sticky-body-cell]=\"c.fixed && c.width\"\n                [class.sticky-end]=\"true\"\n                [class.isFirst]=\"c['isFirstFixedColumn']\"\n                [style.--sticky-end]=\"c['stickyEnd']\"\n                [attr.data-label]=\"c.caption\"\n                tabindex=\"0\"\n                [class]=\"c.cssClass\"\n              >\n                @if (row && !isLoading()) {\n                  <ng-container\n                    *ngTemplateOutlet=\"c.renderCellTemplate; context: { $implicit: { data: row, rowIndex: calculateRowIndex(rowIndex) } }\"\n                  ></ng-container>\n                } @else {\n                  @if (c.loadingEnabled && loading.enabled) {\n                    @if (loading.loadingTemplate) {\n                      <ng-container *ngTemplateOutlet=\"loading.loadingTemplate\"></ng-container>\n                    } @else {\n                      <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                    }\n                  }\n                }\n              </td>\n            }\n          </tr>\n        }\n      }\n\n      <tr class=\"empty-row\"></tr>\n    </tbody>\n    @if (showFooter) {\n      <tfoot [ngClass]=\"{ 'ax-data-table-sticky-footer': fixedFooter }\">\n        <tr>\n          @for (c of startFixedColumnsList(); track $index) {\n            <td\n              class=\"ax-data-table-sticky-footer-cell sticky-start\"\n              [class.ax-data-table-sticky-footer-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isLast]=\"c['isLastFixedColumn']\"\n              [style.--sticky-start]=\"c['stickyStart']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderFooterTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </td>\n          }\n          @for (c of normalColumnsList(); track $index) {\n            <td\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderFooterTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n              @if (c.allowResizing && !c.fixed) {\n                <div class=\"ax-resize-handle\" (mousedown)=\"onResizeColumnStart($event, this.startFixedColumnsList().length + $index)\"></div>\n              }\n            </td>\n          }\n          <td></td>\n          @for (c of endFixedColumnsList(); track $index) {\n            <td\n              class=\"ax-data-table-sticky-footer-cell sticky-end\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isFirst]=\"c['isFirstFixedColumn']\"\n              [style.--sticky-end]=\"c['stickyEnd']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderFooterTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </td>\n          }\n        </tr>\n      </tfoot>\n    }\n  </table>\n</div>\n\n@if (paging) {\n  <div class=\"ax-table-footer\" #footerContainer>\n    <ax-data-pager\n      #dataPager\n      [displayMode]=\"'custom'\"\n      (onChanged)=\"onPageChanged($event)\"\n      [total]=\"dataSource.totalCount\"\n      [size]=\"dataSource.pageSize\"\n      [isLoading]=\"isLoading()\"\n    >\n      <ax-prefix class=\"ax-data-table-numeric-paging\">\n        <ax-data-pager-numeric-selector> </ax-data-pager-numeric-selector>\n        <ax-data-pager-page-sizes> </ax-data-pager-page-sizes>\n      </ax-prefix>\n      <ax-prefix class=\"ax-data-table-input-paging\">\n        <ax-data-pager-prev-buttons> </ax-data-pager-prev-buttons>\n        <ax-data-pager-input-selector> </ax-data-pager-input-selector>\n        <ax-data-pager-next-buttons> </ax-data-pager-next-buttons>\n      </ax-prefix>\n      <ax-suffix class=\"ax-data-table-info\">\n        <ax-data-pager-info> </ax-data-pager-info>\n        <ax-button look=\"blank\" class=\"ax-sm\" (onClick)=\"refresh()\">\n          <ax-icon icon=\"ax-icon ax-icon-refresh\"></ax-icon>\n        </ax-button>\n      </ax-suffix>\n    </ax-data-pager>\n  </div>\n}\n<ng-content select=\"ax-footer\"> </ng-content>\n"]}
504
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../../libs/components/data-table/src/lib/data-table/data-table.component.ts","../../../../../../../libs/components/data-table/src/lib/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXDataPagerChangedEvent } from '@acorex/components/data-pager';\nimport { AXHtmlUtil, AXUnsubscriber } from '@acorex/core/utils';\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnInit,\n  Output,\n  QueryList,\n  Signal,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  WritableSignal,\n  computed,\n  inject,\n  signal,\n} from '@angular/core';\nimport { Subject, buffer, debounceTime, filter } from 'rxjs';\nimport { AXBaseDataTable, AXColumnsOrderChangedEvent, AXDataTableRowClick, AXDataTableRowDbClick } from '../base-data-table.class';\nimport { AXDataTableColumnComponent } from '../columns/data-table-column';\nimport { AXDataTableTextColumnComponent } from '../columns/data-text-column.component';\n\n/**\n * Component for displaying and managing a data table with advanced features.\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: { ngSkipHydration: 'true' },\n  inputs: ['dataSource'],\n  outputs: ['selectedRowsChange'],\n  providers: [\n    {\n      provide: AXBaseDataTable,\n      useExisting: AXDataTableComponent,\n    },\n    AXUnsubscriber,\n  ],\n})\nexport class AXDataTableComponent extends AXBaseDataTable implements OnInit, AfterViewInit {\n  private _unsubscriber = inject(AXUnsubscriber);\n  private _zone = inject(NgZone);\n\n  /**\n   *  @ignore\n   */\n  @ViewChild('dataPager') dataPager;\n\n  /**\n   *  @ignore\n   */\n  protected rtl!: boolean;\n\n  /**\n   *  @ignore\n   */\n  protected displayedRows: WritableSignal<any[]> = signal([]);\n\n  /**\n   *  @ignore\n   */\n  protected page: WritableSignal<number> = signal(0);\n\n  /**\n   *  @ignore\n   */\n  protected pageSize: WritableSignal<number> = signal(0);\n\n  /**\n   *  @ignore\n   */\n  protected isLoading: WritableSignal<boolean> = signal(true);\n\n  /**\n   *  @ignore\n   */\n  protected columnsList: WritableSignal<any[]> = signal([]);\n\n  /**\n   *  @ignore\n   */\n  protected endFixedColumnsList: Signal<any[]> = computed(() => this.columnsList().filter((c) => c.fixed === 'end'));\n\n  /**\n   *  @ignore\n   */\n  protected startFixedColumnsList: Signal<any[]> = computed(() => this.columnsList().filter((c) => c.fixed === 'start'));\n\n  /**\n   *  @ignore\n   */\n  protected normalColumnsList: Signal<any[]> = computed(() => this.columnsList().filter((c) => c.fixed !== 'end' && c.fixed !== 'start'));\n\n  /**\n   *  @ignore\n   */\n  protected resizeColumnProp = {\n    startX: 0,\n    startWidth: 0,\n    columnIndex: 0,\n    newColumnWidth: 0,\n    thElement: null,\n  };\n\n  /**\n   *  @ignore\n   */\n  protected hasItems = false;\n\n  /**\n   *  @ignore\n   */\n  protected totalRows = 0;\n\n  /**\n   *  @ignore\n   */\n  protected currentPage = 0;\n\n  /**\n   *  @ignore\n   */\n  protected totalPages = 0;\n\n  /**\n   *  @ignore\n   */\n  protected startRowIndex = 0;\n\n  /**\n   * Template for custom row content.\n   */\n  @Input()\n  rowTemplate?: TemplateRef<unknown>;\n\n  /**\n   * Template to display when the table is empty.\n   */\n  @Input()\n  emptyTemplate?: TemplateRef<unknown>;\n\n/**\n * Defines if alternative row styling should be applied.\n * \n * @defaultValue `true`\n */\n  @Input()\n  alternative = true;\n\n  /**\n   * Indicates if the table header should be displayed.\n   *\n   * @defaultValue `true`\n   */\n  @Input()\n  showHeader = true;\n\n  /**\n   * Indicates if the table header should be fixed.\n   *\n   * @defaultValue `true`\n   */\n  @Input()\n  fixedHeader = true;\n\n   /**\n   * Indicates if the table footer should be displayed.\n   * \n   * @defaultValue `false`\n   */\n  @Input()\n  showFooter = false;\n\n    /**\n   * Indicates if the table footer should be fixed.\n   * \n   * @defaultValue `true`\n   */\n  @Input()\n  fixedFooter = true;\n\n    /**\n   * Specifies the height of each item in the table.\n   * \n   * @defaultValue `40`\n   */\n  @Input()\n  itemHeight: number | 'auto' = 40;\n\n   /**\n   * Enables or disables row reordering.\n   * \n   * @defaultValue `false`\n   */\n  @Input()\n  allowReordering = false;\n\n    /**\n   * Enables or disables paging.\n   * \n   * @defaultValue `true`\n   */\n  @Input()\n  paging = true;\n\n    /**\n   * Specifies how data should be fetched.\n   * \n   * @defaultValue `'auto'`\n   */\n  @Input()\n  fetchDataMode: 'auto' | 'manual' = 'auto';\n\n    /**\n   * Configuration for loading state.\n   * \n   * @defaultValue `{ enabled: true, animation: true }`\n   */\n  @Input()\n  loading: {\n    enabled: boolean;\n    animation: boolean;\n    loadingTemplate?: TemplateRef<unknown>;\n  } = {\n    enabled: true,\n    animation: true,\n  };\n\n  /**\n   *  @ignore\n   */\n  private _focusedRow: unknown;\n\n  /**\n * Gets the currently focused row.\n */\n  @Input()\n  public get focusedRow(): unknown {\n    return this._focusedRow;\n  }\n\n  /**\n * Sets the currently focused row and emits the change event.\n *\n * @param v - The row to be focused.\n */\n  public set focusedRow(v: unknown) {\n    this._focusedRow = v;\n    this.focusedRowChange.emit(v);\n  }\n\n\n  /**\n * Emits when the focused row changes.\n * \n * @event \n */\n  @Output()\n  focusedRowChange: EventEmitter<unknown> = new EventEmitter<unknown>();\n\n  /**\n * Emits when a row is clicked.\n * \n * @event onRowClick\n */\n  @Output()\n  onRowClick: EventEmitter<AXDataTableRowClick> = new EventEmitter<AXDataTableRowClick>();\n\n  /**\n * Emits when a row is double-clicked.\n * \n * @event onRowDbClick\n */\n  @Output()\n  onRowDbClick: EventEmitter<AXDataTableRowDbClick> = new EventEmitter<AXDataTableRowDbClick>();\n\n  /**\n * Emits when the order of columns changes.\n * \n * @event onColumnsOrderChanged\n */\n  @Output()\n  onColumnsOrderChanged: EventEmitter<AXColumnsOrderChangedEvent> = new EventEmitter<AXColumnsOrderChangedEvent>();\n\n  /**\n   *  @ignore\n   */\n  private clickSubject = new Subject<{ event: MouseEvent; item: any }>();\n\n  /**\n   *  @ignore\n   */\n  @ContentChildren(AXDataTableColumnComponent)\n  protected columns: QueryList<AXDataTableColumnComponent>;\n\n  /**\n   *  @ignore\n   */\n  override ngOnInit() {\n    super.ngOnInit();\n    this.rtl = AXHtmlUtil.isRtl(this.getHostElement());\n    this.dataSource.useCache = false;\n    if (this.fetchDataMode == 'auto') {\n      this.dataSource.setPage(0);\n    }\n    this.displayedRows.set(new Array(this.dataSource.pageSize));\n    this.totalRows = this.dataSource.items.length;\n    this.dataSource.onLoadingChanged.pipe(this._unsubscriber.takeUntilDestroy).subscribe((data) => {\n      this.isLoading.set(data);\n    });\n\n    this.dataSource.onChanged.pipe(this._unsubscriber.takeUntilDestroy).subscribe((data) => {\n      this.displayedRows.set(data.items);\n      this.totalRows = data.totalCount;\n      this.hasItems = data.totalCount > 0;\n    });\n\n    this.pageSize.set(this.dataSource.pageSize);\n\n    //\n    this.clickSubject\n      .pipe(\n        buffer(this.clickSubject.pipe(debounceTime(250))),\n        filter((clickArray) => clickArray.length === 2),\n      )\n      .subscribe((clickArray) => {\n        this.handleRowDoubleClick(clickArray[0].event, clickArray[0].item);\n      });\n  }\n\n  /**\n   *  @ignore\n   */\n  ngAfterViewInit(): void {\n    this.calculateStickyColumnsPositions();\n    this.columnsList.set(this.columns.toArray());\n    this.columns.changes.pipe(this._unsubscriber.takeUntilDestroy).subscribe((cols) => {\n      this.columnsList.set(cols.toArray());\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  protected drop(event: CdkDragDrop<any, any, any>) {\n    const clonedColumns = [...this.columnsList()];\n    moveItemInArray(clonedColumns, event.previousIndex, event.currentIndex);\n    this.columnsList.set(clonedColumns);\n\n    this.onColumnsOrderChanged.emit({\n      component: this,\n      data: { event },\n      isUserInteraction: true,\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  protected handleRowClick(event: MouseEvent, item: unknown) {\n    this.handleRowSingleClick(event, item);\n    this.clickSubject.next({ event, item });\n  }\n\n  /**\n   *  @ignore\n   */\n  private handleRowSingleClick(event: Event, item: any): void {\n    if (this.focusedRow == item) {\n      this.focusedRow = null;\n    } else {\n      this.focusedRow = item;\n    }\n    //\n    this.onRowClick.emit({\n      component: this,\n      data: item,\n      isUserInteraction: true,\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  protected onPageChanged(event: AXDataPagerChangedEvent) {\n    if (event.isUserInteraction) {\n      const pageChanged = event.page - 1 != this.page();\n      const pageSizeChanged = event.take != this.pageSize();\n\n      if (pageChanged || pageSizeChanged) {\n        if (pageChanged) {\n          this.page.set(event.page - 1);\n          this.dataSource.setPage(this.page());\n        }\n\n        if (pageSizeChanged) {\n          this.pageSize.set(event.take);\n          this.dataSource.setPageSize(this.pageSize());\n        }\n\n        // Update displayed rows and data source\n        this.displayedRows.set(new Array(this.pageSize()));\n      }\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected handleRowDoubleClick(e: MouseEvent, item: unknown) {\n    this.focusedRow = item;\n    //\n    this.onRowDbClick.emit({\n      component: this,\n      data: item,\n      isUserInteraction: true,\n    });\n  }\n\n  /**\n * Handles the click event on a column header.\n * Toggles the sorting direction or removes the sort if already sorted.\n * \n * @param e - The mouse event triggered by the click.\n * @param column - The column that was clicked.\n * @ignore\n */\n  handleColumnClick(e: MouseEvent, column: AXDataTableColumnComponent) {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);\n      if (!sort) {\n        this.dataSource.query.sort.push({\n          field: column.dataField,\n          dir: 'asc',\n        });\n      } else {\n        if (sort.dir == 'asc') {\n          sort.dir = 'desc';\n        } else {\n          this.dataSource.query.sort = this.dataSource.query.sort.filter((c) => c != sort);\n        }\n      }\n      this.refresh();\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected getSort(column: AXDataTableColumnComponent): string | undefined {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);\n      return sort ? (sort.dir == 'asc' ? 'ax-icon-arrow-long-down' : 'ax-icon-arrow-long-up') : undefined;\n    }\n    return undefined;\n  }\n\n  /**\n * Refreshes the data in the data source and resets the data pager to the first page.\n * @ignore\n */\n  public refresh() {\n    this.dataSource.refresh();\n    if (this.dataPager) {\n      this.dataPager.goFirstPage();\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected calculateRowIndex(index: number) {\n    return this.dataSource.pageSize * this.page() + index;\n  }\n\n  /**\n   *  @ignore\n   */\n  protected onResizeColumnStart(event: MouseEvent, columnIndex: number): void {\n    event.preventDefault();\n    event.stopPropagation();\n\n    this.resizeColumnProp.startX = event.pageX;\n    this.resizeColumnProp.thElement = (event.target as HTMLElement).parentElement;\n    this.resizeColumnProp.startWidth = parseInt(this.resizeColumnProp.thElement.style.width);\n    this.resizeColumnProp.columnIndex = columnIndex;\n    this._zone.runOutsideAngular(() => {\n      document.addEventListener('mousemove', this.onResizeColumnMove);\n      document.addEventListener('mouseup', this.onResizeColumnEnd);\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  private onResizeColumnMove = (event: MouseEvent): void => {\n    const diffX = event.pageX - this.resizeColumnProp.startX;\n    const newWidth = this.rtl ? this.resizeColumnProp.startWidth - diffX : this.resizeColumnProp.startWidth + diffX;\n    this.resizeColumnProp.thElement.style.width = `${Math.max(100, newWidth)}px`;\n    this.resizeColumnProp.thElement.setAttribute('new-width', `${newWidth}`);\n  };\n\n  /**\n   *  @ignore\n   */\n  private onResizeColumnEnd = (): void => {\n    document.removeEventListener('mousemove', this.onResizeColumnMove);\n    document.removeEventListener('mouseup', this.onResizeColumnEnd);\n\n    const newWidth = parseInt(this.resizeColumnProp.thElement.attributes.getNamedItem('new-width').value);\n    this.columns.get(this.resizeColumnProp.columnIndex).width = `${Math.max(100, newWidth)}px`;\n    this.resetResizingProcess();\n  };\n\n  /**\n   *  @ignore\n   */\n  private resetResizingProcess() {\n    this.resizeColumnProp.thElement.removeAttribute('new-width');\n    this.resizeColumnProp = {\n      startX: 0,\n      startWidth: 0,\n      columnIndex: 0,\n      newColumnWidth: 0,\n      thElement: null,\n    };\n  }\n\n  /**\n   *  @ignore\n   */\n  private calculateStickyColumnsPositions() {\n    let totalWidth = 0;\n    let accumulatedWidthFromStart = 0;\n    this.columns.forEach((column) => {\n      const width = parseInt(column.width as string);\n      if (!isNaN(width)) {\n        totalWidth += width;\n      }\n    });\n    let lastStartColumn: AXDataTableColumnComponent;\n\n    this.columns.forEach((column) => {\n      const width = parseInt(column.width as string);\n\n      if (column.fixed === 'start' && !isNaN(width)) {\n        column['stickyStart'] = accumulatedWidthFromStart + 'px';\n        lastStartColumn = column;\n      }\n\n      if (!isNaN(width)) {\n        accumulatedWidthFromStart += width;\n      }\n    });\n    if (lastStartColumn) lastStartColumn['isLastFixedColumn'] = true;\n\n    let accumulatedWidthFromEnd = 0;\n    let firstEndColumn: AXDataTableColumnComponent;\n\n    for (let i = this.columns.length - 1; i >= 0; i--) {\n      const column = this.columns.get(i);\n\n      const width = parseInt(column.width as string);\n\n      if (column.fixed === 'end' && !isNaN(width)) {\n        column['stickyEnd'] = accumulatedWidthFromEnd + 'px';\n        firstEndColumn = column;\n      }\n\n      if (!isNaN(width)) {\n        accumulatedWidthFromEnd += width;\n      }\n    }\n    if (firstEndColumn) firstEndColumn['isFirstFixedColumn'] = true;\n  }\n}\n","<ng-content select=\"ax-header\"> </ng-content>\n@if (!displayedRows().length) {\n  <div class=\"ax-data-table-empty-data\">\n    @if (emptyTemplate) {\n      <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n    } @else {\n      <span>No Record Found!</span>\n    }\n  </div>\n}\n<div class=\"ax-data-table-wrapper\">\n  <table>\n    @if (showHeader) {\n      <thead [ngClass]=\"{ 'ax-data-table-sticky-header': fixedHeader }\">\n        <tr\n          [cdkDropListDisabled]=\"!allowReordering\"\n          cdkDropList\n          cdkScrollable\n          cdkDropListOrientation=\"horizontal\"\n          (cdkDropListDropped)=\"drop($event)\"\n        >\n          @for (c of startFixedColumnsList(); track $index) {\n            <th\n              cdkDrag\n              [cdkDragDisabled]=\"true\"\n              cdkDragLockAxis=\"x\"\n              class=\"ax-data-table-head-cell sticky-start\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isLast]=\"c['isLastFixedColumn']\"\n              [style.--sticky-start]=\"c['stickyStart']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderHeaderTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </th>\n          }\n          @for (c of normalColumnsList(); track $index) {\n            <th\n              cdkDrag\n              cdkDragLockAxis=\"x\"\n              class=\"ax-data-table-head-cell\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderHeaderTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n              @if (c.allowResizing && !c.fixed) {\n                <div class=\"ax-resize-handle\" (mousedown)=\"onResizeColumnStart($event, this.startFixedColumnsList().length + $index)\"></div>\n              }\n            </th>\n          }\n          <th></th>\n          @for (c of endFixedColumnsList(); track $index) {\n            <th\n              cdkDrag\n              [cdkDragDisabled]=\"true\"\n              cdkDragLockAxis=\"x\"\n              class=\"ax-data-table-head-cell sticky-end\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isFirst]=\"c['isFirstFixedColumn']\"\n              [style.--sticky-end]=\"c['stickyEnd']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderHeaderTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </th>\n          }\n        </tr>\n      </thead>\n    }\n    <tbody [ngClass]=\"{ 'ax-data-table-row-alternative': alternative }\">\n      @for (row of displayedRows(); let rowIndex = $index; track rowIndex) {\n        @if (rowTemplate) {\n          <ng-container *ngTemplateOutlet=\"rowTemplate; context: { $implicit: { data: row, rowIndex: rowIndex } }\"> </ng-container>\n        } @else {\n          <tr\n            [class.ax-state-focused]=\"focusedRow && row === focusedRow\"\n            [attr.data-index]=\"rowIndex\"\n            [class.ax-state-selected]=\"selectedRows.includes(row)\"\n            style.height=\"{{ itemHeight }}px\"\n            style.max-height=\"{{ itemHeight }}px\"\n            (click)=\"handleRowClick($event, row)\"\n          >\n            @for (c of startFixedColumnsList(); track $index) {\n              <td\n                [style.width]=\"c.width\"\n                [class.ax-data-table-sticky-body-cell]=\"c.fixed && c.width\"\n                [class.sticky-start]=\"true\"\n                [class.isLast]=\"c['isLastFixedColumn']\"\n                [style.--sticky-start]=\"c['stickyStart']\"\n                [attr.data-label]=\"c.caption\"\n                tabindex=\"0\"\n                [class]=\"c.cssClass\"\n              >\n                @if (row && !isLoading()) {\n                  <ng-container\n                    *ngTemplateOutlet=\"c.renderCellTemplate; context: { $implicit: { data: row, rowIndex: calculateRowIndex(rowIndex) } }\"\n                  ></ng-container>\n                } @else {\n                  @if (c.loadingEnabled && loading.enabled) {\n                    @if (loading.loadingTemplate) {\n                      <ng-container *ngTemplateOutlet=\"loading.loadingTemplate\"></ng-container>\n                    } @else {\n                      <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                    }\n                  }\n                }\n              </td>\n            }\n            @for (c of normalColumnsList(); track $index) {\n              <td\n                [style.width]=\"c.width\"\n                [class.ax-data-table-sticky-body-cell]=\"c.fixed && c.width\"\n                [attr.data-label]=\"c.caption\"\n                tabindex=\"0\"\n                [class]=\"c.cssClass\"\n              >\n                @if (row && !isLoading()) {\n                  <ng-container\n                    *ngTemplateOutlet=\"c.renderCellTemplate; context: { $implicit: { data: row, rowIndex: calculateRowIndex(rowIndex) } }\"\n                  ></ng-container>\n                } @else {\n                  @if (c.loadingEnabled && loading.enabled) {\n                    @if (loading.loadingTemplate) {\n                      <ng-container *ngTemplateOutlet=\"loading.loadingTemplate\"></ng-container>\n                    } @else {\n                      <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                    }\n                  }\n                }\n              </td>\n            }\n            <td></td>\n            @for (c of endFixedColumnsList(); track $index) {\n              <td\n                [style.width]=\"c.width\"\n                [class.ax-data-table-sticky-body-cell]=\"c.fixed && c.width\"\n                [class.sticky-end]=\"true\"\n                [class.isFirst]=\"c['isFirstFixedColumn']\"\n                [style.--sticky-end]=\"c['stickyEnd']\"\n                [attr.data-label]=\"c.caption\"\n                tabindex=\"0\"\n                [class]=\"c.cssClass\"\n              >\n                @if (row && !isLoading()) {\n                  <ng-container\n                    *ngTemplateOutlet=\"c.renderCellTemplate; context: { $implicit: { data: row, rowIndex: calculateRowIndex(rowIndex) } }\"\n                  ></ng-container>\n                } @else {\n                  @if (c.loadingEnabled && loading.enabled) {\n                    @if (loading.loadingTemplate) {\n                      <ng-container *ngTemplateOutlet=\"loading.loadingTemplate\"></ng-container>\n                    } @else {\n                      <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                    }\n                  }\n                }\n              </td>\n            }\n          </tr>\n        }\n      }\n\n      <tr class=\"empty-row\"></tr>\n    </tbody>\n    @if (showFooter) {\n      <tfoot [ngClass]=\"{ 'ax-data-table-sticky-footer': fixedFooter }\">\n        <tr>\n          @for (c of startFixedColumnsList(); track $index) {\n            <td\n              class=\"ax-data-table-sticky-footer-cell sticky-start\"\n              [class.ax-data-table-sticky-footer-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isLast]=\"c['isLastFixedColumn']\"\n              [style.--sticky-start]=\"c['stickyStart']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderFooterTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </td>\n          }\n          @for (c of normalColumnsList(); track $index) {\n            <td\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderFooterTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n              @if (c.allowResizing && !c.fixed) {\n                <div class=\"ax-resize-handle\" (mousedown)=\"onResizeColumnStart($event, this.startFixedColumnsList().length + $index)\"></div>\n              }\n            </td>\n          }\n          <td></td>\n          @for (c of endFixedColumnsList(); track $index) {\n            <td\n              class=\"ax-data-table-sticky-footer-cell sticky-end\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isFirst]=\"c['isFirstFixedColumn']\"\n              [style.--sticky-end]=\"c['stickyEnd']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderFooterTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </td>\n          }\n        </tr>\n      </tfoot>\n    }\n  </table>\n</div>\n\n@if (paging) {\n  <div class=\"ax-table-footer\" #footerContainer>\n    <ax-data-pager\n      #dataPager\n      [displayMode]=\"'custom'\"\n      (onChanged)=\"onPageChanged($event)\"\n      [total]=\"dataSource.totalCount\"\n      [size]=\"dataSource.pageSize\"\n      [isLoading]=\"isLoading()\"\n    >\n      <ax-prefix class=\"ax-data-table-numeric-paging\">\n        <ax-data-pager-numeric-selector> </ax-data-pager-numeric-selector>\n        <ax-data-pager-page-sizes> </ax-data-pager-page-sizes>\n      </ax-prefix>\n      <ax-prefix class=\"ax-data-table-input-paging\">\n        <ax-data-pager-prev-buttons> </ax-data-pager-prev-buttons>\n        <ax-data-pager-input-selector> </ax-data-pager-input-selector>\n        <ax-data-pager-next-buttons> </ax-data-pager-next-buttons>\n      </ax-prefix>\n      <ax-suffix class=\"ax-data-table-info\">\n        <ax-data-pager-info> </ax-data-pager-info>\n        <ax-button look=\"blank\" class=\"ax-sm\" (onClick)=\"refresh()\">\n          <ax-icon icon=\"ax-icon ax-icon-refresh\"></ax-icon>\n        </ax-button>\n      </ax-suffix>\n    </ax-data-pager>\n  </div>\n}\n<ng-content select=\"ax-footer\"> </ng-content>\n"]}