//**************************************************************** 
// You are free to copy the "Folder-Tree" script as long as you  
// keep this copyright notice: 
// Script found in: http://www.geocities.com/Paris/LeftBank/2178/ 
// Author: Marcelino Alves Martins (martins@hks.com) December '97. 
//**************************************************************** 
 
//Log of changes: 
//       17 Feb 98 - Fix initialization flashing problem with Netscape
//       
//       27 Jan 98 - Root folder starts open; support for USETEXTLINKS; 
//                   make the ftien4 a js file 
//       
 
 
// Definition of class Folder 
// ***************************************************************** 


function Folder(iconHeight, folderDescription, hreference) //constructor 
{ 
  //constant data 
  this.iconHeight = iconHeight
  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 = "" 
  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 
 
  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 = "" 
      else 
	  folder.nodeImg.src = "" 
    folder.iconImg.src = "" 
    for (i=0; i<folder.nChildren; i++) 
      folder.children[i].display() 
  } 
  else 
  { 
    if (folder.nodeImg) 
      if (folder.isLastNode) 
        folder.nodeImg.src = "" 
      else 
	  folder.nodeImg.src = "" 
    folder.iconImg.src = "" 
    for (i=0; i<folder.nChildren; i++) 
      folder.children[i].hide() 
  }  
} 
 
function hideFolder() 
{ 
  if (browserVersion == 1) { 
    if (this.navObj.style.display == "none") 
      return 
    this.navObj.style.display = "none" 
  } else { 
    if (this.navObj.visibility == "hidden") 
      return 
    this.navObj.visibility = "hidden" 
  } 
   
  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 + "' src='' width=0 height=" + this.iconHeight + " align=bottom border=0></a></td></tr><tr><td align=left><img src='images/line-orange.gif' height=1 width=128></td></tr>") 
      leftSide = leftSide + "<img src='' width=0 height=" + this.iconHeight + " align=bottom></td></tr><tr><td align=left><img src='images/line-orange.gif' height=1 width=128></td></tr>"  
      this.isLastNode = 1 
    } 
    else 
    { 
      
      this.renderOb(leftSide + auxEv + "<img name='nodeIcon" + this.id + "' src='' width=0 height=" + this.iconHeight + " align=bottom border=0></a></td></tr><tr><td align=left><img src='images/line-orange.gif' height=1 width=128></td></tr>") 
      leftSide = leftSide + "<img src='' width=0 height=" + this.iconHeight + " align=bottom></td></tr><tr><td align=left><img src='images/line-orange.gif' height=1 width=128></td></tr>" 
      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=0 
    doc.write("<layer id='folder" + this.id + "' top=" + doc.yPos + " visibility=hidden>") 
  } 
   
  doc.write("<table ") 
  if (browserVersion == 1) 
    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 + "' ") 
  doc.write("src='" + this.iconSrc+"' border=0 width=1 height=" + this.iconHeight + " align=bottom></a></td></tr><tr><td align=left><img src='images/line-orange.gif' height=1 width=128></td><td rowspan=2><img src='images/line-orange.gif' width=1 height=24></td></tr>") 
  doc.write("</td><td valign=bottom nowrap><img src='images/space-black.gif' width=0 height=22 align=center>") 
  if (USETEXTLINKS) 
  { 
    this.outputLink() 
    doc.write("" + this.desc + "</a>") 
  } 
  else 
    doc.write("" + this.desc + "") 
  doc.write("</td>")
  doc.write("</table>") 
  //customised table end for na piarsaigh site
   if (this.desc== "Fundraising Lotto"){
  	doc.write("<table border=0 cellpadding=0 cellspacing=0 style='border:0px solid orange;' width='100%'><tr><td><iframe id='Fundraising-Draws-4'  src='http://www.helpourclub.ie/fundraising-draws.asp?LGO=1&amp;V=v3&amp;LL_ID=261&amp;HDR=1&amp;RLNK=1&amp;HDR=0&amp;LNKL=ff0000&amp;LNKH=999999&amp;ST=3&amp;FACE=arial&amp;BDYC=ffffcc'  height='160' width='125' scrolling='no' frameborder='0' style='margin:0px;border: 1px solid #ffba00;border-right: 2px solid #ffba00;border-left: 2px solid #ffba00;margin-bottom:5px;'></iframe></td></tr></table>")
}
  if (this.desc== "Development Draw"){
  	doc.write("<table border=0 cellpadding=0 cellspacing=0 style='border:0px solid orange;' width='100%'><tr><td><a href='http://www.locallotto.ie/tickets.asp?LL_ID=261&intTE_ID=6&CLB=1' onclick='fctDrawLink();return false;' onkeypress='fctDrawLink();return false;' target='_blank'><img src='Na-Piarsaigh-Development-Draw-link.jpg' width='125' height='121' alt='Click here to Enter our Development Draw Online.'  style='margin:0px;border: 1px solid #ffba00;border-right: 2px solid #ffba00;border-left: 2px solid #ffba00;margin-bottom:5px;'></a></td></tr></table>")
}
  if (this.desc== "Sponsors")
  	doc.write("<table border=0 cellpadding=0 cellspacing=0><tr><td><img src='images/line-orange.gif' border=0 width=129 height=1></td></tr></table>")

   
  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 
  } 
} 
 
function outputFolderLink() 
{ 
  if (this.hreference) 
  { 
    doc.write("<a href='" + this.hreference + "' class=\"headerlink\" ") 
	if (this.desc=="Fundraising Lotto")
		doc.write(" title='Click here for full details.'") 
    if (browserVersion > 0) 
      doc.write("onClick='javascript:clickOnFolder("+this.id+")'") 
    doc.write(">") 
  } 
  else 
//    doc.write("<a class=\"headerlink\" >") 
  doc.write("<a href= 'javascript:clickOnFolder("+this.id+")' class=\"headerlink\" >")   
} 
 
function addChild(childNode) 
{ 
  this.children[this.nChildren] = childNode 
  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 = "space-black.gif" 
  
  // methods 
  this.initialize = initializeItem 
  this.createIndex = createEntryIndex 
  this.hide = hideItem 
  this.display = display 
  this.renderOb = drawItem 
  this.totalHeight = totalHeight 
} 
 
function hideItem() 
{ 
  if (browserVersion == 1) { 
    if (this.navObj.style.display == "none") 
      return 
    this.navObj.style.display = "none" 
  } else { 
    if (this.navObj.visibility == "hidden") 
      return 
    this.navObj.visibility = "hidden" 
  }     
} 
 //submenu
function initializeItem(level, lastNode, leftSide) 
{  
  this.createIndex() 
 
  if (level>0) 
    if (lastNode) //the last 'brother' in the children array 
    { 
      this.renderOb(leftSide + "<img src='' width=0 height=" + this.iconHeight + " align=bottom></td></tr><tr><td align=left><img src='images/line-orange.gif' height=1 width=128></td></tr>") 
      leftSide = leftSide + "<img src='images/space-black.gif' width=1 height=" +this.iconHeight + " align=bottom></td></tr><tr><td align=left><img src='images/line-orange.gif' height=1 width=128></td></tr>"  
    } 
    else 
    { 
      this.renderOb(leftSide + "<img src='' width=0 height=" + this.iconHeight + " align=bottom></td></tr><tr><td align=left><img src='images/line-orange.gif' height=1 width=128></td></tr>") 
      leftSide = leftSide + "<img src='' width=0 height=" + this.iconHeight + " align=bottom></td></tr><tr><td align=left><img src='images/line-orange.gif' height=1 width=128></td></tr>" 
    } 
  else 
    this.renderOb("")   
} 
 
function drawItem(leftSide) 
{ 
  if (browserVersion == 2) 
    doc.write("<layer id='item" + this.id + "' top=" + doc.yPos + " visibility=hidden>") 
     
  doc.write("<table ") 
  if (browserVersion == 1) 
    doc.write(" id='item" + this.id + "' style='position:block;' ") 
  doc.write(" border=0 cellspacing=0 cellpadding=0>")
  doc.write("<tr><td></td><td valign=top rowspan=4><img src='images/line-orange.gif' width=1 height=22></td></tr>")  
  doc.write("<tr><td>") 
  doc.write(leftSide) 
//   doc.write("<a href=" + this.link + ">") 
//   doc.write("<img id='itemIcon"+this.id+"' ")
//   doc.write("src='"+this.iconSrc+"' border=0>")
//   doc.write("</a>")
  doc.write("</td><td valign=middle nowrap>") 
  if (USETEXTLINKS)
  {
    if (this.link=="") 
      doc.write(this.desc)
    else
      doc.write("<a href=" + this.link + "class='links2'>" + this.desc + "</a>")
  } 
  else 
    doc.write("this.desc") 
  doc.write("</td></tr></table>")
   
  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 
  } 
} 
function drawLotto() 
{ 
  if (browserVersion == 2) 
    doc.write("<layer id='itemlotto' top=" + doc.yPos + " visibility=show>") 
     
  doc.write("<table ") 
  if (browserVersion == 1) 
    doc.write(" id='itemlotto' style='position:block;' ") 
  doc.write(" border=0 cellspacing=0 cellpadding=0>")
  doc.write("<tr><td></td><td valign=top rowspan=4><img src='images/line-orange.gif' width=1 height=22></td></tr>")  
  doc.write("<tr><td>this is it") 
 
  doc.write("</td><td valign=middle nowrap>") 
  doc.write("<a href=fundraising-lotto.html class='links2'>Fundraising Lotto</a>")
   
  doc.write("</td></tr></table>")
   
  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 
  } 
} 
 
 
// Methods common to both objects (pseudo-inheritance) 
// ******************************************************** 
 
function display() 
{ 
  if (browserVersion == 1) 
    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 (!clicked.isOpen) 
//    clickOnNode(folderId) 
 
//  return  
 
//  if (clicked.isSelected) 
//    return 

  var clickedFolder = 0 
  var state = 0 
 
  clickedFolder = indexOfEntries[folderId] 
  state = clickedFolder.isOpen 
 
  clickedFolder.setState(!state) //open<->close  
} 
 
function clickOnNode(folderId) 
{ 
  var clickedFolder = 0 
  var state = 0 
 
  clickedFolder = indexOfEntries[folderId] 
  state = clickedFolder.isOpen 
 
  clickedFolder.setState(!state) //open<->close  
} 
 

 
// Auxiliary Functions for Folder-Treee backward compatibility 
// ********************************************************* 
 
function gFld(iconHeight, description, hreference) 
{ 
  folder = new Folder(iconHeight, description, hreference) 
  return folder 
} 
 
function gLnk(target, description, linkData) 
{ 
  fullLink = "" 
 
  if (target==0) 
  { 
    fullLink = "'"+linkData+"'" 
  } 
  else if (target==1) 
  { 
    fullLink = "'http://"+linkData+"'" 
  }
  else if (target==2)
  {
    fullLink = "'"+linkData+"'"
  }
   else if (target==3)
  {
    fullLink = ""
  }
  else
  { 
       fullLink = "'"+linkData+"'" 
  }
  
 
  linkItem = new Item(description, fullLink)   
  return linkItem 
} 
 
function insFld(parentFolder, childFolder) 
{ 
  return parentFolder.addChild(childFolder) 
} 
 
function insDoc(parentFolder, document) 
{ 
  parentFolder.addChild(document) 
} 
 
// Global variables 
// **************** 
 
USETEXTLINKS = 1 
indexOfEntries = new Array 
nEntries = 0 
doc = document 
browserVersion = 0 
selectedFolder=0


function fctPopUp(name,url,wdth,hght,scrl,mnu,resz){
	if (eval('window.'+name)) { 
		if (eval('!window.'+name+'.closed')) {
			eval(name+'.close()');
		}
	} 
	
	var intX = 0
	var intY = 0
	var strScrl
	var strMnu
	
	if (scrl){
		strScrl = "yes";
	}else{
		strScrl = "no";
	}
	
	if (mnu){
		strMnu = "yes";
	}else{
		strMnu = "no";
	}
	
	if (resz){
		strResize = "yes";
	}else{
		strResize = "no";
	}
	
	if (window.screen.width){
		if (screen.width - wdth > 0){
			intX = (screen.width - wdth)/2
		}
	}
	
	if (window.screen.height){
		if (screen.height - hght> 0){
			intY = (screen.height - hght)/2
		}
	}
	eval(name+'=window.open("'+url+'","'+name+'","menubar='+strMnu+',scrollbars='+strScrl+',scrolling='+strScrl+',width='+wdth+',height='+hght+',resizable='+strResize+',screenX='+intX+',screenY='+intY+',left='+intX+',top='+intY+', status")');
	//if (eval('window.'+name)) { 
		//eval(name+'.focus()');
	//}
}
function fctDrawLink(){
	fctPopUp('_tckt','http://www.locallotto.ie/tickets.asp?LL_ID=261&intTE_ID=6&CLB=1',790,500,1,0,1);
}