/*
+------------------------------------------------------+
|【moocalen 1.01】                                     |
|Copyright : 無料素材屋 Moo　～無料素材～              |
|URL       : http://common1.biz/                       |
+------------------------------------------------------+
|※注意事項                                            |
|１．このスクリプトはフリー素材です。                  |
|２．このスクリプトを使用したことによって生じる        |
|    いかなる損害に対して作者は一切の責任を負いません。|
+------------------------------------------------------+
*/
var Holiday        = new Object();
var RegularHoliday = new Object();
var HolidayColor   = new Array();
var Yasumi         = new Array();
//----------------------------------------------------//
Yasumi[1] = '休業';
Yasumi[3] = '臨時営業';
Yasumi[4] = '祝日';

HolidayColor[1] = '#CCBB99';
HolidayColor[3] = '#FFFFFF';
HolidayColor[4] = '#F6EEF6';

Holiday['20110101'] = 1;
Holiday['20110102'] = 1;
Holiday['20110103'] = 1;
Holiday['20110104'] = 1;
Holiday['20110110'] = 1;
Holiday['20110111'] = 3;
Holiday['20110117'] = 1;
Holiday['20110118'] = 3;
Holiday['20110124'] = 1;
Holiday['20110131'] = 1;
Holiday['20110207'] = 1;
Holiday['20110211'] = 4;
Holiday['20110214'] = 1;
Holiday['20110221'] = 1;
Holiday['20110228'] = 1;
Holiday['20110404'] = 1;
Holiday['20110411'] = 1;
Holiday['20110418'] = 1;
Holiday['20110425'] = 1;
Holiday['20110429'] = 4;
Holiday['20110502'] = 1;
Holiday['20110503'] = 4;
Holiday['20110504'] = 4;
Holiday['20110505'] = 4;
Holiday['20110509'] = 1;
Holiday['20110516'] = 1;
Holiday['20110517'] = 1;
Holiday['20110518'] = 1;
Holiday['20110523'] = 1;
Holiday['20110530'] = 1;
Holiday['20110905'] = 1;
Holiday['20110912'] = 1;
Holiday['20110919'] = 1;
Holiday['20110923'] = 4;
Holiday['20110926'] = 1;
Holiday['20111107'] = 1;
Holiday['20111114'] = 1;
Holiday['20111121'] = 1;
Holiday['20111123'] = 4;
Holiday['20111128'] = 1;
Holiday['20111205'] = 1;
Holiday['20111212'] = 1;
Holiday['20111219'] = 1;
Holiday['20111223'] = 4;
Holiday['20111226'] = 1;
Holiday['20120101'] = 1;
Holiday['20120102'] = 1;
Holiday['20120103'] = 1;
Holiday['20120104'] = 1;
Holiday['20120109'] = 1;
Holiday['20120110'] = -1;
Holiday['20120116'] = 1;
Holiday['20120117'] = -1;
Holiday['20120123'] = 1;
Holiday['20120130'] = 1;

RegularHoliday['1-0'] = 0;
RegularHoliday['1-1'] = 1;
RegularHoliday['1-2'] = 0;
RegularHoliday['1-3'] = 0;
RegularHoliday['1-4'] = 0;
RegularHoliday['1-5'] = 0;
RegularHoliday['1-6'] = 0;
RegularHoliday['2-0'] = 0;
RegularHoliday['2-1'] = 1;
RegularHoliday['2-2'] = 1;
RegularHoliday['2-3'] = 0;
RegularHoliday['2-4'] = 0;
RegularHoliday['2-5'] = 0;
RegularHoliday['2-6'] = 0;
RegularHoliday['3-0'] = 0;
RegularHoliday['3-1'] = 1;
RegularHoliday['3-2'] = 1;
RegularHoliday['3-3'] = 0;
RegularHoliday['3-4'] = 0;
RegularHoliday['3-5'] = 0;
RegularHoliday['3-6'] = 0;
RegularHoliday['4-0'] = 0;
RegularHoliday['4-1'] = 1;
RegularHoliday['4-2'] = 0;
RegularHoliday['4-3'] = 0;
RegularHoliday['4-4'] = 0;
RegularHoliday['4-5'] = 0;
RegularHoliday['4-6'] = 0;
RegularHoliday['5-0'] = 0;
RegularHoliday['5-1'] = 1;
RegularHoliday['5-2'] = 0;
RegularHoliday['5-3'] = 0;
RegularHoliday['5-4'] = 0;
RegularHoliday['5-5'] = 0;
RegularHoliday['5-6'] = 0;
RegularHoliday['6-0'] = 0;
RegularHoliday['6-1'] = 1;
RegularHoliday['6-2'] = 0;
RegularHoliday['6-3'] = 0;
RegularHoliday['6-4'] = 0;
RegularHoliday['6-5'] = 0;
RegularHoliday['6-6'] = 0;

var type        = '1';
var fsize       = '11px';
var view_month  = '2';
var yoko        = '2';
var main_color  = '#DDDDCC';
var wid         = '30px';
var hei         = '24px';
var b0_color    = '#F6EEF6';
var b6_color    = '#EEF6F6';

//----------------------------------------------------//

var Week = new Array('S','M','T','W','S','F','S');


var Days = new Array(31,28,31,30,31,30,31,31,30,31,30,31);
var calen = new String();

var now = new Date();
var yea = now.getFullYear();
var mon = now.getMonth()+1;
calen += '<table style="border-collapse:collapse;border:none;margin:0px;padding:0px;background-color:transparent;">';
for(var c=0;c<view_month;c++){
	if(c % yoko == 0){calen += '<tr>';}
	calen += '<td style="border:none;padding:2px;">';
	calen += moo_calen(yea,mon);
	calen += '</td>';
	if(c % yoko == yoko-1){calen += '</tr>';}
	mon++;
	if(mon > 12){yea++;mon-=12;}
}

calen += '</table>';
document.write(calen);

function moo_calen(yea,mon){
	var now = new Date();
	var now_yea = now.getFullYear();
	var now_mon = now.getMonth()+1;
	var now_day = now.getDate();
	
	if(!yea){yea = now_yea;}
	if(!mon){mon = now_mon;}
	
	var date = new Date();
	    date.setDate(1);
	    date.setMonth(mon-1);
	    date.setFullYear(yea);
	var start_week = date.getDay();
	
	uruu(yea);
	var last_day = Days[mon-1];
	
	var back_yea = yea;
	var back_mon = mon-1;
	if(back_mon < 1){
		back_yea --;
		back_mon += 12;
	}
	var next_yea = yea;
	var next_mon = mon+1;
	if(next_mon > 12){
		next_yea ++;
		next_mon -= 12;
	}
	
	var ye = new String(yea);
	var mo = new String(mon);
	if(mo < 10){mo = '0'+mo;}
	
	var base;
	var tabl;
	var tdym;
	var tdw;
	var td0;
	var td6;
	var tdh = new Object();
	var td;
	if(type == 1){
		base = 'text-align:center;vertical-align:middle;font-size:'+fsize+';padding:0px;margin:0px;line-height:120%;color:#666666;';
		tabl = '<table style="border-collapse:collapse;border:none;background-color:transparent;">';
		tdym = '<td style="'+base+'border:none;width:auto;height:'+hei+';background-color:transparent;color:#770033;font-weight:bold;vertical-align:bottom;font-size:12px;" colspan="7">';
		tdw  = '<td style="'+base+'border:solid 1px '+main_color+';width:'+wid+';height:'+hei+';background-color:#ffffff;font-weight:bold;">';
		td0  = '<td style="'+base+'border:solid 1px '+main_color+';width:'+wid+';height:'+hei+';background-color:'+b0_color+';">';
		td6  = '<td style="'+base+'border:solid 1px '+main_color+';width:'+wid+';height:'+hei+';background-color:'+b6_color+';">';
		td   = '<td style="'+base+'border:solid 1px '+main_color+';width:'+wid+';height:'+hei+';background-color:#ffffff;">';
		for(var h=1;h<HolidayColor.length;h++){
			tdh[h]  = '<td style="'+base+'border:solid 1px '+main_color+';width:'+wid+';height:'+hei+';background-color:'+HolidayColor[h]+';">';
		}
	}else if(type == 2){
		base = 'border:none;text-align:center;vertical-align:middle;font-size:'+fsize+';padding:0px;margin:auto;line-height:120%;color:#000000;';
		tabl = '<table style="border-collapse:separate;border:none;background-color:transparent;">';
		tdym = '<td style="'+base+'width:auto;height:'+hei+';background-color:transparent;" colspan="7">';
		tdw  = '<td style="'+base+'width:'+wid+';height:'+hei+';background-color:'+main_color+';color:#ffffff;">';
		td0  = '<td style="'+base+'width:'+wid+';height:'+hei+';background-color:'+b0_color+';">';
		td6  = '<td style="'+base+'width:'+wid+';height:'+hei+';background-color:'+b6_color+';">';
		td   = '<td style="'+base+'width:'+wid+';height:'+hei+';background-color:#f3f3f3;">';
		for(var h=1;h<HolidayColor.length;h++){
			tdh[h]  = '<td style="'+base+'width:'+wid+';height:'+hei+';background-color:'+HolidayColor[h]+';">';
		}
	}else if(type == 3){
		base = 'text-align:center;vertical-align:middle;font-size:'+fsize+';padding:0px;margin:auto;line-height:120%;color:#000000;';
		tabl = '<table style="border-collapse:separate;border:none;background-color:transparent;">';
		tdym = '<td style="'+base+'border:none;width:auto;height:'+hei+';background-color:transparent;" colspan="7">';
		tdw  = '<td style="'+base+'border:none;width:'+wid+';height:'+hei+';background-color:transparent;">';
		td0  = '<td style="'+base+'border:solid 1px '+main_color+';width:'+wid+';height:'+hei+';background-color:'+b0_color+';">';
		td6  = '<td style="'+base+'border:solid 1px '+main_color+';width:'+wid+';height:'+hei+';background-color:'+b6_color+';">';
		td   = '<td style="'+base+'border:solid 1px '+main_color+';width:'+wid+';height:'+hei+';background-color:#ffffff;">';
		for(var h=1;h<HolidayColor.length;h++){
			tdh[h]  = '<td style="'+base+'border:solid 1px '+main_color+';width:'+wid+';height:'+hei+';background-color:'+HolidayColor[h]+';">';
		}
	}
    
	var view = new String();
	var nanshuume = new Object();
	var we = 0;
	var da = 0;
	
	view += tabl;
	view += '<tr>'+tdym;
	view += yea+'.'+mon+'';
	view += '</td></tr>';
	view += '<tr>';
	for(var w=0;w<7;w++){
		view += tdw+Week[w]+'</td>';
		nanshuume[w] = 0;
	}
	view += '</tr>';
	
	for(var g=0;g<6;g++){
		view += '<tr>';
		for(var d=g*7+1;d<=g*7+7;d++){
			if(we < start_week){
				view += td+'&nbsp;</td>';
        	}else{
        		var wee = we % 7;
        		nanshuume[wee]++;
        		if(da < Days[mo-1]){
					da++;
					var dd = da;
					if(da < 10){dd = '0'+da;}
					if(Holiday[ye+mo+dd] == -1){
						view += td;
					}else if(Holiday[ye+mo+dd] > 0){
						view += tdh[Holiday[ye+mo+dd]];
					}else if(RegularHoliday[nanshuume[wee]+'-'+wee] > 0){
						view += tdh[RegularHoliday[nanshuume[wee]+'-'+wee]];
					}else if(we % 7 == 0){
						view += td0;
					}else if(we % 7 == 6){
						view += td6;
					}else{
						view += td;
					}
					view += da+'</td>';
        		}else{
					view += td+'&nbsp;</td>';
        		}
        	}
			we++;
		}
		view += '</tr>';
	}
	view += '</table>';
	return view;
}

function uruu(yea){
	var uruu = 28;
	if((yea % 4 == 0 && yea % 100 != 0) || yea % 400 == 0){
		uruu = 29;
	}
	Days[1] = uruu;
}

