
(function($) {

	$(function() {
		$.common.fontsize();
		$.common.rollover();
	});

	//////////////////////////////////////////////////////////////
	// ブラウザによってclassかclassNameかを選別する
	//////////////////////////////////////////////////////////////
	$(function(_class){
		if(navigator.appName == 'Microsoft Internet Explorer'){
			_class = 'className'
		}else{
			_class = 'class'
		}
	});

	//---------------------------------------------------------------------

	$.common = {
		// URIを解析したオブジェクトを返すfunction
		Uri: function(path){
			var self = this;
			this.originalPath = path;
			//絶対パスを取得
			this.absolutePath = (function(){
				var e = document.createElement('span');
				e.innerHTML = '<a href="' + path + '" />';
				return e.firstChild.href;
			})();
			//絶対パスを分解
			var fields = {'schema' : 2, 'username' : 5, 'password' : 6, 'host' : 7, 'path' : 9, 'query' : 10, 'fragment' : 11};
			var r = /^((\w+):)?(\/\/)?((\w+):?(\w+)?@)?([^\/\?:]+):?(\d+)?(\/?[^\?#]+)?\??([^#]+)?#?(\w*)/.exec(this.absolutePath);
			for (var field in fields) {
				this[field] = r[fields[field]];
			}
			this.querys = {};
			if(this.query){
				$.each(self.query.split('&'), function(){
					var a = this.split('=');
					if (a.length == 2) self.querys[a[0]] = a[1];
				});
			}
		},

		//////////////////////////////////////////////////////////////
		// 追記：2009-06-24 man'age
		// フォントサイズ変更スクリプト（jquery_cookie.jsと併用）
		//////////////////////////////////////////////////////////////
		fontsize: function(options) {
			var c = $.extend({
				selfLinkAreaSelector:'#fontsize',
				selfLinkClass:'selecting',
				postfix: '_on',
				changeImgSelf:true,
				changeImgParents:true
			}, options);

			var size = $.cookie('fsize');

			if(size != null){
				$('body').addClass(size);
			}else{
				size = 'middle';
			}
			selfsize = $(c.selfLinkAreaSelector).find('input[value='+size+']');
			selfsize.addClass(c.selfLinkClass);
			this.originalSrc = $(selfsize).attr('src');
			this.currentSrc = this.originalSrc.replace(/(\.gif|\.jpg|\.png)/, c.postfix+"$1");
			$(selfsize).attr('src',this.currentSrc);

			$('#fontsize input').each(function(){
				$(this).click(function(event){
					size = escape($(this).val());
					$('body').attr('class', size);
					$('.'+c.selfLinkClass).removeClass(c.selfLinkClass);
					$(this).addClass(c.selfLinkClass);
					$.cookie('fsize',size,{expires:30,path:'/'});
					location.reload();
				});
			});

		},

		//ロールオーバー
		rollover: function(options) {
			var c = $.extend({
				hoverSelector: '.Hover, #fontsize input, #gnav a img, #main_body a img',
				groupSelector: '.btngroup',
				postfix: '_on'
			}, options);
			//ロールオーバーするノードの初期化
			var rolloverImgs = $(c.hoverSelector).filter(isNotCurrent);
			rolloverImgs.each(function(){
				this.originalSrc = $(this).attr('src');
				this.rolloverSrc = this.originalSrc.replace(new RegExp('('+c.postfix+')?(\.gif|\.jpg|\.png)$'), c.postfix+"$2");
				this.rolloverImg = new Image;
				this.rolloverImg.src = this.rolloverSrc;
			});
			//グループ内のimg要素を指定するセレクタ生成
			var groupingImgs = $(c.groupSelector).find('img').filter(isRolloverImg);

			//通常ロールオーバー
			rolloverImgs.not(groupingImgs).hover(function(){
				$(this).attr('src',this.rolloverSrc);
			},function(){
				$(this).attr('src',this.originalSrc);
			});
			//グループ化されたロールオーバー
			$(c.groupSelector).hover(function(){
				$(this).find('img').filter(isRolloverImg).each(function(){
					$(this).attr('src',this.rolloverSrc);
				});
			},function(){
				$(this).find('img').filter(isRolloverImg).each(function(){
					$(this).attr('src',this.originalSrc);
				});
			});

			//フィルタ用function
			function isNotCurrent(i){
				return Boolean(!this.currentSrc);
			}
			function isRolloverImg(i){
				return Boolean(this.rolloverSrc);
			}
		}
	};
})(jQuery);
