﻿/**
* common.js
*
* @version		1.0.2.1
* @update		21:54 2008/11/25
* @extends		----
*
*/

/* ============================================================================== scroll
*/
var eventTimer;    // タイマー変数
var restScroll=0;    // スクロール残量

function Scroll(base,move){
    // 移動元(base)要素＆オブジェクトを取得
    var obj_base = getElemPosition(base);
    // 移動先(move)要素＆オブジェクトを取得
    var elem_move = document.getElementById(move);
    var obj_move = getElemPosition(elem_move);
    restScroll = obj_move.y-obj_base.y;
    eventTimer = setInterval(setScrollPosition,10);
}

// スクロール処理をする
function setScrollPosition() {
    var moveValue=0;
    // スクロール残量が80以上の場合、スクロール量を変える
    // Math.abs()では値の絶対値を取得
    if(Math.abs(restScroll)>80){
        moveValue = (restScroll>0)?20:-20;
    }else{
        moveValue = Math.round(restScroll/4);
    }
    // スクロールを処理
    parent.scrollBy(0,moveValue);
    // スクロール残量を計算して、残りが無ければタイマー解除
    restScroll = (restScroll>0)?restScroll-moveValue:restScroll-moveValue;
    if(moveValue==0){
        clearInterval(eventTimer);
        restScroll=0;
    }
}

// 要素の位置を取得し、オブジェクトとして返す
function getElemPosition(elem) {
    var obj = new Object();
    obj.x = elem.offsetLeft;
    obj.y = elem.offsetTop;
    // 親要素を取得して位置情報を修正する
    while(elem.offsetParent) {
        elem = elem.offsetParent;
        obj.x += elem.offsetLeft;
        obj.y += elem.offsetTop;
    }
    return obj;
}

/* ============================================================================== gotop
*/

var scrj = 1;
function softScrollBack() {
   if(navigator.appName == "Microsoft Internet Explorer" && document.compatMode == "CSS1Compat") {
      var scdist = document.body.parentNode.scrollTop;
   } else {
      var scdist = document.body.scrollTop;
   }
   if(scrj<50 && scdist) {
      scdist = (scdist>2) ? Math.ceil(scdist*.2) : 1;
      scrj++;
      scrollBy(0,-scdist);
      setTimeout("softScrollBack()",20);
   } else {
      scrollTo(0,0);
      scrj = 1;
   }
};

( function() { if (!document.getElementById) return

/* ============================================================================== colorRows - 'rowTint'
	Automatic coloured rows | Bite Size Standards
	http://bitesizestandards.com/bites/automatic-coloured-rows
*/

var colorRows = function() {
	var tr = document.getElementsByTagName('tr');
	for (var i = 0; i < tr.length; i++) {
		if (i % 2) {
			tr[i].className = 'rowTint';
		}
	}
};

/* ============================================================================== initRollovers - 'imgover'
	Standards Compliant Rollover Script
	Author : Daniel Nolan
	http://www.bleedingego.co.uk/webdev.php
*/

var initRollovers = function() {

	var aPreLoad = new Array();
	var sTempSrc;
	var img = document.getElementsByTagName('img');

	for (var i = 0; i < img.length; i++) {
		if (img[i].className == 'imgover') {
			var src = img[i].getAttribute('src');
			var ftype = src.substring(src.lastIndexOf('.'), src.length);
			var hsrc = src.replace(ftype, '_o' + ftype);

			img[i].setAttribute('hsrc', hsrc);

			aPreLoad[i] = new Image();
			aPreLoad[i].src = hsrc;

			img[i].onmouseover = function() {
				sTempSrc = this.getAttribute('src');
				this.setAttribute('src', this.getAttribute('hsrc'));
			};

			img[i].onmouseout = img[i].onclick = function() {
				if (!sTempSrc) sTempSrc = this.getAttribute('src').replace('_o' + ftype, ftype);
				this.setAttribute('src', sTempSrc);
			};
		}
	}
};

/* ============================================================================== createExternalLink - 'external'
	Author : Sakai
	Date   : 2008-01-19
*/

var createExternalLink = function() {
	var externalLink = document.getElementsByTagName('a');
	for (var i = 0, len = externalLink.length; i < len; i++) {
		var a = externalLink[i];
		if (a.getAttribute('rel') == 'external') {
			if (a.title) a.title += ' : 新しいウィンドウで開きます';
			a.onclick = function() {
				window.open(this.getAttribute('href'), '_blank');
				return false;
			}
		}
	}
};

/* ============================================================================== formAdjust
	Author : Sakai
	Date   : 2008-03-10
	Update : 2008-10-08
*/

var formAdjuster = function() {
	var inputForm = document.getElementsByTagName('input');
	for (var i = 0, len = inputForm.length; i < len; i++) {
		var iptFm = inputForm[i];
		if (iptFm.getAttribute('type') == 'text' && iptFm.size) {
			var inputSize = iptFm.size;
			if (0 < inputSize && inputSize <= 5) {
				if (iptFm.className != '') {
					iptFm.className += ' level1 typeText';
				} else {
					iptFm.className = 'level1 typeText';
				}
			} else if (inputSize <= 20) {
				if (iptFm.className != '') {
					iptFm.className += ' level2 typeText';
				} else {
					iptFm.className = 'level2 typeText';
				}
			} else if (inputSize <= 40) {
				if (iptFm.className != '') {
					iptFm.className += ' level3 typeText';
				} else {
					iptFm.className = 'level3 typeText';
				}
			} else {
				if (iptFm.className != '') {
					iptFm.className += ' level4 typeText';
				} else {
					iptFm.className = 'level4 typeText';
				}
			}
		}
	}
};

/* ============================================================================== addEvent
*/

function addEvent(elm, listener, fn){
	try {
		elm.addEventListener(listener, fn, false);
	} catch(e) {
		elm.attachEvent('on' + listener, fn);
	}
}

addEvent(window, 'load', function() {
	// colorRows();
	initRollovers();
	formAdjuster();
	createExternalLink();
});

}) ();
