X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/4bfbdcc2f14a7c1f11f67d7454ada8ea36e130ff..5384ee236cfbb1a33e018f9b85c63d765961a479:/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 a11f6a72c..8c2ab5c56 100644 --- a/app/assets/javascripts/index/note.js.erb +++ b/app/assets/javascripts/index/note.js.erb @@ -1,93 +1,97 @@ -OSM.Note = function(map) { - var noteLayer = map.noteLayer, - content = $('#sidebar_content'), - page = {}; +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); - }); + $.ajax({ + url: url, + type: method, + oauth: true, + data: {text: $(form.text).val()}, + success: function () { + OSM.loadSidebarContent(window.location.pathname, page.load); + } + }); + } - content.find("textarea").on("input", function (e) { - var form = e.target.form; + page.pushstate = page.popstate = function (path) { + OSM.loadSidebarContent(path, 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.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); + }); - content.find("textarea").val('').trigger("input"); - } + content.find("textarea").on("input", function (e) { + var form = e.target.form; - page.pushstate = page.popstate = function() { - 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.load = function() { - 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(); - }); - }; + content.find("textarea").val('').trigger("input"); - function setLoading() { - if($('#browse_status').is(':empty')) { - $('#browse_status').append($('

').text(I18n.t('browse.start_rjs.loading'))); - } + var data = $('.details').data(); + if (!window.location.hash) { + var coords = data.coordinates.split(','); + OSM.route.moveListenerOff(); + map.once('moveend', OSM.route.moveListenerOn); + map.getZoom() > 15 ? map.panTo(coords) : map.setView(coords, 16); } - function clearLoading() { - $('#browse_status').empty(); + if (!map.hasLayer(halo)) { + halo = L.circleMarker(data.coordinates.split(','), { + 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(data.coordinates.split(','), { + 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; };