map.layersControl.addOverlay(noteLayer, I18n.t("browse.start_rjs.notes_layer_name"));
if (params.notes) map.addLayer(noteLayer);
+
+ if (params.note) {
+ $.ajax({
+ url: "/api/" + OSM.API_VERSION + "/notes/" + params.note + ".json",
+ success: function (feature) {
+ var marker = updateMarker(notes[feature.properties.id], feature);
+
+ notes[feature.properties.id] = marker;
+
+ map.addLayer(noteLayer);
+ marker.openPopup();
+ }
+ });
+ }
}
function updateMarker(marker, feature) {
return marker;
}
+ var noteLoader;
+
function loadNotes() {
var bounds = map.getBounds();
- var url = "/api/" + OSM.API_VERSION + "/notes.json?bbox=" + bounds.toBBOX();
+ var size = bounds.getSize();
- $.ajax({
- url: url,
- success: function (json) {
- var oldNotes = notes;
+ if (size <= OSM.MAX_NOTE_REQUEST_AREA) {
+ var url = "/api/" + OSM.API_VERSION + "/notes.json?bbox=" + bounds.toBBOX();
- notes = {};
+ if (noteLoader) noteLoader.abort();
- json.features.forEach(function (feature) {
- var marker = oldNotes[feature.properties.id];
+ noteLoader = $.ajax({
+ url: url,
+ success: function (json) {
+ var oldNotes = notes;
- delete oldNotes[feature.properties.id];
+ notes = {};
- notes[feature.properties.id] = updateMarker(marker, feature);
- });
+ json.features.forEach(function (feature) {
+ var marker = oldNotes[feature.properties.id];
- for (id in oldNotes) {
- noteLayer.removeLayer(oldNotes[id]);
+ delete oldNotes[feature.properties.id];
+
+ notes[feature.properties.id] = updateMarker(marker, feature);
+ });
+
+ for (id in oldNotes) {
+ noteLayer.removeLayer(oldNotes[id]);
+ }
+
+ noteLoader = null;
}
- }
- });
+ });
+ }
};
function popupOptions() {
var mapSize = map.getSize();
- return { maxHeight: mapSize.y * 2 / 3 };
+ return {
+ minWidth: 320,
+ maxWidth: mapSize.y * 1 / 3,
+ maxHeight: mapSize.y * 2 / 3,
+ offset: new L.Point(0, -3),
+ autoPanPadding: new L.Point(60, 40)
+ };
}
function createPopupContent(marker, properties) {
notes[feature.properties.id] = updateMarker(marker, feature);
$(".leaflet-popup-close-button").off("click.close");
+ $("#createnoteanchor").removeClass("disabled").addClass("geolink");
}
});
}
$("#createnoteanchor").click(function (e) {
e.preventDefault();
+ if ($(e.target).hasClass("disabled")) return;
+
+ $(e.target).removeClass("geolink").addClass("disabled");
+
map.addLayer(noteLayer);
- var marker = L.marker(map.getCenter(), {
+ var mapSize = map.getSize();
+ var markerPosition;
+
+ if (mapSize.y > 800)
+ {
+ markerPosition = [mapSize.x / 2, mapSize.y / 2];
+ }
+ else if (mapSize.y > 400)
+ {
+ markerPosition = [mapSize.x / 2, 400];
+ }
+ else
+ {
+ markerPosition = [mapSize.x / 2, mapSize.y];
+ }
+
+ var marker = L.marker(map.containerPointToLatLng(markerPosition), {
icon: noteIcons["new"],
opacity: 0.7,
draggable: true
var popupContent = $(JST["templates/notes/new"]({ create_url: $(e.target).attr("href") }));
+ popupContent.find("textarea").on("input", function (e) {
+ var form = e.target.form;
+
+ if ($(e.target).val() == "") {
+ $(form.add).prop("disabled", true);
+ } else {
+ $(form.add).prop("disabled", false);
+ }
+ });
+
popupContent.find("input[type=submit]").on("click", function (e) {
e.preventDefault();
createNote(marker, e.target.form, $(e.target).data("url"));
$(".leaflet-popup-close-button").on("click.close", function (e) {
map.removeLayer(marker);
+
+ $("#createnoteanchor").removeClass("disabled").addClass("geolink");
});
marker.on("dragend", function (e) {