@simplysm/solid 13.0.28 → 13.0.30

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 (379) hide show
  1. package/README.md +15 -9
  2. package/dist/components/data/Pagination.d.ts +4 -5
  3. package/dist/components/data/Pagination.d.ts.map +1 -1
  4. package/dist/components/data/Pagination.js +14 -14
  5. package/dist/components/data/Pagination.js.map +2 -2
  6. package/dist/components/data/Table.js +1 -1
  7. package/dist/components/data/calendar/Calendar.d.ts.map +1 -1
  8. package/dist/components/data/calendar/Calendar.js +1 -1
  9. package/dist/components/data/calendar/Calendar.js.map +1 -1
  10. package/dist/components/data/kanban/Kanban.d.ts +9 -9
  11. package/dist/components/data/kanban/Kanban.d.ts.map +1 -1
  12. package/dist/components/data/kanban/Kanban.js +6 -6
  13. package/dist/components/data/kanban/Kanban.js.map +2 -2
  14. package/dist/components/data/list/List.d.ts.map +1 -1
  15. package/dist/components/data/list/List.js.map +1 -1
  16. package/dist/components/data/list/ListItem.d.ts.map +1 -1
  17. package/dist/components/data/list/ListItem.js.map +1 -1
  18. package/dist/components/data/permission-table/PermissionTable.d.ts.map +1 -1
  19. package/dist/components/data/permission-table/PermissionTable.js.map +1 -1
  20. package/dist/components/data/sheet/DataSheet.d.ts.map +1 -1
  21. package/dist/components/data/sheet/DataSheet.js +102 -107
  22. package/dist/components/data/sheet/DataSheet.js.map +2 -2
  23. package/dist/components/data/sheet/DataSheet.styles.d.ts.map +1 -1
  24. package/dist/components/data/sheet/DataSheet.styles.js +24 -6
  25. package/dist/components/data/sheet/DataSheet.styles.js.map +1 -1
  26. package/dist/components/data/sheet/DataSheetColumn.d.ts.map +1 -1
  27. package/dist/components/data/sheet/DataSheetColumn.js.map +1 -1
  28. package/dist/components/data/sheet/DataSheetConfigDialog.d.ts.map +1 -1
  29. package/dist/components/data/sheet/DataSheetConfigDialog.js.map +1 -1
  30. package/dist/components/data/sheet/sheetUtils.d.ts.map +1 -1
  31. package/dist/components/data/sheet/sheetUtils.js.map +1 -1
  32. package/dist/components/data/sheet/types.d.ts +2 -2
  33. package/dist/components/data/sheet/types.d.ts.map +1 -1
  34. package/dist/components/disclosure/Collapse.d.ts.map +1 -1
  35. package/dist/components/disclosure/Collapse.js +0 -3
  36. package/dist/components/disclosure/Collapse.js.map +1 -1
  37. package/dist/components/disclosure/Dialog.d.ts +8 -8
  38. package/dist/components/disclosure/Dialog.d.ts.map +1 -1
  39. package/dist/components/disclosure/Dialog.js +64 -69
  40. package/dist/components/disclosure/Dialog.js.map +2 -2
  41. package/dist/components/disclosure/DialogContext.d.ts +4 -4
  42. package/dist/components/disclosure/DialogContext.d.ts.map +1 -1
  43. package/dist/components/disclosure/DialogContext.js.map +1 -1
  44. package/dist/components/disclosure/DialogProvider.d.ts.map +1 -1
  45. package/dist/components/disclosure/DialogProvider.js +8 -8
  46. package/dist/components/disclosure/DialogProvider.js.map +2 -2
  47. package/dist/components/disclosure/Dropdown.d.ts.map +1 -1
  48. package/dist/components/disclosure/Dropdown.js.map +1 -1
  49. package/dist/components/disclosure/Tabs.d.ts.map +1 -1
  50. package/dist/components/disclosure/Tabs.js.map +1 -1
  51. package/dist/components/display/Alert.d.ts.map +1 -1
  52. package/dist/components/display/Alert.js.map +1 -1
  53. package/dist/components/display/Card.d.ts +0 -1
  54. package/dist/components/display/Card.d.ts.map +1 -1
  55. package/dist/components/display/Card.js +1 -2
  56. package/dist/components/display/Card.js.map +1 -1
  57. package/dist/components/display/Echarts.d.ts +1 -1
  58. package/dist/components/display/Echarts.d.ts.map +1 -1
  59. package/dist/components/display/Echarts.js +2 -2
  60. package/dist/components/display/Echarts.js.map +2 -2
  61. package/dist/components/display/Link.d.ts +5 -0
  62. package/dist/components/display/Link.d.ts.map +1 -0
  63. package/dist/components/display/Link.js +26 -0
  64. package/dist/components/display/Link.js.map +6 -0
  65. package/dist/components/feedback/Progress.d.ts +3 -3
  66. package/dist/components/feedback/Progress.d.ts.map +1 -1
  67. package/dist/components/feedback/Progress.js +1 -1
  68. package/dist/components/feedback/Progress.js.map +2 -2
  69. package/dist/components/feedback/busy/BusyContainer.d.ts +13 -0
  70. package/dist/components/feedback/busy/BusyContainer.d.ts.map +1 -0
  71. package/dist/components/feedback/{loading/LoadingContainer.js → busy/BusyContainer.js} +20 -13
  72. package/dist/components/feedback/busy/BusyContainer.js.map +6 -0
  73. package/dist/components/feedback/busy/BusyContext.d.ts +11 -0
  74. package/dist/components/feedback/busy/BusyContext.d.ts.map +1 -0
  75. package/dist/components/feedback/busy/BusyContext.js +14 -0
  76. package/dist/components/feedback/busy/BusyContext.js.map +6 -0
  77. package/dist/components/feedback/busy/BusyProvider.d.ts +7 -0
  78. package/dist/components/feedback/busy/BusyProvider.d.ts.map +1 -0
  79. package/dist/components/feedback/{loading/LoadingProvider.js → busy/BusyProvider.js} +7 -7
  80. package/dist/components/feedback/busy/BusyProvider.js.map +6 -0
  81. package/dist/components/feedback/notification/NotificationBanner.d.ts.map +1 -1
  82. package/dist/components/feedback/notification/NotificationBanner.js +1 -1
  83. package/dist/components/feedback/notification/NotificationBanner.js.map +1 -1
  84. package/dist/components/feedback/notification/NotificationBell.d.ts.map +1 -1
  85. package/dist/components/feedback/notification/NotificationBell.js +4 -2
  86. package/dist/components/feedback/notification/NotificationBell.js.map +2 -2
  87. package/dist/components/feedback/notification/NotificationContext.d.ts.map +1 -1
  88. package/dist/components/feedback/notification/NotificationContext.js.map +1 -1
  89. package/dist/components/feedback/notification/NotificationProvider.d.ts.map +1 -1
  90. package/dist/components/feedback/notification/NotificationProvider.js +1 -0
  91. package/dist/components/feedback/notification/NotificationProvider.js.map +1 -1
  92. package/dist/components/form-control/Button.d.ts.map +1 -1
  93. package/dist/components/form-control/Button.js +2 -2
  94. package/dist/components/form-control/Button.js.map +1 -1
  95. package/dist/components/form-control/DropdownTrigger.styles.d.ts.map +1 -1
  96. package/dist/components/form-control/DropdownTrigger.styles.js +6 -1
  97. package/dist/components/form-control/DropdownTrigger.styles.js.map +1 -1
  98. package/dist/components/form-control/Invalid.d.ts +4 -2
  99. package/dist/components/form-control/Invalid.d.ts.map +1 -1
  100. package/dist/components/form-control/Invalid.js +81 -41
  101. package/dist/components/form-control/Invalid.js.map +2 -2
  102. package/dist/components/form-control/ThemeToggle.d.ts.map +1 -1
  103. package/dist/components/form-control/ThemeToggle.js +4 -5
  104. package/dist/components/form-control/ThemeToggle.js.map +2 -2
  105. package/dist/components/form-control/checkbox/Checkbox.d.ts +4 -2
  106. package/dist/components/form-control/checkbox/Checkbox.d.ts.map +1 -1
  107. package/dist/components/form-control/checkbox/Checkbox.js +65 -52
  108. package/dist/components/form-control/checkbox/Checkbox.js.map +2 -2
  109. package/dist/components/form-control/checkbox/Checkbox.styles.d.ts +1 -2
  110. package/dist/components/form-control/checkbox/Checkbox.styles.d.ts.map +1 -1
  111. package/dist/components/form-control/checkbox/Checkbox.styles.js +8 -10
  112. package/dist/components/form-control/checkbox/Checkbox.styles.js.map +1 -1
  113. package/dist/components/form-control/checkbox/CheckboxGroup.d.ts +9 -9
  114. package/dist/components/form-control/checkbox/CheckboxGroup.d.ts.map +1 -1
  115. package/dist/components/form-control/checkbox/CheckboxGroup.js +10 -82
  116. package/dist/components/form-control/checkbox/CheckboxGroup.js.map +2 -2
  117. package/dist/components/form-control/checkbox/Radio.d.ts +4 -2
  118. package/dist/components/form-control/checkbox/Radio.d.ts.map +1 -1
  119. package/dist/components/form-control/checkbox/Radio.js +64 -51
  120. package/dist/components/form-control/checkbox/Radio.js.map +2 -2
  121. package/dist/components/form-control/checkbox/RadioGroup.d.ts +9 -9
  122. package/dist/components/form-control/checkbox/RadioGroup.d.ts.map +1 -1
  123. package/dist/components/form-control/checkbox/RadioGroup.js +10 -77
  124. package/dist/components/form-control/checkbox/RadioGroup.js.map +2 -2
  125. package/dist/components/form-control/color-picker/ColorPicker.d.ts +8 -3
  126. package/dist/components/form-control/color-picker/ColorPicker.d.ts.map +1 -1
  127. package/dist/components/form-control/color-picker/ColorPicker.js +43 -26
  128. package/dist/components/form-control/color-picker/ColorPicker.js.map +2 -2
  129. package/dist/components/form-control/combobox/Combobox.d.ts +8 -8
  130. package/dist/components/form-control/combobox/Combobox.d.ts.map +1 -1
  131. package/dist/components/form-control/combobox/Combobox.js +72 -59
  132. package/dist/components/form-control/combobox/Combobox.js.map +2 -2
  133. package/dist/components/form-control/editor/EditorToolbar.d.ts.map +1 -1
  134. package/dist/components/form-control/editor/EditorToolbar.js +3 -2
  135. package/dist/components/form-control/editor/EditorToolbar.js.map +2 -2
  136. package/dist/components/form-control/editor/RichTextEditor.d.ts.map +1 -1
  137. package/dist/components/form-control/editor/RichTextEditor.js.map +1 -1
  138. package/dist/components/form-control/field/DatePicker.d.ts +6 -0
  139. package/dist/components/form-control/field/DatePicker.d.ts.map +1 -1
  140. package/dist/components/form-control/field/DatePicker.js +138 -117
  141. package/dist/components/form-control/field/DatePicker.js.map +2 -2
  142. package/dist/components/form-control/field/DateTimePicker.d.ts +6 -0
  143. package/dist/components/form-control/field/DateTimePicker.d.ts.map +1 -1
  144. package/dist/components/form-control/field/DateTimePicker.js +138 -115
  145. package/dist/components/form-control/field/DateTimePicker.js.map +2 -2
  146. package/dist/components/form-control/field/Field.styles.d.ts +14 -0
  147. package/dist/components/form-control/field/Field.styles.d.ts.map +1 -1
  148. package/dist/components/form-control/field/Field.styles.js +47 -3
  149. package/dist/components/form-control/field/Field.styles.js.map +1 -1
  150. package/dist/components/form-control/field/FieldPlaceholder.d.ts +7 -0
  151. package/dist/components/form-control/field/FieldPlaceholder.d.ts.map +1 -0
  152. package/dist/components/form-control/field/FieldPlaceholder.js +34 -0
  153. package/dist/components/form-control/field/FieldPlaceholder.js.map +6 -0
  154. package/dist/components/form-control/field/NumberInput.d.ts +13 -0
  155. package/dist/components/form-control/field/NumberInput.d.ts.map +1 -1
  156. package/dist/components/form-control/field/NumberInput.js +163 -111
  157. package/dist/components/form-control/field/NumberInput.js.map +2 -2
  158. package/dist/components/form-control/field/TextInput.d.ts +16 -1
  159. package/dist/components/form-control/field/TextInput.d.ts.map +1 -1
  160. package/dist/components/form-control/field/TextInput.js +177 -114
  161. package/dist/components/form-control/field/TextInput.js.map +2 -2
  162. package/dist/components/form-control/field/Textarea.d.ts +10 -0
  163. package/dist/components/form-control/field/Textarea.d.ts.map +1 -1
  164. package/dist/components/form-control/field/Textarea.js +156 -121
  165. package/dist/components/form-control/field/Textarea.js.map +2 -2
  166. package/dist/components/form-control/field/TimePicker.d.ts +10 -0
  167. package/dist/components/form-control/field/TimePicker.d.ts.map +1 -1
  168. package/dist/components/form-control/field/TimePicker.js +126 -94
  169. package/dist/components/form-control/field/TimePicker.js.map +2 -2
  170. package/dist/components/form-control/select/Select.d.ts +7 -9
  171. package/dist/components/form-control/select/Select.d.ts.map +1 -1
  172. package/dist/components/form-control/select/Select.js +71 -60
  173. package/dist/components/form-control/select/Select.js.map +2 -2
  174. package/dist/components/form-control/select/SelectItem.d.ts.map +1 -1
  175. package/dist/components/form-control/select/SelectItem.js.map +1 -1
  176. package/dist/components/form-control/state-preset/StatePreset.d.ts.map +1 -1
  177. package/dist/components/form-control/state-preset/StatePreset.js +2 -1
  178. package/dist/components/form-control/state-preset/StatePreset.js.map +2 -2
  179. package/dist/components/layout/FormGroup.d.ts.map +1 -1
  180. package/dist/components/layout/FormGroup.js.map +1 -1
  181. package/dist/components/layout/sidebar/Sidebar.d.ts.map +1 -1
  182. package/dist/components/layout/sidebar/Sidebar.js +1 -1
  183. package/dist/components/layout/sidebar/Sidebar.js.map +1 -1
  184. package/dist/components/layout/sidebar/SidebarContainer.d.ts.map +1 -1
  185. package/dist/components/layout/sidebar/SidebarContainer.js.map +1 -1
  186. package/dist/components/layout/sidebar/SidebarMenu.js +1 -1
  187. package/dist/components/layout/sidebar/SidebarMenu.js.map +1 -1
  188. package/dist/components/layout/sidebar/SidebarUser.d.ts.map +1 -1
  189. package/dist/components/layout/sidebar/SidebarUser.js +4 -4
  190. package/dist/components/layout/sidebar/SidebarUser.js.map +1 -1
  191. package/dist/components/layout/topbar/Topbar.js +1 -1
  192. package/dist/components/layout/topbar/TopbarMenu.d.ts.map +1 -1
  193. package/dist/components/layout/topbar/TopbarMenu.js.map +1 -1
  194. package/dist/components/layout/topbar/TopbarUser.d.ts.map +1 -1
  195. package/dist/components/layout/topbar/TopbarUser.js.map +1 -1
  196. package/dist/helpers/createAppStructure.d.ts.map +1 -1
  197. package/dist/helpers/createAppStructure.js +17 -12
  198. package/dist/helpers/createAppStructure.js.map +1 -1
  199. package/dist/helpers/mergeStyles.d.ts.map +1 -1
  200. package/dist/helpers/mergeStyles.js +4 -1
  201. package/dist/helpers/mergeStyles.js.map +1 -1
  202. package/dist/helpers/splitSlots.d.ts.map +1 -1
  203. package/dist/helpers/splitSlots.js.map +1 -1
  204. package/dist/hooks/createControllableSignal.d.ts.map +1 -1
  205. package/dist/hooks/createControllableSignal.js.map +1 -1
  206. package/dist/hooks/createItemTemplate.d.ts +17 -0
  207. package/dist/hooks/createItemTemplate.d.ts.map +1 -0
  208. package/dist/hooks/createItemTemplate.js +40 -0
  209. package/dist/hooks/createItemTemplate.js.map +6 -0
  210. package/dist/hooks/createPointerDrag.d.ts +13 -0
  211. package/dist/hooks/createPointerDrag.d.ts.map +1 -0
  212. package/dist/hooks/createPointerDrag.js +15 -0
  213. package/dist/hooks/createPointerDrag.js.map +6 -0
  214. package/dist/hooks/createSelectionGroup.d.ts +70 -0
  215. package/dist/hooks/createSelectionGroup.d.ts.map +1 -0
  216. package/dist/hooks/createSelectionGroup.js +141 -0
  217. package/dist/hooks/createSelectionGroup.js.map +6 -0
  218. package/dist/hooks/useClipboardValueCopy.js +3 -1
  219. package/dist/hooks/useClipboardValueCopy.js.map +1 -1
  220. package/dist/hooks/useLocalStorage.d.ts +5 -3
  221. package/dist/hooks/useLocalStorage.d.ts.map +1 -1
  222. package/dist/hooks/useLocalStorage.js.map +1 -1
  223. package/dist/hooks/usePrint.d.ts.map +1 -1
  224. package/dist/hooks/usePrint.js +5 -3
  225. package/dist/hooks/usePrint.js.map +1 -1
  226. package/dist/hooks/{createPwaUpdate.d.ts → usePwaUpdate.d.ts} +2 -2
  227. package/dist/hooks/usePwaUpdate.d.ts.map +1 -0
  228. package/dist/hooks/{createPwaUpdate.js → usePwaUpdate.js} +3 -3
  229. package/dist/hooks/usePwaUpdate.js.map +6 -0
  230. package/dist/hooks/useRouterLink.d.ts.map +1 -1
  231. package/dist/hooks/useRouterLink.js.map +1 -1
  232. package/dist/hooks/useSyncConfig.d.ts +3 -3
  233. package/dist/hooks/useSyncConfig.d.ts.map +1 -1
  234. package/dist/hooks/useSyncConfig.js +6 -7
  235. package/dist/hooks/useSyncConfig.js.map +1 -1
  236. package/dist/index.d.ts +5 -6
  237. package/dist/index.d.ts.map +1 -1
  238. package/dist/index.js +6 -7
  239. package/dist/index.js.map +1 -1
  240. package/dist/providers/ConfigContext.d.ts +2 -2
  241. package/dist/providers/ConfigContext.d.ts.map +1 -1
  242. package/dist/providers/InitializeProvider.js +5 -5
  243. package/dist/providers/InitializeProvider.js.map +2 -2
  244. package/dist/providers/ServiceClientProvider.d.ts.map +1 -1
  245. package/dist/providers/ServiceClientProvider.js.map +1 -1
  246. package/dist/providers/ThemeContext.d.ts.map +1 -1
  247. package/dist/providers/ThemeContext.js +2 -1
  248. package/dist/providers/ThemeContext.js.map +2 -2
  249. package/dist/providers/shared-data/SharedDataChangeEvent.d.ts.map +1 -1
  250. package/dist/providers/shared-data/SharedDataChangeEvent.js +1 -3
  251. package/dist/providers/shared-data/SharedDataChangeEvent.js.map +1 -1
  252. package/dist/providers/shared-data/SharedDataContext.d.ts +1 -1
  253. package/dist/providers/shared-data/SharedDataContext.d.ts.map +1 -1
  254. package/dist/providers/shared-data/SharedDataProvider.d.ts.map +1 -1
  255. package/dist/providers/shared-data/SharedDataProvider.js +6 -6
  256. package/dist/providers/shared-data/SharedDataProvider.js.map +2 -2
  257. package/dist/styles/patterns.styles.d.ts +1 -0
  258. package/dist/styles/patterns.styles.d.ts.map +1 -1
  259. package/dist/styles/patterns.styles.js +12 -1
  260. package/dist/styles/patterns.styles.js.map +1 -1
  261. package/dist/styles/tokens.styles.d.ts +2 -1
  262. package/dist/styles/tokens.styles.d.ts.map +1 -1
  263. package/dist/styles/tokens.styles.js +1 -1
  264. package/dist/styles/tokens.styles.js.map +1 -1
  265. package/docs/data-components.md +34 -5
  266. package/docs/disclosure.md +28 -8
  267. package/docs/display.md +19 -2
  268. package/docs/feedback.md +35 -12
  269. package/docs/form-controls.md +289 -33
  270. package/docs/hooks.md +21 -9
  271. package/docs/layout.md +15 -3
  272. package/docs/providers.md +120 -8
  273. package/docs/styling.md +90 -0
  274. package/package.json +3 -3
  275. package/src/components/data/Pagination.tsx +26 -22
  276. package/src/components/data/Table.tsx +1 -1
  277. package/src/components/data/calendar/Calendar.tsx +19 -5
  278. package/src/components/data/kanban/Kanban.tsx +72 -35
  279. package/src/components/data/list/List.tsx +11 -4
  280. package/src/components/data/list/ListItem.tsx +12 -2
  281. package/src/components/data/permission-table/PermissionTable.tsx +32 -5
  282. package/src/components/data/sheet/DataSheet.styles.ts +24 -6
  283. package/src/components/data/sheet/DataSheet.tsx +215 -149
  284. package/src/components/data/sheet/DataSheetColumn.tsx +5 -1
  285. package/src/components/data/sheet/DataSheetConfigDialog.tsx +27 -5
  286. package/src/components/data/sheet/sheetUtils.ts +12 -3
  287. package/src/components/data/sheet/types.ts +2 -2
  288. package/src/components/disclosure/Collapse.tsx +14 -3
  289. package/src/components/disclosure/Dialog.tsx +122 -106
  290. package/src/components/disclosure/DialogContext.ts +8 -5
  291. package/src/components/disclosure/DialogProvider.tsx +19 -7
  292. package/src/components/disclosure/Dropdown.tsx +12 -2
  293. package/src/components/disclosure/Tabs.tsx +29 -5
  294. package/src/components/display/Alert.tsx +3 -4
  295. package/src/components/display/Card.tsx +1 -2
  296. package/src/components/display/Echarts.tsx +12 -5
  297. package/src/components/display/Link.tsx +22 -0
  298. package/src/components/feedback/Progress.tsx +9 -5
  299. package/src/components/feedback/{loading/LoadingContainer.tsx → busy/BusyContainer.tsx} +52 -19
  300. package/src/components/feedback/busy/BusyContext.ts +20 -0
  301. package/src/components/feedback/{loading/LoadingProvider.tsx → busy/BusyProvider.tsx} +10 -10
  302. package/src/components/feedback/notification/NotificationBanner.tsx +14 -3
  303. package/src/components/feedback/notification/NotificationBell.tsx +21 -15
  304. package/src/components/feedback/notification/NotificationContext.ts +4 -1
  305. package/src/components/feedback/notification/NotificationProvider.tsx +4 -1
  306. package/src/components/form-control/Button.tsx +8 -3
  307. package/src/components/form-control/DropdownTrigger.styles.ts +7 -1
  308. package/src/components/form-control/Invalid.tsx +114 -48
  309. package/src/components/form-control/ThemeToggle.tsx +9 -18
  310. package/src/components/form-control/checkbox/Checkbox.styles.ts +7 -10
  311. package/src/components/form-control/checkbox/Checkbox.tsx +39 -28
  312. package/src/components/form-control/checkbox/CheckboxGroup.tsx +18 -97
  313. package/src/components/form-control/checkbox/Radio.tsx +39 -28
  314. package/src/components/form-control/checkbox/RadioGroup.tsx +18 -92
  315. package/src/components/form-control/color-picker/ColorPicker.tsx +51 -18
  316. package/src/components/form-control/combobox/Combobox.tsx +53 -35
  317. package/src/components/form-control/editor/EditorToolbar.tsx +19 -19
  318. package/src/components/form-control/editor/RichTextEditor.tsx +22 -4
  319. package/src/components/form-control/field/DatePicker.tsx +99 -93
  320. package/src/components/form-control/field/DateTimePicker.tsx +115 -96
  321. package/src/components/form-control/field/Field.styles.ts +62 -3
  322. package/src/components/form-control/field/FieldPlaceholder.tsx +18 -0
  323. package/src/components/form-control/field/NumberInput.tsx +136 -84
  324. package/src/components/form-control/field/TextInput.tsx +135 -88
  325. package/src/components/form-control/field/Textarea.tsx +126 -99
  326. package/src/components/form-control/field/TimePicker.tsx +101 -71
  327. package/src/components/form-control/select/Select.tsx +75 -42
  328. package/src/components/form-control/select/SelectItem.tsx +3 -1
  329. package/src/components/form-control/state-preset/StatePreset.tsx +41 -22
  330. package/src/components/layout/FormGroup.tsx +11 -2
  331. package/src/components/layout/sidebar/Sidebar.tsx +3 -2
  332. package/src/components/layout/sidebar/SidebarContainer.tsx +8 -1
  333. package/src/components/layout/sidebar/SidebarMenu.tsx +8 -2
  334. package/src/components/layout/sidebar/SidebarUser.tsx +12 -7
  335. package/src/components/layout/topbar/Topbar.tsx +1 -1
  336. package/src/components/layout/topbar/TopbarMenu.tsx +27 -5
  337. package/src/components/layout/topbar/TopbarUser.tsx +5 -1
  338. package/src/helpers/createAppStructure.ts +29 -15
  339. package/src/helpers/mergeStyles.ts +6 -2
  340. package/src/helpers/splitSlots.ts +4 -1
  341. package/src/hooks/createControllableSignal.ts +2 -1
  342. package/src/hooks/createItemTemplate.tsx +42 -0
  343. package/src/hooks/createPointerDrag.ts +28 -0
  344. package/src/hooks/createSelectionGroup.tsx +235 -0
  345. package/src/hooks/useClipboardValueCopy.ts +5 -2
  346. package/src/hooks/useLocalStorage.ts +11 -5
  347. package/src/hooks/usePrint.ts +9 -4
  348. package/src/hooks/{createPwaUpdate.ts → usePwaUpdate.ts} +1 -1
  349. package/src/hooks/useRouterLink.ts +3 -1
  350. package/src/hooks/useSyncConfig.ts +9 -13
  351. package/src/index.ts +6 -7
  352. package/src/providers/ConfigContext.ts +2 -2
  353. package/src/providers/InitializeProvider.tsx +4 -4
  354. package/src/providers/ServiceClientProvider.tsx +14 -3
  355. package/src/providers/ThemeContext.tsx +12 -3
  356. package/src/providers/shared-data/SharedDataChangeEvent.ts +4 -3
  357. package/src/providers/shared-data/SharedDataContext.ts +1 -1
  358. package/src/providers/shared-data/SharedDataProvider.tsx +13 -8
  359. package/src/styles/patterns.styles.ts +13 -1
  360. package/src/styles/tokens.styles.ts +2 -1
  361. package/tailwind.config.ts +9 -0
  362. package/tailwind.css +1 -1
  363. package/dist/components/display/Card.css +0 -15
  364. package/dist/components/feedback/loading/LoadingContainer.d.ts +0 -12
  365. package/dist/components/feedback/loading/LoadingContainer.d.ts.map +0 -1
  366. package/dist/components/feedback/loading/LoadingContainer.js.map +0 -6
  367. package/dist/components/feedback/loading/LoadingContext.d.ts +0 -11
  368. package/dist/components/feedback/loading/LoadingContext.d.ts.map +0 -1
  369. package/dist/components/feedback/loading/LoadingContext.js +0 -14
  370. package/dist/components/feedback/loading/LoadingContext.js.map +0 -6
  371. package/dist/components/feedback/loading/LoadingProvider.d.ts +0 -7
  372. package/dist/components/feedback/loading/LoadingProvider.d.ts.map +0 -1
  373. package/dist/components/feedback/loading/LoadingProvider.js.map +0 -6
  374. package/dist/hooks/createPwaUpdate.d.ts.map +0 -1
  375. package/dist/hooks/createPwaUpdate.js.map +0 -6
  376. package/src/components/display/Card.css +0 -15
  377. package/src/components/feedback/loading/LoadingContext.ts +0 -20
  378. /package/dist/components/feedback/{loading/LoadingContainer.css → busy/BusyContainer.css} +0 -0
  379. /package/src/components/feedback/{loading/LoadingContainer.css → busy/BusyContainer.css} +0 -0
@@ -1,18 +1,10 @@
1
1
  import clsx from "clsx";
2
- import { type Component, type JSX, Show, splitProps } from "solid-js";
2
+ import { type Component, createMemo, type JSX, Show, splitProps } from "solid-js";
3
3
  import { twMerge } from "tailwind-merge";
4
4
  import { DateTime } from "@simplysm/core-common";
5
5
  import { createControllableSignal } from "../../../hooks/createControllableSignal";
6
- import {
7
- type FieldSize,
8
- fieldBaseClass,
9
- fieldSizeClasses,
10
- fieldInsetClass,
11
- fieldInsetHeightClass,
12
- fieldInsetSizeHeightClasses,
13
- fieldDisabledClass,
14
- fieldInputClass,
15
- } from "./Field.styles";
6
+ import { type FieldSize, fieldInputClass, getFieldWrapperClass } from "./Field.styles";
7
+ import { Invalid } from "../../form-control/Invalid";
16
8
 
17
9
  type DateTimePickerUnit = "minute" | "second";
18
10
 
@@ -52,13 +44,25 @@ export interface DateTimePickerProps {
52
44
 
53
45
  /** 커스텀 style */
54
46
  style?: JSX.CSSProperties;
47
+
48
+ /** 필수 입력 여부 */
49
+ required?: boolean;
50
+
51
+ /** 커스텀 유효성 검사 함수 */
52
+ validate?: (value: DateTime | undefined) => string | undefined;
53
+
54
+ /** touchMode: 포커스 해제 후에만 에러 표시 */
55
+ touchMode?: boolean;
55
56
  }
56
57
 
57
58
  /**
58
- * DateTime 값을 input value용 문자열로 변환 (ISO 형식)
59
+ * DateTime 값을 타입에 맞는 문자열로 변환
59
60
  */
60
- function formatValue(value: DateTime | undefined, unit: DateTimePickerUnit): string {
61
- if (value == null) return "";
61
+ function formatDateTimeValue(
62
+ value: DateTime | undefined,
63
+ unit: DateTimePickerUnit,
64
+ ): string | undefined {
65
+ if (value == null) return undefined;
62
66
 
63
67
  switch (unit) {
64
68
  case "minute":
@@ -79,7 +83,14 @@ function parseValue(str: string, unit: DateTimePickerUnit): DateTime | undefined
79
83
  // yyyy-MM-ddTHH:mm 형식
80
84
  const match = /^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2})$/.exec(str);
81
85
  if (match == null) return undefined;
82
- return new DateTime(Number(match[1]), Number(match[2]), Number(match[3]), Number(match[4]), Number(match[5]), 0);
86
+ return new DateTime(
87
+ Number(match[1]),
88
+ Number(match[2]),
89
+ Number(match[3]),
90
+ Number(match[4]),
91
+ Number(match[5]),
92
+ 0,
93
+ );
83
94
  }
84
95
  case "second": {
85
96
  // yyyy-MM-ddTHH:mm:ss 형식
@@ -97,20 +108,6 @@ function parseValue(str: string, unit: DateTimePickerUnit): DateTime | undefined
97
108
  }
98
109
  }
99
110
 
100
- /**
101
- * min/max 속성을 타입에 맞는 문자열로 변환
102
- */
103
- function formatMinMax(value: DateTime | undefined, unit: DateTimePickerUnit): string | undefined {
104
- if (value == null) return undefined;
105
-
106
- switch (unit) {
107
- case "minute":
108
- return value.toFormatString("yyyy-MM-ddTHH:mm");
109
- case "second":
110
- return value.toFormatString("yyyy-MM-ddTHH:mm:ss");
111
- }
112
- }
113
-
114
111
  /**
115
112
  * DateTimePicker 컴포넌트
116
113
  *
@@ -148,6 +145,9 @@ export const DateTimePicker: Component<DateTimePickerProps> = (props) => {
148
145
  "inset",
149
146
  "class",
150
147
  "style",
148
+ "required",
149
+ "validate",
150
+ "touchMode",
151
151
  ]);
152
152
 
153
153
  // 기본 단위는 minute
@@ -160,7 +160,7 @@ export const DateTimePicker: Component<DateTimePickerProps> = (props) => {
160
160
  });
161
161
 
162
162
  // 표시 값
163
- const displayValue = () => formatValue(value(), fieldType());
163
+ const displayValue = () => formatDateTimeValue(value(), fieldType()) ?? "";
164
164
 
165
165
  // 값 확정 핸들러 (포커스 아웃 또는 Enter 시)
166
166
  const handleChange: JSX.EventHandler<HTMLInputElement, Event> = (e) => {
@@ -171,15 +171,12 @@ export const DateTimePicker: Component<DateTimePickerProps> = (props) => {
171
171
 
172
172
  // wrapper 클래스 (includeCustomClass: inset 모드에서는 커스텀 class를 외부 div에 적용)
173
173
  const getWrapperClass = (includeCustomClass: boolean) =>
174
- twMerge(
175
- fieldBaseClass,
176
- local.size && fieldSizeClasses[local.size],
177
- local.disabled && fieldDisabledClass,
178
- local.inset && fieldInsetClass + " block",
179
- local.inset && (local.size ? fieldInsetSizeHeightClasses[local.size] : fieldInsetHeightClass),
180
-
181
- includeCustomClass && local.class,
182
- );
174
+ getFieldWrapperClass({
175
+ size: local.size,
176
+ disabled: local.disabled,
177
+ inset: local.inset,
178
+ includeCustomClass: includeCustomClass && local.class,
179
+ });
183
180
 
184
181
  // 편집 가능 여부
185
182
  const isEditable = () => !local.disabled && !local.readonly;
@@ -187,68 +184,90 @@ export const DateTimePicker: Component<DateTimePickerProps> = (props) => {
187
184
  // step 속성 (second일 때 1)
188
185
  const getStep = () => (fieldType() === "second" ? "1" : undefined);
189
186
 
187
+ // 유효성 검사 메시지 (순서대로 검사, 최초 실패 메시지 반환)
188
+ const errorMsg = createMemo(() => {
189
+ const v = value();
190
+ if (local.required && v === undefined) return "필수 입력 항목입니다";
191
+ if (v !== undefined) {
192
+ if (local.min !== undefined && v.tick < local.min.tick)
193
+ return `${local.min.toFormatString("yyyy-MM-dd HH:mm:ss")}보다 크거나 같아야 합니다`;
194
+ if (local.max !== undefined && v.tick > local.max.tick)
195
+ return `${local.max.toFormatString("yyyy-MM-dd HH:mm:ss")}보다 작거나 같아야 합니다`;
196
+ }
197
+ return local.validate?.(v);
198
+ });
199
+
190
200
  return (
191
- <Show
192
- when={local.inset}
193
- fallback={
194
- // standalone 모드
195
- <Show
196
- when={isEditable()}
197
- fallback={
198
- <div
199
- {...rest}
200
- data-datetime-field
201
- class={twMerge(getWrapperClass(true), "sd-datetime-field")}
202
- style={local.style}
203
- title={local.title}
204
- >
205
- {displayValue() || "\u00A0"}
206
- </div>
207
- }
208
- >
209
- <div {...rest} data-datetime-field class={getWrapperClass(true)} style={local.style}>
210
- <input
211
- type="datetime-local"
212
- class={fieldInputClass}
213
- value={displayValue()}
214
- title={local.title}
215
- min={formatMinMax(local.min, fieldType())}
216
- max={formatMinMax(local.max, fieldType())}
217
- step={getStep()}
218
- onChange={handleChange}
219
- />
220
- </div>
221
- </Show>
222
- }
201
+ <Invalid
202
+ message={errorMsg()}
203
+ variant={local.inset ? "dot" : "border"}
204
+ touchMode={local.touchMode}
223
205
  >
224
- {/* inset 모드: dual-element overlay 패턴 */}
225
- <div
226
- {...rest}
227
- data-datetime-field
228
- class={twMerge(getWrapperClass(false), "relative", local.class)}
229
- style={local.style}
206
+ <Show
207
+ when={local.inset}
208
+ fallback={
209
+ // standalone 모드
210
+ <Show
211
+ when={isEditable()}
212
+ fallback={
213
+ <div
214
+ {...rest}
215
+ data-datetime-field
216
+ class={twMerge(getWrapperClass(true), "sd-datetime-field")}
217
+ style={local.style}
218
+ title={local.title}
219
+ >
220
+ {displayValue() || "\u00A0"}
221
+ </div>
222
+ }
223
+ >
224
+ <div {...rest} data-datetime-field class={getWrapperClass(true)} style={local.style}>
225
+ <input
226
+ type="datetime-local"
227
+ class={fieldInputClass}
228
+ value={displayValue()}
229
+ title={local.title}
230
+ min={formatDateTimeValue(local.min, fieldType())}
231
+ max={formatDateTimeValue(local.max, fieldType())}
232
+ step={getStep()}
233
+ onChange={handleChange}
234
+ />
235
+ </div>
236
+ </Show>
237
+ }
230
238
  >
239
+ {/* inset 모드: dual-element overlay 패턴 */}
231
240
  <div
232
- data-datetime-field-content
233
- style={{ visibility: isEditable() ? "hidden" : undefined }}
234
- title={local.title}
241
+ {...rest}
242
+ data-datetime-field
243
+ class={clsx("relative", local.class)}
244
+ style={local.style}
235
245
  >
236
- {displayValue() || "\u00A0"}
237
- </div>
238
-
239
- <Show when={isEditable()}>
240
- <input
241
- type="datetime-local"
242
- class={clsx(fieldInputClass, "absolute left-0 top-0 size-full", "px-2 py-1")}
243
- value={displayValue()}
246
+ <div
247
+ data-datetime-field-content
248
+ class={getWrapperClass(false)}
249
+ style={{ visibility: isEditable() ? "hidden" : undefined }}
244
250
  title={local.title}
245
- min={formatMinMax(local.min, fieldType())}
246
- max={formatMinMax(local.max, fieldType())}
247
- step={getStep()}
248
- onChange={handleChange}
249
- />
250
- </Show>
251
- </div>
252
- </Show>
251
+ >
252
+ {displayValue() || "\u00A0"}
253
+ </div>
254
+
255
+ <Show when={isEditable()}>
256
+ <div class={twMerge(getWrapperClass(false), "absolute left-0 top-0 size-full")}>
257
+ <input
258
+ type="datetime-local"
259
+ class={fieldInputClass}
260
+ value={displayValue()}
261
+ title={local.title}
262
+ min={formatDateTimeValue(local.min, fieldType())}
263
+ max={formatDateTimeValue(local.max, fieldType())}
264
+ step={getStep()}
265
+ onChange={handleChange}
266
+ />
267
+ </div>
268
+ </Show>
269
+ </div>
270
+ </Show>
271
+ </Invalid>
253
272
  );
254
273
  };
@@ -1,11 +1,22 @@
1
1
  import clsx from "clsx";
2
+ import { twMerge } from "tailwind-merge";
2
3
  import { type ComponentSize, paddingLg, paddingSm, paddingXl } from "../../../styles/tokens.styles";
3
- import { fieldSurface, insetBase, insetFocusOutline, inputBase } from "../../../styles/patterns.styles";
4
+ import {
5
+ fieldSurface,
6
+ insetBase,
7
+ insetFocusOutline,
8
+ inputBase,
9
+ } from "../../../styles/patterns.styles";
4
10
 
5
11
  export type FieldSize = ComponentSize;
6
12
 
7
13
  // 기본 wrapper 스타일
8
- export const fieldBaseClass = clsx("inline-flex items-center", fieldSurface, "px-2 py-1", "h-field");
14
+ export const fieldBaseClass = clsx(
15
+ "inline-flex items-center",
16
+ fieldSurface,
17
+ "px-2 py-1",
18
+ "h-field",
19
+ );
9
20
 
10
21
  // 사이즈별 스타일
11
22
  export const fieldSizeClasses: Record<FieldSize, string> = {
@@ -15,7 +26,11 @@ export const fieldSizeClasses: Record<FieldSize, string> = {
15
26
  };
16
27
 
17
28
  // inset 스타일
18
- export const fieldInsetClass = clsx(insetBase, "bg-primary-50 dark:bg-primary-950/30", insetFocusOutline);
29
+ export const fieldInsetClass = clsx(
30
+ insetBase,
31
+ "bg-primary-50 dark:bg-primary-950/30",
32
+ insetFocusOutline,
33
+ );
19
34
 
20
35
  // inset 높이 (border 2px 제외)
21
36
  export const fieldInsetHeightClass = "h-field-inset";
@@ -40,3 +55,47 @@ export const textAreaSizeClasses: Record<FieldSize, string> = {
40
55
 
41
56
  // input 스타일
42
57
  export const fieldInputClass = inputBase;
58
+
59
+ // prefixIcon gap 클래스 (nested ternary 대체)
60
+ export const fieldGapClasses: Record<FieldSize | "default", string> = {
61
+ default: "gap-2",
62
+ sm: "gap-1.5",
63
+ lg: "gap-3",
64
+ xl: "gap-4",
65
+ };
66
+
67
+ // 공유 wrapper 클래스 생성 함수
68
+ export function getFieldWrapperClass(options: {
69
+ size?: FieldSize;
70
+ disabled?: boolean;
71
+ inset?: boolean;
72
+ includeCustomClass?: string | false;
73
+ extra?: string | false;
74
+ }): string {
75
+ return twMerge(
76
+ fieldBaseClass,
77
+ options.extra,
78
+ options.size && fieldSizeClasses[options.size],
79
+ options.disabled && fieldDisabledClass,
80
+ options.inset && fieldInsetClass,
81
+ options.inset &&
82
+ (options.size ? fieldInsetSizeHeightClasses[options.size] : fieldInsetHeightClass),
83
+ options.includeCustomClass,
84
+ );
85
+ }
86
+
87
+ // Textarea 전용 wrapper 클래스 생성 함수
88
+ export function getTextareaWrapperClass(options: {
89
+ size?: FieldSize;
90
+ disabled?: boolean;
91
+ inset?: boolean;
92
+ includeCustomClass?: string | false;
93
+ }): string {
94
+ return twMerge(
95
+ textAreaBaseClass,
96
+ options.size && textAreaSizeClasses[options.size],
97
+ options.disabled && fieldDisabledClass,
98
+ options.inset && fieldInsetClass,
99
+ options.includeCustomClass,
100
+ );
101
+ }
@@ -0,0 +1,18 @@
1
+ import { type Component, Show } from "solid-js";
2
+ import { textMuted } from "../../../styles/tokens.styles";
3
+
4
+ /** 값이 없을 때 placeholder 또는 NBSP를 표시하는 공유 컴포넌트 */
5
+ export const PlaceholderFallback: Component<{ value?: string; placeholder?: string }> = (props) => (
6
+ <>
7
+ <Show
8
+ when={props.value}
9
+ fallback={
10
+ <Show when={props.placeholder != null && props.placeholder !== ""} fallback={"\u00A0"}>
11
+ <span class={textMuted}>{props.placeholder}</span>
12
+ </Show>
13
+ }
14
+ >
15
+ {props.value}
16
+ </Show>
17
+ </>
18
+ );
@@ -1,18 +1,25 @@
1
- import { type Component, type JSX, Show, splitProps, createSignal, createEffect } from "solid-js";
1
+ import {
2
+ type Component,
3
+ createEffect,
4
+ createMemo,
5
+ type JSX,
6
+ Show,
7
+ splitProps,
8
+ createSignal,
9
+ } from "solid-js";
2
10
  import clsx from "clsx";
3
11
  import { twMerge } from "tailwind-merge";
12
+ import type { IconProps as TablerIconProps } from "@tabler/icons-solidjs";
4
13
  import { createControllableSignal } from "../../../hooks/createControllableSignal";
5
14
  import {
6
15
  type FieldSize,
7
- fieldBaseClass,
8
- fieldSizeClasses,
9
- fieldInsetClass,
10
- fieldInsetHeightClass,
11
- fieldInsetSizeHeightClasses,
12
- fieldDisabledClass,
13
16
  fieldInputClass,
17
+ fieldGapClasses,
18
+ getFieldWrapperClass,
14
19
  } from "./Field.styles";
15
- import { textMuted } from "../../../styles/tokens.styles";
20
+ import { Icon } from "../../display/Icon";
21
+ import { PlaceholderFallback } from "./FieldPlaceholder";
22
+ import { Invalid } from "../../form-control/Invalid";
16
23
 
17
24
  // NumberInput 전용 input 스타일 (우측 정렬 + 스피너 숨김)
18
25
  const numberInputClass = clsx(
@@ -58,6 +65,24 @@ export interface NumberInputProps {
58
65
 
59
66
  /** 커스텀 style */
60
67
  style?: JSX.CSSProperties;
68
+
69
+ /** 접두 아이콘 */
70
+ prefixIcon?: Component<TablerIconProps>;
71
+
72
+ /** 필수 입력 여부 */
73
+ required?: boolean;
74
+
75
+ /** 최솟값 */
76
+ min?: number;
77
+
78
+ /** 최댓값 */
79
+ max?: number;
80
+
81
+ /** 커스텀 유효성 검사 함수 */
82
+ validate?: (value: number | undefined) => string | undefined;
83
+
84
+ /** touchMode: 포커스 해제 후에만 에러 표시 */
85
+ touchMode?: boolean;
61
86
  }
62
87
 
63
88
  /**
@@ -163,6 +188,12 @@ export const NumberInput: Component<NumberInputProps> = (props) => {
163
188
  "readonly",
164
189
  "size",
165
190
  "inset",
191
+ "prefixIcon",
192
+ "required",
193
+ "min",
194
+ "max",
195
+ "validate",
196
+ "touchMode",
166
197
  "class",
167
198
  "style",
168
199
  ]);
@@ -233,90 +264,111 @@ export const NumberInput: Component<NumberInputProps> = (props) => {
233
264
 
234
265
  // wrapper 클래스 (inset 분기에서는 local.class 제외)
235
266
  const getWrapperClass = (includeCustomClass: boolean) =>
236
- twMerge(
237
- fieldBaseClass,
238
- local.size && fieldSizeClasses[local.size],
239
- local.disabled && fieldDisabledClass,
240
- local.inset && fieldInsetClass,
241
- local.inset && (local.size ? fieldInsetSizeHeightClasses[local.size] : fieldInsetHeightClass),
242
-
243
- includeCustomClass && local.class,
244
- );
267
+ getFieldWrapperClass({
268
+ size: local.size,
269
+ disabled: local.disabled,
270
+ inset: local.inset,
271
+ includeCustomClass: includeCustomClass && local.class,
272
+ extra: local.prefixIcon && fieldGapClasses[local.size ?? "default"],
273
+ });
245
274
 
246
275
  const isEditable = () => !local.disabled && !local.readonly;
247
276
 
277
+ const prefixIconEl = () => (
278
+ <Show when={local.prefixIcon}>
279
+ <Icon icon={local.prefixIcon!} class="shrink-0 opacity-70" />
280
+ </Show>
281
+ );
282
+
283
+ // 유효성 검사 메시지 (순서대로 검사, 최초 실패 메시지 반환)
284
+ const errorMsg = createMemo(() => {
285
+ const v = value();
286
+ if (local.required && v === undefined) return "필수 입력 항목입니다";
287
+ if (v !== undefined) {
288
+ if (local.min !== undefined && v < local.min) return `최솟값은 ${local.min}입니다`;
289
+ if (local.max !== undefined && v > local.max) return `최댓값은 ${local.max}입니다`;
290
+ }
291
+ return local.validate?.(v);
292
+ });
293
+
248
294
  return (
249
- <Show
250
- when={local.inset}
251
- fallback={
252
- // standalone 모드: 기존 Show 패턴 유지
253
- <Show
254
- when={isEditable()}
255
- fallback={
256
- <div
257
- {...rest}
258
- data-number-field
259
- class={twMerge(getWrapperClass(true), "sd-number-field", "justify-end")}
260
- style={local.style}
261
- title={local.title}
262
- >
263
- {formatNumber(value(), local.comma ?? true, local.minDigits) ||
264
- (local.placeholder != null && local.placeholder !== "" ? (
265
- <span class={textMuted}>{local.placeholder}</span>
266
- ) : (
267
- "\u00A0"
268
- ))}
295
+ <Invalid
296
+ message={errorMsg()}
297
+ variant={local.inset ? "dot" : "border"}
298
+ touchMode={local.touchMode}
299
+ >
300
+ <Show
301
+ when={local.inset}
302
+ fallback={
303
+ // standalone 모드: 기존 Show 패턴 유지
304
+ <Show
305
+ when={isEditable()}
306
+ fallback={
307
+ <div
308
+ {...rest}
309
+ data-number-field
310
+ class={twMerge(getWrapperClass(true), "sd-number-field", "justify-end")}
311
+ style={local.style}
312
+ title={local.title}
313
+ >
314
+ {prefixIconEl()}
315
+ <PlaceholderFallback
316
+ value={formatNumber(value(), local.comma ?? true, local.minDigits)}
317
+ placeholder={local.placeholder}
318
+ />
319
+ </div>
320
+ }
321
+ >
322
+ <div {...rest} data-number-field class={getWrapperClass(true)} style={local.style}>
323
+ {prefixIconEl()}
324
+ <input
325
+ type="text"
326
+ inputmode="numeric"
327
+ class={numberInputClass}
328
+ value={displayValue()}
329
+ placeholder={local.placeholder}
330
+ title={local.title}
331
+ onInput={handleInput}
332
+ onFocus={handleFocus}
333
+ onBlur={handleBlur}
334
+ />
269
335
  </div>
270
- }
271
- >
272
- <div {...rest} data-number-field class={getWrapperClass(true)} style={local.style}>
273
- <input
274
- type="text"
275
- inputmode="numeric"
276
- class={numberInputClass}
277
- value={displayValue()}
336
+ </Show>
337
+ }
338
+ >
339
+ {/* inset 모드: dual-element overlay 패턴 */}
340
+ <div {...rest} data-number-field class={clsx("relative", local.class)} style={local.style}>
341
+ <div
342
+ data-number-field-content
343
+ class={twMerge(getWrapperClass(false), "justify-end")}
344
+ style={{ visibility: isEditable() ? "hidden" : undefined }}
345
+ title={local.title}
346
+ >
347
+ {prefixIconEl()}
348
+ <PlaceholderFallback
349
+ value={formatNumber(value(), local.comma ?? true, local.minDigits)}
278
350
  placeholder={local.placeholder}
279
- title={local.title}
280
- onInput={handleInput}
281
- onFocus={handleFocus}
282
- onBlur={handleBlur}
283
351
  />
284
352
  </div>
285
- </Show>
286
- }
287
- >
288
- {/* inset 모드: dual-element overlay 패턴 */}
289
- <div {...rest} data-number-field class={clsx("relative", local.class)} style={local.style}>
290
- <div
291
- data-number-field-content
292
- class={twMerge(getWrapperClass(false), "justify-end")}
293
- style={{ visibility: isEditable() ? "hidden" : undefined }}
294
- title={local.title}
295
- >
296
- {formatNumber(value(), local.comma ?? true, local.minDigits) ||
297
- (local.placeholder != null && local.placeholder !== "" ? (
298
- <span class={textMuted}>{local.placeholder}</span>
299
- ) : (
300
- "\u00A0"
301
- ))}
302
- </div>
303
353
 
304
- <Show when={isEditable()}>
305
- <div class={twMerge(getWrapperClass(false), "absolute left-0 top-0 size-full")}>
306
- <input
307
- type="text"
308
- inputmode="numeric"
309
- class={numberInputClass}
310
- value={displayValue()}
311
- placeholder={local.placeholder}
312
- title={local.title}
313
- onInput={handleInput}
314
- onFocus={handleFocus}
315
- onBlur={handleBlur}
316
- />
317
- </div>
318
- </Show>
319
- </div>
320
- </Show>
354
+ <Show when={isEditable()}>
355
+ <div class={twMerge(getWrapperClass(false), "absolute left-0 top-0 size-full")}>
356
+ {prefixIconEl()}
357
+ <input
358
+ type="text"
359
+ inputmode="numeric"
360
+ class={numberInputClass}
361
+ value={displayValue()}
362
+ placeholder={local.placeholder}
363
+ title={local.title}
364
+ onInput={handleInput}
365
+ onFocus={handleFocus}
366
+ onBlur={handleBlur}
367
+ />
368
+ </div>
369
+ </Show>
370
+ </div>
371
+ </Show>
372
+ </Invalid>
321
373
  );
322
374
  };