X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/1673851b50e2932f04891c8140af58464c2866c4..0dbd18e2bb685c432d775f186f114cf4f3de3ca4:/app/assets/javascripts/index/note.js.erb diff --git a/app/assets/javascripts/index/note.js.erb b/app/assets/javascripts/index/note.js.erb index 9afe3b5f8..aa746265c 100644 --- a/app/assets/javascripts/index/note.js.erb +++ b/app/assets/javascripts/index/note.js.erb @@ -1,101 +1,98 @@ -OSM.Note = function(map) { - var noteLayer = map.noteLayer, - content = $('#sidebar_content'), - page = {}, - marker; +OSM.Note = function (map) { + var noteLayer = map.noteLayer, + content = $('#sidebar_content'), + page = {}, + halo, currentNote; - var noteIcons = { - "new": L.icon({ - iconUrl: "<%= image_path('new_note_marker.png') %>", - iconSize: [25, 40], - iconAnchor: [12, 40] - }), - "open": L.icon({ - iconUrl: "<%= image_path('open_note_marker.png') %>", - iconSize: [25, 40], - iconAnchor: [12, 40] - }), - "closed": L.icon({ - iconUrl: "<%= image_path('closed_note_marker.png') %>", - iconSize: [25, 40], - iconAnchor: [12, 40] - }) - }; + var noteIcons = { + "new": L.icon({ + iconUrl: "<%= image_path('new_note_marker.png') %>", + iconSize: [25, 40], + iconAnchor: [12, 40] + }), + "open": L.icon({ + iconUrl: "<%= image_path('open_note_marker.png') %>", + iconSize: [25, 40], + iconAnchor: [12, 40] + }), + "closed": L.icon({ + iconUrl: "<%= image_path('closed_note_marker.png') %>", + iconSize: [25, 40], + iconAnchor: [12, 40] + }) + }; - function updateNote(marker, form, method, url) { - $(form).find("input[type=submit]").prop("disabled", true); + function updateNote(form, method, url) { + $(form).find("input[type=submit]").prop("disabled", true); - $.ajax({ - url: url, - type: method, - oauth: true, - data: {text: $(form.text).val()}, - success: function (feature) { - marker = noteLayer.getLayer(marker); - if (feature.properties.status == "hidden") { - noteLayer.removeLayer(marker); - } else { - marker.setIcon(noteIcons[feature.properties.status]); - page.load(); - } - } - }); - } - - function bind() { - content.find("input[type=submit]").on("click", function (e) { - e.preventDefault(); - var data = $(e.target).data(); - updateNote(data.noteId, e.target.form, data.method, data.url); - }); - - content.find("textarea").on("input", function (e) { - var form = e.target.form; + $.ajax({ + url: url, + type: method, + oauth: true, + data: {text: $(form.text).val()}, + success: function () { + OSM.loadSidebarContent(window.location.pathname, page.load); + } + }); + } - if ($(e.target).val() == "") { - $(form.close).val(I18n.t("javascripts.notes.show.resolve")); - $(form.comment).prop("disabled", true); - } else { - $(form.close).val(I18n.t("javascripts.notes.show.comment_and_resolve")); - $(form.comment).prop("disabled", false); - } - }); + page.pushstate = page.popstate = function (path) { + OSM.loadSidebarContent(path, page.load); + }; - content.find("textarea").val('').trigger("input"); - } + page.load = function () { + content.find("input[type=submit]").on("click", function (e) { + e.preventDefault(); + var data = $(e.target).data(); + updateNote(e.target.form, data.method, data.url); + }); - page.pushstate = page.popstate = function() { - page.load(); - }; + content.find("textarea").on("input", function (e) { + var form = e.target.form; - page.load = function(path, id) { - var loadTimer = setTimeout(setLoading, 250); - $('#sidebar_content').load(window.location.pathname + "?xhr=1", function(a, b, xhr) { - if (xhr.getResponseHeader('X-Page-Title')) { - document.title = xhr.getResponseHeader('X-Page-Title'); - } - bind(); - clearTimeout(loadTimer); - clearLoading(); + if ($(e.target).val() == "") { + $(form.close).val(I18n.t("javascripts.notes.show.resolve")); + $(form.comment).prop("disabled", true); + } else { + $(form.close).val(I18n.t("javascripts.notes.show.comment_and_resolve")); + $(form.comment).prop("disabled", false); + } + }); - if (!map.hasLayer(noteLayer)) map.addLayer(noteLayer); - if (window.location.hash == "") map.panTo($('.details').data().coordinates.split(',')); - }); - }; + content.find("textarea").val('').trigger("input"); - page.unload = function() { - if (marker) map.removeLayer(marker); - }; + var data = $('.details').data(), + latLng = data.coordinates.split(','); - function setLoading() { - if($('#browse_status').is(':empty')) { - $('#browse_status').append($('

').text(I18n.t('browse.start_rjs.loading'))); - } + if (!window.location.hash) { + OSM.router.moveListenerOff(); + map.once('moveend', OSM.router.moveListenerOn); + map.getZoom() > 15 ? map.panTo(latLng) : map.setView(latLng, 16); } - function clearLoading() { - $('#browse_status').empty(); + if (!map.hasLayer(halo)) { + halo = L.circleMarker(latLng, { + weight: 2.5, + radius: 20, + fillOpacity: 0.5, + color: "#FF6200" + }); + map.addLayer(halo); } - return page; + if (map.hasLayer(currentNote)) map.removeLayer(currentNote); + currentNote = L.marker(latLng, { + icon: noteIcons[data.status], + opacity: 1, + clickable: true + }); + map.addLayer(currentNote); + }; + + page.unload = function () { + if (map.hasLayer(halo)) map.removeLayer(halo); + if (map.hasLayer(currentNote)) map.removeLayer(currentNote); + }; + + return page; };