@simplysm/solid 13.0.75 → 13.0.77

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 (782) hide show
  1. package/README.md +13 -14
  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 +50 -16
  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 +7 -28
  19. package/dist/components/data/list/List.d.ts.map +1 -1
  20. package/dist/components/data/list/List.js +5 -7
  21. package/dist/components/data/list/List.js.map +2 -2
  22. package/dist/components/data/list/ListItem.d.ts +7 -34
  23. package/dist/components/data/list/ListItem.d.ts.map +1 -1
  24. package/dist/components/data/list/ListItem.js +15 -20
  25. package/dist/components/data/list/ListItem.js.map +2 -2
  26. package/dist/components/data/list/ListItem.styles.d.ts +1 -1
  27. package/dist/components/data/list/ListItem.styles.d.ts.map +1 -1
  28. package/dist/components/data/list/ListItem.styles.js +8 -8
  29. package/dist/components/data/list/ListItem.styles.js.map +1 -1
  30. package/dist/components/data/sheet/DataSheet.d.ts +3 -7
  31. package/dist/components/data/sheet/DataSheet.d.ts.map +1 -1
  32. package/dist/components/data/sheet/DataSheet.js +557 -843
  33. package/dist/components/data/sheet/DataSheet.js.map +2 -2
  34. package/dist/components/data/sheet/DataSheet.styles.d.ts +2 -1
  35. package/dist/components/data/sheet/DataSheet.styles.d.ts.map +1 -1
  36. package/dist/components/data/sheet/DataSheet.styles.js +32 -10
  37. package/dist/components/data/sheet/DataSheet.styles.js.map +1 -1
  38. package/dist/components/data/sheet/{types.d.ts → DataSheet.types.d.ts} +14 -9
  39. package/dist/components/data/sheet/DataSheet.types.d.ts.map +1 -0
  40. package/dist/components/data/sheet/DataSheet.types.js +1 -0
  41. package/dist/components/data/sheet/{sheetUtils.d.ts → DataSheet.utils.d.ts} +4 -4
  42. package/dist/components/data/sheet/DataSheet.utils.d.ts.map +1 -0
  43. package/dist/components/data/sheet/{sheetUtils.js → DataSheet.utils.js} +8 -8
  44. package/dist/components/data/sheet/DataSheet.utils.js.map +6 -0
  45. package/dist/components/data/sheet/DataSheetColumn.d.ts +4 -3
  46. package/dist/components/data/sheet/DataSheetColumn.d.ts.map +1 -1
  47. package/dist/components/data/sheet/DataSheetColumn.js +4 -22
  48. package/dist/components/data/sheet/DataSheetColumn.js.map +2 -2
  49. package/dist/components/data/sheet/DataSheetConfigDialog.d.ts +2 -1
  50. package/dist/components/data/sheet/DataSheetConfigDialog.d.ts.map +1 -1
  51. package/dist/components/data/sheet/DataSheetConfigDialog.js +19 -18
  52. package/dist/components/data/sheet/DataSheetConfigDialog.js.map +2 -2
  53. package/dist/components/data/sheet/hooks/useDataSheetExpansion.d.ts +17 -0
  54. package/dist/components/data/sheet/hooks/useDataSheetExpansion.d.ts.map +1 -0
  55. package/dist/components/data/sheet/hooks/useDataSheetExpansion.js +61 -0
  56. package/dist/components/data/sheet/hooks/useDataSheetExpansion.js.map +6 -0
  57. package/dist/components/data/sheet/hooks/useDataSheetFixedColumns.d.ts +29 -0
  58. package/dist/components/data/sheet/hooks/useDataSheetFixedColumns.d.ts.map +1 -0
  59. package/dist/components/data/sheet/hooks/useDataSheetFixedColumns.js +101 -0
  60. package/dist/components/data/sheet/hooks/useDataSheetFixedColumns.js.map +6 -0
  61. package/dist/components/data/sheet/hooks/useDataSheetHeaderCell.d.ts +27 -0
  62. package/dist/components/data/sheet/hooks/useDataSheetHeaderCell.d.ts.map +1 -0
  63. package/dist/components/data/sheet/hooks/useDataSheetHeaderCell.js +173 -0
  64. package/dist/components/data/sheet/hooks/useDataSheetHeaderCell.js.map +6 -0
  65. package/dist/components/data/sheet/hooks/useDataSheetPaging.d.ts +17 -0
  66. package/dist/components/data/sheet/hooks/useDataSheetPaging.d.ts.map +1 -0
  67. package/dist/components/data/sheet/hooks/useDataSheetPaging.js +32 -0
  68. package/dist/components/data/sheet/hooks/useDataSheetPaging.js.map +6 -0
  69. package/dist/components/data/sheet/hooks/useDataSheetReorder.d.ts +20 -0
  70. package/dist/components/data/sheet/hooks/useDataSheetReorder.d.ts.map +1 -0
  71. package/dist/components/data/sheet/hooks/useDataSheetReorder.js +112 -0
  72. package/dist/components/data/sheet/hooks/useDataSheetReorder.js.map +6 -0
  73. package/dist/components/data/sheet/hooks/useDataSheetSelection.d.ts +22 -0
  74. package/dist/components/data/sheet/hooks/useDataSheetSelection.d.ts.map +1 -0
  75. package/dist/components/data/sheet/hooks/useDataSheetSelection.js +63 -0
  76. package/dist/components/data/sheet/hooks/useDataSheetSelection.js.map +6 -0
  77. package/dist/components/data/sheet/hooks/useDataSheetSorting.d.ts +17 -0
  78. package/dist/components/data/sheet/hooks/useDataSheetSorting.d.ts.map +1 -0
  79. package/dist/components/data/sheet/hooks/useDataSheetSorting.js +45 -0
  80. package/dist/components/data/sheet/hooks/useDataSheetSorting.js.map +6 -0
  81. package/dist/components/disclosure/Collapse.d.ts.map +1 -1
  82. package/dist/components/disclosure/Collapse.js +1 -3
  83. package/dist/components/disclosure/Collapse.js.map +2 -2
  84. package/dist/components/disclosure/Dialog.d.ts +79 -25
  85. package/dist/components/disclosure/Dialog.d.ts.map +1 -1
  86. package/dist/components/disclosure/Dialog.js +251 -113
  87. package/dist/components/disclosure/Dialog.js.map +2 -2
  88. package/dist/components/disclosure/Dropdown.d.ts +8 -35
  89. package/dist/components/disclosure/Dropdown.d.ts.map +1 -1
  90. package/dist/components/disclosure/Dropdown.js +60 -61
  91. package/dist/components/disclosure/Dropdown.js.map +2 -2
  92. package/dist/components/disclosure/Tabs.d.ts +4 -6
  93. package/dist/components/disclosure/Tabs.d.ts.map +1 -1
  94. package/dist/components/disclosure/Tabs.js +16 -17
  95. package/dist/components/disclosure/Tabs.js.map +2 -2
  96. package/dist/components/display/Alert.d.ts +1 -1
  97. package/dist/components/display/Alert.d.ts.map +1 -1
  98. package/dist/components/display/Alert.js +2 -4
  99. package/dist/components/display/Alert.js.map +2 -2
  100. package/dist/components/display/Barcode.d.ts +1 -1
  101. package/dist/components/display/Barcode.d.ts.map +1 -1
  102. package/dist/components/display/Barcode.js +3 -4
  103. package/dist/components/display/Barcode.js.map +2 -2
  104. package/dist/components/display/Barcode.types.d.ts +2 -0
  105. package/dist/components/display/Barcode.types.d.ts.map +1 -0
  106. package/dist/components/display/Barcode.types.js +1 -0
  107. package/dist/components/display/Card.animate.css +11 -0
  108. package/dist/components/display/Card.d.ts +1 -0
  109. package/dist/components/display/Card.d.ts.map +1 -1
  110. package/dist/components/display/Card.js +3 -2
  111. package/dist/components/display/Card.js.map +2 -2
  112. package/dist/components/display/Echarts.d.ts +2 -2
  113. package/dist/components/display/Echarts.d.ts.map +1 -1
  114. package/dist/components/display/Echarts.js +8 -11
  115. package/dist/components/display/Echarts.js.map +2 -2
  116. package/dist/components/display/Link.d.ts +1 -1
  117. package/dist/components/display/Link.d.ts.map +1 -1
  118. package/dist/components/display/Link.js +3 -4
  119. package/dist/components/display/Link.js.map +2 -2
  120. package/dist/components/display/Tag.d.ts +1 -1
  121. package/dist/components/display/Tag.d.ts.map +1 -1
  122. package/dist/components/display/Tag.js +2 -4
  123. package/dist/components/display/Tag.js.map +2 -2
  124. package/dist/components/features/address/AddressSearch.d.ts +3 -1
  125. package/dist/components/features/address/AddressSearch.d.ts.map +1 -1
  126. package/dist/components/features/address/AddressSearch.js +7 -5
  127. package/dist/components/features/address/AddressSearch.js.map +2 -2
  128. package/dist/components/features/crud-detail/CrudDetail.d.ts +12 -13
  129. package/dist/components/features/crud-detail/CrudDetail.d.ts.map +1 -1
  130. package/dist/components/features/crud-detail/CrudDetail.js +218 -206
  131. package/dist/components/features/crud-detail/CrudDetail.js.map +2 -2
  132. package/dist/components/features/crud-detail/{types.d.ts → CrudDetail.types.d.ts} +3 -13
  133. package/dist/components/features/crud-detail/CrudDetail.types.d.ts.map +1 -0
  134. package/dist/components/features/crud-detail/CrudDetail.types.js +1 -0
  135. package/dist/components/features/crud-detail/CrudDetailAfter.d.ts +5 -4
  136. package/dist/components/features/crud-detail/CrudDetailAfter.d.ts.map +1 -1
  137. package/dist/components/features/crud-detail/CrudDetailAfter.js +3 -10
  138. package/dist/components/features/crud-detail/CrudDetailAfter.js.map +2 -2
  139. package/dist/components/features/crud-detail/CrudDetailBefore.d.ts +5 -4
  140. package/dist/components/features/crud-detail/CrudDetailBefore.d.ts.map +1 -1
  141. package/dist/components/features/crud-detail/CrudDetailBefore.js +3 -10
  142. package/dist/components/features/crud-detail/CrudDetailBefore.js.map +2 -2
  143. package/dist/components/features/crud-detail/CrudDetailTools.d.ts +5 -4
  144. package/dist/components/features/crud-detail/CrudDetailTools.d.ts.map +1 -1
  145. package/dist/components/features/crud-detail/CrudDetailTools.js +3 -10
  146. package/dist/components/features/crud-detail/CrudDetailTools.js.map +2 -2
  147. package/dist/components/features/crud-sheet/CrudSheet.d.ts +6 -9
  148. package/dist/components/features/crud-sheet/CrudSheet.d.ts.map +1 -1
  149. package/dist/components/features/crud-sheet/CrudSheet.js +147 -141
  150. package/dist/components/features/crud-sheet/CrudSheet.js.map +2 -2
  151. package/dist/components/features/crud-sheet/{types.d.ts → CrudSheet.types.d.ts} +14 -44
  152. package/dist/components/features/crud-sheet/CrudSheet.types.d.ts.map +1 -0
  153. package/dist/components/features/crud-sheet/CrudSheet.types.js +1 -0
  154. package/dist/components/features/crud-sheet/CrudSheetColumn.d.ts +4 -3
  155. package/dist/components/features/crud-sheet/CrudSheetColumn.d.ts.map +1 -1
  156. package/dist/components/features/crud-sheet/CrudSheetColumn.js +4 -23
  157. package/dist/components/features/crud-sheet/CrudSheetColumn.js.map +2 -2
  158. package/dist/components/features/crud-sheet/CrudSheetFilter.d.ts +7 -5
  159. package/dist/components/features/crud-sheet/CrudSheetFilter.d.ts.map +1 -1
  160. package/dist/components/features/crud-sheet/CrudSheetFilter.js +4 -8
  161. package/dist/components/features/crud-sheet/CrudSheetFilter.js.map +2 -2
  162. package/dist/components/features/crud-sheet/CrudSheetHeader.d.ts +5 -4
  163. package/dist/components/features/crud-sheet/CrudSheetHeader.d.ts.map +1 -1
  164. package/dist/components/features/crud-sheet/CrudSheetHeader.js +3 -10
  165. package/dist/components/features/crud-sheet/CrudSheetHeader.js.map +2 -2
  166. package/dist/components/features/crud-sheet/CrudSheetTools.d.ts +7 -5
  167. package/dist/components/features/crud-sheet/CrudSheetTools.d.ts.map +1 -1
  168. package/dist/components/features/crud-sheet/CrudSheetTools.js +4 -8
  169. package/dist/components/features/crud-sheet/CrudSheetTools.js.map +2 -2
  170. package/dist/components/features/data-select-button/DataSelectButton.d.ts +25 -28
  171. package/dist/components/features/data-select-button/DataSelectButton.d.ts.map +1 -1
  172. package/dist/components/features/data-select-button/DataSelectButton.js +27 -38
  173. package/dist/components/features/data-select-button/DataSelectButton.js.map +2 -2
  174. package/dist/components/features/permission-table/PermissionTable.d.ts.map +1 -1
  175. package/dist/components/features/permission-table/PermissionTable.js +9 -13
  176. package/dist/components/features/permission-table/PermissionTable.js.map +2 -2
  177. package/dist/components/features/shared-data/SharedDataSelect.d.ts +20 -19
  178. package/dist/components/features/shared-data/SharedDataSelect.d.ts.map +1 -1
  179. package/dist/components/features/shared-data/SharedDataSelect.js +62 -84
  180. package/dist/components/features/shared-data/SharedDataSelect.js.map +2 -2
  181. package/dist/components/features/shared-data/SharedDataSelectButton.d.ts +12 -9
  182. package/dist/components/features/shared-data/SharedDataSelectButton.d.ts.map +1 -1
  183. package/dist/components/features/shared-data/SharedDataSelectButton.js.map +1 -1
  184. package/dist/components/features/shared-data/SharedDataSelectList.d.ts +12 -8
  185. package/dist/components/features/shared-data/SharedDataSelectList.d.ts.map +1 -1
  186. package/dist/components/features/shared-data/SharedDataSelectList.js +136 -116
  187. package/dist/components/features/shared-data/SharedDataSelectList.js.map +2 -2
  188. package/dist/components/feedback/Progress.d.ts +3 -2
  189. package/dist/components/feedback/Progress.d.ts.map +1 -1
  190. package/dist/components/feedback/Progress.js +9 -7
  191. package/dist/components/feedback/Progress.js.map +2 -2
  192. package/dist/components/feedback/busy/BusyContainer.d.ts +2 -2
  193. package/dist/components/feedback/busy/BusyContainer.d.ts.map +1 -1
  194. package/dist/components/feedback/busy/BusyContainer.js +35 -32
  195. package/dist/components/feedback/busy/BusyContainer.js.map +2 -2
  196. package/dist/components/feedback/busy/BusyProvider.d.ts +26 -2
  197. package/dist/components/feedback/busy/BusyProvider.d.ts.map +1 -1
  198. package/dist/components/feedback/busy/BusyProvider.js +13 -7
  199. package/dist/components/feedback/busy/BusyProvider.js.map +2 -2
  200. package/dist/components/feedback/notification/NotificationBanner.d.ts.map +1 -1
  201. package/dist/components/feedback/notification/NotificationBanner.js +13 -19
  202. package/dist/components/feedback/notification/NotificationBanner.js.map +2 -2
  203. package/dist/components/feedback/notification/NotificationBell.d.ts.map +1 -1
  204. package/dist/components/feedback/notification/NotificationBell.js +69 -71
  205. package/dist/components/feedback/notification/NotificationBell.js.map +2 -2
  206. package/dist/components/feedback/notification/NotificationProvider.d.ts +68 -1
  207. package/dist/components/feedback/notification/NotificationProvider.d.ts.map +1 -1
  208. package/dist/components/feedback/notification/NotificationProvider.js +22 -5
  209. package/dist/components/feedback/notification/NotificationProvider.js.map +2 -2
  210. package/dist/components/feedback/print/Print.d.ts +4 -6
  211. package/dist/components/feedback/print/Print.d.ts.map +1 -1
  212. package/dist/components/feedback/print/Print.js +3 -2
  213. package/dist/components/feedback/print/Print.js.map +2 -2
  214. package/dist/components/feedback/print/PrintProvider.d.ts +14 -1
  215. package/dist/components/feedback/print/PrintProvider.d.ts.map +1 -1
  216. package/dist/components/feedback/print/PrintProvider.js +16 -5
  217. package/dist/components/feedback/print/PrintProvider.js.map +2 -2
  218. package/dist/components/form-control/Button.d.ts +2 -1
  219. package/dist/components/form-control/Button.d.ts.map +1 -1
  220. package/dist/components/form-control/Button.js +9 -8
  221. package/dist/components/form-control/Button.js.map +2 -2
  222. package/dist/components/form-control/DropdownTrigger.styles.d.ts +1 -1
  223. package/dist/components/form-control/DropdownTrigger.styles.d.ts.map +1 -1
  224. package/dist/components/form-control/DropdownTrigger.styles.js +16 -16
  225. package/dist/components/form-control/DropdownTrigger.styles.js.map +1 -1
  226. package/dist/components/form-control/Invalid.d.ts +1 -1
  227. package/dist/components/form-control/Invalid.d.ts.map +1 -1
  228. package/dist/components/form-control/Invalid.js +27 -26
  229. package/dist/components/form-control/Invalid.js.map +2 -2
  230. package/dist/components/form-control/ThemeToggle.d.ts +2 -1
  231. package/dist/components/form-control/ThemeToggle.d.ts.map +1 -1
  232. package/dist/components/form-control/ThemeToggle.js +71 -74
  233. package/dist/components/form-control/ThemeToggle.js.map +2 -2
  234. package/dist/components/form-control/checkbox/Checkbox.d.ts +2 -2
  235. package/dist/components/form-control/checkbox/Checkbox.d.ts.map +1 -1
  236. package/dist/components/form-control/checkbox/Checkbox.js +14 -95
  237. package/dist/components/form-control/checkbox/Checkbox.js.map +2 -2
  238. package/dist/components/form-control/checkbox/Checkbox.styles.d.ts +2 -2
  239. package/dist/components/form-control/checkbox/Checkbox.styles.d.ts.map +1 -1
  240. package/dist/components/form-control/checkbox/Checkbox.styles.js +20 -25
  241. package/dist/components/form-control/checkbox/Checkbox.styles.js.map +1 -1
  242. package/dist/components/form-control/checkbox/CheckboxGroup.d.ts +10 -10
  243. package/dist/components/form-control/checkbox/CheckboxGroup.d.ts.map +1 -1
  244. package/dist/components/form-control/checkbox/CheckboxGroup.js +84 -9
  245. package/dist/components/form-control/checkbox/CheckboxGroup.js.map +2 -2
  246. package/dist/components/form-control/checkbox/Radio.d.ts +2 -2
  247. package/dist/components/form-control/checkbox/Radio.d.ts.map +1 -1
  248. package/dist/components/form-control/checkbox/Radio.js +12 -95
  249. package/dist/components/form-control/checkbox/Radio.js.map +2 -2
  250. package/dist/components/form-control/checkbox/RadioGroup.d.ts +10 -10
  251. package/dist/components/form-control/checkbox/RadioGroup.d.ts.map +1 -1
  252. package/dist/components/form-control/checkbox/RadioGroup.js +81 -9
  253. package/dist/components/form-control/checkbox/RadioGroup.js.map +2 -2
  254. package/dist/components/form-control/checkbox/SelectableBase.d.ts +26 -0
  255. package/dist/components/form-control/checkbox/SelectableBase.d.ts.map +1 -0
  256. package/dist/components/form-control/checkbox/SelectableBase.js +100 -0
  257. package/dist/components/form-control/checkbox/SelectableBase.js.map +6 -0
  258. package/dist/components/form-control/checkbox/SelectionGroupBase.d.ts +17 -0
  259. package/dist/components/form-control/checkbox/SelectionGroupBase.d.ts.map +1 -0
  260. package/dist/components/form-control/checkbox/SelectionGroupBase.js +53 -0
  261. package/dist/components/form-control/checkbox/SelectionGroupBase.js.map +6 -0
  262. package/dist/components/form-control/color-picker/ColorPicker.d.ts +3 -3
  263. package/dist/components/form-control/color-picker/ColorPicker.d.ts.map +1 -1
  264. package/dist/components/form-control/color-picker/ColorPicker.js +6 -18
  265. package/dist/components/form-control/color-picker/ColorPicker.js.map +2 -2
  266. package/dist/components/form-control/combobox/Combobox.d.ts +28 -49
  267. package/dist/components/form-control/combobox/Combobox.d.ts.map +1 -1
  268. package/dist/components/form-control/combobox/Combobox.js +116 -63
  269. package/dist/components/form-control/combobox/Combobox.js.map +2 -2
  270. package/dist/components/form-control/date-range-picker/DateRangePicker.d.ts.map +1 -1
  271. package/dist/components/form-control/date-range-picker/DateRangePicker.js +16 -9
  272. package/dist/components/form-control/date-range-picker/DateRangePicker.js.map +2 -2
  273. package/dist/components/form-control/editor/EditorToolbar.d.ts.map +1 -1
  274. package/dist/components/form-control/editor/EditorToolbar.js +250 -239
  275. package/dist/components/form-control/editor/EditorToolbar.js.map +2 -2
  276. package/dist/components/form-control/editor/RichTextEditor.d.ts +1 -1
  277. package/dist/components/form-control/editor/RichTextEditor.d.ts.map +1 -1
  278. package/dist/components/form-control/editor/RichTextEditor.js +10 -10
  279. package/dist/components/form-control/editor/RichTextEditor.js.map +2 -2
  280. package/{src/components/form-control/editor/editor.css → dist/components/form-control/editor/RichTextEditor.tiptap.css} +0 -1
  281. package/dist/components/form-control/field/DatePicker.d.ts +3 -3
  282. package/dist/components/form-control/field/DatePicker.d.ts.map +1 -1
  283. package/dist/components/form-control/field/DatePicker.js +50 -131
  284. package/dist/components/form-control/field/DatePicker.js.map +2 -2
  285. package/dist/components/form-control/field/DateTimePicker.d.ts +3 -3
  286. package/dist/components/form-control/field/DateTimePicker.d.ts.map +1 -1
  287. package/dist/components/form-control/field/DateTimePicker.js +50 -131
  288. package/dist/components/form-control/field/DateTimePicker.js.map +2 -2
  289. package/dist/components/form-control/field/Field.styles.d.ts +3 -3
  290. package/dist/components/form-control/field/Field.styles.d.ts.map +1 -1
  291. package/dist/components/form-control/field/Field.styles.js +46 -40
  292. package/dist/components/form-control/field/Field.styles.js.map +1 -1
  293. package/dist/components/form-control/field/FieldPlaceholder.js +4 -3
  294. package/dist/components/form-control/field/FieldPlaceholder.js.map +2 -2
  295. package/dist/components/form-control/field/FieldShell.d.ts +37 -0
  296. package/dist/components/form-control/field/FieldShell.d.ts.map +1 -0
  297. package/dist/components/form-control/field/FieldShell.js +124 -0
  298. package/dist/components/form-control/field/FieldShell.js.map +6 -0
  299. package/dist/components/form-control/field/NumberInput.d.ts +13 -32
  300. package/dist/components/form-control/field/NumberInput.d.ts.map +1 -1
  301. package/dist/components/form-control/field/NumberInput.js +92 -196
  302. package/dist/components/form-control/field/NumberInput.js.map +2 -2
  303. package/dist/components/form-control/field/TextInput.d.ts +14 -29
  304. package/dist/components/form-control/field/TextInput.d.ts.map +1 -1
  305. package/dist/components/form-control/field/TextInput.js +87 -197
  306. package/dist/components/form-control/field/TextInput.js.map +2 -2
  307. package/dist/components/form-control/field/Textarea.d.ts +3 -3
  308. package/dist/components/form-control/field/Textarea.d.ts.map +1 -1
  309. package/dist/components/form-control/field/Textarea.js +81 -156
  310. package/dist/components/form-control/field/Textarea.js.map +2 -2
  311. package/dist/components/form-control/field/TimePicker.d.ts +3 -3
  312. package/dist/components/form-control/field/TimePicker.d.ts.map +1 -1
  313. package/dist/components/form-control/field/TimePicker.js +46 -123
  314. package/dist/components/form-control/field/TimePicker.js.map +2 -2
  315. package/dist/components/form-control/numpad/Numpad.d.ts +1 -1
  316. package/dist/components/form-control/numpad/Numpad.d.ts.map +1 -1
  317. package/dist/components/form-control/numpad/Numpad.js +5 -5
  318. package/dist/components/form-control/numpad/Numpad.js.map +2 -2
  319. package/dist/components/form-control/select/Select.d.ts +48 -51
  320. package/dist/components/form-control/select/Select.d.ts.map +1 -1
  321. package/dist/components/form-control/select/Select.js +220 -117
  322. package/dist/components/form-control/select/Select.js.map +2 -2
  323. package/dist/components/form-control/state-preset/StatePreset.d.ts +2 -2
  324. package/dist/components/form-control/state-preset/StatePreset.d.ts.map +1 -1
  325. package/dist/components/form-control/state-preset/StatePreset.js +68 -57
  326. package/dist/components/form-control/state-preset/StatePreset.js.map +2 -2
  327. package/dist/components/layout/FormGroup.d.ts +3 -6
  328. package/dist/components/layout/FormGroup.d.ts.map +1 -1
  329. package/dist/components/layout/FormGroup.js +5 -7
  330. package/dist/components/layout/FormGroup.js.map +2 -2
  331. package/dist/components/layout/FormTable.d.ts +7 -1
  332. package/dist/components/layout/FormTable.d.ts.map +1 -1
  333. package/dist/components/layout/FormTable.js +52 -18
  334. package/dist/components/layout/FormTable.js.map +2 -2
  335. package/dist/components/layout/sidebar/Sidebar.d.ts +60 -29
  336. package/dist/components/layout/sidebar/Sidebar.d.ts.map +1 -1
  337. package/dist/components/layout/sidebar/Sidebar.js +341 -21
  338. package/dist/components/layout/sidebar/Sidebar.js.map +2 -2
  339. package/dist/components/layout/topbar/Topbar.d.ts +44 -33
  340. package/dist/components/layout/topbar/Topbar.d.ts.map +1 -1
  341. package/dist/components/layout/topbar/Topbar.js +426 -39
  342. package/dist/components/layout/topbar/Topbar.js.map +2 -2
  343. package/dist/helpers/createAppStructure.d.ts.map +1 -1
  344. package/dist/helpers/createAppStructure.js +4 -5
  345. package/dist/helpers/createAppStructure.js.map +1 -1
  346. package/dist/helpers/createSlot.d.ts +3 -0
  347. package/dist/helpers/createSlot.d.ts.map +1 -0
  348. package/dist/helpers/createSlot.js +40 -0
  349. package/dist/helpers/createSlot.js.map +6 -0
  350. package/dist/helpers/createSlots.d.ts +7 -0
  351. package/dist/helpers/createSlots.d.ts.map +1 -0
  352. package/dist/helpers/createSlots.js +34 -0
  353. package/dist/helpers/createSlots.js.map +6 -0
  354. package/dist/hooks/createControllableSignal.d.ts +4 -12
  355. package/dist/hooks/createControllableSignal.d.ts.map +1 -1
  356. package/dist/hooks/createControllableSignal.js +4 -3
  357. package/dist/hooks/createControllableSignal.js.map +1 -1
  358. package/dist/hooks/createControllableStore.d.ts.map +1 -1
  359. package/dist/hooks/createControllableStore.js +5 -6
  360. package/dist/hooks/createControllableStore.js.map +1 -1
  361. package/dist/hooks/useLogger.d.ts +1 -1
  362. package/dist/hooks/useLogger.d.ts.map +1 -1
  363. package/dist/hooks/useLogger.js +1 -1
  364. package/dist/hooks/useSyncConfig.js +1 -1
  365. package/dist/index.d.ts +17 -23
  366. package/dist/index.d.ts.map +1 -1
  367. package/dist/index.js +17 -23
  368. package/dist/index.js.map +1 -1
  369. package/dist/providers/ConfigContext.d.ts.map +1 -1
  370. package/dist/providers/ConfigContext.js +10 -13
  371. package/dist/providers/ConfigContext.js.map +1 -1
  372. package/dist/providers/{LoggerContext.d.ts → LoggerProvider.d.ts} +1 -1
  373. package/dist/providers/LoggerProvider.d.ts.map +1 -0
  374. package/dist/providers/{LoggerContext.js → LoggerProvider.js} +1 -1
  375. package/dist/providers/{LoggerContext.js.map → LoggerProvider.js.map} +1 -1
  376. package/dist/providers/PwaUpdateProvider.js +1 -1
  377. package/dist/providers/ServiceClientProvider.d.ts +22 -0
  378. package/dist/providers/ServiceClientProvider.d.ts.map +1 -1
  379. package/dist/providers/ServiceClientProvider.js +39 -48
  380. package/dist/providers/ServiceClientProvider.js.map +2 -2
  381. package/dist/providers/{SyncStorageContext.d.ts → SyncStorageProvider.d.ts} +1 -1
  382. package/dist/providers/SyncStorageProvider.d.ts.map +1 -0
  383. package/dist/providers/{SyncStorageContext.js → SyncStorageProvider.js} +1 -1
  384. package/dist/providers/{SyncStorageContext.js.map → SyncStorageProvider.js.map} +1 -1
  385. package/dist/providers/SystemProvider.d.ts +1 -1
  386. package/dist/providers/SystemProvider.d.ts.map +1 -1
  387. package/dist/providers/SystemProvider.js +3 -3
  388. package/dist/providers/SystemProvider.js.map +1 -1
  389. package/dist/providers/i18n/{I18nContext.d.ts → I18nProvider.d.ts} +2 -2
  390. package/dist/providers/i18n/I18nProvider.d.ts.map +1 -0
  391. package/dist/providers/i18n/{I18nContext.js → I18nProvider.js} +1 -1
  392. package/dist/providers/i18n/{I18nContext.js.map → I18nProvider.js.map} +1 -1
  393. package/dist/providers/i18n/{I18nContext.types.d.ts → I18nProvider.types.d.ts} +1 -1
  394. package/dist/providers/i18n/I18nProvider.types.d.ts.map +1 -0
  395. package/dist/providers/i18n/I18nProvider.types.js +1 -0
  396. package/dist/providers/i18n/I18nProvider.types.js.map +6 -0
  397. package/dist/providers/shared-data/SharedDataProvider.d.ts +75 -2
  398. package/dist/providers/shared-data/SharedDataProvider.d.ts.map +1 -1
  399. package/dist/providers/shared-data/SharedDataProvider.js +111 -91
  400. package/dist/providers/shared-data/SharedDataProvider.js.map +2 -2
  401. package/dist/styles/base.styles.d.ts +15 -0
  402. package/dist/styles/base.styles.d.ts.map +1 -0
  403. package/dist/styles/base.styles.js +21 -0
  404. package/dist/styles/base.styles.js.map +6 -0
  405. package/dist/styles/control.styles.d.ts +19 -0
  406. package/dist/styles/control.styles.d.ts.map +1 -0
  407. package/dist/styles/control.styles.js +24 -0
  408. package/dist/styles/control.styles.js.map +6 -0
  409. package/dist/styles/theme.styles.d.ts +52 -0
  410. package/dist/styles/theme.styles.d.ts.map +1 -0
  411. package/dist/styles/theme.styles.js +55 -0
  412. package/dist/styles/theme.styles.js.map +6 -0
  413. package/package.json +5 -5
  414. package/src/components/data/Pagination.tsx +9 -9
  415. package/src/components/data/Table.tsx +63 -30
  416. package/src/components/data/calendar/Calendar.tsx +38 -36
  417. package/src/components/data/kanban/{Kanban.css → Kanban.animate.css} +0 -2
  418. package/src/components/data/kanban/Kanban.tsx +133 -94
  419. package/src/components/data/list/List.tsx +8 -22
  420. package/src/components/data/list/ListItem.styles.ts +8 -8
  421. package/src/components/data/list/ListItem.tsx +20 -31
  422. package/src/components/data/sheet/DataSheet.styles.ts +32 -9
  423. package/src/components/data/sheet/DataSheet.tsx +356 -747
  424. package/src/components/data/sheet/{types.ts → DataSheet.types.ts} +13 -8
  425. package/src/components/data/sheet/{sheetUtils.ts → DataSheet.utils.ts} +8 -8
  426. package/src/components/data/sheet/DataSheetColumn.tsx +7 -29
  427. package/src/components/data/sheet/DataSheetConfigDialog.tsx +15 -21
  428. package/src/components/data/sheet/hooks/useDataSheetExpansion.ts +85 -0
  429. package/src/components/data/sheet/hooks/useDataSheetFixedColumns.ts +131 -0
  430. package/src/components/data/sheet/hooks/useDataSheetHeaderCell.tsx +168 -0
  431. package/src/components/data/sheet/hooks/useDataSheetPaging.ts +51 -0
  432. package/src/components/data/sheet/hooks/useDataSheetReorder.ts +154 -0
  433. package/src/components/data/sheet/hooks/useDataSheetSelection.ts +99 -0
  434. package/src/components/data/sheet/hooks/useDataSheetSorting.ts +68 -0
  435. package/src/components/disclosure/Collapse.tsx +1 -9
  436. package/src/components/disclosure/Dialog.tsx +254 -59
  437. package/src/components/disclosure/Dropdown.tsx +66 -80
  438. package/src/components/disclosure/Tabs.tsx +23 -37
  439. package/src/components/display/Alert.tsx +2 -5
  440. package/src/components/display/Barcode.tsx +5 -117
  441. package/src/components/display/Barcode.types.ts +111 -0
  442. package/src/components/display/Card.animate.css +11 -0
  443. package/src/components/display/Card.tsx +10 -11
  444. package/src/components/display/Echarts.tsx +11 -15
  445. package/src/components/display/Link.tsx +3 -5
  446. package/src/components/display/Tag.tsx +2 -5
  447. package/src/components/features/address/AddressSearch.tsx +24 -7
  448. package/src/components/features/crud-detail/CrudDetail.tsx +135 -165
  449. package/src/components/features/crud-detail/{types.ts → CrudDetail.types.ts} +3 -16
  450. package/src/components/features/crud-detail/CrudDetailAfter.tsx +3 -16
  451. package/src/components/features/crud-detail/CrudDetailBefore.tsx +3 -16
  452. package/src/components/features/crud-detail/CrudDetailTools.tsx +3 -16
  453. package/src/components/features/crud-sheet/CrudSheet.tsx +158 -176
  454. package/src/components/features/crud-sheet/{types.ts → CrudSheet.types.ts} +13 -47
  455. package/src/components/features/crud-sheet/CrudSheetColumn.tsx +7 -30
  456. package/src/components/features/crud-sheet/CrudSheetFilter.tsx +12 -16
  457. package/src/components/features/crud-sheet/CrudSheetHeader.tsx +3 -16
  458. package/src/components/features/crud-sheet/CrudSheetTools.tsx +12 -16
  459. package/src/components/features/data-select-button/DataSelectButton.tsx +57 -66
  460. package/src/components/features/permission-table/PermissionTable.tsx +9 -13
  461. package/src/components/features/shared-data/SharedDataSelect.tsx +97 -127
  462. package/src/components/features/shared-data/SharedDataSelectButton.tsx +22 -14
  463. package/src/components/features/shared-data/SharedDataSelectList.tsx +61 -42
  464. package/src/components/feedback/Progress.tsx +16 -21
  465. package/src/components/feedback/busy/BusyContainer.tsx +18 -45
  466. package/src/components/feedback/busy/BusyProvider.tsx +40 -7
  467. package/src/components/feedback/notification/NotificationBanner.tsx +13 -32
  468. package/src/components/feedback/notification/NotificationBell.tsx +18 -47
  469. package/src/components/feedback/notification/NotificationProvider.tsx +105 -11
  470. package/src/components/feedback/print/Print.tsx +4 -8
  471. package/src/components/feedback/print/PrintProvider.tsx +37 -5
  472. package/src/components/form-control/Button.tsx +11 -29
  473. package/src/components/form-control/DropdownTrigger.styles.ts +16 -17
  474. package/src/components/form-control/Invalid.tsx +33 -29
  475. package/src/components/form-control/ThemeToggle.tsx +18 -15
  476. package/src/components/form-control/checkbox/Checkbox.styles.ts +20 -26
  477. package/src/components/form-control/checkbox/Checkbox.tsx +15 -101
  478. package/src/components/form-control/checkbox/CheckboxGroup.tsx +83 -17
  479. package/src/components/form-control/checkbox/Radio.tsx +15 -104
  480. package/src/components/form-control/checkbox/RadioGroup.tsx +80 -17
  481. package/src/components/form-control/checkbox/SelectableBase.tsx +123 -0
  482. package/src/components/form-control/checkbox/SelectionGroupBase.tsx +57 -0
  483. package/src/components/form-control/color-picker/ColorPicker.tsx +12 -32
  484. package/src/components/form-control/combobox/Combobox.tsx +143 -44
  485. package/src/components/form-control/date-range-picker/DateRangePicker.tsx +10 -10
  486. package/src/components/form-control/editor/EditorToolbar.tsx +120 -217
  487. package/{dist/components/form-control/editor/editor.css → src/components/form-control/editor/RichTextEditor.tiptap.css} +0 -1
  488. package/src/components/form-control/editor/RichTextEditor.tsx +14 -29
  489. package/src/components/form-control/field/DatePicker.tsx +34 -76
  490. package/src/components/form-control/field/DateTimePicker.tsx +35 -83
  491. package/src/components/form-control/field/Field.styles.ts +48 -42
  492. package/src/components/form-control/field/FieldPlaceholder.tsx +2 -2
  493. package/src/components/form-control/field/FieldShell.tsx +113 -0
  494. package/src/components/form-control/field/NumberInput.tsx +75 -137
  495. package/src/components/form-control/field/TextInput.tsx +58 -120
  496. package/src/components/form-control/field/Textarea.tsx +67 -111
  497. package/src/components/form-control/field/TimePicker.tsx +33 -74
  498. package/src/components/form-control/numpad/Numpad.tsx +5 -6
  499. package/src/components/form-control/select/Select.tsx +266 -151
  500. package/src/components/form-control/state-preset/StatePreset.tsx +65 -88
  501. package/src/components/layout/FormGroup.tsx +10 -13
  502. package/src/components/layout/FormTable.tsx +40 -19
  503. package/src/components/layout/sidebar/Sidebar.tsx +456 -44
  504. package/src/components/layout/topbar/Topbar.tsx +420 -49
  505. package/src/helpers/createAppStructure.ts +22 -7
  506. package/src/helpers/createSlot.ts +45 -0
  507. package/src/helpers/createSlots.ts +44 -0
  508. package/src/hooks/createControllableSignal.ts +10 -18
  509. package/src/hooks/createControllableStore.ts +5 -6
  510. package/src/hooks/useLogger.ts +1 -1
  511. package/src/hooks/useSyncConfig.ts +1 -1
  512. package/src/index.ts +18 -23
  513. package/src/providers/ConfigContext.tsx +0 -1
  514. package/src/providers/PwaUpdateProvider.tsx +1 -1
  515. package/src/providers/ServiceClientProvider.tsx +62 -56
  516. package/src/providers/SystemProvider.tsx +4 -5
  517. package/src/providers/i18n/{I18nContext.tsx → I18nProvider.tsx} +1 -1
  518. package/src/providers/shared-data/SharedDataProvider.tsx +228 -124
  519. package/src/styles/base.styles.ts +21 -0
  520. package/src/styles/control.styles.ts +25 -0
  521. package/src/styles/theme.styles.ts +54 -0
  522. package/tailwind.config.ts +0 -11
  523. package/tests/components/data/List.spec.tsx +1 -262
  524. package/tests/components/data/Pagination.spec.tsx +0 -75
  525. package/tests/components/data/kanban/Kanban.selection.spec.tsx +1 -17
  526. package/tests/components/data/sheet/DataSheet.spec.tsx +38 -67
  527. package/tests/components/data/sheet/hooks/useDataSheetExpansion.spec.ts +254 -0
  528. package/tests/components/data/sheet/hooks/useDataSheetFixedColumns.spec.ts +488 -0
  529. package/tests/components/data/sheet/hooks/useDataSheetPaging.spec.ts +359 -0
  530. package/tests/components/data/sheet/hooks/useDataSheetReorder.spec.ts +251 -0
  531. package/tests/components/data/sheet/hooks/useDataSheetSelection.spec.ts +362 -0
  532. package/tests/components/data/sheet/hooks/useDataSheetSorting.spec.ts +279 -0
  533. package/tests/components/disclosure/Collapse.spec.tsx +0 -24
  534. package/tests/components/disclosure/Dialog.spec.tsx +11 -61
  535. package/tests/components/disclosure/DialogProvider.spec.tsx +9 -12
  536. package/tests/components/disclosure/Tabs.spec.tsx +0 -99
  537. package/tests/components/display/Barcode.spec.tsx +15 -15
  538. package/tests/components/features/address/AddressSearch.spec.tsx +3 -4
  539. package/tests/components/features/crud-detail/CrudDetail.spec.tsx +12 -74
  540. package/tests/components/features/crud-sheet/CrudSheet.spec.tsx +19 -72
  541. package/tests/components/features/data-select-button/DataSelectButton.spec.tsx +51 -29
  542. package/tests/components/features/permission-table/PermissionTable.spec.tsx +5 -30
  543. package/tests/components/features/shared-data/SharedDataSelect.spec.tsx +15 -19
  544. package/tests/components/features/shared-data/SharedDataSelectList.spec.tsx +17 -44
  545. package/tests/components/feedback/busy/BusyContainer.spec.tsx +15 -9
  546. package/tests/components/feedback/notification/LiveRegion.spec.tsx +2 -27
  547. package/tests/components/feedback/notification/NotificationBanner.spec.tsx +2 -27
  548. package/tests/components/feedback/notification/NotificationBell.spec.tsx +2 -16
  549. package/tests/components/feedback/notification/NotificationContext.spec.tsx +2 -16
  550. package/tests/components/form-control/Button.spec.tsx +0 -97
  551. package/tests/components/form-control/Invalid.spec.tsx +5 -20
  552. package/tests/components/form-control/checkbox/Checkbox.spec.tsx +1 -47
  553. package/tests/components/form-control/checkbox/CheckboxGroup.spec.tsx +1 -26
  554. package/tests/components/form-control/checkbox/Radio.spec.tsx +1 -46
  555. package/tests/components/form-control/checkbox/RadioGroup.spec.tsx +1 -26
  556. package/tests/components/form-control/color-picker/ColorPicker.spec.tsx +1 -31
  557. package/tests/components/form-control/combobox/Combobox.spec.tsx +28 -49
  558. package/tests/components/form-control/combobox/ComboboxItem.spec.tsx +7 -27
  559. package/tests/components/form-control/date-range-picker/DateRangePicker.spec.tsx +1 -58
  560. package/tests/components/form-control/field/DatePicker.spec.tsx +5 -93
  561. package/tests/components/form-control/field/DateTimePicker.spec.tsx +5 -86
  562. package/tests/components/form-control/field/FieldShell.spec.tsx +127 -0
  563. package/tests/components/form-control/field/NumberInput.spec.tsx +14 -133
  564. package/tests/components/form-control/field/TextInput.spec.tsx +6 -148
  565. package/tests/components/form-control/field/Textarea.spec.tsx +5 -69
  566. package/tests/components/form-control/field/TimePicker.spec.tsx +5 -84
  567. package/tests/components/form-control/numpad/Numpad.spec.tsx +1 -78
  568. package/tests/components/form-control/select/Select.spec.tsx +9 -59
  569. package/tests/components/form-control/select/SelectItem.spec.tsx +10 -62
  570. package/tests/components/layout/sidebar/Sidebar.spec.tsx +3 -122
  571. package/tests/components/layout/sidebar/SidebarContainer.spec.tsx +3 -45
  572. package/tests/components/layout/sidebar/SidebarMenu.spec.tsx +1 -74
  573. package/tests/components/layout/sidebar/SidebarUser.spec.tsx +0 -48
  574. package/tests/components/layout/topbar/TopbarActions.spec.tsx +5 -5
  575. package/tests/components/layout/topbar/{createTopbarActions.spec.tsx → useTopbarActions.spec.tsx} +4 -13
  576. package/tests/helpers/createAppStructure.spec.tsx +0 -26
  577. package/tests/helpers/createSlot.spec.tsx +99 -0
  578. package/tests/helpers/createSlots.spec.tsx +100 -0
  579. package/tests/hooks/createControllableSignal.spec.ts +0 -50
  580. package/tests/hooks/createControllableStore.spec.ts +67 -0
  581. package/tests/hooks/createMountTransition.spec.ts +0 -9
  582. package/tests/hooks/useLocalStorage.spec.tsx +0 -34
  583. package/tests/hooks/useLogger.spec.tsx +1 -18
  584. package/tests/hooks/usePrint.spec.tsx +1 -24
  585. package/tests/hooks/useSyncConfig.spec.tsx +1 -18
  586. package/tests/providers/ErrorLoggerProvider.spec.tsx +1 -11
  587. package/tests/providers/ServiceClientContext.spec.tsx +2 -20
  588. package/tests/providers/i18n/I18nContext.spec.tsx +1 -5
  589. package/tests/providers/shared-data/SharedDataProvider.spec.tsx +143 -21
  590. package/dist/components/data/kanban/KanbanContext.d.ts +0 -43
  591. package/dist/components/data/kanban/KanbanContext.d.ts.map +0 -1
  592. package/dist/components/data/kanban/KanbanContext.js +0 -24
  593. package/dist/components/data/kanban/KanbanContext.js.map +0 -6
  594. package/dist/components/data/sheet/DataSheet.css +0 -44
  595. package/dist/components/data/sheet/sheetUtils.d.ts.map +0 -1
  596. package/dist/components/data/sheet/sheetUtils.js.map +0 -6
  597. package/dist/components/data/sheet/types.d.ts.map +0 -1
  598. package/dist/components/data/sheet/types.js +0 -1
  599. package/dist/components/disclosure/DialogContext.d.ts +0 -57
  600. package/dist/components/disclosure/DialogContext.d.ts.map +0 -1
  601. package/dist/components/disclosure/DialogContext.js +0 -14
  602. package/dist/components/disclosure/DialogContext.js.map +0 -6
  603. package/dist/components/disclosure/DialogInstanceContext.d.ts +0 -20
  604. package/dist/components/disclosure/DialogInstanceContext.d.ts.map +0 -1
  605. package/dist/components/disclosure/DialogInstanceContext.js +0 -10
  606. package/dist/components/disclosure/DialogInstanceContext.js.map +0 -6
  607. package/dist/components/disclosure/DialogProvider.d.ts +0 -19
  608. package/dist/components/disclosure/DialogProvider.d.ts.map +0 -1
  609. package/dist/components/disclosure/DialogProvider.js +0 -145
  610. package/dist/components/disclosure/DialogProvider.js.map +0 -6
  611. package/dist/components/features/crud-detail/types.d.ts.map +0 -1
  612. package/dist/components/features/crud-detail/types.js +0 -1
  613. package/dist/components/features/crud-sheet/types.d.ts.map +0 -1
  614. package/dist/components/features/crud-sheet/types.js +0 -1
  615. package/dist/components/features/shared-data/SharedDataSelectListContext.d.ts +0 -15
  616. package/dist/components/features/shared-data/SharedDataSelectListContext.d.ts.map +0 -1
  617. package/dist/components/features/shared-data/SharedDataSelectListContext.js +0 -27
  618. package/dist/components/features/shared-data/SharedDataSelectListContext.js.map +0 -6
  619. package/dist/components/feedback/busy/BusyContext.d.ts +0 -29
  620. package/dist/components/feedback/busy/BusyContext.d.ts.map +0 -1
  621. package/dist/components/feedback/busy/BusyContext.js +0 -14
  622. package/dist/components/feedback/busy/BusyContext.js.map +0 -6
  623. package/dist/components/feedback/notification/NotificationContext.d.ts +0 -69
  624. package/dist/components/feedback/notification/NotificationContext.d.ts.map +0 -1
  625. package/dist/components/feedback/notification/NotificationContext.js +0 -14
  626. package/dist/components/feedback/notification/NotificationContext.js.map +0 -6
  627. package/dist/components/feedback/notification/index.d.ts +0 -5
  628. package/dist/components/feedback/notification/index.d.ts.map +0 -1
  629. package/dist/components/feedback/notification/index.js +0 -5
  630. package/dist/components/feedback/notification/index.js.map +0 -6
  631. package/dist/components/feedback/print/PrintContext.d.ts +0 -12
  632. package/dist/components/feedback/print/PrintContext.d.ts.map +0 -1
  633. package/dist/components/feedback/print/PrintContext.js +0 -12
  634. package/dist/components/feedback/print/PrintContext.js.map +0 -6
  635. package/dist/components/feedback/print/PrintInstanceContext.d.ts +0 -6
  636. package/dist/components/feedback/print/PrintInstanceContext.d.ts.map +0 -1
  637. package/dist/components/feedback/print/PrintInstanceContext.js +0 -10
  638. package/dist/components/feedback/print/PrintInstanceContext.js.map +0 -6
  639. package/dist/components/form-control/combobox/ComboboxContext.d.ts +0 -14
  640. package/dist/components/form-control/combobox/ComboboxContext.d.ts.map +0 -1
  641. package/dist/components/form-control/combobox/ComboboxContext.js +0 -14
  642. package/dist/components/form-control/combobox/ComboboxContext.js.map +0 -6
  643. package/dist/components/form-control/combobox/ComboboxItem.d.ts +0 -12
  644. package/dist/components/form-control/combobox/ComboboxItem.d.ts.map +0 -1
  645. package/dist/components/form-control/combobox/ComboboxItem.js +0 -56
  646. package/dist/components/form-control/combobox/ComboboxItem.js.map +0 -6
  647. package/dist/components/form-control/select/SelectContext.d.ts +0 -21
  648. package/dist/components/form-control/select/SelectContext.d.ts.map +0 -1
  649. package/dist/components/form-control/select/SelectContext.js +0 -14
  650. package/dist/components/form-control/select/SelectContext.js.map +0 -6
  651. package/dist/components/form-control/select/SelectItem.d.ts +0 -30
  652. package/dist/components/form-control/select/SelectItem.d.ts.map +0 -1
  653. package/dist/components/form-control/select/SelectItem.js +0 -112
  654. package/dist/components/form-control/select/SelectItem.js.map +0 -6
  655. package/dist/components/layout/sidebar/SidebarContainer.d.ts +0 -34
  656. package/dist/components/layout/sidebar/SidebarContainer.d.ts.map +0 -1
  657. package/dist/components/layout/sidebar/SidebarContainer.js +0 -88
  658. package/dist/components/layout/sidebar/SidebarContainer.js.map +0 -6
  659. package/dist/components/layout/sidebar/SidebarContext.d.ts +0 -28
  660. package/dist/components/layout/sidebar/SidebarContext.d.ts.map +0 -1
  661. package/dist/components/layout/sidebar/SidebarContext.js +0 -20
  662. package/dist/components/layout/sidebar/SidebarContext.js.map +0 -6
  663. package/dist/components/layout/sidebar/SidebarMenu.d.ts +0 -35
  664. package/dist/components/layout/sidebar/SidebarMenu.d.ts.map +0 -1
  665. package/dist/components/layout/sidebar/SidebarMenu.js +0 -153
  666. package/dist/components/layout/sidebar/SidebarMenu.js.map +0 -6
  667. package/dist/components/layout/sidebar/SidebarUser.d.ts +0 -48
  668. package/dist/components/layout/sidebar/SidebarUser.d.ts.map +0 -1
  669. package/dist/components/layout/sidebar/SidebarUser.js +0 -128
  670. package/dist/components/layout/sidebar/SidebarUser.js.map +0 -6
  671. package/dist/components/layout/topbar/TopbarActions.d.ts +0 -3
  672. package/dist/components/layout/topbar/TopbarActions.d.ts.map +0 -1
  673. package/dist/components/layout/topbar/TopbarActions.js +0 -17
  674. package/dist/components/layout/topbar/TopbarActions.js.map +0 -6
  675. package/dist/components/layout/topbar/TopbarContainer.d.ts +0 -25
  676. package/dist/components/layout/topbar/TopbarContainer.d.ts.map +0 -1
  677. package/dist/components/layout/topbar/TopbarContainer.js +0 -37
  678. package/dist/components/layout/topbar/TopbarContainer.js.map +0 -6
  679. package/dist/components/layout/topbar/TopbarContext.d.ts +0 -9
  680. package/dist/components/layout/topbar/TopbarContext.d.ts.map +0 -1
  681. package/dist/components/layout/topbar/TopbarContext.js +0 -29
  682. package/dist/components/layout/topbar/TopbarContext.js.map +0 -6
  683. package/dist/components/layout/topbar/TopbarMenu.d.ts +0 -41
  684. package/dist/components/layout/topbar/TopbarMenu.d.ts.map +0 -1
  685. package/dist/components/layout/topbar/TopbarMenu.js +0 -288
  686. package/dist/components/layout/topbar/TopbarMenu.js.map +0 -6
  687. package/dist/components/layout/topbar/TopbarUser.d.ts +0 -35
  688. package/dist/components/layout/topbar/TopbarUser.d.ts.map +0 -1
  689. package/dist/components/layout/topbar/TopbarUser.js +0 -110
  690. package/dist/components/layout/topbar/TopbarUser.js.map +0 -6
  691. package/dist/helpers/createHmrSafeContext.d.ts +0 -3
  692. package/dist/helpers/createHmrSafeContext.d.ts.map +0 -1
  693. package/dist/helpers/createHmrSafeContext.js +0 -10
  694. package/dist/helpers/createHmrSafeContext.js.map +0 -6
  695. package/dist/helpers/createSlotComponent.d.ts +0 -12
  696. package/dist/helpers/createSlotComponent.d.ts.map +0 -1
  697. package/dist/helpers/createSlotComponent.js +0 -13
  698. package/dist/helpers/createSlotComponent.js.map +0 -6
  699. package/dist/hooks/createSelectionGroup.d.ts +0 -70
  700. package/dist/hooks/createSelectionGroup.d.ts.map +0 -1
  701. package/dist/hooks/createSelectionGroup.js +0 -145
  702. package/dist/hooks/createSelectionGroup.js.map +0 -6
  703. package/dist/hooks/createSlotSignal.d.ts +0 -9
  704. package/dist/hooks/createSlotSignal.d.ts.map +0 -1
  705. package/dist/hooks/createSlotSignal.js +0 -10
  706. package/dist/hooks/createSlotSignal.js.map +0 -6
  707. package/dist/providers/LoggerContext.d.ts.map +0 -1
  708. package/dist/providers/ServiceClientContext.d.ts +0 -23
  709. package/dist/providers/ServiceClientContext.d.ts.map +0 -1
  710. package/dist/providers/ServiceClientContext.js +0 -14
  711. package/dist/providers/ServiceClientContext.js.map +0 -6
  712. package/dist/providers/SyncStorageContext.d.ts.map +0 -1
  713. package/dist/providers/i18n/I18nContext.d.ts.map +0 -1
  714. package/dist/providers/i18n/I18nContext.types.d.ts.map +0 -1
  715. package/dist/providers/i18n/I18nContext.types.js +0 -1
  716. package/dist/providers/shared-data/SharedDataContext.d.ts +0 -77
  717. package/dist/providers/shared-data/SharedDataContext.d.ts.map +0 -1
  718. package/dist/providers/shared-data/SharedDataContext.js +0 -14
  719. package/dist/providers/shared-data/SharedDataContext.js.map +0 -6
  720. package/dist/styles/patterns.styles.d.ts +0 -7
  721. package/dist/styles/patterns.styles.d.ts.map +0 -1
  722. package/dist/styles/patterns.styles.js +0 -47
  723. package/dist/styles/patterns.styles.js.map +0 -6
  724. package/dist/styles/tokens.styles.d.ts +0 -23
  725. package/dist/styles/tokens.styles.d.ts.map +0 -1
  726. package/dist/styles/tokens.styles.js +0 -76
  727. package/dist/styles/tokens.styles.js.map +0 -6
  728. package/src/components/data/kanban/KanbanContext.ts +0 -76
  729. package/src/components/data/sheet/DataSheet.css +0 -44
  730. package/src/components/disclosure/DialogContext.ts +0 -69
  731. package/src/components/disclosure/DialogInstanceContext.ts +0 -25
  732. package/src/components/disclosure/DialogProvider.tsx +0 -147
  733. package/src/components/features/shared-data/SharedDataSelectListContext.ts +0 -39
  734. package/src/components/feedback/busy/BusyContext.ts +0 -38
  735. package/src/components/feedback/notification/NotificationContext.ts +0 -95
  736. package/src/components/feedback/notification/index.ts +0 -4
  737. package/src/components/feedback/print/PrintContext.ts +0 -20
  738. package/src/components/feedback/print/PrintInstanceContext.ts +0 -11
  739. package/src/components/form-control/combobox/ComboboxContext.ts +0 -25
  740. package/src/components/form-control/combobox/ComboboxItem.tsx +0 -69
  741. package/src/components/form-control/select/SelectContext.ts +0 -35
  742. package/src/components/form-control/select/SelectItem.tsx +0 -128
  743. package/src/components/layout/sidebar/SidebarContainer.tsx +0 -123
  744. package/src/components/layout/sidebar/SidebarContext.ts +0 -40
  745. package/src/components/layout/sidebar/SidebarMenu.tsx +0 -182
  746. package/src/components/layout/sidebar/SidebarUser.tsx +0 -142
  747. package/src/components/layout/topbar/TopbarActions.tsx +0 -8
  748. package/src/components/layout/topbar/TopbarContainer.tsx +0 -44
  749. package/src/components/layout/topbar/TopbarContext.ts +0 -36
  750. package/src/components/layout/topbar/TopbarMenu.tsx +0 -227
  751. package/src/components/layout/topbar/TopbarUser.tsx +0 -97
  752. package/src/helpers/createHmrSafeContext.ts +0 -8
  753. package/src/helpers/createSlotComponent.ts +0 -23
  754. package/src/hooks/createSelectionGroup.tsx +0 -241
  755. package/src/hooks/createSlotSignal.ts +0 -14
  756. package/src/providers/ServiceClientContext.ts +0 -32
  757. package/src/providers/shared-data/SharedDataContext.ts +0 -91
  758. package/src/styles/patterns.styles.ts +0 -50
  759. package/src/styles/tokens.styles.ts +0 -86
  760. package/tests/components/data/Table.spec.tsx +0 -55
  761. package/tests/components/display/Alert.spec.tsx +0 -47
  762. package/tests/components/display/Card.spec.tsx +0 -41
  763. package/tests/components/display/Link.spec.tsx +0 -62
  764. package/tests/components/display/Tag.spec.tsx +0 -47
  765. package/tests/components/feedback/print/Print.spec.tsx +0 -45
  766. package/tests/components/layout/FormGroup.spec.tsx +0 -104
  767. package/tests/components/layout/FormTable.spec.tsx +0 -43
  768. package/tests/components/layout/topbar/TopbarContainer.spec.tsx +0 -38
  769. package/tests/providers/ClipboardProvider.spec.tsx +0 -20
  770. package/tests/providers/ConfigContext.spec.tsx +0 -42
  771. package/tests/providers/LoggerContext.spec.tsx +0 -76
  772. package/tests/providers/PwaUpdateProvider.spec.tsx +0 -32
  773. package/tests/providers/SyncStorageContext.spec.tsx +0 -77
  774. /package/dist/components/data/sheet/{types.js.map → DataSheet.types.js.map} +0 -0
  775. /package/dist/components/{features/crud-detail/types.js.map → display/Barcode.types.js.map} +0 -0
  776. /package/dist/components/features/{crud-sheet/types.js.map → crud-detail/CrudDetail.types.js.map} +0 -0
  777. /package/dist/{providers/i18n/I18nContext.types.js.map → components/features/crud-sheet/CrudSheet.types.js.map} +0 -0
  778. /package/dist/components/feedback/busy/{BusyContainer.css → BusyContainer.animate.css} +0 -0
  779. /package/src/components/feedback/busy/{BusyContainer.css → BusyContainer.animate.css} +0 -0
  780. /package/src/providers/{LoggerContext.tsx → LoggerProvider.tsx} +0 -0
  781. /package/src/providers/{SyncStorageContext.tsx → SyncStorageProvider.tsx} +0 -0
  782. /package/src/providers/i18n/{I18nContext.types.ts → I18nProvider.types.ts} +0 -0
@@ -10,33 +10,101 @@ import {
10
10
  Show,
11
11
  splitProps,
12
12
  useContext,
13
+ type Accessor,
14
+ type Component,
13
15
  } from "solid-js";
14
- import { Portal } from "solid-js/web";
16
+ import { Portal, Dynamic } from "solid-js/web";
15
17
  import clsx from "clsx";
16
18
  import { twMerge } from "tailwind-merge";
17
19
  import { IconX } from "@tabler/icons-solidjs";
18
20
  import { createControllableSignal } from "../../hooks/createControllableSignal";
19
- import { createSlotSignal, type SlotAccessor } from "../../hooks/createSlotSignal";
20
21
  import { createMountTransition } from "../../hooks/createMountTransition";
21
22
  import { startPointerDrag } from "../../helpers/startPointerDrag";
22
- import { createSlotComponent } from "../../helpers/createSlotComponent";
23
+ import { createSlot } from "../../helpers/createSlot";
23
24
  import { mergeStyles } from "../../helpers/mergeStyles";
24
- import { useI18n } from "../../providers/i18n/I18nContext";
25
+ import { useI18n } from "../../providers/i18n/I18nProvider";
25
26
  import { Icon } from "../display/Icon";
26
- import { borderSubtle } from "../../styles/tokens.styles";
27
- import { DialogDefaultsContext } from "./DialogContext";
27
+ import { bg, border } from "../../styles/base.styles";
28
28
  import { bringToFront, registerDialog, unregisterDialog, isTopmost } from "./dialogZIndex";
29
29
  import { Button } from "../form-control/Button";
30
30
 
31
- interface DialogSlotsContextValue {
32
- setHeader: (content: SlotAccessor) => void;
33
- setAction: (content: SlotAccessor) => void;
31
+ //#region Dialog Context Types & Utilities
32
+
33
+ /** Dialog default configuration */
34
+ export interface DialogDefaults {
35
+ /** Allow closing via ESC key */
36
+ closeOnEscape?: boolean;
37
+ /** Allow closing via backdrop click */
38
+ closeOnInteractOutside?: boolean;
39
+ }
40
+
41
+ /** Dialog default configuration Context */
42
+ export const DialogDefaultsContext = createContext<Accessor<DialogDefaults>>();
43
+
44
+ /** Programmatic dialog options */
45
+ export interface DialogShowOptions {
46
+ /** Dialog header */
47
+ header?: JSX.Element;
48
+ /** Show close button */
49
+ closable?: boolean;
50
+ /** Close on backdrop click */
51
+ closeOnInteractOutside?: boolean;
52
+ /** Close on ESC key */
53
+ closeOnEscape?: boolean;
54
+ /** Resizable */
55
+ resizable?: boolean;
56
+ /** Draggable */
57
+ draggable?: boolean;
58
+ /** Display mode */
59
+ mode?: "float" | "fill";
60
+ /** Initial width (px) */
61
+ width?: number;
62
+ /** Initial height (px) */
63
+ height?: number;
64
+ /** Minimum width (px) */
65
+ minWidth?: number;
66
+ /** Minimum height (px) */
67
+ minHeight?: number;
68
+ /** Floating position */
69
+ position?: "bottom-right" | "top-right";
70
+ /** Custom header style */
71
+ headerStyle?: JSX.CSSProperties | string;
72
+ /** Confirmation function before closing (return false to cancel) */
73
+ beforeClose?: () => boolean;
34
74
  }
35
75
 
36
- const DialogSlotsContext = createContext<DialogSlotsContextValue>();
76
+ /** Extract result type from component's close prop */
77
+ export type ExtractCloseResult<P> =
78
+ P extends { close?: (result?: infer T) => void } ? T : undefined;
79
+
80
+ /** Programmatic dialog Context value */
81
+ export interface DialogContextValue {
82
+ /** Open dialog and wait until closing, returns result */
83
+ show<P extends Record<string, any>>(
84
+ component: Component<P>,
85
+ props: "close" extends keyof P ? Omit<P, "close"> : never,
86
+ options?: DialogShowOptions,
87
+ ): Promise<ExtractCloseResult<P> | undefined>;
88
+ }
89
+
90
+ /** Programmatic dialog Context */
91
+ export const DialogContext = createContext<DialogContextValue>();
92
+
93
+ /**
94
+ * Hook to access programmatic dialogs
95
+ *
96
+ * @throws Throws error if DialogProvider is not present
97
+ */
98
+ export function useDialog(): DialogContextValue {
99
+ const ctx = useContext(DialogContext);
100
+ if (!ctx) throw new Error("useDialog can only be used inside DialogProvider");
101
+ return ctx;
102
+ }
103
+
104
+ //#endregion
37
105
 
38
- const DialogHeader = createSlotComponent(DialogSlotsContext, (ctx) => ctx.setHeader);
39
- const DialogAction = createSlotComponent(DialogSlotsContext, (ctx) => ctx.setAction);
106
+ const [DialogHeader, createHeaderSlotAccessor] = createSlot<{ children: JSX.Element }>();
107
+ const [DialogAction, createActionSlotAccessor] = createSlot<{ children: JSX.Element }>();
40
108
 
41
109
  export interface DialogProps {
42
110
  /** Dialog open state */
@@ -46,17 +114,15 @@ export interface DialogProps {
46
114
  /** Show close button (default: true) */
47
115
  closable?: boolean;
48
116
  /** Close on backdrop click */
49
- closeOnBackdrop?: boolean;
117
+ closeOnInteractOutside?: boolean;
50
118
  /** Close on Escape key (default: true) */
51
119
  closeOnEscape?: boolean;
52
120
  /** Resizable (default: false) */
53
121
  resizable?: boolean;
54
122
  /** Draggable (default: true) */
55
- movable?: boolean;
56
- /** Floating mode (no backdrop) */
57
- float?: boolean;
58
- /** Full-screen mode */
59
- fill?: boolean;
123
+ draggable?: boolean;
124
+ /** Display mode */
125
+ mode?: "float" | "fill";
60
126
  /** Width */
61
127
  width?: number;
62
128
  /** Height */
@@ -70,7 +136,7 @@ export interface DialogProps {
70
136
  /** Header style */
71
137
  headerStyle?: JSX.CSSProperties | string;
72
138
  /** Confirmation function before closing */
73
- canDeactivate?: () => boolean;
139
+ beforeClose?: () => boolean;
74
140
  /** Callback after close animation completes */
75
141
  onCloseComplete?: () => void;
76
142
  /** Additional CSS class */
@@ -109,8 +175,6 @@ const resizeCursorMap: Record<ResizeDirection, string> = {
109
175
  "bottom-right": "cursor-nwse-resize",
110
176
  };
111
177
 
112
- const dialogContentClass = clsx("flex-1", "overflow-auto");
113
-
114
178
  const resizePositionMap: Record<ResizeDirection, string> = {
115
179
  "left": clsx("left-0 top-0", "h-full w-1.5"),
116
180
  "right": clsx("right-0 top-0", "h-full w-1.5"),
@@ -139,12 +203,7 @@ const resizePositionMap: Record<ResizeDirection, string> = {
139
203
  * </Dialog>
140
204
  * ```
141
205
  */
142
- interface DialogComponent extends ParentComponent<DialogProps> {
143
- Header: typeof DialogHeader;
144
- Action: typeof DialogAction;
145
- }
146
-
147
- export const Dialog: DialogComponent = (props) => {
206
+ const DialogInner: ParentComponent<DialogProps> = (props) => {
148
207
  const dialogDefaults = useContext(DialogDefaultsContext);
149
208
  const i18n = useI18n();
150
209
 
@@ -152,19 +211,18 @@ export const Dialog: DialogComponent = (props) => {
152
211
  "open",
153
212
  "onOpenChange",
154
213
  "closable",
155
- "closeOnBackdrop",
214
+ "closeOnInteractOutside",
156
215
  "closeOnEscape",
157
216
  "resizable",
158
- "movable",
159
- "float",
160
- "fill",
217
+ "draggable",
218
+ "mode",
161
219
  "width",
162
220
  "height",
163
221
  "minWidth",
164
222
  "minHeight",
165
223
  "position",
166
224
  "headerStyle",
167
- "canDeactivate",
225
+ "beforeClose",
168
226
  "onCloseComplete",
169
227
  "class",
170
228
  "children",
@@ -172,8 +230,8 @@ export const Dialog: DialogComponent = (props) => {
172
230
 
173
231
  const headerId = "dialog-header-" + createUniqueId();
174
232
 
175
- const [header, setHeader] = createSlotSignal();
176
- const [action, setAction] = createSlotSignal();
233
+ const [header, HeaderProvider] = createHeaderSlotAccessor();
234
+ const [action, ActionProvider] = createActionSlotAccessor();
177
235
  const hasHeader = () => header() !== undefined;
178
236
 
179
237
  const [open, setOpen] = createControllableSignal({
@@ -216,8 +274,8 @@ export const Dialog: DialogComponent = (props) => {
216
274
  const [wrapperRef, setWrapperRef] = createSignal<HTMLDivElement>();
217
275
 
218
276
  const closeOnEscape = () => local.closeOnEscape ?? dialogDefaults?.().closeOnEscape ?? true;
219
- const closeOnBackdrop = () =>
220
- local.closeOnBackdrop ?? dialogDefaults?.().closeOnBackdrop ?? false;
277
+ const closeOnInteractOutside = () =>
278
+ local.closeOnInteractOutside ?? dialogDefaults?.().closeOnInteractOutside ?? false;
221
279
 
222
280
  // Detect Escape key
223
281
  createEffect(() => {
@@ -248,15 +306,15 @@ export const Dialog: DialogComponent = (props) => {
248
306
  onCleanup(() => unregisterDialog(el));
249
307
  });
250
308
 
251
- // Attempt to close (check canDeactivate)
309
+ // Attempt to close (check beforeClose)
252
310
  const tryClose = () => {
253
- if (local.canDeactivate && !local.canDeactivate()) return;
311
+ if (local.beforeClose && !local.beforeClose()) return;
254
312
  setOpen(false);
255
313
  };
256
314
 
257
315
  // Backdrop click handler
258
316
  const handleBackdropClick = () => {
259
- if (!closeOnBackdrop()) return;
317
+ if (!closeOnInteractOutside()) return;
260
318
  tryClose();
261
319
  };
262
320
 
@@ -282,8 +340,8 @@ export const Dialog: DialogComponent = (props) => {
282
340
 
283
341
  // Dragging
284
342
  const handleHeaderPointerDown = (event: PointerEvent) => {
285
- // movable default is true
286
- if (local.movable === false) return;
343
+ // draggable default is true
344
+ if (local.draggable === false) return;
287
345
  const wrapperEl = wrapperRef();
288
346
  if (!dialogRef || !wrapperEl) return;
289
347
  // Do not treat events from interactive elements like close button as drag
@@ -387,7 +445,7 @@ export const Dialog: DialogComponent = (props) => {
387
445
  const dialogStyle = (): JSX.CSSProperties => {
388
446
  const style: JSX.CSSProperties = {};
389
447
 
390
- if (local.fill) {
448
+ if (local.mode === "fill") {
391
449
  style.width = "100%";
392
450
  style.height = "100%";
393
451
  } else {
@@ -436,8 +494,8 @@ export const Dialog: DialogComponent = (props) => {
436
494
  clsx(
437
495
  "fixed bottom-0 left-0 right-0 top-0",
438
496
  "flex flex-col items-center",
439
- !local.fill && "pt-[calc(3rem+0.5rem)]",
440
- local.float && "pointer-events-none",
497
+ local.mode !== "fill" && "pt-[calc(3rem+0.5rem)]",
498
+ local.mode === "float" && "pointer-events-none",
441
499
  );
442
500
 
443
501
  // Backdrop class
@@ -459,29 +517,30 @@ export const Dialog: DialogComponent = (props) => {
459
517
  "relative",
460
518
  "mx-auto",
461
519
  "w-fit min-w-[200px]",
462
- "bg-white dark:bg-base-800",
463
- local.float
464
- ? clsx("shadow-md dark:shadow-black/30", "border", borderSubtle)
520
+ bg.surface,
521
+ local.mode === "float"
522
+ ? clsx("shadow-md dark:shadow-black/30", "border", border.subtle)
465
523
  : "shadow-2xl dark:shadow-black/40",
466
- local.fill ? "rounded-none border-none" : "rounded-lg",
524
+ local.mode === "fill" ? "rounded-none border-none" : "rounded-lg",
467
525
  "overflow-hidden",
468
526
  "flex flex-col",
469
527
  "focus:outline-none",
470
- local.float && "pointer-events-auto",
528
+ local.mode === "float" && "pointer-events-auto",
471
529
  animationClass(),
472
530
  );
473
531
 
474
532
  // Header class
475
533
  const headerClass = () =>
476
- clsx("flex items-center gap-2", "px-3 py-1", "select-none", "border-b", borderSubtle);
534
+ clsx("flex items-center gap-2", "px-3 py-1", "select-none", "border-b", border.subtle);
477
535
 
478
536
  return (
479
537
  <Show when={mounted()}>
480
538
  <Portal>
481
- <DialogSlotsContext.Provider value={{ setHeader, setAction }}>
539
+ <HeaderProvider>
540
+ <ActionProvider>
482
541
  <div ref={setWrapperRef} data-dialog class={wrapperClass()}>
483
542
  {/* Backdrop */}
484
- <Show when={!local.float}>
543
+ <Show when={local.mode !== "float"}>
485
544
  <div data-dialog-backdrop class={backdropClass()} onClick={handleBackdropClick} />
486
545
  </Show>
487
546
 
@@ -492,7 +551,7 @@ export const Dialog: DialogComponent = (props) => {
492
551
  }}
493
552
  data-dialog-panel
494
553
  role="dialog"
495
- aria-modal={local.float ? undefined : true}
554
+ aria-modal={local.mode === "float" ? undefined : true}
496
555
  aria-labelledby={hasHeader() ? headerId : undefined}
497
556
  tabIndex={0}
498
557
  class={twMerge(dialogBaseClass(), local.class)}
@@ -513,9 +572,9 @@ export const Dialog: DialogComponent = (props) => {
513
572
  onPointerDown={handleHeaderPointerDown}
514
573
  >
515
574
  <h5 id={headerId} class={clsx("flex-1 font-bold")}>
516
- {header()!()}
575
+ {header()!.children}
517
576
  </h5>
518
- <Show when={action()}>{action()!()}</Show>
577
+ <Show when={action()}>{action()!.children}</Show>
519
578
  <Show when={local.closable ?? true}>
520
579
  <Button
521
580
  data-dialog-close
@@ -531,7 +590,7 @@ export const Dialog: DialogComponent = (props) => {
531
590
  </Show>
532
591
 
533
592
  {/* Content */}
534
- <div data-dialog-content class={dialogContentClass}>
593
+ <div data-dialog-content class="flex-1 overflow-auto">
535
594
  {local.children}
536
595
  </div>
537
596
 
@@ -554,11 +613,147 @@ export const Dialog: DialogComponent = (props) => {
554
613
  </Show>
555
614
  </div>
556
615
  </div>
557
- </DialogSlotsContext.Provider>
616
+ </ActionProvider>
617
+ </HeaderProvider>
558
618
  </Portal>
559
619
  </Show>
560
620
  );
561
621
  };
562
622
 
563
- Dialog.Header = DialogHeader;
564
- Dialog.Action = DialogAction;
623
+ //#region Export
624
+ export const Dialog = Object.assign(DialogInner, {
625
+ Header: DialogHeader,
626
+ Action: DialogAction,
627
+ });
628
+ //#endregion
629
+
630
+ //#region DialogProvider
631
+
632
+ interface DialogEntry {
633
+ id: string;
634
+ component: Component<any>;
635
+ props: Record<string, unknown>;
636
+ options: DialogShowOptions;
637
+ resolve: (result: unknown) => void;
638
+ open: Accessor<boolean>;
639
+ setOpen: (value: boolean) => void;
640
+ pendingResult?: unknown;
641
+ }
642
+
643
+ let nextId = 0;
644
+
645
+ /**
646
+ * Programmatic dialog Provider
647
+ *
648
+ * Open dialogs with `useDialog().show(component, props, options)`,
649
+ * and close them with `props.close(result)` to resolve the Promise.
650
+ *
651
+ * @example
652
+ * ```tsx
653
+ * <DialogProvider>
654
+ * <App />
655
+ * </DialogProvider>
656
+ * ```
657
+ */
658
+ export interface DialogProviderProps extends DialogDefaults {}
659
+
660
+ export const DialogProvider: ParentComponent<DialogProviderProps> = (props) => {
661
+ const [local, _rest] = splitProps(props, ["closeOnEscape", "closeOnInteractOutside", "children"]);
662
+
663
+ const defaults = () => ({
664
+ closeOnEscape: local.closeOnEscape,
665
+ closeOnInteractOutside: local.closeOnInteractOutside,
666
+ });
667
+
668
+ const [entries, setEntries] = createSignal<DialogEntry[]>([]);
669
+
670
+ const show = <P extends Record<string, any>,>(
671
+ component: Component<P>,
672
+ componentProps: Record<string, any>,
673
+ options?: DialogShowOptions,
674
+ ): Promise<any> => {
675
+ return new Promise((resolve) => {
676
+ const id = String(nextId++);
677
+ const [open, setOpen] = createSignal(true);
678
+ const entry: DialogEntry = {
679
+ id,
680
+ component,
681
+ props: componentProps,
682
+ options: options ?? {},
683
+ resolve,
684
+ open,
685
+ setOpen,
686
+ };
687
+ setEntries((prev) => [...prev, entry]);
688
+ });
689
+ };
690
+
691
+ // Start close animation (set open to false)
692
+ const requestClose = (id: string, result?: unknown) => {
693
+ const entry = entries().find((e) => e.id === id);
694
+ if (entry) {
695
+ entry.pendingResult = result;
696
+ entry.setOpen(false);
697
+ }
698
+ };
699
+
700
+ // Actually remove after animation completes
701
+ const removeEntry = (id: string) => {
702
+ setEntries((prev) => {
703
+ const entry = prev.find((e) => e.id === id);
704
+ if (entry) {
705
+ entry.resolve(entry.pendingResult);
706
+ }
707
+ return prev.filter((e) => e.id !== id);
708
+ });
709
+ };
710
+
711
+ const contextValue: DialogContextValue = {
712
+ show,
713
+ };
714
+
715
+ return (
716
+ <DialogDefaultsContext.Provider value={defaults}>
717
+ <DialogContext.Provider value={contextValue}>
718
+ {local.children}
719
+ <For each={entries()}>
720
+ {(entry) => (
721
+ <Dialog
722
+ open={entry.open()}
723
+ onOpenChange={(open) => {
724
+ if (!open && entry.pendingResult === undefined) {
725
+ requestClose(entry.id);
726
+ }
727
+ }}
728
+ onCloseComplete={() => removeEntry(entry.id)}
729
+ closable={entry.options.closable}
730
+ closeOnInteractOutside={entry.options.closeOnInteractOutside}
731
+ closeOnEscape={entry.options.closeOnEscape}
732
+ resizable={entry.options.resizable}
733
+ draggable={entry.options.draggable}
734
+ mode={entry.options.mode}
735
+ width={entry.options.width}
736
+ height={entry.options.height}
737
+ minWidth={entry.options.minWidth}
738
+ minHeight={entry.options.minHeight}
739
+ position={entry.options.position}
740
+ headerStyle={entry.options.headerStyle}
741
+ beforeClose={entry.options.beforeClose}
742
+ >
743
+ <Show when={entry.options.header !== undefined}>
744
+ <Dialog.Header>{entry.options.header}</Dialog.Header>
745
+ </Show>
746
+ <Dynamic
747
+ component={entry.component}
748
+ {...entry.props}
749
+ close={(result?: unknown) => requestClose(entry.id, result)}
750
+ />
751
+ </Dialog>
752
+ )}
753
+ </For>
754
+ </DialogContext.Provider>
755
+ </DialogDefaultsContext.Provider>
756
+ );
757
+ };
758
+
759
+ //#endregion
@@ -3,40 +3,25 @@ import {
3
3
  type ParentComponent,
4
4
  createSignal,
5
5
  createEffect,
6
- createContext,
7
6
  onCleanup,
8
7
  Show,
9
8
  splitProps,
10
9
  } from "solid-js";
11
10
  import { createResizeObserver } from "@solid-primitives/resize-observer";
12
11
  import { createControllableSignal } from "../../hooks/createControllableSignal";
13
- import { createSlotSignal, type SlotAccessor } from "../../hooks/createSlotSignal";
14
12
  import { createMountTransition } from "../../hooks/createMountTransition";
15
13
  import { Portal } from "solid-js/web";
16
14
  import clsx from "clsx";
17
15
  import { twMerge } from "tailwind-merge";
18
16
  import { mergeStyles } from "../../helpers/mergeStyles";
19
- import { createSlotComponent } from "../../helpers/createSlotComponent";
20
- import { borderSubtle } from "../../styles/tokens.styles";
17
+ import { createSlot } from "../../helpers/createSlot";
18
+ import { bg, border } from "../../styles/base.styles";
21
19
  import { tabbable } from "tabbable";
22
20
 
23
- // --- DropdownContext (internal) ---
21
+ // --- DropdownTrigger / DropdownContent slots ---
24
22
 
25
- interface DropdownContextValue {
26
- toggle: () => void;
27
- setTrigger: (content: SlotAccessor) => void;
28
- setContent: (content: SlotAccessor) => void;
29
- }
30
-
31
- const DropdownContext = createContext<DropdownContextValue>();
32
-
33
- // --- DropdownTrigger ---
34
-
35
- const DropdownTrigger = createSlotComponent(DropdownContext, (ctx) => ctx.setTrigger);
36
-
37
- // --- DropdownContent ---
38
-
39
- const DropdownContent = createSlotComponent(DropdownContext, (ctx) => ctx.setContent);
23
+ const [DropdownTrigger, createTriggerSlotAccessor] = createSlot<{ children: JSX.Element }>();
24
+ const [DropdownContent, createContentSlotAccessor] = createSlot<{ children: JSX.Element }>();
40
25
 
41
26
  // --- Dropdown ---
42
27
 
@@ -100,11 +85,6 @@ export interface DropdownProps {
100
85
  children: JSX.Element;
101
86
  }
102
87
 
103
- interface DropdownComponent extends ParentComponent<DropdownProps> {
104
- Trigger: typeof DropdownTrigger;
105
- Content: typeof DropdownContent;
106
- }
107
-
108
88
  /**
109
89
  * Dropdown popup component
110
90
  *
@@ -132,7 +112,7 @@ interface DropdownComponent extends ParentComponent<DropdownProps> {
132
112
  * </Dropdown>
133
113
  * ```
134
114
  */
135
- export const Dropdown: DropdownComponent = ((props: DropdownProps) => {
115
+ const DropdownInner: ParentComponent<DropdownProps> = (props: DropdownProps) => {
136
116
  const [local, rest] = splitProps(props, [
137
117
  "position",
138
118
  "open",
@@ -156,9 +136,9 @@ export const Dropdown: DropdownComponent = ((props: DropdownProps) => {
156
136
  setOpen(!open());
157
137
  };
158
138
 
159
- // Slot registration signals
160
- const [triggerSlot, setTrigger] = createSlotSignal();
161
- const [contentSlot, setContent] = createSlotSignal();
139
+ // Slot accessors
140
+ const [trigger, TriggerProvider] = createTriggerSlotAccessor();
141
+ const [content, ContentProvider] = createContentSlotAccessor();
162
142
 
163
143
  // Trigger wrapper ref (needed for position calculation)
164
144
  let triggerRef: HTMLDivElement | undefined;
@@ -436,58 +416,64 @@ export const Dropdown: DropdownComponent = ((props: DropdownProps) => {
436
416
  };
437
417
 
438
418
  return (
439
- <DropdownContext.Provider value={{ toggle, setTrigger, setContent }}>
440
- {local.children}
441
-
442
- {/* Render trigger slot (attach click/keyboard handlers to wrapper div) */}
443
- <Show when={triggerSlot()}>
444
- <div
445
- ref={(el) => {
446
- triggerRef = el;
447
- }}
448
- tabIndex={-1}
449
- data-dropdown-trigger
450
- onClick={toggle}
451
- onKeyDown={handleTriggerKeyDown}
452
- >
453
- {triggerSlot()!()}
454
- </div>
455
- </Show>
456
-
457
- {/* Content slot: Portal + popup */}
458
- <Show when={mounted()}>
459
- <Portal>
419
+ <TriggerProvider>
420
+ <ContentProvider>
421
+ {local.children}
422
+
423
+ {/* Render trigger slot (attach click/keyboard handlers to wrapper div) */}
424
+ <Show when={trigger()}>
460
425
  <div
461
- {...rest}
462
- ref={setPopupRef}
463
- data-dropdown
464
- class={twMerge(
465
- clsx(
466
- "fixed",
467
- "z-dropdown",
468
- "bg-white dark:bg-base-800",
469
- "border",
470
- borderSubtle,
471
- "shadow-lg dark:shadow-black/30",
472
- "rounded-md",
473
- "overflow-y-auto",
474
- animationClass(),
475
- ),
476
- local.class,
477
- )}
478
- style={mergeStyles(computedStyle(), local.style, {
479
- "max-height": `${maxHeight()}px`,
480
- })}
481
- onTransitionEnd={handleTransitionEnd}
482
- onKeyDown={handlePopupKeyDown}
426
+ ref={(el) => {
427
+ triggerRef = el;
428
+ }}
429
+ tabIndex={-1}
430
+ data-dropdown-trigger
431
+ onClick={toggle}
432
+ onKeyDown={handleTriggerKeyDown}
483
433
  >
484
- <Show when={contentSlot()}>{contentSlot()!()}</Show>
434
+ {trigger()!.children}
485
435
  </div>
486
- </Portal>
487
- </Show>
488
- </DropdownContext.Provider>
436
+ </Show>
437
+
438
+ {/* Content slot: Portal + popup */}
439
+ <Show when={mounted()}>
440
+ <Portal>
441
+ <div
442
+ {...rest}
443
+ ref={setPopupRef}
444
+ data-dropdown
445
+ class={twMerge(
446
+ clsx(
447
+ "fixed",
448
+ "z-dropdown",
449
+ bg.surface,
450
+ "border",
451
+ border.subtle,
452
+ "shadow-lg dark:shadow-black/30",
453
+ "rounded-md",
454
+ "overflow-y-auto",
455
+ animationClass(),
456
+ ),
457
+ local.class,
458
+ )}
459
+ style={mergeStyles(computedStyle(), local.style, {
460
+ "max-height": `${maxHeight()}px`,
461
+ })}
462
+ onTransitionEnd={handleTransitionEnd}
463
+ onKeyDown={handlePopupKeyDown}
464
+ >
465
+ <Show when={content()}>{content()!.children}</Show>
466
+ </div>
467
+ </Portal>
468
+ </Show>
469
+ </ContentProvider>
470
+ </TriggerProvider>
489
471
  );
490
- }) as DropdownComponent;
491
-
492
- Dropdown.Trigger = DropdownTrigger;
493
- Dropdown.Content = DropdownContent;
472
+ };
473
+
474
+ //#region Export
475
+ export const Dropdown = Object.assign(DropdownInner, {
476
+ Trigger: DropdownTrigger,
477
+ Content: DropdownContent,
478
+ });
479
+ //#endregion