include("lib.prototype"); if (!modularjs.loaded["lib.shiftzoom.shiftzoom"]) { /** * shiftzoom.js 3.7 (06-Oct-2010) (c) by Christian Effenberger * All Rights Reserved. Source: shiftzoom.netzgesta.de * Distributed under Netzgestade Software License Agreement. * This license permits free of charge use on non-commercial * and private web sites only under special conditions. * Read more at... http://www.netzgesta.de/cvi/LICENSE.txt * * syntax: shiftzoom.defaultFading = true; //BOOLEAN startup fading shiftzoom.defaultButtons = true; //BOOLEAN left top info & zoom buttons shiftzoom.defaultNozoom = false; //BOOLEAN disable zooming feature shiftzoom.defaultBicubic = false; //BOOLEAN enable MS bicubic image interpolation mode for IE7+ shiftzoom.defaultZoom = 0; //INT/FLOAT 0-100 (%) zooming percentage shiftzoom.defaultXpos = 50; //INT/FLOAT 0-100 (%) horizontal position shiftzoom.defaultYpos = 50; //INT/FLOAT 0-100 (%) vertical position shiftzoom.defaultOpacity = 90; //INT 0-100 (%) zoom button opacity shiftzoom.defaultMillisec = 40; //INT 5-100 zoom interval delay shiftzoom.defaultIntitle = ''; //STR 'click or press shift key to zoom in' shiftzoom.defaultOuttitle = ''; //STR 'click or press alt key to zoom out' shiftzoom.defaultInfoblock = ''; //STR '
Mouseover Keyboard Support<\/big><\/div>
Zoom in:<\/dt>
[+] / [PgDn] / [End] (is faster)<\/em> /
[shift] + left mouse button /
middle / wheel mouse button /
mouse wheel down

<\/small><\/dd>
Zoom out:<\/dt>
[–] / [PgUp] / [Home] (is faster)<\/em> /
[alt] + left mouse button /
right mouse button /
mouse wheel up

<\/small><\/dd>
Pan / Shift / Move:<\/dt>
[left] / [right] / [down] / [up] arrow buttons
+ [shift] (is faster) and + [alt] (is slower)<\/em><\/dd><\/dl>' shiftzoom.defaultCurpath = ''; //STR cursor path (*.cur) IE only shiftzoom.defaultLowres = ''; //STR lowres image (dimension should equal elements width and height) shiftzoom.defaultIcons = null; //OBJ icon array (see shiftzoom.construct) shiftzoom.defaultShowcoords = false;//BOOLEAN show coordinates shiftzoom.defaultRelativecoords = false;//BOOLEAN Pixel coordinates are relative instead of absolute shiftzoom.defaultPixelcoords = true;//BOOLEAN Pixel instead of Latitude/Longitude coordinates shiftzoom.defaultPercentcoords=false;//BOOLEAN Percentage instead of Lat/Lon/Pixel coordinates shiftzoom.defaultForcetouchui=false;//BOOLEAN Forces touch UI over the mouse UI if both available shiftzoom.defaultOverview = true; //BOOLEAN show overview shiftzoom.defaultOvsfact = 25; //INT 10-50 (%) overview size percentage shiftzoom.defaultOvaopac = 75; //INT 0-100 (%) overview area opacity shiftzoom.defaultOvacolor = 'red'; //STR overview area css color shiftzoom.defaultOvbcolor = 'white';//STR overview border css color shiftzoom.defaultOvborder = ''; //INT 0-20 (px) or "" overview border width shiftzoom.add( image, options ); shiftzoom.add( image, { fading: value, buttons: value, nozoom: value, zoom: value, xpos: value, ypos: value, overview: value, curpath: value, intitle: value, outtitle: value, millisec: value, ovaopac: value, opacity: value, ovborder: value, ovacolor: value, ovbcolor: value, ovsfact: value } ); shiftzoom.remove( image, value ); //BOOLEAN reset to max image width/height shiftzoom.source( image, URI, value ); //BOOLEAN with fading shiftzoom.lowsource( image, URI ); shiftzoom.set( image, ['buttons'|'overview'|'showcoords'|'relativecoords'|'pixelcoords'|'percentcoords'|'zoomin'|'zoomout'|'nozoom'], [true|false] ); INT=shiftzoom.get( image, ['maxzoomx'|'maxzoomy'|'maxwidth'|'maxheight'] ); BOL=shiftzoom.get( image, 'playing' ); OBJ=shiftzoom.get( image, 'currentxyz' );//returns current x=Xpos, y=Ypos and z=Zoom as INT/FLOAT 0-100 (%) FLT=shiftzoom.version; STR=shiftzoom.released; shiftzoom.zooming( image, value ); //INT 0 - 100 (%) zoom factor (e.g. 33.33) shiftzoom.moveto( image, x, y ); //INT x|y from within natural image dimension (e.g. 400,297) or //STR Lon|Lat (e.g. '52.04','-23.4405') or //STR %|% (e.g. '50%','50%') shiftzoom.kenburns( image, [x, y, z, e, s, d, callback, arg] ); //INT x|y|z 0 - 100 (%) move/zoom factor //FLT 0-2|3 e == progression [< 1 == ease-out | 1 == linear | > 1 == ease-in | 3 == ease-in-out] (default: 1) optional (set to false for default value if you want to use callback) //INT 10-100 s equals animation steps (default: auto equals max distance/interval delay) optional (set to false for default value if you want to use callback) //INT 10-100 d equals interval delay (default: 30) optional (set to false for default value if you want to use callback) //STR callback function name (executes on end playing) //STR arg callback function argument shiftzoom.play( image, delay, loop, array, callback ); //INT delay between anims (millisec) //BOOLEAN endless loop or once //OBJ two dimensional Array [[x,y,z,e,s,d], [x,y,z,e,s,d]...] (syntax like kenburns) //STR callback function name (executes on stop playing) shiftzoom.stop( image ); //stop auto playing shiftzoom.construct( image, object ); //create icon object(s) object = [{x:INT, y:INT, w:INT, h:INT, pos:INT, noscale:BOL, id:'STR', href:'STR', target:'STR', title:'STR', src:'STR', src2:'STR'}, {...}] pos equals 1=left-top, 2=center-top, 3=right-top, 4=center-left, 0/5=center, 6=center-right, 7=left-bottom, 8=center-bottom, 9=right-bottom if noscale is true (fixed icon dimensions), pos equals always left-top shiftzoom.destruct( image, id|true ); //delete named or all icon(s) * **/ var cvi_szclback, cvi_sztimer, cvi_szactive, cvi_szimage=null, shiftzoom = { _shiftzoom : null, version : 3.7, released : '2010-10-06 12:00:00', defaultFading : true, defaultButtons : true, defaultOverview : true, defaultNozoom : false, defaultIcons : null, defaultBicubic : false, defaultForcetouchui : false, defaultShowcoords : false, defaultPixelcoords : true, defaultRelativecoords : false, defaultPercentcoords : false, defaultLowres : '', defaultMillisec : 40, defaultOpacity : 90, defaultOvsfact : 25, defaultOvaopac : 75, defaultOvacolor : 'red', defaultOvbcolor : 'white', defaultIntitle : 'click or press shift key to zoom in', defaultOuttitle : 'click or press alt key to zoom out', defaultInfoblock : '
Mouseover Keyboard Support<\/big><\/div>
Zoom in:<\/dt>
[+] / [PgDn] / [End] (is faster)<\/em> /
[shift] + left mouse button /
double click + left mouse button /
middle / wheel mouse button /
mouse wheel down

<\/small><\/dd>
Zoom out:<\/dt>
[–] / [PgUp] / [Home] (is faster)<\/em> /
[alt] + left mouse button /
right mouse button /
mouse wheel up

<\/small><\/dd>
Pan / Shift / Move:<\/dt>
[left] / [right] / [down] / [up] arrow buttons
+ [shift] (is faster) and + [alt] (is slower)<\/em><\/dd><\/dl>', defaultOvborder : '', defaultCurpath : '', defaultZoom : 0, defaultXpos : 50, defaultYpos : 50, gif : "", add : function(ele,opts) { function roundTo(val,dig) {var num=val; if(val>8191&&val<10485) {val=val-5000; num=Math.round(val*Math.pow(10,dig))/Math.pow(10,dig); num=num+5000;}else {num=Math.round(val*Math.pow(10,dig))/Math.pow(10,dig);} return num;} function uniqueID() {var val=Date.parse(new Date())+Math.floor(Math.random()*100000000000); return val.toString(16);} function boxShadow() {var bs=false,mbs=false,kbs=false,wbs=false; try {bs=(document.body.style.boxShadow!==undefined);}catch(e) {} try {mbs=(document.body.style.MozBoxShadow!==undefined);}catch(e) {} try {kbs=(document.body.style.KhtmlBoxShadow!==undefined);}catch(e) {} try {wbs=(document.body.style.WebkitBoxShadow!==undefined);}catch(e) {} return (bs||mbs||kbs||wbs?true:false);} if(!ele.active) {ele.style.visibility="hidden"; var defopts={"curpath" : shiftzoom.defaultCurpath, "opacity" : shiftzoom.defaultOpacity, "millisec" : shiftzoom.defaultMillisec, "intitle" : shiftzoom.defaultIntitle, "outtitle" : shiftzoom.defaultOuttitle, "infoblock" : shiftzoom.defaultInfoblock, "ovsfact" : shiftzoom.defaultOvsfact, "ovaopac" : shiftzoom.defaultOvaopac, "ovacolor" : shiftzoom.defaultOvacolor, "ovbcolor" : shiftzoom.defaultOvbcolor, "zoom" : shiftzoom.defaultZoom, "xpos" : shiftzoom.defaultXpos, "ypos" : shiftzoom.defaultYpos, "lowres" : shiftzoom.defaultLowres, "icons" : shiftzoom.defaultIcons, "bicubic" : shiftzoom.defaultBicubic, "forcetouchui" : shiftzoom.defaultForcetouchui}; if(opts) {for(var i in defopts){if(!opts[i]){opts[i]=defopts[i];}}}else{opts=defopts;} if(document.images&&document.createElement&&document.getElementById&&document.getElementsByTagName) { var st,over,view,div=ele.parentNode,img=shiftzoom.E('div'),xref=shiftzoom.E('img'),outer=shiftzoom.E('div'); img.xid=(ele.id!=""?ele.id:ele.id=uniqueID()); div.appendChild(outer); outer.id=img.xid+'_wrap'; outer.appendChild(xref); outer.appendChild(img); img.wrapid=outer.id; img.opts=defopts; img.highres=ele.src; if(ele.naturalWidth && ele.naturalHeight) {img.xfactor=roundTo(ele.naturalWidth/ele.width,4); img.yfactor=roundTo(ele.naturalHeight/ele.height,4); img.maxwidth=ele.naturalWidth*2; img.maxheight=ele.naturalHeight*2;} else {var tmp=new Image; tmp.src=ele.src; img.xfactor=roundTo(tmp.width/ele.width,4); img.yfactor=roundTo(tmp.height/ele.height,4); img.maxwidth=tmp.width*2; img.maxheight=tmp.height*2; tmp=null; delete tmp;} if(ele.width>=100&&ele.width=100&&ele.height=9) {st.background="url("+shiftzoom.gif+") transparent";} st.left='0px'; st.top='0px'; st.width='100%'; st.height='100%'; st.cursor="crosshair"; img.pointer=st.cursor; img.minwidth=outer.width; img.hasmoved=false; img.lasttap=0; img.minheight=outer.height; img.maxleft=img.maxwidth-img.minwidth; img.maxtop=img.maxheight-img.minheight; ele.id=""; outer.parentNode.removeChild(ele); img.id=img.xid;img.aos=navigator.userAgent.match(/android/i);img.ios=navigator.platform.match(/iPad|iPhone|iPod/i); img.stg=typeof(document.ontouchstart)!="undefined"?true:false;img.mtg=typeof(document.ongesturestart)!="undefined"?true:false;img.tod=img.stg&&(img.ios||img.aos||img.forcetouchui)?true:false;if(img.tod) {img.buttons=false; img.showcoords=false;} img.trident=document.all&&!window.opera&&(!document.documentMode||document.documentMode<9)?1:0; img.chakra=document.all&&document.documentMode&&document.documentMode>=9?1:0; img.notrans=img.trident&&!window.XMLHttpRequest?1:0; if(img.fading) {if(img.trident) {outer.style.filter="alpha(opacity=0)";}else{outer.style.opacity=0;}} outer.style.visibility='visible'; img.webkit=window.atob!=undefined&&!window.updateCommands&&!window.opera?1:0; img.divbug=!img.webkit&&navigator.userAgent.indexOf('WebKit')>-1?1:0; img.gecko=navigator.userAgent.indexOf('Gecko')>-1&&window.updateCommands&&!window.opera?1:0; img.presto=window.opera?1:0; img.bshadow=boxShadow(); img.bmode=(img.trident&&(document.compatMode=='BackCompat'||document.compatMode=='QuirksMode')?true:false); img.active=true; over=shiftzoom.E('img'); over.src=img.trident?null:null; over.style.display='none'; over.id=img.id+'_isrc'; div.appendChild(over); img.isrcid=over.id; over=shiftzoom.E('div'); over.id=img.id+'_xyco'; st=over.style; if(img.trident) {st.backgroundColor='black';} st.height='auto'; st.width='auto'; st.display='block'; st.position='absolute'; st.left='0px'; st.bottom='0px'; st.MozUserSelect=st.KhtmlUserSelect="none"; over.unselectable="on"; if(img.fading&&img.showcoords||!img.showcoords) {st.visibility='hidden';} st.cursor='help'; div.appendChild(over); img.xycoid=over.id; if(!img.trident) {var view=shiftzoom.E('div'); st=view.style; st.height='100%'; st.width='100%'; st.left='0px'; st.bottom='0px'; st.position='absolute'; st.backgroundColor='black'; st.opacity=0.5; over.appendChild(view);} view=shiftzoom.E('div'); view.id=img.id+'_cpos'; view.innerHTML="x:0 y:0"; view.unselectable="on"; st=view.style; st.textAlign='left'; st.verticalAlign='middle'; st.left='0px'; st.bottom='0px'; st.position='relative'; st.display='block'; st.color='white'; st.fontSize='10px'; st.fontFamily='Arial, Helvetica, sans-serif'; st.fontStyle='normal'; st.fontWeight='bold'; st.whiteSpace='nowrap'; st.padding='2px 4px'; st.textShadow='0px 0px 4px black'; over.appendChild(view); img.cposid=view.id; over=shiftzoom.E('div'); st=over.style; if(img.fading&&img.buttons||!img.buttons) {st.visibility='hidden';} over.id=img.id+'_ctrl'; st.height='16px'; st.width='42px'; st.display="block"; st.position='absolute'; st.lineHeight='1px'; st.fontSize='1px'; st.backgroundColor="#cccccc"; if(img.trident) {st.filter="alpha(opacity="+img.opacity+")";}else{st.opacity=img.opacity/100;} st.cursor='pointer'; st.left='0px'; st.top='0px'; if(img.webkit||img.bshadow) {st.boxShadow=st.MozBoxShadow=st.KhtmlBoxShadow=st.WebkitBoxShadow="0px 0px 8px black";} div.appendChild(over); img.ctrlid=over.id; view=shiftzoom.E('div'); st=view.style; st.height='2px'; st.width='2px'; st.position='absolute'; st.lineHeight='1px'; st.fontSize='1px'; st.left='4px'; st.top='3px'; st.backgroundColor="black"; over.appendChild(view); view=shiftzoom.E('div'); st=view.style; st.height='6px'; st.width='2px'; st.position='absolute'; st.lineHeight='1px'; st.fontSize='1px'; st.left='4px'; st.top='7px'; st.backgroundColor="black"; over.appendChild(view); view=shiftzoom.E('div'); st=view.style; st.height='2px'; st.width='8px'; st.position='absolute'; st.lineHeight='1px'; st.fontSize='1px'; st.left='14px'; st.top='7px'; st.backgroundColor="black"; over.appendChild(view); view=shiftzoom.E('div'); st=view.style; st.height='8px'; st.width='2px'; st.position='absolute'; st.lineHeight='1px'; st.fontSize='1px'; st.left='17px'; st.top='4px'; st.backgroundColor="black"; over.appendChild(view); view=shiftzoom.E('div'); st=view.style; st.height='2px'; st.width='8px'; st.position='absolute'; st.lineHeight='1px'; st.fontSize='1px'; st.left='30px'; st.top='7px'; st.backgroundColor="black"; over.appendChild(view); view=shiftzoom.E('div'); view.id=img.id+'_kbin'; st=view.style; st.height=(img.bmode?16:14)+'px'; st.cursor='help'; st.width=(img.bmode?10:8)+'px'; st.display="block"; st.position='absolute'; st.border=img.bc; st.borderBottom=img.dc; st.borderRight=img.dc; st.left='0px'; st.top='0px'; img.ttipid=img.id+'_ttip'; if(img.trident) {view.onmouseover=new Function('shiftzoom._showTooltip("'+img.id+'");'); view.onmouseout=new Function('shiftzoom._killTooltip("'+img.id+'");');} else {view.setAttribute("onmouseover","shiftzoom._showTooltip('"+img.id+"');"); view.setAttribute("onmouseout","shiftzoom._killTooltip('"+img.id+"');");} over.appendChild(view); img.kbinid=view.id; view=shiftzoom.E('div'); view.id=img.id+'_zoin'; view.title=img.intitle; st=view.style; st.height=(img.bmode?16:14)+'px'; st.width=(img.bmode?16:14)+'px'; st.display="block"; st.position='absolute'; st.border=img.bc; st.borderBottom=img.dc; st.borderRight=img.dc; st.left='10px';st.top='0px'; if(img.trident) {view.onclick=new Function('shiftzoom._setCursor(this,1,"'+img.id+'");');}else {view.setAttribute("onclick","shiftzoom._setCursor(this,1,'"+img.id+"');");} over.appendChild(view); img.zoinid=view.id; view=shiftzoom.E('div'); view.id=img.id+'_zout'; view.title=img.outtitle; st=view.style; st.height=(img.bmode?16:14)+'px'; st.width=(img.bmode?16:14)+'px'; st.display="block"; st.position='absolute'; st.border=img.bc; st.borderBottom=img.dc; st.borderRight=img.dc; st.left='26px'; st.top='0px'; if(img.trident) {view.onclick=new Function('shiftzoom._setCursor(this,0,"'+img.id+'");');}else {view.setAttribute("onclick","shiftzoom._setCursor(this,0,'"+img.id+"');"); } over.appendChild(view); img.zoutid=view.id; over=shiftzoom.E('div'); over.id=img.id+'_info'; st=over.style; st.visibility='hidden'; st.height='16px'; st.width='7em'; st.left=(img.buttons?'42px':'0px'); st.top='0px'; st.display="block"; st.overflow='hidden'; st.position='absolute'; st.lineHeight='16px'; st.fontSize='10px'; st.fontFamily='Arial, Helvetica, sans-serif'; st.fontStyle='normal'; st.fontWeight='bold'; st.textShadow='0px 0px 4px black'; st.color="#ffffff"; if(img.trident) {st.filter="alpha(opacity=100)";}else{st.opacity=1;} st.cursor='default'; div.appendChild(over); img.infoid=over.id; view=shiftzoom.E('div'); st=view.style; st.position='absolute'; st.height='16px'; st.width='7em'; st.left='0px'; st.top='0px'; st.display="block"; st.backgroundColor="#000000"; if(img.trident) {st.filter="alpha(opacity=50)";}else{st.opacity=0.50;} over.appendChild(view); view=shiftzoom.E('div'); view.id=img.id+'_text'; st=view.style; st.position='absolute'; st.height='16px'; st.width='7em'; st.left='0px'; st.top='0px'; st.textAlign='center'; st.verticalAlign='middle'; st.overflow='hidden'; st.display="block"; st.color="#ffffff"; if(img.trident) {st.filter="alpha(opacity=100)";} over.appendChild(view); img.textid=view.id; view.innerHTML="100 / "+parseInt(img.xfactor*100)+" %"; over=shiftzoom.E('div'); over.id=img.id+'_over'; st=over.style; st.height=(outer.height*img.ovsfact)+'px'; st.width=(outer.width*img.ovsfact)+'px'; st.display="block"; st.position='absolute'; st.bottom='0px'; st.right='0px'; st.borderLeft=img.ovborder+'px solid '+img.ovbcolor; st.borderTop=img.ovborder+'px solid '+img.ovbcolor; if(img.webkit||img.bshadow) {st.borderLeft='0px solid '+img.ovbcolor; st.borderTop='0px solid '+img.ovbcolor; st.WebkitBoxShadow=st.MozBoxShadow=st.KhtmlBoxShadow=st.boxShadow="0px 0px 8px black";} st.MozUserSelect=st.KhtmlUserSelect="none"; st.visibility="hidden"; over.unselectable="on"; div.appendChild(over); view=shiftzoom.E('img'); view.id=img.id+'_tumb'; view.src=xref.src; st=view.style; st.height=(outer.height*img.ovsfact)+'px'; st.width=(outer.width*img.ovsfact)+'px'; st.display="block"; st.position='absolute'; st.bottom='0px'; st.right='0px'; st.msInterpolationMode=img.bicubic; over.appendChild(view); img.tumbid=view.id; if(!img.tod) {view.onmousedown=shiftzoom._catchDrag;} view=shiftzoom.E('div'); view.id=img.id+'_view'; view.maxleft=0; view.maxtop=0; st=view.style; st.lineHeight='1px'; st.fontSize='1px'; st.display="block"; st.position='absolute'; st.left='0px'; st.top='0px'; st.border='1px solid '+img.ovacolor; st.height=parseInt((outer.height*img.ovsfact)-(img.bmode?0:2))+'px'; st.width=parseInt((outer.width*img.ovsfact)-(img.bmode?0:2))+'px'; if(img.trident){st.background="url('"+img.curpath+"nop.gif') transparent"; st.filter="alpha(opacity="+img.ovaopac+")";}else{st.opacity=img.ovaopac/100;} if(img.chakra) {st.background="url("+shiftzoom.gif+") transparent";} over.appendChild(view); img.overid=over.id; img.viewid=view.id; cvi_szclback=function(){var img=shiftzoom.G(cvi_szactive);shiftzoom.G(img.textid).innerHTML=parseInt((img.parentNode.width/img.minwidth)*100)+" / "+parseInt(img.xfactor*100)+" %";}; if(img.tod) {img.ontouchstart=shiftzoom._catchTouch; if(img.mtg) {img.ongesturestart=shiftzoom._catchGesture;}}else{view.onmousedown=shiftzoom._startMove; img.ondblclick=function(){shiftzoom._setCursor(this,1,img.id);}; img.oncontextmenu=function() {return false;shiftzoom._setCursor(this,0,img.id);return false;}; img.onmousedown=shiftzoom._catchKey; img.onmouseover=shiftzoom._catchOver; img.onmouseout=shiftzoom._catchOut; if(img.showcoords) {img.onmousemove=(img.pixelcoords?img.relativecoords?shiftzoom._showPixel:shiftzoom._showCoords:img.percentcoords?shiftzoom._showPercent:shiftzoom._showLatLon);}}if(img.zoom>0&&img.fading&&img.overview) {img.overview=false; img.special=true;} if(img.zoom>0) {shiftzoom.zooming(img,img.zoom);} if(img.xpos!=50||img.ypos!=50) {shiftzoom.moveto(img,img.xpos+'%',img.ypos+'%');} if(img.icons) {shiftzoom.construct(img,img.icons);} if(img.fading) {shiftzoom._fadeImage(img.id,0);} }else {ele.parentNode.removeChild(outer); ele.style.visibility='visible';} }else {ele.style.visibility='visible';} } return false; }, remove : function(img,v) { if(img&&typeof(img.ctrlid)==="string") {var ele,obj=img.parentNode.parentNode; img.onmousedown=null; img.onmousemove=null; document.onmousemove=null; document.onmouseup=null; document.onkeydown=null; document.onkeyup=null; document.onkeypress=null; if(img.gecko) {window.removeEventListener('DOMMouseScroll', shiftzoom._catchWheel, false);}else {window.onmousewheel=null;} ele=shiftzoom.G(img.overid); if(ele) {obj.removeChild(ele);} ele=shiftzoom.G(img.infoid); if(ele) {obj.removeChild(ele);} ele=shiftzoom.G(img.ctrlid); if(ele) {obj.removeChild(ele);} ele=shiftzoom.G(img.xycoid); if(ele) {obj.removeChild(ele);} ele=shiftzoom.G(img.isrcid); if(ele) {obj.removeChild(ele);} ele=shiftzoom.E('img'); ele.id=img.id; img.id=""; img.ctrlid=false; ele.width=(v?img.maxwidth:img.minwidth); ele.height=(v?img.maxheight:img.minheight); ele.style.width=(v?img.maxwidth:img.minwidth)+'px'; ele.style.height=(v?img.maxheight:img.minheight)+'px'; ele.style.border="0px none"; ele.style.cursor="default"; ele.src=img.highres; obj.style.width=(v?img.maxwidth:img.minwidth)+'px'; obj.style.height=(v?img.maxheight:img.minheight)+'px'; obj.removeChild(img.parentNode); obj.appendChild(ele); }return false; }, construct : function(img,v) { if(img&&typeof(v)==="object"&&typeof(img.ctrlid)==="string") {var i,d,x,y,w,h,p,q,r,t,g,s,z,m,n,oe,oes,ie,ies,ele,l=v.length; for(i=0;i=8&&h>=8&&s!='') {x=Math.abs(v[i].x)||0; y=Math.abs(v[i].y)||0; p=Math.max(Math.min(Math.abs(v[i].pos),9),0)||0; z=v[i].src2||0; r=v[i].href||0; t=v[i].title||0; g=v[i].target||0; oe=shiftzoom.E('a'); oes=oe.style; if(d) {oe.id=d;} if(r) {oe.href=r;} if(g) {oe.target=g;} oe.unselectable="on"; oes.border="0px none"; oes.fontSize="0px"; oes.lineHeight="0px"; oes.margin="0px"; oes.padding="0px"; oes.textDecoration="none"; oes.mozUserSelect=oes.khtmlUserSelect=oes.webkitUserSelect="none"; img.appendChild(oe); ie=shiftzoom.E('img'); ies=ie.style; if(img.notrans) {ie.src=img.curpath+"nop.gif"; ie.style.filter="progid:DXImageTransform.Microsoft.AlphaImageLoader(src='"+s+"', sizingMethod='scale')";}else {ie.src=s;} ie.width=w; ie.height=h; if(t) {ie.title=t;} ie.unselectable="on"; ies.position="absolute"; ies.margin="0px"; ies.padding="0px"; ies.border="0px none"; ies.width=q?w+'px':(w/(img.maxwidth/100))+'%'; ies.height=q?h+'px':(h/(img.maxheight/100))+'%'; n=(img.maxheight/100); m=(img.maxwidth/100); if(q) {ies.top=(y?y/n:0)+'%'; ies.left=(x?x/m:0)+'%';}else { if(!p||p==4||p==5||p==6) {ies.top=((y?y/n:0)-(parseFloat(ies.height)/2))+'%';}else if(p==7||p==8||p==9) {ies.top=((y?y/n:0)-parseFloat(ies.height))+'%';}else if(p==1||p==2||p==3) {ies.top=(y?y/n:0)+'%';} if(!p||p==2||p==5||p==8) {ies.left=((x?x/m:0)-(parseFloat(ies.width)/2))+'%';}else if(p==3||p==6||p==9) {ies.left=((x?x/m:0)-parseFloat(ies.width))+'%';}else if(p==1||p==4||p==7) {ies.left=(x?x/m:0)+'%';}} ies.mozUserSelect=ies.khtmlUserSelect=ies.webkitUserSelect="none"; ies.msInterpolationMode=img.bicubic; if(z) {ie.first=s; ie.secnd=z; if(!img.trident) {ie.setAttribute("onmouseover","this.src=this.secnd;"); ie.setAttribute("onmouseout","this.src=this.first;");}} oe.appendChild(ie); if(z&&img.trident) {oe.onmouseover=shiftzoom._switchOver; oe.onmouseout=shiftzoom._switchOut;} } } }return false; }, destruct : function(img,v) { if(img&&v&&typeof(img.ctrlid)==="string") { if(typeof(v)==="string") {var ele=shiftzoom.G(v); if(ele) {img.removeChild(ele);}} if(typeof(v)==="boolean") {img.innerHTML="";} }return false; }, moveto : function(img,x,y) { if(img&&typeof(img.ctrlid)==="string") { if(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight) { function LFL(m,i,n){var d=parseFloat(m); if(d>n){d=n;}else if(d0?v/100:0; mw=Math.round(f*(img.maxwidth-img.minwidth))+img.minwidth; mh=Math.round(f*(img.maxheight-img.minheight))+img.minheight; mx=Math.round((mw/2)-(img.minwidth/2))*-1; my=Math.round((mh/2)-(img.minheight/2))*-1; img.parentNode.style.width=mw+'px'; img.parentNode.style.height=mh+'px'; img.parentNode.style.left=mx+'px'; img.parentNode.style.top=my+'px'; img.parentNode.width=mw; img.parentNode.height=mh; img.parentNode.left=mx; img.parentNode.top=my; img.maxleft=img.parentNode.width-img.minwidth; img.maxtop=img.parentNode.height-img.minheight; if(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight) { if(img.trident) {img.style.cursor="url('"+img.curpath+"grab.cur'),move";}else {img.style.cursor="move";} if(img.overview) {shiftzoom._setOverview(img); shiftzoom.G(img.overid).style.visibility="visible";} }else {img.style.cursor="crosshair"; if(img.overview) {shiftzoom.G(img.overid).style.visibility="hidden";}} } }return false; }, kenburns : function(img,obj) { if(img&&typeof(img.ctrlid)==="string") { function GNV(v){if(typeof(v)==="number") {v=Math.max(0,Math.min(100,parseFloat(v)));}else {v=0.5;} return v;}; var io=false,x=obj[0],y=obj[1],z=obj[2],p=obj[3]||false,s=obj[4]||false,d=obj[5]||false,b=obj[6]||false,a=obj[7]||false; if(typeof(p)==="number") {if(p==3) {io=true;}else if(p==0) {p=1;}else {p=Math.max(0,Math.min(2,parseFloat(p)));}}else {p=1;} if(typeof(s)==="number") {s=Math.max(10,Math.min(100,parseInt(s)));} if(typeof(d)==="number") {d=Math.max(10,Math.min(100,parseInt(d)));}else {d=30;} var fz,mz,ix,iy,wf,hf,sw,sh,sx,sy,ew,eh,ex,ey; x=GNV(x); y=GNV(y); z=GNV(z); fz=z*0.01; if(img.lowres&&img.highres) {shiftzoom.source(img,img.lowres,false,true);} img.zoomin=false; img.zoomout=false; if(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight) {if(img.trident) {img.style.cursor="url('"+img.curpath+"grab.cur'),move";}else {img.style.cursor="move";}}else {img.style.cursor="crosshair";} ix=(img.maxwidth-img.minwidth)*(x*0.01); iy=(img.maxheight-img.minheight)*(y*0.01); sw=parseInt(img.parentNode.style.width,10); sh=parseInt(img.parentNode.style.height,10); sx=parseInt(img.parentNode.style.left,10); sy=parseInt(img.parentNode.style.top,10); ew=z>-1?Math.round(fz*(img.maxwidth-img.minwidth))+img.minwidth:sw; eh=z>-1?Math.round(fz*(img.maxheight-img.minheight))+img.minheight:sh; wf=parseFloat((ew-img.minwidth)/(img.maxwidth-img.minwidth)); hf=parseFloat((eh-img.minheight)/(img.maxheight-img.minheight)); ex=Math.max(0,Math.min(ew-img.minwidth,ix*wf))*-1; ey=Math.max(0,Math.min(eh-img.minheight,iy*hf))*-1; if(typeof(s)!=="number") {mz=Math.abs(Math.abs(ex)-Math.abs(sx)); mz=Math.max(mz,Math.abs(Math.abs(ey)-Math.abs(sy))); mz=Math.max(mz,Math.abs(Math.abs(ew)-Math.abs(sw))); mz=Math.max(mz,Math.abs(Math.abs(eh)-Math.abs(sh))); s=Math.round(mz/d);} if(img.timer) {window.clearInterval(img.timer);} var mx,my,mw,mh,q=0,c=0,t=Math.max(5,s),k=1/t; img.timer=window.setInterval(function() { q=io?((-Math.cos((k*c)*Math.PI)/2)+0.5)||0:Math.pow((k*c),p)||0; mw=Math.ceil(sw+(q*(ew-sw))); mh=Math.ceil(sh+(q*(eh-sh))); mx=Math.ceil(sx+(q*(ex-sx))); my=Math.ceil(sy+(q*(ey-sy))); img.parentNode.style.width=mw+'px'; img.parentNode.style.height=mh+'px'; img.parentNode.style.left=mx+'px'; img.parentNode.style.top=my+'px'; img.parentNode.width=mw; img.parentNode.height=mh; img.parentNode.left=mx; img.parentNode.top=my; if(img.divbug) {img.parentNode.firstChild.style.width=mw+'px'; img.parentNode.firstChild.style.height=mh+'px';} c++; if(c>t) {window.clearInterval(img.timer); img.maxleft=img.parentNode.width-img.minwidth; img.maxtop=img.parentNode.height-img.minheight; img.zoomin=false; img.zoomout=false; if(img.lowres&&img.highres) {shiftzoom.source(img,img.highres,false,true);} if(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight) { if(img.trident) {img.style.cursor="url('"+img.curpath+"grab.cur'),move";}else {img.style.cursor="move";} if(img.overview) {shiftzoom._setOverview(img); shiftzoom.G(img.overid).style.visibility="visible";} }else {img.style.cursor="crosshair"; if(img.overview) {shiftzoom.G(img.overid).style.visibility="hidden";}} if(img.automode) {if(b&&typeof(b)==="string"&&eval('typeof '+b)=="function") {window.setTimeout("window['"+b+"']('"+(typeof(a)=='number'||typeof(a)=='string'?a:'')+"')",30);} window.setTimeout("shiftzoom._next(shiftzoom.G('"+img.id+"'))",img.autowait+1000);}else {if(b&&typeof(b)==="string"&&eval('typeof '+b)=="function") {window.setTimeout("window['"+b+"']('"+(typeof(a)=='number'||typeof(a)=='string'?a:'')+"')",200);}}} },d); }return false; }, play : function(img,d,l,obj,c) { if(img&&typeof(img.ctrlid)==="string") { if(!img.automode&&typeof(d)==="number"&&typeof(l)==="boolean"&&typeof(obj)==="object") { if(obj.length>=1) {var n=0,mx=3,t=obj.length,i; for(i=0;i=3) {img.step=obj; img.cpos=0; img.automode=true; img.autoloop=l; img.autowait=Math.abs(d); img.nozoom=true; if(img.overview) {shiftzoom.set(img,'overview',false);} if(img.buttons&&!img.tod) {shiftzoom.set(img,'buttons',false);} if(img.showcoords&&!img.tod) {shiftzoom.set(img,'showcoords',false);} shiftzoom.kenburns(shiftzoom.G(img.id),img.step[img.cpos]); } } } }return false; }, stop : function(img) { if(img&&typeof(img.ctrlid)==="string") { if(img.automode) { img.automode=false; if(img.timer) {window.clearInterval(img.timer);} img.autoloop=false; img.cpos=0; img.maxleft=img.parentNode.width-img.minwidth; img.maxtop=img.parentNode.height-img.minheight; if(img.lowres&&img.highres) {shiftzoom.source(img,img.highres,false,true);} if(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight) { if(img.trident) {img.style.cursor="url('"+img.curpath+"grab.cur'),move";}else {img.style.cursor="move";} if(img.overview) {shiftzoom._setOverview(img); shiftzoom.G(img.overid).style.visibility="visible";} }else {img.style.cursor="crosshair"; if(img.overview) {shiftzoom.G(img.overid).style.visibility="hidden";}} if(img.callback) {window.setTimeout("window['"+img.callback+"']()",200);} } }return false; }, source : function(img,src,v,z) { if(img&&typeof(img.ctrlid)==="string") { if(typeof(src)==="string"&&typeof(v)==="boolean") { var tmp=new Image(); shiftzoom.G(img.xrefid) tmp.onload=function() { shiftzoom.G(img.ctrlid).style.visibility="hidden"; shiftzoom.G(img.overid).style.visibility="hidden"; shiftzoom.G(img.xycoid).style.visibility="hidden"; if(v==true) { shiftzoom.G(img.isrcid).src=tmp.src; if(!z) {if(img.trident) {tmp.onload=''; tmp=null;} delete tmp;} shiftzoom._fadeOut(img.id,100); }else if(v==false) {var obj=shiftzoom.G(img.xrefid); obj.src=tmp.src; obj.style.msInterpolationMode=img.bicubic; if(!z) {shiftzoom.G(img.tumbid).src=obj.src; if(img.highres!=obj.src) {img.highres=obj.src;} if(img.trident) {tmp.onload=''; tmp=null;} delete tmp;} if(img.buttons&&!img.tod) {shiftzoom.G(img.ctrlid).style.visibility="visible";} if(img.overview&&(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight)) {shiftzoom.G(img.overid).style.visibility="visible";} if(img.showcoords&&!img.tod) {shiftzoom.G(img.xycoid).style.visibility="visible";} } }; tmp.src=src; } }return false; }, lowsource : function(img,src) { if(img&&typeof(img.ctrlid)==="string") { if(typeof(src)==="string"&&!img.automode&&!img.zoomin&&!img.zoomout) { var low=new Image(); low.onload=function() {img.lowres=low.src; if(img.trident) {low.onload=''; low=null;} delete low;}; low.src=src; } }return false; }, info : function(img,v) { if(img&&typeof(img.ctrlid)==="string") { if(v&&typeof(v)==="string") {img.infoblock=v;}else {img.infoblock=img.defblock;} }return false; }, set : function(img,d,v) { if(img&&typeof(img.ctrlid)==="string") { if(d&&typeof(v)==="boolean") { switch(d.toLowerCase()) { case 'overview': if(v==false&&img.overview==true) {shiftzoom.G(img.overid).style.visibility="hidden";}else if(v==true&&img.overview==false) { if(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight) {shiftzoom._setOverview(img); shiftzoom.G(img.overid).style.visibility="visible";}else {shiftzoom.G(img.overid).style.visibility="hidden";}}img.overview=v; break; case 'showcoords': if(v==false&&img.showcoords==true) {img.onmousemove=null; shiftzoom.G(img.xycoid).style.visibility="hidden";}else if(v==true&&img.showcoords==false&&!img.tod) {shiftzoom.G(img.xycoid).style.visibility="visible"; img.onmousemove=shiftzoom._showCoords;}img.showcoords=v; break; case 'relativecoords': if(v==false&&img.pixelcoords==true&&img.showcoords==true&&!img.tod) {img.onmousemove=shiftzoom._showCoords;}else if(v==true&&img.pixelcoords==true&&img.showcoords==true&&!img.tod) {img.onmousemove=shiftzoom._showPixel;}img.relativecoords=v; break; case 'pixelcoords': if(v==false&&img.pixelcoords==true&&img.showcoords==true&&!img.tod) {img.onmousemove=shiftzoom._showLatLon;}else if(v==true&&img.pixelcoords==false&&img.showcoords==true&&!img.tod) {img.onmousemove=shiftzoom._showCoords;}img.pixelcoords=v; break; case 'percentcoords': if(v==false&&img.percentcoords==true&&img.showcoords==true&&!img.tod) {img.onmousemove=shiftzoom._showLatLon;}else if(v==true&&img.percentcoords==false&&img.showcoords==true&&!img.tod) {img.onmousemove=shiftzoom._showPercent;}img.percentcoords=v; break; case 'buttons': if(v==false&&img.buttons==true) {shiftzoom.G(img.ctrlid).style.visibility="hidden"; shiftzoom.G(img.infoid).style.left='0px';}else if(v==true&&img.buttons==false&&!img.tod) {shiftzoom.G(img.infoid).style.left='42px'; shiftzoom.G(img.ctrlid).style.visibility="visible";}img.buttons=v; break; case 'zoomin': if(!img.nozoom&&!img.buttons&&(parseInt(img.parentNode.style.width,10)img.minwidth||parseInt(img.parentNode.style.height,10)>img.minheight)) { if(v==true) {img.zoomout=true; img.zoomin=false; if(img.gecko) {img.style.cursor="-moz-zoom-out";}else if(img.webkit) {img.style.cursor="-webkit-zoom-out";} else if(img.trident||img.chakra) {img.style.cursor="url('"+img.curpath+"zoom-out.cur'),crosshair";}else {img.style.cursor="crosshair";}}else {img.zoomout=false;}}break; case 'nozoom': img.nozoom=v; break; } } }return false; }, get : function(img,d) { if(img&&d&&typeof(img.ctrlid)==="string") { if(d.toLowerCase()=="maxzoomx") {return img.xfactor;}else if(d.toLowerCase()=="maxzoomy") {return img.yfactor;}else if(d.toLowerCase()=="maxwidth") {return img.maxwidth;}else if(d.toLowerCase()=="maxheight") {return img.maxheight;}else if(d.toLowerCase()=="playing") {return img.automode;}else if(d.toLowerCase()=="currentxyz") { var q=parseFloat((img.parentNode.width-img.minwidth)/(img.maxwidth-img.minwidth)),z=Math.min(Math.max(q*100,0),100)||0; var x=Math.min(Math.max(((Math.abs(parseFloat(img.parentNode.style.left))/((img.maxwidth-img.minwidth)*q))*100),0),100)||0; var y=Math.min(Math.max(((Math.abs(parseFloat(img.parentNode.style.top))/((img.maxheight-img.minheight)*q))*100),0),100)||0; return {x:x,y:y,z:z}; } }return false; }, G : function(v) {return(document.getElementById(v));}, E : function(v) {return(document.createElement(v));}, L : function(s,v) {s=s.toUpperCase()||'LOG'; if(window.console) {if(!window.console.warn) {window.console.log(s+': '+v);}else {window.console[s.toLowerCase()||'log'](v);}}else if(window.opera) {opera.postError(s+': '+v);}else {window.document.title=s+': '+v;} return false;}, _next : function(img) { if(img&&typeof(img.ctrlid)==="string") { if(img.automode) { if(img.autoloop&&img.cpos<(img.step.length-1)) {img.cpos=img.cpos+1;}else if(img.autoloop&&img.cpos>=(img.step.length-1)) {img.cpos=0;}else if(!img.autoloop&&img.cpos<(img.step.length-1)) {img.cpos=img.cpos+1;}else {img.cpos=img.step.length; } if(img.cpos0&&px==ex) {ex-=ox;} oy=self.pageYOffset; if(oy>0&&py==ey) {ey-=oy;}}else if(document.documentElement) {ox=document.documentElement.scrollLeft; oy=document.documentElement.scrollTop;}else if(document.body) {ox=document.body.scrollLeft; oy=document.body.scrollTop;} k.ox=ox; k.oy=oy; k.ex=ex; k.ey=ey; return k; }, _showCoords : function(e) { if(cvi_szactive!=null) {var k,t,x,y,ex,ey,px=0,py=0,o=shiftzoom.G(cvi_szactive),w=o.parentNode.width,h=o.parentNode.height; e=e?e:window.event; ex=e.clientX; ey=e.clientY; if(e.pageX||e.pageY) {px=e.pageX; py=e.pageY;} k=shiftzoom._getMousePos(ex,ey,px,py); t=shiftzoom._findPosXY(o); x=Math.min(Math.max(k.ex+k.ox-t.x,0),w); y=Math.min(Math.max(k.ey+k.oy-t.y,0),h); shiftzoom.G(o.cposid).innerHTML='x:'+x+' y:'+y+'<\/span>'; }return false; }, _showPixel : function(e) { if(cvi_szactive!=null) {var k,t,x,y,z,ex,ey,px=0,py=0,o=shiftzoom.G(cvi_szactive),w=o.parentNode.width,h=o.parentNode.height; e=e?e:window.event; ex=e.clientX; ey=e.clientY; if(e.pageX||e.pageY) {px=e.pageX; py=e.pageY;} k=shiftzoom._getMousePos(ex,ey,px,py); t=shiftzoom._findPosXY(o); z=(o.minwidth/w)*o.xfactor; x=parseInt((Math.min(Math.max(k.ex+k.ox-t.x,0),w)*z),10); y=parseInt((Math.min(Math.max(k.ey+k.oy-t.y,0),h)*z),10); shiftzoom.G(o.cposid).innerHTML='x:'+x+' y:'+y+'<\/span>'; }return false; }, _showPercent : function(e) { if(cvi_szactive!=null) {var k,t,x,y,z,ex,ey,px=0,py=0,na=!Number.prototype.toFixed?0:1,o=shiftzoom.G(cvi_szactive),w=o.parentNode.width,h=o.parentNode.height; e=e?e:window.event; ex=e.clientX; ey=e.clientY; if(e.pageX||e.pageY) {px=e.pageX; py=e.pageY;} k=shiftzoom._getMousePos(ex,ey,px,py); t=shiftzoom._findPosXY(o); x=parseFloat((Math.min(Math.max(k.ex+k.ox-t.x,0.0),w)/w)*100); x=na?x.toFixed(2):parseInt(x); y=parseFloat((Math.min(Math.max(k.ey+k.oy-t.y,0.0),h)/h)*100); y=na?y.toFixed(2):parseInt(y); z=parseFloat(((w-o.minwidth)/(o.maxwidth-o.minwidth))*100); z=na?z.toFixed(2):parseInt(z); shiftzoom.G(o.cposid).innerHTML='x:'+x+'% y:'+y+'% z:'+z+'%<\/span>'; }return false; }, _showLatLon : function(e) { if(cvi_szactive!=null) {function parseDMS(v,n){var d,m,s; d=parseInt(v); m=Math.abs(parseFloat(v-d)*60); s=Math.abs(parseFloat(parseInt(m)-m)*60); return Math.abs(d)+"°"+parseInt(m)+"'"+parseInt(s)+"'' "+n;} var k,t,x,y,lat,lon,ex,ey,px=0,py=0,o=document.getElementById(cvi_szactive),w=o.parentNode.width,h=o.parentNode.height; e=e?e:window.event; ex=e.clientX; ey=e.clientY; if(e.pageX||e.pageY) {px=e.pageX; py=e.pageY;} k=shiftzoom._getMousePos(ex,ey,px,py); t=shiftzoom._findPosXY(o); x=Math.min(Math.max(k.ex+k.ox-t.x,0),w); y=Math.min(Math.max(k.ey+k.oy-t.y,0),h); lon=(x*360/w)-180; lat=90-(y*180/h); lon=parseDMS(lon,lon!=0?(lon<0?"W":"E"):""); lat=parseDMS(lat,lat!=0?(lat<0?"S":"N"):""); shiftzoom.G(o.cposid).innerHTML='Lat: '+lat+' • Lon: '+lon+'<\/span>'; }return false; }, _killTooltip : function(id) {var ison,img=shiftzoom.G(id); ison=shiftzoom.G(img.ttipid); if(ison) {document.getElementsByTagName("body")[0].removeChild(ison);}return false;}, _showTooltip : function(id,xx,yy) {xx=xx||0;yy=yy||0;var over,view,img=shiftzoom.G(id),ison=shiftzoom.G(img.ttipid); if(!ison) {var t=shiftzoom._findPosXY(img.parentNode.parentNode); over=shiftzoom.E('div'); if(img.trident) {over.style.backgroundColor='black';} over.id=img.ttipid; over.style.height='auto'; over.style.width='auto'; over.style.display='block'; over.style.position='absolute'; over.style.filter="alpha(opacity=0)"; over.style.opacity=0; over.style.left=(t.x+10+xx)+'px'; over.style.top=(t.y+yy)+'px'; over.style.visibility='visible'; over.style.border='solid 2px white'; over.style.MozBorderRadius=over.style.KhtmlBorderRadius=over.style.WebkitBorderRadius=over.style.borderRadius='6px'; over.unselectable="on"; over.style.MozBoxShadow=over.style.WebkitBoxShadow=over.style.KhtmlBoxShadow=over.style.boxShadow='0px 0px 8px black'; over.style.MozUserSelect=over.style.KhtmlUserSelect="none"; document.getElementsByTagName("body")[0].appendChild(over); over.onclick=function(){document.getElementsByTagName("body")[0].removeChild(this);}; if(!img.trident) {view=shiftzoom.E('div'); view.style.height='100%'; view.style.width='100%'; view.style.left='0px'; view.style.top='0px'; view.style.position='absolute'; view.style.opacity=0.5; view.style.backgroundColor='black'; view.style.MozBorderRadius=view.style.KhtmlBorderRadius=view.style.WebkitBorderRadius=view.style.borderRadius='4px'; over.appendChild(view);} view=shiftzoom.E('div'); view.style.display='block'; view.style.left='0px'; view.style.top='0px'; view.style.position='relative'; view.style.textAlign='left'; view.style.verticalAlign='middle'; view.style.color='white'; view.style.fontSize='12px'; view.style.fontFamily='Arial,Helvetica,sans-serif'; view.style.fontStyle='normal'; view.style.fontWeight='bold'; view.style.whiteSpace='nowrap'; view.style.textShadow='black 0px 0px 4px'; view.style.margin='10px'; view.innerHTML=img.infoblock; over.appendChild(view); if(img.timer) {window.clearInterval(img.timer);} var q=0,c=0,t=5,k=20; img.timer=window.setInterval(function() {q+=k; over.style.filter="alpha(opacity="+q+")"; over.style.opacity=q/100; c++; if(c>t) {window.clearInterval(img.timer); over.style.filter="alpha(opacity=100)"; over.style.opacity=1;} },30); }return false; }, _setCursor : function(ele,d,id) {var img=shiftzoom.G(id); if(!img.nozoom) {var butt=shiftzoom.G(d==1?img.zoutid:img.zoinid).style; img.zoomin=false; img.zoomout=false; ele.style.border=img.bc; ele.style.borderBottom=img.dc; ele.style.borderRight=img.dc; butt.border=img.bc; butt.borderBottom=img.dc; butt.borderRight=img.dc; if(d==1&&(parseInt(img.parentNode.style.width,10)img.minwidth||parseInt(img.parentNode.style.height,10)>img.minheight)) { ele.style.border=img.bc; ele.style.borderTop=img.dc; ele.style.borderLeft=img.dc; img.zoomout=true; if(img.gecko) {img.style.cursor="-moz-zoom-out";}else if(img.webkit) {img.style.cursor="-webkit-zoom-out";} else if(img.trident||img.chakra) {img.style.cursor="url('"+img.curpath+"zoom-out.cur'),crosshair";}else {img.style.cursor="crosshair";} }else {img.style.cursor=img.pointer;} }return false; }, _zoomIn : function(id,ct,st,sw,ew,sh,eh,sx,ex,sy,ey,nz) { if(!nz) {var mw,mh,mx,my,obj=shiftzoom.G(id); if(parseInt(obj.parentNode.style.width,10)obj.minwidth||parseInt(obj.parentNode.style.height,10)>obj.minheight) {clearInterval(cvi_sztimer); mw=Math.max(obj.minwidth,Math.min(obj.maxwidth,Math.round(ew*ct/st+sw))); mx=Math.round(ex*ct/st+sx); mh=Math.max(obj.minheight,Math.min(obj.maxheight,Math.round(eh*ct/st+sh))); my=Math.round(ey*ct/st+sy); obj.parentNode.style.width=mw+'px'; obj.parentNode.style.height=mh+'px'; obj.parentNode.style.left=mx+'px'; obj.parentNode.style.top=my+'px'; ct++; if(obj.divbug) {obj.parentNode.firstChild.style.width=mw+'px'; obj.parentNode.firstChild.style.height=mh+'px';} shiftzoom.G(obj.textid).innerHTML=parseInt((mw/obj.minwidth)*100)+" / "+parseInt(obj.xfactor*100)+" %"; cvi_sztimer=setInterval("shiftzoom._zoomOut('"+id+"',"+rm+","+ct+","+st+","+sw+","+ew+","+sh+","+eh+","+sx+","+ex+","+sy+","+ey+","+nz+")",obj.millisec); }else {clearInterval(cvi_sztimer); if(obj.webkit&&rm){shiftzoom._stopZoom();}} }return false; }, _stopZoom : function() { var view, butt, img=shiftzoom._shiftzoom; document.onmouseup=null; clearInterval(cvi_sztimer); img.zoomin=false; img.zoomout=false; img.parentNode.left=parseInt(img.parentNode.style.left,10); img.parentNode.top=parseInt(img.parentNode.style.top,10); img.parentNode.width=parseInt(img.parentNode.style.width,10); img.parentNode.height=parseInt(img.parentNode.style.height,10); img.maxleft=img.parentNode.width-img.minwidth; img.maxtop=img.parentNode.height-img.minheight; if(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight) { if(img.trident) {img.style.cursor="url('"+img.curpath+"grab.cur'),move";}else {img.style.cursor="move";} if(img.overview) {shiftzoom._setOverview(img); shiftzoom.G(img.overid).style.visibility="visible";} }else {img.style.cursor="crosshair"; if(img.overview) {shiftzoom.G(img.overid).style.visibility="hidden";}} butt=shiftzoom.G(img.zoinid).style; butt.border=img.bc; butt.borderBottom=img.dc; butt.borderRight=img.dc; butt=shiftzoom.G(img.zoutid).style; butt.border=img.bc; butt.borderBottom=img.dc; butt.borderRight=img.dc; img.pointer=img.style.cursor; shiftzoom.G(img.textid).innerHTML=parseInt((img.parentNode.width/img.minwidth)*100)+" / "+parseInt(img.xfactor*100)+" %"; if(img.lowres&&img.highres) {shiftzoom.source(img,img.highres,false,true);} cvi_sztimer=setInterval("shiftzoom._fadeInfo('"+img.id+"',100)",30); shiftzoom._shiftzoom=null; return false; }, _catchDrag : function(e) {return false;}, _catchWheel : function(e){ var d,p,n,v=0; e=e?e:window.event; if(e.wheelDelta) {v=e.wheelDelta/120; d=(v<0?1:0);}else if (e.detail) {v=-e.detail/3; d=(v<0?1:0);} if(e.preventDefault) {e.preventDefault();}else {e.returnValue=false;} if(cvi_szactive!=null&&v!=0) {cvi_szimage=true; var img=shiftzoom.G(cvi_szactive),obj=shiftzoom.G(img.infoid).style; obj.visibility='visible'; obj.opacity=1; p=shiftzoom.get(img,'currentxyz'); if(p.z<=0) {p.x=50;p.y=50;} shiftzoom.G(img.textid).innerHTML=parseInt((img.parentNode.width/img.minwidth)*100)+" / "+parseInt(img.xfactor*100)+" %"; n=d<1?Math.max(p.z-20,0):Math.min(p.z+20,100); shiftzoom.kenburns(img,[p.x,p.y,n,3,false,false,'cvi_szclback']); shiftzoom.G(img.textid).innerHTML=parseInt((img.parentNode.width/img.minwidth)*100)+" / "+parseInt(img.xfactor*100)+" %"; shiftzoom._fadeInfo(img.id,100); } return false; }, _catchOver : function(e) { cvi_szactive=this.id; this.focus(); if(this.gecko) {window.addEventListener('DOMMouseScroll', shiftzoom._catchWheel, false);}else {window.onmousewheel=document.onmousewheel=shiftzoom._catchWheel;} document.onkeyup=shiftzoom._upKey;document.onkeypress=shiftzoom._pressKey; document.onkeydown=shiftzoom._downKey;return false; }, _catchOut : function() { cvi_szactive=null; if(this.gecko) {window.removeEventListener('DOMMouseScroll', shiftzoom._catchWheel, false);}else {window.onmousewheel=document.onmousewheel=null;} document.onkeydown=null;document.onkeypress=null;document.onkeyup=null;return false; }, _switchOver : function(e) { if(window.XMLHttpRequest) {this.firstChild.src=this.firstChild.secnd; return false;} else {this.firstChild.style.filter="progid:DXImageTransform.Microsoft.AlphaImageLoader(src='"+this.firstChild.secnd+"', sizingMethod='scale')";} return false; }, _switchOut : function(e) { if(window.XMLHttpRequest) {this.firstChild.src=this.firstChild.first; return false;} else {this.firstChild.style.filter="progid:DXImageTransform.Microsoft.AlphaImageLoader(src='"+this.firstChild.first+"', sizingMethod='scale')";} return false; }, _catchKey : function(e) { clearInterval(cvi_sztimer); var img=shiftzoom._shiftzoom=this; var rm=false,mm=false,k,t,ex,ey,px=0,py=0,obj=shiftzoom.G(img.infoid).style; e=e?e:window.event; if(e.which) {mm=(e.which==2); rm=(e.which==3);}else if(e.button) {mm=(e.button==4); rm=(e.button==2);} if(img.trident) {obj.filter="alpha(opacity=100)";}else {obj.opacity=1;} obj.visibility='hidden'; ex=e.clientX; ey=e.clientY; if(e.pageX||e.pageY) {px=e.pageX; py=e.pageY;} k=shiftzoom._getMousePos(ex,ey,px,py); t=shiftzoom._findPosXY(img.parentNode.parentNode); img.mouseX=Math.min(Math.max(k.ex+k.ox-t.x,0),img.minwidth); img.mouseY=Math.min(Math.max(k.ey+k.oy-t.y,0),img.minheight); if(((e.altKey&&!e.shiftKey)||rm||img.zoomout)&&!img.automode&&!img.nozoom&&(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight)) { var butt,sw,ew,sh,eh,sx,ex,sy,ey,st; if(img.gecko) {img.style.cursor="-moz-zoom-out";}else if(img.webkit) {img.style.cursor="-webkit-zoom-out";} else if(img.trident||img.chakra) {img.style.cursor="url('"+img.curpath+"zoom-out.cur'),crosshair";}else {img.style.cursor="crosshair";}img.pointer=img.style.cursor; if(!img.zoomout) {butt=shiftzoom.G(img.zoutid).style; butt.border=img.bc; butt.borderLeft=img.dc; butt.borderTop=img.dc; img.zoomout=true;} sw=img.parentNode.width; ew=(img.parentNode.width-img.minwidth)*-1; sh=img.parentNode.height; eh=(img.parentNode.height-img.minheight)*-1; sx=parseInt(img.parentNode.style.left,10); ex=sx*-1; sy=parseInt(img.parentNode.style.top,10); ey=sy*-1; st=Math.max(1,Math.round((img.parentNode.width/img.minwidth)*3)); document.onmouseup=shiftzoom._stopZoom; obj.visibility='visible'; if(img.lowres&&img.highres) {shiftzoom.source(img,img.lowres,false,true);} cvi_sztimer=setInterval("shiftzoom._zoomOut('"+img.id+"',"+rm+","+(img.webkit&&rm?1:0)+","+st+","+sw+","+ew+","+sh+","+eh+","+sx+","+ex+","+sy+","+ey+","+img.nozoom+")",img.millisec); }else if(((!e.altKey&&e.shiftKey)||mm||img.zoomin)&&!img.automode&&!img.nozoom&&(img.parentNode.widthimg.minwidth||img.parentNode.height>img.minheight) { if(img.automode) {shiftzoom.stop(img);} if(img.gecko) {img.style.cursor="-moz-grabbing";}else if(img.trident) {img.style.cursor="url('"+img.curpath+"grabbing.cur'),move";}else {img.style.cursor="move";} var x=parseInt(img.parentNode.style.left,10), y=parseInt(img.parentNode.style.top,10); img.mouseX=e.clientX; img.mouseY=e.clientY; document.onmousemove=shiftzoom._whilePan; document.onmouseup=shiftzoom._stopPan; }return false; }, _catchTouch : function(e) { if(e.touches.length==1) {e.preventDefault(); clearInterval(cvi_sztimer); var img=shiftzoom._shiftzoom=e.target; if(img&&typeof(img.ctrlid)==="string") {cvi_sztimer=new Date().getTime(); cvi_szactive=img.id; cvi_szimage=true; var delay=cvi_sztimer-img.lasttap; if(delay<500&&delay>0) {img.lasttap=0; var p=shiftzoom.get(img,'currentxyz'); if(p.z<=0) {p.x=50;p.y=50;} if(p.z<100) {shiftzoom.kenburns(img,[p.x,p.y,100,3]);}}else{ var k,t,ex,ey,px=0,py=0,obj=shiftzoom.G(img.infoid).style; obj.opacity=1; obj.visibility='hidden'; img.lasttap=cvi_sztimer; ex=e.touches[0].clientX; ey=e.touches[0].clientY; if(e.touches[0].pageX||e.touches[0].pageY) {px=e.touches[0].pageX; py=e.touches[0].pageY;} k=shiftzoom._getMousePos(ex,ey,px,py); t=shiftzoom._findPosXY(img.parentNode.parentNode); img.mouseX=Math.min(Math.max(k.ex+k.ox-t.x,0),img.minwidth); img.mouseY=Math.min(Math.max(k.ey+k.oy-t.y,0),img.minheight); if(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight) { if(img.automode) {shiftzoom.stop(img);} img.hasmoved=false; img.mouseX=e.touches[0].clientX; img.mouseY=e.touches[0].clientY; img.ontouchmove=shiftzoom._touchMove; img.ontouchend=shiftzoom._touchEnd; } } } } return false; }, _touchMove : function(e) { if(e.touches.length==1) { var img=shiftzoom._shiftzoom; if(img&&typeof(img.ctrlid)==="string") { var x=Math.max(0,Math.min(img.maxleft,Math.abs(parseInt(img.parentNode.style.left,10))-(e.touches[0].clientX-img.mouseX))); var y=Math.max(0,Math.min(img.maxtop,Math.abs(parseInt(img.parentNode.style.top,10))-(e.touches[0].clientY-img.mouseY))); img.parentNode.style.left=(x*-1)+'px'; img.parentNode.style.top=(y*-1)+'px'; img.parentNode.left=(x*-1); img.parentNode.top=(y*-1); img.mouseX=e.touches[0].clientX; img.mouseY=e.touches[0].clientY; img.hasmoved=true; } } return false; }, _touchEnd : function() {var img=shiftzoom._shiftzoom; if(img&&typeof(img.ctrlid)==="string") {clearInterval(cvi_sztimer); img.ontouchmove=null; img.ontouchend=null; if(img.overview) { var view=shiftzoom.G(img.viewid).style; view.left=Math.round((Math.abs(parseInt(img.parentNode.style.left,10))/(img.parentNode.width/img.minwidth))*img.ovsfact)-(img.bmode?2:0)+'px'; view.top=Math.round((Math.abs(parseInt(img.parentNode.style.top,10))/(img.parentNode.height/img.minheight))*img.ovsfact)-(img.bmode?2:0)+'px'; } } cvi_szactive=null; cvi_szimage=false; shiftzoom._shiftzoom=null; return false; }, _catchGesture : function(e) {e.preventDefault(); clearInterval(cvi_sztimer); var img=shiftzoom._shiftzoom=e.target; if(img&&typeof(img.ctrlid)==="string"&&!img.zoomin&&!img.zoomout&&!img.automode&&!img.nozoom) {cvi_szactive=img.id; cvi_szimage=true; var obj=shiftzoom.G(img.infoid).style; obj.visibility='hidden'; obj.opacity=1; obj.visibility='visible'; shiftzoom.G(img.textid).innerHTML=parseInt((img.parentNode.width/img.minwidth)*100)+" / "+parseInt(img.xfactor*100)+" %"; img.ongesturechange=shiftzoom._gestureChange; img.ongestureend=shiftzoom._gestureEnd; } return false; }, _gestureChange : function(e) {e.preventDefault(); var img=shiftzoom._shiftzoom; if(img&&typeof(img.ctrlid)==="string") { var n,obj=shiftzoom.G(img.infoid).style,p=shiftzoom.get(img,'currentxyz'); if(p.z<=0) {p.x=50;p.y=50;} obj.visibility='visible'; obj.opacity=1; shiftzoom.G(img.textid).innerHTML=parseInt((img.parentNode.width/img.minwidth)*100)+" / "+parseInt(img.xfactor*100)+" %"; n=e.scale<1?Math.max(p.z-33.333333,0):Math.min(p.z+33.333333,100); shiftzoom.kenburns(img,[p.x,p.y,n,3]); shiftzoom.G(img.textid).innerHTML=parseInt((img.parentNode.width/img.minwidth)*100)+" / "+parseInt(img.xfactor*100)+" %"; } return false; }, _gestureEnd : function() {var img=shiftzoom._shiftzoom; if(img&&typeof(img.ctrlid)==="string") {img.ongesturechange=null; img.ongestureend=null; clearInterval(cvi_sztimer); img.zoomin=false; img.zoomout=false; img.parentNode.left=parseInt(img.parentNode.style.left,10); img.parentNode.top=parseInt(img.parentNode.style.top,10); img.parentNode.width=parseInt(img.parentNode.style.width,10); img.parentNode.height=parseInt(img.parentNode.style.height,10); img.maxleft=img.parentNode.width-img.minwidth; img.maxtop=img.parentNode.height-img.minheight; shiftzoom.G(img.textid).innerHTML=parseInt((img.parentNode.width/img.minwidth)*100)+" / "+parseInt(img.xfactor*100)+" %"; if(img.lowres&&img.highres) {shiftzoom.source(img,img.highres,false,true);} shiftzoom._fadeInfo(img.id,100); } cvi_szactive=null; cvi_szimage=false; shiftzoom._shiftzoom=null; return false; }, _downKey : function(e) { if(cvi_szactive!=null) { e=e?e:window.event; var k=(e.keyCode?e.keyCode:e.which),s=e.shiftKey,a=e.altKey,w=false,AL=37,AU=38,AR=39,AD=40,HO=36,EN=35,PD=34,PU=33,PL=187,MN=189; switch(k) { case AL : cvi_szimage=true; shiftzoom._panKey(8,0,s,a); break; case AR : cvi_szimage=true; shiftzoom._panKey(-8,0,s,a); break; case AU : cvi_szimage=true; shiftzoom._panKey(0,8,s,a); break; case AD : cvi_szimage=true; shiftzoom._panKey(0,-8,s,a); break; case HO : if(cvi_szimage==null) {cvi_szimage=true; shiftzoom._initZoom(0,1,w); }break; case EN : if(cvi_szimage==null) {cvi_szimage=true; shiftzoom._initZoom(1,1,w); }break; case MN : case PU : if(cvi_szimage==null) {cvi_szimage=true; shiftzoom._initZoom(0,4,w); }break; case PL : case PD : if(cvi_szimage==null) {cvi_szimage=true; shiftzoom._initZoom(1,4,w); }break; } }return false; }, _pressKey : function(e) {return false; }, _upKey : function() {if(cvi_szactive!=null) {cvi_szimage=null;}return false;}, _initZoom : function(d,v,w) {var sw,ew,sh,eh,sx,ex,sy,ey,st,img=shiftzoom.G(cvi_szactive); if(img.automode) {shiftzoom.stop(img);} if(d==0&&!img.nozoom&&(parseInt(img.parentNode.style.width,10)>img.minwidth||parseInt(img.parentNode.style.height,10)>img.minheight)) { if(img.gecko) {img.style.cursor="-moz-zoom-out";}else if(img.webkit) {img.style.cursor="-webkit-zoom-out";} else if(img.trident||img.chakra) {img.style.cursor="url('"+img.curpath+"zoom-out.cur'),crosshair";}else {img.style.cursor="crosshair";}img.pointer=img.style.cursor; sw=img.parentNode.width; ew=(img.parentNode.width-img.minwidth)*-1; sh=img.parentNode.height; eh=(img.parentNode.height-img.minheight)*-1; sx=parseInt(img.parentNode.style.left,10); ex=sx*-1; sy=parseInt(img.parentNode.style.top,10); ey=sy*-1; st=Math.max(1,Math.round((img.parentNode.width/img.minwidth)*v)); if(img.lowres&&img.highres) {shiftzoom.source(img,img.lowres,false,true);} shiftzoom._zoomKey(d,(w?1:0),w,st,sw,ew,sh,eh,sx,ex,sy,ey,img.nozoom); }else if(d==1&&!img.nozoom&&(parseInt(img.parentNode.style.width,10)img.minwidth||img.parentNode.height>img.minheight) { if(img.trident) {img.style.cursor="url('"+img.curpath+"grab.cur'),move";}else {img.style.cursor="move";} if(img.overview) {shiftzoom._setOverview(img); shiftzoom.G(img.overid).style.visibility="visible";} }else {img.style.cursor="crosshair"; if(img.overview) {shiftzoom.G(img.overid).style.visibility="hidden";}} img.pointer=img.style.cursor; shiftzoom.G(img.infoid).style.visibility='hidden'; } if(d==0&&(parseInt(img.parentNode.style.width,10)>img.minwidth||parseInt(img.parentNode.style.height,10)>img.minheight)) { mw=Math.max(img.minwidth,Math.min(img.maxwidth,Math.round(ew*ct/st+sw))); mx=Math.round(ex*ct/st+sx); mh=Math.max(img.minheight,Math.min(img.maxheight,Math.round(eh*ct/st+sh))); my=Math.round(ey*ct/st+sy); img.parentNode.style.width=mw+'px'; img.parentNode.style.height=mh+'px'; img.parentNode.style.left=mx+'px'; img.parentNode.style.top=my+'px'; shiftzoom.G(img.infoid).style.visibility='visible'; shiftzoom.G(img.textid).innerHTML=parseInt((mw/img.minwidth)*100)+" / "+parseInt(img.xfactor*100)+" %"; img.parentNode.width=mw; img.parentNode.height=mh; img.parentNode.left=mx; img.parentNode.top=my; img.maxleft=img.parentNode.width-img.minwidth; img.maxtop=img.parentNode.height-img.minheight; ct++; if(img.divbug) {img.parentNode.firstChild.style.width=mw+'px'; img.parentNode.firstChild.style.height=mh+'px';} if((cvi_szimage||ww)&&(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight)) { if(!ww) {setTimeout("shiftzoom._zoomKey("+d+","+ct+","+ww+","+st+","+sw+","+ew+","+sh+","+eh+","+sx+","+ex+","+sy+","+ey+","+nz+")",50);} else {setoverview(); if(cvi_szactive!=null) {cvi_szimage=null;}} }else {setoverview();} }else if(d==1&&(parseInt(img.parentNode.style.width,10)img.minwidth||img.parentNode.height>img.minheight)) { var x=Math.max(0,Math.min(img.maxleft,Math.abs(parseInt(img.parentNode.style.left))-(s?4*h:a?h/4:h))); var y=Math.max(0,Math.min(img.maxtop,Math.abs(parseInt(img.parentNode.style.top))-(s?4*v:a?v/4:v))); img.parentNode.style.left=(x*-1)+'px'; img.parentNode.style.top=(y*-1)+'px'; img.parentNode.left=(x*-1); img.parentNode.top=(y*-1); if(img.overview) {var view=shiftzoom.G(img.viewid).style; view.left=Math.round((Math.abs(parseInt(img.parentNode.style.left))/(img.parentNode.width/img.minwidth))*img.ovsfact)-(img.bmode?2:0)+'px'; view.top=Math.round((Math.abs(parseInt(img.parentNode.style.top))/(img.parentNode.height/img.minheight))*img.ovsfact)-(img.bmode?2:0)+'px'; } if(cvi_szimage) {setTimeout("shiftzoom._panKey("+h+","+v+","+s+","+a+")",50);} } }return false; }, _fadeImage : function(id,o) {var img=shiftzoom.G(id); if(o<=100) {if(img.trident) {img.parentNode.style.filter="alpha(opacity="+o+")";}else {img.parentNode.style.opacity=o/100;} o+=10; window.setTimeout("shiftzoom._fadeImage('"+id+"',"+o+")",30);}else {if(img.buttons&&!img.tod) {shiftzoom.G(img.ctrlid).style.visibility='visible';} if(img.showcoords&&!img.tod) {shiftzoom.G(img.xycoid).style.visibility='visible';} if(img.special&&(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight)) {img.overview=true; img.special=false; shiftzoom._setOverview(img); shiftzoom.G(img.overid).style.visibility="visible";} }return false; }, _fadeInfo : function(id,o) { clearInterval(cvi_sztimer); var img=shiftzoom.G(id), obj=shiftzoom.G(img.infoid); if(o>0&&cvi_szactive==img.id&&!img.zoomin&&!img.zoomout){ if(img.trident) {obj.style.filter="alpha(opacity="+o+")";}else {obj.style.opacity=o/100;} o-=5; cvi_sztimer=setInterval("shiftzoom._fadeInfo('"+id+"',"+o+")",50);} else {if(img.trident) {obj.style.filter="alpha(opacity=100)";}else {obj.style.opacity=1;} obj.style.visibility='hidden';} return false; }, _fadeOut : function(id,o) { var img=shiftzoom.G(id); if(o>0) {if(img.trident) {img.parentNode.style.filter="alpha(opacity="+o+")";}else {img.parentNode.style.opacity=o/100;} o-=10; window.setTimeout("shiftzoom._fadeOut('"+id+"',"+o+")",30);}else {var obj=shiftzoom.G(img.xrefid); obj.src=shiftzoom.G(img.isrcid).src; shiftzoom.G(img.tumbid).src=obj.src; obj.style.msInterpolationMode=img.bicubic; shiftzoom.G(img.isrcid).src=img.trident?null:null; if(img.highres!=obj.src) {img.highres=obj.src;} shiftzoom._fadeIn(id,0);} return false; }, _fadeIn : function(id,o) {var img=shiftzoom.G(id); if(o<=100) {if(img.trident) {img.parentNode.style.filter="alpha(opacity="+o+")";}else {img.parentNode.style.opacity=o/100;} o+=10; window.setTimeout("shiftzoom._fadeIn('"+id+"',"+o+")",30);}else {if(img.buttons&&!img.tod) {shiftzoom.G(img.ctrlid).style.visibility="visible";} if(img.overview&&(img.parentNode.width>img.minwidth||img.parentNode.height>img.minheight)) {shiftzoom.G(img.overid).style.visibility="visible";} if(img.showcoords&&!img.tod) {shiftzoom.G(img.xycoid).style.visibility="visible";}} return false; }, _whilePan : function(e) { var img=shiftzoom._shiftzoom; e=e?e:window.event; var x=Math.max(0,Math.min(img.maxleft,Math.abs(parseInt(img.parentNode.style.left))-(e.clientX-img.mouseX))); var y=Math.max(0,Math.min(img.maxtop,Math.abs(parseInt(img.parentNode.style.top))-(e.clientY-img.mouseY))); img.parentNode.style.left=(x*-1)+'px'; img.parentNode.style.top=(y*-1)+'px'; img.parentNode.left=(x*-1); img.parentNode.top=(y*-1); img.mouseX=e.clientX; img.mouseY=e.clientY; return false; }, _stopPan : function() { var view, butt, img=shiftzoom._shiftzoom; document.onmousemove=null; document.onmouseup=null; if(img.gecko||img.presto) {img.style.cursor="move";} else {img.style.cursor=img.pointer;}if(img.overview) { view=shiftzoom.G(img.viewid).style; view.left=Math.round((Math.abs(parseInt(img.parentNode.style.left))/(img.parentNode.width/img.minwidth))*img.ovsfact)-(img.bmode?2:0)+'px'; view.top=Math.round((Math.abs(parseInt(img.parentNode.style.top))/(img.parentNode.height/img.minheight))*img.ovsfact)-(img.bmode?2:0)+'px'; } shiftzoom._shiftzoom=null; return false; }, _startMove : function(e) { if(!e) {e=window.event; var view=e.srcElement;}else {var view=e.target;} var l=parseInt(view.style.left), t=parseInt(view.style.top); cvi_szimage=view.id.substring(0,view.id.indexOf("_")); view.style.cursor="default"; view.mouseX=e.clientX; view.mouseY=e.clientY; document.onmousemove=shiftzoom._whileMove; document.onmouseup=shiftzoom._stopMove; return false; }, _whileMove : function(e) { if(!e) {e=window.event; var view=e.srcElement;}else {var view=e.target;} var cen=view.id.split("_"), img=shiftzoom.G(cvi_szimage); if(view && cen[cen.length-1]=='view' && view.maxleft && view.maxtop) { var l=Math.max(0,Math.min(view.maxleft,Math.abs(parseInt(view.style.left))+(e.clientX-view.mouseX))); var t=Math.max(0,Math.min(view.maxtop,Math.abs(parseInt(view.style.top))+(e.clientY-view.mouseY))); view.style.left=(l-(img.bmode?2:0))+'px'; view.style.top=(t-(img.bmode?2:0))+'px'; view.mouseX=e.clientX; view.mouseY=e.clientY; var x=Math.max(0,Math.min(img.maxleft,Math.abs(l*(img.parentNode.width/img.minwidth)*(1/img.ovsfact)))); var y=Math.max(0,Math.min(img.maxtop,Math.abs(t*(img.parentNode.height/img.minheight)*(1/img.ovsfact)))); img.parentNode.style.left=(x*-1)+'px'; img.parentNode.style.top=(y*-1)+'px'; img.parentNode.left=(x*-1); img.parentNode.top=(y*-1); }else {document.onmousemove=null; document.onmouseup=null; img.onmousedown=shiftzoom._catchKey; cvi_szimage=null;} return false; }, _stopMove : function() {document.onmousemove=null; document.onmouseup=null; shiftzoom.G(cvi_szimage).onmousedown=shiftzoom._catchKey; cvi_szimage=null; return false;} } shiftzoom.defaultCurpath="js/lib/shiftzoom/shiftzoom/images/cursors/"; } modularjs.loaded["lib.shiftzoom.shiftzoom"] = true; if (!modularjs.loaded["fitbank.ui.ventana"]) { if (!modularjs.loaded["lib.onload"]) { __onload__ = false; addOnLoad = function(f) { if (__onload__) { f(); } else { document.observe("dom:loaded", f); } } addOnLoad(function() { __onload__ = true; }); } modularjs.loaded["lib.onload"] = true; if (!modularjs.loaded["fitbank.evento"]) { /** * Inicializa el evento si no está inicializado y lo devuelve. */ $E = function(e) { // Si está extendido, simplemente devolverlo if (window.event && window.event.inicializado) { return window.event.evento; } else if (e && e.inicializado) { return e.evento; } // Si se pasó un objeto tipo Evento usar ese. var evento = e && e.evento ? e : e && new Evento(e); if (evento) { evento.evento.evento = evento; } return evento; }; /** * Clase Evento - Clase que contiene los manejadores de eventos disparados desde * los elementos. Se recomienda usar mejor el método $E en lugar de esta clase * directamente. */ var Evento = Class.create( { /** * Es el evento en si */ evento: null, /** * Contiene la tecla si se apalastó una tecla */ tecla: null, /** * Verdadero si se aplastó alt */ alt: null, /** * Verdadero si se aplastó ctrl */ ctrl: null, /** * Verdadero si se aplastó shift */ shift: null, /** * Contiene el caracter correspondiente a la tecla */ caracter: null, /** * Contiene el elemento que lanzó el evento */ elemento: null, /** * Contiene la coordenada en x del elemento que lanzó el evento */ x: null, /** * Contiene la coordenada en y del elemento que lanzó el evento */ y: null, /** * @private */ initialize: function(e, debug) { // capturar el evento para todos los navegadores // capturar tecla del evento if (window.event) { this.evento = window.event; // IE this.tecla = window.event.keyCode; } else { this.evento = e; this.tecla = e.which; } this.initTeclas(); switch (this.tecla) { case this.SLASH: this.caracter = '/'; break; case this.DOT: this.caracter = '.'; break; case this.DASH: this.caracter = '-'; break; case this.BACKSLASH: this.caracter = '\\'; break; default: if (!this.esEspecial()) { this.caracter = String.fromCharCode(this.tecla); } else { this.caracter = 13; } break; } this.alt = this.evento.altKey; this.ctrl = this.evento.ctrlKey; this.shift = this.evento.shiftKey; // capturar posición del evento if (this.evento.layerX && this.evento.layerY) { this.x = this.evento.layerX; this.y = this.evento.layerY; } else { this.x = this.evento.offsetX; this.y = this.evento.offsetY; } if (window.scrollX && window.scrollY) { this.X = this.evento.clientX + window.scrollX; this.Y = this.evento.clientY + window.scrollY; } else { this.X = this.evento.clientX + document.documentElement.scrollLeft + document.body.scrollLeft; this.Y = this.evento.clientY + document.documentElement.scrollTop + document.body.scrollTop; } // capturar origen del evento if (this.evento.srcElement) { this.elemento = this.evento.srcElement; } else if (this.evento.target) { this.elemento = this.evento.target; } else { Logger.warning("No hay elemento que genere el evento!!!!"); } if (debug) { Logger.debug(this.toString()); } }, toString: function() { var string = ''; string += 'Evento\n'; string += 'evento:' + this.evento + '\n'; string += 'tecla:' + this.tecla + '\n'; string += 'caracter:' + this.caracter + '\n'; string += 'alt:' + this.alt + '\n'; string += 'ctrl:' + this.ctrl + '\n'; string += 'shift:' + this.shift + '\n'; string += 'elemento:' + this.elemento + '\n'; string += 'x:' + this.x + '\n'; string += 'y:' + this.y + '\n'; string += 'X:' + this.X + '\n'; string += 'Y:' + this.Y + '\n'; return string; }, /** * Cancela la propagación del evento. * * @param (Event) * e Evento pasado por el browser. */ cancelar: function(e) { if (!e || !this.esEspecial()) { try { event.keyCode = 0; } catch (e) { } try { event.returnValue = false; } catch (e) { } Event.stop(this.evento); } }, /** * Verifica si una tecla especial fue presionada. * * @return (Boolean) Verdadero si una tecla especial fue presionada */ esEspecial: function() { return !this.tecla || (this.tecla == this.TAB) || (this.tecla == this.BACKSPACE) || (this.tecla == this.ENTER) || (this.tecla == this.FIN) || (this.tecla == this.INICIO) || (this.tecla == this.IZQUIERDA) || (this.tecla == this.ARRIBA) || (this.tecla == this.DERECHA) || (this.tecla == this.ABAJO) || (this.tecla == this.ESC) || (this.tecla == this.SUPR); }, /** * Verifica si una tecla especial fue presionada. * * @return (Boolean) Verdadero si una tecla especial fue presionada */ esIngreso: function() { return !this.esEspecial() || (this.tecla == this.BACKSPACE) || (this.tecla == this.SUPR); }, esFuncion: function() { return !Object.isNumber(this.tecla) || (this.F1 == this.tecla) || (this.F2 == this.tecla) || (this.F3 == this.tecla) || (this.F4 == this.tecla) || (this.F5 == this.tecla) || (this.F6 == this.tecla) || (this.F7 == this.tecla) || (this.F8 == this.tecla) || (this.F9 == this.tecla) || (this.F10 == this.tecla) || (this.F11 == this.tecla) || (this.F12 == this.tecla); }, /** * Encuentra la longitud de la selección en el campo donde se disparó el * evento. * * @return (int) La longitud de la selección */ getSelLength: function() { if (document.getSelection) { return (document.getSelection() + '').length; } else if (this.evento.elemento && Object.isNumber(this.evento.elemento.selectionStart)) { return this.evento.elemento.selectionEnd - this.evento.elemento.selectionStart; } else if (window.getSelection) { return (window.getSelection() + '').length; } else if (document.selection) { return (document.selection.createRange().text + '').length; } else { return -1; } }, /** * @private */ initTeclas: function() { this.TAB = 9; this.BACKSPACE = 8; this.ENTER = 13; this.SHIFT = 16; this.CTRL = 17; this.ESC = 27; this.ESPACIO = 32; this.PGUP = 33; this.PGDOWN = 34; this.FIN = 35; this.INICIO = 36; this.IZQUIERDA = 37; this.ARRIBA = 38; this.DERECHA = 39; this.ABAJO = 40; this.INS = 45; this.SUPR = 46; this.PUNTO = 190; this.DECIMAL = 110; this.F1 = 112; this.F2 = 113; this.F3 = 114; this.F4 = 115; this.F5 = 116; this.F6 = 117; this.F7 = 118; this.F8 = 119; this.F9 = 120; this.F10 = 121; this.F11 = 122; this.F12 = 123; this.DOT = 190; this.SLASH = 191; if (Prototype.Browser.IE) { this.DASH = 189; } else { this.DASH = 109; } this.BACKSLASH = 220; } }); } modularjs.loaded["fitbank.evento"] = true; if (!modularjs.loaded["fitbank.util"]) { if (!modularjs.loaded["lib.split"]) { /*! * Cross-Browser Split 1.1.1 * Copyright 2007-2012 Steven Levithan * Available under the MIT License * ECMAScript compliant, uniform cross-browser split method */ /** * Splits a string into an array of strings using a regex or string separator. Matches of the * separator are not included in the result array. However, if `separator` is a regex that contains * capturing groups, backreferences are spliced into the result each time `separator` is matched. * Fixes browser bugs compared to the native `String.prototype.split` and can be used reliably * cross-browser. * @param {String} str String to split. * @param {RegExp|String} separator Regex or string to use for separating the string. * @param {Number} [limit] Maximum number of items to include in the result array. * @returns {Array} Array of substrings. * @example * * // Basic use * split('a b c d', ' '); * // -> ['a', 'b', 'c', 'd'] * * // With limit * split('a b c d', ' ', 2); * // -> ['a', 'b'] * * // Backreferences in result array * split('..word1 word2..', /([a-z]+)(\d+)/i); * // -> ['..', 'word', '1', ' ', 'word', '2', '..'] */ var split; // Avoid running twice; that would break the `nativeSplit` reference split = split || function (undef) { var nativeSplit = String.prototype.split, compliantExecNpcg = /()??/.exec("")[1] === undef, // NPCG: nonparticipating capturing group self; self = function (str, separator, limit) { // If `separator` is not a regex, use `nativeSplit` if (Object.prototype.toString.call(separator) !== "[object RegExp]") { return nativeSplit.call(str, separator, limit); } var output = [], flags = (separator.ignoreCase ? "i" : "") + (separator.multiline ? "m" : "") + (separator.extended ? "x" : "") + // Proposed for ES6 (separator.sticky ? "y" : ""), // Firefox 3+ lastLastIndex = 0, // Make `global` and avoid `lastIndex` issues by working with a copy separator = new RegExp(separator.source, flags + "g"), separator2, match, lastIndex, lastLength; str += ""; // Type-convert if (!compliantExecNpcg) { // Doesn't need flags gy, but they don't hurt separator2 = new RegExp("^" + separator.source + "$(?!\\s)", flags); } /* Values for `limit`, per the spec: * If undefined: 4294967295 // Math.pow(2, 32) - 1 * If 0, Infinity, or NaN: 0 * If positive number: limit = Math.floor(limit); if (limit > 4294967295) limit -= 4294967296; * If negative number: 4294967296 - Math.floor(Math.abs(limit)) * If other: Type-convert, then use the above rules */ limit = limit === undef ? -1 >>> 0 : // Math.pow(2, 32) - 1 limit >>> 0; // ToUint32(limit) while (match = separator.exec(str)) { // `separator.lastIndex` is not reliable cross-browser lastIndex = match.index + match[0].length; if (lastIndex > lastLastIndex) { output.push(str.slice(lastLastIndex, match.index)); // Fix browsers whose `exec` methods don't consistently return `undefined` for // nonparticipating capturing groups if (!compliantExecNpcg && match.length > 1) { match[0].replace(separator2, function () { for (var i = 1; i < arguments.length - 2; i++) { if (arguments[i] === undef) { match[i] = undef; } } }); } if (match.length > 1 && match.index < str.length) { Array.prototype.push.apply(output, match.slice(1)); } lastLength = match[0].length; lastLastIndex = lastIndex; if (output.length >= limit) { break; } } if (separator.lastIndex === match.index) { separator.lastIndex++; // Avoid an infinite loop } } if (lastLastIndex === str.length) { if (lastLength || !separator.test("")) { output.push(""); } } else { output.push(str.slice(lastLastIndex)); } return output.length > limit ? output.slice(0, limit) : output; }; // For convenience String.prototype.split = function (separator, limit) { return self(this, separator, limit); }; return self; }(); } modularjs.loaded["lib.split"] = true; /** * Namespace Util - Define funciones utilitarias. */ var Util = { //Selectores para encontrar los elementos candidatos a verificar si su valor //ha cambiado, pueden agregarse mas filtros selectors: [ "input:not([readonly='']), select:not([readonly='']), textarea:not([readonly=''])", "[type!='hidden']", ".record, [class*='control']" ], getCaret: function(elemento) { var caret = ''; return caret; }, //Aplicar selectores para encontrar campos candidatos a revisar cambios applySelectors: function() { var target = new Element("input"); var first = true; this.selectors.each(function(selector) { if (first) { target = c.form; first = false; } var selected = Prototype.Selector.select(selector, target); target = new Element("input"); selected.each(function(el) { if(el.type === "select-one") { var tmpInput = new Element("input", { id: el.id, "class": el.className }); tmpInput.value = el.options[el.selectedIndex].value; target.appendChild(tmpInput); } else if(el.type === "checkbox") { var tmpInput = new Element("input", { id: el.id, "class": el.className }); tmpInput.value = el.value; target.appendChild(tmpInput); } else { target.appendChild(el.clone(true)); } }); }); return target.childElements(); }, //Obtener el estatos actual de campos y valores en el formulario getOriginalElements: function() { var elements = {}; var targetElements = Util.applySelectors(); targetElements.each(function(e) { elements[e.id] = e.value; }); return elements; }, //Revisar si hay cambios en los elementos candidatos, segun su estado original checkForChanges: function(originalElements) { if (!originalElements || !c.form || !c.formulario) { return false; } var changes = false; var currentElements = {}; var targetElements = Util.applySelectors(); targetElements.each(function(e) { if(e.type !== "select-one") { currentElements[e.id] = e.value; } else { currentElements[e.id] = e.options[e.selectedIndex].text; } }); $H(originalElements).each(function(pair) { if (currentElements[pair.key]) { var check = pair.value !== currentElements[pair.key]; changes = changes || check; } }); return changes; }, /** * Función que obtiene el valor del nombre de la clase css. * * @param className * Valor del nombre de la clase css. */ getStyleClass: function(className) { for ( var s = 0; s < document.styleSheets.length; s++) { if (document.styleSheets[s].rules) { for ( var r = 0; r < document.styleSheets[s].rules.length; r++) { if (document.styleSheets[s].rules[r].selectorText == '.' + className) { return document.styleSheets[s].rules[r]; } } } else if (document.styleSheets[s].cssRules) { for ( var r = 0; r < document.styleSheets[s].cssRules.length; r++) { if (document.styleSheets[s].cssRules[r].selectorText == '.' + className) { return document.styleSheets[s].cssRules[r]; } } } } return null; }, encodeHTML: function(string) { return string.replace(/&/g, "&").replace(//g, ">"); }, firstUpperOtherLower: function(string) { return string.charAt(0).toUpperCase() + string.slice(1).toLowerCase(); }, getContentWindow: function(iframe) { iframe = $(iframe); return iframe.contentWindow || iframe; }, getMensaje: function(mensajes, msg) { var mobileMsg = msg + "_MOBILE"; if(window.Mobile && mensajes[mobileMsg]) { return mensajes[mobileMsg]; } else { return mensajes[msg]; } }, /** * Inicializa un elemento para que use un oculto. */ initHtmlElement: function(elementId, reverse) { var elemento = $(elementId); var oculto = $(elementId + "_oculto"); if (reverse && reverse == "1") { oculto.widget = oculto; oculto.oculto = oculto; } else { oculto.widget = elemento; oculto.oculto = oculto; } elemento.oculto = oculto; elemento.widget = elemento; oculto.hide = Element.hideCurry(elemento); oculto.show = Element.showCurry(elemento); }, /** * Inicializa un elemento para que use un oculto. */ initHiddenInput: function(elemento, suffix) { elemento = $(elemento); if (!elemento) { return; } elemento.sync = function(oculto, e) { elemento.changeValue(oculto.value, e && e.options || e); }; elemento.setValueOculto = function (oculto) { oculto.changeValue(elemento.value); }; Util._initHiddenInput(elemento, suffix); }, /** * Inicializa un checkbox para que use un oculto. */ initCheckBox: function(elemento) { elemento = $(elemento); elemento.valueOn = elemento.getAttribute("value-on"); elemento.valueOff = elemento.getAttribute("value-off"); elemento.hide = Element.hideCurry(elemento.next("label")); elemento.show = Element.showCurry(elemento.next("label")); elemento.sync = function(e) { elemento.setChecked(e.target.value == elemento.valueOn, e && e.options || e); }; elemento.fixValue = function() { var value = elemento.checked ? elemento.valueOn : elemento.valueOff; elemento.value = value; return value; }; elemento.setValueOculto = function (oculto) { oculto.value = elemento.fixValue(); }; Util._initHiddenInput(elemento, "checkbox"); }, /** * Inicializa un combobox para que use un oculto. */ initComboBox: function(elemento) { elemento = $(elemento); elemento.on("keyup", function(e) { elemento.fireDOMEvent("change", { generated: false }); }); elemento.sync = function(e) { for (var i = 0 ; i < elemento.options.length ; i++) { if (e.target && e.target.value == elemento.options[i].value) { elemento.selectedIndex = i; break; } } }; elemento.setValueOculto = function (oculto) { oculto.value = elemento.options[elemento.selectedIndex].value; }; Util._initHiddenInput(elemento, "combobox"); }, /** * Inicializa un elemento para que use un oculto. * Se sincronizan los cambios efectuados por evento onChange */ _initHiddenInput: function(elemento, suffix) { var name = elemento.name; elemento.name = name + "_" + (suffix || "widget"); var oculto = new Element("input", { type: "hidden", name: name, registro: elemento.registro }); elemento.insert( { before: oculto }); oculto.oculto = oculto; elemento.oculto = oculto; oculto.widget = elemento; elemento.widget = elemento; oculto.hide = Element.hide.curry(elemento); oculto.show = Element.show.curry(elemento); if (suffix) { oculto[suffix] = elemento; elemento[suffix] = elemento; } if (elemento.sync) { oculto.on("change", elemento.sync.curry(oculto)); oculto.on("widget:init", elemento.sync.curry(oculto, { load: true })); } if (elemento.setValueOculto) { elemento.on("change", elemento.setValueOculto.curry(oculto)); elemento.setValueOculto(oculto); } return oculto; }, /** * Inicializa una tabla para que tenga scroll. */ initTableScroll: function(elemento, rows, horizontal) { if (Mobile) { return; } elemento = $(elemento); if (elemento.visible()) { Tabs.removeListener(elemento.scrollHandler); Util._initTableScroll(elemento, rows, horizontal); c.resize(elemento); } else if (!elemento.scrollHandler) { elemento.scrollHandler = Util.initTableScroll.curry(elemento, rows, horizontal); Tabs.addListener(elemento.scrollHandler); } }, _initTableScroll: function(elemento, rows, horizontal) { var div = elemento.down("div"); if (div && !div.hasClassName('*-container')) { div = elemento; } var table = elemento.down("table"); var thead = table.down("thead"); var tbody = table.down("tbody"); var tfoot = table.down("tfoot"); var tr = tbody && tbody.down("tr"); var borders = 2; if (!tbody || !tr || (div && div.className.match('dynamic-*').length > 0)) { return; } if (!horizontal) { var resize = function(td) { var w = parseInt(td.getStyle("width")); td.setStyle("width:" + w + "px"); }; table && table.select("th, td").each(resize); var totalHeight = (((thead && thead.getHeight() || 0) + 4) + (rows * ((tr && tr.getHeight() || 0) + borders))); div && div.setStyle({ display: "block", overflowY: "auto", overflowX: "auto", height: totalHeight + "px" }); thead && thead.setStyle({ display: "block" }); tbody && tbody.setStyle({ display: "block" }); tfoot && tfoot.setStyle({ display: "block" }); } else if (horizontal) { // TODO implementar scroll horizontal } else { var height = rows * tr.getHeight() + (thead ? thead.getHeight() : 0) + (tfoot ? tfoot.getHeight() : 0); elemento.setStyle({ overflowY: "auto", overflowX: "hidden", paddingRight: "20px", height: height + "px" }); } }, initDeleteRecord: function(name) { c.$N(name).each(function(elemento) { if (elemento.widget) { elemento = elemento.widget; } elemento.setDisabled(true); elemento.on("change", function(e) { var tr = elemento.up("td").up("tr"); if (elemento.checked) { tr.addClassName("delete-record"); } else { tr.removeClassName("delete-record"); } c.formulario.evalFormulas(elemento); c.calcular(); }); }); }, generarIdUnicoTemporal: function() { // IMPORTANTE: Mantener sincronizado con Servicios.java var id = "_id_"; id += Math.round(Math.random() * 999); id += "_"; id += Math.round(Math.random() * 999); id += "_"; id += Math.round(Math.random() * 999); return id; }, generarIdUnicoPermanente: function() { // IMPORTANTE: Mantener sincronizado con Servicios.java return "ID_" + Util.generarIdUnicoTemporal(); }, eliminarReferenciasCirculares: function(obj) { var seen = {}; function isPrimitive(obj) { var t = typeof obj; return !obj || t == 'string' || t == 'number' || t == 'boolean'; } function deCycle(obj) { var deCycled; if (!isPrimitive(obj)) { seen[obj] = true; } if (obj instanceof Array) { deCycled = []; for (var i = 0; i < obj.length; i += 1) { if (!seen[obj[i]]) { deCycled[i] = deCycle(obj[i]); } } } else if (typeof obj == 'object' && obj) { deCycled = {}; for (var k in obj) { if (obj.hasOwnProperty(k) && !seen[obj[k]]) { try { deCycled[k] = deCycle(obj[k]); } catch(e) { // no hacer nada } } } } else { deCycled = obj; } return deCycled; } return deCycle(obj); }, clean: function(obj) { if (!obj) { return; } try { obj.initialize = null; obj.constructor = null; delete obj.initialize; delete obj.constructor; } catch(e) { // no hacer nada } return obj; }, isError: function(codigo) { // Esto debe ser igual a ManejoExcepcion.isError() return codigo && !/0|.*-0|ok-.*/i.test(codigo); }, /** * Hace un elemento que sea movible. * * @param movableElement El elemento movible * @param handlerElement El elemento que puede mover */ makeMovable: function(movableElement, handlerElement) { handlerElement.unselectable = "on"; handlerElement.onselectstart = function() { return false }; handlerElement.style.userSelect = handlerElement.style.MozUserSelect = "none"; handlerElement.on('mousedown', function(e) { e = $E(e); var initX = e.X; var initY = e.Y; var divx = movableElement.style.left; var divy = movableElement.style.top; var divLeft = divx.substr(0, divx.indexOf('px')) * 1; var divTop = divy.substr(0, divy.indexOf('px')) * 1; var divNewLeft = initX - divLeft; var divNewTop = initY - divTop; handlerElement.moveHandler = Event.on(document.body, 'mousemove', function(e) { e = $E(e); movableElement.style.left = Math.max(0, e.X - divNewLeft) + 'px'; movableElement.style.top = Math.max(0, e.Y - divNewTop) + 'px'; }); }); handlerElement.on('mouseup', function(e) { e = $E(e); if (handlerElement.moveHandler) { handlerElement.moveHandler.stop(); } }); } }; /** * Extensiones para elementos de html */ Element.addMethods({ ensureVisible: function(element) { element = $(element); var parent = element.parentNode; if (parent) { var parentPosition = parent.positionedOffset().top; var minScroll = parentPosition + parent.scrollTop; var maxScroll = parentPosition + parent.scrollTop + parent.getHeight(); var position = element.positionedOffset().top; if (position < minScroll) { parent.scrollTop = position - parentPosition; } else if (position + element.getHeight() > maxScroll) { parent.scrollTop = position + element.getHeight() - parent.getHeight() - parentPosition; } } }, ensureInside: function(element, parent) { element = $(element); parent = ($(parent) || document.viewport); var d = element.getDimensions(); var vd = parent.getDimensions(); var p = element.viewportOffset(); var diff = vd.height - p.top - d.height; if (diff < 0) { element.style.top = (parseInt("0" + element.style.top, 10) + diff) + "px"; } p = element.viewportOffset(); diff = p.top; if (diff < 0) { element.style.top = (parseInt("0" + element.style.top, 10) - diff) + "px"; } p = element.viewportOffset(); diff = vd.width - p.left - d.width; if (diff < 0) { element.style.left = (parseInt("0" + element.style.left, 10) + diff) + "px"; } p = element.viewportOffset(); diff = p.left; if (diff < 0) { element.style.left = (parseInt("0" + element.style.left, 10) - diff) + "px"; } }, center: function(element, parent) { parent = parent || element.getOffsetParent(); var top = (parent.getHeight() - element.getHeight()) / 2; var left = (parent.getWidth() - element.getWidth()) / 2; if (top < 0) { top = 0; } if (left < 0) { left = 0; } element.absolutize(); element.setStyle( { top: top + "px", left: left + "px" }); }, relativize2: function(element) { element = $(element); var pos = element.positionedOffset(); element.relativize(); var newPos = element.positionedOffset(); var dx = pos[0] - newPos[0]; var dy = pos[1] - newPos[1]; element.moveMargin(dx, dy); element.nextSiblings().each(function(sibling) { if (element.visible()) { sibling.moveMargin(dx, dy); } }); }, moveMargin: function(element, dx, dy) { if (dx != 0) { element.style.marginLeft = (parseInt(element.style.marginLeft) + dx) + "px"; } if (dy != 0) { element.style.marginTop = (parseInt(element.style.marginTop) + dy) + "px"; } }, fireDOMEvent: function(element, event, options) { element = $(element); options = Object.extend({ generated: true }, options); if (document.createEventObject){ // dispatch para IE var evt = document.createEventObject(); evt.options = options; return element.fireEvent('on' + event, evt) } else{ // dispatch para firefox + others var evt = document.createEvent("HTMLEvents"); evt.initEvent(event, true, true); // event type,bubbling,cancelable evt.options = options; return !element.dispatchEvent(evt); } }, getOriginalDimensions: function(element) { element = $(element); var currentW; var currentH; if (element.tagName == "IMG") { currentW = element.width; currentH = element.height; } else { currentW = element.getWidth(); currentH = element.getHeight(); } element.removeAttribute("width"); element.removeAttribute("height"); var h = element.getHeight(); var w = element.getWidth(); if (element.tagName == "IMG") { element.width = currentW; element.height = currentH; } else { element.setStyle({ width: currentW + "px", height: currentH + "px" }); } return {width: w, height: h}; }, hide: function(element) { element = $(element); element.style.display = 'none'; var nextElement = element.next(); if (nextElement && nextElement.hasClassName("asistente-icono")) { nextElement.style.display = 'none'; } return element; }, show: function(element) { element = $(element); element.style.display = ''; var nextElement = element.next(); if (nextElement && nextElement.hasClassName("asistente-icono")) { nextElement.style.display = ''; } return element; }, // Metodos para optimizar carga de formularios solamente hideCurry: function(element) { return function() { element.hide(); }; }, showCurry: function(element) { return function() { element.show(); }; }, syncCurry: function(element) { return function(e) { element.sync(e); }; }, setValueOcultoCurry: function(element, oculto) { return function() { element.setValueOculto(oculto); }; } }); /** * Estos metodos sirven para elementos de tipo Form.Element aunque hay que * registrarlos en Element directamente */ Element.addMethods({ /** * Cambia el valor de un elemento de un formulario. * * @param element Elemento donde se cambia el valor * @param newValue Nuevo valor del elemento * @param options Opciones donde se especifica si el evento es parcial */ changeValue: function(element, value, options) { if (element.nodeName == "SPAN" || element.nodeName == "LABEL") { var originalValue = element.innerHTML; if (value != originalValue) { element.update(value); return true; } else { return false; } } var originalValue = element.value; element._formatValue(value, options); if (originalValue != element.value) { element.fireDOMEvent("change", options); return true; } else { return false; } }, _processValue: function(element, options) { element = $(element); var originalValue = element.value; var cambios = false; if (element.value != "") { Validar.ok(element, "required"); } else { Validar.ok(element, "empty"); } element._formatValue(element.value, options); if (originalValue != element.value) { if (!options.partial) { element.fireDOMEvent("change", options); } cambios = true; } c.formulario.evalFormulas(element); return cambios; }, _formatValue: function(element, value, options) { var newValue = value; var className = null; options = options || {}; try { // Formatear valor con todos los formateadores (element.formatters || $A()).each(function(formatter) { className = formatter.constructor.simpleClassName; newValue = formatter.transform(newValue, options.partial); Validar.ok(element, className); }); } catch(e) { Validar.error(element, e, className); return element.value; } newValue = typeof newValue != "undefined" && newValue != null && newValue.toString() || ""; if (element.value != newValue) { var pos = element.value.length - element.getCaretPosition(); //Hack temporal. Ver Incidencia #8266, bug Chrome #152537 element.value = ""; element.value = newValue; element.setCaretPosition(element.value.length - pos, false); } (element.formatters || $A()).each(function(formatter) { formatter.changeValues(element, options.partial); }); }, /** * Obtiene el objectValue o value adecuadamente * * @param element Elemento de donde obtener el objectValue */ getObjectValue: function(element) { element = $(element); return typeof element.objectValue != "undefined" ? element.objectValue : element.value; }, /** * Obtiene el elemento visible de un objeto HTML * * @param element Elemento de referencia */ getWidget: function(element) { element = $(element); return typeof element.widget != "undefined" ? element.widget : element; }, getCaretPosition: function(element) { element = $(element); if (!element.focused) { return -1; } try { if (element.type === "date" || element.type === "number") { return element.value.length; } if (typeof document.selection != "undefined") { // IE var sel = document.selection.createRange(); sel.moveStart('character', -element.value.length); return sel.text.length; } else if (typeof element.selectionStart != "undefined") { // Otros browsers return element.selectionStart; } } catch(e) { console.log("No se puede obtener la posicion en el texto: " + e); } return element.value.length; }, setCaretPosition: function(element, pos, focus) { element = $(element); if (!element.focused && !focus) { return; } else { element.focus(); } if (element.type === "date" || element.type === "number") { return; } if (typeof element.createTextRange != "undefined") { // IE var range = element.createTextRange(); range.collapse(true); range.moveEnd('character', pos); range.moveStart('character', pos); range.select(); } else if (typeof element.setSelectionRange != "undefined") { // Otros browsers element.setSelectionRange(pos, pos); } }, setChecked: function(elemento, checked, options) { if (!Object.isElement(elemento)) { elemento = c.$(elemento); } if (elemento.widget) { elemento = elemento.widget; } elemento.checked = checked; elemento.fireDOMEvent("change", options); }, setDisabled: function(elemento, disabled) { if (!Object.isElement(elemento)) { elemento = c.$(elemento); } if (elemento.widget) { elemento = elemento.widget; } if (elemento.type != "checkbox" && elemento.type != "radio" && elemento.type != "image" && elemento.type != "select-one" && elemento.type != "button") { elemento.readOnly = disabled; } else { elemento.disabled = disabled; } if (elemento.hasDatePicker) { datePickerController[disabled ? "disable" : "enable"](elemento.id); } elemento.tabIndex = disabled ? -1 : elemento.originalTabIndex; }, getScrollFromBottom: function(elemento) { return elemento.scrollHeight - elemento.clientHeight - elemento.scrollTop; } }); String.prototype.hashCode = function(){ var hash = 0; for (var i = 0; i < this.length; i++) { hash = 31 * hash + this.charCodeAt(i); hash = hash & hash; } return hash; }; String.prototype.capitalizeFirstLetterWords = function() { var l = this.split(" "); var result = ""; var counter = 0; l.map(function(i) { result = result + Util.firstUpperOtherLower(i) + (counter === l.lenght ? "" : " "); }); return result; }; /** * Obtiene un array de elementos dado su name. Los parametros pueden ser así: * * $N(name) => Obtiene un array de elementos buscando en toda la página * $N(name, index) => Obtiene el elemento indicado del array * $N(base, name) => Obtiene un elemento con el name indicado dentro de la base * $N(base, name, index) => Obtiene el elemento indicado del array * * @param a Ver arriba. * @param b Ver arriba. * @param c Ver arriba. */ var $N = function(a, b, c) { var base = null; var index = null; var name = null; if (typeof c == "number") { base = a; name = b; index = c; } else if (typeof b == "number") { base = document; name = a; index = b; } else if (a && (a.querySelectorAll || base.getElementsByName || a.elements || a.select)) { base = a; name = b; } else { base = document; name = a; } var isNumber = (typeof index == "number"); if (!name) { return isNumber ? null : []; } var elements = null; if (base.querySelectorAll) { // Nativo rapido if (isNumber) { return base.querySelector("#c_" + name + "_" + index); } elements = $A(base.querySelectorAll("*[name='" + name + "']")); } else if (base.getElementsByName) { // También rápido elements = $A(base.getElementsByName(name)); } else if (base.elements) { // Optimizado elements = $A(); var els = base.elements; for (var i = 0; i < els.length; i++) { if (els[i].name == name) { elements.push(els[i]); } } } else { // Mas lento elements = base.select("*[name='" + name + "']"); } return isNumber ? elements[index] : elements; }; /** * Obtiene un array de valores de un elemento dado su name. * * @param i, j, k se pasan directo a $N */ var $V = function(i, j, k) { var n = $N(i, j, k); return Object.isArray(n) ? n.invoke("getObjectValue") : n && n.getObjectValue(); }; /** * Obtiene un array de widgets visibles de un elemento dado su name. * * @param i, j, k se pasan directo a $N */ var $W = function(i, j, k) { var n = $N(i, j, k); return Object.isArray(n) ? n.invoke("getWidget") : n && n.getWidget(); }; var trim = function(s) { Logger.trace("Usar mejor s.strip en vez de trim"); return s.strip(); }; var recargar = function(modulo) { modularjs.loading[modulo] = false; modularjs.loaded[modulo] = false; include(modulo); }; var rethrow = function(transport, e) { console && console.log("Exception", transport, e, arguments); Estatus.mensaje(e && e.message || Util.getMensaje(Mensajes, 'fitbank.validar.ERROR'), e && e.stack, "error"); throw e; }; var deepCopy = function(object) { if (!object || typeof object != "object") { return object; } else if (Object.isArray(object)) { var copy = $A(); object.each(function(value) { copy.push(deepCopy(value)); }); return copy; } else { var copy = new object.constructor(); $H(object).each(function(pair) { copy[pair.key] = deepCopy(pair.value); }); return copy; } }; var copyConstructor = function(params) { if (this.id && this.id.startsWith("_id_")) { this.id = Util.generarIdUnicoTemporal(); } $H(this).each(function(pair) { this[pair.key] = deepCopy(pair.value); }, this); if (params) { Object.extend(this, params); } if (this.constructor.className) { this.className = this.constructor.className; this.simpleClassName = this.constructor.simpleClassName; } }; var caducar = function () { window.onbeforeunload = null; document.location.href = "caducidad.html#cerrar"; } Object.extend(Function.prototype, (function() { var slice = Array.prototype.slice; function tryCatch() { var args = slice.call(arguments, 0); try { return this.apply(this, args); } catch (e) { Estatus.mensaje(e, e && e.stack, 'error'); throw e; } } function bindTryCatch() { var args = slice.call(arguments, 0); var f = this.bind.apply(this, args); return f.tryCatch.bind(f); } return { tryCatch: tryCatch, bindTryCatch: bindTryCatch, tryDefer: tryCatch.defer } })()); var tryEval = function(code) { return (function() { eval(code); }).tryCatch(); }; var tryEvent = function(nameOrId, event, func) { var elements = c.$N(nameOrId) || [ $(nameOrId) ]; elements.each(function(element) { if (element.widget) { element = element.widget; } element.on(event, func.bindTryCatch(element)); }); }; Ajax.Request.addMethods({ abort: function() { this.transport.onreadystatechange = Prototype.emptyFunction; this.transport.abort(); if (Ajax.activeRequestCount > 0) { Ajax.activeRequestCount--; } } }); document.disableContextMenu = function() { if (this.captureEvents) { this.captureEvents(Event.MOUSEDOWN); this.onmousedown = function(e) { if (e.which == 2 || e.which == 3) { return false; } }; } this.oncontextmenu = function() { return false; }; }; } modularjs.loaded["fitbank.util"] = true; /** * Clase Ventana - Representa una ventana con cualquier tipo de contenido. */ var Ventana = Class.create({ /** * Título de la ventana. */ titulo: null, /** * Contenedor del título de la ventana. */ divTitulo: null, /** * Elemento dentro del que va a crear la ventana si se lo especifica. */ elementoPadre: null, /** * Elemento junto al que va a crear la ventana si se lo especifica. */ elemento: null, /** * Posición en x de la ventana. */ x: null, /** * Posición en y de la ventana. */ y: null, /** * Ancho de la ventana. */ w: null, /** * Alto de la ventana. */ h: null, /** * Condición de centrado de la ventana. */ centrada: true, /** * Contenido de la ventana. */ contenido: null, /** * Ver fondo oscuro. */ verFondo: true, /** * Activar el bloqueo de ventanas modales. Cuando el bloqueo está activado, cualquier cambio que se haga a la * ventana causa que se cierre la sesión. */ bloqueoModal: false, /** * Indica si se debe destruir al cerrar. */ destruirAlCerrar: true, /** * Indica si se puede seleccionar el texto del contenido. */ selectable: true, /** * Indica si se puede mover la ventana. */ movable: true, /** * @private */ table: null, /** * @private */ barra: null, /** * @private */ onVer: function() { if (!this.selectable) { this.divContenido.onmousedown = function() { return false; }; } }, /** * @private */ onCerrar: function() { }, /** * @private */ initialize: function(parametros) { this.verFondo = Parametros["fitbank.ui.ventana.fondo.ENABLED"] == "true"; this.movable = Parametros["fitbank.ui.ventana.MAKE_MOVABLE"] == "true"; this.bloqueoModal = Parametros["fitbank.ui.ventana.BLOQUEOMODAL"] == "true"; Object.extend(this, parametros); if (!this.elementoPadre) { this.elementoPadre = document.body; } else { this.elementoPadre = $(this.elementoPadre); } if (this.elemento) { this.elemento = $(this.elemento); this.centrada = false; } if (Mobile) { this.centrada = false; this.x = 0; this.y = 0; this.w = "100%"; this.h = "100%"; this.verFondo = false; this.movable = false; } this.crear(); this.insertar(); }, /** * @private */ crear: function() { this.div = new Element('div', { className: "ventana" }).hide(); var x = function(n) { return n + (Object.isNumber(n) ? 'px' : ''); }; if (this.x) { this.div.style.left = x(this.x); } if (this.y) { this.div.style.top = x(this.y); } var divTitulo = new Element("div", { className: "titulo holo-action-bar" }); this.div.insert(divTitulo); var cerrar = new Element("a", { 'href': "#", 'class': "holo-up" }).update(new Element("img", { src: "img/cerrar.png" })); if (Mobile) { divTitulo.insert(new Element("h1").update(cerrar).insert(this.titulo)); } else { divTitulo.insert(cerrar); divTitulo.insert(new Element("span").update(this.titulo || "FitBank")); } cerrar.on("click", this.cerrar.bind(this)); if (this.movable) { Util.makeMovable(this.div, divTitulo); } if (!Mobile) { divTitulo.on("dblclick", function(e) { this.divContenido.toggle(); }.bind(this)); } this.divTitulo = divTitulo; this.divContenido = new Element("div", { className: "contenido" }); this.div.insert(this.divContenido); this.divContenido.style.width = x(this.w); this.divContenido.style.height = x(this.h); if (this.contenido) { this.setContenido(this.contenido); } }, /** * Inserta la ventana en el documento en la posicion necesitada. * * @private */ setContenido: function(contenido) { if (typeof contenido == "string") { contenido = new Element("span").update(contenido); } this.contenido = contenido; this.divContenido.update(this.contenido); }, /** * Inserta la ventana en el documento en la posicion necesitada. * * @private */ insertar: function() { if (this.elemento) { Element.insert(this.elemento, { after: this.div }); } else { Element.insert(this.elementoPadre, this.div); } }, _getSecureModalStyle: function() { return Object.toJSON(new copyConstructor(getComputedStyle(Ventana.fondo))); }, /** * Muestra la ventana. */ ver: function() { this.insertar(); if (this.verFondo) { Ventana.fondo.show(); c && c.form && c.form.setStyle("pointer-events: none"); var style = this._getSecureModalStyle(); if (this.bloqueoModal) { this.verFondoInterval = setInterval(function () { if (!Ventana.fondo.visible() || !Ventana.fondo.parentElement || style != this._getSecureModalStyle()) { clearInterval(this.verFondoInterval); alert("Acción no permitida"); Entorno.caducar(null); } }.bind(this), 1000); } Ventana.abiertas++; } this.div.show(); Element.addClassName.defer(this.div, "visible"); var maxTamano = document.viewport.getHeight() - (Mobile ? 0 : 10); if (this.div.getHeight() > maxTamano) { this.div.setStyle({ height: maxTamano + "px" }); this.divContenido.setStyle({ height: (maxTamano - this.divTitulo.getHeight() - 20) + "px" }); } if (this.centrada) { this.div.style.position = "absolute"; if (this.contenido.getWidth() && !this.w) { this.div.setStyle({ width: (this.contenido.getWidth() + 20) + "px" }); } this.div.center(); } this.visible = true; this.onVer(); }, /** * Esconde la ventana. */ esconder: function() { if (this.visible) { if (this.verFondo) { Ventana.abiertas--; if (!Ventana.abiertas) { Ventana.fondo.hide(); c && c.form && c.form.setStyle("pointer-events: initial"); this.bloqueoModal && this.verFondoInterval && clearInterval(this.verFondoInterval); } } (function() { this.div.hide(); this.visible = false; }).bind(this).delay(0.2); this.div.removeClassName("visible"); } }, /** * Cierra la ventana. */ cerrar: function() { if (this.onCerrar() !== false) { this.esconder(); if (this.destruirAlCerrar) { this.destruir.bind(this).delay(0.2); } } }, /** * Destruye la ventana. */ destruir: function() { this.div.remove(); } }); addOnLoad(function() { Ventana.fondo = new Element('div', { className: "ventana-fondo" }); document.body.appendChild(Ventana.fondo); Ventana.fondo.setOpacity(0.8); Ventana.fondo.hide(); Ventana.abiertas = 0; }); } modularjs.loaded["fitbank.ui.ventana"] = true; /** * Namespace Escaneo - Contiene funciones para manejar el escaneo. */ var Escaneo = { webCamInterval: null, BASE: "http://localhost:1089/", escanear : function(trabajoEscaneo, opciones) { trabajoEscaneo = new ScanningJob(trabajoEscaneo); trabajoEscaneo.query = $H({ json: Object.toJSON(Util.clean(trabajoEscaneo)) }); trabajoEscaneo.pagina = 0; // Opciones por default trabajoEscaneo.opciones = { crossDomain: true, paginar: false, elemento: null, onComplete: function() {}, onCancel: function() {} } if (Object.isFunction(opciones)) { trabajoEscaneo.opciones.onComplete = opciones; } else if (Object.isElement(opciones)) { trabajoEscaneo.opciones.elemento = opciones; } else { Object.extend(trabajoEscaneo.opciones, opciones || {}); } var contenido = new Element("div"); var ventana = new Ventana({ titulo: "Escanear", contenido: contenido, w: 640, h: 480 }); // Crear imagen (con contenedor) contenido.insert(Escaneo._crearImagen(trabajoEscaneo)); // Compara Tipo Normal o Photo if (trabajoEscaneo.scannerType == ScannerType.PHOTO) { contenido.insert(Escaneo._crearControlesWebCam(trabajoEscaneo, ventana)); } else { contenido.insert(Escaneo._crearControles(trabajoEscaneo, ventana)); } ventana.ver(); Escaneo._hacerPedido(trabajoEscaneo); }, _crearImagen: function(trabajoEscaneo) { var w = trabajoEscaneo.w * trabajoEscaneo.resolution; var h = trabajoEscaneo.w * trabajoEscaneo.resolution; if (w > 600) { h = h * 600 / w; w = 600; } if (h > 350) { w = w * 350 / h; h = 350; } var divImagen = new Element("div", { className: "escaneo-imagen-container" }).setStyle({ width: (w + 40) + "px", height: (h + 40) + "px" }); var imagen = new Element("img", { src: "img/blanco.png", width: w, height: h }); divImagen.insert(imagen); trabajoEscaneo.imagenId = imagen.identify(); return divImagen; }, _crearControlesWebCam: function(trabajoEscaneo, ventana) { var controles = new Element("div", { className: "escaneo-botones" }); var tomarFoto = new Element("button").update("Capturar"); var cancelar = new Element("button").update("Cancelar"); //Check sirve para envair peticiones/s al scanner-server var chkWebCamInterval = new Element("input", { type: "checkbox", value: "0" }); //Boton de guardar trabajoEscaneo.guardar = new Element("button", { title: "Guardar esta pagina y cerrar la ventana." }).update("Terminar"); controles.insert(tomarFoto); controles.insert(trabajoEscaneo.guardar); controles.insert(cancelar); controles.insert(chkWebCamInterval); tomarFoto.on("click", function() { if (chkWebCamInterval.checked) { clearTimeout(Escaneo.webCamInterval.timeout); chkWebCamInterval.checked = false; } else { Escaneo._hacerPedido(trabajoEscaneo); } }); cancelar.on("click", function() { if (Escaneo.webCamInterval) { clearTimeout(Escaneo.webCamInterval.timeout); } ventana.cerrar(); trabajoEscaneo.opciones.onCancel(trabajoEscaneo); }); trabajoEscaneo.guardar.on("click", function() { if (Escaneo.webCamInterval) { clearTimeout(Escaneo.webCamInterval.timeout); } Escaneo._guardar(trabajoEscaneo); ventana.cerrar(); }); chkWebCamInterval.on("change", function() { if (chkWebCamInterval.checked) { Escaneo.webCamInterval = function() { Escaneo._hacerPedido(trabajoEscaneo); Escaneo.webCamInterval.timeout = setTimeout(Escaneo.webCamInterval, 1500); } Escaneo.webCamInterval(); } else { clearTimeout(Escaneo.webCamInterval.timeout); } }); return controles; }, _crearControles: function(trabajoEscaneo, ventana) { var controles = new Element("div", { className: "escaneo-botones" }); var label = new Element("span").update("Pagina 1: "); controles.insert(label); /////////////////////////////////////////////////////// // Boton de escanear var escanear = new Element("button").update("Re-escanear"); controles.insert(escanear); escanear.on("click", function() { Escaneo._hacerPedido(trabajoEscaneo); }); /////////////////////////////////////////////////////// // Pagina actual trabajoEscaneo.siguiente = new Element("button", { title: "Guardar esta pagina y escanear la siguiente pagina." }).update("Siguiente"); controles.insert(trabajoEscaneo.siguiente); trabajoEscaneo.siguiente.disabled = true; if (!trabajoEscaneo.opciones.paginar) { trabajoEscaneo.siguiente.hide(); } trabajoEscaneo.siguiente.on("click", function() { Escaneo._guardar(trabajoEscaneo); label.update("Pagina " + (++trabajoEscaneo.pagina + 1) + ": "); Escaneo._hacerPedido(trabajoEscaneo); }); /////////////////////////////////////////////////////// // Boton de guardar trabajoEscaneo.guardar = new Element("button", { title: "Guardar esta pagina y cerrar la ventana." }).update("Terminar"); controles.insert(trabajoEscaneo.guardar); trabajoEscaneo.guardar.disabled = true; trabajoEscaneo.guardar.on("click", function() { Escaneo._guardar(trabajoEscaneo); ventana.cerrar(); }); /////////////////////////////////////////////////////// // Boton de cancelar var cancelar = new Element("button").update("Cancelar"); controles.insert(cancelar); if (trabajoEscaneo.opciones.paginar) { cancelar.hide(); } cancelar.on("click", function() { ventana.cerrar(); trabajoEscaneo.opciones.onCancel(trabajoEscaneo); }); /////////////////////////////////////////////////////// // Imagen de progreso trabajoEscaneo.progreso = new Element("img", { src: "img/blanco.png", width: 56, height: 21 }); controles.insert(trabajoEscaneo.progreso); return controles; }, _hacerPedido: function(trabajoEscaneo) { var cb = Escaneo._previsualizar.curry(trabajoEscaneo); var url = Escaneo.BASE + 'preview/default/imagen.jpg'; if (trabajoEscaneo.scannerType == ScannerType.NORMAL) { trabajoEscaneo.progreso.src = "img/progreso2.gif"; } if (trabajoEscaneo.opciones.crossDomain) { var unique = Math.random(); trabajoEscaneo.query.set("callback", "Escaneo['" + unique + "']"); var script = new Element("script", { src: url + '/data.js?' + trabajoEscaneo.query.toQueryString() }); Escaneo[unique] = function(json) { cb({ responseJSON: json }); script.remove(); } $$("head")[0].insert(script); } else { new Ajax.Request(url + '/data.json', { parameters: trabajoEscaneo.query, onComplete: cb }); } }, _previsualizar: function(trabajoEscaneo, response) { trabajoEscaneo.data = response.responseJSON.data; trabajoEscaneo.guardar.disabled = false; if (trabajoEscaneo.siguiente) { trabajoEscaneo.siguiente.disabled = false; trabajoEscaneo.progreso.src = "img/blanco.png"; } Escaneo._verImagen(trabajoEscaneo); }, _verImagen: function(trabajoEscaneo) { var imagen = $(trabajoEscaneo.imagenId); var url = "data:image/jpeg;base64," + trabajoEscaneo.data; if (imagen.parentNode.hasClassName("escaneo-imagen-container")) { imagen.src = url; if (trabajoEscaneo.scannerType == ScannerType.NORMAL) { imagen.onload = function() { shiftzoom.add(imagen, { buttons: false }); imagen.onload = null; }; } } else { shiftzoom.source(imagen, url, true); } }, _guardar: function(trabajoEscaneo) { trabajoEscaneo.opciones.onComplete(trabajoEscaneo); if (trabajoEscaneo.opciones.elemento) { trabajoEscaneo.opciones.elemento.changeValue(trabajoEscaneo.data); Estatus.mensaje("ESCANEO REALIZADO CORRECTAMENTE, DEBE GUARDAR PARA FINALIZAR LA TRANSACCION", null, null); } } };