diff --git a/GeocacheCircles/Geocache_Circles.meta.js b/GeocacheCircles/Geocache_Circles.meta.js
index 1a543a2..76d1b02 100644
--- a/GeocacheCircles/Geocache_Circles.meta.js
+++ b/GeocacheCircles/Geocache_Circles.meta.js
@@ -7,7 +7,7 @@
// @oujs:author JRI
// @license MIT; http://www.opensource.org/licenses/mit-license.php
// @copyright 2016-2017, James Inge (http://geo.inge.org.uk/)
-// @version 0.0.4
+// @version 0.0.5
// @icon https://geo.inge.org.uk/userscripts/circleIcon48.png
// @icon64 https://geo.inge.org.uk/userscripts/circleIcon64.png
// @connect www.geocaching.com
diff --git a/GeocacheCircles/Geocache_Circles.user.js b/GeocacheCircles/Geocache_Circles.user.js
index 4b60076..27d3865 100644
--- a/GeocacheCircles/Geocache_Circles.user.js
+++ b/GeocacheCircles/Geocache_Circles.user.js
@@ -7,7 +7,7 @@
// @oujs:author JRI
// @license MIT; http://www.opensource.org/licenses/mit-license.php
// @copyright 2016-2017, James Inge (http://geo.inge.org.uk/)
-// @version 0.0.4
+// @version 0.0.5
// @icon https://geo.inge.org.uk/userscripts/circleIcon48.png
// @icon64 https://geo.inge.org.uk/userscripts/circleIcon64.png
// @connect www.geocaching.com
@@ -19,87 +19,114 @@
/*jshint esversion: 6, undef:true, unused:true */
/*global L, MapSettings, window, console */
-(function () {
- "use strict";
- const version = "Geocache Circles v0.0.4";
- const loggedIn = document.getElementById("uxLoginStatus_divSignedIn");
- const template = document.getElementById("cacheDetailsTemplate");
- const script = document.createElement("script");
- const circleIcon = "";
-
- function handleCircleRequest(e) {
- /* Fetch coordinates from cache page */
- const req = new XMLHttpRequest();
- const gc = e.detail;
- req.addEventListener("load", function (ignore) {
- const r = req.responseText;
- const k = r.indexOf("mapLatLng = {");
-
- if (req.status < 400) {
- try {
- const {lat, lng, name} = JSON.parse(r.substring(k + 12, r.indexOf("}", k) + 1));
-
- if (typeof lat !== "number" || typeof lng !== "number") {
- // Missing data in JSON string
- console.error("Geocache Circles: no cache coordinates retrieved.");
- return;
- }
-
- if (window.MapSettings && MapSettings.Map && window.L && window.L.Circle) {
- const ll = new L.LatLng(lat, lng);
- new L.Circle(ll, 161, {weight: 2})
- .addTo(MapSettings.Map)
- .bindPopup(`
${name}
${ll.toUrl()}`);
- } else {
- console.error("Geocache Circles: couldn't find map interface.");
- }
- } catch (err) {
- if (err instanceof SyntaxError) {
- console.warn(`Geocache Circles: Received ${r.length} bytes, coords at ${k} but couldn't extract cache coordinates from data (are you still logged in?):
+(function() {
+ "use strict";
+ const version = "Geocache Circles v0.0.5";
+ const loggedIn = document.getElementById("uxLoginStatus_divSignedIn");
+ const template = document.getElementById("cacheDetailsTemplate");
+ const script = document.createElement("script");
+ const circleIcon = "";
+
+ //delete existing circle
+ function handleCircleRemove(e) {
+ const gc = e.detail;
+ if (window.MapSettings && MapSettings.Map && window.L && circleStorage[gc]) {
+ {
+ MapSettings.Map.removeLayer(circleStorage[gc]);
+ delete circleStorage[gc];
+ }
+ }
+ }
+
+ function handleCircleRequest(e) {
+ /* Fetch coordinates from cache page */
+ const req = new XMLHttpRequest();
+ const gc = e.detail;
+
+ //if circle exists, delete it
+ if (circleStorage[gc] && window.MapSettings && MapSettings.Map && window.L && window.L.Circle) {
+ MapSettings.Map.removeLayer(circleStorage[gc]);
+ delete circleStorage[gc];
+ return;
+ }
+
+ req.addEventListener("load", function(ignore) {
+ const r = req.responseText;
+ const k = r.indexOf("mapLatLng = {");
+
+
+
+ if (req.status < 400) {
+ try {
+ const { lat, lng, name } = JSON.parse(r.substring(k + 12, r.indexOf("}", k) + 1));
+
+ if (typeof lat !== "number" || typeof lng !== "number") {
+ // Missing data in JSON string
+ console.error("Geocache Circles: no cache coordinates retrieved.");
+ return;
+ }
+
+ if (window.MapSettings && MapSettings.Map && window.L && window.L.Circle) {
+ const ll = new L.LatLng(lat, lng);
+ var circle = new L.Circle(ll, 161, { weight: 2 });
+ circle.addTo(MapSettings.Map)
+ .bindPopup(`
${name}
${ll.toUrl()}
+ OpenCache
+ Remove circle`);
+ circleStorage[gc] = circle;
+ } else {
+ console.error("Geocache Circles: couldn't find map interface.");
+ }
+ } catch (err) {
+ if (err instanceof SyntaxError) {
+ console.warn(`Geocache Circles: Received ${r.length} bytes, coords at ${k} but couldn't extract cache coordinates from data (are you still logged in?):
${err}`);
- } else {
- console.error(`Geocache Circles: couldn't add circle to ssmap: ${err}`);
- }
- }
- } else {
- console.warn(`Geocache Circles: error retrieving cache page to find coords for ${gc}: ${req.statusText}`);
- }
- });
- req.open("GET", `https://www.geocaching.com/geocache/${gc}`);
- req.send();
- }
-
- // Don't run on frames or iframes
- if (window.top !== window.self) {
- return false;
- }
-
- // Check feature support
- if (!window.JSON || !window.XMLHttpRequest) {
- console.warn(`${version} requires a browser with support for JSON and XMLHttpRequest`);
- return false;
- }
-
- if (loggedIn === null) {
- // Warn if not logged in, as coords unavailable. Don't quit, as user might log in later in a different window, or login detection might have failed.
- console.warn("Geocache Circles may not be able to locate caches as you don't seem to be logged in.");
- }
-
- if (template) {
- console.info(version);
-
- // Attach to cache info popup template
- template.textContent = template.textContent.replace(/
/, `
Circle `);
-
- // Add event listener to content script context
- script.type = "text/javascript";
- script.text = `"use strict";
- ${handleCircleRequest.toString()}
- document.addEventListener("gme_circle_request", handleCircleRequest, false)`;
- document.documentElement.firstChild.appendChild(script);
- document.documentElement.firstChild.removeChild(script);
- } else {
- // Couldn't find popup template
- console.error(`${version} didn't understand page structure.`);
- }
-}());
\ No newline at end of file
+ } else {
+ console.error(`Geocache Circles: couldn't add circle to ssmap: ${err}`);
+ }
+ }
+ } else {
+ console.warn(`Geocache Circles: error retrieving cache page to find coords for ${gc}: ${req.statusText}`);
+ }
+ });
+ req.open("GET", `https://www.geocaching.com/geocache/${gc}`);
+ req.send();
+ }
+
+ // Don't run on frames or iframes
+ if (window.top !== window.self) {
+ return false;
+ }
+
+ // Check feature support
+ if (!window.JSON || !window.XMLHttpRequest) {
+ console.warn(`${version} requires a browser with support for JSON and XMLHttpRequest`);
+ return false;
+ }
+
+ if (loggedIn === null) {
+ // Warn if not logged in, as coords unavailable. Don't quit, as user might log in later in a different window, or login detection might have failed.
+ console.warn("Geocache Circles may not be able to locate caches as you don't seem to be logged in.");
+ }
+
+ if (template) {
+ console.info(version);
+
+ // Attach to cache info popup template
+ template.textContent = template.textContent.replace(/
/, `
Circle `);
+
+ // Add event listener to content script context
+ script.type = "text/javascript";
+ script.text = `"use strict";
+ const circleStorage = {};
+ ${handleCircleRequest.toString()}
+ ${handleCircleRemove.toString()}
+ document.addEventListener("gme_circle_request", handleCircleRequest, false);
+ document.addEventListener("gme_circle_remove", handleCircleRemove, false)`;
+ document.documentElement.firstChild.appendChild(script);
+ document.documentElement.firstChild.removeChild(script);
+ } else {
+ // Couldn't find popup template
+ console.error(`${version} didn't understand page structure.`);
+ }
+}());
diff --git a/GeocacheCircles/src/Geocache_Circles.js b/GeocacheCircles/src/Geocache_Circles.js
index 37372f4..ddc0465 100644
--- a/GeocacheCircles/src/Geocache_Circles.js
+++ b/GeocacheCircles/src/Geocache_Circles.js
@@ -1,81 +1,108 @@
- const version = "Geocache Circles v0.0.4";
- const loggedIn = document.getElementById("uxLoginStatus_divSignedIn");
- const template = document.getElementById("cacheDetailsTemplate");
- const script = document.createElement("script");
- const circleIcon = "";
+const version = "Geocache Circles v0.0.5";
+const loggedIn = document.getElementById("uxLoginStatus_divSignedIn");
+const template = document.getElementById("cacheDetailsTemplate");
+const script = document.createElement("script");
+const circleIcon = "";
- function handleCircleRequest(e) {
- /* Fetch coordinates from cache page */
- const req = new XMLHttpRequest();
- const gc = e.detail;
- req.addEventListener("load", function (ignore) {
- const r = req.responseText;
- const k = r.indexOf("mapLatLng = {");
+//delete existing circle
+function handleCircleRemove(e) {
+ const gc = e.detail;
+ if (window.MapSettings && MapSettings.Map && window.L && circleStorage[gc]) {
+ {
+ MapSettings.Map.removeLayer(circleStorage[gc]);
+ delete circleStorage[gc];
+ }
+ }
+}
- if (req.status < 400) {
- try {
- const {lat, lng, name} = JSON.parse(r.substring(k + 12, r.indexOf("}", k) + 1));
+function handleCircleRequest(e) {
+ /* Fetch coordinates from cache page */
+ const req = new XMLHttpRequest();
+ const gc = e.detail;
- if (typeof lat !== "number" || typeof lng !== "number") {
- // Missing data in JSON string
- console.error("Geocache Circles: no cache coordinates retrieved.");
- return;
- }
+ //if circle exists, delete it
+ if (circleStorage[gc] && window.MapSettings && MapSettings.Map && window.L && window.L.Circle) {
+ MapSettings.Map.removeLayer(circleStorage[gc]);
+ delete circleStorage[gc];
+ return;
+ }
- if (window.MapSettings && MapSettings.Map && window.L && window.L.Circle) {
- const ll = new L.LatLng(lat, lng);
- new L.Circle(ll, 161, {weight: 2})
- .addTo(MapSettings.Map)
- .bindPopup(`
${name}
${ll.toUrl()}`);
- } else {
- console.error("Geocache Circles: couldn't find map interface.");
- }
- } catch (err) {
- if (err instanceof SyntaxError) {
- console.warn(`Geocache Circles: Received ${r.length} bytes, coords at ${k} but couldn't extract cache coordinates from data (are you still logged in?):
+ req.addEventListener("load", function(ignore) {
+ const r = req.responseText;
+ const k = r.indexOf("mapLatLng = {");
+
+
+
+ if (req.status < 400) {
+ try {
+ const { lat, lng, name } = JSON.parse(r.substring(k + 12, r.indexOf("}", k) + 1));
+
+ if (typeof lat !== "number" || typeof lng !== "number") {
+ // Missing data in JSON string
+ console.error("Geocache Circles: no cache coordinates retrieved.");
+ return;
+ }
+
+ if (window.MapSettings && MapSettings.Map && window.L && window.L.Circle) {
+ const ll = new L.LatLng(lat, lng);
+ var circle = new L.Circle(ll, 161, { weight: 2 });
+ circle.addTo(MapSettings.Map)
+ .bindPopup(`
${name}
${ll.toUrl()}
+ OpenCache
+ Remove circle`);
+ circleStorage[gc] = circle;
+ } else {
+ console.error("Geocache Circles: couldn't find map interface.");
+ }
+ } catch (err) {
+ if (err instanceof SyntaxError) {
+ console.warn(`Geocache Circles: Received ${r.length} bytes, coords at ${k} but couldn't extract cache coordinates from data (are you still logged in?):
${err}`);
- } else {
- console.error(`Geocache Circles: couldn't add circle to ssmap: ${err}`);
- }
- }
- } else {
- console.warn(`Geocache Circles: error retrieving cache page to find coords for ${gc}: ${req.statusText}`);
- }
- });
- req.open("GET", `https://www.geocaching.com/geocache/${gc}`);
- req.send();
- }
+ } else {
+ console.error(`Geocache Circles: couldn't add circle to ssmap: ${err}`);
+ }
+ }
+ } else {
+ console.warn(`Geocache Circles: error retrieving cache page to find coords for ${gc}: ${req.statusText}`);
+ }
+ });
+ req.open("GET", `https://www.geocaching.com/geocache/${gc}`);
+ req.send();
+}
- // Don't run on frames or iframes
- if (window.top !== window.self) {
- return false;
- }
+// Don't run on frames or iframes
+if (window.top !== window.self) {
+ return false;
+}
- // Check feature support
- if (!window.JSON || !window.XMLHttpRequest) {
- console.warn(`${version} requires a browser with support for JSON and XMLHttpRequest`);
- return false;
- }
+// Check feature support
+if (!window.JSON || !window.XMLHttpRequest) {
+ console.warn(`${version} requires a browser with support for JSON and XMLHttpRequest`);
+ return false;
+}
- if (loggedIn === null) {
- // Warn if not logged in, as coords unavailable. Don't quit, as user might log in later in a different window, or login detection might have failed.
- console.warn("Geocache Circles may not be able to locate caches as you don't seem to be logged in.");
- }
+if (loggedIn === null) {
+ // Warn if not logged in, as coords unavailable. Don't quit, as user might log in later in a different window, or login detection might have failed.
+ console.warn("Geocache Circles may not be able to locate caches as you don't seem to be logged in.");
+}
- if (template) {
- console.info(version);
+if (template) {
+ console.info(version);
- // Attach to cache info popup template
- template.textContent = template.textContent.replace(/
/, `
Circle `);
+ // Attach to cache info popup template
+ template.textContent = template.textContent.replace(/
/, `
Circle `);
- // Add event listener to content script context
- script.type = "text/javascript";
- script.text = `"use strict";
- ${handleCircleRequest.toString()}
- document.addEventListener("gme_circle_request", handleCircleRequest, false)`;
- document.documentElement.firstChild.appendChild(script);
- document.documentElement.firstChild.removeChild(script);
- } else {
- // Couldn't find popup template
- console.error(`${version} didn't understand page structure.`);
- }
+ // Add event listener to content script context
+ script.type = "text/javascript";
+ script.text = `"use strict";
+ const circleStorage = {};
+ ${handleCircleRequest.toString()}
+ ${handleCircleRemove.toString()}
+ document.addEventListener("gme_circle_request", handleCircleRequest, false);
+ document.addEventListener("gme_circle_remove", handleCircleRemove, false)`;
+ document.documentElement.firstChild.appendChild(script);
+ document.documentElement.firstChild.removeChild(script);
+} else {
+ // Couldn't find popup template
+ console.error(`${version} didn't understand page structure.`);
+}
diff --git a/GeocacheCircles/src/Geocache_Circles.meta.js b/GeocacheCircles/src/Geocache_Circles.meta.js
index 1a543a2..76d1b02 100644
--- a/GeocacheCircles/src/Geocache_Circles.meta.js
+++ b/GeocacheCircles/src/Geocache_Circles.meta.js
@@ -7,7 +7,7 @@
// @oujs:author JRI
// @license MIT; http://www.opensource.org/licenses/mit-license.php
// @copyright 2016-2017, James Inge (http://geo.inge.org.uk/)
-// @version 0.0.4
+// @version 0.0.5
// @icon https://geo.inge.org.uk/userscripts/circleIcon48.png
// @icon64 https://geo.inge.org.uk/userscripts/circleIcon64.png
// @connect www.geocaching.com
diff --git a/GeocachingMapEnhancements/Geocaching_Map_Enhancements.user.js b/GeocachingMapEnhancements/Geocaching_Map_Enhancements.user.js
index 9655b1e..cab5a68 100644
--- a/GeocachingMapEnhancements/Geocaching_Map_Enhancements.user.js
+++ b/GeocachingMapEnhancements/Geocaching_Map_Enhancements.user.js
@@ -76,8 +76,8 @@ var gmeResources = {
.gme-button-active {border:solid 3px #02b; padding:1px 0 1px 1px; background-color:#fff;}\
.gme-button-active:hover {border-color:#63f;filter:alpha(opacity=100);}\
span.gme-button, .gme-button-wide { padding-left:5px; padding-right:5px; font-size:12px; font-weight:bold; width:auto; background-image:none; color: #424242; }\
- .GME_home { background-position: -572px 4px;}\
- .GME_config { background-position: -284px 4px;}\
+ .GME_home { background-size: 18px 18px; background-position: center;background-image: url("")}\
+ .GME_config { background-size: 18px 18px; background-position: center;background-image: url("")}\
.GME_route, .GME_hide {background: url(https://geo.inge.org.uk/userscripts/gme_icons_0_8_0.png) no-repeat #eee;}\
.GME_route { background-position: 7px 3px;}\
.GME_route.gme-button-active { background-position: 5px 1px;}\
@@ -87,8 +87,8 @@ var gmeResources = {
.gme-button-clear-labels { background-position: -69px 4px;}\
span.gme-distance-container { display: none; }\
span.gme-distance-container.show { display: inline-block; }\
- .GME_info { background-position: -537px 4px;}\
- .GME_info.gme-button-active {background-position: -540px 1px;}\
+ .GME_info { background-size: 16px 16px; background-position: center;background-image: url("")}\
+ .GME_info.gme-button-active {}\
#GME_loc, a.gme-button.leaflet-active {outline: none;}\
.leaflet-control-zoomwarning { top: 94px; }\
.leaflet-control-zoomwarning a { filter: progid:DXImageTransform.Microsoft.gradient(startColorStr="#BFC80000",EndColorStr="#BFC80000"); background-color:rgba(200,0,0,0.75); margin-left: -4px; background-position: -502px 2px;height:14px;width:14px; border-color: #b00; box-shadow: 0 0 8px rgba(0, 0, 0, 0.4); }\