Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/rob-blackbourn/jetblack-map

A map component for React
https://github.com/rob-blackbourn/jetblack-map

map openstreetmap osm react react-component reactjs slippy-map slippy-tiles tiles

Last synced: 3 months ago
JSON representation

A map component for React

Awesome Lists containing this project

README

        

# @jetblack/map

A map component for React.

The component has a few unique features:

* Is is built as a pure react component with no dependencies,
* When zoomed out the map can scroll continuously in the horizontal direction.
* It uses hooks to provide interaction with the map.

## Demo

You can see a demo of the map [here](https://rob-blackbourn.github.io/jetblack-example-map/).

There are some examples of map usage in the `demos` folder. These can be run
with `npm`.

```bash
npm install
npm start
```

## Installation

Install from npmjs:

```bash
npm install --save @jetblack/map
```

React is a peer dependency and will not be automatically installed.

## Packages

There are two official packages:

* [@jetblack/map-geojson](https://github.com/rob-blackbourn/jetblack-map-geojson) - support for geojson
* [@jetblack/map-cluster-marker](https://github.com/rob-blackbourn/jetblack-map-cluster-marker) - cluster markers

## Usage

### Basic

Here is a basic map using the default tile provider.

```typescript
import { Map } from '@jetblack/map'

export default function App() {
return (

)
}
```

Typically we will want to specify the center of the map and the zoom level.

```typescript
import { Map } from '@jetblack/map'

const GREENWICH_OBSERVATORY: Coordinate = {
latitude: 51.47684676353231,
longitude: -0.0005261695762532147,
}

export default function App() {
return (

)
}
```

### Overlay Layer

An overlay layer can be added.

```typescript
import {
Map,
Marker,
OverlayLayer,
SVGPin
} from '@jetblack/map'

const GREENWICH_OBSERVATORY: Coordinate = {
latitude: 51.47684676353231,
longitude: -0.0005261695762532147,
}

const BUCKINGHAM_PALACE: Coordinate = {
latitude: 51.501200111998415,
longitude: -0.14182556179982908,
}

export default function App() {
return (


}
/>
}
/>


)
}
```

### Interaction

Hooks are provided for interaction with the map.

The default tile provider is Open Street Map (`osmTileProvider`), which has a
tile width and height of 256.

```typescript
import { useRef } from 'react'
import {
Coordinate,
Map,
Marker,
OverlayLayer,
Point,
SVGPin,
useClick,
useDrag,
useZoom,
} from '@jetblack/map'

const GREENWICH_OBSERVATORY: Coordinate = {
latitude: 51.47684676353231,
longitude: -0.0005261695762532147,
}

const EMPIRE_STATE_BUILDING: Coordinate = {
latitude: 40.748585815569854,
longitude: -73.9856543574467,
}

const tileSize = { width: 256, height: 256 }

export default function App() {
const ref = useRef(null)

const [zoom, setZoom] = useZoom({ ref, defaultZoom: 6 })
const [center, setCenter] = useDrag({
ref,
defaultCenter: GREENWICH_OBSERVATORY,
zoom,
tileSize
})

useClick({
ref,
center,
zoom,
tileSize,
onClick: (coordinate: Coordinate, point: Point) => {
console.log('click', { coordinate, point })
},
onDoubleClick: (coordinate: Coordinate, point: Point) => {
// Center and zoom to the double clicked point.
setCenter(coordinate)
setZoom(zoom + 1)
}
})

return (





}
/>
}
/>




)
}
```

### Hooks

As shown in the example above some hooks are provided for interacting with the map.

The hooks are intentionally primitive. There are a number of excellent packages
which can achieve this.

## Acknowledgements

This is largely a reworking of other libraries.

In particular much of the heavy lifting was done by [Pigeon Maps](https://github.com/mariusandra/pigeon-maps).

Another library which was a good source of ideas was [react-slippy-map](https://github.com/gaswelder/react-slippy-map).