@stfrigerio/sito-template 0.1.62 → 0.1.64
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/molecules/Tabs/Tabs.d.ts +2 -0
- package/dist/components/molecules/Tabs/Tabs.d.ts.map +1 -1
- package/dist/components/organisms/Calendar/Calendar.stories.d.ts +1 -0
- package/dist/components/organisms/Calendar/Calendar.stories.d.ts.map +1 -1
- package/dist/index.esm.js +3 -3
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +3 -3
- package/dist/index.js.map +1 -1
- package/dist/styles.css +1 -1
- package/dist/styles.css.map +1 -1
- package/package.json +1 -1
- package/storybook-static/assets/{ASCIIText.stories-DnfO7fez.js → ASCIIText.stories-D1Xf4qUP.js} +1 -1
- package/storybook-static/assets/{AllAtoms.stories-Ba6-Bol6.js → AllAtoms.stories-BWZpG8YP.js} +1 -1
- package/storybook-static/assets/{AnimatedContent.stories-DsDGVq-z.js → AnimatedContent.stories-JsJZW15E.js} +1 -1
- package/storybook-static/assets/{AnimatedList.stories-3AG8fvlU.js → AnimatedList.stories-CcfSw525.js} +1 -1
- package/storybook-static/assets/{Antigravity.stories-BEj0FFv9.js → Antigravity.stories-LGQb0uWU.js} +1 -1
- package/storybook-static/assets/{ArrayInput.stories-BPlQuZlG.js → ArrayInput.stories-C_NfcMRX.js} +1 -1
- package/storybook-static/assets/{Aurora.stories-DFqySZoR.js → Aurora.stories-CJaNMHWy.js} +1 -1
- package/storybook-static/assets/{Beams.stories-BlbivGGz.js → Beams.stories-DJBLky2z.js} +1 -1
- package/storybook-static/assets/{BlobCursor.stories-DhCLXdUz.js → BlobCursor.stories-D3s5SIIZ.js} +1 -1
- package/storybook-static/assets/{BlurText.stories-4eOzH8gv.js → BlurText.stories-Wa5QMu-F.js} +1 -1
- package/storybook-static/assets/{BooleansHeatmap.stories-BxuSyUnM.js → BooleansHeatmap.stories-DZUhByYN.js} +1 -1
- package/storybook-static/assets/{BorderGlow.stories-Ds8Hnghj.js → BorderGlow.stories-DC_aZNge.js} +1 -1
- package/storybook-static/assets/{BubbleMenu.stories-vvlhUjKe.js → BubbleMenu.stories-ByI_irJ5.js} +1 -1
- package/storybook-static/assets/{Button-DPHgFgB6.js → Button-ca-WP0WI.js} +1 -1
- package/storybook-static/assets/{Button.stories-D2y3JftI.js → Button.stories-B-RlJwIP.js} +1 -1
- package/storybook-static/assets/Calendar-CmqcM0p9.css +1 -0
- package/storybook-static/assets/Calendar.stories-BAC0V9U_.js +367 -0
- package/storybook-static/assets/{Card-DEC0GAaM.js → Card-zYnUu79L.js} +1 -1
- package/storybook-static/assets/{Card.stories-DHIM2UNi.js → Card.stories-D3nX7F1p.js} +1 -1
- package/storybook-static/assets/{CardNav.stories-BH31a-v8.js → CardNav.stories-DRFo00SW.js} +1 -1
- package/storybook-static/assets/{Carousel.stories-CCMyd0By.js → Carousel.stories-HbqEyU8u.js} +1 -1
- package/storybook-static/assets/{Checkbox-DbM_xHWZ.js → Checkbox-_QVpBl9h.js} +1 -1
- package/storybook-static/assets/{Checkbox.stories-Bv1qqmYX.js → Checkbox.stories-DBj6Gf_0.js} +1 -1
- package/storybook-static/assets/{ChromaGrid.stories-BHcwhoSD.js → ChromaGrid.stories-CEWWsyh9.js} +1 -1
- package/storybook-static/assets/{CircularGallery.stories-D0WnYo0x.js → CircularGallery.stories-C7Xyelp6.js} +1 -1
- package/storybook-static/assets/{CircularText.stories-N-fj9Dj9.js → CircularText.stories-BN4-zQYC.js} +1 -1
- package/storybook-static/assets/{ClickSpark.stories-CzYqvfBX.js → ClickSpark.stories-CgOAOvv1.js} +1 -1
- package/storybook-static/assets/{ColorBends.stories-f7hp2-11.js → ColorBends.stories-D3HYC9rL.js} +1 -1
- package/storybook-static/assets/{CountUp.stories-CGD8JtLI.js → CountUp.stories-tCzExq-Z.js} +1 -1
- package/storybook-static/assets/{Counter.stories-CfT1Nqlz.js → Counter.stories-zCflYapu.js} +1 -1
- package/storybook-static/assets/{Crosshair.stories-DeevB-57.js → Crosshair.stories-COhV5_Y7.js} +1 -1
- package/storybook-static/assets/{Cubes.stories-CQHIY01P.js → Cubes.stories-BtnbTbvB.js} +1 -1
- package/storybook-static/assets/{CurvedLoop.stories-Bn_7KGsS.js → CurvedLoop.stories-CJ5pLoIz.js} +1 -1
- package/storybook-static/assets/{DarkVeil.stories-DTSZr2hp.js → DarkVeil.stories-CK2esiiE.js} +1 -1
- package/storybook-static/assets/{DateInput-OxjUFqm9.js → DateInput-DO3zkLe0.js} +1 -1
- package/storybook-static/assets/{DateInput.stories-Sf1Aaitz.js → DateInput.stories-CxgW9cZx.js} +1 -1
- package/storybook-static/assets/{DecayCard.stories-DbiTiEkE.js → DecayCard.stories-UBtFVBLm.js} +1 -1
- package/storybook-static/assets/{DecryptedText.stories-DHJdAoTy.js → DecryptedText.stories-b4fTRSry.js} +1 -1
- package/storybook-static/assets/{Dither.stories-BtRWPhPm.js → Dither.stories-m9NAEf3T.js} +1 -1
- package/storybook-static/assets/{Dock.stories-DYFI1gE8.js → Dock.stories-I1MBrUpZ.js} +1 -1
- package/storybook-static/assets/{EditFAB.stories-dmRTA8hS.js → EditFAB.stories-BBvvPWME.js} +1 -1
- package/storybook-static/assets/{EvilEye.stories-DltHyYtJ.js → EvilEye.stories-C_IRHT0H.js} +1 -1
- package/storybook-static/assets/{FadeContent.stories-CFnIoL5L.js → FadeContent.stories-cA0ehF9u.js} +1 -1
- package/storybook-static/assets/{FaultyTerminal.stories-CxaAuDIK.js → FaultyTerminal.stories-BH17AZyd.js} +1 -1
- package/storybook-static/assets/{Fbo-woAXI7JG.js → Fbo-s3d9A5Ww.js} +1 -1
- package/storybook-static/assets/{FloatingLines.stories-dUO5RM_p.js → FloatingLines.stories-D08G-orK.js} +1 -1
- package/storybook-static/assets/{FlowingMenu.stories-BEDr1xuO.js → FlowingMenu.stories-lt-kmfSP.js} +1 -1
- package/storybook-static/assets/{FluidGlass.stories-DuVNxkrZ.js → FluidGlass.stories-BuhWZ_Ae.js} +1 -1
- package/storybook-static/assets/{Folder.stories-CJ7nEgQJ.js → Folder.stories-DkcDSS4C.js} +1 -1
- package/storybook-static/assets/{FuzzyText.stories-BuKAygiD.js → FuzzyText.stories--rgAbGdd.js} +1 -1
- package/storybook-static/assets/{Galaxy.stories-Bi5RCMcB.js → Galaxy.stories-BtoQgZ5g.js} +1 -1
- package/storybook-static/assets/{GhostCursor.stories-DMy5vu_C.js → GhostCursor.stories-DdZuzAPN.js} +1 -1
- package/storybook-static/assets/{GlareHover.stories-RA0buZVP.js → GlareHover.stories-BRqYHSpA.js} +1 -1
- package/storybook-static/assets/{GlassSurface.stories-oOyCFma0.js → GlassSurface.stories-DRIBU9EM.js} +1 -1
- package/storybook-static/assets/{GlitchText.stories-C3dw2f69.js → GlitchText.stories-BpY-FnEO.js} +1 -1
- package/storybook-static/assets/{GooeyNav.stories-DodnfpCO.js → GooeyNav.stories-BRcQ83Ow.js} +1 -1
- package/storybook-static/assets/{GradientBlinds.stories-BmX-ivyr.js → GradientBlinds.stories-CBDfLww2.js} +1 -1
- package/storybook-static/assets/{GradientText.stories-BdTnvb1T.js → GradientText.stories-X35aGA0z.js} +1 -1
- package/storybook-static/assets/{Grainient.stories-C0CnVFdJ.js → Grainient.stories-DxXaNTYL.js} +1 -1
- package/storybook-static/assets/{GridMotion.stories-Daolnb9j.js → GridMotion.stories-DqSG90cL.js} +1 -1
- package/storybook-static/assets/{ImageSlideshow.stories-CvKoNAI-.js → ImageSlideshow.stories-CtfQ0gfF.js} +1 -1
- package/storybook-static/assets/{Iridescence.stories-D0HUq878.js → Iridescence.stories-Dg0-a4BI.js} +1 -1
- package/storybook-static/assets/{LaserFlow.stories-DJDB4Xfr.js → LaserFlow.stories-HphAKxl3.js} +1 -1
- package/storybook-static/assets/{LetterGlitch.stories-DjMZR_xw.js → LetterGlitch.stories-DLHnI11F.js} +1 -1
- package/storybook-static/assets/{LightPillar.stories-9RuJG_6x.js → LightPillar.stories-CUbwXI-r.js} +1 -1
- package/storybook-static/assets/{LightRays.stories-BOX7_bV-.js → LightRays.stories-CN6SEiVL.js} +1 -1
- package/storybook-static/assets/{Lightning.stories-Dh-kp375.js → Lightning.stories-DKPrYnXR.js} +1 -1
- package/storybook-static/assets/{LineWaves.stories-BdrjoqN1.js → LineWaves.stories-CQG48pTS.js} +1 -1
- package/storybook-static/assets/{LiquidChrome.stories-N0zJbXUQ.js → LiquidChrome.stories-eT_xiYak.js} +1 -1
- package/storybook-static/assets/{LiquidEther.stories-vWRDBVr_.js → LiquidEther.stories-DXBLkgMd.js} +1 -1
- package/storybook-static/assets/{LoadingSpinner-B6-vh5z6.js → LoadingSpinner-CZ8UT8Bc.js} +1 -1
- package/storybook-static/assets/{LoadingSpinner.stories-1yZ6ClJ7.js → LoadingSpinner.stories-CR6A9mp_.js} +1 -1
- package/storybook-static/assets/{MagicRings.stories-ZoVWbjmT.js → MagicRings.stories-DfJhHwvh.js} +1 -1
- package/storybook-static/assets/{Magnet.stories-Ctd5tOiG.js → Magnet.stories-B-jKkHeX.js} +1 -1
- package/storybook-static/assets/{MagnetLines.stories-CmglSxov.js → MagnetLines.stories-CxFq3Ubm.js} +1 -1
- package/storybook-static/assets/{Masonry.stories-W_1YF3ub.js → Masonry.stories-BdK8xuEJ.js} +1 -1
- package/storybook-static/assets/{MetaBalls.stories-DXEdwmr8.js → MetaBalls.stories-C46SwkDW.js} +1 -1
- package/storybook-static/assets/{MetallicPaint.stories-CVyAY9vu.js → MetallicPaint.stories-DoezHDKx.js} +1 -1
- package/storybook-static/assets/{MoodChart.stories-Cjr6JTQP.js → MoodChart.stories-B9OgTXVp.js} +1 -1
- package/storybook-static/assets/{MotionConfigContext-gDsDtkMT.js → MotionConfigContext-Bw_b3ZUg.js} +1 -1
- package/storybook-static/assets/{Navbar.stories-DMQ51qfl.js → Navbar.stories-kGHTDdld.js} +1 -1
- package/storybook-static/assets/{Noise.stories-DOjA3l8c.js → Noise.stories-DVCl2Bri.js} +1 -1
- package/storybook-static/assets/{NumberStepper-jhNsTAPE.js → NumberStepper-YeXfyuax.js} +1 -1
- package/storybook-static/assets/{NumberStepper.stories-vFmsqFsD.js → NumberStepper.stories-DH0q8Pfx.js} +1 -1
- package/storybook-static/assets/{Orb.stories-uPxwcKg3.js → Orb.stories-DqhtrskE.js} +1 -1
- package/storybook-static/assets/{OrbitImages.stories-BgrJkWbr.js → OrbitImages.stories-DkgbzqRA.js} +1 -1
- package/storybook-static/assets/{PieChart.stories-C31zCqib.js → PieChart.stories-DtsuEu3P.js} +1 -1
- package/storybook-static/assets/{PixelBlast.stories-BxqNm5KA.js → PixelBlast.stories-DFVJyyCJ.js} +1 -1
- package/storybook-static/assets/{PixelCard.stories-BmB4_DHy.js → PixelCard.stories-rN2a2n6z.js} +1 -1
- package/storybook-static/assets/{PixelSnow.stories-DDLh_bMD.js → PixelSnow.stories-CTi1PQmJ.js} +1 -1
- package/storybook-static/assets/{PixelTransition.stories-Dpp9AFXb.js → PixelTransition.stories-2HV20X_n.js} +1 -1
- package/storybook-static/assets/{Plasma.stories-anL1BNRI.js → Plasma.stories-CRgiU8eT.js} +1 -1
- package/storybook-static/assets/{Prism.stories-BSPPpO86.js → Prism.stories-DXiBjhaz.js} +1 -1
- package/storybook-static/assets/{PrismaticBurst.stories-BvFMNl0Q.js → PrismaticBurst.stories-C-0bgAlq.js} +1 -1
- package/storybook-static/assets/{ProfileCard.stories-DB2Tf_1X.js → ProfileCard.stories-DqaByaZ1.js} +1 -1
- package/storybook-static/assets/{QuantifiableHabitsChart.stories-BVhIczSc.js → QuantifiableHabitsChart.stories-BZunSv8G.js} +1 -1
- package/storybook-static/assets/{Radar.stories-By7hndPb.js → Radar.stories-C8wwlosb.js} +1 -1
- package/storybook-static/assets/{Ribbons.stories-DHqHm_uy.js → Ribbons.stories-CmNeTz58.js} +1 -1
- package/storybook-static/assets/{RippleGrid.stories-DtKOX5px.js → RippleGrid.stories-hdUoMUQU.js} +1 -1
- package/storybook-static/assets/{RotatingText.stories-CSAGuKeZ.js → RotatingText.stories-ByoOkJK3.js} +1 -1
- package/storybook-static/assets/{ScrollFloat.stories-DwKU0qcO.js → ScrollFloat.stories-DzBb88Gj.js} +1 -1
- package/storybook-static/assets/{ScrollReveal.stories-BmCswYU6.js → ScrollReveal.stories-Cvj4Nyqh.js} +1 -1
- package/storybook-static/assets/{ScrollVelocity.stories-BqO1n76Z.js → ScrollVelocity.stories-Dv-M9Wnr.js} +1 -1
- package/storybook-static/assets/{SearchBar.stories-DWCltoQD.js → SearchBar.stories-CerIHZtb.js} +1 -1
- package/storybook-static/assets/{SearchableDropdown-BEETzyT2.js → SearchableDropdown-BYUsXzuw.js} +1 -1
- package/storybook-static/assets/{SearchableDropdown.stories-BeUAZttq.js → SearchableDropdown.stories-Be0en2w9.js} +1 -1
- package/storybook-static/assets/{SelectInput-DA6pWzMy.js → SelectInput-B1qnSkvU.js} +1 -1
- package/storybook-static/assets/{SelectInput.stories-BQPV2qQl.js → SelectInput.stories-rG534PQk.js} +1 -1
- package/storybook-static/assets/{ShapeBlur.stories-Cu7Cxe-n.js → ShapeBlur.stories-C0OfXwcj.js} +1 -1
- package/storybook-static/assets/{ShapeGrid.stories-Byhs9nUn.js → ShapeGrid.stories-CGVyt0ij.js} +1 -1
- package/storybook-static/assets/{ShinyText.stories-BlbDPW62.js → ShinyText.stories-CdqZ9sbE.js} +1 -1
- package/storybook-static/assets/{Silk.stories-Dz6Uo5vG.js → Silk.stories-C-SfR0Jg.js} +1 -1
- package/storybook-static/assets/{SleepChart.stories-Byl7YxjU.js → SleepChart.stories-aftHcHdn.js} +1 -1
- package/storybook-static/assets/{Slider-BFtq8rhf.js → Slider-83i6BK20.js} +1 -1
- package/storybook-static/assets/{Slider.stories-BO90SAoK.js → Slider.stories-B8uqaRWJ.js} +1 -1
- package/storybook-static/assets/{SoftAurora.stories-D_iSc_yX.js → SoftAurora.stories-B7X9ZV2K.js} +1 -1
- package/storybook-static/assets/{SoundDemo.stories-BuueCJTM.js → SoundDemo.stories-B2dUHnjX.js} +1 -1
- package/storybook-static/assets/{SplashCursor.stories-CAU9m78O.js → SplashCursor.stories-B-X6nqbL.js} +1 -1
- package/storybook-static/assets/{SpotlightCard.stories-CYppdBKP.js → SpotlightCard.stories-DzWyLfst.js} +1 -1
- package/storybook-static/assets/{Stack.stories-CwiKrAMZ.js → Stack.stories-Difhxomv.js} +1 -1
- package/storybook-static/assets/{StaggeredMenu.stories-2-CiXuH6.js → StaggeredMenu.stories-jMzvdn-y.js} +1 -1
- package/storybook-static/assets/{StarBorder.stories-BjbQ_ysY.js → StarBorder.stories-tllhEWZ6.js} +1 -1
- package/storybook-static/assets/{SunburstChart.stories-78mgI5fv.js → SunburstChart.stories-5vIpij27.js} +1 -1
- package/storybook-static/assets/{Table.stories-CuiNMdKq.js → Table.stories-BkYY9ch2.js} +1 -1
- package/storybook-static/assets/Tabs-CxzfjVJB.css +1 -0
- package/storybook-static/assets/Tabs.stories-BNA5iGAY.js +37 -0
- package/storybook-static/assets/{TargetCursor.stories-Bzi6cjME.js → TargetCursor.stories-DtezwDkw.js} +1 -1
- package/storybook-static/assets/{TextArea-DHGAj1Rw.js → TextArea-B2Ks28b3.js} +1 -1
- package/storybook-static/assets/{TextArea.stories-Coqx4wmC.js → TextArea.stories-DkqiL7is.js} +1 -1
- package/storybook-static/assets/{TextCursor.stories-C5Mxt8ms.js → TextCursor.stories-BA8KwHmz.js} +1 -1
- package/storybook-static/assets/{TextInput-CPzihem6.js → TextInput-RcF1I7gc.js} +1 -1
- package/storybook-static/assets/{TextInput.stories-B5oDvMs0.js → TextInput.stories-1ZvqndSt.js} +1 -1
- package/storybook-static/assets/{TextPressure.stories-B3_5j2PJ.js → TextPressure.stories-CagLTfG3.js} +1 -1
- package/storybook-static/assets/{TextType.stories-BFTYpHJO.js → TextType.stories-D_VO9NN0.js} +1 -1
- package/storybook-static/assets/{ThemeSwitcher.stories-CLgxSRsb.js → ThemeSwitcher.stories-D65qyRcn.js} +1 -1
- package/storybook-static/assets/{Threads.stories-CwmvO1um.js → Threads.stories-BKuIk-S8.js} +1 -1
- package/storybook-static/assets/{TimeInput.stories-Urm7XztJ.js → TimeInput.stories-CtLYgtN1.js} +1 -1
- package/storybook-static/assets/{Toggle-vFvItRbv.js → Toggle-DoFVZPP7.js} +1 -1
- package/storybook-static/assets/{Toggle.stories-COonxmPL.js → Toggle.stories-BphSAMdU.js} +1 -1
- package/storybook-static/assets/{ToggleButton-BxW27xmM.js → ToggleButton-CMV9gTJe.js} +1 -1
- package/storybook-static/assets/{ToggleButton.stories-DUi9a2DN.js → ToggleButton.stories-1J1Cc9rs.js} +1 -1
- package/storybook-static/assets/{TrueFocus.stories-CCTarbA0.js → TrueFocus.stories-BF_15cUA.js} +1 -1
- package/storybook-static/assets/{VariableProximity.stories-CyquT21F.js → VariableProximity.stories-CCJGixEX.js} +1 -1
- package/storybook-static/assets/{Waves.stories-C499bI1r.js → Waves.stories-5St-l3Wf.js} +1 -1
- package/storybook-static/assets/{check-C-uk-1GS.js → check-BeLtWVMx.js} +1 -1
- package/storybook-static/assets/{chevron-down-BWmeTqc3.js → chevron-down-D_mEXhKp.js} +1 -1
- package/storybook-static/assets/{chevron-right-DdnHj_ph.js → chevron-right-DBSgwEbi.js} +1 -1
- package/storybook-static/assets/client-C7ctmdCq.js +1 -0
- package/storybook-static/assets/{createLucideIcon-C3-RdmHA.js → createLucideIcon-DuhF9yZF.js} +1 -1
- package/storybook-static/assets/{download-DHOAXk8b.js → download-j4xSjMSA.js} +1 -1
- package/storybook-static/assets/{folder-BCmHh0Sx.js → folder-Bwjab-Ym.js} +1 -1
- package/storybook-static/assets/{iconBase-Cx_1NF0H.js → iconBase-qbjzzLYR.js} +1 -1
- package/storybook-static/assets/{iframe-HmiFVzZT.js → iframe-CK6Mw28k.js} +3 -3
- package/storybook-static/assets/{index-XC2I4cGy.js → index-CQOm43iW.js} +1 -1
- package/storybook-static/assets/{index-B_qji0Qz.js → index-DhjWRu4G.js} +1 -1
- package/storybook-static/assets/{index-Cttuif0Y.js → index-Dwwpkjqo.js} +1 -1
- package/storybook-static/assets/{proxy-DO5PJWgK.js → proxy-Bl04PYET.js} +1 -1
- package/storybook-static/assets/{react-18-S_WX7EKh.js → react-18-CDj_Zhc2.js} +1 -1
- package/storybook-static/assets/{react-three-fiber.esm-C6-7Gojs.js → react-three-fiber.esm-B-YAFtc0.js} +1 -1
- package/storybook-static/assets/{search-CST8cPDe.js → search-Bjs6a96N.js} +1 -1
- package/storybook-static/assets/{settings-DHql6i9P.js → settings-Z-MOtXdz.js} +1 -1
- package/storybook-static/assets/{sun-C_3qakxC.js → sun-Ci0RAefo.js} +1 -1
- package/storybook-static/assets/{trash-2-Cq_G-7_J.js → trash-2-G87MiWs9.js} +1 -1
- package/storybook-static/assets/{use-animation-frame-i5HP95EG.js → use-animation-frame-CHMft_Mi.js} +1 -1
- package/storybook-static/assets/{use-in-view-BqvigfYI.js → use-in-view-DJYXLAij.js} +1 -1
- package/storybook-static/assets/{use-motion-value-V8Oqo0cZ.js → use-motion-value-Do20FICu.js} +1 -1
- package/storybook-static/assets/{use-spring-CF8fu7Fb.js → use-spring-BK29UAI4.js} +1 -1
- package/storybook-static/assets/{use-transform-CaqBFIhx.js → use-transform-whfZpWa9.js} +1 -1
- package/storybook-static/assets/{useSound-B_1vRfvB.js → useSound-D6Fr1PWT.js} +1 -1
- package/storybook-static/assets/{users-CNY6nLXf.js → users-BZc8oR_p.js} +1 -1
- package/storybook-static/assets/{x-DeqHBv2X.js → x-lYUPUVqC.js} +1 -1
- package/storybook-static/iframe.html +1 -1
- package/storybook-static/index.json +1 -1
- package/storybook-static/project.json +1 -1
- package/storybook-static/assets/Calendar-CXrUBxYt.css +0 -1
- package/storybook-static/assets/Calendar.stories-B4HwroXI.js +0 -352
- package/storybook-static/assets/Tabs-CDVjuS9_.css +0 -1
- package/storybook-static/assets/Tabs.stories-BK-nggXM.js +0 -37
- package/storybook-static/assets/client-GT8pSxh_.js +0 -1
|
@@ -0,0 +1,367 @@
|
|
|
1
|
+
import{r as S,j as e}from"./iframe-CK6Mw28k.js";import{u as st}from"./use-motion-value-Do20FICu.js";import{u as nn}from"./use-transform-whfZpWa9.js";import{m as Pe}from"./proxy-Bl04PYET.js";import{T as an}from"./trash-2-G87MiWs9.js";import{c as qt}from"./createLucideIcon-DuhF9yZF.js";import{C as on}from"./check-BeLtWVMx.js";import{a as xe}from"./index-CQOm43iW.js";import{D as rn}from"./download-j4xSjMSA.js";import"./preload-helper-C1FmrZbK.js";import"./MotionConfigContext-Bw_b3ZUg.js";/**
|
|
2
|
+
* @license lucide-react v0.539.0 - ISC
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the ISC license.
|
|
5
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
6
|
+
*/const sn=[["circle",{cx:"9",cy:"12",r:"1",key:"1vctgf"}],["circle",{cx:"9",cy:"5",r:"1",key:"hp0tcf"}],["circle",{cx:"9",cy:"19",r:"1",key:"fkjjf6"}],["circle",{cx:"15",cy:"12",r:"1",key:"1tmaij"}],["circle",{cx:"15",cy:"5",r:"1",key:"19l28e"}],["circle",{cx:"15",cy:"19",r:"1",key:"f4zoj3"}]],ln=qt("grip-vertical",sn);/**
|
|
7
|
+
* @license lucide-react v0.539.0 - ISC
|
|
8
|
+
*
|
|
9
|
+
* This source code is licensed under the ISC license.
|
|
10
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
11
|
+
*/const dn=[["path",{d:"M21.174 6.812a1 1 0 0 0-3.986-3.987L3.842 16.174a2 2 0 0 0-.5.83l-1.321 4.352a.5.5 0 0 0 .623.622l4.353-1.32a2 2 0 0 0 .83-.497z",key:"1a8usu"}],["path",{d:"m15 5 4 4",key:"1mk7zo"}]],cn=qt("pencil",dn),mn="_calendar_10jyd_2",un="_loading_10jyd_14",pn="_loadingSpinner_10jyd_21",yn="_header_10jyd_27",gn="_navigation_10jyd_35",vn="_navButton_10jyd_41",hn="_title_10jyd_60",fn="_controls_10jyd_70",wn="_exportDropdown_10jyd_76",Dn="_exportButton_10jyd_80",_n="_exportMenu_10jyd_98",xn="_exportMenuItem_10jyd_113",Sn="_todayButton_10jyd_130",kn="_viewToggle_10jyd_146",jn="_viewButton_10jyd_153",Cn="_active_10jyd_167",Tn="_filterBar_10jyd_177",En="_filterPill_10jyd_186",bn="_filterPillActive_10jyd_205",Nn="_filterDot_10jyd_211",Hn="_weekDays_10jyd_219",Mn="_withWeekNumbers_10jyd_226",$n="_weekNumberHeader_10jyd_230",Ln="_weekDay_10jyd_219",In="_daysGrid_10jyd_247",Pn="_dayCell_10jyd_263",Bn="_dayNumber_10jyd_292",Fn="_today_10jyd_130",Wn="_events_10jyd_311",An="_event_10jyd_311",On="_eventTitle_10jyd_338",Rn="_eventTime_10jyd_347",qn="_otherMonth_10jyd_392",Vn="_selected_10jyd_397",zn="_compact_10jyd_409",Gn="_dots_10jyd_431",Un="_dot_10jyd_431",Yn="_dotMore_10jyd_446",Xn="_weekNumberCell_10jyd_453",Jn="_completed_10jyd_499",Qn="_completedIcon_10jyd_520",Kn="_moreEvents_10jyd_527",Zn="_emptyState_10jyd_537",ea="_dayView_10jyd_547",ta="_dayViewHeader_10jyd_556",na="_timeColumnHeader_10jyd_566",aa="_dayColumnHeader_10jyd_573",oa="_allDayStrip_10jyd_583",ra="_allDayLabel_10jyd_591",sa="_allDayList_10jyd_602",ia="_dayViewScrollContainer_10jyd_625",la="_dayTimelineGrid_10jyd_634",da="_hourRow_10jyd_639",ca="_hourLabel_10jyd_645",ma="_hourSlots_10jyd_656",ua="_halfHourSlot_10jyd_663",pa="_halfHourSlotBottom_10jyd_673",ya="_dayEventAnchor_10jyd_678",ga="_weekTimeline_10jyd_686",va="_weekTimelineHeader_10jyd_695",ha="_weekDayColumnHeader_10jyd_707",fa="_weekDayLabel_10jyd_741",wa="_weekDayNumber_10jyd_749",Da="_weekTimelineScroll_10jyd_754",_a="_weekTimelineGrid_10jyd_762",xa="_weekTimeColumn_10jyd_768",Sa="_weekTimeSlot_10jyd_776",ka="_weekHourLabel_10jyd_783",ja="_weekDayColumns_10jyd_789",Ca="_weekDayColumn_10jyd_707",Ta="_weekHourRow_10jyd_807",Ea="_weekEventAnchor_10jyd_813",ba="_currentTimeIndicator_10jyd_821",n={calendar:mn,loading:un,loadingSpinner:pn,header:yn,navigation:gn,navButton:vn,title:hn,controls:fn,exportDropdown:wn,exportButton:Dn,exportMenu:_n,exportMenuItem:xn,todayButton:Sn,viewToggle:kn,viewButton:jn,active:Cn,filterBar:Tn,filterPill:En,filterPillActive:bn,filterDot:Nn,weekDays:Hn,withWeekNumbers:Mn,weekNumberHeader:$n,weekDay:Ln,daysGrid:In,dayCell:Pn,dayNumber:Bn,today:Fn,events:Wn,event:An,eventTitle:On,eventTime:Rn,otherMonth:qn,selected:Vn,compact:zn,dots:Gn,dot:Un,dotMore:Yn,weekNumberCell:Xn,completed:Jn,completedIcon:Qn,moreEvents:Kn,emptyState:Zn,dayView:ea,dayViewHeader:ta,timeColumnHeader:na,dayColumnHeader:aa,allDayStrip:oa,allDayLabel:ra,allDayList:sa,dayViewScrollContainer:ia,dayTimelineGrid:la,hourRow:da,hourLabel:ca,hourSlots:ma,halfHourSlot:ua,halfHourSlotBottom:pa,dayEventAnchor:ya,weekTimeline:ga,weekTimelineHeader:va,weekDayColumnHeader:ha,weekDayLabel:fa,weekDayNumber:wa,weekTimelineScroll:Da,weekTimelineGrid:_a,weekTimeColumn:xa,weekTimeSlot:Sa,weekHourLabel:ka,weekDayColumns:ja,weekDayColumn:Ca,weekHourRow:Ta,weekEventAnchor:Ea,currentTimeIndicator:ba},Na="_wrapper_nyv1b_1",Ha="_deleteUnderlay_nyv1b_7",Ma="_card_nyv1b_23",$a="_dragging_nyv1b_43",La="_completed_nyv1b_49",Ia="_text_nyv1b_53",Pa="_grip_nyv1b_57",Ba="_checkIcon_nyv1b_77",Fa="_time_nyv1b_89",Wa="_editButton_nyv1b_96",F={wrapper:Na,deleteUnderlay:Ha,card:Ma,dragging:$a,completed:La,text:Ia,grip:Pa,checkIcon:Ba,time:Fa,editButton:Wa},Aa=-80,Ie=({event:o,color:a,textColor:s,onComplete:l,onEdit:d,onDelete:u,onDragEnd:c,draggable:h=!0})=>{const w=st(0),x=st(0),D=nn(w,[-80,0],[1,0]),[C,b]=S.useState(!1),I=S.useRef(!1),H=S.useRef(null),K=o.status==="completed",q=(p,z)=>{u&&z.offset.x<Aa?xe(w,-1e3,{duration:.2,onComplete:()=>u(o)}):xe(w,0,{type:"spring",stiffness:400,damping:30})},Z=()=>{if(I.current){I.current=!1;return}C||l==null||l(o)},le=p=>{!h||!c||(p.stopPropagation(),p.preventDefault(),H.current={x:p.clientX,y:p.clientY,pointerId:p.pointerId},p.currentTarget.setPointerCapture(p.pointerId),b(!0))},ee=p=>{H.current&&(w.set(p.clientX-H.current.x),x.set(p.clientY-H.current.y))},de=p=>{if(!H.current)return;const z=p.clientY,_=p.clientX;try{p.currentTarget.releasePointerCapture(H.current.pointerId)}catch{}H.current=null,b(!1),xe(x,0,{type:"spring",stiffness:400,damping:30}),xe(w,0,{type:"spring",stiffness:400,damping:30}),c==null||c(z,_)},V=!!u,ce=h&&!!c;return e.jsxs("div",{className:F.wrapper,children:[V&&e.jsxs(Pe.div,{className:F.deleteUnderlay,style:{opacity:D},children:[e.jsx(an,{size:16}),e.jsx("span",{children:"Delete"})]}),e.jsxs(Pe.div,{className:`${F.card} ${K?F.completed:""} ${C?F.dragging:""}`,style:{x:w,y:x,background:a,color:s,borderLeftColor:a},drag:V&&!C?"x":!1,dragConstraints:V?{left:-200,right:0}:void 0,dragElastic:.15,dragDirectionLock:!0,onDragStart:()=>{I.current=!0},onDragEnd:q,whileTap:C?void 0:{scale:.98},animate:C?{scale:1.03}:{scale:1},onClick:Z,children:[ce&&e.jsx("div",{className:F.grip,onPointerDown:le,onPointerMove:ee,onPointerUp:de,onPointerCancel:de,onClick:p=>p.stopPropagation(),children:e.jsx(ln,{size:14})}),K&&e.jsx(on,{size:14,className:F.checkIcon,strokeWidth:3}),e.jsx("span",{className:F.text,children:o.title}),o.time&&e.jsx("span",{className:F.time,children:o.time}),d&&e.jsx("button",{className:F.editButton,onClick:p=>{p.stopPropagation(),d(o)},"aria-label":"Edit event",children:e.jsx(cn,{size:13})})]})]})};Ie.__docgenInfo={description:"",methods:[],displayName:"DayEventCard",props:{draggable:{defaultValue:{value:"true",computed:!1},required:!1}}};const ye=["id","title","date","time","endTime","allDay","type","status","priority","category"],Oa=o=>(typeof o=="string"?new Date(o):o).toISOString(),Ge=o=>{const a={};for(const s of ye){const l=o[s];l!==void 0&&(a[s]=s==="date"?Oa(l):l)}return a},Ra=o=>{if(o==null)return"";const a=String(o);return/[",\n\r]/.test(a)?`"${a.replace(/"/g,'""')}"`:a},qa=o=>{const a=ye.join(","),s=o.map(l=>{const d=Ge(l);return ye.map(u=>Ra(d[u])).join(",")});return[a,...s].join(`
|
|
12
|
+
`)},Va=o=>JSON.stringify(o.map(Ge),null,2),za=o=>{if(o==null)return"";const a=String(o);return/[",\n\r]/.test(a)?`"${a.replace(/"/g,'""')}"`:a},Ga=o=>{const a=`events[${o.length}]{${ye.join(",")}}:`,s=o.map(l=>{const d=Ge(l);return" "+ye.map(u=>za(d[u])).join(",")});return[a,...s].join(`
|
|
13
|
+
`)},Ua={csv:"text/csv;charset=utf-8;",json:"application/json;charset=utf-8;",toon:"text/plain;charset=utf-8;"},Ya={csv:"csv",json:"json",toon:"toon"},Xa=(o,a)=>a==="csv"?qa(o):a==="json"?Va(o):Ga(o),Ja=(o,a,s)=>{const l=Xa(o,a),d=new Blob([l],{type:Ua[a]}),u=URL.createObjectURL(d),c=document.createElement("a");c.href=u,c.download=`events-${new Date().toISOString().slice(0,10)}.${Ya[a]}`,document.body.appendChild(c),c.click(),document.body.removeChild(c),URL.revokeObjectURL(u)};function se({events:o,onEventClick:a,onDateClick:s,onEventClickByView:l,onDateClickByView:d,onTimeSlotClick:u,onEventDrop:c,onEventComplete:h,onEventDelete:w,onEventEdit:x,viewMode:D="month",initialDate:C=new Date,config:b={},className:I="",style:H={},loading:K=!1,emptyState:q,hideHeader:Z=!1,compact:le=!1,selectedDate:ee,selectedCategoryId:de,onCategoryChange:V,exportFormats:ce}){const[p,z]=S.useState(C),[_,Fe]=S.useState(D),[zt,Gt]=S.useState(null),Ue=de!==void 0,te=Ue?de??null:zt,Ye=t=>{Ue||Gt(t),V==null||V(t)},We=S.useRef(null),Ae=S.useRef(null),[ge,Oe]=S.useState(!1),Re=S.useRef(null);S.useEffect(()=>{if(!ge)return;const t=r=>{Re.current&&!Re.current.contains(r.target)&&Oe(!1)};return document.addEventListener("mousedown",t),()=>document.removeEventListener("mousedown",t)},[ge]);const{eventColors:Xe={},iconRenderer:Je,maxEventsPerDay:G=3,mondayStart:me=!1,showWeekNumbers:ve=!1,dateFormat:Qe={month:"long",year:"numeric"},locale:U="en-US",dayLabels:Ut,monthNames:he,startHour:P=0,endHour:Ke=24,hourHeight:T=60,halfHourSlots:B=!1,categories:ne}=b,Ze=S.useMemo(()=>!ne||ne.length===0||te===null?o:o.filter(t=>!t.category||t.category===te),[o,ne,te]),Yt=Ut||(me?["Mon","Tue","Wed","Thu","Fri","Sat","Sun"]:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"]),et=(b==null?void 0:b.hourHeight)??60,tt=(b==null?void 0:b.startHour)??0,ue=S.useMemo(()=>{const t=p.getFullYear(),r=p.getMonth();let y,m,k;if(_==="week"){y=new Date(p);const $=y.getDay(),f=me?y.getDate()-$+($===0?-6:1):y.getDate()-$;y=new Date(y.setDate(f)),y.setHours(0,0,0,0),m=new Date(y),m.setDate(m.getDate()+6);const A=y.toLocaleDateString(U,{day:"numeric",month:"short"}),L=m.toLocaleDateString(U,{day:"numeric",month:"short"});k=`${A} - ${L}`}else if(_==="day")y=new Date(p),y.setHours(0,0,0,0),m=new Date(p),m.setHours(23,59,59,999),k=p.toLocaleDateString(U,{weekday:"long",year:"numeric",month:"long",day:"numeric"});else{const $=new Date(t,r,1),f=new Date(t,r+1,0);y=new Date($);const A=me?($.getDay()+6)%7:$.getDay();y.setDate(y.getDate()-A),m=new Date(f);const L=me?(f.getDay()+6)%7:f.getDay();m.setDate(m.getDate()+(6-L)),he&&he[r]?k=`${he[r]} ${t}`:k=p.toLocaleDateString(U,Qe)}const N=[],M=new Date(y);for(;M<=m;)N.push(new Date(M)),M.setDate(M.getDate()+1);return{days:N,displayTitle:k}},[p,_,me,U,Qe,he]);S.useEffect(()=>{const t=_==="day"?We:_==="week"?Ae:null;if(!(t!=null&&t.current))return;const r=new Date;if(!(_==="day"?p.toDateString()===r.toDateString():ue.days.some(N=>N.toDateString()===r.toDateString())))return;const m=(r.getHours()-tt)*60+r.getMinutes(),k=Math.max(0,m/60*et-100);setTimeout(()=>{t.current&&(t.current.scrollTop=k)},0)},[_,p,tt,et,ue]);const qe=t=>{const r=Ze.filter(y=>new Date(y.date).toDateString()===t.toDateString());return _==="week"?r.sort((y,m)=>{const k=y.time?nt(y.time):999999,N=m.time?nt(m.time):999999;return k-N}):r},nt=t=>{const[r,y]=t.split(":").map(Number);return r*60+y},Xt=()=>{const t=new Date(p);_==="week"?t.setDate(t.getDate()-7):_==="day"?t.setDate(t.getDate()-1):t.setMonth(t.getMonth()-1),z(t)},Jt=()=>{const t=new Date(p);_==="week"?t.setDate(t.getDate()+7):_==="day"?t.setDate(t.getDate()+1):t.setMonth(t.getMonth()+1),z(t)},Qt=()=>{z(new Date)},ae=t=>{if(t.color)return t.color;if(t.type&&Xe[t.type])return Xe[t.type];const r={high:"#FF4444",medium:"#FFA500",low:"#4A90E2"};return t.priority&&r[t.priority]?r[t.priority]:"#4A90E2"},Kt=t=>{const r=t.replace("#",""),y=parseInt(r.substring(0,2),16),m=parseInt(r.substring(2,4),16),k=parseInt(r.substring(4,6),16);return(.299*y+.587*m+.114*k)/255>.5?"#000000":"#FFFFFF"},fe=t=>{if(t.textColor)return t.textColor;const r=ae(t);return Kt(r)},we=t=>{l&&l[_]?l[_](t):a&&a(t)},at=t=>{d&&d[_]?d[_](t):s&&s(t)},Zt=t=>{const r=new Date;return t.toDateString()===r.toDateString()},en=t=>t.getMonth()===p.getMonth(),tn=t=>{const r=new Date(t.getFullYear(),0,1),y=t.getTime()-r.getTime(),m=1e3*60*60*24*7;return Math.floor(y/m)+1};return K?e.jsx("div",{className:`${n.calendar} ${n.loading} ${I}`,style:H,children:e.jsx("div",{className:n.loadingSpinner,children:"Loading..."})}):e.jsxs("div",{className:`${n.calendar} ${le?n.compact:""} ${I}`,style:H,children:[!Z&&e.jsxs("div",{className:n.header,children:[e.jsxs("div",{className:n.navigation,children:[e.jsx("button",{onClick:Xt,className:n.navButton,"aria-label":"Previous",children:e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",children:e.jsx("polyline",{points:"15,18 9,12 15,6"})})}),e.jsx("h3",{className:n.title,children:ue.displayTitle}),e.jsx("button",{onClick:Jt,className:n.navButton,"aria-label":"Next",children:e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",children:e.jsx("polyline",{points:"9,6 15,12 9,18"})})})]}),ne&&ne.length>0&&e.jsxs("div",{className:n.filterBar,role:"tablist","aria-label":"Filter by category",children:[e.jsx("button",{type:"button",role:"tab","aria-selected":te===null,className:`${n.filterPill} ${te===null?n.filterPillActive:""}`,onClick:()=>Ye(null),children:"All"}),ne.map(t=>{const r=te===t.id;return e.jsxs("button",{type:"button",role:"tab","aria-selected":r,className:`${n.filterPill} ${r?n.filterPillActive:""}`,style:r?{background:t.color,borderColor:t.color,color:"#ffffff"}:void 0,onClick:()=>Ye(t.id),children:[!r&&e.jsx("span",{className:n.filterDot,style:{background:t.color}}),t.label]},t.id)})]}),e.jsxs("div",{className:n.controls,children:[ce&&ce.length>0&&e.jsxs("div",{className:n.exportDropdown,ref:Re,children:[e.jsx("button",{type:"button",className:n.exportButton,onClick:()=>Oe(t=>!t),"aria-haspopup":"menu","aria-expanded":ge,"aria-label":"Export events",title:"Export events",children:e.jsx(rn,{size:16})}),ge&&e.jsx("div",{className:n.exportMenu,role:"menu",children:ce.map(t=>e.jsx("button",{type:"button",role:"menuitem",className:n.exportMenuItem,onClick:()=>{Ja(Ze,t),Oe(!1)},children:t.toUpperCase()},t))})]}),e.jsx("button",{onClick:Qt,className:n.todayButton,children:"Today"}),e.jsxs("div",{className:n.viewToggle,children:[e.jsx("button",{className:`${n.viewButton} ${_==="month"?n.active:""}`,onClick:()=>Fe("month"),children:"Month"}),e.jsx("button",{className:`${n.viewButton} ${_==="week"?n.active:""}`,onClick:()=>Fe("week"),children:"Week"}),e.jsx("button",{className:`${n.viewButton} ${_==="day"?n.active:""}`,onClick:()=>Fe("day"),children:"Day"})]})]})]}),_==="month"&&e.jsxs("div",{className:`${n.weekDays} ${ve?n.withWeekNumbers:""}`,children:[ve&&e.jsx("div",{className:n.weekNumberHeader,children:"Wk"}),Yt.map(t=>e.jsx("div",{className:n.weekDay,children:t},t))]}),_==="day"?(()=>{const t=qe(p),r=t.filter(i=>!i.allDay&&i.time),y=t.filter(i=>i.allDay||!i.time),m=Array.from({length:Ke-P},(i,g)=>P+g),k=m.length*T,N=new Date,M=p.toDateString()===N.toDateString(),f=((N.getHours()-P)*60+N.getMinutes())/60*T,A=M&&f>=0&&f<=k,L=i=>{const[g,E]=i.split(":").map(Number);return g*60+E},Ve=i=>{if(!i.time||!i.endTime)return 30;const g=L(i.endTime)-L(i.time);return g>0?g:30},v=(i,g)=>{if(u){const E=new Date(p);E.setHours(i,g,0,0);const O=`${i.toString().padStart(2,"0")}:${g.toString().padStart(2,"0")}`;u(E,i,O)}},j=(i,g)=>{var _e;if(!c)return;const E=(_e=We.current)==null?void 0:_e.querySelector(`.${n.dayTimelineGrid}`);if(!E)return;const O=E.getBoundingClientRect(),Y=g-O.top,X=B?T/2:T,R=Math.max(0,Math.floor(Y/X)),J=B?m.length*2:m.length,Q=Math.min(J-1,R),ze=P+Math.floor(B?Q/2:Q),pe=B&&Q%2===1?30:0,De=new Date(p);De.setHours(ze,pe,0,0),c(i,De)};return e.jsxs("div",{className:n.dayView,children:[e.jsxs("div",{className:n.dayViewHeader,children:[e.jsx("div",{className:n.timeColumnHeader}),e.jsx("div",{className:n.dayColumnHeader,children:p.toLocaleDateString(U,{weekday:"short",day:"numeric"})})]}),y.length>0&&e.jsxs("div",{className:n.allDayStrip,children:[e.jsx("span",{className:n.allDayLabel,children:"All day"}),e.jsx("div",{className:n.allDayList,children:y.map(i=>e.jsx(Ie,{event:i,color:ae(i),textColor:fe(i),onComplete:h??(a?we:void 0),onEdit:x,onDelete:w,draggable:!1},i.id))})]}),e.jsx("div",{className:n.dayViewScrollContainer,ref:We,children:e.jsxs("div",{className:n.dayTimelineGrid,style:{height:k},children:[m.map(i=>e.jsxs("div",{className:n.hourRow,style:{height:T},children:[e.jsxs("span",{className:n.hourLabel,children:[i.toString().padStart(2,"0"),":00"]}),e.jsx("div",{className:n.hourSlots,children:B?e.jsxs(e.Fragment,{children:[e.jsx("div",{className:n.halfHourSlot,onClick:()=>v(i,0)}),e.jsx("div",{className:`${n.halfHourSlot} ${n.halfHourSlotBottom}`,onClick:()=>v(i,30)})]}):e.jsx("div",{className:n.halfHourSlot,onClick:()=>v(i,0)})})]},i)),r.map(i=>{const[g,E]=i.time.split(":").map(Number),O=(g-P)*T+E/60*T,Y=Ve(i),X=Math.max(24,Y/60*T-2);return e.jsx("div",{className:n.dayEventAnchor,style:{top:O,height:X},onClick:R=>R.stopPropagation(),children:e.jsx(Ie,{event:i,color:ae(i),textColor:fe(i),onComplete:h??(a?we:void 0),onEdit:x,onDelete:w,onDragEnd:c?R=>j(i,R):void 0})},i.id)}),A&&e.jsx("div",{className:n.currentTimeIndicator,style:{top:`${f}px`}})]})})]})})():_==="week"?(()=>{const t=ue.days,r=Array.from({length:Ke-P},(v,j)=>P+j),y=r.length*T,m=new Date,k=t.findIndex(v=>v.toDateString()===m.toDateString()),M=((m.getHours()-P)*60+m.getMinutes())/60*T,$=k>=0&&M>=0&&M<=y,f=v=>{const[j,i]=v.split(":").map(Number);return j*60+i},A=v=>{if(!v.time||!v.endTime)return 30;const j=f(v.endTime)-f(v.time);return j>0?j:30},L=(v,j,i)=>{if(!u)return;const g=new Date(v);g.setHours(j,i,0,0);const E=`${j.toString().padStart(2,"0")}:${i.toString().padStart(2,"0")}`;u(g,j,E)},Ve=(v,j,i)=>{var rt;if(!c)return;const g=(rt=Ae.current)==null?void 0:rt.querySelector(`.${n.weekDayColumns}`);if(!g)return;const E=g.getBoundingClientRect(),O=i-E.left,Y=j-E.top,X=E.width/7,R=Math.min(6,Math.max(0,Math.floor(O/X))),J=t[R],Q=B?T/2:T,ze=B?r.length*2:r.length,pe=Math.min(ze-1,Math.max(0,Math.floor(Y/Q))),De=P+Math.floor(B?pe/2:pe),_e=B&&pe%2===1?30:0,ot=new Date(J);ot.setHours(De,_e,0,0),c(v,ot)};return e.jsxs("div",{className:n.weekTimeline,children:[e.jsxs("div",{className:n.weekTimelineHeader,children:[e.jsx("div",{className:n.timeColumnHeader}),t.map(v=>{const j=v.toDateString()===m.toDateString(),i=ee&&v.toDateString()===ee.toDateString();return e.jsxs("button",{type:"button",className:`${n.weekDayColumnHeader} ${j?n.today:""} ${i?n.selected:""}`,onClick:()=>at(v),children:[e.jsx("span",{className:n.weekDayLabel,children:v.toLocaleDateString(U,{weekday:"short"})}),e.jsx("span",{className:n.weekDayNumber,children:v.getDate()})]},v.toISOString())})]}),e.jsx("div",{className:n.weekTimelineScroll,ref:Ae,children:e.jsxs("div",{className:n.weekTimelineGrid,style:{height:y},children:[e.jsx("div",{className:n.weekTimeColumn,children:r.map(v=>e.jsx("div",{className:n.weekTimeSlot,style:{height:T},children:e.jsxs("span",{className:n.weekHourLabel,children:[v.toString().padStart(2,"0"),":00"]})},v))}),e.jsx("div",{className:n.weekDayColumns,children:t.map(v=>{const j=qe(v).filter(g=>!g.allDay&&g.time),i=v.toDateString()===m.toDateString();return e.jsxs("div",{className:n.weekDayColumn,children:[r.map(g=>e.jsx("div",{className:n.weekHourRow,style:{height:T},children:B?e.jsxs(e.Fragment,{children:[e.jsx("div",{className:n.halfHourSlot,onClick:()=>L(v,g,0)}),e.jsx("div",{className:`${n.halfHourSlot} ${n.halfHourSlotBottom}`,onClick:()=>L(v,g,30)})]}):e.jsx("div",{className:n.halfHourSlot,onClick:()=>L(v,g,0)})},g)),j.map(g=>{const[E,O]=g.time.split(":").map(Number),Y=(E-P)*T+O/60*T,X=A(g),R=Math.max(24,X/60*T-2);return e.jsx("div",{className:n.weekEventAnchor,style:{top:Y,height:R},onClick:J=>J.stopPropagation(),children:e.jsx(Ie,{event:g,color:ae(g),textColor:fe(g),onComplete:h??(a?we:void 0),onEdit:x,onDelete:w,onDragEnd:c?(J,Q)=>Ve(g,J,Q):void 0})},g.id)}),i&&$&&e.jsx("div",{className:n.currentTimeIndicator,style:{top:`${M}px`,left:0}})]},v.toISOString())})})]})})]})})():(()=>{const t=le?void 0:40+G*24;return e.jsx("div",{className:`${n.daysGrid} ${ve?n.withWeekNumbers:""}`,children:ue.days.map((r,y)=>{const m=qe(r),k=Zt(r),N=en(r),M=ve&&y%7===0,$=ee&&r.toDateString()===ee.toDateString();return e.jsxs(S.Fragment,{children:[M&&e.jsx("div",{className:n.weekNumberCell,style:t!==void 0?{height:t,minHeight:t}:void 0,children:tn(r)}),e.jsxs(Pe.div,{className:`${n.dayCell} ${k?n.today:""} ${N?"":n.otherMonth} ${$?n.selected:""}`,style:t!==void 0?{height:t,minHeight:t}:void 0,initial:{opacity:0,y:20},animate:{opacity:1,y:0},transition:{duration:.3,delay:y*.02,ease:"easeOut"},onClick:()=>at(r),children:[e.jsx("div",{className:n.dayNumber,children:r.getDate()}),m.length>0&&le&&_==="month"?e.jsxs("div",{className:n.dots,children:[m.slice(0,G).map(f=>e.jsx("span",{className:n.dot,style:{backgroundColor:ae(f)}},f.id)),m.length>G&&e.jsxs("span",{className:n.dotMore,children:["+",m.length-G]})]}):m.length>0?e.jsxs("div",{className:n.events,children:[m.slice(0,G).map((f,A)=>e.jsxs(Pe.div,{className:`${n.event} ${f.status==="completed"?n.completed:""}`,style:{backgroundColor:ae(f),color:fe(f),opacity:f.status==="completed"?.7:1},onClick:L=>{L.stopPropagation(),we(f)},initial:{opacity:0,x:-10},animate:{opacity:1,x:0},transition:{duration:.2,delay:A*.05,ease:"easeOut"},whileHover:{scale:1.02,y:-1,transition:{duration:.1}},whileTap:{scale:.98,transition:{duration:.1}},children:[Je&&Je(f),e.jsxs("span",{className:n.eventTitle,children:[f.time&&e.jsx("span",{className:n.eventTime,children:f.time}),f.title]}),f.status==="completed"&&e.jsx("svg",{className:n.completedIcon,width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",children:e.jsx("polyline",{points:"20,6 9,17 4,12"})})]},f.id)),m.length>G&&e.jsxs("div",{className:n.moreEvents,children:["+",m.length-G," more"]})]}):q?e.jsx("div",{className:n.emptyState,children:q}):null]})]},`${r.getFullYear()}-${r.getMonth()}-${r.getDate()}`)})})})()]})}se.__docgenInfo={description:`Calendar component - A flexible, reusable calendar for displaying events
|
|
14
|
+
|
|
15
|
+
@component
|
|
16
|
+
@description
|
|
17
|
+
A highly customizable calendar component that can display events in month or week view.
|
|
18
|
+
Supports custom event types, colors, icons, and localization. Perfect for scheduling,
|
|
19
|
+
project management, habit tracking, or any date-based data visualization.
|
|
20
|
+
|
|
21
|
+
@example
|
|
22
|
+
// Basic usage
|
|
23
|
+
<Calendar
|
|
24
|
+
events={myEvents}
|
|
25
|
+
onEventClick={handleEventClick}
|
|
26
|
+
viewMode="month"
|
|
27
|
+
/>
|
|
28
|
+
|
|
29
|
+
@example
|
|
30
|
+
// With custom configuration
|
|
31
|
+
<Calendar
|
|
32
|
+
events={projectEvents}
|
|
33
|
+
config={{
|
|
34
|
+
eventColors: { task: '#4A90E2', meeting: '#7ED321' },
|
|
35
|
+
maxEventsPerDay: 5,
|
|
36
|
+
mondayStart: true
|
|
37
|
+
}}
|
|
38
|
+
onEventClick={handleEventClick}
|
|
39
|
+
/>`,methods:[],displayName:"Calendar",props:{events:{required:!0,tsType:{name:"Array",elements:[{name:"CalendarEvent"}],raw:"CalendarEvent[]"},description:"Array of events to display"},onEventClick:{required:!1,tsType:{name:"signature",type:"function",raw:"(event: CalendarEvent) => void",signature:{arguments:[{type:{name:"CalendarEvent"},name:"event"}],return:{name:"void"}}},description:"Callback when an event is clicked"},onDateClick:{required:!1,tsType:{name:"signature",type:"function",raw:"(date: Date) => void",signature:{arguments:[{type:{name:"Date"},name:"date"}],return:{name:"void"}}},description:"Callback when a date is clicked"},onEventClickByView:{required:!1,tsType:{name:"signature",type:"object",raw:`{
|
|
40
|
+
month?: (event: CalendarEvent) => void;
|
|
41
|
+
week?: (event: CalendarEvent) => void;
|
|
42
|
+
day?: (event: CalendarEvent) => void;
|
|
43
|
+
}`,signature:{properties:[{key:"month",value:{name:"signature",type:"function",raw:"(event: CalendarEvent) => void",signature:{arguments:[{type:{name:"CalendarEvent"},name:"event"}],return:{name:"void"}},required:!1}},{key:"week",value:{name:"signature",type:"function",raw:"(event: CalendarEvent) => void",signature:{arguments:[{type:{name:"CalendarEvent"},name:"event"}],return:{name:"void"}},required:!1}},{key:"day",value:{name:"signature",type:"function",raw:"(event: CalendarEvent) => void",signature:{arguments:[{type:{name:"CalendarEvent"},name:"event"}],return:{name:"void"}},required:!1}}]}},description:"View-specific event click handlers"},onDateClickByView:{required:!1,tsType:{name:"signature",type:"object",raw:`{
|
|
44
|
+
month?: (date: Date) => void;
|
|
45
|
+
week?: (date: Date) => void;
|
|
46
|
+
day?: (date: Date) => void;
|
|
47
|
+
}`,signature:{properties:[{key:"month",value:{name:"signature",type:"function",raw:"(date: Date) => void",signature:{arguments:[{type:{name:"Date"},name:"date"}],return:{name:"void"}},required:!1}},{key:"week",value:{name:"signature",type:"function",raw:"(date: Date) => void",signature:{arguments:[{type:{name:"Date"},name:"date"}],return:{name:"void"}},required:!1}},{key:"day",value:{name:"signature",type:"function",raw:"(date: Date) => void",signature:{arguments:[{type:{name:"Date"},name:"date"}],return:{name:"void"}},required:!1}}]}},description:"View-specific date click handlers"},onTimeSlotClick:{required:!1,tsType:{name:"signature",type:"function",raw:"(date: Date, hour: number, time: string) => void",signature:{arguments:[{type:{name:"Date"},name:"date"},{type:{name:"number"},name:"hour"},{type:{name:"string"},name:"time"}],return:{name:"void"}}},description:"Callback when a time slot is clicked in day view"},onEventDrop:{required:!1,tsType:{name:"signature",type:"function",raw:"(event: CalendarEvent, newDate: Date) => void",signature:{arguments:[{type:{name:"CalendarEvent"},name:"event"},{type:{name:"Date"},name:"newDate"}],return:{name:"void"}}},description:"Callback when an event is dropped (drag-rescheduled) in day view"},onEventComplete:{required:!1,tsType:{name:"signature",type:"function",raw:"(event: CalendarEvent) => void",signature:{arguments:[{type:{name:"CalendarEvent"},name:"event"}],return:{name:"void"}}},description:"Day view: callback when an event body is tapped to toggle complete"},onEventDelete:{required:!1,tsType:{name:"signature",type:"function",raw:"(event: CalendarEvent) => void",signature:{arguments:[{type:{name:"CalendarEvent"},name:"event"}],return:{name:"void"}}},description:"Day view: callback when an event is swiped left to delete"},onEventEdit:{required:!1,tsType:{name:"signature",type:"function",raw:"(event: CalendarEvent) => void",signature:{arguments:[{type:{name:"CalendarEvent"},name:"event"}],return:{name:"void"}}},description:"Day view: callback when an event's edit button is clicked"},viewMode:{required:!1,tsType:{name:"union",raw:"'month' | 'week' | 'day'",elements:[{name:"literal",value:"'month'"},{name:"literal",value:"'week'"},{name:"literal",value:"'day'"}]},description:"Initial view mode",defaultValue:{value:"'month'",computed:!1}},initialDate:{required:!1,tsType:{name:"Date"},description:"Initial date to display",defaultValue:{value:"new Date()",computed:!1}},config:{required:!1,tsType:{name:"CalendarConfig"},description:"Configuration options",defaultValue:{value:"{}",computed:!1}},className:{required:!1,tsType:{name:"string"},description:"Custom CSS class",defaultValue:{value:"''",computed:!1}},style:{required:!1,tsType:{name:"ReactCSSProperties",raw:"React.CSSProperties"},description:"Custom styles",defaultValue:{value:"{}",computed:!1}},loading:{required:!1,tsType:{name:"boolean"},description:"Loading state",defaultValue:{value:"false",computed:!1}},emptyState:{required:!1,tsType:{name:"ReactReactNode",raw:"React.ReactNode"},description:"Custom empty state component"},hideHeader:{required:!1,tsType:{name:"boolean"},description:"Hide the calendar header (navigation, title, view controls)",defaultValue:{value:"false",computed:!1}},compact:{required:!1,tsType:{name:"boolean"},description:"Compact mode - renders colored dots instead of event blocks in month view",defaultValue:{value:"false",computed:!1}},selectedDate:{required:!1,tsType:{name:"Date"},description:"Externally controlled selected date highlight (distinct from initialDate which controls navigation)"},selectedCategoryId:{required:!1,tsType:{name:"union",raw:"string | null",elements:[{name:"string"},{name:"null"}]},description:'Controlled category filter selection. `null` means "All". Omit for uncontrolled.'},onCategoryChange:{required:!1,tsType:{name:"signature",type:"function",raw:"(categoryId: string | null) => void",signature:{arguments:[{type:{name:"union",raw:"string | null",elements:[{name:"string"},{name:"null"}]},name:"categoryId"}],return:{name:"void"}}},description:'Called when the user picks a pill in the category filter. `null` = "All".'},exportFormats:{required:!1,tsType:{name:"Array",elements:[{name:"union",raw:"'csv' | 'json' | 'toon'",elements:[{name:"literal",value:"'csv'"},{name:"literal",value:"'json'"},{name:"literal",value:"'toon'"}]}],raw:"ExportFormat[]"},description:'Offer an "Export" dropdown in the header with the given formats. Exports the currently\nfiltered events (respects category filter). Omit or pass `[]` to hide the button.'}}};const uo={title:"Organisms/Calendar",component:se,parameters:{layout:"padded"},argTypes:{viewMode:{control:"radio",options:["month","week","day"]},compact:{control:"boolean"},config:{control:"object"},onEventClick:{action:"event-clicked"},onDateClick:{action:"date-clicked"},onTimeSlotClick:{action:"slot-clicked"}}},oe=["#4A90E2","#7ED321","#BD10E0","#F5B829","#FF6B6B","#4ECDC4","#7C6FBF"],re=["Morning standup","Sprint planning","Code review","1:1 with manager","Design critique","Client demo","Deep work","Lunch with Ava","Architecture review","Release sign-off","Interview (FE)","Write weekly summary","Bug triage","Pairing session","Retro","Security debrief"],Be=["meeting","task","review","deadline"],W=(o,a=0)=>`${o.toString().padStart(2,"0")}:${a.toString().padStart(2,"0")}`,Qa=o=>{let a=o;return()=>{a|=0,a=a+1831565813|0;let s=Math.imul(a^a>>>15,1|a);return s=s+Math.imul(s^s>>>7,61|s)^s,((s^s>>>14)>>>0)/4294967296}},ie=(o=42)=>{const a=Qa(o),s=new Date,l=[];for(let d=0;d<28;d++){const u=new Date(s);u.setDate(s.getDate()+Math.floor(a()*30)-15);const c=8+Math.floor(a()*10),h=a()>.5?0:30;l.push({id:`m-${d}`,title:re[d%re.length],date:u,time:a()>.35?W(c,h):void 0,type:Be[Math.floor(a()*Be.length)],status:a()>.75?"completed":"pending",color:oe[d%oe.length],textColor:"#ffffff"})}return l},Vt=()=>{const o=new Date,a=(s,l=0)=>{const d=new Date(o);return d.setHours(s,l,0,0),d};return[{id:"ad-1",title:"Offsite — Q2 planning",date:a(0),allDay:!0,color:"#7C6FBF",textColor:"#ffffff"},{id:"d-1",title:"Morning standup",date:a(9),time:"09:00",endTime:"09:30",status:"completed",color:"#4A90E2",textColor:"#ffffff"},{id:"d-2",title:"Deep work: refactor auth",date:a(10),time:"10:00",endTime:"12:00",color:"#F5B829",textColor:"#1a1a1a"},{id:"d-3",title:"Lunch with Ava",date:a(12,30),time:"12:30",endTime:"13:30",color:"#4ECDC4",textColor:"#1a1a1a"},{id:"d-4",title:"1:1 with manager",date:a(14),time:"14:00",endTime:"14:30",color:"#BD10E0",textColor:"#ffffff"},{id:"d-5",title:"Design review",date:a(15),time:"15:00",endTime:"16:30",color:"#FF6B6B",textColor:"#ffffff"},{id:"d-6",title:"Write weekly summary",date:a(17,30),time:"17:30",endTime:"18:00",color:"#10b981",textColor:"#ffffff"}]},Ka=o=>{const a={meeting:"👥",task:"✓",review:"👀",deadline:"⏰"};return e.jsx("span",{style:{fontSize:11},children:a[o.type??""]??"📅"})},Se={args:{events:ie(),viewMode:"month",config:{mondayStart:!0,maxEventsPerDay:3,iconRenderer:Ka}},render:o=>{const[a,s]=S.useState(o.events??[]);return e.jsx(se,{...o,events:a,onEventClick:l=>{s(d=>d.map(u=>u.id===l.id?{...u,status:u.status==="completed"?"pending":"completed"}:u))},onDateClick:l=>{s(d=>[...d,{id:`new-${Date.now()}`,title:"New event",date:l,time:"15:00",type:"task",status:"pending",color:"#6366f1",textColor:"#ffffff"}])}})}},ke={args:{events:[],viewMode:"week",config:{mondayStart:!0,startHour:7,endHour:22,hourHeight:56,halfHourSlots:!0}},render:o=>{const a=new Date,s=(a.getDay()+6)%7,l=new Date(a);l.setDate(a.getDate()-s),l.setHours(0,0,0,0);const d=[];for(let h=0;h<7;h++){const w=new Date(l);w.setDate(l.getDate()+h);const x=h*2%3+1;for(let D=0;D<x;D++){const C=9+D*3+h%2;d.push({id:`w-${h}-${D}`,title:re[(h*3+D)%re.length],date:new Date(w),time:W(C,D%2===0?0:30),endTime:W(C+1,D%2===0?0:30),color:oe[(h+D)%oe.length],textColor:"#ffffff"})}}const[u,c]=S.useState(d);return e.jsx(se,{...o,events:u,onTimeSlotClick:(h,w,x)=>{const D=Math.min(23,h.getHours()+1);c(C=>[...C,{id:`new-${Date.now()}`,title:`New @ ${x}`,date:h,time:x,endTime:W(D,h.getMinutes()),color:"#6366f1",textColor:"#ffffff"}])},onEventComplete:h=>c(w=>w.map(x=>x.id===h.id?{...x,status:x.status==="completed"?"pending":"completed"}:x)),onEventDelete:h=>c(w=>w.filter(x=>x.id!==h.id)),onEventDrop:(h,w)=>{c(x=>x.map(D=>{if(D.id!==h.id)return D;const C=new Date(D.date),b=w.getTime()-C.getTime(),I=(()=>{if(!D.endTime||!D.time)return D.endTime;const[H,K]=D.endTime.split(":").map(Number),q=new Date(C);q.setHours(H,K,0,0);const Z=new Date(q.getTime()+b);return W(Z.getHours(),Z.getMinutes())})();return{...D,date:w,time:W(w.getHours(),w.getMinutes()),endTime:I}}))}})}},je={args:{events:[],viewMode:"day",config:{startHour:6,endHour:24,hourHeight:72,halfHourSlots:!0,mondayStart:!0}},render:o=>{const[a,s]=S.useState(Vt());return e.jsx(se,{...o,events:a,onTimeSlotClick:(l,d,u)=>{const c=Math.min(23,l.getHours()+1);s(h=>[...h,{id:`new-${Date.now()}`,title:`New @ ${u}`,date:l,time:u,endTime:W(c,l.getMinutes()),color:"#6366f1",textColor:"#ffffff"}])},onEventComplete:l=>s(d=>d.map(u=>u.id===l.id?{...u,status:u.status==="completed"?"pending":"completed"}:u)),onEventDelete:l=>s(d=>d.filter(u=>u.id!==l.id)),onEventEdit:l=>{const d=window.prompt("Rename event",l.title);d&&s(u=>u.map(c=>c.id===l.id?{...c,title:d}:c))},onEventDrop:(l,d)=>{s(u=>u.map(c=>{if(c.id!==l.id)return c;const h=new Date(c.date),w=d.getTime()-h.getTime(),x=(()=>{if(!c.endTime||!c.time)return c.endTime;const[D,C]=c.endTime.split(":").map(Number),b=new Date(h);b.setHours(D,C,0,0);const I=new Date(b.getTime()+w);return W(I.getHours(),I.getMinutes())})();return{...c,date:d,time:W(d.getHours(),d.getMinutes()),endTime:x}}))}})}},Ce={args:{events:ie(1).map((a,s)=>({...a,category:s%3===0?"work":s%3===1?"life":"side"})),viewMode:"month",compact:!0,config:{mondayStart:!0,maxEventsPerDay:4,categories:[{id:"life",label:"Life",color:"#F5B829"},{id:"work",label:"Work",color:"#7C6FBF"},{id:"side",label:"Side",color:"#4ECDC4"}]},style:{maxWidth:420}}},Te={args:{events:Vt(),viewMode:"day",compact:!0,config:{startHour:7,endHour:22,hourHeight:56,halfHourSlots:!0},style:{maxWidth:520}}},Ee={args:{events:ie(3),viewMode:"month",config:{mondayStart:!0,showWeekNumbers:!0,maxEventsPerDay:3}}},be={args:{events:(()=>{const o=new Date;return Array.from({length:9},(a,s)=>({id:`over-${s}`,title:re[s%re.length],date:new Date(o),time:W(8+s),type:Be[s%Be.length],color:oe[s%oe.length],textColor:"#ffffff"}))})(),viewMode:"month",config:{mondayStart:!0,maxEventsPerDay:3}}},Ne={args:{events:[],loading:!0}},He={args:{events:[],viewMode:"month",config:{mondayStart:!0},emptyState:e.jsx("span",{style:{color:"var(--color-text-tertiary)",fontSize:11},children:"No events"})}},Me={args:{events:ie(5),viewMode:"month",exportFormats:["csv","json","toon"],config:{mondayStart:!0,maxEventsPerDay:3}}},$e={args:{events:ie(11).map((a,s)=>({...a,category:s%3===0?"work":s%3===1?"life":"side"})),viewMode:"month",config:{mondayStart:!0,maxEventsPerDay:3,categories:[{id:"life",label:"Life",color:"#F5B829"},{id:"work",label:"Work",color:"#7C6FBF"},{id:"side",label:"Side projects",color:"#4ECDC4"}]}}},Le={args:{events:[]},render:()=>{const[o,a]=S.useState(new Date),s=S.useMemo(()=>ie(9),[]);return e.jsxs("div",{style:{display:"grid",gap:"var(--spacing-md)"},children:[e.jsxs("div",{style:{fontSize:"var(--font-size-sm)",color:"var(--color-text-secondary)"},children:["Selected: ",e.jsx("strong",{children:o.toLocaleDateString()})]}),e.jsx(se,{events:s,viewMode:"month",selectedDate:o,onDateClick:a,config:{mondayStart:!0,maxEventsPerDay:3}})]})}};var it,lt,dt;Se.parameters={...Se.parameters,docs:{...(it=Se.parameters)==null?void 0:it.docs,source:{originalSource:`{
|
|
48
|
+
args: {
|
|
49
|
+
events: buildMonthEvents(),
|
|
50
|
+
viewMode: 'month',
|
|
51
|
+
config: {
|
|
52
|
+
mondayStart: true,
|
|
53
|
+
maxEventsPerDay: 3,
|
|
54
|
+
iconRenderer: iconForType
|
|
55
|
+
}
|
|
56
|
+
},
|
|
57
|
+
render: args => {
|
|
58
|
+
const [events, setEvents] = useState<CalendarEvent[]>(args.events ?? []);
|
|
59
|
+
return <Calendar {...args} events={events} onEventClick={e => {
|
|
60
|
+
setEvents(prev => prev.map(ev => ev.id === e.id ? {
|
|
61
|
+
...ev,
|
|
62
|
+
status: ev.status === 'completed' ? 'pending' : 'completed'
|
|
63
|
+
} : ev));
|
|
64
|
+
}} onDateClick={date => {
|
|
65
|
+
setEvents(prev => [...prev, {
|
|
66
|
+
id: \`new-\${Date.now()}\`,
|
|
67
|
+
title: 'New event',
|
|
68
|
+
date,
|
|
69
|
+
time: '15:00',
|
|
70
|
+
type: 'task',
|
|
71
|
+
status: 'pending',
|
|
72
|
+
color: '#6366f1',
|
|
73
|
+
textColor: '#ffffff'
|
|
74
|
+
}]);
|
|
75
|
+
}} />;
|
|
76
|
+
}
|
|
77
|
+
}`,...(dt=(lt=Se.parameters)==null?void 0:lt.docs)==null?void 0:dt.source}}};var ct,mt,ut;ke.parameters={...ke.parameters,docs:{...(ct=ke.parameters)==null?void 0:ct.docs,source:{originalSource:`{
|
|
78
|
+
args: {
|
|
79
|
+
events: [],
|
|
80
|
+
viewMode: 'week',
|
|
81
|
+
config: {
|
|
82
|
+
mondayStart: true,
|
|
83
|
+
startHour: 7,
|
|
84
|
+
endHour: 22,
|
|
85
|
+
hourHeight: 56,
|
|
86
|
+
halfHourSlots: true
|
|
87
|
+
}
|
|
88
|
+
},
|
|
89
|
+
render: args => {
|
|
90
|
+
// Build 7 days of timed events around "today" so drag has neighbours to land on
|
|
91
|
+
const today = new Date();
|
|
92
|
+
const mondayOffset = (today.getDay() + 6) % 7;
|
|
93
|
+
const weekStart = new Date(today);
|
|
94
|
+
weekStart.setDate(today.getDate() - mondayOffset);
|
|
95
|
+
weekStart.setHours(0, 0, 0, 0);
|
|
96
|
+
const initial: CalendarEvent[] = [];
|
|
97
|
+
for (let i = 0; i < 7; i++) {
|
|
98
|
+
const d = new Date(weekStart);
|
|
99
|
+
d.setDate(weekStart.getDate() + i);
|
|
100
|
+
const count = i * 2 % 3 + 1;
|
|
101
|
+
for (let j = 0; j < count; j++) {
|
|
102
|
+
const startH = 9 + j * 3 + i % 2;
|
|
103
|
+
initial.push({
|
|
104
|
+
id: \`w-\${i}-\${j}\`,
|
|
105
|
+
title: TITLES[(i * 3 + j) % TITLES.length],
|
|
106
|
+
date: new Date(d),
|
|
107
|
+
time: hhmm(startH, j % 2 === 0 ? 0 : 30),
|
|
108
|
+
endTime: hhmm(startH + 1, j % 2 === 0 ? 0 : 30),
|
|
109
|
+
color: PALETTE[(i + j) % PALETTE.length],
|
|
110
|
+
textColor: '#ffffff'
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
const [events, setEvents] = useState<CalendarEvent[]>(initial);
|
|
115
|
+
return <Calendar {...args} events={events} onTimeSlotClick={(date, _h, time) => {
|
|
116
|
+
const endH = Math.min(23, date.getHours() + 1);
|
|
117
|
+
setEvents(prev => [...prev, {
|
|
118
|
+
id: \`new-\${Date.now()}\`,
|
|
119
|
+
title: \`New @ \${time}\`,
|
|
120
|
+
date,
|
|
121
|
+
time,
|
|
122
|
+
endTime: hhmm(endH, date.getMinutes()),
|
|
123
|
+
color: '#6366f1',
|
|
124
|
+
textColor: '#ffffff'
|
|
125
|
+
}]);
|
|
126
|
+
}} onEventComplete={e => setEvents(prev => prev.map(ev => ev.id === e.id ? {
|
|
127
|
+
...ev,
|
|
128
|
+
status: ev.status === 'completed' ? 'pending' : 'completed'
|
|
129
|
+
} : ev))} onEventDelete={e => setEvents(prev => prev.filter(ev => ev.id !== e.id))} onEventDrop={(e, newDate) => {
|
|
130
|
+
setEvents(prev => prev.map(ev => {
|
|
131
|
+
if (ev.id !== e.id) return ev;
|
|
132
|
+
const oldStart = new Date(ev.date);
|
|
133
|
+
const deltaMs = newDate.getTime() - oldStart.getTime();
|
|
134
|
+
const nextEndTime = (() => {
|
|
135
|
+
if (!ev.endTime || !ev.time) return ev.endTime;
|
|
136
|
+
const [oh, om] = ev.endTime.split(':').map(Number);
|
|
137
|
+
const endOld = new Date(oldStart);
|
|
138
|
+
endOld.setHours(oh, om, 0, 0);
|
|
139
|
+
const endNew = new Date(endOld.getTime() + deltaMs);
|
|
140
|
+
return hhmm(endNew.getHours(), endNew.getMinutes());
|
|
141
|
+
})();
|
|
142
|
+
return {
|
|
143
|
+
...ev,
|
|
144
|
+
date: newDate,
|
|
145
|
+
time: hhmm(newDate.getHours(), newDate.getMinutes()),
|
|
146
|
+
endTime: nextEndTime
|
|
147
|
+
};
|
|
148
|
+
}));
|
|
149
|
+
}} />;
|
|
150
|
+
}
|
|
151
|
+
}`,...(ut=(mt=ke.parameters)==null?void 0:mt.docs)==null?void 0:ut.source}}};var pt,yt,gt;je.parameters={...je.parameters,docs:{...(pt=je.parameters)==null?void 0:pt.docs,source:{originalSource:`{
|
|
152
|
+
args: {
|
|
153
|
+
events: [],
|
|
154
|
+
viewMode: 'day',
|
|
155
|
+
config: {
|
|
156
|
+
startHour: 6,
|
|
157
|
+
endHour: 24,
|
|
158
|
+
hourHeight: 72,
|
|
159
|
+
halfHourSlots: true,
|
|
160
|
+
mondayStart: true
|
|
161
|
+
}
|
|
162
|
+
},
|
|
163
|
+
render: args => {
|
|
164
|
+
const [events, setEvents] = useState<CalendarEvent[]>(buildDayEvents());
|
|
165
|
+
return <Calendar {...args} events={events} onTimeSlotClick={(date, _h, time) => {
|
|
166
|
+
const endH = Math.min(23, date.getHours() + 1);
|
|
167
|
+
setEvents(prev => [...prev, {
|
|
168
|
+
id: \`new-\${Date.now()}\`,
|
|
169
|
+
title: \`New @ \${time}\`,
|
|
170
|
+
date,
|
|
171
|
+
time,
|
|
172
|
+
endTime: hhmm(endH, date.getMinutes()),
|
|
173
|
+
color: '#6366f1',
|
|
174
|
+
textColor: '#ffffff'
|
|
175
|
+
}]);
|
|
176
|
+
}} onEventComplete={e => setEvents(prev => prev.map(ev => ev.id === e.id ? {
|
|
177
|
+
...ev,
|
|
178
|
+
status: ev.status === 'completed' ? 'pending' : 'completed'
|
|
179
|
+
} : ev))} onEventDelete={e => setEvents(prev => prev.filter(ev => ev.id !== e.id))} onEventEdit={e => {
|
|
180
|
+
const next = window.prompt('Rename event', e.title);
|
|
181
|
+
if (!next) return;
|
|
182
|
+
setEvents(prev => prev.map(ev => ev.id === e.id ? {
|
|
183
|
+
...ev,
|
|
184
|
+
title: next
|
|
185
|
+
} : ev));
|
|
186
|
+
}} onEventDrop={(e, newDate) => {
|
|
187
|
+
setEvents(prev => prev.map(ev => {
|
|
188
|
+
if (ev.id !== e.id) return ev;
|
|
189
|
+
const oldStart = new Date(ev.date);
|
|
190
|
+
const deltaMs = newDate.getTime() - oldStart.getTime();
|
|
191
|
+
const nextEndTime = (() => {
|
|
192
|
+
if (!ev.endTime || !ev.time) return ev.endTime;
|
|
193
|
+
const [oh, om] = ev.endTime.split(':').map(Number);
|
|
194
|
+
const endOld = new Date(oldStart);
|
|
195
|
+
endOld.setHours(oh, om, 0, 0);
|
|
196
|
+
const endNew = new Date(endOld.getTime() + deltaMs);
|
|
197
|
+
return hhmm(endNew.getHours(), endNew.getMinutes());
|
|
198
|
+
})();
|
|
199
|
+
return {
|
|
200
|
+
...ev,
|
|
201
|
+
date: newDate,
|
|
202
|
+
time: hhmm(newDate.getHours(), newDate.getMinutes()),
|
|
203
|
+
endTime: nextEndTime
|
|
204
|
+
};
|
|
205
|
+
}));
|
|
206
|
+
}} />;
|
|
207
|
+
}
|
|
208
|
+
}`,...(gt=(yt=je.parameters)==null?void 0:yt.docs)==null?void 0:gt.source}}};var vt,ht,ft;Ce.parameters={...Ce.parameters,docs:{...(vt=Ce.parameters)==null?void 0:vt.docs,source:{originalSource:`{
|
|
209
|
+
args: {
|
|
210
|
+
events: (() => {
|
|
211
|
+
const base = buildMonthEvents(1);
|
|
212
|
+
return base.map((e, i) => ({
|
|
213
|
+
...e,
|
|
214
|
+
category: i % 3 === 0 ? 'work' : i % 3 === 1 ? 'life' : 'side'
|
|
215
|
+
}));
|
|
216
|
+
})(),
|
|
217
|
+
viewMode: 'month',
|
|
218
|
+
compact: true,
|
|
219
|
+
config: {
|
|
220
|
+
mondayStart: true,
|
|
221
|
+
maxEventsPerDay: 4,
|
|
222
|
+
categories: [{
|
|
223
|
+
id: 'life',
|
|
224
|
+
label: 'Life',
|
|
225
|
+
color: '#F5B829'
|
|
226
|
+
}, {
|
|
227
|
+
id: 'work',
|
|
228
|
+
label: 'Work',
|
|
229
|
+
color: '#7C6FBF'
|
|
230
|
+
}, {
|
|
231
|
+
id: 'side',
|
|
232
|
+
label: 'Side',
|
|
233
|
+
color: '#4ECDC4'
|
|
234
|
+
}]
|
|
235
|
+
},
|
|
236
|
+
style: {
|
|
237
|
+
maxWidth: 420
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
}`,...(ft=(ht=Ce.parameters)==null?void 0:ht.docs)==null?void 0:ft.source}}};var wt,Dt,_t;Te.parameters={...Te.parameters,docs:{...(wt=Te.parameters)==null?void 0:wt.docs,source:{originalSource:`{
|
|
241
|
+
args: {
|
|
242
|
+
events: buildDayEvents(),
|
|
243
|
+
viewMode: 'day',
|
|
244
|
+
compact: true,
|
|
245
|
+
config: {
|
|
246
|
+
startHour: 7,
|
|
247
|
+
endHour: 22,
|
|
248
|
+
hourHeight: 56,
|
|
249
|
+
halfHourSlots: true
|
|
250
|
+
},
|
|
251
|
+
style: {
|
|
252
|
+
maxWidth: 520
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
}`,...(_t=(Dt=Te.parameters)==null?void 0:Dt.docs)==null?void 0:_t.source}}};var xt,St,kt;Ee.parameters={...Ee.parameters,docs:{...(xt=Ee.parameters)==null?void 0:xt.docs,source:{originalSource:`{
|
|
256
|
+
args: {
|
|
257
|
+
events: buildMonthEvents(3),
|
|
258
|
+
viewMode: 'month',
|
|
259
|
+
config: {
|
|
260
|
+
mondayStart: true,
|
|
261
|
+
showWeekNumbers: true,
|
|
262
|
+
maxEventsPerDay: 3
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
}`,...(kt=(St=Ee.parameters)==null?void 0:St.docs)==null?void 0:kt.source}}};var jt,Ct,Tt;be.parameters={...be.parameters,docs:{...(jt=be.parameters)==null?void 0:jt.docs,source:{originalSource:`{
|
|
266
|
+
args: {
|
|
267
|
+
events: (() => {
|
|
268
|
+
const today = new Date();
|
|
269
|
+
return Array.from({
|
|
270
|
+
length: 9
|
|
271
|
+
}, (_, i) => ({
|
|
272
|
+
id: \`over-\${i}\`,
|
|
273
|
+
title: TITLES[i % TITLES.length],
|
|
274
|
+
date: new Date(today),
|
|
275
|
+
time: hhmm(8 + i),
|
|
276
|
+
type: TYPES[i % TYPES.length],
|
|
277
|
+
color: PALETTE[i % PALETTE.length],
|
|
278
|
+
textColor: '#ffffff'
|
|
279
|
+
}));
|
|
280
|
+
})(),
|
|
281
|
+
viewMode: 'month',
|
|
282
|
+
config: {
|
|
283
|
+
mondayStart: true,
|
|
284
|
+
maxEventsPerDay: 3
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
}`,...(Tt=(Ct=be.parameters)==null?void 0:Ct.docs)==null?void 0:Tt.source}}};var Et,bt,Nt;Ne.parameters={...Ne.parameters,docs:{...(Et=Ne.parameters)==null?void 0:Et.docs,source:{originalSource:`{
|
|
288
|
+
args: {
|
|
289
|
+
events: [],
|
|
290
|
+
loading: true
|
|
291
|
+
}
|
|
292
|
+
}`,...(Nt=(bt=Ne.parameters)==null?void 0:bt.docs)==null?void 0:Nt.source}}};var Ht,Mt,$t;He.parameters={...He.parameters,docs:{...(Ht=He.parameters)==null?void 0:Ht.docs,source:{originalSource:`{
|
|
293
|
+
args: {
|
|
294
|
+
events: [],
|
|
295
|
+
viewMode: 'month',
|
|
296
|
+
config: {
|
|
297
|
+
mondayStart: true
|
|
298
|
+
},
|
|
299
|
+
emptyState: <span style={{
|
|
300
|
+
color: 'var(--color-text-tertiary)',
|
|
301
|
+
fontSize: 11
|
|
302
|
+
}}>
|
|
303
|
+
No events
|
|
304
|
+
</span>
|
|
305
|
+
}
|
|
306
|
+
}`,...($t=(Mt=He.parameters)==null?void 0:Mt.docs)==null?void 0:$t.source}}};var Lt,It,Pt;Me.parameters={...Me.parameters,docs:{...(Lt=Me.parameters)==null?void 0:Lt.docs,source:{originalSource:`{
|
|
307
|
+
args: {
|
|
308
|
+
events: buildMonthEvents(5),
|
|
309
|
+
viewMode: 'month',
|
|
310
|
+
exportFormats: ['csv', 'json', 'toon'],
|
|
311
|
+
config: {
|
|
312
|
+
mondayStart: true,
|
|
313
|
+
maxEventsPerDay: 3
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
}`,...(Pt=(It=Me.parameters)==null?void 0:It.docs)==null?void 0:Pt.source}}};var Bt,Ft,Wt;$e.parameters={...$e.parameters,docs:{...(Bt=$e.parameters)==null?void 0:Bt.docs,source:{originalSource:`{
|
|
317
|
+
args: {
|
|
318
|
+
events: (() => {
|
|
319
|
+
const base = buildMonthEvents(11);
|
|
320
|
+
return base.map((e, i) => ({
|
|
321
|
+
...e,
|
|
322
|
+
category: i % 3 === 0 ? 'work' : i % 3 === 1 ? 'life' : 'side'
|
|
323
|
+
}));
|
|
324
|
+
})(),
|
|
325
|
+
viewMode: 'month',
|
|
326
|
+
config: {
|
|
327
|
+
mondayStart: true,
|
|
328
|
+
maxEventsPerDay: 3,
|
|
329
|
+
categories: [{
|
|
330
|
+
id: 'life',
|
|
331
|
+
label: 'Life',
|
|
332
|
+
color: '#F5B829'
|
|
333
|
+
}, {
|
|
334
|
+
id: 'work',
|
|
335
|
+
label: 'Work',
|
|
336
|
+
color: '#7C6FBF'
|
|
337
|
+
}, {
|
|
338
|
+
id: 'side',
|
|
339
|
+
label: 'Side projects',
|
|
340
|
+
color: '#4ECDC4'
|
|
341
|
+
}]
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
}`,...(Wt=(Ft=$e.parameters)==null?void 0:Ft.docs)==null?void 0:Wt.source}}};var At,Ot,Rt;Le.parameters={...Le.parameters,docs:{...(At=Le.parameters)==null?void 0:At.docs,source:{originalSource:`{
|
|
345
|
+
args: {
|
|
346
|
+
events: []
|
|
347
|
+
},
|
|
348
|
+
render: () => {
|
|
349
|
+
const [selected, setSelected] = useState(new Date());
|
|
350
|
+
const events = useMemo(() => buildMonthEvents(9), []);
|
|
351
|
+
return <div style={{
|
|
352
|
+
display: 'grid',
|
|
353
|
+
gap: 'var(--spacing-md)'
|
|
354
|
+
}}>
|
|
355
|
+
<div style={{
|
|
356
|
+
fontSize: 'var(--font-size-sm)',
|
|
357
|
+
color: 'var(--color-text-secondary)'
|
|
358
|
+
}}>
|
|
359
|
+
Selected: <strong>{selected.toLocaleDateString()}</strong>
|
|
360
|
+
</div>
|
|
361
|
+
<Calendar events={events} viewMode="month" selectedDate={selected} onDateClick={setSelected} config={{
|
|
362
|
+
mondayStart: true,
|
|
363
|
+
maxEventsPerDay: 3
|
|
364
|
+
}} />
|
|
365
|
+
</div>;
|
|
366
|
+
}
|
|
367
|
+
}`,...(Rt=(Ot=Le.parameters)==null?void 0:Ot.docs)==null?void 0:Rt.source}}};const po=["Default","WeekView","DayView","CompactMonth","CompactDay","WithWeekNumbers","OverflowDay","Loading","Empty","WithExport","WithCategoryFilter","ControlledSelection"];export{Te as CompactDay,Ce as CompactMonth,Le as ControlledSelection,je as DayView,Se as Default,He as Empty,Ne as Loading,be as OverflowDay,ke as WeekView,$e as WithCategoryFilter,Me as WithExport,Ee as WithWeekNumbers,po as __namedExportsOrder,uo as default};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as I,j as e}from"./iframe-
|
|
1
|
+
import{r as I,j as e}from"./iframe-CK6Mw28k.js";import{A as M}from"./index-DhjWRu4G.js";import{m as _}from"./proxy-Bl04PYET.js";const B="_card_k0xft_1",V="_hoverable_k0xft_50",A="_elevated_k0xft_65",L="_outlined_k0xft_78",S="_flat_k0xft_111",E="_glass_k0xft_156",W="_imageContainer_k0xft_187",F="_image_k0xft_187",H="_header_k0xft_233",R="_headerContent_k0xft_248",O="_expandButton_k0xft_254",D="_expandIcon_k0xft_285",J="_expandableContent_k0xft_289",U="_expandable_k0xft_289",X="_body_k0xft_313",z="_footer_k0xft_319",G="_title_k0xft_350",K="_subtitle_k0xft_366",Q="_clickable_k0xft_380",Y="_padding_k0xft_394",Z="_noPadding_k0xft_398",$="_loading_k0xft_403",ee="_loadingShimmer_k0xft_1",ae="_loadingPulse_k0xft_1",a={card:B,hoverable:V,elevated:A,outlined:L,flat:S,glass:E,imageContainer:W,image:F,header:H,headerContent:R,expandButton:O,expandIcon:D,expandableContent:J,expandable:U,body:X,footer:z,title:G,subtitle:K,clickable:Q,padding:Y,noPadding:Z,loading:$,loadingShimmer:ee,loadingPulse:ae},te=({variant:g="elevated",hoverable:d=!1,clickable:l=!1,padding:c=!0,image:p,imageAlt:v="",title:o,subtitle:s,header:u,footer:m,children:f,expandable:t=!1,defaultExpanded:C=!1,expanded:i,onExpandChange:r,className:b="",onClick:k,motionProps:y,...j})=>{const[T,N]=I.useState(C),n=i!==void 0?i:T,h=()=>{const x=!n;i===void 0&&N(x),r==null||r(x)},q=[a.card,a[g],d&&a.hoverable,l&&a.clickable,!c&&a.noPadding,t&&a.expandable,b].filter(Boolean).join(" "),w=()=>u?e.jsxs("div",{className:a.header,children:[e.jsx("div",{className:a.headerContent,children:u}),t&&e.jsx("button",{className:a.expandButton,onClick:h,"aria-label":n?"Collapse card":"Expand card",children:e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:a.expandIcon,style:{transform:n?"rotate(180deg)":"rotate(0deg)"},children:e.jsx("path",{d:"M6 9l6 6 6-6"})})})]}):o||s?e.jsxs("div",{className:a.header,children:[e.jsxs("div",{className:a.headerContent,children:[o&&e.jsx("h3",{className:a.title,children:o}),s&&e.jsx("p",{className:a.subtitle,children:s})]}),t&&e.jsx("button",{className:a.expandButton,onClick:h,"aria-label":n?"Collapse card":"Expand card",children:e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:a.expandIcon,style:{transform:n?"rotate(180deg)":"rotate(0deg)"},children:e.jsx("path",{d:"M6 9l6 6 6-6"})})})]}):null,P=e.jsxs(e.Fragment,{children:[p&&e.jsx("div",{className:a.imageContainer,children:e.jsx("img",{src:p,alt:v,className:a.image})}),w(),e.jsx(M,{initial:!1,children:(!t||n)&&e.jsxs(_.div,{initial:t?{height:0,opacity:0}:void 0,animate:t?{height:"auto",opacity:1}:void 0,exit:t?{height:0,opacity:0}:void 0,transition:{duration:.3,ease:"easeInOut"},className:a.expandableContent,children:[f&&e.jsx("div",{className:c?a.body:void 0,children:f}),m&&e.jsx("div",{className:a.footer,children:m})]},"content")})]});return e.jsx(_.div,{className:q,onClick:l?k:void 0,whileHover:d?{y:-4}:void 0,transition:{type:"spring",stiffness:400,damping:17},...y,...j,children:P})};te.__docgenInfo={description:`Card Component
|
|
2
2
|
|
|
3
3
|
@component
|
|
4
4
|
@description
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{j as e,r as T}from"./iframe-
|
|
1
|
+
import{j as e,r as T}from"./iframe-CK6Mw28k.js";import{C as a}from"./Card-zYnUu79L.js";import{B as t}from"./Button-ca-WP0WI.js";import"./preload-helper-C1FmrZbK.js";import"./index-DhjWRu4G.js";import"./proxy-Bl04PYET.js";import"./MotionConfigContext-Bw_b3ZUg.js";import"./useSound-D6Fr1PWT.js";const D={title:"Atoms/Card",component:a,parameters:{layout:"centered",docs:{description:{component:"A flexible container component with various styling options and animation support."}}},argTypes:{variant:{control:"select",options:["elevated","outlined","flat","glass"],description:"Visual style variant of the card"},padding:{control:"boolean"},hoverable:{control:"boolean"},clickable:{control:"boolean"},expandable:{control:"boolean"},defaultExpanded:{control:"boolean"},title:{control:"text"},subtitle:{control:"text"},onClick:{action:"clicked"},onExpandChange:{action:"expand-changed"}}},r={args:{title:"Card Title",subtitle:"Optional subtitle",hoverable:!0,children:e.jsx("p",{children:"Card content goes here. Use controls to switch between elevated, outlined, flat, and glass variants."})}},n={args:{variant:"elevated",hoverable:!0,image:"https://via.placeholder.com/350x200",imageAlt:"Feature image",children:e.jsxs("div",{style:{maxWidth:"350px"},children:[e.jsx("h2",{style:{marginBottom:"0.5rem"},children:"Feature Card"}),e.jsx("p",{style:{marginBottom:"1rem",color:"#666"},children:"Image, title, description, and action buttons composed together."}),e.jsxs("div",{style:{display:"flex",gap:"0.5rem"},children:[e.jsx(t,{variant:"primary",size:"small",children:"Learn More"}),e.jsx(t,{variant:"outline",size:"small",children:"Share"})]})]})}},l={render:()=>e.jsxs("div",{style:{display:"grid",gridTemplateColumns:"repeat(3, 1fr)",gap:"1rem",maxWidth:"800px"},children:[e.jsxs(a,{variant:"elevated",hoverable:!0,children:[e.jsx("h4",{children:"Elevated"}),e.jsx("p",{children:"With shadow"})]}),e.jsxs(a,{variant:"outlined",hoverable:!0,children:[e.jsx("h4",{children:"Outlined"}),e.jsx("p",{children:"With border"})]}),e.jsxs(a,{variant:"glass",hoverable:!0,children:[e.jsx("h4",{children:"Glass"}),e.jsx("p",{children:"Glassmorphism"})]})]}),parameters:{controls:{disable:!0},layout:"padded"}},s={args:{title:"Expandable Card",subtitle:"Click the arrow to expand",expandable:!0,variant:"outlined",children:e.jsxs("div",{children:[e.jsx("p",{children:"This content is collapsible. Useful for FAQ sections, settings panels, or progressive disclosure."}),e.jsxs("div",{style:{display:"flex",gap:"0.5rem",marginTop:"1rem"},children:[e.jsx(t,{variant:"primary",size:"small",children:"Action"}),e.jsx(t,{variant:"outline",size:"small",children:"Secondary"})]})]})}},i={render:()=>{const[d,p]=T.useState(!1);return e.jsxs("div",{style:{width:"400px"},children:[e.jsxs(a,{title:"Controlled Expandable",subtitle:"State managed externally",expandable:!0,expanded:d,onExpandChange:p,variant:"glass",hoverable:!0,children:[e.jsx("p",{children:"Expanded state is controlled via props."}),e.jsxs("p",{children:["Current: ",e.jsx("strong",{children:d?"Expanded":"Collapsed"})]})]}),e.jsx("div",{style:{marginTop:"1rem",textAlign:"center"},children:e.jsx(t,{variant:"primary",onClick:()=>p(!d),children:"External Toggle"})})]})},parameters:{controls:{disable:!0}}},o={render:()=>e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"1rem",maxWidth:"600px"},children:[e.jsx(a,{title:"Getting Started",expandable:!0,variant:"outlined",children:e.jsx("p",{children:"Create an account and follow the onboarding tutorial to get started."})}),e.jsx(a,{title:"Account Management",expandable:!0,variant:"outlined",children:e.jsx("p",{children:"Manage settings from the profile page: personal info, password, notifications."})}),e.jsx(a,{title:"Billing & Payments",expandable:!0,defaultExpanded:!0,variant:"outlined",children:e.jsx("p",{children:"We accept all major credit cards and PayPal. Billing is monthly or annual."})})]}),parameters:{controls:{disable:!0},layout:"padded"}};var c,m,u;r.parameters={...r.parameters,docs:{...(c=r.parameters)==null?void 0:c.docs,source:{originalSource:`{
|
|
2
2
|
args: {
|
|
3
3
|
title: 'Card Title',
|
|
4
4
|
subtitle: 'Optional subtitle',
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as o,j as t}from"./iframe-
|
|
1
|
+
import{r as o,j as t}from"./iframe-CK6Mw28k.js";import{g as u}from"./index-C8pce-KX.js";import{G as M}from"./iconBase-qbjzzLYR.js";import"./preload-helper-C1FmrZbK.js";function U(f){return M({attr:{viewBox:"0 0 24 24"},child:[{tag:"path",attr:{d:"M18.25 15.5a.75.75 0 0 1-.75-.75V7.56L7.28 17.78a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734L16.44 6.5H9.25a.75.75 0 0 1 0-1.5h9a.75.75 0 0 1 .75.75v9a.75.75 0 0 1-.75.75Z"},child:[]}]})(f)}const G="_open_87iwp_63",O="_logo_87iwp_71",n={"card-nav-container":"_card-nav-container_87iwp_1","card-nav":"_card-nav_87iwp_1","card-nav-top":"_card-nav-top_87iwp_25","hamburger-menu":"_hamburger-menu_87iwp_38","hamburger-line":"_hamburger-line_87iwp_48",open:G,"logo-container":"_logo-container_87iwp_71",logo:O,"card-nav-cta-button":"_card-nav-cta-button_87iwp_84","card-nav-content":"_card-nav-content_87iwp_101","nav-card":"_nav-card_87iwp_121","nav-card-label":"_nav-card-label_87iwp_134","nav-card-links":"_nav-card-links_87iwp_140","nav-card-link":"_nav-card-link_87iwp_140"},L=({logo:f,logoAlt:$="Logo",items:m,className:N="",ease:b="power3.out",baseColor:k="#fff",menuColor:R,buttonBgColor:j,buttonTextColor:E})=>{const[A,g]=o.useState(!1),[s,_]=o.useState(!1),c=o.useRef(null),p=o.useRef([]),l=o.useRef(null),C=()=>{const e=c.current;if(!e)return 260;if(window.matchMedia("(max-width: 768px)").matches){const a=e.querySelector(".card-nav-content");if(a){const i=a.style.visibility,v=a.style.pointerEvents,S=a.style.position,T=a.style.height;a.style.visibility="visible",a.style.pointerEvents="auto",a.style.position="static",a.style.height="auto",a.offsetHeight;const V=60,q=16,I=a.scrollHeight;return a.style.visibility=i,a.style.pointerEvents=v,a.style.position=S,a.style.height=T,V+I+q}}return 260},h=()=>{const e=c.current;if(!e)return null;u.set(e,{height:60,overflow:"hidden"}),u.set(p.current,{y:50,opacity:0});const r=u.timeline({paused:!0});return r.to(e,{height:C,duration:.4,ease:b}),r.to(p.current,{y:0,opacity:1,duration:.4,ease:b,stagger:.08},"-=0.1"),r};o.useLayoutEffect(()=>{const e=h();return l.current=e,()=>{e==null||e.kill(),l.current=null}},[b,m]),o.useLayoutEffect(()=>{const e=()=>{if(l.current)if(s){const r=C();u.set(c.current,{height:r}),l.current.kill();const a=h();a&&(a.progress(1),l.current=a)}else{l.current.kill();const r=h();r&&(l.current=r)}};return window.addEventListener("resize",e),()=>window.removeEventListener("resize",e)},[s]);const D=()=>{const e=l.current;e&&(s?(g(!1),e.eventCallback("onReverseComplete",()=>_(!1)),e.reverse()):(g(!0),_(!0),e.play(0)))},H=e=>r=>{r&&(p.current[e]=r)};return t.jsx("div",{className:`${n["card-nav-container"]} ${N}`,children:t.jsxs("nav",{ref:c,className:`${n["card-nav"]} ${s?n.open:""}`,style:{backgroundColor:k},children:[t.jsxs("div",{className:`${n["card-nav-top"]}`,children:[t.jsxs("div",{className:`${n["hamburger-menu"]} ${A?n.open:""}`,onClick:D,role:"button","aria-label":s?"Close menu":"Open menu",tabIndex:0,style:{color:R||"#000"},children:[t.jsx("div",{className:`${n["hamburger-line"]}`}),t.jsx("div",{className:`${n["hamburger-line"]}`})]}),t.jsx("div",{className:`${n["logo-container"]}`,children:t.jsx("img",{src:f,alt:$,className:`${n.logo}`})}),t.jsx("button",{type:"button",className:`${n["card-nav-cta-button"]}`,style:{backgroundColor:j,color:E},children:"Get Started"})]}),t.jsx("div",{className:`${n["card-nav-content"]}`,"aria-hidden":!s,children:(m||[]).slice(0,3).map((e,r)=>{var a;return t.jsxs("div",{className:`${n["nav-card"]}`,ref:H(r),style:{backgroundColor:e.bgColor,color:e.textColor},children:[t.jsx("div",{className:`${n["nav-card-label"]}`,children:e.label}),t.jsx("div",{className:`${n["nav-card-links"]}`,children:(a=e.links)==null?void 0:a.map((i,v)=>t.jsxs("a",{className:`${n["nav-card-link"]}`,href:i.href,"aria-label":i.ariaLabel,children:[t.jsx(U,{className:"nav-card-link-icon","aria-hidden":"true"}),i.label]},`${i.label}-${v}`))})]},`${e.label}-${r}`)})})]})})};L.__docgenInfo={description:"",methods:[],displayName:"CardNav",props:{logoAlt:{defaultValue:{value:"'Logo'",computed:!1},required:!1},className:{defaultValue:{value:"''",computed:!1},required:!1},ease:{defaultValue:{value:"'power3.out'",computed:!1},required:!1},baseColor:{defaultValue:{value:"'#fff'",computed:!1},required:!1}}};const Z={title:"ReactBits/Components/CardNav",component:L,parameters:{layout:"fullscreen"}},d={args:{logoAlt:"Logo",items:[{label:"Products",bgColor:"#1a1a2e",textColor:"#fff",links:[{label:"Analytics",href:"#",ariaLabel:"Analytics"},{label:"Dashboard",href:"#",ariaLabel:"Dashboard"},{label:"Reports",href:"#",ariaLabel:"Reports"}]},{label:"Resources",bgColor:"#16213e",textColor:"#fff",links:[{label:"Documentation",href:"#",ariaLabel:"Documentation"},{label:"Tutorials",href:"#",ariaLabel:"Tutorials"}]},{label:"Company",bgColor:"#0f3460",textColor:"#fff",links:[{label:"About Us",href:"#",ariaLabel:"About Us"},{label:"Careers",href:"#",ariaLabel:"Careers"},{label:"Contact",href:"#",ariaLabel:"Contact"}]}],ease:"power3.out",baseColor:"#fff"}};var y,w,x;d.parameters={...d.parameters,docs:{...(y=d.parameters)==null?void 0:y.docs,source:{originalSource:`{
|
|
2
2
|
args: {
|
|
3
3
|
logoAlt: 'Logo',
|
|
4
4
|
items: [{
|
package/storybook-static/assets/{Carousel.stories-CCMyd0By.js → Carousel.stories-HbqEyU8u.js}
RENAMED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as c,j as i}from"./iframe-
|
|
1
|
+
import{r as c,j as i}from"./iframe-CK6Mw28k.js";import{G as v}from"./iconBase-qbjzzLYR.js";import{u as Y}from"./use-motion-value-Do20FICu.js";import{m as k}from"./proxy-Bl04PYET.js";import{u as z}from"./use-transform-whfZpWa9.js";import"./preload-helper-C1FmrZbK.js";import"./MotionConfigContext-Bw_b3ZUg.js";function K(e){return v({attr:{viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},child:[{tag:"rect",attr:{x:"3",y:"3",width:"18",height:"18",rx:"2",ry:"2"},child:[]},{tag:"line",attr:{x1:"3",y1:"9",x2:"21",y2:"9"},child:[]},{tag:"line",attr:{x1:"9",y1:"21",x2:"9",y2:"9"},child:[]}]})(e)}function Q(e){return v({attr:{viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},child:[{tag:"polygon",attr:{points:"12 2 2 7 12 12 22 7 12 2"},child:[]},{tag:"polyline",attr:{points:"2 17 12 22 22 17"},child:[]},{tag:"polyline",attr:{points:"2 12 12 17 22 12"},child:[]}]})(e)}function X(e){return v({attr:{viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},child:[{tag:"path",attr:{d:"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"},child:[]},{tag:"polyline",attr:{points:"14 2 14 8 20 8"},child:[]},{tag:"line",attr:{x1:"16",y1:"13",x2:"8",y2:"13"},child:[]},{tag:"line",attr:{x1:"16",y1:"17",x2:"8",y2:"17"},child:[]},{tag:"polyline",attr:{points:"10 9 9 9 8 9"},child:[]}]})(e)}function Z(e){return v({attr:{viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},child:[{tag:"polyline",attr:{points:"16 18 22 12 16 6"},child:[]},{tag:"polyline",attr:{points:"8 6 2 12 8 18"},child:[]}]})(e)}function ee(e){return v({attr:{viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},child:[{tag:"circle",attr:{cx:"12",cy:"12",r:"10"},child:[]}]})(e)}const te="_round_14jni_33",ne="_active_14jni_60",oe="_inactive_14jni_64",n={"carousel-container":"_carousel-container_14jni_1","carousel-track":"_carousel-track_14jni_11","carousel-item":"_carousel-item_14jni_15",round:te,"carousel-item-header":"_carousel-item-header_14jni_47","carousel-indicators-container":"_carousel-indicators-container_14jni_52","carousel-indicator":"_carousel-indicator_14jni_52",active:ne,inactive:oe,"carousel-icon-container":"_carousel-icon-container_14jni_74","carousel-icon":"_carousel-icon_14jni_74","carousel-item-content":"_carousel-item-content_14jni_90","carousel-item-title":"_carousel-item-title_14jni_95","carousel-item-description":"_carousel-item-description_14jni_102","carousel-indicators":"_carousel-indicators_14jni_52"},ie=[{title:"Text Animations",description:"Cool text animations for your projects.",id:1,icon:i.jsx(X,{className:`${n["carousel-icon"]}`})},{title:"Animations",description:"Smooth animations for your projects.",id:2,icon:i.jsx(ee,{className:`${n["carousel-icon"]}`})},{title:"Components",description:"Reusable components for your projects.",id:3,icon:i.jsx(Q,{className:`${n["carousel-icon"]}`})},{title:"Backgrounds",description:"Beautiful backgrounds and patterns for your projects.",id:4,icon:i.jsx(K,{className:`${n["carousel-icon"]}`})},{title:"Common UI",description:"Common UI components are coming soon!",id:5,icon:i.jsx(Z,{className:`${n["carousel-icon"]}`})}],S=0,B=500,T=16,se={type:"spring",stiffness:300,damping:30};function ae({item:e,index:l,itemWidth:g,round:m,trackItemOffset:u,x:s,transition:f}){const N=[-(l+1)*u,-l*u,-(l-1)*u],r=z(s,N,[90,0,-90],{clamp:!1});return i.jsxs(k.div,{className:`${n["carousel-item"]} ${m?n.round:""}`,style:{width:g,height:m?g:"100%",rotateY:r,...m&&{borderRadius:"50%"}},transition:f,children:[i.jsx("div",{className:`${n["carousel-item-header"]} ${m?n.round:""}`,children:i.jsx("span",{className:`${n["carousel-icon-container"]}`,children:e.icon})}),i.jsxs("div",{className:`${n["carousel-item-content"]}`,children:[i.jsx("div",{className:`${n["carousel-item-title"]}`,children:e.title}),i.jsx("p",{className:`${n["carousel-item-description"]}`,children:e.description})]})]},`${(e==null?void 0:e.id)??l}-${l}`)}function V({items:e=ie,baseWidth:l=300,autoplay:g=!1,autoplayDelay:m=3e3,pauseOnHover:u=!1,loop:s=!1,round:f=!1}){const x=l-32,r=x+T,a=c.useMemo(()=>s?e.length===0?[]:[e[e.length-1],...e,e[0]]:e,[e,s]),[d,p]=c.useState(s?1:0),h=Y(0),[L,A]=c.useState(!1),[q,j]=c.useState(!1),[w,_]=c.useState(!1),C=c.useRef(null);c.useEffect(()=>{if(u&&C.current){const o=C.current,t=()=>A(!0),y=()=>A(!1);return o.addEventListener("mouseenter",t),o.addEventListener("mouseleave",y),()=>{o.removeEventListener("mouseenter",t),o.removeEventListener("mouseleave",y)}}},[u]),c.useEffect(()=>{if(!g||a.length<=1||u&&L)return;const o=setInterval(()=>{p(t=>Math.min(t+1,a.length-1))},m);return()=>clearInterval(o)},[g,m,L,u,a.length]),c.useEffect(()=>{const o=s?1:0;p(o),h.set(-o*r)},[e.length,s,r,h]),c.useEffect(()=>{!s&&d>a.length-1&&p(Math.max(0,a.length-1))},[a.length,s,d]);const E=q?{duration:0}:se,P=()=>{_(!0)},U=()=>{if(!s||a.length<=1){_(!1);return}const o=a.length-1;if(d===o){j(!0);const t=1;p(t),h.set(-t*r),requestAnimationFrame(()=>{j(!1),_(!1)});return}if(d===0){j(!0);const t=e.length;p(t),h.set(-t*r),requestAnimationFrame(()=>{j(!1),_(!1)});return}_(!1)},W=(o,t)=>{const{offset:y,velocity:I}=t,R=y.x<-S||I.x<-B?1:y.x>S||I.x>B?-1:0;R!==0&&p(H=>{const O=H+R,J=a.length-1;return Math.max(0,Math.min(O,J))})},G=s?{}:{dragConstraints:{left:-r*Math.max(a.length-1,0),right:0}},F=e.length===0?0:s?(d-1+e.length)%e.length:Math.min(d,e.length-1);return i.jsxs("div",{ref:C,className:`${n["carousel-container"]} ${f?n.round:""}`,style:{width:`${l}px`,...f&&{height:`${l}px`,borderRadius:"50%"}},children:[i.jsx(k.div,{className:`${n["carousel-track"]}`,drag:w?!1:"x",...G,style:{width:x,gap:`${T}px`,perspective:1e3,perspectiveOrigin:`${d*r+x/2}px 50%`,x:h},onDragEnd:W,animate:{x:-(d*r)},transition:E,onAnimationStart:P,onAnimationComplete:U,children:a.map((o,t)=>i.jsx(ae,{item:o,index:t,itemWidth:x,round:f,trackItemOffset:r,x:h,transition:E},`${(o==null?void 0:o.id)??t}-${t}`))}),i.jsx("div",{className:`${n["carousel-indicators-container"]} ${f?n.round:""}`,children:i.jsx("div",{className:`${n["carousel-indicators"]}`,children:e.map((o,t)=>i.jsx(k.div,{className:`${n["carousel-indicator"]} ${F===t?n.active:n.inactive}`,animate:{scale:F===t?1.2:1},onClick:()=>p(s?t+1:t),transition:{duration:.15}},t))})})]})}V.__docgenInfo={description:"",methods:[],displayName:"Carousel",props:{items:{defaultValue:{value:`[
|
|
2
2
|
{
|
|
3
3
|
title: 'Text Animations',
|
|
4
4
|
description: 'Cool text animations for your projects.',
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as i,j as a}from"./iframe-
|
|
1
|
+
import{r as i,j as a}from"./iframe-CK6Mw28k.js";import{u as k}from"./useSound-D6Fr1PWT.js";const x="_checkboxLabel_kh8g9_1",f="_checkbox_kh8g9_1",g="_checkboxText_kh8g9_92",c={checkboxLabel:x,checkbox:f,checkboxText:g},C=({checked:o,onChange:r,label:s,disabled:h=!1,indeterminate:n=!1,id:l,name:d,value:b,soundConfig:e})=>{const t=i.useRef(null),{playSound:u}=k(e);return i.useEffect(()=>{t.current&&(t.current.indeterminate=n)},[n]),a.jsxs("label",{className:c.checkboxLabel,children:[a.jsx("input",{ref:t,type:"checkbox",checked:o,onChange:m=>{const p=m.target.checked;r(p),(e==null?void 0:e.onClick)!==!1&&u("toggle")},className:c.checkbox,disabled:h,id:l,name:d,value:b,"aria-checked":n?"mixed":o}),s&&a.jsx("span",{className:c.checkboxText,children:s})]})};C.__docgenInfo={description:`Checkbox component - Modern interactive checkbox with animations
|
|
2
2
|
|
|
3
3
|
@component
|
|
4
4
|
@description
|
package/storybook-static/assets/{Checkbox.stories-Bv1qqmYX.js → Checkbox.stories-DBj6Gf_0.js}
RENAMED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as g,j as t}from"./iframe-
|
|
1
|
+
import{r as g,j as t}from"./iframe-CK6Mw28k.js";import{C as s}from"./Checkbox-_QVpBl9h.js";import"./preload-helper-C1FmrZbK.js";import"./useSound-D6Fr1PWT.js";const E={title:"Atoms/Checkbox",component:s,parameters:{layout:"centered",docs:{description:{component:"A simple checkbox component with optional label."}}},tags:["autodocs"],argTypes:{checked:{control:"boolean"},label:{control:"text"},disabled:{control:"boolean"},onChange:{action:"changed"}}},n={args:{checked:!1,label:"Accept terms and conditions",onChange:()=>{}}},c={args:{checked:!1,label:"This option is disabled",disabled:!0,onChange:()=>{}}},i={args:{checked:!1,label:"Multiple checkboxes example",onChange:()=>{}},render:()=>{const[e,a]=g.useState({option1:!1,option2:!0,option3:!1,option4:!1});return t.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"0.5rem"},children:[t.jsx(s,{checked:e.option1,onChange:o=>a({...e,option1:o}),label:"Enable notifications"}),t.jsx(s,{checked:e.option2,onChange:o=>a({...e,option2:o}),label:"Receive marketing emails"}),t.jsx(s,{checked:e.option3,onChange:o=>a({...e,option3:o}),label:"Share usage statistics"}),t.jsx(s,{checked:e.option4,onChange:o=>a({...e,option4:o}),label:"Enable dark mode",disabled:!0})]})},parameters:{controls:{disable:!0}}};var l,r,p;n.parameters={...n.parameters,docs:{...(l=n.parameters)==null?void 0:l.docs,source:{originalSource:`{
|
|
2
2
|
args: {
|
|
3
3
|
checked: false,
|
|
4
4
|
label: 'Accept terms and conditions',
|