Я начал работать с перекомпоновкой и использовал функцию StateHandlers, но мне нужно обновить состояние, когда новые данные поступают в реквизит, и я не могу понять, как это сделать.
import React from "react";
import {compose, withProps, withStateHandlers} from "recompose"
import {GoogleMap, InfoWindow, Marker, withGoogleMap, withScriptjs} from "react-google-maps"
import './Map.module.css'
const mapGoogle = compose(
withProps({
googleMapURL:
"https://maps.googleapis.com/maps/api/js&v=3.exp&libraries=geometry,drawing,places",
loadingElement: <div style={{height: `100%`}}/>,
containerElement: <div style={{height: "100vh", width: "100%"}}/>,
mapElement: <div style={{height: "100%"}}/>,
}),
Здесь я хочу обновить состояниеfrom fetched props =>
withStateHandlers(
props => ({
infoWindows: props.markers ? props.markers.map(p => {
return {isOpen: false};
}) : null
}),
{
onToggleOpen: ({infoWindows}) => selectedIndex => ({
infoWindows: infoWindows ? infoWindows.map((iw, i) => {
iw.isOpen = selectedIndex === i;
return iw;
}) : null
})
}
),
Если props.markers не равен NULL, я хочу разместить их на карте
withScriptjs,
withGoogleMap
)(props => {
let markers = null;
if (props.markers) {
console.log(props.markers);
markers = props.markers.map((place, i) => {
let lat = parseFloat(place.latitude);
let lng = parseFloat(place.longitude);
return (
<Marker
id={place.id}
key={place.id}
position={{lat: lat, lng: lng}}
title="Click to zoom"
onClick={props.onToggleOpen.bind(this, i)}
>
{props.infoWindows[i].isOpen && (
<InfoWindow onCloseClick={props.onToggleOpen.bind(i)}>
<div>{place.description}</div>
</InfoWindow>
)}
</Marker>
);
})
}
return (
<GoogleMap defaultZoom={props.zoom} defaultCenter={props.center}>
{markers}
</GoogleMap>
)
});
export default mapGoogle;