From 5d60eca04556c508e165832dcafb3f29b250f28b Mon Sep 17 00:00:00 2001 From: Pramod S <87521752+pramodcog@users.noreply.github.com> Date: Tue, 20 Aug 2024 14:46:29 +0530 Subject: [PATCH] fix(react-components): export useAssetMappedNodesForRevisions hook to check for loading state of asset mapping (#4709) * exported useAssetMappedNodesForRevisions hook to check for loading state of asset mapping * enable useSearchMappedEquipmentAssetMappings query only when initialAssetMappings value is loaded * renamed asset mapping node fetch variable --- react-components/src/index.ts | 1 + .../useSearchMappedEquipmentAssetMappings.tsx | 18 +++++++++++------- 2 files changed, 12 insertions(+), 7 deletions(-) diff --git a/react-components/src/index.ts b/react-components/src/index.ts index 4d153a24734..bbc7b8b38e0 100644 --- a/react-components/src/index.ts +++ b/react-components/src/index.ts @@ -48,6 +48,7 @@ export { export { useImage360AnnotationMappingsForAssetIds } from './components/CacheProvider/Image360AnnotationCacheProvider'; export { useLoadedScene } from './components/SceneContainer/LoadedSceneContext'; export { useIsDraggingOnViewer } from './hooks/useIsDraggingOnViewer'; +export { useAssetMappedNodesForRevisions } from './components/CacheProvider/AssetMappingAndNode3DCacheProvider'; // Queries export { use3DModelName } from './query/use3DModelName'; diff --git a/react-components/src/query/useSearchMappedEquipmentAssetMappings.tsx b/react-components/src/query/useSearchMappedEquipmentAssetMappings.tsx index 658ec82b311..374b50a67ff 100644 --- a/react-components/src/query/useSearchMappedEquipmentAssetMappings.tsx +++ b/react-components/src/query/useSearchMappedEquipmentAssetMappings.tsx @@ -46,10 +46,10 @@ export const useSearchMappedEquipmentAssetMappings = ( userSdk?: CogniteClient ): UseInfiniteQueryResult, Error> => { const sdk = useSDK(userSdk); - const { data: assetMappingList, isFetched } = useAssetMappedNodesForRevisions( - models.map((model) => ({ ...model, type: 'cad' })) - ); - const initialAssetMappings = useAllMappedEquipmentAssetMappings(models, sdk); + const { data: assetMappingList, isFetched: isAssetMappingNodesFetched } = + useAssetMappedNodesForRevisions(models.map((model) => ({ ...model, type: 'cad' }))); + const { data: initialAssetMappings, isLoading: isInitialAssetMappingsLoading } = + useAllMappedEquipmentAssetMappings(models, sdk); return useInfiniteQuery({ queryKey: [ @@ -60,11 +60,11 @@ export const useSearchMappedEquipmentAssetMappings = ( ...models.map((model) => [model.modelId, model.revisionId]) ], queryFn: async ({ pageParam }: { pageParam: string | undefined }) => { - if (initialAssetMappings.data === undefined) { + if (initialAssetMappings === undefined) { return { assets: [], nextCursor: undefined }; } if (query === '') { - const assets = initialAssetMappings.data?.pages.flatMap((modelWithAssets) => + const assets = initialAssetMappings.pages.flatMap((modelWithAssets) => modelWithAssets.modelsAssets.flatMap((modelsAsset) => modelsAsset.assets).flat() ); return { assets, nextCursor: undefined }; @@ -100,7 +100,11 @@ export const useSearchMappedEquipmentAssetMappings = ( const lastPageData = allPages[allPages.length - 1]; return lastPageData.nextCursor; }, - enabled: isFetched && assetMappingList !== undefined && assetMappingList.length > 0 + enabled: + !isInitialAssetMappingsLoading && + isAssetMappingNodesFetched && + assetMappingList !== undefined && + assetMappingList.length > 0 }); };