// ==UserScript==
// @name Google Images Enhancer
// @author Keyser Söze
// @namespace http://userscripts.org/users/KeyserSoze
// @homepageURL https://userscripts.org/scripts/show/150950
// @website http://userscripts.org/scripts/show/150950
// @icon http://files.myopera.com/TrikiTran/albums/11598242/avatar117399_1.gif
// @description Mejora Tu Experiencia Al Navegar En Google IMÁGENES | Improves Your Browsing Experience In Google IMAGES.
// @grant GM_addStyle
// @version 2.0
// @include htt*://*.google.*/*tbm=isch*
// @include htt*://*.google.*/images?*
// @include htt*://images.google.*/search?*imghp*
// @include htt*://*.google.*/search?*
// @include htt*://*.google.*/
// @include htt*://*.google.*/firefox
// @exclude htt*://*.google.com/
// @exclude htt*://*.google.tld/
// @exclude htt*://*.google.*/mail/*
// Basado en "Google Enlarge", "PicViewer" & "Greased LightBox"... Así que, muchas gracias a los autores originales!
// Based on "Google Enlarge", "PicViewer" & "Greased LightBox"... So, many thanks to original authors
// ==/UserScript==
(function() {
/*
=============================
|| Google From Dusk 2 Dawn ||
=============================
*/
{ var css = "#pmocntr2,#gt-bbar{display:none!important}select,select > button{-moz-appearance:none!important;-webkit-appearance:none!important}*{color:hsl(0,0%,80%);outline:none!important}h1,h2,h3,h4,h5,h6,strong,span,select,#rhs *,.jfk-button-standard,#sections-header,div[style=\"display:table-cell;padding-left:16px;font-size:13px;color:#222\"],.cell-header-label,.header-label,.sllabel,.goog-slider li,#srchButton,.ksb,.ab_button{color:hsl(0,0%,80%)!important}a{color:hsl(240,99%,73%)!important}a:hover,a:active,#gbz .gbts:hover{color:hsl(0,0%,85%)!important;text-shadow:0 0 5px hsla(0,0%,90%,.9)!important;-moz-transition:text-shadow .2s ease!important;-webkit-transition:text-shadow .2s ease!important} a:visited{color:hsla(105,66%,39%,.6)!important} .f,#pocs,.gt-baf-word{color:hsl(240,96%,90%)!important} .goog-menuitem-highlight div,.goog-option-selected .goog-menuitem-content{color:hsl(0,0%,99%)!important} b,em,.gt-baf-pos,#lc a,.tbou > a.q, #tbpi,#tbtro,.tbt label,#prc_opt,#set_location_section a,.tbtctlabel,#swr a{color:hsl(240,99%,80%)!important} #gt-src-wrap *,#gt-res-wrap *{color:hsl(0,0%,0%)!important}html,body,div[style=\"border-bottom:1px solid #dedede;height:57px\"],#gbx1,#gbx2,.rg_hv,.uh_hv,li.g.psgi:hover,#il_m,#il_ic{background:hsl(0,0%,5%)!important} .c,.gssb_c,.gssb_c td,#nycp,select{background-color:hsl(0,0%,17%)!important} select > button,.gbxms{background-color:hsla(0,0%,17%,.6)!important} select > optgroup{background-color:hsl(0,0%,6%)!important} #nycp{background-color:hsl(0,0%,28%)!important} #gt-src-wrap{background-color:hsl(0,0%,66%)!important} #gt-res-wrap,.close_lk{background-color:hsl(0,0%,77%)!important} .gssb_a span *,.gbto #gbs,#gbx3,#gbx4,.lst-d,.lst-t,.ab_wrp,#appbar,.lhshdr,.tphdr,#tbbcc,.rshdr{background:transparent!important} #header,#footer,.signin-box,.accountchooser-box,.google-header-bar,#leftnav,#tbdi,#hidden_modes,#hmp,#sc-block .sc,#leftnav a,#gt-appbar,#gt-ft-res,.goog-menuitem-content,div.bottom-links-wrapper,.gssb_m,.gbgt-hvr #gbgs3,#gbg3:focus #gbgs3,#gbg3:active #gbgs3,.flyr-o,.flyr-w,#advd-search-header h1{background-color:transparent!important}#bms *,#gbx1,#gbx2,div[style=\"border-bottom:1px solid #dedede;height:57px\"],.google-header-bar,#footer,#footer > div,.google-footer-bar,#top-content,#header,#gt-ft-res,#nycp,.gstl_0.gssb_c *,.lst-d,.lst-d:hover{border-color:transparent!important}.gbm ol *,.c,.appbar_b,div.splitter,.ab_dropdownrule,.ab_wrp{border-color:hsla(0,0%,6%,.6)!important}.gsq_a tr{border:2px solid transparent!important} button:not(#nycx):not(.eswd),.vsh.nyc_opening .vsc:hover .vspii,.vsh.nyc_open .vsc:hover .vspii,.vso .vspii,.jfk-button-standard,.jfk-button,.g-button,select,.cpbb,.kpbb,.kprb,.kpgb,.kpgrb,.ksb,.ab_button{border:hsl(0,0%,70%) 2px ridge!important}button,select,select > optgroup,select > option,.vsh.nyc_opening .vsc:hover .vspii,.vsh.nyc_open .vsc:hover .vspii,.vso .vspii,.mitem,.msel .kls,.c,.gbmc,.gssb_c,.gssb_c table,.goog-flat-menu-button,.gsq_a span,.jfk-button-standard,.jfk-button,.g-button,.rgsh,.cpbb,.kpbb,.kprb,.kpgb,.kpgrb,.ksb,.ab_button,#taw div,.selector,.ab_dropdownitem,ol,ul,li,.goog-menuitem,#gt-src-wrap,#gt-res-wrap,#nycp,.rg_hv,.uh_hv,.gssb_a td,.gssb_e,#srchButton,#il_ic,#il_fi,.close_lk{border-radius:4px!important} img,.rg_i{border-radius:2px!important}.rg-hi,.rg_hv:hover,#rhs,#nycp,.uh_hv,li.g.psgi:hover{border-radius:6px!important;box-shadow:1px 1px 2px #000,-1px -1px 2px hsl(0,0%,32%),2px 6px 16px 5px hsl(0,0%,0%)!important} .lst-d:hover{box-shadow:none!important}.goog-menu,.gbmc,.ab_dropdown{-moz-appearance:none!important;-webkit-appearance:none!important;background:hsl(60,3%,6%) -moz-linear-gradient(left,hsl(0,0%,6%),hsl(0,0%,28%))!important;background:hsl(60,3%,6%) -webkit-linear-gradient(left,hsl(0,0%,6%),hsl(0,0%,28%))!important;background-repeat:repeat!important;background-position:left!important;background-attachment:fixed!important;text-shadow:1px 1px 1px hsl(0,0%,0%)!important;border-radius:6px!important;box-shadow:2px 2px 5px 5px hsl(0,0%,0%),1px 1px 3px hsl(0,0%,6%),-1px -1px 3px hsl(0,0%,28%)!important} #gbx3,#gsr .p_ksb{-moz-appearance:none!important;-webkit-appearance:none!important;background:-moz-linear-gradient(top,hsl(0,0%,33%) 48%,hsl(0,0%,20%) 49%,hsl(0,0%,0%) 85%,hsl(0,0%,20%))!important;background:-webkit-linear-gradient(top,hsl(0,0%,33%) 48%,hsl(0,0%,20%) 49%,hsl(0,0%,0%) 85%,hsl(0,0%,20%))!important;text-shadow:1px 1px 1px hsl(227,32%,28%)!important;box-shadow:0 1px 5px hsl(0,0%,0%)!important} :not(select) > button:not(#nycx):not(.eswd),.vsh.nyc_opening .vsc:hover .vspii,.vsh.nyc_open .vsc:hover .vspii,.vso .vspii,#gbgs4,.gbgs,.kpbb,.g-button,.jfk-button,.goog-flat-menu-button,.cpbb,.kpbb,.kprb,.kpgb,.kpgrb,.ksb,.ab_button,.goog-button-base-pos,#srchButton{-moz-appearance:none!important;-webkit-appearance:none!important;background:transparent!important;background-image:-moz-linear-gradient(top,hsl(0,0%,33%) 48%,hsl(0,0%,20%) 49%,hsl(0,0%,0%) 85%,hsl(0,0%,20%))!important;background-image:-webkit-linear-gradient(top,hsl(0,0%,33%) 48%,hsl(0,0%,20%) 49%,hsl(0,0%,0%) 85%,hsl(0,0%,20%))!important;text-shadow:1px 1px 3px hsl(0,0%,0%)!important;box-shadow:1px 1px 5px hsl(0,0%,0%),-1px -1px 5px hsl(219,16%,32%)!important}button:not(#nycx):not(.eswd):hover,.mitem:hover,.vsh.nyc_opening .vsc:hover .vspii,.vsh.nyc_open .vsc:hover .vspii,.vso .vspii:hover,#gbgs4:hover,.gbgs:hover,.kpbb:hover,.g-button:hover,.jfk-button:hover,.gbto .gbts,.gbmcc li:hover,.ab_dropdownlnk:hover,.ab_dropdownlnkinfo:hover,.goog-menuitem:hover,.cpbb:hover,.kpbb:hover,.kprb:hover,.kpgb:hover,.kpgrb:hover,.ksb:hover,.ab_button:hover,.scroll-tree li a:hover,.selector:hover,.lhn-section-primary:hover,.ab_dropdownitem:hover,#gsr .p_ksb:hover,#doodle-site-navigation li a:hover,.gbmcc.gbsbic li a:hover,.goog-toolbar-button:hover,.goog-flat-menu-button:hover,select > option:hover,.gssb_a td:hover,#srchButton:hover{-moz-appearance:none;-webkit-appearance:none;background:-moz-radial-gradient(center bottom,hsla(123,50%,65%,.6),transparent), -moz-linear-gradient(top,hsl(0,0%,33%) 48%,hsl(0,0%,20%) 49%,hsl(0,0%,0%) 85%,hsl(0,0%,20%))!important;background:-webkit-radial-gradient(center bottom,hsla(123,50%,65%,.6),transparent), -webkit-linear-gradient(top,hsl(0,0%,33%) 48%,hsl(0,0%,20%) 49%,hsl(0,0%,0%) 85%,hsl(0,0%,20%))!important;-moz-transition:background-color .1s ease-in!important;-webkit-transition:background-color .1s ease-in!important;outline:none!important;opacity:1.0!important;color:hsl(0,0%,99%)!important;text-shadow:1px 1px 1px hsl(0,0%,0%),0 0 2px hsla(123,50%,50%,.8)!important} button:not(#nycx):not(.eswd):hover,.mitem:hover,.vsh.nyc_opening .vsc:hover .vspii,.vsh.nyc_open .vsc:hover .vspii,.vso .vspii:hover,#gbgs4:hover,.gbgs:hover,.kpbb:hover,.g-button:hover,.jfk-button:hover,.gbto .gbts,.gbmcc li:hover,.ab_dropdownlnk:hover,.ab_dropdownlnkinfo:hover,.goog-menuitem:hover,.gsq_a tr:hover span,.cpbb:hover,.kpbb:hover,.kprb:hover,.kpgb:hover,.kpgrb:hover,.ksb:hover,.ab_button:hover,.scroll-tree li a:hover,.selector:hover,.lhn-section-primary:hover,.ab_dropdownitem:hover,#gsr .p_ksb:hover,.mitem:hover,.goog-flat-menu-button:hover,select > option:hover,#srchButton:hover,.close_lk:hover{-moz-appearance:none;-webkit-appearance:none;border-color:hsla(123,50%,75%,.6) hsla(123,50%,65%,.6) hsla(123,50%,55%,.6)!important;box-shadow:0 0 10px hsl(123,50%,75%)!important;-moz-transition:border-color .2s ease,box-shadow .3s ease!important;-webkit-transition:border-color .2s ease,box-shadow .3s ease!important} li.selected,.msel .kls,.goog-option-selected,.rgsh,#scrollable-sections .tree-link-selected,.selector.selected,#tbbc,.goog-toolbar-button-selected,.goog-toolbar-button-checked,.goog-toolbar-menu-button-open,.goog-option-selected .goog-menuitem-content{background-image:-moz-radial-gradient(center bottom,hsl(123,99%,55%),transparent),-moz-linear-gradient(top,hsl(0,0%,33%) 48%,hsl(0,0%,20%) 49%,hsl(0,0%,0%) 85%,hsl(0,0%,20%))!important;background-image:-webkit-radial-gradient(center bottom,hsl(123,99%,55%),transparent),-webkit-linear-gradient(top,hsl(0,0%,33%) 48%,hsl(0,0%,20%) 49%,hsl(0,0%,0%) 85%,hsl(0,0%,20%))!important;-moz-transition:all .3s!important;-webkit-transition:all .3s!important}.gbqfqw,#lst-ib,input[type=\"email\"],input[type=\"number\"],input[type=\"password\"],input[type=\"tel\"],input[type=\"url\"],.signin-box input[type=\"text\"],.advtable input[type=\"text\"],#newu,#search_box,.as-text-input,.as-table-cont td input[type=\"text\"],.ktf{-moz-appearance:none!important;-webkit-appearance:none!important;font-weight:bold!important;box-shadow:1px 1px 5px hsl(0,0%,0%) inset,0 -1px 1px 1px hsl(240,20%,30%) inset!important;background:hsl(0,0%,17%)!important;text-shadow:1px 1px 1px hsla(123,99%,89%,.6),-1px -1px 1px hsl(0,0%,0%)!important;color:hsl(0,0%,80%)!important;border-radius:50px!important;border:none!important;padding-left:4px!important}#lga > *{opacity:0!important}#lga {background:transparent url(\"https://lh6.ggpht.com/_6Bqt_HqYues/THR8YbT0qxI/AAAAAAAAADc/NALhWF1Xjsk/logo.png\") top center no-repeat!important;height:100%!important;top:9px!important;margin-bottom:10px!important;background-size:contain!important}";
if (typeof GM_addStyle != "undefined") {
GM_addStyle(css);
} else if (typeof PRO_addStyle != "undefined") {
PRO_addStyle(css);
} else if (typeof addStyle != "undefined") {
addStyle(css);
} else {
var heads = document.getElementsByTagName("head");
if (heads.length > 0) {
var node = document.createElement("style");
node.type = "text/css";
node.appendChild(document.createTextNode(css));
heads[0].appendChild(node);}
}
var css = "*, \n* {cursor: \nurl(\"http://reloaded.site88.net/Data/aero_arrow.cur\"), \ndefault !important\n}\na, a \n* {cursor: \nurl(\"http://reloaded.site88.net/Data/aero_link.cur\"), \npointer !important\n}\nHtml, Div.Span\n, DIV.gb_yb.gb_3b, Div#LeftNav, Span.st, Div#fbar, Div.fbar, Div.gb_Ab.gb_5b, Div.gb_na.gb_5b.gb_k.gb_4b, Div.gb_t.gb_u, Div.gb_t.gb_A, UL.gb_v.gb_z, UL.gb_v.gb_Kb, Div#hdtbSum, Div#gbd, Div#gbmmb, a#gb, ol#gbmm, p.sp_cnt, Div#res.med, Div#center_col, Div#cnt.big, Div#LeftNavc, Div#gbx3, Div#hdtb_more_mn, a#hdtb_tls, Div#hdtbMenus, Box, A#ShowModes, Div#More_Link, Span.Tbpo, A#Tbpi, Div#Ms.Open, Div#Bms, Div.Insep, DIV.gb_yb.gb_Fb.gb_j, DIV.gb_fa.gb_Fb.gb_j.gb_Eb, DIV.gb_ib.gb_Fb, DIV#gb.gb_Bb.gb_1a, DIV#mngb, DIV#tphdr.tphdr,Box1, Box2, Box3, Box4, Box5, O1, Table, Div.Gbmc, #Gbmm, Li, Input, Input.Post, Body\n {\nBackground : url(\"\") \nFixed Repeat Center!important\n; Background-color: Black !important\n; Color : SkyBlue !important\n}\na:Link\n{\nColor: YellowGreen !important;\n}\na:Visited\n{\nColor: Plum !important;\n}\na:Hover\n{\nBackground-color: #222334 !important;\nText-decoration: none !important;\nColor: Teal !important;\n}\na.gbmt, a.gbml1, .gbmt:visited {\n background-color: transparent !important;\n color: Red !important;\n border-color: #444 !important;\n text-decoration: none !important}\n*, *:focus {outline: none !important}\n\nh1, h2, h3, h4, h5, h6, h1 *, h2 *, h3 *, .med, em, #rg_hta, .qbtt, .ss-link.ss-selected, td > font > b, #qbut b, #qbft b, a.spell, a.spell *, a.spell_orig, #gen-query .operator, .threadCountNumber, #popup_dialog_title, .settings-title, .thread-subject, .leftTitle, #conditions #temp, #conditions #condition, .mapBalloon .b {color: Yellow !important}\n#hplogo div, #ftby a, .page-title, .jhp input[type=\"submit\"], body > div[style*=\"fixed\"] > div > b, .rhsvw span > .fl, .rhsvw span > .fl b, .rhsvw span > b, .rhsvw fieldset > legend {color: #c75805 !important}\n\n.titleBox, .titleBox *, .tablib_selected .tab_content {color: #444 !important; text-shadow: 0 1px 0 #000 !important}\n\n.msel, .msel .kls, .tbos, .tbos b, .tbots, .tbotu, #leftnav > h2, .selectedTab .kdSidebarContent > div, .cb .G-G- {color: Crimson !important}\n.a, .cite, cite, cite a, cite b, #ans > i, .f .bc, cite .bc, #rg_hr, #rg_hr a {color: Orange !important}\n.gac_b *, .gssb_i *, .esc.kb, .ac-row.active, .ac-row.active *, .dropdown-box > div:hover {color: Violet !important}\n.xsm, .psgiprice, .psliprice b, .selectionTools span, .pagination-div a, .f span[style*=\"background:#aaa;border:#999 1px solid;border-radius:2px;\"] {color: #F80 !important}\n#GMmessages a, .bubble .item-body a, .mapBalloon a, .item-body a, #weather .on a, #weather a.active, #weather .active a, #conditions #obsTable .b, #conditions #obsTable .b *, #stars table .b, #conditions .b {color: Purple !important}\n#leftnav a, #leftnav a *, .cb > div, .kdSidebarContent > div, .kdSidebar > div, #talk_title, a.ss-link, .fl > span {color: DeepSkyBlue !important}\n.f, .f span, .osl, .osl a, .bc a, .gl a, .esc > a, #knavm, .pslipricecol cite > a, .goog-date-picker-other-month, .RssSummary div, .RssEntryOuterContent, #bp-bd form span.small, .thread_table .read .thread, .read .subject_and_snippet, #views .Nk.Pk *,\n.tn-snippet, .tn-time, .tn-source, #container .source, #container .source-link {color: Cyan !important}\n.msel, #leftnav > h2 {font-weight: bold !important}\n.msel, #leftnav > h2, .tbos, .selectedTab div.kdTabTitle, .selectedGadgetTitle {text-shadow: 0 1px 0 rgba(0,0,0,0.5) !important}\n.gbts, #gbgs4dn {text-shadow: 0 1px 0 #000 !important}\n#knavm {text-shadow: 0 0 2px #000 !important}\n#content .uim .title-cell strong, #content .uim .callout strong, .thread_table .unread b, .thread_table .selected b, #views .Nk.Ok b {color: #FFF !important; text-shadow: 0 0 6px rgba(255,255,200,0.8) !important}\nspan.bd, .controls > b > a, td.goog-date-picker-month, td.goog-date-picker-year, th.goog-date-picker-wday {border-bottom: 1px dotted #444 !important}\n.f span[style*=\"background:#aaa;border:#999 1px solid;border-radius:2px;\"] {border-style: dashed !important}\n\n#res a:hover img, .videobox a:hover img, .vstb, .vsbb, .vstbb, .vstbt, a:hover .newsimg {border-color: #FA0 !important}\n.f span[style*=\"background:#aaa;border:#999 1px solid;border-radius:2px;\"] {border-color: #F80 !important}\n\na:hover, a:hover *, .link:hover, #gbgs4dn:hover, .cb > div:hover, .kdSidebarContent > div:hover, #sharesLink:hover, #updatesLink:hover, #friendsLink:hover, #talk_title:hover, .as-tip-span:hover, .g a:visited:hover, .g a:visited:hover *, #footer a:hover, #leftnav a:hover, #leftnav a:hover *, .chip_x:hover, .gsib_b:hover, #rg_hta:hover, .goog-date-picker-date:hover, #add_gadget:hover, #change_theme:hover, #themes_keep_theme_link:hover, .selectionTools span:hover, #GMmessages a:hover, .bubble .item-body a:hover {\n color: LightPink !important;\n text-shadow: 0 0 6px rgba(255,255,200,0.8) !important}\na.kd-button:hover *, a.nolink:hover {text-shadow: none !important; color: #999 !important}\ntd.menulist:hover {\n color: #BBB !important;\n background: -o-linear-gradient(left, #333, #111) !important;\n background: -moz-linear-gradient(left, #333, #111) !important;\n background: -webkit-linear-gradient(left, #333, #111) !important}\n\n.vst {border-bottom: 1px dotted #666 !important}\n.g a:visited, .g a:visited * {color: DarkCyan !important}";
if (typeof GM_addStyle != "undefined") {
GM_addStyle(css);
} else if (typeof PRO_addStyle != "undefined") {
PRO_addStyle(css);
} else if (typeof addStyle != "undefined") {
addStyle(css);
} else {
var heads = document.getElementsByTagName("head");
if (heads.length > 0) {
var node = document.createElement("style");
node.type = "text/css";
node.appendChild(document.createTextNode(css));
heads[0].appendChild(node);
}
}
}{
/*
================================
|| Google Images Enhancements ||
================================
*/
var doubleDecodeURIComponent = function (component){
var tmp = decodeURIComponent(component);
tmp = decodeURIComponent(tmp);
return tmp;
}
var parseUrl = function (url) {
var qstr = url.split('?');
if (qstr.length <= 1)
return [];
var rawparams = qstr[1].split('&');
var par = [];
for (var i=0 ; i<rawparams.length ; i++){
var p = rawparams[i].split("=");
par[p[0]] = p[1];
}
return par;
}
var getImageLinks = function (url) {
var param = parseUrl(url);
var links = new Object();
links.toImgHref = decodeURIComponent(param["imgurl"]);
links.toPageHref = decodeURIComponent(param["url"]);
return links;
}
var getNewImageLinks = function (url) {
var param = parseUrl(url);
var links = new Object();
links.toImgHref = doubleDecodeURIComponent(param["imgurl"]);
links.toPageHref = decodeURIComponent(param["imgrefurl"]);
return links;
}
var firstOrNull = function (elems) {
return (elems.length > 0 ) ? elems[0] : null;
}
var imgTable = firstOrNull(document.getElementsByClassName('images_table'));
if ( imgTable ) { // for basic version
var imgCell = imgTable.getElementsByTagName('td');
for( j=0 ; j<imgCell.length ; j++ ) {
var imageAnchor = imgCell[j].getElementsByTagName('a')[0];
var domainText = imgCell[j].getElementsByTagName('cite')[0];
console.log(imageAnchor.href);
var links = getImageLinks(imageAnchor.href);
//links.toPageHref = imageAnchor.href; // TODO fixme
links.toImgHref = imageAnchor.href; // TODO fixme
domainText.innerHTML = '<a href="' + links.toPageHref + '">' + domainText.innerHTML + '/…<\a>';
imageAnchor.href = links.toImgHref;
}
}
else { // standard version
console.log("standard version");
var stopEvent = function(event){ event.stopPropagation() }
var fixStyle = function(target){
var parent = target.parentNode;
parent.style.height = target.style.height;
parent.style.width = target.style.width;
parent.style.left = target.style.left;
target.style.left = 'auto';
}
var fixBoxObserver = new MutationObserver(function(mutations){
mutations.forEach(function(mutation) {
var target = mutation.target;
var parent = mutation.target.parentNode;
if (mutation.attributeName === 'style' && target.style.left !== 'auto'){
fixStyle(target);
}
});
});
var fixBoxMutationConfig = { attributes: true, childList: true, characterData: false, subtree: false };
var fixImageBox = function(image){
if ( /\blinkOk\b/.test(image.className) ) {
return;
}
var span = image.querySelector('span.rg_ilmn');
if (span !== null) {
var a = firstOrNull(image.getElementsByTagName('a'));
var links = getNewImageLinks(a.href);
a.href = links.toImgHref;
a.addEventListener('click', stopEvent, false);
a.addEventListener('mousedown', stopEvent, false);
var newContainer = document.createElement('div');
newContainer.className = 'newCont';
a.parentNode.appendChild(newContainer);
newContainer.appendChild(a);
newContainer.appendChild(span.parentNode);
fixStyle(a);
var desc = span.innerHTML;
span.innerHTML = '<a style="color:#fff" href="' + links.toPageHref + '">' + desc + '</a>';
image.className += ' linkOk'
fixBoxObserver.observe(a, fixBoxMutationConfig);
}
else {
console.log("incomplete span");
image.className += ' notComplete';
}
}
var fixImages = function(){
var imagesContainer = document.getElementById('rg_s');
if ( imagesContainer == null ) return;
var images = imagesContainer.getElementsByClassName('rg_di');
for (var i = 0 ; i< images.length ; i++) {
fixImageBox(images[i]);
}
}
var newBoxMutationConfig = { attributes: false, childList: true, characterData: false, subtree: true };
var newBoxObserver = new MutationObserver(function(mutations){
var needFix = false;
mutations.forEach(function(mutation) {
needFix = needFix || mutation.target.id == 'rg_s';
});
if (needFix)
fixImages();
});
fixImages();
newBoxObserver.observe(document.body, newBoxMutationConfig);
var css = []; var i = 0;
css[i++] = '.newCont { position: relative; }';
css[i++] = '.newCont .rg_ilmbg { display: none; }';
css[i++] = '.newCont:hover .rg_ilmbg { display: block; }';
css[i++] = '.imgSiteLnk {'; ///img preview
css[i++] = ' background-color: rgba(255, 255, 255, 0.77);';
css[i++] = ' bottom: 0;';
css[i++] = ' color: #000000;';
css[i++] = ' display: block;';
css[i++] = ' line-height: normal;';
css[i++] = ' position: absolute;';
css[i++] = ' text-decoration: none;';
css[i++] = ' width: 100%; ';
css[i++] = ' display: none }';
css[i++] = '.imgPrev:hover .imgSiteLnk { display: block }';///img preview
var style = document.createElement('style');
style.type = 'text/css';
style.appendChild(document.createTextNode(css.join('\n')));
document.head.appendChild(style);
///img preview in google search (only links to page)
var fixImagePreview = function(div){
var images = document.getElementsByClassName('bicc');
for (var i = 0 ; i<images.length ; i++) {
var div = images[i];
var el = div.getElementsByTagName('a');
if ( el.length == 1 ) {
div.className += ' imgPrev';
//div.style.border = '4em solid black';
var href = el[0].href;
var link = doubleDecodeURIComponent(parseUrl(href)['imgil']);
link = decodeURIComponent(link.split(';')[5]);
var a = document.createElement('a');
a.href = link;
a.className = 'imgSiteLnk';
a.textContent = link.split('/')[2];
div.appendChild(a);
}
}
}
var searchObserver = new MutationObserver(function(mutations){
fixImagePreview();
});
searchObserver.observe(document.body,
{
attributes: false,
childList: true,
characterData: false,
subtree: true
}
);
// visually similar search img preview (oly links to image)
var similars = document.querySelectorAll('div._mj a');
console.log(similars.length)
for (var i = 0 ; i < similars.length ; i++){
var a = similars[i];
var href = getNewImageLinks(a.href);
console.log(href)
if ( typeof href.toImgHref === 'undefined' ) {
console.log('skip')
continue;
}
console.log(href.toImgHref)
var newA = document.createElement('a');
newA.href = href.toImgHref;
newA.appendChild(a.firstChild);
a.parentNode.replaceChild(newA, a);
}
}
}{
/* =================================
|| Additional Google SearchBar ||
=================================
*/
var langs = {
'':'-'
,'Any Language': '-'
,'Spanish': 'es'
,'Russian': 'ru'
,'Portuguese': 'pt'
,'Italian': 'it'
,'Greek': 'el'
,'German': 'de'
,'French': 'fr'
,'English': 'en'
,'==========': '-'
,'Afrikaans': 'af'
,'Arabic': 'ar'
,'Armenian': 'hy'
,'Belarusian': 'be'
,'Bulgarian': 'bg'
//,'Catalan': 'ca'
,'Chinese': 'zh-CN'
//,'Chinese (Traditional)': 'zh-TW'
,'Croatian': 'hr'
,'Czech': 'cs'
,'Danish': 'da'
,'Dutch': 'nl'
//,'Esperanto': 'eo'
,'Estonian': 'et'
,'Filipino': 'tl'
,'Finnish': 'fi'
,'Hebrew': 'iw'
,'Hindi': 'hi'
,'Hungarian': 'hu'
,'Icelandic': 'is'
,'Indonesian': 'id'
,'Japanese': 'ja'
,'Korean': 'ko'
,'Latvian': 'lv'
,'Lithuanian': 'lt'
,'Norwegian': 'no'
,'Persian': 'fa'
,'Polish': 'pl'
,'Romanian': 'ro'
,'Serbian': 'sr'
,'Slovak': 'sk'
,'Slovenian': 'sl'
//,'Swahili': 'sw'
,'Swedish': 'sv'
,'Thai': 'th'
,'Turkish': 'tr'
,'Ukrainian': 'uk'
,'Vietnamese': 'vi'
};
var filetypes = {
'':'-'
,'Any Format': '-'
,'Adobe PDF (.pdf)': 'pdf'
,'Adobe Postscript (.ps)': 'ps'
,'Autodesk DWF (.dwf)': 'dwf'
,'Digital Audio M4A (.m4a)': 'm4a'
,'Digital Audio MP3 (.mp3)': 'mp3'
,'Digital Video Avi (.avi)': 'avi'
,'Digital Video MP4 (.mp4)': 'mp4'
,'Digital Video MKV (.mkv)': 'mkv'
,'Excel Datasheet(.xls)': 'xls'
,'Google Earth KML (.kml)': 'kml'
,'Google Earth KMZ (.kmz)': 'kmz'
,'Metadata File (.torrent)': 'torrent'
,'PowerPoint (.ppt)': 'ppt'
,'Rich Text Format (.rtf)': 'rtf'
,'Shockwave Flash (.swf)': 'swf'
,'WinRAR Archiver (.rar)': 'rar'
,'Word Document (.doc)': 'doc'
};
var sitesearches = {
'':'-'
,'Any Site': '-'
,'AvaxHome': 'avaxho.me'
,'Ba-K': 'ba-k.com'
,'EbookBrowse': 'ebookbrowse.com'
,'EbooksBay': 'ebooksbay.org'
,'Education': '.edu'
,'Fapdu': 'fapdu.com'
,'FileShut': 'fileshut.com'
,'Gobierno MX': '.gob.mx'
,'Government': '.gov'
,'IATE': 'iate.europa.eu'
,'Identi': 'identi.li'
,'Redalyc': 'redalyc.org'
,'Taringa': 'taringa.net'
,'Twilight': 'twilight.ws'
};
var holder = document.createElement('div')
,cboLang = document.createElement('select')
,cboFileType = document.createElement('select')
,cboSiteSearch = document.createElement('select')
,btnSearch = document.createElement('button')
,searchBoxHolderID = 'gbqfw'
,searchBoxID = 'gbqfq'
,query = location.search;
/* Fill combo boxes */
for (var l in langs) {
cboLang.innerHTML += '<option ' +
((query.indexOf('&lr=lang_' + langs[l]) !== -1) ? 'selected="selected"' : '') +
'value="' + langs[l] + '">' + l + '</option>';
}
for (var f in filetypes) {
cboFileType.innerHTML += '<option ' +
((query.indexOf('&as_filetype=' + filetypes[f]) !== -1) ? 'selected="selected"' : '') +
'value="' + filetypes[f] + '">' + f + '</option>';
}
for (var s in sitesearches) {
cboSiteSearch.innerHTML += '<option ' +
((query.indexOf('&as_sitesearch=' + sitesearches[s]) !== -1) ? 'selected="selected"' : '') +
'value="' + sitesearches[s] + '">' + s + '</option>';
}
/* Add elements to the page */
holder.setAttribute('style','background-color:inherit;border:1px solid inherit;padding:1px 5px;');
holder.appendChild(document.createTextNode(' Language: '));
holder.appendChild(cboLang);
holder.appendChild(document.createTextNode(' File Type: '));
holder.appendChild(cboFileType);
holder.appendChild(document.createTextNode(' Site: '));
holder.appendChild(cboSiteSearch);
btnSearch.appendChild(document.createTextNode('Search'));
btnSearch.setAttribute('style','margin-left:5px;');
holder.appendChild(btnSearch);
document.getElementById(searchBoxHolderID).appendChild(holder);
/* Search with customized settings */
btnSearch.onclick = function () {
var selectedLang = cboLang.options[cboLang.selectedIndex].value
,searchTerm = document.getElementById(searchBoxID).value.replace(/ +filetype:[^ ]*/gi, '')
,selectedFileType = cboFileType.options[cboFileType.selectedIndex].value
,searchTerm = document.getElementById(searchBoxID).value.replace(/ +OR+sitesearch:[^ ]*/gi, '')
,selectedSiteSearch = cboSiteSearch.options[cboSiteSearch.selectedIndex].value
,lang = (selectedLang == '-') ? '' : ('&lr=lang_' + selectedLang)
,filetype = (selectedFileType == '-') ? '' : ('&as_filetype=' + selectedFileType)
,sitesearch = (selectedSiteSearch == '-') ? '' : ('&as_sitesearch=' + selectedSiteSearch)
,url = location.protocol + '//' + location.host + '/search?q=' + encodeURIComponent(searchTerm) + lang + filetype + sitesearch;
window.location.replace(url);
};
}{
/*
========================================
|| Pictures Viewer & Greased LightBox ||
========================================
*/
(function(topObject,window,document){
'use strict';
function init(topObject,window,document,arrayFn,envir){
//一些设定。
var prefs={
floatBar:{//浮动工具栏相关设置.
butonOrder:['actual','current','magnifier','gallery'],//按钮排列顺序'actual'(实际的图片),'current'(当前显示的图片),'magnifier'(放大镜观察),'gallery'(图集)
showDelay:366,//浮动工具栏显示延时.单位(毫秒)
hideDelay:566,//浮动工具栏隐藏延时.单位(毫秒)
position:'top left',// 取值为: 'top left'(图片左上角) 或者 'top right'(图片右上角) 'bottom right'(图片右下角) 'bottom left'(图片左下角);
offset:{//浮动工具栏偏移.单位(像素)
x:-15,//x轴偏移(正值,向右偏移,负值向左)
y:-15,//y轴偏移(正值,向下,负值向上)
},
forceShow:{//在没有被缩放的图片上,但是大小超过下面设定的尺寸时,强制显示浮动框.(以便进行旋转,放大,翻转等等操作)..
enabled:true,//启用强制显示.
size:{//图片尺寸.单位(像素);
w:166,
h:166,
},
},
minSizeLimit:{//就算是图片被缩放了(看到的图片被设定了width或者height限定了大小,这种情况下),如果没有被缩放的原图片小于设定值,那么也不显示浮动工具栏.
w:100,
h:100,
},
},
magnifier:{//放大镜的设置.
radius:77,//默认半径.单位(像素).
wheelZoom:{//滚轮缩放.
enabled:true,
pauseFirst:true,//需要暂停(单击暂停)后,才能缩放.(推荐,否则因为放大镜会跟着鼠标,如果放大镜过大,那么会影响滚动.)..
range:[0.4,0.5,0.6,0.7,0.8,0.9,1,1.1,1.2,1.3,1.4,1.5,1.7,1.9,2,2.5,3.0,4.0],//缩放的范围
},
},
gallery:{//图库相关设定
fitToScreen:false,//图片适应屏幕(适应方式为contain,非cover).
sidebarPosition:'bottom',//'top' 'right' 'bottom' 'left' 四个可能值
sidebarSize:130,//侧栏的高(如果是水平放置)或者宽(如果是垂直放置)
preload:true,//对附近的图片进行预读。
max:5,//最多预读多少张(前后各多少张)
},
imgWindow:{//图片窗相关设置
fitToScreen:false,//适应屏幕,并且水平垂直居中(适应方式为contain,非cover).
defaultTool:'hand',//"hand","rotate","zoom";打开窗口的时候默认选择的工具
overlayer:{//覆盖层.
shown:false,//显示
color:'rgba(0,0,0,0.73)',//颜色和不透明度设置.
clickToClose:[true,'click'],//[是否使用点击关闭窗口 "true,false",关闭触发方式,"click,dblclick"]
},
zoom:{//滚轮缩放
range:[0.1,0.2,0.3,0.4,0.5,0.6,0.7,0.8,0.9,1,1.1,1.2,1.3,1.4,1.5,1.7,1.9,2,2.5,3.0,4.0],//缩放比例.(不要出现负数,谢谢-_-!~)
mouseWheelZoom:true,//是否允许使用滚轮缩放。
},
},
//旋转的时候,按住shift键时,旋转的步进.单位:度.
shiftRotateStep:15,
//等图片完全载入后,才开始执行弹出,放大等等操作,
//按住ctrl键的时候,可以临时执行和这个设定相反的设定.
waitImgLoad:true,
//框架里面的图片在顶层窗口展示出来,但是当frame与顶层窗口domain不一样的时候,可能导致图片被反盗链拦截,
//按住shift键,可以临时执行和这个设定相反的设定
framesPicOpenInTopWindow:true,
};
//各网站高级规则;
var siteInfo=[
{siteName:"google图片搜索",
//网址例子.(方便测试.查看.之类的)
siteExample:"http://www.google.com.hk/search?q=opera&tbm=isch",
//是否启用
enabled:true,
//站点正则
url:/https?:\/\/www.google(\.\w{1,3}){1,3}\/search\?.*&tbm=isch/,
//鼠标左键点击直接打开..(这个只是当高级规则的getImage()返回图片的时候生效)
clikToOpen:{
enabled:true,
preventDefault:true,//是否尝试阻止点击的默认行为(比如如果是你点的是一个链接,默认行为是打开这个链接,如果是true,js会尝试阻止链接的打开(如果想临时打开这个链接,请使用右键的打开命令))
type:'actual',//默认的打开方式: 'actual'(弹出,原始图片) 'magnifier'(放大镜) 'current'(弹出,当前图片)
},
//获取图片实际地址的处理函数,
//this 为当前鼠标悬浮图片的引用,
//第一个参数为当前图片的引用,
//第二个参数为包裹当前图片的第一个a元素(可能不存在).
getImage:function(img,a){
if(!a)return;
return (a.href.match(/imgurl=(.*?\.\w{1,5})&/i) || [])[1];
},
},
{sitename:"百度图片搜索",
enabled:true,
url:/^https?:\/\/image\.baidu\.com\/i\?/i,
getImage:function(img,a){
var origin=img.dataset['origin'];
if(origin){
return origin
}else{
if(a){
var onclick=a.getAttribute('onclick');
if(onclick){
return (onclick.match(/u:'(https?:\/\/[^']+)'/i) || [])[1];
};
};
};
},
},
{sitename:"豆瓣",
siteExample:"http://movie.douban.com/photos/photo/1000656155/",
enabled:true,
url:/^https?:\/\/[^.]*\.douban\.com/i,
getImage:function(){
var oldsrc=this.src;
var newsrc=oldsrc.replace(/\/view\/photo\/photo\/public\//i,'/view/photo/raw/public/');
if(newsrc!=oldsrc)return newsrc;
}
},
{sitename:"deviantart",
enabled:true,
url:/^https?:\/\/[^.]*\.deviantart\.com/i,
siteExample:"http://www.deviantart.com",
getImage:function(){
var oldsrc=this.src;
var newsrc=oldsrc.replace(/(http:\/\/[^\/]+\/fs\d+\/)200H\/(.*)/i,'$1$2');
return newsrc==oldsrc? '' : newsrc;
},
},
{sitename:"opera官方论坛",
enabled:true,
url:/^http:\/\/bbs\.operachina\.com/i,
siteExample:"http://bbs.operachina.com",
getImage:function(){
var src=this.src;
if(/file.php\?id=\d+$/i.test(src)){
return src+'&mode=view';
};
},
},
{sitename:"QQ微博",
enabled:true,
url:/^http:\/\/[^\/]*t\.qq\.com\//i,
siteExample:"http://t.qq.com/p/news",
getImage:function(img){
var pic=/(\.qpic\.cn\/mblogpic\/\w+)\/\d+/i;//图片
var head=/(\.qlogo\.cn\/mbloghead\/\w+)\/\d+/i;//头像.
var oldsrc=this.src;
var newsrc;
if(pic.test(oldsrc)){
newsrc=oldsrc.replace(pic,'$1/2000');
return newsrc==oldsrc? '' : newsrc;;
}else if(head.test(oldsrc)){
newsrc=oldsrc.replace(head,'$1/0');
return newsrc==oldsrc? '' : newsrc;;
};
},
},
{sitename:"新浪微博",
enabled:true,
url:/^http:\/\/weibo\.com/i,
siteExample:"http://weibo.com/pub/?source=toptray",
getImage:function(img){
var oldsrc=this.src;
var pic=/(\.sinaimg\.cn\/)(?:bmiddle|thumbnail)/i;//图片.
var head=/(\.sinaimg\.cn\/\d+)\/50\//i;//头像.
var photoList=/\.sinaimg\.cn\/thumb150\/\w+/i//相册
var newsrc;
if(pic.test(oldsrc)){
newsrc=oldsrc.replace(pic,'$1large');
return newsrc==oldsrc? '' : newsrc;
}else if(head.test(oldsrc)){
newsrc=oldsrc.replace(head,'$1/180/');
return newsrc==oldsrc? '' : newsrc;
}else if(photoList.test(oldsrc)){
newsrc=oldsrc.replace('/thumb150/','/mw690/');
return newsrc==oldsrc? '' : newsrc;
};
},
},
{sitename:"pixiv",
enabled:true,
url:/^http:\/\/www\.pixiv\.net/i,
getImage:function(img){
var oldsrc=this.src;
var reg=/(\d+)(_\w)(\.\w{2,5})$/i
if(reg.test(oldsrc)){
return oldsrc.replace(reg,'$1$3');
};
},
},
{sitename:"沪江碎碎",
enabled:true,
url:/^https?:\/\/([^.]+\.)*(?:yeshj\.com|hjenglish\.com|hujiang\.com)/i,
getImage:function(img){
var oldsrc=this.src;
var reg=/^(https?:\/\/(?:[^.]+\.)*hjfile.cn\/.+)(_(?:s|m))(\.\w+)$/i;
if(reg.test(oldsrc)){
return oldsrc.replace(reg,'$1$3');
};
},
},
{sitename:"百度贴吧",
enabled:true,
url:/^http:\/\/tieba\.baidu\.com\/.+/i,
getImage:function(img){
var src=img.src;
var reg=/^(http:\/\/imgsrc\.baidu\.com\/forum\/)ab(pic\/item\/[\w.]+)/i
var result=src.match(reg);
if(result){
return result[1]+result[2];
}else{
var id=img.id;
if(id.indexOf('big_img_')==0){
return src;
};
};
},
},
{sitename:"178.com",
enabled:true,
url:/^https?:\/\/(?:\w+\.)+178\.com\//i,
clikToOpen:{
enabled:true,
preventDefault:true,
type:'actual',
},
getImage:function(img,a){
if(!a)return;
var reg=/^https?:\/\/(?:\w+\.)+178\.com\/.+?(https?:\/\/img\d*.178.com\/[^.]+\.(?:jpg|jpeg|png|gif|bmp))/i;
var matched=a.href.match(reg);
return (a.href.match(reg) || [])[1];
},
},
];
//通配型规则,无视站点.
var tprules=[
function(img,a){//解决新的dz论坛的原图获取方式.
var reg=/(.+\/attachments?\/.+)\.thumb\.\w{2,5}$/i;
var oldsrc=this.src;
var newsrc=oldsrc.replace(reg,'$1');
if(oldsrc!=newsrc)return newsrc;
},
];
//图标
prefs.icons={
actual:'',
magnifier:'',
current:'',
gallery:'',
loading:' sf///yH/C05FVFNDQVBFMi4wAwEAAAAh/wtYTVAgRGF0YVhNUDw/eHBhY2tldCBiZWdpbj0i77u/ IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRv YmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwg MjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8v d3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiBy ZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxu czp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0 dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9y VG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNlSUQ9Inht cC5paWQ6QUU5MTZGNDMxQ0E4MTFFMkE1Q0NEMTFGODU0MkUzNzUiIHhtcE1NOkRvY3VtZW50SUQ9 InhtcC5kaWQ6QUU5MTZGNDQxQ0E4MTFFMkE1Q0NEMTFGODU0MkUzNzUiPiA8eG1wTU06RGVyaXZl ZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDpBRTkxNkY0MTFDQTgxMUUyQTVDQ0QxMUY4 NTQyRTM3NSIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDpBRTkxNkY0MjFDQTgxMUUyQTVDQ0Qx MUY4NTQyRTM3NSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4g PD94cGFja2V0IGVuZD0iciI/PgH//v38+/r5+Pf29fTz8vHw7+7t7Ovq6ejn5uXk4+Lh4N/e3dzb 2tnY19bV1NPS0dDPzs3My8rJyMfGxcTDwsHAv769vLu6ubi3trW0s7KxsK+urayrqqmop6alpKOi oaCfnp2cm5qZmJeWlZSTkpGQj46NjIuKiYiHhoWEg4KBgH9+fXx7enl4d3Z1dHNycXBvbm1sa2pp aGdmZWRjYmFgX15dXFtaWVhXVlVUU1JRUE9OTUxLSklIR0ZFRENCQUA/Pj08Ozo5ODc2NTQzMjEw Ly4tLCsqKSgnJiUkIyIhIB8eHRwbGhkYFxYVFBMSERAPDg0MCwoJCAcGBQQDAgEAACH5BAUFAA8A LAAAAAAYABgAAATMMMlJq710GQQAMgBmLYMSKMuirMQiSocZnOlqH68h06qtFJhPomASEDoEwQpY MFQWM2fhEJoADkyBwDVxMBgBp6igVBAm0C8D8YqtBFWDWlHFABo2MQLMGLwkCFoCbAkAKQt1IoaL Eh2Of4WOVQUDBANiL4ENAjgJJAOViRYADoJAhZagpxgGgg11BqAtLwWbgxQABLMaiQAGLrUNXGgu JA4EVB4DDQ7AmE8DDtIDHQ4N18200dIO1dfMq3YI0dSkDQMckI1NHb+i6vARACH5BAUFAA8ALAAA AAABAAEAAAQC8EUAIfkEBQUADwAsAQABABYAFgAABJbwySkPoYtq6gILEzhsmsd8YQCS4YlK6roV meEpY0gdE0AQNQRLolBMDoMBcEiUjHzJQYFJUSwW0QtVQCkoBwbqg1A0PgBo8SSj3mRqjjhPLVAI 444cs1EOD/BhQwdlXA8HcXpDdQpaD0lMcw8ChRJTEg4NiQ4CDZYsmA0NDhINk5yeG6ANE6WTq0MZ mKMPpa9tcweoFBEAIfkEBQUADwAsAAAAAAEAAQAABALwRQAh+QQFBQAPACwBAAEAFQAVAAAEgvDJ +cAykhzKJzjEQABPwARONxXhIJImc6rP0r6lfGKqLfIDxe7Bk7gki0IHgSlKHI4BjRMIGKGpqaRq fWC1FK4BuwGbz+gOqfFgmwkKhaRBPws4dPdZ3m5ktXwUWUoqhHEdBQ0CDggZDYGFigICbgJxCncq BpKUEpZxAk4dipWYHREAIfkEBQUADwAsAAAAAAEAAQAABALwRQAh+QQFBQAPACwBAAEAFgAWAAAE n/DJKcs0C9A9FxrO8ADEQBzcBjrhWA6mlT5rS8Lmwhky+KAPQ4mgeyA6LFmqUAwEZIhGw6FMGQIM BkXaMMwkiKz2UeCKvhKFGNUAoyUDBpbwrkuK9oXuIGgIjnYTBQKEDnZOARJ+hEAzCIgPOgiEDVUz TmcPUjKNE4AzMgIKbRMCDwoSBp2lCq2mC6hpaKKukbF2BKICerFEdQsGgJ8cEQAh+QQFBQAPACwA AAAAAQABAAAEAvBFACH5BAUFAA8ALAEAAQAWABYAAASU8Mk5zyw0a9ecHM6AABrFNd3nrEMpFWf6 gKz7eq10gPmCTaiJwbYgEEgSgaBhkxQHA8ujoRQ0HwUolFT1XAnagoV6lRgG4GE5A2hTkGuKQvEg lAeMAMM+VzCvCgyCUn1lgnkTc1ZNBnoMXg9KV0ONARRqDwoBAnYSmg+YJXQBAXQSpJahGZ+lE6im TXQKSK1rcGYuEQAh+QQFBQAPACwAAAAAAQABAAAEAvBFACH5BAUFAA8ALAEAAQAWABYAAASV8MlJ 5amYkiaadI3zLJlkcEL3NaxYPqj6gO0rcQ5ChUWWSj2MYTIYkB4EhUJgkwwcOYlAqbjYoK4H1dOc QaVMQvfgeEpIx25lwVY/APCHTqs2DAiD4YTZxBdJfHI2BUV3AEgSCk0LflYkihJzGYwEhxV6FAMP DAFnQRRDnWcPAQymohlWoiSlpg9WJZqdrAwPml1pTREAIfkEBQUADwAsAAAAAAEAAQAABALwRQAh +QQFBQAPACwBAAEAFgAWAAAEi/DJKQ2iOFOhhGxCo2Gc0n1C2hjjU54PqBbZMXGihDjhxE6mloT2 cDgAGIVQ4mjkHsplxdlwPH5SyYAqMUWzVpsEmS2bywfHwGoIuL9Co4OmcAek8sHEnV1bgVeBGQUL WnoUPwEMCocGBAMEhS2KDAx3AI8DkJIalJYPmJqbcYqXjwQGZEsHBEOcGBEAIfkEBQUADwAsAAAA AAEAAQAABALwRQAh+QQFBQAPACwBAAEAFgAWAAAEk/DJSSUyNc+hnlqPoAiENh2dlIrKaKrTF7au hnlhKTV1YUuHTPBRaDRAj0Eg8JoUBQLKktkMQRuSabTqgEYR1KpF0NhKkOK0mhFgDNSOR5BBTw+M WAmdUTXgN3QBNy8ORghSZz4Vgw5xJ2cEAwQ3BwMOby8LkQOSAEmNly8Fm5yelo0DihoAB5EEppdD VQALN4MZEQAh+QQFBQAPACwAAAAAAQABAAAEAvBFADs=',
loadingCancle:' bWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNl SUQ9InhtcC5paWQ6MzBFMjYzRTUxQ0IwMTFFMkE5RkRDMDFGNUY3NTA2OTYiIHhtcE1NOkRvY3Vt ZW50SUQ9InhtcC5kaWQ6MzBFMjYzRTYxQ0IwMTFFMkE5RkRDMDFGNUY3NTA2OTYiPiA8eG1wTU06 RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDozMEUyNjNFMzFDQjAxMUUyQTlG REMwMUY1Rjc1MDY5NiIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDozMEUyNjNFNDFDQjAxMUUy QTlGREMwMUY1Rjc1MDY5NiIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1w bWV0YT4gPD94cGFja2V0IGVuZD0iciI/PmI2XfsAAADqSURBVHja7FTLDYMwDI1puwQr5MCJKZCy B3cklsg9GzAAEjAEezBFhRtHISr/T9VD1VgyJP68ZzsBQET2TQFP8McEaZoGJ7F6pdTMeN9KaNv2 nR3iODYLbaeX82k7nO6g67oRiBCC6VgDBABYluUIhx5hGM5w9sbgKrOARLgIfrWDQXCvgLUOVgmi KGJ2HEarqhoFJklicod8zjkriuL0iLY6OHS/jxCgrn5mtDb8lADrunabPM8fpMPe+vASAc20aZrp gT6tusOlGIpdk60PLciy7EYLKWW/dIO0P5gU2vu/qSf4QYKXAAMAJ5qBE+5PPaUAAAAASUVORK5C YII=',
hand:' bWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNl SUQ9InhtcC5paWQ6QjI3OEJEQkYxQ0U3MTFFMjg5NDZFNzJBMTc5RTBBMzMiIHhtcE1NOkRvY3Vt ZW50SUQ9InhtcC5kaWQ6QjI3OEJEQzAxQ0U3MTFFMjg5NDZFNzJBMTc5RTBBMzMiPiA8eG1wTU06 RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDpCMjc4QkRCRDFDRTcxMUUyODk0 NkU3MkExNzlFMEEzMyIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDpCMjc4QkRCRTFDRTcxMUUy ODk0NkU3MkExNzlFMEEzMyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1w bWV0YT4gPD94cGFja2V0IGVuZD0iciI/PjEL5KQAAAHBSURBVHja5FRNywFhFGVmkM9EEaWQEik1 Fqws/AWJn2Dl/8haKTsW/ANljaQslLLwka98NjNOpvTkfeadUXo371k83bndOXPuufcZfT6f130D jO5L+EOi0Wg0GAxUyzhqdj6fX6/XYDDIsmytVlssFo1G43w+z2Yzh8Ph9/u1KspkMsViURRF+dHn 8+G0WCzVarVQKHygqFQqCYIwHo+Px+MrGY1GcTqdzg882mw2OMPhMOheSbvdTvY+nU7ViWCKJEmx WOx0OklPrNdrtCbHt9stnU6Xy2V1ot1uB4O8Xq/b7RafQEfJZBLB/X4/HA5YY7PZTL7CxuNxOdpu t5g0JNhsNqPRGIlE8PFUKiWrgAQ5QNcejycQCGCsqKcQ8TxfqVSsVmu/30d1NpuVaHC5XGAxmUyt VgtfpUxtuVxyHIfBJxKJer2+3+9hitL6YaFQT28N9AzDhEIhGAF1l8vFYDBQRWFLu90uKed9j3q9 HkwFF4rgJTl7EhC7Wq1U9qjT6UAzLBCVIW+Z+kI2m01MEIGgAK1EQLvdFpTxZvNvRPBoOBxS+8IQ cD+0XlpgMpnkcrmfefIak9D/53+2RjwEGAAlkHhWHev9/QAAAABJRU5ErkJggg==',
rotate:' bWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNl SUQ9InhtcC5paWQ6RjM2M0UyRTcxQ0U3MTFFMjgxRDNEQkM4N0Q3NTg2QkMiIHhtcE1NOkRvY3Vt ZW50SUQ9InhtcC5kaWQ6RjM2M0UyRTgxQ0U3MTFFMjgxRDNEQkM4N0Q3NTg2QkMiPiA8eG1wTU06 RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDpGMzYzRTJFNTFDRTcxMUUyODFE M0RCQzg3RDc1ODZCQyIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDpGMzYzRTJFNjFDRTcxMUUy ODFEM0RCQzg3RDc1ODZCQyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1w bWV0YT4gPD94cGFja2V0IGVuZD0iciI/PlX779gAAAJXSURBVHja3JQ5a6pREIbzqbigoqBeNyI2 pghEAnZiJZZ2/gMLQZBgoYUEXIJgYyD+gYhYxcJGtDKQH6CIImKhuIAGFHHfl9yXyPV6DZoUKS6Z YjhHzzxn5p05H2EwGM6+w0hn32T/H4hy7I/RaNTpdCaTCYVCWa1W6/X617vVajV4BoPxOQgx1WpV oVCYzWa5XD6fz2k0Gn58fHxMJpMmk+n5+RlbMpm8H0UcdA0n6vX67e2tQCCIx+OlUqlQKFxeXl5f X+t0OuQokUiAttvtfD5/n3Wo0XA49Hq9r6+vgUAAFKSGLXw6nQady+WiWFx2c3OD+05lpNfrZ7MZ SsAa8R6Ph0qlLhYLv99/d3fH4XB2J/v9Pi47CtpZLpfTarVisVilUkEjsFwuFyT7avszmUyr1cLC arUul8tsNnt/f48t8kJ2yPGrIIfDgRgsNBoN2ux2u5VKZT6fh3aQ1ul0HmMdglgslsVi2Sa1NQj8 9PQUiUQwTSQSCZJXKpXPQegFhCAIYrPZNJtNeOTi8/l4PN763cBC1h9ZpH11Go0GWo6bUQK80WiE Pz8/Z7PZ0Gv9x8B6eHg4CrLZbEwm8+XlBY8ABSKATqfDq9VqeIzfDiQUCkOh0NEngmvRl0Qi0W63 RSLRwblutwsEFlKpNBgM9nq9gwNkjP92hXbIZLKrqys8js2/ViwW397eoDooyAWjeEpsDHQ0GsUL WH0w5IhROEE57BpYsVjsIwjtu7i4CIfDg8Hg2ED+LW1r4/EYg4dm7+pKpVLlchkjPp1OT3zYiJ/7 8f8twABFT5G5Yf+a5QAAAABJRU5ErkJggg==',
zoom:' bWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNl SUQ9InhtcC5paWQ6MzI2NDFENzExQ0NBMTFFMjhDOUNGQ0NDOTYzODI4REUiIHhtcE1NOkRvY3Vt ZW50SUQ9InhtcC5kaWQ6MzI2NDFENzIxQ0NBMTFFMjhDOUNGQ0NDOTYzODI4REUiPiA8eG1wTU06 RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDozMjY0MUQ2RjFDQ0ExMUUyOEM5 Q0ZDQ0M5NjM4MjhERSIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDozMjY0MUQ3MDFDQ0ExMUUy OEM5Q0ZDQ0M5NjM4MjhERSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1w bWV0YT4gPD94cGFja2V0IGVuZD0iciI/PjUXtsUAAAHTSURBVHjazJTHakJREIZzc63YS2xYsKx0 5cYXEHwBfQb3PpgbwRdw60oXtoWoWBAL9i7mQyGERMNNWeRfXA4znO/M/GfuEZLJ5NNf6Pnpj/T/ QLK70cPhMBgMlsslC4VCodPpnE4ni++BVqsViFQqFQgEjEbjbDZrNpu5XA6cVqt9BBLD4fCHWuRy eSaT4fxOp1Ov17fbrdvtTiQSpVLpdDqJoijJo/1+n06nQTQajcvlQkXn87larbZaLeJkpZodj8fp pd/v04UgCFD46vX6Xq83nU7JSgX5/X4oarWawyFOJpP5fL7b7TQaDXGyUs2mF7ygKTafryKITSqV itKi0ajUiqjCZDJh6of48XgkTlYqaDQacUcc/nyVeNVt7fV6y+UylUoCFYtFs9nMBMES3ykYDNps NpfL1e1277LuzNFwOIzFYlarFYPokUUkEgmFQuv1+uWqQqHAncpksq9AaLFYMERs8Hg8ZNnD3dGa wWDgGIfDYbfbP7ME6e8RPw30zWbDGrOy2azP53sb9DsVPVKlUuEe+OPwiH6xkgjz9W0QqtVqsGjq xrrN6g/fI56B8XhssVgY3bdyHr5HXyufz+OOUqnkB/wVCLXb7X//Zr8KMADSBu6sAZizOwAAAABJ RU5ErkJggg==',
flipVertical:' bWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNl SUQ9InhtcC5paWQ6Mzc5RkM3NzYxQ0Y0MTFFMkFGQzk4NzFDMzc4MTVBMTIiIHhtcE1NOkRvY3Vt ZW50SUQ9InhtcC5kaWQ6Mzc5RkM3NzcxQ0Y0MTFFMkFGQzk4NzFDMzc4MTVBMTIiPiA8eG1wTU06 RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDozNzlGQzc3NDFDRjQxMUUyQUZD OTg3MUMzNzgxNUExMiIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDozNzlGQzc3NTFDRjQxMUUy QUZDOTg3MUMzNzgxNUExMiIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1w bWV0YT4gPD94cGFja2V0IGVuZD0iciI/PoWGg/MAAAFCSURBVHja3JTNboMwDMftaVyKVlrYCU68 Ae/Ci/MQE1JRCuok1gNCnuMExgQEJnGaUaIA8S9/fwDmeQ5H2AscZIeBXqc3Xde1bcvzppvneb7v 87wMSpIkjuOdEsqyrKpqGcSUoigQkPQgQuQZkN8gkKz0JUuALMtWQWxBEOyRQ+4csYXXUCTovYR6 IGo3lHsYFRJtgKL3SPbooSMD8TPBoDxGOYeo73snKArFGa2z4AxJpOEo7XarXKArhzac7TKEDdDb +Qw/9TGx2AFDesAG7MyRfzqtVAn/0NlsX88n6BzIhNNiGyGms+ZFm4E+H495OrYStgSq68Y0r9QK x8sCLdH0lhN0r5XeRxYCQ3bpl7gFkTOQuoNtOrQlI3HTeZl8bQCX4OICNU2z8+t3gZRSaZruBPHm VdCH2H/5Zx8G+hZgAJcamqB3G0N7AAAAAElFTkSuQmCC',
flipHorizontal:' bWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNl SUQ9InhtcC5paWQ6NUVBRDRDOTkxQ0Y0MTFFMkI0OUU5NThEQzI4NTFGNDMiIHhtcE1NOkRvY3Vt ZW50SUQ9InhtcC5kaWQ6NUVBRDRDOUExQ0Y0MTFFMkI0OUU5NThEQzI4NTFGNDMiPiA8eG1wTU06 RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDo1RUFENEM5NzFDRjQxMUUyQjQ5 RTk1OERDMjg1MUY0MyIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDo1RUFENEM5ODFDRjQxMUUy QjQ5RTk1OERDMjg1MUY0MyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1w bWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pnl92swAAAFKSURBVHja3JTJjoMwDIbxqBw6SKVAT3Di DXgX3l9cRkhFLKIjekHIk9gJoXQhB07jILPFX37bAcjz3NnDvpydbDfQYXkzjuMwDMJvhrmu63me 8K9BSZLEcWwpoSzLqqpegwSlKIogCKJLFIWXMAxOvv99PA73++/t1nVt07RN3bRd2/d9lmVL0Lsa gRhkSA75Sp7h4fUnEIhZKkhPpzhyqPBg1TVAMcBEMJnRjAJECxBKkloUlo+FWLkG8S1SU8sDPjDm M2u0UwScnJFDUCEHqIIrpR9qhHIAeZ2Tfj4rsUptlZW6RWSk2RAbIFw2Ho2nxFSN0E4RzUe9qUxi YPTZ1Agck5rqDhdbooC1gGNZbN7JWpFOEFbpb9VIBZnNrLCyj6KZT4znr7+u6zRNxcU0Tdequi4+ 7tn881kcPPkt6Ifsv/yzdwP9CTAAzDedWzss4SgAAAAASUVORK5CYII=',
close:' bWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNl SUQ9InhtcC5paWQ6Q0I3NzA1RDAxQ0Y3MTFFMkJGMTU4MTc4OEQ2N0MzQjkiIHhtcE1NOkRvY3Vt ZW50SUQ9InhtcC5kaWQ6Q0I3NzA1RDExQ0Y3MTFFMkJGMTU4MTc4OEQ2N0MzQjkiPiA8eG1wTU06 RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDpDQjc3MDVDRTFDRjcxMUUyQkYx NTgxNzg4RDY3QzNCOSIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDpDQjc3MDVDRjFDRjcxMUUy QkYxNTgxNzg4RDY3QzNCOSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1w bWV0YT4gPD94cGFja2V0IGVuZD0iciI/PmUW1owAAADqSURBVHja5FWxCoQwDL2W+x4X/QmHujvX zV0XadHN31HUn2gR/KD2AgWRAytETpTLEF5eSfqaaEvyPH/dw97W2rtIMcY8uytKKQeiKPKTP5fS dZ0DSZKEYQhAa72SdV0japIsy3D9XPdjjIHv+96FUkpPFqV0VwrnHD3dpmm+GCHEwdEJ2VVpTlhV VdtaEB6m2H2j9oTN87yVAuFhikclviuw8TAMWykQAonuCvJeWZZlmiaHy7IE37Yt+HEc4zgOggBR EzmgVUdRFI4B4BhYwg2IpGl65ZXq+ZmvfoM838MfP4fPGNBHgAEAi7gyuvHuhZcAAAAASUVORK5C YII=',
rotateIndicatorBG:' bWFnZVJlYWR5ccllPAAAA2ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEu MC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVz b3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1N Ok9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDowNDQzRDlCNjE4MjRFMjExQTlDNjhCQTlBOTYy NUVGMyIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDpGRDEzOEEzQTI0MjAxMUUyOTRGREE2Njky QjdBREQ5OCIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDpGRDEzOEEzOTI0MjAxMUUyOTRGREE2 NjkyQjdBREQ5OCIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgQ1M2IChXaW5kb3dz KSI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOjMwOTI1OTNB MUUyNEUyMTFBOUM2OEJBOUE5NjI1RUYzIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjA0NDNE OUI2MTgyNEUyMTFBOUM2OEJBOUE5NjI1RUYzIi8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpS REY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+Q3ni7gAAGahJREFUeNrsXQtYVOW6 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 9BnasNkcSoMAAAAASUVORK5CYII=',
rotateIndicatorPointer:' bWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNl SUQ9InhtcC5paWQ6OTQ0RjM2N0YyNDJFMTFFMjk1QkFBRDIwRTU4OTdBRDgiIHhtcE1NOkRvY3Vt ZW50SUQ9InhtcC5kaWQ6OTQ0RjM2ODAyNDJFMTFFMjk1QkFBRDIwRTU4OTdBRDgiPiA8eG1wTU06 RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDo5NDRGMzY3RDI0MkUxMUUyOTVC QUFEMjBFNTg5N0FEOCIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDo5NDRGMzY3RTI0MkUxMUUy OTVCQUFEMjBFNTg5N0FEOCIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1w bWV0YT4gPD94cGFja2V0IGVuZD0iciI/Psfyr6YAAArZSURBVHja3J1bbyNJFcfL7cT25D6Jc2Em ziYZVqBhGFZCCBADgn0cHuYFaSUekGbeQbvwlskH2BeyCAkeeED7AUBoQPuOhBBCgoWZZYUyuV8m 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',
arrowTop:' bWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNl SUQ9InhtcC5paWQ6QjNFMkVGMDEyQzI0MTFFMjg3QzRFMzA4RUMzNUU1M0UiIHhtcE1NOkRvY3Vt ZW50SUQ9InhtcC5kaWQ6QjNFMkVGMDIyQzI0MTFFMjg3QzRFMzA4RUMzNUU1M0UiPiA8eG1wTU06 RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDpCM0UyRUVGRjJDMjQxMUUyODdD NEUzMDhFQzM1RTUzRSIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDpCM0UyRUYwMDJDMjQxMUUy ODdDNEUzMDhFQzM1RTUzRSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1w bWV0YT4gPD94cGFja2V0IGVuZD0iciI/PlvCjVAAAAD/SURBVHja1JjRDYQgDIbZgBEYwREcgREY xREcoSMxwo3gCHc+0MQQPCgUKCT/G8r3GW0RpfoNfceHaLXYQPhvyFISJoJ/Shjp8NudKwGPucKc JeFFS9hC+KeElQLvCOBx3Mrw0yVOBnjMORoeGOExIBEeKuYP664UGIpEl67dAj9dwjDA10o0bz1K uyulmlCqV1PXpsK7Tv2jSsJ2hK+VsD1u3NpJ2dcaCc++JvXj2hnL9N5aLGBUZWAsGiAJvknCC4Gv kfC4Tchd8Bn8G7iFNXMPVJdYzzoS+bf/Sr4NThB8TuK1lB4CD6NiiaPkh0XaSRpKQOlkiceASa6f AAMADgHRdvHjSZ0AAAAASUVORK5CYII=',
arrowBottom:' bWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNl SUQ9InhtcC5paWQ6Qzg4RUFEREQyQzI0MTFFMkJGRTVENTM1RUFERUEyNjMiIHhtcE1NOkRvY3Vt ZW50SUQ9InhtcC5kaWQ6Qzg4RUFEREUyQzI0MTFFMkJGRTVENTM1RUFERUEyNjMiPiA8eG1wTU06 RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDpDODhFQUREQjJDMjQxMUUyQkZF NUQ1MzVFQURFQTI2MyIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDpDODhFQUREQzJDMjQxMUUy QkZFNUQ1MzVFQURFQTI2MyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1w bWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pl7tKzkAAAEVSURBVHja1JjREYQgDES5CizhSqAES7gS UoolUAIlUcKVQAmRD5hhPBXDkRgzk79V3uK4Roz5LZ86pJ6Mnpoyk28Jl9SYW4uJAl+4liMhVCIt JrbwpWErtKnjjvBOE0fwmFltLTyCL/2tLxAom9c8Y4plY0NDuOuaGT5eZAoldVCJCQo81qmkwUQ3 fClHNDEPhJ+J8I4SpWcNA+CHrylpgm2tD/GRAjN8zEysLxUwwlupZHAX7umkE+9N+NhhY2KkxHXI a7PPJVdNUOGHz1//mLgdvncnfYdepDwxv1XB96TJiPRiKRgAD+bmgifD944eXaOBlj8pqT87FhOq 4Vujx9DRQPpIRNtJH8kEK/wLEc2TaxVgABhX1Dief8wFAAAAAElFTkSuQmCC',
arrowLeft:' bWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNl SUQ9InhtcC5paWQ6NTkwNjJDNTkyQzI0MTFFMkI0NzZFM0NEMTRCQUU4NzAiIHhtcE1NOkRvY3Vt ZW50SUQ9InhtcC5kaWQ6NTkwNjJDNUEyQzI0MTFFMkI0NzZFM0NEMTRCQUU4NzAiPiA8eG1wTU06 RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDo1OTA2MkM1NzJDMjQxMUUyQjQ3 NkUzQ0QxNEJBRTg3MCIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDo1OTA2MkM1ODJDMjQxMUUy QjQ3NkUzQ0QxNEJBRTg3MCIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1w bWV0YT4gPD94cGFja2V0IGVuZD0iciI/Ps3mm0sAAAEHSURBVHjaxNhhDcMgEIZhMgOVMAmVMAmV gJRJQAKSJmESJoHRhSVkNIM7oC/J/WrSJ2nhA86EEMyk4WM9Yi3Fk0noDoZUr1jrbNRlYA7bWag9 APO6j0Zr4Lf8KHRrBMNncg1A1/TP2sB9NneicrDzn15VYAe6pBe1gM8iIBSoBCyDQYn2gQrUd4NC dAwoQJ1g8d+qb2tArQC0Td+sgo4HK+g2BfyDSuLNiqPlAJWAThWgP6gkT716m8hQSbzpwQw9D8zQ 88A4LoYY5OdFJhK2ZLBwwGIQC3xsa8M2cey4gh3MsCModtjGrhXIBQq7KmKXYuz6jzU6sJYO1rzC 2nRYQ7Laen0LMACbElNZVX4epQAAAABJRU5ErkJggg==',
arrowRight:' bWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0 NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNl SUQ9InhtcC5paWQ6N0M5MkUyMEIyQzI0MTFFMkJEREE4MzFDNDE2ODE0OTAiIHhtcE1NOkRvY3Vt ZW50SUQ9InhtcC5kaWQ6N0M5MkUyMEMyQzI0MTFFMkJEREE4MzFDNDE2ODE0OTAiPiA8eG1wTU06 RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDo3QzkyRTIwOTJDMjQxMUUyQkRE QTgzMUM0MTY4MTQ5MCIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDo3QzkyRTIwQTJDMjQxMUUy QkREQTgzMUM0MTY4MTQ5MCIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1w bWV0YT4gPD94cGFja2V0IGVuZD0iciI/PrqtTzoAAADVSURBVHja5NjhCYMwEAXgows4giN0BEdw hBvFETpCRsoIjuAINsIJpfgjoZf3YhN4/4QPgj6TE7leQ0pMCQJaz5QtZbdUh/ULPPOqBS4X2GfU ExtsC/eMqCcaM9EjMwPe7GXrCx494TUTjvZ8lYJoFhYGHP4CngrKw7WntQDW7uCZAbvWpdgLQ4ED o6dLYNe6vAf8kBsv+PY2C7p9MvBy0FZBt8KH/9rgIPy4Aj+YNQ1GBvhzvcEvUPCrIvxSTLmFwwcd lJEOZXhFHdPRBpKQ0etbgAEA5TXHBKbv1IkAAAAASUVORK5CYII=',
};
//获取位置
function getTargetPosition(target){
var target=target;
var rect=target.getBoundingClientRect();
var compStyle=getComputedStyle(target,'');
var pFloat=parseFloat;
var t=rect.top + pFloat(compStyle.paddingTop) + pFloat(compStyle.borderTopWidth);
var l=rect.left + pFloat(compStyle.paddingLeft) + pFloat(compStyle.borderLeftWidth);
var r=rect.right - pFloat(compStyle.paddingRight) - pFloat(compStyle.borderRightWidth);
var b=rect.bottom - pFloat(compStyle.paddingBottom) - pFloat(compStyle.borderBottomWidth);
var scrollXY={
x:window.scrollX,
y:window.scrollY,
};
return {
t:t,
l:l,
r:r,
b:b,
top: t + scrollXY.y,
left: l + scrollXY.x,
right: r + scrollXY.x,
bottom: b + scrollXY.y,
};
};
//获取窗口大小.
function getWindowSize(){
//window.innerHeight;window.innerWidth;
return {
h:window.innerHeight,
w:window.innerWidth,
};
/*
var de=document.documentElement;
return {
h:document.compatMode=='BackCompat'? document.body.clientHeight : de.clientHeight,
w:de.clientWidth,
};
*/
};
function getCurrentSize(target){//获取页面上显示的图片的宽 高.
var iCS=getComputedStyle(target,'');
return {
h:parseFloat(iCS.height),
w:parseFloat(iCS.width),
};
};
//xpath 获取单个元素
function getElementByXpath(xpath,contextNode,doc){
doc=doc || document;
contextNode=contextNode || doc;
return doc.evaluate(xpath,contextNode,null,9,null).singleNodeValue;
};
//事件支持检测.
function eventSupported( eventName,el ){
el = el || document.createElement("div");
eventName = "on" + eventName;
var isSupported = (eventName in el);
if (!isSupported && el.setAttribute) {
el.setAttribute(eventName, "return;");
isSupported = typeof el[eventName] === "function";
};
return isSupported;
};
//检测属性支持.
function attrSupported(proName,el){
el = el || document.createElement("div");
var isSupported = (proName in el);
return isSupported;
};
//css属性支持
function cssProSupported(proName,elem){
var prefix=['','-webkit-','-o-','-moz-','-ms-'];
elem=elem || document.createElement('div');
var style=elem.style;
var camelPro;
for(var i=0,ii=prefix.length;i<ii;i++){
camelPro=(prefix[i]+proName).replace(/-([a-z])/g,function(a,b){
return b.toUpperCase();
});
if(camelPro in style){
return camelPro;
};
};
};
//css属性值支持
function cssValueSupported(proName,value,elem){
var prefix=['','-webkit-','-o-','-moz-','-ms-'];
elem=elem || document.createElement('div');
var style=elem.style;
var prefixedValue;
for(var i=0,ii=prefix.length;i<ii;i++){
prefixedValue=prefix[i] + value;
style[proName]=prefixedValue;
if(style[proName]==prefixedValue){
return prefixedValue;
};
};
};
//抛出错误到错误控制台
function throwErrorInfo(err){
if(console && console.error){
console.error(err.message + '\n\n' + (err.stacktrace? err.stacktrace : '') + '\n\n' , err);
};
};
//支持情况.
var support={
cssTransform:cssProSupported('transform'),
cssCursorValue:{
zoomIn:cssValueSupported('cursor','zoom-in'),
zoomOut:cssValueSupported('cursor','zoom-out'),
},
requestFullscreen:(function(){
var array=['webkitRequestFullScreen','mozRequestFullScreen','requestFullscreen'];
var tempEle=document.body;
var ret;
for(var i=array.length-1;i>=0;i--){
ret=array[i];
if(ret in tempEle){
return ret;
};
};
})(),
};
//console.log('浏览器的一些对象支持情况:',support);
//imgReady
var imgReady=(function(){
var iRInterval,
iRReadyFn=[],
isrcs=[]
;
var timeLimit=3 * 60 * 1000;//3分钟
function checkReady(){
var now=Date.now();
for(var i=0,ii=iRReadyFn.length,iRReadyFn_i;i<ii;i++){
iRReadyFn_i=iRReadyFn[i];
//now - iRReadyFn_i.startTime >= timeLimit ||
if(iRReadyFn_i()){
iRReadyFn.splice(i,1);
isrcs.splice(i,1);
i--;
ii--;
};
};
//console.log('checkReady',iRReadyFn.length)
if(iRReadyFn.length==0){
clearInterval(iRInterval);
iRInterval=null;
};
};
var imgReady=function(img,opts){
if(/NodeList|HTMLCollection/.test(Object.prototype.toString.call(img)) || Array.isArray(img)){
arrayFn.forEach.call(img,function(img,index,array){
if(img instanceof HTMLImageElement){
imgReady(img,opts);
};
});
return;
};
if(!(img instanceof HTMLImageElement)){
var t_img=new Image();
t_img.src=img;
img=t_img;
t_img=null;
};
var ready,load,error,loadEnd,abort,timeout,time;
ready=opts.ready;
load=opts.load;
error=opts.error;
loadEnd=opts.loadEnd;
abort=opts.abort;
timeout=opts.timeout;
time=typeof opts.time=='number'? opts.time : 0;
if(time){
setTimeout(function(){
if(!loadEndDone){
aborted=true;
removeListener();
img.src='data:';
if(timeout){
timeout.call(img,{
target:img,
type:'timeout',
});
};
loadEndDone=true;
if(loadEnd){
loadEnd.call(img,{
target:img,
type:'timeout',
});
};
};
},time);
};
var src=img.src;
var loadEndDone;
function go(type,e){
switch(type){
case 'load':{
removeListener();
go('ready');//如果直接触发load,那么先触发ready
if(load){
load.call(img,e);
};
loadEndDone=true;
if(loadEnd){
loadEnd.call(img,e);
};
}break;
case 'ready':{
if(!ready || readyHandler.done)return;
readyHandler.done=true;
ready.call(img,{
target:img,
type:'ready',
});
}break;
case 'error':{
removeListener();
if(error){
error.call(img,e);
};
loadEndDone=true;
if(loadEnd){
loadEnd.call(img,e);
};
}break;
};
};
var aborted;
var ret={
img:img,
abort:function(){
if(!loadEndDone){
aborted=true;
removeListener();
img.src='data:';
if(abort){
abort.call(img,{
target:img,
type:'abort',
});
};
loadEndDone=true;
if(loadEnd){
loadEnd.call(img,{
target:img,
type:'abort',
});
};
};
},
};
function readyHandler(){//尽快的检测图片大小.
if(loadEndDone || aborted)return true;
if(img.naturalWidth==0 || img.naturalHeight==0)return;
go('ready');
return true;
};
function loadHandler(e){
go('load',e);
};
function errorHandler(e){
go('error',e);
};
function removeListener(){
img.removeEventListener('load',loadHandler,true);
img.removeEventListener('error',errorHandler,true);
};
//ready必须在load之前触发。
if(img.complete){//图片已经加载完成.
if(typeof img.width=='number' && img.width && img.height){//图片
setTimeout(function(){
if(aborted)return;
go('load',{
type:'load',
target:img,
});
},0);
}else{//这不是图片.opera会识别错误.
setTimeout(function(){
if(aborted)return;
go('error',{
type:'error',
target:img,
});
},0);
};
return ret;
};
img.addEventListener('load',loadHandler,true);
img.addEventListener('error',errorHandler,true);
if(ready){
var index=isrcs.indexOf(src);
if(index==-1){
isrcs.push(src);
readyHandler.startTime=Date.now();
iRReadyFn.push(readyHandler);
}else{
iRReadyFn[index].startTime=Date.now();
};
if(!iRInterval){
iRInterval=setInterval(checkReady,66);
};
};
return ret;
};
return imgReady;
})();
var addWheelEvent=(function(){
var eventName;
if('onwheel' in document){//w3c FF>=17 ie>=9
eventName='wheel';
}else if('onmousewheel' in document){//ie
eventName='mousewheel';
}else{// < FF17
eventName='DOMMouseScroll';
};
return function(ele,callback,useCapture){
ele.addEventListener(eventName,function(e){
var type=e.type;
var ne;
if(type!='wheel'){
ne={};
for(var i in e){
ne[i]=e[i];
};
ne.type='wheel';
ne.deltaX=0;
ne.deltaY=0;
ne.deltaZ=0;
ne.deltaMode=1;//line
ne.preventDefault=e.preventDefault.bind(e);
ne.stopPropagation=e.stopPropagation.bind(e);
if((typeof e.axis=='number' && e.axis==2) || (typeof e.wheelDeltaY=='number' && e.wheelDeltaY!=0)){//Y轴的滚动
ne.deltaY = e.wheelDeltaY? -e.wheelDeltaY/40 : e.detail;
}else{
ne.deltaX = e.wheelDeltaX? -e.wheelDeltaX/40 : e.detail;
};
};
callback.call(this,ne? ne : e);
},useCapture || false);
};
})();
var addCusMouseEvent=(function(){
var tele= document.documentElement || document.createElement('div');
var support={
mouseleave:'onmouseleave' in tele,
mouseenter:'onmouseenter' in tele,
};
tele=null;
var map={
'mouseleave':'mouseout',
'mouseenter':'mouseover',
};
return function(type, ele, fn){//事件类型,元素,监听函数
type=type.toLowerCase();
if(support[type]){
ele.addEventListener(type,fn,false);//mouseleave,enter不冒泡
}else{
ele.addEventListener(map[type],function(e){
var relatedTarget=e.relatedTarget;//mouseout,去往的元素;mouseover,来自的元素
if(!this.contains(relatedTarget)){
fn.call(this,e);
};
},true);
};
};
})();
//库
function GalleryC(){
this.init();
};
var gallery;
var galleryMode;
GalleryC.prototype={
init:function(){
this.addStyle();
var container=document.createElement('span');
this.gallery=container;
container.className='pv-gallery-container';
container.tabIndex=1;
container.innerHTML=''+
'<span class="pv-gallery-head">'+
'<span title="弹出照片进行复杂操作" class="pv-gallery-operate">折腾</span>'+
'<span title="一些命令菜单" class="pv-gallery-commands">命令</span>'+
'<span title="分享" class="pv-gallery-share">分享</span>'+
'<span title="Close | Cerrar" class="pv-gallery-close"></span>'+
'</span>'+
'<span class="pv-gallery-body">'+
'<span class="pv-gallery-img-container">'+
'<span class="pv-gallery-img-container-left-side">'+
'<span class="pv-gallery-img-controler-pre"></span>'+
'</span>'+
'<span class="pv-gallery-img-content">'+
'<span class="pv-gallery-img-parent"><!--图片放在这个里面--></span>'+
'<span class="pv-gallery-vertical-align-helper"></span>'+
'</span>'+
'<span class="pv-gallery-img-container-right-side">'+
'<span class="pv-gallery-scrollbar-v pv-gallery-img-scrollbar-v">'+
'<span class="pv-gallery-scrollbar-v-track pv-gallery-img-scrollbar-v-track">'+
'<span class="pv-gallery-scrollbar-v-handle pv-gallery-img-scrollbar-v-handle"></span>'+
'</span>'+
'</span>'+
'<span class="pv-gallery-img-controler-next"></span>'+
'</span>'+
'<span class="pv-gallery-img-container-bottom-side">'+
'<span class="pv-gallery-scrollbar-h pv-gallery-img-scrollbar-h">'+
'<span class="pv-gallery-scrollbar-h-track pv-gallery-img-scrollbar-h-track">'+
'<span class="pv-gallery-scrollbar-h-handle pv-gallery-img-scrollbar-h-handle"></span>'+
'</span>'+
'</span>'+
'</span>'+
'</span>'+
'<span class="pv-gallery-sidebar-container" unselectable="on">'+
'<span class="pv-gallery-sidebar-content" >'+
'<span class="pv-gallery-scrollbar-h pv-gallery-thumb-scrollbar-h">'+
'<span class="pv-gallery-scrollbar-h-track pv-gallery-thumb-scrollbar-h-track">'+
'<span class="pv-gallery-scrollbar-h-handle pv-gallery-thumb-scrollbar-h-handle"></span>'+
'</span>'+
'</span>'+
'<span class="pv-gallery-sidebar-controler-pre"></span>'+
'<span class="pv-gallery-sidebar-thumbnails-container">'+
'<span class="pv-gallery-sidebar-thumbnails">'+
'<!--用innerHTML写入被span.pv-gallery-sidebar-thumb包裹的img元素,并设置宽度货高度-->'+
'</span>'+
'</span>'+
'<span class="pv-gallery-scrollbar-v pv-gallery-thumb-scrollbar-v">'+
'<span class="pv-gallery-scrollbar-v-track pv-gallery-thumb-scrollbar-v-track">'+
'<span class="pv-gallery-scrollbar-v-handle pv-gallery-thumb-scrollbar-v-handle"></span>'+
'</span>'+
'</span>'+
'<span class="pv-gallery-sidebar-controler-next"></span>'+
'</span>'+
'</span>'+
'</span>';
document.body.appendChild(container);
var validPos=['top','right','bottom','left'];
var sBarPosition=prefs.gallery.sidebarPosition.trim();
if(validPos.indexOf(sBarPosition)==-1){
sBarPosition='bottom';
};
this.sBarPosition=sBarPosition;
this.selectedClassName='pv-gallery-sidebar-thumb_selected-' + sBarPosition;
var sBarDirection;
var isHorizontal=false;
if(sBarPosition=='top' || sBarPosition=='bottom'){
sBarDirection='h';//水平放置
isHorizontal=true;
}else{
sBarDirection='v';//垂直放置
};
this.sBarDirection=sBarDirection;
this.isHorizontal=isHorizontal;
var classPrefix='pv-gallery-';
var validClass=[
'close',
'body',
'img-container',
'img-scrollbar-h',
'img-scrollbar-h-handle',
'img-scrollbar-h-track',
'img-scrollbar-v',
'img-scrollbar-v-handle',
'img-scrollbar-v-track',
'thumb-scrollbar-h',
'thumb-scrollbar-h-handle',
'thumb-scrollbar-h-track',
'thumb-scrollbar-v',
'thumb-scrollbar-v-handle',
'thumb-scrollbar-v-track',
'img-content',
'img-parent',
'img-controler-pre',
'img-controler-next',
'sidebar-container',
'sidebar-content',
'sidebar-controler-pre',
'sidebar-controler-next',
'sidebar-thumbnails',
'sidebar-thumbnails-container',
];
var eleMaps={};
this.eleMaps=eleMaps;
validClass.forEach(function(c){
eleMaps[c]=container.querySelector('.'+ classPrefix + c);
});
var posClass=[//需要添加'top bottom left right'class的元素
'img-container',
'sidebar-container',
'sidebar-thumbnails-container',
];
posClass.forEach(function(c){
eleMaps[c].classList.add(classPrefix + c + '-' +sBarPosition);
});
var hvClass=[//需要添加'v h'class的元素
'sidebar-container',
'sidebar-content',
'sidebar-controler-pre',
'sidebar-controler-next',
'sidebar-thumbnails',
];
hvClass.forEach(function(c){
eleMaps[c].classList.add(classPrefix + c + '-' + sBarDirection);
});
//图片区域水平方向的滚动条
var imgScrollbarH=new this.Scrollbar({
bar:eleMaps['img-scrollbar-h'],
handle:eleMaps['img-scrollbar-h-handle'],
track:eleMaps['img-scrollbar-h-track'],
},
eleMaps['img-parent'],
eleMaps['img-content'],
true);
this.imgScrollbarH=imgScrollbarH;
//图片区域垂直方向的滚动条
var imgScrollbarV=new this.Scrollbar({
bar:eleMaps['img-scrollbar-v'],
handle:eleMaps['img-scrollbar-v-handle'],
track:eleMaps['img-scrollbar-v-track'],
},
eleMaps['img-parent'],
eleMaps['img-content'],
false);
this.imgScrollbarV=imgScrollbarV;
//缩略图区域的滚动条
var thumbScrollbar;
if(isHorizontal){
thumbScrollbar=new this.Scrollbar({
bar:eleMaps['thumb-scrollbar-h'],
handle:eleMaps['thumb-scrollbar-h-handle'],
track:eleMaps['thumb-scrollbar-h-track'],
},
eleMaps['sidebar-thumbnails'],
eleMaps['sidebar-thumbnails-container'],
true);
}else{
thumbScrollbar=new this.Scrollbar({
bar:eleMaps['thumb-scrollbar-v'],
handle:eleMaps['thumb-scrollbar-v-handle'],
track:eleMaps['thumb-scrollbar-v-track'],
},
eleMaps['sidebar-thumbnails'],
eleMaps['sidebar-thumbnails-container'],
false);
};
this.thumbScrollbar=thumbScrollbar;
var self=this;
eleMaps['sidebar-thumbnails-container'].addEventListener('scroll',function(e){//发生scroll事件时加载缩略图
self.loadThumb();
},false);
addWheelEvent(eleMaps['body'],function(e){//wheel事件
var target=e.target;
e.preventDefault();
if(eleMaps['sidebar-container'].contains(target)){//缩略图区滚动滚轮翻图片
var distance=self.sideLengthO;
if(e.deltaY<0 || e.deltaX<0 || e.deltaZ<0){//向上滚
distance=-distance;
};
thumbScrollbar.scrollBy(distance)
}else{//图片区域滚动
var distance=100;
if(e.deltaY!=0){//y轴
if(e.deltaY < 0){
distance=-distance;
};
imgScrollbarV.scrollBy(distance);
}else if(e.deltaX!=0){//x轴
if(e.deltaX < 0){
distance=-distance;
};
imgScrollbarH.scrollBy(distance);
};
};
self.forceRepaint();
},true);
var validKeyCode=[38,39,40,37]//上右下左
var keyUp=true;
var keyIntervalTimer;
container.addEventListener('keydown',function(e){//上下左右切换图片
e.stopPropagation();
var keyCode=e.keyCode;
var index=validKeyCode.indexOf(keyCode);
if(index==-1)return;
e.preventDefault();
if(!keyUp)return;//已按下。
keyUp=false;
switch(index){
case 0:;
case 3:{
self.selectPrevious();
keyIntervalTimer=setInterval(function(e){
self.selectPrevious();
},800);
}break;
case 1:;
case 2:{
self.selectNext();
keyIntervalTimer=setInterval(function(e){
self.selectNext();
},800);
}break;
};
function keyUpHandler(e){
if(e.keyCode!=validKeyCode[index])return;
this.removeEventListener('keyup',keyUpHandler,false);
clearInterval(keyIntervalTimer);
keyUp=true;
};
this.addEventListener('keyup',keyUpHandler,false);
},false);
var imgDraged;
eleMaps['img-parent'].addEventListener('mousedown',function(e){//如果图片尺寸大于屏幕的时候按住图片进行拖移
var target=e.target;
if(e.button!=0 || target.nodeName!='IMG')return;
var bigger=target.classList.contains('pv-gallery-img_zoom-out');//如果是大于屏幕
var oClient={
x:e.clientX,
y:e.clientY,
};
var oScroll={
left:self.imgScrollbarH.getScrolled(),
top:self.imgScrollbarV.getScrolled(),
};
var moveHandler=function(e){
imgDraged=true;
if(bigger){
target.style.cursor='pointer';
self.imgScrollbarV.scroll(oScroll.top-(e.clientY-oClient.y));
self.imgScrollbarH.scroll(oScroll.left-(e.clientX-oClient.x));
};
};
var upHandler=function(){
target.style.cursor='';
//拖曳之后阻止随后可能产生click事件产生的大小切换。
//确保在随后的click事件发生后执行
setTimeout(function(){
imgDraged=false;
},0);
document.removeEventListener('mousemove',moveHandler,true);
document.removeEventListener('mouseup',upHandler,true);
};
document.addEventListener('mousemove',moveHandler,true);
document.addEventListener('mouseup',upHandler,true);
},true);
eleMaps['img-parent'].addEventListener('click',function(e){//点击图片本身就行图片缩放处理
var target=e.target;
if(e.button!=0 || target.nodeName!='IMG')return;
if(imgDraged){//在拖动后触发的click事件,取消掉。免得一拖动完就立即进行的缩放。。。
imgDraged=false;
return;
};
if(target.classList.contains('pv-gallery-img_zoom-in')){//放大
self.fitContains=false;
var zoomX = typeof e.offsetX=='undefined' ? e.layerX : e.offsetX;
var zoomY = typeof e.offsetY=='undefined' ? e.layerY : e.offsetY;
var scaleX=zoomX/target.clientWidth;
var scaleY=zoomY/target.clientHeight;
self.fitToScreen({
x:scaleX,
y:scaleY,
});
}else if(target.classList.contains('pv-gallery-img_zoom-out')){
self.fitContains=true;
self.fitToScreen();
};
},true);
var mouseIntervalTimer;
container.addEventListener('mousedown',function(e){//鼠标按在导航上,切换图片
if(e.button!=0)return;//左键
var target=e.target;
if(target.nodeName=='IMG')e.preventDefault();
var matched=true;
switch(target){
case eleMaps['img-controler-pre']:;
case eleMaps['sidebar-controler-pre']:{//上一个
self.selectPrevious();
clearInterval(mouseIntervalTimer);
mouseIntervalTimer=setInterval(function(e){
self.selectPrevious();
},800);
}break;
case eleMaps['img-controler-next']:;
case eleMaps['sidebar-controler-next']:{//下一个
self.selectNext();
clearInterval(mouseIntervalTimer);
mouseIntervalTimer=setInterval(function(e){
self.selectNext();
},800);
}break;
default:{
matched=false;
}break;
};
function mouseUpHandler(e){//opera,按下左键的时候,按右键然后松开不会触发mouseup,再松开左键,还是不会触发mouseup
document.removeEventListener('mouseup',mouseUpHandler,true);
clearInterval(mouseIntervalTimer);
};
if(matched){
e.preventDefault();
document.addEventListener('mouseup',mouseUpHandler,true);
};
},false);
eleMaps['sidebar-content'].addEventListener('click',function(e){//点击缩略图切换
if(e.button!=0)return;//左键
var target=e.target;
if(!target.dataset['src'])return;
self.select((target.nodeName=='SPAN'? target : target.parentNode));
},false);
eleMaps['close'].addEventListener('click',function(e){//关闭
self.close();
},false);
this._resizeHandler=this.resizeHandler.bind(this);
this.sideLength=isHorizontal ? eleMaps['sidebar-thumbnails'].clientHeight : eleMaps['sidebar-thumbnails'].clientWidth;
this.sideLengthO=this.sideLength + 3;//加上margin
this.thumbSpanStyle=isHorizontal ? ';width:' + this.sideLength +'px;' : ';height:' + this.sideLength +'px;';
container.style.display='none';
},
selectPrevious:function(){
var pre;
var _pre=this.selected.previousElementSibling;
while(_pre){
if(_pre.clientWidth!=0){
pre=_pre;
break;
};
_pre=_pre.previousElementSibling;
};
this.select(pre);
},
selectNext:function(){
var next;
var _next=this.selected.nextElementSibling;
while(_next){
if(_next.clientWidth!=0){
next=_next;
break;
};
_next=_next.nextElementSibling;
};
this.select(next);
},
close:function(){
galleryMode=false;
this.gallery.blur();
this.gallery.style.display='none';
var des=document.documentElement.style;
des.overflowX=this.deOverflow.x;
des.overflowY=this.deOverflow.y;
window.removeEventListener('resize',this._resizeHandler,true);
},
selectedIntoView:function(){
var thumBC=this.eleMaps['sidebar-thumbnails-container'];
//需要滚动的距离。
var needScrollDis=this.isHorizontal ? this.selected.offsetLeft : this.selected.offsetTop;
//尽可能的居中显示
var thumBCClient=this.isHorizontal ? thumBC.clientWidth : thumBC.clientHeight;
var scrollCenter=Math.max((thumBCClient - this.sideLengthO)/2,0);
needScrollDis=Math.max(needScrollDis-scrollCenter,0);
this.thumbScrollbar.scroll(needScrollDis);
},
select:function(ele){
if(!ele || this.selected==ele)return;
if(this.selected){
this.selected.classList.remove(this.selectedClassName);
this.selected.classList.remove('pv-gallery-sidebar-thumb_selected');
};
ele.classList.add(this.selectedClassName);
ele.classList.add('pv-gallery-sidebar-thumb_selected');
this.selected=ele;
var self=this;
clearTimeout(this.loadImgTimer);
this.loadImgTimer=setTimeout(function(){//快速跳转的时候不要尝试读取图片。
self.loadImg(ele);
},200);
this.selectedIntoView();
this.forceRepaint();
},
clear:function(){
this.allLoading=[];//读取中的图片数组
this.allImgs={//图片的总类,统计
rule:{
shown:true,
number:0,
},
tpRule:{
shown:true,
number:0,
},
scale:{
shown:true,
number:0,
},
force:{
shown:true,
number:0,
},
};
if(this.img){
this.img.style.display='none';
};
this.img=null;
this.selected==null;
this.eleMaps['sidebar-thumbnails'].innerHTML='';
this.imgScrollbarV.hide();
this.imgScrollbarH.hide();
this.thumbScrollbar.hide();
window.removeEventListener('resize',this._resizeHandler,true);
},
load:function(img,data,from){
this.clear();//还原对象的一些修改,以便复用。
galleryMode=true;
var gallery=this.gallery;
var galleryStyle=gallery.style;
if(galleryStyle.display=='none'){
var des=document.documentElement.style;
this.deOverflow={
x:des.overflowX,
y:des.overflowY,
};
des.overflow='hidden';
galleryStyle.display='';
gallery.focus();
};
var imgSrc=img.src;
var dataSrcs=[];
var data_i;
var index;
var data_i_src;
for(var i=0,ii=data.length;i<ii;i++){//unique顺便算出img所在data中的index;
data_i=data[i];
data_i_src=data_i.src;
if(dataSrcs.indexOf(data_i_src)!=-1){//已经存在
data.splice(i,1);//移除
i--;
ii--;
continue;
};
dataSrcs.push(data_i_src);
if(imgSrc==data_i_src){
index=i;
};
};
if(typeof index =='undefined'){
index=0;
data.unshift(data.target);
};
//console.log(data);
this.data=data;
this.from=from;//如果来自frame,那么这个from应该保存了那个frame的窗口id,便于以后通信。
var thumbnails=this.eleMaps['sidebar-thumbnails'];
if(this.isHorizontal){
thumbnails.style.width=this.sideLengthO * data.length + 'px';//如果是水平放置,需要设置宽度
};
var spanMark='';
var data_i;
for(var i=0,ii=data.length;i<ii;i++){
data_i=data[i];
this.allImgs[data_i.type].number++;
spanMark +=
'<span class="pv-gallery-sidebar-thumb-container'+
'" data-type="' + data_i.type +
'" data-src="' + data_i.src +
'" data-img-src="' + data_i.imgSrc +
'" style="'+ this.thumbSpanStyle +'">'+
'<span class="pv-gallery-vertical-align-helper"></span>'+
'<span class="pv-gallery-sidebar-thumb-loading" title="正在读取中......"></span>'+
'</span>';
};
//console.log(this.allImgs);
thumbnails.innerHTML=spanMark;
//初始化滚动条
this.thumbScrollbar.reset();
this.imgSpans=thumbnails.children;
this.select(this.imgSpans[index]);
this.loadThumb();
//resize监听
window.addEventListener('resize',this._resizeHandler,true);
},
forceRepaint:function(){//解决opera的fixed元素,当滚动条不再最高处的时候,不重绘fixed元素的问题。
if(envir.opera){
window.scrollBy(0,1);
window.scrollBy(0,-1);
};
},
resizeHandler:function(){//窗口变化时,调整一些东西。
this.fitToScreen();
this.thumbScrollbar.reset();
this.selectedIntoView();
this.loadThumb();
},
getImg:function(ele){
var allLoading=this.allLoading;
var src=ele.dataset['src']
var index=allLoading.indexOf(src);
if(index!=-1){
allLoading.splice(index,1);
};
allLoading.push(src);
if(this.imgReady && this.img && this.imgReady.img.src!=this.img.src){
this.imgReady.abort();
this.imgReady.loadingIndicator.style.removeProperty('display');
};
var loadingIndicator=ele.querySelector('.pv-gallery-sidebar-thumb-loading');
loadingIndicator.style.display='block';
var self=this;
this.imgReady=imgReady(src,{
ready:function(){
if(allLoading.indexOf(src)!=allLoading.length-1)return;//如果不是最后一张
loadingIndicator.style.removeProperty('display');
self.loadImg(this);
},
loadEnd:function(){//在loadend后开始预读。
if(allLoading.indexOf(src)!=allLoading.length-1)return;
if(self.preloading){//结束上次的预读。
self.preloading.finish();
};
//console.log(this,'预读开始');
if(prefs.gallery.preload){
self.preloading=new self.Preload(ele);
};
},
});
this.imgReady.loadingIndicator=loadingIndicator;
},
Preload:function(ele){
this.ele=ele;
this.init();
},
Scrollbar:function(scrollbar,content,container,isHorizontal){
this.scrollbar=scrollbar;
this.content=content;
this.container=container;
this.isHorizontal=isHorizontal
this.init();
},
loadImg:function(img){
if(img.nodeName!='IMG'){//先读取。
this.getImg(img);
return;
};
if(this.img){
this.img.style.display='none';
};
this.img=img;
img.className='pv-gallery-img';
this.eleMaps['img-parent'].appendChild(img);
this.fitContains=prefs.gallery.fitToScreen;//适应屏幕
this.fitToScreen();
},
fitToScreen:function(scale){
var container=this.eleMaps['img-content'];
var containerSize={
h:container.clientHeight,
w:container.clientWidth,
};
var img=this.img;
img.classList.remove('pv-gallery-img_zoom-in');
img.classList.remove('pv-gallery-img_zoom-out');
img.removeAttribute('height');
img.removeAttribute('width');
var content=this.eleMaps['img-parent'];
var contentSize={
w:content.offsetWidth,
h:content.offsetHeight,
};
var larger=contentSize.w > containerSize.w || contentSize.h > containerSize.h;
if(this.fitContains){//适应屏幕
this.imgScrollbarV.hide();
this.imgScrollbarH.hide();
if(larger){
img.classList.add('pv-gallery-img_zoom-in');
if(contentSize.h/contentSize.w >=containerSize.h/containerSize.w){
img.height=containerSize.h-20;//20是父元素padding之和
}else{
img.width=containerSize.w-20;
};
};
}else{//不做尺寸调整,如果大于屏幕就出现滚动条
this.imgScrollbarV.reset();
this.imgScrollbarH.reset();
if(larger){
img.classList.add('pv-gallery-img_zoom-out');
if(scale){//通过鼠标点击进行的切换。
this.imgScrollbarH.scroll(container.scrollWidth * scale.x - containerSize.w/2);
this.imgScrollbarV.scroll(container.scrollHeight * scale.y - containerSize.h/2);
};
};
};
},
loadThumb:function(){//读取可视范围里面的缩略图
var self=this;
function ready(){
var naturalSize={
h:this.naturalHeight,
w:this.naturalWidth,
};
var style=this.style;
style.removeProperty('width');
style.removeProperty('height');
if(naturalSize.h > self.sideLength || naturalSize.w > self.sideLength){
if(naturalSize.h>=naturalSize.w){
style.height='100%';
}else{
style.width='100%';
};
};
self.forceRepaint();
};
var thumBC=this.eleMaps['sidebar-thumbnails-container'];
var scrolled=this.isHorizontal ? thumBC.scrollLeft : thumBC.scrollTop;
var thumBCClient=this.isHorizontal ? thumBC.clientWidth : thumBC.clientHeight;
var loadDis=scrolled - this.sideLengthO;
var loadIndex=Math.floor(scrolled/this.sideLengthO);//至少从第几张开始读取。
var loadStopDis=scrolled + thumBCClient;
var imgSpans=this.imgSpans;
var span_i;
var pro=this.isHorizontal ? 'offsetLeft' : 'offsetTop';
var proValue;
var thumb;
for(var i=loadIndex,ii=imgSpans.length;i<ii;i++){
span_i=imgSpans[i];
if(span_i.clientWidth==0)continue;//隐藏的
proValue=span_i[pro];
if(proValue <= loadDis)continue;//在滚动条上面了
if(proValue >= loadStopDis)break;//在滚动条下面了
if(span_i.dataset['loaded'])continue;//已经加载了缩略图
thumb=new Image();
thumb.src=span_i.dataset['imgSrc']; //+ '?' +Math.random();
thumb.style.cssText='\
height:100%;\
width:100%;\
';
thumb.className='pv-gallery-sidebar-thumb';
//GM环境下的dataset可读不可写。。
thumb.setAttribute('data-src',span_i.dataset['src']);
span_i.setAttribute('data-loaded','true');
span_i.appendChild(thumb);
imgReady(thumb,{
ready:ready,
});
};
},
addStyle:function(){
var style=document.createElement('style');
style.type='text/css';
style.textContent='\
.pv-gallery-container {\
position: fixed;\
top: 0;\
left: 0;\
width: 100%;\
height: 100%;\
padding: 0;\
margin: 0;\
border: none;\
z-index:899999999;\
background-color: transparent;\
}\
.pv-gallery-container span{\
-moz-box-sizing: border-box;\
box-sizing: border-box;\
}\
.pv-gallery-head {\
position: absolute;\
top: 0;\
left: 0;\
width: 100%;\
height:26px;\
z-index:1;\
background-color:rgba(0,0,0,0.96);\
border:none;\
border-bottom:1px solid #333333;\
}\
.pv-gallery-operate,\
.pv-gallery-commands,\
.pv-gallery-share{\
color:#ccc;\
display:none;\
}\
.pv-gallery-close{\
cursor:pointer;\
position:absolute;\
top:0;\
right:0;\
height:100%;\
width:40px;\
border:none;\
border-left: 1px solid #333333;\
opacity:0.6;\
background:transparent no-repeat center;\
background-image:url("'+prefs.icons.loadingCancle+'");\
}\
.pv-gallery-close:hover{\
opacity:1;\
}\
.pv-gallery-body {\
display: block;\
height: 100%;\
width: 100%;\
margin: 0;\
padding: 0;\
border: none;\
border-top: 26px solid transparent;\
position: relative;\
background-clip: padding-box;\
}\
.pv-gallery-img-container {\
display: block;\
padding: 0;\
margin: 0;\
border: none;\
height: 100%;\
width: 100%;\
background-clip: padding-box;\
background-color: rgba(20,20,20,0.96);\
position:relative;\
}\
.pv-gallery-img-container-top {\
border-top: '+ prefs.gallery.sidebarSize +'px solid transparent;\
}\
.pv-gallery-img-container-right {\
border-right: '+ prefs.gallery.sidebarSize +'px solid transparent;\
}\
.pv-gallery-img-container-bottom {\
border-bottom: '+ prefs.gallery.sidebarSize +'px solid transparent;\
}\
.pv-gallery-img-container-left {\
border-left: '+ prefs.gallery.sidebarSize +'px solid transparent;\
}\
.pv-gallery-img-container-left-side,\
.pv-gallery-img-container-right-side{\
position:absolute;\
height:100%;\
top:0;\
z-index:2;\
}\
.pv-gallery-img-container-left-side{\
left:0;\
}\
.pv-gallery-img-container-right-side{\
right:0;\
}\
.pv-gallery-img-container-bottom-side{\
position:absolute;\
width:100%;\
left:0;\
bottom:0;\
z-index:2;\
}\
.pv-gallery-img-controler-pre,\
.pv-gallery-img-controler-next{\
position:absolute;\
top:50%;\
height:120px;\
width:50px;\
margin-top:-60px;\
cursor:pointer;\
opacity:0.3;\
}\
.pv-gallery-img-controler-pre{\
background:rgba(70,70,70,0.5) url("'+prefs.icons.arrowLeft+'") no-repeat center;\
left:10px;\
}\
.pv-gallery-img-controler-next{\
background:rgba(70,70,70,0.5) url("'+prefs.icons.arrowRight+'") no-repeat center;\
right:10px;\
}\
.pv-gallery-img-controler-pre:hover,\
.pv-gallery-img-controler-next:hover{\
opacity:0.8;\
}\
/*滚动条样式--开始*/\
.pv-gallery-scrollbar-h,\
.pv-gallery-scrollbar-v{\
display:none;\
position:relative;\
z-index:1;\
opacity:0.6;\
}\
.pv-gallery-thumb-scrollbar-v,\
.pv-gallery-thumb-scrollbar-h{\
position:absolute;\
}\
.pv-gallery-scrollbar-h:hover,\
.pv-gallery-scrollbar-v:hover{\
opacity:0.95;\
}\
.pv-gallery-scrollbar-h{\
width:100%;\
overflow:hidden;\
padding:0;\
padding-left:2px;\
padding-right:16px;\
}\
.pv-gallery-scrollbar-v{\
height:100%;\
padding:0;\
padding-top:2px;\
padding-bottom:16px;\
}\
.pv-gallery-thumb-scrollbar-h{\
bottom:0;\
left:0;\
padding:0 2px;\
}\
.pv-gallery-thumb-scrollbar-v{\
right:0;\
top:0;\
padding:2px 0;\
}\
.pv-gallery-scrollbar-h-track,\
.pv-gallery-scrollbar-v-track{\
position:relative;\
display:block;\
background-color:rgba(100,100,100,1);\
}\
.pv-gallery-scrollbar-h-track{\
margin:5px 0;\
height:10px;\
width:100%;\
}\
.pv-gallery-scrollbar-h:hover .pv-gallery-scrollbar-h-track{\
height:16px;\
}\
.pv-gallery-scrollbar-v-track{\
height:100%;\
width:10px;\
margin:0 5px;\
}\
.pv-gallery-scrollbar-v:hover .pv-gallery-scrollbar-v-track{\
width:16px;\
}\
.pv-gallery-scrollbar-h-handle,\
.pv-gallery-scrollbar-v-handle{\
position:absolute;\
background-color:black;\
}\
.pv-gallery-scrollbar-h-handle:hover,\
.pv-gallery-scrollbar-v-handle:hover{\
background-color:#502121;\
}\
.pv-gallery-scrollbar-h-handle:active,\
.pv-gallery-scrollbar-v-handle:active{\
background-color:#391A1A;\
}\
.pv-gallery-scrollbar-h-handle{\
height:100%;\
width:20px;\
left:10px;\
top:0;\
}\
.pv-gallery-scrollbar-v-handle{\
height:20px;\
width:100%;\
top:10px;\
left:0;\
}\
/*滚动条样式--结束*/\
.pv-gallery-img-content{\
display:block;\
width:100%;\
height:100%;\
overflow:hidden;\
text-align:center;\
padding:0;\
border:none;\
margin:0;\
line-height:0;\
font-size:0;\
white-space:nowrap;\
}\
.pv-gallery-img-parent{\
display:inline-block;\
vertical-align:middle;\
padding:10px;\
border:none;\
margin:0;\
line-height:0;\
font-size:0;\
}\
.pv-gallery-img{\
box-shadow:0 0 10px rgba(0,0,0,0.6);\
display:inline-block;\
vertical-align:middle;\
padding:0;\
border:none;\
margin:0;\
}\
.pv-gallery-img_zoom-out{\
cursor:'+support.cssCursorValue.zoomOut+';\
}\
.pv-gallery-img_zoom-in{\
cursor:'+support.cssCursorValue.zoomIn+';\
}\
.pv-gallery-sidebar-container {\
position: absolute;\
background-color:rgba(0,0,0,0.96);\
padding:10px;\
border:none;\
margin:none;\
-o-user-select: none;\
-webkit-user-select: none;\
-moz-user-select: -moz-none;\
user-select: none;\
}\
.pv-gallery-sidebar-container-h {\
height: '+ prefs.gallery.sidebarSize +'px;\
width: 100%;\
}\
.pv-gallery-sidebar-container-v {\
width: '+ prefs.gallery.sidebarSize +'px;\
height: 100%;\
}\
.pv-gallery-sidebar-container-top {\
top: 0;\
left: 0;\
border-bottom:1px solid #333333;\
}\
.pv-gallery-sidebar-container-right {\
top: 0;\
right: 0;\
border-left:1px solid #333333;\
}\
.pv-gallery-sidebar-container-bottom {\
bottom: 0;\
left: 0;\
border-top:1px solid #333333;\
}\
.pv-gallery-sidebar-container-left {\
top: 0;\
left: 0;\
border-right:1px solid #333333;\
}\
.pv-gallery-sidebar-content {\
display: block;\
margin: 0;\
padding: 0;\
border: 0;\
background-clip: padding-box;\
position: relative;\
}\
.pv-gallery-sidebar-content-h {\
height: 100%;\
width: 90%;\
margin-left: auto;\
margin-right: auto;\
border-left: 40px solid transparent;\
border-right: 40px solid transparent;\
}\
.pv-gallery-sidebar-content-v {\
height: 90%;\
width: 100%;\
top: 5%;\
border-top: 40px solid transparent;\
border-bottom: 40px solid transparent;\
}\
.pv-gallery-sidebar-controler-pre,\
.pv-gallery-sidebar-controler-next{\
cursor:pointer;\
position:absolute;\
background:rgba(255,255,255,0.1) no-repeat center;\
}\
.pv-gallery-sidebar-controler-pre-h,\
.pv-gallery-sidebar-controler-next-h{\
top:2px;\
width:36px;\
height:100%;\
}\
.pv-gallery-sidebar-controler-pre-v,\
.pv-gallery-sidebar-controler-next-v{\
left:2px;\
width:100%;\
height:36px;\
}\
.pv-gallery-sidebar-controler-pre-h {\
left: -40px;\
background-image: url("'+prefs.icons.arrowLeft+'");\
}\
.pv-gallery-sidebar-controler-next-h {\
right: -40px;\
background-image: url("'+prefs.icons.arrowRight+'");\
}\
.pv-gallery-sidebar-controler-pre-h:hover{\
box-shadow:inset 22px 0 0 rgba(255,255,255,0.2) ,inset -14px 0 0 rgba(0,0,0,0.2);\
}\
.pv-gallery-sidebar-controler-next-h:hover{\
box-shadow:inset -22px 0 0 rgba(255,255,255,0.2),inset 14px 0 0 rgba(0,0,0,0.2);\
}\
.pv-gallery-sidebar-controler-pre-v {\
top: -40px;\
background-image: url("'+prefs.icons.arrowTop+'");\
}\
.pv-gallery-sidebar-controler-next-v {\
bottom: -40px;\
background-image: url("'+prefs.icons.arrowBottom+'");\
}\
.pv-gallery-sidebar-controler-pre-v:hover{\
box-shadow:inset 0 22px 0 rgba(255,255,255,0.2) ,inset 0 -14px 0 rgba(0,0,0,0.2);\
}\
.pv-gallery-sidebar-controler-next-v:hover{\
box-shadow:inset 0 -22px 0 rgba(255,255,255,0.2),inset 0 14px 0 rgba(0,0,0,0.2);\
}\
.pv-gallery-sidebar-thumbnails-container {\
display: block;\
overflow: hidden;\
height: 100%;\
width: 100%;\
margin:0;\
border:none;\
padding:0;\
}\
.pv-gallery-sidebar-thumbnails-container-top {\
padding-bottom:5px;\
}\
.pv-gallery-sidebar-thumbnails-container-right {\
padding-left:5px;\
}\
.pv-gallery-sidebar-thumbnails-container-bottom {\
padding-top:5px;\
}\
.pv-gallery-sidebar-thumbnails-container-left {\
padding-right:5px;\
}\
.pv-gallery-sidebar-thumbnails {\
position:relative;\
display: block;\
padding: 0;\
margin: 0;\
border: none;\
line-height:0;/*竖列时消除inline-block元素的行高*/\
}\
.pv-gallery-sidebar-thumbnails-h {\
height: 100%;\
}\
.pv-gallery-sidebar-thumbnails-v {\
width: 100%;\
}\
.pv-gallery-sidebar-thumb-container {\
display:inline-block;\
text-align: center;\
border:2px solid rgb(52,52,52);\
cursor:pointer;\
position:relative;\
padding:2px;\
font-size:0;\
line-height:0;\
/*强制图片后面作为vertical-align参考的字符不换行,以防vertical-align:middle达不到预期效果*/\
white-space:nowrap;\
}\
.pv-gallery-sidebar-container-h .pv-gallery-sidebar-thumb-container {\
margin:0 3px 0 0;\
height:100%;\
}\
.pv-gallery-sidebar-container-v .pv-gallery-sidebar-thumb-container {\
margin:0 0 3px 0;\
width:100%;\
}\
.pv-gallery-sidebar-thumb-container:hover {\
border:2px solid rgb(57,149,211);\
}\
.pv-gallery-sidebar-thumb_selected {\
border:2px solid rgb(229,59,62);\
}\
.pv-gallery-sidebar-thumb_selected-top {\
bottom:-5px;\
}\
.pv-gallery-sidebar-thumb_selected-right {\
left:-5px;\
}\
.pv-gallery-sidebar-thumb_selected-bottom {\
top:-5px;\
}\
.pv-gallery-sidebar-thumb_selected-left {\
right:-5px;\
}\
.pv-gallery-sidebar-thumb-loading{\
position:absolute;\
top:0;\
left:0;\
width:100%;\
height:100%;\
display:none;\
opacity:0.5;\
background:black url("'+ prefs.icons.loading + '") no-repeat center ;\
}\
.pv-gallery-sidebar-thumb-loading:hover{\
opacity:0.6;\
}\
.pv-gallery-sidebar-thumb {\
display: inline-block;\
vertical-align: middle;\
}\
.pv-gallery-vertical-align-helper{\
display:inline-block;\
vertical-align:middle;\
width:0;\
height:100%;\
margin:0;\
border:0;\
padding:0;\
visibility:hidden;\
white-space:nowrap;\
}\
';
document.querySelector('head').appendChild(style);
},
};
GalleryC.prototype.Preload.prototype={//预读对象
container:(function(){
var div=document.createElement('div');
div.className='pv-gallery-preloaded-img-container';
div.style.display='none';
document.body.appendChild(div);
return div;
})(),
init:function(){
this.max=prefs.gallery.max;
this.nextNumber=0;
this.nextEle=this.ele;
this.preNumber=0;
this.preEle=this.ele;
this.direction='pre';
this.preload();
},
preload:function(){
var ele=this.getPreloadEle();
if(!ele){
//conole.log('预读正常结束');
return;
};
//conole.log('正在预读:',ele);
var self=this;
this.imgReady=imgReady(ele.dataset['src'],{
loadEnd:function(){
if(self.finished){
//conole.log('强制终止了');
return;
};
ele.setAttribute('data-preloaded','true');
self.container.appendChild(this);
self.preload();
},
time:60 * 1000,//限时一分钟,否则强制结束并开始预读下一张。
});
},
getPreloadEle:function(){
if((this.max<=this.nextNumber && this.max<=this.preNumber) || (!this.nextEle && !this.preEle)){
return;
};
var ele=this.direction=='pre'? this.getNext() : this.getPrevious();
if(ele && !ele.dataset['preloaded']){
return ele;
}else{
return this.getPreloadEle();
};
},
getNext:function(){
this.nextNumber++;
this.direction='next';
if(!this.nextEle)return;
var next;
var _next=this.nextEle.nextElementSibling;
while(_next){
if(_next.clientWidth!=0){
next=_next;
break;
};
_next=_next.nextElementSibling;
};
this.nextEle=next;
return next;
},
getPrevious:function(){
this.preNumber++;
this.direction='pre';
if(!this.preEle)return;
var pre;
var _pre=this.preEle.previousElementSibling;
while(_pre){
if(_pre.clientWidth!=0){
pre=_pre;
break;
};
_pre=_pre.previousElementSibling;
};
this.preEle=pre;
return pre;
},
finish:function(){
this.finished=true;
if(this.imgReady){
this.imgReady.abort();
};
},
};
GalleryC.prototype.Scrollbar.prototype={//滚动条对象
init:function(){
var self=this;
this.scrollbar.bar.addEventListener('mousedown',function(e){//点击滚动条区域,该干点什么!
e.preventDefault();
var target=e.target;
var handle=self.scrollbar.handle;
var track=self.scrollbar.track;
switch(target){
case handle:{//手柄;功能,拖动手柄来滚动窗口
var pro=self.isHorizontal ? ['left','clientX'] : ['top','clientY'];
var oHOffset=parseFloat(handle.style[pro[0]]);
var oClient=e[pro[1]];
var moveHandler=function(e){
self.scroll(oHOffset + e[pro[1]] - oClient,true);
};
var upHandler=function(){
document.removeEventListener('mousemove',moveHandler,true);
document.removeEventListener('mouseup',upHandler,true);
};
document.addEventListener('mousemove',moveHandler,true);
document.addEventListener('mouseup',upHandler,true);
}break;
case track:{//轨道;功能,按住不放来连续滚动一个页面的距离
var pro=self.isHorizontal ? ['left','offsetX','layerX','clientWidth','offsetWidth'] : ['top' , 'offsetY' ,'layerY','clientHeight','offsetHeight'];
var clickOffset=typeof e[pro[1]]=='undefined' ? e[pro[2]] : e[pro[1]];
var handleOffset=parseFloat(handle.style[pro[0]]);
var handleSize=handle[pro[4]];
var under= clickOffset > handleOffset ;//点击在滚动手柄的下方
var containerSize=self.container[pro[3]];
var scroll=function(){
self.scrollBy(under? (containerSize - 10) : (-containerSize + 10));//滚动一个页面距离少一点
};
scroll();
var checkStop=function(){//当手柄到达点击位置时停止
var handleOffset=parseFloat(handle.style[pro[0]]);
if(clickOffset >= handleOffset && clickOffset <= (handleOffset + handleSize)){
clearInterval(scrollInterval);
};
};
var scrollInterval=setInterval(function(){
scroll();
checkStop();
},300);
checkStop();
var upHandler=function(){
clearInterval(scrollInterval);
document.removeEventListener('mouseup',upHandler,true);
};
document.addEventListener('mouseup',upHandler,true);
}break;
};
},true);
},
reset:function(){//判断滚动条该显示还是隐藏
var contentPro,containerPro,trackPro,handlePro;
if(this.isHorizontal){
contentPro='offsetWidth';
containerPro='clientWidth';
handlePro='width';
trackPro='clientWidth';
}else{
contentPro='offsetHeight';
containerPro='clientHeight';
handlePro='height';
trackPro='clientHeight';
};
//如果内容大于容器的content区域
var contentSize=this.content[contentPro];
var containerSize=this.container[containerPro];
if(contentSize > containerSize){
this.show();
var trackSize=this.scrollbar.track[trackPro];
this.trackSize=trackSize;
var handleSize=Math.floor((containerSize/contentSize) * trackSize);
handleSize=Math.max(20,handleSize);//限制手柄的最小大小;
this.handleSize=handleSize;
this.one=(trackSize-handleSize) / (contentSize-containerSize);//一个像素对应的滚动条长度
this.scrollbar.handle.style[handlePro]= handleSize + 'px';
this.scroll(this.getScrolled());
}else{
this.hide();
};
},
show:function(){
this.scrollbar.bar.style.display='block';
this.shown=true;
},
hide:function(){
this.scrollbar.bar.style.display='none';
this.shown=false;
},
scrollBy:function(distance,handleDistance){
this.scroll(this.getScrolled() + (handleDistance? distance / this.one : distance));
},
scroll:function(distance,handleDistance){
if(!this.shown)return;
var pro;
//滚动实际滚动条
var _distance=distance;
_distance=handleDistance? distance / this.one : distance;
if(this.isHorizontal){
pro='left';
this.container.scrollLeft=_distance;
}else{
pro='top';
this.container.scrollTop=_distance;
};
//滚动虚拟滚动条
//根据比例转换为滚动条上应该滚动的距离。
distance=handleDistance? distance : this.one * distance;
//处理非法值
distance=Math.max(0,distance);//如果值小于0那么取0
distance=Math.min(distance,this.trackSize - this.handleSize);//大于极限值,取极限值
this.scrollbar.handle.style[pro]=distance + 'px';
},
getScrolled:function(){
if(this.isHorizontal){
return this.container.scrollLeft;
}else{
return this.container.scrollTop;
};
},
};
//放大镜
function MagnifierC(img,data){
this.img=img;
this.data=data;
this.init();
};
MagnifierC.all=[];
MagnifierC.styleZIndex=900000000;//全局z-index;
MagnifierC.zoomRange=prefs.magnifier.wheelZoom.range.slice(0).sort();//升序
MagnifierC.zoomRangeR=MagnifierC.zoomRange.slice(0).reverse();//降序
MagnifierC.prototype={
init:function(){
this.addStyle();
MagnifierC.all.push(this);
var container=document.createElement('span');
container.className='pv-magnifier-container';
document.body.appendChild(container);
this.magnifier=container;
var imgNaturalSize={
h:this.img.naturalHeight,
w:this.img.naturalWidth,
};
this.imgNaturalSize=imgNaturalSize;
var cs=container.style;
cs.zIndex=MagnifierC.styleZIndex++;
var maxDia=Math.ceil(Math.sqrt(Math.pow(1/2*imgNaturalSize.w,2) + Math.pow(1/2*imgNaturalSize.h,2)) * 2);
this.maxDia=maxDia;
var radius=prefs.magnifier.radius;
radius=Math.min(maxDia/2,radius);
this.radius=radius;
var diameter=radius * 2;
this.diameter=diameter;
cs.width=diameter + 'px';
cs.height=diameter + 'px';
cs.borderRadius=radius+1 + 'px';
cs.backgroundImage='url("'+ this.img.src +'")';
cs.marginLeft= -radius +'px';
cs.marginTop= -radius +'px';
var imgPos=getTargetPosition(this.data.img);
var imgRange={//图片所在范围
x:[imgPos.left , imgPos.right],
y:[imgPos.top , imgPos.bottom],
};
var imgW=imgRange.x[1] - imgRange.x[0];
var imgH=imgRange.y[1] - imgRange.y[0];
//如果图片太小的话,进行范围扩大。
var minSize=60;
if(imgW < minSize){
imgRange.x[1] +=(minSize - imgW)/2;
imgRange.x[0] -=(minSize - imgW)/2;
imgW=minSize;
};
if(imgH < minSize){
imgRange.y[1] +=(minSize - imgH)/2;
imgRange.y[0] -=(minSize - imgH)/2;
imgH=minSize;
};
this.imgSize={
w:imgW,
h:imgH,
};
this.imgRange=imgRange;
//console.log(this.imgRange,this.imgSize);
this.setMouseRange();
this.move({
pageX:imgRange.x[0],
pageY:imgRange.y[0],
});
this._focus=this.focus.bind(this);
this._blur=this.blur.bind(this);
this._move=this.move.bind(this);
this._remove=this.remove.bind(this);
this._pause=this.pause.bind(this);
this._zoom=this.zoom.bind(this);
if(prefs.magnifier.wheelZoom.enabled){
this.zoomLevel=1;
this.defaultDia=diameter;
addWheelEvent(container,this._zoom,false);
};
container.addEventListener('mouseover',this._focus,false);
container.addEventListener('mouseout',this._blur,false);
container.addEventListener('dblclick',this._remove,false);
container.addEventListener('click',this._pause,false);
document.addEventListener('mousemove',this._move,true);
},
addStyle:function(){
if(MagnifierC.style)return;
var style=document.createElement('style');
style.type='text/css';
MagnifierC.style=style;
style.textContent='\
.pv-magnifier-container{\
position:absolute;\
padding:0;\
margin:0;\
background-origin:border-box;\
-moz-box-sizing:border-box;\
box-sizing:border-box;\
border:3px solid #CCCCCC;\
background:rgba(40, 40, 40, 0.9) no-repeat;\
}\
.pv-magnifier-container_focus{\
box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.7);\
}\
.pv-magnifier-container_pause{\
border-color:red;\
}\
';
document.querySelector('head').appendChild(style);
},
focus:function(){
this.magnifier.classList.add('pv-magnifier-container_focus');
this.magnifier.style.zIndex=MagnifierC.styleZIndex++;
},
blur:function(){
this.magnifier.classList.remove('pv-magnifier-container_focus');
},
move:function(e){
var mouseCoor={
x:e.pageX,
y:e.pageY,
};
var mouseRange=this.mouseRange;
var imgRange=this.imgRange;
if( !(mouseCoor.x >= mouseRange.x[0] && mouseCoor.x <= mouseRange.x[1] && mouseCoor.y >= mouseRange.y[0] && mouseCoor.y <= mouseRange.y[1]))return;//如果不再鼠标范围
if(mouseCoor.x > imgRange.x[1]){
mouseCoor.x = imgRange.x[1];
}else if(mouseCoor.x < imgRange.x[0]){
mouseCoor.x = imgRange.x[0];
};
if(mouseCoor.y > imgRange.y[1]){
mouseCoor.y = imgRange.y[1];
}else if(mouseCoor.y < imgRange.y[0]){
mouseCoor.y = imgRange.y[0];
};
var ms=this.magnifier.style;
ms.top= mouseCoor.y + 'px';
ms.left= mouseCoor.x + 'px';
var radius=this.radius;
var imgSize=this.imgSize;
var imgNaturalSize=this.imgNaturalSize;
var px=-((mouseCoor.x-imgRange.x[0])/imgSize.w * imgNaturalSize.w) + radius +'px';
var py=-((mouseCoor.y-imgRange.y[0])/imgSize.h * imgNaturalSize.h) + radius +'px';
//console.log(px,py);
ms.backgroundPosition=px + ' ' + py;
},
getNextZoomLevel:function(){
var level;
var self=this;
if(this.zoomOut){//缩小
MagnifierC.zoomRangeR._find(function(value){
if(value < self.zoomLevel){
level=value;
return true;
}
})
}else{
MagnifierC.zoomRange._find(function(value){
if(value > self.zoomLevel){
level=value;
return true;
};
});
}
return level;
},
zoom:function(e){
if(e.deltaY===0)return;//非Y轴的滚动
if(prefs.magnifier.wheelZoom.pauseFirst && !this.paused)return;
e.preventDefault();
if(e.deltaY < 0){//向上滚,放大;
if(this.diameter >= this.maxDia)return;
this.zoomOut=false;
}else{
this.zoomOut=true;
};
var level=this.getNextZoomLevel();
if(!level)return;
this.zoomLevel=level;
var diameter=this.defaultDia * level;
if(diameter > this.maxDia){
diameter = this.maxDia;
};
var radius=diameter/2
this.diameter=diameter;
var bRadius=this.radius;
this.radius=radius;
this.setMouseRange();
var ms=this.magnifier.style;
ms.width=diameter+'px';
ms.height=diameter+'px';
ms.borderRadius=radius+1 + 'px';
ms.marginLeft=-radius+'px';
ms.marginTop=-radius+'px';
var bBP=ms.backgroundPosition.split(' ');
ms.backgroundPosition=parseFloat(bBP[0]) + (radius - bRadius) + 'px' + ' ' + (parseFloat(bBP[1]) + ( radius - bRadius) + 'px');
},
pause:function(){
if(this.paused){
this.magnifier.classList.remove('pv-magnifier-container_pause');
document.addEventListener('mousemove',this._move,true);
}else{
this.magnifier.classList.add('pv-magnifier-container_pause');
document.removeEventListener('mousemove',this._move,true);
};
this.paused=!this.paused;
},
setMouseRange:function(){
var imgRange=this.imgRange;
var radius=this.radius;
this.mouseRange={//鼠标活动范围
x:[imgRange.x[0]-radius , imgRange.x[1] + radius],
y:[imgRange.y[0]-radius , imgRange.y[1] + radius],
};
},
remove:function(){
this.magnifier.parentNode.removeChild(this.magnifier);
document.removeEventListener('mousemove',this._move,true);
MagnifierC.all.splice(MagnifierC.all.indexOf(this),1);
},
};
//图片窗口
function ImgWindowC(img){
this.img=img;
this.src=img.src;
this.init();
};
ImgWindowC.styleZIndex=1000000000;//全局z-index;
ImgWindowC.all=[];//所有的窗口对象
ImgWindowC.zoomRange=prefs.imgWindow.zoom.range.slice(0).sort();//升序
ImgWindowC.zoomRangeR=ImgWindowC.zoomRange.slice(0).reverse();//降序
ImgWindowC.prototype={
init:function(){
var self=this;
//图片是否已经被打开
if(ImgWindowC.all._find(function(iwin){
if(iwin.src==self.src){
iwin.firstOpen();
return true;
};
}))return;
this.addStyle();
this.addRotateIndicator();
var img=this.img;
img.className='pv-pic-window-pic pv-pic-not-allowed';
img.style.cssText='\
top:0px;\
left:0px;\
';
var imgNaturalSize={
h:img.naturalHeight,
w:img.naturalWidth,
};
this.imgNaturalSize=imgNaturalSize;
var container=document.createElement('span');
container.style.cssText='\
cursor:pointer;\
top:0px;\
left:0px;\
';
container.className='pv-pic-window-container';
container.innerHTML=''+
'<span class="pv-pic-window-toolbar">'+
'<span class="pv-pic-window-tb-hand pv-pic-window-tb-tool pv-pic-window-tb-tool-selected" title="Hand Tool"></span>'+
'<span class="pv-pic-window-tb-tool-badge-container">'+
'<span class="pv-pic-window-tb-rotate pv-pic-window-tb-tool" title="Rotate | Rotar"></span>'+
'<span class="pv-pic-window-tb-tool-badge">0</span>'+
'</span>'+
'<span class="pv-pic-window-tb-tool-badge-container">'+
'<span class="pv-pic-window-tb-zoom pv-pic-window-tb-tool" title="Zoom"></span>'+
'<span class="pv-pic-window-tb-tool-badge">0</span>'+
'</span>'+
'<span class="pv-pic-window-tb-flip-horizontal pv-pic-window-tb-command" title="Giro HORIZONTAL Flip"></span>'+
'<span class="pv-pic-window-tb-flip-vertical pv-pic-window-tb-command" title="Giro VERTICAL Flip"></span>'+
'</span>'+
'<span class="pv-pic-window-close"></span>'+
'<span class="pv-pic-window-range"></span>';
container.insertBefore(img,container.firstChild);
this.imgWindow=container;
var toolMap={
'hand':container.querySelector('.pv-pic-window-tb-hand'),
'rotate':container.querySelector('.pv-pic-window-tb-rotate'),
'zoom':container.querySelector('.pv-pic-window-tb-zoom'),
'fh':container.querySelector('.pv-pic-window-tb-flip-horizontal'),
'fv':container.querySelector('.pv-pic-window-tb-flip-vertical'),
};
this.toolMap=toolMap;
this.viewRange=container.querySelector('.pv-pic-window-range');
//关闭
var closeButton=container.querySelector('.pv-pic-window-close');
closeButton.style.cssText='\
top: -24px;\
right: 0px;\
';
this.closeButton=closeButton;
closeButton.addEventListener('click',function(e){
self.remove();
},false);
var toolbar=container.querySelector('.pv-pic-window-toolbar');
toolbar.style.cssText='\
top: 0px;\
left: -45px;\
';
this.toolbar=toolbar;
this.selectedTool='hand';
this.cursor='hand';
this.selectedToolClass='pv-pic-window-tb-tool-selected';
this.hKeyUp=true;
this.rKeyUp=true;
this.zKeyUp=true;
this.spaceKeyUp=true;
this.ctrlKeyUp=true;
this.altKeyUp=true;
this.shiftKeyUp=true;
toolbar.addEventListener('mousedown',function(e){//鼠标按下选择工具
self.toolbarEventHandler(e);
},false);
toolbar.addEventListener('dblclick',function(e){//鼠标双击工具
self.toolbarEventHandler(e);
},false);
//阻止浏览器对图片的默认控制行为
img.addEventListener('mousedown',function(e){
e.preventDefault();
},false);
container.addEventListener('mousedown',function(e){//当按下的时,执行平移,缩放,旋转操作
self.imgWindowEventHandler(e);
},false);
container.addEventListener('click',function(e){//阻止opera ctrl+点击保存图片
self.imgWindowEventHandler(e);
},false);
if(prefs.imgWindow.zoom.mouseWheelZoom){//是否使用鼠标缩放
addWheelEvent(container,function(e){//滚轮缩放
self.imgWindowEventHandler(e);
},false);
};
if(prefs.imgWindow.overlayer.shown){//是否显示覆盖层
var overlayer=document.createElement('span');
this.overlayer=overlayer;
overlayer.className='pv-pic-window-overlayer';
overlayer.style.backgroundColor=prefs.imgWindow.overlayer.color;
document.body.appendChild(overlayer);
if(prefs.imgWindow.overlayer.clickToClose[0]){
overlayer.addEventListener(prefs.imgWindow.overlayer.clickToClose[1],function(e){
self.remove();
},false);
}
};
document.body.appendChild(container);
ImgWindowC.all.push(this);
this._blur=this.blur.bind(this);
this._focusedKeydown=this.focusedKeydown.bind(this);
this._focusedKeyup=this.focusedKeyup.bind(this);
this.rotatedRadians=0;//已经旋转的角度
this.zoomLevel=1;//缩放级别
this.setToolBadge('zoom',1);
//选中默认工具
this.selectTool(prefs.imgWindow.defaultTool);
this.firstOpen();
},
firstOpen:function(){
this.focus();
var imgWindow=this.imgWindow;
imgWindow.style.left=-5 + window.scrollX + 'px';
imgWindow.style.top=-5 + window.scrollY + 'px';
if(prefs.imgWindow.fitToScreen){
this.fitToScreen();
this.center(true,true);
}else{
//window的尺寸
var wSize=getWindowSize();
//空隙
wSize.h -= 16;
wSize.w -= 16;
var imgWindowCS=getComputedStyle(imgWindow,'');
var rectSize={
h:parseFloat(imgWindowCS.height),
w:parseFloat(imgWindowCS.width),
};
this.center(rectSize.w <= wSize.w , rectSize.h <= wSize.h);
};
this.keepScreenInside();
},
addStyle:function(){
if(ImgWindowC.style)return;
var style=document.createElement('style');
ImgWindowC.style=style;
style.textContent='\
.pv-pic-window-container {\
position: absolute;\
background-color: rgba(40,40,40,0.9);\
padding: 8px;\
border: 5px solid #ccc;\
line-height: 0;\
text-align: left;\
}\
.pv-pic-window-container_focus {\
box-shadow: 0 0 10px rgba(0,0,0,0.6);\
}\
.pv-pic-window-close, .pv-pic-window-toolbar {\
-webkit-transition: opacity 0.2s ease-in-out;\
transition: opacity 0.2s ease-in-out;\
}\
.pv-pic-window-toolbar {\
position: absolute;\
background-color: #535353;\
padding: 0;\
opacity: 0.9;\
display: none;\
cursor: default;\
}\
.pv-pic-window-toolbar:hover {\
opacity: 1;\
}\
.pv-pic-window-toolbar_focus {\
display: block;\
}\
.pv-pic-window-close {\
cursor: pointer;\
position: absolute;\
right: 0px;\
top: -24px;\
background: url("'+prefs.icons.close+'") no-repeat center bottom;\
height: 17px;\
width: 46px;\
opacity: 0.9;\
border:none;\
padding:0;\
padding-top:2px;\
background-color:#1771FF;\
display: none;\
}\
.pv-pic-window-close:hover {\
background-color:red;\
opacity: 1;\
}\
.pv-pic-window-close_focus {\
display: block;\
}\
.pv-pic-window-pic {\
position: relative;\
display:inline-block;\/*opera把图片设置display:block会出现渲染问题,会有残影,还会引发其他各种问题,吓尿*/\
max-width:none;\
min-width:none;\
max-height:none;\
min-height:none;\
padding:0;\
margin:0;\
}\
.pv-pic-window-pic_focus {\
box-shadow: 0 0 6px black;\
}\
.pv-pic-window-tb-tool, .pv-pic-window-tb-command{\
height: 24px;\
width: 24px;\
padding: 12px 8px 6px 6px;\
margin:0;\
display: block;\
background: transparent no-repeat center;\
cursor: pointer;\
position: relative;\
border: none;\
border-left: 2px solid transparent;\
border-bottom: 1px solid #868686;\
background-origin: content-box;\
}\
.pv-pic-window-toolbar > span:last-child {\
border-bottom: none;\
}\
.pv-pic-window-tb-tool:hover, .pv-pic-window-tb-command:hover{\
border-left: 2px solid red;\
}\
.pv-pic-window-tb-tool-selected{\
box-shadow: inset 0 21px 0 rgba(255,255,255,0.3) ,inset 0 -21px 0 rgba(0,0,0,0.3);\
border-left:2px solid #1771FF;\
}\
.pv-pic-window-tb-hand {\
background-image: url("'+prefs.icons.hand+'");\
}\
.pv-pic-window-tb-rotate {\
background-image: url("'+prefs.icons.rotate+'");\
}\
.pv-pic-window-tb-zoom {\
background-image: url("'+prefs.icons.zoom+'");\
}\
.pv-pic-window-tb-flip-horizontal {\
background-image: url("'+prefs.icons.flipHorizontal+'");\
}\
.pv-pic-window-tb-flip-vertical {\
background-image: url("'+prefs.icons.flipVertical+'");\
}\
.pv-pic-window-tb-tool-badge-container {\
display: block;\
position: relative;\
}\
.pv-pic-window-tb-tool-badge {\
position: absolute;\
top: -3px;\
right: 1px;\
font-size: 10px;\
line-height: 1.5;\
padding: 0 3px;\
background-color: #F93;\
border-radius: 50px;\
opacity: 0.5;\
color: black;\
}\
.pv-pic-window-overlayer{\
height:100%;\
width:100%;\
position:fixed;\
z-index:999999999;\
top:0;\
left:0;\
}\
.pv-pic-window-rotate-indicator{\
cursor: progress;\
position:absolute;\
z-index:1100000000;\
width:250px;\
height:250px;\
padding:10px;\
margin-top:-135px;\
margin-left:-135px;\
background:transparent url("'+ prefs.icons.rotateIndicatorBG +'") no-repeat center;\
}\
.pv-pic-window-rotate-indicator-pointer{\
display:block;\
margin-left:auto;\
margin-right:auto;\
background:transparent url("'+ prefs.icons.rotateIndicatorPointer +'") no-repeat center;\
width:60px;\
height:240px;\
position:relative;\
top:5px;\
}\
.pv-pic-window-range{\
position:absolute;\
border:none;\
width:100px;\
height:100px;\
box-shadow: 0px 0px 5px rgba(0, 0, 0, 0.8);\
display:none;\
padding:0;\
background-color:rgba(255, 0, 0, 0.150);\
}\
';
document.querySelector('head').appendChild(style);
},
addRotateIndicator:function(){
if(ImgWindowC.rotateIndicator)return;
var rotateIndicator=document.createElement('span');
rotateIndicator.className='pv-pic-window-rotate-indicator';
ImgWindowC.rotateIndicator=rotateIndicator;
rotateIndicator.style.cssText='\
display:none;\
';
var rotateIndicatorPointer=document.createElement('span');
rotateIndicatorPointer.className='pv-pic-window-rotate-indicator-pointer';
ImgWindowC.rotateIndicatorPointer=rotateIndicatorPointer;
rotateIndicator.appendChild(rotateIndicatorPointer);
document.body.appendChild(rotateIndicator);
},
keepScreenInside:function(){//保持按钮在屏幕里面.
var imgWindow=this.imgWindow;
var imgWindowFullSize={
h:imgWindow.offsetHeight,
w:imgWindow.offsetWidth,
};
var windowSize=getWindowSize();
function keepSI(obj,offsetDirection,defaultValue){
var objRect=obj.getBoundingClientRect();
var objStyle=obj.style;
while(offsetDirection.length){
var oD=offsetDirection[0];
var oDV=defaultValue[0];
offsetDirection.shift();
defaultValue.shift();
var oValue=parseFloat(objStyle[oD]);
var newValue;
switch(oD){
case 'top':{
newValue=oValue - objRect.top;
if(objRect.top<0){
newValue=Math.min(newValue,imgWindowFullSize.h);
}else{
newValue=Math.max(newValue,oDV);
};
}break;
case 'right':{
newValue=oValue + (objRect.right - windowSize.w);
if(objRect.right > windowSize.w){//屏幕外
newValue=Math.min(newValue,imgWindowFullSize.w);
}else{
newValue=Math.max(newValue,oDV);
};
}break;
case 'bottom':{
newValue=oValue + (objRect.bottom - windowSize.h);
if(objRect.bottom > windowSize.h){//屏幕外
newValue=Math.min(newValue,imgWindowFullSize.h);
}else{
newValue=Math.max(newValue,oDV);
};
}break;
case 'left':{
newValue=oValue - objRect.left;
if(objRect.left<0){
newValue=Math.min(newValue,imgWindowFullSize.w);
}else{
newValue=Math.max(newValue,oDV);
}
}break;
};
//console.log(newValue);
objStyle[oD]=newValue + 'px';
};
};
keepSI(this.closeButton,['top','right'],[-24,0]);
keepSI(this.toolbar,['top','left'],[0,-45]);
},
fitToScreen:function(){
var wSize=getWindowSize();
//空隙
wSize.h -= 16;
wSize.w -= 16;
var imgWindow=this.imgWindow;
var imgWindowCS=getComputedStyle(imgWindow,'');
var rectSize={
h:parseFloat(imgWindowCS.height),
w:parseFloat(imgWindowCS.width),
};
var size;
if(rectSize.w - wSize.w>0 || rectSize.h - wSize.h>0){//超出屏幕,那么缩小。
if(rectSize.w/rectSize.h > wSize.w/wSize.h){
size={
w:wSize.w,
h:wSize.w / (rectSize.w/rectSize.h),
};
}else{
size={
h:wSize.h,
w:wSize.h * (rectSize.w/rectSize.h),
}
};
this.zoom(this.getRotatedImgCliSize(size).w/this.imgNaturalSize.w);
};
},
center:function(horizontal,vertical){
if(!horizontal && !vertical)return;
var wSize=getWindowSize();
var imgWindow=this.imgWindow;
if(horizontal)imgWindow.style.left= (wSize.w - imgWindow.offsetWidth)/2 + window.scrollX +'px';
if(vertical)imgWindow.style.top= (wSize.h - imgWindow.offsetHeight)/2 + window.scrollY +'px';
},
move:function(e){
this.working=true;
var mouseCoor={
x:e.pageX,
y:e.pageY,
};
var imgWindow=this.imgWindow;
var imgWStyle=imgWindow.style;
var oriOffset={
left:parseFloat(imgWStyle.left),
top:parseFloat(imgWStyle.top),
};
var self=this;
var moveHandler=function(e){
imgWStyle.left=oriOffset.left+ e.pageX-mouseCoor.x +'px';
imgWStyle.top=oriOffset.top + e.pageY-mouseCoor.y +'px';
self.keepScreenInside();
};
var mouseupHandler=function(){
e.preventDefault();
self.working=false;
if(self.tempHand && self.spaceKeyUp){//如果是临时切换到抓手工具,平移完成后返回上个工具
self.tempHand=false;
self.changeCursor(self.selectedTool);
};
document.removeEventListener('mousemove',moveHandler,true);
document.removeEventListener('mouseup',mouseupHandler,true);
};
document.addEventListener('mousemove',moveHandler,true);
document.addEventListener('mouseup',mouseupHandler,true);
},
rotate:function(origin,topLeft){
var img=this.img;
var imgWindow=this.imgWindow;
var iTransform=img.style[support.cssTransform].replace(/rotate\([^)]*\)/i,'');
var imgWindowCS=getComputedStyle(imgWindow,'');
var imgRectSize={
h:parseFloat(imgWindowCS.height),
w:parseFloat(imgWindowCS.width),
};
var rectOffset={
top:parseFloat(imgWindow.style.top),
left:parseFloat(imgWindow.style.left),
};
var imgSize={
h:img.clientHeight,
w:img.clientWidth,
};
var imgOffset={
top:parseFloat(img.style.top),
left:parseFloat(img.style.left),
};
var self=this;
var PI=Math.PI;
var rotate=function (radians){
if(self.rotatedRadians==radians)return;
img.style[support.cssTransform] = ' rotate('+ radians +'rad) ' + iTransform;
ImgWindowC.rotateIndicatorPointer.style[support.cssTransform]='rotate('+ radians +'rad)';
self.rotatedRadians=radians;
self.setToolBadge('rotate',radians/(PI/180));
var afterimgRectSize=self.getRotatedImgRectSize( radians, imgSize );
imgWindow.style.width=afterimgRectSize.w +'px';
imgWindow.style.height=afterimgRectSize.h + 'px';
if(!topLeft)self.setImgWindowOffset(rectOffset,imgRectSize,afterimgRectSize);
self.setImgOffset(imgOffset,imgRectSize,afterimgRectSize);
self.keepScreenInside();
};
if(typeof origin=='number'){
rotate(origin);
return;
};
this.working=true;
var lastRotatedRadians=this.rotatedRadians;
this.shiftKeyUp=true;
var shiftRotateStep=prefs.shiftRotateStep / (180/Math.PI);//转成弧度
var moveHandler=function(e){
var radians=lastRotatedRadians + Math.atan2( e.pageY - origin.pageY, e.pageX - origin.pageX );
if(radians>2*PI){
radians-=2*PI;
}else if(radians<0){
radians+=2*PI;
};
if(!self.shiftKeyUp){//如果按下了shift键,那么步进缩放
radians -= radians % shiftRotateStep;
radians += shiftRotateStep;
};
rotate(radians);
};
var mouseupHandler=function(){
self.working=false;
ImgWindowC.rotateIndicator.style.display='none';
document.removeEventListener('mousemove',moveHandler,true);
document.removeEventListener('mouseup',mouseupHandler,true);
};
document.addEventListener('mousemove',moveHandler,true);
document.addEventListener('mouseup',mouseupHandler,true);
},
getNextZoomLevel:function(){
var level;
var self=this;
if(this.zoomOut){//缩小
ImgWindowC.zoomRangeR._find(function(value){
if(value < self.zoomLevel){
level=value;
return true;
}
})
}else{
ImgWindowC.zoomRange._find(function(value){
if(value > self.zoomLevel){
level=value;
return true;
};
});
}
return level;
},
getZoomRatio:function(mouseCoor){
var ibcRect=this.img.getBoundingClientRect();
var ratio={
x:(mouseCoor.x-ibcRect.left)/ibcRect.width,
y:(mouseCoor.y-ibcRect.top)/ibcRect.height,
};
if(ratio.x<0){
ratio.x=0
}else if(ratio.x>1){
ratio.x=1
};
if(ratio.y<0){
ratio.y=0
}else if(ratio.y>1){
ratio.y=1
};
return ratio;
},
zoom:function(e,ratio){//e可能是undefined,可能是事件对象,可能是直接的缩放级别数字
var imgWindow=this.imgWindow;
var imgWindowCS=getComputedStyle(imgWindow,'');
var imgRectSize={
h:parseFloat(imgWindowCS.height),
w:parseFloat(imgWindowCS.width),
};
var rectOffset={
top:parseFloat(imgWindow.style.top),
left:parseFloat(imgWindow.style.left),
};
var img=this.img;
var self=this;
var zoom=function(level){//缩放到指定级别
if(typeof level==='undefined' || level<0 || level==self.zoomLevel)return;
var afterImgSize={
h:self.imgNaturalSize.h * level,
w:self.imgNaturalSize.w * level,
};
img.width=afterImgSize.w;
img.height=afterImgSize.h;
var afterimgRectSize=self.getRotatedImgRectSize( self.rotatedRadians, afterImgSize );
imgWindow.style.width=afterimgRectSize.w +'px';
imgWindow.style.height=afterimgRectSize.h + 'px';
self.setImgWindowOffset(rectOffset,imgRectSize,afterimgRectSize,ratio);
self.setImgOffset({top:0,left:0},afterImgSize,afterimgRectSize);//如果旋转了,调整偏移
self.zoomLevel=level;
self.setToolBadge('zoom',level);
self.keepScreenInside();
};
if(typeof e!='object'){
ratio=ratio? ratio : {
x:1/2,
y:1/2,
};
zoom(e);
return;
};
this.working=true;
ratio=this.getZoomRatio({
x:e.clientX,
y:e.clientY,
});
var moved;
var lastPageX=e.pageX;
var currentLevel=this.zoomLevel;
var moveHandler=function(e){
moved=true;
var pageX=e.pageX;
var level;
if(pageX > lastPageX){//向右移,zoomin扩大
self.changeCursor('zoom',false);
level=0.05;
}else{//向左移,zoomout缩小
self.changeCursor('zoom',true);
level=-0.05;
};
lastPageX=pageX;
currentLevel += level;
zoom(currentLevel);
};
var mouseupHandler=function(e){
self.working=false;
document.removeEventListener('mousemove',moveHandler,true);
document.removeEventListener('mouseup',mouseupHandler,true);
var level=self.getNextZoomLevel();
if(self.zoomOut && self.altKeyUp){
self.zoomOut=false;
};
if(!moved){//如果没有平移缩放。
zoom(level);
};
self.changeCursor('zoom',self.zoomOut);
if(self.tempZoom && self.ctrlKeyUp && self.altKeyUp){
self.tempZoom=false;
self.changeCursor(self.selectedTool);
};
};
document.addEventListener('mousemove',moveHandler,true);
document.addEventListener('mouseup',mouseupHandler,true);
},
convertToValidRadians:function(radians){
//转成0-90的等价角度。
var PI=Math.PI;
if(radians > PI){
radians = 2*PI - radians;
};
if(radians > 1/2*PI){
radians = PI - radians;
};
return radians;
},
getRotatedImgRectSize:function( radians, imgSize ){//通过旋转后的角度和图片的大小,求虚拟矩形的大小
imgSize= imgSize ? imgSize :{
h:this.img.clientHeight,
w:this.img.clentWidth,
};
if(typeof radians==='undefined'){
radians = this.rotatedRadians;
};
radians=this.convertToValidRadians(radians);
return {
h:imgSize.h* Math.cos(radians) + imgSize.w * Math.sin(radians),
w:imgSize.h* Math.sin(radians) + imgSize.w * Math.cos(radians),
};
},
getRotatedImgCliSize:function(rectSize,radians){//通过虚拟矩形的大小和图片的旋转角度,求图片的大小
if(typeof radians==='undefined'){
radians = this.rotatedRadians;
};
radians=this.convertToValidRadians(radians);
if(radians==0){
//radians=Math.PI/180 * 1/100;
return rectSize;
};
var h=(rectSize.h-rectSize.w * Math.tan(radians))/(Math.cos(radians)-Math.sin(radians)*Math.tan(radians));
var w=(rectSize.h - h*Math.cos(radians))/Math.sin(radians);
return {
h:h,
w:w,
};
},
setImgOffset:function(oriOffset,bImgSize,aImgSize){
var imgStyle=this.img.style;
var top=Math.floor(oriOffset.top + (aImgSize.h-bImgSize.h)*1/2) + 'px';
var left=Math.floor(oriOffset.left + (aImgSize.w-bImgSize.w)*1/2) + 'px';
imgStyle.top= top;
imgStyle.left= left;
},
setImgWindowOffset:function(oriOffset,bImgWindowSize,aImgWidnowSize,ratio){
ratio= ratio? ratio : {x:1/2,y:1/2};
var imgWindowStyle=this.imgWindow.style;
var top=oriOffset.top - (aImgWidnowSize.h-bImgWindowSize.h)*ratio.y + 'px';
var left=oriOffset.left - (aImgWidnowSize.w-bImgWindowSize.w)*ratio.x + 'px';
imgWindowStyle.top= top;
imgWindowStyle.left= left;
},
setToolBadge:function(tool,content){
var scale=0;
switch(tool){
case 'zoom':{
scale=2;
}break;
case 'rotate':{
scale=1;
}break;
default:break;
}
content=typeof content=='string'? content : content.toFixed(scale);
this.toolMap[tool].nextElementSibling.textContent=content;
},
changeCursor:function(tool,zoomOut){
if(tool=='zoom'){
tool+=zoomOut? '-out' : '-in';
};
if(this.cursor==tool)return;
this.cursor=tool;
var imgWStyle=this.imgWindow.style;
switch(tool){
case 'hand':{
imgWStyle.cursor='pointer';
}break;
case 'zoom-in':{
imgWStyle.cursor=support.cssCursorValue.zoomIn;
}break;
case 'zoom-out':{
imgWStyle.cursor=support.cssCursorValue.zoomOut;
}break;
case 'rotate':{
imgWStyle.cursor='progress';
}break;
case 'default':{
imgWStyle.removeProperty('cursor');
}break;
default:break;
};
},
blur:function(e){
if(!this.focused)return;
var imgWindow =this.imgWindow;
//点击imgWinodw的外部的时候失去焦点
if(e!==true && (imgWindow==e.target || (imgWindow.compareDocumentPosition(e.target) & 16)))return;
imgWindow.classList.remove('pv-pic-window-container_focus');
this.toolbar.classList.remove('pv-pic-window-toolbar_focus');
this.closeButton.classList.remove('pv-pic-window-close_focus');
this.img.classList.remove('pv-pic-window-pic_focus');
document.removeEventListener('mousedown',this._blur,true);
document.removeEventListener('keydown',this._focusedKeydown,true);
document.removeEventListener('keyup',this._focusedKeyup,true);
this.changeCursor('default');
this.focused=false;
},
focus:function(){
if(this.focused)return;
this.imgWindow.classList.add('pv-pic-window-container_focus');
this.toolbar.classList.add('pv-pic-window-toolbar_focus');
this.closeButton.classList.add('pv-pic-window-close_focus');
this.img.classList.add('pv-pic-window-pic_focus');
this.imgWindow.style.zIndex= ImgWindowC.styleZIndex;
this.zIndex=ImgWindowC.styleZIndex;
ImgWindowC.styleZIndex ++;
document.addEventListener('keydown',this._focusedKeydown,true);
document.addEventListener('keyup',this._focusedKeyup,true);
document.addEventListener('mousedown',this._blur,true);
this.changeCursor(this.selectedTool);//还原鼠标样式。
this.focused=true;
},
focusedKeyup:function(e){
var keyCode=e.keyCode;
var valid=[32,18,16,72,17,72,82,90,67];
if(valid.indexOf(keyCode)==-1)return;
e.preventDefault();
switch(keyCode){
case 32:{//空格键,临时切换到移动
this.spaceKeyUp=true;
if(!this.tempHand)return;//如果之前没有临时切换到抓手工具(当已经在工作的时候,按下空格不会临时切换到抓手工具)
if(!this.working){//松开按键的时候,没有在继续平移了。
this.tempHand=false;
this.changeCursor(this.selectedTool);
};
}break;
case 18:{//alt键盘切换缩小放大。
this.altKeyUp=true;
if(!this.zoomOut)return;
if(!this.working){
this.zoomOut=false;
this.changeCursor('zoom');
if(this.tempZoom && this.ctrlKeyUp){
this.tempZoom=false;
this.changeCursor(this.selectedTool);
};
};
}break;
case 16:{//shift键,旋转的时候按住shift键,步进缩放。
this.shiftKeyUp=true;
}break;
case 17:{//ctrl键
clearTimeout(this.ctrlkeyDownTimer);
if(!this.justCKeyUp){//如果刚才没有松开c,规避划词软件的ctrl+c松开
this.ctrlKeyUp=true;
if(!this.tempZoom)return;//如果没有切换到了缩放
if(!this.working && this.altKeyUp){
this.tempZoom=false;
this.changeCursor(this.selectedTool);
};
};
}break;
case 67:{//c键
this.justCKeyUp=true;
var self=this;
clearTimeout(this.justCKeyUpTimer);
this.justCKeyUpTimer=setTimeout(function(){
self.justCKeyUp=false;
},100)
}break;
case 72:{//h键
this.hKeyUp=true;
}break;
case 82:{//r键
this.rKeyUp=true;
}break;
case 90:{//z键
this.zKeyUp=true;
}break;
default:break;
};
if([72,82,90].indexOf(keyCode)!=-1){
if(!this.working && this.restoreBeforeTool){
this.restoreBeforeTool=false;
this.selectTool(this.beforeTool);
};
};
},
focusedKeydown:function(e){
var keyCode=e.keyCode;
var valid=[32,82,72,90,18,16,17,27,67];//有效的按键
if(valid.indexOf(keyCode)==-1) return;
e.preventDefault();
if(this.working){//working的时候也可以接受按下shift键,以便旋转的时候可以任何时候按下
if(keyCode==16){//shift键
this.shiftKeyUp=false;
};
return;
};
switch(keyCode){
case 82:{//r键,切换到旋转工具
if(this.rKeyUp){
this.rKeyUp=false;
this.beforeTool=this.selectedTool;
this.selectTool('rotate');
};
}break;
case 72:{//h键,切换到抓手工具
if(this.hKeyUp){
this.hKeyUp=false;
this.beforeTool=this.selectedTool;
this.selectTool('hand');
};
}break;
case 90:{//z键,切换到缩放工具
if(this.zKeyUp){
this.zKeyUp=false;
this.beforeTool=this.selectedTool;
this.selectTool('zoom');
};
}break;
case 32:{//空格键阻止,临时切换到抓手功能
if(this.spaceKeyUp){
this.spaceKeyUp=false;
if(this.selectedTool!='hand'){
this.tempHand=true;
this.changeCursor('hand');
};
};
}break;
case 18:{//alt键,在当前选择是缩放工具的时候,按下的时候切换到缩小功能
if(this.altKeyUp){
if((this.selectedTool!='zoom' && !this.tempZoom) || this.zoomOut)return;
this.zoomOut=true;
this.altKeyUp=false;
this.changeCursor('zoom',true);
};
}break;
case 17:{//ctrl键临时切换到缩放工具
if(this.ctrlKeyUp){
var self=this;
this.ctrlkeyDownTimer=setTimeout(function(){//规避词典软件的ctrl+c,一瞬间切换到缩放的问题
self.ctrlKeyUp=false;
if(self.selectedTool!='zoom'){
self.tempZoom=true;
self.changeCursor('zoom');
};
},100);
};
}break;
case 67:{//c键
clearTimeout(this.ctrlkeyDownTimer);
}break;
case 27:{//ese关闭窗口
this.remove();
}break;
default:break;
};
},
toolbarEventHandler:function(e){
e.stopPropagation();
var target=e.target;
var toolMap=this.toolMap;
for(var i in toolMap){
if(toolMap.hasOwnProperty(i) && toolMap[i]==target){
switch(e.type){
case 'mousedown':{
this.selectTool(i);
}break;
case 'dblclick':{
this.dblclickCommand(i);
}break;
default:break;
};
break;
};
};
},
imgWindowEventHandler:function(e){
e.stopPropagation();
switch(e.type){
case 'click':{//阻止opera的图片保存
if(e.ctrlKey && e.target.nodeName=='IMG'){
e.preventDefault();
};
}break;
case 'mousedown':{
if(!this.focused){//如果没有focus,先focus
this.focus();
this.keepScreenInside();
};
var target=e.target;
if(e.button!=0 || (target!=this.imgWindow && target!=this.img))return;
var selectedTool=this.selectedTool;
if(this.tempHand){
this.move(e);
}else if(this.tempZoom){
this.zoom(e);
}else if(selectedTool=='hand'){
this.restoreBeforeTool=!this.hKeyUp;
if(this.hKeyUp){
this.move(e);
}else{//鸟瞰视图
this.aerialView(e);
};
}else if(selectedTool=='rotate'){
var rIS=ImgWindowC.rotateIndicator.style;
rIS.display='block';
var origin={//旋转原点
pageX:e.pageX - 30,//稍微偏左一点。
pageY:e.pageY,
};
rIS.top=origin.pageY + 'px';
rIS.left=origin.pageX + 'px';
ImgWindowC.rotateIndicatorPointer.style[support.cssTransform]='rotate(' + this.rotatedRadians + 'rad)';
this.restoreBeforeTool=!this.rKeyUp;
this.rotate(origin);
}else if(selectedTool=='zoom'){
this.restoreBeforeTool=!this.zKeyUp;
this.zoom(e);
};
}break;
case 'wheel':{
if(!this.focused)return;//如果没有focus
if(e.deltaY===0)return;//非Y轴的滚动
e.preventDefault();
if(this.working)return;
var oriZoomOut=this.zoomOut;
this.zoomOut = !!(e.deltaY > 0);
var ratio=this.getZoomRatio({
x:e.clientX,
y:e.clientY,
});
var level=this.getNextZoomLevel();
this.zoom(level,ratio);
this.zoomOut=oriZoomOut;
}break;
default:break;
};
},
dblclickCommand:function(tool){
var done;
switch(tool){
case 'hand':{//双击居中,并且适应屏幕
this.zoom(1);
this.fitToScreen();
this.center(true,true);
this.keepScreenInside();
}break;
case 'rotate':{//双击还原旋转
if(this.rotatedRadians==0)return;
done=true;
this.rotate(0,true);
}break;
case 'zoom':{//双击还原缩放
if(this.zoomLevel==1)return;
done=true;
this.zoom(1,{x:0,y:0});
}break;
default:break;
};
if((tool=='rotate' || tool=='zoom') && done){
var imgWindow=this.imgWindow;
var imgWinodowRect=imgWindow.getBoundingClientRect();
var imgWindowStyle=imgWindow.style;
if(imgWinodowRect.left<40){
imgWindowStyle.left=40 + window.scrollX + 'px';
};
if(imgWinodowRect.top<-5){
imgWindowStyle.top=-5 + window.scrollY +'px';
};
this.keepScreenInside();
};
},
doFlipCommand:function(command){
var map={
fv:[/scaleY\([^)]*\)/i,' scaleY(-1) '],
fh:[/scaleX\([^)]*\)/i,' scaleX(-1) '],
};
var iTransform=this.img.style[support.cssTransform];
var toolClassList=this.toolMap[command].classList;
if(map[command][0].test(iTransform)){
iTransform=iTransform.replace(map[command][0],'');
toolClassList.remove(this.selectedToolClass);
}else{
iTransform += map[command][1];
toolClassList.add(this.selectedToolClass);
};
this.img.style[support.cssTransform]=iTransform;
},
selectTool:function(tool){
var command=['fv','fh'];
if(command.indexOf(tool)==-1){//工具选择
if(this.selectedTool==tool)return;
var selectedTool=this.selectedTool;
this.selectedTool=tool;
if(this.tempHand || this.tempZoom){//临时工具中。不变鼠标
return;
};
this.toolMap[selectedTool].classList.remove(this.selectedToolClass);
this.toolMap[tool].classList.add(this.selectedToolClass);
this.changeCursor(tool);
}else{//命令
this.doFlipCommand(tool);
};
},
remove:function(){
if(this.removed)return;
this.removed=true;
this.blur(true);
this.img.src='';//如果在加载中取消,图片也取消读取。
if(this.overlayer){
this.overlayer.parentNode.removeChild(this.overlayer);
};
this.imgWindow.parentNode.removeChild(this.imgWindow);
var index=ImgWindowC.all.indexOf(this);
ImgWindowC.all.splice(index,1);
//focus next
var topmost=0;
ImgWindowC.all.forEach(function(iwin){
if(iwin.zIndex > topmost){
topmost=iwin;
};
});
if(topmost){
topmost.focus();
};
},
aerialView:function(e){
this.working=true;
//记住现在的缩放比例
var cLevel=this.zoomLevel;
var wSize=getWindowSize();
wSize.h -= 16;
wSize.w -= 16;
var imgWindow=this.imgWindow;
var imgWindowCS=getComputedStyle(imgWindow,'');
var rectSize={
h:parseFloat(imgWindowCS.height),
w:parseFloat(imgWindowCS.width),
};
var rectRatio=rectSize.h/rectSize.w;
var windowRatio=wSize.h/wSize.w;
var size;
var rangeSize={};
if(rectRatio > windowRatio){
size={
h:wSize.h,
w:wSize.h / rectRatio,
};
rangeSize.h=Math.min(wSize.h * (size.h / rectSize.h), size.h);
rangeSize.w=Math.min(rangeSize.h / windowRatio , size.w);
}else{
size={
w:wSize.w,
h:wSize.w * rectRatio,
};
rangeSize.w=Math.min(wSize.w * (size.w / rectSize.w), size.w);
rangeSize.h=Math.min(rangeSize.w * windowRatio , size.h);
};
this.zoom(this.getRotatedImgCliSize(size).w/this.imgNaturalSize.w);
this.center(true,true);
this.keepScreenInside();
var viewRange=this.viewRange;
var vRS=viewRange.style;
vRS.display='block';
vRS.height=rangeSize.h + 'px';
vRS.width=rangeSize.w + 'px';
vRS.top=0 + 'px';
vRS.left=0 + 'px';
var viewRangeRect=viewRange.getBoundingClientRect();
var viewRangeCenterCoor={
x:viewRangeRect.left + window.scrollX + 1/2 * rangeSize.w,
y:viewRangeRect.top + window.scrollY + 1/2 * rangeSize.h,
};
var self=this;
var moveRange={
x:[8,8+size.w-rangeSize.w],
y:[8,8+size.h-rangeSize.h]
};
function setViewRangePosition(pageXY){
var top=pageXY.y - viewRangeCenterCoor.y;
var left=pageXY.x - viewRangeCenterCoor.x;
if(top<=moveRange.y[0]){
top=moveRange.y[0];
}else if(top>=moveRange.y[1]){
top=moveRange.y[1];
};
vRS.top= top + 'px';
if(left<=moveRange.x[0]){
left=moveRange.x[0];
}else if(left>=moveRange.x[1]){
left=moveRange.x[1];
};
vRS.left= left + 'px';
};
setViewRangePosition({
x:e.pageX,
y:e.pageY,
});
var moveHandler=function(e){
setViewRangePosition({
x:e.pageX,
y:e.pageY,
});
};
var mouseupHandler=function(){
self.working=false;
viewRange.style.display='none';
self.zoom(cLevel);
imgWindow.style.top= -13 - rectSize.h * ((parseFloat(vRS.top) - moveRange.y[0])/size.h) + window.scrollY +'px';
imgWindow.style.left= -13 - rectSize.w * ((parseFloat(vRS.left) - moveRange.x[0])/size.w) + window.scrollX +'px';
//说明图片的高度没有屏幕高,居中
//说明图片的宽度没有屏幕宽,居中
self.center(rangeSize.w == size.w , rangeSize.h == size.h);
self.keepScreenInside();
document.removeEventListener('mousemove',moveHandler,true);
document.removeEventListener('mouseup',mouseupHandler,true);
};
document.addEventListener('mousemove',moveHandler,true);
document.addEventListener('mouseup',mouseupHandler,true);
},
};
//载入动画
function LoadingAnimC(data,buttonType,waitImgLoad,openInTopWindow){
this.data=data;//data
this.buttonType=buttonType;//点击的按钮类型
this.openInTopWindow=openInTopWindow;//是否在顶层窗口打开,如果在frame里面的话
this.waitImgLoad=waitImgLoad;//是否等待完全读取后打开
this.init();
};
LoadingAnimC.all=[];
LoadingAnimC.prototype={
init:function(){
LoadingAnimC.all.push(this);
this.addStyle();
var container=document.createElement('span');
container.classList.add('pv-loading-container');
this.loadingAnim=container;
container.title='正在加载:' + this.data.src;
container.innerHTML=''+
'<span class="pv-loading-error" style="display:none;">Error</span>'+
'<span class="pv-loading-cancle" title="取消"></span>';
var loadingError=container.querySelector('.pv-loading-error');
var loadingCancle=container.querySelector('.pv-loading-cancle');
this.loadingError=loadingError;
this.loadingCancle=loadingCancle;
var self=this;
loadingCancle.addEventListener('click',function(e){
self.imgReady.abort();
self.remove();
},true);
document.body.appendChild(container);
this.setPosition();
var img=new Image();
img.src= this.buttonType=='current'? this.data.imgSrc : this.data.src;
var opts={
error:function(e){
self.error(this,e);
},
};
opts[this.waitImgLoad? 'load' : 'ready' ]=function(e){
self.load(this,e);
};
this.imgReady=imgReady(img,opts);
},
addStyle:function(){
if(LoadingAnimC.styleAdded)return;
LoadingAnimC.styleAdded=true;
var style=document.createElement('style');
style.type='text/css';
style.textContent='\
.pv-loading-container {\
position: absolute;\
z-index:999999997;\
top: 100px;\
left: 100px;\
background-color: black;\
background-image: url("'+prefs.icons.loading+'");\
background-repeat: no-repeat;\
background-position: center;\
background-origin: content-box;\
border: none;\
padding: 1px 30px 1px 2px;\
margin: 0;\
opacity: 0.6;\
height: 24px;\
min-width: 24px;\
box-shadow: 2px 2px 0px #666;\
-webkit-transition: opacity 0.15s ease-in-out;\
transition: opacity 0.15s ease-in-out;\
}\
.pv-loading-container:hover {\
opacity: 0.9;\
}\
.pv-loading-cancle {\
cursor: pointer;\
background-image: url("'+prefs.icons.loadingCancle+'");\
height: 24px;\
width: 24px;\
position: absolute;\
right: 0;\
top: 0;\
opacity: 0.2;\
display: block;\
-webkit-transition: opacity 0.15s ease-in-out;\
transition: opacity 0.15s ease-in-out;\
}\
.pv-loading-cancle:hover {\
opacity: 1;\
}\
.pv-loading-error {\
line-height: 24px;\
color: red;\
font-size: 12px;\
}\
';
document.querySelector('head').appendChild(style);
},
remove:function(){
if(!this.removed){
this.removed=true;
this.loadingAnim.parentNode.removeChild(this.loadingAnim);
LoadingAnimC.all.splice(LoadingAnimC.all.indexOf(this),1);
};
},
error:function(img,e){
this.loadingAnim.style.backgroundImage='none';
this.loadingError.style.removeProperty('display');
var self=this;
setTimeout(function(){
self.remove();
},2000)
},
setPosition:function(){
var position=getTargetPosition(this.data.img);
var cs=this.loadingAnim.style;
cs.top=position.top +1 + 'px';
cs.left=position.left +1 + 'px';
cs.removeProperty('display');
},
load:function(img,e){
this.remove();
this.img=img;
var buttonType=this.buttonType;
if(buttonType=='gallery'){
var allData=this.getAllValidImgs();
allData.target=this.data;
this.data=allData;
};
if(this.openInTopWindow && isFrame && buttonType!='magnifier'){
var data=this.data;
//删除不能发送的项。
var delCantClone=function(obj){
delete obj.img;
delete obj.imgPA;
};
if(Array.isArray(data)){
delCantClone(data.target);
data.forEach(function(obj){
delCantClone(obj);
});
}else{
delCantClone(data);
};
window.postMessage({
messageID:messageID,
src:img.src,
data:data,
buttonType:buttonType,
to:'top',
},'*');
}else{
this.open();
};
},
getAllValidImgs:function(){
var imgs=document.getElementsByTagName('img'),//html collection
validImgs=[]
;
arrayFn.forEach.call(imgs,function(img,index,imgs){
var result=findPic(img);
if(result){
validImgs.push(result);
};
});
return validImgs;
},
open:function(){
switch(this.buttonType){
case 'gallery':{
if(!gallery){
gallery=new GalleryC();
};
gallery.load(this.img,this.data,this.from);
}break;
case 'magnifier':{
new MagnifierC(this.img,this.data);
}break;
case 'actual':;
case 'current':;
case 'original':{//original 是为了兼容以前的规则
new ImgWindowC(this.img);
}break;
};
},
};
//工具栏
function FloatBarC(){
this.init();
};
FloatBarC.prototype={
init:function(){
this.addStyle();
var container=document.createElement('span');
container.id='pv-float-bar-container';
//innerHTML中的span不能加空格
container.innerHTML=''+
'<span class="pv-float-bar-button"></span>'+
'<span class="pv-float-bar-button"></span>'+
'<span class="pv-float-bar-button"></span>'+
'<span class="pv-float-bar-button"></span>';
document.body.appendChild(container);
var buttons={};
this.buttons=buttons;
this.children=container.children;
arrayFn.forEach.call(this.children,function(child,index,children){
var titleMap={
actual:'Tamaño REAL Size',
gallery:'Picture Gallery | Galeria de Imágenes',
current:'Current Size | Tamaño Actual',
magnifier:'Lupa | Magnifier',
};
var buttonName=prefs.floatBar.butonOrder[index];
buttons[buttonName]=child;
child.title=titleMap[buttonName];
child.classList.add('pv-float-bar-button-' + buttonName);
});
this.floatBar=container;
this.shown=true;
this.preShownImg=null;
var self=this;
container.addEventListener('click',function(e){
var buttonType;
var target=e.target;
for(var type in buttons){
if(!buttons.hasOwnProperty(type))return;
if(target==buttons[type]){
buttonType=type;
break;
};
};
if(!buttonType)return;
self.hide();
self.open(e,buttonType);
},true);
addCusMouseEvent('mouseleave',container,function(e){
clearTimeout(self.hideTimer);
self.hideTimer=setTimeout(function(){
self.hide();
},prefs.floatBar.hideDelay);
});
addCusMouseEvent('mouseenter',container,function(e){
clearTimeout(self.hideTimer);
});
},
addStyle:function(){
var style=document.createElement('style');
style.type='text/css';
style.textContent='\
#pv-float-bar-container {\
position: absolute;\
z-index:999999998;\
top: -100px;\
left: -100px;\
padding: 5px;\
margin: 0;\
border: none;\
opacity: 0.6;\
line-height: 0;\
-webkit-transition: opacity 0.2s ease-in-out;\
transition: opacity 0.2s ease-in-out;\
}\
#pv-float-bar-container:hover {\
opacity: 1;\
}\
.pv-float-bar-button {\
cursor: pointer;\
width: 18px;\
height: 18px;\
padding: 1px;\
margin: 0;\
border: none;\
display: inline-block;\
position: relative;\
border-radius: 100px;\
box-shadow: 1px 1px 3px 0px black;\
background-color: transparent;\
background-repeat: no-repeat;\
background-origin: content-box;\
background-clip: content-box;\
background-size: 100% 100%;\
-webkit-transition: margin-left 0.15s ease-in-out, width 0.15s ease-in-out, height 0.15s ease-in-out;\
transition: margin-left 0.15s ease-in-out, width 0.15s ease-in-out, height 0.15s ease-in-out;\
}\
.pv-float-bar-button:nth-child(n+2){\
margin-left: -16px;\
}\
.pv-float-bar-button:first-child {\
z-index: 4;\
}\
.pv-float-bar-button:nth-child(2) {\
z-index: 3;\
}\
.pv-float-bar-button:nth-child(3) {\
z-index: 2;\
}\
.pv-float-bar-button:last-child {\
z-index: 1;\
}\
#pv-float-bar-container:hover > .pv-float-bar-button {\
width: 24px;\
height: 24px;\
}\
#pv-float-bar-container:hover > .pv-float-bar-button:nth-child(n+2) {\
margin-left: 0;\
}\
.pv-float-bar-button-actual {\
background-image:url("'+ prefs.icons.actual +'");\
background-color: red;\
}\
.pv-float-bar-button-gallery {\
background-image:url("'+ prefs.icons.gallery +'");\
background-color: yellow;\
}\
.pv-float-bar-button-current {\
background-image:url("'+ prefs.icons.current +'");\
background-color: blue;\
}\
.pv-float-bar-button-magnifier {\
background-image:url("'+ prefs.icons.magnifier +'");\
background-color: pink;\
}\
';
document.querySelector('head').appendChild(style);
},
start:function(data){
//读取中的图片,不显示浮动栏,调整读取图标的位置.
if(LoadingAnimC.all._find(function(item,index,array){
if(data.img==item.data.img){
return true;
};
}))return;
//被放大镜盯上的图片,不要显示浮动栏.
if(MagnifierC.all._find(function(item,index,array){
if(data.img==item.data.img){
return true;
};
}))return;
this.data=data;
var self=this;
clearTimeout(this.hideTimer);
var imgOutHandler=function(e){
document.removeEventListener('mouseout',imgOutHandler,true);
clearTimeout(self.showTimer);
clearTimeout(self.hideTimer);
self.hideTimer=setTimeout(function(){
self.hide();
},prefs.floatBar.hideDelay);
};
clearTimeout(this.globarOutTimer);
this.globarOutTimer=setTimeout(function(){//稍微延时。错开由于css hover样式发生的out;
document.addEventListener('mouseout',imgOutHandler,true);
},100);
if(data.img==this.preShownImg && this.shown){
this.setPosition();
return;
};
clearTimeout(this.showTimer);
this.showTimer=setTimeout(function(){
self.show();
},prefs.floatBar.showDelay);
},
setButton:function(){
if(this.data.type=='force'){
this.buttons['actual'].style.display='none';
this.buttons['magnifier'].style.display='none';
}else{
this.buttons['actual'].style.removeProperty('display');
this.buttons['magnifier'].style.removeProperty('display');
};
//如果隐藏的按钮是第一个,css弹出层叠按钮的动画会有些维和,这些修正一下。
var firstHidden;
arrayFn._find.call(this.children,function(child, index, children){
var cs=child.style;
if(index==0){
if(cs.display=='none'){
firstHidden=true;
};
};
if(firstHidden){//如果第一个是隐藏的,那么去掉以后第一个非隐藏的marginleft
if(cs.display!='none'){
cs.marginLeft=0;
return true;
};
}else{
cs.removeProperty('margin-left');
};
});
},
setPosition:function(){
//如果图片被删除了,或者隐藏了。
var bCR=this.data.img.getBoundingClientRect();
if((bCR.left==0 && bCR.right==0) || (bCR.top==0 && bCR.bottom==0))return false;
var targetPosi=getTargetPosition(this.data.img);
var windowSize=getWindowSize();
var floatBarPosi=prefs.floatBar.position.toLowerCase().trim().split(/\s+/);
var offsetX=prefs.floatBar.offset.x;
var offsetY=prefs.floatBar.offset.y;
var scrollXY={
x:window.scrollX,
y:window.scrollY,
};
var fbs=this.floatBar.style;
var setPosition={
top:function(){
var top=targetPosi.top;
if(targetPosi.t < -offsetY){//满足图标被遮住的条件.
top=scrollXY.y;
offsetY=0;
};
fbs.top=top + offsetY + 'px';
},
right:function(){
var right=windowSize.w - targetPosi.r;
if(right < offsetX){
right= -scrollXY.x;
offsetX=0;
}else{
right -=scrollXY.x;
};
fbs.right=right - offsetX + 'px';
},
bottom:function(){
var bottom=windowSize.h-targetPosi.b;
if(bottom <= offsetY){
offsetY=0;
};
bottom -= scrollXY.y;
fbs.bottom=bottom - offsetY + 'px';
},
left:function(){
var left=targetPosi.left;
if(targetPosi.l < -offsetX){
left=scrollXY.x;
offsetX=0;
};
fbs.left=left + offsetX + 'px';
},
};
setPosition[floatBarPosi[0]]();
setPosition[floatBarPosi[1]]();
},
show:function(){
if(this.setPosition()===false){
return;
};
this.preShownImg=this.data.img;
this.shown=true;
this.setButton();
this.floatBar.style.removeProperty('display');
clearTimeout(this.hideTimer);
},
hide:function(){
clearTimeout(this.showTimer);
this.shown=false;
this.floatBar.style.display='none';
},
open:function(e,buttonType){
var waitImgLoad=e.ctrlKey? !prefs.waitImgLoad : prefs.waitImgLoad;//按住ctrl取反向值
var openInTopWindow=e.shiftKey? !prefs.framesPicOpenInTopWindow : prefs.framesPicOpenInTopWindow;//按住shift取反向值
if(!waitImgLoad && buttonType=='magnifier' && !envir.chrome){//非chrome的background-image需要全部载入后才能显示出来
waitImgLoad=true;
};
new LoadingAnimC(this.data,buttonType,waitImgLoad,openInTopWindow);
},
};
var matchedRule,
URL=location.href,
floatBar
;
function findPic(img){
var imgPA=getElementByXpath('./ancestor::a[1]',img);
var iPASrc=imgPA? imgPA.href : '';
//base64字符串过场导致正则匹配卡死浏览器
var base64Img=/^data:[^;]+;base64,/i.test(img.src);
if(matchedRule===undefined){//找到符合站点的高级规则,并缓存.
matchedRule=siteInfo._find(function(site,index,array){
if(site.enabled && site.url && site.url.test(URL)){
return true;
};
});
matchedRule=matchedRule? matchedRule[0] : false;
//console.log('匹配的规则:',matchedRule);
};
var src, type;
if(!src && matchedRule){//通过高级规则获取.
try{
src=matchedRule.getImage.call(img,img,imgPA);
}catch(err){
throwErrorInfo(err);
};
if(src)type='rule';
};
if(!src && !base64Img){//遍历通配规则
tprules._find(function(rule,index,array){
try{
src=rule.call(img,img,imgPA);
if(src){
//console.log('匹配的通配规则',rule);
return true;
};
}catch(err){
throwErrorInfo(err);
};
});
if(src)type='tpRule';
};
if(!src && imgPA){//链接可能是一张图片...
if(/\.(?:jpg|jpeg|png|gif|bmp)$/i.test(iPASrc)){
src=iPASrc;
};
if(src)type='scale';
};
if(!src){//本图片是否被缩放.
var imgAS={//实际尺寸。
h:img.naturalHeight,
w:img.naturalWidth,
};
var imgCS=getCurrentSize(img);
if(!(imgAS.w==imgCS.w && imgAS.h==imgCS.h)){//如果不是两者完全相等,那么被缩放了.
if(imgAS.h > prefs.floatBar.minSizeLimit.h || imgAS.w > prefs.floatBar.minSizeLimit.w){//最小限定判断.
src=img.src;
type='scale';
};
}else{
if(prefs.floatBar.forceShow.enabled && (imgCS.w>=prefs.floatBar.forceShow.size.w && imgCS.h>=prefs.floatBar.forceShow.size.h)){
src=img.src;
type='force';
};
};
};
if(!src)return;
var ret={
src:src,//得到的src
type:type,//通过哪种方式得到的
imgSrc:img.src,//处理的图片的src
iPASrc:iPASrc,//图片的第一个父a元素的链接地址
img:img,//处理的图片
imgPA:imgPA,//图片的第一个父a元素
};
//console.log('图片查找结果:',ret);
return ret;
};
var isFrame=window!=window.parent;
window.addEventListener('message',function(e){//contentscript里面的message监听,监听来自别的窗口的数据。
var data=e.data;
if( !data || !data.messageID || data.messageID != messageID )return;//通信ID认证
var source=e.source;
if(typeof source=='undefined' || source!==window){//来自别的窗口
if(!isFrame){//顶层窗口
//console.log('top-contentscript接收到:',e);
/*
window.postMessage({
messageID:messageID,
to:data.from,
data:'hello',
},'*');
*/
var img=new Image();
img.src=data.src;
imgReady(img,{
ready:function(){
LoadingAnimC.prototype.open.call({
img:img,
data:data.data,
buttonType:data.buttonType,
from:data.from,//来自哪个窗口
});
},
});
}else{//frame窗口
//console.log('frame-contentscript接收到',e);
};
};
},true);
//页面脚本用来转发消息
//原因chrome的contentscript无法访问非自己外的别的窗口。都会返回undefined,自然也无法向其他的窗口发送信息,这里用pagescript做个中间代理
//通讯逻辑..A页面的contentscript发送到A页面的pagescript,pagescript转交给B页面的contentscript
var messageID='pv-0.5106795670312598';
var pageScript=document.createElement('script');
var pageScriptText=function(messageID){
var frameID=Math.random();
var frames={
top:window.top,
};
window.addEventListener('message',function(e){
var data=e.data;
if( !data || !data.messageID || data.messageID != messageID )return;//通信ID认证
var source=e.source;
if(source===window){//来自contentscript,发送出去
data.from=frameID;
frames[data.to].postMessage(data,'*');
}else{//来自别的窗口的,contentscript可以直接接收,这里保存下来自的窗口的引用
frames[data.from]=source;
};
},true)
};
pageScript.textContent='(' + pageScriptText.toString() + ')('+ JSON.stringify(messageID) +')';
document.querySelector('head').appendChild(pageScript);
function clikToOpen(data){
var preventDefault = matchedRule.clikToOpen.preventDefault;
function mouseout(){
document.removeEventListener('mouseout',mouseout,true);
document.removeEventListener('click',click,true);
if(data.imgPA && preventDefault){
data.imgPA.removeEventListener('click',clickA,false);
};
};
function click(e){
FloatBarC.prototype.open.call({
data:data,
},
e,
matchedRule.clikToOpen.type);
};
function clickA(e){//阻止a的默认行为
e.preventDefault();
};
document.addEventListener('click',click,true);
if(data.imgPA && preventDefault){
data.imgPA.addEventListener('click',clickA,false);
};
setTimeout(function(){//稍微延时。错开由于css hover样式发生的out;
document.addEventListener('mouseout',mouseout,true);
},100);
return function(){
mouseout()
};
};
//监听 mouseover
var canclePreCTO;
function globalMouseoverHandler(e){
if(galleryMode)return;//库模式全屏中......
var target=e.target;
if(target.nodeName!='IMG' || target.classList.contains('pv-pic-not-allowed')){
return;
};
var result=findPic(target);
if(result){
if(!floatBar){
floatBar=new FloatBarC();
};
if(result.type=='rule' && matchedRule.clikToOpen && matchedRule.clikToOpen.enabled){
if(canclePreCTO){//取消上次的,防止一次点击打开多张图片
canclePreCTO();
};
canclePreCTO=clikToOpen(result);
};
floatBar.start(result);//出现悬浮工具栏
};
};
document.addEventListener('mouseover',globalMouseoverHandler,true);
};
function init2(){
init(topObject,window,document,arrayFn,envir);
};
var arrayFn=(function(){
//Array的某些方法对所有的类数组都有效,比如HTMLCollection,NodeList
//添加一个当函数返回true时,返回[array[index],index],并且跳出循环的方法
//类似做到 for 循环,在满足条件的时候直接break跳出的效果。
if(typeof Array.prototype['_find']!='function'){
Object.defineProperty(Array.prototype,'_find',{
value:function(callback , thisArg){
if (this == null){
throw new TypeError( "this is null or not defined" );
};
if(typeof callback != 'function') {
throw new TypeError( callback + " is not a function" );
};
var i = 0,
l = this.length,
value,
hasOwnProperty=Object.prototype.hasOwnProperty
;
while(i<l){
if(hasOwnProperty.call(this,i)){
value = this[i];
if(callback.call( thisArg, value, i, this )===true){
return [value,i,this];
};
};
i++;
};
},
writable:true,
enumerable:false,//与原生方法一样不可枚举,维护网页和谐。。。
configurable:true,
});
};
var arrayProto=Array.prototype;
return {
_find:arrayProto._find,
slice:arrayProto.slice,
forEach:arrayProto.forEach,
some:arrayProto.some,
every:arrayProto.every,
map:arrayProto.map,
filter:arrayProto.filter,
indexOf:arrayProto.indexOf,
lastIndexOf:arrayProto.lastIndexOf,
};
})();
//检测运行环境
var envir={
opera:!!window.opera,
chrome:!!window.chrome,
firefox:typeof XPCNativeWrapper=='function'? true : false,
};
if(document.readyState=='loading'){
document.addEventListener('DOMContentLoaded',init2,true);
}else if(document.readyState!='complete'){
document.addEventListener('DOMContentLoaded',function(){
window.removeEventListener('load',init2,true);
init2();
},true);
window.addEventListener('load',init2,true);
}else{
init2();
};
})(this,window,document)
}{ var greasedLightbox = {
aspectRatio : null,
timer : null,
slideTime : 3,
currentAddress : null,
allImageLinks : [],
currentImagePosition : 0,
lastMove : 1,
isShowing : false,
isSlideShow : false,
searchDefs : [
// wikipedia (needs to come before 'show')
{
name : 'wikipedia',
includeRegExp : /^https?:\/\/(.*?\.)?wikipedia\.org/i,
linkRegExp : /.*?\/(Fi(le?|xter|txategi|gura|n?ch(ier|eiro))|Fa(il|sciculus)|Dat(oteka|ei)|Delwedd|Dosiero|Be(stand|rkas)|Billede|Skeudenn|Soubor|Slika|Pilt|Archivo|Mynd|Vaizdas|Tiedosto|Larawan|Resim):.*\.(jpe?g|gif|png)$/i,
findImageRegExp : /(.+?)\/thumb\/(.+?)\.(jpe?g|gif|png).*$/i,
replaceString : '$1/$2.$3',
showFunction : function(event) { greasedLightbox.showFrom(event, 'wikipedia'); return false; }
}, // wikipedia
// imagesocket (needs to come before 'show')
{
name : 'imagesocket',
includeRegExp : /./, // used on every page
linkRegExp : /^(https?:\/\/)(.*?\.)?imagesocket\.com\/(view|thumbs)\/(.*?\.(jpe?g|gif|png))$/i,
replaceString : '$1content.imagesocket.com/images/$4',
showFunction : function(event) { greasedLightbox.showFrom(event, 'imagesocket'); return false; }
}, // imagesocket
// imagesocket site (needs to come before 'show')
{
name : 'imagesocketSite',
includeRegExp : /^https?:\/\/(.*?\.)?imagesocket\.com/i,
linkRegExp : /^\/view\/(.*?\.(jpe?g|gif|png))$/i,
replaceString : 'http://content.imagesocket.com/images/$1',
showFunction : function(event) { greasedLightbox.showFrom(event, 'imagesocketSite'); return false; }
}, // imagesocket site
// blogger/blogspot (needs to come before 'show')
{
name : 'blogger',
includeRegExp : /^https?:\/\/(.*?\.)?blog(ger|spot)\.com/i,
linkRegExp : /^(https?:\/\/.*?\.blogger\.com\/.*?\/.*?\/.*?\/.*?)\/.*?-h(\/.*?\.(jpe?g|gif|png))$/i,
replaceString : '$1$2',
showFunction : function(event) { greasedLightbox.showFrom(event, 'blogger'); return false; }
}, // blogger/blogspot
// radikal.ru
{
name : 'radikal',
includeRegExp : /./, // used in every page
linkRegExp : /http:\/\/(radikal.ru\/F\/)?(.*\.(jpg|png))(\.html)?$/i,
replaceString : 'http://$2',
showFunction : function(event) { greasedLightbox.showFrom(event, 'radikal'); return false; }
}, // radikal.ru
// regular links to images
{
name : 'show',
includeRegExp : /./, // used on every page
linkRegExp : /.*?\.(jpe?g|gif|png)$/i,
excludeLinkRegExp : /\?/i,
showFunction : function(event) { greasedLightbox.show(event); return false; }
}, // regular links to images
// picasa
/* "view in original context" is not worked propertly */
{
name : 'picasa',
includeRegExp : /./, // used on every page
linkRegExp : /https?:\/\/picasaweb\.google\..*\/.+/i,
findImageRegExp : /^(https?:\/\/.*)\/s[0-9]+\/(.*)\.jpg$/i,
replaceString : '$1/s1024/$2.jpg',
showFunction : function(event) { greasedLightbox.showFrom(event, 'picasa'); return false; }
},
// ipicture/upload
{
name : 'ipicture',
includeRegExp : /./, // used on every page
linkRegExp : /http:\/\/ipicture\.ru\/upload\/(.*(jpg|png|jpeg|gif))$/i,
replaceString : 'http://ipicture.ru/upload/$1',
showFunction : function(event) { greasedLightbox.showFrom(event, 'picasa'); return false; }
},
// search engine images (google, yahoo, ask jeeves, blingo)
{
name : 'search',
includeRegExp : /^https?:\/\/(.*?\.)?(google\..*|search\.yahoo\.com|blingo\.com\/images)/i,
linkRegExp : /.*?(im(age|g)(ur(i|l)|src))=(http(s?):\/\/)?(.*?)&.*/i,
replaceString : 'http$6://$7',
showFunction : function(event) { greasedLightbox.showFrom(event, 'search'); return false; }
}, // search engine images
// doubanpic
{
name : 'doubanpic',
includeRegExp : /^http:\/\/www\.douban\.com\/subject\/[0-9]+\//i,
linkRegExp : /^(http:\/\/t\.douban\.com\/)l(pic\/s[0-9]+\.jpg)/i,
replaceString : '$1m$2',
showFunction : function(event) { greasedLightbox.showFrom(event, 'doubanpic'); return false; }
}, // doubanpic
// doubanphoto
{
name : 'doubanphoto',
includeRegExp : /^http:\/\/www\.douban\.com\/photos\/album\/[0-9]+\//i,
linkRegExp : /^http:\/\/www\.douban\.com\/photos\/photo\/([0-9]+)\/$/i,
replaceString : 'http://t.douban.com/view/photo/photo/public/p$1.jpg',
showFunction : function(event) { greasedLightbox.showFrom(event, 'doubanphoto'); return false; }
}, // doubanphoto
// doubanevent
{
name : 'doubanevent',
includeRegExp : /^http:\/\/www\.douban\.com\/event\/album\/[0-9]+\//i,
linkRegExp : /^http:\/\/www\.douban\.com\/event\/photo\/([0-9]+)\/$/i,
replaceString : 'http://t.douban.com/view/photo/photo/public/p$1.jpg',
showFunction : function(event) { greasedLightbox.showFrom(event, 'doubanevent'); return false; }
}, // doubanevent
// doubanonline
{
name : 'doubanonline',
includeRegExp : /^http:\/\/www\.douban\.com\/online\/[0-9]+\/album\/[0-9]+\//i,
linkRegExp : /^http:\/\/www\.douban\.com\/online\/[0-9]+\/photo\/([0-9]+)\/$/i,
replaceString : 'http://img2.douban.com/view/photo/photo/public/p$1.jpg',
showFunction : function(event) { greasedLightbox.showFrom(event, 'doubanonline'); return false; }
}, // doubanonline
// doubanartist1
{
name : 'doubanartist1',
includeRegExp : /^http:\/\/www\.douban\.com\/artist\/[a-z]+\/album\/[0-9]+\//i,
linkRegExp : /^http:\/\/www\.douban\.com\/artist\/[a-z]+\/photo\/([0-9]+)\/$/i,
replaceString : 'http://t.douban.com/view/photo/photo/public/p$1.jpg',
showFunction : function(event) { greasedLightbox.showFrom(event, 'doubanartist1'); return false; }
}, // artist1
// doubanartist2
{
name : 'doubanartist2',
includeRegExp : /^http:\/\/www\.douban\.com\/artist\/[a-z]+\/public_album\/[0-9]+\//i,
linkRegExp : /^http:\/\/www\.douban\.com\/artist\/[a-z]+\/public_photo\/([0-9]+)\/$/i,
replaceString : 'http://t.douban.com/view/photo/photo/public/p$1.jpg',
showFunction : function(event) { greasedLightbox.showFrom(event, 'doubanartist2'); return false; }
}, // doubanartist2
// flickr
{
name : 'flickr',
includeRegExp : /^https?:\/\/(.*?\.)?flickr\.com/i,
linkRegExp : /\/photos\/[^\/]+\/[0-9]+/i,
findImageRegExp : /_[tsm]\.jpg/i,
replaceString : '.jpg',
showFunction : function(event) { greasedLightbox.showFrom(event, 'flickr'); return false; }
}, // flickr
// facebook
/* removed support because they now have nice built-in image viewing features
{
name : 'facebook',
includeRegExp : /^https?:\/\/(.*?\.)?facebook\.com/i,
linkRegExp : /photo\.php\?pid=[0-9]+/i,
findImageRegExp : /[st]([0-9]+.*?)\.jpg/i,
replaceString : 'n$1.jpg',
showFunction : function(event) { greasedLightbox.showFrom(event, 'facebook'); return false; }
}, // facebook
*/
// myspace1
{
name : 'myspace1',
includeRegExp : /^https?:\/\/(.*?\.)?myspace\.com/i,
linkRegExp : /imageID=[0-9]+/i,
findImageRegExp : /m_(.+)\.jpg/i,
replaceString : 'l_$1.jpg',
showFunction : function(event) { greasedLightbox.showFrom(event, 'myspace1'); return false; }
}, // myspace1
// myspace2
{
name : 'myspace2',
includeRegExp : /^https?:\/\/(.*?\.)?myspace\.com/i,
linkRegExp : /imageID/i,
findImageRegExp : /_m/i,
replaceString : '_l',
showFunction : function(event) { greasedLightbox.showFrom(event, 'myspace2'); return false; }
}, // myspace2
// deviantart
{
name : 'deviantart',
includeRegExp : /^https?:\/\/(.*?\.)?deviantart\.com/i,
linkRegExp : /deviantart\.com\/(deviation|print|art)\/.+/i,
findImageRegExp : /^http(s)?:\/\/.*?\.deviantart\.com\/([^\/]*)\/[^\/]*\/(.*?)\.(jpe?g|gif|png)$/i,
replaceString : 'http$1://fc01.deviantart.com/$2/$3.$4',
showFunction : function(event) { greasedLightbox.showFrom(event, 'deviantart'); return false; }
}, // deviantart
// subvariance
{
name : 'subvariance',
includeRegExp : /^https?:\/\/(.*?\.)?subvariance\.com/i,
linkRegExp : /\/view\/[0-9]+/i,
findImageRegExp : /\/items\/thumbs\/(.*?)\.jpg/i,
replaceString : '/items/$1.jpg',
showFunction : function(event) { greasedLightbox.showFrom(event, 'subvariance'); return false; }
}, // subvariance
// gmail
{
name : 'gmail',
includeRegExp : /^https?:\/\/mail\.google\..*/i,
linkRegExp : /^(\/mail\/\?view=att&(amp;)?disp=)inline/i,
replaceString : 'http://' + window.location.host + '$1emb',
showFunction : function(event) { greasedLightbox.showFrom(event, 'gmail'); return false; }
}, // gmail
// imagefap
{
name : 'imagefap',
includeRegExp : /^https?:\/\/(.*?\.)?imagefap\.com/i,
linkRegExp : /(image.php\?id=|gallery\/)[0-9]+/i,
findImageRegExp : /\/images\/(thumb|mini)\/([0-9]+)\/([0-9]+)\/([0-9]+)\.jpg/i,
replaceString : '/full/$2/$3/$4.jpg',
showFunction : function(event) { greasedLightbox.showFrom(event, 'imagefap'); return false; }
},
// ffffound!
{
name : 'ffffound',
includeRegExp : /^https?:\/\/(.*?\.)?ffffound\.com/i,
linkRegExp : /\/image\/[\w]+$/i,
findImageRegExp : /img(-thumb)?\.ffffound\.com\/static-data\/assets\/([\w\/]+?)_[\w]+\.(jpe?g|gif|png)$/i,
replaceString : 'img.ffffound.com/static-data/assets/$2.$3',
showFunction : function(event) { greasedLightbox.showFrom(event, 'ffffound'); return false; }
},
// textamerica
/* removed support because they are now subscription-based
{
name : 'textamerica',
includeRegExp : /^http(s)?:\/\/(.*?\.)?textamerica\.com/i,
linkRegExp : /\?r=[0-9]+$/i,
findImageRegExp : /user\.images\.x\/(.*?\/.*?)\/(.*?)\/(.*?)\.jpg(.*)$/i,
replaceString : 'user.images.x/$1\/$3.jpg',
showFunction : function(event) { greasedLightbox.showFrom(event, 'textamerica'); return false; }
} // textamerica
*/
// image http://bp2.blogger.com/_a7jkcMVp5Vg/SAGu9Ym-S2I/AAAAAAAAEoM/WCGF3uywJzE/s400/empty.jpg
// link http://bp2.blogger.com/_a7jkcMVp5Vg/SAGu9Ym-S2I/AAAAAAAAEoM/WCGF3uywJzE/s1600-h/empty.jpg
// final image http://bp2.blogger.com/_a7jkcMVp5Vg/SAGu9Ym-S2I/AAAAAAAAEoM/WCGF3uywJzE/s1600/empty.jpg
], // searchDefs[]
// useLinkForShow()
useLinkForShow : function(searchDef) {
if (searchDef.findImageRegExp)
return false;
else
return true;
},
// showFrom()
// generic helper function that calls show() with the correct parameters
showFrom : function(event, showName) {
var link;
if (event.currentTarget)
link = event.currentTarget;
else
link = event;
var address = unescape(unescape(greasedLightbox.getAddress(link)));
var img = greasedLightbox.getImageToShow(link, address, showName);
greasedLightbox.show(event, img, address);
}, // showFromLink()
// getImageToShow()
getImageToShow : function(link, address, showName) {
var searchDef = greasedLightbox.getRegExpObj(greasedLightbox.searchDefs, showName);
if (greasedLightbox.useLinkForShow(searchDef)) {
address = unescape(unescape(address));
if (searchDef['replaceString'])
var img = address.replace(searchDef['linkRegExp'], searchDef['replaceString']);
else
var img = address.match(searchDef['linkRegExp'])[0];
} else {
var img = greasedLightbox.containsThumb(link, greasedLightbox.getRegExpObj(greasedLightbox.searchDefs, showName), true);
}
return img;
}, // getImageToShow()
// getRegExpObj()
// returns the requested regular expression object from the regExp array
getRegExpObj : function(regExpObject, showName) {
var rExObj;
for (var i = 0; i < regExpObject.length; i++) {
rExObj = regExpObject[i];
if (rExObj['name'] == showName)
return rExObj;
}
}, // getRegExpObj()
// containsThumb()
containsThumb : function(elem, rExObj, verbose) {
var images, image, src;
images = document.evaluate('descendant::img[@src]', elem, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null);
for(var i = 0; i < images.snapshotLength; i++) {
thisImage = images.snapshotItem(i);
src = thisImage.getAttribute('src');
if(rExObj['findImageRegExp'].test(src)) {
if(!verbose) return true;
return src.replace(rExObj['findImageRegExp'], rExObj['replaceString']);
}
}
return false;
}, // containsThumb()
// getAddress()
// extracts an address out of a linkObj
getAddress : function(linkObj) {
var address = linkObj.getAttribute('href');
// for GreaseKit users because Safari doesn't like stopping events even though it says it does...
if(/Safari/.test(navigator.userAgent)) {
linkObj.onclick = function() { return false; };
}
return address;
}, // getAddress()
// getPageScroll()
// Returns array with x,y page scroll values.
// Core code from - quirksmode.org
getPageScroll : function() {
var xScroll, yScroll;
if (self.pageYOffset) {
yScroll = self.pageYOffset;
} else if (document.documentElement && document.documentElement.scrollTop){ // Explorer 6 Strict
yScroll = document.documentElement.scrollTop;
} else if (document.body) {// all other Explorers
yScroll = document.body.scrollTop;
}
if (self.pageXOffset) {
xScroll = self.pageXOffset;
} else if (document.documentElement && document.documentElement.scrollLeft){ // Explorer 6 Strict
xScroll = document.documentElement.scrollLeft;
} else if (document.body) {// all other Explorers
xScroll = document.body.scrollLeft;
}
arrayPageScroll = new Array(xScroll,yScroll)
return arrayPageScroll;
}, // getPageScroll()
// getPageSize()
// Returns array with page width, height and window width, height
// Core code from - quirksmode.org
// Edit for Firefox by pHaez
getPageSize : function() {
var xScroll, yScroll;
if (window.innerHeight && window.scrollMaxY) {
xScroll = document.body.scrollWidth;
yScroll = window.innerHeight + window.scrollMaxY;
} else if (document.body.scrollHeight > document.body.offsetHeight){ // all but Explorer Mac
xScroll = document.body.scrollWidth;
yScroll = document.body.scrollHeight;
} else { // Explorer Mac...would also work in Explorer 6 Strict, Mozilla and Safari
xScroll = document.body.offsetWidth;
yScroll = document.body.offsetHeight;
}
var windowWidth, windowHeight;
if (self.innerHeight) { // all except Explorer
windowWidth = self.innerWidth;
windowHeight = self.innerHeight;
} else if (document.documentElement && document.documentElement.clientHeight) { // Explorer 6 Strict Mode
windowWidth = document.documentElement.clientWidth;
windowHeight = document.documentElement.clientHeight;
} else if (document.body) { // other Explorers
windowWidth = document.body.clientWidth;
windowHeight = document.body.clientHeight;
}
// for small pages with total height less then height of the viewport
if(yScroll < windowHeight){
pageHeight = windowHeight;
} else {
pageHeight = yScroll;
}
// for small pages with total width less then width of the viewport
if(xScroll < windowWidth){
pageWidth = windowWidth;
} else {
pageWidth = xScroll;
}
arrayPageSize = new Array(pageWidth,pageHeight,windowWidth,windowHeight);
return arrayPageSize;
}, // getPageSize()
// center()
// centers the object in the page
center : function(objToCenter, arrayPageScroll, arrayPageSize) {
var oldDisplay = new Array(objToCenter.style.visibility, objToCenter.style.display);
objToCenter.style.display = 'none';
var arrayPageScroll = (arrayPageScroll) ? arrayPageScroll : greasedLightbox.getPageScroll();
var arrayPageSize = (arrayPageSize) ? arrayPageSize : greasedLightbox.getPageSize();
objToCenter.style.visibility = 'hidden';
objToCenter.style.display = 'block';
var objTop = arrayPageScroll[1] + ((arrayPageSize[3] + 35 - objToCenter.offsetHeight) / 2);
var objLeft = (arrayPageSize[0] - objToCenter.offsetWidth) / 2;
objToCenter.style.top = (objTop < 0) ? "0px" : objTop + "px";
objToCenter.style.left = (objLeft < 0) ? "0px" : objLeft + "px";
objToCenter.style.visibility = oldDisplay[0];
objToCenter.style.display = oldDisplay[1];
}, // center()
// centerItAll()
// Centers the lightbox object and the loading/error object on the page
centerItAll : function() {
var objLightbox = document.getElementById('greasedLightbox');
var objLoading = document.getElementById('greasedLightboxLoading');
var arrayPageSize = greasedLightbox.getPageSize();
var arrayPageScroll = greasedLightbox.getPageScroll();
greasedLightbox.center(objLightbox, arrayPageScroll, arrayPageSize);
greasedLightbox.center(objLoading, arrayPageScroll, arrayPageSize);
}, // centerItAll()
// show()
// Preloads images. Pleaces new image in lightbox then centers and displays.
show : function(event, img, context) {
//alert(img);
// let shift+click and ctrl+click (but not ctrl+shift+click) through without lightbox
if ((event.shiftKey || event.ctrlKey) && !(event.shiftKey && event.ctrlKey)) return true;
// if this is a real event stop the click and set the link, otherwise, just set the link
if (event.currentTarget) {
var link = event.currentTarget;
greasedLightbox.stopEvents(event);
} else {
var link = event;
}
if (img == null || img == '') img = link.getAttribute('href');
greasedLightbox.currentAddress = unescape(unescape(greasedLightbox.getAddress(link)));
// make ctrl+shift+click follow link without lightbox
if (event.shiftKey && event.ctrlKey) {
window.location.href = greasedLightbox.currentAddress;
return true;
}
// center when resized
if (greasedLightbox.isShowing != true)
window.addEventListener('resize', greasedLightbox.centerItAll, true);
greasedLightbox.isShowing = true;
// get the caption from the title attribute of the link. if that doesn't exist, look for it in the title attribute of the image.
capt = link.getAttribute('title');
if (capt == null || capt == '') {
try {
var imgObj = link.firstChild;
capt = imgObj.getAttribute('title');
} catch (e) { }
}
if (capt == null || capt == '') {
try {
var imgObj = link.firstChild;
capt = imgObj.getAttribute('alt');
} catch (e) { }
}
// prep objects
var objOverlay = document.getElementById('greasedLightboxOverlay');
var objMenu = document.getElementById('greasedLightboxMenu');
var objLightbox = document.getElementById('greasedLightbox');
var objCaption = document.getElementById('greasedLightboxCaption');
var imgPreload = document.getElementById('greasedLightboxPreload');
var objImage = document.getElementById('greasedLightboxImage');
var objLoading = document.getElementById('greasedLightboxLoading');
objOverlay.style.display = 'none'; // This will ensure that we have a correct reading of the page size
var arrayPageSize = greasedLightbox.getPageSize();
var arrayPageScroll = greasedLightbox.getPageScroll();
// set height of Overlay to take up whole page and show
objOverlay.style.height = (arrayPageSize[1] + 'px');
objOverlay.style.display = 'block';
// show menu
objMenu.style.display = 'block';
// center loader and error message
objLoading.style.visibility = 'hidden';
objLoading.style.display = 'block';
greasedLightbox.center(objLoading, arrayPageScroll, arrayPageSize);
objLoading.style.visibility = 'visible';
var imgPreload = document.getElementById('greasedLightboxPreload');
// preload image
preloaderDone = function() {
loaderDone = function() {
objImage.removeAttribute('width');
objImage.removeAttribute('height');
greasedLightbox.aspectRatio = null;
if (capt) {
objCaption.innerHTML = capt;
} else {
objCaption.innerHTML = img;
}
// dimensions
// objCaption.innerHTML = objCaption.innerHTML + '<br/><br/>(width: ' + objImage.width + 'px; height: ' + objImage.height + 'px;)';
// add a link for context
if (context) objCaption.innerHTML = objCaption.innerHTML + '<br/><br/><a href="' + context + '">' + greasedLanguage[greasedLanguage.language][0].context + '</a>';
// center lightbox and make sure that the top and left values are not negative
// and the image placed outside the viewport
//objLightbox.style.visibility = 'hidden';
objLightbox.style.display = 'block';
greasedLightbox.aspectRatio = objImage.height / objImage.width;
// if image is larger than the screen
if (objImage.height > arrayPageSize[3] - 70) {
var newHeight = arrayPageSize[3] - 70;
var newWidth = (objImage.width / objImage.height) * newHeight;
objImage.height = newHeight;
objImage.width = newWidth;
}
if (objImage.width > arrayPageSize[2] - 70) {
var newWidth = arrayPageSize[2] - 70;
var newHeight = greasedLightbox.aspectRatio * newWidth;
objImage.height = newHeight;
objImage.width = newWidth;
}
greasedLightbox.center(objLightbox, arrayPageScroll, arrayPageSize);
// if it went bigger than the page
if (objLightbox.offsetHeight > objOverlay.offsetHeight) objOverlay.style.height = objLightbox.offsetHeight + 'px';
if (objLightbox.offsetWidth > objOverlay.offsetwidth) objOverlay.style.width = objLightbox.offsetWidth + 'px';
greasedLightbox.center(objLightbox, arrayPageScroll, arrayPageSize);
objLoading.style.display = 'none';
objCaption.style.display = 'block';
objLightbox.style.visibility = 'visible';
// clean it up a bit for memory's sake
objImage.removeEventListener('load', loaderDone, false);
imgPreload.removeEventListener('load', preloaderDone, false);
imgPreload.removeEventListener('error', greasedLightbox.noImage, false);
imgPreload.src = '';
if (greasedLightbox.isSlideShow)
greasedLightbox.timer = setTimeout(function(event) { greasedLightbox.moveSlide(event, 1) }, greasedLightbox.slideTime * 1000);
return false;
} // loaderDone()
objImage.addEventListener('load', loaderDone, false);
objImage.src = img;
return false;
} // preloaderDone()
if (imgPreload.src != img) {
imgPreload.addEventListener('load', preloaderDone, false);
imgPreload.addEventListener('error', greasedLightbox.noImage, false);
imgPreload.src = img;
} else {
preloaderDone();
}
// hides flash movies that peek through the overlay
var obtrusives, thisObtrusive;
obtrusives = document.evaluate('//object|//embed|//iframe', document, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null);
for(var i = 0; i < obtrusives.snapshotLength; i++) {
thisObtrusive = obtrusives.snapshotItem(i);
thisObtrusive.style.visibility = 'hidden';
}
if (greasedLightbox.allImageLinks.length > 1) {
// initialize slideshow
// set currentImagePosition
findCurrentPosition : for(var i = 0; i < greasedLightbox.allImageLinks.length; i++) {
if (greasedLightbox.allImageLinks[i]['link'] == link) {
greasedLightbox.currentImagePosition = i;
break findCurrentPosition;
}
} // for()
// pre-fetch next image
if (!window.opera) { // for some reason this pre-fetching breaks lightbox in opera
var imgPrefetch = document.getElementById('greasedLightboxPrefetch');
var nextImagePosition = (greasedLightbox.currentImagePosition + greasedLightbox.lastMove) % greasedLightbox.allImageLinks.length;
if (nextImagePosition < 0) nextImagePosition = greasedLightbox.allImageLinks.length - 1;
var nextImage = greasedLightbox.allImageLinks[nextImagePosition];
var nextImageSrc = greasedLightbox.getImageToShow(nextImage['link'], greasedLightbox.getAddress(nextImage['link']), nextImage['name']);
imgPrefetch.src = nextImageSrc;
}
} // if()
}, // show()
// slideShow()
// cycles through all of the lightboxable images
slideShow: function(cmd) {
var objMenuButtonShow = document.getElementById('greasedLightboxButtonSlide');
if (cmd != 'stop') { // start the show
greasedLightbox.isSlideShow = true;
greasedLightbox.moveSlide(null, 1);
// switch function to stop button
objMenuButtonShow.removeEventListener('click', greasedLightbox.slideShow, false);
objMenuButtonShow.innerHTML = '\u2169';
objMenuButtonShow.addEventListener('click', function(event) { greasedLightbox.slideShow('stop') }, false);
}
else { // stop the show
clearTimeout(greasedLightbox.timer);
greasedLightbox.isSlideShow = false;
objMenuButtonShow.removeEventListener('click', function(event) { greasedLightbox.slideShow('stop') }, false);
objMenuButtonShow.innerHTML = '\u21BB';
objMenuButtonShow.addEventListener('click', greasedLightbox.slideShow, false);
}
}, // slideShow()
// hide()
// Stops the preloader in case it hasn't finished and then hides all of the lightbox components
hide : function(event) {
greasedLightbox.stopEvents(event);
greasedLightbox.isShowing = false;
window.removeEventListener('resize', greasedLightbox.centerItAll, true);
// get objects
var objPreloader = document.getElementById('greasedLightboxPreload');
var objLoading = document.getElementById('greasedLightboxLoading');
var objError = document.getElementById('greasedLightboxError');
var objOverlay = document.getElementById('greasedLightboxOverlay');
var objLightbox = document.getElementById('greasedLightbox');
var objMenu = document.getElementById('greasedLightboxMenu');
var imgPreload = document.getElementById('greasedLightboxPreload');
// stop preloader
objPreloader.removeEventListener('load', preloaderDone, false);
imgPreload.removeEventListener('error', greasedLightbox.noImage, false);
//imgPreload.src = '';
// show flash movies again
var obtrusives, thisObtrusive;
obtrusives = document.evaluate('//object|//embed|//iframe', document, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null);
for(var i = 0; i < obtrusives.snapshotLength; i++) {
thisObtrusive = obtrusives.snapshotItem(i);
thisObtrusive.style.visibility = 'visible';
}
// hide everything
objLoading.style.display = 'none';
objError.style.display = 'none';
objOverlay.style.display = 'none';
objLightbox.style.display = 'none';
objMenu.style.display = 'none';
}, // hide()
// halt()
// stops the slideshow and hides the lightbox
halt : function() {
greasedLightbox.slideShow('stop');
greasedLightbox.hide();
},
// stopEvents()
stopEvents : function(event) {
if (event) {
if (event.stopPropagation) event.stopPropagation();
if (event.preventDefault) event.preventDefault();
}
},
// resize()
resize : function(event, resizeByAmount) {
greasedLightbox.stopEvents(event);
// stop slidshow
greasedLightbox.slideShow('stop');
// resize the image
var objImage = document.getElementById('greasedLightboxImage');
var imgPreload = document.getElementById('greasedLightboxPreload');
if (resizeByAmount == 0) {
objImage.removeAttribute('width');
objImage.removeAttribute('height');
} else {
var newWidth = objImage.width + (objImage.width * (resizeByAmount/100));
var newHeight = this.aspectRatio * newWidth;
if (newWidth > 30 || newHeight > 30) {
objImage.width = newWidth;
objImage.height = newHeight;
}
}
// re-center the lightbox
var objLightbox = document.getElementById('greasedLightbox');
greasedLightbox.center(objLightbox);
}, // resize()
// noImage()
// Displays a nice error message when no image can be found.
noImage : function(event) {
var objLoading = document.getElementById('greasedLightboxLoading');
var objError = document.getElementById('greasedLightboxError');
var objErrorContext = document.getElementById('greasedLightboxErrorContext');
objError.style.visibility = 'hidden';
objError.style.display = 'block';
objErrorContext.innerHTML = '<a href="' + greasedLightbox.currentAddress + '">' + greasedLanguage[greasedLanguage.language][0].context + '</a>';
greasedLightbox.center(objError);
objLoading.style.display = 'none';
objError.style.visibility = 'visible';
if (greasedLightbox.isSlideShow)
greasedLightbox.timer = setTimeout(function(event) { greasedLightbox.moveSlide(event, 1) }, 500);
}, // noImage()
// handleKey(event)
// handles keypress. If 'x' is pressed then it hides the lightbox. If a left or right arrow is pressed it cycles through images on a page
handleKey : function(event) {
if (greasedLightbox.isShowing) {
var keycode = event.which;
var key = String.fromCharCode(keycode).toLowerCase();
switch(key) {
case 'x':
greasedLightbox.halt(event);
break;
case '+': // increase size
greasedLightbox.resize(event, 13);
break;
case '-': // decrease size
greasedLightbox.resize(event, -13);
break;
case '0': // set to default size
greasedLightbox.resize(event, 0);
break;
/* @todo
case 'v': // view image in original context
break;
*/
default:
switch(event.keyCode) {
// esc key
case 27:
greasedLightbox.halt(event);
break;
// left arrow
case 37: // firefox
case 63234: // safari
greasedLightbox.slideShow('stop');
greasedLightbox.moveSlide(event, -1);
break;
// right arrow
case 39: // firefox
case 63235: // safari
greasedLightbox.slideShow('stop');
greasedLightbox.moveSlide(event, 1);
break;
} // switch(event.keyCode)
break;
} // switch(key)
} // if
}, // getKey()
// moveSlide()
// loads another image from allImageLinks[]
moveSlide : function(event, moveByAmount) {
if (greasedLightbox.allImageLinks.length > 1) {
if (greasedLightbox.currentImagePosition + moveByAmount == -1) greasedLightbox.currentImagePosition = greasedLightbox.allImageLinks.length;
var newSlidePosition = (greasedLightbox.currentImagePosition + moveByAmount) % greasedLightbox.allImageLinks.length;
var slideToLoad = greasedLightbox.allImageLinks[newSlidePosition];
greasedLightbox.hide(event);
slideToLoad['showFunction'](slideToLoad['link']);
greasedLightbox.lastMove = moveByAmount;
} // if
}, // moveSlide()
// lightBulbOnIcon
// used when an update is available
lightBulbOnIcon :"url('%2F9hAAAABGdBTUEAAK%2FINwWK6QAAABl0RVh0U29mdHdhcmUAQWRvYmUgSW1hZ2VSZWFkeXHJZTwAAAKgSURBVDjLlZLrS1NxGMd90ZvovdEfEBEUEhZIb0xMjdyLIuyGkiHGUFKydFKKJiRegjIyFJRwojMxzfJSaVOYeTfxtpSNuZ1tXnY2z27nsss5334uWloG9uLD7%2FA7z%2FfzPPx4IgBE7ISl3qWyelUvu9JIueZqeOdUmcCMFDgcQ3fntjSK0j%2Frwx%2BcsesIZ3jbL1j6EbCPIej5DpE3QRIoBJ3LEFb74BjIxkbXVYNdrTixS8Ca3h%2Fy6pSTfloD0UcRjCS8BJGbRdA7QRgjd1pIfhruyeewKOMdm%2BrCw2GBV1tXKZh7SIEVoqAjpwVS0AlIvhBSkCGyeQRcPYDogO1DNixvrveFBa6ZCkuAmSe1OtJpFVLATkJboWCIAE3%2BGYngI6ENgnUK%2BhcxfFiw9fWRT%2BRWEWTHEeRmyPhaMvYCgu5ZEpgkbzCCgPszBNsr8NY8iF4Ky5WnpLDArs41%2BzYnSPdF8OYi0qEcTHc6mF45mJ4M2Ftl4C1lYPU34KerwFNTWKmO%2Fj2BfbiwghmvJuPawZsUsNVHgTPlEx6ANcjJeR9r5QfhWUqEJOlhbc%2BFoV42FBY4R0sPbPbKlz2LLeQB9aCbYkJhzpIFlkoDZ8zDRk0kRHYYrm8d0JYeEyyduUd37QH9pTBqvSOV9iy0wtmZ%2BVNAOm%2BHOeM92JtlYDQN0JYcD1BtmTf%2FWqRtbJ%2FyTxtUt9fXGhPBq5MhriVBtMYhoLkMQ1Ek5sqi3eb2O4l7buIvhlRPkmsfZ%2Fibax%2BiruosnpacQUFOOq7Fn5TUypJz%2F1zlnRQr5JSypRVKZRvq6htR%2FewlriTH03vV7ilQ5NwaHRgchM1GY3p6Bq%2BbmpEii9XtWzCgqkhLuXSBTUg4L8XFxUoXk2K57obirH0L%2FocfNQ8V8wE%2BuE0AAAAASUVORK5CYII%3D')",
// showUpdate()
// shows the user that an update is available
showUpdate : function(latestVersion) {
var titleLink = document.getElementById('greasedLightboxTitleLink');
titleLink.setAttribute('title', greasedLanguage[greasedLanguage.language][0].update + ' (v' + latestVersion + ')');
titleLink.innerHTML = titleLink.innerHTML + ' - ' + greasedLanguage[greasedLanguage.language][0].update + ' (v' + latestVersion + ')';
var cssStr = '#greasedLightboxTitleLink { background-image: ' + greasedLightbox.lightBulbOnIcon + ' !important; }';
var styleSheet = document.getElementById('greasedLightboxCSS');
var cssText = document.createTextNode(cssStr);
styleSheet.appendChild(cssText);
},
// init()
// Function runs on window load, going through link tags looking for links to images.
// These links receive onclick events that enable the lightbox display for their targets.
// The function also inserts html markup at the top of the page which will be used as a
// container for the overlay pattern and the inline image.
init : function() {
// initialize localization
greasedLanguage.init();
// set up list of searchDefs to use based on how includeRegExp matches window.location.href
var currentURL, searchDefsToUse;
currentURL = window.location.href;
searchDefsToUse = new Array();
for(var i = 0; i < greasedLightbox.searchDefs.length; i++) {
if(greasedLightbox.searchDefs[i]['includeRegExp'].test(currentURL)) searchDefsToUse.push(greasedLightbox.searchDefs[i]);
}
if(!searchDefsToUse.length) return;
// set variables
var links, thisLink, href, lightboxedLinksTotal = 0;
links = document.evaluate('//a[@href]', document, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
for(var i = 0; i < links.snapshotLength; i++) {
thisLink = links.snapshotItem(i);
href = unescape(thisLink.getAttribute('href'));
// check regularExpressions from searchDefsToUse
checkLink : for (var ii = 0; ii < searchDefsToUse.length; ii++) {
// for links that reveal larger image's location
if (!searchDefsToUse[ii]['findImageRegExp']) {
if(searchDefsToUse[ii]['linkRegExp'].test(href)) {
if (!searchDefsToUse[ii]['excludeLinkRegExp'] || !searchDefsToUse[ii]['excludeLinkRegExp'].test(href)) {
if (!(thisLink.getAttribute('rel') && thisLink.getAttribute('rel').toLowerCase().match('lightbox'))) // prevents doubling lightboxes
thisLink.addEventListener('click', searchDefsToUse[ii]['showFunction'], true);
this.allImageLinks[lightboxedLinksTotal] = new Array(3);
this.allImageLinks[lightboxedLinksTotal]['name'] = searchDefsToUse[ii]['name'];
this.allImageLinks[lightboxedLinksTotal]['showFunction'] = searchDefsToUse[ii]['showFunction'];
this.allImageLinks[lightboxedLinksTotal]['link'] = thisLink;
lightboxedLinksTotal++;
break checkLink;
}
}
// for links that contain images that reveal larger image's location
} else if (searchDefsToUse[ii]['findImageRegExp']) {
if(this.containsThumb(thisLink, searchDefsToUse[ii], false)) {
if(searchDefsToUse[ii]['linkRegExp'].test(href)) {
if (!searchDefsToUse[ii]['excludeLinkRegExp'] || !searchDefsToUse[ii]['excludeLinkRegExp'].test(href)) {
if (!(thisLink.getAttribute('rel') && thisLink.getAttribute('rel').toLowerCase().match('lightbox'))) // prevents doubling lightboxes
thisLink.addEventListener('click', searchDefsToUse[ii]['showFunction'], true);
/*for (ii = 0; ii < lightboxedLinksTotal; ii++) {
if(greasedLightbox.allImageLinks[ii]['link'] == links[i]) break checkLink;
}*/
this.allImageLinks[lightboxedLinksTotal] = new Array(3);
this.allImageLinks[lightboxedLinksTotal]['name'] = searchDefsToUse[ii]['name'];
this.allImageLinks[lightboxedLinksTotal]['showFunction'] = searchDefsToUse[ii]['showFunction'];
this.allImageLinks[lightboxedLinksTotal]['link'] = thisLink;
lightboxedLinksTotal++;
break checkLink;
}
}
}
}
} // checkLink : for()
} // for()
if (lightboxedLinksTotal == 0) return;
window.addEventListener('unload', this.unload, false);
var objBody = document.getElementsByTagName("body").item(0);
var pngOverlay = "url('%2FINwWK6QAAABl0RVh0U29mdHdhcmUAQWRvYmUgSW1hZ2VSZWFkeXHJZTwAAAAPSURBVHjaYmJgYDgDEGAAANsAz1TKIeAAAAAASUVORK5CYII%3D')";
var lightbulbOffIcon = "url('%2F9hAAAABGdBTUEAAK%2FINwWK6QAAABl0RVh0U29mdHdhcmUAQWRvYmUgSW1hZ2VSZWFkeXHJZTwAAAJOSURBVDjLlZLdTxJQGMa96K4%2FoPUHdFfrpntyZrXsoq25tlbroi6qi7ZuYsuZ0UXRWiv72NS0gjIgDQ1LS0wkwU%2FUVEREUkEIBBFE%2BV48ve%2FZICza7OLZOTt739%2FznHPeEgAlhZpyB8%2BMLa58HHL63H2zy4muycVku8UZahl2TNJ688%2F6wsbd31yBLps3BNdqFCvrMYRjSURIvOdzzdAcmozWhTaLc%2B8WADXvHHb6RhYCEdEU2kiIJu%2FaBtwEywE3k2lQKjz8NB7Sjs7vygPMDu9ddogmUliNxsWaSGfwM5sViqcy%2BBHeFCl4r6YkzwzTnXlA9%2FSSh924md25qFDszMnmfGuga4pEd3QjiTxAN%2F49xY0c10MgjsuOuSssBdfh8IdBSUG1AibTDmbzAHrhZab6IzHQq6N3xo3%2BLyqY%2B1phMmig%2F9AISolm8yyMdo9IcKtt6HcC%2Bh653uoScTsJ0K65jw5yYrWOOISrol6Kht4pcUV%2Bg0efJwx5ADXtUA3a7aMLflHQoa0VzfTSoHMBUClqwL9EM4Lrb01JOt%2BzZQ7ob%2Fc%2FN1qDDGEHBugKxO6mOS%2BqWswZRb%2Ft9F%2BDxCLHAzQovsfdEyAYXn6d4cHBa7r7NXU%2FbrwbiCpNtsNFJzEnaqp4KjufblDU4XbtJVTJL%2BBqjQynyvZl6e8P%2FnOUC1UtvehWNr%2BBUqlGXX0T7j14gpMVZcFitUUB0ivnBvQ9PQgEgrBYxvBC8QqVxyXz2wboVfKzlSeOxsrLD2VLSyXZY0ck8feN1Ze3Dfgf%2FQJBCig%2B4GhFlwAAAABJRU5ErkJggg%3D%3D')";
// CSS
var head, styleSheet, cssStr, cssText;
head = document.getElementsByTagName('head')[0];
styleSheet = document.createElement('style');
styleSheet.setAttribute('id','greasedLightboxCSS');
styleSheet.setAttribute('type','text/css');
head.appendChild(styleSheet);
cssStr = ''+
'#greasedLightboxOverlay { position: absolute; top: 0; left: 0; z-index: 10000000; width: 100%; background-image: ' + pngOverlay + '; background-repeat: repeat; cursor: pointer; }'+
'#greasedLightboxMenu { position: fixed; top: 0; left: 0; width: 100%; z-index: 10000100; background: #000; font-family: "Terbuchet MS", Tahoma, Arial, Verdana, sans-serif; font-size: 14px; font-weight: bold; height: 35px; line-height: 35px; opacity: .5; }'+
'#greasedLightboxMenu:hover { opacity: 1; }'+
'a#greasedLightboxTitleLink { position: absolute; top: 0; left: 0; display: block; height: 35px; line-height: 35px; margin: 0 5px; padding: 0 5px 0 27px; background-image: ' + lightbulbOffIcon + '; background-repeat: no-repeat; background-position: 5px 55%; color: #aaa; background-color: #000; text-decoration: none; cursor: pointer; z-index: 10000450; }'+
'a#greasedLightboxTitleLink:hover { color: #fff; background-color: #333; }'+
'#greasedLightboxButtons { position: absolute; top: 0; left: 0; height: 35px; width: 100%; line-height: 35px; margin: 0; padding: 0; z-index: 10000400; }'+
'#greasedLightboxButtons a { display: block; width: 33px; height: 33px; border: 1px solid #000; background: #000; cursor: pointer; float: right; text-align: center; color: #aaa; z-index: 10000450; }'+
'#greasedLightboxButtons a:hover { border-color: orange; background-color: #333; color: #fff; }'+
'#greasedLightboxLoading { position: absolute; z-index: 10000050; color: #fff; font-weight: bold; font-family: "Trebuchet MS", Tahoma, Arial, Verdana, sans-serif; text-align: center; line-height: 2em; }'+
'p#greasedLightboxLoadingText { margin: 0; padding: 25px 0 5px 0; font-size: 45px; color: #fff; font-weight: bold; font-family: "Trebuchet MS", Tahoma, Arial, Verdana, sans-serif; line-height: 1em; text-align: center; }'+
'p#greasedLightboxLoadingHelp { margin: 0; padding: 5px 0; font-weight: normal; font-size: 11px; color: #fff; font-family: "Trebuchet MS", Tahoma, Arial, Verdana, sans-serif; line-height: 1em; text-align: center; }'+
'#greasedLightboxError { position: absolute; z-index: 10000050; text-align: center; background: #000; color: #aaa; padding: 10px; border: 1px solid #444; -moz-border-radius: 10px; font-family: verdana, sans-serif; font-size: 11px; }'+
'p#greasedLightboxErrorMessage { color: #fff; font-size: 45px; font-weight: bold; margin: 10px 20px; font-family: "Trebuchet MS", Tahoma, Arial, Verdana, sans-serif; text-decoration: none; border: none; text-align: center; }'+
'#greasedLightboxError a, #greasedLightbox a { color: #aaa; text-decoration: none; border-bottom: 1px solid #777; }'+
'p#greasedLightboxErrorContext { margin: 0; padding: 5px 0; font-weight: normal; font-size: 11px; color: #fff; font-family: "Trebuchet MS", Tahoma, Arial, Verdana, sans-serif; line-height: 1em; text-align: center; }'+
'#greasedLightbox { position: absolute; z-index: 10000050; text-align: center; background: #000; color: #aaa; padding: 10px; border: 1px solid #444; -moz-border-radius: 10px; font-family: verdana, sans-serif; font-size: 12px; }'+
'img#greasedLightboxImage { border: none; cursor: pointer; }'+
'img#greasedLightboxImage, img#greasedLightboxPreload, img#greasedLightboxPrefetch { max-height: none; max-width: none; }'+
'#greasedLightbox, #greasedLightboxMenu, #greasedLightboxOverlay, #greasedLightboxError, #greasedLightboxLoading, img#greasedLightboxPreload, img#greasedLightboxPrefetch { display: none; }'+
'#greasedLightboxCaption { color: #aaa; padding: 10px 0; }';
cssText = document.createTextNode(cssStr);
styleSheet.appendChild(cssText);
// overlay div
var objOverlay = document.createElement("div");
objOverlay.addEventListener('click', greasedLightbox.halt, false);
objOverlay.setAttribute('id','greasedLightboxOverlay');
objBody.appendChild(objOverlay);
// menu div
var objMenu = document.createElement("div");
objMenu.setAttribute('id', 'greasedLightboxMenu');
objBody.appendChild(objMenu);
// title link
var objMenuLink = document.createElement("a");
objMenuLink.setAttribute('id', 'greasedLightboxTitleLink');
objMenuLink.setAttribute('href', 'http://userscripts.org/users/426977/scripts');
objMenuLink.innerHTML = 'Keyser Söze Scripts';
objMenu.appendChild(objMenuLink);
// menu buttons div
var objMenuButtons = document.createElement("div");
objMenuButtons.setAttribute('id', 'greasedLightboxButtons');
objMenu.appendChild(objMenuButtons);
// right button
var objMenuButtonRight = document.createElement("a");
objMenuButtonRight.setAttribute('id', 'greasedLightboxButtonRight');
objMenuButtonRight.setAttribute('title', greasedLanguage[greasedLanguage.language][0].next);
objMenuButtonRight.innerHTML = '\u2192';
objMenuButtonRight.addEventListener('click', function(event) { greasedLightbox.slideShow('stop'); greasedLightbox.moveSlide(event, 1); }, false);
objMenuButtons.appendChild(objMenuButtonRight);
// left button
var objMenuButtonLeft = document.createElement("a");
objMenuButtonLeft.setAttribute('id', 'greasedLightboxButtonLeft');
objMenuButtonLeft.setAttribute('title', greasedLanguage[greasedLanguage.language][0].previous);
objMenuButtonLeft.innerHTML = '\u2190';
objMenuButtonLeft.addEventListener('click', function(event) { greasedLightbox.slideShow('stop'); greasedLightbox.moveSlide(event, -1); }, false);
objMenuButtons.appendChild(objMenuButtonLeft);
// magnify button
var objMenuButtonPlus = document.createElement("a");
objMenuButtonPlus.setAttribute('id', 'greasedLightboxButtonPlus');
objMenuButtonPlus.setAttribute('title', greasedLanguage[greasedLanguage.language][0].magnify);
objMenuButtonPlus.innerHTML = '+';
objMenuButtonPlus.addEventListener('click', function(event) { greasedLightbox.slideShow('stop'); greasedLightbox.resize(event, 13); }, false);
objMenuButtons.appendChild(objMenuButtonPlus);
// shrink button
var objMenuButtonMinus = document.createElement("a");
objMenuButtonMinus.setAttribute('id', 'greasedLightboxButtonMinus');
objMenuButtonMinus.setAttribute('title', greasedLanguage[greasedLanguage.language][0].shrink);
objMenuButtonMinus.innerHTML = '-';
objMenuButtonMinus.addEventListener('click', function(event) { greasedLightbox.slideShow('stop'); greasedLightbox.resize(event, -13); }, false);
objMenuButtons.appendChild(objMenuButtonMinus);
// slideshow button
var objMenuButtonShow = document.createElement('a');
objMenuButtonShow.setAttribute('id', 'greasedLightboxButtonSlide');
objMenuButtonShow.setAttribute('title', greasedLanguage[greasedLanguage.language][0].slideshow);
objMenuButtonShow.innerHTML = '\u21BB';
objMenuButtonShow.addEventListener('click', greasedLightbox.slideShow, false);
objMenuButtons.appendChild(objMenuButtonShow);
// loader div
var objLoading = document.createElement("div");
objLoading.setAttribute('id','greasedLightboxLoading');
objLoading.addEventListener('click', greasedLightbox.halt, false);
objBody.appendChild(objLoading);
var loadingGif = document.createElement('img');
loadingGif.src = "data:image/gif,GIF89a%80%00%80%00%A2%00%00%FF%FF%FF%DD%DD%DD%BB%BB%BB%99%99%99%00%00%FF%00%00%00%00%00%00%00%00%00!%FF%0BNETSCAPE2."+
"0%03%01%00%00%00!%F9%04%05%05%00%04%00%2C%02%00%02%00%7C%00%7C%00%00%03%FFH%BA%DC%FE0%CA%06*%988%EB%CD%BB_%96%F5%8Ddibax%AEl%AB%A5%A2%2B%CF.%5C%D1x%"+
"3E%DA%97%EE%FF%12%1EpHT%08%8B%C8G%60%190%1DI%83%E8%20%F9a2K%CF%8FTJ%E5X%AD%A4lg%BB%EDj%BE%D7%9D%0DJ%8E%9A3%E8%B4G%BCis%DF%93%B8%9CC%CF%D8%EFx%12zMsk"+
"%1E%7FS%81%18%83%850%87%7F%8Apz%8D)%8Fv%91%92q%1D%7D%12%88%98%99%9A%1B%9C%10%88%89%9Fy%93%A2%86%1A%9E%A7%8B%8C%2F%AB%18%A5%AE%A0_%AA%8E%AC%90%B5%B6%"+
"60%19%A3%0D%AD%BC%AF%A1(%B2%9D%BB%C3%C4h%BF%C7%A4%C9%CA%A8%A9A%CE%0E%B4%D1%BD%7B%10%C0%0A%C2%D8%D2%C5%DB%D5%0C%D7%DF%CB%B7%13%B9%C8%97x%02%EE%02%2B%"+
"B0%D47%13%DEln%1E%EF%EF'%F2%2B%F6Zd%3A%E8%1Bhb%9A%3Fv%F7%DAp%18%C8%90%84%C1%13%D0%C6%94%CB%C0%B0%E2%08f2%14%02%2Ce%8A%FFb%C5%86U%B4%B5(%B3%91%A3%C0%"+
"8F%20%CD%CD%E2%08h!%CA%94*%AD%B1l%99%EF%25%C1%98%0Bf%D2%1Ca%F3fL%9D%F8X%F4%D4g%0EhG%17C%F7%0D3%EA%23%A9%3B%5EL%818u%054%C9P%AA%2C%DF%D8%C4%FA%8F%CAK"+
"%AE%08%15Y%AC%15%F6%13%D1%A5%3Bq%AA%5D%CB%B6%AD%DB%B7p%E3%CA%9DK%B7%AE%DD%BBx%F3B4%DA%F5%1B_a%7F'%16%0D%0C%89%B0%E0h%86%13%F3%FD%A9%B8qV%95%8E%23%F7"+
"%85*%D9Me%B5%97%BB9f%1BY%AF%E7%CF%A0C%8B%1EM%BA%B4%E9%D3%A8S%AB%C6A%92r%D0Se1%C5~s8P%ED%24%26a%DF%1E2%13%EC%E4%1CUu%F7%06%12%D5wn%E0%C1%5D%0F%9FQ%1C"+
"q%F2%83%3A1%3FO%F8Xzt%EA%C7%DB6%AFs%5D%EE%F4%95%D5%25%BEv%D1Z%7Cv%F0%BB%EB%05%CC%B8%DERz%99%BF%D5kd%11%91%C3y%F9%F3G%D4%2F%B1%DF~%FF%08%BC%F9%E9%F7_"+
"I%EDaW%12t%01%3EP%DE3%B3%B9g%DB%80%9A-%A8%20%84%8CAha%7C%90Q%A8!%85~a%B8!%87%CE5%18%8C%88%E4%80%88%16%89%25%26%C8%A0%8A%19%A2%98%93%8B%11%B2%D8!%8C1"+
"J%08%A0%89%9F%BC%97b%81%F8%C9x%A2%8F%F0%F1%D8%A3%8D%CA%E8%B8%23%91%2B%02)%9C%92%232y%24%92%C6%A55%E4x~%E0H%9B%95%04%60%89%A1%22%5B%06%09%E5%8D4%9Aa%"+
"A4%97RNY%26%97X%D6x%E6%3ANv%91%A6%9ATr%D7%26%15of%19%26%99q%E6(%A4%7Fs%929%E3Q%EE%7D%89%1Eiu%AAVhj%87%A2%96%E8i%8B%9A%D6%A8%A3%7B%AE%C6'%A0%AE%24%00"+
"%00!%F9%04%05%05%00%04%00%2C%0A%00%02%00W%000%00%00%03%FFH%BA%DC%FE0%BE%40%83%BC8%EB%3D%2B%E5%60(J%9E7%9E(WVi%EBv%EB%2B%BF%EB7%DFgm%E1%3C%A8%F7%23%8"+
"1P%90%FA%A1%00H%40k8D%19G%C9%24%8A%C9%CC%D5N%D1%E8%89%DA%1C%3DCYi%90%2B%F4%5EEa%B1%88%DC%F5%9DAi%F5%9A-%FAn%E2%CA%14%9B%E8%8E%C1%E3.%7B!v%19x%2F%82*"+
"o%1A%86%87%88%1A%84%12xy%8Dd%89~%8B%803%7B%7C%19%90%10%928%8E%18%9E%0F%8C%A1t%9D%8A%91%99%3C%A2%24%AA%11%A6%AD%A8%17%A4%0C%B2%B3%B4%11%B6%0A%A0%40%0"+
"A%AE0%25%18%B8%3D%9B%B5%B0%0D%BE%BF%C0%BA%10%97%B1%AC%10%03%D4%03%81%CE%C2%C4%D2%0F%D5%D5K%D8G%DB%0D%DD%E4z%952%E2%E3%E4%E5c%5C3%E9%0C%EB%F2%EDm%E8Y"+
"%18%F2%F3se%3CZ%19%F9%FA%98%09%04%18P%E0%2F%82%EB%0C2C%C8N!%10%86%DD%1C%1E%84HMb%0F%8A%15-%F2%C0%A8%F1%13%22%C3%8E%0F%09%82%0C%99o%E4%C4%86%26IZK%A9"+
"!%01%00!%F9%04%05%05%00%04%00%2C%1F%00%02%00W%000%00%00%03%FFH%BA%DC%FEKH%01%AB%BD8%EB6%E7%FE%60%A8u%9Dh%9E%22%E9%A1l%5B%A9%92%2B%CF%04L%D1%F8i%E7%7"+
"C%B8%F7%A2%81p%C0%FA%9D%02%C8%40k8D%19E%C9%24%8A%C9%D4%C1%8EQ%A9%89%DA4%3DAYm%90%2B%F4%5E%A1a%E4%89%DC%05%7D5i%F1%98%9C%3A%83%E3K%B6%CF%BE%89%2B%F3t"+
"n%7Cpx.lD%1Fo%17~3%87%88%23%83%8B%8C%8Dz%1B%8A%15%93%94%95%19%97%0F~%7F4%87%96%91%98%859%A2%9C%A4%9E%A6%A7%9B%17%9D%0D%99%3C%A8%AF%AA%B1%AC%B3%B4%2F"+
"%B6%0B%9F%40%0B%BA%10%B0%0A%B2%40%8E%B5*%92%B8%C6%AE%C2%24%18%C5%BF%04%C1%0F%25%CAa.%00%DA%00%18%D4(%D1!%DB%DB%DD%812%CB%20%E2%E9%17%CD%2C%E7%1A%E9%"+
"F0%E4U8%D8%22%F0%F7%19%F39Q%26%F7%F8%D2%D2%FC%FD%03%D8C%E0%40%828%0C%C6C%C8C%A1%3A%86%09%1D%8E%83HC%E2D%8A3%2Cj%C3X%D1%14%22%C7%88%0A%3F%E6%08)r%A4%"+
"C0%92%05%17%A2L%B9%D1D%02%00!%F9%04%05%05%00%04%00%2C%3C%00%02%00B%00B%00%00%03%FEH4%3C%FA0%CAI%AB%9D%AD%DD%CD%7B%CD%99'%8E%16%A8%91hj2i%3B%AE%8E%2B"+
"o%F0l%7F%EB%ADG%B5%2B%FC%82%DD%A3%97%02%02%85%8B%5C%D1x%DC%11I%CC%A6%EE)%8AJo%D4%8E%F5j%CBr%B6A%A1%F7%02F%26M%D0%ADy%5C)%AF%95Z7%92%3D%91%CF%E1%1Bp%"+
"F8%8D%8E%5B%CDCx%16v%7C%20~Q%80%81%7Ddj%89%0At%0Az%8E%8F%82u%8D%93%90%92%93%94!%8C%7F%9B%8A1%83%97.%01%A6%01%3B%84(%A7%A7%3A%A4%AB%AC%AC7%AF%22%B1%B"+
"6%AEL)%B6%BB%A9%5C%1E%BB%BC%A0%1B%C0%C1%C2%15%C4%C5%C6%12%C8%B7%CA%14%CC%B1%CE%13%D0%B2%D2%11%D4%AD%D6%D7%D8%A8%DA%10%DC%DE%CB%D0%E1%D3%C8%E4%CF%C4%"+
"E7%C7%CD%EA%EB%A6%ED%F0%F1%F2%F3%F4%F5%F6%F7%F8%F9%FA%FA%00%FD%FE%FF%00%03%024%26%B0%A0%C1%7F%A0%0E*4%B8i%A1%C3%81%93%1EJ%04%D0p%A2%C3%84%16%0F%12%C"+
"C(%03PA%02%00!%F9%04%05%05%00%04%00%2CN%00%0A%000%00W%00%00%03%ECH%BA%BC%F3%A3%C9I%2B%85%D0%EA%7Dq%E6%E0%E6%7Da)%8D%A4%A9%A2%A9Z%B2%91%BB%B2%B2%0B%D"+
"7%E6%8D%87p%BCs%BA%9F((%B4%10%8B%1D%14r%A8%5CV%8ENF%2F%9A%1CQ'%D3k%03z%E5%AA%04%60%81%91%B6%0B%87%9F%CD%9Ay%5D%C5%A8%D7%EC%B6%CF%04%AF%8F%1F%B2%BA%9"+
"D%AA%DF%3B%FB~H%80p%7C%83fQ%86%87%7F%89%60%85%8C%8E%86Z%89Z%0A%83%94%0B%80%97%0C%81%9A%95g%9D%A0%A1%A2%A3%A4%A5%A6%A7%A8%A9%AA*%01%AD%AE%AF%B0%B1%B0"+
"5%B2%B5%B6%AF.%B7%BA%B6%AC%BB%BE%B8%26%BF%C2%01%BD%C3%BB%B9%C6%B7%B4%C9%B2%AB%CE%CF%D0%D1%D2%D3%D4%D52%00%D8%00%A5%D9%DC%A2%DC%DF%DA%9D%E0%DF%E2%E3%"+
"E4%94%E6%E3%E8%E9%E0Z%EC%ED%EE%EF%DD%F1%F2%D8%F4%F5%EB%F5%E1W%FA%FB%FC%F8%F9%D8%95K%17%8A%A0%B7s%A3%E6QH%00%00!%F9%04%05%05%00%04%00%2CN%00%1F%000%0"+
"0W%00%00%03%E9H%BA%DC%FEn%C8%01%AB%BDmN%CC%3B%D1%A0'F%608%8Eez%8A%A9%BAb%AD%FBV%B1%3C%93%B5v%D3%B9%BE%E3%3D%CA%2F%13%94%0C%81%BD%231%A8D%B6%9A%8F%1C"+
"%14R%9B%F2L%D6%AB0%CB%EDz%BF%E0%B0xL.%9B%CF%5C%81z%CDn%BB%DB%B3%B7%7C%CE%5E%D1%EF%F3%13~%0F%1F%F1%FF%02z%80%7Bv%83tq%86oh%8B%8C%8D%8E%8F%90%91%92%93"+
"%0A%01%96%01f%97%9Ac%9A%9D%98%60%9E%9D%A0%A1%A2%5D%A4%A1%A6%A7%9E%5C%AA%AB%AC%AD%9B%AF%B0%96%B2%B3%A9%B3%9FY%B8%B9%10%00%BE%00%2F%B8%15%BF%BF%C1%B0%"+
"BD%C4%C5%C6%A7%C8%C9%C07%CC%0F%CE%CA%D0%A5%D2%D3%CF%3B%B1%C3%D8b%D8%BE%DE%DDa%DF%D9_%DFc%E7%E3%E2%EA%D3%E1%EB%E6%EF%5E%E4%EE%CE%E8%F1%5D%E9%EC%F5%FA"+
"%FB%60%F9%FE%ED%E8%11%23%D3%CF%1E%B8)%09%00%00!%F9%04%05%05%00%04%00%2C%3C%00%3C%00B%00B%00%00%03%F9H%BA%DC%FEP%8DI%AB%BD6%EA%1D%B1%FF%15'r%60%F9%8D"+
"%E8c%AEY%EAJl%FC%BE%B1%3C%BB%B5y%CF%F9%B9%FF%C0%A0pH%2C%1A%8F%C8%A4r%C9l%3A%9F%D0%A8tJ%10X%05%D4%D7u%9B%1Dm%BF%D8%AE%06%FC%15G%C8%60%B3%03MV3%D8mw%1"+
"5%5E%96%CF%E9W%FB%1D%1Fv%F3%F3v%7FVz%82F%01%87%017%7FD%88%88%8AxC%8D%8D%3Bt%91%92%87%40l%96%97%89%99u%11%00%A1%00%1C%9C%98A%5C%1A%A2%A2%A4%A5O%AA%AA"+
"%1B%A5%A6L%AF%AB%B1%ADM%B5%A1%AC%B8K%BA%A3%BC%97%B9%BA%23%B2%B4%C4%22%C6%BE%C8%C9%BDH%BF(%B2%9D%CF%CC%CD%9CJ%D0%D1%CAG%D9%DA%D7%D4%B5%2F%DBE%DD%DE%C"+
"2%DC%D5%E6%92%E8%E1%E2%E3B%E5)%EFA%F1%F2%DFD%F5%EA%8E%E4%E9.%E7%FC%EDvLb%F7J%8F%83%7Cv%10%CAQ%E8%86%A1%1A%87%0F%0B%1A%7C%00kb%83%04%00!%F9%04%05%05%"+
"00%04%00%2C%1F%00N%00W%000%00%00%03%FFH%BA%DC%FE0%CA7%EA%988%EB%CD%89%FD%5D(%8E%CDg%5Ed%AAJ%A7%B9%BE%B0%D7%BAq%1D%CE%AD%ADkx%BE%FF%90%DE%09Ht%08i%C5"+
"%E4%11%94%2C.-M%E5%13%15%05N5%80%2C%E0'%E8%0AFO%8CV%AB%F3z%C1%C7%C9x%5C3%9BIB%F5%3A%DBvwU8%C9%9C%1C%B3%9F%F1H%10%7Bt%13%01%86%01%18~w%2BL%11%83%5B%8"+
"5%87%86%89%8AQ%8F%90%11%92%92%13%8A%8BE%8F%18%9A%87%94~I%97%A1%A2%88%9C%9D%9F%83%19%A9%AA%AB%A5%40%A0%AF%A9%1A%AC%3F%B5%A8%A2%B8%95%3B%BB%BC%9A%1B%B"+
"95%A7%1A%B0%C4%C50%C1%C2%9B%CA%B3%CC%CD%91%BD%D0%D1%2B%D3%D4%C3%1C%CB)%D9%DA%CF%DC%BF*%DF%12%C9%1D%DD%22%E5%E6%B7!%E9%1C%C7%1D%E7%E8%EFX%AE%22%F3%F4"+
"%D7%1D%F7%F8%ED%22%E3B%F4%0B%91O%9F%1BokR%144%E8%89%04%1B%85%FFF%BC%A9%E2l%14%C5(%0B%2F%FE%C8%A8Q%13%07%C7%8E5%3E%82%84!r%E4%8Bj%26%89%84K%A9%20%01%"+
"00!%F9%04%05%05%00%04%00%2C%0A%00N%00W%000%00%00%03%FFH%BA%DC%0E%10%B8I%AB%BD8%B7%C8%B5%FF%E0%C7%8DRh%9E!9%A2lK%A9%A4%2B%B7%B0%3A%DF%60m%E3%3C%A6%C7"+
"%BD%E0%E4%B7%12%1A%17%C4%CEq%99%8C%2C%8FM%C8%13%DA%9CR%89%A7%806%20%1Cx%07%99dv%AB%ED%7D%BF%3E%1D%8AL%C6%9D%CF%97Z%8B%BDu%BF%BDi%25%8B%5E%BF%DD%D1qN"+
".%7Ce%17%02%87%02%18%7FxV%04%84%5C%86%88%87%8A%8BV%8F%90%15%92%92%17%8B%8CK%8F%18%9A%88%94%7FO%97%A1%A2%89%9C%9D%9F%84%19%A9%AA%AB%A5F%A0%AF%A9%1A%A"+
"CB%B5%A8%A2%B8%95A%BB%BC%9A%1E%B98%A7%1A%B0%C4%C53%C1%C2%9B%CA%B3%CC%CD%91%BD%D0%D1%83%AE%1F%C9%1F%CB%7B%D9%DA%B7%20%DDc%7C!%DB%DC%BF%DE%E5%E6%E1%E2"+
"%E9%26%C7%20%E7%E8%EF%20%D3%C8%ED%EE%D7%F6%EB%26%F3%FAo%D6%F4cW%CDD%3D~mP%FC%03%E8I%60!%85%F9%0C%02jDm%18E%2B%0B%2F%0A%C9%A8%B1%12%07%C7%8E8%3E%82%9"+
"C!r%A4%8C%82%26%8D%3C%E3%91%00%00!%F9%04%05%05%00%04%00%2C%02%00%3C%00B%00B%00%00%03%F5H%04%DC%FE%F0%A9I%AB%BD%98%C6%CD%5D%FE%E0%D5%8D%5Ch%82d*%9D%A"+
"C%A5%BE%40%2BO%B0%3A%DF%F5x%EF%F9%B6%FF%C0%A0pH%2C%1A%8F%C8%A4r%C9l%3A%9F%D0%A8tJ%3D%05%AE%81%AA%0C%CB%D5%9A%B8%E0%AC7%13%06%8F%2F%E5%F0%99%92.%AF%0"+
"9m%F7%3A%AE%3E%D3%CD%F6%3B%F6%AD%DF%E7%FB%7C%80%81w%3B%02%86%02Fz%85%87%86Et%3F%8C%8CDmA%91%87%8Ex%40%96%97%98WC%9B%8D%20%03%A3%03R%A0%88%A2%A4%A3P%"+
"A7%A8%19%AA%AAO%A7!%B0%A4N%AD%B4%B5%A5M%B3%B9%B5%BC%A0'%BA%BBK%BD%BE%B0L%C6%C7%B1J%B8%C2%BA%C5%C1%2C%C3%CD%CA%CB%B6I%D6%D7%ABH%DA%DB%C4F%DE%A9%BFG%E"+
"2%E3%C8%E1%E6%1F%D4%E9%9B%3B%ECE%D27%F0D%F23%F4%F5%91%40%F8%F9%A1%3F%FCo%26%00%0CH%60%60%40%83o%10%AEQx%86aCt%0410K%00%00!%F9%04%05%05%00%04%00%2C%0"+
"2%00%1F%000%00W%00%00%03%E7H%BA%0C%0E%2C%CAIk%7B%CE%EAM%B1%E7%E0%E6%8Da)%8D%A8%A9%A2%A9Z%B2%AD%CB%C1%B1%AC%D1%A4%7D%E3%98.%F2%0F%DF%0E%08%11v%88E%E3"+
"%04%A9%AC%00%9B%16%1C4%0A%9B%0E%7B%D6_%26%CB%EDz%BF%E0%B0xL.%9B%CF%A1%80z%CDn%BB%DB%B6%B7%7C%CEv%D1%EFs%15~%0F7%F1%FF%01z%80%7Bv%83tq%86oh%8B%8C%8D%"+
"8E%8F%90%91%92%93h%02%96%02f%97%9Ac%9A%9D%98%60%9E%9D_%A1%9E%5D%A4%A1Y%A7%A8V%AA%A5S%AD%A2%AF%B0%97%A9%B3%96%AC%B6%9F%B2%B3%5C%B62%03%C0%03%16%BC.%C"+
"1%C1%15%AD6%C6%C6%14%A7%3E%CB%C7%CD%B1%3A%D0%D1%D2%B7B%D5%C0b%DA%C2a%DD%DE%60%DD%DC%E3%DF%DA%E4%D5c%E5%E2%E7%E6%ED%EC%E9%EE%F1%F0%D0%E8%F5%F6%CB%F8%"+
"CC%F2%F7%F4%F9%FA%DB%D4%CD%D3wf%9F%86%04%00!%F9%04%09%05%00%04%00%2C%02%00%02%00%7C%00%7C%00%00%03%FFH%BA%DC%FE0%CAI%AB%BD8%EB%CD%BB%FF%60(%8Edi%9Eh"+
"%AA%AEl%EB%BEp%2C%CFt%0A%DC%40%AD%938%BE%FF%9E%5E%0FH%CC%08%7D%C5%24%E5%88T%3A%1D%CC%E6sJ%88%E6%A8X%2B%96%AA%DDN%BB%5E%A5%F5%1AN%82%CB%C41%DA%1C%5D%"+
"B3%99%EEt%3B%0E%3C%D3i%EA%BB%CE%AE%8F%E5%FB3%7C%80%12%01%85%01!%82%83%0E%86%86%20%89%8A%0B%8C%92%1Fs%90%10%92%98%1D%95%96%8B%98%99%1BG%9C%11%9E%9E%1"+
"CC%A2%A3%A4%9F%A8%26%AA%A5%AC%AD%AE%93%B0%24%B2%B3%B4%23%B6%8C%B8%B5%BA%85%BC%22%BE%BF%C0!%C2%C4%C1%B6%C7%B9%AE%CA%CB%A4%CD%BD%B7%D0%CE%87%D3%D6%D7%"+
"D8%D9%DA%DB%DC%DD%DE%DF%E0%E1%C0%02%E4%E5%E6%E7%E8%E7%DC%E9%EC%ED%E6%DA%EE%F1%ED%D9%F2%F5%EA%D8%F6%F9%02%F4%FA%F5%F0%FD%EE%D6%01L'%AE%A0%C1%83%08%13"+
"*%5C%C8%B0%A1%C3%87h%06H%1C%00q%C1%C4%8B%10%2Fj%A4%D8pP%A3F%86%1E7*%0C%E9%11!%C9%92%07O%8A4%A8%F2%23%CB%96%13M%C2%94%98r%26%C7%970%13%CE%5C%98%93%E7"+
"I%87%24%2B%AE%ACH%00%23%D1%A3H%93*%5D%CA%B4%A9%D3%A7P%A3J%9DJ%B5%AA%D5%ABX%B3j%DD%CA%B5%AB%D7%AF%60%C3%16I%00%00%3B";
loadingGif.style.border = 'none';
objLoading.appendChild(loadingGif);
// loading text
var objLoadingText = document.createElement("p");
objLoadingText.setAttribute('id','greasedLightboxLoadingText');
objLoadingText.innerHTML = greasedLanguage[greasedLanguage.language][0].loading;
objLoading.appendChild(objLoadingText);
// helper message
var objLoadingHelp = document.createElement("p");
objLoadingHelp.setAttribute('id','greasedLightboxLoadingHelp');
objLoadingHelp.innerHTML = greasedLanguage[greasedLanguage.language][0].loadingSub;
objLoading.appendChild(objLoadingHelp);
// error div
var objErrorBox = document.createElement("div");
objErrorBox.setAttribute('id','greasedLightboxError');
objBody.appendChild(objErrorBox);
// error message
var objError = document.createElement("p");
objError.setAttribute('id','greasedLightboxErrorMessage');
objError.innerHTML = greasedLanguage[greasedLanguage.language][0].error +
'<p id="greasedLightboxErrorContext"></p>';
objErrorBox.appendChild(objError);
// lightbox div
var objLightbox = document.createElement("div");
objLightbox.setAttribute('id','greasedLightbox');
objOverlay.appendChild(objLightbox);
// empty image
var objImage = document.createElement("img");
objImage.addEventListener('click', greasedLightbox.halt, false);
objImage.setAttribute('id','greasedLightboxImage');
objLightbox.appendChild(objImage);
// empty preloader
var objPreload = document.createElement("img");
objPreload.setAttribute('id','greasedLightboxPreload');
objBody.appendChild(objPreload);
// empty prefetcher
var objPrefetch = document.createElement("img");
objPrefetch.setAttribute('id','greasedLightboxPrefetch');
objPrefetch.addEventListener('error', function() { return false; }, false);
objBody.appendChild(objPrefetch);
// empty caption
var objCaption = document.createElement("div");
objCaption.setAttribute('id','greasedLightboxCaption');
objLightbox.appendChild(objCaption);
document.addEventListener('keypress', greasedLightbox.handleKey, true);
}, // init()
// unload
// runs onunload to clear up possible memory leaks
unload : function () {
var objOverlay = document.getElementById('greasedLightboxOverlay');
objOverlay.removeEventListener('click', greasedLightbox.halt, false);
var objMenuButtonRight = document.getElementById('greasedLightboxButtonRight');
objMenuButtonRight.removeEventListener('click', function(event) { greasedLightbox.moveSlide(event, 1); }, false);
var objMenuButtonLeft = document.getElementById('greasedLightboxButtonLeft');
objMenuButtonLeft.removeEventListener('click', function(event) { greasedLightbox.moveSlide(event, -1); }, false);
var objMenuButtonPlus = document.getElementById('greasedLightboxButtonPlus');
objMenuButtonPlus.removeEventListener('click', function(event) { greasedLightbox.resize(event, 13); }, false);
var objMenuButtonMinus = document.getElementById('greasedLightboxButtonMinus');
objMenuButtonMinus.removeEventListener('click', function(event) { greasedLightbox.resize(event, -13); }, false);
var objLoading = document.getElementById('greasedLightboxLoading');
objLoading.removeEventListener('click', greasedLightbox.halt, false);
var objError = document.getElementById('greasedLightboxErrorMessage');
objError.removeEventListener('click', greasedLightbox.halt, false);
var objImage = document.getElementById('greasedLightboxImage');
objImage.removeEventListener('click', greasedLightbox.halt, false);
var objPrefetch = document.getElementById('greasedLightboxPrefetch');
objPrefetch.removeEventListener('error', function() { return false; }, false);
document.removeEventListener('keypress', greasedLightbox.handleKey, true);
} // unload()
} // greasedLightbox
var greasedLanguage = {
// english
en : [
{
loading : 'Loading image',
loadingSub : 'Click anywhere to cancel',
context : 'View image in its original context',
error : 'Image unavailable',
next : 'Next image (right arrow key)',
previous : 'Previous image (left arrow key)',
magnify : 'Magnify image (+ key)',
shrink : 'Shrink image (- key)',
update : 'Update available',
slideshow : 'Start/stop slideshow'
}
], // english
// español
es : [
{
loading : 'Cargando imagen',
loadingSub : 'Click en cualquier sitio para cancelar',
context : 'Ver imagen en su contexto original',
error : 'La imagen no está disponible',
next : 'Siguiente imagen (tecla derecha)',
previous : 'Imagen anterior (tecla izquierda)',
magnify : 'Aumentar tamaño (tecla +)',
shrink : 'Reducir tamaño (tecla -)',
update : 'Actualización disponible',
slideshow : ''
}
], // español
// português (portuguese)
pt : [
{
loading : 'Carregando imagem',
loadingSub : 'Clique em qualquer lugar para cancelar',
context : 'Imagem no contexto original',
error : 'Imagem indisponível',
next : 'Próxima imagem (tecle na seta da direita)',
previous : 'Imagem anterior (tecle na seta da esquerda)',
magnify : 'Aumente o zoom (tecle +)',
shrink : 'Diminua o zoom (tecle -)',
update : 'Atualização disponível',
slideshow : 'Iniciar/cancelar apresentação'
}
], // português
// deutsch (german)
de : [
{
loading : 'Bild wird geladen',
loadingSub : 'Zum Abbrechen irgendwo klicken',
context : 'Bild im ursprünglichen Kontext anzeigen',
error : 'Bild nicht verfügbar',
next : 'Nächstes Bild (Pfeil rechts)',
previous : 'Vorheriges Bild (Pfeil links)',
magnify : 'Bild vergrößern (+ Taste)',
shrink : 'Bild verkleinern (- Taste)',
update : 'Aktualisierung verfügbar',
slideshow : 'Diashow starten/beenden'
}
], // deutsch
// français (french)
fr : [
{
loading : 'Chargement de l\'image',
loadingSub : 'Cliquez n\'importe où pour annuler',
context : 'Voir cette image dans son contexte original',
error : 'Image indisponible',
next : 'Image suivante (Touche flèche droite) ',
previous : 'Image précédente (Touche fléche gauche)',
magnify : 'Agrandir l\'image (Touche +)',
shrink : 'Reduire l\'image (Touche -)',
update : 'Mise à jour disponible',
slideshow : ''
}
], // français
// het Nederlands (dutch)
nl : [
{
loading : 'Laden',
loadingSub : 'Klik ergens om terug te keren',
context : 'Bekijk het plaatje in zijn originele context',
error : 'Plaatje niet beschikbaar',
next : 'Volgend plaatje (rechter pijltjestoets)',
previous : 'Vorig plaatje (linker pijltjestoets)',
magnify : 'Vergoot plaatje (+ toets)',
shrink : 'Verklein plaatje (- toets)',
update : 'Update beschikbaar',
slideshow : 'Start/stop diavoorstelling'
}
], // het Nederlands
// italiano (italian)
it : [
{
loading : 'Scarico immagine',
loadingSub : 'Fai clic sullo sfondo per annullare',
context : 'Mostra nel suo contesto originale',
error : 'Immagine non disponibile',
next : 'Successiva (tasto freccia a destra)',
previous : 'Precedente (tasto freccia a sinistra)',
magnify : 'Ingrandisci (tasto +)',
shrink : 'Riduci zoom (tasto -)',
update : 'Aggiornamento disponibile',
slideshow : 'Avvia/ferma presentazione'
}
], // italiano
// ???????? (greek)
el : [
{
loading : '?????a f??t?s??',
loadingSub : '?t?p?ste ?p??d?p?te ??a ?a a????sete',
context : '?????a ?p???? st? a????? p?a?s?? t??',
error : '?????a µ? d?a??s?µ?',
next : 'Next image (right arrow key)',
previous : 'Previous image (left arrow key)',
magnify : 'Magnify image (+ key)',
shrink : 'Shrink image (- key)',
update : 'Update available',
slideshow : ''
}
], // ????????
// russki (russian)
ru : [
{
loading : '??????????? ????????',
loadingSub : 'Click ???-????, ????? ????? ????????',
context : '??????????? ??????? ? ????? ????????????? ??????',
error : '??????????? ?????????????',
next : 'Next image (right arrow key)',
previous : 'Previous image (left arrow key)',
magnify : 'Magnify image (+ key)',
shrink : 'Shrink image (- key)',
update : 'Update available',
slideshow : ''
}
], // russki
// hungarian
hu : [
{
loading : 'K\u00E9p bet\u00F6lt\u00E9se',
loadingSub : 'Kattints a visszal\u00E9p\u00E9shez',
context : 'Megtekint\u00E9s az eredeti k\u00F6rnyezet\u00E9ben',
error : 'K\u00E9p nem el\u00E9rhet\u0151',
next : 'K\u00F6vetkez\u0150 k\u00E9p (jobbra gomb)',
previous : 'El\u0150z\u0150 k\u00E9p (balra gomb)',
magnify : 'Nagy\u00EDtás (+ gomb)',
shrink : 'Kicsiny\u00EDt\u00E9s (- gomb)',
update : 'El\u00E9rhet\u0150 az \u00FAjabb verzi\u00F3',
slideshow : ''
}
], // hungarian
// finnish
fi : [
{
loading : 'Ladataan kuvaa',
loadingSub : 'Napsauta kerran keskeyttääksesi',
context : 'Näytä kuva alkuperäisessä kontekstissa',
error : 'Kuvaa ei saatavissa',
next : 'Seuraava kuva (oikea nuolinäppäin)',
previous : 'Edellinen kuva (vasen nuolinäppäin)',
magnify : 'Suurenna kuvaa (+ näppäin)',
shrink : 'Pienennä kuvaa (- näppäin)',
update : 'Päivitys saatavilla',
slideshow : 'Käynnistä/Pysäytä dia esitys'
}
], // finnish
// japanese
ja : [
{
loading : '\u8AAD\u307F\u8FBC\u307F\u4E2D',
loadingSub : '\u30AF\u30EA\u30C3\u30AF\u3067\u30AD\u30E3\u30F3\u30BB\u30EB\u3057\u307E\u3059',
context : '\u5143\u306E\u753B\u50CF\u3092\u8868\u793A',
error : '\u753B\u50CF\u304C\u5B58\u5728\u3057\u307E\u305B\u3093',
next : '\u6B21\u306E\u753B\u50CF',
previous : '\u524D\u306E\u753B\u50CF',
magnify : '\u753B\u50CF\u3092\u62E1\u5927 (+)',
shrink : '\u753B\u50CF\u3092\u7E2E\u5C0F (-)',
update : '\u65B0\u3057\u3044\u66F4\u65B0\u304C\u3042\u308A\u307E\u3059',
slideshow : '\u30B9\u30E9\u30A4\u30C9\u30B7\u30E7\u30FC\u3092\u958B\u59CB\u002F\u505C\u6B62'
}
], // japanese
// chinese (simplified)
zh : [
{
loading : '\u8BFB\u53D6\u56FE\u7247',
loadingSub : '\u6309\u4EFB\u610F\u952E\u6765\u53D6\u6D88',
context : '\u4EE5\u539F\u6587\u672C\u67E5\u770B\u56FE\u7247',
error : '\u56FE\u7247\u4E0D\u53EF\u8BFB',
next : '\u4E0B\u4E00\u4E2A\u56FE\u7247 (\u53F3\u952E)',
previous : '\u524D\u4E00\u4E2A\u56FE\u7247 (\u56FE\u7247)',
magnify : '\u653E\u5927\u56FE\u7247 (+\u952E)',
shrink : '\u7F29\u5C0F\u56FE\u7247 (-\u952E)',
update : '\u53EF\u63D0\u4F9B\u66F4\u65B0',
slideshow : ''
}
], // chinese (simplified)
// Chinese (traditional)
tw : [
{
loading : '\\u8F09\\u5165\\u5716\\u7247\\u4E2D',
loadingSub : '\\u6309\\u4EFB\\u610F\\u9375\\u53D6\\u6D88',
context : '\\u6253\\u958B\\u5716\\u7247\\u539F\\u59CB\\u7DB2\\u5740',
error : '\\u7121\\u6CD5\\u8F09\\u5165\\u5716\\u7247',
next : '\\u4E0B\\u4E00\\u5F35\\u5716 (\\u53F3\\u9375)',
previous : '\\u4E0A\\u4E00\\u5F35\\u5716 (\\u5DE6\\u9375)',
magnify : '\\u653E\\u5927\\u5716\\u7247 (+\\u9375)',
shrink : '\\u7E2E\\u5C0F\\u5716\\u7247 (-\\u9375)',
update : '\\u6709\\u66F4\\u65B0\\u7248\\u672C',
slideshow : '\\u958B\\u59CB/\\u505C\\u6B62\\u5FAA\\u5E8F\\u64AD\\u653E'
}
], // Chinese (traditional)
// polish
pl : [
{
loading : '\u0141aduj\u0119 obraz',
loadingSub : 'Kliknij aby przerwa\u010B',
context : 'Zobacz obraz w oryginalnym kontek\u015Bcie',
error : 'Obraz niedost\u0119pny',
next : 'Nast\u0119pny obraz (klawisz \u2192)',
previous : 'Poprzedni obraz (klawisz \u2190)',
magnify : 'Powi\u0119ksz obraz (klawisz +)',
shrink : 'Zmniejsz obraz (klawisz -)',
update : 'Dost\u0119pna nowa wersja',
slideshow : 'Uruchom/zatrzymaj pokaz slajd\u00F3w'
}
], // polish
// czech
cs : [
{
loading : 'Nahrávám obrázek',
loadingSub : 'Kliknete kamkoliv pro zrušení',
context : 'Prohlížet obrázek v orignálním kontextu',
error : 'Obrázek není dostupný',
next : 'Další obrázek (šipka doprava)',
previous : 'Predchozí obrázek (šipka doleva)',
magnify : 'Priblížit obrázek (klávesa +)',
shrink : 'Oddálit obrázek (klávesa -)',
update : 'Je dostupná aktualizace',
slideshow : 'Spustit/zastavit slideshow'
}
], // czech
// slovak
sk : [
{
loading : 'Nahrávam obrázok',
loadingSub : 'Pre zrušenie kliknite kdekolvek',
context : 'Prezriet obrázok v orignálnom kontexte',
error : 'Obrázok nie je dostupný',
next : 'Další obrázok (šípka doprava)',
previous : 'Predchádzajúci obrázok (šípka dolava)',
magnify : 'Priblížit obrázok (klávesa +)',
shrink : 'Oddialit obrázok (klávesa -)',
update : 'Je dostupná aktualizácia',
slideshow : ''
}
], // slovak
// swedish
sv : [
{
loading : 'Laddar bild',
loadingSub : 'Klicka för att avbryta',
context : 'Visa originalbild',
error : 'Bild inte tillgänglig',
next : 'Nästa bild (höger piltangent)',
previous : 'Föregående bild (vänster piltangent)',
magnify : 'Förstora bild (+-tangent)',
shrink : 'Förminska bild (–tangent)',
update : 'Ny uppdatering tillgänglig',
slideshow : 'Starta/stoppa bildspel'
}
], // swedish
/* language template
//
: [
{
loading : '',
loadingSub : '',
context : '',
error : '',
next : '',
previous : '',
magnify : '',
shrink : '',
update : '',
slideshow : ''
}
], // end
*/
// lauguage
// the correct language for localization is set in init()
language : null,
// init()
// sets this.language to the correct value based on navigator.language
init : function() {
this.language = this[navigator.language.substring(0,2)] ? navigator.language.substring(0,2) : 'en';
} // init()
}; // greasedLanguage
if (document.body) greasedLightbox.init();}
var offInstantSearch = true;
if (offInstantSearch) {
if (top != self) return;
var target = document.getElementById("po-off");
if (!target) return;
var className = target.className;
if (!className) return;
if (/unselected/.test(className))window.location = target.href;}
})();