function Folder(folderDescription, hreference) //constructor 
{   
  //constant data 
  this.desc = folderDescription 
  this.hreference = hreference 
  this.id = -1   
  this.navObj = 0  
  this.iconImg = 0  
  this.nodeImg = 0  
  this.isLastNode = 0 
 
  //dynamic data 
  this.isOpen = true 
  //this.iconSrc = "images/loading.gif"   //folder icon jerry chou
  this.children = new Array 
  this.nChildren = 0 
 
  //methods 
  this.initialize = initializeFolder 
  this.setState = setStateFolder 
  this.addChild = addChild 
  this.createIndex = createEntryIndex 
  this.hide = hideFolder 
  this.display = display 
  this.renderOb = drawFolder 
  this.totalHeight = totalHeight 
  this.subEntries = folderSubEntries 
  this.outputLink = outputFolderLink 
} 
 
function setStateFolder(isOpen) 
{ 
  var subEntries 
  var totalHeight 
  var fIt = 0 
  var i=0 
 
  if (isOpen == this.isOpen) 
    return true
 
  if (browserVersion == 2)  
  { 
    totalHeight = 0 
    for (i=0; i < this.nChildren; i++) 
      totalHeight = totalHeight + this.children[i].navObj.clip.height 
      subEntries = this.subEntries() 
    if (this.isOpen) 
      totalHeight = 0 - totalHeight 
    for (fIt = this.id + subEntries + 1; fIt < nEntries; fIt++) 
      indexOfEntries[fIt].navObj.moveBy(0, totalHeight) 
}
  this.isOpen = isOpen 
  propagateChangesInState(this) 
} 
 
function propagateChangesInState(folder) 
{   
  var i=0 
 
  if (folder.isOpen)   { 
    if (folder.nodeImg) 
      if (folder.isLastNode ) 
        folder.nodeImg.src = "images/ftv2mlastnode.gif" 
      else 
	    folder.nodeImg.src = "images/ftv2mnode.gif" 
    //folder.iconImg.src = "images/f2fo.gif" //folder icon jerry chou
    for (i=0; i<folder.nChildren; i++)
      folder.children[i].display() 
  } else { 
    if (folder.nodeImg) 
      if (folder.isLastNode) 
        folder.nodeImg.src = "images/ftv2plastnode.gif" 
      else 
	    folder.nodeImg.src = "images/ftv2pnode.gif" 
    //folder.iconImg.src = "images/f2fc.gif" //folder icon jerry chou
    for (i=0; i<folder.nChildren; i++) 
      folder.children[i].hide() 
  }  
} 
 
function hideFolder() 
{ 
  if (browserVersion == 1 || browserVersion == 3) { 
    if (this.navObj.style.display == "none") 
      return 
    this.navObj.style.display = "none" 
  } else { 
    if (this.navObj.visibility == "hiden") 
      return 
    this.navObj.visibility = "hiden" 
  } 
   
  this.setState(0) 
} 
 
function initializeFolder(level, lastNode, leftSide) 
{ 
var j=0 
var i=0 
var numberOfFolders 
var numberOfDocs 
var nc 
      
  nc = this.nChildren 
   
  this.createIndex() 
 
  var auxEv = "" 
 
  if (browserVersion > 0) 
    auxEv = "<a href='javascript:clickOnNode("+this.id+")'>" 
  else 
    auxEv = "<a>" 
 
  if (level>0) 
    if (lastNode) //the last 'brother' in the children array 
    { 
      this.renderOb(leftSide + auxEv + "<img name='nodeIcon" + this.id + "' id='nodeIcon" + this.id + "' src='images/ftv2mlastnode.gif' width=16 height=22 border=0></a>") 
      leftSide = leftSide + "<img src='images/tblank.gif' width=16 height=22>"  
      this.isLastNode = 1 
    } 
    else 
    { 
      this.renderOb(leftSide + auxEv + "<img name='nodeIcon" + this.id + "' id='nodeIcon" + this.id + "' src='images/ftv2mnode.gif' width=16 height=22 border=0></a>") 
      leftSide = leftSide + "<img src='images/ftv2vertline.gif' width=16 height=22>" 
      this.isLastNode = 0 
    } 
  else 
    this.renderOb("") 
   
  if (nc > 0) 
  { 
    level = level + 1 
    for (i=0 ; i < this.nChildren; i++)  
    { 
      if (i == this.nChildren-1) 
        this.children[i].initialize(level, 1, leftSide) 
      else 
        this.children[i].initialize(level, 0, leftSide) 
      } 
  } 
} 
 
function drawFolder(leftSide) 
{ 
  if (browserVersion == 2) {
    if (!doc.yPos)
      doc.yPos=8
    doc.write("<layer id='folder" + this.id + "' top=" + doc.yPos + " visibility=hiden>")
  }
   
  doc.write("<table ")
  if (browserVersion == 1 || browserVersion == 3)
    doc.write(" id='folder" + this.id + "' style='position:block;' ")
  doc.write(" border=0 cellspacing=0 cellpadding=0>")
  doc.write("<tr><td>")
  doc.write(leftSide)
  this.outputLink()
  //doc.write("<img name='folderIcon" + this.id + "' ") //folder icon jerry chou
 // doc.write("src='" + this.iconSrc+"' border=0></a>") //folder icon jerry chou
  //doc.write("src='" + "' border=0></a>") //folder icon jerry chou
  doc.write("</td");
  doc.write(">");
  doc.write("<td valign=middle nowrap>");
  if (USETEXTLINKS)
  {
    this.outputLink()
    doc.write(this.desc + "</a>")
  }
  else
    doc.write(this.desc)
  
  doc.write("</td")
  doc.write(">")
  doc.write("</table")
  doc.write(">")
  
  if (browserVersion == 2) {
    doc.write("</layer>")
  }
 
  if (browserVersion == 1) { 
    this.navObj = doc.all["folder"+this.id]
    //this.iconImg = doc.all["folderIcon"+this.id]
    this.nodeImg = doc.all["nodeIcon"+this.id]
  } else if (browserVersion == 2) {
    this.navObj = doc.layers["folder"+this.id]
    //this.iconImg = this.navObj.document.images["folderIcon"+this.id]
    this.nodeImg = this.navObj.document.images["nodeIcon"+this.id]
    doc.yPos=doc.yPos+this.navObj.clip.height
  } else if (browserVersion == 3) {
    this.navObj = doc.getElementById("folder"+this.id)
    //this.iconImg = doc.getElementById("folderIcon"+this.id)
    this.nodeImg = doc.getElementById("nodeIcon"+this.id)
  }
}

function outputFolderLink()
{
  if (this.hreference)
  {
    doc.write("<a href='" + this.hreference + "' TARGET=\"main\" ")
    if (browserVersion > 0)
      doc.write("onClick='javascript:clickOnFolder("+this.id+")'")
    doc.write(">")
  }
  else
    doc.write("<a>")
  if (this.id != 0)
  	doc.write("<a href='javascript:clickOnFolder("+this.id+")' style='text-decoration:none'>")
}

function addChild(childNode)
{
  this.children[this.nChildren] = childNode
  childNode.parentObj = this
  this.nChildren++
  return childNode
}

function folderSubEntries()
{
  var i = 0
  var se = this.nChildren
 
  for (i=0; i < this.nChildren; i++){
    if (this.children[i].children) //is a folder
      se = se + this.children[i].subEntries()
  }
 
  return se
}


// Definition of class Item (a document or link inside a Folder)
// *************************************************************

function Item(itemDescription, itemLink) // Constructor
{
  // constant data
  this.desc = itemDescription
  this.link = itemLink
  this.id = -1 //initialized in initalize()
  this.navObj = 0 //initialized in render()
  this.iconImg = 0 //initialized in render()
  //this.iconSrc = "images/f2d.gif" //folder icon jerry chou
 
  // methods
  this.initialize = initializeItem
  this.createIndex = createEntryIndex
  this.hide = hideItem
  this.display = display
  this.renderOb = drawItem
  this.totalHeight = totalHeight
}

function hideItem()
{
  if (browserVersion == 1 || browserVersion == 3) {
    if (this.navObj.style.display == "none")
      return
    this.navObj.style.display = "none"
  } else {
    if (this.navObj.visibility == "hiden")
      return
    this.navObj.visibility = "hiden"
  }
}

function initializeItem(level, lastNode, leftSide)
{
  this.createIndex()
 
  if (level>0)
    if (lastNode) //the last 'brother' in the children array
    {
      this.renderOb(leftSide + "<img src='images/joinbottom.gif' width=16 height=22>")//ftv2.gif
      leftSide = leftSide + "<img src='images/tblank.gif' width=16 height=22>"
    }
    else
    {
      this.renderOb(leftSide + "<img src='images/join.gif' width=16 height=22>") //ftv3.gif
      leftSide = leftSide + "<img src='images/ftv2vertline.gif' width=16 height=22>"
    }
  else
    this.renderOb("")
}

function drawItem(leftSide)
{
  if (browserVersion == 2)
    doc.write("<layer id='item" + this.id + "' top=" + doc.yPos + " visibility=hiden>")
  
  doc.write("<table ")
  if (browserVersion == 1 || browserVersion == 3)
    doc.write(" id='item" + this.id + "' style='position:block;' ")
  doc.write(" border=0 cellspacing=0 cellpadding=0>")
  doc.write("<tr><td>")
  doc.write(leftSide)
  //doc.write("<a href=" + this.link + ">") //folder icon jerry chou
  //doc.write("<img id='itemIcon"+this.id+"' ") //folder icon jerry chou
 // doc.write("src='"+this.iconSrc+"' border=0>") //folder icon jerry chou
  //doc.write("</a>") //folder icon jerry chou
  doc.write("</td")
  doc.write(">")
  doc.write("<td valign=middle nowrap>")
  if (USETEXTLINKS)
    doc.write("<a href=" + this.link + "style='text-decoration:none'>" + this.desc + "</a>");
  else
    doc.write(this.desc);
  doc.write("</table");
  doc.write(">");
  
  if (browserVersion == 2)
    doc.write("</layer>");
 
  if (browserVersion == 1) {
    this.navObj = doc.all["item"+this.id];
    //this.iconImg = doc.all["itemIcon"+this.id];
  } else if (browserVersion == 2) {
    this.navObj = doc.layers["item"+this.id];
    //this.iconImg = this.navObj.document.images["itemIcon"+this.id];
    doc.yPos=doc.yPos+this.navObj.clip.height;
  }  else if (browserVersion == 3) {
    this.navObj = doc.getElementById("item"+this.id);
    //this.iconImg = doc.getElementById("itemIcon"+this.id);
  }
}

// Methods common to both objects (pseudo-inheritance)
// ********************************************************

function display()
{
  if (browserVersion == 1 || browserVersion == 3)
    this.navObj.style.display = "block";
  else
    this.navObj.visibility = "show";
}

function createEntryIndex()
{
  this.id = nEntries
  indexOfEntries[nEntries] = this
  nEntries++
}

// total height of subEntries open
function totalHeight() //used with browserVersion == 2
{
  var h = this.navObj.clip.height
  var i = 0

  if (this.isOpen) //is a folder and _is_ open
    for (i=0 ; i < this.nChildren; i++)
      h = h + this.children[i].totalHeight()
  return h
}


// Events
// *********************************************************

function clickOnFolder(folderId)
{
  var clicked = indexOfEntries[folderId]
  if (folderId != 0)
  	clickOnNode(folderId)
}

function clickOnNode(folderId)
{
  var clickedFolder = 0
  var state = 0

  clickedFolder = indexOfEntries[folderId]
  state = clickedFolder.isOpen

  clickedFolder.setState(!state) //open<->close
}

function initializeDocument()
{
  if (doc.all)
    browserVersion = 1 //IE > 4
  else
    if (doc.layers)
      browserVersion = 2 //NS 4 .x
    else
	 if (doc.getElementById)
      browserVersion = 3 //NS 6.x
	else
	  browserVersion = 0

  foldersTree.initialize(0, 1, "")
  foldersTree.display()
  
  if (browserVersion > 0)
  {
    doc.write("<layer top="+indexOfEntries[nEntries-1].navObj.top+">&nbsp;</layer>")
 
    // close the whole tree
    clickOnNode(0)
    // open the root folder
    clickOnNode(0)
  }
}

// Auxiliary Functions for Folder-Treee backward compatibility
// *********************************************************

function gFld(description, hreference)
{
  folder = new Folder(description, hreference)
  return folder
}
 
function gLnk(target, description, linkData, title)
{
  fullLink = ""

  if (target==0)
  {
    fullLink = "'"+linkData+"' target=\"main\""
  }
  else
  {
    if (target==1)
       fullLink = "'http://"+linkData+"' target=_blank"
    else
    {
    if (target==2)
   		 fullLink = "'"+linkData+"' target=\"_blank\""
    else
	  {
       if (target==3)
	   {
       fullLink = "'"+linkData+"' target=\"_top\""
	   }
	   else
	   {
       fullLink = "'http://"+linkData+"' target=\"main\""
	   }
	  }
    }
  }

  linkItem = new Item(description, fullLink)
  return linkItem
}

function insFld(parentFolder, childFolder)
{
  return parentFolder.addChild(childFolder)
}

function insDoc(parentFolder, document)
{
  return parentFolder.addChild(document)
}

 // Global variables
// ****************

USETEXTLINKS = 0
indexOfEntries = new Array
nEntries = 0
doc = document
browserVersion = 0
selectedFolder=0
