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,122 @@
|
|
|
1
|
+
import { t as useOverlayEffects } from "./overlay-TycCIFOu.mjs";
|
|
2
|
+
import { useEffect, useRef } from "react";
|
|
3
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
4
|
+
import { AnimatePresence, motion } from "framer-motion";
|
|
5
|
+
//#region src/components/overlays/drawer/Drawer.tsx
|
|
6
|
+
var basePanel = "relative flex flex-col overflow-hidden rounded-2xl border border-white/30 bg-gradient-to-br from-white/80 via-white/68 to-white/52 p-6 shadow-[0_24px_80px_rgba(15,23,42,0.22),0_8px_28px_rgba(15,23,42,0.14)] ring-1 ring-inset ring-white/25 backdrop-blur-2xl backdrop-saturate-150 dark:border-white/10 dark:from-neutral-950/84 dark:via-neutral-950/72 dark:to-neutral-900/58 dark:shadow-[0_28px_90px_rgba(0,0,0,0.52),0_10px_30px_rgba(0,0,0,0.3)] dark:ring-white/10";
|
|
7
|
+
var positionClasses = {
|
|
8
|
+
right: "h-[calc(100%-8px)] my-1 mr-1 w-full max-w-md ml-auto border",
|
|
9
|
+
left: "h-[calc(100%-8px)] my-1 ml-1 w-full max-w-md mr-auto border",
|
|
10
|
+
top: "w-[calc(100%-8px)] mx-1 mt-1 max-h-[80vh] border",
|
|
11
|
+
bottom: "w-[calc(100%-8px)] mx-1 mb-1 max-h-[80vh] mt-auto border"
|
|
12
|
+
};
|
|
13
|
+
var getVariants = (position) => {
|
|
14
|
+
switch (position) {
|
|
15
|
+
case "left": return {
|
|
16
|
+
hidden: { x: "-100%" },
|
|
17
|
+
visible: { x: 0 }
|
|
18
|
+
};
|
|
19
|
+
case "right": return {
|
|
20
|
+
hidden: { x: "100%" },
|
|
21
|
+
visible: { x: 0 }
|
|
22
|
+
};
|
|
23
|
+
case "top": return {
|
|
24
|
+
hidden: { y: "-100%" },
|
|
25
|
+
visible: { y: 0 }
|
|
26
|
+
};
|
|
27
|
+
case "bottom": return {
|
|
28
|
+
hidden: { y: "100%" },
|
|
29
|
+
visible: { y: 0 }
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
var Drawer = ({ open, onOpenChange, title, description, position = "right", children, footer }) => {
|
|
34
|
+
const panelRef = useRef(null);
|
|
35
|
+
useOverlayEffects(panelRef, open);
|
|
36
|
+
useEffect(() => {
|
|
37
|
+
if (!open || typeof window === "undefined") return;
|
|
38
|
+
const handleKey = (event) => {
|
|
39
|
+
if (event.key === "Escape") onOpenChange?.(false);
|
|
40
|
+
};
|
|
41
|
+
window.addEventListener("keydown", handleKey);
|
|
42
|
+
return () => window.removeEventListener("keydown", handleKey);
|
|
43
|
+
}, [open, onOpenChange]);
|
|
44
|
+
const variants = getVariants(position);
|
|
45
|
+
return /* @__PURE__ */ jsx(AnimatePresence, { children: open && /* @__PURE__ */ jsxs("div", {
|
|
46
|
+
className: "fixed inset-0 z-40 flex overlay-backdrop",
|
|
47
|
+
role: "presentation",
|
|
48
|
+
children: [/* @__PURE__ */ jsx(motion.div, {
|
|
49
|
+
initial: { opacity: 0 },
|
|
50
|
+
animate: { opacity: 1 },
|
|
51
|
+
exit: { opacity: 0 },
|
|
52
|
+
transition: { duration: .3 },
|
|
53
|
+
className: "fixed inset-0 bg-slate-950/24 backdrop-blur-[3px] dark:bg-black/44",
|
|
54
|
+
onClick: () => onOpenChange?.(false)
|
|
55
|
+
}), /* @__PURE__ */ jsxs(motion.div, {
|
|
56
|
+
role: "dialog",
|
|
57
|
+
"aria-modal": "true",
|
|
58
|
+
"aria-label": title,
|
|
59
|
+
className: `${basePanel} ${positionClasses[position]}`,
|
|
60
|
+
tabIndex: -1,
|
|
61
|
+
ref: panelRef,
|
|
62
|
+
onClick: (event) => event.stopPropagation(),
|
|
63
|
+
initial: "hidden",
|
|
64
|
+
animate: "visible",
|
|
65
|
+
exit: "hidden",
|
|
66
|
+
variants,
|
|
67
|
+
transition: {
|
|
68
|
+
type: "spring",
|
|
69
|
+
damping: 25,
|
|
70
|
+
stiffness: 200
|
|
71
|
+
},
|
|
72
|
+
children: [
|
|
73
|
+
/* @__PURE__ */ jsx("div", {
|
|
74
|
+
"aria-hidden": "true",
|
|
75
|
+
className: "pointer-events-none absolute inset-0 bg-linear-to-b from-white/30 via-white/10 to-transparent dark:from-white/10 dark:via-white/[0.03] dark:to-transparent"
|
|
76
|
+
}),
|
|
77
|
+
/* @__PURE__ */ jsx("div", {
|
|
78
|
+
"aria-hidden": "true",
|
|
79
|
+
className: "pointer-events-none absolute inset-x-0 top-0 h-24 bg-linear-to-b from-white/40 to-transparent dark:from-white/12"
|
|
80
|
+
}),
|
|
81
|
+
/* @__PURE__ */ jsx("div", {
|
|
82
|
+
"aria-hidden": "true",
|
|
83
|
+
className: "pointer-events-none absolute -right-10 top-[-72px] h-40 w-40 rounded-full bg-white/35 blur-3xl dark:bg-sky-200/10"
|
|
84
|
+
}),
|
|
85
|
+
/* @__PURE__ */ jsx("button", {
|
|
86
|
+
type: "button",
|
|
87
|
+
className: "absolute right-4 top-4 z-20 inline-flex h-9 w-9 items-center justify-center rounded-full border border-white/35 bg-white/45 text-lg font-light text-foreground shadow-sm backdrop-blur-md transition-all duration-200 hover:bg-white/72 dark:border-white/10 dark:bg-white/5 dark:hover:bg-white/10",
|
|
88
|
+
"aria-label": "Close drawer",
|
|
89
|
+
onClick: () => onOpenChange?.(false),
|
|
90
|
+
children: "×"
|
|
91
|
+
}),
|
|
92
|
+
/* @__PURE__ */ jsxs("div", {
|
|
93
|
+
className: "relative z-10 flex h-full flex-col",
|
|
94
|
+
children: [
|
|
95
|
+
(title || description) && /* @__PURE__ */ jsxs("header", {
|
|
96
|
+
className: "space-y-1 pr-10",
|
|
97
|
+
children: [title && /* @__PURE__ */ jsx("h2", {
|
|
98
|
+
className: "text-lg font-semibold tracking-tight text-foreground",
|
|
99
|
+
children: title
|
|
100
|
+
}), description && /* @__PURE__ */ jsx("p", {
|
|
101
|
+
className: "text-sm text-muted-foreground",
|
|
102
|
+
children: description
|
|
103
|
+
})]
|
|
104
|
+
}),
|
|
105
|
+
children && /* @__PURE__ */ jsx("div", {
|
|
106
|
+
className: "mt-4 flex-1 overflow-auto space-y-4 pr-1",
|
|
107
|
+
children
|
|
108
|
+
}),
|
|
109
|
+
footer && /* @__PURE__ */ jsx("footer", {
|
|
110
|
+
className: "mt-6 border-t border-white/20 pt-4 dark:border-white/10",
|
|
111
|
+
children: footer
|
|
112
|
+
})
|
|
113
|
+
]
|
|
114
|
+
})
|
|
115
|
+
]
|
|
116
|
+
})]
|
|
117
|
+
}) });
|
|
118
|
+
};
|
|
119
|
+
//#endregion
|
|
120
|
+
export { Drawer as t };
|
|
121
|
+
|
|
122
|
+
//# sourceMappingURL=drawer-D82Jz6KO.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"drawer-D82Jz6KO.mjs","names":[],"sources":["../../src/components/overlays/drawer/Drawer.tsx"],"sourcesContent":["import { useEffect, useRef } from \"react\";\nimport { motion, AnimatePresence } from \"framer-motion\";\nimport type { DrawerProps, DrawerPosition } from \"./types\";\nimport { useOverlayEffects } from \"../../shared/overlay\";\n\nconst basePanel =\n \"relative flex flex-col overflow-hidden rounded-2xl border border-white/30 bg-gradient-to-br from-white/80 via-white/68 to-white/52 p-6 shadow-[0_24px_80px_rgba(15,23,42,0.22),0_8px_28px_rgba(15,23,42,0.14)] ring-1 ring-inset ring-white/25 backdrop-blur-2xl backdrop-saturate-150 dark:border-white/10 dark:from-neutral-950/84 dark:via-neutral-950/72 dark:to-neutral-900/58 dark:shadow-[0_28px_90px_rgba(0,0,0,0.52),0_10px_30px_rgba(0,0,0,0.3)] dark:ring-white/10\";\n\nconst positionClasses: Record<DrawerPosition, string> = {\n right: \"h-[calc(100%-8px)] my-1 mr-1 w-full max-w-md ml-auto border\",\n left: \"h-[calc(100%-8px)] my-1 ml-1 w-full max-w-md mr-auto border\",\n top: \"w-[calc(100%-8px)] mx-1 mt-1 max-h-[80vh] border\",\n bottom: \"w-[calc(100%-8px)] mx-1 mb-1 max-h-[80vh] mt-auto border\",\n};\n\nconst getVariants = (position: DrawerPosition) => {\n switch (position) {\n case \"left\":\n return { hidden: { x: \"-100%\" }, visible: { x: 0 } };\n case \"right\":\n return { hidden: { x: \"100%\" }, visible: { x: 0 } };\n case \"top\":\n return { hidden: { y: \"-100%\" }, visible: { y: 0 } };\n case \"bottom\":\n return { hidden: { y: \"100%\" }, visible: { y: 0 } };\n }\n};\n\nexport const Drawer = ({\n open,\n onOpenChange,\n title,\n description,\n position = \"right\",\n children,\n footer,\n}: DrawerProps) => {\n const panelRef = useRef<HTMLDivElement | null>(null);\n useOverlayEffects(panelRef, open);\n\n useEffect(() => {\n if (!open || typeof window === \"undefined\") return;\n const handleKey = (event: KeyboardEvent) => {\n if (event.key === \"Escape\") {\n onOpenChange?.(false);\n }\n };\n window.addEventListener(\"keydown\", handleKey);\n return () => window.removeEventListener(\"keydown\", handleKey);\n }, [open, onOpenChange]);\n\n const variants = getVariants(position);\n\n return (\n <AnimatePresence>\n {open && (\n <div\n className=\"fixed inset-0 z-40 flex overlay-backdrop\"\n role=\"presentation\"\n >\n <motion.div\n initial={{ opacity: 0 }}\n animate={{ opacity: 1 }}\n exit={{ opacity: 0 }}\n transition={{ duration: 0.3 }}\n className=\"fixed inset-0 bg-slate-950/24 backdrop-blur-[3px] dark:bg-black/44\"\n onClick={() => onOpenChange?.(false)}\n />\n <motion.div\n role=\"dialog\"\n aria-modal=\"true\"\n aria-label={title}\n className={`${basePanel} ${positionClasses[position]}`}\n tabIndex={-1}\n ref={panelRef}\n onClick={(event) => event.stopPropagation()}\n initial=\"hidden\"\n animate=\"visible\"\n exit=\"hidden\"\n variants={variants}\n transition={{ type: \"spring\", damping: 25, stiffness: 200 }}\n >\n <div\n aria-hidden=\"true\"\n className=\"pointer-events-none absolute inset-0 bg-linear-to-b from-white/30 via-white/10 to-transparent dark:from-white/10 dark:via-white/[0.03] dark:to-transparent\"\n />\n <div\n aria-hidden=\"true\"\n className=\"pointer-events-none absolute inset-x-0 top-0 h-24 bg-linear-to-b from-white/40 to-transparent dark:from-white/12\"\n />\n <div\n aria-hidden=\"true\"\n className=\"pointer-events-none absolute -right-10 top-[-72px] h-40 w-40 rounded-full bg-white/35 blur-3xl dark:bg-sky-200/10\"\n />\n <button\n type=\"button\"\n className=\"absolute right-4 top-4 z-20 inline-flex h-9 w-9 items-center justify-center rounded-full border border-white/35 bg-white/45 text-lg font-light text-foreground shadow-sm backdrop-blur-md transition-all duration-200 hover:bg-white/72 dark:border-white/10 dark:bg-white/5 dark:hover:bg-white/10\"\n aria-label=\"Close drawer\"\n onClick={() => onOpenChange?.(false)}\n >\n ×\n </button>\n <div className=\"relative z-10 flex h-full flex-col\">\n {(title || description) && (\n <header className=\"space-y-1 pr-10\">\n {title && (\n <h2 className=\"text-lg font-semibold tracking-tight text-foreground\">\n {title}\n </h2>\n )}\n {description && (\n <p className=\"text-sm text-muted-foreground\">\n {description}\n </p>\n )}\n </header>\n )}\n {children && (\n <div className=\"mt-4 flex-1 overflow-auto space-y-4 pr-1\">\n {children}\n </div>\n )}\n {footer && (\n <footer className=\"mt-6 border-t border-white/20 pt-4 dark:border-white/10\">\n {footer}\n </footer>\n )}\n </div>\n </motion.div>\n </div>\n )}\n </AnimatePresence>\n );\n};\n"],"mappings":";;;;;AAKA,IAAM,YACJ;AAEF,IAAM,kBAAkD;CACtD,OAAO;CACP,MAAM;CACN,KAAK;CACL,QAAQ;CACT;AAED,IAAM,eAAe,aAA6B;AAChD,SAAQ,UAAR;EACE,KAAK,OACH,QAAO;GAAE,QAAQ,EAAE,GAAG,SAAS;GAAE,SAAS,EAAE,GAAG,GAAG;GAAE;EACtD,KAAK,QACH,QAAO;GAAE,QAAQ,EAAE,GAAG,QAAQ;GAAE,SAAS,EAAE,GAAG,GAAG;GAAE;EACrD,KAAK,MACH,QAAO;GAAE,QAAQ,EAAE,GAAG,SAAS;GAAE,SAAS,EAAE,GAAG,GAAG;GAAE;EACtD,KAAK,SACH,QAAO;GAAE,QAAQ,EAAE,GAAG,QAAQ;GAAE,SAAS,EAAE,GAAG,GAAG;GAAE;;;AAIzD,IAAa,UAAU,EACrB,MACA,cACA,OACA,aACA,WAAW,SACX,UACA,aACiB;CACjB,MAAM,WAAW,OAA8B,KAAK;AACpD,mBAAkB,UAAU,KAAK;AAEjC,iBAAgB;AACd,MAAI,CAAC,QAAQ,OAAO,WAAW,YAAa;EAC5C,MAAM,aAAa,UAAyB;AAC1C,OAAI,MAAM,QAAQ,SAChB,gBAAe,MAAM;;AAGzB,SAAO,iBAAiB,WAAW,UAAU;AAC7C,eAAa,OAAO,oBAAoB,WAAW,UAAU;IAC5D,CAAC,MAAM,aAAa,CAAC;CAExB,MAAM,WAAW,YAAY,SAAS;AAEtC,QACE,oBAAC,iBAAD,EAAA,UACG,QACC,qBAAC,OAAD;EACE,WAAU;EACV,MAAK;YAFP,CAIE,oBAAC,OAAO,KAAR;GACE,SAAS,EAAE,SAAS,GAAG;GACvB,SAAS,EAAE,SAAS,GAAG;GACvB,MAAM,EAAE,SAAS,GAAG;GACpB,YAAY,EAAE,UAAU,IAAK;GAC7B,WAAU;GACV,eAAe,eAAe,MAAM;GACpC,CAAA,EACF,qBAAC,OAAO,KAAR;GACE,MAAK;GACL,cAAW;GACX,cAAY;GACZ,WAAW,GAAG,UAAU,GAAG,gBAAgB;GAC3C,UAAU;GACV,KAAK;GACL,UAAU,UAAU,MAAM,iBAAiB;GAC3C,SAAQ;GACR,SAAQ;GACR,MAAK;GACK;GACV,YAAY;IAAE,MAAM;IAAU,SAAS;IAAI,WAAW;IAAK;aAZ7D;IAcE,oBAAC,OAAD;KACE,eAAY;KACZ,WAAU;KACV,CAAA;IACF,oBAAC,OAAD;KACE,eAAY;KACZ,WAAU;KACV,CAAA;IACF,oBAAC,OAAD;KACE,eAAY;KACZ,WAAU;KACV,CAAA;IACF,oBAAC,UAAD;KACE,MAAK;KACL,WAAU;KACV,cAAW;KACX,eAAe,eAAe,MAAM;eACrC;KAEQ,CAAA;IACT,qBAAC,OAAD;KAAK,WAAU;eAAf;OACI,SAAS,gBACT,qBAAC,UAAD;OAAQ,WAAU;iBAAlB,CACG,SACC,oBAAC,MAAD;QAAI,WAAU;kBACX;QACE,CAAA,EAEN,eACC,oBAAC,KAAD;QAAG,WAAU;kBACV;QACC,CAAA,CAEC;;MAEV,YACC,oBAAC,OAAD;OAAK,WAAU;OACZ;OACG,CAAA;MAEP,UACC,oBAAC,UAAD;OAAQ,WAAU;iBACf;OACM,CAAA;MAEP;;IACK;KACT;KAEQ,CAAA"}
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { Children, cloneElement, isValidElement, useId } from "react";
|
|
2
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
3
|
+
//#region src/components/forms/form/Form.tsx
|
|
4
|
+
var cx = (...classes) => classes.filter(Boolean).join(" ").replace(/\s+/g, " ").trim();
|
|
5
|
+
var gapClassMap = {
|
|
6
|
+
sm: "space-y-4",
|
|
7
|
+
md: "space-y-6",
|
|
8
|
+
lg: "space-y-8"
|
|
9
|
+
};
|
|
10
|
+
var sectionColumnsMap = {
|
|
11
|
+
1: "space-y-4",
|
|
12
|
+
2: "grid grid-cols-2 gap-4",
|
|
13
|
+
3: "grid grid-cols-3 gap-4"
|
|
14
|
+
};
|
|
15
|
+
var inputGroupMap = {
|
|
16
|
+
1: "grid-cols-1",
|
|
17
|
+
2: "grid-cols-2",
|
|
18
|
+
3: "grid-cols-3",
|
|
19
|
+
4: "grid-cols-4"
|
|
20
|
+
};
|
|
21
|
+
var actionsAlignMap = {
|
|
22
|
+
start: "justify-start",
|
|
23
|
+
center: "justify-center",
|
|
24
|
+
end: "justify-end",
|
|
25
|
+
between: "justify-between"
|
|
26
|
+
};
|
|
27
|
+
var messageIntentMap = {
|
|
28
|
+
default: "text-neutral-500 dark:text-neutral-400",
|
|
29
|
+
error: "text-destructive",
|
|
30
|
+
success: "text-success"
|
|
31
|
+
};
|
|
32
|
+
var sanitizeId = (value) => value.replace(/[^a-zA-Z0-9_-]/g, "-");
|
|
33
|
+
var Form = ({ title, description, gap = "lg", children, className = "", ...props }) => {
|
|
34
|
+
return /* @__PURE__ */ jsxs("form", {
|
|
35
|
+
className: cx("w-full space-y-6 rounded-lg border border-neutral-200 dark:border-neutral-700 bg-white dark:bg-neutral-800 p-6", className),
|
|
36
|
+
...props,
|
|
37
|
+
children: [(title || description) && /* @__PURE__ */ jsxs("div", {
|
|
38
|
+
className: "space-y-2",
|
|
39
|
+
children: [title && /* @__PURE__ */ jsx("h2", {
|
|
40
|
+
className: "text-xl font-semibold text-neutral-900 dark:text-white",
|
|
41
|
+
children: title
|
|
42
|
+
}), description && /* @__PURE__ */ jsx("p", {
|
|
43
|
+
className: "text-sm text-neutral-500 dark:text-neutral-400",
|
|
44
|
+
children: description
|
|
45
|
+
})]
|
|
46
|
+
}), /* @__PURE__ */ jsx("div", {
|
|
47
|
+
className: gapClassMap[gap],
|
|
48
|
+
children
|
|
49
|
+
})]
|
|
50
|
+
});
|
|
51
|
+
};
|
|
52
|
+
var FormSection = ({ title, description, columns = 1, children, className = "" }) => {
|
|
53
|
+
return /* @__PURE__ */ jsxs("section", {
|
|
54
|
+
className: cx("space-y-4", className),
|
|
55
|
+
children: [(title || description) && /* @__PURE__ */ jsxs("header", {
|
|
56
|
+
className: "space-y-1",
|
|
57
|
+
children: [title && /* @__PURE__ */ jsx("h3", {
|
|
58
|
+
className: "text-base font-medium text-neutral-900 dark:text-white",
|
|
59
|
+
children: title
|
|
60
|
+
}), description && /* @__PURE__ */ jsx("p", {
|
|
61
|
+
className: "text-sm text-neutral-500 dark:text-neutral-400",
|
|
62
|
+
children: description
|
|
63
|
+
})]
|
|
64
|
+
}), /* @__PURE__ */ jsx("div", {
|
|
65
|
+
className: sectionColumnsMap[columns] || sectionColumnsMap[1],
|
|
66
|
+
children
|
|
67
|
+
})]
|
|
68
|
+
});
|
|
69
|
+
};
|
|
70
|
+
var FormDescription = ({ children, className = "", id }) => /* @__PURE__ */ jsx("p", {
|
|
71
|
+
id,
|
|
72
|
+
className: cx("text-sm text-neutral-500 dark:text-neutral-400", className),
|
|
73
|
+
children
|
|
74
|
+
});
|
|
75
|
+
var FormMessage = ({ children, intent = "default", className = "", id }) => /* @__PURE__ */ jsx("p", {
|
|
76
|
+
id,
|
|
77
|
+
role: intent === "error" ? "alert" : "status",
|
|
78
|
+
className: cx("text-sm", messageIntentMap[intent], className),
|
|
79
|
+
children
|
|
80
|
+
});
|
|
81
|
+
var FormField = ({ label, description, error, required, htmlFor, helperAction, layout = "stacked", children, className = "" }) => {
|
|
82
|
+
const autoId = useId();
|
|
83
|
+
const fieldId = sanitizeId(htmlFor ?? autoId);
|
|
84
|
+
const descriptionId = description ? `${fieldId}-description` : void 0;
|
|
85
|
+
const errorId = error ? `${fieldId}-error` : void 0;
|
|
86
|
+
const controls = Children.map(children, (child) => {
|
|
87
|
+
if (!isValidElement(child)) return child;
|
|
88
|
+
const element = child;
|
|
89
|
+
const describedBy = [
|
|
90
|
+
element.props?.["aria-describedby"],
|
|
91
|
+
descriptionId,
|
|
92
|
+
errorId
|
|
93
|
+
].filter(Boolean).join(" ").trim();
|
|
94
|
+
return cloneElement(element, {
|
|
95
|
+
id: element.props?.id ?? fieldId,
|
|
96
|
+
"aria-describedby": describedBy || void 0,
|
|
97
|
+
"aria-invalid": element.props?.["aria-invalid"] ?? Boolean(error)
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
const labelNode = /* @__PURE__ */ jsxs("div", {
|
|
101
|
+
className: "flex items-center justify-between gap-2",
|
|
102
|
+
children: [/* @__PURE__ */ jsxs("label", {
|
|
103
|
+
htmlFor: fieldId,
|
|
104
|
+
className: "text-sm font-medium text-neutral-900 dark:text-white",
|
|
105
|
+
children: [label, required && /* @__PURE__ */ jsx("span", {
|
|
106
|
+
className: "ml-1 text-destructive",
|
|
107
|
+
children: "*"
|
|
108
|
+
})]
|
|
109
|
+
}), helperAction && /* @__PURE__ */ jsx("div", {
|
|
110
|
+
className: "text-xs text-neutral-500 dark:text-neutral-400",
|
|
111
|
+
children: helperAction
|
|
112
|
+
})]
|
|
113
|
+
});
|
|
114
|
+
if (layout === "inline") return /* @__PURE__ */ jsxs("div", {
|
|
115
|
+
className: cx("flex flex-wrap items-start gap-6", className),
|
|
116
|
+
children: [/* @__PURE__ */ jsxs("div", {
|
|
117
|
+
className: "min-w-[200px] space-y-1",
|
|
118
|
+
children: [labelNode, description && /* @__PURE__ */ jsx(FormDescription, {
|
|
119
|
+
id: descriptionId,
|
|
120
|
+
children: description
|
|
121
|
+
})]
|
|
122
|
+
}), /* @__PURE__ */ jsxs("div", {
|
|
123
|
+
className: "flex-1 space-y-2",
|
|
124
|
+
children: [controls, error && /* @__PURE__ */ jsx(FormMessage, {
|
|
125
|
+
id: errorId,
|
|
126
|
+
intent: "error",
|
|
127
|
+
children: error
|
|
128
|
+
})]
|
|
129
|
+
})]
|
|
130
|
+
});
|
|
131
|
+
return /* @__PURE__ */ jsxs("div", {
|
|
132
|
+
className: cx("space-y-2", className),
|
|
133
|
+
children: [
|
|
134
|
+
labelNode,
|
|
135
|
+
description && /* @__PURE__ */ jsx(FormDescription, {
|
|
136
|
+
id: descriptionId,
|
|
137
|
+
children: description
|
|
138
|
+
}),
|
|
139
|
+
/* @__PURE__ */ jsxs("div", {
|
|
140
|
+
className: "space-y-2",
|
|
141
|
+
children: [controls, error && /* @__PURE__ */ jsx(FormMessage, {
|
|
142
|
+
id: errorId,
|
|
143
|
+
intent: "error",
|
|
144
|
+
children: error
|
|
145
|
+
})]
|
|
146
|
+
})
|
|
147
|
+
]
|
|
148
|
+
});
|
|
149
|
+
};
|
|
150
|
+
var FormActions = ({ children, align = "end", className = "" }) => /* @__PURE__ */ jsx("div", {
|
|
151
|
+
className: cx("flex flex-wrap gap-3", actionsAlignMap[align], className),
|
|
152
|
+
children
|
|
153
|
+
});
|
|
154
|
+
var InputGroup = ({ columns = 2, children, className = "" }) => /* @__PURE__ */ jsx("div", {
|
|
155
|
+
className: cx("grid gap-4", inputGroupMap[columns], className),
|
|
156
|
+
children
|
|
157
|
+
});
|
|
158
|
+
//#endregion
|
|
159
|
+
export { FormMessage as a, FormField as i, FormActions as n, FormSection as o, FormDescription as r, InputGroup as s, Form as t };
|
|
160
|
+
|
|
161
|
+
//# sourceMappingURL=form-B2vcaHwh.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"form-B2vcaHwh.mjs","names":[],"sources":["../../src/components/forms/form/Form.tsx"],"sourcesContent":["import { Children, cloneElement, isValidElement, useId } from \"react\";\nimport type { ReactElement } from \"react\";\n\nimport type {\n FormProps,\n FormSectionProps,\n FormFieldProps,\n FormActionsProps,\n InputGroupProps,\n FormDescriptionProps,\n FormMessageProps,\n} from \"./types\";\n\nconst cx = (...classes: Array<string | false | undefined>) =>\n classes.filter(Boolean).join(\" \").replace(/\\s+/g, \" \").trim();\n\nconst gapClassMap: Record<NonNullable<FormProps[\"gap\"]>, string> = {\n sm: \"space-y-4\",\n md: \"space-y-6\",\n lg: \"space-y-8\",\n};\n\nconst sectionColumnsMap: Record<\n NonNullable<FormSectionProps[\"columns\"]>,\n string\n> = {\n 1: \"space-y-4\",\n 2: \"grid grid-cols-2 gap-4\",\n 3: \"grid grid-cols-3 gap-4\",\n};\n\nconst inputGroupMap: Record<NonNullable<InputGroupProps[\"columns\"]>, string> = {\n 1: \"grid-cols-1\",\n 2: \"grid-cols-2\",\n 3: \"grid-cols-3\",\n 4: \"grid-cols-4\",\n};\n\nconst actionsAlignMap: Record<\n NonNullable<FormActionsProps[\"align\"]>,\n string\n> = {\n start: \"justify-start\",\n center: \"justify-center\",\n end: \"justify-end\",\n between: \"justify-between\",\n};\n\nconst messageIntentMap: Record<\n NonNullable<FormMessageProps[\"intent\"]>,\n string\n> = {\n default: \"text-neutral-500 dark:text-neutral-400\",\n error: \"text-destructive\",\n success: \"text-success\",\n};\n\nconst sanitizeId = (value: string) => value.replace(/[^a-zA-Z0-9_-]/g, \"-\");\n\nexport const Form = ({\n title,\n description,\n gap = \"lg\",\n children,\n className = \"\",\n ...props\n}: FormProps) => {\n return (\n <form\n className={cx(\n \"w-full space-y-6 rounded-lg border border-neutral-200 dark:border-neutral-700 bg-white dark:bg-neutral-800 p-6\",\n className,\n )}\n {...props}\n >\n {(title || description) && (\n <div className=\"space-y-2\">\n {title && (\n <h2 className=\"text-xl font-semibold text-neutral-900 dark:text-white\">\n {title}\n </h2>\n )}\n {description && (\n <p className=\"text-sm text-neutral-500 dark:text-neutral-400\">\n {description}\n </p>\n )}\n </div>\n )}\n <div className={gapClassMap[gap]}>{children}</div>\n </form>\n );\n};\n\nexport const FormSection = ({\n title,\n description,\n columns = 1,\n children,\n className = \"\",\n}: FormSectionProps) => {\n return (\n <section className={cx(\"space-y-4\", className)}>\n {(title || description) && (\n <header className=\"space-y-1\">\n {title && (\n <h3 className=\"text-base font-medium text-neutral-900 dark:text-white\">\n {title}\n </h3>\n )}\n {description && (\n <p className=\"text-sm text-neutral-500 dark:text-neutral-400\">\n {description}\n </p>\n )}\n </header>\n )}\n <div className={sectionColumnsMap[columns] || sectionColumnsMap[1]}>\n {children}\n </div>\n </section>\n );\n};\n\nexport const FormDescription = ({\n children,\n className = \"\",\n id,\n}: FormDescriptionProps) => (\n <p\n id={id}\n className={cx(\"text-sm text-neutral-500 dark:text-neutral-400\", className)}\n >\n {children}\n </p>\n);\n\nexport const FormMessage = ({\n children,\n intent = \"default\",\n className = \"\",\n id,\n}: FormMessageProps) => (\n <p\n id={id}\n role={intent === \"error\" ? \"alert\" : \"status\"}\n className={cx(\"text-sm\", messageIntentMap[intent], className)}\n >\n {children}\n </p>\n);\n\nexport const FormField = ({\n label,\n description,\n error,\n required,\n htmlFor,\n helperAction,\n layout = \"stacked\",\n children,\n className = \"\",\n}: FormFieldProps) => {\n const autoId = useId();\n const fieldId = sanitizeId(htmlFor ?? autoId);\n const descriptionId = description ? `${fieldId}-description` : undefined;\n const errorId = error ? `${fieldId}-error` : undefined;\n\n const controls = Children.map(children, (child) => {\n if (!isValidElement(child)) {\n return child;\n }\n\n const element = child as ReactElement<Record<string, unknown>>;\n const currentDescribedBy = element.props?.[\"aria-describedby\"] as\n | string\n | undefined;\n const describedBy = [currentDescribedBy, descriptionId, errorId]\n .filter(Boolean)\n .join(\" \")\n .trim();\n\n return cloneElement(element, {\n id: element.props?.id ?? fieldId,\n \"aria-describedby\": describedBy || undefined,\n \"aria-invalid\": element.props?.[\"aria-invalid\"] ?? Boolean(error),\n });\n });\n\n const labelNode = (\n <div className=\"flex items-center justify-between gap-2\">\n <label\n htmlFor={fieldId}\n className=\"text-sm font-medium text-neutral-900 dark:text-white\"\n >\n {label}\n {required && <span className=\"ml-1 text-destructive\">*</span>}\n </label>\n {helperAction && (\n <div className=\"text-xs text-neutral-500 dark:text-neutral-400\">\n {helperAction}\n </div>\n )}\n </div>\n );\n\n if (layout === \"inline\") {\n return (\n <div className={cx(\"flex flex-wrap items-start gap-6\", className)}>\n <div className=\"min-w-[200px] space-y-1\">\n {labelNode}\n {description && (\n <FormDescription id={descriptionId}>{description}</FormDescription>\n )}\n </div>\n <div className=\"flex-1 space-y-2\">\n {controls}\n {error && (\n <FormMessage id={errorId} intent=\"error\">\n {error}\n </FormMessage>\n )}\n </div>\n </div>\n );\n }\n\n return (\n <div className={cx(\"space-y-2\", className)}>\n {labelNode}\n {description && (\n <FormDescription id={descriptionId}>{description}</FormDescription>\n )}\n <div className=\"space-y-2\">\n {controls}\n {error && (\n <FormMessage id={errorId} intent=\"error\">\n {error}\n </FormMessage>\n )}\n </div>\n </div>\n );\n};\n\nexport const FormActions = ({\n children,\n align = \"end\",\n className = \"\",\n}: FormActionsProps) => (\n <div\n className={cx(\"flex flex-wrap gap-3\", actionsAlignMap[align], className)}\n >\n {children}\n </div>\n);\n\nexport const InputGroup = ({\n columns = 2,\n children,\n className = \"\",\n}: InputGroupProps) => (\n <div className={cx(\"grid gap-4\", inputGroupMap[columns], className)}>\n {children}\n </div>\n);\n"],"mappings":"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"}
|
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
require("./chunk-B_GkZjkl.cjs");
|
|
2
|
+
let react = require("react");
|
|
3
|
+
let react_jsx_runtime = require("react/jsx-runtime");
|
|
4
|
+
//#region src/components/forms/form/Form.tsx
|
|
5
|
+
var cx = (...classes) => classes.filter(Boolean).join(" ").replace(/\s+/g, " ").trim();
|
|
6
|
+
var gapClassMap = {
|
|
7
|
+
sm: "space-y-4",
|
|
8
|
+
md: "space-y-6",
|
|
9
|
+
lg: "space-y-8"
|
|
10
|
+
};
|
|
11
|
+
var sectionColumnsMap = {
|
|
12
|
+
1: "space-y-4",
|
|
13
|
+
2: "grid grid-cols-2 gap-4",
|
|
14
|
+
3: "grid grid-cols-3 gap-4"
|
|
15
|
+
};
|
|
16
|
+
var inputGroupMap = {
|
|
17
|
+
1: "grid-cols-1",
|
|
18
|
+
2: "grid-cols-2",
|
|
19
|
+
3: "grid-cols-3",
|
|
20
|
+
4: "grid-cols-4"
|
|
21
|
+
};
|
|
22
|
+
var actionsAlignMap = {
|
|
23
|
+
start: "justify-start",
|
|
24
|
+
center: "justify-center",
|
|
25
|
+
end: "justify-end",
|
|
26
|
+
between: "justify-between"
|
|
27
|
+
};
|
|
28
|
+
var messageIntentMap = {
|
|
29
|
+
default: "text-neutral-500 dark:text-neutral-400",
|
|
30
|
+
error: "text-destructive",
|
|
31
|
+
success: "text-success"
|
|
32
|
+
};
|
|
33
|
+
var sanitizeId = (value) => value.replace(/[^a-zA-Z0-9_-]/g, "-");
|
|
34
|
+
var Form = ({ title, description, gap = "lg", children, className = "", ...props }) => {
|
|
35
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("form", {
|
|
36
|
+
className: cx("w-full space-y-6 rounded-lg border border-neutral-200 dark:border-neutral-700 bg-white dark:bg-neutral-800 p-6", className),
|
|
37
|
+
...props,
|
|
38
|
+
children: [(title || description) && /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
39
|
+
className: "space-y-2",
|
|
40
|
+
children: [title && /* @__PURE__ */ (0, react_jsx_runtime.jsx)("h2", {
|
|
41
|
+
className: "text-xl font-semibold text-neutral-900 dark:text-white",
|
|
42
|
+
children: title
|
|
43
|
+
}), description && /* @__PURE__ */ (0, react_jsx_runtime.jsx)("p", {
|
|
44
|
+
className: "text-sm text-neutral-500 dark:text-neutral-400",
|
|
45
|
+
children: description
|
|
46
|
+
})]
|
|
47
|
+
}), /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
|
|
48
|
+
className: gapClassMap[gap],
|
|
49
|
+
children
|
|
50
|
+
})]
|
|
51
|
+
});
|
|
52
|
+
};
|
|
53
|
+
var FormSection = ({ title, description, columns = 1, children, className = "" }) => {
|
|
54
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("section", {
|
|
55
|
+
className: cx("space-y-4", className),
|
|
56
|
+
children: [(title || description) && /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("header", {
|
|
57
|
+
className: "space-y-1",
|
|
58
|
+
children: [title && /* @__PURE__ */ (0, react_jsx_runtime.jsx)("h3", {
|
|
59
|
+
className: "text-base font-medium text-neutral-900 dark:text-white",
|
|
60
|
+
children: title
|
|
61
|
+
}), description && /* @__PURE__ */ (0, react_jsx_runtime.jsx)("p", {
|
|
62
|
+
className: "text-sm text-neutral-500 dark:text-neutral-400",
|
|
63
|
+
children: description
|
|
64
|
+
})]
|
|
65
|
+
}), /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
|
|
66
|
+
className: sectionColumnsMap[columns] || sectionColumnsMap[1],
|
|
67
|
+
children
|
|
68
|
+
})]
|
|
69
|
+
});
|
|
70
|
+
};
|
|
71
|
+
var FormDescription = ({ children, className = "", id }) => /* @__PURE__ */ (0, react_jsx_runtime.jsx)("p", {
|
|
72
|
+
id,
|
|
73
|
+
className: cx("text-sm text-neutral-500 dark:text-neutral-400", className),
|
|
74
|
+
children
|
|
75
|
+
});
|
|
76
|
+
var FormMessage = ({ children, intent = "default", className = "", id }) => /* @__PURE__ */ (0, react_jsx_runtime.jsx)("p", {
|
|
77
|
+
id,
|
|
78
|
+
role: intent === "error" ? "alert" : "status",
|
|
79
|
+
className: cx("text-sm", messageIntentMap[intent], className),
|
|
80
|
+
children
|
|
81
|
+
});
|
|
82
|
+
var FormField = ({ label, description, error, required, htmlFor, helperAction, layout = "stacked", children, className = "" }) => {
|
|
83
|
+
const autoId = (0, react.useId)();
|
|
84
|
+
const fieldId = sanitizeId(htmlFor ?? autoId);
|
|
85
|
+
const descriptionId = description ? `${fieldId}-description` : void 0;
|
|
86
|
+
const errorId = error ? `${fieldId}-error` : void 0;
|
|
87
|
+
const controls = react.Children.map(children, (child) => {
|
|
88
|
+
if (!(0, react.isValidElement)(child)) return child;
|
|
89
|
+
const element = child;
|
|
90
|
+
const describedBy = [
|
|
91
|
+
element.props?.["aria-describedby"],
|
|
92
|
+
descriptionId,
|
|
93
|
+
errorId
|
|
94
|
+
].filter(Boolean).join(" ").trim();
|
|
95
|
+
return (0, react.cloneElement)(element, {
|
|
96
|
+
id: element.props?.id ?? fieldId,
|
|
97
|
+
"aria-describedby": describedBy || void 0,
|
|
98
|
+
"aria-invalid": element.props?.["aria-invalid"] ?? Boolean(error)
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
const labelNode = /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
102
|
+
className: "flex items-center justify-between gap-2",
|
|
103
|
+
children: [/* @__PURE__ */ (0, react_jsx_runtime.jsxs)("label", {
|
|
104
|
+
htmlFor: fieldId,
|
|
105
|
+
className: "text-sm font-medium text-neutral-900 dark:text-white",
|
|
106
|
+
children: [label, required && /* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
|
|
107
|
+
className: "ml-1 text-destructive",
|
|
108
|
+
children: "*"
|
|
109
|
+
})]
|
|
110
|
+
}), helperAction && /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
|
|
111
|
+
className: "text-xs text-neutral-500 dark:text-neutral-400",
|
|
112
|
+
children: helperAction
|
|
113
|
+
})]
|
|
114
|
+
});
|
|
115
|
+
if (layout === "inline") return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
116
|
+
className: cx("flex flex-wrap items-start gap-6", className),
|
|
117
|
+
children: [/* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
118
|
+
className: "min-w-[200px] space-y-1",
|
|
119
|
+
children: [labelNode, description && /* @__PURE__ */ (0, react_jsx_runtime.jsx)(FormDescription, {
|
|
120
|
+
id: descriptionId,
|
|
121
|
+
children: description
|
|
122
|
+
})]
|
|
123
|
+
}), /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
124
|
+
className: "flex-1 space-y-2",
|
|
125
|
+
children: [controls, error && /* @__PURE__ */ (0, react_jsx_runtime.jsx)(FormMessage, {
|
|
126
|
+
id: errorId,
|
|
127
|
+
intent: "error",
|
|
128
|
+
children: error
|
|
129
|
+
})]
|
|
130
|
+
})]
|
|
131
|
+
});
|
|
132
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
133
|
+
className: cx("space-y-2", className),
|
|
134
|
+
children: [
|
|
135
|
+
labelNode,
|
|
136
|
+
description && /* @__PURE__ */ (0, react_jsx_runtime.jsx)(FormDescription, {
|
|
137
|
+
id: descriptionId,
|
|
138
|
+
children: description
|
|
139
|
+
}),
|
|
140
|
+
/* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
141
|
+
className: "space-y-2",
|
|
142
|
+
children: [controls, error && /* @__PURE__ */ (0, react_jsx_runtime.jsx)(FormMessage, {
|
|
143
|
+
id: errorId,
|
|
144
|
+
intent: "error",
|
|
145
|
+
children: error
|
|
146
|
+
})]
|
|
147
|
+
})
|
|
148
|
+
]
|
|
149
|
+
});
|
|
150
|
+
};
|
|
151
|
+
var FormActions = ({ children, align = "end", className = "" }) => /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
|
|
152
|
+
className: cx("flex flex-wrap gap-3", actionsAlignMap[align], className),
|
|
153
|
+
children
|
|
154
|
+
});
|
|
155
|
+
var InputGroup = ({ columns = 2, children, className = "" }) => /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
|
|
156
|
+
className: cx("grid gap-4", inputGroupMap[columns], className),
|
|
157
|
+
children
|
|
158
|
+
});
|
|
159
|
+
//#endregion
|
|
160
|
+
Object.defineProperty(exports, "Form", {
|
|
161
|
+
enumerable: true,
|
|
162
|
+
get: function() {
|
|
163
|
+
return Form;
|
|
164
|
+
}
|
|
165
|
+
});
|
|
166
|
+
Object.defineProperty(exports, "FormActions", {
|
|
167
|
+
enumerable: true,
|
|
168
|
+
get: function() {
|
|
169
|
+
return FormActions;
|
|
170
|
+
}
|
|
171
|
+
});
|
|
172
|
+
Object.defineProperty(exports, "FormDescription", {
|
|
173
|
+
enumerable: true,
|
|
174
|
+
get: function() {
|
|
175
|
+
return FormDescription;
|
|
176
|
+
}
|
|
177
|
+
});
|
|
178
|
+
Object.defineProperty(exports, "FormField", {
|
|
179
|
+
enumerable: true,
|
|
180
|
+
get: function() {
|
|
181
|
+
return FormField;
|
|
182
|
+
}
|
|
183
|
+
});
|
|
184
|
+
Object.defineProperty(exports, "FormMessage", {
|
|
185
|
+
enumerable: true,
|
|
186
|
+
get: function() {
|
|
187
|
+
return FormMessage;
|
|
188
|
+
}
|
|
189
|
+
});
|
|
190
|
+
Object.defineProperty(exports, "FormSection", {
|
|
191
|
+
enumerable: true,
|
|
192
|
+
get: function() {
|
|
193
|
+
return FormSection;
|
|
194
|
+
}
|
|
195
|
+
});
|
|
196
|
+
Object.defineProperty(exports, "InputGroup", {
|
|
197
|
+
enumerable: true,
|
|
198
|
+
get: function() {
|
|
199
|
+
return InputGroup;
|
|
200
|
+
}
|
|
201
|
+
});
|
|
202
|
+
|
|
203
|
+
//# sourceMappingURL=form-CzH9GQc6.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"form-CzH9GQc6.cjs","names":[],"sources":["../../src/components/forms/form/Form.tsx"],"sourcesContent":["import { Children, cloneElement, isValidElement, useId } from \"react\";\nimport type { ReactElement } from \"react\";\n\nimport type {\n FormProps,\n FormSectionProps,\n FormFieldProps,\n FormActionsProps,\n InputGroupProps,\n FormDescriptionProps,\n FormMessageProps,\n} from \"./types\";\n\nconst cx = (...classes: Array<string | false | undefined>) =>\n classes.filter(Boolean).join(\" \").replace(/\\s+/g, \" \").trim();\n\nconst gapClassMap: Record<NonNullable<FormProps[\"gap\"]>, string> = {\n sm: \"space-y-4\",\n md: \"space-y-6\",\n lg: \"space-y-8\",\n};\n\nconst sectionColumnsMap: Record<\n NonNullable<FormSectionProps[\"columns\"]>,\n string\n> = {\n 1: \"space-y-4\",\n 2: \"grid grid-cols-2 gap-4\",\n 3: \"grid grid-cols-3 gap-4\",\n};\n\nconst inputGroupMap: Record<NonNullable<InputGroupProps[\"columns\"]>, string> = {\n 1: \"grid-cols-1\",\n 2: \"grid-cols-2\",\n 3: \"grid-cols-3\",\n 4: \"grid-cols-4\",\n};\n\nconst actionsAlignMap: Record<\n NonNullable<FormActionsProps[\"align\"]>,\n string\n> = {\n start: \"justify-start\",\n center: \"justify-center\",\n end: \"justify-end\",\n between: \"justify-between\",\n};\n\nconst messageIntentMap: Record<\n NonNullable<FormMessageProps[\"intent\"]>,\n string\n> = {\n default: \"text-neutral-500 dark:text-neutral-400\",\n error: \"text-destructive\",\n success: \"text-success\",\n};\n\nconst sanitizeId = (value: string) => value.replace(/[^a-zA-Z0-9_-]/g, \"-\");\n\nexport const Form = ({\n title,\n description,\n gap = \"lg\",\n children,\n className = \"\",\n ...props\n}: FormProps) => {\n return (\n <form\n className={cx(\n \"w-full space-y-6 rounded-lg border border-neutral-200 dark:border-neutral-700 bg-white dark:bg-neutral-800 p-6\",\n className,\n )}\n {...props}\n >\n {(title || description) && (\n <div className=\"space-y-2\">\n {title && (\n <h2 className=\"text-xl font-semibold text-neutral-900 dark:text-white\">\n {title}\n </h2>\n )}\n {description && (\n <p className=\"text-sm text-neutral-500 dark:text-neutral-400\">\n {description}\n </p>\n )}\n </div>\n )}\n <div className={gapClassMap[gap]}>{children}</div>\n </form>\n );\n};\n\nexport const FormSection = ({\n title,\n description,\n columns = 1,\n children,\n className = \"\",\n}: FormSectionProps) => {\n return (\n <section className={cx(\"space-y-4\", className)}>\n {(title || description) && (\n <header className=\"space-y-1\">\n {title && (\n <h3 className=\"text-base font-medium text-neutral-900 dark:text-white\">\n {title}\n </h3>\n )}\n {description && (\n <p className=\"text-sm text-neutral-500 dark:text-neutral-400\">\n {description}\n </p>\n )}\n </header>\n )}\n <div className={sectionColumnsMap[columns] || sectionColumnsMap[1]}>\n {children}\n </div>\n </section>\n );\n};\n\nexport const FormDescription = ({\n children,\n className = \"\",\n id,\n}: FormDescriptionProps) => (\n <p\n id={id}\n className={cx(\"text-sm text-neutral-500 dark:text-neutral-400\", className)}\n >\n {children}\n </p>\n);\n\nexport const FormMessage = ({\n children,\n intent = \"default\",\n className = \"\",\n id,\n}: FormMessageProps) => (\n <p\n id={id}\n role={intent === \"error\" ? \"alert\" : \"status\"}\n className={cx(\"text-sm\", messageIntentMap[intent], className)}\n >\n {children}\n </p>\n);\n\nexport const FormField = ({\n label,\n description,\n error,\n required,\n htmlFor,\n helperAction,\n layout = \"stacked\",\n children,\n className = \"\",\n}: FormFieldProps) => {\n const autoId = useId();\n const fieldId = sanitizeId(htmlFor ?? autoId);\n const descriptionId = description ? `${fieldId}-description` : undefined;\n const errorId = error ? `${fieldId}-error` : undefined;\n\n const controls = Children.map(children, (child) => {\n if (!isValidElement(child)) {\n return child;\n }\n\n const element = child as ReactElement<Record<string, unknown>>;\n const currentDescribedBy = element.props?.[\"aria-describedby\"] as\n | string\n | undefined;\n const describedBy = [currentDescribedBy, descriptionId, errorId]\n .filter(Boolean)\n .join(\" \")\n .trim();\n\n return cloneElement(element, {\n id: element.props?.id ?? fieldId,\n \"aria-describedby\": describedBy || undefined,\n \"aria-invalid\": element.props?.[\"aria-invalid\"] ?? Boolean(error),\n });\n });\n\n const labelNode = (\n <div className=\"flex items-center justify-between gap-2\">\n <label\n htmlFor={fieldId}\n className=\"text-sm font-medium text-neutral-900 dark:text-white\"\n >\n {label}\n {required && <span className=\"ml-1 text-destructive\">*</span>}\n </label>\n {helperAction && (\n <div className=\"text-xs text-neutral-500 dark:text-neutral-400\">\n {helperAction}\n </div>\n )}\n </div>\n );\n\n if (layout === \"inline\") {\n return (\n <div className={cx(\"flex flex-wrap items-start gap-6\", className)}>\n <div className=\"min-w-[200px] space-y-1\">\n {labelNode}\n {description && (\n <FormDescription id={descriptionId}>{description}</FormDescription>\n )}\n </div>\n <div className=\"flex-1 space-y-2\">\n {controls}\n {error && (\n <FormMessage id={errorId} intent=\"error\">\n {error}\n </FormMessage>\n )}\n </div>\n </div>\n );\n }\n\n return (\n <div className={cx(\"space-y-2\", className)}>\n {labelNode}\n {description && (\n <FormDescription id={descriptionId}>{description}</FormDescription>\n )}\n <div className=\"space-y-2\">\n {controls}\n {error && (\n <FormMessage id={errorId} intent=\"error\">\n {error}\n </FormMessage>\n )}\n </div>\n </div>\n );\n};\n\nexport const FormActions = ({\n children,\n align = \"end\",\n className = \"\",\n}: FormActionsProps) => (\n <div\n className={cx(\"flex flex-wrap gap-3\", actionsAlignMap[align], className)}\n >\n {children}\n </div>\n);\n\nexport const InputGroup = ({\n columns = 2,\n children,\n className = \"\",\n}: InputGroupProps) => (\n <div className={cx(\"grid gap-4\", inputGroupMap[columns], className)}>\n {children}\n </div>\n);\n"],"mappings":"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"}
|
|
@@ -0,0 +1,65 @@
|
|
|
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/gradual-blur/GradualBlur.tsx
|
|
7
|
+
var GradualBlur = ({ children, duration = .5, delay = 0, blur = 8, triggerOnView = true, triggerOnce = true, threshold = .05, visible = false, direction = "none", distance = 20, className, as = "div" }) => {
|
|
8
|
+
const ref = (0, react.useRef)(null);
|
|
9
|
+
const getInitialPosition = () => {
|
|
10
|
+
switch (direction) {
|
|
11
|
+
case "top": return { y: -distance };
|
|
12
|
+
case "bottom": return { y: distance };
|
|
13
|
+
case "left": return { x: -distance };
|
|
14
|
+
case "right": return { x: distance };
|
|
15
|
+
default: return {
|
|
16
|
+
x: 0,
|
|
17
|
+
y: 0
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
const initialPosition = getInitialPosition();
|
|
22
|
+
const variants = {
|
|
23
|
+
hidden: {
|
|
24
|
+
opacity: 0,
|
|
25
|
+
filter: `blur(${blur}px)`,
|
|
26
|
+
...initialPosition
|
|
27
|
+
},
|
|
28
|
+
visible: {
|
|
29
|
+
opacity: 1,
|
|
30
|
+
filter: "blur(0px)",
|
|
31
|
+
x: 0,
|
|
32
|
+
y: 0
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(framer_motion.motion.create(as), {
|
|
36
|
+
ref,
|
|
37
|
+
variants,
|
|
38
|
+
initial: "hidden",
|
|
39
|
+
animate: !triggerOnView ? visible ? "visible" : "hidden" : void 0,
|
|
40
|
+
whileInView: triggerOnView ? "visible" : void 0,
|
|
41
|
+
viewport: {
|
|
42
|
+
once: triggerOnce,
|
|
43
|
+
amount: threshold,
|
|
44
|
+
margin: "0px 0px -50px 0px"
|
|
45
|
+
},
|
|
46
|
+
transition: {
|
|
47
|
+
duration,
|
|
48
|
+
delay,
|
|
49
|
+
ease: "easeOut",
|
|
50
|
+
filter: { duration },
|
|
51
|
+
opacity: { duration }
|
|
52
|
+
},
|
|
53
|
+
className: require_utils.mergeClassNames("relative", className),
|
|
54
|
+
children
|
|
55
|
+
});
|
|
56
|
+
};
|
|
57
|
+
//#endregion
|
|
58
|
+
Object.defineProperty(exports, "GradualBlur", {
|
|
59
|
+
enumerable: true,
|
|
60
|
+
get: function() {
|
|
61
|
+
return GradualBlur;
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
//# sourceMappingURL=gradual-blur-B9GoY8o1.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gradual-blur-B9GoY8o1.cjs","names":[],"sources":["../../src/components/effects/gradual-blur/GradualBlur.tsx"],"sourcesContent":["import { useRef, type ComponentType } from \"react\";\nimport { motion, type HTMLMotionProps } from \"framer-motion\";\nimport { mergeClassNames } from \"../../../utils\";\nimport type { GradualBlurProps } from \"./types\";\n\nexport const GradualBlur = ({\n children,\n duration = 0.5,\n delay = 0,\n blur = 8,\n triggerOnView = true,\n triggerOnce = true,\n threshold = 0.05,\n visible = false,\n direction = \"none\",\n distance = 20,\n className,\n as = \"div\",\n}: GradualBlurProps) => {\n const ref = useRef<HTMLDivElement>(null);\n\n const getInitialPosition = () => {\n switch (direction) {\n case \"top\":\n return { y: -distance };\n case \"bottom\":\n return { y: distance };\n case \"left\":\n return { x: -distance };\n case \"right\":\n return { x: distance };\n default:\n return { x: 0, y: 0 };\n }\n };\n\n const initialPosition = getInitialPosition();\n\n const variants = {\n hidden: {\n opacity: 0,\n filter: `blur(${blur}px)`,\n ...initialPosition,\n },\n visible: {\n opacity: 1,\n filter: \"blur(0px)\",\n x: 0,\n y: 0,\n },\n };\n\n const MotionComponent = motion.create(as as string) as ComponentType<\n HTMLMotionProps<\"div\">\n >;\n\n return (\n <MotionComponent\n ref={ref}\n variants={variants}\n initial=\"hidden\"\n animate={!triggerOnView ? (visible ? \"visible\" : \"hidden\") : undefined}\n whileInView={triggerOnView ? \"visible\" : undefined}\n viewport={{\n once: triggerOnce,\n amount: threshold,\n margin: \"0px 0px -50px 0px\", // Slight bottom margin to trigger earlier\n }}\n transition={{\n duration,\n delay,\n ease: \"easeOut\",\n filter: { duration: duration },\n opacity: { duration: duration },\n }}\n className={mergeClassNames(\"relative\", className)}\n >\n {children}\n </MotionComponent>\n );\n};\n"],"mappings":";;;;;;AAKA,IAAa,eAAe,EAC1B,UACA,WAAW,IACX,QAAQ,GACR,OAAO,GACP,gBAAgB,MAChB,cAAc,MACd,YAAY,KACZ,UAAU,OACV,YAAY,QACZ,WAAW,IACX,WACA,KAAK,YACiB;CACtB,MAAM,OAAA,GAAA,MAAA,QAA6B,KAAK;CAExC,MAAM,2BAA2B;AAC/B,UAAQ,WAAR;GACE,KAAK,MACH,QAAO,EAAE,GAAG,CAAC,UAAU;GACzB,KAAK,SACH,QAAO,EAAE,GAAG,UAAU;GACxB,KAAK,OACH,QAAO,EAAE,GAAG,CAAC,UAAU;GACzB,KAAK,QACH,QAAO,EAAE,GAAG,UAAU;GACxB,QACE,QAAO;IAAE,GAAG;IAAG,GAAG;IAAG;;;CAI3B,MAAM,kBAAkB,oBAAoB;CAE5C,MAAM,WAAW;EACf,QAAQ;GACN,SAAS;GACT,QAAQ,QAAQ,KAAK;GACrB,GAAG;GACJ;EACD,SAAS;GACP,SAAS;GACT,QAAQ;GACR,GAAG;GACH,GAAG;GACJ;EACF;AAMD,QACE,iBAAA,GAAA,kBAAA,KALsB,cAAA,OAAO,OAAO,GAAa,EAKjD;EACO;EACK;EACV,SAAQ;EACR,SAAS,CAAC,gBAAiB,UAAU,YAAY,WAAY,KAAA;EAC7D,aAAa,gBAAgB,YAAY,KAAA;EACzC,UAAU;GACR,MAAM;GACN,QAAQ;GACR,QAAQ;GACT;EACD,YAAY;GACV;GACA;GACA,MAAM;GACN,QAAQ,EAAY,UAAU;GAC9B,SAAS,EAAY,UAAU;GAChC;EACD,WAAW,cAAA,gBAAgB,YAAY,UAAU;EAEhD;EACe,CAAA"}
|