X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/c3d1123965b2d9bc34299c3a6c64d186c62c0ed2..e96a64ca9c2ea068dd9167e074ee26c8d28744b4:/app/assets/javascripts/osm.js.erb diff --git a/app/assets/javascripts/osm.js.erb b/app/assets/javascripts/osm.js.erb index 3c3378f98..81c1e3152 100644 --- a/app/assets/javascripts/osm.js.erb +++ b/app/assets/javascripts/osm.js.erb @@ -1,17 +1,31 @@ OSM = { <% if defined?(PIWIK_LOCATION) and defined?(PIWIK_SITE) %> - PIWIK_LOCATION: <%= PIWIK_LOCATION.to_json %>, - PIWIK_SITE: <%= PIWIK_SITE.to_json %>, + PIWIK_LOCATION: <%= PIWIK_LOCATION.to_json %>, + PIWIK_SITE: <%= PIWIK_SITE.to_json %>, <% end %> - MAX_REQUEST_AREA: <%= MAX_REQUEST_AREA.to_json %>, - SERVER_URL: <%= SERVER_URL.to_json %>, - API_VERSION: <%= API_VERSION.to_json %>, + MAX_REQUEST_AREA: <%= MAX_REQUEST_AREA.to_json %>, + SERVER_URL: <%= SERVER_URL.to_json %>, + API_VERSION: <%= API_VERSION.to_json %>, + STATUS: <%= STATUS.to_json %>, + MAX_NOTE_REQUEST_AREA: <%= MAX_NOTE_REQUEST_AREA.to_json %>, + + apiUrl: function (object) { + var url = "/api/" + OSM.API_VERSION + "/" + object.type + "/" + object.id; + + if (object.type != "node") { + url += "/full"; + } else if (object.version) { + url += "/" + object.version; + } + + return url; + }, mapParams: function (search) { var params = {}, mapParams = {}, loc; - search = (search || window.location.search).replace('?', '').split('&'); + search = (search || window.location.search).replace('?', '').split(/&|;/); for (var i = 0; i < search.length; ++i) { var pair = search[i], @@ -32,18 +46,14 @@ OSM = { } if (params.node || params.way || params.relation) { - mapParams.object = true; mapParams.object_zoom = true; if (params.node) { - mapParams.object_type = 'node'; - mapParams.object_id = parseInt(params.node); + mapParams.object = {type: 'node', id: parseInt(params.node)}; } else if (params.way) { - mapParams.object_type = 'way'; - mapParams.object_id = parseInt(params.way); + mapParams.object = {type: 'way', id: parseInt(params.way)}; } else if (params.relation) { - mapParams.object_type = 'relation'; - mapParams.object_id = parseInt(params.relation); + mapParams.object = {type: 'relation', id: parseInt(params.relation)}; } } @@ -101,6 +111,12 @@ OSM = { mapParams.lat = (mapParams.minlat + mapParams.maxlat) / 2; } + mapParams.notes = params.notes == "yes"; + + if (params.note) { + mapParams.note = parseInt(params.note); + } + var scale = parseFloat(params.scale); if (scale > 0) { mapParams.zoom = Math.log(360.0 / (scale * 512.0)) / Math.log(2.0);