var setEvent, getClassAttr, setClassAttr, addWinLoadEvent;

setFunction();
addWinLoadEvent( setStyle4Ie6 );
addWinLoadEvent( setAnchor );

// -------------------------------------------------------------------
// IEとそのほかのモダンブラウザで異なるメソッドをラップ
function setFunction () {
	if ( navigator.userAgent.indexOf( 'MSIE 6' ) >= 0 ||
		navigator.userAgent.indexOf( 'MSIE 7' ) >= 0 ) {
		setEvent = function ( elem, ehandler, efunc ) {
			return elem.setAttribute( ehandler, new Function( efunc ) );
		}
		getClassAttr = function ( elem ) {
			return elem.getAttribute( "className" );
		}
		setClassAttr = function ( elem, val ) {
			return elem.setAttribute( "className", val );
		}
	}
	else {
		setEvent = function ( elem, ehandler, efunc ) {
			return elem.setAttribute( ehandler, efunc );
		}
		getClassAttr = function ( elem ) {
			return elem.getAttribute( "class" );
		}
		setClassAttr = function ( elem, val ) {
			return elem.setAttribute( "class", val );
		}
	}

	addWinLoadEvent = function ( evf ) {
		if ( window.addEventListener ) {
			return window.addEventListener( 'load', evf, false );
		}
		return window.attachEvent( 'onload',  evf );
	}
	return true;
}

// -------------------------------------------------------------------
// IE6は、CSSではa要素以外にhoverが効かない。
// IE6用のCSS（ie6.css）はhoverなしのスタイル（プルダウンメニューがすべて展開状態）になっている。
// JavaScriptが有効なIE6では、csshover.htcを使うことでa要素以外でもhoverが使えるようになるので、スタイルもドロップダウンメニュー用CSSに入れ替える。
function setStyle4Ie6 () {
	if ( navigator.userAgent.indexOf( 'MSIE 6.' ) === -1 ) return false;
	if ( !document.styleSheets ) return false;

	var ss = document.styleSheets;
	for ( var i=0; i<ss.length; i++ ) {
		if ( ss[i].href.indexOf( 'ie6.css' ) >= 0 ) {
			ss[i].href = ss[i].href.replace( 'ie6.css', 'ie6withscript.css' );
			break;
		}
	}
	return true;
}

// -------------------------------------------------------------------
function setAnchor () {
	if( !document.getElementsByTagName ||
		!document.getElementsByTagName( 'a' ) ) return false;

	// ページトップ（#）への移動の場合はJavaScriptで乗っ取る
	// #でページトップにジャンプできないSafari 3対策。（これは本来はスクリプトで解決すべきではない…）
	// アドレスに#をつけない
	function _movePageTop () {
		if ( ('#' === as[i].getAttribute( 'href' ) && location.hostname.indexOf( 'store.e-frontier.co.jp' ) === -1 && location.pathname.indexOf( '/efimage/' ) === -1 ) || '#wrapper' === as[i].getAttribute( 'href' ) ) {
			setEvent( as[i], 'onclick', 'window.scrollTo(0, 0); return false;' );
		}
		return true;
	}

	// イーフロンティア以外のサイトへのリンクは別ウィンドウで開きGoogleAnalyticsに記録する
	function _openWin4OutLink () {
		var href = as[i].getAttribute( 'href' );
		if ( href && href.indexOf( 'http' ) === 0 ) {
			var pn;
			if ( href.indexOf( location.hostname ) === -1 &&
				href.indexOf( '/shop.vector.co.jp' ) !== -1 )
			{
				pn = as[i];
				setEvent( as[i], 'onclick', 'javascript:' + gafuncname + 
					"('/outsidelink//" + pn + as[i].search + "');" )
			} else if ( href.indexOf( location.hostname ) === -1 &&
				href.indexOf( '.e-frontier.co.jp' ) === -1 &&
				href.indexOf( '/www.viruskiller.jp' ) === -1 &&
				href.indexOf( '/www.carrara.jp' ) === -1 &&
				href.indexOf( '/www.aztv.gr.jp' ) === -1 &&
				href.indexOf( '/f-groove.com' ) === -1 &&
				href.indexOf( '/www.musicsheet.jp' ) === -1 &&
				href.indexOf( '/www.mixvibes.jp' ) === -1 )
			{
				pn = as[i];
				setEvent( as[i], 'onclick', 'javascript:' + gafuncname + 
					"('/outsidelink//" + pn + as[i].search + "'); window.open( this.href ); return false;" )
			}

		}
		return true;
	}

	//GoogleAnalyticsの2種類のうちどちらのコードを使っているかを判別
	function _getGACodeType () {
		var st = document.getElementsByTagName( 'script' );
		for ( var i=0; i<st.length; i++ ) {
			var src = st[i].getAttribute( 'src' );
			var inhtml = st[i].innerHTML;
			if ( src && src.indexOf( 'google-analytics.com/urchin.js' ) !== -1 ) {
				return 'urchinTracker';
			} else if ( inhtml.indexOf( 'google-analytics.com/ga.js' ) !== -1 ) {
				return 'pageTracker._trackPageview';
			}
		}
		return false;
	}

	var gafuncname = _getGACodeType();

	var as = document.getElementsByTagName( 'a' );
	for ( var i=0; i<as.length; i++ ) {
		_movePageTop();
		_openWin4OutLink();
	}

	return true;
}

var useBSNns;

if (useBSNns)
{
	if (typeof(bsn) == "undefined")
		bsn = {}
	var _bsn = bsn;
}
else
{
	var _bsn = this;
}





_bsn.Crossfader = function (divs, fadetime, delay )
{	
	this.nAct = -1;
	this.aDivs = divs;
	
	for (var i=0;i<divs.length;i++)
	{
		document.getElementById(divs[i]).style.opacity = 0;
		document.getElementById(divs[i]).style.position = "absolute";
		document.getElementById(divs[i]).style.filter = "alpha(opacity=0)";
		document.getElementById(divs[i]).style.visibility = "hidden";
	}
	
	this.nDur = fadetime;
	this.nDelay = delay;
		
	this._newfade();
}


_bsn.Crossfader.prototype._newfade = function()
{
	if (this.nID1)
		clearInterval(this.nID1);
	
	this.nOldAct = this.nAct;
	this.nAct++;
	if (!this.aDivs[this.nAct])	this.nAct = 0;
	
	if (this.nAct == this.nOldAct)
		return false;
	
	document.getElementById( this.aDivs[this.nAct] ).style.visibility = "visible";
	
	this.nInt = 50;
	this.nTime = 0;
	
	var p=this;
	this.nID2 = setInterval(function() { p._fade() }, this.nInt);
}


_bsn.Crossfader.prototype._fade = function()
{
	this.nTime += this.nInt;
	
	var ieop = Math.round( this._easeInOut(this.nTime, 0, 1, this.nDur) * 100 );
	var op = ieop / 100;
	document.getElementById( this.aDivs[this.nAct] ).style.opacity = op;
	document.getElementById( this.aDivs[this.nAct] ).style.filter = "alpha(opacity="+ieop+")";
	
	if (this.nOldAct > -1)
	{
		document.getElementById( this.aDivs[this.nOldAct] ).style.opacity = 1 - op;
		document.getElementById( this.aDivs[this.nOldAct] ).style.filter = "alpha(opacity="+(100 - ieop)+")";
	}
	
	if (this.nTime == this.nDur)
	{
		clearInterval( this.nID2 );
		
		if (this.nOldAct > -1)
			document.getElementById( this.aDivs[this.nOldAct] ).style.visibility = "hidden";	
		
		var p=this;
		this.nID1 = setInterval(function() { p._newfade() }, this.nDelay);
	}
}



_bsn.Crossfader.prototype._easeInOut = function(t,b,c,d)
{
	return c/2 * (1 - Math.cos(Math.PI*t/d)) + b;
}
