map: define layers in config.js
This commit is contained in:
parent
9ea5d67bf2
commit
3954ec5eaf
@ -67,6 +67,13 @@ Setting this to `false` will hide contact information for nodes.
|
|||||||
Nodes being online for less than maxAge days are considered "new". Likewise,
|
Nodes being online for less than maxAge days are considered "new". Likewise,
|
||||||
nodes being offline for less than than maxAge days are considered "lost".
|
nodes being offline for less than than maxAge days are considered "lost".
|
||||||
|
|
||||||
|
## mapLayers (List)
|
||||||
|
|
||||||
|
A list of objects describing map layers. Each object has at least `name`
|
||||||
|
property and optionally `url` and `config` properties. If no `url` is supplied
|
||||||
|
`name` is assumed to name a
|
||||||
|
[Leaflet-provider](http://leaflet-extras.github.io/leaflet-providers/preview/).
|
||||||
|
|
||||||
## nodeInfos (array, optional)
|
## nodeInfos (array, optional)
|
||||||
|
|
||||||
This option allows to show client statistics depending on following case-sensitive parameters:
|
This option allows to show client statistics depending on following case-sensitive parameters:
|
||||||
|
@ -3,5 +3,19 @@ define({
|
|||||||
"siteName": "Freifunk Lübeck",
|
"siteName": "Freifunk Lübeck",
|
||||||
"mapSigmaScale": 0.5,
|
"mapSigmaScale": 0.5,
|
||||||
"showContact": true,
|
"showContact": true,
|
||||||
"maxAge": 14
|
"maxAge": 14,
|
||||||
|
"mapLayers": [
|
||||||
|
{ "name": "MapQuest",
|
||||||
|
"url": "https://otile{s}-s.mqcdn.com/tiles/1.0.0/osm/{z}/{x}/{y}.jpg",
|
||||||
|
"config": {
|
||||||
|
"subdomains": "1234",
|
||||||
|
"type": "osm",
|
||||||
|
"attribution": "Tiles © <a href=\"https://www.mapquest.com/\" target=\"_blank\">MapQuest</a>, Data CC-BY-SA OpenStreetMap",
|
||||||
|
"maxZoom": 18
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Stamen.TonerLite"
|
||||||
|
}
|
||||||
|
]
|
||||||
})
|
})
|
||||||
|
30
lib/map.js
30
lib/map.js
@ -129,6 +129,7 @@ define(["map/clientlayer", "map/labelslayer",
|
|||||||
var map, userLocation
|
var map, userLocation
|
||||||
var layerControl
|
var layerControl
|
||||||
var customLayers = new Set()
|
var customLayers = new Set()
|
||||||
|
var baseLayers = {}
|
||||||
|
|
||||||
var locateUserButton = new LocateButton(function (d) {
|
var locateUserButton = new LocateButton(function (d) {
|
||||||
if (d)
|
if (d)
|
||||||
@ -186,6 +187,9 @@ define(["map/clientlayer", "map/labelslayer",
|
|||||||
}
|
}
|
||||||
|
|
||||||
function addLayer(layerName) {
|
function addLayer(layerName) {
|
||||||
|
if (layerName in baseLayers)
|
||||||
|
return
|
||||||
|
|
||||||
if (customLayers.has(layerName))
|
if (customLayers.has(layerName))
|
||||||
return
|
return
|
||||||
|
|
||||||
@ -212,12 +216,18 @@ define(["map/clientlayer", "map/labelslayer",
|
|||||||
|
|
||||||
map = L.map(el, options)
|
map = L.map(el, options)
|
||||||
|
|
||||||
var baseLayer = L.tileLayer("https://otile{s}-s.mqcdn.com/tiles/1.0.0/osm/{z}/{x}/{y}.jpg", {
|
var layers = config.mapLayers.map( function (d) {
|
||||||
subdomains: "1234",
|
return {
|
||||||
type: "osm",
|
"name": d.name,
|
||||||
attribution: "Tiles © <a href=\"https://www.mapquest.com/\" target=\"_blank\">MapQuest</a>, Data CC-BY-SA OpenStreetMap",
|
"layer": "url" in d ? L.tileLayer(d.url, d.config) : L.tileLayer.provider(d.name)
|
||||||
maxZoom: 18
|
}
|
||||||
}).addTo(map)
|
})
|
||||||
|
|
||||||
|
layers[0].layer.addTo(map)
|
||||||
|
|
||||||
|
layers.forEach( function (d) {
|
||||||
|
baseLayers[d.name] = d.layer
|
||||||
|
})
|
||||||
|
|
||||||
map.on("locationfound", locationFound)
|
map.on("locationfound", locationFound)
|
||||||
map.on("locationerror", locationError)
|
map.on("locationerror", locationError)
|
||||||
@ -231,13 +241,13 @@ define(["map/clientlayer", "map/labelslayer",
|
|||||||
addLayer(layerName)
|
addLayer(layerName)
|
||||||
}))
|
}))
|
||||||
|
|
||||||
layerControl = L.control.layers({"MapQuest": baseLayer}, [], {position: "bottomright"})
|
layerControl = L.control.layers(baseLayers, [], {position: "bottomright"})
|
||||||
|
|
||||||
if (localStorageTest()) {
|
if (localStorageTest()) {
|
||||||
var layers = JSON.parse(localStorage.getItem("map/customLayers"))
|
var d = JSON.parse(localStorage.getItem("map/customLayers"))
|
||||||
|
|
||||||
if (layers)
|
if (d)
|
||||||
layers.forEach(addLayer)
|
d.forEach(addLayer)
|
||||||
}
|
}
|
||||||
|
|
||||||
var clientLayer = new ClientLayer({minZoom: 15})
|
var clientLayer = new ClientLayer({minZoom: 15})
|
||||||
|
Loading…
Reference in New Issue
Block a user