shad-m 1.0.2 → 1.0.3
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/dist/assets/Animation/index.js +180 -0
- package/dist/assets/Animation/index.js.map +1 -0
- package/dist/assets/Animation/index.mjs +79 -0
- package/dist/assets/Animation/index.mjs.map +1 -0
- package/dist/assets/Icon/index.js +2102 -0
- package/dist/assets/Icon/index.js.map +1 -0
- package/dist/assets/Icon/index.mjs +421 -0
- package/dist/assets/Icon/index.mjs.map +1 -0
- package/dist/assets/Image/index.js +755 -0
- package/dist/assets/Image/index.js.map +1 -0
- package/dist/assets/Image/index.mjs +150 -0
- package/dist/assets/Image/index.mjs.map +1 -0
- package/dist/common/display/countdown.js +68 -0
- package/dist/common/display/countdown.js.map +1 -0
- package/dist/common/display/countdown.mjs +46 -0
- package/dist/common/display/countdown.mjs.map +1 -0
- package/dist/common/display/display-field-group.js +91 -0
- package/dist/common/display/display-field-group.js.map +1 -0
- package/dist/common/display/display-field-group.mjs +89 -0
- package/dist/common/display/display-field-group.mjs.map +1 -0
- package/dist/common/display/display-field.js +46 -0
- package/dist/common/display/display-field.js.map +1 -0
- package/dist/common/display/display-field.mjs +40 -0
- package/dist/common/display/display-field.mjs.map +1 -0
- package/dist/common/display/display-html-string.js +52 -0
- package/dist/common/display/display-html-string.js.map +1 -0
- package/dist/common/display/display-html-string.mjs +30 -0
- package/dist/common/display/display-html-string.mjs.map +1 -0
- package/dist/common/display/index.js +59 -0
- package/dist/common/display/index.js.map +1 -0
- package/dist/common/display/index.mjs +10 -0
- package/dist/common/display/index.mjs.map +1 -0
- package/dist/common/display/page-breadcrumb.js +43 -0
- package/dist/common/display/page-breadcrumb.js.map +1 -0
- package/dist/common/display/page-breadcrumb.mjs +37 -0
- package/dist/common/display/page-breadcrumb.mjs.map +1 -0
- package/dist/common/display/page-v2.js +58 -0
- package/dist/common/display/page-v2.js.map +1 -0
- package/dist/common/display/page-v2.mjs +20 -0
- package/dist/common/display/page-v2.mjs.map +1 -0
- package/dist/common/display/page.js +155 -0
- package/dist/common/display/page.js.map +1 -0
- package/dist/common/display/page.mjs +138 -0
- package/dist/common/display/page.mjs.map +1 -0
- package/dist/common/display/score-meter.js +161 -0
- package/dist/common/display/score-meter.js.map +1 -0
- package/dist/common/display/score-meter.mjs +140 -0
- package/dist/common/display/score-meter.mjs.map +1 -0
- package/dist/common/display/sidebar/app-sidebar.js +114 -0
- package/dist/common/display/sidebar/app-sidebar.js.map +1 -0
- package/dist/common/display/sidebar/app-sidebar.mjs +92 -0
- package/dist/common/display/sidebar/app-sidebar.mjs.map +1 -0
- package/dist/common/display/sidebar/index.js +89 -0
- package/dist/common/display/sidebar/index.js.map +1 -0
- package/dist/common/display/sidebar/index.mjs +81 -0
- package/dist/common/display/sidebar/index.mjs.map +1 -0
- package/dist/common/display/sidebar/nav-main.js +406 -0
- package/dist/common/display/sidebar/nav-main.js.map +1 -0
- package/dist/common/display/sidebar/nav-main.mjs +400 -0
- package/dist/common/display/sidebar/nav-main.mjs.map +1 -0
- package/dist/common/display/sidebar/sidebar-sheet.js +140 -0
- package/dist/common/display/sidebar/sidebar-sheet.js.map +1 -0
- package/dist/common/display/sidebar/sidebar-sheet.mjs +118 -0
- package/dist/common/display/sidebar/sidebar-sheet.mjs.map +1 -0
- package/dist/common/display/sidebar/types.js +4 -0
- package/dist/common/display/sidebar/types.js.map +1 -0
- package/dist/common/display/sidebar/types.mjs +3 -0
- package/dist/common/display/sidebar/types.mjs.map +1 -0
- package/dist/common/display/status-state.js +97 -0
- package/dist/common/display/status-state.js.map +1 -0
- package/dist/common/display/status-state.mjs +88 -0
- package/dist/common/display/status-state.mjs.map +1 -0
- package/dist/common/forms/auto-form.js +101 -0
- package/dist/common/forms/auto-form.js.map +1 -0
- package/dist/common/forms/auto-form.mjs +78 -0
- package/dist/common/forms/auto-form.mjs.map +1 -0
- package/dist/common/forms/form-field.js +58 -0
- package/dist/common/forms/form-field.js.map +1 -0
- package/dist/common/forms/form-field.mjs +56 -0
- package/dist/common/forms/form-field.mjs.map +1 -0
- package/dist/common/forms/form-input-field.js +64 -0
- package/dist/common/forms/form-input-field.js.map +1 -0
- package/dist/common/forms/form-input-field.mjs +62 -0
- package/dist/common/forms/form-input-field.mjs.map +1 -0
- package/dist/common/forms/index.js +22 -0
- package/dist/common/forms/index.js.map +1 -0
- package/dist/common/forms/index.mjs +5 -0
- package/dist/common/forms/index.mjs.map +1 -0
- package/dist/common/forms/switch-field.js +106 -0
- package/dist/common/forms/switch-field.js.map +1 -0
- package/dist/common/forms/switch-field.mjs +104 -0
- package/dist/common/forms/switch-field.mjs.map +1 -0
- package/dist/common/interactive/alert-dialog-wrapper.js +141 -0
- package/dist/common/interactive/alert-dialog-wrapper.js.map +1 -0
- package/dist/common/interactive/alert-dialog-wrapper.mjs +119 -0
- package/dist/common/interactive/alert-dialog-wrapper.mjs.map +1 -0
- package/dist/common/interactive/autocomplete.js +178 -0
- package/dist/common/interactive/autocomplete.js.map +1 -0
- package/dist/common/interactive/autocomplete.mjs +157 -0
- package/dist/common/interactive/autocomplete.mjs.map +1 -0
- package/dist/common/interactive/copy-tooltip.js +152 -0
- package/dist/common/interactive/copy-tooltip.js.map +1 -0
- package/dist/common/interactive/copy-tooltip.mjs +143 -0
- package/dist/common/interactive/copy-tooltip.mjs.map +1 -0
- package/dist/common/interactive/date-field.js +303 -0
- package/dist/common/interactive/date-field.js.map +1 -0
- package/dist/common/interactive/date-field.mjs +281 -0
- package/dist/common/interactive/date-field.mjs.map +1 -0
- package/dist/common/interactive/date-input/date-input.js +68 -0
- package/dist/common/interactive/date-input/date-input.js.map +1 -0
- package/dist/common/interactive/date-input/date-input.mjs +62 -0
- package/dist/common/interactive/date-input/date-input.mjs.map +1 -0
- package/dist/common/interactive/date-input/index.js +17 -0
- package/dist/common/interactive/date-input/index.js.map +1 -0
- package/dist/common/interactive/date-input/index.mjs +4 -0
- package/dist/common/interactive/date-input/index.mjs.map +1 -0
- package/dist/common/interactive/date-input/types.js +4 -0
- package/dist/common/interactive/date-input/types.js.map +1 -0
- package/dist/common/interactive/date-input/types.mjs +3 -0
- package/dist/common/interactive/date-input/types.mjs.map +1 -0
- package/dist/common/interactive/date-input/use-typed-date.js +478 -0
- package/dist/common/interactive/date-input/use-typed-date.js.map +1 -0
- package/dist/common/interactive/date-input/use-typed-date.mjs +476 -0
- package/dist/common/interactive/date-input/use-typed-date.mjs.map +1 -0
- package/dist/common/interactive/date-input/utils.js +34 -0
- package/dist/common/interactive/date-input/utils.js.map +1 -0
- package/dist/common/interactive/date-input/utils.mjs +29 -0
- package/dist/common/interactive/date-input/utils.mjs.map +1 -0
- package/dist/common/interactive/date-picker.js +616 -0
- package/dist/common/interactive/date-picker.js.map +1 -0
- package/dist/common/interactive/date-picker.mjs +594 -0
- package/dist/common/interactive/date-picker.mjs.map +1 -0
- package/dist/common/interactive/date-range-input/date-range-input.js +82 -0
- package/dist/common/interactive/date-range-input/date-range-input.js.map +1 -0
- package/dist/common/interactive/date-range-input/date-range-input.mjs +76 -0
- package/dist/common/interactive/date-range-input/date-range-input.mjs.map +1 -0
- package/dist/common/interactive/date-range-input/index.js +12 -0
- package/dist/common/interactive/date-range-input/index.js.map +1 -0
- package/dist/common/interactive/date-range-input/index.mjs +3 -0
- package/dist/common/interactive/date-range-input/index.mjs.map +1 -0
- package/dist/common/interactive/date-range-input/types.js +4 -0
- package/dist/common/interactive/date-range-input/types.js.map +1 -0
- package/dist/common/interactive/date-range-input/types.mjs +3 -0
- package/dist/common/interactive/date-range-input/types.mjs.map +1 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.js +602 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.js.map +1 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.mjs +600 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.mjs.map +1 -0
- package/dist/common/interactive/date-time-picker.js +215 -0
- package/dist/common/interactive/date-time-picker.js.map +1 -0
- package/dist/common/interactive/date-time-picker.mjs +213 -0
- package/dist/common/interactive/date-time-picker.mjs.map +1 -0
- package/dist/common/interactive/dialog-wrapper.js +124 -0
- package/dist/common/interactive/dialog-wrapper.js.map +1 -0
- package/dist/common/interactive/dialog-wrapper.mjs +102 -0
- package/dist/common/interactive/dialog-wrapper.mjs.map +1 -0
- package/dist/common/interactive/filter.js +287 -0
- package/dist/common/interactive/filter.js.map +1 -0
- package/dist/common/interactive/filter.mjs +280 -0
- package/dist/common/interactive/filter.mjs.map +1 -0
- package/dist/common/interactive/index.js +235 -0
- package/dist/common/interactive/index.js.map +1 -0
- package/dist/common/interactive/index.mjs +24 -0
- package/dist/common/interactive/index.mjs.map +1 -0
- package/dist/common/interactive/list.js +160 -0
- package/dist/common/interactive/list.js.map +1 -0
- package/dist/common/interactive/list.mjs +134 -0
- package/dist/common/interactive/list.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/index.js +35 -0
- package/dist/common/interactive/otp-dialog/index.js.map +1 -0
- package/dist/common/interactive/otp-dialog/index.mjs +6 -0
- package/dist/common/interactive/otp-dialog/index.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.js +325 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.js.map +1 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.mjs +303 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/reducer.js +40 -0
- package/dist/common/interactive/otp-dialog/reducer.js.map +1 -0
- package/dist/common/interactive/otp-dialog/reducer.mjs +37 -0
- package/dist/common/interactive/otp-dialog/reducer.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/types.js +15 -0
- package/dist/common/interactive/otp-dialog/types.js.map +1 -0
- package/dist/common/interactive/otp-dialog/types.mjs +13 -0
- package/dist/common/interactive/otp-dialog/types.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/utils.js +24 -0
- package/dist/common/interactive/otp-dialog/utils.js.map +1 -0
- package/dist/common/interactive/otp-dialog/utils.mjs +21 -0
- package/dist/common/interactive/otp-dialog/utils.mjs.map +1 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.js +51 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.js.map +1 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.mjs +49 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.mjs.map +1 -0
- package/dist/common/interactive/pagination/index.js +235 -0
- package/dist/common/interactive/pagination/index.js.map +1 -0
- package/dist/common/interactive/pagination/index.mjs +223 -0
- package/dist/common/interactive/pagination/index.mjs.map +1 -0
- package/dist/common/interactive/pagination/usePagination.js +28 -0
- package/dist/common/interactive/pagination/usePagination.js.map +1 -0
- package/dist/common/interactive/pagination/usePagination.mjs +25 -0
- package/dist/common/interactive/pagination/usePagination.mjs.map +1 -0
- package/dist/common/interactive/popover-wrapper.js +138 -0
- package/dist/common/interactive/popover-wrapper.js.map +1 -0
- package/dist/common/interactive/popover-wrapper.mjs +116 -0
- package/dist/common/interactive/popover-wrapper.mjs.map +1 -0
- package/dist/common/interactive/pressable.js +84 -0
- package/dist/common/interactive/pressable.js.map +1 -0
- package/dist/common/interactive/pressable.mjs +62 -0
- package/dist/common/interactive/pressable.mjs.map +1 -0
- package/dist/common/interactive/select/context.js +38 -0
- package/dist/common/interactive/select/context.js.map +1 -0
- package/dist/common/interactive/select/context.mjs +14 -0
- package/dist/common/interactive/select/context.mjs.map +1 -0
- package/dist/common/interactive/select/index.js +123 -0
- package/dist/common/interactive/select/index.js.map +1 -0
- package/dist/common/interactive/select/index.mjs +18 -0
- package/dist/common/interactive/select/index.mjs.map +1 -0
- package/dist/common/interactive/select/select-body.js +89 -0
- package/dist/common/interactive/select/select-body.js.map +1 -0
- package/dist/common/interactive/select/select-body.mjs +67 -0
- package/dist/common/interactive/select/select-body.mjs.map +1 -0
- package/dist/common/interactive/select/select-close.js +38 -0
- package/dist/common/interactive/select/select-close.js.map +1 -0
- package/dist/common/interactive/select/select-close.mjs +16 -0
- package/dist/common/interactive/select/select-close.mjs.map +1 -0
- package/dist/common/interactive/select/select-content-auto-layout.js +221 -0
- package/dist/common/interactive/select/select-content-auto-layout.js.map +1 -0
- package/dist/common/interactive/select/select-content-auto-layout.mjs +199 -0
- package/dist/common/interactive/select/select-content-auto-layout.mjs.map +1 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.js +411 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.js.map +1 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.mjs +389 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.mjs.map +1 -0
- package/dist/common/interactive/select/select-content.js +187 -0
- package/dist/common/interactive/select/select-content.js.map +1 -0
- package/dist/common/interactive/select/select-content.mjs +165 -0
- package/dist/common/interactive/select/select-content.mjs.map +1 -0
- package/dist/common/interactive/select/select-footer.js +82 -0
- package/dist/common/interactive/select/select-footer.js.map +1 -0
- package/dist/common/interactive/select/select-footer.mjs +60 -0
- package/dist/common/interactive/select/select-footer.mjs.map +1 -0
- package/dist/common/interactive/select/select-item.js +214 -0
- package/dist/common/interactive/select/select-item.js.map +1 -0
- package/dist/common/interactive/select/select-item.mjs +191 -0
- package/dist/common/interactive/select/select-item.mjs.map +1 -0
- package/dist/common/interactive/select/select-layout.js +66 -0
- package/dist/common/interactive/select/select-layout.js.map +1 -0
- package/dist/common/interactive/select/select-layout.mjs +41 -0
- package/dist/common/interactive/select/select-layout.mjs.map +1 -0
- package/dist/common/interactive/select/select-search.js +55 -0
- package/dist/common/interactive/select/select-search.js.map +1 -0
- package/dist/common/interactive/select/select-search.mjs +33 -0
- package/dist/common/interactive/select/select-search.mjs.map +1 -0
- package/dist/common/interactive/select/select-states.js +57 -0
- package/dist/common/interactive/select/select-states.js.map +1 -0
- package/dist/common/interactive/select/select-states.mjs +34 -0
- package/dist/common/interactive/select/select-states.mjs.map +1 -0
- package/dist/common/interactive/select/select-trigger.js +310 -0
- package/dist/common/interactive/select/select-trigger.js.map +1 -0
- package/dist/common/interactive/select/select-trigger.mjs +286 -0
- package/dist/common/interactive/select/select-trigger.mjs.map +1 -0
- package/dist/common/interactive/select/select-value.js +52 -0
- package/dist/common/interactive/select/select-value.js.map +1 -0
- package/dist/common/interactive/select/select-value.mjs +30 -0
- package/dist/common/interactive/select/select-value.mjs.map +1 -0
- package/dist/common/interactive/select/select.js +184 -0
- package/dist/common/interactive/select/select.js.map +1 -0
- package/dist/common/interactive/select/select.mjs +162 -0
- package/dist/common/interactive/select/select.mjs.map +1 -0
- package/dist/common/interactive/select/types.js +4 -0
- package/dist/common/interactive/select/types.js.map +1 -0
- package/dist/common/interactive/select/types.mjs +3 -0
- package/dist/common/interactive/select/types.mjs.map +1 -0
- package/dist/common/interactive/select/utils.js +31 -0
- package/dist/common/interactive/select/utils.js.map +1 -0
- package/dist/common/interactive/select/utils.mjs +28 -0
- package/dist/common/interactive/select/utils.mjs.map +1 -0
- package/dist/common/interactive/select/variants.js +27 -0
- package/dist/common/interactive/select/variants.js.map +1 -0
- package/dist/common/interactive/select/variants.mjs +25 -0
- package/dist/common/interactive/select/variants.mjs.map +1 -0
- package/dist/common/interactive/select-chip.js +76 -0
- package/dist/common/interactive/select-chip.js.map +1 -0
- package/dist/common/interactive/select-chip.mjs +74 -0
- package/dist/common/interactive/select-chip.mjs.map +1 -0
- package/dist/common/interactive/select-level.js +236 -0
- package/dist/common/interactive/select-level.js.map +1 -0
- package/dist/common/interactive/select-level.mjs +230 -0
- package/dist/common/interactive/select-level.mjs.map +1 -0
- package/dist/common/interactive/select-range.js +211 -0
- package/dist/common/interactive/select-range.js.map +1 -0
- package/dist/common/interactive/select-range.mjs +209 -0
- package/dist/common/interactive/select-range.mjs.map +1 -0
- package/dist/common/interactive/select-with-api.js +767 -0
- package/dist/common/interactive/select-with-api.js.map +1 -0
- package/dist/common/interactive/select-with-api.mjs +758 -0
- package/dist/common/interactive/select-with-api.mjs.map +1 -0
- package/dist/common/interactive/select.js +15 -0
- package/dist/common/interactive/select.js.map +1 -0
- package/dist/common/interactive/select.mjs +4 -0
- package/dist/common/interactive/select.mjs.map +1 -0
- package/dist/common/interactive/sheet-wrapper.js +105 -0
- package/dist/common/interactive/sheet-wrapper.js.map +1 -0
- package/dist/common/interactive/sheet-wrapper.mjs +83 -0
- package/dist/common/interactive/sheet-wrapper.mjs.map +1 -0
- package/dist/common/interactive/table/enhanced-table.js +390 -0
- package/dist/common/interactive/table/enhanced-table.js.map +1 -0
- package/dist/common/interactive/table/enhanced-table.mjs +388 -0
- package/dist/common/interactive/table/enhanced-table.mjs.map +1 -0
- package/dist/common/interactive/table/index.js +83 -0
- package/dist/common/interactive/table/index.js.map +1 -0
- package/dist/common/interactive/table/index.mjs +68 -0
- package/dist/common/interactive/table/index.mjs.map +1 -0
- package/dist/common/interactive/table/table-pagination.js +12 -0
- package/dist/common/interactive/table/table-pagination.js.map +1 -0
- package/dist/common/interactive/table/table-pagination.mjs +10 -0
- package/dist/common/interactive/table/table-pagination.mjs.map +1 -0
- package/dist/common/interactive/table/types.js +4 -0
- package/dist/common/interactive/table/types.js.map +1 -0
- package/dist/common/interactive/table/types.mjs +3 -0
- package/dist/common/interactive/table/types.mjs.map +1 -0
- package/dist/common/interactive/time-picker.js +313 -0
- package/dist/common/interactive/time-picker.js.map +1 -0
- package/dist/common/interactive/time-picker.mjs +307 -0
- package/dist/common/interactive/time-picker.mjs.map +1 -0
- package/dist/common/interactive/types.js +4 -0
- package/dist/common/interactive/types.js.map +1 -0
- package/dist/common/interactive/types.mjs +3 -0
- package/dist/common/interactive/types.mjs.map +1 -0
- package/dist/common/pages/page-404.js +16 -0
- package/dist/common/pages/page-404.js.map +1 -0
- package/dist/common/pages/page-404.mjs +11 -0
- package/dist/common/pages/page-404.mjs.map +1 -0
- package/dist/common/pages/page-500.js +30 -0
- package/dist/common/pages/page-500.js.map +1 -0
- package/dist/common/pages/page-500.mjs +25 -0
- package/dist/common/pages/page-500.mjs.map +1 -0
- package/dist/components/accordion.js +65 -0
- package/dist/components/accordion.js.map +1 -0
- package/dist/components/accordion.mjs +39 -0
- package/dist/components/accordion.mjs.map +1 -0
- package/dist/components/alert-dialog.js +231 -0
- package/dist/components/alert-dialog.js.map +1 -0
- package/dist/components/alert-dialog.mjs +197 -0
- package/dist/components/alert-dialog.mjs.map +1 -0
- package/dist/components/alert.js +97 -0
- package/dist/components/alert.js.map +1 -0
- package/dist/components/alert.mjs +72 -0
- package/dist/components/alert.mjs.map +1 -0
- package/dist/components/aspect-ratio.js +29 -0
- package/dist/components/aspect-ratio.js.map +1 -0
- package/dist/components/aspect-ratio.mjs +7 -0
- package/dist/components/aspect-ratio.mjs.map +1 -0
- package/dist/components/avatar.js +64 -0
- package/dist/components/avatar.js.map +1 -0
- package/dist/components/avatar.mjs +39 -0
- package/dist/components/avatar.mjs.map +1 -0
- package/dist/components/badge.js +72 -0
- package/dist/components/badge.js.map +1 -0
- package/dist/components/badge.mjs +69 -0
- package/dist/components/badge.mjs.map +1 -0
- package/dist/components/breadcrumb.js +109 -0
- package/dist/components/breadcrumb.js.map +1 -0
- package/dist/components/breadcrumb.mjs +81 -0
- package/dist/components/breadcrumb.mjs.map +1 -0
- package/dist/components/button.js +250 -0
- package/dist/components/button.js.map +1 -0
- package/dist/components/button.mjs +226 -0
- package/dist/components/button.mjs.map +1 -0
- package/dist/components/calendar.js +681 -0
- package/dist/components/calendar.js.map +1 -0
- package/dist/components/calendar.mjs +659 -0
- package/dist/components/calendar.mjs.map +1 -0
- package/dist/components/card.js +98 -0
- package/dist/components/card.js.map +1 -0
- package/dist/components/card.mjs +71 -0
- package/dist/components/card.mjs.map +1 -0
- package/dist/components/carousel.js +237 -0
- package/dist/components/carousel.js.map +1 -0
- package/dist/components/carousel.mjs +208 -0
- package/dist/components/carousel.mjs.map +1 -0
- package/dist/components/chart.js +252 -0
- package/dist/components/chart.js.map +1 -0
- package/dist/components/chart.mjs +224 -0
- package/dist/components/chart.mjs.map +1 -0
- package/dist/components/checkbox.js +97 -0
- package/dist/components/checkbox.js.map +1 -0
- package/dist/components/checkbox.mjs +74 -0
- package/dist/components/checkbox.mjs.map +1 -0
- package/dist/components/chip.js +88 -0
- package/dist/components/chip.js.map +1 -0
- package/dist/components/chip.mjs +82 -0
- package/dist/components/chip.mjs.map +1 -0
- package/dist/components/collapsible.js +33 -0
- package/dist/components/collapsible.js.map +1 -0
- package/dist/components/collapsible.mjs +9 -0
- package/dist/components/collapsible.mjs.map +1 -0
- package/dist/components/command.js +125 -0
- package/dist/components/command.js.map +1 -0
- package/dist/components/command.mjs +95 -0
- package/dist/components/command.mjs.map +1 -0
- package/dist/components/context-menu.js +168 -0
- package/dist/components/context-menu.js.map +1 -0
- package/dist/components/context-menu.mjs +131 -0
- package/dist/components/context-menu.mjs.map +1 -0
- package/dist/components/dialog.js +192 -0
- package/dist/components/dialog.js.map +1 -0
- package/dist/components/dialog.mjs +159 -0
- package/dist/components/dialog.mjs.map +1 -0
- package/dist/components/drawer.js +98 -0
- package/dist/components/drawer.js.map +1 -0
- package/dist/components/drawer.mjs +67 -0
- package/dist/components/drawer.mjs.map +1 -0
- package/dist/components/dropdown-menu.js +163 -0
- package/dist/components/dropdown-menu.js.map +1 -0
- package/dist/components/dropdown-menu.mjs +126 -0
- package/dist/components/dropdown-menu.mjs.map +1 -0
- package/dist/components/form.js +123 -0
- package/dist/components/form.js.map +1 -0
- package/dist/components/form.mjs +94 -0
- package/dist/components/form.mjs.map +1 -0
- package/dist/components/hover-card.js +50 -0
- package/dist/components/hover-card.js.map +1 -0
- package/dist/components/hover-card.mjs +25 -0
- package/dist/components/hover-card.mjs.map +1 -0
- package/dist/components/input-otp.js +84 -0
- package/dist/components/input-otp.js.map +1 -0
- package/dist/components/input-otp.mjs +59 -0
- package/dist/components/input-otp.mjs.map +1 -0
- package/dist/components/input.js +858 -0
- package/dist/components/input.js.map +1 -0
- package/dist/components/input.mjs +831 -0
- package/dist/components/input.mjs.map +1 -0
- package/dist/components/label.js +38 -0
- package/dist/components/label.js.map +1 -0
- package/dist/components/label.mjs +15 -0
- package/dist/components/label.mjs.map +1 -0
- package/dist/components/lottie.js +59 -0
- package/dist/components/lottie.js.map +1 -0
- package/dist/components/lottie.mjs +49 -0
- package/dist/components/lottie.mjs.map +1 -0
- package/dist/components/menubar.js +195 -0
- package/dist/components/menubar.js.map +1 -0
- package/dist/components/menubar.mjs +157 -0
- package/dist/components/menubar.mjs.map +1 -0
- package/dist/components/navigation-menu.js +126 -0
- package/dist/components/navigation-menu.js.map +1 -0
- package/dist/components/navigation-menu.mjs +95 -0
- package/dist/components/navigation-menu.mjs.map +1 -0
- package/dist/components/pagination.js +112 -0
- package/dist/components/pagination.js.map +1 -0
- package/dist/components/pagination.mjs +84 -0
- package/dist/components/pagination.mjs.map +1 -0
- package/dist/components/popover.js +63 -0
- package/dist/components/popover.js.map +1 -0
- package/dist/components/popover.mjs +38 -0
- package/dist/components/popover.mjs.map +1 -0
- package/dist/components/progress.js +50 -0
- package/dist/components/progress.js.map +1 -0
- package/dist/components/progress.mjs +27 -0
- package/dist/components/progress.mjs.map +1 -0
- package/dist/components/radio-group.js +91 -0
- package/dist/components/radio-group.js.map +1 -0
- package/dist/components/radio-group.mjs +67 -0
- package/dist/components/radio-group.mjs.map +1 -0
- package/dist/components/resizable.js +59 -0
- package/dist/components/resizable.js.map +1 -0
- package/dist/components/resizable.mjs +35 -0
- package/dist/components/resizable.mjs.map +1 -0
- package/dist/components/responsive-popover.js +74 -0
- package/dist/components/responsive-popover.js.map +1 -0
- package/dist/components/responsive-popover.mjs +50 -0
- package/dist/components/responsive-popover.mjs.map +1 -0
- package/dist/components/scroll-area.js +63 -0
- package/dist/components/scroll-area.js.map +1 -0
- package/dist/components/scroll-area.mjs +39 -0
- package/dist/components/scroll-area.mjs.map +1 -0
- package/dist/components/separator.js +47 -0
- package/dist/components/separator.js.map +1 -0
- package/dist/components/separator.mjs +24 -0
- package/dist/components/separator.mjs.map +1 -0
- package/dist/components/sheet.js +239 -0
- package/dist/components/sheet.js.map +1 -0
- package/dist/components/sheet.mjs +206 -0
- package/dist/components/sheet.mjs.map +1 -0
- package/dist/components/sidebar.js +888 -0
- package/dist/components/sidebar.js.map +1 -0
- package/dist/components/sidebar.mjs +842 -0
- package/dist/components/sidebar.mjs.map +1 -0
- package/dist/components/skeleton.js +153 -0
- package/dist/components/skeleton.js.map +1 -0
- package/dist/components/skeleton.mjs +127 -0
- package/dist/components/skeleton.mjs.map +1 -0
- package/dist/components/slider.js +45 -0
- package/dist/components/slider.js.map +1 -0
- package/dist/components/slider.mjs +22 -0
- package/dist/components/slider.mjs.map +1 -0
- package/dist/components/sonner.js +76 -0
- package/dist/components/sonner.js.map +1 -0
- package/dist/components/sonner.mjs +71 -0
- package/dist/components/sonner.mjs.map +1 -0
- package/dist/components/spinner.js +59 -0
- package/dist/components/spinner.js.map +1 -0
- package/dist/components/spinner.mjs +36 -0
- package/dist/components/spinner.mjs.map +1 -0
- package/dist/components/stepper.js +726 -0
- package/dist/components/stepper.js.map +1 -0
- package/dist/components/stepper.mjs +702 -0
- package/dist/components/stepper.mjs.map +1 -0
- package/dist/components/switch.js +85 -0
- package/dist/components/switch.js.map +1 -0
- package/dist/components/switch.mjs +62 -0
- package/dist/components/switch.mjs.map +1 -0
- package/dist/components/table.js +91 -0
- package/dist/components/table.js.map +1 -0
- package/dist/components/table.mjs +62 -0
- package/dist/components/table.mjs.map +1 -0
- package/dist/components/tabs.js +287 -0
- package/dist/components/tabs.js.map +1 -0
- package/dist/components/tabs.mjs +261 -0
- package/dist/components/tabs.mjs.map +1 -0
- package/dist/components/textarea.js +200 -0
- package/dist/components/textarea.js.map +1 -0
- package/dist/components/textarea.mjs +174 -0
- package/dist/components/textarea.mjs.map +1 -0
- package/dist/components/toggle-group.js +67 -0
- package/dist/components/toggle-group.js.map +1 -0
- package/dist/components/toggle-group.mjs +43 -0
- package/dist/components/toggle-group.mjs.map +1 -0
- package/dist/components/toggle.js +63 -0
- package/dist/components/toggle.js.map +1 -0
- package/dist/components/toggle.mjs +39 -0
- package/dist/components/toggle.mjs.map +1 -0
- package/dist/components/tooltip.js +172 -0
- package/dist/components/tooltip.js.map +1 -0
- package/dist/components/tooltip.mjs +145 -0
- package/dist/components/tooltip.mjs.map +1 -0
- package/dist/hooks/index.js +27 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/index.mjs +6 -0
- package/dist/hooks/index.mjs.map +1 -0
- package/dist/hooks/useCopyToClipboard.js +59 -0
- package/dist/hooks/useCopyToClipboard.js.map +1 -0
- package/dist/hooks/useCopyToClipboard.mjs +57 -0
- package/dist/hooks/useCopyToClipboard.mjs.map +1 -0
- package/dist/hooks/useDevice.js +20 -0
- package/dist/hooks/useDevice.js.map +1 -0
- package/dist/hooks/useDevice.mjs +14 -0
- package/dist/hooks/useDevice.mjs.map +1 -0
- package/dist/hooks/useDialogTracking.js +113 -0
- package/dist/hooks/useDialogTracking.js.map +1 -0
- package/dist/hooks/useDialogTracking.mjs +91 -0
- package/dist/hooks/useDialogTracking.mjs.map +1 -0
- package/dist/hooks/useIsMounted.js +15 -0
- package/dist/hooks/useIsMounted.js.map +1 -0
- package/dist/hooks/useIsMounted.mjs +13 -0
- package/dist/hooks/useIsMounted.mjs.map +1 -0
- package/dist/hooks/usePathname.js +85 -0
- package/dist/hooks/usePathname.js.map +1 -0
- package/dist/hooks/usePathname.mjs +83 -0
- package/dist/hooks/usePathname.mjs.map +1 -0
- package/dist/icons.js +14 -0
- package/dist/icons.js.map +1 -0
- package/dist/icons.mjs +3 -0
- package/dist/icons.mjs.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +403 -8151
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +62 -7844
- package/dist/index.mjs.map +1 -1
- package/dist/lib/formatCurrency.js +187 -0
- package/dist/lib/formatCurrency.js.map +1 -0
- package/dist/lib/formatCurrency.mjs +185 -0
- package/dist/lib/formatCurrency.mjs.map +1 -0
- package/dist/lib/helpers.js +171 -0
- package/dist/lib/helpers.js.map +1 -0
- package/dist/lib/helpers.mjs +157 -0
- package/dist/lib/helpers.mjs.map +1 -0
- package/dist/lib/index.js +33 -0
- package/dist/lib/index.js.map +1 -0
- package/dist/lib/index.mjs +6 -0
- package/dist/lib/index.mjs.map +1 -0
- package/dist/lib/types.js +11 -0
- package/dist/lib/types.js.map +1 -0
- package/dist/lib/types.mjs +9 -0
- package/dist/lib/types.mjs.map +1 -0
- package/dist/lib/utils.js +24 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/lib/utils.mjs +19 -0
- package/dist/lib/utils.mjs.map +1 -0
- package/dist/providers/DeviceSizeWatcher/index.js +72 -0
- package/dist/providers/DeviceSizeWatcher/index.js.map +1 -0
- package/dist/providers/DeviceSizeWatcher/index.mjs +47 -0
- package/dist/providers/DeviceSizeWatcher/index.mjs.map +1 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.js +22 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.js.map +1 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.mjs +20 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.mjs.map +1 -0
- package/dist/providers/UISystemProvider.js +197 -0
- package/dist/providers/UISystemProvider.js.map +1 -0
- package/dist/providers/UISystemProvider.mjs +188 -0
- package/dist/providers/UISystemProvider.mjs.map +1 -0
- package/dist/providers/index.js +24 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/providers/index.mjs +3 -0
- package/dist/providers/index.mjs.map +1 -0
- package/dist/theme.js +333 -0
- package/dist/theme.js.map +1 -0
- package/dist/theme.mjs +327 -0
- package/dist/theme.mjs.map +1 -0
- package/package.json +1 -1
- package/dist/index.css +0 -43
- package/dist/index.css.map +0 -1
|
@@ -0,0 +1,303 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
4
|
+
var input = require('@/components/input');
|
|
5
|
+
var icons = require('@/icons');
|
|
6
|
+
var utils = require('@/lib/utils');
|
|
7
|
+
var dateFns = require('date-fns');
|
|
8
|
+
var locale = require('date-fns/locale');
|
|
9
|
+
var React = require('react');
|
|
10
|
+
|
|
11
|
+
function _interopNamespace(e) {
|
|
12
|
+
if (e && e.__esModule) return e;
|
|
13
|
+
var n = Object.create(null);
|
|
14
|
+
if (e) {
|
|
15
|
+
Object.keys(e).forEach(function (k) {
|
|
16
|
+
if (k !== 'default') {
|
|
17
|
+
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
18
|
+
Object.defineProperty(n, k, d.get ? d : {
|
|
19
|
+
enumerable: true,
|
|
20
|
+
get: function () { return e[k]; }
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
n.default = e;
|
|
26
|
+
return Object.freeze(n);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
var React__namespace = /*#__PURE__*/_interopNamespace(React);
|
|
30
|
+
|
|
31
|
+
const parseStringToDate = (dateStr, format2 = "dd/MM/yyyy") => {
|
|
32
|
+
if (!dateStr) return null;
|
|
33
|
+
try {
|
|
34
|
+
const parsedDate = dateFns.parse(dateStr, format2, /* @__PURE__ */ new Date());
|
|
35
|
+
return dateFns.isValid(parsedDate) ? parsedDate : null;
|
|
36
|
+
} catch (error) {
|
|
37
|
+
return null;
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
const getDateValue = (value, format2 = "dd/MM/yyyy") => {
|
|
41
|
+
if (!value) return null;
|
|
42
|
+
if (typeof value === "string") return parseStringToDate(value, format2);
|
|
43
|
+
return value instanceof Date ? value : null;
|
|
44
|
+
};
|
|
45
|
+
const formatDateToString = (date, dateFormat = "dd/MM/yyyy") => {
|
|
46
|
+
if (!date || !dateFns.isValid(date)) return "";
|
|
47
|
+
try {
|
|
48
|
+
return dateFns.format(date, dateFormat, { locale: locale.vi });
|
|
49
|
+
} catch (error) {
|
|
50
|
+
return "";
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
const formatDateInput = (input) => {
|
|
54
|
+
const digitsOnly = input.replace(/\D/g, "");
|
|
55
|
+
if (digitsOnly.length <= 2) {
|
|
56
|
+
return digitsOnly;
|
|
57
|
+
} else if (digitsOnly.length <= 4) {
|
|
58
|
+
return `${digitsOnly.slice(0, 2)}/${digitsOnly.slice(2)}`;
|
|
59
|
+
} else if (digitsOnly.length <= 8) {
|
|
60
|
+
return `${digitsOnly.slice(0, 2)}/${digitsOnly.slice(2, 4)}/${digitsOnly.slice(4)}`;
|
|
61
|
+
} else {
|
|
62
|
+
return `${digitsOnly.slice(0, 2)}/${digitsOnly.slice(2, 4)}/${digitsOnly.slice(4, 8)}`;
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
const validateDateInput = (input, dateFormat = "dd/MM/yyyy", minDate, maxDate, strictValidation = false) => {
|
|
66
|
+
if (!input) return { isValid: true };
|
|
67
|
+
if (strictValidation && input.length !== 10) {
|
|
68
|
+
return { isValid: false, error: "Vui l\xF2ng nh\u1EADp \u0111\u1EA7y \u0111\u1EE7 ng\xE0y th\xE1ng (dd/MM/yyyy)" };
|
|
69
|
+
}
|
|
70
|
+
if (input.length < 10) {
|
|
71
|
+
return { isValid: true };
|
|
72
|
+
}
|
|
73
|
+
const parts = input.split("/");
|
|
74
|
+
if (parts.length !== 3) {
|
|
75
|
+
return { isValid: false, error: "\u0110\u1ECBnh d\u1EA1ng ng\xE0y kh\xF4ng h\u1EE3p l\u1EC7" };
|
|
76
|
+
}
|
|
77
|
+
const day = parseInt(parts[0] || "0", 10);
|
|
78
|
+
const month = parseInt(parts[1] || "0", 10);
|
|
79
|
+
const year = parseInt(parts[2] || "0", 10);
|
|
80
|
+
if (isNaN(day) || day < 1 || day > 31) {
|
|
81
|
+
return { isValid: false, error: "Ng\xE0y ph\u1EA3i t\u1EEB 01 \u0111\u1EBFn 31" };
|
|
82
|
+
}
|
|
83
|
+
if (isNaN(month) || month < 1 || month > 12) {
|
|
84
|
+
return { isValid: false, error: "Th\xE1ng ph\u1EA3i t\u1EEB 01 \u0111\u1EBFn 12" };
|
|
85
|
+
}
|
|
86
|
+
if (isNaN(year) || year < 1900 || year > 2099) {
|
|
87
|
+
return { isValid: false, error: "N\u0103m ph\u1EA3i t\u1EEB 1900 \u0111\u1EBFn 2099" };
|
|
88
|
+
}
|
|
89
|
+
const date = new Date(year, month - 1, day);
|
|
90
|
+
if (date.getFullYear() !== year || date.getMonth() !== month - 1 || date.getDate() !== day) {
|
|
91
|
+
return { isValid: false, error: "Ng\xE0y kh\xF4ng t\u1ED3n t\u1EA1i" };
|
|
92
|
+
}
|
|
93
|
+
if (minDate && date < minDate) {
|
|
94
|
+
return {
|
|
95
|
+
isValid: false,
|
|
96
|
+
error: `Ng\xE0y kh\xF4ng \u0111\u01B0\u1EE3c nh\u1ECF h\u01A1n ${formatDateToString(minDate, dateFormat)}`
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
if (maxDate && date > maxDate) {
|
|
100
|
+
return {
|
|
101
|
+
isValid: false,
|
|
102
|
+
error: `Ng\xE0y kh\xF4ng \u0111\u01B0\u1EE3c l\u1EDBn h\u01A1n ${formatDateToString(maxDate, dateFormat)}`
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
return { isValid: true };
|
|
106
|
+
};
|
|
107
|
+
const DateField = React__namespace.forwardRef(
|
|
108
|
+
({
|
|
109
|
+
value,
|
|
110
|
+
defaultValue,
|
|
111
|
+
onChange,
|
|
112
|
+
onInputChange,
|
|
113
|
+
placeholder = "dd/MM/yyyy",
|
|
114
|
+
label,
|
|
115
|
+
disabled = false,
|
|
116
|
+
isError = false,
|
|
117
|
+
errorText,
|
|
118
|
+
helpText,
|
|
119
|
+
size = "default",
|
|
120
|
+
className,
|
|
121
|
+
inputClassName,
|
|
122
|
+
minDate,
|
|
123
|
+
maxDate,
|
|
124
|
+
showCalendarIcon = true,
|
|
125
|
+
showClearButton = true,
|
|
126
|
+
format: dateFormat = "dd/MM/yyyy",
|
|
127
|
+
strictValidation = false,
|
|
128
|
+
style,
|
|
129
|
+
onCalendarIconClick,
|
|
130
|
+
onClearValue,
|
|
131
|
+
onInputClick,
|
|
132
|
+
...props
|
|
133
|
+
}, ref) => {
|
|
134
|
+
const initialDate = getDateValue(value || defaultValue, dateFormat);
|
|
135
|
+
const initialInputValue = formatDateToString(initialDate, dateFormat);
|
|
136
|
+
const [inputValue, setInputValue] = React__namespace.useState(initialInputValue);
|
|
137
|
+
const [internalError, setInternalError] = React__namespace.useState("");
|
|
138
|
+
const [isFocused, setIsFocused] = React__namespace.useState(false);
|
|
139
|
+
React__namespace.useEffect(() => {
|
|
140
|
+
const dateValue = getDateValue(value, dateFormat);
|
|
141
|
+
const formattedValue = formatDateToString(dateValue, dateFormat);
|
|
142
|
+
setInputValue(formattedValue);
|
|
143
|
+
}, [value, dateFormat]);
|
|
144
|
+
const handleInputChange = React__namespace.useCallback(
|
|
145
|
+
(e) => {
|
|
146
|
+
const rawValue = e.target.value;
|
|
147
|
+
const formattedValue = formatDateInput(rawValue);
|
|
148
|
+
setInputValue(formattedValue);
|
|
149
|
+
onInputChange?.(formattedValue);
|
|
150
|
+
const validation = validateDateInput(
|
|
151
|
+
formattedValue,
|
|
152
|
+
dateFormat,
|
|
153
|
+
minDate,
|
|
154
|
+
maxDate,
|
|
155
|
+
strictValidation
|
|
156
|
+
);
|
|
157
|
+
if (validation.isValid) {
|
|
158
|
+
setInternalError("");
|
|
159
|
+
if (formattedValue.length === 10) {
|
|
160
|
+
const parsedDate = parseStringToDate(formattedValue, dateFormat);
|
|
161
|
+
if (parsedDate) {
|
|
162
|
+
onChange?.(parsedDate);
|
|
163
|
+
} else {
|
|
164
|
+
onChange?.(null);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
} else {
|
|
168
|
+
setInternalError(validation.error || "");
|
|
169
|
+
if (formattedValue.length === 10) {
|
|
170
|
+
onChange?.(null);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
},
|
|
174
|
+
[onChange, onInputChange, dateFormat, minDate, maxDate, strictValidation]
|
|
175
|
+
);
|
|
176
|
+
const handleInputClick = React__namespace.useCallback(
|
|
177
|
+
(e) => {
|
|
178
|
+
const input = e.currentTarget;
|
|
179
|
+
if (!input || !inputValue) {
|
|
180
|
+
onInputClick?.();
|
|
181
|
+
return;
|
|
182
|
+
}
|
|
183
|
+
const cursorPosition = input.selectionStart || 0;
|
|
184
|
+
let selectionStart = 0;
|
|
185
|
+
let selectionEnd = 0;
|
|
186
|
+
if (cursorPosition <= 2) {
|
|
187
|
+
selectionStart = 0;
|
|
188
|
+
selectionEnd = 2;
|
|
189
|
+
} else if (cursorPosition <= 5) {
|
|
190
|
+
selectionStart = 3;
|
|
191
|
+
selectionEnd = 5;
|
|
192
|
+
} else {
|
|
193
|
+
selectionStart = 6;
|
|
194
|
+
selectionEnd = 10;
|
|
195
|
+
}
|
|
196
|
+
setTimeout(() => {
|
|
197
|
+
input.setSelectionRange(selectionStart, selectionEnd);
|
|
198
|
+
}, 0);
|
|
199
|
+
onInputClick?.();
|
|
200
|
+
},
|
|
201
|
+
[inputValue, onInputClick]
|
|
202
|
+
);
|
|
203
|
+
const handleFocus = React__namespace.useCallback(
|
|
204
|
+
(e) => {
|
|
205
|
+
setIsFocused(true);
|
|
206
|
+
if (inputValue) {
|
|
207
|
+
const input = e.currentTarget;
|
|
208
|
+
setTimeout(() => {
|
|
209
|
+
input.setSelectionRange(0, 2);
|
|
210
|
+
}, 0);
|
|
211
|
+
}
|
|
212
|
+
},
|
|
213
|
+
[inputValue]
|
|
214
|
+
);
|
|
215
|
+
const handleBlur = React__namespace.useCallback(() => {
|
|
216
|
+
setIsFocused(false);
|
|
217
|
+
if (inputValue) {
|
|
218
|
+
const validation = validateDateInput(inputValue, dateFormat, minDate, maxDate, true);
|
|
219
|
+
if (!validation.isValid) {
|
|
220
|
+
setInternalError(validation.error || "");
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}, [inputValue, dateFormat, minDate, maxDate]);
|
|
224
|
+
const handleClear = React__namespace.useCallback(() => {
|
|
225
|
+
setInputValue("");
|
|
226
|
+
setInternalError("");
|
|
227
|
+
onChange?.(null);
|
|
228
|
+
onInputChange?.("");
|
|
229
|
+
onClearValue?.();
|
|
230
|
+
}, [onChange, onInputChange, onClearValue]);
|
|
231
|
+
const handleKeyPress = React__namespace.useCallback((e) => {
|
|
232
|
+
if (!/[\d/]/.test(e.key) && !["Backspace", "Delete", "ArrowLeft", "ArrowRight", "Tab"].includes(e.key)) {
|
|
233
|
+
e.preventDefault();
|
|
234
|
+
}
|
|
235
|
+
}, []);
|
|
236
|
+
const handleKeyDown = React__namespace.useCallback(
|
|
237
|
+
(e) => {
|
|
238
|
+
const input = e.currentTarget;
|
|
239
|
+
const cursorPosition = input.selectionStart || 0;
|
|
240
|
+
const selectionLength = (input.selectionEnd || 0) - (input.selectionStart || 0);
|
|
241
|
+
const isSegmentSelected = selectionLength > 0;
|
|
242
|
+
if (e.key === "ArrowLeft" && isSegmentSelected) {
|
|
243
|
+
e.preventDefault();
|
|
244
|
+
if (cursorPosition <= 2) {
|
|
245
|
+
input.setSelectionRange(6, 10);
|
|
246
|
+
} else if (cursorPosition <= 5) {
|
|
247
|
+
input.setSelectionRange(0, 2);
|
|
248
|
+
} else {
|
|
249
|
+
input.setSelectionRange(3, 5);
|
|
250
|
+
}
|
|
251
|
+
} else if (e.key === "ArrowRight" && isSegmentSelected) {
|
|
252
|
+
e.preventDefault();
|
|
253
|
+
if (cursorPosition <= 2) {
|
|
254
|
+
input.setSelectionRange(3, 5);
|
|
255
|
+
} else if (cursorPosition <= 5) {
|
|
256
|
+
input.setSelectionRange(6, 10);
|
|
257
|
+
} else {
|
|
258
|
+
input.setSelectionRange(0, 2);
|
|
259
|
+
}
|
|
260
|
+
} else {
|
|
261
|
+
handleKeyPress(e);
|
|
262
|
+
}
|
|
263
|
+
},
|
|
264
|
+
[handleKeyPress]
|
|
265
|
+
);
|
|
266
|
+
const hasError = isError || !!internalError;
|
|
267
|
+
const displayErrorText = errorText || internalError;
|
|
268
|
+
const displayHelpText = isFocused && !hasError ? helpText || `\u0110\u1ECBnh d\u1EA1ng: ${dateFormat.toLowerCase()}` : helpText;
|
|
269
|
+
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
270
|
+
input.Input,
|
|
271
|
+
{
|
|
272
|
+
ref,
|
|
273
|
+
type: "text",
|
|
274
|
+
value: inputValue,
|
|
275
|
+
onChange: handleInputChange,
|
|
276
|
+
onFocus: handleFocus,
|
|
277
|
+
onBlur: handleBlur,
|
|
278
|
+
onKeyDown: handleKeyDown,
|
|
279
|
+
onClick: handleInputClick,
|
|
280
|
+
placeholder,
|
|
281
|
+
label,
|
|
282
|
+
disabled,
|
|
283
|
+
isError: hasError,
|
|
284
|
+
errorText: displayErrorText,
|
|
285
|
+
helpText: displayHelpText,
|
|
286
|
+
size,
|
|
287
|
+
className: utils.cn("w-full", className),
|
|
288
|
+
inputClassName: utils.cn("font-mono w-full min-w-0 flex-1", inputClassName),
|
|
289
|
+
showRemoveIcon: showClearButton && !!inputValue && !disabled,
|
|
290
|
+
onClearValue: handleClear,
|
|
291
|
+
buttonIcon: showCalendarIcon ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: "cursor-pointer", "data-calendar-icon": true, children: /* @__PURE__ */ jsxRuntime.jsx(icons.CalendarOutlinedIcon, { className: "h-5 w-5" }) }) : void 0,
|
|
292
|
+
maxLength: 10,
|
|
293
|
+
style: { width: "100%", ...style },
|
|
294
|
+
...props
|
|
295
|
+
}
|
|
296
|
+
);
|
|
297
|
+
}
|
|
298
|
+
);
|
|
299
|
+
DateField.displayName = "DateField";
|
|
300
|
+
|
|
301
|
+
exports.DateField = DateField;
|
|
302
|
+
//# sourceMappingURL=date-field.js.map
|
|
303
|
+
//# sourceMappingURL=date-field.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/common/interactive/date-field.tsx"],"names":["format","parse","isValid","vi","React","jsx","Input","cn","CalendarOutlinedIcon"],"mappings":"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","file":"date-field.js","sourcesContent":["'use client';\n\nimport { Input } from '@/components/input';\nimport { CalendarOutlinedIcon } from '@/icons';\nimport { cn } from '@/lib/utils';\nimport { format, isValid, parse } from 'date-fns';\nimport { vi } from 'date-fns/locale';\nimport * as React from 'react';\n\nexport interface DateFieldProps {\n /**\n * The selected date value\n * Can be a Date object or a string in 'dd/MM/yyyy' format\n */\n value?: Date | string | null;\n\n /**\n * Default date value\n */\n defaultValue?: Date | string;\n\n /**\n * Callback fired when the date value changes\n */\n onChange?: (date: Date | null) => void;\n\n /**\n * Callback fired when the input value changes (raw string)\n */\n onInputChange?: (value: string) => void;\n\n /**\n * Input placeholder\n */\n placeholder?: string;\n\n /**\n * Input label\n */\n label?: string;\n\n /**\n * Whether the input is disabled\n */\n disabled?: boolean;\n\n /**\n * Whether the input is in error state\n */\n isError?: boolean;\n\n /**\n * Error message to display\n */\n errorText?: string;\n\n /**\n * Help text to display\n */\n helpText?: string;\n\n /**\n * Input size\n */\n size?: 'default' | 'lg';\n\n /**\n * Additional CSS classes\n */\n className?: string;\n\n /**\n * Input CSS classes\n */\n inputClassName?: string;\n\n /**\n * Minimum date allowed\n */\n minDate?: Date;\n\n /**\n * Maximum date allowed\n */\n maxDate?: Date;\n\n /**\n * Whether to show calendar icon\n */\n showCalendarIcon?: boolean;\n\n /**\n * Whether to show clear button\n */\n showClearButton?: boolean;\n\n /**\n * Custom date format (default: 'dd/MM/yyyy')\n */\n format?: string;\n\n /**\n * Whether to enable strict validation\n */\n strictValidation?: boolean;\n\n /**\n * Inline styles\n */\n style?: React.CSSProperties;\n\n /**\n * Callback when calendar icon is clicked\n */\n onCalendarIconClick?: () => void;\n\n /**\n * Callback when clear button is clicked\n */\n onClearValue?: () => void;\n\n /**\n * Callback when input is clicked\n */\n onInputClick?: () => void;\n}\n\n/**\n * Converts a date string in dd/MM/yyyy format to a Date object\n */\nconst parseStringToDate = (dateStr: string, format: string = 'dd/MM/yyyy'): Date | null => {\n if (!dateStr) return null;\n try {\n const parsedDate = parse(dateStr, format, new Date());\n return isValid(parsedDate) ? parsedDate : null;\n } catch (error) {\n return null;\n }\n};\n\n/**\n * Gets a Date object from either a Date or a string\n */\nconst getDateValue = (\n value: Date | string | null | undefined,\n format: string = 'dd/MM/yyyy',\n): Date | null => {\n if (!value) return null;\n if (typeof value === 'string') return parseStringToDate(value, format);\n return value instanceof Date ? value : null;\n};\n\n/**\n * Formats a date to string\n */\nconst formatDateToString = (date: Date | null, dateFormat: string = 'dd/MM/yyyy'): string => {\n if (!date || !isValid(date)) return '';\n try {\n return format(date, dateFormat, { locale: vi });\n } catch (error) {\n return '';\n }\n};\n\n/**\n * Smart date input formatter that handles partial input\n */\nconst formatDateInput = (input: string): string => {\n // Remove all non-digit characters\n const digitsOnly = input.replace(/\\D/g, '');\n\n // Apply dd/MM/yyyy format progressively\n if (digitsOnly.length <= 2) {\n return digitsOnly;\n } else if (digitsOnly.length <= 4) {\n return `${digitsOnly.slice(0, 2)}/${digitsOnly.slice(2)}`;\n } else if (digitsOnly.length <= 8) {\n return `${digitsOnly.slice(0, 2)}/${digitsOnly.slice(2, 4)}/${digitsOnly.slice(4)}`;\n } else {\n // Limit to 8 digits (ddMMyyyy)\n return `${digitsOnly.slice(0, 2)}/${digitsOnly.slice(2, 4)}/${digitsOnly.slice(4, 8)}`;\n }\n};\n\n/**\n * Validate date input with strict rules\n */\nconst validateDateInput = (\n input: string,\n dateFormat: string = 'dd/MM/yyyy',\n minDate?: Date,\n maxDate?: Date,\n strictValidation: boolean = false,\n): { isValid: boolean; error?: string } => {\n if (!input) return { isValid: true };\n\n // Check if input is complete (dd/MM/yyyy = 10 characters)\n if (strictValidation && input.length !== 10) {\n return { isValid: false, error: 'Vui lòng nhập đầy đủ ngày tháng (dd/MM/yyyy)' };\n }\n\n // For incomplete input, don't show error yet\n if (input.length < 10) {\n return { isValid: true };\n }\n\n // Parse components manually for strict validation\n const parts = input.split('/');\n if (parts.length !== 3) {\n return { isValid: false, error: 'Định dạng ngày không hợp lệ' };\n }\n\n const day = parseInt(parts[0] || '0', 10);\n const month = parseInt(parts[1] || '0', 10);\n const year = parseInt(parts[2] || '0', 10);\n\n // Validate ranges\n if (isNaN(day) || day < 1 || day > 31) {\n return { isValid: false, error: 'Ngày phải từ 01 đến 31' };\n }\n\n if (isNaN(month) || month < 1 || month > 12) {\n return { isValid: false, error: 'Tháng phải từ 01 đến 12' };\n }\n\n if (isNaN(year) || year < 1900 || year > 2099) {\n return { isValid: false, error: 'Năm phải từ 1900 đến 2099' };\n }\n\n // Check if date is valid (e.g., 31/02/2023 is invalid)\n const date = new Date(year, month - 1, day);\n if (date.getFullYear() !== year || date.getMonth() !== month - 1 || date.getDate() !== day) {\n return { isValid: false, error: 'Ngày không tồn tại' };\n }\n\n // Check min date\n if (minDate && date < minDate) {\n return {\n isValid: false,\n error: `Ngày không được nhỏ hơn ${formatDateToString(minDate, dateFormat)}`,\n };\n }\n\n // Check max date\n if (maxDate && date > maxDate) {\n return {\n isValid: false,\n error: `Ngày không được lớn hơn ${formatDateToString(maxDate, dateFormat)}`,\n };\n }\n\n return { isValid: true };\n};\n\nexport const DateField = React.forwardRef<HTMLInputElement, DateFieldProps>(\n (\n {\n value,\n defaultValue,\n onChange,\n onInputChange,\n placeholder = 'dd/MM/yyyy',\n label,\n disabled = false,\n isError = false,\n errorText,\n helpText,\n size = 'default',\n className,\n inputClassName,\n minDate,\n maxDate,\n showCalendarIcon = true,\n showClearButton = true,\n format: dateFormat = 'dd/MM/yyyy',\n strictValidation = false,\n style,\n onCalendarIconClick,\n onClearValue,\n onInputClick,\n\n ...props\n },\n ref,\n ) => {\n // Convert initial value to date\n const initialDate = getDateValue(value || defaultValue, dateFormat);\n const initialInputValue = formatDateToString(initialDate, dateFormat);\n\n // Internal state\n const [inputValue, setInputValue] = React.useState(initialInputValue);\n const [internalError, setInternalError] = React.useState<string>('');\n const [isFocused, setIsFocused] = React.useState(false);\n\n // Update input value when external value changes\n React.useEffect(() => {\n const dateValue = getDateValue(value, dateFormat);\n const formattedValue = formatDateToString(dateValue, dateFormat);\n setInputValue(formattedValue);\n }, [value, dateFormat]);\n\n // Handle input change\n const handleInputChange = React.useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n const rawValue = e.target.value;\n const formattedValue = formatDateInput(rawValue);\n\n setInputValue(formattedValue);\n onInputChange?.(formattedValue);\n\n // Validate and parse date\n const validation = validateDateInput(\n formattedValue,\n dateFormat,\n minDate,\n maxDate,\n strictValidation,\n );\n\n if (validation.isValid) {\n setInternalError('');\n\n // Only parse and set date if input is complete (10 characters)\n if (formattedValue.length === 10) {\n const parsedDate = parseStringToDate(formattedValue, dateFormat);\n if (parsedDate) {\n onChange?.(parsedDate);\n } else {\n // Only clear if the complete input is invalid\n onChange?.(null);\n }\n }\n // Don't clear date for incomplete input - let user continue typing\n } else {\n setInternalError(validation.error || '');\n // Only call onChange with null for complete invalid dates\n if (formattedValue.length === 10) {\n onChange?.(null);\n }\n }\n },\n [onChange, onInputChange, dateFormat, minDate, maxDate, strictValidation],\n );\n\n // Handle input click - segmented selection based on cursor position\n const handleInputClick = React.useCallback(\n (e: React.MouseEvent<HTMLInputElement>) => {\n const input = e.currentTarget;\n if (!input || !inputValue) {\n // Call external onClick handler if provided\n onInputClick?.();\n return;\n }\n\n // Get cursor position\n const cursorPosition = input.selectionStart || 0;\n\n // Determine which segment to select based on cursor position\n // Format: dd/MM/yyyy (10 characters)\n // Positions: 01/34/6789\n let selectionStart = 0;\n let selectionEnd = 0;\n\n if (cursorPosition <= 2) {\n // Day segment (positions 0-1)\n selectionStart = 0;\n selectionEnd = 2;\n } else if (cursorPosition <= 5) {\n // Month segment (positions 3-4)\n selectionStart = 3;\n selectionEnd = 5;\n } else {\n // Year segment (positions 6-9)\n selectionStart = 6;\n selectionEnd = 10;\n }\n\n // Select the segment\n setTimeout(() => {\n input.setSelectionRange(selectionStart, selectionEnd);\n }, 0);\n\n // Call external onClick handler if provided\n onInputClick?.();\n },\n [inputValue, onInputClick],\n );\n\n // Handle focus with segmented selection\n const handleFocus = React.useCallback(\n (e: React.FocusEvent<HTMLInputElement>) => {\n setIsFocused(true);\n\n // Select first segment (day) when focusing\n if (inputValue) {\n const input = e.currentTarget;\n // Use setTimeout to ensure selection happens after focus\n setTimeout(() => {\n input.setSelectionRange(0, 2); // Select day segment\n }, 0);\n }\n },\n [inputValue],\n );\n\n // Handle blur\n const handleBlur = React.useCallback(() => {\n setIsFocused(false);\n\n // On blur, validate more strictly\n if (inputValue) {\n const validation = validateDateInput(inputValue, dateFormat, minDate, maxDate, true);\n if (!validation.isValid) {\n setInternalError(validation.error || '');\n }\n }\n }, [inputValue, dateFormat, minDate, maxDate]);\n\n // Handle clear\n const handleClear = React.useCallback(() => {\n setInputValue('');\n setInternalError('');\n onChange?.(null);\n onInputChange?.('');\n onClearValue?.();\n }, [onChange, onInputChange, onClearValue]);\n\n // Handle key press\n const handleKeyPress = React.useCallback((e: React.KeyboardEvent<HTMLInputElement>) => {\n // Allow only digits and forward slash\n if (\n !/[\\d/]/.test(e.key) &&\n !['Backspace', 'Delete', 'ArrowLeft', 'ArrowRight', 'Tab'].includes(e.key)\n ) {\n e.preventDefault();\n }\n }, []);\n\n // Handle key down for segment navigation\n const handleKeyDown = React.useCallback(\n (e: React.KeyboardEvent<HTMLInputElement>) => {\n const input = e.currentTarget;\n const cursorPosition = input.selectionStart || 0;\n const selectionLength = (input.selectionEnd || 0) - (input.selectionStart || 0);\n\n // Check if we have a segment selected\n const isSegmentSelected = selectionLength > 0;\n\n if (e.key === 'ArrowLeft' && isSegmentSelected) {\n e.preventDefault();\n // Move to previous segment\n if (cursorPosition <= 2) {\n // At day segment, go to year segment (wrap around)\n input.setSelectionRange(6, 10);\n } else if (cursorPosition <= 5) {\n // At month segment, go to day\n input.setSelectionRange(0, 2);\n } else {\n // At year segment, go to month\n input.setSelectionRange(3, 5);\n }\n } else if (e.key === 'ArrowRight' && isSegmentSelected) {\n e.preventDefault();\n // Move to next segment\n if (cursorPosition <= 2) {\n // At day segment, go to month\n input.setSelectionRange(3, 5);\n } else if (cursorPosition <= 5) {\n // At month segment, go to year\n input.setSelectionRange(6, 10);\n } else {\n // At year segment, go to day (wrap around)\n input.setSelectionRange(0, 2);\n }\n } else {\n // Call original key press handler for other keys\n handleKeyPress(e);\n }\n },\n [handleKeyPress],\n );\n\n // Determine error state and message\n const hasError = isError || !!internalError;\n const displayErrorText = errorText || internalError;\n\n // Show help text with format hint when focused and no error\n const displayHelpText =\n isFocused && !hasError ? helpText || `Định dạng: ${dateFormat.toLowerCase()}` : helpText;\n\n return (\n <Input\n ref={ref}\n type=\"text\"\n value={inputValue}\n onChange={handleInputChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n onKeyDown={handleKeyDown}\n onClick={handleInputClick}\n placeholder={placeholder}\n label={label}\n disabled={disabled}\n isError={hasError}\n errorText={displayErrorText}\n helpText={displayHelpText}\n size={size}\n className={cn('w-full', className)}\n inputClassName={cn('font-mono w-full min-w-0 flex-1', inputClassName)}\n showRemoveIcon={showClearButton && !!inputValue && !disabled}\n onClearValue={handleClear}\n buttonIcon={\n showCalendarIcon ? (\n <div className=\"cursor-pointer\" data-calendar-icon>\n <CalendarOutlinedIcon className=\"h-5 w-5\" />\n </div>\n ) : undefined\n }\n maxLength={10} // dd/MM/yyyy = 10 characters\n style={{ width: '100%', ...style }}\n {...props}\n />\n );\n },\n);\n\nDateField.displayName = 'DateField';\n"]}
|
|
@@ -0,0 +1,281 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { Input } from '@/components/input';
|
|
3
|
+
import { CalendarOutlinedIcon } from '@/icons';
|
|
4
|
+
import { cn } from '@/lib/utils';
|
|
5
|
+
import { isValid, format, parse } from 'date-fns';
|
|
6
|
+
import { vi } from 'date-fns/locale';
|
|
7
|
+
import * as React from 'react';
|
|
8
|
+
|
|
9
|
+
const parseStringToDate = (dateStr, format2 = "dd/MM/yyyy") => {
|
|
10
|
+
if (!dateStr) return null;
|
|
11
|
+
try {
|
|
12
|
+
const parsedDate = parse(dateStr, format2, /* @__PURE__ */ new Date());
|
|
13
|
+
return isValid(parsedDate) ? parsedDate : null;
|
|
14
|
+
} catch (error) {
|
|
15
|
+
return null;
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
const getDateValue = (value, format2 = "dd/MM/yyyy") => {
|
|
19
|
+
if (!value) return null;
|
|
20
|
+
if (typeof value === "string") return parseStringToDate(value, format2);
|
|
21
|
+
return value instanceof Date ? value : null;
|
|
22
|
+
};
|
|
23
|
+
const formatDateToString = (date, dateFormat = "dd/MM/yyyy") => {
|
|
24
|
+
if (!date || !isValid(date)) return "";
|
|
25
|
+
try {
|
|
26
|
+
return format(date, dateFormat, { locale: vi });
|
|
27
|
+
} catch (error) {
|
|
28
|
+
return "";
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
const formatDateInput = (input) => {
|
|
32
|
+
const digitsOnly = input.replace(/\D/g, "");
|
|
33
|
+
if (digitsOnly.length <= 2) {
|
|
34
|
+
return digitsOnly;
|
|
35
|
+
} else if (digitsOnly.length <= 4) {
|
|
36
|
+
return `${digitsOnly.slice(0, 2)}/${digitsOnly.slice(2)}`;
|
|
37
|
+
} else if (digitsOnly.length <= 8) {
|
|
38
|
+
return `${digitsOnly.slice(0, 2)}/${digitsOnly.slice(2, 4)}/${digitsOnly.slice(4)}`;
|
|
39
|
+
} else {
|
|
40
|
+
return `${digitsOnly.slice(0, 2)}/${digitsOnly.slice(2, 4)}/${digitsOnly.slice(4, 8)}`;
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
const validateDateInput = (input, dateFormat = "dd/MM/yyyy", minDate, maxDate, strictValidation = false) => {
|
|
44
|
+
if (!input) return { isValid: true };
|
|
45
|
+
if (strictValidation && input.length !== 10) {
|
|
46
|
+
return { isValid: false, error: "Vui l\xF2ng nh\u1EADp \u0111\u1EA7y \u0111\u1EE7 ng\xE0y th\xE1ng (dd/MM/yyyy)" };
|
|
47
|
+
}
|
|
48
|
+
if (input.length < 10) {
|
|
49
|
+
return { isValid: true };
|
|
50
|
+
}
|
|
51
|
+
const parts = input.split("/");
|
|
52
|
+
if (parts.length !== 3) {
|
|
53
|
+
return { isValid: false, error: "\u0110\u1ECBnh d\u1EA1ng ng\xE0y kh\xF4ng h\u1EE3p l\u1EC7" };
|
|
54
|
+
}
|
|
55
|
+
const day = parseInt(parts[0] || "0", 10);
|
|
56
|
+
const month = parseInt(parts[1] || "0", 10);
|
|
57
|
+
const year = parseInt(parts[2] || "0", 10);
|
|
58
|
+
if (isNaN(day) || day < 1 || day > 31) {
|
|
59
|
+
return { isValid: false, error: "Ng\xE0y ph\u1EA3i t\u1EEB 01 \u0111\u1EBFn 31" };
|
|
60
|
+
}
|
|
61
|
+
if (isNaN(month) || month < 1 || month > 12) {
|
|
62
|
+
return { isValid: false, error: "Th\xE1ng ph\u1EA3i t\u1EEB 01 \u0111\u1EBFn 12" };
|
|
63
|
+
}
|
|
64
|
+
if (isNaN(year) || year < 1900 || year > 2099) {
|
|
65
|
+
return { isValid: false, error: "N\u0103m ph\u1EA3i t\u1EEB 1900 \u0111\u1EBFn 2099" };
|
|
66
|
+
}
|
|
67
|
+
const date = new Date(year, month - 1, day);
|
|
68
|
+
if (date.getFullYear() !== year || date.getMonth() !== month - 1 || date.getDate() !== day) {
|
|
69
|
+
return { isValid: false, error: "Ng\xE0y kh\xF4ng t\u1ED3n t\u1EA1i" };
|
|
70
|
+
}
|
|
71
|
+
if (minDate && date < minDate) {
|
|
72
|
+
return {
|
|
73
|
+
isValid: false,
|
|
74
|
+
error: `Ng\xE0y kh\xF4ng \u0111\u01B0\u1EE3c nh\u1ECF h\u01A1n ${formatDateToString(minDate, dateFormat)}`
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
if (maxDate && date > maxDate) {
|
|
78
|
+
return {
|
|
79
|
+
isValid: false,
|
|
80
|
+
error: `Ng\xE0y kh\xF4ng \u0111\u01B0\u1EE3c l\u1EDBn h\u01A1n ${formatDateToString(maxDate, dateFormat)}`
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
return { isValid: true };
|
|
84
|
+
};
|
|
85
|
+
const DateField = React.forwardRef(
|
|
86
|
+
({
|
|
87
|
+
value,
|
|
88
|
+
defaultValue,
|
|
89
|
+
onChange,
|
|
90
|
+
onInputChange,
|
|
91
|
+
placeholder = "dd/MM/yyyy",
|
|
92
|
+
label,
|
|
93
|
+
disabled = false,
|
|
94
|
+
isError = false,
|
|
95
|
+
errorText,
|
|
96
|
+
helpText,
|
|
97
|
+
size = "default",
|
|
98
|
+
className,
|
|
99
|
+
inputClassName,
|
|
100
|
+
minDate,
|
|
101
|
+
maxDate,
|
|
102
|
+
showCalendarIcon = true,
|
|
103
|
+
showClearButton = true,
|
|
104
|
+
format: dateFormat = "dd/MM/yyyy",
|
|
105
|
+
strictValidation = false,
|
|
106
|
+
style,
|
|
107
|
+
onCalendarIconClick,
|
|
108
|
+
onClearValue,
|
|
109
|
+
onInputClick,
|
|
110
|
+
...props
|
|
111
|
+
}, ref) => {
|
|
112
|
+
const initialDate = getDateValue(value || defaultValue, dateFormat);
|
|
113
|
+
const initialInputValue = formatDateToString(initialDate, dateFormat);
|
|
114
|
+
const [inputValue, setInputValue] = React.useState(initialInputValue);
|
|
115
|
+
const [internalError, setInternalError] = React.useState("");
|
|
116
|
+
const [isFocused, setIsFocused] = React.useState(false);
|
|
117
|
+
React.useEffect(() => {
|
|
118
|
+
const dateValue = getDateValue(value, dateFormat);
|
|
119
|
+
const formattedValue = formatDateToString(dateValue, dateFormat);
|
|
120
|
+
setInputValue(formattedValue);
|
|
121
|
+
}, [value, dateFormat]);
|
|
122
|
+
const handleInputChange = React.useCallback(
|
|
123
|
+
(e) => {
|
|
124
|
+
const rawValue = e.target.value;
|
|
125
|
+
const formattedValue = formatDateInput(rawValue);
|
|
126
|
+
setInputValue(formattedValue);
|
|
127
|
+
onInputChange?.(formattedValue);
|
|
128
|
+
const validation = validateDateInput(
|
|
129
|
+
formattedValue,
|
|
130
|
+
dateFormat,
|
|
131
|
+
minDate,
|
|
132
|
+
maxDate,
|
|
133
|
+
strictValidation
|
|
134
|
+
);
|
|
135
|
+
if (validation.isValid) {
|
|
136
|
+
setInternalError("");
|
|
137
|
+
if (formattedValue.length === 10) {
|
|
138
|
+
const parsedDate = parseStringToDate(formattedValue, dateFormat);
|
|
139
|
+
if (parsedDate) {
|
|
140
|
+
onChange?.(parsedDate);
|
|
141
|
+
} else {
|
|
142
|
+
onChange?.(null);
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
} else {
|
|
146
|
+
setInternalError(validation.error || "");
|
|
147
|
+
if (formattedValue.length === 10) {
|
|
148
|
+
onChange?.(null);
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
},
|
|
152
|
+
[onChange, onInputChange, dateFormat, minDate, maxDate, strictValidation]
|
|
153
|
+
);
|
|
154
|
+
const handleInputClick = React.useCallback(
|
|
155
|
+
(e) => {
|
|
156
|
+
const input = e.currentTarget;
|
|
157
|
+
if (!input || !inputValue) {
|
|
158
|
+
onInputClick?.();
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
const cursorPosition = input.selectionStart || 0;
|
|
162
|
+
let selectionStart = 0;
|
|
163
|
+
let selectionEnd = 0;
|
|
164
|
+
if (cursorPosition <= 2) {
|
|
165
|
+
selectionStart = 0;
|
|
166
|
+
selectionEnd = 2;
|
|
167
|
+
} else if (cursorPosition <= 5) {
|
|
168
|
+
selectionStart = 3;
|
|
169
|
+
selectionEnd = 5;
|
|
170
|
+
} else {
|
|
171
|
+
selectionStart = 6;
|
|
172
|
+
selectionEnd = 10;
|
|
173
|
+
}
|
|
174
|
+
setTimeout(() => {
|
|
175
|
+
input.setSelectionRange(selectionStart, selectionEnd);
|
|
176
|
+
}, 0);
|
|
177
|
+
onInputClick?.();
|
|
178
|
+
},
|
|
179
|
+
[inputValue, onInputClick]
|
|
180
|
+
);
|
|
181
|
+
const handleFocus = React.useCallback(
|
|
182
|
+
(e) => {
|
|
183
|
+
setIsFocused(true);
|
|
184
|
+
if (inputValue) {
|
|
185
|
+
const input = e.currentTarget;
|
|
186
|
+
setTimeout(() => {
|
|
187
|
+
input.setSelectionRange(0, 2);
|
|
188
|
+
}, 0);
|
|
189
|
+
}
|
|
190
|
+
},
|
|
191
|
+
[inputValue]
|
|
192
|
+
);
|
|
193
|
+
const handleBlur = React.useCallback(() => {
|
|
194
|
+
setIsFocused(false);
|
|
195
|
+
if (inputValue) {
|
|
196
|
+
const validation = validateDateInput(inputValue, dateFormat, minDate, maxDate, true);
|
|
197
|
+
if (!validation.isValid) {
|
|
198
|
+
setInternalError(validation.error || "");
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
}, [inputValue, dateFormat, minDate, maxDate]);
|
|
202
|
+
const handleClear = React.useCallback(() => {
|
|
203
|
+
setInputValue("");
|
|
204
|
+
setInternalError("");
|
|
205
|
+
onChange?.(null);
|
|
206
|
+
onInputChange?.("");
|
|
207
|
+
onClearValue?.();
|
|
208
|
+
}, [onChange, onInputChange, onClearValue]);
|
|
209
|
+
const handleKeyPress = React.useCallback((e) => {
|
|
210
|
+
if (!/[\d/]/.test(e.key) && !["Backspace", "Delete", "ArrowLeft", "ArrowRight", "Tab"].includes(e.key)) {
|
|
211
|
+
e.preventDefault();
|
|
212
|
+
}
|
|
213
|
+
}, []);
|
|
214
|
+
const handleKeyDown = React.useCallback(
|
|
215
|
+
(e) => {
|
|
216
|
+
const input = e.currentTarget;
|
|
217
|
+
const cursorPosition = input.selectionStart || 0;
|
|
218
|
+
const selectionLength = (input.selectionEnd || 0) - (input.selectionStart || 0);
|
|
219
|
+
const isSegmentSelected = selectionLength > 0;
|
|
220
|
+
if (e.key === "ArrowLeft" && isSegmentSelected) {
|
|
221
|
+
e.preventDefault();
|
|
222
|
+
if (cursorPosition <= 2) {
|
|
223
|
+
input.setSelectionRange(6, 10);
|
|
224
|
+
} else if (cursorPosition <= 5) {
|
|
225
|
+
input.setSelectionRange(0, 2);
|
|
226
|
+
} else {
|
|
227
|
+
input.setSelectionRange(3, 5);
|
|
228
|
+
}
|
|
229
|
+
} else if (e.key === "ArrowRight" && isSegmentSelected) {
|
|
230
|
+
e.preventDefault();
|
|
231
|
+
if (cursorPosition <= 2) {
|
|
232
|
+
input.setSelectionRange(3, 5);
|
|
233
|
+
} else if (cursorPosition <= 5) {
|
|
234
|
+
input.setSelectionRange(6, 10);
|
|
235
|
+
} else {
|
|
236
|
+
input.setSelectionRange(0, 2);
|
|
237
|
+
}
|
|
238
|
+
} else {
|
|
239
|
+
handleKeyPress(e);
|
|
240
|
+
}
|
|
241
|
+
},
|
|
242
|
+
[handleKeyPress]
|
|
243
|
+
);
|
|
244
|
+
const hasError = isError || !!internalError;
|
|
245
|
+
const displayErrorText = errorText || internalError;
|
|
246
|
+
const displayHelpText = isFocused && !hasError ? helpText || `\u0110\u1ECBnh d\u1EA1ng: ${dateFormat.toLowerCase()}` : helpText;
|
|
247
|
+
return /* @__PURE__ */ jsx(
|
|
248
|
+
Input,
|
|
249
|
+
{
|
|
250
|
+
ref,
|
|
251
|
+
type: "text",
|
|
252
|
+
value: inputValue,
|
|
253
|
+
onChange: handleInputChange,
|
|
254
|
+
onFocus: handleFocus,
|
|
255
|
+
onBlur: handleBlur,
|
|
256
|
+
onKeyDown: handleKeyDown,
|
|
257
|
+
onClick: handleInputClick,
|
|
258
|
+
placeholder,
|
|
259
|
+
label,
|
|
260
|
+
disabled,
|
|
261
|
+
isError: hasError,
|
|
262
|
+
errorText: displayErrorText,
|
|
263
|
+
helpText: displayHelpText,
|
|
264
|
+
size,
|
|
265
|
+
className: cn("w-full", className),
|
|
266
|
+
inputClassName: cn("font-mono w-full min-w-0 flex-1", inputClassName),
|
|
267
|
+
showRemoveIcon: showClearButton && !!inputValue && !disabled,
|
|
268
|
+
onClearValue: handleClear,
|
|
269
|
+
buttonIcon: showCalendarIcon ? /* @__PURE__ */ jsx("div", { className: "cursor-pointer", "data-calendar-icon": true, children: /* @__PURE__ */ jsx(CalendarOutlinedIcon, { className: "h-5 w-5" }) }) : void 0,
|
|
270
|
+
maxLength: 10,
|
|
271
|
+
style: { width: "100%", ...style },
|
|
272
|
+
...props
|
|
273
|
+
}
|
|
274
|
+
);
|
|
275
|
+
}
|
|
276
|
+
);
|
|
277
|
+
DateField.displayName = "DateField";
|
|
278
|
+
|
|
279
|
+
export { DateField };
|
|
280
|
+
//# sourceMappingURL=date-field.mjs.map
|
|
281
|
+
//# sourceMappingURL=date-field.mjs.map
|