From f3b0e87a071356ae07b8aa5a4e5329d58cf4d4aa Mon Sep 17 00:00:00 2001 From: prajwalism Date: Wed, 24 Jul 2024 07:27:51 +0545 Subject: [PATCH] feat: add 100km validation to drawn areas --- .../FormContents/DefineAOI/index.tsx | 31 ++++++++++++++++++- 1 file changed, 30 insertions(+), 1 deletion(-) diff --git a/src/frontend/src/components/CreateProject/FormContents/DefineAOI/index.tsx b/src/frontend/src/components/CreateProject/FormContents/DefineAOI/index.tsx index b4668407..c4e4b72d 100644 --- a/src/frontend/src/components/CreateProject/FormContents/DefineAOI/index.tsx +++ b/src/frontend/src/components/CreateProject/FormContents/DefineAOI/index.tsx @@ -18,6 +18,7 @@ import { FeatureCollection } from 'geojson'; import { uploadAreaOptions } from '@Constants/createProject'; import { validateGeoJSON } from '@Utils/convertLayerUtils'; import Icon from '@Components/common/Icon'; +import { toast } from 'react-toastify'; import MapSection from './MapSection'; export default function DefineAOI({ @@ -60,6 +61,20 @@ export default function DefineAOI({ dispatch(setCreateProjectState({ drawProjectAreaEnable: true })); return; } + const drawnArea = + drawnProjectArea && area(drawnProjectArea as FeatureCollection); + if (drawnArea && drawnArea > 1000000) { + toast.error('Drawn Area should not exceed 100km²'); + dispatch( + setCreateProjectState({ + drawProjectAreaEnable: false, + drawnProjectArea: null, + }), + ); + // @ts-ignore + resetDrawTool(); + return; + } dispatch( setCreateProjectState({ projectArea: drawnProjectArea, @@ -77,6 +92,20 @@ export default function DefineAOI({ dispatch(setCreateProjectState({ drawNoFlyZoneEnable: true })); return; } + const drawnNoFlyZoneArea = + drawnProjectArea && area(drawnNoFlyZone as FeatureCollection); + if (drawnNoFlyZoneArea && drawnNoFlyZoneArea > 1000000) { + toast.error('Drawn Area should not exceed 100km²'); + dispatch( + setCreateProjectState({ + drawNoFlyZoneEnable: false, + drawnNoFlyZone: null, + }), + ); + // @ts-ignore + resetDrawTool(); + return; + } dispatch( setCreateProjectState({ noFlyZone: drawnNoFlyZone, @@ -208,7 +237,7 @@ export default function DefineAOI({ Reset Project Area

- Total Area: {Math.trunc(totalProjectArea as number)} m2 + Total Area: {Math.trunc(totalProjectArea as number)} m²