WordPress.org

Make WordPress Core

Ticket #5492: jquery.diff

File jquery.diff, 118.6 KB (added by ryan, 6 years ago)
  • wp-includes/js/jquery/jquery.js

     
     1(function(){ 
    12/* 
    2  * jQuery 1.1.4 - New Wave Javascript 
     3 * jQuery 1.2.2b2 - New Wave Javascript 
    34 * 
    45 * Copyright (c) 2007 John Resig (jquery.com) 
    56 * Dual licensed under the MIT (MIT-LICENSE.txt) 
    67 * and GPL (GPL-LICENSE.txt) licenses. 
    78 * 
    8  * $Date: 2007-08-23 21:49:27 -0400 (Thu, 23 Aug 2007) $ 
    9  * $Rev: 2862 $ 
     9 * $Date: 2007-12-20 21:47:33 -0800 (Thu, 20 Dec 2007) $ 
     10 * $Rev: 4293 $ 
    1011 */ 
    11 eval(function(p,a,c,k,e,r){e=function(c){return(c<a?'':e(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--)r[e(c)]=k[c]||e(c);k=[function(e){return r[e]}];e=function(){return'\\w+'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\b'+e(c)+'\\b','g'),k[c]);return p}('(9(){6(1f C!="Q")E v=C;E C=19.16=9(a,c){6(19==7||!7.4a)F 1s C(a,c);F 7.4a(a,c)};6(1f $!="Q")E B=$;19.$=C;E q=/^[^<]*(<(.|\\s)+>)[^>]*$|^#(\\w+)$/;C.15=C.3v={4a:9(a,c){a=a||R;6(1f a=="1E"){E m=q.2d(a);6(m&&(m[1]||!c)){6(m[1])a=C.3c([m[1]]);G{E b=R.37(m[3]);6(b)6(b.2j!=m[3])F C().1F(a);G{7[0]=b;7.H=1;F 7}G a=[]}}G F 1s C(c).1F(a)}G 6(C.1g(a))F 1s C(R)[C.15.1L?"1L":"2f"](a);F 7.5J(a.1b==1K&&a||(a.3w||a.H&&a!=19&&!a.1t&&a[0]!=Q&&a[0].1t)&&C.2V(a)||[a])},3w:"1.1.4",7K:9(){F 7.H},H:0,21:9(a){F a==Q?C.2V(7):7[a]},1O:9(a){E b=C(a);b.5c=7;F b},5J:9(a){7.H=0;1K.3v.Y.T(7,a);F 7},J:9(a,b){F C.J(7,a,b)},45:9(a){E b=-1;7.J(9(i){6(7==a)b=i});F b},1j:9(f,d,e){E c=f;6(f.1b==3n)6(d==Q)F 7.H&&C[e||"1j"](7[0],f)||Q;G{c={};c[f]=d}F 7.J(9(a){I(E b 17 c)C.1j(e?7.S:7,b,C.4Q(7,c[b],e,a,b))})},1h:9(b,a){F 7.1j(b,a,"34")},2Q:9(e){6(1f e!="4P"&&e!=K)F 7.3K().3H(R.60(e));E t="";C.J(e||7,9(){C.J(7.2Z,9(){6(7.1t!=8)t+=7.1t!=1?7.5S:C.15.2Q([7])})});F t},82:9(){E a,2e=1a;F 7.J(9(){6(!a)a=C.3c(2e,7.2I);E b=a[0].3B(O);7.P.2p(b,7);20(b.1k)b=b.1k;b.4p(7)})},3H:9(){F 7.2J(1a,O,1,9(a){7.4p(a)})},5v:9(){F 7.2J(1a,O,-1,9(a){7.2p(a,7.1k)})},5u:9(){F 7.2J(1a,M,1,9(a){7.P.2p(a,7)})},5t:9(){F 7.2J(1a,M,-1,9(a){7.P.2p(a,7.2a)})},3L:9(){F 7.5c||C([])},1F:9(t){E b=C.3M(7,9(a){F C.1F(t,a)});F 7.1O(/[^+>] [^+>]/.1d(t)||t.U("..")>-1?C.4d(b):b)},7o:9(e){e=e!=Q?e:O;E d=7.1r(7.1F("*"));6(C.N.12){d.J(9(){7.2l$1i={};I(E a 17 7.$1i)7.2l$1i[a]=C.14({},7.$1i[a])}).49()}E r=7.1O(C.3M(7,9(a){F a.3B(e)}));6(C.N.12){d.J(9(){E c=7.2l$1i;I(E a 17 c)I(E b 17 c[a])C.1c.1r(7,a,c[a][b],c[a][b].V);7.2l$1i=K})}6(e){E f=r.1r(r.1F(\'*\')).1l(\'2b,39[@L=3i]\');d.1l(\'2b,39[@L=3i]\').J(9(i){6(7.3j)f[i].3j=7.3j;6(7.27)f[i].27=O})}F r},1l:9(t){F 7.1O(C.1g(t)&&C.2B(7,9(b,a){F t.T(b,[a])})||C.2R(t,7))},5l:9(t){F 7.1O(t.1b==3n&&C.2R(t,7,O)||C.2B(7,9(a){F(t.1b==1K||t.3w)?C.4K(a,t)<0:a!=t}))},1r:9(t){F 7.1O(C.29(7.21(),t.1b==3n?C(t).21():t.H!=Q&&(!t.W||t.W=="6s")?t:[t]))},3y:9(a){F a?C.2R(a,7).H>0:M},2G:9(a){F a==Q?(7.H?7[0].2A:K):7.1j("2A",a)},5W:9(a){F a==Q?(7.H?7[0].2W:K):7.3K().3H(a)},3S:9(){F 7.1O(1K.3v.3S.T(7,1a))},2J:9(f,d,g,e){E c=7.H>1,a;F 7.J(9(){6(!a){a=C.3c(f,7.2I);6(g<0)a.8E()}E b=7;6(d&&C.W(7,"1A")&&C.W(a[0],"3O"))b=7.4L("1w")[0]||7.4p(R.6a("1w"));C.J(a,9(){6(C.W(7,"33")){6(7.32)C.31({1G:7.32,2w:M,3G:"33"});G C.4E(7.2Q||7.5Z||7.2W||"")}G e.T(b,[c?7.3B(O):7])})})}};C.14=C.15.14=9(){E c=1a[0]||{},a=1,1M=1a.H,4D=M;6(c.1b==8d){4D=c;c=1a[1]||{}}6(1M==1){c=7;a=0}E b;I(;a<1M;a++)6((b=1a[a])!=K)I(E i 17 b){6(c==b[i])5X;6(4D&&1f b[i]==\'4P\'&&c[i])C.14(c[i],b[i]);G 6(b[i]!=Q)c[i]=b[i]}F c};C.14({8a:9(a){19.$=B;6(a)19.16=v;F C},1g:9(a){F!!a&&1f a!="1E"&&!a.W&&a.1b!=1K&&/9/i.1d(a+"")},3E:9(a){F a.3D&&!a.4z||a.4y&&a.2I&&!a.2I.4z},4E:9(a){a=C.2s(a);6(a){6(19.5N)19.5N(a);G 6(C.N.1H)19.4x(a,0);G 2T.2S(19,a)}},W:9(b,a){F b.W&&b.W.1I()==a.1I()},J:9(a,b,c){6(c){6(a.H==Q)I(E i 17 a)b.T(a[i],c);G I(E i=0,3A=a.H;i<3A;i++)6(b.T(a[i],c)===M)1J}G{6(a.H==Q)I(E i 17 a)b.2S(a[i],i,a[i]);G I(E i=0,3A=a.H,2G=a[0];i<3A&&b.2S(2G,i,2G)!==M;2G=a[++i]){}}F a},4Q:9(c,b,d,e,a){6(C.1g(b))b=b.2S(c,[e]);E f=/z-?45|7S-?7Q|1e|5y|7O-?1u/i;F b&&b.1b==3x&&d=="34"&&!f.1d(a)?b+"4t":b},18:{1r:9(b,c){C.J((c||"").2M(/\\s+/),9(i,a){6(!C.18.2N(b.18,a))b.18+=(b.18?" ":"")+a})},23:9(b,c){b.18=c!=Q?C.2B(b.18.2M(/\\s+/),9(a){F!C.18.2N(c,a)}).5w(" "):""},2N:9(t,c){F C.4K(c,(t.18||t).3s().2M(/\\s+/))>-1}},1V:9(e,o,f){I(E i 17 o){e.S["2U"+i]=e.S[i];e.S[i]=o[i]}f.T(e,[]);I(E i 17 o)e.S[i]=e.S["2U"+i]},1h:9(e,p){6(p=="1u"||p=="24"){E b={},3p,3o,d=["7J","7G","7F","7B"];C.J(d,9(){b["7A"+7]=0;b["7x"+7+"7u"]=0});C.1V(e,b,9(){6(C(e).3y(\':4N\')){3p=e.7t;3o=e.7q}G{e=C(e.3B(O)).1F(":4e").5d("27").3L().1h({3V:"1C",3k:"7n",11:"2m",7h:"0",7e:"0"}).57(e.P)[0];E a=C.1h(e.P,"3k")||"3g";6(a=="3g")e.P.S.3k="76";3p=e.74;3o=e.71;6(a=="3g")e.P.S.3k="3g";e.P.3e(e)}});F p=="1u"?3p:3o}F C.34(e,p)},34:9(h,d,g){E i,1R=[],1V=[];9 2E(a){6(!C.N.1H)F M;E b=R.2L.3b(a,K);F!b||b.44("2E")==""}6(d=="1e"&&C.N.12){i=C.1j(h.S,"1e");F i==""?"1":i}6(d.2k(/3a/i))d=x;6(!g&&h.S[d])i=h.S[d];G 6(R.2L&&R.2L.3b){6(d.2k(/3a/i))d="3a";d=d.1v(/([A-Z])/g,"-$1").2D();E e=R.2L.3b(h,K);6(e&&!2E(h))i=e.44(d);G{I(E a=h;a&&2E(a);a=a.P)1R.42(a);I(a=0;a<1R.H;a++)6(2E(1R[a])){1V[a]=1R[a].S.11;1R[a].S.11="2m"}i=d=="11"&&1V[1R.H-1]!=K?"1T":R.2L.3b(h,K).44(d)||"";I(a=0;a<1V.H;a++)6(1V[a]!=K)1R[a].S.11=1V[a]}6(d=="1e"&&i=="")i="1"}G 6(h.41){E f=d.1v(/\\-(\\w)/g,9(m,c){F c.1I()});i=h.41[d]||h.41[f]}F i},3c:9(a,c){E r=[];c=c||R;C.J(a,9(i,b){6(!b)F;6(b.1b==3x)b=b.3s();6(1f b=="1E"){E s=C.2s(b).2D(),1m=c.6a("1m"),1P=[];E a=!s.U("<1Z")&&[1,"<2b>","</2b>"]||!s.U("<6L")&&[1,"<4V>","</4V>"]||s.2k(/^<(6I|1w|6H|6F|6D)/)&&[1,"<1A>","</1A>"]||!s.U("<3O")&&[2,"<1A><1w>","</1w></1A>"]||(!s.U("<6A")||!s.U("<6y"))&&[3,"<1A><1w><3O>","</3O></1w></1A>"]||!s.U("<6x")&&[2,"<1A><1w></1w><4T>","</4T></1A>"]||C.N.12&&[1,"1m<1m>","</1m>"]||[0,"",""];1m.2W=a[1]+b+a[2];20(a[0]--)1m=1m.3Y;6(C.N.12){6(!s.U("<1A")&&s.U("<1w")<0)1P=1m.1k&&1m.1k.2Z;G 6(a[1]=="<1A>"&&s.U("<1w")<0)1P=1m.2Z;I(E n=1P.H-1;n>=0;--n)6(C.W(1P[n],"1w")&&!1P[n].2Z.H)1P[n].P.3e(1P[n]);6(/^\\s/.1d(b))1m.2p(c.60(b.2k(/^\\s*/)[0]),1m.1k)}b=C.2V(1m.2Z)}6(0===b.H&&(!C.W(b,"38")&&!C.W(b,"2b")))F;6(b[0]==Q||C.W(b,"38")||b.6u)r.Y(b);G r=C.29(r,b)});F r},1j:9(c,d,a){E e=C.3E(c)?{}:C.4q;6(d=="28"&&C.N.1H)c.P.3j;6(e[d]){6(a!=Q)c[e[d]]=a;F c[e[d]]}G 6(C.N.12&&d=="S")F C.1j(c.S,"6p",a);G 6(a==Q&&C.N.12&&C.W(c,"38")&&(d=="6n"||d=="6m"))F c.6k(d).5S;G 6(c.4y){6(a!=Q)c.6j(d,a);6(C.N.12&&/5R|32/.1d(d)&&!C.3E(c))F c.3F(d,2);F c.3F(d)}G{6(d=="1e"&&C.N.12){6(a!=Q){c.5y=1;c.1l=(c.1l||"").1v(/5T\\([^)]*\\)/,"")+(3m(a).3s()=="6d"?"":"5T(1e="+a*6c+")")}F c.1l?(3m(c.1l.2k(/1e=([^)]*)/)[1])/6c).3s():""}d=d.1v(/-([a-z])/8I,9(z,b){F b.1I()});6(a!=Q)c[d]=a;F c[d]}},2s:9(t){F(t||"").1v(/^\\s+|\\s+$/g,"")},2V:9(a){E r=[];6(1f a!="8H")I(E i=0,1M=a.H;i<1M;i++)r.Y(a[i]);G r=a.3S(0);F r},4K:9(b,a){I(E i=0,1M=a.H;i<1M;i++)6(a[i]==b)F i;F-1},29:9(a,b){6(C.N.12){I(E i=0;b[i];i++)6(b[i].1t!=8)a.Y(b[i])}G I(E i=0;b[i];i++)a.Y(b[i]);F a},4d:9(a){E r=[],4O=C.1q++;2g{I(E i=0,69=a.H;i<69;i++)6(4O!=a[i].1q){a[i].1q=4O;r.Y(a[i])}}2h(e){r=a}F r},1q:0,2B:9(b,a,c){6(1f a=="1E")a=2T("M||9(a,i){F "+a+"}");E d=[];I(E i=0,3P=b.H;i<3P;i++)6(!c&&a(b[i],i)||c&&!a(b[i],i))d.Y(b[i]);F d},3M:9(c,b){6(1f b=="1E")b=2T("M||9(a){F "+b+"}");E d=[];I(E i=0,3P=c.H;i<3P;i++){E a=b(c[i],i);6(a!==K&&a!=Q){6(a.1b!=1K)a=[a];d=d.8x(a)}}F d}});E u=8w.8u.2D();C.N={6b:(u.2k(/.+(?:8s|8q|8p|8o)[\\/: ]([\\d.]+)/)||[])[1],1H:/61/.1d(u),2t:/2t/.1d(u),12:/12/.1d(u)&&!/2t/.1d(u),3J:/3J/.1d(u)&&!/(8n|61)/.1d(u)};E x=C.N.12?"3I":"4G";C.14({8m:!C.N.12||R.8l=="8k",3I:C.N.12?"3I":"4G",4q:{"I":"8j","8i":"18","3a":x,4G:x,3I:x,2W:"2W",18:"18",2A:"2A",30:"30",27:"27",8h:"8g",28:"28",8f:"8e"}});C.J({5Y:"a.P",4C:"16.4C(a)",8c:"16.25(a,2,\'2a\')",8b:"16.25(a,2,\'4B\')",88:"16.4A(a.P.1k,a)",87:"16.4A(a.1k)"},9(i,n){C.15[i]=9(a){E b=C.3M(7,n);6(a&&1f a=="1E")b=C.2R(a,b);F 7.1O(C.4d(b))}});C.J({57:"3H",86:"5v",2p:"5u",85:"5t"},9(i,n){C.15[i]=9(){E a=1a;F 7.J(9(){I(E j=0,1M=a.H;j<1M;j++)C(a[j])[n](7)})}});C.J({5d:9(a){C.1j(7,a,"");7.84(a)},83:9(c){C.18.1r(7,c)},81:9(c){C.18.23(7,c)},80:9(c){C.18[C.18.2N(7,c)?"23":"1r"](7,c)},23:9(a){6(!a||C.1l(a,[7]).r.H)7.P.3e(7)},3K:9(){20(7.1k)7.3e(7.1k)}},9(i,n){C.15[i]=9(){F 7.J(n,1a)}});C.J(["5Q","5P","5M","5L"],9(i,n){C.15[n]=9(a,b){F 7.1l(":"+n+"("+a+")",b)}});C.J(["1u","24"],9(i,n){C.15[n]=9(h){F h==Q?(7.H?C.1h(7[0],n):K):7.1h(n,h.1b==3n?h:h+"4t")}});E A=C.N.1H&&5K(C.N.6b)<7Z?"(?:[\\\\w*2l-]|\\\\\\\\.)":"(?:[\\\\w\\7Y-\\7V*2l-]|\\\\\\\\.)",5I=1s 3C("^[/>]\\\\s*("+A+"+)"),5H=1s 3C("^("+A+"+)(#)("+A+"+)"),5G=1s 3C("^([#.]?)("+A+"*)");C.14({4w:{"":"m[2]==\'*\'||16.W(a,m[2])","#":"a.3F(\'2j\')==m[2]",":":{5P:"i<m[3]-0",5M:"i>m[3]-0",25:"m[3]-0==i",5Q:"m[3]-0==i",2H:"i==0",2P:"i==r.H-1",5E:"i%2==0",5D:"i%2","2H-3z":"a.P.4L(\'*\')[0]==a","2P-3z":"16.25(a.P.3Y,1,\'4B\')==a","7U-3z":"!16.25(a.P.3Y,2,\'4B\')",5Y:"a.1k",3K:"!a.1k",5L:"(a.5Z||a.7T||\'\').U(m[3])>=0",4N:\'"1C"!=a.L&&16.1h(a,"11")!="1T"&&16.1h(a,"3V")!="1C"\',1C:\'"1C"==a.L||16.1h(a,"11")=="1T"||16.1h(a,"3V")=="1C"\',7R:"!a.30",30:"a.30",27:"a.27",28:"a.28||16.1j(a,\'28\')",2Q:"\'2Q\'==a.L",4e:"\'4e\'==a.L",3i:"\'3i\'==a.L",4v:"\'4v\'==a.L",5C:"\'5C\'==a.L",4u:"\'4u\'==a.L",5B:"\'5B\'==a.L",5A:"\'5A\'==a.L",1X:\'"1X"==a.L||16.W(a,"1X")\',39:"/39|2b|7P|1X/i.1d(a.W)",2N:"16.1F(m[3],a).H"},"[":"16.1F(m[2],a).H"},5x:[/^\\[ *(@)([\\w-]+) *([!*$^~=]*) *(\'?"?)(.*?)\\4 *\\]/,/^(\\[)\\s*(.*?(\\[.*?\\])?[^[]*?)\\s*\\]/,/^(:)([\\w-]+)\\("?\'?(.*?(\\(.*?\\))?[^(]*?)"?\'?\\)/,1s 3C("^([:.#]*)("+A+"+)")],2R:9(a,c,b){E d,1Y=[];20(a&&a!=d){d=a;E f=C.1l(a,c,b);a=f.t.1v(/^\\s*,\\s*/,"");1Y=b?c=f.r:C.29(1Y,f.r)}F 1Y},1F:9(t,l){6(1f t!="1E")F[t];6(l&&!l.1t)l=K;l=l||R;6(!t.U("//")){t=t.2K(2,t.H)}G 6(!t.U("/")&&!l.2I){l=l.3D;t=t.2K(1,t.H);6(t.U("/")>=1)t=t.2K(t.U("/"),t.H)}E d=[l],2q=[],2P;20(t&&2P!=t){E r=[];2P=t;t=C.2s(t).1v(/^\\/\\//,"");E k=M;E g=5I;E m=g.2d(t);6(m){E o=m[1].1I();I(E i=0;d[i];i++)I(E c=d[i].1k;c;c=c.2a)6(c.1t==1&&(o=="*"||c.W.1I()==o.1I()))r.Y(c);d=r;t=t.1v(g,"");6(t.U(" ")==0)5X;k=O}G{g=/^((\\/?\\.\\.)|([>\\/+~]))\\s*(\\w*)/i;6((m=g.2d(t))!=K){r=[];E o=m[4],1q=C.1q++;m=m[1];I(E j=0,2o=d.H;j<2o;j++)6(m.U("..")<0){E n=m=="~"||m=="+"?d[j].2a:d[j].1k;I(;n;n=n.2a)6(n.1t==1){6(m=="~"&&n.1q==1q)1J;6(!o||n.W.1I()==o.1I()){6(m=="~")n.1q=1q;r.Y(n)}6(m=="+")1J}}G r.Y(d[j].P);d=r;t=C.2s(t.1v(g,""));k=O}}6(t&&!k){6(!t.U(",")){6(l==d[0])d.4s();2q=C.29(2q,d);r=d=[l];t=" "+t.2K(1,t.H)}G{E h=5H;E m=h.2d(t);6(m){m=[0,m[2],m[3],m[1]]}G{h=5G;m=h.2d(t)}m[2]=m[2].1v(/\\\\/g,"");E f=d[d.H-1];6(m[1]=="#"&&f&&f.37&&!C.3E(f)){E p=f.37(m[2]);6((C.N.12||C.N.2t)&&p&&1f p.2j=="1E"&&p.2j!=m[2])p=C(\'[@2j="\'+m[2]+\'"]\',f)[0];d=r=p&&(!m[3]||C.W(p,m[3]))?[p]:[]}G{I(E i=0;d[i];i++){E a=m[1]!=""||m[0]==""?"*":m[2];6(a=="*"&&d[i].W.2D()=="4P")a="2O";r=C.29(r,d[i].4L(a))}6(m[1]==".")r=C.4r(r,m[2]);6(m[1]=="#"){E e=[];I(E i=0;r[i];i++)6(r[i].3F("2j")==m[2]){e=[r[i]];1J}r=e}d=r}t=t.1v(h,"")}}6(t){E b=C.1l(t,r);d=r=b.r;t=C.2s(b.t)}}6(t)d=[];6(d&&l==d[0])d.4s();2q=C.29(2q,d);F 2q},4r:9(r,m,a){m=" "+m+" ";E c=[];I(E i=0;r[i];i++){E b=(" "+r[i].18+" ").U(m)>=0;6(!a&&b||a&&!b)c.Y(r[i])}F c},1l:9(t,r,h){E d;20(t&&t!=d){d=t;E p=C.5x,m;I(E i=0;p[i];i++){m=p[i].2d(t);6(m){t=t.7N(m[0].H);m[2]=m[2].1v(/\\\\/g,"");1J}}6(!m)1J;6(m[1]==":"&&m[2]=="5l")r=C.1l(m[3],r,O).r;G 6(m[1]==".")r=C.4r(r,m[2],h);G 6(m[1]=="@"){E g=[],L=m[3];I(E i=0,2o=r.H;i<2o;i++){E a=r[i],z=a[C.4q[m[2]]||m[2]];6(z==K||/5R|32|28/.1d(m[2]))z=C.1j(a,m[2])||\'\';6((L==""&&!!z||L=="="&&z==m[5]||L=="!="&&z!=m[5]||L=="^="&&z&&!z.U(m[5])||L=="$="&&z.2K(z.H-m[5].H)==m[5]||(L=="*="||L=="~=")&&z.U(m[5])>=0)^h)g.Y(a)}r=g}G 6(m[1]==":"&&m[2]=="25-3z"){E e=C.1q++,g=[],1d=/(\\d*)n\\+?(\\d*)/.2d(m[3]=="5E"&&"2n"||m[3]=="5D"&&"2n+1"||!/\\D/.1d(m[3])&&"n+"+m[3]||m[3]),2H=(1d[1]||1)-0,d=1d[2]-0;I(E i=0,2o=r.H;i<2o;i++){E j=r[i],P=j.P;6(e!=P.1q){E c=1;I(E n=P.1k;n;n=n.2a)6(n.1t==1)n.4o=c++;P.1q=e}E b=M;6(2H==1){6(d==0||j.4o==d)b=O}G 6((j.4o+d)%2H==0)b=O;6(b^h)g.Y(j)}r=g}G{E f=C.4w[m[1]];6(1f f!="1E")f=C.4w[m[1]][m[2]];f=2T("M||9(a,i){F "+f+"}");r=C.2B(r,f,h)}}F{r:r,t:t}},4C:9(c){E b=[];E a=c.P;20(a&&a!=R){b.Y(a);a=a.P}F b},25:9(a,e,c,b){e=e||1;E d=0;I(;a;a=a[c])6(a.1t==1&&++d==e)1J;F a},4A:9(n,a){E r=[];I(;n;n=n.2a){6(n.1t==1&&(!a||n!=a))r.Y(n)}F r}});C.1c={1r:9(f,d,c,b){6(C.N.12&&f.3t!=Q)f=19;6(!c.22)c.22=7.22++;6(b!=Q){E e=c;c=9(){F e.T(7,1a)};c.V=b;c.22=e.22}6(!f.$1i)f.$1i={};6(!f.$1y)f.$1y=9(){E a;6(1f C=="Q"||C.1c.4n)F a;a=C.1c.1y.T(f,1a);F a};E g=f.$1i[d];6(!g){g=f.$1i[d]={};6(f.4m)f.4m(d,f.$1y,M);G f.7M("3r"+d,f.$1y)}g[c.22]=c;7.1D[d]=O},22:1,1D:{},23:9(c,b,a){E d=c.$1i,2c,45;6(d){6(b&&b.L){a=b.4l;b=b.L}6(!b){I(b 17 d)7.23(c,b)}G 6(d[b]){6(a)4k d[b][a.22];G I(a 17 c.$1i[b])4k d[b][a];I(2c 17 d[b])1J;6(!2c){6(c.4j)c.4j(b,c.$1y,M);G c.7L("3r"+b,c.$1y);2c=K;4k d[b]}}I(2c 17 d)1J;6(!2c)c.$1y=c.$1i=K}},1z:9(c,b,d){b=C.2V(b||[]);6(!d){6(7.1D[c])C("*").1r([19,R]).1z(c,b)}G{E a,2c,15=C.1g(d[c]||K);b.42(7.4i({L:c,1S:d}));6(C.1g(d.$1y))a=d.$1y.T(d,b);6(!15&&d["3r"+c]&&d["3r"+c].T(d,b)===M)a=M;6(15&&a!==M&&!(C.W(d,\'a\')&&c=="4h")){7.4n=O;d[c]()}7.4n=M}},1y:9(b){E a;b=C.1c.4i(b||19.1c||{});E c=7.$1i&&7.$1i[b.L],2e=1K.3v.3S.2S(1a,1);2e.42(b);I(E j 17 c){2e[0].4l=c[j];2e[0].V=c[j].V;6(c[j].T(7,2e)===M){b.2u();b.2X();a=M}}6(C.N.12)b.1S=b.2u=b.2X=b.4l=b.V=K;F a},4i:9(c){E a=c;c=C.14({},a);c.2u=9(){6(a.2u)a.2u();a.7I=M};c.2X=9(){6(a.2X)a.2X();a.7H=O};6(!c.1S&&c.5r)c.1S=c.5r;6(C.N.1H&&c.1S.1t==3)c.1S=a.1S.P;6(!c.4g&&c.4F)c.4g=c.4F==c.1S?c.7C:c.4F;6(c.5p==K&&c.66!=K){E e=R.3D,b=R.4z;c.5p=c.66+(e&&e.5o||b.5o||0);c.7z=c.7v+(e&&e.5m||b.5m||0)}6(!c.3Q&&(c.5k||c.5j))c.3Q=c.5k||c.5j;6(!c.5i&&c.5g)c.5i=c.5g;6(!c.3Q&&c.1X)c.3Q=(c.1X&1?1:(c.1X&2?3:(c.1X&4?2:0)));F c}};C.15.14({3l:9(c,a,b){F c=="5f"?7.5e(c,a,b):7.J(9(){C.1c.1r(7,c,b||a,b&&a)})},5e:9(d,b,c){F 7.J(9(){C.1c.1r(7,d,9(a){C(7).49(a);F(c||b).T(7,1a)},c&&b)})},49:9(a,b){F 7.J(9(){C.1c.23(7,a,b)})},1z:9(a,b){F 7.J(9(){C.1c.1z(a,b,7)})},1W:9(){E a=1a;F 7.4h(9(e){7.3T=0==7.3T?1:0;e.2u();F a[7.3T].T(7,[e])||M})},7p:9(f,g){9 3U(e){E p=e.4g;20(p&&p!=7)2g{p=p.P}2h(e){p=7};6(p==7)F M;F(e.L=="3W"?f:g).T(7,[e])}F 7.3W(3U).5b(3U)},1L:9(f){5a();6(C.36)f.T(R,[C]);G C.2C.Y(9(){F f.T(7,[C])});F 7}});C.14({36:M,2C:[],1L:9(){6(!C.36){C.36=O;6(C.2C){C.J(C.2C,9(){7.T(R)});C.2C=K}6(C.N.3J||C.N.2t)R.4j("59",C.1L,M);6(!19.7m.H)C(19).2f(9(){C("#4b").23()})}}});C.J(("7l,7k,2f,7j,7i,5f,4h,7g,"+"7f,7d,7c,3W,5b,7b,2b,"+"4u,7a,79,78,3f").2M(","),9(i,o){C.15[o]=9(f){F f?7.3l(o,f):7.1z(o)}});E w=M;9 5a(){6(w)F;w=O;6(C.N.3J||C.N.2t)R.4m("59",C.1L,M);G 6(C.N.12){R.75("<73"+"72 2j=4b 70=O "+"32=//:><\\/33>");E a=R.37("4b");6(a)a.6Z=9(){6(R.3d!="1x")F;C.1L()};a=K}G 6(C.N.1H)C.48=3t(9(){6(R.3d=="6Y"||R.3d=="1x"){47(C.48);C.48=K;C.1L()}},10);C.1c.1r(19,"2f",C.1L)}C.15.14({6X:9(c,b,a){7.2f(c,b,a,1)},2f:9(g,e,c,d){6(C.1g(g))F 7.3l("2f",g);c=c||9(){};E f="46";6(e)6(C.1g(e)){c=e;e=K}G{e=C.2O(e);f="55"}E h=7;C.31({1G:g,L:f,V:e,2F:d,1x:9(a,b){6(b=="1U"||!d&&b=="54")h.5W(a.43);4x(9(){h.J(c,[a.43,b,a])},13)}});F 7},6W:9(){F C.2O(7)},6V:9(){}});C.J("53,52,51,50,4Z,5h".2M(","),9(i,o){C.15[o]=9(f){F 7.3l(o,f)}});C.14({21:9(e,c,a,d,b){6(C.1g(c)){a=c;c=K}F C.31({L:"46",1G:e,V:c,1U:a,3G:d,2F:b})},6U:9(d,b,a,c){F C.21(d,b,a,c,1)},6T:9(b,a){F C.21(b,K,a,"33")},77:9(c,b,a){F C.21(c,b,a,"56")},6S:9(d,b,a,c){6(C.1g(b)){a=b;b={}}F C.31({L:"55",1G:d,V:b,1U:a,3G:c})},6R:9(a){C.3u.1Q=a},6Q:9(a){C.14(C.3u,a)},3u:{1D:O,L:"46",1Q:0,4Y:"6P/x-6O-38-6N",4X:O,2w:O,V:K},3h:{},31:9(s){s=C.14(O,s,C.14(O,{},C.3u,s));6(s.V){6(s.4X&&1f s.V!="1E")s.V=C.2O(s.V);6(s.L.2D()=="21"){s.1G+=(s.1G.U("?")>-1?"&":"?")+s.V;s.V=K}}6(s.1D&&!C.40++)C.1c.1z("53");E f=M;E h=19.4W?1s 4W("6M.6K"):1s 58();h.6J(s.L,s.1G,s.2w);6(s.V)h.4c("7r-7s",s.4Y);6(s.2F)h.4c("6G-3Z-6E",C.3h[s.1G]||"7w, 6C 7y 6B 4J:4J:4J 6z");h.4c("X-7D-7E","58");6(s.4U)s.4U(h);6(s.1D)C.1c.1z("5h",[h,s]);E g=9(d){6(!f&&h&&(h.3d==4||d=="1Q")){f=O;6(i){47(i);i=K}E c=d=="1Q"&&"1Q"||!C.5n(h)&&"3f"||s.2F&&C.5s(h,s.1G)&&"54"||"1U";6(c=="1U"){2g{E a=C.5q(h,s.3G)}2h(e){c="4I"}}6(c=="1U"){E b;2g{b=h.4f("4S-3Z")}2h(e){}6(s.2F&&b)C.3h[s.1G]=b;6(s.1U)s.1U(a,c);6(s.1D)C.1c.1z("4Z",[h,s])}G C.3X(s,h,c);6(s.1D)C.1c.1z("51",[h,s]);6(s.1D&&!--C.40)C.1c.1z("52");6(s.1x)s.1x(h,c);6(s.2w)h=K}};6(s.2w){E i=3t(g,13);6(s.1Q>0)4x(9(){6(h){h.6w();6(!f)g("1Q")}},s.1Q)}2g{h.6v(s.V)}2h(e){C.3X(s,h,K,e)}6(!s.2w)g();F h},3X:9(s,a,b,e){6(s.3f)s.3f(a,b,e);6(s.1D)C.1c.1z("50",[a,s,e])},40:0,5n:9(r){2g{F!r.26&&6t.6r=="4v:"||(r.26>=4R&&r.26<6q)||r.26==5z||C.N.1H&&r.26==Q}2h(e){}F M},5s:9(a,c){2g{E b=a.4f("4S-3Z");F a.26==5z||b==C.3h[c]||C.N.1H&&a.26==Q}2h(e){}F M},5q:9(r,a){E b=r.4f("6o-L");E c=a=="5F"||!a&&b&&b.U("5F")>=0;V=c?r.7W:r.43;6(c&&V.3D.4y=="4I")7X"4I";6(a=="33")C.4E(V);6(a=="56")V=2T("("+V+")");F V},2O:9(a){E s=[];6(a.1b==1K||a.3w)C.J(a,9(){s.Y(2y(7.6l)+"="+2y(7.2A))});G I(E j 17 a)6(a[j]&&a[j].1b==1K)C.J(a[j],9(){s.Y(2y(j)+"="+2y(7))});G s.Y(2y(j)+"="+2y(a[j]));F s.5w("&")}});C.15.14({1o:9(b,a){F b?7.1B({1u:"1o",24:"1o",1e:"1o"},b,a):7.1l(":1C").J(9(){7.S.11=7.2r?7.2r:"";6(C.1h(7,"11")=="1T")7.S.11="2m"}).3L()},1p:9(b,a){F b?7.1B({1u:"1p",24:"1p",1e:"1p"},b,a):7.1l(":4N").J(9(){7.2r=7.2r||C.1h(7,"11");6(7.2r=="1T")7.2r="2m";7.S.11="1T"}).3L()},5O:C.15.1W,1W:9(a,b){F C.1g(a)&&C.1g(b)?7.5O(a,b):a?7.1B({1u:"1W",24:"1W",1e:"1W"},a,b):7.J(9(){C(7)[C(7).3y(":1C")?"1o":"1p"]()})},6i:9(b,a){F 7.1B({1u:"1o"},b,a)},6h:9(b,a){F 7.1B({1u:"1p"},b,a)},6g:9(b,a){F 7.1B({1u:"1W"},b,a)},6f:9(b,a){F 7.1B({1e:"1o"},b,a)},89:9(b,a){F 7.1B({1e:"1p"},b,a)},6e:9(c,a,b){F 7.1B({1e:a},c,b)},1B:9(d,h,f,g){F 7.1n(9(){E c=C(7).3y(":1C"),1Z=C.5V(h,f,g),5U=7;I(E p 17 d){6(d[p]=="1p"&&c||d[p]=="1o"&&!c)F C.1g(1Z.1x)&&1Z.1x.T(7);6(p=="1u"||p=="24"){1Z.11=C.1h(7,"11");1Z.2z=7.S.2z}}6(1Z.2z!=K)7.S.2z="1C";7.2v=C.14({},d);C.J(d,9(a,b){E e=1s C.2Y(5U,1Z,a);6(b.1b==3x)e.3R(e.1Y()||0,b);G e[b=="1W"?c?"1o":"1p":b](d)});F O})},1n:9(a,b){6(!b){b=a;a="2Y"}F 7.J(9(){6(!7.1n)7.1n={};6(!7.1n[a])7.1n[a]=[];7.1n[a].Y(b);6(7.1n[a].H==1)b.T(7)})}});C.14({5V:9(b,a,c){E d=b&&b.1b==8G?b:{1x:c||!c&&a||C.1g(b)&&b,1N:b,35:c&&a||a&&a.1b!=8F&&a};d.1N=(d.1N&&d.1N.1b==3x?d.1N:{8D:8C,8B:4R}[d.1N])||8A;d.2U=d.1x;d.1x=9(){C.68(7,"2Y");6(C.1g(d.2U))d.2U.T(7)};F d},35:{62:9(p,n,b,a){F b+a*p},4H:9(p,n,b,a){F((-67.8z(p*67.8y)/2)+0.5)*a+b}},1n:{},68:9(b,a){a=a||"2Y";6(b.1n&&b.1n[a]){b.1n[a].4s();E f=b.1n[a][0];6(f)f.T(b)}},3N:[],2Y:9(f,e,g){E z=7;E y=f.S;z.a=9(){6(e.3q)e.3q.T(f,[z.2x]);6(g=="1e")C.1j(y,"1e",z.2x);G{y[g]=5K(z.2x)+"4t";6(g=="1u"||g=="24")y.11="2m"}};z.65=9(){F 3m(C.1h(f,g))};z.1Y=9(){E r=3m(C.34(f,g));F r&&r>-8v?r:z.65()};z.3R=9(c,b){z.4M=(1s 64()).63();z.2x=c;z.a();C.3N.Y(9(){F z.3q(c,b)});6(C.3N.H==1){E d=3t(9(){E a=C.3N;I(E i=0;i<a.H;i++)6(!a[i]())a.8t(i--,1);6(!a.H)47(d)},13)}};z.1o=9(){6(!f.2i)f.2i={};f.2i[g]=C.1j(f.S,g);e.1o=O;z.3R(0,7.1Y());6(g!="1e")y[g]="8r";C(f).1o()};z.1p=9(){6(!f.2i)f.2i={};f.2i[g]=C.1j(f.S,g);e.1p=O;z.3R(7.1Y(),0)};z.3q=9(a,c){E t=(1s 64()).63();6(t>e.1N+z.4M){z.2x=c;z.a();6(f.2v)f.2v[g]=O;E b=O;I(E i 17 f.2v)6(f.2v[i]!==O)b=M;6(b){6(e.11!=K){y.2z=e.2z;y.11=e.11;6(C.1h(f,"11")=="1T")y.11="2m"}6(e.1p)y.11="1T";6(e.1p||e.1o)I(E p 17 f.2v)C.1j(y,p,f.2i[p])}6(b&&C.1g(e.1x))e.1x.T(f);F M}G{E n=t-7.4M;E p=n/e.1N;z.2x=C.35[e.35||(C.35.4H?"4H":"62")](p,n,a,(c-a),e.1N);z.a()}F O}}})})();',62,541,'||||||if|this||function|||||||||||||||||||||||||||||||var|return|else|length|for|each|null|type|false|browser|true|parentNode|undefined|document|style|apply|indexOf|data|nodeName||push|||display|msie||extend|fn|jQuery|in|className|window|arguments|constructor|event|test|opacity|typeof|isFunction|css|events|attr|firstChild|filter|div|queue|show|hide|mergeNum|add|new|nodeType|height|replace|tbody|complete|handle|trigger|table|animate|hidden|global|string|find|url|safari|toUpperCase|break|Array|ready|al|duration|pushStack|tb|timeout|stack|target|none|success|swap|toggle|button|cur|opt|while|get|guid|remove|width|nth|status|checked|selected|merge|nextSibling|select|ret|exec|args|load|try|catch|orig|id|match|_|block||rl|insertBefore|done|oldblock|trim|opera|preventDefault|curAnim|async|now|encodeURIComponent|overflow|value|grep|readyList|toLowerCase|color|ifModified|val|first|ownerDocument|domManip|substr|defaultView|split|has|param|last|text|multiFilter|call|eval|old|makeArray|innerHTML|stopPropagation|fx|childNodes|disabled|ajax|src|script|curCSS|easing|isReady|getElementById|form|input|float|getComputedStyle|clean|readyState|removeChild|error|static|lastModified|checkbox|selectedIndex|position|bind|parseFloat|String|oWidth|oHeight|step|on|toString|setInterval|ajaxSettings|prototype|jquery|Number|is|child|ol|cloneNode|RegExp|documentElement|isXMLDoc|getAttribute|dataType|append|styleFloat|mozilla|empty|end|map|timers|tr|el|which|custom|slice|lastToggle|handleHover|visibility|mouseover|handleError|lastChild|Modified|active|currentStyle|unshift|responseText|getPropertyValue|index|GET|clearInterval|safariTimer|unbind|init|__ie_init|setRequestHeader|unique|radio|getResponseHeader|relatedTarget|click|fix|removeEventListener|delete|handler|addEventListener|triggered|nodeIndex|appendChild|props|classFilter|shift|px|submit|file|expr|setTimeout|tagName|body|sibling|previousSibling|parents|deep|globalEval|fromElement|cssFloat|swing|parsererror|00|inArray|getElementsByTagName|startTime|visible|num|object|prop|200|Last|colgroup|beforeSend|fieldset|ActiveXObject|processData|contentType|ajaxSuccess|ajaxError|ajaxComplete|ajaxStop|ajaxStart|notmodified|POST|json|appendTo|XMLHttpRequest|DOMContentLoaded|bindReady|mouseout|prevObject|removeAttr|one|unload|ctrlKey|ajaxSend|metaKey|keyCode|charCode|not|scrollTop|httpSuccess|scrollLeft|pageX|httpData|srcElement|httpNotModified|after|before|prepend|join|parse|zoom|304|reset|image|password|odd|even|xml|quickClass|quickID|quickChild|setArray|parseInt|contains|gt|execScript|_toggle|lt|eq|href|nodeValue|alpha|self|speed|html|continue|parent|textContent|createTextNode|webkit|linear|getTime|Date|max|clientX|Math|dequeue|fl|createElement|version|100|NaN|fadeTo|fadeIn|slideToggle|slideUp|slideDown|setAttribute|getAttributeNode|name|method|action|content|cssText|300|protocol|FORM|location|options|send|abort|col|th|GMT|td|1970|01|cap|Since|colg|If|tfoot|thead|open|XMLHTTP|leg|Microsoft|urlencoded|www|application|ajaxSetup|ajaxTimeout|post|getScript|getIfModified|evalScripts|serialize|loadIfModified|loaded|onreadystatechange|defer|clientWidth|ipt|scr|clientHeight|write|relative|getJSON|keyup|keypress|keydown|change|mousemove|mouseup|left|mousedown|dblclick|right|scroll|resize|focus|blur|frames|absolute|clone|hover|offsetWidth|Content|Type|offsetHeight|Width|clientY|Thu|border|Jan|pageY|padding|Left|toElement|Requested|With|Right|Bottom|cancelBubble|returnValue|Top|size|detachEvent|attachEvent|substring|line|textarea|weight|enabled|font|innerText|only|uFFFF|responseXML|throw|u0128|417|toggleClass|removeClass|wrap|addClass|removeAttribute|insertAfter|prependTo|children|siblings|fadeOut|noConflict|prev|next|Boolean|maxLength|maxlength|readOnly|readonly|class|htmlFor|CSS1Compat|compatMode|boxModel|compatible|ie|ra|it|1px|rv|splice|userAgent|10000|navigator|concat|PI|cos|400|fast|600|slow|reverse|Function|Object|array|ig'.split('|'),0,{})); 
     12 
     13// Map over jQuery in case of overwrite 
     14if ( window.jQuery ) 
     15        var _jQuery = window.jQuery; 
     16 
     17var jQuery = window.jQuery = function( selector, context ) { 
     18        // The jQuery object is actually just the init constructor 'enhanced' 
     19        return new jQuery.prototype.init( selector, context ); 
     20}; 
     21 
     22// Map over the $ in case of overwrite 
     23if ( window.$ ) 
     24        var _$ = window.$; 
     25         
     26// Map the jQuery namespace to the '$' one 
     27window.$ = jQuery; 
     28 
     29// A simple way to check for HTML strings or ID strings 
     30// (both of which we optimize for) 
     31var quickExpr = /^[^<]*(<(.|\s)+>)[^>]*$|^#(\w+)$/; 
     32 
     33// Is it a simple selector 
     34var isSimple = /^.[^:#\[\.]*$/; 
     35 
     36jQuery.fn = jQuery.prototype = { 
     37        init: function( selector, context ) { 
     38                // Make sure that a selection was provided 
     39                selector = selector || document; 
     40 
     41                // Handle $(DOMElement) 
     42                if ( selector.nodeType ) { 
     43                        this[0] = selector; 
     44                        this.length = 1; 
     45                        return this; 
     46 
     47                // Handle HTML strings 
     48                } else if ( typeof selector == "string" ) { 
     49                        // Are we dealing with HTML string or an ID? 
     50                        var match = quickExpr.exec( selector ); 
     51 
     52                        // Verify a match, and that no context was specified for #id 
     53                        if ( match && (match[1] || !context) ) { 
     54 
     55                                // HANDLE: $(html) -> $(array) 
     56                                if ( match[1] ) 
     57                                        selector = jQuery.clean( [ match[1] ], context ); 
     58 
     59                                // HANDLE: $("#id") 
     60                                else { 
     61                                        var elem = document.getElementById( match[3] ); 
     62 
     63                                        // Make sure an element was located 
     64                                        if ( elem ) 
     65                                                // Handle the case where IE and Opera return items 
     66                                                // by name instead of ID 
     67                                                if ( elem.id != match[3] ) 
     68                                                        return jQuery().find( selector ); 
     69 
     70                                                // Otherwise, we inject the element directly into the jQuery object 
     71                                                else { 
     72                                                        this[0] = elem; 
     73                                                        this.length = 1; 
     74                                                        return this; 
     75                                                } 
     76 
     77                                        else 
     78                                                selector = []; 
     79                                } 
     80 
     81                        // HANDLE: $(expr, [context]) 
     82                        // (which is just equivalent to: $(content).find(expr) 
     83                        } else 
     84                                return new jQuery( context ).find( selector ); 
     85 
     86                // HANDLE: $(function) 
     87                // Shortcut for document ready 
     88                } else if ( jQuery.isFunction( selector ) ) 
     89                        return new jQuery( document )[ jQuery.fn.ready ? "ready" : "load" ]( selector ); 
     90 
     91                return this.setArray( 
     92                        // HANDLE: $(array) 
     93                        selector.constructor == Array && selector || 
     94 
     95                        // HANDLE: $(arraylike) 
     96                        // Watch for when an array-like object, contains DOM nodes, is passed in as the selector 
     97                        (selector.jquery || selector.length && selector != window && !selector.nodeType && selector[0] != undefined && selector[0].nodeType) && jQuery.makeArray( selector ) || 
     98 
     99                        // HANDLE: $(*) 
     100                        [ selector ] ); 
     101        }, 
     102         
     103        // The current version of jQuery being used 
     104        jquery: "@VERSION", 
     105 
     106        // The number of elements contained in the matched element set 
     107        size: function() { 
     108                return this.length; 
     109        }, 
     110         
     111        // The number of elements contained in the matched element set 
     112        length: 0, 
     113 
     114        // Get the Nth element in the matched element set OR 
     115        // Get the whole matched element set as a clean array 
     116        get: function( num ) { 
     117                return num == undefined ? 
     118 
     119                        // Return a 'clean' array 
     120                        jQuery.makeArray( this ) : 
     121 
     122                        // Return just the object 
     123                        this[ num ]; 
     124        }, 
     125         
     126        // Take an array of elements and push it onto the stack 
     127        // (returning the new matched element set) 
     128        pushStack: function( elems ) { 
     129                // Build a new jQuery matched element set 
     130                var ret = jQuery( elems ); 
     131 
     132                // Add the old object onto the stack (as a reference) 
     133                ret.prevObject = this; 
     134 
     135                // Return the newly-formed element set 
     136                return ret; 
     137        }, 
     138         
     139        // Force the current matched set of elements to become 
     140        // the specified array of elements (destroying the stack in the process) 
     141        // You should use pushStack() in order to do this, but maintain the stack 
     142        setArray: function( elems ) { 
     143                // Resetting the length to 0, then using the native Array push 
     144                // is a super-fast way to populate an object with array-like properties 
     145                this.length = 0; 
     146                Array.prototype.push.apply( this, elems ); 
     147                 
     148                return this; 
     149        }, 
     150 
     151        // Execute a callback for every element in the matched set. 
     152        // (You can seed the arguments with an array of args, but this is 
     153        // only used internally.) 
     154        each: function( callback, args ) { 
     155                return jQuery.each( this, callback, args ); 
     156        }, 
     157 
     158        // Determine the position of an element within  
     159        // the matched set of elements 
     160        index: function( elem ) { 
     161                var ret = -1; 
     162 
     163                // Locate the position of the desired element 
     164                this.each(function(i){ 
     165                        if ( this == elem ) 
     166                                ret = i; 
     167                }); 
     168 
     169                return ret; 
     170        }, 
     171 
     172        attr: function( name, value, type ) { 
     173                var options = name; 
     174                 
     175                // Look for the case where we're accessing a style value 
     176                if ( name.constructor == String ) 
     177                        if ( value == undefined ) 
     178                                return this.length && jQuery[ type || "attr" ]( this[0], name ) || undefined; 
     179 
     180                        else { 
     181                                options = {}; 
     182                                options[ name ] = value; 
     183                        } 
     184                 
     185                // Check to see if we're setting style values 
     186                return this.each(function(i){ 
     187                        // Set all the styles 
     188                        for ( name in options ) 
     189                                jQuery.attr( 
     190                                        type ? 
     191                                                this.style : 
     192                                                this, 
     193                                        name, jQuery.prop( this, options[ name ], type, i, name ) 
     194                                ); 
     195                }); 
     196        }, 
     197 
     198        css: function( key, value ) { 
     199                // ignore negative width and height values 
     200                if ( (key == 'width' || key == 'height') && parseFloat(value) < 0 ) 
     201                        value = undefined; 
     202                return this.attr( key, value, "curCSS" ); 
     203        }, 
     204 
     205        text: function( text ) { 
     206                if ( typeof text != "object" && text != null ) 
     207                        return this.empty().append( (this[0] && this[0].ownerDocument || document).createTextNode( text ) ); 
     208 
     209                var ret = ""; 
     210 
     211                jQuery.each( text || this, function(){ 
     212                        jQuery.each( this.childNodes, function(){ 
     213                                if ( this.nodeType != 8 ) 
     214                                        ret += this.nodeType != 1 ? 
     215                                                this.nodeValue : 
     216                                                jQuery.fn.text( [ this ] ); 
     217                        }); 
     218                }); 
     219 
     220                return ret; 
     221        }, 
     222 
     223        wrapAll: function( html ) { 
     224                if ( this[0] ) 
     225                        // The elements to wrap the target around 
     226                        jQuery( html, this[0].ownerDocument ) 
     227                                .clone() 
     228                                .insertBefore( this[0] ) 
     229                                .map(function(){ 
     230                                        var elem = this; 
     231 
     232                                        while ( elem.firstChild ) 
     233                                                elem = elem.firstChild; 
     234 
     235                                        return elem; 
     236                                }) 
     237                                .append(this); 
     238 
     239                return this; 
     240        }, 
     241 
     242        wrapInner: function( html ) { 
     243                return this.each(function(){ 
     244                        jQuery( this ).contents().wrapAll( html ); 
     245                }); 
     246        }, 
     247 
     248        wrap: function( html ) { 
     249                return this.each(function(){ 
     250                        jQuery( this ).wrapAll( html ); 
     251                }); 
     252        }, 
     253 
     254        append: function() { 
     255                return this.domManip(arguments, true, false, function(elem){ 
     256                        if (this.nodeType == 1) 
     257                                this.appendChild( elem ); 
     258                }); 
     259        }, 
     260 
     261        prepend: function() { 
     262                return this.domManip(arguments, true, true, function(elem){ 
     263                        if (this.nodeType == 1) 
     264                                this.insertBefore( elem, this.firstChild ); 
     265                }); 
     266        }, 
     267         
     268        before: function() { 
     269                return this.domManip(arguments, false, false, function(elem){ 
     270                        this.parentNode.insertBefore( elem, this ); 
     271                }); 
     272        }, 
     273 
     274        after: function() { 
     275                return this.domManip(arguments, false, true, function(elem){ 
     276                        this.parentNode.insertBefore( elem, this.nextSibling ); 
     277                }); 
     278        }, 
     279 
     280        end: function() { 
     281                return this.prevObject || jQuery( [] ); 
     282        }, 
     283 
     284        find: function( selector ) { 
     285                var elems = jQuery.map(this, function(elem){ 
     286                        return jQuery.find( selector, elem ); 
     287                }); 
     288 
     289                return this.pushStack( /[^+>] [^+>]/.test( selector ) || selector.indexOf("..") > -1 ? 
     290                        jQuery.unique( elems ) : 
     291                        elems ); 
     292        }, 
     293 
     294        clone: function( events ) { 
     295                // Do the clone 
     296                var ret = this.map(function(){ 
     297                        if ( jQuery.browser.msie && !jQuery.isXMLDoc(this) ) { 
     298                                // IE copies events bound via attachEvent when 
     299                                // using cloneNode. Calling detachEvent on the 
     300                                // clone will also remove the events from the orignal 
     301                                // In order to get around this, we use innerHTML. 
     302                                // Unfortunately, this means some modifications to  
     303                                // attributes in IE that are actually only stored  
     304                                // as properties will not be copied (such as the 
     305                                // the name attribute on an input). 
     306                                var clone = this.cloneNode(true), 
     307                                        container = document.createElement("div"), 
     308                                        container2 = document.createElement("div"); 
     309                                container.appendChild(clone); 
     310                                container2.innerHTML = container.innerHTML; 
     311                                return container2.firstChild; 
     312                        } else 
     313                                return this.cloneNode(true); 
     314                }); 
     315 
     316                // Need to set the expando to null on the cloned set if it exists 
     317                // removeData doesn't work here, IE removes it from the original as well 
     318                // this is primarily for IE but the data expando shouldn't be copied over in any browser 
     319                var clone = ret.find("*").andSelf().each(function(){ 
     320                        if ( this[ expando ] != undefined ) 
     321                                this[ expando ] = null; 
     322                }); 
     323                 
     324                // Copy the events from the original to the clone 
     325                if ( events === true ) 
     326                        this.find("*").andSelf().each(function(i){ 
     327                                if (this.nodeType == 3) 
     328                                        return; 
     329                                var events = jQuery.data( this, "events" ); 
     330 
     331                                for ( var type in events ) 
     332                                        for ( var handler in events[ type ] ) 
     333                                                jQuery.event.add( clone[ i ], type, events[ type ][ handler ], events[ type ][ handler ].data ); 
     334                        }); 
     335 
     336                // Return the cloned set 
     337                return ret; 
     338        }, 
     339 
     340        filter: function( selector ) { 
     341                return this.pushStack( 
     342                        jQuery.isFunction( selector ) && 
     343                        jQuery.grep(this, function(elem, i){ 
     344                                return selector.call( elem, i ); 
     345                        }) || 
     346 
     347                        jQuery.multiFilter( selector, this ) ); 
     348        }, 
     349 
     350        not: function( selector ) { 
     351                if ( selector.constructor == String ) 
     352                        // test special case where just one selector is passed in 
     353                        if ( isSimple.test( selector ) ) 
     354                                return this.pushStack( jQuery.multiFilter( selector, this, true ) ); 
     355                        else 
     356                                selector = jQuery.multiFilter( selector, this ); 
     357 
     358                var isArrayLike = selector.length && selector[selector.length - 1] !== undefined && !selector.nodeType; 
     359                return this.filter(function() { 
     360                        return isArrayLike ? jQuery.inArray( this, selector ) < 0 : this != selector; 
     361                }); 
     362        }, 
     363 
     364        add: function( selector ) { 
     365                return !selector ? this : this.pushStack( jQuery.merge(  
     366                        this.get(), 
     367                        selector.constructor == String ?  
     368                                jQuery( selector ).get() : 
     369                                selector.length != undefined && (!selector.nodeName || jQuery.nodeName(selector, "form")) ? 
     370                                        selector : [selector] ) ); 
     371        }, 
     372 
     373        is: function( selector ) { 
     374                return selector ? 
     375                        jQuery.multiFilter( selector, this ).length > 0 : 
     376                        false; 
     377        }, 
     378 
     379        hasClass: function( selector ) { 
     380                return this.is( "." + selector ); 
     381        }, 
     382         
     383        val: function( value ) { 
     384                if ( value == undefined ) { 
     385 
     386                        if ( this.length ) { 
     387                                var elem = this[0]; 
     388 
     389                                // We need to handle select boxes special 
     390                                if ( jQuery.nodeName( elem, "select" ) ) { 
     391                                        var index = elem.selectedIndex, 
     392                                                values = [], 
     393                                                options = elem.options, 
     394                                                one = elem.type == "select-one"; 
     395                                         
     396                                        // Nothing was selected 
     397                                        if ( index < 0 ) 
     398                                                return null; 
     399 
     400                                        // Loop through all the selected options 
     401                                        for ( var i = one ? index : 0, max = one ? index + 1 : options.length; i < max; i++ ) { 
     402                                                var option = options[ i ]; 
     403 
     404                                                if ( option.selected ) { 
     405                                                        // Get the specifc value for the option 
     406                                                        value = jQuery.browser.msie && !option.attributes.value.specified ? option.text : option.value; 
     407                                                         
     408                                                        // We don't need an array for one selects 
     409                                                        if ( one ) 
     410                                                                return value; 
     411                                                         
     412                                                        // Multi-Selects return an array 
     413                                                        values.push( value ); 
     414                                                } 
     415                                        } 
     416                                         
     417                                        return values; 
     418                                         
     419                                // Everything else, we just grab the value 
     420                                } else 
     421                                        return (this[0].value || "").replace(/\r/g, ""); 
     422 
     423                        } 
     424 
     425                        return undefined; 
     426                } 
     427 
     428                return this.each(function(){ 
     429                        if ( this.nodeType != 1 ) 
     430                                return; 
     431 
     432                        if ( value.constructor == Array && /radio|checkbox/.test( this.type ) ) 
     433                                this.checked = (jQuery.inArray(this.value, value) >= 0 || 
     434                                        jQuery.inArray(this.name, value) >= 0); 
     435 
     436                        else if ( jQuery.nodeName( this, "select" ) ) { 
     437                                var values = value.constructor == Array ? 
     438                                        value : 
     439                                        [ value ]; 
     440 
     441                                jQuery( "option", this ).each(function(){ 
     442                                        this.selected = (jQuery.inArray( this.value, values ) >= 0 || 
     443                                                jQuery.inArray( this.text, values ) >= 0); 
     444                                }); 
     445 
     446                                if ( !values.length ) 
     447                                        this.selectedIndex = -1; 
     448 
     449                        } else 
     450                                this.value = value; 
     451                }); 
     452        }, 
     453         
     454        html: function( value ) { 
     455                return value == undefined ? 
     456                        (this.length ? 
     457                                this[0].innerHTML : 
     458                                null) : 
     459                        this.empty().append( value ); 
     460        }, 
     461 
     462        replaceWith: function( value ) { 
     463                return this.after( value ).remove(); 
     464        }, 
     465 
     466        eq: function( i ) { 
     467                return this.slice( i, i + 1 ); 
     468        }, 
     469 
     470        slice: function() { 
     471                return this.pushStack( Array.prototype.slice.apply( this, arguments ) ); 
     472        }, 
     473 
     474        map: function( callback ) { 
     475                return this.pushStack( jQuery.map(this, function(elem, i){ 
     476                        return callback.call( elem, i, elem ); 
     477                })); 
     478        }, 
     479 
     480        andSelf: function() { 
     481                return this.add( this.prevObject ); 
     482        }, 
     483         
     484        domManip: function( args, table, reverse, callback ) { 
     485                var clone = this.length > 1, elems;  
     486 
     487                return this.each(function(){ 
     488                        if ( !elems ) { 
     489                                elems = jQuery.clean( args, this.ownerDocument ); 
     490 
     491                                if ( reverse ) 
     492                                        elems.reverse(); 
     493                        } 
     494 
     495                        var obj = this; 
     496 
     497                        if ( table && jQuery.nodeName( this, "table" ) && jQuery.nodeName( elems[0], "tr" ) ) 
     498                                obj = this.getElementsByTagName("tbody")[0] || this.appendChild( this.ownerDocument.createElement("tbody") ); 
     499 
     500                        var scripts = jQuery( [] ); 
     501 
     502                        jQuery.each(elems, function(){ 
     503                                var elem = clone ? 
     504                                        jQuery( this ).clone( true )[0] : 
     505                                        this; 
     506 
     507                                // execute all scripts after the elements have been injected 
     508                                if ( jQuery.nodeName( elem, "script" ) ) { 
     509                                        scripts = scripts.add( elem ); 
     510                                } else { 
     511                                        // Remove any inner scripts for later evaluation 
     512                                        if ( elem.nodeType == 1 ) 
     513                                                scripts = scripts.add( jQuery( "script", elem ).remove() ); 
     514 
     515                                        // Inject the elements into the document 
     516                                        callback.call( obj, elem ); 
     517                                } 
     518                        }); 
     519 
     520                        scripts.each( evalScript ); 
     521                }); 
     522        } 
     523}; 
     524 
     525// Give the init function the jQuery prototype for later instantiation 
     526jQuery.prototype.init.prototype = jQuery.prototype; 
     527 
     528function evalScript( i, elem ) { 
     529        if ( elem.src ) 
     530                jQuery.ajax({ 
     531                        url: elem.src, 
     532                        async: false, 
     533                        dataType: "script" 
     534                }); 
     535 
     536        else 
     537                jQuery.globalEval( elem.text || elem.textContent || elem.innerHTML || "" ); 
     538 
     539        if ( elem.parentNode ) 
     540                elem.parentNode.removeChild( elem ); 
     541} 
     542 
     543jQuery.extend = jQuery.fn.extend = function() { 
     544        // copy reference to target object 
     545        var target = arguments[0] || {}, i = 1, length = arguments.length, deep = false, options; 
     546 
     547        // Handle a deep copy situation 
     548        if ( target.constructor == Boolean ) { 
     549                deep = target; 
     550                target = arguments[1] || {}; 
     551                // skip the boolean and the target 
     552                i = 2; 
     553        } 
     554 
     555        // Handle case when target is a string or something (possible in deep copy) 
     556        if ( typeof target != "object" && typeof target != "function" ) 
     557                target = {}; 
     558 
     559        // extend jQuery itself if only one argument is passed 
     560        if ( length == 1 ) { 
     561                target = this; 
     562                i = 0; 
     563        } 
     564 
     565        for ( ; i < length; i++ ) 
     566                // Only deal with non-null/undefined values 
     567                if ( (options = arguments[ i ]) != null ) 
     568                        // Extend the base object 
     569                        for ( var name in options ) { 
     570                                // Prevent never-ending loop 
     571                                if ( target === options[ name ] ) 
     572                                        continue; 
     573 
     574                                // Recurse if we're merging object values 
     575                                if ( deep && options[ name ] && typeof options[ name ] == "object" && target[ name ] && !options[ name ].nodeType ) 
     576                                        target[ name ] = jQuery.extend( target[ name ], options[ name ] ); 
     577 
     578                                // Don't bring in undefined values 
     579                                else if ( options[ name ] != undefined ) 
     580                                        target[ name ] = options[ name ]; 
     581 
     582                        } 
     583 
     584        // Return the modified object 
     585        return target; 
     586}; 
     587 
     588var expando = "jQuery" + (new Date()).getTime(), uuid = 0, windowData = {}; 
     589 
     590// exclude the following css properties to add px 
     591var exclude = /z-?index|font-?weight|opacity|zoom|line-?height/i; 
     592 
     593jQuery.extend({ 
     594        noConflict: function( deep ) { 
     595                window.$ = _$; 
     596 
     597                if ( deep ) 
     598                        window.jQuery = _jQuery; 
     599 
     600                return jQuery; 
     601        }, 
     602 
     603        // This may seem like some crazy code, but trust me when I say that this 
     604        // is the only cross-browser way to do this. --John 
     605        isFunction: function( fn ) { 
     606                return !!fn && typeof fn != "string" && !fn.nodeName &&  
     607                        fn.constructor != Array && /function/i.test( fn + "" ); 
     608        }, 
     609         
     610        // check if an element is in a (or is an) XML document 
     611        isXMLDoc: function( elem ) { 
     612                return elem.documentElement && !elem.body || 
     613                        elem.tagName && elem.ownerDocument && !elem.ownerDocument.body; 
     614        }, 
     615 
     616        // Evalulates a script in a global context 
     617        globalEval: function( data ) { 
     618                data = jQuery.trim( data ); 
     619 
     620                if ( data ) { 
     621                        // Inspired by code by Andrea Giammarchi 
     622                        // http://webreflection.blogspot.com/2007/08/global-scope-evaluation-and-dom.html 
     623                        var head = document.getElementsByTagName("head")[0] || document.documentElement, 
     624                                script = document.createElement("script"); 
     625 
     626                        script.type = "text/javascript"; 
     627                        if ( jQuery.browser.msie ) 
     628                                script.text = data; 
     629                        else 
     630                                script.appendChild( document.createTextNode( data ) ); 
     631 
     632                        head.appendChild( script ); 
     633                        head.removeChild( script ); 
     634                } 
     635        }, 
     636 
     637        nodeName: function( elem, name ) { 
     638                return elem.nodeName && elem.nodeName.toUpperCase() == name.toUpperCase(); 
     639        }, 
     640         
     641        cache: {}, 
     642         
     643        data: function( elem, name, data ) { 
     644                elem = elem == window ? 
     645                        windowData : 
     646                        elem; 
     647 
     648                var id = elem[ expando ]; 
     649 
     650                // Compute a unique ID for the element 
     651                if ( !id )  
     652                        id = elem[ expando ] = ++uuid; 
     653 
     654                // Only generate the data cache if we're 
     655                // trying to access or manipulate it 
     656                if ( name && !jQuery.cache[ id ] ) 
     657                        jQuery.cache[ id ] = {}; 
     658                 
     659                // Prevent overriding the named cache with undefined values 
     660                if ( data != undefined ) 
     661                        jQuery.cache[ id ][ name ] = data; 
     662                 
     663                // Return the named cache data, or the ID for the element        
     664                return name ? 
     665                        jQuery.cache[ id ][ name ] : 
     666                        id; 
     667        }, 
     668         
     669        removeData: function( elem, name ) { 
     670                elem = elem == window ? 
     671                        windowData : 
     672                        elem; 
     673 
     674                var id = elem[ expando ]; 
     675 
     676                // If we want to remove a specific section of the element's data 
     677                if ( name ) { 
     678                        if ( jQuery.cache[ id ] ) { 
     679                                // Remove the section of cache data 
     680                                delete jQuery.cache[ id ][ name ]; 
     681 
     682                                // If we've removed all the data, remove the element's cache 
     683                                name = ""; 
     684 
     685                                for ( name in jQuery.cache[ id ] ) 
     686                                        break; 
     687 
     688                                if ( !name ) 
     689                                        jQuery.removeData( elem ); 
     690                        } 
     691 
     692                // Otherwise, we want to remove all of the element's data 
     693                } else { 
     694                        // Clean up the element expando 
     695                        try { 
     696                                delete elem[ expando ]; 
     697                        } catch(e){ 
     698                                // IE has trouble directly removing the expando 
     699                                // but it's ok with using removeAttribute 
     700                                if ( elem.removeAttribute ) 
     701                                        elem.removeAttribute( expando ); 
     702                        } 
     703 
     704                        // Completely remove the data cache 
     705                        delete jQuery.cache[ id ]; 
     706                } 
     707        }, 
     708 
     709        // args is for internal usage only 
     710        each: function( object, callback, args ) { 
     711                if ( args ) { 
     712                        if ( object.length == undefined ) 
     713                                for ( var name in object ) 
     714                                        callback.apply( object[ name ], args ); 
     715                        else 
     716                                for ( var i = 0, length = object.length; i < length; i++ ) 
     717                                        if ( callback.apply( object[ i ], args ) === false ) 
     718                                                break; 
     719 
     720                // A special, fast, case for the most common use of each 
     721                } else { 
     722                        if ( object.length == undefined ) 
     723                                for ( var name in object ) 
     724                                        callback.call( object[ name ], name, object[ name ] ); 
     725                        else 
     726                                for ( var i = 0, length = object.length, value = object[0];  
     727                                        i < length && callback.call( value, i, value ) !== false; value = object[++i] ){} 
     728                } 
     729 
     730                return object; 
     731        }, 
     732         
     733        prop: function( elem, value, type, i, name ) { 
     734                        // Handle executable functions 
     735                        if ( jQuery.isFunction( value ) ) 
     736                                value = value.call( elem, i ); 
     737                                 
     738                        // Handle passing in a number to a CSS property 
     739                        return value && value.constructor == Number && type == "curCSS" && !exclude.test( name ) ? 
     740                                value + "px" : 
     741                                value; 
     742        }, 
     743 
     744        className: { 
     745                // internal only, use addClass("class") 
     746                add: function( elem, classNames ) { 
     747                        jQuery.each((classNames || "").split(/\s+/), function(i, className){ 
     748                                if ( elem.nodeType == 1 && !jQuery.className.has( elem.className, className ) ) 
     749                                        elem.className += (elem.className ? " " : "") + className; 
     750                        }); 
     751                }, 
     752 
     753                // internal only, use removeClass("class") 
     754                remove: function( elem, classNames ) { 
     755                        if (elem.nodeType == 1) 
     756                                elem.className = classNames != undefined ? 
     757                                        jQuery.grep(elem.className.split(/\s+/), function(className){ 
     758                                                return !jQuery.className.has( classNames, className );   
     759                                        }).join(" ") : 
     760                                        ""; 
     761                }, 
     762 
     763                // internal only, use is(".class") 
     764                has: function( elem, className ) { 
     765                        return jQuery.inArray( className, (elem.className || elem).toString().split(/\s+/) ) > -1; 
     766                } 
     767        }, 
     768 
     769        // A method for quickly swapping in/out CSS properties to get correct calculations 
     770        swap: function( elem, options, callback ) { 
     771                var old = {}; 
     772                // Remember the old values, and insert the new ones 
     773                for ( var name in options ) { 
     774                        old[ name ] = elem.style[ name ]; 
     775                        elem.style[ name ] = options[ name ]; 
     776                } 
     777 
     778                callback.call( elem ); 
     779 
     780                // Revert the old values 
     781                for ( var name in options ) 
     782                        elem.style[ name ] = old[ name ]; 
     783        }, 
     784 
     785        css: function( elem, name, force ) { 
     786                if ( name == "width" || name == "height" ) { 
     787                        var val, props = { position: "absolute", visibility: "hidden", display:"block" }, which = name == "width" ? [ "Left", "Right" ] : [ "Top", "Bottom" ]; 
     788                 
     789                        function getWH() { 
     790                                val = name == "width" ? elem.offsetWidth : elem.offsetHeight; 
     791                                var padding = 0, border = 0; 
     792                                jQuery.each( which, function() { 
     793                                        padding += parseFloat(jQuery.curCSS( elem, "padding" + this, true)) || 0; 
     794                                        border += parseFloat(jQuery.curCSS( elem, "border" + this + "Width", true)) || 0; 
     795                                }); 
     796                                val -= Math.round(padding + border); 
     797                        } 
     798                 
     799                        if ( jQuery(elem).is(":visible") ) 
     800                                getWH(); 
     801                        else 
     802                                jQuery.swap( elem, props, getWH ); 
     803                         
     804                        return Math.max(0, val); 
     805                } 
     806                 
     807                return jQuery.curCSS( elem, name, force ); 
     808        }, 
     809 
     810        curCSS: function( elem, name, force ) { 
     811                var ret; 
     812 
     813                // A helper method for determining if an element's values are broken 
     814                function color( elem ) { 
     815                        if ( !jQuery.browser.safari ) 
     816                                return false; 
     817 
     818                        var ret = document.defaultView.getComputedStyle( elem, null ); 
     819                        return !ret || ret.getPropertyValue("color") == ""; 
     820                } 
     821 
     822                // We need to handle opacity special in IE 
     823                if ( name == "opacity" && jQuery.browser.msie ) { 
     824                        ret = jQuery.attr( elem.style, "opacity" ); 
     825 
     826                        return ret == "" ? 
     827                                "1" : 
     828                                ret; 
     829                } 
     830                // Opera sometimes will give the wrong display answer, this fixes it, see #2037 
     831                if ( jQuery.browser.opera && name == "display" ) { 
     832                        var save = elem.style.display; 
     833                        elem.style.display = "block"; 
     834                        elem.style.display = save; 
     835                } 
     836                 
     837                // Make sure we're using the right name for getting the float value 
     838                if ( name.match( /float/i ) ) 
     839                        name = styleFloat; 
     840 
     841                if ( !force && elem.style[ name ] ) 
     842                        ret = elem.style[ name ]; 
     843 
     844                else if ( document.defaultView && document.defaultView.getComputedStyle ) { 
     845 
     846                        // Only "float" is needed here 
     847                        if ( name.match( /float/i ) ) 
     848                                name = "float"; 
     849 
     850                        name = name.replace( /([A-Z])/g, "-$1" ).toLowerCase(); 
     851 
     852                        var getComputedStyle = document.defaultView.getComputedStyle( elem, null ); 
     853 
     854                        if ( getComputedStyle && !color( elem ) ) 
     855                                ret = getComputedStyle.getPropertyValue( name ); 
     856 
     857                        // If the element isn't reporting its values properly in Safari 
     858                        // then some display: none elements are involved 
     859                        else { 
     860                                var swap = [], stack = []; 
     861 
     862                                // Locate all of the parent display: none elements 
     863                                for ( var a = elem; a && color(a); a = a.parentNode ) 
     864                                        stack.unshift(a); 
     865 
     866                                // Go through and make them visible, but in reverse 
     867                                // (It would be better if we knew the exact display type that they had) 
     868                                for ( var i = 0; i < stack.length; i++ ) 
     869                                        if ( color( stack[ i ] ) ) { 
     870                                                swap[ i ] = stack[ i ].style.display; 
     871                                                stack[ i ].style.display = "block"; 
     872                                        } 
     873 
     874                                // Since we flip the display style, we have to handle that 
     875                                // one special, otherwise get the value 
     876                                ret = name == "display" && swap[ stack.length - 1 ] != null ? 
     877                                        "none" : 
     878                                        ( getComputedStyle && getComputedStyle.getPropertyValue( name ) ) || ""; 
     879 
     880                                // Finally, revert the display styles back 
     881                                for ( var i = 0; i < swap.length; i++ ) 
     882                                        if ( swap[ i ] != null ) 
     883                                                stack[ i ].style.display = swap[ i ]; 
     884                        } 
     885 
     886                        // We should always get a number back from opacity 
     887                        if ( name == "opacity" && ret == "" ) 
     888                                ret = "1"; 
     889 
     890                } else if ( elem.currentStyle ) { 
     891                        var camelCase = name.replace(/\-(\w)/g, function(all, letter){ 
     892                                return letter.toUpperCase(); 
     893                        }); 
     894 
     895                        ret = elem.currentStyle[ name ] || elem.currentStyle[ camelCase ]; 
     896 
     897                        // From the awesome hack by Dean Edwards 
     898                        // http://erik.eae.net/archives/2007/07/27/18.54.15/#comment-102291 
     899 
     900                        // If we're not dealing with a regular pixel number 
     901                        // but a number that has a weird ending, we need to convert it to pixels 
     902                        if ( !/^\d+(px)?$/i.test( ret ) && /^\d/.test( ret ) ) { 
     903                                // Remember the original values 
     904                                var style = elem.style.left, runtimeStyle = elem.runtimeStyle.left; 
     905 
     906                                // Put in the new values to get a computed value out 
     907                                elem.runtimeStyle.left = elem.currentStyle.left; 
     908                                elem.style.left = ret || 0; 
     909                                ret = elem.style.pixelLeft + "px"; 
     910 
     911                                // Revert the changed values 
     912                                elem.style.left = style; 
     913                                elem.runtimeStyle.left = runtimeStyle; 
     914                        } 
     915                } 
     916 
     917                return ret; 
     918        }, 
     919         
     920        clean: function( elems, context ) { 
     921                var ret = []; 
     922                context = context || document; 
     923                // !context.createElement fails in IE with an error but returns typeof 'object' 
     924                if (typeof context.createElement == 'undefined')  
     925                        context = context.ownerDocument || context[0] && context[0].ownerDocument || document; 
     926 
     927                jQuery.each(elems, function(i, elem){ 
     928                        if ( !elem ) 
     929                                return; 
     930 
     931                        if ( elem.constructor == Number ) 
     932                                elem = elem.toString(); 
     933                         
     934                        // Convert html string into DOM nodes 
     935                        if ( typeof elem == "string" ) { 
     936                                // Fix "XHTML"-style tags in all browsers 
     937                                elem = elem.replace(/(<(\w+)[^>]*?)\/>/g, function(all, front, tag){ 
     938                                        return tag.match(/^(abbr|br|col|img|input|link|meta|param|hr|area|embed)$/i) ? 
     939                                                all : 
     940                                                front + "></" + tag + ">"; 
     941                                }); 
     942 
     943                                // Trim whitespace, otherwise indexOf won't work as expected 
     944                                var tags = jQuery.trim( elem ).toLowerCase(), div = context.createElement("div"); 
     945 
     946                                var wrap = 
     947                                        // option or optgroup 
     948                                        !tags.indexOf("<opt") && 
     949                                        [ 1, "<select multiple='multiple'>", "</select>" ] || 
     950                                         
     951                                        !tags.indexOf("<leg") && 
     952                                        [ 1, "<fieldset>", "</fieldset>" ] || 
     953                                         
     954                                        tags.match(/^<(thead|tbody|tfoot|colg|cap)/) && 
     955                                        [ 1, "<table>", "</table>" ] || 
     956                                         
     957                                        !tags.indexOf("<tr") && 
     958                                        [ 2, "<table><tbody>", "</tbody></table>" ] || 
     959                                         
     960                                        // <thead> matched above 
     961                                        (!tags.indexOf("<td") || !tags.indexOf("<th")) && 
     962                                        [ 3, "<table><tbody><tr>", "</tr></tbody></table>" ] || 
     963                                         
     964                                        !tags.indexOf("<col") && 
     965                                        [ 2, "<table><tbody></tbody><colgroup>", "</colgroup></table>" ] || 
     966 
     967                                        // IE can't serialize <link> and <script> tags normally 
     968                                        jQuery.browser.msie && 
     969                                        [ 1, "div<div>", "</div>" ] || 
     970                                         
     971                                        [ 0, "", "" ]; 
     972 
     973                                // Go to html and back, then peel off extra wrappers 
     974                                div.innerHTML = wrap[1] + elem + wrap[2]; 
     975                                 
     976                                // Move to the right depth 
     977                                while ( wrap[0]-- ) 
     978                                        div = div.lastChild; 
     979                                 
     980                                // Remove IE's autoinserted <tbody> from table fragments 
     981                                if ( jQuery.browser.msie ) { 
     982                                         
     983                                        // String was a <table>, *may* have spurious <tbody> 
     984                                        var tbody = !tags.indexOf("<table") && tags.indexOf("<tbody") < 0 ? 
     985                                                div.firstChild && div.firstChild.childNodes : 
     986                                                 
     987                                                // String was a bare <thead> or <tfoot> 
     988                                                wrap[1] == "<table>" && tags.indexOf("<tbody") < 0 ? 
     989                                                        div.childNodes : 
     990                                                        []; 
     991                                 
     992                                        for ( var j = tbody.length - 1; j >= 0 ; --j ) 
     993                                                if ( jQuery.nodeName( tbody[ j ], "tbody" ) && !tbody[ j ].childNodes.length ) 
     994                                                        tbody[ j ].parentNode.removeChild( tbody[ j ] ); 
     995                                         
     996                                        // IE completely kills leading whitespace when innerHTML is used         
     997                                        if ( /^\s/.test( elem ) )        
     998                                                div.insertBefore( context.createTextNode( elem.match(/^\s*/)[0] ), div.firstChild ); 
     999                                 
     1000                                } 
     1001                                 
     1002                                elem = jQuery.makeArray( div.childNodes ); 
     1003                        } 
     1004 
     1005                        if ( elem.length === 0 && (!jQuery.nodeName( elem, "form" ) && !jQuery.nodeName( elem, "select" )) ) 
     1006                                return; 
     1007 
     1008                        if ( elem[0] == undefined || jQuery.nodeName( elem, "form" ) || elem.options ) 
     1009                                ret.push( elem ); 
     1010 
     1011                        else 
     1012                                ret = jQuery.merge( ret, elem ); 
     1013 
     1014                }); 
     1015 
     1016                return ret; 
     1017        }, 
     1018         
     1019        attr: function( elem, name, value ) { 
     1020                // don't set attributes on text and comment nodes 
     1021                if (!elem || elem.nodeType == 3 || elem.nodeType == 8) 
     1022                        return undefined; 
     1023 
     1024                var fix = jQuery.isXMLDoc( elem ) ? 
     1025                        {} : 
     1026                        jQuery.props; 
     1027 
     1028                // Safari mis-reports the default selected property of a hidden option 
     1029                // Accessing the parent's selectedIndex property fixes it 
     1030                if ( name == "selected" && jQuery.browser.safari ) 
     1031                        elem.parentNode.selectedIndex; 
     1032                 
     1033                // Certain attributes only work when accessed via the old DOM 0 way 
     1034                if ( fix[ name ] ) { 
     1035                        if ( value != undefined ) 
     1036                                elem[ fix[ name ] ] = value; 
     1037 
     1038                        return elem[ fix[ name ] ]; 
     1039 
     1040                } else if ( jQuery.browser.msie && name == "style" ) 
     1041                        return jQuery.attr( elem.style, "cssText", value ); 
     1042 
     1043                else if ( value == undefined && jQuery.browser.msie && jQuery.nodeName( elem, "form" ) && (name == "action" || name == "method") ) 
     1044                        return elem.getAttributeNode( name ).nodeValue; 
     1045 
     1046                // IE elem.getAttribute passes even for style 
     1047                else if ( elem.tagName ) { 
     1048 
     1049                        if ( value != undefined ) { 
     1050                                // We can't allow the type property to be changed (since it causes problems in IE) 
     1051                                if ( name == "type" && jQuery.nodeName( elem, "input" ) && elem.parentNode ) 
     1052                                        throw "type property can't be changed"; 
     1053 
     1054                                // convert the value to a string (all browsers do this but IE) see #1070 
     1055                                elem.setAttribute( name, "" + value ); 
     1056                        } 
     1057 
     1058                        if ( jQuery.browser.msie && /href|src/.test( name ) && !jQuery.isXMLDoc( elem ) )  
     1059                                return elem.getAttribute( name, 2 ); 
     1060 
     1061                        return elem.getAttribute( name ); 
     1062 
     1063                // elem is actually elem.style ... set the style 
     1064                } else { 
     1065                        // IE actually uses filters for opacity 
     1066                        if ( name == "opacity" && jQuery.browser.msie ) { 
     1067                                if ( value != undefined ) { 
     1068                                        // IE has trouble with opacity if it does not have layout 
     1069                                        // Force it by setting the zoom level 
     1070                                        elem.zoom = 1;  
     1071         
     1072                                        // Set the alpha filter to set the opacity 
     1073                                        elem.filter = (elem.filter || "").replace( /alpha\([^)]*\)/, "" ) + 
     1074                                                (parseFloat( value ).toString() == "NaN" ? "" : "alpha(opacity=" + value * 100 + ")"); 
     1075                                } 
     1076         
     1077                                return elem.filter && elem.filter.indexOf("opacity=") >= 0 ? 
     1078                                        (parseFloat( elem.filter.match(/opacity=([^)]*)/)[1] ) / 100).toString() : 
     1079                                        ""; 
     1080                        } 
     1081 
     1082                        name = name.replace(/-([a-z])/ig, function(all, letter){ 
     1083                                return letter.toUpperCase(); 
     1084                        }); 
     1085 
     1086                        if ( value != undefined ) 
     1087                                elem[ name ] = value; 
     1088 
     1089                        return elem[ name ]; 
     1090                } 
     1091        }, 
     1092         
     1093        trim: function( text ) { 
     1094                return (text || "").replace( /^\s+|\s+$/g, "" ); 
     1095        }, 
     1096 
     1097        makeArray: function( array ) { 
     1098                var ret = []; 
     1099 
     1100                // Need to use typeof to fight Safari childNodes crashes 
     1101                if ( typeof array != "array" ) 
     1102                        for ( var i = 0, length = array.length; i < length; i++ ) 
     1103                                ret.push( array[ i ] ); 
     1104                else 
     1105                        ret = array.slice( 0 ); 
     1106 
     1107                return ret; 
     1108        }, 
     1109 
     1110        inArray: function( elem, array ) { 
     1111                for ( var i = 0, length = array.length; i < length; i++ ) 
     1112                        if ( array[ i ] == elem ) 
     1113                                return i; 
     1114 
     1115                return -1; 
     1116        }, 
     1117 
     1118        merge: function( first, second ) { 
     1119                // We have to loop this way because IE & Opera overwrite the length 
     1120                // expando of getElementsByTagName 
     1121 
     1122                // Also, we need to make sure that the correct elements are being returned 
     1123                // (IE returns comment nodes in a '*' query) 
     1124                if ( jQuery.browser.msie ) { 
     1125                        for ( var i = 0; second[ i ]; i++ ) 
     1126                                if ( second[ i ].nodeType != 8 ) 
     1127                                        first.push( second[ i ] ); 
     1128 
     1129                } else 
     1130                        for ( var i = 0; second[ i ]; i++ ) 
     1131                                first.push( second[ i ] ); 
     1132 
     1133                return first; 
     1134        }, 
     1135 
     1136        unique: function( array ) { 
     1137                var ret = [], done = {}; 
     1138 
     1139                try { 
     1140 
     1141                        for ( var i = 0, length = array.length; i < length; i++ ) { 
     1142                                var id = jQuery.data( array[ i ] ); 
     1143 
     1144                                if ( !done[ id ] ) { 
     1145                                        done[ id ] = true; 
     1146                                        ret.push( array[ i ] ); 
     1147                                } 
     1148                        } 
     1149 
     1150                } catch( e ) { 
     1151                        ret = array; 
     1152                } 
     1153 
     1154                return ret; 
     1155        }, 
     1156 
     1157        grep: function( elems, callback, inv ) { 
     1158                // If a string is passed in for the function, make a function 
     1159                // for it (a handy shortcut) 
     1160                if ( typeof callback == "string" ) 
     1161                        callback = eval("false||function(a,i){return " + callback + "}"); 
     1162 
     1163                var ret = []; 
     1164 
     1165                // Go through the array, only saving the items 
     1166                // that pass the validator function 
     1167                for ( var i = 0, length = elems.length; i < length; i++ ) 
     1168                        if ( !inv && callback( elems[ i ], i ) || inv && !callback( elems[ i ], i ) ) 
     1169                                ret.push( elems[ i ] ); 
     1170 
     1171                return ret; 
     1172        }, 
     1173 
     1174        map: function( elems, callback ) { 
     1175                var ret = []; 
     1176 
     1177                // Go through the array, translating each of the items to their 
     1178                // new value (or values). 
     1179                for ( var i = 0, length = elems.length; i < length; i++ ) { 
     1180                        var value = callback( elems[ i ], i ); 
     1181 
     1182                        if ( value !== null && value != undefined ) { 
     1183                                if ( value.constructor != Array ) 
     1184                                        value = [ value ]; 
     1185 
     1186                                ret = ret.concat( value ); 
     1187                        } 
     1188                } 
     1189 
     1190                return ret; 
     1191        } 
     1192}); 
     1193 
     1194var userAgent = navigator.userAgent.toLowerCase(); 
     1195 
     1196// Figure out what browser is being used 
     1197jQuery.browser = { 
     1198        version: (userAgent.match( /.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/ ) || [])[1], 
     1199        safari: /webkit/.test( userAgent ), 
     1200        opera: /opera/.test( userAgent ), 
     1201        msie: /msie/.test( userAgent ) && !/opera/.test( userAgent ), 
     1202        mozilla: /mozilla/.test( userAgent ) && !/(compatible|webkit)/.test( userAgent ) 
     1203}; 
     1204 
     1205var styleFloat = jQuery.browser.msie ? 
     1206        "styleFloat" : 
     1207        "cssFloat"; 
     1208         
     1209jQuery.extend({ 
     1210        // Check to see if the W3C box model is being used 
     1211        boxModel: !jQuery.browser.msie || document.compatMode == "CSS1Compat", 
     1212         
     1213        props: { 
     1214                "for": "htmlFor", 
     1215                "class": "className", 
     1216                "float": styleFloat, 
     1217                cssFloat: styleFloat, 
     1218                styleFloat: styleFloat, 
     1219                innerHTML: "innerHTML", 
     1220                className: "className", 
     1221                value: "value", 
     1222                disabled: "disabled", 
     1223                checked: "checked", 
     1224                readonly: "readOnly", 
     1225                selected: "selected", 
     1226                maxlength: "maxLength", 
     1227                selectedIndex: "selectedIndex", 
     1228                defaultValue: "defaultValue", 
     1229                tagName: "tagName", 
     1230                nodeName: "nodeName" 
     1231        } 
     1232}); 
     1233 
     1234jQuery.each({ 
     1235        parent: "elem.parentNode", 
     1236        parents: "jQuery.dir(elem,'parentNode')", 
     1237        next: "jQuery.nth(elem,2,'nextSibling')", 
     1238        prev: "jQuery.nth(elem,2,'previousSibling')", 
     1239        nextAll: "jQuery.dir(elem,'nextSibling')", 
     1240        prevAll: "jQuery.dir(elem,'previousSibling')", 
     1241        siblings: "jQuery.sibling(elem.parentNode.firstChild,elem)", 
     1242        children: "jQuery.sibling(elem.firstChild)", 
     1243        contents: "jQuery.nodeName(elem,'iframe')?elem.contentDocument||elem.contentWindow.document:jQuery.makeArray(elem.childNodes)" 
     1244}, function(name, fn){ 
     1245        fn = eval("false||function(elem){return " + fn + "}"); 
     1246 
     1247        jQuery.fn[ name ] = function( selector ) { 
     1248                var ret = jQuery.map( this, fn ); 
     1249 
     1250                if ( selector && typeof selector == "string" ) 
     1251                        ret = jQuery.multiFilter( selector, ret ); 
     1252 
     1253                return this.pushStack( jQuery.unique( ret ) ); 
     1254        }; 
     1255}); 
     1256 
     1257jQuery.each({ 
     1258        appendTo: "append", 
     1259        prependTo: "prepend", 
     1260        insertBefore: "before", 
     1261        insertAfter: "after", 
     1262        replaceAll: "replaceWith" 
     1263}, function(name, original){ 
     1264        jQuery.fn[ name ] = function() { 
     1265                var args = arguments; 
     1266 
     1267                return this.each(function(){ 
     1268                        for ( var i = 0, length = args.length; i < length; i++ ) 
     1269                                jQuery( args[ i ] )[ original ]( this ); 
     1270                }); 
     1271        }; 
     1272}); 
     1273 
     1274jQuery.each({ 
     1275        removeAttr: function( name ) { 
     1276                jQuery.attr( this, name, "" ); 
     1277                if (this.nodeType == 1)  
     1278                        this.removeAttribute( name ); 
     1279        }, 
     1280 
     1281        addClass: function( classNames ) { 
     1282                jQuery.className.add( this, classNames ); 
     1283        }, 
     1284 
     1285        removeClass: function( classNames ) { 
     1286                jQuery.className.remove( this, classNames ); 
     1287        }, 
     1288 
     1289        toggleClass: function( classNames ) { 
     1290                jQuery.className[ jQuery.className.has( this, classNames ) ? "remove" : "add" ]( this, classNames ); 
     1291        }, 
     1292 
     1293        remove: function( selector ) { 
     1294                if ( !selector || jQuery.filter( selector, [ this ] ).r.length ) { 
     1295                        // Prevent memory leaks 
     1296                        jQuery( "*", this ).add(this).each(function(){ 
     1297                                jQuery.event.remove(this); 
     1298                                jQuery.removeData(this); 
     1299                        }); 
     1300                        if (this.parentNode) 
     1301                                this.parentNode.removeChild( this ); 
     1302                } 
     1303        }, 
     1304 
     1305        empty: function() { 
     1306                // Remove element nodes and prevent memory leaks 
     1307                jQuery( ">*", this ).remove(); 
     1308                 
     1309                // Remove any remaining nodes 
     1310                while ( this.firstChild ) 
     1311                        this.removeChild( this.firstChild ); 
     1312        } 
     1313}, function(name, fn){ 
     1314        jQuery.fn[ name ] = function(){ 
     1315                return this.each( fn, arguments ); 
     1316        }; 
     1317}); 
     1318 
     1319jQuery.each([ "Height", "Width" ], function(i, name){ 
     1320        var type = name.toLowerCase(); 
     1321         
     1322        jQuery.fn[ type ] = function( size ) { 
     1323                // Get window width or height 
     1324                return this[0] == window ? 
     1325                        // Opera reports document.body.client[Width/Height] properly in both quirks and standards 
     1326                        jQuery.browser.opera && document.body[ "client" + name ] ||  
     1327                         
     1328                        // Safari reports inner[Width/Height] just fine (Mozilla and Opera include scroll bar widths) 
     1329                        jQuery.browser.safari && window[ "inner" + name ] || 
     1330                         
     1331                        // Everyone else use document.documentElement or document.body depending on Quirks vs Standards mode 
     1332                        document.compatMode == "CSS1Compat" && document.documentElement[ "client" + name ] || document.body[ "client" + name ] : 
     1333                 
     1334                        // Get document width or height 
     1335                        this[0] == document ? 
     1336                                // Either scroll[Width/Height] or offset[Width/Height], whichever is greater 
     1337                                Math.max(  
     1338                                        Math.max(document.body["scroll" + name], document.documentElement["scroll" + name]),  
     1339                                        Math.max(document.body["offset" + name], document.documentElement["offset" + name])  
     1340                                ) : 
     1341 
     1342                                // Get or set width or height on the element 
     1343                                size == undefined ? 
     1344                                        // Get width or height on the element 
     1345                                        (this.length ? jQuery.css( this[0], type ) : null) : 
     1346 
     1347                                        // Set the width or height on the element (default to pixels if value is unitless) 
     1348                                        this.css( type, size.constructor == String ? size : size + "px" ); 
     1349        }; 
     1350}); 
     1351 
     1352var chars = jQuery.browser.safari && parseInt(jQuery.browser.version) < 417 ? 
     1353                "(?:[\\w*_-]|\\\\.)" : 
     1354                "(?:[\\w\u0128-\uFFFF*_-]|\\\\.)", 
     1355        quickChild = new RegExp("^>\\s*(" + chars + "+)"), 
     1356        quickID = new RegExp("^(" + chars + "+)(#)(" + chars + "+)"), 
     1357        quickClass = new RegExp("^([#.]?)(" + chars + "*)"); 
     1358 
     1359jQuery.extend({ 
     1360        expr: { 
     1361                "": "m[2]=='*'||jQuery.nodeName(a,m[2])", 
     1362                "#": "a.getAttribute('id')==m[2]", 
     1363                ":": { 
     1364                        // Position Checks 
     1365                        lt: "i<m[3]-0", 
     1366                        gt: "i>m[3]-0", 
     1367                        nth: "m[3]-0==i", 
     1368                        eq: "m[3]-0==i", 
     1369                        first: "i==0", 
     1370                        last: "i==r.length-1", 
     1371                        even: "i%2==0", 
     1372                        odd: "i%2", 
     1373 
     1374                        // Child Checks 
     1375                        "first-child": "a.parentNode.getElementsByTagName('*')[0]==a", 
     1376                        "last-child": "jQuery.nth(a.parentNode.lastChild,1,'previousSibling')==a", 
     1377                        "only-child": "!jQuery.nth(a.parentNode.lastChild,2,'previousSibling')", 
     1378 
     1379                        // Parent Checks 
     1380                        parent: "a.firstChild", 
     1381                        empty: "!a.firstChild", 
     1382 
     1383                        // Text Check 
     1384                        contains: "(a.textContent||a.innerText||jQuery(a).text()||'').indexOf(m[3])>=0", 
     1385 
     1386                        // Visibility 
     1387                        visible: '"hidden"!=a.type&&jQuery.css(a,"display")!="none"&&jQuery.css(a,"visibility")!="hidden"', 
     1388                        hidden: '"hidden"==a.type||jQuery.css(a,"display")=="none"||jQuery.css(a,"visibility")=="hidden"', 
     1389 
     1390                        // Form attributes 
     1391                        enabled: "!a.disabled", 
     1392                        disabled: "a.disabled", 
     1393                        checked: "a.checked", 
     1394                        selected: "a.selected||jQuery.attr(a,'selected')", 
     1395 
     1396                        // Form elements 
     1397                        text: "'text'==a.type", 
     1398                        radio: "'radio'==a.type", 
     1399                        checkbox: "'checkbox'==a.type", 
     1400                        file: "'file'==a.type", 
     1401                        password: "'password'==a.type", 
     1402                        submit: "'submit'==a.type", 
     1403                        image: "'image'==a.type", 
     1404                        reset: "'reset'==a.type", 
     1405                        button: '"button"==a.type||jQuery.nodeName(a,"button")', 
     1406                        input: "/input|select|textarea|button/i.test(a.nodeName)", 
     1407 
     1408                        // :has() 
     1409                        has: "jQuery.find(m[3],a).length", 
     1410 
     1411                        // :header 
     1412                        header: "/h\\d/i.test(a.nodeName)", 
     1413 
     1414                        // :animated 
     1415                        animated: "jQuery.grep(jQuery.timers,function(fn){return a==fn.elem;}).length" 
     1416                } 
     1417        }, 
     1418         
     1419        // The regular expressions that power the parsing engine 
     1420        parse: [ 
     1421                // Match: [@value='test'], [@foo] 
     1422                /^(\[) *@?([\w-]+) *([!*$^~=]*) *('?"?)(.*?)\4 *\]/, 
     1423 
     1424                // Match: :contains('foo') 
     1425                /^(:)([\w-]+)\("?'?(.*?(\(.*?\))?[^(]*?)"?'?\)/, 
     1426 
     1427                // Match: :even, :last-chlid, #id, .class 
     1428                new RegExp("^([:.#]*)(" + chars + "+)") 
     1429        ], 
     1430 
     1431        multiFilter: function( expr, elems, not ) { 
     1432                var old, cur = []; 
     1433 
     1434                while ( expr && expr != old ) { 
     1435                        old = expr; 
     1436                        var f = jQuery.filter( expr, elems, not ); 
     1437                        expr = f.t.replace(/^\s*,\s*/, "" ); 
     1438                        cur = not ? elems = f.r : jQuery.merge( cur, f.r ); 
     1439                } 
     1440 
     1441                return cur; 
     1442        }, 
     1443 
     1444        find: function( t, context ) { 
     1445                // Quickly handle non-string expressions 
     1446                if ( typeof t != "string" ) 
     1447                        return [ t ]; 
     1448 
     1449                // check to make sure context is a DOM element or a document 
     1450                if ( context && context.nodeType != 1 && context.nodeType != 9) 
     1451                        return [ ]; 
     1452 
     1453                // Set the correct context (if none is provided) 
     1454                context = context || document; 
     1455 
     1456                // Initialize the search 
     1457                var ret = [context], done = [], last, nodeName; 
     1458 
     1459                // Continue while a selector expression exists, and while 
     1460                // we're no longer looping upon ourselves 
     1461                while ( t && last != t ) { 
     1462                        var r = []; 
     1463                        last = t; 
     1464 
     1465                        t = jQuery.trim(t); 
     1466 
     1467                        var foundToken = false; 
     1468 
     1469                        // An attempt at speeding up child selectors that 
     1470                        // point to a specific element tag 
     1471                        var re = quickChild; 
     1472                        var m = re.exec(t); 
     1473 
     1474                        if ( m ) { 
     1475                                nodeName = m[1].toUpperCase(); 
     1476 
     1477                                // Perform our own iteration and filter 
     1478                                for ( var i = 0; ret[i]; i++ ) 
     1479                                        for ( var c = ret[i].firstChild; c; c = c.nextSibling ) 
     1480                                                if ( c.nodeType == 1 && (nodeName == "*" || c.nodeName.toUpperCase() == nodeName) ) 
     1481                                                        r.push( c ); 
     1482 
     1483                                ret = r; 
     1484                                t = t.replace( re, "" ); 
     1485                                if ( t.indexOf(" ") == 0 ) continue; 
     1486                                foundToken = true; 
     1487                        } else { 
     1488                                re = /^([>+~])\s*(\w*)/i; 
     1489 
     1490                                if ( (m = re.exec(t)) != null ) { 
     1491                                        r = []; 
     1492 
     1493                                        var merge = {}; 
     1494                                        nodeName = m[2].toUpperCase(); 
     1495                                        m = m[1]; 
     1496 
     1497                                        for ( var j = 0, rl = ret.length; j < rl; j++ ) { 
     1498                                                var n = m == "~" || m == "+" ? ret[j].nextSibling : ret[j].firstChild; 
     1499                                                for ( ; n; n = n.nextSibling ) 
     1500                                                        if ( n.nodeType == 1 ) { 
     1501                                                                var id = jQuery.data(n); 
     1502 
     1503                                                                if ( m == "~" && merge[id] ) break; 
     1504                                                                 
     1505                                                                if (!nodeName || n.nodeName.toUpperCase() == nodeName ) { 
     1506                                                                        if ( m == "~" ) merge[id] = true; 
     1507                                                                        r.push( n ); 
     1508                                                                } 
     1509                                                                 
     1510                                                                if ( m == "+" ) break; 
     1511                                                        } 
     1512                                        } 
     1513 
     1514                                        ret = r; 
     1515 
     1516                                        // And remove the token 
     1517                                        t = jQuery.trim( t.replace( re, "" ) ); 
     1518                                        foundToken = true; 
     1519                                } 
     1520                        } 
     1521 
     1522                        // See if there's still an expression, and that we haven't already 
     1523                        // matched a token 
     1524                        if ( t && !foundToken ) { 
     1525                                // Handle multiple expressions 
     1526                                if ( !t.indexOf(",") ) { 
     1527                                        // Clean the result set 
     1528                                        if ( context == ret[0] ) ret.shift(); 
     1529 
     1530                                        // Merge the result sets 
     1531                                        done = jQuery.merge( done, ret ); 
     1532 
     1533                                        // Reset the context 
     1534                                        r = ret = [context]; 
     1535 
     1536                                        // Touch up the selector string 
     1537                                        t = " " + t.substr(1,t.length); 
     1538 
     1539                                } else { 
     1540                                        // Optimize for the case nodeName#idName 
     1541                                        var re2 = quickID; 
     1542                                        var m = re2.exec(t); 
     1543                                         
     1544                                        // Re-organize the results, so that they're consistent 
     1545                                        if ( m ) { 
     1546                                                m = [ 0, m[2], m[3], m[1] ]; 
     1547 
     1548                                        } else { 
     1549                                                // Otherwise, do a traditional filter check for 
     1550                                                // ID, class, and element selectors 
     1551                                                re2 = quickClass; 
     1552                                                m = re2.exec(t); 
     1553                                        } 
     1554 
     1555                                        m[2] = m[2].replace(/\\/g, ""); 
     1556 
     1557                                        var elem = ret[ret.length-1]; 
     1558 
     1559                                        // Try to do a global search by ID, where we can 
     1560                                        if ( m[1] == "#" && elem && elem.getElementById && !jQuery.isXMLDoc(elem) ) { 
     1561                                                // Optimization for HTML document case 
     1562                                                var oid = elem.getElementById(m[2]); 
     1563                                                 
     1564                                                // Do a quick check for the existence of the actual ID attribute 
     1565                                                // to avoid selecting by the name attribute in IE 
     1566                                                // also check to insure id is a string to avoid selecting an element with the name of 'id' inside a form 
     1567                                                if ( (jQuery.browser.msie||jQuery.browser.opera) && oid && typeof oid.id == "string" && oid.id != m[2] ) 
     1568                                                        oid = jQuery('[@id="'+m[2]+'"]', elem)[0]; 
     1569 
     1570                                                // Do a quick check for node name (where applicable) so 
     1571                                                // that div#foo searches will be really fast 
     1572                                                ret = r = oid && (!m[3] || jQuery.nodeName(oid, m[3])) ? [oid] : []; 
     1573                                        } else { 
     1574                                                // We need to find all descendant elements 
     1575                                                for ( var i = 0; ret[i]; i++ ) { 
     1576                                                        // Grab the tag name being searched for 
     1577                                                        var tag = m[1] == "#" && m[3] ? m[3] : m[1] != "" || m[0] == "" ? "*" : m[2]; 
     1578 
     1579                                                        // Handle IE7 being really dumb about <object>s 
     1580                                                        if ( tag == "*" && ret[i].nodeName.toLowerCase() == "object" ) 
     1581                                                                tag = "param"; 
     1582 
     1583                                                        r = jQuery.merge( r, ret[i].getElementsByTagName( tag )); 
     1584                                                } 
     1585 
     1586                                                // It's faster to filter by class and be done with it 
     1587                                                if ( m[1] == "." ) 
     1588                                                        r = jQuery.classFilter( r, m[2] ); 
     1589 
     1590                                                // Same with ID filtering 
     1591                                                if ( m[1] == "#" ) { 
     1592                                                        var tmp = []; 
     1593 
     1594                                                        // Try to find the element with the ID 
     1595                                                        for ( var i = 0; r[i]; i++ ) 
     1596                                                                if ( r[i].getAttribute("id") == m[2] ) { 
     1597                                                                        tmp = [ r[i] ]; 
     1598                                                                        break; 
     1599                                                                } 
     1600 
     1601                                                        r = tmp; 
     1602                                                } 
     1603 
     1604                                                ret = r; 
     1605                                        } 
     1606 
     1607                                        t = t.replace( re2, "" ); 
     1608                                } 
     1609 
     1610                        } 
     1611 
     1612                        // If a selector string still exists 
     1613                        if ( t ) { 
     1614                                // Attempt to filter it 
     1615                                var val = jQuery.filter(t,r); 
     1616                                ret = r = val.r; 
     1617                                t = jQuery.trim(val.t); 
     1618                        } 
     1619                } 
     1620 
     1621                // An error occurred with the selector; 
     1622                // just return an empty set instead 
     1623                if ( t ) 
     1624                        ret = []; 
     1625 
     1626                // Remove the root context 
     1627                if ( ret && context == ret[0] ) 
     1628                        ret.shift(); 
     1629 
     1630                // And combine the results 
     1631                done = jQuery.merge( done, ret ); 
     1632 
     1633                return done; 
     1634        }, 
     1635 
     1636        classFilter: function(r,m,not){ 
     1637                m = " " + m + " "; 
     1638                var tmp = []; 
     1639                for ( var i = 0; r[i]; i++ ) { 
     1640                        var pass = (" " + r[i].className + " ").indexOf( m ) >= 0; 
     1641                        if ( !not && pass || not && !pass ) 
     1642                                tmp.push( r[i] ); 
     1643                } 
     1644                return tmp; 
     1645        }, 
     1646 
     1647        filter: function(t,r,not) { 
     1648                var last; 
     1649 
     1650                // Look for common filter expressions 
     1651                while ( t && t != last ) { 
     1652                        last = t; 
     1653 
     1654                        var p = jQuery.parse, m; 
     1655 
     1656                        for ( var i = 0; p[i]; i++ ) { 
     1657                                m = p[i].exec( t ); 
     1658 
     1659                                if ( m ) { 
     1660                                        // Remove what we just matched 
     1661                                        t = t.substring( m[0].length ); 
     1662 
     1663                                        m[2] = m[2].replace(/\\/g, ""); 
     1664                                        break; 
     1665                                } 
     1666                        } 
     1667 
     1668                        if ( !m ) 
     1669                                break; 
     1670 
     1671                        // :not() is a special case that can be optimized by 
     1672                        // keeping it out of the expression list 
     1673                        if ( m[1] == ":" && m[2] == "not" ) 
     1674                                // optimize if only one selector found (most common case) 
     1675                                r = isSimple.test( m[3] ) ? 
     1676                                        jQuery.filter(m[3], r, true).r : 
     1677                                        jQuery( r ).not( m[3] ); 
     1678 
     1679                        // We can get a big speed boost by filtering by class here 
     1680                        else if ( m[1] == "." ) 
     1681                                r = jQuery.classFilter(r, m[2], not); 
     1682 
     1683                        else if ( m[1] == "[" ) { 
     1684                                var tmp = [], type = m[3]; 
     1685                                 
     1686                                for ( var i = 0, rl = r.length; i < rl; i++ ) { 
     1687                                        var a = r[i], z = a[ jQuery.props[m[2]] || m[2] ]; 
     1688                                         
     1689                                        if ( z == null || /href|src|selected/.test(m[2]) ) 
     1690                                                z = jQuery.attr(a,m[2]) || ''; 
     1691 
     1692                                        if ( (type == "" && !!z || 
     1693                                                 type == "=" && z == m[5] || 
     1694                                                 type == "!=" && z != m[5] || 
     1695                                                 type == "^=" && z && !z.indexOf(m[5]) || 
     1696                                                 type == "$=" && z.substr(z.length - m[5].length) == m[5] || 
     1697                                                 (type == "*=" || type == "~=") && z.indexOf(m[5]) >= 0) ^ not ) 
     1698                                                        tmp.push( a ); 
     1699                                } 
     1700                                 
     1701                                r = tmp; 
     1702 
     1703                        // We can get a speed boost by handling nth-child here 
     1704                        } else if ( m[1] == ":" && m[2] == "nth-child" ) { 
     1705                                var merge = {}, tmp = [], 
     1706                                        // parse equations like 'even', 'odd', '5', '2n', '3n+2', '4n-1', '-n+6' 
     1707                                        test = /(-?)(\d*)n((?:\+|-)?\d*)/.exec( 
     1708                                                m[3] == "even" && "2n" || m[3] == "odd" && "2n+1" || 
     1709                                                !/\D/.test(m[3]) && "0n+" + m[3] || m[3]), 
     1710                                        // calculate the numbers (first)n+(last) including if they are negative 
     1711                                        first = (test[1] + (test[2] || 1)) - 0, last = test[3] - 0; 
     1712  
     1713                                // loop through all the elements left in the jQuery object 
     1714                                for ( var i = 0, rl = r.length; i < rl; i++ ) { 
     1715                                        var node = r[i], parentNode = node.parentNode, id = jQuery.data(parentNode); 
     1716 
     1717                                        if ( !merge[id] ) { 
     1718                                                var c = 1; 
     1719 
     1720                                                for ( var n = parentNode.firstChild; n; n = n.nextSibling ) 
     1721                                                        if ( n.nodeType == 1 ) 
     1722                                                                n.nodeIndex = c++; 
     1723 
     1724                                                merge[id] = true; 
     1725                                        } 
     1726 
     1727                                        var add = false; 
     1728 
     1729                                        if ( first == 0 ) { 
     1730                                                if ( node.nodeIndex == last ) 
     1731                                                        add = true; 
     1732                                        } else if ( (node.nodeIndex - last) % first == 0 && (node.nodeIndex - last) / first >= 0 ) 
     1733                                                add = true; 
     1734 
     1735                                        if ( add ^ not ) 
     1736                                                tmp.push( node ); 
     1737                                } 
     1738 
     1739                                r = tmp; 
     1740 
     1741                        // Otherwise, find the expression to execute 
     1742                        } else { 
     1743                                var f = jQuery.expr[m[1]]; 
     1744                                if ( typeof f != "string" ) 
     1745                                        f = jQuery.expr[m[1]][m[2]]; 
     1746 
     1747                                // Build a custom macro to enclose it 
     1748                                f = eval("false||function(a,i){return " + f + "}"); 
     1749 
     1750                                // Execute it against the current filter 
     1751                                r = jQuery.grep( r, f, not ); 
     1752                        } 
     1753                } 
     1754 
     1755                // Return an array of filtered elements (r) 
     1756                // and the modified expression string (t) 
     1757                return { r: r, t: t }; 
     1758        }, 
     1759 
     1760        dir: function( elem, dir ){ 
     1761                var matched = []; 
     1762                var cur = elem[dir]; 
     1763                while ( cur && cur != document ) { 
     1764                        if ( cur.nodeType == 1 ) 
     1765                                matched.push( cur ); 
     1766                        cur = cur[dir]; 
     1767                } 
     1768                return matched; 
     1769        }, 
     1770         
     1771        nth: function(cur,result,dir,elem){ 
     1772                result = result || 1; 
     1773                var num = 0; 
     1774 
     1775                for ( ; cur; cur = cur[dir] ) 
     1776                        if ( cur.nodeType == 1 && ++num == result ) 
     1777                                break; 
     1778 
     1779                return cur; 
     1780        }, 
     1781         
     1782        sibling: function( n, elem ) { 
     1783                var r = []; 
     1784 
     1785                for ( ; n; n = n.nextSibling ) { 
     1786                        if ( n.nodeType == 1 && (!elem || n != elem) ) 
     1787                                r.push( n ); 
     1788                } 
     1789 
     1790                return r; 
     1791        } 
     1792}); 
     1793 
     1794/* 
     1795 * A number of helper functions used for managing events. 
     1796 * Many of the ideas behind this code orignated from  
     1797 * Dean Edwards' addEvent library. 
     1798 */ 
     1799jQuery.event = { 
     1800 
     1801        // Bind an event to an element 
     1802        // Original by Dean Edwards 
     1803        add: function(elem, types, handler, data) { 
     1804                if ( elem.nodeType == 3 || elem.nodeType == 8 ) 
     1805                        return; 
     1806 
     1807                // For whatever reason, IE has trouble passing the window object 
     1808                // around, causing it to be cloned in the process 
     1809                if ( jQuery.browser.msie && elem.setInterval != undefined ) 
     1810                        elem = window; 
     1811 
     1812                // Make sure that the function being executed has a unique ID 
     1813                if ( !handler.guid ) 
     1814                        handler.guid = this.guid++; 
     1815                         
     1816                // if data is passed, bind to handler  
     1817                if( data != undefined ) {  
     1818                        // Create temporary function pointer to original handler  
     1819                        var fn = handler;  
     1820 
     1821                        // Create unique handler function, wrapped around original handler  
     1822                        handler = function() {  
     1823                                // Pass arguments and context to original handler  
     1824                                return fn.apply(this, arguments);  
     1825                        }; 
     1826 
     1827                        // Store data in unique handler  
     1828                        handler.data = data; 
     1829 
     1830                        // Set the guid of unique handler to the same of original handler, so it can be removed  
     1831                        handler.guid = fn.guid; 
     1832                } 
     1833 
     1834                // Init the element's event structure 
     1835                var events = jQuery.data(elem, "events") || jQuery.data(elem, "events", {}), 
     1836                        handle = jQuery.data(elem, "handle") || jQuery.data(elem, "handle", function(){ 
     1837                                // returned undefined or false 
     1838                                var val; 
     1839 
     1840                                // Handle the second event of a trigger and when 
     1841                                // an event is called after a page has unloaded 
     1842                                if ( typeof jQuery == "undefined" || jQuery.event.triggered ) 
     1843                                        return val; 
     1844                 
     1845                                val = jQuery.event.handle.apply(arguments.callee.elem, arguments); 
     1846                 
     1847                                return val; 
     1848                        }); 
     1849                // Add elem as a property of the handle function 
     1850                // This is to prevent a memory leak with non-native 
     1851                // event in IE. 
     1852                handle.elem = elem; 
     1853                         
     1854                        // Handle multiple events seperated by a space 
     1855                        // jQuery(...).bind("mouseover mouseout", fn); 
     1856                        jQuery.each(types.split(/\s+/), function(index, type) { 
     1857                                // Namespaced event handlers 
     1858                                var parts = type.split("."); 
     1859                                type = parts[0]; 
     1860                                handler.type = parts[1]; 
     1861 
     1862                                // Get the current list of functions bound to this event 
     1863                                var handlers = events[type]; 
     1864 
     1865                                // Init the event handler queue 
     1866                                if (!handlers) { 
     1867                                        handlers = events[type] = {}; 
     1868                 
     1869                                        // Check for a special event handler 
     1870                                        // Only use addEventListener/attachEvent if the special 
     1871                                        // events handler returns false 
     1872                                        if ( !jQuery.event.special[type] || jQuery.event.special[type].setup.call(elem) === false ) { 
     1873                                                // Bind the global event handler to the element 
     1874                                                if (elem.addEventListener) 
     1875                                                        elem.addEventListener(type, handle, false); 
     1876                                                else if (elem.attachEvent) 
     1877                                                        elem.attachEvent("on" + type, handle); 
     1878                                        } 
     1879                                } 
     1880 
     1881                                // Add the function to the element's handler list 
     1882                                handlers[handler.guid] = handler; 
     1883 
     1884                                // Keep track of which events have been used, for global triggering 
     1885                                jQuery.event.global[type] = true; 
     1886                        }); 
     1887                 
     1888                // Nullify elem to prevent memory leaks in IE 
     1889                elem = null; 
     1890        }, 
     1891 
     1892        guid: 1, 
     1893        global: {}, 
     1894 
     1895        // Detach an event or set of events from an element 
     1896        remove: function(elem, types, handler) { 
     1897                // don't do events on text and comment nodes 
     1898                if ( elem.nodeType == 3 || elem.nodeType == 8 ) 
     1899                        return; 
     1900 
     1901                var events = jQuery.data(elem, "events"), ret, index; 
     1902 
     1903                if ( events ) { 
     1904                        // Unbind all events for the element 
     1905                        if ( types == undefined ) 
     1906                                for ( var type in events ) 
     1907                                        this.remove( elem, type ); 
     1908                        else { 
     1909                                // types is actually an event object here 
     1910                                if ( types.type ) { 
     1911                                        handler = types.handler; 
     1912                                        types = types.type; 
     1913                                } 
     1914                                 
     1915                                // Handle multiple events seperated by a space 
     1916                                // jQuery(...).unbind("mouseover mouseout", fn); 
     1917                                jQuery.each(types.split(/\s+/), function(index, type){ 
     1918                                        // Namespaced event handlers 
     1919                                        var parts = type.split("."); 
     1920                                        type = parts[0]; 
     1921                                         
     1922                                        if ( events[type] ) { 
     1923                                                // remove the given handler for the given type 
     1924                                                if ( handler ) 
     1925                                                        delete events[type][handler.guid]; 
     1926                         
     1927                                                // remove all handlers for the given type 
     1928                                                else 
     1929                                                        for ( handler in events[type] ) 
     1930                                                                // Handle the removal of namespaced events 
     1931                                                                if ( !parts[1] || events[type][handler].type == parts[1] ) 
     1932                                                                        delete events[type][handler]; 
     1933 
     1934                                                // remove generic event handler if no more handlers exist 
     1935                                                for ( ret in events[type] ) break; 
     1936                                                if ( !ret ) { 
     1937                                                        if ( !jQuery.event.special[type] || jQuery.event.special[type].teardown.call(elem) === false ) { 
     1938                                                                if (elem.removeEventListener) 
     1939                                                                        elem.removeEventListener(type, jQuery.data(elem, "handle"), false); 
     1940                                                                else if (elem.detachEvent) 
     1941                                                                        elem.detachEvent("on" + type, jQuery.data(elem, "handle")); 
     1942                                                        } 
     1943                                                        ret = null; 
     1944                                                        delete events[type]; 
     1945                                                } 
     1946                                        } 
     1947                                }); 
     1948                        } 
     1949 
     1950                        // Remove the expando if it's no longer used 
     1951                        for ( ret in events ) break; 
     1952                        if ( !ret ) { 
     1953                                var handle = jQuery.data( elem, "handle" ); 
     1954                                if ( handle ) handle.elem = null; 
     1955                                jQuery.removeData( elem, "events" ); 
     1956                                jQuery.removeData( elem, "handle" ); 
     1957                        } 
     1958                } 
     1959        }, 
     1960 
     1961        trigger: function(type, data, elem, donative, extra) { 
     1962                // Clone the incoming data, if any 
     1963                data = jQuery.makeArray(data || []); 
     1964 
     1965                // Handle a global trigger 
     1966                if ( !elem ) { 
     1967                        // Only trigger if we've ever bound an event for it 
     1968                        if ( this.global[type] ) 
     1969                                jQuery("*").add([window, document]).trigger(type, data); 
     1970 
     1971                // Handle triggering a single element 
     1972                } else { 
     1973                        // don't do events on text and comment nodes 
     1974                        if ( elem.nodeType == 3 || elem.nodeType == 8 ) 
     1975                                return undefined; 
     1976 
     1977                        var val, ret, fn = jQuery.isFunction( elem[ type ] || null ), 
     1978                                // Check to see if we need to provide a fake event, or not 
     1979                                event = !data[0] || !data[0].preventDefault; 
     1980                         
     1981                        // Pass along a fake event 
     1982                        if ( event ) 
     1983                                data.unshift( this.fix({ type: type, target: elem }) ); 
     1984 
     1985                        // Enforce the right trigger type 
     1986                        data[0].type = type; 
     1987 
     1988                        // Trigger the event 
     1989                        if ( jQuery.isFunction( jQuery.data(elem, "handle") ) ) 
     1990                                val = jQuery.data(elem, "handle").apply( elem, data ); 
     1991 
     1992                        // Handle triggering native .onfoo handlers 
     1993                        if ( !fn && elem["on"+type] && elem["on"+type].apply( elem, data ) === false ) 
     1994                                val = false; 
     1995 
     1996                        // Extra functions don't get the custom event object 
     1997                        if ( event ) 
     1998                                data.shift(); 
     1999 
     2000                        // Handle triggering of extra function 
     2001                        if ( extra && jQuery.isFunction( extra ) ) { 
     2002                                // call the extra function and tack the current return value on the end for possible inspection 
     2003                                ret = extra.apply( elem, data.concat( val ) ); 
     2004                                // if anything is returned, give it precedence and have it overwrite the previous value 
     2005                                if (ret !== undefined) 
     2006                                        val = ret; 
     2007                        } 
     2008 
     2009                        // Trigger the native events (except for clicks on links) 
     2010                        if ( fn && donative !== false && val !== false && !(jQuery.nodeName(elem, 'a') && type == "click") ) { 
     2011                                this.triggered = true; 
     2012                                try { 
     2013                                        elem[ type ](); 
     2014                                // prevent IE from throwing an error for some hidden elements 
     2015                                } catch (e) {} 
     2016                        } 
     2017 
     2018                        this.triggered = false; 
     2019                } 
     2020 
     2021                return val; 
     2022        }, 
     2023 
     2024        handle: function(event) { 
     2025                // returned undefined or false 
     2026                var val; 
     2027 
     2028                // Empty object is for triggered events with no data 
     2029                event = jQuery.event.fix( event || window.event || {} );  
     2030 
     2031                // Namespaced event handlers 
     2032                var parts = event.type.split("."); 
     2033                event.type = parts[0]; 
     2034 
     2035                var handlers = jQuery.data(this, "events") && jQuery.data(this, "events")[event.type], args = Array.prototype.slice.call( arguments, 1 ); 
     2036                args.unshift( event ); 
     2037 
     2038                for ( var j in handlers ) { 
     2039                        var handler = handlers[j]; 
     2040                        // Pass in a reference to the handler function itself 
     2041                        // So that we can later remove it 
     2042                        args[0].handler = handler; 
     2043                        args[0].data = handler.data; 
     2044 
     2045                        // Filter the functions by class 
     2046                        if ( !parts[1] || handler.type == parts[1] ) { 
     2047                                var ret = handler.apply( this, args ); 
     2048 
     2049                                if ( val !== false ) 
     2050                                        val = ret; 
     2051 
     2052                                if ( ret === false ) { 
     2053                                        event.preventDefault(); 
     2054                                        event.stopPropagation(); 
     2055                                } 
     2056                        } 
     2057                } 
     2058 
     2059                // Clean up added properties in IE to prevent memory leak 
     2060                if (jQuery.browser.msie) 
     2061                        event.target = event.preventDefault = event.stopPropagation = 
     2062                                event.handler = event.data = null; 
     2063 
     2064                return val; 
     2065        }, 
     2066 
     2067        fix: function(event) { 
     2068                // store a copy of the original event object  
     2069                // and clone to set read-only properties 
     2070                var originalEvent = event; 
     2071                event = jQuery.extend({}, originalEvent); 
     2072                 
     2073                // add preventDefault and stopPropagation since  
     2074                // they will not work on the clone 
     2075                event.preventDefault = function() { 
     2076                        // if preventDefault exists run it on the original event 
     2077                        if (originalEvent.preventDefault) 
     2078                                originalEvent.preventDefault(); 
     2079                        // otherwise set the returnValue property of the original event to false (IE) 
     2080                        originalEvent.returnValue = false; 
     2081                }; 
     2082                event.stopPropagation = function() { 
     2083                        // if stopPropagation exists run it on the original event 
     2084                        if (originalEvent.stopPropagation) 
     2085                                originalEvent.stopPropagation(); 
     2086                        // otherwise set the cancelBubble property of the original event to true (IE) 
     2087                        originalEvent.cancelBubble = true; 
     2088                }; 
     2089                 
     2090                // Fix target property, if necessary 
     2091                if ( !event.target ) 
     2092                        event.target = event.srcElement || document; // Fixes #1925 where srcElement might not be defined either 
     2093                                 
     2094                // check if target is a textnode (safari) 
     2095                if ( event.target.nodeType == 3 ) 
     2096                        event.target = originalEvent.target.parentNode; 
     2097 
     2098                // Add relatedTarget, if necessary 
     2099                if ( !event.relatedTarget && event.fromElement ) 
     2100                        event.relatedTarget = event.fromElement == event.target ? event.toElement : event.fromElement; 
     2101 
     2102                // Calculate pageX/Y if missing and clientX/Y available 
     2103                if ( event.pageX == null && event.clientX != null ) { 
     2104                        var doc = document.documentElement, body = document.body; 
     2105                        event.pageX = event.clientX + (doc && doc.scrollLeft || body && body.scrollLeft || 0) - (doc.clientLeft || 0); 
     2106                        event.pageY = event.clientY + (doc && doc.scrollTop || body && body.scrollTop || 0) - (doc.clientTop || 0); 
     2107                } 
     2108                         
     2109                // Add which for key events 
     2110                if ( !event.which && ((event.charCode || event.charCode === 0) ? event.charCode : event.keyCode) ) 
     2111                        event.which = event.charCode || event.keyCode; 
     2112                 
     2113                // Add metaKey to non-Mac browsers (use ctrl for PC's and Meta for Macs) 
     2114                if ( !event.metaKey && event.ctrlKey ) 
     2115                        event.metaKey = event.ctrlKey; 
     2116 
     2117                // Add which for click: 1 == left; 2 == middle; 3 == right 
     2118                // Note: button is not normalized, so don't use it 
     2119                if ( !event.which && event.button ) 
     2120                        event.which = (event.button & 1 ? 1 : ( event.button & 2 ? 3 : ( event.button & 4 ? 2 : 0 ) )); 
     2121                         
     2122                return event; 
     2123        }, 
     2124         
     2125        special: { 
     2126                ready: { 
     2127                        setup: function() { 
     2128                                // Make sure the ready event is setup 
     2129                                bindReady(); 
     2130                                return; 
     2131                        }, 
     2132                         
     2133                        teardown: function() { return; } 
     2134                }, 
     2135                 
     2136                mouseenter: { 
     2137                        setup: function() { 
     2138                                if ( jQuery.browser.msie ) return false; 
     2139                                jQuery(this).bind("mouseover", jQuery.event.special.mouseenter.handler); 
     2140                                return true; 
     2141                        }, 
     2142                 
     2143                        teardown: function() { 
     2144                                if ( jQuery.browser.msie ) return false; 
     2145                                jQuery(this).unbind("mouseover", jQuery.event.special.mouseenter.handler); 
     2146                                return true; 
     2147                        }, 
     2148                         
     2149                        handler: function(event) { 
     2150                                // If we actually just moused on to a sub-element, ignore it 
     2151                                if ( withinElement(event, this) ) return true; 
     2152                                // Execute the right handlers by setting the event type to mouseenter 
     2153                                arguments[0].type = "mouseenter"; 
     2154                                return jQuery.event.handle.apply(this, arguments); 
     2155                        } 
     2156                }, 
     2157         
     2158                mouseleave: { 
     2159                        setup: function() { 
     2160                                if ( jQuery.browser.msie ) return false; 
     2161                                jQuery(this).bind("mouseout", jQuery.event.special.mouseleave.handler); 
     2162                                return true; 
     2163                        }, 
     2164                 
     2165                        teardown: function() { 
     2166                                if ( jQuery.browser.msie ) return false; 
     2167                                jQuery(this).unbind("mouseout", jQuery.event.special.mouseleave.handler); 
     2168                                return true; 
     2169                        }, 
     2170                         
     2171                        handler: function(event) { 
     2172                                // If we actually just moused on to a sub-element, ignore it 
     2173                                if ( withinElement(event, this) ) return true; 
     2174                                // Execute the right handlers by setting the event type to mouseleave 
     2175                                arguments[0].type = "mouseleave"; 
     2176                                return jQuery.event.handle.apply(this, arguments); 
     2177                        } 
     2178                } 
     2179        } 
     2180}; 
     2181 
     2182jQuery.fn.extend({ 
     2183        bind: function( type, data, fn ) { 
     2184                return type == "unload" ? this.one(type, data, fn) : this.each(function(){ 
     2185                        jQuery.event.add( this, type, fn || data, fn && data ); 
     2186                }); 
     2187        }, 
     2188         
     2189        one: function( type, data, fn ) { 
     2190                return this.each(function(){ 
     2191                        jQuery.event.add( this, type, function(event) { 
     2192                                jQuery(this).unbind(event); 
     2193                                return (fn || data).apply( this, arguments); 
     2194                        }, fn && data); 
     2195                }); 
     2196        }, 
     2197 
     2198        unbind: function( type, fn ) { 
     2199                return this.each(function(){ 
     2200                        jQuery.event.remove( this, type, fn ); 
     2201                }); 
     2202        }, 
     2203 
     2204        trigger: function( type, data, fn ) { 
     2205                return this.each(function(){ 
     2206                        jQuery.event.trigger( type, data, this, true, fn ); 
     2207                }); 
     2208        }, 
     2209 
     2210        triggerHandler: function( type, data, fn ) { 
     2211                if ( this[0] ) 
     2212                        return jQuery.event.trigger( type, data, this[0], false, fn ); 
     2213                return undefined; 
     2214        }, 
     2215 
     2216        toggle: function() { 
     2217                // Save reference to arguments for access in closure 
     2218                var args = arguments; 
     2219 
     2220                return this.click(function(event) { 
     2221                        // Figure out which function to execute 
     2222                        this.lastToggle = 0 == this.lastToggle ? 1 : 0; 
     2223                         
     2224                        // Make sure that clicks stop 
     2225                        event.preventDefault(); 
     2226                         
     2227                        // and execute the function 
     2228                        return args[this.lastToggle].apply( this, arguments ) || false; 
     2229                }); 
     2230        }, 
     2231 
     2232        hover: function(fnOver, fnOut) { 
     2233                return this.bind('mouseenter', fnOver).bind('mouseleave', fnOut); 
     2234        }, 
     2235         
     2236        ready: function(fn) { 
     2237                // Attach the listeners 
     2238                bindReady(); 
     2239 
     2240                // If the DOM is already ready 
     2241                if ( jQuery.isReady ) 
     2242                        // Execute the function immediately 
     2243                        fn.call( document, jQuery ); 
     2244                         
     2245                // Otherwise, remember the function for later 
     2246                else 
     2247                        // Add the function to the wait list 
     2248                        jQuery.readyList.push( function() { return fn.call(this, jQuery); } ); 
     2249         
     2250                return this; 
     2251        } 
     2252}); 
     2253 
     2254jQuery.extend({ 
     2255        isReady: false, 
     2256        readyList: [], 
     2257        // Handle when the DOM is ready 
     2258        ready: function() { 
     2259                // Make sure that the DOM is not already loaded 
     2260                if ( !jQuery.isReady ) { 
     2261                        // Remember that the DOM is ready 
     2262                        jQuery.isReady = true; 
     2263                         
     2264                        // If there are functions bound, to execute 
     2265                        if ( jQuery.readyList ) { 
     2266                                // Execute all of them 
     2267                                jQuery.each( jQuery.readyList, function(){ 
     2268                                        this.apply( document ); 
     2269                                }); 
     2270                                 
     2271                                // Reset the list of functions 
     2272                                jQuery.readyList = null; 
     2273                        } 
     2274                 
     2275                        // Trigger any bound ready events 
     2276                        jQuery(document).triggerHandler("ready"); 
     2277                } 
     2278        } 
     2279}); 
     2280 
     2281var readyBound = false; 
     2282 
     2283function bindReady(){ 
     2284        if ( readyBound ) return; 
     2285        readyBound = true; 
     2286 
     2287        // Mozilla, Opera (see further below for it) and webkit nightlies currently support this event 
     2288        if ( document.addEventListener && !jQuery.browser.opera) 
     2289                // Use the handy event callback 
     2290                document.addEventListener( "DOMContentLoaded", jQuery.ready, false ); 
     2291         
     2292        // If IE is used and is not in a frame 
     2293        // Continually check to see if the document is ready 
     2294        if ( jQuery.browser.msie && window == top ) (function(){ 
     2295                if (jQuery.isReady) return; 
     2296                try { 
     2297                        // If IE is used, use the trick by Diego Perini 
     2298                        // http://javascript.nwbox.com/IEContentLoaded/ 
     2299                        document.documentElement.doScroll("left"); 
     2300                } catch( error ) { 
     2301                        setTimeout( arguments.callee, 0 ); 
     2302                        return; 
     2303                } 
     2304                // and execute any waiting functions 
     2305                jQuery.ready(); 
     2306        })(); 
     2307 
     2308        if ( jQuery.browser.opera ) 
     2309                document.addEventListener( "DOMContentLoaded", function () { 
     2310                        if (jQuery.isReady) return; 
     2311                        for (var i = 0; i < document.styleSheets.length; i++) 
     2312                                if (document.styleSheets[i].disabled) { 
     2313                                        setTimeout( arguments.callee, 0 ); 
     2314                                        return; 
     2315                                } 
     2316                        // and execute any waiting functions 
     2317                        jQuery.ready(); 
     2318                }, false); 
     2319 
     2320        if ( jQuery.browser.safari ) { 
     2321                var numStyles; 
     2322                (function(){ 
     2323                        if (jQuery.isReady) return; 
     2324                        if ( document.readyState != "loaded" && document.readyState != "complete" ) { 
     2325                                setTimeout( arguments.callee, 0 ); 
     2326                                return; 
     2327                        } 
     2328                        if ( numStyles === undefined ) 
     2329                                numStyles = jQuery("style, link[rel=stylesheet]").length; 
     2330                        if ( document.styleSheets.length != numStyles ) { 
     2331                                setTimeout( arguments.callee, 0 ); 
     2332                                return; 
     2333                        } 
     2334                        // and execute any waiting functions 
     2335                        jQuery.ready(); 
     2336                })(); 
     2337        } 
     2338 
     2339        // A fallback to window.onload, that will always work 
     2340        jQuery.event.add( window, "load", jQuery.ready ); 
     2341} 
     2342 
     2343jQuery.each( ("blur,focus,load,resize,scroll,unload,click,dblclick," + 
     2344        "mousedown,mouseup,mousemove,mouseover,mouseout,change,select," +  
     2345        "submit,keydown,keypress,keyup,error").split(","), function(i, name){ 
     2346         
     2347        // Handle event binding 
     2348        jQuery.fn[name] = function(fn){ 
     2349                return fn ? this.bind(name, fn) : this.trigger(name); 
     2350        }; 
     2351}); 
     2352 
     2353// Checks if an event happened on an element within another element 
     2354// Used in jQuery.event.special.mouseenter and mouseleave handlers 
     2355var withinElement = function(event, elem) { 
     2356        // Check if mouse(over|out) are still within the same parent element 
     2357        var parent = event.relatedTarget; 
     2358        // Traverse up the tree 
     2359        while ( parent && parent != elem ) try { parent = parent.parentNode; } catch(error) { parent = elem; } 
     2360        // Return true if we actually just moused on to a sub-element 
     2361        return parent == elem; 
     2362}; 
     2363 
     2364// Prevent memory leaks in IE 
     2365// And prevent errors on refresh with events like mouseover in other browsers 
     2366// Window isn't included so as not to unbind existing unload events 
     2367jQuery(window).bind("unload", function() { 
     2368        jQuery("*").add(document).unbind(); 
     2369}); 
     2370jQuery.fn.extend({ 
     2371        load: function( url, params, callback ) { 
     2372                if ( jQuery.isFunction( url ) ) 
     2373                        return this.bind("load", url); 
     2374 
     2375                var off = url.indexOf(" "); 
     2376                if ( off >= 0 ) { 
     2377                        var selector = url.slice(off, url.length); 
     2378                        url = url.slice(0, off); 
     2379                } 
     2380 
     2381                callback = callback || function(){}; 
     2382 
     2383                // Default to a GET request 
     2384                var type = "GET"; 
     2385 
     2386                // If the second parameter was provided 
     2387                if ( params ) 
     2388                        // If it's a function 
     2389                        if ( jQuery.isFunction( params ) ) { 
     2390                                // We assume that it's the callback 
     2391                                callback = params; 
     2392                                params = null; 
     2393 
     2394                        // Otherwise, build a param string 
     2395                        } else { 
     2396                                params = jQuery.param( params ); 
     2397                                type = "POST"; 
     2398                        } 
     2399 
     2400                var self = this; 
     2401 
     2402                // Request the remote document 
     2403                jQuery.ajax({ 
     2404                        url: url, 
     2405                        type: type, 
     2406                        dataType: "html", 
     2407                        data: params, 
     2408                        complete: function(res, status){ 
     2409                                // If successful, inject the HTML into all the matched elements 
     2410                                if ( status == "success" || status == "notmodified" ) 
     2411                                        // See if a selector was specified 
     2412                                        self.html( selector ? 
     2413                                                // Create a dummy div to hold the results 
     2414                                                jQuery("<div/>") 
     2415                                                        // inject the contents of the document in, removing the scripts 
     2416                                                        // to avoid any 'Permission Denied' errors in IE 
     2417                                                        .append(res.responseText.replace(/<script(.|\s)*?\/script>/g, "")) 
     2418 
     2419                                                        // Locate the specified elements 
     2420                                                        .find(selector) : 
     2421 
     2422                                                // If not, just inject the full result 
     2423                                                res.responseText ); 
     2424 
     2425                                self.each( callback, [res.responseText, status, res] ); 
     2426                        } 
     2427                }); 
     2428                return this; 
     2429        }, 
     2430 
     2431        serialize: function() { 
     2432                return jQuery.param(this.serializeArray()); 
     2433        }, 
     2434        serializeArray: function() { 
     2435                return this.map(function(){ 
     2436                        return jQuery.nodeName(this, "form") ? 
     2437                                jQuery.makeArray(this.elements) : this; 
     2438                }) 
     2439                .filter(function(){ 
     2440                        return this.name && !this.disabled &&  
     2441                                (this.checked || /select|textarea/i.test(this.nodeName) ||  
     2442                                        /text|hidden|password/i.test(this.type)); 
     2443                }) 
     2444                .map(function(i, elem){ 
     2445                        var val = jQuery(this).val(); 
     2446                        return val == null ? null : 
     2447                                val.constructor == Array ? 
     2448                                        jQuery.map( val, function(val, i){ 
     2449                                                return {name: elem.name, value: val}; 
     2450                                        }) : 
     2451                                        {name: elem.name, value: val}; 
     2452                }).get(); 
     2453        } 
     2454}); 
     2455 
     2456// Attach a bunch of functions for handling common AJAX events 
     2457jQuery.each( "ajaxStart,ajaxStop,ajaxComplete,ajaxError,ajaxSuccess,ajaxSend".split(","), function(i,o){ 
     2458        jQuery.fn[o] = function(f){ 
     2459                return this.bind(o, f); 
     2460        }; 
     2461}); 
     2462 
     2463var jsc = (new Date).getTime(); 
     2464 
     2465jQuery.extend({ 
     2466        get: function( url, data, callback, type ) { 
     2467                // shift arguments if data argument was ommited 
     2468                if ( jQuery.isFunction( data ) ) { 
     2469                        callback = data; 
     2470                        data = null; 
     2471                } 
     2472                 
     2473                return jQuery.ajax({ 
     2474                        type: "GET", 
     2475                        url: url, 
     2476                        data: data, 
     2477                        success: callback, 
     2478                        dataType: type 
     2479                }); 
     2480        }, 
     2481 
     2482        getScript: function( url, callback ) { 
     2483                return jQuery.get(url, null, callback, "script"); 
     2484        }, 
     2485 
     2486        getJSON: function( url, data, callback ) { 
     2487                return jQuery.get(url, data, callback, "json"); 
     2488        }, 
     2489 
     2490        post: function( url, data, callback, type ) { 
     2491                if ( jQuery.isFunction( data ) ) { 
     2492                        callback = data; 
     2493                        data = {}; 
     2494                } 
     2495 
     2496                return jQuery.ajax({ 
     2497                        type: "POST", 
     2498                        url: url, 
     2499                        data: data, 
     2500                        success: callback, 
     2501                        dataType: type 
     2502                }); 
     2503        }, 
     2504 
     2505        ajaxSetup: function( settings ) { 
     2506                jQuery.extend( jQuery.ajaxSettings, settings ); 
     2507        }, 
     2508 
     2509        ajaxSettings: { 
     2510                global: true, 
     2511                type: "GET", 
     2512                timeout: 0, 
     2513                contentType: "application/x-www-form-urlencoded", 
     2514                processData: true, 
     2515                async: true, 
     2516                data: null 
     2517        }, 
     2518         
     2519        // Last-Modified header cache for next request 
     2520        lastModified: {}, 
     2521 
     2522        ajax: function( s ) { 
     2523                var jsonp, jsre = /=\?(&|$)/g, status, data; 
     2524 
     2525                // Extend the settings, but re-extend 's' so that it can be 
     2526                // checked again later (in the test suite, specifically) 
     2527                s = jQuery.extend(true, s, jQuery.extend(true, {}, jQuery.ajaxSettings, s)); 
     2528 
     2529                // convert data if not already a string 
     2530                if ( s.data && s.processData && typeof s.data != "string" ) 
     2531                        s.data = jQuery.param(s.data); 
     2532 
     2533                // Handle JSONP Parameter Callbacks 
     2534                if ( s.dataType == "jsonp" ) { 
     2535                        if ( s.type.toLowerCase() == "get" ) { 
     2536                                if ( !s.url.match(jsre) ) 
     2537                                        s.url += (s.url.match(/\?/) ? "&" : "?") + (s.jsonp || "callback") + "=?"; 
     2538                        } else if ( !s.data || !s.data.match(jsre) ) 
     2539                                s.data = (s.data ? s.data + "&" : "") + (s.jsonp || "callback") + "=?"; 
     2540                        s.dataType = "json"; 
     2541                } 
     2542 
     2543                // Build temporary JSONP function 
     2544                if ( s.dataType == "json" && (s.data && s.data.match(jsre) || s.url.match(jsre)) ) { 
     2545                        jsonp = "jsonp" + jsc++; 
     2546 
     2547                        // Replace the =? sequence both in the query string and the data 
     2548                        if ( s.data ) 
     2549                                s.data = (s.data + "").replace(jsre, "=" + jsonp + "$1"); 
     2550                        s.url = s.url.replace(jsre, "=" + jsonp + "$1"); 
     2551 
     2552                        // We need to make sure 
     2553                        // that a JSONP style response is executed properly 
     2554                        s.dataType = "script"; 
     2555 
     2556                        // Handle JSONP-style loading 
     2557                        window[ jsonp ] = function(tmp){ 
     2558                                data = tmp; 
     2559                                success(); 
     2560                                complete(); 
     2561                                // Garbage collect 
     2562                                window[ jsonp ] = undefined; 
     2563                                try{ delete window[ jsonp ]; } catch(e){} 
     2564                                if ( head ) 
     2565                                        head.removeChild( script ); 
     2566                        }; 
     2567                } 
     2568 
     2569                if ( s.dataType == "script" && s.cache == null ) 
     2570                        s.cache = false; 
     2571 
     2572                if ( s.cache === false && s.type.toLowerCase() == "get" ) { 
     2573                        var ts = (new Date()).getTime(); 
     2574                        // try replacing _= if it is there 
     2575                        var ret = s.url.replace(/(\?|&)_=.*?(&|$)/, "$1_=" + ts + "$2"); 
     2576                        // if nothing was replaced, add timestamp to the end 
     2577                        s.url = ret + ((ret == s.url) ? (s.url.match(/\?/) ? "&" : "?") + "_=" + ts : ""); 
     2578                } 
     2579 
     2580                // If data is available, append data to url for get requests 
     2581                if ( s.data && s.type.toLowerCase() == "get" ) { 
     2582                        s.url += (s.url.match(/\?/) ? "&" : "?") + s.data; 
     2583 
     2584                        // IE likes to send both get and post data, prevent this 
     2585                        s.data = null; 
     2586                } 
     2587 
     2588                // Watch for a new set of requests 
     2589                if ( s.global && ! jQuery.active++ ) 
     2590                        jQuery.event.trigger( "ajaxStart" ); 
     2591 
     2592                // If we're requesting a remote document 
     2593                // and trying to load JSON or Script with a GET 
     2594                if ( (!s.url.indexOf("http") || !s.url.indexOf("//")) && ( s.dataType == "script" || s.dataType =="json" ) && s.type.toLowerCase() == "get" ) { 
     2595                        var head = document.getElementsByTagName("head")[0]; 
     2596                        var script = document.createElement("script"); 
     2597                        script.src = s.url; 
     2598                        if (s.scriptCharset) 
     2599                                script.charset = s.scriptCharset; 
     2600 
     2601                        // Handle Script loading 
     2602                        if ( !jsonp ) { 
     2603                                var done = false; 
     2604 
     2605                                // Attach handlers for all browsers 
     2606                                script.onload = script.onreadystatechange = function(){ 
     2607                                        if ( !done && (!this.readyState ||  
     2608                                                        this.readyState == "loaded" || this.readyState == "complete") ) { 
     2609                                                done = true; 
     2610                                                success(); 
     2611                                                complete(); 
     2612                                                head.removeChild( script ); 
     2613                                        } 
     2614                                }; 
     2615                        } 
     2616 
     2617                        head.appendChild(script); 
     2618 
     2619                        // We handle everything using the script element injection 
     2620                        return undefined; 
     2621                } 
     2622 
     2623                var requestDone = false; 
     2624 
     2625                // Create the request object; Microsoft failed to properly 
     2626                // implement the XMLHttpRequest in IE7, so we use the ActiveXObject when it is available 
     2627                var xml = window.ActiveXObject ? new ActiveXObject("Microsoft.XMLHTTP") : new XMLHttpRequest(); 
     2628 
     2629                // Open the socket 
     2630                xml.open(s.type, s.url, s.async); 
     2631 
     2632                // Need an extra try/catch for cross domain requests in Firefox 3 
     2633                try { 
     2634                        // Set the correct header, if data is being sent 
     2635                        if ( s.data ) 
     2636                                xml.setRequestHeader("Content-Type", s.contentType); 
     2637 
     2638                        // Set the If-Modified-Since header, if ifModified mode. 
     2639                        if ( s.ifModified ) 
     2640                                xml.setRequestHeader("If-Modified-Since", 
     2641                                        jQuery.lastModified[s.url] || "Thu, 01 Jan 1970 00:00:00 GMT" ); 
     2642 
     2643                        // Set header so the called script knows that it's an XMLHttpRequest 
     2644                        xml.setRequestHeader("X-Requested-With", "XMLHttpRequest"); 
     2645                } catch(e){} 
     2646 
     2647                // Allow custom headers/mimetypes 
     2648                if ( s.beforeSend ) 
     2649                        s.beforeSend(xml); 
     2650                         
     2651                if ( s.global ) 
     2652                        jQuery.event.trigger("ajaxSend", [xml, s]); 
     2653 
     2654                // Wait for a response to come back 
     2655                var onreadystatechange = function(isTimeout){ 
     2656                        // The transfer is complete and the data is available, or the request timed out 
     2657                        if ( !requestDone && xml && (xml.readyState == 4 || isTimeout == "timeout") ) { 
     2658                                requestDone = true; 
     2659                                 
     2660                                // clear poll interval 
     2661                                if (ival) { 
     2662                                        clearInterval(ival); 
     2663                                        ival = null; 
     2664                                } 
     2665                                 
     2666                                status = isTimeout == "timeout" && "timeout" || 
     2667                                        !jQuery.httpSuccess( xml ) && "error" || 
     2668                                        s.ifModified && jQuery.httpNotModified( xml, s.url ) && "notmodified" || 
     2669                                        "success"; 
     2670 
     2671                                if ( status == "success" ) { 
     2672                                        // Watch for, and catch, XML document parse errors 
     2673                                        try { 
     2674                                                // process the data (runs the xml through httpData regardless of callback) 
     2675                                                data = jQuery.httpData( xml, s.dataType ); 
     2676                                        } catch(e) { 
     2677                                                status = "parsererror"; 
     2678                                        } 
     2679                                } 
     2680 
     2681                                // Make sure that the request was successful or notmodified 
     2682                                if ( status == "success" ) { 
     2683                                        // Cache Last-Modified header, if ifModified mode. 
     2684                                        var modRes; 
     2685                                        try { 
     2686                                                modRes = xml.getResponseHeader("Last-Modified"); 
     2687                                        } catch(e) {} // swallow exception thrown by FF if header is not available 
     2688         
     2689                                        if ( s.ifModified && modRes ) 
     2690                                                jQuery.lastModified[s.url] = modRes; 
     2691 
     2692                                        // JSONP handles its own success callback 
     2693                                        if ( !jsonp ) 
     2694                                                success();       
     2695                                } else 
     2696                                        jQuery.handleError(s, xml, status); 
     2697 
     2698                                // Fire the complete handlers 
     2699                                complete(); 
     2700 
     2701                                // Stop memory leaks 
     2702                                if ( s.async ) 
     2703                                        xml = null; 
     2704                        } 
     2705                }; 
     2706                 
     2707                if ( s.async ) { 
     2708                        // don't attach the handler to the request, just poll it instead 
     2709                        var ival = setInterval(onreadystatechange, 13);  
     2710 
     2711                        // Timeout checker 
     2712                        if ( s.timeout > 0 ) 
     2713                                setTimeout(function(){ 
     2714                                        // Check to see if the request is still happening 
     2715                                        if ( xml ) { 
     2716                                                // Cancel the request 
     2717                                                xml.abort(); 
     2718         
     2719                                                if( !requestDone ) 
     2720                                                        onreadystatechange( "timeout" ); 
     2721                                        } 
     2722                                }, s.timeout); 
     2723                } 
     2724                         
     2725                // Send the data 
     2726                try { 
     2727                        xml.send(s.data); 
     2728                } catch(e) { 
     2729                        jQuery.handleError(s, xml, null, e); 
     2730                } 
     2731                 
     2732                // firefox 1.5 doesn't fire statechange for sync requests 
     2733                if ( !s.async ) 
     2734                        onreadystatechange(); 
     2735 
     2736                function success(){ 
     2737                        // If a local callback was specified, fire it and pass it the data 
     2738                        if ( s.success ) 
     2739                                s.success( data, status ); 
     2740 
     2741                        // Fire the global callback 
     2742                        if ( s.global ) 
     2743                                jQuery.event.trigger( "ajaxSuccess", [xml, s] ); 
     2744                } 
     2745 
     2746                function complete(){ 
     2747                        // Process result 
     2748                        if ( s.complete ) 
     2749                                s.complete(xml, status); 
     2750 
     2751                        // The request was completed 
     2752                        if ( s.global ) 
     2753                                jQuery.event.trigger( "ajaxComplete", [xml, s] ); 
     2754 
     2755                        // Handle the global AJAX counter 
     2756                        if ( s.global && ! --jQuery.active ) 
     2757                                jQuery.event.trigger( "ajaxStop" ); 
     2758                } 
     2759                 
     2760                // return XMLHttpRequest to allow aborting the request etc. 
     2761                return xml; 
     2762        }, 
     2763 
     2764        handleError: function( s, xml, status, e ) { 
     2765                // If a local callback was specified, fire it 
     2766                if ( s.error ) s.error( xml, status, e ); 
     2767 
     2768                // Fire the global callback 
     2769                if ( s.global ) 
     2770                        jQuery.event.trigger( "ajaxError", [xml, s, e] ); 
     2771        }, 
     2772 
     2773        // Counter for holding the number of active queries 
     2774        active: 0, 
     2775 
     2776        // Determines if an XMLHttpRequest was successful or not 
     2777        httpSuccess: function( r ) { 
     2778                try { 
     2779                        // IE error sometimes returns 1223 when it should be 204 so treat it as success, see #1450 
     2780                        return !r.status && location.protocol == "file:" || 
     2781                                ( r.status >= 200 && r.status < 300 ) || r.status == 304 || r.status == 1223 || 
     2782                                jQuery.browser.safari && r.status == undefined; 
     2783                } catch(e){} 
     2784                return false; 
     2785        }, 
     2786 
     2787        // Determines if an XMLHttpRequest returns NotModified 
     2788        httpNotModified: function( xml, url ) { 
     2789                try { 
     2790                        var xmlRes = xml.getResponseHeader("Last-Modified"); 
     2791 
     2792                        // Firefox always returns 200. check Last-Modified date 
     2793                        return xml.status == 304 || xmlRes == jQuery.lastModified[url] || 
     2794                                jQuery.browser.safari && xml.status == undefined; 
     2795                } catch(e){} 
     2796                return false; 
     2797        }, 
     2798 
     2799        httpData: function( r, type ) { 
     2800                var ct = r.getResponseHeader("content-type"); 
     2801                var xml = type == "xml" || !type && ct && ct.indexOf("xml") >= 0; 
     2802                var data = xml ? r.responseXML : r.responseText; 
     2803 
     2804                if ( xml && data.documentElement.tagName == "parsererror" ) 
     2805                        throw "parsererror"; 
     2806 
     2807                // If the type is "script", eval it in global context 
     2808                if ( type == "script" ) 
     2809                        jQuery.globalEval( data ); 
     2810 
     2811                // Get the JavaScript object, if JSON is used. 
     2812                if ( type == "json" ) 
     2813                        data = eval("(" + data + ")"); 
     2814 
     2815                return data; 
     2816        }, 
     2817 
     2818        // Serialize an array of form elements or a set of 
     2819        // key/values into a query string 
     2820        param: function( a ) { 
     2821                var s = []; 
     2822 
     2823                // If an array was passed in, assume that it is an array 
     2824                // of form elements 
     2825                if ( a.constructor == Array || a.jquery ) 
     2826                        // Serialize the form elements 
     2827                        jQuery.each( a, function(){ 
     2828                                s.push( encodeURIComponent(this.name) + "=" + encodeURIComponent( this.value ) ); 
     2829                        }); 
     2830 
     2831                // Otherwise, assume that it's an object of key/value pairs 
     2832                else 
     2833                        // Serialize the key/values 
     2834                        for ( var j in a ) 
     2835                                // If the value is an array then the key names need to be repeated 
     2836                                if ( a[j] && a[j].constructor == Array ) 
     2837                                        jQuery.each( a[j], function(){ 
     2838                                                s.push( encodeURIComponent(j) + "=" + encodeURIComponent( this ) ); 
     2839                                        }); 
     2840                                else 
     2841                                        s.push( encodeURIComponent(j) + "=" + encodeURIComponent( a[j] ) ); 
     2842 
     2843                // Return the resulting serialization 
     2844                return s.join("&").replace(/%20/g, "+"); 
     2845        } 
     2846 
     2847}); 
     2848jQuery.fn.extend({ 
     2849        show: function(speed,callback){ 
     2850                return speed ? 
     2851                        this.animate({ 
     2852                                height: "show", width: "show", opacity: "show" 
     2853                        }, speed, callback) : 
     2854                         
     2855                        this.filter(":hidden").each(function(){ 
     2856                                this.style.display = this.oldblock || ""; 
     2857                                if ( jQuery.css(this,"display") == "none" ) { 
     2858                                        var elem = jQuery("<" + this.tagName + " />").appendTo("body"); 
     2859                                        this.style.display = elem.css("display"); 
     2860                                        elem.remove(); 
     2861                                } 
     2862                        }).end(); 
     2863        }, 
     2864         
     2865        hide: function(speed,callback){ 
     2866                return speed ? 
     2867                        this.animate({ 
     2868                                height: "hide", width: "hide", opacity: "hide" 
     2869                        }, speed, callback) : 
     2870                         
     2871                        this.filter(":visible").each(function(){ 
     2872                                this.oldblock = this.oldblock || jQuery.css(this,"display"); 
     2873                                this.style.display = "none"; 
     2874                        }).end(); 
     2875        }, 
     2876 
     2877        // Save the old toggle function 
     2878        _toggle: jQuery.fn.toggle, 
     2879         
     2880        toggle: function( fn, fn2 ){ 
     2881                return jQuery.isFunction(fn) && jQuery.isFunction(fn2) ? 
     2882                        this._toggle( fn, fn2 ) : 
     2883                        fn ? 
     2884                                this.animate({ 
     2885                                        height: "toggle", width: "toggle", opacity: "toggle" 
     2886                                }, fn, fn2) : 
     2887                                this.each(function(){ 
     2888                                        jQuery(this)[ jQuery(this).is(":hidden") ? "show" : "hide" ](); 
     2889                                }); 
     2890        }, 
     2891         
     2892        slideDown: function(speed,callback){ 
     2893                return this.animate({height: "show"}, speed, callback); 
     2894        }, 
     2895         
     2896        slideUp: function(speed,callback){ 
     2897                return this.animate({height: "hide"}, speed, callback); 
     2898        }, 
     2899 
     2900        slideToggle: function(speed, callback){ 
     2901                return this.animate({height: "toggle"}, speed, callback); 
     2902        }, 
     2903         
     2904        fadeIn: function(speed, callback){ 
     2905                return this.animate({opacity: "show"}, speed, callback); 
     2906        }, 
     2907         
     2908        fadeOut: function(speed, callback){ 
     2909                return this.animate({opacity: "hide"}, speed, callback); 
     2910        }, 
     2911         
     2912        fadeTo: function(speed,to,callback){ 
     2913                return this.animate({opacity: to}, speed, callback); 
     2914        }, 
     2915         
     2916        animate: function( prop, speed, easing, callback ) { 
     2917                var optall = jQuery.speed(speed, easing, callback); 
     2918 
     2919                return this[ optall.queue === false ? "each" : "queue" ](function(){ 
     2920                        if ( this.nodeType != 1) 
     2921                                return false; 
     2922 
     2923                        var opt = jQuery.extend({}, optall); 
     2924                        var hidden = jQuery(this).is(":hidden"), self = this; 
     2925                         
     2926                        for ( var p in prop ) { 
     2927                                if ( prop[p] == "hide" && hidden || prop[p] == "show" && !hidden ) 
     2928                                        return jQuery.isFunction(opt.complete) && opt.complete.apply(this); 
     2929 
     2930                                if ( p == "height" || p == "width" ) { 
     2931                                        // Store display property 
     2932                                        opt.display = jQuery.css(this, "display"); 
     2933 
     2934                                        // Make sure that nothing sneaks out 
     2935                                        opt.overflow = this.style.overflow; 
     2936                                } 
     2937                        } 
     2938 
     2939                        if ( opt.overflow != null ) 
     2940                                this.style.overflow = "hidden"; 
     2941 
     2942                        opt.curAnim = jQuery.extend({}, prop); 
     2943                         
     2944                        jQuery.each( prop, function(name, val){ 
     2945                                var e = new jQuery.fx( self, opt, name ); 
     2946 
     2947                                if ( /toggle|show|hide/.test(val) ) 
     2948                                        e[ val == "toggle" ? hidden ? "show" : "hide" : val ]( prop ); 
     2949                                else { 
     2950                                        var parts = val.toString().match(/^([+-]=)?([\d+-.]+)(.*)$/), 
     2951                                                start = e.cur(true) || 0; 
     2952 
     2953                                        if ( parts ) { 
     2954                                                var end = parseFloat(parts[2]), 
     2955                                                        unit = parts[3] || "px"; 
     2956 
     2957                                                // We need to compute starting value 
     2958                                                if ( unit != "px" ) { 
     2959                                                        self.style[ name ] = (end || 1) + unit; 
     2960                                                        start = ((end || 1) / e.cur(true)) * start; 
     2961                                                        self.style[ name ] = start + unit; 
     2962                                                } 
     2963 
     2964                                                // If a +=/-= token was provided, we're doing a relative animation 
     2965                                                if ( parts[1] ) 
     2966                                                        end = ((parts[1] == "-=" ? -1 : 1) * end) + start; 
     2967 
     2968                                                e.custom( start, end, unit ); 
     2969                                        } else 
     2970                                                e.custom( start, val, "" ); 
     2971                                } 
     2972                        }); 
     2973 
     2974                        // For JS strict compliance 
     2975                        return true; 
     2976                }); 
     2977        }, 
     2978         
     2979        queue: function(type, fn){ 
     2980                if ( jQuery.isFunction(type) || ( type && type.constructor == Array )) { 
     2981                        fn = type; 
     2982                        type = "fx"; 
     2983                } 
     2984 
     2985                if ( !type || (typeof type == "string" && !fn) ) 
     2986                        return queue( this[0], type ); 
     2987 
     2988                return this.each(function(){ 
     2989                        if ( fn.constructor == Array ) 
     2990                                queue(this, type, fn); 
     2991                        else { 
     2992                                queue(this, type).push( fn ); 
     2993                         
     2994                                if ( queue(this, type).length == 1 ) 
     2995                                        fn.apply(this); 
     2996                        } 
     2997                }); 
     2998        }, 
     2999 
     3000        stop: function(clearQueue, gotoEnd){ 
     3001                var timers = jQuery.timers; 
     3002 
     3003                if (clearQueue) 
     3004                        this.queue([]); 
     3005 
     3006                this.each(function(){ 
     3007                        // go in reverse order so anything added to the queue during the loop is ignored 
     3008                        for ( var i = timers.length - 1; i >= 0; i-- ) 
     3009                                if ( timers[i].elem == this ) { 
     3010                                        if (gotoEnd) 
     3011                                                // force the next step to be the last 
     3012                                                timers[i](true); 
     3013                                        timers.splice(i, 1); 
     3014                                } 
     3015                }); 
     3016 
     3017                // start the next in the queue if the last step wasn't forced 
     3018                if (!gotoEnd) 
     3019                        this.dequeue(); 
     3020 
     3021                return this; 
     3022        } 
     3023 
     3024}); 
     3025 
     3026var queue = function( elem, type, array ) { 
     3027        if ( !elem ) 
     3028                return undefined; 
     3029 
     3030        type = type || "fx"; 
     3031 
     3032        var q = jQuery.data( elem, type + "queue" ); 
     3033 
     3034        if ( !q || array ) 
     3035                q = jQuery.data( elem, type + "queue",  
     3036                        array ? jQuery.makeArray(array) : [] ); 
     3037 
     3038        return q; 
     3039}; 
     3040 
     3041jQuery.fn.dequeue = function(type){ 
     3042        type = type || "fx"; 
     3043 
     3044        return this.each(function(){ 
     3045                var q = queue(this, type); 
     3046 
     3047                q.shift(); 
     3048 
     3049                if ( q.length ) 
     3050                        q[0].apply( this ); 
     3051        }); 
     3052}; 
     3053 
     3054jQuery.extend({ 
     3055         
     3056        speed: function(speed, easing, fn) { 
     3057                var opt = speed && speed.constructor == Object ? speed : { 
     3058                        complete: fn || !fn && easing ||  
     3059                                jQuery.isFunction( speed ) && speed, 
     3060                        duration: speed, 
     3061                        easing: fn && easing || easing && easing.constructor != Function && easing 
     3062                }; 
     3063 
     3064                opt.duration = (opt.duration && opt.duration.constructor == Number ?  
     3065                        opt.duration :  
     3066                        { slow: 600, fast: 200 }[opt.duration]) || 400; 
     3067         
     3068                // Queueing 
     3069                opt.old = opt.complete; 
     3070                opt.complete = function(){ 
     3071                        if ( opt.queue !== false ) 
     3072                                jQuery(this).dequeue(); 
     3073                        if ( jQuery.isFunction( opt.old ) ) 
     3074                                opt.old.apply( this ); 
     3075                }; 
     3076         
     3077                return opt; 
     3078        }, 
     3079         
     3080        easing: { 
     3081                linear: function( p, n, firstNum, diff ) { 
     3082                        return firstNum + diff * p; 
     3083                }, 
     3084                swing: function( p, n, firstNum, diff ) { 
     3085                        return ((-Math.cos(p*Math.PI)/2) + 0.5) * diff + firstNum; 
     3086                } 
     3087        }, 
     3088         
     3089        timers: [], 
     3090        timerId: null, 
     3091 
     3092        fx: function( elem, options, prop ){ 
     3093                this.options = options; 
     3094                this.elem = elem; 
     3095                this.prop = prop; 
     3096 
     3097                if ( !options.orig ) 
     3098                        options.orig = {}; 
     3099        } 
     3100 
     3101}); 
     3102 
     3103jQuery.fx.prototype = { 
     3104 
     3105        // Simple function for setting a style value 
     3106        update: function(){ 
     3107                if ( this.options.step ) 
     3108                        this.options.step.apply( this.elem, [ this.now, this ] ); 
     3109 
     3110                (jQuery.fx.step[this.prop] || jQuery.fx.step._default)( this ); 
     3111 
     3112                // Set display property to block for height/width animations 
     3113                if ( this.prop == "height" || this.prop == "width" ) 
     3114                        this.elem.style.display = "block"; 
     3115        }, 
     3116 
     3117        // Get the current size 
     3118        cur: function(force){ 
     3119                if ( this.elem[this.prop] != null && this.elem.style[this.prop] == null ) 
     3120                        return this.elem[ this.prop ]; 
     3121 
     3122                var r = parseFloat(jQuery.css(this.elem, this.prop, force)); 
     3123                return r && r > -10000 ? r : parseFloat(jQuery.curCSS(this.elem, this.prop)) || 0; 
     3124        }, 
     3125 
     3126        // Start an animation from one number to another 
     3127        custom: function(from, to, unit){ 
     3128                this.startTime = (new Date()).getTime(); 
     3129                this.start = from; 
     3130                this.end = to; 
     3131                this.unit = unit || this.unit || "px"; 
     3132                this.now = this.start; 
     3133                this.pos = this.state = 0; 
     3134                this.update(); 
     3135 
     3136                var self = this; 
     3137                function t(gotoEnd){ 
     3138                        return self.step(gotoEnd); 
     3139                } 
     3140 
     3141                t.elem = this.elem; 
     3142 
     3143                jQuery.timers.push(t); 
     3144 
     3145                if ( jQuery.timerId == null ) { 
     3146                        jQuery.timerId = setInterval(function(){ 
     3147                                var timers = jQuery.timers; 
     3148                                 
     3149                                for ( var i = 0; i < timers.length; i++ ) 
     3150                                        if ( !timers[i]() ) 
     3151                                                timers.splice(i--, 1); 
     3152 
     3153                                if ( !timers.length ) { 
     3154                                        clearInterval( jQuery.timerId ); 
     3155                                        jQuery.timerId = null; 
     3156                                } 
     3157                        }, 13); 
     3158                } 
     3159        }, 
     3160 
     3161        // Simple 'show' function 
     3162        show: function(){ 
     3163                // Remember where we started, so that we can go back to it later 
     3164                this.options.orig[this.prop] = jQuery.attr( this.elem.style, this.prop ); 
     3165                this.options.show = true; 
     3166 
     3167                // Begin the animation 
     3168                this.custom(0, this.cur()); 
     3169 
     3170                // Make sure that we start at a small width/height to avoid any 
     3171                // flash of content 
     3172                if ( this.prop == "width" || this.prop == "height" ) 
     3173                        this.elem.style[this.prop] = "1px"; 
     3174                 
     3175                // Start by showing the element 
     3176                jQuery(this.elem).show(); 
     3177        }, 
     3178 
     3179        // Simple 'hide' function 
     3180        hide: function(){ 
     3181                // Remember where we started, so that we can go back to it later 
     3182                this.options.orig[this.prop] = jQuery.attr( this.elem.style, this.prop ); 
     3183                this.options.hide = true; 
     3184 
     3185                // Begin the animation 
     3186                this.custom(this.cur(), 0); 
     3187        }, 
     3188 
     3189        // Each step of an animation 
     3190        step: function(gotoEnd){ 
     3191                var t = (new Date()).getTime(); 
     3192 
     3193                if ( gotoEnd || t > this.options.duration + this.startTime ) { 
     3194                        this.now = this.end; 
     3195                        this.pos = this.state = 1; 
     3196                        this.update(); 
     3197 
     3198                        this.options.curAnim[ this.prop ] = true; 
     3199 
     3200                        var done = true; 
     3201                        for ( var i in this.options.curAnim ) 
     3202                                if ( this.options.curAnim[i] !== true ) 
     3203                                        done = false; 
     3204 
     3205                        if ( done ) { 
     3206                                if ( this.options.display != null ) { 
     3207                                        // Reset the overflow 
     3208                                        this.elem.style.overflow = this.options.overflow; 
     3209                                 
     3210                                        // Reset the display 
     3211                                        this.elem.style.display = this.options.display; 
     3212                                        if ( jQuery.css(this.elem, "display") == "none" ) 
     3213                                                this.elem.style.display = "block"; 
     3214                                } 
     3215 
     3216                                // Hide the element if the "hide" operation was done 
     3217                                if ( this.options.hide ) 
     3218                                        this.elem.style.display = "none"; 
     3219 
     3220                                // Reset the properties, if the item has been hidden or shown 
     3221                                if ( this.options.hide || this.options.show ) 
     3222                                        for ( var p in this.options.curAnim ) 
     3223                                                jQuery.attr(this.elem.style, p, this.options.orig[p]); 
     3224                        } 
     3225 
     3226                        // If a callback was provided, execute it 
     3227                        if ( done && jQuery.isFunction( this.options.complete ) ) 
     3228                                // Execute the complete function 
     3229                                this.options.complete.apply( this.elem ); 
     3230 
     3231                        return false; 
     3232                } else { 
     3233                        var n = t - this.startTime; 
     3234                        this.state = n / this.options.duration; 
     3235 
     3236                        // Perform the easing function, defaults to swing 
     3237                        this.pos = jQuery.easing[this.options.easing || (jQuery.easing.swing ? "swing" : "linear")](this.state, n, 0, 1, this.options.duration); 
     3238                        this.now = this.start + ((this.end - this.start) * this.pos); 
     3239 
     3240                        // Perform the next step of the animation 
     3241                        this.update(); 
     3242                } 
     3243 
     3244                return true; 
     3245        } 
     3246 
     3247}; 
     3248 
     3249jQuery.fx.step = { 
     3250        scrollLeft: function(fx){ 
     3251                fx.elem.scrollLeft = fx.now; 
     3252        }, 
     3253 
     3254        scrollTop: function(fx){ 
     3255                fx.elem.scrollTop = fx.now; 
     3256        }, 
     3257 
     3258        opacity: function(fx){ 
     3259                jQuery.attr(fx.elem.style, "opacity", fx.now); 
     3260        }, 
     3261 
     3262        _default: function(fx){ 
     3263                fx.elem.style[ fx.prop ] = fx.now + fx.unit; 
     3264        } 
     3265}; 
     3266// The Offset Method 
     3267// Originally By Brandon Aaron, part of the Dimension Plugin 
     3268// http://jquery.com/plugins/project/dimensions 
     3269jQuery.fn.offset = function() { 
     3270        var left = 0, top = 0, elem = this[0], results; 
     3271         
     3272        if ( elem ) with ( jQuery.browser ) { 
     3273                var parent       = elem.parentNode,  
     3274                    offsetChild  = elem, 
     3275                    offsetParent = elem.offsetParent,  
     3276                    doc          = elem.ownerDocument, 
     3277                    safari2      = safari && parseInt(version) < 522, 
     3278                    fixed        = jQuery.css(elem, "position") == "fixed"; 
     3279         
     3280                // Use getBoundingClientRect if available 
     3281                if ( elem.getBoundingClientRect ) { 
     3282                        var box = elem.getBoundingClientRect(); 
     3283                 
     3284                        // Add the document scroll offsets 
     3285                        add(box.left + Math.max(doc.documentElement.scrollLeft, doc.body.scrollLeft), 
     3286                                box.top  + Math.max(doc.documentElement.scrollTop,  doc.body.scrollTop)); 
     3287                 
     3288                        // IE adds the HTML element's border, by default it is medium which is 2px 
     3289                        // IE 6 and 7 quirks mode the border width is overwritable by the following css html { border: 0; } 
     3290                        // IE 7 standards mode, the border is always 2px 
     3291                        // This border/offset is typically represented by the clientLeft and clientTop properties 
     3292                        // However, in IE6 and 7 quirks mode the clientLeft and clientTop properties are not updated when overwriting it via CSS 
     3293                        // Therefore this method will be off by 2px in IE while in quirksmode 
     3294                        add( -doc.documentElement.clientLeft, -doc.documentElement.clientTop ); 
     3295         
     3296                // Otherwise loop through the offsetParents and parentNodes 
     3297                } else { 
     3298                 
     3299                        // Initial element offsets 
     3300                        add( elem.offsetLeft, elem.offsetTop ); 
     3301                         
     3302                        // Get parent offsets 
     3303                        while ( offsetParent ) { 
     3304                                // Add offsetParent offsets 
     3305                                add( offsetParent.offsetLeft, offsetParent.offsetTop ); 
     3306                         
     3307                                // Mozilla and Safari > 2 does not include the border on offset parents 
     3308                                // However Mozilla adds the border for table or table cells 
     3309                                if ( mozilla && !/^t(able|d|h)$/i.test(offsetParent.tagName) || safari && !safari2 ) 
     3310                                        border( offsetParent ); 
     3311                                         
     3312                                // Add the document scroll offsets if position is fixed on any offsetParent 
     3313                                if ( !fixed && jQuery.css(offsetParent, "position") == "fixed" ) 
     3314                                        fixed = true; 
     3315                         
     3316                                // Set offsetChild to previous offsetParent unless it is the body element 
     3317                                offsetChild  = /^body$/i.test(offsetParent.tagName) ? offsetChild : offsetParent; 
     3318                                // Get next offsetParent 
     3319                                offsetParent = offsetParent.offsetParent; 
     3320                        } 
     3321                 
     3322                        // Get parent scroll offsets 
     3323                        while ( parent && parent.tagName && !/^body|html$/i.test(parent.tagName) ) { 
     3324                                // Remove parent scroll UNLESS that parent is inline or a table to work around Opera inline/table scrollLeft/Top bug 
     3325                                if ( !/^inline|table.*$/i.test(jQuery.css(parent, "display")) ) 
     3326                                        // Subtract parent scroll offsets 
     3327                                        add( -parent.scrollLeft, -parent.scrollTop ); 
     3328                         
     3329                                // Mozilla does not add the border for a parent that has overflow != visible 
     3330                                if ( mozilla && jQuery.css(parent, "overflow") != "visible" ) 
     3331                                        border( parent ); 
     3332                         
     3333                                // Get next parent 
     3334                                parent = parent.parentNode; 
     3335                        } 
     3336                 
     3337                        // Safari <= 2 doubles body offsets with a fixed position element/offsetParent or absolutely positioned offsetChild 
     3338                        // Mozilla doubles body offsets with a non-absolutely positioned offsetChild 
     3339                        if ( (safari2 && (fixed || jQuery.css(offsetChild, "position") == "absolute")) ||  
     3340                                (mozilla && jQuery.css(offsetChild, "position") != "absolute") ) 
     3341                                        add( -doc.body.offsetLeft, -doc.body.offsetTop ); 
     3342                         
     3343                        // Add the document scroll offsets if position is fixed 
     3344                        if ( fixed ) 
     3345                                add(Math.max(doc.documentElement.scrollLeft, doc.body.scrollLeft), 
     3346                                        Math.max(doc.documentElement.scrollTop,  doc.body.scrollTop)); 
     3347                } 
     3348 
     3349                // Return an object with top and left properties 
     3350                results = { top: top, left: left }; 
     3351        } 
     3352 
     3353        function border(elem) { 
     3354                add( jQuery.curCSS(elem, "borderLeftWidth", true), jQuery.curCSS(elem, "borderTopWidth", true) ); 
     3355        } 
     3356 
     3357        function add(l, t) { 
     3358                left += parseInt(l) || 0; 
     3359                top += parseInt(t) || 0; 
     3360        } 
     3361 
     3362        return results; 
     3363}; 
     3364})(); 
    123365jQuery.noConflict(); 
  • wp-includes/script-loader.php

     
    7777 
    7878                $this->add( 'cropper', '/wp-includes/js/crop/cropper.js', array('scriptaculous-dragdrop'), '20070118'); 
    7979 
    80                 $this->add( 'jquery', '/wp-includes/js/jquery/jquery.js', false, '1.1.4'); 
     80                $this->add( 'jquery', '/wp-includes/js/jquery/jquery.js', false, '1.2.2b2'); 
    8181                $this->add( 'jquery-form', '/wp-includes/js/jquery/jquery.form.js', array('jquery'), '1.0.3'); 
    8282                $this->add( 'interface', '/wp-includes/js/jquery/interface.js', array('jquery'), '1.2'); 
    8383