Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/rob-blackbourn/jetblack-map
- Owner: rob-blackbourn
- Created: 2022-06-02T07:22:18.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-09-12T06:00:37.000Z (over 1 year ago)
- Last Synced: 2024-10-01T14:59:28.697Z (4 months ago)
- Topics: map, openstreetmap, osm, react, react-component, reactjs, slippy-map, slippy-tiles, tiles
- Language: TypeScript
- Homepage: https://rob-blackbourn.github.io/jetblack-map/
- Size: 3.61 MB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
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).