@goongmaps/goong-geocoder-reat
React wrapper for @goongmaps/goong-geocoder for use with @goongmaps/goong-map-react.
Installation
NPM
$ npm install @goongmaps/goong-geocoder-react
or
Yarn
$ yarn add @goongmaps/goong-geocoder-react
Styling
Import:
import '@goongmaps/goong-geocoder-react/dist/goong-geocoder.css'
or
Link tag in header:
<link href='https://unpkg.com/@goongmaps/[email protected]/dist/goong-geocoder.css' rel='stylesheet' />
Props
Only mapRef
and goongApiAccessToken
are required.
Name | Type | Default | Description |
---|---|---|---|
mapRef | Object | Ref for react-map-gl map component. | |
containerRef | Object | This can be used to place the geocoder outside of the map. The position prop is ignored if this is passed in. |
|
onViewportChange | Function | () => {} | Is passed updated viewport values after executing a query. |
goongApiAccessToken | String | https://account.goong.io | |
inputValue | String | Sets the search input value | |
origin | String | "https://rsapi.goong.io" | Use to set a custom API origin. |
zoom | Number | 14 | On geocoded result what zoom level should the map animate to |
radius | Number | 3000 | Distance by kilometers around map center |
placeholder | String | "Search" | Override the default placeholder attribute value. |
proximity | Object | A proximity argument: this is a geographical point given as an object with latitude and longitude properties. Search results closer to this point will be given higher priority. | |
trackProximity | Boolean | false | If true, the geocoder proximity will automatically update based on the map view. |
collapsed | Boolean | false | If true, the geocoder control will collapse until hovered or in focus. |
clearAndBlurOnEsc | Boolean | false | If true, the geocoder control will clear it's contents and blur when user presses the escape key. |
clearOnBlur | Boolean | false | If true, the geocoder control will clear its value when the input blurs. |
minLength | Number | 2 | Minimum number of characters to enter before results are shown. |
limit | Number | 5 | Maximum number of results to show. |
render | Function | A function that specifies how the results should be rendered in the dropdown menu. Accepts a single Carmen GeoJSON object as input and return a string. Any html in the returned string will be rendered. Uses goong-geocoder's default rendering if no function provided. | |
position | String | "top-right" | Position on the map to which the geocoder control will be added. Valid values are "top-left" , "top-right" , "bottom-left" , and "bottom-right" . |
onInit | Function | () => {} | Is passed Goong geocoder instance as param and is executed after Goong geocoder is initialized. |
onClear | Function | () => {} | Executed when the input is cleared. |
onLoading | Function | () => {} | Is passed { query } as a param and is executed when the geocoder is looking up a query. |
onResults | Function | () => {} | Is passed { results } as a param and is executed when the geocoder returns a response. |
onResult | Function | () => {} | Is passed { result } as a param and is executed when the geocoder input is set. |
onError | Function | () => {} | Is passed { error } as a param and is executed when an error occurs with the geocoder. |
Example
import '@goongmaps/goong-js/dist/goong-js.css'
import '@goongmaps/goong-geocoder/dist/goong-geocoder.css'
import React, { Component } from 'react'
import MapGL from '@goongmaps/goong-map-react'
import Geocoder from '@goongmaps/goong-geocoder-react'
class Example extends Component {
state = {
viewport: {
latitude: 21.026975,
longitude: 105.853460,
zoom: 12
}
}
mapRef = React.createRef()
handleViewportChange = (viewport) => {
this.setState({
viewport: { ...this.state.viewport, ...viewport }
})
}
// if you are happy with Geocoder default settings, you can just use handleViewportChange directly
handleGeocoderViewportChange = (viewport) => {
const geocoderDefaultOverrides = { transitionDuration: 1000 }
return this.handleViewportChange({
...viewport,
...geocoderDefaultOverrides
})
}
render() {
return (
<MapGL
ref={this.mapRef}
{...this.state.viewport}
width="100%"
height="100%"
onViewportChange={this.handleViewportChange}
goongApiAccessToken='YOUR_MAPTILES_KEY'>
<Geocoder
mapRef={this.mapRef}
onViewportChange={this.handleGeocoderViewportChange}
goongApiAccessToken='YOUR_API_KEY'
/>
</MapGL>
)
}
}
export default Example