Skip to content

Commit

Permalink
display plots based on dfs/sda values
Browse files Browse the repository at this point in the history
  • Loading branch information
agnlez committed Mar 19, 2024
1 parent bfe2b45 commit 557c2bb
Show file tree
Hide file tree
Showing 2 changed files with 82 additions and 23 deletions.
99 changes: 77 additions & 22 deletions client/src/containers/analysis-eudr/map/component.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { useState, useCallback } from 'react';
import { useState, useCallback, useMemo } from 'react';
import DeckGL from '@deck.gl/react/typed';
import { BitmapLayer, GeoJsonLayer } from '@deck.gl/layers/typed';
import Map from 'react-map-gl/maplibre';
Expand All @@ -14,7 +14,7 @@ import BasemapControl from './basemap';

import { useAppSelector } from '@/store/hooks';
import { INITIAL_VIEW_STATE, MAP_STYLES } from '@/components/map';
import { usePlotGeometries } from '@/hooks/eudr';
import { useEUDRData, usePlotGeometries } from '@/hooks/eudr';
import { formatNumber } from '@/utils/number-format';

import type { PickingInfo, MapViewState } from '@deck.gl/core/typed';
Expand Down Expand Up @@ -42,14 +42,46 @@ const EUDRMap = () => {
planetCompareLayer,
supplierLayer,
contextualLayers,
filters: { suppliers, materials, origins, plots },
filters: { suppliers, materials, origins, plots, dates },
} = useAppSelector((state) => state.eudr);

const [hoverInfo, setHoverInfo] = useState<PickingInfo>(null);
const [viewState, setViewState] = useState<MapViewState>(DEFAULT_VIEW_STATE);

const params = useParams();

const { data } = useEUDRData(
{
startAlertDate: dates.from,
endAlertDate: dates.to,
producerIds: suppliers?.map(({ value }) => value),
materialIds: materials?.map(({ value }) => value),
originIds: origins?.map(({ value }) => value),
geoRegionIds: plots?.map(({ value }) => value),
},
{
select: (data) => {
if (params?.supplierId) {
return {
dfs: data.table
.filter((row) => row.supplierId === (params.supplierId as string))
.map((row) => row.plots.dfs.flat())
.flat(),
sda: data.table
.filter((row) => row.supplierId === (params.supplierId as string))
.map((row) => row.plots.sda.flat())
.flat(),
};
}

return {
dfs: data.table.map((row) => row.plots.dfs.flat()).flat(),
sda: data.table.map((row) => row.plots.sda.flat()).flat(),
};
},
},
);

const plotGeometries = usePlotGeometries({
producerIds: params?.supplierId
? [params.supplierId as string]
Expand All @@ -59,25 +91,48 @@ const EUDRMap = () => {
geoRegionIds: plots?.map(({ value }) => value),
});

// Supplier plot layer
const eudrSupplierLayer: GeoJsonLayer = new GeoJsonLayer({
id: 'full-plots-layer',
data: plotGeometries.data,
// Styles
filled: true,
getFillColor: [63, 89, 224, 84],
stroked: true,
getLineColor: [63, 89, 224, 255],
getLineWidth: 1,
lineWidthUnits: 'pixels',
// Interactive props
pickable: true,
autoHighlight: true,
highlightColor: [63, 89, 224, 255],
visible: supplierLayer.active,
onHover: setHoverInfo,
opacity: supplierLayer.opacity,
});
const eudrSupplierLayer = useMemo(() => {
if (!plotGeometries.data || !data) return null;

return new GeoJsonLayer({
id: 'full-plots-layer',
data: plotGeometries.data,
// Styles
filled: true,
getFillColor: ({ properties }) => {
if (data.dfs.indexOf(properties.id) > -1) return [74, 183, 243, 84];
if (data.sda.indexOf(properties.id) > -1) return [255, 192, 56, 84];
return [0, 0, 0, 84];
},
stroked: true,
getLineColor: ({ properties }) => {
if (data.dfs.indexOf(properties.id) > -1) return [74, 183, 243, 255];
if (data.sda.indexOf(properties.id) > -1) return [255, 192, 56, 255];
return [0, 0, 0, 84];
},
getLineWidth: 1,
lineWidthUnits: 'pixels',
// Interactive props
pickable: true,
autoHighlight: true,
highlightColor: (x: PickingInfo) => {
if (x.object?.properties?.id) {
const {
object: {
properties: { id },
},
} = x;

if (data.dfs.indexOf(id) > -1) return [74, 183, 243, 255];
if (data.sda.indexOf(id) > -1) return [255, 192, 56, 255];
}
return [0, 0, 0, 84];
},
visible: supplierLayer.active,
onHover: setHoverInfo,
opacity: supplierLayer.opacity,
});
}, [plotGeometries.data, data, supplierLayer.active, supplierLayer.opacity]);

const basemapPlanetLayer = new TileLayer({
id: 'top-planet-monthly-layer',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ import type {
} from '@tanstack/react-table';

export interface Supplier {
supplierId: number;
supplierId: string;
supplierName: string;
companyId: string;
baselineVolume: number;
Expand All @@ -47,6 +47,10 @@ export interface Supplier {
name: string;
id: string;
}[];
plots: {
dfs: string[];
sda: string[];
};
}

const SuppliersListTable = (): JSX.Element => {
Expand Down

0 comments on commit 557c2bb

Please sign in to comment.