Skip to content

Commit

Permalink
Add api integration for keyfigures,charts
Browse files Browse the repository at this point in the history
  • Loading branch information
roshni73 committed Dec 20, 2024
1 parent 9976005 commit 1b813b6
Show file tree
Hide file tree
Showing 6 changed files with 77 additions and 163 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
"namespace": "operationalLearning",
"strings": {
"downloadMapTitle": "Operational learning map",
"learningLegendLabel": "Learnings"
"learningLegendLabel": "Learnings",
"learningCountLegendLabel":"Learning count"
}
}
82 changes: 43 additions & 39 deletions app/src/views/OperationalLearning/OperationalLearningMap/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import {
TextOutput,
} from '@ifrc-go/ui';
import { useTranslation } from '@ifrc-go/ui/hooks';
import { maxSafe } from '@ifrc-go/ui/utils';
import {
_cs,
isDefined,
Expand All @@ -32,13 +33,18 @@ import {
adminFillLayerOptions,
getPointCircleHaloPaint,
} from '#utils/map';
import { GoApiResponse } from '#utils/restRequest';

import i18n from './i18n.json';
import styles from './styles.module.css';

type learningStatsResponse = GoApiResponse<'/api/v2/ops-learning/stats/'>;
const DEFAULT_MAX_LEARNING = 1000;

const sourceOptions: mapboxgl.GeoJSONSourceRaw = {
type: 'geojson',
};

interface CountryProperties {
country_id: number;
name: string;
Expand All @@ -50,64 +56,47 @@ interface ClickedPoint {
}
interface Props {
className?: string;
learning: learningStatsResponse | undefined;
}

const LEARNINGS_LOW_COLOR = COLOR_LIGHT_BLUE;
const LEARNINGS_HIGH_COLOR = COLOR_BLUE;

function getMaxLearning(learning: learningStatsResponse) {
const learningData = learning?.learning_by_country.filter(
({ count }: { count: number }) => isDefined(count),
);

const maxLearning = maxSafe(
learningData?.map(({ count }: { count: number }) => count),
);
return maxLearning;
}

function OperationalLearningMap(props: Props) {
const strings = useTranslation(i18n);
const {
className,
learning: learningFromProps,
} = props;

const learning = learningFromProps;
const [
clickedPointProperties,
setClickedPointProperties,
] = useState<ClickedPoint | undefined>();

const countryResponse = useCountry();
const countryCentroidGeoJson = useMemo(
(): GeoJSON.FeatureCollection<GeoJSON.Geometry> => {
const learning_by_country = [
{
country_name: 'Afghanistan',
country_id: 14,
operation_count: 40,
},
{
country_name: 'Albania',
country_id: 15,
operation_count: 10,
},
{
country_name: 'Argentina',
country_id: 20,
operation_count: 29,
},
{
country_name: 'Australia',
country_id: 22,
operation_count: 11,
},
{
country_name: 'Belgium',
country_id: 30,
operation_count: 222,
},
{
country_name: 'Canada',
country_id: 42,
operation_count: 1,
},
];
const features = countryResponse
?.map((country) => {
const learningList = learning_by_country.find(
(item) => item.country_id === country.id,
const learningList = learning?.learning_by_country?.find(
(item: { country_id: number; }) => item.country_id === country.id,
);
if (isNotDefined(learningList)) {
return undefined;
}
const units = learningList.operation_count;
const units = learningList.count;
return {
type: 'Feature' as const,
geometry: country.centroid as {
Expand All @@ -127,10 +116,20 @@ function OperationalLearningMap(props: Props) {
features,
};
},
[countryResponse],
[countryResponse, learning],
);
const learningCount = useMemo(() => (
learning?.learning_by_country
.filter((country) => country.count > 0)
), [learning?.learning_by_country]);

const maxScaleValue = useMemo(() => (
Math.max(
...(learningCount
?.map((activity: { count: number; }) => activity.count)
.filter(isDefined) ?? []),
)), [learningCount]);

const maxScaleValue = 10; // FIX ME
const {
bluePointHaloCirclePaint,
} = useMemo(
Expand Down Expand Up @@ -164,6 +163,10 @@ function OperationalLearningMap(props: Props) {
},
[setClickedPointProperties],
);
const maxLearning = useMemo(() => (
getMaxLearning(learning) ?? DEFAULT_MAX_LEARNING
), [learning]);

return (
<Container
className={_cs(styles.learningMap, className)}
Expand All @@ -181,7 +184,7 @@ function OperationalLearningMap(props: Props) {
value={0}
/>
<NumberOutput
value={100} // FIXME:ADD MAX LEARNINGS
value={maxLearning}
/>
</div>
</div>
Expand Down Expand Up @@ -239,6 +242,7 @@ function OperationalLearningMap(props: Props) {
>
<TextOutput
value={clickedPointProperties.feature.properties.operation_count}
label={strings.learningCountLegendLabel}
valueType="number"
/>
</Container>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@
display: flex;
flex-direction: column;
gap: var(--go-ui-spacing-md);


.popup-appeal {
gap: var(--go-ui-spacing-xs);
Expand Down
6 changes: 3 additions & 3 deletions app/src/views/OperationalLearning/i18n.json
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,8 @@
"sourcesUsed": "Sources Used",
"learningExtract": "Learning Extracts",
"sectorsCovered": "Sectors Covered",
"learningBySector": "learnings by sectors",
"learningByRegions": "learnings by regions",
"sourceOvertime": "Sources Overtime"
"learningBySector": "Learning by sectors",
"learningByRegions": "Learning by regions",
"sourceOvertime": "Sources overtime"
}
}
Loading

0 comments on commit 1b813b6

Please sign in to comment.