@refinedev/core 4.0.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/CHANGELOG.md +2577 -0
- package/README.md +257 -0
- package/dist/components/authenticated/index.d.ts +41 -0
- package/dist/components/authenticated/index.d.ts.map +1 -0
- package/dist/components/canAccess/index.d.ts +11 -0
- package/dist/components/canAccess/index.d.ts.map +1 -0
- package/dist/components/containers/index.d.ts +2 -0
- package/dist/components/containers/index.d.ts.map +1 -0
- package/dist/components/containers/refine/index.d.ts +144 -0
- package/dist/components/containers/refine/index.d.ts.map +1 -0
- package/dist/components/gh-banner/index.d.ts +3 -0
- package/dist/components/gh-banner/index.d.ts.map +1 -0
- package/dist/components/gh-banner/styles.d.ts +2 -0
- package/dist/components/gh-banner/styles.d.ts.map +1 -0
- package/dist/components/index.d.ts +9 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/layoutWrapper/defaultLayout/index.d.ts +4 -0
- package/dist/components/layoutWrapper/defaultLayout/index.d.ts.map +1 -0
- package/dist/components/layoutWrapper/index.d.ts +46 -0
- package/dist/components/layoutWrapper/index.d.ts.map +1 -0
- package/dist/components/pages/auth/components/forgotPassword/index.d.ts +7 -0
- package/dist/components/pages/auth/components/forgotPassword/index.d.ts.map +1 -0
- package/dist/components/pages/auth/components/index.d.ts +5 -0
- package/dist/components/pages/auth/components/index.d.ts.map +1 -0
- package/dist/components/pages/auth/components/login/index.d.ts +7 -0
- package/dist/components/pages/auth/components/login/index.d.ts.map +1 -0
- package/dist/components/pages/auth/components/register/index.d.ts +7 -0
- package/dist/components/pages/auth/components/register/index.d.ts.map +1 -0
- package/dist/components/pages/auth/components/updatePassword/index.d.ts +7 -0
- package/dist/components/pages/auth/components/updatePassword/index.d.ts.map +1 -0
- package/dist/components/pages/auth/index.d.ts +12 -0
- package/dist/components/pages/auth/index.d.ts.map +1 -0
- package/dist/components/pages/error/index.d.ts +9 -0
- package/dist/components/pages/error/index.d.ts.map +1 -0
- package/dist/components/pages/index.d.ts +7 -0
- package/dist/components/pages/index.d.ts.map +1 -0
- package/dist/components/pages/login/index.d.ts +13 -0
- package/dist/components/pages/login/index.d.ts.map +1 -0
- package/dist/components/pages/ready/index.d.ts +9 -0
- package/dist/components/pages/ready/index.d.ts.map +1 -0
- package/dist/components/pages/welcome/index.d.ts +6 -0
- package/dist/components/pages/welcome/index.d.ts.map +1 -0
- package/dist/components/routeChangeHandler/index.d.ts +3 -0
- package/dist/components/routeChangeHandler/index.d.ts.map +1 -0
- package/dist/components/telemetry/index.d.ts +3 -0
- package/dist/components/telemetry/index.d.ts.map +1 -0
- package/dist/components/undoableQueue/index.d.ts +6 -0
- package/dist/components/undoableQueue/index.d.ts.map +1 -0
- package/dist/contexts/accessControl/IAccessControlContext.d.ts +31 -0
- package/dist/contexts/accessControl/IAccessControlContext.d.ts.map +1 -0
- package/dist/contexts/accessControl/index.d.ts +9 -0
- package/dist/contexts/accessControl/index.d.ts.map +1 -0
- package/dist/contexts/auditLog/IAuditLogContext.d.ts +29 -0
- package/dist/contexts/auditLog/IAuditLogContext.d.ts.map +1 -0
- package/dist/contexts/auditLog/index.d.ts +7 -0
- package/dist/contexts/auditLog/index.d.ts.map +1 -0
- package/dist/contexts/auth/IAuthContext.d.ts +26 -0
- package/dist/contexts/auth/IAuthContext.d.ts.map +1 -0
- package/dist/contexts/auth/index.d.ts +20 -0
- package/dist/contexts/auth/index.d.ts.map +1 -0
- package/dist/contexts/data/IDataContext.d.ts +193 -0
- package/dist/contexts/data/IDataContext.d.ts.map +1 -0
- package/dist/contexts/data/index.d.ts +52 -0
- package/dist/contexts/data/index.d.ts.map +1 -0
- package/dist/contexts/legacy-router/IRouterContext.d.ts +35 -0
- package/dist/contexts/legacy-router/IRouterContext.d.ts.map +1 -0
- package/dist/contexts/legacy-router/index.d.ts +9 -0
- package/dist/contexts/legacy-router/index.d.ts.map +1 -0
- package/dist/contexts/live/ILiveContext.d.ts +39 -0
- package/dist/contexts/live/ILiveContext.d.ts.map +1 -0
- package/dist/contexts/live/index.d.ts +5 -0
- package/dist/contexts/live/index.d.ts.map +1 -0
- package/dist/contexts/notification/INotificationContext.d.ts +14 -0
- package/dist/contexts/notification/INotificationContext.d.ts.map +1 -0
- package/dist/contexts/notification/index.d.ts +9 -0
- package/dist/contexts/notification/index.d.ts.map +1 -0
- package/dist/contexts/refine/IRefineContext.d.ts +106 -0
- package/dist/contexts/refine/IRefineContext.d.ts.map +1 -0
- package/dist/contexts/refine/index.d.ts +6 -0
- package/dist/contexts/refine/index.d.ts.map +1 -0
- package/dist/contexts/resource/IResourceContext.d.ts +49 -0
- package/dist/contexts/resource/IResourceContext.d.ts.map +1 -0
- package/dist/contexts/resource/index.d.ts +9 -0
- package/dist/contexts/resource/index.d.ts.map +1 -0
- package/dist/contexts/router/index.d.ts +7 -0
- package/dist/contexts/router/index.d.ts.map +1 -0
- package/dist/contexts/router-picker/index.d.ts +15 -0
- package/dist/contexts/router-picker/index.d.ts.map +1 -0
- package/dist/contexts/translation/ITranslationContext.d.ts +11 -0
- package/dist/contexts/translation/ITranslationContext.d.ts.map +1 -0
- package/dist/contexts/translation/index.d.ts +9 -0
- package/dist/contexts/translation/index.d.ts.map +1 -0
- package/dist/contexts/undoableQueue/IUndoableQueueContext.d.ts +7 -0
- package/dist/contexts/undoableQueue/IUndoableQueueContext.d.ts.map +1 -0
- package/dist/contexts/undoableQueue/actionTypes.d.ts +6 -0
- package/dist/contexts/undoableQueue/actionTypes.d.ts.map +1 -0
- package/dist/contexts/undoableQueue/index.d.ts +3 -0
- package/dist/contexts/undoableQueue/index.d.ts.map +1 -0
- package/dist/contexts/undoableQueue/undoableQueueContext.d.ts +8 -0
- package/dist/contexts/undoableQueue/undoableQueueContext.d.ts.map +1 -0
- package/dist/contexts/unsavedWarn/IUnsavedWarnContext.d.ts +5 -0
- package/dist/contexts/unsavedWarn/IUnsavedWarnContext.d.ts.map +1 -0
- package/dist/contexts/unsavedWarn/index.d.ts +7 -0
- package/dist/contexts/unsavedWarn/index.d.ts.map +1 -0
- package/dist/definitions/helpers/check-router-prop-misuse/index.d.ts +3 -0
- package/dist/definitions/helpers/check-router-prop-misuse/index.d.ts.map +1 -0
- package/dist/definitions/helpers/handleMultiple/index.d.ts +6 -0
- package/dist/definitions/helpers/handleMultiple/index.d.ts.map +1 -0
- package/dist/definitions/helpers/handlePaginationParams/index.d.ts +9 -0
- package/dist/definitions/helpers/handlePaginationParams/index.d.ts.map +1 -0
- package/dist/definitions/helpers/handleRefineOptions/index.d.ts +26 -0
- package/dist/definitions/helpers/handleRefineOptions/index.d.ts.map +1 -0
- package/dist/definitions/helpers/handleUseParams/index.d.ts +2 -0
- package/dist/definitions/helpers/handleUseParams/index.d.ts.map +1 -0
- package/dist/definitions/helpers/hasPermission/index.d.ts +2 -0
- package/dist/definitions/helpers/hasPermission/index.d.ts.map +1 -0
- package/dist/definitions/helpers/humanizeString/index.d.ts +2 -0
- package/dist/definitions/helpers/humanizeString/index.d.ts.map +1 -0
- package/dist/definitions/helpers/importCSVMapper/index.d.ts +3 -0
- package/dist/definitions/helpers/importCSVMapper/index.d.ts.map +1 -0
- package/dist/definitions/helpers/index.d.ts +23 -0
- package/dist/definitions/helpers/index.d.ts.map +1 -0
- package/dist/definitions/helpers/legacy-resource-transform/index.d.ts +9 -0
- package/dist/definitions/helpers/legacy-resource-transform/index.d.ts.map +1 -0
- package/dist/definitions/helpers/menu/create-resource-key.d.ts +3 -0
- package/dist/definitions/helpers/menu/create-resource-key.d.ts.map +1 -0
- package/dist/definitions/helpers/menu/create-tree.d.ts +13 -0
- package/dist/definitions/helpers/menu/create-tree.d.ts.map +1 -0
- package/dist/definitions/helpers/pick-resource/index.d.ts +8 -0
- package/dist/definitions/helpers/pick-resource/index.d.ts.map +1 -0
- package/dist/definitions/helpers/pickDataProvider/index.d.ts +6 -0
- package/dist/definitions/helpers/pickDataProvider/index.d.ts.map +1 -0
- package/dist/definitions/helpers/pickNotDeprecated/index.d.ts +2 -0
- package/dist/definitions/helpers/pickNotDeprecated/index.d.ts.map +1 -0
- package/dist/definitions/helpers/queryKeys/index.d.ts +4 -0
- package/dist/definitions/helpers/queryKeys/index.d.ts.map +1 -0
- package/dist/definitions/helpers/redirectPage/index.d.ts +9 -0
- package/dist/definitions/helpers/redirectPage/index.d.ts.map +1 -0
- package/dist/definitions/helpers/routeGenerator/index.d.ts +7 -0
- package/dist/definitions/helpers/routeGenerator/index.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/check-by-segments.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/check-by-segments.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/compose-route.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/compose-route.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/get-action-routes-from-resource.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/get-action-routes-from-resource.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/get-default-action-path.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/get-default-action-path.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/get-parent-prefix-for-resource.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/get-parent-prefix-for-resource.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/get-parent-resource.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/get-parent-resource.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/is-segment-counts-same.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/is-segment-counts-same.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/match-resource-from-route.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/match-resource-from-route.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/pick-matched-route.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/pick-matched-route.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/pick-route-params.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/pick-route-params.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/prepare-route-params.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/prepare-route-params.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/remove-leading-trailing-slashes.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/remove-leading-trailing-slashes.d.ts.map +1 -0
- package/dist/definitions/helpers/router/__tests__/split-to-segments.d.ts +2 -0
- package/dist/definitions/helpers/router/__tests__/split-to-segments.d.ts.map +1 -0
- package/dist/definitions/helpers/router/check-by-segments.d.ts +9 -0
- package/dist/definitions/helpers/router/check-by-segments.d.ts.map +1 -0
- package/dist/definitions/helpers/router/compose-route.d.ts +10 -0
- package/dist/definitions/helpers/router/compose-route.d.ts.map +1 -0
- package/dist/definitions/helpers/router/get-action-routes-from-resource.d.ts +15 -0
- package/dist/definitions/helpers/router/get-action-routes-from-resource.d.ts.map +1 -0
- package/dist/definitions/helpers/router/get-default-action-path.d.ts +8 -0
- package/dist/definitions/helpers/router/get-default-action-path.d.ts.map +1 -0
- package/dist/definitions/helpers/router/get-parent-prefix-for-resource.d.ts +7 -0
- package/dist/definitions/helpers/router/get-parent-prefix-for-resource.d.ts.map +1 -0
- package/dist/definitions/helpers/router/get-parent-resource.d.ts +7 -0
- package/dist/definitions/helpers/router/get-parent-resource.d.ts.map +1 -0
- package/dist/definitions/helpers/router/index.d.ts +10 -0
- package/dist/definitions/helpers/router/index.d.ts.map +1 -0
- package/dist/definitions/helpers/router/is-parameter.d.ts +5 -0
- package/dist/definitions/helpers/router/is-parameter.d.ts.map +1 -0
- package/dist/definitions/helpers/router/is-segment-counts-same.d.ts +5 -0
- package/dist/definitions/helpers/router/is-segment-counts-same.d.ts.map +1 -0
- package/dist/definitions/helpers/router/match-resource-from-route.d.ts +14 -0
- package/dist/definitions/helpers/router/match-resource-from-route.d.ts.map +1 -0
- package/dist/definitions/helpers/router/pick-matched-route.d.ts +8 -0
- package/dist/definitions/helpers/router/pick-matched-route.d.ts.map +1 -0
- package/dist/definitions/helpers/router/pick-route-params.d.ts +6 -0
- package/dist/definitions/helpers/router/pick-route-params.d.ts.map +1 -0
- package/dist/definitions/helpers/router/prepare-route-params.d.ts +9 -0
- package/dist/definitions/helpers/router/prepare-route-params.d.ts.map +1 -0
- package/dist/definitions/helpers/router/remove-leading-trailing-slashes.d.ts +5 -0
- package/dist/definitions/helpers/router/remove-leading-trailing-slashes.d.ts.map +1 -0
- package/dist/definitions/helpers/router/split-to-segments.d.ts +5 -0
- package/dist/definitions/helpers/router/split-to-segments.d.ts.map +1 -0
- package/dist/definitions/helpers/sanitize-resource/index.d.ts +8 -0
- package/dist/definitions/helpers/sanitize-resource/index.d.ts.map +1 -0
- package/dist/definitions/helpers/sequentialPromises/index.d.ts +5 -0
- package/dist/definitions/helpers/sequentialPromises/index.d.ts.map +1 -0
- package/dist/definitions/helpers/treeView/createTreeView/index.d.ts +6 -0
- package/dist/definitions/helpers/treeView/createTreeView/index.d.ts.map +1 -0
- package/dist/definitions/helpers/treeView/index.d.ts +2 -0
- package/dist/definitions/helpers/treeView/index.d.ts.map +1 -0
- package/dist/definitions/helpers/useActiveAuthProvider/index.d.ts +34 -0
- package/dist/definitions/helpers/useActiveAuthProvider/index.d.ts.map +1 -0
- package/dist/definitions/helpers/useInfinitePagination/index.d.ts +4 -0
- package/dist/definitions/helpers/useInfinitePagination/index.d.ts.map +1 -0
- package/dist/definitions/helpers/userFriendlyResourceName/index.d.ts +6 -0
- package/dist/definitions/helpers/userFriendlyResourceName/index.d.ts.map +1 -0
- package/dist/definitions/helpers/userFriendlySeconds/index.d.ts +2 -0
- package/dist/definitions/helpers/userFriendlySeconds/index.d.ts.map +1 -0
- package/dist/definitions/index.d.ts +4 -0
- package/dist/definitions/index.d.ts.map +1 -0
- package/dist/definitions/table/index.d.ts +34 -0
- package/dist/definitions/table/index.d.ts.map +1 -0
- package/dist/definitions/upload/file2Base64/index.d.ts +2 -0
- package/dist/definitions/upload/file2Base64/index.d.ts.map +1 -0
- package/dist/definitions/upload/index.d.ts +2 -0
- package/dist/definitions/upload/index.d.ts.map +1 -0
- package/dist/esm/index.js +56 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/hooks/accessControl/index.d.ts +3 -0
- package/dist/hooks/accessControl/index.d.ts.map +1 -0
- package/dist/hooks/accessControl/useCan/index.d.ts +18 -0
- package/dist/hooks/accessControl/useCan/index.d.ts.map +1 -0
- package/dist/hooks/accessControl/useCanWithoutCache.d.ts +3 -0
- package/dist/hooks/accessControl/useCanWithoutCache.d.ts.map +1 -0
- package/dist/hooks/auditLog/index.d.ts +3 -0
- package/dist/hooks/auditLog/index.d.ts.map +1 -0
- package/dist/hooks/auditLog/useLog/index.d.ts +26 -0
- package/dist/hooks/auditLog/useLog/index.d.ts.map +1 -0
- package/dist/hooks/auditLog/useLogList/index.d.ts +16 -0
- package/dist/hooks/auditLog/useLogList/index.d.ts.map +1 -0
- package/dist/hooks/auth/index.d.ts +11 -0
- package/dist/hooks/auth/index.d.ts.map +1 -0
- package/dist/hooks/auth/useForgotPassword/index.d.ts +21 -0
- package/dist/hooks/auth/useForgotPassword/index.d.ts.map +1 -0
- package/dist/hooks/auth/useGetIdentity/index.d.ts +21 -0
- package/dist/hooks/auth/useGetIdentity/index.d.ts.map +1 -0
- package/dist/hooks/auth/useInvaliteAuthStore/index.d.ts +2 -0
- package/dist/hooks/auth/useInvaliteAuthStore/index.d.ts.map +1 -0
- package/dist/hooks/auth/useIsAuthenticated/index.d.ts +25 -0
- package/dist/hooks/auth/useIsAuthenticated/index.d.ts.map +1 -0
- package/dist/hooks/auth/useIsExistAuthentication/index.d.ts +6 -0
- package/dist/hooks/auth/useIsExistAuthentication/index.d.ts.map +1 -0
- package/dist/hooks/auth/useLogin/index.d.ts +22 -0
- package/dist/hooks/auth/useLogin/index.d.ts.map +1 -0
- package/dist/hooks/auth/useLogout/index.d.ts +26 -0
- package/dist/hooks/auth/useLogout/index.d.ts.map +1 -0
- package/dist/hooks/auth/useOnError/index.d.ts +22 -0
- package/dist/hooks/auth/useOnError/index.d.ts.map +1 -0
- package/dist/hooks/auth/usePermissions/index.d.ts +21 -0
- package/dist/hooks/auth/usePermissions/index.d.ts.map +1 -0
- package/dist/hooks/auth/useRegister/index.d.ts +21 -0
- package/dist/hooks/auth/useRegister/index.d.ts.map +1 -0
- package/dist/hooks/auth/useUpdatePassword/index.d.ts +21 -0
- package/dist/hooks/auth/useUpdatePassword/index.d.ts.map +1 -0
- package/dist/hooks/breadcrumb/index.d.ts +18 -0
- package/dist/hooks/breadcrumb/index.d.ts.map +1 -0
- package/dist/hooks/data/index.d.ts +15 -0
- package/dist/hooks/data/index.d.ts.map +1 -0
- package/dist/hooks/data/useApiUrl.d.ts +2 -0
- package/dist/hooks/data/useApiUrl.d.ts.map +1 -0
- package/dist/hooks/data/useCreate.d.ts +48 -0
- package/dist/hooks/data/useCreate.d.ts.map +1 -0
- package/dist/hooks/data/useCreateMany.d.ts +29 -0
- package/dist/hooks/data/useCreateMany.d.ts.map +1 -0
- package/dist/hooks/data/useCustom.d.ts +60 -0
- package/dist/hooks/data/useCustom.d.ts.map +1 -0
- package/dist/hooks/data/useCustomMutation.d.ts +40 -0
- package/dist/hooks/data/useCustomMutation.d.ts.map +1 -0
- package/dist/hooks/data/useDataProvider.d.ts +3 -0
- package/dist/hooks/data/useDataProvider.d.ts.map +1 -0
- package/dist/hooks/data/useDelete.d.ts +35 -0
- package/dist/hooks/data/useDelete.d.ts.map +1 -0
- package/dist/hooks/data/useDeleteMany.d.ts +35 -0
- package/dist/hooks/data/useDeleteMany.d.ts.map +1 -0
- package/dist/hooks/data/useInfiniteList.d.ts +67 -0
- package/dist/hooks/data/useInfiniteList.d.ts.map +1 -0
- package/dist/hooks/data/useList.d.ts +67 -0
- package/dist/hooks/data/useList.d.ts.map +1 -0
- package/dist/hooks/data/useMany.d.ts +44 -0
- package/dist/hooks/data/useMany.d.ts.map +1 -0
- package/dist/hooks/data/useOne.d.ts +44 -0
- package/dist/hooks/data/useOne.d.ts.map +1 -0
- package/dist/hooks/data/useUpdate.d.ts +64 -0
- package/dist/hooks/data/useUpdate.d.ts.map +1 -0
- package/dist/hooks/data/useUpdateMany.d.ts +40 -0
- package/dist/hooks/data/useUpdateMany.d.ts.map +1 -0
- package/dist/hooks/deepMemo/index.d.ts +7 -0
- package/dist/hooks/deepMemo/index.d.ts.map +1 -0
- package/dist/hooks/export/csvDownload.interface.d.ts +20 -0
- package/dist/hooks/export/csvDownload.interface.d.ts.map +1 -0
- package/dist/hooks/export/index.d.ts +75 -0
- package/dist/hooks/export/index.d.ts.map +1 -0
- package/dist/hooks/form/index.d.ts +2 -0
- package/dist/hooks/form/index.d.ts.map +1 -0
- package/dist/hooks/form/useForm.d.ts +103 -0
- package/dist/hooks/form/useForm.d.ts.map +1 -0
- package/dist/hooks/import/index.d.ts +100 -0
- package/dist/hooks/import/index.d.ts.map +1 -0
- package/dist/hooks/index.d.ts +25 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/invalidate/index.d.ts +9 -0
- package/dist/hooks/invalidate/index.d.ts.map +1 -0
- package/dist/hooks/legacy-router/index.d.ts +2 -0
- package/dist/hooks/legacy-router/index.d.ts.map +1 -0
- package/dist/hooks/legacy-router/useRouterContext.d.ts +10 -0
- package/dist/hooks/legacy-router/useRouterContext.d.ts.map +1 -0
- package/dist/hooks/live/index.d.ts +5 -0
- package/dist/hooks/live/index.d.ts.map +1 -0
- package/dist/hooks/live/useLiveMode/index.d.ts +3 -0
- package/dist/hooks/live/useLiveMode/index.d.ts.map +1 -0
- package/dist/hooks/live/usePublish/index.d.ts +3 -0
- package/dist/hooks/live/usePublish/index.d.ts.map +1 -0
- package/dist/hooks/live/useResourceSubscription/index.d.ts +34 -0
- package/dist/hooks/live/useResourceSubscription/index.d.ts.map +1 -0
- package/dist/hooks/live/useSubscription/index.d.ts +46 -0
- package/dist/hooks/live/useSubscription/index.d.ts.map +1 -0
- package/dist/hooks/memoized/index.d.ts +6 -0
- package/dist/hooks/memoized/index.d.ts.map +1 -0
- package/dist/hooks/menu/index.d.ts +2 -0
- package/dist/hooks/menu/index.d.ts.map +1 -0
- package/dist/hooks/menu/useMenu.d.ts +28 -0
- package/dist/hooks/menu/useMenu.d.ts.map +1 -0
- package/dist/hooks/modal/index.d.ts +2 -0
- package/dist/hooks/modal/index.d.ts.map +1 -0
- package/dist/hooks/modal/useModal/index.d.ts +13 -0
- package/dist/hooks/modal/useModal/index.d.ts.map +1 -0
- package/dist/hooks/navigation/index.d.ts +27 -0
- package/dist/hooks/navigation/index.d.ts.map +1 -0
- package/dist/hooks/notification/index.d.ts +4 -0
- package/dist/hooks/notification/index.d.ts.map +1 -0
- package/dist/hooks/notification/useCancelNotification/index.d.ts +8 -0
- package/dist/hooks/notification/useCancelNotification/index.d.ts.map +1 -0
- package/dist/hooks/notification/useHandleNotification/index.d.ts +3 -0
- package/dist/hooks/notification/useHandleNotification/index.d.ts.map +1 -0
- package/dist/hooks/notification/useNotification/index.d.ts +3 -0
- package/dist/hooks/notification/useNotification/index.d.ts.map +1 -0
- package/dist/hooks/redirection/index.d.ts +9 -0
- package/dist/hooks/redirection/index.d.ts.map +1 -0
- package/dist/hooks/refine/index.d.ts +6 -0
- package/dist/hooks/refine/index.d.ts.map +1 -0
- package/dist/hooks/refine/useMutationMode.d.ts +15 -0
- package/dist/hooks/refine/useMutationMode.d.ts.map +1 -0
- package/dist/hooks/refine/useRefineContext.d.ts +19 -0
- package/dist/hooks/refine/useRefineContext.d.ts.map +1 -0
- package/dist/hooks/refine/useSyncWithLocation.d.ts +13 -0
- package/dist/hooks/refine/useSyncWithLocation.d.ts.map +1 -0
- package/dist/hooks/refine/useTitle.d.ts +10 -0
- package/dist/hooks/refine/useTitle.d.ts.map +1 -0
- package/dist/hooks/refine/useWarnAboutChange/index.d.ts +15 -0
- package/dist/hooks/refine/useWarnAboutChange/index.d.ts.map +1 -0
- package/dist/hooks/resource/index.d.ts +3 -0
- package/dist/hooks/resource/index.d.ts.map +1 -0
- package/dist/hooks/resource/useResource/index.d.ts +45 -0
- package/dist/hooks/resource/useResource/index.d.ts.map +1 -0
- package/dist/hooks/resource/useResourceWithRoute/index.d.ts +8 -0
- package/dist/hooks/resource/useResourceWithRoute/index.d.ts.map +1 -0
- package/dist/hooks/router/index.d.ts +8 -0
- package/dist/hooks/router/index.d.ts.map +1 -0
- package/dist/hooks/router/use-back/index.d.ts +2 -0
- package/dist/hooks/router/use-back/index.d.ts.map +1 -0
- package/dist/hooks/router/use-get-to-path/index.d.ts +18 -0
- package/dist/hooks/router/use-get-to-path/index.d.ts.map +1 -0
- package/dist/hooks/router/use-go/index.d.ts +2 -0
- package/dist/hooks/router/use-go/index.d.ts.map +1 -0
- package/dist/hooks/router/use-link/index.d.ts +6 -0
- package/dist/hooks/router/use-link/index.d.ts.map +1 -0
- package/dist/hooks/router/use-parse/index.d.ts +3 -0
- package/dist/hooks/router/use-parse/index.d.ts.map +1 -0
- package/dist/hooks/router/use-parsed/index.d.ts +2 -0
- package/dist/hooks/router/use-parsed/index.d.ts.map +1 -0
- package/dist/hooks/router/use-router-misuse-warning/index.d.ts +3 -0
- package/dist/hooks/router/use-router-misuse-warning/index.d.ts.map +1 -0
- package/dist/hooks/router/use-to-path/index.d.ts +17 -0
- package/dist/hooks/router/use-to-path/index.d.ts.map +1 -0
- package/dist/hooks/show/index.d.ts +2 -0
- package/dist/hooks/show/index.d.ts.map +1 -0
- package/dist/hooks/show/useShow.d.ts +47 -0
- package/dist/hooks/show/useShow.d.ts.map +1 -0
- package/dist/hooks/translate/index.d.ts +4 -0
- package/dist/hooks/translate/index.d.ts.map +1 -0
- package/dist/hooks/translate/useGetLocale.d.ts +9 -0
- package/dist/hooks/translate/useGetLocale.d.ts.map +1 -0
- package/dist/hooks/translate/useSetLocale.d.ts +8 -0
- package/dist/hooks/translate/useSetLocale.d.ts.map +1 -0
- package/dist/hooks/translate/useTranslate.d.ts +11 -0
- package/dist/hooks/translate/useTranslate.d.ts.map +1 -0
- package/dist/hooks/useSelect/index.d.ts +100 -0
- package/dist/hooks/useSelect/index.d.ts.map +1 -0
- package/dist/hooks/useTable/index.d.ts +153 -0
- package/dist/hooks/useTable/index.d.ts.map +1 -0
- package/dist/hooks/useTelemetryData/index.d.ts +3 -0
- package/dist/hooks/useTelemetryData/index.d.ts.map +1 -0
- package/dist/iife/index.js +56 -0
- package/dist/iife/index.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +56 -0
- package/dist/index.js.map +1 -0
- package/dist/interfaces/HttpError.d.ts +5 -0
- package/dist/interfaces/HttpError.d.ts.map +1 -0
- package/dist/interfaces/actions.d.ts +10 -0
- package/dist/interfaces/actions.d.ts.map +1 -0
- package/dist/interfaces/auditLog/index.d.ts +2 -0
- package/dist/interfaces/auditLog/index.d.ts.map +1 -0
- package/dist/interfaces/auditLog/logData.d.ts +14 -0
- package/dist/interfaces/auditLog/logData.d.ts.map +1 -0
- package/dist/interfaces/auth.d.ts +158 -0
- package/dist/interfaces/auth.d.ts.map +1 -0
- package/dist/interfaces/bindings/access-control.d.ts +50 -0
- package/dist/interfaces/bindings/access-control.d.ts.map +1 -0
- package/dist/interfaces/bindings/auth.d.ts +66 -0
- package/dist/interfaces/bindings/auth.d.ts.map +1 -0
- package/dist/interfaces/bindings/data.d.ts +15 -0
- package/dist/interfaces/bindings/data.d.ts.map +1 -0
- package/dist/interfaces/bindings/i18n.d.ts +19 -0
- package/dist/interfaces/bindings/i18n.d.ts.map +1 -0
- package/dist/interfaces/bindings/index.d.ts +9 -0
- package/dist/interfaces/bindings/index.d.ts.map +1 -0
- package/dist/interfaces/bindings/live.d.ts +43 -0
- package/dist/interfaces/bindings/live.d.ts.map +1 -0
- package/dist/interfaces/bindings/notifications.d.ts +24 -0
- package/dist/interfaces/bindings/notifications.d.ts.map +1 -0
- package/dist/interfaces/bindings/resource.d.ts +150 -0
- package/dist/interfaces/bindings/resource.d.ts.map +1 -0
- package/dist/interfaces/bindings/router.d.ts +70 -0
- package/dist/interfaces/bindings/router.d.ts.map +1 -0
- package/dist/interfaces/customComponents.d.ts +26 -0
- package/dist/interfaces/customComponents.d.ts.map +1 -0
- package/dist/interfaces/form-url-params.d.ts +12 -0
- package/dist/interfaces/form-url-params.d.ts.map +1 -0
- package/dist/interfaces/index.d.ts +49 -0
- package/dist/interfaces/index.d.ts.map +1 -0
- package/dist/interfaces/live/LiveEvent.d.ts +11 -0
- package/dist/interfaces/live/LiveEvent.d.ts.map +1 -0
- package/dist/interfaces/live/LiveModeProps.d.ts +27 -0
- package/dist/interfaces/live/LiveModeProps.d.ts.map +1 -0
- package/dist/interfaces/live/index.d.ts +3 -0
- package/dist/interfaces/live/index.d.ts.map +1 -0
- package/dist/interfaces/mapDataFn.d.ts +4 -0
- package/dist/interfaces/mapDataFn.d.ts.map +1 -0
- package/dist/interfaces/metaData/fields.d.ts +3 -0
- package/dist/interfaces/metaData/fields.d.ts.map +1 -0
- package/dist/interfaces/metaData/index.d.ts +3 -0
- package/dist/interfaces/metaData/index.d.ts.map +1 -0
- package/dist/interfaces/metaData/metaDataQuery.d.ts +10 -0
- package/dist/interfaces/metaData/metaDataQuery.d.ts.map +1 -0
- package/dist/interfaces/metaData/metaQuery.d.ts +7 -0
- package/dist/interfaces/metaData/metaQuery.d.ts.map +1 -0
- package/dist/interfaces/metaData/nestedField.d.ts +8 -0
- package/dist/interfaces/metaData/nestedField.d.ts.map +1 -0
- package/dist/interfaces/metaData/queryBuilderOptions.d.ts +8 -0
- package/dist/interfaces/metaData/queryBuilderOptions.d.ts.map +1 -0
- package/dist/interfaces/metaData/variableOptions.d.ts +10 -0
- package/dist/interfaces/metaData/variableOptions.d.ts.map +1 -0
- package/dist/interfaces/mutationMode.d.ts +17 -0
- package/dist/interfaces/mutationMode.d.ts.map +1 -0
- package/dist/interfaces/notification.d.ts +11 -0
- package/dist/interfaces/notification.d.ts.map +1 -0
- package/dist/interfaces/prettify.d.ts +4 -0
- package/dist/interfaces/prettify.d.ts.map +1 -0
- package/dist/interfaces/queryKey.d.ts +17 -0
- package/dist/interfaces/queryKey.d.ts.map +1 -0
- package/dist/interfaces/resourceErrorRouterParams.d.ts +6 -0
- package/dist/interfaces/resourceErrorRouterParams.d.ts.map +1 -0
- package/dist/interfaces/resourceRouterParams.d.ts +7 -0
- package/dist/interfaces/resourceRouterParams.d.ts.map +1 -0
- package/dist/interfaces/successErrorNotification.d.ts +15 -0
- package/dist/interfaces/successErrorNotification.d.ts.map +1 -0
- package/dist/interfaces/telementry.d.ts +15 -0
- package/dist/interfaces/telementry.d.ts.map +1 -0
- package/package.json +67 -0
- package/refine.config.js +120 -0
- package/src/components/authenticated/index.tsx +202 -0
- package/src/components/canAccess/index.tsx +42 -0
- package/src/components/containers/index.ts +1 -0
- package/src/components/containers/refine/index.tsx +412 -0
- package/src/components/gh-banner/index.tsx +75 -0
- package/src/components/gh-banner/styles.ts +59 -0
- package/src/components/index.ts +9 -0
- package/src/components/layoutWrapper/defaultLayout/index.tsx +7 -0
- package/src/components/layoutWrapper/index.tsx +121 -0
- package/src/components/pages/auth/components/forgotPassword/index.tsx +122 -0
- package/src/components/pages/auth/components/index.ts +4 -0
- package/src/components/pages/auth/components/login/index.tsx +182 -0
- package/src/components/pages/auth/components/register/index.tsx +168 -0
- package/src/components/pages/auth/components/updatePassword/index.tsx +104 -0
- package/src/components/pages/auth/index.tsx +52 -0
- package/src/components/pages/error/index.tsx +64 -0
- package/src/components/pages/index.tsx +7 -0
- package/src/components/pages/login/index.tsx +91 -0
- package/src/components/pages/ready/index.tsx +39 -0
- package/src/components/pages/welcome/index.tsx +32 -0
- package/src/components/routeChangeHandler/index.tsx +16 -0
- package/src/components/telemetry/index.tsx +32 -0
- package/src/components/undoableQueue/index.tsx +68 -0
- package/src/contexts/accessControl/IAccessControlContext.ts +32 -0
- package/src/contexts/accessControl/index.tsx +22 -0
- package/src/contexts/auditLog/IAuditLogContext.ts +31 -0
- package/src/contexts/auditLog/index.tsx +17 -0
- package/src/contexts/auth/IAuthContext.ts +27 -0
- package/src/contexts/auth/index.tsx +203 -0
- package/src/contexts/data/IDataContext.ts +285 -0
- package/src/contexts/data/index.tsx +50 -0
- package/src/contexts/legacy-router/IRouterContext.ts +37 -0
- package/src/contexts/legacy-router/index.tsx +45 -0
- package/src/contexts/live/ILiveContext.ts +48 -0
- package/src/contexts/live/index.tsx +16 -0
- package/src/contexts/notification/INotificationContext.ts +15 -0
- package/src/contexts/notification/index.tsx +20 -0
- package/src/contexts/refine/IRefineContext.ts +116 -0
- package/src/contexts/refine/index.tsx +87 -0
- package/src/contexts/resource/IResourceContext.ts +68 -0
- package/src/contexts/resource/index.tsx +34 -0
- package/src/contexts/router/index.tsx +17 -0
- package/src/contexts/router-picker/index.tsx +21 -0
- package/src/contexts/translation/ITranslationContext.ts +19 -0
- package/src/contexts/translation/index.tsx +24 -0
- package/src/contexts/undoableQueue/IUndoableQueueContext.ts +6 -0
- package/src/contexts/undoableQueue/actionTypes.ts +5 -0
- package/src/contexts/undoableQueue/index.ts +5 -0
- package/src/contexts/undoableQueue/undoableQueueContext.tsx +83 -0
- package/src/contexts/unsavedWarn/IUnsavedWarnContext.ts +4 -0
- package/src/contexts/unsavedWarn/index.tsx +17 -0
- package/src/definitions/helpers/check-router-prop-misuse/index.ts +30 -0
- package/src/definitions/helpers/handleMultiple/index.ts +7 -0
- package/src/definitions/helpers/handlePaginationParams/index.ts +30 -0
- package/src/definitions/helpers/handleRefineOptions/index.ts +94 -0
- package/src/definitions/helpers/handleUseParams/index.tsx +9 -0
- package/src/definitions/helpers/hasPermission/index.ts +9 -0
- package/src/definitions/helpers/humanizeString/index.ts +14 -0
- package/src/definitions/helpers/importCSVMapper/index.ts +15 -0
- package/src/definitions/helpers/index.ts +25 -0
- package/src/definitions/helpers/legacy-resource-transform/index.ts +30 -0
- package/src/definitions/helpers/menu/create-resource-key.ts +33 -0
- package/src/definitions/helpers/menu/create-tree.ts +87 -0
- package/src/definitions/helpers/pick-resource/index.ts +40 -0
- package/src/definitions/helpers/pickDataProvider/index.ts +29 -0
- package/src/definitions/helpers/pickNotDeprecated/index.ts +9 -0
- package/src/definitions/helpers/queryKeys/index.ts +47 -0
- package/src/definitions/helpers/redirectPage/index.ts +28 -0
- package/src/definitions/helpers/routeGenerator/index.ts +29 -0
- package/src/definitions/helpers/router/__tests__/check-by-segments.ts +24 -0
- package/src/definitions/helpers/router/__tests__/compose-route.ts +42 -0
- package/src/definitions/helpers/router/__tests__/get-action-routes-from-resource.ts +169 -0
- package/src/definitions/helpers/router/__tests__/get-default-action-path.ts +47 -0
- package/src/definitions/helpers/router/__tests__/get-parent-prefix-for-resource.ts +84 -0
- package/src/definitions/helpers/router/__tests__/get-parent-resource.ts +51 -0
- package/src/definitions/helpers/router/__tests__/is-segment-counts-same.ts +21 -0
- package/src/definitions/helpers/router/__tests__/match-resource-from-route.ts +59 -0
- package/src/definitions/helpers/router/__tests__/pick-matched-route.ts +89 -0
- package/src/definitions/helpers/router/__tests__/pick-route-params.ts +18 -0
- package/src/definitions/helpers/router/__tests__/prepare-route-params.ts +23 -0
- package/src/definitions/helpers/router/__tests__/remove-leading-trailing-slashes.ts +15 -0
- package/src/definitions/helpers/router/__tests__/split-to-segments.ts +15 -0
- package/src/definitions/helpers/router/check-by-segments.ts +28 -0
- package/src/definitions/helpers/router/compose-route.ts +30 -0
- package/src/definitions/helpers/router/get-action-routes-from-resource.ts +71 -0
- package/src/definitions/helpers/router/get-default-action-path.ts +33 -0
- package/src/definitions/helpers/router/get-parent-prefix-for-resource.ts +39 -0
- package/src/definitions/helpers/router/get-parent-resource.ts +31 -0
- package/src/definitions/helpers/router/index.ts +10 -0
- package/src/definitions/helpers/router/is-parameter.ts +6 -0
- package/src/definitions/helpers/router/is-segment-counts-same.ts +11 -0
- package/src/definitions/helpers/router/match-resource-from-route.ts +37 -0
- package/src/definitions/helpers/router/pick-matched-route.ts +61 -0
- package/src/definitions/helpers/router/pick-route-params.ts +19 -0
- package/src/definitions/helpers/router/prepare-route-params.ts +32 -0
- package/src/definitions/helpers/router/remove-leading-trailing-slashes.ts +6 -0
- package/src/definitions/helpers/router/split-to-segments.ts +7 -0
- package/src/definitions/helpers/sanitize-resource/index.ts +31 -0
- package/src/definitions/helpers/sequentialPromises/index.ts +32 -0
- package/src/definitions/helpers/treeView/createTreeView/index.ts +44 -0
- package/src/definitions/helpers/treeView/index.ts +1 -0
- package/src/definitions/helpers/useActiveAuthProvider/index.ts +30 -0
- package/src/definitions/helpers/useInfinitePagination/index.ts +30 -0
- package/src/definitions/helpers/userFriendlyResourceName/index.ts +17 -0
- package/src/definitions/helpers/userFriendlySeconds/index.ts +3 -0
- package/src/definitions/index.ts +3 -0
- package/src/definitions/table/__snapshots__/index.spec.ts.snap +7 -0
- package/src/definitions/table/index.ts +192 -0
- package/src/definitions/upload/file2Base64/index.ts +21 -0
- package/src/definitions/upload/index.ts +1 -0
- package/src/hooks/accessControl/index.ts +2 -0
- package/src/hooks/accessControl/useCan/index.ts +69 -0
- package/src/hooks/accessControl/useCanWithoutCache.ts +10 -0
- package/src/hooks/auditLog/index.ts +2 -0
- package/src/hooks/auditLog/useLog/index.ts +139 -0
- package/src/hooks/auditLog/useLogList/index.ts +55 -0
- package/src/hooks/auth/index.ts +10 -0
- package/src/hooks/auth/useForgotPassword/index.ts +174 -0
- package/src/hooks/auth/useGetIdentity/index.ts +92 -0
- package/src/hooks/auth/useInvaliteAuthStore/index.ts +13 -0
- package/src/hooks/auth/useIsAuthenticated/index.ts +80 -0
- package/src/hooks/auth/useIsExistAuthentication/index.ts +12 -0
- package/src/hooks/auth/useLogin/index.ts +220 -0
- package/src/hooks/auth/useLogout/index.ts +199 -0
- package/src/hooks/auth/useOnError/index.ts +110 -0
- package/src/hooks/auth/usePermissions/index.ts +87 -0
- package/src/hooks/auth/useRegister/index.ts +186 -0
- package/src/hooks/auth/useUpdatePassword/index.ts +215 -0
- package/src/hooks/breadcrumb/index.ts +126 -0
- package/src/hooks/data/index.ts +18 -0
- package/src/hooks/data/useApiUrl.ts +9 -0
- package/src/hooks/data/useCreate.ts +258 -0
- package/src/hooks/data/useCreateMany.ts +239 -0
- package/src/hooks/data/useCustom.ts +177 -0
- package/src/hooks/data/useCustomMutation.ts +188 -0
- package/src/hooks/data/useDataProvider.tsx +39 -0
- package/src/hooks/data/useDelete.ts +415 -0
- package/src/hooks/data/useDeleteMany.ts +442 -0
- package/src/hooks/data/useInfiniteList.ts +290 -0
- package/src/hooks/data/useList.ts +300 -0
- package/src/hooks/data/useMany.ts +202 -0
- package/src/hooks/data/useOne.ts +205 -0
- package/src/hooks/data/useUpdate.ts +488 -0
- package/src/hooks/data/useUpdateMany.ts +496 -0
- package/src/hooks/deepMemo/index.tsx +17 -0
- package/src/hooks/export/csvDownload.interface.ts +27 -0
- package/src/hooks/export/index.ts +189 -0
- package/src/hooks/form/index.ts +1 -0
- package/src/hooks/form/useForm.ts +524 -0
- package/src/hooks/import/index.tsx +336 -0
- package/src/hooks/index.ts +24 -0
- package/src/hooks/invalidate/index.tsx +62 -0
- package/src/hooks/legacy-router/index.ts +1 -0
- package/src/hooks/legacy-router/useRouterContext.ts +18 -0
- package/src/hooks/live/index.ts +4 -0
- package/src/hooks/live/useLiveMode/index.ts +12 -0
- package/src/hooks/live/usePublish/index.ts +10 -0
- package/src/hooks/live/useResourceSubscription/index.ts +99 -0
- package/src/hooks/live/useSubscription/index.ts +85 -0
- package/src/hooks/memoized/index.tsx +16 -0
- package/src/hooks/menu/index.ts +1 -0
- package/src/hooks/menu/useMenu.tsx +153 -0
- package/src/hooks/modal/index.ts +1 -0
- package/src/hooks/modal/useModal/index.tsx +29 -0
- package/src/hooks/navigation/index.ts +385 -0
- package/src/hooks/notification/index.ts +3 -0
- package/src/hooks/notification/useCancelNotification/index.tsx +16 -0
- package/src/hooks/notification/useHandleNotification/index.ts +26 -0
- package/src/hooks/notification/useNotification/index.ts +10 -0
- package/src/hooks/redirection/index.ts +56 -0
- package/src/hooks/refine/index.ts +5 -0
- package/src/hooks/refine/useMutationMode.ts +22 -0
- package/src/hooks/refine/useRefineContext.ts +41 -0
- package/src/hooks/refine/useSyncWithLocation.ts +20 -0
- package/src/hooks/refine/useTitle.tsx +15 -0
- package/src/hooks/refine/useWarnAboutChange/index.ts +32 -0
- package/src/hooks/resource/index.ts +2 -0
- package/src/hooks/resource/useResource/index.ts +151 -0
- package/src/hooks/resource/useResourceWithRoute/index.ts +27 -0
- package/src/hooks/router/index.ts +7 -0
- package/src/hooks/router/use-back/index.tsx +15 -0
- package/src/hooks/router/use-get-to-path/index.ts +60 -0
- package/src/hooks/router/use-go/index.tsx +15 -0
- package/src/hooks/router/use-link/index.tsx +17 -0
- package/src/hooks/router/use-parse/index.tsx +21 -0
- package/src/hooks/router/use-parsed/index.tsx +10 -0
- package/src/hooks/router/use-router-misuse-warning/index.ts +18 -0
- package/src/hooks/router/use-to-path/index.ts +27 -0
- package/src/hooks/show/index.ts +1 -0
- package/src/hooks/show/useShow.ts +183 -0
- package/src/hooks/translate/index.ts +3 -0
- package/src/hooks/translate/useGetLocale.ts +16 -0
- package/src/hooks/translate/useSetLocale.ts +14 -0
- package/src/hooks/translate/useTranslate.ts +40 -0
- package/src/hooks/useSelect/index.ts +280 -0
- package/src/hooks/useTable/index.ts +544 -0
- package/src/hooks/useTelemetryData/index.ts +73 -0
- package/src/index.tsx +120 -0
- package/src/interfaces/HttpError.ts +4 -0
- package/src/interfaces/actions.ts +16 -0
- package/src/interfaces/auditLog/index.ts +1 -0
- package/src/interfaces/auditLog/logData.ts +15 -0
- package/src/interfaces/auth.tsx +192 -0
- package/src/interfaces/bindings/access-control.ts +53 -0
- package/src/interfaces/bindings/auth.ts +72 -0
- package/src/interfaces/bindings/data.ts +18 -0
- package/src/interfaces/bindings/i18n.ts +29 -0
- package/src/interfaces/bindings/index.ts +24 -0
- package/src/interfaces/bindings/live.ts +56 -0
- package/src/interfaces/bindings/notifications.ts +25 -0
- package/src/interfaces/bindings/resource.ts +178 -0
- package/src/interfaces/bindings/router.ts +73 -0
- package/src/interfaces/customComponents.ts +28 -0
- package/src/interfaces/form-url-params.ts +8 -0
- package/src/interfaces/index.ts +86 -0
- package/src/interfaces/live/LiveEvent.ts +11 -0
- package/src/interfaces/live/LiveModeProps.ts +28 -0
- package/src/interfaces/live/index.ts +2 -0
- package/src/interfaces/mapDataFn.ts +3 -0
- package/src/interfaces/metaData/fields.ts +3 -0
- package/src/interfaces/metaData/index.ts +2 -0
- package/src/interfaces/metaData/metaDataQuery.ts +10 -0
- package/src/interfaces/metaData/metaQuery.ts +7 -0
- package/src/interfaces/metaData/nestedField.ts +8 -0
- package/src/interfaces/metaData/queryBuilderOptions.ts +8 -0
- package/src/interfaces/metaData/variableOptions.ts +9 -0
- package/src/interfaces/mutationMode.ts +29 -0
- package/src/interfaces/notification.ts +10 -0
- package/src/interfaces/prettify.ts +3 -0
- package/src/interfaces/queryKey.ts +23 -0
- package/src/interfaces/resourceErrorRouterParams.ts +6 -0
- package/src/interfaces/resourceRouterParams.ts +7 -0
- package/src/interfaces/successErrorNotification.ts +33 -0
- package/src/interfaces/telementry.ts +14 -0
- package/tsconfig.json +28 -0
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
import { getActionRoutesFromResource } from "../get-action-routes-from-resource";
|
|
2
|
+
|
|
3
|
+
describe("getActionRoutesFromResource", () => {
|
|
4
|
+
it("should return empty array if no actions are found", () => {
|
|
5
|
+
const result = getActionRoutesFromResource(
|
|
6
|
+
{
|
|
7
|
+
name: "users",
|
|
8
|
+
meta: {},
|
|
9
|
+
},
|
|
10
|
+
[],
|
|
11
|
+
);
|
|
12
|
+
|
|
13
|
+
expect(result).toEqual([]);
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
it("should return the default routes for a given resource", () => {
|
|
17
|
+
const result = getActionRoutesFromResource(
|
|
18
|
+
{
|
|
19
|
+
name: "users",
|
|
20
|
+
meta: {},
|
|
21
|
+
list: () => null,
|
|
22
|
+
create: () => null,
|
|
23
|
+
edit: () => null,
|
|
24
|
+
show: () => null,
|
|
25
|
+
clone: () => null,
|
|
26
|
+
},
|
|
27
|
+
[],
|
|
28
|
+
);
|
|
29
|
+
|
|
30
|
+
expect(result).toEqual(
|
|
31
|
+
expect.arrayContaining([
|
|
32
|
+
expect.objectContaining({
|
|
33
|
+
action: "list",
|
|
34
|
+
route: "/users",
|
|
35
|
+
}),
|
|
36
|
+
expect.objectContaining({
|
|
37
|
+
action: "create",
|
|
38
|
+
route: "/users/create",
|
|
39
|
+
}),
|
|
40
|
+
expect.objectContaining({
|
|
41
|
+
action: "edit",
|
|
42
|
+
route: "/users/edit/:id",
|
|
43
|
+
}),
|
|
44
|
+
expect.objectContaining({
|
|
45
|
+
action: "show",
|
|
46
|
+
route: "/users/show/:id",
|
|
47
|
+
}),
|
|
48
|
+
expect.objectContaining({
|
|
49
|
+
action: "clone",
|
|
50
|
+
route: "/users/clone/:id",
|
|
51
|
+
}),
|
|
52
|
+
]),
|
|
53
|
+
);
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
it("should return the default routes for a given resource with parent prefix [legacy]", () => {
|
|
57
|
+
const result = getActionRoutesFromResource(
|
|
58
|
+
{
|
|
59
|
+
name: "users",
|
|
60
|
+
meta: {
|
|
61
|
+
parent: "orgs",
|
|
62
|
+
},
|
|
63
|
+
edit: () => null,
|
|
64
|
+
},
|
|
65
|
+
[],
|
|
66
|
+
true,
|
|
67
|
+
);
|
|
68
|
+
|
|
69
|
+
expect(result).toEqual(
|
|
70
|
+
expect.arrayContaining([
|
|
71
|
+
expect.objectContaining({
|
|
72
|
+
action: "edit",
|
|
73
|
+
route: "/orgs/users/edit/:id",
|
|
74
|
+
}),
|
|
75
|
+
]),
|
|
76
|
+
);
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
it("should return the default routes for a given resource without parent prefix", () => {
|
|
80
|
+
const result = getActionRoutesFromResource(
|
|
81
|
+
{
|
|
82
|
+
name: "users",
|
|
83
|
+
meta: {
|
|
84
|
+
parent: "orgs",
|
|
85
|
+
},
|
|
86
|
+
edit: () => null,
|
|
87
|
+
},
|
|
88
|
+
[],
|
|
89
|
+
);
|
|
90
|
+
|
|
91
|
+
expect(result).toEqual(
|
|
92
|
+
expect.arrayContaining([
|
|
93
|
+
expect.objectContaining({
|
|
94
|
+
action: "edit",
|
|
95
|
+
route: "/users/edit/:id",
|
|
96
|
+
}),
|
|
97
|
+
]),
|
|
98
|
+
);
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
it("should not include parent prefix if route is explicitly defined", () => {
|
|
102
|
+
const result = getActionRoutesFromResource(
|
|
103
|
+
{
|
|
104
|
+
name: "users",
|
|
105
|
+
meta: {
|
|
106
|
+
parent: "orgs",
|
|
107
|
+
},
|
|
108
|
+
edit: {
|
|
109
|
+
path: "edit/:id",
|
|
110
|
+
component: () => null,
|
|
111
|
+
},
|
|
112
|
+
},
|
|
113
|
+
[],
|
|
114
|
+
);
|
|
115
|
+
|
|
116
|
+
expect(result).toEqual(
|
|
117
|
+
expect.arrayContaining([
|
|
118
|
+
expect.objectContaining({
|
|
119
|
+
action: "edit",
|
|
120
|
+
route: "/edit/:id",
|
|
121
|
+
}),
|
|
122
|
+
]),
|
|
123
|
+
);
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
it("should use deprecated route prop if legacy is set to true", () => {
|
|
127
|
+
const result = getActionRoutesFromResource(
|
|
128
|
+
{
|
|
129
|
+
name: "users",
|
|
130
|
+
parentName: "orgs",
|
|
131
|
+
options: {
|
|
132
|
+
route: "custom-users",
|
|
133
|
+
},
|
|
134
|
+
list: () => null,
|
|
135
|
+
},
|
|
136
|
+
[],
|
|
137
|
+
true,
|
|
138
|
+
);
|
|
139
|
+
|
|
140
|
+
expect(result).toEqual(
|
|
141
|
+
expect.arrayContaining([
|
|
142
|
+
expect.objectContaining({
|
|
143
|
+
action: "list",
|
|
144
|
+
route: "/orgs/custom-users",
|
|
145
|
+
}),
|
|
146
|
+
]),
|
|
147
|
+
);
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
it("should use the specific route instead of the default one with no component", () => {
|
|
151
|
+
const result = getActionRoutesFromResource(
|
|
152
|
+
{
|
|
153
|
+
name: "users",
|
|
154
|
+
meta: {},
|
|
155
|
+
list: "/super-cool-nesting/users/list",
|
|
156
|
+
},
|
|
157
|
+
[],
|
|
158
|
+
);
|
|
159
|
+
|
|
160
|
+
expect(result).toEqual(
|
|
161
|
+
expect.arrayContaining([
|
|
162
|
+
expect.objectContaining({
|
|
163
|
+
action: "list",
|
|
164
|
+
route: "/super-cool-nesting/users/list",
|
|
165
|
+
}),
|
|
166
|
+
]),
|
|
167
|
+
);
|
|
168
|
+
});
|
|
169
|
+
});
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { getDefaultActionPath } from "../get-default-action-path";
|
|
2
|
+
|
|
3
|
+
describe("getDefaultActionPath", () => {
|
|
4
|
+
it("should return the default path for a given action and resource", () => {
|
|
5
|
+
expect(getDefaultActionPath("users", "list")).toBe("/users");
|
|
6
|
+
expect(getDefaultActionPath("users", "create")).toBe("/users/create");
|
|
7
|
+
expect(getDefaultActionPath("users", "edit")).toBe("/users/edit/:id");
|
|
8
|
+
expect(getDefaultActionPath("users", "show")).toBe("/users/show/:id");
|
|
9
|
+
expect(getDefaultActionPath("users", "clone")).toBe("/users/clone/:id");
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
it("should return the default path for a given action and resource with parent prefix", () => {
|
|
13
|
+
expect(getDefaultActionPath("users", "list", "/orgs")).toBe(
|
|
14
|
+
"/orgs/users",
|
|
15
|
+
);
|
|
16
|
+
expect(getDefaultActionPath("users", "create", "/orgs")).toBe(
|
|
17
|
+
"/orgs/users/create",
|
|
18
|
+
);
|
|
19
|
+
expect(getDefaultActionPath("users", "edit", "/orgs")).toBe(
|
|
20
|
+
"/orgs/users/edit/:id",
|
|
21
|
+
);
|
|
22
|
+
expect(getDefaultActionPath("users", "show", "/orgs")).toBe(
|
|
23
|
+
"/orgs/users/show/:id",
|
|
24
|
+
);
|
|
25
|
+
expect(getDefaultActionPath("users", "clone", "/orgs")).toBe(
|
|
26
|
+
"/orgs/users/clone/:id",
|
|
27
|
+
);
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
it("should return the default path for a given action and resource with multiple parent prefixes", () => {
|
|
31
|
+
expect(getDefaultActionPath("users", "list", "/orgs/posts")).toBe(
|
|
32
|
+
"/orgs/posts/users",
|
|
33
|
+
);
|
|
34
|
+
expect(getDefaultActionPath("users", "create", "/orgs/posts")).toBe(
|
|
35
|
+
"/orgs/posts/users/create",
|
|
36
|
+
);
|
|
37
|
+
expect(getDefaultActionPath("users", "edit", "/orgs/posts")).toBe(
|
|
38
|
+
"/orgs/posts/users/edit/:id",
|
|
39
|
+
);
|
|
40
|
+
expect(getDefaultActionPath("users", "show", "/orgs/posts")).toBe(
|
|
41
|
+
"/orgs/posts/users/show/:id",
|
|
42
|
+
);
|
|
43
|
+
expect(getDefaultActionPath("users", "clone", "/orgs/posts")).toBe(
|
|
44
|
+
"/orgs/posts/users/clone/:id",
|
|
45
|
+
);
|
|
46
|
+
});
|
|
47
|
+
});
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { getParentPrefixForResource } from "../get-parent-prefix-for-resource";
|
|
2
|
+
|
|
3
|
+
describe("getParentPrefixForResource", () => {
|
|
4
|
+
it("should return undefined if no parent is found", () => {
|
|
5
|
+
const resources = [
|
|
6
|
+
{
|
|
7
|
+
name: "users",
|
|
8
|
+
},
|
|
9
|
+
];
|
|
10
|
+
|
|
11
|
+
expect(getParentPrefixForResource(resources[0], resources)).toBe(
|
|
12
|
+
undefined,
|
|
13
|
+
);
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
it("should return the parent prefix", () => {
|
|
17
|
+
const resources = [
|
|
18
|
+
{
|
|
19
|
+
name: "users",
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
name: "posts",
|
|
23
|
+
meta: {
|
|
24
|
+
parent: "users",
|
|
25
|
+
},
|
|
26
|
+
},
|
|
27
|
+
];
|
|
28
|
+
|
|
29
|
+
expect(getParentPrefixForResource(resources[1], resources)).toBe(
|
|
30
|
+
"/users",
|
|
31
|
+
);
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
it("should return the parent prefix for deeply nested resources", () => {
|
|
35
|
+
const resources = [
|
|
36
|
+
{
|
|
37
|
+
name: "users",
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
name: "posts",
|
|
41
|
+
meta: {
|
|
42
|
+
parent: "users",
|
|
43
|
+
},
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
name: "comments",
|
|
47
|
+
meta: {
|
|
48
|
+
parent: "posts",
|
|
49
|
+
},
|
|
50
|
+
},
|
|
51
|
+
];
|
|
52
|
+
|
|
53
|
+
expect(getParentPrefixForResource(resources[2], resources)).toBe(
|
|
54
|
+
"/users/posts",
|
|
55
|
+
);
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
it("should return the parent prefix for deeply nested resources with legacy routes", () => {
|
|
59
|
+
const resources = [
|
|
60
|
+
{
|
|
61
|
+
name: "users",
|
|
62
|
+
options: {
|
|
63
|
+
route: "custom-users",
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
name: "posts",
|
|
68
|
+
meta: {
|
|
69
|
+
parent: "users",
|
|
70
|
+
},
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
name: "comments",
|
|
74
|
+
meta: {
|
|
75
|
+
parent: "posts",
|
|
76
|
+
},
|
|
77
|
+
},
|
|
78
|
+
];
|
|
79
|
+
|
|
80
|
+
expect(getParentPrefixForResource(resources[2], resources, true)).toBe(
|
|
81
|
+
"/custom-users/posts",
|
|
82
|
+
);
|
|
83
|
+
});
|
|
84
|
+
});
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { getParentResource } from "../get-parent-resource";
|
|
2
|
+
|
|
3
|
+
describe("getParentResource", () => {
|
|
4
|
+
it("should return undefined if no parent is given", () => {
|
|
5
|
+
const result = getParentResource(
|
|
6
|
+
{
|
|
7
|
+
name: "users",
|
|
8
|
+
meta: {},
|
|
9
|
+
},
|
|
10
|
+
[],
|
|
11
|
+
);
|
|
12
|
+
|
|
13
|
+
expect(result).toEqual(undefined);
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
it("should return the parent resource if parent is given", () => {
|
|
17
|
+
const result = getParentResource(
|
|
18
|
+
{
|
|
19
|
+
name: "users",
|
|
20
|
+
meta: {
|
|
21
|
+
parent: "orgs",
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
[
|
|
25
|
+
{
|
|
26
|
+
name: "orgs",
|
|
27
|
+
},
|
|
28
|
+
],
|
|
29
|
+
);
|
|
30
|
+
|
|
31
|
+
expect(result).toEqual({
|
|
32
|
+
name: "orgs",
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
it("should return the parent resource if parent is given even if the parent is not defined", () => {
|
|
37
|
+
const result = getParentResource(
|
|
38
|
+
{
|
|
39
|
+
name: "users",
|
|
40
|
+
options: {
|
|
41
|
+
parent: "orgs",
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
[],
|
|
45
|
+
);
|
|
46
|
+
|
|
47
|
+
expect(result).toEqual({
|
|
48
|
+
name: "orgs",
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
});
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { isSegmentCountsSame } from "../is-segment-counts-same";
|
|
2
|
+
|
|
3
|
+
describe("isSegmentCountsSame", () => {
|
|
4
|
+
it("should return true if the route and resourceRoute have the same number of segments", () => {
|
|
5
|
+
const result = isSegmentCountsSame(
|
|
6
|
+
"/users/edit/123",
|
|
7
|
+
"/users/edit/:id",
|
|
8
|
+
);
|
|
9
|
+
|
|
10
|
+
expect(result).toEqual(true);
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
it("should return false if the route and resourceRoute don't have the same number of segments", () => {
|
|
14
|
+
const result = isSegmentCountsSame(
|
|
15
|
+
"/users/edit/123",
|
|
16
|
+
"users/posts/edit/:id/",
|
|
17
|
+
);
|
|
18
|
+
|
|
19
|
+
expect(result).toEqual(false);
|
|
20
|
+
});
|
|
21
|
+
});
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { matchResourceFromRoute } from "../match-resource-from-route";
|
|
2
|
+
|
|
3
|
+
describe("matchResourceFromRoute", () => {
|
|
4
|
+
it("should return found false if no resource is given", () => {
|
|
5
|
+
const result = matchResourceFromRoute("/users", []);
|
|
6
|
+
|
|
7
|
+
expect(result.found).toEqual(false);
|
|
8
|
+
});
|
|
9
|
+
|
|
10
|
+
it("should return found false if no route is given", () => {
|
|
11
|
+
const result = matchResourceFromRoute("", [
|
|
12
|
+
{
|
|
13
|
+
name: "users",
|
|
14
|
+
edit: {
|
|
15
|
+
path: "/users/edit/:id",
|
|
16
|
+
component: () => null,
|
|
17
|
+
},
|
|
18
|
+
},
|
|
19
|
+
]);
|
|
20
|
+
|
|
21
|
+
expect(result.found).toEqual(false);
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
it("should return found true if route is found", () => {
|
|
25
|
+
const result = matchResourceFromRoute("/users/edit/123", [
|
|
26
|
+
{
|
|
27
|
+
name: "users",
|
|
28
|
+
edit: {
|
|
29
|
+
path: "/users/edit/:id",
|
|
30
|
+
component: () => null,
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
]);
|
|
34
|
+
|
|
35
|
+
expect(result.found).toEqual(true);
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
it("should return the best one if multiple routes are found", () => {
|
|
39
|
+
const result = matchResourceFromRoute("/users/orgs/edit/123", [
|
|
40
|
+
{
|
|
41
|
+
name: "users",
|
|
42
|
+
edit: {
|
|
43
|
+
path: "/users/:type/edit/:id",
|
|
44
|
+
component: () => null,
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
name: "org-users",
|
|
49
|
+
edit: {
|
|
50
|
+
path: "/users/orgs/edit/:id",
|
|
51
|
+
component: () => null,
|
|
52
|
+
},
|
|
53
|
+
},
|
|
54
|
+
]);
|
|
55
|
+
|
|
56
|
+
expect(result.found).toEqual(true);
|
|
57
|
+
expect(result.matchedRoute).toEqual("/users/orgs/edit/:id");
|
|
58
|
+
});
|
|
59
|
+
});
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { pickMatchedRoute } from "../pick-matched-route";
|
|
2
|
+
|
|
3
|
+
describe("pickMatchedRoute", () => {
|
|
4
|
+
it("should return the route with no params", () => {
|
|
5
|
+
const routes = [
|
|
6
|
+
{
|
|
7
|
+
route: "/users/edit/123",
|
|
8
|
+
action: "edit" as const,
|
|
9
|
+
resource: { name: "users" },
|
|
10
|
+
},
|
|
11
|
+
{
|
|
12
|
+
route: "users/:action/:id/",
|
|
13
|
+
action: "edit" as const,
|
|
14
|
+
resource: { name: "users" },
|
|
15
|
+
},
|
|
16
|
+
{
|
|
17
|
+
route: "/users/:action/:id",
|
|
18
|
+
action: "edit" as const,
|
|
19
|
+
resource: { name: "users" },
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
route: "/users/edit/:id",
|
|
23
|
+
action: "edit" as const,
|
|
24
|
+
resource: { name: "users" },
|
|
25
|
+
},
|
|
26
|
+
];
|
|
27
|
+
|
|
28
|
+
const picked = pickMatchedRoute(routes);
|
|
29
|
+
|
|
30
|
+
expect(picked?.route).toEqual("/users/edit/123");
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
it("should return the route with least params", () => {
|
|
34
|
+
const routes = [
|
|
35
|
+
{
|
|
36
|
+
route: "/users/:action/:id",
|
|
37
|
+
action: "edit" as const,
|
|
38
|
+
resource: { name: "users" },
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
route: "/users/edit/:id",
|
|
42
|
+
action: "edit" as const,
|
|
43
|
+
resource: { name: "users" },
|
|
44
|
+
},
|
|
45
|
+
];
|
|
46
|
+
|
|
47
|
+
const picked = pickMatchedRoute(routes);
|
|
48
|
+
|
|
49
|
+
expect(picked?.route).toEqual("/users/edit/:id");
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
it("should return the latest parametrized route", () => {
|
|
53
|
+
const routes = [
|
|
54
|
+
{
|
|
55
|
+
route: "/users/page/:action/:id",
|
|
56
|
+
action: "edit" as const,
|
|
57
|
+
resource: { name: "users" },
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
route: "/users/page/list/:id/",
|
|
61
|
+
action: "edit" as const,
|
|
62
|
+
resource: { name: "users" },
|
|
63
|
+
},
|
|
64
|
+
];
|
|
65
|
+
|
|
66
|
+
const picked = pickMatchedRoute(routes);
|
|
67
|
+
|
|
68
|
+
expect(picked?.route).toEqual("/users/page/list/:id/");
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
it("should return the latest parametrized route with single", () => {
|
|
72
|
+
const routes = [
|
|
73
|
+
{
|
|
74
|
+
route: "/users/:org/list/123",
|
|
75
|
+
action: "edit" as const,
|
|
76
|
+
resource: { name: "users" },
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
route: "/users/refine/list/:id",
|
|
80
|
+
action: "edit" as const,
|
|
81
|
+
resource: { name: "users" },
|
|
82
|
+
},
|
|
83
|
+
];
|
|
84
|
+
|
|
85
|
+
const picked = pickMatchedRoute(routes);
|
|
86
|
+
|
|
87
|
+
expect(picked?.route).toEqual("/users/refine/list/:id");
|
|
88
|
+
});
|
|
89
|
+
});
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { pickRouteParams } from "../pick-route-params";
|
|
2
|
+
|
|
3
|
+
describe("pickRouteParams", () => {
|
|
4
|
+
it("should extract route params from a path", () => {
|
|
5
|
+
expect(pickRouteParams("/users/:id/posts/:postId")).toEqual([
|
|
6
|
+
"id",
|
|
7
|
+
"postId",
|
|
8
|
+
]);
|
|
9
|
+
});
|
|
10
|
+
|
|
11
|
+
it("should return an empty array if no route params are given", () => {
|
|
12
|
+
expect(pickRouteParams("/users/list")).toEqual([]);
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
it("should extract route params from a path", () => {
|
|
16
|
+
expect(pickRouteParams("users/:id")).toEqual(["id"]);
|
|
17
|
+
});
|
|
18
|
+
});
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { prepareRouteParams } from "../prepare-route-params";
|
|
2
|
+
|
|
3
|
+
describe("prepareRouteParams", () => {
|
|
4
|
+
it("should return an empty object if no route params are given", () => {
|
|
5
|
+
expect(prepareRouteParams([])).toEqual({});
|
|
6
|
+
});
|
|
7
|
+
|
|
8
|
+
it("should return `id` property when params array contains `id`", () => {
|
|
9
|
+
expect(prepareRouteParams(["id"], { id: "1" })).toEqual({ id: "1" });
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
it("should prioritize meta over params", () => {
|
|
13
|
+
expect(prepareRouteParams(["id"], { id: "1" }, { id: "2" })).toEqual({
|
|
14
|
+
id: "2",
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
it("should combine params and meta", () => {
|
|
19
|
+
expect(
|
|
20
|
+
prepareRouteParams(["id", "action"], { id: "1" }, { action: "2" }),
|
|
21
|
+
).toEqual({ id: "1", action: "2" });
|
|
22
|
+
});
|
|
23
|
+
});
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { removeLeadingTrailingSlashes } from "../remove-leading-trailing-slashes";
|
|
2
|
+
|
|
3
|
+
describe("removeLeadingTrailingSlashes", () => {
|
|
4
|
+
it("should remove leading and trailing slashes", () => {
|
|
5
|
+
expect(removeLeadingTrailingSlashes("/a/b/c")).toEqual("a/b/c");
|
|
6
|
+
});
|
|
7
|
+
|
|
8
|
+
it("should remove leading and trailing slashes", () => {
|
|
9
|
+
expect(removeLeadingTrailingSlashes("a/b/c")).toEqual("a/b/c");
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
it("should remove leading and trailing slashes", () => {
|
|
13
|
+
expect(removeLeadingTrailingSlashes("/a/b/c/")).toEqual("a/b/c");
|
|
14
|
+
});
|
|
15
|
+
});
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { splitToSegments } from "../split-to-segments";
|
|
2
|
+
|
|
3
|
+
describe("splitToSegments", () => {
|
|
4
|
+
it("should split a path to segments", () => {
|
|
5
|
+
expect(splitToSegments("/a/b/c")).toEqual(["a", "b", "c"]);
|
|
6
|
+
});
|
|
7
|
+
|
|
8
|
+
it("should split a path to segments", () => {
|
|
9
|
+
expect(splitToSegments("a/b/c")).toEqual(["a", "b", "c"]);
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
it("should split a path to segments", () => {
|
|
13
|
+
expect(splitToSegments("/a/b/c/")).toEqual(["a", "b", "c"]);
|
|
14
|
+
});
|
|
15
|
+
});
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { isParameter } from "./is-parameter";
|
|
2
|
+
import { isSegmentCountsSame } from "./is-segment-counts-same";
|
|
3
|
+
import { removeLeadingTrailingSlashes } from "./remove-leading-trailing-slashes";
|
|
4
|
+
import { splitToSegments } from "./split-to-segments";
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* This function if the route and resourceRoute match by segments.
|
|
8
|
+
* - First, trailing and leading slashes are removed
|
|
9
|
+
* - Then, the route and resourceRoute are split to segments and checked if they have the same number of segments
|
|
10
|
+
* - Then, each segment is checked if it is a parameter or if it matches the resourceRoute segment
|
|
11
|
+
* - If all segments match, the function returns true, otherwise false
|
|
12
|
+
*/
|
|
13
|
+
export const checkBySegments = (route: string, resourceRoute: string) => {
|
|
14
|
+
const stdRoute = removeLeadingTrailingSlashes(route);
|
|
15
|
+
const stdResourceRoute = removeLeadingTrailingSlashes(resourceRoute);
|
|
16
|
+
// we need to check if the route and resourceRoute have the same number of segments
|
|
17
|
+
// if not, we can't match them
|
|
18
|
+
if (!isSegmentCountsSame(stdRoute, stdResourceRoute)) {
|
|
19
|
+
return false;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
const routeSegments = splitToSegments(stdRoute);
|
|
23
|
+
const resourceRouteSegments = splitToSegments(stdResourceRoute);
|
|
24
|
+
|
|
25
|
+
return resourceRouteSegments.every((segment, index) => {
|
|
26
|
+
return isParameter(segment) || segment === routeSegments[index];
|
|
27
|
+
});
|
|
28
|
+
};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { MetaDataQuery, ParseResponse } from "../../../interfaces";
|
|
2
|
+
|
|
3
|
+
import { pickRouteParams } from "./pick-route-params";
|
|
4
|
+
import { prepareRouteParams } from "./prepare-route-params";
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* This function will compose a route with the given params and meta.
|
|
8
|
+
* - A route can have parameters like (eg: /users/:id)
|
|
9
|
+
* - First we pick the route params from the route (eg: [id])
|
|
10
|
+
* - Then we prepare the route params with the given params and meta (eg: { id: 1 })
|
|
11
|
+
* - Then we replace the route params with the prepared route params (eg: /users/1)
|
|
12
|
+
*/
|
|
13
|
+
export const composeRoute = (
|
|
14
|
+
designatedRoute: string,
|
|
15
|
+
params: ParseResponse = {},
|
|
16
|
+
meta: MetaDataQuery = {},
|
|
17
|
+
): string => {
|
|
18
|
+
// pickRouteParams (from the route)
|
|
19
|
+
const routeParams = pickRouteParams(designatedRoute);
|
|
20
|
+
// prepareRouteParams (from route params, params and meta)
|
|
21
|
+
const preparedRouteParams = prepareRouteParams(routeParams, params, meta);
|
|
22
|
+
// replace route params with prepared route params
|
|
23
|
+
return designatedRoute.replace(/:([^\/]+)/g, (match, key) => {
|
|
24
|
+
const fromParams = preparedRouteParams[key];
|
|
25
|
+
if (typeof fromParams !== "undefined") {
|
|
26
|
+
return `${fromParams}`;
|
|
27
|
+
}
|
|
28
|
+
return match;
|
|
29
|
+
});
|
|
30
|
+
};
|