Skip to content

Latest commit

 

History

History
 
 

MapGL

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 

The MapGL component represents map on the page.

Static map

By default, MapGL component renders in a static mode. That means that the user cannot interact with the map.

import React from 'react';
import MapGL from '@urbica/react-map-gl';
import 'mapbox-gl/dist/mapbox-gl.css';

<MapGL
  style={{ width: '100%', height: '400px' }}
  mapStyle='mapbox://styles/mapbox/light-v9'
  accessToken={MAPBOX_ACCESS_TOKEN}
  latitude={37.78}
  longitude={-122.41}
  zoom={11}
/>;

Interactive map

In most cases, you will want the user to interact with the map. To do this, you need to provide onViewportChange handler, that will update map viewport state.

import React, { useState } from 'react';
import MapGL from '@urbica/react-map-gl';
import 'mapbox-gl/dist/mapbox-gl.css';

const [viewport, setViewport] = useState({
  latitude: 37.78,
  longitude: -122.41,
  zoom: 11
});

<MapGL
  style={{ width: '100%', height: '400px' }}
  mapStyle='mapbox://styles/mapbox/light-v9'
  accessToken={MAPBOX_ACCESS_TOKEN}
  latitude={viewport.latitude}
  longitude={viewport.longitude}
  zoom={viewport.zoom}
  onViewportChange={setViewport}
/>;

Changing Map Style

import React, { useState } from 'react';
import MapGL, { Source, Layer } from '@urbica/react-map-gl';
import 'mapbox-gl/dist/mapbox-gl.css';

const styles = {
  light: 'mapbox://styles/mapbox/light-v9',
  dark: 'mapbox://styles/mapbox/dark-v9'
};

const [styleId, setStyleId] = useState('light');

const [viewport, setViewport] = useState({
  latitude: 37.78,
  longitude: -122.41,
  zoom: 11
});

<React.Fragment>
  <button onClick={() => setStyleId('light')}>light</button>
  <button onClick={() => setStyleId('dark')}>dark</button>
  <MapGL
    style={{ width: '100%', height: '400px' }}
    mapStyle={styles[styleId]}
    accessToken={MAPBOX_ACCESS_TOKEN}
    latitude={viewport.latitude}
    longitude={viewport.longitude}
    zoom={viewport.zoom}
    onViewportChange={setViewport}
  />
</React.Fragment>;

Using JSON Map Style

import React, { useState } from 'react';
import MapGL from '@urbica/react-map-gl';
import 'mapbox-gl/dist/mapbox-gl.css';

const [mapStyle, setMapStyle] = useState(null);

const [viewport, setViewport] = useState({
  latitude: 37.78,
  longitude: -122.41,
  zoom: 11
});

const mapStyleURL = `https://api.mapbox.com/styles/v1/mapbox/light-v9?access_token=${MAPBOX_ACCESS_TOKEN}`;

if (!mapStyle) {
  fetch(mapStyleURL)
    .then((response) => response.json())
    .then((style) => setMapStyle(style));
}

<MapGL
  style={{ width: '100%', height: '400px' }}
  mapStyle={mapStyle}
  accessToken={MAPBOX_ACCESS_TOKEN}
  onViewportChange={setViewport}
  {...viewport}
/>;

Viewport Change Methods

There are two props viewportChangeMethod and viewportChangeOptions that controls how MapGL component reacts to the new viewport props.

You can find list of available viewportChangeOptions here.

import React, { useState } from 'react';
import MapGL from '@urbica/react-map-gl';
import 'mapbox-gl/dist/mapbox-gl.css';

const [viewportChangeMethod, setViewportChangeMethod] = useState('flyTo');

const [viewport, setViewport] = useState({
  latitude: 37.78,
  longitude: -122.41,
  zoom: 11
});

changeOptions = {
  duration: 1000
};

const onChange = (event) => {
  setViewportChangeMethod(event.target.value);
};

const onClick = (event) => {
  const { lngLat } = event;

  const newVewport = {
    ...viewport,
    latitude: lngLat.lat,
    longitude: lngLat.lng
  };

  setViewport(newVewport);
};

<React.Fragment>
  Select viewportChangeMethod and click on the map
  <select value={viewportChangeMethod} onChange={onChange}>
    <option value='flyTo'>flyTo</option>
    <option value='jumpTo'>jumpTo</option>
    <option value='easeTo'>easeTo</option>
  </select>
  <MapGL
    style={{ width: '100%', height: '400px' }}
    mapStyle='mapbox://styles/mapbox/light-v9'
    accessToken={MAPBOX_ACCESS_TOKEN}
    onClick={onClick}
    onViewportChange={setViewport}
    viewportChangeMethod={viewportChangeMethod}
    viewportChangeOptions={changeOptions}
    {...viewport}
  />
</React.Fragment>;

Events

mapbox-gl emit events in response to user interactions or changes in state.

You can find full list of supported props in eventProps.

Here is an example for onClick prop.

import React, { useState } from 'react';
import MapGL from '@urbica/react-map-gl';
import 'mapbox-gl/dist/mapbox-gl.css';

const [viewport, setViewport] = useState({
  latitude: 37.78,
  longitude: -122.41,
  zoom: 11
});

const onClick = (event) => {
  const { lngLat } = event;

  const newVewport = {
    ...viewport,
    latitude: lngLat.lat,
    longitude: lngLat.lng
  };

  setViewport(newVewport);
};

<MapGL
  style={{ width: '100%', height: '400px' }}
  mapStyle='mapbox://styles/mapbox/light-v9'
  accessToken={MAPBOX_ACCESS_TOKEN}
  onClick={onClick}
  onViewportChange={setViewport}
  {...viewport}
/>;

Layer-specific events

You can also set layer-specific event-handlers passing prop in the form of the array where the first element is a layer id and the second element is an event handler:

onClick={['national_park', onClick]}

Getting Mapbox GL JS Map Instance

Using MapContext

To access Mapbox GL JS Map instance you can use MapContext.Consumer component.

import React from 'react';
import MapGL, { MapContext } from '@urbica/react-map-gl';
import 'mapbox-gl/dist/mapbox-gl.css';

<MapGL
  style={{ width: '100%', height: '400px' }}
  mapStyle='mapbox://styles/mapbox/light-v9'
  accessToken={MAPBOX_ACCESS_TOKEN}
  latitude={37.78}
  longitude={-122.41}
  zoom={11}
>
  <MapContext.Consumer>
    {(map) => {
      map.setPaintProperty('water', 'fill-color', '#fdbdba');
      return;
    }}
  </MapContext.Consumer>
</MapGL>;

Using Ref

You can also call getMap() method on the MapGL ref.

import React from 'react';
import MapGL from '@urbica/react-map-gl';
import 'mapbox-gl/dist/mapbox-gl.css';

class MyMapGL extends React.PureComponent {
  constructor(props) {
    super(props);
    this._map = React.createRef();
  }

  componentDidMount() {
    const map = this._map.current.getMap();
    map.once('load', () => {
      map.setPaintProperty('water', 'fill-color', '#db7093');
    });
  }

  render() {
    return <MapGL {...this.props} ref={this._map} />;
  }
}

<MyMapGL
  style={{ width: '100%', height: '400px' }}
  mapStyle='mapbox://styles/mapbox/light-v9'
  accessToken={MAPBOX_ACCESS_TOKEN}
  latitude={37.78}
  longitude={-122.41}
  zoom={11}
/>;