// x.js
// X v3.10-mjk, Cross-Browser DHTML Library from Cross-Browser.com
// Copyright (c) 2002,2003 Michael Foster (mike@cross-browser.com)
// This library is distributed under the terms of the LGPL (gnu.org)
//
// July 6, 2003 - Modification by Martin Krolik
//   I changed xLayer to also look for images too.  I added new functions denoted at bottom.

// Variables:
var xVersion='3.10',xOp7=false,xOp5or6=false,xIE4Up=false,xNN4=false,xUA=navigator.userAgent.toLowerCase();
if(window.opera){
  xOp7=(xUA.indexOf('opera 7')!=-1 || xUA.indexOf('opera/7')!=-1);
  if (!xOp7) xOp5or6=(xUA.indexOf('opera 5')!=-1 || xUA.indexOf('opera/5')!=-1 || xUA.indexOf('opera 6')!=-1 || xUA.indexOf('opera/6')!=-1);
}
else if(document.layers) xNN4=true;
else {xIE4Up=document.all && xUA.indexOf('msie')!=-1 && parseInt(navigator.appVersion)>=4;}

// Appearance:
function xShow(e) {
  if(!(e=xGetElementById(e))) return;
  if(e.style && xDef(e.style.visibility)) e.style.visibility='inherit';
  else if(xDef(e.visibility)) e.visibility='show';
}
function xHide(e) {
  if(!(e=xGetElementById(e))) return;
  if(e.style && xDef(e.style.visibility)) e.style.visibility='hidden';
  else if(xDef(e.visibility)) e.visibility='hide';
}
function xZIndex(e,uZ) {
  if(!(e=xGetElementById(e))) return 0;
  if(e.style && xDef(e.style.zIndex)) {
    if(arguments.length>1) e.style.zIndex=uZ;
    else uZ=e.style.zIndex;
  }
  else if(xDef(e.zIndex)) {
    if(arguments.length>1) e.zIndex=uZ;
    else uZ=e.zIndex;
  }
  return uZ;
}
function xColor(e,sColor) {
  if(!(e=xGetElementById(e))) return "";
  var c="";
  if(e.style && xDef(e.style.color)) {
    if(arguments.length>1) e.style.color=sColor;
    c=e.style.color;
  }
  return c;
}
function xBackground(e,sColor,sImage) {
  if(!(e=xGetElementById(e))) return "";
  var bg="";
  if(e.style) {
    if(arguments.length>1) e.style.backgroundColor=sColor;
    if(arguments.length==3) e.style.backgroundImage=(sImage && sImage!="")? "url("+sImage+")" : null;
    bg=e.style.backgroundColor;
  }
  else if(xDef(e.bgColor)) {
    if(arguments.length>1) e.bgColor=sColor;
    bg=e.bgColor;
    if(arguments.length==3) e.background.src=sImage;
  }
  return bg;
}

// Position:
function xMoveTo(e,iX,iY) {
  xLeft(e,iX);
  xTop(e,iY);
}
function xLeft(e,iX) {
  if(!(e=xGetElementById(e))) return 0;
  var css=xDef(e.style);
  if (css && xDef(e.style.left) && typeof(e.style.left)=="string") {
    if(arguments.length>1) e.style.left=iX+"px";
    else {
      iX=parseInt(e.style.left);
      if(isNaN(iX)) iX=0;
    }
  }
  else if(css && xDef(e.style.pixelLeft)) {
    if(arguments.length>1) e.style.pixelLeft=iX;
    else iX=e.style.pixelLeft;
  }
  else if(xDef(e.left)) {
    if(arguments.length>1) e.left=iX;
    else iX=e.left;
  }
  return iX;
}
function xTop(e,iY) {
  if(!(e=xGetElementById(e))) return 0;
  var css=xDef(e.style);
  if(css && xDef(e.style.top) && typeof(e.style.top)=="string") {
    if(arguments.length>1) e.style.top=iY+"px";
    else {
      iY=parseInt(e.style.top);
      if(isNaN(iY)) iY=0;
    }
  }
  else if(css && xDef(e.style.pixelTop)) {
    if(arguments.length>1) e.style.pixelTop=iY;
    else iY=e.style.pixelTop;
  }
  else if(xDef(e.top)) {
    if(arguments.length>1) e.top=iY;
    else iY=e.top;
  }
  return iY;
}
function xPageX(e) {
  if (!(e=xGetElementById(e))) return 0;
  if (xDef(e.pageX)) return e.pageX;
  var x = 0;
  while (e) {
    if (xDef(e.offsetLeft)) x += e.offsetLeft;
    e = xParent(e);
  }
  return x;
}
function xPageY(e) {
  if (!(e=xGetElementById(e))) return 0;
  if (xDef(e.pageY)) return e.pageY;
  var y = 0;
  while (e) {
    if (xDef(e.offsetTop)) y += e.offsetTop;
    e = xParent(e);
  }
  return y;
}
function xSlideTo(e,x,y,uTime) {
  if (!(e=xGetElementById(e))) return;
  if (!e.timeout) e.timeout = 25;
  e.xTarget = x; e.yTarget = y; e.slideTime = uTime; e.stop = false;
  e.yA = e.yTarget - xTop(e); e.xA = e.xTarget - xLeft(e); // A = distance
  e.B = Math.PI / (2 * e.slideTime); // B = period
  e.yD = xTop(e); e.xD = xLeft(e); // D = initial position
  var d = new Date(); e.C = d.getTime();
  if (!e.moving) xSlide(e);
//  if (!e.moving) setTimeout("xSlide('"+e.id+"')", e.timeout);
}
function xSlide(e) {
  if (!(e=xGetElementById(e))) return;
  var now, s, t, newY, newX;
  now = new Date();
  t = now.getTime() - e.C;
  if (e.stop) { e.moving = false; }
  else if (t < e.slideTime) {
    setTimeout("xSlide('"+e.id+"')", e.timeout);
    s = Math.sin(e.B * t);
    newX = Math.round(e.xA * s + e.xD);
    newY = Math.round(e.yA * s + e.yD);
    xMoveTo(e, newX, newY);
    e.moving = true;
  }
  else {
    xMoveTo(e, e.xTarget, e.yTarget);
    e.moving = false;
  }
}

// Size:
function xResizeTo(e,uW,uH) {
  xWidth(e,uW);
  xHeight(e,uH);
}
function xWidth(e,uW) {
  if(!(e=xGetElementById(e)) || (uW && uW<0)) return 0;
  uW=Math.round(uW);
  var css=xDef(e.style);
  if(css && xDef(e.style.width,e.offsetWidth) && typeof(e.style.width)=="string") {
    if(arguments.length>1) xSetCW(e, uW);
    uW=e.offsetWidth;
  }
  else if(css && xDef(e.style.pixelWidth)) {
    if(arguments.length>1) e.style.pixelWidth=uW;
    uW=e.style.pixelWidth;
  }
  else if(xDef(e.clip) && xDef(e.clip.right)) {
    if(arguments.length>1) e.clip.right=uW;
    uW=e.clip.right;
  }
  else if(e.width)
  {
    uW = e.width
  }
  return uW;
}
function xHeight(e,uH) {
  if(!(e=xGetElementById(e)) || (uH && uH<0)) return 0;
  uH=Math.round(uH);
  var css=xDef(e.style);
  if(css && xDef(e.style.height,e.offsetHeight) && typeof(e.style.height)=="string") {
    if(arguments.length>1) xSetCH(e, uH);
    uH=e.offsetHeight;
  }
  else if(css && xDef(e.style.pixelHeight)) {
    if(arguments.length>1) e.style.pixelHeight=uH;
    uH=e.style.pixelHeight;
  }
  else if(xDef(e.clip) && xDef(e.clip.bottom)) {
    if(arguments.length>1) e.clip.bottom=uH;
    uH=e.clip.bottom;
  }
  else if(e.height)
  {
    uH = e.height
  }
  return uH;
}
// thank moz for the next 2000 bytes
function xGetCS(ele,sP){return parseInt(document.defaultView.getComputedStyle(ele,"").getPropertyValue(sP));}
function xSetCW(ele,uW){
  if(uW<0) return;
  var pl=0,pr=0,bl=0,br=0;
  if(xDef(document.defaultView) && xDef(document.defaultView.getComputedStyle)){
    pl=xGetCS(ele,"padding-left");
    pr=xGetCS(ele,"padding-right");
    bl=xGetCS(ele,"border-left-width");
    br=xGetCS(ele,"border-right-width");
  }
  else if(xDef(ele.currentStyle,document.compatMode)){
    if(document.compatMode=="CSS1Compat"){
      pl=parseInt(ele.currentStyle.paddingLeft);
      pr=parseInt(ele.currentStyle.paddingRight);
      bl=parseInt(ele.currentStyle.borderLeftWidth);
      br=parseInt(ele.currentStyle.borderRightWidth);
    }
  }
  else if(xDef(ele.offsetWidth,ele.style.width)){
    ele.style.width=uW+"px";
    pl=ele.offsetWidth-uW;
  }
  if(isNaN(pl)) pl=0; if(isNaN(pr)) pr=0; if(isNaN(bl)) bl=0; if(isNaN(br)) br=0;
  var cssW=uW-(pl+pr+bl+br);
  if(isNaN(cssW)||cssW<0) return;
  else ele.style.width=cssW+"px";
}
function xSetCH(ele,uH){
  if(uH<0) return;
  var pt=0,pb=0,bt=0,bb=0;
  if(xDef(document.defaultView) && xDef(document.defaultView.getComputedStyle)){
    pt=xGetCS(ele,"padding-top");
    pb=xGetCS(ele,"padding-bottom");
    bt=xGetCS(ele,"border-top-width");
    bb=xGetCS(ele,"border-bottom-width");
  }
  else if(xDef(ele.currentStyle,document.compatMode)){
    if(document.compatMode=="CSS1Compat"){
      pt=parseInt(ele.currentStyle.paddingTop);
      pb=parseInt(ele.currentStyle.paddingBottom);
      bt=parseInt(ele.currentStyle.borderTopWidth);
      bb=parseInt(ele.currentStyle.borderBottomWidth);
    }
  }
  else if(xDef(ele.offsetHeight,ele.style.height)){
    ele.style.height=uH+"px";
    pt=ele.offsetHeight-uH;
  }
  if(isNaN(pt)) pt=0; if(isNaN(pb)) pb=0; if(isNaN(bt)) bt=0; if(isNaN(bb)) bb=0;
  var cssH=uH-(pt+pb+bt+bb);
  if(isNaN(cssH)||cssH<0) return;
  else ele.style.height=cssH+"px";
}
function xClip(e,iTop,iRight,iBottom,iLeft) {
  if(!(e=xGetElementById(e))) return;
  if (iTop==null) iTop = xClipValues(e,'t');
  if (iRight==null) iRight = xClipValues(e,'r');
  if (iBottom==null) iBottom = xClipValues(e,'b');
  if (iLeft==null) iLeft = xClipValues(e,'l');

  if(e.style) {
    if (arguments.length == 5) e.style.clip="rect("+iTop+"px "+iRight+"px "+iBottom+"px "+iLeft+"px)";
    else e.style.clip="rect(0 "+parseInt(e.style.width)+"px "+parseInt(e.style.height)+"px 0)";
  }
  else if(e.clip) {
    if (arguments.length == 5) { e.clip.top=iTop; e.clip.right=iRight; e.clip.bottom=iBottom; e.clip.left=iLeft; }
    else { e.clip.top=0; e.clip.right=xWidth(e); e.clip.bottom=xHeight(e); e.clip.left=0; }
  }
}

// Event:
function xAddEventListener(e,eventType,eventListener,useCapture) {
  if(!(e=xGetElementById(e))) return;
  eventType=eventType.toLowerCase();
  if((!xIE4Up && !xOp7) && e==window) {
    if(eventType=='resize') { window.xPCW=xClientWidth(); window.xPCH=xClientHeight(); window.xREL=eventListener; xResizeEvent(); return; }
    if(eventType=='scroll') { window.xPSL=xScrollLeft(); window.xPST=xScrollTop(); window.xSEL=eventListener; xScrollEvent(); return; }
  }
  var eh="e.on"+eventType+"=eventListener";
  if(e.addEventListener) e.addEventListener(eventType,eventListener,useCapture);
  else if(e.attachEvent) e.attachEvent("on"+eventType,eventListener);
  else if(e.captureEvents) {
    if(useCapture||(eventType.indexOf('mousemove')!=-1)) { e.captureEvents(eval("Event."+eventType.toUpperCase())); }
    eval(eh);
  }
  else eval(eh);
}
function xRemoveEventListener(e,eventType,eventListener,useCapture) {
  if(!(e=xGetElementById(e))) return;
  eventType=eventType.toLowerCase();
  if((!xIE4Up && !xOp7) && e==window) {
    if(eventType=='resize') { window.xREL=null; return; }
    if(eventType=='scroll') { window.xSEL=null; return; }
  }
  var eh="e.on"+eventType+"=null";
  if(e.removeEventListener) e.removeEventListener(eventType,eventListener,useCapture);
  else if(e.detachEvent) e.detachEvent("on"+eventType,eventListener);
  else if(e.releaseEvents) {
    if(useCapture||(eventType.indexOf('mousemove')!=-1)) { e.releaseEvents(eval("Event."+eventType.toUpperCase())); }
    eval(eh);
  }
  else eval(eh);
}
function xEvent(evt) { // cross-browser event object prototype
  this.type = "";
  this.target = null;
  this.pageX = 0;
  this.pageY = 0;
  this.offsetX = 0;
  this.offsetY = 0;
  this.keyCode = 0;
  var e = evt ? evt : window.event;
  if(!e) return;
  // type
  if(e.type) this.type = e.type;
  // target
  if(xNN4) this.target = xLayerFromPoint(e.pageX, e.pageY);
  if(!(this.target))
    {
    if(e.target) this.target = e.target;
    else if(e.srcElement) this.target = e.srcElement;
    }
  //if ((! this.keyCode) & (e.keyCode)) { this.keyCode = e.keyCode; }
  // pageX, pageY
  if(xOp5or6) { this.pageX = e.clientX; this.pageY = e.clientY; }
  else if(xDef(e.pageX,e.pageY)) { this.pageX = e.pageX; this.pageY = e.pageY; }
  else if(xDef(e.clientX,e.clientY)) { this.pageX = e.clientX + xScrollLeft(); this.pageY = e.clientY + xScrollTop(); }
  // offsetX, offsetY
  if(xDef(e.layerX,e.layerY)) { this.offsetX = e.layerX; this.offsetY = e.layerY; }
  else if(xDef(e.offsetX,e.offsetY)) { this.offsetX = e.offsetX; this.offsetY = e.offsetY; }
  else { this.offsetX = this.pageX - xPageX(this.target); this.offsetY = this.pageY - xPageY(this.target); }
  // keycode
  if (xDef(e.keyCode)) { this.keyCode = e.keyCode; }
  else if (xDef(e.which)) { this.keyCode = e.which; }
}
function xResizeEvent() { // window resize event simulation
  if (window.xREL) setTimeout("xResizeEvent()", 250);
  var cw = xClientWidth(), ch = xClientHeight();
  if (window.xPCW != cw || window.xPCH != ch) { window.xPCW = cw; window.xPCH = ch; if (window.xREL) window.xREL(); }
}
function xScrollEvent() { // window scroll event simulation
  if (window.xSEL) setTimeout("xScrollEvent()", 250);
  var sl = xScrollLeft(), st = xScrollTop();
  if (window.xPSL != sl || window.xPST != st) { window.xPSL = sl; window.xPST = st; if (window.xSEL) window.xSEL(); }
}

// Object:
function xGetElementById(e, src) {
  if(typeof(e)!="string") return e;
  if(document.getElementById) e=document.getElementById(e);
  else if(document.all) e=document.all[e];
  else if(document.layers)
    {
      e = xLayer(e);
    }
  else
    {
      e=null;
    }
  return e;
}
function xLayer(id,root) { // only for nn4
  var i,j,layer,formiterator,formelement,found=null;
  if (!root) root=window;
  var e=root.document.images[id.toString()];
  if (e) return e;
  for(i=0; i<root.document.forms.length; i++) {
    formiterator=root.document.forms[i];
    for (j=0; j<formiterator.elements.length; j++)
      {
        formelement=formiterator.elements[j];
	if (formelement.name == id) return formelement;
      }
  }
  for(i=0; i<root.document.layers.length; i++) {
    layer=root.document.layers[i];
    if(layer.id==id) return layer;
    found=xLayer(id,layer);
    if(found) return found;
  }
  return null;
}
function xLayerFromPoint(x,y,root) { // only for nn4
  var i, hn=null, hz=-1, cn;
  if (!root) root = window;
  for (i=0; i < root.document.layers.length; ++i) {
    cn = root.document.layers[i];
    if (cn.visibility != "hide" && x >= cn.pageX && x <= cn.pageX + cn.clip.right && y >= cn.pageY && y <= cn.pageY + cn.clip.bottom ) {
      if (cn.zIndex > hz) { hz = cn.zIndex; hn = cn; }
    }
  }
  if (hn) {
    cn = xLayerFromPoint(x,y,hn);
    if (cn) hn = cn;
  }
  return hn;
}
function xParent(e){
  if (!(e=xGetElementById(e))) return null;
  var p=null;
  if (e.parentLayer){if (e.parentLayer!=window) p=e.parentLayer;}
  else{
    if (e.offsetParent) p=e.offsetParent;
    else if (e.parentNode) p=e.parentNode;
    else if (e.parentElement) p=e.parentElement;
  }
  return p;
}
function xDef() {
  for(var i=0; i<arguments.length; ++i){if(typeof(arguments[i])=="" || typeof(arguments[i])=="undefined") return false;}
  return true;
}

// Window:
function xScrollLeft() {
  var offset=0;
  if(xDef(window.pageXOffset)) offset=window.pageXOffset;
  else if(document.documentElement && document.documentElement.scrollLeft) offset=document.documentElement.scrollLeft;
  else if(document.body && xDef(document.body.scrollLeft)) offset=document.body.scrollLeft;
  return offset;
}
function xScrollTop() {
  var offset=0;
  if(xDef(window.pageYOffset)) offset=window.pageYOffset;
  else if(document.documentElement && document.documentElement.scrollTop) offset=document.documentElement.scrollTop;
  else if(document.body && xDef(document.body.scrollTop)) offset=document.body.scrollTop;
  return offset;
}
function xClientWidth() {
  var w=0;
  if(xOp5or6) w=window.innerWidth;
  else if(xIE4Up && document.documentElement && document.documentElement.clientWidth)
    w=document.documentElement.clientWidth;
  else if(document.body && document.body.clientWidth)
    w=document.body.clientWidth;
  else if(xDef(window.innerWidth,window.innerHeight,document.height)) {
    w=window.innerWidth;
    if(document.height>window.innerHeight) w-=16;
  }
  return w;
}
function xClientHeight() {
  var h=0;
  if(xOp5or6) h=window.innerHeight;
  else if(xIE4Up && document.documentElement && document.documentElement.clientHeight)
    h=document.documentElement.clientHeight;
  else if(document.body && document.body.clientHeight)
    h=document.body.clientHeight;
  else if(xDef(window.innerWidth,window.innerHeight,document.width)) {
    h=window.innerHeight;
    if(document.width>window.innerWidth) h-=16;
  }
  return h;
}
// end x.js

// begin m-x.js extension by Martin Krolik
function xClipValues(e,which) {
        if(!(e=xGetElementById(e))) return;
        var clipv;
        if (e.style) {
          if (e.style.clip == "") return Number.NaN;
          clipv = e.style.clip.split("rect(")[1].split(")")[0].split("px");
        }
        which=which.toLowerCase()
        if (which=="t") return (e.clip)? e.clip.top : Number(clipv[0]);
        if (which=="r") return (e.clip)? e.clip.right : Number(clipv[1]);
        if (which=="b") return (e.clip)? e.clip.bottom : Number(clipv[2]);
        if (which=="l") return (e.clip)? e.clip.left : Number(clipv[3]);
}
function xDisolveTo(e,t,r,b,l,uTime) {
  if (!(e=xGetElementById(e))) return;
  if (!e.timeout) e.timeout = 25;
  e.tTarget = t; e.rTarget = r; e.bTarget = b; e.lTarget = l; e.desolveTime = uTime; e.stop = false;
  e.tA = e.tTarget - xClipValues(e,"t"); e.rA = e.rTarget - xClipValues(e,"r"); e.bA = e.bTarget - xClipValues(e,"b"); e.lA = e.lTarget - xClipValues(e,"l");// A = distance
  e.B = Math.PI / (2 * e.desolveTime); // B = period
  e.tD = xClipValues(e,"t"); e.rD = xClipValues(e,"r"); e.bD = xClipValues(e,"b"); e.lD = xClipValues(e,"l");// D = initial position
  var d = new Date(); e.C = d.getTime();
  if (!e.desolving) xDisolve(e);
}
function xDisolve(e) {
  if (!(e=xGetElementById(e))) return;
  var now, s, t, newY, newX;
  now = new Date();
  t = now.getTime() - e.C;
  if (e.stop) { e.desolving = false; }
  else if (t < e.desolveTime) {
    //setTimeout("xDisolve('"+e.id+"')", e.timeout);
    s = Math.sin(e.B * t);
    newT = Math.round(e.tA * s + e.tD);
    newR = Math.round(e.rA * s + e.rD);
    newB = Math.round(e.bA * s + e.bD);
    newL = Math.round(e.lA * s + e.lD);
    xClip(e, newT, newR, newB, newL);
    e.desolving = true;
    setTimeout("xDisolve('"+e.id+"')", e.timeout);
  }
  else {
    xClip(e, e.tTarget, e.rTarget, e.bTarget, e.lTarget);
    e.desolving = false;
  }
}
function xAppearFrom(e,dir,uTime) {
  if (!(e=xGetElementById(e))) return;
  if (!e.timeout) e.timeout = 25;
  dir=dir.toLowerCase();
  e.direction=dir;
  e.xTarget = xPageX(e); e.yTarget = xPageY(e);
  e.wTarget = xWidth(e); e.hTarget = xHeight(e);
  e.desolveTime = uTime; e.stop = false;
  e.tTarget = xClipValues(e,"t"); e.rTarget = xClipValues(e,"r"); e.bTarget = xClipValues(e,"b"); e.lTarget = xClipValues(e,"l");
  if (dir=="nw") {
    xMoveTo(e,(e.xTarget - e.wTarget), (e.yTarget - e.hTarget));
    xClip(e, e.bTarget, e.rTarget, e.bTarget, e.rTarget);
  }
  else if (dir=="n") {
    xMoveTo(e,e.xTarget, (e.yTarget - e.hTarget));
    xClip(e, e.bTarget, e.rTarget, e.bTarget, e.lTarget);
  }
  else if (dir=="ne") {
    xMoveTo(e,(e.xTarget + e.wTarget), (e.yTarget - e.hTarget));
    xClip(e, e.bTarget, e.lTarget, e.bTarget, e.lTarget);
  }
  else if (dir=="e") {
    xMoveTo(e,(e.xTarget + e.wTarget), e.yTarget);
    xClip(e, e.tTarget, e.lTarget, e.bTarget, e.lTarget);
  }
  else if (dir=="w") {
    xMoveTo(e,(e.xTarget - e.wTarget), e.yTarget);
    xClip(e, e.tTarget, e.rTarget, e.bTarget, e.rTarget);
  }
  else if (dir=="se") {
    xMoveTo(e,(e.xTarget - e.wTarget), (e.yTarget + e.hTarget));
    xClip(e, e.tTarget, e.rTarget, e.tTarget, e.rTarget);
  }
  else if (dir=="s") {
    xMoveTo(e,e.xTarget, (e.yTarget + e.hTarget));
    xClip(e, e.tTarget, e.rTarget, e.tTarget, e.lTarget);
  }
  else if (dir=="sw") {
    xMoveTo(e,(e.xTarget + e.wTarget), (e.yTarget + e.hTarget));
    xClip(e, e.tTarget, e.lTarget, e.tTarget, e.lTarget);
  }
  e.xD = xPageX(e); e.yD = xPageY(e)
  e.tD = xClipValues(e,"t"); e.rD = xClipValues(e,"r"); e.bD = xClipValues(e,"b"); e.lD = xClipValues(e,"l");// D = initial position
  e.xA = e.xTarget - e.xD;   e.yA = e.yTarget - e.yD;
  e.tA = e.tTarget - e.tD; e.rA = e.rTarget - e.rD; e.bA = e.bTarget - e.bD; e.lA = e.lTarget - e.lD;// A = distance
  e.B = Math.PI / (2 * e.desolveTime); // B = period
  var d = new Date(); e.C = d.getTime();
  xShow(e);
  if (!e.appearing) xAppear(e);
}
function xAppear(e) {
  if (!(e=xGetElementById(e))) return;
  var now, s, t, newY, newX;
  now = new Date();
  t = now.getTime() - e.C;
  if (e.stop) { e.appearing = false; }
  else if (t < e.desolveTime) {
    //setTimeout("xAppear('"+e.id+"')", e.timeout);
    s = Math.sin(e.B * t);
    newX = Math.round(e.xA * s + e.xD);
    newY = Math.round(e.yA * s + e.yD);
    newT = Math.round(e.tA * s + e.tD);
    newR = Math.round(e.rA * s + e.rD);
    newB = Math.round(e.bA * s + e.bD);
    newL = Math.round(e.lA * s + e.lD);
    xMoveTo(e, newX, newY);
    xClip(e, newT, newR, newB, newL);
    e.appearing = true;
    setTimeout("xAppear('"+e.id+"')", e.timeout);

  }
  else {
    xMoveTo(e, e.xTarget, e.yTarget);
    xClip(e, e.tTarget, e.rTarget, e.bTarget, e.lTarget);
    if(e.disappear) {
      xHide(e);
      xMoveTo(e, e.xD, e.yD);
      xClip(e, e.tD, e.rD, e.bD, e.lD);
      e.disappear=false;
    }
    e.appearing = false;
  }
}
function xDisappearTo(e,dir,uTime) {
  if (!(e=xGetElementById(e))) return;
  if (!e.timeout) e.timeout = 25;
  e.disappear=true;
  //xHide(e);
  dir=dir.toLowerCase();
  e.direction=dir;
  e.tD = xClipValues(e,"t"); e.rD = xClipValues(e,"r"); e.bD = xClipValues(e,"b"); e.lD = xClipValues(e,"l");// D = initial position
  e.xD = xPageX(e); e.yD = xPageY(e)
  e.wD = e.rD - e.lD; e.hD = e.bD - e.tD;
  e.desolveTime = uTime; e.stop = false;
  //xMoveTo(e, e.xD; e.yD);
  if (dir=="nw") {
    e.xTarget=(e.xD-e.wD); e.yTarget=(e.yD-e.hD);
    e.tTarget=(e.tD+e.hD); e.rTarget=e.rD; e.bTarget=e.bD; e.lTarget=(e.lD+e.wD);
  }
  else if (dir=="n") {
    e.xTarget=e.xD; e.yTarget=(e.yD-e.hD);
    e.tTarget=(e.tD+e.hD); e.rTarget=e.rD; e.bTarget=e.bD; e.lTarget=e.lD;
  }
  else if (dir=="ne") {
    e.xTarget=(e.xD+e.wD); e.yTarget=(e.yD-e.hD);
    e.tTarget=(e.tD+e.hD); e.rTarget=(e.rD-e.wD); e.bTarget=e.bD; e.lTarget=(e.lD-e.wD);
  }
  else if (dir=="w") {
    e.xTarget=(e.xD-e.wD); e.yTarget=e.yD;
    e.tTarget=e.tD; e.rTarget=e.rD; e.bTarget=e.bD; e.lTarget=(e.lD+e.wD);
  }
  else if (dir=="e") {
    e.xTarget=(e.xD+e.wD); e.yTarget=e.yD;
    e.tTarget=e.tD; e.rTarget=(e.rD-e.wD); e.bTarget=e.bD; e.lTarget=(e.lD-e.wD);
  }
  else if (dir=="se") {
    e.xTarget=(e.xD-e.wD); e.yTarget=(e.yD+e.hD);
    e.tTarget=e.tD; e.rTarget=e.rD; e.bTarget=(e.bD-e.hD); e.lTarget=(e.lD+e.wD);
  }
  else if (dir=="s") {
    e.xTarget=e.xD; e.yTarget=(e.yD+e.hD);
    e.tTarget=e.tD; e.rTarget=e.rD; e.bTarget=(e.bD-e.hD); e.lTarget=e.lD;
  }
  else if (dir=="sw") {
    e.xTarget=(e.xD+e.wD); e.yTarget=(e.yD+e.hD);
    e.tTarget=e.tD; e.rTarget=(e.rD-e.wD); e.bTarget=(e.bD-e.hD); e.lTarget=(e.lD-e.wD);
  }
  e.xA = e.xTarget - e.xD;   e.yA = e.yTarget - e.yD;
  e.tA = e.tTarget - e.tD; e.rA = e.rTarget - e.rD; e.bA = e.bTarget - e.bD; e.lA = e.lTarget - e.lD;// A = distance
  e.B = Math.PI / (2 * e.desolveTime); // B = period
  var d = new Date(); e.C = d.getTime();
  xShow(e);
  if (!e.appearing) xAppear(e);
}
function xFadeIn(evnt, e, uTime)
{
  if (!(e=xGetElementById(e))) return;
  if ((e.faded) && (e.faded == "in") ) return;
  if (!e.timeout) e.timeout = 25;
  if (!e.fading) {
    e.fading = true;
    e.faded == "in";
    e.fadeTime = uTime; e.stop = false;
    var d = new Date(); e.C = d.getTime();
    e.B = Math.PI / (2 * e.fadeTime); // B = period
    e.opacityDelta = 1;
    e.opacityStart = 0;
    xFade(e);
  }
}
function xFadeOut(evnt, e, uTime)
{
  if (!(e=xGetElementById(e))) return;
  if ((e.faded) && (e.faded == "out") ) return;
  if (!e.timeout) e.timeout = 25;
  if (!e.fading) {
    e.fading = true;
    e.faded == "out";
    e.fadeTime = uTime; e.stop = false;
    var d = new Date(); e.C = d.getTime();
    e.B = Math.PI / (2 * e.fadeTime); // B = period
    e.opacityDelta = (0-1);
    e.opacityStart = 1;
    xFade(e);
  }
}
function xFadeFlex(evnt, e, start, stop, uTime)
{
  if (!(e=xGetElementById(e))) return;
  if (!e.timeout) e.timeout = 25;
  if (!e.fading) {
    e.fading = true;
    e.faded == "flex";
    e.fadeTime = uTime; e.stop = false;
    var d = new Date(); e.C = d.getTime();
    e.B = Math.PI / (2 * e.fadeTime); // B = period
    e.opacityDelta = stop - start;
    e.opacityStart = start;
    xFade(e);
  }
}
function xFade(e)
{
  if (!(e=xGetElementById(e))) return;
  var now, s, t, newOC;
  now = new Date();
  t = now.getTime() - e.C;
  if (e.stop) { e.fading = false; }
  // else if ((t < e.fadeTime) && (navigator.appName != "Netscape")) {
  else if (t < e.fadeTime) {
    s = Math.sin(e.B * t);
    newOC = e.opacityDelta * s + e.opacityStart;
    e.style.filter = "alpha(opacity=" + (newOC * 100) + ")";
    e.style.MozOpacity=newOC;
    e.style.opacity=newOC;
    e.fading = true;
    setTimeout("xFade('"+e.id+"')", e.timeout);
  }
  else {
    newOC = e.opacityDelta * 1 + e.opacityStart;
    e.style.filter = "alpha(opacity=" + (newOC * 100) + ")";
    e.style.MozOpacity=newOC;
    e.style.opacity=newOC;
    //window.status = newOC + " - " + e.opacityDelta  + " - " + e.opacityStart + " - " + s + " - " + t;
    e.fading = false;
    if (newOC == 0)
    {
	xHide(e);
    }
  }
}
function xDisplay(e,how) {
  if(!(e=xGetElementById(e))) return;
  if(e.style && xDef(e.style.display)) e.style.display=how;
  else if(xDef(e.display)) e.display=how;
}

function xLayerWrite(e,text) {
  if(!(e=xGetElementById(e))) return;
  if (document.layers)
  {
    e.document.open();
    e.document.write(text);
    e.document.close();
  } else {
    e.innerHTML = text;
  }
}
// end m-x.js extension

var mytimer,xdist,ydist,xoffset,yoffset,xviewport,yviewport,defaulttravel,defaulttimeout,borderheight,borderwidth,bwidth,bheight,myobject,outerimgdiv,mypframe,myloadingdiv,myimage,mysecondimage,initialized,loaded,xoffsetwithinpic,yoffsetwithinpic,origimagewidth,origimageheight,maxtravel;
var automoveonstart = true;
var numberofimages = 4 ;
xoffset = 0;
yoffset = 0;
xoffsetwithinpic = 0;
yoffsetwithinpic = 0;
xviewport = 360;
yviewport = 250;
defaulttravel = 3;
defaulttimeout = 20;
maxtravel = 8;
borderheight = 0;
borderwidth = 0;
var dblZoom = 1.0;
var vCurrentImageType = "2";
var blnZoomEnabled = true;
initialized = false;
loaded = false;
var pOldOnLoadPIV = null;
var pOldOnResizePIV = null;
if (window.onload != null) {
  pOldOnLoadPIV = window.onload;
}
if (window.onresize != null) {
  pOldOnResizePIV = window.onresize;
}
var arrImageURL = new Array();
var arrImageTitle = new Array();
var arrImageType = new Array();
var arrImageWidth = new Array();
var arrImageHeight = new Array();
var mypreloadedimages=new Array();
function preloadimages()
{
    for (i=0;i<preloadimages.arguments.length;i++)
    {
        mypreloadedimages[i]=new Image();
        mypreloadedimages[i].src=preloadimages.arguments[i];
    }
}
preloadimages('/images/LeftArrow-over.gif' , '/images/RightArrow-over.gif', '/images/LeftArrow.gif' , '/images/RightArrow.gif'   );
var vstate = false;
var startx = 0;
var starty = 0;
function mdevent(objEvent)
{
  if (vstate == false)
  {
    var oEvent = new xEvent(objEvent);
    quitmoving();
    xdist = 0;
    ydist = 0;
    startx = oEvent.pageX;
    starty = oEvent.pageY;
    vstate = true;
  }
}
function mmevent(objEvent)
{
  if (vstate) {
    var oEvent = new xEvent(objEvent);
    var xdelta, ydelta;
    xdelta = oEvent.pageX - startx;
    ydelta = oEvent.pageY - starty;
    if (xdelta > 0)
      {
      xdist = Math.round(Math.min(( xdelta / 2) , maxtravel));
      }
    Else
      {
      xdist = Math.round(Math.max(( xdelta / 2) , 0-maxtravel));
      }
    if (ydelta > 0)
      {
      ydist = Math.round(Math.min(( ydelta / 2) , maxtravel));
      }
    Else
      {
      ydist = Math.round(Math.max(( ydelta / 2) , 0-maxtravel));
      }
    /*
    // begin experimental mouse moving 2
    if (oEvent.pageX > startx)  {
      xdist = defaulttravel;
    } else if (oEvent.pageX < startx)  {
      xdist = 0 - defaulttravel;
    } else {
      xdist = 0;
    }

    if (oEvent.pageY > starty)  {
      ydist = defaulttravel;
    } else if (oEvent.pageY < starty) {
      ydist = 0 - defaulttravel;
    } else {
      ydist = 0;
    }
            end experimental mouse moving 2 */
    shiftover();
  }
}
function muevent(objEvent)
{
  if (vstate)
  {
    var oEvent = new xEvent(objEvent);
    vstate = false;
  }
}
function zoomReset()
{
    if (!loaded) return;
    if (document.layers)
   {
    alert('The Zoom feature is not supported in Netscape 4.');
      return;
    }
    var nheight = xHeight(myimage);
    var nwidth = xWidth(myimage);
    var left = xLeft(myobject);
    var top = xTop(myobject);
    var nl = left;
    var nt = top;
    if (nt < 0 - nheight + yviewport)
    {
      nt = 0 - nheight + yviewport ;
    }
    if (nt > 0)
    {
      nt = 0;
    }
    if (nl > 0)
    {
      nl = 0;
    }
     if (vCurrentImageType == "2")
     {
      if (nl < 0 - nwidth + xviewport)
      {
        nl = 0 - nwidth + xviewport + 1;
      }
    }
    xWidth(myimage, origimagewidth);
    xHeight(myimage, origimageheight);
     if (vCurrentImageType == "1")
     {
       xWidth(mysecondimage, origimagewidth);
        xHeight(mysecondimage, origimageheight);
    }
    xLeft(myobject, nl);
    xTop(myobject, nt);
    shiftover();
}
function zoomIn()
{
    if (!loaded) return;
    if (document.layers)
    {
      alert('The Zoom feature is not supported in Netscape 4.');
      return;
    }
    dblZoom = 1.2; // Zoom Out Percentage
    var nwidth = Math.round(dblZoom * xWidth(myimage)) ;
    var nheight = Math.round(dblZoom * xHeight(myimage)) ;
    xWidth(myimage, nwidth);
    xHeight(myimage, nheight);
     if (vCurrentImageType == "1") {
      xWidth(mysecondimage, nwidth );
      xHeight(mysecondimage, nheight );
     }
    var left = xLeft(myobject);
    var top = xTop(myobject);
    var nl = dblZoom * (left - (0.5 * xviewport)) + (0.5 * xviewport) ;
    var nt = dblZoom * (top - (0.5 * yviewport)) + (0.5 * yviewport) ;
    xLeft(myobject, nl);
    xTop(myobject, nt);
    if (document.layers)
    {
      xClip(myobject,null, xviewport - xLeft(myobject) ,null,null);
    }
    shiftover();
    return;
}
function zoomOut()
{
    if (!loaded) return;
    if (document.layers)
    {
      alert('The Zoom feature is not supported in Netscape 4.');
      return;
    }
    dblZoom = 0.8;  // Zoom Out Percentage
    var nwidth = Math.round(dblZoom * xWidth(myimage)) ;
    var nheight = Math.round(dblZoom * xHeight(myimage)) ;
    if (( xviewport < nwidth ) && ( yviewport < nheight ) )
    {
      var left = xLeft(myobject);
      var top = xTop(myobject);
      var nl = dblZoom * (left - (0.5 * xviewport)) + (0.5 * xviewport) ;
      var nt = dblZoom * (top - (0.5 * yviewport)) + (0.5 * yviewport) ;
      if (nt < 0 - nheight + yviewport)
      {
        nt = 0 - nheight + yviewport ;
      }
      if (nt > 0)
      {
        nt = 0;
      }
      if (nl > 0)
      {
        nl = 0;
      }
        if (vCurrentImageType == "2" )
        {
        if (nl < 0 - nwidth + xviewport)
        {
          nl = 0 - nwidth + xviewport + 1;
        }
        }

      xWidth(myimage, nwidth);
      xHeight(myimage, nheight);

        if (vCurrentImageType == "1" )
        {
          xWidth(mysecondimage, nwidth);
       xHeight(mysecondimage, nheight);
        }
      xLeft(myobject, nl);
      xTop(myobject, nt);
      if (document.layers)
      {
        xClip(myobject,null, xviewport - xLeft(myobject) ,null,null);
      }
    }
    shiftover();
    return;
}
function initpiv()
{
  myobject = xGetElementById("dimg");
  outerimgdiv = xGetElementById("dimgOuter");
  mypframe = xGetElementById("mypicframe");
  myloadingdiv = xGetElementById("nowloading");
  myimage = xGetElementById("ione");
  mysecondimage = xGetElementById("itwo");
  document.onkeydown=keyhandlepiv;
  origimagewidth = xWidth(myimage);
  origimageheight = xHeight(myimage);
  loaded = true;

  UpdateScene();

  positionpiv();

  if (pOldOnLoadPIV != null) {
    pOldOnLoadPIV();
  }
}
function positionpiv()
{
  xoffset = 0 + borderwidth;
  yoffset = 0 + borderheight;
  if (loaded)
  {
    xMoveTo(outerimgdiv,xoffset,yoffset);
    xMoveTo(mypframe,xoffset-borderwidth,yoffset-borderheight+1);
  }
  xHide(myloadingdiv);
  xClip(myloadingdiv,0,0,0,0);
  xShow(outerimgdiv);
  xShow(myobject);
  xShow(mypframe);

  xClip(mypframe,0,(xviewport+borderwidth+borderwidth),(yviewport+borderheight+borderheight),0);
  xClip(mypframe,0,(xviewport+borderwidth+borderwidth),(yviewport+borderheight+borderheight),0);

  xdist = xoffsetwithinpic;
  ydist = yoffsetwithinpic;

  shiftover();
  quitmoving();
  if (automoveonstart)
  {
    xdist=1;
    ydist=0;
    shiftover();
  }
  if (pOldOnResizePIV != null) {
    pOldOnResizePIV();
  }

}
function shiftover()
{
 if (loaded)
 {
  quitmoving();
  if ( ((xTop(myobject) - ydist ) >= 0) && (ydist<0) )
  {
    ydist = 0;
  } else
  if ( ((xTop(myobject) - ydist ) <= ( yviewport - xHeight(myimage) ) ) && (ydist>0) )
  {
    ydist = 0;
  }
  if (vCurrentImageType == "2")
   {
    if ( ((xLeft(myobject) - xdist ) >= 0) && (xdist<0) )
    {
      xdist = 1;
    } else
    if ( ((xLeft(myobject) - xdist ) <= ( xviewport - xWidth(myimage) ) ) && (xdist>0) )
    {
      xdist = -1;
    }
  }
  xMoveTo(myobject, xLeft(myobject) - xdist, xTop(myobject) - ydist);
  if (vCurrentImageType == "1")
  {
    if (xLeft(myobject) > 0 )
    {
      xLeft(myobject, 0 - xWidth(myimage));
    } else
    if (xLeft(myobject) < (0 - xWidth(myimage) ) )
    {
      xLeft(myobject, 0);
    }
  }
  if (document.layers)
  {
    xClip(myobject,null, xviewport - xLeft(myobject) ,null,null);
  }
  initialized == true;
  if ((xdist != 0) || (ydist != 0))
  {
    mytimer = setTimeout("shiftover()",defaulttimeout);
  }
 }
}
function quitmoving()
{
  if (mytimer)
  {
    clearTimeout(mytimer);
  }
  if (quitmoving.arguments.length > 0)
  {
    var blnClearDist = quitmoving.arguments[0];
    if (blnClearDist == true)
    {
      xdist = 0;
      ydist = 0;
    }
  }
}
function MouseOverImage(vImageName)
{
  var objImg = xGetElementById(vImageName);
  if (!(objImg.OriginalSrc)) objImg.OriginalSrc = objImg.src;
  var intLastDotLocation = objImg.OriginalSrc.lastIndexOf(".");
  if (intLastDotLocation > 0)
  {
    var strTemp = objImg.OriginalSrc.substring(0, intLastDotLocation) + "-over"+ objImg.OriginalSrc.substr(intLastDotLocation);
    objImg.src = strTemp;
  }
}
function MouseOutImage(vImageName)
{
  var objImg = xGetElementById(vImageName);
  if (objImg.OriginalSrc) objImg.src = objImg.OriginalSrc;
}
function SwapImage(vImageName, vImageSrc)
{
  var objImg = xGetElementById(vImageName);
  if (objImg)
  {
    if (objImg.src)
    {
      objImg.src = vImageSrc;
    }
  }
}
function move_NW() {
  xdist=-defaulttravel;
  ydist=-defaulttravel;
  shiftover();
}
function move_N() {
  xdist=0;
  ydist=-defaulttravel;
  shiftover();
}
function move_NE() {
  xdist=defaulttravel;
  ydist=-defaulttravel;
  shiftover();
}
function move_W() {
  xdist=-defaulttravel;
  ydist=0;
  shiftover();
}
function move_E() {
  xdist=defaulttravel;
  ydist=0;
  shiftover();
}
function move_SW() {
  xdist=-defaulttravel;
  ydist=defaulttravel;
  shiftover();
}
function move_S() {
  xdist=0;
  ydist=defaulttravel;
  shiftover();
}
function move_SE() {
  xdist=defaulttravel;
  ydist=defaulttravel;
  shiftover();
}


function UpdateScene()
{
    var objSelect = xGetElementById("SceneSelector");
    if (objSelect)
    {
        var intSelectedIndex = objSelect.selectedIndex;
        var strImageURL = objSelect.options[intSelectedIndex].value;
        myimage.src = strImageURL;
        if (mysecondimage)  mysecondimage.src = strImageURL;
    }
}
function ChangeScene(imageUrl,imageType, blnAutoStart, imageWidth, imageHeight)
{


    var strImageURL = imageUrl;

    myimage.src = strImageURL;
    if (mysecondimage)  mysecondimage.src = strImageURL;



    vCurrentImageType = "2";
    origimagewidth = imageWidth;
    origimageheight = imageHeight;

    if (!(document.layers)) zoomReset();

    xTop(myobject, 0);
    xLeft(myobject, 0);
    if (document.layers)
    {
        xClip(myobject,null, xviewport - xLeft(myobject) ,null,null);
    }


    positionpiv();

}

function keyhandlepiv(evt)
{
    var objEvent = new xEvent(evt);
    if (objEvent.keyCode == 37) {   move_W(); quitmoving(true); }
    if (objEvent.keyCode == 38) {   move_N(); quitmoving(true); }
    if (objEvent.keyCode == 39) {   move_E(); quitmoving(true); }
    if (objEvent.keyCode == 40) {   move_S(); quitmoving(true); }
}

xMoveTo(myloadingdiv, xLeft('PlaceHolderDiv'), xTop('PlaceHolderDiv'));
window.onload=initpiv;
window.onresize=positionpiv;

