var ns = ( navigator.appName == 'Netscape' )

function MenuList() {
 this.name = "MenuList"+(MenuList.count++)
 this.obj = this.name + "MenuListObject"
 eval(this.obj + "=this")
 if (arguments.length==4) {
  this.isChild = false
  this.x = arguments[0]
  this.y = arguments[1]
  this.w = arguments[2]
  this.itemH = arguments[3]
  this.subOnSelect = false
  this.offsetX = -11
  this.offsetY = 0
 }
 else {
  this.isChild = true
  this.parent = arguments[0]
  var index = arguments[1]
  this.parent.list.items[index].hasImage = true
  this.parent.list.items[index].hasChild = true
  this.parent.list.items[index].child = this
  this.x = this.parent.w
  this.y = this.parent.list.items[index].y
  this.w = (arguments.length==3)? arguments[2] : this.parent.w
  this.itemH = this.parent.itemH
  this.childShown = null
  this.subOnSelect = this.parent.subOnSelect
  this.offsetX = this.parent.offsetX
  this.offsetY = this.parent.offsetY
 }

 this.visibility = 'hidden'
 this.zIndex = 99
 this.overOpen = false
 
 this.list = new List(1,1,this.w-2,this.itemH)
 this.list.visibility = 'inherit'
 this.list.allowDeselect = true
 this.list.menulist = this
 
 if (this.isChild) {
  this.list.image = this.parent.list.image
  this.list.color = this.parent.list.color
  this.list.itemSpacing = this.parent.list.itemSpacing
  this.list.fontname = this.parent.list.fontname
  this.list.fontsize = this.parent.list.fontsize
 }
 
 this.cssChildren = ''
 this.divChildren = ''

 this.build = MenuListBuild
 this.activate = MenuListActivate
 this.showMenu = MenuListShowMenu
 this.hideMenu = MenuListHideMenu
 this.show = MenuListShow
 this.hide = MenuListHide
 this.toggle = MenuListToggle
 this.select = MenuListSelect
 if (this.isChild) this.onSelect = this.parent.onSelect
 else this.onSelect = new Function()
}
function MenuListBuild(write) {
 for (var i=0;i<this.list.items.length;i++) {
  if (this.list.items[i].hasChild) {
   this.list.items[i].child.overOpen = this.overOpen
   this.list.items[i].child.build()
  }
 }
 this.list.overOpen = this.overOpen
 this.list.build()
 this.css = css(this.name,this.x+this.offsetX,this.y+this.offsetY,null,null,null,(this.isChild)?'hidden':this.visibility,this.zIndex)+
 css(this.name+'ListW',0,0,this.w,this.list.h+2,menuBorderColor)+
 this.list.css+
 this.cssChildren

 this.div = '<div id="'+this.name+'">\n'+
 '<div id="'+this.name+'ListW">\n'+
 this.list.div+
 '</div>\n'+
 this.divChildren+
 '</div>\n'

 if (this.isChild) {
  this.parent.cssChildren += this.css
  this.parent.divChildren += this.div
 }
}
function MenuListActivate() {
 this.list.activate()
 this.lyr = new DynLayer(this.name)
 this.h = this.list.h+2
 if (is.ns && !this.isChild) {
  this.lyr.clipInit()
  this.lyr.clipTo(0,this.w,this.h,0)
 }
 this.list.onSelect = new Function(this.obj+'.select(); return false;')
 for (var i=0;i<this.list.items.length;i++) {
  if (this.list.items[i].hasChild) this.list.items[i].child.activate()
 }
}
function MenuListSelect() {
 var i = this.list.selectedIndex
 if (i!=null) {
 if (this.childShown==i) {
  this.hideMenu(this.childShown)
 }
 else {
  this.hideMenu()
  if (this.list.items[i].hasChild) this.showMenu(i)
  if (!this.list.items[i].hasChild || this.subOnSelect) this.onSelect()
 }
 }
}
function MenuListHideMenu() {
 var i = this.childShown
 if (i!=null && this.list.items[i]!=null) {
  this.childShown = null
  this.list.items[i].child.lyr.hide()
  this.list.items[i].child.hideMenu()
  if (this.list.items[i].child.list.selectedIndex!=null) {
   this.list.items[i].child.list.deselect(this.list.items[i].child.list.selectedIndex)
  }
  if (is.ns && !this.isChild) this.lyr.clipTo(0,this.w,this.h,0)
 }
}
function MenuListShowMenu(i) {
 if (is.ns && !this.isChild) this.lyr.clipTo(0,this.lyr.w,this.lyr.h,0)
 this.list.items[i].child.lyr.show()
 this.childShown = i
}
function MenuListToggle() {
 if (!this.visible) this.show()
 else this.hide()
}
function MenuListHide() {
 this.hideMenu()
 this.list.deselect(this.list.selectedIndex)
 this.lyr.hide()
 this.visible = false
}
function MenuListShow() {
 this.lyr.css.visibility = 'inherit'
 this.visible = true
}
function MenuListRedirect() {
 this.hide()
 location.href = this.list.value
}

MenuList.count = 0



// List Function
function List(x,y,width,itemH) {
 this.name = "List"+(List.count++)
 this.x = x
 this.y = y
 this.w = width
 if (arguments.length==4) {
  this.itemH = itemH
  this.itemHset = true
  this.h = -1
 }
 else {
  this.itemH = null
  this.itemHset = false
  this.h = (is.ns)? -1 : 1000
 }

 this.itemSpacing = 0
 this.fontname = 'Verdana'
 this.fontsize = (ns)? 8:7
 this.visibility = 'inherit'

 this.overOpen = false
 this.menulist = null
 this.indent = 3
 
 this.color = new Object()
 this.color.textNormal = menuTextNormal
 this.color.textSelected = menuTextSelected
 this.color.bgNormal = menuBgNormal
 this.color.bgSelected = menuBgSelected
 this.color.bgRollover = menuBgRollover
 this.color.bg = menuBg

 this.allowDeselect = false
 this.multiSelect = false
 this.preSelect = null

 this.items = new Array()
 this.selectedIndex = null
 this.obj = this.name + "ListObject"
 eval(this.obj + "=this")

 this.add = ListAdd
 this.build = ListBuild
 this.activate = ListActivate
 this.over = ListOver
 this.out = ListOut
 this.down = ListDown
 this.select = ListSelect
 this.setCols = ListSetCols
 this.image = new Object()
 this.setImage = ListSetImage
 this.deselect = ListDeselect
 this.onSelect = new Function()
}
function ListSetCols() {
 this.cols = arguments
 this.multiCol = true
}
function ListSetImage(image0,image1,width,height) {
 this.image.image0 = new Image()
 this.image.image0.src = image0
 this.image.image1 = new Image()
 this.image.image1.src = image1
 this.image.w = width
 this.image.h = height
}
function ListAdd(value) {
 var i = this.items.length
 this.items[i] = new Array()
 this.items[i].selected = false
 this.items[i].value = value
 if (arguments.length>2) {
  this.items[i].textNormal = this.items[i].textSelected = '<table border=0 cellpadding=0 cellspacing=0><tr>'
  this.items[i].text = new Array()
  for (var j=1;j<arguments.length;j++) {
   this.items[i].text[j-1] = ''+arguments[j]
   this.items[i].textNormal += '<td width='+this.cols[j-1]+'><div class="'+this.name+'TextNormal">'+arguments[j]+'</div></td>'
   this.items[i].textSelected += '<td width='+this.cols[j-1]+'><div class="'+this.name+'TextSelected">'+arguments[j]+'</div></td>'
  }
  this.items[i].textNormal += '</tr></table>'
  this.items[i].textSelected += '</tr></table>'
 }
 else {
  this.items[i].text = arguments[1]
  this.items[i].textNormal = '<div class="'+this.name+'TextNormal">'+arguments[1]+'</div>'
  this.items[i].textSelected = '<div class="'+this.name+'TextSelected">'+arguments[1]+'</div>'
 }
 if (this.itemH) {
  this.h += this.itemH+this.itemSpacing
  this.items[i].y = i*this.itemH+i*this.itemSpacing
 }
 else this.items[i].y = 0
}
function ListBuild() {
 this.css = ''
 this.css += css(this.name+'List',this.x,this.y,this.w,this.h,this.color.bg,(this.itemHset)?this.visibility:'hidden')
 for (var i=0;i<this.items.length;i++) {
  this.css += css(this.name+'ListItem'+i,0,this.items[i].y,this.w,this.itemH,this.color.bgNormal)
  if (this.items[i].hasImage) this.css += css(this.name+'ListItemImgLyr'+i,this.w-this.image.w,this.items[i].y)
  this.css += css(this.name+'ListItemC'+i,0,this.items[i].y,this.w,this.itemH)
 }
 this.css += '.'+this.name+'TextNormal {font-family:"'+this.fontname+'"; font-size:'+this.fontsize+'pt; color:'+this.color.textNormal+'; background-color:transparent; margin-left:'+this.indent+'px;}\n'+
 '.'+this.name+'TextSelected {font-family:"'+this.fontname+'"; font-size:'+this.fontsize+'pt; color:'+this.color.textSelected+'; background-color:transparent; margin-left:'+this.indent+'px;}\n'

 this.div = '<div id="'+this.name+'List">\n'
 for (var i=0;i<this.items.length;i++) {
  this.div += '<div id="'+this.name+'ListItem'+i+'">'+this.items[i].textNormal+'</div>\n'
  if (this.items[i].hasImage) this.div += '<div id="'+this.name+'ListItemImgLyr'+i+'"><img name="'+this.name+'ListItemImg'+i+'" src="'+this.image.image0.src+'" width='+this.image.w+' height='+this.image.h+'></div>\n'
  this.div += '<div id="'+this.name+'ListItemC'+i+'"></div>\n'
 }
 this.div += '</div>'
}
function ListActivate() {
 if (is.ie) this.h -= 1001
 this.lyr = new DynLayer(this.name+'List')
 this.lyr.clipInit()

 for (var i=0;i<this.items.length;i++) {
  this.items[i].lyr = new DynLayer(this.name+'ListItem'+i)
  this.items[i].lyr.setbg = DynLayerSetbg
  this.items[i].lyre = new DynLayer(this.name+'ListItemC'+i)
  if (is.ns) this.items[i].lyre.event.captureEvents(Event.MOUSEDOWN)
  this.items[i].lyre.event.onmouseover = new Function(this.obj+'.over('+i+'); return false;')
  this.items[i].lyre.event.onmouseout = new Function(this.obj+'.out('+i+'); return false;')
  this.items[i].lyre.event.onmousedown = new Function(this.obj+'.down('+i+'); return false;')
  if (!this.itemHset) {
   this.itemH = (is.ns)? this.items[0].lyr.doc.height : this.items[0].lyr.event.offsetHeight
   this.items[i].lyr.moveTo(null,i*this.itemH+this.itemSpacing*i)
   this.items[i].lyre.moveTo(null,i*this.itemH+this.itemSpacing*i)
   if (is.ns) {
    this.items[i].lyr.clipInit()
    this.items[i].lyr.clipTo(0,this.w,this.itemH,0)
    this.items[i].lyre.clipInit()
    this.items[i].lyre.clipTo(0,this.w,this.itemH,0)
   }
   this.h += this.itemH+this.itemSpacing
  }
  if (this.items[i].hasImage) {
   this.items[i].imagelyr = new DynLayer(this.name+'ListItemImgLyr'+i)
  }
 }
 if (!this.itemHset) {
  this.lyr.clipTo(0,this.w,this.h,0)
  if (is.ie) this.lyr.css.height = this.h
 }
 if (this.preSelect!=null) this.select(this.preSelect)
 this.lyr.css.visibility = this.visibility
}
function ListOver(i) {
 if (!this.items[i].selected) {
    this.items[i].lyr.setbg(this.color.bgRollover)
 }
 if (this.overOpen && i!=this.selectedIndex) {
  this.menulist.hideMenu()
  this.deselect(this.selectedIndex)
  if (this.items[i].hasChild) this.select(i)
 }
}
function ListOut(i) {
 if (!this.items[i].selected) this.items[i].lyr.setbg(this.color.bgNormal)
}
function ListDown(i) {
 if (!this.items[i].selected) {
  if (!this.multiSelect && this.selectedIndex!=null) this.deselect(this.selectedIndex)
  this.select(i)  
 }
 else {
  if (this.multiSelect || this.allowDeselect) {
   this.menulist.hideMenu()
   this.deselect(i)
  }
 }
}
function ListSelect(i) {
 if (this.items[i]!=null) { 
  this.selectedIndex = i
  this.value = this.items[i].value
  if (this.items[i].hasImage) this.items[i].imagelyr.doc.images[this.name+'ListItemImg'+i].src = this.image.image1.src
  this.items[i].lyr.setbg(this.color.bgSelected)
  this.items[i].lyr.write(this.items[i].textSelected)
  this.items[i].selected = true
  this.onSelect()
 }
}

function ListDeselect(i) {
 if (this.items[i]!=null) {
    if (this.items[i].selected) {
  if (this.items[i].hasImage) this.items[i].imagelyr.doc.images[this.name+'ListItemImg'+i].src = this.image.image0.src
  this.items[i].lyr.setbg(this.color.bgNormal)
  this.items[i].lyr.write(this.items[i].textNormal)
  this.items[i].selected = false
  if (!this.multiSelect) this.selectedIndex = null
    }
 }
}
function ListRedirect() {
 location.href = this.value
}
List.count = 0


function DynLayerSetbg(color) {
 if (is.ns) this.doc.bgColor = color
 else if (is.ie) this.css.backgroundColor = color
}



// *** MiniScroller ***
function MiniScroll(window,content) {
 this.window = window
 this.content = content
 this.inc = 8
 this.speed = 80
 this.contentHeight = (is.ns)? this.content.doc.height : this.content.elm.scrollHeight
 this.contentWidth = (is.ns)? this.content.doc.width : this.content.elm.scrollWidth
 this.up = MiniScrollUp
 this.down = MiniScrollDown
 this.left = MiniScrollLeft
 this.right = MiniScrollRight
 this.stop = MiniScrollStop
 this.activate = MiniScrollActivate
 this.activate(this.contentWidth,this.contentHeight)
}
function MiniScrollActivate() {
 this.offsetHeight = this.contentHeight-this.window.h
 this.offsetWidth = this.contentWidth-this.window.w
 this.enableVScroll = (this.offsetHeight>0)
 this.enableHScroll = (this.offsetWidth>0)
}
function MiniScrollUp() {
 if (this.enableVScroll) this.content.slideTo(null,0,this.inc,this.speed)
}
function MiniScrollDown() {
 if (this.enableVScroll) this.content.slideTo(null,-this.offsetHeight,this.inc,this.speed)
}
function MiniScrollLeft() {
 if (this.enableHScroll) this.content.slideTo(0,null,this.inc,this.speed)
}
function MiniScrollRight() {
 if (this.enableHScroll) this.content.slideTo(-this.offsetWidth,null,this.inc,this.speed)
}
function MiniScrollStop() {
 this.content.slideActive = false
}


// *** DynLayer Function ***
function DynLayer(id,nestref,frame) {
 if (!is.ns5 && !DynLayer.set && !frame) DynLayerInit()
 this.frame = frame || self
 if (is.ns) {
  if (is.ns4) {
   if (!frame) {
    if (!nestref) var nestref = DynLayer.nestRefArray[id]
    if (!DynLayerTest(id,nestref)) return
    this.css = (nestref)? eval("document."+nestref+".document."+id) : document.layers[id]
   }
   else this.css = (nestref)? eval("frame.document."+nestref+".document."+id) : frame.document.layers[id]
   this.elm = this.event = this.css
   this.doc = this.css.document
  }
  else if (is.ns5) {
   this.elm = document.getElementById(id)
   this.css = this.elm.style
   this.doc = document
  }
  this.x = this.css.left
  this.y = this.css.top
  this.w = this.css.clip.width
  this.h = this.css.clip.height
 }
 else if (is.ie) {
  this.elm = this.event = this.frame.document.all[id]
  this.css = this.frame.document.all[id].style
  this.doc = document
  this.x = this.elm.offsetLeft
  this.y = this.elm.offsetTop
  this.w = (is.ie4)? this.css.pixelWidth : this.elm.offsetWidth
  this.h = (is.ie4)? this.css.pixelHeight : this.elm.offsetHeight
 }
 this.id = id
 this.nestref = nestref
 this.obj = id + "DynLayer"
 eval(this.obj + "=this")
}
function DynLayerMoveTo(x,y) {
 if (x!=null) {
  this.x = x
  if (is.ns) this.css.left = this.x
  else this.css.pixelLeft = this.x
 }
 if (y!=null) {
  this.y = y
  if (is.ns) this.css.top = this.y
  else this.css.pixelTop = this.y
 }
}
function DynLayerMoveBy(x,y) {
 this.moveTo(this.x+x,this.y+y)
}
function DynLayerShow() {
 this.css.visibility = (is.ns4)? "show" : "visible"
}
function DynLayerHide() {
 this.css.visibility = (is.ns4)? "hide" : "hidden"
}
DynLayer.prototype.moveTo = DynLayerMoveTo
DynLayer.prototype.moveBy = DynLayerMoveBy
DynLayer.prototype.show = DynLayerShow
DynLayer.prototype.hide = DynLayerHide
DynLayerTest = new Function('return true')

// DynLayerInit Function
function DynLayerInit(nestref) {
 if (!DynLayer.set) DynLayer.set = true
 if (is.ns) {
  if (nestref) ref = eval('document.'+nestref+'.document')
  else {nestref = ''; ref = document;}
  for (var i=0; i<ref.layers.length; i++) {
   var divname = ref.layers[i].name
   DynLayer.nestRefArray[divname] = nestref
   var index = divname.indexOf("Div")
   if (index > 0) {
    eval(divname.substr(0,index)+' = new DynLayer("'+divname+'","'+nestref+'")')
   }
   if (ref.layers[i].document.layers.length > 0) {
    DynLayer.refArray[DynLayer.refArray.length] = (nestref=='')? ref.layers[i].name : nestref+'.document.'+ref.layers[i].name
   }
  }
  if (DynLayer.refArray.i < DynLayer.refArray.length) {
   DynLayerInit(DynLayer.refArray[DynLayer.refArray.i++])
  }
 }
 else if (is.ie) {
  for (var i=0; i<document.all.tags("DIV").length; i++) {
   var divname = document.all.tags("DIV")[i].id
   var index = divname.indexOf("Div")
   if (index > 0) {
    eval(divname.substr(0,index)+' = new DynLayer("'+divname+'")')
   }
  }
 }
 return true
}
DynLayer.nestRefArray = new Array()
DynLayer.refArray = new Array()
DynLayer.refArray.i = 0
DynLayer.set = false

// Slide Methods
function DynLayerSlideTo(endx,endy,inc,speed,fn) {
 if (endx==null) endx = this.x
 if (endy==null) endy = this.y
 var distx = endx-this.x
 var disty = endy-this.y
 this.slideStart(endx,endy,distx,disty,inc,speed,fn)
}
function DynLayerSlideBy(distx,disty,inc,speed,fn) {
 var endx = this.x + distx
 var endy = this.y + disty
 this.slideStart(endx,endy,distx,disty,inc,speed,fn)
}
function DynLayerSlideStart(endx,endy,distx,disty,inc,speed,fn) {
 if (this.slideActive) return
 if (!inc) inc = 10
 if (!speed) speed = 20
 var num = Math.sqrt(Math.pow(distx,2) + Math.pow(disty,2))/inc
 if (num==0) return
 var dx = distx/num
 var dy = disty/num
 if (!fn) fn = null
 this.slideActive = true
 this.slide(dx,dy,endx,endy,num,1,speed,fn)
}
function DynLayerSlide(dx,dy,endx,endy,num,i,speed,fn) {
 if (!this.slideActive) return
 if (i++ < num) {
  this.moveBy(dx,dy)
  this.onSlide()
  if (this.slideActive) setTimeout(this.obj+".slide("+dx+","+dy+","+endx+","+endy+","+num+","+i+","+speed+",\""+fn+"\")",speed)
  else this.onSlideEnd()
 }
 else {
  this.slideActive = false
  this.moveTo(endx,endy)
  this.onSlide()
  this.onSlideEnd()
  eval(fn)
 }
}
function DynLayerSlideInit() {}
DynLayer.prototype.slideInit = DynLayerSlideInit
DynLayer.prototype.slideTo = DynLayerSlideTo
DynLayer.prototype.slideBy = DynLayerSlideBy
DynLayer.prototype.slideStart = DynLayerSlideStart
DynLayer.prototype.slide = DynLayerSlide
DynLayer.prototype.onSlide = new Function()
DynLayer.prototype.onSlideEnd = new Function()

// Clip Methods
function DynLayerClipInit(clipTop,clipRight,clipBottom,clipLeft) {
 if (is.ie) {
  if (arguments.length==4) this.clipTo(clipTop,clipRight,clipBottom,clipLeft)
  else if (is.ie4) this.clipTo(0,this.css.pixelWidth,this.css.pixelHeight,0)
 }
}
function DynLayerClipTo(t,r,b,l) {
 if (t==null) t = this.clipValues('t')
 if (r==null) r = this.clipValues('r')
 if (b==null) b = this.clipValues('b')
 if (l==null) l = this.clipValues('l')
 if (is.ns) {
  this.css.clip.top = t
  this.css.clip.right = r
  this.css.clip.bottom = b
  this.css.clip.left = l
 }
 else if (is.ie) this.css.clip = "rect("+t+"px "+r+"px "+b+"px "+l+"px)"
}
function DynLayerClipBy(t,r,b,l) {
 this.clipTo(this.clipValues('t')+t,this.clipValues('r')+r,this.clipValues('b')+b,this.clipValues('l')+l)
}
function DynLayerClipValues(which) {
 if (is.ie) var clipv = this.css.clip.split("rect(")[1].split(")")[0].split("px")
 if (which=="t") return (is.ns)? this.css.clip.top : Number(clipv[0])
 if (which=="r") return (is.ns)? this.css.clip.right : Number(clipv[1])
 if (which=="b") return (is.ns)? this.css.clip.bottom : Number(clipv[2])
 if (which=="l") return (is.ns)? this.css.clip.left : Number(clipv[3])
}
DynLayer.prototype.clipInit = DynLayerClipInit
DynLayer.prototype.clipTo = DynLayerClipTo
DynLayer.prototype.clipBy = DynLayerClipBy
DynLayer.prototype.clipValues = DynLayerClipValues

// Write Method
function DynLayerWrite(html) {
 if (is.ns) {
  this.doc.open()
  this.doc.write(html)
  this.doc.close()
 }
 else if (is.ie) {
  this.event.innerHTML = html
 }
}
DynLayer.prototype.write = DynLayerWrite

// BrowserCheck Object
function BrowserCheck() {
 var b = navigator.appName
 if (b=="Netscape") this.b = "ns"
 else if (b=="Microsoft Internet Explorer") this.b = "ie"
 else this.b = b
 this.version = navigator.appVersion
 this.v = parseInt(this.version)
 this.ns = (this.b=="ns" && this.v>=4)
 this.ns4 = (this.b=="ns" && this.v==4)
 this.ns5 = (this.b=="ns" && this.v==5)
 this.ie = (this.b=="ie" && this.v>=4)
 this.ie4 = (this.version.indexOf('MSIE 4')>0)
 this.ie5 = (this.version.indexOf('MSIE 5')>0)
 this.min = (this.ns||this.ie)
}
is = new BrowserCheck()

// CSS Function
function css(id,left,top,width,height,color,vis,z,other) {
 if (id=="START") return '<STYLE TYPE="text/css">\n'
 else if (id=="END") return '</STYLE>'
 var str = (left!=null && top!=null)? '#'+id+' {position:absolute; left:'+left+'px; top:'+top+'px;' : '#'+id+' {position:relative;'
 if (arguments.length>=4 && width!=null) str += ' width:'+width+'px;'
 if (arguments.length>=5 && height!=null) {
  str += ' height:'+height+'px;'
  if (arguments.length<9 || other.indexOf('clip')==-1) str += ' clip:rect(0px '+width+'px '+height+'px 0px);'
 }
 if (arguments.length>=6 && color!=null) str += (is.ns)? ' layer-background-color:'+color+';' : ' background-color:'+color+';'
 if (arguments.length>=7 && vis!=null) str += ' visibility:'+vis+';'
 if (arguments.length>=8 && z!=null) str += ' z-index:'+z+';'
 if (arguments.length==9 && other!=null) str += ' '+other
 str += '}\n'
 return str
}
function writeCSS(str,showAlert) {
 str = css('START')+str+css('END')
 document.write(str)
 if (showAlert) alert(str)
}

