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/intervention #2343

Open
wants to merge 54 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 43 commits
Commits
Show all changes
54 commits
Select commit Hold shift + click to select a range
23261b4
Intervention Constant added
shyambhongle Dec 10, 2024
140cb0d
Basic intervention filter added
shyambhongle Dec 10, 2024
a3e6a30
Project Context updated
shyambhongle Dec 10, 2024
067d46d
Intervention polygon color logic added
shyambhongle Dec 10, 2024
3afbe9e
Intervetion filter updated
shyambhongle Dec 10, 2024
3e17a09
default filter added
shyambhongle Dec 10, 2024
d861be7
'All' added in intervention filter
shyambhongle Dec 10, 2024
b4f31fc
minor:Content Updated
shyambhongle Dec 11, 2024
411c121
Intervention webapp fixes
shyambhongle Dec 26, 2024
2d6de25
plantinfo mobileview reverted
shyambhongle Dec 26, 2024
8b9ccf9
Mobile view slider fix
shyambhongle Dec 26, 2024
1659928
minor
shyambhongle Dec 26, 2024
282b8e4
minor UI fixes
shyambhongle Dec 27, 2024
96a027b
mutlitree polygon color updated
shyambhongle Dec 27, 2024
43d3856
code refactor
shyambhongle Dec 27, 2024
9f9021c
unused code refactored
shyambhongle Dec 27, 2024
8bfe467
zoom out when intervention selecte
shyambhongle Dec 30, 2024
7829842
Filter container height fixed
shyambhongle Dec 30, 2024
b3cfe1b
UI fixes
shyambhongle Dec 30, 2024
9c4e9b5
highlight selected intervention
shyambhongle Dec 30, 2024
bcabeb4
toggle menu feature added
shyambhongle Dec 30, 2024
578a4c2
All Intervention set to default
shyambhongle Dec 30, 2024
9a88fe8
minor fix
shyambhongle Dec 30, 2024
2d82886
padding added inbetween overlapping intervention header
shyambhongle Dec 30, 2024
57d4527
minor clipath refactor
shyambhongle Dec 30, 2024
59b6165
Merge branch 'develop' into feature/intervention
shyambhongle Jan 3, 2025
0b86b1f
code changes
shyambhongle Jan 3, 2025
588bfc2
minor
shyambhongle Jan 3, 2025
171adf8
HID added
shyambhongle Jan 5, 2025
b22fc3a
enrichement planting changes
shyambhongle Jan 5, 2025
a7555c3
minor
shyambhongle Jan 5, 2025
4c6de8d
minor
shyambhongle Jan 6, 2025
1ac22f6
type added in imports
shyambhongle Jan 8, 2025
6ea3699
minor css issue fix
shyambhongle Jan 8, 2025
7c1e9e9
empty slide due tio metadata fix
shyambhongle Jan 8, 2025
6bf4248
removed unwanted code and renamed variables
shyambhongle Jan 8, 2025
548994b
code refactor
shyambhongle Jan 8, 2025
555e3ec
intervention type error fix
shyambhongle Jan 8, 2025
d7dc806
code refactor
shyambhongle Jan 8, 2025
36de55d
condition refactorred
shyambhongle Jan 9, 2025
72797b1
code refactor
shyambhongle Jan 13, 2025
98c4379
refactor: extract createCardData fn outside component
mohitb35 Jan 13, 2025
0225fc9
minor
shyambhongle Jan 13, 2025
6aa75f4
Rename OtherInterventionMetaData.tsx to OtherInterventionMetadata.tsx
shyambhongle Jan 13, 2025
b84ea21
fix: removes extra comma visible below OtherInterventionMetadata
mohitb35 Jan 13, 2025
364dae1
refactor: uses type imports & removes unused imports
mohitb35 Jan 13, 2025
b80d951
refactor: use type imports and improve code formatting in interventio…
mohitb35 Jan 13, 2025
78492b4
refactor: defines more specific types for selectedInterventionType
mohitb35 Jan 13, 2025
9f802c2
feat: add geometry property to OtherInterventions interface
mohitb35 Jan 14, 2025
c1d748f
refactor: code formatting changes per prettier rules
mohitb35 Jan 14, 2025
10096f6
date component placement changes
shyambhongle Jan 15, 2025
b51cf14
Date UI fix
shyambhongle Jan 15, 2025
a35837b
hover issue fix
shyambhongle Jan 15, 2025
01c9cfd
dynamic string added for localization
shyambhongle Jan 15, 2025
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
20 changes: 20 additions & 0 deletions public/assets/images/icons/InterventionIcon.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
function InterventionIcon() {
return (
<svg width="27" height="27" viewBox="0 0 27 27" fill="none" xmlns="http://www.w3.org/2000/svg">
<rect width="27" height="27" transform="matrix(-1 0 0 1 27 0)" fill="white" />
<g clipPath="url(#clip0_5513_164)">
<path d="M9.73693 25C9.4499 24.9184 9.30557 24.7177 9.22936 24.4354C9.09638 23.9458 8.95043 23.4578 8.79151 22.9764C8.75097 22.8524 8.65204 22.743 8.56447 22.6402C7.78932 21.728 7.30769 20.6868 7.19904 19.4857C7.11633 18.58 7.2412 17.7086 7.62067 16.873C7.8704 16.323 8.08608 15.7568 8.31798 15.197C8.7834 14.0759 9.24071 12.9531 9.71585 11.8369C9.93964 11.313 10.2315 10.8267 10.6402 10.4204C10.6694 10.391 10.6872 10.3273 10.6791 10.2849C10.5186 9.43632 10.3483 8.59098 10.1894 7.74238C10.0856 7.18426 9.97208 6.62614 9.90883 6.06313C9.83748 5.42504 9.86018 4.7837 10.1051 4.17499C10.2851 3.72784 10.564 3.35413 11.0099 3.13871C11.138 3.07507 11.2775 3.04406 11.4105 3C11.5289 3 11.6489 3 11.7673 3C11.8013 3.00979 11.8354 3.02448 11.871 3.03101C12.1337 3.0816 12.2959 3.23826 12.377 3.49447C12.6867 4.45568 12.9997 5.41362 13.3127 6.37319C13.7327 7.65915 14.1527 8.94511 14.5727 10.2294C14.7511 10.7761 14.9408 11.3196 15.1062 11.8712C15.2554 12.3705 15.283 12.8846 15.1338 13.3872C14.7657 14.634 14.3846 15.8759 14.0068 17.1211C13.7862 17.8505 13.5641 18.58 13.3467 19.3111C13.3289 19.3699 13.3305 19.4449 13.3532 19.502C13.7927 20.6656 14.2354 21.8275 14.6798 22.9895C14.7933 23.2881 14.7414 23.5378 14.5273 23.7091C14.2322 23.9458 13.7781 23.8348 13.6419 23.4807C13.3403 22.7006 13.0451 21.9173 12.7484 21.1356C12.5927 20.7276 12.4532 20.3115 12.2765 19.9133C12.137 19.5983 12.1402 19.3095 12.2408 18.9831C12.8375 17.0476 13.4181 15.1073 14.0084 13.1702C14.1106 12.8324 14.1073 12.4994 13.9987 12.1682C13.4959 10.626 12.9916 9.08545 12.4889 7.54492C12.1435 6.4858 11.8013 5.42831 11.4559 4.36919C11.4429 4.33165 11.4283 4.29412 11.4056 4.23863C11.2629 4.38877 11.1689 4.54543 11.1186 4.72658C11.0035 5.14762 10.9905 5.58008 11.0472 6.00601C11.1121 6.50211 11.2126 6.99332 11.3051 7.48453C11.4559 8.27765 11.6132 9.06913 11.764 9.86225C11.777 9.92916 11.8013 9.95853 11.8662 9.96833C12.3283 10.0369 12.6559 10.311 12.9138 10.6815C13.0273 10.8447 13.0467 11.0258 12.9803 11.2167C12.4986 12.6072 12.1727 14.04 11.8467 15.4728C11.7267 16.0016 11.6245 16.5336 11.5159 17.0656C11.464 17.3169 11.3229 17.4866 11.0716 17.5421C10.8267 17.596 10.624 17.5111 10.4764 17.3087C10.3775 17.1716 10.3597 17.0117 10.3937 16.8485C10.5315 16.186 10.6564 15.5201 10.8121 14.8625C11.0407 13.8947 11.2905 12.9335 11.537 11.9707C11.5986 11.7292 11.6862 11.4925 11.7575 11.2527C11.7689 11.2151 11.7737 11.1417 11.7575 11.1352C11.7154 11.1156 11.6554 11.1041 11.6148 11.1205C11.5483 11.1482 11.4851 11.1923 11.4316 11.2429C11.1251 11.5382 10.9191 11.9038 10.757 12.2889C10.1018 13.849 9.45963 15.4141 8.80935 16.9758C8.62285 17.4246 8.42825 17.8685 8.35528 18.3548C8.22393 19.2409 8.35204 20.0814 8.75259 20.881C8.98448 21.3461 9.29098 21.7557 9.64774 22.1327C9.7191 22.2094 9.78396 22.3057 9.81477 22.4052C10.0013 23.0042 10.178 23.6063 10.3532 24.2101C10.457 24.5675 10.3207 24.8368 9.97856 24.9706C9.96072 24.9772 9.94613 24.9886 9.92991 24.9967H9.72883L9.73693 25Z" fill="#333333" />
<path d="M25 13.9992C25 15.7274 25 17.4556 25 19.1838C25 19.5412 24.7632 19.7844 24.4081 19.7844C23.654 19.786 22.8983 19.786 22.1442 19.7844C21.8102 19.7844 21.5653 19.5412 21.5637 19.2051C21.5604 17.4099 21.562 15.6132 21.5604 13.8181C21.5604 12.1568 21.5604 10.4955 21.5604 8.8358C21.5604 8.44577 21.7907 8.21403 22.1767 8.2124C22.9161 8.2124 23.6556 8.2124 24.3951 8.2124C24.76 8.2124 24.9967 8.44903 24.9967 8.81295C24.9967 10.5412 24.9967 12.2694 24.9967 13.9976L25 13.9992Z" fill="#333333" />
<path d="M20.3993 13.9994C20.3993 15.7276 20.3993 17.4558 20.3993 19.184C20.3993 19.5398 20.1577 19.7862 19.8074 19.7878C19.0598 19.7878 18.3139 19.7878 17.5663 19.7878C17.1998 19.7878 16.963 19.5528 16.963 19.1856C16.963 15.7259 16.963 12.2646 16.963 8.80495C16.963 8.45082 17.2014 8.21582 17.5533 8.21582C18.3041 8.21582 19.055 8.21582 19.8058 8.21582C20.1609 8.21582 20.3993 8.45571 20.3993 8.81637C20.3993 10.5446 20.3993 12.2728 20.3993 14.001V13.9994Z" fill="#333333" />
<path d="M8.3131 9.54893C8.2985 9.60768 8.27418 9.71702 8.24175 9.82309C7.80552 11.1972 7.36767 12.5713 6.93307 13.9453C6.51468 15.2656 6.09629 16.5874 5.67952 17.9077C5.53033 18.3809 5.37952 18.8542 5.23032 19.3291C5.1087 19.7126 4.79734 19.8627 4.41625 19.7322C3.77245 19.5118 3.12865 19.2964 2.48161 19.0843C2.07133 18.9488 1.91565 18.6665 2.04701 18.2536C2.4508 16.9791 2.85784 15.7046 3.26001 14.43C3.71569 12.9874 4.17138 11.5448 4.62707 10.1022C4.78275 9.60768 4.93843 9.11157 5.09897 8.61873C5.20113 8.30214 5.51249 8.13895 5.82872 8.24339C6.51468 8.46696 7.1974 8.69543 7.88012 8.92717C8.17039 9.02508 8.31634 9.22581 8.31472 9.5473L8.3131 9.54893Z" fill="#333333" />
</g>
<defs>
<clipPath id="clip0_5513_164">
<rect width="23" height="22" fill="white" transform="translate(2 3)" />
</clipPath>
</defs>
</svg>
);
}

export default InterventionIcon;
21 changes: 17 additions & 4 deletions src/features/common/types/plantLocation.d.ts
mohitb35 marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
import type { DateString } from './common';
import type { Links } from './payments';
import type { Polygon, Point } from 'geojson';
import type { INTERVENTION_TYPE } from '../../../utils/constants/intervention';


import { InterventionTypes } from '@planet-sdk/common';
import { DateString } from './common';
import { Links } from './payments';
import { Polygon, Point } from 'geojson';

export interface PlantLocationBase {
hid: string;
Expand Down Expand Up @@ -52,7 +56,16 @@ export interface PlantLocationMulti extends PlantLocationBase {
nextMeasurementDate: null;
}

export type PlantLocation = PlantLocationSingle | PlantLocationMulti;
export interface OtherInterventions extends PlantLocationBase {
type: InterventionTypes;
sampleTreeCount: number;
sampleInterventions: SamplePlantLocation[];
plantedSpecies: PlantedSpecies[];
}



export type PlantLocation = PlantLocationSingle | PlantLocationMulti | OtherInterventions ;

export interface SamplePlantLocation extends PlantLocationBase {
type: 'sample-tree-registration';
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,217 @@
import type {
OtherInterventions,
SamplePlantLocation,
} from '../../../common/types/plantLocation';
import type { SetState } from '../../../common/types/common';

import { useMemo } from 'react';
import { useTranslations } from 'next-intl';
import styles from '../styles/PlantLocationInfo.module.scss';
import SpeciesPlanted from './microComponents/SpeciesPlanted';
import SampleTrees from './microComponents/SampleTrees';
import TreeMapperBrand from './microComponents/TreeMapperBrand';
import ImageSlider from './microComponents/ImageSlider';
import MobileInfoSwiper from '../../MobileInfoSwiper';
import OtherInterventionInfoHeader from './microComponents/OtherInterventionHeader';
import OtherInterventionMetadata from './microComponents/OtherInterventionMetadata';
import InterventionHeader from './microComponents/InterventionHeader';

interface MetaDataValue {
value: string;
label: string;
}

interface PublicMetaData {
[key: string]: string | MetaDataValue;
}

function isJsonString(str: string) {
try {
const parsed = JSON.parse(str);
return typeof parsed === 'object' && parsed !== null;
} catch (e) {
return false;
}
}

const createCardData = (plantLocationInfo: OtherInterventions | null) => {
// Initialize an array to store the cleaned key-value pairs
const cleanedData: { key: string; value: string }[] = [];

// Extract metadata from the plantLocationInfo object, if it exists
const parsedData = plantLocationInfo?.metadata;

// Check if `parsedData.public` exists, is an object, and is not an array
if (
parsedData?.public &&
typeof parsedData.public === 'object' &&
!Array.isArray(parsedData.public)
) {
// Iterate over the entries of `parsedData.public` as key-value pairs
Object.entries(parsedData.public as PublicMetaData).forEach(
([key, value]) => {
// Skip the entry if the key is 'isEntireSite' as it's used to show point location and no use to user
if (key !== 'isEntireSite') {
// If the value is a string, directly add it to cleanedData
if (typeof value === 'string') {
cleanedData.push({ value, key });
}
// If the value is an object with `value` and `label` properties
else if (
typeof value === 'object' &&
value !== null &&
'value' in value &&
'label' in value
) {
// Check if the `value` property contains a valid JSON string
if (isJsonString(value.value)) {
try {
// Parse the JSON string
const parsedValue = JSON.parse(value.value);
// If the parsed value is an object with a `value` property, add it to cleanedData
if (
parsedValue &&
typeof parsedValue === 'object' &&
'value' in parsedValue
) {
cleanedData.push({
key: value.label, // Use the `label` property as the key
value: parsedValue.value, // Use the parsed `value` property
});
}
} catch (error) {
// Log an error if JSON parsing fails
console.error('Error parsing JSON:', error);
}
} else {
// If not a JSON string, add the `label` and `value` directly
cleanedData.push({
key: value.label,
value: value.value,
});
}
}
}
}
);
}

// Return the array of cleaned key-value pairs
return cleanedData;
};
Comment on lines +36 to +100
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🛠️ Refactor suggestion

Move createCardData to a dedicated utility file.

For better maintainability and reusability, move this function to a separate utility file. This aligns with the single responsibility principle and makes the code more modular.

Create a new file src/features/projectsV2/ProjectDetails/utils/metadata.ts:

import { OtherInterventions } from '../../../common/types/plantLocation';

interface MetaDataValue {
  value: string;
  label: string;
}

interface PublicMetaData {
  [key: string]: string | MetaDataValue;
}

/**
 * Processes and cleans metadata from plant location information
 * @param plantLocationInfo - The plant location information containing metadata
 * @returns Array of cleaned key-value pairs with metadata
 */
export function cleanPublicMetadata(plantLocationInfo: OtherInterventions | null) {
  // Move existing implementation here...
}


interface Props {
plantLocationInfo: OtherInterventions | null;
isMobile: boolean;
setSelectedSamplePlantLocation: SetState<SamplePlantLocation | null>;
}

const OtherInterventionInfo = ({
plantLocationInfo,
isMobile,
setSelectedSamplePlantLocation,
}: Props) => {
const tProjectDetails = useTranslations('ProjectDetails');

const { totalTreesCount } = useMemo(() => {
const totalTreesCount =
plantLocationInfo &&
plantLocationInfo.plantedSpecies &&
plantLocationInfo.plantedSpecies.length > 0
? plantLocationInfo.plantedSpecies.reduce(
(sum, species: { treeCount: number }) => sum + species.treeCount,
0
)
: 0;
return { totalTreesCount };
}, [plantLocationInfo, plantLocationInfo?.type]);

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🛠️ Refactor suggestion

Optimize useMemo implementation.

  1. Simplify the conditional check using optional chaining
  2. Remove unnecessary dependency
 const { totalTreesCount } = useMemo(() => {
   const totalTreesCount =
-    plantLocationInfo &&
-    plantLocationInfo.plantedSpecies &&
-    plantLocationInfo.plantedSpecies.length > 0
+    plantLocationInfo?.plantedSpecies?.length > 0
       ? plantLocationInfo.plantedSpecies.reduce(
           (sum, species: { treeCount: number }) => sum + species.treeCount,
           0
         )
       : 0;
   return { totalTreesCount };
- }, [plantLocationInfo, plantLocationInfo?.type]);
+ }, [plantLocationInfo?.plantedSpecies]);
📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
const { totalTreesCount } = useMemo(() => {
const totalTreesCount =
plantLocationInfo &&
plantLocationInfo.plantedSpecies &&
plantLocationInfo.plantedSpecies.length > 0
? plantLocationInfo.plantedSpecies.reduce(
(sum, species: { treeCount: number }) => sum + species.treeCount,
0
)
: 0;
return { totalTreesCount };
}, [plantLocationInfo, plantLocationInfo?.type]);
const { totalTreesCount } = useMemo(() => {
const totalTreesCount =
plantLocationInfo?.plantedSpecies?.length > 0
? plantLocationInfo.plantedSpecies.reduce(
(sum, species: { treeCount: number }) => sum + species.treeCount,
0
)
: 0;
return { totalTreesCount };
}, [plantLocationInfo?.plantedSpecies]);
🧰 Tools
🪛 Biome (1.9.4)

[error] 118-119: Change to an optional chain.

Unsafe fix: Change to an optional chain.

(lint/complexity/useOptionalChain)

const sampleInterventionSpeciesImages = useMemo(() => {
if (plantLocationInfo && plantLocationInfo.sampleInterventions.length > 0) {
const result =
plantLocationInfo.sampleInterventions &&
plantLocationInfo.sampleInterventions.map((item) => {
return {
id: item.coordinates[0].id,
image: item.coordinates[0].image ?? '',
description: tProjectDetails('sampleTreeTag', { tag: item.tag }),
};
});
return result;
}
}, [plantLocationInfo]);
Comment on lines +130 to +143
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🛠️ Refactor suggestion

Simplify sampleInterventionSpeciesImages logic.

The current implementation has unnecessary complexity and potential undefined access.

 const sampleInterventionSpeciesImages = useMemo(() => {
-  if (plantLocationInfo && plantLocationInfo.sampleInterventions.length > 0) {
-    const result = plantLocationInfo.sampleInterventions && plantLocationInfo.sampleInterventions.map((item) => {
+  if (plantLocationInfo?.sampleInterventions?.length > 0) {
+    return plantLocationInfo.sampleInterventions.map((item) => {
       return {
         id: item.coordinates[0].id,
-        image: item.coordinates[0].image ?? '',
+        image: item.coordinates[0]?.image ?? '',
         description: tProjectDetails('sampleTreeTag', { tag: item.tag }),
       };
     });
-    return result;
   }
+  return [];
 }, [plantLocationInfo]);
📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
const sampleInterventionSpeciesImages = useMemo(() => {
if (plantLocationInfo && plantLocationInfo.sampleInterventions.length > 0) {
const result =
plantLocationInfo.sampleInterventions &&
plantLocationInfo.sampleInterventions.map((item) => {
return {
id: item.coordinates[0].id,
image: item.coordinates[0].image ?? '',
description: tProjectDetails('sampleTreeTag', { tag: item.tag }),
};
});
return result;
}
}, [plantLocationInfo]);
const sampleInterventionSpeciesImages = useMemo(() => {
if (plantLocationInfo?.sampleInterventions?.length > 0) {
return plantLocationInfo.sampleInterventions.map((item) => {
return {
id: item.coordinates[0].id,
image: item.coordinates[0]?.image ?? '',
description: tProjectDetails('sampleTreeTag', { tag: item.tag }),
};
});
}
return [];
}, [plantLocationInfo]);
🧰 Tools
🪛 Biome (1.9.4)

[error] 132-139: Change to an optional chain.

Unsafe fix: Change to an optional chain.

(lint/complexity/useOptionalChain)


const shouldDisplayImageCarousel =
sampleInterventionSpeciesImages !== undefined &&
sampleInterventionSpeciesImages?.length > 0;

const cleanedPublicMetadata = createCardData(plantLocationInfo);

const content = [
<>
<InterventionHeader
plHid={plantLocationInfo?.hid}
interventionType={plantLocationInfo?.type}
key="interventionHeader"
/>
{shouldDisplayImageCarousel && (
<ImageSlider
key="imageSlider"
images={sampleInterventionSpeciesImages}
type="coordinate"
isMobile={isMobile}
imageSize="large"
allowFullView={!isMobile}
/>
)}
</>,

cleanedPublicMetadata.length > 0 && (
<>
<OtherInterventionInfoHeader
key="interventionHeader"
plantDate={plantLocationInfo?.interventionStartDate}
/>
<OtherInterventionMetadata
key="plantingDetails"
metadata={cleanedPublicMetadata}
plantDate={plantLocationInfo?.interventionStartDate}
type={plantLocationInfo?.type}
/>
,
</>
),
plantLocationInfo?.plantedSpecies &&
plantLocationInfo.plantedSpecies.length > 0 && (
<SpeciesPlanted
key="speciesPlanted"
totalTreesCount={totalTreesCount}
plantedSpecies={plantLocationInfo.plantedSpecies}
/>
),
plantLocationInfo &&
plantLocationInfo.sampleInterventions &&
plantLocationInfo.sampleInterventions.length > 0 && (
<SampleTrees
key="sampleTrees"
sampleInterventions={plantLocationInfo.sampleInterventions}
setSelectedSamplePlantLocation={setSelectedSamplePlantLocation}
/>
),
].filter(Boolean);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ Potential issue

Fix duplicate keys and improve conditional rendering in content array.

There are several issues in the content array that need to be addressed:

  1. Duplicate key "interventionHeader"
  2. Complex conditional rendering
  3. Unnecessary comma after OtherInterventionMetadata
 const content = [
   <>
     <InterventionHeader
       plHid={plantLocationInfo?.hid}
       interventionType={plantLocationInfo?.type}
       key="interventionHeader"
     />
     {shouldDisplayImageCarousel && (
       <ImageSlider
         key="imageSlider"
         images={sampleInterventionSpeciesImages}
         type="coordinate"
         isMobile={isMobile}
         imageSize="large"
         allowFullView={!isMobile}
       />
     )}
   </>,
   cleanedPublicMetadata.length > 0 && (
     <>
       <OtherInterventionInfoHeader
-        key="interventionHeader"
+        key="otherInterventionHeader"
         plantDate={plantLocationInfo?.interventionStartDate}
       />
       <OtherInterventionMetadata
         key="plantingDetails"
         metadata={cleanedPublicMetadata}
         plantDate={plantLocationInfo?.interventionStartDate}
         type={plantLocationInfo?.type}
-      />
-      ,
+      />
     </>
   ),
   plantLocationInfo?.plantedSpecies?.length > 0 && (
     <SpeciesPlanted
       key="speciesPlanted"
       totalTreesCount={totalTreesCount}
       plantedSpecies={plantLocationInfo.plantedSpecies}
     />
   ),
-  plantLocationInfo &&
-  plantLocationInfo.sampleInterventions &&
-  plantLocationInfo.sampleInterventions.length > 0 && (
+  plantLocationInfo?.sampleInterventions?.length > 0 && (
     <SampleTrees
       key="sampleTrees"
       sampleInterventions={plantLocationInfo.sampleInterventions}
       setSelectedSamplePlantLocation={setSelectedSamplePlantLocation}
     />
   ),
 ].filter(Boolean);
📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
const content = [
<>
<InterventionHeader
plHid={plantLocationInfo?.hid}
interventionType={plantLocationInfo?.type}
key="interventionHeader"
/>
{shouldDisplayImageCarousel && (
<ImageSlider
key="imageSlider"
images={sampleInterventionSpeciesImages}
type="coordinate"
isMobile={isMobile}
imageSize="large"
allowFullView={!isMobile}
/>
)}
</>,
cleanedPublicMetadata.length > 0 && (
<>
<OtherInterventionInfoHeader
key="interventionHeader"
plantDate={plantLocationInfo?.interventionStartDate}
/>
<OtherInterventionMetadata
key="plantingDetails"
metadata={cleanedPublicMetadata}
plantDate={plantLocationInfo?.interventionStartDate}
type={plantLocationInfo?.type}
/>
,
</>
),
plantLocationInfo?.plantedSpecies &&
plantLocationInfo.plantedSpecies.length > 0 && (
<SpeciesPlanted
key="speciesPlanted"
totalTreesCount={totalTreesCount}
plantedSpecies={plantLocationInfo.plantedSpecies}
/>
),
plantLocationInfo &&
plantLocationInfo.sampleInterventions &&
plantLocationInfo.sampleInterventions.length > 0 && (
<SampleTrees
key="sampleTrees"
sampleInterventions={plantLocationInfo.sampleInterventions}
setSelectedSamplePlantLocation={setSelectedSamplePlantLocation}
/>
),
].filter(Boolean);
const content = [
<>
<InterventionHeader
plHid={plantLocationInfo?.hid}
interventionType={plantLocationInfo?.type}
key="interventionHeader"
/>
{shouldDisplayImageCarousel && (
<ImageSlider
key="imageSlider"
images={sampleInterventionSpeciesImages}
type="coordinate"
isMobile={isMobile}
imageSize="large"
allowFullView={!isMobile}
/>
)}
</>,
cleanedPublicMetadata.length > 0 && (
<>
<OtherInterventionInfoHeader
key="otherInterventionHeader"
plantDate={plantLocationInfo?.interventionStartDate}
/>
<OtherInterventionMetadata
key="plantingDetails"
metadata={cleanedPublicMetadata}
plantDate={plantLocationInfo?.interventionStartDate}
type={plantLocationInfo?.type}
/>
</>
),
plantLocationInfo?.plantedSpecies?.length > 0 && (
<SpeciesPlanted
key="speciesPlanted"
totalTreesCount={totalTreesCount}
plantedSpecies={plantLocationInfo.plantedSpecies}
/>
),
plantLocationInfo?.sampleInterventions?.length > 0 && (
<SampleTrees
key="sampleTrees"
sampleInterventions={plantLocationInfo.sampleInterventions}
setSelectedSamplePlantLocation={setSelectedSamplePlantLocation}
/>
),
].filter(Boolean);
🧰 Tools
🪛 Biome (1.9.4)

[error] 192-193: Change to an optional chain.

Unsafe fix: Change to an optional chain.

(lint/complexity/useOptionalChain)

return isMobile ? (
<>
<MobileInfoSwiper
slides={content}
uniqueKey={plantLocationInfo?.hid || ''}
/>
</>
) : (
<section className={styles.plantLocationInfoSection}>
{content}
<TreeMapperBrand />
</section>
);
};

export default OtherInterventionInfo;
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import styles from '../../styles/PlantLocationInfo.module.scss';
import { formatHid } from '../../../../../utils/projectV2';
import {findInterventionHeader } from '../../../../../utils/constants/intervention';

interface Props {
plHid: string | undefined;
interventionType: string | undefined
}

const InterventionHeader = ({
plHid,
interventionType
}: Props) => {
const interventionTitle = findInterventionHeader(interventionType)
return (
<div
className={`plant-location-header-container ${styles.plantLocationHeaderContainer}`}
>
<div className={`${styles.interventionTitle}`}>
{interventionTitle}
</div>
<div className={`hid ${styles.hid}`}>{formatHid(plHid)}</div>
</div>
);
};

export default InterventionHeader;
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
import formatDate from '../../../../../utils/countryCurrency/getFormattedDate';
import styles from '../../styles/PlantLocationInfo.module.scss';

interface Props {
plantDate: string | null | undefined;
}

const OtherInterventionInfoHeader = ({ plantDate }: Props) => {
return (
<div className={`intervention-header ${styles.otherInterventionGroup}`}>
<div
className={`intervention-item ${styles.otherInterventionDetailsItem}`}
>
<h2 className={styles.label}>Intervention Date</h2>
<p className={styles.data}>{plantDate ? formatDate(plantDate) : null}</p>
</div>
</div>
);
};

export default OtherInterventionInfoHeader;
mohitb35 marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
import styles from '../../styles/PlantLocationInfo.module.scss';

interface Props {
metadata: { key: string; value: string }[];
type: string | undefined,
plantDate: string | null | undefined;
}

const OtherInterventionMetadata = ({ metadata }: Props) => {
if(metadata.length===0){
return null
}
return (
<div className={`planting-details-group ${styles.interventionMetadataGroup}`}>
{metadata.map((item, key) => {
return (
<div
key={key}
className={`planting-details-item ${styles.interventionMetaItem}`}
>
<h2 className={styles.label}>{item.key}</h2>
<p className={styles.data}>{item.value}</p>
</div>
);
})}
</div>
);
};

export default OtherInterventionMetadata;
Loading
Loading