EnstylerJS

MyDealz Enstyler Frontend and enhanced features

目前为 2016-10-30 提交的版本,查看 最新版本

// ==UserScript==
// @name        EnstylerJS
// @namespace   Enstyler
// @description MyDealz Enstyler Frontend and enhanced features
// @include     http://www.mydealz.de/*
// @include     https://www.mydealz.de/*
// @version     2.10.304
// @grant       GM_getValue
// @grant       GM_setValue
// @grant       GM_log
// @grant       GM_xmlhttpRequest
// @require     http://code.jquery.com/jquery-latest.js
// @require     https://openuserjs.org/src/libs/sizzle/GM_config.js
// ==/UserScript==

// ========== RUN EnstylerJS =====================================
function EnstylerJS () {

    // create object for enstyler "Menu Button"
    var input = document.createElement('input');
    input.type = 'button';
    input.value = 'Enstyler';
    input.onclick = showEnstylerConfig;

    // add Enstyler Button to ...
    var myElement;
    if (GM_config.get('enConfMain')) { 
       // add button to MainNav
       var Elements = document.getElementsByClassName("navMenu-trigger");
       myElement = Elements[0]; 
       input.className = 'nav-link-text vAlign--all-m';
    } else {
       // add button to SubNav
       myElement = document.getElementById('tour-filter');
       input.className = 'box--all-i subNavMenu-link';
       input.setAttribute('style', 'font-size: 1.28571em; font-weight: 700; top: 3px; left: -0.7em'); 
    }
  
    // only if myElement exist
    if (myElement !== null) {
        myElement.appendChild(input);
    }

    // hide Enstyler2 CSS (c) text because we have a button now
    addStyleString('.threadWidget-footer::after {display: none !important};');

    // basic config panel formatting, everything else is formatted by enstyler
    var enCSS = ['#GM_config { left: 5% !important; top: 5% !important; height: auto !important; min-width: 19em; max-width: 33em !important;}',
             '#GM_config input[type=button], #GM_config button { border: 1px solid; margin: 0.5em 0em 0.2em 1em; padding: 0.1em;}',
             '#GM_config .reset { font-size: 9pt; padding-right: 1em; }',
            ].join(" ");
    addStyleString(enCSS);
}  
// ========= END INIT, we are ready to go ===============================

// ============ functions to modify page content =============================

// REGEX to detect external URL
var REGEX_THREAD     = /^https?:\/\/www\.mydealz\.de\/visit\/thread(image)?\/\d+$/;
var REGEX_DESC       = /^https?:\/\/www\.mydealz\.de\/visit\/threaddesc\/\d+\/\d+$/;
var REGEX_COMMENT    = /^https?:\/\/www\.mydealz\.de\/visit\/comment\/\d+\/\d+$/;
var REGEX_AMAZONMOB  = /^https?:\/\/www\.amazon\..*\/gp\/aw\/.*$/;
//var REGEX_AMAZON     = /^https?:\/\/www\.amazon\..*$/;

// abfangen aller links mit jQuery
// wird genutzt zum filtern und 
$('a').bind('click', function(){
     var url = this.href;

     // externer Link mit Redirect ...
     // Match REDIRECT URLs and open new Window with finalUrl
     if (GM_config.get('enConfFilterLink') && url.match(REGEX_THREAD) || url.match(REGEX_DESC) || url.match(REGEX_COMMENT)) {
         // Workaround: pre open window because of popup blockers
         // Workaround: if GM_xmlhttpRequest is not availible 
         var asyncWindow = window.open(url, '_blank');
         
         //* GM_xmlhhtpREquest not supported by firefox mobile :-((( 
         // now lookup redirecd external URL ...
         // alert("external URL detected");
         GM_xmlhttpRequest({
             method: 'GET',
             url: url,
             // here we get the final URL from redirect
             onload: function (response) {
               // process final URL
               var newUrl = response.finalUrl;
               //alert(newUrl);
               // lets see ...
               if (newUrl.match(REGEX_AMAZONMOB)) {
                   newUrl = newUrl.replace("/gp/aw/d/", "/dp/");
                   newUrl = newUrl.replace("/gp/aw/ol/", "/gp/offer-listing/");
                   //alert("Amazon rewritten URL: " + newUrl);
               }
               // load processed URL in preopened window
               asyncWindow.location = newUrl;
             }
         });
         // return without link processing by Browser - END GM_xmlhttpRequest */
         return false;
     }
  
     // return with link processing in Browser
     return true;  
});

// ============= GM_config functions =======================================

// define GM_config elements
var fieldDefs = {
    // Part one: load external content --------
    'enstyler': { 
      'section': ['additonal features for Enstyler', ''],
      'label': 'Install / Update CSS...', // Appears on the button
      'type': 'button', // Makes this setting a button input
      'click': function() { // Function to call when button is clicked
               showUrl('https://userstyles.org/styles/128262#style-info'); }
    },

    /*
    'mobileRedirect': {
      'label': 'Amazon mobile redirect...', // Appears on the button
      'type': 'button', // Makes this setting a button input
      'click': function() { // Function to call when button is clicked
               showUrl('https://greasyfork.org/de/scripts/19700'); }
    }, // */

   'dontCookies': {
      'label': 'Mozilla no cookies...', // Appears on the button
      'type': 'button', // Makes this setting a button input
      'click': function() { // Function to call when button is clicked
               showUrl('https://addons.mozilla.org/de/addon/i-dont-care-about-cookies/'); }
    },

   // part two: EnstylerJS internal configuration options ------ 
   'hidden1': { // display next section, dont kow why ...
      'section': ['Configuration', ''],
        'type': 'hidden', // Makes this setting a hidden input
        'value': 'Some hidden value' // Value stored
   },

   // postion of enstyler "button"
   'enConfMain': {
      'label': 'Enstyler in MainNav', // Appears next to field
      'type': 'checkbox', // Makes this setting a checkbox input
      'default': false // Default value if user doesn't change it
    },

  // enable filtering of external links
  'enConfFilterLink': { 
      'label': 'Amazon mobile redirect', // Appears next to field
      'type': 'checkbox', // Makes this setting a checkbox input
      'default': true // Default value if user doesn't change it
    },
  
   // display copy message at end of section ...
   'copy': {
        'section': ['', '(c) Gnadelwartz - <a target="blank" href="https://www.mydealz.de/diskussion/enstyler2-style-your-mydealz-incl-pepper-sites-736219">Enstyler2 - Style your MyDealz</a>'],
        'type': 'hidden', // Makes this setting a hidden input
        'value': 'Some hidden value' // Value stored
   },
  

};


// display GM_copnfig as div, so we cam apply CSS!!
var frame = document.createElement('div');
document.body.appendChild(frame);

GM_config.init(
  {
    id: 'GM_config',
    title: 'EnstylerJS - Settings', 
    fields: fieldDefs, 
    // relaod page on close 
   'events': // Callback functions object
     {
      //'init': function() { alert('onInit()'); },
      //'open': function() { alert('onOpen()'); },
      //'save': function() { alert('onSave()'); },
      'close': function() { location.reload(); },
      //'reset': function() { alert('onReset()'); }
     },
   'frame': frame // Element used for the panel
  }
);

// EnstylerJS Config Panel anzeigen
function showEnstylerConfig() {
    GM_config.open(); 
}

//=========== Support functions for actual use =======

// display website in external window

function showUrl(str) {
    var myDeco = "innerheight=800,innerwidth=600";
    var myName = "enstyler";
    
    // workaround for not working window.focus(): close an existing window first
    var myWindowShow = window.open('', myName, "width=100,height=100").close();
    myWindowShow = window.open(str, myName, myDeco);
}

// add CSS in to document
function addStyleString(str) {
    var node = document.createElement('style');
    node.innerHTML = str;
    document.body.appendChild(node);
}
// sleep time expects milliseconds, then execute code
// NOTE: code runs in parallel (asnyc)!
// Usage!
//     sleepAsync(500).then(() => {
//               Do something after the sleep!
//      });

function sleepAsync (time) {
  return new Promise((resolve) => setTimeout(resolve, time));
}

// ============== INIT EnstyerJS =============
EnstylerJS();