shad-m 1.0.2 → 1.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/Animation/index.js +180 -0
- package/dist/assets/Animation/index.js.map +1 -0
- package/dist/assets/Animation/index.mjs +79 -0
- package/dist/assets/Animation/index.mjs.map +1 -0
- package/dist/assets/Icon/index.js +2102 -0
- package/dist/assets/Icon/index.js.map +1 -0
- package/dist/assets/Icon/index.mjs +421 -0
- package/dist/assets/Icon/index.mjs.map +1 -0
- package/dist/assets/Image/index.js +755 -0
- package/dist/assets/Image/index.js.map +1 -0
- package/dist/assets/Image/index.mjs +150 -0
- package/dist/assets/Image/index.mjs.map +1 -0
- package/dist/common/display/countdown.js +68 -0
- package/dist/common/display/countdown.js.map +1 -0
- package/dist/common/display/countdown.mjs +46 -0
- package/dist/common/display/countdown.mjs.map +1 -0
- package/dist/common/display/display-field-group.js +91 -0
- package/dist/common/display/display-field-group.js.map +1 -0
- package/dist/common/display/display-field-group.mjs +89 -0
- package/dist/common/display/display-field-group.mjs.map +1 -0
- package/dist/common/display/display-field.js +46 -0
- package/dist/common/display/display-field.js.map +1 -0
- package/dist/common/display/display-field.mjs +40 -0
- package/dist/common/display/display-field.mjs.map +1 -0
- package/dist/common/display/display-html-string.js +52 -0
- package/dist/common/display/display-html-string.js.map +1 -0
- package/dist/common/display/display-html-string.mjs +30 -0
- package/dist/common/display/display-html-string.mjs.map +1 -0
- package/dist/common/display/index.js +59 -0
- package/dist/common/display/index.js.map +1 -0
- package/dist/common/display/index.mjs +10 -0
- package/dist/common/display/index.mjs.map +1 -0
- package/dist/common/display/page-breadcrumb.js +43 -0
- package/dist/common/display/page-breadcrumb.js.map +1 -0
- package/dist/common/display/page-breadcrumb.mjs +37 -0
- package/dist/common/display/page-breadcrumb.mjs.map +1 -0
- package/dist/common/display/page-v2.js +58 -0
- package/dist/common/display/page-v2.js.map +1 -0
- package/dist/common/display/page-v2.mjs +20 -0
- package/dist/common/display/page-v2.mjs.map +1 -0
- package/dist/common/display/page.js +155 -0
- package/dist/common/display/page.js.map +1 -0
- package/dist/common/display/page.mjs +138 -0
- package/dist/common/display/page.mjs.map +1 -0
- package/dist/common/display/score-meter.js +161 -0
- package/dist/common/display/score-meter.js.map +1 -0
- package/dist/common/display/score-meter.mjs +140 -0
- package/dist/common/display/score-meter.mjs.map +1 -0
- package/dist/common/display/sidebar/app-sidebar.js +114 -0
- package/dist/common/display/sidebar/app-sidebar.js.map +1 -0
- package/dist/common/display/sidebar/app-sidebar.mjs +92 -0
- package/dist/common/display/sidebar/app-sidebar.mjs.map +1 -0
- package/dist/common/display/sidebar/index.js +89 -0
- package/dist/common/display/sidebar/index.js.map +1 -0
- package/dist/common/display/sidebar/index.mjs +81 -0
- package/dist/common/display/sidebar/index.mjs.map +1 -0
- package/dist/common/display/sidebar/nav-main.js +406 -0
- package/dist/common/display/sidebar/nav-main.js.map +1 -0
- package/dist/common/display/sidebar/nav-main.mjs +400 -0
- package/dist/common/display/sidebar/nav-main.mjs.map +1 -0
- package/dist/common/display/sidebar/sidebar-sheet.js +140 -0
- package/dist/common/display/sidebar/sidebar-sheet.js.map +1 -0
- package/dist/common/display/sidebar/sidebar-sheet.mjs +118 -0
- package/dist/common/display/sidebar/sidebar-sheet.mjs.map +1 -0
- package/dist/common/display/sidebar/types.js +4 -0
- package/dist/common/display/sidebar/types.js.map +1 -0
- package/dist/common/display/sidebar/types.mjs +3 -0
- package/dist/common/display/sidebar/types.mjs.map +1 -0
- package/dist/common/display/status-state.js +97 -0
- package/dist/common/display/status-state.js.map +1 -0
- package/dist/common/display/status-state.mjs +88 -0
- package/dist/common/display/status-state.mjs.map +1 -0
- package/dist/common/forms/auto-form.js +101 -0
- package/dist/common/forms/auto-form.js.map +1 -0
- package/dist/common/forms/auto-form.mjs +78 -0
- package/dist/common/forms/auto-form.mjs.map +1 -0
- package/dist/common/forms/form-field.js +58 -0
- package/dist/common/forms/form-field.js.map +1 -0
- package/dist/common/forms/form-field.mjs +56 -0
- package/dist/common/forms/form-field.mjs.map +1 -0
- package/dist/common/forms/form-input-field.js +64 -0
- package/dist/common/forms/form-input-field.js.map +1 -0
- package/dist/common/forms/form-input-field.mjs +62 -0
- package/dist/common/forms/form-input-field.mjs.map +1 -0
- package/dist/common/forms/index.js +22 -0
- package/dist/common/forms/index.js.map +1 -0
- package/dist/common/forms/index.mjs +5 -0
- package/dist/common/forms/index.mjs.map +1 -0
- package/dist/common/forms/switch-field.js +106 -0
- package/dist/common/forms/switch-field.js.map +1 -0
- package/dist/common/forms/switch-field.mjs +104 -0
- package/dist/common/forms/switch-field.mjs.map +1 -0
- package/dist/common/interactive/alert-dialog-wrapper.js +141 -0
- package/dist/common/interactive/alert-dialog-wrapper.js.map +1 -0
- package/dist/common/interactive/alert-dialog-wrapper.mjs +119 -0
- package/dist/common/interactive/alert-dialog-wrapper.mjs.map +1 -0
- package/dist/common/interactive/autocomplete.js +178 -0
- package/dist/common/interactive/autocomplete.js.map +1 -0
- package/dist/common/interactive/autocomplete.mjs +157 -0
- package/dist/common/interactive/autocomplete.mjs.map +1 -0
- package/dist/common/interactive/copy-tooltip.js +152 -0
- package/dist/common/interactive/copy-tooltip.js.map +1 -0
- package/dist/common/interactive/copy-tooltip.mjs +143 -0
- package/dist/common/interactive/copy-tooltip.mjs.map +1 -0
- package/dist/common/interactive/date-field.js +303 -0
- package/dist/common/interactive/date-field.js.map +1 -0
- package/dist/common/interactive/date-field.mjs +281 -0
- package/dist/common/interactive/date-field.mjs.map +1 -0
- package/dist/common/interactive/date-input/date-input.js +68 -0
- package/dist/common/interactive/date-input/date-input.js.map +1 -0
- package/dist/common/interactive/date-input/date-input.mjs +62 -0
- package/dist/common/interactive/date-input/date-input.mjs.map +1 -0
- package/dist/common/interactive/date-input/index.js +17 -0
- package/dist/common/interactive/date-input/index.js.map +1 -0
- package/dist/common/interactive/date-input/index.mjs +4 -0
- package/dist/common/interactive/date-input/index.mjs.map +1 -0
- package/dist/common/interactive/date-input/types.js +4 -0
- package/dist/common/interactive/date-input/types.js.map +1 -0
- package/dist/common/interactive/date-input/types.mjs +3 -0
- package/dist/common/interactive/date-input/types.mjs.map +1 -0
- package/dist/common/interactive/date-input/use-typed-date.js +478 -0
- package/dist/common/interactive/date-input/use-typed-date.js.map +1 -0
- package/dist/common/interactive/date-input/use-typed-date.mjs +476 -0
- package/dist/common/interactive/date-input/use-typed-date.mjs.map +1 -0
- package/dist/common/interactive/date-input/utils.js +34 -0
- package/dist/common/interactive/date-input/utils.js.map +1 -0
- package/dist/common/interactive/date-input/utils.mjs +29 -0
- package/dist/common/interactive/date-input/utils.mjs.map +1 -0
- package/dist/common/interactive/date-picker.js +616 -0
- package/dist/common/interactive/date-picker.js.map +1 -0
- package/dist/common/interactive/date-picker.mjs +594 -0
- package/dist/common/interactive/date-picker.mjs.map +1 -0
- package/dist/common/interactive/date-range-input/date-range-input.js +82 -0
- package/dist/common/interactive/date-range-input/date-range-input.js.map +1 -0
- package/dist/common/interactive/date-range-input/date-range-input.mjs +76 -0
- package/dist/common/interactive/date-range-input/date-range-input.mjs.map +1 -0
- package/dist/common/interactive/date-range-input/index.js +12 -0
- package/dist/common/interactive/date-range-input/index.js.map +1 -0
- package/dist/common/interactive/date-range-input/index.mjs +3 -0
- package/dist/common/interactive/date-range-input/index.mjs.map +1 -0
- package/dist/common/interactive/date-range-input/types.js +4 -0
- package/dist/common/interactive/date-range-input/types.js.map +1 -0
- package/dist/common/interactive/date-range-input/types.mjs +3 -0
- package/dist/common/interactive/date-range-input/types.mjs.map +1 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.js +602 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.js.map +1 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.mjs +600 -0
- package/dist/common/interactive/date-range-input/use-typed-date-range.mjs.map +1 -0
- package/dist/common/interactive/date-time-picker.js +215 -0
- package/dist/common/interactive/date-time-picker.js.map +1 -0
- package/dist/common/interactive/date-time-picker.mjs +213 -0
- package/dist/common/interactive/date-time-picker.mjs.map +1 -0
- package/dist/common/interactive/dialog-wrapper.js +124 -0
- package/dist/common/interactive/dialog-wrapper.js.map +1 -0
- package/dist/common/interactive/dialog-wrapper.mjs +102 -0
- package/dist/common/interactive/dialog-wrapper.mjs.map +1 -0
- package/dist/common/interactive/filter.js +287 -0
- package/dist/common/interactive/filter.js.map +1 -0
- package/dist/common/interactive/filter.mjs +280 -0
- package/dist/common/interactive/filter.mjs.map +1 -0
- package/dist/common/interactive/index.js +235 -0
- package/dist/common/interactive/index.js.map +1 -0
- package/dist/common/interactive/index.mjs +24 -0
- package/dist/common/interactive/index.mjs.map +1 -0
- package/dist/common/interactive/list.js +160 -0
- package/dist/common/interactive/list.js.map +1 -0
- package/dist/common/interactive/list.mjs +134 -0
- package/dist/common/interactive/list.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/index.js +35 -0
- package/dist/common/interactive/otp-dialog/index.js.map +1 -0
- package/dist/common/interactive/otp-dialog/index.mjs +6 -0
- package/dist/common/interactive/otp-dialog/index.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.js +325 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.js.map +1 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.mjs +303 -0
- package/dist/common/interactive/otp-dialog/otp-dialog.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/reducer.js +40 -0
- package/dist/common/interactive/otp-dialog/reducer.js.map +1 -0
- package/dist/common/interactive/otp-dialog/reducer.mjs +37 -0
- package/dist/common/interactive/otp-dialog/reducer.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/types.js +15 -0
- package/dist/common/interactive/otp-dialog/types.js.map +1 -0
- package/dist/common/interactive/otp-dialog/types.mjs +13 -0
- package/dist/common/interactive/otp-dialog/types.mjs.map +1 -0
- package/dist/common/interactive/otp-dialog/utils.js +24 -0
- package/dist/common/interactive/otp-dialog/utils.js.map +1 -0
- package/dist/common/interactive/otp-dialog/utils.mjs +21 -0
- package/dist/common/interactive/otp-dialog/utils.mjs.map +1 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.js +51 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.js.map +1 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.mjs +49 -0
- package/dist/common/interactive/pagination/PaginationSkeleton.mjs.map +1 -0
- package/dist/common/interactive/pagination/index.js +235 -0
- package/dist/common/interactive/pagination/index.js.map +1 -0
- package/dist/common/interactive/pagination/index.mjs +223 -0
- package/dist/common/interactive/pagination/index.mjs.map +1 -0
- package/dist/common/interactive/pagination/usePagination.js +28 -0
- package/dist/common/interactive/pagination/usePagination.js.map +1 -0
- package/dist/common/interactive/pagination/usePagination.mjs +25 -0
- package/dist/common/interactive/pagination/usePagination.mjs.map +1 -0
- package/dist/common/interactive/popover-wrapper.js +138 -0
- package/dist/common/interactive/popover-wrapper.js.map +1 -0
- package/dist/common/interactive/popover-wrapper.mjs +116 -0
- package/dist/common/interactive/popover-wrapper.mjs.map +1 -0
- package/dist/common/interactive/pressable.js +84 -0
- package/dist/common/interactive/pressable.js.map +1 -0
- package/dist/common/interactive/pressable.mjs +62 -0
- package/dist/common/interactive/pressable.mjs.map +1 -0
- package/dist/common/interactive/select/context.js +38 -0
- package/dist/common/interactive/select/context.js.map +1 -0
- package/dist/common/interactive/select/context.mjs +14 -0
- package/dist/common/interactive/select/context.mjs.map +1 -0
- package/dist/common/interactive/select/index.js +123 -0
- package/dist/common/interactive/select/index.js.map +1 -0
- package/dist/common/interactive/select/index.mjs +18 -0
- package/dist/common/interactive/select/index.mjs.map +1 -0
- package/dist/common/interactive/select/select-body.js +89 -0
- package/dist/common/interactive/select/select-body.js.map +1 -0
- package/dist/common/interactive/select/select-body.mjs +67 -0
- package/dist/common/interactive/select/select-body.mjs.map +1 -0
- package/dist/common/interactive/select/select-close.js +38 -0
- package/dist/common/interactive/select/select-close.js.map +1 -0
- package/dist/common/interactive/select/select-close.mjs +16 -0
- package/dist/common/interactive/select/select-close.mjs.map +1 -0
- package/dist/common/interactive/select/select-content-auto-layout.js +221 -0
- package/dist/common/interactive/select/select-content-auto-layout.js.map +1 -0
- package/dist/common/interactive/select/select-content-auto-layout.mjs +199 -0
- package/dist/common/interactive/select/select-content-auto-layout.mjs.map +1 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.js +411 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.js.map +1 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.mjs +389 -0
- package/dist/common/interactive/select/select-content-group-auto-layout.mjs.map +1 -0
- package/dist/common/interactive/select/select-content.js +187 -0
- package/dist/common/interactive/select/select-content.js.map +1 -0
- package/dist/common/interactive/select/select-content.mjs +165 -0
- package/dist/common/interactive/select/select-content.mjs.map +1 -0
- package/dist/common/interactive/select/select-footer.js +82 -0
- package/dist/common/interactive/select/select-footer.js.map +1 -0
- package/dist/common/interactive/select/select-footer.mjs +60 -0
- package/dist/common/interactive/select/select-footer.mjs.map +1 -0
- package/dist/common/interactive/select/select-item.js +214 -0
- package/dist/common/interactive/select/select-item.js.map +1 -0
- package/dist/common/interactive/select/select-item.mjs +191 -0
- package/dist/common/interactive/select/select-item.mjs.map +1 -0
- package/dist/common/interactive/select/select-layout.js +66 -0
- package/dist/common/interactive/select/select-layout.js.map +1 -0
- package/dist/common/interactive/select/select-layout.mjs +41 -0
- package/dist/common/interactive/select/select-layout.mjs.map +1 -0
- package/dist/common/interactive/select/select-search.js +55 -0
- package/dist/common/interactive/select/select-search.js.map +1 -0
- package/dist/common/interactive/select/select-search.mjs +33 -0
- package/dist/common/interactive/select/select-search.mjs.map +1 -0
- package/dist/common/interactive/select/select-states.js +57 -0
- package/dist/common/interactive/select/select-states.js.map +1 -0
- package/dist/common/interactive/select/select-states.mjs +34 -0
- package/dist/common/interactive/select/select-states.mjs.map +1 -0
- package/dist/common/interactive/select/select-trigger.js +310 -0
- package/dist/common/interactive/select/select-trigger.js.map +1 -0
- package/dist/common/interactive/select/select-trigger.mjs +286 -0
- package/dist/common/interactive/select/select-trigger.mjs.map +1 -0
- package/dist/common/interactive/select/select-value.js +52 -0
- package/dist/common/interactive/select/select-value.js.map +1 -0
- package/dist/common/interactive/select/select-value.mjs +30 -0
- package/dist/common/interactive/select/select-value.mjs.map +1 -0
- package/dist/common/interactive/select/select.js +184 -0
- package/dist/common/interactive/select/select.js.map +1 -0
- package/dist/common/interactive/select/select.mjs +162 -0
- package/dist/common/interactive/select/select.mjs.map +1 -0
- package/dist/common/interactive/select/types.js +4 -0
- package/dist/common/interactive/select/types.js.map +1 -0
- package/dist/common/interactive/select/types.mjs +3 -0
- package/dist/common/interactive/select/types.mjs.map +1 -0
- package/dist/common/interactive/select/utils.js +31 -0
- package/dist/common/interactive/select/utils.js.map +1 -0
- package/dist/common/interactive/select/utils.mjs +28 -0
- package/dist/common/interactive/select/utils.mjs.map +1 -0
- package/dist/common/interactive/select/variants.js +27 -0
- package/dist/common/interactive/select/variants.js.map +1 -0
- package/dist/common/interactive/select/variants.mjs +25 -0
- package/dist/common/interactive/select/variants.mjs.map +1 -0
- package/dist/common/interactive/select-chip.js +76 -0
- package/dist/common/interactive/select-chip.js.map +1 -0
- package/dist/common/interactive/select-chip.mjs +74 -0
- package/dist/common/interactive/select-chip.mjs.map +1 -0
- package/dist/common/interactive/select-level.js +236 -0
- package/dist/common/interactive/select-level.js.map +1 -0
- package/dist/common/interactive/select-level.mjs +230 -0
- package/dist/common/interactive/select-level.mjs.map +1 -0
- package/dist/common/interactive/select-range.js +211 -0
- package/dist/common/interactive/select-range.js.map +1 -0
- package/dist/common/interactive/select-range.mjs +209 -0
- package/dist/common/interactive/select-range.mjs.map +1 -0
- package/dist/common/interactive/select-with-api.js +767 -0
- package/dist/common/interactive/select-with-api.js.map +1 -0
- package/dist/common/interactive/select-with-api.mjs +758 -0
- package/dist/common/interactive/select-with-api.mjs.map +1 -0
- package/dist/common/interactive/select.js +15 -0
- package/dist/common/interactive/select.js.map +1 -0
- package/dist/common/interactive/select.mjs +4 -0
- package/dist/common/interactive/select.mjs.map +1 -0
- package/dist/common/interactive/sheet-wrapper.js +105 -0
- package/dist/common/interactive/sheet-wrapper.js.map +1 -0
- package/dist/common/interactive/sheet-wrapper.mjs +83 -0
- package/dist/common/interactive/sheet-wrapper.mjs.map +1 -0
- package/dist/common/interactive/table/enhanced-table.js +390 -0
- package/dist/common/interactive/table/enhanced-table.js.map +1 -0
- package/dist/common/interactive/table/enhanced-table.mjs +388 -0
- package/dist/common/interactive/table/enhanced-table.mjs.map +1 -0
- package/dist/common/interactive/table/index.js +83 -0
- package/dist/common/interactive/table/index.js.map +1 -0
- package/dist/common/interactive/table/index.mjs +68 -0
- package/dist/common/interactive/table/index.mjs.map +1 -0
- package/dist/common/interactive/table/table-pagination.js +12 -0
- package/dist/common/interactive/table/table-pagination.js.map +1 -0
- package/dist/common/interactive/table/table-pagination.mjs +10 -0
- package/dist/common/interactive/table/table-pagination.mjs.map +1 -0
- package/dist/common/interactive/table/types.js +4 -0
- package/dist/common/interactive/table/types.js.map +1 -0
- package/dist/common/interactive/table/types.mjs +3 -0
- package/dist/common/interactive/table/types.mjs.map +1 -0
- package/dist/common/interactive/time-picker.js +313 -0
- package/dist/common/interactive/time-picker.js.map +1 -0
- package/dist/common/interactive/time-picker.mjs +307 -0
- package/dist/common/interactive/time-picker.mjs.map +1 -0
- package/dist/common/interactive/types.js +4 -0
- package/dist/common/interactive/types.js.map +1 -0
- package/dist/common/interactive/types.mjs +3 -0
- package/dist/common/interactive/types.mjs.map +1 -0
- package/dist/common/pages/page-404.js +16 -0
- package/dist/common/pages/page-404.js.map +1 -0
- package/dist/common/pages/page-404.mjs +11 -0
- package/dist/common/pages/page-404.mjs.map +1 -0
- package/dist/common/pages/page-500.js +30 -0
- package/dist/common/pages/page-500.js.map +1 -0
- package/dist/common/pages/page-500.mjs +25 -0
- package/dist/common/pages/page-500.mjs.map +1 -0
- package/dist/components/accordion.js +65 -0
- package/dist/components/accordion.js.map +1 -0
- package/dist/components/accordion.mjs +39 -0
- package/dist/components/accordion.mjs.map +1 -0
- package/dist/components/alert-dialog.js +231 -0
- package/dist/components/alert-dialog.js.map +1 -0
- package/dist/components/alert-dialog.mjs +197 -0
- package/dist/components/alert-dialog.mjs.map +1 -0
- package/dist/components/alert.js +97 -0
- package/dist/components/alert.js.map +1 -0
- package/dist/components/alert.mjs +72 -0
- package/dist/components/alert.mjs.map +1 -0
- package/dist/components/aspect-ratio.js +29 -0
- package/dist/components/aspect-ratio.js.map +1 -0
- package/dist/components/aspect-ratio.mjs +7 -0
- package/dist/components/aspect-ratio.mjs.map +1 -0
- package/dist/components/avatar.js +64 -0
- package/dist/components/avatar.js.map +1 -0
- package/dist/components/avatar.mjs +39 -0
- package/dist/components/avatar.mjs.map +1 -0
- package/dist/components/badge.js +72 -0
- package/dist/components/badge.js.map +1 -0
- package/dist/components/badge.mjs +69 -0
- package/dist/components/badge.mjs.map +1 -0
- package/dist/components/breadcrumb.js +109 -0
- package/dist/components/breadcrumb.js.map +1 -0
- package/dist/components/breadcrumb.mjs +81 -0
- package/dist/components/breadcrumb.mjs.map +1 -0
- package/dist/components/button.js +250 -0
- package/dist/components/button.js.map +1 -0
- package/dist/components/button.mjs +226 -0
- package/dist/components/button.mjs.map +1 -0
- package/dist/components/calendar.js +681 -0
- package/dist/components/calendar.js.map +1 -0
- package/dist/components/calendar.mjs +659 -0
- package/dist/components/calendar.mjs.map +1 -0
- package/dist/components/card.js +98 -0
- package/dist/components/card.js.map +1 -0
- package/dist/components/card.mjs +71 -0
- package/dist/components/card.mjs.map +1 -0
- package/dist/components/carousel.js +237 -0
- package/dist/components/carousel.js.map +1 -0
- package/dist/components/carousel.mjs +208 -0
- package/dist/components/carousel.mjs.map +1 -0
- package/dist/components/chart.js +252 -0
- package/dist/components/chart.js.map +1 -0
- package/dist/components/chart.mjs +224 -0
- package/dist/components/chart.mjs.map +1 -0
- package/dist/components/checkbox.js +97 -0
- package/dist/components/checkbox.js.map +1 -0
- package/dist/components/checkbox.mjs +74 -0
- package/dist/components/checkbox.mjs.map +1 -0
- package/dist/components/chip.js +88 -0
- package/dist/components/chip.js.map +1 -0
- package/dist/components/chip.mjs +82 -0
- package/dist/components/chip.mjs.map +1 -0
- package/dist/components/collapsible.js +33 -0
- package/dist/components/collapsible.js.map +1 -0
- package/dist/components/collapsible.mjs +9 -0
- package/dist/components/collapsible.mjs.map +1 -0
- package/dist/components/command.js +125 -0
- package/dist/components/command.js.map +1 -0
- package/dist/components/command.mjs +95 -0
- package/dist/components/command.mjs.map +1 -0
- package/dist/components/context-menu.js +168 -0
- package/dist/components/context-menu.js.map +1 -0
- package/dist/components/context-menu.mjs +131 -0
- package/dist/components/context-menu.mjs.map +1 -0
- package/dist/components/dialog.js +192 -0
- package/dist/components/dialog.js.map +1 -0
- package/dist/components/dialog.mjs +159 -0
- package/dist/components/dialog.mjs.map +1 -0
- package/dist/components/drawer.js +98 -0
- package/dist/components/drawer.js.map +1 -0
- package/dist/components/drawer.mjs +67 -0
- package/dist/components/drawer.mjs.map +1 -0
- package/dist/components/dropdown-menu.js +163 -0
- package/dist/components/dropdown-menu.js.map +1 -0
- package/dist/components/dropdown-menu.mjs +126 -0
- package/dist/components/dropdown-menu.mjs.map +1 -0
- package/dist/components/form.js +123 -0
- package/dist/components/form.js.map +1 -0
- package/dist/components/form.mjs +94 -0
- package/dist/components/form.mjs.map +1 -0
- package/dist/components/hover-card.js +50 -0
- package/dist/components/hover-card.js.map +1 -0
- package/dist/components/hover-card.mjs +25 -0
- package/dist/components/hover-card.mjs.map +1 -0
- package/dist/components/input-otp.js +84 -0
- package/dist/components/input-otp.js.map +1 -0
- package/dist/components/input-otp.mjs +59 -0
- package/dist/components/input-otp.mjs.map +1 -0
- package/dist/components/input.js +858 -0
- package/dist/components/input.js.map +1 -0
- package/dist/components/input.mjs +831 -0
- package/dist/components/input.mjs.map +1 -0
- package/dist/components/label.js +38 -0
- package/dist/components/label.js.map +1 -0
- package/dist/components/label.mjs +15 -0
- package/dist/components/label.mjs.map +1 -0
- package/dist/components/lottie.js +59 -0
- package/dist/components/lottie.js.map +1 -0
- package/dist/components/lottie.mjs +49 -0
- package/dist/components/lottie.mjs.map +1 -0
- package/dist/components/menubar.js +195 -0
- package/dist/components/menubar.js.map +1 -0
- package/dist/components/menubar.mjs +157 -0
- package/dist/components/menubar.mjs.map +1 -0
- package/dist/components/navigation-menu.js +126 -0
- package/dist/components/navigation-menu.js.map +1 -0
- package/dist/components/navigation-menu.mjs +95 -0
- package/dist/components/navigation-menu.mjs.map +1 -0
- package/dist/components/pagination.js +112 -0
- package/dist/components/pagination.js.map +1 -0
- package/dist/components/pagination.mjs +84 -0
- package/dist/components/pagination.mjs.map +1 -0
- package/dist/components/popover.js +63 -0
- package/dist/components/popover.js.map +1 -0
- package/dist/components/popover.mjs +38 -0
- package/dist/components/popover.mjs.map +1 -0
- package/dist/components/progress.js +50 -0
- package/dist/components/progress.js.map +1 -0
- package/dist/components/progress.mjs +27 -0
- package/dist/components/progress.mjs.map +1 -0
- package/dist/components/radio-group.js +91 -0
- package/dist/components/radio-group.js.map +1 -0
- package/dist/components/radio-group.mjs +67 -0
- package/dist/components/radio-group.mjs.map +1 -0
- package/dist/components/resizable.js +59 -0
- package/dist/components/resizable.js.map +1 -0
- package/dist/components/resizable.mjs +35 -0
- package/dist/components/resizable.mjs.map +1 -0
- package/dist/components/responsive-popover.js +74 -0
- package/dist/components/responsive-popover.js.map +1 -0
- package/dist/components/responsive-popover.mjs +50 -0
- package/dist/components/responsive-popover.mjs.map +1 -0
- package/dist/components/scroll-area.js +63 -0
- package/dist/components/scroll-area.js.map +1 -0
- package/dist/components/scroll-area.mjs +39 -0
- package/dist/components/scroll-area.mjs.map +1 -0
- package/dist/components/separator.js +47 -0
- package/dist/components/separator.js.map +1 -0
- package/dist/components/separator.mjs +24 -0
- package/dist/components/separator.mjs.map +1 -0
- package/dist/components/sheet.js +239 -0
- package/dist/components/sheet.js.map +1 -0
- package/dist/components/sheet.mjs +206 -0
- package/dist/components/sheet.mjs.map +1 -0
- package/dist/components/sidebar.js +888 -0
- package/dist/components/sidebar.js.map +1 -0
- package/dist/components/sidebar.mjs +842 -0
- package/dist/components/sidebar.mjs.map +1 -0
- package/dist/components/skeleton.js +153 -0
- package/dist/components/skeleton.js.map +1 -0
- package/dist/components/skeleton.mjs +127 -0
- package/dist/components/skeleton.mjs.map +1 -0
- package/dist/components/slider.js +45 -0
- package/dist/components/slider.js.map +1 -0
- package/dist/components/slider.mjs +22 -0
- package/dist/components/slider.mjs.map +1 -0
- package/dist/components/sonner.js +76 -0
- package/dist/components/sonner.js.map +1 -0
- package/dist/components/sonner.mjs +71 -0
- package/dist/components/sonner.mjs.map +1 -0
- package/dist/components/spinner.js +59 -0
- package/dist/components/spinner.js.map +1 -0
- package/dist/components/spinner.mjs +36 -0
- package/dist/components/spinner.mjs.map +1 -0
- package/dist/components/stepper.js +726 -0
- package/dist/components/stepper.js.map +1 -0
- package/dist/components/stepper.mjs +702 -0
- package/dist/components/stepper.mjs.map +1 -0
- package/dist/components/switch.js +85 -0
- package/dist/components/switch.js.map +1 -0
- package/dist/components/switch.mjs +62 -0
- package/dist/components/switch.mjs.map +1 -0
- package/dist/components/table.js +91 -0
- package/dist/components/table.js.map +1 -0
- package/dist/components/table.mjs +62 -0
- package/dist/components/table.mjs.map +1 -0
- package/dist/components/tabs.js +287 -0
- package/dist/components/tabs.js.map +1 -0
- package/dist/components/tabs.mjs +261 -0
- package/dist/components/tabs.mjs.map +1 -0
- package/dist/components/textarea.js +200 -0
- package/dist/components/textarea.js.map +1 -0
- package/dist/components/textarea.mjs +174 -0
- package/dist/components/textarea.mjs.map +1 -0
- package/dist/components/toggle-group.js +67 -0
- package/dist/components/toggle-group.js.map +1 -0
- package/dist/components/toggle-group.mjs +43 -0
- package/dist/components/toggle-group.mjs.map +1 -0
- package/dist/components/toggle.js +63 -0
- package/dist/components/toggle.js.map +1 -0
- package/dist/components/toggle.mjs +39 -0
- package/dist/components/toggle.mjs.map +1 -0
- package/dist/components/tooltip.js +172 -0
- package/dist/components/tooltip.js.map +1 -0
- package/dist/components/tooltip.mjs +145 -0
- package/dist/components/tooltip.mjs.map +1 -0
- package/dist/hooks/index.js +27 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/index.mjs +6 -0
- package/dist/hooks/index.mjs.map +1 -0
- package/dist/hooks/useCopyToClipboard.js +59 -0
- package/dist/hooks/useCopyToClipboard.js.map +1 -0
- package/dist/hooks/useCopyToClipboard.mjs +57 -0
- package/dist/hooks/useCopyToClipboard.mjs.map +1 -0
- package/dist/hooks/useDevice.js +20 -0
- package/dist/hooks/useDevice.js.map +1 -0
- package/dist/hooks/useDevice.mjs +14 -0
- package/dist/hooks/useDevice.mjs.map +1 -0
- package/dist/hooks/useDialogTracking.js +113 -0
- package/dist/hooks/useDialogTracking.js.map +1 -0
- package/dist/hooks/useDialogTracking.mjs +91 -0
- package/dist/hooks/useDialogTracking.mjs.map +1 -0
- package/dist/hooks/useIsMounted.js +15 -0
- package/dist/hooks/useIsMounted.js.map +1 -0
- package/dist/hooks/useIsMounted.mjs +13 -0
- package/dist/hooks/useIsMounted.mjs.map +1 -0
- package/dist/hooks/usePathname.js +85 -0
- package/dist/hooks/usePathname.js.map +1 -0
- package/dist/hooks/usePathname.mjs +83 -0
- package/dist/hooks/usePathname.mjs.map +1 -0
- package/dist/icons.js +14 -0
- package/dist/icons.js.map +1 -0
- package/dist/icons.mjs +3 -0
- package/dist/icons.mjs.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +403 -8151
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +62 -7844
- package/dist/index.mjs.map +1 -1
- package/dist/lib/formatCurrency.js +187 -0
- package/dist/lib/formatCurrency.js.map +1 -0
- package/dist/lib/formatCurrency.mjs +185 -0
- package/dist/lib/formatCurrency.mjs.map +1 -0
- package/dist/lib/helpers.js +171 -0
- package/dist/lib/helpers.js.map +1 -0
- package/dist/lib/helpers.mjs +157 -0
- package/dist/lib/helpers.mjs.map +1 -0
- package/dist/lib/index.js +33 -0
- package/dist/lib/index.js.map +1 -0
- package/dist/lib/index.mjs +6 -0
- package/dist/lib/index.mjs.map +1 -0
- package/dist/lib/types.js +11 -0
- package/dist/lib/types.js.map +1 -0
- package/dist/lib/types.mjs +9 -0
- package/dist/lib/types.mjs.map +1 -0
- package/dist/lib/utils.js +24 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/lib/utils.mjs +19 -0
- package/dist/lib/utils.mjs.map +1 -0
- package/dist/providers/DeviceSizeWatcher/index.js +72 -0
- package/dist/providers/DeviceSizeWatcher/index.js.map +1 -0
- package/dist/providers/DeviceSizeWatcher/index.mjs +47 -0
- package/dist/providers/DeviceSizeWatcher/index.mjs.map +1 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.js +22 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.js.map +1 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.mjs +20 -0
- package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.mjs.map +1 -0
- package/dist/providers/UISystemProvider.js +197 -0
- package/dist/providers/UISystemProvider.js.map +1 -0
- package/dist/providers/UISystemProvider.mjs +188 -0
- package/dist/providers/UISystemProvider.mjs.map +1 -0
- package/dist/providers/index.js +24 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/providers/index.mjs +3 -0
- package/dist/providers/index.mjs.map +1 -0
- package/dist/theme.js +333 -0
- package/dist/theme.js.map +1 -0
- package/dist/theme.mjs +327 -0
- package/dist/theme.mjs.map +1 -0
- package/package.json +1 -1
- package/dist/index.css +0 -43
- package/dist/index.css.map +0 -1
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
4
|
+
var React = require('react');
|
|
5
|
+
var useDevice = require('@/hooks/useDevice');
|
|
6
|
+
var utils = require('@/lib/utils');
|
|
7
|
+
var alertDialog = require('../../components/alert-dialog');
|
|
8
|
+
var scrollArea = require('../../components/scroll-area');
|
|
9
|
+
|
|
10
|
+
function _interopNamespace(e) {
|
|
11
|
+
if (e && e.__esModule) return e;
|
|
12
|
+
var n = Object.create(null);
|
|
13
|
+
if (e) {
|
|
14
|
+
Object.keys(e).forEach(function (k) {
|
|
15
|
+
if (k !== 'default') {
|
|
16
|
+
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
17
|
+
Object.defineProperty(n, k, d.get ? d : {
|
|
18
|
+
enumerable: true,
|
|
19
|
+
get: function () { return e[k]; }
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
n.default = e;
|
|
25
|
+
return Object.freeze(n);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
var React__namespace = /*#__PURE__*/_interopNamespace(React);
|
|
29
|
+
|
|
30
|
+
const AlertDialogWrapper = React__namespace.forwardRef(
|
|
31
|
+
({
|
|
32
|
+
// Trigger props
|
|
33
|
+
trigger,
|
|
34
|
+
triggerAsChild = false,
|
|
35
|
+
triggerClassName,
|
|
36
|
+
// Header props
|
|
37
|
+
showHeader = true,
|
|
38
|
+
title,
|
|
39
|
+
titleClassName,
|
|
40
|
+
description,
|
|
41
|
+
descriptionClassName,
|
|
42
|
+
headerClassName,
|
|
43
|
+
headerContent,
|
|
44
|
+
// Footer props
|
|
45
|
+
showFooter = true,
|
|
46
|
+
footerContent,
|
|
47
|
+
footerClassName,
|
|
48
|
+
// Action buttons
|
|
49
|
+
actionLabel = "Confirm",
|
|
50
|
+
actionVariant = "default",
|
|
51
|
+
actionClassName,
|
|
52
|
+
onActionClick,
|
|
53
|
+
cancelLabel = "Cancel",
|
|
54
|
+
cancelClassName,
|
|
55
|
+
onCancelClick,
|
|
56
|
+
showDefaultActions = true,
|
|
57
|
+
// Content props
|
|
58
|
+
children,
|
|
59
|
+
contentClassName,
|
|
60
|
+
childrenClassName,
|
|
61
|
+
// AlertDialog behavior props
|
|
62
|
+
open,
|
|
63
|
+
onOpenChange,
|
|
64
|
+
defaultOpen,
|
|
65
|
+
// ScrollArea props
|
|
66
|
+
autoHeight = true,
|
|
67
|
+
// Close button props
|
|
68
|
+
hasCloseButton = true,
|
|
69
|
+
// Size variants
|
|
70
|
+
size = "lg",
|
|
71
|
+
// Tracking props
|
|
72
|
+
trackingNameView,
|
|
73
|
+
trackingNameClose,
|
|
74
|
+
trackingData,
|
|
75
|
+
trackingIndex,
|
|
76
|
+
// Other props
|
|
77
|
+
className,
|
|
78
|
+
...props
|
|
79
|
+
}, ref) => {
|
|
80
|
+
const { isDesktop } = useDevice.useDevice();
|
|
81
|
+
const effectiveAutoHeight = autoHeight && isDesktop;
|
|
82
|
+
const contentComponent = effectiveAutoHeight ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: utils.cn("h-full overflow-y-auto px-4 py-2 pb-4", childrenClassName), children }) : /* @__PURE__ */ jsxRuntime.jsx("div", { className: "h-full min-h-0 flex-1", children: /* @__PURE__ */ jsxRuntime.jsx(scrollArea.ScrollArea, { className: "h-full w-full", children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: utils.cn("h-full px-4", childrenClassName), children }) }) });
|
|
83
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(alertDialog.AlertDialog, { open, onOpenChange, defaultOpen, children: [
|
|
84
|
+
trigger && /* @__PURE__ */ jsxRuntime.jsx(alertDialog.AlertDialogTrigger, { asChild: triggerAsChild, className: triggerClassName, children: trigger }),
|
|
85
|
+
/* @__PURE__ */ jsxRuntime.jsxs(
|
|
86
|
+
alertDialog.AlertDialogContent,
|
|
87
|
+
{
|
|
88
|
+
ref,
|
|
89
|
+
hasCloseButton,
|
|
90
|
+
size,
|
|
91
|
+
trackingNameView,
|
|
92
|
+
trackingNameClose,
|
|
93
|
+
trackingData,
|
|
94
|
+
trackingIndex,
|
|
95
|
+
className: utils.cn(
|
|
96
|
+
"flex flex-col p-0",
|
|
97
|
+
// For autoHeight dialogs on desktop, handle max-height
|
|
98
|
+
effectiveAutoHeight && "max-h-full lg:max-h-[88vh]",
|
|
99
|
+
// Default height for non-full size dialogs or mobile/tablet
|
|
100
|
+
!effectiveAutoHeight && size !== "full" && "h-full lg:h-[500px]",
|
|
101
|
+
className,
|
|
102
|
+
contentClassName
|
|
103
|
+
),
|
|
104
|
+
...props,
|
|
105
|
+
children: [
|
|
106
|
+
showHeader && (title || description || headerContent) && /* @__PURE__ */ jsxRuntime.jsx(alertDialog.AlertDialogHeader, { className: utils.cn("flex-shrink-0", headerClassName), children: headerContent ? headerContent : /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
|
|
107
|
+
title && /* @__PURE__ */ jsxRuntime.jsx(alertDialog.AlertDialogTitle, { className: titleClassName, children: title }),
|
|
108
|
+
description && /* @__PURE__ */ jsxRuntime.jsx(alertDialog.AlertDialogDescription, { className: descriptionClassName, children: description })
|
|
109
|
+
] }) }),
|
|
110
|
+
contentComponent,
|
|
111
|
+
showFooter && /* @__PURE__ */ jsxRuntime.jsx(
|
|
112
|
+
alertDialog.AlertDialogFooter,
|
|
113
|
+
{
|
|
114
|
+
className: utils.cn("border-border flex-shrink-0 border-t p-4", footerClassName),
|
|
115
|
+
children: footerContent ? footerContent : showDefaultActions && /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
|
|
116
|
+
/* @__PURE__ */ jsxRuntime.jsx(alertDialog.AlertDialogCancel, { className: cancelClassName, onClick: onCancelClick, children: cancelLabel }),
|
|
117
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
118
|
+
alertDialog.AlertDialogAction,
|
|
119
|
+
{
|
|
120
|
+
className: utils.cn(
|
|
121
|
+
actionVariant === "destructive" && "bg-destructive hover:bg-destructive/90",
|
|
122
|
+
actionClassName
|
|
123
|
+
),
|
|
124
|
+
onClick: onActionClick,
|
|
125
|
+
children: actionLabel
|
|
126
|
+
}
|
|
127
|
+
)
|
|
128
|
+
] })
|
|
129
|
+
}
|
|
130
|
+
)
|
|
131
|
+
]
|
|
132
|
+
}
|
|
133
|
+
)
|
|
134
|
+
] });
|
|
135
|
+
}
|
|
136
|
+
);
|
|
137
|
+
AlertDialogWrapper.displayName = "AlertDialogWrapper";
|
|
138
|
+
|
|
139
|
+
exports.AlertDialogWrapper = AlertDialogWrapper;
|
|
140
|
+
//# sourceMappingURL=alert-dialog-wrapper.js.map
|
|
141
|
+
//# sourceMappingURL=alert-dialog-wrapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/common/interactive/alert-dialog-wrapper.tsx"],"names":["React","useDevice","jsx","cn","ScrollArea","jsxs","AlertDialog","AlertDialogTrigger","AlertDialogContent","AlertDialogHeader","Fragment","AlertDialogTitle","AlertDialogDescription","AlertDialogFooter","AlertDialogCancel","AlertDialogAction"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiFA,MAAM,qBAAqBA,gBAAA,CAAM,UAAA;AAAA,EAI/B,CACE;AAAA;AAAA,IAEE,OAAA;AAAA,IACA,cAAA,GAAiB,KAAA;AAAA,IACjB,gBAAA;AAAA;AAAA,IAGA,UAAA,GAAa,IAAA;AAAA,IACb,KAAA;AAAA,IACA,cAAA;AAAA,IACA,WAAA;AAAA,IACA,oBAAA;AAAA,IACA,eAAA;AAAA,IACA,aAAA;AAAA;AAAA,IAGA,UAAA,GAAa,IAAA;AAAA,IACb,aAAA;AAAA,IACA,eAAA;AAAA;AAAA,IAGA,WAAA,GAAc,SAAA;AAAA,IACd,aAAA,GAAgB,SAAA;AAAA,IAChB,eAAA;AAAA,IACA,aAAA;AAAA,IAEA,WAAA,GAAc,QAAA;AAAA,IACd,eAAA;AAAA,IACA,aAAA;AAAA,IAEA,kBAAA,GAAqB,IAAA;AAAA;AAAA,IAGrB,QAAA;AAAA,IACA,gBAAA;AAAA,IACA,iBAAA;AAAA;AAAA,IAGA,IAAA;AAAA,IACA,YAAA;AAAA,IACA,WAAA;AAAA;AAAA,IAGA,UAAA,GAAa,IAAA;AAAA;AAAA,IAGb,cAAA,GAAiB,IAAA;AAAA;AAAA,IAGjB,IAAA,GAAO,IAAA;AAAA;AAAA,IAGP,gBAAA;AAAA,IACA,iBAAA;AAAA,IACA,YAAA;AAAA,IACA,aAAA;AAAA;AAAA,IAGA,SAAA;AAAA,IACA,GAAG;AAAA,KAEL,GAAA,KACG;AACH,IAAA,MAAM,EAAE,SAAA,EAAU,GAAIC,mBAAA,EAAU;AAGhC,IAAA,MAAM,sBAAsB,UAAA,IAAc,SAAA;AAE1C,IAAA,MAAM,gBAAA,GAAmB,mBAAA,mBACvBC,cAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAWC,QAAA,CAAG,uCAAA,EAAyC,iBAAiB,CAAA,EAC1E,QAAA,EACH,CAAA,mBAEAD,cAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAU,uBAAA,EACb,QAAA,kBAAAA,cAAA,CAACE,qBAAA,EAAA,EAAW,SAAA,EAAU,eAAA,EACpB,QAAA,kBAAAF,cAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAWC,QAAA,CAAG,aAAA,EAAe,iBAAiB,CAAA,EAAI,QAAA,EAAS,CAAA,EAClE,CAAA,EACF,CAAA;AAGF,IAAA,uBACEE,eAAA,CAACC,uBAAA,EAAA,EAAY,IAAA,EAAY,YAAA,EAA4B,WAAA,EAClD,QAAA,EAAA;AAAA,MAAA,OAAA,mCACEC,8BAAA,EAAA,EAAmB,OAAA,EAAS,cAAA,EAAgB,SAAA,EAAW,kBACrD,QAAA,EAAA,OAAA,EACH,CAAA;AAAA,sBAGFF,eAAA;AAAA,QAACG,8BAAA;AAAA,QAAA;AAAA,UACC,GAAA;AAAA,UACA,cAAA;AAAA,UACA,IAAA;AAAA,UACA,gBAAA;AAAA,UACA,iBAAA;AAAA,UACA,YAAA;AAAA,UACA,aAAA;AAAA,UACA,SAAA,EAAWL,QAAA;AAAA,YACT,mBAAA;AAAA;AAAA,YAEA,mBAAA,IAAuB,4BAAA;AAAA;AAAA,YAEvB,CAAC,mBAAA,IAAuB,IAAA,KAAS,MAAA,IAAU,qBAAA;AAAA,YAC3C,SAAA;AAAA,YACA;AAAA,WACF;AAAA,UACC,GAAG,KAAA;AAAA,UAEH,QAAA,EAAA;AAAA,YAAA,UAAA,KAAe,KAAA,IAAS,WAAA,IAAe,aAAA,CAAA,oBACtCD,cAAA,CAACO,6BAAA,EAAA,EAAkB,SAAA,EAAWN,QAAA,CAAG,eAAA,EAAiB,eAAe,CAAA,EAC9D,QAAA,EAAA,aAAA,GACC,aAAA,mBAEAE,eAAA,CAAAK,mBAAA,EAAA,EACG,QAAA,EAAA;AAAA,cAAA,KAAA,oBAASR,cAAA,CAACS,4BAAA,EAAA,EAAiB,SAAA,EAAW,cAAA,EAAiB,QAAA,EAAA,KAAA,EAAM,CAAA;AAAA,cAC7D,WAAA,oBACCT,cAAA,CAACU,kCAAA,EAAA,EAAuB,SAAA,EAAW,sBAChC,QAAA,EAAA,WAAA,EACH;AAAA,aAAA,EAEJ,CAAA,EAEJ,CAAA;AAAA,YAGD,gBAAA;AAAA,YAEA,UAAA,oBACCV,cAAA;AAAA,cAACW,6BAAA;AAAA,cAAA;AAAA,gBACC,SAAA,EAAWV,QAAA,CAAG,0CAAA,EAA4C,eAAe,CAAA;AAAA,gBAExE,QAAA,EAAA,aAAA,GACG,aAAA,GACA,kBAAA,oBACEE,eAAA,CAAAK,mBAAA,EAAA,EACE,QAAA,EAAA;AAAA,kCAAAR,cAAA,CAACY,6BAAA,EAAA,EAAkB,SAAA,EAAW,eAAA,EAAiB,OAAA,EAAS,eACrD,QAAA,EAAA,WAAA,EACH,CAAA;AAAA,kCACAZ,cAAA;AAAA,oBAACa,6BAAA;AAAA,oBAAA;AAAA,sBACC,SAAA,EAAWZ,QAAA;AAAA,wBACT,kBAAkB,aAAA,IAChB,wCAAA;AAAA,wBACF;AAAA,uBACF;AAAA,sBACA,OAAA,EAAS,aAAA;AAAA,sBAER,QAAA,EAAA;AAAA;AAAA;AACH,iBAAA,EACF;AAAA;AAAA;AAER;AAAA;AAAA;AAEJ,KAAA,EACF,CAAA;AAAA,EAEJ;AACF;AAEA,kBAAA,CAAmB,WAAA,GAAc,oBAAA","file":"alert-dialog-wrapper.js","sourcesContent":["'use client';\n\nimport * as React from 'react';\n\nimport { useDevice } from '@/hooks/useDevice';\nimport { cn } from '@/lib/utils';\nimport {\n AlertDialog,\n AlertDialogAction,\n AlertDialogCancel,\n AlertDialogContent,\n AlertDialogDescription,\n AlertDialogFooter,\n AlertDialogHeader,\n AlertDialogTitle,\n AlertDialogTrigger,\n alertDialogVariants,\n type VariantProps,\n} from '../../components/alert-dialog';\nimport { ScrollArea } from '../../components/scroll-area';\n\ninterface AlertDialogWrapperProps extends React.ComponentPropsWithoutRef<\n typeof AlertDialogContent\n> {\n // Trigger props\n trigger?: React.ReactNode;\n triggerAsChild?: boolean;\n triggerClassName?: string;\n\n // Header props\n showHeader?: boolean;\n title?: string;\n titleClassName?: string;\n description?: string;\n descriptionClassName?: string;\n headerClassName?: string;\n headerContent?: React.ReactNode;\n\n // Footer props\n showFooter?: boolean;\n footerContent?: React.ReactNode;\n footerClassName?: string;\n\n // Action buttons\n actionLabel?: string;\n actionVariant?: 'default' | 'destructive';\n actionClassName?: string;\n onActionClick?: () => void;\n\n cancelLabel?: string;\n cancelClassName?: string;\n onCancelClick?: () => void;\n\n showDefaultActions?: boolean;\n\n // Content props\n children?: React.ReactNode;\n contentClassName?: string;\n childrenClassName?: string;\n\n // AlertDialog behavior props\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n defaultOpen?: boolean;\n\n // ScrollArea props\n autoHeight?: boolean;\n\n // Close button props\n hasCloseButton?: boolean;\n\n // Size variants\n size?: VariantProps<typeof alertDialogVariants>['size'];\n\n // Tracking props\n trackingNameView?: string;\n trackingNameClose?: string;\n trackingData?: Record<string, any>;\n trackingIndex?: number;\n}\n\nconst AlertDialogWrapper = React.forwardRef<\n React.ElementRef<typeof AlertDialogContent>,\n AlertDialogWrapperProps\n>(\n (\n {\n // Trigger props\n trigger,\n triggerAsChild = false,\n triggerClassName,\n\n // Header props\n showHeader = true,\n title,\n titleClassName,\n description,\n descriptionClassName,\n headerClassName,\n headerContent,\n\n // Footer props\n showFooter = true,\n footerContent,\n footerClassName,\n\n // Action buttons\n actionLabel = 'Confirm',\n actionVariant = 'default',\n actionClassName,\n onActionClick,\n\n cancelLabel = 'Cancel',\n cancelClassName,\n onCancelClick,\n\n showDefaultActions = true,\n\n // Content props\n children,\n contentClassName,\n childrenClassName,\n\n // AlertDialog behavior props\n open,\n onOpenChange,\n defaultOpen,\n\n // ScrollArea props\n autoHeight = true,\n\n // Close button props\n hasCloseButton = true,\n\n // Size variants\n size = 'lg',\n\n // Tracking props\n trackingNameView,\n trackingNameClose,\n trackingData,\n trackingIndex,\n\n // Other props\n className,\n ...props\n },\n ref,\n ) => {\n const { isDesktop } = useDevice();\n\n // autoHeight only works on desktop, mobile/tablet always use ScrollArea (full screen)\n const effectiveAutoHeight = autoHeight && isDesktop;\n\n const contentComponent = effectiveAutoHeight ? (\n <div className={cn('h-full overflow-y-auto px-4 py-2 pb-4', childrenClassName)}>\n {children}\n </div>\n ) : (\n <div className=\"h-full min-h-0 flex-1\">\n <ScrollArea className=\"h-full w-full\">\n <div className={cn('h-full px-4', childrenClassName)}>{children}</div>\n </ScrollArea>\n </div>\n );\n\n return (\n <AlertDialog open={open} onOpenChange={onOpenChange} defaultOpen={defaultOpen}>\n {trigger && (\n <AlertDialogTrigger asChild={triggerAsChild} className={triggerClassName}>\n {trigger}\n </AlertDialogTrigger>\n )}\n\n <AlertDialogContent\n ref={ref}\n hasCloseButton={hasCloseButton}\n size={size}\n trackingNameView={trackingNameView}\n trackingNameClose={trackingNameClose}\n trackingData={trackingData}\n trackingIndex={trackingIndex}\n className={cn(\n 'flex flex-col p-0',\n // For autoHeight dialogs on desktop, handle max-height\n effectiveAutoHeight && 'max-h-full lg:max-h-[88vh]',\n // Default height for non-full size dialogs or mobile/tablet\n !effectiveAutoHeight && size !== 'full' && 'h-full lg:h-[500px]',\n className,\n contentClassName,\n )}\n {...props}\n >\n {showHeader && (title || description || headerContent) && (\n <AlertDialogHeader className={cn('flex-shrink-0', headerClassName)}>\n {headerContent ? (\n headerContent\n ) : (\n <>\n {title && <AlertDialogTitle className={titleClassName}>{title}</AlertDialogTitle>}\n {description && (\n <AlertDialogDescription className={descriptionClassName}>\n {description}\n </AlertDialogDescription>\n )}\n </>\n )}\n </AlertDialogHeader>\n )}\n\n {contentComponent}\n\n {showFooter && (\n <AlertDialogFooter\n className={cn('border-border flex-shrink-0 border-t p-4', footerClassName)}\n >\n {footerContent\n ? footerContent\n : showDefaultActions && (\n <>\n <AlertDialogCancel className={cancelClassName} onClick={onCancelClick}>\n {cancelLabel}\n </AlertDialogCancel>\n <AlertDialogAction\n className={cn(\n actionVariant === 'destructive' &&\n 'bg-destructive hover:bg-destructive/90',\n actionClassName,\n )}\n onClick={onActionClick}\n >\n {actionLabel}\n </AlertDialogAction>\n </>\n )}\n </AlertDialogFooter>\n )}\n </AlertDialogContent>\n </AlertDialog>\n );\n },\n);\n\nAlertDialogWrapper.displayName = 'AlertDialogWrapper';\n\nexport { AlertDialogWrapper, type AlertDialogWrapperProps };\n"]}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { useDevice } from '@/hooks/useDevice';
|
|
4
|
+
import { cn } from '@/lib/utils';
|
|
5
|
+
import { AlertDialog, AlertDialogTrigger, AlertDialogContent, AlertDialogHeader, AlertDialogTitle, AlertDialogDescription, AlertDialogFooter, AlertDialogCancel, AlertDialogAction } from '../../components/alert-dialog';
|
|
6
|
+
import { ScrollArea } from '../../components/scroll-area';
|
|
7
|
+
|
|
8
|
+
const AlertDialogWrapper = React.forwardRef(
|
|
9
|
+
({
|
|
10
|
+
// Trigger props
|
|
11
|
+
trigger,
|
|
12
|
+
triggerAsChild = false,
|
|
13
|
+
triggerClassName,
|
|
14
|
+
// Header props
|
|
15
|
+
showHeader = true,
|
|
16
|
+
title,
|
|
17
|
+
titleClassName,
|
|
18
|
+
description,
|
|
19
|
+
descriptionClassName,
|
|
20
|
+
headerClassName,
|
|
21
|
+
headerContent,
|
|
22
|
+
// Footer props
|
|
23
|
+
showFooter = true,
|
|
24
|
+
footerContent,
|
|
25
|
+
footerClassName,
|
|
26
|
+
// Action buttons
|
|
27
|
+
actionLabel = "Confirm",
|
|
28
|
+
actionVariant = "default",
|
|
29
|
+
actionClassName,
|
|
30
|
+
onActionClick,
|
|
31
|
+
cancelLabel = "Cancel",
|
|
32
|
+
cancelClassName,
|
|
33
|
+
onCancelClick,
|
|
34
|
+
showDefaultActions = true,
|
|
35
|
+
// Content props
|
|
36
|
+
children,
|
|
37
|
+
contentClassName,
|
|
38
|
+
childrenClassName,
|
|
39
|
+
// AlertDialog behavior props
|
|
40
|
+
open,
|
|
41
|
+
onOpenChange,
|
|
42
|
+
defaultOpen,
|
|
43
|
+
// ScrollArea props
|
|
44
|
+
autoHeight = true,
|
|
45
|
+
// Close button props
|
|
46
|
+
hasCloseButton = true,
|
|
47
|
+
// Size variants
|
|
48
|
+
size = "lg",
|
|
49
|
+
// Tracking props
|
|
50
|
+
trackingNameView,
|
|
51
|
+
trackingNameClose,
|
|
52
|
+
trackingData,
|
|
53
|
+
trackingIndex,
|
|
54
|
+
// Other props
|
|
55
|
+
className,
|
|
56
|
+
...props
|
|
57
|
+
}, ref) => {
|
|
58
|
+
const { isDesktop } = useDevice();
|
|
59
|
+
const effectiveAutoHeight = autoHeight && isDesktop;
|
|
60
|
+
const contentComponent = effectiveAutoHeight ? /* @__PURE__ */ jsx("div", { className: cn("h-full overflow-y-auto px-4 py-2 pb-4", childrenClassName), children }) : /* @__PURE__ */ jsx("div", { className: "h-full min-h-0 flex-1", children: /* @__PURE__ */ jsx(ScrollArea, { className: "h-full w-full", children: /* @__PURE__ */ jsx("div", { className: cn("h-full px-4", childrenClassName), children }) }) });
|
|
61
|
+
return /* @__PURE__ */ jsxs(AlertDialog, { open, onOpenChange, defaultOpen, children: [
|
|
62
|
+
trigger && /* @__PURE__ */ jsx(AlertDialogTrigger, { asChild: triggerAsChild, className: triggerClassName, children: trigger }),
|
|
63
|
+
/* @__PURE__ */ jsxs(
|
|
64
|
+
AlertDialogContent,
|
|
65
|
+
{
|
|
66
|
+
ref,
|
|
67
|
+
hasCloseButton,
|
|
68
|
+
size,
|
|
69
|
+
trackingNameView,
|
|
70
|
+
trackingNameClose,
|
|
71
|
+
trackingData,
|
|
72
|
+
trackingIndex,
|
|
73
|
+
className: cn(
|
|
74
|
+
"flex flex-col p-0",
|
|
75
|
+
// For autoHeight dialogs on desktop, handle max-height
|
|
76
|
+
effectiveAutoHeight && "max-h-full lg:max-h-[88vh]",
|
|
77
|
+
// Default height for non-full size dialogs or mobile/tablet
|
|
78
|
+
!effectiveAutoHeight && size !== "full" && "h-full lg:h-[500px]",
|
|
79
|
+
className,
|
|
80
|
+
contentClassName
|
|
81
|
+
),
|
|
82
|
+
...props,
|
|
83
|
+
children: [
|
|
84
|
+
showHeader && (title || description || headerContent) && /* @__PURE__ */ jsx(AlertDialogHeader, { className: cn("flex-shrink-0", headerClassName), children: headerContent ? headerContent : /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
85
|
+
title && /* @__PURE__ */ jsx(AlertDialogTitle, { className: titleClassName, children: title }),
|
|
86
|
+
description && /* @__PURE__ */ jsx(AlertDialogDescription, { className: descriptionClassName, children: description })
|
|
87
|
+
] }) }),
|
|
88
|
+
contentComponent,
|
|
89
|
+
showFooter && /* @__PURE__ */ jsx(
|
|
90
|
+
AlertDialogFooter,
|
|
91
|
+
{
|
|
92
|
+
className: cn("border-border flex-shrink-0 border-t p-4", footerClassName),
|
|
93
|
+
children: footerContent ? footerContent : showDefaultActions && /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
94
|
+
/* @__PURE__ */ jsx(AlertDialogCancel, { className: cancelClassName, onClick: onCancelClick, children: cancelLabel }),
|
|
95
|
+
/* @__PURE__ */ jsx(
|
|
96
|
+
AlertDialogAction,
|
|
97
|
+
{
|
|
98
|
+
className: cn(
|
|
99
|
+
actionVariant === "destructive" && "bg-destructive hover:bg-destructive/90",
|
|
100
|
+
actionClassName
|
|
101
|
+
),
|
|
102
|
+
onClick: onActionClick,
|
|
103
|
+
children: actionLabel
|
|
104
|
+
}
|
|
105
|
+
)
|
|
106
|
+
] })
|
|
107
|
+
}
|
|
108
|
+
)
|
|
109
|
+
]
|
|
110
|
+
}
|
|
111
|
+
)
|
|
112
|
+
] });
|
|
113
|
+
}
|
|
114
|
+
);
|
|
115
|
+
AlertDialogWrapper.displayName = "AlertDialogWrapper";
|
|
116
|
+
|
|
117
|
+
export { AlertDialogWrapper };
|
|
118
|
+
//# sourceMappingURL=alert-dialog-wrapper.mjs.map
|
|
119
|
+
//# sourceMappingURL=alert-dialog-wrapper.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/common/interactive/alert-dialog-wrapper.tsx"],"names":[],"mappings":"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","file":"alert-dialog-wrapper.mjs","sourcesContent":["'use client';\n\nimport * as React from 'react';\n\nimport { useDevice } from '@/hooks/useDevice';\nimport { cn } from '@/lib/utils';\nimport {\n AlertDialog,\n AlertDialogAction,\n AlertDialogCancel,\n AlertDialogContent,\n AlertDialogDescription,\n AlertDialogFooter,\n AlertDialogHeader,\n AlertDialogTitle,\n AlertDialogTrigger,\n alertDialogVariants,\n type VariantProps,\n} from '../../components/alert-dialog';\nimport { ScrollArea } from '../../components/scroll-area';\n\ninterface AlertDialogWrapperProps extends React.ComponentPropsWithoutRef<\n typeof AlertDialogContent\n> {\n // Trigger props\n trigger?: React.ReactNode;\n triggerAsChild?: boolean;\n triggerClassName?: string;\n\n // Header props\n showHeader?: boolean;\n title?: string;\n titleClassName?: string;\n description?: string;\n descriptionClassName?: string;\n headerClassName?: string;\n headerContent?: React.ReactNode;\n\n // Footer props\n showFooter?: boolean;\n footerContent?: React.ReactNode;\n footerClassName?: string;\n\n // Action buttons\n actionLabel?: string;\n actionVariant?: 'default' | 'destructive';\n actionClassName?: string;\n onActionClick?: () => void;\n\n cancelLabel?: string;\n cancelClassName?: string;\n onCancelClick?: () => void;\n\n showDefaultActions?: boolean;\n\n // Content props\n children?: React.ReactNode;\n contentClassName?: string;\n childrenClassName?: string;\n\n // AlertDialog behavior props\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n defaultOpen?: boolean;\n\n // ScrollArea props\n autoHeight?: boolean;\n\n // Close button props\n hasCloseButton?: boolean;\n\n // Size variants\n size?: VariantProps<typeof alertDialogVariants>['size'];\n\n // Tracking props\n trackingNameView?: string;\n trackingNameClose?: string;\n trackingData?: Record<string, any>;\n trackingIndex?: number;\n}\n\nconst AlertDialogWrapper = React.forwardRef<\n React.ElementRef<typeof AlertDialogContent>,\n AlertDialogWrapperProps\n>(\n (\n {\n // Trigger props\n trigger,\n triggerAsChild = false,\n triggerClassName,\n\n // Header props\n showHeader = true,\n title,\n titleClassName,\n description,\n descriptionClassName,\n headerClassName,\n headerContent,\n\n // Footer props\n showFooter = true,\n footerContent,\n footerClassName,\n\n // Action buttons\n actionLabel = 'Confirm',\n actionVariant = 'default',\n actionClassName,\n onActionClick,\n\n cancelLabel = 'Cancel',\n cancelClassName,\n onCancelClick,\n\n showDefaultActions = true,\n\n // Content props\n children,\n contentClassName,\n childrenClassName,\n\n // AlertDialog behavior props\n open,\n onOpenChange,\n defaultOpen,\n\n // ScrollArea props\n autoHeight = true,\n\n // Close button props\n hasCloseButton = true,\n\n // Size variants\n size = 'lg',\n\n // Tracking props\n trackingNameView,\n trackingNameClose,\n trackingData,\n trackingIndex,\n\n // Other props\n className,\n ...props\n },\n ref,\n ) => {\n const { isDesktop } = useDevice();\n\n // autoHeight only works on desktop, mobile/tablet always use ScrollArea (full screen)\n const effectiveAutoHeight = autoHeight && isDesktop;\n\n const contentComponent = effectiveAutoHeight ? (\n <div className={cn('h-full overflow-y-auto px-4 py-2 pb-4', childrenClassName)}>\n {children}\n </div>\n ) : (\n <div className=\"h-full min-h-0 flex-1\">\n <ScrollArea className=\"h-full w-full\">\n <div className={cn('h-full px-4', childrenClassName)}>{children}</div>\n </ScrollArea>\n </div>\n );\n\n return (\n <AlertDialog open={open} onOpenChange={onOpenChange} defaultOpen={defaultOpen}>\n {trigger && (\n <AlertDialogTrigger asChild={triggerAsChild} className={triggerClassName}>\n {trigger}\n </AlertDialogTrigger>\n )}\n\n <AlertDialogContent\n ref={ref}\n hasCloseButton={hasCloseButton}\n size={size}\n trackingNameView={trackingNameView}\n trackingNameClose={trackingNameClose}\n trackingData={trackingData}\n trackingIndex={trackingIndex}\n className={cn(\n 'flex flex-col p-0',\n // For autoHeight dialogs on desktop, handle max-height\n effectiveAutoHeight && 'max-h-full lg:max-h-[88vh]',\n // Default height for non-full size dialogs or mobile/tablet\n !effectiveAutoHeight && size !== 'full' && 'h-full lg:h-[500px]',\n className,\n contentClassName,\n )}\n {...props}\n >\n {showHeader && (title || description || headerContent) && (\n <AlertDialogHeader className={cn('flex-shrink-0', headerClassName)}>\n {headerContent ? (\n headerContent\n ) : (\n <>\n {title && <AlertDialogTitle className={titleClassName}>{title}</AlertDialogTitle>}\n {description && (\n <AlertDialogDescription className={descriptionClassName}>\n {description}\n </AlertDialogDescription>\n )}\n </>\n )}\n </AlertDialogHeader>\n )}\n\n {contentComponent}\n\n {showFooter && (\n <AlertDialogFooter\n className={cn('border-border flex-shrink-0 border-t p-4', footerClassName)}\n >\n {footerContent\n ? footerContent\n : showDefaultActions && (\n <>\n <AlertDialogCancel className={cancelClassName} onClick={onCancelClick}>\n {cancelLabel}\n </AlertDialogCancel>\n <AlertDialogAction\n className={cn(\n actionVariant === 'destructive' &&\n 'bg-destructive hover:bg-destructive/90',\n actionClassName,\n )}\n onClick={onActionClick}\n >\n {actionLabel}\n </AlertDialogAction>\n </>\n )}\n </AlertDialogFooter>\n )}\n </AlertDialogContent>\n </AlertDialog>\n );\n },\n);\n\nAlertDialogWrapper.displayName = 'AlertDialogWrapper';\n\nexport { AlertDialogWrapper, type AlertDialogWrapperProps };\n"]}
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
4
|
+
var cmdk = require('cmdk');
|
|
5
|
+
var React = require('react');
|
|
6
|
+
var command = require('@/components/command');
|
|
7
|
+
var input = require('@/components/input');
|
|
8
|
+
var popover = require('@/components/popover');
|
|
9
|
+
var skeleton = require('@/components/skeleton');
|
|
10
|
+
var utils = require('@/lib/utils');
|
|
11
|
+
|
|
12
|
+
function _interopNamespace(e) {
|
|
13
|
+
if (e && e.__esModule) return e;
|
|
14
|
+
var n = Object.create(null);
|
|
15
|
+
if (e) {
|
|
16
|
+
Object.keys(e).forEach(function (k) {
|
|
17
|
+
if (k !== 'default') {
|
|
18
|
+
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
19
|
+
Object.defineProperty(n, k, d.get ? d : {
|
|
20
|
+
enumerable: true,
|
|
21
|
+
get: function () { return e[k]; }
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
n.default = e;
|
|
27
|
+
return Object.freeze(n);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
var React__namespace = /*#__PURE__*/_interopNamespace(React);
|
|
31
|
+
|
|
32
|
+
function AutoComplete({
|
|
33
|
+
label = "",
|
|
34
|
+
placeholder = "",
|
|
35
|
+
options,
|
|
36
|
+
searchApi,
|
|
37
|
+
value,
|
|
38
|
+
onInputChange,
|
|
39
|
+
onSelectChange,
|
|
40
|
+
children,
|
|
41
|
+
enableAddNewItem,
|
|
42
|
+
newItemOption,
|
|
43
|
+
renderOption,
|
|
44
|
+
className,
|
|
45
|
+
renderEmpty,
|
|
46
|
+
...props
|
|
47
|
+
}) {
|
|
48
|
+
const triggerRef = React__namespace.useRef(null);
|
|
49
|
+
const [triggerWidth, setTriggerWidth] = React.useState();
|
|
50
|
+
const [open, setOpen] = React.useState(false);
|
|
51
|
+
const [isLoading, setIsLoading] = React.useState(false);
|
|
52
|
+
const [searchedOptions, setSearchedOptions] = React.useState([]);
|
|
53
|
+
const newItem = React.useMemo(() => newItemOption?.(value ?? ""), [newItemOption, value]);
|
|
54
|
+
React.useEffect(() => {
|
|
55
|
+
if (open) handleSearch(value);
|
|
56
|
+
if (triggerRef.current) {
|
|
57
|
+
setTriggerWidth(triggerRef.current.offsetWidth);
|
|
58
|
+
}
|
|
59
|
+
}, [open, value]);
|
|
60
|
+
const isPaginatedApi = (api) => {
|
|
61
|
+
return typeof api === "function" && api.length >= 2;
|
|
62
|
+
};
|
|
63
|
+
const handleSearch = async (searchValue) => {
|
|
64
|
+
if (!searchValue) {
|
|
65
|
+
setSearchedOptions([]);
|
|
66
|
+
} else if (searchApi) {
|
|
67
|
+
handleSearchApi(value, 1, 10);
|
|
68
|
+
} else if (options) {
|
|
69
|
+
handleSearchLocal(searchValue);
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
const handleSearchLocal = (searchValue) => {
|
|
73
|
+
if (searchValue && options && options?.length > 0) {
|
|
74
|
+
const resultOptions = [...options ?? []].filter(
|
|
75
|
+
// (option) => (option.name?.toLowerCase().search(searchValue.toLowerCase()) ?? -1) > -1,
|
|
76
|
+
(option) => option.name?.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g, "").includes(
|
|
77
|
+
searchValue.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g, "")
|
|
78
|
+
) ?? false
|
|
79
|
+
);
|
|
80
|
+
setSearchedOptions(resultOptions);
|
|
81
|
+
} else if (options && options?.length > 0) {
|
|
82
|
+
setSearchedOptions([...options ?? []]);
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
const handleSearchApi = async (searchValue = "", page = 1, size = 10) => {
|
|
86
|
+
try {
|
|
87
|
+
setIsLoading(true);
|
|
88
|
+
if (isPaginatedApi(searchApi)) {
|
|
89
|
+
const res = await searchApi?.(searchValue, page, size);
|
|
90
|
+
const resultOptions = res?.data ?? [];
|
|
91
|
+
setSearchedOptions(resultOptions);
|
|
92
|
+
} else {
|
|
93
|
+
const resultOptions = await searchApi(searchValue);
|
|
94
|
+
setSearchedOptions(resultOptions);
|
|
95
|
+
}
|
|
96
|
+
} catch (error) {
|
|
97
|
+
} finally {
|
|
98
|
+
setIsLoading(false);
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
const handleSelectItem = (option) => {
|
|
102
|
+
onSelectChange?.(option);
|
|
103
|
+
setOpen(false);
|
|
104
|
+
};
|
|
105
|
+
return /* @__PURE__ */ jsxRuntime.jsx(popover.Popover, { open, onOpenChange: setOpen, children: /* @__PURE__ */ jsxRuntime.jsxs(command.Command, { shouldFilter: false, children: [
|
|
106
|
+
/* @__PURE__ */ jsxRuntime.jsx(popover.PopoverTrigger, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx("div", { ref: triggerRef, children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
107
|
+
cmdk.Command.Input,
|
|
108
|
+
{
|
|
109
|
+
...props,
|
|
110
|
+
asChild: true,
|
|
111
|
+
value,
|
|
112
|
+
onValueChange: onInputChange,
|
|
113
|
+
placeholder,
|
|
114
|
+
onKeyDown: (e) => setOpen(e.key !== "Escape"),
|
|
115
|
+
children: children ?? /* @__PURE__ */ jsxRuntime.jsx(input.Input, { label })
|
|
116
|
+
}
|
|
117
|
+
) }) }),
|
|
118
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
119
|
+
popover.PopoverContent,
|
|
120
|
+
{
|
|
121
|
+
asChild: true,
|
|
122
|
+
onOpenAutoFocus: (e) => e.preventDefault(),
|
|
123
|
+
onInteractOutside: (e) => {
|
|
124
|
+
if (e.target instanceof Element && e.target.hasAttribute("cmdk-input")) {
|
|
125
|
+
e.preventDefault();
|
|
126
|
+
}
|
|
127
|
+
},
|
|
128
|
+
className: "w-full min-w-[300px] p-0",
|
|
129
|
+
hidden: !value,
|
|
130
|
+
align: "start",
|
|
131
|
+
style: { width: triggerWidth },
|
|
132
|
+
children: /* @__PURE__ */ jsxRuntime.jsxs(command.CommandList, { children: [
|
|
133
|
+
isLoading && /* @__PURE__ */ jsxRuntime.jsx(cmdk.Command.Loading, { children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "space-y-2 p-3", children: new Array(5).fill(1).map((_item, index) => /* @__PURE__ */ jsxRuntime.jsx(skeleton.Skeleton, { className: "h-10 w-full" }, index)) }) }),
|
|
134
|
+
searchedOptions?.length > 0 && !isLoading && /* @__PURE__ */ jsxRuntime.jsx(command.CommandGroup, { className: "px-0 py-2", children: searchedOptions.map((option, index) => /* @__PURE__ */ jsxRuntime.jsx(
|
|
135
|
+
command.CommandItem,
|
|
136
|
+
{
|
|
137
|
+
value: option.value,
|
|
138
|
+
onMouseDown: (e) => e.preventDefault(),
|
|
139
|
+
onSelect: () => handleSelectItem(option),
|
|
140
|
+
className: utils.cn(
|
|
141
|
+
"text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none p-3",
|
|
142
|
+
index > 0 && "border-border border-t"
|
|
143
|
+
),
|
|
144
|
+
children: renderOption ? renderOption(option) : option.name ?? option.value
|
|
145
|
+
},
|
|
146
|
+
option.value
|
|
147
|
+
)) }),
|
|
148
|
+
searchedOptions?.length === 0 && !isLoading && enableAddNewItem && newItem && /* @__PURE__ */ jsxRuntime.jsx(command.CommandGroup, { className: "px-0 py-2", children: [newItem].filter((o) => !!o).map((option, index) => /* @__PURE__ */ jsxRuntime.jsx(
|
|
149
|
+
command.CommandItem,
|
|
150
|
+
{
|
|
151
|
+
value: option.value,
|
|
152
|
+
onMouseDown: (e) => e.preventDefault(),
|
|
153
|
+
onSelect: () => handleSelectItem(option),
|
|
154
|
+
className: utils.cn(
|
|
155
|
+
"text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none px-3 py-4",
|
|
156
|
+
index > 0 && "border-border border-t"
|
|
157
|
+
),
|
|
158
|
+
children: renderOption ? renderOption(option, true) : option.name ?? option.value
|
|
159
|
+
},
|
|
160
|
+
option.value
|
|
161
|
+
)) }),
|
|
162
|
+
searchedOptions?.length === 0 && !isLoading && !enableAddNewItem && /* @__PURE__ */ jsxRuntime.jsx(command.CommandGroup, { className: "px-0 py-2", children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
163
|
+
command.CommandItem,
|
|
164
|
+
{
|
|
165
|
+
onMouseDown: (e) => e.preventDefault(),
|
|
166
|
+
className: utils.cn("!text-t16 !text-muted-foreground !bg-transparent px-3 py-4"),
|
|
167
|
+
children: renderEmpty ? renderEmpty() : /* @__PURE__ */ jsxRuntime.jsx("p", { children: "Kh\xF4ng c\xF3 th\xF4ng tin hi\u1EC3n th\u1ECB" })
|
|
168
|
+
}
|
|
169
|
+
) })
|
|
170
|
+
] })
|
|
171
|
+
}
|
|
172
|
+
)
|
|
173
|
+
] }) });
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
exports.AutoComplete = AutoComplete;
|
|
177
|
+
//# sourceMappingURL=autocomplete.js.map
|
|
178
|
+
//# sourceMappingURL=autocomplete.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/common/interactive/autocomplete.tsx"],"names":["React","useState","useMemo","useEffect","jsx","Popover","jsxs","Command","PopoverTrigger","CommandPrimitive","Input","PopoverContent","CommandList","Skeleton","CommandGroup","CommandItem","cn"],"mappings":"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","file":"autocomplete.js","sourcesContent":["import { Command as CommandPrimitive } from 'cmdk';\nimport { useEffect, useMemo, useState } from 'react';\nimport { Command, CommandGroup, CommandItem, CommandList } from '@/components/command';\nimport { Input } from '@/components/input';\nimport { Popover, PopoverTrigger, PopoverContent } from '@/components/popover';\nimport { Skeleton } from '@/components/skeleton';\nimport { Option } from '@/common/interactive/select';\nimport {\n ApiSearchFunction,\n ApiSearchPaginatedFunction,\n} from '@/common/interactive/select-with-api';\nimport * as React from 'react';\nimport { cn } from '@/lib/utils';\n\ntype Props<T extends string> = {\n label?: string;\n placeholder?: string;\n options?: Option[];\n searchApi?: ApiSearchFunction<Option> | ApiSearchPaginatedFunction<Option>;\n value?: string;\n onInputChange?: (value?: string) => void;\n onSelectChange?: (value?: Option) => void;\n children?: React.ReactNode;\n enableAddNewItem?: boolean;\n newItemOption?: (value: string) => Option | null;\n renderOption?: (option: Option, isNewItem?: boolean) => React.ReactNode;\n renderEmpty?: () => React.ReactNode;\n className?: string;\n};\n\nexport function AutoComplete<T extends string>({\n label = '',\n placeholder = '',\n options,\n searchApi,\n value,\n onInputChange,\n onSelectChange,\n children,\n enableAddNewItem,\n newItemOption,\n renderOption,\n className,\n renderEmpty,\n ...props\n}: Props<T>) {\n const triggerRef = React.useRef<HTMLDivElement>(null);\n const [triggerWidth, setTriggerWidth] = useState<number>();\n const [open, setOpen] = useState(false);\n const [isLoading, setIsLoading] = useState(false);\n const [searchedOptions, setSearchedOptions] = useState<Option[]>([]);\n\n const newItem = useMemo(() => newItemOption?.(value ?? ''), [newItemOption, value]);\n\n useEffect(() => {\n if (open) handleSearch(value);\n\n if (triggerRef.current) {\n setTriggerWidth(triggerRef.current.offsetWidth);\n }\n }, [open, value]);\n\n const isPaginatedApi = (api: any): api is ApiSearchPaginatedFunction<Option> => {\n return typeof api === 'function' && api.length >= 2;\n };\n\n const handleSearch = async (searchValue?: string) => {\n if (!searchValue) {\n setSearchedOptions([]);\n } else if (searchApi) {\n handleSearchApi(value, 1, 10);\n } else if (options) {\n handleSearchLocal(searchValue);\n }\n };\n\n const handleSearchLocal = (searchValue?: string) => {\n if (searchValue && options && options?.length > 0) {\n const resultOptions = [...(options ?? [])].filter(\n // (option) => (option.name?.toLowerCase().search(searchValue.toLowerCase()) ?? -1) > -1,\n (option) =>\n option.name\n ?.toLowerCase()\n .normalize('NFD')\n .replace(/[\\u0300-\\u036f]/g, '')\n .includes(\n searchValue\n .toLowerCase()\n .normalize('NFD')\n .replace(/[\\u0300-\\u036f]/g, ''),\n ) ?? false,\n );\n\n setSearchedOptions(resultOptions);\n } else if (options && options?.length > 0) {\n setSearchedOptions([...(options ?? [])]);\n }\n };\n\n const handleSearchApi = async (searchValue: string = '', page: number = 1, size: number = 10) => {\n try {\n setIsLoading(true);\n if (isPaginatedApi(searchApi)) {\n const res = await searchApi?.(searchValue, page, size);\n const resultOptions = res?.data ?? [];\n setSearchedOptions(resultOptions);\n } else {\n const resultOptions = await (searchApi as ApiSearchFunction<Option>)(searchValue);\n setSearchedOptions(resultOptions);\n }\n } catch (error) {\n } finally {\n setIsLoading(false);\n }\n };\n\n const handleSelectItem = (option: Option) => {\n onSelectChange?.(option);\n setOpen(false);\n };\n\n return (\n <Popover open={open} onOpenChange={setOpen}>\n <Command shouldFilter={false}>\n <PopoverTrigger asChild>\n <div ref={triggerRef}>\n <CommandPrimitive.Input\n {...props}\n asChild\n value={value}\n onValueChange={onInputChange}\n placeholder={placeholder}\n onKeyDown={(e) => setOpen(e.key !== 'Escape')}\n >\n {children ?? <Input label={label} />}\n </CommandPrimitive.Input>\n </div>\n </PopoverTrigger>\n\n <PopoverContent\n asChild\n onOpenAutoFocus={(e) => e.preventDefault()}\n onInteractOutside={(e) => {\n if (e.target instanceof Element && e.target.hasAttribute('cmdk-input')) {\n e.preventDefault();\n }\n }}\n className=\"w-full min-w-[300px] p-0\"\n // hidden={\n // // (!searchedOptions || searchedOptions?.length == 0) &&\n // // (!enableAddNewItem || !value || !newItem) &&\n // // !isLoading\n // }\n hidden={!value}\n align=\"start\"\n style={{ width: triggerWidth }}\n >\n <CommandList>\n {isLoading && (\n <CommandPrimitive.Loading>\n <div className=\"space-y-2 p-3\">\n {new Array(5).fill(1).map((_item, index) => (\n <Skeleton className=\"h-10 w-full\" key={index} />\n ))}\n </div>\n </CommandPrimitive.Loading>\n )}\n\n {searchedOptions?.length > 0 && !isLoading && (\n <CommandGroup className=\"px-0 py-2\">\n {searchedOptions.map((option, index: number) => (\n <CommandItem\n key={option.value}\n value={option.value}\n onMouseDown={(e) => e.preventDefault()}\n onSelect={() => handleSelectItem(option)}\n className={cn(\n \"text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none p-3\",\n index > 0 && 'border-border border-t',\n )}\n >\n {renderOption ? renderOption(option) : (option.name ?? option.value)}\n </CommandItem>\n ))}\n </CommandGroup>\n )}\n\n {searchedOptions?.length === 0 && !isLoading && enableAddNewItem && newItem && (\n <CommandGroup className=\"px-0 py-2\">\n {[newItem]\n .filter((o) => !!o)\n .map((option, index: number) => (\n <CommandItem\n key={option.value}\n value={option.value}\n onMouseDown={(e) => e.preventDefault()}\n onSelect={() => handleSelectItem(option)}\n className={cn(\n \"text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none px-3 py-4\",\n index > 0 && 'border-border border-t',\n )}\n >\n {renderOption ? renderOption(option, true) : (option.name ?? option.value)}\n </CommandItem>\n ))}\n </CommandGroup>\n )}\n\n {searchedOptions?.length === 0 && !isLoading && !enableAddNewItem && (\n <CommandGroup className=\"px-0 py-2\">\n <CommandItem\n onMouseDown={(e) => e.preventDefault()}\n className={cn('!text-t16 !text-muted-foreground !bg-transparent px-3 py-4')}\n >\n {renderEmpty ? renderEmpty() : <p>Không có thông tin hiển thị</p>}\n </CommandItem>\n </CommandGroup>\n )}\n </CommandList>\n </PopoverContent>\n </Command>\n </Popover>\n );\n}\n"]}
|