navchandar / Google Image Direct View

// ==UserScript==
// @name         Google Image Direct View
// @version      3.0
// @namespace    Google_Image_Direct_View
// @description  A different take on Google direct image viewer
// @author       navchandar
// @include      https://www.google.tld/*tbm=isch*
// @include      https://www.google.tld/search?tbm=isch*
// @include      https://www.google.co.*/*tbm=isch*
// @include      https://www.google.co.*/search?tbm=isch*
// @run-at       document-end
// @license      MIT
// @grant        none
// @homepage     https://navchandar.github.io/
// @homepage     https://github.com/navchandar/
// @homepageURL  https://navchandar.github.io/
// @contributionURL https://paypal.me/navchandar
// @contributionAmount $1.00
// @copyright    2019+, navchandar (https://openuserjs.org/users/navchandar)
// @supportURL   https://openuserjs.org/scripts/navchandar/Google_Image_Direct_View/issues
// @updateURL    https://openuserjs.org/meta/navchandar/Google_Image_Direct_View.meta.js
// @downloadURL  https://openuserjs.org/install/navchandar/Google_Image_Direct_View.user.js
// @setupURL     https://openuserjs.org/install/navchandar/Google_Image_Direct_View.user.js
// @icon         
// ==/UserScript==

function getElementsByXPath(xpath, parent) {
  let results = [];
  let query = document.evaluate(xpath, parent || document, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
  for (let i = 0, length = query.snapshotLength; i < length; ++i) {
    results.push(query.snapshotItem(i))
  }
  return results
}

function has(String, search) {
  try {
    if (String.indexOf(search) > -1) {
      return !0
    }
  }
  catch (err) {}
  return !1
}

function UpdateElements(imgXpath) {
  var int = 0;
  var Img_items = getElementsByXPath(imgXpath);
  console.log(Img_items.length.toString() + " Image items found");

  if (Img_items.length > 0) {
    var Link_items = getElementsByXPath(imgXpath + "//../../../a[@href] | " + imgXpath + "//../../a[@href]");
    // console.log(Link_items.length.toString() + " Image items found");

    for (var i = 0; i < Img_items.length; i++) {
      try {
        var src = Img_items[i].src;
        var uri = Link_items[i].href;
        if (uri != src) {
          int++;
          Link_items[i].title = "Image Loading... Wait..."

          if (has(src, "data:image")) {
            //Link_items[i].href = src.replace(/^data:image\/[^;]+/, 'data:application/octet-stream');
            Link_items[i].href = src;
            Link_items[i].download = "Base64_Image.jpg";

          }
          else if (has(src, "https://encrypted")) {
            var uri_enc = encodeURIComponent(uri);
            var uri_dec = decodeURIComponent(uri_enc);

          }
          else {
            Link_items[i].href = src;
          }

        }
        else {
          Link_items[i].title = "Image URL updated!"
        }
      }
      catch (err) {
        console.log(err);
      }
    }
    if (int > 0) {
      console.log("Updated " + int + " image links.");
    }
  }
}

function addCssToDocument(css) {
  var style = document.createElement('style')
  style.innerText = css
  document.head.appendChild(style)
}

(function () {
  'use strict';
  // optimized xpath and interval
  var img_locator = "//c-wiz[@jsname]/parent::div[not(contains(@style, 'display: none'))]//a[(contains(@jsaction, 'focus'))]//img";
  setInterval(function () {
    UpdateElements(img_locator)
  }, 500)
})()