var expand_speed = 50;  // メニュー項目を開閉する速さ (ミリ秒)
var updown_speed =  0;  // メニューが移動する速さ (ミリ秒)
var steps        =  0;  // メニューが updown_speed ミリ秒ごとに移動するピクセル幅
var jump         =   0;  // メニューが離れすぎたら高速移動する (1: yes 0: no)
var sticky       =   1;  // メニューを固定する (1: yes 0: no)
var steps2       =  0;  // メニューが updown_speed ミリ秒ごとに移動するピクセル幅

// メニュー HTML (下記の説明参照)
var menu_html =
"<div id='tfm-head'>クリニック選択</div>" +
"<div id='tfm-body'>" +
"<div id='item1'     class='tf1'>▼美容外科・美容皮膚科" +
"   <div id='item11' class='tf2'><a href='83.html'>●新宿</a></div>" +
"   <div id='item12' class='tf2'><a href='79.html'>●札幌</a></div>" +
"   <div id='item13' class='tf2'><a href='84.html'>●大宮（さいたま）</a></div>" +
"   <div id='item14' class='tf2'><a href='85.html'>●所沢</a></div>" +
"   <div id='item15' class='tf2'><a href='87.html'>●浜松</a></div>" +
"   <div id='item16' class='tf2'><a href='88.html'>●仙台</a></div>" +
"   <div id='item17' class='tf2'><a href='89.html'>●宇都宮</a></div>" +
"   <div id='item18' class='tf2'><a href='90.html'>●高崎</a></div>" +
"   <div id='item19' class='tf2'><a href='91.html'>●大阪</a></div>" +
"   <div id='item20' class='tf2'><a href='92.html'>●岡山</a></div>" +
"   <div id='item21' class='tf2'><a href='93.html'>●高松</a></div>" +
"   <div id='item22' class='tf2'><a href='94.html'>●福岡</a></div>" +
"   <div id='item23' class='tf2'><a href='95.html'>●大分</a></div>" +
"   <div id='item24' class='tf2'><a href='96.html'>●熊本</a></div>" +
"</div>" +
"<div id='item2'     class='tf1'>▼美容歯科・審美歯科" +
"   <div id='item25' class='tf2'><a href='83.html'>●新宿</a></div>" +
"   <div id='item26' class='tf2'><a href='91.html'>●大阪</a></div>" +
"   <div id='item26' class='tf2'><a href='86.html'>●福岡</a></div>" +
"</div>" +
"</div>" +  // end of #tfm-body
"<div id='item10'     class='tf4'>&nbsp;</div>" +
" <div id='item100' class='tf3'>初診の方はこちら<br />"+
"   <a href='http://www.kyoritsu-biyo.com/mypage/pc/mm10RegistQuestion.php'><img src='../image/soudan.gif' alt='新規相談' /></a>" +
"   <a href='http://www.kyoritsu-biyo.com/mypage/pc/mm11RegistReserve.php'><img src='../image/yoyaku.gif' alt='新規予約' /></a></div>" +
"   <div id='item101' class='tf3'><a href='http://www.kyoritsu-biyo.com/mypage/pc/mm01Login.php'><img src='../image/login.gif' alt='患者様専用ページ' height='25' class='image-left' />MyPage登録済みの方はこちら</a></div>"+
"<div id='tfm-foot'></div>";

var curr_y;
var istimerc_on = 0;
var istimere_on = 0;
var limit_y;
var menu_pos = new Object();
var status_p;
var tfm_body;
var tfmenu;
var isInternetExplorer;

if (navigator.appName.indexOf("Microsoft") < 0) {
   // it's not IE.
   steps = steps2;
}

function expandMenu(e) {
   var close_only = 0;
   var col_elem;
   var exp_elem;
   var ic;
   var ie;
   var isopen = 0;
   var target_elem;
   var target_node;
   var timerc;
   var timere;

   var collapseItem = function() {
      if(col_elem[ic]) {
         setVisibility(col_elem[ic], "hidden");
         ic++;
      } else {
         clearInterval(timerc);
         istimerc_on = 0;
      }
   }
   var expandItem = function() {
      if(!istimerc_on) {
         if(exp_elem[ie]) {
            setVisibility(exp_elem[ie], "visible");
            ie++;
         } else {
            clearInterval(timere);
            istimere_on = 0;
         }
      }
   }

   if(e.target) {
      target_node = e.target;
   } else if (e.srcElement) {
      target_node = e.srcElement;
   }
   // for Safari.
   if (target_node.nodeType == 3) {
      target_node = target_node.parentNode;
   }
   target_elem = target_node.getElementsByTagName("div");
   // if a gap between items (background tfm_body) was clicked, ignore.
   if(target_node.id == "tfm-body") {
      return;
   }
   // if the top item was clicked and it was already open, just close it.
   if(target_elem[0]) {
      if(target_elem[0].style.visibility == "visible") {
         close_only = 1;
      }
   }
   // collapse menu.
   if(!istimerc_on && !istimere_on) {
      for(var i = 0; i < tfm_body.length && !isopen; ++i) { // search the first visible chiled item.
         col_elem = tfm_body[i].getElementsByTagName("div");
         for(var ii = 0; ii < col_elem.length; ++ii) {
            if(col_elem[ii].style.visibility == "visible") {
               isopen = 1;
               break;
            }
         }
      }
      if(isopen) {
         ic          = 0;
         istimerc_on = 1;
         timerc      = setInterval(collapseItem, expand_speed);
      }
   }
   // expand active menu items.
   if(!istimere_on && !close_only) {
      exp_elem    = target_elem;
      ie          = 0;
      istimere_on = 1;
      timere      = setInterval(expandItem, expand_speed);
   }
}

function setVisibility(e, value) {
   e.style.visibility = value;
   if(value == "hidden") {
      e.style.lineHeight     = "0px";
      e.parentNode.className = "tf1";
   } else {
      e.style.lineHeight     = "100%";
      e.parentNode.className = "tf1active";
   }
}

function setTopPos() {}

function setListeners(e) {
   var i;
   var ii;
   tfmenu           = document.getElementById("tfmenu");
   tfmenu.innerHTML = menu_html;
   tfm_body         = document.getElementById("tfm-body")
   tfmenu.className = "tfm-stop";
   addListener(tfm_body, 'mouseup', expandMenu, false);
   tfm_body         = tfm_body.childNodes;

   for(i = 0; i < tfm_body.length; ++i) {
      // if name property was set, make that node (id) to visible.
      var items = tfm_body[i].getElementsByTagName("div");
      var visib = "hidden";
      if(tfmenu.getAttribute('name') == tfm_body[i].id) {
         visib = "visible";
      }
      for(ii = 0; ii < items.length; ++ii) {
         setVisibility(items[ii], visib);
      }
   }

   tfmenu.style.position = "absolute";
   tfmenu.style.left     = "0px";
   if(sticky) {
      tfmenu.style.top = "0px";
   } else {
      curr_y           = document.body.scrollTop;
      tfmenu.style.top = curr_y + "px";
      setInterval("setTopPos()", updown_speed);
   }
   // bug: if there is no parent element, limit_y will be screen height which is too short.
   limit_y = tfmenu.parentNode.offsetHeight - tfmenu.offsetHeight;
}

function addListener(elem, eventType, func, cap) {
   if(elem.addEventListener) {
      elem.addEventListener(eventType, func, cap);
   } else if(elem.attachEvent) {
      elem.attachEvent('on' + eventType, func);
   } else {
      window.alert("Sorry... Please use Internet Explorer or Firefox.");
      return false;
   }
}

addListener(window, 'load', setListeners, false);

// eof