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

[TM-850] polygon functionality #248

Merged
merged 26 commits into from
Jun 11, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
6fba959
polygon review tab
diego-morales-flores-1996 Jun 7, 2024
f07a7f7
Merge branch 'feat/TM-905-create-map-instance' into feat/TM-850-polyg…
cesarLima1 Jun 7, 2024
1798e27
[TM-850] remove audit endpoints
cesarLima1 Jun 7, 2024
bc32ba1
fix status enum
egrojMonroy Jun 10, 2024
fb2e118
[TM-850] fix Status Enum in Modal Add
egrojMonroy Jun 10, 2024
21a09e2
[TM-850] add refetch call for bbox
egrojMonroy Jun 10, 2024
59cf1d7
Merge branch 'feat/TM-905-create-map-instance' into feat/TM-850-polyg…
cesarLima1 Jun 10, 2024
db5a5cc
Merge branch 'staging' into feat/TM-850-polygon-functionality
cesarLima1 Jun 10, 2024
22e0561
[TM-850] coalescing nullish and unused code removed
cesarLima1 Jun 10, 2024
6bc12d3
[TM-850] change to coalescing nullish
egrojMonroy Jun 10, 2024
a736a6a
[TM-850] reduce re render
cesarLima1 Jun 10, 2024
fc1d8e7
[TM-850] Remove unnecesary ...
egrojMonroy Jun 10, 2024
457036f
[TM-850] onclick edit polygon as void function
cesarLima1 Jun 10, 2024
d804453
edit the fragment isn't needed
dottyy Jun 10, 2024
6f34e8d
remove copy
dottyy Jun 10, 2024
ac4b8f2
[TM-850] update reference for site name
cesarLima1 Jun 10, 2024
0a023f8
Merge branch 'feat/TM-850-polygon-functionality' of https://github.co…
cesarLima1 Jun 10, 2024
b9fdb4a
[TM-850] fix map tooltip desgin
diego-morales-flores-1996 Jun 10, 2024
5d986f5
delete polygon Panel Item
dottyy Jun 10, 2024
656a149
[TM-850] delete unused mocked Data
diego-morales-flores-1996 Jun 10, 2024
175aaa1
Merge branch 'feat/TM-850-polygon-functionality' of https://github.co…
diego-morales-flores-1996 Jun 10, 2024
98d8ff5
update storyshot
dottyy Jun 10, 2024
862bcdd
remove file copy
dottyy Jun 10, 2024
476dc68
fix build in PR
dottyy Jun 11, 2024
f6ad52f
[TM-850] Refactor functions to use POST instead of GET for polygon va…
cesarLima1 Jun 11, 2024
cc3b9cc
[TM-850] update storyshots
cesarLima1 Jun 11, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,25 +1,22 @@
import { When } from "react-if";

import Commentary from "@/components/elements/Commentary/Commentary";
import CommentaryBox from "@/components/elements/CommentaryBox/CommentaryBox";
import Text from "@/components/elements/Text/Text";
import Loader from "@/components/generic/Loading/Loader";
import { useGetAuthMe } from "@/generated/apiComponents";

const CommentarySection = ({
auditLogData,
refresh,
record,
entity,
viewCommentsList = true,
attachmentRefetch
loading = false
}: {
auditLogData?: any;
refresh?: any;
refresh?: () => void;
record?: any;
entity?: "Project" | "SitePolygon" | "Site";
viewCommentsList?: boolean;
attachmentRefetch?: any;
loading?: boolean;
}) => {
const { data: authMe } = useGetAuthMe({}) as {
data: {
Expand All @@ -40,27 +37,11 @@ const CommentarySection = ({
entity={entity}
/>
<When condition={viewCommentsList}>
<div className="max-h-[60vh] min-h-[10vh] grid-cols-[14%_20%_18%_15%_33%] overflow-auto">
{auditLogData ? (
auditLogData.length > 0 ? (
auditLogData
.filter((item: any) => item.type === "comment")
.map((item: any) => (
<Commentary
key={item.id}
name={item?.first_name || item.created_by}
lastName={item?.last_name}
date={item.date_created}
commentary={item.comment}
/>
))
) : (
<></>
)
) : (
{loading && (
<div className="max-h-[60vh] min-h-[10vh] grid-cols-[14%_20%_18%_15%_33%]">
<Loader />
)}
</div>
</div>
)}
</When>
</div>
);
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,226 @@
import { Divider } from "@mui/material";
import { useEffect, useState } from "react";
import { Else, If, Then, When } from "react-if";

import Accordion from "@/components/elements/Accordion/Accordion";
import Button from "@/components/elements/Button/Button";
import { StatusEnum } from "@/components/elements/Status/constants/statusMap";
import Status from "@/components/elements/Status/Status";
import Text from "@/components/elements/Text/Text";
import { useSitePolygonData } from "@/context/sitePolygon.provider";
import {
fetchPostV2TerrafundValidationPolygon,
useGetV2TerrafundValidationCriteriaData
} from "@/generated/apiComponents";
import { SitePolygon } from "@/generated/apiSchemas";

import CommentarySection from "../CommentarySection/CommentarySection";
import StatusDisplay from "../PolygonStatus/StatusDisplay";
import AttributeInformation from "./components/AttributeInformation";
import PolygonValidation from "./components/PolygonValidation";
import VersionHistory from "./components/VersionHistory";

const statusColor: Record<string, string> = {
draft: "bg-pinkCustom",
submitted: "bg-blue",
approved: "bg-green",
"needs-more-information": "bg-tertiary-600"
};

const validationLabels: any = {
3: "No Overlapping Polygon",
4: "No Self-Intersection",
6: "Inside Size Limit",
7: "Within Country",
8: "No Spike",
10: "Polygon Type",
12: "Within Total Area Expected",
14: "Data Completed"
};

export interface ICriteriaCheckItem {
id: string;
status: boolean;
label: string;
date?: string;
}

const ESTIMATED_AREA_CRITERIA_ID = 12;

const PolygonDrawer = ({
polygonSelected,
isPolygonStatusOpen,
refresh
}: {
polygonSelected: string;
isPolygonStatusOpen: any;
refresh?: () => void;
}) => {
const [buttonToogle, setButtonToogle] = useState(true);
const [selectedPolygonData, setSelectedPolygonData] = useState<SitePolygon>();
const [statusSelectedPolygon, setStatusSelectedPolygon] = useState<string>("");
const [openAttributes, setOpenAttributes] = useState(true);
const [checkPolygonValidation, setCheckPolygonValidation] = useState(false);
const [validationStatus, setValidationStatus] = useState(false);
const [polygonValidationData, setPolygonValidationData] = useState<ICriteriaCheckItem[]>();
const [criteriaValidation, setCriteriaValidation] = useState<boolean | any>();

const context = useSitePolygonData();
const sitePolygonData = context?.sitePolygonData as undefined | Array<SitePolygon>;
const openEditNewPolygon = context?.isUserDrawingEnabled;
const selectedPolygon = sitePolygonData?.find((item: SitePolygon) => item?.poly_id === polygonSelected);
const { data: criteriaData, refetch: reloadCriteriaValidation } = useGetV2TerrafundValidationCriteriaData(
{
queryParams: {
uuid: polygonSelected
}
},
{
enabled: !!polygonSelected
}
);

const validatePolygon = async () => {
await fetchPostV2TerrafundValidationPolygon({ queryParams: { uuid: polygonSelected } });
reloadCriteriaValidation();
setCheckPolygonValidation(false);
};
roguenet marked this conversation as resolved.
Show resolved Hide resolved

useEffect(() => {
if (checkPolygonValidation) {
validatePolygon();
reloadCriteriaValidation();
}
}, [checkPolygonValidation]);

useEffect(() => {
setButtonToogle(!isPolygonStatusOpen);
}, [isPolygonStatusOpen]);

useEffect(() => {
if (criteriaData?.criteria_list) {
const transformedData: ICriteriaCheckItem[] = criteriaData.criteria_list.map((criteria: any) => ({
id: criteria.criteria_id,
date: criteria.latest_created_at,
status: criteria.valid === 1,
label: validationLabels[criteria.criteria_id]
}));
setPolygonValidationData(transformedData);
setValidationStatus(true);
} else {
setValidationStatus(false);
}
}, [criteriaData]);

useEffect(() => {
if (Array.isArray(sitePolygonData)) {
const PolygonData = sitePolygonData.find((data: SitePolygon) => data.poly_id === polygonSelected);
setSelectedPolygonData(PolygonData ?? {});
setStatusSelectedPolygon(PolygonData?.status ?? "");
} else {
setSelectedPolygonData({});
setStatusSelectedPolygon("");
}
}, [polygonSelected, sitePolygonData]);
useEffect(() => {
if (openEditNewPolygon) {
setButtonToogle(true);
setOpenAttributes(true);
}
}, [openEditNewPolygon]);

const isValidCriteriaData = (criteriaData: any) => {
if (!criteriaData?.criteria_list?.length) {
return true;
}
return criteriaData.criteria_list.some(
(criteria: any) => criteria.criteria_id !== ESTIMATED_AREA_CRITERIA_ID && criteria.valid !== 1
);
};

useEffect(() => {
const fetchCriteriaValidation = async () => {
if (!buttonToogle) {
const criteriaData = await fetchPostV2TerrafundValidationPolygon({
queryParams: {
uuid: polygonSelected
}
});
setCriteriaValidation(criteriaData);
}
};

fetchCriteriaValidation();
}, [buttonToogle, selectedPolygonData]);

return (
<div className="flex flex-1 flex-col gap-6 overflow-visible">
<div>
<Text variant={"text-12-light"}>{`Polygon ID: ${selectedPolygonData?.id}`}</Text>
<Text variant={"text-20-bold"} className="flex items-center gap-1">
{selectedPolygonData?.poly_name ? selectedPolygonData?.poly_name : "Unnamed Polygon"}
<div className={`h-4 w-4 rounded-full ${statusColor[statusSelectedPolygon]}`} />
</Text>
</div>
<div className="flex w-fit gap-1 rounded-lg bg-neutral-200 p-1">
<Button
variant={`${buttonToogle ? "white-toggle" : "transparent-toggle"}`}
onClick={() => setButtonToogle(!buttonToogle)}
>
Attributes
</Button>
<Button
variant={`${buttonToogle ? "transparent-toggle" : "white-toggle"}`}
onClick={() => setButtonToogle(!buttonToogle)}
>
Polygon Status
</Button>
</div>
<If condition={!buttonToogle}>
<Then>
<div className="flex max-h-max flex-[1_1_0] flex-col gap-6 overflow-auto pr-3">
<div className="flex items-center gap-2">
<Text variant="text-14-semibold" className="w-[15%] break-words">
Status:
</Text>
<When condition={selectedPolygon?.status}>
<Status className="w-[35%]" status={selectedPolygon?.status as StatusEnum} />
</When>
</div>
<StatusDisplay
titleStatus="Polygon"
name={selectedPolygon?.poly_name}
refresh={refresh}
record={selectedPolygon}
tab="polygonReview"
checkPolygonsSite={isValidCriteriaData(criteriaValidation)}
/>
<CommentarySection record={selectedPolygon} entity={"SitePolygon"}></CommentarySection>
</div>
</Then>
<Else>
<div className="flex max-h-max flex-[1_1_0] flex-col gap-6 overflow-auto pr-3">
<Accordion variant="drawer" title={"Validation"} defaultOpen={true}>
<PolygonValidation
menu={polygonValidationData ?? []}
clickedValidation={setCheckPolygonValidation}
status={validationStatus}
/>
</Accordion>
<Divider />
<Accordion variant="drawer" title={"Attribute Information"} defaultOpen={openAttributes}>
{selectedPolygonData && <AttributeInformation selectedPolygon={selectedPolygonData} />}
</Accordion>
<Divider />
<Accordion variant="drawer" title={"Version History"} defaultOpen={true}>
<VersionHistory />
</Accordion>
<Divider />
</div>
</Else>
</If>
</div>
);
};

export default PolygonDrawer;
Loading