shad-m 1.0.0
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 +260 -0
- package/dist/assets/Animation/index.d.ts +25655 -0
- package/dist/assets/Animation/index.d.ts.map +1 -0
- 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.d.ts +420 -0
- package/dist/assets/Icon/index.d.ts.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.d.ts +151 -0
- package/dist/assets/Image/index.d.ts.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.d.ts +26 -0
- package/dist/common/display/countdown.d.ts.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.d.ts +59 -0
- package/dist/common/display/display-field-group.d.ts.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.d.ts +45 -0
- package/dist/common/display/display-field.d.ts.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.d.ts +7 -0
- package/dist/common/display/display-html-string.d.ts.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.d.ts +16 -0
- package/dist/common/display/index.d.ts.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.d.ts +19 -0
- package/dist/common/display/page-breadcrumb.d.ts.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.d.ts +15 -0
- package/dist/common/display/page-v2.d.ts.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.d.ts +53 -0
- package/dist/common/display/page.d.ts.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.d.ts +22 -0
- package/dist/common/display/score-meter.d.ts.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.d.ts +28 -0
- package/dist/common/display/sidebar/app-sidebar.d.ts.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.d.ts +30 -0
- package/dist/common/display/sidebar/index.d.ts.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.d.ts +17 -0
- package/dist/common/display/sidebar/nav-main.d.ts.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.d.ts +46 -0
- package/dist/common/display/sidebar/sidebar-sheet.d.ts.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.d.ts +18 -0
- package/dist/common/display/sidebar/types.d.ts.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.d.ts +16 -0
- package/dist/common/display/status-state.d.ts.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.d.ts +17 -0
- package/dist/common/forms/auto-form.d.ts.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.d.ts +16 -0
- package/dist/common/forms/form-field.d.ts.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.d.ts +16 -0
- package/dist/common/forms/form-input-field.d.ts.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.d.ts +7 -0
- package/dist/common/forms/index.d.ts.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.d.ts +19 -0
- package/dist/common/forms/switch-field.d.ts.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.d.ts +41 -0
- package/dist/common/interactive/alert-dialog-wrapper.d.ts.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.d.ts +21 -0
- package/dist/common/interactive/autocomplete.d.ts.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.d.ts +27 -0
- package/dist/common/interactive/copy-tooltip.d.ts.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.d.ts +98 -0
- package/dist/common/interactive/date-field.d.ts.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.d.ts +12 -0
- package/dist/common/interactive/date-input/date-input.d.ts.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.d.ts +4 -0
- package/dist/common/interactive/date-input/index.d.ts.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.d.ts +17 -0
- package/dist/common/interactive/date-input/types.d.ts.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.d.ts +17 -0
- package/dist/common/interactive/date-input/use-typed-date.d.ts.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.d.ts +5 -0
- package/dist/common/interactive/date-input/utils.d.ts.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.d.ts +114 -0
- package/dist/common/interactive/date-picker.d.ts.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.d.ts +23 -0
- package/dist/common/interactive/date-range-input/date-range-input.d.ts.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.d.ts +4 -0
- package/dist/common/interactive/date-range-input/index.d.ts.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.d.ts +35 -0
- package/dist/common/interactive/date-range-input/types.d.ts.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.d.ts +17 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.d.ts.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.d.ts +86 -0
- package/dist/common/interactive/date-time-picker.d.ts.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.d.ts +34 -0
- package/dist/common/interactive/dialog-wrapper.d.ts.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.d.ts +51 -0
- package/dist/common/interactive/filter.d.ts.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.d.ts +41 -0
- package/dist/common/interactive/index.d.ts.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.d.ts +36 -0
- package/dist/common/interactive/list.d.ts.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.d.ts +7 -0
- package/dist/common/interactive/otp-dialog/index.d.ts.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.d.ts +34 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.d.ts.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.d.ts +11 -0
- package/dist/common/interactive/otp-dialog/reducer.d.ts.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.d.ts +82 -0
- package/dist/common/interactive/otp-dialog/types.d.ts.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.d.ts +17 -0
- package/dist/common/interactive/otp-dialog/utils.d.ts.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.d.ts +6 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.d.ts.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.d.ts +14 -0
- package/dist/common/interactive/pagination/index.d.ts.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.d.ts +3 -0
- package/dist/common/interactive/pagination/usePagination.d.ts.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.d.ts +38 -0
- package/dist/common/interactive/popover-wrapper.d.ts.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.d.ts +11 -0
- package/dist/common/interactive/pressable.d.ts.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.d.ts +6 -0
- package/dist/common/interactive/select/context.d.ts.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.d.ts +18 -0
- package/dist/common/interactive/select/index.d.ts.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.d.ts +5 -0
- package/dist/common/interactive/select/select-body.d.ts.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.d.ts +3 -0
- package/dist/common/interactive/select/select-close.d.ts.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.d.ts +5 -0
- package/dist/common/interactive/select/select-content-auto-layout.d.ts.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.d.ts +5 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.d.ts.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.d.ts +5 -0
- package/dist/common/interactive/select/select-content.d.ts.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.d.ts +5 -0
- package/dist/common/interactive/select/select-footer.d.ts.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.d.ts +6 -0
- package/dist/common/interactive/select/select-item.d.ts.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.d.ts +8 -0
- package/dist/common/interactive/select/select-layout.d.ts.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.d.ts +8 -0
- package/dist/common/interactive/select/select-search.d.ts.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.d.ts +6 -0
- package/dist/common/interactive/select/select-states.d.ts.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.d.ts +7 -0
- package/dist/common/interactive/select/select-trigger.d.ts.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.d.ts +5 -0
- package/dist/common/interactive/select/select-value.d.ts.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.css +62 -0
- package/dist/common/interactive/select/select.d.ts +4 -0
- package/dist/common/interactive/select/select.d.ts.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.d.ts +213 -0
- package/dist/common/interactive/select/types.d.ts.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.d.ts +8 -0
- package/dist/common/interactive/select/utils.d.ts.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.d.ts +4 -0
- package/dist/common/interactive/select/variants.d.ts.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.d.ts +20 -0
- package/dist/common/interactive/select-chip.d.ts.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.d.ts +19 -0
- package/dist/common/interactive/select-level.d.ts.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.d.ts +30 -0
- package/dist/common/interactive/select-range.d.ts.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.d.ts +97 -0
- package/dist/common/interactive/select-with-api.d.ts.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.d.ts +3 -0
- package/dist/common/interactive/select.d.ts.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.d.ts +34 -0
- package/dist/common/interactive/sheet-wrapper.d.ts.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.d.ts +5 -0
- package/dist/common/interactive/table/enhanced-table.d.ts.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.d.ts +10 -0
- package/dist/common/interactive/table/index.d.ts.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.d.ts +5 -0
- package/dist/common/interactive/table/table-pagination.d.ts.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.d.ts +54 -0
- package/dist/common/interactive/table/types.d.ts.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.d.ts +74 -0
- package/dist/common/interactive/time-picker.d.ts.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.d.ts +2 -0
- package/dist/common/interactive/types.d.ts.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.d.ts +3 -0
- package/dist/common/pages/page-404.d.ts.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.d.ts +9 -0
- package/dist/common/pages/page-500.d.ts.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.d.ts +8 -0
- package/dist/components/accordion.d.ts.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.d.ts +33 -0
- package/dist/components/alert-dialog.d.ts.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.d.ts +13 -0
- package/dist/components/alert.d.ts.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.d.ts +4 -0
- package/dist/components/aspect-ratio.d.ts.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.d.ts +7 -0
- package/dist/components/avatar.d.ts.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.d.ts +12 -0
- package/dist/components/badge.d.ts.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.d.ts +20 -0
- package/dist/components/breadcrumb.d.ts.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.d.ts +28 -0
- package/dist/components/button.d.ts.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.d.ts +57 -0
- package/dist/components/calendar.d.ts.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.d.ts +12 -0
- package/dist/components/card.d.ts.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.d.ts +23 -0
- package/dist/components/carousel.d.ts.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.d.ts +63 -0
- package/dist/components/chart.d.ts.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.d.ts +18 -0
- package/dist/components/checkbox.d.ts.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.d.ts +30 -0
- package/dist/components/chip.d.ts.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.d.ts +6 -0
- package/dist/components/collapsible.d.ts.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.d.ts +81 -0
- package/dist/components/command.d.ts.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.d.ts +28 -0
- package/dist/components/context-menu.d.ts.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.d.ts +32 -0
- package/dist/components/dialog.d.ts.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.d.ts +23 -0
- package/dist/components/drawer.d.ts.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.d.ts +28 -0
- package/dist/components/dropdown-menu.d.ts.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.d.ts +24 -0
- package/dist/components/form.d.ts.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.d.ts +7 -0
- package/dist/components/hover-card.d.ts.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.d.ts +39 -0
- package/dist/components/input-otp.d.ts.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.d.ts +150 -0
- package/dist/components/input.d.ts.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.d.ts +6 -0
- package/dist/components/label.d.ts.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.d.ts +63 -0
- package/dist/components/lottie.d.ts.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.d.ts +29 -0
- package/dist/components/menubar.d.ts.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.d.ts +13 -0
- package/dist/components/navigation-menu.d.ts.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.d.ts +29 -0
- package/dist/components/pagination.d.ts.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.d.ts +7 -0
- package/dist/components/popover.d.ts.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.d.ts +7 -0
- package/dist/components/progress.d.ts.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.d.ts +17 -0
- package/dist/components/radio-group.d.ts.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.d.ts +24 -0
- package/dist/components/resizable.d.ts.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.d.ts +25 -0
- package/dist/components/responsive-popover.d.ts.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.d.ts +6 -0
- package/dist/components/scroll-area.d.ts.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.d.ts +5 -0
- package/dist/components/separator.d.ts.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.d.ts +29 -0
- package/dist/components/sheet.d.ts.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.d.ts +87 -0
- package/dist/components/sidebar.d.ts.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.d.ts +36 -0
- package/dist/components/skeleton.d.ts.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.d.ts +5 -0
- package/dist/components/slider.d.ts.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.d.ts +4 -0
- package/dist/components/sonner.d.ts.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.d.ts +11 -0
- package/dist/components/spinner.d.ts.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.d.ts +114 -0
- package/dist/components/stepper.d.ts.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.d.ts +16 -0
- package/dist/components/switch.d.ts.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.d.ts +11 -0
- package/dist/components/table.d.ts.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.d.ts +32 -0
- package/dist/components/tabs.d.ts.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.d.ts +21 -0
- package/dist/components/textarea.d.ts.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.d.ts +13 -0
- package/dist/components/toggle-group.d.ts.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.d.ts +13 -0
- package/dist/components/toggle.d.ts.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.d.ts +31 -0
- package/dist/components/tooltip.d.ts.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/globals.css +1179 -0
- package/dist/hooks/index.d.ts +6 -0
- package/dist/hooks/index.d.ts.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.d.ts +26 -0
- package/dist/hooks/useCopyToClipboard.d.ts.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.d.ts +7 -0
- package/dist/hooks/useDevice.d.ts.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.d.ts +17 -0
- package/dist/hooks/useDialogTracking.d.ts.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.d.ts +8 -0
- package/dist/hooks/useIsMounted.d.ts.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.d.ts +20 -0
- package/dist/hooks/usePathname.d.ts.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.d.ts +2 -0
- package/dist/icons.d.ts.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/lib/formatCurrency.d.ts +106 -0
- package/dist/lib/formatCurrency.d.ts.map +1 -0
- 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.d.ts +64 -0
- package/dist/lib/helpers.d.ts.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.d.ts +6 -0
- package/dist/lib/index.d.ts.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.d.ts +37 -0
- package/dist/lib/types.d.ts.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.d.ts +4 -0
- package/dist/lib/utils.d.ts.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.d.ts +3 -0
- package/dist/providers/DeviceSizeWatcher/index.d.ts.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.d.ts +13 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.d.ts.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.d.ts +68 -0
- package/dist/providers/UISystemProvider.d.ts.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.d.ts +3 -0
- package/dist/providers/index.d.ts.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.d.ts +10 -0
- package/dist/theme.d.ts.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 +252 -0
- package/postcss.config.mjs +6 -0
- package/tailwind.config.ts +350 -0
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import React, { useState, useCallback, useEffect } from 'react';
|
|
3
|
+
import { TooltipProvider, Tooltip, TooltipTrigger, TooltipContent, TooltipArrow } from '../../components/tooltip';
|
|
4
|
+
import { cn } from '../../lib/utils';
|
|
5
|
+
|
|
6
|
+
const CopyTooltip = React.forwardRef(
|
|
7
|
+
({
|
|
8
|
+
// Trigger props
|
|
9
|
+
trigger,
|
|
10
|
+
triggerAsChild = false,
|
|
11
|
+
triggerClassName,
|
|
12
|
+
// Tooltip behavior props
|
|
13
|
+
delayDuration = 700,
|
|
14
|
+
open: controlledOpen,
|
|
15
|
+
onOpenChange: controlledOnOpenChange,
|
|
16
|
+
defaultOpen = false,
|
|
17
|
+
disableHoverableContent = true,
|
|
18
|
+
// Arrow props
|
|
19
|
+
showArrow = true,
|
|
20
|
+
arrowClassName,
|
|
21
|
+
// Content props
|
|
22
|
+
children,
|
|
23
|
+
text,
|
|
24
|
+
responseContent = "\u0110\xE3 sao ch\xE9p",
|
|
25
|
+
contentClassName,
|
|
26
|
+
childrenClassName,
|
|
27
|
+
// Copy behavior props
|
|
28
|
+
onCopySuccess,
|
|
29
|
+
onCopyError,
|
|
30
|
+
resetDelay = 2e3,
|
|
31
|
+
// Tooltip provider props
|
|
32
|
+
skipDelayDuration = 300,
|
|
33
|
+
// Other props
|
|
34
|
+
className,
|
|
35
|
+
...props
|
|
36
|
+
}, ref) => {
|
|
37
|
+
const [internalOpen, setInternalOpen] = useState(defaultOpen);
|
|
38
|
+
const [status, setStatus] = useState("idle");
|
|
39
|
+
const isControlled = controlledOpen !== void 0;
|
|
40
|
+
const open = isControlled ? controlledOpen : internalOpen && status !== "idle";
|
|
41
|
+
const setOpen = isControlled ? controlledOnOpenChange : setInternalOpen;
|
|
42
|
+
const handleOpenChange = useCallback(
|
|
43
|
+
(newOpen) => {
|
|
44
|
+
setOpen?.(newOpen);
|
|
45
|
+
},
|
|
46
|
+
[setOpen]
|
|
47
|
+
);
|
|
48
|
+
const copyToClipboard = useCallback(
|
|
49
|
+
async (textToCopy) => {
|
|
50
|
+
try {
|
|
51
|
+
await navigator.clipboard.writeText(textToCopy);
|
|
52
|
+
setStatus("copied");
|
|
53
|
+
setInternalOpen(true);
|
|
54
|
+
onCopySuccess?.(textToCopy);
|
|
55
|
+
return true;
|
|
56
|
+
} catch (error) {
|
|
57
|
+
const err = error;
|
|
58
|
+
setStatus("failed");
|
|
59
|
+
setInternalOpen(true);
|
|
60
|
+
onCopyError?.(err);
|
|
61
|
+
console.error("Failed to copy text to clipboard:", err);
|
|
62
|
+
return false;
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
[onCopySuccess, onCopyError]
|
|
66
|
+
);
|
|
67
|
+
const handleTriggerClick = useCallback(
|
|
68
|
+
(event) => {
|
|
69
|
+
event.preventDefault();
|
|
70
|
+
if (text) {
|
|
71
|
+
copyToClipboard(text);
|
|
72
|
+
}
|
|
73
|
+
},
|
|
74
|
+
[text, copyToClipboard]
|
|
75
|
+
);
|
|
76
|
+
useEffect(() => {
|
|
77
|
+
if (status === "copied" || status === "failed") {
|
|
78
|
+
const timeout = setTimeout(() => {
|
|
79
|
+
setStatus("idle");
|
|
80
|
+
setInternalOpen(false);
|
|
81
|
+
}, resetDelay);
|
|
82
|
+
return () => clearTimeout(timeout);
|
|
83
|
+
}
|
|
84
|
+
}, [status, resetDelay]);
|
|
85
|
+
return /* @__PURE__ */ jsx(
|
|
86
|
+
TooltipProvider,
|
|
87
|
+
{
|
|
88
|
+
delayDuration,
|
|
89
|
+
skipDelayDuration,
|
|
90
|
+
disableHoverableContent,
|
|
91
|
+
children: /* @__PURE__ */ jsxs(
|
|
92
|
+
Tooltip,
|
|
93
|
+
{
|
|
94
|
+
open,
|
|
95
|
+
onOpenChange: handleOpenChange,
|
|
96
|
+
defaultOpen: false,
|
|
97
|
+
delayDuration,
|
|
98
|
+
disableHoverableContent,
|
|
99
|
+
children: [
|
|
100
|
+
trigger && /* @__PURE__ */ jsx(
|
|
101
|
+
TooltipTrigger,
|
|
102
|
+
{
|
|
103
|
+
asChild: triggerAsChild,
|
|
104
|
+
className: cn("cursor-pointer", triggerClassName),
|
|
105
|
+
onClick: handleTriggerClick,
|
|
106
|
+
children: trigger
|
|
107
|
+
}
|
|
108
|
+
),
|
|
109
|
+
children && /* @__PURE__ */ jsx(
|
|
110
|
+
TooltipTrigger,
|
|
111
|
+
{
|
|
112
|
+
asChild: triggerAsChild,
|
|
113
|
+
className: cn("cursor-pointer", triggerClassName),
|
|
114
|
+
onClick: handleTriggerClick,
|
|
115
|
+
children
|
|
116
|
+
}
|
|
117
|
+
),
|
|
118
|
+
/* @__PURE__ */ jsxs(
|
|
119
|
+
TooltipContent,
|
|
120
|
+
{
|
|
121
|
+
ref,
|
|
122
|
+
showArrow,
|
|
123
|
+
className: cn("flex flex-col px-3 py-1", className, contentClassName),
|
|
124
|
+
...props,
|
|
125
|
+
children: [
|
|
126
|
+
/* @__PURE__ */ jsx("div", { className: cn(childrenClassName), children: responseContent }),
|
|
127
|
+
showArrow && /* @__PURE__ */ jsx(TooltipArrow, { className: cn("fill-foreground !h-[5px] !w-[8px]", arrowClassName) })
|
|
128
|
+
]
|
|
129
|
+
}
|
|
130
|
+
)
|
|
131
|
+
]
|
|
132
|
+
}
|
|
133
|
+
)
|
|
134
|
+
}
|
|
135
|
+
);
|
|
136
|
+
}
|
|
137
|
+
);
|
|
138
|
+
CopyTooltip.displayName = "CopyTooltip";
|
|
139
|
+
var copy_tooltip_default = CopyTooltip;
|
|
140
|
+
|
|
141
|
+
export { CopyTooltip, copy_tooltip_default as default };
|
|
142
|
+
//# sourceMappingURL=copy-tooltip.mjs.map
|
|
143
|
+
//# sourceMappingURL=copy-tooltip.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/common/interactive/copy-tooltip.tsx"],"names":[],"mappings":"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","file":"copy-tooltip.mjs","sourcesContent":["import React, { ComponentPropsWithoutRef, useCallback, useEffect, useState } from 'react';\nimport {\n Tooltip,\n TooltipArrow,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from '../../components/tooltip';\nimport { type CopyStatus } from '../../hooks/useCopyToClipboard';\nimport { cn } from '../../lib/utils';\n\nexport interface CopyTooltipProps extends ComponentPropsWithoutRef<typeof TooltipContent> {\n // Trigger props\n trigger?: React.ReactNode;\n triggerAsChild?: boolean;\n triggerClassName?: string;\n\n // Content props\n children?: React.ReactNode;\n text?: string;\n responseContent?: string;\n contentClassName?: string;\n childrenClassName?: string;\n\n // Tooltip behavior props\n delayDuration?: number;\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n defaultOpen?: boolean;\n disableHoverableContent?: boolean;\n\n // Arrow props\n showArrow?: boolean;\n arrowClassName?: string;\n\n // Copy behavior props\n onCopySuccess?: (text: string) => void;\n onCopyError?: (error: Error) => void;\n resetDelay?: number;\n\n // Tooltip provider props\n skipDelayDuration?: number;\n}\n\nconst CopyTooltip = React.forwardRef<React.ElementRef<typeof TooltipContent>, CopyTooltipProps>(\n (\n {\n // Trigger props\n trigger,\n triggerAsChild = false,\n triggerClassName,\n\n // Tooltip behavior props\n delayDuration = 700,\n open: controlledOpen,\n onOpenChange: controlledOnOpenChange,\n defaultOpen = false,\n disableHoverableContent = true,\n\n // Arrow props\n showArrow = true,\n arrowClassName,\n\n // Content props\n children,\n text,\n responseContent = 'Đã sao chép',\n contentClassName,\n childrenClassName,\n\n // Copy behavior props\n onCopySuccess,\n onCopyError,\n resetDelay = 2000,\n\n // Tooltip provider props\n skipDelayDuration = 300,\n\n // Other props\n className,\n ...props\n },\n ref,\n ) => {\n const [internalOpen, setInternalOpen] = useState(defaultOpen);\n const [status, setStatus] = useState<CopyStatus>('idle');\n\n // Use controlled or uncontrolled state\n const isControlled = controlledOpen !== undefined;\n const open = isControlled ? controlledOpen : internalOpen && status !== 'idle';\n const setOpen = isControlled ? controlledOnOpenChange : setInternalOpen;\n\n const handleOpenChange = useCallback(\n (newOpen: boolean) => {\n setOpen?.(newOpen);\n },\n [setOpen],\n );\n\n const copyToClipboard = useCallback(\n async (textToCopy: string): Promise<boolean> => {\n try {\n await navigator.clipboard.writeText(textToCopy);\n setStatus('copied');\n setInternalOpen(true);\n onCopySuccess?.(textToCopy);\n return true;\n } catch (error) {\n const err = error as Error;\n setStatus('failed');\n setInternalOpen(true);\n onCopyError?.(err);\n console.error('Failed to copy text to clipboard:', err);\n return false;\n }\n },\n [onCopySuccess, onCopyError],\n );\n\n const handleTriggerClick = useCallback(\n (event: React.MouseEvent) => {\n event.preventDefault();\n if (text) {\n copyToClipboard(text);\n }\n },\n [text, copyToClipboard],\n );\n\n // Reset status after specified delay\n useEffect(() => {\n if (status === 'copied' || status === 'failed') {\n const timeout = setTimeout(() => {\n setStatus('idle');\n setInternalOpen(false);\n }, resetDelay);\n\n return () => clearTimeout(timeout);\n }\n }, [status, resetDelay]);\n\n return (\n <TooltipProvider\n delayDuration={delayDuration}\n skipDelayDuration={skipDelayDuration}\n disableHoverableContent={disableHoverableContent}\n >\n <Tooltip\n open={open}\n onOpenChange={handleOpenChange}\n defaultOpen={false}\n delayDuration={delayDuration}\n disableHoverableContent={disableHoverableContent}\n >\n {trigger && (\n <TooltipTrigger\n asChild={triggerAsChild}\n className={cn('cursor-pointer', triggerClassName)}\n onClick={handleTriggerClick}\n >\n {trigger}\n </TooltipTrigger>\n )}\n {children && (\n <TooltipTrigger\n asChild={triggerAsChild}\n className={cn('cursor-pointer', triggerClassName)}\n onClick={handleTriggerClick}\n >\n {children}\n </TooltipTrigger>\n )}\n <TooltipContent\n ref={ref}\n showArrow={showArrow}\n className={cn('flex flex-col px-3 py-1', className, contentClassName)}\n {...props}\n >\n <div className={cn(childrenClassName)}>{responseContent}</div>\n {showArrow && (\n <TooltipArrow className={cn('fill-foreground !h-[5px] !w-[8px]', arrowClassName)} />\n )}\n </TooltipContent>\n </Tooltip>\n </TooltipProvider>\n );\n },\n);\n\nCopyTooltip.displayName = 'CopyTooltip';\n\nexport { CopyTooltip };\nexport default CopyTooltip;\n"]}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
export interface DateFieldProps {
|
|
3
|
+
/**
|
|
4
|
+
* The selected date value
|
|
5
|
+
* Can be a Date object or a string in 'dd/MM/yyyy' format
|
|
6
|
+
*/
|
|
7
|
+
value?: Date | string | null;
|
|
8
|
+
/**
|
|
9
|
+
* Default date value
|
|
10
|
+
*/
|
|
11
|
+
defaultValue?: Date | string;
|
|
12
|
+
/**
|
|
13
|
+
* Callback fired when the date value changes
|
|
14
|
+
*/
|
|
15
|
+
onChange?: (date: Date | null) => void;
|
|
16
|
+
/**
|
|
17
|
+
* Callback fired when the input value changes (raw string)
|
|
18
|
+
*/
|
|
19
|
+
onInputChange?: (value: string) => void;
|
|
20
|
+
/**
|
|
21
|
+
* Input placeholder
|
|
22
|
+
*/
|
|
23
|
+
placeholder?: string;
|
|
24
|
+
/**
|
|
25
|
+
* Input label
|
|
26
|
+
*/
|
|
27
|
+
label?: string;
|
|
28
|
+
/**
|
|
29
|
+
* Whether the input is disabled
|
|
30
|
+
*/
|
|
31
|
+
disabled?: boolean;
|
|
32
|
+
/**
|
|
33
|
+
* Whether the input is in error state
|
|
34
|
+
*/
|
|
35
|
+
isError?: boolean;
|
|
36
|
+
/**
|
|
37
|
+
* Error message to display
|
|
38
|
+
*/
|
|
39
|
+
errorText?: string;
|
|
40
|
+
/**
|
|
41
|
+
* Help text to display
|
|
42
|
+
*/
|
|
43
|
+
helpText?: string;
|
|
44
|
+
/**
|
|
45
|
+
* Input size
|
|
46
|
+
*/
|
|
47
|
+
size?: 'default' | 'lg';
|
|
48
|
+
/**
|
|
49
|
+
* Additional CSS classes
|
|
50
|
+
*/
|
|
51
|
+
className?: string;
|
|
52
|
+
/**
|
|
53
|
+
* Input CSS classes
|
|
54
|
+
*/
|
|
55
|
+
inputClassName?: string;
|
|
56
|
+
/**
|
|
57
|
+
* Minimum date allowed
|
|
58
|
+
*/
|
|
59
|
+
minDate?: Date;
|
|
60
|
+
/**
|
|
61
|
+
* Maximum date allowed
|
|
62
|
+
*/
|
|
63
|
+
maxDate?: Date;
|
|
64
|
+
/**
|
|
65
|
+
* Whether to show calendar icon
|
|
66
|
+
*/
|
|
67
|
+
showCalendarIcon?: boolean;
|
|
68
|
+
/**
|
|
69
|
+
* Whether to show clear button
|
|
70
|
+
*/
|
|
71
|
+
showClearButton?: boolean;
|
|
72
|
+
/**
|
|
73
|
+
* Custom date format (default: 'dd/MM/yyyy')
|
|
74
|
+
*/
|
|
75
|
+
format?: string;
|
|
76
|
+
/**
|
|
77
|
+
* Whether to enable strict validation
|
|
78
|
+
*/
|
|
79
|
+
strictValidation?: boolean;
|
|
80
|
+
/**
|
|
81
|
+
* Inline styles
|
|
82
|
+
*/
|
|
83
|
+
style?: React.CSSProperties;
|
|
84
|
+
/**
|
|
85
|
+
* Callback when calendar icon is clicked
|
|
86
|
+
*/
|
|
87
|
+
onCalendarIconClick?: () => void;
|
|
88
|
+
/**
|
|
89
|
+
* Callback when clear button is clicked
|
|
90
|
+
*/
|
|
91
|
+
onClearValue?: () => void;
|
|
92
|
+
/**
|
|
93
|
+
* Callback when input is clicked
|
|
94
|
+
*/
|
|
95
|
+
onInputClick?: () => void;
|
|
96
|
+
}
|
|
97
|
+
export declare const DateField: React.ForwardRefExoticComponent<DateFieldProps & React.RefAttributes<HTMLInputElement>>;
|
|
98
|
+
//# sourceMappingURL=date-field.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"date-field.d.ts","sourceRoot":"","sources":["../../../src/common/interactive/date-field.tsx"],"names":[],"mappings":"AAOA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,MAAM,WAAW,cAAc;IAC7B;;;OAGG;IACH,KAAK,CAAC,EAAE,IAAI,GAAG,MAAM,GAAG,IAAI,CAAC;IAE7B;;OAEG;IACH,YAAY,CAAC,EAAE,IAAI,GAAG,MAAM,CAAC;IAE7B;;OAEG;IACH,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,KAAK,IAAI,CAAC;IAEvC;;OAEG;IACH,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAExC;;OAEG;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf;;OAEG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB;;OAEG;IACH,OAAO,CAAC,EAAE,OAAO,CAAC;IAElB;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB;;OAEG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB;;OAEG;IACH,IAAI,CAAC,EAAE,SAAS,GAAG,IAAI,CAAC;IAExB;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB;;OAEG;IACH,cAAc,CAAC,EAAE,MAAM,CAAC;IAExB;;OAEG;IACH,OAAO,CAAC,EAAE,IAAI,CAAC;IAEf;;OAEG;IACH,OAAO,CAAC,EAAE,IAAI,CAAC;IAEf;;OAEG;IACH,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAE3B;;OAEG;IACH,eAAe,CAAC,EAAE,OAAO,CAAC;IAE1B;;OAEG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB;;OAEG;IACH,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAE3B;;OAEG;IACH,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IAE5B;;OAEG;IACH,mBAAmB,CAAC,EAAE,MAAM,IAAI,CAAC;IAEjC;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAE1B;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;CAC3B;AAiID,eAAO,MAAM,SAAS,yFA8QrB,CAAC"}
|
|
@@ -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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkIA,MAAM,iBAAA,GAAoB,CAAC,OAAA,EAAiBA,OAAAA,GAAiB,YAAA,KAA8B;AACzF,EAAA,IAAI,CAAC,SAAS,OAAO,IAAA;AACrB,EAAA,IAAI;AACF,IAAA,MAAM,aAAaC,aAAA,CAAM,OAAA,EAASD,OAAAA,kBAAQ,IAAI,MAAM,CAAA;AACpD,IAAA,OAAOE,eAAA,CAAQ,UAAU,CAAA,GAAI,UAAA,GAAa,IAAA;AAAA,EAC5C,SAAS,KAAA,EAAO;AACd,IAAA,OAAO,IAAA;AAAA,EACT;AACF,CAAA;AAKA,MAAM,YAAA,GAAe,CACnB,KAAA,EACAF,OAAAA,GAAiB,YAAA,KACD;AAChB,EAAA,IAAI,CAAC,OAAO,OAAO,IAAA;AACnB,EAAA,IAAI,OAAO,KAAA,KAAU,QAAA,EAAU,OAAO,iBAAA,CAAkB,OAAOA,OAAM,CAAA;AACrE,EAAA,OAAO,KAAA,YAAiB,OAAO,KAAA,GAAQ,IAAA;AACzC,CAAA;AAKA,MAAM,kBAAA,GAAqB,CAAC,IAAA,EAAmB,UAAA,GAAqB,YAAA,KAAyB;AAC3F,EAAA,IAAI,CAAC,IAAA,IAAQ,CAACE,eAAA,CAAQ,IAAI,GAAG,OAAO,EAAA;AACpC,EAAA,IAAI;AACF,IAAA,OAAOF,eAAO,IAAA,EAAM,UAAA,EAAY,EAAE,MAAA,EAAQG,WAAI,CAAA;AAAA,EAChD,SAAS,KAAA,EAAO;AACd,IAAA,OAAO,EAAA;AAAA,EACT;AACF,CAAA;AAKA,MAAM,eAAA,GAAkB,CAAC,KAAA,KAA0B;AAEjD,EAAA,MAAM,UAAA,GAAa,KAAA,CAAM,OAAA,CAAQ,KAAA,EAAO,EAAE,CAAA;AAG1C,EAAA,IAAI,UAAA,CAAW,UAAU,CAAA,EAAG;AAC1B,IAAA,OAAO,UAAA;AAAA,EACT,CAAA,MAAA,IAAW,UAAA,CAAW,MAAA,IAAU,CAAA,EAAG;AACjC,IAAA,OAAO,CAAA,EAAG,UAAA,CAAW,KAAA,CAAM,CAAA,EAAG,CAAC,CAAC,CAAA,CAAA,EAAI,UAAA,CAAW,KAAA,CAAM,CAAC,CAAC,CAAA,CAAA;AAAA,EACzD,CAAA,MAAA,IAAW,UAAA,CAAW,MAAA,IAAU,CAAA,EAAG;AACjC,IAAA,OAAO,GAAG,UAAA,CAAW,KAAA,CAAM,CAAA,EAAG,CAAC,CAAC,CAAA,CAAA,EAAI,UAAA,CAAW,KAAA,CAAM,CAAA,EAAG,CAAC,CAAC,CAAA,CAAA,EAAI,UAAA,CAAW,KAAA,CAAM,CAAC,CAAC,CAAA,CAAA;AAAA,EACnF,CAAA,MAAO;AAEL,IAAA,OAAO,GAAG,UAAA,CAAW,KAAA,CAAM,CAAA,EAAG,CAAC,CAAC,CAAA,CAAA,EAAI,UAAA,CAAW,KAAA,CAAM,CAAA,EAAG,CAAC,CAAC,CAAA,CAAA,EAAI,WAAW,KAAA,CAAM,CAAA,EAAG,CAAC,CAAC,CAAA,CAAA;AAAA,EACtF;AACF,CAAA;AAKA,MAAM,iBAAA,GAAoB,CACxB,KAAA,EACA,UAAA,GAAqB,cACrB,OAAA,EACA,OAAA,EACA,mBAA4B,KAAA,KACa;AACzC,EAAA,IAAI,CAAC,KAAA,EAAO,OAAO,EAAE,SAAS,IAAA,EAAK;AAGnC,EAAA,IAAI,gBAAA,IAAoB,KAAA,CAAM,MAAA,KAAW,EAAA,EAAI;AAC3C,IAAA,OAAO,EAAE,OAAA,EAAS,KAAA,EAAO,KAAA,EAAO,gFAAA,EAA+C;AAAA,EACjF;AAGA,EAAA,IAAI,KAAA,CAAM,SAAS,EAAA,EAAI;AACrB,IAAA,OAAO,EAAE,SAAS,IAAA,EAAK;AAAA,EACzB;AAGA,EAAA,MAAM,KAAA,GAAQ,KAAA,CAAM,KAAA,CAAM,GAAG,CAAA;AAC7B,EAAA,IAAI,KAAA,CAAM,WAAW,CAAA,EAAG;AACtB,IAAA,OAAO,EAAE,OAAA,EAAS,KAAA,EAAO,KAAA,EAAO,4DAAA,EAA8B;AAAA,EAChE;AAEA,EAAA,MAAM,MAAM,QAAA,CAAS,KAAA,CAAM,CAAC,CAAA,IAAK,KAAK,EAAE,CAAA;AACxC,EAAA,MAAM,QAAQ,QAAA,CAAS,KAAA,CAAM,CAAC,CAAA,IAAK,KAAK,EAAE,CAAA;AAC1C,EAAA,MAAM,OAAO,QAAA,CAAS,KAAA,CAAM,CAAC,CAAA,IAAK,KAAK,EAAE,CAAA;AAGzC,EAAA,IAAI,MAAM,GAAG,CAAA,IAAK,GAAA,GAAM,CAAA,IAAK,MAAM,EAAA,EAAI;AACrC,IAAA,OAAO,EAAE,OAAA,EAAS,KAAA,EAAO,KAAA,EAAO,+CAAA,EAAyB;AAAA,EAC3D;AAEA,EAAA,IAAI,MAAM,KAAK,CAAA,IAAK,KAAA,GAAQ,CAAA,IAAK,QAAQ,EAAA,EAAI;AAC3C,IAAA,OAAO,EAAE,OAAA,EAAS,KAAA,EAAO,KAAA,EAAO,gDAAA,EAA0B;AAAA,EAC5D;AAEA,EAAA,IAAI,MAAM,IAAI,CAAA,IAAK,IAAA,GAAO,IAAA,IAAQ,OAAO,IAAA,EAAM;AAC7C,IAAA,OAAO,EAAE,OAAA,EAAS,KAAA,EAAO,KAAA,EAAO,oDAAA,EAA4B;AAAA,EAC9D;AAGA,EAAA,MAAM,OAAO,IAAI,IAAA,CAAK,IAAA,EAAM,KAAA,GAAQ,GAAG,GAAG,CAAA;AAC1C,EAAA,IAAI,IAAA,CAAK,WAAA,EAAY,KAAM,IAAA,IAAQ,IAAA,CAAK,QAAA,EAAS,KAAM,KAAA,GAAQ,CAAA,IAAK,IAAA,CAAK,OAAA,EAAQ,KAAM,GAAA,EAAK;AAC1F,IAAA,OAAO,EAAE,OAAA,EAAS,KAAA,EAAO,KAAA,EAAO,oCAAA,EAAqB;AAAA,EACvD;AAGA,EAAA,IAAI,OAAA,IAAW,OAAO,OAAA,EAAS;AAC7B,IAAA,OAAO;AAAA,MACL,OAAA,EAAS,KAAA;AAAA,MACT,KAAA,EAAO,CAAA,uDAAA,EAA2B,kBAAA,CAAmB,OAAA,EAAS,UAAU,CAAC,CAAA;AAAA,KAC3E;AAAA,EACF;AAGA,EAAA,IAAI,OAAA,IAAW,OAAO,OAAA,EAAS;AAC7B,IAAA,OAAO;AAAA,MACL,OAAA,EAAS,KAAA;AAAA,MACT,KAAA,EAAO,CAAA,uDAAA,EAA2B,kBAAA,CAAmB,OAAA,EAAS,UAAU,CAAC,CAAA;AAAA,KAC3E;AAAA,EACF;AAEA,EAAA,OAAO,EAAE,SAAS,IAAA,EAAK;AACzB,CAAA;AAEO,MAAM,YAAYC,gBAAA,CAAM,UAAA;AAAA,EAC7B,CACE;AAAA,IACE,KAAA;AAAA,IACA,YAAA;AAAA,IACA,QAAA;AAAA,IACA,aAAA;AAAA,IACA,WAAA,GAAc,YAAA;AAAA,IACd,KAAA;AAAA,IACA,QAAA,GAAW,KAAA;AAAA,IACX,OAAA,GAAU,KAAA;AAAA,IACV,SAAA;AAAA,IACA,QAAA;AAAA,IACA,IAAA,GAAO,SAAA;AAAA,IACP,SAAA;AAAA,IACA,cAAA;AAAA,IACA,OAAA;AAAA,IACA,OAAA;AAAA,IACA,gBAAA,GAAmB,IAAA;AAAA,IACnB,eAAA,GAAkB,IAAA;AAAA,IAClB,QAAQ,UAAA,GAAa,YAAA;AAAA,IACrB,gBAAA,GAAmB,KAAA;AAAA,IACnB,KAAA;AAAA,IACA,mBAAA;AAAA,IACA,YAAA;AAAA,IACA,YAAA;AAAA,IAEA,GAAG;AAAA,KAEL,GAAA,KACG;AAEH,IAAA,MAAM,WAAA,GAAc,YAAA,CAAa,KAAA,IAAS,YAAA,EAAc,UAAU,CAAA;AAClE,IAAA,MAAM,iBAAA,GAAoB,kBAAA,CAAmB,WAAA,EAAa,UAAU,CAAA;AAGpE,IAAA,MAAM,CAAC,UAAA,EAAY,aAAa,CAAA,GAAIA,gBAAA,CAAM,SAAS,iBAAiB,CAAA;AACpE,IAAA,MAAM,CAAC,aAAA,EAAe,gBAAgB,CAAA,GAAIA,gBAAA,CAAM,SAAiB,EAAE,CAAA;AACnE,IAAA,MAAM,CAAC,SAAA,EAAW,YAAY,CAAA,GAAIA,gBAAA,CAAM,SAAS,KAAK,CAAA;AAGtD,IAAAA,gBAAA,CAAM,UAAU,MAAM;AACpB,MAAA,MAAM,SAAA,GAAY,YAAA,CAAa,KAAA,EAAO,UAAU,CAAA;AAChD,MAAA,MAAM,cAAA,GAAiB,kBAAA,CAAmB,SAAA,EAAW,UAAU,CAAA;AAC/D,MAAA,aAAA,CAAc,cAAc,CAAA;AAAA,IAC9B,CAAA,EAAG,CAAC,KAAA,EAAO,UAAU,CAAC,CAAA;AAGtB,IAAA,MAAM,oBAAoBA,gBAAA,CAAM,WAAA;AAAA,MAC9B,CAAC,CAAA,KAA2C;AAC1C,QAAA,MAAM,QAAA,GAAW,EAAE,MAAA,CAAO,KAAA;AAC1B,QAAA,MAAM,cAAA,GAAiB,gBAAgB,QAAQ,CAAA;AAE/C,QAAA,aAAA,CAAc,cAAc,CAAA;AAC5B,QAAA,aAAA,GAAgB,cAAc,CAAA;AAG9B,QAAA,MAAM,UAAA,GAAa,iBAAA;AAAA,UACjB,cAAA;AAAA,UACA,UAAA;AAAA,UACA,OAAA;AAAA,UACA,OAAA;AAAA,UACA;AAAA,SACF;AAEA,QAAA,IAAI,WAAW,OAAA,EAAS;AACtB,UAAA,gBAAA,CAAiB,EAAE,CAAA;AAGnB,UAAA,IAAI,cAAA,CAAe,WAAW,EAAA,EAAI;AAChC,YAAA,MAAM,UAAA,GAAa,iBAAA,CAAkB,cAAA,EAAgB,UAAU,CAAA;AAC/D,YAAA,IAAI,UAAA,EAAY;AACd,cAAA,QAAA,GAAW,UAAU,CAAA;AAAA,YACvB,CAAA,MAAO;AAEL,cAAA,QAAA,GAAW,IAAI,CAAA;AAAA,YACjB;AAAA,UACF;AAAA,QAEF,CAAA,MAAO;AACL,UAAA,gBAAA,CAAiB,UAAA,CAAW,SAAS,EAAE,CAAA;AAEvC,UAAA,IAAI,cAAA,CAAe,WAAW,EAAA,EAAI;AAChC,YAAA,QAAA,GAAW,IAAI,CAAA;AAAA,UACjB;AAAA,QACF;AAAA,MACF,CAAA;AAAA,MACA,CAAC,QAAA,EAAU,aAAA,EAAe,UAAA,EAAY,OAAA,EAAS,SAAS,gBAAgB;AAAA,KAC1E;AAGA,IAAA,MAAM,mBAAmBA,gBAAA,CAAM,WAAA;AAAA,MAC7B,CAAC,CAAA,KAA0C;AACzC,QAAA,MAAM,QAAQ,CAAA,CAAE,aAAA;AAChB,QAAA,IAAI,CAAC,KAAA,IAAS,CAAC,UAAA,EAAY;AAEzB,UAAA,YAAA,IAAe;AACf,UAAA;AAAA,QACF;AAGA,QAAA,MAAM,cAAA,GAAiB,MAAM,cAAA,IAAkB,CAAA;AAK/C,QAAA,IAAI,cAAA,GAAiB,CAAA;AACrB,QAAA,IAAI,YAAA,GAAe,CAAA;AAEnB,QAAA,IAAI,kBAAkB,CAAA,EAAG;AAEvB,UAAA,cAAA,GAAiB,CAAA;AACjB,UAAA,YAAA,GAAe,CAAA;AAAA,QACjB,CAAA,MAAA,IAAW,kBAAkB,CAAA,EAAG;AAE9B,UAAA,cAAA,GAAiB,CAAA;AACjB,UAAA,YAAA,GAAe,CAAA;AAAA,QACjB,CAAA,MAAO;AAEL,UAAA,cAAA,GAAiB,CAAA;AACjB,UAAA,YAAA,GAAe,EAAA;AAAA,QACjB;AAGA,QAAA,UAAA,CAAW,MAAM;AACf,UAAA,KAAA,CAAM,iBAAA,CAAkB,gBAAgB,YAAY,CAAA;AAAA,QACtD,GAAG,CAAC,CAAA;AAGJ,QAAA,YAAA,IAAe;AAAA,MACjB,CAAA;AAAA,MACA,CAAC,YAAY,YAAY;AAAA,KAC3B;AAGA,IAAA,MAAM,cAAcA,gBAAA,CAAM,WAAA;AAAA,MACxB,CAAC,CAAA,KAA0C;AACzC,QAAA,YAAA,CAAa,IAAI,CAAA;AAGjB,QAAA,IAAI,UAAA,EAAY;AACd,UAAA,MAAM,QAAQ,CAAA,CAAE,aAAA;AAEhB,UAAA,UAAA,CAAW,MAAM;AACf,YAAA,KAAA,CAAM,iBAAA,CAAkB,GAAG,CAAC,CAAA;AAAA,UAC9B,GAAG,CAAC,CAAA;AAAA,QACN;AAAA,MACF,CAAA;AAAA,MACA,CAAC,UAAU;AAAA,KACb;AAGA,IAAA,MAAM,UAAA,GAAaA,gBAAA,CAAM,WAAA,CAAY,MAAM;AACzC,MAAA,YAAA,CAAa,KAAK,CAAA;AAGlB,MAAA,IAAI,UAAA,EAAY;AACd,QAAA,MAAM,aAAa,iBAAA,CAAkB,UAAA,EAAY,UAAA,EAAY,OAAA,EAAS,SAAS,IAAI,CAAA;AACnF,QAAA,IAAI,CAAC,WAAW,OAAA,EAAS;AACvB,UAAA,gBAAA,CAAiB,UAAA,CAAW,SAAS,EAAE,CAAA;AAAA,QACzC;AAAA,MACF;AAAA,IACF,GAAG,CAAC,UAAA,EAAY,UAAA,EAAY,OAAA,EAAS,OAAO,CAAC,CAAA;AAG7C,IAAA,MAAM,WAAA,GAAcA,gBAAA,CAAM,WAAA,CAAY,MAAM;AAC1C,MAAA,aAAA,CAAc,EAAE,CAAA;AAChB,MAAA,gBAAA,CAAiB,EAAE,CAAA;AACnB,MAAA,QAAA,GAAW,IAAI,CAAA;AACf,MAAA,aAAA,GAAgB,EAAE,CAAA;AAClB,MAAA,YAAA,IAAe;AAAA,IACjB,CAAA,EAAG,CAAC,QAAA,EAAU,aAAA,EAAe,YAAY,CAAC,CAAA;AAG1C,IAAA,MAAM,cAAA,GAAiBA,gBAAA,CAAM,WAAA,CAAY,CAAC,CAAA,KAA6C;AAErF,MAAA,IACE,CAAC,OAAA,CAAQ,IAAA,CAAK,CAAA,CAAE,GAAG,KACnB,CAAC,CAAC,WAAA,EAAa,QAAA,EAAU,aAAa,YAAA,EAAc,KAAK,EAAE,QAAA,CAAS,CAAA,CAAE,GAAG,CAAA,EACzE;AACA,QAAA,CAAA,CAAE,cAAA,EAAe;AAAA,MACnB;AAAA,IACF,CAAA,EAAG,EAAE,CAAA;AAGL,IAAA,MAAM,gBAAgBA,gBAAA,CAAM,WAAA;AAAA,MAC1B,CAAC,CAAA,KAA6C;AAC5C,QAAA,MAAM,QAAQ,CAAA,CAAE,aAAA;AAChB,QAAA,MAAM,cAAA,GAAiB,MAAM,cAAA,IAAkB,CAAA;AAC/C,QAAA,MAAM,eAAA,GAAA,CAAmB,KAAA,CAAM,YAAA,IAAgB,CAAA,KAAM,MAAM,cAAA,IAAkB,CAAA,CAAA;AAG7E,QAAA,MAAM,oBAAoB,eAAA,GAAkB,CAAA;AAE5C,QAAA,IAAI,CAAA,CAAE,GAAA,KAAQ,WAAA,IAAe,iBAAA,EAAmB;AAC9C,UAAA,CAAA,CAAE,cAAA,EAAe;AAEjB,UAAA,IAAI,kBAAkB,CAAA,EAAG;AAEvB,YAAA,KAAA,CAAM,iBAAA,CAAkB,GAAG,EAAE,CAAA;AAAA,UAC/B,CAAA,MAAA,IAAW,kBAAkB,CAAA,EAAG;AAE9B,YAAA,KAAA,CAAM,iBAAA,CAAkB,GAAG,CAAC,CAAA;AAAA,UAC9B,CAAA,MAAO;AAEL,YAAA,KAAA,CAAM,iBAAA,CAAkB,GAAG,CAAC,CAAA;AAAA,UAC9B;AAAA,QACF,CAAA,MAAA,IAAW,CAAA,CAAE,GAAA,KAAQ,YAAA,IAAgB,iBAAA,EAAmB;AACtD,UAAA,CAAA,CAAE,cAAA,EAAe;AAEjB,UAAA,IAAI,kBAAkB,CAAA,EAAG;AAEvB,YAAA,KAAA,CAAM,iBAAA,CAAkB,GAAG,CAAC,CAAA;AAAA,UAC9B,CAAA,MAAA,IAAW,kBAAkB,CAAA,EAAG;AAE9B,YAAA,KAAA,CAAM,iBAAA,CAAkB,GAAG,EAAE,CAAA;AAAA,UAC/B,CAAA,MAAO;AAEL,YAAA,KAAA,CAAM,iBAAA,CAAkB,GAAG,CAAC,CAAA;AAAA,UAC9B;AAAA,QACF,CAAA,MAAO;AAEL,UAAA,cAAA,CAAe,CAAC,CAAA;AAAA,QAClB;AAAA,MACF,CAAA;AAAA,MACA,CAAC,cAAc;AAAA,KACjB;AAGA,IAAA,MAAM,QAAA,GAAW,OAAA,IAAW,CAAC,CAAC,aAAA;AAC9B,IAAA,MAAM,mBAAmB,SAAA,IAAa,aAAA;AAGtC,IAAA,MAAM,eAAA,GACJ,aAAa,CAAC,QAAA,GAAW,YAAY,CAAA,0BAAA,EAAc,UAAA,CAAW,WAAA,EAAa,CAAA,CAAA,GAAK,QAAA;AAElF,IAAA,uBACEC,cAAA;AAAA,MAACC,WAAA;AAAA,MAAA;AAAA,QACC,GAAA;AAAA,QACA,IAAA,EAAK,MAAA;AAAA,QACL,KAAA,EAAO,UAAA;AAAA,QACP,QAAA,EAAU,iBAAA;AAAA,QACV,OAAA,EAAS,WAAA;AAAA,QACT,MAAA,EAAQ,UAAA;AAAA,QACR,SAAA,EAAW,aAAA;AAAA,QACX,OAAA,EAAS,gBAAA;AAAA,QACT,WAAA;AAAA,QACA,KAAA;AAAA,QACA,QAAA;AAAA,QACA,OAAA,EAAS,QAAA;AAAA,QACT,SAAA,EAAW,gBAAA;AAAA,QACX,QAAA,EAAU,eAAA;AAAA,QACV,IAAA;AAAA,QACA,SAAA,EAAWC,QAAA,CAAG,QAAA,EAAU,SAAS,CAAA;AAAA,QACjC,cAAA,EAAgBA,QAAA,CAAG,iCAAA,EAAmC,cAAc,CAAA;AAAA,QACpE,cAAA,EAAgB,eAAA,IAAmB,CAAC,CAAC,cAAc,CAAC,QAAA;AAAA,QACpD,YAAA,EAAc,WAAA;AAAA,QACd,UAAA,EACE,gBAAA,mBACEF,cAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAU,gBAAA,EAAiB,oBAAA,EAAkB,IAAA,EAChD,QAAA,kBAAAA,cAAA,CAACG,0BAAA,EAAA,EAAqB,SAAA,EAAU,SAAA,EAAU,GAC5C,CAAA,GACE,MAAA;AAAA,QAEN,SAAA,EAAW,EAAA;AAAA,QACX,KAAA,EAAO,EAAE,KAAA,EAAO,MAAA,EAAQ,GAAG,KAAA,EAAM;AAAA,QAChC,GAAG;AAAA;AAAA,KACN;AAAA,EAEJ;AACF;AAEA,SAAA,CAAU,WAAA,GAAc,WAAA","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"]}
|