Реагируйте заново, как обновлять состояние асинхронно - PullRequest
0 голосов
/ 28 февраля 2019

Я начал работать с перекомпоновкой и использовал функцию 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;
...