@vadimcomanescu/nadicode-design-system 2.0.0
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/.agents/skills/seed/SKILL.md +433 -0
- package/.agents/skills/seed/contract.md +92 -0
- package/.agents/skills/seed/intent-map.md +320 -0
- package/.agents/skills/seed/recipes/agency-home.md +311 -0
- package/.agents/skills/seed/recipes/agents-chat.md +281 -0
- package/.agents/skills/seed/recipes/analytics.md +253 -0
- package/.agents/skills/seed/recipes/auth.md +254 -0
- package/.agents/skills/seed/recipes/blog-content.md +307 -0
- package/.agents/skills/seed/recipes/checkout.md +311 -0
- package/.agents/skills/seed/recipes/company-about.md +276 -0
- package/.agents/skills/seed/recipes/company-contact.md +234 -0
- package/.agents/skills/seed/recipes/crud-form.md +233 -0
- package/.agents/skills/seed/recipes/crud-list-detail.md +230 -0
- package/.agents/skills/seed/recipes/dashboard.md +354 -0
- package/.agents/skills/seed/recipes/digital-workers.md +314 -0
- package/.agents/skills/seed/recipes/error-pages.md +199 -0
- package/.agents/skills/seed/recipes/marketing-landing.md +293 -0
- package/.agents/skills/seed/recipes/marketing-shell.md +165 -0
- package/.agents/skills/seed/recipes/navigation-shell.md +786 -0
- package/.agents/skills/seed/recipes/onboarding.md +258 -0
- package/.agents/skills/seed/recipes/pricing.md +271 -0
- package/.agents/skills/seed/recipes/service-detail.md +302 -0
- package/.agents/skills/seed/recipes/settings.md +252 -0
- package/.agents/skills/seed/references/animation.md +292 -0
- package/.agents/skills/seed/references/blocks.md +122 -0
- package/.agents/skills/seed/references/brand-override.md +140 -0
- package/.agents/skills/seed/references/components.md +270 -0
- package/.agents/skills/seed/references/composition.md +258 -0
- package/.agents/skills/seed/references/dashboard-patterns.md +101 -0
- package/.agents/skills/seed/references/glass-and-effects.md +201 -0
- package/.agents/skills/seed/references/icons.md +169 -0
- package/.agents/skills/seed/references/nextjs.md +109 -0
- package/.agents/skills/seed/references/opinions.md +271 -0
- package/.agents/skills/seed/references/patterns.md +373 -0
- package/.agents/skills/seed/references/responsive.md +209 -0
- package/.agents/skills/seed/references/state-machines.md +252 -0
- package/.agents/skills/seed/references/tokens.md +279 -0
- package/LICENSE +21 -0
- package/README.md +243 -0
- package/css/tokens.css +981 -0
- package/dist/chunk-226EBOTK.js +43 -0
- package/dist/chunk-2HDB6MDK.js +142 -0
- package/dist/chunk-2IZC7HSV.js +42 -0
- package/dist/chunk-2MOEOEOI.js +106 -0
- package/dist/chunk-2NT57K4U.js +43 -0
- package/dist/chunk-2SDZMTB2.js +47 -0
- package/dist/chunk-2WEUTBDI.js +79 -0
- package/dist/chunk-2ZJVU7NV.js +36 -0
- package/dist/chunk-3CLXYQKB.js +31 -0
- package/dist/chunk-3NYTIDKZ.js +1 -0
- package/dist/chunk-3R2VLZUR.js +56 -0
- package/dist/chunk-3UJ3HJZ3.js +24 -0
- package/dist/chunk-3ZDYYZDD.js +1 -0
- package/dist/chunk-4FEAWXJD.js +64 -0
- package/dist/chunk-4GSFNJAJ.js +19 -0
- package/dist/chunk-4HRVRW2X.js +669 -0
- package/dist/chunk-4K3PATUT.js +370 -0
- package/dist/chunk-4NXZIMYZ.js +32 -0
- package/dist/chunk-4O6L5YWT.js +17 -0
- package/dist/chunk-4OBE2FS2.js +44 -0
- package/dist/chunk-4S326Z3D.js +143 -0
- package/dist/chunk-55HD4L6G.js +67 -0
- package/dist/chunk-55U27XY4.js +28 -0
- package/dist/chunk-5DKCZWC6.js +186 -0
- package/dist/chunk-5ESF6N36.js +79 -0
- package/dist/chunk-5I3FWRC5.js +148 -0
- package/dist/chunk-5LCXASRW.js +41 -0
- package/dist/chunk-5UZDOF6V.js +35 -0
- package/dist/chunk-5Y4BOIYO.js +121 -0
- package/dist/chunk-666N6OTL.js +45 -0
- package/dist/chunk-6BAV4TZ5.js +39 -0
- package/dist/chunk-6DYFX5IR.js +44 -0
- package/dist/chunk-6FOHUNXR.js +14 -0
- package/dist/chunk-6G3RRWJT.js +43 -0
- package/dist/chunk-72X6SXOX.js +36 -0
- package/dist/chunk-73T6GXPA.js +37 -0
- package/dist/chunk-74RKVIBV.js +83 -0
- package/dist/chunk-756Q7AC5.js +27 -0
- package/dist/chunk-7KIDDF3I.js +67 -0
- package/dist/chunk-7WDT2PRI.js +43 -0
- package/dist/chunk-A7NUWD76.js +40 -0
- package/dist/chunk-ACRVOD7W.js +32 -0
- package/dist/chunk-AH6YSYYT.js +88 -0
- package/dist/chunk-ALMGJVMT.js +43 -0
- package/dist/chunk-ALUL3PF7.js +161 -0
- package/dist/chunk-ANBJ2OLC.js +104 -0
- package/dist/chunk-AP3XXYAY.js +51 -0
- package/dist/chunk-AP5Y5M3R.js +43 -0
- package/dist/chunk-ASKFAYYR.js +39 -0
- package/dist/chunk-AUSYEAIJ.js +93 -0
- package/dist/chunk-AWIJHDNK.js +65 -0
- package/dist/chunk-AZUJNRQU.js +52 -0
- package/dist/chunk-B3BYBSF2.js +38 -0
- package/dist/chunk-B5QL76GA.js +40 -0
- package/dist/chunk-BFLN54VR.js +31 -0
- package/dist/chunk-BJYCQ2NV.js +35 -0
- package/dist/chunk-BPCCTJSK.js +37 -0
- package/dist/chunk-BRP6D56U.js +47 -0
- package/dist/chunk-BRXNGF5W.js +96 -0
- package/dist/chunk-BYASYDOH.js +22 -0
- package/dist/chunk-BZYMCJHW.js +104 -0
- package/dist/chunk-C4SNHMYC.js +21 -0
- package/dist/chunk-CGUCH322.js +53 -0
- package/dist/chunk-CI7GPGCJ.js +43 -0
- package/dist/chunk-CRY67BIF.js +57 -0
- package/dist/chunk-CRZ2JE24.js +35 -0
- package/dist/chunk-CUZJIDU7.js +19 -0
- package/dist/chunk-CXACRCZ4.js +38 -0
- package/dist/chunk-D4NC7WX5.js +107 -0
- package/dist/chunk-DARC2ACH.js +240 -0
- package/dist/chunk-DF47R6LN.js +347 -0
- package/dist/chunk-DFPXK2JO.js +71 -0
- package/dist/chunk-DJTF3XFB.js +86 -0
- package/dist/chunk-DQPK2XRL.js +66 -0
- package/dist/chunk-DT6DGTVW.js +41 -0
- package/dist/chunk-E7RBK6ML.js +44 -0
- package/dist/chunk-EB5PYS7Q.js +57 -0
- package/dist/chunk-ELKIUARM.js +32 -0
- package/dist/chunk-EV2V5RWT.js +432 -0
- package/dist/chunk-EYWOKTOY.js +58 -0
- package/dist/chunk-F3T2U7YL.js +79 -0
- package/dist/chunk-FLF5AMNO.js +28 -0
- package/dist/chunk-FMH55OKV.js +42 -0
- package/dist/chunk-FOFGPWFS.js +7 -0
- package/dist/chunk-FTVLDDOQ.js +69 -0
- package/dist/chunk-G24VV5NO.js +62 -0
- package/dist/chunk-G5EO22OR.js +1 -0
- package/dist/chunk-G5EO5FWC.js +29 -0
- package/dist/chunk-G5YLGJXR.js +62 -0
- package/dist/chunk-GAKU7DFY.js +36 -0
- package/dist/chunk-GCUTJI7M.js +41 -0
- package/dist/chunk-GHIBG7OM.js +21 -0
- package/dist/chunk-GJUR6HT3.js +81 -0
- package/dist/chunk-GLU236NN.js +48 -0
- package/dist/chunk-GMMPLZLC.js +142 -0
- package/dist/chunk-GO35FTNJ.js +1 -0
- package/dist/chunk-H466RJCI.js +611 -0
- package/dist/chunk-HJBXUXTD.js +62 -0
- package/dist/chunk-HJC6U46F.js +83 -0
- package/dist/chunk-HNY45VUQ.js +35 -0
- package/dist/chunk-HOWTYZL5.js +134 -0
- package/dist/chunk-HRIEX66J.js +86 -0
- package/dist/chunk-HS7QNBCO.js +49 -0
- package/dist/chunk-I23DDSU7.js +40 -0
- package/dist/chunk-I3TH7PIB.js +69 -0
- package/dist/chunk-IFIDWZ5M.js +38 -0
- package/dist/chunk-IJJI4RQU.js +32 -0
- package/dist/chunk-ILIHQ2KZ.js +73 -0
- package/dist/chunk-IPXL7WX7.js +90 -0
- package/dist/chunk-IQEBXXB5.js +35 -0
- package/dist/chunk-J3QL5UQ7.js +163 -0
- package/dist/chunk-J5DRK4RF.js +54 -0
- package/dist/chunk-JBK2LA6U.js +46 -0
- package/dist/chunk-JC5W5UPI.js +125 -0
- package/dist/chunk-JHQ5NMLZ.js +43 -0
- package/dist/chunk-JHQTKMKG.js +35 -0
- package/dist/chunk-JJTQOH7J.js +76 -0
- package/dist/chunk-JL4MVVFH.js +36 -0
- package/dist/chunk-JMCSAGZ3.js +101 -0
- package/dist/chunk-JRJGSNI4.js +32 -0
- package/dist/chunk-JWQXBRE7.js +30 -0
- package/dist/chunk-JZ4G2SJH.js +52 -0
- package/dist/chunk-K6GIX57H.js +15 -0
- package/dist/chunk-KRBLVZII.js +20 -0
- package/dist/chunk-KSHJQ2VT.js +37 -0
- package/dist/chunk-KYGKJ553.js +52 -0
- package/dist/chunk-KYZT3RNW.js +37 -0
- package/dist/chunk-LCDDAE7J.js +28 -0
- package/dist/chunk-LDW4LHUM.js +47 -0
- package/dist/chunk-LIBXYD5Q.js +19 -0
- package/dist/chunk-LNVZNQCZ.js +124 -0
- package/dist/chunk-LQLFA2EL.js +65 -0
- package/dist/chunk-LSPO6OBI.js +94 -0
- package/dist/chunk-LV4LBWCS.js +29 -0
- package/dist/chunk-M7YSMMAC.js +294 -0
- package/dist/chunk-MAUTIHQG.js +54 -0
- package/dist/chunk-MDAYDDTC.js +23 -0
- package/dist/chunk-MJ4CB6ZL.js +23 -0
- package/dist/chunk-MLUSJTS2.js +107 -0
- package/dist/chunk-N53OMWW2.js +45 -0
- package/dist/chunk-NAAU5IWU.js +54 -0
- package/dist/chunk-NCULQXJE.js +36 -0
- package/dist/chunk-NURPUVUV.js +97 -0
- package/dist/chunk-O74AEVHW.js +37 -0
- package/dist/chunk-OCQB4IU7.js +71 -0
- package/dist/chunk-OHCQPI3W.js +31 -0
- package/dist/chunk-OHX2LFAH.js +112 -0
- package/dist/chunk-OITJWGFV.js +48 -0
- package/dist/chunk-ONGJ7AC2.js +34 -0
- package/dist/chunk-P6IRHPFM.js +32 -0
- package/dist/chunk-PD2YEH3H.js +84 -0
- package/dist/chunk-PJNHVPHF.js +266 -0
- package/dist/chunk-PKVTEDKO.js +32 -0
- package/dist/chunk-PRUXIDBD.js +69 -0
- package/dist/chunk-PSVQ7ZNX.js +44 -0
- package/dist/chunk-PX2WVDDB.js +69 -0
- package/dist/chunk-PXDHNGTG.js +142 -0
- package/dist/chunk-Q7LVUGFL.js +58 -0
- package/dist/chunk-QPXTBZWN.js +49 -0
- package/dist/chunk-QSU23VYZ.js +49 -0
- package/dist/chunk-QUKDUSHD.js +39 -0
- package/dist/chunk-QYZT24TS.js +18 -0
- package/dist/chunk-R3AO6AZM.js +49 -0
- package/dist/chunk-R5XP45PD.js +36 -0
- package/dist/chunk-R674XI7C.js +31 -0
- package/dist/chunk-R7N7YLFT.js +27 -0
- package/dist/chunk-RASEB2XI.js +16 -0
- package/dist/chunk-RBPLOM3A.js +52 -0
- package/dist/chunk-RF6ECFS5.js +36 -0
- package/dist/chunk-RHEF3WH6.js +83 -0
- package/dist/chunk-RWNJ54CI.js +22 -0
- package/dist/chunk-RX5EUODB.js +174 -0
- package/dist/chunk-RYOTIXZO.js +57 -0
- package/dist/chunk-S2WSXZ7Y.js +90 -0
- package/dist/chunk-S4GKGKON.js +38 -0
- package/dist/chunk-S4JAHKOP.js +26 -0
- package/dist/chunk-S733NAYS.js +34 -0
- package/dist/chunk-SEMWC3IT.js +32 -0
- package/dist/chunk-SGI25ZJ6.js +54 -0
- package/dist/chunk-SH72GWB7.js +28 -0
- package/dist/chunk-SR5U52V3.js +43 -0
- package/dist/chunk-SV3KZ6CB.js +136 -0
- package/dist/chunk-SW6QPJM4.js +79 -0
- package/dist/chunk-SXHYB7JB.js +36 -0
- package/dist/chunk-T5LXQNIP.js +177 -0
- package/dist/chunk-T6BRD7TS.js +44 -0
- package/dist/chunk-T7H53CK2.js +83 -0
- package/dist/chunk-TBKJ34BB.js +43 -0
- package/dist/chunk-TSVN5A2F.js +65 -0
- package/dist/chunk-TV4RSQH4.js +33 -0
- package/dist/chunk-TXGANOAX.js +37 -0
- package/dist/chunk-U7V6TREO.js +55 -0
- package/dist/chunk-UBIGDGOP.js +52 -0
- package/dist/chunk-UEG2LI7Z.js +43 -0
- package/dist/chunk-UHXGBV5N.js +35 -0
- package/dist/chunk-UIUMTURU.js +31 -0
- package/dist/chunk-UJDEGCCZ.js +49 -0
- package/dist/chunk-ULLTRLBD.js +268 -0
- package/dist/chunk-UN2SJ42K.js +118 -0
- package/dist/chunk-UWHKZX4Y.js +99 -0
- package/dist/chunk-UYT33NG6.js +23 -0
- package/dist/chunk-V6WNRZT3.js +43 -0
- package/dist/chunk-VCCI3NRD.js +392 -0
- package/dist/chunk-VDYPDMYR.js +37 -0
- package/dist/chunk-VJIL7W55.js +8 -0
- package/dist/chunk-VM462WZC.js +37 -0
- package/dist/chunk-VTAOHSPW.js +63 -0
- package/dist/chunk-W3B3UOEG.js +36 -0
- package/dist/chunk-W4YX7N46.js +60 -0
- package/dist/chunk-W73JAOHW.js +143 -0
- package/dist/chunk-WA45EC4Y.js +36 -0
- package/dist/chunk-WAP7DBSW.js +47 -0
- package/dist/chunk-WDGIQDQG.js +35 -0
- package/dist/chunk-WFJQ43SM.js +43 -0
- package/dist/chunk-WGPK3FQ7.js +44 -0
- package/dist/chunk-WH62BE24.js +165 -0
- package/dist/chunk-WI37ZYIF.js +370 -0
- package/dist/chunk-WI547C47.js +43 -0
- package/dist/chunk-WKRIKCJC.js +32 -0
- package/dist/chunk-WN5ONOHC.js +77 -0
- package/dist/chunk-WSU2PCA2.js +248 -0
- package/dist/chunk-WUO7OONN.js +33 -0
- package/dist/chunk-WXVNTJIB.js +99 -0
- package/dist/chunk-XBBR4PLJ.js +39 -0
- package/dist/chunk-XCZIF75R.js +114 -0
- package/dist/chunk-XQ2UDMPO.js +35 -0
- package/dist/chunk-XZ3A33GP.js +29 -0
- package/dist/chunk-Y56WBNCY.js +37 -0
- package/dist/chunk-YQIABLDO.js +18 -0
- package/dist/chunk-Z74D6D2W.js +46 -0
- package/dist/chunk-ZHTQF2KI.js +93 -0
- package/dist/chunk-ZJ6PY5ST.js +66 -0
- package/dist/chunk-ZLSWCV55.js +19 -0
- package/dist/chunk-ZU2GYVAP.js +32 -0
- package/dist/chunk-ZU55E4A7.js +50 -0
- package/dist/chunk-ZUHIWALK.js +48 -0
- package/dist/components/animate-ui/primitives/animate/scroll-progress.d.ts +27 -0
- package/dist/components/animate-ui/primitives/animate/scroll-progress.js +91 -0
- package/dist/components/animate-ui/primitives/animate/slot.d.ts +17 -0
- package/dist/components/animate-ui/primitives/animate/slot.js +6 -0
- package/dist/components/animate-ui/primitives/effects/fade.d.ts +18 -0
- package/dist/components/animate-ui/primitives/effects/fade.js +72 -0
- package/dist/components/animate-ui/primitives/effects/highlight.d.ts +91 -0
- package/dist/components/animate-ui/primitives/effects/highlight.js +433 -0
- package/dist/components/animate-ui/primitives/effects/shine.d.ts +17 -0
- package/dist/components/animate-ui/primitives/effects/shine.js +5 -0
- package/dist/components/animate-ui/primitives/effects/slide.d.ts +19 -0
- package/dist/components/animate-ui/primitives/effects/slide.js +74 -0
- package/dist/components/animate-ui/primitives/effects/zoom.d.ts +18 -0
- package/dist/components/animate-ui/primitives/effects/zoom.js +72 -0
- package/dist/components/blocks/AccountLockedBlock.d.ts +11 -0
- package/dist/components/blocks/AccountLockedBlock.js +61 -0
- package/dist/components/blocks/ActivityFeedBlock.d.ts +14 -0
- package/dist/components/blocks/ActivityFeedBlock.js +43 -0
- package/dist/components/blocks/AgentConversationBlock.d.ts +25 -0
- package/dist/components/blocks/AgentConversationBlock.js +149 -0
- package/dist/components/blocks/AgentProfileGridBlock.d.ts +19 -0
- package/dist/components/blocks/AgentProfileGridBlock.js +90 -0
- package/dist/components/blocks/AgentRunOverviewBlock.d.ts +32 -0
- package/dist/components/blocks/AgentRunOverviewBlock.js +154 -0
- package/dist/components/blocks/AgentWorkbenchBlock.d.ts +56 -0
- package/dist/components/blocks/AgentWorkbenchBlock.js +374 -0
- package/dist/components/blocks/AudioVisualizerBlock.d.ts +6 -0
- package/dist/components/blocks/AudioVisualizerBlock.js +51 -0
- package/dist/components/blocks/AuthLayout.d.ts +17 -0
- package/dist/components/blocks/AuthLayout.js +82 -0
- package/dist/components/blocks/AuthSuccessBlock.d.ts +12 -0
- package/dist/components/blocks/AuthSuccessBlock.js +63 -0
- package/dist/components/blocks/BannerBlock.d.ts +9 -0
- package/dist/components/blocks/BannerBlock.js +178 -0
- package/dist/components/blocks/BarChartBlock.d.ts +15 -0
- package/dist/components/blocks/BarChartBlock.js +52 -0
- package/dist/components/blocks/CallToActionBlock.d.ts +13 -0
- package/dist/components/blocks/CallToActionBlock.js +67 -0
- package/dist/components/blocks/ChangelogBlock.d.ts +16 -0
- package/dist/components/blocks/ChangelogBlock.js +218 -0
- package/dist/components/blocks/ChartBlock.d.ts +16 -0
- package/dist/components/blocks/ChartBlock.js +169 -0
- package/dist/components/blocks/ChartCollectionBlock.d.ts +5 -0
- package/dist/components/blocks/ChartCollectionBlock.js +177 -0
- package/dist/components/blocks/ChatLayout.d.ts +14 -0
- package/dist/components/blocks/ChatLayout.js +238 -0
- package/dist/components/blocks/CodeBlock.d.ts +8 -0
- package/dist/components/blocks/CodeBlock.js +65 -0
- package/dist/components/blocks/ComparisonBlock.d.ts +13 -0
- package/dist/components/blocks/ComparisonBlock.js +99 -0
- package/dist/components/blocks/ContactBlock.d.ts +17 -0
- package/dist/components/blocks/ContactBlock.js +126 -0
- package/dist/components/blocks/CreateBlock.d.ts +16 -0
- package/dist/components/blocks/CreateBlock.js +222 -0
- package/dist/components/blocks/DataGridBlock.d.ts +16 -0
- package/dist/components/blocks/DataGridBlock.js +236 -0
- package/dist/components/blocks/DirectoryBlock.d.ts +17 -0
- package/dist/components/blocks/DirectoryBlock.js +204 -0
- package/dist/components/blocks/FAQBlock.d.ts +12 -0
- package/dist/components/blocks/FAQBlock.js +160 -0
- package/dist/components/blocks/FeatureBlock.d.ts +27 -0
- package/dist/components/blocks/FeatureBlock.js +265 -0
- package/dist/components/blocks/FeatureGridBlock.d.ts +14 -0
- package/dist/components/blocks/FeatureGridBlock.js +62 -0
- package/dist/components/blocks/FooterBlock.d.ts +19 -0
- package/dist/components/blocks/FooterBlock.js +74 -0
- package/dist/components/blocks/GalleryBlock.d.ts +13 -0
- package/dist/components/blocks/GalleryBlock.js +187 -0
- package/dist/components/blocks/HeaderBlock.d.ts +14 -0
- package/dist/components/blocks/HeaderBlock.js +123 -0
- package/dist/components/blocks/HeatmapChartBlock.d.ts +15 -0
- package/dist/components/blocks/HeatmapChartBlock.js +9 -0
- package/dist/components/blocks/HeroBlock.d.ts +21 -0
- package/dist/components/blocks/HeroBlock.js +318 -0
- package/dist/components/blocks/HeroSectionBlock.d.ts +19 -0
- package/dist/components/blocks/HeroSectionBlock.js +267 -0
- package/dist/components/blocks/IntegrationsBlock.d.ts +15 -0
- package/dist/components/blocks/IntegrationsBlock.js +211 -0
- package/dist/components/blocks/InteractiveAreaChartBlock.d.ts +21 -0
- package/dist/components/blocks/InteractiveAreaChartBlock.js +407 -0
- package/dist/components/blocks/KanbanDemoBlock.d.ts +4 -0
- package/dist/components/blocks/KanbanDemoBlock.js +154 -0
- package/dist/components/blocks/LoginBlock.d.ts +41 -0
- package/dist/components/blocks/LoginBlock.js +13 -0
- package/dist/components/blocks/LogoCloud.d.ts +12 -0
- package/dist/components/blocks/LogoCloud.js +47 -0
- package/dist/components/blocks/NavUser.d.ts +18 -0
- package/dist/components/blocks/NavUser.js +211 -0
- package/dist/components/blocks/NewsletterBlock.d.ts +8 -0
- package/dist/components/blocks/NewsletterBlock.js +90 -0
- package/dist/components/blocks/NotFoundBlock.d.ts +9 -0
- package/dist/components/blocks/NotFoundBlock.js +157 -0
- package/dist/components/blocks/OnboardingBlock.d.ts +14 -0
- package/dist/components/blocks/OnboardingBlock.js +181 -0
- package/dist/components/blocks/PasswordRecoveryBlock.d.ts +12 -0
- package/dist/components/blocks/PasswordRecoveryBlock.js +146 -0
- package/dist/components/blocks/PricingBlock.d.ts +19 -0
- package/dist/components/blocks/PricingBlock.js +125 -0
- package/dist/components/blocks/ProcessFlowBlock.d.ts +15 -0
- package/dist/components/blocks/ProcessFlowBlock.js +82 -0
- package/dist/components/blocks/ResetPasswordBlock.d.ts +9 -0
- package/dist/components/blocks/ResetPasswordBlock.js +132 -0
- package/dist/components/blocks/SettingsLayout.d.ts +16 -0
- package/dist/components/blocks/SettingsLayout.js +205 -0
- package/dist/components/blocks/SignUpBlock.d.ts +11 -0
- package/dist/components/blocks/SignUpBlock.js +173 -0
- package/dist/components/blocks/SocialProofBlock.d.ts +23 -0
- package/dist/components/blocks/SocialProofBlock.js +122 -0
- package/dist/components/blocks/SolutionShowcaseBlock.d.ts +17 -0
- package/dist/components/blocks/SolutionShowcaseBlock.js +117 -0
- package/dist/components/blocks/StatsBlock.d.ts +21 -0
- package/dist/components/blocks/StatsBlock.js +180 -0
- package/dist/components/blocks/StatsMarketingBlock.d.ts +14 -0
- package/dist/components/blocks/StatsMarketingBlock.js +51 -0
- package/dist/components/blocks/TeamBlock.d.ts +16 -0
- package/dist/components/blocks/TeamBlock.js +57 -0
- package/dist/components/blocks/TestimonialsBlock.d.ts +15 -0
- package/dist/components/blocks/TestimonialsBlock.js +138 -0
- package/dist/components/blocks/TwoFactorChallengeBlock.d.ts +12 -0
- package/dist/components/blocks/TwoFactorChallengeBlock.js +207 -0
- package/dist/components/blocks/TwoFactorSetupBlock.d.ts +12 -0
- package/dist/components/blocks/TwoFactorSetupBlock.js +296 -0
- package/dist/components/blocks/UsageDonutBlock.d.ts +16 -0
- package/dist/components/blocks/UsageDonutBlock.js +84 -0
- package/dist/components/blocks/VoiceAgentCard.d.ts +17 -0
- package/dist/components/blocks/VoiceAgentCard.js +79 -0
- package/dist/components/blocks/WizardBlock.d.ts +15 -0
- package/dist/components/blocks/WizardBlock.js +207 -0
- package/dist/components/blocks/user/InviteUserModal.d.ts +20 -0
- package/dist/components/blocks/user/InviteUserModal.js +248 -0
- package/dist/components/layout/Grid.d.ts +13 -0
- package/dist/components/layout/Grid.js +42 -0
- package/dist/components/layout/GridSystem.d.ts +51 -0
- package/dist/components/layout/GridSystem.js +115 -0
- package/dist/components/logos/Gemini.d.ts +2 -0
- package/dist/components/logos/Gemini.js +2 -0
- package/dist/components/logos/GooglePaLM.d.ts +2 -0
- package/dist/components/logos/GooglePaLM.js +2 -0
- package/dist/components/logos/MagicUI.d.ts +2 -0
- package/dist/components/logos/MagicUI.js +2 -0
- package/dist/components/logos/MediaWiki.d.ts +2 -0
- package/dist/components/logos/MediaWiki.js +2 -0
- package/dist/components/logos/Replit.d.ts +2 -0
- package/dist/components/logos/Replit.js +2 -0
- package/dist/components/logos/VSCodium.d.ts +2 -0
- package/dist/components/logos/VSCodium.js +2 -0
- package/dist/components/logos/index.d.ts +6 -0
- package/dist/components/logos/index.js +7 -0
- package/dist/components/ui/Accordion.d.ts +13 -0
- package/dist/components/ui/Accordion.js +115 -0
- package/dist/components/ui/AgentAvatar.d.ts +15 -0
- package/dist/components/ui/AgentAvatar.js +73 -0
- package/dist/components/ui/AgentMessageBubble.d.ts +21 -0
- package/dist/components/ui/AgentMessageBubble.js +115 -0
- package/dist/components/ui/AgentMetricsCard.d.ts +19 -0
- package/dist/components/ui/AgentMetricsCard.js +7 -0
- package/dist/components/ui/AgentStatus.d.ts +19 -0
- package/dist/components/ui/AgentStatus.js +77 -0
- package/dist/components/ui/AgentTeamPanel.d.ts +30 -0
- package/dist/components/ui/AgentTeamPanel.js +6 -0
- package/dist/components/ui/AgentTerminal.d.ts +14 -0
- package/dist/components/ui/AgentTerminal.js +3 -0
- package/dist/components/ui/AgentTimeline.d.ts +17 -0
- package/dist/components/ui/AgentTimeline.js +90 -0
- package/dist/components/ui/Alert.d.ts +18 -0
- package/dist/components/ui/Alert.js +3 -0
- package/dist/components/ui/AlertDialog.d.ts +26 -0
- package/dist/components/ui/AlertDialog.js +137 -0
- package/dist/components/ui/AmbientGrid.d.ts +9 -0
- package/dist/components/ui/AmbientGrid.js +26 -0
- package/dist/components/ui/AnimatedBackground.d.ts +3 -0
- package/dist/components/ui/AnimatedBackground.js +3 -0
- package/dist/components/ui/AnimatedDialog.d.ts +30 -0
- package/dist/components/ui/AnimatedDialog.js +119 -0
- package/dist/components/ui/AnimatedSheet.d.ts +26 -0
- package/dist/components/ui/AnimatedSheet.js +264 -0
- package/dist/components/ui/AnimatedTabs.d.ts +16 -0
- package/dist/components/ui/AnimatedTabs.js +175 -0
- package/dist/components/ui/AnnouncementBanner.d.ts +10 -0
- package/dist/components/ui/AnnouncementBanner.js +48 -0
- package/dist/components/ui/ApprovalCard.d.ts +16 -0
- package/dist/components/ui/ApprovalCard.js +117 -0
- package/dist/components/ui/ArtifactCard.d.ts +18 -0
- package/dist/components/ui/ArtifactCard.js +4 -0
- package/dist/components/ui/AspectRatio.d.ts +3 -0
- package/dist/components/ui/AspectRatio.js +6 -0
- package/dist/components/ui/AudioWaveform.d.ts +18 -0
- package/dist/components/ui/AudioWaveform.js +77 -0
- package/dist/components/ui/AuroraEffect.d.ts +9 -0
- package/dist/components/ui/AuroraEffect.js +77 -0
- package/dist/components/ui/Avatar.d.ts +12 -0
- package/dist/components/ui/Avatar.js +3 -0
- package/dist/components/ui/Avatar3D.d.ts +18 -0
- package/dist/components/ui/Avatar3D.js +6 -0
- package/dist/components/ui/AvatarUpload.d.ts +6 -0
- package/dist/components/ui/AvatarUpload.js +124 -0
- package/dist/components/ui/Badge.d.ts +11 -0
- package/dist/components/ui/Badge.js +3 -0
- package/dist/components/ui/BentoGrid.d.ts +10 -0
- package/dist/components/ui/BentoGrid.js +32 -0
- package/dist/components/ui/BrandIcons.d.ts +5 -0
- package/dist/components/ui/BrandIcons.js +2 -0
- package/dist/components/ui/Breadcrumb.d.ts +23 -0
- package/dist/components/ui/Breadcrumb.js +217 -0
- package/dist/components/ui/Button.d.ts +14 -0
- package/dist/components/ui/Button.js +6 -0
- package/dist/components/ui/ButtonGroup.d.ts +5 -0
- package/dist/components/ui/ButtonGroup.js +19 -0
- package/dist/components/ui/Calendar.d.ts +5 -0
- package/dist/components/ui/Calendar.js +119 -0
- package/dist/components/ui/Card.d.ts +26 -0
- package/dist/components/ui/Card.js +6 -0
- package/dist/components/ui/Carousel.d.ts +31 -0
- package/dist/components/ui/Carousel.js +331 -0
- package/dist/components/ui/Chart.d.ts +43 -0
- package/dist/components/ui/Chart.js +3 -0
- package/dist/components/ui/ChartCard.d.ts +17 -0
- package/dist/components/ui/ChartCard.js +42 -0
- package/dist/components/ui/CheckStatus.d.ts +11 -0
- package/dist/components/ui/CheckStatus.js +58 -0
- package/dist/components/ui/Checkbox.d.ts +6 -0
- package/dist/components/ui/Checkbox.js +115 -0
- package/dist/components/ui/CheckoutForm.d.ts +7 -0
- package/dist/components/ui/CheckoutForm.js +186 -0
- package/dist/components/ui/CheckoutFormDemo.d.ts +7 -0
- package/dist/components/ui/CheckoutFormDemo.js +294 -0
- package/dist/components/ui/CodeDiffViewer.d.ts +20 -0
- package/dist/components/ui/CodeDiffViewer.js +4 -0
- package/dist/components/ui/Collapsible.d.ts +5 -0
- package/dist/components/ui/Collapsible.js +2 -0
- package/dist/components/ui/Combobox.d.ts +11 -0
- package/dist/components/ui/Combobox.js +195 -0
- package/dist/components/ui/Command.d.ts +28 -0
- package/dist/components/ui/Command.js +121 -0
- package/dist/components/ui/ConfettiBurst.d.ts +11 -0
- package/dist/components/ui/ConfettiBurst.js +74 -0
- package/dist/components/ui/ContextMenu.d.ts +40 -0
- package/dist/components/ui/ContextMenu.js +296 -0
- package/dist/components/ui/ContextMeter.d.ts +18 -0
- package/dist/components/ui/ContextMeter.js +3 -0
- package/dist/components/ui/ConversationThread.d.ts +21 -0
- package/dist/components/ui/ConversationThread.js +81 -0
- package/dist/components/ui/DataFreshness.d.ts +10 -0
- package/dist/components/ui/DataFreshness.js +74 -0
- package/dist/components/ui/DataTable.d.ts +8 -0
- package/dist/components/ui/DataTable.js +123 -0
- package/dist/components/ui/DatePicker.d.ts +1 -0
- package/dist/components/ui/DatePicker.js +154 -0
- package/dist/components/ui/DateRangePicker.d.ts +2 -0
- package/dist/components/ui/DateRangePicker.js +167 -0
- package/dist/components/ui/Dialog.d.ts +27 -0
- package/dist/components/ui/Dialog.js +120 -0
- package/dist/components/ui/DiffStat.d.ts +7 -0
- package/dist/components/ui/DiffStat.js +33 -0
- package/dist/components/ui/Drawer.d.ts +27 -0
- package/dist/components/ui/Drawer.js +117 -0
- package/dist/components/ui/DropdownMenu.d.ts +40 -0
- package/dist/components/ui/DropdownMenu.js +115 -0
- package/dist/components/ui/Empty.d.ts +14 -0
- package/dist/components/ui/Empty.js +3 -0
- package/dist/components/ui/Field.d.ts +44 -0
- package/dist/components/ui/Field.js +3 -0
- package/dist/components/ui/FileUpload.d.ts +33 -0
- package/dist/components/ui/FileUpload.js +252 -0
- package/dist/components/ui/FloatingDock.d.ts +14 -0
- package/dist/components/ui/FloatingDock.js +103 -0
- package/dist/components/ui/Form.d.ts +34 -0
- package/dist/components/ui/Form.js +4 -0
- package/dist/components/ui/FormWizard.d.ts +31 -0
- package/dist/components/ui/FormWizard.js +9 -0
- package/dist/components/ui/HandoffIndicator.d.ts +14 -0
- package/dist/components/ui/HandoffIndicator.js +46 -0
- package/dist/components/ui/Heading.d.ts +293 -0
- package/dist/components/ui/Heading.js +3 -0
- package/dist/components/ui/HoverCard.d.ts +8 -0
- package/dist/components/ui/HoverCard.js +24 -0
- package/dist/components/ui/InfiniteSlider.d.ts +11 -0
- package/dist/components/ui/InfiniteSlider.js +3 -0
- package/dist/components/ui/Input.d.ts +15 -0
- package/dist/components/ui/Input.js +4 -0
- package/dist/components/ui/InputGroup.d.ts +8 -0
- package/dist/components/ui/InputGroup.js +37 -0
- package/dist/components/ui/InputOTP.d.ts +17 -0
- package/dist/components/ui/InputOTP.js +115 -0
- package/dist/components/ui/Item.d.ts +42 -0
- package/dist/components/ui/Item.js +177 -0
- package/dist/components/ui/KanbanBoard.d.ts +8 -0
- package/dist/components/ui/KanbanBoard.js +11 -0
- package/dist/components/ui/Kbd.d.ts +4 -0
- package/dist/components/ui/Kbd.js +18 -0
- package/dist/components/ui/Label.d.ts +6 -0
- package/dist/components/ui/Label.js +3 -0
- package/dist/components/ui/LanguageSwitcher.d.ts +9 -0
- package/dist/components/ui/LanguageSwitcher.js +116 -0
- package/dist/components/ui/Logo.d.ts +3 -0
- package/dist/components/ui/Logo.js +2 -0
- package/dist/components/ui/MagneticElement.d.ts +10 -0
- package/dist/components/ui/MagneticElement.js +44 -0
- package/dist/components/ui/MemoryInspector.d.ts +16 -0
- package/dist/components/ui/MemoryInspector.js +95 -0
- package/dist/components/ui/Menubar.d.ts +47 -0
- package/dist/components/ui/Menubar.js +338 -0
- package/dist/components/ui/MeteorShower.d.ts +9 -0
- package/dist/components/ui/MeteorShower.js +3 -0
- package/dist/components/ui/MetricCard.d.ts +22 -0
- package/dist/components/ui/MetricCard.js +16 -0
- package/dist/components/ui/MouseEffect.d.ts +20 -0
- package/dist/components/ui/MouseEffect.js +6 -0
- package/dist/components/ui/MovingBorder.d.ts +11 -0
- package/dist/components/ui/MovingBorder.js +41 -0
- package/dist/components/ui/NativeSelect.d.ts +5 -0
- package/dist/components/ui/NativeSelect.js +19 -0
- package/dist/components/ui/NavigationMenu.d.ts +24 -0
- package/dist/components/ui/NavigationMenu.js +242 -0
- package/dist/components/ui/NotificationCenter.d.ts +25 -0
- package/dist/components/ui/NotificationCenter.js +217 -0
- package/dist/components/ui/PageTransition.d.ts +9 -0
- package/dist/components/ui/PageTransition.js +56 -0
- package/dist/components/ui/Pagination.d.ts +17 -0
- package/dist/components/ui/Pagination.js +230 -0
- package/dist/components/ui/PasswordInput.d.ts +6 -0
- package/dist/components/ui/PasswordInput.js +8 -0
- package/dist/components/ui/Popover.d.ts +8 -0
- package/dist/components/ui/Popover.js +3 -0
- package/dist/components/ui/Progress.d.ts +6 -0
- package/dist/components/ui/Progress.js +3 -0
- package/dist/components/ui/ProgressRing.d.ts +17 -0
- package/dist/components/ui/ProgressRing.js +131 -0
- package/dist/components/ui/ProgressiveBlur.d.ts +7 -0
- package/dist/components/ui/ProgressiveBlur.js +3 -0
- package/dist/components/ui/PromoCard.d.ts +9 -0
- package/dist/components/ui/PromoCard.js +45 -0
- package/dist/components/ui/RadioGroup.d.ts +9 -0
- package/dist/components/ui/RadioGroup.js +151 -0
- package/dist/components/ui/Resizable.d.ts +8 -0
- package/dist/components/ui/Resizable.js +149 -0
- package/dist/components/ui/RoleBadge.d.ts +11 -0
- package/dist/components/ui/RoleBadge.js +3 -0
- package/dist/components/ui/ScrollArea.d.ts +9 -0
- package/dist/components/ui/ScrollArea.js +3 -0
- package/dist/components/ui/ScrollFadeIn.d.ts +12 -0
- package/dist/components/ui/ScrollFadeIn.js +6 -0
- package/dist/components/ui/SearchCommand.d.ts +33 -0
- package/dist/components/ui/SearchCommand.js +263 -0
- package/dist/components/ui/Select.d.ts +27 -0
- package/dist/components/ui/Select.js +115 -0
- package/dist/components/ui/Separator.d.ts +7 -0
- package/dist/components/ui/Separator.js +3 -0
- package/dist/components/ui/SettingsModal.d.ts +19 -0
- package/dist/components/ui/SettingsModal.js +219 -0
- package/dist/components/ui/ShaderBackground.d.ts +16 -0
- package/dist/components/ui/ShaderBackground.js +74 -0
- package/dist/components/ui/Sheet.d.ts +33 -0
- package/dist/components/ui/Sheet.js +116 -0
- package/dist/components/ui/Sidebar.d.ts +122 -0
- package/dist/components/ui/Sidebar.js +128 -0
- package/dist/components/ui/Skeleton.d.ts +5 -0
- package/dist/components/ui/Skeleton.js +3 -0
- package/dist/components/ui/SkipNav.d.ts +2 -0
- package/dist/components/ui/SkipNav.js +20 -0
- package/dist/components/ui/Slider.d.ts +22 -0
- package/dist/components/ui/Slider.js +6 -0
- package/dist/components/ui/Sonner.d.ts +4 -0
- package/dist/components/ui/Sonner.js +26 -0
- package/dist/components/ui/SourceCitation.d.ts +19 -0
- package/dist/components/ui/SourceCitation.js +120 -0
- package/dist/components/ui/Spinner.d.ts +6 -0
- package/dist/components/ui/Spinner.js +3 -0
- package/dist/components/ui/SpringHover.d.ts +12 -0
- package/dist/components/ui/SpringHover.js +35 -0
- package/dist/components/ui/StaggerChildren.d.ts +11 -0
- package/dist/components/ui/StaggerChildren.js +6 -0
- package/dist/components/ui/StaggeredEntrance.d.ts +8 -0
- package/dist/components/ui/StaggeredEntrance.js +24 -0
- package/dist/components/ui/StatusDot.d.ts +11 -0
- package/dist/components/ui/StatusDot.js +3 -0
- package/dist/components/ui/StyleToggle.d.ts +7 -0
- package/dist/components/ui/StyleToggle.js +65 -0
- package/dist/components/ui/SuccessCheck.d.ts +10 -0
- package/dist/components/ui/SuccessCheck.js +55 -0
- package/dist/components/ui/Switch.d.ts +6 -0
- package/dist/components/ui/Switch.js +3 -0
- package/dist/components/ui/Table.d.ts +29 -0
- package/dist/components/ui/Table.js +3 -0
- package/dist/components/ui/Tabs.d.ts +13 -0
- package/dist/components/ui/Tabs.js +3 -0
- package/dist/components/ui/TagInput.d.ts +10 -0
- package/dist/components/ui/TagInput.js +216 -0
- package/dist/components/ui/Textarea.d.ts +13 -0
- package/dist/components/ui/Textarea.js +4 -0
- package/dist/components/ui/ThemeToggle.d.ts +7 -0
- package/dist/components/ui/ThemeToggle.js +150 -0
- package/dist/components/ui/ThinkingIndicator.d.ts +12 -0
- package/dist/components/ui/ThinkingIndicator.js +8 -0
- package/dist/components/ui/TiltCard.d.ts +10 -0
- package/dist/components/ui/TiltCard.js +51 -0
- package/dist/components/ui/Timeline.d.ts +14 -0
- package/dist/components/ui/Timeline.js +3 -0
- package/dist/components/ui/Toast.d.ts +28 -0
- package/dist/components/ui/Toast.js +115 -0
- package/dist/components/ui/Toaster.d.ts +1 -0
- package/dist/components/ui/Toaster.js +136 -0
- package/dist/components/ui/Toggle.d.ts +11 -0
- package/dist/components/ui/Toggle.js +3 -0
- package/dist/components/ui/ToggleGroup.d.ts +11 -0
- package/dist/components/ui/ToggleGroup.js +57 -0
- package/dist/components/ui/ToolCallCard.d.ts +16 -0
- package/dist/components/ui/ToolCallCard.js +9 -0
- package/dist/components/ui/Tooltip.d.ts +9 -0
- package/dist/components/ui/Tooltip.js +3 -0
- package/dist/components/ui/TreeView.d.ts +15 -0
- package/dist/components/ui/TreeView.js +299 -0
- package/dist/components/ui/TrendIndicator.d.ts +11 -0
- package/dist/components/ui/TrendIndicator.js +7 -0
- package/dist/components/ui/Typography.d.ts +11 -0
- package/dist/components/ui/Typography.js +3 -0
- package/dist/components/ui/VisuallyHidden.d.ts +2 -0
- package/dist/components/ui/VisuallyHidden.js +8 -0
- package/dist/components/ui/WorkflowGraph.d.ts +25 -0
- package/dist/components/ui/WorkflowGraph.js +3 -0
- package/dist/components/ui/charts/AreaChart.d.ts +14 -0
- package/dist/components/ui/charts/AreaChart.js +4 -0
- package/dist/components/ui/charts/BarChart.d.ts +16 -0
- package/dist/components/ui/charts/BarChart.js +4 -0
- package/dist/components/ui/charts/HeatmapChart.d.ts +16 -0
- package/dist/components/ui/charts/HeatmapChart.js +4 -0
- package/dist/components/ui/charts/LineChart.d.ts +13 -0
- package/dist/components/ui/charts/LineChart.js +4 -0
- package/dist/components/ui/charts/PieChart.d.ts +15 -0
- package/dist/components/ui/charts/PieChart.js +4 -0
- package/dist/components/ui/charts/RadarChart.d.ts +12 -0
- package/dist/components/ui/charts/RadarChart.js +4 -0
- package/dist/components/ui/charts/RadialBarChart.d.ts +14 -0
- package/dist/components/ui/charts/RadialBarChart.js +4 -0
- package/dist/components/ui/charts/Sparkline.d.ts +13 -0
- package/dist/components/ui/charts/Sparkline.js +6 -0
- package/dist/components/ui/charts/index.d.ts +7 -0
- package/dist/components/ui/charts/index.js +9 -0
- package/dist/components/ui/icons/activity.d.ts +7 -0
- package/dist/components/ui/icons/activity.js +4 -0
- package/dist/components/ui/icons/alert-circle.d.ts +7 -0
- package/dist/components/ui/icons/alert-circle.js +4 -0
- package/dist/components/ui/icons/alert-triangle.d.ts +7 -0
- package/dist/components/ui/icons/alert-triangle.js +4 -0
- package/dist/components/ui/icons/arrow-down-right.d.ts +7 -0
- package/dist/components/ui/icons/arrow-down-right.js +4 -0
- package/dist/components/ui/icons/arrow-down.d.ts +7 -0
- package/dist/components/ui/icons/arrow-down.js +4 -0
- package/dist/components/ui/icons/arrow-left.d.ts +7 -0
- package/dist/components/ui/icons/arrow-left.js +4 -0
- package/dist/components/ui/icons/arrow-right.d.ts +7 -0
- package/dist/components/ui/icons/arrow-right.js +4 -0
- package/dist/components/ui/icons/arrow-up-right.d.ts +7 -0
- package/dist/components/ui/icons/arrow-up-right.js +4 -0
- package/dist/components/ui/icons/arrow-up.d.ts +7 -0
- package/dist/components/ui/icons/arrow-up.js +4 -0
- package/dist/components/ui/icons/bell.d.ts +7 -0
- package/dist/components/ui/icons/bell.js +4 -0
- package/dist/components/ui/icons/bold.d.ts +7 -0
- package/dist/components/ui/icons/bold.js +4 -0
- package/dist/components/ui/icons/bot.d.ts +7 -0
- package/dist/components/ui/icons/bot.js +4 -0
- package/dist/components/ui/icons/calendar.d.ts +7 -0
- package/dist/components/ui/icons/calendar.js +4 -0
- package/dist/components/ui/icons/chart-bar.d.ts +7 -0
- package/dist/components/ui/icons/chart-bar.js +4 -0
- package/dist/components/ui/icons/chart-line.d.ts +7 -0
- package/dist/components/ui/icons/chart-line.js +4 -0
- package/dist/components/ui/icons/chart-pie.d.ts +7 -0
- package/dist/components/ui/icons/chart-pie.js +4 -0
- package/dist/components/ui/icons/check-circle.d.ts +7 -0
- package/dist/components/ui/icons/check-circle.js +4 -0
- package/dist/components/ui/icons/check.d.ts +7 -0
- package/dist/components/ui/icons/check.js +4 -0
- package/dist/components/ui/icons/chevron-down.d.ts +7 -0
- package/dist/components/ui/icons/chevron-down.js +4 -0
- package/dist/components/ui/icons/chevron-left.d.ts +7 -0
- package/dist/components/ui/icons/chevron-left.js +4 -0
- package/dist/components/ui/icons/chevron-right.d.ts +7 -0
- package/dist/components/ui/icons/chevron-right.js +4 -0
- package/dist/components/ui/icons/chevron-up.d.ts +7 -0
- package/dist/components/ui/icons/chevron-up.js +4 -0
- package/dist/components/ui/icons/chevrons-up-down.d.ts +7 -0
- package/dist/components/ui/icons/chevrons-up-down.js +4 -0
- package/dist/components/ui/icons/circle.d.ts +7 -0
- package/dist/components/ui/icons/circle.js +4 -0
- package/dist/components/ui/icons/clipboard.d.ts +7 -0
- package/dist/components/ui/icons/clipboard.js +4 -0
- package/dist/components/ui/icons/clock.d.ts +7 -0
- package/dist/components/ui/icons/clock.js +4 -0
- package/dist/components/ui/icons/cloud.d.ts +7 -0
- package/dist/components/ui/icons/cloud.js +4 -0
- package/dist/components/ui/icons/code-2.d.ts +7 -0
- package/dist/components/ui/icons/code-2.js +4 -0
- package/dist/components/ui/icons/copy.d.ts +7 -0
- package/dist/components/ui/icons/copy.js +4 -0
- package/dist/components/ui/icons/corner-down-left.d.ts +7 -0
- package/dist/components/ui/icons/corner-down-left.js +4 -0
- package/dist/components/ui/icons/credit-card.d.ts +7 -0
- package/dist/components/ui/icons/credit-card.js +4 -0
- package/dist/components/ui/icons/database.d.ts +7 -0
- package/dist/components/ui/icons/database.js +4 -0
- package/dist/components/ui/icons/dollar-sign.d.ts +7 -0
- package/dist/components/ui/icons/dollar-sign.js +4 -0
- package/dist/components/ui/icons/dot.d.ts +7 -0
- package/dist/components/ui/icons/dot.js +4 -0
- package/dist/components/ui/icons/download.d.ts +7 -0
- package/dist/components/ui/icons/download.js +4 -0
- package/dist/components/ui/icons/ellipsis.d.ts +7 -0
- package/dist/components/ui/icons/ellipsis.js +4 -0
- package/dist/components/ui/icons/external-link.d.ts +7 -0
- package/dist/components/ui/icons/external-link.js +4 -0
- package/dist/components/ui/icons/eye-off.d.ts +7 -0
- package/dist/components/ui/icons/eye-off.js +4 -0
- package/dist/components/ui/icons/eye.d.ts +7 -0
- package/dist/components/ui/icons/eye.js +4 -0
- package/dist/components/ui/icons/file.d.ts +7 -0
- package/dist/components/ui/icons/file.js +4 -0
- package/dist/components/ui/icons/filter.d.ts +7 -0
- package/dist/components/ui/icons/filter.js +4 -0
- package/dist/components/ui/icons/folder.d.ts +7 -0
- package/dist/components/ui/icons/folder.js +4 -0
- package/dist/components/ui/icons/github.d.ts +7 -0
- package/dist/components/ui/icons/github.js +4 -0
- package/dist/components/ui/icons/globe.d.ts +7 -0
- package/dist/components/ui/icons/globe.js +4 -0
- package/dist/components/ui/icons/grip-vertical.d.ts +7 -0
- package/dist/components/ui/icons/grip-vertical.js +4 -0
- package/dist/components/ui/icons/home.d.ts +7 -0
- package/dist/components/ui/icons/home.js +4 -0
- package/dist/components/ui/icons/image.d.ts +7 -0
- package/dist/components/ui/icons/image.js +4 -0
- package/dist/components/ui/icons/index.d.ts +111 -0
- package/dist/components/ui/icons/index.js +113 -0
- package/dist/components/ui/icons/info.d.ts +7 -0
- package/dist/components/ui/icons/info.js +4 -0
- package/dist/components/ui/icons/italic.d.ts +7 -0
- package/dist/components/ui/icons/italic.js +4 -0
- package/dist/components/ui/icons/key.d.ts +7 -0
- package/dist/components/ui/icons/key.js +4 -0
- package/dist/components/ui/icons/laptop.d.ts +7 -0
- package/dist/components/ui/icons/laptop.js +4 -0
- package/dist/components/ui/icons/layers.d.ts +7 -0
- package/dist/components/ui/icons/layers.js +4 -0
- package/dist/components/ui/icons/layout-dashboard.d.ts +7 -0
- package/dist/components/ui/icons/layout-dashboard.js +4 -0
- package/dist/components/ui/icons/lib/create-animated-icon.d.ts +7 -0
- package/dist/components/ui/icons/lib/create-animated-icon.js +4 -0
- package/dist/components/ui/icons/lib/types.d.ts +8 -0
- package/dist/components/ui/icons/lib/types.js +1 -0
- package/dist/components/ui/icons/lib/use-animated-icon.d.ts +26 -0
- package/dist/components/ui/icons/lib/use-animated-icon.js +2 -0
- package/dist/components/ui/icons/link.d.ts +7 -0
- package/dist/components/ui/icons/link.js +4 -0
- package/dist/components/ui/icons/linkedin.d.ts +7 -0
- package/dist/components/ui/icons/linkedin.js +4 -0
- package/dist/components/ui/icons/list.d.ts +7 -0
- package/dist/components/ui/icons/list.js +4 -0
- package/dist/components/ui/icons/loader-circle.d.ts +7 -0
- package/dist/components/ui/icons/loader-circle.js +4 -0
- package/dist/components/ui/icons/loader.d.ts +7 -0
- package/dist/components/ui/icons/loader.js +4 -0
- package/dist/components/ui/icons/lock.d.ts +7 -0
- package/dist/components/ui/icons/lock.js +4 -0
- package/dist/components/ui/icons/log-in.d.ts +7 -0
- package/dist/components/ui/icons/log-in.js +4 -0
- package/dist/components/ui/icons/log-out.d.ts +7 -0
- package/dist/components/ui/icons/log-out.js +4 -0
- package/dist/components/ui/icons/lucide-wrapped.d.ts +289 -0
- package/dist/components/ui/icons/lucide-wrapped.js +5 -0
- package/dist/components/ui/icons/mail.d.ts +7 -0
- package/dist/components/ui/icons/mail.js +4 -0
- package/dist/components/ui/icons/menu.d.ts +7 -0
- package/dist/components/ui/icons/menu.js +4 -0
- package/dist/components/ui/icons/mic-off.d.ts +7 -0
- package/dist/components/ui/icons/mic-off.js +4 -0
- package/dist/components/ui/icons/mic.d.ts +7 -0
- package/dist/components/ui/icons/mic.js +4 -0
- package/dist/components/ui/icons/minus.d.ts +7 -0
- package/dist/components/ui/icons/minus.js +4 -0
- package/dist/components/ui/icons/monitor.d.ts +7 -0
- package/dist/components/ui/icons/monitor.js +4 -0
- package/dist/components/ui/icons/moon.d.ts +7 -0
- package/dist/components/ui/icons/moon.js +4 -0
- package/dist/components/ui/icons/package-2.d.ts +7 -0
- package/dist/components/ui/icons/package-2.js +4 -0
- package/dist/components/ui/icons/package.d.ts +7 -0
- package/dist/components/ui/icons/package.js +4 -0
- package/dist/components/ui/icons/panel-left.d.ts +7 -0
- package/dist/components/ui/icons/panel-left.js +4 -0
- package/dist/components/ui/icons/paperclip.d.ts +7 -0
- package/dist/components/ui/icons/paperclip.js +4 -0
- package/dist/components/ui/icons/pause.d.ts +7 -0
- package/dist/components/ui/icons/pause.js +4 -0
- package/dist/components/ui/icons/pencil.d.ts +7 -0
- package/dist/components/ui/icons/pencil.js +4 -0
- package/dist/components/ui/icons/play.d.ts +7 -0
- package/dist/components/ui/icons/play.js +4 -0
- package/dist/components/ui/icons/plus.d.ts +7 -0
- package/dist/components/ui/icons/plus.js +4 -0
- package/dist/components/ui/icons/receipt.d.ts +7 -0
- package/dist/components/ui/icons/receipt.js +4 -0
- package/dist/components/ui/icons/refresh-cw.d.ts +7 -0
- package/dist/components/ui/icons/refresh-cw.js +4 -0
- package/dist/components/ui/icons/reply.d.ts +7 -0
- package/dist/components/ui/icons/reply.js +4 -0
- package/dist/components/ui/icons/rocket.d.ts +7 -0
- package/dist/components/ui/icons/rocket.js +4 -0
- package/dist/components/ui/icons/save.d.ts +7 -0
- package/dist/components/ui/icons/save.js +4 -0
- package/dist/components/ui/icons/search.d.ts +7 -0
- package/dist/components/ui/icons/search.js +4 -0
- package/dist/components/ui/icons/send.d.ts +7 -0
- package/dist/components/ui/icons/send.js +4 -0
- package/dist/components/ui/icons/settings-2.d.ts +7 -0
- package/dist/components/ui/icons/settings-2.js +4 -0
- package/dist/components/ui/icons/settings.d.ts +7 -0
- package/dist/components/ui/icons/settings.js +4 -0
- package/dist/components/ui/icons/share.d.ts +7 -0
- package/dist/components/ui/icons/share.js +4 -0
- package/dist/components/ui/icons/shield-check.d.ts +7 -0
- package/dist/components/ui/icons/shield-check.js +4 -0
- package/dist/components/ui/icons/shield.d.ts +7 -0
- package/dist/components/ui/icons/shield.js +4 -0
- package/dist/components/ui/icons/smartphone.d.ts +7 -0
- package/dist/components/ui/icons/smartphone.js +4 -0
- package/dist/components/ui/icons/snowflake.d.ts +7 -0
- package/dist/components/ui/icons/snowflake.js +4 -0
- package/dist/components/ui/icons/sort.d.ts +7 -0
- package/dist/components/ui/icons/sort.js +4 -0
- package/dist/components/ui/icons/sparkles.d.ts +7 -0
- package/dist/components/ui/icons/sparkles.js +4 -0
- package/dist/components/ui/icons/star.d.ts +7 -0
- package/dist/components/ui/icons/star.js +4 -0
- package/dist/components/ui/icons/stop.d.ts +7 -0
- package/dist/components/ui/icons/stop.js +4 -0
- package/dist/components/ui/icons/sun.d.ts +7 -0
- package/dist/components/ui/icons/sun.js +4 -0
- package/dist/components/ui/icons/table.d.ts +7 -0
- package/dist/components/ui/icons/table.js +4 -0
- package/dist/components/ui/icons/terminal.d.ts +7 -0
- package/dist/components/ui/icons/terminal.js +4 -0
- package/dist/components/ui/icons/thumbs-down.d.ts +7 -0
- package/dist/components/ui/icons/thumbs-down.js +4 -0
- package/dist/components/ui/icons/thumbs-up.d.ts +7 -0
- package/dist/components/ui/icons/thumbs-up.js +4 -0
- package/dist/components/ui/icons/trash-2.d.ts +7 -0
- package/dist/components/ui/icons/trash-2.js +4 -0
- package/dist/components/ui/icons/twitter.d.ts +7 -0
- package/dist/components/ui/icons/twitter.js +4 -0
- package/dist/components/ui/icons/underline.d.ts +7 -0
- package/dist/components/ui/icons/underline.js +4 -0
- package/dist/components/ui/icons/upload.d.ts +7 -0
- package/dist/components/ui/icons/upload.js +4 -0
- package/dist/components/ui/icons/user.d.ts +7 -0
- package/dist/components/ui/icons/user.js +4 -0
- package/dist/components/ui/icons/users.d.ts +7 -0
- package/dist/components/ui/icons/users.js +4 -0
- package/dist/components/ui/icons/wrench.d.ts +7 -0
- package/dist/components/ui/icons/wrench.js +4 -0
- package/dist/components/ui/icons/x-circle.d.ts +7 -0
- package/dist/components/ui/icons/x-circle.js +4 -0
- package/dist/components/ui/icons/x.d.ts +7 -0
- package/dist/components/ui/icons/x.js +4 -0
- package/dist/components/ui/icons/zap.d.ts +7 -0
- package/dist/components/ui/icons/zap.js +4 -0
- package/dist/components/ui/kanban.a11y.d.ts +10 -0
- package/dist/components/ui/kanban.a11y.js +1 -0
- package/dist/components/ui/kanban.context.d.ts +18 -0
- package/dist/components/ui/kanban.context.js +2 -0
- package/dist/components/ui/kanban.types.d.ts +56 -0
- package/dist/components/ui/kanban.types.js +1 -0
- package/dist/components/ui/kanban.utils.d.ts +14 -0
- package/dist/components/ui/kanban.utils.js +1 -0
- package/dist/components/ui/stepper/index.d.ts +2 -0
- package/dist/components/ui/stepper/index.js +7 -0
- package/dist/components/ui/stepper/step.d.ts +10 -0
- package/dist/components/ui/stepper/step.js +6 -0
- package/dist/components/ui/stepper/stepper.d.ts +19 -0
- package/dist/components/ui/stepper/stepper.js +3 -0
- package/dist/components/ui/text-effects/AnimatedGradientText.d.ts +9 -0
- package/dist/components/ui/text-effects/AnimatedGradientText.js +3 -0
- package/dist/components/ui/text-effects/CountingNumber.d.ts +15 -0
- package/dist/components/ui/text-effects/CountingNumber.js +3 -0
- package/dist/components/ui/text-effects/FlipWords.d.ts +10 -0
- package/dist/components/ui/text-effects/FlipWords.js +6 -0
- package/dist/components/ui/text-effects/HighlightText.d.ts +9 -0
- package/dist/components/ui/text-effects/HighlightText.js +7 -0
- package/dist/components/ui/text-effects/MorphingText.d.ts +10 -0
- package/dist/components/ui/text-effects/MorphingText.js +6 -0
- package/dist/components/ui/text-effects/ShimmeringText.d.ts +9 -0
- package/dist/components/ui/text-effects/ShimmeringText.js +2 -0
- package/dist/components/ui/text-effects/SlidingNumber.d.ts +16 -0
- package/dist/components/ui/text-effects/SlidingNumber.js +6 -0
- package/dist/components/ui/text-effects/StreamingText.d.ts +26 -0
- package/dist/components/ui/text-effects/StreamingText.js +3 -0
- package/dist/components/ui/text-effects/TextReveal.d.ts +11 -0
- package/dist/components/ui/text-effects/TextReveal.js +3 -0
- package/dist/components/ui/text-effects/index.d.ts +15 -0
- package/dist/components/ui/text-effects/index.js +15 -0
- package/dist/hooks/use-dismissed.d.ts +1 -0
- package/dist/hooks/use-dismissed.js +2 -0
- package/dist/hooks/use-is-in-view.d.ts +12 -0
- package/dist/hooks/use-is-in-view.js +2 -0
- package/dist/hooks/use-mobile.d.ts +1 -0
- package/dist/hooks/use-mobile.js +2 -0
- package/dist/hooks/use-motion-value-state.d.ts +3 -0
- package/dist/hooks/use-motion-value-state.js +2 -0
- package/dist/hooks/use-reduced-motion.d.ts +1 -0
- package/dist/hooks/use-reduced-motion.js +2 -0
- package/dist/hooks/use-safe-timeout.d.ts +5 -0
- package/dist/hooks/use-safe-timeout.js +1 -0
- package/dist/hooks/use-shader-preset.d.ts +12 -0
- package/dist/hooks/use-shader-preset.js +4 -0
- package/dist/hooks/use-toast.d.ts +44 -0
- package/dist/hooks/use-toast.js +2 -0
- package/dist/hooks/use-token.d.ts +9 -0
- package/dist/hooks/use-token.js +28 -0
- package/dist/hooks/useHotkey.d.ts +3 -0
- package/dist/hooks/useHotkey.js +37 -0
- package/dist/index.js +139 -0
- package/dist/lib/ThemeProvider.d.ts +21 -0
- package/dist/lib/ThemeProvider.js +2 -0
- package/dist/lib/animation.tokens.d.ts +249 -0
- package/dist/lib/animation.tokens.js +1 -0
- package/dist/lib/get-strict-context.d.ts +9 -0
- package/dist/lib/get-strict-context.js +2 -0
- package/dist/lib/merge-messages.d.ts +7 -0
- package/dist/lib/merge-messages.js +19 -0
- package/dist/lib/motion.d.ts +281 -0
- package/dist/lib/motion.js +4 -0
- package/dist/lib/patterns.d.ts +11 -0
- package/dist/lib/patterns.js +174 -0
- package/dist/lib/react-utils.d.ts +12 -0
- package/dist/lib/react-utils.js +1 -0
- package/dist/lib/shader-presets.d.ts +15 -0
- package/dist/lib/shader-presets.js +1 -0
- package/dist/lib/tokens.config.d.ts +796 -0
- package/dist/lib/tokens.config.test.d.ts +1 -0
- package/dist/lib/utils.d.ts +4 -0
- package/dist/lib/utils.js +1 -0
- package/dist/lib-index.d.ts +29 -0
- package/dist/messages/en.d.ts +3 -0
- package/dist/messages/en.js +1 -0
- package/dist/messages/it.d.ts +3 -0
- package/dist/messages/it.js +1 -0
- package/dist/site.config.d.ts +25 -0
- package/dist/test/PublicSeedTestProvider.d.ts +16 -0
- package/dist/test/PublicSeedTestProvider.js +25 -0
- package/dist/tokens.d.ts +188 -0
- package/eslint-rules/nadicode/__tests__/rules.test.js +2143 -0
- package/eslint-rules/nadicode/config.js +154 -0
- package/eslint-rules/nadicode/flat-config.mjs +16 -0
- package/eslint-rules/nadicode/index.js +145 -0
- package/eslint-rules/nadicode/rules/__tests__/no-direct-motion-import.test.js +72 -0
- package/eslint-rules/nadicode/rules/__tests__/no-diy-backdrop-blur.test.js +115 -0
- package/eslint-rules/nadicode/rules/__tests__/no-forbidden-tokens.test.js +97 -0
- package/eslint-rules/nadicode/rules/__tests__/no-handcoded-heading.test.js +107 -0
- package/eslint-rules/nadicode/rules/__tests__/no-hardcoded-motion-transition.test.js +149 -0
- package/eslint-rules/nadicode/rules/__tests__/require-aria-hidden-on-decorative-icon.test.js +73 -0
- package/eslint-rules/nadicode/rules/__tests__/require-focus-ring-with-outline-none.test.js +65 -0
- package/eslint-rules/nadicode/rules/__tests__/require-focus-visible-with-group-hover.test.js +60 -0
- package/eslint-rules/nadicode/rules/no-admin-arbitrary-text-size.js +53 -0
- package/eslint-rules/nadicode/rules/no-admin-manual-chart-bars.js +46 -0
- package/eslint-rules/nadicode/rules/no-app-primitive-composition.js +58 -0
- package/eslint-rules/nadicode/rules/no-arbitrary-chart-color.js +65 -0
- package/eslint-rules/nadicode/rules/no-barrel-imports.js +44 -0
- package/eslint-rules/nadicode/rules/no-deprecated-segment-config.js +56 -0
- package/eslint-rules/nadicode/rules/no-derived-state-via-useeffect.js +139 -0
- package/eslint-rules/nadicode/rules/no-direct-lucide-import.js +30 -0
- package/eslint-rules/nadicode/rules/no-direct-motion-import.js +68 -0
- package/eslint-rules/nadicode/rules/no-diy-backdrop-blur.js +82 -0
- package/eslint-rules/nadicode/rules/no-external-ui-library.js +43 -0
- package/eslint-rules/nadicode/rules/no-falsy-and-render.js +106 -0
- package/eslint-rules/nadicode/rules/no-forbidden-bespoke-chat-primitive.js +54 -0
- package/eslint-rules/nadicode/rules/no-forbidden-chat-class-usage.js +53 -0
- package/eslint-rules/nadicode/rules/no-forbidden-tokens.js +153 -0
- package/eslint-rules/nadicode/rules/no-forward-ref.js +44 -0
- package/eslint-rules/nadicode/rules/no-framer-motion-import.js +36 -0
- package/eslint-rules/nadicode/rules/no-handcoded-badge.js +132 -0
- package/eslint-rules/nadicode/rules/no-handcoded-empty-state.js +82 -0
- package/eslint-rules/nadicode/rules/no-handcoded-heading.js +273 -0
- package/eslint-rules/nadicode/rules/no-hardcoded-inline-color.js +233 -0
- package/eslint-rules/nadicode/rules/no-hardcoded-inline-duration.js +98 -0
- package/eslint-rules/nadicode/rules/no-hardcoded-inline-spacing.js +84 -0
- package/eslint-rules/nadicode/rules/no-hardcoded-inline-zindex.js +54 -0
- package/eslint-rules/nadicode/rules/no-hardcoded-motion-transition.js +139 -0
- package/eslint-rules/nadicode/rules/no-has-svg-selector.js +51 -0
- package/eslint-rules/nadicode/rules/no-inline-default-nonprimitive-props.js +93 -0
- package/eslint-rules/nadicode/rules/no-layout-property-animation.js +84 -0
- package/eslint-rules/nadicode/rules/no-low-contrast-text-opacity.js +67 -0
- package/eslint-rules/nadicode/rules/no-mutating-sort-on-state.js +136 -0
- package/eslint-rules/nadicode/rules/no-nested-glass.js +64 -0
- package/eslint-rules/nadicode/rules/no-object-in-effect-deps.js +48 -0
- package/eslint-rules/nadicode/rules/no-off-grid-spacing.js +69 -0
- package/eslint-rules/nadicode/rules/no-raw-recharts-import.js +36 -0
- package/eslint-rules/nadicode/rules/no-raw-tailwind-palette.js +57 -0
- package/eslint-rules/nadicode/rules/no-redirect-in-try-catch.js +129 -0
- package/eslint-rules/nadicode/rules/no-regexp-in-render.js +140 -0
- package/eslint-rules/nadicode/rules/no-runtime-api-in-use-cache.js +130 -0
- package/eslint-rules/nadicode/rules/no-screen-height-classes.js +72 -0
- package/eslint-rules/nadicode/rules/no-ssr-false-on-page.js +101 -0
- package/eslint-rules/nadicode/rules/no-unregistered-glass.js +125 -0
- package/eslint-rules/nadicode/rules/no-unstable-cache.js +36 -0
- package/eslint-rules/nadicode/rules/require-action-schema.js +142 -0
- package/eslint-rules/nadicode/rules/require-admin-sidebar-group-label.js +39 -0
- package/eslint-rules/nadicode/rules/require-aria-hidden-on-decorative-icon.js +76 -0
- package/eslint-rules/nadicode/rules/require-aria-label-on-nav.js +44 -0
- package/eslint-rules/nadicode/rules/require-auth-in-server-action.js +203 -0
- package/eslint-rules/nadicode/rules/require-chart-empty-handler.js +67 -0
- package/eslint-rules/nadicode/rules/require-dashboard-loading-skeleton.js +78 -0
- package/eslint-rules/nadicode/rules/require-effect-cleanup.js +116 -0
- package/eslint-rules/nadicode/rules/require-focus-ring-with-outline-none.js +48 -0
- package/eslint-rules/nadicode/rules/require-focus-visible-with-group-hover.js +57 -0
- package/eslint-rules/nadicode/rules/require-form-action.js +32 -0
- package/eslint-rules/nadicode/rules/require-glass-on-floating-ui.js +105 -0
- package/eslint-rules/nadicode/rules/require-input-name.js +56 -0
- package/eslint-rules/nadicode/rules/require-lazy-motion-provider.js +47 -0
- package/eslint-rules/nadicode/rules/require-lazy-state-init.js +61 -0
- package/eslint-rules/nadicode/rules/require-loading-fallback-on-dynamic.js +58 -0
- package/eslint-rules/nadicode/rules/require-metadata-on-page.js +96 -0
- package/eslint-rules/nadicode/rules/require-overflow-x-on-table-wrapper.js +59 -0
- package/eslint-rules/nadicode/rules/require-passive-event-listener.js +92 -0
- package/eslint-rules/nadicode/rules/require-reduced-motion-on-motion-import.js +112 -0
- package/eslint-rules/nadicode/rules/require-scroll-containment-on-overlay.js +69 -0
- package/eslint-rules/nadicode/rules/require-sidebar-trigger.js +52 -0
- package/eslint-rules/nadicode/rules/require-sizes-on-fill-image.js +65 -0
- package/eslint-rules/nadicode/rules/require-stagger-on-metric-grid.js +74 -0
- package/eslint-rules/nadicode/rules/require-touch-target-on-interactive.js +146 -0
- package/eslint-rules/nadicode/rules/require-usememo-for-render-filter-sort.js +172 -0
- package/eslint-rules/nadicode/rules/require-usesyncexternalstore-for-subscriptions.js +117 -0
- package/eslint-rules/nadicode/utils.js +302 -0
- package/package.json +1673 -0
- package/scripts/ds-check.mjs +969 -0
- package/scripts/ds-update.mjs +50 -0
- package/scripts/sync-seed-skill.mjs +64 -0
- package/src/lib/tokens.config.js +561 -0
- package/tailwind.config.js +300 -0
- package/tailwind.js +42 -0
- package/templates/consumer-eslint.config.mjs +63 -0
|
@@ -0,0 +1,786 @@
|
|
|
1
|
+
# Recipe: Navigation Shell
|
|
2
|
+
|
|
3
|
+
Shared app navigation frame with sidebar, top bar, Cmd+K search, breadcrumbs, and user menu.
|
|
4
|
+
|
|
5
|
+
## Purpose
|
|
6
|
+
|
|
7
|
+
The navigation shell wraps all app-shell pages. It is not a page itself but the persistent frame around page content. This recipe defines the complete app shell layout with working wiring for every navigation subsystem.
|
|
8
|
+
|
|
9
|
+
## Shell
|
|
10
|
+
|
|
11
|
+
`app-shell` (this IS the shell definition)
|
|
12
|
+
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
## Layout Blueprint (Desktop)
|
|
16
|
+
|
|
17
|
+
```
|
|
18
|
+
+--+----------------------------------------------+
|
|
19
|
+
| | [=] Home > Settings [Cmd+K] [🔔] [User] |
|
|
20
|
+
|S | |
|
|
21
|
+
|I | +------------------------------------------+ |
|
|
22
|
+
|D | | | |
|
|
23
|
+
|E | | Page Content | |
|
|
24
|
+
|B | | (filled by child route) | |
|
|
25
|
+
|A | | | |
|
|
26
|
+
|R | | | |
|
|
27
|
+
| | +------------------------------------------+ |
|
|
28
|
+
+--+----------------------------------------------+
|
|
29
|
+
|
|
30
|
+
Sidebar (expanded):
|
|
31
|
+
+------------------+
|
|
32
|
+
| [v] Acme Inc | <-- Workspace switcher (DropdownMenu)
|
|
33
|
+
+------------------+
|
|
34
|
+
| Group: Main |
|
|
35
|
+
| Dashboard |
|
|
36
|
+
| Analytics |
|
|
37
|
+
| Agents |
|
|
38
|
+
+------------------+
|
|
39
|
+
| Group: Manage |
|
|
40
|
+
| Team |
|
|
41
|
+
| Settings |
|
|
42
|
+
+------------------+
|
|
43
|
+
| [Avatar] Jane | <-- NavUser (DropdownMenu)
|
|
44
|
+
+------------------+
|
|
45
|
+
|
|
46
|
+
Mobile: Sidebar hidden, hamburger in top bar opens Sheet overlay
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
---
|
|
50
|
+
|
|
51
|
+
## Section Sequence
|
|
52
|
+
|
|
53
|
+
### 1. App Shell Layout (the file)
|
|
54
|
+
|
|
55
|
+
This is your app route group layout (e.g. src/app/(app)/layout.tsx). It composes every subsystem.
|
|
56
|
+
|
|
57
|
+
```tsx
|
|
58
|
+
'use client'
|
|
59
|
+
|
|
60
|
+
import { usePathname } from 'next/navigation'
|
|
61
|
+
import {
|
|
62
|
+
Sidebar,
|
|
63
|
+
SidebarProvider,
|
|
64
|
+
SidebarTrigger,
|
|
65
|
+
SidebarInset,
|
|
66
|
+
SidebarHeader,
|
|
67
|
+
SidebarContent,
|
|
68
|
+
SidebarFooter,
|
|
69
|
+
SidebarGroup,
|
|
70
|
+
SidebarGroupLabel,
|
|
71
|
+
SidebarMenu,
|
|
72
|
+
SidebarMenuItem,
|
|
73
|
+
SidebarMenuButton,
|
|
74
|
+
SidebarMenuSub,
|
|
75
|
+
SidebarMenuSubItem,
|
|
76
|
+
SidebarMenuSubButton,
|
|
77
|
+
} from '@vadimcomanescu/nadicode-design-system/sidebar'
|
|
78
|
+
import { NavUser } from '@vadimcomanescu/nadicode-design-system/nav-user'
|
|
79
|
+
import { AppBreadcrumb } from '@vadimcomanescu/nadicode-design-system/app-breadcrumb'
|
|
80
|
+
import { AppSearch } from '@vadimcomanescu/nadicode-design-system/app-search'
|
|
81
|
+
import { WorkspaceSwitcher } from '@vadimcomanescu/nadicode-design-system/workspace-switcher'
|
|
82
|
+
import { ThemeToggle } from '@vadimcomanescu/nadicode-design-system/theme-toggle'
|
|
83
|
+
import { Button } from '@vadimcomanescu/nadicode-design-system/button'
|
|
84
|
+
import { BellIcon } from '@vadimcomanescu/nadicode-design-system/icons/bell'
|
|
85
|
+
import { DashboardIcon } from '@vadimcomanescu/nadicode-design-system/icons/dashboard'
|
|
86
|
+
import { ChartBarIcon } from '@vadimcomanescu/nadicode-design-system/icons/chart-bar'
|
|
87
|
+
import { BotIcon } from '@vadimcomanescu/nadicode-design-system/icons/bot'
|
|
88
|
+
import { UsersIcon } from '@vadimcomanescu/nadicode-design-system/icons/users'
|
|
89
|
+
import { SettingsIcon } from '@vadimcomanescu/nadicode-design-system/icons/settings'
|
|
90
|
+
|
|
91
|
+
const NAV_ITEMS = [
|
|
92
|
+
{
|
|
93
|
+
group: 'Main',
|
|
94
|
+
items: [
|
|
95
|
+
{ label: 'Dashboard', href: '/dashboard', icon: DashboardIcon },
|
|
96
|
+
{ label: 'Analytics', href: '/analytics', icon: ChartBarIcon },
|
|
97
|
+
{
|
|
98
|
+
label: 'Agents',
|
|
99
|
+
href: '/agents',
|
|
100
|
+
icon: BotIcon,
|
|
101
|
+
children: [
|
|
102
|
+
{ label: 'Active', href: '/agents/active' },
|
|
103
|
+
{ label: 'History', href: '/agents/history' },
|
|
104
|
+
],
|
|
105
|
+
},
|
|
106
|
+
],
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
group: 'Manage',
|
|
110
|
+
items: [
|
|
111
|
+
{ label: 'Team', href: '/team', icon: UsersIcon },
|
|
112
|
+
{ label: 'Settings', href: '/settings', icon: SettingsIcon },
|
|
113
|
+
],
|
|
114
|
+
},
|
|
115
|
+
]
|
|
116
|
+
|
|
117
|
+
export default function AppShellLayout({
|
|
118
|
+
children,
|
|
119
|
+
}: {
|
|
120
|
+
children: React.ReactNode
|
|
121
|
+
}) {
|
|
122
|
+
const pathname = usePathname()
|
|
123
|
+
|
|
124
|
+
return (
|
|
125
|
+
<SidebarProvider>
|
|
126
|
+
<Sidebar>
|
|
127
|
+
<SidebarHeader>
|
|
128
|
+
<WorkspaceSwitcher />
|
|
129
|
+
</SidebarHeader>
|
|
130
|
+
|
|
131
|
+
<SidebarContent>
|
|
132
|
+
{NAV_ITEMS.map((group) => (
|
|
133
|
+
<SidebarGroup key={group.group}>
|
|
134
|
+
<SidebarGroupLabel>{group.group}</SidebarGroupLabel>
|
|
135
|
+
<SidebarMenu>
|
|
136
|
+
{group.items.map((item) => (
|
|
137
|
+
<SidebarMenuItem key={item.href}>
|
|
138
|
+
<SidebarMenuButton
|
|
139
|
+
asChild
|
|
140
|
+
isActive={pathname === item.href || pathname.startsWith(item.href + '/')}
|
|
141
|
+
tooltip={item.label}
|
|
142
|
+
>
|
|
143
|
+
<a href={item.href}>
|
|
144
|
+
<item.icon size={16} />
|
|
145
|
+
{item.label}
|
|
146
|
+
</a>
|
|
147
|
+
</SidebarMenuButton>
|
|
148
|
+
|
|
149
|
+
{item.children && (
|
|
150
|
+
<SidebarMenuSub>
|
|
151
|
+
{item.children.map((child) => (
|
|
152
|
+
<SidebarMenuSubItem key={child.href}>
|
|
153
|
+
<SidebarMenuSubButton
|
|
154
|
+
asChild
|
|
155
|
+
isActive={pathname === child.href}
|
|
156
|
+
>
|
|
157
|
+
<a href={child.href}>{child.label}</a>
|
|
158
|
+
</SidebarMenuSubButton>
|
|
159
|
+
</SidebarMenuSubItem>
|
|
160
|
+
))}
|
|
161
|
+
</SidebarMenuSub>
|
|
162
|
+
)}
|
|
163
|
+
</SidebarMenuItem>
|
|
164
|
+
))}
|
|
165
|
+
</SidebarMenu>
|
|
166
|
+
</SidebarGroup>
|
|
167
|
+
))}
|
|
168
|
+
</SidebarContent>
|
|
169
|
+
|
|
170
|
+
<SidebarFooter>
|
|
171
|
+
<NavUser
|
|
172
|
+
user={{ name: 'Jane Smith', email: 'jane@acme.com', avatar: '/avatars/jane.jpg' }}
|
|
173
|
+
items={[
|
|
174
|
+
{ label: 'Profile', href: '/settings/profile' },
|
|
175
|
+
{ label: 'Billing', href: '/settings/billing' },
|
|
176
|
+
{ label: 'Sign out', onClick: handleSignOut },
|
|
177
|
+
]}
|
|
178
|
+
/>
|
|
179
|
+
</SidebarFooter>
|
|
180
|
+
</Sidebar>
|
|
181
|
+
|
|
182
|
+
<SidebarInset>
|
|
183
|
+
<header className="flex items-center gap-3 px-4 py-3 border-b border-border">
|
|
184
|
+
<SidebarTrigger />
|
|
185
|
+
<AppBreadcrumb />
|
|
186
|
+
<div className="ml-auto flex items-center gap-2">
|
|
187
|
+
<AppSearch />
|
|
188
|
+
<Button variant="ghost" size="icon" className="relative">
|
|
189
|
+
<BellIcon size={16} />
|
|
190
|
+
<span className="absolute -top-0.5 -right-0.5 size-2 rounded-full bg-destructive" />
|
|
191
|
+
</Button>
|
|
192
|
+
<ThemeToggle />
|
|
193
|
+
</div>
|
|
194
|
+
</header>
|
|
195
|
+
|
|
196
|
+
<div className="flex-1 p-4 lg:p-6">
|
|
197
|
+
{children}
|
|
198
|
+
</div>
|
|
199
|
+
</SidebarInset>
|
|
200
|
+
</SidebarProvider>
|
|
201
|
+
)
|
|
202
|
+
}
|
|
203
|
+
```
|
|
204
|
+
|
|
205
|
+
---
|
|
206
|
+
|
|
207
|
+
### 2. Breadcrumb Generation
|
|
208
|
+
|
|
209
|
+
The breadcrumb builds itself from the current pathname and a route config map. This is a reusable block, not inline logic.
|
|
210
|
+
|
|
211
|
+
**Consumer file: src/components/blocks/AppBreadcrumb.tsx**
|
|
212
|
+
|
|
213
|
+
```tsx
|
|
214
|
+
'use client'
|
|
215
|
+
|
|
216
|
+
import { usePathname } from 'next/navigation'
|
|
217
|
+
import {
|
|
218
|
+
Breadcrumb,
|
|
219
|
+
BreadcrumbList,
|
|
220
|
+
BreadcrumbItem,
|
|
221
|
+
BreadcrumbLink,
|
|
222
|
+
BreadcrumbPage,
|
|
223
|
+
BreadcrumbSeparator,
|
|
224
|
+
BreadcrumbEllipsis,
|
|
225
|
+
} from '@vadimcomanescu/nadicode-design-system/breadcrumb'
|
|
226
|
+
import { Fragment } from 'react'
|
|
227
|
+
|
|
228
|
+
// Map route segments to display labels.
|
|
229
|
+
// Dynamic segments use a placeholder; the caller can resolve them.
|
|
230
|
+
const ROUTE_LABELS: Record<string, string> = {
|
|
231
|
+
dashboard: 'Dashboard',
|
|
232
|
+
analytics: 'Analytics',
|
|
233
|
+
agents: 'Agents',
|
|
234
|
+
active: 'Active',
|
|
235
|
+
history: 'History',
|
|
236
|
+
team: 'Team',
|
|
237
|
+
settings: 'Settings',
|
|
238
|
+
profile: 'Profile',
|
|
239
|
+
billing: 'Billing',
|
|
240
|
+
security: 'Security',
|
|
241
|
+
}
|
|
242
|
+
|
|
243
|
+
// Max visible crumbs before collapsing middle segments.
|
|
244
|
+
const MAX_VISIBLE = 4
|
|
245
|
+
|
|
246
|
+
export function AppBreadcrumb() {
|
|
247
|
+
const pathname = usePathname()
|
|
248
|
+
const segments = pathname.split('/').filter(Boolean)
|
|
249
|
+
|
|
250
|
+
if (segments.length === 0) return null
|
|
251
|
+
|
|
252
|
+
// Build crumb list: [{label, href}]
|
|
253
|
+
const crumbs = segments.map((segment, i) => ({
|
|
254
|
+
label: ROUTE_LABELS[segment] ?? decodeURIComponent(segment),
|
|
255
|
+
href: '/' + segments.slice(0, i + 1).join('/'),
|
|
256
|
+
}))
|
|
257
|
+
|
|
258
|
+
// Collapse if too many crumbs
|
|
259
|
+
const shouldCollapse = crumbs.length > MAX_VISIBLE
|
|
260
|
+
const visible = shouldCollapse
|
|
261
|
+
? [crumbs[0], ...crumbs.slice(-2)]
|
|
262
|
+
: crumbs
|
|
263
|
+
|
|
264
|
+
return (
|
|
265
|
+
<Breadcrumb>
|
|
266
|
+
<BreadcrumbList>
|
|
267
|
+
{visible.map((crumb, i) => (
|
|
268
|
+
<Fragment key={crumb.href}>
|
|
269
|
+
{i > 0 && <BreadcrumbSeparator />}
|
|
270
|
+
{shouldCollapse && i === 1 && (
|
|
271
|
+
<>
|
|
272
|
+
<BreadcrumbItem>
|
|
273
|
+
<BreadcrumbEllipsis />
|
|
274
|
+
</BreadcrumbItem>
|
|
275
|
+
<BreadcrumbSeparator />
|
|
276
|
+
</>
|
|
277
|
+
)}
|
|
278
|
+
<BreadcrumbItem>
|
|
279
|
+
{i === visible.length - 1 ? (
|
|
280
|
+
<BreadcrumbPage>{crumb.label}</BreadcrumbPage>
|
|
281
|
+
) : (
|
|
282
|
+
<BreadcrumbLink href={crumb.href}>{crumb.label}</BreadcrumbLink>
|
|
283
|
+
)}
|
|
284
|
+
</BreadcrumbItem>
|
|
285
|
+
</Fragment>
|
|
286
|
+
))}
|
|
287
|
+
</BreadcrumbList>
|
|
288
|
+
</Breadcrumb>
|
|
289
|
+
)
|
|
290
|
+
}
|
|
291
|
+
```
|
|
292
|
+
|
|
293
|
+
**Dynamic segments** (e.g., `/agents/[id]`): extend `ROUTE_LABELS` with a resolver function, or pass a `resolveLabel` prop that fetches the entity name from a cache.
|
|
294
|
+
|
|
295
|
+
---
|
|
296
|
+
|
|
297
|
+
### 3. SearchCommand (Cmd+K) Wiring
|
|
298
|
+
|
|
299
|
+
The search palette needs three things: route items, action items, and a router integration. Wrap it in a Dialog triggered by Cmd+K.
|
|
300
|
+
|
|
301
|
+
**Consumer file: src/components/blocks/AppSearch.tsx**
|
|
302
|
+
|
|
303
|
+
```tsx
|
|
304
|
+
'use client'
|
|
305
|
+
|
|
306
|
+
import { useCallback, useMemo, useState } from 'react'
|
|
307
|
+
import { useRouter } from 'next/navigation'
|
|
308
|
+
import { Dialog, DialogContent } from '@vadimcomanescu/nadicode-design-system/dialog'
|
|
309
|
+
import { SearchCommand, SearchResult } from '@vadimcomanescu/nadicode-design-system/search-command'
|
|
310
|
+
import { Button } from '@vadimcomanescu/nadicode-design-system/button'
|
|
311
|
+
import { SearchIcon } from '@vadimcomanescu/nadicode-design-system/icons/search'
|
|
312
|
+
import { useHotkey } from '@/hooks/useHotkey'
|
|
313
|
+
|
|
314
|
+
// Route items: all navigable pages in the app.
|
|
315
|
+
const PAGE_ITEMS: SearchResult[] = [
|
|
316
|
+
{ id: 'dashboard', title: 'Dashboard', category: 'Pages', description: 'Overview and KPIs' },
|
|
317
|
+
{ id: 'analytics', title: 'Analytics', category: 'Pages', description: 'Charts and trends' },
|
|
318
|
+
{ id: 'agents', title: 'Agents', category: 'Pages', description: 'AI agent management' },
|
|
319
|
+
{ id: 'team', title: 'Team', category: 'Pages', description: 'Team members' },
|
|
320
|
+
{ id: 'settings', title: 'Settings', category: 'Pages', description: 'App configuration' },
|
|
321
|
+
]
|
|
322
|
+
|
|
323
|
+
// Action items: commands that do something (not navigation).
|
|
324
|
+
const ACTION_ITEMS: SearchResult[] = [
|
|
325
|
+
{ id: 'new-agent', title: 'Create Agent', category: 'Actions' },
|
|
326
|
+
{ id: 'invite-user', title: 'Invite Team Member', category: 'Actions' },
|
|
327
|
+
{ id: 'toggle-theme', title: 'Toggle Theme', category: 'Actions' },
|
|
328
|
+
]
|
|
329
|
+
|
|
330
|
+
// Combine all items into a single searchable list.
|
|
331
|
+
const ALL_ITEMS = [...PAGE_ITEMS, ...ACTION_ITEMS]
|
|
332
|
+
|
|
333
|
+
// Map item IDs to routes (pages) or callbacks (actions).
|
|
334
|
+
const ROUTE_MAP: Record<string, string> = {
|
|
335
|
+
dashboard: '/dashboard',
|
|
336
|
+
analytics: '/analytics',
|
|
337
|
+
agents: '/agents',
|
|
338
|
+
team: '/team',
|
|
339
|
+
settings: '/settings',
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
export function AppSearch() {
|
|
343
|
+
const [open, setOpen] = useState(false)
|
|
344
|
+
const [query, setQuery] = useState('')
|
|
345
|
+
const router = useRouter()
|
|
346
|
+
|
|
347
|
+
// Cmd+K to open
|
|
348
|
+
useHotkey('mod+k', (e) => {
|
|
349
|
+
e.preventDefault()
|
|
350
|
+
setOpen(true)
|
|
351
|
+
})
|
|
352
|
+
|
|
353
|
+
// Filter results by query
|
|
354
|
+
const results = useMemo(() => {
|
|
355
|
+
if (!query) return ALL_ITEMS
|
|
356
|
+
const q = query.toLowerCase()
|
|
357
|
+
return ALL_ITEMS.filter(
|
|
358
|
+
(item) =>
|
|
359
|
+
item.title.toLowerCase().includes(q) ||
|
|
360
|
+
item.description?.toLowerCase().includes(q),
|
|
361
|
+
)
|
|
362
|
+
}, [query])
|
|
363
|
+
|
|
364
|
+
const handleSelect = useCallback(
|
|
365
|
+
(result: SearchResult) => {
|
|
366
|
+
setOpen(false)
|
|
367
|
+
setQuery('')
|
|
368
|
+
|
|
369
|
+
const route = ROUTE_MAP[result.id]
|
|
370
|
+
if (route) {
|
|
371
|
+
router.push(route)
|
|
372
|
+
return
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
// Handle action items
|
|
376
|
+
switch (result.id) {
|
|
377
|
+
case 'toggle-theme':
|
|
378
|
+
document.documentElement.classList.toggle('dark')
|
|
379
|
+
break
|
|
380
|
+
case 'new-agent':
|
|
381
|
+
router.push('/agents/new')
|
|
382
|
+
break
|
|
383
|
+
case 'invite-user':
|
|
384
|
+
router.push('/team?invite=true')
|
|
385
|
+
break
|
|
386
|
+
}
|
|
387
|
+
},
|
|
388
|
+
[router],
|
|
389
|
+
)
|
|
390
|
+
|
|
391
|
+
return (
|
|
392
|
+
<>
|
|
393
|
+
<Button
|
|
394
|
+
variant="ghost"
|
|
395
|
+
size="sm"
|
|
396
|
+
className="gap-2 text-text-secondary"
|
|
397
|
+
onClick={() => setOpen(true)}
|
|
398
|
+
>
|
|
399
|
+
<SearchIcon size={16} />
|
|
400
|
+
<span className="hidden sm:inline">Search...</span>
|
|
401
|
+
<kbd className="hidden sm:inline text-xs bg-surface-raised px-1.5 py-0.5 rounded border border-border">
|
|
402
|
+
⌘K
|
|
403
|
+
</kbd>
|
|
404
|
+
</Button>
|
|
405
|
+
|
|
406
|
+
<Dialog open={open} onOpenChange={setOpen}>
|
|
407
|
+
<DialogContent className="p-0 max-w-lg">
|
|
408
|
+
<SearchCommand
|
|
409
|
+
value={query}
|
|
410
|
+
onChange={setQuery}
|
|
411
|
+
results={results}
|
|
412
|
+
onSelect={handleSelect}
|
|
413
|
+
placeholder="Search pages and actions..."
|
|
414
|
+
/>
|
|
415
|
+
</DialogContent>
|
|
416
|
+
</Dialog>
|
|
417
|
+
</>
|
|
418
|
+
)
|
|
419
|
+
}
|
|
420
|
+
```
|
|
421
|
+
|
|
422
|
+
**Extending with recent items**: store last 5 selected IDs in `localStorage`, prepend them as a "Recent" category on mount.
|
|
423
|
+
|
|
424
|
+
---
|
|
425
|
+
|
|
426
|
+
### 4. NavUser Wiring
|
|
427
|
+
|
|
428
|
+
NavUser sits in the sidebar footer. It needs auth data and menu items.
|
|
429
|
+
|
|
430
|
+
```tsx
|
|
431
|
+
// In the layout, wire NavUser to your auth context:
|
|
432
|
+
|
|
433
|
+
import { useAuth } from '@/hooks/useAuth' // your auth hook
|
|
434
|
+
|
|
435
|
+
function AppShellSidebarFooter() {
|
|
436
|
+
const { user, signOut } = useAuth()
|
|
437
|
+
|
|
438
|
+
if (!user) return null
|
|
439
|
+
|
|
440
|
+
return (
|
|
441
|
+
<SidebarFooter>
|
|
442
|
+
<NavUser
|
|
443
|
+
user={{
|
|
444
|
+
name: user.name,
|
|
445
|
+
email: user.email,
|
|
446
|
+
avatar: user.avatarUrl,
|
|
447
|
+
}}
|
|
448
|
+
items={[
|
|
449
|
+
{ label: 'Profile', href: '/settings/profile' },
|
|
450
|
+
{ label: 'Billing', href: '/settings/billing' },
|
|
451
|
+
]}
|
|
452
|
+
footer={
|
|
453
|
+
<button
|
|
454
|
+
onClick={signOut}
|
|
455
|
+
className="w-full text-left px-2 py-1.5 text-sm text-text-secondary hover:text-text-primary"
|
|
456
|
+
>
|
|
457
|
+
Sign out
|
|
458
|
+
</button>
|
|
459
|
+
}
|
|
460
|
+
/>
|
|
461
|
+
</SidebarFooter>
|
|
462
|
+
)
|
|
463
|
+
}
|
|
464
|
+
```
|
|
465
|
+
|
|
466
|
+
NavUser renders a `DropdownMenu` with the user's avatar and name as trigger. On mobile, the dropdown opens upward (`side="top"`). On desktop, it opens right (`side="right"`).
|
|
467
|
+
|
|
468
|
+
---
|
|
469
|
+
|
|
470
|
+
### 5. Mobile Sidebar (Sheet Overlay)
|
|
471
|
+
|
|
472
|
+
The Sidebar component handles mobile automatically. No extra code needed, but you need to understand the behavior:
|
|
473
|
+
|
|
474
|
+
```
|
|
475
|
+
MOBILE BEHAVIOR
|
|
476
|
+
===============
|
|
477
|
+
|
|
478
|
+
Trigger: SidebarTrigger (hamburger icon in top bar)
|
|
479
|
+
Container: Sheet overlay (slides from left, 80% viewport width)
|
|
480
|
+
Backdrop: Semi-transparent overlay, tap to close
|
|
481
|
+
Close: Tap backdrop, tap X button, or navigate to a new route
|
|
482
|
+
Focus trap: Yes (keyboard focus stays inside sheet)
|
|
483
|
+
Scroll: SidebarContent scrolls independently
|
|
484
|
+
Width: var(--sidebar-width), max 320px
|
|
485
|
+
|
|
486
|
+
DESKTOP BEHAVIOR
|
|
487
|
+
================
|
|
488
|
+
|
|
489
|
+
< lg: Sidebar hidden (mobile mode, Sheet overlay)
|
|
490
|
+
lg: Sidebar visible, collapsible to icon-only (var(--sidebar-width-icon) = 3rem)
|
|
491
|
+
xl: Sidebar expanded by default (var(--sidebar-width) = 16rem)
|
|
492
|
+
Collapse: SidebarTrigger or Cmd+B toggles between expanded and icon-only
|
|
493
|
+
Rail: SidebarRail provides invisible drag handle on sidebar edge
|
|
494
|
+
Cookie: Expanded/collapsed state persists via cookie
|
|
495
|
+
```
|
|
496
|
+
|
|
497
|
+
To close the mobile sidebar on navigation:
|
|
498
|
+
|
|
499
|
+
```tsx
|
|
500
|
+
// In nav item click handlers or via useEffect:
|
|
501
|
+
const { setOpenMobile } = useSidebar()
|
|
502
|
+
|
|
503
|
+
// Close mobile sidebar after navigating
|
|
504
|
+
function handleNavClick(href: string) {
|
|
505
|
+
setOpenMobile(false)
|
|
506
|
+
router.push(href)
|
|
507
|
+
}
|
|
508
|
+
```
|
|
509
|
+
|
|
510
|
+
---
|
|
511
|
+
|
|
512
|
+
### 6. Top Bar Composition
|
|
513
|
+
|
|
514
|
+
The top bar is a `<header>` inside `SidebarInset`. It contains four zones:
|
|
515
|
+
|
|
516
|
+
```
|
|
517
|
+
+---+------------------+-----------------------------------+
|
|
518
|
+
| = | Breadcrumb | [Search] [Notifications] [Theme] |
|
|
519
|
+
+---+------------------+-----------------------------------+
|
|
520
|
+
^ ^ ^ ^ ^
|
|
521
|
+
| | | | |
|
|
522
|
+
Trigger AppBreadcrumb AppSearch NotifButton ThemeToggle
|
|
523
|
+
```
|
|
524
|
+
|
|
525
|
+
**Notification button pattern** (badge + dropdown):
|
|
526
|
+
|
|
527
|
+
```tsx
|
|
528
|
+
import { DropdownMenu, DropdownMenuTrigger, DropdownMenuContent, DropdownMenuItem } from '@vadimcomanescu/nadicode-design-system/dropdown-menu'
|
|
529
|
+
import { BellIcon } from '@vadimcomanescu/nadicode-design-system/icons/bell'
|
|
530
|
+
import { Button } from '@vadimcomanescu/nadicode-design-system/button'
|
|
531
|
+
import { Badge } from '@vadimcomanescu/nadicode-design-system/badge'
|
|
532
|
+
import { ScrollArea } from '@vadimcomanescu/nadicode-design-system/scroll-area'
|
|
533
|
+
|
|
534
|
+
function NotificationButton({ notifications }: { notifications: Notification[] }) {
|
|
535
|
+
const unreadCount = notifications.filter((n) => !n.read).length
|
|
536
|
+
|
|
537
|
+
return (
|
|
538
|
+
<DropdownMenu>
|
|
539
|
+
<DropdownMenuTrigger asChild>
|
|
540
|
+
<Button variant="ghost" size="icon" className="relative">
|
|
541
|
+
<BellIcon size={16} />
|
|
542
|
+
{unreadCount > 0 && (
|
|
543
|
+
<span className="absolute -top-0.5 -right-0.5 size-4 rounded-full bg-destructive text-destructive-foreground text-[10px] flex items-center justify-center">
|
|
544
|
+
{unreadCount}
|
|
545
|
+
</span>
|
|
546
|
+
)}
|
|
547
|
+
</Button>
|
|
548
|
+
</DropdownMenuTrigger>
|
|
549
|
+
<DropdownMenuContent align="end" className="w-80">
|
|
550
|
+
<div className="px-3 py-2 border-b border-border">
|
|
551
|
+
<span className="text-sm font-medium">Notifications</span>
|
|
552
|
+
</div>
|
|
553
|
+
<ScrollArea className="max-h-64">
|
|
554
|
+
{notifications.length === 0 ? (
|
|
555
|
+
<div className="px-3 py-6 text-center text-sm text-text-secondary">
|
|
556
|
+
No notifications
|
|
557
|
+
</div>
|
|
558
|
+
) : (
|
|
559
|
+
notifications.map((n) => (
|
|
560
|
+
<DropdownMenuItem key={n.id} className="flex flex-col items-start gap-1 py-2">
|
|
561
|
+
<span className="text-sm">{n.title}</span>
|
|
562
|
+
<span className="text-xs text-text-secondary">{n.timeAgo}</span>
|
|
563
|
+
</DropdownMenuItem>
|
|
564
|
+
))
|
|
565
|
+
)}
|
|
566
|
+
</ScrollArea>
|
|
567
|
+
</DropdownMenuContent>
|
|
568
|
+
</DropdownMenu>
|
|
569
|
+
)
|
|
570
|
+
}
|
|
571
|
+
```
|
|
572
|
+
|
|
573
|
+
---
|
|
574
|
+
|
|
575
|
+
### 7. Workspace Switcher
|
|
576
|
+
|
|
577
|
+
Logo area in sidebar header doubles as a workspace/org switcher.
|
|
578
|
+
|
|
579
|
+
**Consumer file: src/components/blocks/WorkspaceSwitcher.tsx**
|
|
580
|
+
|
|
581
|
+
```tsx
|
|
582
|
+
'use client'
|
|
583
|
+
|
|
584
|
+
import {
|
|
585
|
+
DropdownMenu,
|
|
586
|
+
DropdownMenuTrigger,
|
|
587
|
+
DropdownMenuContent,
|
|
588
|
+
DropdownMenuItem,
|
|
589
|
+
DropdownMenuSeparator,
|
|
590
|
+
} from '@vadimcomanescu/nadicode-design-system/dropdown-menu'
|
|
591
|
+
import { SidebarMenuButton } from '@vadimcomanescu/nadicode-design-system/sidebar'
|
|
592
|
+
import { ChevronsUpDownIcon } from '@vadimcomanescu/nadicode-design-system/icons/chevrons-up-down'
|
|
593
|
+
import { PlusIcon } from '@vadimcomanescu/nadicode-design-system/icons/plus'
|
|
594
|
+
import { Avatar, AvatarFallback, AvatarImage } from '@vadimcomanescu/nadicode-design-system/avatar'
|
|
595
|
+
|
|
596
|
+
interface Workspace {
|
|
597
|
+
id: string
|
|
598
|
+
name: string
|
|
599
|
+
logo?: string
|
|
600
|
+
plan: string
|
|
601
|
+
}
|
|
602
|
+
|
|
603
|
+
export function WorkspaceSwitcher({
|
|
604
|
+
workspaces,
|
|
605
|
+
activeId,
|
|
606
|
+
onSwitch,
|
|
607
|
+
}: {
|
|
608
|
+
workspaces: Workspace[]
|
|
609
|
+
activeId: string
|
|
610
|
+
onSwitch: (id: string) => void
|
|
611
|
+
}) {
|
|
612
|
+
const active = workspaces.find((w) => w.id === activeId)
|
|
613
|
+
|
|
614
|
+
return (
|
|
615
|
+
<DropdownMenu>
|
|
616
|
+
<DropdownMenuTrigger asChild>
|
|
617
|
+
<SidebarMenuButton size="lg" className="gap-2">
|
|
618
|
+
<Avatar className="size-6 rounded-md">
|
|
619
|
+
<AvatarImage src={active?.logo} />
|
|
620
|
+
<AvatarFallback className="rounded-md text-xs">
|
|
621
|
+
{active?.name.slice(0, 2).toUpperCase()}
|
|
622
|
+
</AvatarFallback>
|
|
623
|
+
</Avatar>
|
|
624
|
+
<div className="flex-1 text-left">
|
|
625
|
+
<span className="text-sm font-medium truncate">{active?.name}</span>
|
|
626
|
+
<span className="text-xs text-text-secondary block">{active?.plan}</span>
|
|
627
|
+
</div>
|
|
628
|
+
<ChevronsUpDownIcon size={14} className="text-text-secondary" />
|
|
629
|
+
</SidebarMenuButton>
|
|
630
|
+
</DropdownMenuTrigger>
|
|
631
|
+
<DropdownMenuContent align="start" className="w-56">
|
|
632
|
+
{workspaces.map((ws) => (
|
|
633
|
+
<DropdownMenuItem
|
|
634
|
+
key={ws.id}
|
|
635
|
+
onClick={() => onSwitch(ws.id)}
|
|
636
|
+
className={ws.id === activeId ? 'bg-sidebar-accent' : ''}
|
|
637
|
+
>
|
|
638
|
+
<Avatar className="size-5 rounded-md mr-2">
|
|
639
|
+
<AvatarImage src={ws.logo} />
|
|
640
|
+
<AvatarFallback className="rounded-md text-[10px]">
|
|
641
|
+
{ws.name.slice(0, 2).toUpperCase()}
|
|
642
|
+
</AvatarFallback>
|
|
643
|
+
</Avatar>
|
|
644
|
+
{ws.name}
|
|
645
|
+
</DropdownMenuItem>
|
|
646
|
+
))}
|
|
647
|
+
<DropdownMenuSeparator />
|
|
648
|
+
<DropdownMenuItem>
|
|
649
|
+
<PlusIcon size={14} className="mr-2" />
|
|
650
|
+
Create workspace
|
|
651
|
+
</DropdownMenuItem>
|
|
652
|
+
</DropdownMenuContent>
|
|
653
|
+
</DropdownMenu>
|
|
654
|
+
)
|
|
655
|
+
}
|
|
656
|
+
```
|
|
657
|
+
|
|
658
|
+
---
|
|
659
|
+
|
|
660
|
+
## Navigation Rules
|
|
661
|
+
|
|
662
|
+
1. **Max 3 levels**: Group > Item > Sub-item. No deeper nesting.
|
|
663
|
+
2. **Group labels required**: Every `SidebarGroup` must have `SidebarGroupLabel` (ESLint enforced).
|
|
664
|
+
3. **Active state**: Use `isActive` prop on `SidebarMenuButton`. Match with `pathname === href || pathname.startsWith(href + '/')`.
|
|
665
|
+
4. **Icons required**: Every top-level nav item has an icon from `@vadimcomanescu/nadicode-design-system/icons/`.
|
|
666
|
+
5. **Max 7 top-level items**: Keep primary nav focused. Use groups to organize.
|
|
667
|
+
6. **Labels from config**: Nav labels come from the `NAV_ITEMS` config array, not hardcoded in JSX.
|
|
668
|
+
7. **Close on navigate (mobile)**: Call `setOpenMobile(false)` before `router.push()`.
|
|
669
|
+
8. **Breadcrumb on every page**: Every app-shell page must show breadcrumb context in the top bar.
|
|
670
|
+
|
|
671
|
+
---
|
|
672
|
+
|
|
673
|
+
## Animation Storyboard
|
|
674
|
+
|
|
675
|
+
```
|
|
676
|
+
ANIMATION STORYBOARD
|
|
677
|
+
====================
|
|
678
|
+
BUDGET: 200ms | SPRING: snappy | REDUCED: none (shell is instant)
|
|
679
|
+
|
|
680
|
+
T+0ms [sidebar] Sidebar visible (instant)
|
|
681
|
+
T+0ms [topbar] Top bar visible (instant)
|
|
682
|
+
T+0ms [content] Page content area visible (instant)
|
|
683
|
+
|
|
684
|
+
SIDEBAR COLLAPSE/EXPAND:
|
|
685
|
+
T+0ms [sidebar] Width transitions {CSS ease-in-out-cubic, 200ms}
|
|
686
|
+
T+0ms [labels] Text fades out (collapse) {opacity, 100ms}
|
|
687
|
+
T+100ms [icons] Icons center-align {CSS ease-out, 100ms}
|
|
688
|
+
|
|
689
|
+
MOBILE SIDEBAR OPEN:
|
|
690
|
+
T+0ms [backdrop] Backdrop fades in {opacity 0->1, 150ms}
|
|
691
|
+
T+0ms [sheet] Sidebar slides from left {translateX(-100% -> 0), snappy spring}
|
|
692
|
+
|
|
693
|
+
CMD+K OPEN:
|
|
694
|
+
T+0ms [overlay] Backdrop fades in {fadeIn, 150ms}
|
|
695
|
+
T+0ms [dialog] Command palette scales in {scaleIn 0.95->1, snappy}
|
|
696
|
+
|
|
697
|
+
REDUCED MOTION: All transitions instant
|
|
698
|
+
```
|
|
699
|
+
|
|
700
|
+
---
|
|
701
|
+
|
|
702
|
+
## Required Components
|
|
703
|
+
|
|
704
|
+
| Component | Import Path | Purpose |
|
|
705
|
+
|-----------|-------------|---------|
|
|
706
|
+
| `Sidebar` (full system) | `@vadimcomanescu/nadicode-design-system/sidebar` | App sidebar with all subcomponents |
|
|
707
|
+
| `NavUser` | `@vadimcomanescu/nadicode-design-system/nav-user` | User menu in sidebar footer |
|
|
708
|
+
| `AppBreadcrumb` | Consumer block (see Section 2) | Route-aware breadcrumb |
|
|
709
|
+
| `AppSearch` | Consumer block (see Section 3) | Cmd+K search palette |
|
|
710
|
+
| `WorkspaceSwitcher` | Consumer block (see Section 7) | Org/workspace picker |
|
|
711
|
+
| `SearchCommand` | `@vadimcomanescu/nadicode-design-system/search-command` | Search UI primitive |
|
|
712
|
+
| `Breadcrumb` (full system) | `@vadimcomanescu/nadicode-design-system/breadcrumb` | Breadcrumb primitives |
|
|
713
|
+
| `Dialog` | `@vadimcomanescu/nadicode-design-system/dialog` | Cmd+K dialog wrapper |
|
|
714
|
+
| `DropdownMenu` | `@vadimcomanescu/nadicode-design-system/dropdown-menu` | Notifications, workspace switcher |
|
|
715
|
+
| `ThemeToggle` | `@vadimcomanescu/nadicode-design-system/theme-toggle` | Light/dark switch |
|
|
716
|
+
| `Button` | `@vadimcomanescu/nadicode-design-system/button` | Top bar actions |
|
|
717
|
+
| `ScrollArea` | `@vadimcomanescu/nadicode-design-system/scroll-area` | Notification dropdown scroll |
|
|
718
|
+
| `Avatar` | `@vadimcomanescu/nadicode-design-system/avatar` | User and workspace avatars |
|
|
719
|
+
|
|
720
|
+
### Allowed (optional)
|
|
721
|
+
|
|
722
|
+
`NotificationCenter`, `Badge` (notification count), `StyleToggle`, `Tooltip`, `ContextMenu`, `Menubar`
|
|
723
|
+
|
|
724
|
+
### Forbidden
|
|
725
|
+
|
|
726
|
+
Marketing blocks (`HeroBlock`, `FooterBlock`), chart components, form components, agentic components in the shell itself
|
|
727
|
+
|
|
728
|
+
---
|
|
729
|
+
|
|
730
|
+
## Responsive Contract
|
|
731
|
+
|
|
732
|
+
| Breakpoint | Sidebar | Top Bar | Breadcrumb |
|
|
733
|
+
|------------|---------|---------|------------|
|
|
734
|
+
| Mobile | Hidden, Sheet overlay via SidebarTrigger | Always visible, hamburger left | Hidden (not enough space) |
|
|
735
|
+
| `sm:` | Same as mobile | Same | Visible, max 2 crumbs |
|
|
736
|
+
| `lg:` | Collapsible (icon-only or full, Cmd+B) | Visible with all actions | Full breadcrumb trail |
|
|
737
|
+
| `xl:` | Full sidebar (expanded by default) | Same | Same |
|
|
738
|
+
|
|
739
|
+
---
|
|
740
|
+
|
|
741
|
+
## Styling Rules
|
|
742
|
+
|
|
743
|
+
- Sidebar: `bg-sidebar` token (not `bg-background`)
|
|
744
|
+
- Sidebar border: `border-sidebar-border`
|
|
745
|
+
- Active item: `bg-sidebar-accent text-sidebar-accent-foreground`
|
|
746
|
+
- Top bar: `border-b border-border`, same `bg-background` as content
|
|
747
|
+
- Content area: `bg-background`
|
|
748
|
+
- No raw palette colors
|
|
749
|
+
- Sidebar width: `var(--sidebar-width)` (16rem) and `var(--sidebar-width-icon)` (3rem)
|
|
750
|
+
- Workspace switcher: `SidebarMenuButton size="lg"` for consistent sizing
|
|
751
|
+
|
|
752
|
+
---
|
|
753
|
+
|
|
754
|
+
## Accessibility
|
|
755
|
+
|
|
756
|
+
- Sidebar: `<nav aria-label="Main navigation">`
|
|
757
|
+
- Groups: `role="group"` with `aria-labelledby` pointing to group label
|
|
758
|
+
- Active item: `aria-current="page"` (handled by `isActive` prop)
|
|
759
|
+
- SidebarTrigger: `aria-label="Toggle sidebar"`, `aria-expanded`
|
|
760
|
+
- Cmd+K: keyboard-triggered (Cmd/Ctrl+K), focus trapped in dialog
|
|
761
|
+
- Skip-nav link: `<SkipNav />` before sidebar targets `#main-content`
|
|
762
|
+
- Mobile sheet: focus trap, Escape to close, backdrop click to close
|
|
763
|
+
- Notification button: `aria-label="Notifications"`, badge announces count
|
|
764
|
+
- Breadcrumb: `<nav aria-label="breadcrumb">` with `aria-current="page"` on last item
|
|
765
|
+
|
|
766
|
+
---
|
|
767
|
+
|
|
768
|
+
## Reference Implementations
|
|
769
|
+
|
|
770
|
+
- `src/app/(showcase)/layout.tsx` (showcase shell, uses AnimatedTabs instead of Sidebar)
|
|
771
|
+
- `src/components/ui/Sidebar.tsx` (sidebar system)
|
|
772
|
+
- `src/components/blocks/NavUser.tsx` (user menu)
|
|
773
|
+
- `src/components/ui/SearchCommand.tsx` (search primitive)
|
|
774
|
+
- `src/components/ui/Breadcrumb.tsx` (breadcrumb primitives)
|
|
775
|
+
- `src/components/ui/Command.tsx` (cmdk wrapper)
|
|
776
|
+
|
|
777
|
+
---
|
|
778
|
+
|
|
779
|
+
## Verification
|
|
780
|
+
|
|
781
|
+
```bash
|
|
782
|
+
npx tsc --noEmit
|
|
783
|
+
npm run lint
|
|
784
|
+
npm run test
|
|
785
|
+
npx vitest run src/test/opinion-navigation.test.ts
|
|
786
|
+
```
|