@hyperobjekt/mapgl

1.1.8 • Public • Published

MapGL

This library is a wrapper for react-map-gl that provides some functionality out of the box, including:

  • controls for flying to bounds on the map (<ZoomToBoundsControl />)
  • sizing the map to fill the parent container
  • managing hover and selected state on interactive features
  • providing map view state, hovered feature, selected feature via global store

Demo

Components

<MapGL />

Props

  • mapboxAccessToken: required mapbox access token
  • children: any children (e.g. legend)
  • onLoad: handler function for when the map has loaded
  • ContainerProps: an object containing props to pass to the container div
  • sources: an array of source objects following mapboxgl source format
  • layers: an array of layer styles (with optional additional parameters for beforeId and interactive)

Any additional props are passed on to the ReactMapGL Map. Essentially, any options available to the mapboxgl map can be passed as props to the <MapGL /> component.

Usage

A map centered on New York City

import MapGL from "@hyperobjekt/mapgl";
import "@hyperobjekt/mapgl/dist/style.css";

const NycMap = (props) => (
  <MapGL
    mapboxAccessToken={`...`}
    bounds={[
      [-74.05, 40.47],
      [-73.9, 40.9],
    ]}
    {...props}
  />
);

<ZoomToBoundsControl />

Adds a control that zooms to the provided bounds when clicked.

Note: you can customize the icon by providing some CSS to override the existing background-image property.

Props

Any options that can be passed to fitBounds are accepted as props.

Usage

import MapGL, { ZoomToBoundsControl } from "@hyperobjekt/mapgl";
import "@hyperobjekt/mapgl/dist/style.css";

const ZoomToBoundsMap = (props) => (
  <MapGL {...props}>
    <ZoomToBoundsControl
      bounds={[
        [-73.9876, 40.7661],
        [-73.9397, 40.8002],
      ]}
    />
  </MapGL>
);

Hooks

useMapFlyTo()

Returns the flyTo function for the map.

function (options: FlyToOptions) {}

useMapFlyToBounds():

Returns a function that flys to the bounds of a feature on the map. The available options are the same as the fitBounds options.

function(
  bounds: [number[], number[]],
  options?: FitBoundsOptions
) {...}

useMapFlyToFeature()

Returns a function that flys to the bounds of a feature on the map. The available options are the same as the fitBounds options.

function(
  feature: GeoJSON.Feature,
  options?: FitBoundsOptions
) {...}

useMapFlyToDefault()

Returns a function that flys to the default bounds provided to the map. The available options are the same as the fitBounds options.

function(options?: FitBoundsOptions) {...}

useMapStore()

This is the store for all of the map state.

The following can be retrieved from the store:

  • loaded: true or false, depending on if the map is loaded or not
  • setLoaded: setter for loaded state
  • map: the map instance
  • setMap: setter for the map instance
  • viewState: the current viewport object
  • setViewState: setter for current viewport
  • hoveredFeature: the currently hovered feature (if any)
  • setHoveredFeature: setter for hovered feature
  • selectedFeature: the currently selected feature (if any)
  • setSelectedFeature: setter for selected feature
  • flyToFeature(feature, options): function to fly to the bounds of a feature
  • flyToBounds(bounds, options): function to fly to the provided bounds (see fitBounds for options)
  • flyTo(options): function to fly to the provided viewport (see flyTo for options)

Usage

the map store is a zustand store. use a selector function to retrieve values.

Example: retrieve the hovered feature

/**
 * Renders the currently hovered feature name
 */
const HoveredFeatureName = () => {
  const hoveredFeature = useMapStore((state) => state.hoveredFeature);
  return <p>{hoveredFeature?.properties?.name}</p>;
};

useMapState(key: string)

This hook is a shortcut for selecting state from the store (vs. using useMapStore). Any of they keys within the map store can be used.

Example: selecting the hovered feature

const hoveredFeature = useMapState("hoveredFeature");

Dependencies (7)

Dev Dependencies (6)

Package Sidebar

Install

npm i @hyperobjekt/mapgl

Weekly Downloads

8

Version

1.1.8

License

MIT

Unpacked Size

104 kB

Total Files

8

Last publish

Collaborators

  • hoshmn
  • chris_hull
  • laneolson