/*************************************************************************
  This code is from Dynamic Web Coding at dyn-web.com
  Copyright 2001-5 by Sharon Paine
  See Terms of Use at www.dyn-web.com/bus/terms.html
  regarding conditions under which you may use this code.
  This notice must be retained in the code as is!
*************************************************************************/

/*
    dw_scrollObj.js  version date: March 2005
    GeckoTableBugFix algorithm revised, and now excludes Safari and Konqueror.

    dw_scrollObj.js contains constructor and basic methods for scrolling layers.
    Use with dw_hoverscroll.js and/or dw_glidescroll.js,
    and when including scrollbars: dw_scroll-aux.js and dw_slidebar.js
*/

dw_scrollObjs = {};
dw_scrollObj.speed=100;
function dw_scrollObj(wnId,lyrId,cntId){
this.id=wnId;dw_scrollObjs[this.id]=this;
this.animString="dw_scrollObjs."+this.id;
this.load(lyrId,cntId);
};

dw_scrollObj.loadLayer=function(wnId,id,cntId){
if(dw_scrollObjs[wnId])dw_scrollObjs[wnId].load(id,cntId);
};

dw_scrollObj.prototype.load=function(lyrId,cntId){
if(!document.getElementById)return;
var wndo,lyr;
if(this.lyrId){
lyr=document.getElementById(this.lyrId);
lyr.style.visibility="hidden";
}
lyr=document.getElementById(lyrId);
wndo=document.getElementById(this.id);
lyr.style.top=this.y=0;
lyr.style.left=this.x=0;
this.maxY=(lyr.offsetHeight-wndo.offsetHeight>0)?lyr.offsetHeight-wndo.offsetHeight:0;
this.wd=cntId?document.getElementById(cntId).offsetWidth:lyr.offsetWidth;
this.maxX=(this.wd-wndo.offsetWidth>0)?this.wd-wndo.offsetWidth:0;
this.lyrId=lyrId;lyr.style.visibility="visible";
this.on_load();
this.ready=true;
};

dw_scrollObj.prototype.on_load=function(){};

dw_scrollObj.prototype.shiftTo=function(lyr,x,y){
if(!lyr.style)return;
//if(!lyr.style||!dw_scrollObj.scrdy)return;
lyr.style.left=(this.x=x)+"px";
lyr.style.top=(this.y=y)+"px";
};

dw_scrollObj.GeckoTableBugFix=function(){
var ua=navigator.userAgent;
if(ua.indexOf("Gecko")>-1&&ua.indexOf("Firefox")==-1&&ua.indexOf("Safari")==-1&&ua.indexOf("Konqueror")==-1){dw_scrollObj.hold=[];
 for(var i=0;arguments[i];i++){
  if(dw_scrollObjs[arguments[i]]){
    var wndo=document.getElementById(arguments[i]);
    var holderId=wndo.parentNode.id;
    var holder=document.getElementById(holderId);
    document.body.appendChild(holder.removeChild(wndo));
    wndo.style.zIndex=1000;
    var pos=getPageOffsets(holder);
    wndo.style.left=pos.x+"px";wndo.style.top=pos.y+"px";
    dw_scrollObj.hold[i]=[arguments[i],holderId];
  }
 }
 window.addEventListener("resize",dw_scrollObj.rePositionGecko,true);
}
};

dw_scrollObj.rePositionGecko=function(){
if(dw_scrollObj.hold){
   for(var i=0;dw_scrollObj.hold[i];i++){
    var wndo=document.getElementById(dw_scrollObj.hold[i][0]);
    var holder=document.getElementById(dw_scrollObj.hold[i][1]);
    var pos=getPageOffsets(holder);wndo.style.left=pos.x+"px";wndo.style.top=pos.y+"px";
   }
}
};

function getPageOffsets(el){
  var left=el.offsetLeft;
  var top=el.offsetTop;
  if(el.offsetParent&&el.offsetParent.clientLeft||el.offsetParent.clientTop){
    left+=el.offsetParent.clientLeft;top+=el.offsetParent.clientTop;
  }
  while(el=el.offsetParent){
    left+=el.offsetLeft;top+=el.offsetTop;
  }
  return{x:left,y:top};
};

