Google Maps Coordinates Grabber

Once in Google Maps, click on the map (Do not click on markers) a popup should show at the bottom with the place and the coordinates displayed in the last line, click on any white space of that popup. The coordinates should now be copied to clipboard.

目前為 2019-03-02 提交的版本,檢視 最新版本

// ==UserScript==
// @name     		Google Maps Coordinates Grabber
// @version  		0.1.0
// @namespace   https://greasyfork.org/en/users/250979-mrmike
// @author      MrAmericanMike
// @description Once in Google Maps, click on the map (Do not click on markers) a popup should show at the bottom with the place and the coordinates displayed in the last line, click on any white space of that popup. The coordinates should now be copied to clipboard.
// @grant 		  none
// @include  		http*://*google*/maps/*
// @run-at   		document-end
// ==/UserScript==

document.addEventListener("mouseup", lookForCoordinates);

function lookForCoordinates(){
  
  let card = document.getElementById("reveal-card");
  
  if(card){
    let latlng = document.getElementsByClassName("widget-reveal-card-lat-lng");
    if(latlng[0]){
      copyTextToClipboard(latlng[0].innerText, latlng[0]);
    }
  }
  
}


function fallbackCopyTextToClipboard(text, element) {
    var textArea = document.createElement("textarea");
    textArea.value = text;
    document.body.appendChild(textArea);
    textArea.focus();
    textArea.select();
  
    try {
      document.execCommand('copy');
    } catch (err) {
      if(!err){
        element.innerText = "Copied to Clipboard";
        resetElement(element, text);
      }
    }
  
    document.body.removeChild(textArea);
}

function copyTextToClipboard(text, element) {
    if (!navigator.clipboard) {
        fallbackCopyTextToClipboard(text, element);
        return;
    }
    navigator.clipboard.writeText(text).then(function() {
      element.innerText = "Copied to Clipboard";
      resetElement(element, text);
    }, function(err) {
    });
}

function resetElement(element, text){
  setTimeout(() => {
	  element.innerText = text;
  }, 2500);  
}