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);
}
}
};