From e5e3efa18acc15f56ff936a5c085e9bf60f18054 Mon Sep 17 00:00:00 2001 From: Vilem Lipold Date: Fri, 8 Mar 2019 10:34:45 +0100 Subject: [PATCH 1/3] new icons in js --- .../Geocaching_Map_Enhancements.user.js | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) 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); }\ From a2f3af8322e8b4cfbfe5f14cbd6d1c0404c09a34 Mon Sep 17 00:00:00 2001 From: Vilem Lipold Date: Sat, 4 Jan 2020 13:46:25 +0100 Subject: [PATCH 2/3] Better work with circles --- GeocacheCircles/Geocache_Circles.user.js | 195 +++++++++++++---------- GeocacheCircles/src/Geocache_Circles.js | 167 +++++++++++-------- 2 files changed, 208 insertions(+), 154 deletions(-) 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(//, `