/**************************************************
Trivantis (http://www.trivantis.com)
**************************************************/

function Entry(fdesc, href, type) {
  this.desc = fdesc
  if( href.indexOf( 'javascript:' ) == 0 )
    this.href = href
  else
    this.href = 'javascript:trivExitPage("' + href + '")'
  this.id = -1
  this.navObj = null
  this.iconImg = null
  this.entryImg = null
  this.isLast = 0
  this.frame = -1
  this.hidden = false
  this.isOpen = false
  this.c = new Array
  this.nC = 0
  this.entryLeftSide = ""
  this.entryLevel = 0
  this.parent = 0
  this.isInitial = false
  this.isFolder = true
  if( type ) this.iType = type
  else this.iType = "page"
}

{ // Setup prototypes
var p=Entry.prototype
p.init = InitEntry
p.setState = setStateFolder
p.moveState = moveStateFolder
p.addChild = addChild
p.createIndex = createEntryIndex
p.hide = hide
p.display = display
p.initMode = initMode
p.initLayer = initLayer
p.setEntryDraw = setEntryDraw
p.entryIcon = entryIcon
p.treeIcon = entryTreeIcon
p.clickOn = clickOnEntry
}

function setStateFolder(isOpen) {
  this.isOpen = isOpen
  propagateChangesInState(this)
}

function moveStateFolder(isOpen) {
  var ht
  var i=0
  var j=0
  var parent = 0
  var thisentry = 0
  var found = false
  var width = 0
  ht = 0
  for (i=0; i < this.nC; i++) {
    if (!noDocs || this.c[i].isFolder){
      ht += this.c[i].navObj.clip.height
      if (isOpen) width = Math.max(width,this.c[i].navObj.clip.width)
    }
  }
  if (!isOpen) ht = -ht
  this.navObj.clip.height += ht
  if (isOpen) this.navObj.clip.width = Math.max(width, this.navObj.clip.width)
  thisentry = this
  parent = thisentry.parent
  for (i=0; i < this.entryLevel; i++){
    parent.navObj.clip.height += ht
    if (isOpen) parent.navObj.clip.width = Math.max(width, parent.navObj.clip.width)
    found = false
    for (j=0; j < parent.nC; j++){
      if (!noDocs || parent.c[j].nC != null){
        if (found) parent.c[j].navObj.moveBy(0,ht)
        else if (parent.c[j] == thisentry) found = true
      }
    }
    thisentry = parent
    parent = thisentry.parent
  }
  newHeight= fT.navObj.clip.height
  topLayer.clip.height = newHeight
  topLayer.clip.width = Math.max(topLayer.clip.width,fT.navObj.clip.width)
  newHeight = newHeight + gap
  frameHeight = thisFrame.innerHeight
  if (isOpen){
    if (doc.height < newHeight) doc.height = newHeight
    else if (newHeight < frameHeight) {
      doc.height = frameHeight
      thisFrame.scrollTo(0,0)
    }
    else if (doc.height > newHeight + 0.5*frameHeight){
      doc.height = doc.height*0.5 + (newHeight + 0.5*frameHeight)*0.5
    }
  }
}

function propagateChangesInState(folder) {
  var i=0
  if (folder.nC && treeLines == 1) {
    if (!folder.entryImg){
      if (is.ns4) folder.entryImg = folder.navObj.document.images["treeIcon"+folder.id]
      else if (doc.images) folder.entryImg = doc.images["treeIcon"+folder.id]
    }
    if (folder.entryLevel > 0) folder.entryImg.src = folder.treeIcon()
  }
  if (folder.isOpen && folder.isInitial){
    for (i=0; i<folder.nC; i++)
      if (!noDocs || folder.c[i].isFolder) folder.c[i].display()
  }
  else {
    if (folder.isInitial)
      for (i=0; i<folder.nC; i++)
        if (!noDocs || folder.c[i].isFolder) folder.c[i].hide()
  }
  if (!folder.iconImg){
    if (is.ns4) folder.iconImg = folder.navObj.document.images["entryIcon"+folder.id]
    else if (doc.images) folder.iconImg = doc.images["entryIcon"+folder.id]
  }
}

function display() {
  var i=0
  if (!is.ns4) {
    if (!this.navObj) this.navObj = doc.all["entry" + this.id]
      this.navObj.style.display = "block"
    if (this.isInitial && this.isOpen)
      for (i=0; i < this.nC; i++)
        if (!noDocs || this.c[i].isFolder) this.c[i].display()
  }
  else this.navObj.visibility = "inherit"
}

function hide() {
  var i = 0
  if (!is.ns4){
    if (!this.navObj) this.navObj = doc.all["entry" + this.id]
    this.navObj.style.display = "none"
  }
  else if (is.ns) this.navObj.visibility = "hidden"
  if (!is.ns4) {
    if (this.isInitial)
      for (i=this.nC-1; i>-1; i--){
        if (!noDocs || this.c[i].isFolder) this.c[i].hide()
      }
  }
}

function InitEntry(level, lastentry, leftSide, doc, prior) {
  this.createIndex()
  this.entryLevel = level
  if(!this.isFolder) this.isInitial = true
  if (level>0) {
    this.isLast = lastentry
    tmpIcon = this.treeIcon()
    if (this.isLast == 1) tmp2Icon = iTA["b"].src
    else tmp2Icon = iTA["vl"].src
    if (treeLines == 0) tmp2Icon = iTA["b"].src
    if (this.hidden == false) {
      if (level == 1 && treeLines == 0 && noTopFolder) this.setEntryDraw(leftSide, doc, prior)
      else {
        auxEv = ""
        if (this.isFolder && treeLines == 1 ){
          if( frameParent == "" ) {
            auxEv = ancStart + "href='javascript:void(null);' onClick='return clickOnEntry("+this.id+");'>"
            auxEv += "<img name='treeIcon" + this.id + "' src='" + tmpIcon + "' border='0' align='absmiddle' alt='' />"
          }
          else {
            if( scrollWnd ) {
              if( (is.ns5 && scrollWnd.tocFrame) || !is.ns5 ) auxEv = ancStart + "href='javascript:void(null);' onClick='return " +scrollWnd.name+".foldertree.clickOn("+this.id+");'>"
              else auxEv = ancStart + "href='javascript:void(null);' onClick='return clickOnEntry("+this.id+");'>"
            }
            else auxEv = ancStart + "href='javascript:void(null);' onClick='return " +frameParent + ".clickOnEntry("+this.id+");'>"
            auxEv += "<img name='treeIcon" + this.id + "' src='" + tmpIcon + "' border='0' align='absmiddle' alt='' />"
          }
          auxEv += "</a>"
        }
        else auxEv = "<img src='" + tmpIcon + "' align='absmiddle' />"
        this.setEntryDraw(leftSide + auxEv, doc, prior)
        if (this.isFolder) leftSide +=  "<img src='" + tmp2Icon + "' align='absmiddle' />"
      }
    }
  }
  else this.setEntryDraw("", doc, prior)
  if (this.isFolder) {
    this.entryLeftSide = leftSide
    if (this.nC > 0 && this.isInitial) {
      level = level + 1
      for (var i=0 ; i < this.nC; i++) {
        this.c[i].parent = this
        if (noDocs) {
          newLastEntry = 1
          for (var j=i+1; j < this.nC; j++)
            if (this.c[j].isFolder) newLastEntry = 0
        }
        else {
          newLastEntry = 0
          if (i == this.nC-1) newLastEntry = 1
        }
        if (i==0 && level == 1 && noTopFolder) newLastEntry = -1
        if (!noDocs || this.c[i].isFolder) {
          this.c[i].init(level, newLastEntry, leftSide, doc, prior)
        }
      }
    }
  }
  if (is.ns4 && this.hidden == false && !prior) doc.write("</layer>");
}

function setEntryDraw(leftSide,doc,prior) {
  var strbuf = ""
  if (prior) nEntries--;
  if (is.ns4) {
    if (!prior) {
      strbuf += "<layer id='entry" + this.id + "' visibility='hidden'>"
    }
    else {
      laywidth = 400
      var testlayer = new Layer(laywidth, prior)
    }
  }
  fullLink = ""
  if (this.href) {
    linkText = this.href
    int1 = linkText.indexOf("this\.id")
    if (int1 != -1) {
      linkText = linkText.substring(0,int1) + this.id + linkText.substring(int1+7)
    }
    fullLink = " href='" + linkText + "' " + targetFrameParm
  }
  else fullLink = " href='javascript:void(null);' "
  if (noFrame) fullLink = " href='" + this.href + "'"
  if (!is.ns4) strbuf += "<div id='entry" + this.id + "' style='position:static;'>"
  strbuf += "<table border='0' cellspacing='0' cellpadding='0'><tr><td valign='middle' nowrap>"
  strbuf += leftSide + ancStart + fullLink + ">"
  if( showIcons ) {
    strbuf += "<img name='entryIcon" + this.id + "' "
    var iA = iNA
    tmpIcon = this.entryIcon("",iA)
    strbuf += "src='" + tmpIcon + "' border='0' align='absmiddle' />"
  }
  var space = gap
  hspace = parseInt("" + (space/2 + .5) + "")
  wspace = 1
  if (hspace*2 == space) wspace = 2
  hspace = hspace - 1;
  var blankIcon = "<img border='0' align='absmiddle' height='" + wspace + "' width='" + wspace + "' src='" + iTA["b"].src + "' hspace='" + hspace + "' />"
  strbuf += blankIcon
  strbuf += "</a></td><td valign='middle' nowrap>"
  if (this.href) strbuf += ancStart + fullLink + " >" + this.desc + "</a>"
  else strbuf += this.desc
  if (is.ns4) strbuf += blankIcon
  strbuf += "</td></tr></table>\n"
  if (!is.ns4) strbuf += "</div>"
  if (this.entryLevel == 0 && noTopFolder) {
    if (is.ns4) strbuf = "<layer id='entry" + this.id + "' visibility='hidden'>"
    else strbuf = "<div id='entry" + this.id + "'></div>"
  }
  this.navObj = null
  if (this.isFolder) this.entryImg = null
  this.iconImg = null
  if ( !prior) {
    if (is.ns4) doc.write(strbuf)
    else strbufarray[this.id] = strbuf
  }
  else {
    if(!is.ns4) {
      strbufarray[strbufIndex]=strbuf
      strbufIndex++
      nEntries++
    }
    else {
      testlayer.document.open()
      testlayer.document.write(strbuf)
      testlayer.document.close()
      this.navObj=testlayer
      this.navObj.top=doc.yPos
      this.navObj.visibility='inherit'
      doc.yPos+=this.navObj.clip.height
      nEntries++
    }
  }
}

function createEntryIndex(){
  this.id = nEntries
  indexOfEntries[nEntries] = this
  nEntries++
}

function entryTreeIcon (){
  iName = ""
  if (this.isFolder) {
    if (this.isOpen) {
      if (this.isLast == 0) iName = "mn"
      else if (this.isLast == 1) iName = "mln"
      else iName = "mfn"
    }
    else {
      if (this.isLast == 0) iName = "pn"
      else if (this.isLast == 1) iName = "pln"
      else iName = "pfn"
    }
    folderChildren = false
    if( this.nC ) folderChildren = true
    if (!folderChildren) {
      if (this.isLast == 0) iName = "n"
      else if (this.isLast == 1) iName = "ln"
      else iName = "fn"
    }
  }
  else {
    if (this.isLast == 0) iName = "n"
    else if (this.isLast == 1) iName = "ln"
    else iName = "fn"
  }
  if (treeLines == 0) iName = "b"
  tmpIcon = iTA[iName].src
  return tmpIcon
}

function entryIcon(over,iA){
  tmpIcon = ""
  tmpIcon = iA[this.iType].src
  if (tmpIcon == "") tmpIcon = iTA["b"].src
  return tmpIcon;
}

function clickOnEntry(folderId){
  var cF = 0
  var state = 0
  cF = indexOfEntries[folderId]
  if (!cF) return false;
  if (!cF.navObj && !is.ns4) cF.navObj = doc.all["entry" + cF.id]
  state = cF.isOpen
  if (!state) {
    if (cF.isInitial == false) {
      if(cF.nC > 0) {
        if (is.ns4) doc.yPos = cF.navObj.clip.height
        prior = cF.navObj
        level = cF.entryLevel
        leftSide = cF.entryLeftSide
        if (!is.ns4){
          strbufarray = new Array
          strbufIndex = 0
        }
        for (var i=0 ; i < cF.nC; i++) {
          cF.c[i].parent = cF
          if (i == cF.nC-1) newLastEntry = 1
          else last = 0
          if (noDocs) {
            newLastEntry = 1
            for (var j=i+1; j < cF.nC; j++)
              if (cF.c[j].isFolder) newLastEntry = 0
          }
          else {
            newLastEntry = 0
            if (i == cF.nC-1) newLastEntry = 1
          }
          if (!noDocs || cF.c[i].isFolder){
            cF.c[i].init(level + 1, newLastEntry, leftSide, doc, prior)
            needRewrite = true
          }
        }
        if (!is.ns4) {
          htmlStr = strbufarray.join("")
          if( prior.insertAdjacentHTML ) {
            prior.insertAdjacentHTML("AfterEnd",htmlStr)
          }
          else {
            var ihtml = prior.innerHTML;
            var newHTML, range = document.createRange();
            range.selectNode(prior);
            newHTML = range.createContextualFragment(prior.innerHTML+htmlStr);
            prior.parentNode.replaceChild(newHTML, prior);
            prior.innerHTML = ihtml;          
          }
        }
        cF.setState(!state)
        cF.isInitial = true
      }
    }
    else cF.setState(!state)
  }
  else cF.setState(!state)
  if (is.ns4)cF.moveState(!state);
  if (!state && modalClick && (cF.entryLevel > 0)) {
    for (i=0; i < cF.parent.nC; i++) {
      if (cF.parent.c[i].isOpen && (cF.parent.c[i] != cF)) {
        if (is.ns4) cF.parent.c[i].moveState(false)
        cF.parent.c[i].setState(false)
      }
    }
  }
  doc.close()
    
  if( scrollWnd != null ) {
    if( topLayer ) scrollWnd.activate(topLayer.clip.width, topLayer.clip.height+gap, false)
    else scrollWnd.activate(null,null,false)
  }
  return false;
}

function initMode() {
  var i=0
  if (initialMode == 2) {
    if (this.isFolder) this.isOpen = true
    this.isInitial = true
  }
  if (this.isFolder) {
    for (i=0; i<this.nC; i++){
      this.c[i].initMode()
      if (this.c[i].isOpen && this.c[i].isInitial){
        this.isOpen = true
        this.isInitial = true
      }
    }
  }
}

function initializeDocument() {
  if (firstInitial) {
    if (initialMode == 0) {
      fT.isInitial = false
      fT.isOpen = false
    }
    if (initialMode == 1){
      fT.isInitial = true
      fT.isOpen = true
    }
    fT.initMode()
  }
  prior = null
  fT.init(0, 1, "", doc, prior)
  firstInitial = false
}

function initLayer() {
  var i
  var ht
  var oldyPos
  var width = 0
  if (!this.parent) layer = topLayer
  else layer = this.parent.navObj
  this.navObj = layer.document.layers["entry"+this.id]
  this.navObj.top = doc.yPos
  this.navObj.visibility = "inherit"
  if (this.nC > 0 && this.isInitial) {
    doc.yPos += this.navObj.document.layers[0].top
    oldyPos = doc.yPos
    doc.yPos = this.navObj.document.layers[0].top
    this.navObj.clip.height = doc.yPos
    ht = 0
    for (i=0 ; i < this.nC; i++) {
      if (!noDocs || this.c[i].isFolder) {
        if (this.c[i].hidden == false) this.c[i].initLayer()
        if (is.ns4) {
          ht +=  this.c[i].navObj.clip.height
          width = Math.max(width,this.c[i].navObj.clip.width)
        }
      }
    }
    if (this.isOpen) {
      doc.yPos = oldyPos + ht
      this.navObj.clip.height += ht
      this.navObj.clip.width = Math.max(width, this.navObj.clip.width)
    }
    else doc.yPos = oldyPos
  }
  else doc.yPos += this.navObj.clip.height
}

function NewFolder(d, h, t){
  folder = new Entry(d, h, t)
  folder.isFolder = true
  return folder
}

function NewLink(d, h, t){
  linkItem = new Entry(d, h, t)
  linkItem.isFolder = false
  return linkItem
}

function insertFolder(p, c){
  return p.addChild(c)
}

function insertEntry(p, d){
  return p.addChild(d)
}

function addChild(childentry){
  this.c[this.nC] = childentry
  this.nC++
  return childentry
}

function fTimage(f){
  this.src = imageFolder + f
  return
}

function AddIcon(icon,prop,f) {
  if (is.ns4) icon[prop] = new fTimage(f)
  else {
    icon[prop] = new Image()
    icon[prop].src = imageFolder + f
  }
}

function initImage(){
  AddIcon(iNA,"au",auIcon)
  AddIcon(iNA,"chap",chapIcon)
  AddIcon(iNA,"page",pageIcon)
  AddIcon(iNA,"ques",questIcon)
  AddIcon(iNA,"test",testIcon)
  AddIcon(iNA,"sect",sectIcon)
  AddIcon(iNA,"testsect",testsectIcon)
  AddIcon(iTA,"mn",mnIcon)
  AddIcon(iTA,"pn",pnIcon)
  AddIcon(iTA,"pln",plnIcon)
  AddIcon(iTA,"mln",mlnIcon)
  AddIcon(iTA,"pfn",pfnIcon)
  AddIcon(iTA,"mfn",mfnIcon)
  AddIcon(iTA,"b",bIcon)
  AddIcon(iTA,"ln",lnIcon)
  AddIcon(iTA,"fn",fnIcon)
  AddIcon(iTA,"vl",vlIcon)
  AddIcon(iTA,"n",nIcon)
}

backButton = false

function rewritepage() {
  if (backButton ) {
    if( !is.ns4) {
      history.back();
      setTimeout("history.back()",200);
      backButton = false
      return false;
    }
    else {
      history.back();
      backButton = false
      return false;
    }
  }
  backButton = true
  if (rewriting) return false;
  rewriting = true
  if (!fT) {
    alert("No TOC structure")
    rewriting = false
    return false;
  }
  if (noFrame) {
    doc = document
    if( !is.ns4 ) frameParent = "window"
    else frameParent = ""
    thisFrame = self
  }
  else {
    if( is.ns4 ) thisFrame = parent.frames[menuFrame]
    else thisFrame = this
        
    doc = thisFrame.document
    if (is.ns4) {
      if (doc.width == 0) {
        clearTimeout(rewriteID)
        rewriteID = setTimeout("rewritepage()",1000)
        rewriting = false
        return false;
      }
    }
  }
  if( is.ns5 ) doc.all = doc.getElementsByTagName("*");
  
  if( is.ieMac ) initialMode=2
  initImage()
  if (!is.ns4) doc.open()
  nEntries = 0
  doc = thisFrame.document
  if (!is.ns4) {
    doc.write("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\">" )
    doc.write("<html><head>")
    if (cssFile != "") doc.write("<link rel='stylesheet' href='" + cssFile + "' />")
    doc.write("<base href='" + document.location + "' />");
    doc.write("<title></title></head>")
    doc.write("<body>")
    doc.write("<table border='0' style='height:100%;width:100%;'><tr><td width='1' valign='top'>")
    doc.write("<div id='foldertree' style='position:static; '>")
    strbufarray = new Array
    ancStart = "<a style='" + ancStyle + "' "
    initializeDocument()
    eval("htmlStr = strbufarray.join(''); doc.write(htmlStr);")
    doc.write("</div>")
    doc.write("</td></tr></table>\n")
    doc.write("</body></html>\n")
  }
  else {
    doc.write("<layer id='body' visibility='inherit'></layer>")
    doc.write("<layer id = 'foldertree' visibility='inherit' top='" + gap + "' left='" + gap + "' z-index='1'>")
    initializeDocument()
    doc.write("</layer>")
  }
  if (!is.ns4) {
    doc.body.topMargin = 0
    doc.body.leftMargin = 0
    doc.body.rightMargin = 0
  }
  // Reset
  if( is.ns4) {
    doc = document
    topLayer = doc.layers["foldertree"]
    doc.yPos = 0
    fT.initLayer()
    topLayer.clip.height = fT.navObj.clip.height
    doc.height = topLayer.clip.height + gap
    topLayer.visibility = "inherit"
    fT.display()
    doc.body.left = doc.foldertree.clip.width
    doc.body.resizeTo(self.innerWidth - doc.body.left,self.innerHeight)
  }
  rewriting = false
  needRewrite = false
  needReload = false
  if( scrollWnd != null ) {
    if( topLayer ) scrollWnd.activate(topLayer.clip.width, topLayer.clip.height+gap, false)
    else scrollWnd.activate(null,null,false)
  }
  return false;
}

// Global variables
// ****************
var indexOfEntries = new Array
var nEntries = 0
var needRewrite = true
var needReload = false
var doc = document
var topLayer = null
var firstInitial = true
top.defaultStatus = "";
iNA = new Object()
iTA = new Object()
imageArray = new Object()
var nImageArray = 0
rewriteID = 0
rewriting = false
frameParent = "parent"
thisFrame = self
pnIcon = "ftpn.gif";
mnIcon = "ftmn.gif";
pfnIcon = "ftpfn.gif";
mfnIcon = "ftmfn.gif";
plnIcon = "ftpln.gif";
mlnIcon = "ftmln.gif";
nIcon = "ftn.gif";
fnIcon = "ftfn.gif";
lnIcon = "ftln.gif";
bIcon = "ftb.gif";
vlIcon = "ftvl.gif";
pageIcon = "tocpageicon.gif"
questIcon = "tocquesicon.gif"
chapIcon = "tocchapicon.gif"
auIcon   = "tocauicon.gif"
testIcon = "toctesticon.gif"
sectIcon = "tocsecticon.gif"
testsectIcon = "toctestsecticon.gif"
var fT = 0

var cssFile = "trivantis.css"
var noFrame = true
var menuFrame = "menufrm"
var targetFrameParm = ""
var ancStart = "<a "
var ancStyle = ""
//var defFrame = 1
var gap = 8
var modalClick = false
var initialMode = 1
var treeLines = 1
var noDocs = false
var noTopFolder = true
var imageFolder = "images/"
var showIcons = true
var scrollWnd = null

function ObjInlineTOC(name,x,y,width,height,visible,zorder,bgcolor,frame) {
  this.name=name
  this.x=x
  this.y=y
  this.w=width
  this.h=height
  this.frame=(!is.ns4 && frame!=null)? window.top.frames[frame] : parent
  if( this.frame == null ) this.frame = parent
  if( visible ) this.v = "inherit"
  else this.v = (is.ns4)? "hide" : "hidden"
  this.bgColor=bgcolor
  this.z = zorder
  this.obj=this.name+"Object"
  this.foldertree=null
  this.tocFrame=null
  eval(this.obj+"=this")
}

{ //Setup prototypes
var p=ObjInlineTOC.prototype
p.build=ObjInlineTOCBuild
p.activate=ObjInlineTOCActivate
p.load=ObjInlineTOCLoad
p.actionGoTo = ObjInlineTOCActionNULL
p.actionGoToNewWindow = ObjInlineTOCActionNULL
p.actionPlay = ObjInlineTOCActionNULL
p.actionStop = ObjInlineTOCActionNULL
p.actionShow = ObjInlineTOCActionShow
p.actionHide = ObjInlineTOCActionHide
p.actionLaunch = ObjInlineTOCActionNULL
p.actionExit = ObjInlineTOCActionNULL
p.actionChangeContents = ObjInlineTOCActionNULL
p.actionTogglePlay = ObjInlineTOCActionNULL
p.actionToggleShow = ObjInlineTOCActionToggleShow
p.slideTo = ObjInlineTOCSlideTo
p.moveTo = ObjInlineTOCMoveTo
}

function ObjInlineTOCBuild() {
  this.css=buildCSS(this.name,this.x,this.y,this.w,this.h,this.v,this.z)
  this.css+=buildCSS(this.name+'Content',0,0,this.w,null,null,null,this.bgColor)
  this.divStart=(!is.ns4)? '<iframe name="'+this.name+'Frame" width=0 height=0 style="position:absolute; left:0; top:0; visibility:none"></iframe>\n':''
  this.divStart+='<div id="'+this.name+'"><div id="'+this.name+'Content">'
  this.divEnd='</div></div>'
  this.div=this.divStart+this.divEnd
}
function ObjInlineTOCActivate(w,h) {
  if( is.ns5 ) document.all = document.getElementsByTagName("*");
  if( !is.ns4 && !this.tocFrame ) return;
  if (!this.activated) this.objLyr=new ObjLayer(this.name)
  if (!is.ns4 && this.tocFrame.document.body.innerHTML) 
    document.all[this.name+'Content'].innerHTML=this.tocFrame.document.body.innerHTML
  this.contentlyr=new ObjLayer(this.name+'Content')
  this.contentHeight=h
  this.contentWidth=w
  if (is.ns4) {
    this.contentlyr.styObj.clip.bottom=this.contentHeight
    this.contentlyr.styObj.clip.right=this.contentWidth
    this.objLyr.styObj.clip.bottom=this.contentHeight
    this.objLyr.styObj.clip.right=this.contentWidth
    document.height=this.objLyr.y+this.contentHeight
  }
  else {
    this.objLyr.clipTo(0,document.all[this.name+'Content'].scrollWidth,document.all[this.name+'Content'].scrollHeight,0)
    if( is.ieMac ) {
      this.objLyr.ele.offsetHeight = this.contentlyr.ele.offsetHeight
      this.objLyr.ele.offsetWidth = this.contentlyr.ele.offsetWidth
    }
  }
  this.activated=true
}

function locateFrame( frameName, currFrame ) {
  if( currFrame[frameName] ) return currFrame[frameName]
  else {
    var index = 0
    while( index < currFrame.length ) {
      var testFrame = locateFrame( frameName, currFrame[index] )
      if( testFrame ) return testFrame
      index++
    }
  }
}
function ObjInlineTOCLoad(url) {
  if( !this.activated ) {
    this.url=url
    this.refresh=true
    if (is.ns4) {
      this.contentlyr=new ObjLayer(this.name+'Content')
      this.contentlyr.moveTo(0,0)
      this.contentlyr.ele.load(this.url,this.w)
    }
    else {
      var targFrameName = this.name+'Frame'
      var targFrame = locateFrame( targFrameName, this.frame.frames )

      if( targFrame ) {            
        this.tocFrame = targFrame
        this.tocFrame.document.location=this.url
      }
    }
  }
}

function ObjInlineTOCActionShow( ) {
  if( !this.objLyr ) {
    if( !this.activated ) setTimeout( this.obj + ".actionShow()", 1000 );
  }
  else this.objLyr.actionShow();
}

function ObjInlineTOCActionHide( ) {
  if( !this.objLyr ) {
    if( !this.activated ) setTimeout( this.obj + ".actionHide()", 1000 );
  }
  else this.objLyr.actionHide();
}

function ObjInlineTOCActionToggleShow( ) {
  if( !this.objLyr ) {
    if( !this.activated ) setTimeout( this.obj + ".actionToggleShow()", 1000 );
  }
  else this.objLyr.actionToggleShow();
}

function ObjInlineTOCSlideTo(ex,ey,amt,spd,fn) {
  if (this.objLyr) this.objLyr.slideTo(ex,ey,amt,spd,fn);
}

function ObjInlineTOCMoveTo(x,y) {
  if (this.objLyr) this.objLyr.moveTo(x,y);
}

function ObjInlineTOCActionNULL( ) {
}

