newHalo() wasn't always creating new halos. It had an event type argument that was checked against drag event. Depending on this check, newHalo() could remove the halo.
marker.addTo(noteLayer);
}
marker.addTo(noteLayer);
}
- function newHalo(loc, a) {
- var hasHalo = halo && map.hasLayer(halo);
+ function addHalo(latlng) {
+ if (halo) map.removeLayer(halo);
- if (a === "dragstart" && hasHalo) {
- map.removeLayer(halo);
- } else {
- if (hasHalo) map.removeLayer(halo);
+ halo = L.circleMarker(latlng, {
+ weight: 2.5,
+ radius: 20,
+ fillOpacity: 0.5,
+ color: "#FF6200"
+ });
- halo = L.circleMarker(loc, {
- weight: 2.5,
- radius: 20,
- fillOpacity: 0.5,
- color: "#FF6200"
- });
+ map.addLayer(halo);
+ }
- map.addLayer(halo);
- }
+ function removeHalo() {
+ if (halo) map.removeLayer(halo);
+ halo = null;
}
page.pushstate = page.popstate = function (path) {
}
page.pushstate = page.popstate = function (path) {
});
newNoteMarker.on("dragstart dragend", function (a) {
});
newNoteMarker.on("dragstart dragend", function (a) {
- newHalo(newNoteMarker.getLatLng(), a.type);
+ removeHalo();
+ if (a.type !== "dragstart") {
+ addHalo(newNoteMarker.getLatLng());
+ }
});
newNoteMarker.addTo(map);
});
newNoteMarker.addTo(map);
- newHalo(newNoteMarker.getLatLng());
+ addHalo(newNoteMarker.getLatLng());
newNoteMarker.on("remove", function () {
addNoteButton.removeClass("active");
newNoteMarker.on("remove", function () {
addNoteButton.removeClass("active");
page.unload = function () {
if (newNoteMarker) map.removeLayer(newNoteMarker);
page.unload = function () {
if (newNoteMarker) map.removeLayer(newNoteMarker);
- if (halo) map.removeLayer(halo);
addNoteButton.removeClass("active");
};
addNoteButton.removeClass("active");
};