Use array in L.Control.Layers to preserve layer order fixes #2086
This commit is contained in:
parent
e083d41ff7
commit
0bed05d537
51
debug/map/control-layers.html
Normal file
51
debug/map/control-layers.html
Normal file
@ -0,0 +1,51 @@
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>Leaflet debug page</title>
|
||||
|
||||
<link rel="stylesheet" href="../../dist/leaflet.css" />
|
||||
|
||||
<link rel="stylesheet" href="../css/screen.css" />
|
||||
|
||||
<script type="text/javascript" src="../../build/deps.js"></script>
|
||||
<script src="../leaflet-include.js"></script>
|
||||
</head>
|
||||
<body>
|
||||
<div id="map"></div>
|
||||
|
||||
<script type="text/javascript">
|
||||
var geojson = {
|
||||
"type": "Polygon",
|
||||
"coordinates": [[
|
||||
[5.4931640625, 51.781435604431195],
|
||||
[0.9008789062499999, 53.35710874569601],
|
||||
[-2.30712890625, 51.795027225829145],
|
||||
[2.8125, 49.109837790524416],
|
||||
[5.4931640625, 51.781435604431195]
|
||||
]]
|
||||
};
|
||||
|
||||
var map = L.map('map').setView([50.5, 0], 5);
|
||||
|
||||
var OSM_Mapnik = L.tileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
|
||||
maxZoom: 19,
|
||||
attribution: '© <a href="http://www.openstreetmap.org/copyright">OpenStreetMap</a>'
|
||||
}).addTo(map);
|
||||
var OSM_BlackAndWhite = L.tileLayer('http://{s}.tiles.wmflabs.org/bw-mapnik/{z}/{x}/{y}.png', {
|
||||
maxZoom: 18,
|
||||
attribution: '© <a href="http://www.openstreetmap.org/copyright">OpenStreetMap</a>'
|
||||
});
|
||||
|
||||
L.control.layers({
|
||||
'OSM': OSM_Mapnik,
|
||||
'OSM BW': OSM_BlackAndWhite
|
||||
}, {
|
||||
'Circle': L.circle([53, 4], 111111).addTo(map),
|
||||
'Polygon': L.polygon([[48, -3], [50, -4], [52, 4]]),
|
||||
'GeoJSON': L.geoJson(geojson),
|
||||
}, {
|
||||
collapsed: false
|
||||
}).addTo(map);
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
@ -4,6 +4,9 @@ describe("Control.Layers", function () {
|
||||
beforeEach(function () {
|
||||
map = L.map(document.createElement('div'));
|
||||
});
|
||||
afterEach(function () {
|
||||
map.remove();
|
||||
});
|
||||
|
||||
describe("baselayerchange event", function () {
|
||||
beforeEach(function () {
|
||||
@ -43,7 +46,7 @@ describe("Control.Layers", function () {
|
||||
map.setView([0, 0], 14);
|
||||
});
|
||||
|
||||
it("when an included layer is addded or removed", function () {
|
||||
it("when an included layer is added or removed from the map", function () {
|
||||
var baseLayer = L.tileLayer(),
|
||||
overlay = L.marker([0, 0]),
|
||||
layers = L.control.layers({"Base": baseLayer}, {"Overlay": overlay}).addTo(map);
|
||||
@ -57,6 +60,23 @@ describe("Control.Layers", function () {
|
||||
expect(spy.callCount).to.eql(2);
|
||||
});
|
||||
|
||||
it("when an included layer is added or removed from the map, it's (un)checked", function () {
|
||||
document.body.appendChild(map._container);
|
||||
var baseLayer = L.tileLayer(),
|
||||
overlay = L.marker([0, 0]),
|
||||
layers = L.control.layers({"Baselayer": baseLayer}, {"Overlay": overlay}).addTo(map);
|
||||
|
||||
function isChecked() {
|
||||
return !!(map._container.querySelector('.leaflet-control-layers-overlays input').checked);
|
||||
}
|
||||
|
||||
expect(isChecked()).to.not.be.ok();
|
||||
map.addLayer(overlay);
|
||||
expect(isChecked()).to.be.ok();
|
||||
map.removeLayer(overlay);
|
||||
expect(isChecked()).to.not.be.ok();
|
||||
});
|
||||
|
||||
it("not when a non-included layer is added or removed", function () {
|
||||
var baseLayer = L.tileLayer(),
|
||||
overlay = L.marker([0, 0]),
|
||||
@ -69,6 +89,17 @@ describe("Control.Layers", function () {
|
||||
|
||||
expect(spy.called).to.not.be.ok();
|
||||
});
|
||||
|
||||
it("updates when an included layer is removed from the control", function () {
|
||||
document.body.appendChild(map._container);
|
||||
var baseLayer = L.tileLayer(),
|
||||
overlay = L.marker([0, 0]),
|
||||
layers = L.control.layers({"Base": baseLayer}, {"Overlay": overlay}).addTo(map);
|
||||
|
||||
layers.removeLayer(overlay);
|
||||
expect(map._container.querySelector('.leaflet-control-layers-overlays').children.length)
|
||||
.to.be.equal(0);
|
||||
});
|
||||
});
|
||||
|
||||
describe("is removed cleanly", function () {
|
||||
@ -84,7 +115,6 @@ describe("Control.Layers", function () {
|
||||
expect(function () {
|
||||
map.removeLayer(baseLayer);
|
||||
}).to.not.throwException();
|
||||
|
||||
});
|
||||
});
|
||||
|
||||
|
@ -59,7 +59,7 @@ L.Control.Layers = L.Control.extend({
|
||||
initialize: function (baseLayers, overlays, options) {
|
||||
L.setOptions(this, options);
|
||||
|
||||
this._layers = {};
|
||||
this._layers = [];
|
||||
this._lastZIndex = 0;
|
||||
this._handlingClick = false;
|
||||
|
||||
@ -109,7 +109,8 @@ L.Control.Layers = L.Control.extend({
|
||||
removeLayer: function (layer) {
|
||||
layer.off('add remove', this._onLayerChange, this);
|
||||
|
||||
delete this._layers[L.stamp(layer)];
|
||||
var obj = this._getLayer(L.stamp(layer));
|
||||
this._layers.splice(this._layers.indexOf(obj), 1);
|
||||
return (this._map) ? this._update() : this;
|
||||
},
|
||||
|
||||
@ -188,16 +189,22 @@ L.Control.Layers = L.Control.extend({
|
||||
container.appendChild(form);
|
||||
},
|
||||
|
||||
_getLayer: function (id) {
|
||||
for (var i = 0; i <= this._layers.length; i++) {
|
||||
if (L.stamp(this._layers[i].layer) === id) {
|
||||
return this._layers[i];
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
_addLayer: function (layer, name, overlay) {
|
||||
layer.on('add remove', this._onLayerChange, this);
|
||||
|
||||
var id = L.stamp(layer);
|
||||
|
||||
this._layers[id] = {
|
||||
this._layers.push({
|
||||
layer: layer,
|
||||
name: name,
|
||||
overlay: overlay
|
||||
};
|
||||
});
|
||||
|
||||
if (this.options.autoZIndex && layer.setZIndex) {
|
||||
this._lastZIndex++;
|
||||
@ -237,7 +244,7 @@ L.Control.Layers = L.Control.extend({
|
||||
this._update();
|
||||
}
|
||||
|
||||
var obj = this._layers[L.stamp(e.target)];
|
||||
var obj = this._getLayer(L.stamp(e.target));
|
||||
|
||||
// @namespace Map
|
||||
// @section Layer events
|
||||
@ -315,7 +322,7 @@ L.Control.Layers = L.Control.extend({
|
||||
|
||||
for (var i = inputs.length - 1; i >= 0; i--) {
|
||||
input = inputs[i];
|
||||
layer = this._layers[input.layerId].layer;
|
||||
layer = this._getLayer(input.layerId).layer;
|
||||
hasLayer = this._map.hasLayer(layer);
|
||||
|
||||
if (input.checked && !hasLayer) {
|
||||
@ -347,7 +354,7 @@ L.Control.Layers = L.Control.extend({
|
||||
|
||||
for (var i = inputs.length - 1; i >= 0; i--) {
|
||||
input = inputs[i];
|
||||
layer = this._layers[input.layerId].layer;
|
||||
layer = this._getLayer(input.layerId).layer;
|
||||
input.disabled = (layer.options.minZoom !== undefined && zoom < layer.options.minZoom) ||
|
||||
(layer.options.maxZoom !== undefined && zoom > layer.options.maxZoom);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user