@wix/auto-patterns 1.6.0 → 1.8.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/cjs/components/AutoPatternsApp/AutoPatternsApp.js +10 -25
- package/dist/cjs/components/AutoPatternsApp/AutoPatternsApp.js.map +1 -1
- package/dist/cjs/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.js +3 -2
- package/dist/cjs/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.js.map +1 -1
- package/dist/cjs/components/AutoPatternsEntityPage/AutoPatternsEntityPage.js +242 -71
- package/dist/cjs/components/AutoPatternsEntityPage/AutoPatternsEntityPage.js.map +1 -1
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/DateInput.js +28 -5
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/DateInput.js.map +1 -1
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/DateTime.js +45 -10
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/DateTime.js.map +1 -1
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/FormFieldInput.js +7 -5
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/FormFieldInput.js.map +1 -1
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/LongText.js +16 -5
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/LongText.js.map +1 -1
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/Number.js +43 -5
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/Number.js.map +1 -1
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/ShortText.js +30 -5
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/ShortText.js.map +1 -1
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/Url.js +27 -9
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/Url.js.map +1 -1
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/types.js.map +1 -1
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/utils/validateTextLength.js +39 -0
- package/dist/cjs/components/AutoPatternsEntityPage/Fields/utils/validateTextLength.js.map +1 -0
- package/dist/cjs/components/AutoPatternsGrid/AutoPatternsGrid.js +8 -10
- package/dist/cjs/components/AutoPatternsGrid/AutoPatternsGrid.js.map +1 -1
- package/dist/cjs/components/AutoPatternsRoute/AutoPatternsRoutes.js +84 -0
- package/dist/cjs/components/AutoPatternsRoute/AutoPatternsRoutes.js.map +1 -0
- package/dist/cjs/components/AutoPatternsTable/AutoPatternsTable.js +8 -10
- package/dist/cjs/components/AutoPatternsTable/AutoPatternsTable.js.map +1 -1
- package/dist/cjs/components/AutoPatternsTable/AutoPatternsTableContent.js +7 -8
- package/dist/cjs/components/AutoPatternsTable/AutoPatternsTableContent.js.map +1 -1
- package/dist/cjs/components/DynamicIcon.js +71 -0
- package/dist/cjs/components/DynamicIcon.js.map +1 -0
- package/dist/cjs/components/ModalRenderer.js +40 -0
- package/dist/cjs/components/ModalRenderer.js.map +1 -0
- package/dist/cjs/components/filters/DynamicCollectionFilter.js +63 -0
- package/dist/cjs/components/filters/DynamicCollectionFilter.js.map +1 -0
- package/dist/cjs/components/filters/StaticCollectionFilter.js +31 -0
- package/dist/cjs/components/filters/StaticCollectionFilter.js.map +1 -0
- package/dist/cjs/components/filters/index.js +9 -0
- package/dist/cjs/components/filters/index.js.map +1 -0
- package/dist/cjs/components/modals/actions/BulkDeleteModal.js +95 -0
- package/dist/cjs/components/modals/actions/BulkDeleteModal.js.map +1 -0
- package/dist/cjs/components/modals/actions/EditModal.js +136 -0
- package/dist/cjs/components/modals/actions/EditModal.js.map +1 -0
- package/dist/cjs/components/modals/actions/index.js +16 -0
- package/dist/cjs/components/modals/actions/index.js.map +1 -0
- package/dist/cjs/{collectionData/CollectionData.js → components/modals/actions/types.js} +1 -1
- package/dist/cjs/components/modals/actions/types.js.map +1 -0
- package/dist/cjs/components/modals/index.js +10 -0
- package/dist/cjs/components/modals/index.js.map +1 -0
- package/dist/cjs/{collectionData/cms/CmsCollectionData.js → dataSourceAdapters/cms/cmsAdapter.js} +57 -18
- package/dist/cjs/dataSourceAdapters/cms/cmsAdapter.js.map +1 -0
- package/dist/cjs/{collectionData → dataSourceAdapters}/cms/filterUtils.js +18 -11
- package/dist/cjs/dataSourceAdapters/cms/filterUtils.js.map +1 -0
- package/dist/cjs/dataSourceAdapters/cms/sortUtils.js.map +1 -0
- package/dist/cjs/dataSourceAdapters/constants.js.map +1 -0
- package/dist/cjs/dataSourceAdapters/factory.js +34 -0
- package/dist/cjs/dataSourceAdapters/factory.js.map +1 -0
- package/dist/cjs/exports/form.js +10 -0
- package/dist/cjs/exports/form.js.map +1 -0
- package/dist/cjs/hooks/index.js +12 -0
- package/dist/cjs/hooks/index.js.map +1 -1
- package/dist/cjs/hooks/useActionCell.js +109 -0
- package/dist/cjs/hooks/useActionCell.js.map +1 -0
- package/dist/cjs/hooks/useAutoPatternsOptimisticActions.js +15 -0
- package/dist/cjs/hooks/useAutoPatternsOptimisticActions.js.map +1 -0
- package/dist/cjs/hooks/useBulkActionToolbar.js +88 -0
- package/dist/cjs/hooks/useBulkActionToolbar.js.map +1 -0
- package/dist/cjs/hooks/useColumns.js +90 -37
- package/dist/cjs/hooks/useColumns.js.map +1 -1
- package/dist/cjs/hooks/useCommonCollectionFeatures.js +27 -35
- package/dist/cjs/hooks/useCommonCollectionFeatures.js.map +1 -1
- package/dist/cjs/hooks/useFetchData.js +33 -9
- package/dist/cjs/hooks/useFetchData.js.map +1 -1
- package/dist/cjs/hooks/useFilters.js +83 -92
- package/dist/cjs/hooks/useFilters.js.map +1 -1
- package/dist/cjs/hooks/useGridFeatures.js +31 -21
- package/dist/cjs/hooks/useGridFeatures.js.map +1 -1
- package/dist/cjs/hooks/useNavigationUtils.js +51 -0
- package/dist/cjs/hooks/useNavigationUtils.js.map +1 -0
- package/dist/cjs/hooks/usePagePath.js +35 -0
- package/dist/cjs/hooks/usePagePath.js.map +1 -0
- package/dist/cjs/hooks/useSharedDataForActions.js +44 -0
- package/dist/cjs/hooks/useSharedDataForActions.js.map +1 -0
- package/dist/cjs/hooks/useTableFeatures.js +23 -15
- package/dist/cjs/hooks/useTableFeatures.js.map +1 -1
- package/dist/cjs/providers/AppConfigContext.js +33 -0
- package/dist/cjs/providers/AppConfigContext.js.map +1 -0
- package/dist/cjs/providers/ModalContext.js +58 -0
- package/dist/cjs/providers/ModalContext.js.map +1 -0
- package/dist/cjs/providers/PatternsWizardOverridesContext.js +1 -1
- package/dist/cjs/providers/PatternsWizardOverridesContext.js.map +1 -1
- package/dist/cjs/providers/RootAppProvider.js +40 -0
- package/dist/cjs/providers/RootAppProvider.js.map +1 -0
- package/dist/cjs/providers/SchemaContext.js +49 -5
- package/dist/cjs/providers/SchemaContext.js.map +1 -1
- package/dist/cjs/providers/SchemaRegistryContext.js +49 -0
- package/dist/cjs/providers/SchemaRegistryContext.js.map +1 -0
- package/dist/cjs/providers/index.js +22 -4
- package/dist/cjs/providers/index.js.map +1 -1
- package/dist/cjs/types/CollectionPageConfig.js.map +1 -1
- package/dist/cjs/types/EntityPageConfig.js.map +1 -1
- package/dist/cjs/types/actions/actionCell.js +4 -0
- package/dist/cjs/types/actions/actionCell.js.map +1 -0
- package/dist/cjs/types/actions/base.js +4 -0
- package/dist/cjs/types/actions/base.js.map +1 -0
- package/dist/cjs/types/actions/bulkActions.js +4 -0
- package/dist/cjs/types/actions/bulkActions.js.map +1 -0
- package/dist/cjs/types/actions/index.js +22 -0
- package/dist/cjs/types/actions/index.js.map +1 -0
- package/dist/cjs/types/index.js +12 -0
- package/dist/cjs/types/index.js.map +1 -1
- package/dist/cjs/types/types.js.map +1 -1
- package/dist/cjs/utils/actions/bulkDeleteAction.js +26 -0
- package/dist/cjs/utils/actions/bulkDeleteAction.js.map +1 -0
- package/dist/cjs/utils/actions/customAction.js +23 -0
- package/dist/cjs/utils/actions/customAction.js.map +1 -0
- package/dist/cjs/utils/actions/customModalAction.js +22 -0
- package/dist/cjs/utils/actions/customModalAction.js.map +1 -0
- package/dist/cjs/utils/actions/deleteAction.js +61 -0
- package/dist/cjs/utils/actions/deleteAction.js.map +1 -0
- package/dist/cjs/utils/actions/index.js +40 -0
- package/dist/cjs/utils/actions/index.js.map +1 -0
- package/dist/cjs/utils/actions/resolveAction.js +27 -0
- package/dist/cjs/utils/actions/resolveAction.js.map +1 -0
- package/dist/cjs/utils/actions/types.js +4 -0
- package/dist/cjs/utils/actions/types.js.map +1 -0
- package/dist/cjs/utils/actions/updateAction.js +46 -0
- package/dist/cjs/utils/actions/updateAction.js.map +1 -0
- package/dist/cjs/utils/filterCreators.js +137 -0
- package/dist/cjs/utils/filterCreators.js.map +1 -0
- package/dist/cjs/utils/media/getImageUrl.js +22 -0
- package/dist/cjs/utils/media/getImageUrl.js.map +1 -0
- package/dist/esm/components/AutoPatternsApp/AutoPatternsApp.js +6 -14
- package/dist/esm/components/AutoPatternsApp/AutoPatternsApp.js.map +1 -1
- package/dist/esm/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.js +1 -0
- package/dist/esm/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.js.map +1 -1
- package/dist/esm/components/AutoPatternsEntityPage/AutoPatternsEntityPage.js +155 -34
- package/dist/esm/components/AutoPatternsEntityPage/AutoPatternsEntityPage.js.map +1 -1
- package/dist/esm/components/AutoPatternsEntityPage/Fields/DateInput.js +27 -4
- package/dist/esm/components/AutoPatternsEntityPage/Fields/DateInput.js.map +1 -1
- package/dist/esm/components/AutoPatternsEntityPage/Fields/DateTime.js +41 -6
- package/dist/esm/components/AutoPatternsEntityPage/Fields/DateTime.js.map +1 -1
- package/dist/esm/components/AutoPatternsEntityPage/Fields/FormFieldInput.js +7 -5
- package/dist/esm/components/AutoPatternsEntityPage/Fields/FormFieldInput.js.map +1 -1
- package/dist/esm/components/AutoPatternsEntityPage/Fields/LongText.js +14 -4
- package/dist/esm/components/AutoPatternsEntityPage/Fields/LongText.js.map +1 -1
- package/dist/esm/components/AutoPatternsEntityPage/Fields/Number.js +41 -4
- package/dist/esm/components/AutoPatternsEntityPage/Fields/Number.js.map +1 -1
- package/dist/esm/components/AutoPatternsEntityPage/Fields/ShortText.js +28 -4
- package/dist/esm/components/AutoPatternsEntityPage/Fields/ShortText.js.map +1 -1
- package/dist/esm/components/AutoPatternsEntityPage/Fields/Url.js +23 -5
- package/dist/esm/components/AutoPatternsEntityPage/Fields/Url.js.map +1 -1
- package/dist/esm/components/AutoPatternsEntityPage/Fields/types.js.map +1 -1
- package/dist/esm/components/AutoPatternsEntityPage/Fields/utils/validateTextLength.js +35 -0
- package/dist/esm/components/AutoPatternsEntityPage/Fields/utils/validateTextLength.js.map +1 -0
- package/dist/esm/components/AutoPatternsGrid/AutoPatternsGrid.js +5 -6
- package/dist/esm/components/AutoPatternsGrid/AutoPatternsGrid.js.map +1 -1
- package/dist/esm/components/AutoPatternsRoute/AutoPatternsRoutes.js +47 -0
- package/dist/esm/components/AutoPatternsRoute/AutoPatternsRoutes.js.map +1 -0
- package/dist/esm/components/AutoPatternsTable/AutoPatternsTable.js +5 -6
- package/dist/esm/components/AutoPatternsTable/AutoPatternsTable.js.map +1 -1
- package/dist/esm/components/AutoPatternsTable/AutoPatternsTableContent.js +9 -10
- package/dist/esm/components/AutoPatternsTable/AutoPatternsTableContent.js.map +1 -1
- package/dist/esm/components/DynamicIcon.js +33 -0
- package/dist/esm/components/DynamicIcon.js.map +1 -0
- package/dist/esm/components/ModalRenderer.js +25 -0
- package/dist/esm/components/ModalRenderer.js.map +1 -0
- package/dist/esm/components/filters/DynamicCollectionFilter.js +50 -0
- package/dist/esm/components/filters/DynamicCollectionFilter.js.map +1 -0
- package/dist/esm/components/filters/StaticCollectionFilter.js +18 -0
- package/dist/esm/components/filters/StaticCollectionFilter.js.map +1 -0
- package/dist/esm/components/filters/index.js +3 -0
- package/dist/esm/components/filters/index.js.map +1 -0
- package/dist/esm/components/modals/actions/BulkDeleteModal.js +57 -0
- package/dist/esm/components/modals/actions/BulkDeleteModal.js.map +1 -0
- package/dist/esm/components/modals/actions/EditModal.js +78 -0
- package/dist/esm/components/modals/actions/EditModal.js.map +1 -0
- package/dist/esm/components/modals/actions/index.js +3 -0
- package/dist/esm/components/modals/actions/index.js.map +1 -0
- package/dist/esm/components/modals/actions/types.js +2 -0
- package/dist/esm/components/modals/actions/types.js.map +1 -0
- package/dist/esm/components/modals/index.js +2 -0
- package/dist/esm/components/modals/index.js.map +1 -0
- package/dist/esm/dataSourceAdapters/cms/cmsAdapter.js +131 -0
- package/dist/esm/dataSourceAdapters/cms/cmsAdapter.js.map +1 -0
- package/dist/esm/{collectionData → dataSourceAdapters}/cms/filterUtils.js +18 -11
- package/dist/esm/dataSourceAdapters/cms/filterUtils.js.map +1 -0
- package/dist/esm/dataSourceAdapters/cms/sortUtils.js.map +1 -0
- package/dist/esm/dataSourceAdapters/constants.js.map +1 -0
- package/dist/esm/dataSourceAdapters/factory.js +30 -0
- package/dist/esm/dataSourceAdapters/factory.js.map +1 -0
- package/dist/esm/exports/form.js +2 -0
- package/dist/esm/exports/form.js.map +1 -0
- package/dist/esm/hooks/index.js +2 -0
- package/dist/esm/hooks/index.js.map +1 -1
- package/dist/esm/hooks/useActionCell.js +105 -0
- package/dist/esm/hooks/useActionCell.js.map +1 -0
- package/dist/esm/hooks/useAutoPatternsOptimisticActions.js +13 -0
- package/dist/esm/hooks/useAutoPatternsOptimisticActions.js.map +1 -0
- package/dist/esm/hooks/useBulkActionToolbar.js +75 -0
- package/dist/esm/hooks/useBulkActionToolbar.js.map +1 -0
- package/dist/esm/hooks/useColumns.js +70 -38
- package/dist/esm/hooks/useColumns.js.map +1 -1
- package/dist/esm/hooks/useCommonCollectionFeatures.js +23 -24
- package/dist/esm/hooks/useCommonCollectionFeatures.js.map +1 -1
- package/dist/esm/hooks/useFetchData.js +34 -10
- package/dist/esm/hooks/useFetchData.js.map +1 -1
- package/dist/esm/hooks/useFilters.js +75 -85
- package/dist/esm/hooks/useFilters.js.map +1 -1
- package/dist/esm/hooks/useGridFeatures.js +31 -21
- package/dist/esm/hooks/useGridFeatures.js.map +1 -1
- package/dist/esm/hooks/useNavigationUtils.js +47 -0
- package/dist/esm/hooks/useNavigationUtils.js.map +1 -0
- package/dist/esm/hooks/usePagePath.js +30 -0
- package/dist/esm/hooks/usePagePath.js.map +1 -0
- package/dist/esm/hooks/useSharedDataForActions.js +40 -0
- package/dist/esm/hooks/useSharedDataForActions.js.map +1 -0
- package/dist/esm/hooks/useTableFeatures.js +20 -13
- package/dist/esm/hooks/useTableFeatures.js.map +1 -1
- package/dist/esm/providers/AppConfigContext.js +19 -0
- package/dist/esm/providers/AppConfigContext.js.map +1 -0
- package/dist/esm/providers/ModalContext.js +37 -0
- package/dist/esm/providers/ModalContext.js.map +1 -0
- package/dist/esm/providers/PatternsWizardOverridesContext.js.map +1 -1
- package/dist/esm/providers/RootAppProvider.js +14 -0
- package/dist/esm/providers/RootAppProvider.js.map +1 -0
- package/dist/esm/providers/SchemaContext.js +48 -4
- package/dist/esm/providers/SchemaContext.js.map +1 -1
- package/dist/esm/providers/SchemaRegistryContext.js +35 -0
- package/dist/esm/providers/SchemaRegistryContext.js.map +1 -0
- package/dist/esm/providers/index.js +4 -1
- package/dist/esm/providers/index.js.map +1 -1
- package/dist/esm/types/CollectionPageConfig.js.map +1 -1
- package/dist/esm/types/EntityPageConfig.js.map +1 -1
- package/dist/esm/types/actions/actionCell.js +2 -0
- package/dist/esm/types/actions/actionCell.js.map +1 -0
- package/dist/esm/types/actions/base.js +2 -0
- package/dist/esm/types/actions/base.js.map +1 -0
- package/dist/esm/types/actions/bulkActions.js +2 -0
- package/dist/esm/types/actions/bulkActions.js.map +1 -0
- package/dist/esm/types/actions/index.js +4 -0
- package/dist/esm/types/actions/index.js.map +1 -0
- package/dist/esm/types/index.js +2 -0
- package/dist/esm/types/index.js.map +1 -1
- package/dist/esm/types/types.js.map +1 -1
- package/dist/esm/utils/actions/bulkDeleteAction.js +21 -0
- package/dist/esm/utils/actions/bulkDeleteAction.js.map +1 -0
- package/dist/esm/utils/actions/customAction.js +18 -0
- package/dist/esm/utils/actions/customAction.js.map +1 -0
- package/dist/esm/utils/actions/customModalAction.js +17 -0
- package/dist/esm/utils/actions/customModalAction.js.map +1 -0
- package/dist/esm/utils/actions/deleteAction.js +56 -0
- package/dist/esm/utils/actions/deleteAction.js.map +1 -0
- package/dist/esm/utils/actions/index.js +8 -0
- package/dist/esm/utils/actions/index.js.map +1 -0
- package/dist/esm/utils/actions/resolveAction.js +13 -0
- package/dist/esm/utils/actions/resolveAction.js.map +1 -0
- package/dist/esm/utils/actions/types.js +2 -0
- package/dist/esm/utils/actions/types.js.map +1 -0
- package/dist/esm/utils/actions/updateAction.js +41 -0
- package/dist/esm/utils/actions/updateAction.js.map +1 -0
- package/dist/esm/utils/filterCreators.js +139 -0
- package/dist/esm/utils/filterCreators.js.map +1 -0
- package/dist/esm/utils/media/getImageUrl.js +16 -0
- package/dist/esm/utils/media/getImageUrl.js.map +1 -0
- package/dist/types/components/AutoPatternsApp/AutoPatternsApp.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsEntityPage/AutoPatternsEntityPage.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsEntityPage/Fields/Checkbox.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsEntityPage/Fields/DateInput.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsEntityPage/Fields/DateTime.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsEntityPage/Fields/FormFieldInput.d.ts +3 -1
- package/dist/types/components/AutoPatternsEntityPage/Fields/FormFieldInput.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsEntityPage/Fields/LongText.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsEntityPage/Fields/Number.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsEntityPage/Fields/ShortText.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsEntityPage/Fields/Url.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsEntityPage/Fields/types.d.ts +2 -0
- package/dist/types/components/AutoPatternsEntityPage/Fields/types.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsEntityPage/Fields/utils/dates.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsEntityPage/Fields/utils/validateTextLength.d.ts +12 -0
- package/dist/types/components/AutoPatternsEntityPage/Fields/utils/validateTextLength.d.ts.map +1 -0
- package/dist/types/components/AutoPatternsGrid/AutoPatternsGrid.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsGrid/AutoPatternsGridContent.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsRoute/AutoPatternsPage.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsRoute/AutoPatternsRoutes.d.ts +6 -0
- package/dist/types/components/AutoPatternsRoute/AutoPatternsRoutes.d.ts.map +1 -0
- package/dist/types/components/AutoPatternsTable/AutoPatternsTable.d.ts.map +1 -1
- package/dist/types/components/AutoPatternsTable/AutoPatternsTableContent.d.ts.map +1 -1
- package/dist/types/components/DynamicIcon.d.ts +6 -0
- package/dist/types/components/DynamicIcon.d.ts.map +1 -0
- package/dist/types/components/ModalRenderer.d.ts +3 -0
- package/dist/types/components/ModalRenderer.d.ts.map +1 -0
- package/dist/types/components/filters/DynamicCollectionFilter.d.ts +12 -0
- package/dist/types/components/filters/DynamicCollectionFilter.d.ts.map +1 -0
- package/dist/types/components/filters/StaticCollectionFilter.d.ts +14 -0
- package/dist/types/components/filters/StaticCollectionFilter.d.ts.map +1 -0
- package/dist/types/components/filters/index.d.ts +3 -0
- package/dist/types/components/filters/index.d.ts.map +1 -0
- package/dist/types/components/modals/actions/BulkDeleteModal.d.ts +9 -0
- package/dist/types/components/modals/actions/BulkDeleteModal.d.ts.map +1 -0
- package/dist/types/components/modals/actions/EditModal.d.ts +11 -0
- package/dist/types/components/modals/actions/EditModal.d.ts.map +1 -0
- package/dist/types/components/modals/actions/index.d.ts +3 -0
- package/dist/types/components/modals/actions/index.d.ts.map +1 -0
- package/dist/types/components/modals/actions/types.d.ts +7 -0
- package/dist/types/components/modals/actions/types.d.ts.map +1 -0
- package/dist/types/components/modals/index.d.ts +2 -0
- package/dist/types/components/modals/index.d.ts.map +1 -0
- package/dist/types/dataSourceAdapters/cms/cmsAdapter.d.ts +14 -0
- package/dist/types/dataSourceAdapters/cms/cmsAdapter.d.ts.map +1 -0
- package/dist/types/{collectionData → dataSourceAdapters}/cms/filterUtils.d.ts +3 -2
- package/dist/types/dataSourceAdapters/cms/filterUtils.d.ts.map +1 -0
- package/dist/types/dataSourceAdapters/cms/sortUtils.d.ts.map +1 -0
- package/dist/types/dataSourceAdapters/constants.d.ts.map +1 -0
- package/dist/types/dataSourceAdapters/factory.d.ts +13 -0
- package/dist/types/dataSourceAdapters/factory.d.ts.map +1 -0
- package/dist/types/exports/form.d.ts +2 -0
- package/dist/types/exports/form.d.ts.map +1 -0
- package/dist/types/hooks/index.d.ts +2 -0
- package/dist/types/hooks/index.d.ts.map +1 -1
- package/dist/types/hooks/useActionCell.d.ts +11 -0
- package/dist/types/hooks/useActionCell.d.ts.map +1 -0
- package/dist/types/hooks/useAutoPatternsOptimisticActions.d.ts +3 -0
- package/dist/types/hooks/useAutoPatternsOptimisticActions.d.ts.map +1 -0
- package/dist/types/hooks/useBulkActionToolbar.d.ts +11 -0
- package/dist/types/hooks/useBulkActionToolbar.d.ts.map +1 -0
- package/dist/types/hooks/useColumns.d.ts.map +1 -1
- package/dist/types/hooks/useCommonCollectionFeatures.d.ts +9 -9
- package/dist/types/hooks/useCommonCollectionFeatures.d.ts.map +1 -1
- package/dist/types/hooks/useEmptyStates.d.ts.map +1 -1
- package/dist/types/hooks/useFetchData.d.ts +6 -2
- package/dist/types/hooks/useFetchData.d.ts.map +1 -1
- package/dist/types/hooks/useFilters.d.ts +5 -1
- package/dist/types/hooks/useFilters.d.ts.map +1 -1
- package/dist/types/hooks/useGridFeatures.d.ts +2 -8
- package/dist/types/hooks/useGridFeatures.d.ts.map +1 -1
- package/dist/types/hooks/useNavigationUtils.d.ts +10 -0
- package/dist/types/hooks/useNavigationUtils.d.ts.map +1 -0
- package/dist/types/hooks/usePagePath.d.ts +5 -0
- package/dist/types/hooks/usePagePath.d.ts.map +1 -0
- package/dist/types/hooks/useSharedDataForActions.d.ts +8 -0
- package/dist/types/hooks/useSharedDataForActions.d.ts.map +1 -0
- package/dist/types/hooks/useTableFeatures.d.ts +3 -7
- package/dist/types/hooks/useTableFeatures.d.ts.map +1 -1
- package/dist/types/providers/AppConfigContext.d.ts +8 -0
- package/dist/types/providers/AppConfigContext.d.ts.map +1 -0
- package/dist/types/providers/ModalContext.d.ts +20 -0
- package/dist/types/providers/ModalContext.d.ts.map +1 -0
- package/dist/types/providers/PatternsWizardOverridesContext.d.ts +5 -2
- package/dist/types/providers/PatternsWizardOverridesContext.d.ts.map +1 -1
- package/dist/types/providers/RootAppProvider.d.ts +7 -0
- package/dist/types/providers/RootAppProvider.d.ts.map +1 -0
- package/dist/types/providers/SchemaContext.d.ts.map +1 -1
- package/dist/types/providers/SchemaRegistryContext.d.ts +13 -0
- package/dist/types/providers/SchemaRegistryContext.d.ts.map +1 -0
- package/dist/types/providers/index.d.ts +4 -1
- package/dist/types/providers/index.d.ts.map +1 -1
- package/dist/types/types/CollectionPageConfig.d.ts +33 -32
- package/dist/types/types/CollectionPageConfig.d.ts.map +1 -1
- package/dist/types/types/EntityPageConfig.d.ts +51 -2
- package/dist/types/types/EntityPageConfig.d.ts.map +1 -1
- package/dist/types/types/actions/actionCell.d.ts +24 -0
- package/dist/types/types/actions/actionCell.d.ts.map +1 -0
- package/dist/types/types/actions/base.d.ts +93 -0
- package/dist/types/types/actions/base.d.ts.map +1 -0
- package/dist/types/types/actions/bulkActions.d.ts +28 -0
- package/dist/types/types/actions/bulkActions.d.ts.map +1 -0
- package/dist/types/types/actions/index.d.ts +4 -0
- package/dist/types/types/actions/index.d.ts.map +1 -0
- package/dist/types/types/index.d.ts +2 -0
- package/dist/types/types/index.d.ts.map +1 -1
- package/dist/types/types/types.d.ts +48 -10
- package/dist/types/types/types.d.ts.map +1 -1
- package/dist/types/utils/actions/bulkDeleteAction.d.ts +7 -0
- package/dist/types/utils/actions/bulkDeleteAction.d.ts.map +1 -0
- package/dist/types/utils/actions/customAction.d.ts +3 -0
- package/dist/types/utils/actions/customAction.d.ts.map +1 -0
- package/dist/types/utils/actions/customModalAction.d.ts +5 -0
- package/dist/types/utils/actions/customModalAction.d.ts.map +1 -0
- package/dist/types/utils/actions/deleteAction.d.ts +7 -0
- package/dist/types/utils/actions/deleteAction.d.ts.map +1 -0
- package/dist/types/utils/actions/index.d.ts +8 -0
- package/dist/types/utils/actions/index.d.ts.map +1 -0
- package/dist/types/utils/actions/resolveAction.d.ts +11 -0
- package/dist/types/utils/actions/resolveAction.d.ts.map +1 -0
- package/dist/types/utils/actions/types.d.ts +65 -0
- package/dist/types/utils/actions/types.d.ts.map +1 -0
- package/dist/types/utils/actions/updateAction.d.ts +7 -0
- package/dist/types/utils/actions/updateAction.d.ts.map +1 -0
- package/dist/types/utils/filterCreators.d.ts +48 -0
- package/dist/types/utils/filterCreators.d.ts.map +1 -0
- package/dist/types/utils/media/getImageUrl.d.ts +3 -0
- package/dist/types/utils/media/getImageUrl.d.ts.map +1 -0
- package/form/package.json +6 -0
- package/package.json +10 -8
- package/dist/cjs/collectionData/CollectionData.js.map +0 -1
- package/dist/cjs/collectionData/CollectionDataFactory.js +0 -12
- package/dist/cjs/collectionData/CollectionDataFactory.js.map +0 -1
- package/dist/cjs/collectionData/SchemaFactory.js +0 -12
- package/dist/cjs/collectionData/SchemaFactory.js.map +0 -1
- package/dist/cjs/collectionData/cms/CmsCollectionData.js.map +0 -1
- package/dist/cjs/collectionData/cms/filterUtils.js.map +0 -1
- package/dist/cjs/collectionData/cms/sortUtils.js.map +0 -1
- package/dist/cjs/collectionData/constants.js.map +0 -1
- package/dist/cjs/collectionData/index.js +0 -10
- package/dist/cjs/collectionData/index.js.map +0 -1
- package/dist/cjs/providers/CollectionDataContext.js +0 -44
- package/dist/cjs/providers/CollectionDataContext.js.map +0 -1
- package/dist/cjs/utils/filters.js +0 -53
- package/dist/cjs/utils/filters.js.map +0 -1
- package/dist/esm/collectionData/CollectionData.js +0 -2
- package/dist/esm/collectionData/CollectionData.js.map +0 -1
- package/dist/esm/collectionData/CollectionDataFactory.js +0 -8
- package/dist/esm/collectionData/CollectionDataFactory.js.map +0 -1
- package/dist/esm/collectionData/SchemaFactory.js +0 -8
- package/dist/esm/collectionData/SchemaFactory.js.map +0 -1
- package/dist/esm/collectionData/cms/CmsCollectionData.js +0 -91
- package/dist/esm/collectionData/cms/CmsCollectionData.js.map +0 -1
- package/dist/esm/collectionData/cms/filterUtils.js.map +0 -1
- package/dist/esm/collectionData/cms/sortUtils.js.map +0 -1
- package/dist/esm/collectionData/constants.js.map +0 -1
- package/dist/esm/collectionData/index.js +0 -2
- package/dist/esm/collectionData/index.js.map +0 -1
- package/dist/esm/providers/CollectionDataContext.js +0 -30
- package/dist/esm/providers/CollectionDataContext.js.map +0 -1
- package/dist/esm/utils/filters.js +0 -49
- package/dist/esm/utils/filters.js.map +0 -1
- package/dist/types/collectionData/CollectionData.d.ts +0 -9
- package/dist/types/collectionData/CollectionData.d.ts.map +0 -1
- package/dist/types/collectionData/CollectionDataFactory.d.ts +0 -4
- package/dist/types/collectionData/CollectionDataFactory.d.ts.map +0 -1
- package/dist/types/collectionData/SchemaFactory.d.ts +0 -3
- package/dist/types/collectionData/SchemaFactory.d.ts.map +0 -1
- package/dist/types/collectionData/cms/CmsCollectionData.d.ts +0 -8
- package/dist/types/collectionData/cms/CmsCollectionData.d.ts.map +0 -1
- package/dist/types/collectionData/cms/filterUtils.d.ts.map +0 -1
- package/dist/types/collectionData/cms/sortUtils.d.ts.map +0 -1
- package/dist/types/collectionData/constants.d.ts.map +0 -1
- package/dist/types/collectionData/index.d.ts +0 -2
- package/dist/types/collectionData/index.d.ts.map +0 -1
- package/dist/types/providers/CollectionDataContext.d.ts +0 -12
- package/dist/types/providers/CollectionDataContext.d.ts.map +0 -1
- package/dist/types/utils/filters.d.ts +0 -7
- package/dist/types/utils/filters.d.ts.map +0 -1
- /package/dist/cjs/{collectionData → dataSourceAdapters}/cms/sortUtils.js +0 -0
- /package/dist/cjs/{collectionData → dataSourceAdapters}/constants.js +0 -0
- /package/dist/esm/{collectionData → dataSourceAdapters}/cms/sortUtils.js +0 -0
- /package/dist/esm/{collectionData → dataSourceAdapters}/constants.js +0 -0
- /package/dist/types/{collectionData → dataSourceAdapters}/cms/sortUtils.d.ts +0 -0
- /package/dist/types/{collectionData → dataSourceAdapters}/constants.d.ts +0 -0
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.createReferenceFilter = exports.createNumberFilter = exports.createEnumFilter = exports.createDateTimeFilter = exports.createBooleanFilter = void 0;
|
|
5
|
+
var _patterns = require("@wix/patterns");
|
|
6
|
+
var _constants = require("../dataSourceAdapters/constants");
|
|
7
|
+
const createDateTimeFilter = ({
|
|
8
|
+
id,
|
|
9
|
+
fieldId,
|
|
10
|
+
commonFilterProps,
|
|
11
|
+
config
|
|
12
|
+
}) => ({
|
|
13
|
+
key: id,
|
|
14
|
+
fieldId,
|
|
15
|
+
filter: (0, _patterns.dateRangeFilter)(),
|
|
16
|
+
component: _patterns.DateRangeFilter,
|
|
17
|
+
props: {
|
|
18
|
+
...commonFilterProps,
|
|
19
|
+
mode: config == null ? void 0 : config.mode,
|
|
20
|
+
dateRangeOptions: config == null ? void 0 : config.presets,
|
|
21
|
+
filterByTime: config == null ? void 0 : config.includeTime
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
exports.createDateTimeFilter = createDateTimeFilter;
|
|
25
|
+
const createBooleanFilter = ({
|
|
26
|
+
id,
|
|
27
|
+
fieldId,
|
|
28
|
+
commonFilterProps,
|
|
29
|
+
config
|
|
30
|
+
}) => ({
|
|
31
|
+
key: id,
|
|
32
|
+
fieldId,
|
|
33
|
+
filter: (0, _patterns.idNameArrayFilter)({
|
|
34
|
+
matches: (fieldValue, filterValue) => {
|
|
35
|
+
if (fieldValue) {
|
|
36
|
+
return filterValue.some(v => v.id === _constants.BooleanFilters.checked);
|
|
37
|
+
}
|
|
38
|
+
return filterValue.some(v => v.id === _constants.BooleanFilters.unchecked);
|
|
39
|
+
}
|
|
40
|
+
}),
|
|
41
|
+
component: _patterns.RadioGroupFilter,
|
|
42
|
+
props: {
|
|
43
|
+
...commonFilterProps,
|
|
44
|
+
data: [{
|
|
45
|
+
id: 'checked',
|
|
46
|
+
name: (config == null ? void 0 : config.trueLabel) || 'Yes'
|
|
47
|
+
}, {
|
|
48
|
+
id: 'unchecked',
|
|
49
|
+
name: (config == null ? void 0 : config.falseLabel) || 'No'
|
|
50
|
+
}]
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
exports.createBooleanFilter = createBooleanFilter;
|
|
54
|
+
const createNumberFilter = ({
|
|
55
|
+
id,
|
|
56
|
+
fieldId,
|
|
57
|
+
commonFilterProps,
|
|
58
|
+
config
|
|
59
|
+
}) => ({
|
|
60
|
+
key: id,
|
|
61
|
+
fieldId,
|
|
62
|
+
filter: (0, _patterns.numberRangeFilter)(),
|
|
63
|
+
component: _patterns.NumberRangeFilter,
|
|
64
|
+
props: {
|
|
65
|
+
...commonFilterProps,
|
|
66
|
+
min: config == null ? void 0 : config.min,
|
|
67
|
+
max: config == null ? void 0 : config.max,
|
|
68
|
+
decimal: config == null ? void 0 : config.allowedDecimals
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
exports.createNumberFilter = createNumberFilter;
|
|
72
|
+
const createEnumFilter = ({
|
|
73
|
+
id,
|
|
74
|
+
fieldId,
|
|
75
|
+
commonFilterProps,
|
|
76
|
+
config
|
|
77
|
+
}) => {
|
|
78
|
+
const {
|
|
79
|
+
options,
|
|
80
|
+
selectionMode,
|
|
81
|
+
optionType
|
|
82
|
+
} = config;
|
|
83
|
+
const data = (options == null ? void 0 : options.map(option => ({
|
|
84
|
+
id: option.value,
|
|
85
|
+
name: option.label
|
|
86
|
+
}))) ?? [];
|
|
87
|
+
const inlineComponentThreshold = 5;
|
|
88
|
+
let component;
|
|
89
|
+
if (selectionMode === 'single') {
|
|
90
|
+
component = data.length > inlineComponentThreshold ? _patterns.AutoCompleteFilter : _patterns.RadioGroupFilter;
|
|
91
|
+
if (optionType === 'select') {
|
|
92
|
+
component = _patterns.AutoCompleteFilter;
|
|
93
|
+
} else if (optionType === 'radio') {
|
|
94
|
+
component = _patterns.RadioGroupFilter;
|
|
95
|
+
}
|
|
96
|
+
} else {
|
|
97
|
+
component = data.length > inlineComponentThreshold ? _patterns.MultiSelectCheckboxFilter : _patterns.MultiInlineCheckboxFilter;
|
|
98
|
+
if (optionType === 'select') {
|
|
99
|
+
component = _patterns.MultiSelectCollectionFilter;
|
|
100
|
+
} else if (optionType === 'inlineCheckbox') {
|
|
101
|
+
component = _patterns.MultiInlineCheckboxFilter;
|
|
102
|
+
} else if (optionType === 'checkbox') {
|
|
103
|
+
component = _patterns.MultiSelectCheckboxFilter;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
return {
|
|
107
|
+
key: id,
|
|
108
|
+
fieldId,
|
|
109
|
+
filter: (0, _patterns.idNameArrayFilter)(),
|
|
110
|
+
component,
|
|
111
|
+
collectionData: data,
|
|
112
|
+
props: {
|
|
113
|
+
...commonFilterProps,
|
|
114
|
+
data
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
};
|
|
118
|
+
exports.createEnumFilter = createEnumFilter;
|
|
119
|
+
const createReferenceFilter = ({
|
|
120
|
+
id,
|
|
121
|
+
fieldId,
|
|
122
|
+
commonFilterProps,
|
|
123
|
+
config,
|
|
124
|
+
additionalParams
|
|
125
|
+
}) => {
|
|
126
|
+
const component = (config == null ? void 0 : config.selectionMode) === 'single' ? _patterns.AutoCompleteFilter : _patterns.MultiSelectCollectionFilter;
|
|
127
|
+
return {
|
|
128
|
+
key: id,
|
|
129
|
+
fieldId,
|
|
130
|
+
filter: (0, _patterns.idNameArrayFilter)(),
|
|
131
|
+
component,
|
|
132
|
+
collectionId: additionalParams.referencedSchema.id,
|
|
133
|
+
props: commonFilterProps
|
|
134
|
+
};
|
|
135
|
+
};
|
|
136
|
+
exports.createReferenceFilter = createReferenceFilter;
|
|
137
|
+
//# sourceMappingURL=filterCreators.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_patterns","require","_constants","createDateTimeFilter","id","fieldId","commonFilterProps","config","key","filter","dateRangeFilter","component","DateRangeFilter","props","mode","dateRangeOptions","presets","filterByTime","includeTime","exports","createBooleanFilter","idNameArrayFilter","matches","fieldValue","filterValue","some","v","BooleanFilters","checked","unchecked","RadioGroupFilter","data","name","trueLabel","falseLabel","createNumberFilter","numberRangeFilter","NumberRangeFilter","min","max","decimal","allowedDecimals","createEnumFilter","options","selectionMode","optionType","map","option","value","label","inlineComponentThreshold","length","AutoCompleteFilter","MultiSelectCheckboxFilter","MultiInlineCheckboxFilter","MultiSelectCollectionFilter","collectionData","createReferenceFilter","additionalParams","collectionId","referencedSchema"],"sources":["../../../src/utils/filterCreators.ts"],"sourcesContent":["import {\n dateRangeFilter,\n idNameArrayFilter,\n numberRangeFilter,\n DateRangeFilter,\n RadioGroupFilter,\n NumberRangeFilter,\n AutoCompleteFilter,\n MultiSelectCheckboxFilter,\n MultiInlineCheckboxFilter,\n MultiSelectCollectionFilter,\n} from '@wix/patterns';\nimport { BooleanFilters } from '../dataSourceAdapters/constants';\nimport { FilterOptions } from '../hooks/useFilters';\nimport { SchemaConfig } from '../types';\n\ninterface FilterOption {\n value: string;\n label: string;\n}\n\ninterface BaseFilterParams {\n id: string;\n fieldId: string;\n commonFilterProps: Record<string, any>;\n}\n\nexport const createDateTimeFilter = ({\n id,\n fieldId,\n commonFilterProps,\n config,\n}: BaseFilterParams & {\n config?: {\n mode?: 'ONLY_PREDEFINED' | 'ONLY_CUSTOM' | 'COMBINE';\n presets?: string[];\n includeTime?: boolean;\n };\n}): FilterOptions => ({\n key: id,\n fieldId,\n filter: dateRangeFilter(),\n component: DateRangeFilter,\n props: {\n ...commonFilterProps,\n mode: config?.mode,\n dateRangeOptions: config?.presets,\n filterByTime: config?.includeTime,\n },\n});\n\nexport const createBooleanFilter = ({\n id,\n fieldId,\n commonFilterProps,\n config,\n}: BaseFilterParams & {\n config?: {\n trueLabel?: string;\n falseLabel?: string;\n };\n}): FilterOptions => ({\n key: id,\n fieldId,\n filter: idNameArrayFilter({\n matches: (fieldValue, filterValue) => {\n if (fieldValue) {\n return filterValue.some((v) => v.id === BooleanFilters.checked);\n }\n return filterValue.some((v) => v.id === BooleanFilters.unchecked);\n },\n }),\n component: RadioGroupFilter,\n props: {\n ...commonFilterProps,\n data: [\n {\n id: 'checked',\n name: config?.trueLabel || 'Yes',\n },\n {\n id: 'unchecked',\n name: config?.falseLabel || 'No',\n },\n ],\n },\n});\n\nexport const createNumberFilter = ({\n id,\n fieldId,\n commonFilterProps,\n config,\n}: BaseFilterParams & {\n config?: {\n min?: number;\n max?: number;\n allowedDecimals?: boolean;\n };\n}): FilterOptions => ({\n key: id,\n fieldId,\n filter: numberRangeFilter(),\n component: NumberRangeFilter,\n props: {\n ...commonFilterProps,\n min: config?.min,\n max: config?.max,\n decimal: config?.allowedDecimals,\n },\n});\n\nexport const createEnumFilter = ({\n id,\n fieldId,\n commonFilterProps,\n config,\n}: BaseFilterParams & {\n config: {\n options?: FilterOption[];\n selectionMode?: 'single' | 'multiple';\n optionType?: 'select' | 'radio' | 'checkbox' | 'inlineCheckbox';\n };\n}): FilterOptions => {\n const { options, selectionMode, optionType } = config;\n const data =\n options?.map((option: FilterOption) => ({\n id: option.value,\n name: option.label,\n })) ?? [];\n\n const inlineComponentThreshold = 5;\n\n let component;\n\n if (selectionMode === 'single') {\n component =\n data.length > inlineComponentThreshold\n ? AutoCompleteFilter\n : RadioGroupFilter;\n if (optionType === 'select') {\n component = AutoCompleteFilter;\n } else if (optionType === 'radio') {\n component = RadioGroupFilter;\n }\n } else {\n component =\n data.length > inlineComponentThreshold\n ? MultiSelectCheckboxFilter\n : MultiInlineCheckboxFilter;\n if (optionType === 'select') {\n component = MultiSelectCollectionFilter;\n } else if (optionType === 'inlineCheckbox') {\n component = MultiInlineCheckboxFilter;\n } else if (optionType === 'checkbox') {\n component = MultiSelectCheckboxFilter;\n }\n }\n\n return {\n key: id,\n fieldId,\n filter: idNameArrayFilter(),\n component,\n collectionData: data,\n props: { ...commonFilterProps, data },\n };\n};\n\nexport const createReferenceFilter = ({\n id,\n fieldId,\n commonFilterProps,\n config,\n additionalParams,\n}: BaseFilterParams & {\n config?: {\n selectionMode?: 'single' | 'multiple';\n };\n additionalParams: {\n referencedSchema: SchemaConfig;\n };\n}): FilterOptions => {\n const component =\n config?.selectionMode === 'single'\n ? AutoCompleteFilter\n : MultiSelectCollectionFilter;\n\n return {\n key: id,\n fieldId,\n filter: idNameArrayFilter(),\n component,\n collectionId: additionalParams.referencedSchema.id,\n props: commonFilterProps,\n };\n};\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.getImageUrl = void 0;
|
|
5
|
+
exports.isAbsoluteUrl = isAbsoluteUrl;
|
|
6
|
+
var _sdk = require("@wix/sdk");
|
|
7
|
+
const getImageUrl = image => {
|
|
8
|
+
if (isAbsoluteUrl(image)) {
|
|
9
|
+
return image;
|
|
10
|
+
}
|
|
11
|
+
return _sdk.media.getImageUrl(image).url;
|
|
12
|
+
};
|
|
13
|
+
exports.getImageUrl = getImageUrl;
|
|
14
|
+
function isAbsoluteUrl(url) {
|
|
15
|
+
try {
|
|
16
|
+
const parsed = new URL(url);
|
|
17
|
+
return !!parsed.protocol && !!parsed.host;
|
|
18
|
+
} catch {
|
|
19
|
+
return false;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=getImageUrl.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_sdk","require","getImageUrl","image","isAbsoluteUrl","media","url","exports","parsed","URL","protocol","host"],"sources":["../../../../src/utils/media/getImageUrl.ts"],"sourcesContent":["import { media } from '@wix/sdk';\n\nexport const getImageUrl = (image: string) => {\n if (isAbsoluteUrl(image)) {\n return image;\n }\n\n return media.getImageUrl(image).url;\n};\n\nexport function isAbsoluteUrl(url: string): boolean {\n try {\n const parsed = new URL(url);\n return !!parsed.protocol && !!parsed.host;\n } catch {\n return false;\n }\n}\n"],"mappings":";;;;;AAAA,IAAAA,IAAA,GAAAC,OAAA;AAEO,MAAMC,WAAW,GAAIC,KAAa,IAAK;EAC5C,IAAIC,aAAa,CAACD,KAAK,CAAC,EAAE;IACxB,OAAOA,KAAK;EACd;EAEA,OAAOE,UAAK,CAACH,WAAW,CAACC,KAAK,CAAC,CAACG,GAAG;AACrC,CAAC;AAACC,OAAA,CAAAL,WAAA,GAAAA,WAAA;AAEK,SAASE,aAAaA,CAACE,GAAW,EAAW;EAClD,IAAI;IACF,MAAME,MAAM,GAAG,IAAIC,GAAG,CAACH,GAAG,CAAC;IAC3B,OAAO,CAAC,CAACE,MAAM,CAACE,QAAQ,IAAI,CAAC,CAACF,MAAM,CAACG,IAAI;EAC3C,CAAC,CAAC,MAAM;IACN,OAAO,KAAK;EACd;AACF","ignoreList":[]}
|
|
@@ -1,22 +1,14 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
const pageTypeToRouteType = {
|
|
5
|
-
collectionPage: 'collection',
|
|
6
|
-
entityPage: 'editEntity'
|
|
7
|
-
};
|
|
2
|
+
import { RootAppProvider } from '../../providers/RootAppProvider';
|
|
3
|
+
import { AutoPatternsRoutes } from '../AutoPatternsRoute/AutoPatternsRoutes';
|
|
8
4
|
export const AutoPatternsApp = _ref => {
|
|
9
5
|
let {
|
|
10
6
|
configuration
|
|
11
7
|
} = _ref;
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
element: /*#__PURE__*/React.createElement(AutoPatternsPage, {
|
|
17
|
-
pageConfig: page
|
|
18
|
-
})
|
|
8
|
+
return /*#__PURE__*/React.createElement(RootAppProvider, {
|
|
9
|
+
appConfig: configuration
|
|
10
|
+
}, /*#__PURE__*/React.createElement(AutoPatternsRoutes, {
|
|
11
|
+
config: configuration
|
|
19
12
|
}));
|
|
20
|
-
return /*#__PURE__*/React.createElement(PatternsReactRouter, null, routes);
|
|
21
13
|
};
|
|
22
14
|
//# sourceMappingURL=AutoPatternsApp.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","
|
|
1
|
+
{"version":3,"names":["React","RootAppProvider","AutoPatternsRoutes","AutoPatternsApp","_ref","configuration","createElement","appConfig","config"],"sources":["../../../../src/components/AutoPatternsApp/AutoPatternsApp.tsx"],"sourcesContent":["import React from 'react';\nimport { AppConfig } from '../../types';\nimport { RootAppProvider } from '../../providers/RootAppProvider';\nimport { AutoPatternsRoutes } from '../AutoPatternsRoute/AutoPatternsRoutes';\n\nexport interface AutoPatternsAppPageProps {\n configuration: AppConfig;\n}\n\nexport const AutoPatternsApp: React.FC<AutoPatternsAppPageProps> = ({\n configuration,\n}) => {\n return (\n <RootAppProvider appConfig={configuration}>\n <AutoPatternsRoutes config={configuration} />\n </RootAppProvider>\n );\n};\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAEzB,SAASC,eAAe,QAAQ,iCAAiC;AACjE,SAASC,kBAAkB,QAAQ,yCAAyC;AAM5E,OAAO,MAAMC,eAAmD,GAAGC,IAAA,IAE7D;EAAA,IAF8D;IAClEC;EACF,CAAC,GAAAD,IAAA;EACC,oBACEJ,KAAA,CAAAM,aAAA,CAACL,eAAe;IAACM,SAAS,EAAEF;EAAc,gBACxCL,KAAA,CAAAM,aAAA,CAACJ,kBAAkB;IAACM,MAAM,EAAEH;EAAc,CAAE,CAC7B,CAAC;AAEtB,CAAC","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","AutoPatternsTable","AutoPatternsGrid","AutoPatternsCollectionPageContent","_ref","configuration","components","createElement","Fragment","map","component","type","table","key","collection","collectionId","grid"],"sources":["../../../../src/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.tsx"],"sourcesContent":["import React from 'react';\nimport { AutoPatternsTable } from '../AutoPatternsTable';\nimport { CollectionPageConfig } from '../../types';\nimport { AutoPatternsGrid } from '../AutoPatternsGrid';\n\nexport interface AutoPatternsCollectionPageContentProps {\n configuration: CollectionPageConfig;\n}\n\nexport const AutoPatternsCollectionPageContent = ({\n configuration,\n}: AutoPatternsCollectionPageContentProps) => {\n const { components } = configuration;\n return (\n <>\n {components.map((component) => {\n const { type } = component;\n switch (type) {\n case 'Table':\n if (component.table) {\n return (\n <AutoPatternsTable\n key={component.table.collection.collectionId}\n configuration={component.table}\n />\n );\n }\n return null;\n case 'Grid':\n if (component.grid) {\n return <AutoPatternsGrid
|
|
1
|
+
{"version":3,"names":["React","AutoPatternsTable","AutoPatternsGrid","AutoPatternsCollectionPageContent","_ref","configuration","components","createElement","Fragment","map","component","type","table","key","collection","collectionId","grid"],"sources":["../../../../src/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.tsx"],"sourcesContent":["import React from 'react';\nimport { AutoPatternsTable } from '../AutoPatternsTable';\nimport { CollectionPageConfig } from '../../types';\nimport { AutoPatternsGrid } from '../AutoPatternsGrid';\n\nexport interface AutoPatternsCollectionPageContentProps {\n configuration: CollectionPageConfig;\n}\n\nexport const AutoPatternsCollectionPageContent = ({\n configuration,\n}: AutoPatternsCollectionPageContentProps) => {\n const { components } = configuration;\n return (\n <>\n {components.map((component) => {\n const { type } = component;\n switch (type) {\n case 'Table':\n if (component.table) {\n return (\n <AutoPatternsTable\n key={component.table.collection.collectionId}\n configuration={component.table}\n />\n );\n }\n return null;\n case 'Grid':\n if (component.grid) {\n return (\n <AutoPatternsGrid\n key={component.grid.collection.collectionId}\n configuration={component.grid}\n />\n );\n }\n return null;\n default:\n return null;\n }\n })}\n </>\n );\n};\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,iBAAiB,QAAQ,sBAAsB;AAExD,SAASC,gBAAgB,QAAQ,qBAAqB;AAMtD,OAAO,MAAMC,iCAAiC,GAAGC,IAAA,IAEH;EAAA,IAFI;IAChDC;EACsC,CAAC,GAAAD,IAAA;EACvC,MAAM;IAAEE;EAAW,CAAC,GAAGD,aAAa;EACpC,oBACEL,KAAA,CAAAO,aAAA,CAAAP,KAAA,CAAAQ,QAAA,QACGF,UAAU,CAACG,GAAG,CAAEC,SAAS,IAAK;IAC7B,MAAM;MAAEC;IAAK,CAAC,GAAGD,SAAS;IAC1B,QAAQC,IAAI;MACV,KAAK,OAAO;QACV,IAAID,SAAS,CAACE,KAAK,EAAE;UACnB,oBACEZ,KAAA,CAAAO,aAAA,CAACN,iBAAiB;YAChBY,GAAG,EAAEH,SAAS,CAACE,KAAK,CAACE,UAAU,CAACC,YAAa;YAC7CV,aAAa,EAAEK,SAAS,CAACE;UAAM,CAChC,CAAC;QAEN;QACA,OAAO,IAAI;MACb,KAAK,MAAM;QACT,IAAIF,SAAS,CAACM,IAAI,EAAE;UAClB,oBACEhB,KAAA,CAAAO,aAAA,CAACL,gBAAgB;YACfW,GAAG,EAAEH,SAAS,CAACM,IAAI,CAACF,UAAU,CAACC,YAAa;YAC5CV,aAAa,EAAEK,SAAS,CAACM;UAAK,CAC/B,CAAC;QAEN;QACA,OAAO,IAAI;MACb;QACE,OAAO,IAAI;IACf;EACF,CAAC,CACD,CAAC;AAEP,CAAC","ignoreList":[]}
|
|
@@ -1,44 +1,153 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import { EntityPage, useEntity, useEntityPage } from '@wix/patterns';
|
|
1
|
+
import React, { useMemo, useRef } from 'react';
|
|
2
|
+
import { EntityPage, useEntity, useEntityPage, useEntityPageContext } from '@wix/patterns';
|
|
3
3
|
import { useForm } from '@wix/patterns/form';
|
|
4
|
-
import {
|
|
5
|
-
import { FormFieldInput } from './Fields/FormFieldInput';
|
|
4
|
+
import { Card, Cell, Layout } from '@wix/design-system';
|
|
6
5
|
import { useParams } from 'react-router-dom';
|
|
7
6
|
import { useSchema } from '../../providers/SchemaContext';
|
|
8
|
-
|
|
7
|
+
import { FormFieldInput } from './Fields/FormFieldInput';
|
|
8
|
+
import { useNavigation } from '../../hooks';
|
|
9
|
+
import { usePatternsWizardOverridesContext } from '../../providers';
|
|
10
|
+
const RenderLayoutContent = _ref => {
|
|
11
|
+
var _content$container$ch, _overrides$components;
|
|
9
12
|
let {
|
|
10
|
-
|
|
13
|
+
content,
|
|
14
|
+
level,
|
|
15
|
+
sectionId,
|
|
16
|
+
cardIndex,
|
|
17
|
+
contentIndex,
|
|
18
|
+
setInputRef
|
|
11
19
|
} = _ref;
|
|
20
|
+
const schema = useSchema();
|
|
21
|
+
const overrides = usePatternsWizardOverridesContext();
|
|
22
|
+
const pageState = useEntityPageContext();
|
|
23
|
+
switch (content.type) {
|
|
24
|
+
case 'field':
|
|
25
|
+
if (!content.field.fieldId) {
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
const field = schema.fields[content.field.fieldId];
|
|
29
|
+
if (!field) {
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
return /*#__PURE__*/React.createElement(Cell, {
|
|
33
|
+
span: content.field.span
|
|
34
|
+
}, /*#__PURE__*/React.createElement(FormFieldInput, {
|
|
35
|
+
key: content.field.fieldId,
|
|
36
|
+
field: field,
|
|
37
|
+
inputRef: ref => setInputRef(content.field.fieldId, ref)
|
|
38
|
+
}));
|
|
39
|
+
case 'container':
|
|
40
|
+
if (!((_content$container$ch = content.container.children) != null && _content$container$ch.length)) {
|
|
41
|
+
return null;
|
|
42
|
+
}
|
|
43
|
+
return /*#__PURE__*/React.createElement(Cell, {
|
|
44
|
+
span: content.container.span
|
|
45
|
+
}, /*#__PURE__*/React.createElement(Layout, null, content.container.children.map((child, index) => /*#__PURE__*/React.createElement(RenderLayoutContent, {
|
|
46
|
+
key: `${sectionId}-card-${cardIndex}-content-${contentIndex}-level-${level}-child-${index}`,
|
|
47
|
+
content: child,
|
|
48
|
+
level: level + 1,
|
|
49
|
+
sectionId: sectionId,
|
|
50
|
+
cardIndex: cardIndex,
|
|
51
|
+
contentIndex: index,
|
|
52
|
+
setInputRef: setInputRef
|
|
53
|
+
}))));
|
|
54
|
+
case 'component':
|
|
55
|
+
if (!content.component.componentId) {
|
|
56
|
+
return null;
|
|
57
|
+
}
|
|
58
|
+
const Component = overrides == null || (_overrides$components = overrides.components) == null ? void 0 : _overrides$components[content.component.componentId];
|
|
59
|
+
if (!Component) {
|
|
60
|
+
return null;
|
|
61
|
+
}
|
|
62
|
+
return /*#__PURE__*/React.createElement(Cell, {
|
|
63
|
+
span: content.component.span
|
|
64
|
+
}, /*#__PURE__*/React.createElement(Component, {
|
|
65
|
+
form: pageState.form,
|
|
66
|
+
entity: pageState.entity
|
|
67
|
+
}));
|
|
68
|
+
default:
|
|
69
|
+
return null;
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
const RenderLayoutCard = _ref2 => {
|
|
73
|
+
var _layout$card$subtitle;
|
|
74
|
+
let {
|
|
75
|
+
layout,
|
|
76
|
+
sectionId,
|
|
77
|
+
cardIndex,
|
|
78
|
+
setInputRef
|
|
79
|
+
} = _ref2;
|
|
80
|
+
switch (layout.type) {
|
|
81
|
+
case 'card':
|
|
82
|
+
return /*#__PURE__*/React.createElement(EntityPage.Card, {
|
|
83
|
+
minHeight: "50px"
|
|
84
|
+
}, /*#__PURE__*/React.createElement(Card.Header, {
|
|
85
|
+
title: layout.card.title.text,
|
|
86
|
+
subtitle: (_layout$card$subtitle = layout.card.subtitle) == null ? void 0 : _layout$card$subtitle.text
|
|
87
|
+
}), /*#__PURE__*/React.createElement(Card.Divider, null), /*#__PURE__*/React.createElement(Card.Content, null, /*#__PURE__*/React.createElement(Layout, null, layout.card.children.map((child, index) => /*#__PURE__*/React.createElement(RenderLayoutContent, {
|
|
88
|
+
key: `${sectionId}-card-${cardIndex}-content-${index}`,
|
|
89
|
+
content: child,
|
|
90
|
+
level: 0,
|
|
91
|
+
sectionId: sectionId,
|
|
92
|
+
cardIndex: cardIndex,
|
|
93
|
+
contentIndex: index,
|
|
94
|
+
setInputRef: setInputRef
|
|
95
|
+
})))));
|
|
96
|
+
default:
|
|
97
|
+
return null;
|
|
98
|
+
}
|
|
99
|
+
};
|
|
100
|
+
export const AutoPatternsEntityPage = _ref3 => {
|
|
101
|
+
var _pageLayout$main, _pageLayout$sidebar;
|
|
102
|
+
let {
|
|
103
|
+
configuration
|
|
104
|
+
} = _ref3;
|
|
12
105
|
const {
|
|
13
106
|
title,
|
|
14
107
|
subtitle,
|
|
15
|
-
|
|
16
|
-
|
|
108
|
+
layout: pageLayout,
|
|
109
|
+
parentPageId,
|
|
110
|
+
route
|
|
17
111
|
} = configuration;
|
|
18
112
|
const form = useForm();
|
|
19
113
|
const params = useParams();
|
|
20
|
-
const entityId = params.
|
|
114
|
+
const entityId = params[route.params.id];
|
|
21
115
|
const schema = useSchema();
|
|
116
|
+
const inputRefs = useRef({});
|
|
117
|
+
const setInputRef = (id, input) => {
|
|
118
|
+
inputRefs.current[id] = input;
|
|
119
|
+
};
|
|
120
|
+
const validate = () => {
|
|
121
|
+
const invalidFieldId = Object.keys(inputRefs.current).find(fieldId => {
|
|
122
|
+
var _inputRefs$current$fi;
|
|
123
|
+
return (_inputRefs$current$fi = inputRefs.current[fieldId]) == null ? void 0 : _inputRefs$current$fi.invalid;
|
|
124
|
+
});
|
|
125
|
+
if (invalidFieldId) {
|
|
126
|
+
var _inputRefs$current$in;
|
|
127
|
+
(_inputRefs$current$in = inputRefs.current[invalidFieldId]) == null || _inputRefs$current$in.focus == null || _inputRefs$current$in.focus();
|
|
128
|
+
throw new Error('Invalid form');
|
|
129
|
+
}
|
|
130
|
+
};
|
|
131
|
+
const {
|
|
132
|
+
getParentPagePath
|
|
133
|
+
} = useNavigation();
|
|
134
|
+
const parentPath = useMemo(() => getParentPagePath(parentPageId), [parentPageId, getParentPagePath]);
|
|
22
135
|
const state = useEntityPage({
|
|
23
136
|
parentPath,
|
|
24
137
|
form,
|
|
25
138
|
onSave: async () => {
|
|
139
|
+
validate();
|
|
26
140
|
const formValues = form.getValues();
|
|
141
|
+
const baseEntity = state.entity || {};
|
|
27
142
|
const updatedEntity = {
|
|
28
|
-
...
|
|
143
|
+
...baseEntity,
|
|
29
144
|
...formValues
|
|
30
145
|
};
|
|
31
|
-
|
|
32
|
-
if (entityId) {
|
|
33
|
-
newUpdatedEntity = await schema.actions.update(updatedEntity);
|
|
34
|
-
} else {
|
|
35
|
-
newUpdatedEntity = await schema.actions.create(updatedEntity);
|
|
36
|
-
}
|
|
146
|
+
const newEntity = entityId ? await schema.actions.update(updatedEntity) : await schema.actions.create(updatedEntity);
|
|
37
147
|
return {
|
|
38
|
-
updatedEntity:
|
|
148
|
+
updatedEntity: newEntity
|
|
39
149
|
};
|
|
40
150
|
},
|
|
41
|
-
saveErrorToast: () => 'Failed to save',
|
|
42
151
|
fetch: async () => {
|
|
43
152
|
if (!entityId) {
|
|
44
153
|
return {
|
|
@@ -60,21 +169,33 @@ export const AutoPatternsEntityPage = _ref => {
|
|
|
60
169
|
text: (entity == null ? void 0 : entity[schema.displayField]) ?? 'Edit Entity'
|
|
61
170
|
},
|
|
62
171
|
subtitle: subtitle
|
|
63
|
-
}), /*#__PURE__*/React.createElement(EntityPage.Content, null, /*#__PURE__*/React.createElement(EntityPage.MainContent, null, /*#__PURE__*/React.createElement(
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
}
|
|
76
|
-
key: fieldId,
|
|
77
|
-
field: schema.fields[fieldId]
|
|
78
|
-
}))))))))));
|
|
172
|
+
}), /*#__PURE__*/React.createElement(EntityPage.Content, null, /*#__PURE__*/React.createElement(EntityPage.MainContent, null, pageLayout == null || (_pageLayout$main = pageLayout.main) == null ? void 0 : _pageLayout$main.map((layout, layoutIndex) => /*#__PURE__*/React.createElement(RenderLayoutCard, {
|
|
173
|
+
key: `main-section-card-${layoutIndex}`,
|
|
174
|
+
layout: layout,
|
|
175
|
+
sectionId: "main",
|
|
176
|
+
cardIndex: layoutIndex,
|
|
177
|
+
setInputRef: setInputRef
|
|
178
|
+
}))), pageLayout != null && pageLayout.sidebar ? /*#__PURE__*/React.createElement(EntityPage.AdditionalContent, null, (_pageLayout$sidebar = pageLayout.sidebar) == null ? void 0 : _pageLayout$sidebar.map((layout, layoutIndex) => /*#__PURE__*/React.createElement(RenderLayoutCard, {
|
|
179
|
+
key: `sidebar-section-card-${layoutIndex}`,
|
|
180
|
+
layout: layout,
|
|
181
|
+
sectionId: "sidebar",
|
|
182
|
+
cardIndex: layoutIndex,
|
|
183
|
+
setInputRef: setInputRef
|
|
184
|
+
}))) : null));
|
|
79
185
|
};
|
|
186
|
+
|
|
187
|
+
/*
|
|
188
|
+
Key structure explanation:
|
|
189
|
+
|
|
190
|
+
Main cards: main-section-card-{layoutIndex}
|
|
191
|
+
Sidebar cards: sidebar-section-card-{layoutIndex}
|
|
192
|
+
|
|
193
|
+
Layout content:
|
|
194
|
+
{sectionId}-card-{cardIndex}-content-{contentIndex}
|
|
195
|
+
|
|
196
|
+
Nested children:
|
|
197
|
+
{sectionId}-card-{cardIndex}-content-{parentContentIndex}-level-{level}-child-{childIndex}
|
|
198
|
+
|
|
199
|
+
This ensures uniqueness across all levels and sections.
|
|
200
|
+
*/
|
|
80
201
|
//# sourceMappingURL=AutoPatternsEntityPage.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","EntityPage","useEntity","useEntityPage","useForm","Box","Card","Cell","FormFieldInput","useParams","useSchema","AutoPatternsEntityPage","_ref","configuration","title","subtitle","visibleFieldIds","collectionPagePath","parentPath","form","params","entityId","schema","state","onSave","formValues","getValues","updatedEntity","entity","newUpdatedEntity","actions","update","create","saveErrorToast","fetch","undefined","get","createElement","dataHook","Header","text","displayField","Content","MainContent","minHeight","Divider","gap","direction","map","fieldId","Fragment","key","span","field","fields"],"sources":["../../../../src/components/AutoPatternsEntityPage/AutoPatternsEntityPage.tsx"],"sourcesContent":["import React from 'react';\nimport { EntityPageConfig } from '../../types';\nimport {\n EntityPage,\n EntityPageState,\n useEntity,\n useEntityPage,\n} from '@wix/patterns';\nimport { useForm } from '@wix/patterns/form';\nimport { Box, Card, Cell } from '@wix/design-system';\nimport { FormFieldInput } from './Fields/FormFieldInput';\nimport { useParams } from 'react-router-dom';\nimport { useSchema } from '../../providers/SchemaContext';\n\nexport interface AutoPatternsEntityPageProps {\n configuration: EntityPageConfig;\n}\n\nexport const AutoPatternsEntityPage: React.FC<AutoPatternsEntityPageProps> = ({\n configuration,\n}) => {\n const {\n title,\n subtitle,\n visibleFieldIds = [],\n collectionPagePath: parentPath,\n } = configuration;\n const form = useForm<any>();\n const params = useParams();\n const entityId = params.entityId;\n const schema = useSchema();\n const state: EntityPageState<any> = useEntityPage<any, any>({\n parentPath,\n form,\n onSave: async () => {\n const formValues = form.getValues();\n const updatedEntity: any = {\n ...state.entity,\n ...formValues,\n };\n\n let newUpdatedEntity;\n if (entityId) {\n newUpdatedEntity = await schema.actions.update(updatedEntity);\n } else {\n newUpdatedEntity = await schema.actions.create(updatedEntity);\n }\n\n return { updatedEntity: newUpdatedEntity };\n },\n saveErrorToast: () => 'Failed to save',\n fetch: async () => {\n if (!entityId) {\n return { entity: undefined };\n }\n\n const entity = await schema.actions.get(entityId);\n return { entity };\n },\n });\n const entity = useEntity(state);\n\n return (\n <EntityPage state={state} dataHook=\"auto-patterns-entity-page\">\n <EntityPage.Header\n title={\n title ?? { text: entity?.[schema.displayField] ?? 'Edit Entity' }\n }\n subtitle={subtitle}\n />\n <EntityPage.Content>\n <EntityPage.MainContent>\n <EntityPage.Card minHeight=\"50px\">\n <Card.Header\n title=\"Item details\"\n subtitle=\"Modify the details of your selected item below\"\n />\n <Card.Divider />\n <Card.Content>\n <Box gap=\"SP2\" direction=\"vertical\">\n {visibleFieldIds.map((fieldId) => (\n <React.Fragment key={fieldId}>\n <Cell span={12}>\n <FormFieldInput\n key={fieldId}\n field={schema.fields[fieldId]}\n />\n </Cell>\n </React.Fragment>\n ))}\n </Box>\n </Card.Content>\n </EntityPage.Card>\n </EntityPage.MainContent>\n </EntityPage.Content>\n </EntityPage>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["React","useMemo","useRef","EntityPage","useEntity","useEntityPage","useEntityPageContext","useForm","Card","Cell","Layout","useParams","useSchema","FormFieldInput","useNavigation","usePatternsWizardOverridesContext","RenderLayoutContent","_ref","_content$container$ch","_overrides$components","content","level","sectionId","cardIndex","contentIndex","setInputRef","schema","overrides","pageState","type","field","fieldId","fields","createElement","span","key","inputRef","ref","container","children","length","map","child","index","component","componentId","Component","components","form","entity","RenderLayoutCard","_ref2","_layout$card$subtitle","layout","minHeight","Header","title","card","text","subtitle","Divider","Content","AutoPatternsEntityPage","_ref3","_pageLayout$main","_pageLayout$sidebar","configuration","pageLayout","parentPageId","route","params","entityId","id","inputRefs","input","current","validate","invalidFieldId","Object","keys","find","_inputRefs$current$fi","invalid","_inputRefs$current$in","focus","Error","getParentPagePath","parentPath","state","onSave","formValues","getValues","baseEntity","updatedEntity","newEntity","actions","update","create","fetch","undefined","get","dataHook","displayField","MainContent","main","layoutIndex","sidebar","AdditionalContent"],"sources":["../../../../src/components/AutoPatternsEntityPage/AutoPatternsEntityPage.tsx"],"sourcesContent":["import React, { useMemo, useRef } from 'react';\nimport { CardLayout, EntityPageConfig, LayoutContent } from '../../types';\nimport {\n EntityPage,\n EntityPageState,\n useEntity,\n useEntityPage,\n useEntityPageContext,\n} from '@wix/patterns';\nimport { useForm } from '@wix/patterns/form';\nimport { Card, Cell, Layout } from '@wix/design-system';\nimport { useParams } from 'react-router-dom';\nimport { useSchema } from '../../providers/SchemaContext';\nimport { BaseInputRef } from './Fields/types';\nimport { FormFieldInput } from './Fields/FormFieldInput';\nimport { useNavigation } from '../../hooks';\nimport { usePatternsWizardOverridesContext } from '../../providers';\n\nconst RenderLayoutContent: React.FC<{\n content: LayoutContent;\n level: number;\n sectionId: string;\n cardIndex: number;\n contentIndex: number;\n setInputRef: (id: string, input: BaseInputRef) => void;\n}> = ({ content, level, sectionId, cardIndex, contentIndex, setInputRef }) => {\n const schema = useSchema();\n const overrides = usePatternsWizardOverridesContext();\n const pageState = useEntityPageContext();\n\n switch (content.type) {\n case 'field':\n if (!content.field.fieldId) {\n return null;\n }\n\n const field = schema.fields[content.field.fieldId];\n\n if (!field) {\n return null;\n }\n\n return (\n <Cell span={content.field.span}>\n <FormFieldInput\n key={content.field.fieldId}\n field={field}\n inputRef={(ref) => setInputRef(content.field.fieldId, ref)}\n />\n </Cell>\n );\n\n case 'container':\n if (!content.container.children?.length) {\n return null;\n }\n\n return (\n <Cell span={content.container.span}>\n <Layout>\n {content.container.children.map((child, index) => (\n <RenderLayoutContent\n key={`${sectionId}-card-${cardIndex}-content-${contentIndex}-level-${level}-child-${index}`}\n content={child}\n level={level + 1}\n sectionId={sectionId}\n cardIndex={cardIndex}\n contentIndex={index}\n setInputRef={setInputRef}\n />\n ))}\n </Layout>\n </Cell>\n );\n\n case 'component':\n if (!content.component.componentId) {\n return null;\n }\n\n const Component = overrides?.components?.[content.component.componentId];\n\n if (!Component) {\n return null;\n }\n\n return (\n <Cell span={content.component.span}>\n <Component\n form={pageState.form as any}\n entity={pageState.entity as any as Record<string, any>}\n />\n </Cell>\n );\n\n default:\n return null;\n }\n};\n\nconst RenderLayoutCard: React.FC<{\n layout: CardLayout;\n sectionId: string;\n cardIndex: number;\n setInputRef: (id: string, input: BaseInputRef) => void;\n}> = ({ layout, sectionId, cardIndex, setInputRef }) => {\n switch (layout.type) {\n case 'card':\n return (\n <EntityPage.Card minHeight=\"50px\">\n <Card.Header\n title={layout.card.title.text}\n subtitle={layout.card.subtitle?.text}\n />\n <Card.Divider />\n <Card.Content>\n <Layout>\n {layout.card.children.map((child, index: number) => (\n <RenderLayoutContent\n key={`${sectionId}-card-${cardIndex}-content-${index}`}\n content={child}\n level={0}\n sectionId={sectionId}\n cardIndex={cardIndex}\n contentIndex={index}\n setInputRef={setInputRef}\n />\n ))}\n </Layout>\n </Card.Content>\n </EntityPage.Card>\n );\n default:\n return null;\n }\n};\n\nexport interface AutoPatternsEntityPageProps {\n configuration: EntityPageConfig;\n}\n\nexport const AutoPatternsEntityPage: React.FC<AutoPatternsEntityPageProps> = ({\n configuration,\n}) => {\n const {\n title,\n subtitle,\n layout: pageLayout,\n parentPageId,\n route,\n } = configuration;\n\n const form = useForm<any>();\n const params = useParams();\n const entityId = params[route.params.id];\n const schema = useSchema();\n\n const inputRefs = useRef<{ [fieldId: string]: BaseInputRef }>({});\n\n const setInputRef = (id: string, input: BaseInputRef) => {\n inputRefs.current[id] = input;\n };\n\n const validate = () => {\n const invalidFieldId = Object.keys(inputRefs.current).find((fieldId) => {\n return inputRefs.current[fieldId]?.invalid;\n });\n\n if (invalidFieldId) {\n inputRefs.current[invalidFieldId]?.focus?.();\n throw new Error('Invalid form');\n }\n };\n const { getParentPagePath } = useNavigation();\n\n const parentPath = useMemo(\n () => getParentPagePath(parentPageId),\n [parentPageId, getParentPagePath],\n );\n\n const state: EntityPageState<any> = useEntityPage<any, any>({\n parentPath,\n form,\n onSave: async () => {\n validate();\n\n const formValues = form.getValues();\n const baseEntity = state.entity || {};\n const updatedEntity = {\n ...baseEntity,\n ...formValues,\n };\n\n const newEntity = entityId\n ? await schema.actions.update(updatedEntity)\n : await schema.actions.create(updatedEntity);\n\n return { updatedEntity: newEntity };\n },\n fetch: async () => {\n if (!entityId) {\n return { entity: undefined };\n }\n const entity = await schema.actions.get(entityId);\n return { entity };\n },\n });\n\n const entity = useEntity(state);\n\n return (\n <EntityPage state={state} dataHook=\"auto-patterns-entity-page\">\n <EntityPage.Header\n title={\n title ?? { text: entity?.[schema.displayField] ?? 'Edit Entity' }\n }\n subtitle={subtitle}\n />\n <EntityPage.Content>\n <EntityPage.MainContent>\n {pageLayout?.main?.map((layout, layoutIndex) => (\n <RenderLayoutCard\n key={`main-section-card-${layoutIndex}`}\n layout={layout}\n sectionId=\"main\"\n cardIndex={layoutIndex}\n setInputRef={setInputRef}\n />\n ))}\n </EntityPage.MainContent>\n {pageLayout?.sidebar ? (\n <EntityPage.AdditionalContent>\n {pageLayout.sidebar?.map((layout, layoutIndex) => (\n <RenderLayoutCard\n key={`sidebar-section-card-${layoutIndex}`}\n layout={layout}\n sectionId=\"sidebar\"\n cardIndex={layoutIndex}\n setInputRef={setInputRef}\n />\n ))}\n </EntityPage.AdditionalContent>\n ) : null}\n </EntityPage.Content>\n </EntityPage>\n );\n};\n\n/*\n Key structure explanation:\n\n Main cards: main-section-card-{layoutIndex}\n Sidebar cards: sidebar-section-card-{layoutIndex}\n\n Layout content:\n {sectionId}-card-{cardIndex}-content-{contentIndex}\n\n Nested children:\n {sectionId}-card-{cardIndex}-content-{parentContentIndex}-level-{level}-child-{childIndex}\n\n This ensures uniqueness across all levels and sections.\n*/\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,18 +1,38 @@
|
|
|
1
1
|
import React, { useRef, useState } from 'react';
|
|
2
2
|
import { FormField, DatePicker } from '@wix/design-system';
|
|
3
3
|
import { getDateWithoutTimezone, getISODateStringWithFixedTimezone } from './utils/dates';
|
|
4
|
+
import { useSelector, useWixPatternsContainer } from '@wix/patterns';
|
|
4
5
|
export const DateInput = props => {
|
|
6
|
+
var _field$validation;
|
|
5
7
|
const {
|
|
6
8
|
field,
|
|
7
9
|
value,
|
|
8
|
-
onChange
|
|
10
|
+
onChange,
|
|
11
|
+
dataHook,
|
|
12
|
+
inputRef
|
|
9
13
|
} = props;
|
|
14
|
+
const {
|
|
15
|
+
translate: t,
|
|
16
|
+
...container
|
|
17
|
+
} = useWixPatternsContainer();
|
|
18
|
+
useSelector(() => container.initTask.status);
|
|
10
19
|
const [date, setDate] = useState(() => value ? getDateWithoutTimezone(getISODateStringWithFixedTimezone(value)) : undefined);
|
|
11
20
|
const ref = useRef({});
|
|
12
21
|
const [statusMessage, setStatusMessage] = useState('');
|
|
13
22
|
return /*#__PURE__*/React.createElement(FormField, {
|
|
14
|
-
label: field.displayName
|
|
23
|
+
label: field.displayName,
|
|
24
|
+
required: (_field$validation = field.validation) == null ? void 0 : _field$validation.required,
|
|
25
|
+
dataHook: dataHook
|
|
15
26
|
}, /*#__PURE__*/React.createElement(DatePicker, {
|
|
27
|
+
ref: internalRef => {
|
|
28
|
+
inputRef == null || inputRef(ref.current);
|
|
29
|
+
// TODO: PR to WSR needed to expose as public API
|
|
30
|
+
// @ts-expect-error
|
|
31
|
+
ref.current.focus = () => {
|
|
32
|
+
var _internalRef$state;
|
|
33
|
+
return internalRef == null || (_internalRef$state = internalRef.state) == null || (_internalRef$state = _internalRef$state.inputRef) == null || _internalRef$state.focus == null ? void 0 : _internalRef$state.focus();
|
|
34
|
+
};
|
|
35
|
+
},
|
|
16
36
|
dataHook: `date-${field.id}`,
|
|
17
37
|
width: "100%",
|
|
18
38
|
value: date,
|
|
@@ -24,7 +44,8 @@ export const DateInput = props => {
|
|
|
24
44
|
onValidate: _ref => {
|
|
25
45
|
let {
|
|
26
46
|
validationType,
|
|
27
|
-
value: newValue
|
|
47
|
+
value: newValue,
|
|
48
|
+
format
|
|
28
49
|
} = _ref;
|
|
29
50
|
if (validationType === 'valid') {
|
|
30
51
|
setStatusMessage('');
|
|
@@ -35,7 +56,9 @@ export const DateInput = props => {
|
|
|
35
56
|
setStatusMessage('');
|
|
36
57
|
ref.current.invalid = false;
|
|
37
58
|
} else {
|
|
38
|
-
setStatusMessage('
|
|
59
|
+
setStatusMessage(t('cairo.customFields.fieldType.date.invalid.value', {
|
|
60
|
+
dateFormat: format ?? ''
|
|
61
|
+
}));
|
|
39
62
|
ref.current.invalid = true;
|
|
40
63
|
}
|
|
41
64
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","useRef","useState","FormField","DatePicker","getDateWithoutTimezone","getISODateStringWithFixedTimezone","DateInput","props","field","value","onChange","date","setDate","undefined","ref","statusMessage","setStatusMessage","createElement","label","displayName","
|
|
1
|
+
{"version":3,"names":["React","useRef","useState","FormField","DatePicker","getDateWithoutTimezone","getISODateStringWithFixedTimezone","useSelector","useWixPatternsContainer","DateInput","props","_field$validation","field","value","onChange","dataHook","inputRef","translate","t","container","initTask","status","date","setDate","undefined","ref","statusMessage","setStatusMessage","createElement","label","displayName","required","validation","internalRef","current","focus","_internalRef$state","state","id","width","newValue","formattedDate","split","onValidate","_ref","validationType","format","invalid","dateFormat"],"sources":["../../../../../src/components/AutoPatternsEntityPage/Fields/DateInput.tsx"],"sourcesContent":["import React, { useRef, useState } from 'react';\nimport { FormField, DatePicker } from '@wix/design-system';\nimport {\n getDateWithoutTimezone,\n getISODateStringWithFixedTimezone,\n} from './utils/dates';\nimport { BaseInputProps, BaseInputRef } from './types';\nimport { useSelector, useWixPatternsContainer } from '@wix/patterns';\n\nexport interface DateProps extends BaseInputProps<string | null> {}\n\nexport const DateInput = (props: DateProps) => {\n const { field, value, onChange, dataHook, inputRef } = props;\n const { translate: t, ...container } = useWixPatternsContainer();\n useSelector(() => container.initTask.status);\n\n const [date, setDate] = useState<Date | undefined>(() =>\n value\n ? getDateWithoutTimezone(getISODateStringWithFixedTimezone(value))\n : undefined,\n );\n\n const ref = useRef<BaseInputRef>({});\n const [statusMessage, setStatusMessage] = useState('');\n\n return (\n <FormField\n label={field.displayName}\n required={field.validation?.required}\n dataHook={dataHook}\n >\n <DatePicker\n ref={(internalRef) => {\n inputRef?.(ref.current);\n // TODO: PR to WSR needed to expose as public API\n // @ts-expect-error\n ref.current.focus = () => internalRef?.state?.inputRef?.focus?.();\n }}\n dataHook={`date-${field.id}`}\n width=\"100%\"\n value={date}\n onChange={(newValue: Date) => {\n const formattedDate = getISODateStringWithFixedTimezone(newValue);\n setDate(newValue);\n onChange(formattedDate.split('T')[0]);\n }}\n onValidate={({ validationType, value: newValue, format }) => {\n if (validationType === 'valid') {\n setStatusMessage('');\n ref.current.invalid = false;\n } else if (validationType === 'formatError' && newValue === '') {\n setDate(undefined);\n onChange(null);\n setStatusMessage('');\n ref.current.invalid = false;\n } else {\n setStatusMessage(\n t('cairo.customFields.fieldType.date.invalid.value', {\n dateFormat: format ?? '',\n }),\n );\n ref.current.invalid = true;\n }\n }}\n status={ref.current.invalid ? 'error' : undefined}\n statusMessage={statusMessage}\n />\n </FormField>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|