X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/5c086dad6ed20bdd877ae53251ff8a097b61cc9a..31f4ab5c466bcbafb940db5668627f9922beaaba:/app/assets/javascripts/leaflet.layers.js diff --git a/app/assets/javascripts/leaflet.layers.js b/app/assets/javascripts/leaflet.layers.js index 5c5e43c5c..1a34b05c2 100644 --- a/app/assets/javascripts/leaflet.layers.js +++ b/app/assets/javascripts/leaflet.layers.js @@ -1,55 +1,34 @@ L.OSM.layers = function (options) { - var control = L.control(options); + var control = L.OSM.sidebarPane(options, "layers", "javascripts.map.layers.title", "javascripts.map.layers.header"); - control.onAdd = function (map) { + control.onAddPane = function (map, button, $ui, toggle) { var 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 = $("
") - .attr("class", "layers-ui"); - - $("
") - .attr("class", "sidebar_heading") - .appendTo($ui) - .append( - $("") - .text(I18n.t("javascripts.close")) - .attr("class", "icon close") - .bind("click", toggle)) - .append( - $("

") - .text(I18n.t("javascripts.map.layers.header"))); - var baseSection = $("
") - .attr("class", "section base-layers") + .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) { + var id = "map-ui-layer-" + i; + + var buttonContainer = $("
    ") + .appendTo(baseSection); - layers.forEach(function (layer) { - var item = $("
  • ") - .appendTo(baseLayers); + var mapContainer = $("
    ") + .appendTo(buttonContainer); - if (map.hasLayer(layer)) { - item.addClass("active"); - } + var input = $("") + .prop("id", id) + .prop("checked", map.hasLayer(layer)) + .appendTo(buttonContainer); - var div = $("
    ") - .appendTo(item); + var item = $("
  • ") - .tooltip({ - placement: "top" - }) .appendTo(overlays); + if (name === "notes" || name === "data") { + item + .attr("title", I18n.t("javascripts.site.map_" + name + "_zoom_in_tooltip")) + .tooltip("disable"); + } + var label = $("