// UTF-8
/**
 * scrollsmoothly.js
 * Copyright (c) 2008 KAZUMiX
 * http://d.hatena.ne.jp/KAZUMiX/20080418/scrollsmoothly
 * Licensed under the MIT License:
 * http://www.opensource.org/licenses/mit-license.php
 * 
 * 更新履歴
 * 2009/02/12
 * スクロール先が画面左上にならない場合の挙動を修正
 * 2008/04/18
 * 公開
 *
*/

   var ss_easing = 0.25;
   var ss_interval = 20;
   var ss_d = document;
   var ss_targetX = 0;
   var ss_targetY = 0;
   var ss_targetHash = '';
   var ss_scrolling = false;
   var ss_splitHref = location.href.split('#');
   var ss_currentHref_WOHash = ss_splitHref[0];
   var ss_incomingHash = ss_splitHref[1];
   var ss_prevX = null;
   var ss_prevY = null;

   // ドキュメント読み込み完了時にss_init()を実行する
   ss_addEvent(window, 'load', ss_init);

   // ドキュメント読み込み完了時の処理
   function ss_init(){
     // ページ内リンクにイベントを設定する
     ss_setOnClickHandler();
     // 外部からページ内リンク付きで呼び出された場合
     if(ss_incomingHash){
       if(window.attachEvent && !window.opera){
         // IEの場合はちょっと待ってからスクロール
         setTimeout(function(){scrollTo(0,0);ss_setScroll('#'+ss_incomingHash);},50);
       }else{
         // IE以外はそのままGO
         scrollTo(0, 0);
         ss_setScroll('#'+ss_incomingHash);
       }
     }
   }

   // イベントを追加する関数
   function ss_addEvent(eventTarget, eventName, func){
     if(eventTarget.addEventListener){
       // モダンブラウザ
       eventTarget.addEventListener(eventName, func, false);
     }else if(window.attachEvent){
       // IE
       eventTarget.attachEvent('on'+eventName, function(){func.apply(eventTarget);});
     }
   }
   
   function ss_setOnClickHandler(){
     var links = ss_d.links;
     for(var i=0; i<links.length; i++){
       // ページ内リンクならスクロールさせる
       var link = links[i];
       var splitLinkHref = link.href.split('#');
       if(ss_currentHref_WOHash == splitLinkHref[0] && ss_d.getElementById(splitLinkHref[1])){
         ss_addEvent(link, 'click', ss_startScroll);
       }
     }
   }

   function ss_startScroll(event){
     // リンクのデフォルト動作を殺す
     if(event){ // モダンブラウザ
       event.preventDefault();
       //alert('modern');
     }else if(window.event){ // IE
       window.event.returnValue = false;
       //alert('ie');
     }
     // thisは呼び出し元になってる
     ss_setScroll(this.hash);
   }

   function ss_setScroll(hash){
     // ハッシュからターゲット要素の座標をゲットする
     var targetEle = ss_d.getElementById(hash.substr(1));
     if(!targetEle)return;
     //alert(scrollSize.height);
     // スクロール先座標をセットする
     var ele = targetEle;
     var x = 0;
     var y = 0;
     while(ele){
       x += ele.offsetLeft;
       y += ele.offsetTop;
       ele = ele.offsetParent;
     }
     var maxScroll = ss_getScrollMaxXY();
     ss_targetX = Math.min(x, maxScroll.x);
     ss_targetY = Math.min(y, maxScroll.y);
     ss_targetHash = hash;
     // スクロール停止中ならスクロール開始
     if(!ss_scrolling){
       ss_scrolling = true;
       ss_scroll();
     }
   }

   function ss_scroll(){
     var currentX = ss_d.documentElement.scrollLeft||ss_d.body.scrollLeft;
     var currentY = ss_d.documentElement.scrollTop||ss_d.body.scrollTop;
     var vx = (ss_targetX - currentX) * ss_easing;
     var vy = (ss_targetY - currentY) * ss_easing;
     var nextX = currentX + vx;
     var nextY = currentY + vy;
     if((Math.abs(vx) < 1 && Math.abs(vy) < 1)
       || (ss_prevX === currentX && ss_prevY === currentY)){
       // 目標座標付近に到達していたら終了
       scrollTo(ss_targetX, ss_targetY);
       ss_scrolling = false;
//       location.hash = ss_targetHash;	//mcstudio on comment
       ss_prevX = ss_prevY = null;
       return;
     }else{
       // 繰り返し
       scrollTo(parseInt(nextX), parseInt(nextY));
       ss_prevX = currentX;
       ss_prevY = currentY;
       setTimeout(function(){ss_scroll()},ss_interval);
     }
   }
   
   function ss_getDocumentSize(){
     return {width:Math.max(document.body.scrollWidth, document.documentElement.scrollWidth), height:Math.max(document.body.scrollHeight, document.documentElement.scrollHeight)};
   }

   function ss_getWindowSize(){
     var result = {};
     if(window.innerWidth){
       var box = ss_d.createElement('div');
       with(box.style){
         position = 'absolute';
         top = '0px';
         left = '0px';
         width = '100%';
         height = '100%';
         margin = '0px';
         padding = '0px';
         border = 'none';
         visibility = 'hidden';
       }
       ss_d.body.appendChild(box);
       var width = box.offsetWidth;
       var height = box.offsetHeight;
       ss_d.body.removeChild(box);
       result = {width:width, height:height};
     }else{
       result = {width:ss_d.documentElement.clientWidth || ss_d.body.clientWidth, height:ss_d.documentElement.clientHeight || ss_d.body.clientHeight};
     }
     return result;
   }
   
   function ss_getScrollMaxXY() {
     if(window.scrollMaxX && window.scrollMaxY){
       return {x:window.scrollMaxX, y:window.scrollMaxY};
     }
     var documentSize = ss_getDocumentSize();
     var windowSize = ss_getWindowSize();
     return {x:documentSize.width - windowSize.width, y:documentSize.height - windowSize.height};
   }
   

