Skip to content

Commit

Permalink
front: Fetch siblings directly from API.
Browse files Browse the repository at this point in the history
Replaced the previous method of fetching sibling regions, which was to
fetch the parent region then fetch its subregions, with a direct call to
an API endpoint that fetches the siblings. This simplifies the code in
ListOfRegions.jsx and speeds up the application.

Issue: #159

Signed-off-by: Nikolay Martyanov <ohmspectator@gmail.com>
  • Loading branch information
OhmSpectator committed Dec 27, 2023
1 parent 4a3439a commit dba4382
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 15 deletions.
13 changes: 13 additions & 0 deletions frontend/src/api/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,19 @@ export const fetchRootRegions = async (hierarchyId) => {
}
};

export const fetchSiblings = async (regionId, hierarchyId) => {
try {
const response = await api.get(`/api/regions/${regionId}/siblings`, { params: { hierarchyId } });
if (response.status === 404) {
return [];
}
return response.data;
} catch (error) {
console.error('Error fetching siblings:', error);
return [];
}
};

export const fetchSubregions = async (regionId, hierarchyId) => {
try {
const response = await api.get(`/api/regions/${regionId}/subregions`, { params: { hierarchyId } });
Expand Down
19 changes: 4 additions & 15 deletions frontend/src/components/ListOfRegions.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@ import React, { useState, useEffect } from 'react';
import List from '@mui/material/List';
import ListItem from '@mui/material/ListItem';
import { Box } from '@mui/material';
import { fetchAncestors, fetchRootRegions, fetchSubregions } from '../api';
import {
fetchRootRegions, fetchSiblings, fetchSubregions,
} from '../api';
import { useNavigation } from './NavigationContext';

/**
Expand All @@ -26,20 +28,7 @@ function ListOfRegions() {
if (hasSubregions) {
newRegions = await fetchSubregions(regionId, selectedHierarchy.hierarchyId);
} else {
// Fecth the siblings of the selected region
// TODO: do not fetch the siblings if they are already fetched. Address in #159.
// First - fetch the parent of the selected region
// TODO: add a dedicated API endpoint for fetching siblings. Address in #159.
const ancestors = await fetchAncestors(regionId, selectedHierarchy.hierarchyId);
// The parent is the second item in the ancestors array as the
// first item is the region itself.
if (!ancestors || ancestors.length < 2) {
setError('Unable to find the parent region, and hence the siblings.');
return;
}
const parent = ancestors[1];
// Then fetch the subregions of the parent
newRegions = await fetchSubregions(parent.id, selectedHierarchy.hierarchyId);
newRegions = await fetchSiblings(regionId, selectedHierarchy.hierarchyId);
}
} else {
newRegions = await fetchRootRegions(selectedHierarchy.hierarchyId);
Expand Down

0 comments on commit dba4382

Please sign in to comment.