marker.addTo(noteLayer);
}
+ function addHalo(latlng) {
+ if (halo) map.removeLayer(halo);
+
+ halo = L.circleMarker(latlng, {
+ weight: 2.5,
+ radius: 20,
+ fillOpacity: 0.5,
+ color: "#FF6200"
+ });
+
+ map.addLayer(halo);
+ }
+
+ function removeHalo() {
+ if (halo) map.removeLayer(halo);
+ halo = null;
+ }
+
page.pushstate = page.popstate = function (path) {
OSM.loadSidebarContent(path, function () {
page.load(path);
});
};
- function newHalo(loc, a) {
- var hasHalo = halo && map.hasLayer(halo);
-
- if (a === "dragstart" && hasHalo) {
- map.removeLayer(halo);
- } else {
- if (hasHalo) map.removeLayer(halo);
-
- halo = L.circleMarker(loc, {
- weight: 2.5,
- radius: 20,
- fillOpacity: 0.5,
- color: "#FF6200"
- });
-
- map.addLayer(halo);
- }
- }
-
page.load = function (path) {
if (addNoteButton.hasClass("disabled")) return;
if (addNoteButton.hasClass("active")) return;
});
newNoteMarker.on("dragstart dragend", function (a) {
- newHalo(newNoteMarker.getLatLng(), a.type);
+ removeHalo();
+ if (a.type !== "dragstart") {
+ addHalo(newNoteMarker.getLatLng());
+ }
});
newNoteMarker.addTo(map);
- newHalo(newNoteMarker.getLatLng());
+ addHalo(newNoteMarker.getLatLng());
newNoteMarker.on("remove", function () {
addNoteButton.removeClass("active");
page.unload = function () {
if (newNoteMarker) map.removeLayer(newNoteMarker);
- if (halo) map.removeLayer(halo);
+ removeHalo();
addNoteButton.removeClass("active");
};