Greasy Fork is available in English.

GoogleBarReturns2017

Google Bar Returns

Fra og med 14.04.2018. Se Den nyeste version.

// ==UserScript==
// @name         GoogleBarReturns2017
// @namespace    http://jtg.ii.com/
// @version      Alpha 0.2.51
// @run-at       document-start
// @description  Google Bar Returns
// @author       James Griffing
// @include     /^https?://(?:www|encrypted|ipv[46])\.google\.[^/]
// @include         http://*.google.*/webhp*
// @include         http://*.google.*/search*
// @include         http://*.google.*/ig*
// @include         http://*.google.*/*
// @include         http://*.google.*/#*
// @include         https://*.google.*/webhp*
// @include         https://*.google.*/search*
// @include         https://*.google.*/ig?*
// @include         https://*.google.*/*
// @include         https://*.google.*/#*
// @include         https://encrypted.google.*/webhp*
// @include         https://encrypted.google.*/search*
// @include         https://encrypted.google.*/ig*
// @include         https://encrypted.google.*/
// @include         https://encrypted.google.*/#*
// @include        https://www.youtube.*/
// @match        https://greasyfork.org/*
// @grant        GM_addStyle
// @grant        GM_setValue
// @grant        GM_getValue
// @grant        GM_listValues
// @grant        GM_deleteValue
// @require      http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js

// @noframes
// ==/UserScript==

//============================required====================
// Spectrum Colorpicker v1.8.0
// https://github.com/bgrins/spectrum
// Author: Brian Grinstead
// License: MIT

(function(factory){"use strict";if(typeof define==='function'&&define.amd){define(['jquery'],factory);}
else if(typeof exports=="object"&&typeof module=="object"){module.exports=factory(require('jquery'));}
else{factory(jQuery);}})(function($,undefined){"use strict";var defaultOpts={beforeShow:noop,move:noop,change:noop,show:noop,hide:noop,color:false,flat:false,showInput:false,allowEmpty:false,showButtons:true,clickoutFiresChange:true,showInitial:false,showPalette:false,showPaletteOnly:false,hideAfterPaletteSelect:false,togglePaletteOnly:false,showSelectionPalette:true,localStorageKey:false,appendTo:"body",maxSelectionSize:7,cancelText:"cancel",chooseText:"choose",togglePaletteMoreText:"more",togglePaletteLessText:"less",clearText:"Clear Color Selection",noColorSelectedText:"No Color Selected",preferredFormat:false,className:"",containerClassName:"",replacerClassName:"",showAlpha:false,theme:"sp-light",palette:[["#ffffff","#000000","#ff0000","#ff8000","#ffff00","#008000","#0000ff","#4b0082","#9400d3"]],selectionPalette:[],disabled:false,offset:null},spectrums=[],IE=!!/msie/i.exec(window.navigator.userAgent),rgbaSupport=(function(){function contains(str,substr){return!!~(''+str).indexOf(substr);}
var elem=document.createElement('div');var style=elem.style;style.cssText='background-color:rgba(0,0,0,.5)';return contains(style.backgroundColor,'rgba')||contains(style.backgroundColor,'hsla');})(),replaceInput=["<div class='sp-replacer'>","<div class='sp-preview'><div class='sp-preview-inner'></div></div>","<div class='sp-dd'>&#9660;</div>","</div>"].join(''),markup=(function(){var gradientFix="";if(IE){for(var i=1;i<=6;i++){gradientFix+="<div class='sp-"+i+"'></div>";}}
return["<div class='sp-container sp-hidden'>","<div class='sp-palette-container'>","<div class='sp-palette sp-thumb sp-cf'></div>","<div class='sp-palette-button-container sp-cf'>","<button type='button' class='sp-palette-toggle'></button>","</div>","</div>","<div class='sp-picker-container'>","<div class='sp-top sp-cf'>","<div class='sp-fill'></div>","<div class='sp-top-inner'>","<div class='sp-color'>","<div class='sp-sat'>","<div class='sp-val'>","<div class='sp-dragger'></div>","</div>","</div>","</div>","<div class='sp-clear sp-clear-display'>","</div>","<div class='sp-hue'>","<div class='sp-slider'></div>",gradientFix,"</div>","</div>","<div class='sp-alpha'><div class='sp-alpha-inner'><div class='sp-alpha-handle'></div></div></div>","</div>","<div class='sp-input-container sp-cf'>","<input class='sp-input' type='text' spellcheck='false'  />","</div>","<div class='sp-initial sp-thumb sp-cf'></div>","<div class='sp-button-container sp-cf'>","<a class='sp-cancel' href='#'></a>","<button type='button' class='sp-choose'></button>","</div>","</div>","</div>"].join("");})();function paletteTemplate(p,color,className,opts){var html=[];for(var i=0;i<p.length;i++){var current=p[i];if(current){var tiny=tinycolor(current);var c=tiny.toHsl().l<0.5?"sp-thumb-el sp-thumb-dark":"sp-thumb-el sp-thumb-light";c+=(tinycolor.equals(color,current))?" sp-thumb-active":"";var formattedString=tiny.toString(opts.preferredFormat||"rgb");var swatchStyle=rgbaSupport?("background-color:"+tiny.toRgbString()):"filter:"+tiny.toFilter();html.push('<span title="'+formattedString+'" data-color="'+tiny.toRgbString()+'" class="'+c+'"><span class="sp-thumb-inner" style="'+swatchStyle+';" /></span>');}else{var cls='sp-clear-display';html.push($('<div />').append($('<span data-color="" style="background-color:transparent;" class="'+cls+'"></span>').attr('title',opts.noColorSelectedText)).html());}}
return"<div class='sp-cf "+className+"'>"+html.join('')+"</div>";}
function hideAll(){for(var i=0;i<spectrums.length;i++){if(spectrums[i]){spectrums[i].hide();}}}
function instanceOptions(o,callbackContext){var opts=$.extend({},defaultOpts,o);opts.callbacks={'move':bind(opts.move,callbackContext),'change':bind(opts.change,callbackContext),'show':bind(opts.show,callbackContext),'hide':bind(opts.hide,callbackContext),'beforeShow':bind(opts.beforeShow,callbackContext)};return opts;}
function spectrum(element,o){var opts=instanceOptions(o,element),flat=opts.flat,showSelectionPalette=opts.showSelectionPalette,localStorageKey=opts.localStorageKey,theme=opts.theme,callbacks=opts.callbacks,resize=throttle(reflow,10),visible=false,isDragging=false,dragWidth=0,dragHeight=0,dragHelperHeight=0,slideHeight=0,slideWidth=0,alphaWidth=0,alphaSlideHelperWidth=0,slideHelperHeight=0,currentHue=0,currentSaturation=0,currentValue=0,currentAlpha=1,palette=[],paletteArray=[],paletteLookup={},selectionPalette=opts.selectionPalette.slice(0),maxSelectionSize=opts.maxSelectionSize,draggingClass="sp-dragging",shiftMovementDirection=null;var doc=element.ownerDocument,body=doc.body,boundElement=$(element),disabled=false,container=$(markup,doc).addClass(theme),pickerContainer=container.find(".sp-picker-container"),dragger=container.find(".sp-color"),dragHelper=container.find(".sp-dragger"),slider=container.find(".sp-hue"),slideHelper=container.find(".sp-slider"),alphaSliderInner=container.find(".sp-alpha-inner"),alphaSlider=container.find(".sp-alpha"),alphaSlideHelper=container.find(".sp-alpha-handle"),textInput=container.find(".sp-input"),paletteContainer=container.find(".sp-palette"),initialColorContainer=container.find(".sp-initial"),cancelButton=container.find(".sp-cancel"),clearButton=container.find(".sp-clear"),chooseButton=container.find(".sp-choose"),toggleButton=container.find(".sp-palette-toggle"),isInput=boundElement.is("input"),isInputTypeColor=isInput&&boundElement.attr("type")==="color"&&inputTypeColorSupport(),shouldReplace=isInput&&!flat,replacer=(shouldReplace)?$(replaceInput).addClass(theme).addClass(opts.className).addClass(opts.replacerClassName):$([]),offsetElement=(shouldReplace)?replacer:boundElement,previewElement=replacer.find(".sp-preview-inner"),initialColor=opts.color||(isInput&&boundElement.val()),colorOnShow=false,currentPreferredFormat=opts.preferredFormat,clickoutFiresChange=!opts.showButtons||opts.clickoutFiresChange,isEmpty=!initialColor,allowEmpty=opts.allowEmpty&&!isInputTypeColor;function applyOptions(){if(opts.showPaletteOnly){opts.showPalette=true;}
toggleButton.text(opts.showPaletteOnly?opts.togglePaletteMoreText:opts.togglePaletteLessText);if(opts.palette){palette=opts.palette.slice(0);paletteArray=$.isArray(palette[0])?palette:[palette];paletteLookup={};for(var i=0;i<paletteArray.length;i++){for(var j=0;j<paletteArray[i].length;j++){var rgb=tinycolor(paletteArray[i][j]).toRgbString();paletteLookup[rgb]=true;}}}
container.toggleClass("sp-flat",flat);container.toggleClass("sp-input-disabled",!opts.showInput);container.toggleClass("sp-alpha-enabled",opts.showAlpha);container.toggleClass("sp-clear-enabled",allowEmpty);container.toggleClass("sp-buttons-disabled",!opts.showButtons);container.toggleClass("sp-palette-buttons-disabled",!opts.togglePaletteOnly);container.toggleClass("sp-palette-disabled",!opts.showPalette);container.toggleClass("sp-palette-only",opts.showPaletteOnly);container.toggleClass("sp-initial-disabled",!opts.showInitial);container.addClass(opts.className).addClass(opts.containerClassName);reflow();}
function initialize(){if(IE){container.find("*:not(input)").attr("unselectable","on");}
applyOptions();if(shouldReplace){boundElement.after(replacer).hide();}
if(!allowEmpty){clearButton.hide();}
if(flat){boundElement.after(container).hide();}
else{var appendTo=opts.appendTo==="parent"?boundElement.parent():$(opts.appendTo);if(appendTo.length!==1){appendTo=$("body");}
appendTo.append(container);}
updateSelectionPaletteFromStorage();offsetElement.bind("click.spectrum touchstart.spectrum",function(e){if(!disabled){toggle();}
e.stopPropagation();if(!$(e.target).is("input")){e.preventDefault();}});if(boundElement.is(":disabled")||(opts.disabled===true)){disable();}
container.click(stopPropagation);textInput.change(setFromTextInput);textInput.bind("paste",function(){setTimeout(setFromTextInput,1);});textInput.keydown(function(e){if(e.keyCode==13){setFromTextInput();}});cancelButton.text(opts.cancelText);cancelButton.bind("click.spectrum",function(e){e.stopPropagation();e.preventDefault();revert();hide();});clearButton.attr("title",opts.clearText);clearButton.bind("click.spectrum",function(e){e.stopPropagation();e.preventDefault();isEmpty=true;move();if(flat){updateOriginalInput(true);}});chooseButton.text(opts.chooseText);chooseButton.bind("click.spectrum",function(e){e.stopPropagation();e.preventDefault();if(IE&&textInput.is(":focus")){textInput.trigger('change');}
if(isValid()){updateOriginalInput(true);hide();}});toggleButton.text(opts.showPaletteOnly?opts.togglePaletteMoreText:opts.togglePaletteLessText);toggleButton.bind("click.spectrum",function(e){e.stopPropagation();e.preventDefault();opts.showPaletteOnly=!opts.showPaletteOnly;if(!opts.showPaletteOnly&&!flat){container.css('left','-='+(pickerContainer.outerWidth(true)+5));}
applyOptions();});draggable(alphaSlider,function(dragX,dragY,e){currentAlpha=(dragX/alphaWidth);isEmpty=false;if(e.shiftKey){currentAlpha=Math.round(currentAlpha*10)/10;}
move();},dragStart,dragStop);draggable(slider,function(dragX,dragY){currentHue=parseFloat(dragY/slideHeight);isEmpty=false;if(!opts.showAlpha){currentAlpha=1;}
move();},dragStart,dragStop);draggable(dragger,function(dragX,dragY,e){if(!e.shiftKey){shiftMovementDirection=null;}
else if(!shiftMovementDirection){var oldDragX=currentSaturation*dragWidth;var oldDragY=dragHeight-(currentValue*dragHeight);var furtherFromX=Math.abs(dragX-oldDragX)>Math.abs(dragY-oldDragY);shiftMovementDirection=furtherFromX?"x":"y";}
var setSaturation=!shiftMovementDirection||shiftMovementDirection==="x";var setValue=!shiftMovementDirection||shiftMovementDirection==="y";if(setSaturation){currentSaturation=parseFloat(dragX/dragWidth);}
if(setValue){currentValue=parseFloat((dragHeight-dragY)/dragHeight);}
isEmpty=false;if(!opts.showAlpha){currentAlpha=1;}
move();},dragStart,dragStop);if(!!initialColor){set(initialColor);updateUI();currentPreferredFormat=opts.preferredFormat||tinycolor(initialColor).format;addColorToSelectionPalette(initialColor);}
else{updateUI();}
if(flat){show();}
function paletteElementClick(e){if(e.data&&e.data.ignore){set($(e.target).closest(".sp-thumb-el").data("color"));move();}
else{set($(e.target).closest(".sp-thumb-el").data("color"));move();updateOriginalInput(true);if(opts.hideAfterPaletteSelect){hide();}}
return false;}
var paletteEvent=IE?"mousedown.spectrum":"click.spectrum touchstart.spectrum";paletteContainer.delegate(".sp-thumb-el",paletteEvent,paletteElementClick);initialColorContainer.delegate(".sp-thumb-el:nth-child(1)",paletteEvent,{ignore:true},paletteElementClick);}
function updateSelectionPaletteFromStorage(){if(localStorageKey&&window.localStorage){try{var oldPalette=window.localStorage[localStorageKey].split(",#");if(oldPalette.length>1){delete window.localStorage[localStorageKey];$.each(oldPalette,function(i,c){addColorToSelectionPalette(c);});}}
catch(e){}
try{selectionPalette=window.localStorage[localStorageKey].split(";");}
catch(e){}}}
function addColorToSelectionPalette(color){if(showSelectionPalette){var rgb=tinycolor(color).toRgbString();if(!paletteLookup[rgb]&&$.inArray(rgb,selectionPalette)===-1){selectionPalette.push(rgb);while(selectionPalette.length>maxSelectionSize){selectionPalette.shift();}}
if(localStorageKey&&window.localStorage){try{window.localStorage[localStorageKey]=selectionPalette.join(";");}
catch(e){}}}}
function getUniqueSelectionPalette(){var unique=[];if(opts.showPalette){for(var i=0;i<selectionPalette.length;i++){var rgb=tinycolor(selectionPalette[i]).toRgbString();if(!paletteLookup[rgb]){unique.push(selectionPalette[i]);}}}
return unique.reverse().slice(0,opts.maxSelectionSize);}
function drawPalette(){var currentColor=get();var html=$.map(paletteArray,function(palette,i){return paletteTemplate(palette,currentColor,"sp-palette-row sp-palette-row-"+i,opts);});updateSelectionPaletteFromStorage();if(selectionPalette){html.push(paletteTemplate(getUniqueSelectionPalette(),currentColor,"sp-palette-row sp-palette-row-selection",opts));}
paletteContainer.html(html.join(""));}
function drawInitial(){if(opts.showInitial){var initial=colorOnShow;var current=get();initialColorContainer.html(paletteTemplate([initial,current],current,"sp-palette-row-initial",opts));}}
function dragStart(){if(dragHeight<=0||dragWidth<=0||slideHeight<=0){reflow();}
isDragging=true;container.addClass(draggingClass);shiftMovementDirection=null;boundElement.trigger('dragstart.spectrum',[get()]);}
function dragStop(){isDragging=false;container.removeClass(draggingClass);boundElement.trigger('dragstop.spectrum',[get()]);}
function setFromTextInput(){var value=textInput.val();if((value===null||value==="")&&allowEmpty){set(null);updateOriginalInput(true);}
else{var tiny=tinycolor(value);if(tiny.isValid()){set(tiny);updateOriginalInput(true);}
else{textInput.addClass("sp-validation-error");}}}
function toggle(){if(visible){hide();}
else{show();}}
function show(){var event=$.Event('beforeShow.spectrum');if(visible){reflow();return;}
boundElement.trigger(event,[get()]);if(callbacks.beforeShow(get())===false||event.isDefaultPrevented()){return;}
hideAll();visible=true;$(doc).bind("keydown.spectrum",onkeydown);$(doc).bind("click.spectrum",clickout);$(window).bind("resize.spectrum",resize);replacer.addClass("sp-active");container.removeClass("sp-hidden");reflow();updateUI();colorOnShow=get();drawInitial();callbacks.show(colorOnShow);boundElement.trigger('show.spectrum',[colorOnShow]);}
function onkeydown(e){if(e.keyCode===27){hide();}}
function clickout(e){if(e.button==2){return;}
if(isDragging){return;}
if(clickoutFiresChange){updateOriginalInput(true);}
else{revert();}
hide();}
function hide(){if(!visible||flat){return;}
visible=false;$(doc).unbind("keydown.spectrum",onkeydown);$(doc).unbind("click.spectrum",clickout);$(window).unbind("resize.spectrum",resize);replacer.removeClass("sp-active");container.addClass("sp-hidden");callbacks.hide(get());boundElement.trigger('hide.spectrum',[get()]);}
function revert(){set(colorOnShow,true);}
function set(color,ignoreFormatChange){if(tinycolor.equals(color,get())){updateUI();return;}
var newColor,newHsv;if(!color&&allowEmpty){isEmpty=true;}else{isEmpty=false;newColor=tinycolor(color);newHsv=newColor.toHsv();currentHue=(newHsv.h%360)/360;currentSaturation=newHsv.s;currentValue=newHsv.v;currentAlpha=newHsv.a;}
updateUI();if(newColor&&newColor.isValid()&&!ignoreFormatChange){currentPreferredFormat=opts.preferredFormat||newColor.getFormat();}}
function get(opts){opts=opts||{};if(allowEmpty&&isEmpty){return null;}
return tinycolor.fromRatio({h:currentHue,s:currentSaturation,v:currentValue,a:Math.round(currentAlpha*100)/100},{format:opts.format||currentPreferredFormat});}
function isValid(){return!textInput.hasClass("sp-validation-error");}
function move(){updateUI();callbacks.move(get());boundElement.trigger('move.spectrum',[get()]);}
function updateUI(){textInput.removeClass("sp-validation-error");updateHelperLocations();var flatColor=tinycolor.fromRatio({h:currentHue,s:1,v:1});dragger.css("background-color",flatColor.toHexString());var format=currentPreferredFormat;if(currentAlpha<1&&!(currentAlpha===0&&format==="name")){if(format==="hex"||format==="hex3"||format==="hex6"||format==="name"){format="rgb";}}
var realColor=get({format:format}),displayColor='';previewElement.removeClass("sp-clear-display");previewElement.css('background-color','transparent');if(!realColor&&allowEmpty){previewElement.addClass("sp-clear-display");}
else{var realHex=realColor.toHexString(),realRgb=realColor.toRgbString();if(rgbaSupport||realColor.alpha===1){previewElement.css("background-color",realRgb);}
else{previewElement.css("background-color","transparent");previewElement.css("filter",realColor.toFilter());}
if(opts.showAlpha){var rgb=realColor.toRgb();rgb.a=0;var realAlpha=tinycolor(rgb).toRgbString();var gradient="linear-gradient(left, "+realAlpha+", "+realHex+")";if(IE){alphaSliderInner.css("filter",tinycolor(realAlpha).toFilter({gradientType:1},realHex));}
else{alphaSliderInner.css("background","-webkit-"+gradient);alphaSliderInner.css("background","-moz-"+gradient);alphaSliderInner.css("background","-ms-"+gradient);alphaSliderInner.css("background","linear-gradient(to right, "+realAlpha+", "+realHex+")");}}
displayColor=realColor.toString(format);}
if(opts.showInput){textInput.val(displayColor);}
if(opts.showPalette){drawPalette();}
drawInitial();}
function updateHelperLocations(){var s=currentSaturation;var v=currentValue;if(allowEmpty&&isEmpty){alphaSlideHelper.hide();slideHelper.hide();dragHelper.hide();}
else{alphaSlideHelper.show();slideHelper.show();dragHelper.show();var dragX=s*dragWidth;var dragY=dragHeight-(v*dragHeight);dragX=Math.max(-dragHelperHeight,Math.min(dragWidth-dragHelperHeight,dragX-dragHelperHeight));dragY=Math.max(-dragHelperHeight,Math.min(dragHeight-dragHelperHeight,dragY-dragHelperHeight));dragHelper.css({"top":dragY+"px","left":dragX+"px"});var alphaX=currentAlpha*alphaWidth;alphaSlideHelper.css({"left":(alphaX-(alphaSlideHelperWidth/2))+"px"});var slideY=(currentHue)*slideHeight;slideHelper.css({"top":(slideY-slideHelperHeight)+"px"});}}
function updateOriginalInput(fireCallback){var color=get(),displayColor='',hasChanged=!tinycolor.equals(color,colorOnShow);if(color){displayColor=color.toString(currentPreferredFormat);addColorToSelectionPalette(color);}
if(isInput){boundElement.val(displayColor);}
if(fireCallback&&hasChanged){callbacks.change(color);boundElement.trigger('change',[color]);}}
function reflow(){if(!visible){return;}
dragWidth=dragger.width();dragHeight=dragger.height();dragHelperHeight=dragHelper.height();slideWidth=slider.width();slideHeight=slider.height();slideHelperHeight=slideHelper.height();alphaWidth=alphaSlider.width();alphaSlideHelperWidth=alphaSlideHelper.width();if(!flat){container.css("position","absolute");if(opts.offset){container.offset(opts.offset);}else{container.offset(getOffset(container,offsetElement));}}
updateHelperLocations();if(opts.showPalette){drawPalette();}
boundElement.trigger('reflow.spectrum');}
function destroy(){boundElement.show();offsetElement.unbind("click.spectrum touchstart.spectrum");container.remove();replacer.remove();spectrums[spect.id]=null;}
function option(optionName,optionValue){if(optionName===undefined){return $.extend({},opts);}
if(optionValue===undefined){return opts[optionName];}
opts[optionName]=optionValue;if(optionName==="preferredFormat"){currentPreferredFormat=opts.preferredFormat;}
applyOptions();}
function enable(){disabled=false;boundElement.attr("disabled",false);offsetElement.removeClass("sp-disabled");}
function disable(){hide();disabled=true;boundElement.attr("disabled",true);offsetElement.addClass("sp-disabled");}
function setOffset(coord){opts.offset=coord;reflow();}
initialize();var spect={show:show,hide:hide,toggle:toggle,reflow:reflow,option:option,enable:enable,disable:disable,offset:setOffset,set:function(c){set(c);updateOriginalInput();},get:get,destroy:destroy,container:container};spect.id=spectrums.push(spect)-1;return spect;}
function getOffset(picker,input){var extraY=0;var dpWidth=picker.outerWidth();var dpHeight=picker.outerHeight();var inputHeight=input.outerHeight();var doc=picker[0].ownerDocument;var docElem=doc.documentElement;var viewWidth=docElem.clientWidth+$(doc).scrollLeft();var viewHeight=docElem.clientHeight+$(doc).scrollTop();var offset=input.offset();offset.top+=inputHeight;offset.left-=Math.min(offset.left,(offset.left+dpWidth>viewWidth&&viewWidth>dpWidth)?Math.abs(offset.left+dpWidth-viewWidth):0);offset.top-=Math.min(offset.top,((offset.top+dpHeight>viewHeight&&viewHeight>dpHeight)?Math.abs(dpHeight+inputHeight-extraY):extraY));return offset;}
function noop(){}
function stopPropagation(e){e.stopPropagation();}
function bind(func,obj){var slice=Array.prototype.slice;var args=slice.call(arguments,2);return function(){return func.apply(obj,args.concat(slice.call(arguments)));};}
function draggable(element,onmove,onstart,onstop){onmove=onmove||function(){};onstart=onstart||function(){};onstop=onstop||function(){};var doc=document;var dragging=false;var offset={};var maxHeight=0;var maxWidth=0;var hasTouch=('ontouchstart'in window);var duringDragEvents={};duringDragEvents["selectstart"]=prevent;duringDragEvents["dragstart"]=prevent;duringDragEvents["touchmove mousemove"]=move;duringDragEvents["touchend mouseup"]=stop;function prevent(e){if(e.stopPropagation){e.stopPropagation();}
if(e.preventDefault){e.preventDefault();}
e.returnValue=false;}
function move(e){if(dragging){if(IE&&doc.documentMode<9&&!e.button){return stop();}
var t0=e.originalEvent&&e.originalEvent.touches&&e.originalEvent.touches[0];var pageX=t0&&t0.pageX||e.pageX;var pageY=t0&&t0.pageY||e.pageY;var dragX=Math.max(0,Math.min(pageX-offset.left,maxWidth));var dragY=Math.max(0,Math.min(pageY-offset.top,maxHeight));if(hasTouch){prevent(e);}
onmove.apply(element,[dragX,dragY,e]);}}
function start(e){var rightclick=(e.which)?(e.which==3):(e.button==2);if(!rightclick&&!dragging){if(onstart.apply(element,arguments)!==false){dragging=true;maxHeight=$(element).height();maxWidth=$(element).width();offset=$(element).offset();$(doc).bind(duringDragEvents);$(doc.body).addClass("sp-dragging");move(e);prevent(e);}}}
function stop(){if(dragging){$(doc).unbind(duringDragEvents);$(doc.body).removeClass("sp-dragging");setTimeout(function(){onstop.apply(element,arguments);},0);}
dragging=false;}
$(element).bind("touchstart mousedown",start);}
function throttle(func,wait,debounce){var timeout;return function(){var context=this,args=arguments;var throttler=function(){timeout=null;func.apply(context,args);};if(debounce)clearTimeout(timeout);if(debounce||!timeout)timeout=setTimeout(throttler,wait);};}
function inputTypeColorSupport(){return $.fn.spectrum.inputTypeColorSupport();}
var dataID="spectrum.id";$.fn.spectrum=function(opts,extra){if(typeof opts=="string"){var returnValue=this;var args=Array.prototype.slice.call(arguments,1);this.each(function(){var spect=spectrums[$(this).data(dataID)];if(spect){var method=spect[opts];if(!method){throw new Error("Spectrum: no such method: '"+opts+"'");}
if(opts=="get"){returnValue=spect.get();}
else if(opts=="container"){returnValue=spect.container;}
else if(opts=="option"){returnValue=spect.option.apply(spect,args);}
else if(opts=="destroy"){spect.destroy();$(this).removeData(dataID);}
else{method.apply(spect,args);}}});return returnValue;}
return this.spectrum("destroy").each(function(){var options=$.extend({},opts,$(this).data());var spect=spectrum(this,options);$(this).data(dataID,spect.id);});};$.fn.spectrum.load=true;$.fn.spectrum.loadOpts={};$.fn.spectrum.draggable=draggable;$.fn.spectrum.defaults=defaultOpts;$.fn.spectrum.inputTypeColorSupport=function inputTypeColorSupport(){if(typeof inputTypeColorSupport._cachedResult==="undefined"){var colorInput=$("<input type='color'/>")[0];inputTypeColorSupport._cachedResult=colorInput.type==="color"&&colorInput.value!=="";}
return inputTypeColorSupport._cachedResult;};$.spectrum={};$.spectrum.localization={};$.spectrum.palettes={};$.fn.spectrum.processNativeColorInputs=function(){var colorInputs=$("input[type=color]");if(colorInputs.length&&!inputTypeColorSupport()){colorInputs.spectrum({preferredFormat:"hex6"});}};(function(){var trimLeft=/^[\s,#]+/,trimRight=/\s+$/,tinyCounter=0,math=Math,mathRound=math.round,mathMin=math.min,mathMax=math.max,mathRandom=math.random;var tinycolor=function(color,opts){color=(color)?color:'';opts=opts||{};if(color instanceof tinycolor){return color;}
if(!(this instanceof tinycolor)){return new tinycolor(color,opts);}
var rgb=inputToRGB(color);this._originalInput=color,this._r=rgb.r,this._g=rgb.g,this._b=rgb.b,this._a=rgb.a,this._roundA=mathRound(100*this._a)/100,this._format=opts.format||rgb.format;this._gradientType=opts.gradientType;if(this._r<1){this._r=mathRound(this._r);}
if(this._g<1){this._g=mathRound(this._g);}
if(this._b<1){this._b=mathRound(this._b);}
this._ok=rgb.ok;this._tc_id=tinyCounter++;};tinycolor.prototype={isDark:function(){return this.getBrightness()<128;},isLight:function(){return!this.isDark();},isValid:function(){return this._ok;},getOriginalInput:function(){return this._originalInput;},getFormat:function(){return this._format;},getAlpha:function(){return this._a;},getBrightness:function(){var rgb=this.toRgb();return(rgb.r*299+rgb.g*587+rgb.b*114)/1000;},setAlpha:function(value){this._a=boundAlpha(value);this._roundA=mathRound(100*this._a)/100;return this;},toHsv:function(){var hsv=rgbToHsv(this._r,this._g,this._b);return{h:hsv.h*360,s:hsv.s,v:hsv.v,a:this._a};},toHsvString:function(){var hsv=rgbToHsv(this._r,this._g,this._b);var h=mathRound(hsv.h*360),s=mathRound(hsv.s*100),v=mathRound(hsv.v*100);return(this._a==1)?"hsv("+h+", "+s+"%, "+v+"%)":"hsva("+h+", "+s+"%, "+v+"%, "+this._roundA+")";},toHsl:function(){var hsl=rgbToHsl(this._r,this._g,this._b);return{h:hsl.h*360,s:hsl.s,l:hsl.l,a:this._a};},toHslString:function(){var hsl=rgbToHsl(this._r,this._g,this._b);var h=mathRound(hsl.h*360),s=mathRound(hsl.s*100),l=mathRound(hsl.l*100);return(this._a==1)?"hsl("+h+", "+s+"%, "+l+"%)":"hsla("+h+", "+s+"%, "+l+"%, "+this._roundA+")";},toHex:function(allow3Char){return rgbToHex(this._r,this._g,this._b,allow3Char);},toHexString:function(allow3Char){return'#'+this.toHex(allow3Char);},toHex8:function(){return rgbaToHex(this._r,this._g,this._b,this._a);},toHex8String:function(){return'#'+this.toHex8();},toRgb:function(){return{r:mathRound(this._r),g:mathRound(this._g),b:mathRound(this._b),a:this._a};},toRgbString:function(){return(this._a==1)?"rgb("+mathRound(this._r)+", "+mathRound(this._g)+", "+mathRound(this._b)+")":"rgba("+mathRound(this._r)+", "+mathRound(this._g)+", "+mathRound(this._b)+", "+this._roundA+")";},toPercentageRgb:function(){return{r:mathRound(bound01(this._r,255)*100)+"%",g:mathRound(bound01(this._g,255)*100)+"%",b:mathRound(bound01(this._b,255)*100)+"%",a:this._a};},toPercentageRgbString:function(){return(this._a==1)?"rgb("+mathRound(bound01(this._r,255)*100)+"%, "+mathRound(bound01(this._g,255)*100)+"%, "+mathRound(bound01(this._b,255)*100)+"%)":"rgba("+mathRound(bound01(this._r,255)*100)+"%, "+mathRound(bound01(this._g,255)*100)+"%, "+mathRound(bound01(this._b,255)*100)+"%, "+this._roundA+")";},toName:function(){if(this._a===0){return"transparent";}
if(this._a<1){return false;}
return hexNames[rgbToHex(this._r,this._g,this._b,true)]||false;},toFilter:function(secondColor){var hex8String='#'+rgbaToHex(this._r,this._g,this._b,this._a);var secondHex8String=hex8String;var gradientType=this._gradientType?"GradientType = 1, ":"";if(secondColor){var s=tinycolor(secondColor);secondHex8String=s.toHex8String();}
return"progid:DXImageTransform.Microsoft.gradient("+gradientType+"startColorstr="+hex8String+",endColorstr="+secondHex8String+")";},toString:function(format){var formatSet=!!format;format=format||this._format;var formattedString=false;var hasAlpha=this._a<1&&this._a>=0;var needsAlphaFormat=!formatSet&&hasAlpha&&(format==="hex"||format==="hex6"||format==="hex3"||format==="name");if(needsAlphaFormat){if(format==="name"&&this._a===0){return this.toName();}
return this.toRgbString();}
if(format==="rgb"){formattedString=this.toRgbString();}
if(format==="prgb"){formattedString=this.toPercentageRgbString();}
if(format==="hex"||format==="hex6"){formattedString=this.toHexString();}
if(format==="hex3"){formattedString=this.toHexString(true);}
if(format==="hex8"){formattedString=this.toHex8String();}
if(format==="name"){formattedString=this.toName();}
if(format==="hsl"){formattedString=this.toHslString();}
if(format==="hsv"){formattedString=this.toHsvString();}
return formattedString||this.toHexString();},_applyModification:function(fn,args){var color=fn.apply(null,[this].concat([].slice.call(args)));this._r=color._r;this._g=color._g;this._b=color._b;this.setAlpha(color._a);return this;},lighten:function(){return this._applyModification(lighten,arguments);},brighten:function(){return this._applyModification(brighten,arguments);},darken:function(){return this._applyModification(darken,arguments);},desaturate:function(){return this._applyModification(desaturate,arguments);},saturate:function(){return this._applyModification(saturate,arguments);},greyscale:function(){return this._applyModification(greyscale,arguments);},spin:function(){return this._applyModification(spin,arguments);},_applyCombination:function(fn,args){return fn.apply(null,[this].concat([].slice.call(args)));},analogous:function(){return this._applyCombination(analogous,arguments);},complement:function(){return this._applyCombination(complement,arguments);},monochromatic:function(){return this._applyCombination(monochromatic,arguments);},splitcomplement:function(){return this._applyCombination(splitcomplement,arguments);},triad:function(){return this._applyCombination(triad,arguments);},tetrad:function(){return this._applyCombination(tetrad,arguments);}};tinycolor.fromRatio=function(color,opts){if(typeof color=="object"){var newColor={};for(var i in color){if(color.hasOwnProperty(i)){if(i==="a"){newColor[i]=color[i];}
else{newColor[i]=convertToPercentage(color[i]);}}}
color=newColor;}
return tinycolor(color,opts);};function inputToRGB(color){var rgb={r:0,g:0,b:0};var a=1;var ok=false;var format=false;if(typeof color=="string"){color=stringInputToObject(color);}
if(typeof color=="object"){if(color.hasOwnProperty("r")&&color.hasOwnProperty("g")&&color.hasOwnProperty("b")){rgb=rgbToRgb(color.r,color.g,color.b);ok=true;format=String(color.r).substr(-1)==="%"?"prgb":"rgb";}
else if(color.hasOwnProperty("h")&&color.hasOwnProperty("s")&&color.hasOwnProperty("v")){color.s=convertToPercentage(color.s);color.v=convertToPercentage(color.v);rgb=hsvToRgb(color.h,color.s,color.v);ok=true;format="hsv";}
else if(color.hasOwnProperty("h")&&color.hasOwnProperty("s")&&color.hasOwnProperty("l")){color.s=convertToPercentage(color.s);color.l=convertToPercentage(color.l);rgb=hslToRgb(color.h,color.s,color.l);ok=true;format="hsl";}
if(color.hasOwnProperty("a")){a=color.a;}}
a=boundAlpha(a);return{ok:ok,format:color.format||format,r:mathMin(255,mathMax(rgb.r,0)),g:mathMin(255,mathMax(rgb.g,0)),b:mathMin(255,mathMax(rgb.b,0)),a:a};}
function rgbToRgb(r,g,b){return{r:bound01(r,255)*255,g:bound01(g,255)*255,b:bound01(b,255)*255};}
function rgbToHsl(r,g,b){r=bound01(r,255);g=bound01(g,255);b=bound01(b,255);var max=mathMax(r,g,b),min=mathMin(r,g,b);var h,s,l=(max+min)/2;if(max==min){h=s=0;}
else{var d=max-min;s=l>0.5?d/(2-max-min):d/(max+min);switch(max){case r:h=(g-b)/d+(g<b?6:0);break;case g:h=(b-r)/d+2;break;case b:h=(r-g)/d+4;break;}
h/=6;}
return{h:h,s:s,l:l};}
function hslToRgb(h,s,l){var r,g,b;h=bound01(h,360);s=bound01(s,100);l=bound01(l,100);function hue2rgb(p,q,t){if(t<0)t+=1;if(t>1)t-=1;if(t<1/6)return p+(q-p)*6*t;if(t<1/2)return q;if(t<2/3)return p+(q-p)*(2/3-t)*6;return p;}
if(s===0){r=g=b=l;}
else{var q=l<0.5?l*(1+s):l+s-l*s;var p=2*l-q;r=hue2rgb(p,q,h+1/3);g=hue2rgb(p,q,h);b=hue2rgb(p,q,h-1/3);}
return{r:r*255,g:g*255,b:b*255};}
function rgbToHsv(r,g,b){r=bound01(r,255);g=bound01(g,255);b=bound01(b,255);var max=mathMax(r,g,b),min=mathMin(r,g,b);var h,s,v=max;var d=max-min;s=max===0?0:d/max;if(max==min){h=0;}
else{switch(max){case r:h=(g-b)/d+(g<b?6:0);break;case g:h=(b-r)/d+2;break;case b:h=(r-g)/d+4;break;}
h/=6;}
return{h:h,s:s,v:v};}
function hsvToRgb(h,s,v){h=bound01(h,360)*6;s=bound01(s,100);v=bound01(v,100);var i=math.floor(h),f=h-i,p=v*(1-s),q=v*(1-f*s),t=v*(1-(1-f)*s),mod=i%6,r=[v,q,p,p,t,v][mod],g=[t,v,v,q,p,p][mod],b=[p,p,t,v,v,q][mod];return{r:r*255,g:g*255,b:b*255};}
function rgbToHex(r,g,b,allow3Char){var hex=[pad2(mathRound(r).toString(16)),pad2(mathRound(g).toString(16)),pad2(mathRound(b).toString(16))];if(allow3Char&&hex[0].charAt(0)==hex[0].charAt(1)&&hex[1].charAt(0)==hex[1].charAt(1)&&hex[2].charAt(0)==hex[2].charAt(1)){return hex[0].charAt(0)+hex[1].charAt(0)+hex[2].charAt(0);}
return hex.join("");}
function rgbaToHex(r,g,b,a){var hex=[pad2(convertDecimalToHex(a)),pad2(mathRound(r).toString(16)),pad2(mathRound(g).toString(16)),pad2(mathRound(b).toString(16))];return hex.join("");}
tinycolor.equals=function(color1,color2){if(!color1||!color2){return false;}
return tinycolor(color1).toRgbString()==tinycolor(color2).toRgbString();};tinycolor.random=function(){return tinycolor.fromRatio({r:mathRandom(),g:mathRandom(),b:mathRandom()});};function desaturate(color,amount){amount=(amount===0)?0:(amount||10);var hsl=tinycolor(color).toHsl();hsl.s-=amount/100;hsl.s=clamp01(hsl.s);return tinycolor(hsl);}
function saturate(color,amount){amount=(amount===0)?0:(amount||10);var hsl=tinycolor(color).toHsl();hsl.s+=amount/100;hsl.s=clamp01(hsl.s);return tinycolor(hsl);}
function greyscale(color){return tinycolor(color).desaturate(100);}
function lighten(color,amount){amount=(amount===0)?0:(amount||10);var hsl=tinycolor(color).toHsl();hsl.l+=amount/100;hsl.l=clamp01(hsl.l);return tinycolor(hsl);}
function brighten(color,amount){amount=(amount===0)?0:(amount||10);var rgb=tinycolor(color).toRgb();rgb.r=mathMax(0,mathMin(255,rgb.r-mathRound(255*-(amount/100))));rgb.g=mathMax(0,mathMin(255,rgb.g-mathRound(255*-(amount/100))));rgb.b=mathMax(0,mathMin(255,rgb.b-mathRound(255*-(amount/100))));return tinycolor(rgb);}
function darken(color,amount){amount=(amount===0)?0:(amount||10);var hsl=tinycolor(color).toHsl();hsl.l-=amount/100;hsl.l=clamp01(hsl.l);return tinycolor(hsl);}
function spin(color,amount){var hsl=tinycolor(color).toHsl();var hue=(mathRound(hsl.h)+amount)%360;hsl.h=hue<0?360+hue:hue;return tinycolor(hsl);}
function complement(color){var hsl=tinycolor(color).toHsl();hsl.h=(hsl.h+180)%360;return tinycolor(hsl);}
function triad(color){var hsl=tinycolor(color).toHsl();var h=hsl.h;return[tinycolor(color),tinycolor({h:(h+120)%360,s:hsl.s,l:hsl.l}),tinycolor({h:(h+240)%360,s:hsl.s,l:hsl.l})];}
function tetrad(color){var hsl=tinycolor(color).toHsl();var h=hsl.h;return[tinycolor(color),tinycolor({h:(h+90)%360,s:hsl.s,l:hsl.l}),tinycolor({h:(h+180)%360,s:hsl.s,l:hsl.l}),tinycolor({h:(h+270)%360,s:hsl.s,l:hsl.l})];}
function splitcomplement(color){var hsl=tinycolor(color).toHsl();var h=hsl.h;return[tinycolor(color),tinycolor({h:(h+72)%360,s:hsl.s,l:hsl.l}),tinycolor({h:(h+216)%360,s:hsl.s,l:hsl.l})];}
function analogous(color,results,slices){results=results||6;slices=slices||30;var hsl=tinycolor(color).toHsl();var part=360/slices;var ret=[tinycolor(color)];for(hsl.h=((hsl.h-(part*results>>1))+720)%360;--results;){hsl.h=(hsl.h+part)%360;ret.push(tinycolor(hsl));}
return ret;}
function monochromatic(color,results){results=results||6;var hsv=tinycolor(color).toHsv();var h=hsv.h,s=hsv.s,v=hsv.v;var ret=[];var modification=1/results;while(results--){ret.push(tinycolor({h:h,s:s,v:v}));v=(v+modification)%1;}
return ret;}
tinycolor.mix=function(color1,color2,amount){amount=(amount===0)?0:(amount||50);var rgb1=tinycolor(color1).toRgb();var rgb2=tinycolor(color2).toRgb();var p=amount/100;var w=p*2-1;var a=rgb2.a-rgb1.a;var w1;if(w*a==-1){w1=w;}else{w1=(w+a)/(1+w*a);}
w1=(w1+1)/2;var w2=1-w1;var rgba={r:rgb2.r*w1+rgb1.r*w2,g:rgb2.g*w1+rgb1.g*w2,b:rgb2.b*w1+rgb1.b*w2,a:rgb2.a*p+rgb1.a*(1-p)};return tinycolor(rgba);};tinycolor.readability=function(color1,color2){var c1=tinycolor(color1);var c2=tinycolor(color2);var rgb1=c1.toRgb();var rgb2=c2.toRgb();var brightnessA=c1.getBrightness();var brightnessB=c2.getBrightness();var colorDiff=(Math.max(rgb1.r,rgb2.r)-Math.min(rgb1.r,rgb2.r)+
Math.max(rgb1.g,rgb2.g)-Math.min(rgb1.g,rgb2.g)+
Math.max(rgb1.b,rgb2.b)-Math.min(rgb1.b,rgb2.b));return{brightness:Math.abs(brightnessA-brightnessB),color:colorDiff};};tinycolor.isReadable=function(color1,color2){var readability=tinycolor.readability(color1,color2);return readability.brightness>125&&readability.color>500;};tinycolor.mostReadable=function(baseColor,colorList){var bestColor=null;var bestScore=0;var bestIsReadable=false;for(var i=0;i<colorList.length;i++){var readability=tinycolor.readability(baseColor,colorList[i]);var readable=readability.brightness>125&&readability.color>500;var score=3*(readability.brightness/125)+(readability.color/500);if((readable&&!bestIsReadable)||(readable&&bestIsReadable&&score>bestScore)||((!readable)&&(!bestIsReadable)&&score>bestScore)){bestIsReadable=readable;bestScore=score;bestColor=tinycolor(colorList[i]);}}
return bestColor;};var names=tinycolor.names={aliceblue:"f0f8ff",antiquewhite:"faebd7",aqua:"0ff",aquamarine:"7fffd4",azure:"f0ffff",beige:"f5f5dc",bisque:"ffe4c4",black:"000",blanchedalmond:"ffebcd",blue:"00f",blueviolet:"8a2be2",brown:"a52a2a",burlywood:"deb887",burntsienna:"ea7e5d",cadetblue:"5f9ea0",chartreuse:"7fff00",chocolate:"d2691e",coral:"ff7f50",cornflowerblue:"6495ed",cornsilk:"fff8dc",crimson:"dc143c",cyan:"0ff",darkblue:"00008b",darkcyan:"008b8b",darkgoldenrod:"b8860b",darkgray:"a9a9a9",darkgreen:"006400",darkgrey:"a9a9a9",darkkhaki:"bdb76b",darkmagenta:"8b008b",darkolivegreen:"556b2f",darkorange:"ff8c00",darkorchid:"9932cc",darkred:"8b0000",darksalmon:"e9967a",darkseagreen:"8fbc8f",darkslateblue:"483d8b",darkslategray:"2f4f4f",darkslategrey:"2f4f4f",darkturquoise:"00ced1",darkviolet:"9400d3",deeppink:"ff1493",deepskyblue:"00bfff",dimgray:"696969",dimgrey:"696969",dodgerblue:"1e90ff",firebrick:"b22222",floralwhite:"fffaf0",forestgreen:"228b22",fuchsia:"f0f",gainsboro:"dcdcdc",ghostwhite:"f8f8ff",gold:"ffd700",goldenrod:"daa520",gray:"808080",green:"008000",greenyellow:"adff2f",grey:"808080",honeydew:"f0fff0",hotpink:"ff69b4",indianred:"cd5c5c",indigo:"4b0082",ivory:"fffff0",khaki:"f0e68c",lavender:"e6e6fa",lavenderblush:"fff0f5",lawngreen:"7cfc00",lemonchiffon:"fffacd",lightblue:"add8e6",lightcoral:"f08080",lightcyan:"e0ffff",lightgoldenrodyellow:"fafad2",lightgray:"d3d3d3",lightgreen:"90ee90",lightgrey:"d3d3d3",lightpink:"ffb6c1",lightsalmon:"ffa07a",lightseagreen:"20b2aa",lightskyblue:"87cefa",lightslategray:"789",lightslategrey:"789",lightsteelblue:"b0c4de",lightyellow:"ffffe0",lime:"0f0",limegreen:"32cd32",linen:"faf0e6",magenta:"f0f",maroon:"800000",mediumaquamarine:"66cdaa",mediumblue:"0000cd",mediumorchid:"ba55d3",mediumpurple:"9370db",mediumseagreen:"3cb371",mediumslateblue:"7b68ee",mediumspringgreen:"00fa9a",mediumturquoise:"48d1cc",mediumvioletred:"c71585",midnightblue:"191970",mintcream:"f5fffa",mistyrose:"ffe4e1",moccasin:"ffe4b5",navajowhite:"ffdead",navy:"000080",oldlace:"fdf5e6",olive:"808000",olivedrab:"6b8e23",orange:"ffa500",orangered:"ff4500",orchid:"da70d6",palegoldenrod:"eee8aa",palegreen:"98fb98",paleturquoise:"afeeee",palevioletred:"db7093",papayawhip:"ffefd5",peachpuff:"ffdab9",peru:"cd853f",pink:"ffc0cb",plum:"dda0dd",powderblue:"b0e0e6",purple:"800080",rebeccapurple:"663399",red:"f00",rosybrown:"bc8f8f",royalblue:"4169e1",saddlebrown:"8b4513",salmon:"fa8072",sandybrown:"f4a460",seagreen:"2e8b57",seashell:"fff5ee",sienna:"a0522d",silver:"c0c0c0",skyblue:"87ceeb",slateblue:"6a5acd",slategray:"708090",slategrey:"708090",snow:"fffafa",springgreen:"00ff7f",steelblue:"4682b4",tan:"d2b48c",teal:"008080",thistle:"d8bfd8",tomato:"ff6347",turquoise:"40e0d0",violet:"ee82ee",wheat:"f5deb3",white:"fff",whitesmoke:"f5f5f5",yellow:"ff0",yellowgreen:"9acd32"};var hexNames=tinycolor.hexNames=flip(names);function flip(o){var flipped={};for(var i in o){if(o.hasOwnProperty(i)){flipped[o[i]]=i;}}
return flipped;}
function boundAlpha(a){a=parseFloat(a);if(isNaN(a)||a<0||a>1){a=1;}
return a;}
function bound01(n,max){if(isOnePointZero(n)){n="100%";}
var processPercent=isPercentage(n);n=mathMin(max,mathMax(0,parseFloat(n)));if(processPercent){n=parseInt(n*max,10)/100;}
if((math.abs(n-max)<0.000001)){return 1;}
return(n%max)/parseFloat(max);}
function clamp01(val){return mathMin(1,mathMax(0,val));}
function parseIntFromHex(val){return parseInt(val,16);}
function isOnePointZero(n){return typeof n=="string"&&n.indexOf('.')!=-1&&parseFloat(n)===1;}
function isPercentage(n){return typeof n==="string"&&n.indexOf('%')!=-1;}
function pad2(c){return c.length==1?'0'+c:''+c;}
function convertToPercentage(n){if(n<=1){n=(n*100)+"%";}
return n;}
function convertDecimalToHex(d){return Math.round(parseFloat(d)*255).toString(16);}
function convertHexToDecimal(h){return(parseIntFromHex(h)/255);}
var matchers=(function(){var CSS_INTEGER="[-\\+]?\\d+%?";var CSS_NUMBER="[-\\+]?\\d*\\.\\d+%?";var CSS_UNIT="(?:"+CSS_NUMBER+")|(?:"+CSS_INTEGER+")";var PERMISSIVE_MATCH3="[\\s|\\(]+("+CSS_UNIT+")[,|\\s]+("+CSS_UNIT+")[,|\\s]+("+CSS_UNIT+")\\s*\\)?";var PERMISSIVE_MATCH4="[\\s|\\(]+("+CSS_UNIT+")[,|\\s]+("+CSS_UNIT+")[,|\\s]+("+CSS_UNIT+")[,|\\s]+("+CSS_UNIT+")\\s*\\)?";return{rgb:new RegExp("rgb"+PERMISSIVE_MATCH3),rgba:new RegExp("rgba"+PERMISSIVE_MATCH4),hsl:new RegExp("hsl"+PERMISSIVE_MATCH3),hsla:new RegExp("hsla"+PERMISSIVE_MATCH4),hsv:new RegExp("hsv"+PERMISSIVE_MATCH3),hsva:new RegExp("hsva"+PERMISSIVE_MATCH4),hex3:/^([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,hex6:/^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,hex8:/^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/};})();function stringInputToObject(color){color=color.replace(trimLeft,'').replace(trimRight,'').toLowerCase();var named=false;if(names[color]){color=names[color];named=true;}
else if(color=='transparent'){return{r:0,g:0,b:0,a:0,format:"name"};}
var match;if((match=matchers.rgb.exec(color))){return{r:match[1],g:match[2],b:match[3]};}
if((match=matchers.rgba.exec(color))){return{r:match[1],g:match[2],b:match[3],a:match[4]};}
if((match=matchers.hsl.exec(color))){return{h:match[1],s:match[2],l:match[3]};}
if((match=matchers.hsla.exec(color))){return{h:match[1],s:match[2],l:match[3],a:match[4]};}
if((match=matchers.hsv.exec(color))){return{h:match[1],s:match[2],v:match[3]};}
if((match=matchers.hsva.exec(color))){return{h:match[1],s:match[2],v:match[3],a:match[4]};}
if((match=matchers.hex8.exec(color))){return{a:convertHexToDecimal(match[1]),r:parseIntFromHex(match[2]),g:parseIntFromHex(match[3]),b:parseIntFromHex(match[4]),format:named?"name":"hex8"};}
if((match=matchers.hex6.exec(color))){return{r:parseIntFromHex(match[1]),g:parseIntFromHex(match[2]),b:parseIntFromHex(match[3]),format:named?"name":"hex"};}
if((match=matchers.hex3.exec(color))){return{r:parseIntFromHex(match[1]+''+match[1]),g:parseIntFromHex(match[2]+''+match[2]),b:parseIntFromHex(match[3]+''+match[3]),format:named?"name":"hex"};}
return false;}
window.tinycolor=tinycolor;})();$(function(){if($.fn.spectrum.load){$.fn.spectrum.processNativeColorInputs();}});});;(function(root,factory){if(typeof exports==='object'){var randomColor=factory();if(typeof module==='object'&&module&&module.exports){exports=module.exports=randomColor;}
exports.randomColor=randomColor;}else if(typeof define==='function'&&define.amd){define([],factory);}else{root.randomColor=factory();}}(this,function(){var seed=null;var colorDictionary={};loadColorBounds();var randomColor=function(options){options=options||{};if(options.seed!==undefined&&options.seed!==null&&options.seed===parseInt(options.seed,10)){seed=options.seed;}else if(typeof options.seed==='string'){seed=stringToInteger(options.seed);}else if(options.seed!==undefined&&options.seed!==null){throw new TypeError('The seed value must be an integer or string');}else{seed=null;}
var H,S,B;if(options.count!==null&&options.count!==undefined){var totalColors=options.count,colors=[];options.count=null;while(totalColors>colors.length){if(seed&&options.seed)options.seed+=1;colors.push(randomColor(options));}
options.count=totalColors;return colors;}
H=pickHue(options);S=pickSaturation(H,options);B=pickBrightness(H,S,options);return setFormat([H,S,B],options);};function pickHue(options){var hueRange=getHueRange(options.hue),hue=randomWithin(hueRange);if(hue<0){hue=360+hue;}
return hue;}
function pickSaturation(hue,options){if(options.hue==='monochrome'){return 0;}
if(options.luminosity==='random'){return randomWithin([0,100]);}
var saturationRange=getSaturationRange(hue);var sMin=saturationRange[0],sMax=saturationRange[1];switch(options.luminosity){case'bright':sMin=55;break;case'dark':sMin=sMax-10;break;case'light':sMax=55;break;}
return randomWithin([sMin,sMax]);}
function pickBrightness(H,S,options){var bMin=getMinimumBrightness(H,S),bMax=100;switch(options.luminosity){case'dark':bMax=bMin+20;break;case'light':bMin=(bMax+bMin)/2;break;case'random':bMin=0;bMax=100;break;}
return randomWithin([bMin,bMax]);}
function setFormat(hsv,options){switch(options.format){case'hsvArray':return hsv;case'hslArray':return HSVtoHSL(hsv);case'hsl':var hsl=HSVtoHSL(hsv);return'hsl('+hsl[0]+', '+hsl[1]+'%, '+hsl[2]+'%)';case'hsla':var hslColor=HSVtoHSL(hsv);var alpha=options.alpha||Math.random();return'hsla('+hslColor[0]+', '+hslColor[1]+'%, '+hslColor[2]+'%, '+alpha+')';case'rgbArray':return HSVtoRGB(hsv);case'rgb':var rgb=HSVtoRGB(hsv);return'rgb('+rgb.join(', ')+')';case'rgba':var rgbColor=HSVtoRGB(hsv);var alpha=options.alpha||Math.random();return'rgba('+rgbColor.join(', ')+', '+alpha+')';default:return HSVtoHex(hsv);}}
function getMinimumBrightness(H,S){var lowerBounds=getColorInfo(H).lowerBounds;for(var i=0;i<lowerBounds.length-1;i++){var s1=lowerBounds[i][0],v1=lowerBounds[i][1];var s2=lowerBounds[i+1][0],v2=lowerBounds[i+1][1];if(S>=s1&&S<=s2){var m=(v2-v1)/(s2-s1),b=v1-m*s1;return m*S+b;}}
return 0;}
function getHueRange(colorInput){if(typeof parseInt(colorInput)==='number'){var number=parseInt(colorInput);if(number<360&&number>0){return[number,number];}}
if(typeof colorInput==='string'){if(colorDictionary[colorInput]){var color=colorDictionary[colorInput];if(color.hueRange){return color.hueRange;}}else if(colorInput.match(/^#?([0-9A-F]{3}|[0-9A-F]{6})$/i)){const hue=HexToHSB(colorInput)[0];return[hue,hue];}}
return[0,360];}
function getSaturationRange(hue){return getColorInfo(hue).saturationRange;}
function getColorInfo(hue){if(hue>=334&&hue<=360){hue-=360;}
for(var colorName in colorDictionary){var color=colorDictionary[colorName];if(color.hueRange&&hue>=color.hueRange[0]&&hue<=color.hueRange[1]){return colorDictionary[colorName];}}return'Color not found';}
function randomWithin(range){if(seed===null){return Math.floor(range[0]+Math.random()*(range[1]+1-range[0]));}else{var max=range[1]||1;var min=range[0]||0;seed=(seed*9301+49297)%233280;var rnd=seed/233280.0;return Math.floor(min+rnd*(max-min));}}
function HSVtoHex(hsv){var rgb=HSVtoRGB(hsv);function componentToHex(c){var hex=c.toString(16);return hex.length==1?'0'+hex:hex;}
var hex='#'+componentToHex(rgb[0])+componentToHex(rgb[1])+componentToHex(rgb[2]);return hex;}
function defineColor(name,hueRange,lowerBounds){var sMin=lowerBounds[0][0],sMax=lowerBounds[lowerBounds.length-1][0],bMin=lowerBounds[lowerBounds.length-1][1],bMax=lowerBounds[0][1];colorDictionary[name]={hueRange:hueRange,lowerBounds:lowerBounds,saturationRange:[sMin,sMax],brightnessRange:[bMin,bMax]};}
function loadColorBounds(){defineColor('monochrome',null,[[0,0],[100,0]]);defineColor('red',[-26,18],[[20,100],[30,92],[40,89],[50,85],[60,78],[70,70],[80,60],[90,55],[100,50]]);defineColor('orange',[19,46],[[20,100],[30,93],[40,88],[50,86],[60,85],[70,70],[100,70]]);defineColor('yellow',[47,62],[[25,100],[40,94],[50,89],[60,86],[70,84],[80,82],[90,80],[100,75]]);defineColor('green',[63,178],[[30,100],[40,90],[50,85],[60,81],[70,74],[80,64],[90,50],[100,40]]);defineColor('blue',[179,257],[[20,100],[30,86],[40,80],[50,74],[60,60],[70,52],[80,44],[90,39],[100,35]]);defineColor('purple',[258,282],[[20,100],[30,87],[40,79],[50,70],[60,65],[70,59],[80,52],[90,45],[100,42]]);defineColor('pink',[283,334],[[20,100],[30,90],[40,86],[60,84],[80,80],[90,75],[100,73]]);}
function HSVtoRGB(hsv){var h=hsv[0];if(h===0){h=1;}
if(h===360){h=359;}
h=h/360;var s=hsv[1]/100,v=hsv[2]/100;var h_i=Math.floor(h*6),f=h*6-h_i,p=v*(1-s),q=v*(1-f*s),t=v*(1-(1-f)*s),r=256,g=256,b=256;switch(h_i){case 0:r=v;g=t;b=p;break;case 1:r=q;g=v;b=p;break;case 2:r=p;g=v;b=t;break;case 3:r=p;g=q;b=v;break;case 4:r=t;g=p;b=v;break;case 5:r=v;g=p;b=q;break;}
var result=[Math.floor(r*255),Math.floor(g*255),Math.floor(b*255)];return result;}
function HexToHSB(hex){hex=hex.replace(/^#/,'');hex=hex.length===3?hex.replace(/(.)/g,'$1$1'):hex;const red=parseInt(hex.substr(0,2),16)/255,green=parseInt(hex.substr(2,2),16)/255,blue=parseInt(hex.substr(4,2),16)/255;const cMax=Math.max(red,green,blue),delta=cMax-Math.min(red,green,blue),saturation=cMax?(delta/cMax):0;switch(cMax){case red:return[60*(((green-blue)/delta)%6)||0,saturation,cMax];case green:return[60*(((blue-red)/delta)+2)||0,saturation,cMax];case blue:return[60*(((red-green)/delta)+4)||0,saturation,cMax];}}
function HSVtoHSL(hsv){var h=hsv[0],s=hsv[1]/100,v=hsv[2]/100,k=(2-s)*v;return[h,Math.round(s*v/(k<1?k:2-k)*10000)/100,k/2*100];}
function stringToInteger(string){var total=0
for(var i=0;i!==string.length;i++){if(total>=Number.MAX_SAFE_INTEGER)break;total+=string.charCodeAt(i)}
return total}
return randomColor;}));


(function() {
    'use strict';

    //==============================Default Settings==============================
if (typeof GM_getValue("GB_BGColor") === 'undefined')     {    //
        SetDefaults();
        addGoogleFont(GM_getValue("GB_Font"));
    }



    function SetDefaults() {
        var AllSettings = GM_listValues();
        for (var AllSettingsIndex = 0, key = null; key = AllSettings[AllSettingsIndex]; AllSettingsIndex++) {
            GM_deleteValue(key);
        }
        GM_setValue("GB_Url1", "https://plus.google.com/");
        GM_setValue("GB_Url1text", "+You");
        GM_setValue("GB_Url2", "https://www.google.com/webhp");
        GM_setValue("GB_Url2text", "Search");
        GM_setValue("GB_Url3", "https://www.google.com/imghp");
        GM_setValue("GB_Url3text", "Images");
        GM_setValue("GB_Url4", "https://www.youtube.com/");
        GM_setValue("GB_Url4text", "YouTube");
        GM_setValue("GB_Url5", "https://maps.google.com");
        GM_setValue("GB_Url5text", "Maps");
        GM_setValue("GB_Url6", "https://play.google.com/store");
        GM_setValue("GB_Url6text", "Play");
        GM_setValue("GB_Url7", "https://news.google.com/");
        GM_setValue("GB_Url7text", "News");
        GM_setValue("GB_Url8", "https://mail.google.com/");
        GM_setValue("GB_Url8text", "Gmail");
        GM_setValue("GB_Url9", "https://drive.google.com/drive/");
        GM_setValue("GB_Url9text", "Drive");
        GM_setValue("GB_Url10", "https://calendar.google.com");
        GM_setValue("GB_Url10text", "Calendar");
        GM_setValue("GB_Url11", "https://www.amazon.com");
        GM_setValue("GB_Url11text", "Amazon");
        GM_setValue("GB_Url12", "https://www.facebook.com");
        GM_setValue("GB_Url12text", "Facebook");
        GM_setValue("GB_DropDownUrl1", "https://greasyfork.org/");
        GM_setValue("GB_DropDownUrl1text", "GreasyFork");
        GM_setValue("GB_DropDownUrl2", "https://books.google.com/");
        GM_setValue("GB_DropDownUrl2text", "Books");
        GM_setValue("GB_DropDownUrl3", "https://finance.google.com");
        GM_setValue("GB_DropDownUrl3text", "Finance");
        GM_setValue("GB_DropDownUrl4", "http://translate.google.com/");
        GM_setValue("GB_DropDownUrl4text", "Translate");
        GM_setValue("GB_DropDownUrl5", "https://music.google.com");
        GM_setValue("GB_DropDownUrl5text", "Music");
        GM_setValue("GB_TotalBarLinks", 10);
        GM_setValue("GB_TotalBarMenuLinks", 5);
        GM_setValue("GB_Hover", 10);
        GM_setValue("GB_BGColor", "#333333");
        GM_setValue("GB_LColor", "#FFFFFF");
        GM_setValue("GB_BColor", "#dd4b39");
        GM_setValue('GB_LColMode', "2");
        GM_setValue('GB_Pos', "fixed");
        GM_setValue('GB_RandCol', "0");
        GM_setValue('GB_MenuDisplay', "1");
        GM_setValue('GB_Font', "Source Code Pro");
        GM_setValue('GB_ColorCycleDuration', 2500);
    }

    //==============================Getting Variables==============================
    var vCurrentWebpage = window.location.href;
    var vColCycleDuration = GM_getValue("GB_ColorCycleDuration");
    var vGoogleBarFontType = GM_getValue("GB_Font");
    var vGoogleBarBackgroundColor = GM_getValue("GB_BGColor");
    var vGoogleBarLinkColor = GM_getValue("GB_LColor");
    var vGoogleBarBorderColor = GM_getValue("GB_BColor");
    var vBarPosition = GM_getValue('GB_Pos');
    var vMenuDisplay = GM_getValue('GB_MenuDisplay');
    var vTotalBarLinks = GM_getValue('GB_TotalBarLinks');
    var vTotalMenuLinks = GM_getValue('GB_TotalBarMenuLinks');
    var GoogleColorBorder = "#3CBA54"
    var GoogleColorBorderIndex = 0;
    var vLinkColorMode = GM_getValue('GB_LColMode');
    var vRandomColorMode = GM_getValue('GB_RandCol');


    //==============================Reusable Functions==============================
    function addGoogleFont(FontName) {
        $("head").append("<link href='https://fonts.googleapis.com/css?family=" + FontName + "' rel='stylesheet' type='text/css'>");
    }
    addGoogleFont(vGoogleBarFontType);

    function GenerateBarLinksFromGetValues() {
        var GoogleBarUrls = [];
        var LinkIndex;
        var vTotalBarLinks = GM_getValue('GB_TotalBarLinks');
        for (LinkIndex = 1; LinkIndex <= GM_getValue("GB_TotalBarLinks"); LinkIndex++) {
            if (GM_getValue("GB_Url" + LinkIndex + "text") === undefined) {
                GM_setValue("GB_Url" + LinkIndex + "text", "Title");
                GM_setValue("GB_Url" + LinkIndex, "https://www.example.com");
            }
            GoogleBarUrls.push({
                "title": GM_getValue("GB_Url" + LinkIndex + "text"),
                "link": GM_getValue("GB_Url" + LinkIndex)
            });
        }

        $.each(GoogleBarUrls, function(key, val) {
            //  if (val.LinkIndex.length > 0){
            var $li = $("<li class=\"GBLinkBlock\"><a class=\"GBLink\" href='" + val.link + "'>" + val.title + "</a></li>");
            $("#GoogleBar ul").append($li);

        });
    }

    function GenerateBarMenuLinksFromGetValues() {
        var GoogleBarDropDownUrls = [];
        var LinkIndex;
        for (LinkIndex = 1; LinkIndex <= GM_getValue("GB_TotalBarMenuLinks"); LinkIndex++) {
            if (GM_getValue("GB_DropDownUrl" + LinkIndex + "text") === undefined) {
                GM_setValue("GB_DropDownUrl" + LinkIndex + "text", "Title");
                GM_setValue("GB_DropDownUrl" + LinkIndex, "https://www.example.com");
            }
            GoogleBarDropDownUrls.push({
                "title": GM_getValue("GB_DropDownUrl" + LinkIndex + "text"),
                "link": GM_getValue("GB_DropDownUrl" + LinkIndex)
            });
        }
        $.each(GoogleBarDropDownUrls, function(key, val) {
            //  if (val.link.length > 0){
            var $DropDownLink = $("<a href='" + val.link + "'>" + val.title + "</a>");
            $(".dropdown-content").append($DropDownLink);
        });
        if (vMenuDisplay === "0") {
            $('[name=GBMenuDisplay]').prop('checked', true);
            $(".dropdown").css("display", "none");
        } else if (vMenuDisplay === "1") {
            $(".dropdown").css("display", "inline-block");
        }
    }

    function GenerateSetBarLinkInput() {
        var table = $('<table></table>').addClass('SettingsGoogleBarLinksTable');
        for (var i = 1; i <= GM_getValue("GB_TotalBarLinks"); i++) {
            var row = $('<tr></tr>').html('<td><input type="text" name="texturl' + i + '"></td><td><input type="text" name="barurl' + i + '"></td>');
            table.append(row);
        };
        $('#tab1').append(table);
        $('[name*= "barurl"]').keyup(function() {
            var Urlindex = $('[name*= "barurl"]').index(this);
            $('.GBLink').eq(Urlindex).attr("href", this.value);
            GM_setValue('GB_Url' + parseInt(Urlindex + 1) + '', this.value);
            GenerateExportSettings();
        });
        $('[name*= "texturl"]').keyup(function() {
            var Textindex = $('[name*= "texturl"]').index(this);
            $('.GBLink').eq(Textindex).html(this.value);
            GM_setValue('GB_Url' + parseInt(Textindex + 1) + 'text', this.value);
            GenerateExportSettings();
        });
        for (var i = 1; i <= GM_getValue("GB_TotalBarLinks"); i++) {
            $('[name = "barurl' + i + '"]').val(GM_getValue('GB_Url' + i + ''));
            $('[name = "texturl' + i + '"]').val(GM_getValue('GB_Url' + i + 'text'));
        }
    }

function DestroyAndCreateBarLinksAndSettingInput(){
            $(".SettingsGoogleBarLinksTable").remove();
            $(".GBLinkBlock").remove();
            GenerateBarLinksFromGetValues();
            GenerateSetBarLinkInput();
            $('.GBLinkBlock').eq(0).css("margin-left", "25px")
            $(".GBLinkBlock,.dropdown-content a,.GoogleBarDropDownButton").hover(function(e) {
                $(this).css("background-color", e.type === "mouseenter" ? shadeColor(GM_getValue("GB_BGColor"), parseInt(GM_getValue("GB_Hover"))) : "transparent")
            });
}

function DestroyAndCreateMoreLinksAndSettingInput(){
            var GoogleBarUrls = [];
            $(".SettingsGoogleBarMenuTable").remove();
            $(".dropdown-content a").remove();
            // $("").remove();
            GenerateBarMenuLinksFromGetValues();
            GenerateSetBarMenuLinkInputBoxes();
        }
    function GenerateSetBarMenuLinkInputBoxes() {
        var table = $('<table></table>').addClass('SettingsGoogleBarMenuTable');
        for (var i = 1; i <= GM_getValue("GB_TotalBarMenuLinks"); i++) {
            var row = $('<tr></tr>').html('<td><input type="text" value="' + GM_getValue('GB_DropDownUrl' + i + 'text') + '" name="DropDownText' + i + '"></td><td><input type="text" value="' + GM_getValue('GB_DropDownUrl' + i + '') + '" name="DropDownURL' + i + '"></td>');
            table.append(row);
        };
        $('#tab2').append(table);
        $('[name*= "DropDownURL"]').keyup(function() {
            var Urlindex = $('[name*= "DropDownURL"]').index(this);
            $('.dropdown-content a').eq(Urlindex).attr("href", this.value);
            GM_setValue('GB_DropDownUrl' + parseInt(Urlindex + 1) + '', this.value);
            GenerateExportSettings();
        });
        $('[name*= "DropDownText"]').keyup(function() {
            var Textindex = $('[name*= "DropDownText"]').index(this);
            $('.dropdown-content a').eq(Textindex).html(this.value);
            GM_setValue('GB_DropDownUrl' + parseInt(Textindex + 1) + 'text', this.value);
            GenerateExportSettings();
        });
    }

    function GenerateExportSettings() {
        var ExportSettingsText = "|===============Google Bar===============|";
        ExportSettingsText += "\n" + GM_getValue("GB_BGColor");
        ExportSettingsText += "|" + GM_getValue("GB_BColor");
        ExportSettingsText += "|" + GM_getValue("GB_LColor");
        ExportSettingsText += "|" + GM_getValue('GB_Pos');
        ExportSettingsText += "|" + GM_getValue('GB_TotalBarLinks');
        ExportSettingsText += "|" + GM_getValue('GB_TotalBarMenuLinks');
        ExportSettingsText += "|" + GM_getValue('GB_LColMode');
        ExportSettingsText += "|" + GM_getValue('GB_RandCol');
        ExportSettingsText += "|" + GM_getValue('GB_MenuDisplay');
        ExportSettingsText += "|" + GM_getValue('GB_Font');
        ExportSettingsText += "|" + GM_getValue('GB_ColorCycleDuration');
        ExportSettingsText += "\n|============Google Bar Links============|\n";

        for (var i = 1; i <= GM_getValue("GB_TotalBarLinks"); i++) {
            ExportSettingsText += GM_getValue('GB_Url' + i) + '|' + GM_getValue('GB_Url' + i + 'text') + "\n";
        }

        ExportSettingsText += "|==========Google Bar More Links=========|\n";

        for (var i = 1; i <= GM_getValue("GB_TotalBarMenuLinks"); i++) {
            ExportSettingsText += GM_getValue('GB_DropDownUrl' + i) + '|' + GM_getValue('GB_DropDownUrl' + i + 'text') + "\n";
        }
        $('#ExportSettings').val(ExportSettingsText);
    }



    function extractHostname(url) {
        var hostname;
        //find & remove protocol (http, ftp, etc.) and get the hostname
        if (url.indexOf("://") > -1) {
            hostname = url.split('/')[2];
        } else {
            hostname = url.split('/')[0];
        }
        //find & remove port number
        hostname = hostname.split(':')[0];

        return hostname;
    }

    function shadeColor(color, percent) {
        var R = parseInt(color.substring(1, 3), 16);
        var G = parseInt(color.substring(3, 5), 16);
        var B = parseInt(color.substring(5, 7), 16);
        R = parseInt(R * (100 + percent) / 100);
        G = parseInt(G * (100 + percent) / 100);
        B = parseInt(B * (100 + percent) / 100);
        R = (R < 255) ? R : 255;
        G = (G < 255) ? G : 255;
        B = (B < 255) ? B : 255;
        var RR = ((R.toString(16).length == 1) ? "0" + R.toString(16) : R.toString(16));
        var GG = ((G.toString(16).length == 1) ? "0" + G.toString(16) : G.toString(16));
        var BB = ((B.toString(16).length == 1) ? "0" + B.toString(16) : B.toString(16));
        return "#" + RR + GG + BB;
    }

    function invertColor(hex, bw) {
        if (hex.indexOf('#') === 0) {
            hex = hex.slice(1);
        }
        // convert 3-digit hex to 6-digits.
        if (hex.length === 3) {
            hex = hex[0] + hex[0] + hex[1] + hex[1] + hex[2] + hex[2];
        }
        if (hex.length !== 6) {
            throw new Error('Invalid HEX color.');
        }
        var r = parseInt(hex.slice(0, 2), 16),
            g = parseInt(hex.slice(2, 4), 16),
            b = parseInt(hex.slice(4, 6), 16);
        if (bw) {
            // http://stackoverflow.com/a/3943023/112731
            return (r * 0.299 + g * 0.587 + b * 0.114) > 186 ?
                '#000000' :
                '#FFFFFF';
        }
        // invert color components
        r = (255 - r).toString(16);
        g = (255 - g).toString(16);
        b = (255 - b).toString(16);
        // pad each with zeros and return
        return "#" + padZero(r) + padZero(g) + padZero(b);
    }

    function padZero(str, len) {
        len = len || 2;
        var zeros = new Array(len).join('0');
        return (zeros + str).slice(-len);
    }

    function RandomizeBarColor() {
    var vLinkColorMode = GM_getValue('GB_LColMode');
    var vRandomColorMode = GM_getValue('GB_RandCol');
        if (vRandomColorMode === "1") {

GM_addStyle(`#GoogleBar a,#GearIcon,.GoogleBarDropDownButton{
             ms-transition:color ` + vColCycleDuration + `ms linear;
             transition:color ` + vColCycleDuration + `ms linear;
             webkit-transition:color ` + vColCycleDuration + `ms linear;}
             #GoogleBar,.dropdown-content{
             ms-transition:background-color ` + vColCycleDuration + `ms linear;
             transition:background-color ` + vColCycleDuration + `ms linear;
             webkit-transition:background-color ` + vColCycleDuration + `ms linear;}`);

            var vLinkColorMode = GM_getValue("GB_LColMode");
            var RandomColorCSS = randomColor({
                luminosity: 'dark',
                hue: ''
            });

            $(".GBLinkBlock,.dropdown-content a,.GoogleBarDropDownButton").hover(function(e) {
                $(this).css("background-color", e.type === "mouseenter" ? "transparent" : "transparent")
            });
            $('#GBColRand').prop('checked', true);
            $('#GoogleBar,.dropdown-content').css("background-color", RandomColorCSS);
            $("#GBarColorPicker").spectrum("set", RandomColorCSS);

            if (vLinkColorMode === "1") {
                $('#GoogleBar a,#GearIcon,.GoogleBarDropDownButton').css("color", invertColor(RandomColorCSS, ""));
                $("#GBarLinkColorPicker").spectrum("set", invertColor(RandomColorCSS, ""));
            } else if (vLinkColorMode === "2") {
                $('#GoogleBar a,#GearIcon,.GoogleBarDropDownButton').css("color", invertColor(RandomColorCSS, "BW"));
                $("#GBarLinkColorPicker").spectrum("set", invertColor(RandomColorCSS, "BW"));
            } else if (vLinkColorMode === "3") {}
        } else {
            $(".GBLinkBlock,.dropdown-content a,.GoogleBarDropDownButton").hover(function(e) {
                $(this).css("background-color", e.type === "mouseenter" ? shadeColor(GM_getValue("GB_BGColor"), parseInt(GM_getValue("GB_Hover"))) : "transparent")
            });
        }
    }


    function GoogleBarSearch(SearchURL, SearchPath = 0) {
        $('[name="q"]').keyup(function KeyUp() {
            var Gsearchterm = encodeURIComponent(this.value);
            var Hostname = extractHostname(SearchURL);

            if (SearchURL.indexOf(SearchPath) > 1) {
                Hostname = SearchPath;
            }

            var SearchURLwQ = SearchURL + Gsearchterm;
            $('#GoogleBar [href*="' + Hostname + '"]').attr("href", SearchURLwQ);
        });
    }
    //==============================Initially Create Bar Links==============================

    function CreateGoogleBar(){

    $("html").append(`
<div id="GoogleBar">
   <ul></ul>
</div>
<div id="settings_box">
<div id="close_button">x</div>
<div class="tabs">
   <ul class="tab-links">
      <li class="active"><a href="#tab1">Links</a>
      </li>
      <li><a href="#tab2">More</a>
      </li>
      <li><a href="#tab3">Colors</a>
      </li>
      <li><a href="#tab4">Placement</a>
      </li>
      <li><a href="#tab5">Font</a>
      </li>
      <li><a href="#tab6">&#x25B2;&#x25BC;</a>
      </li>
   </ul>
   <div class="tab-content">
      <div id="tab1" class="tab active">
         <h2>Google Bar Links<input type="number" name="BarLinkNumberInput" min="1" max="30" maxlength="2" oninput="javascript: if (this.value.length > this.maxLength) this.value = this.value.slice(0, this.maxLength);" value=` + vTotalBarLinks + `></h2>
      </div>
      <div id="tab2" class="tab">
         <h2>Google Bar Drop Down Menu<input type="number" name="BarMenuNumberInput" min="1" max="30" maxlength="2" oninput="javascript: if (this.value.length > this.maxLength) this.value = this.value.slice(0, this.maxLength);" value=` + GM_getValue("GB_TotalBarMenuLinks") + `></h2>
         <div id="MoreDisplaySetting">
            <label for="GBMenuDisplay">Disable More</label>
            <input type="checkbox" name="GBMenuDisplay" id="GBMenuDisplay" />
         </div>
      </div>
      <div id="tab3" class="tab">
         <h2>Google Bar Colors</h2>
         <br>
                  <table id="GoogleBarColorLabels">
         <tr><td>Bar Color</td><td>Link Color</td><td>Border Color</td></tr>
         </table>
          <input type='text' id="GBarColorPicker" />
          <input type='text' id="GBarLinkColorPicker" />
          <input type='text' id="GBarBorderColorPicker" />
         <br>
         <label for="GBColRand">Cycle Color</label>
         <input type="checkbox" name="group-three" id="GBColRand" />
         <input type='number' min="250" max="60000" step="250" value="` + vColCycleDuration + `" name='vColCycleDuration' />
         <label for="ICol">Invert</label>
         <input title="Link Color is inverted from Bar Color" type="radio" name="group-one" id="ICol" value="1" />
         <label for="BWCol">Black/White</label>
         <input title="Link Color is Black or White based on Bar Color" type="radio" name="group-one" id="BWCol" value="2" />
         <label for="HPcol">Handpick</label>
         <input title="No Automatic Link Color Manipulation" type="radio" name="group-one" id="HPcol" value="3" />
      </div>
      <div id="tab4" class="tab">
         <h2>Google Bar Placement</h2>
         <div id="BarPosRadioButtons">
            <label for="GBPosA">Sticky</label>
            <input type="checkbox" name="StickyCheckBox" id="GBPosA" value="absolute" />
         </div>
      </div>
      <div id="tab5" class="tab">
         <h2>Google Bar Font</h2>
         <div id="BarFontOption">
                <select name="GoogleBarFont">
                    <option value="ABeeZee">ABeeZee</option>
                    <option value="Abel">Abel</option>
                    <option value="Abril Fatface">Abril Fatface</option>
                    <option value="Aclonica">Aclonica</option>
                    <option value="Acme">Acme</option>
                    <option value="Actor">Actor</option>
                    <option value="Adamina">Adamina</option>
                    <option value="Advent Pro">Advent Pro</option>
                    <option value="Aguafina Script">Aguafina Script</option>
                    <option value="Akronim">Akronim</option>
                    <option value="Aladin">Aladin</option>
                    <option value="Aldrich">Aldrich</option>
                    <option value="Alef">Alef</option>
                    <option value="Alegreya">Alegreya</option>
                    <option value="Alegreya SC">Alegreya SC</option>
                    <option value="Alegreya Sans">Alegreya Sans</option>
                    <option value="Alegreya Sans SC">Alegreya Sans SC</option>
                    <option value="Alex Brush">Alex Brush</option>
                    <option value="Alfa Slab One">Alfa Slab One</option>
                    <option value="Alice">Alice</option>
                    <option value="Alike">Alike</option>
                    <option value="Alike Angular">Alike Angular</option>
                    <option value="Allan">Allan</option>
                    <option value="Allerta">Allerta</option>
                    <option value="Allerta Stencil">Allerta Stencil</option>
                    <option value="Allura">Allura</option>
                    <option value="Almendra">Almendra</option>
                    <option value="Almendra Display">Almendra Display</option>
                    <option value="Almendra SC">Almendra SC</option>
                    <option value="Amarante">Amarante</option>
                    <option value="Amaranth">Amaranth</option>
                    <option value="Amatic SC">Amatic SC</option>
                    <option value="Amethysta">Amethysta</option>
                    <option value="Amiri">Amiri</option>
                    <option value="Amita">Amita</option>
                    <option value="Anaheim">Anaheim</option>
                    <option value="Andada">Andada</option>
                    <option value="Andika">Andika</option>
                    <option value="Angkor">Angkor</option>
                    <option value="Annie Use Your Telescope">Annie Use Your Telescope</option>
                    <option value="Anonymous Pro">Anonymous Pro</option>
                    <option value="Antic">Antic</option>
                    <option value="Antic Didone">Antic Didone</option>
                    <option value="Antic Slab">Antic Slab</option>
                    <option value="Anton">Anton</option>
                    <option value="Arapey">Arapey</option>
                    <option value="Arbutus">Arbutus</option>
                    <option value="Arbutus Slab">Arbutus Slab</option>
                    <option value="Architects Daughter">Architects Daughter</option>
                    <option value="Archivo Black">Archivo Black</option>
                    <option value="Archivo Narrow">Archivo Narrow</option>
                    <option value="Arimo">Arimo</option>
                    <option value="Arizonia">Arizonia</option>
                    <option value="Armata">Armata</option>
                    <option value="Artifika">Artifika</option>
                    <option value="Arvo">Arvo</option>
                    <option value="Arya">Arya</option>
                    <option value="Asap">Asap</option>
                    <option value="Asar">Asar</option>
                    <option value="Asset">Asset</option>
                    <option value="Astloch">Astloch</option>
                    <option value="Asul">Asul</option>
                    <option value="Atomic Age">Atomic Age</option>
                    <option value="Aubrey">Aubrey</option>
                    <option value="Audiowide">Audiowide</option>
                    <option value="Autour One">Autour One</option>
                    <option value="Average">Average</option>
                    <option value="Average Sans">Average Sans</option>
                    <option value="Averia Gruesa Libre">Averia Gruesa Libre</option>
                    <option value="Averia Libre">Averia Libre</option>
                    <option value="Averia Sans Libre">Averia Sans Libre</option>
                    <option value="Averia Serif Libre">Averia Serif Libre</option>
                    <option value="Bad Script">Bad Script</option>
                    <option value="Balthazar">Balthazar</option>
                    <option value="Bangers">Bangers</option>
                    <option value="Basic">Basic</option>
                    <option value="Battambang">Battambang</option>
                    <option value="Baumans">Baumans</option>
                    <option value="Bayon">Bayon</option>
                    <option value="Belgrano">Belgrano</option>
                    <option value="Belleza">Belleza</option>
                    <option value="BenchNine">BenchNine</option>
                    <option value="Bentham">Bentham</option>
                    <option value="Berkshire Swash">Berkshire Swash</option>
                    <option value="Bevan">Bevan</option>
                    <option value="Bigelow Rules">Bigelow Rules</option>
                    <option value="Bigshot One">Bigshot One</option>
                    <option value="Bilbo">Bilbo</option>
                    <option value="Bilbo Swash Caps">Bilbo Swash Caps</option>
                    <option value="Biryani">Biryani</option>
                    <option value="Bitter">Bitter</option>
                    <option value="Black Ops One">Black Ops One</option>
                    <option value="Bokor">Bokor</option>
                    <option value="Bonbon">Bonbon</option>
                    <option value="Boogaloo">Boogaloo</option>
                    <option value="Bowlby One">Bowlby One</option>
                    <option value="Bowlby One SC">Bowlby One SC</option>
                    <option value="Brawler">Brawler</option>
                    <option value="Bree Serif">Bree Serif</option>
                    <option value="Bubblegum Sans">Bubblegum Sans</option>
                    <option value="Bubbler One">Bubbler One</option>
                    <option value="Buda">Buda</option>
                    <option value="Buenard">Buenard</option>
                    <option value="Butcherman">Butcherman</option>
                    <option value="Butterfly Kids">Butterfly Kids</option>
                    <option value="Cabin">Cabin</option>
                    <option value="Cabin Condensed">Cabin Condensed</option>
                    <option value="Cabin Sketch">Cabin Sketch</option>
                    <option value="Caesar Dressing">Caesar Dressing</option>
                    <option value="Cagliostro">Cagliostro</option>
                    <option value="Calligraffitti">Calligraffitti</option>
                    <option value="Cambay">Cambay</option>
                    <option value="Cambo">Cambo</option>
                    <option value="Candal">Candal</option>
                    <option value="Cantarell">Cantarell</option>
                    <option value="Cantata One">Cantata One</option>
                    <option value="Cantora One">Cantora One</option>
                    <option value="Capriola">Capriola</option>
                    <option value="Cardo">Cardo</option>
                    <option value="Carme">Carme</option>
                    <option value="Carrois Gothic">Carrois Gothic</option>
                    <option value="Carrois Gothic SC">Carrois Gothic SC</option>
                    <option value="Carter One">Carter One</option>
                    <option value="Catamaran">Catamaran</option>
                    <option value="Caudex">Caudex</option>
                    <option value="Caveat">Caveat</option>
                    <option value="Caveat Brush">Caveat Brush</option>
                    <option value="Cedarville Cursive">Cedarville Cursive</option>
                    <option value="Ceviche One">Ceviche One</option>
                    <option value="Changa One">Changa One</option>
                    <option value="Chango">Chango</option>
                    <option value="Chau Philomene One">Chau Philomene One</option>
                    <option value="Chela One">Chela One</option>
                    <option value="Chelsea Market">Chelsea Market</option>
                    <option value="Chenla">Chenla</option>
                    <option value="Cherry Cream Soda">Cherry Cream Soda</option>
                    <option value="Cherry Swash">Cherry Swash</option>
                    <option value="Chewy">Chewy</option>
                    <option value="Chicle">Chicle</option>
                    <option value="Chivo">Chivo</option>
                    <option value="Chonburi">Chonburi</option>
                    <option value="Cinzel">Cinzel</option>
                    <option value="Cinzel Decorative">Cinzel Decorative</option>
                    <option value="Clicker Script">Clicker Script</option>
                    <option value="Coda">Coda</option>
                    <option value="Coda Caption">Coda Caption</option>
                    <option value="Codystar">Codystar</option>
                    <option value="Combo">Combo</option>
                    <option value="Comfortaa">Comfortaa</option>
                    <option value="Coming Soon">Coming Soon</option>
                    <option value="Concert One">Concert One</option>
                    <option value="Condiment">Condiment</option>
                    <option value="Content">Content</option>
                    <option value="Contrail One">Contrail One</option>
                    <option value="Convergence">Convergence</option>
                    <option value="Cookie">Cookie</option>
                    <option value="Copse">Copse</option>
                    <option value="Corben">Corben</option>
                    <option value="Courgette">Courgette</option>
                    <option value="Cousine">Cousine</option>
                    <option value="Coustard">Coustard</option>
                    <option value="Covered By Your Grace">Covered By Your Grace</option>
                    <option value="Crafty Girls">Crafty Girls</option>
                    <option value="Creepster">Creepster</option>
                    <option value="Crete Round">Crete Round</option>
                    <option value="Crimson Text">Crimson Text</option>
                    <option value="Croissant One">Croissant One</option>
                    <option value="Crushed">Crushed</option>
                    <option value="Cuprum">Cuprum</option>
                    <option value="Cutive">Cutive</option>
                    <option value="Cutive Mono">Cutive Mono</option>
                    <option value="Damion">Damion</option>
                    <option value="Dancing Script">Dancing Script</option>
                    <option value="Dangrek">Dangrek</option>
                    <option value="Dawning of a New Day">Dawning of a New Day</option>
                    <option value="Days One">Days One</option>
                    <option value="Dekko">Dekko</option>
                    <option value="Delius">Delius</option>
                    <option value="Delius Swash Caps">Delius Swash Caps</option>
                    <option value="Delius Unicase">Delius Unicase</option>
                    <option value="Della Respira">Della Respira</option>
                    <option value="Denk One">Denk One</option>
                    <option value="Devonshire">Devonshire</option>
                    <option value="Dhurjati">Dhurjati</option>
                    <option value="Didact Gothic">Didact Gothic</option>
                    <option value="Diplomata">Diplomata</option>
                    <option value="Diplomata SC">Diplomata SC</option>
                    <option value="Domine">Domine</option>
                    <option value="Donegal One">Donegal One</option>
                    <option value="Doppio One">Doppio One</option>
                    <option value="Dorsa">Dorsa</option>
                    <option value="Dosis">Dosis</option>
                    <option value="Dr Sugiyama">Dr Sugiyama</option>
                    <option value="Droid Sans">Droid Sans</option>
                    <option value="Droid Sans Mono">Droid Sans Mono</option>
                    <option value="Droid Serif">Droid Serif</option>
                    <option value="Duru Sans">Duru Sans</option>
                    <option value="Dynalight">Dynalight</option>
                    <option value="EB Garamond">EB Garamond</option>
                    <option value="Eagle Lake">Eagle Lake</option>
                    <option value="Eater">Eater</option>
                    <option value="Economica">Economica</option>
                    <option value="Eczar">Eczar</option>
                    <option value="Ek Mukta">Ek Mukta</option>
                    <option value="Electrolize">Electrolize</option>
                    <option value="Elsie">Elsie</option>
                    <option value="Elsie Swash Caps">Elsie Swash Caps</option>
                    <option value="Emblema One">Emblema One</option>
                    <option value="Emilys Candy">Emilys Candy</option>
                    <option value="Engagement">Engagement</option>
                    <option value="Englebert">Englebert</option>
                    <option value="Enriqueta">Enriqueta</option>
                    <option value="Erica One">Erica One</option>
                    <option value="Esteban">Esteban</option>
                    <option value="Euphoria Script">Euphoria Script</option>
                    <option value="Ewert">Ewert</option>
                    <option value="Exo">Exo</option>
                    <option value="Exo 2">Exo 2</option>
                    <option value="Expletus Sans">Expletus Sans</option>
                    <option value="Fanwood Text">Fanwood Text</option>
                    <option value="Fascinate">Fascinate</option>
                    <option value="Fascinate Inline">Fascinate Inline</option>
                    <option value="Faster One">Faster One</option>
                    <option value="Fasthand">Fasthand</option>
                    <option value="Fauna One">Fauna One</option>
                    <option value="Federant">Federant</option>
                    <option value="Federo">Federo</option>
                    <option value="Felipa">Felipa</option>
                    <option value="Fenix">Fenix</option>
                    <option value="Finger Paint">Finger Paint</option>
                    <option value="Fira Mono">Fira Mono</option>
                    <option value="Fira Sans">Fira Sans</option>
                    <option value="Fjalla One">Fjalla One</option>
                    <option value="Fjord One">Fjord One</option>
                    <option value="Flamenco">Flamenco</option>
                    <option value="Flavors">Flavors</option>
                    <option value="Fondamento">Fondamento</option>
                    <option value="Fontdiner Swanky">Fontdiner Swanky</option>
                    <option value="Forum">Forum</option>
                    <option value="Francois One">Francois One</option>
                    <option value="Freckle Face">Freckle Face</option>
                    <option value="Fredericka the Great">Fredericka the Great</option>
                    <option value="Fredoka One">Fredoka One</option>
                    <option value="Fresca">Fresca</option>
                    <option value="Frijole">Frijole</option>
                    <option value="Fruktur">Fruktur</option>
                    <option value="Fugaz One">Fugaz One</option>
                    <option value="Gabriela">Gabriela</option>
                    <option value="Gafata">Gafata</option>
                    <option value="Galdeano">Galdeano</option>
                    <option value="Galindo">Galindo</option>
                    <option value="Gentium Basic">Gentium Basic</option>
                    <option value="Gentium Book Basic">Gentium Book Basic</option>
                    <option value="Geo">Geo</option>
                    <option value="Geostar">Geostar</option>
                    <option value="Geostar Fill">Geostar Fill</option>
                    <option value="Germania One">Germania One</option>
                    <option value="Gidugu">Gidugu</option>
                    <option value="Gilda Display">Gilda Display</option>
                    <option value="Give You Glory">Give You Glory</option>
                    <option value="Glass Antiqua">Glass Antiqua</option>
                    <option value="Glegoo">Glegoo</option>
                    <option value="Gloria Hallelujah">Gloria Hallelujah</option>
                    <option value="Goblin One">Goblin One</option>
                    <option value="Gochi Hand">Gochi Hand</option>
                    <option value="Gorditas">Gorditas</option>
                    <option value="Graduate">Graduate</option>
                    <option value="Grand Hotel">Grand Hotel</option>
                    <option value="Gravitas One">Gravitas One</option>
                    <option value="Great Vibes">Great Vibes</option>
                    <option value="Griffy">Griffy</option>
                    <option value="Gruppo">Gruppo</option>
                    <option value="Gudea">Gudea</option>
                    <option value="Gurajada">Gurajada</option>
                    <option value="Habibi">Habibi</option>
                    <option value="Halant">Halant</option>
                    <option value="Hammersmith One">Hammersmith One</option>
                    <option value="Hanalei">Hanalei</option>
                    <option value="Hanalei Fill">Hanalei Fill</option>
                    <option value="Handlee">Handlee</option>
                    <option value="Hanuman">Hanuman</option>
                    <option value="Happy Monkey">Happy Monkey</option>
                    <option value="Headland One">Headland One</option>
                    <option value="Henny Penny">Henny Penny</option>
                    <option value="Herr Von Muellerhoff">Herr Von Muellerhoff</option>
                    <option value="Hind">Hind</option>
                    <option value="Hind Siliguri">Hind Siliguri</option>
                    <option value="Hind Vadodara">Hind Vadodara</option>
                    <option value="Holtwood One SC">Holtwood One SC</option>
                    <option value="Homemade Apple">Homemade Apple</option>
                    <option value="Homenaje">Homenaje</option>
                    <option value="IM Fell DW Pica">IM Fell DW Pica</option>
                    <option value="IM Fell DW Pica SC">IM Fell DW Pica SC</option>
                    <option value="IM Fell Double Pica">IM Fell Double Pica</option>
                    <option value="IM Fell Double Pica SC">IM Fell Double Pica SC</option>
                    <option value="IM Fell English">IM Fell English</option>
                    <option value="IM Fell English SC">IM Fell English SC</option>
                    <option value="IM Fell French Canon">IM Fell French Canon</option>
                    <option value="IM Fell French Canon SC">IM Fell French Canon SC</option>
                    <option value="IM Fell Great Primer">IM Fell Great Primer</option>
                    <option value="IM Fell Great Primer SC">IM Fell Great Primer SC</option>
                    <option value="Iceberg">Iceberg</option>
                    <option value="Iceland">Iceland</option>
                    <option value="Imprima">Imprima</option>
                    <option value="Inconsolata">Inconsolata</option>
                    <option value="Inder">Inder</option>
                    <option value="Indie Flower">Indie Flower</option>
                    <option value="Inika">Inika</option>
                    <option value="Inknut Antiqua">Inknut Antiqua</option>
                    <option value="Irish Grover">Irish Grover</option>
                    <option value="Istok Web">Istok Web</option>
                    <option value="Italiana">Italiana</option>
                    <option value="Italianno">Italianno</option>
                    <option value="Itim">Itim</option>
                    <option value="Jacques Francois">Jacques Francois</option>
                    <option value="Jacques Francois Shadow">Jacques Francois Shadow</option>
                    <option value="Jaldi">Jaldi</option>
                    <option value="Jim Nightshade">Jim Nightshade</option>
                    <option value="Jockey One">Jockey One</option>
                    <option value="Jolly Lodger">Jolly Lodger</option>
                    <option value="Josefin Sans">Josefin Sans</option>
                    <option value="Josefin Slab">Josefin Slab</option>
                    <option value="Joti One">Joti One</option>
                    <option value="Judson">Judson</option>
                    <option value="Julee">Julee</option>
                    <option value="Julius Sans One">Julius Sans One</option>
                    <option value="Junge">Junge</option>
                    <option value="Jura">Jura</option>
                    <option value="Just Another Hand">Just Another Hand</option>
                    <option value="Just Me Again Down Here">Just Me Again Down Here</option>
                    <option value="Kadwa">Kadwa</option>
                    <option value="Kalam">Kalam</option>
                    <option value="Kameron">Kameron</option>
                    <option value="Kantumruy">Kantumruy</option>
                    <option value="Karla">Karla</option>
                    <option value="Karma">Karma</option>
                    <option value="Kaushan Script">Kaushan Script</option>
                    <option value="Kavoon">Kavoon</option>
                    <option value="Kdam Thmor">Kdam Thmor</option>
                    <option value="Keania One">Keania One</option>
                    <option value="Kelly Slab">Kelly Slab</option>
                    <option value="Kenia">Kenia</option>
                    <option value="Khand">Khand</option>
                    <option value="Khmer">Khmer</option>
                    <option value="Khula">Khula</option>
                    <option value="Kite One">Kite One</option>
                    <option value="Knewave">Knewave</option>
                    <option value="Kotta One">Kotta One</option>
                    <option value="Koulen">Koulen</option>
                    <option value="Kranky">Kranky</option>
                    <option value="Kreon">Kreon</option>
                    <option value="Kristi">Kristi</option>
                    <option value="Krona One">Krona One</option>
                    <option value="Kurale">Kurale</option>
                    <option value="La Belle Aurore">La Belle Aurore</option>
                    <option value="Laila">Laila</option>
                    <option value="Lakki Reddy">Lakki Reddy</option>
                    <option value="Lancelot">Lancelot</option>
                    <option value="Lateef">Lateef</option>
                    <option value="Lato">Lato</option>
                    <option value="League Script">League Script</option>
                    <option value="Leckerli One">Leckerli One</option>
                    <option value="Ledger">Ledger</option>
                    <option value="Lekton">Lekton</option>
                    <option value="Lemon">Lemon</option>
                    <option value="Libre Baskerville">Libre Baskerville</option>
                    <option value="Life Savers">Life Savers</option>
                    <option value="Lilita One">Lilita One</option>
                    <option value="Lily Script One">Lily Script One</option>
                    <option value="Limelight">Limelight</option>
                    <option value="Linden Hill">Linden Hill</option>
                    <option value="Lobster">Lobster</option>
                    <option value="Lobster Two">Lobster Two</option>
                    <option value="Londrina Outline">Londrina Outline</option>
                    <option value="Londrina Shadow">Londrina Shadow</option>
                    <option value="Londrina Sketch">Londrina Sketch</option>
                    <option value="Londrina Solid">Londrina Solid</option>
                    <option value="Lora">Lora</option>
                    <option value="Love Ya Like A Sister">Love Ya Like A Sister</option>
                    <option value="Loved by the King">Loved by the King</option>
                    <option value="Lovers Quarrel">Lovers Quarrel</option>
                    <option value="Luckiest Guy">Luckiest Guy</option>
                    <option value="Lusitana">Lusitana</option>
                    <option value="Lustria">Lustria</option>
                    <option value="Macondo">Macondo</option>
                    <option value="Macondo Swash Caps">Macondo Swash Caps</option>
                    <option value="Magra">Magra</option>
                    <option value="Maiden Orange">Maiden Orange</option>
                    <option value="Mako">Mako</option>
                    <option value="Mallanna">Mallanna</option>
                    <option value="Mandali">Mandali</option>
                    <option value="Marcellus">Marcellus</option>
                    <option value="Marcellus SC">Marcellus SC</option>
                    <option value="Marck Script">Marck Script</option>
                    <option value="Margarine">Margarine</option>
                    <option value="Marko One">Marko One</option>
                    <option value="Marmelad">Marmelad</option>
                    <option value="Martel">Martel</option>
                    <option value="Martel Sans">Martel Sans</option>
                    <option value="Marvel">Marvel</option>
                    <option value="Mate">Mate</option>
                    <option value="Mate SC">Mate SC</option>
                    <option value="Maven Pro">Maven Pro</option>
                    <option value="McLaren">McLaren</option>
                    <option value="Meddon">Meddon</option>
                    <option value="MedievalSharp">MedievalSharp</option>
                    <option value="Medula One">Medula One</option>
                    <option value="Megrim">Megrim</option>
                    <option value="Meie Script">Meie Script</option>
                    <option value="Merienda">Merienda</option>
                    <option value="Merienda One">Merienda One</option>
                    <option value="Merriweather">Merriweather</option>
                    <option value="Merriweather Sans">Merriweather Sans</option>
                    <option value="Metal">Metal</option>
                    <option value="Metal Mania">Metal Mania</option>
                    <option value="Metamorphous">Metamorphous</option>
                    <option value="Metrophobic">Metrophobic</option>
                    <option value="Michroma">Michroma</option>
                    <option value="Milonga">Milonga</option>
                    <option value="Miltonian">Miltonian</option>
                    <option value="Miltonian Tattoo">Miltonian Tattoo</option>
                    <option value="Miniver">Miniver</option>
                    <option value="Miss Fajardose">Miss Fajardose</option>
                    <option value="Modak">Modak</option>
                    <option value="Modern Antiqua">Modern Antiqua</option>
                    <option value="Molengo">Molengo</option>
                    <option value="Molle">Molle</option>
                    <option value="Monda">Monda</option>
                    <option value="Monofett">Monofett</option>
                    <option value="Monoton">Monoton</option>
                    <option value="Monsieur La Doulaise">Monsieur La Doulaise</option>
                    <option value="Montaga">Montaga</option>
                    <option value="Montez">Montez</option>
                    <option value="Montserrat">Montserrat</option>
                    <option value="Montserrat Alternates">Montserrat Alternates</option>
                    <option value="Montserrat Subrayada">Montserrat Subrayada</option>
                    <option value="Moul">Moul</option>
                    <option value="Moulpali">Moulpali</option>
                    <option value="Mountains of Christmas">Mountains of Christmas</option>
                    <option value="Mouse Memoirs">Mouse Memoirs</option>
                    <option value="Mr Bedfort">Mr Bedfort</option>
                    <option value="Mr Dafoe">Mr Dafoe</option>
                    <option value="Mr De Haviland">Mr De Haviland</option>
                    <option value="Mrs Saint Delafield">Mrs Saint Delafield</option>
                    <option value="Mrs Sheppards">Mrs Sheppards</option>
                    <option value="Muli">Muli</option>
                    <option value="Mystery Quest">Mystery Quest</option>
                    <option value="NTR">NTR</option>
                    <option value="Neucha">Neucha</option>
                    <option value="Neuton">Neuton</option>
                    <option value="New Rocker">New Rocker</option>
                    <option value="News Cycle">News Cycle</option>
                    <option value="Niconne">Niconne</option>
                    <option value="Nixie One">Nixie One</option>
                    <option value="Nobile">Nobile</option>
                    <option value="Nokora">Nokora</option>
                    <option value="Norican">Norican</option>
                    <option value="Nosifer">Nosifer</option>
                    <option value="Nothing You Could Do">Nothing You Could Do</option>
                    <option value="Noticia Text">Noticia Text</option>
                    <option value="Noto Sans">Noto Sans</option>
                    <option value="Noto Serif">Noto Serif</option>
                    <option value="Nova Cut">Nova Cut</option>
                    <option value="Nova Flat">Nova Flat</option>
                    <option value="Nova Mono">Nova Mono</option>
                    <option value="Nova Oval">Nova Oval</option>
                    <option value="Nova Round">Nova Round</option>
                    <option value="Nova Script">Nova Script</option>
                    <option value="Nova Slim">Nova Slim</option>
                    <option value="Nova Square">Nova Square</option>
                    <option value="Numans">Numans</option>
                    <option value="Nunito">Nunito</option>
                    <option value="Odor Mean Chey">Odor Mean Chey</option>
                    <option value="Offside">Offside</option>
                    <option value="Old Standard TT">Old Standard TT</option>
                    <option value="Oldenburg">Oldenburg</option>
                    <option value="Oleo Script">Oleo Script</option>
                    <option value="Oleo Script Swash Caps">Oleo Script Swash Caps</option>
                    <option value="Open Sans">Open Sans</option>
                    <option value="Open Sans Condensed">Open Sans Condensed</option>
                    <option value="Oranienbaum">Oranienbaum</option>
                    <option value="Orbitron">Orbitron</option>
                    <option value="Oregano">Oregano</option>
                    <option value="Orienta">Orienta</option>
                    <option value="Original Surfer">Original Surfer</option>
                    <option value="Oswald">Oswald</option>
                    <option value="Over the Rainbow">Over the Rainbow</option>
                    <option value="Overlock">Overlock</option>
                    <option value="Overlock SC">Overlock SC</option>
                    <option value="Ovo">Ovo</option>
                    <option value="Oxygen">Oxygen</option>
                    <option value="Oxygen Mono">Oxygen Mono</option>
                    <option value="PT Mono">PT Mono</option>
                    <option value="PT Sans">PT Sans</option>
                    <option value="PT Sans Caption">PT Sans Caption</option>
                    <option value="PT Sans Narrow">PT Sans Narrow</option>
                    <option value="PT Serif">PT Serif</option>
                    <option value="PT Serif Caption">PT Serif Caption</option>
                    <option value="Pacifico">Pacifico</option>
                    <option value="Palanquin">Palanquin</option>
                    <option value="Palanquin Dark">Palanquin Dark</option>
                    <option value="Paprika">Paprika</option>
                    <option value="Parisienne">Parisienne</option>
                    <option value="Passero One">Passero One</option>
                    <option value="Passion One">Passion One</option>
                    <option value="Pathway Gothic One">Pathway Gothic One</option>
                    <option value="Patrick Hand">Patrick Hand</option>
                    <option value="Patrick Hand SC">Patrick Hand SC</option>
                    <option value="Patua One">Patua One</option>
                    <option value="Paytone One">Paytone One</option>
                    <option value="Peddana">Peddana</option>
                    <option value="Peralta">Peralta</option>
                    <option value="Permanent Marker">Permanent Marker</option>
                    <option value="Petit Formal Script">Petit Formal Script</option>
                    <option value="Petrona">Petrona</option>
                    <option value="Philosopher">Philosopher</option>
                    <option value="Piedra">Piedra</option>
                    <option value="Pinyon Script">Pinyon Script</option>
                    <option value="Pirata One">Pirata One</option>
                    <option value="Plaster">Plaster</option>
                    <option value="Play">Play</option>
                    <option value="Playball">Playball</option>
                    <option value="Playfair Display">Playfair Display</option>
                    <option value="Playfair Display SC">Playfair Display SC</option>
                    <option value="Podkova">Podkova</option>
                    <option value="Poiret One">Poiret One</option>
                    <option value="Poller One">Poller One</option>
                    <option value="Poly">Poly</option>
                    <option value="Pompiere">Pompiere</option>
                    <option value="Pontano Sans">Pontano Sans</option>
                    <option value="Poppins">Poppins</option>
                    <option value="Port Lligat Sans">Port Lligat Sans</option>
                    <option value="Port Lligat Slab">Port Lligat Slab</option>
                    <option value="Pragati Narrow">Pragati Narrow</option>
                    <option value="Prata">Prata</option>
                    <option value="Preahvihear">Preahvihear</option>
                    <option value="Press Start 2P">Press Start 2P</option>
                    <option value="Princess Sofia">Princess Sofia</option>
                    <option value="Prociono">Prociono</option>
                    <option value="Prosto One">Prosto One</option>
                    <option value="Puritan">Puritan</option>
                    <option value="Purple Purse">Purple Purse</option>
                    <option value="Quando">Quando</option>
                    <option value="Quantico">Quantico</option>
                    <option value="Quattrocento">Quattrocento</option>
                    <option value="Quattrocento Sans">Quattrocento Sans</option>
                    <option value="Questrial">Questrial</option>
                    <option value="Quicksand">Quicksand</option>
                    <option value="Quintessential">Quintessential</option>
                    <option value="Qwigley">Qwigley</option>
                    <option value="Racing Sans One">Racing Sans One</option>
                    <option value="Radley">Radley</option>
                    <option value="Rajdhani">Rajdhani</option>
                    <option value="Raleway">Raleway</option>
                    <option value="Raleway Dots">Raleway Dots</option>
                    <option value="Ramabhadra">Ramabhadra</option>
                    <option value="Ramaraja">Ramaraja</option>
                    <option value="Rambla">Rambla</option>
                    <option value="Rammetto One">Rammetto One</option>
                    <option value="Ranchers">Ranchers</option>
                    <option value="Rancho">Rancho</option>
                    <option value="Ranga">Ranga</option>
                    <option value="Rationale">Rationale</option>
                    <option value="Ravi Prakash">Ravi Prakash</option>
                    <option value="Redressed">Redressed</option>
                    <option value="Reenie Beanie">Reenie Beanie</option>
                    <option value="Revalia">Revalia</option>
                    <option value="Rhodium Libre">Rhodium Libre</option>
                    <option value="Ribeye">Ribeye</option>
                    <option value="Ribeye Marrow">Ribeye Marrow</option>
                    <option value="Righteous">Righteous</option>
                    <option value="Risque">Risque</option>
                    <option value="Roboto">Roboto</option>
                    <option value="Roboto Condensed">Roboto Condensed</option>
                    <option value="Roboto Mono">Roboto Mono</option>
                    <option value="Roboto Slab">Roboto Slab</option>
                    <option value="Rochester">Rochester</option>
                    <option value="Rock Salt">Rock Salt</option>
                    <option value="Rokkitt">Rokkitt</option>
                    <option value="Romanesco">Romanesco</option>
                    <option value="Ropa Sans">Ropa Sans</option>
                    <option value="Rosario">Rosario</option>
                    <option value="Rosarivo">Rosarivo</option>
                    <option value="Rouge Script">Rouge Script</option>
                    <option value="Rozha One">Rozha One</option>
                    <option value="Rubik">Rubik</option>
                    <option value="Rubik Mono One">Rubik Mono One</option>
                    <option value="Rubik One">Rubik One</option>
                    <option value="Ruda">Ruda</option>
                    <option value="Rufina">Rufina</option>
                    <option value="Ruge Boogie">Ruge Boogie</option>
                    <option value="Ruluko">Ruluko</option>
                    <option value="Rum Raisin">Rum Raisin</option>
                    <option value="Ruslan Display">Ruslan Display</option>
                    <option value="Russo One">Russo One</option>
                    <option value="Ruthie">Ruthie</option>
                    <option value="Rye">Rye</option>
                    <option value="Sacramento">Sacramento</option>
                    <option value="Sahitya">Sahitya</option>
                    <option value="Sail">Sail</option>
                    <option value="Salsa">Salsa</option>
                    <option value="Sanchez">Sanchez</option>
                    <option value="Sancreek">Sancreek</option>
                    <option value="Sansita One">Sansita One</option>
                    <option value="Sarala">Sarala</option>
                    <option value="Sarina">Sarina</option>
                    <option value="Sarpanch">Sarpanch</option>
                    <option value="Satisfy">Satisfy</option>
                    <option value="Scada">Scada</option>
                    <option value="Scheherazade">Scheherazade</option>
                    <option value="Schoolbell">Schoolbell</option>
                    <option value="Seaweed Script">Seaweed Script</option>
                    <option value="Sevillana">Sevillana</option>
                    <option value="Seymour One">Seymour One</option>
                    <option value="Shadows Into Light">Shadows Into Light</option>
                    <option value="Shadows Into Light Two">Shadows Into Light Two</option>
                    <option value="Shanti">Shanti</option>
                    <option value="Share">Share</option>
                    <option value="Share Tech">Share Tech</option>
                    <option value="Share Tech Mono">Share Tech Mono</option>
                    <option value="Shojumaru">Shojumaru</option>
                    <option value="Short Stack">Short Stack</option>
                    <option value="Siemreap">Siemreap</option>
                    <option value="Sigmar One">Sigmar One</option>
                    <option value="Signika">Signika</option>
                    <option value="Signika Negative">Signika Negative</option>
                    <option value="Simonetta">Simonetta</option>
                    <option value="Sintony">Sintony</option>
                    <option value="Sirin Stencil">Sirin Stencil</option>
                    <option value="Six Caps">Six Caps</option>
                    <option value="Skranji">Skranji</option>
                    <option value="Slabo 13px">Slabo 13px</option>
                    <option value="Slabo 27px">Slabo 27px</option>
                    <option value="Slackey">Slackey</option>
                    <option value="Smokum">Smokum</option>
                    <option value="Smythe">Smythe</option>
                    <option value="Sniglet">Sniglet</option>
                    <option value="Snippet">Snippet</option>
                    <option value="Snowburst One">Snowburst One</option>
                    <option value="Sofadi One">Sofadi One</option>
                    <option value="Sofia">Sofia</option>
                    <option value="Sonsie One">Sonsie One</option>
                    <option value="Sorts Mill Goudy">Sorts Mill Goudy</option>
                    <option value="Source Code Pro">Source Code Pro</option>
                    <option value="Source Sans Pro">Source Sans Pro</option>
                    <option value="Source Serif Pro">Source Serif Pro</option>
                    <option value="Special Elite">Special Elite</option>
                    <option value="Spicy Rice">Spicy Rice</option>
                    <option value="Spinnaker">Spinnaker</option>
                    <option value="Spirax">Spirax</option>
                    <option value="Squada One">Squada One</option>
                    <option value="Sree Krushnadevaraya">Sree Krushnadevaraya</option>
                    <option value="Stalemate">Stalemate</option>
                    <option value="Stalinist One">Stalinist One</option>
                    <option value="Stardos Stencil">Stardos Stencil</option>
                    <option value="Stint Ultra Condensed">Stint Ultra Condensed</option>
                    <option value="Stint Ultra Expanded">Stint Ultra Expanded</option>
                    <option value="Stoke">Stoke</option>
                    <option value="Strait">Strait</option>
                    <option value="Sue Ellen Francisco">Sue Ellen Francisco</option>
                    <option value="Sumana">Sumana</option>
                    <option value="Sunshiney">Sunshiney</option>
                    <option value="Supermercado One">Supermercado One</option>
                    <option value="Sura">Sura</option>
                    <option value="Suranna">Suranna</option>
                    <option value="Suravaram">Suravaram</option>
                    <option value="Suwannaphum">Suwannaphum</option>
                    <option value="Swanky and Moo Moo">Swanky and Moo Moo</option>
                    <option value="Syncopate">Syncopate</option>
                    <option value="Tangerine">Tangerine</option>
                    <option value="Taprom">Taprom</option>
                    <option value="Tauri">Tauri</option>
                    <option value="Teko">Teko</option>
                    <option value="Telex">Telex</option>
                    <option value="Tenali Ramakrishna">Tenali Ramakrishna</option>
                    <option value="Tenor Sans">Tenor Sans</option>
                    <option value="Text Me One">Text Me One</option>
                    <option value="The Girl Next Door">The Girl Next Door</option>
                    <option value="Tienne">Tienne</option>
                    <option value="Tillana">Tillana</option>
                    <option value="Timmana">Timmana</option>
                    <option value="Tinos">Tinos</option>
                    <option value="Titan One">Titan One</option>
                    <option value="Titillium Web">Titillium Web</option>
                    <option value="Trade Winds">Trade Winds</option>
                    <option value="Trocchi">Trocchi</option>
                    <option value="Trochut">Trochut</option>
                    <option value="Trykker">Trykker</option>
                    <option value="Tulpen One">Tulpen One</option>
                    <option value="Ubuntu">Ubuntu</option>
                    <option value="Ubuntu Condensed">Ubuntu Condensed</option>
                    <option value="Ubuntu Mono">Ubuntu Mono</option>
                    <option value="Ultra">Ultra</option>
                    <option value="Uncial Antiqua">Uncial Antiqua</option>
                    <option value="Underdog">Underdog</option>
                    <option value="Unica One">Unica One</option>
                    <option value="UnifrakturCook">UnifrakturCook</option>
                    <option value="UnifrakturMaguntia">UnifrakturMaguntia</option>
                    <option value="Unkempt">Unkempt</option>
                    <option value="Unlock">Unlock</option>
                    <option value="Unna">Unna</option>
                    <option value="VT323">VT323</option>
                    <option value="Vampiro One">Vampiro One</option>
                    <option value="Varela">Varela</option>
                    <option value="Varela Round">Varela Round</option>
                    <option value="Vast Shadow">Vast Shadow</option>
                    <option value="Vesper Libre">Vesper Libre</option>
                    <option value="Vibur">Vibur</option>
                    <option value="Vidaloka">Vidaloka</option>
                    <option value="Viga">Viga</option>
                    <option value="Voces">Voces</option>
                    <option value="Volkhov">Volkhov</option>
                    <option value="Vollkorn">Vollkorn</option>
                    <option value="Voltaire">Voltaire</option>
                    <option value="Waiting for the Sunrise">Waiting for the Sunrise</option>
                    <option value="Wallpoet">Wallpoet</option>
                    <option value="Walter Turncoat">Walter Turncoat</option>
                    <option value="Warnes">Warnes</option>
                    <option value="Wellfleet">Wellfleet</option>
                    <option value="Wendy One">Wendy One</option>
                    <option value="Wire One">Wire One</option>
                    <option value="Work Sans">Work Sans</option>
                    <option value="Yanone Kaffeesatz">Yanone Kaffeesatz</option>
                    <option value="Yantramanav">Yantramanav</option>
                    <option value="Yellowtail">Yellowtail</option>
                    <option value="Yeseva One">Yeseva One</option>
                    <option value="Yesteryear">Yesteryear</option>
                    <option value="Zeyada">Zeyada</option>
                </select>
         </div>
      </div>
      <div id="tab6" class="tab">
         <h2>Import/Export</h2>
         <h4>Import</h4>
         <textarea id="ImportSettings" rows="6" cols="50"></textarea>
         <h4>Export</h4>
         <textarea id="ExportSettings" rows="6" cols="50"></textarea>
         <button id="CopyButton">Copy</button>
      </div>
   </div>
   <div>
      <table id="SettingsFooter">
         <tr>
            <td><a id="SubmitBug" title="Submit a bug" href="https://greasyfork.org/en/forum/post/discussion?script=29660"><img src=""></a></td>
         </tr>
      </table>
   </div>
</div>
`);


    $("#GoogleBar").append('<div class="dropdown"><button class="GoogleBarDropDownButton">More ▾</button><div class="dropdown-content"></div></div>');
    $("#GoogleBar").append('<div id="GearIcon">⚙</div>');
    GenerateBarLinksFromGetValues();
    GenerateBarMenuLinksFromGetValues();
    GenerateExportSettings();
    GenerateSetBarLinkInput();
    GenerateSetBarMenuLinkInputBoxes();
    addGoogleFont(GM_getValue("GB_Font"));
    $("#GoogleBar a,.GoogleBarDropDownButton").css("font-family", GM_getValue("GB_Font"));

}

CreateGoogleBar();

    $(document).ready(function() {

    var allowedKeys = {37: 'left',38: 'up',39: 'right',40: 'down',65: 'a',66: 'b'};
    var konamiCode = ['up', 'up', 'down', 'down', 'left', 'right', 'left', 'right', 'b', 'a'];
    var konamiCodePosition = 0;                          // a variable to remember the 'position' the user has reached so far.
    document.addEventListener('keydown', function(e) {   // add keydown event listener
        var key = allowedKeys[e.keyCode];                // get the value of the key code from the key map
        var requiredKey = konamiCode[konamiCodePosition];// get the value of the required key from the konami code
        if (key == requiredKey) {                        // compare the key with the required key
            konamiCodePosition++;                        // move to the next key in the konami code sequence
            if (konamiCodePosition == konamiCode.length) // if the last key is reached, activate cheats
                activateCheats();
        } else
            konamiCodePosition = 0;
    });
    function activateCheats() {
        var OneUpAudio = new Audio('http://themushroomkingdom.net/sounds/wav/smw/smw_1-up.wav');
        OneUpAudio.play();
        OneUpAudio.addEventListener('ended', function() {
            this.currentTime = 0;
            this.play();
        }, false);
    }

    $('[name=GoogleBarFont]').val(GM_getValue("GB_Font"));

    RandomizeBarColor();

    if (vRandomColorMode === "1") {
        var ColorCycleFunction = setInterval(RandomizeBarColor, vColCycleDuration);
    }

        $('[name=GBMenuDisplay]').change(function() {
            var c = this.checked ? GM_setValue("GB_MenuDisplay", "0") : GM_setValue("GB_MenuDisplay", "1");
            if (GM_getValue("GB_MenuDisplay") === "0") {
                $(".dropdown").css("display", "none");
            } else if (GM_getValue("GB_MenuDisplay") === "1") {
                $(".dropdown").css("display", "inline-block");
            }
            GenerateExportSettings();
        });


        $('#GBColRand').change(function() {
            var c = this.checked ? GM_setValue("GB_RandCol", "1") : GM_setValue("GB_RandCol", "0");
            if (GM_getValue("GB_RandCol") === "1") {
                RandomizeBarColor();
                ColorCycleFunction = setInterval(RandomizeBarColor, vColCycleDuration);
                GM_addStyle(`#GoogleBar a,#GearIcon,.GoogleBarDropDownButton{
                             color:` + GM_getValue('GB_LColor') + `;
                             ms-transition:color ` + vColCycleDuration + `ms linear;
                             transition:color ` + vColCycleDuration + `ms linear;
                             webkit-transition:color ` + vColCycleDuration + `ms linear;}
                             #GoogleBar,.dropdown-content{
                             background-color:` + GM_getValue('GB_BGColor') + `;
                             ms-transition:background-color ` + vColCycleDuration + `ms linear;
                             transition:background-color ` + vColCycleDuration + `ms linear;
                             webkit-transition:background-color ` + vColCycleDuration + `ms linear;`);
            }
                else {
                $(".GBLinkBlock,.dropdown-content a,.GoogleBarDropDownButton").hover(function(e) {
                    $(this).css("background-color", e.type === "mouseenter" ? shadeColor(GM_getValue("GB_BGColor"), parseInt(GM_getValue("GB_Hover"))) : "transparent")
                });
                $('#GoogleBar a,#GearIcon,.GoogleBarDropDownButton').css("color", GM_getValue('GB_LColor'));

                $('#GoogleBar,.dropdown-content').css("background-color", GM_getValue('GB_BGColor'));

                GM_addStyle(`#GoogleBar a,#GearIcon,.GoogleBarDropDownButton{
                              color:` + GM_getValue('GB_LColor') + `;
                              ms-transition:color 333ms linear;
                              transition:color 333ms linear;
                              webkit-transition:color 333ms linear;}
                              #GoogleBar,.dropdown-content{
                              background-color:` + GM_getValue('GB_BGColor') + `;
                              ms-transition:background-color 333ms linear;
                              transition:background-color 333ms linear;
                              webkit-transition:background-color 333ms linear;}`);
            }
                GenerateExportSettings();
        });

        $('input[type=radio][name=group-one]').change(function() {
            if (this.value === "1") {
                GM_setValue('GB_LColMode', "1");
                GM_setValue('GB_LColor', invertColor(GM_getValue('GB_BGColor'), ""));
                GM_setValue('GB_BGColor', color.toHexString());
                GenerateExportSettings();
                $('#GoogleBar a,#GearIcon,.GoogleBarDropDownButton').css("color", invertColor(GM_getValue('GB_BGColor'), ""));
                $('#GoogleBar,.dropdown-content').css("background-color", color.toHexString());
            } else if (this.value === "2") {
                GM_setValue('GB_LColMode', "2");
                GM_setValue('GB_LColor', invertColor(GM_getValue('GB_BGColor'), "BW"));
                GM_setValue('GB_BGColor', color.toHexString());
                GenerateExportSettings();
                $('#GoogleBar a,#GearIcon,.GoogleBarDropDownButton').css("color", invertColor(GM_getValue('GB_BGColor'), "BW"));
                $('#GoogleBar,.dropdown-content').css("background-color", color.toHexString());
            } else if (this.value === "3") {
                GM_setValue('GB_LColMode', "3");
                GenerateExportSettings();
            }

        });

        $('input[type=number][name=BarLinkNumberInput]').bind('keyup input', function() {
            GM_setValue("GB_TotalBarLinks", this.value);
            DestroyAndCreateBarLinksAndSettingInput();
            GenerateExportSettings();
        });

        $('input[type=number][name=vColCycleDuration]').bind('keyup input', function() {
            GM_setValue("GB_ColorCycleDuration;", this.value);
            clearTimeout(ColorCycleFunction);
            vColCycleDuration = this.value;
            ColorCycleFunction = setInterval(RandomizeBarColor, vColCycleDuration);

            if (vRandomColorMode === "1") {
                GM_addStyle(`#GoogleBar a,#GearIcon,.GoogleBarDropDownButton{
                             color:` + GM_getValue('GB_LColor') + `!important;
                             ms-transition:color ` + vColCycleDuration + `ms linear;
                             transition:color ` + vColCycleDuration + `ms linear;
                             webkit-transition:color ` + vColCycleDuration + `ms linear;}
                             #GoogleBar,.dropdown-content{
                             background-color:` + GM_getValue('GB_BGColor') + `;
                             ms-transition:background-color ` + vColCycleDuration + `ms linear;
                             transition:background-color ` + vColCycleDuration + `ms linear;
                             webkit-transition:background-color ` + vColCycleDuration + `ms linear;}`);
            }
            GenerateExportSettings();
        });

        $('input[type=number][name=BarMenuNumberInput]').bind('keyup input', function() {
            GM_setValue("GB_TotalBarMenuLinks", this.value);
DestroyAndCreateMoreLinksAndSettingInput();
            GenerateExportSettings();
        });


        $('[name=StickyCheckBox]').change(function() {
            var c = this.checked ? GM_setValue("GB_Pos", "fixed") : GM_setValue("GB_Pos", "absolute");
            if (GM_getValue("GB_Pos") === "fixed") {
                GM_setValue('GB_Pos', "fixed");
            } else {
                GM_setValue('GB_Pos', "absolute");

            }
            $('#GoogleBar').css("position", GM_getValue("GB_Pos"));
            GenerateExportSettings();
        });


        $('[name=GoogleBarFont]').change(function() {
            var fontID = $('[name=GoogleBarFont]').find(":selected").text();
            GM_setValue("GB_Font", fontID);
            addGoogleFont(fontID);
            $("#GoogleBar a,.GoogleBarDropDownButton").css("font-family", fontID);
            GenerateExportSettings();
        });




 $('#ImportSettings').on('input',function(e){
 var ImportedSettings =  $('#ImportSettings').val();
 if (ImportedSettings.startsWith("|===============Google Bar===============|")){
var ImportedRow = ImportedSettings.split(/\r?\n/);
var ImportedBarSettings=ImportedRow[1];
var ImportedBarSettingsCell = ImportedBarSettings.split("|");
GM_setValue("GB_BGColor",ImportedBarSettingsCell[0]);
GM_setValue("GB_BColor",ImportedBarSettingsCell[1]);
GM_setValue("GB_LColor",ImportedBarSettingsCell[2]);
GM_setValue("GB_Pos",ImportedBarSettingsCell[3]);
GM_setValue("GB_TotalBarLinks",ImportedBarSettingsCell[4]);
GM_setValue("GB_TotalBarMenuLinks",ImportedBarSettingsCell[5]);
GM_setValue("GB_LColMode",ImportedBarSettingsCell[6]);
GM_setValue("GB_RandCol",ImportedBarSettingsCell[7]);
GM_setValue("GB_MenuDisplay",ImportedBarSettingsCell[8]);
GM_setValue("GB_Font",ImportedBarSettingsCell[9]);
GM_setValue("GB_ColorCycleDuration",ImportedBarSettingsCell[10]);




$('#GoogleBar,.dropdown-content').css("background-color", ImportedBarSettingsCell[0]);
                $(".GBLinkBlock,.dropdown-content a,.GoogleBarDropDownButton").hover(function(e) {
                    $(this).css("background-color", e.type === "mouseenter" ? shadeColor(GM_getValue("GB_BGColor"), parseInt(GM_getValue("GB_Hover"))) : "transparent")
                });
$('.GBLinkActive').css("borderTop", "2px solid " + ImportedBarSettingsCell[1]);
$(".GBLinkBlock").hover(function(e) {$(this).css("borderTop", e.type === "mouseenter" ? "2px solid " + ImportedBarSettingsCell[1] : "2px solid transparent")});
                $('#GoogleBar a,#GearIcon,.GoogleBarDropDownButton').css("color", ImportedBarSettingsCell[2]);
$('#GoogleBar').css("position", ImportedBarSettingsCell[3]);
   if (ImportedBarSettingsCell[7] === "1") {
                RandomizeBarColor();
                ColorCycleFunction = setInterval(RandomizeBarColor, ImportedBarSettingsCell[10]);
                GM_addStyle(`#GoogleBar a,#GearIcon,.GoogleBarDropDownButton{ms-transition:color ` + ImportedBarSettingsCell[10] + `ms linear;
                             transition:color ` + ImportedBarSettingsCell[10] + `ms linear;
                             webkit-transition:color ` + ImportedBarSettingsCell[10] + `ms linear;}
                             #GoogleBar,.dropdown-content{ms-transition:background-color ` + ImportedBarSettingsCell[10] + `ms linear;
                             transition:background-color ` + ImportedBarSettingsCell[10] + `ms linear;
                             webkit-transition:background-color ` + ImportedBarSettingsCell[10] + `ms linear;`);
            }else{
                              GM_addStyle(`#GoogleBar a,#GearIcon,.GoogleBarDropDownButton{ms-transition:color 400ms linear;
                             transition:color 400ms linear;
                             webkit-transition:color 400ms linear;}
                             #GoogleBar,.dropdown-content{ms-transition:background-color 400ms linear;
                             transition:background-color 400ms linear;
                             webkit-transition:background-color 400ms linear;`);  
            }

            DestroyAndCreateBarLinksAndSettingInput();
            DestroyAndCreateMoreLinksAndSettingInput();
}
                 GenerateExportSettings();
    });


        if (vLinkColorMode === "1") {
            $("#ICol").prop("checked", true)
        } else if (vLinkColorMode === "2") {
            $("#BWCol").prop("checked", true)
        } else if (vLinkColorMode === "3") {
            $("#HPcol").prop("checked", true)
        }


        if (vBarPosition === "fixed") {
            $("#GBPosA").prop("checked", true)
        }


        $("#GBarColorPicker").spectrum({
            flat: true,
            color: GM_getValue('GB_BGColor'),
            showPalette: false,
            showButtons: false,
            containerClassName: 'GBBGCP',
            move: function(color) {;
                var vLinkColorMode = GM_getValue('GB_LColMode')
                $(".GBLinkBlock,.dropdown-content a,.GoogleBarDropDownButton").hover(function(e) {
                    $(this).css("background-color", e.type === "mouseenter" ? shadeColor(GM_getValue("GB_BGColor"), parseInt(GM_getValue("GB_Hover"))) : "transparent")
                });
                if (vLinkColorMode === "1") {
                    GM_setValue('GB_BGColor', color.toHexString());
                    GM_setValue('GB_LColor', invertColor(GM_getValue('GB_BGColor'), ""));
                    $('#GoogleBar a,#GearIcon,.GoogleBarDropDownButton').css("color", invertColor(GM_getValue('GB_BGColor'), ""));
                    $('#GoogleBar,.dropdown-content').css("background-color", color.toHexString());
                } else if (vLinkColorMode === "2") {
                    GM_setValue('GB_BGColor', color.toHexString());
                    GM_setValue('GB_LColor', invertColor(GM_getValue('GB_BGColor'), "BW"));
                    $('#GoogleBar a,#GearIcon,.GoogleBarDropDownButton').css("color", invertColor(GM_getValue('GB_BGColor'), "BW"));
                    $('#GoogleBar,.dropdown-content').css("background-color", color.toHexString());
                } else if (vLinkColorMode === "3") {
                    GM_setValue('GB_BGColor', color.toHexString());
                    $('#GoogleBar').css("background-color", color.toHexString());
                }
                GenerateExportSettings();
            }

        });
        $("#GBarLinkColorPicker").spectrum({
            flat: true,
            color: GM_getValue('GB_LColor'),
            showPalette: false,
            showButtons: false,
            containerClassName: 'GBLCP',
            move: function(color) {;
                $('#GoogleBar a,#GearIcon,.GoogleBarDropDownButton').css("color", color.toHexString());
                GM_setValue('GB_LColor', color.toHexString());
                GenerateExportSettings();
            }
        });

        $("#GBarBorderColorPicker").spectrum({
            flat:true,
            color: GM_getValue('GB_BColor'),
            showPalette: false,
            showButtons: false,
            containerClassName: 'GBBCP',
            move: function(color) {;
                $('.GBLinkActive').css("borderTop", "2px solid " + GM_getValue("GB_BColor"));
            $(".GBLinkBlock").hover(function(e) {
                $(this).css("borderTop", e.type === "mouseenter" ? "2px solid " + GM_getValue("GB_BColor") : "2px solid transparent")
            });
                GM_setValue('GB_BColor', color.toHexString());
                GenerateExportSettings();
            }
        });

  

        $("#CopyButton").click(function() {
            var copyText = document.querySelector("#ExportSettings");
            copyText.select();
            document.execCommand("Copy");
        });
        
        $("#GearIcon,#close_button").click(function() {
            showsettings();
        });
        
        $('.tabs .tab-links a').on('click', function(e) {
            var currentAttrValue = $(this).attr('href');
            GoogleColorBorderIndex++
            if (GoogleColorBorderIndex === 1) {
                GoogleColorBorder = "#3CBA54";
            } else if (GoogleColorBorderIndex === 2) {
                GoogleColorBorder = "#f4c20d";
            } else if (GoogleColorBorderIndex === 3) {
                GoogleColorBorder = "#db3236";
            } else if (GoogleColorBorderIndex === 4) {
                GoogleColorBorder = "#4885ed";
                GoogleColorBorderIndex = 0
            }


            // Show/Hide Tabs
            $('.tabs ' + currentAttrValue).slideDown(250);
            $('.tabs ' + currentAttrValue).siblings().slideUp(250);
            $("#GBarLinkColorPicker").spectrum("reflow");
            $("#GBarColorPicker").spectrum("reflow");
            $("#GBarBorderColorPicker").spectrum("reflow");
            // Change/remove current tab to active
            $(this).parent('li').addClass('active').css('borderBottom', '2px solid ' + GoogleColorBorder).siblings().removeClass('active').css('borderBottom', '2px solid transparent');

            e.preventDefault();
        });

        //loop to set value to all inpot boxes

    });

    GoogleBarSearch("https://www.google.com/webhp#q=", "webhp");
    GoogleBarSearch("https://www.google.com/search?site=imghp&tbm=isch&q=", "imghp");
    GoogleBarSearch("https://books.google.com/?q=", "");
    GoogleBarSearch("https://developers.google.com/s/results/?q=", "");
    GoogleBarSearch("https://docs.google.com/document/u/0/?q=", "");
    GoogleBarSearch("https://drive.google.com/drive/search?q=", "");
    GoogleBarSearch("https://earth.google.com/web/search/", "");
    GoogleBarSearch("https://www.google.com/finance?q=", "finance");
    GoogleBarSearch("https://groups.google.com/forum/#!search/", "");
    GoogleBarSearch("https://mail.google.com/mail/u/0/#search/", "");
    GoogleBarSearch("https://inbox.google.com/search/", "");
    GoogleBarSearch("https://keep.google.com/#search/text ", "");
    GoogleBarSearch("https://maps.google.com/?q=", "");
    GoogleBarSearch("https://myactivity.google.com/myactivity?q=", "");
    GoogleBarSearch("https://news.google.com/news/section?cf=all&q=", "");
    GoogleBarSearch("https://patents.google.com/?q=", "");
    GoogleBarSearch("https://plus.google.com/s/", "");
    GoogleBarSearch("https://photos.google.com/search/", "");
    GoogleBarSearch("https://www.google.com/publicdata/directory#!q=", "publicdata");
    GoogleBarSearch("https://scholar.google.com/scholar?hl=en&q=", "");
    GoogleBarSearch("https://www.google.com/shopping?q=", "shopping");
    GoogleBarSearch("https://support.google.com/search?q=", "");
    //not gonna work....\/\/\/
    //GoogleBarSearch("https://www.google.com/search?tbm=vid&hl=en&source=hp&q=","vid");
    //not gonna work..../\/\/\
    GoogleBarSearch("https://www.youtube.com/results?search_query=", "");
    GoogleBarSearch("https://www.facebook.com/search/top/?q=", "");
    GoogleBarSearch("https://www.reddit.com/search?q=", "");
    GoogleBarSearch("https://www.amazon.com/s/?field-keywords=", "");
    GoogleBarSearch("https://en.wikipedia.org/wiki/", "");
    GoogleBarSearch("https://search.yahoo.com/search;?p=", "");
    GoogleBarSearch("https://twitter.com/search?q=", "");
    GoogleBarSearch("https://www.netflix.com/search?q=", "");
    GoogleBarSearch("http://www.ntd.tv/?s=", "");
    GoogleBarSearch("http://craigslist.org/search/sss?query=", "");
    GoogleBarSearch("https://www.pinterest.com/search/pins/?q=", "");
    GoogleBarSearch("http://www.espn.com/search/results?q=", "");
    GoogleBarSearch("https://www.pornhub.com/video/search?search=", "");
    GoogleBarSearch("http://www.cnn.com/search/?text=", "");
    GoogleBarSearch("https://www.bing.com/search?q=", "");
    GoogleBarSearch("http://www.imdb.com/find?q=", "");
    GoogleBarSearch("https://query.nytimes.com/search/sitesearch/?&pgtype=Homepage#/", "");
    GoogleBarSearch("http://stackoverflow.com/search?q=", "");
    GoogleBarSearch("https://github.com/search?q=", "");
    GoogleBarSearch("http://www.xvideos.com/?k=", "");
    GoogleBarSearch("https://xhamster.com/search.php?q=", "");
    GoogleBarSearch("https://greasyfork.org/en/scripts?&q=", "");
    GoogleBarSearch("https://support.google.com/websearch/search?q=", "");

    //https://research.google.com/bigpicture/music/#s%3Arascal%20flatts
    //play store
    //alerts


    function showsettings() {
        $("#settings_box").fadeToggle(250);
        $("#settings_box").css({
            "visibility": "visible",
            "display": "block"
        });
    }

    $('.GBLinkBlock').eq(0).css("margin-left", "25px")
    GM_addStyle(`
#GoogleBar {
    height: 29px;
    position: ` + GM_getValue("GB_Pos") + `;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 2999999998;
}
.GBLink,
.GoogleBarDropDownButton {
    font-family: ` + vGoogleBarFontType + `;
}
#GoogleBar *,
#settings_box * {
    font-size: 13px;
    text-decoration: none;
}
#GoogleBar h2 {
    Background-calendar: #ddd!important;
}
#GoogleBar ul {
    white-space: nowrap;
    margin: 0;
    padding: 0;
}
.GBLinkBlock {
    display: block;
    float: left;
    height: 27px;
    line-height: 27px!important;
    padding-left: 8px;
    padding-right: 8px;
    text-align: center;
    text-align: left;
    border-top: 2px solid transparent;
}
.GBLinkBlock:hover {
    border-top: 2px solid `+vGoogleBarBorderColor+`;
}
.GBLinkActive {
    border-top: 2px solid `+vGoogleBarBorderColor+`;
}
#GoogleBar,
.dropdown-content {
    background-color: ` + vGoogleBarBackgroundColor + `;
    ms-transition: background-color 400ms ease;
    transition: background-color 400ms ease;
    webkit-transition: background-color 400ms ease;
}
#GoogleBar a,
#GearIcon,
.GoogleBarDropDownButton {
    color: ` + GM_getValue('GB_LColor') + `;
    ms-transition: color 400ms ease;
    transition: color 400ms ease;
    webkit-transition: color 400ms ease;
}
.GoogleBarDropDownButton {
    background-color: transparent;
    height: 29px;
    padding-left: 8px;
    padding-right: 8px;
    text-align: center;
    cursor: pointer;
    border: solid 0px transparent;
}
.dropdown {
    position: relative;
}
.dropdown-content {
    box-shadow: 0px 5px 7px 1px rgba(0, 0, 0, 0.2);
    display: none;
    min-width: 100px;
    position: relative;
    top: 0px;
    width: auto;
    z-index: 2999999998;
}
.dropdown-content a {
    color: black;
    display: block;
    padding: 10px 12px;
    text-decoration: none;
}
.dropdown:hover .dropdown-content {
    display: block;
}
#GearIcon {
    display: block;
    float: right;
    height: 29px;
    line-height: 29px!important;
    padding-left: 8px;
    padding-right: 8px;
    text-align: center;
    text-align: left;
    font-size: 20px;
    cursor: pointer;
}
#H3Right {
    float: right!important;
    width: 50%!important;
}
#H3Left {
    float: left!important;
    width: 50%!important;
}
#settings_box {
    background-color: #fff!important;
    border: 1px solid #acacac!important;
    box-shadow: rgba(0, 0, 0, .3) 0 4px 16px!important;
    display: none;
    position: fixed!important;
    right: 6px!important;
    top: 35px!important;
    visibility: hidden;
    min-width: 420px!important;
    max-width: 420px!important;
    z-index: 11111111111!important;
    font-family: helvetica, sans-serif;
}
#settings_box #cancel_button {
    background-color: grey;
    border: 1px solid #acacac;
    border: none;
    box-shadow: rgba(0, 0, 0, .2) 0 4px 16px;
    color: white;
    cursor: pointer;
    float: right;
    margin-bottom: 2px!important;
    margin-right: 2px!important;
    margin-top: 2px!important;
    padding: 5px;
    width: 16px;
}
#settings_box #info_text {
    background-color: #eee;
    clear: both;
    color: #6E6E6E;
    padding: 10px!important;
}
#settings_box h2 {
    display: block;
    font-size: 1.5em;
    font-weight: bold;
    webkit-margin-after: 0.83em;
    webkit-margin-before: 0.83em;
    webkit-margin-end: 0px;
    webkit-margin-start: 0px;
}
#settings_box h4 {
    font-size: 1.5em;
    font-weight: bold;
    webkit-margin-after: 0.83em;
    webkit-margin-before: 0.83em;
    webkit-margin-end: 0px;
    webkit-margin-start: 0px;
    width: 100px;
    display: table-cell;
}
#settings_box th,
#settings_box td {
    padding: 0px;
    background-color: transparent;
}
#GoogleBarColorLabels {
    width: 100%;
}
#GoogleBarColorLabels td {
    width: 33.333333%;
}
#SettingsFooter {
    width: 100%;
}
#SubmitBug {
    float: right;
}
label[for="ICol"] {
    padding-left: 17px!important;
}
#settings_box #close_button {
    color: grey;
    cursor: pointer;
    float: right;
    font-size: 15px;
    height: 6px;
    position: relative;
    width: 11px;
}
.tabs {
    display: inline-block;
    width: 100%;
}
.tab-links:after {
    clear: both;
    content: '';
    display: block;
}
.tab-links {
    margin: 0;
    padding: 0;
}
.tab-links li {
    float: left;
    list-style: none;
    margin: 0px 5px;
}
.tab-links a {
    color: #000!important;
    display: inline-block;
    font-size: 16px!important;
    font-weight: 100;
    padding: 3px 5px!important;
    padding-bottom: 12px;
    transition: all linear 0.15s;
}
.tab-links a:hover {
    background: #eee;
    text-decoration: none;
}
li.active a,
li.active a:hover {
    color: #262626;
    font-weight: bold;
    padding-bottom: 18px;
    font-size: 20px;
}
.tab-content {
    background: #fff;
    border-radius: 3px;
    box-shadow: -1px 1px 1px rgba(0, 0, 0, 0.15);
    height: auto;
    max-height: 666px;
    overflow: auto;
    padding: 5px;
}
.tab {
    display: none;
}
.tab.active {
    display: block;
}
[name="BarLinkNumberInput"],
[name="BarMenuNumberInput"] {
    margin-left: 5px;
    width: 30px;
}
[name=vColCycleDuration] {
    width: 50px;
}
#ExportSettings,
#ImportSettings {
    font-size: 11px!important;
    width: 98%;
}
#CopyButton{float:right;}
[name*="barurl"],
[name*="DropDownURL"] {
    color: black!important;
    margin-right: 5px;
    margin-top: 2px;
    width: 280px!important;
}
[name*="texturl"],
[name*="DropDownText"] {
    color: black!important;
    margin-right: 5px;
    margin-top: 2px;
    width: 100px!important;
}

/*====reset css====*/
.gb_eg.gb_eg .gb_Q,.gb_fa{display:none!important;}
/*===spectrum=====*/

.sp-container {
    position: absolute;
    top: 0;
    left: 0;
    display: inline-block;
    *display: inline;
    *zoom: 1;
    z-index: 9999994;
    overflow: hidden
}
.sp-container.sp-flat {
    position: relative
}
.sp-container,
.sp-container * {
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    box-sizing: content-box
}
.sp-top {
    position: relative;
    width: 100%;
    display: inline-block
}
.sp-top-inner {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0
}
.sp-color {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 20%
}
.sp-hue {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 84%;
    height: 100%
}
.sp-clear-enabled .sp-hue {
    top: 33px;
    height: 77.5%
}
.sp-fill {
    padding-top: 80%
}
.sp-sat,
.sp-val {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0
}
.sp-alpha-enabled .sp-top {
    margin-bottom: 18px
}
.sp-alpha-enabled .sp-alpha {
    display: block
}
.sp-clear {
    display: none
}
.sp-clear.sp-clear-display {
    background-position: center
}
.sp-clear-enabled .sp-clear {
    display: block;
    position: absolute;
    top: 0px;
    right: 0;
    bottom: 0;
    left: 84%;
    height: 28px
}
.sp-container,
.sp-replacer,
.sp-preview,
.sp-dragger,
.sp-slider,
.sp-alpha,
.sp-clear,
.sp-alpha-handle,
.sp-container.sp-dragging .sp-input,
.sp-container button {
    -webkit-user-select: none;
    -moz-user-select: -moz-none;
    -o-user-select: none;
    user-select: none
}
.sp-container.sp-input-disabled .sp-input-container {
    display: none
}
.sp-container.sp-buttons-disabled .sp-button-container {
    display: none
}
.sp-container.sp-palette-buttons-disabled .sp-palette-button-container {
    display: none
}
.sp-palette-only .sp-picker-container {
    display: none
}
.sp-palette-disabled .sp-palette-container {
    display: none
}
.sp-initial-disabled .sp-initial {
    display: none
}
.sp-sat {
    background-image: -webkit-gradient(linear, 0 0, 100% 0, from(#FFF), to(rgba(204, 154, 129, 0)));
    background-image: -webkit-linear-gradient(left, #FFF, rgba(204, 154, 129, 0));
    background-image: -moz-linear-gradient(left, #fff, rgba(204, 154, 129, 0));
    background-image: -o-linear-gradient(left, #fff, rgba(204, 154, 129, 0));
    background-image: -ms-linear-gradient(left, #fff, rgba(204, 154, 129, 0));
    background-image: linear-gradient(to right, #fff, rgba(204, 154, 129, 0));
    -ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType = 1, startColorstr=#FFFFFFFF, endColorstr=#00CC9A81)";
    filter: progid: DXImageTransform.Microsoft.gradient(GradientType 1, startColorstr='#FFFFFFFF', endColorstr='#00CC9A81')
}
.sp-val {
    background-image: -webkit-gradient(linear, 0 100%, 0 0, from(#000000), to(rgba(204, 154, 129, 0)));
    background-image: -webkit-linear-gradient(bottom, #000000, rgba(204, 154, 129, 0));
    background-image: -moz-linear-gradient(bottom, #000, rgba(204, 154, 129, 0));
    background-image: -o-linear-gradient(bottom, #000, rgba(204, 154, 129, 0));
    background-image: -ms-linear-gradient(bottom, #000, rgba(204, 154, 129, 0));
    background-image: linear-gradient(to top, #000, rgba(204, 154, 129, 0));
    -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#00CC9A81, endColorstr=#FF000000)";
    filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#00CC9A81', endColorstr='#FF000000')
}
.sp-hue {
    background: -moz-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
    background: -ms-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
    background: -o-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
    background: -webkit-gradient(linear, left top, left bottom, from(#ff0000), color-stop(0.17, #ffff00), color-stop(0.33, #00ff00), color-stop(0.5, #00ffff), color-stop(0.67, #0000ff), color-stop(0.83, #ff00ff), to(#ff0000));
    background: -webkit-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
    background: linear-gradient(to bottom, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%)
}
.sp-1 {
    height: 17%;
    filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#ff0000', endColorstr='#ffff00')
}
.sp-2 {
    height: 16%;
    filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#ffff00', endColorstr='#00ff00')
}
.sp-3 {
    height: 17%;
    filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#00ff00', endColorstr='#00ffff')
}
.sp-4 {
    height: 17%;
    filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#00ffff', endColorstr='#0000ff')
}
.sp-5 {
    height: 16%;
    filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#0000ff', endColorstr='#ff00ff')
}
.sp-6 {
    height: 17%;
    filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#ff00ff', endColorstr='#ff0000')
}
.sp-hidden {
    display: none !important
}
.sp-cf:before,
.sp-cf:after {
    content: "";
    display: table
}
.sp-cf:after {
    clear: both
}
.sp-cf {
    *zoom: 1
}
@media (max-device-width: 480px) {
    .sp-color {
        right: 40%
    }
    .sp-hue {
        left: 63%
    }
    .sp-fill {
        padding-top: 60%
    }
}
.sp-dragger {
    border-radius: 10px;
    height: 5px;
    width: 5px;
    border: 1px solid #fff;
    background: rgba(0,0,0,0.3);
    cursor: pointer;
    position: absolute;
    top: 0;
    left: 0
}
.sp-slider {
    position: absolute;
    top: 0px;
    cursor: pointer;
    height: 3px;
    left: -1px;
    right: -1px;
    border: 1px solid rgba(255,255,255,0.5);
    background: rgba(0,0,0,0.3);
    opacity: 1;
}
.sp-container {
    border-radius: 0;
    border: solid 0px #f0c49B;
    padding: 0
}
.sp-container,
.sp-container button,
.sp-container input,
.sp-color,
.sp-hue,
.sp-clear {
    font: normal 12px "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Geneva, Verdana, sans-serif;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box
}
.sp-top {
    margin-bottom: 3px
}
.sp-color,
.sp-hue,
.sp-clear {
    border: solid 1px #666
}
.sp-input-container {
    float: right;
    width: 100px;
    margin-bottom: 4px
}
.sp-initial-disabled .sp-input-container {
    width: 100%
}
.sp-input {
    font-size: 12px !important;
    border: 1px inset;
    padding: 4px 5px;
    margin: 0;
    width: 100%;
    background: transparent;
    border-radius: 3px;
    color: #222
}
.sp-input:focus {
    border: 1px solid orange
}
.sp-input.sp-validation-error {
    border: 1px solid red;
    background: #fdd
}
.sp-picker-container,
.sp-palette-container {
    float: left;
    position: relative;
    padding: 1px;
    padding-bottom: 300px;
    margin-bottom: -290px
}
.sp-picker-container {
    width: 130px;
    border-left: solid 1px #fff
}
.sp-palette-container {
    border-right: solid 1px #ccc
}
.sp-palette-only .sp-palette-container {
    border: 0
}
.sp-palette .sp-thumb-el {
    display: block;
    position: relative;
    float: left;
    width: 24px;
    height: 15px;
    margin: 3px;
    cursor: pointer;
    border: solid 2px transparent
}
.sp-palette .sp-thumb-el:hover,
.sp-palette .sp-thumb-el.sp-thumb-active {
    border-color: orange
}
.sp-thumb-el {
    position: relative
}
.sp-initial {
    float: left;
    border: solid 1px #333
}
.sp-initial span {
    width: 30px;
    height: 25px;
    border: none;
    display: block;
    float: left;
    margin: 0
}
.sp-initial .sp-clear-display {
    background-position: center
}
.sp-palette-button-container,
.sp-button-container {
    float: right
}

.sp-dd {
    padding: 2px 0;
    height: 16px;
    line-height: 16px;
    float: left;
    font-size: 10px
}

.sp-container {
    padding-bottom: 0
}

.sp-palette span:hover,
.sp-palette span.sp-thumb-active {
    border-color: #000
}
.sp-preview,
.sp-alpha,
.sp-thumb-el {
    position: relative;
    background-image: url()
}
.sp-preview-inner,
.sp-alpha-inner,
.sp-thumb-inner {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0
}
.sp-palette .sp-thumb-inner {
    background-position: 50% 50%;
    background-repeat: no-repeat
}
.sp-palette .sp-thumb-light.sp-thumb-active .sp-thumb-inner {
    background-image: url()
}
.sp-palette .sp-thumb-dark.sp-thumb-active .sp-thumb-inner {
    background-image: url()
}
.sp-clear-display {
    background-repeat: no-repeat;
    background-position: center;
    background-image: url()
}`);

    //================Keep
    //================Keep
    //================Keep
   
    $('.GBLinkBlock a').each(function(){
        var $this = $(this);
        // if the current path is like this link, make it active
        
        if($this.attr('href')===vCurrentWebpage){
        $this.parent().addClass('GBLinkActive');
        
        }

    });

    if (vCurrentWebpage == "https://www.google.com/") {
        GM_addStyle(`
        body{position:relative!important;
            top:29px!important;}
        `);
    } else if (/google.{2,14}about\/products/.test(vCurrentWebpage) == true ||
        /google.{2,14}policies\//.test(vCurrentWebpage) == true ||
        /google.{2,14}ads\//.test(vCurrentWebpage) == true ||
        /google.{2,14}safetycenter\//.test(vCurrentWebpage) == true ||
        /google.{2,14}about\//.test(vCurrentWebpage) == true ||
        /.greasyfork.{2,6}/.test(vCurrentWebpage) == true ||
        /calendar.google.{2,6}/.test(vCurrentWebpage) == true ||
        /duo.google.{2,6}/.test(vCurrentWebpage) == true ||
        /google.{2,6}#q=/.test(vCurrentWebpage) == true ||
        /google.{2,6}#safe/.test(vCurrentWebpage) == true ||
        /google.{2,6}?ei=/.test(vCurrentWebpage) == true ||
        /google.{2,6}adsense/.test(vCurrentWebpage) == true ||
        /google.{2,6}adwords/.test(vCurrentWebpage) == true ||
        /google.{2,6}alerts/.test(vCurrentWebpage) == true ||
        /google.{2,6}analytics/.test(vCurrentWebpage) == true ||
        /google.{2,6}business/.test(vCurrentWebpage) == true ||
        /google.{2,6}chrome\//.test(vCurrentWebpage) == true ||
        /google.{2,6}earth\//.test(vCurrentWebpage) == true ||
        /google.{2,6}finance/.test(vCurrentWebpage) == true ||
        /google.{2,6}flights/.test(vCurrentWebpage) == true ||
        /google.{2,6}imghp/.test(vCurrentWebpage) == true ||
        /google.{2,6}preferences/.test(vCurrentWebpage) == true ||
        /google.{2,6}settings/.test(vCurrentWebpage) == true ||
        /google.{2,6}search/.test(vCurrentWebpage) == true ||
        /google.{2,6}shopping/.test(vCurrentWebpage) == true ||
        /google.{2,6}videohp/.test(vCurrentWebpage) == true ||
        /google.{2,6}webhp/.test(vCurrentWebpage) == true ||
        /google.{2,6}$/.test(vCurrentWebpage) == true ||
        /adwords.google.{2,6}/.test(vCurrentWebpage) == true ||
        /classroom.google.{2,6}/.test(vCurrentWebpage) == true ||
        /mail.google.{2,6}/.test(vCurrentWebpage) == true ||
        /myaccount.google.{2,6}/.test(vCurrentWebpage) == true ||
        /privacy.google.{2,6}/.test(vCurrentWebpage) == true ||
        /play.google.{2,6}music/.test(vCurrentWebpage) == true ||
        /support.google.{2,6}/.test(vCurrentWebpage) == true ||
        /translate.google.{2,6}/.test(vCurrentWebpage) == true
    ) {
        GM_addStyle(`
        body{position:relative!important;
            top:29px!important;}
        `);
    } else if (/google.{2,14}about\/products/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        .products .glue-sticky.glue-sticky-active{top:98px!important;}
        .fixed-nav{top:29px!important;}
                body{position:relative!important;
            top:29px!important;}
        `);
    } else if (/google.{2,6}maps/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        #omnibox,
        .gb_6f{top:29px!important;}
        `);
    } else if (/news.google.{2,6}/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        body{position:relative!important;
             top:29px!important;}
        .gb_qd{top:29px!important;}
        `);
        } else if (/google.{2,6}express/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        body{position:relative!important;
             top:29px!important;}
        .header,.stickyMobileHeader .mobileSearchWrapper,.mobileNavHeader{top:29px!important;}

        #GoogleBar{position:fixed!important;}
        `);
    } else if (/google.{2,6}forms/.test(vCurrentWebpage) == true ||
        /google.{2,6}slides/.test(vCurrentWebpage) == true ||
        /google.{2,6}sheets/.test(vCurrentWebpage) == true ||
        /google.{2,6}docs/.test(vCurrentWebpage) == true ||
        /google.{2,6}services/.test(vCurrentWebpage) == true ||
        /google.{2,6}cloudprint/.test(vCurrentWebpage) == true
    ) {
        GM_addStyle(`
        body{position:relative!important;
             top:29px!important;}
        .header,.stickyMobileHeader .mobileSearchWrapper,.mobileNavHeader{top:29px!important;}

        #GoogleBar{position:fixed!important;}
        `);
    } else if (/store.google.{2,6}/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        body{position:relative!important;
             top:29px!important;}
        .sticky-stacky,.nav-panel{top:29px!important;}

        #GoogleBar{position:fixed!important;}
        `);
    } else if (/photos.google.{2,6}/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        body{position:relative!important;
             top:29px!important;}
        .SmZ4Wd,.scwMhd{top:29px;}
        #GoogleBar{position:fixed!important;}
        `);
    } else if (/docs.google.{2,6}/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        body{position:relative!important;
             top:29px!important;}
        .gb_qd{top:29px;}
        #GoogleBar{position:fixed!important;}
        `);
    } else if (/drive.google.{2,6}/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        body{position:relative!important;
             top:20px!important;}
        .a-D-Pe-Q{top:29px!important;}
        .a-s-tb-Pe-Q{top:8px!important;}
        #GoogleBar{position:fixed!important;}
        `);
    } else if (/keep.google.{2,6}/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        body{position:relative!important;
             top:29px!important;}
             .gb_qd{top:29px!important;}
        #GoogleBar{position:fixed!important;}
        `);
    } else if (/contacts.google.{2,6}/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        body{position:relative!important;
             top:29px!important;}

        #GoogleBar{position:fixed!important;}
        `);
    } else if (/books.google.{2,6}/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        .gb_6f{top:29px!important;}
        `);
    } else if (/voice.google.{2,6}/.test(vCurrentWebpage) == true ||
        /.google.{2,6}voice/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        body{position:relative!important;
             top:29px!important;}
        `);
    } else if (/youtube.{2,6}/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        #masthead-positioner,#appbar-guide-menu{top:29px!important;}
        #guide-spacer,#page-manager {
        margin-top: var(--ytd-masthead-height, 85px) !important;}

            #GoogleBar{position:fixed!important;}
        `);
    } else if (/youtube.{2,6}watch/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        #masthead-container,#contentContainer.app-drawer{top:29px!important;}
        `);
    } else if (/plus.google.{2,6}/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        .Wxeofe,
        /*Google Plus Images*/
        .KXqTuf{top:29px!important;}
        .u5oEgd{top:120px!important;}
        #GoogleBar{position:fixed!important;}
        `);
    } else if (/google.{2,20}chromecast/.test(vCurrentWebpage) == true ||
        /allo.google.{2,6}/.test(vCurrentWebpage) == true ||
        /google.{2,20}chromebook/.test(vCurrentWebpage) == true
    ) {
        GM_addStyle(`
        header{top:29px!important;}
        body{position:relative!important;
        top:29px!important;}
        #GoogleBar{position:fixed!important;}
        `);
    } else if (/google.{2,10}chrome\/newtab/.test(vCurrentWebpage) == true) {
        GM_addStyle(`
        body{position:relative!important;
        top:10px!important;}
        `);
    } else if (/play.google.{2,6}store/.test(vCurrentWebpage) == true) {
        var vBarPosition = GM_getValue('GB_Pos');
        //play nested if
        if (vBarPosition === "fixed") {
            GM_addStyle(`
            body{position:relative!important;
            top:29px!important;}
            .sticky,.action-bar{top:29px!important;}
        `);
        }
        GM_addStyle(`
        body{position:relative!important;
            top:29px!important;}
    `);

    }

})();