2011-08-11 13:22:07 +04:00
|
|
|
/*************************************************
|
|
|
|
* ownCloud - Calendar Plugin *
|
|
|
|
* *
|
2011-08-31 22:20:46 +04:00
|
|
|
* (c) Copyright 2011 Georg Ehrke *
|
2011-08-11 13:22:07 +04:00
|
|
|
* author: Georg Ehrke *
|
|
|
|
* email: ownclouddev at georgswebsite dot de *
|
|
|
|
* homepage: ownclouddev.georgswebsite.de *
|
|
|
|
* manual: ownclouddev.georgswebsite.de/manual *
|
2011-08-12 16:29:45 +04:00
|
|
|
* License: GNU AFFERO GENERAL PUBLIC LICENSE *
|
2011-08-11 13:22:07 +04:00
|
|
|
* *
|
2011-08-12 16:29:45 +04:00
|
|
|
* <http://www.gnu.org/licenses/> *
|
2011-08-11 13:22:07 +04:00
|
|
|
* If you are not able to view the License, *
|
|
|
|
* <http://www.gnu.org/licenses/> *
|
|
|
|
* <http://ownclouddev.georgswebsite.de/license/> *
|
|
|
|
* please write to the Free Software Foundation. *
|
|
|
|
* Address: *
|
|
|
|
* 59 Temple Place, Suite 330, Boston, *
|
|
|
|
* MA 02111-1307 USA *
|
|
|
|
**************************************************
|
|
|
|
* list of all fx *
|
|
|
|
* calw - Calendarweek *
|
|
|
|
* doy - Day of the year *
|
|
|
|
* checkforleapyear - check for a leap year *
|
|
|
|
* forward_day - switching one day forward *
|
|
|
|
* forward_week - switching one week forward *
|
|
|
|
* forward_month - switching one month forward *
|
|
|
|
* backward_day - switching one day backward *
|
|
|
|
* backward_week - switching one week backward *
|
|
|
|
* backward_month - switching one month backward *
|
2011-08-31 17:59:22 +04:00
|
|
|
* update_view - update the view of the calendar *
|
|
|
|
* onedayview - one day view *
|
|
|
|
* oneweekview - one week view *
|
2011-09-02 18:44:25 +04:00
|
|
|
* fourweekview - four Weeks view *
|
2011-08-31 17:59:22 +04:00
|
|
|
* onemonthview - one Month view *
|
|
|
|
* listview - listview *
|
2011-08-11 13:22:07 +04:00
|
|
|
* generate_monthview - generating month view *
|
|
|
|
* generate_dates - generate other days for view *
|
|
|
|
* switch2today - switching to today *
|
2011-09-01 17:15:38 +04:00
|
|
|
* removeEvents - remove old events in view *
|
|
|
|
* loadEvents - load the events *
|
2011-08-11 13:22:07 +04:00
|
|
|
*************************************************/
|
2011-08-31 17:59:22 +04:00
|
|
|
Calendar={
|
|
|
|
Date:{
|
2011-08-31 18:31:33 +04:00
|
|
|
normal_year_cal: [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],
|
|
|
|
leap_year_cal: [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],
|
2011-08-31 17:59:22 +04:00
|
|
|
calw:function() {
|
|
|
|
var generate_dayofweek = oc_cal_dayofweek;
|
|
|
|
if(generate_dayofweek == 0) {
|
|
|
|
generate_dayofweek = 7;
|
|
|
|
}
|
|
|
|
var calw = Math.floor((this.doy() - generate_dayofweek) / 7) + 1;
|
|
|
|
return calw;
|
|
|
|
},
|
2011-08-11 13:22:07 +04:00
|
|
|
|
2011-08-31 17:59:22 +04:00
|
|
|
doy:function() {
|
2011-08-31 18:31:33 +04:00
|
|
|
var cal = this.getnumberofdays(oc_cal_year);
|
2011-08-31 17:59:22 +04:00
|
|
|
var doy = 0;
|
|
|
|
for(var i = 0; i < oc_cal_month; i++) {
|
|
|
|
doy = doy + parseInt(cal[i]);
|
|
|
|
}
|
|
|
|
doy = doy + parseInt(oc_cal_dayofmonth);
|
|
|
|
return doy;
|
|
|
|
},
|
2011-08-11 13:22:07 +04:00
|
|
|
|
2011-08-31 18:31:33 +04:00
|
|
|
getnumberofdays:function(year) {
|
|
|
|
if(this.checkforleapyear(year) == true) {
|
|
|
|
var cal = this.leap_year_cal;
|
|
|
|
} else {
|
|
|
|
var cal = this.normal_year_cal;
|
|
|
|
}
|
|
|
|
return cal;
|
|
|
|
},
|
|
|
|
|
2011-08-31 17:59:22 +04:00
|
|
|
checkforleapyear:function(year2check) {
|
|
|
|
if((year2check / 600) == Math.floor(year2check / 400)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if((year2check / 4) == Math.floor(year2check / 4)) {
|
|
|
|
if((year2check / 100) == Math.floor(year2check / 100)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2011-08-11 13:22:07 +04:00
|
|
|
return false;
|
2011-08-31 17:59:22 +04:00
|
|
|
},
|
|
|
|
|
|
|
|
forward_day:function(){
|
2011-08-31 18:31:33 +04:00
|
|
|
var cal = this.getnumberofdays(oc_cal_year);
|
2011-08-31 17:59:22 +04:00
|
|
|
if(oc_cal_dayofmonth == cal[oc_cal_month]) {
|
|
|
|
if(oc_cal_month == 11) {
|
|
|
|
oc_cal_year++;
|
|
|
|
oc_cal_month = 0;
|
|
|
|
oc_cal_dayofmonth = 1;
|
|
|
|
} else {
|
|
|
|
oc_cal_month++;
|
|
|
|
oc_cal_dayofmonth = 1;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
oc_cal_dayofmonth++;
|
2011-09-02 00:29:57 +04:00
|
|
|
}
|
|
|
|
if(oc_cal_dayofweek == 6) {
|
|
|
|
oc_cal_dayofweek = 0;
|
|
|
|
} else {
|
|
|
|
oc_cal_dayofweek++;
|
2011-08-31 17:59:22 +04:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
forward_week:function(){
|
|
|
|
for(var i = 1; i <= 7; i++) {
|
|
|
|
this.forward_day();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
forward_month:function(){
|
2011-08-31 18:31:33 +04:00
|
|
|
var cal = this.getnumberofdays(oc_cal_year);
|
2011-08-31 17:59:22 +04:00
|
|
|
for(var i = 1; i <= cal[oc_cal_month]; i++) {
|
|
|
|
this.forward_day();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
backward_day:function(){
|
2011-08-31 18:31:33 +04:00
|
|
|
var cal = this.getnumberofdays(oc_cal_year);
|
2011-08-31 17:59:22 +04:00
|
|
|
if(oc_cal_dayofmonth == 1) {
|
|
|
|
if(oc_cal_month == 0) {
|
|
|
|
oc_cal_year--;
|
|
|
|
oc_cal_month = 11;
|
|
|
|
oc_cal_dayofmonth = 31
|
|
|
|
} else {
|
|
|
|
oc_cal_month--;
|
|
|
|
oc_cal_dayofmonth = cal[oc_cal_month];
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
oc_cal_dayofmonth--;
|
2011-09-02 00:29:57 +04:00
|
|
|
}
|
|
|
|
if(oc_cal_dayofweek == 0) {
|
|
|
|
oc_cal_dayofweek = 6;
|
|
|
|
} else {
|
|
|
|
oc_cal_dayofweek--;
|
2011-08-31 17:59:22 +04:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
backward_week:function(){
|
|
|
|
for(var i = 1; i <= 7; i++) {
|
|
|
|
this.backward_day();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
backward_month:function(){
|
2011-08-31 18:31:33 +04:00
|
|
|
var cal = this.getnumberofdays(oc_cal_year);
|
2011-08-31 17:59:22 +04:00
|
|
|
for(var i = cal[oc_cal_month]; i >= 1; i--) {
|
|
|
|
this.backward_day();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
UI:{
|
|
|
|
weekdays: ["monday", "tuesday", "wednesday", "thursday", "friday", "saturday", "sunday"],
|
2011-09-02 01:27:00 +04:00
|
|
|
updateView:function(task) {
|
2011-09-01 17:15:38 +04:00
|
|
|
this.current.removeEvents();
|
|
|
|
this.current.renderCal();
|
2011-09-02 01:27:00 +04:00
|
|
|
this.current.showEvents();
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
setCurrentView:function(view){
|
2011-09-02 01:27:00 +04:00
|
|
|
if (view == oc_cal_currentview){
|
|
|
|
return;
|
|
|
|
}
|
2011-09-03 01:51:18 +04:00
|
|
|
$('#'+oc_cal_currentview).hide();
|
|
|
|
$('#'+oc_cal_currentview + "_radio").removeClass('active');
|
2011-09-02 01:27:00 +04:00
|
|
|
oc_cal_currentview = view;
|
2011-09-02 12:14:56 +04:00
|
|
|
//sending ajax request on every change view
|
2011-09-02 01:27:00 +04:00
|
|
|
$("#sysbox").load(oc_webroot + "/apps/calendar/ajax/changeview.php?v="+view);
|
|
|
|
//not necessary to check whether the response is true or not
|
2011-09-01 17:15:38 +04:00
|
|
|
switch(view) {
|
|
|
|
case "onedayview":
|
|
|
|
this.current = Calendar.UI.OneDay;
|
|
|
|
break;
|
|
|
|
case "oneweekview":
|
|
|
|
this.current = Calendar.UI.OneWeek;
|
|
|
|
break;
|
|
|
|
case "fourweeksview":
|
|
|
|
this.current = Calendar.UI.FourWeeks;
|
|
|
|
break;
|
|
|
|
case "onemonthview":
|
|
|
|
this.current = Calendar.UI.OneMonth;
|
|
|
|
break;
|
|
|
|
case "listview":
|
|
|
|
this.current = Calendar.UI.List;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
2011-08-11 13:22:07 +04:00
|
|
|
}
|
2011-09-03 01:51:18 +04:00
|
|
|
$('#'+oc_cal_currentview).show();
|
|
|
|
$('#'+oc_cal_currentview + "_radio").addClass('active');
|
2011-09-02 12:14:56 +04:00
|
|
|
this.updateView();
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
updateDate:function(direction){
|
|
|
|
if(direction == "forward") {
|
|
|
|
this.current.forward();
|
2011-09-02 01:27:00 +04:00
|
|
|
if(oc_cal_month == 11){
|
|
|
|
this.loadEvents(oc_cal_year + 1);
|
|
|
|
}
|
2011-09-02 12:14:56 +04:00
|
|
|
Calendar.UI.updateView();
|
2011-08-11 13:22:07 +04:00
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
if(direction == "backward") {
|
|
|
|
this.current.backward();
|
2011-09-02 01:27:00 +04:00
|
|
|
if(oc_cal_month == 0){
|
|
|
|
this.loadEvents(oc_cal_year - 1);
|
|
|
|
}
|
2011-09-02 12:14:56 +04:00
|
|
|
Calendar.UI.updateView();
|
2011-08-11 13:22:07 +04:00
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
2011-09-02 01:27:00 +04:00
|
|
|
loadEvents:function(year){
|
|
|
|
$.getJSON(oc_webroot + "/apps/calendar/ajax/getcal.php?year=" + year, function(newevents, status) {
|
|
|
|
if(status == "nosession") {
|
|
|
|
alert("You are not logged in. That can happen if you don't use owncloud for a long time.");
|
|
|
|
document.location(oc_webroot);
|
|
|
|
}
|
|
|
|
if(status == "parsingfail" || typeof (newevents) == "undefined") {
|
|
|
|
$.ready(function() {
|
|
|
|
$( "#parsingfail_dialog" ).dialog();
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
oc_cal_events[year] = newevents[year];
|
|
|
|
//$.ready(function() {
|
|
|
|
Calendar.UI.updateView();
|
|
|
|
//});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
2011-09-01 17:15:38 +04:00
|
|
|
createEventsForDate:function(date, week, weekday){
|
|
|
|
var day = date[0];
|
|
|
|
var month = date[1];
|
|
|
|
var year = date[2];
|
|
|
|
if( typeof (oc_cal_events[year]) == "undefined") {
|
|
|
|
return;
|
2011-08-11 13:22:07 +04:00
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
if( typeof (oc_cal_events[year][month]) == "undefined") {
|
|
|
|
return;
|
2011-08-11 13:22:07 +04:00
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
if( typeof (oc_cal_events[year][month][day]) == "undefined") {
|
|
|
|
return;
|
2011-08-11 13:22:07 +04:00
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
events = oc_cal_events[year][month][day];
|
|
|
|
if( typeof (events["allday"]) != "undefined") {
|
|
|
|
var eventnumber = 1;
|
|
|
|
var eventcontainer = this.current.getEventContainer(week, weekday, "allday");
|
|
|
|
while( typeof (events["allday"][eventnumber]) != "undefined") {
|
2011-09-03 16:05:20 +04:00
|
|
|
this.addEventLabel(eventcontainer, events['allday'][eventnumber]);
|
2011-09-01 17:15:38 +04:00
|
|
|
eventnumber++;
|
|
|
|
}
|
2011-08-11 13:22:07 +04:00
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
for(var time = 0; time <= 23; time++) {
|
|
|
|
if( typeof (events[time]) != "undefined") {
|
|
|
|
var eventnumber = 1;
|
|
|
|
var eventcontainer = this.current.getEventContainer(week, weekday, time);
|
|
|
|
while( typeof (events[time][eventnumber]) != "undefined") {
|
2011-09-03 16:05:20 +04:00
|
|
|
this.addEventLabel(eventcontainer, events[time][eventnumber]);
|
2011-09-01 17:15:38 +04:00
|
|
|
eventnumber++;
|
|
|
|
}
|
|
|
|
}
|
2011-08-11 13:22:07 +04:00
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
2011-09-03 16:05:20 +04:00
|
|
|
addEventLabel:function(eventcontainer, event){
|
|
|
|
var event_holder = this.current.createEventLabel(event)
|
|
|
|
.addClass('event')
|
2011-09-04 00:13:14 +04:00
|
|
|
.data('event_info', event)
|
|
|
|
.hover(this.createEventPopup,
|
|
|
|
this.hideEventPopup);
|
2011-09-03 16:05:20 +04:00
|
|
|
eventcontainer.append(event_holder);
|
|
|
|
},
|
2011-09-04 00:13:14 +04:00
|
|
|
createEventPopup:function(e){
|
|
|
|
var event = $(this).data('event_info');
|
|
|
|
var popup = $(this).data('popup');
|
|
|
|
if (!popup){
|
|
|
|
popup = $(document.createElement('div'));
|
|
|
|
$(this).data('popup', popup).append(popup);
|
|
|
|
popup.addClass('event_popup')
|
|
|
|
.html(Calendar.UI.getEventPopupText(event));
|
|
|
|
}
|
|
|
|
popup.css('left', -(popup.width() - $(this).width())/2)
|
|
|
|
.show();
|
|
|
|
},
|
|
|
|
hideEventPopup:function(){
|
|
|
|
$(this).data('popup').hide();
|
|
|
|
},
|
|
|
|
getEventPopupText:function(event){
|
|
|
|
var startdate = this.formatDate(event.startdate)
|
|
|
|
var starttime = this.formatTime(event.startdate)
|
|
|
|
var enddate = this.formatDate(event.enddate)
|
|
|
|
var endtime = this.formatTime(event.enddate)
|
|
|
|
if (event.allday){
|
|
|
|
var timespan = startdate;
|
|
|
|
if (event.startdate[2] != parseInt(event.enddate[2])-1){
|
|
|
|
timespan += ' - ' + enddate;
|
|
|
|
}
|
|
|
|
}else{
|
|
|
|
var start = startdate + ' ' + starttime;
|
|
|
|
if (startdate == enddate){
|
|
|
|
var end = endtime;
|
|
|
|
}else{
|
|
|
|
var end = enddate + ' ' + endtime;
|
|
|
|
}
|
|
|
|
var timespan = start + ' - ' + end;
|
|
|
|
}
|
|
|
|
return '<span class="timespan">' + timespan + '</span>'
|
|
|
|
+ ' '
|
|
|
|
+ '<span class="summary">' + event.description + '</span>';
|
|
|
|
},
|
|
|
|
formatDate:function(date){
|
|
|
|
return date[0] + '-' + date[1] + '-' + date[2];
|
|
|
|
},
|
|
|
|
formatTime:function(date){
|
|
|
|
return date[3] + ':' + date[4];
|
|
|
|
},
|
2011-09-01 17:15:38 +04:00
|
|
|
OneDay:{
|
|
|
|
forward:function(){
|
2011-08-31 17:59:22 +04:00
|
|
|
Calendar.Date.forward_day();
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
backward:function(){
|
2011-08-31 17:59:22 +04:00
|
|
|
Calendar.Date.backward_day();
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
removeEvents:function(){
|
2011-09-02 18:44:25 +04:00
|
|
|
$("#onedayview .calendar_row").html("");
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
renderCal:function(){
|
|
|
|
$("#datecontrol_date").val(oc_cal_dayshort[oc_cal_dayofweek] + oc_cal_space + oc_cal_dayofmonth + oc_cal_space + oc_cal_monthshort[oc_cal_month] + oc_cal_space + oc_cal_year);
|
|
|
|
$("#onedayview_today").html(oc_cal_daylong[oc_cal_dayofweek] + oc_cal_space + oc_cal_dayofmonth + oc_cal_space + oc_cal_monthshort[oc_cal_month]);
|
|
|
|
var generate_dayofmonth = oc_cal_dayofmonth;
|
|
|
|
var generate_month = oc_cal_month;
|
|
|
|
var generate_year = oc_cal_year;
|
|
|
|
if(parseInt(generate_dayofmonth) <= 9){
|
|
|
|
generate_dayofmonth = "0" + generate_dayofmonth;
|
|
|
|
}
|
|
|
|
generate_month++;
|
|
|
|
if(parseInt(generate_month) <= 9){
|
|
|
|
generate_month = "0" + generate_month;
|
|
|
|
}
|
|
|
|
var generate_title = String(generate_dayofmonth) + String(generate_month) + String(generate_year);
|
|
|
|
$('#onedayview_today').attr('title', generate_title);
|
|
|
|
},
|
2011-09-02 01:27:00 +04:00
|
|
|
showEvents:function(){
|
2011-09-01 17:15:38 +04:00
|
|
|
Calendar.UI.createEventsForDate([oc_cal_dayofmonth, oc_cal_month, oc_cal_year], 0, 0);
|
|
|
|
},
|
|
|
|
getEventContainer:function(week, weekday, when){
|
2011-09-02 18:44:25 +04:00
|
|
|
return $("#onedayview ." + when);
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
2011-09-03 16:05:20 +04:00
|
|
|
createEventLabel:function(event){
|
|
|
|
var time = '';
|
|
|
|
if (!event['allday']){
|
2011-09-04 00:13:14 +04:00
|
|
|
time = '<strong>' + Calendar.UI.formatTime(event['startdate']) + ' - ' + Calendar.UI.formatTime(event['enddate']) + '</strong> ';
|
2011-09-03 16:05:20 +04:00
|
|
|
}
|
|
|
|
return $(document.createElement('p'))
|
|
|
|
.html(time + event['description'])
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
},
|
|
|
|
OneWeek:{
|
|
|
|
forward:function(){
|
|
|
|
Calendar.Date.forward_week();
|
|
|
|
},
|
|
|
|
backward:function(){
|
|
|
|
Calendar.Date.backward_week();
|
|
|
|
},
|
|
|
|
removeEvents:function(){
|
|
|
|
for( i = 0; i <= 6; i++) {
|
2011-09-02 18:44:25 +04:00
|
|
|
$("#oneweekview ." + Calendar.UI.weekdays[i]).html("");
|
2011-09-01 17:15:38 +04:00
|
|
|
}
|
2011-09-02 18:44:25 +04:00
|
|
|
$("#oneweekview .thisday").removeClass("thisday");
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
renderCal:function(){
|
|
|
|
$("#datecontrol_date").val(cw_label + ": " + Calendar.Date.calw());
|
2011-09-02 00:31:25 +04:00
|
|
|
var dates = this.generateDates();
|
2011-09-01 17:15:38 +04:00
|
|
|
var weekday = 1;
|
|
|
|
for(var i = 0; i <= 6; i++){
|
|
|
|
var generate_dayofmonth = String(dates[i][0]);
|
|
|
|
var generate_month = String(dates[i][1]);
|
2011-09-02 18:44:25 +04:00
|
|
|
var generate_year = String(dates[i][2]);
|
|
|
|
$("#oneweekview th." + Calendar.UI.weekdays[i]).html(oc_cal_dayshort[weekday] + oc_cal_space + dates[i][0] + oc_cal_space + oc_cal_monthshort[dates[i][1]]);
|
|
|
|
if(generate_dayofmonth == oc_cal_todaydayofmonth && generate_month == oc_cal_todaymonth && generate_year == oc_cal_todayyear){
|
|
|
|
$("#oneweekview ." + Calendar.UI.weekdays[i]).addClass("thisday");
|
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
if(parseInt(generate_dayofmonth) <= 9){
|
|
|
|
generate_dayofmonth = "0" + generate_dayofmonth;
|
|
|
|
}
|
|
|
|
generate_month++;
|
|
|
|
if(parseInt(generate_month) <= 9){
|
|
|
|
generate_month = "0" + generate_month;
|
|
|
|
}
|
|
|
|
var generate_title = String(generate_dayofmonth) + String(generate_month) + String(dates[i][2]);
|
2011-09-02 18:44:25 +04:00
|
|
|
$("#oneweekview th." + Calendar.UI.weekdays[i]).attr('title', generate_title);
|
2011-09-01 17:15:38 +04:00
|
|
|
if(weekday == 6){
|
|
|
|
weekday = 0;
|
|
|
|
}else{
|
|
|
|
weekday++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2011-09-02 01:27:00 +04:00
|
|
|
showEvents:function(){
|
2011-09-02 00:31:25 +04:00
|
|
|
var dates = this.generateDates();
|
2011-09-01 17:15:38 +04:00
|
|
|
for(var weekday = 0; weekday <= 6; weekday++) {
|
|
|
|
Calendar.UI.createEventsForDate(dates[weekday], 0, weekday);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
getEventContainer:function(week, weekday, when){
|
2011-09-02 18:44:25 +04:00
|
|
|
return $("#oneweekview ." + Calendar.UI.weekdays[weekday] + "." + when);
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
2011-09-03 16:05:20 +04:00
|
|
|
createEventLabel:function(event){
|
|
|
|
var time = '';
|
|
|
|
if (!event['allday']){
|
2011-09-04 00:13:14 +04:00
|
|
|
time = '<strong>' + Calendar.UI.formatTime(event['startdate']) + ' - ' + Calendar.UI.formatTime(event['enddate']) + '</strong> ';
|
2011-09-03 16:05:20 +04:00
|
|
|
}
|
|
|
|
return $(document.createElement('p'))
|
|
|
|
.html(time + event['description'])
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
2011-09-02 00:31:25 +04:00
|
|
|
generateDates:function(){
|
|
|
|
var dates = new Array();
|
2011-09-06 13:47:23 +04:00
|
|
|
var generate_date = new Date(oc_cal_year, oc_cal_month, oc_cal_dayofmonth);
|
|
|
|
var generate_dayofweek = generate_date.getDay();
|
2011-09-02 00:31:25 +04:00
|
|
|
if(generate_dayofweek == 0) {
|
|
|
|
generate_dayofweek = 7;
|
|
|
|
}
|
2011-09-06 13:47:23 +04:00
|
|
|
generate_date.setDate(generate_date.getDate() - generate_dayofweek + 1);
|
|
|
|
for(var i = 0; i <= 6; i++) {
|
|
|
|
dates[i] = new Array(generate_date.getDate(), generate_date.getMonth(), generate_date.getFullYear());
|
|
|
|
generate_date.setDate(generate_date.getDate() + 1);
|
2011-09-02 00:31:25 +04:00
|
|
|
}
|
|
|
|
return dates;
|
|
|
|
},
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
FourWeeks:{
|
|
|
|
forward:function(){
|
|
|
|
Calendar.Date.forward_week();
|
|
|
|
},
|
|
|
|
backward:function(){
|
|
|
|
Calendar.Date.backward_week();
|
|
|
|
},
|
|
|
|
removeEvents:function(){
|
2011-09-02 18:44:25 +04:00
|
|
|
$('#fourweeksview .day.thisday').removeClass('thisday');
|
|
|
|
$('#fourweeksview .day .events').html('');
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
renderCal:function(){
|
|
|
|
var calw1 = Calendar.Date.calw();
|
|
|
|
var calw2 = calw1 + 1;
|
|
|
|
var calw3 = calw1 + 2;
|
|
|
|
var calw4 = calw1 + 3;
|
|
|
|
switch(calw1) {
|
|
|
|
case 50:
|
|
|
|
calw4 = 1;
|
|
|
|
break;
|
|
|
|
case 51:
|
|
|
|
calw3 = 1;
|
|
|
|
calw4 = 2;
|
|
|
|
break;
|
|
|
|
case 52:
|
|
|
|
calw2 = 1;
|
|
|
|
calw3 = 2;
|
|
|
|
calw4 = 3;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
var calwplusfour = calw4;
|
2011-09-02 00:31:25 +04:00
|
|
|
var dates = this.generateDates();
|
2011-09-01 17:15:38 +04:00
|
|
|
var week = 1;
|
|
|
|
var weekday = 0;
|
|
|
|
for(var i = 0; i <= 27; i++){
|
|
|
|
var generate_dayofmonth = String(dates[i][0]);
|
|
|
|
var generate_month = String(dates[i][1]);
|
|
|
|
var generate_year = dates[i][2];
|
2011-09-02 18:44:25 +04:00
|
|
|
$("#fourweeksview .week_" + week + " ." + Calendar.UI.weekdays[weekday] + " .dateinfo").html(generate_dayofmonth + oc_cal_space + oc_cal_monthshort[generate_month]);
|
|
|
|
if(generate_dayofmonth == oc_cal_todaydayofmonth && generate_month == oc_cal_todaymonth && generate_year == oc_cal_todayyear){
|
|
|
|
$("#fourweeksview .week_" + week + " ." + Calendar.UI.weekdays[weekday]).addClass('thisday');
|
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
if(parseInt(generate_dayofmonth) <= 9){
|
|
|
|
generate_dayofmonth = "0" + generate_dayofmonth;
|
|
|
|
}
|
|
|
|
generate_month++;
|
|
|
|
if(parseInt(generate_month) <= 9){
|
|
|
|
generate_month = "0" + generate_month;
|
|
|
|
}
|
|
|
|
var generate_title = String(generate_dayofmonth) + String(generate_month) + String(dates[i][2]);
|
2011-09-02 18:44:25 +04:00
|
|
|
$("#fourweeksview ." + ".week_" + week + " ." + Calendar.UI.weekdays[weekday]).attr('title', generate_title);
|
2011-09-01 17:15:38 +04:00
|
|
|
if(weekday == 6){
|
|
|
|
weekday = 0;
|
|
|
|
week++;
|
|
|
|
}else{
|
|
|
|
weekday++;
|
|
|
|
}
|
|
|
|
}
|
2011-09-02 18:44:25 +04:00
|
|
|
$("#fourweeksview .week_1 .calw").html(calw1);
|
|
|
|
$("#fourweeksview .week_2 .calw").html(calw2);
|
|
|
|
$("#fourweeksview .week_3 .calw").html(calw3);
|
|
|
|
$("#fourweeksview .week_4 .calw").html(calw4);
|
2011-09-01 17:15:38 +04:00
|
|
|
$("#datecontrol_date").val(cws_label + ": " + Calendar.Date.calw() + " - " + calwplusfour);
|
|
|
|
},
|
2011-09-02 01:27:00 +04:00
|
|
|
showEvents:function(){
|
2011-09-02 00:31:25 +04:00
|
|
|
var dates = this.generateDates();
|
2011-09-01 17:15:38 +04:00
|
|
|
var weekdaynum = 0;
|
|
|
|
var weeknum = 1;
|
|
|
|
for(var i = 0; i <= 27; i++) {
|
|
|
|
Calendar.UI.createEventsForDate(dates[i], weeknum, weekdaynum);
|
|
|
|
if(weekdaynum == 6){
|
|
|
|
weekdaynum = 0;
|
|
|
|
weeknum++;
|
|
|
|
}else{
|
|
|
|
weekdaynum++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
getEventContainer:function(week, weekday, when){
|
2011-09-02 18:44:25 +04:00
|
|
|
return $("#fourweeksview .week_" + week + " .day." + Calendar.UI.weekdays[weekday] + " .events");
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
2011-09-03 16:05:20 +04:00
|
|
|
createEventLabel:function(event){
|
|
|
|
var time = '';
|
|
|
|
if (!event['allday']){
|
2011-09-04 00:13:14 +04:00
|
|
|
time = '<strong>' + Calendar.UI.formatTime(event['startdate']) + '</strong> ';
|
2011-09-03 16:05:20 +04:00
|
|
|
}
|
|
|
|
return $(document.createElement('p'))
|
|
|
|
.html(time + event['description'])
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
2011-09-02 00:31:25 +04:00
|
|
|
generateDates:function(){
|
|
|
|
var dates = new Array();
|
2011-09-06 13:47:23 +04:00
|
|
|
var generate_date = new Date(oc_cal_year, oc_cal_month, oc_cal_dayofmonth);
|
|
|
|
var generate_dayofweek = generate_date.getDay();
|
2011-09-02 00:31:25 +04:00
|
|
|
if(generate_dayofweek == 0) {
|
|
|
|
generate_dayofweek = 7;
|
|
|
|
}
|
2011-09-06 13:47:23 +04:00
|
|
|
generate_date.setDate(generate_date.getDate() - generate_dayofweek + 1);
|
|
|
|
for(var i = 0; i <= 27; i++) {
|
|
|
|
dates[i] = new Array(generate_date.getDate(), generate_date.getMonth(), generate_date.getFullYear());
|
|
|
|
generate_date.setDate(generate_date.getDate() + 1);
|
2011-09-02 00:31:25 +04:00
|
|
|
}
|
|
|
|
return dates;
|
|
|
|
},
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
OneMonth:{
|
|
|
|
forward:function(){
|
|
|
|
Calendar.Date.forward_month();
|
|
|
|
},
|
|
|
|
backward:function(){
|
|
|
|
Calendar.Date.backward_month();
|
|
|
|
},
|
|
|
|
removeEvents:function(){
|
2011-09-02 18:44:25 +04:00
|
|
|
$('#onemonthview .day.thisday').removeClass('thisday');
|
|
|
|
$('#onemonthview .day .events').html('');
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
renderCal:function(){
|
|
|
|
$("#datecontrol_date").val(oc_cal_monthlong[oc_cal_month] + oc_cal_space + oc_cal_year);
|
|
|
|
var cal = Calendar.Date.getnumberofdays(oc_cal_year);
|
|
|
|
var monthview_dayofweek = oc_cal_dayofweek;
|
|
|
|
var monthview_dayofmonth = oc_cal_dayofmonth;
|
|
|
|
for(var i = monthview_dayofmonth; i > 1; i--) {
|
|
|
|
if(monthview_dayofweek == 0) {
|
|
|
|
monthview_dayofweek = 6;
|
|
|
|
} else {
|
|
|
|
monthview_dayofweek--;
|
|
|
|
}
|
|
|
|
}
|
2011-09-03 01:51:18 +04:00
|
|
|
$("#onemonthview .week_5").hide();
|
|
|
|
$("#onemonthview .week_6").hide();
|
2011-09-01 17:15:38 +04:00
|
|
|
oc_cal_rows = parseInt(monthview_dayofweek) + parseInt(cal[oc_cal_month]);
|
|
|
|
oc_cal_rows = oc_cal_rows / 7;
|
|
|
|
oc_cal_rows = Math.ceil(oc_cal_rows);
|
2011-09-02 00:31:25 +04:00
|
|
|
var dates = this.generateDates();
|
2011-09-01 17:15:38 +04:00
|
|
|
var week = 1;
|
|
|
|
var weekday = 0;
|
|
|
|
for(var i = 0; i <= 41; i++){
|
|
|
|
var generate_dayofmonth = dates[i][0];
|
|
|
|
var generate_month = dates[i][1];
|
|
|
|
var generate_year = dates[i][2];
|
2011-09-02 18:44:25 +04:00
|
|
|
$("#onemonthview .week_" + week + " ." + Calendar.UI.weekdays[weekday] + " .dateinfo").html(generate_dayofmonth + oc_cal_space + oc_cal_monthshort[generate_month]);
|
|
|
|
if(generate_dayofmonth == oc_cal_todaydayofmonth && generate_month == oc_cal_todaymonth && generate_year == oc_cal_todayyear){
|
|
|
|
$("#onemonthview .week_" + week + " ." + Calendar.UI.weekdays[weekday]).addClass('thisday');
|
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
if(parseInt(generate_dayofmonth) <= 9){
|
|
|
|
generate_dayofmonth = "0" + generate_dayofmonth;
|
|
|
|
}
|
|
|
|
generate_month++;
|
|
|
|
if(parseInt(generate_month) <= 9){
|
|
|
|
generate_month = "0" + generate_month;
|
|
|
|
}
|
|
|
|
var generate_title = String(generate_dayofmonth) + String(generate_month) + String(generate_year);
|
2011-09-02 18:44:25 +04:00
|
|
|
$("#onemonthview .week_" + week + " ." + Calendar.UI.weekdays[weekday]).attr('title', generate_title);
|
2011-09-01 17:15:38 +04:00
|
|
|
if(weekday == 6){
|
|
|
|
weekday = 0;
|
|
|
|
week++;
|
|
|
|
}else{
|
|
|
|
weekday++;
|
|
|
|
}
|
|
|
|
}
|
2011-09-02 14:55:56 +04:00
|
|
|
if(oc_cal_rows == 4){
|
|
|
|
for(var i = 1;i <= 6;i++){
|
2011-09-02 18:44:25 +04:00
|
|
|
$("#onemonthview .week_" + String(i)).height("23%");
|
2011-09-02 14:55:56 +04:00
|
|
|
}
|
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
if(oc_cal_rows == 5) {
|
2011-09-03 01:51:18 +04:00
|
|
|
$("#onemonthview .week_5").show();
|
2011-09-02 14:55:56 +04:00
|
|
|
for(var i = 1;i <= 6;i++){
|
2011-09-02 18:44:25 +04:00
|
|
|
$("#onemonthview .week_" + String(i)).height("18%");
|
2011-09-02 14:55:56 +04:00
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
}
|
|
|
|
if(oc_cal_rows == 6) {
|
2011-09-03 01:51:18 +04:00
|
|
|
$("#onemonthview .week_5").show();
|
|
|
|
$("#onemonthview .week_6").show();
|
2011-09-02 14:55:56 +04:00
|
|
|
for(var i = 1;i <= 6;i++){
|
2011-09-02 18:44:25 +04:00
|
|
|
$("#onemonthview .week_" + String(i)).height("14%");
|
2011-09-02 14:55:56 +04:00
|
|
|
}
|
2011-09-01 17:15:38 +04:00
|
|
|
}
|
|
|
|
},
|
2011-09-02 01:27:00 +04:00
|
|
|
showEvents:function(){
|
2011-09-02 00:31:25 +04:00
|
|
|
var dates = this.generateDates();
|
2011-09-01 17:15:38 +04:00
|
|
|
var weekdaynum = 0;
|
|
|
|
var weeknum = 1;
|
|
|
|
for(var i = 0; i <= 41; i++) {
|
|
|
|
Calendar.UI.createEventsForDate(dates[i], weeknum, weekdaynum);
|
|
|
|
if(weekdaynum == 6){
|
|
|
|
weekdaynum = 0;
|
|
|
|
weeknum++;
|
|
|
|
}else{
|
|
|
|
weekdaynum++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
getEventContainer:function(week, weekday, when){
|
2011-09-02 18:44:25 +04:00
|
|
|
return $("#onemonthview .week_" + week + " .day." + Calendar.UI.weekdays[weekday] + " .events");
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
2011-09-03 16:05:20 +04:00
|
|
|
createEventLabel:function(event){
|
|
|
|
var time = '';
|
|
|
|
if (!event['allday']){
|
2011-09-04 00:13:14 +04:00
|
|
|
time = '<strong>' + Calendar.UI.formatTime(event['startdate']) + '</strong> ';
|
2011-09-03 16:05:20 +04:00
|
|
|
}
|
|
|
|
return $(document.createElement('p'))
|
|
|
|
.html(time + event['description'])
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
2011-09-02 00:31:25 +04:00
|
|
|
generateDates:function(){
|
|
|
|
var dates = new Array();
|
2011-09-06 13:47:23 +04:00
|
|
|
var generate_date = new Date(oc_cal_year, oc_cal_month, oc_cal_dayofmonth);
|
|
|
|
generate_date.setDate(1);
|
|
|
|
var generate_dayofweek = generate_date.getDay();
|
2011-09-02 00:31:25 +04:00
|
|
|
if(generate_dayofweek == 0) {
|
|
|
|
generate_dayofweek = 7;
|
|
|
|
oc_cal_rows++;
|
|
|
|
}
|
2011-09-06 13:47:23 +04:00
|
|
|
generate_date.setDate(generate_date.getDate() - generate_dayofweek + 1);
|
|
|
|
for(var i = 0; i <= 41; i++) {
|
|
|
|
dates[i] = new Array(generate_date.getDate(), generate_date.getMonth(), generate_date.getFullYear());
|
|
|
|
generate_date.setDate(generate_date.getDate() + 1);
|
2011-09-02 00:31:25 +04:00
|
|
|
}
|
|
|
|
return dates;
|
|
|
|
},
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
List:{
|
|
|
|
forward:function(){
|
|
|
|
Calendar.Date.forward_day();
|
|
|
|
},
|
|
|
|
backward:function(){
|
|
|
|
Calendar.Date.backward_day();
|
|
|
|
},
|
|
|
|
removeEvents:function(){
|
|
|
|
$("#listview").html("");
|
|
|
|
},
|
|
|
|
renderCal:function(){
|
|
|
|
$("#datecontrol_date").val(oc_cal_dayshort[oc_cal_dayofweek] + oc_cal_space + oc_cal_dayofmonth + oc_cal_space + oc_cal_monthshort[oc_cal_month] + oc_cal_space + oc_cal_year);
|
|
|
|
},
|
2011-09-02 01:27:00 +04:00
|
|
|
showEvents:function(){
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
getEventContainer:function(week, weekday, when){
|
|
|
|
},
|
2011-09-03 16:05:20 +04:00
|
|
|
createEventLabel:function(event){
|
|
|
|
var time = '';
|
|
|
|
if (!event['allday']){
|
2011-09-04 00:13:14 +04:00
|
|
|
time = Calendar.UI.formatTime(event['startdate']) + ' - ' + Calendar.UI.formatTime(event['enddate']) + ' ';
|
2011-09-03 16:05:20 +04:00
|
|
|
}
|
|
|
|
return $(document.createElement('p'))
|
|
|
|
.html(time + event['description'])
|
2011-09-01 17:15:38 +04:00
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-08-12 16:29:45 +04:00
|
|
|
function oc_cal_switch2today() {
|
|
|
|
oc_cal_date = oc_cal_today;
|
|
|
|
oc_cal_dayofweek = oc_cal_todaydayofweek;
|
|
|
|
oc_cal_month = oc_cal_todaymonth;
|
|
|
|
oc_cal_dayofmonth = oc_cal_todaydayofmonth;
|
|
|
|
oc_cal_year = oc_cal_todayyear;
|
2011-09-02 01:27:00 +04:00
|
|
|
Calendar.UI.updateView();
|
2011-08-11 13:22:07 +04:00
|
|
|
}
|
|
|
|
|
2011-08-19 22:33:48 +04:00
|
|
|
function oc_cal_newevent(date, time){
|
|
|
|
if(oc_cal_opendialog == 0){
|
|
|
|
$("#dialog_holder").load(oc_webroot + "/apps/calendar/ajax/neweventform.php?d=" + date + "&t=" + time);
|
|
|
|
oc_cal_opendialog = 1;
|
|
|
|
}else{
|
|
|
|
alert(t("calendar", "You can't open more than one dialog per site!"));
|
|
|
|
}
|
2011-08-23 20:02:36 +04:00
|
|
|
}
|
|
|
|
function oc_cal_choosecalendar(){
|
|
|
|
if(oc_cal_opendialog == 0){
|
|
|
|
$("#dialog_holder").load(oc_webroot + "/apps/calendar/ajax/choosecalendar.php");
|
|
|
|
oc_cal_opendialog = 1;
|
|
|
|
}else{
|
|
|
|
alert(t("calendar", "You can't open more than one dialog per site!"));
|
|
|
|
}
|
2011-08-31 19:29:38 +04:00
|
|
|
}
|
2011-08-31 22:20:46 +04:00
|
|
|
function oc_cal_calender_activation(checkbox, calendarid)
|
|
|
|
{
|
2011-08-31 19:29:38 +04:00
|
|
|
$.post(oc_webroot + "/apps/calendar/ajax/activation.php", { calendarid: calendarid, active: checkbox.checked?1:0 },
|
2011-08-31 22:20:46 +04:00
|
|
|
function(data) {
|
|
|
|
checkbox.checked = data == 1;
|
2011-09-02 01:27:00 +04:00
|
|
|
Calendar.UI.loadEvents(oc_cal_year);
|
2011-08-31 22:20:46 +04:00
|
|
|
});
|
|
|
|
}
|
|
|
|
function oc_cal_editcalendar(object, calendarid){
|
|
|
|
$(object).closest('tr').load(oc_webroot + "/apps/calendar/ajax/editcalendar.php?calendarid="+calendarid);
|
|
|
|
}
|
|
|
|
function oc_cal_editcalendar_submit(button, calendarid){
|
|
|
|
var displayname = $("#displayname_"+calendarid).val();
|
|
|
|
var active = $("#active_"+calendarid+":checked").length;
|
|
|
|
var description = $("#description_"+calendarid).val();
|
|
|
|
var calendarcolor = $("#calendarcolor_"+calendarid).val();
|
|
|
|
|
|
|
|
$.post("ajax/updatecalendar.php", { id: calendarid, name: displayname, active: active, description: description, color: calendarcolor },
|
|
|
|
function(data){
|
|
|
|
if(data.error == "true"){
|
|
|
|
}else{
|
|
|
|
$(button).closest('tr').html(data.data)
|
|
|
|
}
|
|
|
|
}, 'json');
|
|
|
|
}
|