1318 |
alexandre_ |
1 |
/*
|
|
|
2 |
Copyright (c) 2004-2006, The Dojo Foundation
|
|
|
3 |
All Rights Reserved.
|
|
|
4 |
|
|
|
5 |
Licensed under the Academic Free License version 2.1 or above OR the
|
|
|
6 |
modified BSD license. For more information on Dojo licensing, see:
|
|
|
7 |
|
|
|
8 |
http://dojotoolkit.org/community/licensing.shtml
|
|
|
9 |
*/
|
|
|
10 |
|
|
|
11 |
dojo.provide("dojo.widget.MonthlyCalendar");
|
|
|
12 |
dojo.require("dojo.date.common");
|
|
|
13 |
dojo.require("dojo.date.format");
|
|
|
14 |
dojo.require("dojo.widget.*");
|
|
|
15 |
dojo.require("dojo.widget.DatePicker");
|
|
|
16 |
dojo.require("dojo.event.*");
|
|
|
17 |
dojo.require("dojo.html.*");
|
|
|
18 |
dojo.require("dojo.experimental");
|
|
|
19 |
dojo.experimental("dojo.widget.MonthlyCalendar");
|
|
|
20 |
dojo.widget.defineWidget("dojo.widget.MonthlyCalendar", dojo.widget.DatePicker, {dayWidth:"wide", templateString:"<div class=\"datePickerContainer\" dojoAttachPoint=\"datePickerContainerNode\">\n\t<h3 class=\"monthLabel\">\n\t<!--\n\t<span \n\t\tdojoAttachPoint=\"decreaseWeekNode\" \n\t\tdojoAttachEvent=\"onClick: onIncrementWeek;\" \n\t\tclass=\"incrementControl\">\n\t\t<img src=\"${dojoWidgetModuleUri}templates/decrementWeek.gif\" alt=\"↑\" />\n\t</span>\n\t-->\n\t<span \n\t\tdojoAttachPoint=\"decreaseMonthNode\" \n\t\tdojoAttachEvent=\"onClick: onIncrementMonth;\" class=\"incrementControl\">\n\t\t<img src=\"${dojoWidgetModuleUri}templates/decrementMonth.gif\" \n\t\t\talt=\"↑\" dojoAttachPoint=\"decrementMonthImageNode\">\n\t</span>\n\t<span dojoAttachPoint=\"monthLabelNode\" class=\"month\">July</span>\n\t<span \n\t\tdojoAttachPoint=\"increaseMonthNode\" \n\t\tdojoAttachEvent=\"onClick: onIncrementMonth;\" class=\"incrementControl\">\n\t\t<img src=\"${dojoWidgetModuleUri}templates/incrementMonth.gif\" \n\t\t\talt=\"↓\" dojoAttachPoint=\"incrementMonthImageNode\">\n\t</span>\n\t<!--\n\t\t<span dojoAttachPoint=\"increaseWeekNode\" \n\t\t\tdojoAttachEvent=\"onClick: onIncrementWeek;\" \n\t\t\tclass=\"incrementControl\">\n\t\t\t<img src=\"${dojoWidgetModuleUri}templates/incrementWeek.gif\" \n\t\t\talt=\"↓\" />\n\t\t</span>\n\t-->\n\t</h3>\n\t<table class=\"calendarContainer\">\n\t\t<thead>\n\t\t\t<tr dojoAttachPoint=\"dayLabelsRow\">\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t</tr>\n\t\t</thead>\n\t\t<tbody dojoAttachPoint=\"calendarDatesContainerNode\" \n\t\t\tdojoAttachEvent=\"onClick: onSetDate;\">\n\t\t\t<tr dojoAttachPoint=\"calendarRow0\">\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t</tr>\n\t\t\t<tr dojoAttachPoint=\"calendarRow1\">\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t</tr>\n\t\t\t<tr dojoAttachPoint=\"calendarRow2\">\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t</tr>\n\t\t\t<tr dojoAttachPoint=\"calendarRow3\">\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t</tr>\n\t\t\t<tr dojoAttachPoint=\"calendarRow4\">\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t</tr>\n\t\t\t<tr dojoAttachPoint=\"calendarRow5\">\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t\t<td></td>\n\t\t\t</tr>\n\t\t</tbody>\n\t</table>\n\t<h3 class=\"yearLabel\">\n\t\t<span dojoAttachPoint=\"previousYearLabelNode\"\n\t\t\tdojoAttachEvent=\"onClick: onIncrementYear;\" class=\"previousYear\"></span>\n\t\t<span class=\"selectedYear\" dojoAttachPoint=\"currentYearLabelNode\"></span>\n\t\t<span dojoAttachPoint=\"nextYearLabelNode\" \n\t\t\tdojoAttachEvent=\"onClick: onIncrementYear;\" class=\"nextYear\"></span>\n\t</h3>\n</div>\n", templateCssString:".datePickerContainer {\n\tmargin:0.5em 2em 0.5em 0;\n\t/*width:10em;*/\n\tfloat:left;\n}\n\n.previousMonth {\n\tbackground-color:#bbbbbb;\n}\n\n.currentMonth {\n\tbackground-color:#8f8f8f;\n}\n\n.nextMonth {\n\tbackground-color:#eeeeee;\n}\n\n.currentDate {\n\ttext-decoration:underline;\n\tfont-style:italic;\n}\n\n.selectedItem {\n\tbackground-color:#3a3a3a;\n\tcolor:#ffffff;\n}\n\n.calendarContainer {\n\tborder-collapse:collapse;\n\tborder-spacing:0;\n\tborder-bottom:1px solid #e6e6e6;\n\toverflow: hidden;\n\ttext-align: right;\n}\n\n.calendarContainer thead{\n\tborder-bottom:1px solid #e6e6e6;\n}\n\n.calendarContainer tbody * td {\n height: 100px;\n border: 1px solid gray;\n}\n\n.calendarContainer td {\n width: 100px;\n padding: 2px;\n\tvertical-align: top;\n}\n\n.monthLabel {\n\tfont-size:0.9em;\n\tfont-weight:400;\n\tmargin:0;\n\ttext-align:center;\n}\n\n.monthLabel .month {\n\tpadding:0 0.4em 0 0.4em;\n}\n\n.yearLabel {\n\tfont-size:0.9em;\n\tfont-weight:400;\n\tmargin:0.25em 0 0 0;\n\ttext-align:right;\n\tcolor:#a3a3a3;\n}\n\n.yearLabel .selectedYear {\n\tcolor:#000;\n\tpadding:0 0.2em;\n}\n\n.nextYear, .previousYear {\n\tcursor:pointer;cursor:hand;\n}\n\n.incrementControl {\n\tcursor:pointer;cursor:hand;\n\twidth:1em;\n}\n\n.dojoMonthlyCalendarEvent {\n\tfont-size:0.7em;\n\toverflow: hidden;\n\tfont-color: grey;\n\twhite-space: nowrap;\n\ttext-align: left;\n}\n", templateCssPath:dojo.uri.moduleUri("dojo.widget", "templates/MonthlyCalendar.css"), initializer:function () {
|
|
|
21 |
this.iCalendars = [];
|
|
|
22 |
}, addCalendar:function (cal) {
|
|
|
23 |
dojo.debug("Adding Calendar");
|
|
|
24 |
this.iCalendars.push(cal);
|
|
|
25 |
dojo.debug("Starting init");
|
|
|
26 |
this.initUI();
|
|
|
27 |
dojo.debug("done init");
|
|
|
28 |
}, createDayContents:function (node, mydate) {
|
|
|
29 |
dojo.html.removeChildren(node);
|
|
|
30 |
node.appendChild(document.createTextNode(mydate.getDate()));
|
|
|
31 |
for (var x = 0; x < this.iCalendars.length; x++) {
|
|
|
32 |
var evts = this.iCalendars[x].getEvents(mydate);
|
|
|
33 |
if ((dojo.lang.isArray(evts)) && (evts.length > 0)) {
|
|
|
34 |
for (var y = 0; y < evts.length; y++) {
|
|
|
35 |
var el = document.createElement("div");
|
|
|
36 |
dojo.html.addClass(el, "dojoMonthlyCalendarEvent");
|
|
|
37 |
el.appendChild(document.createTextNode(evts[y].summary.value));
|
|
|
38 |
el.width = dojo.html.getContentBox(node).width;
|
|
|
39 |
node.appendChild(el);
|
|
|
40 |
}
|
|
|
41 |
}
|
|
|
42 |
}
|
|
|
43 |
}, initUI:function () {
|
|
|
44 |
var dayLabels = dojo.date.getNames("days", this.dayWidth, "standAlone", this.lang);
|
|
|
45 |
var dayLabelNodes = this.dayLabelsRow.getElementsByTagName("td");
|
|
|
46 |
for (var i = 0; i < 7; i++) {
|
|
|
47 |
dayLabelNodes.item(i).innerHTML = dayLabels[i];
|
|
|
48 |
}
|
|
|
49 |
this.selectedIsUsed = false;
|
|
|
50 |
this.currentIsUsed = false;
|
|
|
51 |
var currentClassName = "";
|
|
|
52 |
var previousDate = new Date();
|
|
|
53 |
var calendarNodes = this.calendarDatesContainerNode.getElementsByTagName("td");
|
|
|
54 |
var currentCalendarNode;
|
|
|
55 |
previousDate.setHours(8);
|
|
|
56 |
var nextDate = new Date(this.firstSaturday.year, this.firstSaturday.month, this.firstSaturday.date, 8);
|
|
|
57 |
var lastDay = new Date(this.firstSaturday.year, this.firstSaturday.month, this.firstSaturday.date + 42, 8);
|
|
|
58 |
if (this.iCalendars.length > 0) {
|
|
|
59 |
for (var x = 0; x < this.iCalendars.length; x++) {
|
|
|
60 |
this.iCalendars[x].preComputeRecurringEvents(lastDay);
|
|
|
61 |
}
|
|
|
62 |
}
|
|
|
63 |
if (this.firstSaturday.date < 7) {
|
|
|
64 |
var dayInWeek = 6;
|
|
|
65 |
for (var i = this.firstSaturday.date; i > 0; i--) {
|
|
|
66 |
currentCalendarNode = calendarNodes.item(dayInWeek);
|
|
|
67 |
this.createDayContents(currentCalendarNode, nextDate);
|
|
|
68 |
dojo.html.setClass(currentCalendarNode, this.getDateClassName(nextDate, "current"));
|
|
|
69 |
dayInWeek--;
|
|
|
70 |
previousDate = nextDate;
|
|
|
71 |
nextDate = this.incrementDate(nextDate, false);
|
|
|
72 |
}
|
|
|
73 |
for (var i = dayInWeek; i > -1; i--) {
|
|
|
74 |
currentCalendarNode = calendarNodes.item(i);
|
|
|
75 |
this.createDayContents(currentCalendarNode, nextDate);
|
|
|
76 |
dojo.html.setClass(currentCalendarNode, this.getDateClassName(nextDate, "previous"));
|
|
|
77 |
previousDate = nextDate;
|
|
|
78 |
nextDate = this.incrementDate(nextDate, false);
|
|
|
79 |
}
|
|
|
80 |
} else {
|
|
|
81 |
nextDate.setDate(1);
|
|
|
82 |
for (var i = 0; i < 7; i++) {
|
|
|
83 |
currentCalendarNode = calendarNodes.item(i);
|
|
|
84 |
this.createDayContents(currentCalendarNode, nextDate);
|
|
|
85 |
dojo.html.setClass(currentCalendarNode, this.getDateClassName(nextDate, "current"));
|
|
|
86 |
previousDate = nextDate;
|
|
|
87 |
nextDate = this.incrementDate(nextDate, true);
|
|
|
88 |
}
|
|
|
89 |
}
|
|
|
90 |
previousDate.setDate(this.firstSaturday.date);
|
|
|
91 |
previousDate.setMonth(this.firstSaturday.month);
|
|
|
92 |
previousDate.setFullYear(this.firstSaturday.year);
|
|
|
93 |
nextDate = this.incrementDate(previousDate, true);
|
|
|
94 |
var count = 7;
|
|
|
95 |
currentCalendarNode = calendarNodes.item(count);
|
|
|
96 |
while ((nextDate.getMonth() == previousDate.getMonth()) && (count < 42)) {
|
|
|
97 |
this.createDayContents(currentCalendarNode, nextDate);
|
|
|
98 |
dojo.html.setClass(currentCalendarNode, this.getDateClassName(nextDate, "current"));
|
|
|
99 |
currentCalendarNode = calendarNodes.item(++count);
|
|
|
100 |
previousDate = nextDate;
|
|
|
101 |
nextDate = this.incrementDate(nextDate, true);
|
|
|
102 |
}
|
|
|
103 |
while (count < 42) {
|
|
|
104 |
this.createDayContents(currentCalendarNode, nextDate);
|
|
|
105 |
dojo.html.setClass(currentCalendarNode, this.getDateClassName(nextDate, "next"));
|
|
|
106 |
currentCalendarNode = calendarNodes.item(++count);
|
|
|
107 |
previousDate = nextDate;
|
|
|
108 |
nextDate = this.incrementDate(nextDate, true);
|
|
|
109 |
}
|
|
|
110 |
this.setMonthLabel(this.firstSaturday.month);
|
|
|
111 |
this.setYearLabels(this.firstSaturday.year);
|
|
|
112 |
}});
|
|
|
113 |
dojo.widget.MonthlyCalendar.util = new function () {
|
|
|
114 |
this.toRfcDate = function (jsDate) {
|
|
|
115 |
if (!jsDate) {
|
|
|
116 |
jsDate = this.today;
|
|
|
117 |
}
|
|
|
118 |
var year = jsDate.getFullYear();
|
|
|
119 |
var month = jsDate.getMonth() + 1;
|
|
|
120 |
if (month < 10) {
|
|
|
121 |
month = "0" + month.toString();
|
|
|
122 |
}
|
|
|
123 |
var date = jsDate.getDate();
|
|
|
124 |
if (date < 10) {
|
|
|
125 |
date = "0" + date.toString();
|
|
|
126 |
}
|
|
|
127 |
return year + "-" + month + "-" + date + "T00:00:00+00:00";
|
|
|
128 |
};
|
|
|
129 |
this.fromRfcDate = function (rfcDate) {
|
|
|
130 |
var tempDate = rfcDate.split("-");
|
|
|
131 |
if (tempDate.length < 3) {
|
|
|
132 |
return new Date();
|
|
|
133 |
}
|
|
|
134 |
return new Date(parseInt(tempDate[0]), (parseInt(tempDate[1], 10) - 1), parseInt(tempDate[2].substr(0, 2), 10));
|
|
|
135 |
};
|
|
|
136 |
this.initFirstSaturday = function (month, year) {
|
|
|
137 |
if (!month) {
|
|
|
138 |
month = this.date.getMonth();
|
|
|
139 |
}
|
|
|
140 |
if (!year) {
|
|
|
141 |
year = this.date.getFullYear();
|
|
|
142 |
}
|
|
|
143 |
var firstOfMonth = new Date(year, month, 1);
|
|
|
144 |
return {year:year, month:month, date:7 - firstOfMonth.getDay()};
|
|
|
145 |
};
|
|
|
146 |
};
|
|
|
147 |
|