@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.
- package/README.md +1652 -0
- package/dist/components/data/Pagination.js +110 -0
- package/dist/components/data/Pagination.js.map +7 -0
- package/dist/components/data/Table.js +34 -0
- package/dist/components/data/Table.js.map +7 -0
- package/dist/components/data/calendar/Calendar.js +90 -0
- package/dist/components/data/calendar/Calendar.js.map +7 -0
- package/dist/components/data/kanban/Kanban.js +367 -0
- package/dist/components/data/kanban/Kanban.js.map +7 -0
- package/dist/components/data/kanban/KanbanContext.js +24 -0
- package/dist/components/data/kanban/KanbanContext.js.map +7 -0
- package/dist/components/data/list/List.js +133 -0
- package/dist/components/data/list/List.js.map +7 -0
- package/dist/components/data/list/ListContext.js +8 -0
- package/dist/components/data/list/ListContext.js.map +7 -0
- package/dist/components/data/list/ListItem.js +101 -0
- package/dist/components/data/list/ListItem.js.map +7 -0
- package/dist/components/data/list/ListItem.styles.js +43 -0
- package/dist/components/data/list/ListItem.styles.js.map +7 -0
- package/dist/components/data/permission-table/PermissionTable.js +189 -0
- package/dist/components/data/permission-table/PermissionTable.js.map +7 -0
- package/dist/components/data/sheet/DataSheet.js +907 -0
- package/dist/components/data/sheet/DataSheet.js.map +7 -0
- package/dist/components/data/sheet/DataSheet.styles.js +142 -0
- package/dist/components/data/sheet/DataSheet.styles.js.map +7 -0
- package/dist/components/data/sheet/DataSheetColumn.js +28 -0
- package/dist/components/data/sheet/DataSheetColumn.js.map +7 -0
- package/dist/components/data/sheet/DataSheetConfigDialog.js +83 -0
- package/dist/components/data/sheet/DataSheetConfigDialog.js.map +7 -0
- package/dist/components/data/sheet/sheetUtils.js +125 -0
- package/dist/components/data/sheet/sheetUtils.js.map +7 -0
- package/dist/components/data/sheet/types.js +1 -0
- package/dist/components/data/sheet/types.js.map +7 -0
- package/dist/components/disclosure/Collapse.js +45 -0
- package/dist/components/disclosure/Collapse.js.map +7 -0
- package/dist/components/disclosure/Dialog.js +367 -0
- package/dist/components/disclosure/Dialog.js.map +7 -0
- package/dist/components/disclosure/DialogContext.js +14 -0
- package/dist/components/disclosure/DialogContext.js.map +7 -0
- package/dist/components/disclosure/DialogInstanceContext.js +10 -0
- package/dist/components/disclosure/DialogInstanceContext.js.map +7 -0
- package/dist/components/disclosure/DialogProvider.js +88 -0
- package/dist/components/disclosure/DialogProvider.js.map +7 -0
- package/dist/components/disclosure/Dropdown.js +244 -0
- package/dist/components/disclosure/Dropdown.js.map +7 -0
- package/dist/components/disclosure/Tabs.js +75 -0
- package/dist/components/disclosure/Tabs.js.map +7 -0
- package/dist/components/disclosure/dialogZIndex.js +32 -0
- package/dist/components/disclosure/dialogZIndex.js.map +7 -0
- package/dist/components/display/Alert.js +18 -0
- package/dist/components/display/Alert.js.map +7 -0
- package/dist/components/display/Barcode.js +39 -0
- package/dist/components/display/Barcode.js.map +7 -0
- package/dist/components/display/Card.js +21 -0
- package/dist/components/display/Card.js.map +7 -0
- package/dist/components/display/Echarts.js +33 -0
- package/dist/components/display/Echarts.js.map +7 -0
- package/dist/components/display/Icon.js +10 -0
- package/dist/components/display/Icon.js.map +7 -0
- package/dist/components/display/Tag.js +20 -0
- package/dist/components/display/Tag.js.map +7 -0
- package/dist/components/feedback/Progress.js +37 -0
- package/dist/components/feedback/Progress.js.map +7 -0
- package/dist/components/feedback/loading/LoadingContainer.js +83 -0
- package/dist/components/feedback/loading/LoadingContainer.js.map +7 -0
- package/dist/components/feedback/loading/LoadingContext.js +14 -0
- package/dist/components/feedback/loading/LoadingContext.js.map +7 -0
- package/dist/components/feedback/loading/LoadingProvider.js +47 -0
- package/dist/components/feedback/loading/LoadingProvider.js.map +7 -0
- package/dist/components/feedback/notification/NotificationBanner.js +61 -0
- package/dist/components/feedback/notification/NotificationBanner.js.map +7 -0
- package/dist/components/feedback/notification/NotificationBell.js +85 -0
- package/dist/components/feedback/notification/NotificationBell.js.map +7 -0
- package/dist/components/feedback/notification/NotificationContext.js +14 -0
- package/dist/components/feedback/notification/NotificationContext.js.map +7 -0
- package/dist/components/feedback/notification/NotificationProvider.js +101 -0
- package/dist/components/feedback/notification/NotificationProvider.js.map +7 -0
- package/dist/components/feedback/notification/index.js +5 -0
- package/dist/components/feedback/notification/index.js.map +7 -0
- package/dist/components/feedback/print/Print.js +12 -0
- package/dist/components/feedback/print/Print.js.map +7 -0
- package/dist/components/feedback/print/PrintInstanceContext.js +10 -0
- package/dist/components/feedback/print/PrintInstanceContext.js.map +7 -0
- package/dist/components/form-control/Button.js +74 -0
- package/dist/components/form-control/Button.js.map +7 -0
- package/dist/components/form-control/DropdownTrigger.styles.js +44 -0
- package/dist/components/form-control/DropdownTrigger.styles.js.map +7 -0
- package/dist/components/form-control/ThemeToggle.js +57 -0
- package/dist/components/form-control/ThemeToggle.js.map +7 -0
- package/dist/components/form-control/checkbox/Checkbox.js +78 -0
- package/dist/components/form-control/checkbox/Checkbox.js.map +7 -0
- package/dist/components/form-control/checkbox/Checkbox.styles.js +57 -0
- package/dist/components/form-control/checkbox/Checkbox.styles.js.map +7 -0
- package/dist/components/form-control/checkbox/CheckboxGroup.js +65 -0
- package/dist/components/form-control/checkbox/CheckboxGroup.js.map +7 -0
- package/dist/components/form-control/checkbox/Radio.js +78 -0
- package/dist/components/form-control/checkbox/Radio.js.map +7 -0
- package/dist/components/form-control/checkbox/RadioGroup.js +60 -0
- package/dist/components/form-control/checkbox/RadioGroup.js.map +7 -0
- package/dist/components/form-control/color-picker/ColorPicker.js +55 -0
- package/dist/components/form-control/color-picker/ColorPicker.js.map +7 -0
- package/dist/components/form-control/combobox/Combobox.js +214 -0
- package/dist/components/form-control/combobox/Combobox.js.map +7 -0
- package/dist/components/form-control/combobox/ComboboxContext.js +14 -0
- package/dist/components/form-control/combobox/ComboboxContext.js.map +7 -0
- package/dist/components/form-control/combobox/ComboboxItem.js +49 -0
- package/dist/components/form-control/combobox/ComboboxItem.js.map +7 -0
- package/dist/components/form-control/date-range-picker/DateRangePicker.js +136 -0
- package/dist/components/form-control/date-range-picker/DateRangePicker.js.map +7 -0
- package/dist/components/form-control/editor/EditorToolbar.js +290 -0
- package/dist/components/form-control/editor/EditorToolbar.js.map +7 -0
- package/dist/components/form-control/editor/RichTextEditor.js +114 -0
- package/dist/components/form-control/editor/RichTextEditor.js.map +7 -0
- package/dist/components/form-control/field/DatePicker.js +167 -0
- package/dist/components/form-control/field/DatePicker.js.map +7 -0
- package/dist/components/form-control/field/DateTimePicker.js +168 -0
- package/dist/components/form-control/field/DateTimePicker.js.map +7 -0
- package/dist/components/form-control/field/Field.styles.js +35 -0
- package/dist/components/form-control/field/Field.styles.js.map +7 -0
- package/dist/components/form-control/field/NumberInput.js +193 -0
- package/dist/components/form-control/field/NumberInput.js.map +7 -0
- package/dist/components/form-control/field/TextInput.js +178 -0
- package/dist/components/form-control/field/TextInput.js.map +7 -0
- package/dist/components/form-control/field/Textarea.js +186 -0
- package/dist/components/form-control/field/Textarea.js.map +7 -0
- package/dist/components/form-control/field/TimePicker.js +138 -0
- package/dist/components/form-control/field/TimePicker.js.map +7 -0
- package/dist/components/form-control/numpad/Numpad.js +107 -0
- package/dist/components/form-control/numpad/Numpad.js.map +7 -0
- package/dist/components/form-control/select/Select.js +196 -0
- package/dist/components/form-control/select/Select.js.map +7 -0
- package/dist/components/form-control/select/SelectContext.js +14 -0
- package/dist/components/form-control/select/SelectContext.js.map +7 -0
- package/dist/components/form-control/select/SelectItem.js +65 -0
- package/dist/components/form-control/select/SelectItem.js.map +7 -0
- package/dist/components/form-control/state-preset/StatePreset.js +195 -0
- package/dist/components/form-control/state-preset/StatePreset.js.map +7 -0
- package/dist/components/layout/FormGroup.js +34 -0
- package/dist/components/layout/FormGroup.js.map +7 -0
- package/dist/components/layout/FormTable.js +24 -0
- package/dist/components/layout/FormTable.js.map +7 -0
- package/dist/components/layout/sidebar/Sidebar.js +63 -0
- package/dist/components/layout/sidebar/Sidebar.js.map +7 -0
- package/dist/components/layout/sidebar/SidebarContainer.js +70 -0
- package/dist/components/layout/sidebar/SidebarContainer.js.map +7 -0
- package/dist/components/layout/sidebar/SidebarContext.js +20 -0
- package/dist/components/layout/sidebar/SidebarContext.js.map +7 -0
- package/dist/components/layout/sidebar/SidebarMenu.js +84 -0
- package/dist/components/layout/sidebar/SidebarMenu.js.map +7 -0
- package/dist/components/layout/sidebar/SidebarUser.js +51 -0
- package/dist/components/layout/sidebar/SidebarUser.js.map +7 -0
- package/dist/components/layout/topbar/Topbar.js +48 -0
- package/dist/components/layout/topbar/Topbar.js.map +7 -0
- package/dist/components/layout/topbar/TopbarContainer.js +13 -0
- package/dist/components/layout/topbar/TopbarContainer.js.map +7 -0
- package/dist/components/layout/topbar/TopbarMenu.js +106 -0
- package/dist/components/layout/topbar/TopbarMenu.js.map +7 -0
- package/dist/components/layout/topbar/TopbarUser.js +44 -0
- package/dist/components/layout/topbar/TopbarUser.js.map +7 -0
- package/dist/core-browser/src/extensions/element-ext.d.ts +98 -0
- package/dist/core-browser/src/extensions/element-ext.d.ts.map +1 -0
- package/dist/core-browser/src/extensions/html-element-ext.d.ts +54 -0
- package/dist/core-browser/src/extensions/html-element-ext.d.ts.map +1 -0
- package/dist/core-browser/src/index.d.ts +7 -0
- package/dist/core-browser/src/index.d.ts.map +1 -0
- package/dist/core-browser/src/utils/blob.d.ts +10 -0
- package/dist/core-browser/src/utils/blob.d.ts.map +1 -0
- package/dist/core-browser/src/utils/download.d.ts +11 -0
- package/dist/core-browser/src/utils/download.d.ts.map +1 -0
- package/dist/core-common/src/common.types.d.ts +74 -0
- package/dist/core-common/src/common.types.d.ts.map +1 -0
- package/dist/core-common/src/env.d.ts +6 -0
- package/dist/core-common/src/env.d.ts.map +1 -0
- package/dist/core-common/src/errors/argument-error.d.ts +25 -0
- package/dist/core-common/src/errors/argument-error.d.ts.map +1 -0
- package/dist/core-common/src/errors/not-implemented-error.d.ts +29 -0
- package/dist/core-common/src/errors/not-implemented-error.d.ts.map +1 -0
- package/dist/core-common/src/errors/sd-error.d.ts +27 -0
- package/dist/core-common/src/errors/sd-error.d.ts.map +1 -0
- package/dist/core-common/src/errors/timeout-error.d.ts +31 -0
- package/dist/core-common/src/errors/timeout-error.d.ts.map +1 -0
- package/dist/core-common/src/extensions/arr-ext.d.ts +15 -0
- package/dist/core-common/src/extensions/arr-ext.d.ts.map +1 -0
- package/dist/core-common/src/extensions/arr-ext.helpers.d.ts +19 -0
- package/dist/core-common/src/extensions/arr-ext.helpers.d.ts.map +1 -0
- package/dist/core-common/src/extensions/arr-ext.types.d.ts +215 -0
- package/dist/core-common/src/extensions/arr-ext.types.d.ts.map +1 -0
- package/dist/core-common/src/extensions/map-ext.d.ts +57 -0
- package/dist/core-common/src/extensions/map-ext.d.ts.map +1 -0
- package/dist/core-common/src/extensions/set-ext.d.ts +36 -0
- package/dist/core-common/src/extensions/set-ext.d.ts.map +1 -0
- package/dist/core-common/src/features/debounce-queue.d.ts +53 -0
- package/dist/core-common/src/features/debounce-queue.d.ts.map +1 -0
- package/dist/core-common/src/features/event-emitter.d.ts +66 -0
- package/dist/core-common/src/features/event-emitter.d.ts.map +1 -0
- package/dist/core-common/src/features/serial-queue.d.ts +47 -0
- package/dist/core-common/src/features/serial-queue.d.ts.map +1 -0
- package/dist/core-common/src/index.d.ts +32 -0
- package/dist/core-common/src/index.d.ts.map +1 -0
- package/dist/core-common/src/types/date-only.d.ts +152 -0
- package/dist/core-common/src/types/date-only.d.ts.map +1 -0
- package/dist/core-common/src/types/date-time.d.ts +96 -0
- package/dist/core-common/src/types/date-time.d.ts.map +1 -0
- package/dist/core-common/src/types/lazy-gc-map.d.ts +80 -0
- package/dist/core-common/src/types/lazy-gc-map.d.ts.map +1 -0
- package/dist/core-common/src/types/time.d.ts +68 -0
- package/dist/core-common/src/types/time.d.ts.map +1 -0
- package/dist/core-common/src/types/uuid.d.ts +35 -0
- package/dist/core-common/src/types/uuid.d.ts.map +1 -0
- package/dist/core-common/src/utils/bytes.d.ts +51 -0
- package/dist/core-common/src/utils/bytes.d.ts.map +1 -0
- package/dist/core-common/src/utils/date-format.d.ts +90 -0
- package/dist/core-common/src/utils/date-format.d.ts.map +1 -0
- package/dist/core-common/src/utils/json.d.ts +34 -0
- package/dist/core-common/src/utils/json.d.ts.map +1 -0
- package/dist/core-common/src/utils/num.d.ts +60 -0
- package/dist/core-common/src/utils/num.d.ts.map +1 -0
- package/dist/core-common/src/utils/obj.d.ts +258 -0
- package/dist/core-common/src/utils/obj.d.ts.map +1 -0
- package/dist/core-common/src/utils/path.d.ts +23 -0
- package/dist/core-common/src/utils/path.d.ts.map +1 -0
- package/dist/core-common/src/utils/primitive.d.ts +18 -0
- package/dist/core-common/src/utils/primitive.d.ts.map +1 -0
- package/dist/core-common/src/utils/str.d.ts +103 -0
- package/dist/core-common/src/utils/str.d.ts.map +1 -0
- package/dist/core-common/src/utils/template-strings.d.ts +84 -0
- package/dist/core-common/src/utils/template-strings.d.ts.map +1 -0
- package/dist/core-common/src/utils/transferable.d.ts +47 -0
- package/dist/core-common/src/utils/transferable.d.ts.map +1 -0
- package/dist/core-common/src/utils/wait.d.ts +19 -0
- package/dist/core-common/src/utils/wait.d.ts.map +1 -0
- package/dist/core-common/src/utils/xml.d.ts +36 -0
- package/dist/core-common/src/utils/xml.d.ts.map +1 -0
- package/dist/core-common/src/zip/sd-zip.d.ts +80 -0
- package/dist/core-common/src/zip/sd-zip.d.ts.map +1 -0
- package/dist/directives/ripple.js +106 -0
- package/dist/directives/ripple.js.map +7 -0
- package/dist/helpers/createAppStructure.js +96 -0
- package/dist/helpers/createAppStructure.js.map +7 -0
- package/dist/helpers/mergeStyles.js +27 -0
- package/dist/helpers/mergeStyles.js.map +7 -0
- package/dist/helpers/splitSlots.js +25 -0
- package/dist/helpers/splitSlots.js.map +7 -0
- package/dist/hooks/createControllableSignal.js +24 -0
- package/dist/hooks/createControllableSignal.js.map +7 -0
- package/dist/hooks/createIMEHandler.js +50 -0
- package/dist/hooks/createIMEHandler.js.map +7 -0
- package/dist/hooks/createMountTransition.js +33 -0
- package/dist/hooks/createMountTransition.js.map +7 -0
- package/dist/hooks/useClipboardValueCopy.js +120 -0
- package/dist/hooks/useClipboardValueCopy.js.map +7 -0
- package/dist/hooks/usePersisted.js +25 -0
- package/dist/hooks/usePersisted.js.map +7 -0
- package/dist/hooks/usePrint.js +208 -0
- package/dist/hooks/usePrint.js.map +7 -0
- package/dist/hooks/useRouterLink.js +24 -0
- package/dist/hooks/useRouterLink.js.map +7 -0
- package/dist/index.js +94 -0
- package/dist/index.js.map +7 -0
- package/dist/orm-common/src/db-context.d.ts +669 -0
- package/dist/orm-common/src/db-context.d.ts.map +1 -0
- package/dist/orm-common/src/errors/db-transaction-error.d.ts +51 -0
- package/dist/orm-common/src/errors/db-transaction-error.d.ts.map +1 -0
- package/dist/orm-common/src/exec/executable.d.ts +79 -0
- package/dist/orm-common/src/exec/executable.d.ts.map +1 -0
- package/dist/orm-common/src/exec/queryable.d.ts +708 -0
- package/dist/orm-common/src/exec/queryable.d.ts.map +1 -0
- package/dist/orm-common/src/exec/search-parser.d.ts +72 -0
- package/dist/orm-common/src/exec/search-parser.d.ts.map +1 -0
- package/dist/orm-common/src/expr/expr-unit.d.ts +25 -0
- package/dist/orm-common/src/expr/expr-unit.d.ts.map +1 -0
- package/dist/orm-common/src/expr/expr.d.ts +1369 -0
- package/dist/orm-common/src/expr/expr.d.ts.map +1 -0
- package/dist/orm-common/src/index.d.ts +32 -0
- package/dist/orm-common/src/index.d.ts.map +1 -0
- package/dist/orm-common/src/models/system-migration.d.ts +10 -0
- package/dist/orm-common/src/models/system-migration.d.ts.map +1 -0
- package/dist/orm-common/src/query-builder/base/expr-renderer-base.d.ts +95 -0
- package/dist/orm-common/src/query-builder/base/expr-renderer-base.d.ts.map +1 -0
- package/dist/orm-common/src/query-builder/base/query-builder-base.d.ts +66 -0
- package/dist/orm-common/src/query-builder/base/query-builder-base.d.ts.map +1 -0
- package/dist/orm-common/src/query-builder/mssql/mssql-expr-renderer.d.ts +84 -0
- package/dist/orm-common/src/query-builder/mssql/mssql-expr-renderer.d.ts.map +1 -0
- package/dist/orm-common/src/query-builder/mssql/mssql-query-builder.d.ts +45 -0
- package/dist/orm-common/src/query-builder/mssql/mssql-query-builder.d.ts.map +1 -0
- package/dist/orm-common/src/query-builder/mysql/mysql-expr-renderer.d.ts +84 -0
- package/dist/orm-common/src/query-builder/mysql/mysql-expr-renderer.d.ts.map +1 -0
- package/dist/orm-common/src/query-builder/mysql/mysql-query-builder.d.ts +54 -0
- package/dist/orm-common/src/query-builder/mysql/mysql-query-builder.d.ts.map +1 -0
- package/dist/orm-common/src/query-builder/postgresql/postgresql-expr-renderer.d.ts +84 -0
- package/dist/orm-common/src/query-builder/postgresql/postgresql-expr-renderer.d.ts.map +1 -0
- package/dist/orm-common/src/query-builder/postgresql/postgresql-query-builder.d.ts +52 -0
- package/dist/orm-common/src/query-builder/postgresql/postgresql-query-builder.d.ts.map +1 -0
- package/dist/orm-common/src/query-builder/query-builder.d.ts +7 -0
- package/dist/orm-common/src/query-builder/query-builder.d.ts.map +1 -0
- package/dist/orm-common/src/schema/factory/column-builder.d.ts +394 -0
- package/dist/orm-common/src/schema/factory/column-builder.d.ts.map +1 -0
- package/dist/orm-common/src/schema/factory/index-builder.d.ts +151 -0
- package/dist/orm-common/src/schema/factory/index-builder.d.ts.map +1 -0
- package/dist/orm-common/src/schema/factory/relation-builder.d.ts +337 -0
- package/dist/orm-common/src/schema/factory/relation-builder.d.ts.map +1 -0
- package/dist/orm-common/src/schema/procedure-builder.d.ts +202 -0
- package/dist/orm-common/src/schema/procedure-builder.d.ts.map +1 -0
- package/dist/orm-common/src/schema/table-builder.d.ts +259 -0
- package/dist/orm-common/src/schema/table-builder.d.ts.map +1 -0
- package/dist/orm-common/src/schema/view-builder.d.ts +183 -0
- package/dist/orm-common/src/schema/view-builder.d.ts.map +1 -0
- package/dist/orm-common/src/types/column.d.ts +172 -0
- package/dist/orm-common/src/types/column.d.ts.map +1 -0
- package/dist/orm-common/src/types/db.d.ts +175 -0
- package/dist/orm-common/src/types/db.d.ts.map +1 -0
- package/dist/orm-common/src/types/expr.d.ts +474 -0
- package/dist/orm-common/src/types/expr.d.ts.map +1 -0
- package/dist/orm-common/src/types/query-def.d.ts +351 -0
- package/dist/orm-common/src/types/query-def.d.ts.map +1 -0
- package/dist/orm-common/src/utils/result-parser.d.ts +38 -0
- package/dist/orm-common/src/utils/result-parser.d.ts.map +1 -0
- package/dist/providers/ConfigContext.js +14 -0
- package/dist/providers/ConfigContext.js.map +7 -0
- package/dist/providers/InitializeProvider.js +10 -0
- package/dist/providers/InitializeProvider.js.map +7 -0
- package/dist/providers/ServiceClientContext.js +16 -0
- package/dist/providers/ServiceClientContext.js.map +7 -0
- package/dist/providers/ServiceClientProvider.js +116 -0
- package/dist/providers/ServiceClientProvider.js.map +7 -0
- package/dist/providers/ThemeContext.js +48 -0
- package/dist/providers/ThemeContext.js.map +7 -0
- package/dist/providers/shared-data/SharedDataChangeEvent.js +8 -0
- package/dist/providers/shared-data/SharedDataChangeEvent.js.map +7 -0
- package/dist/providers/shared-data/SharedDataContext.js +16 -0
- package/dist/providers/shared-data/SharedDataContext.js.map +7 -0
- package/dist/providers/shared-data/SharedDataProvider.js +115 -0
- package/dist/providers/shared-data/SharedDataProvider.js.map +7 -0
- package/dist/service-client/src/features/event-client.d.ts +14 -0
- package/dist/service-client/src/features/event-client.d.ts.map +1 -0
- package/dist/service-client/src/features/file-client.d.ts +13 -0
- package/dist/service-client/src/features/file-client.d.ts.map +1 -0
- package/dist/service-client/src/features/orm/orm-client-connector.d.ts +10 -0
- package/dist/service-client/src/features/orm/orm-client-connector.d.ts.map +1 -0
- package/dist/service-client/src/features/orm/orm-client-db-context-executor.d.ts +26 -0
- package/dist/service-client/src/features/orm/orm-client-db-context-executor.d.ts.map +1 -0
- package/dist/service-client/src/features/orm/orm-connect-config.d.ts +13 -0
- package/dist/service-client/src/features/orm/orm-connect-config.d.ts.map +1 -0
- package/dist/service-client/src/index.d.ts +12 -0
- package/dist/service-client/src/index.d.ts.map +1 -0
- package/dist/service-client/src/protocol/client-protocol-wrapper.d.ts +23 -0
- package/dist/service-client/src/protocol/client-protocol-wrapper.d.ts.map +1 -0
- package/dist/service-client/src/service-client.d.ts +41 -0
- package/dist/service-client/src/service-client.d.ts.map +1 -0
- package/dist/service-client/src/transport/service-transport.d.ts +24 -0
- package/dist/service-client/src/transport/service-transport.d.ts.map +1 -0
- package/dist/service-client/src/transport/socket-provider.d.ts +31 -0
- package/dist/service-client/src/transport/socket-provider.d.ts.map +1 -0
- package/dist/service-client/src/types/connection-config.d.ts +8 -0
- package/dist/service-client/src/types/connection-config.d.ts.map +1 -0
- package/dist/service-client/src/types/progress.types.d.ts +10 -0
- package/dist/service-client/src/types/progress.types.d.ts.map +1 -0
- package/dist/service-common/src/index.d.ts +8 -0
- package/dist/service-common/src/index.d.ts.map +1 -0
- package/dist/service-common/src/protocol/protocol.types.d.ts +100 -0
- package/dist/service-common/src/protocol/protocol.types.d.ts.map +1 -0
- package/dist/service-common/src/protocol/service-protocol.d.ts +63 -0
- package/dist/service-common/src/protocol/service-protocol.d.ts.map +1 -0
- package/dist/service-common/src/service-types/auto-update-service.types.d.ts +17 -0
- package/dist/service-common/src/service-types/auto-update-service.types.d.ts.map +1 -0
- package/dist/service-common/src/service-types/crypto-service.types.d.ts +22 -0
- package/dist/service-common/src/service-types/crypto-service.types.d.ts.map +1 -0
- package/dist/service-common/src/service-types/orm-service.types.d.ts +30 -0
- package/dist/service-common/src/service-types/orm-service.types.d.ts.map +1 -0
- package/dist/service-common/src/service-types/smtp-service.types.d.ts +55 -0
- package/dist/service-common/src/service-types/smtp-service.types.d.ts.map +1 -0
- package/dist/service-common/src/types.d.ts +43 -0
- package/dist/service-common/src/types.d.ts.map +1 -0
- package/dist/solid/src/components/data/Pagination.d.ts +12 -0
- package/dist/solid/src/components/data/Pagination.d.ts.map +1 -0
- package/dist/solid/src/components/data/Table.d.ts +6 -0
- package/dist/solid/src/components/data/Table.d.ts.map +1 -0
- package/dist/solid/src/components/data/calendar/Calendar.d.ts +15 -0
- package/dist/solid/src/components/data/calendar/Calendar.d.ts.map +1 -0
- package/dist/solid/src/components/data/kanban/Kanban.d.ts +38 -0
- package/dist/solid/src/components/data/kanban/Kanban.d.ts.map +1 -0
- package/dist/solid/src/components/data/kanban/KanbanContext.d.ts +40 -0
- package/dist/solid/src/components/data/kanban/KanbanContext.d.ts.map +1 -0
- package/dist/solid/src/components/data/list/List.d.ts +36 -0
- package/dist/solid/src/components/data/list/List.d.ts.map +1 -0
- package/dist/solid/src/components/data/list/ListContext.d.ts +9 -0
- package/dist/solid/src/components/data/list/ListContext.d.ts.map +1 -0
- package/dist/solid/src/components/data/list/ListItem.d.ts +88 -0
- package/dist/solid/src/components/data/list/ListItem.d.ts.map +1 -0
- package/dist/solid/src/components/data/list/ListItem.styles.d.ts +10 -0
- package/dist/solid/src/components/data/list/ListItem.styles.d.ts.map +1 -0
- package/dist/solid/src/components/data/permission-table/PermissionTable.d.ts +26 -0
- package/dist/solid/src/components/data/permission-table/PermissionTable.d.ts.map +1 -0
- package/dist/solid/src/components/data/sheet/DataSheet.d.ts +12 -0
- package/dist/solid/src/components/data/sheet/DataSheet.d.ts.map +1 -0
- package/dist/solid/src/components/data/sheet/DataSheet.styles.d.ts +33 -0
- package/dist/solid/src/components/data/sheet/DataSheet.styles.d.ts.map +1 -0
- package/dist/solid/src/components/data/sheet/DataSheetColumn.d.ts +5 -0
- package/dist/solid/src/components/data/sheet/DataSheetColumn.d.ts.map +1 -0
- package/dist/solid/src/components/data/sheet/DataSheetConfigDialog.d.ts +8 -0
- package/dist/solid/src/components/data/sheet/DataSheetConfigDialog.d.ts.map +1 -0
- package/dist/solid/src/components/data/sheet/sheetUtils.d.ts +7 -0
- package/dist/solid/src/components/data/sheet/sheetUtils.d.ts.map +1 -0
- package/dist/solid/src/components/data/sheet/types.d.ts +113 -0
- package/dist/solid/src/components/data/sheet/types.d.ts.map +1 -0
- package/dist/solid/src/components/disclosure/Collapse.d.ts +21 -0
- package/dist/solid/src/components/disclosure/Collapse.d.ts.map +1 -0
- package/dist/solid/src/components/disclosure/Dialog.d.ts +65 -0
- package/dist/solid/src/components/disclosure/Dialog.d.ts.map +1 -0
- package/dist/solid/src/components/disclosure/DialogContext.d.ts +30 -0
- package/dist/solid/src/components/disclosure/DialogContext.d.ts.map +1 -0
- package/dist/solid/src/components/disclosure/DialogInstanceContext.d.ts +6 -0
- package/dist/solid/src/components/disclosure/DialogInstanceContext.d.ts.map +1 -0
- package/dist/solid/src/components/disclosure/DialogProvider.d.ts +19 -0
- package/dist/solid/src/components/disclosure/DialogProvider.d.ts.map +1 -0
- package/dist/solid/src/components/disclosure/Dropdown.d.ts +65 -0
- package/dist/solid/src/components/disclosure/Dropdown.d.ts.map +1 -0
- package/dist/solid/src/components/disclosure/Tabs.d.ts +24 -0
- package/dist/solid/src/components/disclosure/Tabs.d.ts.map +1 -0
- package/dist/solid/src/components/disclosure/dialogZIndex.d.ts +13 -0
- package/dist/solid/src/components/disclosure/dialogZIndex.d.ts.map +1 -0
- package/dist/solid/src/components/display/Alert.d.ts +8 -0
- package/dist/solid/src/components/display/Alert.d.ts.map +1 -0
- package/dist/solid/src/components/display/Barcode.d.ts +8 -0
- package/dist/solid/src/components/display/Barcode.d.ts.map +1 -0
- package/dist/solid/src/components/display/Card.d.ts +6 -0
- package/dist/solid/src/components/display/Card.d.ts.map +1 -0
- package/dist/solid/src/components/display/Echarts.d.ts +8 -0
- package/dist/solid/src/components/display/Echarts.d.ts.map +1 -0
- package/dist/solid/src/components/display/Icon.d.ts +8 -0
- package/dist/solid/src/components/display/Icon.d.ts.map +1 -0
- package/dist/solid/src/components/display/Tag.d.ts +8 -0
- package/dist/solid/src/components/display/Tag.d.ts.map +1 -0
- package/dist/solid/src/components/feedback/Progress.d.ts +12 -0
- package/dist/solid/src/components/feedback/Progress.d.ts.map +1 -0
- package/dist/solid/src/components/feedback/loading/LoadingContainer.d.ts +12 -0
- package/dist/solid/src/components/feedback/loading/LoadingContainer.d.ts.map +1 -0
- package/dist/solid/src/components/feedback/loading/LoadingContext.d.ts +11 -0
- package/dist/solid/src/components/feedback/loading/LoadingContext.d.ts.map +1 -0
- package/dist/solid/src/components/feedback/loading/LoadingProvider.d.ts +7 -0
- package/dist/solid/src/components/feedback/loading/LoadingProvider.d.ts.map +1 -0
- package/dist/solid/src/components/feedback/notification/NotificationBanner.d.ts +3 -0
- package/dist/solid/src/components/feedback/notification/NotificationBanner.d.ts.map +1 -0
- package/dist/solid/src/components/feedback/notification/NotificationBell.d.ts +6 -0
- package/dist/solid/src/components/feedback/notification/NotificationBell.d.ts.map +1 -0
- package/dist/solid/src/components/feedback/notification/NotificationContext.d.ts +39 -0
- package/dist/solid/src/components/feedback/notification/NotificationContext.d.ts.map +1 -0
- package/dist/solid/src/components/feedback/notification/NotificationProvider.d.ts +3 -0
- package/dist/solid/src/components/feedback/notification/NotificationProvider.d.ts.map +1 -0
- package/dist/solid/src/components/feedback/notification/index.d.ts +5 -0
- package/dist/solid/src/components/feedback/notification/index.d.ts.map +1 -0
- package/dist/solid/src/components/feedback/print/Print.d.ts +9 -0
- package/dist/solid/src/components/feedback/print/Print.d.ts.map +1 -0
- package/dist/solid/src/components/feedback/print/PrintInstanceContext.d.ts +6 -0
- package/dist/solid/src/components/feedback/print/PrintInstanceContext.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/Button.d.ts +14 -0
- package/dist/solid/src/components/form-control/Button.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/DropdownTrigger.styles.d.ts +14 -0
- package/dist/solid/src/components/form-control/DropdownTrigger.styles.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/ThemeToggle.d.ts +25 -0
- package/dist/solid/src/components/form-control/ThemeToggle.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/checkbox/Checkbox.d.ts +16 -0
- package/dist/solid/src/components/form-control/checkbox/Checkbox.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/checkbox/Checkbox.styles.d.ts +12 -0
- package/dist/solid/src/components/form-control/checkbox/Checkbox.styles.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/checkbox/CheckboxGroup.d.ts +27 -0
- package/dist/solid/src/components/form-control/checkbox/CheckboxGroup.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/checkbox/Radio.d.ts +16 -0
- package/dist/solid/src/components/form-control/checkbox/Radio.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/checkbox/RadioGroup.d.ts +27 -0
- package/dist/solid/src/components/form-control/checkbox/RadioGroup.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/color-picker/ColorPicker.d.ts +29 -0
- package/dist/solid/src/components/form-control/color-picker/ColorPicker.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/combobox/Combobox.d.ts +80 -0
- package/dist/solid/src/components/form-control/combobox/Combobox.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/combobox/ComboboxContext.d.ts +11 -0
- package/dist/solid/src/components/form-control/combobox/ComboboxContext.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/combobox/ComboboxItem.d.ts +12 -0
- package/dist/solid/src/components/form-control/combobox/ComboboxItem.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/date-range-picker/DateRangePicker.d.ts +55 -0
- package/dist/solid/src/components/form-control/date-range-picker/DateRangePicker.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/editor/EditorToolbar.d.ts +8 -0
- package/dist/solid/src/components/form-control/editor/EditorToolbar.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/editor/RichTextEditor.d.ts +21 -0
- package/dist/solid/src/components/form-control/editor/RichTextEditor.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/field/DatePicker.d.ts +61 -0
- package/dist/solid/src/components/form-control/field/DatePicker.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/field/DateTimePicker.d.ts +58 -0
- package/dist/solid/src/components/form-control/field/DateTimePicker.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/field/Field.styles.d.ts +13 -0
- package/dist/solid/src/components/form-control/field/Field.styles.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/field/NumberInput.d.ts +47 -0
- package/dist/solid/src/components/form-control/field/NumberInput.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/field/TextInput.d.ts +51 -0
- package/dist/solid/src/components/form-control/field/TextInput.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/field/Textarea.d.ts +42 -0
- package/dist/solid/src/components/form-control/field/Textarea.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/field/TimePicker.d.ts +46 -0
- package/dist/solid/src/components/form-control/field/TimePicker.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/numpad/Numpad.d.ts +28 -0
- package/dist/solid/src/components/form-control/numpad/Numpad.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/select/Select.d.ts +104 -0
- package/dist/solid/src/components/form-control/select/Select.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/select/SelectContext.d.ts +14 -0
- package/dist/solid/src/components/form-control/select/SelectContext.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/select/SelectItem.d.ts +33 -0
- package/dist/solid/src/components/form-control/select/SelectItem.d.ts.map +1 -0
- package/dist/solid/src/components/form-control/state-preset/StatePreset.d.ts +14 -0
- package/dist/solid/src/components/form-control/state-preset/StatePreset.d.ts.map +1 -0
- package/dist/solid/src/components/layout/FormGroup.d.ts +14 -0
- package/dist/solid/src/components/layout/FormGroup.d.ts.map +1 -0
- package/dist/solid/src/components/layout/FormTable.d.ts +5 -0
- package/dist/solid/src/components/layout/FormTable.d.ts.map +1 -0
- package/dist/solid/src/components/layout/sidebar/Sidebar.d.ts +35 -0
- package/dist/solid/src/components/layout/sidebar/Sidebar.d.ts.map +1 -0
- package/dist/solid/src/components/layout/sidebar/SidebarContainer.d.ts +34 -0
- package/dist/solid/src/components/layout/sidebar/SidebarContainer.d.ts.map +1 -0
- package/dist/solid/src/components/layout/sidebar/SidebarContext.d.ts +28 -0
- package/dist/solid/src/components/layout/sidebar/SidebarContext.d.ts.map +1 -0
- package/dist/solid/src/components/layout/sidebar/SidebarMenu.d.ts +41 -0
- package/dist/solid/src/components/layout/sidebar/SidebarMenu.d.ts.map +1 -0
- package/dist/solid/src/components/layout/sidebar/SidebarUser.d.ts +36 -0
- package/dist/solid/src/components/layout/sidebar/SidebarUser.d.ts.map +1 -0
- package/dist/solid/src/components/layout/topbar/Topbar.d.ts +35 -0
- package/dist/solid/src/components/layout/topbar/Topbar.d.ts.map +1 -0
- package/dist/solid/src/components/layout/topbar/TopbarContainer.d.ts +25 -0
- package/dist/solid/src/components/layout/topbar/TopbarContainer.d.ts.map +1 -0
- package/dist/solid/src/components/layout/topbar/TopbarMenu.d.ts +41 -0
- package/dist/solid/src/components/layout/topbar/TopbarMenu.d.ts.map +1 -0
- package/dist/solid/src/components/layout/topbar/TopbarUser.d.ts +35 -0
- package/dist/solid/src/components/layout/topbar/TopbarUser.d.ts.map +1 -0
- package/dist/solid/src/directives/ripple.d.ts +24 -0
- package/dist/solid/src/directives/ripple.d.ts.map +1 -0
- package/dist/solid/src/helpers/createAppStructure.d.ts +52 -0
- package/dist/solid/src/helpers/createAppStructure.d.ts.map +1 -0
- package/dist/solid/src/helpers/mergeStyles.d.ts +27 -0
- package/dist/solid/src/helpers/mergeStyles.d.ts.map +1 -0
- package/dist/solid/src/helpers/splitSlots.d.ts +25 -0
- package/dist/solid/src/helpers/splitSlots.d.ts.map +1 -0
- package/dist/solid/src/hooks/createControllableSignal.d.ts +40 -0
- package/dist/solid/src/hooks/createControllableSignal.d.ts.map +1 -0
- package/dist/solid/src/hooks/createIMEHandler.d.ts +20 -0
- package/dist/solid/src/hooks/createIMEHandler.d.ts.map +1 -0
- package/dist/solid/src/hooks/createMountTransition.d.ts +14 -0
- package/dist/solid/src/hooks/createMountTransition.d.ts.map +1 -0
- package/dist/solid/src/hooks/useClipboardValueCopy.d.ts +15 -0
- package/dist/solid/src/hooks/useClipboardValueCopy.d.ts.map +1 -0
- package/dist/solid/src/hooks/usePersisted.d.ts +26 -0
- package/dist/solid/src/hooks/usePersisted.d.ts.map +1 -0
- package/dist/solid/src/hooks/usePrint.d.ts +11 -0
- package/dist/solid/src/hooks/usePrint.d.ts.map +1 -0
- package/dist/solid/src/hooks/useRouterLink.d.ts +38 -0
- package/dist/solid/src/hooks/useRouterLink.d.ts.map +1 -0
- package/dist/solid/src/index.d.ts +85 -0
- package/dist/solid/src/index.d.ts.map +1 -0
- package/dist/solid/src/providers/ConfigContext.d.ts +48 -0
- package/dist/solid/src/providers/ConfigContext.d.ts.map +1 -0
- package/dist/solid/src/providers/InitializeProvider.d.ts +23 -0
- package/dist/solid/src/providers/InitializeProvider.d.ts.map +1 -0
- package/dist/solid/src/providers/ServiceClientContext.d.ts +10 -0
- package/dist/solid/src/providers/ServiceClientContext.d.ts.map +1 -0
- package/dist/solid/src/providers/ServiceClientProvider.d.ts +3 -0
- package/dist/solid/src/providers/ServiceClientProvider.d.ts.map +1 -0
- package/dist/solid/src/providers/ThemeContext.d.ts +65 -0
- package/dist/solid/src/providers/ThemeContext.d.ts.map +1 -0
- package/dist/solid/src/providers/shared-data/SharedDataChangeEvent.d.ts +8 -0
- package/dist/solid/src/providers/shared-data/SharedDataChangeEvent.d.ts.map +1 -0
- package/dist/solid/src/providers/shared-data/SharedDataContext.d.ts +22 -0
- package/dist/solid/src/providers/shared-data/SharedDataContext.d.ts.map +1 -0
- package/dist/solid/src/providers/shared-data/SharedDataProvider.d.ts +9 -0
- package/dist/solid/src/providers/shared-data/SharedDataProvider.d.ts.map +1 -0
- package/dist/solid/src/styles/patterns.styles.d.ts +6 -0
- package/dist/solid/src/styles/patterns.styles.d.ts.map +1 -0
- package/dist/solid/src/styles/tokens.styles.d.ts +20 -0
- package/dist/solid/src/styles/tokens.styles.d.ts.map +1 -0
- package/dist/styles/patterns.styles.js +30 -0
- package/dist/styles/patterns.styles.js.map +7 -0
- package/dist/styles/tokens.styles.js +72 -0
- package/dist/styles/tokens.styles.js.map +7 -0
- package/package.json +60 -0
- 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
|
+
}
|