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,172 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
4
|
+
var React = require('react');
|
|
5
|
+
var TooltipPrimitive = require('@radix-ui/react-tooltip');
|
|
6
|
+
var utils = require('@/lib/utils');
|
|
7
|
+
|
|
8
|
+
function _interopNamespace(e) {
|
|
9
|
+
if (e && e.__esModule) return e;
|
|
10
|
+
var n = Object.create(null);
|
|
11
|
+
if (e) {
|
|
12
|
+
Object.keys(e).forEach(function (k) {
|
|
13
|
+
if (k !== 'default') {
|
|
14
|
+
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
15
|
+
Object.defineProperty(n, k, d.get ? d : {
|
|
16
|
+
enumerable: true,
|
|
17
|
+
get: function () { return e[k]; }
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
n.default = e;
|
|
23
|
+
return Object.freeze(n);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
var React__namespace = /*#__PURE__*/_interopNamespace(React);
|
|
27
|
+
var TooltipPrimitive__namespace = /*#__PURE__*/_interopNamespace(TooltipPrimitive);
|
|
28
|
+
|
|
29
|
+
const TooltipProvider = TooltipPrimitive__namespace.Provider;
|
|
30
|
+
const Tooltip = React__namespace.forwardRef(
|
|
31
|
+
({ enableClickTrigger = true, clickOnly = false, children, ...props }, ref) => {
|
|
32
|
+
const [clickOpen, setClickOpen] = React__namespace.useState(false);
|
|
33
|
+
const isControlled = props.open !== void 0;
|
|
34
|
+
const handleOpenChange = React__namespace.useCallback(
|
|
35
|
+
(newOpen) => {
|
|
36
|
+
if ((enableClickTrigger || clickOnly) && !isControlled) {
|
|
37
|
+
setClickOpen(newOpen);
|
|
38
|
+
}
|
|
39
|
+
props.onOpenChange?.(newOpen);
|
|
40
|
+
},
|
|
41
|
+
[enableClickTrigger, clickOnly, isControlled, props]
|
|
42
|
+
);
|
|
43
|
+
const finalOpen = React__namespace.useMemo(() => {
|
|
44
|
+
if (isControlled) {
|
|
45
|
+
return props.open;
|
|
46
|
+
}
|
|
47
|
+
if (enableClickTrigger || clickOnly) {
|
|
48
|
+
return clickOpen;
|
|
49
|
+
}
|
|
50
|
+
return props.open;
|
|
51
|
+
}, [isControlled, enableClickTrigger, clickOnly, clickOpen, props.open]);
|
|
52
|
+
if (enableClickTrigger || clickOnly) {
|
|
53
|
+
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
54
|
+
TooltipPrimitive__namespace.Root,
|
|
55
|
+
{
|
|
56
|
+
...props,
|
|
57
|
+
open: finalOpen,
|
|
58
|
+
onOpenChange: handleOpenChange,
|
|
59
|
+
disableHoverableContent: clickOnly,
|
|
60
|
+
children: React__namespace.Children.map(children, (child) => {
|
|
61
|
+
if (React__namespace.isValidElement(child) && child.type === TooltipTrigger) {
|
|
62
|
+
return React__namespace.cloneElement(child, {
|
|
63
|
+
...child.props,
|
|
64
|
+
enableClickTrigger,
|
|
65
|
+
clickOnly,
|
|
66
|
+
tooltipSetOpen: setClickOpen,
|
|
67
|
+
isControlledTooltip: isControlled,
|
|
68
|
+
onTooltipOpenChange: handleOpenChange
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
return child;
|
|
72
|
+
})
|
|
73
|
+
}
|
|
74
|
+
);
|
|
75
|
+
}
|
|
76
|
+
return /* @__PURE__ */ jsxRuntime.jsx(TooltipPrimitive__namespace.Root, { ...props, onOpenChange: handleOpenChange, children });
|
|
77
|
+
}
|
|
78
|
+
);
|
|
79
|
+
Tooltip.displayName = "Tooltip";
|
|
80
|
+
const TooltipTrigger = React__namespace.forwardRef(
|
|
81
|
+
({
|
|
82
|
+
className,
|
|
83
|
+
onClick,
|
|
84
|
+
enableClickTrigger = false,
|
|
85
|
+
clickOnly = false,
|
|
86
|
+
tooltipSetOpen,
|
|
87
|
+
isControlledTooltip,
|
|
88
|
+
onTooltipOpenChange,
|
|
89
|
+
...props
|
|
90
|
+
}, ref) => {
|
|
91
|
+
const [isOpen, setIsOpen] = React__namespace.useState(false);
|
|
92
|
+
const handleClick = React__namespace.useCallback(
|
|
93
|
+
(event) => {
|
|
94
|
+
if (enableClickTrigger || clickOnly) {
|
|
95
|
+
if (clickOnly) {
|
|
96
|
+
event.preventDefault();
|
|
97
|
+
}
|
|
98
|
+
const newOpen = !isOpen;
|
|
99
|
+
setIsOpen(newOpen);
|
|
100
|
+
if (!isControlledTooltip && tooltipSetOpen) {
|
|
101
|
+
tooltipSetOpen(newOpen);
|
|
102
|
+
}
|
|
103
|
+
if (onTooltipOpenChange) {
|
|
104
|
+
onTooltipOpenChange(newOpen);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
onClick?.(event);
|
|
108
|
+
},
|
|
109
|
+
[
|
|
110
|
+
enableClickTrigger,
|
|
111
|
+
clickOnly,
|
|
112
|
+
isOpen,
|
|
113
|
+
isControlledTooltip,
|
|
114
|
+
tooltipSetOpen,
|
|
115
|
+
onTooltipOpenChange,
|
|
116
|
+
onClick
|
|
117
|
+
]
|
|
118
|
+
);
|
|
119
|
+
if (clickOnly) {
|
|
120
|
+
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
121
|
+
TooltipPrimitive__namespace.Trigger,
|
|
122
|
+
{
|
|
123
|
+
ref,
|
|
124
|
+
className: utils.cn("cursor-pointer", className),
|
|
125
|
+
...props,
|
|
126
|
+
onClick: handleClick,
|
|
127
|
+
onPointerEnter: void 0,
|
|
128
|
+
onPointerLeave: void 0,
|
|
129
|
+
onFocus: void 0,
|
|
130
|
+
onBlur: void 0
|
|
131
|
+
}
|
|
132
|
+
);
|
|
133
|
+
}
|
|
134
|
+
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
135
|
+
TooltipPrimitive__namespace.Trigger,
|
|
136
|
+
{
|
|
137
|
+
ref,
|
|
138
|
+
className: utils.cn(enableClickTrigger ? "cursor-pointer" : "", className),
|
|
139
|
+
...props,
|
|
140
|
+
onClick: handleClick
|
|
141
|
+
}
|
|
142
|
+
);
|
|
143
|
+
}
|
|
144
|
+
);
|
|
145
|
+
TooltipTrigger.displayName = TooltipPrimitive__namespace.Trigger.displayName;
|
|
146
|
+
const TooltipArrow = React__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(TooltipPrimitive__namespace.Arrow, { ref, className: utils.cn("fill-popover", className), ...props }));
|
|
147
|
+
TooltipArrow.displayName = TooltipPrimitive__namespace.Arrow.displayName;
|
|
148
|
+
const TooltipContent = React__namespace.forwardRef(({ className, sideOffset = 4, showArrow = true, children, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsxs(
|
|
149
|
+
TooltipPrimitive__namespace.Content,
|
|
150
|
+
{
|
|
151
|
+
ref,
|
|
152
|
+
sideOffset,
|
|
153
|
+
className: utils.cn(
|
|
154
|
+
"bg-popover text-popover-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 bg-ink-500s border-ink-500s z-[9999] max-w-[280px] overflow-hidden rounded-md border-none px-3 py-1.5 text-sm text-white shadow-sm",
|
|
155
|
+
className
|
|
156
|
+
),
|
|
157
|
+
...props,
|
|
158
|
+
children: [
|
|
159
|
+
children,
|
|
160
|
+
showArrow && /* @__PURE__ */ jsxRuntime.jsx(TooltipArrow, { className: "fill-ink-500s" })
|
|
161
|
+
]
|
|
162
|
+
}
|
|
163
|
+
));
|
|
164
|
+
TooltipContent.displayName = TooltipPrimitive__namespace.Content.displayName;
|
|
165
|
+
|
|
166
|
+
exports.Tooltip = Tooltip;
|
|
167
|
+
exports.TooltipArrow = TooltipArrow;
|
|
168
|
+
exports.TooltipContent = TooltipContent;
|
|
169
|
+
exports.TooltipProvider = TooltipProvider;
|
|
170
|
+
exports.TooltipTrigger = TooltipTrigger;
|
|
171
|
+
//# sourceMappingURL=tooltip.js.map
|
|
172
|
+
//# sourceMappingURL=tooltip.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/components/tooltip.tsx"],"names":["TooltipPrimitive","React","jsx","cn","jsxs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOA,MAAM,kBAAkBA,2BAAA,CAAiB;AAgBzC,MAAM,UAAUC,gBAAA,CAAM,UAAA;AAAA,EACpB,CAAC,EAAE,kBAAA,GAAqB,IAAA,EAAM,SAAA,GAAY,OAAO,QAAA,EAAU,GAAG,KAAA,EAAM,EAAG,GAAA,KAAQ;AAC7E,IAAA,MAAM,CAAC,SAAA,EAAW,YAAY,CAAA,GAAIA,gBAAA,CAAM,SAAS,KAAK,CAAA;AACtD,IAAA,MAAM,YAAA,GAAe,MAAM,IAAA,KAAS,MAAA;AAEpC,IAAA,MAAM,mBAAmBA,gBAAA,CAAM,WAAA;AAAA,MAC7B,CAAC,OAAA,KAAqB;AACpB,QAAA,IAAA,CAAK,kBAAA,IAAsB,SAAA,KAAc,CAAC,YAAA,EAAc;AACtD,UAAA,YAAA,CAAa,OAAO,CAAA;AAAA,QACtB;AACA,QAAA,KAAA,CAAM,eAAe,OAAO,CAAA;AAAA,MAC9B,CAAA;AAAA,MACA,CAAC,kBAAA,EAAoB,SAAA,EAAW,YAAA,EAAc,KAAK;AAAA,KACrD;AAEA,IAAA,MAAM,SAAA,GAAYA,gBAAA,CAAM,OAAA,CAAQ,MAAM;AACpC,MAAA,IAAI,YAAA,EAAc;AAChB,QAAA,OAAO,KAAA,CAAM,IAAA;AAAA,MACf;AACA,MAAA,IAAI,sBAAsB,SAAA,EAAW;AACnC,QAAA,OAAO,SAAA;AAAA,MACT;AACA,MAAA,OAAO,KAAA,CAAM,IAAA;AAAA,IACf,CAAA,EAAG,CAAC,YAAA,EAAc,kBAAA,EAAoB,WAAW,SAAA,EAAW,KAAA,CAAM,IAAI,CAAC,CAAA;AAEvE,IAAA,IAAI,sBAAsB,SAAA,EAAW;AACnC,MAAA,uBACEC,cAAA;AAAA,QAACF,2BAAA,CAAiB,IAAA;AAAA,QAAjB;AAAA,UACE,GAAG,KAAA;AAAA,UACJ,IAAA,EAAM,SAAA;AAAA,UACN,YAAA,EAAc,gBAAA;AAAA,UACd,uBAAA,EAAyB,SAAA;AAAA,UAExB,QAAA,EAAAC,gBAAA,CAAM,QAAA,CAAS,GAAA,CAAI,QAAA,EAAU,CAAC,KAAA,KAAU;AACvC,YAAA,IAAIA,iBAAM,cAAA,CAAe,KAAK,CAAA,IAAK,KAAA,CAAM,SAAS,cAAA,EAAgB;AAChE,cAAA,OAAOA,gBAAA,CAAM,aAAa,KAAA,EAAO;AAAA,gBAC/B,GAAG,KAAA,CAAM,KAAA;AAAA,gBACT,kBAAA;AAAA,gBACA,SAAA;AAAA,gBACA,cAAA,EAAgB,YAAA;AAAA,gBAChB,mBAAA,EAAqB,YAAA;AAAA,gBACrB,mBAAA,EAAqB;AAAA,eACtB,CAAA;AAAA,YACH;AACA,YAAA,OAAO,KAAA;AAAA,UACT,CAAC;AAAA;AAAA,OACH;AAAA,IAEJ;AAEA,IAAA,uBACEC,cAAA,CAACF,4BAAiB,IAAA,EAAjB,EAAuB,GAAG,KAAA,EAAO,YAAA,EAAc,kBAC7C,QAAA,EACH,CAAA;AAAA,EAEJ;AACF;AACA,OAAA,CAAQ,WAAA,GAAc,SAAA;AActB,MAAM,iBAAiBC,gBAAA,CAAM,UAAA;AAAA,EAI3B,CACE;AAAA,IACE,SAAA;AAAA,IACA,OAAA;AAAA,IACA,kBAAA,GAAqB,KAAA;AAAA,IACrB,SAAA,GAAY,KAAA;AAAA,IACZ,cAAA;AAAA,IACA,mBAAA;AAAA,IACA,mBAAA;AAAA,IACA,GAAG;AAAA,KAEL,GAAA,KACG;AACH,IAAA,MAAM,CAAC,MAAA,EAAQ,SAAS,CAAA,GAAIA,gBAAA,CAAM,SAAS,KAAK,CAAA;AAEhD,IAAA,MAAM,cAAcA,gBAAA,CAAM,WAAA;AAAA,MACxB,CAAC,KAAA,KAAiD;AAChD,QAAA,IAAI,sBAAsB,SAAA,EAAW;AAEnC,UAAA,IAAI,SAAA,EAAW;AACb,YAAA,KAAA,CAAM,cAAA,EAAe;AAAA,UACvB;AAEA,UAAA,MAAM,UAAU,CAAC,MAAA;AACjB,UAAA,SAAA,CAAU,OAAO,CAAA;AAEjB,UAAA,IAAI,CAAC,uBAAuB,cAAA,EAAgB;AAC1C,YAAA,cAAA,CAAe,OAAO,CAAA;AAAA,UACxB;AAEA,UAAA,IAAI,mBAAA,EAAqB;AACvB,YAAA,mBAAA,CAAoB,OAAO,CAAA;AAAA,UAC7B;AAAA,QACF;AACA,QAAA,OAAA,GAAU,KAAK,CAAA;AAAA,MACjB,CAAA;AAAA,MACA;AAAA,QACE,kBAAA;AAAA,QACA,SAAA;AAAA,QACA,MAAA;AAAA,QACA,mBAAA;AAAA,QACA,cAAA;AAAA,QACA,mBAAA;AAAA,QACA;AAAA;AACF,KACF;AAEA,IAAA,IAAI,SAAA,EAAW;AAEb,MAAA,uBACEC,cAAA;AAAA,QAACF,2BAAA,CAAiB,OAAA;AAAA,QAAjB;AAAA,UACC,GAAA;AAAA,UACA,SAAA,EAAWG,QAAA,CAAG,gBAAA,EAAkB,SAAS,CAAA;AAAA,UACxC,GAAG,KAAA;AAAA,UACJ,OAAA,EAAS,WAAA;AAAA,UACT,cAAA,EAAgB,MAAA;AAAA,UAChB,cAAA,EAAgB,MAAA;AAAA,UAChB,OAAA,EAAS,MAAA;AAAA,UACT,MAAA,EAAQ;AAAA;AAAA,OACV;AAAA,IAEJ;AAGA,IAAA,uBACED,cAAA;AAAA,MAACF,2BAAA,CAAiB,OAAA;AAAA,MAAjB;AAAA,QACC,GAAA;AAAA,QACA,SAAA,EAAWG,QAAA,CAAG,kBAAA,GAAqB,gBAAA,GAAmB,IAAI,SAAS,CAAA;AAAA,QAClE,GAAG,KAAA;AAAA,QACJ,OAAA,EAAS;AAAA;AAAA,KACX;AAAA,EAEJ;AACF;AACA,cAAA,CAAe,WAAA,GAAcH,4BAAiB,OAAA,CAAQ,WAAA;AAEtD,MAAM,YAAA,GAAeC,iBAAM,UAAA,CAGzB,CAAC,EAAE,SAAA,EAAW,GAAG,KAAA,EAAM,EAAG,GAAA,qBAC1BC,cAAA,CAACF,4BAAiB,KAAA,EAAjB,EAAuB,KAAU,SAAA,EAAWG,QAAA,CAAG,gBAAgB,SAAS,CAAA,EAAI,GAAG,KAAA,EAAO,CACxF;AACD,YAAA,CAAa,WAAA,GAAcH,4BAAiB,KAAA,CAAM,WAAA;AAElD,MAAM,cAAA,GAAiBC,gBAAA,CAAM,UAAA,CAK3B,CAAC,EAAE,SAAA,EAAW,UAAA,GAAa,CAAA,EAAG,SAAA,GAAY,IAAA,EAAM,QAAA,EAAU,GAAG,KAAA,IAAS,GAAA,qBACtEG,eAAA;AAAA,EAACJ,2BAAA,CAAiB,OAAA;AAAA,EAAjB;AAAA,IACC,GAAA;AAAA,IACA,UAAA;AAAA,IACA,SAAA,EAAWG,QAAA;AAAA,MACT,kcAAA;AAAA,MACA;AAAA,KACF;AAAA,IACC,GAAG,KAAA;AAAA,IAEH,QAAA,EAAA;AAAA,MAAA,QAAA;AAAA,MACA,SAAA,oBAAaD,cAAA,CAAC,YAAA,EAAA,EAAa,SAAA,EAAU,eAAA,EAAgB;AAAA;AAAA;AACxD,CACD;AACD,cAAA,CAAe,WAAA,GAAcF,4BAAiB,OAAA,CAAQ,WAAA","file":"tooltip.js","sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport * as TooltipPrimitive from '@radix-ui/react-tooltip';\n\nimport { cn } from '@/lib/utils';\n\nconst TooltipProvider = TooltipPrimitive.Provider;\n\n// Enhanced Tooltip with click support\nexport interface TooltipProps extends React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Root> {\n /**\n * Whether the tooltip should also trigger on click (in addition to hover/focus)\n * Default: true (hover/focus + click)\n */\n enableClickTrigger?: boolean;\n /**\n * Whether the tooltip should ONLY trigger on click (disables hover/focus)\n * Default: false\n */\n clickOnly?: boolean;\n}\n\nconst Tooltip = React.forwardRef<React.ElementRef<typeof TooltipPrimitive.Root>, TooltipProps>(\n ({ enableClickTrigger = true, clickOnly = false, children, ...props }, ref) => {\n const [clickOpen, setClickOpen] = React.useState(false);\n const isControlled = props.open !== undefined;\n\n const handleOpenChange = React.useCallback(\n (newOpen: boolean) => {\n if ((enableClickTrigger || clickOnly) && !isControlled) {\n setClickOpen(newOpen);\n }\n props.onOpenChange?.(newOpen);\n },\n [enableClickTrigger, clickOnly, isControlled, props],\n );\n\n const finalOpen = React.useMemo(() => {\n if (isControlled) {\n return props.open;\n }\n if (enableClickTrigger || clickOnly) {\n return clickOpen;\n }\n return props.open;\n }, [isControlled, enableClickTrigger, clickOnly, clickOpen, props.open]);\n\n if (enableClickTrigger || clickOnly) {\n return (\n <TooltipPrimitive.Root\n {...props}\n open={finalOpen}\n onOpenChange={handleOpenChange}\n disableHoverableContent={clickOnly} // Only disable hover if clickOnly=true\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child) && child.type === TooltipTrigger) {\n return React.cloneElement(child, {\n ...child.props,\n enableClickTrigger: enableClickTrigger,\n clickOnly: clickOnly,\n tooltipSetOpen: setClickOpen,\n isControlledTooltip: isControlled,\n onTooltipOpenChange: handleOpenChange,\n });\n }\n return child;\n })}\n </TooltipPrimitive.Root>\n );\n }\n\n return (\n <TooltipPrimitive.Root {...props} onOpenChange={handleOpenChange}>\n {children}\n </TooltipPrimitive.Root>\n );\n },\n);\nTooltip.displayName = 'Tooltip';\n\n// Enhanced TooltipTrigger with click support\ninterface TooltipTriggerProps extends React.ComponentPropsWithoutRef<\n typeof TooltipPrimitive.Trigger\n> {\n enableClickTrigger?: boolean;\n clickOnly?: boolean;\n tooltipSetOpen?: (open: boolean) => void;\n isControlledTooltip?: boolean;\n onTooltipOpenChange?: (open: boolean) => void;\n onClick?: (event: React.MouseEvent<Element, MouseEvent>) => void;\n}\n\nconst TooltipTrigger = React.forwardRef<\n React.ElementRef<typeof TooltipPrimitive.Trigger>,\n TooltipTriggerProps\n>(\n (\n {\n className,\n onClick,\n enableClickTrigger = false,\n clickOnly = false,\n tooltipSetOpen,\n isControlledTooltip,\n onTooltipOpenChange,\n ...props\n },\n ref,\n ) => {\n const [isOpen, setIsOpen] = React.useState(false);\n\n const handleClick = React.useCallback(\n (event: React.MouseEvent<Element, MouseEvent>) => {\n if (enableClickTrigger || clickOnly) {\n // Don't prevent default for regular tooltips that also have hover\n if (clickOnly) {\n event.preventDefault();\n }\n\n const newOpen = !isOpen;\n setIsOpen(newOpen);\n\n if (!isControlledTooltip && tooltipSetOpen) {\n tooltipSetOpen(newOpen);\n }\n\n if (onTooltipOpenChange) {\n onTooltipOpenChange(newOpen);\n }\n }\n onClick?.(event);\n },\n [\n enableClickTrigger,\n clickOnly,\n isOpen,\n isControlledTooltip,\n tooltipSetOpen,\n onTooltipOpenChange,\n onClick,\n ],\n );\n\n if (clickOnly) {\n // Click-only mode: disable hover/focus completely\n return (\n <TooltipPrimitive.Trigger\n ref={ref}\n className={cn('cursor-pointer', className)}\n {...props}\n onClick={handleClick}\n onPointerEnter={undefined} // Disable hover when click-only mode\n onPointerLeave={undefined} // Disable hover when click-only mode\n onFocus={undefined} // Disable focus when click-only mode\n onBlur={undefined} // Disable focus when click-only mode\n />\n );\n }\n\n // Default mode or click + hover mode\n return (\n <TooltipPrimitive.Trigger\n ref={ref}\n className={cn(enableClickTrigger ? 'cursor-pointer' : '', className)}\n {...props}\n onClick={handleClick}\n />\n );\n },\n);\nTooltipTrigger.displayName = TooltipPrimitive.Trigger.displayName;\n\nconst TooltipArrow = React.forwardRef<\n React.ElementRef<typeof TooltipPrimitive.Arrow>,\n React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Arrow>\n>(({ className, ...props }, ref) => (\n <TooltipPrimitive.Arrow ref={ref} className={cn('fill-popover', className)} {...props} />\n));\nTooltipArrow.displayName = TooltipPrimitive.Arrow.displayName;\n\nconst TooltipContent = React.forwardRef<\n React.ElementRef<typeof TooltipPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content> & {\n showArrow?: boolean;\n }\n>(({ className, sideOffset = 4, showArrow = true, children, ...props }, ref) => (\n <TooltipPrimitive.Content\n ref={ref}\n sideOffset={sideOffset}\n className={cn(\n 'bg-popover text-popover-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 bg-ink-500s border-ink-500s z-[9999] max-w-[280px] overflow-hidden rounded-md border-none px-3 py-1.5 text-sm text-white shadow-sm',\n className,\n )}\n {...props}\n >\n {children}\n {showArrow && <TooltipArrow className=\"fill-ink-500s\" />}\n </TooltipPrimitive.Content>\n));\nTooltipContent.displayName = TooltipPrimitive.Content.displayName;\n\nexport { Tooltip, TooltipTrigger, TooltipContent, TooltipArrow, TooltipProvider };\n"]}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import * as TooltipPrimitive from '@radix-ui/react-tooltip';
|
|
4
|
+
import { cn } from '@/lib/utils';
|
|
5
|
+
|
|
6
|
+
const TooltipProvider = TooltipPrimitive.Provider;
|
|
7
|
+
const Tooltip = React.forwardRef(
|
|
8
|
+
({ enableClickTrigger = true, clickOnly = false, children, ...props }, ref) => {
|
|
9
|
+
const [clickOpen, setClickOpen] = React.useState(false);
|
|
10
|
+
const isControlled = props.open !== void 0;
|
|
11
|
+
const handleOpenChange = React.useCallback(
|
|
12
|
+
(newOpen) => {
|
|
13
|
+
if ((enableClickTrigger || clickOnly) && !isControlled) {
|
|
14
|
+
setClickOpen(newOpen);
|
|
15
|
+
}
|
|
16
|
+
props.onOpenChange?.(newOpen);
|
|
17
|
+
},
|
|
18
|
+
[enableClickTrigger, clickOnly, isControlled, props]
|
|
19
|
+
);
|
|
20
|
+
const finalOpen = React.useMemo(() => {
|
|
21
|
+
if (isControlled) {
|
|
22
|
+
return props.open;
|
|
23
|
+
}
|
|
24
|
+
if (enableClickTrigger || clickOnly) {
|
|
25
|
+
return clickOpen;
|
|
26
|
+
}
|
|
27
|
+
return props.open;
|
|
28
|
+
}, [isControlled, enableClickTrigger, clickOnly, clickOpen, props.open]);
|
|
29
|
+
if (enableClickTrigger || clickOnly) {
|
|
30
|
+
return /* @__PURE__ */ jsx(
|
|
31
|
+
TooltipPrimitive.Root,
|
|
32
|
+
{
|
|
33
|
+
...props,
|
|
34
|
+
open: finalOpen,
|
|
35
|
+
onOpenChange: handleOpenChange,
|
|
36
|
+
disableHoverableContent: clickOnly,
|
|
37
|
+
children: React.Children.map(children, (child) => {
|
|
38
|
+
if (React.isValidElement(child) && child.type === TooltipTrigger) {
|
|
39
|
+
return React.cloneElement(child, {
|
|
40
|
+
...child.props,
|
|
41
|
+
enableClickTrigger,
|
|
42
|
+
clickOnly,
|
|
43
|
+
tooltipSetOpen: setClickOpen,
|
|
44
|
+
isControlledTooltip: isControlled,
|
|
45
|
+
onTooltipOpenChange: handleOpenChange
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
return child;
|
|
49
|
+
})
|
|
50
|
+
}
|
|
51
|
+
);
|
|
52
|
+
}
|
|
53
|
+
return /* @__PURE__ */ jsx(TooltipPrimitive.Root, { ...props, onOpenChange: handleOpenChange, children });
|
|
54
|
+
}
|
|
55
|
+
);
|
|
56
|
+
Tooltip.displayName = "Tooltip";
|
|
57
|
+
const TooltipTrigger = React.forwardRef(
|
|
58
|
+
({
|
|
59
|
+
className,
|
|
60
|
+
onClick,
|
|
61
|
+
enableClickTrigger = false,
|
|
62
|
+
clickOnly = false,
|
|
63
|
+
tooltipSetOpen,
|
|
64
|
+
isControlledTooltip,
|
|
65
|
+
onTooltipOpenChange,
|
|
66
|
+
...props
|
|
67
|
+
}, ref) => {
|
|
68
|
+
const [isOpen, setIsOpen] = React.useState(false);
|
|
69
|
+
const handleClick = React.useCallback(
|
|
70
|
+
(event) => {
|
|
71
|
+
if (enableClickTrigger || clickOnly) {
|
|
72
|
+
if (clickOnly) {
|
|
73
|
+
event.preventDefault();
|
|
74
|
+
}
|
|
75
|
+
const newOpen = !isOpen;
|
|
76
|
+
setIsOpen(newOpen);
|
|
77
|
+
if (!isControlledTooltip && tooltipSetOpen) {
|
|
78
|
+
tooltipSetOpen(newOpen);
|
|
79
|
+
}
|
|
80
|
+
if (onTooltipOpenChange) {
|
|
81
|
+
onTooltipOpenChange(newOpen);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
onClick?.(event);
|
|
85
|
+
},
|
|
86
|
+
[
|
|
87
|
+
enableClickTrigger,
|
|
88
|
+
clickOnly,
|
|
89
|
+
isOpen,
|
|
90
|
+
isControlledTooltip,
|
|
91
|
+
tooltipSetOpen,
|
|
92
|
+
onTooltipOpenChange,
|
|
93
|
+
onClick
|
|
94
|
+
]
|
|
95
|
+
);
|
|
96
|
+
if (clickOnly) {
|
|
97
|
+
return /* @__PURE__ */ jsx(
|
|
98
|
+
TooltipPrimitive.Trigger,
|
|
99
|
+
{
|
|
100
|
+
ref,
|
|
101
|
+
className: cn("cursor-pointer", className),
|
|
102
|
+
...props,
|
|
103
|
+
onClick: handleClick,
|
|
104
|
+
onPointerEnter: void 0,
|
|
105
|
+
onPointerLeave: void 0,
|
|
106
|
+
onFocus: void 0,
|
|
107
|
+
onBlur: void 0
|
|
108
|
+
}
|
|
109
|
+
);
|
|
110
|
+
}
|
|
111
|
+
return /* @__PURE__ */ jsx(
|
|
112
|
+
TooltipPrimitive.Trigger,
|
|
113
|
+
{
|
|
114
|
+
ref,
|
|
115
|
+
className: cn(enableClickTrigger ? "cursor-pointer" : "", className),
|
|
116
|
+
...props,
|
|
117
|
+
onClick: handleClick
|
|
118
|
+
}
|
|
119
|
+
);
|
|
120
|
+
}
|
|
121
|
+
);
|
|
122
|
+
TooltipTrigger.displayName = TooltipPrimitive.Trigger.displayName;
|
|
123
|
+
const TooltipArrow = React.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx(TooltipPrimitive.Arrow, { ref, className: cn("fill-popover", className), ...props }));
|
|
124
|
+
TooltipArrow.displayName = TooltipPrimitive.Arrow.displayName;
|
|
125
|
+
const TooltipContent = React.forwardRef(({ className, sideOffset = 4, showArrow = true, children, ...props }, ref) => /* @__PURE__ */ jsxs(
|
|
126
|
+
TooltipPrimitive.Content,
|
|
127
|
+
{
|
|
128
|
+
ref,
|
|
129
|
+
sideOffset,
|
|
130
|
+
className: cn(
|
|
131
|
+
"bg-popover text-popover-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 bg-ink-500s border-ink-500s z-[9999] max-w-[280px] overflow-hidden rounded-md border-none px-3 py-1.5 text-sm text-white shadow-sm",
|
|
132
|
+
className
|
|
133
|
+
),
|
|
134
|
+
...props,
|
|
135
|
+
children: [
|
|
136
|
+
children,
|
|
137
|
+
showArrow && /* @__PURE__ */ jsx(TooltipArrow, { className: "fill-ink-500s" })
|
|
138
|
+
]
|
|
139
|
+
}
|
|
140
|
+
));
|
|
141
|
+
TooltipContent.displayName = TooltipPrimitive.Content.displayName;
|
|
142
|
+
|
|
143
|
+
export { Tooltip, TooltipArrow, TooltipContent, TooltipProvider, TooltipTrigger };
|
|
144
|
+
//# sourceMappingURL=tooltip.mjs.map
|
|
145
|
+
//# sourceMappingURL=tooltip.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/components/tooltip.tsx"],"names":[],"mappings":"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","file":"tooltip.mjs","sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport * as TooltipPrimitive from '@radix-ui/react-tooltip';\n\nimport { cn } from '@/lib/utils';\n\nconst TooltipProvider = TooltipPrimitive.Provider;\n\n// Enhanced Tooltip with click support\nexport interface TooltipProps extends React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Root> {\n /**\n * Whether the tooltip should also trigger on click (in addition to hover/focus)\n * Default: true (hover/focus + click)\n */\n enableClickTrigger?: boolean;\n /**\n * Whether the tooltip should ONLY trigger on click (disables hover/focus)\n * Default: false\n */\n clickOnly?: boolean;\n}\n\nconst Tooltip = React.forwardRef<React.ElementRef<typeof TooltipPrimitive.Root>, TooltipProps>(\n ({ enableClickTrigger = true, clickOnly = false, children, ...props }, ref) => {\n const [clickOpen, setClickOpen] = React.useState(false);\n const isControlled = props.open !== undefined;\n\n const handleOpenChange = React.useCallback(\n (newOpen: boolean) => {\n if ((enableClickTrigger || clickOnly) && !isControlled) {\n setClickOpen(newOpen);\n }\n props.onOpenChange?.(newOpen);\n },\n [enableClickTrigger, clickOnly, isControlled, props],\n );\n\n const finalOpen = React.useMemo(() => {\n if (isControlled) {\n return props.open;\n }\n if (enableClickTrigger || clickOnly) {\n return clickOpen;\n }\n return props.open;\n }, [isControlled, enableClickTrigger, clickOnly, clickOpen, props.open]);\n\n if (enableClickTrigger || clickOnly) {\n return (\n <TooltipPrimitive.Root\n {...props}\n open={finalOpen}\n onOpenChange={handleOpenChange}\n disableHoverableContent={clickOnly} // Only disable hover if clickOnly=true\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child) && child.type === TooltipTrigger) {\n return React.cloneElement(child, {\n ...child.props,\n enableClickTrigger: enableClickTrigger,\n clickOnly: clickOnly,\n tooltipSetOpen: setClickOpen,\n isControlledTooltip: isControlled,\n onTooltipOpenChange: handleOpenChange,\n });\n }\n return child;\n })}\n </TooltipPrimitive.Root>\n );\n }\n\n return (\n <TooltipPrimitive.Root {...props} onOpenChange={handleOpenChange}>\n {children}\n </TooltipPrimitive.Root>\n );\n },\n);\nTooltip.displayName = 'Tooltip';\n\n// Enhanced TooltipTrigger with click support\ninterface TooltipTriggerProps extends React.ComponentPropsWithoutRef<\n typeof TooltipPrimitive.Trigger\n> {\n enableClickTrigger?: boolean;\n clickOnly?: boolean;\n tooltipSetOpen?: (open: boolean) => void;\n isControlledTooltip?: boolean;\n onTooltipOpenChange?: (open: boolean) => void;\n onClick?: (event: React.MouseEvent<Element, MouseEvent>) => void;\n}\n\nconst TooltipTrigger = React.forwardRef<\n React.ElementRef<typeof TooltipPrimitive.Trigger>,\n TooltipTriggerProps\n>(\n (\n {\n className,\n onClick,\n enableClickTrigger = false,\n clickOnly = false,\n tooltipSetOpen,\n isControlledTooltip,\n onTooltipOpenChange,\n ...props\n },\n ref,\n ) => {\n const [isOpen, setIsOpen] = React.useState(false);\n\n const handleClick = React.useCallback(\n (event: React.MouseEvent<Element, MouseEvent>) => {\n if (enableClickTrigger || clickOnly) {\n // Don't prevent default for regular tooltips that also have hover\n if (clickOnly) {\n event.preventDefault();\n }\n\n const newOpen = !isOpen;\n setIsOpen(newOpen);\n\n if (!isControlledTooltip && tooltipSetOpen) {\n tooltipSetOpen(newOpen);\n }\n\n if (onTooltipOpenChange) {\n onTooltipOpenChange(newOpen);\n }\n }\n onClick?.(event);\n },\n [\n enableClickTrigger,\n clickOnly,\n isOpen,\n isControlledTooltip,\n tooltipSetOpen,\n onTooltipOpenChange,\n onClick,\n ],\n );\n\n if (clickOnly) {\n // Click-only mode: disable hover/focus completely\n return (\n <TooltipPrimitive.Trigger\n ref={ref}\n className={cn('cursor-pointer', className)}\n {...props}\n onClick={handleClick}\n onPointerEnter={undefined} // Disable hover when click-only mode\n onPointerLeave={undefined} // Disable hover when click-only mode\n onFocus={undefined} // Disable focus when click-only mode\n onBlur={undefined} // Disable focus when click-only mode\n />\n );\n }\n\n // Default mode or click + hover mode\n return (\n <TooltipPrimitive.Trigger\n ref={ref}\n className={cn(enableClickTrigger ? 'cursor-pointer' : '', className)}\n {...props}\n onClick={handleClick}\n />\n );\n },\n);\nTooltipTrigger.displayName = TooltipPrimitive.Trigger.displayName;\n\nconst TooltipArrow = React.forwardRef<\n React.ElementRef<typeof TooltipPrimitive.Arrow>,\n React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Arrow>\n>(({ className, ...props }, ref) => (\n <TooltipPrimitive.Arrow ref={ref} className={cn('fill-popover', className)} {...props} />\n));\nTooltipArrow.displayName = TooltipPrimitive.Arrow.displayName;\n\nconst TooltipContent = React.forwardRef<\n React.ElementRef<typeof TooltipPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content> & {\n showArrow?: boolean;\n }\n>(({ className, sideOffset = 4, showArrow = true, children, ...props }, ref) => (\n <TooltipPrimitive.Content\n ref={ref}\n sideOffset={sideOffset}\n className={cn(\n 'bg-popover text-popover-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 bg-ink-500s border-ink-500s z-[9999] max-w-[280px] overflow-hidden rounded-md border-none px-3 py-1.5 text-sm text-white shadow-sm',\n className,\n )}\n {...props}\n >\n {children}\n {showArrow && <TooltipArrow className=\"fill-ink-500s\" />}\n </TooltipPrimitive.Content>\n));\nTooltipContent.displayName = TooltipPrimitive.Content.displayName;\n\nexport { Tooltip, TooltipTrigger, TooltipContent, TooltipArrow, TooltipProvider };\n"]}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var useDevice = require('./useDevice');
|
|
4
|
+
var useCopyToClipboard = require('./useCopyToClipboard');
|
|
5
|
+
var useIsMounted = require('./useIsMounted');
|
|
6
|
+
var usePathname = require('./usePathname');
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
Object.defineProperty(exports, "useDevice", {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
get: function () { return useDevice.useDevice; }
|
|
13
|
+
});
|
|
14
|
+
Object.defineProperty(exports, "useCopyToClipboard", {
|
|
15
|
+
enumerable: true,
|
|
16
|
+
get: function () { return useCopyToClipboard.useCopyToClipboard; }
|
|
17
|
+
});
|
|
18
|
+
Object.defineProperty(exports, "useIsMounted", {
|
|
19
|
+
enumerable: true,
|
|
20
|
+
get: function () { return useIsMounted.useIsMounted; }
|
|
21
|
+
});
|
|
22
|
+
Object.defineProperty(exports, "usePathname", {
|
|
23
|
+
enumerable: true,
|
|
24
|
+
get: function () { return usePathname.usePathname; }
|
|
25
|
+
});
|
|
26
|
+
//# sourceMappingURL=index.js.map
|
|
27
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"index.js","sourcesContent":[]}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export { useDevice } from './useDevice';
|
|
2
|
+
export { useCopyToClipboard } from './useCopyToClipboard';
|
|
3
|
+
export { useIsMounted } from './useIsMounted';
|
|
4
|
+
export { usePathname } from './usePathname';
|
|
5
|
+
//# sourceMappingURL=index.mjs.map
|
|
6
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"index.mjs","sourcesContent":[]}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var react = require('react');
|
|
4
|
+
var sonner = require('../components/sonner');
|
|
5
|
+
|
|
6
|
+
function useCopyToClipboard() {
|
|
7
|
+
const [status, setStatus] = react.useState("idle");
|
|
8
|
+
const [copiedText, setCopiedText] = react.useState(null);
|
|
9
|
+
const copyToClipboard = react.useCallback(
|
|
10
|
+
async (text, successNotifyText) => {
|
|
11
|
+
try {
|
|
12
|
+
await navigator.clipboard.writeText(text);
|
|
13
|
+
setStatus("copied");
|
|
14
|
+
setCopiedText(text);
|
|
15
|
+
sonner.toast.success(successNotifyText ?? "Copied to clipboard!");
|
|
16
|
+
return true;
|
|
17
|
+
} catch (error) {
|
|
18
|
+
setStatus("failed");
|
|
19
|
+
setCopiedText(null);
|
|
20
|
+
sonner.toast.error("Failed to copy to clipboard");
|
|
21
|
+
console.error("Failed to copy text to clipboard:", error);
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
},
|
|
25
|
+
[]
|
|
26
|
+
);
|
|
27
|
+
const copyToClipboardNoNotify = react.useCallback(async (text) => {
|
|
28
|
+
try {
|
|
29
|
+
await navigator.clipboard.writeText(text);
|
|
30
|
+
setStatus("copied");
|
|
31
|
+
setCopiedText(text);
|
|
32
|
+
return true;
|
|
33
|
+
} catch (error) {
|
|
34
|
+
setStatus("failed");
|
|
35
|
+
setCopiedText(null);
|
|
36
|
+
console.error("Failed to copy text to clipboard:", error);
|
|
37
|
+
return false;
|
|
38
|
+
}
|
|
39
|
+
}, []);
|
|
40
|
+
react.useEffect(() => {
|
|
41
|
+
if (status === "copied" || status === "failed") {
|
|
42
|
+
const timeout = setTimeout(() => {
|
|
43
|
+
setStatus("idle");
|
|
44
|
+
setCopiedText(null);
|
|
45
|
+
}, 2e3);
|
|
46
|
+
return () => clearTimeout(timeout);
|
|
47
|
+
}
|
|
48
|
+
}, [status]);
|
|
49
|
+
return {
|
|
50
|
+
copyToClipboard,
|
|
51
|
+
status,
|
|
52
|
+
copiedText,
|
|
53
|
+
copyToClipboardNoNotify
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
exports.useCopyToClipboard = useCopyToClipboard;
|
|
58
|
+
//# sourceMappingURL=useCopyToClipboard.js.map
|
|
59
|
+
//# sourceMappingURL=useCopyToClipboard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/hooks/useCopyToClipboard.ts"],"names":["useState","useCallback","toast","useEffect"],"mappings":";;;;;AAeO,SAAS,kBAAA,GAA+C;AAC7D,EAAA,MAAM,CAAC,MAAA,EAAQ,SAAS,CAAA,GAAIA,eAAqB,MAAM,CAAA;AACvD,EAAA,MAAM,CAAC,UAAA,EAAY,aAAa,CAAA,GAAIA,eAAwB,IAAI,CAAA;AAEhE,EAAA,MAAM,eAAA,GAAkBC,iBAAA;AAAA,IACtB,OAAO,MAAc,iBAAA,KAAiD;AACpE,MAAA,IAAI;AACF,QAAA,MAAM,SAAA,CAAU,SAAA,CAAU,SAAA,CAAU,IAAI,CAAA;AACxC,QAAA,SAAA,CAAU,QAAQ,CAAA;AAClB,QAAA,aAAA,CAAc,IAAI,CAAA;AAClB,QAAAC,YAAA,CAAM,OAAA,CAAQ,qBAAqB,sBAAsB,CAAA;AACzD,QAAA,OAAO,IAAA;AAAA,MACT,SAAS,KAAA,EAAO;AACd,QAAA,SAAA,CAAU,QAAQ,CAAA;AAClB,QAAA,aAAA,CAAc,IAAI,CAAA;AAClB,QAAAA,YAAA,CAAM,MAAM,6BAA6B,CAAA;AACzC,QAAA,OAAA,CAAQ,KAAA,CAAM,qCAAqC,KAAK,CAAA;AACxD,QAAA,OAAO,KAAA;AAAA,MACT;AAAA,IACF,CAAA;AAAA,IACA;AAAC,GACH;AAEA,EAAA,MAAM,uBAAA,GAA0BD,iBAAA,CAAY,OAAO,IAAA,KAAmC;AACpF,IAAA,IAAI;AACF,MAAA,MAAM,SAAA,CAAU,SAAA,CAAU,SAAA,CAAU,IAAI,CAAA;AACxC,MAAA,SAAA,CAAU,QAAQ,CAAA;AAClB,MAAA,aAAA,CAAc,IAAI,CAAA;AAClB,MAAA,OAAO,IAAA;AAAA,IACT,SAAS,KAAA,EAAO;AACd,MAAA,SAAA,CAAU,QAAQ,CAAA;AAClB,MAAA,aAAA,CAAc,IAAI,CAAA;AAClB,MAAA,OAAA,CAAQ,KAAA,CAAM,qCAAqC,KAAK,CAAA;AACxD,MAAA,OAAO,KAAA;AAAA,IACT;AAAA,EACF,CAAA,EAAG,EAAE,CAAA;AAGL,EAAAE,eAAA,CAAU,MAAM;AACd,IAAA,IAAI,MAAA,KAAW,QAAA,IAAY,MAAA,KAAW,QAAA,EAAU;AAC9C,MAAA,MAAM,OAAA,GAAU,WAAW,MAAM;AAC/B,QAAA,SAAA,CAAU,MAAM,CAAA;AAChB,QAAA,aAAA,CAAc,IAAI,CAAA;AAAA,MACpB,GAAG,GAAI,CAAA;AAEP,MAAA,OAAO,MAAM,aAAa,OAAO,CAAA;AAAA,IACnC;AAAA,EACF,CAAA,EAAG,CAAC,MAAM,CAAC,CAAA;AAEX,EAAA,OAAO;AAAA,IACL,eAAA;AAAA,IACA,MAAA;AAAA,IACA,UAAA;AAAA,IACA;AAAA,GACF;AACF","file":"useCopyToClipboard.js","sourcesContent":["import { useState, useEffect, useCallback } from 'react';\nimport { toast } from '../components/sonner';\n\nexport type CopyStatus = 'idle' | 'copied' | 'failed';\n\nexport interface UseCopyToClipboardReturn {\n copyToClipboard: (text: string, successNotifyText?: string) => Promise<boolean>;\n copyToClipboardNoNotify: (text: string) => Promise<boolean>;\n status: CopyStatus;\n copiedText: string | null;\n}\n\n/**\n * Hook to copy text to clipboard with status tracking\n */\nexport function useCopyToClipboard(): UseCopyToClipboardReturn {\n const [status, setStatus] = useState<CopyStatus>('idle');\n const [copiedText, setCopiedText] = useState<string | null>(null);\n\n const copyToClipboard = useCallback(\n async (text: string, successNotifyText?: string): Promise<boolean> => {\n try {\n await navigator.clipboard.writeText(text);\n setStatus('copied');\n setCopiedText(text);\n toast.success(successNotifyText ?? 'Copied to clipboard!');\n return true;\n } catch (error) {\n setStatus('failed');\n setCopiedText(null);\n toast.error('Failed to copy to clipboard');\n console.error('Failed to copy text to clipboard:', error);\n return false;\n }\n },\n [],\n );\n\n const copyToClipboardNoNotify = useCallback(async (text: string): Promise<boolean> => {\n try {\n await navigator.clipboard.writeText(text);\n setStatus('copied');\n setCopiedText(text);\n return true;\n } catch (error) {\n setStatus('failed');\n setCopiedText(null);\n console.error('Failed to copy text to clipboard:', error);\n return false;\n }\n }, []);\n\n // Reset status after 2 seconds\n useEffect(() => {\n if (status === 'copied' || status === 'failed') {\n const timeout = setTimeout(() => {\n setStatus('idle');\n setCopiedText(null);\n }, 2000);\n\n return () => clearTimeout(timeout);\n }\n }, [status]);\n\n return {\n copyToClipboard,\n status,\n copiedText,\n copyToClipboardNoNotify,\n };\n}\n\n/**\n * Example usage:\n * const { copyToClipboard, status } = useCopyToClipboard();\n *\n * const handleCopy = () => {\n * copyToClipboard('Text to copy', 'Custom success message!');\n * };\n *\n * return (\n * <button onClick={handleCopy}>\n * {status === 'copied' ? 'Copied!' : 'Copy'}\n * </button>\n * );\n */\n"]}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { useState, useCallback, useEffect } from 'react';
|
|
2
|
+
import { toast } from '../components/sonner';
|
|
3
|
+
|
|
4
|
+
function useCopyToClipboard() {
|
|
5
|
+
const [status, setStatus] = useState("idle");
|
|
6
|
+
const [copiedText, setCopiedText] = useState(null);
|
|
7
|
+
const copyToClipboard = useCallback(
|
|
8
|
+
async (text, successNotifyText) => {
|
|
9
|
+
try {
|
|
10
|
+
await navigator.clipboard.writeText(text);
|
|
11
|
+
setStatus("copied");
|
|
12
|
+
setCopiedText(text);
|
|
13
|
+
toast.success(successNotifyText ?? "Copied to clipboard!");
|
|
14
|
+
return true;
|
|
15
|
+
} catch (error) {
|
|
16
|
+
setStatus("failed");
|
|
17
|
+
setCopiedText(null);
|
|
18
|
+
toast.error("Failed to copy to clipboard");
|
|
19
|
+
console.error("Failed to copy text to clipboard:", error);
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
[]
|
|
24
|
+
);
|
|
25
|
+
const copyToClipboardNoNotify = useCallback(async (text) => {
|
|
26
|
+
try {
|
|
27
|
+
await navigator.clipboard.writeText(text);
|
|
28
|
+
setStatus("copied");
|
|
29
|
+
setCopiedText(text);
|
|
30
|
+
return true;
|
|
31
|
+
} catch (error) {
|
|
32
|
+
setStatus("failed");
|
|
33
|
+
setCopiedText(null);
|
|
34
|
+
console.error("Failed to copy text to clipboard:", error);
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
}, []);
|
|
38
|
+
useEffect(() => {
|
|
39
|
+
if (status === "copied" || status === "failed") {
|
|
40
|
+
const timeout = setTimeout(() => {
|
|
41
|
+
setStatus("idle");
|
|
42
|
+
setCopiedText(null);
|
|
43
|
+
}, 2e3);
|
|
44
|
+
return () => clearTimeout(timeout);
|
|
45
|
+
}
|
|
46
|
+
}, [status]);
|
|
47
|
+
return {
|
|
48
|
+
copyToClipboard,
|
|
49
|
+
status,
|
|
50
|
+
copiedText,
|
|
51
|
+
copyToClipboardNoNotify
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
export { useCopyToClipboard };
|
|
56
|
+
//# sourceMappingURL=useCopyToClipboard.mjs.map
|
|
57
|
+
//# sourceMappingURL=useCopyToClipboard.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/hooks/useCopyToClipboard.ts"],"names":[],"mappings":";;;AAeO,SAAS,kBAAA,GAA+C;AAC7D,EAAA,MAAM,CAAC,MAAA,EAAQ,SAAS,CAAA,GAAI,SAAqB,MAAM,CAAA;AACvD,EAAA,MAAM,CAAC,UAAA,EAAY,aAAa,CAAA,GAAI,SAAwB,IAAI,CAAA;AAEhE,EAAA,MAAM,eAAA,GAAkB,WAAA;AAAA,IACtB,OAAO,MAAc,iBAAA,KAAiD;AACpE,MAAA,IAAI;AACF,QAAA,MAAM,SAAA,CAAU,SAAA,CAAU,SAAA,CAAU,IAAI,CAAA;AACxC,QAAA,SAAA,CAAU,QAAQ,CAAA;AAClB,QAAA,aAAA,CAAc,IAAI,CAAA;AAClB,QAAA,KAAA,CAAM,OAAA,CAAQ,qBAAqB,sBAAsB,CAAA;AACzD,QAAA,OAAO,IAAA;AAAA,MACT,SAAS,KAAA,EAAO;AACd,QAAA,SAAA,CAAU,QAAQ,CAAA;AAClB,QAAA,aAAA,CAAc,IAAI,CAAA;AAClB,QAAA,KAAA,CAAM,MAAM,6BAA6B,CAAA;AACzC,QAAA,OAAA,CAAQ,KAAA,CAAM,qCAAqC,KAAK,CAAA;AACxD,QAAA,OAAO,KAAA;AAAA,MACT;AAAA,IACF,CAAA;AAAA,IACA;AAAC,GACH;AAEA,EAAA,MAAM,uBAAA,GAA0B,WAAA,CAAY,OAAO,IAAA,KAAmC;AACpF,IAAA,IAAI;AACF,MAAA,MAAM,SAAA,CAAU,SAAA,CAAU,SAAA,CAAU,IAAI,CAAA;AACxC,MAAA,SAAA,CAAU,QAAQ,CAAA;AAClB,MAAA,aAAA,CAAc,IAAI,CAAA;AAClB,MAAA,OAAO,IAAA;AAAA,IACT,SAAS,KAAA,EAAO;AACd,MAAA,SAAA,CAAU,QAAQ,CAAA;AAClB,MAAA,aAAA,CAAc,IAAI,CAAA;AAClB,MAAA,OAAA,CAAQ,KAAA,CAAM,qCAAqC,KAAK,CAAA;AACxD,MAAA,OAAO,KAAA;AAAA,IACT;AAAA,EACF,CAAA,EAAG,EAAE,CAAA;AAGL,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,IAAI,MAAA,KAAW,QAAA,IAAY,MAAA,KAAW,QAAA,EAAU;AAC9C,MAAA,MAAM,OAAA,GAAU,WAAW,MAAM;AAC/B,QAAA,SAAA,CAAU,MAAM,CAAA;AAChB,QAAA,aAAA,CAAc,IAAI,CAAA;AAAA,MACpB,GAAG,GAAI,CAAA;AAEP,MAAA,OAAO,MAAM,aAAa,OAAO,CAAA;AAAA,IACnC;AAAA,EACF,CAAA,EAAG,CAAC,MAAM,CAAC,CAAA;AAEX,EAAA,OAAO;AAAA,IACL,eAAA;AAAA,IACA,MAAA;AAAA,IACA,UAAA;AAAA,IACA;AAAA,GACF;AACF","file":"useCopyToClipboard.mjs","sourcesContent":["import { useState, useEffect, useCallback } from 'react';\nimport { toast } from '../components/sonner';\n\nexport type CopyStatus = 'idle' | 'copied' | 'failed';\n\nexport interface UseCopyToClipboardReturn {\n copyToClipboard: (text: string, successNotifyText?: string) => Promise<boolean>;\n copyToClipboardNoNotify: (text: string) => Promise<boolean>;\n status: CopyStatus;\n copiedText: string | null;\n}\n\n/**\n * Hook to copy text to clipboard with status tracking\n */\nexport function useCopyToClipboard(): UseCopyToClipboardReturn {\n const [status, setStatus] = useState<CopyStatus>('idle');\n const [copiedText, setCopiedText] = useState<string | null>(null);\n\n const copyToClipboard = useCallback(\n async (text: string, successNotifyText?: string): Promise<boolean> => {\n try {\n await navigator.clipboard.writeText(text);\n setStatus('copied');\n setCopiedText(text);\n toast.success(successNotifyText ?? 'Copied to clipboard!');\n return true;\n } catch (error) {\n setStatus('failed');\n setCopiedText(null);\n toast.error('Failed to copy to clipboard');\n console.error('Failed to copy text to clipboard:', error);\n return false;\n }\n },\n [],\n );\n\n const copyToClipboardNoNotify = useCallback(async (text: string): Promise<boolean> => {\n try {\n await navigator.clipboard.writeText(text);\n setStatus('copied');\n setCopiedText(text);\n return true;\n } catch (error) {\n setStatus('failed');\n setCopiedText(null);\n console.error('Failed to copy text to clipboard:', error);\n return false;\n }\n }, []);\n\n // Reset status after 2 seconds\n useEffect(() => {\n if (status === 'copied' || status === 'failed') {\n const timeout = setTimeout(() => {\n setStatus('idle');\n setCopiedText(null);\n }, 2000);\n\n return () => clearTimeout(timeout);\n }\n }, [status]);\n\n return {\n copyToClipboard,\n status,\n copiedText,\n copyToClipboardNoNotify,\n };\n}\n\n/**\n * Example usage:\n * const { copyToClipboard, status } = useCopyToClipboard();\n *\n * const handleCopy = () => {\n * copyToClipboard('Text to copy', 'Custom success message!');\n * };\n *\n * return (\n * <button onClick={handleCopy}>\n * {status === 'copied' ? 'Copied!' : 'Copy'}\n * </button>\n * );\n */\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var useDeviceSizeStore = require('@/providers/DeviceSizeWatcher/useDeviceSizeStore');
|
|
4
|
+
|
|
5
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
6
|
+
|
|
7
|
+
var useDeviceSizeStore__default = /*#__PURE__*/_interopDefault(useDeviceSizeStore);
|
|
8
|
+
|
|
9
|
+
function useDevice() {
|
|
10
|
+
const deviceSize = useDeviceSizeStore__default.default((state) => state.deviceSize);
|
|
11
|
+
return {
|
|
12
|
+
isMobile: !(deviceSize.lg || deviceSize.xl || deviceSize.md),
|
|
13
|
+
isTablet: deviceSize.md,
|
|
14
|
+
isDesktop: deviceSize.lg || deviceSize.xl
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
exports.useDevice = useDevice;
|
|
19
|
+
//# sourceMappingURL=useDevice.js.map
|
|
20
|
+
//# sourceMappingURL=useDevice.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/hooks/useDevice.ts"],"names":["useDeviceSizeStore"],"mappings":";;;;;;;;AASO,SAAS,SAAA,GAAyB;AACvC,EAAA,MAAM,UAAA,GAAaA,mCAAA,CAAmB,CAAC,KAAA,KAAU,MAAM,UAAU,CAAA;AACjE,EAAA,OAAO;AAAA,IACL,UAAU,EAAE,UAAA,CAAW,EAAA,IAAM,UAAA,CAAW,MAAM,UAAA,CAAW,EAAA,CAAA;AAAA,IACzD,UAAU,UAAA,CAAW,EAAA;AAAA,IACrB,SAAA,EAAW,UAAA,CAAW,EAAA,IAAM,UAAA,CAAW;AAAA,GACzC;AACF","file":"useDevice.js","sourcesContent":["import useDeviceSizeStore from '@/providers/DeviceSizeWatcher/useDeviceSizeStore';\n\nexport interface DeviceState {\n isMobile: boolean;\n isTablet: boolean;\n isDesktop: boolean;\n}\n\n// Main device hook\nexport function useDevice(): DeviceState {\n const deviceSize = useDeviceSizeStore((state) => state.deviceSize);\n return {\n isMobile: !(deviceSize.lg || deviceSize.xl || deviceSize.md),\n isTablet: deviceSize.md,\n isDesktop: deviceSize.lg || deviceSize.xl,\n };\n}\n"]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import useDeviceSizeStore from '@/providers/DeviceSizeWatcher/useDeviceSizeStore';
|
|
2
|
+
|
|
3
|
+
function useDevice() {
|
|
4
|
+
const deviceSize = useDeviceSizeStore((state) => state.deviceSize);
|
|
5
|
+
return {
|
|
6
|
+
isMobile: !(deviceSize.lg || deviceSize.xl || deviceSize.md),
|
|
7
|
+
isTablet: deviceSize.md,
|
|
8
|
+
isDesktop: deviceSize.lg || deviceSize.xl
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export { useDevice };
|
|
13
|
+
//# sourceMappingURL=useDevice.mjs.map
|
|
14
|
+
//# sourceMappingURL=useDevice.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/hooks/useDevice.ts"],"names":[],"mappings":";;AASO,SAAS,SAAA,GAAyB;AACvC,EAAA,MAAM,UAAA,GAAa,kBAAA,CAAmB,CAAC,KAAA,KAAU,MAAM,UAAU,CAAA;AACjE,EAAA,OAAO;AAAA,IACL,UAAU,EAAE,UAAA,CAAW,EAAA,IAAM,UAAA,CAAW,MAAM,UAAA,CAAW,EAAA,CAAA;AAAA,IACzD,UAAU,UAAA,CAAW,EAAA;AAAA,IACrB,SAAA,EAAW,UAAA,CAAW,EAAA,IAAM,UAAA,CAAW;AAAA,GACzC;AACF","file":"useDevice.mjs","sourcesContent":["import useDeviceSizeStore from '@/providers/DeviceSizeWatcher/useDeviceSizeStore';\n\nexport interface DeviceState {\n isMobile: boolean;\n isTablet: boolean;\n isDesktop: boolean;\n}\n\n// Main device hook\nexport function useDevice(): DeviceState {\n const deviceSize = useDeviceSizeStore((state) => state.deviceSize);\n return {\n isMobile: !(deviceSize.lg || deviceSize.xl || deviceSize.md),\n isTablet: deviceSize.md,\n isDesktop: deviceSize.lg || deviceSize.xl,\n };\n}\n"]}
|