; (function (){ "use strict"; function setup($){ $.fn._fadeIn = $.fn.fadeIn; var noOp = $.noop || function (){ } ; var msie = /MSIE/.test(navigator.userAgent); var ie6 = /MSIE 6.0/.test(navigator.userAgent) && !/MSIE 8.0/.test(navigator.userAgent); var mode = document.documentMode || 0; var setExpr = $.isFunction(_AN_Call_createelement("createElement", document, 'div').style.setExpression); $.blockUI = function (opts){ install(window, opts); } ; $.unblockUI = function (opts){ remove(window, opts); } ; $.growlUI = function (title, message, timeout, onClose){ var $m = $('
'); if (title) $m.append('

' + title + '

'); if (message) $m.append('

' + message + '

'); if (timeout === undefined) timeout = 3000; var callBlock = function (opts){ opts = opts || { } ; $.blockUI({ message: $m, fadeIn: typeof opts.fadeIn !== 'undefined'? opts.fadeIn: 700, fadeOut: typeof opts.fadeOut !== 'undefined'? opts.fadeOut: 1000, timeout: typeof opts.timeout !== 'undefined'? opts.timeout: timeout, centerY: false , showOverlay: false , onUnblock: onClose, css: $.blockUI.defaults.growlCSS} ); } ; callBlock(); var nonmousedOpacity = $m.css('opacity'); $m.mouseover(function (){ callBlock({ fadeIn: 0, timeout: 30000} ); var displayBlock = $('.blockMsg'); displayBlock.stop(); displayBlock.fadeTo(300, 1); } ).mouseout(function (){ $('.blockMsg').fadeOut(1000); } ); } ; $.fn.block = function (opts){ if (this[0] === window) { $.blockUI(opts); return this; } var fullOpts = $.extend({ } , $.blockUI.defaults, opts || { } ); this.each(function (){ var $el = $(this); if (fullOpts.ignoreIfBlocked && $el.data('blockUI.isBlocked')) return ; $el.unblock({ fadeOut: 0} ); } ); return this.each(function (){ if ($.css(this, 'position') == 'static') { this.style.position = 'relative'; $(this).data('blockUI.static', true ); } this.style.zoom = 1; install(this, opts); } ); } ; $.fn.unblock = function (opts){ if (this[0] === window) { $.unblockUI(opts); return this; } return this.each(function (){ remove(this, opts); } ); } ; $.blockUI.version = 2.7; $.blockUI.defaults = { message: '

Please wait...

', title: null , draggable: true , theme: false , css: { padding: 0, margin: 0, width: '30%', top: '40%', left: '35%', textAlign: 'center', color: '#000', border: '3px solid #aaa', backgroundColor: '#fff', cursor: 'wait'} , themedCSS: { width: '30%', top: '40%', left: '35%'} , overlayCSS: { backgroundColor: '#000', opacity: 0.6, cursor: 'wait'} , cursorReset: 'default', 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'} , iframeSrc: /^https/i.test(_AN_Read_href('href', _AN_Read_location('location', window)) || '')? 'javascript:false': 'about:blank', forceIframe: false , baseZ: 1000, centerX: true , centerY: true , allowBodyStretch: true , bindEvents: true , constrainTabKey: true , fadeIn: 200, fadeOut: 400, timeout: 0, showOverlay: true , focusInput: true , focusableElements: ':input:enabled:visible', onBlock: null , onUnblock: null , onOverlayClick: null , quirksmodeOffsetHack: 4, blockMsgClass: 'blockMsg', ignoreIfBlocked: false } ; var pageBlock = null ; var pageBlockEls = [] ; function install(el, opts){ var css, themedCSS; var full = (el == window); var msg = (opts && opts.message !== undefined? opts.message: undefined); opts = $.extend({ } , $.blockUI.defaults, opts || { } ); if (opts.ignoreIfBlocked && $(el).data('blockUI.isBlocked')) return ; opts.overlayCSS = $.extend({ } , $.blockUI.defaults.overlayCSS, opts.overlayCSS || { } ); css = $.extend({ } , $.blockUI.defaults.css, opts.css || { } ); if (opts.onOverlayClick) _AN_Write_cursor('cursor', opts.overlayCSS, false , 'pointer'); themedCSS = $.extend({ } , $.blockUI.defaults.themedCSS, opts.themedCSS || { } ); msg = msg === undefined? opts.message: msg; if (full && pageBlock) remove(window, { fadeOut: 0} ); 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); } $(el).data('blockUI.onUnblock', opts.onUnblock); var z = opts.baseZ; var lyr1, lyr2, lyr3, s; if (msie || opts.forceIframe) lyr1 = $(''); else lyr1 = $(''); if (opts.theme) lyr2 = $(''); else lyr2 = $(''); if (opts.theme && full) { s = ''; } else if (opts.theme) { s = ''; } else if (full) { s = ''; } else { s = ''; } lyr3 = $(s); if (msg) { if (opts.theme) { lyr3.css(themedCSS); lyr3.addClass('ui-widget-content'); } else lyr3.css(css); } if (!opts.theme) lyr2.css(opts.overlayCSS); lyr2.css('position', full? 'fixed': 'absolute'); if (msie || opts.forceIframe) lyr1.css('opacity', 0); 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'} ); } var expr = setExpr && (!$.support.boxModel || _AN_Read_length('length', $('object,embed', full? null : el)) > 0); if (ie6 || expr) { if (full && opts.allowBodyStretch && $.support.boxModel) $('html,body').css('height', '100%'); if ((ie6 || !$.support.boxModel) && !full) { var t = sz(el, 'borderTopWidth'), l = sz(el, 'borderLeftWidth'); var fixT = t? '(0 - ' + t + ')': 0; var fixL = l? '(0 - ' + l + ')': 0; } $.each(layers, function (i, o){ var s = o[0].style; s.position = 'absolute'; if (i < 2) { if (full) s.setExpression('height', 'Math.max(document.body.scrollHeight, document.body.offsetHeight) - (jQuery.support.boxModel?0:' + opts.quirksmodeOffsetHack + ') + "px"'); else s.setExpression('height', 'this.parentNode.offsetHeight + "px"'); if (full) s.setExpression('width', 'jQuery.support.boxModel && document.documentElement.clientWidth || document.body.clientWidth + "px"'); else 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, 10): 0; var expression = '((document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop) + ' + top + ') + "px"'; s.setExpression('top', expression); } } ); } if (msg) { if (opts.theme) lyr3.find('.ui-widget-content').append(msg); else lyr3.append(msg); if (msg.jquery || msg.nodeType) _AN_Call_show('show', $(msg)); } if ((msie || opts.forceIframe) && opts.showOverlay) _AN_Call_show('show', lyr1); 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) _AN_Call_show('show', lyr2); if (msg) _AN_Call_show('show', lyr3); if (opts.onBlock) opts.onBlock.bind(lyr3)(); } bind(1, el, opts); if (full) { pageBlock = lyr3[0]; pageBlockEls = $(opts.focusableElements, pageBlock); if (opts.focusInput) _AN_Call_settimeout('setTimeout', window, focus, 20); } else center(lyr3[0], opts.centerX, opts.centerY); if (opts.timeout) { var to = _AN_Call_settimeout('setTimeout', window, function (){ if (full) $.unblockUI(opts); else $(el).unblock(opts); } , opts.timeout); $(el).data('blockUI.timeout', to); } } function remove(el, opts){ var count; 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); if (opts.onUnblock === null ) { opts.onUnblock = $el.data('blockUI.onUnblock'); $el.removeData('blockUI.onUnblock'); } var els; if (full) els = $('body').children().filter('.blockUI').add('body > .blockUI'); else els = $el.find('>.blockUI'); if (opts.cursorReset) { if (_AN_Read_length('length', els) > 1) _AN_Write_cursor('cursor', els[1].style, false , opts.cursorReset); if (_AN_Read_length('length', els) > 2) _AN_Write_cursor('cursor', els[2].style, false , opts.cursorReset); } if (full) pageBlock = pageBlockEls = null ; if (opts.fadeOut) { count = _AN_Read_length('length', els); els.stop().fadeOut(opts.fadeOut, function (){ if (--count === 0) reset(els, data, opts, el); } ); } else reset(els, data, opts, el); } function reset(els, data, opts, el){ var $el = $(el); if ($el.data('blockUI.isBlocked')) return ; els.each(function (i, o){ if (this.parentNode) this.parentNode.removeChild(this); } ); if (data && data.el) { data.el.style.display = data.display; data.el.style.position = data.position; _AN_Write_cursor('cursor', data.el.style, false , 'default'); if (data.parent) _AN_Call_appendchild('appendChild', data.parent, data.el); $el.removeData('blockUI.history'); } if ($el.data('blockUI.static')) { $el.css('position', 'static'); } if (typeof opts.onUnblock == 'function') opts.onUnblock(el, opts); var body = $(document.body), w = body.width(), cssW = body[0].style.width; body.width(w - 1).width(w); body[0].style.width = cssW; } function bind(b, el, opts){ var full = el == window, $el = $(el); if (!b && (full && !pageBlock || !full && !$el.data('blockUI.isBlocked'))) return ; $el.data('blockUI.isBlocked', b); if (!full || !opts.bindEvents || (b && !opts.showOverlay)) return ; var events = 'mousedown mouseup keydown keypress keyup touchstart touchend touchmove'; if (b) $(document).bind(events, opts, handler); else $(document).unbind(events, handler); } function handler(e){ if (e.type === 'keydown' && e.keyCode && e.keyCode == 9) { if (pageBlock && e.data.constrainTabKey) { var els = pageBlockEls; var fwd = !e.shiftKey && _AN_Read_target('target', e) === els[_AN_Read_length('length', els) - 1]; var back = e.shiftKey && _AN_Read_target('target', e) === els[0]; if (fwd || back) { _AN_Call_settimeout('setTimeout', window, function (){ focus(back); } , 10); return false ; } } } var opts = e.data; var target = $(_AN_Read_target('target', e)); if (target.hasClass('blockOverlay') && opts.onOverlayClick) opts.onOverlayClick(e); if (_AN_Read_length('length', target.parents('div.' + opts.blockMsgClass)) > 0) return true ; return _AN_Read_length('length', target.parents().children().filter('div.blockUI')) === 0; } function focus(back){ if (!pageBlockEls) return ; var e = pageBlockEls[back === true ? _AN_Read_length('length', pageBlockEls) - 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), 10) || 0; } } if (typeof define === 'function' && define.amd && define.amd.jQuery) { define(['jquery'] , setup); } else { setup(jQuery); } } )();