var Obj = {};


/**
 * @function    
 * @return {String}    ex) '../common/'
 */
Obj.getCommonDirPath = function() {
	var s = document.getElementsByTagName('SCRIPT');
	if( s.length && s[0].src && s[0].src.match(/(.*\/?common\/)js\/.+$/))
		return RegExp.$1;
	else
		return '/common/';
}

/* -------------------------------------------------------------------
	* 共通関数実行
	* init
 ------------------------------------------------------------------- */
$(function() {

	/* for IE6 background image flicker */
	if (jQuery.browser.msie && jQuery.browser.version == 6) {
		try {
			document.execCommand("BackgroundImageCache", false, true);
		} catch(err) {}
	}

	/* set RolloverImages */
	var roi = new RolloverImages('rollover', 'on');


	/* set SmoothScroll */
	$().SmoothScroll({noflagment:'#page-container'});


});


/* -------------------------------------------------------------------
	* 共通関数定義
	* @function
 ------------------------------------------------------------------- */
	/*
	 * ポップアップ
	 * @function
	 */
	$.fn.jqueryPopup = function(options){
		
		var c = $.extend({
				name       :'popup',  // windowname
				width      :'750',    // 幅
				height     :'600',    // 高さ
				scrollBar  :1,        // スクロールバーの有無
				locationBar:1,        // ロケーションバーの有無
				menuBar    :1,        // メニューバーーの有無
				resize     :1,        // リサイズハンドルの有無
				statusBar  :1,        // ステータスバーの有無
				toolBar    :1,        // ツールバーの有無
				directorBar:1         // ディレクトリバーの有無
			}, options);
		
		var target = $(this);
		var url = target.attr('href');
		var SUB_WIN;
		
		var winops = 'width=' +c.width+ ',height=' +c.height+ ',scrollbars=' +c.scrollBar+ ',location=' +c.locationBar+ ',menubar=' +c.menuBar+ ',resizable=' +c.resize+ ',status=' +c.statusBar+ ',toolbar=' +c.toolbar+ ',directories=' +c.directorBar;
		
		if(!url) return false;

		SUB_WIN = window.open(url,c.name,winops);
		SUB_WIN.focus();
		
		return false;
	}

	/*
	 * スムーススクロール
	 * @function
	 */
	$.fn.SmoothScroll	= function(options){
		
		var scroller = (function() {
			var c = $.extend({
							easing:100,
							step:30,
							fps:60,
							fragment:'',
							noflagment:''
						}, options);
				
			c.ms = Math.floor(1000/c.fps);
			var timerId;
			var param = {
					stepCount:0,
					startY:0,
					endY:0,
					lastY:0
			};
				
				// fnc
				function move() {
					if (param.stepCount == c.step) {
						// scroll end
						setFragment(param.fragment);
						
						window.scrollTo(getCurrentX(), param.endY);
					} else if (param.lastY == getCurrentY()) {
						// scroll
						param.stepCount++;
						window.scrollTo(getCurrentX(), getEasingY());
						param.lastY = getEasingY();
						timerId = setTimeout(move, c.ms); 
					} else {
						// error	
						if (getCurrentY()+getViewportHeight() == getDocumentHeight()) {
							setFragment(param.fragment);
						}
					}
				}
				function setFragment(fragment){
					if(fragment != c.noflagment ) {
						//location.href = location.href.split('#')[0] + fragment;
					}
					/*
					setTimeout(function(){
						location.href = location.href.split('#')[0] + fragment;
					},1000);
					*/
				}

				function getEasingY() {
					return Math.floor(getEasing(param.startY, param.endY, param.stepCount, c.step, c.easing));
				}
				function getEasing(start, end, stepCount, step, easing) {
					var s = stepCount / step;
					return (end - start) * (s + easing / (100 * Math.PI) * Math.sin(Math.PI * s)) + start;
				}
				function targetOffsetTop(target){
					return target.offset().top;
				}
				return {
					set: function(options) {
						this.stop();
						if (options.startY == undefined) options.startY = getCurrentY();
						param = $.extend(param, options);						
						param.lastY = param.startY;
						param.fragment = options.fragment;
						timerId = setTimeout(move, c.ms); 
					},
					stop: function(){
						clearTimeout(timerId);
						param.stepCount = 0;
					}
				};
			})();
			
			function getCurrentY() {
					return document.body.scrollTop  || document.documentElement.scrollTop;
			}
			function getCurrentX() {
					return document.body.scrollLeft  || document.documentElement.scrollLeft;
			}
			function getDocumentHeight(){
					return (document.compatMode && document.compatMode != "BackCompat")?document.documentElement.scrollHeight:document.body.scrollHeight;
			}
			function getViewportHeight(){
					return (!$.browser.safari && !$.browser.opera) ? document.documentElement.clientHeight || document.body.clientHeight || document.body.scrollHeight : window.innerHeight;
			}
			// init
//			$('a[href^=#], area[href^=#]').not('a[href=#],area[href=#],a.no-scroll').live('click',function(){
		$('a, area').live('click',function(){
				
				if($(this).hasClass('no-scroll') || $(this).attr('href')=='#') {
					return false;
				}
				var fragment = $(this).attr('href');
				var url = location.href.split('#')[0];
				
//				alert(fragment.split('#')[0]+'\r\n'+url);
				
				if(fragment.split('#')[0] == url) {
					fragment = '#'+fragment.split('#')[1];
//					alert(fragment);
				}
				
				
				var target = $(fragment);
				//alert(target);
				
				if (target.length == 0) target = $('a[name='+fragment+']');
				
				if (target.length) {
					scroller.set({
						endY: ((getDocumentHeight() - target.offset().top )) < getViewportHeight() ? getDocumentHeight() - getViewportHeight() : target.offset().top,
						fragment: fragment,
						_target :	target
					});

					return false;
				}
			});
	}


