Skip to content

Instantly share code, notes, and snippets.

@IzzySoft
Last active December 7, 2019 02:30
Show Gist options
  • Star 4 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save IzzySoft/1fc06876b16d6bf3ded8396e81d07961 to your computer and use it in GitHub Desktop.
Save IzzySoft/1fc06876b16d6bf3ded8396e81d07961 to your computer and use it in GitHub Desktop.
GoogleMonkeyR
// ==UserScript==
// @author rampageX
// @version 1.7.3.23
// @name GoogleMonkeyR (modified by rampageX)
// @namespace http://www.monkeyr.com
// @namespace https://greasyfork.org/zh-CN/scripts/378527-googlemonkeyr-modified-by-rampagex
// @description Google - Multiple columns of results, Remove "Sponsored Links", Number results, Auto-load more results, Remove web search dialogues, Open external links in a new tab, self updating and all configurable from a simple user dialogue.
// @include http*://www.google.*.*/webhp?*
// @include http*://www.google.*.*/search?*
// @include http*://www.google.*.*/ig?*
// @include http*://www.google.*.*/
// @include http*://www.google.*.*/#*
// @include http*://www.google.*/webhp?*
// @include http*://www.google.*/search?*
// @include http*://www.google.*/ig?*
// @include http*://www.google.*/
// @include http*://www.google.*/#*
// @include https://encrypted.google.*/webhp?*
// @include https://encrypted.google.*/search?*
// @include https://encrypted.google.*/ig?*
// @include https://encrypted.google.*/
// @include https://encrypted.google.*/#*
// @grant GM_registerMenuCommand
// @grant GM_addStyle
// @grant GM_setValue
// @grant GM_getValue
// @grant GM_xmlhttpRequest
// @icon https://www.google.com/favicon.ico
// @uso:script 378527
// @scriptsource https://greasyfork.org/zh-CN/scripts/378527-googlemonkeyr-modified-by-rampagex
// @scriptsource https://greasyfork.org/zh-CN/scripts/378527-googlemonkeyr-modified-by-rampagex/code/GoogleMonkeyR%20(modified%20by%20rampagex).user.js
/* StartHistory
1.7.3.23 by Izzy
Google site changes:
* #GTR -> #search
* column count: add "#rso .srg { column-count … }" and "#cnt #center_col" w/o "#cnt.singleton" (plus "#cnt #foot" to adjust footer)
* hiding related hid all results (".bkWMgd .kno-kp" instead of just ".bkWMgd" fixed that)
* autoLoad, numResults still broken
1.7.3.22 by rampageX
hide new related search
1.7.3.21 by Cook Wu
Get the video and image thumbnail after autoloading back
1.7.3.20 by Cook Wu
try to fix bug images after autoloading again, may be only effective on chrome
1.7.3.19 by Cook Wu
fix bug images after autoloading page > 1, remove site preview and favicon for image search results
1.7.3.18 by Cook Wu
add the option to hide the extra search results like videos, images but not appbar
1.7.3.17 by Cook Wu
modify to show more hidden results
1.7.3.16 by Cook Wu
remove igoogle specific content
1.7.3.15 by Cook Wu
GoogleMonkeyR settings link is back
1.7.3.14 by Cook Wu
fix the bug of numbered list
1.7.3.13 by Cook Wu
fix the bug of open link in a new tab
EndHistory */
// ==/UserScript==
/**
* Processing of the current page.
**/
(function () {
var UIL =
{
scriptName: "GoogleMonkeyR",
scriptVersion: "v.1.7.3.23",
scriptId: "373206",
watching: false,
init: function () {
var pageType = this.determineCurrentPageType();
if (pageType !== null) {
this.processPage(pageType);
}
else {
var self = arguments.callee;
setTimeout(self.bind(this), 100);
}
},
determineCurrentPageType: function () {
var pageType = null;
var loc = window.location.href.toLowerCase();
if (loc.indexOf("tbm=isch") != -1) {
pageType = "image";
}
else if (loc.indexOf("tbm=shop") != -1) {
pageType = "shopping";
}
else if (loc.indexOf("/webhp?") != -1) {
this.instant = true;
pageType = "search";
}
else if ((loc.indexOf("/search?") != -1)) {
this.instant = false;
pageType = "search";
}
else if ((loc.indexOf(window.location.protocol + '//' + window.location.hostname + '/#') != -1)) {
this.instant = true;
pageType = "search";
}
else if (window.location.href == (window.location.protocol + '//' + window.location.hostname + '/')) {
this.instant = true;
pageType = "search";
}
return pageType;
},
processPage: function (pageType) {
if (pageType !== null) {
var pageProcessor = pageType + "PageProcessor";
if (typeof (this[pageProcessor]) == "function") {
this.hideSearch = UIL.Config.getHideSearch();
this.numResults = UIL.Config.getNumResults();
this.numColumns = UIL.Config.getNumCol();
this.newspaper = UIL.Config.getResultFlow() != "l2r";
this.noSitePreview = UIL.Config.getNoSitePreview();
this.autoLoad = UIL.Config.getAutoLoad();
this.favIcon = UIL.Config.getFavIcon();
this.externalLinksResults = UIL.Config.getExtLinkSearch();
this.searchLinkTracking = UIL.Config.getSearchLinkTracking();
this.showExtraResults = UIL.Config.getShowExtraResults();
this.searchesRelatedTo = UIL.Config.getSearchesRelatedTo();
this.imagePreview = UIL.Config.getImagePreview();
this.remSponsor = UIL.Config.getRemSponsor();
this.remRightPanel = UIL.Config.getRemRightPanel();
this.resHue = UIL.Config.getResHue();
this.bGBorder = UIL.Config.getBGBorder();
this.backToTopLinkInsert = true;
this.backToTopLinkShow = true;
this.initialise = true;
this[pageProcessor]();
}
}
},
searchPageProcessor: function () {
var watch, that = this
if (this.watching) {
watch = document.querySelector(this.watching);
watch.addEventListener("DOMNodeInserted", function (e) {
monkeyr.log('inserted', e.target);
that.whackTest('inserted', e);
}, false);
watch.addEventListener("DOMSubtreeModified", function (e) {
monkeyr.log('subtree', e.target, e.attrName, e.newValue, e.prevValue, e)
that.whackTest('subtree', e);
}, false);
watch.addEventListener("DOMAttrModified", function (e) {
monkeyr.log('attribute', e.target, e.attrName, e.newValue, e.prevValue, e);
that.whackTest('attribute', e);
}, false);
watch.addEventListener("DOMNodeRemoved", function (e) {
monkeyr.log('removed', e.target);
that.whackTest('removed', e);
}, false);
// var observer = new MutationObserver(function(mutations) {
// mutations.forEach(function(e) {
// if(e.type!='childList'){
// if(e.target.getAttribute(e.attributeName) != e.oldValue){
// monkeyr.log('mutation', e.type, e.target, e.attributeName, e.target.getAttribute(e.attributeName), e.oldValue);
// }
// }
// else{
// monkeyr.log('mutation', e.type, e.target, e.addedNodes, e.removedNodes);
// }
// that.whackTest('mutation', e);
// });
// });
// observer.observe(watch, {
// attributes: true,
// childList: true,
// characterData: true,
// subtree: true,
// attributeOldValue: true
// });
return;
}
else {
watch = document.querySelector('#main');
watch.addEventListener("DOMNodeInserted", this.DOMNodeInsertedWatcher.bind(this), false);
watch.addEventListener("DOMNodeRemoved", this.DOMNodeRemovedWatcher.bind(this), false);
watch.addEventListener("DOMSubtreeModified", this.DOMSubtreeModifiedWatcher.bind(this), false);
watch.addEventListener("DOMAttrModified", this.DOMAttrModifiedWatcher.bind(this), false);
// if(typeof MutationObserver === 'function')
// {
// // Only firefox and chrome currently support MutationObserver
// var observer = new MutationObserver(function(mutations) {
// mutations.forEach(that.MutationObserver.bind(that))
// });
// observer.observe(watch, {
// attributes: true,
// childList: false,
// characterData: true,
// subtree: true,
// attributeOldValue: true
// });
// }
// else
// {
// // 4 opera
// watch.addEventListener("DOMSubtreeModified", this.DOMSubtreeModifiedWatcher.bind(this), false);
// watch.addEventListener("DOMAttrModified", this.DOMAttrModifiedWatcher.bind(this), false);
// }
}
if (!this.instant) {
this.registerControls();
this.whackDom();
}
var style = ''
style += ("#cnt.singleton #center_col, #cnt #center_col, #cnt.singleton #foot, #cnt #foot, .mw {width:auto !important; max-width:100% !important;} #rhs {left:auto !important; position:absolute}#botstuff .sp_cnt,#botstuff .ssp, #ires{display:none} .s{max-width:98%!important;} .vshid{display:inline} .ab_dropdown ul{list-style:none} #search *{white-space:normal!important} #search{border-spacing:5px} #rcnt .col:nth-of-type(3){width:100%!important} #rcnt .col:nth-of-type(4){float: none; right: 0px; top: -140px; width:100% !important}");
style += ("div#scrollTop a {background:url(" + UIL.RES.TOP_PNG + ") transparent;border-radius: 10px 10px 10px 10px;bottom: 30px;height: 40px;position: fixed;right: 30px;width: 40px;z-index: 10000;}div#scrollTop a{-webkit-transition: opacity 1.0s ease;-moz-transition: opacity 1.0s ease;-o-transition: opacity 1.0s ease;0} div#scrollTop a.mh_show{opacity: 0.2} div#scrollTop a.mh_hide{opacity: 0}div#scrollTop a:hover{-webkit-transition: opacity .5s ease;-moz-transition: opacity .5s ease;-o-transition: opacity .5s ease;opacity: 0.5;}");
style += ("div.col {width: 100% !important;} #rso .srg {column-count: " + this.numColumns +";}");
if (this.numColumns > 1) {
var bkWMgdWidth = '';
switch (this.numColumns) {
case 2:
bkWMgdWidth = '40vw';
break;
case 3:
bkWMgdWidth = '25vw';
break;
case 4:
bkWMgdWidth = '20vw';
break;
}
bkWMgdWidth = 'auto'; /* Izzy */
style += ("#cnt.singleton #center_col, #cnt.singleton #foot, #cnt #foot, .mw {margin-left:0 !important;}div.bkWMgd{max-width:" + bkWMgdWidth + " !important}");
}
if (this.autoLoad) {
style += ("#loadingimg {width:180px;height:34px;background-image:url(" + UIL.RES.LOADING_GIF + ");background-repeat:no-repeat;margin:2em auto auto auto;padding:10px;display:none;} #loadingimg p{font-size:130%;font-weight:bold;padding-left:40px;margin:0;float:left} #loadingimg a{text-align: left; float: left;margin: 2px 10px;}");
}
if (this.hideSearch) {
style += ("#ab_ctls,#ab_name,#resultStats{top:0} #gb,#gb.gbes,#gb.gbesi,#gb.gbem,#gb.gbemi{height:0!important}#gbx1,#gbx2{height:0!important}#gbq2[class='gbt'] #gbqfw{display:none;}#main{margin-top:44px!important}#gbu{margin-right:232px!important}");
//document.getElementById('gbq').addEventListener("DOMAttrModified", this.resizeWatcher, false);
//this.resizeWatcher(true);
}
if (this.remSponsor) {
style += ("#tvcap, #tads, #topstuff table.ts, #bottomads{display:none;}");
}
// if(this.noSitePreview)
// {
// style += (".vspib {display:none}");
// }
if (this.searchesRelatedTo) {
style += (".bkWMgd .kno-kp {display:none;} #center_col #extrares.med{display:none;} #botstuff #brs{display:none;} #topstuff .tqref{display:none;}");
}
// if(this.remRightPanel)
// {
// style += ("#rhs {display:none}");
// }
if (this.numResults) {
style += ("#res h3.r {display:inline}");
}
var hue = this.resHue;
if (hue.length == 0) {
hue = "transparent";
}
var BGBorder;
if (this.bGBorder == 'background') {
BGBorder = "background-color:";
}
else {
BGBorder = "border: 1pt solid ";
}
var imagePreview = "";
if (this.imagePreview) {
imagePreview = "min-height:102px;";
}
// style += ("#side_tab a {color:#444;background-color:"+hue+";border: meduim none;box-shadow: 0 -1px 3px rgba(0, 0, 0, 0.2);-webkit-box-shadow: 0 -1px 3px rgba(0, 0, 0, 0.2);font-weight: bold;padding: 3px 14px;margin-top: 50px;text-decoration: none;border-radius: 6px 6px 0 0;transform: rotate(-90deg);-webkit-transform: rotate(-90deg);-moz-transform: rotate(-90deg);filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=3);position: absolute;}#side_tab{float: right;height: 100px;position: absolute;right: -50px;width: 100px;z-index:-10000000}#rhs_block{float:right;}");
// style += (".side_out{-webkit-transform: translate(100%,0);-moz-transform: translate(100%,0);-o-transform: translate(100%,0);transition: all 2s ease-in-out;}#side_tab a:hover + .side_out{-webkit-transform: translate(-200%,0);-moz-transform: translate(-200%,0);-o-transform: translate(-100%,0);transition: all 2s ease-in-out;}");
style += ("#search li.g, #search div.g { margin-top: 0.15em !important; margin-right: 0.25em !important; margin-bottom: 0.15em !important; margin-left: 0.25em; -moz-border-radius: 10px; border-radius: 10px; " + BGBorder + " " + hue + " ! important; padding: 0.5em ! important; } li.g {list-style:none outside none;" + imagePreview + "};");
if (!this.watching) this.addStyle("@namespace url(http://www.w3.org/1999/xhtml); " + style);
if ((rhs = document.getElementById('rhs'))) {
this.rightPanelAdjuster(rhs);
}
// setInterval(this.watchTimer.bind(this),500);
// //monkeyr.log('google.timers.load.t.prt')
// monkeyr.log(window);
},
imagePageProcessor: function () {
this.registerControls();
var style = '';
style += ("div#scrollTop a {background:url(" + UIL.RES.TOP_PNG + ") transparent;border-radius: 10px 10px 10px 10px;bottom: 30px;height: 40px;position: fixed;right: 30px;width: 40px;z-index: 10000;}div#scrollTop a{-webkit-transition: opacity 1.0s ease;-moz-transition: opacity 1.0s ease;-o-transition: opacity 1.0s ease;0} div#scrollTop a.mh_show{opacity: 0.2} div#scrollTop a.mh_hide{opacity: 0}div#scrollTop a:hover{-webkit-transition: opacity .5s ease;-moz-transition: opacity .5s ease;-o-transition: opacity .5s ease;opacity: 0.5;}");
this.showBackToTopLink(true);
// style += ("#cnt #center_col, #cnt #foot, .mw {width:auto !important; max-width:100% !important;} #rhs {left:auto; !important}#botstuff .sp_cnt,#botstuff .ssp, #ires{display:none} .s{max-width:98%!important;} .vshid{display:inline} #res h3.r {white-space:normal}");
if (this.hideSearch) {
// style += ("#rcnt{margin-top:1em} #sfcnt,#sftr,#searchform{display:none!important;}#cnt{padding:0}#cnt .mw:first-child{position:absolute;top:4.5em;right:0}#rshdr .sfcc{position:absolute;top:2em;right:0}");
style += ("#ab_ctls,#ab_name,#resultStats{top:0} #gb,#gb.gbes,#gb.gbesi,#gb.gbem,#gb.gbemi{height:0!important}#gbx1,#gbx2{height:0!important}#gbq2[class='gbt'] #gbqfw{display:none;}#main{margin-top:0!important}");
// document.getElementById('gbq').addEventListener("DOMAttrModified", this.resizeWatcher, false);
//this.resizeWatcher(true);
}
if (this.remSponsor) {
style += ("#center_col, #foot {margin-right: 0 !important;} #rhs, #tads, #topstuff table.ts, #bottomads{display:none;}");
}
if (this.searchesRelatedTo) {
style += (".bkWMgd{display:none;} #center_col #extrares.med{display:none;} #botstuff #brs{display:none;} #topstuff .tqref{display:none;}");
}
if (this.showExtraResults) {
style += ("#appbar{display:none !important;}");
}
this.addStyle("@namespace url(http://www.w3.org/1999/xhtml); " + style);
},
whackTest: function (from, e) {
// if(from=='subtree' && e.target.id=='nyc' && e.target.className=='rhstc5'){
// monkeyr.logA('whackTest TRIGGER')
// return true;
// }
if (from == 'inserted' && e.target.id == 'navcnt') {
monkeyr.logA('whackTest DOM TRIGGER');
return 'dom';
}
// else if(from=='mutation' && e.target.id=='xfoot' && e.attributeName=='style' && e.target.style.visibility==''){
// monkeyr.logA('whackTest img TRIGGER');
// // return 'img';
// }
// else if(from=='attribute' && e.target.id=='pnnext' && e.attrName=='href'){
// monkeyr.logA('whackTest lnk TRIGGER', this);
// this.getAutoLoadParams();
// }
return false;
},
DOMNodeInsertedWatcher: function (e) {
monkeyr.logE('inserted', e.target)
if (e.target.id == 'ab_ctls' || e.target.id == 'hdtb') {
this.registerControls();
}
else if (e.target.id == 'rhs') {
this.rightPanelAdjuster(e.target);
}
if (this.whackTest('inserted', e) == 'dom') this.whackDom();
// if(this.whackTest('inserted', e)=='img') this.whackImages(document);
},
MutationObserver: function (e) {
if (e.type != 'childList') {
if (e.target.getAttribute(e.attributeName) != e.oldValue) {
monkeyr.logE('mutation', e.type, e.target, e.attributeName, e.target.getAttribute(e.attributeName), e.oldValue);
}
}
else {
monkeyr.logE('mutation', e.type, e.target, e.addedNodes, e.removedNodes);
}
if (this.whackTest('mutation', e) == 'dom') this.whackDom();
// if(this.whackTest('mutation', e)=='img') this.whackImages(document);
},
DOMSubtreeModifiedWatcher: function (e) {
monkeyr.logE('subtree', e.target, e.attrName, e.newValue, e.prevValue, e)
// monkeyr.logE('subtree', e.target, e.attributeName, e.target.getAttribute(e.attributeName), e.oldValue)
// if(this.whackTest('subtree', e)) this.whackDom();
if (this.whackTest('subtree', e) == 'dom') this.whackDom();
// if(this.whackTest('subtree', e)=='img') this.whackImages(document);
},
DOMAttrModifiedWatcher: function (e) {
monkeyr.logE('attribute', e.target, e.attrName, e.newValue, e.prevValue, e)
// monkeyr.logE('subtree', e.target, e.attributeName, e.target.getAttribute(e.attributeName), e.oldValue)
// if(this.whackTest('subtree', e)) this.whackDom();
if (this.whackTest('attribute', e) == 'dom') this.whackDom();
// if(this.whackTest('attribute', e)=='img') this.whackImages(document);
},
DOMNodeRemovedWatcher: function (e) {
monkeyr.logE('removed', e.target)
if (e.target.id == 'GTR') {
monkeyr.log('GTR REMOVED')
this.initialise = true;
clearTimeout(this.watchForScrollTimer);
}
},
whackDom: function () {
if (!document.getElementById('GTR')) {
clearTimeout(this.whackDomTimeOut);
this.whackDomTimeOut = setTimeout(function () {
var ires = document.getElementById('ires');
if (ires) {
monkeyr.log('!!!!! Whacking DOM !!!!!')
var extrares = document.getElementById('extrares');
var res = document.getElementById('res');
monkeyr.log(extrares, res, this.autoLoad)
if (extrares && res && this.autoLoad) {
res.parentNode.insertBefore(extrares, res);
}
if (this.hideSearch) {
// this.resizeWatcher(true);
}
if (!this.buildResultTable()) {
return;
}
if (this.autoLoad) {
if (this.getAutoLoadParams() && this.insertLoadingImage()) {
//monkeyr.log('watchForScroll');
this.watchForScroll.bind(this)();
}
}
this.processResults(document.getElementById('center_col'))
ires.parentNode.removeChild(ires);
this.initialise = false;
}
}.bind(this), 0);
}
},
resizeWatcher: function (e) {
//monkeyr.log(e.target.id)
if (e === true || (e.target && e.target.id == 'gbq')) {
setTimeout(function () {
//monkeyr.log('here')
//left side
var glogo = document.getElementById('gbq1');
var ab_name = document.getElementById('ab_name');
var ab_ctls = document.getElementById('ab_ctls');
var resultStats = document.getElementById('resultStats');
var gbu = document.getElementById('gbu');
var appbar = document.getElementById('appbar');
var glogoPos = findPos(glogo);
//monkeyr.log(glogoPos)
lft = glogoPos[0] + glogo.offsetWidth + 20;
ab_name.style.marginLeft = lft + 'px'
resultStats.style.marginLeft = (lft + ab_name.offsetWidth + 50) + 'px'
//right side
//monkeyr.log(getStyle(gbu, 'margin-right'))
ab_ctls.style.right = (gbu.offsetWidth + getStyle(gbu, 'margin-right') + 10) + 'px';
//heights
//monkeyr.log(gbu.offsetHeight)
ab_ctls.style.marginTop = getStyle(gbu, 'padding-top') + 'px'
ab_name.style.marginTop = (getStyle(gbu, 'padding-top') + 3) + 'px'
resultStats.style.marginTop = (getStyle(gbu, 'padding-top') + 10) + 'px'
appbar.style.height = (gbu.offsetHeight) + 'px'
}, 0);
}
},
rightPanelAdjuster: function (el) {
if (el && (center_col = document.getElementById('center_col')) && (foot = document.getElementById('foot'))) {
monkeyr.log('----rhs stuff----', el, this.remSponsor, this.remRightPanel);
if (this.remSponsor && (mbEnd = document.getElementById('mbEnd'))) {
monkeyr.log('rem mbEnd', mbEnd);
mbEnd.parentNode.removeChild(mbEnd);
}
if (this.remSponsor && (rhsvw = el.querySelector('div#rhs_block > div.rhsvw'))) {
monkeyr.log('rem .rhsvw');
rhsvw.parentNode.removeChild(rhsvw);
}
if (el.offsetHeight > 50) {
monkeyr.log('el.offsetWidth:', el.offsetWidth, 'el.offsetHeight', el.offsetHeight)
var div = document.buildElement('div', { id: 'slideout_tab' }, 'more info'),
width = el.offsetWidth,
height = el.offsetHeight,
css = "#slideout_tab{color:#444;border:meduim none;background-color: #fff;box-shadow:0 -1px 3px rgba(0,0,0,0.2);font-weight:bold;padding:3px 14px;margin:50px 0 0 -22px;text-decoration:none;width:65px;border-radius:6px 6px 0 0;transform:rotate(-90deg);-webkit-transform:rotate(-90deg);}.slideout{border-radius:5px 0 0 5px;right:0;padding:12px 0;position:absolute;text-align:center;top:140px;transition:all .5s ease-in-out;-webkit-transition:all .5s ease-in-out;width:35px;overflow:hidden;min-width:0!important;height:105px;}.slideout_inner{background-color:#fff;padding:0;position:absolute;text-align:left;top:0;width:0;margin-left:35px;width:" + width + "px!important;}.slideout:hover,.start_out{width:" + (width + 35) + "px!important;height:" + height + "px!important;}.start_in{transition:all 0s ease;-webkit-transition:all 0s ease;}";
var style = document.getElementById('side_tab_style');
if (!style) {
style = document.buildElement('style', { type: 'text/css', id: 'side_tab_style' });
if (style.styleSheet) {
style.styleSheet.cssText = css;
} else {
style.appendChild(document.createTextNode(css));
}
el.appendChild(style);
}
if (this.remRightPanel) {
setTimeout(function () { el.className = el.className.replace(' start_in', ''); }, 500)
el.className = el.className + ' start_in';
}
else {
setTimeout(function () { el.className = el.className.replace(' start_out', ''); }, 2000)
el.className = el.className + ' start_out';
}
el.className = el.className + ' slideout';
var t = el.firstChild;
el.insertBefore(div, el.firstChild);
t.className = t.className + " slideout_inner";
center_col.style.marginRight = '0px';
foot.style.marginRight = '0px';
}
else {
center_col.style.marginRight = '0px';
foot.style.marginRight = '0px';
}
}
},
insertEndText: function () {
//monkeyr.log('insertEndText');
var elem = document.buildElement('table', {
id: "endtext", width: "100%", cellspacing: "2", cellpadding: "0", border: "0", "class": "t bt",
style: "font-weight:bold;text-decoration:blink"
}, " End of the search results");
var res = document.getElementById("res");
res.parentNode.insertBefore(elem, res.nextSibling);
return elem;
},
reqMoreRes: function () {
if (this.requested == this.startNumber) {
return;
}
else {
this.requested = this.startNumber;
this.loadingImage.style.display = "block";
var query = this.query.replace(/start=\d*/, "start=" + this.startNumber);
this.nextLink.href = query;
monkeyr.log('reqMoreRes ' + query);
// monkeyr.log('reqMoreRes', this.startNumber, query);
this.UI.getURL(query, this.processResults.bind(this));
}
},
remainingScroll: function () {
var ret = (document.body.scrollHeight - window.pageYOffset - window.innerHeight);
return ret;
},
watchForScroll: function () {
var self = arguments.callee;
if (this.remainingScroll() < 300 && !this.requestingMoreResults && !this.initialise && document.getElementById('GTR')) {
//monkeyr.log('watchForScroll', this.scrollHeight, document.body.scrollHeight, this.winInnerHeight, window.innerHeight, window.pageYOffset)
// monkeyr.log('watchForScroll '+this.remainingScroll());
this.requestingMoreResults = true;
this.reqMoreRes();
this.scrollHeight = document.body.scrollHeight;
this.winInnerHeight = window.innerHeight;
}
else if (this.backToTopLinkInsert == window.pageYOffset > window.innerHeight * .5) {
this.insertBackToTopLink(this.backToTopLinkInsert);
}
else if (this.backToTopLinkShow == window.pageYOffset > window.innerHeight * .75) {
this.showBackToTopLink(this.backToTopLinkShow);
}
this.watchForScrollTimer = setTimeout(self.bind(this), 100);
},
insertLoadingImage: function () {
monkeyr.log('insertLoadingImage');
var nextLink = document.getElementByXPath("//table[@id='nav']//td[last()]/a");
var navbar = document.getElementByXPath("//table[@id='nav']//td/ancestor::table");
var loadingimg = document.getElementById('loadingimg');
if (navbar) {
navbar.style.display = "none";
if (!loadingimg) {
var div = document.buildElement('div', { id: '' });
var p = document.buildElement('p', {}, "");
var a = document.buildElement('a', { href: nextLink.href }, '');
div.appendChild(p);
div.appendChild(a);
this.nextLink = a;
navbar.parentNode.insertBefore(div, navbar)
this.loadingImage = div;
}
}
if (!this.endText) {
this.endText = this.insertEndText();
}
this.endText.style.display = nextLink && (nextLink.href.indexOf('start=') != -1) ? 'none' : 'block';
//monkeyr.log('insertLoadingImage '+nextLink);
return nextLink
},
insertBackToTopLink: function (insert) {
var a = document.querySelector('#scrollTop a');
if (insert && !a) {
var div = document.buildElement('div', { id: 'scrollTop' });
a = document.buildElement('a', { href: '#top', 'class': 'mh_hide' }, '', 'click', function (e) {
e.preventDefault();
e.stopPropagation();
document.querySelector("body").scrollIntoView();
});
div.appendChild(a);
document.body.appendChild(div);
}
a.style.display = ((insert) ? "inline" : "none");
this.backToTopLinkInsert = !insert;
return a;
},
showBackToTopLink: function (show) {
var a = document.querySelector('#scrollTop a');
if (!a) {
a = this.insertBackToTopLink(true);
}
this.backToTopLinkShow = !show
a.className = ((show) ? "mh_show" : "mh_hide");
},
getAutoLoadParams: function () {
// monkeyr.log('getAutoLoadParams');
var nextLink = document.getElementByXPath("//table[@id='nav']//td[last()]/a[contains(@href,'start')]");
if (nextLink) {
var href = nextLink.href;
this.startNumber = this._matchNum(href, /start=(\d+)/, 10);
this.itemsQuantity = this._matchNum(href, /num=(\d+)/, 10);
monkeyr.log('getAutoLoadParams', this.startNumber, this.itemsQuantity);
this.query = href;
this.resultStats = document.getElementById('resultStats');
return true;
}
else {
monkeyr.log('no more results');
return false;
}
},
buildResultTable: function () {
monkeyr.log('buildResultTable')
var tab = document.getElementById('GTR');
if (tab) {
//monkeyr.log('del tab')
tab.parentNode.removeChild(tab);
}
var table = document.buildElement('table', { id: 'GTR' });
this.resultsTable = table;
var div = document.getElementByXPath("//div/div[@class='g']/parent::div | //div[@id='rso']/div/div | //div[@id='res']/span[@id='search'] | //g-section-with-header");
if (div) {
// monkeyr.log('init this')
var start = window.location.search.match(/start=(\d+)/);
this.startBase = (start && start[1].retNum()) || 0;
this.lastI = 0;
this.startNumber = 0;
this.curRow = 0;
this.nextRow = 0;
this.requested = 0;
this.requestingMoreResults = false;
this.scrollHeight = 0;
// this.winInnerHeight = 0;
document.getElementById('ires').parentNode.appendChild(table);
if (this.showExtraResults) {
if (document.getElementById('appbar')) {
document.getElementById('appbar').outerHTML = "";
}
var list = document.getElementsByXPath("//div[@class='g' and not(@id='imagebox_bigimages')]");
}
else {
var multipleCheck = document.getElementByXPath("//*[@id='rso']/div[2]");
var list = multipleCheck ? document.getElementsByXPath("//*[@id='rso']/div/div[@class='srg']/div[@class='g'] | //*[@id='rso']/div[not(*[contains(@class, 'srg')])]") : document.getElementsByXPath("//div[@class='g']");
}
var length = list.length;
if ((ires = document.getElementById('ires')) && (cnt = document.getElementById('cnt'))) {
ires.style.display = ((length == 1) ? 'block' : 'none');
cnt.className = ((length == 1) ? cnt.className.replace(' singleton', '') : cnt.className + ' singleton');
if (length == 1) return false;
}
for (var i = 0; i < list.length; i++) {
this.resultsToTable(list, i, length, true);
}
this.nextRow = this.curRow;
this.paginationBoundry();
this.lastI = i;
return true;
}
},
paginationBoundry: function () {
if (this.newspaper && this.autoLoad) {
var row = this.nextRow++;
this.resultsTable.insertRow(row);
var cell = this.resultsTable.rows[row].insertCell(0);
cell.setAttribute("valign", "top");
cell.setAttribute("width", "100%");
cell.setAttribute("colspan", this.numColumns);
var hr = document.createElement('hr');
cell.appendChild(hr);
}
},
resultsToTable: function (list, i, resLength, initial) {
var link = list[i], div;
// console.log(link);
if (this.numResults && (div = document.getElementByXPath(".//div/div/a", link))) {
// console.log(div)
var str = document.buildElement('strong', null, (i + this.lastI + this.startBase + 1) + ' ');
div.parentNode.insertBefore(str, div);
}
// if(this.noSitePreview){
// var divs = document.getElementsByXPath(".//div[contains(@class,'vsc')]", link)
// for (var j = 0; j < divs.length; j++)
// {
// divs[j].setAttribute('class', divs[j].getAttribute('class').replace('vsc',''));
// }
// }
var col = 0, row = 0;
if (this.newspaper) {
var rowsPfetch = Math.ceil(resLength / this.numColumns);
col = Math.floor(i / rowsPfetch);
row = Math.floor(i - (col * rowsPfetch) + this.nextRow);
this.curRow = ((this.curRow <= row) && (row + 1)) || this.curRow;
}
else {
col = (i + this.lastI) % this.numColumns;
row = Math.floor((i + this.lastI) / this.numColumns);
}
if (col == 0) {
this.resultsTable.insertRow(row);
}
var a = document.getElementByXPath(".//div[contains(@class,'r')]/a", link);
var imageboxBigimages = document.getElementByXPath(".//div[contains(@id, 'imagebox_bigimages')]", link);
if (imageboxBigimages) {
Array.from(document.getElementsByClassName('tHqoQ rg_meta notranslate', link)).forEach(function (element) {
element.outerHTML = "";
});
Array.from(document.getElementsByClassName('vsqVBf rg_el ivg-i', link)).forEach(function (element) {
element.style = "display:inline-block;width:auto !important;height:auto !important;margin-left:5px;margin-right:5px;";
});
Array.from(document.getElementsByTagName('g-img', link)).forEach(function (element) {
element.style = "";
});
Array.from(document.getElementsByClassName('rISBZc M4dUYb', link)).forEach(function (element) {
element.style = "";
});
}
Array.from(document.getElementsByClassName('tHqoQ rg_meta notranslate', link)).forEach(function (element) {
element.outerHTML = "";
});
Array.from(document.getElementsByClassName('vsqVBf rg_el ivg-i', link)).forEach(function (element) {
element.style = "display:inline-block;width:auto !important;height:auto !important;margin-left:5px;margin-right:5px;";
});
Array.from(document.getElementsByTagName('g-img', link)).forEach(function (element) {
element.style = "";
});
Array.from(document.getElementsByClassName('rISBZc M4dUYb', link)).forEach(function (element) {
element.style = "";
});
if (a) {
var isImage = a.className != "bia";
if (this.externalLinksResults) {
a.target = "_blank";
}
else {
a.target = "_self";
}
if (this.searchLinkTracking) {
a.removeAttribute("onmousedown");
}
if (this.favIcon) {
var base = a.href.match(/http[s]?:\/\/([\w\.\-]+)[:\/]/);
if (base && isImage) {
var fav = document.buildElement('img', { width: '16', height: '16', style: 'margin-bottom:-3px;', src: window.location.protocol + '//www.google.com/s2/favicons?domain=' + encodeURIComponent(base[1]) });
a.parentNode.insertBefore(fav, a);
a.parentNode.insertBefore(document.createTextNode(' '), a);
}
}
if (this.imagePreview && isImage) {
// monkeyr.log(this.imagePreview)
var a2 = a.cloneNode(false);
a2.removeAttribute('class');
var sl = a.href.match(/:\/\/www.(\w)|:\/\/(\w)/);
var bs = a.href.match(/(http:\/\/[\w\.\-:]+)\/|(ftp:\/\/[\w\.\-:]+)\/|(https:\/\/[\w\.\-:]+)\//);
sl = sl[1] || sl[2];
bs = bs[1] || bs[2] || bs[3];
var img = document.buildElement('img', {
align: 'left', src: window.location.protocol + "//" + sl + ".searchpreview.de/preview?s=" + bs + "&ra=1",
style: 'border:1px solid #BBB;margin:2px 4px 5px 0px;width:111px;height:82px;'
});
a2.appendChild(img);
a.parentNode.parentNode.insertBefore(a2, a.parentNode);
}
var ele = document.getElementByXPath(".//div[@class='f kv']/cite/parent::div", link);
if (!this.searchLinkTracking && ele) {
var notrack = document.buildElement('a',
{ href: a.href, 'class': 'fl', title: 'Visit the link without Google tracking you' }, 'Trackless');
if (this.externalLinksResults) {
notrack.target = "_blank";
}
else {
notrack.target = "_self";
}
ele.appendChild(notrack, ele.nextSibling);
}
}
var sublinks = link.querySelectorAll('tr.mslg > a, span a.l');
for (var m = 0; m < sublinks.length; m++) {
var sublink = sublinks[m];
if (this.searchLinkTracking) {
sublink.removeAttribute("onmousedown");
if (this.externalLinksResults) {
sublink.target = "_blank";
}
else {
sublink.target = "_self";
}
}
else {
var notrack = document.buildElement('a',
{ href: sublink.href, 'style': 'font-size:x-small', title: 'Visit the link without Google tracking you' }, 'Trackless');
if (this.externalLinksResults) {
notrack.target = "_blank";
}
else {
notrack.target = "_self";
}
sublink.parentNode.appendChild(document.createTextNode(" - "), sublink.parentNode.nextSibling);
sublink.parentNode.appendChild(notrack, sublink.parentNode.nextSibling);
}
}
var cell = this.resultsTable.rows[row].insertCell(col);
cell.setAttribute("valign", "top");
if (!initial) cell.setAttribute("class", "dyna");
var cellWidth = Math.floor(100 / this.numColumns) + "%";
cell.setAttribute("width", cellWidth);
cell.appendChild(link);
},
processResults: function (responseText) {
// monkeyr.log('processResults')
var i, img;
//this.loadingImage.style.display = "none";
var nextResult = document.buildElement('div', null, responseText);
// var imgs = document.getElementsByXPath(".//img[contains(@class,@id)]");
// for (i = 0; (img = imgs[i++]);)
// {
// img.removeAttribute('id')
// }
var imageRegex = /var _image_src='(\S+)';/gm;
var imageIdRegex = /var _image_ids=\['(\S+)'\];/gm;
var imageResult;
var imageIdResult;
while ((imageResult = imageRegex.exec(responseText)) !== null) {
imageIdResult = imageIdRegex.exec(responseText);
if (imageResult.index === imageRegex.lastIndex) {
imageRegex.lastIndex++;
}
if (imageIdResult.index === imageIdRegex.lastIndex) {
imageIdRegex.lastIndex++;
}
var tempElement = document.getElementByXPath(".//img[@id='" + imageIdResult[1] + "']", nextResult);
if (tempElement) {
tempElement.src = eval('"' + imageResult[1] + '"');
}
}
var stats = document.getElementByXPath(".//div[@id='resultStats']", nextResult);
if (this.resultStats && stats) {
this.resultStats.innerHTML = stats.innerHTML;
}
if (this.showExtraResults) {
var list = document.getElementsByXPath("//div[@class='g' and not(@id='imagebox_bigimages')]", nextResult);
if (document.getElementById('appbar', nextResult)) {
document.getElementById('appbar', nextResult).outerHTML = "";
}
}
else {
var multipleCheck = document.getElementByXPath("//*[@id='rso']/div[2]", nextResult);
var list = multipleCheck ? document.getElementsByXPath("//*[@id='rso']/div/div[@class='srg']/div[@class='g'] | //*[@id='rso']/div[not(*[contains(@class, 'srg')])]", nextResult) : document.getElementsByXPath("//div[@class='g']", nextResult);
}
var length = list.length;
if ((ires = document.getElementById('ires')) && (cnt = document.getElementById('cnt'))) {
ires.style.display = ((length == 1) ? 'block' : 'none');
cnt.className = ((length == 1) ? cnt.className.replace(' g', '') : cnt.className + ' g');
if (length == 1) return false;
}
for (i = 0; i < list.length; i++) {
this.resultsToTable(list, i, length, false);
}
this.nextRow = this.curRow;
this.paginationBoundry();
this.lastI += i;
var isNextExist = document.getElementByXPath(".//table[@id='nav']//td[last()]/a[@href]", nextResult);
if (isNextExist) {
this.startNumber += this.itemsQuantity;
}
else {
// this.endText.style.display = 'block';
}
this.requestingMoreResults = false;
},
whackImages: function (whackie) {
clearTimeout(this.whackImagesTimeOut);
this.whackImagesTimeOut = setTimeout(function () {
if (this.requestingMoreResults) return;
monkeyr.log('!!!!! Whacking Img !!!!!')
// fix for thumnail display from google image search on 2nd or greater autoloaded pages
var xfoot = document.getElementByXPath(".//div[@id='xfoot']", whackie);
var scrxpath = (xfoot) ? ".//div[@id='xfoot']/script" : "./script"; //results returned in Opera have no xfoot div. Weird!)
var imgscrs = document.getElementsByXPath(scrxpath, whackie);
// monkeyr.log(scrxpath +', '+imgscrs.length)
if (imgscrs && imgscrs.length > 1) {
for (i = 0; i < (imgscrs.length - 1); i++) {
var scr = imgscrs[i] && imgscrs[i].innerHTML;
if (scr.indexOf('data:image/') != -1) {
// monkeyr.log(scr);
eval(scr);
}
}
}
// monkeyr.log(whackie.nodeName)
// fix for thumnail zoom from google image search on 2nd or greater autoloaded pages
var xjsi = whackie.querySelector('#xjsi script');
if (xjsi) {
// monkeyr.log(xjsi.innerHTML);
// commented out as it seems to fix the zoom on autoloaded results but breaks the "more" link
// this.exec(xjsi.innerHTML);
}
// fix for auto load thumnails being overwritten
var imgs = document.querySelectorAll('td.dyna div.th img[id]');
for (var m = 0; m < imgs.length; m++) {
// monkeyr.log('removeid', imgs[m].id);
imgs[m].removeAttribute('id');
}
// Fix for image mouseover error
var imgs = document.querySelectorAll('img.rg_hi:not([id])');
for (var m = 0; m < imgs.length; m++) {
// monkeyr.log('mouseover',imgs[m]);
imgs[m].id = 'rg_hi';
}
}.bind(this), 0);
},
exec: function (fn) {
var script = document.buildElement('script', { 'type': 'application/javascript' });
script.textContent = '(function(){' + fn + '})();';
document.body.appendChild(script); // run the script
document.body.removeChild(script); // clean up
},
externalLinks: function (scope, blank) {
var thisdomain = window.location.host;
var links = scope.getElementsByTagName('a');
for (var i = 0; i < links.length; i++) {
var a = links[i];
if (a.href && a.host && a.host != thisdomain) {
a.target = (blank ? "_blank" : "_self");
}
}
},
registerControls: function () {
monkeyr.log('registerControls');
var controls = document.getElementByXPath("//*[@id='ab_options']");
var liclass = 'hdtb-mitem';
var linkclass = (controls) ? 'ab_dropdownlnk' : 'gbmt';
var link = document.getElementById('GoogleMonkeyRLink');
if (controls && !link) {
monkeyr.log('registerControls Registered');
var parent = controls.parentNode;
var li = document.buildElement('g-header-menu', { 'class': liclass });
link = document.buildElement('a', { href: '#', id: 'GoogleMonkeyRLink', 'class': linkclass }, 'GoogleMonkeyR settings', 'click', UIL.UI.preferencesShow.bind(UIL.UI));
li.appendChild(link);
parent.insertBefore(li, controls);
}
if (typeof GM_registerMenuCommand !== "undefined") {
GM_registerMenuCommand("GoogleMonkeyR Preferences", UIL.UI.preferencesShow.bind(UIL.UI));
}
},
addStyle: function (css) {
if (typeof GM_addStyle != "undefined") {
GM_addStyle(css);
} else {
var heads = document.getElementsByTagName("head");
if (heads.length > 0) {
var node = document.createElement("style");
node.type = "text/css";
node.innerHTML = css;
heads[0].appendChild(node);
}
}
},
_matchNum: function (subject, test, def) {
var out = subject.match(test);
return (out ? +(out[1]) : (def || 0));
}
};
/**
* Configuration.
**/
UIL.Config =
{
getBGBorder: function () {
return this._getBooleanConfig("BGBorder", "background");
},
setBGBorder: function (BGBorder) {
GM_setValue("BGBorder", BGBorder);
},
getResHue: function () {
return this._getBooleanConfig("resHue", "#FAFAE6");
},
setResHue: function (resHue) {
resHue = resHue.toUpperCase();
if (!resHue.match(/^#[0-9A-F]{6}$/)) {
resHue = "";
}
GM_setValue("resHue", resHue);
},
getNumCol: function () {
return this._getBooleanConfig("numCol", 1);
},
setNumCol: function (numCol) {
GM_setValue("numCol", numCol);
},
getRemSponsor: function () {
return this._getBooleanConfig("remSponsor", false);
},
setRemSponsor: function (remSponsor) {
GM_setValue("remSponsor", remSponsor);
},
getRemRightPanel: function () {
return this._getBooleanConfig("remRightPanel", false);
},
setRemRightPanel: function (remRightPanel) {
GM_setValue("remRightPanel", remRightPanel);
},
getNumResults: function () {
return this._getBooleanConfig("numResults", false);
},
setNumResults: function (numResults) {
GM_setValue("numResults", numResults);
},
getAutoLoad: function () {
return this._getBooleanConfig("autoLoad", false);
},
setAutoLoad: function (autoLoad) {
GM_setValue("autoLoad", autoLoad);
},
getHideSearch: function () {
return this._getBooleanConfig("hideSearch", false);
},
setHideSearch: function (hideSearch) {
GM_setValue("hideSearch", hideSearch);
},
getExtLinkSearch: function () {
return this._getBooleanConfig("extLinkSearch", false);
},
setExtLinkSearch: function (extLinkSearch) {
GM_setValue("extLinkSearch", extLinkSearch);
},
getSearchLinkTracking: function () {
return this._getBooleanConfig("searchLinkTracking", false);
},
setSearchLinkTracking: function (searchLinkTracking) {
GM_setValue("searchLinkTracking", searchLinkTracking);
},
getShowExtraResults: function () {
return this._getBooleanConfig("showExtraResults", false);
},
setShowExtraResults: function (showExtraResults) {
GM_setValue("showExtraResults", showExtraResults);
},
getImagePreview: function () {
return this._getBooleanConfig("imagePreview", false);
},
setImagePreview: function (imagePreview) {
GM_setValue("imagePreview", imagePreview);
},
getFavIcon: function () {
return this._getBooleanConfig("favIcon", false);
},
setFavIcon: function (favIcon) {
GM_setValue("favIcon", favIcon);
},
getSearchesRelatedTo: function () {
return this._getBooleanConfig("hideSearchesRelatedTo", false);
},
setSearchesRelatedTo: function (hideSearchesRelatedTo) {
GM_setValue("hideSearchesRelatedTo", hideSearchesRelatedTo);
},
getResultFlow: function () {
return this._getBooleanConfig("resultFlow", "l2r");
},
setResultFlow: function (resultFlow) {
GM_setValue("resultFlow", resultFlow);
},
getNoSitePreview: function () {
return this._getBooleanConfig("noSitePreview", false);
},
setNoSitePreview: function (noSitePreview) {
GM_setValue("noSitePreview", noSitePreview);
},
_getBooleanConfig: function (configName, defaultValue) {
var config = GM_getValue(configName);
if (config === undefined) {
GM_setValue(configName, defaultValue);
config = defaultValue;
}
return config;
}
};
/**
* Preferences User Interface (UI).
**/
UIL.UI =
{
preferencesShow: function (e) {
if (e) {
e.preventDefault();
e.stopPropagation();
}
this._loadBlocker();
var prefs = document.buildElement('div',
{
id: 'uil_preferences', name: 'uil_preferences',
style: 'position:fixed;top:5%;left:0px;right:0px;border:none;height:100%;width:100%;overflow:hidden;z-index:10001;'
}
, this.Base64.decode(UIL.RES.PREFS_HTML));
document.body.appendChild(prefs);
this.preferencesDocumentLoadHandler();
this.prefs = prefs;
},
_loadBlocker: function () {
if (this.blocker == null) {
var blocker = document.buildElement('div',
{
id: 'uil_blocker',
style: 'position:fixed;top:0px;left:0px;right:0px;bottom:0px;background-color:#000;opacity:0.5;z-index:10000;'
});
this.blocker = blocker;
document.body.appendChild(blocker);
}
},
updateScript: function (e) {
if (e) {
e.preventDefault();
e.stopPropagation();
}
this._loadBlocker();
try {
window.location.replace("http://userscripts.org/scripts/source/" + UIL.scriptId + ".user.js");
}
catch (e) { }
if (this.prefs) document.body.removeChild(this.prefs);
if (this.history) document.body.removeChild(this.history);
GM_setValue('skipVersion', 0);
setTimeout(this.refreshShow.bind(this), 4000);
},
refreshShow: function () {
var refresh = document.buildElement('iframe',
{
style: 'position:fixed;top:20%;left:0px;right:0px;border:none;height:100%;width:100%;overflow:hidden;z-index:10001;',
src: UIL.RES.REFRESH_HTML
}, '', 'load', this.refreshDocumentLoadHandler.bind(this));
this.refresh = refresh;
document.body.appendChild(refresh);
},
refreshDocumentLoadHandler: function () {
this.refresh.contentDocument.getElementById("scriptName").innerHTML = UIL.scriptName;
},
hide: function () {
if (this.history) document.body.removeChild(this.history);
if (this.prefs) document.body.removeChild(this.prefs);
if (this.blocker) document.body.removeChild(this.blocker);
this.history = null;
this.prefs = null;
this.blocker = null;
},
preferencesDocumentLoadHandler: function () {
var form = document.getElementById("preferences");
// Set up form state
form.elements.namedItem("numcol" + UIL.Config.getNumCol()).checked = true;
form.elements.namedItem("remsponsor").checked = UIL.Config.getRemSponsor();
form.elements.namedItem("numresults").checked = UIL.Config.getNumResults();
form.elements.namedItem("remrightpanel").checked = UIL.Config.getRemRightPanel();
form.elements.namedItem("autoload").checked = UIL.Config.getAutoLoad();
form.elements.namedItem("hidesearch").checked = UIL.Config.getHideSearch();
form.elements.namedItem("noSitePreview").checked = UIL.Config.getNoSitePreview();
form.elements.namedItem("extlinksearch").checked = UIL.Config.getExtLinkSearch();
form.elements.namedItem("searchlinktracking").checked = UIL.Config.getSearchLinkTracking();
form.elements.namedItem("showextraresults").checked = UIL.Config.getShowExtraResults();
form.elements.namedItem("ResHuefield").value = UIL.Config.getResHue();
form.elements.namedItem("imagepreview").checked = UIL.Config.getImagePreview();
form.elements.namedItem("favicon").checked = UIL.Config.getFavIcon();
form.elements.namedItem("remsearchesrelatedto").checked = UIL.Config.getSearchesRelatedTo();
//this.prefs.contentDocument.getElementById("ResHue").style.color = UIL.Config.getResHue();
document.getElementById("ResHue").style.background = UIL.Config.getResHue();
document.getElementById("BGBorderlink").innerHTML = UIL.Config.getBGBorder();
document.getElementById("flowimg").className = UIL.Config.getResultFlow();
// Set up event handlers
form.elements.namedItem("close_button").addEventListener("click", this.hide.bind(this), false);
form.elements.namedItem("save_button").addEventListener("click", this.preferencesSaveConfigurationHandler.bind(this), false);
document.getElementById("ResHue").addEventListener("click", UIL.RES.colorPicker.pickColor.bind(UIL.RES.colorPicker), false);
document.getElementById("flowimg").addEventListener("click", UIL.RES.flowtog, false);
document.getElementById("BGBorderlink").addEventListener("click", UIL.RES.bgBordertog, false);
document.getElementById("ResHuefield").addEventListener("change", UIL.RES.colorPicker.relateColor('ResHue'), false);
document.getElementById("version").innerHTML = UIL.scriptVersion;
if (BrowserDetect.csQuery) {
this.getURL("http://userscripts.org/scripts/source/" + UIL.scriptId + ".meta.js", this.updateTestOnPreferences.bind(this));
}
else {
this.updateLink(false);
}
},
getURL: function (address, cb) {
GM_xmlhttpRequest({
method: "GET",
url: address,//+"?"+Math.random(),
onload: function (xhr) { cb(xhr.responseText); }
});
},
updateCheckRequest: function () {
if (!BrowserDetect.csQuery) return;
var lastCheck = GM_getValue('lastCheck', 0);
if (this._currentTime() > (lastCheck + 86400)) //24 hours after last check
{
GM_setValue('delayUpdate', false);
this.getURL("http://userscripts.org/scripts/source/" + UIL.scriptId + ".meta.js", this.updateTestOnPage.bind(this));
}
else {
this.onSiteVersion = GM_getValue('onSiteVersion', 0);
var delayUpdate = GM_getValue('delayUpdate', false);
var skipVersion = GM_getValue('skipVersion', 0);
if (this.versionCompare(UIL.scriptVersion, this.onSiteVersion)) {
if (this.versionCompare(skipVersion, this.onSiteVersion) && !delayUpdate) {
this.updateMessageShow();
}
}
}
},
updateTestOnPage: function (text) {
var skipVersion = GM_getValue('skipVersion', 0);
var onSiteVersion = text.match(/\/\/\s*@version\s*(\d.*)/);
this.onSiteVersion = (onSiteVersion === null) ? 0 : onSiteVersion[1];
GM_setValue('onSiteVersion', this.onSiteVersion);
var updateHistory = text.substring(text.search(/\/\*.*StartHistory/im));
updateHistory = updateHistory.substring(0, updateHistory.search(/EndHistory.*\*\//im))
GM_setValue('onSiteVersionHistory', encodeURI(updateHistory));
if (this.versionCompare(UIL.scriptVersion, this.onSiteVersion)) {
if (this.versionCompare(skipVersion, this.onSiteVersion)) {
this.updateMessageShow();
}
}
GM_setValue('lastCheck', this._currentTime());
},
updateLink: function (update) {
var link = document.getElementById("check_update");
link.setAttribute("target", "_top");
if (update) {
link.addEventListener("click", this.historyShow.bind(this), false);
link.setAttribute("title", " see what's new with GoogleMonkeyR... ");
link.style.textDecoration = "blink";
link.innerHTML = "v" + this.onSiteVersion + " available";
}
else {
if (BrowserDetect.csQuery) {
link.setAttribute("href", "#");
link.setAttribute("title", " the history of GoogleMonkeyR ");
link.innerHTML = "history";
link.addEventListener("click", this.historyShow.bind(this), false);
}
else {
link.setAttribute("href", "https://greasyfork.org/zh-TW/scripts/373206-googlemonkeyr-modified-by-cook-wu");
link.setAttribute("title", " check for the latest script version on the homepage ");
link.innerHTML = "script homepage";
}
link.parentNode.appendChild(document.createTextNode(" - "));
var link2 = document.buildElement('a', {
href: "http://" + location.hostname + "/preferences",
target: '_parent', title: ' your Google preferences '
}, 'prefs');
link.parentNode.appendChild(link2);
}
},
updateTestOnPreferences: function (text) {
var onSiteVersion = text.match(/\/\/\s*@version\s*(\d.*)/);
this.onSiteVersion = (onSiteVersion === null) ? 0 : onSiteVersion[1];
GM_setValue('onSiteVersion', this.onSiteVersion);
var updateHistory = text.substring(text.search(/\/\*/));
updateHistory = updateHistory.substring(0, updateHistory.search(/\*\//))
GM_setValue('onSiteVersionHistory', encodeURI(updateHistory));
this.updateLink(this.versionCompare(UIL.scriptVersion, this.onSiteVersion));
GM_setValue('lastCheck', this._currentTime());
},
versionCompare: function (ver1, ver2) {
var maxVersionPartTest = 5;
var ver1Arr = (ver1 + ('.0'.repeat(maxVersionPartTest))).split(".", maxVersionPartTest);
var ver2Arr = (ver2 + ('.0'.repeat(maxVersionPartTest))).split(".", maxVersionPartTest);
//alert(ver1Arr.join(',') + ' - ' +ver2Arr.join(','));
for (var i = 0; i < maxVersionPartTest; i++) {
//alert(ver1Arr[i].retNum() +' '+ ver2Arr[i].retNum());
if (ver1Arr[i].retNum() < ver2Arr[i].retNum()) {
break;
}
else if (ver1Arr[i].retNum() > ver2Arr[i].retNum()) {
i = maxVersionPartTest
break;
}
}
return (i < maxVersionPartTest);
},
updateMessageShow: function () {
UIL.addStyle("@namespace url(http://www.w3.org/1999/xhtml); .gbh{display: none !important;} #gm_update_alert {margin: 10px; background-color: #E5ECF9; text-align: center; -moz-border-radius: 5px; position: relative; z-index: 2000; border: 1px solid; } #gm_update_alert a:visited {color: #0000CC !important} #gm_update_alert p {padding: 5px}");
var div = document.buildElement("div", { id: 'gm_update_alert' });
var p = document.createElement("p");
var sn = document.buildElement("strong", {}, UIL.scriptName + "&nbsp;");
var sep = document.buildElement("span", {}, "&nbsp;&nbsp;-&nbsp;&nbsp;");
p.appendChild(sn);
p.appendChild(document.createTextNode(" update available v" + this.onSiteVersion + " (current v" + UIL.scriptVersion + ")"));
p.appendChild(sep.cloneNode(true));
p.appendChild(document.buildElement('a', { href: '#' }, "Ignore for 24 hours", 'click', UIL.UI.updateDelay.bind(UIL.UI)));
p.appendChild(sep.cloneNode(true));
p.appendChild(document.buildElement('a', { href: '#' }, "Wait for next version", 'click', UIL.UI.updateSkip.bind(UIL.UI)));
p.appendChild(sep.cloneNode(true));
var a = document.buildElement("a", { target: "_blank", href: "http://userscripts.org/scripts/show/" + UIL.scriptId }, "Script homepage");
p.appendChild(a);
p.appendChild(sep.cloneNode(true));
p.appendChild(document.buildElement('a', { href: '#' }, "What's new", 'click', UIL.UI.historyShow.bind(UIL.UI)));
p.appendChild(sep.cloneNode(true));
p.appendChild(document.buildElement('a', { href: '#' }, "Update", 'click', UIL.UI.updateScript.bind(UIL.UI)));
div.appendChild(p);
document.body.insertBefore(div, document.body.firstChild);
this.updateMessage = div
},
updateMessageHide: function () {
if (this.updateMessage) document.body.removeChild(this.updateMessage);
this.updateMessage = null;
},
updateDelay: function (e) {
if (e) {
e.preventDefault();
e.stopPropagation();
}
GM_setValue('delayUpdate', true);
alert("You will not be reminded about this update again for 24 hours.");
this.updateMessageHide();
},
updateSkip: function (e) {
if (e) {
e.preventDefault();
e.stopPropagation();
}
GM_setValue('skipVersion', this.onSiteVersion);
alert("You will not be reminded again until the next new version is released.");
this.updateMessageHide();
},
_currentTime: function () {
var d = new Date();
return Math.round(d.getTime() / 1000); // Unix time in seconds
},
historyShow: function (e) {
if (e) {
e.preventDefault();
e.stopPropagation();
}
this._loadBlocker();
if (this.prefs) document.body.removeChild(this.prefs);
this.prefs = null;
var history = document.buildElement("iframe", {
src: UIL.RES.HISTORY_HTML,
style: "position:fixed;top:5%;left:0px;right:0px;border:none;height:100%;width:100%;overflow:hidden;z-index:10001"
},
null, "load", this.historyDocumentLoadHandler.bind(this));
this.history = history;
document.body.appendChild(history);
},
historyDocumentLoadHandler: function () {
this.history.contentDocument.getElementById("version").innerHTML = UIL.scriptVersion;
this.history.contentDocument.getElementById("scriptName").innerHTML = UIL.scriptName;
var form = this.history.contentDocument.forms.namedItem("history");
// Set up form state
form.elements.namedItem("history_text").innerHTML = decodeURI(GM_getValue('onSiteVersionHistory', ''));
// Set up event handlers
form.elements.namedItem("install_button").addEventListener("click", this.updateScript.bind(this), false);
form.elements.namedItem("close_button").addEventListener("click", this.hide.bind(this), false);
},
preferencesSaveConfigurationHandler: function () {
var form = document.getElementById("preferences");
for (var i = 1; i <= 4; i++) {
if (form.elements.namedItem("numcol" + i).checked) {
UIL.Config.setNumCol(i);
break;
}
}
UIL.Config.setRemSponsor(form.elements.namedItem("remsponsor").checked);
UIL.Config.setNumResults(form.elements.namedItem("numresults").checked);
UIL.Config.setRemRightPanel(form.elements.namedItem("remrightpanel").checked);
UIL.Config.setAutoLoad(form.elements.namedItem("autoload").checked);
UIL.Config.setHideSearch(form.elements.namedItem("hidesearch").checked);
UIL.Config.setNoSitePreview(form.elements.namedItem("noSitePreview").checked);
UIL.Config.setExtLinkSearch(form.elements.namedItem("extlinksearch").checked);
UIL.Config.setSearchLinkTracking(form.elements.namedItem("searchlinktracking").checked);
UIL.Config.setShowExtraResults(form.elements.namedItem("showextraresults").checked);
UIL.Config.setResHue(form.elements.namedItem("ResHuefield").value);
UIL.Config.setBGBorder(document.getElementById("BGBorderlink").innerHTML);
UIL.Config.setImagePreview(form.elements.namedItem("imagepreview").checked);
UIL.Config.setFavIcon(form.elements.namedItem("favicon").checked);
UIL.Config.setSearchesRelatedTo(form.elements.namedItem("remsearchesrelatedto").checked);
UIL.Config.setResultFlow(document.getElementById("flowimg").className);
this.hide();
window.location.reload(true);
},
/**
*
* Base64 encode / decode
* http://www.webtoolkit.info/
*
**/
Base64: {
// private property
_keyStr:
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",
// public method for encoding
encode: function (input, isBinaryData) {
var output = [];
var chr1, chr2, chr3, enc1, enc2, enc3, enc4;
var i = 0;
input = isBinaryData ? String.fromCharCode.apply(null, input) :
this._utf8_encode(input);
var len = input.length;
while (i < len) {
chr1 = input.charCodeAt(i++);
chr2 = input.charCodeAt(i++);
chr3 = input.charCodeAt(i++);
enc1 = chr1 >> 2;
enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
enc4 = chr3 & 63;
if (isNaN(chr2)) {
enc3 = enc4 = 64;
} else if (isNaN(chr3)) {
enc4 = 64;
}
output.push(
this._keyStr.charAt(enc1) + this._keyStr.charAt(enc2) +
this._keyStr.charAt(enc3) + this._keyStr.charAt(enc4));
}
return output.join("");
},
// public method for decoding
decode: function (input) {
if (!input)
return "";
var output = [];
var chr1, chr2, chr3;
var enc1, enc2, enc3, enc4;
var i = 0;
input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");
var len = input.length;
while (i < len) {
enc1 = this._keyStr.indexOf(input.charAt(i++));
enc2 = this._keyStr.indexOf(input.charAt(i++));
enc3 = this._keyStr.indexOf(input.charAt(i++));
enc4 = this._keyStr.indexOf(input.charAt(i++));
chr1 = (enc1 << 2) | (enc2 >> 4);
chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
chr3 = ((enc3 & 3) << 6) | enc4;
output.push(String.fromCharCode(chr1));
if (enc3 != 64) {
output.push(String.fromCharCode(chr2));
}
if (enc4 != 64) {
output.push(String.fromCharCode(chr3));
}
}
return this._utf8_decode(output.join(""));
},
// private method for UTF-8 encoding
_utf8_encode: function (string) {
string = string.replace(/\r\n/g, "\n");
var utftext = [];
var len = string.length;
for (var n = 0; n < len; n++) {
var c = string.charCodeAt(n);
if (c < 128) {
utftext.push(String.fromCharCode(c));
}
else if ((c > 127) & (c < 2048)) {
utftext.push(String.fromCharCode((c >> 6) | 192),
String.fromCharCode((c & 63) | 128));
}
else {
utftext.push(String.fromCharCode((c >> 12) | 224),
String.fromCharCode(((c >> 6) & 63) | 128),
String.fromCharCode((c & 63) | 128));
}
}
return utftext.join("");
},
// private method for UTF-8 decoding
_utf8_decode: function (utftext) {
var string = [];
var i = 0;
var c = c1 = c2 = 0;
var len = utftext.length;
while (i < len) {
c = utftext.charCodeAt(i);
if (c < 128) {
string.push(String.fromCharCode(c));
i++;
}
else if ((c > 191) & (c < 224)) {
c2 = utftext.charCodeAt(i + 1);
string.push(String.fromCharCode(((c & 31) << 6) | (c2 & 63)));
i += 2;
}
else {
c2 = utftext.charCodeAt(i + 1);
c3 = utftext.charCodeAt(i + 2);
string.push(String.fromCharCode(((c & 15) << 12) |
((c2 & 63) << 6) | (c3 & 63)));
i += 3;
}
}
return string.join("");
}
}
};
/**
* Resource section (RES).
**/
UIL.RES =
{
PREFS_HTML: "<style type="text/css">
    .body {
        margin: 0;
        padding: 0;
        font-size: 12px;
        font-family: "Lucida Grande", "Bitstream Vera Sans", Verdana, Arial, sans-serif;
        color: #333;
        width: 550px;
        margin: 0 auto;
    }
    #colorpicker {
        position: absolute;
        border: #000000 1px solid;
        background: #FFFFFF;
        display: none;
        z-index: 10002;
    }
    .module {
        border: 1px solid #ccc;
        margin-bottom: 5px;
        background-color: #fff;
    }
    .module caption,
    .module h2 {
        margin: 0;
        padding: 2px 5px 3px;
        font-size: 11px;
        font-weight: bold;
        background: #CCCCCC url("data:image/gif;base64,R0lGODlhAQAWAMQAAMjKysXHx9%2Fh4c%2FR0ePl5cbIyNPV1c3Pz%2Bfp6d7h4e7w8Ovt7cvNzdfZ2eHj49vd3fDy8gAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAAAAAAALAAAAAABABYAAAUSICQqC0IIT3MEBcAMRvMkjhMCADs%3D") top left repeat-x;
        color: #666666;
        border-bottom: 0;
    }
    .form-row {
        overflow: hidden;
        padding: 8px 12px;
        margin-top: 3px;
        font-size: 11px;
        border-bottom: 1px solid #eee;
        border-right: 1px solid #eee;
    }
    .form-row img,
    .form-row input {
        vertical-align: middle;
        margin-top: 0;
    }
    .aligned label {
        padding: 0 1em 3px 0;
        float: left;
        width: auto;
    }
    .checkbox-row label {
        padding: 0;
        float: none;
        width: auto;
    }
    .body input.btn {
        padding: 0 10px;
        color: #999999;
        background-color: White;
        font-weight: bold;
        border: solid 1px #CCCCCC;
        text-align: center;
        font-size: 12px;
    }
    .body input.btn:hover {
        padding: 1px 11px;
        color: #333333;
        border-color: #666666;
    }
    .body a {
        font-weight: bold;
        color: #999999;
        text-decoration: none;
        cursor: pointer;
    }
    .body a:hover {
        font-weight: bold;
        color: #333333 !important;
        text-decoration: none;
    }
    .body img.l2r {
        background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAZCAMAAAAc9R5vAAAABGdBTUEAAK%2FINwWK6QAAABl0RVh0U29mdHdhcmUAQWRvYmUgSW1hZ2VSZWFkeXHJZTwAAAAYUExURf97e%2F%2FJyTUAAP87O7oAAP8AAAAAAP%2F%2F%2F%2BVYFu4AAABySURBVHjarJFLDoAwCET5td7%2FxiZ8rIA2LpwVGXgpTOF4EWwaM5TKLSEu5qic4FHEQdQGtTdAfWxboc%2FXrVAfg3YHqS%2F9Do6FCiFrPhF5fhE6z9Syuh2QCHK%2FpmuHAV5ygiysD%2BkOI6j5Y%2F795886BRgA%2F5sN2H8r99QAAAAASUVORK5CYII%3D") no-repeat transparent;
    }
    .body img.t2b {
        background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAZCAMAAAAc9R5vAAAABGdBTUEAAK%2FINwWK6QAAABl0RVh0U29mdHdhcmUAQWRvYmUgSW1hZ2VSZWFkeXHJZTwAAAAMUExURf9%2Ff%2F8AAAAAAP%2F%2F%2FyCZFIoAAABwSURBVHjalNJLDsAgCATQGXv%2FOzflX8EmZUWQFxXFdQh8LCyPV6oCBVqugkwhuQmQ0U%2FLRTAFOYqnfxRSH4TWuwBnIXWgCe%2Fehfbnfi4ksHy%2FFHGcSdjYmojLb8Km20QZ7zjdXZQHrOL85n%2B%2Bzy3AAE%2F6BSjaFBabAAAAAElFTkSuQmCC") no-repeat transparent;
    }
</style>
<div class="body">
    <form name="preferences" id="preferences" class="aligned">
        <div class="module" id="root">
            <table border="0" cellpadding="0" cellspacing="0" width="100%">
                <tbody>
                    <tr>
                        <td>
                            <h2>GoogleMonkeyR :: v<span id="version">1.0.0</span></h2>
                        </td>
                        <td align="right">
                            <h2>
                                <a href="http://www.monkeyr.com/" target="_top">MonkeyR.com</a>
                            </h2>
                        </td>
                    </tr>
                </tbody>
            </table>
            <div class="form-row checkbox-row">
                <label for="numcol1">
                    <input name="numcol" value="1" id="numcol1" type="radio">
                    1 column
                </label>
                &nbsp;&nbsp;
                <label for="numcol2">
                    <input name="numcol" value="2" id="numcol2" type="radio">
                    2 columns</label>
                &nbsp;&nbsp;
                <label for="numcol3">
                    <input name="numcol" value="3" id="numcol3" type="radio">
                    3 columns</label>
                &nbsp;&nbsp;
                <label for="numcol4">
                    <input name="numcol" value="4" id="numcol4" type="radio">
                    4 columns</label>
                &nbsp;&nbsp;( of results )&nbsp;&nbsp;&nbsp;<a href="javascript:;"><img id="flowimg" name="flowimg" class="l2r" title=" flow of results " border="0" style="width:24px;	height:25px;	margin-top:-4px;" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAZCAMAAAAc9R5vAAAABGdBTUEAAK%2FINwWK6QAAABl0RVh0U29mdHdhcmUAQWRvYmUgSW1hZ2VSZWFkeXHJZTwAAAAGUExURf%2F%2F%2FwAAAFXC034AAAABdFJOUwBA5thmAAAAEUlEQVR42mJgGAWjgI4AIMAAAnEAAfWgarkAAAAASUVORK5CYII%3D"></a>
            </div>
            <div class="form-row checkbox-row">
                Remove:<br><br>
                <label for="remsearchesrelatedto">
                    <input name="remsearchesrelatedto" id="remsearchesrelatedto" type="checkbox">
                    "Related Searches"</label>
                &nbsp;
                <label for="remsponsor">
                    <input name="remsponsor" id="remsponsor" type="checkbox">
                    "Sponsored Links"</label>
                &nbsp;
                <label for="remrightpanel">
                    <input name="remrightpanel" id="remrightpanel" type="checkbox">
                    "Right Panel"</label>
                &nbsp;
                <label for="noSitePreview">
                    <input name="noSitePreview" id="noSitePreview" type="checkbox">
                    "Site Preview"</label>
            </div>
            <div class="form-row checkbox-row">
                <label for="numresults">
                    <input name="numresults" id="numresults" type="checkbox">
                    Number results ( 1, 2, 3... etc. )</label>
            </div>
            <div class="form-row checkbox-row">
                <label for="autoload">
                    <input name="autoload" id="autoload" type="checkbox">
                    Auto load more results</label>
            </div>
            <div class="form-row checkbox-row">
                <label for="hidesearch">
                    <input name="hidesearch" id="hidesearch" type="checkbox">
                    Don't display the Google web search dialogues ( I use the Google toolbar instead! )</label>
            </div>
            <div class="form-row checkbox-row">
                Select the
                <a href="javascript:;" name="BGBorderlink" id="BGBorderlink" title=" toggle between a background or border hue ">background</a>
                color ( hue ) for your search results&nbsp;&nbsp;&nbsp;
                <a href="javascript:;" id="ResHue" style="border: 1px solid rgb(0, 0, 0); font-family: Verdana; font-size: 10px; text-decoration: none;">&nbsp;&nbsp;&nbsp;&nbsp;</a>
                <input id="ResHuefield" size="7" maxlength="7">
                &nbsp;&nbsp;&nbsp;&nbsp;<a href="http://www.flooble.com/scripts/colorpicker.php" target="_blank" title=" flooble color picker script " style="font-size: 8px;">flooble</a>
            </div>
            <div class="form-row checkbox-row">
                Make my Google links open in a new target &nbsp;
                <label for="extlinksearch">
                    <input name="extlinksearch" id="extlinksearch" type="checkbox">
                    for search results</label>
            </div>
            <div class="form-row checkbox-row">
                <label for="searchlinktracking">
                    <input name="searchlinktracking" id="searchlinktracking" type="checkbox">
                    Disable Google tracking my search results
                </label>
            </div>
            <div class="form-row checkbox-row">
                <label for="showextraresults">
                    <input name="showextraresults" id="showextraresults" type="checkbox">
                    Disable Google showing extra search results like videos, images, etc.
                </label>
            </div>
            <div class="form-row checkbox-row">
                For each result show &nbsp;
                <input name="favicon" id="favicon" type="checkbox">
                <label for="favicon">
                    favicons</label>
                &nbsp;&nbsp;
                <input name="imagepreview" id="imagepreview" type="checkbox">
                <label for="imagepreview">
                    GooglePreview images</label>
                &nbsp; &nbsp;&nbsp;<a href="http://www.googlepreview.com/" target="_blank" title=" GooglePreview " style="font-size: 8px;">GooglePreview</a>
            </div>
        </div>
        <div class="module">
            <table border="0" cellpadding="0" cellspacing="0" width="100%">
                <tbody>
                    <tr height="30">
                        <td align="left" valign="middle">&nbsp;&nbsp;&nbsp;<a href="#" name="check_update" id="check_update">checking for update...</a>
                        </td>
                        <td align="center" valign="middle" width="72"><input value="Close" name="close_button" id="close_button" class="btn" type="button"></td>
                        <td align="center" valign="middle" width="165"><input value="Save Preferences" name="save_button" id="save_button" class="btn" type="button"></td>
                    </tr>
                </tbody>
            </table>
        </div>
    </form>
</div>",
HISTORY_HTML: "data:text/html;charset=utf-8;base64,PCFET0NUWVBFIGh0bWwgUFVCTElDICItLy9XM0MvL0RURCBIVE1MIDQuMDEvL0VO" +
"IiAiaHR0cDovL3d3dy53My5vcmcvVFIvaHRtbDQvc3RyaWN0LmR0ZCI%2BDQo8aHRtbD48aGVhZD4NCjxtZXRhIGh0dHAtZXF1aX" +
"Y9IkNvbnRlbnQtVHlwZSIgY29udGVudD0idGV4dC9odG1sOyBjaGFyc2V0PVVURi04Ij4NCjxtZXRhIG5hbWU9IkF1dGhvciIgY2" +
"9udGVudD0ibXVuZ3VzaHVtZSI%2BDQo8bWV0YSBuYW1lPSJDb3B5cmlnaHQiIGNvbnRlbnQ9IsKpIDIwMDcsIE1vbmtleVIuY29t" +
"Ij4NCjxtZXRhIG5hbWU9Ik9yaWdpbmFsQXV0aG9yIiBjb250ZW50PSJKb25hdGhhbiBCdWNoYW5hbiI%2BDQo8bWV0YSBuYW1lPS" +
"JPcmlnaW5hbENvcHlyaWdodCIgY29udGVudD0iwqkgMjAwNiwgSm9uYXRoYW4gQnVjaGFuYW4iPg0KPHN0eWxlIHR5cGU9InRleH" +
"QvY3NzIj4NCmJvZHkgeyBtYXJnaW46MDsgcGFkZGluZzowOyBmb250LXNpemU6MTJweDsgZm9udC1mYW1pbHk6Ikx1Y2lkYSBHcm" +
"FuZGUiLCJCaXRzdHJlYW0gVmVyYSBTYW5zIixWZXJkYW5hLEFyaWFsLHNhbnMtc2VyaWY7IGNvbG9yOiMzMzM7IHdpZHRoOiA2OD" +
"ZweDsgbWFyZ2luOiAwIGF1dG87IH0NCi5tb2R1bGUgeyBib3JkZXI6IDFweCBzb2xpZCAjY2NjOyBtYXJnaW4tYm90dG9tOiA1cH" +
"g7IGJhY2tncm91bmQtY29sb3I6ICNmZmY7IH0NCi5tb2R1bGUgaDIsIC5tb2R1bGUgY2FwdGlvbiB7IG1hcmdpbjogMDsgcGFkZG" +
"luZzogMnB4IDVweCAzcHggNXB4OyBmb250LXNpemU6IDExcHg7IGZvbnQtd2VpZ2h0OiBib2xkOyBiYWNrZ3JvdW5kOiAjQ0NDQ0" +
"NDIHVybCgiZGF0YTppbWFnZS9naWY7YmFzZTY0LFIwbEdPRGxoQVFBV0FNUUFBTWpLeXNYSHg5JTJGaDRjJTJGUjBlUGw1Y2JJeU" +
"5QVjFjM1B6JTJCZnA2ZDdoNGU3dzhPdnQ3Y3ZOemRmWjJlSGo0OXZkM2ZEeThnQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQU" +
"FBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFDSDVCQUFBQUFBQUxBQUFBQUFCQUJZQUFBVVNJQ1FxQzBJSVQzTUVCY0FNUn" +
"ZNa2poTUNBRHMlM0QiKSB0b3AgbGVmdCByZXBlYXQteDsgY29sb3I6ICM2NjY2NjY7IGJvcmRlci1ib3R0b206IDA7IH0NCi5mb3" +
"JtLXJvdyB7IG92ZXJmbG93OiBoaWRkZW47IHBhZGRpbmc6IDhweCA4cHg7IGZvbnQtc2l6ZTogMTFweDsgYm9yZGVyLWJvdHRvbT" +
"ogMXB4IHNvbGlkICNlZWU7IGJvcmRlci1yaWdodDogMXB4IHNvbGlkICNlZWU7IH0NCi5mb3JtLXJvdyBpbWcsIC5mb3JtLXJvdy" +
"BpbnB1dCB7IHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7IH0NCmlucHV0LmJ0biB7CXBhZGRpbmc6IDBweCAxMHB4IDBweCAxMHB4Oy" +
"Bjb2xvcjogIzk5OTk5OTsgYmFja2dyb3VuZC1jb2xvcjogV2hpdGU7IGZvbnQtd2VpZ2h0OiBib2xkOyBib3JkZXI6IHNvbGlkID" +
"FweCAjQ0NDQ0NDOyB0ZXh0LWFsaWduOiBjZW50ZXI7IH0NCmlucHV0LmJ0bjpob3ZlciB7CXBhZGRpbmc6IDFweCAxMXB4IDFweC" +
"AxMXB4OyBjb2xvcjogIzMzMzMzMzsgYm9yZGVyLWNvbG9yOiAjNjY2NjY2OyB9DQphIHsgZm9udC13ZWlnaHQ6IGJvbGQ7IGNvbG" +
"9yOiAjOTk5OTk5OyB0ZXh0LWRlY29yYXRpb246IG5vbmU7IGN1cnNvcjogcG9pbnRlcjsgfQ0KYTpob3ZlciB7CWZvbnQtd2VpZ2" +
"h0OiBib2xkOyBjb2xvcjogIzMzMzMzMzsgdGV4dC1kZWNvcmF0aW9uOiBub25lOyB9DQo8L3N0eWxlPg0KPC9oZWFkPjxib2R5IG" +
"9uTG9hZD0iIj4NCjxmb3JtIG5hbWU9Imhpc3RvcnkiIGlkPSJoaXN0b3J5IiBjbGFzcz0iYWxpZ25lZCI%2BDQogIDxkaXYgY2xh" +
"c3M9Im1vZHVsZSIgaWQ9InJvb3QiPg0KDQogICAgPHRhYmxlIGJvcmRlcj0iMCIgY2VsbHBhZGRpbmc9IjAiIGNlbGxzcGFjaW5n" +
"PSIwIiB3aWR0aD0iMTAwJSI%2BDQogICAgICA8dGJvZHk%2BPHRyPg0KICAgICAgICA8dGQ%2BPGgyPjxzcGFuIGlkPSJzY3JpcH" +
"ROYW1lIj5zY3JpcHROYW1lPC9zcGFuPiA6OiB2PHNwYW4gaWQ9InZlcnNpb24iPjEuMC4wPC9zcGFuPiA6OiBoaXN0b3J5PC9oMj" +
"48L3RkPg0KICAgICAgICA8dGQgYWxpZ249InJpZ2h0Ij48aDI%2BPGEgaHJlZj0iaHR0cDovL3d3dy5tb25rZXlyLmNvbS8iIHRh" +
"cmdldD0iX3RvcCI%2BTW9ua2V5Ui5jb208L2E%2BPC9oMj48L3RkPg0KICAgICAgPC90cj4NCiAgICA8L3Rib2R5PjwvdGFibGU%" +
"2BDQogICAgPGRpdiBjbGFzcz0iZm9ybS1yb3ciPg0KICAgICAgPGRpdiBhbGlnbj0iY2VudGVyIj4NCiAgICAgICAgPHRleHRhcm" +
"VhIGlkPSJoaXN0b3J5X3RleHQiIG5hbWU9Imhpc3RvcnlfdGV4dCIgY29scz0iODAiIHJvd3M9IjE1Ij4mbmJzcDs8L3RleHRhcm" +
"VhPg0KICAgICAgICA8L2Rpdj4NCiAgICA8L2Rpdj4NCiAgPC9kaXY%2BDQogIDxkaXYgY2xhc3M9Im1vZHVsZSI%2BDQogICAgPH" +
"RhYmxlIGJvcmRlcj0iMCIgY2VsbHBhZGRpbmc9IjAiIGNlbGxzcGFjaW5nPSIwIiB3aWR0aD0iMTAwJSI%2BDQogICAgICA8dGJv" +
"ZHk%2BPHRyIGhlaWdodD0iMzAiPg0KICAgICAgICA8dGQgd2lkdGg9IjUxNCIgYWxpZ249ImxlZnQiIHZhbGlnbj0ibWlkZGxlIj" +
"4mbmJzcDs8L3RkPg0KICAgICAgICA8dGQgYWxpZ249ImNlbnRlciIgdmFsaWduPSJtaWRkbGUiIHdpZHRoPSI4NSI%2BPGlucHV0" +
"IHZhbHVlPSJJbnN0YWxsIiBuYW1lPSJpbnN0YWxsX2J1dHRvbiIgaWQ9Imluc3RhbGxfYnV0dG9uIiBjbGFzcz0iYnRuIiB0eXBl" +
"PSJidXR0b24iPg0KICAgICAgICA8L3RkPg0KICAgICAgICA8dGQgYWxpZ249ImNlbnRlciIgdmFsaWduPSJtaWRkbGUiIHdpZHRo" +
"PSI4NSI%2BPGlucHV0IHZhbHVlPSJDbG9zZSIgbmFtZT0iY2xvc2VfYnV0dG9uIiBpZD0iY2xvc2VfYnV0dG9uIiBjbGFzcz0iYn" +
"RuIiB0eXBlPSJidXR0b24iPg0KICAgICAgICA8L3RkPg0KICAgICAgPC90cj4NCiAgICA8L3Rib2R5PjwvdGFibGU%2BDQogIDwv" +
"ZGl2Pg0KPC9mb3JtPg0KPC9ib2R5PjwvaHRtbD4%3D",
REFRESH_HTML: "data:text/html;base64,PCFET0NUWVBFIGh0bWwgUFVCTElDICItLy9XM0MvL0RURCBIVE1MIDQuMDEvL0VOIiAiaHR0cDovL3" +
"d3dy53My5vcmcvVFIvaHRtbDQvc3RyaWN0LmR0ZCI%2BDQo8aHRtbD48aGVhZD48dGl0bGU%2BR29vZ2xlTW9ua2V5UiBVcGRhdG" +
"U8L3RpdGxlPg0KPG1ldGEgaHR0cC1lcXVpdj0iQ29udGVudC1UeXBlIiBjb250ZW50PSJ0ZXh0L2h0bWw7IGNoYXJzZXQ9VVRGLT" +
"giPg0KPG1ldGEgbmFtZT0iQXV0aG9yIiBjb250ZW50PSJtdW5ndXNodW1lIj4NCjxtZXRhIG5hbWU9IkNvcHlyaWdodCIgY29udG" +
"VudD0iwqkgMjAwNywgTW9ua2V5Ui5jb20iPg0KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4NCmJvZHkgeyBtYXJnaW46MDsgcGFkZG" +
"luZzowOyBmb250LXNpemU6MTJweDsgZm9udC1mYW1pbHk6Ikx1Y2lkYSBHcmFuZGUiLCJCaXRzdHJlYW0gVmVyYSBTYW5zIixWZX" +
"JkYW5hLEFyaWFsLHNhbnMtc2VyaWY7IGNvbG9yOiMzMzM7IHdpZHRoOiAzMDBweDsgbWFyZ2luOiAwIGF1dG87IH0NCi5tb2R1bG" +
"UgeyBib3JkZXI6IDFweCBzb2xpZCAjY2NjOyBtYXJnaW4tYm90dG9tOiA1cHg7IGJhY2tncm91bmQtY29sb3I6ICNmZmY7IH0NCi" +
"5tb2R1bGUgaDIgeyBtYXJnaW46IDA7IHBhZGRpbmc6IDJweCA1cHggM3B4IDVweDsgZm9udC1zaXplOiAxMXB4OyBmb250LXdlaW" +
"dodDogYm9sZDsgYmFja2dyb3VuZDogI0NDQ0NDQyB1cmwoImRhdGE6aW1hZ2UvZ2lmO2Jhc2U2NCxSMGxHT0RsaEFRQVdBTVFBQU" +
"1qS3lzWEh4OSUyRmg0YyUyRlIwZVBsNWNiSXlOUFYxYzNQeiUyQmZwNmQ3aDRlN3c4T3Z0N2N2TnpkZloyZUhqNDl2ZDNmRHk4Z0" +
"FBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQUFBQ0g1QkFBQUFBQUFMQUFBQU" +
"FBQkFCWUFBQVVTSUNRcUMwSUlUM01FQmNBTVJ2TWtqaE1DQURzJTNEIikgdG9wIGxlZnQgcmVwZWF0LXg7IGNvbG9yOiAjNjY2Nj" +
"Y2OyBib3JkZXItYm90dG9tOiAwOyB9DQouZm9ybS1yb3cgeyBvdmVyZmxvdzogaGlkZGVuOyBwYWRkaW5nOiAxMnB4IDEycHg7IG" +
"ZvbnQtc2l6ZTogMTFweDsgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICNlZWU7IGJvcmRlci1yaWdodDogMXB4IHNvbGlkICNlZW" +
"U7IHZlcnRpY2FsLWFsaWduOm1pZGRsZTsgdGV4dC1hbGlnbjpjZW50ZXI7IH0NCmlucHV0LmJ0biB7CXBhZGRpbmc6IDBweCAxMH" +
"B4IDBweCAxMHB4OyBjb2xvcjogIzk5OTk5OTsgYmFja2dyb3VuZC1jb2xvcjogV2hpdGU7IGZvbnQtd2VpZ2h0OiBib2xkOyBib3" +
"JkZXI6IHNvbGlkIDFweCAjQ0NDQ0NDOyB0ZXh0LWFsaWduOiBjZW50ZXI7IH0NCmlucHV0LmJ0bjpob3ZlciB7CXBhZGRpbmc6ID" +
"FweCAxMXB4IDFweCAxMXB4OyBjb2xvcjogIzMzMzMzMzsgYm9yZGVyLWNvbG9yOiAjNjY2NjY2OyB9DQphIHsgZm9udC13ZWlnaH" +
"Q6IGJvbGQ7IGNvbG9yOiAjOTk5OTk5OyB0ZXh0LWRlY29yYXRpb246IG5vbmU7IGN1cnNvcjogcG9pbnRlcjsgfQ0KYTpob3Zlci" +
"B7CWZvbnQtd2VpZ2h0OiBib2xkOyBjb2xvcjogIzMzMzMzMzsgdGV4dC1kZWNvcmF0aW9uOiBub25lOyB9DQo8L3N0eWxlPjwvaG" +
"VhZD48Ym9keSBvbkxvYWQ9IiI%2BDQo8Zm9ybSBuYW1lPSJ1cGRhdGUiIGlkPSJ1cGRhdGUiIGNsYXNzPSJhbGlnbmVkIj4NCiAg" +
"PGRpdiBjbGFzcz0ibW9kdWxlIj4NCiAgICA8dGFibGUgYm9yZGVyPSIwIiBjZWxscGFkZGluZz0iMCIgY2VsbHNwYWNpbmc9IjAi" +
"IHdpZHRoPSIxMDAlIj4NCg0KICAgICAgPHRib2R5Pjx0cj4NCiAgICAgICAgPHRkPjxoMj48c3BhbiBpZD0ic2NyaXB0TmFtZSI%" +
"2Bc2NyaXB0TmFtZTwvc3Bhbj48L2gyPjwvdGQ%2BDQogICAgICAgIDx0ZCBhbGlnbj0icmlnaHQiPjxoMj48YSBocmVmPSJodHRw" +
"Oi8vd3d3Lm1vbmtleXIuY29tLyIgdGFyZ2V0PSJfdG9wIj5Nb25rZXlSLmNvbTwvYT48L2gyPjwvdGQ%2BDQogICAgICA8L3RyPg" +
"0KICAgIDwvdGJvZHk%2BPC90YWJsZT4NCiAgICA8ZGl2IGNsYXNzPSJmb3JtLXJvdyI%2BDQoJPHRhYmxlIGJvcmRlcj0iMCIgY2" +
"VsbHBhZGRpbmc9IjAiIGNlbGxzcGFjaW5nPSIwIiB3aWR0aD0iMTAwJSI%2BDQoJPHRib2R5Pjx0cj48dGQgYWxpZ249ImNlbnRl" +
"ciIgaGVpZ2h0PSI0MCIgdmFsaWduPSJtaWRkbGUiPlJlZnJlc2ggeW91ciBicm93c2VyIHRvIGNvbnRpbnVlLjwvdGQ%2BPC90cj" +
"4NCg0KCTx0cj48dGQgYWxpZ249ImNlbnRlciIgaGVpZ2h0PSI0MCIgdmFsaWduPSJtaWRkbGUiPjxpbnB1dCBuYW1lPSJidXR0b2" +
"4iIGNsYXNzPSJidG4iIG9uQ2xpY2s9ImphdmFzY3JpcHQ6dG9wLmxvY2F0aW9uLnJlbG9hZCh0cnVlKTsiIHZhbHVlPSJSZWZyZX" +
"NoIiB0eXBlPSJidXR0b24iPjwvdGQ%2BPC90cj4NCgk8L3Rib2R5PjwvdGFibGU%2BPC9kaXY%2BDQogIDwvZGl2Pg0KPC9mb3Jt" +
"Pg0KPC9ib2R5PjwvaHRtbD4%3D",
TOP_PNG: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACgAAAAoCAYAAACM%2FrhtAAAACXBIWXMAAAsTAAALEwEAmpwYAAAK" +
"T2lDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjanVNnVFPpFj333vRCS4iAlEtvUhUIIFJCi4AUkSYqIQkQSoghodkVUcERRUUE" +
"G8igiAOOjoCMFVEsDIoK2AfkIaKOg6OIisr74Xuja9a89%2BbN%2FrXXPues852zzwfACAyWSDNRNYAMqUIeEeCDx8TG4eQuQIEK" +
"JHAAEAizZCFz%2FSMBAPh%2BPDwrIsAHvgABeNMLCADATZvAMByH%2Fw%2FqQplcAYCEAcB0kThLCIAUAEB6jkKmAEBGAYCdmCZT" +
"AKAEAGDLY2LjAFAtAGAnf%2BbTAICd%2BJl7AQBblCEVAaCRACATZYhEAGg7AKzPVopFAFgwABRmS8Q5ANgtADBJV2ZIALC3AMDO" +
"EAuyAAgMADBRiIUpAAR7AGDIIyN4AISZABRG8lc88SuuEOcqAAB4mbI8uSQ5RYFbCC1xB1dXLh4ozkkXKxQ2YQJhmkAuwnmZGTKB" +
"NA%2Fg88wAAKCRFRHgg%2FP9eM4Ors7ONo62Dl8t6r8G%2FyJiYuP%2B5c%2BrcEAAAOF0ftH%2BLC%2BzGoA7BoBt%2FqIl7gRo" +
"XgugdfeLZrIPQLUAoOnaV%2FNw%2BH48PEWhkLnZ2eXk5NhKxEJbYcpXff5nwl%2FAV%2F1s%2BX48%2FPf14L7iJIEyXYFHBPjg" +
"wsz0TKUcz5IJhGLc5o9H%2FLcL%2F%2Fwd0yLESWK5WCoU41EScY5EmozzMqUiiUKSKcUl0v9k4t8s%2BwM%2B3zUAsGo%2BAXuR" +
"LahdYwP2SycQWHTA4vcAAPK7b8HUKAgDgGiD4c93%2F%2B8%2F%2FUegJQCAZkmScQAAXkQkLlTKsz%2FHCAAARKCBKrBBG%2FTB" +
"GCzABhzBBdzBC%2FxgNoRCJMTCQhBCCmSAHHJgKayCQiiGzbAdKmAv1EAdNMBRaIaTcA4uwlW4Dj1wD%2FphCJ7BKLyBCQRByAgT" +
"YSHaiAFiilgjjggXmYX4IcFIBBKLJCDJiBRRIkuRNUgxUopUIFVIHfI9cgI5h1xGupE7yAAygvyGvEcxlIGyUT3UDLVDuag3GoRG" +
"ogvQZHQxmo8WoJvQcrQaPYw2oefQq2gP2o8%2BQ8cwwOgYBzPEbDAuxsNCsTgsCZNjy7EirAyrxhqwVqwDu4n1Y8%2BxdwQSgUXA" +
"CTYEd0IgYR5BSFhMWE7YSKggHCQ0EdoJNwkDhFHCJyKTqEu0JroR%2BcQYYjIxh1hILCPWEo8TLxB7iEPENyQSiUMyJ7mQAkmxpF" +
"TSEtJG0m5SI%2BksqZs0SBojk8naZGuyBzmULCAryIXkneTD5DPkG%2BQh8lsKnWJAcaT4U%2BIoUspqShnlEOU05QZlmDJBVaOa" +
"Ut2ooVQRNY9aQq2htlKvUYeoEzR1mjnNgxZJS6WtopXTGmgXaPdpr%2Bh0uhHdlR5Ol9BX0svpR%2BiX6AP0dwwNhhWDx4hnKBmb" +
"GAcYZxl3GK%2BYTKYZ04sZx1QwNzHrmOeZD5lvVVgqtip8FZHKCpVKlSaVGyovVKmqpqreqgtV81XLVI%2BpXlN9rkZVM1PjqQnU" +
"lqtVqp1Q61MbU2epO6iHqmeob1Q%2FpH5Z%2FYkGWcNMw09DpFGgsV%2FjvMYgC2MZs3gsIWsNq4Z1gTXEJrHN2Xx2KruY%2FR27" +
"iz2qqaE5QzNKM1ezUvOUZj8H45hx%2BJx0TgnnKKeX836K3hTvKeIpG6Y0TLkxZVxrqpaXllirSKtRq0frvTau7aedpr1Fu1n7gQ" +
"5Bx0onXCdHZ4%2FOBZ3nU9lT3acKpxZNPTr1ri6qa6UbobtEd79up%2B6Ynr5egJ5Mb6feeb3n%2Bhx9L%2F1U%2FW36p%2FVHDF" +
"gGswwkBtsMzhg8xTVxbzwdL8fb8VFDXcNAQ6VhlWGX4YSRudE8o9VGjUYPjGnGXOMk423GbcajJgYmISZLTepN7ppSTbmmKaY7TD" +
"tMx83MzaLN1pk1mz0x1zLnm%2Beb15vft2BaeFostqi2uGVJsuRaplnutrxuhVo5WaVYVVpds0atna0l1rutu6cRp7lOk06rntZn" +
"w7Dxtsm2qbcZsOXYBtuutm22fWFnYhdnt8Wuw%2B6TvZN9un2N%2FT0HDYfZDqsdWh1%2Bc7RyFDpWOt6azpzuP33F9JbpL2dYzx" +
"DP2DPjthPLKcRpnVOb00dnF2e5c4PziIuJS4LLLpc%2BLpsbxt3IveRKdPVxXeF60vWdm7Obwu2o26%2FuNu5p7ofcn8w0nymeWT" +
"Nz0MPIQ%2BBR5dE%2FC5%2BVMGvfrH5PQ0%2BBZ7XnIy9jL5FXrdewt6V3qvdh7xc%2B9j5yn%2BM%2B4zw33jLeWV%2FMN8C3yL" +
"fLT8Nvnl%2BF30N%2FI%2F9k%2F3r%2F0QCngCUBZwOJgUGBWwL7%2BHp8Ib%2BOPzrbZfay2e1BjKC5QRVBj4KtguXBrSFoyOyQ" +
"rSH355jOkc5pDoVQfujW0Adh5mGLw34MJ4WHhVeGP45wiFga0TGXNXfR3ENz30T6RJZE3ptnMU85ry1KNSo%2Bqi5qPNo3ujS6P8" +
"YuZlnM1VidWElsSxw5LiquNm5svt%2F87fOH4p3iC%2BN7F5gvyF1weaHOwvSFpxapLhIsOpZATIhOOJTwQRAqqBaMJfITdyWOCn" +
"nCHcJnIi%2FRNtGI2ENcKh5O8kgqTXqS7JG8NXkkxTOlLOW5hCepkLxMDUzdmzqeFpp2IG0yPTq9MYOSkZBxQqohTZO2Z%2Bpn5m" +
"Z2y6xlhbL%2BxW6Lty8elQfJa7OQrAVZLQq2QqboVFoo1yoHsmdlV2a%2FzYnKOZarnivN7cyzytuQN5zvn%2F%2FtEsIS4ZK2pY" +
"ZLVy0dWOa9rGo5sjxxedsK4xUFK4ZWBqw8uIq2Km3VT6vtV5eufr0mek1rgV7ByoLBtQFr6wtVCuWFfevc1%2B1dT1gvWd%2B1Yf" +
"qGnRs%2BFYmKrhTbF5cVf9go3HjlG4dvyr%2BZ3JS0qavEuWTPZtJm6ebeLZ5bDpaql%2BaXDm4N2dq0Dd9WtO319kXbL5fNKNu7" +
"g7ZDuaO%2FPLi8ZafJzs07P1SkVPRU%2BlQ27tLdtWHX%2BG7R7ht7vPY07NXbW7z3%2FT7JvttVAVVN1WbVZftJ%2B7P3P66Jqu" +
"n4lvttXa1ObXHtxwPSA%2F0HIw6217nU1R3SPVRSj9Yr60cOxx%2B%2B%2Fp3vdy0NNg1VjZzG4iNwRHnk6fcJ3%2FceDTradox7" +
"rOEH0x92HWcdL2pCmvKaRptTmvtbYlu6T8w%2B0dbq3nr8R9sfD5w0PFl5SvNUyWna6YLTk2fyz4ydlZ19fi753GDborZ752PO32" +
"oPb%2B%2B6EHTh0kX%2Fi%2Bc7vDvOXPK4dPKy2%2BUTV7hXmq86X23qdOo8%2FpPTT8e7nLuarrlca7nuer21e2b36RueN87d9L" +
"158Rb%2F1tWeOT3dvfN6b%2FfF9%2FXfFt1%2Bcif9zsu72Xcn7q28T7xf9EDtQdlD3YfVP1v%2B3Njv3H9qwHeg89HcR%2FcGhY" +
"PP%2FpH1jw9DBY%2BZj8uGDYbrnjg%2BOTniP3L96fynQ89kzyaeF%2F6i%2FsuuFxYvfvjV69fO0ZjRoZfyl5O%2FbXyl%2FerA" +
"6xmv28bCxh6%2ByXgzMV70VvvtwXfcdx3vo98PT%2BR8IH8o%2F2j5sfVT0Kf7kxmTk%2F8EA5jz%2FGMzLdsAAAAgY0hSTQAAei" +
"UAAICDAAD5%2FwAAgOkAAHUwAADqYAAAOpgAABdvkl%2FFRgAAAcRJREFUeNrs2b1OFFEUwPEfMIWJGAsQAlqL8A4UiFQYsbS2tB" +
"MJIbBBxIgxxvgOWixEG03o1HexsrKwhGyCzTHZbGbG3WWWvdE51eR83X%2Fux5lzZ0Zur9z9jqs4k5aM4FeGCVyWpmSjaElXWqMS" +
"lxrwnwfMKsx1iE%2FxvIYHKQG%2BxXoH7A88TmGJ33TA%2FZH1sA0V8DU2Suwb4TMUwFfY7MJvM3wvFPAltnrw34qYCwF8ge0%2B" +
"4rYjdqCAz9E4x7ZoRI6BAD7DbgWnfjdyVQr4FHsFtisYz9GPhy1P9iJnJYAN7BfYJvEOczm2ubBNFsTud7NdygDPsFOysSfQxH2c" +
"5NhPwtYM36IDt1PWzZcBvsdBycw1cQenJTlOw6dZMpMHMVbPgB8K9NfiXbvSNtNlqyB8DyO2l7FKAWdzdFM4wnIfp3c5Yqe6HOuv" +
"gE86Nv8CPmLpHCVmKXIstOluxVg9t1s38QWfcQmrmK6gDi7iG47jwraK6%2F32gzfwaACN8jQe1neSGvB%2FAmx1qRsKYFZQaGer" +
"uDVWATgW7dNMm24mdGOp3IsX8TWKOtzDfGpfFuargqrLTA2YGmCWMF%2BW4WdU%2FSR%2FQ%2FweACo1SBSU%2Bf00AAAAAElFTk" +
"SuQmCC",
LOADING_GIF: "data:image/gif;base64,R0lGODlhIgAiAPQAADk5OVJSUlpaWmtra3t7e4SEhIyMjJSUlJycnKWlpa2trbW1tb29vcbGxs7Ozt" +
"bW1t7e3ufn5%2B%2Fv7%2Ff39%2F%2F%2F%2FwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAgFAAAAIf8LTkVU" +
"U0NBUEUyLjADAQAAACwAAAAAIgAiAAAFhiAljmRJLYmprqx4AG1cBgb5yjjVCDacxxKBYnT7lQoI0mBA9BlHEOToIYC4nE9RNCUa" +
"1CjFLLTAdQQmYKyYshUJkodAVhFBQwkpB2OtSygYEVMFVnwjDSh0hSwSDX6EiioOj5CUJRIPEJiamJATERESn6CflaWmp6ipqqus" +
"ra6vsLGys6ohACH5BAgFAAAALAAAAAAiACIAhCEhISkpKVpaWmNjY2tra3Nzc4SEhIyMjJSUlKWlpa2trbW1tb29vcbGxs7OztbW" +
"1t7e3ufn5%2B%2Fv7%2Ff39%2F%2F%2F%2FwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAWTICWOZElJiqmuZkMqAi" +
"urUPHG4wNEM2ukIsWAJAj0SBPSwzASjiQA15HyUCRFEoPUKSIApqNF4kpBALkUwAIctoqWSW4BQGYv3BTDmhs4sEsKQAx%2BCjYJ" +
"ABBTDg91EwprKCQJBGwQixIjjg5%2FLBAPDhF1nCwRDw%2BJoz0SmKmtrq%2BwsbKztLW2t7i5uru8vb6%2FwL4hACH5BAgFAAAA" +
"LAAAAAAiACIAhCEhISkpKTk5OUJCQkpKSlJSUlpaWmNjY3Nzc4SEhIyMjJSUlJycnK2trbW1tb29vcbGxs7OztbW1t7e3ufn5%2B" +
"%2Fv7%2Ff39%2F%2F%2F%2FwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAWT4CWOZCk6ZqqaFAkha5xSjJuQiiHHTTRCt1FBsltNGj" +
"%2BYaKEriiQTUoXRugBHB%2BSoEpBFoiMHRPQSPQqVEQUg2H3VNWswobxMAIOiBTrqXR43FQU%2BdnhOFxZvFxFIEAsXDE0SAASH" +
"IntRFYRmPpMFliOJVSkAn6BOQaeqq6ytrq%2BwsbKztLW2t7i5uru8vb6%2FwIchACH5BAgFAAAALAAAAAAiACIAhCEhIUJCQlJS" +
"UlpaWnNzc4SEhIyMjJSUlJycnKWlpa2trbW1tb29vcbGxs7OztbW1t7e3ufn5%2B%2Fv7%2Ff39%2F%2F%2F%2FwAAAAAAAAAAAA" +
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAWVICWOZCk2Zqqu4qOwcDk55JOQShGvTzS6JMNrl3o8frdWwUc0TR6T1pCCMJAag2YL0k" +
"pKCtyTYEqUHClASm6kGBy0I4fPJiqcGQOyFnKEvBYFUW0IcCQTTCIONHiEJBIMhSUSAo0iDAEAABKRJEwSCpkBBJwmDgKZBIikJA" +
"UBOquwsbKztLW2t7i5uru8vb6%2FwMHCsCEAIfkECAUAAAAsAAAAACIAIgCEISEhKSkpQkJCWlpaY2Nja2tre3t7hISEjIyMlJSU" +
"nJycra2ttbW1vb29xsbGzs7O1tbW3t7e5%2Bfn7%2B%2Fv9%2Ff3%2F%2F%2F%2FAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA" +
"AAAABYlgJY5kKU5mqq7nw76vBJGRAt%2FV5I4Ng8OyEWUh%2Bb0mM5FjQaIcjKWgSFE8GRJQkk70YJ4O2OxISrXaxKNJpNKlVCSH" +
"M7oUcbzjpQdhPsKfHAMDT3wVDVwGgQluhCIQBAMFcowiDAlrk5g4CZucnIt8AgEAogClAAiZqaqrrK2ur7CxsrO0tbavIQAh%2BQ" +
"QIBQAAACwAAAAAIgAiAIQhISEpKSlKSkpra2t7e3uEhISMjIyUlJScnJylpaWtra21tbW9vb3GxsbOzs7W1tbe3t7n5%2Bfv7%2B" +
"%2F39%2Ff%2F%2F%2F8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFjCAljmRpnmiqriwbPW1cOpJsS7AtQxA5KbqU" +
"YzL6LYInSI4iURyRpkeN6YSaIg6RJMGwmiTEZte3tHJJkAOh4BVlmY8CIVH2QhCFArBdYiQafIE6BwaFBgSIBGNehAYIj48Lb4KU" +
"IgkElSQKAAADPZkUCgEAAgagFAwCnAOnEQsARKeys7S1tre4uYEhACH5BAgFAAAALAAAAAAiACIAhCEhIUJCQkpKSlJSUlpaWmNj" +
"Y2tra4yMjJSUlJycnK2trbW1tb29vcbGxs7OztbW1t7e3ufn5%2B%2Fv7%2Ff39%2F%2F%2F%2FwAAAAAAAAAAAAAAAAAAAAAAAA" +
"AAAAAAAAAAAAAAAAAAAAWEICWOZGmeaKqubOu%2BcCzP6EOvk2Pf6PRAvN4vePIBiSVjMkIcjiILRYIoEU0gUsaRGGEkFI4JcvRg" +
"7MboVYOxbrjd1WDiQK%2FTGen8ArFNPwoDBVNoYhQPCQQDCExBCgANIzmJBkQEAA4lEINBlph5IgMAZ3mhfWkCAKZoAQCfrq%2Bw" +
"sS8hACH5BAgFAAAALAAAAAAiACIAhCEhIUJCQkpKSlJSUlpaWnNzc4SEhIyMjJSUlJycnKWlpa2trbW1tb29vcbGxs7OztbW1t7e" +
"3ufn5%2B%2Fv7%2Ff39%2F%2F%2F%2FwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAWCYCWOZGmeaKqubOu%2BcCzPdG3f" +
"eK7T1D5SkcfDN4E8IhId0Jj0SZC%2BaCoCqVqrucVCse0qHNLdgxGuPAwFxoQoghgMCUhOMmiMIgjDYVEzgBMDfCMTDQY1AQMiCQ" +
"R2OggAaxWLgjkAlAuBOgUAJIAIcwCNIgsEOgIBZZuRUqFlPWUsIQAh%2BQQIBQAAACwAAAAAIgAiAIQxMTFSUlJaWlpjY2Nzc3OE" +
"hISMjIyUlJScnJylpaWtra21tbW9vb3GxsbOzs7W1tbe3t7n5%2Bfv7%2B%2F39%2Ff%2F%2F%2F8AAAAAAAAAAAAAAAAAAAAAAA" +
"AAAAAAAAAAAAAAAAAAAAAFgSAljmRpnmiqrmzrvnAsz3Rt33iu73zv%2F8DgSRIhGosTHOTBbDIjwhvEAYQkFI2kD6JIMCA5BwEq" +
"iiwU2BqDmiiARxKrLHCgHAQiRIFsA9QlAVQUenw0fiIFBCN6En11FA4BfAgEWjOHIgMIJHo1mHYCljefFIE6pAZ4OaQ8B28uIQAh" +
"%2BQQIBQAAACwAAAAAIgAiAIQhISEpKSlCQkJSUlJaWlpjY2Nra2tzc3N7e3uEhISMjIyUlJScnJylpaWtra21tbW9vb3GxsbW1t" +
"be3t7n5%2Bfv7%2B%2F39%2Ff%2F%2F%2F8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFkOAljmRpnmiqrmzrvnAsz3Rt33iu73zv" +
"%2F8CgcEgcVShAS0QyqfwskigSR2k4RRaKJDJtRRqkyOQCcXSxkhfgcHEg2gpR%2BSqDAJAOw2WSmEKsMwIDInkiCg4jfxYxEwAP" +
"hAUiDwmLkg6VLgwBIw6RIglpIw9gamyQnAk1diSdIxYJYzMBnoQEJAsLOg62T4gvIQAh%2BQQIBQAAACwAAAAAIgAiAIQhISFaWl" +
"pjY2Nzc3N7e3uEhISMjIycnJylpaWtra21tbW9vb3GxsbOzs7W1tbe3t7n5%2Bfv7%2B%2F39%2Ff%2F%2F%2F8AAAAAAAAAAAAA" +
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFkeAkjmRpnmiqrmzrvnAsz3Rt33iu73zv%2F8CgcEgs2hpAAiCCkjQkM6Vi4kiQHJ" +
"DJw8GEDQDWycAwSSwmjKm20W19DyJIAHmYPhLdbVv1Hi0CIgdnZQ4jD2wrXwgkAXATCGoNYSJ6KgCOIg0BUBOCIwhZhkgvAgWfkw" +
"yTMhEBg2WuEqA0miQIqgqjOAquPQy5LSEAIfkECAUAAAAsAAAAACIAIgCEISEhMTExOTk5SkpKWlpaY2Nja2trc3Nze3t7hISEjI" +
"yMnJycra2ttbW1vb29xsbGzs7O1tbW3t7e5%2Bfn7%2B%2Fv9%2Ff3%2F%2F%2F%2FAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA" +
"AABY%2BgJY5kaZ5oqq5s675wLM90bd94ru987%2F%2FAoHCIexgWPUQAIHjoJgYAoAARVXADaeMqigwit2ZJQkhYJNURhTuTDMyW" +
"RMPiAEvAs0m5m7gywBURbC8TAwgjC0gWDXgREzEUBAdqCXh%2FIhNpL5IkEHCLeBYRFDYJDCOXInc1EocjjJ2DMAqnqKFntzapPo" +
"IwIQAh%2BQQIBQAAACwAAAAAIgAiAIQ5OTlSUlJaWlpra2t7e3uEhISMjIyUlJScnJylpaWtra29vb3GxsbOzs7W1tbe3t7n5%2B" +
"fv7%2B%2F39%2Ff%2F%2F%2F8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFguAkjmRpnmiqrmzrvnAsz3Rt33" +
"iu73zv%2F0DYAUAsEgO4xWHJZAaDEsSi9zAEBI7dYRAYNEQPnEEgIGRFiYLkJmhESOnsI6xLEOiK7%2BNtQxToDwkiDhB9fyMKDG" +
"CFNH50ExAKfA58M4cjCwojlDoSeZuMOBCCIw%2BhN4kknD%2BrPhGVLSEAIfkECAUAAAAsAAAAACIAIgCEISEhKSkpQkJCWlpaY2" +
"Nja2trc3Nze3t7hISEjIyMlJSUpaWlra2ttbW1vb29xsbG1tbW3t7e5%2Bfn7%2B%2Fv9%2Ff3%2F%2F%2F%2FAAAAAAAAAAAAAA" +
"AAAAAAAAAAAAAAAAAAAAAAAAAABYRgJY5kaZ5oqq5s675wLM90bd94HgMOpZcEAAAB%2BZEMAYDAYRw9BkJmszI5LKY%2FCmPL5e" +
"IYA4K4QC4ksOhRhCH9NRIIRUQ3YSAQDIloflPciyMODDhyJYJ6FBM%2FDguKFRB6OQ0MjhMPOow%2Be3w3k5oVFBCONwyfFRKAUw" +
"%2BRTaFoq2mxNyEAIfkECAUAAAAsAAAAACIAIgCEISEhWlpaY2Njc3Nze3t7hISEjIyMnJycpaWlra2ttbW1vb29xsbGzs7O1tbW" +
"3t7e5%2Bfn7%2B%2Fv9%2Ff3%2F%2F%2F%2FAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABYLgJI5kaZ5oqq5s" +
"675wLJPAMLdIfbOHvqsK3w%2B1ABCGokakFBQgAwFBgxRkIBcF6AIiWiJFEoMgMHB8TQ1D4swmOQ4IBFyOWA8bi8RCwc8v2oApDw" +
"xmbQ0JCQpcXxIMdQ5eEkiICYsiD4U%2FSiWYXm2dgaCAmJKjkIETDpaorK2ur4AhACH5BAgFAAAALAAAAAAiACIAhCEhITExMTk5" +
"OVJSUlpaWmNjY2tra3Nzc3t7e4SEhIyMjJycnKWlpa2trbW1tb29vcbGxs7OztbW1t7e3ufn5%2B%2Fv7%2Ff39%2F%2F%2F%2Fw" +
"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAWM4CWOZGmeaKqurDCw8PkAVWyPgHGrRD06gF3qMKCMKgCEEHUgGEWFwBKFKIoggMj0VJ" +
"2IArqpwktKDCQXiGLLSCQivkuCYNmSGu4FOm03QdoJZH0mFQ5ag4gnEg4ODYyODQ%2BDFhKVlpaJmTAWFHGJFJaefRMSEROidqQR" +
"dZoXEqytsbKztLW2t7i5tCEAOw%3D%3D",
// Color Picker Script from Flooble.com
// For more information, visit
// http://www.flooble.com/scripts/colorpicker.php
// Copyright 2003 Animus Pactum Consulting inc.
// You may use and distribute this code freely, as long as
// you keep this copyright notice and the link to flooble.com
// if you chose to remove them, you must link to the page
// listed above from every web page where you use the color
// picker code.
//---------------------------------------------------------
colorPicker: {
perline: 5,
divSet: false,
curId: null,
colorLevels: Array('A', 'B', 'C', 'D', 'E', 'F'),
colorArray: Array(),
addColor: function (r, g, b) {
this.colorArray[this.colorArray.length] = '#' + this.colorLevels[r] + this.colorLevels[r] + this.colorLevels[g] + this.colorLevels[g] + this.colorLevels[b] + this.colorLevels[b];
},
setColor: function (color) {
var that = this;
return function () {
var link = document.getElementById(that.curId);
var field = document.getElementById(that.curId + 'field');
var picker = document.getElementById('colorpicker');
field.value = color;
if (color == '') {
link.style.background = 'none';
link.style.color = 'none';
color = 'none';
} else {
link.style.background = color;
link.style.color = color;
}
picker.style.display = 'none';
eval(document.getElementById(that.curId + 'field').title);
}.bind(this)
},
setDiv: function (id) {
if (!document.createElement) { return; }
this.genColors();
var div = document.buildElement('div', { id: 'colorpicker' });
var spn = document.buildElement('span', { style: "font-family:Verdana; font-size:11px;" });
var a = document.buildElement('a', { href: "javascript:;" }, 'No color', 'click', this.setColor(''));
spn.appendChild(a);
spn.appendChild(this.getColorTable());
div.appendChild(spn);
document.body.appendChild(div);
this.divSet = true;
},
pickColor: function (id) {
id = 'ResHue';
if (!this.divSet) { this.setDiv(id); }
var picker = document.getElementById('colorpicker');
if (id == this.curId && picker.style.display == 'block') {
picker.style.display = 'none';
return;
}
this.curId = id;
var thelink = document.getElementById(id);
picker.style.top = (this.getAbsoluteOffsetTop(thelink) + 20) + "px";
picker.style.left = this.getAbsoluteOffsetLeft(thelink) + "px";
picker.style.display = 'block';
},
genColors: function () {
for (a = 0; a < this.colorLevels.length - 1; a++)
this.addColor(a, a, 5);
for (a = 0; a < this.colorLevels.length - 1; a++)
this.addColor(a, 5, a);
for (a = 0; a < this.colorLevels.length - 1; a++)
this.addColor(5, a, a);
for (a = 0; a < this.colorLevels.length - 1; a++)
this.addColor(5, 5, a);
for (a = 0; a < this.colorLevels.length - 1; a++)
this.addColor(a, 5, 5);
for (a = 0; a < this.colorLevels.length - 1; a++)
this.addColor(5, a, 5);
this.colorArray[this.colorArray.length] = "#E5ECF9";
this.colorArray[this.colorArray.length] = "#FAFAE6";
return this.colorArray;
},
getColorTable: function () {
var colors = this.colorArray;
var tab = document.buildElement('table', { border: "0", cellspacing: "1", cellpadding: "1" });
for (var i = 0; i < colors.length; i++) {
if (i % this.perline == 0) { var tr = document.buildElement('tr'); tab.appendChild(tr) }
var td = document.buildElement('td', { bgcolor: colors[i] });
var a = document.buildElement('a', { style: "outline: 1px solid #000000; color:" + colors[i] + "; background: ' + colors[i] + ';font-size: 11px;", title: colors[i], href: "javascript:;" }, "&nbsp;&nbsp;&nbsp;&nbsp;", 'click', this.setColor(colors[i]));
td.appendChild(a);
tr.appendChild(td)
}
return tab;
},
getColorTable2: function () {
var colors = this.colorArray;
var tableCode = '';
tableCode += '<table border="0" cellspacing="1" cellpadding="1">';
for (i = 0; i < colors.length; i++) {
if (i % this.perline == 0) { tableCode += '<tr>'; }
tableCode += '<td bgcolor="#000000"><a style="outline: 1px solid #000000; color: '
+ colors[i] + '; background: ' + colors[i] + ';font-size: 11px;" title="'
+ colors[i] + '" href="javascript:setColor(\'' + colors[i] + '\');">&nbsp;&nbsp;&nbsp;&nbsp;</a></td>';
if (i % this.perline == this.perline - 1) { tableCode += '</tr>'; }
}
if (i % this.perline != 0) { tableCode += '</tr>'; }
tableCode += '</table>';
return tableCode;
},
relateColor: function (id) {
return function (e) {
var color = (e.srcElement.value)
var link = document.getElementById(id);
if (color == '') {
link.style.background = 'none';
link.style.color = 'none';
color = 'none';
} else {
link.style.background = color;
link.style.color = color;
}
eval(document.getElementById(id + 'field').title);
}.bind(this)
},
getAbsoluteOffsetTop: function (obj) {
var top = obj.offsetTop;
var parent = obj.offsetParent;
while (parent != document.body && parent !== null) {
top += parent.offsetTop;
parent = parent.offsetParent;
}
return top;
},
getAbsoluteOffsetLeft: function (obj) {
var left = obj.offsetLeft;
var parent = obj.offsetParent;
while (parent != document.body && parent !== null) {
left += parent.offsetLeft;
parent = parent.offsetParent;
}
return left;
}
},
bgBordertog: function () {
var e = document.getElementById('BGBorderlink');
e.innerHTML = (e.innerHTML == 'background') ? 'border' : 'background';
},
flowtog: function () {
var e = document.getElementById('flowimg');
e.className = (e.className == 'l2r') ? 't2b' : 'l2r';
}
};
/* Prototypes and additional document functions */
document.getElementByXPath = function (XPath, contextNode) {
var a = this.evaluate(XPath, (contextNode || this), null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
return (a.snapshotLength ? a.snapshotItem(0) : null);
};
document.getElementsByXPath = function (XPath, contextNode) {
var ret = [], i = 0;
var a = this.evaluate(XPath, (contextNode || this), null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
while (a.snapshotItem(i)) {
ret.push(a.snapshotItem(i++));
}
return ret;
};
document.buildElement = function (type, atArr, inner, action, listen) {
var e = document.createElement(type);
for (var at in atArr) {
if (atArr.hasOwnProperty(at)) {
e.setAttribute(at, atArr[at]);
}
}
if (action && listen) {
e.addEventListener(action, listen, false);
}
if (inner) {
e.innerHTML = inner;
}
return e;
};
Function.prototype.bind = function (object) {
var __method = this;
return function () {
__method.apply(object, arguments);
}
};
String.prototype.repeat = function (l) {
return new Array(l + 1).join(this);
};
String.prototype.retNum = function () {
return (isNaN(this) ? 0 : (+this));
};
if (typeof GM_getValue === "undefined" || GM_getValue("a", "b") === undefined) {
if (typeof window.localStorage == "object") {
GM_setValue = function (key, value) {
window.localStorage.setItem(key, value);
}
}
else {
function getRecoverableString(oVar, notFirst) {
var oType = typeof (oVar);
if ((oType == 'null') || (oType == 'object' && !oVar)) {
//most browsers say that the typeof for null is 'object', but unlike a real
//object, it will not have any overall value
return 'null';
}
if (oType == 'undefined') { return 'window.uDfXZ0_d'; }
if (oType == 'object') {
//Safari throws errors when comparing non-objects with window/document/etc
if (oVar == window) { return 'window'; }
if (oVar == document) { return 'document'; }
if (oVar == document.body) { return 'document.body'; }
if (oVar == document.documentElement) { return 'document.documentElement'; }
}
if (oVar.nodeType && (oVar.childNodes || oVar.ownerElement)) { return '{error:\'DOM node\'}'; }
if (!notFirst) {
Object.prototype.toRecoverableString = function (oBn) {
if (this.tempLockIgnoreMe) { return '{\'LoopBack\'}'; }
this.tempLockIgnoreMe = true;
var retVal = '{', sepChar = '', j;
for (var i in this) {
if (i == 'toRecoverableString' || i == 'tempLockIgnoreMe' || i == 'prototype' || i == 'constructor') { continue; }
if (oBn && (i == 'index' || i == 'input' || i == 'length' || i == 'toRecoverableObString')) { continue; }
j = this[i];
if (!i.match(basicObPropNameValStr)) {
//for some reason, you cannot use unescape when defining peoperty names inline
for (var x = 0; x < cleanStrFromAr.length; x++) {
i = i.replace(cleanStrFromAr[x], cleanStrToAr[x]);
}
i = '\'' + i + '\'';
} else if (window.ActiveXObject && navigator.userAgent.indexOf('Mac') + 1 && !navigator.__ice_version && window.ScriptEngine && ScriptEngine() == 'JScript' && i.match(/^\d+$/)) {
//IE mac does not allow numerical property names to be used unless they are quoted
i = '\'' + i + '\'';
}
retVal += sepChar + i + ':' + getRecoverableString(j, true);
sepChar = ',';
}
retVal += '}';
this.tempLockIgnoreMe = false;
return retVal;
};
Array.prototype.toRecoverableObString = Object.prototype.toRecoverableString;
Array.prototype.toRecoverableString = function () {
if (this.tempLock) { return '[\'LoopBack\']'; }
if (!this.length) {
var oCountProp = 0;
for (var i in this) { if (i != 'toRecoverableString' && i != 'toRecoverableObString' && i != 'tempLockIgnoreMe' && i != 'prototype' && i != 'constructor' && i != 'index' && i != 'input' && i != 'length') { oCountProp++; } }
if (oCountProp) { return this.toRecoverableObString(true); }
}
this.tempLock = true;
var retVal = '[';
for (var i = 0; i < this.length; i++) {
retVal += (i ? ',' : '') + getRecoverableString(this[i], true);
}
retVal += ']';
delete this.tempLock;
return retVal;
};
Boolean.prototype.toRecoverableString = function () {
return '' + this + '';
};
Date.prototype.toRecoverableString = function () {
return 'new Date(' + this.getTime() + ')';
};
Function.prototype.toRecoverableString = function () {
return this.toString().replace(/^\s+|\s+$/g, '').replace(/^function\s*\w*\([^\)]*\)\s*\{\s*\[native\s+code\]\s*\}$/i, 'function () {[\'native code\'];}');
};
Number.prototype.toRecoverableString = function () {
if (isNaN(this)) { return 'Number.NaN'; }
if (this == Number.POSITIVE_INFINITY) { return 'Number.POSITIVE_INFINITY'; }
if (this == Number.NEGATIVE_INFINITY) { return 'Number.NEGATIVE_INFINITY'; }
return '' + this + '';
};
RegExp.prototype.toRecoverableString = function () {
return '\/' + this.source + '\/' + (this.global ? 'g' : '') + (this.ignoreCase ? 'i' : '');
};
String.prototype.toRecoverableString = function () {
var oTmp = escape(this);
if (oTmp == this) { return '\'' + this + '\''; }
return 'unescape(\'' + oTmp + '\')';
};
}
if (!oVar.toRecoverableString) { return '{error:\'internal object\'}'; }
var oTmp = oVar.toRecoverableString();
if (!notFirst) {
//prevent it from changing for...in loops that the page may be using
delete Object.prototype.toRecoverableString;
delete Array.prototype.toRecoverableObString;
delete Array.prototype.toRecoverableString;
delete Boolean.prototype.toRecoverableString;
delete Date.prototype.toRecoverableString;
delete Function.prototype.toRecoverableString;
delete Number.prototype.toRecoverableString;
delete RegExp.prototype.toRecoverableString;
delete String.prototype.toRecoverableString;
}
return oTmp;
}
GM_setValue = function (cookieName, cookieValue, lifeTime) {
if (!cookieName) { return; }
if (lifeTime == "delete") { lifeTime = -10; } else { lifeTime = 31536000; }
document.cookie = escape(cookieName) + "=" + escape(getRecoverableString(cookieValue)) +
";expires=" + (new Date((new Date()).getTime() + (1000 * lifeTime))).toGMTString() + ";path=/";
}
}
}
if (typeof GM_getValue === "undefined" || GM_getValue("a", "b") === undefined) {
if (typeof window.localStorage == "object") {
GM_getValue = function (key, defaultValue) {
var value = window.localStorage.getItem(key);
if (value == null) value = defaultValue;
else if (value == 'true') value = true;
else if (value == 'false') value = false;
return value;
}
}
else {
GM_getValue = function (cookieName, oDefault) {
var cookieJar = document.cookie.split("; ");
for (var x = 0; x < cookieJar.length; x++) {
var oneCookie = cookieJar[x].split("=");
if (oneCookie[0] == escape(cookieName)) {
try {
eval('var footm = ' + unescape(oneCookie[1]));
} catch (e) { return oDefault; }
return footm;
}
}
return oDefault;
}
}
}
if (typeof GM_xmlhttpRequest === "undefined") {
GM_xmlhttpRequest = function (details) {
var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function () {
var responseState = {
responseXML: (xmlhttp.readyState == 4 ? xmlhttp.responseXML : ''),
responseText: (xmlhttp.readyState == 4 ? xmlhttp.responseText : ''),
readyState: xmlhttp.readyState,
responseHeaders: (xmlhttp.readyState == 4 ? xmlhttp.getAllResponseHeaders() : ''),
status: (xmlhttp.readyState == 4 ? xmlhttp.status : 0),
statusText: (xmlhttp.readyState == 4 ? xmlhttp.statusText : '')
}
if (details["onreadystatechange"]) {
details["onreadystatechange"](responseState);
}
if (xmlhttp.readyState == 4) {
if (details["onload"] && xmlhttp.status >= 200 && xmlhttp.status < 300) {
details["onload"](responseState);
}
if (details["onerror"] && (xmlhttp.status < 200 || xmlhttp.status >= 300)) {
details["onerror"](responseState);
}
}
}
try {
//cannot do cross domain
xmlhttp.open(details.method, details.url);
// alert(details.method +':'+ details.url)
} catch (e) {
if (details["onerror"]) {
//simulate a real error
details["onerror"]({ responseXML: '', responseText: '', readyState: 4, responseHeaders: '', status: 403, statusText: 'Forbidden' });
}
return;
}
if (details.headers) {
for (var prop in details.headers) {
xmlhttp.setRequestHeader(prop, details.headers[prop]);
}
}
xmlhttp.send((typeof (details.data) != 'undefined') ? details.data : null);
}
}
// Browser detect
// http://www.quirksmode.org/js/detect.html
// A useful but often overrated JavaScript function is the browser detect.
// Sometimes you want to give specific instructions or load a new page in case the viewer uses, for instance, Safari.
var BrowserDetect = {
init: function () {
this.browser = this.searchString(this.dataBrowser) || "An unknown browser";
this.version = this.searchVersion(navigator.userAgent)
|| this.searchVersion(navigator.appVersion)
|| "an unknown version";
this.OS = this.searchString(this.dataOS) || "an unknown OS";
this.csQuery = this.searchCSQuery(this.dataBrowser) || false;
return (this.browser != "An unknown browser");
},
searchString: function (data) {
for (var i = 0; i < data.length; i++) {
var dataString = data[i].string;
var dataProp = data[i].prop;
this.versionSearchString = data[i].versionSearch || data[i].identity;
if (dataString) {
if (dataString.indexOf(data[i].subString) != -1)
return data[i].identity;
}
else if (dataProp)
return data[i].identity;
}
},
searchCSQuery: function (data) {
for (var i = 0; i < data.length; i++) {
var dataString = data[i].string;
var dataProp = data[i].prop;
this.versionSearchString = data[i].versionSearch || data[i].identity;
if (dataString) {
if (dataString.indexOf(data[i].subString) != -1)
return data[i].csQuery;
}
else if (dataProp)
return data[i].csQuery;
}
},
searchVersion: function (dataString) {
var index = dataString.indexOf(this.versionSearchString);
if (index == -1) return;
return parseFloat(dataString.substring(index + this.versionSearchString.length + 1));
},
dataBrowser: [
{
string: navigator.userAgent,
subString: "Chrome",
identity: "Chrome",
csQuery: false
},
{
string: navigator.userAgent,
subString: "OmniWeb",
versionSearch: "OmniWeb/",
identity: "OmniWeb",
csQuery: false
},
{
string: navigator.vendor,
subString: "Apple",
identity: "Safari",
versionSearch: "Version",
csQuery: false
},
{
prop: window.opera,
identity: "Opera",
csQuery: false
},
{
string: navigator.vendor,
subString: "iCab",
identity: "iCab",
csQuery: false
},
{
string: navigator.vendor,
subString: "KDE",
identity: "Konqueror",
csQuery: false
},
{
string: navigator.userAgent,
subString: "Firefox",
identity: "Firefox",
csQuery: true
},
{
string: navigator.vendor,
subString: "Camino",
identity: "Camino",
csQuery: false
},
{ // for newer Netscapes (6+)
string: navigator.userAgent,
subString: "Netscape",
identity: "Netscape",
csQuery: false
},
{
string: navigator.userAgent,
subString: "MSIE",
identity: "Explorer",
versionSearch: "MSIE",
csQuery: false
},
{
string: navigator.userAgent,
subString: "Gecko",
identity: "Mozilla",
versionSearch: "rv",
csQuery: false
},
{ // for older Netscapes (4-)
string: navigator.userAgent,
subString: "Mozilla",
identity: "Netscape",
versionSearch: "Mozilla",
csQuery: false
}
],
dataOS: [
{
string: navigator.platform,
subString: "Win",
identity: "Windows"
},
{
string: navigator.platform,
subString: "Mac",
identity: "Mac"
},
{
string: navigator.userAgent,
subString: "iPhone",
identity: "iPhone/iPod"
},
{
string: navigator.platform,
subString: "Linux",
identity: "Linux"
}
]
};
function findPos(obj) {
var curleft = curtop = 0;
if (obj.offsetParent) {
do {
curleft += obj.offsetLeft;
curtop += obj.offsetTop;
} while ((obj = obj.offsetParent));
}
return [curleft, curtop];
}
function getStyle(el, styleProp) {
if (el.currentStyle)
var y = el.currentStyle[styleProp];
else if (window.getComputedStyle)
var y = document.defaultView.getComputedStyle(el, null).getPropertyValue(styleProp);
if ((match = y.match(/^(\d+)px$/))) y = +match[1];
return y;
}
var monkeyr = {
toLog: false,
toLogE: false,
log: function () {
if (!this.toLog) return;
this._log.apply(this, arguments);
},
logE: function () {
if (!this.toLogE) return;
this._log.apply(this, arguments);
},
logA: function () {
if (!this.toLog && !this.toLogE) return;
this._log.apply(this, arguments);
},
_log: function () {
if (window.console) {
if (arguments.length == 1) {
console.log(arguments[0]);
}
else {
console.log(Array.prototype.slice.call(arguments));
}
}
}
}
// monkeyr.toLog = true;
// monkeyr.toLogE = true;
// UIL.watching = '#main';
/* Run the browser detect script */
BrowserDetect.init();
/* Run the update check */
UIL.UI.updateCheckRequest();
/* Run the script */
UIL.init();
})();
@Gus1664
Copy link

Gus1664 commented Aug 2, 2019

Thanks for this modification of the script. Maybe you should also change the line 82
scriptVersion: "v.1.7.3.21",
to reflect the new version.

@IzzySoft
Copy link
Author

IzzySoft commented Aug 2, 2019

@Gus1664 thanks, done. Though I consider this nothing but a temporary work-around and hope someone more qualified will provide a real fix – and pick up further development as well. My knowledge of this is too limited for such a complex script (and I lack the time to dig in).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment