Last active
June 25, 2016 14:07
-
-
Save eminarcissus/48c89e61a9324c4456a7 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// ==UserScript== | |
// @name ThunderAssistant | |
// @namespace http://dynamic.cloud.vip.xunlei.com | |
// @include http://dynamic.cloud.vip.xunlei.com/* | |
// @updateURL http://userscripts.org/scripts/source/111748.user.js | |
// @version 0.3.3 | |
// @grant GM_xmlhttpRequest | |
// ==/UserScript== | |
// | |
// For Firefox & Chrome & Safari | |
// Added $gdrive | |
// Will fix script malfunction when choosing between download categories next release. | |
// Fixed position problem 1/24/2013 | |
// Fixex Rule Reset problem when press cancel button on rule prompting | |
// Fixed shiftCheck not working after the update of Xunlei(async loading problem) | |
// Some minor changes to code | |
// Fixed onclick problem 9/24/2013 | |
if (document.title.length == 0) return; | |
// var s=document.createElement('script'); | |
//s.setAttribute('src', 'http://mcpub.googlecode.com/files/jquery.blockUI.js'); | |
// s.setAttribute('src', 'http://us.misuzi.me/jquery.blockUI.js'); | |
// document.body.appendChild(s); | |
function selectNode (node) { | |
//This is a third party function written by Martin Honnen | |
//In comp.lang.javascript | |
//http://groups-beta.google.com/group/comp.lang.javascript/browse_thread/thread/2b389e61c7b951f2/99b5f1bee9922c39?lnk=gst&q=(doc+%3D+node.ownerDocu ment)+%26%26+(win+%3D+doc.defaultView)&rnum=1&hl=e n#99b5f1bee9922c39 | |
var selection, range, doc, win; | |
if ((doc = node.ownerDocument) && (win = doc.defaultView) && typeof | |
win.getSelection != 'undefined' && typeof doc.createRange != 'undefined' | |
&& (selection = window.getSelection()) && typeof | |
selection.removeAllRanges != 'undefined') { | |
range = doc.createRange(); | |
range.selectNode(node); | |
selection.removeAllRanges(); | |
selection.addRange(range); | |
} else if (document.body && typeof document.body.createTextRange != | |
'undefined' && (range = document.body.createTextRange())) { | |
range.moveToElementText(node); | |
range.select(); | |
} | |
} | |
var XL=function(){ | |
this.init(); | |
} | |
XL.prototype={ | |
init:function() | |
{ | |
var o = this; | |
this.isSafari = navigator.userAgent.match(/Safari/) ? true : false; | |
this.auto_select = this.getAutoSelect(); | |
o.batchContent=[]; | |
o.links={}; | |
o.links['normal']={}; | |
o.links['bt']={}; | |
o.nowType=null; | |
//Rule only accept 2 variable $name $url | |
//wget -O $name $url | |
//localStorage.setItem('outputRule','wget -O "$name" "$url"'); | |
o.outputRule=localStorage.getItem('outputRule'); | |
o.aria2addr=localStorage.getItem('aria2addr'); | |
o.aria2addr = o.aria2addr ? o.aria2addr : 'http://localhost:6800/jsonrpc'; | |
o.outputRule= o.outputRule ? o.outputRule : 'default'; | |
o.returnData=new Array(); | |
o.showButton=$('.saveside:first').clone().attr('id','showAddr').css('clear','both').css('display','').html('<a></a>').find('a').attr('href','#').html('<em class="ic_sf ic_xl"></em>显示地址').end(); | |
o.watchButton=$('.saveside:first').clone().attr('id','ic_watchnow').html('<a></a>').find('a').attr('href','#').html('<em class="ic_yun"></em>在线观看').end(); | |
o.buttonPoint=$('.saveside:last').parent(); | |
//o.buttonPoint=$('#antherpt'); | |
o.buttonPoint.append(o.showButton).append(o.watchButton); | |
$('.ic_xl').css('background','url()'); | |
$('#showAddr a').click(function() | |
{ | |
o.showCheckedLinks(); | |
}); | |
/* | |
$('#showAddr a').live('click',function(){ | |
o.showCheckedLinks(); | |
}); | |
*/ | |
//Fetch download links at current page | |
o.fetchAll(); | |
//Live bind function to address box | |
$('#close_btn').live('click',function(){ | |
o.closeBox(); | |
}); | |
$('#send_rpc').live('click',function(){ | |
o.addToAria2(); | |
}) | |
// $('#output_txt').live('click',function(){ | |
// o.saveToDownList('normal'); | |
// }); | |
$('#batchedlink').live('click',function() | |
{ | |
o.auto_select ? selectNode(this) : null; | |
}); | |
$('#linkpage').live('click',function(){ | |
o.showLinkPage('normal'); | |
}); | |
$('#reform').live('click',function(){ | |
o.promptForRule(); | |
}) | |
$('#reset').live('click',function(){ | |
var result=confirm("Reset export rule?"); | |
result ? o.resetRule() : null; | |
}) | |
$('#reverse').live('click',function(){ | |
o.reverseResult(); | |
}); | |
$('#aria2addr').live('click',function(){ | |
o.setAria2Address(); | |
}); | |
$('#output_cmd').live('click',function(){ | |
o.outputCMD(); | |
}); | |
$('#ic_watchnow a').click(function(){ | |
o.watchOnline(); | |
}); | |
$('.auto_select').live('click',function(e){ | |
o.changeAutoSelect(); | |
}); | |
}, | |
fetchAll:function() | |
{ | |
var o = this; | |
//Trigger stands for BT Folder to be parsed. | |
//o.triggers=$('a[onclick*=bt_task_down]'); | |
//Normal stands for Emule/http links which had already been parsed. | |
o.triggers=$('a[onclick*=bt_list_show]'); | |
o.normals=$('input[value*=gdl][id*=dl]'); | |
o.normals.each(function(i,down) | |
{ | |
var tid=down.id.split('dl_url'); | |
var tid= tid ? tid[1] : null; | |
if (tid) | |
{ | |
var fname=$(down).siblings('input[id^=durl]')[0].value; | |
var furl=down.value; | |
o.links['normal'][tid]={'url':furl,'name':fname}; | |
} | |
}); | |
o.triggers.each(function(i,link) | |
{ | |
//var args=$(link).attr('onclick').toString().match(/bt_task_down\((.*)\)/)[1]; | |
var args=$(link).attr('onclick').toString().match(/bt_list_show\((.*)\)/)[1]; | |
var args=args.split(','); | |
var infoid=args[0].trim().replace("'",'').replace("'",'').replace('"','').replace('%27',''); | |
var tid=args[1].match(/\d+/)[0].trim(); | |
var G_section= o.isSafari ? $('html').html().match(/G_section = (.*?);/)[1] : unsafeWindow.G_section; | |
var G_USERID= o.isSafari ? location.href.match(/userid=(\d+)/)[1] : unsafeWindow.G_USERID; | |
console.log("infoid="+infoid); | |
//console.log("tid="+tid); | |
var base = i < 6 ? 10 : 5; | |
var target = i < 6 ? 10 : 100; | |
var time = base*target*i*Math.random() | |
setTimeout(function(){ | |
o.handle_bt_link(tid,infoid,G_section,G_USERID,time,10); | |
},time) | |
}); | |
}, | |
threaded_download:function(url,thread){ | |
}, | |
handle_bt_link:function(tid,infoid,G_section,G_USERID,timeout,retry){ | |
var o = this; | |
var url = "/interface/fill_bt_list?callback=fill_bt_list&tid="+tid+"&infoid="+infoid+"&g_net=1&p=1&uid="+G_USERID+"&noCacheIE="+Math.floor( new Date().getTime() / 1000 ) ; | |
$.get(url,function(data){ | |
if(data) | |
{ | |
var result = o.pushData(data,tid); | |
if(result == false){ | |
if(retry>0){ | |
//console.log("Retry "+tid+" now"); | |
setTimeout(function(){ | |
o.handle_bt_link(url,tid,G_section,G_USERID,timeout*2,retry-1) | |
},timeout*10); | |
} | |
else | |
{ | |
console.log("failed retry "+tid); | |
} | |
} | |
else | |
{ | |
if(retry<10) | |
{ | |
console.log("succeed retry "+tid); | |
} | |
} | |
} | |
}); | |
}, | |
isBt:function(tid) | |
{ | |
return this.links.bt.hasOwnProperty(tid); | |
}, | |
isNormal:function(tid) | |
{ | |
return this.links.normal.hasOwnProperty(tid); | |
}, | |
parseArgs:function(archor) | |
{ | |
var args=$(archor).attr('onclick').toString().match(/bt_task_down\((.*)\)/)[1]; | |
var args=args.split(','); | |
var infoid=args[0].trim(); | |
var tid=args[1].trim(); | |
return {'infoid':infoid,'tid':tid} ; | |
}, | |
getLinkByTid:function(tid) | |
{ | |
if (this.links.bt.hasOwnProperty(tid)) | |
{ | |
return this.links.bt[tid]; | |
} | |
}, | |
showAddress:function(addrString,type,callback) | |
{ | |
if(type=='normal') | |
{ | |
this.nowType='normal'; | |
this.addrBox=$('<div id="batchPublish"></div>') | |
.append('<div id="batchHeader"></div>') | |
.append('<div id="batchContent" style="float:left;clear:both"></div>') | |
.append('<div id="batchFooter" style="flolat:left;clear:both"></div>') ; | |
this.addrBox.find('.mcTab').css('display','none'); | |
this.addrBox.find('#batchHeader') | |
.append('<a style="float:left" id="output_txt" href="javascript:return null;">输出到文件 | </a>') | |
.append('<a style="float:left" id="linkpage" href="javascript:return null;">输出Linkpage | </a>') | |
.append('<span>ZhaLei LIST</span>') | |
.append('<a style="float:right" id="close_btn" href="javascript:return null;">关闭</a>') | |
.append('<a style="float:right" id="reset" href="javascript:return null;">重置格式|</a>') | |
.append('<a style="float:right" id="reform" href="javascript:return null;">修改|</a>') | |
.append('<a style="float:right" id="reverse" href="javascript:return null;">转序|</a>') | |
.append('<a style="float:right" id="aria2addr" href="javascript:return null;">RPC|</a>'); | |
this.addrBox.find('#batchFooter') | |
// .append('<a style="float:right" id="select_all_text" href="javascript:return null;">全选文本</a>') | |
.append('<div style="float:left"><input class="auto_select" type="checkbox"/><label class="auto_select">自动全选地址</label></div>') | |
.append('<a style="float:right" id="output_cmd" href="javascript:return null;">输出为脚本</a>') | |
.append('<a style="float:right" id="send_rpc" href="javascript:return null;">RPC下载</a>'); | |
var batchContent=this.addrBox.find('#batchContent') | |
.append('<pre id="batchedlink"></pre>'); | |
this.addrBox.find('#batchedlink').css({'width':'500px','height':'250px','overflow':'scroll'}) | |
.html(addrString); | |
$.blockUI({message:this.addrBox,css:{width:"520px",height:"300px"}}); | |
} | |
this.saveToDownList('normal'); | |
this.outputCMD(); | |
$('.auto_select').filter('input').attr('checked',this.auto_select); | |
if(typeof(callback)=='function') | |
{ | |
callback(); | |
} | |
}, | |
updateDownURL:function(text,urlId) | |
{ | |
var uriContent = "data:application/octet-stream," + encodeURIComponent(text).replace(/%26amp%3B/g,'%26'); | |
/*console.log(uriContent);*/ | |
document.getElementById(urlId).href=uriContent; | |
}, | |
saveToDownList:function(type) | |
{ | |
var tempString=""; | |
var returnLinks=this.getCheckedArchors() ; | |
var tempString=this.getPureAddress(returnLinks); | |
this.updateDownURL(tempString,'output_txt'); | |
}, | |
outputCMD:function() | |
{ | |
var tempString=$('#batchedlink').html(); | |
this.updateDownURL(tempString,'output_cmd'); | |
}, | |
closeBox:function() | |
{ | |
$.unblockUI(); | |
this.nowType=null; | |
}, | |
restartBox:function() | |
{ | |
var nowType=this.nowType; | |
this.closeBox(); | |
this.showCheckedLinks() ; | |
}, | |
getCheckedArchors:function() | |
{ | |
var o=this; | |
var checkboxs=$(':checked'); | |
var returnLinks=[]; | |
checkboxs.each(function(i,cb) | |
{ | |
var tid=cb.value; | |
var flag=o.isBt(tid); | |
if(flag) | |
{ | |
console.log("isBT"); | |
var dlinks=o.getLinkByTid(tid); | |
var i = 1; | |
$.each(dlinks,function(i,link){ | |
returnLinks.push(link); | |
}); | |
} | |
else | |
{ | |
if(o.isNormal(tid)) | |
{ | |
returnLinks.push(o.links.normal[tid]); | |
} | |
} | |
}); | |
return returnLinks; | |
}, | |
watchOnline:function(){ | |
var checkboxs=$(':checked'); | |
if (checkboxs.length==0) | |
{ | |
alert('请至少选择一个视频(文件夹不允许'); | |
return false | |
} | |
else if(checkboxs.length>1) | |
{ | |
alert('目前仅允许选择一个视频文件'); | |
return false | |
} | |
var addr=$(checkboxs[0]).parents('.rw_inter').html().match(/\"(http.*?gdl.*?)\"/)[1].replace(/&/g,'&'); | |
var videoDiv=$('<div id="watch_video"><video autoplay controls src="'+addr+'"><p>動画を再生するには、videoタグをサポートしたブラウザが必要です。</p></video></div>'); | |
$.blockUI({message:videoDiv}); | |
return false; | |
}, | |
setAria2Address:function() | |
{ | |
this.promptForAria2() | |
}, | |
addToAria2:function() | |
{ | |
var self = this; | |
var returnLinks=this.getCheckedArchors(); | |
var gdrive = document.cookie.match(/(gdriveid=.*?);/)[1]; | |
var requests = returnLinks.map(function(obj){ | |
return {methodName : "aria2.addUri",params : [[obj.url],{out: obj.name,header: "Cookie:gdriveid=" + gdrive}]}; | |
}); | |
console.log(self.aria2addr); | |
GM_xmlhttpRequest({ | |
method: 'POST', | |
url: self.aria2addr, | |
data: JSON.stringify({'jsonrpc':'2.0', 'id':(new Date).getTime(),'method':'system.multicall',params: [requests]}), | |
onload: function(response){alert("Apply succeed!"); /*display(response)*/} | |
,onerror: function(e){ | |
alert(e); | |
} | |
}); | |
}, | |
showCheckedLinks:function() | |
{ | |
var returnLinks=this.getCheckedArchors(); | |
var linkString=this.getLinkDetail(returnLinks); | |
this.showAddress(linkString,'normal'); | |
}, | |
pushData:function(data,tid) | |
{ | |
try | |
{ | |
var data=data.match(/fill_bt_list\((.*)\)/); | |
var rt=JSON.parse(data[1]); | |
this.returnData.push(data); | |
var tempArray=[]; | |
//console.log(rt); | |
if(!rt['Result']) | |
{return false} | |
$.each(rt['Result']['Record'],function(i,down) | |
{ | |
var fname=down.title; | |
var furl=down.downurl; | |
tempArray.push({'name':fname,'url':furl}); | |
}); | |
this.links['bt'][tid]=tempArray; | |
} | |
catch(e){ | |
return false | |
} | |
}, | |
getLinkDetail:function(links){ | |
var o = this; | |
var returnArray=[]; | |
if (o.outputRule == 'default') | |
{ | |
$.each(links,function(i,link) | |
{ | |
returnArray.push({'uri':link.url,'option':{'out':link.name}}); | |
}); | |
return JSON.stringify(returnArray) | |
} | |
else | |
{ | |
$.each(links,function(i,link) | |
{ | |
var name=link.name.split('\\\*'); | |
var filename=name.pop(); | |
var dir = name.length == 0 ? '/' : +'/'+name.join('/'); | |
var tempString=o.outputRule | |
.replace(/\\n/g,'\n') | |
.replace(/&/g,'&') | |
.replace(/\$name/g,filename) | |
.replace(/\$dir/g,dir) | |
.replace(/\$cookie/g,document.cookie) | |
.replace(/\$gdrive/g,document.cookie.match(/(gdriveid=.*?);/)[1]) | |
.replace(/\$url/g,link.url); | |
returnArray.push(tempString); | |
}); | |
o.batchContent=returnArray; | |
return returnArray.join('\n'); | |
} | |
}, | |
getPureAddress:function(links) | |
{ | |
var tempString=""; | |
$.each(links,function(i,link) | |
{ | |
tempString+=link.url+"\n"; | |
}); | |
return tempString; | |
}, | |
getLinkPage: function (type) | |
{ | |
var o = this; | |
var returnLinks= o.getCheckedArchors() ; | |
var content = $('<div id="main"><h1>Link Page</h1></div>'); | |
var insertPoint = content.filter('#main'); | |
$.each(returnLinks, function (i, link) { | |
var archor = $('<a class="dlinks"></a>'); | |
archor.attr('href', link.url).html(link.name); | |
insertPoint.append(archor).append('<br/>'); | |
}); | |
return content.html(); | |
}, | |
showLinkPage:function(type) | |
{ | |
var content=this.getLinkPage(type); | |
var my_window = window.open("", "flashgot", "status=1,width=400,height=450,scrollbars=1"); | |
my_window.document.write(content); | |
}, | |
promptForAria2 : function() | |
{ | |
var aria2addr = localStorage.getItem('aria2addr'); | |
var addr = prompt('aria2c jsonrpc address',this.aria2addr); | |
// check if lastRule exist, if not, empty string will return default setting,otherwise lastRule will be used | |
addr = addr ? addr : (aria2addr ? aria2addr : 'http://localhost:6800/jsonrpc'); | |
localStorage.setItem('aria2addr',addr); | |
this.aria2addr=addr; | |
// console.log(rule); | |
this.restartBox(); | |
}, | |
promptForRule : function() | |
{ | |
var lastRule = localStorage.getItem('outputRule'); | |
var rule = prompt('Plz input your custom rule which $name stands for Filename and $url for Download URL',this.outputRule); | |
// check if lastRule exist, if not, empty string will return default setting,otherwise lastRule will be used | |
rule = rule ? rule : (lastRule ? lastRule : 'default'); | |
localStorage.setItem('outputRule',rule); | |
this.outputRule=rule; | |
// console.log(rule); | |
this.restartBox(); | |
}, | |
resetRule : function() | |
{ | |
localStorage.setItem('output',null); | |
this.outputRule='default'; | |
alert('Output rule has been reset'); | |
this.restartBox(); | |
}, | |
changeAutoSelect : function() | |
{ | |
var flag=localStorage.getItem('auto_select') == "true" ? true : false ; | |
localStorage.setItem('auto_select',!flag); | |
this.auto_select=!flag; | |
$('.auto_select').filter('input').attr('checked',this.auto_select); | |
}, | |
getAutoSelect : function() | |
{ | |
var flag=localStorage.getItem('auto_select'); | |
flag === null ? localStorage.setItem('auto_select',true) : null; | |
return flag === "true" ? true : false ; | |
}, | |
reverseResult : function() | |
{ | |
$('#batchedlink').html(this.batchContent.reverse().join('\n')); | |
}, | |
} | |
loadJquery=function(){ | |
var triggers=document.getElementsByClassName('rwbtn ic_open'); | |
var normals=[]; | |
var nl=document.getElementsByTagName('input'); | |
for(var i=0;i<nl.length;i++){if(nl[i].hasAttribute('value') && nl[i].value.match(/http:\/\/gdl/) ){normals.push(nl[i])}} | |
/*console.log("Triggers:"+triggers.length); | |
console.log("Normals:"+normals.length);*/ | |
// if(typeof(unsafeWindow.jQuery)=='undefined' && typeof(unsafeWindow.jQuery.blockUI)!='function' ) | |
if((triggers.length==0 && normals.length==0) || typeof(unsafeWindow.jQuery)=='undefined' ) | |
{ | |
setTimeout(loadJquery,3000); | |
return | |
} | |
else | |
{ | |
jQuery=unsafeWindow.jQuery; | |
$=jQuery; | |
//Shiftclick support | |
//Required jquery&thickbox | |
(function($) { | |
$.fn.shiftClick = function() { | |
var lastSelected; | |
var checkBoxes = $(this); | |
this.each(function() { | |
$(this).click(function(ev) { | |
if (ev.shiftKey) { | |
var last = checkBoxes.index(lastSelected); | |
var first = checkBoxes.index(this); | |
var start = Math.min(first, last); | |
var end = Math.max(first, last); | |
var chk = lastSelected.checked; | |
for (var i = start; i < end; i++) { | |
checkBoxes[i].checked = chk; | |
} | |
} else { | |
lastSelected = this; | |
} | |
}) | |
}); | |
}; | |
})(jQuery); | |
var loadCheckbox = function(){ | |
if( $('.in_ztclick').length == 0 ) | |
{setTimeout(loadCheckbox,30);return} | |
$('input[type=checkbox]').shiftClick(); | |
}; | |
loadCheckbox(); | |
//var helloSimple=function(){alert('Hello Grease!')}; | |
//GM_registerMenuCommand("Hello, world! (again)", helloSimple, "e", "shift alt", "w"); | |
(function($) { | |
if (/1\.(0|1|2)\.(0|1|2)/.test($.fn.jquery) || /^1.1/.test($.fn.jquery)) { | |
alert('blockUI requires jQuery v1.2.3 or later! You are using v' + $.fn.jquery); | |
return; | |
} | |
$.fn._fadeIn = $.fn.fadeIn; | |
var noOp = function() {}; | |
// this bit is to ensure we don't call setExpression when we shouldn't (with extra muscle to handle | |
// retarded userAgent strings on Vista) | |
var mode = document.documentMode || 0; | |
var setExpr = $.browser.msie && (($.browser.version < 8 && !mode) || mode < 8); | |
var ie6 = $.browser.msie && /MSIE 6.0/.test(navigator.userAgent) && !mode; | |
// global $ methods for blocking/unblocking the entire page | |
$.blockUI = function(opts) { install(window, opts); }; | |
$.unblockUI = function(opts) { remove(window, opts); }; | |
// convenience method for quick growl-like notifications (http://www.google.com/search?q=growl) | |
$.growlUI = function(title, message, timeout, onClose) { | |
var $m = $('<div class="growlUI"></div>'); | |
if (title) $m.append('<h1>'+title+'</h1>'); | |
if (message) $m.append('<h2>'+message+'</h2>'); | |
if (timeout == undefined) timeout = 3000; | |
$.blockUI({ | |
message: $m, fadeIn: 700, fadeOut: 1000, centerY: false, | |
timeout: timeout, showOverlay: false, | |
onUnblock: onClose, | |
css: $.blockUI.defaults.growlCSS | |
}); | |
}; | |
// plugin method for blocking element content | |
$.fn.block = function(opts) { | |
return this.unblock({ fadeOut: 0 }).each(function() { | |
if ($.css(this,'position') == 'static') | |
this.style.position = 'relative'; | |
if ($.browser.msie) | |
this.style.zoom = 1; // force 'hasLayout' | |
install(this, opts); | |
}); | |
}; | |
// plugin method for unblocking element content | |
$.fn.unblock = function(opts) { | |
return this.each(function() { | |
remove(this, opts); | |
}); | |
}; | |
$.blockUI.version = 2.35; // 2nd generation blocking at no extra cost! | |
// override these in your code to change the default behavior and style | |
$.blockUI.defaults = { | |
// message displayed when blocking (use null for no message) | |
message: '<h1>Please wait...</h1>', | |
title: null, // title string; only used when theme == true | |
draggable: true, // only used when theme == true (requires jquery-ui.js to be loaded) | |
theme: false, // set to true to use with jQuery UI themes | |
// styles for the message when blocking; if you wish to disable | |
// these and use an external stylesheet then do this in your code: | |
// $.blockUI.defaults.css = {}; | |
css: { | |
padding: 0, | |
margin: 0, | |
width: '30%', | |
top: '40%', | |
left: '35%', | |
textAlign: 'center', | |
color: '#000', | |
border: '3px solid #aaa', | |
backgroundColor:'#fff', | |
cursor: 'wait' | |
}, | |
// minimal style set used when themes are used | |
themedCSS: { | |
width: '30%', | |
top: '40%', | |
left: '35%' | |
}, | |
// styles for the overlay | |
overlayCSS: { | |
backgroundColor: '#000', | |
opacity: 0.6, | |
cursor: 'wait' | |
}, | |
// styles applied when using $.growlUI | |
growlCSS: { | |
width: '350px', | |
top: '10px', | |
left: '', | |
right: '10px', | |
border: 'none', | |
padding: '5px', | |
opacity: 0.6, | |
cursor: 'default', | |
color: '#fff', | |
backgroundColor: '#000', | |
'-webkit-border-radius': '10px', | |
'-moz-border-radius': '10px', | |
'border-radius': '10px' | |
}, | |
// IE issues: 'about:blank' fails on HTTPS and javascript:false is s-l-o-w | |
// (hat tip to Jorge H. N. de Vasconcelos) | |
iframeSrc: /^https/i.test(window.location.href || '') ? 'javascript:false' : 'about:blank', | |
// force usage of iframe in non-IE browsers (handy for blocking applets) | |
forceIframe: false, | |
// z-index for the blocking overlay | |
baseZ: 1000, | |
// set these to true to have the message automatically centered | |
centerX: true, // <-- only effects element blocking (page block controlled via css above) | |
centerY: true, | |
// allow body element to be stetched in ie6; this makes blocking look better | |
// on "short" pages. disable if you wish to prevent changes to the body height | |
allowBodyStretch: true, | |
// enable if you want key and mouse events to be disabled for content that is blocked | |
bindEvents: true, | |
// be default blockUI will supress tab navigation from leaving blocking content | |
// (if bindEvents is true) | |
constrainTabKey: true, | |
// fadeIn time in millis; set to 0 to disable fadeIn on block | |
fadeIn: 200, | |
// fadeOut time in millis; set to 0 to disable fadeOut on unblock | |
fadeOut: 400, | |
// time in millis to wait before auto-unblocking; set to 0 to disable auto-unblock | |
timeout: 0, | |
// disable if you don't want to show the overlay | |
showOverlay: true, | |
// if true, focus will be placed in the first available input field when | |
// page blocking | |
focusInput: true, | |
// suppresses the use of overlay styles on FF/Linux (due to performance issues with opacity) | |
applyPlatformOpacityRules: true, | |
// callback method invoked when fadeIn has completed and blocking message is visible | |
onBlock: null, | |
// callback method invoked when unblocking has completed; the callback is | |
// passed the element that has been unblocked (which is the window object for page | |
// blocks) and the options that were passed to the unblock call: | |
// onUnblock(element, options) | |
onUnblock: null, | |
// don't ask; if you really must know: http://groups.google.com/group/jquery-en/browse_thread/thread/36640a8730503595/2f6a79a77a78e493#2f6a79a77a78e493 | |
quirksmodeOffsetHack: 4, | |
// class name of the message block | |
blockMsgClass: 'blockMsg' | |
}; | |
// private data and functions follow... | |
var pageBlock = null; | |
var pageBlockEls = []; | |
function install(el, opts) { | |
var full = (el == window); | |
var msg = opts && opts.message !== undefined ? opts.message : undefined; | |
opts = $.extend({}, $.blockUI.defaults, opts || {}); | |
opts.overlayCSS = $.extend({}, $.blockUI.defaults.overlayCSS, opts.overlayCSS || {}); | |
var css = $.extend({}, $.blockUI.defaults.css, opts.css || {}); | |
var themedCSS = $.extend({}, $.blockUI.defaults.themedCSS, opts.themedCSS || {}); | |
msg = msg === undefined ? opts.message : msg; | |
// remove the current block (if there is one) | |
if (full && pageBlock) | |
remove(window, {fadeOut:0}); | |
// if an existing element is being used as the blocking content then we capture | |
// its current place in the DOM (and current display style) so we can restore | |
// it when we unblock | |
if (msg && typeof msg != 'string' && (msg.parentNode || msg.jquery)) { | |
var node = msg.jquery ? msg[0] : msg; | |
var data = {}; | |
$(el).data('blockUI.history', data); | |
data.el = node; | |
data.parent = node.parentNode; | |
data.display = node.style.display; | |
data.position = node.style.position; | |
if (data.parent) | |
data.parent.removeChild(node); | |
} | |
var z = opts.baseZ; | |
// blockUI uses 3 layers for blocking, for simplicity they are all used on every platform; | |
// layer1 is the iframe layer which is used to supress bleed through of underlying content | |
// layer2 is the overlay layer which has opacity and a wait cursor (by default) | |
// layer3 is the message content that is displayed while blocking | |
var lyr1 = ($.browser.msie || opts.forceIframe) | |
? $('<iframe class="blockUI" style="z-index:'+ (z++) +';display:none;border:none;margin:0;padding:0;position:absolute;width:100%;height:100%;top:0;left:0" src="'+opts.iframeSrc+'"></iframe>') | |
: $('<div class="blockUI" style="display:none"></div>'); | |
var lyr2 = $('<div class="blockUI blockOverlay" style="z-index:'+ (z++) +';display:none;border:none;margin:0;padding:0;width:100%;height:100%;top:0;left:0"></div>'); | |
var lyr3, s; | |
if (opts.theme && full) { | |
s = '<div class="blockUI ' + opts.blockMsgClass + ' blockPage ui-dialog ui-widget ui-corner-all" style="z-index:'+z+';display:none;position:fixed">' + | |
'<div class="ui-widget-header ui-dialog-titlebar ui-corner-all blockTitle">'+(opts.title || ' ')+'</div>' + | |
'<div class="ui-widget-content ui-dialog-content"></div>' + | |
'</div>'; | |
} | |
else if (opts.theme) { | |
s = '<div class="blockUI ' + opts.blockMsgClass + ' blockElement ui-dialog ui-widget ui-corner-all" style="z-index:'+z+';display:none;position:absolute">' + | |
'<div class="ui-widget-header ui-dialog-titlebar ui-corner-all blockTitle">'+(opts.title || ' ')+'</div>' + | |
'<div class="ui-widget-content ui-dialog-content"></div>' + | |
'</div>'; | |
} | |
else if (full) { | |
s = '<div class="blockUI ' + opts.blockMsgClass + ' blockPage" style="z-index:'+z+';display:none;position:fixed"></div>'; | |
} | |
else { | |
s = '<div class="blockUI ' + opts.blockMsgClass + ' blockElement" style="z-index:'+z+';display:none;position:absolute"></div>'; | |
} | |
lyr3 = $(s); | |
// if we have a message, style it | |
if (msg) { | |
if (opts.theme) { | |
lyr3.css(themedCSS); | |
lyr3.addClass('ui-widget-content'); | |
} | |
else | |
lyr3.css(css); | |
} | |
// style the overlay | |
if (!opts.applyPlatformOpacityRules || !($.browser.mozilla && /Linux/.test(navigator.platform))) | |
lyr2.css(opts.overlayCSS); | |
lyr2.css('position', full ? 'fixed' : 'absolute'); | |
// make iframe layer transparent in IE | |
if ($.browser.msie || opts.forceIframe) | |
lyr1.css('opacity',0.0); | |
//$([lyr1[0],lyr2[0],lyr3[0]]).appendTo(full ? 'body' : el); | |
var layers = [lyr1,lyr2,lyr3], $par = full ? $('body') : $(el); | |
$.each(layers, function() { | |
this.appendTo($par); | |
}); | |
if (opts.theme && opts.draggable && $.fn.draggable) { | |
lyr3.draggable({ | |
handle: '.ui-dialog-titlebar', | |
cancel: 'li' | |
}); | |
} | |
// ie7 must use absolute positioning in quirks mode and to account for activex issues (when scrolling) | |
var expr = setExpr && (!$.boxModel || $('object,embed', full ? null : el).length > 0); | |
if (ie6 || expr) { | |
// give body 100% height | |
if (full && opts.allowBodyStretch && $.boxModel) | |
$('html,body').css('height','100%'); | |
// fix ie6 issue when blocked element has a border width | |
if ((ie6 || !$.boxModel) && !full) { | |
var t = sz(el,'borderTopWidth'), l = sz(el,'borderLeftWidth'); | |
var fixT = t ? '(0 - '+t+')' : 0; | |
var fixL = l ? '(0 - '+l+')' : 0; | |
} | |
// simulate fixed position | |
$.each([lyr1,lyr2,lyr3], function(i,o) { | |
var s = o[0].style; | |
s.position = 'absolute'; | |
if (i < 2) { | |
full ? s.setExpression('height','Math.max(document.body.scrollHeight, document.body.offsetHeight) - (jQuery.boxModel?0:'+opts.quirksmodeOffsetHack+') + "px"') | |
: s.setExpression('height','this.parentNode.offsetHeight + "px"'); | |
full ? s.setExpression('width','jQuery.boxModel && document.documentElement.clientWidth || document.body.clientWidth + "px"') | |
: s.setExpression('width','this.parentNode.offsetWidth + "px"'); | |
if (fixL) s.setExpression('left', fixL); | |
if (fixT) s.setExpression('top', fixT); | |
} | |
else if (opts.centerY) { | |
if (full) s.setExpression('top','(document.documentElement.clientHeight || document.body.clientHeight) / 2 - (this.offsetHeight / 2) + (blah = document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop) + "px"'); | |
s.marginTop = 0; | |
} | |
else if (!opts.centerY && full) { | |
var top = (opts.css && opts.css.top) ? parseInt(opts.css.top) : 0; | |
var expression = '((document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop) + '+top+') + "px"'; | |
s.setExpression('top',expression); | |
} | |
}); | |
} | |
// show the message | |
if (msg) { | |
if (opts.theme) | |
lyr3.find('.ui-widget-content').append(msg); | |
else | |
lyr3.append(msg); | |
if (msg.jquery || msg.nodeType) | |
$(msg).show(); | |
} | |
if (($.browser.msie || opts.forceIframe) && opts.showOverlay) | |
lyr1.show(); // opacity is zero | |
if (opts.fadeIn) { | |
var cb = opts.onBlock ? opts.onBlock : noOp; | |
var cb1 = (opts.showOverlay && !msg) ? cb : noOp; | |
var cb2 = msg ? cb : noOp; | |
if (opts.showOverlay) | |
lyr2._fadeIn(opts.fadeIn, cb1); | |
if (msg) | |
lyr3._fadeIn(opts.fadeIn, cb2); | |
} | |
else { | |
if (opts.showOverlay) | |
lyr2.show(); | |
if (msg) | |
lyr3.show(); | |
if (opts.onBlock) | |
opts.onBlock(); | |
} | |
// bind key and mouse events | |
bind(1, el, opts); | |
if (full) { | |
pageBlock = lyr3[0]; | |
pageBlockEls = $(':input:enabled:visible',pageBlock); | |
if (opts.focusInput) | |
setTimeout(focus, 20); | |
} | |
else | |
center(lyr3[0], opts.centerX, opts.centerY); | |
if (opts.timeout) { | |
// auto-unblock | |
var to = setTimeout(function() { | |
full ? $.unblockUI(opts) : $(el).unblock(opts); | |
}, opts.timeout); | |
$(el).data('blockUI.timeout', to); | |
} | |
}; | |
// remove the block | |
function remove(el, opts) { | |
var full = (el == window); | |
var $el = $(el); | |
var data = $el.data('blockUI.history'); | |
var to = $el.data('blockUI.timeout'); | |
if (to) { | |
clearTimeout(to); | |
$el.removeData('blockUI.timeout'); | |
} | |
opts = $.extend({}, $.blockUI.defaults, opts || {}); | |
bind(0, el, opts); // unbind events | |
var els; | |
if (full) // crazy selector to handle odd field errors in ie6/7 | |
els = $('body').children().filter('.blockUI').add('body > .blockUI'); | |
else | |
els = $('.blockUI', el); | |
if (full) | |
pageBlock = pageBlockEls = null; | |
if (opts.fadeOut) { | |
els.fadeOut(opts.fadeOut); | |
setTimeout(function() { reset(els,data,opts,el); }, opts.fadeOut); | |
} | |
else | |
reset(els, data, opts, el); | |
}; | |
// move blocking element back into the DOM where it started | |
function reset(els,data,opts,el) { | |
els.each(function(i,o) { | |
// remove via DOM calls so we don't lose event handlers | |
if (this.parentNode) | |
this.parentNode.removeChild(this); | |
}); | |
if (data && data.el) { | |
data.el.style.display = data.display; | |
data.el.style.position = data.position; | |
if (data.parent) | |
data.parent.appendChild(data.el); | |
$(el).removeData('blockUI.history'); | |
} | |
if (typeof opts.onUnblock == 'function') | |
opts.onUnblock(el,opts); | |
}; | |
// bind/unbind the handler | |
function bind(b, el, opts) { | |
var full = el == window, $el = $(el); | |
// don't bother unbinding if there is nothing to unbind | |
if (!b && (full && !pageBlock || !full && !$el.data('blockUI.isBlocked'))) | |
return; | |
if (!full) | |
$el.data('blockUI.isBlocked', b); | |
// don't bind events when overlay is not in use or if bindEvents is false | |
if (!opts.bindEvents || (b && !opts.showOverlay)) | |
return; | |
// bind anchors and inputs for mouse and key events | |
var events = 'mousedown mouseup keydown keypress'; | |
b ? $(document).bind(events, opts, handler) : $(document).unbind(events, handler); | |
// former impl... | |
// var $e = $('a,:input'); | |
// b ? $e.bind(events, opts, handler) : $e.unbind(events, handler); | |
}; | |
// event handler to suppress keyboard/mouse events when blocking | |
function handler(e) { | |
// allow tab navigation (conditionally) | |
if (e.keyCode && e.keyCode == 9) { | |
if (pageBlock && e.data.constrainTabKey) { | |
var els = pageBlockEls; | |
var fwd = !e.shiftKey && e.target === els[els.length-1]; | |
var back = e.shiftKey && e.target === els[0]; | |
if (fwd || back) { | |
setTimeout(function(){focus(back)},10); | |
return false; | |
} | |
} | |
} | |
var opts = e.data; | |
// allow events within the message content | |
if ($(e.target).parents('div.' + opts.blockMsgClass).length > 0) | |
return true; | |
// allow events for content that is not being blocked | |
return $(e.target).parents().children().filter('div.blockUI').length == 0; | |
}; | |
function focus(back) { | |
if (!pageBlockEls) | |
return; | |
var e = pageBlockEls[back===true ? pageBlockEls.length-1 : 0]; | |
if (e) | |
e.focus(); | |
}; | |
function center(el, x, y) { | |
var p = el.parentNode, s = el.style; | |
var l = ((p.offsetWidth - el.offsetWidth)/2) - sz(p,'borderLeftWidth'); | |
var t = ((p.offsetHeight - el.offsetHeight)/2) - sz(p,'borderTopWidth'); | |
if (x) s.left = l > 0 ? (l+'px') : '0'; | |
if (y) s.top = t > 0 ? (t+'px') : '0'; | |
}; | |
function sz(el, p) { | |
return parseInt($.css(el,p))||0; | |
}; | |
})(jQuery); | |
xlob=new XL(); | |
unsafeWindow.XL=xlob; | |
} | |
} | |
loadJquery(); | |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment