
/*
   -----------------------------------------------------
   カレンダー（リンク機能付き）
   Ver. 1.0.1
   update 2009.5.2
   Copyright (C) WEB-JOZU  URL:http://www.web-jozu.com/
   -----------------------------------------------------
*/


function holidaySet(MM,DD,WEEK,DAY,TTL){
	holiMM[i] = MM; holiDD[i] = DD; holiWEEK[i] = WEEK; holiDAY[i] = DAY; holiTTL[i++] = TTL;
}

function linkdaySet(MM,DD,ACT,URL,TTL){
	this['link' + MM + 'MM']['ok'] = "ok";

	this['link' + MM + 'MM']['d' + DD] = new Array;
	this['link' + MM + 'MM']['d' + DD]['act'] = ACT;
	this['link' + MM + 'MM']['d' + DD]['url'] = URL;
	this['link' + MM + 'MM']['d' + DD]['ttl'] = TTL;
}

function showCalen(MM){
	calenData = createCalen(MM);
	if(document.getElementById) {
		document.getElementById('calenArea').innerHTML = calenData;
	}
}

function showTtl(MM,DD){
	if(document.getElementById && this['link' + MM + 'MM']['d' + DD]['ttl']) {
		document.getElementById('d' + MM + DD).innerHTML = '<span class="linkPopup"><span class="popArrow">△</span><span class="popTxt">' + this['link' + MM + 'MM']['d' + DD]['ttl'] + '</span>';
	}
}

function hideTtl(MM,DD){
	if(document.getElementById) {
		document.getElementById('d' + MM + DD).innerHTML = '';
	}
}

function linkGo(MM,DD){
	actObj = this['link' + MM + 'MM']['d' + DD]['act'];
	urlObj = this['link' + MM + 'MM']['d' + DD]['url'];

	if(actObj == 0 || urlObj == ""){

	}else if(actObj == 1){
		location.href = 'http://' + urlObj;

	}else if(actObj == 2){
		newWin1 = window.open('http://' + urlObj, null);
		newWin1.focus();

	}else if(actObj == 3){
		newWin2 = window.open('http://' + urlObj, 'newWin', 'width=' + winWW + ', height=' + winHH + ', menubar=yes, toolbar=yes, scrollbars=' + winSCL + '');
		newWin2.focus();
	}
}


//リンクを設定
for(i=1; i<=12; i++){
	this['link' + i + 'MM'] = new Array;
	this['link' + i + 'MM']['ok'] = "";
}

i = 0;





/* ---------- 設定領域 start ---------- */

//リンクを設定
//linkdaySet(月,日,ウィンドウ [0:リンクなし, 1:自win, 2:別win, 3:PopUpWin],リンク先,説明)

linkdaySet(1,1,0,'','2012年、新年あけましておめでとうございます。<br>本年もよろしくお願いいたします。<br>正月休み');
linkdaySet(1,2,0,'','正月休み');
linkdaySet(1,3,0,'','正月休み');
linkdaySet(1,4,0,'','本日より、通常通り営業いたします。');
linkdaySet(1,8,0,'','成人式ご用意のため、午前中は多少混み合いますのでご予約ご注意');
linkdaySet(1,9,0,'','祝日･定休日');
linkdaySet(1,15,0,'','毎月第３日曜日は定休日となります');
linkdaySet(1,16,0,'','定休日');
linkdaySet(1,23,0,'','定休日');
linkdaySet(1,25,0,'','竹内は所用のため午後７時に退店します');
linkdaySet(1,30,0,'','定休日');

linkdaySet(2,5,0,'','竹内は所用のため午後４時に退店します');
linkdaySet(2,6,0,'','定休日');
linkdaySet(2,7,0,'','毎月第１火曜日は定休日となります');
linkdaySet(2,11,0,'','建国記念日、午前９時〜午後６時迄の営業となります');
linkdaySet(2,13,0,'','定休日');
linkdaySet(2,15,0,'','竹内は所用のため午後６時に退店します');
linkdaySet(2,19,0,'','毎月第３日曜日は定休日となります');
linkdaySet(2,20,0,'','定休日');
linkdaySet(2,27,0,'','定休日');
linkdaySet(2,29,0,'','竹内は所用のため午後７時に退店します');

linkdaySet(3,5,0,'','定休日');
linkdaySet(3,6,0,'','毎月第１火曜日は定休日となります');
linkdaySet(3,11,0,'','竹内へのご予約は午後１時からとさせていただきます');
linkdaySet(3,12,0,'','定休日');
linkdaySet(3,18,0,'','毎月第３日曜日は定休日となります');
linkdaySet(3,19,0,'','定休日');
linkdaySet(3,20,0,'','春分の日･営業時間は午前９時〜午後６時迄の営業となります');
linkdaySet(3,26,0,'','定休日');

linkdaySet(9,4,0,'','【竹内】はお休みです。');
linkdaySet(9,5,0,'','定休日');
linkdaySet(9,6,0,'','毎月第１火曜日は定休日とさせていただきます。');
linkdaySet(9,12,0,'','定休日');
linkdaySet(9,18,0,'','毎月第３日曜日は定休日とさせていただきます。');
linkdaySet(9,19,0,'','定休日');
linkdaySet(9,26,0,'','定休日');

linkdaySet(10,3,0,'','定休日');
linkdaySet(10,4,0,'','毎月第１火曜日は定休日とさせていただきます。');
linkdaySet(10,10,0,'','定休日');
linkdaySet(10,16,0,'','毎月第３日曜日はお休みさせていただいています。');
linkdaySet(10,17,0,'','定休日');
linkdaySet(10,22,0,'','竹内は午後1時〜3時まで外出します。');
linkdaySet(10,23,0,'','竹内は夕方からの出勤になります。');
linkdaySet(10,24,0,'','定休日');
linkdaySet(10,31,0,'','定休日');

linkdaySet(11,3,0,'','竹内は午後3時からおりません。');
linkdaySet(11,7,0,'','定休日');
linkdaySet(11,8,0,'','毎月第１火曜日は定休日とさせていただきます。');
linkdaySet(11,14,0,'','定休日');
linkdaySet(11,20,0,'','毎月第３日曜日は定休日とさせていただきます。');
linkdaySet(11,21,0,'','定休日');
linkdaySet(11,22,0,'','竹内は午後6時からおりません。');
linkdaySet(11,28,0,'','定休日');

linkdaySet(12,5,0,'','定休日');
linkdaySet(12,6,0,'','毎月第１火曜日は定休日とさせていただきます。');
linkdaySet(12,12,0,'','定休日');
linkdaySet(12,18,0,'','毎月第３日曜日は定休日とさせていただきます。');
linkdaySet(12,19,0,'','定休日');
linkdaySet(12,26,0,'','定休日');
linkdaySet(12,31,0,'','今年一年ありがとうございました。<br>大晦日は午後５時で閉店させていただきます。');

//ポップアップウィンドウの幅と高さを指定
winWW = 400;	//幅
winHH = 400;	//高さ
winSCL = "no";	//スクロール [yes, no]

//現在の月から何ヶ月前まで表示
bfMonNm = 1;

//現在の月から何ヶ月後まで表示
afMonNm = 2;

/* ---------- 設定領域 end ---------- */




function dateReset(){
	//現在の日付を取得
	nowDate = new Date();
	theYear = nowDate.getFullYear();
	theMonth = nowDate.getMonth();
	theDate = nowDate.getDate();
	theDay = nowDate.getDay();

	//現在の日付を保持
	nowMonth = theMonth;
	nowYear = theYear;
}

dateReset();


//リンクの数を取得
linkNum = i;


//カレンダー表示 最後まで
function createCalen(MM){

	i = 0;
	holiMM = new Array;
	holiDD = new Array;
	holiWEEK = new Array;
	holiDAY = new Array;
	holiTTL = new Array;
	

	theMonth = MM;
	
	if(theMonth >= 12){
		theYear++;
		theMonth = 0;
	} else if(theMonth <= -1){
		theYear--;
		theMonth = 11;
	}
	
	
	//月の日数取得
	monNum = new Date(theYear, theMonth + 1, 0).getDate();
	
	//1日の曜日を取得
	firstDay = new Date(theYear, theMonth, 1).getDay();
	
	//月の週を取得
	theWeek = Math.ceil((monNum + firstDay) / 7);
	
	
	//祝日を設定
	holidaySet(1,1,0,0,'元旦');
	holidaySet(1,0,2,1,'成人の日');
	holidaySet(2,11,0,0,'建国記念の日');
	
	if(theYear%4 == 0 || theYear%4 == 1){
		holidaySet(3,20,0,0,'春分の日');
	}else{
		holidaySet(3,21,0,0,'春分の日');
	}
	
	holidaySet(4,29,0,0,'昭和の日');
	holidaySet(5,3,0,0,'憲法記念日');
	holidaySet(5,4,0,0,'みどりの日');
	holidaySet(5,5,0,0,'こどもの日');
	holidaySet(7,0,3,1,'海の日');
	holidaySet(9,0,3,1,'敬老の日');
	
	if(theYear >= 2012 && theYear <= 2044 && theYear%4 == 0){
		holidaySet(9,22,0,0,'秋分の日');
	}else{
		holidaySet(9,23,0,0,'秋分の日');
	}
	
	holidaySet(10,0,2,1,'体育の日');
	holidaySet(11,3,0,0,'文化の日');
	holidaySet(11,23,0,0,'勤労感謝の日');
	holidaySet(12,23,0,0,'天皇誕生日');
	
	//祝日の数を取得
	holiNum = i;
	

	diffY = (theYear - nowYear) * 12;
	diffM = theMonth - nowMonth;

	//月前後ボタンの表示非表示
	if(afMonNm > diffY + diffM){
		rtBtn = '<a href="javascript:showCalen(theMonth + 1); void(0);">＞</a>';
	}else{
		rtBtn = ' ';
	}

	if(bfMonNm > - diffY - diffM){
		ltBtn = '<a href="javascript:showCalen(theMonth - 1); void(0);">＜</a>';
	}else{
		ltBtn = ' ';
	}

	
	//カレンダー表示
	calenData = '';
	calenData += '<table class="calTable">';
	calenData += '<tr>';
	calenData += '<td class="btn">' + ltBtn + '</td>';
	calenData += '<td colspan="5" class="mon"><span class="yView">' + theYear + '年</span> ' + (theMonth + 1) + '月 </td>';
	calenData += '<td class="btn">' + rtBtn + '</td>';
	calenData += '</tr>';
	calenData += '<tr>';
	calenData += '<th>SUN</th>';
	calenData += '<th>MON</th>';
	calenData += '<th>TUE</th>';
	calenData += '<th>WED</th>';
	calenData += '<th>THU</th>';
	calenData += '<th>FRI</th>';
	calenData += '<th>SAT</th>';
	calenData += '</tr>';
	
	
	//重なり順用
	zNum = 32;
	
	dateNum = 0;
	subHoli = "off"
	nationHoli = "off";
	weekSun = 0;
	weekMon = 0;
	weekTue = 0;
	weekWed = 0;
	weekThu = 0;
	weekFri = 0;
	weekSat = 0;
	weekNum = new Array;
	for(i=0; i<=6; i++){
		weekNum[i] = 0;
	}
	
	for(i=0; i<theWeek; i++){
	
		calenData += '<tr>';
	
		for(j=0; j<7; j++){
	
			calenData += '<td';
	
			if(i == 0 && j == firstDay){
				dateNum++;
			}
	
			holiMMDDCk = "off";
			for(k=0; k<holiNum; k++){
	
				holiMMCk = "off";
				holiDDCk = "off";
				if((theMonth + 1) == holiMM[k]){
					holiMMCk = "on";
				}
	
				if(holiMMCk == "on" && dateNum != 0 && holiDD[k] == 0 && holiWEEK[k] - 1 == weekNum[holiDAY[k]] && holiDAY[k] == j){
					holiDDCk = "on";
	
					if(dateNum != 0 && holiDD[k + 1] == 0 && holiWEEK[k + 1] - 1 == weekNum[holiDAY[k + 1]] && holiDAY[k + 1] == j + 2){
						nationHoli = "on";
					}else if(dateNum != 0 && holiDD[k + 1] == dateNum + 2 && holiWEEK[k + 1] == 0 && holiDAY[k + 1] == 0){
						nationHoli = "on";
					}
	
				}else if(holiMMCk == "on" && dateNum != 0 && holiDD[k] == dateNum && holiWEEK[k] == 0 && holiDAY[k] == 0){
					holiDDCk = "on";
	
					if(dateNum != 0 && holiDD[k + 1] == 0 && holiWEEK[k + 1] - 1 == weekNum[holiDAY[k + 1]] && holiDAY[k + 1] == j + 2){
						nationHoli = "on";
					}else if(dateNum != 0 && holiDD[k + 1] == dateNum + 2 && holiWEEK[k + 1] == 0 && holiDAY[k + 1] == 0){
						nationHoli = "on";
					}
	
				}
	
				if(holiMMCk == "on" && holiDDCk == "on"){
					holiMMDDCk = "on";
					viewTtl = holiTTL[k];
				}
	
			}
	
			if(holiMMDDCk == "on"){
				if(dateNum == theDate && theMonth == nowDate.getMonth() && theYear == nowDate.getFullYear()){
					calenData += ' class="sun today" title="' + viewTtl + '"';
				}else{
					calenData += ' class="sun" title="' + viewTtl + '"';
				}
	
				if(j == 0){
					subHoli = "on";
				}
	
			}else if(nationHoli == "on"){
				if(dateNum == theDate && theMonth == nowDate.getMonth() && theYear == nowDate.getFullYear()){
					calenData += ' class="sun today" title="国民の休日"';
				}else{
					calenData += ' class="sun" title="国民の休日"';
				}
	
				nationHoli = "off";
		
			}else if(subHoli == "on"){
				if(dateNum == theDate && theMonth == nowDate.getMonth() && theYear == nowDate.getFullYear()){
					calenData += ' class="sun today" title="振替休日"';
				}else{
					calenData += ' class="sun" title="振替休日"';
				}
	
				subHoli = "off";
		
			}else if(j == 0){
				if(dateNum == theDate && theMonth == nowDate.getMonth() && theYear == nowDate.getFullYear()){
					calenData += ' class="sun today"';
				}else{
					calenData += ' class="sun"';
				}
		
			}else if(j == 6){
				if(dateNum == theDate && theMonth == nowDate.getMonth() && theYear == nowDate.getFullYear()){
					calenData += ' class="sat today"';
				}else{
					calenData += ' class="sat"';
				}
	
			}else if(dateNum == theDate && theMonth == nowDate.getMonth() && theYear == nowDate.getFullYear()){
				calenData += ' class="today"';
			}
	
			calenData += '>';
	
	
			if((i == 0 && j < firstDay) || dateNum > monNum){
				calenData += ' ';
	
			}else{
				aObj = "";
				if(this['link' + (theMonth + 1) + 'MM']['ok'] == "ok" && this['link' + (theMonth + 1) + 'MM']['d' + dateNum]){
					calenData += '<span style="position:relative; display:block; z-index:' + zNum-- + ';"><span id="d' + (theMonth + 1) + dateNum + '"></span><a href="javascript:linkGo(\'' + (theMonth + 1) + '\',\'' + dateNum + '\'); void(0);" onmouseover="showTtl(\'' + (theMonth + 1) + '\',\'' + dateNum + '\')"  onmouseout="hideTtl(\'' + (theMonth + 1) + '\',\'' + dateNum + '\')" class="linkArea">';
					aObj = "on";
				}

				calenData += dateNum;

				if(aObj == "on"){
					calenData += '</a></span>';
					aObj = "";
				}

				dateNum++;
	
				switch(j){
					case 0: weekNum[0] = ++weekSun; break;
					case 1: weekNum[1] = ++weekMon; break;
					case 2: weekNum[2] = ++weekTue; break;
					case 3: weekNum[3] = ++weekWed; break;
					case 4: weekNum[4] = ++weekThu; break;
					case 5: weekNum[5] = ++weekFri; break;
					case 6: weekNum[6] = ++weekSat; break;
				}
			}
	
			calenData += '</td>';
		}
	
		calenData += '</tr>';
	}
	
	calenData += '<tr>';
	calenData += '<td colspan="7" class="webJozu"></td>';
	calenData += '</tr>';
	calenData += '</table>';

	return calenData;
}
//最初から

showCalen(nowMonth);

