2023-12-01 22:45:42 +00:00
|
|
|
import { useEffect } from 'react';
|
2024-03-26 13:19:40 +00:00
|
|
|
import { useRecoilState, useRecoilValue } from 'recoil';
|
2023-12-01 22:45:42 +00:00
|
|
|
|
2024-08-28 15:15:54 +00:00
|
|
|
import { useIsLogged } from '@/auth/hooks/useIsLogged';
|
2024-03-26 13:19:40 +00:00
|
|
|
import { currentUserState } from '@/auth/states/currentUserState';
|
2024-04-30 16:48:07 +00:00
|
|
|
import { currentWorkspaceState } from '@/auth/states/currentWorkspaceState';
|
2023-12-01 21:06:38 +00:00
|
|
|
import { useFindManyObjectMetadataItems } from '@/object-metadata/hooks/useFindManyObjectMetadataItems';
|
2023-12-01 22:45:42 +00:00
|
|
|
import { objectMetadataItemsState } from '@/object-metadata/states/objectMetadataItemsState';
|
2024-04-29 21:33:23 +00:00
|
|
|
import { getObjectMetadataItemsMock } from '@/object-metadata/utils/getObjectMetadataItemsMock';
|
2024-07-30 10:36:39 +00:00
|
|
|
import { WorkspaceActivationStatus } from '~/generated/graphql';
|
2023-12-01 22:45:42 +00:00
|
|
|
import { isDeeplyEqual } from '~/utils/isDeeplyEqual';
|
2024-03-26 13:19:40 +00:00
|
|
|
import { isUndefinedOrNull } from '~/utils/isUndefinedOrNull';
|
2023-12-01 21:06:38 +00:00
|
|
|
|
|
|
|
|
export const ObjectMetadataItemsLoadEffect = () => {
|
2024-03-26 13:19:40 +00:00
|
|
|
const currentUser = useRecoilValue(currentUserState);
|
2024-04-30 16:48:07 +00:00
|
|
|
const currentWorkspace = useRecoilValue(currentWorkspaceState);
|
2024-08-28 15:15:54 +00:00
|
|
|
const isLoggedIn = useIsLogged();
|
2024-04-30 16:48:07 +00:00
|
|
|
|
2024-05-08 07:28:28 +00:00
|
|
|
const { objectMetadataItems: newObjectMetadataItems, loading } =
|
2024-03-26 13:19:40 +00:00
|
|
|
useFindManyObjectMetadataItems({
|
2024-08-28 15:15:54 +00:00
|
|
|
skip: !isLoggedIn,
|
2024-03-26 13:19:40 +00:00
|
|
|
});
|
2023-12-01 22:45:42 +00:00
|
|
|
|
|
|
|
|
const [objectMetadataItems, setObjectMetadataItems] = useRecoilState(
|
2024-03-20 13:21:58 +00:00
|
|
|
objectMetadataItemsState,
|
2023-12-01 22:45:42 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
useEffect(() => {
|
2024-04-30 16:48:07 +00:00
|
|
|
const toSetObjectMetadataItems =
|
|
|
|
|
isUndefinedOrNull(currentUser) ||
|
2024-07-30 10:36:39 +00:00
|
|
|
currentWorkspace?.activationStatus !== WorkspaceActivationStatus.Active
|
2024-04-30 16:48:07 +00:00
|
|
|
? getObjectMetadataItemsMock()
|
|
|
|
|
: newObjectMetadataItems;
|
2024-05-08 07:28:28 +00:00
|
|
|
if (
|
|
|
|
|
!loading &&
|
|
|
|
|
!isDeeplyEqual(objectMetadataItems, toSetObjectMetadataItems)
|
|
|
|
|
) {
|
2024-04-29 21:33:23 +00:00
|
|
|
setObjectMetadataItems(toSetObjectMetadataItems);
|
2023-12-01 22:45:42 +00:00
|
|
|
}
|
2024-04-29 21:33:23 +00:00
|
|
|
}, [
|
|
|
|
|
currentUser,
|
2024-04-30 16:48:07 +00:00
|
|
|
currentWorkspace?.activationStatus,
|
2024-05-08 07:28:28 +00:00
|
|
|
loading,
|
2024-04-29 21:33:23 +00:00
|
|
|
newObjectMetadataItems,
|
|
|
|
|
objectMetadataItems,
|
|
|
|
|
setObjectMetadataItems,
|
|
|
|
|
]);
|
2023-12-01 21:06:38 +00:00
|
|
|
|
|
|
|
|
return <></>;
|
|
|
|
|
};
|