/* -------------------------------------------------------------------
	* 共通関数実行
	* init
 ------------------------------------------------------------------- */
$(function() {

	/* for IE6 background image flicker */
	if (jQuery.browser.msie && jQuery.browser.version == 6) {
		try {
			document.execCommand("BackgroundImageCache", false, true);
		} catch(err) {}
	}


	/* set PdfLinkBlank */
	$('#contents a').LinkTargetSet();
	
	/* init SearchPlaceholder */
	$('.site-search').SearchPlaceholder();
	
	/* set SmoothScroll */
	$().SmoothScroll();
	

});



	


/* -------------------------------------------------------------------
	* 共通関数定義
	* @function
 ------------------------------------------------------------------- */
(function($){

	/*
	 * リンクのtarget指定の設定・上書き	(初期値：pdfリンクを別窓にする)
	 * @function
	 */
	$.fn.LinkTargetSet = function(config){
		c = jQuery.extend({
					reg	:	new RegExp("(\.pdf$|\.pdf#.*)", "i"),
				 	target	:	'_blank'
			 },config);
		$(this).each(function(){
			var t = this;
			var $t = $(t);
			var href = $t.attr('href');
			if (href.match(c.reg)) {
				$t.attr('target',c.target);
			}
		});
	}

	/*
	 * サイト内検索ボックスのプレースホルダ
	 * @function
	 */
	$.fn.SearchPlaceholder = function(config){
		c = jQuery.extend({
					str				:	'',
					addClass	:	'pre-text'
				},config);
		
		$(this).each(function(){
			var t = this;
			var $t = $(t);
			var $ele = {
					form	:	$t.find('form'),
					input	:	$t.find('input:text'),
					btn		:	$t.find('input:image')
			}
			// 入力支援 
			$ele.input.attr('value',c.str).addClass(c.addClass)
								.focus(function(){
									var value = $ele.input.attr('value');

									if(value == c.str){
										$ele.input.removeClass(c.addClass).attr('value','');
									}
								})
								.blur(function(){						 
									var value = $ele.input.attr('value');
									if(value == c.str || value == ''){
										$ele.input.addClass(c.addClass).attr('value',c.str);
									}
								});

			 //	submit時のエラー処理

/*			$ele.form.submit(function(){
					var value = $ele.input.attr('value');
					
					if(value == c.str || value == ''){
							return false;
					}
			});
*/
			
		});
	}


	/*
	 * ポップアップ
	 * @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:''
						}, 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){
					location.href = location.href.split('#')[0] + fragment;
				}

				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, area.no-scroll').click(function(){

				var fragment = $(this).attr('href');
				var target = $(fragment);
				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;
				}
			});
	}
	
})(jQuery)
