jqModal.js 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /*
  2. * jqModal - Minimalist Modaling with jQuery
  3. *
  4. * Copyright (c) 2007 Brice Burgess <bhb@iceburg.net>, http://www.iceburg.net
  5. * Licensed under the MIT License:
  6. * http://www.opensource.org/licenses/mit-license.php
  7. *
  8. * $Version: 2007.08.17 +r11
  9. *
  10. */
  11. (function($) {
  12. $.fn.jqm=function(o){
  13. var _o = {
  14. zIndex: 3000,
  15. overlay: 50,
  16. overlayClass: 'jqmOverlay',
  17. closeClass: 'jqmClose',
  18. trigger: '.jqModal',
  19. ajax: false,
  20. target: false,
  21. modal: false,
  22. toTop: false,
  23. onShow: false,
  24. onHide: false,
  25. onLoad: false
  26. };
  27. return this.each(function(){if(this._jqm)return; s++; this._jqm=s;
  28. H[s]={c:$.extend(_o, o),a:false,w:$(this).addClass('jqmID'+s),s:s};
  29. if(_o.trigger)$(this).jqmAddTrigger(_o.trigger);
  30. });};
  31. $.fn.jqmAddClose=function(e){hs(this,e,'jqmHide'); return this;};
  32. $.fn.jqmAddTrigger=function(e){hs(this,e,'jqmShow'); return this;};
  33. $.fn.jqmShow=function(t){return this.each(function(){if(!H[this._jqm].a)$.jqm.open(this._jqm,t)});};
  34. $.fn.jqmHide=function(t){return this.each(function(){if(H[this._jqm].a)$.jqm.close(this._jqm,t)});};
  35. $.jqm = {
  36. hash:{},
  37. open:function(s,t){var h=H[s],c=h.c,cc='.'+c.closeClass,z=(/^\d+$/.test(h.w.css('z-index')))?h.w.css('z-index'):c.zIndex,o=$('<div></div>').css({height:'100%',width:'100%',position:'fixed',left:0,top:0,'z-index':z-1,opacity:c.overlay/100});h.t=t;h.a=true;h.w.css('z-index',z);
  38. if(c.modal) {if(!A[0])F('bind');A.push(s);o.css('cursor','wait');}
  39. else if(c.overlay > 0)h.w.jqmAddClose(o);
  40. else o=false;
  41. h.o=(o)?o.addClass(c.overlayClass).prependTo('body'):false;
  42. if(ie6){$('html,body').css({height:'100%',width:'100%'});if(o){o=o.css({position:'absolute'})[0];for(var y in {Top:1,Left:1})o.style.setExpression(y.toLowerCase(),"(_=(document.documentElement.scroll"+y+" || document.body.scroll"+y+"))+'px'");}}
  43. if(c.ajax) {var r=c.target||h.w,u=c.ajax,r=(typeof r == 'string')?$(r,h.w):$(r),u=(u.substr(0,1) == '@')?$(t).attr(u.substring(1)):u;
  44. r.load(u,function(){if(c.onLoad)c.onLoad.call(this,h);if(cc)h.w.jqmAddClose($(cc,h.w));e(h);});}
  45. else if(cc)h.w.jqmAddClose($(cc,h.w));
  46. if(c.toTop&&h.o)h.w.before('<span id="jqmP'+h.w[0]._jqm+'"></span>').insertAfter(h.o);
  47. (c.onShow)?c.onShow(h):h.w.show();e(h);return false;
  48. },
  49. close:function(s){var h=H[s];h.a=false;
  50. if(A[0]){A.pop();if(!A[0])F('unbind');}
  51. if(h.c.toTop&&h.o)$('#jqmP'+h.w[0]._jqm).after(h.w).remove();
  52. if(h.c.onHide)h.c.onHide(h);else{h.w.hide();if(h.o)h.o.remove();} return false;
  53. }};
  54. var s=0,H=$.jqm.hash,A=[],ie6=$.browser.msie&&($.browser.version == "6.0"),
  55. i=$('<iframe src="javascript:false;document.write(\'\');" class="jqm"></iframe>').css({opacity:0}),
  56. e=function(h){if(ie6)if(h.o)h.o.html('<p style="width:100%;height:100%"/>').prepend(i);else if(!$('iframe.jqm',h.w)[0])h.w.prepend(i); f(h);},
  57. f=function(h){try{$(':input:visible',h.w)[0].focus();}catch(e){}},
  58. F=function(t){$()[t]("keypress",m)[t]("keydown",m)[t]("mousedown",m);},
  59. m=function(e){var h=H[A[A.length-1]],r=(!$(e.target).parents('.jqmID'+h.s)[0]);if(r)f(h);return !r;},
  60. hs=function(w,e,y){var s=[];w.each(function(){s.push(this._jqm)});
  61. $(e).each(function(){if(this[y])$.extend(this[y],s);else{this[y]=s;$(this).click(function(){for(var i in {jqmShow:1,jqmHide:1})for(var s in this[i])if(H[this[i][s]])H[this[i][s]].w[i](this);return false;});}});};
  62. })(jQuery);