@lssm/lib.design-system 1.2.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/dist/_virtual/rolldown_runtime.js +33 -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 +1 -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 +46 -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 +28 -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 +21 -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 +23 -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 +31 -0
- package/dist/components/data-view/DataViewRenderer.d.ts.map +1 -0
- package/dist/components/data-view/DataViewRenderer.js +69 -0
- package/dist/components/data-view/DataViewRenderer.js.map +1 -0
- package/dist/components/data-view/DataViewTable.d.ts +25 -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 +29 -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 +31 -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 +58 -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 +67 -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 +25 -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 +25 -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 +25 -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 +47 -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 +39 -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 +45 -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 +46 -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 +37 -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 +31 -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 +53 -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 +52 -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 +47 -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 +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 +90 -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/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 +29 -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 +27 -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 +30 -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 +52 -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 +35 -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 +15 -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 +1 -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 +1 -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 +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 +70 -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 +58 -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 +30 -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 +49 -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 +33 -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 +47 -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 +41 -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 +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.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 +3 -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 +56 -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 +30 -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 +102 -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 +125 -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 +60 -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 +72 -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 +28 -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 +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 +3 -0
- package/dist/contracts/src/client/react/drivers/shadcn.js +12 -0
- package/dist/contracts/src/client/react/drivers/shadcn.js.map +1 -0
- package/dist/contracts/src/client/react/form-render.js +299 -0
- package/dist/contracts/src/client/react/form-render.js.map +1 -0
- package/dist/contracts/src/forms.js +89 -0
- package/dist/contracts/src/forms.js.map +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 +9 -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 +3 -0
- package/dist/ui-kit/dist/ui/button.js +75 -0
- package/dist/ui-kit/dist/ui/button.js.map +1 -0
- package/dist/ui-kit/dist/ui/empty.js +63 -0
- package/dist/ui-kit/dist/ui/empty.js.map +1 -0
- package/dist/ui-kit/dist/ui/input.js +17 -0
- package/dist/ui-kit/dist/ui/input.js.map +1 -0
- package/dist/ui-kit/dist/ui/stack.js +224 -0
- package/dist/ui-kit/dist/ui/stack.js.map +1 -0
- package/dist/ui-kit/dist/ui/text.js +19 -0
- package/dist/ui-kit/dist/ui/text.js.map +1 -0
- package/dist/ui-kit/dist/ui/textarea.js +20 -0
- package/dist/ui-kit/dist/ui/textarea.js.map +1 -0
- package/dist/ui-kit/dist/ui/utils.js +11 -0
- package/dist/ui-kit/dist/ui/utils.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/accordion.js +50 -0
- package/dist/ui-kit-web/dist/ui/accordion.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/atoms/FilterSelect/FilterSelect.js +53 -0
- package/dist/ui-kit-web/dist/ui/atoms/FilterSelect/FilterSelect.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/atoms/Pagination/Pagination.js +157 -0
- package/dist/ui-kit-web/dist/ui/atoms/Pagination/Pagination.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/atoms/SearchInput/SearchInput.js +50 -0
- package/dist/ui-kit-web/dist/ui/atoms/SearchInput/SearchInput.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/avatar.js +35 -0
- package/dist/ui-kit-web/dist/ui/avatar.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/badge.js +28 -0
- package/dist/ui-kit-web/dist/ui/badge.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/breadcrumb.js +60 -0
- package/dist/ui-kit-web/dist/ui/breadcrumb.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/button.js +45 -0
- package/dist/ui-kit-web/dist/ui/button.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/card.js +38 -0
- package/dist/ui-kit-web/dist/ui/card.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/carousel.js +138 -0
- package/dist/ui-kit-web/dist/ui/carousel.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/checkbox.js +27 -0
- package/dist/ui-kit-web/dist/ui/checkbox.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/collapsible.js +29 -0
- package/dist/ui-kit-web/dist/ui/collapsible.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/command.js +92 -0
- package/dist/ui-kit-web/dist/ui/command.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/dialog.js +86 -0
- package/dist/ui-kit-web/dist/ui/dialog.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/dropdown-menu.js +59 -0
- package/dist/ui-kit-web/dist/ui/dropdown-menu.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/empty-state.js +44 -0
- package/dist/ui-kit-web/dist/ui/empty-state.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/empty.js +63 -0
- package/dist/ui-kit-web/dist/ui/empty.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/field.js +80 -0
- package/dist/ui-kit-web/dist/ui/field.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/form.js +18 -0
- package/dist/ui-kit-web/dist/ui/form.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/hover-card.js +42 -0
- package/dist/ui-kit-web/dist/ui/hover-card.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/input.js +18 -0
- package/dist/ui-kit-web/dist/ui/input.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/label.js +21 -0
- package/dist/ui-kit-web/dist/ui/label.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/marketing/Hero.js +54 -0
- package/dist/ui-kit-web/dist/ui/marketing/Hero.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/marketing/PricingTable.js +61 -0
- package/dist/ui-kit-web/dist/ui/marketing/PricingTable.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/molecules/SearchAndFilter/SearchAndFilter.js +103 -0
- package/dist/ui-kit-web/dist/ui/molecules/SearchAndFilter/SearchAndFilter.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/molecules/SkeletonList.js +15 -0
- package/dist/ui-kit-web/dist/ui/molecules/SkeletonList.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/navigation-menu.js +76 -0
- package/dist/ui-kit-web/dist/ui/navigation-menu.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/organisms/ListPage/ListPage.js +198 -0
- package/dist/ui-kit-web/dist/ui/organisms/ListPage/ListPage.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/page-header.js +41 -0
- package/dist/ui-kit-web/dist/ui/page-header.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/radio-group.js +34 -0
- package/dist/ui-kit-web/dist/ui/radio-group.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/select.js +88 -0
- package/dist/ui-kit-web/dist/ui/select.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/separator.js +23 -0
- package/dist/ui-kit-web/dist/ui/separator.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/sheet.js +82 -0
- package/dist/ui-kit-web/dist/ui/sheet.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/sidebar.js +381 -0
- package/dist/ui-kit-web/dist/ui/sidebar.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/skeleton.js +16 -0
- package/dist/ui-kit-web/dist/ui/skeleton.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/stack.js +159 -0
- package/dist/ui-kit-web/dist/ui/stack.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/stepper.js +38 -0
- package/dist/ui-kit-web/dist/ui/stepper.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/switch.js +25 -0
- package/dist/ui-kit-web/dist/ui/switch.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/table.js +59 -0
- package/dist/ui-kit-web/dist/ui/table.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/text.js +17 -0
- package/dist/ui-kit-web/dist/ui/text.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/textarea.js +17 -0
- package/dist/ui-kit-web/dist/ui/textarea.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/tooltip.js +42 -0
- package/dist/ui-kit-web/dist/ui/tooltip.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/use-mobile.js +21 -0
- package/dist/ui-kit-web/dist/ui/use-mobile.js.map +1 -0
- package/dist/ui-kit-web/dist/ui/utils.js +14 -0
- package/dist/ui-kit-web/dist/ui/utils.js.map +1 -0
- package/package.json +348 -0
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { FiltersToolbar } from "../../../molecules/FiltersToolbar.mobile.js";
|
|
2
|
+
import { FlatListScreen } from "../../../native/FlatListScreen.mobile.js";
|
|
3
|
+
import { EmptyDataList } from "../../../organisms/EmptyDataList.mobile.js";
|
|
4
|
+
import { PageHeaderResponsive } from "../../../organisms/PageHeaderResponsive.mobile.js";
|
|
5
|
+
import "react";
|
|
6
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
7
|
+
|
|
8
|
+
//#region src/components/templates/lists/ListPageTemplate/index.mobile.tsx
|
|
9
|
+
function ListPageTemplate({ children, title, description, breadcrumb, actions, searchPlaceholder, searchValue, onSearchChange, onSearchSubmit, isLoading, data, renderItem, emptyProps }) {
|
|
10
|
+
return /* @__PURE__ */ jsx(FlatListScreen, {
|
|
11
|
+
refreshing: isLoading,
|
|
12
|
+
header: /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsx(PageHeaderResponsive, {
|
|
13
|
+
title,
|
|
14
|
+
subtitle: description,
|
|
15
|
+
breadcrumb,
|
|
16
|
+
actions
|
|
17
|
+
}), /* @__PURE__ */ jsx(FiltersToolbar, {
|
|
18
|
+
searchPlaceholder,
|
|
19
|
+
searchValue,
|
|
20
|
+
onSearchChange,
|
|
21
|
+
onSearchSubmit
|
|
22
|
+
})] }),
|
|
23
|
+
data: data ?? [],
|
|
24
|
+
renderItem,
|
|
25
|
+
showsVerticalScrollIndicator: false,
|
|
26
|
+
padding: "md",
|
|
27
|
+
emptyComponent: emptyProps ? /* @__PURE__ */ jsx(EmptyDataList, { ...emptyProps }) : void 0
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
//#endregion
|
|
32
|
+
export { ListPageTemplate };
|
|
33
|
+
//# sourceMappingURL=index.mobile.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mobile.js","names":[],"sources":["../../../../../src/components/templates/lists/ListPageTemplate/index.mobile.tsx"],"sourcesContent":["import * as React from 'react';\nimport type { ListRenderItem } from 'react-native';\nimport { FiltersToolbar } from '../../../molecules/FiltersToolbar.mobile';\nimport { PageHeaderResponsive } from '../../../organisms/PageHeaderResponsive.mobile';\nimport { FlatListScreen } from '../../../native/FlatListScreen.mobile';\nimport type { ListPageTemplateProps } from './types';\nimport { EmptyDataList } from '../../../organisms/EmptyDataList.mobile';\n\nexport * from './types';\n\nexport function ListPageTemplate<T = any>({\n children,\n title,\n description,\n breadcrumb,\n actions,\n searchPlaceholder,\n searchValue,\n onSearchChange,\n onSearchSubmit,\n isLoading,\n data,\n renderItem,\n emptyProps,\n}: ListPageTemplateProps<T>) {\n const header = (\n <>\n <PageHeaderResponsive\n title={title}\n subtitle={description}\n breadcrumb={breadcrumb}\n actions={actions}\n />\n <FiltersToolbar\n searchPlaceholder={searchPlaceholder}\n searchValue={searchValue}\n onSearchChange={onSearchChange}\n onSearchSubmit={onSearchSubmit}\n />\n </>\n );\n\n return (\n <FlatListScreen\n refreshing={isLoading}\n header={header}\n data={data ?? []}\n renderItem={renderItem as unknown as ListRenderItem<T>}\n showsVerticalScrollIndicator={false}\n padding=\"md\"\n emptyComponent={\n emptyProps ? <EmptyDataList {...emptyProps} /> : undefined\n }\n />\n );\n}\n"],"mappings":";;;;;;;;AAUA,SAAgB,iBAA0B,EACxC,UACA,OACA,aACA,YACA,SACA,mBACA,aACA,gBACA,gBACA,WACA,MACA,YACA,cAC2B;AAkB3B,QACE,oBAAC;EACC,YAAY;EACZ,QAnBF,4CACE,oBAAC;GACQ;GACP,UAAU;GACE;GACH;IACT,EACF,oBAAC;GACoB;GACN;GACG;GACA;IAChB,IACD;EAOD,MAAM,QAAQ,EAAE;EACJ;EACZ,8BAA8B;EAC9B,SAAQ;EACR,gBACE,aAAa,oBAAC,iBAAc,GAAI,aAAc,GAAG;GAEnD"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ListPageTemplateProps } from "./types.js";
|
|
2
|
+
import * as react_jsx_runtime108 from "react/jsx-runtime";
|
|
3
|
+
|
|
4
|
+
//#region src/components/templates/lists/ListPageTemplate/index.web.d.ts
|
|
5
|
+
declare function ListPageTemplate<T = any>({
|
|
6
|
+
children,
|
|
7
|
+
title,
|
|
8
|
+
description,
|
|
9
|
+
breadcrumb,
|
|
10
|
+
actions,
|
|
11
|
+
className,
|
|
12
|
+
searchPlaceholder,
|
|
13
|
+
searchValue,
|
|
14
|
+
onSearchChange,
|
|
15
|
+
onSearchSubmit,
|
|
16
|
+
isLoading,
|
|
17
|
+
data,
|
|
18
|
+
renderItem,
|
|
19
|
+
emptyProps
|
|
20
|
+
}: ListPageTemplateProps<T>): react_jsx_runtime108.JSX.Element;
|
|
21
|
+
//#endregion
|
|
22
|
+
export { ListPageTemplate, ListPageTemplateProps };
|
|
23
|
+
//# sourceMappingURL=index.web.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.web.d.ts","names":[],"sources":["../../../../../src/components/templates/lists/ListPageTemplate/index.web.tsx"],"sourcesContent":[],"mappings":";;;;iBAegB;;;;;;;;;;;;;;;GAeb,sBAAsB,KAAE,oBAAA,CAAA,GAAA,CAAA"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { cn, init_utils } from "../../../../ui-kit-web/dist/ui/utils.js";
|
|
2
|
+
import { Skeleton } from "../../../../ui-kit-web/dist/ui/skeleton.js";
|
|
3
|
+
import { Card, CardContent } from "../../../../ui-kit-web/dist/ui/card.js";
|
|
4
|
+
import { PageHeaderResponsive } from "../../../organisms/PageHeaderResponsive.js";
|
|
5
|
+
import { FiltersToolbar } from "../../../molecules/FiltersToolbar.mobile.js";
|
|
6
|
+
import { AiLinkButton } from "../../../molecules/AiLinkButton.js";
|
|
7
|
+
import { EmptyDataList } from "../../../organisms/EmptyDataList.js";
|
|
8
|
+
import * as React$1 from "react";
|
|
9
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
10
|
+
import { cva } from "class-variance-authority";
|
|
11
|
+
|
|
12
|
+
//#region src/components/templates/lists/ListPageTemplate/index.web.tsx
|
|
13
|
+
init_utils();
|
|
14
|
+
const containerVariants = cva("space-y-4 md:space-y-6");
|
|
15
|
+
function ListPageTemplate({ children, title, description, breadcrumb, actions, className, searchPlaceholder, searchValue, onSearchChange, onSearchSubmit, isLoading, data, renderItem, emptyProps }) {
|
|
16
|
+
const mdHref = React$1.useMemo(() => {
|
|
17
|
+
if (typeof window === "undefined") return void 0;
|
|
18
|
+
const url = new URL(window.location.href);
|
|
19
|
+
url.pathname = url.pathname.replace(/\/$/, "") + ".md";
|
|
20
|
+
return url.toString();
|
|
21
|
+
}, []);
|
|
22
|
+
const renderEmpty = () => {
|
|
23
|
+
return /* @__PURE__ */ jsx(Card, { children: /* @__PURE__ */ jsx(CardContent, { children: /* @__PURE__ */ jsx(EmptyDataList, { ...emptyProps }) }) });
|
|
24
|
+
};
|
|
25
|
+
return /* @__PURE__ */ jsxs("div", {
|
|
26
|
+
className: cn(containerVariants(), className),
|
|
27
|
+
children: [
|
|
28
|
+
/* @__PURE__ */ jsx(PageHeaderResponsive, {
|
|
29
|
+
title,
|
|
30
|
+
subtitle: description,
|
|
31
|
+
breadcrumb,
|
|
32
|
+
actions: /* @__PURE__ */ jsxs(Fragment, { children: [actions, mdHref && /* @__PURE__ */ jsx(AiLinkButton, { href: mdHref })] })
|
|
33
|
+
}),
|
|
34
|
+
/* @__PURE__ */ jsx(FiltersToolbar, {
|
|
35
|
+
searchPlaceholder,
|
|
36
|
+
searchValue,
|
|
37
|
+
onSearchChange,
|
|
38
|
+
onSearchSubmit
|
|
39
|
+
}),
|
|
40
|
+
/* @__PURE__ */ jsxs("div", {
|
|
41
|
+
className: "space-y-2",
|
|
42
|
+
children: [data?.map((item, index) => /* @__PURE__ */ jsx("div", { children: renderItem({
|
|
43
|
+
item,
|
|
44
|
+
index
|
|
45
|
+
}) }, index)), !data?.length && (isLoading ? Array.from({ length: 10 }).map((_, index) => /* @__PURE__ */ jsx(Skeleton, { className: "h-20 w-full rounded-md" }, index)) : renderEmpty())]
|
|
46
|
+
}),
|
|
47
|
+
children
|
|
48
|
+
]
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
//#endregion
|
|
53
|
+
export { ListPageTemplate };
|
|
54
|
+
//# sourceMappingURL=index.web.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.web.js","names":["React"],"sources":["../../../../../src/components/templates/lists/ListPageTemplate/index.web.tsx"],"sourcesContent":["import * as React from 'react';\nimport { cva } from 'class-variance-authority';\nimport { cn } from '@lssm/lib.ui-kit-web/ui/utils';\nimport { PageHeaderResponsive } from '../../../organisms/PageHeaderResponsive';\nimport { FiltersToolbar } from '../../../molecules/FiltersToolbar.mobile';\nimport { AiLinkButton } from '../../../molecules/AiLinkButton';\nimport type { ListPageTemplateProps } from './types';\nimport { Skeleton } from '@lssm/lib.ui-kit-web/ui/skeleton';\nimport { Card, CardContent } from '@lssm/lib.ui-kit-web/ui/card';\nimport { EmptyDataList } from '../../../organisms/EmptyDataList';\n\nconst containerVariants = cva('space-y-4 md:space-y-6');\n\nexport * from './types';\n\nexport function ListPageTemplate<T = any>({\n children,\n title,\n description,\n breadcrumb,\n actions,\n className,\n searchPlaceholder,\n searchValue,\n onSearchChange,\n onSearchSubmit,\n isLoading,\n data,\n renderItem,\n emptyProps,\n}: ListPageTemplateProps<T>) {\n const mdHref = React.useMemo(() => {\n if (typeof window === 'undefined') return undefined;\n const url = new URL(window.location.href);\n url.pathname = url.pathname.replace(/\\/$/, '') + '.md';\n return url.toString();\n }, []);\n\n const renderEmpty = () => {\n return (\n <Card>\n <CardContent>\n <EmptyDataList {...emptyProps} />\n </CardContent>\n </Card>\n );\n };\n\n return (\n <div className={cn(containerVariants(), className)}>\n <PageHeaderResponsive\n title={title}\n subtitle={description}\n breadcrumb={breadcrumb}\n actions={\n <>\n {actions}\n {mdHref && <AiLinkButton href={mdHref} />}\n </>\n }\n />\n <FiltersToolbar\n searchPlaceholder={searchPlaceholder}\n searchValue={searchValue}\n onSearchChange={onSearchChange}\n onSearchSubmit={onSearchSubmit}\n />\n <div className=\"space-y-2\">\n {data?.map((item, index) => (\n <div key={index}>{renderItem({ item, index })}</div>\n ))}\n {!data?.length &&\n (isLoading\n ? Array.from({ length: 10 }).map((_, index) => (\n <Skeleton key={index} className=\"h-20 w-full rounded-md\" />\n ))\n : renderEmpty())}\n </div>\n\n {children}\n </div>\n );\n}\n"],"mappings":";;;;;;;;;;;;YAEmD;AASnD,MAAM,oBAAoB,IAAI,yBAAyB;AAIvD,SAAgB,iBAA0B,EACxC,UACA,OACA,aACA,YACA,SACA,WACA,mBACA,aACA,gBACA,gBACA,WACA,MACA,YACA,cAC2B;CAC3B,MAAM,SAASA,QAAM,cAAc;AACjC,MAAI,OAAO,WAAW,YAAa,QAAO;EAC1C,MAAM,MAAM,IAAI,IAAI,OAAO,SAAS,KAAK;AACzC,MAAI,WAAW,IAAI,SAAS,QAAQ,OAAO,GAAG,GAAG;AACjD,SAAO,IAAI,UAAU;IACpB,EAAE,CAAC;CAEN,MAAM,oBAAoB;AACxB,SACE,oBAAC,kBACC,oBAAC,yBACC,oBAAC,iBAAc,GAAI,aAAc,GACrB,GACT;;AAIX,QACE,qBAAC;EAAI,WAAW,GAAG,mBAAmB,EAAE,UAAU;;GAChD,oBAAC;IACQ;IACP,UAAU;IACE;IACZ,SACE,4CACG,SACA,UAAU,oBAAC,gBAAa,MAAM,SAAU,IACxC;KAEL;GACF,oBAAC;IACoB;IACN;IACG;IACA;KAChB;GACF,qBAAC;IAAI,WAAU;eACZ,MAAM,KAAK,MAAM,UAChB,oBAAC,mBAAiB,WAAW;KAAE;KAAM;KAAO,CAAC,IAAnC,MAA0C,CACpD,EACD,CAAC,MAAM,WACL,YACG,MAAM,KAAK,EAAE,QAAQ,IAAI,CAAC,CAAC,KAAK,GAAG,UACjC,oBAAC,YAAqB,WAAU,4BAAjB,MAA4C,CAC3D,GACF,aAAa;KACf;GAEL;;GACG"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { EmptyDataListProps } from "../../../organisms/EmptyDataList.types.js";
|
|
2
|
+
import * as React$1 from "react";
|
|
3
|
+
|
|
4
|
+
//#region src/components/templates/lists/ListPageTemplate/types.d.ts
|
|
5
|
+
interface ListPageTemplateProps<T = any> {
|
|
6
|
+
children?: React$1.ReactNode;
|
|
7
|
+
title: React$1.ReactNode;
|
|
8
|
+
description?: React$1.ReactNode;
|
|
9
|
+
breadcrumb?: React$1.ReactNode;
|
|
10
|
+
actions?: React$1.ReactNode;
|
|
11
|
+
className?: string;
|
|
12
|
+
searchPlaceholder?: string;
|
|
13
|
+
searchValue?: string;
|
|
14
|
+
onSearchChange?: (v: string) => void;
|
|
15
|
+
onSearchSubmit?: () => void;
|
|
16
|
+
isLoading?: boolean;
|
|
17
|
+
data: T[] | null;
|
|
18
|
+
renderItem: (args: {
|
|
19
|
+
item: T;
|
|
20
|
+
index: number;
|
|
21
|
+
}) => React$1.ReactNode;
|
|
22
|
+
emptyProps: EmptyDataListProps;
|
|
23
|
+
}
|
|
24
|
+
//#endregion
|
|
25
|
+
export { ListPageTemplateProps };
|
|
26
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","names":[],"sources":["../../../../../src/components/templates/lists/ListPageTemplate/types.ts"],"sourcesContent":[],"mappings":";;;;UAGiB;aACJ,OAAA,CAAM;EADF,KAAA,EAER,OAAA,CAAM,SAFE;EACJ,WAAM,CAAA,EAEH,OAAA,CAAM,SAFH;EACV,UAAM,CAAA,EAEA,OAAA,CAAM,SAFN;EACC,OAAM,CAAA,EAEV,OAAA,CAAM,SAFI;EACP,SAAM,CAAA,EAAA,MAAA;EACT,iBAAM,CAAA,EAAA,MAAA;EASV,WAAA,CAAA,EAAA,MAAA;EACqB,cAAA,CAAA,EAAA,CAAA,CAAA,EAAA,MAAA,EAAA,GAAA,IAAA;EAAuB,cAAM,CAAA,EAAA,GAAA,GAAA,IAAA;EAC5C,SAAA,CAAA,EAAA,OAAA;EAAkB,IAAA,EAFxB,CAEwB,EAAA,GAAA,IAAA;;UADH;;QAAuB,OAAA,CAAM;cAC5C"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
//#region ../contracts/src/client/react/drivers/shadcn.ts
|
|
2
|
+
/**
|
|
3
|
+
* Create a shadcn/ui driver by mapping required slots to components.
|
|
4
|
+
* Host apps should import their shadcn primitives and pass them here.
|
|
5
|
+
*/
|
|
6
|
+
function shadcnDriver(slots) {
|
|
7
|
+
return slots;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
//#endregion
|
|
11
|
+
export { shadcnDriver };
|
|
12
|
+
//# sourceMappingURL=shadcn.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shadcn.js","names":[],"sources":["../../../../../../../contracts/src/client/react/drivers/shadcn.ts"],"sourcesContent":["import type { DriverSlots } from '../form-render';\n\n/**\n * Create a shadcn/ui driver by mapping required slots to components.\n * Host apps should import their shadcn primitives and pass them here.\n */\nexport function shadcnDriver(slots: DriverSlots): DriverSlots {\n return slots;\n}\n\nexport type ShadcnDriver = ReturnType<typeof shadcnDriver>;\n"],"mappings":";;;;;AAMA,SAAgB,aAAa,OAAiC;AAC5D,QAAO"}
|
|
@@ -0,0 +1,299 @@
|
|
|
1
|
+
import { buildZodWithRelations, evalPredicate } from "../../forms.js";
|
|
2
|
+
import React, { useEffect, useMemo, useState } from "react";
|
|
3
|
+
import { Controller, useFieldArray, useForm } from "react-hook-form";
|
|
4
|
+
import { zodResolver } from "@hookform/resolvers/zod";
|
|
5
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
6
|
+
|
|
7
|
+
//#region ../contracts/src/client/react/form-render.tsx
|
|
8
|
+
function toOptionsArray(src) {
|
|
9
|
+
if (!src) return void 0;
|
|
10
|
+
if (Array.isArray(src)) return {
|
|
11
|
+
kind: "static",
|
|
12
|
+
options: src
|
|
13
|
+
};
|
|
14
|
+
return src;
|
|
15
|
+
}
|
|
16
|
+
function getAtPath(values, path) {
|
|
17
|
+
if (!path) return void 0;
|
|
18
|
+
const segs = path.replace(/\[(\d+)\]/g, ".$1").split(".").filter(Boolean);
|
|
19
|
+
let cur = values;
|
|
20
|
+
for (const s of segs) {
|
|
21
|
+
if (cur == null) return void 0;
|
|
22
|
+
cur = cur[s];
|
|
23
|
+
}
|
|
24
|
+
return cur;
|
|
25
|
+
}
|
|
26
|
+
function makeDepsKey(values, deps) {
|
|
27
|
+
if (!deps || deps.length === 0) return "[]";
|
|
28
|
+
try {
|
|
29
|
+
return JSON.stringify(deps.map((d) => getAtPath(values, d)));
|
|
30
|
+
} catch {
|
|
31
|
+
return "[]";
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
function useResolvedOptions(values, source, resolvers) {
|
|
35
|
+
const [opts, setOpts] = useState([]);
|
|
36
|
+
useEffect(() => {
|
|
37
|
+
let mounted = true;
|
|
38
|
+
const run = async () => {
|
|
39
|
+
if (!source) return setOpts([]);
|
|
40
|
+
if (source.kind === "static") return setOpts([...source.options ?? []]);
|
|
41
|
+
const fn = resolvers?.[source.resolverKey];
|
|
42
|
+
if (!fn) return setOpts([]);
|
|
43
|
+
const res = await fn(values, source.args);
|
|
44
|
+
if (mounted) setOpts([...res ?? []]);
|
|
45
|
+
};
|
|
46
|
+
run();
|
|
47
|
+
return () => {
|
|
48
|
+
mounted = false;
|
|
49
|
+
};
|
|
50
|
+
}, [useMemo(() => {
|
|
51
|
+
if (!source) return "nil";
|
|
52
|
+
if (source.kind === "static") return JSON.stringify(source.options ?? []);
|
|
53
|
+
return makeDepsKey(values, source.deps);
|
|
54
|
+
}, [source, values]), source && source.resolverKey]);
|
|
55
|
+
return opts;
|
|
56
|
+
}
|
|
57
|
+
function fieldPath(parent, name, arrayIndex) {
|
|
58
|
+
if (!name) return parent ?? "";
|
|
59
|
+
const child = typeof arrayIndex === "number" ? `${name.replace(/^\$index$/, String(arrayIndex))}` : name;
|
|
60
|
+
return parent ? `${parent}${typeof arrayIndex === "number" ? `.${arrayIndex}` : ""}.${child}`.replace(/\.+/g, ".") : child;
|
|
61
|
+
}
|
|
62
|
+
function createFormRenderer(base) {
|
|
63
|
+
const conf = base;
|
|
64
|
+
const { driver } = conf;
|
|
65
|
+
function InternalForm(props) {
|
|
66
|
+
const { spec, options, merged } = props;
|
|
67
|
+
const baseZod = useMemo(() => buildZodWithRelations(spec), [spec]);
|
|
68
|
+
const form = useForm({
|
|
69
|
+
...merged.formOptions,
|
|
70
|
+
resolver: zodResolver(baseZod),
|
|
71
|
+
defaultValues: options?.defaultValues
|
|
72
|
+
});
|
|
73
|
+
const values = form.watch();
|
|
74
|
+
const renderOne = (f, parent, arrayIndex) => {
|
|
75
|
+
const DriverField = driver.Field;
|
|
76
|
+
const DriverLabel = driver.FieldLabel;
|
|
77
|
+
const DriverDesc = driver.FieldDescription;
|
|
78
|
+
const DriverError = driver.FieldError;
|
|
79
|
+
const name = fieldPath(parent, f.name, arrayIndex);
|
|
80
|
+
const visible = evalPredicate(values, f.visibleWhen);
|
|
81
|
+
const enabled = evalPredicate(values, f.enabledWhen);
|
|
82
|
+
const invalid = Boolean(form.getFieldState(name)?.invalid);
|
|
83
|
+
if (!visible) return null;
|
|
84
|
+
const id = name?.replace(/\./g, "-");
|
|
85
|
+
const commonWrapProps = {
|
|
86
|
+
"data-invalid": invalid,
|
|
87
|
+
hidden: !visible,
|
|
88
|
+
disabled: !enabled
|
|
89
|
+
};
|
|
90
|
+
const labelNode = f.labelI18n ? /* @__PURE__ */ jsx(DriverLabel, {
|
|
91
|
+
htmlFor: id,
|
|
92
|
+
children: f.labelI18n
|
|
93
|
+
}) : null;
|
|
94
|
+
const descNode = f.descriptionI18n ? /* @__PURE__ */ jsx(DriverDesc, { children: f.descriptionI18n }) : null;
|
|
95
|
+
if (f.kind === "group") {
|
|
96
|
+
const children = f.fields.map((c, i) => /* @__PURE__ */ jsx(React.Fragment, { children: renderOne(c, name, arrayIndex) }, `${name}-${i}`));
|
|
97
|
+
return /* @__PURE__ */ jsxs(DriverField, {
|
|
98
|
+
...commonWrapProps,
|
|
99
|
+
children: [
|
|
100
|
+
labelNode,
|
|
101
|
+
children,
|
|
102
|
+
descNode
|
|
103
|
+
]
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
if (f.kind === "array") return renderArray(f, parent);
|
|
107
|
+
return /* @__PURE__ */ jsx(Controller, {
|
|
108
|
+
name,
|
|
109
|
+
control: form.control,
|
|
110
|
+
render: ({ field, fieldState }) => {
|
|
111
|
+
const err = fieldState.error ? [fieldState.error] : [];
|
|
112
|
+
const ariaInvalid = fieldState.invalid || void 0;
|
|
113
|
+
if (f.kind === "text") {
|
|
114
|
+
const Input = driver.Input;
|
|
115
|
+
return /* @__PURE__ */ jsxs(DriverField, {
|
|
116
|
+
...commonWrapProps,
|
|
117
|
+
children: [
|
|
118
|
+
labelNode,
|
|
119
|
+
/* @__PURE__ */ jsx(Input, {
|
|
120
|
+
id,
|
|
121
|
+
"aria-invalid": ariaInvalid,
|
|
122
|
+
placeholder: f.placeholderI18n,
|
|
123
|
+
autoComplete: f.autoComplete,
|
|
124
|
+
inputMode: f.inputMode,
|
|
125
|
+
maxLength: f.maxLength,
|
|
126
|
+
minLength: f.minLength,
|
|
127
|
+
disabled: !enabled,
|
|
128
|
+
...field,
|
|
129
|
+
...f.uiProps,
|
|
130
|
+
keyboard: f.keyboard,
|
|
131
|
+
autoComplete: f.keyboard?.autoComplete ?? f.autoComplete
|
|
132
|
+
}),
|
|
133
|
+
descNode,
|
|
134
|
+
fieldState.invalid ? /* @__PURE__ */ jsx(DriverError, { errors: err }) : null
|
|
135
|
+
]
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
if (f.kind === "textarea") {
|
|
139
|
+
const Textarea = driver.Textarea;
|
|
140
|
+
return /* @__PURE__ */ jsxs(DriverField, {
|
|
141
|
+
...commonWrapProps,
|
|
142
|
+
children: [
|
|
143
|
+
labelNode,
|
|
144
|
+
/* @__PURE__ */ jsx(Textarea, {
|
|
145
|
+
id,
|
|
146
|
+
"aria-invalid": ariaInvalid,
|
|
147
|
+
placeholder: f.placeholderI18n,
|
|
148
|
+
rows: f.rows,
|
|
149
|
+
maxLength: f.maxLength,
|
|
150
|
+
disabled: !enabled,
|
|
151
|
+
...field,
|
|
152
|
+
...f.uiProps,
|
|
153
|
+
keyboard: f.keyboard,
|
|
154
|
+
autoComplete: f.keyboard?.autoComplete ?? f.autoComplete
|
|
155
|
+
}),
|
|
156
|
+
descNode,
|
|
157
|
+
fieldState.invalid ? /* @__PURE__ */ jsx(DriverError, { errors: err }) : null
|
|
158
|
+
]
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
if (f.kind === "select") {
|
|
162
|
+
const Select = driver.Select;
|
|
163
|
+
const opts = useResolvedOptions(values, toOptionsArray(f.options), merged.resolvers);
|
|
164
|
+
return /* @__PURE__ */ jsxs(DriverField, {
|
|
165
|
+
...commonWrapProps,
|
|
166
|
+
children: [
|
|
167
|
+
labelNode,
|
|
168
|
+
/* @__PURE__ */ jsx(Select, {
|
|
169
|
+
id,
|
|
170
|
+
name,
|
|
171
|
+
"aria-invalid": ariaInvalid,
|
|
172
|
+
disabled: !enabled,
|
|
173
|
+
value: field.value,
|
|
174
|
+
onChange: (v) => field.onChange(v),
|
|
175
|
+
options: opts,
|
|
176
|
+
...f.uiProps
|
|
177
|
+
}),
|
|
178
|
+
descNode,
|
|
179
|
+
fieldState.invalid ? /* @__PURE__ */ jsx(DriverError, { errors: err }) : null
|
|
180
|
+
]
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
if (f.kind === "checkbox") {
|
|
184
|
+
const Checkbox = driver.Checkbox;
|
|
185
|
+
return /* @__PURE__ */ jsxs(DriverField, {
|
|
186
|
+
...commonWrapProps,
|
|
187
|
+
children: [
|
|
188
|
+
labelNode,
|
|
189
|
+
/* @__PURE__ */ jsx(Checkbox, {
|
|
190
|
+
id,
|
|
191
|
+
name,
|
|
192
|
+
disabled: !enabled,
|
|
193
|
+
checked: !!field.value,
|
|
194
|
+
onCheckedChange: (v) => field.onChange(v),
|
|
195
|
+
...f.uiProps
|
|
196
|
+
}),
|
|
197
|
+
descNode,
|
|
198
|
+
fieldState.invalid ? /* @__PURE__ */ jsx(DriverError, { errors: err }) : null
|
|
199
|
+
]
|
|
200
|
+
});
|
|
201
|
+
}
|
|
202
|
+
if (f.kind === "radio") {
|
|
203
|
+
const RadioGroup = driver.RadioGroup;
|
|
204
|
+
const opts = useResolvedOptions(values, toOptionsArray(f.options), merged.resolvers);
|
|
205
|
+
return /* @__PURE__ */ jsxs(DriverField, {
|
|
206
|
+
...commonWrapProps,
|
|
207
|
+
children: [
|
|
208
|
+
labelNode,
|
|
209
|
+
/* @__PURE__ */ jsx(RadioGroup, {
|
|
210
|
+
id,
|
|
211
|
+
name,
|
|
212
|
+
disabled: !enabled,
|
|
213
|
+
value: field.value,
|
|
214
|
+
onValueChange: (v) => field.onChange(v),
|
|
215
|
+
options: opts,
|
|
216
|
+
...f.uiProps
|
|
217
|
+
}),
|
|
218
|
+
descNode,
|
|
219
|
+
fieldState.invalid ? /* @__PURE__ */ jsx(DriverError, { errors: err }) : null
|
|
220
|
+
]
|
|
221
|
+
});
|
|
222
|
+
}
|
|
223
|
+
if (f.kind === "switch") {
|
|
224
|
+
const Switch = driver.Switch;
|
|
225
|
+
return /* @__PURE__ */ jsxs(DriverField, {
|
|
226
|
+
...commonWrapProps,
|
|
227
|
+
children: [
|
|
228
|
+
labelNode,
|
|
229
|
+
/* @__PURE__ */ jsx(Switch, {
|
|
230
|
+
id,
|
|
231
|
+
name,
|
|
232
|
+
disabled: !enabled,
|
|
233
|
+
checked: !!field.value,
|
|
234
|
+
onCheckedChange: (v) => field.onChange(v),
|
|
235
|
+
...f.uiProps
|
|
236
|
+
}),
|
|
237
|
+
descNode,
|
|
238
|
+
fieldState.invalid ? /* @__PURE__ */ jsx(DriverError, { errors: err }) : null
|
|
239
|
+
]
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
return /* @__PURE__ */ jsx(Fragment, {});
|
|
243
|
+
}
|
|
244
|
+
}, name);
|
|
245
|
+
};
|
|
246
|
+
const renderArray = (f, parent) => {
|
|
247
|
+
const name = fieldPath(parent, f.name);
|
|
248
|
+
const { fields, append, remove } = useFieldArray({
|
|
249
|
+
control: form.control,
|
|
250
|
+
name
|
|
251
|
+
});
|
|
252
|
+
const canAdd = f.max == null || fields.length < f.max;
|
|
253
|
+
const canRemove = (idx) => (f.min == null ? fields.length > 0 : fields.length > f.min) && idx >= 0;
|
|
254
|
+
const Button$1 = driver.Button;
|
|
255
|
+
const Label = driver.FieldLabel;
|
|
256
|
+
return /* @__PURE__ */ jsxs("div", { children: [
|
|
257
|
+
f.labelI18n ? /* @__PURE__ */ jsx(Label, { children: f.labelI18n }) : null,
|
|
258
|
+
fields.map((row, idx) => /* @__PURE__ */ jsxs("div", { children: [renderOne(f.of, name, idx), canRemove(idx) ? /* @__PURE__ */ jsx(Button$1, {
|
|
259
|
+
type: "button",
|
|
260
|
+
variant: "ghost",
|
|
261
|
+
size: "sm",
|
|
262
|
+
onClick: () => remove(idx),
|
|
263
|
+
children: "Remove"
|
|
264
|
+
}) : null] }, row.id ?? idx)),
|
|
265
|
+
canAdd ? /* @__PURE__ */ jsx(Button$1, {
|
|
266
|
+
type: "button",
|
|
267
|
+
variant: "outline",
|
|
268
|
+
size: "sm",
|
|
269
|
+
onClick: () => append({}),
|
|
270
|
+
children: "Add"
|
|
271
|
+
}) : null
|
|
272
|
+
] }, name);
|
|
273
|
+
};
|
|
274
|
+
const onSubmit = async (data) => {
|
|
275
|
+
const actionKey = spec.actions?.[0]?.key ?? "submit";
|
|
276
|
+
if (merged.onSubmitOverride) return merged.onSubmitOverride(data, actionKey);
|
|
277
|
+
};
|
|
278
|
+
const Button = driver.Button;
|
|
279
|
+
return /* @__PURE__ */ jsxs("form", {
|
|
280
|
+
onSubmit: form.handleSubmit(onSubmit),
|
|
281
|
+
children: [(spec.fields || []).map((f, i) => /* @__PURE__ */ jsx(React.Fragment, { children: renderOne(f) }, i)), spec.actions && spec.actions.length ? /* @__PURE__ */ jsx("div", { children: spec.actions.map((a) => /* @__PURE__ */ jsx(Button, {
|
|
282
|
+
type: "submit",
|
|
283
|
+
children: a.labelI18n
|
|
284
|
+
}, a.key)) }) : null]
|
|
285
|
+
});
|
|
286
|
+
}
|
|
287
|
+
return { render: (spec, options) => /* @__PURE__ */ jsx(InternalForm, {
|
|
288
|
+
spec,
|
|
289
|
+
options,
|
|
290
|
+
merged: {
|
|
291
|
+
...conf,
|
|
292
|
+
...options?.overrides ?? {}
|
|
293
|
+
}
|
|
294
|
+
}) };
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
//#endregion
|
|
298
|
+
export { createFormRenderer };
|
|
299
|
+
//# sourceMappingURL=form-render.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"form-render.js","names":["cur: any","Button"],"sources":["../../../../../../contracts/src/client/react/form-render.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport { Controller, useFieldArray, useForm } from 'react-hook-form';\nimport { zodResolver } from '@hookform/resolvers/zod';\nimport type {\n ArrayFieldSpec,\n FieldSpec,\n FormOption,\n FormSpec,\n OptionsSource,\n FormValuesFor,\n} from '../../forms';\nimport { buildZodWithRelations, evalPredicate } from '../../forms';\nimport type { AnySchemaModel } from '@lssm/lib.schema';\n\n// Minimal, library-agnostic driver slots. Hosts can provide any UI lib via this interface.\nexport interface DriverSlots {\n Field: React.ComponentType<\n React.PropsWithChildren<{\n 'data-invalid'?: boolean;\n hidden?: boolean;\n disabled?: boolean;\n }>\n >;\n FieldLabel: React.ComponentType<\n React.PropsWithChildren<{ htmlFor?: string }>\n >;\n FieldDescription: React.ComponentType<React.PropsWithChildren<{}>>;\n FieldError: React.ComponentType<{ errors: { message?: string }[] }>;\n FieldGroup?: React.ComponentType<\n React.PropsWithChildren<{ className?: string }>\n >;\n FieldSet?: React.ComponentType<\n React.PropsWithChildren<{ className?: string }>\n >;\n FieldLegend?: React.ComponentType<\n React.PropsWithChildren<{ variant?: 'label' | 'default' }>\n >;\n\n Input: React.ComponentType<React.InputHTMLAttributes<HTMLInputElement>>;\n Textarea: React.ComponentType<\n React.TextareaHTMLAttributes<HTMLTextAreaElement>\n >;\n // Select receives resolved options for simplicity\n Select: React.ComponentType<\n {\n id?: string;\n name?: string;\n value?: unknown;\n onChange?: (v: any) => void;\n disabled?: boolean;\n 'aria-invalid'?: boolean;\n options: FormOption[];\n } & Record<string, unknown>\n >;\n Checkbox: React.ComponentType<\n {\n id?: string;\n name?: string;\n checked?: boolean;\n onCheckedChange?: (v: boolean) => void;\n disabled?: boolean;\n } & Record<string, unknown>\n >;\n RadioGroup: React.ComponentType<\n {\n id?: string;\n name?: string;\n value?: unknown;\n onValueChange?: (v: any) => void;\n disabled?: boolean;\n options: FormOption[];\n } & Record<string, unknown>\n >;\n Switch: React.ComponentType<\n {\n id?: string;\n name?: string;\n checked?: boolean;\n onCheckedChange?: (v: boolean) => void;\n disabled?: boolean;\n } & Record<string, unknown>\n >;\n Button: React.ComponentType<\n React.PropsWithChildren<{\n type?: 'button' | 'submit' | 'reset';\n variant?: string;\n size?: string;\n onClick?: () => void;\n disabled?: boolean;\n }>\n >;\n}\n\nexport type ResolverMap<TValues> = Record<\n string,\n (values: TValues, args?: any) => Promise<FormOption[]> | FormOption[]\n>;\nexport type ComputationMap<TValues> = Record<string, (values: TValues) => any>;\n\nexport interface CreateRendererOptions<TValues = any> {\n driver: DriverSlots;\n formOptions?: Record<string, unknown>;\n onSubmitOverride?: (\n values: TValues,\n actionKey: string\n ) => Promise<void> | void;\n activeFlags?: string[];\n resolvers?: ResolverMap<TValues>;\n computations?: ComputationMap<TValues>;\n unmountStrategy?: 'keep' | 'clear';\n}\n\nexport interface RenderOptions<TValues = any> {\n defaultValues?: Partial<TValues>;\n overrides?: Partial<CreateRendererOptions<TValues>>;\n}\n\nfunction toOptionsArray(\n src: OptionsSource | FormOption[] | undefined\n): OptionsSource | undefined {\n if (!src) return undefined;\n if (Array.isArray(src)) return { kind: 'static', options: src };\n return src;\n}\n\nfunction getAtPath(values: unknown, path: string): unknown {\n if (!path) return undefined;\n const segs = path\n .replace(/\\[(\\d+)\\]/g, '.$1')\n .split('.')\n .filter(Boolean);\n let cur: any = values;\n for (const s of segs) {\n if (cur == null) return undefined;\n cur = cur[s as keyof typeof cur];\n }\n return cur;\n}\n\nfunction makeDepsKey(values: unknown, deps: string[] | undefined) {\n if (!deps || deps.length === 0) return '[]';\n try {\n return JSON.stringify(deps.map((d) => getAtPath(values, d)));\n } catch {\n return '[]';\n }\n}\n\nfunction useResolvedOptions<TValues>(\n values: TValues,\n source: OptionsSource | undefined,\n resolvers?: ResolverMap<TValues>\n): FormOption[] {\n const [opts, setOpts] = useState<FormOption[]>([]);\n const depKey = useMemo(() => {\n if (!source) return 'nil';\n if (source.kind === 'static') return JSON.stringify(source.options ?? []);\n return makeDepsKey(values, source.deps);\n }, [source, values]);\n\n useEffect(() => {\n let mounted = true;\n const run = async () => {\n if (!source) return setOpts([]);\n if (source.kind === 'static') return setOpts([...(source.options ?? [])]);\n const fn = resolvers?.[source.resolverKey];\n if (!fn) return setOpts([]);\n const res = await fn(values as any, source.args);\n if (mounted) setOpts([...(res ?? [])]);\n };\n run();\n return () => {\n mounted = false;\n };\n }, [depKey, source && (source as any).resolverKey]);\n return opts;\n}\n\nfunction fieldPath(\n parent: string | undefined,\n name?: string,\n arrayIndex?: number\n) {\n if (!name) return parent ?? '';\n const child =\n typeof arrayIndex === 'number'\n ? `${name.replace(/^\\$index$/, String(arrayIndex))}`\n : name;\n return parent\n ? `${parent}${typeof arrayIndex === 'number' ? `.${arrayIndex}` : ''}.${child}`.replace(\n /\\.+/g,\n '.'\n )\n : child;\n}\n\nexport function createFormRenderer<M extends AnySchemaModel = AnySchemaModel>(\n base: CreateRendererOptions<FormValuesFor<M>>\n) {\n const conf = base;\n const { driver } = conf;\n\n function InternalForm(props: {\n spec: FormSpec<M>;\n options?: RenderOptions<FormValuesFor<M>>;\n merged: CreateRendererOptions<FormValuesFor<M>>;\n }): React.ReactElement {\n const { spec, options, merged } = props;\n const baseZod = useMemo(() => buildZodWithRelations(spec), [spec]);\n const form = useForm<FormValuesFor<M>>({\n ...merged.formOptions,\n resolver: zodResolver(baseZod as any),\n defaultValues: options?.defaultValues as any,\n });\n\n const values = form.watch();\n\n const renderOne = (\n f: FieldSpec,\n parent?: string,\n arrayIndex?: number\n ): React.ReactElement | null => {\n const DriverField = driver.Field;\n const DriverLabel = driver.FieldLabel;\n const DriverDesc = driver.FieldDescription;\n const DriverError = driver.FieldError;\n const name = fieldPath(parent, f.name, arrayIndex);\n const visible = evalPredicate(values, f.visibleWhen);\n const enabled = evalPredicate(values, f.enabledWhen);\n const invalid = Boolean(form.getFieldState(name as any)?.invalid);\n\n if (!visible) return null;\n\n const id = name?.replace(/\\./g, '-');\n\n const commonWrapProps = {\n 'data-invalid': invalid,\n hidden: !visible,\n disabled: !enabled,\n } as any;\n const labelNode = f.labelI18n ? (\n <DriverLabel htmlFor={id}>{f.labelI18n}</DriverLabel>\n ) : null;\n const descNode = f.descriptionI18n ? (\n <DriverDesc>{f.descriptionI18n}</DriverDesc>\n ) : null;\n\n if (f.kind === 'group') {\n const children = f.fields.map((c: FieldSpec, i: number) => (\n <React.Fragment key={`${name}-${i}`}>\n {renderOne(c, name, arrayIndex)}\n </React.Fragment>\n ));\n return (\n <DriverField {...commonWrapProps}>\n {labelNode}\n {children}\n {descNode}\n </DriverField>\n );\n }\n\n if (f.kind === 'array') {\n return renderArray(f as ArrayFieldSpec, parent);\n }\n\n // Leaf controls\n return (\n <Controller\n key={name}\n name={name as any}\n control={form.control}\n render={({ field, fieldState }) => {\n const err = fieldState.error ? [fieldState.error] : [];\n const ariaInvalid = fieldState.invalid || undefined;\n\n if (f.kind === 'text') {\n const Input = driver.Input;\n return (\n <DriverField {...commonWrapProps}>\n {labelNode}\n <Input\n id={id}\n aria-invalid={ariaInvalid}\n placeholder={f.placeholderI18n}\n autoComplete={(f as any).autoComplete as any}\n inputMode={(f as any).inputMode as any}\n maxLength={(f as any).maxLength as any}\n minLength={(f as any).minLength as any}\n disabled={!enabled}\n {...field}\n {...(f.uiProps as any)}\n // Pass keyboard/autocomplete hints down for adapters that support them\n {...({\n keyboard: (f as any).keyboard,\n autoComplete:\n (f as any).keyboard?.autoComplete ??\n (f as any).autoComplete,\n } as any)}\n />\n {descNode}\n {fieldState.invalid ? (\n <DriverError errors={err as any} />\n ) : null}\n </DriverField>\n );\n }\n if (f.kind === 'textarea') {\n const Textarea = driver.Textarea;\n return (\n <DriverField {...commonWrapProps}>\n {labelNode}\n <Textarea\n id={id}\n aria-invalid={ariaInvalid}\n placeholder={f.placeholderI18n}\n rows={(f as any).rows as any}\n maxLength={(f as any).maxLength as any}\n disabled={!enabled}\n {...field}\n {...(f.uiProps as any)}\n {...({\n keyboard: (f as any).keyboard,\n autoComplete:\n (f as any).keyboard?.autoComplete ??\n (f as any).autoComplete,\n } as any)}\n />\n {descNode}\n {fieldState.invalid ? (\n <DriverError errors={err as any} />\n ) : null}\n </DriverField>\n );\n }\n if (f.kind === 'select') {\n const Select = driver.Select;\n const src = toOptionsArray((f as any).options);\n const opts = useResolvedOptions(values, src, merged.resolvers);\n return (\n <DriverField {...commonWrapProps}>\n {labelNode}\n <Select\n id={id}\n name={name}\n aria-invalid={ariaInvalid}\n disabled={!enabled}\n value={field.value}\n onChange={(v: any) => field.onChange(v)}\n options={opts}\n {...(f.uiProps as any)}\n />\n {descNode}\n {fieldState.invalid ? (\n <DriverError errors={err as any} />\n ) : null}\n </DriverField>\n );\n }\n if (f.kind === 'checkbox') {\n const Checkbox = driver.Checkbox;\n return (\n <DriverField {...commonWrapProps}>\n {labelNode}\n <Checkbox\n id={id}\n name={name}\n disabled={!enabled}\n checked={!!field.value}\n onCheckedChange={(v: boolean) => field.onChange(v)}\n {...(f.uiProps as any)}\n />\n {descNode}\n {fieldState.invalid ? (\n <DriverError errors={err as any} />\n ) : null}\n </DriverField>\n );\n }\n if (f.kind === 'radio') {\n const RadioGroup = driver.RadioGroup;\n const src = toOptionsArray((f as any).options);\n const opts = useResolvedOptions(values, src, merged.resolvers);\n return (\n <DriverField {...commonWrapProps}>\n {labelNode}\n <RadioGroup\n id={id}\n name={name}\n disabled={!enabled}\n value={field.value}\n onValueChange={(v: any) => field.onChange(v)}\n options={opts}\n {...(f.uiProps as any)}\n />\n {descNode}\n {fieldState.invalid ? (\n <DriverError errors={err as any} />\n ) : null}\n </DriverField>\n );\n }\n if (f.kind === 'switch') {\n const Switch = driver.Switch;\n return (\n <DriverField {...commonWrapProps}>\n {labelNode}\n <Switch\n id={id}\n name={name}\n disabled={!enabled}\n checked={!!field.value}\n onCheckedChange={(v: boolean) => field.onChange(v)}\n {...(f.uiProps as any)}\n />\n {descNode}\n {fieldState.invalid ? (\n <DriverError errors={err as any} />\n ) : null}\n </DriverField>\n );\n }\n return <></>;\n }}\n />\n );\n };\n\n const renderArray = (f: ArrayFieldSpec, parent?: string) => {\n const name = fieldPath(parent, f.name);\n const { fields, append, remove } = useFieldArray({\n control: form.control as any,\n name: name as any,\n });\n const canAdd = f.max == null || fields.length < f.max;\n const canRemove = (idx: number) =>\n (f.min == null ? fields.length > 0 : fields.length > f.min) && idx >= 0;\n const Button = driver.Button;\n const Label = driver.FieldLabel;\n return (\n <div key={name}>\n {f.labelI18n ? <Label>{f.labelI18n}</Label> : null}\n {fields.map((row, idx) => (\n <div key={row.id ?? idx}>\n {renderOne(f.of as FieldSpec, name, idx)}\n {canRemove(idx) ? (\n <Button\n type=\"button\"\n variant=\"ghost\"\n size=\"sm\"\n onClick={() => remove(idx)}\n >\n Remove\n </Button>\n ) : null}\n </div>\n ))}\n {canAdd ? (\n <Button\n type=\"button\"\n variant=\"outline\"\n size=\"sm\"\n onClick={() => append({})}\n >\n Add\n </Button>\n ) : null}\n </div>\n );\n };\n\n const onSubmit = async (data: FormValuesFor<M>) => {\n const actionKey = spec.actions?.[0]?.key ?? 'submit';\n if (merged.onSubmitOverride) {\n return merged.onSubmitOverride(data, actionKey);\n }\n // default: noop\n };\n\n const Button = driver.Button;\n return (\n <form onSubmit={form.handleSubmit(onSubmit)}>\n {(spec.fields || []).map((f: FieldSpec, i: number) => (\n <React.Fragment key={i}>{renderOne(f)}</React.Fragment>\n ))}\n {spec.actions && spec.actions.length ? (\n <div>\n {spec.actions.map((a: { key: string; labelI18n: string }) => (\n <Button key={a.key} type=\"submit\">\n {a.labelI18n}\n </Button>\n ))}\n </div>\n ) : null}\n </form>\n );\n }\n\n return {\n render: (spec: FormSpec<M>, options?: RenderOptions<FormValuesFor<M>>) => (\n <InternalForm\n spec={spec}\n options={options}\n merged={{\n ...conf,\n ...(options?.overrides ?? {}),\n }}\n />\n ),\n };\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
//#region ../contracts/src/forms.ts
|
|
2
|
+
function getAtPath(values, path) {
|
|
3
|
+
if (!path) return void 0;
|
|
4
|
+
const segs = path.replace(/\[(\d+)\]/g, ".$1").split(".").filter(Boolean);
|
|
5
|
+
let cur = values;
|
|
6
|
+
for (const s of segs) {
|
|
7
|
+
if (cur == null) return void 0;
|
|
8
|
+
cur = cur[s];
|
|
9
|
+
}
|
|
10
|
+
return cur;
|
|
11
|
+
}
|
|
12
|
+
function evalPredicate(values, pred) {
|
|
13
|
+
if (!pred) return true;
|
|
14
|
+
if (pred.not) return !evalPredicate(values, pred.not);
|
|
15
|
+
if (pred.all && pred.all.length) return pred.all.every((p) => evalPredicate(values, p));
|
|
16
|
+
if (pred.any && pred.any.length) return pred.any.some((p) => evalPredicate(values, p));
|
|
17
|
+
if (pred.when) {
|
|
18
|
+
const { path, op = "truthy", value } = pred.when;
|
|
19
|
+
const v = getAtPath(values, path);
|
|
20
|
+
switch (op) {
|
|
21
|
+
case "equals": return v === value;
|
|
22
|
+
case "notEquals": return v !== value;
|
|
23
|
+
case "in": return Array.isArray(value) && value.includes(v);
|
|
24
|
+
case "notIn": return Array.isArray(value) && !value.includes(v);
|
|
25
|
+
case "gt": return Number(v) > Number(value);
|
|
26
|
+
case "gte": return Number(v) >= Number(value);
|
|
27
|
+
case "lt": return Number(v) < Number(value);
|
|
28
|
+
case "lte": return Number(v) <= Number(value);
|
|
29
|
+
case "empty": return v == null || (Array.isArray(v) ? v.length === 0 : String(v).length === 0);
|
|
30
|
+
case "lengthGt": return (Array.isArray(v) || typeof v === "string") && v.length > Number(value ?? 0);
|
|
31
|
+
case "lengthGte": return (Array.isArray(v) || typeof v === "string") && v.length >= Number(value ?? 0);
|
|
32
|
+
case "lengthLt": return (Array.isArray(v) || typeof v === "string") && v.length < Number(value ?? 0);
|
|
33
|
+
case "lengthLte": return (Array.isArray(v) || typeof v === "string") && v.length <= Number(value ?? 0);
|
|
34
|
+
case "truthy":
|
|
35
|
+
default: return Boolean(v);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
return true;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Wrap the base zod schema with relation-driven refinements (requiredWhen, array min/max)
|
|
42
|
+
* and optional custom constraints. Call this when wiring RHF resolver.
|
|
43
|
+
*/
|
|
44
|
+
function buildZodWithRelations(spec, handlers) {
|
|
45
|
+
return spec.model.getZod().superRefine((values, ctx) => {
|
|
46
|
+
const visit = (field, parentPath) => {
|
|
47
|
+
const path = field.name ? parentPath ? `${parentPath}.${field.name}` : field.name : parentPath ?? "";
|
|
48
|
+
if (field.requiredWhen) {
|
|
49
|
+
if (evalPredicate(values, field.requiredWhen)) {
|
|
50
|
+
const v = getAtPath(values, path);
|
|
51
|
+
if (v == null || typeof v === "string" && v.trim().length === 0 || Array.isArray(v) && v.length === 0) ctx.addIssue({
|
|
52
|
+
code: "custom",
|
|
53
|
+
path: path.split("."),
|
|
54
|
+
message: "required"
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
if (field.kind === "array") {
|
|
59
|
+
const arr = getAtPath(values, path);
|
|
60
|
+
if (field.min != null && Array.isArray(arr) && arr.length < field.min) ctx.addIssue({
|
|
61
|
+
code: "custom",
|
|
62
|
+
path: path.split("."),
|
|
63
|
+
message: `min:${field.min}`
|
|
64
|
+
});
|
|
65
|
+
if (field.max != null && Array.isArray(arr) && arr.length > field.max) ctx.addIssue({
|
|
66
|
+
code: "custom",
|
|
67
|
+
path: path.split("."),
|
|
68
|
+
message: `max:${field.max}`
|
|
69
|
+
});
|
|
70
|
+
visit(field.of, path);
|
|
71
|
+
} else if (field.kind === "group") for (const child of field.fields) visit(child, path);
|
|
72
|
+
};
|
|
73
|
+
for (const f of spec.fields) visit(f);
|
|
74
|
+
if (spec.constraints && handlers) for (const c of spec.constraints) {
|
|
75
|
+
const fn = handlers[c.key];
|
|
76
|
+
if (!fn) continue;
|
|
77
|
+
const res = fn(values, c.paths, c.args);
|
|
78
|
+
if (!res.ok) ctx.addIssue({
|
|
79
|
+
code: "custom",
|
|
80
|
+
path: (res.path ?? c.paths[0] ?? "").split(".").filter(Boolean),
|
|
81
|
+
message: res.message ?? c.messageI18n
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
//#endregion
|
|
88
|
+
export { buildZodWithRelations, evalPredicate };
|
|
89
|
+
//# sourceMappingURL=forms.js.map
|