Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

FEATURE/HCMPRE-1713: PopInbox and filtering integration #2108

Merged
merged 10 commits into from
Jan 9, 2025
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import React, { useState, useEffect } from "react";
import React, { useState, useEffect, Fragment } from "react";
import { useTranslation } from "react-i18next";
import { FilterCard, Dropdown, LabelFieldPair, RadioButtons, TextBlock, Loader } from "@egovernments/digit-ui-components";
import { useMyContext } from "../utils/context";
Expand All @@ -11,34 +11,39 @@ const InboxFilterWrapper = (props) => {
const {microplanId,...rest} = Digit.Hooks.useQueryParams()
const tenantId = Digit.ULBService.getCurrentTenantId();
const [filterValues, setFilterValues] = useState(
{ status: null, onRoadCondition: null, terrain: null, securityQ1: null, securityQ2: null }
{ status: null, onRoadCondition: null, terrain: null, securityQ1: null, securityQ2: null,facilityID:null }
);
abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved


// Default selected option
let defaultSelectedOptions = props.defaultValue
? Object.entries(props.defaultValue).reduce((acc, [key, value]) => {
if (value !== null) {
? Object.entries(props.defaultValue).reduce((acc, [key, value]) => {
if (key === "facilityId") {
acc[key] = { code: value?.code, name: `${t(key)} (${value})` };
} else if (value !== null) {
acc[key] = { code: value, name: `${t(key)} (${value})` };
} else {
acc[key] = null;
}
return acc;
}, {})
: null;
: null;


// Initialize state with the default selected option
useEffect(() => {
if (props.defaultValue && Object.keys(props.defaultValue).length > 0) {
const newDefault = Object.entries(props.defaultValue).reduce((acc, [key, value]) => {
acc[key] = value !== null
? { code: value, name: `${t(key)} (${value})` }
? key === 'facilityId'
? { code: value?.code }
: { code: value, name: `${t(key)} (${value})` }
: null;
return acc;
}, {});
setFilterValues(newDefault);
}
}, [props.defaultValue, t]);




Expand All @@ -65,15 +70,16 @@ const InboxFilterWrapper = (props) => {
const handleApplyFilters = () => {
if (props.onApplyFilters) {
const filtersToApply = {};

for (let key in filterValues) {
if (filterValues[key] && typeof filterValues[key] === 'object' && filterValues[key].hasOwnProperty('code')) {
if(filterValues[key] && typeof filterValues[key] === 'object' && String(key)==='facilityId' &&filterValues[key].hasOwnProperty('code') ){
filtersToApply[key] = filterValues[key]
}
else if (filterValues[key] && typeof filterValues[key] === 'object' && filterValues[key].hasOwnProperty('code')) {
filtersToApply[key] = filterValues[key].code; // Extract 'name' if it exists
abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved
} else {
filtersToApply[key] = filterValues[key]; // Keep the value as is (including null)
}
}

props.onApplyFilters(filtersToApply); // Pass the new array to onApplyFilters
}
};
Expand Down Expand Up @@ -125,7 +131,6 @@ const InboxFilterWrapper = (props) => {
if(isPlanFacilityLoading){
return <Loader/>
}

return (

<FilterCard
Expand Down Expand Up @@ -155,7 +160,8 @@ const InboxFilterWrapper = (props) => {
/>
</LabelFieldPair>
)}

{props.isEstimate &&
<Fragment>
abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved
<LabelFieldPair vertical>
<TextBlock body={t(`MP_VILLAGE_ROAD_CONDITION`)} />
<Dropdown
Expand Down Expand Up @@ -185,8 +191,8 @@ const InboxFilterWrapper = (props) => {
<Dropdown
option={planFacility}
optionKey={"code"}
selected={filterValues["facility"] || defaultSelectedOptions?.facility}
select={(value) => handleDropdownChange("facility", value)}
selected={filterValues["facilityId"] || defaultSelectedOptions?.facilityId }
select={(value) => handleDropdownChange("facilityId", value)}
t={t}
disabled={false}
/>
Expand Down Expand Up @@ -220,6 +226,8 @@ const InboxFilterWrapper = (props) => {
</LabelFieldPair>
);
})}
</Fragment>
}


</div>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ const PlanInbox = () => {
const [hierarchyLevel, setHierarchyLevel] = useState("");
const [censusData, setCensusData] = useState([]);
const [boundaries, setBoundaries] = useState([]);
const [selectedFilter, setSelectedFilter] = useState({status:"PENDING_FOR_VALIDATION",onRoadCondition:null,terrain:null,securityQ1:null,securityQ2:null});
const [selectedFilter, setSelectedFilter] = useState({status:"PENDING_FOR_VALIDATION",onRoadCondition:null,terrain:null,securityQ1:null,securityQ2:null,facilityId:null});
abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved
const [activeFilter, setActiveFilter] = useState({});
const [actionBarPopUp, setactionBarPopUp] = useState(false);
const [selectedRows, setSelectedRows] = useState([]);
Expand Down Expand Up @@ -176,6 +176,7 @@ const PlanInbox = () => {
...(selectedFilter?.terrain != null && { terrain: selectedFilter.terrain }),
...(selectedFilter?.securityQ1 != null && { securityQ1: selectedFilter.securityQ1 }),
...(selectedFilter?.securityQ2 != null && { securityQ2: selectedFilter.securityQ2 }),
...(selectedFilter?.facilityId?.id != null && { facilityId: selectedFilter.facilityId.id }),
assignee: user.info.uuid,
planConfigurationId: microplanId,
limit: limitAndOffset?.limit,
Expand Down Expand Up @@ -216,6 +217,8 @@ const PlanInbox = () => {
...(selectedFilter?.onRoadCondition != null && { onRoadCondition: selectedFilter.onRoadCondition }),
...(selectedFilter?.securityQ1 != null && { securityQ1: selectedFilter.securityQ1 }),
...(selectedFilter?.securityQ2 != null && { securityQ2: selectedFilter.securityQ2 }),
...(selectedFilter?.facilityId?.id != null && { facilityId: selectedFilter.facilityId.id }),

abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved
planConfigurationId: microplanId, //list of plan ids
limit: limitAndOffset?.limit,
offset: limitAndOffset?.offset,
Expand Down Expand Up @@ -882,6 +885,7 @@ const PlanInbox = () => {
}}
>
<InboxFilterWrapper
isEstimate={true}
abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved
abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved
options={activeFilter}
onApplyFilters={onFilter}
clearFilters={clearFilters}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ const PopInbox = () => {
const [boundaries, setBoundaries] = useState([]);
const [selectedRows, setSelectedRows] = useState([]);
const [workFlowPopUp, setworkFlowPopUp] = useState('');
const [selectedFilter, setSelectedFilter] = useState(null);
const [selectedFilter, setSelectedFilter] = useState({status:"PENDING_FOR_VALIDATION"});
const [actionBarPopUp, setactionBarPopUp] = useState(false);
const [activeFilter, setActiveFilter] = useState({});
const [currentPage, setCurrentPage] = useState(1);
Expand Down Expand Up @@ -269,7 +269,7 @@ const PopInbox = () => {
businessServices: "CENSUS",
},
config: {
enabled: selectedFilter ? true : false,
enabled: selectedFilter?.status ? true : false,
abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved
select: (data) => {
return data.BusinessServices?.[0];
},
Expand All @@ -281,7 +281,7 @@ const PopInbox = () => {

// Assume selectedFilter maps to applicationStatus or state
const selectedState = workflowData?.states?.find(
(state) => state.state === selectedFilter
(state) => state.state === selectedFilter?.status
);

// Filter actions based on the selected state
Expand All @@ -293,7 +293,7 @@ const PopInbox = () => {
setAvailableActionsForUser(availableActions || []);

}
}, [workflowData, selectedFilter]);
}, [workflowData, selectedFilter?.status]);


// if availableActionsForUser is defined and is an array
Expand All @@ -313,7 +313,7 @@ const PopInbox = () => {
CensusSearchCriteria: {
tenantId: tenantId,
source: microplanId,
status: selectedFilter !== null && selectedFilter !== undefined ? selectedFilter : "",
status: selectedFilter?.status !== null && selectedFilter?.status !== undefined ? selectedFilter?.status : "",
abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved
assignee: user.info.uuid,
jurisdiction: censusJurisdiction,
limit: limitAndOffset?.limit,
Expand Down Expand Up @@ -344,8 +344,8 @@ const PopInbox = () => {
CensusSearchCriteria: {
tenantId: tenantId,
source: microplanId,
status: selectedFilter !== null && selectedFilter !== undefined ? selectedFilter : "",
...(activeLink.code == "ASSIGNED_TO_ALL" || selectedFilter == "VALIDATED"
status: selectedFilter?.status !== null && selectedFilter?.status !== undefined ? selectedFilter?.status : "",
abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved
...(activeLink.code == "ASSIGNED_TO_ALL" || selectedFilter?.status == "VALIDATED"
? {}
: { assignee: user.info.uuid }),
jurisdiction: censusJurisdiction,
Expand Down Expand Up @@ -422,17 +422,18 @@ const PopInbox = () => {
const activeFilterKeys = Object.keys(reorderedStatusCount || {});

if (
(selectedFilter === null || selectedFilter === undefined || selectedFilter === "") ||
!activeFilterKeys.includes(selectedFilter)
(selectedFilter?.status === null || selectedFilter?.status === undefined || selectedFilter?.status === "")
abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved
) {
setSelectedFilter(activeFilterKeys[0]);
setSelectedFilter((prev) => ({
...prev, // Spread the previous state to retain other attributes
abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved
}));
}
setVillagesSelected(0);
setSelectedRows([]);

if (activeLink.code === "ASSIGNED_TO_ME") {
setAssignedToMeCount(data?.TotalCount);
setAssignedToAllCount(data?.StatusCount[selectedFilter] || 0)
setAssignedToAllCount(data?.StatusCount[selectedFilter?.status] || 0)
} else {
setAssignedToAllCount(data?.TotalCount);
}
Expand All @@ -443,10 +444,10 @@ const PopInbox = () => {
if (censusJurisdiction?.length > 0) {
refetchCensus(); // Trigger the API call again after activeFilter changes
}
}, [selectedFilter, censusJurisdiction, limitAndOffset, activeLink]);
}, [selectedFilter?.status, censusJurisdiction, limitAndOffset, activeLink]);

useEffect(() => {
if (selectedFilter === "VALIDATED") {
if (selectedFilter?.status === "VALIDATED") {
setActiveLink({ code: "", name: "" });
setShowTab(false);
} else {
Expand All @@ -458,17 +459,22 @@ const PopInbox = () => {
setShowTab(true);
}
}
}, [selectedFilter]);
}, [selectedFilter?.status]);

const onFilter = (selectedStatus) => {
const onFilter = (filterValue) => {
setLimitAndOffset((prev)=>{
return {
limit: prev.limit,
offset: 0
}
});
setCurrentPage(1);
setSelectedFilter(selectedStatus?.code);
setSelectedFilter((prev)=>(
{
...prev,
...filterValue
}
));
setActiveLink({
code: "ASSIGNED_TO_ME",
name: "ASSIGNED_TO_ME"
Expand All @@ -487,9 +493,9 @@ const PopInbox = () => {
}

const clearFilters = () => {
if (selectedFilter !== Object.entries(activeFilter)?.[0]?.[0]) {
setSelectedFilter(Object.entries(activeFilter)?.[0]?.[0]);
}
setSelectedFilter((prev)=>({
status:Object.entries(activeFilter)?.[0]?.[0]
}));
setLimitAndOffset((prev)=>{
return {
limit: prev.limit,
Expand Down Expand Up @@ -558,13 +564,13 @@ const PopInbox = () => {

const getButtonState = (action) => {

if (selectedFilter === "PENDING_FOR_VALIDATION" && action === "VALIDATE") {
if (selectedFilter?.status === "PENDING_FOR_VALIDATION" && action === "VALIDATE") {
return true;
}
if (selectedFilter === "PENDING_FOR_APPROVAL" && (action === "APPROVE" || action === "ROOT_APPROVE")) {
if (selectedFilter?.status === "PENDING_FOR_APPROVAL" && (action === "APPROVE" || action === "ROOT_APPROVE")) {
return true;
}
if (selectedFilter === "VALIDATED" && action === "SEND_BACK_FOR_CORRECTION") {
if (selectedFilter?.status === "VALIDATED" && action === "SEND_BACK_FOR_CORRECTION") {
return true;
}
return false;
Expand Down Expand Up @@ -619,7 +625,7 @@ const PopInbox = () => {

</div>
</div>
<GenericKpiFromDSS module="CENSUS" status={selectedFilter} planId={microplanId} refetchTrigger={refetchTrigger} campaignType={campaignObject?.projectType} planEmployee={planEmployee} boundariesForKpi={defaultBoundaries}/>
<GenericKpiFromDSS module="CENSUS" status={selectedFilter?.status} planId={microplanId} refetchTrigger={refetchTrigger} campaignType={campaignObject?.projectType} planEmployee={planEmployee} boundariesForKpi={defaultBoundaries}/>
<SearchJurisdiction
boundaries={boundaries}
defaultHierarchy={defaultHierarchy}
Expand All @@ -634,11 +640,11 @@ const PopInbox = () => {

<div className="pop-inbox-wrapper-filter-table-wrapper" style={{ marginBottom: (isRootApprover && isStatusConditionMet(totalStatusCount) && planObject?.status === "CENSUS_DATA_APPROVAL_IN_PROGRESS") || (!isRootApprover && totalcount===0) || disabledAction ? "2.5rem" : "0rem" }}>
<InboxFilterWrapper
isEstimate={false}
abishekTa-egov marked this conversation as resolved.
Show resolved Hide resolved
options={activeFilter}
onApplyFilters={onFilter}
clearFilters={clearFilters}
defaultValue={ { [selectedFilter]: activeFilter[selectedFilter]}
}
defaultValue={selectedFilter}
></InboxFilterWrapper>

<div className={"pop-inbox-table-wrapper"}>
Expand Down Expand Up @@ -763,7 +769,7 @@ const PopInbox = () => {
)}
</div>
)}
{isLoading || isFetching ? <Loader /> : censusData.length === 0 ? <NoResultsFound style={{ height: selectedFilter === "VALIDATED" ? "472px" : "408px" }} text={t(`HCM_MICROPLAN_NO_DATA_FOUND_FOR_CENSUS`)} /> : <PopInboxTable currentPage={currentPage} rowsPerPage={rowsPerPage} totalRows={totalRows} handlePageChange={handlePageChange} handlePerRowsChange={handlePerRowsChange} onRowSelect={onRowSelect} censusData={censusData} showEditColumn={actionsToHide?.length > 0} employeeNameData={employeeNameMap}
{isLoading || isFetching ? <Loader /> : censusData.length === 0 ? <NoResultsFound style={{ height: selectedFilter?.status === "VALIDATED" ? "472px" : "408px" }} text={t(`HCM_MICROPLAN_NO_DATA_FOUND_FOR_CENSUS`)} /> : <PopInboxTable currentPage={currentPage} rowsPerPage={rowsPerPage} totalRows={totalRows} handlePageChange={handlePageChange} handlePerRowsChange={handlePerRowsChange} onRowSelect={onRowSelect} censusData={censusData} showEditColumn={actionsToHide?.length > 0} employeeNameData={employeeNameMap}
onSuccessEdit={(data) => {
setUpdatedCensus(data);
setShowComment(true);
Expand Down
Loading