From 48dc836abcba0d49ae67ef9016ed32d1d9c03a65 Mon Sep 17 00:00:00 2001 From: vhu-axelor <146069039+vhu-axelor@users.noreply.github.com> Date: Wed, 4 Dec 2024 15:16:46 +0100 Subject: [PATCH] fix: filter issue with chips on CustomerParkScreen --- changelogs/unreleased/87640.json | 5 ++++ .../intervention/src/api/equipment-api.js | 28 ++++++++++++++++--- .../screens/equipment/CustomerParkScreen.tsx | 5 ++-- 3 files changed, 31 insertions(+), 7 deletions(-) create mode 100644 changelogs/unreleased/87640.json diff --git a/changelogs/unreleased/87640.json b/changelogs/unreleased/87640.json new file mode 100644 index 0000000000..41a692231d --- /dev/null +++ b/changelogs/unreleased/87640.json @@ -0,0 +1,5 @@ +{ + "title": "CustomerParkScreen: resolve filter issue with chips", + "type": "fix", + "packages": "intervention" +} diff --git a/packages/apps/intervention/src/api/equipment-api.js b/packages/apps/intervention/src/api/equipment-api.js index bb5bc7ab1a..cf3397582c 100644 --- a/packages/apps/intervention/src/api/equipment-api.js +++ b/packages/apps/intervention/src/api/equipment-api.js @@ -46,9 +46,29 @@ const createEquipmentsCriteria = ({ if (inService != null) { criteria.push({ - fieldName: 'inService', - operator: inService ? '=' : '!=', - value: true, + operator: 'or', + criteria: [ + { + operator: 'and', + criteria: [ + { + fieldName: 'typeSelect', + operator: '=', + value: Equipment?.typeSelect.Equipment, + }, + { + fieldName: 'inService', + operator: inService ? '=' : '!=', + value: true, + }, + ], + }, + { + fieldName: 'typeSelect', + operator: '=', + value: Equipment?.typeSelect.Place, + }, + ], }); } @@ -144,7 +164,7 @@ const createInterventionEquipmentToLinkCriteria = ({ export async function searchEquipment({ searchValue = null, page = 0, - inService, + inService = null, partnerId, parentPlaceId, noParent = false, diff --git a/packages/apps/intervention/src/screens/equipment/CustomerParkScreen.tsx b/packages/apps/intervention/src/screens/equipment/CustomerParkScreen.tsx index 9a262ff8d5..3a1b835fc0 100644 --- a/packages/apps/intervention/src/screens/equipment/CustomerParkScreen.tsx +++ b/packages/apps/intervention/src/screens/equipment/CustomerParkScreen.tsx @@ -67,10 +67,9 @@ const CustomerParkScreen = ({}) => { const sliceFunctionData = useMemo( () => ({ - inService: selectedStatus[0]?.value, partnerId: customer?.id, }), - [customer?.id, selectedStatus], + [customer?.id], ); return ( @@ -89,7 +88,7 @@ const CustomerParkScreen = ({}) => { sliceFunctionDataNoParentName="noParent" fetchBranchData={branchId => searchEquipmentApi({ - inService: selectedStatus[0]?.key, + inService: selectedStatus[0]?.value, partnerId: customer?.id, parentPlaceId: branchId, })