This release requires Leaflet v1.1 in order to support the newly added features such as dynamic z-index in ImageOverlay
and the VideoOverlay
layer, exposed by React-Leaflet as a component.
The prop-types
package is now set as a peer dependency rather than a direct dependency, so you will need to add it to your application dependencies if not already set.
This release changes the way Leaflet elements are created and updated internally. If you are only using public APIs, nothing should change, however if you are extending or creating custom components, you should now use the added createLeafletElement()
and updateLeafletElement()
methods described in the Extending section of the documentation rather than overriding the lifecycle hooks directly.
See the relevant commit for more details about the changes involved.
React-Leaflet v1 requires Leaflet v1.0.0 and therefore contains breaking changes from v0.12, based on Leaflet v0.7.
Make sure to update your Leaflet dependency to v1.0.0, as well as its CSS file.
The following list includes breaking changes upgrading to React-Leaflet v1.0 from v0.12, it may not be exhaustive:
- Renamed
GeoJson
toGeoJSON
to match Leaflet's change. - Removed
MultiPolygon
andMultiPolyline
, now supported byPolygon
andPolyline
respectively. - Removed
CanvasTileLayer
, replaced byGridLayer
. See Leaflet's documentation. - Removed
getLeafletElement()
method inMapComponent
andMapControl
, deprecated since v0.12.0. - Removed
setIconDefaultImagePath()
helper, setLeaflet.Icon.Default.imagePath
directly using Leaflet if you need.
Read the changelog for more details about these changes.
Drop support for IE <= 10 as explained in this comment.
Deprecated: the getLeafletElement()
method on components is deprecated, you can simply use the leafletElement
property instead.
The major change in this version is the use of context instead of props to pass Leaflet instances from components to their children.
If you are only using the components provided by React-Leaflet, everything should continue to work as before.
If you are using custom components, you may have to update your code to provide or access the map
, layerContainer
and popupContainer
using context.
For example, using React-Leaflet < 0.12, you would need to do:
// layerContainer and map need to be passed to Marker
const MyPopupMarker = ({ layerContainer, map, position, children }) => (
<Marker layerContainer={layerContainer} map={map} position={position}>
<Popup>
<span>{children}</span>
</Popup>
</Marker>
)
// layerContainer and map need to be passed through to its children
const MyMarkersList = ({ layerContainer, map, markers }) => {
const items = markers.map(({ key, ...props }) => (
<MyPopupMarker key={key} layerContainer={layerContainer} map={map} {...props} />
))
return <div style={{display: 'none'}}>{items}</div>
}
const CustomComponent = () => {
const markers = [
{key: 'marker1', position: [51.5, -0.1], children: 'My first popup'},
{key: 'marker2', position: [51.51, -0.1], children: 'My second popup'},
{key: 'marker3', position: [51.49, -0.05], children: 'My third popup'},
]
return (
<Map center={[51.51, -0.1]} zoom={10}>
<TileLayer
attribution='© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
url='http://{s}.tile.osm.org/{z}/{x}/{y}.png'
/>
<MyMarkersList markers={markers} />
</Map>
)
}
Using React-Leaflet >= 0.12, it becomes simpler:
// Marker will get `layerContainer` and `map` from context
const MyPopupMarker = ({ children, position }) => (
<Marker position={position}>
<Popup>
<span>{children}</span>
</Popup>
</Marker>
)
// No need to inject `layerContainer` and `map` props to the children
const MyMarkersList = ({ markers }) => {
const items = markers.map(({ key, ...props }) => (
<MyPopupMarker key={key} {...props} />
))
return <div style={{display: 'none'}}>{items}</div>
}