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,287 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
4
|
+
var React = require('react');
|
|
5
|
+
var TabsPrimitive = require('@radix-ui/react-tabs');
|
|
6
|
+
var classVarianceAuthority = require('class-variance-authority');
|
|
7
|
+
var react = require('motion/react');
|
|
8
|
+
var utils = require('@/lib/utils');
|
|
9
|
+
var providers = require('@/providers');
|
|
10
|
+
var lib = require('@/lib');
|
|
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
|
+
var TabsPrimitive__namespace = /*#__PURE__*/_interopNamespace(TabsPrimitive);
|
|
32
|
+
|
|
33
|
+
const Tabs = TabsPrimitive__namespace.Root;
|
|
34
|
+
const tabsListVariants = classVarianceAuthority.cva("inline-flex items-center relative scrollbar-hide", {
|
|
35
|
+
variants: {
|
|
36
|
+
variant: {
|
|
37
|
+
normal: "bg-muted text-muted-foreground rounded-md p-1 h-10",
|
|
38
|
+
specific: "border-b border-border bg-transparent gap-6 h-auto p-0 overflow-x-auto",
|
|
39
|
+
fixed: "bg-transparent border-b border-border h-auto p-0 overflow-x-auto",
|
|
40
|
+
full: "bg-transparent border-b border-border h-auto p-0 w-full overflow-x-auto gap-4"
|
|
41
|
+
},
|
|
42
|
+
scrollable: {
|
|
43
|
+
true: "overflow-x-auto justify-start",
|
|
44
|
+
false: "justify-center"
|
|
45
|
+
}
|
|
46
|
+
},
|
|
47
|
+
defaultVariants: {
|
|
48
|
+
variant: "specific",
|
|
49
|
+
scrollable: true
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
const tabsTriggerVariants = classVarianceAuthority.cva(
|
|
53
|
+
"inline-flex items-center justify-center whitespace-nowrap transition-all duration-200 focus-visible:outline-none disabled:pointer-events-none disabled:opacity-50",
|
|
54
|
+
{
|
|
55
|
+
variants: {
|
|
56
|
+
variant: {
|
|
57
|
+
normal: "rounded-sm px-3 py-1.5 font-medium data-[state=active]:bg-background data-[state=active]:text-foreground data-[state=active]:shadow-sm",
|
|
58
|
+
specific: "relative px-0 py-3 font-medium text-muted-foreground hover:text-foreground data-[state=active]:!text-primary",
|
|
59
|
+
fixed: "relative px-4 py-3 font-medium text-muted-foreground hover:text-foreground data-[state=active]:!text-primary",
|
|
60
|
+
full: "relative px-4 py-3 font-medium text-muted-foreground hover:text-foreground data-[state=active]:!text-primary"
|
|
61
|
+
},
|
|
62
|
+
scrollable: {
|
|
63
|
+
true: "",
|
|
64
|
+
false: ""
|
|
65
|
+
}
|
|
66
|
+
},
|
|
67
|
+
compoundVariants: [
|
|
68
|
+
{
|
|
69
|
+
variant: "full",
|
|
70
|
+
scrollable: false,
|
|
71
|
+
className: "flex-1"
|
|
72
|
+
}
|
|
73
|
+
],
|
|
74
|
+
defaultVariants: {
|
|
75
|
+
variant: "specific",
|
|
76
|
+
scrollable: false
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
);
|
|
80
|
+
const TabsList = React__namespace.forwardRef(
|
|
81
|
+
({ className, variant, scrollable, showAnimatedUnderline = true, children, ...props }, ref) => {
|
|
82
|
+
const listRef = React__namespace.useRef(null);
|
|
83
|
+
const [showLeftFade, setShowLeftFade] = React__namespace.useState(false);
|
|
84
|
+
const [showRightFade, setShowRightFade] = React__namespace.useState(false);
|
|
85
|
+
const [underlineStyle, setUnderlineStyle] = React__namespace.useState({ left: 0, width: 0 });
|
|
86
|
+
const tabRefs = React__namespace.useRef([]);
|
|
87
|
+
react.useMotionValue(0);
|
|
88
|
+
const checkScroll = React__namespace.useCallback(() => {
|
|
89
|
+
if (!listRef.current || !scrollable) return;
|
|
90
|
+
const { scrollLeft, scrollWidth, clientWidth } = listRef.current;
|
|
91
|
+
setShowLeftFade(scrollLeft > 0);
|
|
92
|
+
setShowRightFade(scrollLeft < scrollWidth - clientWidth - 1);
|
|
93
|
+
}, [scrollable]);
|
|
94
|
+
const scrollToActiveTab = React__namespace.useCallback(
|
|
95
|
+
(activeTab) => {
|
|
96
|
+
if (!scrollable || !listRef.current) return;
|
|
97
|
+
const list = listRef.current;
|
|
98
|
+
const listRect = list.getBoundingClientRect();
|
|
99
|
+
const tabRect = activeTab.getBoundingClientRect();
|
|
100
|
+
const tabLeft = tabRect.left - listRect.left + list.scrollLeft;
|
|
101
|
+
const tabRight = tabLeft + tabRect.width;
|
|
102
|
+
const visibleLeft = list.scrollLeft;
|
|
103
|
+
const visibleRight = visibleLeft + list.clientWidth;
|
|
104
|
+
const padding = 32;
|
|
105
|
+
let shouldScroll = false;
|
|
106
|
+
let scrollTarget = 0;
|
|
107
|
+
if (tabLeft < visibleLeft + padding) {
|
|
108
|
+
shouldScroll = true;
|
|
109
|
+
scrollTarget = Math.max(0, tabLeft - padding);
|
|
110
|
+
} else if (tabRight > visibleRight - padding) {
|
|
111
|
+
shouldScroll = true;
|
|
112
|
+
scrollTarget = tabRight - list.clientWidth + padding;
|
|
113
|
+
}
|
|
114
|
+
if (shouldScroll) {
|
|
115
|
+
const startScroll = list.scrollLeft;
|
|
116
|
+
const distance = scrollTarget - startScroll;
|
|
117
|
+
react.animate(0, 1, {
|
|
118
|
+
type: "spring",
|
|
119
|
+
stiffness: 300,
|
|
120
|
+
damping: 30,
|
|
121
|
+
onUpdate: (progress) => {
|
|
122
|
+
list.scrollTo({
|
|
123
|
+
left: startScroll + distance * progress,
|
|
124
|
+
behavior: "auto"
|
|
125
|
+
// We're handling the animation ourselves
|
|
126
|
+
});
|
|
127
|
+
},
|
|
128
|
+
onComplete: () => {
|
|
129
|
+
list.scrollTo({ left: scrollTarget, behavior: "auto" });
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
},
|
|
134
|
+
[scrollable]
|
|
135
|
+
);
|
|
136
|
+
React__namespace.useLayoutEffect(() => {
|
|
137
|
+
if (variant === "normal") return;
|
|
138
|
+
const updateUnderline = () => {
|
|
139
|
+
const activeTab = tabRefs.current.find(
|
|
140
|
+
(tab) => tab?.getAttribute("data-state") === "active"
|
|
141
|
+
);
|
|
142
|
+
if (activeTab && listRef.current) {
|
|
143
|
+
const listRect = listRef.current.getBoundingClientRect();
|
|
144
|
+
const tabRect = activeTab.getBoundingClientRect();
|
|
145
|
+
const newLeft = tabRect.left - listRect.left + (listRef.current.scrollLeft || 0);
|
|
146
|
+
const newWidth = tabRect.width;
|
|
147
|
+
if (showAnimatedUnderline) {
|
|
148
|
+
setUnderlineStyle({
|
|
149
|
+
left: newLeft,
|
|
150
|
+
width: newWidth
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
setTimeout(() => {
|
|
154
|
+
scrollToActiveTab(activeTab);
|
|
155
|
+
}, 50);
|
|
156
|
+
}
|
|
157
|
+
};
|
|
158
|
+
updateUnderline();
|
|
159
|
+
const observer = new MutationObserver(() => {
|
|
160
|
+
updateUnderline();
|
|
161
|
+
});
|
|
162
|
+
tabRefs.current.forEach((tab) => {
|
|
163
|
+
if (tab) {
|
|
164
|
+
observer.observe(tab, { attributes: true, attributeFilter: ["data-state"] });
|
|
165
|
+
}
|
|
166
|
+
});
|
|
167
|
+
return () => observer.disconnect();
|
|
168
|
+
}, [showAnimatedUnderline, variant, children, scrollToActiveTab]);
|
|
169
|
+
React__namespace.useEffect(() => {
|
|
170
|
+
checkScroll();
|
|
171
|
+
window.addEventListener("resize", checkScroll);
|
|
172
|
+
return () => window.removeEventListener("resize", checkScroll);
|
|
173
|
+
}, [checkScroll]);
|
|
174
|
+
const childrenWithRefs = React__namespace.Children.map(children, (child, index) => {
|
|
175
|
+
if (React__namespace.isValidElement(child) && child.type === TabsTrigger) {
|
|
176
|
+
return React__namespace.cloneElement(child, {
|
|
177
|
+
scrollable,
|
|
178
|
+
ref: (el) => {
|
|
179
|
+
tabRefs.current[index] = el;
|
|
180
|
+
const originalRef = child.ref;
|
|
181
|
+
if (typeof originalRef === "function") {
|
|
182
|
+
originalRef(el);
|
|
183
|
+
} else if (originalRef) {
|
|
184
|
+
originalRef.current = el;
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
return child;
|
|
190
|
+
});
|
|
191
|
+
return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "relative", children: [
|
|
192
|
+
showLeftFade && /* @__PURE__ */ jsxRuntime.jsx("div", { className: "from-background via-background/80 pointer-events-none absolute left-0 top-0 z-10 h-full w-16 bg-gradient-to-r to-transparent" }),
|
|
193
|
+
/* @__PURE__ */ jsxRuntime.jsxs(
|
|
194
|
+
TabsPrimitive__namespace.List,
|
|
195
|
+
{
|
|
196
|
+
ref: (node) => {
|
|
197
|
+
if (typeof ref === "function") {
|
|
198
|
+
ref(node);
|
|
199
|
+
} else if (ref) {
|
|
200
|
+
ref.current = node;
|
|
201
|
+
}
|
|
202
|
+
listRef.current = node;
|
|
203
|
+
},
|
|
204
|
+
onScroll: checkScroll,
|
|
205
|
+
className: utils.cn(tabsListVariants({ variant, scrollable, className })),
|
|
206
|
+
...props,
|
|
207
|
+
children: [
|
|
208
|
+
childrenWithRefs,
|
|
209
|
+
showAnimatedUnderline && variant !== "normal" && /* @__PURE__ */ jsxRuntime.jsx(
|
|
210
|
+
react.motion.div,
|
|
211
|
+
{
|
|
212
|
+
className: "bg-primary absolute bottom-0 h-0.5",
|
|
213
|
+
layoutId: "tab-underline",
|
|
214
|
+
style: {
|
|
215
|
+
left: underlineStyle.left,
|
|
216
|
+
width: underlineStyle.width
|
|
217
|
+
},
|
|
218
|
+
transition: {
|
|
219
|
+
type: "spring",
|
|
220
|
+
stiffness: 400,
|
|
221
|
+
damping: 40
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
)
|
|
225
|
+
]
|
|
226
|
+
}
|
|
227
|
+
),
|
|
228
|
+
showRightFade && /* @__PURE__ */ jsxRuntime.jsx("div", { className: "from-background via-background/80 pointer-events-none absolute right-0 top-0 z-10 h-full w-16 bg-gradient-to-l to-transparent" })
|
|
229
|
+
] });
|
|
230
|
+
}
|
|
231
|
+
);
|
|
232
|
+
TabsList.displayName = TabsPrimitive__namespace.List.displayName;
|
|
233
|
+
const TabsTrigger = React__namespace.forwardRef(
|
|
234
|
+
({
|
|
235
|
+
className,
|
|
236
|
+
variant,
|
|
237
|
+
scrollable,
|
|
238
|
+
onClick,
|
|
239
|
+
trackingData,
|
|
240
|
+
trackingIndex,
|
|
241
|
+
trackingName,
|
|
242
|
+
blockSendTracking,
|
|
243
|
+
...props
|
|
244
|
+
}, ref) => {
|
|
245
|
+
const { sendTrack } = providers.useUISystemContext();
|
|
246
|
+
const handleClick = (event) => {
|
|
247
|
+
if ((trackingName || trackingData?.identity) && !blockSendTracking) {
|
|
248
|
+
sendTrack(
|
|
249
|
+
trackingName || `sl_tab_${trackingData?.identity}`,
|
|
250
|
+
lib.TRACKING_TYPE.click,
|
|
251
|
+
trackingData
|
|
252
|
+
);
|
|
253
|
+
}
|
|
254
|
+
onClick?.(event);
|
|
255
|
+
};
|
|
256
|
+
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
257
|
+
TabsPrimitive__namespace.Trigger,
|
|
258
|
+
{
|
|
259
|
+
ref,
|
|
260
|
+
className: utils.cn(tabsTriggerVariants({ variant, scrollable, className })),
|
|
261
|
+
onClick: handleClick,
|
|
262
|
+
...props
|
|
263
|
+
}
|
|
264
|
+
);
|
|
265
|
+
}
|
|
266
|
+
);
|
|
267
|
+
TabsTrigger.displayName = TabsPrimitive__namespace.Trigger.displayName;
|
|
268
|
+
const TabsContent = React__namespace.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsxRuntime.jsx(
|
|
269
|
+
TabsPrimitive__namespace.Content,
|
|
270
|
+
{
|
|
271
|
+
ref,
|
|
272
|
+
className: utils.cn(
|
|
273
|
+
"animate-in fade-in-0 slide-in-from-bottom-1 mt-2 duration-200",
|
|
274
|
+
"focus:outline-none focus-visible:outline-none",
|
|
275
|
+
className
|
|
276
|
+
),
|
|
277
|
+
...props
|
|
278
|
+
}
|
|
279
|
+
));
|
|
280
|
+
TabsContent.displayName = TabsPrimitive__namespace.Content.displayName;
|
|
281
|
+
|
|
282
|
+
exports.Tabs = Tabs;
|
|
283
|
+
exports.TabsContent = TabsContent;
|
|
284
|
+
exports.TabsList = TabsList;
|
|
285
|
+
exports.TabsTrigger = TabsTrigger;
|
|
286
|
+
//# sourceMappingURL=tabs.js.map
|
|
287
|
+
//# sourceMappingURL=tabs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/components/tabs.tsx"],"names":["TabsPrimitive","cva","React","useMotionValue","animate","jsxs","jsx","cn","motion","useUISystemContext","TRACKING_TYPE"],"mappings":"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","file":"tabs.js","sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport * as TabsPrimitive from '@radix-ui/react-tabs';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { motion, useMotionValue, animate } from 'motion/react';\n\nimport { cn } from '@/lib/utils';\nimport { useUISystemContext } from '@/providers';\nimport { TRACKING_TYPE } from '@/lib';\n\nconst Tabs = TabsPrimitive.Root;\n\nconst tabsListVariants = cva('inline-flex items-center relative scrollbar-hide', {\n variants: {\n variant: {\n normal: 'bg-muted text-muted-foreground rounded-md p-1 h-10',\n specific: 'border-b border-border bg-transparent gap-6 h-auto p-0 overflow-x-auto',\n fixed: 'bg-transparent border-b border-border h-auto p-0 overflow-x-auto',\n full: 'bg-transparent border-b border-border h-auto p-0 w-full overflow-x-auto gap-4',\n },\n scrollable: {\n true: 'overflow-x-auto justify-start',\n false: 'justify-center',\n },\n },\n defaultVariants: {\n variant: 'specific',\n scrollable: true,\n },\n});\n\nconst tabsTriggerVariants = cva(\n 'inline-flex items-center justify-center whitespace-nowrap transition-all duration-200 focus-visible:outline-none disabled:pointer-events-none disabled:opacity-50',\n {\n variants: {\n variant: {\n normal:\n 'rounded-sm px-3 py-1.5 font-medium data-[state=active]:bg-background data-[state=active]:text-foreground data-[state=active]:shadow-sm',\n specific:\n 'relative px-0 py-3 font-medium text-muted-foreground hover:text-foreground data-[state=active]:!text-primary',\n fixed:\n 'relative px-4 py-3 font-medium text-muted-foreground hover:text-foreground data-[state=active]:!text-primary',\n full: 'relative px-4 py-3 font-medium text-muted-foreground hover:text-foreground data-[state=active]:!text-primary',\n },\n scrollable: {\n true: '',\n false: '',\n },\n },\n compoundVariants: [\n {\n variant: 'full',\n scrollable: false,\n className: 'flex-1',\n },\n ],\n defaultVariants: {\n variant: 'specific',\n scrollable: false,\n },\n },\n);\n\nexport interface TabsListProps\n extends\n React.ComponentPropsWithoutRef<typeof TabsPrimitive.List>,\n VariantProps<typeof tabsListVariants> {\n scrollable?: boolean;\n showAnimatedUnderline?: boolean;\n}\n\ninterface TrackingData {\n identity?: string;\n object_name?: string; // tab name\n index?: number; // tab index\n}\n\nexport interface TabsTriggerProps\n extends\n React.ComponentPropsWithoutRef<typeof TabsPrimitive.Trigger>,\n VariantProps<typeof tabsTriggerVariants> {\n trackingName?: string;\n trackingData?: TrackingData;\n trackingIndex?: number;\n blockSendTracking?: boolean;\n}\n\nconst TabsList = React.forwardRef<React.ElementRef<typeof TabsPrimitive.List>, TabsListProps>(\n ({ className, variant, scrollable, showAnimatedUnderline = true, children, ...props }, ref) => {\n const listRef = React.useRef<HTMLDivElement>(null);\n const [showLeftFade, setShowLeftFade] = React.useState(false);\n const [showRightFade, setShowRightFade] = React.useState(false);\n const [underlineStyle, setUnderlineStyle] = React.useState({ left: 0, width: 0 });\n const tabRefs = React.useRef<(HTMLButtonElement | null)[]>([]);\n const scrollX = useMotionValue(0);\n\n // Check scroll position to show/hide fade indicators\n const checkScroll = React.useCallback(() => {\n if (!listRef.current || !scrollable) return;\n\n const { scrollLeft, scrollWidth, clientWidth } = listRef.current;\n setShowLeftFade(scrollLeft > 0);\n setShowRightFade(scrollLeft < scrollWidth - clientWidth - 1);\n }, [scrollable]);\n\n // Smooth scroll to active tab using Framer Motion\n const scrollToActiveTab = React.useCallback(\n (activeTab: HTMLButtonElement) => {\n if (!scrollable || !listRef.current) return;\n\n const list = listRef.current;\n const listRect = list.getBoundingClientRect();\n const tabRect = activeTab.getBoundingClientRect();\n\n const tabLeft = tabRect.left - listRect.left + list.scrollLeft;\n const tabRight = tabLeft + tabRect.width;\n const visibleLeft = list.scrollLeft;\n const visibleRight = visibleLeft + list.clientWidth;\n\n const padding = 32; // Padding from edges\n\n let shouldScroll = false;\n let scrollTarget = 0;\n\n // Check if tab is outside visible area\n if (tabLeft < visibleLeft + padding) {\n // Tab is to the left of visible area\n shouldScroll = true;\n scrollTarget = Math.max(0, tabLeft - padding);\n } else if (tabRight > visibleRight - padding) {\n // Tab is to the right of visible area\n shouldScroll = true;\n scrollTarget = tabRight - list.clientWidth + padding;\n }\n\n if (shouldScroll) {\n const startScroll = list.scrollLeft;\n const distance = scrollTarget - startScroll;\n\n // Use Framer Motion animate with better mobile support\n animate(0, 1, {\n type: 'spring',\n stiffness: 300,\n damping: 30,\n onUpdate: (progress) => {\n // Use scrollTo instead of direct scrollLeft assignment for better mobile support\n list.scrollTo({\n left: startScroll + distance * progress,\n behavior: 'auto', // We're handling the animation ourselves\n });\n },\n onComplete: () => {\n // Ensure we're at the exact target position\n list.scrollTo({ left: scrollTarget, behavior: 'auto' });\n },\n });\n }\n },\n [scrollable],\n );\n\n // Update underline position based on active tab\n React.useLayoutEffect(() => {\n if (variant === 'normal') return;\n\n const updateUnderline = () => {\n const activeTab = tabRefs.current.find(\n (tab) => tab?.getAttribute('data-state') === 'active',\n );\n\n if (activeTab && listRef.current) {\n const listRect = listRef.current.getBoundingClientRect();\n const tabRect = activeTab.getBoundingClientRect();\n\n const newLeft = tabRect.left - listRect.left + (listRef.current.scrollLeft || 0);\n const newWidth = tabRect.width;\n\n if (showAnimatedUnderline) {\n setUnderlineStyle({\n left: newLeft,\n width: newWidth,\n });\n }\n\n // Scroll to active tab after a small delay\n setTimeout(() => {\n scrollToActiveTab(activeTab);\n }, 50);\n }\n };\n\n // Initial update\n updateUnderline();\n\n // Watch for tab state changes\n const observer = new MutationObserver(() => {\n updateUnderline();\n });\n\n tabRefs.current.forEach((tab) => {\n if (tab) {\n observer.observe(tab, { attributes: true, attributeFilter: ['data-state'] });\n }\n });\n\n return () => observer.disconnect();\n }, [showAnimatedUnderline, variant, children, scrollToActiveTab]);\n\n React.useEffect(() => {\n checkScroll();\n window.addEventListener('resize', checkScroll);\n return () => window.removeEventListener('resize', checkScroll);\n }, [checkScroll]);\n\n // Clone children to inject refs and scrollable prop\n const childrenWithRefs = React.Children.map(children, (child, index) => {\n if (React.isValidElement(child) && child.type === TabsTrigger) {\n return React.cloneElement(child as React.ReactElement<any>, {\n scrollable,\n ref: (el: HTMLButtonElement | null) => {\n tabRefs.current[index] = el;\n // Preserve original ref if exists\n const originalRef = (child as any).ref;\n if (typeof originalRef === 'function') {\n originalRef(el);\n } else if (originalRef) {\n originalRef.current = el;\n }\n },\n });\n }\n return child;\n });\n\n return (\n <div className=\"relative\">\n {/* Left fade indicator */}\n {showLeftFade && (\n <div className=\"from-background via-background/80 pointer-events-none absolute left-0 top-0 z-10 h-full w-16 bg-gradient-to-r to-transparent\" />\n )}\n\n <TabsPrimitive.List\n ref={(node) => {\n if (typeof ref === 'function') {\n ref(node);\n } else if (ref) {\n ref.current = node;\n }\n // @ts-ignore\n listRef.current = node;\n }}\n onScroll={checkScroll}\n className={cn(tabsListVariants({ variant, scrollable, className }))}\n {...props}\n >\n {childrenWithRefs}\n\n {/* Animated underline */}\n {showAnimatedUnderline && variant !== 'normal' && (\n <motion.div\n className=\"bg-primary absolute bottom-0 h-0.5\"\n layoutId=\"tab-underline\"\n style={{\n left: underlineStyle.left,\n width: underlineStyle.width,\n }}\n transition={{\n type: 'spring',\n stiffness: 400,\n damping: 40,\n }}\n />\n )}\n </TabsPrimitive.List>\n\n {/* Right fade indicator */}\n {showRightFade && (\n <div className=\"from-background via-background/80 pointer-events-none absolute right-0 top-0 z-10 h-full w-16 bg-gradient-to-l to-transparent\" />\n )}\n </div>\n );\n },\n);\nTabsList.displayName = TabsPrimitive.List.displayName;\n\nconst TabsTrigger = React.forwardRef<\n React.ElementRef<typeof TabsPrimitive.Trigger>,\n TabsTriggerProps\n>(\n (\n {\n className,\n variant,\n scrollable,\n onClick,\n trackingData,\n trackingIndex,\n trackingName,\n blockSendTracking,\n ...props\n },\n ref,\n ) => {\n const { sendTrack } = useUISystemContext();\n const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n if ((trackingName || trackingData?.identity) && !blockSendTracking) {\n sendTrack(\n trackingName || `sl_tab_${trackingData?.identity}`,\n TRACKING_TYPE.click,\n trackingData,\n );\n }\n onClick?.(event);\n };\n\n return (\n <TabsPrimitive.Trigger\n ref={ref}\n className={cn(tabsTriggerVariants({ variant, scrollable, className }))}\n onClick={handleClick}\n {...props}\n />\n );\n },\n);\nTabsTrigger.displayName = TabsPrimitive.Trigger.displayName;\n\nconst TabsContent = React.forwardRef<\n React.ElementRef<typeof TabsPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof TabsPrimitive.Content>\n>(({ className, ...props }, ref) => (\n <TabsPrimitive.Content\n ref={ref}\n className={cn(\n 'animate-in fade-in-0 slide-in-from-bottom-1 mt-2 duration-200',\n 'focus:outline-none focus-visible:outline-none',\n className,\n )}\n {...props}\n />\n));\nTabsContent.displayName = TabsPrimitive.Content.displayName;\n\nexport { Tabs, TabsList, TabsTrigger, TabsContent };\n"]}
|
|
@@ -0,0 +1,261 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import * as TabsPrimitive from '@radix-ui/react-tabs';
|
|
4
|
+
import { cva } from 'class-variance-authority';
|
|
5
|
+
import { useMotionValue, animate, motion } from 'motion/react';
|
|
6
|
+
import { cn } from '@/lib/utils';
|
|
7
|
+
import { useUISystemContext } from '@/providers';
|
|
8
|
+
import { TRACKING_TYPE } from '@/lib';
|
|
9
|
+
|
|
10
|
+
const Tabs = TabsPrimitive.Root;
|
|
11
|
+
const tabsListVariants = cva("inline-flex items-center relative scrollbar-hide", {
|
|
12
|
+
variants: {
|
|
13
|
+
variant: {
|
|
14
|
+
normal: "bg-muted text-muted-foreground rounded-md p-1 h-10",
|
|
15
|
+
specific: "border-b border-border bg-transparent gap-6 h-auto p-0 overflow-x-auto",
|
|
16
|
+
fixed: "bg-transparent border-b border-border h-auto p-0 overflow-x-auto",
|
|
17
|
+
full: "bg-transparent border-b border-border h-auto p-0 w-full overflow-x-auto gap-4"
|
|
18
|
+
},
|
|
19
|
+
scrollable: {
|
|
20
|
+
true: "overflow-x-auto justify-start",
|
|
21
|
+
false: "justify-center"
|
|
22
|
+
}
|
|
23
|
+
},
|
|
24
|
+
defaultVariants: {
|
|
25
|
+
variant: "specific",
|
|
26
|
+
scrollable: true
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
const tabsTriggerVariants = cva(
|
|
30
|
+
"inline-flex items-center justify-center whitespace-nowrap transition-all duration-200 focus-visible:outline-none disabled:pointer-events-none disabled:opacity-50",
|
|
31
|
+
{
|
|
32
|
+
variants: {
|
|
33
|
+
variant: {
|
|
34
|
+
normal: "rounded-sm px-3 py-1.5 font-medium data-[state=active]:bg-background data-[state=active]:text-foreground data-[state=active]:shadow-sm",
|
|
35
|
+
specific: "relative px-0 py-3 font-medium text-muted-foreground hover:text-foreground data-[state=active]:!text-primary",
|
|
36
|
+
fixed: "relative px-4 py-3 font-medium text-muted-foreground hover:text-foreground data-[state=active]:!text-primary",
|
|
37
|
+
full: "relative px-4 py-3 font-medium text-muted-foreground hover:text-foreground data-[state=active]:!text-primary"
|
|
38
|
+
},
|
|
39
|
+
scrollable: {
|
|
40
|
+
true: "",
|
|
41
|
+
false: ""
|
|
42
|
+
}
|
|
43
|
+
},
|
|
44
|
+
compoundVariants: [
|
|
45
|
+
{
|
|
46
|
+
variant: "full",
|
|
47
|
+
scrollable: false,
|
|
48
|
+
className: "flex-1"
|
|
49
|
+
}
|
|
50
|
+
],
|
|
51
|
+
defaultVariants: {
|
|
52
|
+
variant: "specific",
|
|
53
|
+
scrollable: false
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
);
|
|
57
|
+
const TabsList = React.forwardRef(
|
|
58
|
+
({ className, variant, scrollable, showAnimatedUnderline = true, children, ...props }, ref) => {
|
|
59
|
+
const listRef = React.useRef(null);
|
|
60
|
+
const [showLeftFade, setShowLeftFade] = React.useState(false);
|
|
61
|
+
const [showRightFade, setShowRightFade] = React.useState(false);
|
|
62
|
+
const [underlineStyle, setUnderlineStyle] = React.useState({ left: 0, width: 0 });
|
|
63
|
+
const tabRefs = React.useRef([]);
|
|
64
|
+
useMotionValue(0);
|
|
65
|
+
const checkScroll = React.useCallback(() => {
|
|
66
|
+
if (!listRef.current || !scrollable) return;
|
|
67
|
+
const { scrollLeft, scrollWidth, clientWidth } = listRef.current;
|
|
68
|
+
setShowLeftFade(scrollLeft > 0);
|
|
69
|
+
setShowRightFade(scrollLeft < scrollWidth - clientWidth - 1);
|
|
70
|
+
}, [scrollable]);
|
|
71
|
+
const scrollToActiveTab = React.useCallback(
|
|
72
|
+
(activeTab) => {
|
|
73
|
+
if (!scrollable || !listRef.current) return;
|
|
74
|
+
const list = listRef.current;
|
|
75
|
+
const listRect = list.getBoundingClientRect();
|
|
76
|
+
const tabRect = activeTab.getBoundingClientRect();
|
|
77
|
+
const tabLeft = tabRect.left - listRect.left + list.scrollLeft;
|
|
78
|
+
const tabRight = tabLeft + tabRect.width;
|
|
79
|
+
const visibleLeft = list.scrollLeft;
|
|
80
|
+
const visibleRight = visibleLeft + list.clientWidth;
|
|
81
|
+
const padding = 32;
|
|
82
|
+
let shouldScroll = false;
|
|
83
|
+
let scrollTarget = 0;
|
|
84
|
+
if (tabLeft < visibleLeft + padding) {
|
|
85
|
+
shouldScroll = true;
|
|
86
|
+
scrollTarget = Math.max(0, tabLeft - padding);
|
|
87
|
+
} else if (tabRight > visibleRight - padding) {
|
|
88
|
+
shouldScroll = true;
|
|
89
|
+
scrollTarget = tabRight - list.clientWidth + padding;
|
|
90
|
+
}
|
|
91
|
+
if (shouldScroll) {
|
|
92
|
+
const startScroll = list.scrollLeft;
|
|
93
|
+
const distance = scrollTarget - startScroll;
|
|
94
|
+
animate(0, 1, {
|
|
95
|
+
type: "spring",
|
|
96
|
+
stiffness: 300,
|
|
97
|
+
damping: 30,
|
|
98
|
+
onUpdate: (progress) => {
|
|
99
|
+
list.scrollTo({
|
|
100
|
+
left: startScroll + distance * progress,
|
|
101
|
+
behavior: "auto"
|
|
102
|
+
// We're handling the animation ourselves
|
|
103
|
+
});
|
|
104
|
+
},
|
|
105
|
+
onComplete: () => {
|
|
106
|
+
list.scrollTo({ left: scrollTarget, behavior: "auto" });
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
},
|
|
111
|
+
[scrollable]
|
|
112
|
+
);
|
|
113
|
+
React.useLayoutEffect(() => {
|
|
114
|
+
if (variant === "normal") return;
|
|
115
|
+
const updateUnderline = () => {
|
|
116
|
+
const activeTab = tabRefs.current.find(
|
|
117
|
+
(tab) => tab?.getAttribute("data-state") === "active"
|
|
118
|
+
);
|
|
119
|
+
if (activeTab && listRef.current) {
|
|
120
|
+
const listRect = listRef.current.getBoundingClientRect();
|
|
121
|
+
const tabRect = activeTab.getBoundingClientRect();
|
|
122
|
+
const newLeft = tabRect.left - listRect.left + (listRef.current.scrollLeft || 0);
|
|
123
|
+
const newWidth = tabRect.width;
|
|
124
|
+
if (showAnimatedUnderline) {
|
|
125
|
+
setUnderlineStyle({
|
|
126
|
+
left: newLeft,
|
|
127
|
+
width: newWidth
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
setTimeout(() => {
|
|
131
|
+
scrollToActiveTab(activeTab);
|
|
132
|
+
}, 50);
|
|
133
|
+
}
|
|
134
|
+
};
|
|
135
|
+
updateUnderline();
|
|
136
|
+
const observer = new MutationObserver(() => {
|
|
137
|
+
updateUnderline();
|
|
138
|
+
});
|
|
139
|
+
tabRefs.current.forEach((tab) => {
|
|
140
|
+
if (tab) {
|
|
141
|
+
observer.observe(tab, { attributes: true, attributeFilter: ["data-state"] });
|
|
142
|
+
}
|
|
143
|
+
});
|
|
144
|
+
return () => observer.disconnect();
|
|
145
|
+
}, [showAnimatedUnderline, variant, children, scrollToActiveTab]);
|
|
146
|
+
React.useEffect(() => {
|
|
147
|
+
checkScroll();
|
|
148
|
+
window.addEventListener("resize", checkScroll);
|
|
149
|
+
return () => window.removeEventListener("resize", checkScroll);
|
|
150
|
+
}, [checkScroll]);
|
|
151
|
+
const childrenWithRefs = React.Children.map(children, (child, index) => {
|
|
152
|
+
if (React.isValidElement(child) && child.type === TabsTrigger) {
|
|
153
|
+
return React.cloneElement(child, {
|
|
154
|
+
scrollable,
|
|
155
|
+
ref: (el) => {
|
|
156
|
+
tabRefs.current[index] = el;
|
|
157
|
+
const originalRef = child.ref;
|
|
158
|
+
if (typeof originalRef === "function") {
|
|
159
|
+
originalRef(el);
|
|
160
|
+
} else if (originalRef) {
|
|
161
|
+
originalRef.current = el;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
return child;
|
|
167
|
+
});
|
|
168
|
+
return /* @__PURE__ */ jsxs("div", { className: "relative", children: [
|
|
169
|
+
showLeftFade && /* @__PURE__ */ jsx("div", { className: "from-background via-background/80 pointer-events-none absolute left-0 top-0 z-10 h-full w-16 bg-gradient-to-r to-transparent" }),
|
|
170
|
+
/* @__PURE__ */ jsxs(
|
|
171
|
+
TabsPrimitive.List,
|
|
172
|
+
{
|
|
173
|
+
ref: (node) => {
|
|
174
|
+
if (typeof ref === "function") {
|
|
175
|
+
ref(node);
|
|
176
|
+
} else if (ref) {
|
|
177
|
+
ref.current = node;
|
|
178
|
+
}
|
|
179
|
+
listRef.current = node;
|
|
180
|
+
},
|
|
181
|
+
onScroll: checkScroll,
|
|
182
|
+
className: cn(tabsListVariants({ variant, scrollable, className })),
|
|
183
|
+
...props,
|
|
184
|
+
children: [
|
|
185
|
+
childrenWithRefs,
|
|
186
|
+
showAnimatedUnderline && variant !== "normal" && /* @__PURE__ */ jsx(
|
|
187
|
+
motion.div,
|
|
188
|
+
{
|
|
189
|
+
className: "bg-primary absolute bottom-0 h-0.5",
|
|
190
|
+
layoutId: "tab-underline",
|
|
191
|
+
style: {
|
|
192
|
+
left: underlineStyle.left,
|
|
193
|
+
width: underlineStyle.width
|
|
194
|
+
},
|
|
195
|
+
transition: {
|
|
196
|
+
type: "spring",
|
|
197
|
+
stiffness: 400,
|
|
198
|
+
damping: 40
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
)
|
|
202
|
+
]
|
|
203
|
+
}
|
|
204
|
+
),
|
|
205
|
+
showRightFade && /* @__PURE__ */ jsx("div", { className: "from-background via-background/80 pointer-events-none absolute right-0 top-0 z-10 h-full w-16 bg-gradient-to-l to-transparent" })
|
|
206
|
+
] });
|
|
207
|
+
}
|
|
208
|
+
);
|
|
209
|
+
TabsList.displayName = TabsPrimitive.List.displayName;
|
|
210
|
+
const TabsTrigger = React.forwardRef(
|
|
211
|
+
({
|
|
212
|
+
className,
|
|
213
|
+
variant,
|
|
214
|
+
scrollable,
|
|
215
|
+
onClick,
|
|
216
|
+
trackingData,
|
|
217
|
+
trackingIndex,
|
|
218
|
+
trackingName,
|
|
219
|
+
blockSendTracking,
|
|
220
|
+
...props
|
|
221
|
+
}, ref) => {
|
|
222
|
+
const { sendTrack } = useUISystemContext();
|
|
223
|
+
const handleClick = (event) => {
|
|
224
|
+
if ((trackingName || trackingData?.identity) && !blockSendTracking) {
|
|
225
|
+
sendTrack(
|
|
226
|
+
trackingName || `sl_tab_${trackingData?.identity}`,
|
|
227
|
+
TRACKING_TYPE.click,
|
|
228
|
+
trackingData
|
|
229
|
+
);
|
|
230
|
+
}
|
|
231
|
+
onClick?.(event);
|
|
232
|
+
};
|
|
233
|
+
return /* @__PURE__ */ jsx(
|
|
234
|
+
TabsPrimitive.Trigger,
|
|
235
|
+
{
|
|
236
|
+
ref,
|
|
237
|
+
className: cn(tabsTriggerVariants({ variant, scrollable, className })),
|
|
238
|
+
onClick: handleClick,
|
|
239
|
+
...props
|
|
240
|
+
}
|
|
241
|
+
);
|
|
242
|
+
}
|
|
243
|
+
);
|
|
244
|
+
TabsTrigger.displayName = TabsPrimitive.Trigger.displayName;
|
|
245
|
+
const TabsContent = React.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx(
|
|
246
|
+
TabsPrimitive.Content,
|
|
247
|
+
{
|
|
248
|
+
ref,
|
|
249
|
+
className: cn(
|
|
250
|
+
"animate-in fade-in-0 slide-in-from-bottom-1 mt-2 duration-200",
|
|
251
|
+
"focus:outline-none focus-visible:outline-none",
|
|
252
|
+
className
|
|
253
|
+
),
|
|
254
|
+
...props
|
|
255
|
+
}
|
|
256
|
+
));
|
|
257
|
+
TabsContent.displayName = TabsPrimitive.Content.displayName;
|
|
258
|
+
|
|
259
|
+
export { Tabs, TabsContent, TabsList, TabsTrigger };
|
|
260
|
+
//# sourceMappingURL=tabs.mjs.map
|
|
261
|
+
//# sourceMappingURL=tabs.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/components/tabs.tsx"],"names":[],"mappings":"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","file":"tabs.mjs","sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport * as TabsPrimitive from '@radix-ui/react-tabs';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { motion, useMotionValue, animate } from 'motion/react';\n\nimport { cn } from '@/lib/utils';\nimport { useUISystemContext } from '@/providers';\nimport { TRACKING_TYPE } from '@/lib';\n\nconst Tabs = TabsPrimitive.Root;\n\nconst tabsListVariants = cva('inline-flex items-center relative scrollbar-hide', {\n variants: {\n variant: {\n normal: 'bg-muted text-muted-foreground rounded-md p-1 h-10',\n specific: 'border-b border-border bg-transparent gap-6 h-auto p-0 overflow-x-auto',\n fixed: 'bg-transparent border-b border-border h-auto p-0 overflow-x-auto',\n full: 'bg-transparent border-b border-border h-auto p-0 w-full overflow-x-auto gap-4',\n },\n scrollable: {\n true: 'overflow-x-auto justify-start',\n false: 'justify-center',\n },\n },\n defaultVariants: {\n variant: 'specific',\n scrollable: true,\n },\n});\n\nconst tabsTriggerVariants = cva(\n 'inline-flex items-center justify-center whitespace-nowrap transition-all duration-200 focus-visible:outline-none disabled:pointer-events-none disabled:opacity-50',\n {\n variants: {\n variant: {\n normal:\n 'rounded-sm px-3 py-1.5 font-medium data-[state=active]:bg-background data-[state=active]:text-foreground data-[state=active]:shadow-sm',\n specific:\n 'relative px-0 py-3 font-medium text-muted-foreground hover:text-foreground data-[state=active]:!text-primary',\n fixed:\n 'relative px-4 py-3 font-medium text-muted-foreground hover:text-foreground data-[state=active]:!text-primary',\n full: 'relative px-4 py-3 font-medium text-muted-foreground hover:text-foreground data-[state=active]:!text-primary',\n },\n scrollable: {\n true: '',\n false: '',\n },\n },\n compoundVariants: [\n {\n variant: 'full',\n scrollable: false,\n className: 'flex-1',\n },\n ],\n defaultVariants: {\n variant: 'specific',\n scrollable: false,\n },\n },\n);\n\nexport interface TabsListProps\n extends\n React.ComponentPropsWithoutRef<typeof TabsPrimitive.List>,\n VariantProps<typeof tabsListVariants> {\n scrollable?: boolean;\n showAnimatedUnderline?: boolean;\n}\n\ninterface TrackingData {\n identity?: string;\n object_name?: string; // tab name\n index?: number; // tab index\n}\n\nexport interface TabsTriggerProps\n extends\n React.ComponentPropsWithoutRef<typeof TabsPrimitive.Trigger>,\n VariantProps<typeof tabsTriggerVariants> {\n trackingName?: string;\n trackingData?: TrackingData;\n trackingIndex?: number;\n blockSendTracking?: boolean;\n}\n\nconst TabsList = React.forwardRef<React.ElementRef<typeof TabsPrimitive.List>, TabsListProps>(\n ({ className, variant, scrollable, showAnimatedUnderline = true, children, ...props }, ref) => {\n const listRef = React.useRef<HTMLDivElement>(null);\n const [showLeftFade, setShowLeftFade] = React.useState(false);\n const [showRightFade, setShowRightFade] = React.useState(false);\n const [underlineStyle, setUnderlineStyle] = React.useState({ left: 0, width: 0 });\n const tabRefs = React.useRef<(HTMLButtonElement | null)[]>([]);\n const scrollX = useMotionValue(0);\n\n // Check scroll position to show/hide fade indicators\n const checkScroll = React.useCallback(() => {\n if (!listRef.current || !scrollable) return;\n\n const { scrollLeft, scrollWidth, clientWidth } = listRef.current;\n setShowLeftFade(scrollLeft > 0);\n setShowRightFade(scrollLeft < scrollWidth - clientWidth - 1);\n }, [scrollable]);\n\n // Smooth scroll to active tab using Framer Motion\n const scrollToActiveTab = React.useCallback(\n (activeTab: HTMLButtonElement) => {\n if (!scrollable || !listRef.current) return;\n\n const list = listRef.current;\n const listRect = list.getBoundingClientRect();\n const tabRect = activeTab.getBoundingClientRect();\n\n const tabLeft = tabRect.left - listRect.left + list.scrollLeft;\n const tabRight = tabLeft + tabRect.width;\n const visibleLeft = list.scrollLeft;\n const visibleRight = visibleLeft + list.clientWidth;\n\n const padding = 32; // Padding from edges\n\n let shouldScroll = false;\n let scrollTarget = 0;\n\n // Check if tab is outside visible area\n if (tabLeft < visibleLeft + padding) {\n // Tab is to the left of visible area\n shouldScroll = true;\n scrollTarget = Math.max(0, tabLeft - padding);\n } else if (tabRight > visibleRight - padding) {\n // Tab is to the right of visible area\n shouldScroll = true;\n scrollTarget = tabRight - list.clientWidth + padding;\n }\n\n if (shouldScroll) {\n const startScroll = list.scrollLeft;\n const distance = scrollTarget - startScroll;\n\n // Use Framer Motion animate with better mobile support\n animate(0, 1, {\n type: 'spring',\n stiffness: 300,\n damping: 30,\n onUpdate: (progress) => {\n // Use scrollTo instead of direct scrollLeft assignment for better mobile support\n list.scrollTo({\n left: startScroll + distance * progress,\n behavior: 'auto', // We're handling the animation ourselves\n });\n },\n onComplete: () => {\n // Ensure we're at the exact target position\n list.scrollTo({ left: scrollTarget, behavior: 'auto' });\n },\n });\n }\n },\n [scrollable],\n );\n\n // Update underline position based on active tab\n React.useLayoutEffect(() => {\n if (variant === 'normal') return;\n\n const updateUnderline = () => {\n const activeTab = tabRefs.current.find(\n (tab) => tab?.getAttribute('data-state') === 'active',\n );\n\n if (activeTab && listRef.current) {\n const listRect = listRef.current.getBoundingClientRect();\n const tabRect = activeTab.getBoundingClientRect();\n\n const newLeft = tabRect.left - listRect.left + (listRef.current.scrollLeft || 0);\n const newWidth = tabRect.width;\n\n if (showAnimatedUnderline) {\n setUnderlineStyle({\n left: newLeft,\n width: newWidth,\n });\n }\n\n // Scroll to active tab after a small delay\n setTimeout(() => {\n scrollToActiveTab(activeTab);\n }, 50);\n }\n };\n\n // Initial update\n updateUnderline();\n\n // Watch for tab state changes\n const observer = new MutationObserver(() => {\n updateUnderline();\n });\n\n tabRefs.current.forEach((tab) => {\n if (tab) {\n observer.observe(tab, { attributes: true, attributeFilter: ['data-state'] });\n }\n });\n\n return () => observer.disconnect();\n }, [showAnimatedUnderline, variant, children, scrollToActiveTab]);\n\n React.useEffect(() => {\n checkScroll();\n window.addEventListener('resize', checkScroll);\n return () => window.removeEventListener('resize', checkScroll);\n }, [checkScroll]);\n\n // Clone children to inject refs and scrollable prop\n const childrenWithRefs = React.Children.map(children, (child, index) => {\n if (React.isValidElement(child) && child.type === TabsTrigger) {\n return React.cloneElement(child as React.ReactElement<any>, {\n scrollable,\n ref: (el: HTMLButtonElement | null) => {\n tabRefs.current[index] = el;\n // Preserve original ref if exists\n const originalRef = (child as any).ref;\n if (typeof originalRef === 'function') {\n originalRef(el);\n } else if (originalRef) {\n originalRef.current = el;\n }\n },\n });\n }\n return child;\n });\n\n return (\n <div className=\"relative\">\n {/* Left fade indicator */}\n {showLeftFade && (\n <div className=\"from-background via-background/80 pointer-events-none absolute left-0 top-0 z-10 h-full w-16 bg-gradient-to-r to-transparent\" />\n )}\n\n <TabsPrimitive.List\n ref={(node) => {\n if (typeof ref === 'function') {\n ref(node);\n } else if (ref) {\n ref.current = node;\n }\n // @ts-ignore\n listRef.current = node;\n }}\n onScroll={checkScroll}\n className={cn(tabsListVariants({ variant, scrollable, className }))}\n {...props}\n >\n {childrenWithRefs}\n\n {/* Animated underline */}\n {showAnimatedUnderline && variant !== 'normal' && (\n <motion.div\n className=\"bg-primary absolute bottom-0 h-0.5\"\n layoutId=\"tab-underline\"\n style={{\n left: underlineStyle.left,\n width: underlineStyle.width,\n }}\n transition={{\n type: 'spring',\n stiffness: 400,\n damping: 40,\n }}\n />\n )}\n </TabsPrimitive.List>\n\n {/* Right fade indicator */}\n {showRightFade && (\n <div className=\"from-background via-background/80 pointer-events-none absolute right-0 top-0 z-10 h-full w-16 bg-gradient-to-l to-transparent\" />\n )}\n </div>\n );\n },\n);\nTabsList.displayName = TabsPrimitive.List.displayName;\n\nconst TabsTrigger = React.forwardRef<\n React.ElementRef<typeof TabsPrimitive.Trigger>,\n TabsTriggerProps\n>(\n (\n {\n className,\n variant,\n scrollable,\n onClick,\n trackingData,\n trackingIndex,\n trackingName,\n blockSendTracking,\n ...props\n },\n ref,\n ) => {\n const { sendTrack } = useUISystemContext();\n const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n if ((trackingName || trackingData?.identity) && !blockSendTracking) {\n sendTrack(\n trackingName || `sl_tab_${trackingData?.identity}`,\n TRACKING_TYPE.click,\n trackingData,\n );\n }\n onClick?.(event);\n };\n\n return (\n <TabsPrimitive.Trigger\n ref={ref}\n className={cn(tabsTriggerVariants({ variant, scrollable, className }))}\n onClick={handleClick}\n {...props}\n />\n );\n },\n);\nTabsTrigger.displayName = TabsPrimitive.Trigger.displayName;\n\nconst TabsContent = React.forwardRef<\n React.ElementRef<typeof TabsPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof TabsPrimitive.Content>\n>(({ className, ...props }, ref) => (\n <TabsPrimitive.Content\n ref={ref}\n className={cn(\n 'animate-in fade-in-0 slide-in-from-bottom-1 mt-2 duration-200',\n 'focus:outline-none focus-visible:outline-none',\n className,\n )}\n {...props}\n />\n));\nTabsContent.displayName = TabsPrimitive.Content.displayName;\n\nexport { Tabs, TabsList, TabsTrigger, TabsContent };\n"]}
|