I'm developing a leaflet map with reactjs but I got this error when I implemented a <MarkerClusterGroup>
from react-leaflet-markercluster
.
TypeError: Super expression must either be null or a function, not object
Here is the error below:
Here's the Javascript:
import React, { Component } from 'react';
import L from 'leaflet';
import { Map, TileLayer, Marker, Popup } from 'react-leaflet';
import MarkerClusterGroup from 'react-leaflet-markercluster';
import 'react-leaflet-markercluster/dist/styles.min.css';
// code for map marker icon
var myIcon = L.icon({
iconUrl: '',
iconSize: [25, 41],
iconAnchor: [12.5, 41],
popupAnchor: [0, -41]
});
export default class BikeMap extends Component {
constructor(props) {
super(props);
this.state = {
location: {
lat: 51.505,
lng: -0.09,
},
bikeData: [],
isLoading: true,
haveUsersLocation: false,
zoom: 3
}
}
//code for loading
componentWillMount() {
setTimeout(() => this.setState({
isLoading: false
}), 2000);
}
componentDidMount() {
//code to get the bike information
fetch('https://api.citybik.es/v2/networks')
.then(res => {
if (!res.ok) {
throw new Error(res.status);
}
return res.json();
})
.then(response => {
const networkData = response.networks;
this.setState({
bikeData: networkData
});
})
.catch(error => {
console.log(error);
});
//code to get the user's location(if so desires)
navigator.geolocation.getCurrentPosition((position) => {
this.setState({
location: {
lat: position.coords.latitude,
lng: position.coords.longitude
},
haveUsersLocation: true,
zoom: 6
});
}, () => {
console.log('Uops! The user didnt give its location!');
fetch('https://ipapi.co/json')
.then(res => {
if (!res.ok) {
throw new Error(res.status);
}
return res.json();
})
.then(location => {
this.setState({
location: {
lat: location.latitude,
lng: location.longitude
},
haveUsersLocation: true,
zoom: 13
});
})
.catch(error => {
console.log(error);
})
});
}
render() {
const { isLoading } = this.state;
const position = [this.state.location.lat, this.state.location.lng]
const bikeData = this.state.bikeData;
if (isLoading) {
return <div className="spinner"></div>
}
return (
<Map className="map markercluster-map" center={position} zoom={this.state.zoom}>
<TileLayer
attribution="&copy <a href="http://osm.org/copyright">OpenStreetMap</a> contributors"
url="https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
/>
<MarkerClusterGroup>
{
bikeData && bikeData.map((data, index) => {
const company = data.company;
if (company) {
const companyList = company.map((station, index) => {
return (
<div key={index}>{station}</div>
)
})
return (
<Marker
icon={myIcon}
key={data.id}
position={[data.location.latitude, data.location.longitude]}>
<Popup>
<b>City:</b> {data.location.city} <br />
<b>Country:</b> {data.location.country} <br />
<b>Name of Network:</b> {data.name} <br />
<b>Number of Stations:</b> {data.company.length} <br />
<b>Name of Stations:</b> {companyList}
</Popup>
</Marker>
)
}
return <div key={index}>No Data</div>
})
}
</MarkerClusterGroup>
</Map>
)
}
}
I am using:
"leaflet": "^1.3.4",
"leaflet.markercluster": "^1.4.1",
"prop-types": "^15.6.2",
"react": "^16.5.2",
"react-dom": "^16.5.2",
"react-leaflet": "^2.0.1",
"react-leaflet-markercluster": "^1.1.8"
Thank you!
Please use
react-leaflet-markercluster@2.0.0-rc1
https://codesandbox.io/embed/31j028qp25