@simplysm/solid 13.0.0-beta.11

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 (581) hide show
  1. package/README.md +1652 -0
  2. package/dist/components/data/Pagination.js +110 -0
  3. package/dist/components/data/Pagination.js.map +7 -0
  4. package/dist/components/data/Table.js +34 -0
  5. package/dist/components/data/Table.js.map +7 -0
  6. package/dist/components/data/calendar/Calendar.js +90 -0
  7. package/dist/components/data/calendar/Calendar.js.map +7 -0
  8. package/dist/components/data/kanban/Kanban.js +367 -0
  9. package/dist/components/data/kanban/Kanban.js.map +7 -0
  10. package/dist/components/data/kanban/KanbanContext.js +24 -0
  11. package/dist/components/data/kanban/KanbanContext.js.map +7 -0
  12. package/dist/components/data/list/List.js +133 -0
  13. package/dist/components/data/list/List.js.map +7 -0
  14. package/dist/components/data/list/ListContext.js +8 -0
  15. package/dist/components/data/list/ListContext.js.map +7 -0
  16. package/dist/components/data/list/ListItem.js +101 -0
  17. package/dist/components/data/list/ListItem.js.map +7 -0
  18. package/dist/components/data/list/ListItem.styles.js +43 -0
  19. package/dist/components/data/list/ListItem.styles.js.map +7 -0
  20. package/dist/components/data/permission-table/PermissionTable.js +189 -0
  21. package/dist/components/data/permission-table/PermissionTable.js.map +7 -0
  22. package/dist/components/data/sheet/DataSheet.js +907 -0
  23. package/dist/components/data/sheet/DataSheet.js.map +7 -0
  24. package/dist/components/data/sheet/DataSheet.styles.js +142 -0
  25. package/dist/components/data/sheet/DataSheet.styles.js.map +7 -0
  26. package/dist/components/data/sheet/DataSheetColumn.js +28 -0
  27. package/dist/components/data/sheet/DataSheetColumn.js.map +7 -0
  28. package/dist/components/data/sheet/DataSheetConfigDialog.js +83 -0
  29. package/dist/components/data/sheet/DataSheetConfigDialog.js.map +7 -0
  30. package/dist/components/data/sheet/sheetUtils.js +125 -0
  31. package/dist/components/data/sheet/sheetUtils.js.map +7 -0
  32. package/dist/components/data/sheet/types.js +1 -0
  33. package/dist/components/data/sheet/types.js.map +7 -0
  34. package/dist/components/disclosure/Collapse.js +45 -0
  35. package/dist/components/disclosure/Collapse.js.map +7 -0
  36. package/dist/components/disclosure/Dialog.js +367 -0
  37. package/dist/components/disclosure/Dialog.js.map +7 -0
  38. package/dist/components/disclosure/DialogContext.js +14 -0
  39. package/dist/components/disclosure/DialogContext.js.map +7 -0
  40. package/dist/components/disclosure/DialogInstanceContext.js +10 -0
  41. package/dist/components/disclosure/DialogInstanceContext.js.map +7 -0
  42. package/dist/components/disclosure/DialogProvider.js +88 -0
  43. package/dist/components/disclosure/DialogProvider.js.map +7 -0
  44. package/dist/components/disclosure/Dropdown.js +244 -0
  45. package/dist/components/disclosure/Dropdown.js.map +7 -0
  46. package/dist/components/disclosure/Tabs.js +75 -0
  47. package/dist/components/disclosure/Tabs.js.map +7 -0
  48. package/dist/components/disclosure/dialogZIndex.js +32 -0
  49. package/dist/components/disclosure/dialogZIndex.js.map +7 -0
  50. package/dist/components/display/Alert.js +18 -0
  51. package/dist/components/display/Alert.js.map +7 -0
  52. package/dist/components/display/Barcode.js +39 -0
  53. package/dist/components/display/Barcode.js.map +7 -0
  54. package/dist/components/display/Card.js +21 -0
  55. package/dist/components/display/Card.js.map +7 -0
  56. package/dist/components/display/Echarts.js +33 -0
  57. package/dist/components/display/Echarts.js.map +7 -0
  58. package/dist/components/display/Icon.js +10 -0
  59. package/dist/components/display/Icon.js.map +7 -0
  60. package/dist/components/display/Tag.js +20 -0
  61. package/dist/components/display/Tag.js.map +7 -0
  62. package/dist/components/feedback/Progress.js +37 -0
  63. package/dist/components/feedback/Progress.js.map +7 -0
  64. package/dist/components/feedback/loading/LoadingContainer.js +83 -0
  65. package/dist/components/feedback/loading/LoadingContainer.js.map +7 -0
  66. package/dist/components/feedback/loading/LoadingContext.js +14 -0
  67. package/dist/components/feedback/loading/LoadingContext.js.map +7 -0
  68. package/dist/components/feedback/loading/LoadingProvider.js +47 -0
  69. package/dist/components/feedback/loading/LoadingProvider.js.map +7 -0
  70. package/dist/components/feedback/notification/NotificationBanner.js +61 -0
  71. package/dist/components/feedback/notification/NotificationBanner.js.map +7 -0
  72. package/dist/components/feedback/notification/NotificationBell.js +85 -0
  73. package/dist/components/feedback/notification/NotificationBell.js.map +7 -0
  74. package/dist/components/feedback/notification/NotificationContext.js +14 -0
  75. package/dist/components/feedback/notification/NotificationContext.js.map +7 -0
  76. package/dist/components/feedback/notification/NotificationProvider.js +101 -0
  77. package/dist/components/feedback/notification/NotificationProvider.js.map +7 -0
  78. package/dist/components/feedback/notification/index.js +5 -0
  79. package/dist/components/feedback/notification/index.js.map +7 -0
  80. package/dist/components/feedback/print/Print.js +12 -0
  81. package/dist/components/feedback/print/Print.js.map +7 -0
  82. package/dist/components/feedback/print/PrintInstanceContext.js +10 -0
  83. package/dist/components/feedback/print/PrintInstanceContext.js.map +7 -0
  84. package/dist/components/form-control/Button.js +74 -0
  85. package/dist/components/form-control/Button.js.map +7 -0
  86. package/dist/components/form-control/DropdownTrigger.styles.js +44 -0
  87. package/dist/components/form-control/DropdownTrigger.styles.js.map +7 -0
  88. package/dist/components/form-control/ThemeToggle.js +57 -0
  89. package/dist/components/form-control/ThemeToggle.js.map +7 -0
  90. package/dist/components/form-control/checkbox/Checkbox.js +78 -0
  91. package/dist/components/form-control/checkbox/Checkbox.js.map +7 -0
  92. package/dist/components/form-control/checkbox/Checkbox.styles.js +57 -0
  93. package/dist/components/form-control/checkbox/Checkbox.styles.js.map +7 -0
  94. package/dist/components/form-control/checkbox/CheckboxGroup.js +65 -0
  95. package/dist/components/form-control/checkbox/CheckboxGroup.js.map +7 -0
  96. package/dist/components/form-control/checkbox/Radio.js +78 -0
  97. package/dist/components/form-control/checkbox/Radio.js.map +7 -0
  98. package/dist/components/form-control/checkbox/RadioGroup.js +60 -0
  99. package/dist/components/form-control/checkbox/RadioGroup.js.map +7 -0
  100. package/dist/components/form-control/color-picker/ColorPicker.js +55 -0
  101. package/dist/components/form-control/color-picker/ColorPicker.js.map +7 -0
  102. package/dist/components/form-control/combobox/Combobox.js +214 -0
  103. package/dist/components/form-control/combobox/Combobox.js.map +7 -0
  104. package/dist/components/form-control/combobox/ComboboxContext.js +14 -0
  105. package/dist/components/form-control/combobox/ComboboxContext.js.map +7 -0
  106. package/dist/components/form-control/combobox/ComboboxItem.js +49 -0
  107. package/dist/components/form-control/combobox/ComboboxItem.js.map +7 -0
  108. package/dist/components/form-control/date-range-picker/DateRangePicker.js +136 -0
  109. package/dist/components/form-control/date-range-picker/DateRangePicker.js.map +7 -0
  110. package/dist/components/form-control/editor/EditorToolbar.js +290 -0
  111. package/dist/components/form-control/editor/EditorToolbar.js.map +7 -0
  112. package/dist/components/form-control/editor/RichTextEditor.js +114 -0
  113. package/dist/components/form-control/editor/RichTextEditor.js.map +7 -0
  114. package/dist/components/form-control/field/DatePicker.js +167 -0
  115. package/dist/components/form-control/field/DatePicker.js.map +7 -0
  116. package/dist/components/form-control/field/DateTimePicker.js +168 -0
  117. package/dist/components/form-control/field/DateTimePicker.js.map +7 -0
  118. package/dist/components/form-control/field/Field.styles.js +35 -0
  119. package/dist/components/form-control/field/Field.styles.js.map +7 -0
  120. package/dist/components/form-control/field/NumberInput.js +193 -0
  121. package/dist/components/form-control/field/NumberInput.js.map +7 -0
  122. package/dist/components/form-control/field/TextInput.js +178 -0
  123. package/dist/components/form-control/field/TextInput.js.map +7 -0
  124. package/dist/components/form-control/field/Textarea.js +186 -0
  125. package/dist/components/form-control/field/Textarea.js.map +7 -0
  126. package/dist/components/form-control/field/TimePicker.js +138 -0
  127. package/dist/components/form-control/field/TimePicker.js.map +7 -0
  128. package/dist/components/form-control/numpad/Numpad.js +107 -0
  129. package/dist/components/form-control/numpad/Numpad.js.map +7 -0
  130. package/dist/components/form-control/select/Select.js +196 -0
  131. package/dist/components/form-control/select/Select.js.map +7 -0
  132. package/dist/components/form-control/select/SelectContext.js +14 -0
  133. package/dist/components/form-control/select/SelectContext.js.map +7 -0
  134. package/dist/components/form-control/select/SelectItem.js +65 -0
  135. package/dist/components/form-control/select/SelectItem.js.map +7 -0
  136. package/dist/components/form-control/state-preset/StatePreset.js +195 -0
  137. package/dist/components/form-control/state-preset/StatePreset.js.map +7 -0
  138. package/dist/components/layout/FormGroup.js +34 -0
  139. package/dist/components/layout/FormGroup.js.map +7 -0
  140. package/dist/components/layout/FormTable.js +24 -0
  141. package/dist/components/layout/FormTable.js.map +7 -0
  142. package/dist/components/layout/sidebar/Sidebar.js +63 -0
  143. package/dist/components/layout/sidebar/Sidebar.js.map +7 -0
  144. package/dist/components/layout/sidebar/SidebarContainer.js +70 -0
  145. package/dist/components/layout/sidebar/SidebarContainer.js.map +7 -0
  146. package/dist/components/layout/sidebar/SidebarContext.js +20 -0
  147. package/dist/components/layout/sidebar/SidebarContext.js.map +7 -0
  148. package/dist/components/layout/sidebar/SidebarMenu.js +84 -0
  149. package/dist/components/layout/sidebar/SidebarMenu.js.map +7 -0
  150. package/dist/components/layout/sidebar/SidebarUser.js +51 -0
  151. package/dist/components/layout/sidebar/SidebarUser.js.map +7 -0
  152. package/dist/components/layout/topbar/Topbar.js +48 -0
  153. package/dist/components/layout/topbar/Topbar.js.map +7 -0
  154. package/dist/components/layout/topbar/TopbarContainer.js +13 -0
  155. package/dist/components/layout/topbar/TopbarContainer.js.map +7 -0
  156. package/dist/components/layout/topbar/TopbarMenu.js +106 -0
  157. package/dist/components/layout/topbar/TopbarMenu.js.map +7 -0
  158. package/dist/components/layout/topbar/TopbarUser.js +44 -0
  159. package/dist/components/layout/topbar/TopbarUser.js.map +7 -0
  160. package/dist/core-browser/src/extensions/element-ext.d.ts +98 -0
  161. package/dist/core-browser/src/extensions/element-ext.d.ts.map +1 -0
  162. package/dist/core-browser/src/extensions/html-element-ext.d.ts +54 -0
  163. package/dist/core-browser/src/extensions/html-element-ext.d.ts.map +1 -0
  164. package/dist/core-browser/src/index.d.ts +7 -0
  165. package/dist/core-browser/src/index.d.ts.map +1 -0
  166. package/dist/core-browser/src/utils/blob.d.ts +10 -0
  167. package/dist/core-browser/src/utils/blob.d.ts.map +1 -0
  168. package/dist/core-browser/src/utils/download.d.ts +11 -0
  169. package/dist/core-browser/src/utils/download.d.ts.map +1 -0
  170. package/dist/core-common/src/common.types.d.ts +74 -0
  171. package/dist/core-common/src/common.types.d.ts.map +1 -0
  172. package/dist/core-common/src/env.d.ts +6 -0
  173. package/dist/core-common/src/env.d.ts.map +1 -0
  174. package/dist/core-common/src/errors/argument-error.d.ts +25 -0
  175. package/dist/core-common/src/errors/argument-error.d.ts.map +1 -0
  176. package/dist/core-common/src/errors/not-implemented-error.d.ts +29 -0
  177. package/dist/core-common/src/errors/not-implemented-error.d.ts.map +1 -0
  178. package/dist/core-common/src/errors/sd-error.d.ts +27 -0
  179. package/dist/core-common/src/errors/sd-error.d.ts.map +1 -0
  180. package/dist/core-common/src/errors/timeout-error.d.ts +31 -0
  181. package/dist/core-common/src/errors/timeout-error.d.ts.map +1 -0
  182. package/dist/core-common/src/extensions/arr-ext.d.ts +15 -0
  183. package/dist/core-common/src/extensions/arr-ext.d.ts.map +1 -0
  184. package/dist/core-common/src/extensions/arr-ext.helpers.d.ts +19 -0
  185. package/dist/core-common/src/extensions/arr-ext.helpers.d.ts.map +1 -0
  186. package/dist/core-common/src/extensions/arr-ext.types.d.ts +215 -0
  187. package/dist/core-common/src/extensions/arr-ext.types.d.ts.map +1 -0
  188. package/dist/core-common/src/extensions/map-ext.d.ts +57 -0
  189. package/dist/core-common/src/extensions/map-ext.d.ts.map +1 -0
  190. package/dist/core-common/src/extensions/set-ext.d.ts +36 -0
  191. package/dist/core-common/src/extensions/set-ext.d.ts.map +1 -0
  192. package/dist/core-common/src/features/debounce-queue.d.ts +53 -0
  193. package/dist/core-common/src/features/debounce-queue.d.ts.map +1 -0
  194. package/dist/core-common/src/features/event-emitter.d.ts +66 -0
  195. package/dist/core-common/src/features/event-emitter.d.ts.map +1 -0
  196. package/dist/core-common/src/features/serial-queue.d.ts +47 -0
  197. package/dist/core-common/src/features/serial-queue.d.ts.map +1 -0
  198. package/dist/core-common/src/index.d.ts +32 -0
  199. package/dist/core-common/src/index.d.ts.map +1 -0
  200. package/dist/core-common/src/types/date-only.d.ts +152 -0
  201. package/dist/core-common/src/types/date-only.d.ts.map +1 -0
  202. package/dist/core-common/src/types/date-time.d.ts +96 -0
  203. package/dist/core-common/src/types/date-time.d.ts.map +1 -0
  204. package/dist/core-common/src/types/lazy-gc-map.d.ts +80 -0
  205. package/dist/core-common/src/types/lazy-gc-map.d.ts.map +1 -0
  206. package/dist/core-common/src/types/time.d.ts +68 -0
  207. package/dist/core-common/src/types/time.d.ts.map +1 -0
  208. package/dist/core-common/src/types/uuid.d.ts +35 -0
  209. package/dist/core-common/src/types/uuid.d.ts.map +1 -0
  210. package/dist/core-common/src/utils/bytes.d.ts +51 -0
  211. package/dist/core-common/src/utils/bytes.d.ts.map +1 -0
  212. package/dist/core-common/src/utils/date-format.d.ts +90 -0
  213. package/dist/core-common/src/utils/date-format.d.ts.map +1 -0
  214. package/dist/core-common/src/utils/json.d.ts +34 -0
  215. package/dist/core-common/src/utils/json.d.ts.map +1 -0
  216. package/dist/core-common/src/utils/num.d.ts +60 -0
  217. package/dist/core-common/src/utils/num.d.ts.map +1 -0
  218. package/dist/core-common/src/utils/obj.d.ts +258 -0
  219. package/dist/core-common/src/utils/obj.d.ts.map +1 -0
  220. package/dist/core-common/src/utils/path.d.ts +23 -0
  221. package/dist/core-common/src/utils/path.d.ts.map +1 -0
  222. package/dist/core-common/src/utils/primitive.d.ts +18 -0
  223. package/dist/core-common/src/utils/primitive.d.ts.map +1 -0
  224. package/dist/core-common/src/utils/str.d.ts +103 -0
  225. package/dist/core-common/src/utils/str.d.ts.map +1 -0
  226. package/dist/core-common/src/utils/template-strings.d.ts +84 -0
  227. package/dist/core-common/src/utils/template-strings.d.ts.map +1 -0
  228. package/dist/core-common/src/utils/transferable.d.ts +47 -0
  229. package/dist/core-common/src/utils/transferable.d.ts.map +1 -0
  230. package/dist/core-common/src/utils/wait.d.ts +19 -0
  231. package/dist/core-common/src/utils/wait.d.ts.map +1 -0
  232. package/dist/core-common/src/utils/xml.d.ts +36 -0
  233. package/dist/core-common/src/utils/xml.d.ts.map +1 -0
  234. package/dist/core-common/src/zip/sd-zip.d.ts +80 -0
  235. package/dist/core-common/src/zip/sd-zip.d.ts.map +1 -0
  236. package/dist/directives/ripple.js +106 -0
  237. package/dist/directives/ripple.js.map +7 -0
  238. package/dist/helpers/createAppStructure.js +96 -0
  239. package/dist/helpers/createAppStructure.js.map +7 -0
  240. package/dist/helpers/mergeStyles.js +27 -0
  241. package/dist/helpers/mergeStyles.js.map +7 -0
  242. package/dist/helpers/splitSlots.js +25 -0
  243. package/dist/helpers/splitSlots.js.map +7 -0
  244. package/dist/hooks/createControllableSignal.js +24 -0
  245. package/dist/hooks/createControllableSignal.js.map +7 -0
  246. package/dist/hooks/createIMEHandler.js +50 -0
  247. package/dist/hooks/createIMEHandler.js.map +7 -0
  248. package/dist/hooks/createMountTransition.js +33 -0
  249. package/dist/hooks/createMountTransition.js.map +7 -0
  250. package/dist/hooks/useClipboardValueCopy.js +120 -0
  251. package/dist/hooks/useClipboardValueCopy.js.map +7 -0
  252. package/dist/hooks/usePersisted.js +25 -0
  253. package/dist/hooks/usePersisted.js.map +7 -0
  254. package/dist/hooks/usePrint.js +208 -0
  255. package/dist/hooks/usePrint.js.map +7 -0
  256. package/dist/hooks/useRouterLink.js +24 -0
  257. package/dist/hooks/useRouterLink.js.map +7 -0
  258. package/dist/index.js +94 -0
  259. package/dist/index.js.map +7 -0
  260. package/dist/orm-common/src/db-context.d.ts +669 -0
  261. package/dist/orm-common/src/db-context.d.ts.map +1 -0
  262. package/dist/orm-common/src/errors/db-transaction-error.d.ts +51 -0
  263. package/dist/orm-common/src/errors/db-transaction-error.d.ts.map +1 -0
  264. package/dist/orm-common/src/exec/executable.d.ts +79 -0
  265. package/dist/orm-common/src/exec/executable.d.ts.map +1 -0
  266. package/dist/orm-common/src/exec/queryable.d.ts +708 -0
  267. package/dist/orm-common/src/exec/queryable.d.ts.map +1 -0
  268. package/dist/orm-common/src/exec/search-parser.d.ts +72 -0
  269. package/dist/orm-common/src/exec/search-parser.d.ts.map +1 -0
  270. package/dist/orm-common/src/expr/expr-unit.d.ts +25 -0
  271. package/dist/orm-common/src/expr/expr-unit.d.ts.map +1 -0
  272. package/dist/orm-common/src/expr/expr.d.ts +1369 -0
  273. package/dist/orm-common/src/expr/expr.d.ts.map +1 -0
  274. package/dist/orm-common/src/index.d.ts +32 -0
  275. package/dist/orm-common/src/index.d.ts.map +1 -0
  276. package/dist/orm-common/src/models/system-migration.d.ts +10 -0
  277. package/dist/orm-common/src/models/system-migration.d.ts.map +1 -0
  278. package/dist/orm-common/src/query-builder/base/expr-renderer-base.d.ts +95 -0
  279. package/dist/orm-common/src/query-builder/base/expr-renderer-base.d.ts.map +1 -0
  280. package/dist/orm-common/src/query-builder/base/query-builder-base.d.ts +66 -0
  281. package/dist/orm-common/src/query-builder/base/query-builder-base.d.ts.map +1 -0
  282. package/dist/orm-common/src/query-builder/mssql/mssql-expr-renderer.d.ts +84 -0
  283. package/dist/orm-common/src/query-builder/mssql/mssql-expr-renderer.d.ts.map +1 -0
  284. package/dist/orm-common/src/query-builder/mssql/mssql-query-builder.d.ts +45 -0
  285. package/dist/orm-common/src/query-builder/mssql/mssql-query-builder.d.ts.map +1 -0
  286. package/dist/orm-common/src/query-builder/mysql/mysql-expr-renderer.d.ts +84 -0
  287. package/dist/orm-common/src/query-builder/mysql/mysql-expr-renderer.d.ts.map +1 -0
  288. package/dist/orm-common/src/query-builder/mysql/mysql-query-builder.d.ts +54 -0
  289. package/dist/orm-common/src/query-builder/mysql/mysql-query-builder.d.ts.map +1 -0
  290. package/dist/orm-common/src/query-builder/postgresql/postgresql-expr-renderer.d.ts +84 -0
  291. package/dist/orm-common/src/query-builder/postgresql/postgresql-expr-renderer.d.ts.map +1 -0
  292. package/dist/orm-common/src/query-builder/postgresql/postgresql-query-builder.d.ts +52 -0
  293. package/dist/orm-common/src/query-builder/postgresql/postgresql-query-builder.d.ts.map +1 -0
  294. package/dist/orm-common/src/query-builder/query-builder.d.ts +7 -0
  295. package/dist/orm-common/src/query-builder/query-builder.d.ts.map +1 -0
  296. package/dist/orm-common/src/schema/factory/column-builder.d.ts +394 -0
  297. package/dist/orm-common/src/schema/factory/column-builder.d.ts.map +1 -0
  298. package/dist/orm-common/src/schema/factory/index-builder.d.ts +151 -0
  299. package/dist/orm-common/src/schema/factory/index-builder.d.ts.map +1 -0
  300. package/dist/orm-common/src/schema/factory/relation-builder.d.ts +337 -0
  301. package/dist/orm-common/src/schema/factory/relation-builder.d.ts.map +1 -0
  302. package/dist/orm-common/src/schema/procedure-builder.d.ts +202 -0
  303. package/dist/orm-common/src/schema/procedure-builder.d.ts.map +1 -0
  304. package/dist/orm-common/src/schema/table-builder.d.ts +259 -0
  305. package/dist/orm-common/src/schema/table-builder.d.ts.map +1 -0
  306. package/dist/orm-common/src/schema/view-builder.d.ts +183 -0
  307. package/dist/orm-common/src/schema/view-builder.d.ts.map +1 -0
  308. package/dist/orm-common/src/types/column.d.ts +172 -0
  309. package/dist/orm-common/src/types/column.d.ts.map +1 -0
  310. package/dist/orm-common/src/types/db.d.ts +175 -0
  311. package/dist/orm-common/src/types/db.d.ts.map +1 -0
  312. package/dist/orm-common/src/types/expr.d.ts +474 -0
  313. package/dist/orm-common/src/types/expr.d.ts.map +1 -0
  314. package/dist/orm-common/src/types/query-def.d.ts +351 -0
  315. package/dist/orm-common/src/types/query-def.d.ts.map +1 -0
  316. package/dist/orm-common/src/utils/result-parser.d.ts +38 -0
  317. package/dist/orm-common/src/utils/result-parser.d.ts.map +1 -0
  318. package/dist/providers/ConfigContext.js +14 -0
  319. package/dist/providers/ConfigContext.js.map +7 -0
  320. package/dist/providers/InitializeProvider.js +10 -0
  321. package/dist/providers/InitializeProvider.js.map +7 -0
  322. package/dist/providers/ServiceClientContext.js +16 -0
  323. package/dist/providers/ServiceClientContext.js.map +7 -0
  324. package/dist/providers/ServiceClientProvider.js +116 -0
  325. package/dist/providers/ServiceClientProvider.js.map +7 -0
  326. package/dist/providers/ThemeContext.js +48 -0
  327. package/dist/providers/ThemeContext.js.map +7 -0
  328. package/dist/providers/shared-data/SharedDataChangeEvent.js +8 -0
  329. package/dist/providers/shared-data/SharedDataChangeEvent.js.map +7 -0
  330. package/dist/providers/shared-data/SharedDataContext.js +16 -0
  331. package/dist/providers/shared-data/SharedDataContext.js.map +7 -0
  332. package/dist/providers/shared-data/SharedDataProvider.js +115 -0
  333. package/dist/providers/shared-data/SharedDataProvider.js.map +7 -0
  334. package/dist/service-client/src/features/event-client.d.ts +14 -0
  335. package/dist/service-client/src/features/event-client.d.ts.map +1 -0
  336. package/dist/service-client/src/features/file-client.d.ts +13 -0
  337. package/dist/service-client/src/features/file-client.d.ts.map +1 -0
  338. package/dist/service-client/src/features/orm/orm-client-connector.d.ts +10 -0
  339. package/dist/service-client/src/features/orm/orm-client-connector.d.ts.map +1 -0
  340. package/dist/service-client/src/features/orm/orm-client-db-context-executor.d.ts +26 -0
  341. package/dist/service-client/src/features/orm/orm-client-db-context-executor.d.ts.map +1 -0
  342. package/dist/service-client/src/features/orm/orm-connect-config.d.ts +13 -0
  343. package/dist/service-client/src/features/orm/orm-connect-config.d.ts.map +1 -0
  344. package/dist/service-client/src/index.d.ts +12 -0
  345. package/dist/service-client/src/index.d.ts.map +1 -0
  346. package/dist/service-client/src/protocol/client-protocol-wrapper.d.ts +23 -0
  347. package/dist/service-client/src/protocol/client-protocol-wrapper.d.ts.map +1 -0
  348. package/dist/service-client/src/service-client.d.ts +41 -0
  349. package/dist/service-client/src/service-client.d.ts.map +1 -0
  350. package/dist/service-client/src/transport/service-transport.d.ts +24 -0
  351. package/dist/service-client/src/transport/service-transport.d.ts.map +1 -0
  352. package/dist/service-client/src/transport/socket-provider.d.ts +31 -0
  353. package/dist/service-client/src/transport/socket-provider.d.ts.map +1 -0
  354. package/dist/service-client/src/types/connection-config.d.ts +8 -0
  355. package/dist/service-client/src/types/connection-config.d.ts.map +1 -0
  356. package/dist/service-client/src/types/progress.types.d.ts +10 -0
  357. package/dist/service-client/src/types/progress.types.d.ts.map +1 -0
  358. package/dist/service-common/src/index.d.ts +8 -0
  359. package/dist/service-common/src/index.d.ts.map +1 -0
  360. package/dist/service-common/src/protocol/protocol.types.d.ts +100 -0
  361. package/dist/service-common/src/protocol/protocol.types.d.ts.map +1 -0
  362. package/dist/service-common/src/protocol/service-protocol.d.ts +63 -0
  363. package/dist/service-common/src/protocol/service-protocol.d.ts.map +1 -0
  364. package/dist/service-common/src/service-types/auto-update-service.types.d.ts +17 -0
  365. package/dist/service-common/src/service-types/auto-update-service.types.d.ts.map +1 -0
  366. package/dist/service-common/src/service-types/crypto-service.types.d.ts +22 -0
  367. package/dist/service-common/src/service-types/crypto-service.types.d.ts.map +1 -0
  368. package/dist/service-common/src/service-types/orm-service.types.d.ts +30 -0
  369. package/dist/service-common/src/service-types/orm-service.types.d.ts.map +1 -0
  370. package/dist/service-common/src/service-types/smtp-service.types.d.ts +55 -0
  371. package/dist/service-common/src/service-types/smtp-service.types.d.ts.map +1 -0
  372. package/dist/service-common/src/types.d.ts +43 -0
  373. package/dist/service-common/src/types.d.ts.map +1 -0
  374. package/dist/solid/src/components/data/Pagination.d.ts +12 -0
  375. package/dist/solid/src/components/data/Pagination.d.ts.map +1 -0
  376. package/dist/solid/src/components/data/Table.d.ts +6 -0
  377. package/dist/solid/src/components/data/Table.d.ts.map +1 -0
  378. package/dist/solid/src/components/data/calendar/Calendar.d.ts +15 -0
  379. package/dist/solid/src/components/data/calendar/Calendar.d.ts.map +1 -0
  380. package/dist/solid/src/components/data/kanban/Kanban.d.ts +38 -0
  381. package/dist/solid/src/components/data/kanban/Kanban.d.ts.map +1 -0
  382. package/dist/solid/src/components/data/kanban/KanbanContext.d.ts +40 -0
  383. package/dist/solid/src/components/data/kanban/KanbanContext.d.ts.map +1 -0
  384. package/dist/solid/src/components/data/list/List.d.ts +36 -0
  385. package/dist/solid/src/components/data/list/List.d.ts.map +1 -0
  386. package/dist/solid/src/components/data/list/ListContext.d.ts +9 -0
  387. package/dist/solid/src/components/data/list/ListContext.d.ts.map +1 -0
  388. package/dist/solid/src/components/data/list/ListItem.d.ts +88 -0
  389. package/dist/solid/src/components/data/list/ListItem.d.ts.map +1 -0
  390. package/dist/solid/src/components/data/list/ListItem.styles.d.ts +10 -0
  391. package/dist/solid/src/components/data/list/ListItem.styles.d.ts.map +1 -0
  392. package/dist/solid/src/components/data/permission-table/PermissionTable.d.ts +26 -0
  393. package/dist/solid/src/components/data/permission-table/PermissionTable.d.ts.map +1 -0
  394. package/dist/solid/src/components/data/sheet/DataSheet.d.ts +12 -0
  395. package/dist/solid/src/components/data/sheet/DataSheet.d.ts.map +1 -0
  396. package/dist/solid/src/components/data/sheet/DataSheet.styles.d.ts +33 -0
  397. package/dist/solid/src/components/data/sheet/DataSheet.styles.d.ts.map +1 -0
  398. package/dist/solid/src/components/data/sheet/DataSheetColumn.d.ts +5 -0
  399. package/dist/solid/src/components/data/sheet/DataSheetColumn.d.ts.map +1 -0
  400. package/dist/solid/src/components/data/sheet/DataSheetConfigDialog.d.ts +8 -0
  401. package/dist/solid/src/components/data/sheet/DataSheetConfigDialog.d.ts.map +1 -0
  402. package/dist/solid/src/components/data/sheet/sheetUtils.d.ts +7 -0
  403. package/dist/solid/src/components/data/sheet/sheetUtils.d.ts.map +1 -0
  404. package/dist/solid/src/components/data/sheet/types.d.ts +113 -0
  405. package/dist/solid/src/components/data/sheet/types.d.ts.map +1 -0
  406. package/dist/solid/src/components/disclosure/Collapse.d.ts +21 -0
  407. package/dist/solid/src/components/disclosure/Collapse.d.ts.map +1 -0
  408. package/dist/solid/src/components/disclosure/Dialog.d.ts +65 -0
  409. package/dist/solid/src/components/disclosure/Dialog.d.ts.map +1 -0
  410. package/dist/solid/src/components/disclosure/DialogContext.d.ts +30 -0
  411. package/dist/solid/src/components/disclosure/DialogContext.d.ts.map +1 -0
  412. package/dist/solid/src/components/disclosure/DialogInstanceContext.d.ts +6 -0
  413. package/dist/solid/src/components/disclosure/DialogInstanceContext.d.ts.map +1 -0
  414. package/dist/solid/src/components/disclosure/DialogProvider.d.ts +19 -0
  415. package/dist/solid/src/components/disclosure/DialogProvider.d.ts.map +1 -0
  416. package/dist/solid/src/components/disclosure/Dropdown.d.ts +65 -0
  417. package/dist/solid/src/components/disclosure/Dropdown.d.ts.map +1 -0
  418. package/dist/solid/src/components/disclosure/Tabs.d.ts +24 -0
  419. package/dist/solid/src/components/disclosure/Tabs.d.ts.map +1 -0
  420. package/dist/solid/src/components/disclosure/dialogZIndex.d.ts +13 -0
  421. package/dist/solid/src/components/disclosure/dialogZIndex.d.ts.map +1 -0
  422. package/dist/solid/src/components/display/Alert.d.ts +8 -0
  423. package/dist/solid/src/components/display/Alert.d.ts.map +1 -0
  424. package/dist/solid/src/components/display/Barcode.d.ts +8 -0
  425. package/dist/solid/src/components/display/Barcode.d.ts.map +1 -0
  426. package/dist/solid/src/components/display/Card.d.ts +6 -0
  427. package/dist/solid/src/components/display/Card.d.ts.map +1 -0
  428. package/dist/solid/src/components/display/Echarts.d.ts +8 -0
  429. package/dist/solid/src/components/display/Echarts.d.ts.map +1 -0
  430. package/dist/solid/src/components/display/Icon.d.ts +8 -0
  431. package/dist/solid/src/components/display/Icon.d.ts.map +1 -0
  432. package/dist/solid/src/components/display/Tag.d.ts +8 -0
  433. package/dist/solid/src/components/display/Tag.d.ts.map +1 -0
  434. package/dist/solid/src/components/feedback/Progress.d.ts +12 -0
  435. package/dist/solid/src/components/feedback/Progress.d.ts.map +1 -0
  436. package/dist/solid/src/components/feedback/loading/LoadingContainer.d.ts +12 -0
  437. package/dist/solid/src/components/feedback/loading/LoadingContainer.d.ts.map +1 -0
  438. package/dist/solid/src/components/feedback/loading/LoadingContext.d.ts +11 -0
  439. package/dist/solid/src/components/feedback/loading/LoadingContext.d.ts.map +1 -0
  440. package/dist/solid/src/components/feedback/loading/LoadingProvider.d.ts +7 -0
  441. package/dist/solid/src/components/feedback/loading/LoadingProvider.d.ts.map +1 -0
  442. package/dist/solid/src/components/feedback/notification/NotificationBanner.d.ts +3 -0
  443. package/dist/solid/src/components/feedback/notification/NotificationBanner.d.ts.map +1 -0
  444. package/dist/solid/src/components/feedback/notification/NotificationBell.d.ts +6 -0
  445. package/dist/solid/src/components/feedback/notification/NotificationBell.d.ts.map +1 -0
  446. package/dist/solid/src/components/feedback/notification/NotificationContext.d.ts +39 -0
  447. package/dist/solid/src/components/feedback/notification/NotificationContext.d.ts.map +1 -0
  448. package/dist/solid/src/components/feedback/notification/NotificationProvider.d.ts +3 -0
  449. package/dist/solid/src/components/feedback/notification/NotificationProvider.d.ts.map +1 -0
  450. package/dist/solid/src/components/feedback/notification/index.d.ts +5 -0
  451. package/dist/solid/src/components/feedback/notification/index.d.ts.map +1 -0
  452. package/dist/solid/src/components/feedback/print/Print.d.ts +9 -0
  453. package/dist/solid/src/components/feedback/print/Print.d.ts.map +1 -0
  454. package/dist/solid/src/components/feedback/print/PrintInstanceContext.d.ts +6 -0
  455. package/dist/solid/src/components/feedback/print/PrintInstanceContext.d.ts.map +1 -0
  456. package/dist/solid/src/components/form-control/Button.d.ts +14 -0
  457. package/dist/solid/src/components/form-control/Button.d.ts.map +1 -0
  458. package/dist/solid/src/components/form-control/DropdownTrigger.styles.d.ts +14 -0
  459. package/dist/solid/src/components/form-control/DropdownTrigger.styles.d.ts.map +1 -0
  460. package/dist/solid/src/components/form-control/ThemeToggle.d.ts +25 -0
  461. package/dist/solid/src/components/form-control/ThemeToggle.d.ts.map +1 -0
  462. package/dist/solid/src/components/form-control/checkbox/Checkbox.d.ts +16 -0
  463. package/dist/solid/src/components/form-control/checkbox/Checkbox.d.ts.map +1 -0
  464. package/dist/solid/src/components/form-control/checkbox/Checkbox.styles.d.ts +12 -0
  465. package/dist/solid/src/components/form-control/checkbox/Checkbox.styles.d.ts.map +1 -0
  466. package/dist/solid/src/components/form-control/checkbox/CheckboxGroup.d.ts +27 -0
  467. package/dist/solid/src/components/form-control/checkbox/CheckboxGroup.d.ts.map +1 -0
  468. package/dist/solid/src/components/form-control/checkbox/Radio.d.ts +16 -0
  469. package/dist/solid/src/components/form-control/checkbox/Radio.d.ts.map +1 -0
  470. package/dist/solid/src/components/form-control/checkbox/RadioGroup.d.ts +27 -0
  471. package/dist/solid/src/components/form-control/checkbox/RadioGroup.d.ts.map +1 -0
  472. package/dist/solid/src/components/form-control/color-picker/ColorPicker.d.ts +29 -0
  473. package/dist/solid/src/components/form-control/color-picker/ColorPicker.d.ts.map +1 -0
  474. package/dist/solid/src/components/form-control/combobox/Combobox.d.ts +80 -0
  475. package/dist/solid/src/components/form-control/combobox/Combobox.d.ts.map +1 -0
  476. package/dist/solid/src/components/form-control/combobox/ComboboxContext.d.ts +11 -0
  477. package/dist/solid/src/components/form-control/combobox/ComboboxContext.d.ts.map +1 -0
  478. package/dist/solid/src/components/form-control/combobox/ComboboxItem.d.ts +12 -0
  479. package/dist/solid/src/components/form-control/combobox/ComboboxItem.d.ts.map +1 -0
  480. package/dist/solid/src/components/form-control/date-range-picker/DateRangePicker.d.ts +55 -0
  481. package/dist/solid/src/components/form-control/date-range-picker/DateRangePicker.d.ts.map +1 -0
  482. package/dist/solid/src/components/form-control/editor/EditorToolbar.d.ts +8 -0
  483. package/dist/solid/src/components/form-control/editor/EditorToolbar.d.ts.map +1 -0
  484. package/dist/solid/src/components/form-control/editor/RichTextEditor.d.ts +21 -0
  485. package/dist/solid/src/components/form-control/editor/RichTextEditor.d.ts.map +1 -0
  486. package/dist/solid/src/components/form-control/field/DatePicker.d.ts +61 -0
  487. package/dist/solid/src/components/form-control/field/DatePicker.d.ts.map +1 -0
  488. package/dist/solid/src/components/form-control/field/DateTimePicker.d.ts +58 -0
  489. package/dist/solid/src/components/form-control/field/DateTimePicker.d.ts.map +1 -0
  490. package/dist/solid/src/components/form-control/field/Field.styles.d.ts +13 -0
  491. package/dist/solid/src/components/form-control/field/Field.styles.d.ts.map +1 -0
  492. package/dist/solid/src/components/form-control/field/NumberInput.d.ts +47 -0
  493. package/dist/solid/src/components/form-control/field/NumberInput.d.ts.map +1 -0
  494. package/dist/solid/src/components/form-control/field/TextInput.d.ts +51 -0
  495. package/dist/solid/src/components/form-control/field/TextInput.d.ts.map +1 -0
  496. package/dist/solid/src/components/form-control/field/Textarea.d.ts +42 -0
  497. package/dist/solid/src/components/form-control/field/Textarea.d.ts.map +1 -0
  498. package/dist/solid/src/components/form-control/field/TimePicker.d.ts +46 -0
  499. package/dist/solid/src/components/form-control/field/TimePicker.d.ts.map +1 -0
  500. package/dist/solid/src/components/form-control/numpad/Numpad.d.ts +28 -0
  501. package/dist/solid/src/components/form-control/numpad/Numpad.d.ts.map +1 -0
  502. package/dist/solid/src/components/form-control/select/Select.d.ts +104 -0
  503. package/dist/solid/src/components/form-control/select/Select.d.ts.map +1 -0
  504. package/dist/solid/src/components/form-control/select/SelectContext.d.ts +14 -0
  505. package/dist/solid/src/components/form-control/select/SelectContext.d.ts.map +1 -0
  506. package/dist/solid/src/components/form-control/select/SelectItem.d.ts +33 -0
  507. package/dist/solid/src/components/form-control/select/SelectItem.d.ts.map +1 -0
  508. package/dist/solid/src/components/form-control/state-preset/StatePreset.d.ts +14 -0
  509. package/dist/solid/src/components/form-control/state-preset/StatePreset.d.ts.map +1 -0
  510. package/dist/solid/src/components/layout/FormGroup.d.ts +14 -0
  511. package/dist/solid/src/components/layout/FormGroup.d.ts.map +1 -0
  512. package/dist/solid/src/components/layout/FormTable.d.ts +5 -0
  513. package/dist/solid/src/components/layout/FormTable.d.ts.map +1 -0
  514. package/dist/solid/src/components/layout/sidebar/Sidebar.d.ts +35 -0
  515. package/dist/solid/src/components/layout/sidebar/Sidebar.d.ts.map +1 -0
  516. package/dist/solid/src/components/layout/sidebar/SidebarContainer.d.ts +34 -0
  517. package/dist/solid/src/components/layout/sidebar/SidebarContainer.d.ts.map +1 -0
  518. package/dist/solid/src/components/layout/sidebar/SidebarContext.d.ts +28 -0
  519. package/dist/solid/src/components/layout/sidebar/SidebarContext.d.ts.map +1 -0
  520. package/dist/solid/src/components/layout/sidebar/SidebarMenu.d.ts +41 -0
  521. package/dist/solid/src/components/layout/sidebar/SidebarMenu.d.ts.map +1 -0
  522. package/dist/solid/src/components/layout/sidebar/SidebarUser.d.ts +36 -0
  523. package/dist/solid/src/components/layout/sidebar/SidebarUser.d.ts.map +1 -0
  524. package/dist/solid/src/components/layout/topbar/Topbar.d.ts +35 -0
  525. package/dist/solid/src/components/layout/topbar/Topbar.d.ts.map +1 -0
  526. package/dist/solid/src/components/layout/topbar/TopbarContainer.d.ts +25 -0
  527. package/dist/solid/src/components/layout/topbar/TopbarContainer.d.ts.map +1 -0
  528. package/dist/solid/src/components/layout/topbar/TopbarMenu.d.ts +41 -0
  529. package/dist/solid/src/components/layout/topbar/TopbarMenu.d.ts.map +1 -0
  530. package/dist/solid/src/components/layout/topbar/TopbarUser.d.ts +35 -0
  531. package/dist/solid/src/components/layout/topbar/TopbarUser.d.ts.map +1 -0
  532. package/dist/solid/src/directives/ripple.d.ts +24 -0
  533. package/dist/solid/src/directives/ripple.d.ts.map +1 -0
  534. package/dist/solid/src/helpers/createAppStructure.d.ts +52 -0
  535. package/dist/solid/src/helpers/createAppStructure.d.ts.map +1 -0
  536. package/dist/solid/src/helpers/mergeStyles.d.ts +27 -0
  537. package/dist/solid/src/helpers/mergeStyles.d.ts.map +1 -0
  538. package/dist/solid/src/helpers/splitSlots.d.ts +25 -0
  539. package/dist/solid/src/helpers/splitSlots.d.ts.map +1 -0
  540. package/dist/solid/src/hooks/createControllableSignal.d.ts +40 -0
  541. package/dist/solid/src/hooks/createControllableSignal.d.ts.map +1 -0
  542. package/dist/solid/src/hooks/createIMEHandler.d.ts +20 -0
  543. package/dist/solid/src/hooks/createIMEHandler.d.ts.map +1 -0
  544. package/dist/solid/src/hooks/createMountTransition.d.ts +14 -0
  545. package/dist/solid/src/hooks/createMountTransition.d.ts.map +1 -0
  546. package/dist/solid/src/hooks/useClipboardValueCopy.d.ts +15 -0
  547. package/dist/solid/src/hooks/useClipboardValueCopy.d.ts.map +1 -0
  548. package/dist/solid/src/hooks/usePersisted.d.ts +26 -0
  549. package/dist/solid/src/hooks/usePersisted.d.ts.map +1 -0
  550. package/dist/solid/src/hooks/usePrint.d.ts +11 -0
  551. package/dist/solid/src/hooks/usePrint.d.ts.map +1 -0
  552. package/dist/solid/src/hooks/useRouterLink.d.ts +38 -0
  553. package/dist/solid/src/hooks/useRouterLink.d.ts.map +1 -0
  554. package/dist/solid/src/index.d.ts +85 -0
  555. package/dist/solid/src/index.d.ts.map +1 -0
  556. package/dist/solid/src/providers/ConfigContext.d.ts +48 -0
  557. package/dist/solid/src/providers/ConfigContext.d.ts.map +1 -0
  558. package/dist/solid/src/providers/InitializeProvider.d.ts +23 -0
  559. package/dist/solid/src/providers/InitializeProvider.d.ts.map +1 -0
  560. package/dist/solid/src/providers/ServiceClientContext.d.ts +10 -0
  561. package/dist/solid/src/providers/ServiceClientContext.d.ts.map +1 -0
  562. package/dist/solid/src/providers/ServiceClientProvider.d.ts +3 -0
  563. package/dist/solid/src/providers/ServiceClientProvider.d.ts.map +1 -0
  564. package/dist/solid/src/providers/ThemeContext.d.ts +65 -0
  565. package/dist/solid/src/providers/ThemeContext.d.ts.map +1 -0
  566. package/dist/solid/src/providers/shared-data/SharedDataChangeEvent.d.ts +8 -0
  567. package/dist/solid/src/providers/shared-data/SharedDataChangeEvent.d.ts.map +1 -0
  568. package/dist/solid/src/providers/shared-data/SharedDataContext.d.ts +22 -0
  569. package/dist/solid/src/providers/shared-data/SharedDataContext.d.ts.map +1 -0
  570. package/dist/solid/src/providers/shared-data/SharedDataProvider.d.ts +9 -0
  571. package/dist/solid/src/providers/shared-data/SharedDataProvider.d.ts.map +1 -0
  572. package/dist/solid/src/styles/patterns.styles.d.ts +6 -0
  573. package/dist/solid/src/styles/patterns.styles.d.ts.map +1 -0
  574. package/dist/solid/src/styles/tokens.styles.d.ts +20 -0
  575. package/dist/solid/src/styles/tokens.styles.d.ts.map +1 -0
  576. package/dist/styles/patterns.styles.js +30 -0
  577. package/dist/styles/patterns.styles.js.map +7 -0
  578. package/dist/styles/tokens.styles.js +72 -0
  579. package/dist/styles/tokens.styles.js.map +7 -0
  580. package/package.json +60 -0
  581. package/tailwind.config.ts +50 -0
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/form-control/field/NumberInput.tsx"],
4
+ "sourcesContent": ["import { type Component, type JSX, Show, splitProps, createSignal, createEffect } from \"solid-js\";\nimport clsx from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\nimport { createControllableSignal } from \"../../../hooks/createControllableSignal\";\nimport {\n type FieldSize,\n fieldBaseClass,\n fieldSizeClasses,\n fieldErrorClass,\n fieldInsetClass,\n fieldInsetHeightClass,\n fieldInsetSizeHeightClasses,\n fieldDisabledClass,\n fieldInputClass,\n} from \"./Field.styles\";\nimport { textMuted } from \"../../../styles/tokens.styles\";\n\n// NumberInput \uC804\uC6A9 input \uC2A4\uD0C0\uC77C (\uC6B0\uCE21 \uC815\uB82C + \uC2A4\uD53C\uB108 \uC228\uAE40)\nconst numberInputClass = clsx(\n fieldInputClass,\n \"text-right\",\n \"[&::-webkit-outer-spin-button]:appearance-none\",\n \"[&::-webkit-inner-spin-button]:appearance-none\",\n);\n\nexport interface NumberInputProps {\n /** \uC785\uB825 \uAC12 */\n value?: number;\n\n /** \uAC12 \uBCC0\uACBD \uCF5C\uBC31 */\n onValueChange?: (value: number | undefined) => void;\n\n /** \uCC9C\uB2E8\uC704 \uCF64\uB9C8 \uD45C\uC2DC (\uAE30\uBCF8\uAC12: true) */\n comma?: boolean;\n\n /** \uCD5C\uC18C \uC18C\uC218\uC810 \uC790\uB9BF\uC218 */\n minDigits?: number;\n\n /** \uD50C\uB808\uC774\uC2A4\uD640\uB354 */\n placeholder?: string;\n\n /** \uD0C0\uC774\uD2C0 (\uD234\uD301) */\n title?: string;\n\n /** \uBE44\uD65C\uC131\uD654 */\n disabled?: boolean;\n\n /** \uC77D\uAE30 \uC804\uC6A9 */\n readonly?: boolean;\n\n /** \uC5D0\uB7EC \uC0C1\uD0DC */\n error?: boolean;\n\n /** \uC0AC\uC774\uC988 */\n size?: FieldSize;\n\n /** \uD14C\uB450\uB9AC \uC5C6\uB294 \uC2A4\uD0C0\uC77C */\n inset?: boolean;\n\n /** \uCEE4\uC2A4\uD140 class */\n class?: string;\n\n /** \uCEE4\uC2A4\uD140 style */\n style?: JSX.CSSProperties;\n}\n\n/**\n * \uC22B\uC790\uB97C \uD45C\uC2DC\uC6A9 \uBB38\uC790\uC5F4\uB85C \uBCC0\uD658\uD55C\uB2E4\n * @param value \uC22B\uC790 \uAC12\n * @param useComma \uCC9C\uB2E8\uC704 \uCF64\uB9C8 \uC0AC\uC6A9 \uC5EC\uBD80\n * @param minDigits \uCD5C\uC18C \uC18C\uC218\uC810 \uC790\uB9BF\uC218\n * @returns \uD45C\uC2DC\uC6A9 \uBB38\uC790\uC5F4\n */\nfunction formatNumber(value: number | undefined, useComma: boolean, minDigits?: number): string {\n if (value == null) return \"\";\n\n let result: string;\n\n if (minDigits != null && minDigits > 0) {\n // \uD604\uC7AC \uC18C\uC218\uC810 \uC790\uB9BF\uC218 \uD655\uC778\n const valueStr = String(value);\n const decimalIndex = valueStr.indexOf(\".\");\n const currentDigits = decimalIndex >= 0 ? valueStr.length - decimalIndex - 1 : 0;\n\n // \uCD5C\uC18C \uC790\uB9BF\uC218\uBCF4\uB2E4 \uC791\uC73C\uBA74 \uD328\uB529\n if (currentDigits < minDigits) {\n result = value.toFixed(minDigits);\n } else {\n result = valueStr;\n }\n } else {\n result = String(value);\n }\n\n if (useComma) {\n // \uC815\uC218\uBD80\uC640 \uC18C\uC218\uBD80 \uBD84\uB9AC\n const dotIndex = result.indexOf(\".\");\n const integerPart = dotIndex >= 0 ? result.slice(0, dotIndex) : result;\n const decimalPart = dotIndex >= 0 ? result.slice(dotIndex + 1) : null;\n // \uC815\uC218\uBD80\uC5D0\uB9CC \uCF64\uB9C8 \uCD94\uAC00\n const formattedInteger = integerPart.replace(/\\B(?=(\\d{3})+(?!\\d))/g, \",\");\n result = decimalPart !== null ? `${formattedInteger}.${decimalPart}` : formattedInteger;\n }\n\n return result;\n}\n\n/**\n * \uD45C\uC2DC\uC6A9 \uBB38\uC790\uC5F4\uC744 \uC22B\uC790\uB85C \uBCC0\uD658\uD55C\uB2E4\n * @param str \uD45C\uC2DC\uC6A9 \uBB38\uC790\uC5F4\n * @returns \uC22B\uC790 \uAC12 \uB610\uB294 undefined\n */\nfunction parseNumber(str: string): number | undefined {\n if (str === \"\" || str === \"-\") return undefined;\n\n // \uCF64\uB9C8 \uC81C\uAC70\n const cleanStr = str.replace(/,/g, \"\");\n\n // \uC22B\uC790\uB85C \uBCC0\uD658 \uC2DC\uB3C4\n const num = Number(cleanStr);\n\n if (Number.isNaN(num)) return undefined;\n\n return num;\n}\n\n/**\n * \uC785\uB825 \uBB38\uC790\uC5F4\uC774 \uC720\uD6A8\uD55C \uC22B\uC790 \uD615\uC2DD\uC778\uC9C0 \uD655\uC778\uD55C\uB2E4\n * @param str \uC785\uB825 \uBB38\uC790\uC5F4\n * @returns \uC720\uD6A8 \uC5EC\uBD80\n */\nfunction isValidNumberInput(str: string): boolean {\n if (str === \"\" || str === \"-\" || str === \".\") return true;\n\n // \uCF64\uB9C8 \uC81C\uAC70\n const cleanStr = str.replace(/,/g, \"\");\n\n // \uC22B\uC790 \uD615\uC2DD \uD328\uD134 (\uC785\uB825 \uC911 \uC0C1\uD0DC \uD3EC\uD568)\n // \uC608: \"123\", \"123.\", \"123.45\", \"-123\", \"-\", \"-.123\"\n return /^-?\\d*\\.?\\d*$/.test(cleanStr);\n}\n\n/**\n * NumberInput \uCEF4\uD3EC\uB10C\uD2B8\n *\n * @example\n * ```tsx\n * // \uAE30\uBCF8 \uC0AC\uC6A9\n * <NumberInput value={num()} onValueChange={setNum} />\n *\n * // \uCC9C\uB2E8\uC704 \uCF64\uB9C8 \uC5C6\uC774\n * <NumberInput value={num()} comma={false} />\n *\n * // \uCD5C\uC18C \uC18C\uC218\uC810 \uC790\uB9BF\uC218 \uC9C0\uC815\n * <NumberInput value={price()} minDigits={2} />\n * ```\n */\nexport const NumberInput: Component<NumberInputProps> = (props) => {\n const [local, rest] = splitProps(props, [\n \"value\",\n \"onValueChange\",\n \"comma\",\n \"minDigits\",\n \"placeholder\",\n \"title\",\n \"disabled\",\n \"readonly\",\n \"error\",\n \"size\",\n \"inset\",\n \"class\",\n \"style\",\n ]);\n\n // \uC785\uB825 \uC911\uC778 \uC0C1\uD0DC\uB97C \uCD94\uC801\uD558\uAE30 \uC704\uD55C \uB0B4\uBD80 \uBB38\uC790\uC5F4 \uC0C1\uD0DC\n const [inputStr, setInputStr] = createSignal<string>(\"\");\n const [isEditing, setIsEditing] = createSignal(false);\n\n // controlled/uncontrolled \uD328\uD134 \uC9C0\uC6D0\n const [value, setValue] = createControllableSignal({\n value: () => local.value,\n onChange: () => local.onValueChange,\n });\n\n // \uC678\uBD80 \uAC12 \uBCC0\uACBD \uC2DC \uC785\uB825 \uBB38\uC790\uC5F4 \uB3D9\uAE30\uD654\n createEffect(() => {\n const val = value();\n if (!isEditing()) {\n setInputStr(formatNumber(val, local.comma ?? true, local.minDigits));\n }\n });\n\n // \uD45C\uC2DC \uAC12 \uACC4\uC0B0\n const displayValue = () => {\n if (isEditing()) {\n return inputStr();\n }\n return formatNumber(value(), local.comma ?? true, local.minDigits);\n };\n\n // \uC785\uB825 \uD578\uB4E4\uB7EC\n const handleInput: JSX.InputEventHandler<HTMLInputElement, InputEvent> = (e) => {\n const newValue = e.currentTarget.value;\n\n // \uC720\uD6A8\uD55C \uC22B\uC790 \uD615\uC2DD\uC778\uC9C0 \uD655\uC778\n if (!isValidNumberInput(newValue)) {\n // \uC720\uD6A8\uD558\uC9C0 \uC54A\uC740 \uC785\uB825\uC740 \uBB34\uC2DC\uD558\uACE0 \uC774\uC804 \uAC12 \uBCF5\uC6D0\n e.currentTarget.value = inputStr();\n return;\n }\n\n setInputStr(newValue);\n setIsEditing(true);\n\n // \uC22B\uC790\uB85C \uBCC0\uD658\n const num = parseNumber(newValue);\n setValue(num);\n };\n\n // focus \uD578\uB4E4\uB7EC\n const handleFocus: JSX.FocusEventHandler<HTMLInputElement, FocusEvent> = () => {\n setIsEditing(true);\n // focus \uC2DC \uCF64\uB9C8 \uC81C\uAC70\uB41C \uAC12\uC73C\uB85C \uC124\uC815\n const val = value();\n if (val != null) {\n setInputStr(String(val));\n } else {\n setInputStr(\"\");\n }\n };\n\n // blur \uD578\uB4E4\uB7EC\n const handleBlur: JSX.FocusEventHandler<HTMLInputElement, FocusEvent> = () => {\n setIsEditing(false);\n // blur \uC2DC \uD3EC\uB9F7\uD305 \uC801\uC6A9\n setInputStr(formatNumber(value(), local.comma ?? true, local.minDigits));\n };\n\n // wrapper \uD074\uB798\uC2A4 (inset \uBD84\uAE30\uC5D0\uC11C\uB294 local.class \uC81C\uC678)\n const getWrapperClass = (includeCustomClass: boolean) =>\n twMerge(\n fieldBaseClass,\n local.size && fieldSizeClasses[local.size],\n local.error && fieldErrorClass,\n local.disabled && fieldDisabledClass,\n local.inset && fieldInsetClass,\n local.inset && (local.size ? fieldInsetSizeHeightClasses[local.size] : fieldInsetHeightClass),\n\n includeCustomClass && local.class,\n );\n\n const isEditable = () => !local.disabled && !local.readonly;\n\n return (\n <Show\n when={local.inset}\n fallback={\n // standalone \uBAA8\uB4DC: \uAE30\uC874 Show \uD328\uD134 \uC720\uC9C0\n <Show\n when={isEditable()}\n fallback={\n <div\n {...rest}\n data-number-field\n class={twMerge(getWrapperClass(true), \"sd-number-field\", \"justify-end\")}\n style={local.style}\n title={local.title}\n >\n {formatNumber(value(), local.comma ?? true, local.minDigits) ||\n (local.placeholder != null && local.placeholder !== \"\" ? (\n <span class={textMuted}>{local.placeholder}</span>\n ) : (\n \"\\u00A0\"\n ))}\n </div>\n }\n >\n <div {...rest} data-number-field class={getWrapperClass(true)} style={local.style}>\n <input\n type=\"text\"\n inputmode=\"numeric\"\n class={numberInputClass}\n value={displayValue()}\n placeholder={local.placeholder}\n title={local.title}\n onInput={handleInput}\n onFocus={handleFocus}\n onBlur={handleBlur}\n />\n </div>\n </Show>\n }\n >\n {/* inset \uBAA8\uB4DC: dual-element overlay \uD328\uD134 */}\n <div {...rest} data-number-field class={clsx(\"relative\", local.class)} style={local.style}>\n <div\n data-number-field-content\n class={twMerge(getWrapperClass(false), \"justify-end\")}\n style={{ visibility: isEditable() ? \"hidden\" : undefined }}\n title={local.title}\n >\n {formatNumber(value(), local.comma ?? true, local.minDigits) ||\n (local.placeholder != null && local.placeholder !== \"\" ? (\n <span class={textMuted}>{local.placeholder}</span>\n ) : (\n \"\\u00A0\"\n ))}\n </div>\n\n <Show when={isEditable()}>\n <div class={twMerge(getWrapperClass(false), \"absolute left-0 top-0 size-full\")}>\n <input\n type=\"text\"\n inputmode=\"numeric\"\n class={numberInputClass}\n value={displayValue()}\n placeholder={local.placeholder}\n title={local.title}\n onInput={handleInput}\n onFocus={handleFocus}\n onBlur={handleBlur}\n />\n </div>\n </Show>\n </div>\n </Show>\n );\n};\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,178 @@
1
+ import clsx from "clsx";
2
+ import { createEffect, Show, splitProps } from "solid-js";
3
+ import { twMerge } from "tailwind-merge";
4
+ import { createControllableSignal } from "../../../hooks/createControllableSignal";
5
+ import { createIMEHandler } from "../../../hooks/createIMEHandler";
6
+ import {
7
+ fieldBaseClass,
8
+ fieldSizeClasses,
9
+ fieldErrorClass,
10
+ fieldInsetClass,
11
+ fieldInsetHeightClass,
12
+ fieldInsetSizeHeightClasses,
13
+ fieldDisabledClass,
14
+ fieldInputClass
15
+ } from "./Field.styles";
16
+ import { textMuted } from "../../../styles/tokens.styles";
17
+ function applyFormat(value, format) {
18
+ if (!value || !format) return value;
19
+ let result = "";
20
+ let valueIndex = 0;
21
+ for (let i = 0; i < format.length && valueIndex < value.length; i++) {
22
+ if (format[i] === "X") {
23
+ result += value[valueIndex];
24
+ valueIndex++;
25
+ } else {
26
+ result += format[i];
27
+ }
28
+ }
29
+ return result;
30
+ }
31
+ function removeFormat(formattedValue, format) {
32
+ if (!formattedValue || !format) return formattedValue;
33
+ let result = "";
34
+ for (let i = 0; i < formattedValue.length; i++) {
35
+ const formatChar = format[i];
36
+ if (formatChar === "X") {
37
+ result += formattedValue[i];
38
+ }
39
+ }
40
+ return result;
41
+ }
42
+ const TextInput = (props) => {
43
+ const [local, rest] = splitProps(props, [
44
+ "value",
45
+ "onValueChange",
46
+ "type",
47
+ "placeholder",
48
+ "title",
49
+ "autocomplete",
50
+ "disabled",
51
+ "readonly",
52
+ "error",
53
+ "size",
54
+ "inset",
55
+ "format",
56
+ "class",
57
+ "style"
58
+ ]);
59
+ const [value, setValue] = createControllableSignal({
60
+ value: () => local.value ?? "",
61
+ onChange: () => local.onValueChange
62
+ });
63
+ const ime = createIMEHandler((v) => setValue(v));
64
+ function extractValue(el) {
65
+ let val = el.value;
66
+ if (local.format != null && local.format !== "") {
67
+ val = removeFormat(val, local.format);
68
+ }
69
+ return val;
70
+ }
71
+ const inputValue = () => {
72
+ const val = value();
73
+ if (local.format != null && local.format !== "") {
74
+ return applyFormat(val, local.format);
75
+ }
76
+ return val;
77
+ };
78
+ const displayValue = () => {
79
+ const composing = ime.composingValue();
80
+ if (composing != null) {
81
+ if (local.format != null && local.format !== "") {
82
+ return applyFormat(composing, local.format);
83
+ }
84
+ return composing;
85
+ }
86
+ return inputValue();
87
+ };
88
+ const handleCompositionStart = () => ime.handleCompositionStart();
89
+ const handleInput = (e) => {
90
+ ime.handleInput(extractValue(e.currentTarget), e.isComposing);
91
+ };
92
+ const handleCompositionEnd = (e) => {
93
+ ime.handleCompositionEnd(extractValue(e.currentTarget));
94
+ };
95
+ const getWrapperClass = (includeCustomClass) => twMerge(
96
+ fieldBaseClass,
97
+ local.size && fieldSizeClasses[local.size],
98
+ local.error && fieldErrorClass,
99
+ local.disabled && fieldDisabledClass,
100
+ local.inset && fieldInsetClass,
101
+ local.inset && (local.size ? fieldInsetSizeHeightClasses[local.size] : fieldInsetHeightClass),
102
+ includeCustomClass && local.class
103
+ );
104
+ const isEditable = () => !local.disabled && !local.readonly;
105
+ createEffect(() => {
106
+ if (!isEditable()) {
107
+ ime.flushComposition();
108
+ }
109
+ });
110
+ return /* @__PURE__ */ React.createElement(
111
+ Show,
112
+ {
113
+ when: local.inset,
114
+ fallback: (
115
+ // standalone 모드: 기존 Show 패턴 유지
116
+ /* @__PURE__ */ React.createElement(
117
+ Show,
118
+ {
119
+ when: isEditable(),
120
+ fallback: /* @__PURE__ */ React.createElement(
121
+ "div",
122
+ {
123
+ ...rest,
124
+ "data-text-field": true,
125
+ class: twMerge(getWrapperClass(true), "sd-text-field"),
126
+ style: local.style,
127
+ title: local.title
128
+ },
129
+ displayValue() || (local.placeholder != null && local.placeholder !== "" ? /* @__PURE__ */ React.createElement("span", { class: textMuted }, local.placeholder) : "\xA0")
130
+ )
131
+ },
132
+ /* @__PURE__ */ React.createElement("div", { ...rest, "data-text-field": true, class: getWrapperClass(true), style: local.style }, /* @__PURE__ */ React.createElement(
133
+ "input",
134
+ {
135
+ type: local.type ?? "text",
136
+ class: fieldInputClass,
137
+ value: inputValue(),
138
+ placeholder: local.placeholder,
139
+ title: local.title,
140
+ autocomplete: local.autocomplete,
141
+ onInput: handleInput,
142
+ onCompositionStart: handleCompositionStart,
143
+ onCompositionEnd: handleCompositionEnd
144
+ }
145
+ ))
146
+ )
147
+ )
148
+ },
149
+ /* @__PURE__ */ React.createElement(
150
+ "div",
151
+ {
152
+ ...rest,
153
+ "data-text-field": true,
154
+ class: twMerge(getWrapperClass(false), "relative", local.class),
155
+ style: local.style
156
+ },
157
+ /* @__PURE__ */ React.createElement("div", { "data-text-field-content": true, style: { visibility: isEditable() ? "hidden" : void 0 } }, displayValue() || (local.placeholder != null && local.placeholder !== "" ? /* @__PURE__ */ React.createElement("span", { class: textMuted }, local.placeholder) : "\xA0")),
158
+ /* @__PURE__ */ React.createElement(Show, { when: isEditable() }, /* @__PURE__ */ React.createElement(
159
+ "input",
160
+ {
161
+ type: local.type ?? "text",
162
+ class: clsx(fieldInputClass, "absolute left-0 top-0 size-full", "px-2 py-1"),
163
+ value: inputValue(),
164
+ placeholder: local.placeholder,
165
+ title: local.title,
166
+ autocomplete: local.autocomplete,
167
+ onInput: handleInput,
168
+ onCompositionStart: handleCompositionStart,
169
+ onCompositionEnd: handleCompositionEnd
170
+ }
171
+ ))
172
+ )
173
+ );
174
+ };
175
+ export {
176
+ TextInput
177
+ };
178
+ //# sourceMappingURL=TextInput.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/form-control/field/TextInput.tsx"],
4
+ "sourcesContent": ["import clsx from \"clsx\";\nimport { type Component, createEffect, type JSX, Show, splitProps } from \"solid-js\";\nimport { twMerge } from \"tailwind-merge\";\nimport { createControllableSignal } from \"../../../hooks/createControllableSignal\";\nimport { createIMEHandler } from \"../../../hooks/createIMEHandler\";\nimport {\n type FieldSize,\n fieldBaseClass,\n fieldSizeClasses,\n fieldErrorClass,\n fieldInsetClass,\n fieldInsetHeightClass,\n fieldInsetSizeHeightClasses,\n fieldDisabledClass,\n fieldInputClass,\n} from \"./Field.styles\";\nimport { textMuted } from \"../../../styles/tokens.styles\";\n\ntype TextInputType = \"text\" | \"password\" | \"email\";\n\nexport interface TextInputProps {\n /** \uC785\uB825 \uAC12 */\n value?: string;\n\n /** \uAC12 \uBCC0\uACBD \uCF5C\uBC31 */\n onValueChange?: (value: string) => void;\n\n /** \uC785\uB825 \uD0C0\uC785 */\n type?: TextInputType;\n\n /** \uD50C\uB808\uC774\uC2A4\uD640\uB354 */\n placeholder?: string;\n\n /** \uD0C0\uC774\uD2C0 (\uD234\uD301) */\n title?: string;\n\n /** \uC790\uB3D9\uC644\uC131 */\n autocomplete?: string;\n\n /** \uBE44\uD65C\uC131\uD654 */\n disabled?: boolean;\n\n /** \uC77D\uAE30 \uC804\uC6A9 */\n readonly?: boolean;\n\n /** \uC5D0\uB7EC \uC0C1\uD0DC */\n error?: boolean;\n\n /** \uC0AC\uC774\uC988 */\n size?: FieldSize;\n\n /** \uD14C\uB450\uB9AC \uC5C6\uB294 \uC2A4\uD0C0\uC77C */\n inset?: boolean;\n\n /** \uC785\uB825 \uD3EC\uB9F7 (\uC608: XXX-XXXX-XXXX) */\n format?: string;\n\n /** \uCEE4\uC2A4\uD140 class */\n class?: string;\n\n /** \uCEE4\uC2A4\uD140 style */\n style?: JSX.CSSProperties;\n}\n\n/**\n * \uAC12\uC5D0 \uD3EC\uB9F7\uC744 \uC801\uC6A9\uD55C\uB2E4\n * @param value \uC6D0\uBCF8 \uAC12\n * @param format \uD3EC\uB9F7 \uBB38\uC790\uC5F4 (\uC608: XXX-XXXX-XXXX)\n * @returns \uD3EC\uB9F7\uC774 \uC801\uC6A9\uB41C \uAC12\n */\nfunction applyFormat(value: string, format: string): string {\n if (!value || !format) return value;\n\n let result = \"\";\n let valueIndex = 0;\n\n for (let i = 0; i < format.length && valueIndex < value.length; i++) {\n if (format[i] === \"X\") {\n result += value[valueIndex];\n valueIndex++;\n } else {\n result += format[i];\n }\n }\n\n return result;\n}\n\n/**\n * \uD3EC\uB9F7 \uBB38\uC790\uB97C \uC81C\uAC70\uD558\uC5EC \uC6D0\uBCF8 \uAC12\uC744 \uCD94\uCD9C\uD55C\uB2E4\n * @param formattedValue \uD3EC\uB9F7\uC774 \uC801\uC6A9\uB41C \uAC12\n * @param format \uD3EC\uB9F7 \uBB38\uC790\uC5F4\n * @returns \uC6D0\uBCF8 \uAC12\n */\nfunction removeFormat(formattedValue: string, format: string): string {\n if (!formattedValue || !format) return formattedValue;\n\n let result = \"\";\n\n for (let i = 0; i < formattedValue.length; i++) {\n const formatChar = format[i];\n if (formatChar === \"X\") {\n result += formattedValue[i];\n }\n // \uD3EC\uB9F7 \uBB38\uC790\uAC00 \uC544\uB2CC \uACBD\uC6B0 (\uAD6C\uBD84\uC790) \uC2A4\uD0B5\n }\n\n return result;\n}\n\n/**\n * TextInput \uCEF4\uD3EC\uB10C\uD2B8\n *\n * @example\n * ```tsx\n * // \uAE30\uBCF8 \uC0AC\uC6A9\n * <TextInput value={text()} onValueChange={setText} />\n *\n * // \uD3EC\uB9F7 \uC801\uC6A9\n * <TextInput format=\"XXX-XXXX-XXXX\" value={phone()} onValueChange={setPhone} />\n *\n * // password \uD0C0\uC785\n * <TextInput type=\"password\" placeholder=\"\uBE44\uBC00\uBC88\uD638 \uC785\uB825\" />\n * ```\n */\nexport const TextInput: Component<TextInputProps> = (props) => {\n const [local, rest] = splitProps(props, [\n \"value\",\n \"onValueChange\",\n \"type\",\n \"placeholder\",\n \"title\",\n \"autocomplete\",\n \"disabled\",\n \"readonly\",\n \"error\",\n \"size\",\n \"inset\",\n \"format\",\n \"class\",\n \"style\",\n ]);\n\n // controlled/uncontrolled \uD328\uD134 \uC9C0\uC6D0\n const [value, setValue] = createControllableSignal({\n value: () => local.value ?? \"\",\n onChange: () => local.onValueChange,\n });\n\n // IME \uC870\uD569 \uC911 onValueChange\uB97C \uC9C0\uC5F0\uD558\uC5EC DOM \uC7AC\uC0DD\uC131(\uD55C\uAE00 \uC870\uD569 \uB04A\uAE40) \uBC29\uC9C0\n const ime = createIMEHandler((v) => setValue(v));\n\n function extractValue(el: HTMLInputElement): string {\n let val = el.value;\n if (local.format != null && local.format !== \"\") {\n val = removeFormat(val, local.format);\n }\n return val;\n }\n\n // input \uC694\uC18C\uC6A9 \uAC12 (composingValue \uBBF8\uD3EC\uD568 \u2014 IME \uC870\uD569 \uBC29\uD574 \uBC29\uC9C0)\n const inputValue = () => {\n const val = value();\n if (local.format != null && local.format !== \"\") {\n return applyFormat(val, local.format);\n }\n return val;\n };\n\n // content div\uC6A9 \uD45C\uC2DC \uAC12 (composingValue \uD3EC\uD568 \u2014 \uC140 \uB108\uBE44 \uACB0\uC815)\n const displayValue = () => {\n const composing = ime.composingValue();\n if (composing != null) {\n if (local.format != null && local.format !== \"\") {\n return applyFormat(composing, local.format);\n }\n return composing;\n }\n return inputValue();\n };\n\n const handleCompositionStart = () => ime.handleCompositionStart();\n\n const handleInput: JSX.InputEventHandler<HTMLInputElement, InputEvent> = (e) => {\n ime.handleInput(extractValue(e.currentTarget), e.isComposing);\n };\n\n const handleCompositionEnd: JSX.EventHandler<HTMLInputElement, CompositionEvent> = (e) => {\n ime.handleCompositionEnd(extractValue(e.currentTarget));\n };\n\n // wrapper \uD074\uB798\uC2A4 (includeCustomClass=false\uC77C \uB54C local.class \uC81C\uC678 \u2014 inset\uC5D0\uC11C outer\uC5D0\uB9CC \uC801\uC6A9)\n const getWrapperClass = (includeCustomClass: boolean) =>\n twMerge(\n fieldBaseClass,\n local.size && fieldSizeClasses[local.size],\n local.error && fieldErrorClass,\n local.disabled && fieldDisabledClass,\n local.inset && fieldInsetClass,\n local.inset && (local.size ? fieldInsetSizeHeightClasses[local.size] : fieldInsetHeightClass),\n\n includeCustomClass && local.class,\n );\n\n // \uD3B8\uC9D1 \uAC00\uB2A5 \uC5EC\uBD80\n const isEditable = () => !local.disabled && !local.readonly;\n\n // disabled \uC804\uD658 \uC2DC \uBBF8\uCEE4\uBC0B \uC870\uD569 \uAC12 flush\n createEffect(() => {\n if (!isEditable()) {\n ime.flushComposition();\n }\n });\n\n return (\n <Show\n when={local.inset}\n fallback={\n // standalone \uBAA8\uB4DC: \uAE30\uC874 Show \uD328\uD134 \uC720\uC9C0\n <Show\n when={isEditable()}\n fallback={\n <div\n {...rest}\n data-text-field\n class={twMerge(getWrapperClass(true), \"sd-text-field\")}\n style={local.style}\n title={local.title}\n >\n {displayValue() ||\n (local.placeholder != null && local.placeholder !== \"\" ? (\n <span class={textMuted}>{local.placeholder}</span>\n ) : (\n \"\\u00A0\"\n ))}\n </div>\n }\n >\n <div {...rest} data-text-field class={getWrapperClass(true)} style={local.style}>\n <input\n type={local.type ?? \"text\"}\n class={fieldInputClass}\n value={inputValue()}\n placeholder={local.placeholder}\n title={local.title}\n autocomplete={local.autocomplete}\n onInput={handleInput}\n onCompositionStart={handleCompositionStart}\n onCompositionEnd={handleCompositionEnd}\n />\n </div>\n </Show>\n }\n >\n {/* inset \uBAA8\uB4DC: dual-element overlay \uD328\uD134 */}\n <div\n {...rest}\n data-text-field\n class={twMerge(getWrapperClass(false), \"relative\", local.class)}\n style={local.style}\n >\n <div data-text-field-content style={{ visibility: isEditable() ? \"hidden\" : undefined }}>\n {displayValue() ||\n (local.placeholder != null && local.placeholder !== \"\" ? (\n <span class={textMuted}>{local.placeholder}</span>\n ) : (\n \"\\u00A0\"\n ))}\n </div>\n\n <Show when={isEditable()}>\n <input\n type={local.type ?? \"text\"}\n class={clsx(fieldInputClass, \"absolute left-0 top-0 size-full\", \"px-2 py-1\")}\n value={inputValue()}\n placeholder={local.placeholder}\n title={local.title}\n autocomplete={local.autocomplete}\n onInput={handleInput}\n onCompositionStart={handleCompositionStart}\n onCompositionEnd={handleCompositionEnd}\n />\n </Show>\n </div>\n </Show>\n );\n};\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,186 @@
1
+ import clsx from "clsx";
2
+ import { createEffect, Show, splitProps } from "solid-js";
3
+ import { twMerge } from "tailwind-merge";
4
+ import { createControllableSignal } from "../../../hooks/createControllableSignal";
5
+ import { createIMEHandler } from "../../../hooks/createIMEHandler";
6
+ import {
7
+ textAreaBaseClass as fieldTextAreaBaseClass,
8
+ textAreaSizeClasses,
9
+ fieldErrorClass,
10
+ fieldInsetClass,
11
+ fieldDisabledClass
12
+ } from "./Field.styles";
13
+ import { textMuted } from "../../../styles/tokens.styles";
14
+ const textareaBaseClass = clsx(
15
+ "absolute left-0 top-0",
16
+ "size-full",
17
+ "resize-none overflow-hidden",
18
+ "bg-transparent",
19
+ "px-2 py-1",
20
+ "placeholder:text-base-400 dark:placeholder:text-base-500"
21
+ );
22
+ const Textarea = (props) => {
23
+ const [local, rest] = splitProps(props, [
24
+ "value",
25
+ "onValueChange",
26
+ "placeholder",
27
+ "title",
28
+ "disabled",
29
+ "readonly",
30
+ "error",
31
+ "size",
32
+ "inset",
33
+ "minRows",
34
+ "class",
35
+ "style"
36
+ ]);
37
+ const [value, setValue] = createControllableSignal({
38
+ value: () => local.value ?? "",
39
+ onChange: () => local.onValueChange
40
+ });
41
+ const ime = createIMEHandler((v) => setValue(v));
42
+ const displayValue = () => ime.composingValue() ?? value();
43
+ const handleCompositionStart = () => ime.handleCompositionStart();
44
+ const handleInput = (e) => {
45
+ ime.handleInput(e.currentTarget.value, e.isComposing);
46
+ };
47
+ const handleCompositionEnd = (e) => {
48
+ ime.handleCompositionEnd(e.currentTarget.value);
49
+ };
50
+ const handleKeyDown = (e) => {
51
+ if (e.key === "Enter" && e.altKey) {
52
+ e.preventDefault();
53
+ e.stopPropagation();
54
+ const el = e.currentTarget;
55
+ const start = el.selectionStart;
56
+ const end = el.selectionEnd;
57
+ const before = el.value.substring(0, start);
58
+ const after = el.value.substring(end);
59
+ const newVal = before + "\n" + after;
60
+ el.value = newVal;
61
+ el.selectionStart = start + 1;
62
+ el.selectionEnd = start + 1;
63
+ el.dispatchEvent(new InputEvent("input", { bubbles: true }));
64
+ }
65
+ };
66
+ const contentForHeight = () => {
67
+ const rows = local.minRows ?? 1;
68
+ const val = displayValue();
69
+ const content = val !== "" && val.split("\n").length >= rows ? val : "\n".repeat(rows - 1) + "\xA0";
70
+ return content.endsWith("\n") ? content + "\xA0" : content;
71
+ };
72
+ const getWrapperClass = (includeCustomClass) => twMerge(
73
+ fieldTextAreaBaseClass,
74
+ local.size && textAreaSizeClasses[local.size],
75
+ local.error && fieldErrorClass,
76
+ local.disabled && fieldDisabledClass,
77
+ local.inset && fieldInsetClass,
78
+ includeCustomClass && local.class
79
+ );
80
+ const getTextareaClass = () => twMerge(textareaBaseClass, local.size && textAreaSizeClasses[local.size], local.inset && "p-0");
81
+ const isEditable = () => !local.disabled && !local.readonly;
82
+ createEffect(() => {
83
+ if (!isEditable()) {
84
+ ime.flushComposition();
85
+ }
86
+ });
87
+ return /* @__PURE__ */ React.createElement(
88
+ Show,
89
+ {
90
+ when: local.inset,
91
+ fallback: (
92
+ // standalone 모드: 기존 Show 패턴 유지
93
+ /* @__PURE__ */ React.createElement(
94
+ Show,
95
+ {
96
+ when: isEditable(),
97
+ fallback: /* @__PURE__ */ React.createElement(
98
+ "div",
99
+ {
100
+ ...rest,
101
+ "data-textarea-field": true,
102
+ class: getWrapperClass(true),
103
+ style: { "white-space": "pre-wrap", "word-break": "break-all", ...local.style },
104
+ title: local.title
105
+ },
106
+ value() || (local.placeholder != null && local.placeholder !== "" ? /* @__PURE__ */ React.createElement("span", { class: textMuted }, local.placeholder) : "\xA0")
107
+ )
108
+ },
109
+ /* @__PURE__ */ React.createElement(
110
+ "div",
111
+ {
112
+ ...rest,
113
+ "data-textarea-field": true,
114
+ class: getWrapperClass(true),
115
+ style: { position: "relative", ...local.style }
116
+ },
117
+ /* @__PURE__ */ React.createElement(
118
+ "div",
119
+ {
120
+ "data-hidden-content": true,
121
+ style: {
122
+ "visibility": "hidden",
123
+ "white-space": "pre-wrap",
124
+ "word-break": "break-all"
125
+ }
126
+ },
127
+ contentForHeight()
128
+ ),
129
+ /* @__PURE__ */ React.createElement(
130
+ "textarea",
131
+ {
132
+ class: getTextareaClass(),
133
+ value: value(),
134
+ placeholder: local.placeholder,
135
+ title: local.title,
136
+ onKeyDown: handleKeyDown,
137
+ onInput: handleInput,
138
+ onCompositionStart: handleCompositionStart,
139
+ onCompositionEnd: handleCompositionEnd
140
+ }
141
+ )
142
+ )
143
+ )
144
+ )
145
+ },
146
+ /* @__PURE__ */ React.createElement(
147
+ "div",
148
+ {
149
+ ...rest,
150
+ "data-textarea-field": true,
151
+ class: twMerge(getWrapperClass(false), "relative", local.class),
152
+ style: local.style
153
+ },
154
+ /* @__PURE__ */ React.createElement(
155
+ "div",
156
+ {
157
+ "data-textarea-field-content": true,
158
+ style: {
159
+ "visibility": isEditable() ? "hidden" : void 0,
160
+ "white-space": "pre-wrap",
161
+ "word-break": "break-all"
162
+ },
163
+ title: local.title
164
+ },
165
+ isEditable() ? contentForHeight() : value() || (local.placeholder != null && local.placeholder !== "" ? /* @__PURE__ */ React.createElement("span", { class: textMuted }, local.placeholder) : "\xA0")
166
+ ),
167
+ /* @__PURE__ */ React.createElement(Show, { when: isEditable() }, /* @__PURE__ */ React.createElement(
168
+ "textarea",
169
+ {
170
+ class: twMerge(textareaBaseClass, local.size && textAreaSizeClasses[local.size]),
171
+ value: value(),
172
+ placeholder: local.placeholder,
173
+ title: local.title,
174
+ onKeyDown: handleKeyDown,
175
+ onInput: handleInput,
176
+ onCompositionStart: handleCompositionStart,
177
+ onCompositionEnd: handleCompositionEnd
178
+ }
179
+ ))
180
+ )
181
+ );
182
+ };
183
+ export {
184
+ Textarea
185
+ };
186
+ //# sourceMappingURL=Textarea.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/form-control/field/Textarea.tsx"],
4
+ "sourcesContent": ["import clsx from \"clsx\";\nimport { type Component, createEffect, type JSX, Show, splitProps } from \"solid-js\";\nimport { twMerge } from \"tailwind-merge\";\nimport { createControllableSignal } from \"../../../hooks/createControllableSignal\";\nimport { createIMEHandler } from \"../../../hooks/createIMEHandler\";\nimport {\n type FieldSize,\n textAreaBaseClass as fieldTextAreaBaseClass,\n textAreaSizeClasses,\n fieldErrorClass,\n fieldInsetClass,\n fieldDisabledClass,\n} from \"./Field.styles\";\nimport { textMuted } from \"../../../styles/tokens.styles\";\n\nexport interface TextareaProps {\n /** \uC785\uB825 \uAC12 */\n value?: string;\n\n /** \uAC12 \uBCC0\uACBD \uCF5C\uBC31 */\n onValueChange?: (value: string) => void;\n\n /** \uD50C\uB808\uC774\uC2A4\uD640\uB354 */\n placeholder?: string;\n\n /** \uD0C0\uC774\uD2C0 (\uD234\uD301) */\n title?: string;\n\n /** \uBE44\uD65C\uC131\uD654 */\n disabled?: boolean;\n\n /** \uC77D\uAE30 \uC804\uC6A9 */\n readonly?: boolean;\n\n /** \uC5D0\uB7EC \uC0C1\uD0DC */\n error?: boolean;\n\n /** \uC0AC\uC774\uC988 */\n size?: FieldSize;\n\n /** \uD14C\uB450\uB9AC \uC5C6\uB294 \uC2A4\uD0C0\uC77C */\n inset?: boolean;\n\n /** \uCD5C\uC18C \uC904 \uC218 (\uAE30\uBCF8\uAC12: 1) */\n minRows?: number;\n\n /** \uCEE4\uC2A4\uD140 class */\n class?: string;\n\n /** \uCEE4\uC2A4\uD140 style */\n style?: JSX.CSSProperties;\n}\n\nconst textareaBaseClass = clsx(\n \"absolute left-0 top-0\",\n \"size-full\",\n \"resize-none overflow-hidden\",\n \"bg-transparent\",\n \"px-2 py-1\",\n \"placeholder:text-base-400 dark:placeholder:text-base-500\",\n);\n\n/**\n * Textarea \uCEF4\uD3EC\uB10C\uD2B8\n *\n * @example\n * ```tsx\n * // \uAE30\uBCF8 \uC0AC\uC6A9\n * <Textarea value={text()} onValueChange={setText} />\n *\n * // \uCD5C\uC18C \uC904 \uC218 \uC9C0\uC815\n * <Textarea minRows={3} value={text()} onValueChange={setText} />\n * ```\n */\nexport const Textarea: Component<TextareaProps> = (props) => {\n const [local, rest] = splitProps(props, [\n \"value\",\n \"onValueChange\",\n \"placeholder\",\n \"title\",\n \"disabled\",\n \"readonly\",\n \"error\",\n \"size\",\n \"inset\",\n \"minRows\",\n \"class\",\n \"style\",\n ]);\n\n const [value, setValue] = createControllableSignal({\n value: () => local.value ?? \"\",\n onChange: () => local.onValueChange,\n });\n\n // IME \uC870\uD569 \uC911 onValueChange\uB97C \uC9C0\uC5F0\uD558\uC5EC DOM \uC7AC\uC0DD\uC131(\uD55C\uAE00 \uC870\uD569 \uB04A\uAE40) \uBC29\uC9C0\n const ime = createIMEHandler((v) => setValue(v));\n\n // content div\uC6A9 \uD45C\uC2DC \uAC12 (composingValue \uD3EC\uD568 \u2014 \uC140 \uB108\uBE44/\uB192\uC774 \uACB0\uC815)\n const displayValue = () => ime.composingValue() ?? value();\n\n const handleCompositionStart = () => ime.handleCompositionStart();\n\n const handleInput: JSX.InputEventHandler<HTMLTextAreaElement, InputEvent> = (e) => {\n ime.handleInput(e.currentTarget.value, e.isComposing);\n };\n\n const handleCompositionEnd: JSX.EventHandler<HTMLTextAreaElement, CompositionEvent> = (e) => {\n ime.handleCompositionEnd(e.currentTarget.value);\n };\n\n const handleKeyDown: JSX.EventHandler<HTMLTextAreaElement, KeyboardEvent> = (e) => {\n if (e.key === \"Enter\" && e.altKey) {\n e.preventDefault();\n e.stopPropagation();\n\n const el = e.currentTarget;\n const start = el.selectionStart;\n const end = el.selectionEnd;\n const before = el.value.substring(0, start);\n const after = el.value.substring(end);\n const newVal = before + \"\\n\" + after;\n\n el.value = newVal;\n el.selectionStart = start + 1;\n el.selectionEnd = start + 1;\n\n // input \uC774\uBCA4\uD2B8\uB97C \uC218\uB3D9 \uBC1C\uD589\uD558\uC5EC \uAC12 \uB3D9\uAE30\uD654\n el.dispatchEvent(new InputEvent(\"input\", { bubbles: true }));\n }\n };\n\n const contentForHeight = () => {\n const rows = local.minRows ?? 1;\n const val = displayValue();\n const content = val !== \"\" && val.split(\"\\n\").length >= rows ? val : \"\\n\".repeat(rows - 1) + \"\\u00A0\";\n // \uB9C8\uC9C0\uB9C9\uC774 \uC904\uBC14\uAFC8\uC774\uBA74 \uBE48 \uC904 \uB192\uC774 \uD655\uBCF4\uB97C \uC704\uD574 \uACF5\uBC31 \uCD94\uAC00\n return content.endsWith(\"\\n\") ? content + \"\\u00A0\" : content;\n };\n\n // wrapper \uD074\uB798\uC2A4 (includeCustomClass=false\uC77C \uB54C local.class \uC81C\uC678 \u2014 inset\uC5D0\uC11C outer\uC5D0\uB9CC \uC801\uC6A9)\n const getWrapperClass = (includeCustomClass: boolean) =>\n twMerge(\n fieldTextAreaBaseClass,\n local.size && textAreaSizeClasses[local.size],\n local.error && fieldErrorClass,\n local.disabled && fieldDisabledClass,\n local.inset && fieldInsetClass,\n\n includeCustomClass && local.class,\n );\n\n const getTextareaClass = () =>\n twMerge(textareaBaseClass, local.size && textAreaSizeClasses[local.size], local.inset && \"p-0\");\n\n // \uD3B8\uC9D1 \uAC00\uB2A5 \uC5EC\uBD80\n const isEditable = () => !local.disabled && !local.readonly;\n\n // disabled \uC804\uD658 \uC2DC \uBBF8\uCEE4\uBC0B \uC870\uD569 \uAC12 flush\n createEffect(() => {\n if (!isEditable()) {\n ime.flushComposition();\n }\n });\n\n return (\n <Show\n when={local.inset}\n fallback={\n // standalone \uBAA8\uB4DC: \uAE30\uC874 Show \uD328\uD134 \uC720\uC9C0\n <Show\n when={isEditable()}\n fallback={\n <div\n {...rest}\n data-textarea-field\n class={getWrapperClass(true)}\n style={{ \"white-space\": \"pre-wrap\", \"word-break\": \"break-all\", ...local.style }}\n title={local.title}\n >\n {value() ||\n (local.placeholder != null && local.placeholder !== \"\" ? (\n <span class={textMuted}>{local.placeholder}</span>\n ) : (\n \"\\u00A0\"\n ))}\n </div>\n }\n >\n <div\n {...rest}\n data-textarea-field\n class={getWrapperClass(true)}\n style={{ position: \"relative\", ...local.style }}\n >\n <div\n data-hidden-content\n style={{\n \"visibility\": \"hidden\",\n \"white-space\": \"pre-wrap\",\n \"word-break\": \"break-all\",\n }}\n >\n {contentForHeight()}\n </div>\n\n <textarea\n class={getTextareaClass()}\n value={value()}\n placeholder={local.placeholder}\n title={local.title}\n onKeyDown={handleKeyDown}\n onInput={handleInput}\n onCompositionStart={handleCompositionStart}\n onCompositionEnd={handleCompositionEnd}\n />\n </div>\n </Show>\n }\n >\n {/* inset \uBAA8\uB4DC: dual-element overlay \uD328\uD134 */}\n <div\n {...rest}\n data-textarea-field\n class={twMerge(getWrapperClass(false), \"relative\", local.class)}\n style={local.style}\n >\n <div\n data-textarea-field-content\n style={{\n \"visibility\": isEditable() ? \"hidden\" : undefined,\n \"white-space\": \"pre-wrap\",\n \"word-break\": \"break-all\",\n }}\n title={local.title}\n >\n {isEditable()\n ? contentForHeight()\n : value() ||\n (local.placeholder != null && local.placeholder !== \"\" ? (\n <span class={textMuted}>{local.placeholder}</span>\n ) : (\n \"\\u00A0\"\n ))}\n </div>\n\n <Show when={isEditable()}>\n <textarea\n class={twMerge(textareaBaseClass, local.size && textAreaSizeClasses[local.size])}\n value={value()}\n placeholder={local.placeholder}\n title={local.title}\n onKeyDown={handleKeyDown}\n onInput={handleInput}\n onCompositionStart={handleCompositionStart}\n onCompositionEnd={handleCompositionEnd}\n />\n </Show>\n </div>\n </Show>\n );\n};\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,138 @@
1
+ import clsx from "clsx";
2
+ import { Show, splitProps } from "solid-js";
3
+ import { twMerge } from "tailwind-merge";
4
+ import { Time } from "@simplysm/core-common";
5
+ import { createControllableSignal } from "../../../hooks/createControllableSignal";
6
+ import {
7
+ fieldBaseClass,
8
+ fieldSizeClasses,
9
+ fieldErrorClass,
10
+ fieldInsetClass,
11
+ fieldInsetHeightClass,
12
+ fieldInsetSizeHeightClasses,
13
+ fieldDisabledClass,
14
+ fieldInputClass
15
+ } from "./Field.styles";
16
+ function formatValue(value, unit) {
17
+ if (value == null) return "";
18
+ switch (unit) {
19
+ case "minute":
20
+ return value.toFormatString("HH:mm");
21
+ case "second":
22
+ return value.toFormatString("HH:mm:ss");
23
+ }
24
+ }
25
+ function parseValue(str, unit) {
26
+ if (str === "") return void 0;
27
+ switch (unit) {
28
+ case "minute": {
29
+ const match = /^(\d{2}):(\d{2})$/.exec(str);
30
+ if (match == null) return void 0;
31
+ return new Time(Number(match[1]), Number(match[2]), 0);
32
+ }
33
+ case "second": {
34
+ const match = /^(\d{2}):(\d{2}):(\d{2})$/.exec(str);
35
+ if (match == null) return void 0;
36
+ return new Time(Number(match[1]), Number(match[2]), Number(match[3]));
37
+ }
38
+ }
39
+ }
40
+ const TimePicker = (props) => {
41
+ const [local, rest] = splitProps(props, [
42
+ "value",
43
+ "onValueChange",
44
+ "unit",
45
+ "title",
46
+ "disabled",
47
+ "readonly",
48
+ "error",
49
+ "size",
50
+ "inset",
51
+ "class",
52
+ "style"
53
+ ]);
54
+ const fieldType = () => local.unit ?? "minute";
55
+ const [value, setValue] = createControllableSignal({
56
+ value: () => local.value,
57
+ onChange: () => local.onValueChange
58
+ });
59
+ const displayValue = () => formatValue(value(), fieldType());
60
+ const handleChange = (e) => {
61
+ const newValue = e.currentTarget.value;
62
+ const parsed = parseValue(newValue, fieldType());
63
+ setValue(parsed);
64
+ };
65
+ const getWrapperClass = (includeCustomClass) => twMerge(
66
+ fieldBaseClass,
67
+ local.size && fieldSizeClasses[local.size],
68
+ local.error && fieldErrorClass,
69
+ local.disabled && fieldDisabledClass,
70
+ local.inset && fieldInsetClass + " block",
71
+ local.inset && (local.size ? fieldInsetSizeHeightClasses[local.size] : fieldInsetHeightClass),
72
+ includeCustomClass && local.class
73
+ );
74
+ const isEditable = () => !local.disabled && !local.readonly;
75
+ const getStep = () => fieldType() === "second" ? "1" : void 0;
76
+ return /* @__PURE__ */ React.createElement(
77
+ Show,
78
+ {
79
+ when: local.inset,
80
+ fallback: (
81
+ // standalone 모드
82
+ /* @__PURE__ */ React.createElement(
83
+ Show,
84
+ {
85
+ when: isEditable(),
86
+ fallback: /* @__PURE__ */ React.createElement(
87
+ "div",
88
+ {
89
+ ...rest,
90
+ "data-time-field": true,
91
+ class: twMerge(getWrapperClass(true), "sd-time-field"),
92
+ style: local.style,
93
+ title: local.title
94
+ },
95
+ displayValue() || "\xA0"
96
+ )
97
+ },
98
+ /* @__PURE__ */ React.createElement("div", { ...rest, "data-time-field": true, class: getWrapperClass(true), style: local.style }, /* @__PURE__ */ React.createElement(
99
+ "input",
100
+ {
101
+ type: "time",
102
+ class: fieldInputClass,
103
+ value: displayValue(),
104
+ title: local.title,
105
+ step: getStep(),
106
+ onChange: handleChange
107
+ }
108
+ ))
109
+ )
110
+ )
111
+ },
112
+ /* @__PURE__ */ React.createElement(
113
+ "div",
114
+ {
115
+ ...rest,
116
+ "data-time-field": true,
117
+ class: twMerge(getWrapperClass(false), "relative", local.class),
118
+ style: local.style
119
+ },
120
+ /* @__PURE__ */ React.createElement("div", { "data-time-field-content": true, style: { visibility: isEditable() ? "hidden" : void 0 }, title: local.title }, displayValue() || "\xA0"),
121
+ /* @__PURE__ */ React.createElement(Show, { when: isEditable() }, /* @__PURE__ */ React.createElement(
122
+ "input",
123
+ {
124
+ type: "time",
125
+ class: clsx(fieldInputClass, "absolute left-0 top-0 size-full", "px-2 py-1"),
126
+ value: displayValue(),
127
+ title: local.title,
128
+ step: getStep(),
129
+ onChange: handleChange
130
+ }
131
+ ))
132
+ )
133
+ );
134
+ };
135
+ export {
136
+ TimePicker
137
+ };
138
+ //# sourceMappingURL=TimePicker.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/form-control/field/TimePicker.tsx"],
4
+ "sourcesContent": ["import clsx from \"clsx\";\nimport { type Component, type JSX, Show, splitProps } from \"solid-js\";\nimport { twMerge } from \"tailwind-merge\";\nimport { Time } from \"@simplysm/core-common\";\nimport { createControllableSignal } from \"../../../hooks/createControllableSignal\";\nimport {\n type FieldSize,\n fieldBaseClass,\n fieldSizeClasses,\n fieldErrorClass,\n fieldInsetClass,\n fieldInsetHeightClass,\n fieldInsetSizeHeightClasses,\n fieldDisabledClass,\n fieldInputClass,\n} from \"./Field.styles\";\n\ntype TimePickerUnit = \"minute\" | \"second\";\n\nexport interface TimePickerProps {\n /** \uC785\uB825 \uAC12 */\n value?: Time;\n\n /** \uAC12 \uBCC0\uACBD \uCF5C\uBC31 */\n onValueChange?: (value: Time | undefined) => void;\n\n /** \uC2DC\uAC04 \uB2E8\uC704 */\n unit?: TimePickerUnit;\n\n /** \uD0C0\uC774\uD2C0 (\uD234\uD301) */\n title?: string;\n\n /** \uBE44\uD65C\uC131\uD654 */\n disabled?: boolean;\n\n /** \uC77D\uAE30 \uC804\uC6A9 */\n readonly?: boolean;\n\n /** \uC5D0\uB7EC \uC0C1\uD0DC */\n error?: boolean;\n\n /** \uC0AC\uC774\uC988 */\n size?: FieldSize;\n\n /** \uD14C\uB450\uB9AC \uC5C6\uB294 \uC2A4\uD0C0\uC77C */\n inset?: boolean;\n\n /** \uCEE4\uC2A4\uD140 class */\n class?: string;\n\n /** \uCEE4\uC2A4\uD140 style */\n style?: JSX.CSSProperties;\n}\n\n/**\n * Time \uAC12\uC744 input value\uC6A9 \uBB38\uC790\uC5F4\uB85C \uBCC0\uD658\n */\nfunction formatValue(value: Time | undefined, unit: TimePickerUnit): string {\n if (value == null) return \"\";\n\n switch (unit) {\n case \"minute\":\n return value.toFormatString(\"HH:mm\");\n case \"second\":\n return value.toFormatString(\"HH:mm:ss\");\n }\n}\n\n/**\n * \uC785\uB825 \uBB38\uC790\uC5F4\uC744 Time\uC73C\uB85C \uBCC0\uD658\n */\nfunction parseValue(str: string, unit: TimePickerUnit): Time | undefined {\n if (str === \"\") return undefined;\n\n switch (unit) {\n case \"minute\": {\n // HH:mm \uD615\uC2DD\n const match = /^(\\d{2}):(\\d{2})$/.exec(str);\n if (match == null) return undefined;\n return new Time(Number(match[1]), Number(match[2]), 0);\n }\n case \"second\": {\n // HH:mm:ss \uD615\uC2DD\n const match = /^(\\d{2}):(\\d{2}):(\\d{2})$/.exec(str);\n if (match == null) return undefined;\n return new Time(Number(match[1]), Number(match[2]), Number(match[3]));\n }\n }\n}\n\n/**\n * TimePicker \uCEF4\uD3EC\uB10C\uD2B8\n *\n * \uC2DC\uAC04 \uC785\uB825 \uD544\uB4DC. minute, second \uB2E8\uC704\uB97C \uC9C0\uC6D0\uD55C\uB2E4.\n * \uB0B4\uBD80\uC801\uC73C\uB85C string \u2194 Time \uD0C0\uC785 \uBCC0\uD658\uC744 \uCC98\uB9AC\uD55C\uB2E4.\n *\n * @example\n * ```tsx\n * // \uC2DC\uAC04 \uC785\uB825 (\uBD84 \uB2E8\uC704)\n * <TimePicker unit=\"minute\" value={time()} onValueChange={setTime} />\n *\n * // \uC2DC\uAC04 \uC785\uB825 (\uCD08 \uB2E8\uC704)\n * <TimePicker unit=\"second\" value={time()} onValueChange={setTime} />\n * ```\n */\nexport const TimePicker: Component<TimePickerProps> = (props) => {\n const [local, rest] = splitProps(props, [\n \"value\",\n \"onValueChange\",\n \"unit\",\n \"title\",\n \"disabled\",\n \"readonly\",\n \"error\",\n \"size\",\n \"inset\",\n \"class\",\n \"style\",\n ]);\n\n // \uAE30\uBCF8 \uB2E8\uC704\uB294 minute\n const fieldType = () => local.unit ?? \"minute\";\n\n // controlled/uncontrolled \uD328\uD134 \uC9C0\uC6D0\n const [value, setValue] = createControllableSignal({\n value: () => local.value,\n onChange: () => local.onValueChange,\n });\n\n // \uD45C\uC2DC \uAC12\n const displayValue = () => formatValue(value(), fieldType());\n\n // \uAC12 \uD655\uC815 \uD578\uB4E4\uB7EC (\uD3EC\uCEE4\uC2A4 \uC544\uC6C3 \uB610\uB294 Enter \uC2DC)\n const handleChange: JSX.EventHandler<HTMLInputElement, Event> = (e) => {\n const newValue = e.currentTarget.value;\n const parsed = parseValue(newValue, fieldType());\n setValue(parsed);\n };\n\n // wrapper \uD074\uB798\uC2A4\n const getWrapperClass = (includeCustomClass: boolean) =>\n twMerge(\n fieldBaseClass,\n local.size && fieldSizeClasses[local.size],\n local.error && fieldErrorClass,\n local.disabled && fieldDisabledClass,\n local.inset && fieldInsetClass + \" block\",\n local.inset && (local.size ? fieldInsetSizeHeightClasses[local.size] : fieldInsetHeightClass),\n\n includeCustomClass && local.class,\n );\n\n // \uD3B8\uC9D1 \uAC00\uB2A5 \uC5EC\uBD80\n const isEditable = () => !local.disabled && !local.readonly;\n\n // step \uC18D\uC131 (second\uC77C \uB54C 1)\n const getStep = () => (fieldType() === \"second\" ? \"1\" : undefined);\n\n return (\n <Show\n when={local.inset}\n fallback={\n // standalone \uBAA8\uB4DC\n <Show\n when={isEditable()}\n fallback={\n <div\n {...rest}\n data-time-field\n class={twMerge(getWrapperClass(true), \"sd-time-field\")}\n style={local.style}\n title={local.title}\n >\n {displayValue() || \"\\u00A0\"}\n </div>\n }\n >\n <div {...rest} data-time-field class={getWrapperClass(true)} style={local.style}>\n <input\n type=\"time\"\n class={fieldInputClass}\n value={displayValue()}\n title={local.title}\n step={getStep()}\n onChange={handleChange}\n />\n </div>\n </Show>\n }\n >\n {/* inset \uBAA8\uB4DC: dual-element overlay \uD328\uD134 */}\n <div\n {...rest}\n data-time-field\n class={twMerge(getWrapperClass(false), \"relative\", local.class)}\n style={local.style}\n >\n <div data-time-field-content style={{ visibility: isEditable() ? \"hidden\" : undefined }} title={local.title}>\n {displayValue() || \"\\u00A0\"}\n </div>\n\n <Show when={isEditable()}>\n <input\n type=\"time\"\n class={clsx(fieldInputClass, \"absolute left-0 top-0 size-full\", \"px-2 py-1\")}\n value={displayValue()}\n title={local.title}\n step={getStep()}\n onChange={handleChange}\n />\n </Show>\n </div>\n </Show>\n );\n};\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }