@strato-admin/faker-ecommerce 0.1.0 → 0.3.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/dataProvider.js +1 -2
- package/dist/generate.d.ts +2 -1
- package/dist/generate.js +15 -8
- package/dist/ra-core/src/auth/LogoutOnMount.d.ts +8 -0
- package/dist/ra-core/src/auth/LogoutOnMount.js +16 -0
- package/dist/ra-core/src/auth/addRefreshAuthToAuthProvider.d.ts +22 -0
- package/dist/ra-core/src/auth/addRefreshAuthToAuthProvider.js +41 -0
- package/dist/ra-core/src/auth/addRefreshAuthToDataProvider.d.ts +21 -0
- package/dist/ra-core/src/auth/addRefreshAuthToDataProvider.js +30 -0
- package/dist/ra-core/src/auth/convertLegacyAuthProvider.d.ts +12 -0
- package/dist/ra-core/src/auth/convertLegacyAuthProvider.js +19 -0
- package/dist/ra-core/src/auth/index.d.ts +27 -0
- package/dist/ra-core/src/auth/index.js +34 -0
- package/dist/ra-core/src/auth/types.d.ts +7 -0
- package/dist/ra-core/src/auth/types.js +5 -0
- package/dist/ra-core/src/auth/useAuthProvider.d.ts +10 -0
- package/dist/ra-core/src/auth/useAuthProvider.js +11 -0
- package/dist/ra-core/src/auth/useAuthState.d.ts +48 -0
- package/dist/ra-core/src/auth/useAuthState.js +171 -0
- package/dist/ra-core/src/auth/useAuthenticated.d.ts +36 -0
- package/dist/ra-core/src/auth/useAuthenticated.js +34 -0
- package/dist/ra-core/src/auth/useCanAccess.d.ts +56 -0
- package/dist/ra-core/src/auth/useCanAccess.js +108 -0
- package/dist/ra-core/src/auth/useCanAccessCallback.d.ts +39 -0
- package/dist/ra-core/src/auth/useCanAccessCallback.js +45 -0
- package/dist/ra-core/src/auth/useCanAccessResources.d.ts +67 -0
- package/dist/ra-core/src/auth/useCanAccessResources.js +92 -0
- package/dist/ra-core/src/auth/useCheckAuth.d.ts +48 -0
- package/dist/ra-core/src/auth/useCheckAuth.js +76 -0
- package/dist/ra-core/src/auth/useGetIdentity.d.ts +41 -0
- package/dist/ra-core/src/auth/useGetIdentity.js +86 -0
- package/dist/ra-core/src/auth/useGetPermissions.d.ts +41 -0
- package/dist/ra-core/src/auth/useGetPermissions.js +47 -0
- package/dist/ra-core/src/auth/useHandleAuthCallback.d.ts +20 -0
- package/dist/ra-core/src/auth/useHandleAuthCallback.js +83 -0
- package/dist/ra-core/src/auth/useIsAuthPending.d.ts +13 -0
- package/dist/ra-core/src/auth/useIsAuthPending.js +30 -0
- package/dist/ra-core/src/auth/useLogin.d.ts +34 -0
- package/dist/ra-core/src/auth/useLogin.js +78 -0
- package/dist/ra-core/src/auth/useLogout.d.ts +31 -0
- package/dist/ra-core/src/auth/useLogout.js +117 -0
- package/dist/ra-core/src/auth/useLogoutIfAccessDenied.d.ts +42 -0
- package/dist/ra-core/src/auth/useLogoutIfAccessDenied.js +111 -0
- package/dist/ra-core/src/auth/usePermissions.d.ts +41 -0
- package/dist/ra-core/src/auth/usePermissions.js +123 -0
- package/dist/ra-core/src/controller/button/index.d.ts +7 -0
- package/dist/ra-core/src/controller/button/index.js +7 -0
- package/dist/ra-core/src/controller/button/useBulkDeleteController.d.ts +14 -0
- package/dist/ra-core/src/controller/button/useBulkDeleteController.js +66 -0
- package/dist/ra-core/src/controller/create/index.d.ts +6 -0
- package/dist/ra-core/src/controller/create/index.js +6 -0
- package/dist/ra-core/src/controller/create/useCreateController.d.ts +50 -0
- package/dist/ra-core/src/controller/create/useCreateController.js +149 -0
- package/dist/ra-core/src/controller/edit/index.d.ts +6 -0
- package/dist/ra-core/src/controller/edit/index.js +6 -0
- package/dist/ra-core/src/controller/edit/useEditController.d.ts +72 -0
- package/dist/ra-core/src/controller/edit/useEditController.js +206 -0
- package/dist/ra-core/src/controller/field/index.d.ts +12 -0
- package/dist/ra-core/src/controller/field/index.js +12 -0
- package/dist/ra-core/src/controller/field/sanitizeFieldRestProps.d.ts +1 -0
- package/dist/ra-core/src/controller/field/sanitizeFieldRestProps.js +1 -0
- package/dist/ra-core/src/controller/field/types.d.ts +28 -0
- package/dist/ra-core/src/controller/field/types.js +1 -0
- package/dist/ra-core/src/controller/field/useReferenceArrayFieldController.d.ts +39 -0
- package/dist/ra-core/src/controller/field/useReferenceArrayFieldController.js +82 -0
- package/dist/ra-core/src/controller/field/useReferenceFieldController.d.ts +14 -0
- package/dist/ra-core/src/controller/field/useReferenceFieldController.js +31 -0
- package/dist/ra-core/src/controller/field/useReferenceManyFieldController.d.ts +49 -0
- package/dist/ra-core/src/controller/field/useReferenceManyFieldController.js +264 -0
- package/dist/ra-core/src/controller/index.d.ts +17 -0
- package/dist/ra-core/src/controller/index.js +16 -0
- package/dist/ra-core/src/controller/input/ArrayInputContext.d.ts +9 -0
- package/dist/ra-core/src/controller/input/ArrayInputContext.js +8 -0
- package/dist/ra-core/src/controller/input/SimpleFormIteratorContext.d.ts +15 -0
- package/dist/ra-core/src/controller/input/SimpleFormIteratorContext.js +8 -0
- package/dist/ra-core/src/controller/input/SimpleFormIteratorItemContext.d.ts +13 -0
- package/dist/ra-core/src/controller/input/SimpleFormIteratorItemContext.js +8 -0
- package/dist/ra-core/src/controller/input/index.d.ts +17 -0
- package/dist/ra-core/src/controller/input/index.js +17 -0
- package/dist/ra-core/src/controller/input/referenceDataStatus.d.ts +32 -0
- package/dist/ra-core/src/controller/input/referenceDataStatus.js +74 -0
- package/dist/ra-core/src/controller/input/sanitizeInputRestProps.d.ts +1 -0
- package/dist/ra-core/src/controller/input/sanitizeInputRestProps.js +1 -0
- package/dist/ra-core/src/controller/input/types.d.ts +3 -0
- package/dist/ra-core/src/controller/input/types.js +1 -0
- package/dist/ra-core/src/controller/input/useArrayInput.d.ts +8 -0
- package/dist/ra-core/src/controller/input/useArrayInput.js +29 -0
- package/dist/ra-core/src/controller/input/useGetArrayInputNewItemDefaults.d.ts +3 -0
- package/dist/ra-core/src/controller/input/useGetArrayInputNewItemDefaults.js +37 -0
- package/dist/ra-core/src/controller/input/useReferenceArrayInputController.d.ts +48 -0
- package/dist/ra-core/src/controller/input/useReferenceArrayInputController.js +137 -0
- package/dist/ra-core/src/controller/input/useReferenceInputController.d.ts +54 -0
- package/dist/ra-core/src/controller/input/useReferenceInputController.js +208 -0
- package/dist/ra-core/src/controller/input/useReferenceParams.d.ts +106 -0
- package/dist/ra-core/src/controller/input/useReferenceParams.js +226 -0
- package/dist/ra-core/src/controller/input/useSimpleFormIterator.d.ts +7 -0
- package/dist/ra-core/src/controller/input/useSimpleFormIterator.js +15 -0
- package/dist/ra-core/src/controller/input/useSimpleFormIteratorItem.d.ts +7 -0
- package/dist/ra-core/src/controller/input/useSimpleFormIteratorItem.js +15 -0
- package/dist/ra-core/src/controller/list/InfinitePaginationContext.d.ts +25 -0
- package/dist/ra-core/src/controller/list/InfinitePaginationContext.js +32 -0
- package/dist/ra-core/src/controller/list/index.d.ts +30 -0
- package/dist/ra-core/src/controller/list/index.js +30 -0
- package/dist/ra-core/src/controller/list/queryReducer.d.ts +45 -0
- package/dist/ra-core/src/controller/list/queryReducer.js +85 -0
- package/dist/ra-core/src/controller/list/useFilterContext.d.ts +2 -0
- package/dist/ra-core/src/controller/list/useFilterContext.js +5 -0
- package/dist/ra-core/src/controller/list/useInfiniteListController.d.ts +44 -0
- package/dist/ra-core/src/controller/list/useInfiniteListController.js +175 -0
- package/dist/ra-core/src/controller/list/useInfinitePaginationContext.d.ts +16 -0
- package/dist/ra-core/src/controller/list/useInfinitePaginationContext.js +17 -0
- package/dist/ra-core/src/controller/list/useList.d.ts +55 -0
- package/dist/ra-core/src/controller/list/useList.js +223 -0
- package/dist/ra-core/src/controller/list/useListContext.d.ts +59 -0
- package/dist/ra-core/src/controller/list/useListContext.js +65 -0
- package/dist/ra-core/src/controller/list/useListContextWithProps.d.ts +44 -0
- package/dist/ra-core/src/controller/list/useListContextWithProps.js +84 -0
- package/dist/ra-core/src/controller/list/useListController.d.ts +296 -0
- package/dist/ra-core/src/controller/list/useListController.js +234 -0
- package/dist/ra-core/src/controller/list/useListFilterContext.d.ts +11 -0
- package/dist/ra-core/src/controller/list/useListFilterContext.js +18 -0
- package/dist/ra-core/src/controller/list/useListPaginationContext.d.ts +12 -0
- package/dist/ra-core/src/controller/list/useListPaginationContext.js +19 -0
- package/dist/ra-core/src/controller/list/useListParams.d.ts +116 -0
- package/dist/ra-core/src/controller/list/useListParams.js +281 -0
- package/dist/ra-core/src/controller/list/useListSortContext.d.ts +12 -0
- package/dist/ra-core/src/controller/list/useListSortContext.js +19 -0
- package/dist/ra-core/src/controller/list/useRecordSelection.d.ts +32 -0
- package/dist/ra-core/src/controller/list/useRecordSelection.js +93 -0
- package/dist/ra-core/src/controller/list/useSavedQueries.d.ts +14 -0
- package/dist/ra-core/src/controller/list/useSavedQueries.js +29 -0
- package/dist/ra-core/src/controller/list/useUnselect.d.ts +10 -0
- package/dist/ra-core/src/controller/list/useUnselect.js +18 -0
- package/dist/ra-core/src/controller/list/useUnselectAll.d.ts +9 -0
- package/dist/ra-core/src/controller/list/useUnselectAll.js +18 -0
- package/dist/ra-core/src/controller/record/index.d.ts +5 -0
- package/dist/ra-core/src/controller/record/index.js +5 -0
- package/dist/ra-core/src/controller/record/useRecordContext.d.ts +34 -0
- package/dist/ra-core/src/controller/record/useRecordContext.js +36 -0
- package/dist/ra-core/src/controller/saveContext/SaveContext.d.ts +20 -0
- package/dist/ra-core/src/controller/saveContext/SaveContext.js +2 -0
- package/dist/ra-core/src/controller/saveContext/index.d.ts +6 -0
- package/dist/ra-core/src/controller/saveContext/index.js +6 -0
- package/dist/ra-core/src/controller/saveContext/useMutationMiddlewares.d.ts +39 -0
- package/dist/ra-core/src/controller/saveContext/useMutationMiddlewares.js +79 -0
- package/dist/ra-core/src/controller/saveContext/usePickSaveContext.d.ts +5 -0
- package/dist/ra-core/src/controller/saveContext/usePickSaveContext.js +25 -0
- package/dist/ra-core/src/controller/saveContext/useRegisterMutationMiddleware.d.ts +6 -0
- package/dist/ra-core/src/controller/saveContext/useRegisterMutationMiddleware.js +18 -0
- package/dist/ra-core/src/controller/saveContext/useSaveContext.d.ts +14 -0
- package/dist/ra-core/src/controller/saveContext/useSaveContext.js +17 -0
- package/dist/ra-core/src/controller/show/index.d.ts +6 -0
- package/dist/ra-core/src/controller/show/index.js +6 -0
- package/dist/ra-core/src/controller/show/useShowController.d.ts +75 -0
- package/dist/ra-core/src/controller/show/useShowController.js +110 -0
- package/dist/ra-core/src/controller/useFilterState.d.ts +46 -0
- package/dist/ra-core/src/controller/useFilterState.js +70 -0
- package/dist/ra-core/src/controller/usePaginationState.d.ts +33 -0
- package/dist/ra-core/src/controller/usePaginationState.js +45 -0
- package/dist/ra-core/src/controller/usePrevNextController.d.ts +127 -0
- package/dist/ra-core/src/controller/usePrevNextController.js +215 -0
- package/dist/ra-core/src/controller/useReference.d.ts +49 -0
- package/dist/ra-core/src/controller/useReference.js +42 -0
- package/dist/ra-core/src/controller/useSortState.d.ts +61 -0
- package/dist/ra-core/src/controller/useSortState.js +96 -0
- package/dist/ra-core/src/core/DefaultTitleContext.d.ts +15 -0
- package/dist/ra-core/src/core/DefaultTitleContext.js +15 -0
- package/dist/ra-core/src/core/HasDashboardContext.d.ts +21 -0
- package/dist/ra-core/src/core/HasDashboardContext.js +22 -0
- package/dist/ra-core/src/core/ResourceContext.d.ts +19 -0
- package/dist/ra-core/src/core/ResourceContext.js +19 -0
- package/dist/ra-core/src/core/UserMenuContext.d.ts +34 -0
- package/dist/ra-core/src/core/UserMenuContext.js +28 -0
- package/dist/ra-core/src/core/index.d.ts +27 -0
- package/dist/ra-core/src/core/index.js +27 -0
- package/dist/ra-core/src/core/useGetRecordRepresentation.d.ts +13 -0
- package/dist/ra-core/src/core/useGetRecordRepresentation.js +44 -0
- package/dist/ra-core/src/core/useGetResourceLabel.d.ts +22 -0
- package/dist/ra-core/src/core/useGetResourceLabel.js +42 -0
- package/dist/ra-core/src/core/useIsOffline.d.ts +7 -0
- package/dist/ra-core/src/core/useIsOffline.js +18 -0
- package/dist/ra-core/src/core/useResourceContext.d.ts +36 -0
- package/dist/ra-core/src/core/useResourceContext.js +38 -0
- package/dist/ra-core/src/core/useResourceDefinition.d.ts +31 -0
- package/dist/ra-core/src/core/useResourceDefinition.js +48 -0
- package/dist/ra-core/src/core/useResourceDefinitionContext.d.ts +1 -0
- package/dist/ra-core/src/core/useResourceDefinitionContext.js +3 -0
- package/dist/ra-core/src/core/useResourceDefinitions.d.ts +21 -0
- package/dist/ra-core/src/core/useResourceDefinitions.js +20 -0
- package/dist/ra-core/src/core/useUserMenu.d.ts +28 -0
- package/dist/ra-core/src/core/useUserMenu.js +30 -0
- package/dist/ra-core/src/core/useWrappedSource.d.ts +11 -0
- package/dist/ra-core/src/core/useWrappedSource.js +15 -0
- package/dist/ra-core/src/dataProvider/DataProviderContext.d.ts +3 -0
- package/dist/ra-core/src/dataProvider/DataProviderContext.js +4 -0
- package/dist/ra-core/src/dataProvider/HttpError.d.ts +6 -0
- package/dist/ra-core/src/dataProvider/HttpError.js +19 -0
- package/dist/ra-core/src/dataProvider/combineDataProviders.d.ts +21 -0
- package/dist/ra-core/src/dataProvider/combineDataProviders.js +32 -0
- package/dist/ra-core/src/dataProvider/convertLegacyDataProvider.d.ts +12 -0
- package/dist/ra-core/src/dataProvider/convertLegacyDataProvider.js +40 -0
- package/dist/ra-core/src/dataProvider/dataFetchActions.d.ts +15 -0
- package/dist/ra-core/src/dataProvider/dataFetchActions.js +49 -0
- package/dist/ra-core/src/dataProvider/defaultDataProvider.d.ts +2 -0
- package/dist/ra-core/src/dataProvider/defaultDataProvider.js +12 -0
- package/dist/ra-core/src/dataProvider/fetch.d.ts +32 -0
- package/dist/ra-core/src/dataProvider/fetch.js +78 -0
- package/dist/ra-core/src/dataProvider/index.d.ts +34 -0
- package/dist/ra-core/src/dataProvider/index.js +33 -0
- package/dist/ra-core/src/dataProvider/populateQueryCache.d.ts +22 -0
- package/dist/ra-core/src/dataProvider/populateQueryCache.js +30 -0
- package/dist/ra-core/src/dataProvider/testDataProvider.d.ts +2 -0
- package/dist/ra-core/src/dataProvider/testDataProvider.js +41 -0
- package/dist/ra-core/src/dataProvider/undo/index.d.ts +6 -0
- package/dist/ra-core/src/dataProvider/undo/index.js +6 -0
- package/dist/ra-core/src/dataProvider/undo/types.d.ts +3 -0
- package/dist/ra-core/src/dataProvider/undo/types.js +1 -0
- package/dist/ra-core/src/dataProvider/undoableEventEmitter.d.ts +3 -0
- package/dist/ra-core/src/dataProvider/undoableEventEmitter.js +2 -0
- package/dist/ra-core/src/dataProvider/useCreate.d.ts +89 -0
- package/dist/ra-core/src/dataProvider/useCreate.js +155 -0
- package/dist/ra-core/src/dataProvider/useDataProvider.d.ts +2 -0
- package/dist/ra-core/src/dataProvider/useDataProvider.js +140 -0
- package/dist/ra-core/src/dataProvider/useDelete.d.ts +83 -0
- package/dist/ra-core/src/dataProvider/useDelete.js +171 -0
- package/dist/ra-core/src/dataProvider/useDeleteMany.d.ts +81 -0
- package/dist/ra-core/src/dataProvider/useDeleteMany.js +193 -0
- package/dist/ra-core/src/dataProvider/useGetList.d.ts +58 -0
- package/dist/ra-core/src/dataProvider/useGetList.js +131 -0
- package/dist/ra-core/src/dataProvider/useGetMany.d.ts +49 -0
- package/dist/ra-core/src/dataProvider/useGetMany.js +143 -0
- package/dist/ra-core/src/dataProvider/useGetManyAggregate.d.ts +62 -0
- package/dist/ra-core/src/dataProvider/useGetManyAggregate.js +295 -0
- package/dist/ra-core/src/dataProvider/useGetManyReference.d.ts +62 -0
- package/dist/ra-core/src/dataProvider/useGetManyReference.js +117 -0
- package/dist/ra-core/src/dataProvider/useGetOne.d.ts +48 -0
- package/dist/ra-core/src/dataProvider/useGetOne.js +94 -0
- package/dist/ra-core/src/dataProvider/useGetRecordId.d.ts +14 -0
- package/dist/ra-core/src/dataProvider/useGetRecordId.js +22 -0
- package/dist/ra-core/src/dataProvider/useInfiniteGetList.d.ts +64 -0
- package/dist/ra-core/src/dataProvider/useInfiniteGetList.js +177 -0
- package/dist/ra-core/src/dataProvider/useIsDataLoaded.d.ts +13 -0
- package/dist/ra-core/src/dataProvider/useIsDataLoaded.js +35 -0
- package/dist/ra-core/src/dataProvider/useLoading.d.ts +12 -0
- package/dist/ra-core/src/dataProvider/useLoading.js +41 -0
- package/dist/ra-core/src/dataProvider/useMutationWithMutationMode.d.ts +51 -0
- package/dist/ra-core/src/dataProvider/useMutationWithMutationMode.js +238 -0
- package/dist/ra-core/src/dataProvider/useRefresh.d.ts +14 -0
- package/dist/ra-core/src/dataProvider/useRefresh.js +21 -0
- package/dist/ra-core/src/dataProvider/useUpdate.d.ts +89 -0
- package/dist/ra-core/src/dataProvider/useUpdate.js +183 -0
- package/dist/ra-core/src/dataProvider/useUpdateMany.d.ts +81 -0
- package/dist/ra-core/src/dataProvider/useUpdateMany.js +171 -0
- package/dist/ra-core/src/dataProvider/validateResponseFormat.d.ts +5 -0
- package/dist/ra-core/src/dataProvider/validateResponseFormat.js +35 -0
- package/dist/ra-core/src/dataProvider/withLifecycleCallbacks.d.ts +162 -0
- package/dist/ra-core/src/dataProvider/withLifecycleCallbacks.js +377 -0
- package/dist/ra-core/src/dataTable/DataTableCallbacksContext.d.ts +18 -0
- package/dist/ra-core/src/dataTable/DataTableCallbacksContext.js +3 -0
- package/dist/ra-core/src/dataTable/DataTableColumnFilterContext.d.ts +2 -0
- package/dist/ra-core/src/dataTable/DataTableColumnFilterContext.js +3 -0
- package/dist/ra-core/src/dataTable/DataTableColumnRankContext.d.ts +2 -0
- package/dist/ra-core/src/dataTable/DataTableColumnRankContext.js +3 -0
- package/dist/ra-core/src/dataTable/DataTableConfigContext.d.ts +22 -0
- package/dist/ra-core/src/dataTable/DataTableConfigContext.js +7 -0
- package/dist/ra-core/src/dataTable/DataTableDataContext.d.ts +4 -0
- package/dist/ra-core/src/dataTable/DataTableDataContext.js +3 -0
- package/dist/ra-core/src/dataTable/DataTableRenderContext.d.ts +3 -0
- package/dist/ra-core/src/dataTable/DataTableRenderContext.js +3 -0
- package/dist/ra-core/src/dataTable/DataTableSelectedIdsContext.d.ts +3 -0
- package/dist/ra-core/src/dataTable/DataTableSelectedIdsContext.js +3 -0
- package/dist/ra-core/src/dataTable/DataTableSortContext.d.ts +3 -0
- package/dist/ra-core/src/dataTable/DataTableSortContext.js +3 -0
- package/dist/ra-core/src/dataTable/DataTableStoreContext.d.ts +8 -0
- package/dist/ra-core/src/dataTable/DataTableStoreContext.js +6 -0
- package/dist/ra-core/src/dataTable/index.d.ts +11 -0
- package/dist/ra-core/src/dataTable/index.js +11 -0
- package/dist/ra-core/src/dataTable/types.d.ts +2 -0
- package/dist/ra-core/src/dataTable/types.js +1 -0
- package/dist/ra-core/src/export/ExporterContext.d.ts +2 -0
- package/dist/ra-core/src/export/ExporterContext.js +4 -0
- package/dist/ra-core/src/export/defaultExporter.d.ts +2 -0
- package/dist/ra-core/src/export/defaultExporter.js +3 -0
- package/dist/ra-core/src/export/downloadCSV.d.ts +1 -0
- package/dist/ra-core/src/export/downloadCSV.js +17 -0
- package/dist/ra-core/src/export/fetchRelatedRecords.d.ts +14 -0
- package/dist/ra-core/src/export/fetchRelatedRecords.js +19 -0
- package/dist/ra-core/src/export/getRelatedIds.d.ts +24 -0
- package/dist/ra-core/src/export/getRelatedIds.js +26 -0
- package/dist/ra-core/src/export/index.d.ts +5 -0
- package/dist/ra-core/src/export/index.js +5 -0
- package/dist/ra-core/src/export/useBulkExport.d.ts +11 -0
- package/dist/ra-core/src/export/useBulkExport.js +30 -0
- package/dist/ra-core/src/form/WarnWhenUnsavedChanges.d.ts +5 -0
- package/dist/ra-core/src/form/WarnWhenUnsavedChanges.js +5 -0
- package/dist/ra-core/src/form/choices/ChoicesContext.d.ts +65 -0
- package/dist/ra-core/src/form/choices/ChoicesContext.js +7 -0
- package/dist/ra-core/src/form/choices/index.d.ts +4 -0
- package/dist/ra-core/src/form/choices/index.js +4 -0
- package/dist/ra-core/src/form/choices/useChoicesContext.d.ts +5 -0
- package/dist/ra-core/src/form/choices/useChoicesContext.js +62 -0
- package/dist/ra-core/src/form/getFormInitialValues.d.ts +8 -0
- package/dist/ra-core/src/form/getFormInitialValues.js +14 -0
- package/dist/ra-core/src/form/groups/FormGroupContext.d.ts +9 -0
- package/dist/ra-core/src/form/groups/FormGroupContext.js +9 -0
- package/dist/ra-core/src/form/groups/index.d.ts +6 -0
- package/dist/ra-core/src/form/groups/index.js +6 -0
- package/dist/ra-core/src/form/groups/useFormGroup.d.ts +67 -0
- package/dist/ra-core/src/form/groups/useFormGroup.js +146 -0
- package/dist/ra-core/src/form/groups/useFormGroupContext.d.ts +4 -0
- package/dist/ra-core/src/form/groups/useFormGroupContext.js +9 -0
- package/dist/ra-core/src/form/groups/useFormGroups.d.ts +4 -0
- package/dist/ra-core/src/form/groups/useFormGroups.js +9 -0
- package/dist/ra-core/src/form/index.d.ts +14 -0
- package/dist/ra-core/src/form/index.js +14 -0
- package/dist/ra-core/src/form/sanitizeEmptyValues.d.ts +7 -0
- package/dist/ra-core/src/form/sanitizeEmptyValues.js +26 -0
- package/dist/ra-core/src/form/useApplyInputDefaultValues.d.ts +19 -0
- package/dist/ra-core/src/form/useApplyInputDefaultValues.js +71 -0
- package/dist/ra-core/src/form/useAugmentedForm.d.ts +32 -0
- package/dist/ra-core/src/form/useAugmentedForm.js +101 -0
- package/dist/ra-core/src/form/useFormIsDirty.d.ts +4 -0
- package/dist/ra-core/src/form/useFormIsDirty.js +39 -0
- package/dist/ra-core/src/form/useInput.d.ts +33 -0
- package/dist/ra-core/src/form/useInput.js +100 -0
- package/dist/ra-core/src/form/useRecordFromLocation.d.ts +22 -0
- package/dist/ra-core/src/form/useRecordFromLocation.js +59 -0
- package/dist/ra-core/src/form/useSuggestions.d.ts +43 -0
- package/dist/ra-core/src/form/useSuggestions.js +186 -0
- package/dist/ra-core/src/form/validation/getSimpleValidationResolver.d.ts +31 -0
- package/dist/ra-core/src/form/validation/getSimpleValidationResolver.js +87 -0
- package/dist/ra-core/src/form/validation/index.d.ts +7 -0
- package/dist/ra-core/src/form/validation/index.js +7 -0
- package/dist/ra-core/src/form/validation/setSubmissionErrors.d.ts +21 -0
- package/dist/ra-core/src/form/validation/setSubmissionErrors.js +34 -0
- package/dist/ra-core/src/form/validation/useGetValidationErrorMessage.d.ts +26 -0
- package/dist/ra-core/src/form/validation/useGetValidationErrorMessage.js +35 -0
- package/dist/ra-core/src/form/validation/useNotifyIsFormInvalid.d.ts +9 -0
- package/dist/ra-core/src/form/validation/useNotifyIsFormInvalid.js +30 -0
- package/dist/ra-core/src/form/validation/useUnique.d.ts +57 -0
- package/dist/ra-core/src/form/validation/useUnique.js +107 -0
- package/dist/ra-core/src/form/validation/validate.d.ts +168 -0
- package/dist/ra-core/src/form/validation/validate.js +218 -0
- package/dist/ra-core/src/i18n/I18nContext.d.ts +3 -0
- package/dist/ra-core/src/i18n/I18nContext.js +11 -0
- package/dist/ra-core/src/i18n/TranslatableContext.d.ts +16 -0
- package/dist/ra-core/src/i18n/TranslatableContext.js +2 -0
- package/dist/ra-core/src/i18n/TranslationMessages.d.ts +221 -0
- package/dist/ra-core/src/i18n/TranslationMessages.js +1 -0
- package/dist/ra-core/src/i18n/TranslationUtils.d.ts +60 -0
- package/dist/ra-core/src/i18n/TranslationUtils.js +70 -0
- package/dist/ra-core/src/i18n/index.d.ts +20 -0
- package/dist/ra-core/src/i18n/index.js +20 -0
- package/dist/ra-core/src/i18n/substituteTokens.d.ts +8 -0
- package/dist/ra-core/src/i18n/substituteTokens.js +18 -0
- package/dist/ra-core/src/i18n/useI18nProvider.d.ts +12 -0
- package/dist/ra-core/src/i18n/useI18nProvider.js +14 -0
- package/dist/ra-core/src/i18n/useLocales.d.ts +31 -0
- package/dist/ra-core/src/i18n/useLocales.js +28 -0
- package/dist/ra-core/src/i18n/useResourceTranslation.d.ts +8 -0
- package/dist/ra-core/src/i18n/useResourceTranslation.js +18 -0
- package/dist/ra-core/src/i18n/useTranslatable.d.ts +29 -0
- package/dist/ra-core/src/i18n/useTranslatable.js +98 -0
- package/dist/ra-core/src/i18n/useTranslatableContext.d.ts +31 -0
- package/dist/ra-core/src/i18n/useTranslatableContext.js +38 -0
- package/dist/ra-core/src/i18n/useTranslate.d.ts +21 -0
- package/dist/ra-core/src/i18n/useTranslate.js +29 -0
- package/dist/ra-core/src/i18n/useTranslateLabel.d.ts +6 -0
- package/dist/ra-core/src/i18n/useTranslateLabel.js +26 -0
- package/dist/ra-core/src/index.d.ts +16 -0
- package/dist/ra-core/src/index.js +16 -0
- package/dist/ra-core/src/inference/InferredElement.d.ts +12 -0
- package/dist/ra-core/src/inference/InferredElement.js +40 -0
- package/dist/ra-core/src/inference/assertions.d.ts +26 -0
- package/dist/ra-core/src/inference/assertions.js +38 -0
- package/dist/ra-core/src/inference/getElementsFromRecords.d.ts +35 -0
- package/dist/ra-core/src/inference/getElementsFromRecords.js +39 -0
- package/dist/ra-core/src/inference/getValuesFromRecords.d.ts +28 -0
- package/dist/ra-core/src/inference/getValuesFromRecords.js +40 -0
- package/dist/ra-core/src/inference/index.d.ts +6 -0
- package/dist/ra-core/src/inference/index.js +6 -0
- package/dist/ra-core/src/inference/inferTypeFromValues.d.ts +21 -0
- package/dist/ra-core/src/inference/inferTypeFromValues.js +141 -0
- package/dist/ra-core/src/inference/types.d.ts +9 -0
- package/dist/ra-core/src/inference/types.js +1 -0
- package/dist/ra-core/src/notification/CloseNotificationContext.d.ts +2 -0
- package/dist/ra-core/src/notification/CloseNotificationContext.js +2 -0
- package/dist/ra-core/src/notification/NotificationContext.d.ts +37 -0
- package/dist/ra-core/src/notification/NotificationContext.js +35 -0
- package/dist/ra-core/src/notification/index.d.ts +9 -0
- package/dist/ra-core/src/notification/index.js +9 -0
- package/dist/ra-core/src/notification/types.d.ts +14 -0
- package/dist/ra-core/src/notification/types.js +1 -0
- package/dist/ra-core/src/notification/useCloseNotification.d.ts +1 -0
- package/dist/ra-core/src/notification/useCloseNotification.js +9 -0
- package/dist/ra-core/src/notification/useNotificationContext.d.ts +1 -0
- package/dist/ra-core/src/notification/useNotificationContext.js +3 -0
- package/dist/ra-core/src/notification/useNotify.d.ts +20 -0
- package/dist/ra-core/src/notification/useNotify.js +28 -0
- package/dist/ra-core/src/preferences/index.d.ts +7 -0
- package/dist/ra-core/src/preferences/index.js +7 -0
- package/dist/ra-core/src/preferences/usePreference.d.ts +18 -0
- package/dist/ra-core/src/preferences/usePreference.js +10 -0
- package/dist/ra-core/src/preferences/usePreferenceInput.d.ts +22 -0
- package/dist/ra-core/src/preferences/usePreferenceInput.js +43 -0
- package/dist/ra-core/src/preferences/usePreferencesEditor.d.ts +2 -0
- package/dist/ra-core/src/preferences/usePreferencesEditor.js +9 -0
- package/dist/ra-core/src/preferences/useSetInspectorTitle.d.ts +7 -0
- package/dist/ra-core/src/preferences/useSetInspectorTitle.js +19 -0
- package/dist/ra-core/src/routing/BasenameContext.d.ts +1 -0
- package/dist/ra-core/src/routing/BasenameContext.js +2 -0
- package/dist/ra-core/src/routing/RouterProvider.d.ts +163 -0
- package/dist/ra-core/src/routing/RouterProvider.js +1 -0
- package/dist/ra-core/src/routing/index.d.ts +28 -0
- package/dist/ra-core/src/routing/index.js +28 -0
- package/dist/ra-core/src/routing/types.d.ts +3 -0
- package/dist/ra-core/src/routing/types.js +1 -0
- package/dist/ra-core/src/routing/useBasename.d.ts +21 -0
- package/dist/ra-core/src/routing/useBasename.js +23 -0
- package/dist/ra-core/src/routing/useBlocker.d.ts +14 -0
- package/dist/ra-core/src/routing/useBlocker.js +17 -0
- package/dist/ra-core/src/routing/useCanBlock.d.ts +7 -0
- package/dist/ra-core/src/routing/useCanBlock.js +11 -0
- package/dist/ra-core/src/routing/useCreatePath.d.ts +42 -0
- package/dist/ra-core/src/routing/useCreatePath.js +69 -0
- package/dist/ra-core/src/routing/useGetPathForRecord.d.ts +42 -0
- package/dist/ra-core/src/routing/useGetPathForRecord.js +135 -0
- package/dist/ra-core/src/routing/useGetPathForRecordCallback.d.ts +6 -0
- package/dist/ra-core/src/routing/useGetPathForRecordCallback.js +82 -0
- package/dist/ra-core/src/routing/useInRouterContext.d.ts +11 -0
- package/dist/ra-core/src/routing/useInRouterContext.js +15 -0
- package/dist/ra-core/src/routing/useLocation.d.ts +10 -0
- package/dist/ra-core/src/routing/useLocation.js +13 -0
- package/dist/ra-core/src/routing/useMatch.d.ts +15 -0
- package/dist/ra-core/src/routing/useMatch.js +15 -0
- package/dist/ra-core/src/routing/useMatchPath.d.ts +17 -0
- package/dist/ra-core/src/routing/useMatchPath.js +17 -0
- package/dist/ra-core/src/routing/useNavigate.d.ts +12 -0
- package/dist/ra-core/src/routing/useNavigate.js +15 -0
- package/dist/ra-core/src/routing/useParams.d.ts +9 -0
- package/dist/ra-core/src/routing/useParams.js +13 -0
- package/dist/ra-core/src/routing/useRedirect.d.ts +30 -0
- package/dist/ra-core/src/routing/useRedirect.js +66 -0
- package/dist/ra-core/src/routing/useResetErrorBoundaryOnLocationChange.d.ts +7 -0
- package/dist/ra-core/src/routing/useResetErrorBoundaryOnLocationChange.js +17 -0
- package/dist/ra-core/src/routing/useRestoreScrollPosition.d.ts +40 -0
- package/dist/ra-core/src/routing/useRestoreScrollPosition.js +70 -0
- package/dist/ra-core/src/routing/useSplatPathBase.d.ts +13 -0
- package/dist/ra-core/src/routing/useSplatPathBase.js +21 -0
- package/dist/ra-core/src/store/index.d.ts +11 -0
- package/dist/ra-core/src/store/index.js +11 -0
- package/dist/ra-core/src/store/localStorageStore.d.ts +27 -0
- package/dist/ra-core/src/store/localStorageStore.js +198 -0
- package/dist/ra-core/src/store/types.d.ts +11 -0
- package/dist/ra-core/src/store/types.js +1 -0
- package/dist/ra-core/src/store/useRemoveFromStore.d.ts +17 -0
- package/dist/ra-core/src/store/useRemoveFromStore.js +29 -0
- package/dist/ra-core/src/store/useRemoveItemsFromStore.d.ts +17 -0
- package/dist/ra-core/src/store/useRemoveItemsFromStore.js +29 -0
- package/dist/ra-core/src/store/useResetStore.d.ts +17 -0
- package/dist/ra-core/src/store/useResetStore.js +21 -0
- package/dist/ra-core/src/store/useStore.d.ts +48 -0
- package/dist/ra-core/src/store/useStore.js +32 -0
- package/dist/ra-core/src/store/useStoreContext.d.ts +4 -0
- package/dist/ra-core/src/store/useStoreContext.js +6 -0
- package/dist/ra-core/src/test-ui/defaultI18nProvider.d.ts +2 -0
- package/dist/ra-core/src/test-ui/defaultI18nProvider.js +10 -0
- package/dist/ra-core/src/test-ui/index.d.ts +21 -0
- package/dist/ra-core/src/test-ui/index.js +21 -0
- package/dist/ra-core/src/types.d.ts +284 -0
- package/dist/ra-core/src/types.js +5 -0
- package/dist/ra-core/src/util/asyncDebounce.d.ts +7 -0
- package/dist/ra-core/src/util/asyncDebounce.js +29 -0
- package/dist/ra-core/src/util/escapePath.d.ts +11 -0
- package/dist/ra-core/src/util/escapePath.js +10 -0
- package/dist/ra-core/src/util/genericMemo.d.ts +5 -0
- package/dist/ra-core/src/util/genericMemo.js +14 -0
- package/dist/ra-core/src/util/getFieldLabelTranslationArgs.d.ts +22 -0
- package/dist/ra-core/src/util/getFieldLabelTranslationArgs.js +73 -0
- package/dist/ra-core/src/util/getMutationMode.d.ts +1 -0
- package/dist/ra-core/src/util/getMutationMode.js +13 -0
- package/dist/ra-core/src/util/hooks.d.ts +15 -0
- package/dist/ra-core/src/util/hooks.js +73 -0
- package/dist/ra-core/src/util/index.d.ts +20 -0
- package/dist/ra-core/src/util/index.js +19 -0
- package/dist/ra-core/src/util/mergeRefs.d.ts +2 -0
- package/dist/ra-core/src/util/mergeRefs.js +13 -0
- package/dist/ra-core/src/util/removeEmpty.d.ts +2 -0
- package/dist/ra-core/src/util/removeEmpty.js +16 -0
- package/dist/ra-core/src/util/removeKey.d.ts +2 -0
- package/dist/ra-core/src/util/removeKey.js +22 -0
- package/dist/ra-core/src/util/shallowEqual.d.ts +1 -0
- package/dist/ra-core/src/util/shallowEqual.js +29 -0
- package/dist/ra-core/src/util/useCheckForApplicationUpdate.d.ts +21 -0
- package/dist/ra-core/src/util/useCheckForApplicationUpdate.js +84 -0
- package/dist/ra-core/src/util/useDebouncedEvent.d.ts +8 -0
- package/dist/ra-core/src/util/useDebouncedEvent.js +28 -0
- package/dist/ra-core/src/util/useEvent.d.ts +7 -0
- package/dist/ra-core/src/util/useEvent.js +19 -0
- package/dist/ra-core/src/util/useFieldValue.d.ts +21 -0
- package/dist/ra-core/src/util/useFieldValue.js +27 -0
- package/dist/ra-core/src/util/useWhyDidYouUpdate.d.ts +12 -0
- package/dist/ra-core/src/util/useWhyDidYouUpdate.js +42 -0
- package/dist/ra-core/src/util/warning.d.ts +2 -0
- package/dist/ra-core/src/util/warning.js +5 -0
- package/dist/strato-faker-ecommerce/src/dataProvider.d.ts +2 -0
- package/dist/strato-faker-ecommerce/src/dataProvider.js +6 -0
- package/dist/strato-faker-ecommerce/src/generate.d.ts +8 -0
- package/dist/strato-faker-ecommerce/src/generate.js +148 -0
- package/dist/strato-faker-ecommerce/src/index.d.ts +3 -0
- package/dist/strato-faker-ecommerce/src/index.js +3 -0
- package/dist/strato-faker-ecommerce/src/types.d.ts +69 -0
- package/dist/strato-faker-ecommerce/src/types.js +1 -0
- package/dist/types.d.ts +1 -1
- package/package.json +6 -5
- package/src/dataProvider.ts +3 -3
- package/src/generate.test.ts +12 -12
- package/src/generate.ts +21 -14
- package/src/types.ts +1 -1
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { QueryObserverResult, UseQueryOptions } from '@tanstack/react-query';
|
|
2
|
+
/**
|
|
3
|
+
* Hook for getting user permissions
|
|
4
|
+
*
|
|
5
|
+
* Calls the authProvider.getPermissions() method using react-query.
|
|
6
|
+
* If the authProvider returns a rejected promise, returns empty permissions.
|
|
7
|
+
*
|
|
8
|
+
* The return value updates according to the request state:
|
|
9
|
+
*
|
|
10
|
+
* - start: { isPending: true }
|
|
11
|
+
* - success: { permissions: [any], isPending: false }
|
|
12
|
+
* - error: { error: [error from provider], isPending: false }
|
|
13
|
+
*
|
|
14
|
+
* Useful to enable features based on user permissions
|
|
15
|
+
*
|
|
16
|
+
* @param {Object} params Any params you want to pass to the authProvider
|
|
17
|
+
*
|
|
18
|
+
* @returns The current auth check state. Destructure as { permissions, error, isPending, refetch }.
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
* import { usePermissions } from 'react-admin';
|
|
22
|
+
*
|
|
23
|
+
* const PostDetail = () => {
|
|
24
|
+
* const { isPending, permissions } = usePermissions();
|
|
25
|
+
* if (!isPending && permissions == 'editor') {
|
|
26
|
+
* return <PostEdit />
|
|
27
|
+
* } else {
|
|
28
|
+
* return <PostShow />
|
|
29
|
+
* }
|
|
30
|
+
* };
|
|
31
|
+
*/
|
|
32
|
+
declare const usePermissions: <PermissionsType = any, ErrorType = Error>(params?: {}, queryParams?: UsePermissionsOptions<PermissionsType, ErrorType>) => UsePermissionsResult<PermissionsType, ErrorType>;
|
|
33
|
+
export default usePermissions;
|
|
34
|
+
export interface UsePermissionsOptions<PermissionsType = any, ErrorType = Error> extends Omit<UseQueryOptions<PermissionsType, ErrorType>, 'queryKey' | 'queryFn'> {
|
|
35
|
+
onSuccess?: (data: PermissionsType) => void;
|
|
36
|
+
onError?: (err: ErrorType) => void;
|
|
37
|
+
onSettled?: (data?: PermissionsType, error?: ErrorType | null) => void;
|
|
38
|
+
}
|
|
39
|
+
export type UsePermissionsResult<PermissionsType = any, ErrorType = Error> = QueryObserverResult<PermissionsType, ErrorType> & {
|
|
40
|
+
permissions: PermissionsType | undefined;
|
|
41
|
+
};
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { useEffect, useMemo } from 'react';
|
|
2
|
+
import { useQuery, } from '@tanstack/react-query';
|
|
3
|
+
import useAuthProvider from './useAuthProvider';
|
|
4
|
+
import useLogoutIfAccessDenied from './useLogoutIfAccessDenied';
|
|
5
|
+
import { useEvent } from '../util';
|
|
6
|
+
const emptyParams = {};
|
|
7
|
+
/**
|
|
8
|
+
* Hook for getting user permissions
|
|
9
|
+
*
|
|
10
|
+
* Calls the authProvider.getPermissions() method using react-query.
|
|
11
|
+
* If the authProvider returns a rejected promise, returns empty permissions.
|
|
12
|
+
*
|
|
13
|
+
* The return value updates according to the request state:
|
|
14
|
+
*
|
|
15
|
+
* - start: { isPending: true }
|
|
16
|
+
* - success: { permissions: [any], isPending: false }
|
|
17
|
+
* - error: { error: [error from provider], isPending: false }
|
|
18
|
+
*
|
|
19
|
+
* Useful to enable features based on user permissions
|
|
20
|
+
*
|
|
21
|
+
* @param {Object} params Any params you want to pass to the authProvider
|
|
22
|
+
*
|
|
23
|
+
* @returns The current auth check state. Destructure as { permissions, error, isPending, refetch }.
|
|
24
|
+
*
|
|
25
|
+
* @example
|
|
26
|
+
* import { usePermissions } from 'react-admin';
|
|
27
|
+
*
|
|
28
|
+
* const PostDetail = () => {
|
|
29
|
+
* const { isPending, permissions } = usePermissions();
|
|
30
|
+
* if (!isPending && permissions == 'editor') {
|
|
31
|
+
* return <PostEdit />
|
|
32
|
+
* } else {
|
|
33
|
+
* return <PostShow />
|
|
34
|
+
* }
|
|
35
|
+
* };
|
|
36
|
+
*/
|
|
37
|
+
const usePermissions = (params = emptyParams, queryParams = {
|
|
38
|
+
staleTime: 5 * 60 * 1000,
|
|
39
|
+
}) => {
|
|
40
|
+
const authProvider = useAuthProvider();
|
|
41
|
+
const logoutIfAccessDenied = useLogoutIfAccessDenied();
|
|
42
|
+
const { onSuccess, onError, onSettled, ...queryOptions } = queryParams ?? {};
|
|
43
|
+
const queryResult = useQuery({
|
|
44
|
+
queryKey: ['auth', 'getPermissions', params],
|
|
45
|
+
queryFn: async ({ signal }) => {
|
|
46
|
+
if (!authProvider || !authProvider.getPermissions) {
|
|
47
|
+
return [];
|
|
48
|
+
}
|
|
49
|
+
const permissions = await authProvider.getPermissions({
|
|
50
|
+
...params,
|
|
51
|
+
signal,
|
|
52
|
+
});
|
|
53
|
+
return permissions ?? null;
|
|
54
|
+
},
|
|
55
|
+
...queryOptions,
|
|
56
|
+
});
|
|
57
|
+
const onSuccessEvent = useEvent(onSuccess ?? noop);
|
|
58
|
+
const onSettledEvent = useEvent(onSettled ?? noop);
|
|
59
|
+
const onErrorEvent = useEvent(onError ??
|
|
60
|
+
((error) => {
|
|
61
|
+
if (process.env.NODE_ENV === 'development') {
|
|
62
|
+
console.error(error);
|
|
63
|
+
}
|
|
64
|
+
logoutIfAccessDenied(error);
|
|
65
|
+
}));
|
|
66
|
+
useEffect(() => {
|
|
67
|
+
if (queryResult.data === undefined || queryResult.isFetching)
|
|
68
|
+
return;
|
|
69
|
+
onSuccessEvent(queryResult.data);
|
|
70
|
+
}, [onSuccessEvent, queryResult.data, queryResult.isFetching]);
|
|
71
|
+
useEffect(() => {
|
|
72
|
+
if (queryResult.error == null || queryResult.isFetching)
|
|
73
|
+
return;
|
|
74
|
+
onErrorEvent(queryResult.error);
|
|
75
|
+
}, [onErrorEvent, queryResult.error, queryResult.isFetching]);
|
|
76
|
+
useEffect(() => {
|
|
77
|
+
if (queryResult.status === 'pending' || queryResult.isFetching)
|
|
78
|
+
return;
|
|
79
|
+
onSettledEvent(queryResult.data, queryResult.error);
|
|
80
|
+
}, [
|
|
81
|
+
onSettledEvent,
|
|
82
|
+
queryResult.data,
|
|
83
|
+
queryResult.error,
|
|
84
|
+
queryResult.status,
|
|
85
|
+
queryResult.isFetching,
|
|
86
|
+
]);
|
|
87
|
+
const result = useMemo(() => ({
|
|
88
|
+
...queryResult,
|
|
89
|
+
permissions: queryResult.data,
|
|
90
|
+
}), [queryResult]);
|
|
91
|
+
return !authProvider || !authProvider.getPermissions
|
|
92
|
+
? fakeQueryResult
|
|
93
|
+
: result;
|
|
94
|
+
};
|
|
95
|
+
export default usePermissions;
|
|
96
|
+
const noop = () => { };
|
|
97
|
+
const fakeQueryResult = {
|
|
98
|
+
permissions: undefined,
|
|
99
|
+
data: undefined,
|
|
100
|
+
dataUpdatedAt: 0,
|
|
101
|
+
error: null,
|
|
102
|
+
errorUpdatedAt: 0,
|
|
103
|
+
errorUpdateCount: 0,
|
|
104
|
+
failureCount: 0,
|
|
105
|
+
failureReason: null,
|
|
106
|
+
fetchStatus: 'idle',
|
|
107
|
+
isError: false,
|
|
108
|
+
isInitialLoading: false,
|
|
109
|
+
isLoading: false,
|
|
110
|
+
isLoadingError: false,
|
|
111
|
+
isFetched: true,
|
|
112
|
+
isFetchedAfterMount: true,
|
|
113
|
+
isFetching: false,
|
|
114
|
+
isPaused: false,
|
|
115
|
+
isPlaceholderData: false,
|
|
116
|
+
isPending: false,
|
|
117
|
+
isRefetchError: false,
|
|
118
|
+
isRefetching: false,
|
|
119
|
+
isStale: false,
|
|
120
|
+
isSuccess: true,
|
|
121
|
+
status: 'success',
|
|
122
|
+
refetch: () => Promise.resolve(fakeQueryResult),
|
|
123
|
+
};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import useDeleteWithUndoController from './useDeleteWithUndoController';
|
|
2
|
+
import useDeleteWithConfirmController from './useDeleteWithConfirmController';
|
|
3
|
+
export { useDeleteWithUndoController, useDeleteWithConfirmController };
|
|
4
|
+
export * from './useDeleteController';
|
|
5
|
+
export * from './useBulkDeleteController';
|
|
6
|
+
export * from './useUpdateController';
|
|
7
|
+
export * from './useBulkUpdateController';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import useDeleteWithUndoController from './useDeleteWithUndoController';
|
|
2
|
+
import useDeleteWithConfirmController from './useDeleteWithConfirmController';
|
|
3
|
+
export { useDeleteWithUndoController, useDeleteWithConfirmController };
|
|
4
|
+
export * from './useDeleteController';
|
|
5
|
+
export * from './useBulkDeleteController';
|
|
6
|
+
export * from './useUpdateController';
|
|
7
|
+
export * from './useBulkUpdateController';
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { UseDeleteManyOptions } from '../../dataProvider/useDeleteMany';
|
|
2
|
+
import { RaRecord, MutationMode } from '../../types';
|
|
3
|
+
export declare const useBulkDeleteController: <RecordType extends RaRecord = any, ErrorType = Error>(props: UseBulkDeleteControllerParams<RecordType, ErrorType>) => UseBulkDeleteControllerReturn;
|
|
4
|
+
export interface UseBulkDeleteControllerParams<RecordType extends RaRecord = any, MutationOptionsError = unknown> {
|
|
5
|
+
mutationMode?: MutationMode;
|
|
6
|
+
mutationOptions?: UseDeleteManyOptions<RecordType, MutationOptionsError>;
|
|
7
|
+
resource?: string;
|
|
8
|
+
successMessage?: string;
|
|
9
|
+
}
|
|
10
|
+
export interface UseBulkDeleteControllerReturn {
|
|
11
|
+
isLoading: boolean;
|
|
12
|
+
isPending: boolean;
|
|
13
|
+
handleDelete: () => void;
|
|
14
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { useCallback, useMemo } from 'react';
|
|
2
|
+
import { useDeleteMany, } from '../../dataProvider/useDeleteMany';
|
|
3
|
+
import { useRefresh } from '../../dataProvider/useRefresh';
|
|
4
|
+
import { useListContext } from '../list/useListContext';
|
|
5
|
+
import { useNotify } from '../../notification/useNotify';
|
|
6
|
+
import { useResourceContext } from '../../core/useResourceContext';
|
|
7
|
+
import { useTranslate } from '../../i18n/useTranslate';
|
|
8
|
+
export const useBulkDeleteController = (props) => {
|
|
9
|
+
const { mutationMode = 'undoable', mutationOptions = {}, successMessage, } = props;
|
|
10
|
+
const { meta: mutationMeta, ...otherMutationOptions } = mutationOptions;
|
|
11
|
+
const resource = useResourceContext(props);
|
|
12
|
+
const notify = useNotify();
|
|
13
|
+
const refresh = useRefresh();
|
|
14
|
+
const translate = useTranslate();
|
|
15
|
+
const { selectedIds, onUnselectItems } = useListContext();
|
|
16
|
+
const [deleteMany, { isPending }] = useDeleteMany(resource, undefined, {
|
|
17
|
+
onSuccess: () => {
|
|
18
|
+
notify(successMessage ??
|
|
19
|
+
`resources.${resource}.notifications.deleted`, {
|
|
20
|
+
type: 'info',
|
|
21
|
+
messageArgs: {
|
|
22
|
+
smart_count: selectedIds.length,
|
|
23
|
+
_: translate("strato.notification.deleted', {
|
|
24
|
+
smart_count: selectedIds.length,
|
|
25
|
+
}),
|
|
26
|
+
},
|
|
27
|
+
undoable: mutationMode === 'undoable',
|
|
28
|
+
});
|
|
29
|
+
onUnselectItems(true);
|
|
30
|
+
},
|
|
31
|
+
onError: (error) => {
|
|
32
|
+
notify(typeof error === 'string'
|
|
33
|
+
? error
|
|
34
|
+
: error?.message || "strato.notification.http_error', {
|
|
35
|
+
type: 'error',
|
|
36
|
+
messageArgs: {
|
|
37
|
+
_: typeof error === 'string'
|
|
38
|
+
? error
|
|
39
|
+
: error?.message,
|
|
40
|
+
},
|
|
41
|
+
});
|
|
42
|
+
refresh();
|
|
43
|
+
},
|
|
44
|
+
});
|
|
45
|
+
const handleDelete = useCallback(() => {
|
|
46
|
+
deleteMany(resource, {
|
|
47
|
+
ids: selectedIds,
|
|
48
|
+
meta: mutationMeta,
|
|
49
|
+
}, {
|
|
50
|
+
mutationMode,
|
|
51
|
+
...otherMutationOptions,
|
|
52
|
+
});
|
|
53
|
+
}, [
|
|
54
|
+
deleteMany,
|
|
55
|
+
mutationMeta,
|
|
56
|
+
mutationMode,
|
|
57
|
+
otherMutationOptions,
|
|
58
|
+
resource,
|
|
59
|
+
selectedIds,
|
|
60
|
+
]);
|
|
61
|
+
return useMemo(() => ({
|
|
62
|
+
isPending,
|
|
63
|
+
isLoading: isPending,
|
|
64
|
+
handleDelete,
|
|
65
|
+
}), [isPending, handleDelete]);
|
|
66
|
+
};
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { UseMutationOptions } from '@tanstack/react-query';
|
|
2
|
+
import { UseCreateMutateParams } from '../../dataProvider';
|
|
3
|
+
import { RedirectionSideEffect } from '../../routing';
|
|
4
|
+
import { SaveContextValue } from '../saveContext';
|
|
5
|
+
import { Identifier, MutationMode, RaRecord, TransformData } from '../../types';
|
|
6
|
+
/**
|
|
7
|
+
* Prepare data for the Create view
|
|
8
|
+
*
|
|
9
|
+
* @param {Object} props The props passed to the Create component.
|
|
10
|
+
*
|
|
11
|
+
* @return {Object} controllerProps Fetched data and callbacks for the Create view
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
*
|
|
15
|
+
* import { useCreateController } from 'react-admin';
|
|
16
|
+
* import CreateView from './CreateView';
|
|
17
|
+
*
|
|
18
|
+
* const MyCreate = props => {
|
|
19
|
+
* const controllerProps = useCreateController(props);
|
|
20
|
+
* return <CreateView {...controllerProps} {...props} />;
|
|
21
|
+
* }
|
|
22
|
+
*/
|
|
23
|
+
export declare const useCreateController: <RecordType extends Omit<RaRecord, "id"> = any, MutationOptionsError = Error, ResultRecordType extends RaRecord = RecordType & {
|
|
24
|
+
id: Identifier;
|
|
25
|
+
}>(props?: CreateControllerProps<RecordType, MutationOptionsError, ResultRecordType>) => CreateControllerResult<RecordType>;
|
|
26
|
+
export interface CreateControllerProps<RecordType extends Omit<RaRecord, 'id'> = any, MutationOptionsError = Error, ResultRecordType extends RaRecord = RecordType & {
|
|
27
|
+
id: Identifier;
|
|
28
|
+
}> {
|
|
29
|
+
disableAuthentication?: boolean;
|
|
30
|
+
hasEdit?: boolean;
|
|
31
|
+
hasShow?: boolean;
|
|
32
|
+
record?: Partial<RecordType>;
|
|
33
|
+
redirect?: RedirectionSideEffect;
|
|
34
|
+
resource?: string;
|
|
35
|
+
mutationMode?: MutationMode;
|
|
36
|
+
mutationOptions?: UseMutationOptions<ResultRecordType, MutationOptionsError, UseCreateMutateParams<RecordType>> & {
|
|
37
|
+
meta?: any;
|
|
38
|
+
};
|
|
39
|
+
transform?: TransformData;
|
|
40
|
+
}
|
|
41
|
+
export interface CreateControllerResult<RecordType extends Omit<RaRecord, 'id'> = any> extends SaveContextValue {
|
|
42
|
+
defaultTitle?: string;
|
|
43
|
+
isFetching: boolean;
|
|
44
|
+
isPending: boolean;
|
|
45
|
+
isLoading: boolean;
|
|
46
|
+
record?: Partial<RecordType>;
|
|
47
|
+
redirect: RedirectionSideEffect;
|
|
48
|
+
resource: string;
|
|
49
|
+
saving: boolean;
|
|
50
|
+
}
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
import { useCallback } from 'react';
|
|
2
|
+
import { useAuthenticated, useRequireAccess } from '../../auth';
|
|
3
|
+
import { HttpError, useCreate, } from '../../dataProvider';
|
|
4
|
+
import { useRedirect } from '../../routing';
|
|
5
|
+
import { useNotify } from '../../notification';
|
|
6
|
+
import { useMutationMiddlewares, } from '../saveContext';
|
|
7
|
+
import { useTranslate } from '../../i18n';
|
|
8
|
+
import { useResourceContext, useResourceDefinition, useGetResourceLabel, } from '../../core';
|
|
9
|
+
/**
|
|
10
|
+
* Prepare data for the Create view
|
|
11
|
+
*
|
|
12
|
+
* @param {Object} props The props passed to the Create component.
|
|
13
|
+
*
|
|
14
|
+
* @return {Object} controllerProps Fetched data and callbacks for the Create view
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
*
|
|
18
|
+
* import { useCreateController } from 'react-admin';
|
|
19
|
+
* import CreateView from './CreateView';
|
|
20
|
+
*
|
|
21
|
+
* const MyCreate = props => {
|
|
22
|
+
* const controllerProps = useCreateController(props);
|
|
23
|
+
* return <CreateView {...controllerProps} {...props} />;
|
|
24
|
+
* }
|
|
25
|
+
*/
|
|
26
|
+
export const useCreateController = (props = {}) => {
|
|
27
|
+
const { disableAuthentication, record, redirect: redirectTo, transform, mutationMode = 'pessimistic', mutationOptions = {}, } = props;
|
|
28
|
+
const resource = useResourceContext(props);
|
|
29
|
+
if (!resource) {
|
|
30
|
+
throw new Error('useCreateController requires a non-empty resource prop or context');
|
|
31
|
+
}
|
|
32
|
+
const { isPending: isPendingAuthenticated } = useAuthenticated({
|
|
33
|
+
enabled: !disableAuthentication,
|
|
34
|
+
});
|
|
35
|
+
const { isPending: isPendingCanAccess } = useRequireAccess({
|
|
36
|
+
action: 'create',
|
|
37
|
+
resource,
|
|
38
|
+
enabled: !disableAuthentication && !isPendingAuthenticated,
|
|
39
|
+
});
|
|
40
|
+
const { hasEdit, hasShow } = useResourceDefinition(props);
|
|
41
|
+
const finalRedirectTo = redirectTo ?? getDefaultRedirectRoute(hasShow, hasEdit);
|
|
42
|
+
const translate = useTranslate();
|
|
43
|
+
const notify = useNotify();
|
|
44
|
+
const redirect = useRedirect();
|
|
45
|
+
const { onSuccess, onError, meta, ...otherMutationOptions } = mutationOptions;
|
|
46
|
+
const { registerMutationMiddleware, getMutateWithMiddlewares, unregisterMutationMiddleware, } = useMutationMiddlewares();
|
|
47
|
+
const [create, { isPending: saving }] = useCreate(resource, undefined, {
|
|
48
|
+
onSuccess: async (...args) => {
|
|
49
|
+
if (onSuccess) {
|
|
50
|
+
return onSuccess(...args);
|
|
51
|
+
}
|
|
52
|
+
const [data] = args;
|
|
53
|
+
notify(`resources.${resource}.notifications.created`, {
|
|
54
|
+
type: 'info',
|
|
55
|
+
messageArgs: {
|
|
56
|
+
smart_count: 1,
|
|
57
|
+
_: translate(`ra.notification.created`, {
|
|
58
|
+
smart_count: 1,
|
|
59
|
+
}),
|
|
60
|
+
},
|
|
61
|
+
undoable: mutationMode === 'undoable',
|
|
62
|
+
});
|
|
63
|
+
redirect(finalRedirectTo, resource, data.id, data);
|
|
64
|
+
},
|
|
65
|
+
onError: (...args) => {
|
|
66
|
+
if (onError) {
|
|
67
|
+
return onError(...args);
|
|
68
|
+
}
|
|
69
|
+
const [error] = args;
|
|
70
|
+
// Don't trigger a notification if this is a validation error
|
|
71
|
+
// (notification will be handled by the useNotifyIsFormInvalid hook)
|
|
72
|
+
const validationErrors = error?.body?.errors;
|
|
73
|
+
const hasValidationErrors = !!validationErrors && Object.keys(validationErrors).length > 0;
|
|
74
|
+
if (!hasValidationErrors || mutationMode !== 'pessimistic') {
|
|
75
|
+
notify(typeof error === 'string'
|
|
76
|
+
? error
|
|
77
|
+
: error.message ||
|
|
78
|
+
"strato.notification.http_error', {
|
|
79
|
+
type: 'error',
|
|
80
|
+
messageArgs: {
|
|
81
|
+
_: typeof error === 'string'
|
|
82
|
+
? error
|
|
83
|
+
: error instanceof Error ||
|
|
84
|
+
(typeof error === 'object' &&
|
|
85
|
+
error !== null &&
|
|
86
|
+
error.hasOwnProperty('message'))
|
|
87
|
+
? // @ts-ignore
|
|
88
|
+
error.message
|
|
89
|
+
: undefined,
|
|
90
|
+
},
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
},
|
|
94
|
+
...otherMutationOptions,
|
|
95
|
+
mutationMode,
|
|
96
|
+
returnPromise: mutationMode === 'pessimistic',
|
|
97
|
+
getMutateWithMiddlewares,
|
|
98
|
+
});
|
|
99
|
+
const save = useCallback((data, { onSuccess: onSuccessFromSave, onError: onErrorFromSave, transform: transformFromSave, meta: metaFromSave, } = {}) => Promise.resolve(transformFromSave
|
|
100
|
+
? transformFromSave(data)
|
|
101
|
+
: transform
|
|
102
|
+
? transform(data)
|
|
103
|
+
: data).then(async (data) => {
|
|
104
|
+
try {
|
|
105
|
+
await create(resource, { data, meta: metaFromSave ?? meta }, {
|
|
106
|
+
onError: onErrorFromSave,
|
|
107
|
+
onSuccess: onSuccessFromSave,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
catch (error) {
|
|
111
|
+
if ((error instanceof HttpError ||
|
|
112
|
+
(typeof error === 'object' &&
|
|
113
|
+
error !== null &&
|
|
114
|
+
error.hasOwnProperty('body'))) &&
|
|
115
|
+
error.body?.errors != null) {
|
|
116
|
+
return error.body.errors;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}), [create, meta, resource, transform]);
|
|
120
|
+
const getResourceLabel = useGetResourceLabel();
|
|
121
|
+
const defaultTitle = translate(`resources.${resource}.page.create`, {
|
|
122
|
+
_: translate("strato.page.create', {
|
|
123
|
+
name: getResourceLabel(resource, 1),
|
|
124
|
+
}),
|
|
125
|
+
});
|
|
126
|
+
return {
|
|
127
|
+
isFetching: false,
|
|
128
|
+
isLoading: false,
|
|
129
|
+
isPending: disableAuthentication ? false : isPendingCanAccess,
|
|
130
|
+
mutationMode,
|
|
131
|
+
saving,
|
|
132
|
+
defaultTitle,
|
|
133
|
+
save,
|
|
134
|
+
record,
|
|
135
|
+
resource,
|
|
136
|
+
redirect: finalRedirectTo,
|
|
137
|
+
registerMutationMiddleware,
|
|
138
|
+
unregisterMutationMiddleware,
|
|
139
|
+
};
|
|
140
|
+
};
|
|
141
|
+
const getDefaultRedirectRoute = (hasShow, hasEdit) => {
|
|
142
|
+
if (hasEdit) {
|
|
143
|
+
return 'edit';
|
|
144
|
+
}
|
|
145
|
+
if (hasShow) {
|
|
146
|
+
return 'show';
|
|
147
|
+
}
|
|
148
|
+
return 'list';
|
|
149
|
+
};
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { RaRecord, MutationMode, TransformData } from '../../types';
|
|
2
|
+
import { RedirectionSideEffect } from '../../routing';
|
|
3
|
+
import { UseGetOneHookValue, UseGetOneOptions, UseUpdateOptions } from '../../dataProvider';
|
|
4
|
+
import { SaveContextValue } from '../saveContext';
|
|
5
|
+
/**
|
|
6
|
+
* Prepare data for the Edit view.
|
|
7
|
+
*
|
|
8
|
+
* useEditController does a few things:
|
|
9
|
+
* - it grabs the id from the URL and the resource name from the ResourceContext,
|
|
10
|
+
* - it fetches the record via useGetOne,
|
|
11
|
+
* - it prepares the page title.
|
|
12
|
+
*
|
|
13
|
+
* @param {Object} props The props passed to the Edit component.
|
|
14
|
+
*
|
|
15
|
+
* @return {Object} controllerProps Fetched data and callbacks for the Edit view
|
|
16
|
+
*
|
|
17
|
+
* @example
|
|
18
|
+
*
|
|
19
|
+
* import { useEditController } from 'react-admin';
|
|
20
|
+
* import EditView from './EditView';
|
|
21
|
+
*
|
|
22
|
+
* const MyEdit = () => {
|
|
23
|
+
* const controllerProps = useEditController({ resource: 'posts', id: 123 });
|
|
24
|
+
* return <EditView {...controllerProps} {...props} />;
|
|
25
|
+
* }
|
|
26
|
+
*/
|
|
27
|
+
export declare const useEditController: <RecordType extends RaRecord = any, ErrorType = Error>(props?: EditControllerProps<RecordType, ErrorType>) => EditControllerResult<RecordType, ErrorType>;
|
|
28
|
+
export interface EditControllerProps<RecordType extends RaRecord = any, ErrorType = Error> {
|
|
29
|
+
disableAuthentication?: boolean;
|
|
30
|
+
id?: RecordType['id'];
|
|
31
|
+
mutationMode?: MutationMode;
|
|
32
|
+
mutationOptions?: UseUpdateOptions<RecordType, ErrorType>;
|
|
33
|
+
queryOptions?: UseGetOneOptions<RecordType, ErrorType>;
|
|
34
|
+
redirect?: RedirectionSideEffect;
|
|
35
|
+
redirectOnError?: RedirectionSideEffect;
|
|
36
|
+
resource?: string;
|
|
37
|
+
transform?: TransformData;
|
|
38
|
+
[key: string]: any;
|
|
39
|
+
}
|
|
40
|
+
export interface EditControllerBaseResult<RecordType extends RaRecord = any> extends SaveContextValue<RecordType> {
|
|
41
|
+
defaultTitle?: string;
|
|
42
|
+
isFetching: boolean;
|
|
43
|
+
isLoading: boolean;
|
|
44
|
+
isPaused?: boolean;
|
|
45
|
+
isPlaceholderData?: boolean;
|
|
46
|
+
refetch: UseGetOneHookValue<RecordType>['refetch'];
|
|
47
|
+
redirect: RedirectionSideEffect;
|
|
48
|
+
redirectOnError: RedirectionSideEffect;
|
|
49
|
+
resource: string;
|
|
50
|
+
saving: boolean;
|
|
51
|
+
}
|
|
52
|
+
export interface EditControllerLoadingResult<RecordType extends RaRecord = any> extends EditControllerBaseResult<RecordType> {
|
|
53
|
+
record: undefined;
|
|
54
|
+
error: null;
|
|
55
|
+
isPending: true;
|
|
56
|
+
}
|
|
57
|
+
export interface EditControllerLoadingErrorResult<RecordType extends RaRecord = any, TError = Error> extends EditControllerBaseResult<RecordType> {
|
|
58
|
+
record: undefined;
|
|
59
|
+
error: TError;
|
|
60
|
+
isPending: false;
|
|
61
|
+
}
|
|
62
|
+
export interface EditControllerRefetchErrorResult<RecordType extends RaRecord = any, TError = Error> extends EditControllerBaseResult<RecordType> {
|
|
63
|
+
record: RecordType;
|
|
64
|
+
error: TError;
|
|
65
|
+
isPending: false;
|
|
66
|
+
}
|
|
67
|
+
export interface EditControllerSuccessResult<RecordType extends RaRecord = any> extends EditControllerBaseResult<RecordType> {
|
|
68
|
+
record: RecordType;
|
|
69
|
+
error: null;
|
|
70
|
+
isPending: false;
|
|
71
|
+
}
|
|
72
|
+
export type EditControllerResult<RecordType extends RaRecord = any, ErrorType = Error> = EditControllerLoadingResult<RecordType> | EditControllerLoadingErrorResult<RecordType, ErrorType> | EditControllerRefetchErrorResult<RecordType, ErrorType> | EditControllerSuccessResult<RecordType>;
|