@lssm/lib.design-system 0.0.0-canary-20251120170226
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 +92 -0
- package/dist/_virtual/rolldown_runtime.js +34 -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 +40 -0
- package/dist/components/atoms/Button.d.ts.map +1 -0
- package/dist/components/atoms/Button.js +35 -0
- package/dist/components/atoms/Button.js.map +1 -0
- package/dist/components/atoms/Button.mobile.d.ts +22 -0
- package/dist/components/atoms/Button.mobile.d.ts.map +1 -0
- package/dist/components/atoms/Button.mobile.js +35 -0
- package/dist/components/atoms/Button.mobile.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 +38 -0
- package/dist/components/atoms/ButtonLink.js.map +1 -0
- package/dist/components/atoms/ButtonLink.mobile.d.ts +20 -0
- package/dist/components/atoms/ButtonLink.mobile.d.ts.map +1 -0
- package/dist/components/atoms/ButtonLink.mobile.js +42 -0
- package/dist/components/atoms/ButtonLink.mobile.js.map +1 -0
- package/dist/components/atoms/Cta.d.ts +21 -0
- package/dist/components/atoms/Cta.d.ts.map +1 -0
- package/dist/components/atoms/Cta.js +59 -0
- package/dist/components/atoms/Cta.js.map +1 -0
- package/dist/components/atoms/Cta.mobile.d.ts +15 -0
- package/dist/components/atoms/Cta.mobile.d.ts.map +1 -0
- package/dist/components/atoms/Cta.mobile.js +40 -0
- package/dist/components/atoms/Cta.mobile.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 +15 -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 +41 -0
- package/dist/components/atoms/ErrorState.js.map +1 -0
- package/dist/components/atoms/ErrorState.mobile.d.ts +29 -0
- package/dist/components/atoms/ErrorState.mobile.d.ts.map +1 -0
- package/dist/components/atoms/ErrorState.mobile.js +42 -0
- package/dist/components/atoms/ErrorState.mobile.js.map +1 -0
- package/dist/components/atoms/Input.d.ts +40 -0
- package/dist/components/atoms/Input.d.ts.map +1 -0
- package/dist/components/atoms/Input.js +29 -0
- package/dist/components/atoms/Input.js.map +1 -0
- package/dist/components/atoms/Input.mobile.d.ts +38 -0
- package/dist/components/atoms/Input.mobile.d.ts.map +1 -0
- package/dist/components/atoms/Input.mobile.js +28 -0
- package/dist/components/atoms/Input.mobile.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 +15 -0
- package/dist/components/atoms/Link.js.map +1 -0
- package/dist/components/atoms/Link.native.d.ts +1 -0
- package/dist/components/atoms/Link.native.js +0 -0
- package/dist/components/atoms/Link.web.d.ts +24 -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 +45 -0
- package/dist/components/atoms/LoaderCircular.js.map +1 -0
- package/dist/components/atoms/LoaderCircular.mobile.d.ts +18 -0
- package/dist/components/atoms/LoaderCircular.mobile.d.ts.map +1 -0
- package/dist/components/atoms/LoaderCircular.mobile.js +27 -0
- package/dist/components/atoms/LoaderCircular.mobile.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 +27 -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 +15 -0
- package/dist/components/atoms/Stepper.js.map +1 -0
- package/dist/components/atoms/Textarea.d.ts +42 -0
- package/dist/components/atoms/Textarea.d.ts.map +1 -0
- package/dist/components/atoms/Textarea.js +37 -0
- package/dist/components/atoms/Textarea.js.map +1 -0
- package/dist/components/atoms/Textarea.mobile.d.ts +38 -0
- package/dist/components/atoms/Textarea.mobile.d.ts.map +1 -0
- package/dist/components/atoms/Textarea.mobile.js +28 -0
- package/dist/components/atoms/Textarea.mobile.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 +81 -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 +68 -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 +94 -0
- package/dist/components/data-view/DataViewTable.js.map +1 -0
- package/dist/components/data-view/utils.d.ts +6 -0
- package/dist/components/data-view/utils.d.ts.map +1 -0
- package/dist/components/data-view/utils.js +44 -0
- package/dist/components/data-view/utils.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 +26 -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 +30 -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 +26 -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 +47 -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 +35 -0
- package/dist/components/legal/templates/TermsTemplate.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 +19 -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 +43 -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 +46 -0
- package/dist/components/molecules/CommandSearchTrigger.js.map +1 -0
- package/dist/components/molecules/DropdownMenu.d.ts +1 -0
- package/dist/components/molecules/DropdownMenu.js +0 -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 +89 -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 +71 -0
- package/dist/components/molecules/FiltersToolbar.js.map +1 -0
- package/dist/components/molecules/FiltersToolbar.mobile.d.ts +19 -0
- package/dist/components/molecules/FiltersToolbar.mobile.d.ts.map +1 -0
- package/dist/components/molecules/FiltersToolbar.mobile.js +49 -0
- package/dist/components/molecules/FiltersToolbar.mobile.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 +27 -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 +23 -0
- package/dist/components/molecules/LangSwitch.js.map +1 -0
- package/dist/components/molecules/LangSwitchDropdown.d.ts +22 -0
- package/dist/components/molecules/LangSwitchDropdown.d.ts.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 +26 -0
- package/dist/components/molecules/LoaderBlock.js.map +1 -0
- package/dist/components/molecules/LoaderBlock.mobile.d.ts +19 -0
- package/dist/components/molecules/LoaderBlock.mobile.d.ts.map +1 -0
- package/dist/components/molecules/LoaderBlock.mobile.js +26 -0
- package/dist/components/molecules/LoaderBlock.mobile.js.map +1 -0
- package/dist/components/molecules/MobileNavMenu.d.ts +14 -0
- package/dist/components/molecules/MobileNavMenu.d.ts.map +1 -0
- package/dist/components/molecules/MobileNavMenu.js +29 -0
- package/dist/components/molecules/MobileNavMenu.js.map +1 -0
- package/dist/components/molecules/NavItemCard.d.ts +15 -0
- package/dist/components/molecules/NavItemCard.d.ts.map +1 -0
- package/dist/components/molecules/NavItemCard.js +51 -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 +39 -0
- package/dist/components/molecules/OverviewCard.js.map +1 -0
- package/dist/components/molecules/SkeletonBlock/index.d.ts +3 -0
- package/dist/components/molecules/SkeletonBlock/index.js +3 -0
- package/dist/components/molecules/SkeletonBlock/index.mobile.d.ts +13 -0
- package/dist/components/molecules/SkeletonBlock/index.mobile.d.ts.map +1 -0
- package/dist/components/molecules/SkeletonBlock/index.mobile.js +19 -0
- package/dist/components/molecules/SkeletonBlock/index.mobile.js.map +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 +14 -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/SkeletonBlock/types.js +0 -0
- package/dist/components/molecules/SkeletonCircle/index.d.ts +3 -0
- package/dist/components/molecules/SkeletonCircle/index.js +3 -0
- package/dist/components/molecules/SkeletonCircle/index.mobile.d.ts +12 -0
- package/dist/components/molecules/SkeletonCircle/index.mobile.d.ts.map +1 -0
- package/dist/components/molecules/SkeletonCircle/index.mobile.js +24 -0
- package/dist/components/molecules/SkeletonCircle/index.mobile.js.map +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 +24 -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/SkeletonCircle/types.js +0 -0
- package/dist/components/molecules/SkeletonList/index.d.ts +3 -0
- package/dist/components/molecules/SkeletonList/index.js +3 -0
- package/dist/components/molecules/SkeletonList/index.mobile.d.ts +11 -0
- package/dist/components/molecules/SkeletonList/index.mobile.d.ts.map +1 -0
- package/dist/components/molecules/SkeletonList/index.mobile.js +23 -0
- package/dist/components/molecules/SkeletonList/index.mobile.js.map +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 +16 -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/SkeletonList/types.js +0 -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 +69 -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 +57 -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 +46 -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 +34 -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 +46 -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 +39 -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 +48 -0
- package/dist/components/molecules/hover-previews/User.js.map +1 -0
- package/dist/components/native/BottomTabs.mobile.d.ts +21 -0
- package/dist/components/native/BottomTabs.mobile.d.ts.map +1 -0
- package/dist/components/native/BottomTabs.mobile.js +29 -0
- package/dist/components/native/BottomTabs.mobile.js.map +1 -0
- package/dist/components/native/FlatListScreen.mobile.d.ts +44 -0
- package/dist/components/native/FlatListScreen.mobile.d.ts.map +1 -0
- package/dist/components/native/FlatListScreen.mobile.js +65 -0
- package/dist/components/native/FlatListScreen.mobile.js.map +1 -0
- package/dist/components/native/SheetMenu.mobile.d.ts +18 -0
- package/dist/components/native/SheetMenu.mobile.d.ts.map +1 -0
- package/dist/components/native/SheetMenu.mobile.js +23 -0
- package/dist/components/native/SheetMenu.mobile.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 +48 -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 +32 -0
- package/dist/components/organisms/AppHeader.js.map +1 -0
- package/dist/components/organisms/AppHeader.mobile.d.ts +22 -0
- package/dist/components/organisms/AppHeader.mobile.d.ts.map +1 -0
- package/dist/components/organisms/AppHeader.mobile.js +54 -0
- package/dist/components/organisms/AppHeader.mobile.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 +46 -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/AppSidebar.mobile.d.ts +1 -0
- package/dist/components/organisms/AppSidebar.mobile.js +0 -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.mobile.d.ts +21 -0
- package/dist/components/organisms/EmptyDataList.mobile.d.ts.map +1 -0
- package/dist/components/organisms/EmptyDataList.mobile.js +28 -0
- package/dist/components/organisms/EmptyDataList.mobile.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/EmptyDataList.types.js +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 +55 -0
- package/dist/components/organisms/Footer.js.map +1 -0
- package/dist/components/organisms/GridLayout.d.ts +26 -0
- package/dist/components/organisms/GridLayout.d.ts.map +1 -0
- package/dist/components/organisms/GridLayout.js +29 -0
- package/dist/components/organisms/GridLayout.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 +101 -0
- package/dist/components/organisms/Header.js.map +1 -0
- package/dist/components/organisms/Header.mobile.d.ts +25 -0
- package/dist/components/organisms/Header.mobile.d.ts.map +1 -0
- package/dist/components/organisms/Header.mobile.js +20 -0
- package/dist/components/organisms/Header.mobile.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 +26 -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 +57 -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 +52 -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 +21 -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 +48 -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 +59 -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 +71 -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 +21 -0
- package/dist/components/organisms/PageHeaderResponsive.js.map +1 -0
- package/dist/components/organisms/PageHeaderResponsive.mobile.d.ts +23 -0
- package/dist/components/organisms/PageHeaderResponsive.mobile.d.ts.map +1 -0
- package/dist/components/organisms/PageHeaderResponsive.mobile.js +34 -0
- package/dist/components/organisms/PageHeaderResponsive.mobile.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 +3 -0
- package/dist/components/templates/lists/ListPageTemplate/index.js +3 -0
- package/dist/components/templates/lists/ListPageTemplate/index.mobile.d.ts +22 -0
- package/dist/components/templates/lists/ListPageTemplate/index.mobile.d.ts.map +1 -0
- package/dist/components/templates/lists/ListPageTemplate/index.mobile.js +33 -0
- package/dist/components/templates/lists/ListPageTemplate/index.mobile.js.map +1 -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 +53 -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 +106 -0
- package/dist/index.js +106 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/keyboard.d.ts +15 -0
- package/dist/lib/keyboard.d.ts.map +1 -0
- package/dist/lib/keyboard.js +365 -0
- package/dist/lib/keyboard.js.map +1 -0
- package/dist/lib/utils.d.ts +7 -0
- package/dist/lib/utils.d.ts.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 +22 -0
- package/dist/platform/useColorScheme.js.map +1 -0
- package/dist/platform/useColorScheme.mobile.d.ts +6 -0
- package/dist/platform/useColorScheme.mobile.d.ts.map +1 -0
- package/dist/platform/useColorScheme.mobile.js +22 -0
- package/dist/platform/useColorScheme.mobile.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 +22 -0
- package/dist/platform/useReducedMotion.js.map +1 -0
- package/dist/platform/useReducedMotion.mobile.d.ts +5 -0
- package/dist/platform/useReducedMotion.mobile.d.ts.map +1 -0
- package/dist/platform/useReducedMotion.mobile.js +30 -0
- package/dist/platform/useReducedMotion.mobile.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 +41 -0
- package/dist/platform/useResponsive.js.map +1 -0
- package/dist/platform/useResponsive.mobile.d.ts +24 -0
- package/dist/platform/useResponsive.mobile.d.ts.map +1 -0
- package/dist/platform/useResponsive.mobile.js +44 -0
- package/dist/platform/useResponsive.mobile.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 +32 -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 +77 -0
- package/dist/renderers/form-contract.js.map +1 -0
- package/dist/renderers/index.d.ts +2 -0
- package/dist/renderers/index.js +3 -0
- package/dist/theme/tokenBridge.d.ts +20 -0
- package/dist/theme/tokenBridge.d.ts.map +1 -0
- package/dist/theme/tokenBridge.js +26 -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 +50 -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 +45 -0
- package/dist/theme/variants.js.map +1 -0
- package/dist/types/nativewind-env.d.ts +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 +347 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"keyboard.js","names":["res: Record<string, unknown>","native: Record<string, unknown>"],"sources":["../../src/lib/keyboard.ts"],"sourcesContent":["export type KeyboardKind =\n | 'text'\n | 'email'\n | 'password'\n | 'new-password'\n | 'username'\n | 'url'\n | 'search'\n | 'phone'\n | 'tel' // alias of phone\n | 'number'\n | 'int' // alias of number\n | 'decimal'\n | 'numbers-and-punctuation'\n | 'otp'\n | 'name'\n | 'given-name'\n | 'family-name'\n | 'address-line1'\n | 'address-line2'\n | 'postal-code'\n | 'cc-number'\n | 'cc-exp'\n | 'cc-csc'\n | 'off'\n | 'date';\n\n// WHATWG HTML autofill tokens (subset + extensible). See:\n// https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill\nexport type AutoCompleteToken =\n | 'on'\n | 'off'\n // identity\n | 'name'\n | 'honorific-prefix'\n | 'given-name'\n | 'additional-name'\n | 'family-name'\n | 'honorific-suffix'\n | 'nickname'\n | 'username'\n | 'new-password'\n | 'current-password'\n | 'one-time-code'\n // organization\n | 'organization-title'\n | 'organization'\n // address\n | 'street-address'\n | 'address-line1'\n | 'address-line2'\n | 'address-line3'\n | 'address-level4'\n | 'address-level3'\n | 'address-level2'\n | 'address-level1'\n | 'country'\n | 'country-name'\n | 'postal-code'\n // credit card / payment\n | 'cc-name'\n | 'cc-given-name'\n | 'cc-additional-name'\n | 'cc-family-name'\n | 'cc-number'\n | 'cc-exp'\n | 'cc-exp-month'\n | 'cc-exp-year'\n | 'cc-csc'\n | 'cc-type'\n | 'transaction-amount'\n // personal\n | 'language'\n | 'bday'\n | 'bday-day'\n | 'bday-month'\n | 'bday-year'\n | 'sex'\n | 'photo'\n // contact\n | 'email'\n | 'impp'\n | 'tel'\n | 'tel-country-code'\n | 'tel-national'\n | 'tel-area-code'\n | 'tel-local'\n | 'tel-local-prefix'\n | 'tel-local-suffix'\n | 'tel-extension'\n | 'url'\n // webauthn and sections (allow prefix)\n | 'webauthn'\n | `section-${string}`\n // allow future spec additions while keeping strong hints\n | (string & {});\n\nexport interface KeyboardOptions {\n kind?: KeyboardKind;\n autoCapitalize?: 'none' | 'sentences' | 'words' | 'characters';\n autoComplete?: AutoCompleteToken;\n autoCorrect?: boolean;\n enterKeyHint?: 'enter' | 'done' | 'go' | 'next' | 'search' | 'send';\n}\n\nfunction deriveKindFromAutoComplete(\n ac?: AutoCompleteToken\n): KeyboardKind | undefined {\n if (!ac) return undefined;\n switch (ac) {\n // Direct mappings\n case 'email':\n return 'email';\n case 'url':\n return 'url';\n case 'username':\n return 'username';\n case 'new-password':\n return 'new-password';\n case 'current-password':\n return 'password';\n case 'one-time-code':\n return 'otp';\n case 'tel':\n case 'tel-country-code':\n case 'tel-national':\n case 'tel-area-code':\n case 'tel-local':\n case 'tel-local-prefix':\n case 'tel-local-suffix':\n case 'tel-extension':\n return 'tel';\n // Numeric leaning\n case 'postal-code':\n case 'cc-number':\n case 'cc-csc':\n case 'bday-day':\n case 'bday-month':\n case 'bday-year':\n return 'int';\n case 'cc-exp':\n case 'cc-exp-month':\n case 'cc-exp-year':\n return 'numbers-and-punctuation';\n // Date-like\n case 'bday':\n return 'date';\n // Everything else is plain text (names, organization, street-address, etc.)\n default:\n return 'text';\n }\n}\n\nfunction applyAutoCompleteDefaultsWeb(\n res: Record<string, unknown>,\n ac?: AutoCompleteToken\n) {\n if (!ac) return;\n // Capitalization defaults for human names/org titles\n const wordsCaps: AutoCompleteToken[] = [\n 'name',\n 'given-name',\n 'additional-name',\n 'family-name',\n 'honorific-prefix',\n 'honorific-suffix',\n 'nickname',\n 'organization',\n 'organization-title',\n 'cc-name',\n 'cc-given-name',\n 'cc-additional-name',\n 'cc-family-name',\n ];\n if (wordsCaps.includes(ac)) {\n (res as Record<string, string>).autoCapitalize = 'words';\n }\n // Lowercase identifiers\n const noneCaps: AutoCompleteToken[] = [\n 'username',\n 'new-password',\n 'current-password',\n 'one-time-code',\n 'email',\n 'url',\n ];\n if (noneCaps.includes(ac)) {\n (res as Record<string, string>).autoCapitalize = 'none';\n }\n}\n\nfunction applyAutoCompleteDefaultsNative(\n native: Record<string, unknown>,\n ac?: AutoCompleteToken\n) {\n if (!ac) return;\n // iOS textContentType hints where available (best-effort)\n const textContentMap: Partial<Record<AutoCompleteToken, string>> = {\n name: 'name',\n 'given-name': 'givenName',\n 'additional-name': 'middleName',\n 'family-name': 'familyName',\n username: 'username',\n 'current-password': 'password',\n 'new-password': 'newPassword',\n email: 'emailAddress',\n url: 'URL',\n tel: 'telephoneNumber',\n 'address-line1': 'streetAddressLine1',\n 'address-line2': 'streetAddressLine2',\n 'postal-code': 'postalCode',\n organization: 'organizationName',\n 'organization-title': 'jobTitle',\n 'one-time-code': 'oneTimeCode',\n };\n const tc = textContentMap[ac];\n if (tc) (native as Record<string, string>).textContentType = tc;\n // Capitalization defaults\n const wordsCaps: AutoCompleteToken[] = [\n 'name',\n 'given-name',\n 'additional-name',\n 'family-name',\n 'honorific-prefix',\n 'honorific-suffix',\n 'nickname',\n 'organization',\n 'organization-title',\n 'cc-name',\n 'cc-given-name',\n 'cc-additional-name',\n 'cc-family-name',\n ];\n if (wordsCaps.includes(ac)) {\n (native as Record<string, string>).autoCapitalize = 'words';\n }\n const noneCaps: AutoCompleteToken[] = [\n 'username',\n 'new-password',\n 'current-password',\n 'one-time-code',\n 'email',\n 'url',\n ];\n if (noneCaps.includes(ac)) {\n (native as Record<string, string>).autoCapitalize = 'none';\n }\n}\n\nexport function mapKeyboardToWeb(opts?: KeyboardOptions) {\n const kind =\n opts?.kind ?? deriveKindFromAutoComplete(opts?.autoComplete) ?? 'text';\n const res: Record<string, unknown> = {};\n\n switch (kind) {\n case 'password':\n res.type = 'password';\n res.autoCapitalize = 'none';\n res.autoComplete = opts?.autoComplete ?? 'current-password';\n if (opts?.autoCorrect != null) res.autoCorrect = opts.autoCorrect;\n break;\n case 'new-password':\n res.type = 'password';\n res.autoCapitalize = 'none';\n res.autoComplete = opts?.autoComplete ?? 'new-password';\n if (opts?.autoCorrect != null) res.autoCorrect = opts.autoCorrect;\n break;\n case 'username':\n res.type = 'text';\n res.autoCapitalize = 'none';\n res.autoComplete = opts?.autoComplete ?? 'username';\n break;\n case 'email':\n res.type = 'email';\n res.inputMode = 'email';\n res.autoCapitalize = 'none';\n res.autoComplete = opts?.autoComplete ?? 'email';\n break;\n case 'url':\n res.type = 'url';\n res.inputMode = 'url';\n res.autoComplete = opts?.autoComplete ?? 'url';\n break;\n case 'search':\n res.type = 'search';\n res.inputMode = 'search';\n res.enterKeyHint = opts?.enterKeyHint ?? 'search';\n res.autoComplete = opts?.autoComplete ?? 'off';\n break;\n case 'phone':\n case 'tel':\n res.type = 'tel';\n res.inputMode = 'tel';\n res.autoComplete = opts?.autoComplete ?? 'tel';\n break;\n case 'number':\n case 'int':\n res.type = 'text';\n res.inputMode = 'numeric';\n res.pattern = '[0-9]*';\n break;\n case 'decimal':\n res.type = 'text';\n res.inputMode = 'decimal';\n (res as Record<string, unknown>).step = 'any';\n break;\n case 'numbers-and-punctuation':\n res.type = 'text';\n res.inputMode = 'text';\n res.pattern = '[0-9.,-]*';\n break;\n case 'otp':\n res.type = 'text';\n res.inputMode = 'numeric';\n res.autoComplete = opts?.autoComplete ?? 'one-time-code';\n res.autoCapitalize = 'none';\n break;\n case 'name':\n res.type = 'text';\n res.autoComplete = opts?.autoComplete ?? 'name';\n res.autoCapitalize = opts?.autoCapitalize ?? 'words';\n break;\n case 'given-name':\n res.type = 'text';\n res.autoComplete = opts?.autoComplete ?? 'given-name';\n res.autoCapitalize = opts?.autoCapitalize ?? 'words';\n break;\n case 'family-name':\n res.type = 'text';\n res.autoComplete = opts?.autoComplete ?? 'family-name';\n res.autoCapitalize = opts?.autoCapitalize ?? 'words';\n break;\n case 'address-line1':\n res.type = 'text';\n res.autoComplete = opts?.autoComplete ?? 'address-line1';\n break;\n case 'address-line2':\n res.type = 'text';\n res.autoComplete = opts?.autoComplete ?? 'address-line2';\n break;\n case 'postal-code':\n res.type = 'text';\n res.inputMode = 'numeric';\n res.pattern = '[0-9]*';\n res.autoComplete = opts?.autoComplete ?? 'postal-code';\n break;\n case 'cc-number':\n res.type = 'text';\n res.inputMode = 'numeric';\n res.pattern = '[0-9]*';\n res.autoComplete = opts?.autoComplete ?? 'cc-number';\n break;\n case 'cc-exp':\n res.type = 'text';\n res.inputMode = 'numeric';\n res.pattern = '[0-9/]*';\n res.autoComplete = opts?.autoComplete ?? 'cc-exp';\n break;\n case 'cc-csc':\n res.type = 'text';\n res.inputMode = 'numeric';\n res.pattern = '[0-9]*';\n res.autoComplete = opts?.autoComplete ?? 'cc-csc';\n break;\n case 'off':\n res.type = 'text';\n res.autoComplete = 'off';\n break;\n case 'date':\n res.type = 'date';\n res.inputMode = 'date';\n res.pattern = '[0-9./-]*';\n break;\n default:\n res.type = 'text';\n break;\n }\n\n if (opts?.autoCapitalize) res.autoCapitalize = opts.autoCapitalize;\n if (opts?.autoComplete) res.autoComplete = opts.autoComplete;\n if (opts?.autoCorrect != null) res.autoCorrect = opts.autoCorrect;\n if (opts?.enterKeyHint) res.enterKeyHint = opts.enterKeyHint;\n // Apply additional defaults based on autofill tokens\n applyAutoCompleteDefaultsWeb(res, opts?.autoComplete);\n return res;\n}\n\nexport function mapKeyboardToNative(opts?: KeyboardOptions) {\n const kind =\n opts?.kind ?? deriveKindFromAutoComplete(opts?.autoComplete) ?? 'text';\n const native: Record<string, unknown> = {};\n\n switch (kind) {\n case 'password':\n native.secureTextEntry = true;\n native.textContentType = 'password';\n native.keyboardType = 'default';\n native.autoCapitalize = 'none';\n native.autoComplete = opts?.autoComplete ?? 'password';\n break;\n case 'new-password':\n native.secureTextEntry = true;\n native.textContentType = 'newPassword';\n native.keyboardType = 'default';\n native.autoCapitalize = 'none';\n native.autoComplete = opts?.autoComplete ?? 'new-password';\n break;\n case 'username':\n native.textContentType = 'username';\n native.keyboardType = 'default';\n native.autoCapitalize = 'none';\n native.autoComplete = opts?.autoComplete ?? 'username';\n break;\n case 'email':\n native.keyboardType = 'email-address';\n native.textContentType = 'emailAddress';\n native.autoCapitalize = 'none';\n native.autoComplete = opts?.autoComplete ?? 'email';\n break;\n case 'url':\n native.keyboardType = 'url';\n native.textContentType = 'URL';\n native.autoComplete = opts?.autoComplete ?? 'url';\n break;\n case 'search':\n native.keyboardType = 'default';\n native.returnKeyType = 'search';\n native.autoComplete = opts?.autoComplete ?? 'off';\n break;\n case 'phone':\n case 'tel':\n native.keyboardType = 'phone-pad';\n native.textContentType = 'telephoneNumber';\n native.autoComplete = opts?.autoComplete ?? 'tel';\n break;\n case 'number':\n case 'int':\n native.keyboardType = 'number-pad';\n break;\n case 'decimal':\n native.keyboardType = 'decimal-pad';\n break;\n case 'numbers-and-punctuation':\n native.keyboardType = 'numbers-and-punctuation';\n break;\n case 'otp':\n native.keyboardType = 'number-pad';\n native.textContentType = 'oneTimeCode';\n native.autoComplete = opts?.autoComplete ?? 'one-time-code';\n native.autoCapitalize = 'none';\n break;\n case 'name':\n native.textContentType = 'name';\n native.autoCapitalize = 'words';\n native.autoComplete = opts?.autoComplete ?? 'name';\n break;\n case 'given-name':\n native.textContentType = 'givenName';\n native.autoCapitalize = 'words';\n native.autoComplete = opts?.autoComplete ?? 'given-name';\n break;\n case 'family-name':\n native.textContentType = 'familyName';\n native.autoCapitalize = 'words';\n native.autoComplete = opts?.autoComplete ?? 'family-name';\n break;\n case 'address-line1':\n native.textContentType = 'streetAddressLine1';\n native.autoComplete = opts?.autoComplete ?? 'address-line1';\n break;\n case 'address-line2':\n native.textContentType = 'streetAddressLine2';\n native.autoComplete = opts?.autoComplete ?? 'address-line2';\n break;\n case 'postal-code':\n native.keyboardType = 'numbers-and-punctuation';\n native.textContentType = 'postalCode';\n native.autoComplete = opts?.autoComplete ?? 'postal-code';\n break;\n case 'cc-number':\n native.keyboardType = 'number-pad';\n native.textContentType = 'creditCardNumber';\n native.autoComplete = opts?.autoComplete ?? 'cc-number';\n break;\n case 'cc-exp':\n native.keyboardType = 'numbers-and-punctuation';\n native.autoComplete = opts?.autoComplete ?? 'cc-exp';\n break;\n case 'cc-csc':\n native.keyboardType = 'number-pad';\n native.autoComplete = opts?.autoComplete ?? 'cc-csc';\n break;\n case 'off':\n native.autoComplete = 'off';\n break;\n case 'date':\n native.keyboardType = 'default';\n break;\n default:\n native.keyboardType = 'default';\n break;\n }\n\n if (opts?.autoCapitalize) native.autoCapitalize = opts.autoCapitalize;\n if (opts?.autoCorrect != null) native.autoCorrect = opts.autoCorrect;\n\n if (opts?.enterKeyHint) {\n const map: Record<string, string> = {\n enter: 'default',\n done: 'done',\n go: 'go',\n next: 'next',\n search: 'search',\n send: 'send',\n };\n native.returnKeyType = map[opts.enterKeyHint] ?? 'default';\n }\n\n // Apply additional defaults based on autofill tokens\n applyAutoCompleteDefaultsNative(native, opts?.autoComplete);\n\n return native;\n}\n"],"mappings":";AAyGA,SAAS,2BACP,IAC0B;AAC1B,KAAI,CAAC,GAAI,QAAO;AAChB,SAAQ,IAAR;EAEE,KAAK,QACH,QAAO;EACT,KAAK,MACH,QAAO;EACT,KAAK,WACH,QAAO;EACT,KAAK,eACH,QAAO;EACT,KAAK,mBACH,QAAO;EACT,KAAK,gBACH,QAAO;EACT,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK,gBACH,QAAO;EAET,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK,YACH,QAAO;EACT,KAAK;EACL,KAAK;EACL,KAAK,cACH,QAAO;EAET,KAAK,OACH,QAAO;EAET,QACE,QAAO;;;AAIb,SAAS,6BACP,KACA,IACA;AACA,KAAI,CAAC,GAAI;AAiBT,KAfuC;EACrC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CACa,SAAS,GAAG,CACxB,CAAC,IAA+B,iBAAiB;AAWnD,KARsC;EACpC;EACA;EACA;EACA;EACA;EACA;EACD,CACY,SAAS,GAAG,CACvB,CAAC,IAA+B,iBAAiB;;AAIrD,SAAS,gCACP,QACA,IACA;AACA,KAAI,CAAC,GAAI;CAoBT,MAAM,KAlB6D;EACjE,MAAM;EACN,cAAc;EACd,mBAAmB;EACnB,eAAe;EACf,UAAU;EACV,oBAAoB;EACpB,gBAAgB;EAChB,OAAO;EACP,KAAK;EACL,KAAK;EACL,iBAAiB;EACjB,iBAAiB;EACjB,eAAe;EACf,cAAc;EACd,sBAAsB;EACtB,iBAAiB;EAClB,CACyB;AAC1B,KAAI,GAAI,CAAC,OAAkC,kBAAkB;AAiB7D,KAfuC;EACrC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CACa,SAAS,GAAG,CACxB,CAAC,OAAkC,iBAAiB;AAUtD,KARsC;EACpC;EACA;EACA;EACA;EACA;EACA;EACD,CACY,SAAS,GAAG,CACvB,CAAC,OAAkC,iBAAiB;;AAIxD,SAAgB,iBAAiB,MAAwB;CACvD,MAAM,OACJ,MAAM,QAAQ,2BAA2B,MAAM,aAAa,IAAI;CAClE,MAAMA,MAA+B,EAAE;AAEvC,SAAQ,MAAR;EACE,KAAK;AACH,OAAI,OAAO;AACX,OAAI,iBAAiB;AACrB,OAAI,eAAe,MAAM,gBAAgB;AACzC,OAAI,MAAM,eAAe,KAAM,KAAI,cAAc,KAAK;AACtD;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,iBAAiB;AACrB,OAAI,eAAe,MAAM,gBAAgB;AACzC,OAAI,MAAM,eAAe,KAAM,KAAI,cAAc,KAAK;AACtD;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,iBAAiB;AACrB,OAAI,eAAe,MAAM,gBAAgB;AACzC;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,OAAI,iBAAiB;AACrB,OAAI,eAAe,MAAM,gBAAgB;AACzC;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,OAAI,eAAe,MAAM,gBAAgB;AACzC;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,OAAI,eAAe,MAAM,gBAAgB;AACzC,OAAI,eAAe,MAAM,gBAAgB;AACzC;EACF,KAAK;EACL,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,OAAI,eAAe,MAAM,gBAAgB;AACzC;EACF,KAAK;EACL,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,OAAI,UAAU;AACd;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,GAAC,IAAgC,OAAO;AACxC;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,OAAI,UAAU;AACd;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,OAAI,eAAe,MAAM,gBAAgB;AACzC,OAAI,iBAAiB;AACrB;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,eAAe,MAAM,gBAAgB;AACzC,OAAI,iBAAiB,MAAM,kBAAkB;AAC7C;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,eAAe,MAAM,gBAAgB;AACzC,OAAI,iBAAiB,MAAM,kBAAkB;AAC7C;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,eAAe,MAAM,gBAAgB;AACzC,OAAI,iBAAiB,MAAM,kBAAkB;AAC7C;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,eAAe,MAAM,gBAAgB;AACzC;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,eAAe,MAAM,gBAAgB;AACzC;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,OAAI,UAAU;AACd,OAAI,eAAe,MAAM,gBAAgB;AACzC;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,OAAI,UAAU;AACd,OAAI,eAAe,MAAM,gBAAgB;AACzC;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,OAAI,UAAU;AACd,OAAI,eAAe,MAAM,gBAAgB;AACzC;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,OAAI,UAAU;AACd,OAAI,eAAe,MAAM,gBAAgB;AACzC;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,eAAe;AACnB;EACF,KAAK;AACH,OAAI,OAAO;AACX,OAAI,YAAY;AAChB,OAAI,UAAU;AACd;EACF;AACE,OAAI,OAAO;AACX;;AAGJ,KAAI,MAAM,eAAgB,KAAI,iBAAiB,KAAK;AACpD,KAAI,MAAM,aAAc,KAAI,eAAe,KAAK;AAChD,KAAI,MAAM,eAAe,KAAM,KAAI,cAAc,KAAK;AACtD,KAAI,MAAM,aAAc,KAAI,eAAe,KAAK;AAEhD,8BAA6B,KAAK,MAAM,aAAa;AACrD,QAAO;;AAGT,SAAgB,oBAAoB,MAAwB;CAC1D,MAAM,OACJ,MAAM,QAAQ,2BAA2B,MAAM,aAAa,IAAI;CAClE,MAAMC,SAAkC,EAAE;AAE1C,SAAQ,MAAR;EACE,KAAK;AACH,UAAO,kBAAkB;AACzB,UAAO,kBAAkB;AACzB,UAAO,eAAe;AACtB,UAAO,iBAAiB;AACxB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,kBAAkB;AACzB,UAAO,kBAAkB;AACzB,UAAO,eAAe;AACtB,UAAO,iBAAiB;AACxB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,kBAAkB;AACzB,UAAO,eAAe;AACtB,UAAO,iBAAiB;AACxB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,eAAe;AACtB,UAAO,kBAAkB;AACzB,UAAO,iBAAiB;AACxB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,eAAe;AACtB,UAAO,kBAAkB;AACzB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,eAAe;AACtB,UAAO,gBAAgB;AACvB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;EACL,KAAK;AACH,UAAO,eAAe;AACtB,UAAO,kBAAkB;AACzB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;EACL,KAAK;AACH,UAAO,eAAe;AACtB;EACF,KAAK;AACH,UAAO,eAAe;AACtB;EACF,KAAK;AACH,UAAO,eAAe;AACtB;EACF,KAAK;AACH,UAAO,eAAe;AACtB,UAAO,kBAAkB;AACzB,UAAO,eAAe,MAAM,gBAAgB;AAC5C,UAAO,iBAAiB;AACxB;EACF,KAAK;AACH,UAAO,kBAAkB;AACzB,UAAO,iBAAiB;AACxB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,kBAAkB;AACzB,UAAO,iBAAiB;AACxB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,kBAAkB;AACzB,UAAO,iBAAiB;AACxB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,kBAAkB;AACzB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,kBAAkB;AACzB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,eAAe;AACtB,UAAO,kBAAkB;AACzB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,eAAe;AACtB,UAAO,kBAAkB;AACzB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,eAAe;AACtB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,eAAe;AACtB,UAAO,eAAe,MAAM,gBAAgB;AAC5C;EACF,KAAK;AACH,UAAO,eAAe;AACtB;EACF,KAAK;AACH,UAAO,eAAe;AACtB;EACF;AACE,UAAO,eAAe;AACtB;;AAGJ,KAAI,MAAM,eAAgB,QAAO,iBAAiB,KAAK;AACvD,KAAI,MAAM,eAAe,KAAM,QAAO,cAAc,KAAK;AAEzD,KAAI,MAAM,aASR,QAAO,gBAR6B;EAClC,OAAO;EACP,MAAM;EACN,IAAI;EACJ,MAAM;EACN,QAAQ;EACR,MAAM;EACP,CAC0B,KAAK,iBAAiB;AAInD,iCAAgC,QAAQ,MAAM,aAAa;AAE3D,QAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","names":[],"sources":["../../src/lib/utils.ts"],"sourcesContent":[],"mappings":";;;iBAGgB,EAAA,YAAc"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","names":[],"sources":["../../src/lib/utils.ts"],"sourcesContent":["import { type ClassValue, clsx } from 'clsx';\nimport { twMerge } from 'tailwind-merge';\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n"],"mappings":";;;;AAGA,SAAgB,GAAG,GAAG,QAAsB;AAC1C,QAAO,QAAQ,KAAK,OAAO,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useColorScheme.d.ts","names":[],"sources":["../../src/platform/useColorScheme.ts"],"sourcesContent":[],"mappings":";KAIY,WAAA;AAAA,iBAEI,cAAA,CAAA,CAFO,EAEW,WAFX"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
import * as React$1 from "react";
|
|
5
|
+
|
|
6
|
+
//#region src/platform/useColorScheme.ts
|
|
7
|
+
function useColorScheme() {
|
|
8
|
+
const [scheme, setScheme] = React$1.useState("light");
|
|
9
|
+
React$1.useEffect(() => {
|
|
10
|
+
if (typeof window === "undefined" || !window.matchMedia) return;
|
|
11
|
+
const media = window.matchMedia("(prefers-color-scheme: dark)");
|
|
12
|
+
const update = () => setScheme(media.matches ? "dark" : "light");
|
|
13
|
+
update();
|
|
14
|
+
media.addEventListener?.("change", update);
|
|
15
|
+
return () => media.removeEventListener?.("change", update);
|
|
16
|
+
}, []);
|
|
17
|
+
return scheme;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
//#endregion
|
|
21
|
+
export { useColorScheme };
|
|
22
|
+
//# sourceMappingURL=useColorScheme.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useColorScheme.js","names":["React"],"sources":["../../src/platform/useColorScheme.ts"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\n\nexport type ColorScheme = 'light' | 'dark';\n\nexport function useColorScheme(): ColorScheme {\n const [scheme, setScheme] = React.useState<ColorScheme>('light');\n\n React.useEffect(() => {\n if (typeof window === 'undefined' || !window.matchMedia) return;\n const media = window.matchMedia('(prefers-color-scheme: dark)');\n const update = () => setScheme(media.matches ? 'dark' : 'light');\n update();\n media.addEventListener?.('change', update);\n return () => media.removeEventListener?.('change', update);\n }, []);\n\n return scheme;\n}\n"],"mappings":";;;;;;AAMA,SAAgB,iBAA8B;CAC5C,MAAM,CAAC,QAAQ,aAAaA,QAAM,SAAsB,QAAQ;AAEhE,SAAM,gBAAgB;AACpB,MAAI,OAAO,WAAW,eAAe,CAAC,OAAO,WAAY;EACzD,MAAM,QAAQ,OAAO,WAAW,+BAA+B;EAC/D,MAAM,eAAe,UAAU,MAAM,UAAU,SAAS,QAAQ;AAChE,UAAQ;AACR,QAAM,mBAAmB,UAAU,OAAO;AAC1C,eAAa,MAAM,sBAAsB,UAAU,OAAO;IACzD,EAAE,CAAC;AAEN,QAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useColorScheme.mobile.d.ts","names":[],"sources":["../../src/platform/useColorScheme.mobile.ts"],"sourcesContent":[],"mappings":";KAKY,WAAA;AAAA,iBAEI,cAAA,CAAA,CAFO,EAEW,WAFX"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
import * as React$1 from "react";
|
|
5
|
+
import { Appearance } from "react-native";
|
|
6
|
+
|
|
7
|
+
//#region src/platform/useColorScheme.mobile.ts
|
|
8
|
+
function useColorScheme() {
|
|
9
|
+
const [scheme, setScheme] = React$1.useState(() => Appearance.getColorScheme?.() === "dark" ? "dark" : "light");
|
|
10
|
+
React$1.useEffect(() => {
|
|
11
|
+
const listener = ({ colorScheme }) => {
|
|
12
|
+
setScheme(colorScheme === "dark" ? "dark" : "light");
|
|
13
|
+
};
|
|
14
|
+
const sub = Appearance.addChangeListener?.(listener);
|
|
15
|
+
return () => sub?.remove?.();
|
|
16
|
+
}, []);
|
|
17
|
+
return scheme;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
//#endregion
|
|
21
|
+
export { useColorScheme };
|
|
22
|
+
//# sourceMappingURL=useColorScheme.mobile.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useColorScheme.mobile.js","names":["React"],"sources":["../../src/platform/useColorScheme.mobile.ts"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { Appearance, type ColorSchemeName } from 'react-native';\n\nexport type ColorScheme = 'light' | 'dark';\n\nexport function useColorScheme(): ColorScheme {\n const [scheme, setScheme] = React.useState<ColorScheme>(() =>\n (Appearance.getColorScheme?.() as ColorSchemeName) === 'dark'\n ? 'dark'\n : 'light'\n );\n\n React.useEffect(() => {\n const listener = ({ colorScheme }: { colorScheme: ColorSchemeName }) => {\n setScheme(colorScheme === 'dark' ? 'dark' : 'light');\n };\n const sub = (Appearance as any).addChangeListener?.(listener);\n return () => sub?.remove?.();\n }, []);\n\n return scheme;\n}\n"],"mappings":";;;;;;;AAOA,SAAgB,iBAA8B;CAC5C,MAAM,CAAC,QAAQ,aAAaA,QAAM,eAC/B,WAAW,kBAAkB,KAAyB,SACnD,SACA,QACL;AAED,SAAM,gBAAgB;EACpB,MAAM,YAAY,EAAE,kBAAoD;AACtE,aAAU,gBAAgB,SAAS,SAAS,QAAQ;;EAEtD,MAAM,MAAO,WAAmB,oBAAoB,SAAS;AAC7D,eAAa,KAAK,UAAU;IAC3B,EAAE,CAAC;AAEN,QAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useReducedMotion.d.ts","names":[],"sources":["../../src/platform/useReducedMotion.ts"],"sourcesContent":[],"mappings":";iBAIgB,gBAAA,CAAA"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
import * as React$1 from "react";
|
|
5
|
+
|
|
6
|
+
//#region src/platform/useReducedMotion.ts
|
|
7
|
+
function useReducedMotion() {
|
|
8
|
+
const [reduced, setReduced] = React$1.useState(false);
|
|
9
|
+
React$1.useEffect(() => {
|
|
10
|
+
if (typeof window === "undefined" || !window.matchMedia) return;
|
|
11
|
+
const mq = window.matchMedia("(prefers-reduced-motion: reduce)");
|
|
12
|
+
const onChange = () => setReduced(mq.matches);
|
|
13
|
+
onChange();
|
|
14
|
+
mq.addEventListener?.("change", onChange);
|
|
15
|
+
return () => mq.removeEventListener?.("change", onChange);
|
|
16
|
+
}, []);
|
|
17
|
+
return reduced;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
//#endregion
|
|
21
|
+
export { useReducedMotion };
|
|
22
|
+
//# sourceMappingURL=useReducedMotion.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useReducedMotion.js","names":["React"],"sources":["../../src/platform/useReducedMotion.ts"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\n\nexport function useReducedMotion() {\n const [reduced, setReduced] = React.useState(false);\n\n React.useEffect(() => {\n if (typeof window === 'undefined' || !window.matchMedia) return;\n const mq = window.matchMedia('(prefers-reduced-motion: reduce)');\n const onChange = () => setReduced(mq.matches);\n onChange();\n mq.addEventListener?.('change', onChange);\n return () => mq.removeEventListener?.('change', onChange);\n }, []);\n\n return reduced;\n}\n"],"mappings":";;;;;;AAIA,SAAgB,mBAAmB;CACjC,MAAM,CAAC,SAAS,cAAcA,QAAM,SAAS,MAAM;AAEnD,SAAM,gBAAgB;AACpB,MAAI,OAAO,WAAW,eAAe,CAAC,OAAO,WAAY;EACzD,MAAM,KAAK,OAAO,WAAW,mCAAmC;EAChE,MAAM,iBAAiB,WAAW,GAAG,QAAQ;AAC7C,YAAU;AACV,KAAG,mBAAmB,UAAU,SAAS;AACzC,eAAa,GAAG,sBAAsB,UAAU,SAAS;IACxD,EAAE,CAAC;AAEN,QAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useReducedMotion.mobile.d.ts","names":[],"sources":["../../src/platform/useReducedMotion.mobile.ts"],"sourcesContent":[],"mappings":";iBAKgB,gBAAA,CAAA"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
import * as React$1 from "react";
|
|
5
|
+
import { AccessibilityInfo } from "react-native";
|
|
6
|
+
|
|
7
|
+
//#region src/platform/useReducedMotion.mobile.ts
|
|
8
|
+
function useReducedMotion() {
|
|
9
|
+
const [reduced, setReduced] = React$1.useState(false);
|
|
10
|
+
React$1.useEffect(() => {
|
|
11
|
+
let mounted = true;
|
|
12
|
+
AccessibilityInfo?.isReduceMotionEnabled().then((v) => {
|
|
13
|
+
if (mounted) setReduced(Boolean(v));
|
|
14
|
+
});
|
|
15
|
+
const handler = (v) => {
|
|
16
|
+
if (mounted) setReduced(Boolean(v));
|
|
17
|
+
};
|
|
18
|
+
const sub = AccessibilityInfo?.addEventListener?.("reduceMotionChanged", handler);
|
|
19
|
+
return () => {
|
|
20
|
+
mounted = false;
|
|
21
|
+
sub?.remove?.();
|
|
22
|
+
AccessibilityInfo?.removeEventListener?.("reduceMotionChanged", handler);
|
|
23
|
+
};
|
|
24
|
+
}, []);
|
|
25
|
+
return reduced;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
//#endregion
|
|
29
|
+
export { useReducedMotion };
|
|
30
|
+
//# sourceMappingURL=useReducedMotion.mobile.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useReducedMotion.mobile.js","names":["React"],"sources":["../../src/platform/useReducedMotion.mobile.ts"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { AccessibilityInfo } from 'react-native';\n\nexport function useReducedMotion() {\n const [reduced, setReduced] = React.useState(false);\n\n React.useEffect(() => {\n let mounted = true;\n AccessibilityInfo?.isReduceMotionEnabled().then((v: any) => {\n if (mounted) setReduced(Boolean(v));\n });\n const handler = (v: any) => {\n if (mounted) setReduced(Boolean(v));\n };\n // RN >= 0.71\n const sub = (AccessibilityInfo as any)?.addEventListener?.(\n 'reduceMotionChanged',\n handler\n );\n return () => {\n mounted = false;\n // RN >= 0.71\n sub?.remove?.();\n // RN < 0.71\n (AccessibilityInfo as any)?.removeEventListener?.(\n 'reduceMotionChanged',\n handler\n );\n };\n }, []);\n\n return reduced;\n}\n"],"mappings":";;;;;;;AAKA,SAAgB,mBAAmB;CACjC,MAAM,CAAC,SAAS,cAAcA,QAAM,SAAS,MAAM;AAEnD,SAAM,gBAAgB;EACpB,IAAI,UAAU;AACd,qBAAmB,uBAAuB,CAAC,MAAM,MAAW;AAC1D,OAAI,QAAS,YAAW,QAAQ,EAAE,CAAC;IACnC;EACF,MAAM,WAAW,MAAW;AAC1B,OAAI,QAAS,YAAW,QAAQ,EAAE,CAAC;;EAGrC,MAAM,MAAO,mBAA2B,mBACtC,uBACA,QACD;AACD,eAAa;AACX,aAAU;AAEV,QAAK,UAAU;AAEf,GAAC,mBAA2B,sBAC1B,uBACA,QACD;;IAEF,EAAE,CAAC;AAEN,QAAO"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
//#region src/platform/useResponsive.d.ts
|
|
2
|
+
interface Breakpoints {
|
|
3
|
+
sm: number;
|
|
4
|
+
md: number;
|
|
5
|
+
lg: number;
|
|
6
|
+
xl: number;
|
|
7
|
+
}
|
|
8
|
+
declare function useResponsive(custom?: Partial<Breakpoints>): {
|
|
9
|
+
readonly width: number;
|
|
10
|
+
readonly breakpoints: {
|
|
11
|
+
sm: number;
|
|
12
|
+
md: number;
|
|
13
|
+
lg: number;
|
|
14
|
+
xl: number;
|
|
15
|
+
};
|
|
16
|
+
readonly isSM: boolean;
|
|
17
|
+
readonly isMD: boolean;
|
|
18
|
+
readonly isLG: boolean;
|
|
19
|
+
readonly isXL: boolean;
|
|
20
|
+
readonly screen: "mobile" | "tablet" | "desktop";
|
|
21
|
+
};
|
|
22
|
+
//#endregion
|
|
23
|
+
export { useResponsive };
|
|
24
|
+
//# sourceMappingURL=useResponsive.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useResponsive.d.ts","names":[],"sources":["../../src/platform/useResponsive.ts"],"sourcesContent":[],"mappings":";UAIU,WAAA;EAAA,EAAA,EAAA,MAAA;EASM,EAAA,EAAA,MAAA;;;;iBAAA,aAAA,UAAuB,QAAQ"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
import * as React$1 from "react";
|
|
5
|
+
|
|
6
|
+
//#region src/platform/useResponsive.ts
|
|
7
|
+
const DEFAULT = {
|
|
8
|
+
sm: 640,
|
|
9
|
+
md: 768,
|
|
10
|
+
lg: 1024,
|
|
11
|
+
xl: 1280
|
|
12
|
+
};
|
|
13
|
+
function useResponsive(custom) {
|
|
14
|
+
const bp = React$1.useMemo(() => ({
|
|
15
|
+
...DEFAULT,
|
|
16
|
+
...custom
|
|
17
|
+
}), [custom]);
|
|
18
|
+
const [width, setWidth] = React$1.useState(typeof window !== "undefined" ? window.innerWidth : bp.md);
|
|
19
|
+
React$1.useEffect(() => {
|
|
20
|
+
if (typeof window === "undefined") return;
|
|
21
|
+
const onResize = () => setWidth(window.innerWidth);
|
|
22
|
+
window.addEventListener("resize", onResize);
|
|
23
|
+
return () => window.removeEventListener("resize", onResize);
|
|
24
|
+
}, []);
|
|
25
|
+
const isSM = width >= bp.sm;
|
|
26
|
+
const isMD = width >= bp.md;
|
|
27
|
+
const isLG = width >= bp.lg;
|
|
28
|
+
return {
|
|
29
|
+
width,
|
|
30
|
+
breakpoints: bp,
|
|
31
|
+
isSM,
|
|
32
|
+
isMD,
|
|
33
|
+
isLG,
|
|
34
|
+
isXL: width >= bp.xl,
|
|
35
|
+
screen: isLG ? "desktop" : isSM ? "tablet" : "mobile"
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
//#endregion
|
|
40
|
+
export { useResponsive };
|
|
41
|
+
//# sourceMappingURL=useResponsive.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useResponsive.js","names":["DEFAULT: Breakpoints","React"],"sources":["../../src/platform/useResponsive.ts"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\n\ninterface Breakpoints {\n sm: number;\n md: number;\n lg: number;\n xl: number;\n}\n\nconst DEFAULT: Breakpoints = { sm: 640, md: 768, lg: 1024, xl: 1280 };\n\nexport function useResponsive(custom?: Partial<Breakpoints>) {\n const bp = React.useMemo(() => ({ ...DEFAULT, ...custom }), [custom]);\n const [width, setWidth] = React.useState<number>(\n typeof window !== 'undefined' ? window.innerWidth : bp.md\n );\n\n React.useEffect(() => {\n if (typeof window === 'undefined') return;\n const onResize = () => setWidth(window.innerWidth);\n window.addEventListener('resize', onResize);\n return () => window.removeEventListener('resize', onResize);\n }, []);\n\n const isSM = width >= bp.sm;\n const isMD = width >= bp.md;\n const isLG = width >= bp.lg;\n const isXL = width >= bp.xl;\n\n const screen: 'mobile' | 'tablet' | 'desktop' = isLG\n ? 'desktop'\n : isSM\n ? 'tablet'\n : 'mobile';\n\n return {\n width,\n breakpoints: bp,\n isSM,\n isMD,\n isLG,\n isXL,\n screen,\n } as const;\n}\n"],"mappings":";;;;;;AAWA,MAAMA,UAAuB;CAAE,IAAI;CAAK,IAAI;CAAK,IAAI;CAAM,IAAI;CAAM;AAErE,SAAgB,cAAc,QAA+B;CAC3D,MAAM,KAAKC,QAAM,eAAe;EAAE,GAAG;EAAS,GAAG;EAAQ,GAAG,CAAC,OAAO,CAAC;CACrE,MAAM,CAAC,OAAO,YAAYA,QAAM,SAC9B,OAAO,WAAW,cAAc,OAAO,aAAa,GAAG,GACxD;AAED,SAAM,gBAAgB;AACpB,MAAI,OAAO,WAAW,YAAa;EACnC,MAAM,iBAAiB,SAAS,OAAO,WAAW;AAClD,SAAO,iBAAiB,UAAU,SAAS;AAC3C,eAAa,OAAO,oBAAoB,UAAU,SAAS;IAC1D,EAAE,CAAC;CAEN,MAAM,OAAO,SAAS,GAAG;CACzB,MAAM,OAAO,SAAS,GAAG;CACzB,MAAM,OAAO,SAAS,GAAG;AASzB,QAAO;EACL;EACA,aAAa;EACb;EACA;EACA;EACA,MAdW,SAAS,GAAG;EAevB,QAb8C,OAC5C,YACA,OACE,WACA;EAUL"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
//#region src/platform/useResponsive.mobile.d.ts
|
|
2
|
+
interface Breakpoints {
|
|
3
|
+
sm: number;
|
|
4
|
+
md: number;
|
|
5
|
+
lg: number;
|
|
6
|
+
xl: number;
|
|
7
|
+
}
|
|
8
|
+
declare function useResponsive(custom?: Partial<Breakpoints>): {
|
|
9
|
+
readonly width: number;
|
|
10
|
+
readonly breakpoints: {
|
|
11
|
+
sm: number;
|
|
12
|
+
md: number;
|
|
13
|
+
lg: number;
|
|
14
|
+
xl: number;
|
|
15
|
+
};
|
|
16
|
+
readonly isSM: boolean;
|
|
17
|
+
readonly isMD: boolean;
|
|
18
|
+
readonly isLG: boolean;
|
|
19
|
+
readonly isXL: boolean;
|
|
20
|
+
readonly screen: "mobile" | "tablet" | "desktop";
|
|
21
|
+
};
|
|
22
|
+
//#endregion
|
|
23
|
+
export { useResponsive };
|
|
24
|
+
//# sourceMappingURL=useResponsive.mobile.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useResponsive.mobile.d.ts","names":[],"sources":["../../src/platform/useResponsive.mobile.ts"],"sourcesContent":[],"mappings":";UAKU,WAAA;EAAA,EAAA,EAAA,MAAA;EASM,EAAA,EAAA,MAAA;;;;iBAAA,aAAA,UAAuB,QAAQ"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
import { useEffect, useMemo, useState } from "react";
|
|
5
|
+
import { Dimensions } from "react-native";
|
|
6
|
+
|
|
7
|
+
//#region src/platform/useResponsive.mobile.ts
|
|
8
|
+
const DEFAULT = {
|
|
9
|
+
sm: 640,
|
|
10
|
+
md: 768,
|
|
11
|
+
lg: 1024,
|
|
12
|
+
xl: 1280
|
|
13
|
+
};
|
|
14
|
+
function useResponsive(custom) {
|
|
15
|
+
const bp = useMemo(() => ({
|
|
16
|
+
...DEFAULT,
|
|
17
|
+
...custom
|
|
18
|
+
}), [custom]);
|
|
19
|
+
const [width, setWidth] = useState(Dimensions.get("window").width);
|
|
20
|
+
useEffect(() => {
|
|
21
|
+
const sub = Dimensions.addEventListener("change", ({ window }) => {
|
|
22
|
+
setWidth(window.width);
|
|
23
|
+
});
|
|
24
|
+
return () => {
|
|
25
|
+
if (typeof sub?.remove === "function") sub.remove();
|
|
26
|
+
};
|
|
27
|
+
}, []);
|
|
28
|
+
const isSM = width >= bp.sm;
|
|
29
|
+
const isMD = width >= bp.md;
|
|
30
|
+
const isLG = width >= bp.lg;
|
|
31
|
+
return {
|
|
32
|
+
width,
|
|
33
|
+
breakpoints: bp,
|
|
34
|
+
isSM,
|
|
35
|
+
isMD,
|
|
36
|
+
isLG,
|
|
37
|
+
isXL: width >= bp.xl,
|
|
38
|
+
screen: isLG ? "desktop" : isSM ? "tablet" : "mobile"
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
//#endregion
|
|
43
|
+
export { useResponsive };
|
|
44
|
+
//# sourceMappingURL=useResponsive.mobile.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useResponsive.mobile.js","names":["DEFAULT: Breakpoints"],"sources":["../../src/platform/useResponsive.mobile.ts"],"sourcesContent":["'use client';\n\nimport { useEffect, useMemo, useState } from 'react';\nimport { Dimensions } from 'react-native';\n\ninterface Breakpoints {\n sm: number;\n md: number;\n lg: number;\n xl: number;\n}\n\nconst DEFAULT: Breakpoints = { sm: 640, md: 768, lg: 1024, xl: 1280 };\n\nexport function useResponsive(custom?: Partial<Breakpoints>) {\n const bp = useMemo(() => ({ ...DEFAULT, ...custom }), [custom]);\n const [width, setWidth] = useState<number>(Dimensions.get('window').width);\n\n useEffect(() => {\n const sub = Dimensions.addEventListener('change', ({ window }) => {\n setWidth(window.width);\n });\n return () => {\n // RN supports remove() on the subscription in newer versions\n if (typeof sub?.remove === 'function') {\n sub.remove();\n }\n };\n }, []);\n\n const isSM = width >= bp.sm;\n const isMD = width >= bp.md;\n const isLG = width >= bp.lg;\n const isXL = width >= bp.xl;\n\n const screen: 'mobile' | 'tablet' | 'desktop' = isLG\n ? 'desktop'\n : isSM\n ? 'tablet'\n : 'mobile';\n\n return {\n width,\n breakpoints: bp,\n isSM,\n isMD,\n isLG,\n isXL,\n screen,\n } as const;\n}\n"],"mappings":";;;;;;;AAYA,MAAMA,UAAuB;CAAE,IAAI;CAAK,IAAI;CAAK,IAAI;CAAM,IAAI;CAAM;AAErE,SAAgB,cAAc,QAA+B;CAC3D,MAAM,KAAK,eAAe;EAAE,GAAG;EAAS,GAAG;EAAQ,GAAG,CAAC,OAAO,CAAC;CAC/D,MAAM,CAAC,OAAO,YAAY,SAAiB,WAAW,IAAI,SAAS,CAAC,MAAM;AAE1E,iBAAgB;EACd,MAAM,MAAM,WAAW,iBAAiB,WAAW,EAAE,aAAa;AAChE,YAAS,OAAO,MAAM;IACtB;AACF,eAAa;AAEX,OAAI,OAAO,KAAK,WAAW,WACzB,KAAI,QAAQ;;IAGf,EAAE,CAAC;CAEN,MAAM,OAAO,SAAS,GAAG;CACzB,MAAM,OAAO,SAAS,GAAG;CACzB,MAAM,OAAO,SAAS,GAAG;AASzB,QAAO;EACL;EACA,aAAa;EACb;EACA;EACA;EACA,MAdW,SAAS,GAAG;EAevB,QAb8C,OAC5C,YACA,OACE,WACA;EAUL"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
//#region src/platform/withPlatformUI.d.ts
|
|
2
|
+
/**
|
|
3
|
+
* withPlatformUI
|
|
4
|
+
* Lightweight adapter inspired by gluestack's withGluestack pattern.
|
|
5
|
+
* It centralizes tokens and responsive options while keeping DS imports
|
|
6
|
+
* pointed at @ui-kit-web. Metro/Webpack aliases can swap to @ui-kit in native.
|
|
7
|
+
*/
|
|
8
|
+
type PlatformKind = 'web' | 'native';
|
|
9
|
+
interface Breakpoints {
|
|
10
|
+
sm: number;
|
|
11
|
+
md: number;
|
|
12
|
+
lg: number;
|
|
13
|
+
xl: number;
|
|
14
|
+
}
|
|
15
|
+
interface WithPlatformUIOptions<TTokens extends Record<string, unknown>> {
|
|
16
|
+
tokens: TTokens;
|
|
17
|
+
platform?: PlatformKind;
|
|
18
|
+
breakpoints?: Partial<Breakpoints>;
|
|
19
|
+
}
|
|
20
|
+
interface PlatformUI<TTokens> {
|
|
21
|
+
platform: PlatformKind;
|
|
22
|
+
tokens: TTokens;
|
|
23
|
+
breakpoints: Breakpoints;
|
|
24
|
+
}
|
|
25
|
+
declare const DEFAULT_BREAKPOINTS: Breakpoints;
|
|
26
|
+
declare function withPlatformUI<TTokens extends Record<string, unknown>>(options: WithPlatformUIOptions<TTokens>): PlatformUI<TTokens>;
|
|
27
|
+
//#endregion
|
|
28
|
+
export { Breakpoints, DEFAULT_BREAKPOINTS, PlatformKind, PlatformUI, WithPlatformUIOptions, withPlatformUI };
|
|
29
|
+
//# sourceMappingURL=withPlatformUI.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"withPlatformUI.d.ts","names":[],"sources":["../../src/platform/withPlatformUI.ts"],"sourcesContent":[],"mappings":";;AASA;AAEA;AAOA;;;AAIa,KAbD,YAAA,GAaC,KAAA,GAAA,QAAA;AACW,UAZP,WAAA,CAYO;EAAR,EAAA,EAAA,MAAA;EAAO,EAAA,EAAA,MAAA;EAGN,EAAA,EAAA,MAAA;EACL,EAAA,EAAA,MAAA;;AAEG,UAXE,qBAWF,CAAA,gBAVG,MAUH,CAAA,MAAA,EAAA,OAAA,CAAA,CAAA,CAAA;EAAW,MAAA,EARhB,OAQgB;EAGb,QAAA,CAAA,EAVA,YAeZ;EAEe,WAAA,CAAA,EAhBA,OAgBc,CAhBN,WAgBM,CAAA;;AACG,UAdhB,UAcgB,CAAA,OAAA,CAAA,CAAA;EAAtB,QAAA,EAbC,YAaD;EACG,MAAA,EAbJ,OAaI;EAAX,WAAA,EAZY,WAYZ;;cATU,qBAAqB;iBAOlB,+BAA+B,kCACpC,sBAAsB,WAC9B,WAAW"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
//#region src/platform/withPlatformUI.ts
|
|
5
|
+
const DEFAULT_BREAKPOINTS = {
|
|
6
|
+
sm: 640,
|
|
7
|
+
md: 768,
|
|
8
|
+
lg: 1024,
|
|
9
|
+
xl: 1280
|
|
10
|
+
};
|
|
11
|
+
function withPlatformUI(options) {
|
|
12
|
+
const platform = options.platform ?? "web";
|
|
13
|
+
const breakpoints = {
|
|
14
|
+
...DEFAULT_BREAKPOINTS,
|
|
15
|
+
...options.breakpoints
|
|
16
|
+
};
|
|
17
|
+
return {
|
|
18
|
+
platform,
|
|
19
|
+
tokens: options.tokens,
|
|
20
|
+
breakpoints
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Example usage (app-level):
|
|
25
|
+
*
|
|
26
|
+
* const ui = withPlatformUI({ tokens: themeTokens });
|
|
27
|
+
* // pass ui.tokens to DS providers or map classes as needed
|
|
28
|
+
*/
|
|
29
|
+
|
|
30
|
+
//#endregion
|
|
31
|
+
export { DEFAULT_BREAKPOINTS, withPlatformUI };
|
|
32
|
+
//# sourceMappingURL=withPlatformUI.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"withPlatformUI.js","names":["DEFAULT_BREAKPOINTS: Breakpoints","platform: PlatformKind","breakpoints: Breakpoints"],"sources":["../../src/platform/withPlatformUI.ts"],"sourcesContent":["'use client';\n\n/**\n * withPlatformUI\n * Lightweight adapter inspired by gluestack's withGluestack pattern.\n * It centralizes tokens and responsive options while keeping DS imports\n * pointed at @ui-kit-web. Metro/Webpack aliases can swap to @ui-kit in native.\n */\n\nexport type PlatformKind = 'web' | 'native';\n\nexport interface Breakpoints {\n sm: number;\n md: number;\n lg: number;\n xl: number;\n}\n\nexport interface WithPlatformUIOptions<\n TTokens extends Record<string, unknown>,\n> {\n tokens: TTokens;\n platform?: PlatformKind;\n breakpoints?: Partial<Breakpoints>;\n}\n\nexport interface PlatformUI<TTokens> {\n platform: PlatformKind;\n tokens: TTokens;\n breakpoints: Breakpoints;\n}\n\nexport const DEFAULT_BREAKPOINTS: Breakpoints = {\n sm: 640,\n md: 768,\n lg: 1024,\n xl: 1280,\n};\n\nexport function withPlatformUI<TTokens extends Record<string, unknown>>(\n options: WithPlatformUIOptions<TTokens>\n): PlatformUI<TTokens> {\n const platform: PlatformKind = options.platform ?? 'web';\n const breakpoints: Breakpoints = {\n ...DEFAULT_BREAKPOINTS,\n ...options.breakpoints,\n };\n return {\n platform,\n tokens: options.tokens,\n breakpoints,\n };\n}\n\n/**\n * Example usage (app-level):\n *\n * const ui = withPlatformUI({ tokens: themeTokens });\n * // pass ui.tokens to DS providers or map classes as needed\n */\n"],"mappings":";;;;AAgCA,MAAaA,sBAAmC;CAC9C,IAAI;CACJ,IAAI;CACJ,IAAI;CACJ,IAAI;CACL;AAED,SAAgB,eACd,SACqB;CACrB,MAAMC,WAAyB,QAAQ,YAAY;CACnD,MAAMC,cAA2B;EAC/B,GAAG;EACH,GAAG,QAAQ;EACZ;AACD,QAAO;EACL;EACA,QAAQ,QAAQ;EAChB;EACD"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as _lssm_lib_contracts_client_react_form_render0 from "@lssm/lib.contracts/client/react/form-render";
|
|
2
|
+
import * as react_jsx_runtime0 from "react/jsx-runtime";
|
|
3
|
+
import * as _lssm_lib_schema0 from "@lssm/lib.schema";
|
|
4
|
+
import * as _lssm_lib_contracts_forms0 from "@lssm/lib.contracts/forms";
|
|
5
|
+
|
|
6
|
+
//#region src/renderers/form-contract.d.ts
|
|
7
|
+
declare const formRenderer: {
|
|
8
|
+
render: (spec: _lssm_lib_contracts_forms0.FormSpec<_lssm_lib_schema0.AnySchemaModel>, options?: _lssm_lib_contracts_client_react_form_render0.RenderOptions<Record<string, any>> | undefined) => react_jsx_runtime0.JSX.Element;
|
|
9
|
+
};
|
|
10
|
+
//#endregion
|
|
11
|
+
export { formRenderer };
|
|
12
|
+
//# sourceMappingURL=form-contract.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"form-contract.d.ts","names":[],"sources":["../../src/renderers/form-contract.tsx"],"sourcesContent":[],"mappings":";;;;;;cAoFa;qDAiBX,iBAAA,CAAA,cAAA"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
import { Button } from "../components/atoms/Button.js";
|
|
5
|
+
import { Input } from "../components/atoms/Input.js";
|
|
6
|
+
import { Textarea } from "../components/atoms/Textarea.js";
|
|
7
|
+
import React from "react";
|
|
8
|
+
import { createFormRenderer } from "@lssm/lib.contracts/client/react/form-render";
|
|
9
|
+
import { shadcnDriver } from "@lssm/lib.contracts/client/react/drivers/shadcn";
|
|
10
|
+
import { Field, FieldDescription, FieldError, FieldGroup, FieldLabel } from "@lssm/lib.ui-kit-web/ui/field";
|
|
11
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
12
|
+
import { Switch } from "@lssm/lib.ui-kit-web/ui/switch";
|
|
13
|
+
import { RadioGroup, RadioGroupItem } from "@lssm/lib.ui-kit-web/ui/radio-group";
|
|
14
|
+
import { Checkbox } from "@lssm/lib.ui-kit-web/ui/checkbox";
|
|
15
|
+
import { Select, SelectContent, SelectGroup, SelectItem, SelectTrigger, SelectValue } from "@lssm/lib.ui-kit-web/ui/select";
|
|
16
|
+
import { Label } from "@lssm/lib.ui-kit-web/ui/label";
|
|
17
|
+
|
|
18
|
+
//#region src/renderers/form-contract.tsx
|
|
19
|
+
const Select$1 = (props) => {
|
|
20
|
+
const { options, value, onChange,...rest } = props;
|
|
21
|
+
return /* @__PURE__ */ jsxs(Select, {
|
|
22
|
+
value: value ?? "",
|
|
23
|
+
onValueChange: (v) => onChange?.(v),
|
|
24
|
+
...rest,
|
|
25
|
+
children: [/* @__PURE__ */ jsx(SelectTrigger, {
|
|
26
|
+
className: "w-[180px]",
|
|
27
|
+
children: /* @__PURE__ */ jsx(SelectValue, { placeholder: props.placeholder })
|
|
28
|
+
}), /* @__PURE__ */ jsx(SelectContent, { children: /* @__PURE__ */ jsx(SelectGroup, { children: options?.map((o, i) => /* @__PURE__ */ jsx(SelectItem, {
|
|
29
|
+
value: o.value,
|
|
30
|
+
disabled: o.disabled,
|
|
31
|
+
children: o.labelI18n
|
|
32
|
+
}, i)) }) })]
|
|
33
|
+
});
|
|
34
|
+
};
|
|
35
|
+
const Checkbox$1 = (props) => /* @__PURE__ */ jsx(Checkbox, {
|
|
36
|
+
checked: !!props.checked,
|
|
37
|
+
onCheckedChange: (v) => props.onCheckedChange?.(v),
|
|
38
|
+
...props
|
|
39
|
+
});
|
|
40
|
+
const RadioGroup$1 = (props) => /* @__PURE__ */ jsx(RadioGroup, {
|
|
41
|
+
...props,
|
|
42
|
+
children: props.options?.map((o, i) => /* @__PURE__ */ jsxs("div", {
|
|
43
|
+
className: "flex items-center gap-3",
|
|
44
|
+
children: [/* @__PURE__ */ jsx(RadioGroupItem, {
|
|
45
|
+
value: o.value,
|
|
46
|
+
id: o.value
|
|
47
|
+
}), /* @__PURE__ */ jsx(Label, {
|
|
48
|
+
htmlFor: o.value,
|
|
49
|
+
children: o.label
|
|
50
|
+
})]
|
|
51
|
+
}))
|
|
52
|
+
});
|
|
53
|
+
const Switch$1 = (props) => /* @__PURE__ */ jsx(Switch, {
|
|
54
|
+
checked: !!props.checked,
|
|
55
|
+
onCheckedChange: (v) => props.onCheckedChange?.(v),
|
|
56
|
+
...props
|
|
57
|
+
});
|
|
58
|
+
const formRenderer = createFormRenderer({ driver: shadcnDriver({
|
|
59
|
+
Field,
|
|
60
|
+
FieldLabel,
|
|
61
|
+
FieldDescription,
|
|
62
|
+
FieldError,
|
|
63
|
+
FieldGroup,
|
|
64
|
+
FieldSet: (p) => /* @__PURE__ */ jsx("fieldset", { ...p }),
|
|
65
|
+
FieldLegend: (p) => /* @__PURE__ */ jsx("legend", { ...p }),
|
|
66
|
+
Input,
|
|
67
|
+
Textarea,
|
|
68
|
+
Select: Select$1,
|
|
69
|
+
Checkbox: Checkbox$1,
|
|
70
|
+
RadioGroup: RadioGroup$1,
|
|
71
|
+
Switch: Switch$1,
|
|
72
|
+
Button
|
|
73
|
+
}) });
|
|
74
|
+
|
|
75
|
+
//#endregion
|
|
76
|
+
export { formRenderer };
|
|
77
|
+
//# sourceMappingURL=form-contract.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"form-contract.js","names":["Select","SelectUiKit","Checkbox","CheckboxUiKit","RadioGroup","RadioGroupUiKit","Switch","SwitchUiKit","FieldWrap"],"sources":["../../src/renderers/form-contract.tsx"],"sourcesContent":["'use client';\nimport React from 'react';\nimport { createFormRenderer } from '@lssm/lib.contracts/client/react/form-render';\nimport { shadcnDriver } from '@lssm/lib.contracts/client/react/drivers/shadcn';\n\n// Minimal shadcn driver mapping: host must wire its components here.\n// Replace these placeholders with actual shadcn/ui imports in your app.\nimport {\n Field as FieldWrap,\n FieldDescription,\n FieldError,\n FieldGroup,\n FieldLabel,\n} from '@lssm/lib.ui-kit-web/ui/field';\nimport { Button } from '../components/atoms/Button';\nimport { Input } from '../components/atoms/Input';\nimport { Textarea } from '../components/atoms/Textarea';\nimport { Switch as SwitchUiKit } from '@lssm/lib.ui-kit-web/ui/switch';\nimport {\n RadioGroup as RadioGroupUiKit,\n RadioGroupItem,\n} from '@lssm/lib.ui-kit-web/ui/radio-group';\nimport { Checkbox as CheckboxUiKit } from '@lssm/lib.ui-kit-web/ui/checkbox';\nimport {\n Select as SelectUiKit,\n SelectContent,\n SelectGroup,\n SelectItem,\n SelectTrigger,\n SelectValue,\n} from '@lssm/lib.ui-kit-web/ui/select';\nimport { Label } from '@lssm/lib.ui-kit-web/ui/label';\n\n// Select/Checkbox/Radio/Switch are app-specific; provide thin wrappers.\nconst Select = (props: any) => {\n const { options, value, onChange, ...rest } = props;\n return (\n <SelectUiKit\n value={value ?? ''}\n onValueChange={(v) => onChange?.(v)}\n {...rest}\n >\n <SelectTrigger className=\"w-[180px]\">\n <SelectValue placeholder={props.placeholder} />\n </SelectTrigger>\n <SelectContent>\n <SelectGroup>\n {/* <SelectLabel>Fruits</SelectLabel> */}\n {/* <SelectItem value=\"\" disabled hidden></SelectItem> */}\n {options?.map((o: any, i: number) => (\n <SelectItem key={i} value={o.value} disabled={o.disabled}>\n {o.labelI18n}\n </SelectItem>\n ))}\n </SelectGroup>\n </SelectContent>\n </SelectUiKit>\n );\n};\nconst Checkbox = (props: any) => (\n <CheckboxUiKit\n checked={!!props.checked}\n onCheckedChange={(v) => props.onCheckedChange?.(v)}\n {...props}\n />\n);\nconst RadioGroup = (props: any) => (\n <RadioGroupUiKit {...props}>\n {props.options?.map((o: any, i: number) => (\n <div className=\"flex items-center gap-3\">\n <RadioGroupItem value={o.value} id={o.value} />\n <Label htmlFor={o.value}>{o.label}</Label>\n </div>\n ))}\n </RadioGroupUiKit>\n);\nconst Switch = (props: any) => (\n <SwitchUiKit\n checked={!!props.checked}\n onCheckedChange={(v) => props.onCheckedChange?.(v)}\n {...props}\n />\n);\n\nexport const formRenderer = createFormRenderer({\n driver: shadcnDriver({\n Field: FieldWrap,\n FieldLabel: FieldLabel,\n FieldDescription: FieldDescription,\n FieldError: FieldError,\n FieldGroup: FieldGroup,\n FieldSet: (p: any) => <fieldset {...p} />,\n FieldLegend: (p: any) => <legend {...p} />,\n Input: Input as any,\n Textarea: Textarea as any,\n Select: Select,\n Checkbox: Checkbox,\n RadioGroup: RadioGroup,\n Switch: Switch,\n Button: Button as any,\n }),\n});\n"],"mappings":";;;;;;;;;;;;;;;;;;AAkCA,MAAMA,YAAU,UAAe;CAC7B,MAAM,EAAE,SAAS,OAAO,SAAU,GAAG,SAAS;AAC9C,QACE,qBAACC;EACC,OAAO,SAAS;EAChB,gBAAgB,MAAM,WAAW,EAAE;EACnC,GAAI;aAEJ,oBAAC;GAAc,WAAU;aACvB,oBAAC,eAAY,aAAa,MAAM,cAAe;IACjC,EAChB,oBAAC,2BACC,oBAAC,yBAGE,SAAS,KAAK,GAAQ,MACrB,oBAAC;GAAmB,OAAO,EAAE;GAAO,UAAU,EAAE;aAC7C,EAAE;KADY,EAEJ,CACb,GACU,GACA;GACJ;;AAGlB,MAAMC,cAAY,UAChB,oBAACC;CACC,SAAS,CAAC,CAAC,MAAM;CACjB,kBAAkB,MAAM,MAAM,kBAAkB,EAAE;CAClD,GAAI;EACJ;AAEJ,MAAMC,gBAAc,UAClB,oBAACC;CAAgB,GAAI;WAClB,MAAM,SAAS,KAAK,GAAQ,MAC3B,qBAAC;EAAI,WAAU;aACb,oBAAC;GAAe,OAAO,EAAE;GAAO,IAAI,EAAE;IAAS,EAC/C,oBAAC;GAAM,SAAS,EAAE;aAAQ,EAAE;IAAc;GACtC,CACN;EACc;AAEpB,MAAMC,YAAU,UACd,oBAACC;CACC,SAAS,CAAC,CAAC,MAAM;CACjB,kBAAkB,MAAM,MAAM,kBAAkB,EAAE;CAClD,GAAI;EACJ;AAGJ,MAAa,eAAe,mBAAmB,EAC7C,QAAQ,aAAa;CACZC;CACK;CACM;CACN;CACA;CACZ,WAAW,MAAW,oBAAC,cAAS,GAAI,IAAK;CACzC,cAAc,MAAW,oBAAC,YAAO,GAAI,IAAK;CACnC;CACG;CACV,QAAQR;CACR,UAAUE;CACV,YAAYE;CACZ,QAAQE;CACA;CACT,CAAC,EACH,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { ColorTokens, RadiusTokens, SpaceTokens, defaultTokens } from "./tokens.js";
|
|
2
|
+
|
|
3
|
+
//#region src/theme/tokenBridge.d.ts
|
|
4
|
+
type PlatformKind = 'web' | 'native';
|
|
5
|
+
type WebTokens = typeof defaultTokens;
|
|
6
|
+
interface NativeTokens {
|
|
7
|
+
colors: ColorTokens;
|
|
8
|
+
spacing: SpaceTokens;
|
|
9
|
+
typography: {
|
|
10
|
+
h1: number;
|
|
11
|
+
body: number;
|
|
12
|
+
};
|
|
13
|
+
radii: RadiusTokens;
|
|
14
|
+
icons: Record<string, number>;
|
|
15
|
+
}
|
|
16
|
+
type BridgedTokens = WebTokens | NativeTokens;
|
|
17
|
+
declare function mapTokensForPlatform(platform: PlatformKind): BridgedTokens;
|
|
18
|
+
//#endregion
|
|
19
|
+
export { BridgedTokens, PlatformKind, mapTokensForPlatform };
|
|
20
|
+
//# sourceMappingURL=tokenBridge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tokenBridge.d.ts","names":[],"sources":["../../src/theme/tokenBridge.ts"],"sourcesContent":[],"mappings":";;;KASY,YAAA;KAEP,SAAA,UAAmB;AAFxB,UAIU,YAAA,CAJc;EAEnB,MAAA,EAIK,WAJI;EAEJ,OAAA,EAGC,WAHW;EAEZ,UAAA,EAAA;IACC,EAAA,EAAA,MAAA;IAKF,IAAA,EAAA,MAAA;EACA,CAAA;EAAM,KAAA,EADN,YACM;EAGH,KAAA,EAHH,MAGG,CAAA,MAAa,EAAA,MAAG,CAAA;AAE5B;KAFY,aAAA,GAAgB,YAAY;iBAExB,oBAAA,WAA+B,eAAe"}
|