@simplysm/solid 13.0.0-beta.6 → 13.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (777) hide show
  1. package/README.md +103 -1544
  2. package/dist/components/data/Pagination.d.ts.map +1 -0
  3. package/dist/components/data/Pagination.js +102 -56
  4. package/dist/components/data/Pagination.js.map +2 -3
  5. package/dist/components/data/Table.d.ts.map +1 -0
  6. package/dist/components/data/Table.js +16 -8
  7. package/dist/components/data/Table.js.map +2 -3
  8. package/dist/components/data/calendar/Calendar.d.ts.map +1 -0
  9. package/dist/components/data/calendar/Calendar.js +73 -21
  10. package/dist/components/data/calendar/Calendar.js.map +2 -3
  11. package/dist/components/data/kanban/Kanban.css +10 -0
  12. package/dist/components/data/kanban/Kanban.d.ts.map +1 -0
  13. package/dist/components/data/kanban/Kanban.js +181 -103
  14. package/dist/components/data/kanban/Kanban.js.map +2 -3
  15. package/dist/components/data/kanban/KanbanContext.d.ts.map +1 -0
  16. package/dist/components/data/kanban/KanbanContext.js.map +0 -1
  17. package/dist/components/data/list/List.d.ts.map +1 -0
  18. package/dist/components/data/list/List.js +32 -23
  19. package/dist/components/data/list/List.js.map +2 -3
  20. package/dist/components/data/list/ListContext.d.ts.map +1 -0
  21. package/dist/components/data/list/ListContext.js.map +0 -1
  22. package/dist/components/data/list/ListItem.d.ts.map +1 -0
  23. package/dist/components/data/list/ListItem.js +108 -59
  24. package/dist/components/data/list/ListItem.js.map +2 -3
  25. package/dist/components/data/list/ListItem.styles.d.ts.map +1 -0
  26. package/dist/components/data/list/ListItem.styles.js +3 -3
  27. package/dist/components/data/list/ListItem.styles.js.map +0 -1
  28. package/dist/components/data/permission-table/PermissionTable.d.ts.map +1 -0
  29. package/dist/components/data/permission-table/PermissionTable.js +105 -38
  30. package/dist/components/data/permission-table/PermissionTable.js.map +2 -3
  31. package/dist/components/data/sheet/DataSheet.css +26 -0
  32. package/dist/components/data/sheet/DataSheet.d.ts.map +1 -0
  33. package/dist/components/data/sheet/DataSheet.js +654 -438
  34. package/dist/components/data/sheet/DataSheet.js.map +2 -3
  35. package/dist/components/data/sheet/DataSheet.styles.d.ts.map +1 -0
  36. package/dist/components/data/sheet/DataSheet.styles.js +1 -1
  37. package/dist/components/data/sheet/DataSheet.styles.js.map +0 -1
  38. package/dist/components/data/sheet/DataSheetColumn.d.ts.map +1 -0
  39. package/dist/components/data/sheet/DataSheetColumn.js +1 -1
  40. package/dist/components/data/sheet/DataSheetColumn.js.map +2 -3
  41. package/dist/components/data/sheet/DataSheetConfigDialog.d.ts.map +1 -0
  42. package/dist/components/data/sheet/DataSheetConfigDialog.js +92 -18
  43. package/dist/components/data/sheet/DataSheetConfigDialog.js.map +2 -3
  44. package/dist/components/data/sheet/sheetUtils.d.ts.map +1 -0
  45. package/dist/components/data/sheet/sheetUtils.js.map +0 -1
  46. package/dist/components/data/sheet/types.d.ts.map +1 -0
  47. package/dist/components/data/sheet/types.js.map +0 -1
  48. package/dist/components/disclosure/Collapse.d.ts.map +1 -0
  49. package/dist/components/disclosure/Collapse.js +40 -23
  50. package/dist/components/disclosure/Collapse.js.map +2 -3
  51. package/dist/components/disclosure/Dialog.d.ts.map +1 -0
  52. package/dist/components/disclosure/Dialog.js +133 -141
  53. package/dist/components/disclosure/Dialog.js.map +2 -3
  54. package/dist/components/disclosure/DialogContext.d.ts.map +1 -0
  55. package/dist/components/disclosure/DialogContext.js.map +0 -1
  56. package/dist/components/disclosure/DialogInstanceContext.d.ts.map +1 -0
  57. package/dist/components/disclosure/DialogInstanceContext.js.map +0 -1
  58. package/dist/components/disclosure/DialogProvider.d.ts.map +1 -0
  59. package/dist/components/disclosure/DialogProvider.js +92 -40
  60. package/dist/components/disclosure/DialogProvider.js.map +2 -3
  61. package/dist/components/disclosure/Dropdown.d.ts.map +1 -0
  62. package/dist/components/disclosure/Dropdown.js +62 -47
  63. package/dist/components/disclosure/Dropdown.js.map +2 -3
  64. package/dist/components/disclosure/Tabs.d.ts.map +1 -0
  65. package/dist/components/disclosure/Tabs.js +57 -29
  66. package/dist/components/disclosure/Tabs.js.map +2 -3
  67. package/dist/components/disclosure/dialogZIndex.d.ts.map +1 -0
  68. package/dist/components/disclosure/dialogZIndex.js.map +0 -1
  69. package/dist/components/display/Alert.d.ts.map +1 -0
  70. package/dist/components/display/Alert.js +16 -2
  71. package/dist/components/display/Alert.js.map +2 -3
  72. package/dist/components/display/Barcode.d.ts.map +1 -0
  73. package/dist/components/display/Barcode.js +16 -1
  74. package/dist/components/display/Barcode.js.map +2 -3
  75. package/dist/components/display/Card.css +14 -0
  76. package/dist/components/display/Card.d.ts.map +1 -0
  77. package/dist/components/display/Card.js +16 -10
  78. package/dist/components/display/Card.js.map +2 -3
  79. package/dist/{solid/src/components → components}/display/Echarts.d.ts +2 -2
  80. package/dist/components/display/Echarts.d.ts.map +1 -0
  81. package/dist/components/display/Echarts.js +28 -6
  82. package/dist/components/display/Echarts.js.map +2 -3
  83. package/dist/components/display/Icon.d.ts.map +1 -0
  84. package/dist/components/display/Icon.js +12 -1
  85. package/dist/components/display/Icon.js.map +2 -3
  86. package/dist/components/display/Tag.d.ts.map +1 -0
  87. package/dist/components/display/Tag.js +17 -5
  88. package/dist/components/display/Tag.js.map +2 -3
  89. package/dist/components/feedback/Progress.d.ts.map +1 -0
  90. package/dist/components/feedback/Progress.js +43 -12
  91. package/dist/components/feedback/Progress.js.map +2 -3
  92. package/dist/components/feedback/loading/LoadingContainer.css +19 -0
  93. package/dist/components/feedback/loading/LoadingContainer.d.ts.map +1 -0
  94. package/dist/components/feedback/loading/LoadingContainer.js +109 -45
  95. package/dist/components/feedback/loading/LoadingContainer.js.map +2 -3
  96. package/dist/components/feedback/loading/LoadingContext.d.ts.map +1 -0
  97. package/dist/components/feedback/loading/LoadingContext.js.map +0 -1
  98. package/dist/components/feedback/loading/LoadingProvider.d.ts.map +1 -0
  99. package/dist/components/feedback/loading/LoadingProvider.js +32 -12
  100. package/dist/components/feedback/loading/LoadingProvider.js.map +2 -3
  101. package/dist/components/feedback/notification/NotificationBanner.d.ts.map +1 -0
  102. package/dist/components/feedback/notification/NotificationBanner.js +64 -30
  103. package/dist/components/feedback/notification/NotificationBanner.js.map +2 -3
  104. package/dist/components/feedback/notification/NotificationBell.d.ts.map +1 -0
  105. package/dist/components/feedback/notification/NotificationBell.js +118 -50
  106. package/dist/components/feedback/notification/NotificationBell.js.map +2 -3
  107. package/dist/components/feedback/notification/NotificationContext.d.ts.map +1 -0
  108. package/dist/components/feedback/notification/NotificationContext.js.map +0 -1
  109. package/dist/components/feedback/notification/NotificationProvider.d.ts.map +1 -0
  110. package/dist/components/feedback/notification/NotificationProvider.js +41 -17
  111. package/dist/components/feedback/notification/NotificationProvider.js.map +2 -3
  112. package/dist/components/feedback/notification/index.d.ts.map +1 -0
  113. package/dist/components/feedback/notification/index.js +4 -4
  114. package/dist/components/feedback/notification/index.js.map +0 -1
  115. package/dist/components/feedback/print/Print.d.ts.map +1 -0
  116. package/dist/components/feedback/print/Print.js +10 -2
  117. package/dist/components/feedback/print/Print.js.map +2 -3
  118. package/dist/components/feedback/print/PrintInstanceContext.d.ts.map +1 -0
  119. package/dist/components/feedback/print/PrintInstanceContext.js.map +0 -1
  120. package/dist/components/form-control/Button.d.ts.map +1 -0
  121. package/dist/components/form-control/Button.js +35 -56
  122. package/dist/components/form-control/Button.js.map +2 -3
  123. package/dist/components/form-control/DropdownTrigger.styles.d.ts.map +1 -0
  124. package/dist/components/form-control/DropdownTrigger.styles.js +2 -2
  125. package/dist/components/form-control/DropdownTrigger.styles.js.map +0 -1
  126. package/dist/components/form-control/Invalid.d.ts +10 -0
  127. package/dist/components/form-control/Invalid.d.ts.map +1 -0
  128. package/dist/components/form-control/Invalid.js +51 -0
  129. package/dist/components/form-control/Invalid.js.map +6 -0
  130. package/dist/components/form-control/ThemeToggle.d.ts.map +1 -0
  131. package/dist/components/form-control/ThemeToggle.js +75 -30
  132. package/dist/components/form-control/ThemeToggle.js.map +2 -3
  133. package/dist/{solid/src/components/form-control/checkbox/Radio.d.ts.map → components/form-control/checkbox/Checkbox.d.ts.map} +1 -1
  134. package/dist/components/form-control/checkbox/Checkbox.js +60 -50
  135. package/dist/components/form-control/checkbox/Checkbox.js.map +2 -3
  136. package/dist/components/form-control/checkbox/Checkbox.styles.d.ts.map +1 -0
  137. package/dist/components/form-control/checkbox/Checkbox.styles.js +2 -2
  138. package/dist/components/form-control/checkbox/Checkbox.styles.js.map +0 -1
  139. package/dist/components/form-control/checkbox/CheckboxGroup.d.ts.map +1 -0
  140. package/dist/components/form-control/checkbox/CheckboxGroup.js +49 -27
  141. package/dist/components/form-control/checkbox/CheckboxGroup.js.map +2 -3
  142. package/dist/components/form-control/checkbox/Radio.d.ts.map +1 -0
  143. package/dist/components/form-control/checkbox/Radio.js +58 -49
  144. package/dist/components/form-control/checkbox/Radio.js.map +2 -3
  145. package/dist/components/form-control/checkbox/RadioGroup.d.ts.map +1 -0
  146. package/dist/components/form-control/checkbox/RadioGroup.js +49 -27
  147. package/dist/components/form-control/checkbox/RadioGroup.js.map +2 -3
  148. package/dist/components/form-control/color-picker/ColorPicker.d.ts.map +1 -0
  149. package/dist/components/form-control/color-picker/ColorPicker.js +30 -21
  150. package/dist/components/form-control/color-picker/ColorPicker.js.map +2 -3
  151. package/dist/components/form-control/combobox/Combobox.d.ts.map +1 -0
  152. package/dist/components/form-control/combobox/Combobox.js +172 -84
  153. package/dist/components/form-control/combobox/Combobox.js.map +2 -3
  154. package/dist/components/form-control/combobox/ComboboxContext.d.ts.map +1 -0
  155. package/dist/components/form-control/combobox/ComboboxContext.js.map +0 -1
  156. package/dist/components/form-control/combobox/ComboboxItem.d.ts.map +1 -0
  157. package/dist/components/form-control/combobox/ComboboxItem.js +38 -31
  158. package/dist/components/form-control/combobox/ComboboxItem.js.map +2 -3
  159. package/dist/components/form-control/date-range-picker/DateRangePicker.d.ts.map +1 -0
  160. package/dist/components/form-control/date-range-picker/DateRangePicker.js +105 -67
  161. package/dist/components/form-control/date-range-picker/DateRangePicker.js.map +2 -3
  162. package/dist/components/form-control/editor/EditorToolbar.d.ts.map +1 -0
  163. package/dist/components/form-control/editor/EditorToolbar.js +211 -248
  164. package/dist/components/form-control/editor/EditorToolbar.js.map +2 -3
  165. package/dist/{solid/src/components → components}/form-control/editor/RichTextEditor.d.ts +0 -2
  166. package/dist/components/form-control/editor/RichTextEditor.d.ts.map +1 -0
  167. package/dist/components/form-control/editor/RichTextEditor.js +73 -58
  168. package/dist/components/form-control/editor/RichTextEditor.js.map +2 -3
  169. package/dist/components/form-control/editor/editor.css +81 -0
  170. package/dist/{solid/src/components → components}/form-control/field/DatePicker.d.ts +0 -2
  171. package/dist/components/form-control/field/DatePicker.d.ts.map +1 -0
  172. package/dist/components/form-control/field/DatePicker.js +123 -91
  173. package/dist/components/form-control/field/DatePicker.js.map +2 -3
  174. package/dist/{solid/src/components → components}/form-control/field/DateTimePicker.d.ts +0 -2
  175. package/dist/components/form-control/field/DateTimePicker.d.ts.map +1 -0
  176. package/dist/components/form-control/field/DateTimePicker.js +123 -108
  177. package/dist/components/form-control/field/DateTimePicker.js.map +2 -3
  178. package/dist/{solid/src/components → components}/form-control/field/Field.styles.d.ts +0 -1
  179. package/dist/components/form-control/field/Field.styles.d.ts.map +1 -0
  180. package/dist/components/form-control/field/Field.styles.js +2 -4
  181. package/dist/components/form-control/field/Field.styles.js.map +1 -2
  182. package/dist/{solid/src/components → components}/form-control/field/NumberInput.d.ts +0 -2
  183. package/dist/components/form-control/field/NumberInput.d.ts.map +1 -0
  184. package/dist/components/form-control/field/NumberInput.js +137 -102
  185. package/dist/components/form-control/field/NumberInput.js.map +2 -3
  186. package/dist/{solid/src/components → components}/form-control/field/TextInput.d.ts +0 -2
  187. package/dist/components/form-control/field/TextInput.d.ts.map +1 -0
  188. package/dist/components/form-control/field/TextInput.js +133 -98
  189. package/dist/components/form-control/field/TextInput.js.map +2 -3
  190. package/dist/{solid/src/components → components}/form-control/field/Textarea.d.ts +0 -2
  191. package/dist/components/form-control/field/Textarea.d.ts.map +1 -0
  192. package/dist/components/form-control/field/Textarea.js +147 -128
  193. package/dist/components/form-control/field/Textarea.js.map +2 -3
  194. package/dist/{solid/src/components → components}/form-control/field/TimePicker.d.ts +0 -2
  195. package/dist/components/form-control/field/TimePicker.d.ts.map +1 -0
  196. package/dist/components/form-control/field/TimePicker.js +115 -87
  197. package/dist/components/form-control/field/TimePicker.js.map +2 -3
  198. package/dist/components/form-control/numpad/Numpad.d.ts.map +1 -0
  199. package/dist/components/form-control/numpad/Numpad.js +189 -31
  200. package/dist/components/form-control/numpad/Numpad.js.map +2 -3
  201. package/dist/components/form-control/select/Select.d.ts.map +1 -0
  202. package/dist/components/form-control/select/Select.js +188 -86
  203. package/dist/components/form-control/select/Select.js.map +2 -3
  204. package/dist/components/form-control/select/SelectContext.d.ts.map +1 -0
  205. package/dist/components/form-control/select/SelectContext.js.map +0 -1
  206. package/dist/components/form-control/select/SelectItem.d.ts.map +1 -0
  207. package/dist/components/form-control/select/SelectItem.js +79 -38
  208. package/dist/components/form-control/select/SelectItem.js.map +2 -3
  209. package/dist/components/form-control/state-preset/StatePreset.d.ts.map +1 -0
  210. package/dist/components/form-control/state-preset/StatePreset.js +95 -80
  211. package/dist/components/form-control/state-preset/StatePreset.js.map +2 -3
  212. package/dist/components/layout/FormGroup.d.ts.map +1 -0
  213. package/dist/components/layout/FormGroup.js +47 -11
  214. package/dist/components/layout/FormGroup.js.map +2 -3
  215. package/dist/components/layout/FormTable.d.ts.map +1 -0
  216. package/dist/components/layout/FormTable.js +15 -1
  217. package/dist/components/layout/FormTable.js.map +2 -3
  218. package/dist/components/layout/sidebar/Sidebar.d.ts.map +1 -0
  219. package/dist/components/layout/sidebar/Sidebar.js +37 -36
  220. package/dist/components/layout/sidebar/Sidebar.js.map +2 -3
  221. package/dist/{solid/src/components → components}/layout/sidebar/SidebarContainer.d.ts +1 -1
  222. package/dist/components/layout/sidebar/SidebarContainer.d.ts.map +1 -0
  223. package/dist/components/layout/sidebar/SidebarContainer.js +48 -35
  224. package/dist/components/layout/sidebar/SidebarContainer.js.map +2 -3
  225. package/dist/components/layout/sidebar/SidebarContext.d.ts.map +1 -0
  226. package/dist/components/layout/sidebar/SidebarContext.js.map +0 -1
  227. package/dist/components/layout/sidebar/SidebarMenu.d.ts.map +1 -0
  228. package/dist/components/layout/sidebar/SidebarMenu.js +91 -25
  229. package/dist/components/layout/sidebar/SidebarMenu.js.map +2 -3
  230. package/dist/components/layout/sidebar/SidebarUser.d.ts +48 -0
  231. package/dist/components/layout/sidebar/SidebarUser.d.ts.map +1 -0
  232. package/dist/components/layout/sidebar/SidebarUser.js +99 -26
  233. package/dist/components/layout/sidebar/SidebarUser.js.map +2 -3
  234. package/dist/components/layout/topbar/Topbar.d.ts.map +1 -0
  235. package/dist/components/layout/topbar/Topbar.js +40 -7
  236. package/dist/components/layout/topbar/Topbar.js.map +2 -3
  237. package/dist/components/layout/topbar/TopbarContainer.d.ts.map +1 -0
  238. package/dist/components/layout/topbar/TopbarContainer.js +16 -1
  239. package/dist/components/layout/topbar/TopbarContainer.js.map +2 -3
  240. package/dist/components/layout/topbar/TopbarMenu.d.ts.map +1 -0
  241. package/dist/components/layout/topbar/TopbarMenu.js +200 -28
  242. package/dist/components/layout/topbar/TopbarMenu.js.map +2 -3
  243. package/dist/components/layout/topbar/TopbarUser.d.ts.map +1 -0
  244. package/dist/components/layout/topbar/TopbarUser.js +83 -16
  245. package/dist/components/layout/topbar/TopbarUser.js.map +2 -3
  246. package/dist/directives/ripple.d.ts.map +1 -0
  247. package/dist/directives/ripple.js.map +0 -1
  248. package/dist/helpers/createAppStructure.d.ts.map +1 -0
  249. package/dist/helpers/createAppStructure.js.map +0 -1
  250. package/dist/helpers/mergeStyles.d.ts.map +1 -0
  251. package/dist/helpers/mergeStyles.js.map +0 -1
  252. package/dist/helpers/splitSlots.d.ts.map +1 -0
  253. package/dist/helpers/splitSlots.js.map +0 -1
  254. package/dist/hooks/createControllableSignal.d.ts.map +1 -0
  255. package/dist/hooks/createControllableSignal.js.map +0 -1
  256. package/dist/hooks/createIMEHandler.d.ts.map +1 -0
  257. package/dist/hooks/createIMEHandler.js.map +0 -1
  258. package/dist/hooks/createMountTransition.d.ts.map +1 -0
  259. package/dist/hooks/createMountTransition.js.map +0 -1
  260. package/dist/hooks/createPwaUpdate.d.ts +14 -0
  261. package/dist/hooks/createPwaUpdate.d.ts.map +1 -0
  262. package/dist/hooks/createPwaUpdate.js +50 -0
  263. package/dist/hooks/createPwaUpdate.js.map +6 -0
  264. package/dist/hooks/useClipboardValueCopy.d.ts.map +1 -0
  265. package/dist/hooks/useClipboardValueCopy.js +1 -2
  266. package/dist/hooks/useClipboardValueCopy.js.map +1 -2
  267. package/dist/hooks/useLocalStorage.d.ts +29 -0
  268. package/dist/hooks/useLocalStorage.d.ts.map +1 -0
  269. package/dist/hooks/useLocalStorage.js +36 -0
  270. package/dist/hooks/useLocalStorage.js.map +6 -0
  271. package/dist/hooks/useLogger.d.ts +9 -0
  272. package/dist/hooks/useLogger.d.ts.map +1 -0
  273. package/dist/hooks/useLogger.js +24 -0
  274. package/dist/hooks/useLogger.js.map +6 -0
  275. package/dist/hooks/usePrint.d.ts.map +1 -0
  276. package/dist/hooks/usePrint.js +2 -2
  277. package/dist/hooks/usePrint.js.map +0 -1
  278. package/dist/hooks/useRouterLink.d.ts.map +1 -0
  279. package/dist/hooks/useRouterLink.js.map +0 -1
  280. package/dist/hooks/useSyncConfig.d.ts +24 -0
  281. package/dist/hooks/useSyncConfig.d.ts.map +1 -0
  282. package/dist/hooks/useSyncConfig.js +60 -0
  283. package/dist/hooks/useSyncConfig.js.map +6 -0
  284. package/dist/{solid/src/index.d.ts → index.d.ts} +9 -4
  285. package/dist/index.d.ts.map +1 -0
  286. package/dist/index.js +90 -84
  287. package/dist/index.js.map +1 -2
  288. package/dist/{solid/src/providers → providers}/ConfigContext.d.ts +20 -2
  289. package/dist/providers/ConfigContext.d.ts.map +1 -0
  290. package/dist/providers/ConfigContext.js.map +1 -2
  291. package/dist/{solid/src/providers → providers}/InitializeProvider.d.ts +6 -3
  292. package/dist/providers/InitializeProvider.d.ts.map +1 -0
  293. package/dist/providers/InitializeProvider.js +58 -3
  294. package/dist/providers/InitializeProvider.js.map +2 -3
  295. package/dist/providers/ServiceClientContext.d.ts.map +1 -0
  296. package/dist/providers/ServiceClientContext.js.map +0 -1
  297. package/dist/providers/ServiceClientProvider.d.ts.map +1 -0
  298. package/dist/providers/ServiceClientProvider.js +30 -24
  299. package/dist/providers/ServiceClientProvider.js.map +2 -3
  300. package/dist/{solid/src/providers → providers}/ThemeContext.d.ts +1 -1
  301. package/dist/providers/ThemeContext.d.ts.map +1 -0
  302. package/dist/providers/ThemeContext.js +10 -6
  303. package/dist/providers/ThemeContext.js.map +2 -3
  304. package/dist/providers/shared-data/SharedDataChangeEvent.d.ts +5 -0
  305. package/dist/providers/shared-data/SharedDataChangeEvent.d.ts.map +1 -0
  306. package/dist/providers/shared-data/SharedDataChangeEvent.js +4 -4
  307. package/dist/providers/shared-data/SharedDataChangeEvent.js.map +1 -2
  308. package/dist/providers/shared-data/SharedDataContext.d.ts.map +1 -0
  309. package/dist/providers/shared-data/SharedDataContext.js.map +0 -1
  310. package/dist/providers/shared-data/SharedDataProvider.d.ts.map +1 -0
  311. package/dist/providers/shared-data/SharedDataProvider.js +20 -17
  312. package/dist/providers/shared-data/SharedDataProvider.js.map +2 -3
  313. package/dist/styles/patterns.styles.d.ts.map +1 -0
  314. package/dist/styles/patterns.styles.js +1 -1
  315. package/dist/styles/patterns.styles.js.map +0 -1
  316. package/dist/styles/tokens.styles.d.ts.map +1 -0
  317. package/dist/styles/tokens.styles.js.map +0 -1
  318. package/docs/data-components.md +304 -0
  319. package/docs/disclosure.md +208 -0
  320. package/docs/display.md +136 -0
  321. package/docs/feedback.md +188 -0
  322. package/docs/form-controls.md +535 -0
  323. package/docs/helpers.md +46 -0
  324. package/docs/hooks.md +313 -0
  325. package/docs/layout.md +289 -0
  326. package/docs/providers.md +35 -0
  327. package/docs/styling.md +67 -0
  328. package/package.json +20 -10
  329. package/src/components/data/list/ListItem.styles.ts +2 -2
  330. package/src/components/data/sheet/DataSheet.tsx +3 -3
  331. package/src/components/display/Echarts.tsx +18 -11
  332. package/src/components/form-control/Invalid.tsx +61 -0
  333. package/src/components/form-control/editor/RichTextEditor.tsx +2 -9
  334. package/src/components/form-control/field/DatePicker.tsx +0 -6
  335. package/src/components/form-control/field/DateTimePicker.tsx +0 -6
  336. package/src/components/form-control/field/Field.styles.ts +0 -3
  337. package/src/components/form-control/field/NumberInput.tsx +0 -6
  338. package/src/components/form-control/field/TextInput.tsx +0 -6
  339. package/src/components/form-control/field/Textarea.tsx +0 -6
  340. package/src/components/form-control/field/TimePicker.tsx +0 -6
  341. package/src/components/form-control/state-preset/StatePreset.tsx +2 -2
  342. package/src/components/layout/sidebar/SidebarContainer.tsx +3 -4
  343. package/src/components/layout/sidebar/SidebarUser.tsx +44 -16
  344. package/src/hooks/createPwaUpdate.ts +73 -0
  345. package/src/hooks/useClipboardValueCopy.ts +1 -1
  346. package/src/hooks/useLocalStorage.ts +68 -0
  347. package/src/hooks/useLogger.ts +32 -0
  348. package/src/hooks/useSyncConfig.ts +99 -0
  349. package/src/index.ts +9 -4
  350. package/src/providers/ConfigContext.ts +23 -2
  351. package/src/providers/InitializeProvider.tsx +59 -5
  352. package/src/providers/ServiceClientProvider.tsx +2 -2
  353. package/src/providers/ThemeContext.tsx +3 -3
  354. package/src/providers/shared-data/SharedDataChangeEvent.ts +4 -7
  355. package/src/providers/shared-data/SharedDataProvider.tsx +3 -0
  356. package/.cache/typecheck-browser.tsbuildinfo +0 -1
  357. package/.cache/typecheck-tests-browser.tsbuildinfo +0 -1
  358. package/dist/core-browser/src/extensions/element-ext.d.ts +0 -98
  359. package/dist/core-browser/src/extensions/element-ext.d.ts.map +0 -1
  360. package/dist/core-browser/src/extensions/html-element-ext.d.ts +0 -54
  361. package/dist/core-browser/src/extensions/html-element-ext.d.ts.map +0 -1
  362. package/dist/core-browser/src/index.d.ts +0 -7
  363. package/dist/core-browser/src/index.d.ts.map +0 -1
  364. package/dist/core-browser/src/utils/blob.d.ts +0 -10
  365. package/dist/core-browser/src/utils/blob.d.ts.map +0 -1
  366. package/dist/core-browser/src/utils/download.d.ts +0 -11
  367. package/dist/core-browser/src/utils/download.d.ts.map +0 -1
  368. package/dist/core-common/src/common.types.d.ts +0 -74
  369. package/dist/core-common/src/common.types.d.ts.map +0 -1
  370. package/dist/core-common/src/env.d.ts +0 -6
  371. package/dist/core-common/src/env.d.ts.map +0 -1
  372. package/dist/core-common/src/errors/argument-error.d.ts +0 -25
  373. package/dist/core-common/src/errors/argument-error.d.ts.map +0 -1
  374. package/dist/core-common/src/errors/not-implemented-error.d.ts +0 -29
  375. package/dist/core-common/src/errors/not-implemented-error.d.ts.map +0 -1
  376. package/dist/core-common/src/errors/sd-error.d.ts +0 -27
  377. package/dist/core-common/src/errors/sd-error.d.ts.map +0 -1
  378. package/dist/core-common/src/errors/timeout-error.d.ts +0 -31
  379. package/dist/core-common/src/errors/timeout-error.d.ts.map +0 -1
  380. package/dist/core-common/src/extensions/arr-ext.d.ts +0 -15
  381. package/dist/core-common/src/extensions/arr-ext.d.ts.map +0 -1
  382. package/dist/core-common/src/extensions/arr-ext.helpers.d.ts +0 -19
  383. package/dist/core-common/src/extensions/arr-ext.helpers.d.ts.map +0 -1
  384. package/dist/core-common/src/extensions/arr-ext.types.d.ts +0 -215
  385. package/dist/core-common/src/extensions/arr-ext.types.d.ts.map +0 -1
  386. package/dist/core-common/src/extensions/map-ext.d.ts +0 -57
  387. package/dist/core-common/src/extensions/map-ext.d.ts.map +0 -1
  388. package/dist/core-common/src/extensions/set-ext.d.ts +0 -36
  389. package/dist/core-common/src/extensions/set-ext.d.ts.map +0 -1
  390. package/dist/core-common/src/features/debounce-queue.d.ts +0 -53
  391. package/dist/core-common/src/features/debounce-queue.d.ts.map +0 -1
  392. package/dist/core-common/src/features/event-emitter.d.ts +0 -66
  393. package/dist/core-common/src/features/event-emitter.d.ts.map +0 -1
  394. package/dist/core-common/src/features/serial-queue.d.ts +0 -47
  395. package/dist/core-common/src/features/serial-queue.d.ts.map +0 -1
  396. package/dist/core-common/src/index.d.ts +0 -32
  397. package/dist/core-common/src/index.d.ts.map +0 -1
  398. package/dist/core-common/src/types/date-only.d.ts +0 -152
  399. package/dist/core-common/src/types/date-only.d.ts.map +0 -1
  400. package/dist/core-common/src/types/date-time.d.ts +0 -96
  401. package/dist/core-common/src/types/date-time.d.ts.map +0 -1
  402. package/dist/core-common/src/types/lazy-gc-map.d.ts +0 -80
  403. package/dist/core-common/src/types/lazy-gc-map.d.ts.map +0 -1
  404. package/dist/core-common/src/types/time.d.ts +0 -68
  405. package/dist/core-common/src/types/time.d.ts.map +0 -1
  406. package/dist/core-common/src/types/uuid.d.ts +0 -35
  407. package/dist/core-common/src/types/uuid.d.ts.map +0 -1
  408. package/dist/core-common/src/utils/bytes.d.ts +0 -51
  409. package/dist/core-common/src/utils/bytes.d.ts.map +0 -1
  410. package/dist/core-common/src/utils/date-format.d.ts +0 -90
  411. package/dist/core-common/src/utils/date-format.d.ts.map +0 -1
  412. package/dist/core-common/src/utils/json.d.ts +0 -34
  413. package/dist/core-common/src/utils/json.d.ts.map +0 -1
  414. package/dist/core-common/src/utils/num.d.ts +0 -60
  415. package/dist/core-common/src/utils/num.d.ts.map +0 -1
  416. package/dist/core-common/src/utils/obj.d.ts +0 -258
  417. package/dist/core-common/src/utils/obj.d.ts.map +0 -1
  418. package/dist/core-common/src/utils/path.d.ts +0 -23
  419. package/dist/core-common/src/utils/path.d.ts.map +0 -1
  420. package/dist/core-common/src/utils/primitive.d.ts +0 -18
  421. package/dist/core-common/src/utils/primitive.d.ts.map +0 -1
  422. package/dist/core-common/src/utils/str.d.ts +0 -103
  423. package/dist/core-common/src/utils/str.d.ts.map +0 -1
  424. package/dist/core-common/src/utils/template-strings.d.ts +0 -84
  425. package/dist/core-common/src/utils/template-strings.d.ts.map +0 -1
  426. package/dist/core-common/src/utils/transferable.d.ts +0 -47
  427. package/dist/core-common/src/utils/transferable.d.ts.map +0 -1
  428. package/dist/core-common/src/utils/wait.d.ts +0 -19
  429. package/dist/core-common/src/utils/wait.d.ts.map +0 -1
  430. package/dist/core-common/src/utils/xml.d.ts +0 -36
  431. package/dist/core-common/src/utils/xml.d.ts.map +0 -1
  432. package/dist/core-common/src/zip/sd-zip.d.ts +0 -80
  433. package/dist/core-common/src/zip/sd-zip.d.ts.map +0 -1
  434. package/dist/hooks/usePersisted.js +0 -25
  435. package/dist/hooks/usePersisted.js.map +0 -7
  436. package/dist/orm-common/src/db-context.d.ts +0 -669
  437. package/dist/orm-common/src/db-context.d.ts.map +0 -1
  438. package/dist/orm-common/src/errors/db-transaction-error.d.ts +0 -51
  439. package/dist/orm-common/src/errors/db-transaction-error.d.ts.map +0 -1
  440. package/dist/orm-common/src/exec/executable.d.ts +0 -79
  441. package/dist/orm-common/src/exec/executable.d.ts.map +0 -1
  442. package/dist/orm-common/src/exec/queryable.d.ts +0 -708
  443. package/dist/orm-common/src/exec/queryable.d.ts.map +0 -1
  444. package/dist/orm-common/src/exec/search-parser.d.ts +0 -72
  445. package/dist/orm-common/src/exec/search-parser.d.ts.map +0 -1
  446. package/dist/orm-common/src/expr/expr-unit.d.ts +0 -25
  447. package/dist/orm-common/src/expr/expr-unit.d.ts.map +0 -1
  448. package/dist/orm-common/src/expr/expr.d.ts +0 -1369
  449. package/dist/orm-common/src/expr/expr.d.ts.map +0 -1
  450. package/dist/orm-common/src/index.d.ts +0 -32
  451. package/dist/orm-common/src/index.d.ts.map +0 -1
  452. package/dist/orm-common/src/models/system-migration.d.ts +0 -10
  453. package/dist/orm-common/src/models/system-migration.d.ts.map +0 -1
  454. package/dist/orm-common/src/query-builder/base/expr-renderer-base.d.ts +0 -95
  455. package/dist/orm-common/src/query-builder/base/expr-renderer-base.d.ts.map +0 -1
  456. package/dist/orm-common/src/query-builder/base/query-builder-base.d.ts +0 -66
  457. package/dist/orm-common/src/query-builder/base/query-builder-base.d.ts.map +0 -1
  458. package/dist/orm-common/src/query-builder/mssql/mssql-expr-renderer.d.ts +0 -84
  459. package/dist/orm-common/src/query-builder/mssql/mssql-expr-renderer.d.ts.map +0 -1
  460. package/dist/orm-common/src/query-builder/mssql/mssql-query-builder.d.ts +0 -45
  461. package/dist/orm-common/src/query-builder/mssql/mssql-query-builder.d.ts.map +0 -1
  462. package/dist/orm-common/src/query-builder/mysql/mysql-expr-renderer.d.ts +0 -84
  463. package/dist/orm-common/src/query-builder/mysql/mysql-expr-renderer.d.ts.map +0 -1
  464. package/dist/orm-common/src/query-builder/mysql/mysql-query-builder.d.ts +0 -54
  465. package/dist/orm-common/src/query-builder/mysql/mysql-query-builder.d.ts.map +0 -1
  466. package/dist/orm-common/src/query-builder/postgresql/postgresql-expr-renderer.d.ts +0 -84
  467. package/dist/orm-common/src/query-builder/postgresql/postgresql-expr-renderer.d.ts.map +0 -1
  468. package/dist/orm-common/src/query-builder/postgresql/postgresql-query-builder.d.ts +0 -52
  469. package/dist/orm-common/src/query-builder/postgresql/postgresql-query-builder.d.ts.map +0 -1
  470. package/dist/orm-common/src/query-builder/query-builder.d.ts +0 -7
  471. package/dist/orm-common/src/query-builder/query-builder.d.ts.map +0 -1
  472. package/dist/orm-common/src/schema/factory/column-builder.d.ts +0 -394
  473. package/dist/orm-common/src/schema/factory/column-builder.d.ts.map +0 -1
  474. package/dist/orm-common/src/schema/factory/index-builder.d.ts +0 -151
  475. package/dist/orm-common/src/schema/factory/index-builder.d.ts.map +0 -1
  476. package/dist/orm-common/src/schema/factory/relation-builder.d.ts +0 -337
  477. package/dist/orm-common/src/schema/factory/relation-builder.d.ts.map +0 -1
  478. package/dist/orm-common/src/schema/procedure-builder.d.ts +0 -202
  479. package/dist/orm-common/src/schema/procedure-builder.d.ts.map +0 -1
  480. package/dist/orm-common/src/schema/table-builder.d.ts +0 -259
  481. package/dist/orm-common/src/schema/table-builder.d.ts.map +0 -1
  482. package/dist/orm-common/src/schema/view-builder.d.ts +0 -183
  483. package/dist/orm-common/src/schema/view-builder.d.ts.map +0 -1
  484. package/dist/orm-common/src/types/column.d.ts +0 -172
  485. package/dist/orm-common/src/types/column.d.ts.map +0 -1
  486. package/dist/orm-common/src/types/db.d.ts +0 -175
  487. package/dist/orm-common/src/types/db.d.ts.map +0 -1
  488. package/dist/orm-common/src/types/expr.d.ts +0 -474
  489. package/dist/orm-common/src/types/expr.d.ts.map +0 -1
  490. package/dist/orm-common/src/types/query-def.d.ts +0 -351
  491. package/dist/orm-common/src/types/query-def.d.ts.map +0 -1
  492. package/dist/orm-common/src/utils/result-parser.d.ts +0 -38
  493. package/dist/orm-common/src/utils/result-parser.d.ts.map +0 -1
  494. package/dist/service-client/src/features/event-client.d.ts +0 -14
  495. package/dist/service-client/src/features/event-client.d.ts.map +0 -1
  496. package/dist/service-client/src/features/file-client.d.ts +0 -13
  497. package/dist/service-client/src/features/file-client.d.ts.map +0 -1
  498. package/dist/service-client/src/features/orm/orm-client-connector.d.ts +0 -10
  499. package/dist/service-client/src/features/orm/orm-client-connector.d.ts.map +0 -1
  500. package/dist/service-client/src/features/orm/orm-client-db-context-executor.d.ts +0 -26
  501. package/dist/service-client/src/features/orm/orm-client-db-context-executor.d.ts.map +0 -1
  502. package/dist/service-client/src/features/orm/orm-connect-config.d.ts +0 -13
  503. package/dist/service-client/src/features/orm/orm-connect-config.d.ts.map +0 -1
  504. package/dist/service-client/src/index.d.ts +0 -12
  505. package/dist/service-client/src/index.d.ts.map +0 -1
  506. package/dist/service-client/src/protocol/client-protocol-wrapper.d.ts +0 -23
  507. package/dist/service-client/src/protocol/client-protocol-wrapper.d.ts.map +0 -1
  508. package/dist/service-client/src/service-client.d.ts +0 -41
  509. package/dist/service-client/src/service-client.d.ts.map +0 -1
  510. package/dist/service-client/src/transport/service-transport.d.ts +0 -24
  511. package/dist/service-client/src/transport/service-transport.d.ts.map +0 -1
  512. package/dist/service-client/src/transport/socket-provider.d.ts +0 -31
  513. package/dist/service-client/src/transport/socket-provider.d.ts.map +0 -1
  514. package/dist/service-client/src/types/connection-config.d.ts +0 -8
  515. package/dist/service-client/src/types/connection-config.d.ts.map +0 -1
  516. package/dist/service-client/src/types/progress.types.d.ts +0 -10
  517. package/dist/service-client/src/types/progress.types.d.ts.map +0 -1
  518. package/dist/service-common/src/index.d.ts +0 -8
  519. package/dist/service-common/src/index.d.ts.map +0 -1
  520. package/dist/service-common/src/protocol/protocol.types.d.ts +0 -100
  521. package/dist/service-common/src/protocol/protocol.types.d.ts.map +0 -1
  522. package/dist/service-common/src/protocol/service-protocol.d.ts +0 -63
  523. package/dist/service-common/src/protocol/service-protocol.d.ts.map +0 -1
  524. package/dist/service-common/src/service-types/auto-update-service.types.d.ts +0 -17
  525. package/dist/service-common/src/service-types/auto-update-service.types.d.ts.map +0 -1
  526. package/dist/service-common/src/service-types/crypto-service.types.d.ts +0 -22
  527. package/dist/service-common/src/service-types/crypto-service.types.d.ts.map +0 -1
  528. package/dist/service-common/src/service-types/orm-service.types.d.ts +0 -30
  529. package/dist/service-common/src/service-types/orm-service.types.d.ts.map +0 -1
  530. package/dist/service-common/src/service-types/smtp-service.types.d.ts +0 -55
  531. package/dist/service-common/src/service-types/smtp-service.types.d.ts.map +0 -1
  532. package/dist/service-common/src/types.d.ts +0 -43
  533. package/dist/service-common/src/types.d.ts.map +0 -1
  534. package/dist/solid/src/components/data/Pagination.d.ts.map +0 -1
  535. package/dist/solid/src/components/data/Table.d.ts.map +0 -1
  536. package/dist/solid/src/components/data/calendar/Calendar.d.ts.map +0 -1
  537. package/dist/solid/src/components/data/kanban/Kanban.d.ts.map +0 -1
  538. package/dist/solid/src/components/data/kanban/KanbanContext.d.ts.map +0 -1
  539. package/dist/solid/src/components/data/list/List.d.ts.map +0 -1
  540. package/dist/solid/src/components/data/list/ListContext.d.ts.map +0 -1
  541. package/dist/solid/src/components/data/list/ListItem.d.ts.map +0 -1
  542. package/dist/solid/src/components/data/list/ListItem.styles.d.ts.map +0 -1
  543. package/dist/solid/src/components/data/permission-table/PermissionTable.d.ts.map +0 -1
  544. package/dist/solid/src/components/data/sheet/DataSheet.d.ts.map +0 -1
  545. package/dist/solid/src/components/data/sheet/DataSheet.styles.d.ts.map +0 -1
  546. package/dist/solid/src/components/data/sheet/DataSheetColumn.d.ts.map +0 -1
  547. package/dist/solid/src/components/data/sheet/DataSheetConfigDialog.d.ts.map +0 -1
  548. package/dist/solid/src/components/data/sheet/sheetUtils.d.ts.map +0 -1
  549. package/dist/solid/src/components/data/sheet/types.d.ts.map +0 -1
  550. package/dist/solid/src/components/disclosure/Collapse.d.ts.map +0 -1
  551. package/dist/solid/src/components/disclosure/Dialog.d.ts.map +0 -1
  552. package/dist/solid/src/components/disclosure/DialogContext.d.ts.map +0 -1
  553. package/dist/solid/src/components/disclosure/DialogInstanceContext.d.ts.map +0 -1
  554. package/dist/solid/src/components/disclosure/DialogProvider.d.ts.map +0 -1
  555. package/dist/solid/src/components/disclosure/Dropdown.d.ts.map +0 -1
  556. package/dist/solid/src/components/disclosure/Tabs.d.ts.map +0 -1
  557. package/dist/solid/src/components/disclosure/dialogZIndex.d.ts.map +0 -1
  558. package/dist/solid/src/components/display/Alert.d.ts.map +0 -1
  559. package/dist/solid/src/components/display/Barcode.d.ts.map +0 -1
  560. package/dist/solid/src/components/display/Card.d.ts.map +0 -1
  561. package/dist/solid/src/components/display/Echarts.d.ts.map +0 -1
  562. package/dist/solid/src/components/display/Icon.d.ts.map +0 -1
  563. package/dist/solid/src/components/display/Tag.d.ts.map +0 -1
  564. package/dist/solid/src/components/feedback/Progress.d.ts.map +0 -1
  565. package/dist/solid/src/components/feedback/loading/LoadingContainer.d.ts.map +0 -1
  566. package/dist/solid/src/components/feedback/loading/LoadingContext.d.ts.map +0 -1
  567. package/dist/solid/src/components/feedback/loading/LoadingProvider.d.ts.map +0 -1
  568. package/dist/solid/src/components/feedback/notification/NotificationBanner.d.ts.map +0 -1
  569. package/dist/solid/src/components/feedback/notification/NotificationBell.d.ts.map +0 -1
  570. package/dist/solid/src/components/feedback/notification/NotificationContext.d.ts.map +0 -1
  571. package/dist/solid/src/components/feedback/notification/NotificationProvider.d.ts.map +0 -1
  572. package/dist/solid/src/components/feedback/notification/index.d.ts.map +0 -1
  573. package/dist/solid/src/components/feedback/print/Print.d.ts.map +0 -1
  574. package/dist/solid/src/components/feedback/print/PrintInstanceContext.d.ts.map +0 -1
  575. package/dist/solid/src/components/form-control/Button.d.ts.map +0 -1
  576. package/dist/solid/src/components/form-control/DropdownTrigger.styles.d.ts.map +0 -1
  577. package/dist/solid/src/components/form-control/ThemeToggle.d.ts.map +0 -1
  578. package/dist/solid/src/components/form-control/checkbox/Checkbox.d.ts.map +0 -1
  579. package/dist/solid/src/components/form-control/checkbox/Checkbox.styles.d.ts.map +0 -1
  580. package/dist/solid/src/components/form-control/checkbox/CheckboxGroup.d.ts.map +0 -1
  581. package/dist/solid/src/components/form-control/checkbox/RadioGroup.d.ts.map +0 -1
  582. package/dist/solid/src/components/form-control/color-picker/ColorPicker.d.ts.map +0 -1
  583. package/dist/solid/src/components/form-control/combobox/Combobox.d.ts.map +0 -1
  584. package/dist/solid/src/components/form-control/combobox/ComboboxContext.d.ts.map +0 -1
  585. package/dist/solid/src/components/form-control/combobox/ComboboxItem.d.ts.map +0 -1
  586. package/dist/solid/src/components/form-control/date-range-picker/DateRangePicker.d.ts.map +0 -1
  587. package/dist/solid/src/components/form-control/editor/EditorToolbar.d.ts.map +0 -1
  588. package/dist/solid/src/components/form-control/editor/RichTextEditor.d.ts.map +0 -1
  589. package/dist/solid/src/components/form-control/field/DatePicker.d.ts.map +0 -1
  590. package/dist/solid/src/components/form-control/field/DateTimePicker.d.ts.map +0 -1
  591. package/dist/solid/src/components/form-control/field/Field.styles.d.ts.map +0 -1
  592. package/dist/solid/src/components/form-control/field/NumberInput.d.ts.map +0 -1
  593. package/dist/solid/src/components/form-control/field/TextInput.d.ts.map +0 -1
  594. package/dist/solid/src/components/form-control/field/Textarea.d.ts.map +0 -1
  595. package/dist/solid/src/components/form-control/field/TimePicker.d.ts.map +0 -1
  596. package/dist/solid/src/components/form-control/numpad/Numpad.d.ts.map +0 -1
  597. package/dist/solid/src/components/form-control/select/Select.d.ts.map +0 -1
  598. package/dist/solid/src/components/form-control/select/SelectContext.d.ts.map +0 -1
  599. package/dist/solid/src/components/form-control/select/SelectItem.d.ts.map +0 -1
  600. package/dist/solid/src/components/form-control/state-preset/StatePreset.d.ts.map +0 -1
  601. package/dist/solid/src/components/layout/FormGroup.d.ts.map +0 -1
  602. package/dist/solid/src/components/layout/FormTable.d.ts.map +0 -1
  603. package/dist/solid/src/components/layout/sidebar/Sidebar.d.ts.map +0 -1
  604. package/dist/solid/src/components/layout/sidebar/SidebarContainer.d.ts.map +0 -1
  605. package/dist/solid/src/components/layout/sidebar/SidebarContext.d.ts.map +0 -1
  606. package/dist/solid/src/components/layout/sidebar/SidebarMenu.d.ts.map +0 -1
  607. package/dist/solid/src/components/layout/sidebar/SidebarUser.d.ts +0 -36
  608. package/dist/solid/src/components/layout/sidebar/SidebarUser.d.ts.map +0 -1
  609. package/dist/solid/src/components/layout/topbar/Topbar.d.ts.map +0 -1
  610. package/dist/solid/src/components/layout/topbar/TopbarContainer.d.ts.map +0 -1
  611. package/dist/solid/src/components/layout/topbar/TopbarMenu.d.ts.map +0 -1
  612. package/dist/solid/src/components/layout/topbar/TopbarUser.d.ts.map +0 -1
  613. package/dist/solid/src/directives/ripple.d.ts.map +0 -1
  614. package/dist/solid/src/helpers/createAppStructure.d.ts.map +0 -1
  615. package/dist/solid/src/helpers/mergeStyles.d.ts.map +0 -1
  616. package/dist/solid/src/helpers/splitSlots.d.ts.map +0 -1
  617. package/dist/solid/src/hooks/createControllableSignal.d.ts.map +0 -1
  618. package/dist/solid/src/hooks/createIMEHandler.d.ts.map +0 -1
  619. package/dist/solid/src/hooks/createMountTransition.d.ts.map +0 -1
  620. package/dist/solid/src/hooks/useClipboardValueCopy.d.ts.map +0 -1
  621. package/dist/solid/src/hooks/usePersisted.d.ts +0 -26
  622. package/dist/solid/src/hooks/usePersisted.d.ts.map +0 -1
  623. package/dist/solid/src/hooks/usePrint.d.ts.map +0 -1
  624. package/dist/solid/src/hooks/useRouterLink.d.ts.map +0 -1
  625. package/dist/solid/src/index.d.ts.map +0 -1
  626. package/dist/solid/src/providers/ConfigContext.d.ts.map +0 -1
  627. package/dist/solid/src/providers/InitializeProvider.d.ts.map +0 -1
  628. package/dist/solid/src/providers/ServiceClientContext.d.ts.map +0 -1
  629. package/dist/solid/src/providers/ServiceClientProvider.d.ts.map +0 -1
  630. package/dist/solid/src/providers/ThemeContext.d.ts.map +0 -1
  631. package/dist/solid/src/providers/shared-data/SharedDataChangeEvent.d.ts +0 -8
  632. package/dist/solid/src/providers/shared-data/SharedDataChangeEvent.d.ts.map +0 -1
  633. package/dist/solid/src/providers/shared-data/SharedDataContext.d.ts.map +0 -1
  634. package/dist/solid/src/providers/shared-data/SharedDataProvider.d.ts.map +0 -1
  635. package/dist/solid/src/styles/patterns.styles.d.ts.map +0 -1
  636. package/dist/solid/src/styles/tokens.styles.d.ts.map +0 -1
  637. package/src/hooks/usePersisted.ts +0 -51
  638. package/tests/components/data/List.spec.tsx +0 -683
  639. package/tests/components/data/Pagination.spec.tsx +0 -317
  640. package/tests/components/data/Table.spec.tsx +0 -55
  641. package/tests/components/data/kanban/Kanban.selection.spec.tsx +0 -209
  642. package/tests/components/data/permission-table/PermissionTable.spec.tsx +0 -280
  643. package/tests/components/data/sheet/DataSheet.spec.tsx +0 -564
  644. package/tests/components/disclosure/Collapse.spec.tsx +0 -162
  645. package/tests/components/disclosure/Dialog.spec.tsx +0 -319
  646. package/tests/components/disclosure/DialogProvider.spec.tsx +0 -110
  647. package/tests/components/disclosure/Dropdown.spec.tsx +0 -410
  648. package/tests/components/disclosure/Tabs.spec.tsx +0 -220
  649. package/tests/components/display/Alert.spec.tsx +0 -47
  650. package/tests/components/display/Barcode.spec.tsx +0 -61
  651. package/tests/components/display/Card.spec.tsx +0 -41
  652. package/tests/components/display/Tag.spec.tsx +0 -47
  653. package/tests/components/feedback/notification/LiveRegion.spec.tsx +0 -41
  654. package/tests/components/feedback/notification/NotificationBanner.spec.tsx +0 -164
  655. package/tests/components/feedback/notification/NotificationBell.spec.tsx +0 -207
  656. package/tests/components/feedback/notification/NotificationContext.spec.tsx +0 -331
  657. package/tests/components/feedback/print/Print.spec.tsx +0 -45
  658. package/tests/components/form-control/Button.spec.tsx +0 -119
  659. package/tests/components/form-control/checkbox/Checkbox.spec.tsx +0 -120
  660. package/tests/components/form-control/checkbox/Radio.spec.tsx +0 -112
  661. package/tests/components/form-control/color-picker/ColorPicker.spec.tsx +0 -67
  662. package/tests/components/form-control/combobox/Combobox.spec.tsx +0 -174
  663. package/tests/components/form-control/combobox/ComboboxItem.spec.tsx +0 -85
  664. package/tests/components/form-control/date-range-picker/DateRangePicker.spec.tsx +0 -172
  665. package/tests/components/form-control/field/DatePicker.spec.tsx +0 -305
  666. package/tests/components/form-control/field/DateTimePicker.spec.tsx +0 -287
  667. package/tests/components/form-control/field/NumberInput.spec.tsx +0 -276
  668. package/tests/components/form-control/field/TextInput.spec.tsx +0 -258
  669. package/tests/components/form-control/field/Textarea.spec.tsx +0 -181
  670. package/tests/components/form-control/field/TimePicker.spec.tsx +0 -243
  671. package/tests/components/form-control/numpad/Numpad.spec.tsx +0 -238
  672. package/tests/components/form-control/select/Select.spec.tsx +0 -239
  673. package/tests/components/form-control/select/SelectItem.spec.tsx +0 -149
  674. package/tests/components/layout/FormGroup.spec.tsx +0 -104
  675. package/tests/components/layout/FormTable.spec.tsx +0 -43
  676. package/tests/components/layout/sidebar/Sidebar.spec.tsx +0 -190
  677. package/tests/components/layout/sidebar/SidebarContainer.spec.tsx +0 -203
  678. package/tests/components/layout/sidebar/SidebarMenu.spec.tsx +0 -213
  679. package/tests/components/layout/sidebar/SidebarUser.spec.tsx +0 -171
  680. package/tests/directives/ripple.spec.tsx +0 -130
  681. package/tests/helpers/createAppStructure.spec.tsx +0 -338
  682. package/tests/helpers/mergeStyles.spec.ts +0 -163
  683. package/tests/helpers/splitSlots.spec.tsx +0 -188
  684. package/tests/hooks/createControllableSignal.spec.ts +0 -194
  685. package/tests/hooks/createIMEHandler.spec.ts +0 -80
  686. package/tests/hooks/createMountTransition.spec.ts +0 -86
  687. package/tests/hooks/usePersisted.spec.tsx +0 -191
  688. package/tests/hooks/usePrint.spec.tsx +0 -123
  689. package/tests/hooks/useRouterLink.spec.tsx +0 -183
  690. package/tests/providers/ConfigContext.spec.ts +0 -40
  691. package/tests/providers/ServiceClientContext.spec.tsx +0 -83
  692. package/tests/providers/shared-data/SharedDataProvider.spec.tsx +0 -233
  693. /package/dist/{solid/src/components → components}/data/Pagination.d.ts +0 -0
  694. /package/dist/{solid/src/components → components}/data/Table.d.ts +0 -0
  695. /package/dist/{solid/src/components → components}/data/calendar/Calendar.d.ts +0 -0
  696. /package/dist/{solid/src/components → components}/data/kanban/Kanban.d.ts +0 -0
  697. /package/dist/{solid/src/components → components}/data/kanban/KanbanContext.d.ts +0 -0
  698. /package/dist/{solid/src/components → components}/data/list/List.d.ts +0 -0
  699. /package/dist/{solid/src/components → components}/data/list/ListContext.d.ts +0 -0
  700. /package/dist/{solid/src/components → components}/data/list/ListItem.d.ts +0 -0
  701. /package/dist/{solid/src/components → components}/data/list/ListItem.styles.d.ts +0 -0
  702. /package/dist/{solid/src/components → components}/data/permission-table/PermissionTable.d.ts +0 -0
  703. /package/dist/{solid/src/components → components}/data/sheet/DataSheet.d.ts +0 -0
  704. /package/dist/{solid/src/components → components}/data/sheet/DataSheet.styles.d.ts +0 -0
  705. /package/dist/{solid/src/components → components}/data/sheet/DataSheetColumn.d.ts +0 -0
  706. /package/dist/{solid/src/components → components}/data/sheet/DataSheetConfigDialog.d.ts +0 -0
  707. /package/dist/{solid/src/components → components}/data/sheet/sheetUtils.d.ts +0 -0
  708. /package/dist/{solid/src/components → components}/data/sheet/types.d.ts +0 -0
  709. /package/dist/{solid/src/components → components}/disclosure/Collapse.d.ts +0 -0
  710. /package/dist/{solid/src/components → components}/disclosure/Dialog.d.ts +0 -0
  711. /package/dist/{solid/src/components → components}/disclosure/DialogContext.d.ts +0 -0
  712. /package/dist/{solid/src/components → components}/disclosure/DialogInstanceContext.d.ts +0 -0
  713. /package/dist/{solid/src/components → components}/disclosure/DialogProvider.d.ts +0 -0
  714. /package/dist/{solid/src/components → components}/disclosure/Dropdown.d.ts +0 -0
  715. /package/dist/{solid/src/components → components}/disclosure/Tabs.d.ts +0 -0
  716. /package/dist/{solid/src/components → components}/disclosure/dialogZIndex.d.ts +0 -0
  717. /package/dist/{solid/src/components → components}/display/Alert.d.ts +0 -0
  718. /package/dist/{solid/src/components → components}/display/Barcode.d.ts +0 -0
  719. /package/dist/{solid/src/components → components}/display/Card.d.ts +0 -0
  720. /package/dist/{solid/src/components → components}/display/Icon.d.ts +0 -0
  721. /package/dist/{solid/src/components → components}/display/Tag.d.ts +0 -0
  722. /package/dist/{solid/src/components → components}/feedback/Progress.d.ts +0 -0
  723. /package/dist/{solid/src/components → components}/feedback/loading/LoadingContainer.d.ts +0 -0
  724. /package/dist/{solid/src/components → components}/feedback/loading/LoadingContext.d.ts +0 -0
  725. /package/dist/{solid/src/components → components}/feedback/loading/LoadingProvider.d.ts +0 -0
  726. /package/dist/{solid/src/components → components}/feedback/notification/NotificationBanner.d.ts +0 -0
  727. /package/dist/{solid/src/components → components}/feedback/notification/NotificationBell.d.ts +0 -0
  728. /package/dist/{solid/src/components → components}/feedback/notification/NotificationContext.d.ts +0 -0
  729. /package/dist/{solid/src/components → components}/feedback/notification/NotificationProvider.d.ts +0 -0
  730. /package/dist/{solid/src/components → components}/feedback/notification/index.d.ts +0 -0
  731. /package/dist/{solid/src/components → components}/feedback/print/Print.d.ts +0 -0
  732. /package/dist/{solid/src/components → components}/feedback/print/PrintInstanceContext.d.ts +0 -0
  733. /package/dist/{solid/src/components → components}/form-control/Button.d.ts +0 -0
  734. /package/dist/{solid/src/components → components}/form-control/DropdownTrigger.styles.d.ts +0 -0
  735. /package/dist/{solid/src/components → components}/form-control/ThemeToggle.d.ts +0 -0
  736. /package/dist/{solid/src/components → components}/form-control/checkbox/Checkbox.d.ts +0 -0
  737. /package/dist/{solid/src/components → components}/form-control/checkbox/Checkbox.styles.d.ts +0 -0
  738. /package/dist/{solid/src/components → components}/form-control/checkbox/CheckboxGroup.d.ts +0 -0
  739. /package/dist/{solid/src/components → components}/form-control/checkbox/Radio.d.ts +0 -0
  740. /package/dist/{solid/src/components → components}/form-control/checkbox/RadioGroup.d.ts +0 -0
  741. /package/dist/{solid/src/components → components}/form-control/color-picker/ColorPicker.d.ts +0 -0
  742. /package/dist/{solid/src/components → components}/form-control/combobox/Combobox.d.ts +0 -0
  743. /package/dist/{solid/src/components → components}/form-control/combobox/ComboboxContext.d.ts +0 -0
  744. /package/dist/{solid/src/components → components}/form-control/combobox/ComboboxItem.d.ts +0 -0
  745. /package/dist/{solid/src/components → components}/form-control/date-range-picker/DateRangePicker.d.ts +0 -0
  746. /package/dist/{solid/src/components → components}/form-control/editor/EditorToolbar.d.ts +0 -0
  747. /package/dist/{solid/src/components → components}/form-control/numpad/Numpad.d.ts +0 -0
  748. /package/dist/{solid/src/components → components}/form-control/select/Select.d.ts +0 -0
  749. /package/dist/{solid/src/components → components}/form-control/select/SelectContext.d.ts +0 -0
  750. /package/dist/{solid/src/components → components}/form-control/select/SelectItem.d.ts +0 -0
  751. /package/dist/{solid/src/components → components}/form-control/state-preset/StatePreset.d.ts +0 -0
  752. /package/dist/{solid/src/components → components}/layout/FormGroup.d.ts +0 -0
  753. /package/dist/{solid/src/components → components}/layout/FormTable.d.ts +0 -0
  754. /package/dist/{solid/src/components → components}/layout/sidebar/Sidebar.d.ts +0 -0
  755. /package/dist/{solid/src/components → components}/layout/sidebar/SidebarContext.d.ts +0 -0
  756. /package/dist/{solid/src/components → components}/layout/sidebar/SidebarMenu.d.ts +0 -0
  757. /package/dist/{solid/src/components → components}/layout/topbar/Topbar.d.ts +0 -0
  758. /package/dist/{solid/src/components → components}/layout/topbar/TopbarContainer.d.ts +0 -0
  759. /package/dist/{solid/src/components → components}/layout/topbar/TopbarMenu.d.ts +0 -0
  760. /package/dist/{solid/src/components → components}/layout/topbar/TopbarUser.d.ts +0 -0
  761. /package/dist/{solid/src/directives → directives}/ripple.d.ts +0 -0
  762. /package/dist/{solid/src/helpers → helpers}/createAppStructure.d.ts +0 -0
  763. /package/dist/{solid/src/helpers → helpers}/mergeStyles.d.ts +0 -0
  764. /package/dist/{solid/src/helpers → helpers}/splitSlots.d.ts +0 -0
  765. /package/dist/{solid/src/hooks → hooks}/createControllableSignal.d.ts +0 -0
  766. /package/dist/{solid/src/hooks → hooks}/createIMEHandler.d.ts +0 -0
  767. /package/dist/{solid/src/hooks → hooks}/createMountTransition.d.ts +0 -0
  768. /package/dist/{solid/src/hooks → hooks}/useClipboardValueCopy.d.ts +0 -0
  769. /package/dist/{solid/src/hooks → hooks}/usePrint.d.ts +0 -0
  770. /package/dist/{solid/src/hooks → hooks}/useRouterLink.d.ts +0 -0
  771. /package/dist/{solid/src/providers → providers}/ServiceClientContext.d.ts +0 -0
  772. /package/dist/{solid/src/providers → providers}/ServiceClientProvider.d.ts +0 -0
  773. /package/dist/{solid/src/providers → providers}/shared-data/SharedDataContext.d.ts +0 -0
  774. /package/dist/{solid/src/providers → providers}/shared-data/SharedDataProvider.d.ts +0 -0
  775. /package/dist/{solid/src/styles → styles}/patterns.styles.d.ts +0 -0
  776. /package/dist/{solid/src/styles → styles}/tokens.styles.d.ts +0 -0
  777. /package/{src/base.css → tailwind.css} +0 -0
package/docs/hooks.md ADDED
@@ -0,0 +1,313 @@
1
+ # Hooks
2
+
3
+ ## createPwaUpdate
4
+
5
+ PWA Service Worker update detection hook. Automatically polls for Service Worker updates every 5 minutes. When a new version is detected, shows a notification with a reload action button.
6
+
7
+ **Automatic Integration:** Already integrated into `InitializeProvider` -- no manual setup required for most applications. The hook runs automatically inside the notification system.
8
+
9
+ **Manual Usage (Custom Provider Tree):**
10
+
11
+ ```tsx
12
+ import { createPwaUpdate } from "@simplysm/solid";
13
+
14
+ function MyProvider(props) {
15
+ // Must be called inside NotificationProvider
16
+ createPwaUpdate();
17
+
18
+ return (
19
+ <NotificationProvider>
20
+ {props.children}
21
+ </NotificationProvider>
22
+ );
23
+ }
24
+ ```
25
+
26
+ **Graceful No-ops:** Works safely in the following scenarios where Service Workers are unavailable:
27
+ - HTTP protocol (non-HTTPS dev servers)
28
+ - Browsers that don't support Service Workers
29
+ - Development/test environments without SW registration
30
+
31
+ **Requirements:**
32
+ - Must be called inside `NotificationProvider` (to display the update notification)
33
+ - `InitializeProvider` already includes both, so manual setup only needed for custom provider trees
34
+
35
+ ---
36
+
37
+ ## useTheme
38
+
39
+ Hook to access theme (dark/light/system) state. Must be used inside `InitializeProvider`.
40
+
41
+ ```tsx
42
+ import { useTheme } from "@simplysm/solid";
43
+
44
+ const theme = useTheme();
45
+ theme.mode(); // "light" | "dark" | "system"
46
+ theme.resolvedTheme(); // "light" | "dark" (follows OS setting when system)
47
+ theme.setMode("dark");
48
+ theme.cycleMode(); // light -> system -> dark -> light
49
+ ```
50
+
51
+ | Property/Method | Type | Description |
52
+ |-----------------|------|-------------|
53
+ | `mode` | `() => ThemeMode` | Current theme mode |
54
+ | `resolvedTheme` | `() => ResolvedTheme` | Actual applied theme |
55
+ | `setMode` | `(mode: ThemeMode) => void` | Set theme mode |
56
+ | `cycleMode` | `() => void` | Cycle to next mode |
57
+
58
+ ---
59
+
60
+ ## useLocalStorage
61
+
62
+ Local-only persistent storage hook. Always uses `localStorage` regardless of `syncStorage` setting. Keys are automatically prefixed as `{clientName}.{key}`. Use for data that should never leave the device (auth tokens, device-specific state).
63
+
64
+ ```tsx
65
+ import { useLocalStorage } from "@simplysm/solid";
66
+
67
+ const [token, setToken] = useLocalStorage<string | undefined>("auth-token", undefined);
68
+ ```
69
+
70
+ | Return value | Type | Description |
71
+ |--------------|------|-------------|
72
+ | `[0]` | `Accessor<T>` | Value getter |
73
+ | `[1]` | `Setter<T>` | Value setter |
74
+
75
+ ---
76
+
77
+ ## useSyncConfig
78
+
79
+ Syncable config hook. Uses `syncStorage` if configured, falls back to `localStorage` otherwise. Keys are automatically prefixed as `{clientName}.{key}`. Use for user preferences that should sync across devices (theme, DataSheet column configs, filter presets).
80
+
81
+ ```tsx
82
+ import { useSyncConfig } from "@simplysm/solid";
83
+
84
+ const [theme, setTheme, loading] = useSyncConfig("theme", "light");
85
+
86
+ // loading state is useful when syncStorage is async (e.g., DB-backed)
87
+ // When syncStorage is not configured, loading is always false
88
+ ```
89
+
90
+ | Return value | Type | Description |
91
+ |--------------|------|-------------|
92
+ | `[0]` | `Accessor<T>` | Value getter |
93
+ | `[1]` | `Setter<T>` | Value setter |
94
+ | `[2]` | `Accessor<boolean>` | Loading state (async storage only) |
95
+
96
+ ---
97
+
98
+ ## useLogger
99
+
100
+ Logging hook. If `logger` adapter is configured in `AppConfig`, logs are sent to the adapter only. Otherwise, logs fall back to `consola`. Must be used inside `InitializeProvider`.
101
+
102
+ ```tsx
103
+ import { useLogger } from "@simplysm/solid";
104
+
105
+ const logger = useLogger();
106
+ logger.log("user action", { userId: 123 });
107
+ logger.info("app started");
108
+ logger.error("something failed", errorObj);
109
+ logger.warn("deprecation notice");
110
+ ```
111
+
112
+ | Method | Signature | Description |
113
+ |--------|-----------|-------------|
114
+ | `log` | `(...args: unknown[]) => void` | Log message (general) |
115
+ | `info` | `(...args: unknown[]) => void` | Log message (informational) |
116
+ | `warn` | `(...args: unknown[]) => void` | Log message (warning) |
117
+ | `error` | `(...args: unknown[]) => void` | Log message (error) |
118
+
119
+ **Global error capturing:** `InitializeProvider` automatically captures uncaught errors (`window.onerror`) and unhandled promise rejections (`unhandledrejection`) and logs them via `useLogger`. No additional setup required.
120
+
121
+ ---
122
+
123
+ ## useNotification
124
+
125
+ Hook to access notification system. Must be used inside `InitializeProvider`. See [Notification](feedback.md#notification) for detailed API.
126
+
127
+ ---
128
+
129
+ ## useLoading
130
+
131
+ Hook to access loading overlay. Must be used inside `InitializeProvider`. See [Loading](feedback.md#loading) for detailed API.
132
+
133
+ ---
134
+
135
+ ## usePrint
136
+
137
+ Hook for printing and PDF generation. Must be used inside `InitializeProvider`. See [Print / usePrint](feedback.md#print--useprint) for detailed API.
138
+
139
+ ---
140
+
141
+ ## useConfig
142
+
143
+ Hook to access app-wide configuration. Must be used inside `InitializeProvider`.
144
+
145
+ ```tsx
146
+ import { useConfig } from "@simplysm/solid";
147
+
148
+ const config = useConfig();
149
+ console.log(config.clientName); // "my-app"
150
+ ```
151
+
152
+ ---
153
+
154
+ ## createControllableSignal
155
+
156
+ Signal hook that automatically handles Controlled/Uncontrolled patterns. Operates in controlled mode when `onChange` is provided, uncontrolled mode otherwise.
157
+
158
+ ```tsx
159
+ import { createControllableSignal } from "@simplysm/solid";
160
+
161
+ // Use inside components
162
+ const [value, setValue] = createControllableSignal({
163
+ value: () => props.value ?? "",
164
+ onChange: () => props.onValueChange,
165
+ });
166
+
167
+ // Supports functional setter
168
+ setValue((prev) => prev + "!");
169
+ ```
170
+
171
+ ---
172
+
173
+ ## createMountTransition
174
+
175
+ Mount transition hook for open/close CSS animations. Control DOM rendering with `mounted()` and toggle CSS classes with `animating()`.
176
+
177
+ ```tsx
178
+ import { createMountTransition } from "@simplysm/solid";
179
+
180
+ const { mounted, animating, unmount } = createMountTransition(() => open());
181
+ ```
182
+
183
+ | Return value | Type | Description |
184
+ |--------------|------|-------------|
185
+ | `mounted` | `() => boolean` | Whether mounted in DOM |
186
+ | `animating` | `() => boolean` | Animation active state |
187
+ | `unmount` | `() => void` | Manual unmount |
188
+
189
+ ---
190
+
191
+ ## createIMEHandler
192
+
193
+ Hook that delays `onValueChange` calls during IME (Korean, etc.) composition to prevent interrupted input.
194
+
195
+ ---
196
+
197
+ ## useRouterLink
198
+
199
+ `@solidjs/router`-based navigation hook. Automatically handles Ctrl/Alt + click (new tab), Shift + click (new window).
200
+
201
+ ```tsx
202
+ import { useRouterLink } from "@simplysm/solid";
203
+
204
+ const navigate = useRouterLink();
205
+
206
+ <List.Item onClick={navigate({ href: "/home/dashboard" })}>
207
+ Dashboard
208
+ </List.Item>
209
+
210
+ // Pass state
211
+ <List.Item onClick={navigate({ href: "/users/123", state: { from: "list" } })}>
212
+ User
213
+ </List.Item>
214
+ ```
215
+
216
+ ---
217
+
218
+ ## createAppStructure
219
+
220
+ Utility for declaratively defining app structure (routing, menus, permissions). Takes a single options object.
221
+
222
+ ```tsx
223
+ import { createAppStructure, type AppStructureItem } from "@simplysm/solid";
224
+ import { IconHome, IconUsers } from "@tabler/icons-solidjs";
225
+
226
+ const items: AppStructureItem<string>[] = [
227
+ {
228
+ code: "home",
229
+ title: "Home",
230
+ icon: IconHome,
231
+ component: HomePage,
232
+ perms: ["use"],
233
+ },
234
+ {
235
+ code: "admin",
236
+ title: "Admin",
237
+ icon: IconUsers,
238
+ children: [
239
+ { code: "users", title: "User Management", component: UsersPage, perms: ["use", "edit"] },
240
+ { code: "roles", title: "Role Management", component: RolesPage, perms: ["use"], isNotMenu: true },
241
+ ],
242
+ },
243
+ ];
244
+
245
+ const structure = createAppStructure({
246
+ items,
247
+ usableModules: () => activeModules(), // optional: filter by active modules
248
+ permRecord: () => userPermissions(), // optional: user permission state
249
+ });
250
+
251
+ // structure.routes -- Route array (pass to @solidjs/router)
252
+ // structure.usableMenus() -- SidebarMenuItem[] for Sidebar.Menu
253
+ // structure.usableFlatMenus() -- Flat menu list
254
+ // structure.permRecord() -- Record<string, boolean> permission state
255
+ ```
256
+
257
+ **Routing integration with `@solidjs/router`:**
258
+
259
+ ```tsx
260
+ import { render } from "solid-js/web";
261
+ import { HashRouter, Navigate, Route } from "@solidjs/router";
262
+ import { For } from "solid-js";
263
+ import { appStructure } from "./appStructure";
264
+
265
+ render(
266
+ () => (
267
+ <HashRouter>
268
+ <Route path="/" component={App}>
269
+ <Route path="/home" component={Home}>
270
+ <Route path="/" component={() => <Navigate href="/home/main" />} />
271
+ <For each={appStructure.routes}>
272
+ {(r) => <Route path={r.path} component={r.component} />}
273
+ </For>
274
+ <Route path="/*" component={NotFoundPage} />
275
+ </Route>
276
+ <Route path="/" component={() => <Navigate href="/home" />} />
277
+ </Route>
278
+ </HashRouter>
279
+ ),
280
+ document.getElementById("root")!,
281
+ );
282
+ ```
283
+
284
+ Each route object in `structure.routes` has `path` (derived from nested `code` values) and `component` properties, ready to pass directly to `<Route>`.
285
+
286
+ **AppStructureItem types:**
287
+
288
+ ```typescript
289
+ // Group item (has children, no component)
290
+ interface AppStructureGroupItem<TModule> {
291
+ code: string;
292
+ title: string;
293
+ icon?: Component<IconProps>;
294
+ modules?: TModule[];
295
+ requiredModules?: TModule[];
296
+ children: AppStructureItem<TModule>[];
297
+ }
298
+
299
+ // Leaf item (has component, no children)
300
+ interface AppStructureLeafItem<TModule> {
301
+ code: string;
302
+ title: string;
303
+ icon?: Component<IconProps>;
304
+ modules?: TModule[];
305
+ requiredModules?: TModule[];
306
+ component?: Component;
307
+ perms?: ("use" | "edit")[];
308
+ subPerms?: AppStructureSubPerm<TModule>[];
309
+ isNotMenu?: boolean; // exclude from menu but include in routing
310
+ }
311
+
312
+ type AppStructureItem<TModule> = AppStructureGroupItem<TModule> | AppStructureLeafItem<TModule>;
313
+ ```
package/docs/layout.md ADDED
@@ -0,0 +1,289 @@
1
+ # Layout Components
2
+
3
+ ## Sidebar
4
+
5
+ Sidebar navigation with responsive support (mobile overlay below 520px). Open/closed state is in-memory only (resets on page refresh).
6
+
7
+ ```tsx
8
+ import { Sidebar, Topbar } from "@simplysm/solid";
9
+ import { useNavigate } from "@solidjs/router";
10
+
11
+ const navigate = useNavigate();
12
+
13
+ <Sidebar.Container>
14
+ <Sidebar>
15
+ <Sidebar.User
16
+ name="John Doe"
17
+ description="john@example.com"
18
+ menus={[
19
+ { title: "Profile", onClick: () => navigate("/profile") },
20
+ { title: "Logout", onClick: handleLogout },
21
+ ]}
22
+ />
23
+ <Sidebar.Menu menus={menuItems} />
24
+ </Sidebar>
25
+ <div class="flex flex-1 flex-col">
26
+ <Topbar>
27
+ <h1>App Name</h1>
28
+ </Topbar>
29
+ <main class="flex-1 overflow-auto p-4">
30
+ {/* main content */}
31
+ </main>
32
+ </div>
33
+ </Sidebar.Container>
34
+ ```
35
+
36
+ **Sub-components:**
37
+ - `Sidebar.Container` -- Container wrapping sidebar and main area (required)
38
+ - `Sidebar.Menu` -- Menu items list (`menus: SidebarMenuItem[]`)
39
+ - `Sidebar.User` -- User info area with avatar and optional dropdown menu
40
+
41
+ **Sidebar.User Props:**
42
+
43
+ | Prop | Type | Default | Description |
44
+ |------|------|---------|-------------|
45
+ | `name` | `string` | **(required)** | User name |
46
+ | `description` | `string` | - | Optional additional info (email, role, etc.). If omitted, only name is shown |
47
+ | `icon` | `Component<TablerIconProps>` | `IconUser` | Avatar icon (Tabler Icons component). Rendered in a circular badge |
48
+ | `menus` | `SidebarUserMenu[]` | - | Dropdown menu items. When present, component becomes clickable |
49
+
50
+ **SidebarUserMenu type:**
51
+
52
+ ```typescript
53
+ interface SidebarUserMenu {
54
+ title: string;
55
+ onClick: () => void;
56
+ }
57
+ ```
58
+
59
+ **SidebarMenuItem type:**
60
+
61
+ ```typescript
62
+ interface SidebarMenuItem {
63
+ title: string;
64
+ href?: string;
65
+ icon?: Component<IconProps>;
66
+ children?: SidebarMenuItem[];
67
+ }
68
+ ```
69
+
70
+ **useSidebarContext hook:**
71
+
72
+ ```tsx
73
+ import { useSidebarContext } from "@simplysm/solid";
74
+
75
+ const sidebar = useSidebarContext();
76
+ sidebar.toggle(); // current open/closed state
77
+ sidebar.setToggle(false); // programmatically close
78
+ ```
79
+
80
+ ---
81
+
82
+ ## Topbar
83
+
84
+ Top navigation bar. When used inside `Sidebar.Container`, a sidebar toggle button appears automatically.
85
+
86
+ ```tsx
87
+ import { Topbar } from "@simplysm/solid";
88
+ import { IconSettings, IconUser } from "@tabler/icons-solidjs";
89
+
90
+ const menuItems: TopbarMenuItem[] = [
91
+ { title: "Settings", icon: IconSettings, href: "/settings" },
92
+ {
93
+ title: "Admin",
94
+ icon: IconUser,
95
+ children: [
96
+ { title: "Users", href: "/admin/users" },
97
+ { title: "Roles", href: "/admin/roles" },
98
+ ],
99
+ },
100
+ ];
101
+
102
+ const userMenus: TopbarUserMenu[] = [
103
+ { title: "Profile", onClick: () => navigate("/profile") },
104
+ { title: "Logout", onClick: handleLogout },
105
+ ];
106
+
107
+ <Topbar>
108
+ <h1 class="text-lg font-bold">App Name</h1>
109
+ <Topbar.Menu menus={menuItems} />
110
+ <div class="flex-1" />
111
+ <Topbar.User menus={userMenus}>User</Topbar.User>
112
+ </Topbar>
113
+ ```
114
+
115
+ **Sub-components:**
116
+ - `Topbar.Container` -- Container wrapping main content below topbar
117
+ - `Topbar.Menu` -- Menu items list
118
+ - `Topbar.User` -- User menu (dropdown)
119
+
120
+ **TopbarMenuItem type:**
121
+
122
+ ```typescript
123
+ interface TopbarMenuItem {
124
+ title: string;
125
+ href?: string;
126
+ icon?: Component<IconProps>;
127
+ children?: TopbarMenuItem[]; // supports unlimited nesting
128
+ }
129
+ ```
130
+
131
+ **TopbarUserMenu type:**
132
+
133
+ ```typescript
134
+ interface TopbarUserMenu {
135
+ title: string;
136
+ onClick: () => void;
137
+ }
138
+ ```
139
+
140
+ ---
141
+
142
+ ## FormGroup
143
+
144
+ Layout component for arranging form fields with labels vertically or inline.
145
+
146
+ ```tsx
147
+ import { FormGroup, TextInput } from "@simplysm/solid";
148
+
149
+ // Vertical layout (default)
150
+ <FormGroup>
151
+ <FormGroup.Item label="Name">
152
+ <TextInput value={name()} onValueChange={setName} />
153
+ </FormGroup.Item>
154
+ <FormGroup.Item label="Email">
155
+ <TextInput type="email" value={email()} onValueChange={setEmail} />
156
+ </FormGroup.Item>
157
+ </FormGroup>
158
+
159
+ // Inline layout
160
+ <FormGroup inline>
161
+ <FormGroup.Item label="Search">
162
+ <TextInput value={query()} onValueChange={setQuery} />
163
+ </FormGroup.Item>
164
+ <FormGroup.Item>
165
+ <Button theme="primary">Search</Button>
166
+ </FormGroup.Item>
167
+ </FormGroup>
168
+ ```
169
+
170
+ | Prop | Type | Default | Description |
171
+ |------|------|---------|-------------|
172
+ | `inline` | `boolean` | `false` | Inline layout mode |
173
+
174
+ **Sub-components:**
175
+ - `FormGroup.Item` -- Form item (`label?: JSX.Element`)
176
+
177
+ ---
178
+
179
+ ## FormTable
180
+
181
+ `<table>`-based form layout. Labels go in `<th>`, input fields in `<td>`.
182
+
183
+ ```tsx
184
+ import { FormTable, TextInput, NumberInput } from "@simplysm/solid";
185
+
186
+ <FormTable>
187
+ <tbody>
188
+ <tr>
189
+ <th>Name</th>
190
+ <td><TextInput value={name()} onValueChange={setName} /></td>
191
+ <th>Age</th>
192
+ <td><NumberInput value={age()} onValueChange={setAge} /></td>
193
+ </tr>
194
+ <tr>
195
+ <th>Email</th>
196
+ <td colSpan={3}><TextInput type="email" value={email()} onValueChange={setEmail} /></td>
197
+ </tr>
198
+ </tbody>
199
+ </FormTable>
200
+ ```
201
+
202
+ ---
203
+
204
+ ## Kanban
205
+
206
+ Kanban board layout component with drag-and-drop cards, lane collapse, multi-select, and loading states.
207
+
208
+ ```tsx
209
+ import { createSignal, For } from "solid-js";
210
+ import { Button, Icon, Kanban, type KanbanDropInfo } from "@simplysm/solid";
211
+ import { IconPlus } from "@tabler/icons-solidjs";
212
+
213
+ const [selected, setSelected] = createSignal<unknown[]>([]);
214
+
215
+ const handleDrop = (info: KanbanDropInfo) => {
216
+ // info.sourceValue: dragged card value
217
+ // info.targetLaneValue: target lane value
218
+ // info.targetCardValue: target card value (undefined if dropped on empty area)
219
+ // info.position: "before" | "after" | undefined
220
+ moveCard(info);
221
+ };
222
+
223
+ <div class="h-[500px]">
224
+ <Kanban
225
+ selectedValues={selected()}
226
+ onSelectedValuesChange={setSelected}
227
+ onDrop={handleDrop}
228
+ >
229
+ <For each={lanes()}>
230
+ {(lane) => (
231
+ <Kanban.Lane value={lane.id} collapsible busy={lane.loading}>
232
+ <Kanban.LaneTitle>
233
+ {lane.title} ({lane.cards.length})
234
+ </Kanban.LaneTitle>
235
+ <Kanban.LaneTools>
236
+ <Button size="sm" variant="ghost">
237
+ <Icon icon={IconPlus} />
238
+ </Button>
239
+ </Kanban.LaneTools>
240
+ <For each={lane.cards}>
241
+ {(card) => (
242
+ <Kanban.Card value={card.id} selectable draggable contentClass="p-2">
243
+ {card.title}
244
+ </Kanban.Card>
245
+ )}
246
+ </For>
247
+ </Kanban.Lane>
248
+ )}
249
+ </For>
250
+ </Kanban>
251
+ </div>
252
+ ```
253
+
254
+ **Kanban Props:**
255
+
256
+ | Prop | Type | Default | Description |
257
+ |------|------|---------|-------------|
258
+ | `onDrop` | `(info: KanbanDropInfo) => void` | - | Drop event handler |
259
+ | `selectedValues` | `unknown[]` | - | Selected card values |
260
+ | `onSelectedValuesChange` | `(values: unknown[]) => void` | - | Selection change callback |
261
+
262
+ `KanbanDropInfo`: `{ sourceValue: unknown; targetLaneValue: unknown; targetCardValue: unknown | undefined; position: "before" | "after" | undefined }`
263
+
264
+ **Kanban.Lane Props:**
265
+
266
+ | Prop | Type | Default | Description |
267
+ |------|------|---------|-------------|
268
+ | `value` | `unknown` | - | Lane identifier |
269
+ | `busy` | `boolean` | - | Show loading bar |
270
+ | `collapsible` | `boolean` | - | Allow collapse/expand |
271
+ | `collapsed` | `boolean` | - | Collapsed state (controlled) |
272
+ | `onCollapsedChange` | `(collapsed: boolean) => void` | - | Collapse state callback |
273
+
274
+ **Kanban.Card Props:**
275
+
276
+ | Prop | Type | Default | Description |
277
+ |------|------|---------|-------------|
278
+ | `value` | `unknown` | - | Card identifier |
279
+ | `draggable` | `boolean` | `true` | Enable drag |
280
+ | `selectable` | `boolean` | `false` | Enable selection |
281
+ | `contentClass` | `string` | - | Card content class |
282
+
283
+ **Sub-components:**
284
+ - `Kanban.Lane` -- Board lane/column
285
+ - `Kanban.LaneTitle` -- Lane header title area
286
+ - `Kanban.LaneTools` -- Lane header action buttons
287
+ - `Kanban.Card` -- Draggable card
288
+
289
+ **Selection:** Shift+Click for multi-select, long press for single select. Lane header checkbox toggles all cards in the lane.
@@ -0,0 +1,35 @@
1
+ # Providers
2
+
3
+ ## InitializeProvider
4
+
5
+ Root provider that wraps the entire application. Automatically sets up all required providers: configuration context, theme (dark/light/system), notification system with banner, global error capturing (window.onerror, unhandledrejection), loading overlay, and programmatic dialog support.
6
+
7
+ See [Getting Started](getting-started.md#provider-setup) for setup instructions and `AppConfig` options.
8
+
9
+ ---
10
+
11
+ ## ServiceClientProvider
12
+
13
+ WebSocket client provider for RPC communication with `@simplysm/service-server`. Wraps `ServiceClient` from `@simplysm/service-client`.
14
+
15
+ ```tsx
16
+ import { ServiceClientProvider } from "@simplysm/solid";
17
+
18
+ <ServiceClientProvider url="ws://localhost:3000">
19
+ <App />
20
+ </ServiceClientProvider>
21
+ ```
22
+
23
+ ---
24
+
25
+ ## SharedDataProvider
26
+
27
+ Shared data provider for managing server-side data subscriptions. Works with `ServiceClientProvider` to provide reactive shared data across components.
28
+
29
+ ```tsx
30
+ import { SharedDataProvider, SharedDataChangeEvent } from "@simplysm/solid";
31
+
32
+ <SharedDataProvider>
33
+ <App />
34
+ </SharedDataProvider>
35
+ ```
@@ -0,0 +1,67 @@
1
+ # Styling & Tailwind Theme
2
+
3
+ `@simplysm/solid` provides the following custom themes via Tailwind CSS preset.
4
+
5
+ ## Semantic Colors
6
+
7
+ | Name | Base Color | Usage |
8
+ |------|------------|-------|
9
+ | `primary` | blue | Primary actions |
10
+ | `info` | sky | Information |
11
+ | `success` | green | Success |
12
+ | `warning` | amber | Warning |
13
+ | `danger` | red | Danger/error |
14
+ | `base` | zinc | Neutral (backgrounds, borders, secondary text, etc.) |
15
+
16
+ > Use `base-*` instead of directly using `zinc-*`.
17
+
18
+ ## Custom Sizes
19
+
20
+ | Class | Description |
21
+ |-------|-------------|
22
+ | `h-field` / `size-field` | Default field height (based on `py-1`) |
23
+ | `h-field-sm` / `size-field-sm` | Small field height (based on `py-0.5`) |
24
+ | `h-field-lg` / `size-field-lg` | Large field height (based on `py-2`) |
25
+ | `h-field-inset` / `size-field-inset` | Inset field height (excludes border) |
26
+ | `h-field-inset-sm` / `size-field-inset-sm` | Small inset field height |
27
+ | `h-field-inset-lg` / `size-field-inset-lg` | Large inset field height |
28
+
29
+ ## z-index Layers
30
+
31
+ | Class | Value | Description |
32
+ |-------|-------|-------------|
33
+ | `z-sidebar` | 100 | Sidebar |
34
+ | `z-sidebar-backdrop` | 99 | Sidebar backdrop |
35
+ | `z-busy` | 500 | Loading overlay |
36
+ | `z-dropdown` | 1000 | Dropdown popup |
37
+ | `z-modal-backdrop` | 1999 | Modal backdrop |
38
+ | `z-modal` | 2000 | Modal dialog |
39
+
40
+ ## Dark Mode
41
+
42
+ Uses Tailwind's `class` strategy. `InitializeProvider` automatically toggles the `dark` class on the `<html>` element via the built-in theme provider.
43
+
44
+ ```html
45
+ <!-- Light mode -->
46
+ <html>
47
+ <!-- Dark mode -->
48
+ <html class="dark">
49
+ ```
50
+
51
+ ## Styling Patterns
52
+
53
+ When using Tailwind classes in components, group them by semantic units with `clsx` and resolve conflicts with `twMerge`:
54
+
55
+ ```typescript
56
+ import clsx from "clsx";
57
+ import { twMerge } from "tailwind-merge";
58
+
59
+ const baseClass = clsx(
60
+ "inline-flex items-center",
61
+ "px-2 py-1",
62
+ "rounded",
63
+ "border border-transparent",
64
+ );
65
+
66
+ const className = twMerge(baseClass, props.class);
67
+ ```