home *** CD-ROM | disk | FTP | other *** search
/ Enter 2001 July / EnterCD7.iso / Off-line / w8 / HM_ScriptDOM.js < prev    next >
Encoding:
Text File  |  2001-02-25  |  25.3 KB  |  735 lines

  1. /*HM_ScriptDOM.js
  2. * by Peter Belesis. v4.0.3 010123
  3. * Copyright (c) 2001 Peter Belesis. All Rights Reserved.
  4. * Originally published and documented at http://www.dhtmlab.com/
  5. * You may use this code on a public Web site only if this entire
  6. * copyright notice appears unchanged and you publicly display
  7. * a link to http://www.dhtmlab.com/.
  8. *
  9. * Contact pbel@meteor.com for all other uses.
  10. */
  11.  
  12. HM_IE5M = HM_IE && HM_Mac;
  13. HM_IE5W = HM_IE && !HM_Mac;
  14. HM_NS6 = (navigator.vendor == ("Netscape6") || navigator.product == ("Gecko"));
  15.  
  16. HM_a_Parameters = [
  17.     ["MenuWidth",          150],
  18.     ["FontFamily",         "Arial,sans-serif"],
  19.     ["FontSize",           10],
  20.     ["FontBold",           false],
  21.     ["FontItalic",         false],
  22.     ["FontColor",          "black"],
  23.     ["FontColorOver",      "white"],
  24.     ["BGColor",            "white"],
  25.     ["BGColorOver",        "black"],
  26.     ["ItemPadding",        3],
  27.     ["BorderWidth",        2],
  28.     ["BorderColor",        "red"],
  29.     ["BorderStyle",        "solid"],
  30.     ["SeparatorSize",      1],
  31.     ["SeparatorColor",     "yellow"],
  32.     ["ImageSrc",           "tre.gif"],
  33.     ["ImageSrcLeft",       ""],
  34.     ["ImageSize",          5],
  35.     ["ImageHorizSpace",    0],
  36.     ["ImageVertSpace",     0],
  37.     ["KeepHilite",         false],
  38.     ["ClickStart",         false],
  39.     ["ClickKill",          true],
  40.     ["ChildOverlap",       20],
  41.     ["ChildOffset",        10],
  42.     ["ChildPerCentOver",   null],
  43.     ["TopSecondsVisible",  .5],
  44.     ["StatusDisplayBuild", 1],
  45.     ["StatusDisplayLink",  1],
  46.     ["UponDisplay",        null],
  47.     ["UponHide",           null],
  48.     ["RightToLeft",        false],
  49.     ["CreateTopOnly",      0],
  50.     ["ShowLinkCursor",     false]
  51. ]
  52.  
  53. HM_MenuIDPrefix = "HM_Menu";
  54. HM_ItemIDPrefix = "HM_Item";
  55. HM_ArrayIDPrefix = "HM_Array";
  56.  
  57. function HM_f_StringTrim(){
  58.     var TestString = this;
  59.     var SpaceChar  = " ";
  60.     while (TestString.charAt(0) == SpaceChar) {TestString = TestString.substr(1)};
  61.     while (TestString.charAt(TestString.length-1) == SpaceChar) {TestString = TestString.substr(0,TestString.length-1)};
  62.     return TestString.toString();
  63. }
  64.  
  65. HM_a_BadChars = [".","/"," ",",","-"];
  66.  
  67. function HM_f_StringStrip(){
  68.     var TestString = this;
  69.     var BadChar;
  70.     for(var i=0;i<HM_a_BadChars.length;i++) {
  71.         BadChar = HM_a_BadChars[i];
  72.         BadCharIndex = TestString.lastIndexOf(BadChar);
  73.         if(BadCharIndex!=-1) TestString = TestString.substr(BadCharIndex + 1);
  74.     }
  75.     return TestString.toString();
  76. }
  77.  
  78. String.prototype.trim = HM_f_StringTrim;
  79. String.prototype.strip = HM_f_StringStrip;
  80.  
  81. function HM_f_AssignParameters(paramname,defaultvalue){
  82.     var FullParamName = "HM_" + paramname;
  83.     if (typeof eval("window.HM_PG_" + paramname) == "undefined") {
  84.         if (typeof eval("window.HM_GL_" + paramname) == "undefined") {
  85.             eval(FullParamName + "= defaultvalue");
  86.         }
  87.         else {
  88.             eval(FullParamName + "= HM_GL_" + paramname);
  89.         }
  90.     }
  91.     else {
  92.         eval(FullParamName + "= HM_PG_" + paramname);
  93.     }
  94.  
  95.     var TestString = eval(FullParamName);
  96.     if(eval("typeof(TestString)") == "string") {
  97.         TestString = TestString.trim();
  98.         if(TestString.length == 0) {
  99.             eval(FullParamName + "= null");
  100.             return;
  101.         }
  102.         if(TestString.charAt(0)=="#")return;
  103.         TestString = TestString.strip();
  104.     }
  105.  
  106.     if (eval("typeof(" + TestString +")") != 'undefined') {
  107.         eval(FullParamName + "= eval("+ FullParamName +")");
  108.     }
  109. }
  110.  
  111. for (i=0;i<HM_a_Parameters.length;i++) {
  112.     HM_f_AssignParameters(HM_a_Parameters[i][0],HM_a_Parameters[i][1]);
  113. }
  114.  
  115. HM_ChildPerCentOver = (isNaN(parseFloat(HM_ChildPerCentOver))) ? null : parseFloat(HM_ChildPerCentOver)/100;
  116.  
  117. function HM_f_ValidateArray(arrayname){
  118.     return ((typeof eval("window." + arrayname) == "object") && (eval(arrayname).length > 1))
  119. }
  120.  
  121. if(!window.HM_a_TreesToBuild) {
  122.     HM_a_TreesToBuild = [];
  123.     for(i=1; i<100; i++){
  124.         if(HM_f_ValidateArray(HM_ArrayIDPrefix + i)) HM_a_TreesToBuild[HM_a_TreesToBuild.length] = i;
  125.     }
  126. }
  127.  
  128. HM_CurrentArray = null;
  129. HM_CurrentTree  = null;
  130. HM_CurrentMenu  = null;
  131. HM_CurrentItem  = null;
  132. HM_a_TopMenus = [];
  133. HM_AreLoaded = false;
  134. HM_AreCreated = false;
  135. HM_BeingCreated = false;
  136. HM_UserOverMenu = false;
  137. HM_HideAllTimer = null;
  138. HM_TotalTrees = 0; 
  139. HM_ZIndex = 5000;
  140.  
  141.  
  142. function HM_f_StartIt() {
  143.     if((typeof(document.body) == "undefined") || (document.body == null)) return;
  144.     HM_AreLoaded = true;
  145.     if (HM_ClickKill) {
  146.         HM_f_OtherMouseDown = (document.onmousedown) ? document.onmousedown :  new Function;
  147.         document.onmousedown = function(){HM_f_PageClick();HM_f_OtherMouseDown()}
  148.     }
  149.     else {
  150.         HM_TopMilliSecondsVisible = HM_TopSecondsVisible * 1000;
  151.     }
  152.     HM_f_MakeTrees();
  153. }
  154.  
  155. function HM_f_AssignTreeParameters(arrayvalue,defaultvalue){
  156.     var ValueIsString = (typeof arrayvalue == "string");
  157.     if (ValueIsString) arrayvalue = arrayvalue.trim();
  158.     var ValueIsNull = ((arrayvalue == null) || (typeof arrayvalue == "undefined") || (ValueIsString && arrayvalue.length == 0));
  159.     if(ValueIsNull) return defaultvalue;
  160.     var TestString = arrayvalue;
  161.     if(eval("typeof(TestString)") == "string") {
  162.         if(TestString.charAt(0)=="#")return arrayvalue;
  163.         TestString = TestString.strip()
  164.     }
  165.     if (eval("typeof("+ TestString+" )") != 'undefined') {
  166.         eval("arrayvalue = eval(arrayvalue)");
  167.     }
  168.     return arrayvalue;
  169. }
  170.  
  171. function HM_f_MakeTrees(){
  172.     HM_BeingCreated = true;
  173.     var TreeParams = null;
  174.     var TreeHasChildren = false;
  175.     var ItemArray = null;
  176.  
  177.     for(var t=0; t<HM_a_TreesToBuild.length; t++) {
  178.         if(!HM_f_ValidateArray(HM_ArrayIDPrefix + HM_a_TreesToBuild[t])) continue;
  179.         HM_CurrentArray = eval(HM_ArrayIDPrefix + HM_a_TreesToBuild[t]);
  180.  
  181.         TreeParams = HM_CurrentArray[0];
  182.         TreeHasChildren = false;
  183.  
  184.         for(var i=1; i<HM_CurrentArray.length; i++) {
  185.             ItemArray = HM_CurrentArray[i];
  186.             if(ItemArray[ItemArray.length-1]) {TreeHasChildren = true; break}
  187.         }
  188.  
  189.         HM_CurrentTree = {
  190.             MenuWidth        : MenuWidth = HM_f_AssignTreeParameters(TreeParams[0],HM_MenuWidth),
  191.             MenuLeft         : MenuLeft = HM_f_AssignTreeParameters(TreeParams[1],null),
  192.             MenuTop          : MenuTop = HM_f_AssignTreeParameters(TreeParams[2],null),
  193.             ItemWidth        : ItemWidth = MenuWidth - (HM_BorderWidth*2),
  194.             ItemTextWidth    : TreeHasChildren ? (ItemWidth - (HM_ImageSize + HM_ImageHorizSpace + HM_ItemPadding)) : ItemWidth,
  195.             HorizOffsetRight : HorizOffsetRight = (parseInt((HM_ChildPerCentOver != null) ? (HM_ChildPerCentOver  * ItemWidth) : HM_ChildOverlap)),
  196.             HorizOffsetLeft  : (MenuWidth - HorizOffsetRight),
  197.             FontColor        : HM_f_AssignTreeParameters(TreeParams[3],HM_FontColor),
  198.             FontColorOver    : HM_f_AssignTreeParameters(TreeParams[4],HM_FontColorOver),
  199.             BGColor          : HM_f_AssignTreeParameters(TreeParams[5],HM_BGColor),
  200.             BGColorOver      : HM_f_AssignTreeParameters(TreeParams[6],HM_BGColorOver),
  201.             BorderColor      : HM_f_AssignTreeParameters(TreeParams[7],HM_BorderColor),
  202.             SeparatorColor   : HM_f_AssignTreeParameters(TreeParams[8],HM_SeparatorColor),
  203.             TopIsPermanent   : ((MenuLeft == null) || (MenuTop == null)) ? false : HM_f_AssignTreeParameters(TreeParams[9],false),
  204.             TopIsHorizontal  : TopIsHorizontal = HM_f_AssignTreeParameters(TreeParams[10],false),
  205.             TreeIsHorizontal : TreeHasChildren ? HM_f_AssignTreeParameters(TreeParams[11],false) : false,
  206.             PositionUnder    : (!TopIsHorizontal || !TreeHasChildren) ? false : HM_f_AssignTreeParameters(TreeParams[12],false),
  207.             TopImageShow     : TreeHasChildren ? HM_f_AssignTreeParameters(TreeParams[13],true)  : false,
  208.             TreeImageShow    : TreeHasChildren ? HM_f_AssignTreeParameters(TreeParams[14],true)  : false,
  209.             UponDisplay      : HM_f_AssignTreeParameters(TreeParams[15],HM_UponDisplay),
  210.             UponHide         : HM_f_AssignTreeParameters(TreeParams[16],HM_UponHide)
  211.         }
  212.  
  213.         HM_CurrentMenu = null;
  214.         HM_f_MakeMenu(HM_a_TreesToBuild[t]);
  215.         HM_a_TopMenus[HM_TotalTrees] = HM_CurrentTree.treeParent;
  216.         HM_TotalTrees++;
  217.         if(HM_CurrentTree.TopIsPermanent){
  218.             with(HM_CurrentTree.treeParent) {
  219.                 moveTo(HM_CurrentTree.MenuLeft,HM_CurrentTree.MenuTop);
  220.                 style.zIndex = 5000;
  221.                 style.visibility = "visible";
  222.             }
  223.         }
  224.     }
  225.  
  226.     if(HM_StatusDisplayBuild) status = HM_TotalTrees + " Hierarchical Menu Trees Created";
  227.     HM_AreCreated = true;
  228.     HM_BeingCreated = false;
  229. }
  230.  
  231. function HM_f_SetItemProperties(itemid,itemidsuffix) {
  232.     this.tree        = HM_CurrentTree;
  233.     this.index       = HM_CurrentMenu.itemCount - 1;
  234.     this.tree        = HM_CurrentTree;
  235.     this.isLastItem  = (HM_CurrentMenu.itemCount == HM_CurrentMenu.maxItems);
  236.     this.array         = HM_CurrentMenu.array[HM_CurrentMenu.itemCount];
  237.     this.dispText    = this.array[0];
  238.     this.linkText    = this.array[1];
  239.     this.hasRollover = this.array[2];
  240.     this.permHilite  = (!this.hasRollover && this.array[3]);
  241.     this.hasMore     = this.array[4];
  242.     this.childID     = this.hasMore ? (HM_MenuIDPrefix + itemidsuffix) : null;
  243.     this.child         = null;
  244.     this.onmouseover = HM_f_ItemOver;
  245.     this.onmouseout  = HM_f_ItemOut;
  246.     this.setItemStyle = HM_f_SetItemStyle;
  247. }
  248.  
  249. function HM_f_MakeElement(menuid) {
  250.     var MenuObject;
  251.     MenuObject = document.createElement("DIV");
  252.     with(MenuObject){
  253.         id = menuid;
  254.         with(style) {
  255.             position = "absolute";
  256.             visibility = "hidden";
  257.             left = "-500px";
  258.             top = "0px";
  259.             width = (HM_NS6 ? HM_CurrentTree.ItemWidth : HM_CurrentTree.MenuWidth) + "px";
  260.         }
  261.     }
  262.     document.body.appendChild(MenuObject);
  263.     return MenuObject;
  264. }
  265.  
  266. function HM_f_MakeMenu(menucount) {
  267.     if(!HM_f_ValidateArray(HM_ArrayIDPrefix + menucount)) return false;
  268.     HM_CurrentArray = eval(HM_ArrayIDPrefix + menucount);
  269.  
  270.     NewMenu = document.getElementById(HM_MenuIDPrefix + menucount);
  271.     if(!NewMenu){
  272.         NewMenu = HM_f_MakeElement(HM_MenuIDPrefix + menucount);
  273.  
  274.         if(HM_CurrentMenu) {
  275.             NewMenu.parentMenu = HM_CurrentMenu;
  276.             NewMenu.parentItem = HM_CurrentMenu.itemElement;
  277.             NewMenu.parentItem.child = NewMenu;
  278.             NewMenu.hasParent = true;
  279.             NewMenu.isHorizontal = HM_CurrentTree.TreeIsHorizontal;
  280.             NewMenu.showImage = HM_CurrentTree.TreeImageShow;
  281.         }
  282.         else {
  283.             NewMenu.isHorizontal = HM_CurrentTree.TopIsHorizontal;
  284.             NewMenu.showImage = HM_CurrentTree.TopImageShow;
  285.         }
  286.  
  287.         HM_CurrentMenu = NewMenu;
  288.         HM_CurrentMenu.array = HM_CurrentArray;
  289.         HM_CurrentMenu.tree  = HM_CurrentTree;
  290.         HM_CurrentMenu.itemCount = 0;
  291.         HM_CurrentMenu.maxItems = HM_CurrentMenu.array.length - 1;
  292.         HM_CurrentMenu.zIndex = ++HM_ZIndex;
  293.         HM_CurrentMenu.showIt = HM_f_ShowIt;
  294.         HM_CurrentMenu.count = menucount;
  295.         HM_CurrentMenu.keepInWindow = HM_f_KeepInWindow;
  296.         HM_CurrentMenu.onmouseover = HM_f_MenuOver;
  297.         HM_CurrentMenu.onmouseout = HM_f_MenuOut;
  298.         HM_CurrentMenu.hideTree = HM_f_HideTree
  299.         HM_CurrentMenu.hideParents = HM_f_HideParents;
  300.         HM_CurrentMenu.hideChildren = HM_f_HideChildren;
  301.         HM_CurrentMenu.hideTop = HM_f_HideTop;
  302.         HM_CurrentMenu.hideSelf = HM_f_HideSelf;
  303.         HM_CurrentMenu.hasChildVisible = false;
  304.         HM_CurrentMenu.isOn = false;
  305.         HM_CurrentMenu.hideTimer = null;
  306.         HM_CurrentMenu.currentItem = null;
  307.         HM_CurrentMenu.setMenuStyle = HM_f_SetMenuStyle;
  308.         if(HM_IE) HM_CurrentMenu.onselectstart = HM_f_CancelSelect;
  309.         HM_CurrentMenu.moveTo = HM_f_MoveTo;
  310.         HM_CurrentMenu.setMenuStyle();
  311.     }
  312.  
  313.     while (HM_CurrentMenu.itemCount < HM_CurrentMenu.maxItems) {
  314.         HM_CurrentMenu.itemCount++;
  315.         HM_CurrentMenu.itemElement = document.getElementById(HM_ItemIDPrefix + menucount + "_" + HM_CurrentMenu.itemCount);
  316.         if(!HM_CurrentMenu.itemElement){
  317.             if(HM_StatusDisplayBuild) status = "Creating Hierarchical Menus: " + menucount + " / " + HM_CurrentMenu.itemCount;
  318.             HM_CurrentMenu.itemElement = HM_f_MakeItemElement(menucount);
  319.         }
  320.         if(HM_CurrentMenu.itemElement.hasMore && (!HM_CreateTopOnly || HM_AreCreated && HM_CreateTopOnly)) {
  321.             MenuCreated = HM_f_MakeMenu(menucount + "_" + HM_CurrentMenu.itemCount);
  322.             if(MenuCreated) {
  323.                 HM_CurrentMenu = HM_CurrentMenu.parentMenu;
  324.             }
  325.             else {
  326.                 HM_CurrentMenu.itemElement.hasMore = false;
  327.             }
  328.         }
  329.     }
  330.  
  331.     if(HM_CurrentMenu.isHorizontal){
  332.         var ChildHeight = parseInt(HM_CurrentMenu.style.height);
  333.         ChildHeight -= (HM_NS6) ? (HM_ItemPadding * 2) : (HM_BorderWidth * 2);
  334.         for(i=0; i<HM_CurrentMenu.childNodes.length; i++){
  335.             HM_CurrentMenu.childNodes[i].style.height = ChildHeight + "px";
  336.         }
  337.     }
  338.     HM_CurrentTree.treeParent = HM_CurrentTree.startChild = HM_CurrentMenu;
  339.     return HM_CurrentMenu;
  340. }
  341.  
  342. function HM_f_SetMenuStyle(){
  343.     with(this.style) {
  344.         borderWidth = HM_BorderWidth + "px";
  345.         borderColor = HM_CurrentTree.BorderColor;
  346.         borderStyle = HM_BorderStyle;
  347.         zIndex      = --HM_ZIndex;
  348.         overflow    = "hidden";
  349.         cursor      = "default";
  350.     }
  351. }
  352.  
  353. function HM_f_MakeItemElement(menucount) {
  354.     var ItemElement = document.createElement("DIV");
  355.     ItemElement.id = HM_ItemIDPrefix + menucount + "_" + HM_CurrentMenu.itemCount;
  356.     ItemElement.style.position = "absolute";
  357.     ItemElement.style.visibility = "inherit";
  358.     HM_CurrentMenu.appendChild(ItemElement);
  359.     ItemElement.setItemProperties = HM_f_SetItemProperties;
  360.     ItemElement.setItemProperties();
  361.     ItemElement.siblingBelow = ItemElement.previousSibling;
  362.     if(ItemElement.linkText) {
  363.         ItemElement.onclick = HM_f_LinkIt;
  364.         if(HM_ShowLinkCursor)ItemElement.style.cursor = HM_NS6 ? "pointer" : "hand";
  365.     }
  366.     ItemElement.menu = HM_CurrentMenu;
  367.     var FullPadding  = (HM_ItemPadding*2) + HM_ImageSize + HM_ImageHorizSpace;
  368.  
  369.     if(ItemElement.hasMore && HM_CurrentMenu.showImage) {
  370.         var ImageElement = document.createElement("IMG");
  371.         with(ImageElement){
  372.             src = HM_RightToLeft ? HM_ImageSrcLeft : HM_ImageSrc;
  373.             removeAttribute("height");
  374.             hspace = (!HM_RightToLeft && HM_IE5W) ? HM_ItemPadding : 0;
  375.             vspace = 0;
  376.             width = HM_ImageSize;
  377.             with(style) {
  378.                 if(HM_RightToLeft) {
  379.                     position = "absolute";
  380.                     top = (HM_ItemPadding + HM_ImageVertSpace) + "px";
  381.                     left = (HM_ItemPadding + HM_ImageHorizSpace) + "px";
  382.                 }
  383.                 else {
  384.                     position = "relative";
  385.                     marginTop = HM_ImageVertSpace + "px";
  386.                     if(HM_IE5W) {
  387.                         marginRight = -FullPadding + "px";
  388.                     }
  389.                     else marginRight = -(HM_ImageSize + HM_ItemPadding) +"px";
  390.                     if(HM_NS6) cssFloat = "right";
  391.                     else styleFloat = "right";
  392.                 }    
  393.             }
  394.         }
  395.     }
  396.  
  397.  
  398.  
  399.  
  400.  
  401.  
  402.  
  403.  
  404.  
  405.  
  406.     ItemElement.innerHTML = ItemElement.dispText;
  407.     if(ImageElement) ItemElement.insertBefore(ImageElement,ItemElement.firstChild);
  408.     ItemElement.setItemStyle();
  409.     return ItemElement;
  410. }
  411.  
  412. function HM_f_SetItemStyle() {
  413.     with(this.style){
  414.         backgroundColor = (this.permHilite) ? HM_CurrentTree.BGColorOver : HM_CurrentTree.BGColor;
  415.         color = (this.permHilite) ? HM_CurrentTree.FontColorOver : HM_CurrentTree.FontColor;
  416.         padding = HM_ItemPadding +"px";
  417.         font = ((HM_FontBold) ? "bold " : "normal ") + HM_FontSize + "pt " + HM_FontFamily;
  418.         fontStyle = (HM_FontItalic) ? "italic" : "normal";
  419.         if(HM_IE) overflow = "hidden";
  420.  
  421.         if(HM_CurrentMenu.showImage)    {
  422.             var FullPadding  = (HM_ItemPadding*2) + HM_ImageSize + HM_ImageHorizSpace;
  423.             if (HM_RightToLeft) paddingLeft = FullPadding + "px";
  424.             else paddingRight = FullPadding + "px";
  425.         }
  426.         if(!this.isLastItem) {
  427.             var SeparatorString = HM_SeparatorSize + "px solid " + this.tree.SeparatorColor;
  428.             if (this.menu.isHorizontal) borderRight = SeparatorString;
  429.             else borderBottom = SeparatorString;
  430.         }
  431.  
  432.         if(HM_IE) width = HM_CurrentTree.ItemWidth + "px";
  433.         else width = (HM_CurrentTree.ItemWidth - (parseInt(paddingLeft) + parseInt(paddingRight))) + "px";
  434.  
  435.         if(this.menu.isHorizontal){
  436.             if(HM_IE){
  437.                 if(this.isLastItem) width = (HM_CurrentTree.MenuWidth - HM_BorderWidth - HM_SeparatorSize) + "px"
  438.                 else width = (HM_CurrentTree.MenuWidth - HM_BorderWidth) + "px"
  439.             }
  440.             if(HM_NS6) width = (HM_CurrentTree.MenuWidth - HM_BorderWidth - parseInt(paddingLeft) - parseInt(paddingRight) - HM_SeparatorSize) + "px";
  441.             top = "0px";
  442.             if(HM_IE) left = (this.index * (HM_CurrentTree.MenuWidth - HM_BorderWidth)) + "px";
  443.             if(HM_NS6) left = ((this.index * parseInt(width)) + ((HM_SeparatorSize * this.index)))  + ((parseInt(paddingLeft) + parseInt(paddingRight)) * this.index) + "px";
  444.             var LeftAndWidth = parseInt(left) + parseInt(width);
  445.             this.menu.style.width = LeftAndWidth + (HM_IE ? (HM_BorderWidth * 2) : (parseInt(paddingLeft) + parseInt(paddingRight))) + "px"
  446.             if(this.index) {
  447.                 var SiblingHeight = this.siblingBelow.offsetHeight;
  448.                 this.menu.style.height = Math.max(parseInt(this.menu.style.height),SiblingHeight+(HM_NS6 ? 0 : HM_BorderWidth * 2)) + "px";
  449.             }
  450.                else{
  451.                 var SiblingHeight = this.offsetHeight;
  452.                 this.menu.style.height = SiblingHeight + (HM_NS6 ? 0 : HM_BorderWidth * 2) + "px";
  453.             }
  454.         }
  455.         else {
  456.             left = "0px";
  457.             if (this.index) {
  458.                 var SiblingHeight = this.siblingBelow.offsetHeight;
  459.                 top = parseInt(this.siblingBelow.style.top) + SiblingHeight + "px";
  460.             }
  461.             else top = "0px";
  462.             this.menu.style.height = parseInt(top) + (HM_IE5W ? this.scrollHeight : this.offsetHeight) + (HM_NS6 ? 0 : (HM_BorderWidth * 2)) + "px";
  463.         }
  464.     }
  465. }
  466.  
  467. function HM_f_PopUp(menuname,e){
  468.     if(HM_IE) e = event;
  469.     if (!HM_AreLoaded) return;
  470.     menuname = menuname.replace("elMenu",HM_MenuIDPrefix);
  471.     var TempMenu = document.getElementById(menuname);
  472.     if(!TempMenu)return;
  473.     HM_CurrentMenu = TempMenu;
  474.     if (HM_ClickStart) {
  475.         var ClickElement = (HM_IE) ? e.srcElement : e.target;
  476.         if(HM_NS6) {
  477.             while(ClickElement.tagName==null){
  478.                 ClickElement = ClickElement.parentNode;
  479.             }
  480.         }
  481.         ClickElement.onclick = HM_f_PopMenu;
  482.     }
  483.     else HM_f_PopMenu(e);
  484. }
  485.  
  486. function HM_f_PopMenu(e){
  487.     if(HM_IE) e = event;
  488.     if (!HM_AreLoaded || !HM_AreCreated) return true;
  489.     if (HM_ClickStart && e.type != "click") return true;
  490.     HM_f_HideAll();
  491.     HM_CurrentMenu.hasParent = false;
  492.     HM_CurrentMenu.tree.startChild = HM_CurrentMenu;
  493.     var EventX = (HM_IE) ? (e.clientX + document.body.scrollLeft) : e.pageX;
  494.     var EventY = (HM_IE) ? (e.clientY + document.body.scrollTop)  : e.pageY;
  495.     HM_CurrentMenu.xPos = (HM_CurrentMenu.tree.MenuLeft!=null) ? HM_CurrentMenu.tree.MenuLeft : EventX;
  496.        HM_CurrentMenu.yPos = (HM_CurrentMenu.tree.MenuTop!=null)  ? HM_CurrentMenu.tree.MenuTop  : EventY;
  497.     HM_CurrentMenu.keepInWindow();
  498.     HM_CurrentMenu.moveTo(HM_CurrentMenu.xPos,HM_CurrentMenu.yPos);
  499.     HM_CurrentMenu.isOn = true;
  500.     HM_CurrentMenu.showIt(true);
  501.     return false;
  502. }
  503.  
  504. function HM_f_MenuOver() {
  505.     if(!this.tree.startChild){this.tree.startChild = this}
  506.     if(this.tree.startChild == this) HM_f_HideAll(this)
  507.     this.isOn = true;
  508.     HM_UserOverMenu = true;
  509.     HM_CurrentMenu = this;
  510.     if (this.hideTimer) clearTimeout(this.hideTimer);
  511. }
  512.  
  513. function HM_f_MenuOut() {
  514.     if(HM_IE && event.srcElement.contains(event.toElement)) return;
  515.     this.isOn = false;
  516.     HM_UserOverMenu = false;
  517.     if(HM_StatusDisplayLink) status = "";
  518.     if(!HM_ClickKill) HM_HideAllTimer = setTimeout("HM_CurrentMenu.hideTree()",10);  
  519. }
  520.  
  521. function HM_f_ItemOver(){
  522.     if (HM_KeepHilite) {
  523.         if (this.menu.currentItem && this.menu.currentItem != this && this.menu.currentItem.hasRollover) {
  524.             with(this.menu.currentItem.style){
  525.                 backgroundColor = this.tree.BGColor;
  526.                 color = this.tree.FontColor
  527.             }
  528.         }
  529.     }
  530.     if(HM_IE && event.srcElement.tagName == "IMG") return;
  531.     if(this.hasRollover) {
  532.         this.style.backgroundColor = this.tree.BGColorOver;
  533.         this.style.color = this.tree.FontColorOver;
  534.     }
  535.  
  536.     if(HM_StatusDisplayLink) status = this.linkText;
  537.     this.menu.currentItem = this;
  538.     if (this.menu.hasChildVisible && (this.menu.visibleChild != this.child)) {
  539.         this.menu.hideChildren(this);
  540.     }
  541.  
  542.     if (this.hasMore) {
  543.         if(!this.child) {
  544.             HM_CurrentTree = this.tree;
  545.             HM_CurrentMenu = this.menu;
  546.             HM_CurrentItem = this;
  547.             this.child = HM_f_MakeMenu(this.menu.count + "_"+(this.index+1));
  548.             this.tree.treeParent = this.menu;
  549.             this.tree.startChild = this.menu;
  550.         }
  551.         if (this.tree.PositionUnder && (this.menu == this.tree.treeParent)) {
  552.             this.child.xPos = parseInt(this.menu.style.left) + parseInt(this.style.left);
  553.             this.child.yPos = parseInt(this.menu.style.top)  + this.menu.offsetHeight - (HM_BorderWidth);
  554.         }
  555.         else {
  556.             if(HM_IE5M) {
  557.                 this.oL = parseInt(this.menu.style.left) - HM_BorderWidth;
  558.                 this.oL += this.offsetLeft;
  559.                 this.oT =  parseInt(this.menu.style.top)  -HM_BorderWidth;
  560.                 this.oT += this.offsetTop;
  561.             }
  562.             else {
  563.                 this.oL = (HM_IE) ? parseInt(this.menu.style.left) : -HM_BorderWidth;
  564.                 this.oL += this.offsetLeft;
  565.                 this.oT = (HM_IE) ? parseInt(this.menu.style.top) : -HM_BorderWidth;
  566.                 this.oT += this.offsetTop;
  567.             }
  568.             if(HM_RightToLeft) {
  569.                 this.child.xPos = this.oL + (this.tree.HorizOffsetRight - this.child.offsetWidth);
  570.             }
  571.             else {        
  572.                 this.child.xPos = this.oL + this.tree.HorizOffsetLeft;
  573.             }
  574.             this.child.yPos = this.oT + HM_ChildOffset + HM_BorderWidth;
  575.         }
  576.         if(!this.tree.PositionUnder) this.child.keepInWindow();
  577.         this.child.moveTo(this.child.xPos,this.child.yPos);
  578.         this.menu.hasChildVisible = true;
  579.         this.menu.visibleChild = this.child;
  580.         this.child.showIt(true);
  581.     }
  582. }
  583.  
  584. function HM_f_ItemOut() {
  585.     if (HM_IE && (event.srcElement.contains(event.toElement)
  586.       || (event.fromElement.tagName=="IMG" && event.toElement.contains(event.fromElement))))
  587.           return;
  588.     if ( (!HM_KeepHilite || ((this.tree.TopIsPermanent && (this.tree.treeParent==this)) && !this.menu.hasChildVisible)) && this.hasRollover) {
  589.         with(this.style) {
  590.             backgroundColor = this.tree.BGColor;
  591.             color = this.tree.FontColor
  592.         }
  593.     }
  594. }
  595.  
  596. function HM_f_MoveTo(xPos,yPos) {
  597.     this.style.left = xPos + "px";
  598.     this.style.top = yPos + "px";
  599. }
  600.  
  601. function HM_f_ShowIt(on) {
  602.     if (!(this.tree.TopIsPermanent && (this.tree.treeParent==this))) {
  603.         if(!this.hasParent || (this.hasParent && this.tree.TopIsPermanent)) {
  604.             var IsVisible = (this.style.visibility == "visible");
  605.             if ((on && !IsVisible) || (!on && IsVisible))
  606.                 eval(on ? this.tree.UponDisplay : this.tree.UponHide)
  607.         }
  608.         this.style.visibility = (on) ? "visible" : "hidden";
  609.     }
  610.     if (HM_KeepHilite && this.currentItem && this.currentItem.hasRollover) {
  611.         with(this.currentItem.style){
  612.             backgroundColor = this.tree.BGColor;
  613.             color = this.tree.FontColor;
  614.         }
  615.     }
  616.     this.currentItem = null;
  617. }
  618.  
  619. function HM_f_KeepInWindow() {
  620.     var ExtraSpace     = 10;
  621.     var WindowLeftEdge = (HM_IE) ? document.body.scrollLeft   : window.pageXOffset;
  622.     var WindowTopEdge  = (HM_IE) ? document.body.scrollTop    : window.pageYOffset;
  623.     var WindowWidth    = (HM_IE) ? document.body.clientWidth  : window.innerWidth;
  624.     var WindowHeight   = (HM_IE) ? document.body.clientHeight : window.innerHeight;
  625.     var WindowRightEdge  = (WindowLeftEdge + WindowWidth) - ExtraSpace;
  626.     var WindowBottomEdge = (WindowTopEdge + WindowHeight) - ExtraSpace;
  627.  
  628.     var MenuLeftEdge = this.xPos;
  629.     var MenuRightEdge = MenuLeftEdge + this.offsetWidth;
  630.     var MenuBottomEdge = this.yPos + this.offsetHeight;
  631.  
  632.     if (this.hasParent) {
  633.         var ParentLeftEdge = parseInt(this.parentMenu.style.left);
  634.     }
  635.     if (MenuRightEdge > WindowRightEdge) {
  636.         if (this.hasParent) {
  637.             this.xPos = ParentLeftEdge + this.tree.HorizOffsetRight - this.offsetWidth;    
  638.         }
  639.         else {
  640.             dif = MenuRightEdge - WindowRightEdge;
  641.             this.xPos -= dif;
  642.         }
  643.     }
  644.  
  645.     if (MenuBottomEdge > WindowBottomEdge) {
  646.         dif = MenuBottomEdge - WindowBottomEdge;
  647.         this.yPos -= dif;
  648.     }
  649.  
  650.     if (MenuLeftEdge < WindowLeftEdge) {
  651.         if (this.hasParent) {
  652.             this.xPos = ParentLeftEdge + this.tree.HorizOffsetLeft;
  653.         }
  654.         else {this.xPos = 5}
  655.     }       
  656. }
  657.  
  658. function HM_f_LinkIt() {
  659.     HM_f_HideAll();
  660.     if (this.linkText.indexOf("javascript")!=-1) eval(this.linkText)
  661.     else location.href = this.linkText;
  662. }
  663.  
  664. function HM_f_PopDown(menuname){
  665.     if (!HM_AreLoaded || !HM_AreCreated) return;
  666.     menuname = menuname.replace("elMenu",HM_MenuIDPrefix);
  667.     var MenuToHide = document.getElementById(menuname);
  668.     if(!MenuToHide)return;
  669.     MenuToHide.isOn = false;
  670.     if (!HM_ClickKill) MenuToHide.hideTop();
  671. }
  672.  
  673. function HM_f_HideAll(callingmenu) {
  674.     for(var i=0; i<HM_TotalTrees; i++) {
  675.         var TopMenu = HM_a_TopMenus[i].tree.startChild;
  676.         if(TopMenu == callingmenu)continue
  677.         TopMenu.isOn = false;
  678.         if (TopMenu.hasChildVisible) TopMenu.hideChildren();
  679.         TopMenu.showIt(false);
  680.     }    
  681. }
  682.  
  683. function HM_f_HideTree() { 
  684.     HM_HideAllTimer = null;
  685.     if (HM_UserOverMenu) return;
  686.     if (this.hasChildVisible) this.hideChildren();
  687.     this.hideParents();
  688. }
  689.  
  690. function HM_f_HideTop() {
  691.     TopMenuToHide = this;
  692.     (HM_ClickKill) ? TopMenuToHide.hideSelf() : (this.hideTimer = setTimeout("TopMenuToHide.hideSelf()",HM_TopMilliSecondsVisible));
  693. }
  694.  
  695. function HM_f_HideSelf() {
  696.     this.hideTimer = null;
  697.     if (!this.isOn && !HM_UserOverMenu) this.showIt(false);
  698. }
  699.  
  700. function HM_f_HideParents() {
  701.     var TempMenu = this;
  702.     while(TempMenu.hasParent) {
  703.         TempMenu.showIt(false);
  704.         TempMenu.parentMenu.isOn = false;        
  705.         TempMenu = TempMenu.parentMenu;
  706.     }
  707.     TempMenu.hideTop();
  708. }
  709.  
  710. function HM_f_HideChildren(callingitem) {
  711.     var TempMenu = this.visibleChild;
  712.     while(TempMenu.hasChildVisible) {
  713.         TempMenu.visibleChild.showIt(false);
  714.         TempMenu.hasChildVisible = false;
  715.         TempMenu = TempMenu.visibleChild;
  716.     }
  717.  
  718.     if (!this.isOn || !callingitem.hasMore || this.visibleChild != this.child) {
  719.         this.visibleChild.showIt(false);
  720.         this.hasChildVisible = false;
  721.     }
  722. }
  723.  
  724. function HM_f_CancelSelect(){return false}
  725.  
  726. function HM_f_PageClick() {
  727.     if (!HM_UserOverMenu && HM_CurrentMenu!=null && !HM_CurrentMenu.isOn) HM_f_HideAll();
  728. }
  729.  
  730. popUp = HM_f_PopUp;
  731. popDown = HM_f_PopDown;
  732.  
  733. window.onload = function(){setTimeout("HM_f_StartIt()",10)};
  734.  
  735. //end