From ba7393cb8c78edb2907b481ccfcc855a3c94d8c2 Mon Sep 17 00:00:00 2001 From: Swathi-eGov Date: Thu, 9 Jan 2025 16:36:21 +0530 Subject: [PATCH 1/2] FEATURE/HCMPRE-1704 : Removing current validation from assumptions and making sure the flow works as expected( for mixed strat, regis and dist can be same) --- .../microplan/src/components/AssumptionsForm.js | 7 ++----- .../microplan/src/components/BoundarySelection.js | 12 +++++++++--- .../modules/microplan/src/utils/utilities.js | 2 +- 3 files changed, 12 insertions(+), 9 deletions(-) diff --git a/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/components/AssumptionsForm.js b/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/components/AssumptionsForm.js index 9a53d0c238..237b5063ec 100644 --- a/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/components/AssumptionsForm.js +++ b/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/components/AssumptionsForm.js @@ -74,9 +74,6 @@ const AssumptionsForm = ({ onSelect, ...props }) => { setSelectedRegistrationProcess(props?.props?.sessionData?.ASSUMPTIONS_FORM?.assumptionsForm?.selectedRegistrationProcess); },[props?.props?.sessionData?.ASSUMPTIONS_FORM?.assumptionsForm]) - const filteredOptions = resourceDistributionStrategyCode === "MIXED" - ? optionsForProcesses.filter(option => option.resourceDistributionStrategyName !== "Fixed post & House-to-House") - : optionsForProcesses; if (isLoadingPlanObject) { return @@ -102,7 +99,7 @@ const AssumptionsForm = ({ onSelect, ...props }) => { variant="select-dropdown" t={t} isMandatory={true} - option={filteredOptions.map(item => ({ + option={optionsForProcesses.map(item => ({ code: item.resourceDistributionStrategyCode, value: item.resourceDistributionStrategyName, }))} @@ -128,7 +125,7 @@ const AssumptionsForm = ({ onSelect, ...props }) => { variant="select-dropdown" t={t} isMandatory={true} - option={filteredOptions.map(item => ({ + option={optionsForProcesses.map(item => ({ code: item.resourceDistributionStrategyCode, value: item.resourceDistributionStrategyName, }))} diff --git a/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/components/BoundarySelection.js b/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/components/BoundarySelection.js index 254b333521..e2eec7a1d8 100644 --- a/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/components/BoundarySelection.js +++ b/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/components/BoundarySelection.js @@ -18,6 +18,7 @@ const BoundarySelection = ({ onSelect, props: customProps, ...props }) => { const [statusMap, setStatusMap] = useState({}); const [executionCount, setExecutionCount] = useState(0); const [updateBoundary, setUpdateBoundary] = useState(true); + const [isStatusMapLoading, setIsStatusMapLoading] = useState(false); const handleBoundaryChange = (value) => { setBoundaryOptions(value?.boundaryOptions); setSelectedData(value?.selectedData); @@ -58,10 +59,15 @@ const BoundarySelection = ({ onSelect, props: customProps, ...props }) => { useEffect(() => { + // Show loader before updating statusMap + setIsStatusMapLoading(true); if (selectedData && selectedData.length >= 0) { - setStatusMap(() => Digit.Utils.microplanv1.createStatusMap(selectedData, boundaryHierarchy)) + const newStatusMap = Digit.Utils.microplanv1.createStatusMap(selectedData, boundaryHierarchy); + setStatusMap(newStatusMap); + // Hide loader after updating statusMap + setIsStatusMapLoading(false); } - }, [selectedData, boundaryHierarchy]) + }, [selectedData, boundaryHierarchy]); useEffect(() => { @@ -94,7 +100,7 @@ const BoundarySelection = ({ onSelect, props: customProps, ...props }) => { return ( <> - + {isStatusMapLoading ? : }
{t(`MICROPLAN_SELECT_BOUNDARY`)}

{t(`MICROPLAN_SELECT_BOUNDARIES_DESCRIPTION`)}

diff --git a/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/utils/utilities.js b/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/utils/utilities.js index 83890c1302..07e634794f 100644 --- a/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/utils/utilities.js +++ b/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/utils/utilities.js @@ -163,7 +163,7 @@ const formValidator = (formData, key, state, t) => { } const processesAreValid = formData?.selectedRegistrationProcess?.code && formData?.selectedDistributionProcess?.code; - if (processesAreValid && (formData?.selectedRegistrationProcess.code === formData?.selectedDistributionProcess.code)) { + if (processesAreValid && (formData?.selectedRegistrationProcess.code === formData?.selectedDistributionProcess.code) && (formData?.selectedRegistrationProcess.code !== "MIXED")) { return { key: "error", label: "ERROR_REGISTRATION_AND_DISTRIBUTION_ARE_SAME" }; // Customize as needed } From 0627954e71b8ce9ad8529a127b9f79d23d09c498 Mon Sep 17 00:00:00 2001 From: Swathi-eGov Date: Thu, 9 Jan 2025 16:42:00 +0530 Subject: [PATCH 2/2] FEATURE/HCMPRE-1704 : Review updates --- .../modules/microplan/src/components/BoundarySelection.js | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/components/BoundarySelection.js b/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/components/BoundarySelection.js index e2eec7a1d8..0131f18c15 100644 --- a/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/components/BoundarySelection.js +++ b/health/micro-ui/web/micro-ui-internals/packages/modules/microplan/src/components/BoundarySelection.js @@ -67,6 +67,10 @@ const BoundarySelection = ({ onSelect, props: customProps, ...props }) => { // Hide loader after updating statusMap setIsStatusMapLoading(false); } + return () => { + // Cleanup function to prevent state updates if component unmounts during loading + setIsStatusMapLoading(false); + }; }, [selectedData, boundaryHierarchy]);