//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
/*
+------------------------------------------------------+
|【営業日カレンダースクリプト】                        |
|Copyright : 営業日カレンダースクリプトだよ            |
|URL       : http://www.calenderdayo.com/              |
+------------------------------------------------------+
|☆注意事項                                            |
|１．このスクリプトはフリー素材です。                  |
|２．このスクリプトを使用したことによって生じる        |
|    いかなる損害に対して作者は一切の責任を負いません。|
+------------------------------------------------------+
*/
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

var holiday = new Object();

<!--設定ここから-->
holiday['2011/3/18'] = 1;
holiday['2011/3/21'] = 1;
holiday['2011/3/22'] = 1;
holiday['2011/3/23'] = 1;
holiday['2011/3/24'] = 1;
holiday['2011/3/25'] = 1;
holiday['2011/3/26'] = 1;
holiday['2011/4/4'] = 1;
holiday['2011/4/29'] = 1;

holiday['2011/5/3'] = 1;
holiday['2011/5/4'] = 1;
holiday['2011/5/5'] = 1;
holiday['2011/7/18'] = 1;
holiday['2011/8/13'] = 1;
holiday['2011/8/15'] = 1;
holiday['2011/8/16'] = 1;
holiday['2011/8/17'] = 1;
holiday['2011/9/13'] = 1;
holiday['2011/9/14'] = 1;
holiday['2011/9/15'] = 1;
holiday['2011/9/16'] = 1;
holiday['2011/9/17'] = 1;
holiday['2011/9/19'] = 1;
holiday['2011/9/23'] = 1;
holiday['2011/10/10'] = 1;
holiday['2011/11/3'] = 1;
holiday['2011/11/12'] = 1;
holiday['2011/11/23'] = 1;
holiday['2011/12/23'] = 1;
holiday['2011/12/27'] = 1;
holiday['2011/12/28'] = 1;
holiday['2011/12/29'] = 1;
holiday['2011/12/30'] = 1;
holiday['2012/1/2'] = 1;
holiday['2012/1/3'] = 1;
holiday['2012/1/4'] = 1;
holiday['2012/1/9'] = 1;
holiday['2012/2/4'] = 1;
holiday['2012/2/11'] = 1;
holiday['2012/3/6'] = 1;
holiday['2012/3/12'] = 1;
holiday['2012/3/13'] = 1;
holiday['2012/3/14'] = 1;
holiday['2012/3/15'] = 1;
holiday['2012/3/16'] = 1;
holiday['2012/3/17'] = 1;
holiday['2012/3/18'] = 1;
holiday['2012/3/19'] = 1;
holiday['2012/3/20'] = 1;
holiday['2012/3/21'] = 1;
holiday['2012/3/22'] = 1;
holiday['2012/3/23'] = 1;
holiday['2012/3/24'] = 1;
holiday['2012/3/25'] = 1;
holiday['2012/3/26'] = 1;

var N_holiday = new Object();
N_holiday['2011/8/18'] = 1;
N_holiday['2011/8/19'] = 1;
<!--設定ここまで-->

//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
var Week     = new Array('月','火','水','木','金','土','日');
var LastDays = new Array(31,28,31,30,31,30,31,31,30,31,30,31);
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
var s_table = ' cellspacing="';
    s_table += '0';
    s_table += '"';
var s_td_ym = ' class="';
    s_td_ym += 's_td_ym';
    s_td_ym += '"';
var s_td_week = ' class="';
    s_td_week += '"';
var s_td_bl = ' class="';
    s_td_bl += 's_td_bl';
    s_td_bl += '"';
var s_td_day = ' class="';
    s_td_day += 's_td_day';
    s_td_day += '"';
var s_td_day2 = ' class="';
    s_td_day2 += 's_td_day2';
    s_td_day2 += '"';
var s_td_day3 = ' class="';
    s_td_day3 += 's_td_day3';
    s_td_day3 += '"';
var s_p = ' class="';
    s_p += 's_p';
    s_p += '"';
var s_table_lay = ' class="';
    s_table_lay += 's_table_lay';
    s_table_lay += '"';
var s_td_lay = ' class="';
    s_td_lay += 's_td_lay';
    s_td_lay += '"';
var s_td_holi = ' class="';
    s_td_holi += 's_td_holi';
    s_td_holi += '"';
var s_td_N_holi = ' class="';
    s_td_N_holi += 's_td_N_holi';
    s_td_N_holi += '"';

var s_td_today = ' class="';
    s_td_today += 's_td_today';
    s_td_today += '"';
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
function cale(how_month,tate_yoko,ko,year,month,view_id){
	if(!view_id){view_id = 'cale';}
	//今日
	if(!year || !month){
		var today = new Date();
		year  = today.getFullYear();
		month = today.getMonth() +1;
	}
	
	var view = new String();
	
	if(!how_month){how_month = 1;}
	if(!tate_yoko){tate_yoko = 1;}
	if(!ko)       {ko = 1;}
	
	var col = 1;
	//view += '<table' + s_table_lay + '>';
	if(tate_yoko == 1 || !tate_yoko){//縦に並べる
		col = 1;
		for(var m=0;m<how_month;m++){
			var next_month_year = year;
			var next_month      = month + m;
			if(next_month > 12){
				next_month = next_month - 12;
				next_month_year++;
			}
			//view += '<tr>';
		//	view += '<td' + s_td_lay + '>';
			view += cale_table(next_month_year,next_month,how_month,tate_yoko,ko);
			//view += '</td>';
			//view += '</tr>';
		}
	}else{//横に並べる
		for(var m=0;m<how_month;m++){
			if((m+ko) % ko == 0){view += '<tr>';}
			var next_month_year = year;
			var next_month      = month + m;
			if(next_month > 12){
				next_month = next_month - 12;
				next_month_year++;
			}
			view += '<td' + s_td_lay + '>';
			view += cale_table(next_month_year,next_month,how_month,tate_yoko,ko);
			view += '</td>';
			if((m+ko) % ko == ko-1){view += '</tr>';}
		}
		col = ko;
	}
	//
	var mes = '<font color="#ff0000">赤字</font>で書かれた日がお休みです。';
/*	view += '<tr>';
	view += '<td colspan="' + col + '"' + s_td_lay + '>';
	view += '<p' + s_p + '>' + mes + '</p>';
	view += '</td>';
	view += '</tr>';*/
//	view += '</table>';
	
	document.getElementById(view_id).innerHTML = view;
}


//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
function cale_table(year,month,how_month,tate_yoko,ko){
	//今月の一日をセット
	var MonthDay1 = new Date();
	    MonthDay1.setFullYear(year);
	    MonthDay1.setMonth(month - 1);
	    MonthDay1.setDate(1);
	//最終日
	uruu(year);
	var MonthLastDay = LastDays[month -1];
	//年と月をセット
	var day = new Date();
	    day.setFullYear(year);
	    day.setMonth(month-1);
	//------------------------------
	//先月
	var p_year  = year;
	var p_month = month - 1;
	if(p_month < 1){
		p_month = 12;
		p_year--;
	}
	//今月
	var today = new Date();
	var t_year  = today.getFullYear();
	var t_month = today.getMonth() + 1;
	var t_day  = today.getDate();
	var t_day = t_year+"/"+t_month +"/"+ t_day;
	//来月
	var n_year  = year;
	var n_month = month + 1;
	if(n_month > 12){
		n_month = n_month - 12;
		n_year++;
	}
	

	//------------------------------
/*	var view = new String();
	view += '<table' + s_table + '>';
	view += '<tr>';
	view += '<td colspan="7"' + s_td_ym + '>' + year + '年' + month + '月';
	view += '</td>';
	view += '</tr>';*/
	
	var view = new String();
	view += '<h3>';
	view += year + '年' + month + '月';
	view += '</h3>';
	//曜日
	view += '<table' + s_table + '>';
	view += '<tr>';
	for(var w=0;w<7;w++){
		view += '<th>' + Week[w] + '</th>';
	}
	view += '</tr>';
	//一日までの空白
	if(MonthDay1.getDay()>0){
		view += '<tr>';
		for(var d=1;d<MonthDay1.getDay();d++){
			view += '<td' + s_td_bl + '>&nbsp;</td>';
		}
	}
	else if(MonthDay1.getDay()==0){
		view += '<tr><td' + s_td_bl + '>&nbsp;</td><td' + s_td_bl + '>&nbsp;</td><td' + s_td_bl + '>&nbsp;</td><td' + s_td_bl + '>&nbsp;</td><td' + s_td_bl + '>&nbsp;</td><td' + s_td_bl + '>&nbsp;</td>';
	}
	var tr = 0;
	for(var d=1;d<=MonthLastDay ;d++){
		
		day.setDate(d);
		
		var style = s_td_day;
		     if(day.getDay() == 6){style = s_td_day2;}
		else if(day.getDay() == 0){style = s_td_day3;}
		
		var date = d;
	//	if(holiday[year+'/'+month+'/'+d] == 1){date = '<font color="#ff0000">' + d + '</font>';}
		if(holiday[year+'/'+month+'/'+d] == 1){style = s_td_holi;}
		if(N_holiday[year+'/'+month+'/'+d] == 1){style = s_td_N_holi;}
		//if(year+'/'+month+'/'+d == t_day){style = s_td_today;}
		if(day.getDay() == 1){view += '<tr>';}
		view += '<td' + style + '>' + date + '</td>';
		if(day.getDay() == 7){view += '</tr>';tr++;}
	}
	
	
	//最終日以降の空白
	if(6-day.getDay() < 6){
		for(var d=0;d<7-day.getDay();d++){
			view += '<td' + s_td_bl + '>&nbsp;</td>';
		}
		view += '</tr>';
		tr++;
	}
	//alert(day.getDay());
	//横に並ぶ形になる時、行数が同じになるように調整
/*	if((tate_yoko == 2 && ko > 1) || (tate_yoko != 2 && tr < 6)){
		for(var t=0;t<6-tr;t++){
			view += '<tr>';
			for(var w=0;w<7;w++){
				view += '<td' + s_td_bl + '>&nbsp;</td>';
			}
			view += '</tr>';
		}
	}*/
	//
	view += '</table>';

	return view;
}



//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
function uruu(year){
	//4の倍数ならうるう年
	//100の倍数ならうるう年でない
	//400の倍数ならうるう年
	//0→28
	//1→29
	var uruu = 28;
	if((year % 4 == 0 && year % 100 != 0) || year % 400 == 0){
	    uruu = 29;
	}
	//2月の日数をセットしなおす
	LastDays[1] = uruu;
}
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

