1 | var viewType; |
---|
2 | var todayDate = new Date(); |
---|
3 | |
---|
4 | function Calendar() |
---|
5 | { |
---|
6 | this.idEl; |
---|
7 | this.lastId; |
---|
8 | this.colorCellSelected = "LIGHTYELLOW"; |
---|
9 | this.nextView; |
---|
10 | this.previousView; |
---|
11 | } |
---|
12 | |
---|
13 | Calendar.prototype.dialog = function() { |
---|
14 | var divAddDialog = document.getElementById("divAddDialog"); |
---|
15 | if (_dragArea.initEvent > _dragArea.endEvent){ |
---|
16 | var temp = _dragArea.initEvent; |
---|
17 | _dragArea.initEvent = _dragArea.endEvent; |
---|
18 | _dragArea.endEvent = temp; |
---|
19 | } |
---|
20 | |
---|
21 | |
---|
22 | if(divAddDialog && divAddDialog.style.display != "none"){ |
---|
23 | divAddDialog.style.display = "none"; |
---|
24 | for (var hour = parseInt(_dragArea.initEvent); hour <= parseInt(_dragArea.endEvent);(hour%100 == 30)?hour+=70:hour+=30) |
---|
25 | document.getElementById(hour).style.background = ""; |
---|
26 | _dragArea.initEvent = null; |
---|
27 | _dragArea.endEvent = null; |
---|
28 | try { |
---|
29 | document.getElementById("div_main").style.opacity = 1; |
---|
30 | document.getElementById("div_main").filters.alpha.opacity=100; |
---|
31 | } catch (e) { } |
---|
32 | return true; |
---|
33 | } |
---|
34 | |
---|
35 | var cell = document.getElementById(_dragArea.endEvent); |
---|
36 | try { |
---|
37 | document.getElementById("div_main").style.opacity = 0.5; |
---|
38 | document.getElementById("div_main").filters.alpha.opacity=50; |
---|
39 | } catch (e) {}; |
---|
40 | |
---|
41 | var data = '<text><date>'+calendar.parseDate(id2timeStamp(_dragArea.initEvent))+'</date><time>'+ calendar.parseTime(_dragArea.initEvent,_dragArea.endEvent)+'</time></text>'; |
---|
42 | var xsl = XMLTools.load('xsl/addDialog.xsl?'+ Date.parse(new Date)); |
---|
43 | |
---|
44 | if(!divAddDialog) { |
---|
45 | divAddDialog = document.createElement("DIV"); |
---|
46 | divAddDialog.id = 'divAddDialog'; |
---|
47 | divAddDialog.style.zIndex = "10"; |
---|
48 | divAddDialog.style.position = "absolute"; |
---|
49 | divAddDialog.style.display = "none"; |
---|
50 | document.body.appendChild(divAddDialog); |
---|
51 | } |
---|
52 | divAddDialog.style.left = "300px"; //cell.offsetLeft + document.body.scrollLeft; |
---|
53 | divAddDialog.style.top = "200px"; //cell.offsetTop - 100 + document.getElementById('div_main').offsetTop; |
---|
54 | var elData = XMLTools.ParseXmlXsl(data, xsl); |
---|
55 | divAddDialog.style.display = "block"; |
---|
56 | divAddDialog.innerHTML = elData.innerHTML; |
---|
57 | document.getElementById('dragEventSubject').focus(); |
---|
58 | document.getElementById('addEventLink').innerHTML = get_lang("Add this event"); |
---|
59 | |
---|
60 | var closeButton = document.getElementById('closeDialog'); |
---|
61 | if (is_ie){ |
---|
62 | closeButton.style.left = '285px'; |
---|
63 | closeButton.style.top = '5px'; |
---|
64 | }else{ |
---|
65 | closeButton.style.left = '320px'; |
---|
66 | closeButton.style.top = '25px'; |
---|
67 | } |
---|
68 | |
---|
69 | this.lastId = _dragArea.endEvent; |
---|
70 | |
---|
71 | } |
---|
72 | Calendar.prototype.getView = function(idEl, type, data) |
---|
73 | { |
---|
74 | this.idEl = idEl; |
---|
75 | var _this = this; |
---|
76 | this.lastId = null; |
---|
77 | |
---|
78 | var handler_getView = function(XMLdata) |
---|
79 | { |
---|
80 | |
---|
81 | try { |
---|
82 | _this.parseView(XMLdata,type); |
---|
83 | |
---|
84 | if (viewType == "Week"){ |
---|
85 | var previousWeek = new Date; |
---|
86 | previousWeek.setTime(id2timeStamp(document.getElementById('day').firstChild.id)-(60*60*24*7*1000)); |
---|
87 | this.previousView = previousWeek.getYear()+1900+""+(previousWeek.getDate()<10?"0":"")+previousWeek.getDate()+""+(previousWeek.getMonth()+1<10?"0":"")+(previousWeek.getMonth()+1); |
---|
88 | var nextWeek = new Date; |
---|
89 | nextWeek.setTime(id2timeStamp(document.getElementById('day').firstChild.id)); |
---|
90 | nextWeek.setDate(nextWeek.getDate()+7); |
---|
91 | this.nextView = nextWeek.getYear()+1900+""+(nextWeek.getDate()<10?"0":"")+nextWeek.getDate()+""+(nextWeek.getMonth()+1<10?"0":"")+(nextWeek.getMonth()+1); |
---|
92 | } |
---|
93 | if (viewType == "Day"){ |
---|
94 | var previousDay = new Date; |
---|
95 | previousDay.setTime(id2timeStamp(document.getElementById('day').firstChild.id)-(60*60*24*1000)); |
---|
96 | this.previousView = previousDay.getYear()+1900+""+(previousDay.getDate()<10?"0":"")+previousDay.getDate()+""+(previousDay.getMonth()+1<10?"0":"")+(previousDay.getMonth()+1); |
---|
97 | var nextDay = new Date; |
---|
98 | nextDay.setTime(id2timeStamp(document.getElementById('day').firstChild.id)+(60*60*24*1000)); |
---|
99 | this.nextView = nextDay.getYear()+1900+""+(nextDay.getDate()<10?"0":"")+nextDay.getDate()+""+(nextDay.getMonth()+1<10?"0":"")+(nextDay.getMonth()+1); |
---|
100 | } |
---|
101 | if (viewType == 'Month'){ |
---|
102 | var previousMonth = new Date; |
---|
103 | previousMonth.setTime(id2timeStamp(document.getElementById('day').firstChild.id)); |
---|
104 | previousMonth.setMonth(previousMonth.getMonth()-1); |
---|
105 | this.previousView = previousMonth.getYear()+1900+""+(previousMonth.getDate()<10?"0":"")+previousMonth.getDate()+""+(previousMonth.getMonth()+1<10?"0":"")+(previousMonth.getMonth()+1); |
---|
106 | var nextMonth = new Date; |
---|
107 | nextMonth.setTime(id2timeStamp(document.getElementById('day').firstChild.id)); |
---|
108 | nextMonth.setMonth(nextMonth.getMonth()+1); |
---|
109 | this.nextView = nextMonth.getYear()+1900+""+(nextMonth.getDate()<10?"0":"")+nextMonth.getDate()+""+(nextMonth.getMonth()+1<10?"0":"")+(nextMonth.getMonth()+1); |
---|
110 | } |
---|
111 | document.getElementById("l_date").innerHTML = "<a href=\"javascript:calendar.getView('div_main','"+viewType+"','&time='+this.previousView);\">\<\< </a>"; |
---|
112 | if (viewType == "Week") |
---|
113 | document.getElementById("l_date").innerHTML += calendar.parseWeek(id2timeStamp(document.getElementById('day').firstChild.id)); |
---|
114 | if (viewType == "Day") |
---|
115 | document.getElementById("l_date").innerHTML += calendar.parseDate(id2timeStamp(document.getElementById('day').firstChild.id)); |
---|
116 | if (viewType == "Month") |
---|
117 | document.getElementById("l_date").innerHTML += calendar.parseMonth(id2timeStamp(document.getElementById('day').firstChild.id)); |
---|
118 | document.getElementById("l_date").innerHTML += "<a href=\"javascript:calendar.getView('div_main','"+viewType+"','&time='+this.nextView);\"> \>\></a>"; |
---|
119 | |
---|
120 | }catch(e){ alert(e+"\n"+e.description); } |
---|
121 | var events = document.getElementById('returnEvents'); |
---|
122 | while(typeof(events.firstChild.id) == 'string'){ |
---|
123 | createEventDiv(events.firstChild); |
---|
124 | } |
---|
125 | |
---|
126 | }; |
---|
127 | |
---|
128 | XMLTools.__RETURN_MODE__ = 'XML'; |
---|
129 | viewType = type; |
---|
130 | screenTable = new Array(); |
---|
131 | XMLTools.request('$this.uicalendar.getView'+type+(data?data:''), 'GET', handler_getView); |
---|
132 | }; |
---|
133 | |
---|
134 | |
---|
135 | Calendar.prototype.parseView = function(data,type) |
---|
136 | { |
---|
137 | var _this = this; |
---|
138 | try { |
---|
139 | var xsl = XMLTools.load('xsl/view'+type+'.xsl?'+ Date.parse(new Date)); |
---|
140 | var div = document.getElementById(this.idEl); |
---|
141 | div.innerHTML = XMLTools.transform(data, xsl); |
---|
142 | } |
---|
143 | catch(e){ |
---|
144 | alert(e); |
---|
145 | } |
---|
146 | |
---|
147 | if (type == 'Week' || type == 'Month'){ |
---|
148 | var trWeek = document.getElementById('tr_week'); |
---|
149 | for (var i=0; i < trWeek.childNodes.length; i++) |
---|
150 | trWeek.childNodes[i].innerHTML = get_lang(trWeek.childNodes[i].innerHTML); |
---|
151 | } |
---|
152 | }; |
---|
153 | |
---|
154 | |
---|
155 | Calendar.prototype.parseTime = function (first, last) { |
---|
156 | |
---|
157 | var hour = first.substring(8,10); |
---|
158 | var minute = first.substring(10,12); |
---|
159 | var startHour = hour+":"+minute; |
---|
160 | |
---|
161 | if(last && first != last) { |
---|
162 | hour = last.substring(8,10); |
---|
163 | minute = last.substring(10,12); |
---|
164 | } |
---|
165 | |
---|
166 | if(minute == "30") { |
---|
167 | hour = parseInt(hour,10); |
---|
168 | hour = (hour < 9 ? "0" : "")+(hour+1); |
---|
169 | minute = "00"; |
---|
170 | } |
---|
171 | else { |
---|
172 | minute = "30"; |
---|
173 | } |
---|
174 | |
---|
175 | return startHour+ " - "+ hour+":"+minute; |
---|
176 | } |
---|
177 | Calendar.prototype.parseWeek = function (timeStamp) { |
---|
178 | dateObj=new Date(); |
---|
179 | dateObj.setTime(timeStamp); |
---|
180 | Year=dateObj.getYear(); |
---|
181 | if (Year < 70) { Year=Year*1+2000; } |
---|
182 | if (Year < 1900) { Year=Year*1+1900; } |
---|
183 | Then=new Date(Year, 0, 1); |
---|
184 | Then_Day=Then.getDay(); |
---|
185 | Diff=dateObj*1-Then*1; |
---|
186 | Days=Math.floor(Diff/(1000*60*60*24)+(1/24)); |
---|
187 | Week=Math.floor((Days+Then_Day)/7)+1; |
---|
188 | return get_lang("Week Number %1 of %2",Week,Year); |
---|
189 | } |
---|
190 | Calendar.prototype.parseMonth = function (timeStamp) { |
---|
191 | obj=new Date(); |
---|
192 | obj.setTime(timeStamp); |
---|
193 | switch(obj.getMonth()) { |
---|
194 | case 0: month = "January"; break; |
---|
195 | case 1: month = "February"; break; |
---|
196 | case 2: month = "March"; break; |
---|
197 | case 3: month = "April"; break; |
---|
198 | case 4: month = "May"; break; |
---|
199 | case 5: month = "June"; break; |
---|
200 | case 6: month = "July"; break; |
---|
201 | case 7: month = "August"; break; |
---|
202 | case 8: month = "September"; break; |
---|
203 | case 9: month = "October"; break; |
---|
204 | case 10: month = "November"; break; |
---|
205 | case 11: month = "December"; break; |
---|
206 | default: month = ""; break; |
---|
207 | } |
---|
208 | return get_lang(month); |
---|
209 | } |
---|
210 | Calendar.prototype.parseDate = function (timeStamp) { |
---|
211 | var obj = new Date(); |
---|
212 | obj.setTime(timeStamp); |
---|
213 | |
---|
214 | var day; |
---|
215 | switch(obj.getDay()) { |
---|
216 | case 0: day = "Sunday"; break; |
---|
217 | case 1: day = "Monday"; break; |
---|
218 | case 2: day = "Tuesday"; break; |
---|
219 | case 3: day = "Wednesday"; break; |
---|
220 | case 4: day = "Thursday"; break; |
---|
221 | case 5: day = "Friday"; break; |
---|
222 | case 6: day = "Saturday"; break; |
---|
223 | default: day = ""; break; |
---|
224 | } |
---|
225 | |
---|
226 | var month; |
---|
227 | switch(obj.getMonth()) { |
---|
228 | case 0: month = "January"; break; |
---|
229 | case 1: month = "February"; break; |
---|
230 | case 2: month = "March"; break; |
---|
231 | case 3: month = "April"; break; |
---|
232 | case 4: month = "May"; break; |
---|
233 | case 5: month = "June"; break; |
---|
234 | case 6: month = "July"; break; |
---|
235 | case 7: month = "August"; break; |
---|
236 | case 8: month = "September"; break; |
---|
237 | case 9: month = "October"; break; |
---|
238 | case 10: month = "November"; break; |
---|
239 | case 11: month = "December"; break; |
---|
240 | default: month = ""; break; |
---|
241 | } |
---|
242 | |
---|
243 | year = (is_ie?parseInt(obj.getYear()):parseInt(obj.getYear())+1900); |
---|
244 | |
---|
245 | return get_lang(day)+", "+obj.getDate()+" "+get_lang("of")+" "+get_lang(month)+" "+get_lang("of")+" "+year; // FIXME USE FORMAT DATE AS PREFERENCE |
---|
246 | } |
---|
247 | var calendar = new Calendar(); |
---|