X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/8a02bd67d9d20c4a6b01b58e88b8d65163a3798e..b4a9d7537785f1b44ea4db42bed69127fbe323ae:/app/assets/javascripts/leaflet.layers.js diff --git a/app/assets/javascripts/leaflet.layers.js b/app/assets/javascripts/leaflet.layers.js index 518cdc7f1..f7142ead1 100644 --- a/app/assets/javascripts/leaflet.layers.js +++ b/app/assets/javascripts/leaflet.layers.js @@ -1,43 +1,35 @@ L.OSM.layers = function (options) { - var control = L.OSM.sidebarPane(options); + const control = L.OSM.sidebarPane(options, "layers", "javascripts.map.layers.title", "javascripts.map.layers.header"); - control.onAdd = function (map) { - var layers = options.layers; + control.onAddPane = function (map, button, $ui, toggle) { + const layers = options.layers; - var $container = $("
") - .attr("class", "control-layers"); - - var button = $("") - .attr("class", "control-button") - .attr("href", "#") - .attr("title", I18n.t("javascripts.map.layers.title")) - .html("") - .on("click", toggle) - .appendTo($container); - - var $ui = this.makeUI("layers-ui", "javascripts.map.layers.header", toggle); - - var baseSection = $("
") - .attr("class", "section base-layers") + const baseSection = $("
") + .attr("class", "base-layers d-grid gap-3 p-3 border-bottom border-secondary-subtle") .appendTo($ui); - var baseLayers = $("
    ") - .appendTo(baseSection); + layers.forEach(function (layer, i) { + const id = "map-ui-layer-" + i; - layers.forEach(function (layer) { - var item = $("
  • ") - .appendTo(baseLayers); + const buttonContainer = $("
    ") + .appendTo(baseSection); - if (map.hasLayer(layer)) { - item.addClass("active"); - } + const mapContainer = $("
    ") + .appendTo(buttonContainer); + + const input = $("") + .prop("id", id) + .prop("checked", map.hasLayer(layer)) + .appendTo(buttonContainer); - var div = $("
    ") - .appendTo(item); + const item = $("