/ˈfōlēˌō/
Map configuration is the map state
folio is a Leaflet wrapper library for React. The basic idea behind folio is to address the problem that the Leaflet library gives you dozens of ways of updating the state of your map, with slightly different APIs, and the state of the map can change but the configuration of the map can stay the same. This can make Leaflet a chore to use in React components.
This library aims to to make it easy to use Leaflet maps in React components and let you manage the map state the same way you would manage the component state.
npm install folio-leaflet
export default class App extends Component {
state = {
schema: {
adapter: LMap,
config: {
name: 'myMap',
style: {width: '100%', height: 800},
className: 'myMap'
},
options: {
zoom: 13,
center: [51.5, -0.09],
zoomControl: true
}
},
decks: [
{
adapter: LTile,
config: {
name: 'Basemap',
url: 'http://{s}.tile.osm.org/{z}/{x}/{y}.png'
},
options: {
attribution: '© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
}
}
]
}
render() {
return <Folio schema={this.state.schema} decks={this.state.decks} />
}
}
In folio, a deck is the term for a configuration object for a Leaflet map element, e.g. layer, control, overlay, marker, etc.
Deck is a simple Javascript object and it looks like this:
{
adapter: LTile,
// Used for the internal configuration of the Deck
config: {
name: 'Basemap',
url: 'http://{s}.tile.osm.org/{z}/{x}/{y}.png'
},
// Leaflet options
options: {
attribution: '© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
}
}
You should use decks to configure any of these elements, with the notable exception of the 'map' itself. For that, you need to use schema.
Schema has exactly the same interface as deck, but it's used exclusively for configuring the map.
{
adapter: LMap,
config: {
name: 'myMap',
style: {width: '100%', height: 800},
className: 'myMap'
},
options: {
zoom: 13,
center: [51.5, -0.09],
zoomControl: true
}
}
Each deck includes an adapter, which provides the bridge to Leaflet. An adapter is a function that takes an object as a function and returns three methods: create, update, and remove.
export default function({ config: c, options: o }) {
return {
create: ({owner: ow}) => { },
update: ({element: e}) => { },
remove: ({element: e, owner: ow}) => { }
};
}
Check out the adapters folder for a full list of available adapters.
Other interfaces on the domain can be found here.