@simplysm/solid 13.0.74 → 13.0.76

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 (742) hide show
  1. package/README.md +4 -4
  2. package/dist/components/data/Pagination.d.ts +2 -2
  3. package/dist/components/data/Pagination.d.ts.map +1 -1
  4. package/dist/components/data/Pagination.js +7 -5
  5. package/dist/components/data/Pagination.js.map +2 -2
  6. package/dist/components/data/Table.d.ts +5 -1
  7. package/dist/components/data/Table.d.ts.map +1 -1
  8. package/dist/components/data/Table.js +64 -22
  9. package/dist/components/data/Table.js.map +2 -2
  10. package/dist/components/data/calendar/Calendar.d.ts.map +1 -1
  11. package/dist/components/data/calendar/Calendar.js +10 -26
  12. package/dist/components/data/calendar/Calendar.js.map +2 -2
  13. package/dist/components/data/kanban/{Kanban.css → Kanban.animate.css} +0 -2
  14. package/dist/components/data/kanban/Kanban.d.ts +46 -5
  15. package/dist/components/data/kanban/Kanban.d.ts.map +1 -1
  16. package/dist/components/data/kanban/Kanban.js +144 -119
  17. package/dist/components/data/kanban/Kanban.js.map +2 -2
  18. package/dist/components/data/list/List.d.ts.map +1 -1
  19. package/dist/components/data/list/List.js +2 -5
  20. package/dist/components/data/list/List.js.map +2 -2
  21. package/dist/components/data/list/ListItem.d.ts +7 -34
  22. package/dist/components/data/list/ListItem.d.ts.map +1 -1
  23. package/dist/components/data/list/ListItem.js +15 -20
  24. package/dist/components/data/list/ListItem.js.map +2 -2
  25. package/dist/components/data/list/ListItem.styles.d.ts +1 -1
  26. package/dist/components/data/list/ListItem.styles.d.ts.map +1 -1
  27. package/dist/components/data/list/ListItem.styles.js +8 -8
  28. package/dist/components/data/list/ListItem.styles.js.map +1 -1
  29. package/dist/components/data/sheet/DataSheet.d.ts +3 -2
  30. package/dist/components/data/sheet/DataSheet.d.ts.map +1 -1
  31. package/dist/components/data/sheet/DataSheet.js +677 -850
  32. package/dist/components/data/sheet/DataSheet.js.map +2 -2
  33. package/dist/components/data/sheet/DataSheet.styles.d.ts +2 -1
  34. package/dist/components/data/sheet/DataSheet.styles.d.ts.map +1 -1
  35. package/dist/components/data/sheet/DataSheet.styles.js +32 -10
  36. package/dist/components/data/sheet/DataSheet.styles.js.map +1 -1
  37. package/dist/components/data/sheet/DataSheetColumn.d.ts +4 -3
  38. package/dist/components/data/sheet/DataSheetColumn.d.ts.map +1 -1
  39. package/dist/components/data/sheet/DataSheetColumn.js +4 -22
  40. package/dist/components/data/sheet/DataSheetColumn.js.map +2 -2
  41. package/dist/components/data/sheet/DataSheetConfigDialog.d.ts +1 -0
  42. package/dist/components/data/sheet/DataSheetConfigDialog.d.ts.map +1 -1
  43. package/dist/components/data/sheet/DataSheetConfigDialog.js +19 -18
  44. package/dist/components/data/sheet/DataSheetConfigDialog.js.map +2 -2
  45. package/dist/components/data/sheet/hooks/useDataSheetExpansion.d.ts +17 -0
  46. package/dist/components/data/sheet/hooks/useDataSheetExpansion.d.ts.map +1 -0
  47. package/dist/components/data/sheet/hooks/useDataSheetExpansion.js +61 -0
  48. package/dist/components/data/sheet/hooks/useDataSheetExpansion.js.map +6 -0
  49. package/dist/components/data/sheet/hooks/useDataSheetFixedColumns.d.ts +29 -0
  50. package/dist/components/data/sheet/hooks/useDataSheetFixedColumns.d.ts.map +1 -0
  51. package/dist/components/data/sheet/hooks/useDataSheetFixedColumns.js +101 -0
  52. package/dist/components/data/sheet/hooks/useDataSheetFixedColumns.js.map +6 -0
  53. package/dist/components/data/sheet/hooks/useDataSheetPaging.d.ts +17 -0
  54. package/dist/components/data/sheet/hooks/useDataSheetPaging.d.ts.map +1 -0
  55. package/dist/components/data/sheet/hooks/useDataSheetPaging.js +32 -0
  56. package/dist/components/data/sheet/hooks/useDataSheetPaging.js.map +6 -0
  57. package/dist/components/data/sheet/hooks/useDataSheetReorder.d.ts +21 -0
  58. package/dist/components/data/sheet/hooks/useDataSheetReorder.d.ts.map +1 -0
  59. package/dist/components/data/sheet/hooks/useDataSheetReorder.js +112 -0
  60. package/dist/components/data/sheet/hooks/useDataSheetReorder.js.map +6 -0
  61. package/dist/components/data/sheet/hooks/useDataSheetSelection.d.ts +22 -0
  62. package/dist/components/data/sheet/hooks/useDataSheetSelection.d.ts.map +1 -0
  63. package/dist/components/data/sheet/hooks/useDataSheetSelection.js +63 -0
  64. package/dist/components/data/sheet/hooks/useDataSheetSelection.js.map +6 -0
  65. package/dist/components/data/sheet/hooks/useDataSheetSorting.d.ts +17 -0
  66. package/dist/components/data/sheet/hooks/useDataSheetSorting.d.ts.map +1 -0
  67. package/dist/components/data/sheet/hooks/useDataSheetSorting.js +45 -0
  68. package/dist/components/data/sheet/hooks/useDataSheetSorting.js.map +6 -0
  69. package/dist/components/data/sheet/sheetUtils.d.ts +2 -2
  70. package/dist/components/data/sheet/sheetUtils.d.ts.map +1 -1
  71. package/dist/components/data/sheet/sheetUtils.js +5 -5
  72. package/dist/components/data/sheet/sheetUtils.js.map +1 -1
  73. package/dist/components/data/sheet/types.d.ts +7 -8
  74. package/dist/components/data/sheet/types.d.ts.map +1 -1
  75. package/dist/components/disclosure/Collapse.d.ts.map +1 -1
  76. package/dist/components/disclosure/Collapse.js +1 -3
  77. package/dist/components/disclosure/Collapse.js.map +2 -2
  78. package/dist/components/disclosure/Dialog.d.ts +78 -20
  79. package/dist/components/disclosure/Dialog.d.ts.map +1 -1
  80. package/dist/components/disclosure/Dialog.js +251 -110
  81. package/dist/components/disclosure/Dialog.js.map +2 -2
  82. package/dist/components/disclosure/Dropdown.d.ts +6 -29
  83. package/dist/components/disclosure/Dropdown.d.ts.map +1 -1
  84. package/dist/components/disclosure/Dropdown.js +60 -61
  85. package/dist/components/disclosure/Dropdown.js.map +2 -2
  86. package/dist/components/disclosure/Tabs.d.ts +1 -1
  87. package/dist/components/disclosure/Tabs.d.ts.map +1 -1
  88. package/dist/components/disclosure/Tabs.js +16 -17
  89. package/dist/components/disclosure/Tabs.js.map +2 -2
  90. package/dist/components/display/Alert.d.ts +1 -1
  91. package/dist/components/display/Alert.d.ts.map +1 -1
  92. package/dist/components/display/Alert.js +2 -4
  93. package/dist/components/display/Alert.js.map +2 -2
  94. package/dist/components/display/Barcode.d.ts.map +1 -1
  95. package/dist/components/display/Barcode.js +1 -3
  96. package/dist/components/display/Barcode.js.map +2 -2
  97. package/dist/components/display/Card.animate.css +11 -0
  98. package/dist/components/display/Card.d.ts +1 -0
  99. package/dist/components/display/Card.d.ts.map +1 -1
  100. package/dist/components/display/Card.js +3 -2
  101. package/dist/components/display/Card.js.map +2 -2
  102. package/dist/components/display/Echarts.d.ts.map +1 -1
  103. package/dist/components/display/Echarts.js +1 -3
  104. package/dist/components/display/Echarts.js.map +2 -2
  105. package/dist/components/display/Link.d.ts +1 -1
  106. package/dist/components/display/Link.d.ts.map +1 -1
  107. package/dist/components/display/Link.js +3 -4
  108. package/dist/components/display/Link.js.map +2 -2
  109. package/dist/components/display/Tag.d.ts +1 -1
  110. package/dist/components/display/Tag.d.ts.map +1 -1
  111. package/dist/components/display/Tag.js +2 -4
  112. package/dist/components/display/Tag.js.map +2 -2
  113. package/dist/components/features/address/AddressSearch.d.ts +3 -1
  114. package/dist/components/features/address/AddressSearch.d.ts.map +1 -1
  115. package/dist/components/features/address/AddressSearch.js +3 -4
  116. package/dist/components/features/address/AddressSearch.js.map +2 -2
  117. package/dist/components/features/crud-detail/CrudDetail.d.ts.map +1 -1
  118. package/dist/components/features/crud-detail/CrudDetail.js +205 -196
  119. package/dist/components/features/crud-detail/CrudDetail.js.map +2 -2
  120. package/dist/components/features/crud-detail/CrudDetailAfter.d.ts +5 -4
  121. package/dist/components/features/crud-detail/CrudDetailAfter.d.ts.map +1 -1
  122. package/dist/components/features/crud-detail/CrudDetailAfter.js +3 -10
  123. package/dist/components/features/crud-detail/CrudDetailAfter.js.map +2 -2
  124. package/dist/components/features/crud-detail/CrudDetailBefore.d.ts +5 -4
  125. package/dist/components/features/crud-detail/CrudDetailBefore.d.ts.map +1 -1
  126. package/dist/components/features/crud-detail/CrudDetailBefore.js +3 -10
  127. package/dist/components/features/crud-detail/CrudDetailBefore.js.map +2 -2
  128. package/dist/components/features/crud-detail/CrudDetailTools.d.ts +5 -4
  129. package/dist/components/features/crud-detail/CrudDetailTools.d.ts.map +1 -1
  130. package/dist/components/features/crud-detail/CrudDetailTools.js +3 -10
  131. package/dist/components/features/crud-detail/CrudDetailTools.js.map +2 -2
  132. package/dist/components/features/crud-detail/types.d.ts +2 -12
  133. package/dist/components/features/crud-detail/types.d.ts.map +1 -1
  134. package/dist/components/features/crud-sheet/CrudSheet.d.ts +8 -1
  135. package/dist/components/features/crud-sheet/CrudSheet.d.ts.map +1 -1
  136. package/dist/components/features/crud-sheet/CrudSheet.js +94 -77
  137. package/dist/components/features/crud-sheet/CrudSheet.js.map +2 -2
  138. package/dist/components/features/crud-sheet/CrudSheetColumn.d.ts +4 -3
  139. package/dist/components/features/crud-sheet/CrudSheetColumn.d.ts.map +1 -1
  140. package/dist/components/features/crud-sheet/CrudSheetColumn.js +4 -23
  141. package/dist/components/features/crud-sheet/CrudSheetColumn.js.map +2 -2
  142. package/dist/components/features/crud-sheet/CrudSheetFilter.d.ts +7 -5
  143. package/dist/components/features/crud-sheet/CrudSheetFilter.d.ts.map +1 -1
  144. package/dist/components/features/crud-sheet/CrudSheetFilter.js +4 -8
  145. package/dist/components/features/crud-sheet/CrudSheetFilter.js.map +2 -2
  146. package/dist/components/features/crud-sheet/CrudSheetHeader.d.ts +5 -4
  147. package/dist/components/features/crud-sheet/CrudSheetHeader.d.ts.map +1 -1
  148. package/dist/components/features/crud-sheet/CrudSheetHeader.js +3 -10
  149. package/dist/components/features/crud-sheet/CrudSheetHeader.js.map +2 -2
  150. package/dist/components/features/crud-sheet/CrudSheetTools.d.ts +7 -5
  151. package/dist/components/features/crud-sheet/CrudSheetTools.d.ts.map +1 -1
  152. package/dist/components/features/crud-sheet/CrudSheetTools.js +4 -8
  153. package/dist/components/features/crud-sheet/CrudSheetTools.js.map +2 -2
  154. package/dist/components/features/crud-sheet/types.d.ts +6 -36
  155. package/dist/components/features/crud-sheet/types.d.ts.map +1 -1
  156. package/dist/components/features/data-select-button/DataSelectButton.d.ts +23 -26
  157. package/dist/components/features/data-select-button/DataSelectButton.d.ts.map +1 -1
  158. package/dist/components/features/data-select-button/DataSelectButton.js +25 -36
  159. package/dist/components/features/data-select-button/DataSelectButton.js.map +2 -2
  160. package/dist/components/features/permission-table/PermissionTable.d.ts.map +1 -1
  161. package/dist/components/features/permission-table/PermissionTable.js +9 -13
  162. package/dist/components/features/permission-table/PermissionTable.js.map +2 -2
  163. package/dist/components/features/shared-data/SharedDataSelect.d.ts +17 -12
  164. package/dist/components/features/shared-data/SharedDataSelect.d.ts.map +1 -1
  165. package/dist/components/features/shared-data/SharedDataSelect.js +57 -80
  166. package/dist/components/features/shared-data/SharedDataSelect.js.map +2 -2
  167. package/dist/components/features/shared-data/SharedDataSelectButton.d.ts +12 -9
  168. package/dist/components/features/shared-data/SharedDataSelectButton.d.ts.map +1 -1
  169. package/dist/components/features/shared-data/SharedDataSelectButton.js.map +1 -1
  170. package/dist/components/features/shared-data/SharedDataSelectList.d.ts +13 -2
  171. package/dist/components/features/shared-data/SharedDataSelectList.d.ts.map +1 -1
  172. package/dist/components/features/shared-data/SharedDataSelectList.js +131 -113
  173. package/dist/components/features/shared-data/SharedDataSelectList.js.map +2 -2
  174. package/dist/components/feedback/Progress.d.ts +3 -2
  175. package/dist/components/feedback/Progress.d.ts.map +1 -1
  176. package/dist/components/feedback/Progress.js +9 -7
  177. package/dist/components/feedback/Progress.js.map +2 -2
  178. package/dist/components/feedback/busy/BusyContainer.d.ts +2 -2
  179. package/dist/components/feedback/busy/BusyContainer.d.ts.map +1 -1
  180. package/dist/components/feedback/busy/BusyContainer.js +35 -32
  181. package/dist/components/feedback/busy/BusyContainer.js.map +2 -2
  182. package/dist/components/feedback/busy/BusyProvider.d.ts +26 -2
  183. package/dist/components/feedback/busy/BusyProvider.d.ts.map +1 -1
  184. package/dist/components/feedback/busy/BusyProvider.js +13 -7
  185. package/dist/components/feedback/busy/BusyProvider.js.map +2 -2
  186. package/dist/components/feedback/notification/NotificationBanner.d.ts.map +1 -1
  187. package/dist/components/feedback/notification/NotificationBanner.js +13 -19
  188. package/dist/components/feedback/notification/NotificationBanner.js.map +2 -2
  189. package/dist/components/feedback/notification/NotificationBell.d.ts.map +1 -1
  190. package/dist/components/feedback/notification/NotificationBell.js +69 -71
  191. package/dist/components/feedback/notification/NotificationBell.js.map +2 -2
  192. package/dist/components/feedback/notification/NotificationProvider.d.ts +68 -1
  193. package/dist/components/feedback/notification/NotificationProvider.d.ts.map +1 -1
  194. package/dist/components/feedback/notification/NotificationProvider.js +13 -4
  195. package/dist/components/feedback/notification/NotificationProvider.js.map +2 -2
  196. package/dist/components/feedback/notification/index.d.ts +0 -1
  197. package/dist/components/feedback/notification/index.d.ts.map +1 -1
  198. package/dist/components/feedback/notification/index.js +0 -1
  199. package/dist/components/feedback/notification/index.js.map +1 -1
  200. package/dist/components/feedback/print/PrintProvider.d.ts +14 -1
  201. package/dist/components/feedback/print/PrintProvider.d.ts.map +1 -1
  202. package/dist/components/feedback/print/PrintProvider.js +15 -5
  203. package/dist/components/feedback/print/PrintProvider.js.map +2 -2
  204. package/dist/components/form-control/Button.d.ts +2 -1
  205. package/dist/components/form-control/Button.d.ts.map +1 -1
  206. package/dist/components/form-control/Button.js +9 -8
  207. package/dist/components/form-control/Button.js.map +2 -2
  208. package/dist/components/form-control/DropdownTrigger.styles.d.ts +1 -1
  209. package/dist/components/form-control/DropdownTrigger.styles.d.ts.map +1 -1
  210. package/dist/components/form-control/DropdownTrigger.styles.js +16 -16
  211. package/dist/components/form-control/DropdownTrigger.styles.js.map +1 -1
  212. package/dist/components/form-control/ThemeToggle.d.ts +2 -1
  213. package/dist/components/form-control/ThemeToggle.d.ts.map +1 -1
  214. package/dist/components/form-control/ThemeToggle.js +71 -74
  215. package/dist/components/form-control/ThemeToggle.js.map +2 -2
  216. package/dist/components/form-control/checkbox/Checkbox.d.ts +1 -1
  217. package/dist/components/form-control/checkbox/Checkbox.d.ts.map +1 -1
  218. package/dist/components/form-control/checkbox/Checkbox.js +14 -95
  219. package/dist/components/form-control/checkbox/Checkbox.js.map +2 -2
  220. package/dist/components/form-control/checkbox/Checkbox.styles.d.ts +2 -2
  221. package/dist/components/form-control/checkbox/Checkbox.styles.d.ts.map +1 -1
  222. package/dist/components/form-control/checkbox/Checkbox.styles.js +20 -25
  223. package/dist/components/form-control/checkbox/Checkbox.styles.js.map +1 -1
  224. package/dist/components/form-control/checkbox/CheckboxGroup.d.ts.map +1 -1
  225. package/dist/components/form-control/checkbox/CheckboxGroup.js +84 -9
  226. package/dist/components/form-control/checkbox/CheckboxGroup.js.map +2 -2
  227. package/dist/components/form-control/checkbox/Radio.d.ts +1 -1
  228. package/dist/components/form-control/checkbox/Radio.d.ts.map +1 -1
  229. package/dist/components/form-control/checkbox/Radio.js +12 -95
  230. package/dist/components/form-control/checkbox/Radio.js.map +2 -2
  231. package/dist/components/form-control/checkbox/RadioGroup.d.ts.map +1 -1
  232. package/dist/components/form-control/checkbox/RadioGroup.js +81 -9
  233. package/dist/components/form-control/checkbox/RadioGroup.js.map +2 -2
  234. package/dist/components/form-control/checkbox/SelectableBase.d.ts +26 -0
  235. package/dist/components/form-control/checkbox/SelectableBase.d.ts.map +1 -0
  236. package/dist/components/form-control/checkbox/SelectableBase.js +100 -0
  237. package/dist/components/form-control/checkbox/SelectableBase.js.map +6 -0
  238. package/dist/components/form-control/checkbox/SelectionGroupBase.d.ts +17 -0
  239. package/dist/components/form-control/checkbox/SelectionGroupBase.d.ts.map +1 -0
  240. package/dist/components/form-control/checkbox/SelectionGroupBase.js +53 -0
  241. package/dist/components/form-control/checkbox/SelectionGroupBase.js.map +6 -0
  242. package/dist/components/form-control/color-picker/ColorPicker.d.ts +1 -1
  243. package/dist/components/form-control/color-picker/ColorPicker.d.ts.map +1 -1
  244. package/dist/components/form-control/color-picker/ColorPicker.js +3 -15
  245. package/dist/components/form-control/color-picker/ColorPicker.js.map +2 -2
  246. package/dist/components/form-control/combobox/Combobox.d.ts +26 -47
  247. package/dist/components/form-control/combobox/Combobox.d.ts.map +1 -1
  248. package/dist/components/form-control/combobox/Combobox.js +107 -59
  249. package/dist/components/form-control/combobox/Combobox.js.map +2 -2
  250. package/dist/components/form-control/date-range-picker/DateRangePicker.d.ts.map +1 -1
  251. package/dist/components/form-control/date-range-picker/DateRangePicker.js +12 -5
  252. package/dist/components/form-control/date-range-picker/DateRangePicker.js.map +2 -2
  253. package/dist/components/form-control/editor/EditorToolbar.d.ts.map +1 -1
  254. package/dist/components/form-control/editor/EditorToolbar.js +358 -211
  255. package/dist/components/form-control/editor/EditorToolbar.js.map +2 -2
  256. package/dist/components/form-control/editor/RichTextEditor.d.ts +1 -1
  257. package/dist/components/form-control/editor/RichTextEditor.d.ts.map +1 -1
  258. package/dist/components/form-control/editor/RichTextEditor.js +10 -10
  259. package/dist/components/form-control/editor/RichTextEditor.js.map +2 -2
  260. package/{src/components/form-control/editor/editor.css → dist/components/form-control/editor/RichTextEditor.tiptap.css} +0 -1
  261. package/dist/components/form-control/field/DatePicker.d.ts +1 -1
  262. package/dist/components/form-control/field/DatePicker.d.ts.map +1 -1
  263. package/dist/components/form-control/field/DatePicker.js +48 -129
  264. package/dist/components/form-control/field/DatePicker.js.map +2 -2
  265. package/dist/components/form-control/field/DateTimePicker.d.ts +1 -1
  266. package/dist/components/form-control/field/DateTimePicker.d.ts.map +1 -1
  267. package/dist/components/form-control/field/DateTimePicker.js +48 -129
  268. package/dist/components/form-control/field/DateTimePicker.js.map +2 -2
  269. package/dist/components/form-control/field/Field.styles.d.ts +3 -3
  270. package/dist/components/form-control/field/Field.styles.d.ts.map +1 -1
  271. package/dist/components/form-control/field/Field.styles.js +46 -40
  272. package/dist/components/form-control/field/Field.styles.js.map +1 -1
  273. package/dist/components/form-control/field/FieldPlaceholder.js +4 -3
  274. package/dist/components/form-control/field/FieldPlaceholder.js.map +2 -2
  275. package/dist/components/form-control/field/FieldShell.d.ts +37 -0
  276. package/dist/components/form-control/field/FieldShell.d.ts.map +1 -0
  277. package/dist/components/form-control/field/FieldShell.js +124 -0
  278. package/dist/components/form-control/field/FieldShell.js.map +6 -0
  279. package/dist/components/form-control/field/NumberInput.d.ts +8 -6
  280. package/dist/components/form-control/field/NumberInput.d.ts.map +1 -1
  281. package/dist/components/form-control/field/NumberInput.js +86 -192
  282. package/dist/components/form-control/field/NumberInput.js.map +2 -2
  283. package/dist/components/form-control/field/TextInput.d.ts +7 -6
  284. package/dist/components/form-control/field/TextInput.d.ts.map +1 -1
  285. package/dist/components/form-control/field/TextInput.js +82 -193
  286. package/dist/components/form-control/field/TextInput.js.map +2 -2
  287. package/dist/components/form-control/field/Textarea.d.ts +1 -1
  288. package/dist/components/form-control/field/Textarea.d.ts.map +1 -1
  289. package/dist/components/form-control/field/Textarea.js +79 -154
  290. package/dist/components/form-control/field/Textarea.js.map +2 -2
  291. package/dist/components/form-control/field/TimePicker.d.ts +1 -1
  292. package/dist/components/form-control/field/TimePicker.d.ts.map +1 -1
  293. package/dist/components/form-control/field/TimePicker.js +44 -121
  294. package/dist/components/form-control/field/TimePicker.js.map +2 -2
  295. package/dist/components/form-control/numpad/Numpad.d.ts +1 -1
  296. package/dist/components/form-control/numpad/Numpad.d.ts.map +1 -1
  297. package/dist/components/form-control/numpad/Numpad.js +5 -5
  298. package/dist/components/form-control/numpad/Numpad.js.map +2 -2
  299. package/dist/components/form-control/select/Select.d.ts +54 -35
  300. package/dist/components/form-control/select/Select.d.ts.map +1 -1
  301. package/dist/components/form-control/select/Select.js +215 -114
  302. package/dist/components/form-control/select/Select.js.map +2 -2
  303. package/dist/components/form-control/state-preset/StatePreset.d.ts +2 -2
  304. package/dist/components/form-control/state-preset/StatePreset.d.ts.map +1 -1
  305. package/dist/components/form-control/state-preset/StatePreset.js +63 -52
  306. package/dist/components/form-control/state-preset/StatePreset.js.map +2 -2
  307. package/dist/components/layout/FormGroup.d.ts +3 -6
  308. package/dist/components/layout/FormGroup.d.ts.map +1 -1
  309. package/dist/components/layout/FormGroup.js +5 -7
  310. package/dist/components/layout/FormGroup.js.map +2 -2
  311. package/dist/components/layout/FormTable.d.ts +7 -1
  312. package/dist/components/layout/FormTable.d.ts.map +1 -1
  313. package/dist/components/layout/FormTable.js +52 -18
  314. package/dist/components/layout/FormTable.js.map +2 -2
  315. package/dist/components/layout/sidebar/Sidebar.d.ts +136 -8
  316. package/dist/components/layout/sidebar/Sidebar.d.ts.map +1 -1
  317. package/dist/components/layout/sidebar/Sidebar.js +341 -21
  318. package/dist/components/layout/sidebar/Sidebar.js.map +2 -2
  319. package/dist/components/layout/topbar/Topbar.d.ts +44 -33
  320. package/dist/components/layout/topbar/Topbar.d.ts.map +1 -1
  321. package/dist/components/layout/topbar/Topbar.js +426 -39
  322. package/dist/components/layout/topbar/Topbar.js.map +2 -2
  323. package/dist/helpers/createAppStructure.d.ts.map +1 -1
  324. package/dist/helpers/createAppStructure.js +4 -5
  325. package/dist/helpers/createAppStructure.js.map +1 -1
  326. package/dist/helpers/createSlot.d.ts +3 -0
  327. package/dist/helpers/createSlot.d.ts.map +1 -0
  328. package/dist/helpers/createSlot.js +40 -0
  329. package/dist/helpers/createSlot.js.map +6 -0
  330. package/dist/helpers/createSlots.d.ts +7 -0
  331. package/dist/helpers/createSlots.d.ts.map +1 -0
  332. package/dist/helpers/createSlots.js +34 -0
  333. package/dist/helpers/createSlots.js.map +6 -0
  334. package/dist/hooks/createControllableSignal.d.ts +4 -12
  335. package/dist/hooks/createControllableSignal.d.ts.map +1 -1
  336. package/dist/hooks/createControllableSignal.js +4 -3
  337. package/dist/hooks/createControllableSignal.js.map +1 -1
  338. package/dist/hooks/createControllableStore.d.ts.map +1 -1
  339. package/dist/hooks/createControllableStore.js +3 -4
  340. package/dist/hooks/createControllableStore.js.map +1 -1
  341. package/dist/hooks/useLogger.d.ts +1 -1
  342. package/dist/hooks/useLogger.d.ts.map +1 -1
  343. package/dist/hooks/useLogger.js +1 -1
  344. package/dist/hooks/useSyncConfig.js +1 -1
  345. package/dist/index.d.ts +13 -20
  346. package/dist/index.d.ts.map +1 -1
  347. package/dist/index.js +13 -20
  348. package/dist/index.js.map +1 -1
  349. package/dist/providers/ConfigContext.d.ts.map +1 -1
  350. package/dist/providers/ConfigContext.js +10 -13
  351. package/dist/providers/ConfigContext.js.map +1 -1
  352. package/dist/providers/{LoggerContext.d.ts → LoggerProvider.d.ts} +1 -1
  353. package/dist/providers/LoggerProvider.d.ts.map +1 -0
  354. package/dist/providers/{LoggerContext.js → LoggerProvider.js} +1 -1
  355. package/dist/providers/{LoggerContext.js.map → LoggerProvider.js.map} +1 -1
  356. package/dist/providers/PwaUpdateProvider.js +1 -1
  357. package/dist/providers/ServiceClientProvider.d.ts +22 -0
  358. package/dist/providers/ServiceClientProvider.d.ts.map +1 -1
  359. package/dist/providers/ServiceClientProvider.js +39 -48
  360. package/dist/providers/ServiceClientProvider.js.map +2 -2
  361. package/dist/providers/{SyncStorageContext.d.ts → SyncStorageProvider.d.ts} +1 -1
  362. package/dist/providers/SyncStorageProvider.d.ts.map +1 -0
  363. package/dist/providers/{SyncStorageContext.js → SyncStorageProvider.js} +1 -1
  364. package/dist/providers/{SyncStorageContext.js.map → SyncStorageProvider.js.map} +1 -1
  365. package/dist/providers/SystemProvider.d.ts +1 -1
  366. package/dist/providers/SystemProvider.d.ts.map +1 -1
  367. package/dist/providers/SystemProvider.js +3 -3
  368. package/dist/providers/SystemProvider.js.map +1 -1
  369. package/dist/providers/i18n/{I18nContext.d.ts → I18nProvider.d.ts} +2 -2
  370. package/dist/providers/i18n/I18nProvider.d.ts.map +1 -0
  371. package/dist/providers/i18n/{I18nContext.js → I18nProvider.js} +1 -1
  372. package/dist/providers/i18n/{I18nContext.js.map → I18nProvider.js.map} +1 -1
  373. package/dist/providers/i18n/{I18nContext.types.d.ts → I18nProvider.types.d.ts} +1 -1
  374. package/dist/providers/i18n/I18nProvider.types.d.ts.map +1 -0
  375. package/dist/providers/i18n/I18nProvider.types.js +1 -0
  376. package/dist/providers/shared-data/SharedDataProvider.d.ts +74 -1
  377. package/dist/providers/shared-data/SharedDataProvider.d.ts.map +1 -1
  378. package/dist/providers/shared-data/SharedDataProvider.js +15 -7
  379. package/dist/providers/shared-data/SharedDataProvider.js.map +2 -2
  380. package/dist/styles/base.styles.d.ts +15 -0
  381. package/dist/styles/base.styles.d.ts.map +1 -0
  382. package/dist/styles/base.styles.js +21 -0
  383. package/dist/styles/base.styles.js.map +6 -0
  384. package/dist/styles/control.styles.d.ts +19 -0
  385. package/dist/styles/control.styles.d.ts.map +1 -0
  386. package/dist/styles/control.styles.js +24 -0
  387. package/dist/styles/control.styles.js.map +6 -0
  388. package/dist/styles/theme.styles.d.ts +52 -0
  389. package/dist/styles/theme.styles.d.ts.map +1 -0
  390. package/dist/styles/theme.styles.js +55 -0
  391. package/dist/styles/theme.styles.js.map +6 -0
  392. package/package.json +5 -5
  393. package/src/components/data/Pagination.tsx +9 -9
  394. package/src/components/data/Table.tsx +63 -30
  395. package/src/components/data/calendar/Calendar.tsx +38 -36
  396. package/src/components/data/kanban/{Kanban.css → Kanban.animate.css} +0 -2
  397. package/src/components/data/kanban/Kanban.tsx +118 -84
  398. package/src/components/data/list/List.tsx +5 -16
  399. package/src/components/data/list/ListItem.styles.ts +8 -8
  400. package/src/components/data/list/ListItem.tsx +20 -31
  401. package/src/components/data/sheet/DataSheet.styles.ts +32 -9
  402. package/src/components/data/sheet/DataSheet.tsx +159 -440
  403. package/src/components/data/sheet/DataSheetColumn.tsx +7 -29
  404. package/src/components/data/sheet/DataSheetConfigDialog.tsx +14 -20
  405. package/src/components/data/sheet/hooks/useDataSheetExpansion.ts +85 -0
  406. package/src/components/data/sheet/hooks/useDataSheetFixedColumns.ts +131 -0
  407. package/src/components/data/sheet/hooks/useDataSheetPaging.ts +51 -0
  408. package/src/components/data/sheet/hooks/useDataSheetReorder.ts +155 -0
  409. package/src/components/data/sheet/hooks/useDataSheetSelection.ts +99 -0
  410. package/src/components/data/sheet/hooks/useDataSheetSorting.ts +68 -0
  411. package/src/components/data/sheet/sheetUtils.ts +5 -5
  412. package/src/components/data/sheet/types.ts +7 -8
  413. package/src/components/disclosure/Collapse.tsx +1 -9
  414. package/src/components/disclosure/Dialog.tsx +242 -41
  415. package/src/components/disclosure/Dropdown.tsx +66 -75
  416. package/src/components/disclosure/Tabs.tsx +23 -32
  417. package/src/components/display/Alert.tsx +2 -5
  418. package/src/components/display/Barcode.tsx +1 -4
  419. package/src/components/display/Card.animate.css +11 -0
  420. package/src/components/display/Card.tsx +10 -11
  421. package/src/components/display/Echarts.tsx +1 -4
  422. package/src/components/display/Link.tsx +3 -5
  423. package/src/components/display/Tag.tsx +2 -5
  424. package/src/components/features/address/AddressSearch.tsx +4 -5
  425. package/src/components/features/crud-detail/CrudDetail.tsx +129 -142
  426. package/src/components/features/crud-detail/CrudDetailAfter.tsx +3 -16
  427. package/src/components/features/crud-detail/CrudDetailBefore.tsx +3 -16
  428. package/src/components/features/crud-detail/CrudDetailTools.tsx +3 -16
  429. package/src/components/features/crud-detail/types.ts +3 -16
  430. package/src/components/features/crud-sheet/CrudSheet.tsx +90 -92
  431. package/src/components/features/crud-sheet/CrudSheetColumn.tsx +7 -30
  432. package/src/components/features/crud-sheet/CrudSheetFilter.tsx +12 -16
  433. package/src/components/features/crud-sheet/CrudSheetHeader.tsx +3 -16
  434. package/src/components/features/crud-sheet/CrudSheetTools.tsx +12 -16
  435. package/src/components/features/crud-sheet/types.ts +6 -40
  436. package/src/components/features/data-select-button/DataSelectButton.tsx +55 -64
  437. package/src/components/features/permission-table/PermissionTable.tsx +9 -13
  438. package/src/components/features/shared-data/SharedDataSelect.tsx +89 -108
  439. package/src/components/features/shared-data/SharedDataSelectButton.tsx +26 -15
  440. package/src/components/features/shared-data/SharedDataSelectList.tsx +55 -32
  441. package/src/components/feedback/Progress.tsx +16 -21
  442. package/src/components/feedback/busy/BusyContainer.tsx +18 -45
  443. package/src/components/feedback/busy/BusyProvider.tsx +40 -7
  444. package/src/components/feedback/notification/NotificationBanner.tsx +13 -32
  445. package/src/components/feedback/notification/NotificationBell.tsx +18 -47
  446. package/src/components/feedback/notification/NotificationProvider.tsx +96 -10
  447. package/src/components/feedback/notification/index.ts +0 -1
  448. package/src/components/feedback/print/PrintProvider.tsx +35 -4
  449. package/src/components/form-control/Button.tsx +11 -29
  450. package/src/components/form-control/DropdownTrigger.styles.ts +16 -17
  451. package/src/components/form-control/ThemeToggle.tsx +18 -15
  452. package/src/components/form-control/checkbox/Checkbox.styles.ts +20 -26
  453. package/src/components/form-control/checkbox/Checkbox.tsx +14 -100
  454. package/src/components/form-control/checkbox/CheckboxGroup.tsx +85 -10
  455. package/src/components/form-control/checkbox/Radio.tsx +14 -103
  456. package/src/components/form-control/checkbox/RadioGroup.tsx +82 -10
  457. package/src/components/form-control/checkbox/SelectableBase.tsx +123 -0
  458. package/src/components/form-control/checkbox/SelectionGroupBase.tsx +57 -0
  459. package/src/components/form-control/color-picker/ColorPicker.tsx +8 -28
  460. package/src/components/form-control/combobox/Combobox.tsx +124 -30
  461. package/src/components/form-control/date-range-picker/DateRangePicker.tsx +5 -5
  462. package/src/components/form-control/editor/EditorToolbar.tsx +105 -82
  463. package/{dist/components/form-control/editor/editor.css → src/components/form-control/editor/RichTextEditor.tiptap.css} +0 -1
  464. package/src/components/form-control/editor/RichTextEditor.tsx +14 -29
  465. package/src/components/form-control/field/DatePicker.tsx +30 -72
  466. package/src/components/form-control/field/DateTimePicker.tsx +31 -79
  467. package/src/components/form-control/field/Field.styles.ts +48 -42
  468. package/src/components/form-control/field/FieldPlaceholder.tsx +2 -2
  469. package/src/components/form-control/field/FieldShell.tsx +113 -0
  470. package/src/components/form-control/field/NumberInput.tsx +67 -126
  471. package/src/components/form-control/field/TextInput.tsx +51 -109
  472. package/src/components/form-control/field/Textarea.tsx +64 -108
  473. package/src/components/form-control/field/TimePicker.tsx +29 -70
  474. package/src/components/form-control/numpad/Numpad.tsx +5 -6
  475. package/src/components/form-control/select/Select.tsx +243 -119
  476. package/src/components/form-control/state-preset/StatePreset.tsx +60 -83
  477. package/src/components/layout/FormGroup.tsx +10 -13
  478. package/src/components/layout/FormTable.tsx +40 -19
  479. package/src/components/layout/sidebar/Sidebar.tsx +456 -38
  480. package/src/components/layout/topbar/Topbar.tsx +420 -49
  481. package/src/helpers/createAppStructure.ts +6 -7
  482. package/src/helpers/createSlot.ts +45 -0
  483. package/src/helpers/createSlots.ts +44 -0
  484. package/src/hooks/createControllableSignal.ts +10 -18
  485. package/src/hooks/createControllableStore.ts +3 -4
  486. package/src/hooks/useLogger.ts +1 -1
  487. package/src/hooks/useSyncConfig.ts +1 -1
  488. package/src/index.ts +14 -20
  489. package/src/providers/ConfigContext.tsx +0 -1
  490. package/src/providers/PwaUpdateProvider.tsx +1 -1
  491. package/src/providers/ServiceClientProvider.tsx +59 -53
  492. package/src/providers/SystemProvider.tsx +4 -5
  493. package/src/providers/i18n/{I18nContext.tsx → I18nProvider.tsx} +1 -1
  494. package/src/providers/shared-data/SharedDataProvider.tsx +95 -14
  495. package/src/styles/base.styles.ts +21 -0
  496. package/src/styles/control.styles.ts +25 -0
  497. package/src/styles/theme.styles.ts +54 -0
  498. package/tailwind.config.ts +0 -11
  499. package/tests/components/data/List.spec.tsx +1 -262
  500. package/tests/components/data/Pagination.spec.tsx +0 -75
  501. package/tests/components/data/kanban/Kanban.selection.spec.tsx +1 -17
  502. package/tests/components/data/sheet/DataSheet.spec.tsx +36 -65
  503. package/tests/components/data/sheet/hooks/useDataSheetExpansion.spec.ts +254 -0
  504. package/tests/components/data/sheet/hooks/useDataSheetFixedColumns.spec.ts +488 -0
  505. package/tests/components/data/sheet/hooks/useDataSheetPaging.spec.ts +359 -0
  506. package/tests/components/data/sheet/hooks/useDataSheetReorder.spec.ts +251 -0
  507. package/tests/components/data/sheet/hooks/useDataSheetSelection.spec.ts +345 -0
  508. package/tests/components/data/sheet/hooks/useDataSheetSorting.spec.ts +279 -0
  509. package/tests/components/disclosure/Collapse.spec.tsx +0 -24
  510. package/tests/components/disclosure/Dialog.spec.tsx +4 -54
  511. package/tests/components/disclosure/DialogProvider.spec.tsx +9 -12
  512. package/tests/components/disclosure/Tabs.spec.tsx +0 -99
  513. package/tests/components/display/Barcode.spec.tsx +0 -14
  514. package/tests/components/features/address/AddressSearch.spec.tsx +3 -4
  515. package/tests/components/features/crud-detail/CrudDetail.spec.tsx +12 -74
  516. package/tests/components/features/crud-sheet/CrudSheet.spec.tsx +13 -66
  517. package/tests/components/features/data-select-button/DataSelectButton.spec.tsx +51 -29
  518. package/tests/components/features/permission-table/PermissionTable.spec.tsx +5 -30
  519. package/tests/components/features/shared-data/SharedDataSelect.spec.tsx +15 -19
  520. package/tests/components/features/shared-data/SharedDataSelectList.spec.tsx +17 -44
  521. package/tests/components/feedback/busy/BusyContainer.spec.tsx +15 -9
  522. package/tests/components/feedback/notification/LiveRegion.spec.tsx +2 -27
  523. package/tests/components/feedback/notification/NotificationBanner.spec.tsx +2 -27
  524. package/tests/components/feedback/notification/NotificationBell.spec.tsx +2 -16
  525. package/tests/components/feedback/notification/NotificationContext.spec.tsx +2 -16
  526. package/tests/components/form-control/Button.spec.tsx +0 -97
  527. package/tests/components/form-control/Invalid.spec.tsx +0 -15
  528. package/tests/components/form-control/checkbox/Checkbox.spec.tsx +1 -47
  529. package/tests/components/form-control/checkbox/CheckboxGroup.spec.tsx +1 -26
  530. package/tests/components/form-control/checkbox/Radio.spec.tsx +1 -46
  531. package/tests/components/form-control/checkbox/RadioGroup.spec.tsx +1 -26
  532. package/tests/components/form-control/color-picker/ColorPicker.spec.tsx +1 -31
  533. package/tests/components/form-control/combobox/Combobox.spec.tsx +5 -49
  534. package/tests/components/form-control/combobox/ComboboxItem.spec.tsx +7 -27
  535. package/tests/components/form-control/date-range-picker/DateRangePicker.spec.tsx +1 -58
  536. package/tests/components/form-control/field/DatePicker.spec.tsx +5 -93
  537. package/tests/components/form-control/field/DateTimePicker.spec.tsx +5 -86
  538. package/tests/components/form-control/field/FieldShell.spec.tsx +127 -0
  539. package/tests/components/form-control/field/NumberInput.spec.tsx +14 -133
  540. package/tests/components/form-control/field/TextInput.spec.tsx +6 -148
  541. package/tests/components/form-control/field/Textarea.spec.tsx +5 -69
  542. package/tests/components/form-control/field/TimePicker.spec.tsx +5 -84
  543. package/tests/components/form-control/numpad/Numpad.spec.tsx +1 -78
  544. package/tests/components/form-control/select/Select.spec.tsx +9 -59
  545. package/tests/components/form-control/select/SelectItem.spec.tsx +10 -62
  546. package/tests/components/layout/sidebar/Sidebar.spec.tsx +3 -122
  547. package/tests/components/layout/sidebar/SidebarContainer.spec.tsx +3 -45
  548. package/tests/components/layout/sidebar/SidebarMenu.spec.tsx +1 -74
  549. package/tests/components/layout/sidebar/SidebarUser.spec.tsx +0 -48
  550. package/tests/components/layout/topbar/TopbarActions.spec.tsx +1 -1
  551. package/tests/components/layout/topbar/createTopbarActions.spec.tsx +0 -9
  552. package/tests/helpers/createAppStructure.spec.tsx +0 -26
  553. package/tests/helpers/createSlot.spec.tsx +99 -0
  554. package/tests/helpers/createSlots.spec.tsx +100 -0
  555. package/tests/hooks/createControllableSignal.spec.ts +0 -50
  556. package/tests/hooks/createControllableStore.spec.ts +67 -0
  557. package/tests/hooks/createMountTransition.spec.ts +0 -9
  558. package/tests/hooks/useLocalStorage.spec.tsx +0 -34
  559. package/tests/hooks/useLogger.spec.tsx +1 -18
  560. package/tests/hooks/usePrint.spec.tsx +1 -24
  561. package/tests/hooks/useSyncConfig.spec.tsx +1 -18
  562. package/tests/providers/ErrorLoggerProvider.spec.tsx +1 -11
  563. package/tests/providers/ServiceClientContext.spec.tsx +2 -20
  564. package/tests/providers/i18n/I18nContext.spec.tsx +1 -5
  565. package/tests/providers/shared-data/SharedDataProvider.spec.tsx +13 -13
  566. package/dist/components/data/kanban/KanbanContext.d.ts +0 -43
  567. package/dist/components/data/kanban/KanbanContext.d.ts.map +0 -1
  568. package/dist/components/data/kanban/KanbanContext.js +0 -24
  569. package/dist/components/data/kanban/KanbanContext.js.map +0 -6
  570. package/dist/components/data/sheet/DataSheet.css +0 -44
  571. package/dist/components/disclosure/DialogContext.d.ts +0 -57
  572. package/dist/components/disclosure/DialogContext.d.ts.map +0 -1
  573. package/dist/components/disclosure/DialogContext.js +0 -14
  574. package/dist/components/disclosure/DialogContext.js.map +0 -6
  575. package/dist/components/disclosure/DialogInstanceContext.d.ts +0 -20
  576. package/dist/components/disclosure/DialogInstanceContext.d.ts.map +0 -1
  577. package/dist/components/disclosure/DialogInstanceContext.js +0 -10
  578. package/dist/components/disclosure/DialogInstanceContext.js.map +0 -6
  579. package/dist/components/disclosure/DialogProvider.d.ts +0 -19
  580. package/dist/components/disclosure/DialogProvider.d.ts.map +0 -1
  581. package/dist/components/disclosure/DialogProvider.js +0 -145
  582. package/dist/components/disclosure/DialogProvider.js.map +0 -6
  583. package/dist/components/features/shared-data/SharedDataSelectListContext.d.ts +0 -15
  584. package/dist/components/features/shared-data/SharedDataSelectListContext.d.ts.map +0 -1
  585. package/dist/components/features/shared-data/SharedDataSelectListContext.js +0 -27
  586. package/dist/components/features/shared-data/SharedDataSelectListContext.js.map +0 -6
  587. package/dist/components/feedback/busy/BusyContext.d.ts +0 -29
  588. package/dist/components/feedback/busy/BusyContext.d.ts.map +0 -1
  589. package/dist/components/feedback/busy/BusyContext.js +0 -14
  590. package/dist/components/feedback/busy/BusyContext.js.map +0 -6
  591. package/dist/components/feedback/notification/NotificationContext.d.ts +0 -69
  592. package/dist/components/feedback/notification/NotificationContext.d.ts.map +0 -1
  593. package/dist/components/feedback/notification/NotificationContext.js +0 -14
  594. package/dist/components/feedback/notification/NotificationContext.js.map +0 -6
  595. package/dist/components/feedback/print/PrintContext.d.ts +0 -12
  596. package/dist/components/feedback/print/PrintContext.d.ts.map +0 -1
  597. package/dist/components/feedback/print/PrintContext.js +0 -12
  598. package/dist/components/feedback/print/PrintContext.js.map +0 -6
  599. package/dist/components/feedback/print/PrintInstanceContext.d.ts +0 -6
  600. package/dist/components/feedback/print/PrintInstanceContext.d.ts.map +0 -1
  601. package/dist/components/feedback/print/PrintInstanceContext.js +0 -10
  602. package/dist/components/feedback/print/PrintInstanceContext.js.map +0 -6
  603. package/dist/components/form-control/combobox/ComboboxContext.d.ts +0 -14
  604. package/dist/components/form-control/combobox/ComboboxContext.d.ts.map +0 -1
  605. package/dist/components/form-control/combobox/ComboboxContext.js +0 -14
  606. package/dist/components/form-control/combobox/ComboboxContext.js.map +0 -6
  607. package/dist/components/form-control/combobox/ComboboxItem.d.ts +0 -12
  608. package/dist/components/form-control/combobox/ComboboxItem.d.ts.map +0 -1
  609. package/dist/components/form-control/combobox/ComboboxItem.js +0 -56
  610. package/dist/components/form-control/combobox/ComboboxItem.js.map +0 -6
  611. package/dist/components/form-control/select/SelectContext.d.ts +0 -21
  612. package/dist/components/form-control/select/SelectContext.d.ts.map +0 -1
  613. package/dist/components/form-control/select/SelectContext.js +0 -14
  614. package/dist/components/form-control/select/SelectContext.js.map +0 -6
  615. package/dist/components/form-control/select/SelectItem.d.ts +0 -30
  616. package/dist/components/form-control/select/SelectItem.d.ts.map +0 -1
  617. package/dist/components/form-control/select/SelectItem.js +0 -112
  618. package/dist/components/form-control/select/SelectItem.js.map +0 -6
  619. package/dist/components/layout/sidebar/SidebarContainer.d.ts +0 -34
  620. package/dist/components/layout/sidebar/SidebarContainer.d.ts.map +0 -1
  621. package/dist/components/layout/sidebar/SidebarContainer.js +0 -88
  622. package/dist/components/layout/sidebar/SidebarContainer.js.map +0 -6
  623. package/dist/components/layout/sidebar/SidebarContext.d.ts +0 -28
  624. package/dist/components/layout/sidebar/SidebarContext.d.ts.map +0 -1
  625. package/dist/components/layout/sidebar/SidebarContext.js +0 -20
  626. package/dist/components/layout/sidebar/SidebarContext.js.map +0 -6
  627. package/dist/components/layout/sidebar/SidebarMenu.d.ts +0 -35
  628. package/dist/components/layout/sidebar/SidebarMenu.d.ts.map +0 -1
  629. package/dist/components/layout/sidebar/SidebarMenu.js +0 -153
  630. package/dist/components/layout/sidebar/SidebarMenu.js.map +0 -6
  631. package/dist/components/layout/sidebar/SidebarUser.d.ts +0 -48
  632. package/dist/components/layout/sidebar/SidebarUser.d.ts.map +0 -1
  633. package/dist/components/layout/sidebar/SidebarUser.js +0 -128
  634. package/dist/components/layout/sidebar/SidebarUser.js.map +0 -6
  635. package/dist/components/layout/topbar/TopbarActions.d.ts +0 -3
  636. package/dist/components/layout/topbar/TopbarActions.d.ts.map +0 -1
  637. package/dist/components/layout/topbar/TopbarActions.js +0 -17
  638. package/dist/components/layout/topbar/TopbarActions.js.map +0 -6
  639. package/dist/components/layout/topbar/TopbarContainer.d.ts +0 -25
  640. package/dist/components/layout/topbar/TopbarContainer.d.ts.map +0 -1
  641. package/dist/components/layout/topbar/TopbarContainer.js +0 -37
  642. package/dist/components/layout/topbar/TopbarContainer.js.map +0 -6
  643. package/dist/components/layout/topbar/TopbarContext.d.ts +0 -9
  644. package/dist/components/layout/topbar/TopbarContext.d.ts.map +0 -1
  645. package/dist/components/layout/topbar/TopbarContext.js +0 -29
  646. package/dist/components/layout/topbar/TopbarContext.js.map +0 -6
  647. package/dist/components/layout/topbar/TopbarMenu.d.ts +0 -41
  648. package/dist/components/layout/topbar/TopbarMenu.d.ts.map +0 -1
  649. package/dist/components/layout/topbar/TopbarMenu.js +0 -288
  650. package/dist/components/layout/topbar/TopbarMenu.js.map +0 -6
  651. package/dist/components/layout/topbar/TopbarUser.d.ts +0 -35
  652. package/dist/components/layout/topbar/TopbarUser.d.ts.map +0 -1
  653. package/dist/components/layout/topbar/TopbarUser.js +0 -110
  654. package/dist/components/layout/topbar/TopbarUser.js.map +0 -6
  655. package/dist/helpers/createHmrSafeContext.d.ts +0 -3
  656. package/dist/helpers/createHmrSafeContext.d.ts.map +0 -1
  657. package/dist/helpers/createHmrSafeContext.js +0 -10
  658. package/dist/helpers/createHmrSafeContext.js.map +0 -6
  659. package/dist/helpers/createSlotComponent.d.ts +0 -12
  660. package/dist/helpers/createSlotComponent.d.ts.map +0 -1
  661. package/dist/helpers/createSlotComponent.js +0 -13
  662. package/dist/helpers/createSlotComponent.js.map +0 -6
  663. package/dist/hooks/createSelectionGroup.d.ts +0 -70
  664. package/dist/hooks/createSelectionGroup.d.ts.map +0 -1
  665. package/dist/hooks/createSelectionGroup.js +0 -145
  666. package/dist/hooks/createSelectionGroup.js.map +0 -6
  667. package/dist/hooks/createSlotSignal.d.ts +0 -9
  668. package/dist/hooks/createSlotSignal.d.ts.map +0 -1
  669. package/dist/hooks/createSlotSignal.js +0 -10
  670. package/dist/hooks/createSlotSignal.js.map +0 -6
  671. package/dist/providers/LoggerContext.d.ts.map +0 -1
  672. package/dist/providers/ServiceClientContext.d.ts +0 -23
  673. package/dist/providers/ServiceClientContext.d.ts.map +0 -1
  674. package/dist/providers/ServiceClientContext.js +0 -14
  675. package/dist/providers/ServiceClientContext.js.map +0 -6
  676. package/dist/providers/SyncStorageContext.d.ts.map +0 -1
  677. package/dist/providers/i18n/I18nContext.d.ts.map +0 -1
  678. package/dist/providers/i18n/I18nContext.types.d.ts.map +0 -1
  679. package/dist/providers/i18n/I18nContext.types.js +0 -1
  680. package/dist/providers/shared-data/SharedDataContext.d.ts +0 -77
  681. package/dist/providers/shared-data/SharedDataContext.d.ts.map +0 -1
  682. package/dist/providers/shared-data/SharedDataContext.js +0 -14
  683. package/dist/providers/shared-data/SharedDataContext.js.map +0 -6
  684. package/dist/styles/patterns.styles.d.ts +0 -7
  685. package/dist/styles/patterns.styles.d.ts.map +0 -1
  686. package/dist/styles/patterns.styles.js +0 -47
  687. package/dist/styles/patterns.styles.js.map +0 -6
  688. package/dist/styles/tokens.styles.d.ts +0 -23
  689. package/dist/styles/tokens.styles.d.ts.map +0 -1
  690. package/dist/styles/tokens.styles.js +0 -76
  691. package/dist/styles/tokens.styles.js.map +0 -6
  692. package/src/components/data/kanban/KanbanContext.ts +0 -76
  693. package/src/components/data/sheet/DataSheet.css +0 -44
  694. package/src/components/disclosure/DialogContext.ts +0 -69
  695. package/src/components/disclosure/DialogInstanceContext.ts +0 -25
  696. package/src/components/disclosure/DialogProvider.tsx +0 -147
  697. package/src/components/features/shared-data/SharedDataSelectListContext.ts +0 -39
  698. package/src/components/feedback/busy/BusyContext.ts +0 -38
  699. package/src/components/feedback/notification/NotificationContext.ts +0 -95
  700. package/src/components/feedback/print/PrintContext.ts +0 -20
  701. package/src/components/feedback/print/PrintInstanceContext.ts +0 -11
  702. package/src/components/form-control/combobox/ComboboxContext.ts +0 -25
  703. package/src/components/form-control/combobox/ComboboxItem.tsx +0 -69
  704. package/src/components/form-control/select/SelectContext.ts +0 -35
  705. package/src/components/form-control/select/SelectItem.tsx +0 -128
  706. package/src/components/layout/sidebar/SidebarContainer.tsx +0 -123
  707. package/src/components/layout/sidebar/SidebarContext.ts +0 -40
  708. package/src/components/layout/sidebar/SidebarMenu.tsx +0 -182
  709. package/src/components/layout/sidebar/SidebarUser.tsx +0 -142
  710. package/src/components/layout/topbar/TopbarActions.tsx +0 -8
  711. package/src/components/layout/topbar/TopbarContainer.tsx +0 -44
  712. package/src/components/layout/topbar/TopbarContext.ts +0 -36
  713. package/src/components/layout/topbar/TopbarMenu.tsx +0 -227
  714. package/src/components/layout/topbar/TopbarUser.tsx +0 -97
  715. package/src/helpers/createHmrSafeContext.ts +0 -8
  716. package/src/helpers/createSlotComponent.ts +0 -23
  717. package/src/hooks/createSelectionGroup.tsx +0 -241
  718. package/src/hooks/createSlotSignal.ts +0 -14
  719. package/src/providers/ServiceClientContext.ts +0 -32
  720. package/src/providers/shared-data/SharedDataContext.ts +0 -91
  721. package/src/styles/patterns.styles.ts +0 -50
  722. package/src/styles/tokens.styles.ts +0 -86
  723. package/tests/components/data/Table.spec.tsx +0 -55
  724. package/tests/components/display/Alert.spec.tsx +0 -47
  725. package/tests/components/display/Card.spec.tsx +0 -41
  726. package/tests/components/display/Link.spec.tsx +0 -62
  727. package/tests/components/display/Tag.spec.tsx +0 -47
  728. package/tests/components/feedback/print/Print.spec.tsx +0 -45
  729. package/tests/components/layout/FormGroup.spec.tsx +0 -104
  730. package/tests/components/layout/FormTable.spec.tsx +0 -43
  731. package/tests/components/layout/topbar/TopbarContainer.spec.tsx +0 -38
  732. package/tests/providers/ClipboardProvider.spec.tsx +0 -20
  733. package/tests/providers/ConfigContext.spec.tsx +0 -42
  734. package/tests/providers/LoggerContext.spec.tsx +0 -76
  735. package/tests/providers/PwaUpdateProvider.spec.tsx +0 -32
  736. package/tests/providers/SyncStorageContext.spec.tsx +0 -77
  737. /package/dist/components/feedback/busy/{BusyContainer.css → BusyContainer.animate.css} +0 -0
  738. /package/dist/providers/i18n/{I18nContext.types.js.map → I18nProvider.types.js.map} +0 -0
  739. /package/src/components/feedback/busy/{BusyContainer.css → BusyContainer.animate.css} +0 -0
  740. /package/src/providers/{LoggerContext.tsx → LoggerProvider.tsx} +0 -0
  741. /package/src/providers/{SyncStorageContext.tsx → SyncStorageProvider.tsx} +0 -0
  742. /package/src/providers/i18n/{I18nContext.types.ts → I18nProvider.types.ts} +0 -0
@@ -0,0 +1,345 @@
1
+ import { describe, it, expect } from "vitest";
2
+ import { createRoot } from "solid-js";
3
+ import { useDataSheetSelection } from "../../../../../src/components/data/sheet/hooks/useDataSheetSelection";
4
+ import type { FlatItem } from "../../../../../src/components/data/sheet/types";
5
+
6
+ interface TestItem {
7
+ id: string;
8
+ name: string;
9
+ selectable?: boolean;
10
+ disabledReason?: string;
11
+ }
12
+
13
+ const testItems: TestItem[] = [
14
+ { id: "a", name: "Item A" },
15
+ { id: "b", name: "Item B" },
16
+ { id: "c", name: "Item C", selectable: false, disabledReason: "Locked" },
17
+ { id: "d", name: "Item D" },
18
+ ];
19
+
20
+ function createTestFlatItems(items: TestItem[]): FlatItem<TestItem>[] {
21
+ return items.map((item, index) => ({
22
+ item,
23
+ index,
24
+ row: index,
25
+ depth: 0,
26
+ hasChildren: false,
27
+ }));
28
+ }
29
+
30
+ describe("useDataSheetSelection", () => {
31
+ it("should initialize with empty selected items by default", () => {
32
+ createRoot(() => {
33
+ const result = useDataSheetSelection({}, () => createTestFlatItems(testItems));
34
+
35
+ expect(result.selection()).toEqual([]);
36
+ });
37
+ });
38
+
39
+ it("should initialize with provided selected items", () => {
40
+ createRoot(() => {
41
+ const selection = [testItems[0]];
42
+ const result = useDataSheetSelection(
43
+ { selection },
44
+ () => createTestFlatItems(testItems),
45
+ );
46
+
47
+ expect(result.selection()).toEqual(selection);
48
+ });
49
+ });
50
+
51
+ it("getItemSelectable should return true for selectable items", () => {
52
+ createRoot(() => {
53
+ const result = useDataSheetSelection({}, () => createTestFlatItems(testItems));
54
+
55
+ expect(result.getItemSelectable(testItems[0])).toBe(true);
56
+ });
57
+ });
58
+
59
+ it("getItemSelectable should return false when item is not selectable", () => {
60
+ createRoot(() => {
61
+ const itemSelectable = (item: TestItem) => item.selectable !== false;
62
+ const result = useDataSheetSelection(
63
+ { itemSelectable },
64
+ () => createTestFlatItems(testItems),
65
+ );
66
+
67
+ expect(result.getItemSelectable(testItems[2])).toBe(false);
68
+ });
69
+ });
70
+
71
+ it("getItemSelectable should return reason string when item is disabled", () => {
72
+ createRoot(() => {
73
+ const itemSelectable = (item: TestItem) => item.disabledReason != null && item.disabledReason !== "" ? item.disabledReason : true;
74
+ const result = useDataSheetSelection(
75
+ { itemSelectable },
76
+ () => createTestFlatItems(testItems),
77
+ );
78
+
79
+ expect(result.getItemSelectable(testItems[2])).toBe("Locked");
80
+ });
81
+ });
82
+
83
+ it("toggleSelect should add item in multiple mode", () => {
84
+ createRoot(() => {
85
+ const result = useDataSheetSelection(
86
+ { selectionMode: "multiple" },
87
+ () => createTestFlatItems(testItems),
88
+ );
89
+
90
+ result.toggleSelect(testItems[0]);
91
+
92
+ expect(result.selection()).toContain(testItems[0]);
93
+ });
94
+ });
95
+
96
+ it("toggleSelect should remove item in multiple mode", () => {
97
+ createRoot(() => {
98
+ const result = useDataSheetSelection(
99
+ { selectionMode: "multiple", selection: [testItems[0]] },
100
+ () => createTestFlatItems(testItems),
101
+ );
102
+
103
+ result.toggleSelect(testItems[0]);
104
+
105
+ expect(result.selection()).not.toContain(testItems[0]);
106
+ });
107
+ });
108
+
109
+ it("toggleSelect should replace selection in single mode", () => {
110
+ createRoot(() => {
111
+ const result = useDataSheetSelection(
112
+ { selectionMode: "single", selection: [testItems[0]] },
113
+ () => createTestFlatItems(testItems),
114
+ );
115
+
116
+ result.toggleSelect(testItems[1]);
117
+
118
+ expect(result.selection()).toEqual([testItems[1]]);
119
+ });
120
+ });
121
+
122
+ it("toggleSelect should deselect in single mode when toggling selected item", () => {
123
+ createRoot(() => {
124
+ const result = useDataSheetSelection(
125
+ { selectionMode: "single", selection: [testItems[0]] },
126
+ () => createTestFlatItems(testItems),
127
+ );
128
+
129
+ result.toggleSelect(testItems[0]);
130
+
131
+ expect(result.selection()).toEqual([]);
132
+ });
133
+ });
134
+
135
+ it("toggleSelect should not select non-selectable items", () => {
136
+ createRoot(() => {
137
+ const itemSelectable = (item: TestItem) => item.selectable !== false;
138
+ const result = useDataSheetSelection(
139
+ { itemSelectable },
140
+ () => createTestFlatItems(testItems),
141
+ );
142
+
143
+ result.toggleSelect(testItems[2]);
144
+
145
+ expect(result.selection()).not.toContain(testItems[2]);
146
+ });
147
+ });
148
+
149
+ it("toggleSelect should update lastClickAction to 'select' when selecting", () => {
150
+ createRoot(() => {
151
+ const result = useDataSheetSelection(
152
+ { selectionMode: "multiple" },
153
+ () => createTestFlatItems(testItems),
154
+ );
155
+
156
+ result.toggleSelect(testItems[0]);
157
+
158
+ expect(result.lastClickAction()).toBe("select");
159
+ });
160
+ });
161
+
162
+ it("toggleSelect should update lastClickAction to 'deselect' when deselecting", () => {
163
+ createRoot(() => {
164
+ const result = useDataSheetSelection(
165
+ { selectionMode: "multiple", selection: [testItems[0]] },
166
+ () => createTestFlatItems(testItems),
167
+ );
168
+
169
+ result.toggleSelect(testItems[0]);
170
+
171
+ expect(result.lastClickAction()).toBe("deselect");
172
+ });
173
+ });
174
+
175
+ it("toggleSelectAll should select all selectable items", () => {
176
+ createRoot(() => {
177
+ const itemSelectable = (item: TestItem) => item.selectable !== false;
178
+ const result = useDataSheetSelection(
179
+ { itemSelectable },
180
+ () => createTestFlatItems(testItems),
181
+ );
182
+
183
+ result.toggleSelectAll();
184
+
185
+ const selectableItems = testItems.filter((i) => i.selectable !== false);
186
+ expect(result.selection()).toEqual(selectableItems);
187
+ });
188
+ });
189
+
190
+ it("toggleSelectAll should deselect all items when all are selected", () => {
191
+ createRoot(() => {
192
+ const itemSelectable = (item: TestItem) => item.selectable !== false;
193
+ const selectableItems = testItems.filter((i) => i.selectable !== false);
194
+ const result = useDataSheetSelection(
195
+ { itemSelectable, selection: selectableItems },
196
+ () => createTestFlatItems(testItems),
197
+ );
198
+
199
+ result.toggleSelectAll();
200
+
201
+ expect(result.selection()).toEqual([]);
202
+ });
203
+ });
204
+
205
+ it("toggleSelectAll should only select selectable items", () => {
206
+ createRoot(() => {
207
+ const itemSelectable = (item: TestItem) => item.selectable !== false;
208
+ const result = useDataSheetSelection(
209
+ { itemSelectable },
210
+ () => createTestFlatItems(testItems),
211
+ );
212
+
213
+ result.toggleSelectAll();
214
+
215
+ expect(result.selection()).not.toContain(testItems[2]);
216
+ });
217
+ });
218
+
219
+ it("rangeSelect should do nothing if lastClickedRow is null", () => {
220
+ createRoot(() => {
221
+ const result = useDataSheetSelection(
222
+ { selectionMode: "multiple" },
223
+ () => createTestFlatItems(testItems),
224
+ );
225
+
226
+ result.rangeSelect(2);
227
+
228
+ expect(result.selection()).toEqual([]);
229
+ });
230
+ });
231
+
232
+ it("rangeSelect should select items in range when lastClickAction is 'select'", () => {
233
+ createRoot(() => {
234
+ const result = useDataSheetSelection(
235
+ { selectionMode: "multiple" },
236
+ () => createTestFlatItems(testItems),
237
+ );
238
+
239
+ result.setLastClickedRow(0);
240
+ result.setLastClickAction("select");
241
+ result.rangeSelect(2);
242
+
243
+ expect(result.selection().length).toBe(3);
244
+ expect(result.selection()).toContain(testItems[0]);
245
+ expect(result.selection()).toContain(testItems[1]);
246
+ expect(result.selection()).toContain(testItems[2]);
247
+ });
248
+ });
249
+
250
+ it("rangeSelect should select items in reverse range", () => {
251
+ createRoot(() => {
252
+ const result = useDataSheetSelection(
253
+ { selectionMode: "multiple" },
254
+ () => createTestFlatItems(testItems),
255
+ );
256
+
257
+ result.setLastClickedRow(2);
258
+ result.setLastClickAction("select");
259
+ result.rangeSelect(0);
260
+
261
+ expect(result.selection().length).toBe(3);
262
+ expect(result.selection()).toContain(testItems[0]);
263
+ expect(result.selection()).toContain(testItems[1]);
264
+ expect(result.selection()).toContain(testItems[2]);
265
+ });
266
+ });
267
+
268
+ it("rangeSelect should deselect items in range when lastClickAction is 'deselect'", () => {
269
+ createRoot(() => {
270
+ const result = useDataSheetSelection(
271
+ { selectionMode: "multiple", selection: testItems },
272
+ () => createTestFlatItems(testItems),
273
+ );
274
+
275
+ result.setLastClickedRow(0);
276
+ result.setLastClickAction("deselect");
277
+ result.rangeSelect(2);
278
+
279
+ expect(result.selection()).not.toContain(testItems[0]);
280
+ expect(result.selection()).not.toContain(testItems[1]);
281
+ expect(result.selection()).toContain(testItems[3]);
282
+ });
283
+ });
284
+
285
+ it("rangeSelect should only select selectable items in range", () => {
286
+ createRoot(() => {
287
+ const itemSelectable = (item: TestItem) => item.selectable !== false;
288
+ const result = useDataSheetSelection(
289
+ { selectionMode: "multiple", itemSelectable },
290
+ () => createTestFlatItems(testItems),
291
+ );
292
+
293
+ result.setLastClickedRow(0);
294
+ result.setLastClickAction("select");
295
+ result.rangeSelect(3);
296
+
297
+ expect(result.selection()).not.toContain(testItems[2]);
298
+ expect(result.selection()).toContain(testItems[0]);
299
+ expect(result.selection()).toContain(testItems[1]);
300
+ expect(result.selection()).toContain(testItems[3]);
301
+ });
302
+ });
303
+
304
+ it("should respect controlled mode with onChange callback", () => {
305
+ createRoot(() => {
306
+ let lastCalledWith: TestItem[] | null = null;
307
+ const onSelectionChange = (items: TestItem[]) => {
308
+ lastCalledWith = items;
309
+ };
310
+
311
+ const result = useDataSheetSelection(
312
+ { selectionMode: "multiple", onSelectionChange },
313
+ () => createTestFlatItems(testItems),
314
+ );
315
+
316
+ result.toggleSelect(testItems[0]);
317
+
318
+ expect(lastCalledWith).toEqual([testItems[0]]);
319
+ });
320
+ });
321
+
322
+ it("should track last clicked row", () => {
323
+ createRoot(() => {
324
+ const result = useDataSheetSelection(
325
+ { selectionMode: "multiple" },
326
+ () => createTestFlatItems(testItems),
327
+ );
328
+
329
+ result.setLastClickedRow(2);
330
+
331
+ expect(result.lastClickedRow()).toBe(2);
332
+ });
333
+ });
334
+
335
+ it("should default to 'select' action", () => {
336
+ createRoot(() => {
337
+ const result = useDataSheetSelection(
338
+ { selectionMode: "multiple" },
339
+ () => createTestFlatItems(testItems),
340
+ );
341
+
342
+ expect(result.lastClickAction()).toBe("select");
343
+ });
344
+ });
345
+ });
@@ -0,0 +1,279 @@
1
+ import { describe, it, expect } from "vitest";
2
+ import { createRoot, createSignal } from "solid-js";
3
+ import { useDataSheetSorting } from "../../../../../src/components/data/sheet/hooks/useDataSheetSorting";
4
+ import type { SortingDef } from "../../../../../src/components/data/sheet/types";
5
+
6
+ interface TestItem {
7
+ id: number;
8
+ name: string;
9
+ age: number;
10
+ }
11
+
12
+ const testData: TestItem[] = [
13
+ { id: 1, name: "Alice", age: 30 },
14
+ { id: 2, name: "Bob", age: 25 },
15
+ { id: 3, name: "Charlie", age: 35 },
16
+ ];
17
+
18
+ describe("useDataSheetSorting", () => {
19
+ it("initializes with empty sorts", () => {
20
+ createRoot(() => {
21
+ const [sorts, _setSorts] = createSignal<SortingDef[] | undefined>(undefined);
22
+ const [onSortsChange, _setOnSortsChange] = createSignal<((sorts: SortingDef[]) => void) | undefined>(
23
+ undefined,
24
+ );
25
+ const [items] = createSignal<TestItem[] | undefined>(testData);
26
+ const [autoSort] = createSignal<boolean | undefined>(true);
27
+
28
+ const { sorts: resultSorts } = useDataSheetSorting({
29
+ sorts,
30
+ onSortsChange,
31
+ items,
32
+ autoSort,
33
+ });
34
+
35
+ expect(resultSorts()).toEqual([]);
36
+ });
37
+ });
38
+
39
+ it("toggleSort adds ascending sort when no sort exists", () => {
40
+ createRoot(() => {
41
+ const [sorts, _setSorts] = createSignal<SortingDef[] | undefined>(undefined);
42
+ const [onSortsChange] = createSignal<((sorts: SortingDef[]) => void) | undefined>(undefined);
43
+ const [items] = createSignal<TestItem[] | undefined>(testData);
44
+ const [autoSort] = createSignal<boolean | undefined>(true);
45
+
46
+ const { toggleSort, sorts: resultSorts } = useDataSheetSorting({
47
+ sorts,
48
+ onSortsChange,
49
+ items,
50
+ autoSort,
51
+ });
52
+
53
+ toggleSort("name", false);
54
+
55
+ expect(resultSorts()).toEqual([{ key: "name", desc: false }]);
56
+ });
57
+ });
58
+
59
+ it("toggleSort cycles asc -> desc -> remove", () => {
60
+ createRoot(() => {
61
+ const [sorts, _setSorts] = createSignal<SortingDef[]>([]);
62
+ const [onSortsChange] = createSignal<((sorts: SortingDef[]) => void) | undefined>(undefined);
63
+ const [items] = createSignal<TestItem[] | undefined>(testData);
64
+ const [autoSort] = createSignal<boolean | undefined>(true);
65
+
66
+ const { toggleSort, sorts: resultSorts } = useDataSheetSorting({
67
+ sorts,
68
+ onSortsChange,
69
+ items,
70
+ autoSort,
71
+ });
72
+
73
+ // Step 1: none -> asc
74
+ toggleSort("name", false);
75
+ expect(resultSorts()).toEqual([{ key: "name", desc: false }]);
76
+
77
+ // Step 2: asc -> desc
78
+ toggleSort("name", false);
79
+ expect(resultSorts()).toEqual([{ key: "name", desc: true }]);
80
+
81
+ // Step 3: desc -> remove
82
+ toggleSort("name", false);
83
+ expect(resultSorts()).toEqual([]);
84
+ });
85
+ });
86
+
87
+ it("toggleSort in multiple mode preserves other sorts", () => {
88
+ createRoot(() => {
89
+ const [sorts, _setSorts] = createSignal<SortingDef[]>([{ key: "id", desc: false }]);
90
+ const [onSortsChange] = createSignal<((sorts: SortingDef[]) => void) | undefined>(undefined);
91
+ const [items] = createSignal<TestItem[] | undefined>(testData);
92
+ const [autoSort] = createSignal<boolean | undefined>(true);
93
+
94
+ const { toggleSort, sorts: resultSorts } = useDataSheetSorting({
95
+ sorts,
96
+ onSortsChange,
97
+ items,
98
+ autoSort,
99
+ });
100
+
101
+ // Add name sort in multiple mode
102
+ toggleSort("name", true);
103
+ expect(resultSorts()).toEqual([
104
+ { key: "id", desc: false },
105
+ { key: "name", desc: false },
106
+ ]);
107
+
108
+ // Toggle name to desc in multiple mode
109
+ toggleSort("name", true);
110
+ expect(resultSorts()).toEqual([
111
+ { key: "id", desc: false },
112
+ { key: "name", desc: true },
113
+ ]);
114
+
115
+ // Remove name in multiple mode
116
+ toggleSort("name", true);
117
+ expect(resultSorts()).toEqual([{ key: "id", desc: false }]);
118
+ });
119
+ });
120
+
121
+ it("sortIndex returns undefined for single sort", () => {
122
+ createRoot(() => {
123
+ const [sorts, _setSorts] = createSignal<SortingDef[]>([{ key: "name", desc: false }]);
124
+ const [onSortsChange] = createSignal<((sorts: SortingDef[]) => void) | undefined>(undefined);
125
+ const [items] = createSignal<TestItem[] | undefined>(testData);
126
+ const [autoSort] = createSignal<boolean | undefined>(true);
127
+
128
+ const { sortIndex } = useDataSheetSorting({
129
+ sorts,
130
+ onSortsChange,
131
+ items,
132
+ autoSort,
133
+ });
134
+
135
+ expect(sortIndex("name")).toBeUndefined();
136
+ });
137
+ });
138
+
139
+ it("sortIndex returns 1-based index for multi sort", () => {
140
+ createRoot(() => {
141
+ const [sorts, _setSorts] = createSignal<SortingDef[]>([
142
+ { key: "id", desc: false },
143
+ { key: "name", desc: false },
144
+ { key: "age", desc: false },
145
+ ]);
146
+ const [onSortsChange] = createSignal<((sorts: SortingDef[]) => void) | undefined>(undefined);
147
+ const [items] = createSignal<TestItem[] | undefined>(testData);
148
+ const [autoSort] = createSignal<boolean | undefined>(true);
149
+
150
+ const { sortIndex } = useDataSheetSorting({
151
+ sorts,
152
+ onSortsChange,
153
+ items,
154
+ autoSort,
155
+ });
156
+
157
+ expect(sortIndex("id")).toBe(1);
158
+ expect(sortIndex("name")).toBe(2);
159
+ expect(sortIndex("age")).toBe(3);
160
+ expect(sortIndex("nonexistent")).toBeUndefined();
161
+ });
162
+ });
163
+
164
+ it("sortedItems applies sorting when autoSort is true", () => {
165
+ createRoot(() => {
166
+ const [sorts, _setSorts] = createSignal<SortingDef[]>([{ key: "age", desc: false }]);
167
+ const [onSortsChange] = createSignal<((sorts: SortingDef[]) => void) | undefined>(undefined);
168
+ const [items] = createSignal<TestItem[] | undefined>(testData);
169
+ const [autoSort] = createSignal<boolean | undefined>(true);
170
+
171
+ const { sortedItems } = useDataSheetSorting({
172
+ sorts,
173
+ onSortsChange,
174
+ items,
175
+ autoSort,
176
+ });
177
+
178
+ // Should be sorted by age ascending: 25, 30, 35
179
+ const result = sortedItems();
180
+ expect(result[0].age).toBe(25);
181
+ expect(result[1].age).toBe(30);
182
+ expect(result[2].age).toBe(35);
183
+ });
184
+ });
185
+
186
+ it("sortedItems returns original items when autoSort is false", () => {
187
+ createRoot(() => {
188
+ const [sorts, _setSorts] = createSignal<SortingDef[]>([{ key: "age", desc: false }]);
189
+ const [onSortsChange] = createSignal<((sorts: SortingDef[]) => void) | undefined>(undefined);
190
+ const [items] = createSignal<TestItem[] | undefined>(testData);
191
+ const [autoSort] = createSignal<boolean | undefined>(false);
192
+
193
+ const { sortedItems } = useDataSheetSorting({
194
+ sorts,
195
+ onSortsChange,
196
+ items,
197
+ autoSort,
198
+ });
199
+
200
+ // Should return original order despite sort definition
201
+ const result = sortedItems();
202
+ expect(result).toEqual(testData);
203
+ });
204
+ });
205
+
206
+ it("sortedItems applies descending sort", () => {
207
+ createRoot(() => {
208
+ const [sorts, _setSorts] = createSignal<SortingDef[]>([{ key: "age", desc: true }]);
209
+ const [onSortsChange] = createSignal<((sorts: SortingDef[]) => void) | undefined>(undefined);
210
+ const [items] = createSignal<TestItem[] | undefined>(testData);
211
+ const [autoSort] = createSignal<boolean | undefined>(true);
212
+
213
+ const { sortedItems } = useDataSheetSorting({
214
+ sorts,
215
+ onSortsChange,
216
+ items,
217
+ autoSort,
218
+ });
219
+
220
+ // Should be sorted by age descending: 35, 30, 25
221
+ const result = sortedItems();
222
+ expect(result[0].age).toBe(35);
223
+ expect(result[1].age).toBe(30);
224
+ expect(result[2].age).toBe(25);
225
+ });
226
+ });
227
+
228
+ it("sortedItems applies multiple sorts in order", () => {
229
+ createRoot(() => {
230
+ const multiData: TestItem[] = [
231
+ { id: 1, name: "Alice", age: 30 },
232
+ { id: 2, name: "Bob", age: 25 },
233
+ { id: 3, name: "Alice", age: 25 },
234
+ ];
235
+
236
+ const [sorts, _setSorts] = createSignal<SortingDef[]>([
237
+ { key: "name", desc: false },
238
+ { key: "age", desc: false },
239
+ ]);
240
+ const [onSortsChange] = createSignal<((sorts: SortingDef[]) => void) | undefined>(undefined);
241
+ const [items] = createSignal<TestItem[] | undefined>(multiData);
242
+ const [autoSort] = createSignal<boolean | undefined>(true);
243
+
244
+ const { sortedItems } = useDataSheetSorting({
245
+ sorts,
246
+ onSortsChange,
247
+ items,
248
+ autoSort,
249
+ });
250
+
251
+ const result = sortedItems();
252
+ // Primary sort by name, secondary by age
253
+ // Alice(25), Alice(30), Bob(25)
254
+ expect(result[0].name).toBe("Alice");
255
+ expect(result[0].age).toBe(25);
256
+ expect(result[1].name).toBe("Alice");
257
+ expect(result[1].age).toBe(30);
258
+ expect(result[2].name).toBe("Bob");
259
+ });
260
+ });
261
+
262
+ it("handles undefined items", () => {
263
+ createRoot(() => {
264
+ const [sorts, _setSorts] = createSignal<SortingDef[] | undefined>(undefined);
265
+ const [onSortsChange] = createSignal<((sorts: SortingDef[]) => void) | undefined>(undefined);
266
+ const [items] = createSignal<TestItem[] | undefined>(undefined);
267
+ const [autoSort] = createSignal<boolean | undefined>(true);
268
+
269
+ const { sortedItems } = useDataSheetSorting({
270
+ sorts,
271
+ onSortsChange,
272
+ items,
273
+ autoSort,
274
+ });
275
+
276
+ expect(sortedItems()).toEqual([]);
277
+ });
278
+ });
279
+ });
@@ -37,24 +37,6 @@ describe("Collapse", () => {
37
37
  ?.firstElementChild as HTMLElement;
38
38
  expect(contentDiv.style.visibility).toBe("hidden");
39
39
  });
40
-
41
- it("renders correctly with no children", () => {
42
- const { container } = render(() => <Collapse open={false} />);
43
- expect(container.firstChild).toBeTruthy();
44
- });
45
-
46
- it("merges custom classes", () => {
47
- const { container } = render(() => (
48
- // eslint-disable-next-line tailwindcss/no-custom-classname
49
- <Collapse open={true} class="my-test-class">
50
- Content
51
- </Collapse>
52
- ));
53
- expect(container.querySelector(".my-test-class")).toBeTruthy();
54
- // overflow: hidden is applied as inline style
55
- const rootDiv = container.querySelector("[data-collapse]") as HTMLElement;
56
- expect(rootDiv.style.overflow).toBe("hidden");
57
- });
58
40
  });
59
41
 
60
42
  describe("margin-top calculation", () => {
@@ -90,12 +72,6 @@ describe("Collapse", () => {
90
72
  });
91
73
 
92
74
  describe("initial render and transition", () => {
93
- it("applies transition class after mount", () => {
94
- const { container } = render(() => <Collapse open={false}>Content</Collapse>);
95
- const contentDiv = container.querySelector("[data-collapse]")?.firstElementChild;
96
- expect(contentDiv?.classList.contains("transition-[margin-top]")).toBeTruthy();
97
- });
98
-
99
75
  it("retains transition class and updates margin-top on open state change", async () => {
100
76
  const [open, setOpen] = createSignal(false);
101
77
  const { container } = render(() => (