erp-pro-ui 0.1.0 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +544 -188
- package/dist/accordion.cjs +3 -0
- package/dist/accordion.d.ts +2 -0
- package/dist/accordion.mjs +2 -0
- package/dist/alert.cjs +3 -0
- package/dist/alert.d.ts +2 -0
- package/dist/alert.mjs +2 -0
- package/dist/animated-content.cjs +3 -0
- package/dist/animated-content.d.ts +2 -0
- package/dist/animated-content.mjs +2 -0
- package/dist/animations.css +91 -0
- package/dist/ascii-text.cjs +3 -0
- package/dist/ascii-text.d.ts +2 -0
- package/dist/ascii-text.mjs +2 -0
- package/dist/background-gradient-animation.cjs +4 -0
- package/dist/background-gradient-animation.d.ts +2 -0
- package/dist/background-gradient-animation.mjs +2 -0
- package/dist/button-hover-border-gradient.cjs +3 -0
- package/dist/button-hover-border-gradient.d.ts +2 -0
- package/dist/button-hover-border-gradient.mjs +2 -0
- package/dist/button.cjs +3 -0
- package/dist/button.d.ts +2 -0
- package/dist/button.mjs +2 -0
- package/dist/calendar.cjs +3 -0
- package/dist/calendar.d.ts +2 -0
- package/dist/calendar.mjs +2 -0
- package/dist/card.cjs +3 -0
- package/dist/card.d.ts +2 -0
- package/dist/card.mjs +2 -0
- package/dist/carousel.cjs +3 -0
- package/dist/carousel.d.ts +2 -0
- package/dist/carousel.mjs +2 -0
- package/dist/catalog.cjs +308 -0
- package/dist/catalog.cjs.map +1 -0
- package/dist/catalog.d.ts +496 -0
- package/dist/catalog.d.ts.map +1 -0
- package/dist/catalog.mjs +304 -0
- package/dist/catalog.mjs.map +1 -0
- package/dist/charts.cjs +11 -0
- package/dist/charts.d.ts +2 -0
- package/dist/charts.mjs +2 -0
- package/dist/checkbox.cjs +3 -0
- package/dist/checkbox.d.ts +2 -0
- package/dist/checkbox.mjs +2 -0
- package/dist/chip.cjs +3 -0
- package/dist/chip.d.ts +2 -0
- package/dist/chip.mjs +2 -0
- package/dist/chroma-grid.cjs +3 -0
- package/dist/chroma-grid.d.ts +2 -0
- package/dist/chroma-grid.mjs +2 -0
- package/dist/chunks/HoverBorderGradient-DVFEIXFQ.mjs +69 -0
- package/dist/chunks/HoverBorderGradient-DVFEIXFQ.mjs.map +1 -0
- package/dist/chunks/HoverBorderGradient-Df3PKpw6.cjs +75 -0
- package/dist/chunks/HoverBorderGradient-Df3PKpw6.cjs.map +1 -0
- package/dist/chunks/accordion-Cbt-SJhj.mjs +66 -0
- package/dist/chunks/accordion-Cbt-SJhj.mjs.map +1 -0
- package/dist/chunks/accordion-pfJR8YYA.cjs +72 -0
- package/dist/chunks/accordion-pfJR8YYA.cjs.map +1 -0
- package/dist/chunks/alert-CtdLy4Hv.mjs +40 -0
- package/dist/chunks/alert-CtdLy4Hv.mjs.map +1 -0
- package/dist/chunks/alert-Dvz1GoL5.cjs +46 -0
- package/dist/chunks/alert-Dvz1GoL5.cjs.map +1 -0
- package/dist/chunks/animated-content-C1uNg1xO.mjs +292 -0
- package/dist/chunks/animated-content-C1uNg1xO.mjs.map +1 -0
- package/dist/chunks/animated-content-CttSmLWV.cjs +298 -0
- package/dist/chunks/animated-content-CttSmLWV.cjs.map +1 -0
- package/dist/chunks/ascii-text-C5tyNsR3.mjs +511 -0
- package/dist/chunks/ascii-text-C5tyNsR3.mjs.map +1 -0
- package/dist/chunks/ascii-text-DlmArZXh.cjs +519 -0
- package/dist/chunks/ascii-text-DlmArZXh.cjs.map +1 -0
- package/dist/chunks/background-gradient-animation-BL-lnrJe.mjs +144 -0
- package/dist/chunks/background-gradient-animation-BL-lnrJe.mjs.map +1 -0
- package/dist/chunks/background-gradient-animation-CXV9GDH8.cjs +156 -0
- package/dist/chunks/background-gradient-animation-CXV9GDH8.cjs.map +1 -0
- package/dist/chunks/button-B0Lhj0AS.mjs +42 -0
- package/dist/chunks/button-B0Lhj0AS.mjs.map +1 -0
- package/dist/chunks/button-CZL6kFzT.cjs +48 -0
- package/dist/chunks/button-CZL6kFzT.cjs.map +1 -0
- package/dist/chunks/button-hover-border-gradient-CSHXM5Cm.cjs +24 -0
- package/dist/chunks/button-hover-border-gradient-CSHXM5Cm.cjs.map +1 -0
- package/dist/chunks/button-hover-border-gradient-CvoM60wz.mjs +18 -0
- package/dist/chunks/button-hover-border-gradient-CvoM60wz.mjs.map +1 -0
- package/dist/chunks/calendar-BarcG6x_.mjs +137 -0
- package/dist/chunks/calendar-BarcG6x_.mjs.map +1 -0
- package/dist/chunks/calendar-xrGmvukr.cjs +143 -0
- package/dist/chunks/calendar-xrGmvukr.cjs.map +1 -0
- package/dist/chunks/card-CcIF6z2H.mjs +24 -0
- package/dist/chunks/card-CcIF6z2H.mjs.map +1 -0
- package/dist/chunks/card-gt-HZh0h.cjs +30 -0
- package/dist/chunks/card-gt-HZh0h.cjs.map +1 -0
- package/dist/chunks/carousel-Cq5uwqQt.cjs +313 -0
- package/dist/chunks/carousel-Cq5uwqQt.cjs.map +1 -0
- package/dist/chunks/carousel-DJdqBVRK.mjs +307 -0
- package/dist/chunks/carousel-DJdqBVRK.mjs.map +1 -0
- package/dist/chunks/charts-BpElnsoR.cjs +687 -0
- package/dist/chunks/charts-BpElnsoR.cjs.map +1 -0
- package/dist/chunks/charts-DugYWvEf.mjs +632 -0
- package/dist/chunks/charts-DugYWvEf.mjs.map +1 -0
- package/dist/chunks/checkbox-DvwlGwWe.mjs +53 -0
- package/dist/chunks/checkbox-DvwlGwWe.mjs.map +1 -0
- package/dist/chunks/checkbox-yHuSw-hV.cjs +59 -0
- package/dist/chunks/checkbox-yHuSw-hV.cjs.map +1 -0
- package/dist/chunks/chip-BGSUmnlO.mjs +139 -0
- package/dist/chunks/chip-BGSUmnlO.mjs.map +1 -0
- package/dist/chunks/chip-DcBji__g.cjs +145 -0
- package/dist/chunks/chip-DcBji__g.cjs.map +1 -0
- package/dist/chunks/chroma-grid-9E9j1s9I.cjs +221 -0
- package/dist/chunks/chroma-grid-9E9j1s9I.cjs.map +1 -0
- package/dist/chunks/chroma-grid-Cdeql_2C.mjs +215 -0
- package/dist/chunks/chroma-grid-Cdeql_2C.mjs.map +1 -0
- package/dist/chunks/chunk-B_GkZjkl.cjs +28 -0
- package/dist/chunks/color-palette-BLvDnCOD.cjs +754 -0
- package/dist/chunks/color-palette-BLvDnCOD.cjs.map +1 -0
- package/dist/chunks/color-palette-CXlCDiZz.mjs +748 -0
- package/dist/chunks/color-palette-CXlCDiZz.mjs.map +1 -0
- package/dist/chunks/combobox-BXu3s0dt.cjs +139 -0
- package/dist/chunks/combobox-BXu3s0dt.cjs.map +1 -0
- package/dist/chunks/combobox-CjK-qG4k.mjs +132 -0
- package/dist/chunks/combobox-CjK-qG4k.mjs.map +1 -0
- package/dist/chunks/data-table-9HELVsYR.cjs +1154 -0
- package/dist/chunks/data-table-9HELVsYR.cjs.map +1 -0
- package/dist/chunks/data-table-DyEQn9Yj.mjs +1123 -0
- package/dist/chunks/data-table-DyEQn9Yj.mjs.map +1 -0
- package/dist/chunks/date-picker-D8gaaMlJ.mjs +135 -0
- package/dist/chunks/date-picker-D8gaaMlJ.mjs.map +1 -0
- package/dist/chunks/date-picker-W9om1j7A.cjs +141 -0
- package/dist/chunks/date-picker-W9om1j7A.cjs.map +1 -0
- package/dist/chunks/dialog-CYFiWN8M.cjs +396 -0
- package/dist/chunks/dialog-CYFiWN8M.cjs.map +1 -0
- package/dist/chunks/dialog-DUWnV9tN.mjs +390 -0
- package/dist/chunks/dialog-DUWnV9tN.mjs.map +1 -0
- package/dist/chunks/drawer-CLjsYdxN.cjs +128 -0
- package/dist/chunks/drawer-CLjsYdxN.cjs.map +1 -0
- package/dist/chunks/drawer-D82Jz6KO.mjs +122 -0
- package/dist/chunks/drawer-D82Jz6KO.mjs.map +1 -0
- package/dist/chunks/form-B2vcaHwh.mjs +161 -0
- package/dist/chunks/form-B2vcaHwh.mjs.map +1 -0
- package/dist/chunks/form-CzH9GQc6.cjs +203 -0
- package/dist/chunks/form-CzH9GQc6.cjs.map +1 -0
- package/dist/chunks/gradual-blur-B9GoY8o1.cjs +65 -0
- package/dist/chunks/gradual-blur-B9GoY8o1.cjs.map +1 -0
- package/dist/chunks/gradual-blur-Bl3dOMEz.mjs +59 -0
- package/dist/chunks/gradual-blur-Bl3dOMEz.mjs.map +1 -0
- package/dist/chunks/hover-card-v0QwmVBU.cjs +191 -0
- package/dist/chunks/hover-card-v0QwmVBU.cjs.map +1 -0
- package/dist/chunks/hover-card-xqwpmZNm.mjs +185 -0
- package/dist/chunks/hover-card-xqwpmZNm.mjs.map +1 -0
- package/dist/chunks/icons-BxIzP2jd.cjs +1717 -0
- package/dist/chunks/icons-BxIzP2jd.cjs.map +1 -0
- package/dist/chunks/icons-DuumN7z-.mjs +1429 -0
- package/dist/chunks/icons-DuumN7z-.mjs.map +1 -0
- package/dist/chunks/input-D9qZNqXV.cjs +99 -0
- package/dist/chunks/input-D9qZNqXV.cjs.map +1 -0
- package/dist/chunks/input-wNqevfQ4.mjs +87 -0
- package/dist/chunks/input-wNqevfQ4.mjs.map +1 -0
- package/dist/chunks/label-BWPEGVam.cjs +32 -0
- package/dist/chunks/label-BWPEGVam.cjs.map +1 -0
- package/dist/chunks/label-KPA-yYOF.mjs +26 -0
- package/dist/chunks/label-KPA-yYOF.mjs.map +1 -0
- package/dist/chunks/loading-S1TdIrbB.mjs +259 -0
- package/dist/chunks/loading-S1TdIrbB.mjs.map +1 -0
- package/dist/chunks/loading-q7IEg56I.cjs +313 -0
- package/dist/chunks/loading-q7IEg56I.cjs.map +1 -0
- package/dist/chunks/multi-select-combobox-ELSH_Xr4.mjs +132 -0
- package/dist/chunks/multi-select-combobox-ELSH_Xr4.mjs.map +1 -0
- package/dist/chunks/multi-select-combobox-UW0X15W7.cjs +139 -0
- package/dist/chunks/multi-select-combobox-UW0X15W7.cjs.map +1 -0
- package/dist/chunks/otp-input-B6zzOEqw.cjs +186 -0
- package/dist/chunks/otp-input-B6zzOEqw.cjs.map +1 -0
- package/dist/chunks/otp-input-Bg4nQG6x.mjs +180 -0
- package/dist/chunks/otp-input-Bg4nQG6x.mjs.map +1 -0
- package/dist/chunks/overlay-DWNTyQzK.cjs +60 -0
- package/dist/chunks/overlay-DWNTyQzK.cjs.map +1 -0
- package/dist/chunks/overlay-TycCIFOu.mjs +54 -0
- package/dist/chunks/overlay-TycCIFOu.mjs.map +1 -0
- package/dist/chunks/password-strength-meter-CbNSBuh_.mjs +99 -0
- package/dist/chunks/password-strength-meter-CbNSBuh_.mjs.map +1 -0
- package/dist/chunks/password-strength-meter-DxMV6GAs.cjs +105 -0
- package/dist/chunks/password-strength-meter-DxMV6GAs.cjs.map +1 -0
- package/dist/chunks/progress-bar-C1OvQ-NI.cjs +96 -0
- package/dist/chunks/progress-bar-C1OvQ-NI.cjs.map +1 -0
- package/dist/chunks/progress-bar-C9FZDrju.mjs +89 -0
- package/dist/chunks/progress-bar-C9FZDrju.mjs.map +1 -0
- package/dist/chunks/radio-C9w_CoiY.mjs +44 -0
- package/dist/chunks/radio-C9w_CoiY.mjs.map +1 -0
- package/dist/chunks/radio-jMHDvaMY.cjs +50 -0
- package/dist/chunks/radio-jMHDvaMY.cjs.map +1 -0
- package/dist/chunks/select-D71tk6-I.mjs +152 -0
- package/dist/chunks/select-D71tk6-I.mjs.map +1 -0
- package/dist/chunks/select-WC_kPqUP.cjs +158 -0
- package/dist/chunks/select-WC_kPqUP.cjs.map +1 -0
- package/dist/chunks/skeleton-BhYWOp0Q.mjs +215 -0
- package/dist/chunks/skeleton-BhYWOp0Q.mjs.map +1 -0
- package/dist/chunks/skeleton-DTXpHYYB.cjs +221 -0
- package/dist/chunks/skeleton-DTXpHYYB.cjs.map +1 -0
- package/dist/chunks/spinners-BBCWD2gw.mjs +11 -0
- package/dist/chunks/spinners-BBCWD2gw.mjs.map +1 -0
- package/dist/chunks/spinners-BL4ERCCw.cjs +17 -0
- package/dist/chunks/spinners-BL4ERCCw.cjs.map +1 -0
- package/dist/chunks/splash-cursor-BVSmbcIX.cjs +279 -0
- package/dist/chunks/splash-cursor-BVSmbcIX.cjs.map +1 -0
- package/dist/chunks/splash-cursor-rSrTnawZ.mjs +273 -0
- package/dist/chunks/splash-cursor-rSrTnawZ.mjs.map +1 -0
- package/dist/chunks/spotlight-card-BpZLMOp6.mjs +104 -0
- package/dist/chunks/spotlight-card-BpZLMOp6.mjs.map +1 -0
- package/dist/chunks/spotlight-card-DS1dy1W3.cjs +110 -0
- package/dist/chunks/spotlight-card-DS1dy1W3.cjs.map +1 -0
- package/dist/chunks/stepper-D4yQsQB0.mjs +261 -0
- package/dist/chunks/stepper-D4yQsQB0.mjs.map +1 -0
- package/dist/chunks/stepper-fY-Sx72k.cjs +267 -0
- package/dist/chunks/stepper-fY-Sx72k.cjs.map +1 -0
- package/dist/chunks/sun-to-moon-button-B2Aje05o.mjs +186 -0
- package/dist/chunks/sun-to-moon-button-B2Aje05o.mjs.map +1 -0
- package/dist/chunks/sun-to-moon-button-BmFwRBye.cjs +192 -0
- package/dist/chunks/sun-to-moon-button-BmFwRBye.cjs.map +1 -0
- package/dist/chunks/switch-C5otDb4c.cjs +64 -0
- package/dist/chunks/switch-C5otDb4c.cjs.map +1 -0
- package/dist/chunks/switch-DOVl_i_s.mjs +58 -0
- package/dist/chunks/switch-DOVl_i_s.mjs.map +1 -0
- package/dist/chunks/textarea-CAUsyu4-.cjs +63 -0
- package/dist/chunks/textarea-CAUsyu4-.cjs.map +1 -0
- package/dist/chunks/textarea-CU5C-Zw9.mjs +57 -0
- package/dist/chunks/textarea-CU5C-Zw9.mjs.map +1 -0
- package/dist/chunks/theme-7DWLxJK_.cjs +68 -0
- package/dist/chunks/theme-7DWLxJK_.cjs.map +1 -0
- package/dist/chunks/theme-BceKeYhw.mjs +56 -0
- package/dist/chunks/theme-BceKeYhw.mjs.map +1 -0
- package/dist/chunks/toast-CvfP7PUP.mjs +339 -0
- package/dist/chunks/toast-CvfP7PUP.mjs.map +1 -0
- package/dist/chunks/toast-Ds7_19Ap.cjs +369 -0
- package/dist/chunks/toast-Ds7_19Ap.cjs.map +1 -0
- package/dist/chunks/tooltip-efHETBo1.mjs +199 -0
- package/dist/chunks/tooltip-efHETBo1.mjs.map +1 -0
- package/dist/chunks/tooltip-nkIqViGk.cjs +205 -0
- package/dist/chunks/tooltip-nkIqViGk.cjs.map +1 -0
- package/dist/chunks/typography-CLu6Hx9j.mjs +83 -0
- package/dist/chunks/typography-CLu6Hx9j.mjs.map +1 -0
- package/dist/chunks/typography-DaLu9tty.cjs +90 -0
- package/dist/chunks/typography-DaLu9tty.cjs.map +1 -0
- package/dist/chunks/utils-B4SmmY4J.cjs +2019 -0
- package/dist/chunks/utils-B4SmmY4J.cjs.map +1 -0
- package/dist/chunks/utils-ati1KkDb.mjs +2002 -0
- package/dist/chunks/utils-ati1KkDb.mjs.map +1 -0
- package/dist/color-palette.cjs +3 -0
- package/dist/color-palette.d.ts +2 -0
- package/dist/color-palette.mjs +2 -0
- package/dist/colors.css +153 -0
- package/dist/combobox.cjs +3 -0
- package/dist/combobox.d.ts +2 -0
- package/dist/combobox.mjs +2 -0
- package/dist/components/data-display/card/Card.d.ts.map +1 -0
- package/dist/components/data-display/card/index.d.ts.map +1 -0
- package/dist/components/data-display/card/types.d.ts +5 -0
- package/dist/components/data-display/card/types.d.ts.map +1 -0
- package/dist/components/data-display/charts/AreaChart.d.ts.map +1 -0
- package/dist/components/data-display/charts/BarChart.d.ts.map +1 -0
- package/dist/components/data-display/charts/NeonLineChart.d.ts.map +1 -0
- package/dist/components/data-display/charts/PieChart.d.ts.map +1 -0
- package/dist/components/data-display/charts/StackedBarChart.d.ts.map +1 -0
- package/dist/components/data-display/charts/ThinBreakdownBar.d.ts.map +1 -0
- package/dist/components/data-display/charts/chartPalette.d.ts +10 -0
- package/dist/components/data-display/charts/chartPalette.d.ts.map +1 -0
- package/dist/components/data-display/charts/index.d.ts +14 -0
- package/dist/components/data-display/charts/index.d.ts.map +1 -0
- package/dist/components/data-display/chip/Chip.d.ts.map +1 -0
- package/dist/components/data-display/chip/index.d.ts.map +1 -0
- package/dist/components/data-display/color-palette/ColorPalette.d.ts.map +1 -0
- package/dist/components/data-display/color-palette/index.d.ts.map +1 -0
- package/dist/components/data-display/color-palette/types.d.ts +14 -0
- package/dist/components/data-display/color-palette/types.d.ts.map +1 -0
- package/dist/components/{basics → data-display}/data-table/DataTable.d.ts +27 -11
- package/dist/components/data-display/data-table/DataTable.d.ts.map +1 -0
- package/dist/components/data-display/data-table/index.d.ts +4 -0
- package/dist/components/data-display/data-table/index.d.ts.map +1 -0
- package/dist/components/data-display/index.d.ts +10 -0
- package/dist/components/data-display/index.d.ts.map +1 -0
- package/dist/components/{basics → data-display}/loading/Loading.d.ts +7 -7
- package/dist/components/data-display/loading/Loading.d.ts.map +1 -0
- package/dist/components/data-display/loading/index.d.ts.map +1 -0
- package/dist/components/data-display/loading/types.d.ts +25 -0
- package/dist/components/data-display/loading/types.d.ts.map +1 -0
- package/dist/components/data-display/progress-bar/ProgressBar.d.ts +18 -0
- package/dist/components/data-display/progress-bar/ProgressBar.d.ts.map +1 -0
- package/dist/components/data-display/progress-bar/index.d.ts +3 -0
- package/dist/components/data-display/progress-bar/index.d.ts.map +1 -0
- package/dist/components/data-display/skeleton/Skeleton.d.ts.map +1 -0
- package/dist/components/data-display/skeleton/index.d.ts.map +1 -0
- package/dist/components/effects/animated-content/AnimatedContent.d.ts.map +1 -0
- package/dist/components/effects/animated-content/index.d.ts.map +1 -0
- package/dist/components/effects/animated-content/types.d.ts +45 -0
- package/dist/components/effects/animated-content/types.d.ts.map +1 -0
- package/dist/components/effects/ascii-text/ASCIIText.d.ts.map +1 -0
- package/dist/components/effects/ascii-text/index.d.ts.map +1 -0
- package/dist/components/effects/background-gradient-animation/BackgroundGradientAnimation.d.ts.map +1 -0
- package/dist/components/effects/background-gradient-animation/BackgroundGradientAnimationDemo.d.ts.map +1 -0
- package/dist/components/effects/background-gradient-animation/index.d.ts.map +1 -0
- package/dist/components/effects/border-beam/BorderBeam.d.ts +12 -0
- package/dist/components/effects/border-beam/BorderBeam.d.ts.map +1 -0
- package/dist/components/effects/border-beam/index.d.ts +3 -0
- package/dist/components/effects/border-beam/index.d.ts.map +1 -0
- package/dist/components/effects/button-hover-border-gradient/ButtonHoverBorderGradient.d.ts.map +1 -0
- package/dist/components/effects/button-hover-border-gradient/index.d.ts.map +1 -0
- package/dist/components/effects/chroma-grid/ChromaGrid.d.ts.map +1 -0
- package/dist/components/effects/chroma-grid/index.d.ts +3 -0
- package/dist/components/effects/chroma-grid/index.d.ts.map +1 -0
- package/dist/components/effects/chroma-grid/types.d.ts +50 -0
- package/dist/components/effects/chroma-grid/types.d.ts.map +1 -0
- package/dist/components/{basics → effects}/gradual-blur/GradualBlur.d.ts +1 -1
- package/dist/components/effects/gradual-blur/GradualBlur.d.ts.map +1 -0
- package/dist/components/effects/gradual-blur/index.d.ts +3 -0
- package/dist/components/effects/gradual-blur/index.d.ts.map +1 -0
- package/dist/components/effects/gradual-blur/types.d.ts +28 -0
- package/dist/components/effects/gradual-blur/types.d.ts.map +1 -0
- package/dist/components/effects/hover-border-gradient/HoverBorderGradient.d.ts.map +1 -0
- package/dist/components/effects/hover-border-gradient/index.d.ts.map +1 -0
- package/dist/components/effects/index.d.ts +12 -0
- package/dist/components/effects/index.d.ts.map +1 -0
- package/dist/components/effects/splash-cursor/SplashCursor.d.ts.map +1 -0
- package/dist/components/effects/splash-cursor/index.d.ts.map +1 -0
- package/dist/components/effects/splash-cursor/types.d.ts +40 -0
- package/dist/components/effects/splash-cursor/types.d.ts.map +1 -0
- package/dist/components/effects/spotlight-card/SpotlightCard.d.ts.map +1 -0
- package/dist/components/effects/spotlight-card/index.d.ts +3 -0
- package/dist/components/effects/spotlight-card/index.d.ts.map +1 -0
- package/dist/components/effects/spotlight-card/types.d.ts +26 -0
- package/dist/components/effects/spotlight-card/types.d.ts.map +1 -0
- package/dist/components/effects/sun-to-moon-button/SunToMoonButton.d.ts +5 -0
- package/dist/components/effects/sun-to-moon-button/SunToMoonButton.d.ts.map +1 -0
- package/dist/components/effects/sun-to-moon-button/index.d.ts.map +1 -0
- package/dist/components/feedback/alert/Alert.d.ts.map +1 -0
- package/dist/components/feedback/alert/index.d.ts.map +1 -0
- package/dist/components/feedback/alert/types.d.ts +11 -0
- package/dist/components/feedback/alert/types.d.ts.map +1 -0
- package/dist/components/feedback/index.d.ts +2 -0
- package/dist/components/feedback/index.d.ts.map +1 -0
- package/dist/components/{basics/Button → forms/button}/Button.d.ts +1 -1
- package/dist/components/forms/button/Button.d.ts.map +1 -0
- package/dist/components/forms/button/index.d.ts.map +1 -0
- package/dist/components/forms/button/types.d.ts +14 -0
- package/dist/components/forms/button/types.d.ts.map +1 -0
- package/dist/components/forms/calendar/Calendar.d.ts.map +1 -0
- package/dist/components/forms/calendar/index.d.ts.map +1 -0
- package/dist/components/forms/calendar/types.d.ts +20 -0
- package/dist/components/forms/calendar/types.d.ts.map +1 -0
- package/dist/components/forms/checkbox/Checkbox.d.ts.map +1 -0
- package/dist/components/forms/checkbox/index.d.ts.map +1 -0
- package/dist/components/forms/checkbox/types.d.ts +8 -0
- package/dist/components/forms/checkbox/types.d.ts.map +1 -0
- package/dist/components/{basics → forms}/combobox/Combobox.d.ts +1 -1
- package/dist/components/forms/combobox/Combobox.d.ts.map +1 -0
- package/dist/components/forms/combobox/index.d.ts.map +1 -0
- package/dist/components/forms/date-picker/DatePicker.d.ts.map +1 -0
- package/dist/components/forms/date-picker/index.d.ts +3 -0
- package/dist/components/forms/date-picker/index.d.ts.map +1 -0
- package/dist/components/forms/date-picker/types.d.ts +21 -0
- package/dist/components/forms/date-picker/types.d.ts.map +1 -0
- package/dist/components/forms/form/Form.d.ts.map +1 -0
- package/dist/components/forms/form/index.d.ts.map +1 -0
- package/dist/components/forms/form/types.d.ts +47 -0
- package/dist/components/forms/form/types.d.ts.map +1 -0
- package/dist/components/forms/index.d.ts +15 -0
- package/dist/components/forms/index.d.ts.map +1 -0
- package/dist/components/forms/input/Input.d.ts.map +1 -0
- package/dist/components/{basics → forms}/input/index.d.ts +1 -0
- package/dist/components/forms/input/index.d.ts.map +1 -0
- package/dist/components/forms/input/types.d.ts.map +1 -0
- package/dist/components/forms/label/Label.d.ts.map +1 -0
- package/dist/components/forms/label/index.d.ts.map +1 -0
- package/dist/components/forms/label/types.d.ts +5 -0
- package/dist/components/forms/label/types.d.ts.map +1 -0
- package/dist/components/{basics → forms}/multi-select-combobox/MultiSelectCombobox.d.ts +1 -1
- package/dist/components/forms/multi-select-combobox/MultiSelectCombobox.d.ts.map +1 -0
- package/dist/components/forms/multi-select-combobox/index.d.ts +3 -0
- package/dist/components/forms/multi-select-combobox/index.d.ts.map +1 -0
- package/dist/components/forms/otp-input/OTPInput.d.ts.map +1 -0
- package/dist/components/forms/otp-input/index.d.ts +3 -0
- package/dist/components/{basics/skeleton → forms/otp-input}/index.d.ts.map +1 -1
- package/dist/components/forms/otp-input/types.d.ts +2 -0
- package/dist/components/forms/otp-input/types.d.ts.map +1 -0
- package/dist/components/forms/password-strength-meter/PasswordCriteria.d.ts.map +1 -0
- package/dist/components/forms/password-strength-meter/PasswordStrengthMeter.d.ts +5 -0
- package/dist/components/forms/password-strength-meter/PasswordStrengthMeter.d.ts.map +1 -0
- package/dist/components/forms/password-strength-meter/index.d.ts +3 -0
- package/dist/components/forms/password-strength-meter/index.d.ts.map +1 -0
- package/dist/components/forms/radio/Radio.d.ts.map +1 -0
- package/dist/components/forms/radio/index.d.ts.map +1 -0
- package/dist/components/forms/radio/types.d.ts +11 -0
- package/dist/components/forms/radio/types.d.ts.map +1 -0
- package/dist/components/forms/select/Select.d.ts.map +1 -0
- package/dist/components/forms/select/index.d.ts.map +1 -0
- package/dist/components/forms/select/types.d.ts +15 -0
- package/dist/components/forms/select/types.d.ts.map +1 -0
- package/dist/components/forms/switch/Switch.d.ts.map +1 -0
- package/dist/components/forms/switch/index.d.ts.map +1 -0
- package/dist/components/forms/switch/types.d.ts +6 -0
- package/dist/components/forms/switch/types.d.ts.map +1 -0
- package/dist/components/forms/textarea/Textarea.d.ts.map +1 -0
- package/dist/components/forms/textarea/index.d.ts.map +1 -0
- package/dist/components/forms/textarea/types.d.ts +7 -0
- package/dist/components/forms/textarea/types.d.ts.map +1 -0
- package/dist/components/icons/AlertCircleIcon.d.ts +9 -0
- package/dist/components/icons/AlertCircleIcon.d.ts.map +1 -0
- package/dist/components/icons/AlertTriangleIcon.d.ts +9 -0
- package/dist/components/icons/AlertTriangleIcon.d.ts.map +1 -0
- package/dist/components/icons/AudioWaveIcon.d.ts +9 -0
- package/dist/components/icons/AudioWaveIcon.d.ts.map +1 -0
- package/dist/components/icons/CheckCircleIcon.d.ts +9 -0
- package/dist/components/icons/CheckCircleIcon.d.ts.map +1 -0
- package/dist/components/icons/ColumnsIcon.d.ts +9 -0
- package/dist/components/icons/ColumnsIcon.d.ts.map +1 -0
- package/dist/components/icons/FilterIcon.d.ts +9 -0
- package/dist/components/icons/FilterIcon.d.ts.map +1 -0
- package/dist/components/icons/FilterProfileIcon.d.ts +9 -0
- package/dist/components/icons/FilterProfileIcon.d.ts.map +1 -0
- package/dist/components/icons/FilterXIcon.d.ts +9 -0
- package/dist/components/icons/FilterXIcon.d.ts.map +1 -0
- package/dist/components/icons/InfoCircleIcon.d.ts +9 -0
- package/dist/components/icons/InfoCircleIcon.d.ts.map +1 -0
- package/dist/components/icons/LoaderIcon.d.ts +10 -0
- package/dist/components/icons/LoaderIcon.d.ts.map +1 -0
- package/dist/components/icons/MailIcon.d.ts +9 -0
- package/dist/components/icons/MailIcon.d.ts.map +1 -0
- package/dist/components/icons/PlayIcon.d.ts +9 -0
- package/dist/components/icons/PlayIcon.d.ts.map +1 -0
- package/dist/components/icons/QuestionCircleIcon.d.ts +9 -0
- package/dist/components/icons/QuestionCircleIcon.d.ts.map +1 -0
- package/dist/components/icons/RefreshIcon.d.ts +9 -0
- package/dist/components/icons/RefreshIcon.d.ts.map +1 -0
- package/dist/components/icons/RingLoaderIcon.d.ts +11 -0
- package/dist/components/icons/RingLoaderIcon.d.ts.map +1 -0
- package/dist/components/icons/SelectionIcon.d.ts +9 -0
- package/dist/components/icons/SelectionIcon.d.ts.map +1 -0
- package/dist/components/icons/XCircleIcon.d.ts +9 -0
- package/dist/components/icons/XCircleIcon.d.ts.map +1 -0
- package/dist/components/icons/ZapIcon.d.ts +9 -0
- package/dist/components/icons/ZapIcon.d.ts.map +1 -0
- package/dist/components/icons/index.d.ts +18 -0
- package/dist/components/icons/index.d.ts.map +1 -1
- package/dist/components/{basics → navigation}/accordion/Accordion.d.ts +1 -1
- package/dist/components/navigation/accordion/Accordion.d.ts.map +1 -0
- package/dist/components/{basics → navigation}/accordion/index.d.ts +1 -1
- package/dist/components/navigation/accordion/index.d.ts.map +1 -0
- package/dist/components/navigation/accordion/types.d.ts +18 -0
- package/dist/components/navigation/accordion/types.d.ts.map +1 -0
- package/dist/components/navigation/carousel/Carousel.d.ts.map +1 -0
- package/dist/components/navigation/carousel/index.d.ts.map +1 -0
- package/dist/components/navigation/carousel/types.d.ts +64 -0
- package/dist/components/navigation/carousel/types.d.ts.map +1 -0
- package/dist/components/navigation/index.d.ts +4 -0
- package/dist/components/navigation/index.d.ts.map +1 -0
- package/dist/components/navigation/stepper/Stepper.d.ts.map +1 -0
- package/dist/components/navigation/stepper/index.d.ts.map +1 -0
- package/dist/components/navigation/stepper/types.d.ts +83 -0
- package/dist/components/navigation/stepper/types.d.ts.map +1 -0
- package/dist/components/overlays/dialog/Dialog.d.ts.map +1 -0
- package/dist/components/overlays/dialog/index.d.ts +3 -0
- package/dist/components/overlays/dialog/index.d.ts.map +1 -0
- package/dist/components/{basics → overlays}/dialog/types.d.ts +18 -18
- package/dist/components/overlays/dialog/types.d.ts.map +1 -0
- package/dist/components/overlays/drawer/Drawer.d.ts.map +1 -0
- package/dist/components/overlays/drawer/index.d.ts +3 -0
- package/dist/components/overlays/drawer/index.d.ts.map +1 -0
- package/dist/components/overlays/drawer/types.d.ts +12 -0
- package/dist/components/overlays/drawer/types.d.ts.map +1 -0
- package/dist/components/overlays/hover-card/HoverCard.d.ts.map +1 -0
- package/dist/components/overlays/hover-card/index.d.ts +3 -0
- package/dist/components/overlays/hover-card/index.d.ts.map +1 -0
- package/dist/components/overlays/hover-card/types.d.ts +2 -0
- package/dist/components/overlays/hover-card/types.d.ts.map +1 -0
- package/dist/components/overlays/index.d.ts +6 -0
- package/dist/components/overlays/index.d.ts.map +1 -0
- package/dist/components/overlays/toast/Toast.d.ts.map +1 -0
- package/dist/components/overlays/toast/index.d.ts.map +1 -0
- package/dist/components/overlays/toast/types.d.ts +2 -0
- package/dist/components/overlays/toast/types.d.ts.map +1 -0
- package/dist/components/overlays/tooltip/Tooltip.d.ts.map +1 -0
- package/dist/components/overlays/tooltip/index.d.ts.map +1 -0
- package/dist/components/overlays/tooltip/types.d.ts +27 -0
- package/dist/components/overlays/tooltip/types.d.ts.map +1 -0
- package/dist/components/spinners/Audio.d.ts.map +1 -1
- package/dist/components/spinners/index.d.ts +2 -0
- package/dist/components/spinners/index.d.ts.map +1 -0
- package/dist/components/text-animations/{BlurText → blur-text}/BlurText.d.ts +2 -2
- package/dist/components/text-animations/blur-text/BlurText.d.ts.map +1 -0
- package/dist/components/text-animations/blur-text/index.d.ts.map +1 -0
- package/dist/components/{basics/typography → typography}/Typography.d.ts +5 -5
- package/dist/components/typography/Typography.d.ts.map +1 -0
- package/dist/components/typography/index.d.ts +3 -0
- package/dist/components/typography/index.d.ts.map +1 -0
- package/dist/contexts/ThemeContext.d.ts +2 -15
- package/dist/contexts/ThemeContext.d.ts.map +1 -1
- package/dist/data-table.cjs +7 -0
- package/dist/data-table.d.ts +2 -0
- package/dist/data-table.mjs +2 -0
- package/dist/date-picker.cjs +3 -0
- package/dist/date-picker.d.ts +2 -0
- package/dist/date-picker.mjs +2 -0
- package/dist/dialog.cjs +3 -0
- package/dist/dialog.d.ts +2 -0
- package/dist/dialog.mjs +2 -0
- package/dist/docs.cjs +699 -0
- package/dist/docs.cjs.map +1 -0
- package/dist/docs.d.ts +257 -0
- package/dist/docs.d.ts.map +1 -0
- package/dist/docs.mjs +691 -0
- package/dist/docs.mjs.map +1 -0
- package/dist/drawer.cjs +3 -0
- package/dist/drawer.d.ts +2 -0
- package/dist/drawer.mjs +2 -0
- package/dist/fonts/geist/Geist-Black.woff2 +0 -0
- package/dist/fonts/geist/Geist-Bold.woff2 +0 -0
- package/dist/fonts/geist/Geist-ExtraBold.woff2 +0 -0
- package/dist/fonts/geist/Geist-ExtraLight.woff2 +0 -0
- package/dist/fonts/geist/Geist-Light.woff2 +0 -0
- package/dist/fonts/geist/Geist-Medium.woff2 +0 -0
- package/dist/fonts/geist/Geist-Regular.woff2 +0 -0
- package/dist/fonts/geist/Geist-SemiBold.woff2 +0 -0
- package/dist/fonts/geist/Geist-Thin.woff2 +0 -0
- package/dist/fonts/geist/Geist[wght].woff2 +0 -0
- package/dist/fonts.css +84 -0
- package/dist/form.cjs +9 -0
- package/dist/form.d.ts +2 -0
- package/dist/form.mjs +2 -0
- package/dist/foundation.css +30 -0
- package/dist/foundations/index.d.ts +2 -0
- package/dist/foundations/index.d.ts.map +1 -0
- package/dist/foundations/theme/ThemeProvider.d.ts +17 -0
- package/dist/foundations/theme/ThemeProvider.d.ts.map +1 -0
- package/dist/foundations/theme/index.d.ts +3 -0
- package/dist/foundations/theme/index.d.ts.map +1 -0
- package/dist/gradual-blur.cjs +3 -0
- package/dist/gradual-blur.d.ts +2 -0
- package/dist/gradual-blur.mjs +2 -0
- package/dist/hover-border-gradient.cjs +3 -0
- package/dist/hover-border-gradient.d.ts +2 -0
- package/dist/hover-border-gradient.mjs +2 -0
- package/dist/hover-card.cjs +3 -0
- package/dist/hover-card.d.ts +2 -0
- package/dist/hover-card.mjs +2 -0
- package/dist/icons.cjs +50 -0
- package/dist/icons.d.ts +2 -0
- package/dist/icons.mjs +2 -0
- package/dist/index.cjs +188 -12516
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +74 -76
- package/dist/index.d.ts.map +1 -1
- package/dist/index.mjs +67 -12500
- package/dist/index.mjs.map +1 -1
- package/dist/input.cjs +4 -0
- package/dist/input.d.ts +2 -0
- package/dist/input.mjs +2 -0
- package/dist/label.cjs +3 -0
- package/dist/label.d.ts +2 -0
- package/dist/label.mjs +2 -0
- package/dist/loading.cjs +11 -0
- package/dist/loading.d.ts +2 -0
- package/dist/loading.mjs +2 -0
- package/dist/multi-select-combobox.cjs +3 -0
- package/dist/multi-select-combobox.d.ts +2 -0
- package/dist/multi-select-combobox.mjs +2 -0
- package/dist/otp-input.cjs +3 -0
- package/dist/otp-input.d.ts +2 -0
- package/dist/otp-input.mjs +2 -0
- package/dist/password-strength-meter.cjs +3 -0
- package/dist/password-strength-meter.d.ts +2 -0
- package/dist/password-strength-meter.mjs +2 -0
- package/dist/progress-bar.cjs +3 -0
- package/dist/progress-bar.d.ts +2 -0
- package/dist/progress-bar.mjs +2 -0
- package/dist/radio.cjs +3 -0
- package/dist/radio.d.ts +2 -0
- package/dist/radio.mjs +2 -0
- package/dist/select.cjs +3 -0
- package/dist/select.d.ts +2 -0
- package/dist/select.mjs +2 -0
- package/dist/skeleton.cjs +3 -0
- package/dist/skeleton.d.ts +2 -0
- package/dist/skeleton.mjs +2 -0
- package/dist/spinners.cjs +3 -0
- package/dist/spinners.d.ts +2 -0
- package/dist/spinners.mjs +2 -0
- package/dist/splash-cursor.cjs +3 -0
- package/dist/splash-cursor.d.ts +2 -0
- package/dist/splash-cursor.mjs +2 -0
- package/dist/spotlight-card.cjs +3 -0
- package/dist/spotlight-card.d.ts +2 -0
- package/dist/spotlight-card.mjs +2 -0
- package/dist/stepper.cjs +3 -0
- package/dist/stepper.d.ts +2 -0
- package/dist/stepper.mjs +2 -0
- package/dist/styles.css +6 -0
- package/dist/sun-to-moon-button.cjs +3 -0
- package/dist/sun-to-moon-button.d.ts +2 -0
- package/dist/sun-to-moon-button.mjs +2 -0
- package/dist/switch.cjs +3 -0
- package/dist/switch.d.ts +2 -0
- package/dist/switch.mjs +2 -0
- package/dist/textarea.cjs +3 -0
- package/dist/textarea.d.ts +2 -0
- package/dist/textarea.mjs +2 -0
- package/dist/theme.cjs +4 -0
- package/dist/theme.d.ts +2 -0
- package/dist/theme.mjs +2 -0
- package/dist/toast.cjs +11 -0
- package/dist/toast.d.ts +6 -0
- package/dist/toast.mjs +2 -0
- package/dist/tokens.css +592 -0
- package/dist/tooltip.cjs +3 -0
- package/dist/tooltip.d.ts +2 -0
- package/dist/tooltip.mjs +2 -0
- package/dist/typography.cjs +3 -0
- package/dist/typography.d.ts +2 -0
- package/dist/typography.mjs +2 -0
- package/dist/utils/generateUniqueKey.d.ts.map +1 -1
- package/dist/utils.cjs +5 -0
- package/dist/utils.d.ts +2 -0
- package/dist/utils.mjs +2 -0
- package/package.json +252 -106
- package/dist/components/Button.d.ts +0 -8
- package/dist/components/Button.d.ts.map +0 -1
- package/dist/components/basics/Button/Button.d.ts.map +0 -1
- package/dist/components/basics/Button/index.d.ts.map +0 -1
- package/dist/components/basics/accordion/Accordion.d.ts.map +0 -1
- package/dist/components/basics/accordion/index.d.ts.map +0 -1
- package/dist/components/basics/alert/Alert.d.ts.map +0 -1
- package/dist/components/basics/alert/index.d.ts.map +0 -1
- package/dist/components/basics/animated-content/AnimatedContent.d.ts.map +0 -1
- package/dist/components/basics/animated-content/index.d.ts.map +0 -1
- package/dist/components/basics/background-gradient-animation/BackgroundGradientAnimation.d.ts.map +0 -1
- package/dist/components/basics/background-gradient-animation/BackgroundGradientAnimationDemo.d.ts.map +0 -1
- package/dist/components/basics/background-gradient-animation/index.d.ts.map +0 -1
- package/dist/components/basics/button-hover-border-gradient/ButtonHoverBorderGradient.d.ts.map +0 -1
- package/dist/components/basics/button-hover-border-gradient/index.d.ts.map +0 -1
- package/dist/components/basics/calendar/Calendar.d.ts.map +0 -1
- package/dist/components/basics/calendar/index.d.ts.map +0 -1
- package/dist/components/basics/card/Card.d.ts.map +0 -1
- package/dist/components/basics/card/index.d.ts.map +0 -1
- package/dist/components/basics/carousel/Carousel.d.ts.map +0 -1
- package/dist/components/basics/carousel/index.d.ts.map +0 -1
- package/dist/components/basics/charts/AreaChart.d.ts.map +0 -1
- package/dist/components/basics/charts/BarChart.d.ts.map +0 -1
- package/dist/components/basics/charts/NeonLineChart.d.ts.map +0 -1
- package/dist/components/basics/charts/PieChart.d.ts.map +0 -1
- package/dist/components/basics/charts/StackedBarChart.d.ts.map +0 -1
- package/dist/components/basics/charts/ThinBreakdownBar.d.ts.map +0 -1
- package/dist/components/basics/checkbox/Checkbox.d.ts.map +0 -1
- package/dist/components/basics/checkbox/index.d.ts.map +0 -1
- package/dist/components/basics/chip/Chip.d.ts.map +0 -1
- package/dist/components/basics/chip/index.d.ts.map +0 -1
- package/dist/components/basics/chroma-grid/ChromaGrid.d.ts.map +0 -1
- package/dist/components/basics/chroma-grid/index.d.ts +0 -3
- package/dist/components/basics/chroma-grid/index.d.ts.map +0 -1
- package/dist/components/basics/colo-palette/ColorPalette.d.ts.map +0 -1
- package/dist/components/basics/colo-palette/index.d.ts.map +0 -1
- package/dist/components/basics/combobox/Combobox.d.ts.map +0 -1
- package/dist/components/basics/combobox/index.d.ts.map +0 -1
- package/dist/components/basics/data-table/DataTable.d.ts.map +0 -1
- package/dist/components/basics/data-table/index.d.ts +0 -4
- package/dist/components/basics/data-table/index.d.ts.map +0 -1
- package/dist/components/basics/date-picker/DatePicker.d.ts.map +0 -1
- package/dist/components/basics/date-picker/index.d.ts +0 -3
- package/dist/components/basics/date-picker/index.d.ts.map +0 -1
- package/dist/components/basics/dialog/Dialog.d.ts.map +0 -1
- package/dist/components/basics/dialog/types.d.ts.map +0 -1
- package/dist/components/basics/drawer/Drawer.d.ts.map +0 -1
- package/dist/components/basics/drawer/index.d.ts +0 -3
- package/dist/components/basics/drawer/index.d.ts.map +0 -1
- package/dist/components/basics/form/Form.d.ts.map +0 -1
- package/dist/components/basics/form/index.d.ts.map +0 -1
- package/dist/components/basics/gradual-blur/GradualBlur.d.ts.map +0 -1
- package/dist/components/basics/gradual-blur/index.d.ts +0 -3
- package/dist/components/basics/gradual-blur/index.d.ts.map +0 -1
- package/dist/components/basics/hover-border-gradient/HoverBorderGradient.d.ts.map +0 -1
- package/dist/components/basics/hover-border-gradient/index.d.ts.map +0 -1
- package/dist/components/basics/hover-card/HoverCard.d.ts.map +0 -1
- package/dist/components/basics/hover-card/index.d.ts +0 -3
- package/dist/components/basics/hover-card/index.d.ts.map +0 -1
- package/dist/components/basics/input/Input.d.ts.map +0 -1
- package/dist/components/basics/input/index.d.ts.map +0 -1
- package/dist/components/basics/input/types.d.ts.map +0 -1
- package/dist/components/basics/label/Label.d.ts.map +0 -1
- package/dist/components/basics/label/index.d.ts.map +0 -1
- package/dist/components/basics/loading/Loading.d.ts.map +0 -1
- package/dist/components/basics/loading/index.d.ts.map +0 -1
- package/dist/components/basics/multi-select-combobox/MultiSelectCombobox.d.ts.map +0 -1
- package/dist/components/basics/multi-select-combobox/index.d.ts +0 -3
- package/dist/components/basics/multi-select-combobox/index.d.ts.map +0 -1
- package/dist/components/basics/otp-Input/OTPInput.d.ts.map +0 -1
- package/dist/components/basics/otp-Input/index.d.ts +0 -3
- package/dist/components/basics/otp-Input/index.d.ts.map +0 -1
- package/dist/components/basics/password-strength-meter/PasswordCriteria.d.ts.map +0 -1
- package/dist/components/basics/password-strength-meter/PasswordStrengthMeter.d.ts +0 -6
- package/dist/components/basics/password-strength-meter/PasswordStrengthMeter.d.ts.map +0 -1
- package/dist/components/basics/preview/Preview.d.ts +0 -2
- package/dist/components/basics/preview/Preview.d.ts.map +0 -1
- package/dist/components/basics/preview/index.d.ts +0 -2
- package/dist/components/basics/preview/index.d.ts.map +0 -1
- package/dist/components/basics/radio/Radio.d.ts.map +0 -1
- package/dist/components/basics/radio/index.d.ts.map +0 -1
- package/dist/components/basics/select/Select.d.ts.map +0 -1
- package/dist/components/basics/select/index.d.ts.map +0 -1
- package/dist/components/basics/skeleton/Skeleton.d.ts.map +0 -1
- package/dist/components/basics/splashCursor/SplashCursor.d.ts.map +0 -1
- package/dist/components/basics/splashCursor/index.d.ts.map +0 -1
- package/dist/components/basics/spotlight-card/SpotlightCard.d.ts.map +0 -1
- package/dist/components/basics/spotlight-card/index.d.ts +0 -3
- package/dist/components/basics/spotlight-card/index.d.ts.map +0 -1
- package/dist/components/basics/stepper/Stepper.d.ts.map +0 -1
- package/dist/components/basics/stepper/index.d.ts.map +0 -1
- package/dist/components/basics/sun-to-moon-button/SunToMoonButton.d.ts +0 -4
- package/dist/components/basics/sun-to-moon-button/SunToMoonButton.d.ts.map +0 -1
- package/dist/components/basics/sun-to-moon-button/index.d.ts.map +0 -1
- package/dist/components/basics/switch/Switch.d.ts.map +0 -1
- package/dist/components/basics/switch/index.d.ts.map +0 -1
- package/dist/components/basics/textarea/Textarea.d.ts.map +0 -1
- package/dist/components/basics/textarea/index.d.ts.map +0 -1
- package/dist/components/basics/toast/Toast.d.ts.map +0 -1
- package/dist/components/basics/toast/index.d.ts.map +0 -1
- package/dist/components/basics/tooltip/Tooltip.d.ts.map +0 -1
- package/dist/components/basics/tooltip/index.d.ts.map +0 -1
- package/dist/components/basics/typography/Typography.d.ts.map +0 -1
- package/dist/components/text-animations/ASCIIText/ASCIIText.d.ts.map +0 -1
- package/dist/components/text-animations/ASCIIText/index.d.ts.map +0 -1
- package/dist/components/text-animations/BlurText/BlurText.d.ts.map +0 -1
- package/dist/components/text-animations/BlurText/index.d.ts.map +0 -1
- /package/dist/components/{basics → data-display}/card/Card.d.ts +0 -0
- /package/dist/components/{basics → data-display}/card/index.d.ts +0 -0
- /package/dist/components/{basics → data-display}/charts/AreaChart.d.ts +0 -0
- /package/dist/components/{basics → data-display}/charts/BarChart.d.ts +0 -0
- /package/dist/components/{basics → data-display}/charts/NeonLineChart.d.ts +0 -0
- /package/dist/components/{basics → data-display}/charts/PieChart.d.ts +0 -0
- /package/dist/components/{basics → data-display}/charts/StackedBarChart.d.ts +0 -0
- /package/dist/components/{basics → data-display}/charts/ThinBreakdownBar.d.ts +0 -0
- /package/dist/components/{basics → data-display}/chip/Chip.d.ts +0 -0
- /package/dist/components/{basics → data-display}/chip/index.d.ts +0 -0
- /package/dist/components/{basics/colo-palette → data-display/color-palette}/ColorPalette.d.ts +0 -0
- /package/dist/components/{basics/colo-palette → data-display/color-palette}/index.d.ts +0 -0
- /package/dist/components/{basics → data-display}/loading/index.d.ts +0 -0
- /package/dist/components/{basics → data-display}/skeleton/Skeleton.d.ts +0 -0
- /package/dist/components/{basics → data-display}/skeleton/index.d.ts +0 -0
- /package/dist/components/{basics → effects}/animated-content/AnimatedContent.d.ts +0 -0
- /package/dist/components/{basics → effects}/animated-content/index.d.ts +0 -0
- /package/dist/components/{text-animations/ASCIIText → effects/ascii-text}/ASCIIText.d.ts +0 -0
- /package/dist/components/{text-animations/ASCIIText → effects/ascii-text}/index.d.ts +0 -0
- /package/dist/components/{basics → effects}/background-gradient-animation/BackgroundGradientAnimation.d.ts +0 -0
- /package/dist/components/{basics → effects}/background-gradient-animation/BackgroundGradientAnimationDemo.d.ts +0 -0
- /package/dist/components/{basics → effects}/background-gradient-animation/index.d.ts +0 -0
- /package/dist/components/{basics → effects}/button-hover-border-gradient/ButtonHoverBorderGradient.d.ts +0 -0
- /package/dist/components/{basics → effects}/button-hover-border-gradient/index.d.ts +0 -0
- /package/dist/components/{basics → effects}/chroma-grid/ChromaGrid.d.ts +0 -0
- /package/dist/components/{basics → effects}/hover-border-gradient/HoverBorderGradient.d.ts +0 -0
- /package/dist/components/{basics → effects}/hover-border-gradient/index.d.ts +0 -0
- /package/dist/components/{basics/splashCursor → effects/splash-cursor}/SplashCursor.d.ts +0 -0
- /package/dist/components/{basics/splashCursor → effects/splash-cursor}/index.d.ts +0 -0
- /package/dist/components/{basics → effects}/spotlight-card/SpotlightCard.d.ts +0 -0
- /package/dist/components/{basics → effects}/sun-to-moon-button/index.d.ts +0 -0
- /package/dist/components/{basics → feedback}/alert/Alert.d.ts +0 -0
- /package/dist/components/{basics → feedback}/alert/index.d.ts +0 -0
- /package/dist/components/{basics/Button → forms/button}/index.d.ts +0 -0
- /package/dist/components/{basics → forms}/calendar/Calendar.d.ts +0 -0
- /package/dist/components/{basics → forms}/calendar/index.d.ts +0 -0
- /package/dist/components/{basics → forms}/checkbox/Checkbox.d.ts +0 -0
- /package/dist/components/{basics → forms}/checkbox/index.d.ts +0 -0
- /package/dist/components/{basics → forms}/combobox/index.d.ts +0 -0
- /package/dist/components/{basics → forms}/date-picker/DatePicker.d.ts +0 -0
- /package/dist/components/{basics → forms}/form/Form.d.ts +0 -0
- /package/dist/components/{basics → forms}/form/index.d.ts +0 -0
- /package/dist/components/{basics → forms}/input/Input.d.ts +0 -0
- /package/dist/components/{basics → forms}/input/types.d.ts +0 -0
- /package/dist/components/{basics → forms}/label/Label.d.ts +0 -0
- /package/dist/components/{basics → forms}/label/index.d.ts +0 -0
- /package/dist/components/{basics/otp-Input → forms/otp-input}/OTPInput.d.ts +0 -0
- /package/dist/components/{basics → forms}/password-strength-meter/PasswordCriteria.d.ts +0 -0
- /package/dist/components/{basics → forms}/radio/Radio.d.ts +0 -0
- /package/dist/components/{basics → forms}/radio/index.d.ts +0 -0
- /package/dist/components/{basics → forms}/select/Select.d.ts +0 -0
- /package/dist/components/{basics → forms}/select/index.d.ts +0 -0
- /package/dist/components/{basics → forms}/switch/Switch.d.ts +0 -0
- /package/dist/components/{basics → forms}/switch/index.d.ts +0 -0
- /package/dist/components/{basics → forms}/textarea/Textarea.d.ts +0 -0
- /package/dist/components/{basics → forms}/textarea/index.d.ts +0 -0
- /package/dist/components/{basics → navigation}/carousel/Carousel.d.ts +0 -0
- /package/dist/components/{basics → navigation}/carousel/index.d.ts +0 -0
- /package/dist/components/{basics → navigation}/stepper/Stepper.d.ts +0 -0
- /package/dist/components/{basics → navigation}/stepper/index.d.ts +0 -0
- /package/dist/components/{basics → overlays}/dialog/Dialog.d.ts +0 -0
- /package/dist/components/{basics → overlays}/drawer/Drawer.d.ts +0 -0
- /package/dist/components/{basics → overlays}/hover-card/HoverCard.d.ts +0 -0
- /package/dist/components/{basics → overlays}/toast/Toast.d.ts +0 -0
- /package/dist/components/{basics → overlays}/toast/index.d.ts +0 -0
- /package/dist/components/{basics → overlays}/tooltip/Tooltip.d.ts +0 -0
- /package/dist/components/{basics → overlays}/tooltip/index.d.ts +0 -0
- /package/dist/components/text-animations/{BlurText → blur-text}/index.d.ts +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"splash-cursor-rSrTnawZ.mjs","names":[],"sources":["../../src/components/effects/splash-cursor/SplashCursor.tsx"],"sourcesContent":["import { useState, useEffect, useRef, useCallback } from \"react\";\nimport { motion, AnimatePresence } from \"framer-motion\";\nimport { mergeClassNames } from \"../../../utils\";\nimport type { SplashCursorProps, Particle } from \"./types\";\n\nconst sizeConfig = {\n sm: { base: 20, variance: 10 },\n md: { base: 40, variance: 20 },\n lg: { base: 60, variance: 30 },\n xl: { base: 100, variance: 50 },\n};\n\nconst defaultColors = [\n \"var(--ds-color-accent)\",\n \"var(--ds-color-accent-hover)\",\n \"var(--ds-color-info)\",\n \"var(--ds-color-success)\",\n \"var(--ds-color-warning)\",\n \"var(--ds-color-danger)\",\n];\n\nexport const SplashCursor = ({\n className,\n color,\n secondaryColor,\n size = \"md\",\n particleCount = 12,\n enabled = true,\n blur = 0,\n opacity = 0.6,\n duration = 800,\n smooth = true,\n smoothFactor = 0.15,\n style,\n children,\n variant = \"splash\",\n}: SplashCursorProps) => {\n const containerRef = useRef<HTMLDivElement>(null);\n const [particles, setParticles] = useState<Particle[]>([]);\n const [mousePos, setMousePos] = useState({ x: 0, y: 0 });\n const [smoothPos, setSmoothPos] = useState({ x: 0, y: 0 });\n const [isInside, setIsInside] = useState(false);\n const particleIdRef = useRef<number>(0);\n const animationFrameRef = useRef<number | undefined>(undefined);\n\n // Smooth cursor following\n useEffect(() => {\n if (!smooth || !enabled) return;\n\n const animate = () => {\n setSmoothPos((prev) => ({\n x: prev.x + (mousePos.x - prev.x) * smoothFactor,\n y: prev.y + (mousePos.y - prev.y) * smoothFactor,\n }));\n animationFrameRef.current = requestAnimationFrame(animate);\n };\n\n animationFrameRef.current = requestAnimationFrame(animate);\n return () => {\n if (animationFrameRef.current) {\n cancelAnimationFrame(animationFrameRef.current);\n }\n };\n }, [mousePos, smooth, smoothFactor, enabled]);\n\n const getRandomColor = useCallback(() => {\n if (color && secondaryColor) {\n return Math.random() > 0.5 ? color : secondaryColor;\n }\n if (color) return color;\n return defaultColors[Math.floor(Math.random() * defaultColors.length)];\n }, [color, secondaryColor]);\n\n const createParticles = useCallback(\n (x: number, y: number) => {\n const config = sizeConfig[size];\n const newParticles: Particle[] = [];\n\n for (let i = 0; i < particleCount; i++) {\n const angle = (Math.PI * 2 * i) / particleCount;\n const distance =\n variant === \"ripple\" ? config.base : Math.random() * config.variance;\n\n newParticles.push({\n id: particleIdRef.current++,\n x: x + Math.cos(angle) * distance * (variant === \"ripple\" ? 0 : 1),\n y: y + Math.sin(angle) * distance * (variant === \"ripple\" ? 0 : 1),\n size: config.base * 0.3 + Math.random() * config.base * 0.4,\n opacity: opacity * (0.5 + Math.random() * 0.5),\n color: getRandomColor(),\n });\n }\n\n setParticles((prev) => [...prev.slice(-50), ...newParticles]);\n\n // Remove particles after animation\n setTimeout(() => {\n setParticles((prev) =>\n prev.filter((p) => !newParticles.find((np) => np.id === p.id)),\n );\n }, duration);\n },\n [size, particleCount, opacity, duration, getRandomColor, variant],\n );\n\n const handleMouseMove = useCallback(\n (e: React.MouseEvent<HTMLDivElement>) => {\n if (!enabled || !containerRef.current) return;\n\n const rect = containerRef.current.getBoundingClientRect();\n const x = e.clientX - rect.left;\n const y = e.clientY - rect.top;\n\n setMousePos({ x, y });\n\n // Create splash effect on movement\n if (variant === \"splash\" || variant === \"trail\") {\n if (Math.random() > (variant === \"trail\" ? 0.7 : 0.85)) {\n createParticles(x, y);\n }\n }\n },\n [enabled, createParticles, variant],\n );\n\n const handleClick = useCallback(\n (e: React.MouseEvent<HTMLDivElement>) => {\n if (!enabled || !containerRef.current) return;\n\n const rect = containerRef.current.getBoundingClientRect();\n const x = e.clientX - rect.left;\n const y = e.clientY - rect.top;\n\n // Create burst effect on click\n createParticles(x, y);\n if (variant === \"ripple\") {\n setTimeout(() => createParticles(x, y), 100);\n setTimeout(() => createParticles(x, y), 200);\n }\n },\n [enabled, createParticles, variant],\n );\n\n const getParticleAnimation = (particle: Particle) => {\n const config = sizeConfig[size];\n\n switch (variant) {\n case \"glow\":\n return {\n initial: { scale: 0, opacity: particle.opacity },\n animate: { scale: 2, opacity: 0 },\n exit: { scale: 3, opacity: 0 },\n };\n case \"trail\":\n return {\n initial: { scale: 1, opacity: particle.opacity, y: 0 },\n animate: { scale: 0.5, opacity: 0, y: 20 },\n exit: { scale: 0, opacity: 0 },\n };\n case \"ripple\":\n return {\n initial: { scale: 0, opacity: particle.opacity },\n animate: { scale: 4, opacity: 0 },\n exit: { scale: 5, opacity: 0 },\n };\n default: // splash\n const angle = Math.random() * Math.PI * 2;\n const distance = config.base + Math.random() * config.variance;\n return {\n initial: { scale: 0, opacity: particle.opacity, x: 0, y: 0 },\n animate: {\n scale: [0, 1.2, 0.8],\n opacity: [particle.opacity, particle.opacity * 0.8, 0],\n x: Math.cos(angle) * distance,\n y: Math.sin(angle) * distance,\n },\n exit: { scale: 0, opacity: 0 },\n };\n }\n };\n\n const cursorPos = smooth ? smoothPos : mousePos;\n const glowColor =\n color && secondaryColor\n ? `color-mix(in srgb, ${color} 60%, ${secondaryColor})`\n : color\n ? `color-mix(in srgb, ${color} 35%, transparent)`\n : \"color-mix(in srgb, var(--ds-color-accent) 35%, transparent)\";\n\n return (\n <div\n ref={containerRef}\n className={mergeClassNames(\"relative overflow-hidden\", className)}\n style={style}\n onMouseMove={handleMouseMove}\n onMouseEnter={() => setIsInside(true)}\n onMouseLeave={() => setIsInside(false)}\n onClick={handleClick}\n >\n {/* Cursor glow effect */}\n {enabled && isInside && variant === \"glow\" && (\n <motion.div\n className=\"pointer-events-none absolute z-10\"\n style={{\n left: cursorPos.x,\n top: cursorPos.y,\n width: sizeConfig[size].base * 2,\n height: sizeConfig[size].base * 2,\n transform: \"translate(-50%, -50%)\",\n background: `radial-gradient(circle, ${glowColor} 0%, transparent 70%)`,\n filter: blur ? `blur(${blur}px)` : undefined,\n }}\n initial={{ scale: 0, opacity: 0 }}\n animate={{ scale: 1, opacity: 1 }}\n exit={{ scale: 0, opacity: 0 }}\n />\n )}\n\n {/* Particles */}\n <AnimatePresence>\n {enabled &&\n particles.map((particle) => {\n const animation = getParticleAnimation(particle);\n return (\n <motion.div\n key={particle.id}\n className=\"pointer-events-none absolute rounded-full z-20\"\n style={{\n left: particle.x,\n top: particle.y,\n width: particle.size,\n height: particle.size,\n backgroundColor: particle.color,\n transform: \"translate(-50%, -50%)\",\n filter: blur ? `blur(${blur}px)` : undefined,\n }}\n {...animation}\n transition={{\n duration: duration / 1000,\n ease: \"easeOut\",\n }}\n />\n );\n })}\n </AnimatePresence>\n\n {/* Children content */}\n <div className=\"relative z-0\">{children}</div>\n </div>\n );\n};\n\nSplashCursor.displayName = \"SplashCursor\";\n\nexport default SplashCursor;\n"],"mappings":"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"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { n as mergeClassNames } from "./utils-ati1KkDb.mjs";
|
|
2
|
+
import { useRef, useState } from "react";
|
|
3
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
4
|
+
import { motion } from "framer-motion";
|
|
5
|
+
//#region src/components/effects/spotlight-card/SpotlightCard.tsx
|
|
6
|
+
var borderRadiusMap = {
|
|
7
|
+
sm: "rounded-sm",
|
|
8
|
+
md: "rounded-md",
|
|
9
|
+
lg: "rounded-lg",
|
|
10
|
+
xl: "rounded-xl",
|
|
11
|
+
"2xl": "rounded-2xl",
|
|
12
|
+
full: "rounded-full"
|
|
13
|
+
};
|
|
14
|
+
var paddingMap = {
|
|
15
|
+
none: "",
|
|
16
|
+
sm: "p-3",
|
|
17
|
+
md: "p-5",
|
|
18
|
+
lg: "p-7",
|
|
19
|
+
xl: "p-10"
|
|
20
|
+
};
|
|
21
|
+
var variantStyles = {
|
|
22
|
+
glass: `
|
|
23
|
+
bg-white/60 dark:bg-neutral-900/50
|
|
24
|
+
backdrop-blur-2xl
|
|
25
|
+
border border-white/40 dark:border-white/10
|
|
26
|
+
shadow-xl shadow-neutral-200/30 dark:shadow-neutral-950/50
|
|
27
|
+
`,
|
|
28
|
+
solid: `
|
|
29
|
+
bg-white dark:bg-neutral-900
|
|
30
|
+
border border-neutral-200 dark:border-neutral-800
|
|
31
|
+
shadow-lg shadow-neutral-200/50 dark:shadow-neutral-950/50
|
|
32
|
+
`,
|
|
33
|
+
outlined: `
|
|
34
|
+
bg-transparent
|
|
35
|
+
border-2 border-neutral-200 dark:border-neutral-700
|
|
36
|
+
`
|
|
37
|
+
};
|
|
38
|
+
var SpotlightCard = ({ children, className, spotlightColor = "rgba(115, 103, 240, 0.15)", spotlightSize = 350, spotlightEnabled = true, variant = "glass", borderRadius = "xl", padding = "md", hoverScale = true, style, onClick }) => {
|
|
39
|
+
const containerRef = useRef(null);
|
|
40
|
+
const [mousePosition, setMousePosition] = useState({
|
|
41
|
+
x: 0,
|
|
42
|
+
y: 0
|
|
43
|
+
});
|
|
44
|
+
const [isHovered, setIsHovered] = useState(false);
|
|
45
|
+
const handleMouseMove = (e) => {
|
|
46
|
+
if (!containerRef.current || !spotlightEnabled) return;
|
|
47
|
+
const rect = containerRef.current.getBoundingClientRect();
|
|
48
|
+
setMousePosition({
|
|
49
|
+
x: e.clientX - rect.left,
|
|
50
|
+
y: e.clientY - rect.top
|
|
51
|
+
});
|
|
52
|
+
};
|
|
53
|
+
const handleMouseEnter = () => {
|
|
54
|
+
setIsHovered(true);
|
|
55
|
+
};
|
|
56
|
+
const handleMouseLeave = () => {
|
|
57
|
+
setIsHovered(false);
|
|
58
|
+
};
|
|
59
|
+
const spotlightStyle = spotlightEnabled && isHovered ? { background: `radial-gradient(${spotlightSize}px circle at ${mousePosition.x}px ${mousePosition.y}px, ${spotlightColor}, transparent 80%)` } : {};
|
|
60
|
+
return /* @__PURE__ */ jsxs(motion.div, {
|
|
61
|
+
ref: containerRef,
|
|
62
|
+
className: mergeClassNames("relative overflow-hidden transition-all duration-300", borderRadiusMap[borderRadius], paddingMap[padding], variantStyles[variant], onClick && "cursor-pointer", className),
|
|
63
|
+
style,
|
|
64
|
+
onMouseMove: handleMouseMove,
|
|
65
|
+
onMouseEnter: handleMouseEnter,
|
|
66
|
+
onMouseLeave: handleMouseLeave,
|
|
67
|
+
onClick,
|
|
68
|
+
whileHover: hoverScale ? { scale: 1.02 } : void 0,
|
|
69
|
+
whileTap: onClick ? { scale: .98 } : void 0,
|
|
70
|
+
transition: {
|
|
71
|
+
type: "spring",
|
|
72
|
+
stiffness: 400,
|
|
73
|
+
damping: 25
|
|
74
|
+
},
|
|
75
|
+
children: [
|
|
76
|
+
spotlightEnabled && /* @__PURE__ */ jsx(motion.div, {
|
|
77
|
+
className: "pointer-events-none absolute inset-0 z-0",
|
|
78
|
+
style: spotlightStyle,
|
|
79
|
+
initial: { opacity: 0 },
|
|
80
|
+
animate: { opacity: isHovered ? 1 : 0 },
|
|
81
|
+
transition: { duration: .3 }
|
|
82
|
+
}),
|
|
83
|
+
spotlightEnabled && isHovered && /* @__PURE__ */ jsx(motion.div, {
|
|
84
|
+
className: mergeClassNames("pointer-events-none absolute inset-0 z-0", borderRadiusMap[borderRadius]),
|
|
85
|
+
style: {
|
|
86
|
+
background: `radial-gradient(${spotlightSize * .6}px circle at ${mousePosition.x}px ${mousePosition.y}px, ${spotlightColor.replace("0.15", "0.3")}, transparent 70%)`,
|
|
87
|
+
filter: "blur(20px)"
|
|
88
|
+
},
|
|
89
|
+
initial: { opacity: 0 },
|
|
90
|
+
animate: { opacity: 1 },
|
|
91
|
+
transition: { duration: .2 }
|
|
92
|
+
}),
|
|
93
|
+
/* @__PURE__ */ jsx("div", {
|
|
94
|
+
className: "relative z-10",
|
|
95
|
+
children
|
|
96
|
+
})
|
|
97
|
+
]
|
|
98
|
+
});
|
|
99
|
+
};
|
|
100
|
+
SpotlightCard.displayName = "SpotlightCard";
|
|
101
|
+
//#endregion
|
|
102
|
+
export { SpotlightCard as t };
|
|
103
|
+
|
|
104
|
+
//# sourceMappingURL=spotlight-card-BpZLMOp6.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spotlight-card-BpZLMOp6.mjs","names":[],"sources":["../../src/components/effects/spotlight-card/SpotlightCard.tsx"],"sourcesContent":["import { useState, useRef } from \"react\";\nimport { motion } from \"framer-motion\";\nimport { mergeClassNames } from \"../../../utils\";\nimport type { SpotlightCardProps } from \"./types\";\n\nconst borderRadiusMap = {\n sm: \"rounded-sm\",\n md: \"rounded-md\",\n lg: \"rounded-lg\",\n xl: \"rounded-xl\",\n \"2xl\": \"rounded-2xl\",\n full: \"rounded-full\",\n};\n\nconst paddingMap = {\n none: \"\",\n sm: \"p-3\",\n md: \"p-5\",\n lg: \"p-7\",\n xl: \"p-10\",\n};\n\nconst variantStyles = {\n glass: `\n bg-white/60 dark:bg-neutral-900/50\n backdrop-blur-2xl\n border border-white/40 dark:border-white/10\n shadow-xl shadow-neutral-200/30 dark:shadow-neutral-950/50\n `,\n solid: `\n bg-white dark:bg-neutral-900\n border border-neutral-200 dark:border-neutral-800\n shadow-lg shadow-neutral-200/50 dark:shadow-neutral-950/50\n `,\n outlined: `\n bg-transparent\n border-2 border-neutral-200 dark:border-neutral-700\n `,\n};\n\nexport const SpotlightCard = ({\n children,\n className,\n spotlightColor = \"rgba(115, 103, 240, 0.15)\",\n spotlightSize = 350,\n spotlightEnabled = true,\n variant = \"glass\",\n borderRadius = \"xl\",\n padding = \"md\",\n hoverScale = true,\n style,\n onClick,\n}: SpotlightCardProps) => {\n const containerRef = useRef<HTMLDivElement>(null);\n const [mousePosition, setMousePosition] = useState({ x: 0, y: 0 });\n const [isHovered, setIsHovered] = useState(false);\n\n const handleMouseMove = (e: React.MouseEvent<HTMLDivElement>) => {\n if (!containerRef.current || !spotlightEnabled) return;\n const rect = containerRef.current.getBoundingClientRect();\n setMousePosition({\n x: e.clientX - rect.left,\n y: e.clientY - rect.top,\n });\n };\n\n const handleMouseEnter = () => {\n setIsHovered(true);\n };\n\n const handleMouseLeave = () => {\n setIsHovered(false);\n };\n\n const spotlightStyle =\n spotlightEnabled && isHovered\n ? {\n background: `radial-gradient(${spotlightSize}px circle at ${mousePosition.x}px ${mousePosition.y}px, ${spotlightColor}, transparent 80%)`,\n }\n : {};\n\n return (\n <motion.div\n ref={containerRef}\n className={mergeClassNames(\n \"relative overflow-hidden transition-all duration-300\",\n borderRadiusMap[borderRadius],\n paddingMap[padding],\n variantStyles[variant],\n onClick && \"cursor-pointer\",\n className,\n )}\n style={style}\n onMouseMove={handleMouseMove}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n onClick={onClick}\n whileHover={hoverScale ? { scale: 1.02 } : undefined}\n whileTap={onClick ? { scale: 0.98 } : undefined}\n transition={{ type: \"spring\", stiffness: 400, damping: 25 }}\n >\n {/* Spotlight overlay */}\n {spotlightEnabled && (\n <motion.div\n className=\"pointer-events-none absolute inset-0 z-0\"\n style={spotlightStyle}\n initial={{ opacity: 0 }}\n animate={{ opacity: isHovered ? 1 : 0 }}\n transition={{ duration: 0.3 }}\n />\n )}\n\n {/* Border glow effect */}\n {spotlightEnabled && isHovered && (\n <motion.div\n className={mergeClassNames(\n \"pointer-events-none absolute inset-0 z-0\",\n borderRadiusMap[borderRadius],\n )}\n style={{\n background: `radial-gradient(${spotlightSize * 0.6}px circle at ${mousePosition.x}px ${mousePosition.y}px, ${spotlightColor.replace(\"0.15\", \"0.3\")}, transparent 70%)`,\n filter: \"blur(20px)\",\n }}\n initial={{ opacity: 0 }}\n animate={{ opacity: 1 }}\n transition={{ duration: 0.2 }}\n />\n )}\n\n {/* Content */}\n <div className=\"relative z-10\">{children}</div>\n </motion.div>\n );\n};\n\nSpotlightCard.displayName = \"SpotlightCard\";\n\nexport default SpotlightCard;\n"],"mappings":";;;;;AAKA,IAAM,kBAAkB;CACtB,IAAI;CACJ,IAAI;CACJ,IAAI;CACJ,IAAI;CACJ,OAAO;CACP,MAAM;CACP;AAED,IAAM,aAAa;CACjB,MAAM;CACN,IAAI;CACJ,IAAI;CACJ,IAAI;CACJ,IAAI;CACL;AAED,IAAM,gBAAgB;CACpB,OAAO;;;;;;CAMP,OAAO;;;;;CAKP,UAAU;;;;CAIX;AAED,IAAa,iBAAiB,EAC5B,UACA,WACA,iBAAiB,6BACjB,gBAAgB,KAChB,mBAAmB,MACnB,UAAU,SACV,eAAe,MACf,UAAU,MACV,aAAa,MACb,OACA,cACwB;CACxB,MAAM,eAAe,OAAuB,KAAK;CACjD,MAAM,CAAC,eAAe,oBAAoB,SAAS;EAAE,GAAG;EAAG,GAAG;EAAG,CAAC;CAClE,MAAM,CAAC,WAAW,gBAAgB,SAAS,MAAM;CAEjD,MAAM,mBAAmB,MAAwC;AAC/D,MAAI,CAAC,aAAa,WAAW,CAAC,iBAAkB;EAChD,MAAM,OAAO,aAAa,QAAQ,uBAAuB;AACzD,mBAAiB;GACf,GAAG,EAAE,UAAU,KAAK;GACpB,GAAG,EAAE,UAAU,KAAK;GACrB,CAAC;;CAGJ,MAAM,yBAAyB;AAC7B,eAAa,KAAK;;CAGpB,MAAM,yBAAyB;AAC7B,eAAa,MAAM;;CAGrB,MAAM,iBACJ,oBAAoB,YAChB,EACE,YAAY,mBAAmB,cAAc,eAAe,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,eAAe,qBACvH,GACD,EAAE;AAER,QACE,qBAAC,OAAO,KAAR;EACE,KAAK;EACL,WAAW,gBACT,wDACA,gBAAgB,eAChB,WAAW,UACX,cAAc,UACd,WAAW,kBACX,UACD;EACM;EACP,aAAa;EACb,cAAc;EACd,cAAc;EACL;EACT,YAAY,aAAa,EAAE,OAAO,MAAM,GAAG,KAAA;EAC3C,UAAU,UAAU,EAAE,OAAO,KAAM,GAAG,KAAA;EACtC,YAAY;GAAE,MAAM;GAAU,WAAW;GAAK,SAAS;GAAI;YAjB7D;GAoBG,oBACC,oBAAC,OAAO,KAAR;IACE,WAAU;IACV,OAAO;IACP,SAAS,EAAE,SAAS,GAAG;IACvB,SAAS,EAAE,SAAS,YAAY,IAAI,GAAG;IACvC,YAAY,EAAE,UAAU,IAAK;IAC7B,CAAA;GAIH,oBAAoB,aACnB,oBAAC,OAAO,KAAR;IACE,WAAW,gBACT,4CACA,gBAAgB,cACjB;IACD,OAAO;KACL,YAAY,mBAAmB,gBAAgB,GAAI,eAAe,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,eAAe,QAAQ,QAAQ,MAAM,CAAC;KACnJ,QAAQ;KACT;IACD,SAAS,EAAE,SAAS,GAAG;IACvB,SAAS,EAAE,SAAS,GAAG;IACvB,YAAY,EAAE,UAAU,IAAK;IAC7B,CAAA;GAIJ,oBAAC,OAAD;IAAK,WAAU;IAAiB;IAAe,CAAA;GACpC;;;AAIjB,cAAc,cAAc"}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
require("./chunk-B_GkZjkl.cjs");
|
|
2
|
+
const require_utils = require("./utils-B4SmmY4J.cjs");
|
|
3
|
+
let react = require("react");
|
|
4
|
+
let react_jsx_runtime = require("react/jsx-runtime");
|
|
5
|
+
let framer_motion = require("framer-motion");
|
|
6
|
+
//#region src/components/effects/spotlight-card/SpotlightCard.tsx
|
|
7
|
+
var borderRadiusMap = {
|
|
8
|
+
sm: "rounded-sm",
|
|
9
|
+
md: "rounded-md",
|
|
10
|
+
lg: "rounded-lg",
|
|
11
|
+
xl: "rounded-xl",
|
|
12
|
+
"2xl": "rounded-2xl",
|
|
13
|
+
full: "rounded-full"
|
|
14
|
+
};
|
|
15
|
+
var paddingMap = {
|
|
16
|
+
none: "",
|
|
17
|
+
sm: "p-3",
|
|
18
|
+
md: "p-5",
|
|
19
|
+
lg: "p-7",
|
|
20
|
+
xl: "p-10"
|
|
21
|
+
};
|
|
22
|
+
var variantStyles = {
|
|
23
|
+
glass: `
|
|
24
|
+
bg-white/60 dark:bg-neutral-900/50
|
|
25
|
+
backdrop-blur-2xl
|
|
26
|
+
border border-white/40 dark:border-white/10
|
|
27
|
+
shadow-xl shadow-neutral-200/30 dark:shadow-neutral-950/50
|
|
28
|
+
`,
|
|
29
|
+
solid: `
|
|
30
|
+
bg-white dark:bg-neutral-900
|
|
31
|
+
border border-neutral-200 dark:border-neutral-800
|
|
32
|
+
shadow-lg shadow-neutral-200/50 dark:shadow-neutral-950/50
|
|
33
|
+
`,
|
|
34
|
+
outlined: `
|
|
35
|
+
bg-transparent
|
|
36
|
+
border-2 border-neutral-200 dark:border-neutral-700
|
|
37
|
+
`
|
|
38
|
+
};
|
|
39
|
+
var SpotlightCard = ({ children, className, spotlightColor = "rgba(115, 103, 240, 0.15)", spotlightSize = 350, spotlightEnabled = true, variant = "glass", borderRadius = "xl", padding = "md", hoverScale = true, style, onClick }) => {
|
|
40
|
+
const containerRef = (0, react.useRef)(null);
|
|
41
|
+
const [mousePosition, setMousePosition] = (0, react.useState)({
|
|
42
|
+
x: 0,
|
|
43
|
+
y: 0
|
|
44
|
+
});
|
|
45
|
+
const [isHovered, setIsHovered] = (0, react.useState)(false);
|
|
46
|
+
const handleMouseMove = (e) => {
|
|
47
|
+
if (!containerRef.current || !spotlightEnabled) return;
|
|
48
|
+
const rect = containerRef.current.getBoundingClientRect();
|
|
49
|
+
setMousePosition({
|
|
50
|
+
x: e.clientX - rect.left,
|
|
51
|
+
y: e.clientY - rect.top
|
|
52
|
+
});
|
|
53
|
+
};
|
|
54
|
+
const handleMouseEnter = () => {
|
|
55
|
+
setIsHovered(true);
|
|
56
|
+
};
|
|
57
|
+
const handleMouseLeave = () => {
|
|
58
|
+
setIsHovered(false);
|
|
59
|
+
};
|
|
60
|
+
const spotlightStyle = spotlightEnabled && isHovered ? { background: `radial-gradient(${spotlightSize}px circle at ${mousePosition.x}px ${mousePosition.y}px, ${spotlightColor}, transparent 80%)` } : {};
|
|
61
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(framer_motion.motion.div, {
|
|
62
|
+
ref: containerRef,
|
|
63
|
+
className: require_utils.mergeClassNames("relative overflow-hidden transition-all duration-300", borderRadiusMap[borderRadius], paddingMap[padding], variantStyles[variant], onClick && "cursor-pointer", className),
|
|
64
|
+
style,
|
|
65
|
+
onMouseMove: handleMouseMove,
|
|
66
|
+
onMouseEnter: handleMouseEnter,
|
|
67
|
+
onMouseLeave: handleMouseLeave,
|
|
68
|
+
onClick,
|
|
69
|
+
whileHover: hoverScale ? { scale: 1.02 } : void 0,
|
|
70
|
+
whileTap: onClick ? { scale: .98 } : void 0,
|
|
71
|
+
transition: {
|
|
72
|
+
type: "spring",
|
|
73
|
+
stiffness: 400,
|
|
74
|
+
damping: 25
|
|
75
|
+
},
|
|
76
|
+
children: [
|
|
77
|
+
spotlightEnabled && /* @__PURE__ */ (0, react_jsx_runtime.jsx)(framer_motion.motion.div, {
|
|
78
|
+
className: "pointer-events-none absolute inset-0 z-0",
|
|
79
|
+
style: spotlightStyle,
|
|
80
|
+
initial: { opacity: 0 },
|
|
81
|
+
animate: { opacity: isHovered ? 1 : 0 },
|
|
82
|
+
transition: { duration: .3 }
|
|
83
|
+
}),
|
|
84
|
+
spotlightEnabled && isHovered && /* @__PURE__ */ (0, react_jsx_runtime.jsx)(framer_motion.motion.div, {
|
|
85
|
+
className: require_utils.mergeClassNames("pointer-events-none absolute inset-0 z-0", borderRadiusMap[borderRadius]),
|
|
86
|
+
style: {
|
|
87
|
+
background: `radial-gradient(${spotlightSize * .6}px circle at ${mousePosition.x}px ${mousePosition.y}px, ${spotlightColor.replace("0.15", "0.3")}, transparent 70%)`,
|
|
88
|
+
filter: "blur(20px)"
|
|
89
|
+
},
|
|
90
|
+
initial: { opacity: 0 },
|
|
91
|
+
animate: { opacity: 1 },
|
|
92
|
+
transition: { duration: .2 }
|
|
93
|
+
}),
|
|
94
|
+
/* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
|
|
95
|
+
className: "relative z-10",
|
|
96
|
+
children
|
|
97
|
+
})
|
|
98
|
+
]
|
|
99
|
+
});
|
|
100
|
+
};
|
|
101
|
+
SpotlightCard.displayName = "SpotlightCard";
|
|
102
|
+
//#endregion
|
|
103
|
+
Object.defineProperty(exports, "SpotlightCard", {
|
|
104
|
+
enumerable: true,
|
|
105
|
+
get: function() {
|
|
106
|
+
return SpotlightCard;
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
//# sourceMappingURL=spotlight-card-DS1dy1W3.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spotlight-card-DS1dy1W3.cjs","names":[],"sources":["../../src/components/effects/spotlight-card/SpotlightCard.tsx"],"sourcesContent":["import { useState, useRef } from \"react\";\nimport { motion } from \"framer-motion\";\nimport { mergeClassNames } from \"../../../utils\";\nimport type { SpotlightCardProps } from \"./types\";\n\nconst borderRadiusMap = {\n sm: \"rounded-sm\",\n md: \"rounded-md\",\n lg: \"rounded-lg\",\n xl: \"rounded-xl\",\n \"2xl\": \"rounded-2xl\",\n full: \"rounded-full\",\n};\n\nconst paddingMap = {\n none: \"\",\n sm: \"p-3\",\n md: \"p-5\",\n lg: \"p-7\",\n xl: \"p-10\",\n};\n\nconst variantStyles = {\n glass: `\n bg-white/60 dark:bg-neutral-900/50\n backdrop-blur-2xl\n border border-white/40 dark:border-white/10\n shadow-xl shadow-neutral-200/30 dark:shadow-neutral-950/50\n `,\n solid: `\n bg-white dark:bg-neutral-900\n border border-neutral-200 dark:border-neutral-800\n shadow-lg shadow-neutral-200/50 dark:shadow-neutral-950/50\n `,\n outlined: `\n bg-transparent\n border-2 border-neutral-200 dark:border-neutral-700\n `,\n};\n\nexport const SpotlightCard = ({\n children,\n className,\n spotlightColor = \"rgba(115, 103, 240, 0.15)\",\n spotlightSize = 350,\n spotlightEnabled = true,\n variant = \"glass\",\n borderRadius = \"xl\",\n padding = \"md\",\n hoverScale = true,\n style,\n onClick,\n}: SpotlightCardProps) => {\n const containerRef = useRef<HTMLDivElement>(null);\n const [mousePosition, setMousePosition] = useState({ x: 0, y: 0 });\n const [isHovered, setIsHovered] = useState(false);\n\n const handleMouseMove = (e: React.MouseEvent<HTMLDivElement>) => {\n if (!containerRef.current || !spotlightEnabled) return;\n const rect = containerRef.current.getBoundingClientRect();\n setMousePosition({\n x: e.clientX - rect.left,\n y: e.clientY - rect.top,\n });\n };\n\n const handleMouseEnter = () => {\n setIsHovered(true);\n };\n\n const handleMouseLeave = () => {\n setIsHovered(false);\n };\n\n const spotlightStyle =\n spotlightEnabled && isHovered\n ? {\n background: `radial-gradient(${spotlightSize}px circle at ${mousePosition.x}px ${mousePosition.y}px, ${spotlightColor}, transparent 80%)`,\n }\n : {};\n\n return (\n <motion.div\n ref={containerRef}\n className={mergeClassNames(\n \"relative overflow-hidden transition-all duration-300\",\n borderRadiusMap[borderRadius],\n paddingMap[padding],\n variantStyles[variant],\n onClick && \"cursor-pointer\",\n className,\n )}\n style={style}\n onMouseMove={handleMouseMove}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n onClick={onClick}\n whileHover={hoverScale ? { scale: 1.02 } : undefined}\n whileTap={onClick ? { scale: 0.98 } : undefined}\n transition={{ type: \"spring\", stiffness: 400, damping: 25 }}\n >\n {/* Spotlight overlay */}\n {spotlightEnabled && (\n <motion.div\n className=\"pointer-events-none absolute inset-0 z-0\"\n style={spotlightStyle}\n initial={{ opacity: 0 }}\n animate={{ opacity: isHovered ? 1 : 0 }}\n transition={{ duration: 0.3 }}\n />\n )}\n\n {/* Border glow effect */}\n {spotlightEnabled && isHovered && (\n <motion.div\n className={mergeClassNames(\n \"pointer-events-none absolute inset-0 z-0\",\n borderRadiusMap[borderRadius],\n )}\n style={{\n background: `radial-gradient(${spotlightSize * 0.6}px circle at ${mousePosition.x}px ${mousePosition.y}px, ${spotlightColor.replace(\"0.15\", \"0.3\")}, transparent 70%)`,\n filter: \"blur(20px)\",\n }}\n initial={{ opacity: 0 }}\n animate={{ opacity: 1 }}\n transition={{ duration: 0.2 }}\n />\n )}\n\n {/* Content */}\n <div className=\"relative z-10\">{children}</div>\n </motion.div>\n );\n};\n\nSpotlightCard.displayName = \"SpotlightCard\";\n\nexport default SpotlightCard;\n"],"mappings":";;;;;;AAKA,IAAM,kBAAkB;CACtB,IAAI;CACJ,IAAI;CACJ,IAAI;CACJ,IAAI;CACJ,OAAO;CACP,MAAM;CACP;AAED,IAAM,aAAa;CACjB,MAAM;CACN,IAAI;CACJ,IAAI;CACJ,IAAI;CACJ,IAAI;CACL;AAED,IAAM,gBAAgB;CACpB,OAAO;;;;;;CAMP,OAAO;;;;;CAKP,UAAU;;;;CAIX;AAED,IAAa,iBAAiB,EAC5B,UACA,WACA,iBAAiB,6BACjB,gBAAgB,KAChB,mBAAmB,MACnB,UAAU,SACV,eAAe,MACf,UAAU,MACV,aAAa,MACb,OACA,cACwB;CACxB,MAAM,gBAAA,GAAA,MAAA,QAAsC,KAAK;CACjD,MAAM,CAAC,eAAe,qBAAA,GAAA,MAAA,UAA6B;EAAE,GAAG;EAAG,GAAG;EAAG,CAAC;CAClE,MAAM,CAAC,WAAW,iBAAA,GAAA,MAAA,UAAyB,MAAM;CAEjD,MAAM,mBAAmB,MAAwC;AAC/D,MAAI,CAAC,aAAa,WAAW,CAAC,iBAAkB;EAChD,MAAM,OAAO,aAAa,QAAQ,uBAAuB;AACzD,mBAAiB;GACf,GAAG,EAAE,UAAU,KAAK;GACpB,GAAG,EAAE,UAAU,KAAK;GACrB,CAAC;;CAGJ,MAAM,yBAAyB;AAC7B,eAAa,KAAK;;CAGpB,MAAM,yBAAyB;AAC7B,eAAa,MAAM;;CAGrB,MAAM,iBACJ,oBAAoB,YAChB,EACE,YAAY,mBAAmB,cAAc,eAAe,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,eAAe,qBACvH,GACD,EAAE;AAER,QACE,iBAAA,GAAA,kBAAA,MAAC,cAAA,OAAO,KAAR;EACE,KAAK;EACL,WAAW,cAAA,gBACT,wDACA,gBAAgB,eAChB,WAAW,UACX,cAAc,UACd,WAAW,kBACX,UACD;EACM;EACP,aAAa;EACb,cAAc;EACd,cAAc;EACL;EACT,YAAY,aAAa,EAAE,OAAO,MAAM,GAAG,KAAA;EAC3C,UAAU,UAAU,EAAE,OAAO,KAAM,GAAG,KAAA;EACtC,YAAY;GAAE,MAAM;GAAU,WAAW;GAAK,SAAS;GAAI;YAjB7D;GAoBG,oBACC,iBAAA,GAAA,kBAAA,KAAC,cAAA,OAAO,KAAR;IACE,WAAU;IACV,OAAO;IACP,SAAS,EAAE,SAAS,GAAG;IACvB,SAAS,EAAE,SAAS,YAAY,IAAI,GAAG;IACvC,YAAY,EAAE,UAAU,IAAK;IAC7B,CAAA;GAIH,oBAAoB,aACnB,iBAAA,GAAA,kBAAA,KAAC,cAAA,OAAO,KAAR;IACE,WAAW,cAAA,gBACT,4CACA,gBAAgB,cACjB;IACD,OAAO;KACL,YAAY,mBAAmB,gBAAgB,GAAI,eAAe,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,eAAe,QAAQ,QAAQ,MAAM,CAAC;KACnJ,QAAQ;KACT;IACD,SAAS,EAAE,SAAS,GAAG;IACvB,SAAS,EAAE,SAAS,GAAG;IACvB,YAAY,EAAE,UAAU,IAAK;IAC7B,CAAA;GAIJ,iBAAA,GAAA,kBAAA,KAAC,OAAD;IAAK,WAAU;IAAiB;IAAe,CAAA;GACpC;;;AAIjB,cAAc,cAAc"}
|
|
@@ -0,0 +1,261 @@
|
|
|
1
|
+
import { n as mergeClassNames } from "./utils-ati1KkDb.mjs";
|
|
2
|
+
import { J as CheckIcon, q as CloseIcon } from "./icons-DuumN7z-.mjs";
|
|
3
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
4
|
+
import { AnimatePresence, motion } from "framer-motion";
|
|
5
|
+
//#region src/components/navigation/stepper/Stepper.tsx
|
|
6
|
+
var sizeConfig = {
|
|
7
|
+
sm: {
|
|
8
|
+
indicator: "w-8 h-8",
|
|
9
|
+
icon: "w-4 h-4",
|
|
10
|
+
text: "text-xs",
|
|
11
|
+
connectorThickness: "2px"
|
|
12
|
+
},
|
|
13
|
+
md: {
|
|
14
|
+
indicator: "w-10 h-10",
|
|
15
|
+
icon: "w-5 h-5",
|
|
16
|
+
text: "text-sm",
|
|
17
|
+
connectorThickness: "2px"
|
|
18
|
+
},
|
|
19
|
+
lg: {
|
|
20
|
+
indicator: "w-12 h-12",
|
|
21
|
+
icon: "w-6 h-6",
|
|
22
|
+
text: "text-base",
|
|
23
|
+
connectorThickness: "4px"
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
var getVariantStyles = (variant, status) => {
|
|
27
|
+
return {
|
|
28
|
+
default: {
|
|
29
|
+
completed: "bg-accent text-on-accent shadow-md shadow-accent/25",
|
|
30
|
+
current: "bg-accent text-on-accent ring-4 ring-focus/40 shadow-lg shadow-accent/30",
|
|
31
|
+
upcoming: "bg-neutral-200 text-neutral-500 dark:bg-neutral-700 dark:text-neutral-400",
|
|
32
|
+
error: "bg-red-500 text-white ring-4 ring-red-500/30"
|
|
33
|
+
},
|
|
34
|
+
glass: {
|
|
35
|
+
completed: "bg-accent/85 text-on-accent backdrop-blur-xl border border-accent/30 shadow-lg shadow-accent/20",
|
|
36
|
+
current: "bg-accent/90 text-on-accent backdrop-blur-xl border-2 border-accent ring-4 ring-focus/30 shadow-xl shadow-accent/30",
|
|
37
|
+
upcoming: "bg-white/60 text-neutral-500 backdrop-blur-xl border border-white/40 dark:bg-neutral-800/60 dark:text-neutral-400 dark:border-white/10",
|
|
38
|
+
error: "bg-red-500/80 text-white backdrop-blur-xl border border-red-400/30 ring-4 ring-red-500/20"
|
|
39
|
+
},
|
|
40
|
+
minimal: {
|
|
41
|
+
completed: "bg-accent-subtle text-accent",
|
|
42
|
+
current: "bg-accent text-on-accent shadow-sm",
|
|
43
|
+
upcoming: "bg-transparent text-neutral-400 border-2 border-neutral-300 dark:border-neutral-600",
|
|
44
|
+
error: "bg-red-100 text-red-500 dark:bg-red-900/30"
|
|
45
|
+
},
|
|
46
|
+
outlined: {
|
|
47
|
+
completed: "bg-transparent text-accent border-2 border-accent",
|
|
48
|
+
current: "bg-accent text-on-accent border-2 border-accent shadow-lg",
|
|
49
|
+
upcoming: "bg-transparent text-neutral-400 border-2 border-neutral-300 dark:border-neutral-600",
|
|
50
|
+
error: "bg-transparent text-red-500 border-2 border-red-500"
|
|
51
|
+
}
|
|
52
|
+
}[variant][status];
|
|
53
|
+
};
|
|
54
|
+
var StepIndicator = ({ step, index, status, size, variant, showNumbers, animated, colors }) => {
|
|
55
|
+
const config = sizeConfig[size];
|
|
56
|
+
const variantStyles = getVariantStyles(variant, status);
|
|
57
|
+
const customColorStyle = colors?.[status] ? {
|
|
58
|
+
backgroundColor: colors[status],
|
|
59
|
+
borderColor: colors[status]
|
|
60
|
+
} : void 0;
|
|
61
|
+
const renderContent = () => {
|
|
62
|
+
if (step.icon) return /* @__PURE__ */ jsx("span", {
|
|
63
|
+
className: config.icon,
|
|
64
|
+
children: step.icon
|
|
65
|
+
});
|
|
66
|
+
if (status === "completed") return /* @__PURE__ */ jsx(CheckIcon, {
|
|
67
|
+
className: config.icon,
|
|
68
|
+
"aria-hidden": "true"
|
|
69
|
+
});
|
|
70
|
+
if (status === "error") return /* @__PURE__ */ jsx(CloseIcon, {
|
|
71
|
+
className: config.icon,
|
|
72
|
+
"aria-hidden": "true"
|
|
73
|
+
});
|
|
74
|
+
if (showNumbers) return /* @__PURE__ */ jsx("span", {
|
|
75
|
+
className: "font-semibold",
|
|
76
|
+
children: index + 1
|
|
77
|
+
});
|
|
78
|
+
return /* @__PURE__ */ jsx("span", { className: mergeClassNames("rounded-full bg-current", size === "sm" ? "w-2 h-2" : "w-3 h-3") });
|
|
79
|
+
};
|
|
80
|
+
return /* @__PURE__ */ jsx(motion.div, {
|
|
81
|
+
className: mergeClassNames("rounded-full flex items-center justify-center transition-all duration-300", config.indicator, variantStyles),
|
|
82
|
+
style: customColorStyle,
|
|
83
|
+
initial: animated ? {
|
|
84
|
+
scale: .8,
|
|
85
|
+
opacity: 0
|
|
86
|
+
} : void 0,
|
|
87
|
+
animate: animated ? {
|
|
88
|
+
scale: 1,
|
|
89
|
+
opacity: 1
|
|
90
|
+
} : void 0,
|
|
91
|
+
whileHover: { scale: 1.05 },
|
|
92
|
+
whileTap: { scale: .95 },
|
|
93
|
+
transition: {
|
|
94
|
+
type: "spring",
|
|
95
|
+
stiffness: 400,
|
|
96
|
+
damping: 17
|
|
97
|
+
},
|
|
98
|
+
children: /* @__PURE__ */ jsx(AnimatePresence, {
|
|
99
|
+
mode: "wait",
|
|
100
|
+
children: /* @__PURE__ */ jsx(motion.span, {
|
|
101
|
+
initial: animated ? {
|
|
102
|
+
scale: 0,
|
|
103
|
+
rotate: -180
|
|
104
|
+
} : void 0,
|
|
105
|
+
animate: animated ? {
|
|
106
|
+
scale: 1,
|
|
107
|
+
rotate: 0
|
|
108
|
+
} : void 0,
|
|
109
|
+
exit: animated ? {
|
|
110
|
+
scale: 0,
|
|
111
|
+
rotate: 180
|
|
112
|
+
} : void 0,
|
|
113
|
+
transition: { duration: .2 },
|
|
114
|
+
children: renderContent()
|
|
115
|
+
}, status)
|
|
116
|
+
})
|
|
117
|
+
});
|
|
118
|
+
};
|
|
119
|
+
var Stepper = ({ steps, currentStep, onStepClick, orientation = "horizontal", size = "md", variant = "glass", showNumbers = true, clickable = true, showConnector = true, className, connectorClassName, stepClassName, showErrors = false, errorSteps = [], completedSteps, animated = true, colors }) => {
|
|
120
|
+
const isVertical = orientation === "vertical";
|
|
121
|
+
const config = sizeConfig[size];
|
|
122
|
+
const getStepStatus = (index) => {
|
|
123
|
+
if (showErrors && errorSteps.includes(index)) return "error";
|
|
124
|
+
if (completedSteps) {
|
|
125
|
+
if (completedSteps.includes(index)) return "completed";
|
|
126
|
+
if (index === currentStep) return "current";
|
|
127
|
+
return "upcoming";
|
|
128
|
+
}
|
|
129
|
+
if (index < currentStep) return "completed";
|
|
130
|
+
if (index === currentStep) return "current";
|
|
131
|
+
return "upcoming";
|
|
132
|
+
};
|
|
133
|
+
const handleStepClick = (index) => {
|
|
134
|
+
if (!clickable || !onStepClick) return;
|
|
135
|
+
if (steps[index].disabled) return;
|
|
136
|
+
const status = getStepStatus(index);
|
|
137
|
+
if (status === "completed" || status === "current") onStepClick(index);
|
|
138
|
+
};
|
|
139
|
+
return /* @__PURE__ */ jsxs("div", {
|
|
140
|
+
className: mergeClassNames("w-full relative", isVertical ? "flex flex-col" : "flex items-start justify-between", className),
|
|
141
|
+
children: [showConnector && (() => {
|
|
142
|
+
const paddingValue = variant === "glass" || variant === "outlined" || variant === "minimal" ? 4 : 2;
|
|
143
|
+
return /* @__PURE__ */ jsx("div", {
|
|
144
|
+
className: mergeClassNames("absolute rounded-full", variant === "glass" ? "bg-white/30 dark:bg-white/10 backdrop-blur-sm" : "bg-neutral-200 dark:bg-neutral-700", connectorClassName),
|
|
145
|
+
style: { ...isVertical ? {
|
|
146
|
+
top: "0",
|
|
147
|
+
bottom: "0",
|
|
148
|
+
left: `calc(${paddingValue}px + 1px + ${config.indicator.split(" ")[0].replace("w-", "")} * 0.125rem - ${config.connectorThickness} / 2)`,
|
|
149
|
+
width: config.connectorThickness
|
|
150
|
+
} : {
|
|
151
|
+
left: "0",
|
|
152
|
+
right: "0",
|
|
153
|
+
top: `calc(${paddingValue}px + 1px + ${config.indicator.split(" ")[1].replace("h-", "")} * 0.125rem - ${config.connectorThickness} / 2)`,
|
|
154
|
+
height: config.connectorThickness
|
|
155
|
+
} },
|
|
156
|
+
children: animated ? /* @__PURE__ */ jsx(motion.div, {
|
|
157
|
+
className: "absolute top-0 left-0 bg-accent rounded-full",
|
|
158
|
+
initial: { [isVertical ? "height" : "width"]: 0 },
|
|
159
|
+
animate: { [isVertical ? "height" : "width"]: `${steps.length > 1 ? Math.min(currentStep, steps.length - 1) / (steps.length - 1) * 100 : 0}%` },
|
|
160
|
+
transition: {
|
|
161
|
+
duration: .4,
|
|
162
|
+
ease: "easeOut"
|
|
163
|
+
},
|
|
164
|
+
style: {
|
|
165
|
+
...isVertical ? { width: "100%" } : { height: "100%" },
|
|
166
|
+
backgroundColor: colors?.connector || colors?.completed
|
|
167
|
+
}
|
|
168
|
+
}) : /* @__PURE__ */ jsx("div", {
|
|
169
|
+
className: "absolute top-0 left-0 bg-accent rounded-full",
|
|
170
|
+
style: {
|
|
171
|
+
...isVertical ? {
|
|
172
|
+
width: "100%",
|
|
173
|
+
height: `${steps.length > 1 ? Math.min(currentStep, steps.length - 1) / (steps.length - 1) * 100 : 0}%`
|
|
174
|
+
} : {
|
|
175
|
+
height: "100%",
|
|
176
|
+
width: `${steps.length > 1 ? Math.min(currentStep, steps.length - 1) / (steps.length - 1) * 100 : 0}%`
|
|
177
|
+
},
|
|
178
|
+
backgroundColor: colors?.connector || colors?.completed
|
|
179
|
+
}
|
|
180
|
+
})
|
|
181
|
+
});
|
|
182
|
+
})(), steps.map((step, index) => {
|
|
183
|
+
const status = getStepStatus(index);
|
|
184
|
+
const isLast = index === steps.length - 1;
|
|
185
|
+
const isClickable = clickable && !step.disabled;
|
|
186
|
+
const paddingValue = variant === "glass" || variant === "outlined" || variant === "minimal" ? 4 : 2;
|
|
187
|
+
return /* @__PURE__ */ jsxs("div", {
|
|
188
|
+
className: mergeClassNames("relative z-10", isVertical ? "flex gap-4 pb-8" : "flex flex-1 flex-col items-center", !isLast && isVertical && "mb-2", isVertical && isLast && "pb-0", stepClassName),
|
|
189
|
+
style: { ...!isVertical ? {
|
|
190
|
+
flexBasis: 0,
|
|
191
|
+
flexGrow: 1,
|
|
192
|
+
alignItems: index === 0 ? "flex-start" : isLast ? "flex-end" : "center"
|
|
193
|
+
} : {} },
|
|
194
|
+
children: [
|
|
195
|
+
/* @__PURE__ */ jsx("button", {
|
|
196
|
+
type: "button",
|
|
197
|
+
onClick: () => handleStepClick(index),
|
|
198
|
+
disabled: !isClickable,
|
|
199
|
+
className: mergeClassNames("relative z-10 shrink-0 flex items-center justify-center bg-white dark:bg-neutral-900 rounded-full", isClickable ? "cursor-pointer" : "cursor-default", !isVertical && index === 0 && "mx-0", !isVertical && isLast && "mx-0"),
|
|
200
|
+
style: { padding: `${paddingValue}px` },
|
|
201
|
+
"aria-current": status === "current" ? "step" : void 0,
|
|
202
|
+
children: /* @__PURE__ */ jsx(StepIndicator, {
|
|
203
|
+
step,
|
|
204
|
+
index,
|
|
205
|
+
status,
|
|
206
|
+
size,
|
|
207
|
+
variant,
|
|
208
|
+
showNumbers,
|
|
209
|
+
animated,
|
|
210
|
+
colors
|
|
211
|
+
})
|
|
212
|
+
}),
|
|
213
|
+
/* @__PURE__ */ jsxs(motion.div, {
|
|
214
|
+
className: mergeClassNames("mt-2", isVertical ? "flex-1 pb-6" : "text-center px-2", !isVertical && index === 0 && "text-left px-0", !isVertical && isLast && "text-right px-0", isVertical && isLast && "pb-0"),
|
|
215
|
+
style: isVertical ? { marginTop: "-4px" } : void 0,
|
|
216
|
+
initial: animated ? {
|
|
217
|
+
opacity: 0,
|
|
218
|
+
y: 10
|
|
219
|
+
} : void 0,
|
|
220
|
+
animate: animated ? {
|
|
221
|
+
opacity: 1,
|
|
222
|
+
y: 0
|
|
223
|
+
} : void 0,
|
|
224
|
+
transition: { delay: index * .1 },
|
|
225
|
+
children: [/* @__PURE__ */ jsxs("p", {
|
|
226
|
+
className: mergeClassNames("font-medium transition-colors duration-200", config.text, status === "current" ? "text-accent" : status === "completed" ? "text-neutral-700 dark:text-neutral-200" : status === "error" ? "text-red-500" : "text-neutral-500 dark:text-neutral-400"),
|
|
227
|
+
children: [step.title, step.optional && /* @__PURE__ */ jsx("span", {
|
|
228
|
+
className: "ml-1 text-neutral-400 dark:text-neutral-500 font-normal",
|
|
229
|
+
children: "(Optional)"
|
|
230
|
+
})]
|
|
231
|
+
}), step.description && /* @__PURE__ */ jsx("p", {
|
|
232
|
+
className: mergeClassNames("mt-0.5 text-neutral-500 dark:text-neutral-400", size === "sm" ? "text-xs" : "text-xs"),
|
|
233
|
+
children: step.description
|
|
234
|
+
})]
|
|
235
|
+
}),
|
|
236
|
+
isVertical && step.content && status === "current" && /* @__PURE__ */ jsx(motion.div, {
|
|
237
|
+
initial: {
|
|
238
|
+
opacity: 0,
|
|
239
|
+
height: 0
|
|
240
|
+
},
|
|
241
|
+
animate: {
|
|
242
|
+
opacity: 1,
|
|
243
|
+
height: "auto"
|
|
244
|
+
},
|
|
245
|
+
exit: {
|
|
246
|
+
opacity: 0,
|
|
247
|
+
height: 0
|
|
248
|
+
},
|
|
249
|
+
className: "pl-14 pb-4 w-full",
|
|
250
|
+
children: step.content
|
|
251
|
+
})
|
|
252
|
+
]
|
|
253
|
+
}, step.id);
|
|
254
|
+
})]
|
|
255
|
+
});
|
|
256
|
+
};
|
|
257
|
+
Stepper.displayName = "Stepper";
|
|
258
|
+
//#endregion
|
|
259
|
+
export { Stepper as t };
|
|
260
|
+
|
|
261
|
+
//# sourceMappingURL=stepper-D4yQsQB0.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stepper-D4yQsQB0.mjs","names":[],"sources":["../../src/components/navigation/stepper/Stepper.tsx"],"sourcesContent":["import { motion, AnimatePresence } from \"framer-motion\";\n\nimport { CheckIcon, CloseIcon } from \"../../icons\";\nimport { mergeClassNames } from \"../../../utils\";\nimport type {\n StepperProps,\n StepIndicatorProps,\n StepStatus,\n StepperSize,\n StepperVariant,\n} from \"./types\";\n\n// Size configurations for indicators and icons\nconst sizeConfig: Record<\n StepperSize,\n { indicator: string; icon: string; text: string; connectorThickness: string }\n> = {\n sm: {\n indicator: \"w-8 h-8\",\n icon: \"w-4 h-4\",\n text: \"text-xs\",\n connectorThickness: \"2px\",\n },\n md: {\n indicator: \"w-10 h-10\",\n icon: \"w-5 h-5\",\n text: \"text-sm\",\n connectorThickness: \"2px\",\n },\n lg: {\n indicator: \"w-12 h-12\",\n icon: \"w-6 h-6\",\n text: \"text-base\",\n connectorThickness: \"4px\",\n },\n};\n\n// Variant styles for the indicator\nconst getVariantStyles = (variant: StepperVariant, status: StepStatus) => {\n const baseStyles = {\n default: {\n completed: \"bg-accent text-on-accent shadow-md shadow-accent/25\",\n current:\n \"bg-accent text-on-accent ring-4 ring-focus/40 shadow-lg shadow-accent/30\",\n upcoming:\n \"bg-neutral-200 text-neutral-500 dark:bg-neutral-700 dark:text-neutral-400\",\n error: \"bg-red-500 text-white ring-4 ring-red-500/30\",\n },\n glass: {\n completed:\n \"bg-accent/85 text-on-accent backdrop-blur-xl border border-accent/30 shadow-lg shadow-accent/20\",\n current:\n \"bg-accent/90 text-on-accent backdrop-blur-xl border-2 border-accent ring-4 ring-focus/30 shadow-xl shadow-accent/30\",\n upcoming:\n \"bg-white/60 text-neutral-500 backdrop-blur-xl border border-white/40 dark:bg-neutral-800/60 dark:text-neutral-400 dark:border-white/10\",\n error:\n \"bg-red-500/80 text-white backdrop-blur-xl border border-red-400/30 ring-4 ring-red-500/20\",\n },\n minimal: {\n completed: \"bg-accent-subtle text-accent\",\n current: \"bg-accent text-on-accent shadow-sm\",\n upcoming:\n \"bg-transparent text-neutral-400 border-2 border-neutral-300 dark:border-neutral-600\",\n error: \"bg-red-100 text-red-500 dark:bg-red-900/30\",\n },\n outlined: {\n completed: \"bg-transparent text-accent border-2 border-accent\",\n current: \"bg-accent text-on-accent border-2 border-accent shadow-lg\",\n upcoming:\n \"bg-transparent text-neutral-400 border-2 border-neutral-300 dark:border-neutral-600\",\n error: \"bg-transparent text-red-500 border-2 border-red-500\",\n },\n };\n\n return baseStyles[variant][status];\n};\n\n// Step Indicator Component\nconst StepIndicator = ({\n step,\n index,\n status,\n size,\n variant,\n showNumbers,\n animated,\n colors,\n}: StepIndicatorProps) => {\n const config = sizeConfig[size];\n const variantStyles = getVariantStyles(variant, status);\n\n // Custom color overrides\n const customColorStyle = colors?.[status]\n ? { backgroundColor: colors[status], borderColor: colors[status] }\n : undefined;\n\n const renderContent = () => {\n if (step.icon) {\n return <span className={config.icon}>{step.icon}</span>;\n }\n\n if (status === \"completed\") {\n return <CheckIcon className={config.icon} aria-hidden=\"true\" />;\n }\n\n if (status === \"error\") {\n return <CloseIcon className={config.icon} aria-hidden=\"true\" />;\n }\n\n if (showNumbers) {\n return <span className=\"font-semibold\">{index + 1}</span>;\n }\n\n return (\n <span\n className={mergeClassNames(\n \"rounded-full bg-current\",\n size === \"sm\" ? \"w-2 h-2\" : \"w-3 h-3\",\n )}\n />\n );\n };\n\n return (\n <motion.div\n className={mergeClassNames(\n \"rounded-full flex items-center justify-center transition-all duration-300\",\n config.indicator,\n variantStyles,\n )}\n style={customColorStyle}\n initial={animated ? { scale: 0.8, opacity: 0 } : undefined}\n animate={animated ? { scale: 1, opacity: 1 } : undefined}\n whileHover={{ scale: 1.05 }}\n whileTap={{ scale: 0.95 }}\n transition={{ type: \"spring\", stiffness: 400, damping: 17 }}\n >\n <AnimatePresence mode=\"wait\">\n <motion.span\n key={status}\n initial={animated ? { scale: 0, rotate: -180 } : undefined}\n animate={animated ? { scale: 1, rotate: 0 } : undefined}\n exit={animated ? { scale: 0, rotate: 180 } : undefined}\n transition={{ duration: 0.2 }}\n >\n {renderContent()}\n </motion.span>\n </AnimatePresence>\n </motion.div>\n );\n};\n\n// Main Stepper Component\nexport const Stepper = ({\n steps,\n currentStep,\n onStepClick,\n orientation = \"horizontal\",\n size = \"md\",\n variant = \"glass\",\n showNumbers = true,\n clickable = true,\n showConnector = true,\n className,\n connectorClassName,\n stepClassName,\n showErrors = false,\n errorSteps = [],\n completedSteps,\n animated = true,\n colors,\n}: StepperProps) => {\n const isVertical = orientation === \"vertical\";\n const config = sizeConfig[size];\n\n const getStepStatus = (index: number): StepStatus => {\n if (showErrors && errorSteps.includes(index)) return \"error\";\n if (completedSteps) {\n if (completedSteps.includes(index)) return \"completed\";\n if (index === currentStep) return \"current\";\n return \"upcoming\";\n }\n if (index < currentStep) return \"completed\";\n if (index === currentStep) return \"current\";\n return \"upcoming\";\n };\n\n const handleStepClick = (index: number) => {\n if (!clickable || !onStepClick) return;\n const step = steps[index];\n if (step.disabled) return;\n\n // Allow clicking on completed or current steps\n const status = getStepStatus(index);\n if (status === \"completed\" || status === \"current\") {\n onStepClick(index);\n }\n };\n\n return (\n <div\n className={mergeClassNames(\n \"w-full relative\",\n isVertical ? \"flex flex-col\" : \"flex items-start justify-between\",\n className,\n )}\n >\n {/* Global Background Continuous Connector */}\n {showConnector &&\n (() => {\n const paddingValue =\n variant === \"glass\" ||\n variant === \"outlined\" ||\n variant === \"minimal\"\n ? 4\n : 2;\n return (\n <div\n className={mergeClassNames(\n \"absolute rounded-full\",\n variant === \"glass\"\n ? \"bg-white/30 dark:bg-white/10 backdrop-blur-sm\"\n : \"bg-neutral-200 dark:bg-neutral-700\",\n connectorClassName,\n )}\n style={{\n ...(isVertical\n ? {\n // Vertical background line\n top: \"0\",\n bottom: \"0\",\n left: `calc(${paddingValue}px + 1px + ${config.indicator.split(\" \")[0].replace(\"w-\", \"\")} * 0.125rem - ${config.connectorThickness} / 2)`,\n width: config.connectorThickness,\n }\n : {\n // Horizontal background line\n left: \"0\",\n right: \"0\",\n top: `calc(${paddingValue}px + 1px + ${config.indicator.split(\" \")[1].replace(\"h-\", \"\")} * 0.125rem - ${config.connectorThickness} / 2)`,\n height: config.connectorThickness,\n }),\n }}\n >\n {/* Animated fill connector */}\n {animated ? (\n <motion.div\n className=\"absolute top-0 left-0 bg-accent rounded-full\"\n initial={{ [isVertical ? \"height\" : \"width\"]: 0 }}\n animate={{\n [isVertical ? \"height\" : \"width\"]:\n `${steps.length > 1 ? (Math.min(currentStep, steps.length - 1) / (steps.length - 1)) * 100 : 0}%`,\n }}\n transition={{ duration: 0.4, ease: \"easeOut\" }}\n style={{\n ...(isVertical ? { width: \"100%\" } : { height: \"100%\" }),\n backgroundColor: colors?.connector || colors?.completed,\n }}\n />\n ) : (\n <div\n className=\"absolute top-0 left-0 bg-accent rounded-full\"\n style={{\n ...(isVertical\n ? {\n width: \"100%\",\n height: `${steps.length > 1 ? (Math.min(currentStep, steps.length - 1) / (steps.length - 1)) * 100 : 0}%`,\n }\n : {\n height: \"100%\",\n width: `${steps.length > 1 ? (Math.min(currentStep, steps.length - 1) / (steps.length - 1)) * 100 : 0}%`,\n }),\n backgroundColor: colors?.connector || colors?.completed,\n }}\n />\n )}\n </div>\n );\n })()}\n\n {steps.map((step, index) => {\n const status = getStepStatus(index);\n const isLast = index === steps.length - 1;\n const isClickable = clickable && !step.disabled; // Keep steps clickable unconditionally for navigation\n const paddingValue =\n variant === \"glass\" || variant === \"outlined\" || variant === \"minimal\"\n ? 4\n : 2;\n\n return (\n <div\n key={step.id}\n className={mergeClassNames(\n \"relative z-10\",\n isVertical\n ? \"flex gap-4 pb-8\" // spacing between vertical elements\n : \"flex flex-1 flex-col items-center\",\n !isLast && isVertical && \"mb-2\",\n isVertical && isLast && \"pb-0\",\n stepClassName,\n )}\n style={{\n // Ensure perfect horizontal distribution\n ...(!isVertical\n ? {\n flexBasis: 0,\n flexGrow: 1,\n // Keep first item aligned left, last aligned right, others centered\n alignItems:\n index === 0\n ? \"flex-start\"\n : isLast\n ? \"flex-end\"\n : \"center\",\n }\n : {}),\n }}\n >\n {/* Step Indicator */}\n <button\n type=\"button\"\n onClick={() => handleStepClick(index)}\n disabled={!isClickable}\n className={mergeClassNames(\n \"relative z-10 shrink-0 flex items-center justify-center bg-white dark:bg-neutral-900 rounded-full\", // Mask background line\n isClickable ? \"cursor-pointer\" : \"cursor-default\",\n // Horizontal offset logic for end items to align with text\n !isVertical && index === 0 && \"mx-0\",\n !isVertical && isLast && \"mx-0\",\n )}\n style={{\n // Adjust the background masking size depending on variant so the line doesn't peek through the edges\n padding: `${paddingValue}px`,\n }}\n aria-current={status === \"current\" ? \"step\" : undefined}\n >\n <StepIndicator\n step={step}\n index={index}\n status={status}\n size={size}\n variant={variant}\n showNumbers={showNumbers}\n animated={animated}\n colors={colors}\n />\n </button>\n\n {/* Step text content */}\n <motion.div\n className={mergeClassNames(\n \"mt-2\",\n isVertical ? \"flex-1 pb-6\" : \"text-center px-2\",\n !isVertical && index === 0 && \"text-left px-0\",\n !isVertical && isLast && \"text-right px-0\",\n isVertical && isLast && \"pb-0\",\n )}\n style={isVertical ? { marginTop: \"-4px\" } : undefined}\n initial={animated ? { opacity: 0, y: 10 } : undefined}\n animate={animated ? { opacity: 1, y: 0 } : undefined}\n transition={{ delay: index * 0.1 }}\n >\n <p\n className={mergeClassNames(\n \"font-medium transition-colors duration-200\",\n config.text,\n status === \"current\"\n ? \"text-accent\"\n : status === \"completed\"\n ? \"text-neutral-700 dark:text-neutral-200\"\n : status === \"error\"\n ? \"text-red-500\"\n : \"text-neutral-500 dark:text-neutral-400\",\n )}\n >\n {step.title}\n {step.optional && (\n <span className=\"ml-1 text-neutral-400 dark:text-neutral-500 font-normal\">\n (Optional)\n </span>\n )}\n </p>\n {step.description && (\n <p\n className={mergeClassNames(\n \"mt-0.5 text-neutral-500 dark:text-neutral-400\",\n size === \"sm\" ? \"text-xs\" : \"text-xs\",\n )}\n >\n {step.description}\n </p>\n )}\n </motion.div>\n\n {/* Step content (for vertical with content) */}\n {isVertical && step.content && status === \"current\" && (\n <motion.div\n initial={{ opacity: 0, height: 0 }}\n animate={{ opacity: 1, height: \"auto\" }}\n exit={{ opacity: 0, height: 0 }}\n className=\"pl-14 pb-4 w-full\"\n >\n {step.content}\n </motion.div>\n )}\n </div>\n );\n })}\n </div>\n );\n};\n\nStepper.displayName = \"Stepper\";\n\nexport default Stepper;\n"],"mappings":"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"}
|