From b8143a680a813fdaf4f6df6f8ea4317e5cc423ba Mon Sep 17 00:00:00 2001 From: henrikmv Date: Fri, 3 Jan 2025 20:52:26 +0100 Subject: [PATCH 1/2] fix: set paging to false --- .../common/useRelationships/useRelationships.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/core_modules/capture-core/components/WidgetsRelationship/common/useRelationships/useRelationships.js b/src/core_modules/capture-core/components/WidgetsRelationship/common/useRelationships/useRelationships.js index 84f3db620e..4d059148c1 100644 --- a/src/core_modules/capture-core/components/WidgetsRelationship/common/useRelationships/useRelationships.js +++ b/src/core_modules/capture-core/components/WidgetsRelationship/common/useRelationships/useRelationships.js @@ -26,6 +26,7 @@ export const useRelationships = ({ entityId, searchMode, relationshipTypes }: Pr // $FlowFixMe - searchMode should be a valid key of RelationshipSearchEntities [searchMode]: entityId, fields: 'relationship,relationshipType,createdAt,from[trackedEntity[trackedEntity,attributes,program,orgUnit,trackedEntityType],event[event,dataValues,program,orgUnit,orgUnitName,status,createdAt]],to[trackedEntity[trackedEntity,attributes,program,orgUnit,trackedEntityType],event[event,dataValues,program,orgUnit,orgUnitName,status,createdAt]]', + paging: false, }, }), [entityId, searchMode]); From e5c1c09367d3182d6decabbd9c4763f552245cef Mon Sep 17 00:00:00 2001 From: henrikmv Date: Thu, 9 Jan 2025 11:04:01 +0100 Subject: [PATCH 2/2] fix: paging parameter based on version --- .../featuresSupport/support.js | 2 ++ .../useRelationships/useRelationships.js | 25 ++++++++++++------- 2 files changed, 18 insertions(+), 9 deletions(-) diff --git a/src/core_modules/capture-core-utils/featuresSupport/support.js b/src/core_modules/capture-core-utils/featuresSupport/support.js index ff5fb4f11a..6c721144d9 100644 --- a/src/core_modules/capture-core-utils/featuresSupport/support.js +++ b/src/core_modules/capture-core-utils/featuresSupport/support.js @@ -11,6 +11,7 @@ export const FEATURES = Object.freeze({ trackedEntitiesCSV: 'trackedEntitiesCSV', newAocApiSeparator: 'newAocApiSeparator', newEntityFilterQueryParam: 'newEntityFilterQueryParam', + newRelationshipQueryParam: 'newRelationshipQueryParam', }); // The first minor version that supports the feature @@ -26,6 +27,7 @@ const MINOR_VERSION_SUPPORT = Object.freeze({ [FEATURES.trackedEntitiesCSV]: 40, [FEATURES.newAocApiSeparator]: 41, [FEATURES.newEntityFilterQueryParam]: 41, + [FEATURES.newRelationshipQueryParam]: 41, }); export const hasAPISupportForFeature = (minorVersion: string | number, featureName: string) => diff --git a/src/core_modules/capture-core/components/WidgetsRelationship/common/useRelationships/useRelationships.js b/src/core_modules/capture-core/components/WidgetsRelationship/common/useRelationships/useRelationships.js index 4d059148c1..489d83a8fd 100644 --- a/src/core_modules/capture-core/components/WidgetsRelationship/common/useRelationships/useRelationships.js +++ b/src/core_modules/capture-core/components/WidgetsRelationship/common/useRelationships/useRelationships.js @@ -1,6 +1,7 @@ // @flow import { useMemo } from 'react'; import { handleAPIResponse, REQUESTED_ENTITIES } from 'capture-core/utils/api'; +import { featureAvailable, FEATURES } from 'capture-core-utils'; import { useApiDataQuery } from '../../../../utils/reactQueryHelpers'; import type { InputRelationshipData, RelationshipTypes } from '../Types'; import { determineLinkedEntity } from '../RelationshipsWidget/useGroupedLinkedEntities'; @@ -20,15 +21,21 @@ type Props = {| type ReturnData = Array; export const useRelationships = ({ entityId, searchMode, relationshipTypes }: Props) => { - const query = useMemo(() => ({ - resource: 'tracker/relationships', - params: { - // $FlowFixMe - searchMode should be a valid key of RelationshipSearchEntities - [searchMode]: entityId, - fields: 'relationship,relationshipType,createdAt,from[trackedEntity[trackedEntity,attributes,program,orgUnit,trackedEntityType],event[event,dataValues,program,orgUnit,orgUnitName,status,createdAt]],to[trackedEntity[trackedEntity,attributes,program,orgUnit,trackedEntityType],event[event,dataValues,program,orgUnit,orgUnitName,status,createdAt]]', - paging: false, - }, - }), [entityId, searchMode]); + const query = useMemo(() => { + const supportForFeature = featureAvailable(FEATURES.newRelationshipQueryParam); + + return { + resource: 'tracker/relationships', + params: { + // $FlowFixMe - searchMode should be a valid key of RelationshipSearchEntities + [searchMode]: entityId, + fields: 'relationship,relationshipType,createdAt,from[trackedEntity[trackedEntity,attributes,program,orgUnit,trackedEntityType],event[event,dataValues,program,orgUnit,orgUnitName,status,createdAt]],to[trackedEntity[trackedEntity,attributes,program,orgUnit,trackedEntityType],event[event,dataValues,program,orgUnit,orgUnitName,status,createdAt]]', + ...(supportForFeature + ? { paging: false } + : { skipPaging: true }), + }, + }; + }, [entityId, searchMode]); return useApiDataQuery( ['relationships', entityId],