import { useEffect, useState } from 'react'; import SampleBackground from '../../../assets/img/sample-bg.jpg'; import SiteRepository from '../../../repository/SiteRepository'; export default function ZoneSelector(props) { const [habitatImageObject, setHabitatImageObject] = useState({}); const [habitatImageFile, setHabitatImageFile] = useState(SampleBackground); const [selectedZoneSegment, setZoneSegment] = useState(null); const getHabitatImage = () => { SiteRepository.getHabitatImage(props.filters.habitatImage).then(response => { if (response.status === 200) { const imageData = response.data setHabitatImageObject(imageData) setHabitatImageFile(require(`../../../assets/img/habitats/${imageData.image_filename}`).default) } }) } const setZone = (zoneSegment) => { setZoneSegment(zoneSegment) props.setNextDisabled(false); } useEffect(() => { // Retrieves the habitat image from the api if they are not loaded already Object.keys(habitatImageObject).length === 0 && getHabitatImage() // Temporarily bypass if there is no image available if (props.filters.zone || !props.filters.habitatImage) { setZone(props.filters.zone) } }); const stepBackground = { backgroundImage: `url(${habitatImageFile})`, backgroundSize: '100% auto', height: '100%', width: '100%', display: 'flex' } const selectZone = (zoneSegment) => { // Update the filters for the selected zone and enable the next button setZone(zoneSegment) props.updateFilterState({ "zone": zoneSegment.zone }); }; return (
{habitatImageObject && habitatImageObject.name}
{Object.keys(habitatImageObject).length === 0 ? ( // Sample segment selector (temporary if no image is available)