@contractspec/lib.design-system 1.44.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/LICENSE +21 -0
- package/README.md +133 -0
- package/dist/_virtual/rolldown_runtime.js +37 -0
- package/dist/components/agent/AgentMonitor.d.ts +29 -0
- package/dist/components/agent/AgentMonitor.d.ts.map +1 -0
- package/dist/components/agent/AgentMonitor.js +79 -0
- package/dist/components/agent/AgentMonitor.js.map +1 -0
- package/dist/components/agent/ApprovalQueue.d.ts +26 -0
- package/dist/components/agent/ApprovalQueue.d.ts.map +1 -0
- package/dist/components/agent/ApprovalQueue.js +89 -0
- package/dist/components/agent/ApprovalQueue.js.map +1 -0
- package/dist/components/atoms/ActionButtons.d.ts +26 -0
- package/dist/components/atoms/ActionButtons.d.ts.map +1 -0
- package/dist/components/atoms/ActionButtons.js +98 -0
- package/dist/components/atoms/ActionButtons.js.map +1 -0
- package/dist/components/atoms/Button.d.ts +39 -0
- package/dist/components/atoms/Button.d.ts.map +1 -0
- package/dist/components/atoms/Button.js +34 -0
- package/dist/components/atoms/Button.js.map +1 -0
- package/dist/components/atoms/ButtonLink.d.ts +22 -0
- package/dist/components/atoms/ButtonLink.d.ts.map +1 -0
- package/dist/components/atoms/ButtonLink.js +37 -0
- package/dist/components/atoms/ButtonLink.js.map +1 -0
- package/dist/components/atoms/Cta.d.ts +32 -0
- package/dist/components/atoms/Cta.d.ts.map +1 -0
- package/dist/components/atoms/Cta.js +58 -0
- package/dist/components/atoms/Cta.js.map +1 -0
- package/dist/components/atoms/DataChips.d.ts +38 -0
- package/dist/components/atoms/DataChips.d.ts.map +1 -0
- package/dist/components/atoms/DataChips.js +88 -0
- package/dist/components/atoms/DataChips.js.map +1 -0
- package/dist/components/atoms/EmptyState.d.ts +8 -0
- package/dist/components/atoms/EmptyState.d.ts.map +1 -0
- package/dist/components/atoms/EmptyState.js +14 -0
- package/dist/components/atoms/EmptyState.js.map +1 -0
- package/dist/components/atoms/ErrorState.d.ts +29 -0
- package/dist/components/atoms/ErrorState.d.ts.map +1 -0
- package/dist/components/atoms/ErrorState.js +40 -0
- package/dist/components/atoms/ErrorState.js.map +1 -0
- package/dist/components/atoms/Input.d.ts +36 -0
- package/dist/components/atoms/Input.d.ts.map +1 -0
- package/dist/components/atoms/Input.js +28 -0
- package/dist/components/atoms/Input.js.map +1 -0
- package/dist/components/atoms/Link.d.ts +12 -0
- package/dist/components/atoms/Link.d.ts.map +1 -0
- package/dist/components/atoms/Link.js +14 -0
- package/dist/components/atoms/Link.js.map +1 -0
- package/dist/components/atoms/Link.web.d.ts +20 -0
- package/dist/components/atoms/Link.web.d.ts.map +1 -0
- package/dist/components/atoms/Link.web.js +16 -0
- package/dist/components/atoms/Link.web.js.map +1 -0
- package/dist/components/atoms/LoaderCircular.d.ts +23 -0
- package/dist/components/atoms/LoaderCircular.d.ts.map +1 -0
- package/dist/components/atoms/LoaderCircular.js +44 -0
- package/dist/components/atoms/LoaderCircular.js.map +1 -0
- package/dist/components/atoms/NavBrand.d.ts +19 -0
- package/dist/components/atoms/NavBrand.d.ts.map +1 -0
- package/dist/components/atoms/NavBrand.js +26 -0
- package/dist/components/atoms/NavBrand.js.map +1 -0
- package/dist/components/atoms/Stepper.d.ts +8 -0
- package/dist/components/atoms/Stepper.d.ts.map +1 -0
- package/dist/components/atoms/Stepper.js +14 -0
- package/dist/components/atoms/Stepper.js.map +1 -0
- package/dist/components/atoms/Textarea.d.ts +38 -0
- package/dist/components/atoms/Textarea.d.ts.map +1 -0
- package/dist/components/atoms/Textarea.js +36 -0
- package/dist/components/atoms/Textarea.js.map +1 -0
- package/dist/components/data-view/DataViewDetail.d.ts +22 -0
- package/dist/components/data-view/DataViewDetail.d.ts.map +1 -0
- package/dist/components/data-view/DataViewDetail.js +80 -0
- package/dist/components/data-view/DataViewDetail.js.map +1 -0
- package/dist/components/data-view/DataViewList.d.ts +24 -0
- package/dist/components/data-view/DataViewList.d.ts.map +1 -0
- package/dist/components/data-view/DataViewList.js +67 -0
- package/dist/components/data-view/DataViewList.js.map +1 -0
- package/dist/components/data-view/DataViewRenderer.d.ts +48 -0
- package/dist/components/data-view/DataViewRenderer.d.ts.map +1 -0
- package/dist/components/data-view/DataViewRenderer.js +148 -0
- package/dist/components/data-view/DataViewRenderer.js.map +1 -0
- package/dist/components/data-view/DataViewTable.d.ts +26 -0
- package/dist/components/data-view/DataViewTable.d.ts.map +1 -0
- package/dist/components/data-view/DataViewTable.js +93 -0
- package/dist/components/data-view/DataViewTable.js.map +1 -0
- package/dist/components/data-view/utils.js +43 -0
- package/dist/components/data-view/utils.js.map +1 -0
- package/dist/components/forms/ActionForm.d.ts +17 -0
- package/dist/components/forms/ActionForm.d.ts.map +1 -0
- package/dist/components/forms/ActionForm.js +19 -0
- package/dist/components/forms/ActionForm.js.map +1 -0
- package/dist/components/forms/FormCardLayout.d.ts +23 -0
- package/dist/components/forms/FormCardLayout.d.ts.map +1 -0
- package/dist/components/forms/FormCardLayout.js +28 -0
- package/dist/components/forms/FormCardLayout.js.map +1 -0
- package/dist/components/forms/FormDialog.d.ts +25 -0
- package/dist/components/forms/FormDialog.d.ts.map +1 -0
- package/dist/components/forms/FormDialog.js +25 -0
- package/dist/components/forms/FormDialog.js.map +1 -0
- package/dist/components/forms/FormLayout.d.ts +30 -0
- package/dist/components/forms/FormLayout.d.ts.map +1 -0
- package/dist/components/forms/FormLayout.js +29 -0
- package/dist/components/forms/FormLayout.js.map +1 -0
- package/dist/components/forms/FormOneByOneLayout.d.ts +26 -0
- package/dist/components/forms/FormOneByOneLayout.d.ts.map +1 -0
- package/dist/components/forms/FormOneByOneLayout.js +57 -0
- package/dist/components/forms/FormOneByOneLayout.js.map +1 -0
- package/dist/components/forms/FormStepsLayout.d.ts +27 -0
- package/dist/components/forms/FormStepsLayout.d.ts.map +1 -0
- package/dist/components/forms/FormStepsLayout.js +66 -0
- package/dist/components/forms/FormStepsLayout.js.map +1 -0
- package/dist/components/forms/ZodForm.d.ts +22 -0
- package/dist/components/forms/ZodForm.d.ts.map +1 -0
- package/dist/components/forms/ZodForm.js +25 -0
- package/dist/components/forms/ZodForm.js.map +1 -0
- package/dist/components/legal/atoms/DefinitionList.d.ts +17 -0
- package/dist/components/legal/atoms/DefinitionList.d.ts.map +1 -0
- package/dist/components/legal/atoms/DefinitionList.js +24 -0
- package/dist/components/legal/atoms/DefinitionList.js.map +1 -0
- package/dist/components/legal/atoms/KeyValueList.d.ts +17 -0
- package/dist/components/legal/atoms/KeyValueList.d.ts.map +1 -0
- package/dist/components/legal/atoms/KeyValueList.js +24 -0
- package/dist/components/legal/atoms/KeyValueList.js.map +1 -0
- package/dist/components/legal/atoms/LegalCallout.d.ts +18 -0
- package/dist/components/legal/atoms/LegalCallout.d.ts.map +1 -0
- package/dist/components/legal/atoms/LegalCallout.js +24 -0
- package/dist/components/legal/atoms/LegalCallout.js.map +1 -0
- package/dist/components/legal/atoms/LegalHeading.d.ts +25 -0
- package/dist/components/legal/atoms/LegalHeading.d.ts.map +1 -0
- package/dist/components/legal/atoms/LegalHeading.js +46 -0
- package/dist/components/legal/atoms/LegalHeading.js.map +1 -0
- package/dist/components/legal/atoms/LegalList.d.ts +21 -0
- package/dist/components/legal/atoms/LegalList.d.ts.map +1 -0
- package/dist/components/legal/atoms/LegalList.js +38 -0
- package/dist/components/legal/atoms/LegalList.js.map +1 -0
- package/dist/components/legal/atoms/LegalSection.d.ts +22 -0
- package/dist/components/legal/atoms/LegalSection.d.ts.map +1 -0
- package/dist/components/legal/atoms/LegalSection.js +44 -0
- package/dist/components/legal/atoms/LegalSection.js.map +1 -0
- package/dist/components/legal/atoms/LegalText.d.ts +25 -0
- package/dist/components/legal/atoms/LegalText.d.ts.map +1 -0
- package/dist/components/legal/atoms/LegalText.js +45 -0
- package/dist/components/legal/atoms/LegalText.js.map +1 -0
- package/dist/components/legal/molecules/Consent.d.ts +36 -0
- package/dist/components/legal/molecules/Consent.d.ts.map +1 -0
- package/dist/components/legal/molecules/Consent.js +36 -0
- package/dist/components/legal/molecules/Consent.js.map +1 -0
- package/dist/components/legal/molecules/ContactFields.d.ts +25 -0
- package/dist/components/legal/molecules/ContactFields.d.ts.map +1 -0
- package/dist/components/legal/molecules/ContactFields.js +64 -0
- package/dist/components/legal/molecules/ContactFields.js.map +1 -0
- package/dist/components/legal/molecules/LegalMeta.d.ts +15 -0
- package/dist/components/legal/molecules/LegalMeta.d.ts.map +1 -0
- package/dist/components/legal/molecules/LegalMeta.js +30 -0
- package/dist/components/legal/molecules/LegalMeta.js.map +1 -0
- package/dist/components/legal/molecules/LegalTOC.d.ts +31 -0
- package/dist/components/legal/molecules/LegalTOC.d.ts.map +1 -0
- package/dist/components/legal/molecules/LegalTOC.js +52 -0
- package/dist/components/legal/molecules/LegalTOC.js.map +1 -0
- package/dist/components/legal/organisms/ContactForm.d.ts +30 -0
- package/dist/components/legal/organisms/ContactForm.d.ts.map +1 -0
- package/dist/components/legal/organisms/ContactForm.js +42 -0
- package/dist/components/legal/organisms/ContactForm.js.map +1 -0
- package/dist/components/legal/organisms/GDPRDataRequest.d.ts +19 -0
- package/dist/components/legal/organisms/GDPRDataRequest.d.ts.map +1 -0
- package/dist/components/legal/organisms/GDPRDataRequest.js +53 -0
- package/dist/components/legal/organisms/GDPRDataRequest.js.map +1 -0
- package/dist/components/legal/organisms/GDPRRights.d.ts +14 -0
- package/dist/components/legal/organisms/GDPRRights.d.ts.map +1 -0
- package/dist/components/legal/organisms/GDPRRights.js +30 -0
- package/dist/components/legal/organisms/GDPRRights.js.map +1 -0
- package/dist/components/legal/organisms/LegalPageLayout.d.ts +24 -0
- package/dist/components/legal/organisms/LegalPageLayout.d.ts.map +1 -0
- package/dist/components/legal/organisms/LegalPageLayout.js +51 -0
- package/dist/components/legal/organisms/LegalPageLayout.js.map +1 -0
- package/dist/components/legal/templates/ContactTemplate.d.ts +24 -0
- package/dist/components/legal/templates/ContactTemplate.d.ts.map +1 -0
- package/dist/components/legal/templates/ContactTemplate.js +48 -0
- package/dist/components/legal/templates/ContactTemplate.js.map +1 -0
- package/dist/components/legal/templates/CookiesTemplate.d.ts +33 -0
- package/dist/components/legal/templates/CookiesTemplate.d.ts.map +1 -0
- package/dist/components/legal/templates/CookiesTemplate.js +36 -0
- package/dist/components/legal/templates/CookiesTemplate.js.map +1 -0
- package/dist/components/legal/templates/PrivacyTemplate.d.ts +33 -0
- package/dist/components/legal/templates/PrivacyTemplate.d.ts.map +1 -0
- package/dist/components/legal/templates/PrivacyTemplate.js +40 -0
- package/dist/components/legal/templates/PrivacyTemplate.js.map +1 -0
- package/dist/components/legal/templates/SalesTermsTemplate.d.ts +28 -0
- package/dist/components/legal/templates/SalesTermsTemplate.d.ts.map +1 -0
- package/dist/components/legal/templates/SalesTermsTemplate.js +32 -0
- package/dist/components/legal/templates/SalesTermsTemplate.js.map +1 -0
- package/dist/components/legal/templates/TermsTemplate.d.ts +28 -0
- package/dist/components/legal/templates/TermsTemplate.d.ts.map +1 -0
- package/dist/components/legal/templates/TermsTemplate.js +34 -0
- package/dist/components/legal/templates/TermsTemplate.js.map +1 -0
- package/dist/components/marketing/MarketingCard.d.ts +17 -0
- package/dist/components/marketing/MarketingCard.d.ts.map +1 -0
- package/dist/components/marketing/MarketingCard.js +21 -0
- package/dist/components/marketing/MarketingCard.js.map +1 -0
- package/dist/components/marketing/MarketingCardsSection.d.ts +22 -0
- package/dist/components/marketing/MarketingCardsSection.d.ts.map +1 -0
- package/dist/components/marketing/MarketingCardsSection.js +29 -0
- package/dist/components/marketing/MarketingCardsSection.js.map +1 -0
- package/dist/components/marketing/MarketingComparisonSection.d.ts +30 -0
- package/dist/components/marketing/MarketingComparisonSection.d.ts.map +1 -0
- package/dist/components/marketing/MarketingComparisonSection.js +53 -0
- package/dist/components/marketing/MarketingComparisonSection.js.map +1 -0
- package/dist/components/marketing/MarketingIconCard.d.ts +38 -0
- package/dist/components/marketing/MarketingIconCard.d.ts.map +1 -0
- package/dist/components/marketing/MarketingIconCard.js +74 -0
- package/dist/components/marketing/MarketingIconCard.js.map +1 -0
- package/dist/components/marketing/MarketingSection.d.ts +34 -0
- package/dist/components/marketing/MarketingSection.d.ts.map +1 -0
- package/dist/components/marketing/MarketingSection.js +62 -0
- package/dist/components/marketing/MarketingSection.js.map +1 -0
- package/dist/components/marketing/MarketingStepCard.d.ts +20 -0
- package/dist/components/marketing/MarketingStepCard.d.ts.map +1 -0
- package/dist/components/marketing/MarketingStepCard.js +37 -0
- package/dist/components/marketing/MarketingStepCard.js.map +1 -0
- package/dist/components/molecules/AiLinkButton.d.ts +16 -0
- package/dist/components/molecules/AiLinkButton.d.ts.map +1 -0
- package/dist/components/molecules/AiLinkButton.js +67 -0
- package/dist/components/molecules/AiLinkButton.js.map +1 -0
- package/dist/components/molecules/Breadcrumbs.d.ts +16 -0
- package/dist/components/molecules/Breadcrumbs.d.ts.map +1 -0
- package/dist/components/molecules/Breadcrumbs.js +18 -0
- package/dist/components/molecules/Breadcrumbs.js.map +1 -0
- package/dist/components/molecules/CommandPalette.d.ts +27 -0
- package/dist/components/molecules/CommandPalette.d.ts.map +1 -0
- package/dist/components/molecules/CommandPalette.js +42 -0
- package/dist/components/molecules/CommandPalette.js.map +1 -0
- package/dist/components/molecules/CommandSearchTrigger.d.ts +19 -0
- package/dist/components/molecules/CommandSearchTrigger.d.ts.map +1 -0
- package/dist/components/molecules/CommandSearchTrigger.js +45 -0
- package/dist/components/molecules/CommandSearchTrigger.js.map +1 -0
- package/dist/components/molecules/EntityCard.d.ts +38 -0
- package/dist/components/molecules/EntityCard.d.ts.map +1 -0
- package/dist/components/molecules/EntityCard.js +88 -0
- package/dist/components/molecules/EntityCard.js.map +1 -0
- package/dist/components/molecules/FiltersToolbar.d.ts +36 -0
- package/dist/components/molecules/FiltersToolbar.d.ts.map +1 -0
- package/dist/components/molecules/FiltersToolbar.js +72 -0
- package/dist/components/molecules/FiltersToolbar.js.map +1 -0
- package/dist/components/molecules/HoverPreview.d.ts +21 -0
- package/dist/components/molecules/HoverPreview.d.ts.map +1 -0
- package/dist/components/molecules/HoverPreview.js +26 -0
- package/dist/components/molecules/HoverPreview.js.map +1 -0
- package/dist/components/molecules/LangSwitch.d.ts +23 -0
- package/dist/components/molecules/LangSwitch.d.ts.map +1 -0
- package/dist/components/molecules/LangSwitch.js +22 -0
- package/dist/components/molecules/LangSwitch.js.map +1 -0
- package/dist/components/molecules/LangSwitchDropdown.js +38 -0
- package/dist/components/molecules/LangSwitchDropdown.js.map +1 -0
- package/dist/components/molecules/LoaderBlock.d.ts +19 -0
- package/dist/components/molecules/LoaderBlock.d.ts.map +1 -0
- package/dist/components/molecules/LoaderBlock.js +25 -0
- package/dist/components/molecules/LoaderBlock.js.map +1 -0
- package/dist/components/molecules/MobileNavMenu.js +28 -0
- package/dist/components/molecules/MobileNavMenu.js.map +1 -0
- package/dist/components/molecules/NavItemCard.js +50 -0
- package/dist/components/molecules/NavItemCard.js.map +1 -0
- package/dist/components/molecules/NavMain.d.ts +14 -0
- package/dist/components/molecules/NavMain.d.ts.map +1 -0
- package/dist/components/molecules/NavMain.js +34 -0
- package/dist/components/molecules/NavMain.js.map +1 -0
- package/dist/components/molecules/NavUser.d.ts +18 -0
- package/dist/components/molecules/NavUser.d.ts.map +1 -0
- package/dist/components/molecules/NavUser.js +58 -0
- package/dist/components/molecules/NavUser.js.map +1 -0
- package/dist/components/molecules/OverviewCard.d.ts +21 -0
- package/dist/components/molecules/OverviewCard.d.ts.map +1 -0
- package/dist/components/molecules/OverviewCard.js +37 -0
- package/dist/components/molecules/OverviewCard.js.map +1 -0
- package/dist/components/molecules/SkeletonBlock/index.d.ts +2 -0
- package/dist/components/molecules/SkeletonBlock/index.js +1 -0
- package/dist/components/molecules/SkeletonBlock/index.web.d.ts +13 -0
- package/dist/components/molecules/SkeletonBlock/index.web.d.ts.map +1 -0
- package/dist/components/molecules/SkeletonBlock/index.web.js +13 -0
- package/dist/components/molecules/SkeletonBlock/index.web.js.map +1 -0
- package/dist/components/molecules/SkeletonBlock/types.d.ts +10 -0
- package/dist/components/molecules/SkeletonBlock/types.d.ts.map +1 -0
- package/dist/components/molecules/SkeletonCircle/index.d.ts +2 -0
- package/dist/components/molecules/SkeletonCircle/index.js +1 -0
- package/dist/components/molecules/SkeletonCircle/index.web.d.ts +12 -0
- package/dist/components/molecules/SkeletonCircle/index.web.d.ts.map +1 -0
- package/dist/components/molecules/SkeletonCircle/index.web.js +23 -0
- package/dist/components/molecules/SkeletonCircle/index.web.js.map +1 -0
- package/dist/components/molecules/SkeletonCircle/types.d.ts +9 -0
- package/dist/components/molecules/SkeletonCircle/types.d.ts.map +1 -0
- package/dist/components/molecules/SkeletonList/index.d.ts +2 -0
- package/dist/components/molecules/SkeletonList/index.js +1 -0
- package/dist/components/molecules/SkeletonList/index.web.d.ts +11 -0
- package/dist/components/molecules/SkeletonList/index.web.d.ts.map +1 -0
- package/dist/components/molecules/SkeletonList/index.web.js +15 -0
- package/dist/components/molecules/SkeletonList/index.web.js.map +1 -0
- package/dist/components/molecules/SkeletonList/types.d.ts +8 -0
- package/dist/components/molecules/SkeletonList/types.d.ts.map +1 -0
- package/dist/components/molecules/StatCard.d.ts +37 -0
- package/dist/components/molecules/StatCard.d.ts.map +1 -0
- package/dist/components/molecules/StatCard.js +68 -0
- package/dist/components/molecules/StatCard.js.map +1 -0
- package/dist/components/molecules/StatusChip.d.ts +27 -0
- package/dist/components/molecules/StatusChip.d.ts.map +1 -0
- package/dist/components/molecules/StatusChip.js +56 -0
- package/dist/components/molecules/StatusChip.js.map +1 -0
- package/dist/components/molecules/hover-previews/Doc.d.ts +28 -0
- package/dist/components/molecules/hover-previews/Doc.d.ts.map +1 -0
- package/dist/components/molecules/hover-previews/Doc.js +45 -0
- package/dist/components/molecules/hover-previews/Doc.js.map +1 -0
- package/dist/components/molecules/hover-previews/Media.d.ts +21 -0
- package/dist/components/molecules/hover-previews/Media.d.ts.map +1 -0
- package/dist/components/molecules/hover-previews/Media.js +33 -0
- package/dist/components/molecules/hover-previews/Media.js.map +1 -0
- package/dist/components/molecules/hover-previews/Simple.d.ts +26 -0
- package/dist/components/molecules/hover-previews/Simple.d.ts.map +1 -0
- package/dist/components/molecules/hover-previews/Simple.js +45 -0
- package/dist/components/molecules/hover-previews/Simple.js.map +1 -0
- package/dist/components/molecules/hover-previews/Stats.d.ts +23 -0
- package/dist/components/molecules/hover-previews/Stats.d.ts.map +1 -0
- package/dist/components/molecules/hover-previews/Stats.js +38 -0
- package/dist/components/molecules/hover-previews/Stats.js.map +1 -0
- package/dist/components/molecules/hover-previews/User.d.ts +26 -0
- package/dist/components/molecules/hover-previews/User.d.ts.map +1 -0
- package/dist/components/molecules/hover-previews/User.js +47 -0
- package/dist/components/molecules/hover-previews/User.js.map +1 -0
- package/dist/components/organisms/AcademyLayout.d.ts +30 -0
- package/dist/components/organisms/AcademyLayout.d.ts.map +1 -0
- package/dist/components/organisms/AcademyLayout.js +47 -0
- package/dist/components/organisms/AcademyLayout.js.map +1 -0
- package/dist/components/organisms/AppHeader.d.ts +19 -0
- package/dist/components/organisms/AppHeader.d.ts.map +1 -0
- package/dist/components/organisms/AppHeader.js +31 -0
- package/dist/components/organisms/AppHeader.js.map +1 -0
- package/dist/components/organisms/AppLayout.d.ts +29 -0
- package/dist/components/organisms/AppLayout.d.ts.map +1 -0
- package/dist/components/organisms/AppLayout.js +45 -0
- package/dist/components/organisms/AppLayout.js.map +1 -0
- package/dist/components/organisms/AppSidebar.d.ts +24 -0
- package/dist/components/organisms/AppSidebar.d.ts.map +1 -0
- package/dist/components/organisms/AppSidebar.js +40 -0
- package/dist/components/organisms/AppSidebar.js.map +1 -0
- package/dist/components/organisms/EmptyDataList.d.ts +21 -0
- package/dist/components/organisms/EmptyDataList.d.ts.map +1 -0
- package/dist/components/organisms/EmptyDataList.js +49 -0
- package/dist/components/organisms/EmptyDataList.js.map +1 -0
- package/dist/components/organisms/EmptyDataList.types.d.ts +20 -0
- package/dist/components/organisms/EmptyDataList.types.d.ts.map +1 -0
- package/dist/components/organisms/EmptySearchResult.d.ts +25 -0
- package/dist/components/organisms/EmptySearchResult.d.ts.map +1 -0
- package/dist/components/organisms/EmptySearchResult.js +28 -0
- package/dist/components/organisms/EmptySearchResult.js.map +1 -0
- package/dist/components/organisms/FAQSection.d.ts +32 -0
- package/dist/components/organisms/FAQSection.d.ts.map +1 -0
- package/dist/components/organisms/FAQSection.js +66 -0
- package/dist/components/organisms/FAQSection.js.map +1 -0
- package/dist/components/organisms/FeatureCarousel.d.ts +19 -0
- package/dist/components/organisms/FeatureCarousel.d.ts.map +1 -0
- package/dist/components/organisms/FeatureCarousel.js +35 -0
- package/dist/components/organisms/FeatureCarousel.js.map +1 -0
- package/dist/components/organisms/FeaturesSection.d.ts +20 -0
- package/dist/components/organisms/FeaturesSection.d.ts.map +1 -0
- package/dist/components/organisms/FeaturesSection.js +38 -0
- package/dist/components/organisms/FeaturesSection.js.map +1 -0
- package/dist/components/organisms/Footer.d.ts +26 -0
- package/dist/components/organisms/Footer.d.ts.map +1 -0
- package/dist/components/organisms/Footer.js +53 -0
- package/dist/components/organisms/Footer.js.map +1 -0
- package/dist/components/organisms/Header.d.ts +38 -0
- package/dist/components/organisms/Header.d.ts.map +1 -0
- package/dist/components/organisms/Header.js +100 -0
- package/dist/components/organisms/Header.js.map +1 -0
- package/dist/components/organisms/HeroResponsive.d.ts +15 -0
- package/dist/components/organisms/HeroResponsive.d.ts.map +1 -0
- package/dist/components/organisms/HeroResponsive.js +25 -0
- package/dist/components/organisms/HeroResponsive.js.map +1 -0
- package/dist/components/organisms/HeroSection.d.ts +30 -0
- package/dist/components/organisms/HeroSection.d.ts.map +1 -0
- package/dist/components/organisms/HeroSection.js +31 -0
- package/dist/components/organisms/HeroSection.js.map +1 -0
- package/dist/components/organisms/ListCardPage.d.ts +37 -0
- package/dist/components/organisms/ListCardPage.d.ts.map +1 -0
- package/dist/components/organisms/ListCardPage.js +56 -0
- package/dist/components/organisms/ListCardPage.js.map +1 -0
- package/dist/components/organisms/ListGridPage.d.ts +37 -0
- package/dist/components/organisms/ListGridPage.d.ts.map +1 -0
- package/dist/components/organisms/ListGridPage.js +50 -0
- package/dist/components/organisms/ListGridPage.js.map +1 -0
- package/dist/components/organisms/ListPageResponsive.d.ts +8 -0
- package/dist/components/organisms/ListPageResponsive.d.ts.map +1 -0
- package/dist/components/organisms/ListPageResponsive.js +20 -0
- package/dist/components/organisms/ListPageResponsive.js.map +1 -0
- package/dist/components/organisms/ListTablePage.d.ts +34 -0
- package/dist/components/organisms/ListTablePage.d.ts.map +1 -0
- package/dist/components/organisms/ListTablePage.js +47 -0
- package/dist/components/organisms/ListTablePage.js.map +1 -0
- package/dist/components/organisms/MarketingHeader.d.ts +37 -0
- package/dist/components/organisms/MarketingHeader.d.ts.map +1 -0
- package/dist/components/organisms/MarketingHeader.js +124 -0
- package/dist/components/organisms/MarketingHeader.js.map +1 -0
- package/dist/components/organisms/MarketingHeaderDesktop.d.ts +16 -0
- package/dist/components/organisms/MarketingHeaderDesktop.d.ts.map +1 -0
- package/dist/components/organisms/MarketingHeaderDesktop.js +58 -0
- package/dist/components/organisms/MarketingHeaderDesktop.js.map +1 -0
- package/dist/components/organisms/MarketingHeaderMobile.d.ts +13 -0
- package/dist/components/organisms/MarketingHeaderMobile.d.ts.map +1 -0
- package/dist/components/organisms/MarketingHeaderMobile.js +70 -0
- package/dist/components/organisms/MarketingHeaderMobile.js.map +1 -0
- package/dist/components/organisms/MarketingLayout.d.ts +19 -0
- package/dist/components/organisms/MarketingLayout.d.ts.map +1 -0
- package/dist/components/organisms/MarketingLayout.js +27 -0
- package/dist/components/organisms/MarketingLayout.js.map +1 -0
- package/dist/components/organisms/PageHeaderResponsive.d.ts +9 -0
- package/dist/components/organisms/PageHeaderResponsive.d.ts.map +1 -0
- package/dist/components/organisms/PageHeaderResponsive.js +20 -0
- package/dist/components/organisms/PageHeaderResponsive.js.map +1 -0
- package/dist/components/organisms/PricingCarousel.d.ts +25 -0
- package/dist/components/organisms/PricingCarousel.d.ts.map +1 -0
- package/dist/components/organisms/PricingCarousel.js +60 -0
- package/dist/components/organisms/PricingCarousel.js.map +1 -0
- package/dist/components/organisms/PricingSection.d.ts +19 -0
- package/dist/components/organisms/PricingSection.d.ts.map +1 -0
- package/dist/components/organisms/PricingSection.js +27 -0
- package/dist/components/organisms/PricingSection.js.map +1 -0
- package/dist/components/organisms/TestimonialCarousel.d.ts +20 -0
- package/dist/components/organisms/TestimonialCarousel.d.ts.map +1 -0
- package/dist/components/organisms/TestimonialCarousel.js +38 -0
- package/dist/components/organisms/TestimonialCarousel.js.map +1 -0
- package/dist/components/templates/lists/ListPageTemplate/index.d.ts +2 -0
- package/dist/components/templates/lists/ListPageTemplate/index.js +2 -0
- package/dist/components/templates/lists/ListPageTemplate/index.web.d.ts +23 -0
- package/dist/components/templates/lists/ListPageTemplate/index.web.d.ts.map +1 -0
- package/dist/components/templates/lists/ListPageTemplate/index.web.js +54 -0
- package/dist/components/templates/lists/ListPageTemplate/index.web.js.map +1 -0
- package/dist/components/templates/lists/ListPageTemplate/types.d.ts +26 -0
- package/dist/components/templates/lists/ListPageTemplate/types.d.ts.map +1 -0
- package/dist/components/templates/lists/ListPageTemplate/types.js +1 -0
- package/dist/hooks/useListUrlState.d.ts +31 -0
- package/dist/hooks/useListUrlState.d.ts.map +1 -0
- package/dist/hooks/useListUrlState.js +90 -0
- package/dist/hooks/useListUrlState.js.map +1 -0
- package/dist/index.d.ts +116 -0
- package/dist/index.js +122 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/keyboard.d.ts +13 -0
- package/dist/lib/keyboard.d.ts.map +1 -0
- package/dist/lib/keyboard.js +194 -0
- package/dist/lib/keyboard.js.map +1 -0
- package/dist/lib/utils.js +11 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/platform/useColorScheme.d.ts +6 -0
- package/dist/platform/useColorScheme.d.ts.map +1 -0
- package/dist/platform/useColorScheme.js +21 -0
- package/dist/platform/useColorScheme.js.map +1 -0
- package/dist/platform/useReducedMotion.d.ts +5 -0
- package/dist/platform/useReducedMotion.d.ts.map +1 -0
- package/dist/platform/useReducedMotion.js +21 -0
- package/dist/platform/useReducedMotion.js.map +1 -0
- package/dist/platform/useResponsive.d.ts +24 -0
- package/dist/platform/useResponsive.d.ts.map +1 -0
- package/dist/platform/useResponsive.js +40 -0
- package/dist/platform/useResponsive.js.map +1 -0
- package/dist/platform/withPlatformUI.d.ts +29 -0
- package/dist/platform/withPlatformUI.d.ts.map +1 -0
- package/dist/platform/withPlatformUI.js +31 -0
- package/dist/platform/withPlatformUI.js.map +1 -0
- package/dist/renderers/form-contract.d.ts +12 -0
- package/dist/renderers/form-contract.d.ts.map +1 -0
- package/dist/renderers/form-contract.js +76 -0
- package/dist/renderers/form-contract.js.map +1 -0
- package/dist/renderers/index.d.ts +1 -0
- package/dist/renderers/index.js +1 -0
- package/dist/theme/tokenBridge.d.ts +20 -0
- package/dist/theme/tokenBridge.d.ts.map +1 -0
- package/dist/theme/tokenBridge.js +25 -0
- package/dist/theme/tokenBridge.js.map +1 -0
- package/dist/theme/tokens.d.ts +51 -0
- package/dist/theme/tokens.d.ts.map +1 -0
- package/dist/theme/tokens.js +49 -0
- package/dist/theme/tokens.js.map +1 -0
- package/dist/theme/variants.d.ts +22 -0
- package/dist/theme/variants.d.ts.map +1 -0
- package/dist/theme/variants.js +44 -0
- package/dist/theme/variants.js.map +1 -0
- package/dist/types/navigation.d.ts +45 -0
- package/dist/types/navigation.d.ts.map +1 -0
- package/dist/types/navigation.js +1 -0
- package/package.json +72 -0
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { CtaAction, HeaderNavItem, UserMenuItem } from "../../types/navigation.js";
|
|
2
|
+
import { CommandPalette } from "../molecules/CommandPalette.js";
|
|
3
|
+
import { LangSwitchProps } from "../molecules/LangSwitch.js";
|
|
4
|
+
import * as React from "react";
|
|
5
|
+
import * as react_jsx_runtime27 from "react/jsx-runtime";
|
|
6
|
+
|
|
7
|
+
//#region src/components/organisms/MarketingHeader.d.ts
|
|
8
|
+
interface MarketingHeaderProps {
|
|
9
|
+
logo: React.ReactNode;
|
|
10
|
+
nav?: HeaderNavItem[];
|
|
11
|
+
userMenu?: {
|
|
12
|
+
name?: string;
|
|
13
|
+
email?: string;
|
|
14
|
+
imageUrl?: string;
|
|
15
|
+
items: UserMenuItem[];
|
|
16
|
+
};
|
|
17
|
+
cta?: CtaAction;
|
|
18
|
+
className?: string;
|
|
19
|
+
density?: 'compact' | 'comfortable';
|
|
20
|
+
right?: React.ReactNode;
|
|
21
|
+
commandPaletteGroups: React.ComponentProps<typeof CommandPalette>['groups'];
|
|
22
|
+
langSwitchProps: LangSwitchProps;
|
|
23
|
+
}
|
|
24
|
+
declare function MarketingHeader({
|
|
25
|
+
logo,
|
|
26
|
+
nav,
|
|
27
|
+
userMenu,
|
|
28
|
+
cta,
|
|
29
|
+
className,
|
|
30
|
+
density,
|
|
31
|
+
right,
|
|
32
|
+
commandPaletteGroups,
|
|
33
|
+
langSwitchProps
|
|
34
|
+
}: MarketingHeaderProps): react_jsx_runtime27.JSX.Element;
|
|
35
|
+
//#endregion
|
|
36
|
+
export { MarketingHeader, MarketingHeaderProps };
|
|
37
|
+
//# sourceMappingURL=MarketingHeader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MarketingHeader.d.ts","names":[],"sources":["../../../src/components/organisms/MarketingHeader.tsx"],"sourcesContent":[],"mappings":";;;;;;;UAsCiB,oBAAA;QACT,KAAA,CAAM;QACN;EAFS,QAAA,CAAA,EAAA;IACH,IAAA,CAAA,EAAA,MAAA;IACN,KAAA,CAAA,EAAA,MAAA;IAKG,QAAA,CAAA,EAAA,MAAA;IAEH,KAAA,EAFG,YAEH,EAAA;EAGE,CAAA;EAC0C,GAAA,CAAA,EAJ5C,SAI4C;EAA5B,SAAM,CAAA,EAAA,MAAA;EACX,OAAA,CAAA,EAAA,SAAA,GAAA,aAAA;EAAe,KAAA,CAAA,EAFxB,KAAA,CAAM,SAEkB;EAalB,oBAAe,EAdP,KAAA,CAAM,cAcC,CAAA,OAdqB,cAcrB,CAAA,CAAA,QAAA,CAAA;EAC7B,eAAA,EAdiB,eAcjB;;AAEA,iBAHc,eAAA,CAGd;EAAA,IAAA;EAAA,GAAA;EAAA,QAAA;EAAA,GAAA;EAAA,SAAA;EAAA,OAAA;EAAA,KAAA;EAAA,oBAAA;EAAA;AAAA,CAAA,EAOC,oBAPD,CAAA,EAOqB,mBAAA,CAAA,GAAA,CAAA,OAPrB"}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import { Button } from "../atoms/Button.js";
|
|
4
|
+
import { ButtonLink } from "../atoms/ButtonLink.js";
|
|
5
|
+
import { NavUser } from "../molecules/NavUser.js";
|
|
6
|
+
import { NavItemCard } from "../molecules/NavItemCard.js";
|
|
7
|
+
import { MobileNavMenu } from "../molecules/MobileNavMenu.js";
|
|
8
|
+
import "../molecules/CommandPalette.js";
|
|
9
|
+
import { CommandSearchTrigger } from "../molecules/CommandSearchTrigger.js";
|
|
10
|
+
import { LangSwitchDropdown } from "../molecules/LangSwitchDropdown.js";
|
|
11
|
+
import * as React from "react";
|
|
12
|
+
import { Menu } from "lucide-react";
|
|
13
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
14
|
+
import { cva } from "class-variance-authority";
|
|
15
|
+
import { Box, HStack, VStack } from "@contractspec/lib.ui-kit-web/ui/stack";
|
|
16
|
+
import { Text } from "@contractspec/lib.ui-kit-web/ui/text";
|
|
17
|
+
import { NavigationMenu, NavigationMenuContent, NavigationMenuItem, NavigationMenuLink, NavigationMenuList, NavigationMenuTrigger } from "@contractspec/lib.ui-kit-web/ui/navigation-menu";
|
|
18
|
+
import { cn } from "@contractspec/lib.ui-kit-web/ui/utils";
|
|
19
|
+
import { Sheet, SheetContent, SheetHeader, SheetTrigger } from "@contractspec/lib.ui-kit-web/ui/sheet";
|
|
20
|
+
import { Separator } from "@contractspec/lib.ui-kit-web/ui/separator";
|
|
21
|
+
|
|
22
|
+
//#region src/components/organisms/MarketingHeader.tsx
|
|
23
|
+
const headerVariants = cva("flex items-center justify-between gap-4", {
|
|
24
|
+
variants: { density: {
|
|
25
|
+
compact: "px-3 py-2",
|
|
26
|
+
comfortable: "px-4 py-3"
|
|
27
|
+
} },
|
|
28
|
+
defaultVariants: { density: "comfortable" }
|
|
29
|
+
});
|
|
30
|
+
function MarketingHeader({ logo, nav = [], userMenu, cta, className, density, right, commandPaletteGroups, langSwitchProps }) {
|
|
31
|
+
const [open, setOpen] = React.useState(false);
|
|
32
|
+
return /* @__PURE__ */ jsx(HStack, {
|
|
33
|
+
as: "header",
|
|
34
|
+
className: cn("bg-background/95 supports-backdrop-filter:bg-background/60 sticky top-0 z-50 w-full border-b backdrop-blur-xs", className),
|
|
35
|
+
children: /* @__PURE__ */ jsxs(HStack, {
|
|
36
|
+
className: cn("mx-auto w-full max-w-7xl items-center justify-center", headerVariants({ density })),
|
|
37
|
+
children: [
|
|
38
|
+
/* @__PURE__ */ jsx(VStack, {
|
|
39
|
+
className: "flex items-center gap-2 md:hidden",
|
|
40
|
+
children: /* @__PURE__ */ jsxs(Sheet, {
|
|
41
|
+
open,
|
|
42
|
+
onOpenChange: setOpen,
|
|
43
|
+
children: [/* @__PURE__ */ jsx(SheetTrigger, {
|
|
44
|
+
asChild: true,
|
|
45
|
+
children: /* @__PURE__ */ jsx(Button, {
|
|
46
|
+
variant: "ghost",
|
|
47
|
+
size: "icon",
|
|
48
|
+
"aria-label": "Open menu",
|
|
49
|
+
children: /* @__PURE__ */ jsx(Menu, { className: "h-5 w-5" })
|
|
50
|
+
})
|
|
51
|
+
}), /* @__PURE__ */ jsxs(SheetContent, {
|
|
52
|
+
side: "left",
|
|
53
|
+
className: "w-[320px] p-4",
|
|
54
|
+
children: [
|
|
55
|
+
!!commandPaletteGroups?.length && /* @__PURE__ */ jsx(SheetHeader, { children: /* @__PURE__ */ jsx(CommandSearchTrigger, { groups: commandPaletteGroups }) }),
|
|
56
|
+
cta && /* @__PURE__ */ jsx(VStack, {
|
|
57
|
+
className: "mb-3",
|
|
58
|
+
children: /* @__PURE__ */ jsx(ButtonLink, {
|
|
59
|
+
variant: cta.variant,
|
|
60
|
+
size: cta.size,
|
|
61
|
+
href: cta.href,
|
|
62
|
+
onClick: cta.onClick,
|
|
63
|
+
children: /* @__PURE__ */ jsx(Text, { children: cta.label })
|
|
64
|
+
})
|
|
65
|
+
}),
|
|
66
|
+
/* @__PURE__ */ jsx(MobileNavMenu, { items: nav })
|
|
67
|
+
]
|
|
68
|
+
})]
|
|
69
|
+
})
|
|
70
|
+
}),
|
|
71
|
+
logo,
|
|
72
|
+
/* @__PURE__ */ jsx(HStack, {
|
|
73
|
+
className: "hidden items-center gap-4 md:flex",
|
|
74
|
+
children: nav.length > 0 && /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsx(Separator, {
|
|
75
|
+
orientation: "vertical",
|
|
76
|
+
className: "h-6"
|
|
77
|
+
}), /* @__PURE__ */ jsx(NavigationMenu, {
|
|
78
|
+
className: "hidden md:flex",
|
|
79
|
+
children: /* @__PURE__ */ jsx(NavigationMenuList, { children: nav.map((item) => /* @__PURE__ */ jsx(NavigationMenuItem, { children: item.items && item.items.length > 0 ? /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsx(NavigationMenuTrigger, { children: item.label }), /* @__PURE__ */ jsx(NavigationMenuContent, { children: /* @__PURE__ */ jsx("div", {
|
|
80
|
+
className: "grid w-[760px] grid-cols-3 gap-3 p-3",
|
|
81
|
+
children: item.items.map((link) => /* @__PURE__ */ jsx(NavItemCard, { item: link }, link.href))
|
|
82
|
+
}) })] }) : /* @__PURE__ */ jsx(NavigationMenuLink, {
|
|
83
|
+
href: item.href || "#",
|
|
84
|
+
children: item.label
|
|
85
|
+
}) }, String(item.key ?? item.href ?? item.label))) })
|
|
86
|
+
})] })
|
|
87
|
+
}),
|
|
88
|
+
/* @__PURE__ */ jsxs(HStack, {
|
|
89
|
+
className: "flex items-center gap-2",
|
|
90
|
+
children: [
|
|
91
|
+
!!commandPaletteGroups?.length && /* @__PURE__ */ jsx(Box, {
|
|
92
|
+
className: "hidden items-center gap-2 md:flex",
|
|
93
|
+
children: /* @__PURE__ */ jsx(CommandSearchTrigger, { groups: commandPaletteGroups })
|
|
94
|
+
}),
|
|
95
|
+
!!(langSwitchProps?.options?.length > 1) && /* @__PURE__ */ jsx(LangSwitchDropdown, {
|
|
96
|
+
value: langSwitchProps.value,
|
|
97
|
+
onChange: langSwitchProps.onChange,
|
|
98
|
+
options: langSwitchProps.options
|
|
99
|
+
}),
|
|
100
|
+
right && /* @__PURE__ */ jsx(Box, {
|
|
101
|
+
className: "hidden md:flex",
|
|
102
|
+
children: right
|
|
103
|
+
}),
|
|
104
|
+
cta && /* @__PURE__ */ jsx(Box, {
|
|
105
|
+
className: "hidden md:flex",
|
|
106
|
+
children: /* @__PURE__ */ jsx(ButtonLink, {
|
|
107
|
+
variant: cta.variant,
|
|
108
|
+
size: cta.size,
|
|
109
|
+
href: cta.href,
|
|
110
|
+
onClick: cta.onClick,
|
|
111
|
+
children: /* @__PURE__ */ jsx(Text, { children: cta.label })
|
|
112
|
+
})
|
|
113
|
+
}),
|
|
114
|
+
userMenu && /* @__PURE__ */ jsx(NavUser, { ...userMenu })
|
|
115
|
+
]
|
|
116
|
+
})
|
|
117
|
+
]
|
|
118
|
+
})
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
//#endregion
|
|
123
|
+
export { MarketingHeader };
|
|
124
|
+
//# sourceMappingURL=MarketingHeader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MarketingHeader.js","names":["Nav","NavList","NavItem","NavTrigger","NavContent","NavLink"],"sources":["../../../src/components/organisms/MarketingHeader.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { cn } from '@contractspec/lib.ui-kit-web/ui/utils';\nimport { Button } from '../atoms/Button';\nimport { ButtonLink } from '../atoms/ButtonLink';\nimport {\n NavigationMenu as Nav,\n NavigationMenuContent as NavContent,\n NavigationMenuItem as NavItem,\n NavigationMenuLink as NavLink,\n NavigationMenuList as NavList,\n NavigationMenuTrigger as NavTrigger,\n} from '@contractspec/lib.ui-kit-web/ui/navigation-menu';\nimport { Separator } from '@contractspec/lib.ui-kit-web/ui/separator';\nimport {\n Sheet,\n SheetContent,\n SheetHeader,\n SheetTrigger,\n} from '@contractspec/lib.ui-kit-web/ui/sheet';\nimport { Menu } from 'lucide-react';\nimport { MobileNavMenu } from '../molecules/MobileNavMenu';\nimport { CommandSearchTrigger } from '../molecules/CommandSearchTrigger';\nimport { LangSwitchDropdown } from '../molecules/LangSwitchDropdown';\nimport type {\n CtaAction,\n HeaderNavItem,\n UserMenuItem,\n} from '../../types/navigation';\nimport { NavUser } from '../molecules/NavUser';\nimport { cva } from 'class-variance-authority';\nimport { NavItemCard } from '../molecules/NavItemCard';\nimport { Box, HStack, VStack } from '@contractspec/lib.ui-kit-web/ui/stack';\nimport { CommandPalette } from '../molecules/CommandPalette';\nimport type { LangSwitchProps } from '../molecules/LangSwitch';\nimport { Text } from '@contractspec/lib.ui-kit-web/ui/text';\n\nexport interface MarketingHeaderProps {\n logo: React.ReactNode;\n nav?: HeaderNavItem[];\n userMenu?: {\n name?: string;\n email?: string;\n imageUrl?: string;\n items: UserMenuItem[];\n };\n cta?: CtaAction;\n className?: string;\n density?: 'compact' | 'comfortable';\n right?: React.ReactNode; // e.g. AI link button, extra actions\n commandPaletteGroups: React.ComponentProps<typeof CommandPalette>['groups'];\n langSwitchProps: LangSwitchProps;\n}\n\nconst headerVariants = cva('flex items-center justify-between gap-4', {\n variants: {\n density: {\n compact: 'px-3 py-2',\n comfortable: 'px-4 py-3',\n },\n },\n defaultVariants: { density: 'comfortable' },\n});\n\nexport function MarketingHeader({\n logo,\n nav = [],\n userMenu,\n cta,\n className,\n density,\n right,\n commandPaletteGroups,\n langSwitchProps,\n}: MarketingHeaderProps) {\n const [open, setOpen] = React.useState(false);\n return (\n <HStack\n as=\"header\"\n className={cn(\n 'bg-background/95 supports-backdrop-filter:bg-background/60 sticky top-0 z-50 w-full border-b backdrop-blur-xs',\n className\n )}\n >\n <HStack\n className={cn(\n 'mx-auto w-full max-w-7xl items-center justify-center',\n headerVariants({ density })\n )}\n >\n {/* Mobile: compact left cluster */}\n <VStack className=\"flex items-center gap-2 md:hidden\">\n {/* Menu trigger (sheet) */}\n <Sheet open={open} onOpenChange={setOpen}>\n <SheetTrigger asChild>\n <Button variant=\"ghost\" size=\"icon\" aria-label=\"Open menu\">\n <Menu className=\"h-5 w-5\" />\n </Button>\n </SheetTrigger>\n\n <SheetContent side=\"left\" className=\"w-[320px] p-4\">\n {!!commandPaletteGroups?.length && (\n <SheetHeader>\n <CommandSearchTrigger groups={commandPaletteGroups} />\n {/*<SheetTitle>Menu</SheetTitle>*/}\n </SheetHeader>\n )}\n\n {cta && (\n <VStack className=\"mb-3\">\n <ButtonLink\n variant={cta.variant}\n size={cta.size}\n href={cta.href}\n onClick={cta.onClick}\n >\n <Text>{cta.label}</Text>\n </ButtonLink>\n </VStack>\n )}\n\n <MobileNavMenu items={nav} />\n </SheetContent>\n </Sheet>\n </VStack>\n\n {logo}\n\n {/* Desktop navigation */}\n <HStack className=\"hidden items-center gap-4 md:flex\">\n {nav.length > 0 && (\n <>\n <Separator orientation=\"vertical\" className=\"h-6\" />\n <Nav className=\"hidden md:flex\">\n <NavList>\n {nav.map((item) => (\n <NavItem key={String(item.key ?? item.href ?? item.label)}>\n {item.items && item.items.length > 0 ? (\n <>\n <NavTrigger>{item.label}</NavTrigger>\n <NavContent>\n <div className=\"grid w-[760px] grid-cols-3 gap-3 p-3\">\n {item.items.map((link) => (\n <NavItemCard key={link.href} item={link} />\n ))}\n </div>\n </NavContent>\n </>\n ) : (\n <NavLink href={item.href || '#'}>{item.label}</NavLink>\n )}\n </NavItem>\n ))}\n </NavList>\n </Nav>\n </>\n )}\n </HStack>\n\n <HStack className=\"flex items-center gap-2\">\n {/* Desktop: show search trigger and custom right slot */}\n {!!commandPaletteGroups?.length && (\n <Box className=\"hidden items-center gap-2 md:flex\">\n <CommandSearchTrigger groups={commandPaletteGroups} />\n </Box>\n )}\n\n {!!(langSwitchProps?.options?.length > 1) && (\n <LangSwitchDropdown\n value={langSwitchProps.value}\n onChange={langSwitchProps.onChange}\n options={langSwitchProps.options}\n />\n )}\n\n {right && <Box className=\"hidden md:flex\">{right}</Box>}\n\n {cta && (\n <Box className=\"hidden md:flex\">\n <ButtonLink\n variant={cta.variant}\n size={cta.size}\n href={cta.href}\n onClick={cta.onClick}\n >\n <Text>{cta.label}</Text>\n </ButtonLink>\n </Box>\n )}\n\n {userMenu && <NavUser {...userMenu} />}\n </HStack>\n </HStack>\n </HStack>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAuDA,MAAM,iBAAiB,IAAI,2CAA2C;CACpE,UAAU,EACR,SAAS;EACP,SAAS;EACT,aAAa;EACd,EACF;CACD,iBAAiB,EAAE,SAAS,eAAe;CAC5C,CAAC;AAEF,SAAgB,gBAAgB,EAC9B,MACA,MAAM,EAAE,EACR,UACA,KACA,WACA,SACA,OACA,sBACA,mBACuB;CACvB,MAAM,CAAC,MAAM,WAAW,MAAM,SAAS,MAAM;AAC7C,QACE,oBAAC;EACC,IAAG;EACH,WAAW,GACT,iHACA,UACD;YAED,qBAAC;GACC,WAAW,GACT,wDACA,eAAe,EAAE,SAAS,CAAC,CAC5B;;IAGD,oBAAC;KAAO,WAAU;eAEhB,qBAAC;MAAY;MAAM,cAAc;iBAC/B,oBAAC;OAAa;iBACZ,oBAAC;QAAO,SAAQ;QAAQ,MAAK;QAAO,cAAW;kBAC7C,oBAAC,QAAK,WAAU,YAAY;SACrB;QACI,EAEf,qBAAC;OAAa,MAAK;OAAO,WAAU;;QACjC,CAAC,CAAC,sBAAsB,UACvB,oBAAC,yBACC,oBAAC,wBAAqB,QAAQ,uBAAwB,GAE1C;QAGf,OACC,oBAAC;SAAO,WAAU;mBAChB,oBAAC;UACC,SAAS,IAAI;UACb,MAAM,IAAI;UACV,MAAM,IAAI;UACV,SAAS,IAAI;oBAEb,oBAAC,kBAAM,IAAI,QAAa;WACb;UACN;QAGX,oBAAC,iBAAc,OAAO,MAAO;;QAChB;OACT;MACD;IAER;IAGD,oBAAC;KAAO,WAAU;eACf,IAAI,SAAS,KACZ,4CACE,oBAAC;MAAU,aAAY;MAAW,WAAU;OAAQ,EACpD,oBAACA;MAAI,WAAU;gBACb,oBAACC,gCACE,IAAI,KAAK,SACR,oBAACC,gCACE,KAAK,SAAS,KAAK,MAAM,SAAS,IACjC,4CACE,oBAACC,mCAAY,KAAK,QAAmB,EACrC,oBAACC,mCACC,oBAAC;OAAI,WAAU;iBACZ,KAAK,MAAM,KAAK,SACf,oBAAC,eAA4B,MAAM,QAAjB,KAAK,KAAoB,CAC3C;QACE,GACK,IACZ,GAEH,oBAACC;OAAQ,MAAM,KAAK,QAAQ;iBAAM,KAAK;QAAgB,IAb7C,OAAO,KAAK,OAAO,KAAK,QAAQ,KAAK,MAAM,CAe/C,CACV,GACM;OACN,IACL;MAEE;IAET,qBAAC;KAAO,WAAU;;MAEf,CAAC,CAAC,sBAAsB,UACvB,oBAAC;OAAI,WAAU;iBACb,oBAAC,wBAAqB,QAAQ,uBAAwB;QAClD;MAGP,CAAC,EAAE,iBAAiB,SAAS,SAAS,MACrC,oBAAC;OACC,OAAO,gBAAgB;OACvB,UAAU,gBAAgB;OAC1B,SAAS,gBAAgB;QACzB;MAGH,SAAS,oBAAC;OAAI,WAAU;iBAAkB;QAAY;MAEtD,OACC,oBAAC;OAAI,WAAU;iBACb,oBAAC;QACC,SAAS,IAAI;QACb,MAAM,IAAI;QACV,MAAM,IAAI;QACV,SAAS,IAAI;kBAEb,oBAAC,kBAAM,IAAI,QAAa;SACb;QACT;MAGP,YAAY,oBAAC,WAAQ,GAAI,WAAY;;MAC/B;;IACF;GACF"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { MarketingHeaderProps } from "./MarketingHeader.js";
|
|
2
|
+
import * as react_jsx_runtime28 from "react/jsx-runtime";
|
|
3
|
+
|
|
4
|
+
//#region src/components/organisms/MarketingHeaderDesktop.d.ts
|
|
5
|
+
declare function MarketingHeaderDesktop({
|
|
6
|
+
logo,
|
|
7
|
+
nav,
|
|
8
|
+
userMenu,
|
|
9
|
+
cta,
|
|
10
|
+
className,
|
|
11
|
+
density,
|
|
12
|
+
right
|
|
13
|
+
}: MarketingHeaderProps): react_jsx_runtime28.JSX.Element;
|
|
14
|
+
//#endregion
|
|
15
|
+
export { MarketingHeaderDesktop };
|
|
16
|
+
//# sourceMappingURL=MarketingHeaderDesktop.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MarketingHeaderDesktop.d.ts","names":[],"sources":["../../../src/components/organisms/MarketingHeaderDesktop.tsx"],"sourcesContent":[],"mappings":";;;;iBAgCgB,sBAAA;;;;;;;;GAQb,uBAAoB,mBAAA,CAAA,GAAA,CAAA"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import { ButtonLink } from "../atoms/ButtonLink.js";
|
|
4
|
+
import { NavUser } from "../molecules/NavUser.js";
|
|
5
|
+
import { NavItemCard } from "../molecules/NavItemCard.js";
|
|
6
|
+
import "react";
|
|
7
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
8
|
+
import { cva } from "class-variance-authority";
|
|
9
|
+
import { NavigationMenu, NavigationMenuContent, NavigationMenuItem, NavigationMenuLink, NavigationMenuList, NavigationMenuTrigger } from "@contractspec/lib.ui-kit-web/ui/navigation-menu";
|
|
10
|
+
import { cn } from "@contractspec/lib.ui-kit-web/ui/utils";
|
|
11
|
+
import { Separator } from "@contractspec/lib.ui-kit-web/ui/separator";
|
|
12
|
+
|
|
13
|
+
//#region src/components/organisms/MarketingHeaderDesktop.tsx
|
|
14
|
+
const headerVariants = cva("hidden items-center justify-between gap-4 md:flex", {
|
|
15
|
+
variants: { density: {
|
|
16
|
+
compact: "px-3 py-2",
|
|
17
|
+
comfortable: "px-4 py-3"
|
|
18
|
+
} },
|
|
19
|
+
defaultVariants: { density: "comfortable" }
|
|
20
|
+
});
|
|
21
|
+
function MarketingHeaderDesktop({ logo, nav = [], userMenu, cta, className, density, right }) {
|
|
22
|
+
return /* @__PURE__ */ jsx("div", {
|
|
23
|
+
className: cn("bg-background/95 supports-backdrop-filter:bg-background/60 w-full border-b backdrop-blur-xs", className),
|
|
24
|
+
children: /* @__PURE__ */ jsxs("div", {
|
|
25
|
+
className: cn("mx-auto w-full max-w-7xl", headerVariants({ density })),
|
|
26
|
+
children: [/* @__PURE__ */ jsxs("div", {
|
|
27
|
+
className: "flex items-center gap-4",
|
|
28
|
+
children: [logo, nav.length > 0 && /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsx(Separator, {
|
|
29
|
+
orientation: "vertical",
|
|
30
|
+
className: "h-6"
|
|
31
|
+
}), /* @__PURE__ */ jsx(NavigationMenu, { children: /* @__PURE__ */ jsx(NavigationMenuList, { children: nav.map((item) => /* @__PURE__ */ jsx(NavigationMenuItem, { children: item.items && item.items.length > 0 ? /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsx(NavigationMenuTrigger, { children: item.label }), /* @__PURE__ */ jsx(NavigationMenuContent, { children: /* @__PURE__ */ jsx("div", {
|
|
32
|
+
className: "grid w-[760px] grid-cols-3 gap-3 p-3",
|
|
33
|
+
children: item.items.map((link) => /* @__PURE__ */ jsx(NavItemCard, { item: link }, link.href))
|
|
34
|
+
}) })] }) : /* @__PURE__ */ jsx(NavigationMenuLink, {
|
|
35
|
+
href: item.href || "#",
|
|
36
|
+
children: item.label
|
|
37
|
+
}) }, String(item.key ?? item.href ?? item.label))) }) })] })]
|
|
38
|
+
}), /* @__PURE__ */ jsxs("div", {
|
|
39
|
+
className: "flex items-center gap-2",
|
|
40
|
+
children: [
|
|
41
|
+
right,
|
|
42
|
+
cta && /* @__PURE__ */ jsx(ButtonLink, {
|
|
43
|
+
variant: cta.variant,
|
|
44
|
+
size: cta.size,
|
|
45
|
+
href: cta.href,
|
|
46
|
+
onClick: cta.onClick,
|
|
47
|
+
children: cta.label
|
|
48
|
+
}),
|
|
49
|
+
userMenu && /* @__PURE__ */ jsx(NavUser, { ...userMenu })
|
|
50
|
+
]
|
|
51
|
+
})]
|
|
52
|
+
})
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
//#endregion
|
|
57
|
+
export { MarketingHeaderDesktop };
|
|
58
|
+
//# sourceMappingURL=MarketingHeaderDesktop.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MarketingHeaderDesktop.js","names":["Nav","NavList","NavItem","NavTrigger","NavContent","NavLink"],"sources":["../../../src/components/organisms/MarketingHeaderDesktop.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { cn } from '@contractspec/lib.ui-kit-web/ui/utils';\nimport {\n NavigationMenu as Nav,\n NavigationMenuContent as NavContent,\n NavigationMenuItem as NavItem,\n NavigationMenuLink as NavLink,\n NavigationMenuList as NavList,\n NavigationMenuTrigger as NavTrigger,\n} from '@contractspec/lib.ui-kit-web/ui/navigation-menu';\nimport { Separator } from '@contractspec/lib.ui-kit-web/ui/separator';\nimport type { MarketingHeaderProps } from './MarketingHeader';\nimport { cva } from 'class-variance-authority';\nimport { NavUser } from '../molecules/NavUser';\nimport { NavItemCard } from '../molecules/NavItemCard';\nimport { ButtonLink } from '../atoms/ButtonLink';\n\nconst headerVariants = cva(\n 'hidden items-center justify-between gap-4 md:flex',\n {\n variants: {\n density: {\n compact: 'px-3 py-2',\n comfortable: 'px-4 py-3',\n },\n },\n defaultVariants: { density: 'comfortable' },\n }\n);\n\nexport function MarketingHeaderDesktop({\n logo,\n nav = [],\n userMenu,\n cta,\n className,\n density,\n right,\n}: MarketingHeaderProps) {\n return (\n <div\n className={cn(\n 'bg-background/95 supports-backdrop-filter:bg-background/60 w-full border-b backdrop-blur-xs',\n className\n )}\n >\n <div\n className={cn('mx-auto w-full max-w-7xl', headerVariants({ density }))}\n >\n <div className=\"flex items-center gap-4\">\n {logo}\n {nav.length > 0 && (\n <>\n <Separator orientation=\"vertical\" className=\"h-6\" />\n <Nav>\n <NavList>\n {nav.map((item) => (\n <NavItem key={String(item.key ?? item.href ?? item.label)}>\n {item.items && item.items.length > 0 ? (\n <>\n <NavTrigger>{item.label}</NavTrigger>\n <NavContent>\n <div className=\"grid w-[760px] grid-cols-3 gap-3 p-3\">\n {item.items.map((link) => (\n <NavItemCard key={link.href} item={link} />\n ))}\n </div>\n </NavContent>\n </>\n ) : (\n <NavLink href={item.href || '#'}>{item.label}</NavLink>\n )}\n </NavItem>\n ))}\n </NavList>\n </Nav>\n </>\n )}\n </div>\n\n <div className=\"flex items-center gap-2\">\n {right}\n {cta && (\n <ButtonLink\n variant={cta.variant}\n size={cta.size}\n href={cta.href}\n onClick={cta.onClick}\n >\n {cta.label}\n </ButtonLink>\n )}\n {userMenu && <NavUser {...userMenu} />}\n </div>\n </div>\n </div>\n );\n}\n"],"mappings":";;;;;;;;;;;;;AAmBA,MAAM,iBAAiB,IACrB,qDACA;CACE,UAAU,EACR,SAAS;EACP,SAAS;EACT,aAAa;EACd,EACF;CACD,iBAAiB,EAAE,SAAS,eAAe;CAC5C,CACF;AAED,SAAgB,uBAAuB,EACrC,MACA,MAAM,EAAE,EACR,UACA,KACA,WACA,SACA,SACuB;AACvB,QACE,oBAAC;EACC,WAAW,GACT,+FACA,UACD;YAED,qBAAC;GACC,WAAW,GAAG,4BAA4B,eAAe,EAAE,SAAS,CAAC,CAAC;cAEtE,qBAAC;IAAI,WAAU;eACZ,MACA,IAAI,SAAS,KACZ,4CACE,oBAAC;KAAU,aAAY;KAAW,WAAU;MAAQ,EACpD,oBAACA,4BACC,oBAACC,gCACE,IAAI,KAAK,SACR,oBAACC,gCACE,KAAK,SAAS,KAAK,MAAM,SAAS,IACjC,4CACE,oBAACC,mCAAY,KAAK,QAAmB,EACrC,oBAACC,mCACC,oBAAC;KAAI,WAAU;eACZ,KAAK,MAAM,KAAK,SACf,oBAAC,eAA4B,MAAM,QAAjB,KAAK,KAAoB,CAC3C;MACE,GACK,IACZ,GAEH,oBAACC;KAAQ,MAAM,KAAK,QAAQ;eAAM,KAAK;MAAgB,IAb7C,OAAO,KAAK,OAAO,KAAK,QAAQ,KAAK,MAAM,CAe/C,CACV,GACM,GACN,IACL;KAED,EAEN,qBAAC;IAAI,WAAU;;KACZ;KACA,OACC,oBAAC;MACC,SAAS,IAAI;MACb,MAAM,IAAI;MACV,MAAM,IAAI;MACV,SAAS,IAAI;gBAEZ,IAAI;OACM;KAEd,YAAY,oBAAC,WAAQ,GAAI,WAAY;;KAClC;IACF;GACF"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { MarketingHeaderProps } from "./MarketingHeader.js";
|
|
2
|
+
import * as react_jsx_runtime29 from "react/jsx-runtime";
|
|
3
|
+
|
|
4
|
+
//#region src/components/organisms/MarketingHeaderMobile.d.ts
|
|
5
|
+
declare function MarketingHeaderMobile({
|
|
6
|
+
logo,
|
|
7
|
+
nav,
|
|
8
|
+
className,
|
|
9
|
+
right
|
|
10
|
+
}: MarketingHeaderProps): react_jsx_runtime29.JSX.Element;
|
|
11
|
+
//#endregion
|
|
12
|
+
export { MarketingHeaderMobile };
|
|
13
|
+
//# sourceMappingURL=MarketingHeaderMobile.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MarketingHeaderMobile.d.ts","names":[],"sources":["../../../src/components/organisms/MarketingHeaderMobile.tsx"],"sourcesContent":[],"mappings":";;;;iBAqBgB,qBAAA;;;;;GAKb,uBAAoB,mBAAA,CAAA,GAAA,CAAA"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import { Button } from "../atoms/Button.js";
|
|
4
|
+
import { MobileNavMenu } from "../molecules/MobileNavMenu.js";
|
|
5
|
+
import { CommandSearchTrigger } from "../molecules/CommandSearchTrigger.js";
|
|
6
|
+
import { LangSwitchDropdown } from "../molecules/LangSwitchDropdown.js";
|
|
7
|
+
import * as React from "react";
|
|
8
|
+
import { Menu } from "lucide-react";
|
|
9
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
10
|
+
import { VStack } from "@contractspec/lib.ui-kit-web/ui/stack";
|
|
11
|
+
import { cn } from "@contractspec/lib.ui-kit-web/ui/utils";
|
|
12
|
+
import { Sheet, SheetContent, SheetDescription, SheetFooter, SheetHeader, SheetTitle, SheetTrigger } from "@contractspec/lib.ui-kit-web/ui/sheet";
|
|
13
|
+
|
|
14
|
+
//#region src/components/organisms/MarketingHeaderMobile.tsx
|
|
15
|
+
function MarketingHeaderMobile({ logo, nav = [], className, right }) {
|
|
16
|
+
const [open, setOpen] = React.useState(false);
|
|
17
|
+
return /* @__PURE__ */ jsx("div", {
|
|
18
|
+
className: cn("bg-background/95 supports-backdrop-filter:bg-background/60 w-full border-b backdrop-blur-xs md:hidden", className),
|
|
19
|
+
children: /* @__PURE__ */ jsxs("div", {
|
|
20
|
+
className: "mx-auto flex w-full max-w-7xl items-center justify-between px-3 py-2",
|
|
21
|
+
children: [/* @__PURE__ */ jsxs("div", {
|
|
22
|
+
className: "flex items-center gap-2",
|
|
23
|
+
children: [/* @__PURE__ */ jsxs(Sheet, {
|
|
24
|
+
open,
|
|
25
|
+
onOpenChange: setOpen,
|
|
26
|
+
children: [/* @__PURE__ */ jsx(SheetTrigger, {
|
|
27
|
+
asChild: true,
|
|
28
|
+
children: /* @__PURE__ */ jsx(Button, {
|
|
29
|
+
variant: "ghost",
|
|
30
|
+
size: "icon",
|
|
31
|
+
"aria-label": "Open menu",
|
|
32
|
+
children: /* @__PURE__ */ jsx(Menu, { className: "h-5 w-5" })
|
|
33
|
+
})
|
|
34
|
+
}), /* @__PURE__ */ jsxs(SheetContent, {
|
|
35
|
+
side: "left",
|
|
36
|
+
className: "w-[320px] p-4",
|
|
37
|
+
children: [
|
|
38
|
+
/* @__PURE__ */ jsxs(SheetHeader, { children: [/* @__PURE__ */ jsx(SheetTitle, { children: "Menu" }), /* @__PURE__ */ jsxs(SheetDescription, { children: [/* @__PURE__ */ jsx("div", {
|
|
39
|
+
className: "mb-3",
|
|
40
|
+
children: /* @__PURE__ */ jsx(CommandSearchTrigger, {
|
|
41
|
+
groups: [],
|
|
42
|
+
compact: true
|
|
43
|
+
})
|
|
44
|
+
}), /* @__PURE__ */ jsx(MobileNavMenu, { items: nav })] })] }),
|
|
45
|
+
/* @__PURE__ */ jsx(VStack, { children: /* @__PURE__ */ jsx(MobileNavMenu, { items: nav }) }),
|
|
46
|
+
/* @__PURE__ */ jsx(SheetFooter, { children: right })
|
|
47
|
+
]
|
|
48
|
+
})]
|
|
49
|
+
}), logo]
|
|
50
|
+
}), /* @__PURE__ */ jsx("div", {
|
|
51
|
+
className: "flex items-center gap-2",
|
|
52
|
+
children: /* @__PURE__ */ jsx(LangSwitchDropdown, {
|
|
53
|
+
value: "en",
|
|
54
|
+
options: [{
|
|
55
|
+
code: "fr",
|
|
56
|
+
label: "FR"
|
|
57
|
+
}, {
|
|
58
|
+
code: "en",
|
|
59
|
+
label: "EN"
|
|
60
|
+
}],
|
|
61
|
+
onChange: () => {}
|
|
62
|
+
})
|
|
63
|
+
})]
|
|
64
|
+
})
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
//#endregion
|
|
69
|
+
export { MarketingHeaderMobile };
|
|
70
|
+
//# sourceMappingURL=MarketingHeaderMobile.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MarketingHeaderMobile.js","names":[],"sources":["../../../src/components/organisms/MarketingHeaderMobile.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { cn } from '@contractspec/lib.ui-kit-web/ui/utils';\nimport { Button } from '../atoms/Button';\nimport {\n Sheet,\n SheetContent,\n SheetTrigger,\n SheetTitle,\n SheetHeader,\n SheetFooter,\n SheetDescription,\n} from '@contractspec/lib.ui-kit-web/ui/sheet';\nimport { Menu } from 'lucide-react';\nimport type { MarketingHeaderProps } from './MarketingHeader';\nimport { MobileNavMenu } from '../molecules/MobileNavMenu';\nimport { CommandSearchTrigger } from '../molecules/CommandSearchTrigger';\nimport { LangSwitchDropdown } from '../molecules/LangSwitchDropdown';\nimport { VStack } from '@contractspec/lib.ui-kit-web/ui/stack';\n\nexport function MarketingHeaderMobile({\n logo,\n nav = [],\n className,\n right,\n}: MarketingHeaderProps) {\n const [open, setOpen] = React.useState(false);\n return (\n <div\n className={cn(\n 'bg-background/95 supports-backdrop-filter:bg-background/60 w-full border-b backdrop-blur-xs md:hidden',\n className\n )}\n >\n <div className=\"mx-auto flex w-full max-w-7xl items-center justify-between px-3 py-2\">\n <div className=\"flex items-center gap-2\">\n <Sheet open={open} onOpenChange={setOpen}>\n <SheetTrigger asChild>\n <Button variant=\"ghost\" size=\"icon\" aria-label=\"Open menu\">\n <Menu className=\"h-5 w-5\" />\n </Button>\n </SheetTrigger>\n <SheetContent side=\"left\" className=\"w-[320px] p-4\">\n <SheetHeader>\n <SheetTitle>Menu</SheetTitle>\n <SheetDescription>\n <div className=\"mb-3\">\n <CommandSearchTrigger groups={[]} compact />\n </div>\n <MobileNavMenu items={nav} />\n </SheetDescription>\n </SheetHeader>\n <VStack>\n <MobileNavMenu items={nav} />\n </VStack>\n <SheetFooter>\n {right}\n {/* todo */}\n </SheetFooter>\n </SheetContent>\n </Sheet>\n {logo}\n </div>\n <div className=\"flex items-center gap-2\">\n <LangSwitchDropdown\n value={'en'}\n options={[\n { code: 'fr', label: 'FR' },\n { code: 'en', label: 'EN' },\n ]}\n onChange={() => {\n /* noop */\n }}\n />\n </div>\n </div>\n </div>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;AAqBA,SAAgB,sBAAsB,EACpC,MACA,MAAM,EAAE,EACR,WACA,SACuB;CACvB,MAAM,CAAC,MAAM,WAAW,MAAM,SAAS,MAAM;AAC7C,QACE,oBAAC;EACC,WAAW,GACT,yGACA,UACD;YAED,qBAAC;GAAI,WAAU;cACb,qBAAC;IAAI,WAAU;eACb,qBAAC;KAAY;KAAM,cAAc;gBAC/B,oBAAC;MAAa;gBACZ,oBAAC;OAAO,SAAQ;OAAQ,MAAK;OAAO,cAAW;iBAC7C,oBAAC,QAAK,WAAU,YAAY;QACrB;OACI,EACf,qBAAC;MAAa,MAAK;MAAO,WAAU;;OAClC,qBAAC,0BACC,oBAAC,wBAAW,SAAiB,EAC7B,qBAAC,+BACC,oBAAC;QAAI,WAAU;kBACb,oBAAC;SAAqB,QAAQ,EAAE;SAAE;UAAU;SACxC,EACN,oBAAC,iBAAc,OAAO,MAAO,IACZ,IACP;OACd,oBAAC,oBACC,oBAAC,iBAAc,OAAO,MAAO,GACtB;OACT,oBAAC,yBACE,QAEW;;OACD;MACT,EACP;KACG,EACN,oBAAC;IAAI,WAAU;cACb,oBAAC;KACC,OAAO;KACP,SAAS,CACP;MAAE,MAAM;MAAM,OAAO;MAAM,EAC3B;MAAE,MAAM;MAAM,OAAO;MAAM,CAC5B;KACD,gBAAgB;MAGhB;KACE;IACF;GACF"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import * as react_jsx_runtime30 from "react/jsx-runtime";
|
|
3
|
+
|
|
4
|
+
//#region src/components/organisms/MarketingLayout.d.ts
|
|
5
|
+
interface MarketingLayoutProps {
|
|
6
|
+
header: React.ReactNode;
|
|
7
|
+
children: React.ReactNode;
|
|
8
|
+
footer?: React.ReactNode;
|
|
9
|
+
className?: string;
|
|
10
|
+
}
|
|
11
|
+
declare function MarketingLayout({
|
|
12
|
+
header,
|
|
13
|
+
children,
|
|
14
|
+
footer,
|
|
15
|
+
className
|
|
16
|
+
}: MarketingLayoutProps): react_jsx_runtime30.JSX.Element;
|
|
17
|
+
//#endregion
|
|
18
|
+
export { MarketingLayout };
|
|
19
|
+
//# sourceMappingURL=MarketingLayout.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MarketingLayout.d.ts","names":[],"sources":["../../../src/components/organisms/MarketingLayout.tsx"],"sourcesContent":[],"mappings":";;;;UAMiB,oBAAA;UACP,KAAA,CAAM;YACJ,KAAA,CAAM;EAFD,MAAA,CAAA,EAGN,KAAA,CAAM,SAHoB;EAC3B,SAAM,CAAA,EAAA,MAAA;;AAEC,iBAID,eAAA,CAJC;EAAA,MAAA;EAAA,QAAA;EAAA,MAAA;EAAA;AAAA,CAAA,EASd,oBATc,CAAA,EASM,mBAAA,CAAA,GAAA,CAAA,OATN"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import "react";
|
|
4
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
5
|
+
import { VStack } from "@contractspec/lib.ui-kit-web/ui/stack";
|
|
6
|
+
import { cn } from "@contractspec/lib.ui-kit-web/ui/utils";
|
|
7
|
+
|
|
8
|
+
//#region src/components/organisms/MarketingLayout.tsx
|
|
9
|
+
function MarketingLayout({ header, children, footer, className }) {
|
|
10
|
+
return /* @__PURE__ */ jsxs(VStack, {
|
|
11
|
+
gap: "none",
|
|
12
|
+
className: cn("bg-background min-h-svh", className),
|
|
13
|
+
children: [
|
|
14
|
+
header,
|
|
15
|
+
/* @__PURE__ */ jsx("main", {
|
|
16
|
+
id: "main",
|
|
17
|
+
className: "flex-1",
|
|
18
|
+
children
|
|
19
|
+
}),
|
|
20
|
+
footer
|
|
21
|
+
]
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
//#endregion
|
|
26
|
+
export { MarketingLayout };
|
|
27
|
+
//# sourceMappingURL=MarketingLayout.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MarketingLayout.js","names":[],"sources":["../../../src/components/organisms/MarketingLayout.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { cn } from '@contractspec/lib.ui-kit-web/ui/utils';\nimport { VStack } from '@contractspec/lib.ui-kit-web/ui/stack';\n\nexport interface MarketingLayoutProps {\n header: React.ReactNode;\n children: React.ReactNode;\n footer?: React.ReactNode;\n className?: string;\n}\n\nexport function MarketingLayout({\n header,\n children,\n footer,\n className,\n}: MarketingLayoutProps) {\n return (\n <VStack gap=\"none\" className={cn('bg-background min-h-svh', className)}>\n {header}\n\n {/* <main id=\"main\" className=\"mx-auto w-full max-w-7xl px-4 py-8\"> */}\n <main id=\"main\" className=\"flex-1\">\n {children}\n </main>\n\n {footer}\n </VStack>\n );\n}\n"],"mappings":";;;;;;;;AAaA,SAAgB,gBAAgB,EAC9B,QACA,UACA,QACA,aACuB;AACvB,QACE,qBAAC;EAAO,KAAI;EAAO,WAAW,GAAG,2BAA2B,UAAU;;GACnE;GAGD,oBAAC;IAAK,IAAG;IAAO,WAAU;IACvB;KACI;GAEN;;GACM"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import * as react_jsx_runtime61 from "react/jsx-runtime";
|
|
2
|
+
import { PageHeaderProps } from "@contractspec/lib.ui-kit-web/ui/page-header";
|
|
3
|
+
|
|
4
|
+
//#region src/components/organisms/PageHeaderResponsive.d.ts
|
|
5
|
+
type PageHeaderResponsiveProps = PageHeaderProps;
|
|
6
|
+
declare function PageHeaderResponsive(props: PageHeaderResponsiveProps): react_jsx_runtime61.JSX.Element;
|
|
7
|
+
//#endregion
|
|
8
|
+
export { PageHeaderResponsive };
|
|
9
|
+
//# sourceMappingURL=PageHeaderResponsive.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PageHeaderResponsive.d.ts","names":[],"sources":["../../../src/components/organisms/PageHeaderResponsive.tsx"],"sourcesContent":[],"mappings":";;;;KASY,yBAAA,GAA4B;iBAExB,oBAAA,QAA4B,4BAAyB,mBAAA,CAAA,GAAA,CAAA"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import { useResponsive } from "../../platform/useResponsive.js";
|
|
4
|
+
import "react";
|
|
5
|
+
import { jsx } from "react/jsx-runtime";
|
|
6
|
+
import { PageHeader } from "@contractspec/lib.ui-kit-web/ui/page-header";
|
|
7
|
+
|
|
8
|
+
//#region src/components/organisms/PageHeaderResponsive.tsx
|
|
9
|
+
function PageHeaderResponsive(props) {
|
|
10
|
+
const { screen } = useResponsive();
|
|
11
|
+
const spacing = screen === "desktop" ? "lg" : screen === "tablet" ? "md" : "sm";
|
|
12
|
+
return /* @__PURE__ */ jsx(PageHeader, {
|
|
13
|
+
...props,
|
|
14
|
+
spacing: props.spacing ?? spacing
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
//#endregion
|
|
19
|
+
export { PageHeaderResponsive };
|
|
20
|
+
//# sourceMappingURL=PageHeaderResponsive.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PageHeaderResponsive.js","names":["WebPageHeader"],"sources":["../../../src/components/organisms/PageHeaderResponsive.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport {\n PageHeader as WebPageHeader,\n type PageHeaderProps,\n} from '@contractspec/lib.ui-kit-web/ui/page-header';\nimport { useResponsive } from '../../platform/useResponsive';\n\nexport type PageHeaderResponsiveProps = PageHeaderProps;\n\nexport function PageHeaderResponsive(props: PageHeaderResponsiveProps) {\n const { screen } = useResponsive();\n const spacing =\n screen === 'desktop' ? 'lg' : screen === 'tablet' ? 'md' : 'sm';\n return (\n <WebPageHeader\n {...props}\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n spacing={props.spacing ?? (spacing as any)}\n />\n );\n}\n"],"mappings":";;;;;;;;AAWA,SAAgB,qBAAqB,OAAkC;CACrE,MAAM,EAAE,WAAW,eAAe;CAClC,MAAM,UACJ,WAAW,YAAY,OAAO,WAAW,WAAW,OAAO;AAC7D,QACE,oBAACA;EACC,GAAI;EAEJ,SAAS,MAAM,WAAY;GAC3B"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import * as react_jsx_runtime56 from "react/jsx-runtime";
|
|
2
|
+
|
|
3
|
+
//#region src/components/organisms/PricingCarousel.d.ts
|
|
4
|
+
interface PricingSlide {
|
|
5
|
+
name: string;
|
|
6
|
+
price: string;
|
|
7
|
+
tagline?: string;
|
|
8
|
+
features: string[];
|
|
9
|
+
cta?: {
|
|
10
|
+
label: string;
|
|
11
|
+
href?: string;
|
|
12
|
+
onPress?: () => void;
|
|
13
|
+
};
|
|
14
|
+
highlighted?: boolean;
|
|
15
|
+
}
|
|
16
|
+
declare function PricingCarousel({
|
|
17
|
+
tiers,
|
|
18
|
+
className
|
|
19
|
+
}: {
|
|
20
|
+
tiers: PricingSlide[];
|
|
21
|
+
className?: string;
|
|
22
|
+
}): react_jsx_runtime56.JSX.Element;
|
|
23
|
+
//#endregion
|
|
24
|
+
export { PricingCarousel };
|
|
25
|
+
//# sourceMappingURL=PricingCarousel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PricingCarousel.d.ts","names":[],"sources":["../../../src/components/organisms/PricingCarousel.tsx"],"sourcesContent":[],"mappings":";;;UAYiB,YAAA;;;EAAA,OAAA,CAAA,EAAA,MAAY;EASb,QAAA,EAAA,MAAA,EAAe;EAC7B,GAAA,CAAA,EAAA;IACA,KAAA,EAAA,MAAA;IAEO,IAAA,CAAA,EAAA,MAAA;IAER,OAAA,CAAA,EAAA,GAAA,GAAA,IAAA;EAAA,CAAA;;;iBANe,eAAA;;;;SAIP;;IAER,mBAAA,CAAA,GAAA,CAAA"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { Button } from "../atoms/Button.js";
|
|
2
|
+
import { ButtonLink } from "../atoms/ButtonLink.js";
|
|
3
|
+
import "react";
|
|
4
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
5
|
+
import { Card, CardContent } from "@contractspec/lib.ui-kit-web/ui/card";
|
|
6
|
+
import { Carousel, CarouselContent, CarouselItem, CarouselNext, CarouselPrevious } from "@contractspec/lib.ui-kit-web/ui/carousel";
|
|
7
|
+
|
|
8
|
+
//#region src/components/organisms/PricingCarousel.tsx
|
|
9
|
+
function PricingCarousel({ tiers, className }) {
|
|
10
|
+
return /* @__PURE__ */ jsx("div", {
|
|
11
|
+
className,
|
|
12
|
+
children: /* @__PURE__ */ jsxs(Carousel, { children: [
|
|
13
|
+
/* @__PURE__ */ jsx(CarouselContent, { children: tiers.map((t, i) => /* @__PURE__ */ jsx(CarouselItem, { children: /* @__PURE__ */ jsx(Card, {
|
|
14
|
+
className: t.highlighted ? "border-primary shadow-lg" : void 0,
|
|
15
|
+
children: /* @__PURE__ */ jsxs(CardContent, {
|
|
16
|
+
className: "p-6",
|
|
17
|
+
children: [
|
|
18
|
+
/* @__PURE__ */ jsx("div", {
|
|
19
|
+
className: "text-muted-foreground mb-2 text-base font-medium",
|
|
20
|
+
children: t.name
|
|
21
|
+
}),
|
|
22
|
+
/* @__PURE__ */ jsx("div", {
|
|
23
|
+
className: "text-3xl font-semibold",
|
|
24
|
+
children: t.price
|
|
25
|
+
}),
|
|
26
|
+
t.tagline && /* @__PURE__ */ jsx("div", {
|
|
27
|
+
className: "text-muted-foreground mt-1 text-base",
|
|
28
|
+
children: t.tagline
|
|
29
|
+
}),
|
|
30
|
+
/* @__PURE__ */ jsx("ul", {
|
|
31
|
+
className: "mt-4 space-y-2 text-base",
|
|
32
|
+
children: t.features.map((f, j) => /* @__PURE__ */ jsxs("li", {
|
|
33
|
+
className: "flex items-start gap-2",
|
|
34
|
+
children: [/* @__PURE__ */ jsx("span", { className: "bg-primary mt-1 h-1.5 w-1.5 rounded-full" }), /* @__PURE__ */ jsx("span", { children: f })]
|
|
35
|
+
}, j))
|
|
36
|
+
}),
|
|
37
|
+
t.cta && /* @__PURE__ */ jsx("div", {
|
|
38
|
+
className: "mt-6",
|
|
39
|
+
children: t.cta.href ? /* @__PURE__ */ jsx(ButtonLink, {
|
|
40
|
+
className: "w-full",
|
|
41
|
+
href: t.cta.href,
|
|
42
|
+
children: t.cta.label
|
|
43
|
+
}) : /* @__PURE__ */ jsx(Button, {
|
|
44
|
+
className: "w-full",
|
|
45
|
+
onPress: t.cta.onPress,
|
|
46
|
+
children: t.cta.label
|
|
47
|
+
})
|
|
48
|
+
})
|
|
49
|
+
]
|
|
50
|
+
})
|
|
51
|
+
}) }, i)) }),
|
|
52
|
+
/* @__PURE__ */ jsx(CarouselPrevious, {}),
|
|
53
|
+
/* @__PURE__ */ jsx(CarouselNext, {})
|
|
54
|
+
] })
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
//#endregion
|
|
59
|
+
export { PricingCarousel };
|
|
60
|
+
//# sourceMappingURL=PricingCarousel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PricingCarousel.js","names":[],"sources":["../../../src/components/organisms/PricingCarousel.tsx"],"sourcesContent":["import * as React from 'react';\nimport {\n Carousel,\n CarouselContent,\n CarouselItem,\n CarouselNext,\n CarouselPrevious,\n} from '@contractspec/lib.ui-kit-web/ui/carousel';\nimport { Card, CardContent } from '@contractspec/lib.ui-kit-web/ui/card';\nimport { Button } from '../atoms/Button';\nimport { ButtonLink } from '../atoms/ButtonLink';\n\nexport interface PricingSlide {\n name: string;\n price: string;\n tagline?: string;\n features: string[];\n cta?: { label: string; href?: string; onPress?: () => void };\n highlighted?: boolean;\n}\n\nexport function PricingCarousel({\n tiers,\n className,\n}: {\n tiers: PricingSlide[];\n className?: string;\n}) {\n return (\n <div className={className}>\n <Carousel>\n <CarouselContent>\n {tiers.map((t, i) => (\n <CarouselItem key={i}>\n <Card\n className={\n t.highlighted ? 'border-primary shadow-lg' : undefined\n }\n >\n <CardContent className=\"p-6\">\n <div className=\"text-muted-foreground mb-2 text-base font-medium\">\n {t.name}\n </div>\n <div className=\"text-3xl font-semibold\">{t.price}</div>\n {t.tagline && (\n <div className=\"text-muted-foreground mt-1 text-base\">\n {t.tagline}\n </div>\n )}\n <ul className=\"mt-4 space-y-2 text-base\">\n {t.features.map((f, j) => (\n <li key={j} className=\"flex items-start gap-2\">\n <span className=\"bg-primary mt-1 h-1.5 w-1.5 rounded-full\" />\n <span>{f}</span>\n </li>\n ))}\n </ul>\n {t.cta && (\n <div className=\"mt-6\">\n {t.cta.href ? (\n <ButtonLink className=\"w-full\" href={t.cta.href}>\n {t.cta.label}\n </ButtonLink>\n ) : (\n <Button className=\"w-full\" onPress={t.cta.onPress}>\n {t.cta.label}\n </Button>\n )}\n </div>\n )}\n </CardContent>\n </Card>\n </CarouselItem>\n ))}\n </CarouselContent>\n <CarouselPrevious />\n <CarouselNext />\n </Carousel>\n </div>\n );\n}\n"],"mappings":";;;;;;;;AAqBA,SAAgB,gBAAgB,EAC9B,OACA,aAIC;AACD,QACE,oBAAC;EAAe;YACd,qBAAC;GACC,oBAAC,6BACE,MAAM,KAAK,GAAG,MACb,oBAAC,0BACC,oBAAC;IACC,WACE,EAAE,cAAc,6BAA6B;cAG/C,qBAAC;KAAY,WAAU;;MACrB,oBAAC;OAAI,WAAU;iBACZ,EAAE;QACC;MACN,oBAAC;OAAI,WAAU;iBAA0B,EAAE;QAAY;MACtD,EAAE,WACD,oBAAC;OAAI,WAAU;iBACZ,EAAE;QACC;MAER,oBAAC;OAAG,WAAU;iBACX,EAAE,SAAS,KAAK,GAAG,MAClB,qBAAC;QAAW,WAAU;mBACpB,oBAAC,UAAK,WAAU,6CAA6C,EAC7D,oBAAC,oBAAM,IAAS;UAFT,EAGJ,CACL;QACC;MACJ,EAAE,OACD,oBAAC;OAAI,WAAU;iBACZ,EAAE,IAAI,OACL,oBAAC;QAAW,WAAU;QAAS,MAAM,EAAE,IAAI;kBACxC,EAAE,IAAI;SACI,GAEb,oBAAC;QAAO,WAAU;QAAS,SAAS,EAAE,IAAI;kBACvC,EAAE,IAAI;SACA;QAEP;;MAEI;KACT,IAtCU,EAuCJ,CACf,GACc;GAClB,oBAAC,qBAAmB;GACpB,oBAAC,iBAAe;MACP;GACP"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import * as react_jsx_runtime62 from "react/jsx-runtime";
|
|
3
|
+
import { PricingTier } from "@contractspec/lib.ui-kit-web/ui/marketing/PricingTable";
|
|
4
|
+
|
|
5
|
+
//#region src/components/organisms/PricingSection.d.ts
|
|
6
|
+
declare function PricingSection({
|
|
7
|
+
tiers,
|
|
8
|
+
title,
|
|
9
|
+
subtitle,
|
|
10
|
+
className
|
|
11
|
+
}: {
|
|
12
|
+
tiers: PricingTier[];
|
|
13
|
+
title?: React.ReactNode;
|
|
14
|
+
subtitle?: React.ReactNode;
|
|
15
|
+
className?: string;
|
|
16
|
+
}): react_jsx_runtime62.JSX.Element;
|
|
17
|
+
//#endregion
|
|
18
|
+
export { PricingSection };
|
|
19
|
+
//# sourceMappingURL=PricingSection.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PricingSection.d.ts","names":[],"sources":["../../../src/components/organisms/PricingSection.tsx"],"sourcesContent":[],"mappings":";;;;;iBAMgB,cAAA;;;;;;SAMP;UACC,KAAA,CAAM;EAPA,QAAA,CAAA,EAQH,KAAA,CAAM,SARW;EAC5B,SAAA,CAAA,EAAA,MAAA;CACA,CAAA,EAQD,mBAAA,CAAA,GAAA,CAAA,OARC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import "react";
|
|
2
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { PricingTable } from "@contractspec/lib.ui-kit-web/ui/marketing/PricingTable";
|
|
4
|
+
|
|
5
|
+
//#region src/components/organisms/PricingSection.tsx
|
|
6
|
+
function PricingSection({ tiers, title, subtitle, className }) {
|
|
7
|
+
return /* @__PURE__ */ jsx("section", {
|
|
8
|
+
className: `py-12 sm:py-16 lg:py-24 ${className || ""}`,
|
|
9
|
+
children: /* @__PURE__ */ jsxs("div", {
|
|
10
|
+
className: "container mx-auto px-4 sm:px-6 lg:px-8",
|
|
11
|
+
children: [title ? /* @__PURE__ */ jsxs("div", {
|
|
12
|
+
className: "mb-8 text-center",
|
|
13
|
+
children: [/* @__PURE__ */ jsx("h2", {
|
|
14
|
+
className: "text-3xl font-bold md:text-4xl",
|
|
15
|
+
children: title
|
|
16
|
+
}), subtitle ? /* @__PURE__ */ jsx("p", {
|
|
17
|
+
className: "text-muted-foreground mx-auto mt-2 max-w-2xl text-base",
|
|
18
|
+
children: subtitle
|
|
19
|
+
}) : null]
|
|
20
|
+
}) : null, /* @__PURE__ */ jsx(PricingTable, { tiers })]
|
|
21
|
+
})
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
//#endregion
|
|
26
|
+
export { PricingSection };
|
|
27
|
+
//# sourceMappingURL=PricingSection.js.map
|