In this PR: - migrate WorkspaceActivationStatus to twenty-shared (and update case to make FE and BE consistent) - introduce isWorkspaceActiveOrSuspended in twenty-shared - refactor the code to use it (when we fetch data on the FE, we want to keep SUSPENDED workspace working + when we sync workspaces we want it too)
36 lines
1.2 KiB
TypeScript
36 lines
1.2 KiB
TypeScript
import { useEffect } from 'react';
|
|
import { useRecoilValue } from 'recoil';
|
|
|
|
import { currentUserState } from '@/auth/states/currentUserState';
|
|
import { currentWorkspaceState } from '@/auth/states/currentWorkspaceState';
|
|
import { useLoadMockedObjectMetadataItems } from '@/object-metadata/hooks/useLoadMockedObjectMetadataItems';
|
|
import { useRefreshObjectMetadataItems } from '@/object-metadata/hooks/useRefreshObjectMetadataItem';
|
|
import { isWorkspaceActiveOrSuspended } from 'twenty-shared';
|
|
import { isUndefinedOrNull } from '~/utils/isUndefinedOrNull';
|
|
|
|
export const ObjectMetadataItemsLoadEffect = () => {
|
|
const currentUser = useRecoilValue(currentUserState);
|
|
const currentWorkspace = useRecoilValue(currentWorkspaceState);
|
|
|
|
const { refreshObjectMetadataItems } = useRefreshObjectMetadataItems();
|
|
const { loadMockedObjectMetadataItems } = useLoadMockedObjectMetadataItems();
|
|
|
|
useEffect(() => {
|
|
if (
|
|
isUndefinedOrNull(currentUser) ||
|
|
!isWorkspaceActiveOrSuspended(currentWorkspace)
|
|
) {
|
|
loadMockedObjectMetadataItems();
|
|
} else {
|
|
refreshObjectMetadataItems();
|
|
}
|
|
}, [
|
|
currentUser,
|
|
currentWorkspace,
|
|
loadMockedObjectMetadataItems,
|
|
refreshObjectMetadataItems,
|
|
]);
|
|
|
|
return <></>;
|
|
};
|