@libreapps/ui 5.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +229 -0
- package/bin/cli.js +100 -0
- package/bin/create-registry.js +108 -0
- package/bin/mcp.js +403 -0
- package/bin/npx-registry-mcp.js +15 -0
- package/bin/registry-mcp-wrapper.sh +19 -0
- package/bin/registry-mcp.js +100 -0
- package/bin/start-mcp-server.sh +22 -0
- package/bin/test-mcp.sh +52 -0
- package/bin/update-registry.js +196 -0
- package/content/index.ts +26 -0
- package/dist/3d/button.js +298 -0
- package/dist/3d/button.mjs +273 -0
- package/dist/3d/card.js +234 -0
- package/dist/3d/card.mjs +207 -0
- package/dist/3d/carousel.js +371 -0
- package/dist/3d/carousel.mjs +344 -0
- package/dist/3d/grid.js +362 -0
- package/dist/3d/grid.mjs +337 -0
- package/dist/3d/index.js +1518 -0
- package/dist/3d/index.mjs +1472 -0
- package/dist/3d/marquee.js +352 -0
- package/dist/3d/marquee.mjs +327 -0
- package/dist/3d/pin.js +46 -0
- package/dist/3d/pin.mjs +24 -0
- package/dist/accordion.js +80 -0
- package/dist/accordion.mjs +55 -0
- package/dist/alert-dialog.js +225 -0
- package/dist/alert-dialog.mjs +192 -0
- package/dist/alert.js +98 -0
- package/dist/alert.mjs +92 -0
- package/dist/animation/animated-background.js +424 -0
- package/dist/animation/animated-background.mjs +418 -0
- package/dist/animation/animated-beam.js +119 -0
- package/dist/animation/animated-beam.mjs +97 -0
- package/dist/animation/animated-cursor.js +275 -0
- package/dist/animation/animated-cursor.mjs +270 -0
- package/dist/animation/animated-icon.js +357 -0
- package/dist/animation/animated-icon.mjs +351 -0
- package/dist/animation/animated-list.js +339 -0
- package/dist/animation/animated-list.mjs +333 -0
- package/dist/animation/animated-number.js +283 -0
- package/dist/animation/animated-number.mjs +277 -0
- package/dist/animation/animated-testimonials.js +97 -0
- package/dist/animation/animated-testimonials.mjs +75 -0
- package/dist/animation/animated-tooltip.js +67 -0
- package/dist/animation/animated-tooltip.mjs +45 -0
- package/dist/animation/apple-cards-carousel.js +308 -0
- package/dist/animation/apple-cards-carousel.mjs +285 -0
- package/dist/animation/apple-hello-effect.js +60 -0
- package/dist/animation/apple-hello-effect.mjs +38 -0
- package/dist/animation/index.js +1952 -0
- package/dist/animation/index.mjs +1921 -0
- package/dist/assets/ai-icons.d.ts +27 -0
- package/dist/assets/crypto.d.ts +6 -0
- package/dist/assets/file-type-icon.d.ts +6 -0
- package/dist/assets/file.d.ts +4 -0
- package/dist/assets/general.d.ts +219 -0
- package/dist/assets/index.d.ts +6 -0
- package/dist/assets/libreapps-logo.d.ts +3 -0
- package/dist/assets/llm-provider.d.ts +63 -0
- package/dist/avatar.js +71 -0
- package/dist/avatar.mjs +47 -0
- package/dist/badge.js +61 -0
- package/dist/badge.mjs +55 -0
- package/dist/blocks/auth/__tests__/forms.test.d.ts +12 -0
- package/dist/blocks/auth/index.d.ts +3 -0
- package/dist/blocks/auth/login/index.d.ts +5 -0
- package/dist/blocks/auth/login/login-01/components/login-form.d.ts +1 -0
- package/dist/blocks/auth/login/login-01/page.d.ts +1 -0
- package/dist/blocks/auth/login/login-02/components/login-form.d.ts +1 -0
- package/dist/blocks/auth/login/login-02/page.d.ts +1 -0
- package/dist/blocks/auth/login/login-03/components/login-form.d.ts +1 -0
- package/dist/blocks/auth/login/login-03/page.d.ts +1 -0
- package/dist/blocks/auth/login/login-04/components/login-form.d.ts +1 -0
- package/dist/blocks/auth/login/login-04/page.d.ts +1 -0
- package/dist/blocks/auth/login/login-05/components/login-form.d.ts +1 -0
- package/dist/blocks/auth/login/login-05/page.d.ts +1 -0
- package/dist/blocks/auth/otp/index.d.ts +5 -0
- package/dist/blocks/auth/otp/otp-01/components/otp-form.d.ts +2 -0
- package/dist/blocks/auth/otp/otp-01/page.d.ts +1 -0
- package/dist/blocks/auth/otp/otp-02/components/otp-form.d.ts +1 -0
- package/dist/blocks/auth/otp/otp-02/page.d.ts +1 -0
- package/dist/blocks/auth/otp/otp-03/components/otp-form.d.ts +2 -0
- package/dist/blocks/auth/otp/otp-03/page.d.ts +1 -0
- package/dist/blocks/auth/otp/otp-04/components/otp-form.d.ts +1 -0
- package/dist/blocks/auth/otp/otp-04/page.d.ts +1 -0
- package/dist/blocks/auth/otp/otp-05/components/otp-form.d.ts +1 -0
- package/dist/blocks/auth/otp/otp-05/page.d.ts +1 -0
- package/dist/blocks/auth/signup/index.d.ts +5 -0
- package/dist/blocks/auth/signup/signup-01/components/signup-form.d.ts +2 -0
- package/dist/blocks/auth/signup/signup-01/page.d.ts +1 -0
- package/dist/blocks/auth/signup/signup-02/components/signup-form.d.ts +1 -0
- package/dist/blocks/auth/signup/signup-02/page.d.ts +1 -0
- package/dist/blocks/auth/signup/signup-03/components/signup-form.d.ts +1 -0
- package/dist/blocks/auth/signup/signup-03/page.d.ts +1 -0
- package/dist/blocks/auth/signup/signup-04/components/signup-form.d.ts +1 -0
- package/dist/blocks/auth/signup/signup-04/page.d.ts +1 -0
- package/dist/blocks/auth/signup/signup-05/components/signup-form.d.ts +1 -0
- package/dist/blocks/auth/signup/signup-05/page.d.ts +1 -0
- package/dist/blocks/calendar/calendar-01.d.ts +1 -0
- package/dist/blocks/calendar/calendar-02.d.ts +1 -0
- package/dist/blocks/calendar/calendar-03.d.ts +1 -0
- package/dist/blocks/calendar/calendar-04.d.ts +1 -0
- package/dist/blocks/calendar/calendar-05.d.ts +1 -0
- package/dist/blocks/calendar/calendar-06.d.ts +1 -0
- package/dist/blocks/calendar/calendar-07.d.ts +1 -0
- package/dist/blocks/calendar/calendar-08.d.ts +1 -0
- package/dist/blocks/calendar/calendar-09.d.ts +1 -0
- package/dist/blocks/calendar/calendar-10.d.ts +1 -0
- package/dist/blocks/calendar/calendar-11.d.ts +1 -0
- package/dist/blocks/calendar/calendar-12.d.ts +1 -0
- package/dist/blocks/calendar/calendar-13.d.ts +1 -0
- package/dist/blocks/calendar/calendar-14.d.ts +1 -0
- package/dist/blocks/calendar/calendar-15.d.ts +1 -0
- package/dist/blocks/calendar/calendar-16.d.ts +1 -0
- package/dist/blocks/calendar/calendar-17.d.ts +1 -0
- package/dist/blocks/calendar/calendar-18.d.ts +1 -0
- package/dist/blocks/calendar/calendar-19.d.ts +1 -0
- package/dist/blocks/calendar/calendar-20.d.ts +1 -0
- package/dist/blocks/calendar/calendar-21.d.ts +1 -0
- package/dist/blocks/calendar/calendar-22.d.ts +1 -0
- package/dist/blocks/calendar/calendar-23.d.ts +1 -0
- package/dist/blocks/calendar/calendar-24.d.ts +1 -0
- package/dist/blocks/calendar/calendar-25.d.ts +1 -0
- package/dist/blocks/calendar/calendar-26.d.ts +1 -0
- package/dist/blocks/calendar/calendar-27.d.ts +1 -0
- package/dist/blocks/calendar/calendar-28.d.ts +1 -0
- package/dist/blocks/calendar/calendar-29.d.ts +1 -0
- package/dist/blocks/calendar/calendar-30.d.ts +1 -0
- package/dist/blocks/calendar/calendar-31.d.ts +1 -0
- package/dist/blocks/calendar/calendar-32.d.ts +1 -0
- package/dist/blocks/calendar/index.d.ts +32 -0
- package/dist/blocks/components/accordian-block.d.ts +4 -0
- package/dist/blocks/components/block-component-props.d.ts +7 -0
- package/dist/blocks/components/bullet-cards-block.d.ts +4 -0
- package/dist/blocks/components/card-block/index.d.ts +6 -0
- package/dist/blocks/components/card-block/link-out-button.d.ts +6 -0
- package/dist/blocks/components/card-block/util.d.ts +4 -0
- package/dist/blocks/components/carte-blanche-block/index.d.ts +4 -0
- package/dist/blocks/components/carte-blanche-block/variant-content-left.d.ts +10 -0
- package/dist/blocks/components/content.d.ts +10 -0
- package/dist/blocks/components/cta-block.d.ts +12 -0
- package/dist/blocks/components/enh-heading-block.d.ts +7 -0
- package/dist/blocks/components/grid-block/grid-block-mutator.d.ts +5 -0
- package/dist/blocks/components/grid-block/index.d.ts +9 -0
- package/dist/blocks/components/grid-block/mutator-registry.d.ts +3 -0
- package/dist/blocks/components/grid-block/table-borders.mutator.d.ts +3 -0
- package/dist/blocks/components/group-block.d.ts +7 -0
- package/dist/blocks/components/heading-block.d.ts +4 -0
- package/dist/blocks/components/image-block.d.ts +7 -0
- package/dist/blocks/components/index.d.ts +14 -0
- package/dist/blocks/components/screenful-block/content.d.ts +8 -0
- package/dist/blocks/components/screenful-block/index.d.ts +12 -0
- package/dist/blocks/components/screenful-block/poster-background.d.ts +7 -0
- package/dist/blocks/components/screenful-block/video-background.d.ts +8 -0
- package/dist/blocks/components/space-block.d.ts +4 -0
- package/dist/blocks/components/video-block.d.ts +9 -0
- package/dist/blocks/dashboard/dashboard-01/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/dashboard/dashboard-01/components/chart-area-interactive.d.ts +2 -0
- package/dist/blocks/dashboard/dashboard-01/components/data-table.d.ts +13 -0
- package/dist/blocks/dashboard/dashboard-01/components/nav-documents.d.ts +8 -0
- package/dist/blocks/dashboard/dashboard-01/components/nav-main.d.ts +8 -0
- package/dist/blocks/dashboard/dashboard-01/components/nav-secondary.d.ts +10 -0
- package/dist/blocks/dashboard/dashboard-01/components/nav-user.d.ts +7 -0
- package/dist/blocks/dashboard/dashboard-01/components/section-cards.d.ts +1 -0
- package/dist/blocks/dashboard/dashboard-01/components/site-header.d.ts +1 -0
- package/dist/blocks/dashboard/dashboard-01/page.d.ts +1 -0
- package/dist/blocks/dashboard/index.d.ts +1 -0
- package/dist/blocks/def/accordian-block.d.ts +10 -0
- package/dist/blocks/def/block.d.ts +4 -0
- package/dist/blocks/def/bullet-cards-block.d.ts +17 -0
- package/dist/blocks/def/card-block.d.ts +17 -0
- package/dist/blocks/def/carte-blanche-block.d.ts +12 -0
- package/dist/blocks/def/cta-block.d.ts +8 -0
- package/dist/blocks/def/element-block.d.ts +7 -0
- package/dist/blocks/def/enh-heading-block.d.ts +22 -0
- package/dist/blocks/def/grid-block.d.ts +12 -0
- package/dist/blocks/def/group-block.d.ts +7 -0
- package/dist/blocks/def/heading-block.d.ts +11 -0
- package/dist/blocks/def/image-block.d.ts +26 -0
- package/dist/blocks/def/index.d.ts +17 -0
- package/dist/blocks/def/screenful-block.d.ts +41 -0
- package/dist/blocks/def/space-block.d.ts +47 -0
- package/dist/blocks/def/video-block.d.ts +5 -0
- package/dist/blocks/index-core.d.ts +2 -0
- package/dist/blocks/index.d.ts +6 -0
- package/dist/blocks/index.js +1685 -0
- package/dist/blocks/index.mjs +1646 -0
- package/dist/blocks/sidebar/index.d.ts +16 -0
- package/dist/blocks/sidebar/sidebar-01/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-01/components/search-form.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-01/components/version-switcher.d.ts +4 -0
- package/dist/blocks/sidebar/sidebar-01/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-02/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-02/components/search-form.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-02/components/version-switcher.d.ts +4 -0
- package/dist/blocks/sidebar/sidebar-02/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-03/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-03/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-04/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-04/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-05/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-05/components/search-form.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-05/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-06/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-06/components/nav-main.d.ts +13 -0
- package/dist/blocks/sidebar/sidebar-06/components/sidebar-opt-in-form.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-06/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-07/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-07/components/nav-main.d.ts +13 -0
- package/dist/blocks/sidebar/sidebar-07/components/nav-projects.d.ts +8 -0
- package/dist/blocks/sidebar/sidebar-07/components/nav-user.d.ts +7 -0
- package/dist/blocks/sidebar/sidebar-07/components/team-switcher.d.ts +8 -0
- package/dist/blocks/sidebar/sidebar-07/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-08/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-08/components/nav-main.d.ts +13 -0
- package/dist/blocks/sidebar/sidebar-08/components/nav-projects.d.ts +8 -0
- package/dist/blocks/sidebar/sidebar-08/components/nav-secondary.d.ts +10 -0
- package/dist/blocks/sidebar/sidebar-08/components/nav-user.d.ts +7 -0
- package/dist/blocks/sidebar/sidebar-08/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-09/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-09/components/nav-user.d.ts +7 -0
- package/dist/blocks/sidebar/sidebar-09/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-10/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-10/components/nav-actions.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-10/components/nav-favorites.d.ts +7 -0
- package/dist/blocks/sidebar/sidebar-10/components/nav-main.d.ts +9 -0
- package/dist/blocks/sidebar/sidebar-10/components/nav-secondary.d.ts +11 -0
- package/dist/blocks/sidebar/sidebar-10/components/nav-workspaces.d.ts +10 -0
- package/dist/blocks/sidebar/sidebar-10/components/team-switcher.d.ts +8 -0
- package/dist/blocks/sidebar/sidebar-10/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-11/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-11/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-12/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-12/components/calendars.d.ts +6 -0
- package/dist/blocks/sidebar/sidebar-12/components/date-picker.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-12/components/nav-user.d.ts +7 -0
- package/dist/blocks/sidebar/sidebar-12/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-13/components/settings-dialog.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-13/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-14/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-14/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-15/components/calendars.d.ts +6 -0
- package/dist/blocks/sidebar/sidebar-15/components/date-picker.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-15/components/nav-favorites.d.ts +7 -0
- package/dist/blocks/sidebar/sidebar-15/components/nav-main.d.ts +9 -0
- package/dist/blocks/sidebar/sidebar-15/components/nav-secondary.d.ts +11 -0
- package/dist/blocks/sidebar/sidebar-15/components/nav-user.d.ts +7 -0
- package/dist/blocks/sidebar/sidebar-15/components/nav-workspaces.d.ts +10 -0
- package/dist/blocks/sidebar/sidebar-15/components/sidebar-left.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-15/components/sidebar-right.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-15/components/team-switcher.d.ts +8 -0
- package/dist/blocks/sidebar/sidebar-15/page.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-16/components/app-sidebar.d.ts +3 -0
- package/dist/blocks/sidebar/sidebar-16/components/nav-main.d.ts +13 -0
- package/dist/blocks/sidebar/sidebar-16/components/nav-projects.d.ts +8 -0
- package/dist/blocks/sidebar/sidebar-16/components/nav-secondary.d.ts +10 -0
- package/dist/blocks/sidebar/sidebar-16/components/nav-user.d.ts +7 -0
- package/dist/blocks/sidebar/sidebar-16/components/search-form.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-16/components/site-header.d.ts +1 -0
- package/dist/blocks/sidebar/sidebar-16/page.d.ts +3 -0
- package/dist/breadcrumb.js +107 -0
- package/dist/breadcrumb.mjs +99 -0
- package/dist/calendar-ext/index.js +208 -0
- package/dist/calendar-ext/index.mjs +170 -0
- package/dist/calendar.js +194 -0
- package/dist/calendar.mjs +169 -0
- package/dist/carousel.js +283 -0
- package/dist/carousel.mjs +254 -0
- package/dist/charts/index.js +5842 -0
- package/dist/charts/index.mjs +5751 -0
- package/dist/checkbox.js +60 -0
- package/dist/checkbox.mjs +35 -0
- package/dist/code/block.js +226 -0
- package/dist/code/block.mjs +203 -0
- package/dist/code/compare.js +446 -0
- package/dist/code/compare.mjs +423 -0
- package/dist/code/diff.js +430 -0
- package/dist/code/diff.mjs +407 -0
- package/dist/code/editor.js +243 -0
- package/dist/code/editor.mjs +218 -0
- package/dist/code/explorer.js +291 -0
- package/dist/code/explorer.mjs +268 -0
- package/dist/code/index.js +2551 -0
- package/dist/code/index.mjs +2510 -0
- package/dist/code/preview.js +400 -0
- package/dist/code/preview.mjs +377 -0
- package/dist/code/snippet.js +274 -0
- package/dist/code/snippet.mjs +250 -0
- package/dist/code/tabs.js +75 -0
- package/dist/code/tabs.mjs +53 -0
- package/dist/code/terminal.js +437 -0
- package/dist/code/terminal.mjs +414 -0
- package/dist/collapsible.js +33 -0
- package/dist/collapsible.mjs +9 -0
- package/dist/command.js +283 -0
- package/dist/command.mjs +252 -0
- package/dist/components/cal-embed.d.ts +10 -0
- package/dist/components/index.d.ts +2 -0
- package/dist/context-menu.js +207 -0
- package/dist/context-menu.mjs +171 -0
- package/dist/desktop/hooks.js +224 -0
- package/dist/desktop/hooks.mjs +199 -0
- package/dist/desktop/index.js +686 -0
- package/dist/desktop/index.mjs +658 -0
- package/dist/desktop/spotlight.js +261 -0
- package/dist/desktop/spotlight.mjs +236 -0
- package/dist/desktop/window.js +274 -0
- package/dist/desktop/window.mjs +248 -0
- package/dist/device/index.js +3 -0
- package/dist/device/index.mjs +2 -0
- package/dist/dialog.js +246 -0
- package/dist/dialog.mjs +214 -0
- package/dist/dock/basic.js +174 -0
- package/dist/dock/basic.mjs +151 -0
- package/dist/dock/index.js +648 -0
- package/dist/dock/index.mjs +621 -0
- package/dist/dock/limelight-nav.js +315 -0
- package/dist/dock/limelight-nav.mjs +294 -0
- package/dist/dock/macos.js +141 -0
- package/dist/dock/macos.mjs +118 -0
- package/dist/dock/menu.js +70 -0
- package/dist/dock/menu.mjs +48 -0
- package/dist/dock/message.js +149 -0
- package/dist/dock/message.mjs +127 -0
- package/dist/drawer.js +115 -0
- package/dist/drawer.mjs +103 -0
- package/dist/dropdown-menu.js +202 -0
- package/dist/dropdown-menu.mjs +166 -0
- package/dist/finance/AdvancedChart.js +48 -0
- package/dist/finance/AdvancedChart.mjs +46 -0
- package/dist/finance/CompanyProfile.js +48 -0
- package/dist/finance/CompanyProfile.mjs +46 -0
- package/dist/finance/CryptoScreener.js +45 -0
- package/dist/finance/CryptoScreener.mjs +43 -0
- package/dist/finance/Financials.js +52 -0
- package/dist/finance/Financials.mjs +50 -0
- package/dist/finance/ForexScreener.js +46 -0
- package/dist/finance/ForexScreener.mjs +44 -0
- package/dist/finance/MarketOverview.js +104 -0
- package/dist/finance/MarketOverview.mjs +102 -0
- package/dist/finance/NewsTimeline.js +44 -0
- package/dist/finance/NewsTimeline.mjs +42 -0
- package/dist/finance/OrderEntry.js +131 -0
- package/dist/finance/OrderEntry.mjs +129 -0
- package/dist/finance/OrdersHistory.js +64 -0
- package/dist/finance/OrdersHistory.mjs +62 -0
- package/dist/finance/PositionsList.js +80 -0
- package/dist/finance/PositionsList.mjs +78 -0
- package/dist/finance/StockScreener.js +46 -0
- package/dist/finance/StockScreener.mjs +44 -0
- package/dist/finance/SymbolInfo.js +46 -0
- package/dist/finance/SymbolInfo.mjs +44 -0
- package/dist/finance/TechnicalAnalysis.js +54 -0
- package/dist/finance/TechnicalAnalysis.mjs +52 -0
- package/dist/finance/TickerTape.js +56 -0
- package/dist/finance/TickerTape.mjs +54 -0
- package/dist/finance/TradingPanel.js +191 -0
- package/dist/finance/TradingPanel.mjs +189 -0
- package/dist/finance/index.js +930 -0
- package/dist/finance/index.mjs +914 -0
- package/dist/form/index.js +155 -0
- package/dist/form/index.mjs +125 -0
- package/dist/form.js +172 -0
- package/dist/form.mjs +142 -0
- package/dist/helpers/file.d.ts +6 -0
- package/dist/helpers/memoization.d.ts +8 -0
- package/dist/hover-card.js +58 -0
- package/dist/hover-card.mjs +34 -0
- package/dist/index.js +9650 -0
- package/dist/index.mjs +9234 -0
- package/dist/input-otp.js +79 -0
- package/dist/input-otp.mjs +54 -0
- package/dist/kanban/index.js +594 -0
- package/dist/kanban/index.mjs +572 -0
- package/dist/lib/utils.js +28 -0
- package/dist/lib/utils.mjs +24 -0
- package/dist/mermaid/index.js +281 -0
- package/dist/mermaid/index.mjs +254 -0
- package/dist/navigation/index.js +98 -0
- package/dist/navigation/index.mjs +79 -0
- package/dist/navigation-menu.js +149 -0
- package/dist/navigation-menu.mjs +116 -0
- package/dist/pattern/grid-pattern.js +333 -0
- package/dist/pattern/grid-pattern.mjs +310 -0
- package/dist/pattern/index.js +333 -0
- package/dist/pattern/index.mjs +310 -0
- package/dist/popover.js +63 -0
- package/dist/popover.mjs +37 -0
- package/dist/primitives/__tests__/core-primitives.test.d.ts +1 -0
- package/dist/primitives/accordion.d.ts +26 -0
- package/dist/primitives/action-button.d.ts +9 -0
- package/dist/primitives/alert-dialog.d.ts +56 -0
- package/dist/primitives/alert.d.ts +10 -0
- package/dist/primitives/apply-typography.d.ts +7 -0
- package/dist/primitives/aspect-ratio.d.ts +3 -0
- package/dist/primitives/avatar.d.ts +24 -0
- package/dist/primitives/background-beams.d.ts +4 -0
- package/dist/primitives/badge.d.ts +10 -0
- package/dist/primitives/breadcrumb.d.ts +50 -0
- package/dist/primitives/breakpoint-indicator.d.ts +3 -0
- package/dist/primitives/button-group.d.ts +11 -0
- package/dist/primitives/button.d.ts +13 -0
- package/dist/primitives/cal-embed.d.ts +10 -0
- package/dist/primitives/calendar.d.ts +10 -0
- package/dist/primitives/card.d.ts +9 -0
- package/dist/primitives/carousel.d.ts +18 -0
- package/dist/primitives/chart.d.ts +40 -0
- package/dist/primitives/charts/__tests__/charts.test.d.ts +9 -0
- package/dist/primitives/charts/area/chart-area-axes.d.ts +2 -0
- package/dist/primitives/charts/area/chart-area-default.d.ts +2 -0
- package/dist/primitives/charts/area/chart-area-gradient.d.ts +2 -0
- package/dist/primitives/charts/area/chart-area-icons.d.ts +2 -0
- package/dist/primitives/charts/area/chart-area-interactive.d.ts +2 -0
- package/dist/primitives/charts/area/chart-area-legend.d.ts +2 -0
- package/dist/primitives/charts/area/chart-area-linear.d.ts +2 -0
- package/dist/primitives/charts/area/chart-area-stacked-expand.d.ts +2 -0
- package/dist/primitives/charts/area/chart-area-stacked.d.ts +2 -0
- package/dist/primitives/charts/area/chart-area-step.d.ts +2 -0
- package/dist/primitives/charts/area/index.d.ts +10 -0
- package/dist/primitives/charts/bar/chart-bar-active.d.ts +2 -0
- package/dist/primitives/charts/bar/chart-bar-default.d.ts +2 -0
- package/dist/primitives/charts/bar/chart-bar-horizontal.d.ts +2 -0
- package/dist/primitives/charts/bar/chart-bar-interactive.d.ts +2 -0
- package/dist/primitives/charts/bar/chart-bar-label-custom.d.ts +2 -0
- package/dist/primitives/charts/bar/chart-bar-label.d.ts +2 -0
- package/dist/primitives/charts/bar/chart-bar-mixed.d.ts +2 -0
- package/dist/primitives/charts/bar/chart-bar-multiple.d.ts +2 -0
- package/dist/primitives/charts/bar/chart-bar-negative.d.ts +2 -0
- package/dist/primitives/charts/bar/chart-bar-stacked.d.ts +2 -0
- package/dist/primitives/charts/bar/index.d.ts +10 -0
- package/dist/primitives/charts/index.d.ts +7 -0
- package/dist/primitives/charts/line/chart-line-default.d.ts +2 -0
- package/dist/primitives/charts/line/chart-line-dots-colors.d.ts +2 -0
- package/dist/primitives/charts/line/chart-line-dots-custom.d.ts +2 -0
- package/dist/primitives/charts/line/chart-line-dots.d.ts +2 -0
- package/dist/primitives/charts/line/chart-line-interactive.d.ts +2 -0
- package/dist/primitives/charts/line/chart-line-label-custom.d.ts +2 -0
- package/dist/primitives/charts/line/chart-line-label.d.ts +2 -0
- package/dist/primitives/charts/line/chart-line-linear.d.ts +2 -0
- package/dist/primitives/charts/line/chart-line-multiple.d.ts +2 -0
- package/dist/primitives/charts/line/chart-line-step.d.ts +2 -0
- package/dist/primitives/charts/line/index.d.ts +10 -0
- package/dist/primitives/charts/pie/chart-pie-donut-active.d.ts +2 -0
- package/dist/primitives/charts/pie/chart-pie-donut-text.d.ts +2 -0
- package/dist/primitives/charts/pie/chart-pie-donut.d.ts +2 -0
- package/dist/primitives/charts/pie/chart-pie-interactive.d.ts +2 -0
- package/dist/primitives/charts/pie/chart-pie-label-custom.d.ts +2 -0
- package/dist/primitives/charts/pie/chart-pie-label-list.d.ts +2 -0
- package/dist/primitives/charts/pie/chart-pie-label.d.ts +2 -0
- package/dist/primitives/charts/pie/chart-pie-legend.d.ts +2 -0
- package/dist/primitives/charts/pie/chart-pie-separator-none.d.ts +2 -0
- package/dist/primitives/charts/pie/index.d.ts +9 -0
- package/dist/primitives/charts/radar/chart-radar-default.d.ts +2 -0
- package/dist/primitives/charts/radar/chart-radar-dots.d.ts +2 -0
- package/dist/primitives/charts/radar/chart-radar-grid-circle-fill.d.ts +2 -0
- package/dist/primitives/charts/radar/chart-radar-grid-circle-no-lines.d.ts +2 -0
- package/dist/primitives/charts/radar/chart-radar-grid-circle.d.ts +2 -0
- package/dist/primitives/charts/radar/chart-radar-grid-custom.d.ts +2 -0
- package/dist/primitives/charts/radar/chart-radar-grid-fill.d.ts +2 -0
- package/dist/primitives/charts/radar/chart-radar-grid-none.d.ts +2 -0
- package/dist/primitives/charts/radar/chart-radar-icons.d.ts +2 -0
- package/dist/primitives/charts/radar/index.d.ts +9 -0
- package/dist/primitives/charts/radial/chart-radial-grid.d.ts +2 -0
- package/dist/primitives/charts/radial/chart-radial-label.d.ts +2 -0
- package/dist/primitives/charts/radial/chart-radial-shape.d.ts +2 -0
- package/dist/primitives/charts/radial/chart-radial-simple.d.ts +2 -0
- package/dist/primitives/charts/radial/chart-radial-stacked.d.ts +2 -0
- package/dist/primitives/charts/radial/chart-radial-text.d.ts +2 -0
- package/dist/primitives/charts/radial/index.d.ts +6 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-advanced.d.ts +2 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-default.d.ts +4 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-formatter.d.ts +2 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-icons.d.ts +2 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-indicator-line.d.ts +4 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-indicator-none.d.ts +2 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-label-custom.d.ts +2 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-label-formatter.d.ts +2 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-label-none.d.ts +2 -0
- package/dist/primitives/charts/tooltip/index.d.ts +9 -0
- package/dist/primitives/chat/chat-input-area.d.ts +23 -0
- package/dist/primitives/chat/chat-input.d.ts +12 -0
- package/dist/primitives/chat/files-preview.d.ts +12 -0
- package/dist/primitives/chat/index.d.ts +6 -0
- package/dist/primitives/chat/json-form.d.ts +3 -0
- package/dist/primitives/chat/message-list.d.ts +19 -0
- package/dist/primitives/chat/message.d.ts +29 -0
- package/dist/primitives/chat/sqlite-preview.d.ts +5 -0
- package/dist/primitives/checkbox.d.ts +11 -0
- package/dist/primitives/collapsible.d.ts +5 -0
- package/dist/primitives/combobox.d.ts +41 -0
- package/dist/primitives/command.d.ts +38 -0
- package/dist/primitives/context-menu.d.ts +53 -0
- package/dist/primitives/copy-to-clipboard-icon.d.ts +14 -0
- package/dist/primitives/dialog-video-controller.d.ts +3 -0
- package/dist/primitives/dialog.d.ts +17 -0
- package/dist/primitives/dot-pattern.d.ts +13 -0
- package/dist/primitives/dots-loader.d.ts +4 -0
- package/dist/primitives/drawer.d.ts +37 -0
- package/dist/primitives/dropdown-menu.d.ts +51 -0
- package/dist/primitives/empty.d.ts +11 -0
- package/dist/primitives/error-message.d.ts +6 -0
- package/dist/primitives/field.d.ts +9 -0
- package/dist/primitives/file-uploader.d.ts +19 -0
- package/dist/primitives/form.d.ts +39 -0
- package/dist/primitives/hover-card.d.ts +9 -0
- package/dist/primitives/icons/github.d.ts +4 -0
- package/dist/primitives/icons/index.d.ts +4 -0
- package/dist/primitives/icons/youtube-logo.d.ts +4 -0
- package/dist/primitives/index-blocks.d.ts +4 -0
- package/dist/primitives/index-common.d.ts +74 -0
- package/dist/primitives/index-core.d.ts +28 -0
- package/dist/primitives/index-next.d.ts +2 -0
- package/dist/primitives/index-selective.d.ts +51 -0
- package/dist/primitives/index-standard.d.ts +78 -0
- package/dist/primitives/index.d.ts +1 -0
- package/dist/primitives/index.js +9650 -0
- package/dist/primitives/index.mjs +9234 -0
- package/dist/primitives/input-group.d.ts +16 -0
- package/dist/primitives/input-otp.d.ts +34 -0
- package/dist/primitives/input.d.ts +14 -0
- package/dist/primitives/item.d.ts +23 -0
- package/dist/primitives/kbd.d.ts +4 -0
- package/dist/primitives/label.d.ts +10 -0
- package/dist/primitives/list-adaptor.d.ts +9 -0
- package/dist/primitives/list-box.d.ts +11 -0
- package/dist/primitives/loading-spinner.d.ts +5 -0
- package/dist/primitives/markdown-preview.d.ts +128 -0
- package/dist/primitives/menubar.d.ts +28 -0
- package/dist/primitives/mermaid.d.ts +7 -0
- package/dist/primitives/native-select.d.ts +8 -0
- package/dist/primitives/navigation-menu.d.ts +12 -0
- package/dist/primitives/next/image.d.ts +11 -0
- package/dist/primitives/next/index.d.ts +7 -0
- package/dist/primitives/next/inline-icon.d.ts +13 -0
- package/dist/primitives/next/link-element.d.ts +23 -0
- package/dist/primitives/next/mdx-link.d.ts +3 -0
- package/dist/primitives/next/media-stack.d.ts +8 -0
- package/dist/primitives/next/nav-items.d.ts +10 -0
- package/dist/primitives/next/youtube-embed.d.ts +11 -0
- package/dist/primitives/pagination.d.ts +34 -0
- package/dist/primitives/popover.d.ts +11 -0
- package/dist/primitives/pretty-json-print.d.ts +4 -0
- package/dist/primitives/progress.d.ts +8 -0
- package/dist/primitives/prompt-textarea.d.ts +18 -0
- package/dist/primitives/qr-code.d.ts +16 -0
- package/dist/primitives/radio-group.d.ts +11 -0
- package/dist/primitives/resizable.d.ts +23 -0
- package/dist/primitives/scroll-area.d.ts +13 -0
- package/dist/primitives/search-input.d.ts +13 -0
- package/dist/primitives/select.d.ts +26 -0
- package/dist/primitives/separator.d.ts +8 -0
- package/dist/primitives/sheet.d.ts +40 -0
- package/dist/primitives/sidebar.d.ts +69 -0
- package/dist/primitives/skeleton.d.ts +4 -0
- package/dist/primitives/slider.d.ts +5 -0
- package/dist/primitives/sonner.d.ts +5 -0
- package/dist/primitives/spinner.d.ts +2 -0
- package/dist/primitives/step-indicator.d.ts +9 -0
- package/dist/primitives/stepper.d.ts +48 -0
- package/dist/primitives/switch.d.ts +8 -0
- package/dist/primitives/table.d.ts +34 -0
- package/dist/primitives/tabs.d.ts +11 -0
- package/dist/primitives/text-area.d.ts +5 -0
- package/dist/primitives/text-link.d.ts +5 -0
- package/dist/primitives/textarea.d.ts +12 -0
- package/dist/primitives/textfield.d.ts +32 -0
- package/dist/primitives/toast.d.ts +5 -0
- package/dist/primitives/toggle-group.d.ts +13 -0
- package/dist/primitives/toggle.d.ts +12 -0
- package/dist/primitives/tooltip.d.ts +14 -0
- package/dist/primitives/video-player.d.ts +6 -0
- package/dist/primitives/youtube-pip-player.d.ts +32 -0
- package/dist/primitives-export.js +9650 -0
- package/dist/primitives-export.mjs +9234 -0
- package/dist/progress.js +62 -0
- package/dist/progress.mjs +37 -0
- package/dist/project/gantt.js +65 -0
- package/dist/project/gantt.mjs +43 -0
- package/dist/project/index.js +636 -0
- package/dist/project/index.mjs +611 -0
- package/dist/project/kanban.js +597 -0
- package/dist/project/kanban.mjs +572 -0
- package/dist/project/list.js +35 -0
- package/dist/project/list.mjs +12 -0
- package/dist/radio-group.js +68 -0
- package/dist/radio-group.mjs +45 -0
- package/dist/resizable.js +72 -0
- package/dist/resizable.mjs +48 -0
- package/dist/scroll-area.js +89 -0
- package/dist/scroll-area.mjs +66 -0
- package/dist/select.js +140 -0
- package/dist/select.mjs +111 -0
- package/dist/separator.js +59 -0
- package/dist/separator.mjs +34 -0
- package/dist/sheet.js +148 -0
- package/dist/sheet.mjs +117 -0
- package/dist/skeleton.js +32 -0
- package/dist/skeleton.mjs +27 -0
- package/dist/slider.js +99 -0
- package/dist/slider.mjs +73 -0
- package/dist/sonner.js +34 -0
- package/dist/sonner.mjs +29 -0
- package/dist/spline/index.js +211 -0
- package/dist/spline/index.mjs +202 -0
- package/dist/spline/media-stack.js +193 -0
- package/dist/spline/media-stack.mjs +185 -0
- package/dist/spline/player.js +37 -0
- package/dist/spline/player.mjs +31 -0
- package/dist/src/3d/button.d.ts +26 -0
- package/dist/src/3d/card.d.ts +28 -0
- package/dist/src/3d/carousel.d.ts +25 -0
- package/dist/src/3d/grid.d.ts +48 -0
- package/dist/src/3d/index.d.ts +6 -0
- package/dist/src/3d/marquee.d.ts +36 -0
- package/dist/src/3d/pin.d.ts +7 -0
- package/dist/src/animation/apple-cards-carousel.d.ts +35 -0
- package/dist/src/animation/apple-hello-effect.d.ts +7 -0
- package/dist/src/animation/background.d.ts +102 -0
- package/dist/src/animation/beam.d.ts +14 -0
- package/dist/src/animation/cursor.d.ts +69 -0
- package/dist/src/animation/icon.d.ts +118 -0
- package/dist/src/animation/index.d.ts +14 -0
- package/dist/src/animation/list.d.ts +125 -0
- package/dist/src/animation/number.d.ts +126 -0
- package/dist/src/animation/testimonials.d.ts +16 -0
- package/dist/src/animation/tooltip.d.ts +8 -0
- package/dist/src/avatar.d.ts +1 -0
- package/dist/src/badge.d.ts +1 -0
- package/dist/src/billing/components/index.d.ts +6 -0
- package/dist/src/billing/components/invoice-manager.d.ts +9 -0
- package/dist/src/billing/components/payment-manager.d.ts +12 -0
- package/dist/src/billing/components/subscription-portal.d.ts +14 -0
- package/dist/src/billing/index.d.ts +6 -0
- package/dist/src/billing/types/index.d.ts +99 -0
- package/dist/src/button.d.ts +1 -0
- package/dist/src/calendar-ext/index.d.ts +3 -0
- package/dist/src/charts/index.d.ts +64 -0
- package/dist/src/code/block.d.ts +21 -0
- package/dist/src/code/compare.d.ts +35 -0
- package/dist/src/code/diff.d.ts +29 -0
- package/dist/src/code/editor.d.ts +22 -0
- package/dist/src/code/explorer.d.ts +33 -0
- package/dist/src/code/index.d.ts +9 -0
- package/dist/src/code/preview.d.ts +30 -0
- package/dist/src/code/snippet.d.ts +28 -0
- package/dist/src/code/tabs.d.ts +11 -0
- package/dist/src/code/terminal.d.ts +33 -0
- package/dist/src/desktop/hooks.d.ts +74 -0
- package/dist/src/desktop/index.d.ts +6 -0
- package/dist/src/desktop/spotlight.d.ts +23 -0
- package/dist/src/desktop/window.d.ts +33 -0
- package/dist/src/device/index.d.ts +1 -0
- package/dist/src/dock/basic.d.ts +19 -0
- package/dist/src/dock/index.d.ts +5 -0
- package/dist/src/dock/limelight-nav.d.ts +9 -0
- package/dist/src/dock/macos.d.ts +16 -0
- package/dist/src/dock/menu.d.ts +13 -0
- package/dist/src/dock/message.d.ts +14 -0
- package/dist/src/form/form.d.ts +23 -0
- package/dist/src/form/index.d.ts +1 -0
- package/dist/src/hooks/index.d.ts +7 -0
- package/dist/src/hooks/use-click-away.d.ts +2 -0
- package/dist/src/hooks/use-combined-refs.d.ts +3 -0
- package/dist/src/hooks/use-copy-clipboard.d.ts +9 -0
- package/dist/src/hooks/use-debounce.d.ts +1 -0
- package/dist/src/hooks/use-fill-ids.d.ts +8 -0
- package/dist/src/hooks/use-map.d.ts +1 -0
- package/dist/src/hooks/use-measure.d.ts +8 -0
- package/dist/src/hooks/use-reverse-video-playback.d.ts +1 -0
- package/dist/src/hooks/use-scroll-restoration.d.ts +8 -0
- package/dist/src/kanban/index.d.ts +2 -0
- package/dist/src/mcp/enhanced-server.d.ts +7 -0
- package/dist/src/mcp/index.d.ts +6 -0
- package/dist/src/mermaid/index.d.ts +2 -0
- package/dist/src/navigation/advanced-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/ai-model-selector-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/app-switcher-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/breadcrumb-and-filters-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/breadcrumb-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/centered-logo-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/collaboration-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/communication-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/context-switcher-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/dashboard-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/e-commerce-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/icon-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/index.d.ts +18 -0
- package/dist/src/navigation/search-and-toggle-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/simple-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/status-dashboard-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/team-switcher-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/two-tier-navigation-bar.d.ts +1 -0
- package/dist/src/navigation/underline-navigation-bar.d.ts +1 -0
- package/dist/src/pattern/grid.d.ts +110 -0
- package/dist/src/pattern/index.d.ts +2 -0
- package/dist/src/primitives-export.d.ts +8 -0
- package/dist/src/project/gantt.d.ts +12 -0
- package/dist/src/project/index.d.ts +3 -0
- package/dist/src/project/kanban.d.ts +35 -0
- package/dist/src/project/list.d.ts +4 -0
- package/dist/src/registry/api.d.ts +37 -0
- package/dist/src/registry/index.d.ts +86 -0
- package/dist/src/spline/index.d.ts +2 -0
- package/dist/src/spline/media-stack.d.ts +14 -0
- package/dist/src/spline/player.d.ts +14 -0
- package/dist/src/ui/announcement.d.ts +8 -0
- package/dist/src/ui/avatar-group.d.ts +11 -0
- package/dist/src/ui/banner.d.ts +10 -0
- package/dist/src/ui/cursor.d.ts +8 -0
- package/dist/src/ui/index.d.ts +17 -0
- package/dist/src/ui/marquee.d.ts +9 -0
- package/dist/src/ui/pill.d.ts +10 -0
- package/dist/src/ui/spinner.d.ts +2 -0
- package/dist/src/ui/tags.d.ts +12 -0
- package/dist/src/ui/ticker.d.ts +9 -0
- package/dist/src/utils.d.ts +4 -0
- package/dist/style/theme-provider.d.ts +4 -0
- package/dist/switch.js +62 -0
- package/dist/switch.mjs +37 -0
- package/dist/table.js +110 -0
- package/dist/table.mjs +101 -0
- package/dist/tabs.js +128 -0
- package/dist/tabs.mjs +102 -0
- package/dist/tailwind/fontFamily.tailwind.d.ts +8 -0
- package/dist/tailwind/fontSize.tailwind.d.ts +36 -0
- package/dist/tailwind/index.d.ts +3 -0
- package/dist/tailwind/index.js +2023 -0
- package/dist/tailwind/index.mjs +2011 -0
- package/dist/tailwind/screens.tailwind.d.ts +9 -0
- package/dist/tailwind/tw-font-desc.d.ts +6 -0
- package/dist/textarea.js +78 -0
- package/dist/textarea.mjs +56 -0
- package/dist/toggle-group.js +118 -0
- package/dist/toggle-group.mjs +93 -0
- package/dist/toggle.js +71 -0
- package/dist/toggle.mjs +48 -0
- package/dist/tooltip.js +67 -0
- package/dist/tooltip.mjs +40 -0
- package/dist/types/animation-def.d.ts +2 -0
- package/dist/types/breakpoints.d.ts +4 -0
- package/dist/types/bullet-item.d.ts +6 -0
- package/dist/types/button-def.d.ts +29 -0
- package/dist/types/dimensions.d.ts +5 -0
- package/dist/types/grid-def.d.ts +36 -0
- package/dist/types/image-def.d.ts +27 -0
- package/dist/types/index.d.ts +14 -0
- package/dist/types/index.js +57 -0
- package/dist/types/index.mjs +51 -0
- package/dist/types/link-def.d.ts +44 -0
- package/dist/types/media-stack-def.d.ts +25 -0
- package/dist/types/t-shirt-size.d.ts +2 -0
- package/dist/types/tshirt-dimensions.d.ts +12 -0
- package/dist/types/video-def.d.ts +9 -0
- package/dist/ui/announcement.js +134 -0
- package/dist/ui/announcement.mjs +112 -0
- package/dist/ui/avatar-group.js +88 -0
- package/dist/ui/avatar-group.mjs +65 -0
- package/dist/ui/banner.js +85 -0
- package/dist/ui/banner.mjs +62 -0
- package/dist/ui/cursor.js +78 -0
- package/dist/ui/cursor.mjs +56 -0
- package/dist/ui/index.js +495 -0
- package/dist/ui/index.mjs +462 -0
- package/dist/ui/marquee.js +74 -0
- package/dist/ui/marquee.mjs +52 -0
- package/dist/ui/pill.js +85 -0
- package/dist/ui/pill.mjs +62 -0
- package/dist/ui/spinner.js +28 -0
- package/dist/ui/spinner.mjs +26 -0
- package/dist/ui/tags.js +117 -0
- package/dist/ui/tags.mjs +95 -0
- package/dist/ui/ticker.js +73 -0
- package/dist/ui/ticker.mjs +51 -0
- package/dist/util/blob.d.ts +2 -0
- package/dist/util/copy-to-clipboard.d.ts +1 -0
- package/dist/util/create-shadow-root.d.ts +7 -0
- package/dist/util/date.d.ts +28 -0
- package/dist/util/debounce.d.ts +1 -0
- package/dist/util/file.d.ts +3 -0
- package/dist/util/format-and-abbreviate-as-currency.d.ts +11 -0
- package/dist/util/format-text.d.ts +7 -0
- package/dist/util/format-to-max-char.d.ts +5 -0
- package/dist/util/index-client.d.ts +2 -0
- package/dist/util/index.d.ts +36 -0
- package/dist/util/index.js +463 -0
- package/dist/util/index.mjs +404 -0
- package/dist/util/number-abbreviate.d.ts +9 -0
- package/dist/util/specifier.d.ts +7 -0
- package/dist/util/spread-to-transform.d.ts +7 -0
- package/dist/util/step-animation.d.ts +5 -0
- package/dist/util/timing.d.ts +1 -0
- package/dist/util/toasts.d.ts +2 -0
- package/dist/util/two-way-map.d.ts +8 -0
- package/dist/util/use-mobile.d.ts +1 -0
- package/dist/utils.d.ts +3 -0
- package/docs/_registry/index.ts +426 -0
- package/docs/_registry/layout/docs-min.tsx +197 -0
- package/docs/_registry/layout/page-min.tsx +128 -0
- package/docs/components/accordion.tsx +118 -0
- package/docs/components/banner.tsx +144 -0
- package/docs/components/callout.tsx +112 -0
- package/docs/components/card.tsx +52 -0
- package/docs/components/codeblock.tsx +258 -0
- package/docs/components/dialog/search-algolia.tsx +132 -0
- package/docs/components/dialog/search-default.tsx +131 -0
- package/docs/components/dialog/search-orama.tsx +143 -0
- package/docs/components/dialog/search.tsx +529 -0
- package/docs/components/dynamic-codeblock.tsx +129 -0
- package/docs/components/files.tsx +81 -0
- package/docs/components/github-info.tsx +107 -0
- package/docs/components/heading.tsx +33 -0
- package/docs/components/image-zoom.css +77 -0
- package/docs/components/image-zoom.tsx +58 -0
- package/docs/components/index.ts +7 -0
- package/docs/components/inline-toc.tsx +48 -0
- package/docs/components/sidebar/base.tsx +451 -0
- package/docs/components/sidebar/link-item.tsx +65 -0
- package/docs/components/sidebar/page-tree.tsx +113 -0
- package/docs/components/sidebar/tabs/dropdown.tsx +109 -0
- package/docs/components/sidebar/tabs/index.tsx +89 -0
- package/docs/components/steps.tsx +9 -0
- package/docs/components/tabs.tsx +203 -0
- package/docs/components/toc/clerk.tsx +173 -0
- package/docs/components/toc/default.tsx +57 -0
- package/docs/components/toc/index.tsx +136 -0
- package/docs/components/type-table.tsx +174 -0
- package/docs/components/ui/accordion.tsx +88 -0
- package/docs/components/ui/button.tsx +28 -0
- package/docs/components/ui/collapsible.tsx +42 -0
- package/docs/components/ui/navigation-menu.tsx +83 -0
- package/docs/components/ui/popover.tsx +32 -0
- package/docs/components/ui/scroll-area.tsx +59 -0
- package/docs/components/ui/tabs.tsx +145 -0
- package/docs/contexts/i18n.tsx +56 -0
- package/docs/contexts/search.tsx +165 -0
- package/docs/contexts/tree.tsx +65 -0
- package/docs/css/aspen.css +39 -0
- package/docs/css/black.css +39 -0
- package/docs/css/catppuccin.css +49 -0
- package/docs/css/colors/index.css +51 -0
- package/docs/css/dusk.css +47 -0
- package/docs/css/emerald.css +39 -0
- package/docs/css/layouts/docs.css +1 -0
- package/docs/css/layouts/home.css +1 -0
- package/docs/css/layouts/notebook.css +1 -0
- package/docs/css/neutral.css +7 -0
- package/docs/css/ocean.css +48 -0
- package/docs/css/preset.css +305 -0
- package/docs/css/purple.css +39 -0
- package/docs/css/ruby.css +39 -0
- package/docs/css/shadcn.css +36 -0
- package/docs/css/shiki.css +90 -0
- package/docs/css/solar.css +75 -0
- package/docs/css/style.css +9 -0
- package/docs/css/vitepress.css +77 -0
- package/docs/i18n.tsx +30 -0
- package/docs/icons.tsx +354 -0
- package/docs/layouts/docs/client.tsx +129 -0
- package/docs/layouts/docs/index.tsx +321 -0
- package/docs/layouts/docs/page/client.tsx +376 -0
- package/docs/layouts/docs/page/index.tsx +251 -0
- package/docs/layouts/docs/sidebar.tsx +265 -0
- package/docs/layouts/home/client.tsx +375 -0
- package/docs/layouts/home/index.tsx +51 -0
- package/docs/layouts/home/navbar.tsx +55 -0
- package/docs/layouts/notebook/client.tsx +281 -0
- package/docs/layouts/notebook/index.tsx +461 -0
- package/docs/layouts/notebook/page/client.tsx +375 -0
- package/docs/layouts/notebook/page/index.tsx +251 -0
- package/docs/layouts/notebook/sidebar.tsx +248 -0
- package/docs/layouts/shared/index.tsx +89 -0
- package/docs/layouts/shared/language-toggle.tsx +66 -0
- package/docs/layouts/shared/link-item.tsx +119 -0
- package/docs/layouts/shared/search-toggle.tsx +78 -0
- package/docs/layouts/shared/theme-toggle.tsx +86 -0
- package/docs/mdx.server.tsx +37 -0
- package/docs/mdx.tsx +97 -0
- package/docs/og.tsx +101 -0
- package/docs/page.tsx +85 -0
- package/docs/provider/base.tsx +173 -0
- package/docs/provider/next.tsx +23 -0
- package/docs/provider/react-router.tsx +23 -0
- package/docs/provider/tanstack.tsx +23 -0
- package/docs/provider/waku.tsx +23 -0
- package/docs/source.ts +3 -0
- package/docs/theme/typography/LICENSE +21 -0
- package/docs/theme/typography/index.ts +201 -0
- package/docs/theme/typography/styles.ts +449 -0
- package/docs/utils/cn.ts +1 -0
- package/docs/utils/is-active.ts +23 -0
- package/docs/utils/merge-refs.ts +15 -0
- package/docs/utils/use-copy-button.ts +39 -0
- package/docs/utils/use-footer-items.ts +27 -0
- package/docs/utils/use-is-scroll-top.ts +21 -0
- package/finance/README.md +164 -0
- package/finance/components/AdvancedChart.tsx +58 -0
- package/finance/components/CompanyProfile.tsx +65 -0
- package/finance/components/CryptoScreener.tsx +55 -0
- package/finance/components/Financials.tsx +71 -0
- package/finance/components/ForexScreener.tsx +56 -0
- package/finance/components/MarketOverview.tsx +114 -0
- package/finance/components/NewsTimeline.tsx +54 -0
- package/finance/components/OrderEntry.tsx +157 -0
- package/finance/components/OrdersHistory.tsx +103 -0
- package/finance/components/PositionsList.tsx +85 -0
- package/finance/components/StockScreener.tsx +56 -0
- package/finance/components/SymbolInfo.tsx +62 -0
- package/finance/components/TechnicalAnalysis.tsx +74 -0
- package/finance/components/TickerTape.tsx +66 -0
- package/finance/components/TradingPanel.tsx +238 -0
- package/finance/components/index.ts +40 -0
- package/finance/index.ts +23 -0
- package/package.json +803 -0
- package/style/drawer.css +163 -0
- package/style/globals.css +146 -0
- package/style/libreapps-common.css +31 -0
- package/style/libreapps-default-colors.css +147 -0
- package/style/tailwind.css +200 -0
- package/style/theme-provider.tsx +20 -0
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { Check, ChevronsUpDown } from '@icons';
|
|
3
|
+
import { type ComponentProps, type ReactNode, useMemo, useState } from 'react';
|
|
4
|
+
import Link from '@hanzo/docs-core/link';
|
|
5
|
+
import { usePathname } from '@hanzo/docs-core/framework';
|
|
6
|
+
import { cn } from '@/utils/cn';
|
|
7
|
+
import { isTabActive } from '@/utils/is-active';
|
|
8
|
+
import { useSidebar } from '@/components/sidebar/base';
|
|
9
|
+
import {
|
|
10
|
+
Popover,
|
|
11
|
+
PopoverContent,
|
|
12
|
+
PopoverTrigger,
|
|
13
|
+
} from '@/components/ui/popover';
|
|
14
|
+
import type { SidebarTab } from '.';
|
|
15
|
+
|
|
16
|
+
export interface SidebarTabWithProps extends SidebarTab {
|
|
17
|
+
props?: ComponentProps<'a'>;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export function SidebarTabsDropdown({
|
|
21
|
+
options,
|
|
22
|
+
placeholder,
|
|
23
|
+
...props
|
|
24
|
+
}: {
|
|
25
|
+
placeholder?: ReactNode;
|
|
26
|
+
options: SidebarTabWithProps[];
|
|
27
|
+
} & ComponentProps<'button'>) {
|
|
28
|
+
const [open, setOpen] = useState(false);
|
|
29
|
+
const { closeOnRedirect } = useSidebar();
|
|
30
|
+
const pathname = usePathname();
|
|
31
|
+
|
|
32
|
+
const selected = useMemo(() => {
|
|
33
|
+
return options.findLast((item) => isTabActive(item, pathname));
|
|
34
|
+
}, [options, pathname]);
|
|
35
|
+
|
|
36
|
+
const onClick = () => {
|
|
37
|
+
closeOnRedirect.current = false;
|
|
38
|
+
setOpen(false);
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
const item = selected ? (
|
|
42
|
+
<>
|
|
43
|
+
<div className="size-9 shrink-0 empty:hidden md:size-5">
|
|
44
|
+
{selected.icon}
|
|
45
|
+
</div>
|
|
46
|
+
<div>
|
|
47
|
+
<p className="text-sm font-medium">{selected.title}</p>
|
|
48
|
+
<p className="text-sm text-fd-muted-foreground empty:hidden md:hidden">
|
|
49
|
+
{selected.description}
|
|
50
|
+
</p>
|
|
51
|
+
</div>
|
|
52
|
+
</>
|
|
53
|
+
) : (
|
|
54
|
+
placeholder
|
|
55
|
+
);
|
|
56
|
+
|
|
57
|
+
return (
|
|
58
|
+
<Popover open={open} onOpenChange={setOpen}>
|
|
59
|
+
{item && (
|
|
60
|
+
<PopoverTrigger
|
|
61
|
+
{...props}
|
|
62
|
+
className={cn(
|
|
63
|
+
'flex items-center gap-2 rounded-lg p-2 border bg-fd-secondary/50 text-start text-fd-secondary-foreground transition-colors hover:bg-fd-accent data-[state=open]:bg-fd-accent data-[state=open]:text-fd-accent-foreground',
|
|
64
|
+
props.className,
|
|
65
|
+
)}
|
|
66
|
+
>
|
|
67
|
+
{item}
|
|
68
|
+
<ChevronsUpDown className="shrink-0 ms-auto size-4 text-fd-muted-foreground" />
|
|
69
|
+
</PopoverTrigger>
|
|
70
|
+
)}
|
|
71
|
+
<PopoverContent className="flex flex-col gap-1 w-(--radix-popover-trigger-width) p-1 fd-scroll-container">
|
|
72
|
+
{options.map((item) => {
|
|
73
|
+
const isActive = selected && item.url === selected.url;
|
|
74
|
+
if (!isActive && item.unlisted) return;
|
|
75
|
+
|
|
76
|
+
return (
|
|
77
|
+
<Link
|
|
78
|
+
key={item.url}
|
|
79
|
+
href={item.url}
|
|
80
|
+
onClick={onClick}
|
|
81
|
+
{...item.props}
|
|
82
|
+
className={cn(
|
|
83
|
+
'flex items-center gap-2 rounded-lg p-1.5 hover:bg-fd-accent hover:text-fd-accent-foreground',
|
|
84
|
+
item.props?.className,
|
|
85
|
+
)}
|
|
86
|
+
>
|
|
87
|
+
<div className="shrink-0 size-9 md:mt-1 md:mb-auto md:size-5 empty:hidden">
|
|
88
|
+
{item.icon}
|
|
89
|
+
</div>
|
|
90
|
+
<div>
|
|
91
|
+
<p className="text-sm font-medium">{item.title}</p>
|
|
92
|
+
<p className="text-[0.8125rem] text-fd-muted-foreground empty:hidden">
|
|
93
|
+
{item.description}
|
|
94
|
+
</p>
|
|
95
|
+
</div>
|
|
96
|
+
|
|
97
|
+
<Check
|
|
98
|
+
className={cn(
|
|
99
|
+
'shrink-0 ms-auto size-3.5 text-fd-primary',
|
|
100
|
+
!isActive && 'invisible',
|
|
101
|
+
)}
|
|
102
|
+
/>
|
|
103
|
+
</Link>
|
|
104
|
+
);
|
|
105
|
+
})}
|
|
106
|
+
</PopoverContent>
|
|
107
|
+
</Popover>
|
|
108
|
+
);
|
|
109
|
+
}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import type * as PageTree from '@hanzo/docs-core/page-tree';
|
|
2
|
+
import type { ReactNode } from 'react';
|
|
3
|
+
|
|
4
|
+
export interface SidebarTab {
|
|
5
|
+
/**
|
|
6
|
+
* Redirect URL of the folder, usually the index page
|
|
7
|
+
*/
|
|
8
|
+
url: string;
|
|
9
|
+
|
|
10
|
+
icon?: ReactNode;
|
|
11
|
+
title: ReactNode;
|
|
12
|
+
description?: ReactNode;
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Detect from a list of urls
|
|
16
|
+
*/
|
|
17
|
+
urls?: Set<string>;
|
|
18
|
+
unlisted?: boolean;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export interface GetSidebarTabsOptions {
|
|
22
|
+
transform?: (option: SidebarTab, node: PageTree.Folder) => SidebarTab | null;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
const defaultTransform: GetSidebarTabsOptions['transform'] = (option, node) => {
|
|
26
|
+
if (!node.icon) return option;
|
|
27
|
+
|
|
28
|
+
return {
|
|
29
|
+
...option,
|
|
30
|
+
icon: (
|
|
31
|
+
<div className="size-full [&_svg]:size-full max-md:p-1.5 max-md:rounded-md max-md:border max-md:bg-fd-secondary">
|
|
32
|
+
{node.icon}
|
|
33
|
+
</div>
|
|
34
|
+
),
|
|
35
|
+
};
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
export function getSidebarTabs(
|
|
39
|
+
tree: PageTree.Root,
|
|
40
|
+
{ transform = defaultTransform }: GetSidebarTabsOptions = {},
|
|
41
|
+
): SidebarTab[] {
|
|
42
|
+
const results: SidebarTab[] = [];
|
|
43
|
+
|
|
44
|
+
function scanOptions(
|
|
45
|
+
node: PageTree.Root | PageTree.Folder,
|
|
46
|
+
unlisted?: boolean,
|
|
47
|
+
) {
|
|
48
|
+
if ('root' in node && node.root) {
|
|
49
|
+
const urls = getFolderUrls(node);
|
|
50
|
+
|
|
51
|
+
if (urls.size > 0) {
|
|
52
|
+
const option: SidebarTab = {
|
|
53
|
+
url: urls.values().next().value ?? '',
|
|
54
|
+
title: node.name,
|
|
55
|
+
icon: node.icon,
|
|
56
|
+
unlisted,
|
|
57
|
+
description: node.description,
|
|
58
|
+
urls,
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
const mapped = transform ? transform(option, node) : option;
|
|
62
|
+
if (mapped) results.push(mapped);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
for (const child of node.children) {
|
|
67
|
+
if (child.type === 'folder') scanOptions(child, unlisted);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
scanOptions(tree);
|
|
72
|
+
if (tree.fallback) scanOptions(tree.fallback, true);
|
|
73
|
+
|
|
74
|
+
return results;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
function getFolderUrls(
|
|
78
|
+
folder: PageTree.Folder,
|
|
79
|
+
output: Set<string> = new Set(),
|
|
80
|
+
): Set<string> {
|
|
81
|
+
if (folder.index) output.add(folder.index.url);
|
|
82
|
+
|
|
83
|
+
for (const child of folder.children) {
|
|
84
|
+
if (child.type === 'page' && !child.external) output.add(child.url);
|
|
85
|
+
if (child.type === 'folder') getFolderUrls(child, output);
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
return output;
|
|
89
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ReactNode } from 'react';
|
|
2
|
+
|
|
3
|
+
export function Steps({ children }: { children: ReactNode }) {
|
|
4
|
+
return <div className="fd-steps">{children}</div>;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export function Step({ children }: { children: ReactNode }) {
|
|
8
|
+
return <div className="fd-step">{children}</div>;
|
|
9
|
+
}
|
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
import {
|
|
5
|
+
type ComponentProps,
|
|
6
|
+
createContext,
|
|
7
|
+
type ReactNode,
|
|
8
|
+
useContext,
|
|
9
|
+
useEffect,
|
|
10
|
+
useId,
|
|
11
|
+
useMemo,
|
|
12
|
+
useState,
|
|
13
|
+
} from 'react';
|
|
14
|
+
import { cn } from '@/utils/cn';
|
|
15
|
+
import * as Unstyled from './ui/tabs';
|
|
16
|
+
|
|
17
|
+
type CollectionKey = string | symbol;
|
|
18
|
+
|
|
19
|
+
export interface TabsProps extends Omit<
|
|
20
|
+
ComponentProps<typeof Unstyled.Tabs>,
|
|
21
|
+
'value' | 'onValueChange'
|
|
22
|
+
> {
|
|
23
|
+
/**
|
|
24
|
+
* Use simple mode instead of advanced usage as documented in https://radix-ui.com/primitives/docs/components/tabs.
|
|
25
|
+
*/
|
|
26
|
+
items?: string[];
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Shortcut for `defaultValue` when `items` is provided.
|
|
30
|
+
*
|
|
31
|
+
* @defaultValue 0
|
|
32
|
+
*/
|
|
33
|
+
defaultIndex?: number;
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Additional label in tabs list when `items` is provided.
|
|
37
|
+
*/
|
|
38
|
+
label?: ReactNode;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
const TabsContext = createContext<{
|
|
42
|
+
items?: string[];
|
|
43
|
+
collection: CollectionKey[];
|
|
44
|
+
} | null>(null);
|
|
45
|
+
|
|
46
|
+
function useTabContext() {
|
|
47
|
+
const ctx = useContext(TabsContext);
|
|
48
|
+
if (!ctx) throw new Error('You must wrap your component in <Tabs>');
|
|
49
|
+
return ctx;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
export const TabsList = React.forwardRef<
|
|
53
|
+
React.ComponentRef<typeof Unstyled.TabsList>,
|
|
54
|
+
React.ComponentPropsWithoutRef<typeof Unstyled.TabsList>
|
|
55
|
+
>((props, ref) => (
|
|
56
|
+
<Unstyled.TabsList
|
|
57
|
+
ref={ref}
|
|
58
|
+
{...props}
|
|
59
|
+
className={cn(
|
|
60
|
+
'flex gap-3.5 text-fd-secondary-foreground overflow-x-auto px-4 not-prose',
|
|
61
|
+
props.className,
|
|
62
|
+
)}
|
|
63
|
+
/>
|
|
64
|
+
));
|
|
65
|
+
TabsList.displayName = 'TabsList';
|
|
66
|
+
|
|
67
|
+
export const TabsTrigger = React.forwardRef<
|
|
68
|
+
React.ComponentRef<typeof Unstyled.TabsTrigger>,
|
|
69
|
+
React.ComponentPropsWithoutRef<typeof Unstyled.TabsTrigger>
|
|
70
|
+
>((props, ref) => (
|
|
71
|
+
<Unstyled.TabsTrigger
|
|
72
|
+
ref={ref}
|
|
73
|
+
{...props}
|
|
74
|
+
className={cn(
|
|
75
|
+
'inline-flex items-center gap-2 whitespace-nowrap text-fd-muted-foreground border-b border-transparent py-2 text-sm font-medium transition-colors [&_svg]:size-4 hover:text-fd-accent-foreground disabled:pointer-events-none disabled:opacity-50 data-[state=active]:border-fd-primary data-[state=active]:text-fd-primary',
|
|
76
|
+
props.className,
|
|
77
|
+
)}
|
|
78
|
+
/>
|
|
79
|
+
));
|
|
80
|
+
TabsTrigger.displayName = 'TabsTrigger';
|
|
81
|
+
|
|
82
|
+
export function Tabs({
|
|
83
|
+
ref,
|
|
84
|
+
className,
|
|
85
|
+
items,
|
|
86
|
+
label,
|
|
87
|
+
defaultIndex = 0,
|
|
88
|
+
defaultValue = items ? escapeValue(items[defaultIndex]) : undefined,
|
|
89
|
+
...props
|
|
90
|
+
}: TabsProps) {
|
|
91
|
+
const [value, setValue] = useState(defaultValue);
|
|
92
|
+
const collection = useMemo<CollectionKey[]>(() => [], []);
|
|
93
|
+
|
|
94
|
+
return (
|
|
95
|
+
<Unstyled.Tabs
|
|
96
|
+
ref={ref}
|
|
97
|
+
className={cn(
|
|
98
|
+
'flex flex-col overflow-hidden rounded-xl border bg-fd-secondary my-4',
|
|
99
|
+
className,
|
|
100
|
+
)}
|
|
101
|
+
value={value}
|
|
102
|
+
onValueChange={(v: string) => {
|
|
103
|
+
if (items && !items.some((item) => escapeValue(item) === v)) return;
|
|
104
|
+
setValue(v);
|
|
105
|
+
}}
|
|
106
|
+
{...props}
|
|
107
|
+
>
|
|
108
|
+
{items && (
|
|
109
|
+
<TabsList>
|
|
110
|
+
{label && (
|
|
111
|
+
<span className="text-sm font-medium my-auto me-auto">{label}</span>
|
|
112
|
+
)}
|
|
113
|
+
{items.map((item) => (
|
|
114
|
+
<TabsTrigger key={item} value={escapeValue(item)}>
|
|
115
|
+
{item}
|
|
116
|
+
</TabsTrigger>
|
|
117
|
+
))}
|
|
118
|
+
</TabsList>
|
|
119
|
+
)}
|
|
120
|
+
<TabsContext.Provider
|
|
121
|
+
value={useMemo(() => ({ items, collection }), [collection, items])}
|
|
122
|
+
>
|
|
123
|
+
{props.children}
|
|
124
|
+
</TabsContext.Provider>
|
|
125
|
+
</Unstyled.Tabs>
|
|
126
|
+
);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
export interface TabProps extends Omit<
|
|
130
|
+
ComponentProps<typeof Unstyled.TabsContent>,
|
|
131
|
+
'value'
|
|
132
|
+
> {
|
|
133
|
+
/**
|
|
134
|
+
* Value of tab, detect from index if unspecified.
|
|
135
|
+
*/
|
|
136
|
+
value?: string;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
export function Tab({ value, ...props }: TabProps) {
|
|
140
|
+
const { items } = useTabContext();
|
|
141
|
+
const resolved =
|
|
142
|
+
value ??
|
|
143
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks -- `value` is not supposed to change
|
|
144
|
+
items?.at(useCollectionIndex());
|
|
145
|
+
if (!resolved)
|
|
146
|
+
throw new Error(
|
|
147
|
+
'Failed to resolve tab `value`, please pass a `value` prop to the Tab component.',
|
|
148
|
+
);
|
|
149
|
+
|
|
150
|
+
return (
|
|
151
|
+
<TabsContent value={escapeValue(resolved)} {...props}>
|
|
152
|
+
{props.children}
|
|
153
|
+
</TabsContent>
|
|
154
|
+
);
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
export function TabsContent({
|
|
158
|
+
value,
|
|
159
|
+
className,
|
|
160
|
+
...props
|
|
161
|
+
}: ComponentProps<typeof Unstyled.TabsContent>) {
|
|
162
|
+
return (
|
|
163
|
+
<Unstyled.TabsContent
|
|
164
|
+
value={value}
|
|
165
|
+
forceMount
|
|
166
|
+
className={cn(
|
|
167
|
+
'p-4 text-[0.9375rem] bg-fd-background rounded-xl outline-none prose-no-margin data-[state=inactive]:hidden [&>figure:only-child]:-m-4 [&>figure:only-child]:border-none',
|
|
168
|
+
className,
|
|
169
|
+
)}
|
|
170
|
+
{...props}
|
|
171
|
+
>
|
|
172
|
+
{props.children}
|
|
173
|
+
</Unstyled.TabsContent>
|
|
174
|
+
);
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
/**
|
|
178
|
+
* Inspired by Headless UI.
|
|
179
|
+
*
|
|
180
|
+
* Return the index of children, this is made possible by registering the order of render from children using React context.
|
|
181
|
+
* This is supposed by work with pre-rendering & pure client-side rendering.
|
|
182
|
+
*/
|
|
183
|
+
function useCollectionIndex() {
|
|
184
|
+
const key = useId();
|
|
185
|
+
const { collection } = useTabContext();
|
|
186
|
+
|
|
187
|
+
useEffect(() => {
|
|
188
|
+
return () => {
|
|
189
|
+
const idx = collection.indexOf(key);
|
|
190
|
+
if (idx !== -1) collection.splice(idx, 1);
|
|
191
|
+
};
|
|
192
|
+
}, [key, collection]);
|
|
193
|
+
|
|
194
|
+
if (!collection.includes(key)) collection.push(key);
|
|
195
|
+
return collection.indexOf(key);
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
/**
|
|
199
|
+
* only escape whitespaces in values in simple mode
|
|
200
|
+
*/
|
|
201
|
+
function escapeValue(v: string): string {
|
|
202
|
+
return v.toLowerCase().replace(/\s/, '-');
|
|
203
|
+
}
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import * as Primitive from '@hanzo/docs-core/toc';
|
|
3
|
+
import { type ComponentProps, useEffect, useRef, useState } from 'react';
|
|
4
|
+
import { cn } from '@/utils/cn';
|
|
5
|
+
import { useTOCItems, TocThumb } from '.';
|
|
6
|
+
import { mergeRefs } from '@/utils/merge-refs';
|
|
7
|
+
import { useI18n } from '@/contexts/i18n';
|
|
8
|
+
|
|
9
|
+
export function TOCItems({ ref, className, ...props }: ComponentProps<'div'>) {
|
|
10
|
+
const containerRef = useRef<HTMLDivElement>(null);
|
|
11
|
+
const items = useTOCItems();
|
|
12
|
+
const { text } = useI18n();
|
|
13
|
+
|
|
14
|
+
const [svg, setSvg] = useState<{
|
|
15
|
+
path: string;
|
|
16
|
+
width: number;
|
|
17
|
+
height: number;
|
|
18
|
+
}>();
|
|
19
|
+
|
|
20
|
+
useEffect(() => {
|
|
21
|
+
if (!containerRef.current) return;
|
|
22
|
+
const container = containerRef.current;
|
|
23
|
+
|
|
24
|
+
function onResize(): void {
|
|
25
|
+
if (container.clientHeight === 0) return;
|
|
26
|
+
let w = 0,
|
|
27
|
+
h = 0;
|
|
28
|
+
const d: string[] = [];
|
|
29
|
+
for (let i = 0; i < items.length; i++) {
|
|
30
|
+
const element: HTMLElement | null = container.querySelector(
|
|
31
|
+
`a[href="#${items[i].url.slice(1)}"]`,
|
|
32
|
+
);
|
|
33
|
+
if (!element) continue;
|
|
34
|
+
|
|
35
|
+
const styles = getComputedStyle(element);
|
|
36
|
+
const offset = getLineOffset(items[i].depth) + 1,
|
|
37
|
+
top = element.offsetTop + parseFloat(styles.paddingTop),
|
|
38
|
+
bottom =
|
|
39
|
+
element.offsetTop +
|
|
40
|
+
element.clientHeight -
|
|
41
|
+
parseFloat(styles.paddingBottom);
|
|
42
|
+
|
|
43
|
+
w = Math.max(offset, w);
|
|
44
|
+
h = Math.max(h, bottom);
|
|
45
|
+
|
|
46
|
+
d.push(`${i === 0 ? 'M' : 'L'}${offset} ${top}`);
|
|
47
|
+
d.push(`L${offset} ${bottom}`);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
setSvg({
|
|
51
|
+
path: d.join(' '),
|
|
52
|
+
width: w + 1,
|
|
53
|
+
height: h,
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
const observer = new ResizeObserver(onResize);
|
|
58
|
+
onResize();
|
|
59
|
+
|
|
60
|
+
observer.observe(container);
|
|
61
|
+
return () => {
|
|
62
|
+
observer.disconnect();
|
|
63
|
+
};
|
|
64
|
+
}, [items]);
|
|
65
|
+
|
|
66
|
+
if (items.length === 0)
|
|
67
|
+
return (
|
|
68
|
+
<div className="rounded-lg border bg-fd-card p-3 text-xs text-fd-muted-foreground">
|
|
69
|
+
{text.tocNoHeadings}
|
|
70
|
+
</div>
|
|
71
|
+
);
|
|
72
|
+
|
|
73
|
+
return (
|
|
74
|
+
<>
|
|
75
|
+
{svg && (
|
|
76
|
+
<div
|
|
77
|
+
className="absolute start-0 top-0 rtl:-scale-x-100"
|
|
78
|
+
style={{
|
|
79
|
+
width: svg.width,
|
|
80
|
+
height: svg.height,
|
|
81
|
+
maskImage: `url("data:image/svg+xml,${
|
|
82
|
+
// Inline SVG
|
|
83
|
+
encodeURIComponent(
|
|
84
|
+
`<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 ${svg.width} ${svg.height}"><path d="${svg.path}" stroke="black" stroke-width="1" fill="none" /></svg>`,
|
|
85
|
+
)
|
|
86
|
+
}")`,
|
|
87
|
+
}}
|
|
88
|
+
>
|
|
89
|
+
<TocThumb
|
|
90
|
+
containerRef={containerRef}
|
|
91
|
+
className="mt-(--fd-top) h-(--fd-height) bg-fd-primary transition-all"
|
|
92
|
+
/>
|
|
93
|
+
</div>
|
|
94
|
+
)}
|
|
95
|
+
<div
|
|
96
|
+
ref={mergeRefs(containerRef, ref)}
|
|
97
|
+
className={cn('flex flex-col', className)}
|
|
98
|
+
{...props}
|
|
99
|
+
>
|
|
100
|
+
{items.map((item, i) => (
|
|
101
|
+
<TOCItem
|
|
102
|
+
key={item.url}
|
|
103
|
+
item={item}
|
|
104
|
+
upper={items[i - 1]?.depth}
|
|
105
|
+
lower={items[i + 1]?.depth}
|
|
106
|
+
/>
|
|
107
|
+
))}
|
|
108
|
+
</div>
|
|
109
|
+
</>
|
|
110
|
+
);
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
function getItemOffset(depth: number): number {
|
|
114
|
+
if (depth <= 2) return 14;
|
|
115
|
+
if (depth === 3) return 26;
|
|
116
|
+
return 36;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
function getLineOffset(depth: number): number {
|
|
120
|
+
return depth >= 3 ? 10 : 0;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
function TOCItem({
|
|
124
|
+
item,
|
|
125
|
+
upper = item.depth,
|
|
126
|
+
lower = item.depth,
|
|
127
|
+
}: {
|
|
128
|
+
item: Primitive.TOCItemType;
|
|
129
|
+
upper?: number;
|
|
130
|
+
lower?: number;
|
|
131
|
+
}) {
|
|
132
|
+
const offset = getLineOffset(item.depth),
|
|
133
|
+
upperOffset = getLineOffset(upper),
|
|
134
|
+
lowerOffset = getLineOffset(lower);
|
|
135
|
+
|
|
136
|
+
return (
|
|
137
|
+
<Primitive.TOCItem
|
|
138
|
+
href={item.url}
|
|
139
|
+
style={{
|
|
140
|
+
paddingInlineStart: getItemOffset(item.depth),
|
|
141
|
+
}}
|
|
142
|
+
className="prose relative py-1.5 text-sm text-fd-muted-foreground hover:text-fd-accent-foreground transition-colors wrap-anywhere first:pt-0 last:pb-0 data-[active=true]:text-fd-primary"
|
|
143
|
+
>
|
|
144
|
+
{offset !== upperOffset && (
|
|
145
|
+
<svg
|
|
146
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
147
|
+
viewBox="0 0 16 16"
|
|
148
|
+
className="absolute -top-1.5 start-0 size-4 rtl:-scale-x-100"
|
|
149
|
+
>
|
|
150
|
+
<line
|
|
151
|
+
x1={upperOffset}
|
|
152
|
+
y1="0"
|
|
153
|
+
x2={offset}
|
|
154
|
+
y2="12"
|
|
155
|
+
className="stroke-fd-foreground/10"
|
|
156
|
+
strokeWidth="1"
|
|
157
|
+
/>
|
|
158
|
+
</svg>
|
|
159
|
+
)}
|
|
160
|
+
<div
|
|
161
|
+
className={cn(
|
|
162
|
+
'absolute inset-y-0 w-px bg-fd-foreground/10',
|
|
163
|
+
offset !== upperOffset && 'top-1.5',
|
|
164
|
+
offset !== lowerOffset && 'bottom-1.5',
|
|
165
|
+
)}
|
|
166
|
+
style={{
|
|
167
|
+
insetInlineStart: offset,
|
|
168
|
+
}}
|
|
169
|
+
/>
|
|
170
|
+
{item.title}
|
|
171
|
+
</Primitive.TOCItem>
|
|
172
|
+
);
|
|
173
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { useI18n } from '@/contexts/i18n';
|
|
3
|
+
import { cn } from '@/utils/cn';
|
|
4
|
+
import { mergeRefs } from '@/utils/merge-refs';
|
|
5
|
+
import { type ComponentProps, useRef } from 'react';
|
|
6
|
+
import { useTOCItems, TocThumb } from '.';
|
|
7
|
+
import * as Primitive from '@hanzo/docs-core/toc';
|
|
8
|
+
|
|
9
|
+
export function TOCItems({ ref, className, ...props }: ComponentProps<'div'>) {
|
|
10
|
+
const containerRef = useRef<HTMLDivElement>(null);
|
|
11
|
+
const items = useTOCItems();
|
|
12
|
+
const { text } = useI18n();
|
|
13
|
+
|
|
14
|
+
if (items.length === 0)
|
|
15
|
+
return (
|
|
16
|
+
<div className="rounded-lg border bg-fd-card p-3 text-xs text-fd-muted-foreground">
|
|
17
|
+
{text.tocNoHeadings}
|
|
18
|
+
</div>
|
|
19
|
+
);
|
|
20
|
+
|
|
21
|
+
return (
|
|
22
|
+
<>
|
|
23
|
+
<TocThumb
|
|
24
|
+
containerRef={containerRef}
|
|
25
|
+
className="absolute top-(--fd-top) h-(--fd-height) w-px bg-fd-primary transition-all"
|
|
26
|
+
/>
|
|
27
|
+
<div
|
|
28
|
+
ref={mergeRefs(ref, containerRef)}
|
|
29
|
+
className={cn(
|
|
30
|
+
'flex flex-col border-s border-fd-foreground/10',
|
|
31
|
+
className,
|
|
32
|
+
)}
|
|
33
|
+
{...props}
|
|
34
|
+
>
|
|
35
|
+
{items.map((item) => (
|
|
36
|
+
<TOCItem key={item.url} item={item} />
|
|
37
|
+
))}
|
|
38
|
+
</div>
|
|
39
|
+
</>
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
function TOCItem({ item }: { item: Primitive.TOCItemType }) {
|
|
44
|
+
return (
|
|
45
|
+
<Primitive.TOCItem
|
|
46
|
+
href={item.url}
|
|
47
|
+
className={cn(
|
|
48
|
+
'prose py-1.5 text-sm text-fd-muted-foreground transition-colors wrap-anywhere first:pt-0 last:pb-0 data-[active=true]:text-fd-primary',
|
|
49
|
+
item.depth <= 2 && 'ps-3',
|
|
50
|
+
item.depth === 3 && 'ps-6',
|
|
51
|
+
item.depth >= 4 && 'ps-8',
|
|
52
|
+
)}
|
|
53
|
+
>
|
|
54
|
+
{item.title}
|
|
55
|
+
</Primitive.TOCItem>
|
|
56
|
+
);
|
|
57
|
+
}
|