From 50564e3d0290604278e694e3f250b92e1499ede9 Mon Sep 17 00:00:00 2001 From: Anton Khorev Date: Thu, 21 Nov 2024 20:08:43 +0300 Subject: [PATCH] Collect map layer credits into a data structure --- app/assets/javascripts/leaflet.map.js | 157 +++++++++++++++++--------- 1 file changed, 102 insertions(+), 55 deletions(-) diff --git a/app/assets/javascripts/leaflet.map.js b/app/assets/javascripts/leaflet.map.js index a907de29581..a4d5aae4b6b 100644 --- a/app/assets/javascripts/leaflet.map.js +++ b/app/assets/javascripts/leaflet.map.js @@ -15,67 +15,69 @@ L.OSM.Map = L.Map.extend({ initialize: function (id, options) { L.Map.prototype.initialize.call(this, id, options); - var copyright_link = $("", { - href: "/copyright", - text: I18n.t("javascripts.map.openstreetmap_contributors") - }).prop("outerHTML"); - var copyright = I18n.t("javascripts.map.copyright_text", { copyright_link: copyright_link }); - - var donate = $("", { - "href": "https://supporting.openstreetmap.org", - "class": "donate-attr", - "text": I18n.t("javascripts.map.make_a_donation") - }).prop("outerHTML"); - - var terms = $("", { - href: "https://wiki.osmfoundation.org/wiki/Terms_of_Use", - text: I18n.t("javascripts.map.website_and_api_terms") - }).prop("outerHTML"); - - var cyclosm_link = $("", { - href: "https://www.cyclosm.org", - target: "_blank", - text: I18n.t("javascripts.map.cyclosm_name") - }).prop("outerHTML"); - var osm_france_link = $("", { - href: "https://openstreetmap.fr/", - target: "_blank", - text: I18n.t("javascripts.map.osm_france") - }).prop("outerHTML"); - var cyclosm = I18n.t("javascripts.map.cyclosm_credit", { cyclosm_link: cyclosm_link, osm_france_link: osm_france_link }); - - var thunderforest_link = $("", { - href: "https://www.thunderforest.com/", - target: "_blank", - text: I18n.t("javascripts.map.andy_allan") - }).prop("outerHTML"); - var thunderforest = I18n.t("javascripts.map.thunderforest_credit", { thunderforest_link: thunderforest_link }); - - var tracestrack_link = $("", { - href: "https://www.tracestrack.com/", - target: "_blank", - text: I18n.t("javascripts.map.tracestrack") - }).prop("outerHTML"); - var tracestrack = I18n.t("javascripts.map.tracestrack_credit", { tracestrack_link: tracestrack_link }); - - var hotosm_link = $("", { - href: "https://www.hotosm.org/", - target: "_blank", - text: I18n.t("javascripts.map.hotosm_name") - }).prop("outerHTML"); - var hotosm = I18n.t("javascripts.map.hotosm_credit", { hotosm_link: hotosm_link, osm_france_link: osm_france_link }); + const layerCredits = { + mapnik: { + id: "make_a_donation", + href: "https://supporting.openstreetmap.org", + donate: true + }, + cyclosm: { + id: "cyclosm_credit", + children: { + cyclosm_link: { + id: "cyclosm_name", + href: "https://www.cyclosm.org" + }, + osm_france_link: { + id: "osm_france", + href: "https://openstreetmap.fr/" + } + } + }, + thunderforest: { + id: "thunderforest_credit", + children: { + thunderforest_link: { + id: "andy_allan", + href: "https://www.thunderforest.com/" + } + } + }, + tracestrack: { + id: "tracestrack_credit", + children: { + tracestrack_link: { + id: "tracestrack", + href: "https://www.tracestrack.com/" + } + } + }, + hotosm: { + id: "hotosm_credit", + children: { + hotosm_link: { + id: "hotosm_name", + href: "https://www.hotosm.org/" + }, + osm_france_link: { + id: "osm_france", + href: "https://openstreetmap.fr/" + } + } + } + } this.baseLayers = []; this.baseLayers.push(new L.OSM.Mapnik({ - attribution: copyright + " ♥ " + donate + ". " + terms, + attribution: makeAttribution("mapnik"), code: "M", keyid: "mapnik", name: I18n.t("javascripts.map.base.standard") })); this.baseLayers.push(new L.OSM.CyclOSM({ - attribution: copyright + ". " + cyclosm + ". " + terms, + attribution: makeAttribution("cyclosm"), code: "Y", keyid: "cyclosm", name: I18n.t("javascripts.map.base.cyclosm") @@ -83,7 +85,7 @@ L.OSM.Map = L.Map.extend({ if (OSM.THUNDERFOREST_KEY) { this.baseLayers.push(new L.OSM.CycleMap({ - attribution: copyright + ". " + thunderforest + ". " + terms, + attribution: makeAttribution("thunderforest"), apikey: OSM.THUNDERFOREST_KEY, code: "C", keyid: "cyclemap", @@ -91,7 +93,7 @@ L.OSM.Map = L.Map.extend({ })); this.baseLayers.push(new L.OSM.TransportMap({ - attribution: copyright + ". " + thunderforest + ". " + terms, + attribution: makeAttribution("thunderforest"), apikey: OSM.THUNDERFOREST_KEY, code: "T", keyid: "transportmap", @@ -101,7 +103,7 @@ L.OSM.Map = L.Map.extend({ if (OSM.TRACESTRACK_KEY) { this.baseLayers.push(new L.OSM.TracestrackTopo({ - attribution: copyright + ". " + tracestrack + ". " + terms, + attribution: makeAttribution("tracestrack"), apikey: OSM.TRACESTRACK_KEY, code: "P", keyid: "tracestracktopo", @@ -110,7 +112,7 @@ L.OSM.Map = L.Map.extend({ } this.baseLayers.push(new L.OSM.HOT({ - attribution: copyright + ". " + hotosm + ". " + terms, + attribution: makeAttribution("hotosm"), code: "H", keyid: "hot", name: I18n.t("javascripts.map.base.hot") @@ -132,6 +134,51 @@ L.OSM.Map = L.Map.extend({ this.setMaxZoom(event.layer.options.maxZoom); } }); + + function makeAttribution(id) { + const layerCredit = layerCredits[id]; + let attribution = ""; + + attribution += I18n.t("javascripts.map.copyright_text", { + copyright_link: $("", { + href: "/copyright", + text: I18n.t("javascripts.map.openstreetmap_contributors") + }).prop("outerHTML") + }); + + attribution += layerCredit.donate ? " ♥ " : ". "; + attribution += makeCredit(layerCredit); + attribution += ". "; + + attribution += $("", { + href: "https://wiki.osmfoundation.org/wiki/Terms_of_Use", + text: I18n.t("javascripts.map.website_and_api_terms") + }).prop("outerHTML"); + + return attribution; + } + + function makeCredit(credit) { + const children = {}; + for (childId in credit.children) { + children[childId] = makeCredit(credit.children[childId]); + } + const text = I18n.t(`javascripts.map.${credit.id}`, children); + if (credit.href) { + const link = $("", { + href: credit.href, + text: text + }); + if (credit.donate) { + link.addClass("donate-attr"); + } else { + link.attr("target", "_blank"); + } + return link.prop("outerHTML"); + } else { + return text; + } + } }, updateLayers: function (layerParam) {