2009-07-19 18:41:42 +02:00
|
|
|
/* -*- Mode: java; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2008-08-28 16:48:45 +02:00
|
|
|
|
2007-03-29 20:05:23 +02:00
|
|
|
/* JavaScript for SOGoCalendar */
|
|
|
|
|
2006-08-31 01:13:18 +02:00
|
|
|
var listFilter = 'view_today';
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2006-10-12 23:05:32 +02:00
|
|
|
var listOfSelection = null;
|
2007-01-30 14:50:52 +01:00
|
|
|
var selectedCalendarCell;
|
2006-10-12 23:05:32 +02:00
|
|
|
|
2009-08-17 22:07:54 +02:00
|
|
|
var showCompletedTasks;;
|
2006-10-11 20:12:02 +02:00
|
|
|
|
2006-08-19 00:40:04 +02:00
|
|
|
var currentDay = '';
|
|
|
|
|
2008-07-16 04:12:18 +02:00
|
|
|
var cachedDateSelectors = [];
|
2006-09-07 17:50:03 +02:00
|
|
|
|
2006-10-14 01:37:27 +02:00
|
|
|
var contactSelectorAction = 'calendars-contacts';
|
|
|
|
|
2008-07-16 04:12:18 +02:00
|
|
|
var eventsToDelete = [];
|
|
|
|
var calendarsOfEventsToDelete = [];
|
2006-10-18 23:53:47 +02:00
|
|
|
|
2008-12-23 16:51:12 +01:00
|
|
|
var usersRightsWindowHeight = 215;
|
2007-04-28 00:06:58 +02:00
|
|
|
var usersRightsWindowWidth = 502;
|
|
|
|
|
2008-07-16 04:12:18 +02:00
|
|
|
var calendarEvents = null;
|
|
|
|
|
2009-08-18 20:23:13 +02:00
|
|
|
var preventAutoScroll = false;
|
|
|
|
|
2008-07-16 23:48:54 +02:00
|
|
|
var userStates = [ "needs-action", "accepted", "declined", "tentative" ];
|
|
|
|
|
2006-10-11 20:12:02 +02:00
|
|
|
function newEvent(sender, type) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var day = $(sender).readAttribute("day");
|
|
|
|
if (!day)
|
|
|
|
day = currentDay;
|
|
|
|
var hour = sender.readAttribute("hour");
|
|
|
|
var folder = getSelectedFolder();
|
|
|
|
var folderID = folder.readAttribute("id");
|
|
|
|
var urlstr = ApplicationBaseURL + folderID + "/new" + type;
|
|
|
|
var params = [];
|
|
|
|
if (day)
|
|
|
|
params.push("day=" + day);
|
|
|
|
if (hour)
|
|
|
|
params.push("hm=" + hour);
|
|
|
|
if (params.length > 0)
|
|
|
|
urlstr += "?" + params.join("&");
|
|
|
|
|
|
|
|
window.open(urlstr, "", "width=490,height=470,resizable=0");
|
2007-05-22 16:38:54 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false; /* stop following the link */
|
2007-05-22 16:38:54 +02:00
|
|
|
}
|
2006-08-15 22:52:23 +02:00
|
|
|
|
2007-09-15 00:01:02 +02:00
|
|
|
function getSelectedFolder() {
|
2009-07-19 18:41:42 +02:00
|
|
|
var folder;
|
|
|
|
var list = $("calendarList");
|
|
|
|
var nodes = list.getSelectedRows();
|
|
|
|
if (nodes.length > 0)
|
|
|
|
folder = nodes[0];
|
|
|
|
else
|
|
|
|
folder = list.down("li");
|
2007-09-15 00:01:02 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return folder;
|
2007-09-15 00:01:02 +02:00
|
|
|
}
|
|
|
|
|
2007-05-22 16:38:54 +02:00
|
|
|
function onMenuNewEventClick(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
newEvent(this, "event");
|
2007-05-22 16:38:54 +02:00
|
|
|
}
|
2006-08-22 00:36:33 +02:00
|
|
|
|
2007-05-22 16:38:54 +02:00
|
|
|
function onMenuNewTaskClick(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
newEvent(this, "task");
|
2006-08-22 00:36:33 +02:00
|
|
|
}
|
|
|
|
|
2008-07-17 23:12:43 +02:00
|
|
|
function _editEventId(id, calendar, recurrence) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var targetname = "SOGo_edit_" + id;
|
|
|
|
var urlstr = ApplicationBaseURL + calendar + "/" + id;
|
|
|
|
if (recurrence) {
|
|
|
|
urlstr += "/" + recurrence;
|
|
|
|
targetname += recurrence;
|
|
|
|
}
|
|
|
|
urlstr += "/edit";
|
|
|
|
var win = window.open(urlstr, "_blank",
|
|
|
|
"width=490,height=470,resizable=0");
|
|
|
|
if (win)
|
|
|
|
win.focus();
|
2006-08-22 00:36:33 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function editEvent() {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (listOfSelection) {
|
|
|
|
var nodes = listOfSelection.getSelectedRows();
|
|
|
|
|
|
|
|
if (nodes.length == 0) {
|
2009-09-16 22:25:47 +02:00
|
|
|
window.alert(getLabel("Please select an event or a task."));
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (var i = 0; i < nodes.length; i++)
|
|
|
|
_editEventId(nodes[i].cname,
|
|
|
|
nodes[i].calendar);
|
|
|
|
} else if (selectedCalendarCell) {
|
|
|
|
if (selectedCalendarCell[0].recurrenceTime && !selectedCalendarCell[0].isException)
|
|
|
|
_editRecurrenceDialog(selectedCalendarCell[0], "confirmEditing");
|
|
|
|
else
|
|
|
|
_editEventId(selectedCalendarCell[0].cname,
|
|
|
|
selectedCalendarCell[0].calendar);
|
|
|
|
} else {
|
2009-09-16 22:25:47 +02:00
|
|
|
window.alert(getLabel("Please select an event or a task."));
|
2007-12-03 15:13:10 +01:00
|
|
|
}
|
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false; /* stop following the link */
|
2006-08-25 22:49:34 +02:00
|
|
|
}
|
|
|
|
|
2006-10-18 23:53:47 +02:00
|
|
|
function _batchDeleteEvents() {
|
2009-07-19 18:41:42 +02:00
|
|
|
var events = eventsToDelete.shift();
|
|
|
|
var calendar = calendarsOfEventsToDelete.shift();
|
|
|
|
var urlstr = (ApplicationBaseURL + calendar
|
|
|
|
+ "/batchDelete?ids=" + events.join('/'));
|
|
|
|
document.deleteEventAjaxRequest = triggerAjaxRequest(urlstr,
|
|
|
|
deleteEventCallback,
|
|
|
|
{ calendar: calendar,
|
|
|
|
events: events });
|
2006-10-17 00:35:22 +02:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function deleteEvent() {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (listOfSelection) {
|
|
|
|
var nodes = listOfSelection.getSelectedRows();
|
|
|
|
if (nodes.length > 0) {
|
|
|
|
var label = "";
|
|
|
|
if (listOfSelection == $("tasksList"))
|
2009-09-16 22:25:47 +02:00
|
|
|
label = getLabel("taskDeleteConfirmation");
|
2009-07-19 18:41:42 +02:00
|
|
|
else
|
2009-09-16 22:25:47 +02:00
|
|
|
label = getLabel("eventDeleteConfirmation");
|
2009-07-19 18:41:42 +02:00
|
|
|
|
|
|
|
if (nodes.length == 1
|
|
|
|
&& nodes[0].recurrenceTime) {
|
|
|
|
_editRecurrenceDialog(nodes[0], "confirmDeletion");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if (confirm(label)) {
|
|
|
|
if (document.deleteEventAjaxRequest) {
|
|
|
|
document.deleteEventAjaxRequest.aborted = true;
|
|
|
|
document.deleteEventAjaxRequest.abort();
|
|
|
|
}
|
|
|
|
var sortedNodes = [];
|
|
|
|
var calendars = [];
|
|
|
|
|
|
|
|
for (var i = 0; i < nodes.length; i++) {
|
|
|
|
var calendar = nodes[i].calendar;
|
|
|
|
if (!sortedNodes[calendar]) {
|
|
|
|
sortedNodes[calendar] = [];
|
|
|
|
calendars.push(calendar);
|
|
|
|
}
|
|
|
|
sortedNodes[calendar].push(nodes[i].cname);
|
|
|
|
}
|
|
|
|
for (var i = 0; i < calendars.length; i++) {
|
|
|
|
calendarsOfEventsToDelete.push(calendars[i]);
|
|
|
|
eventsToDelete.push(sortedNodes[calendars[i]]);
|
|
|
|
}
|
|
|
|
_batchDeleteEvents();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
2009-09-16 22:25:47 +02:00
|
|
|
window.alert(getLabel("Please select an event or a task."));
|
2009-07-19 18:41:42 +02:00
|
|
|
}
|
2008-07-17 23:12:43 +02:00
|
|
|
}
|
2009-07-19 18:41:42 +02:00
|
|
|
else if (selectedCalendarCell) {
|
|
|
|
if (selectedCalendarCell[0].recurrenceTime) {
|
|
|
|
_editRecurrenceDialog(selectedCalendarCell[0], "confirmDeletion");
|
|
|
|
}
|
|
|
|
else {
|
2009-09-16 22:25:47 +02:00
|
|
|
var label = getLabel("eventDeleteConfirmation");
|
2009-07-19 18:41:42 +02:00
|
|
|
if (confirm(label)) {
|
|
|
|
if (document.deleteEventAjaxRequest) {
|
|
|
|
document.deleteEventAjaxRequest.aborted = true;
|
|
|
|
document.deleteEventAjaxRequest.abort();
|
|
|
|
}
|
|
|
|
eventsToDelete.push([selectedCalendarCell[0].cname]);
|
|
|
|
calendarsOfEventsToDelete.push(selectedCalendarCell[0].calendar);
|
|
|
|
_batchDeleteEvents();
|
|
|
|
}
|
|
|
|
}
|
2008-01-24 22:36:51 +01:00
|
|
|
}
|
2009-07-19 18:41:42 +02:00
|
|
|
else
|
2009-09-16 22:25:47 +02:00
|
|
|
window.alert(getLabel("Please select an event or a task."));
|
2006-08-22 00:36:33 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2006-08-25 22:49:34 +02:00
|
|
|
}
|
|
|
|
|
2009-09-10 20:31:20 +02:00
|
|
|
function modifyEvent(sender, modification, parameters) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var currentLocation = '' + window.location;
|
|
|
|
var arr = currentLocation.split("/");
|
|
|
|
arr[arr.length-1] = modification;
|
2006-11-15 01:10:53 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
document.modifyEventAjaxRequest = triggerAjaxRequest(arr.join("/"),
|
|
|
|
modifyEventCallback,
|
2009-09-10 20:31:20 +02:00
|
|
|
modification,
|
|
|
|
parameters,
|
|
|
|
{ "Content-type": "application/x-www-form-urlencoded" });
|
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2006-11-15 01:10:53 +01:00
|
|
|
}
|
|
|
|
|
2007-01-04 23:30:48 +01:00
|
|
|
function closeInvitationWindow() {
|
2009-07-19 18:41:42 +02:00
|
|
|
var closeDiv = document.createElement("div");
|
|
|
|
document.body.appendChild(closeDiv);
|
|
|
|
closeDiv.addClassName("javascriptPopupBackground");
|
2007-10-04 19:26:21 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var closePseudoWin = document.createElement("div");
|
|
|
|
document.body.appendChild(closePseudoWin);
|
|
|
|
closePseudoWin.addClassName("javascriptMessagePseudoTopWindow");
|
|
|
|
closePseudoWin.style.top = "0px;";
|
|
|
|
closePseudoWin.style.left = "0px;";
|
|
|
|
closePseudoWin.style.right = "0px;";
|
2009-09-16 22:25:47 +02:00
|
|
|
closePseudoWin.appendChild(document.createTextNode(getLabel("closeThisWindowMessage")));
|
2007-10-04 19:26:21 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var calLink = document.createElement("a");
|
|
|
|
closePseudoWin.appendChild(calLink);
|
|
|
|
calLink.href = ApplicationBaseURL;
|
2009-09-16 22:25:47 +02:00
|
|
|
calLink.appendChild(document.createTextNode(getLabel("Calendar").toLowerCase()));
|
2007-01-04 23:30:48 +01:00
|
|
|
}
|
|
|
|
|
2006-11-15 01:10:53 +01:00
|
|
|
function modifyEventCallback(http) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (http.readyState == 4) {
|
|
|
|
if (http.status == 200) {
|
|
|
|
var mailInvitation = queryParameters["mail-invitation"];
|
|
|
|
if (mailInvitation && mailInvitation.toLowerCase() == "yes")
|
|
|
|
closeInvitationWindow();
|
|
|
|
else {
|
|
|
|
window.opener.setTimeout("refreshEventsAndDisplay();", 100);
|
|
|
|
window.setTimeout("window.close();", 100);
|
|
|
|
}
|
|
|
|
}
|
2009-09-10 20:31:20 +02:00
|
|
|
else if (http.status == 403) {
|
|
|
|
var data = http.responseText;
|
|
|
|
var msg = data.replace(/^(.*\n)*.*<p>((.*\n)*.*)<\/p>(.*\n)*.*$/, "$2");
|
|
|
|
window.alert(clabels[msg]?clabels[msg]:msg);
|
|
|
|
}
|
2009-07-19 18:41:42 +02:00
|
|
|
else {
|
|
|
|
// log("showing alert...");
|
2009-09-16 22:25:47 +02:00
|
|
|
window.alert(getLabel("eventPartStatModificationError"));
|
2009-07-19 18:41:42 +02:00
|
|
|
}
|
|
|
|
document.modifyEventAjaxRequest = null;
|
2007-08-24 00:10:01 +02:00
|
|
|
}
|
2006-11-07 19:14:29 +01:00
|
|
|
}
|
|
|
|
|
2008-08-03 01:16:50 +02:00
|
|
|
function _deleteCalendarEventBlocks(calendar, cname) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var events = calendarEvents[calendar];
|
|
|
|
if (events) {
|
|
|
|
var occurences = events[cname];
|
|
|
|
if (occurences)
|
|
|
|
for (var i = 0; i < occurences.length; i++) {
|
|
|
|
var nodes = occurences[i].blocks;
|
|
|
|
for (var j = 0; j < nodes.length; j++) {
|
|
|
|
var node = nodes[j];
|
|
|
|
node.parentNode.removeChild(node);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2008-08-03 01:16:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function _deleteEventFromTables(basename) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var tables = [ $("eventsList"), $("tasksList") ];
|
|
|
|
for (var i = 0; i < 2; i++) {
|
|
|
|
var table = tables[i];
|
|
|
|
if (table.tBodies)
|
|
|
|
rows = table.tBodies[0].rows;
|
|
|
|
else
|
|
|
|
rows = $(table).childNodesWithTag("li");
|
|
|
|
for (var j = rows.length; j > 0; j--) {
|
|
|
|
var row = $(rows[j - 1]);
|
|
|
|
var id = row.getAttribute("id");
|
|
|
|
if (id.indexOf(basename) == 0)
|
|
|
|
row.parentNode.removeChild(row);
|
|
|
|
}
|
2008-08-03 01:16:50 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function deleteEventCallback(http) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (http.readyState == 4) {
|
|
|
|
if (isHttpStatus204(http.status)) {
|
|
|
|
var isTask = false;
|
|
|
|
var calendar = http.callbackData.calendar;
|
|
|
|
var events = http.callbackData.events;
|
|
|
|
|
|
|
|
// log("calendar: " + calendar + "\n");
|
|
|
|
// log("events: " + events.join(", " ) + "\n");
|
|
|
|
for (var i = 0; i < events.length; i++) {
|
|
|
|
var cname = events[i];
|
|
|
|
_deleteCalendarEventBlocks(calendar, cname);
|
|
|
|
_deleteEventFromTables(calendar + "-" + cname);
|
|
|
|
delete calendarEvents[calendar][cname];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (eventsToDelete.length)
|
|
|
|
_batchDeleteEvents();
|
|
|
|
else {
|
|
|
|
document.deleteEventAjaxRequest = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (parseInt(http.status) == 403)
|
2009-09-16 22:25:47 +02:00
|
|
|
window.alert(getLabel("You don't have the required privileges to perform the operation."));
|
2009-07-19 18:41:42 +02:00
|
|
|
else
|
|
|
|
log ("deleteEventCallback Ajax error (" + http.status + ")");
|
|
|
|
}
|
2006-08-14 22:32:30 +02:00
|
|
|
}
|
|
|
|
|
2008-07-29 18:35:49 +02:00
|
|
|
function getEventById(cname, owner) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var event = null;
|
|
|
|
|
|
|
|
if (calendarEvents) {
|
|
|
|
if (!owner)
|
|
|
|
owner = UserLogin;
|
|
|
|
var userEvents = calendarEvents[owner];
|
|
|
|
if (userEvents)
|
|
|
|
event = userEvents[cname];
|
|
|
|
}
|
2008-07-29 18:35:49 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return event;
|
2008-07-29 18:35:49 +02:00
|
|
|
}
|
|
|
|
|
2008-07-17 23:12:43 +02:00
|
|
|
function _editRecurrenceDialog(eventDiv, method) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var targetname = "SOGo_edit_" + eventDiv.cname + eventDiv.recurrenceTime;
|
|
|
|
var urlstr = (ApplicationBaseURL + eventDiv.calendar + "/" + eventDiv.cname
|
|
|
|
+ "/occurence" + eventDiv.recurrenceTime + "/" + method);
|
|
|
|
var win = window.open(urlstr, "_blank",
|
|
|
|
"width=490,height=70,resizable=0");
|
|
|
|
if (win)
|
|
|
|
win.focus();
|
2008-07-17 23:12:43 +02:00
|
|
|
}
|
|
|
|
|
2008-08-19 00:45:59 +02:00
|
|
|
function onViewEvent(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (event.detail == 2) return;
|
|
|
|
var url = ApplicationBaseURL + this.calendar + "/" + this.cname;
|
|
|
|
|
|
|
|
if (typeof this.recurrenceTime != "undefined")
|
|
|
|
url += "/occurence" + this.recurrenceTime;
|
|
|
|
url += "/view";
|
|
|
|
if (document.viewEventAjaxRequest) {
|
|
|
|
document.viewEventAjaxRequest.aborted = true;
|
|
|
|
document.viewEventAjaxRequest.abort();
|
|
|
|
}
|
|
|
|
document.viewEventAjaxRequest = triggerAjaxRequest(url, onViewEventCallback, this);
|
2008-08-19 00:45:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function onViewEventCallback(http) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (http.readyState == 4
|
|
|
|
&& http.status == 200) {
|
|
|
|
if (http.responseText.length > 0) {
|
|
|
|
var data = http.responseText.evalJSON(true);
|
|
|
|
// $H(data).keys().each(function(key) {
|
|
|
|
// log (key + " = " + data[key]);
|
|
|
|
// });
|
|
|
|
var cell = http.callbackData;
|
|
|
|
var cellPosition = cell.cumulativeOffset();
|
|
|
|
var cellDimensions = cell.getDimensions();
|
|
|
|
var div = $("eventDialog");
|
|
|
|
var divDimensions = div.getDimensions();
|
|
|
|
var view;
|
|
|
|
var left = cellPosition[0];
|
|
|
|
var top = cellPosition[1];
|
2008-08-19 00:45:59 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (currentView != "monthview") {
|
|
|
|
view = $("daysView");
|
|
|
|
var viewPosition = view.cumulativeOffset();
|
|
|
|
if (parseInt(data["isAllDay"]) == 0) {
|
|
|
|
top -= view.scrollTop;
|
|
|
|
if (viewPosition[1] > top + 2) {
|
|
|
|
view.stopObserving("scroll", onBodyClickHandler);
|
|
|
|
view.scrollTop = cell.offsetTop;
|
|
|
|
top = viewPosition[1];
|
|
|
|
Event.observe.delay(0.1, view, "scroll", onBodyClickHandler);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
view = $("calendarView");
|
|
|
|
top -= cell.up("DIV.day").scrollTop;
|
|
|
|
}
|
2008-08-19 00:45:59 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (left > parseInt(window.width()*0.75)) {
|
|
|
|
left = left - divDimensions["width"] + 10;
|
|
|
|
div.removeClassName("left");
|
|
|
|
div.addClassName("right");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
left = left + cellDimensions["width"] - parseInt(cellDimensions["width"]/3);
|
|
|
|
div.removeClassName("right");
|
|
|
|
div.addClassName("left");
|
|
|
|
}
|
|
|
|
|
|
|
|
// Put the event's data in the DIV
|
2009-07-22 00:53:15 +02:00
|
|
|
div.down("h1").update(data["summary"].replace(/\r?\n/g, "<BR/>"));
|
2009-07-19 18:41:42 +02:00
|
|
|
if (parseInt(data["isAllDay"]) == 0) {
|
|
|
|
div.down("P", 0).down("SPAN", 1).update(data["startTime"]);
|
|
|
|
div.down("P", 0).show();
|
|
|
|
} else
|
|
|
|
div.down("P", 0).hide();
|
|
|
|
if (data["location"].length) {
|
|
|
|
div.down("P", 1).down("SPAN", 1).update(data["location"]);
|
|
|
|
div.down("P", 1).show();
|
|
|
|
} else
|
|
|
|
div.down("P", 1).hide();
|
|
|
|
|
|
|
|
if (data["description"].length) {
|
2009-07-22 00:53:15 +02:00
|
|
|
div.down("P", 2).update(data["description"].replace(/\r?\n/g, "<BR/>"));
|
2009-07-19 18:41:42 +02:00
|
|
|
div.down("P", 2).show();
|
|
|
|
} else
|
|
|
|
div.down("P", 2).hide();
|
2008-08-19 00:45:59 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
div.setStyle({ left: left + "px",
|
|
|
|
top: top + "px" });
|
|
|
|
div.show();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
log("onViewEventCallback ajax error (" + http.status + "): " + http.url);
|
2008-08-19 00:45:59 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-06-11 23:23:48 +02:00
|
|
|
function editDoubleClickedEvent(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (this.isException && this.recurrenceTime)
|
|
|
|
_editEventId(this.cname, this.calendar, "occurence" + this.recurrenceTime);
|
|
|
|
else if (this.recurrenceTime)
|
|
|
|
_editRecurrenceDialog(this, "confirmEditing");
|
|
|
|
else
|
|
|
|
_editEventId(this.cname, this.calendar);
|
2007-06-11 23:23:48 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
Event.stop(event);
|
2006-08-22 00:36:33 +02:00
|
|
|
}
|
|
|
|
|
2008-07-17 23:12:43 +02:00
|
|
|
function performEventEdition(folder, event, recurrence) {
|
2009-07-19 18:41:42 +02:00
|
|
|
_editEventId(event, folder, recurrence);
|
2008-07-17 23:12:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function performEventDeletion(folder, event, recurrence) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (calendarEvents) {
|
|
|
|
if (recurrence) {
|
|
|
|
// Only one recurrence
|
|
|
|
var occurenceTime = recurrence.substring(9);
|
|
|
|
var nodes = _eventBlocksMatching(folder, event, occurenceTime);
|
|
|
|
var urlstr = ApplicationBaseURL + folder + "/" + event + "/" + recurrence + "/delete";
|
2008-11-22 08:20:22 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (nodes)
|
|
|
|
document.deleteEventAjaxRequest = triggerAjaxRequest(urlstr,
|
|
|
|
performDeleteEventCallback,
|
|
|
|
{ nodes: nodes,
|
|
|
|
occurence: occurenceTime });
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
// All recurrences
|
|
|
|
if (document.deleteEventAjaxRequest) {
|
|
|
|
document.deleteEventAjaxRequest.aborted = true;
|
|
|
|
document.deleteEventAjaxRequest.abort();
|
|
|
|
}
|
|
|
|
eventsToDelete.push([event]);
|
|
|
|
calendarsOfEventsToDelete.push(folder);
|
|
|
|
_batchDeleteEvents();
|
|
|
|
}
|
2008-07-29 18:35:49 +02:00
|
|
|
}
|
2008-07-17 23:12:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function performDeleteEventCallback(http) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (http.readyState == 4) {
|
|
|
|
if (isHttpStatus204(http.status)) {
|
|
|
|
var occurenceTime = http.callbackData.occurence;
|
|
|
|
var nodes = http.callbackData.nodes;
|
|
|
|
var cname = nodes[0].cname;
|
|
|
|
var calendar = nodes[0].calendar;
|
|
|
|
for (var i = 0; i < nodes.length; i++) {
|
|
|
|
var node = nodes[i];
|
|
|
|
node.parentNode.removeChild(node);
|
|
|
|
}
|
|
|
|
var basename = calendar + "-" + cname;
|
|
|
|
if (occurenceTime) {
|
|
|
|
var row = $(basename + "-" + occurenceTime);
|
|
|
|
// log("rowID: " + basename + "-" + occurenceTime);
|
|
|
|
if (row)
|
|
|
|
row.parentNode.removeChild(row);
|
|
|
|
|
|
|
|
// Update calendar events cache
|
|
|
|
var occurences = calendarEvents[calendar][cname];
|
|
|
|
var newOccurences = [];
|
|
|
|
for (var i = 0; i < occurences.length; i++) {
|
|
|
|
var occurence = occurences[i];
|
|
|
|
if (occurence[14] != occurenceTime)
|
|
|
|
newOccurences.push(occurence);
|
|
|
|
}
|
|
|
|
calendarEvents[calendar][cname] = newOccurences;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
// log("basename: " + basename);
|
|
|
|
_deleteEventFromTables(basename);
|
|
|
|
delete calendarEvents[calendar][cname];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2008-07-17 23:12:43 +02:00
|
|
|
}
|
|
|
|
|
2006-08-25 22:49:34 +02:00
|
|
|
function onSelectAll() {
|
2009-07-19 18:41:42 +02:00
|
|
|
var list = $("eventsList");
|
|
|
|
list.selectRowsMatchingClass("eventRow");
|
2006-08-25 22:49:34 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2006-08-25 22:49:34 +02:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function onDaySelect(node) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var day = node.getAttribute('day');
|
|
|
|
var needRefresh = (listFilter == 'view_selectedday'
|
|
|
|
&& day != currentDay);
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var td = $(node).getParentWithTagName("td");
|
|
|
|
var table = $(td).getParentWithTagName("table");
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
// log ("table.selected: " + table.selected);
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (document.selectedDate)
|
|
|
|
document.selectedDate.deselect();
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
td.selectElement();
|
|
|
|
document.selectedDate = td;
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
changeCalendarDisplay( { "day": day } );
|
|
|
|
currentDay = day;
|
|
|
|
if (needRefresh)
|
|
|
|
refreshEvents();
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2007-07-05 21:19:17 +02:00
|
|
|
function onDateSelectorGotoMonth(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var day = this.getAttribute("date");
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
changeDateSelectorDisplay(day, true);
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
Event.stop(event);
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function onCalendarGotoDay(node) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var day = node.getAttribute("date");
|
|
|
|
var needRefresh = (listFilter == 'view_selectedday'
|
|
|
|
&& day != currentDay);
|
2008-02-08 22:46:05 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
changeDateSelectorDisplay(day);
|
|
|
|
changeCalendarDisplay( { "day": day } );
|
|
|
|
if (needRefresh)
|
|
|
|
refreshEvents();
|
2008-02-08 22:46:05 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function gotoToday() {
|
2009-07-19 18:41:42 +02:00
|
|
|
changeDateSelectorDisplay('');
|
|
|
|
changeCalendarDisplay();
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function setDateSelectorContent(content) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var div = $("dateSelectorView");
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
div.innerHTML = content;
|
|
|
|
if (currentDay.length > 0)
|
|
|
|
restoreCurrentDaySelection(div);
|
2007-07-05 21:19:17 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
initDateSelectorEvents();
|
2006-09-07 17:50:03 +02:00
|
|
|
}
|
2006-08-22 00:36:33 +02:00
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function dateSelectorCallback(http) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (http.readyState == 4
|
|
|
|
&& http.status == 200) {
|
|
|
|
document.dateSelectorAjaxRequest = null;
|
|
|
|
var content = http.responseText;
|
|
|
|
setDateSelectorContent(content);
|
|
|
|
cachedDateSelectors[http.callbackData] = content;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
log ("dateSelectorCallback Ajax error");
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2007-06-08 01:23:07 +02:00
|
|
|
function eventsListCallback(http) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (http.readyState == 4
|
|
|
|
&& http.status == 200) {
|
|
|
|
var div = $("eventsListView");
|
|
|
|
document.eventsListAjaxRequest = null;
|
|
|
|
var table = $("eventsList");
|
|
|
|
lastClickedRow = -1; // from generic.js
|
|
|
|
|
|
|
|
if (http.responseText.length > 0) {
|
|
|
|
var data = http.responseText.evalJSON(true);
|
|
|
|
for (var i = 0; i < data.length; i++) {
|
|
|
|
var row = $(document.createElement("tr"));
|
|
|
|
table.tBodies[0].appendChild(row);
|
|
|
|
row.addClassName("eventRow");
|
|
|
|
var rTime = data[i][14];
|
|
|
|
var id = escape(data[i][1] + "-" + data[i][0]);
|
|
|
|
if (rTime)
|
|
|
|
id += "-" + escape(rTime);
|
|
|
|
row.setAttribute("id", id);
|
|
|
|
row.cname = escape(data[i][0]);
|
|
|
|
row.calendar = escape(data[i][1]);
|
|
|
|
if (rTime)
|
|
|
|
row.recurrenceTime = escape(rTime);
|
|
|
|
row.isException = data[i][15];
|
|
|
|
var startDate = new Date();
|
|
|
|
startDate.setTime(data[i][4] * 1000);
|
|
|
|
row.day = startDate.getDayString();
|
|
|
|
row.hour = startDate.getHourString();
|
|
|
|
row.observe("mousedown", onRowClick);
|
|
|
|
row.observe("selectstart", listRowMouseDownHandler);
|
2009-10-14 22:29:46 +02:00
|
|
|
if (data[i][2] != null)
|
|
|
|
// Status is defined -- event is readable
|
|
|
|
row.observe("dblclick", editDoubleClickedEvent);
|
2009-07-19 18:41:42 +02:00
|
|
|
row.attachMenu("eventsListMenu");
|
|
|
|
|
|
|
|
var td = $(document.createElement("td"));
|
|
|
|
row.appendChild(td);
|
|
|
|
td.observe("mousedown", listRowMouseDownHandler, true);
|
2009-10-14 21:44:46 +02:00
|
|
|
td.appendChild(document.createTextNode(data[i][3])); // title
|
2009-07-19 18:41:42 +02:00
|
|
|
|
|
|
|
td = $(document.createElement("td"));
|
|
|
|
row.appendChild(td);
|
|
|
|
td.observe("mousedown", listRowMouseDownHandler, true);
|
2009-10-14 21:44:46 +02:00
|
|
|
td.appendChild(document.createTextNode(data[i][16])); // start date
|
2009-07-19 18:41:42 +02:00
|
|
|
|
|
|
|
td = $(document.createElement("td"));
|
|
|
|
row.appendChild(td);
|
|
|
|
td.observe("mousedown", listRowMouseDownHandler, true);
|
2009-10-14 21:44:46 +02:00
|
|
|
td.appendChild(document.createTextNode(data[i][17])); // end date
|
2007-11-02 20:02:24 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
td = $(document.createElement("td"));
|
|
|
|
row.appendChild(td);
|
|
|
|
td.observe("mousedown", listRowMouseDownHandler, true);
|
2009-10-14 21:44:46 +02:00
|
|
|
if (data[i][6])
|
|
|
|
td.appendChild(document.createTextNode(data[i][6])); // location
|
2009-07-19 18:41:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (sorting["attribute"] && sorting["attribute"].length > 0) {
|
|
|
|
var sortHeader = $(sorting["attribute"] + "Header");
|
2007-12-06 18:29:32 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (sortHeader) {
|
|
|
|
var sortImages = $(table.tHead).select(".sortImage");
|
|
|
|
$(sortImages).each(function(item) {
|
|
|
|
item.remove();
|
|
|
|
});
|
|
|
|
|
|
|
|
var sortImage = createElement("img", "messageSortImage", "sortImage");
|
|
|
|
sortHeader.insertBefore(sortImage, sortHeader.firstChild);
|
|
|
|
if (sorting["ascending"])
|
|
|
|
sortImage.src = ResourcesURL + "/title_sortdown_12x12.png";
|
|
|
|
else
|
|
|
|
sortImage.src = ResourcesURL + "/title_sortup_12x12.png";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
log ("eventsListCallback Ajax error");
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function tasksListCallback(http) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var div = $("tasksListView");
|
2006-10-11 20:12:02 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (http.readyState == 4
|
|
|
|
&& http.status == 200) {
|
|
|
|
document.tasksListAjaxRequest = null;
|
|
|
|
var list = $("tasksList");
|
2007-11-02 20:02:24 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (http.responseText.length > 0) {
|
|
|
|
var data = http.responseText.evalJSON(true);
|
|
|
|
|
|
|
|
for (var i = 0; i < data.length; i++) {
|
|
|
|
var listItem = $(document.createElement("li"));
|
|
|
|
list.appendChild(listItem);
|
|
|
|
listItem.observe("mousedown", listRowMouseDownHandler);
|
|
|
|
listItem.observe("click", onRowClick);
|
|
|
|
listItem.observe("dblclick", editDoubleClickedEvent);
|
|
|
|
|
|
|
|
var calendar = escape(data[i][1]);
|
|
|
|
var cname = escape(data[i][0]);
|
|
|
|
listItem.setAttribute("id", calendar + "-" + cname);
|
|
|
|
//listItem.addClassName(data[i][5]); // Classification
|
2009-07-31 21:48:25 +02:00
|
|
|
listItem.addClassName(data[i][8]);
|
2009-07-19 18:41:42 +02:00
|
|
|
listItem.calendar = calendar;
|
|
|
|
listItem.addClassName("calendarFolder" + calendar);
|
|
|
|
listItem.cname = cname;
|
|
|
|
var input = $(document.createElement("input"));
|
|
|
|
input.setAttribute("type", "checkbox");
|
2009-07-22 21:35:37 +02:00
|
|
|
if (parseInt(data[i][6]) == 0)
|
|
|
|
input.setAttribute ("disabled", true);
|
2009-07-31 21:48:25 +02:00
|
|
|
if (parseInt(data[i][7]) == 1) {
|
|
|
|
listItem.addClassName ("important");
|
|
|
|
}
|
2009-07-19 18:41:42 +02:00
|
|
|
listItem.appendChild(input);
|
|
|
|
input.observe("click", updateTaskStatus, true);
|
|
|
|
input.setAttribute("value", "1");
|
|
|
|
if (data[i][2] == 1)
|
|
|
|
input.setAttribute("checked", "checked");
|
|
|
|
$(input).addClassName("checkBox");
|
|
|
|
|
2009-07-31 21:48:25 +02:00
|
|
|
var t = new Element ("span");
|
|
|
|
t.update (data[i][3]);
|
|
|
|
listItem.appendChild (t);
|
2009-08-25 19:34:37 +02:00
|
|
|
|
|
|
|
listItem.attachMenu ("tasksListMenu");
|
2009-07-19 18:41:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
list.scrollTop = list.previousScroll;
|
|
|
|
|
|
|
|
if (http.callbackData) {
|
|
|
|
var selectedNodesId = http.callbackData;
|
|
|
|
for (var i = 0; i < selectedNodesId.length; i++) {
|
|
|
|
// log(selectedNodesId[i] + " (" + i + ") is selected");
|
2009-07-22 21:06:14 +02:00
|
|
|
var node = $(selectedNodesId[i]);
|
|
|
|
if (node) {
|
|
|
|
node.selectElement();
|
|
|
|
}
|
2009-07-19 18:41:42 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
log ("tasksListCallback: no data");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
log ("tasksListCallback Ajax error");
|
2006-10-11 20:12:02 +02:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function restoreCurrentDaySelection(div) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var elements = $(div).getElementsByTagName("a");
|
|
|
|
var day = null;
|
|
|
|
var i = 9;
|
|
|
|
while (!day && i < elements.length)
|
|
|
|
{
|
|
|
|
day = elements[i].day;
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (day
|
|
|
|
&& day.substr(0, 6) == currentDay.substr(0, 6)) {
|
|
|
|
for (i = 0; i < elements.length; i++) {
|
|
|
|
day = elements[i].day;
|
|
|
|
if (day && day == currentDay) {
|
|
|
|
var td = $(elements[i]).getParentWithTagName("td");
|
|
|
|
if (document.selectedDate)
|
|
|
|
document.selectedDate.deselect();
|
|
|
|
$(td).selectElement();
|
|
|
|
document.selectedDate = td;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2009-07-15 20:26:08 +02:00
|
|
|
function loadPreviousView(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var previousArrow = $$("A.leftNavigationArrow").first();
|
|
|
|
onCalendarGotoDay(previousArrow);
|
2009-07-15 20:26:08 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function loadNextView(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var nextArrow = $$("A.rightNavigationArrow").first();
|
|
|
|
onCalendarGotoDay(nextArrow);
|
2009-07-15 20:26:08 +02:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function changeDateSelectorDisplay(day, keepCurrentDay) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var url = ApplicationBaseURL + "dateselector";
|
|
|
|
if (day) {
|
|
|
|
if (day.length < 8)
|
|
|
|
day += "01";
|
|
|
|
url += "?day=" + day;
|
2006-09-07 17:50:03 +02:00
|
|
|
}
|
2009-07-19 18:41:42 +02:00
|
|
|
|
|
|
|
if (day != currentDay) {
|
|
|
|
if (!keepCurrentDay)
|
|
|
|
currentDay = day;
|
|
|
|
|
|
|
|
var month = day.substr(0, 6);
|
|
|
|
if (cachedDateSelectors[month]) {
|
|
|
|
// log ("restoring cached selector for month: " + month);
|
|
|
|
setDateSelectorContent(cachedDateSelectors[month]);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
// log ("loading selector for month: " + month);
|
|
|
|
if (document.dateSelectorAjaxRequest) {
|
|
|
|
document.dateSelectorAjaxRequest.aborted = true;
|
|
|
|
document.dateSelectorAjaxRequest.abort();
|
|
|
|
}
|
|
|
|
document.dateSelectorAjaxRequest
|
|
|
|
= triggerAjaxRequest(url,
|
|
|
|
dateSelectorCallback,
|
|
|
|
month);
|
|
|
|
}
|
2006-09-07 00:27:46 +02:00
|
|
|
}
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2007-11-07 18:37:58 +01:00
|
|
|
function changeCalendarDisplay(data, newView) {
|
2009-07-19 18:41:42 +02:00
|
|
|
newView = ((newView) ? newView : currentView);
|
|
|
|
var url = ApplicationBaseURL + newView;
|
|
|
|
var day = null;
|
|
|
|
var scrollEvent = null;
|
2007-11-19 18:09:14 +01:00
|
|
|
|
2008-08-19 00:45:59 +02:00
|
|
|
if (data) {
|
2009-07-19 18:41:42 +02:00
|
|
|
day = data['day'];
|
|
|
|
scrollEvent = data['scrollEvent'];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!day)
|
|
|
|
day = currentDay;
|
|
|
|
|
|
|
|
if (day) {
|
|
|
|
if (data) {
|
|
|
|
var divs = $$('div.day[day='+day+']');
|
|
|
|
if (divs.length) {
|
|
|
|
// Don't reload the view if the event is present in current view
|
|
|
|
|
|
|
|
// Deselect previous day
|
|
|
|
var selectedDivs = $$('div.day.selectedDay');
|
|
|
|
selectedDivs.each(function(div) {
|
|
|
|
div.removeClassName('selectedDay');
|
|
|
|
});
|
|
|
|
|
|
|
|
// Select new day
|
2009-10-14 21:44:46 +02:00
|
|
|
if (currentView != 'dayview')
|
|
|
|
divs.each(function(div) {
|
|
|
|
div.addClassName('selectedDay');
|
|
|
|
});
|
2007-11-19 18:09:14 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
// Deselect day in date selector
|
|
|
|
if (document.selectedDate)
|
|
|
|
document.selectedDate.deselect();
|
2007-11-19 18:09:14 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
// Select day in date selector
|
2009-07-28 22:09:24 +02:00
|
|
|
var selectedLink = $$('table#dateSelectorTable span[day='+day+']');
|
2009-07-19 18:41:42 +02:00
|
|
|
if (selectedLink.length > 0) {
|
2009-07-28 22:09:24 +02:00
|
|
|
selectedCell = selectedLink[0].getParentWithTagName("td");
|
2009-07-19 18:41:42 +02:00
|
|
|
selectedCell.selectElement();
|
|
|
|
document.selectedDate = selectedCell;
|
|
|
|
}
|
2007-11-19 18:09:14 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
// Scroll to event
|
2009-08-27 18:51:30 +02:00
|
|
|
if (scrollEvent)
|
|
|
|
scrollDayView(scrollEvent);
|
2009-07-19 18:41:42 +02:00
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
else if (day.length == 6) {
|
|
|
|
day += "01";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
url += "?day=" + day;
|
2007-11-16 20:38:49 +01:00
|
|
|
}
|
2006-08-22 00:36:33 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
selectedCalendarCell = null;
|
2007-11-19 18:09:14 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (document.dayDisplayAjaxRequest) {
|
|
|
|
document.dayDisplayAjaxRequest.aborted = true;
|
|
|
|
document.dayDisplayAjaxRequest.abort();
|
|
|
|
}
|
|
|
|
document.dayDisplayAjaxRequest
|
|
|
|
= triggerAjaxRequest(url, calendarDisplayCallback,
|
|
|
|
{ "view": newView,
|
|
|
|
"day": day,
|
|
|
|
"scrollEvent": scrollEvent });
|
2006-08-24 20:48:33 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2006-08-24 20:48:33 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function _ensureView(view) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (currentView != view)
|
|
|
|
changeCalendarDisplay(null, view);
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function onDayOverview() {
|
2009-07-19 18:41:42 +02:00
|
|
|
return _ensureView("dayview");
|
2006-08-24 20:48:33 +02:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function onMulticolumnDayOverview() {
|
2009-07-19 18:41:42 +02:00
|
|
|
return _ensureView("multicolumndayview");
|
2007-02-13 23:01:02 +01:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function onWeekOverview() {
|
2009-07-19 18:41:42 +02:00
|
|
|
return _ensureView("weekview");
|
2006-08-24 20:48:33 +02:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function onMonthOverview() {
|
2009-07-19 18:41:42 +02:00
|
|
|
return _ensureView("monthview");
|
2006-08-24 20:48:33 +02:00
|
|
|
}
|
|
|
|
|
2009-07-15 22:36:06 +02:00
|
|
|
function onCalendarReload() {
|
2009-09-10 19:26:57 +02:00
|
|
|
reloadWebCalendars ();
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2009-07-15 22:36:06 +02:00
|
|
|
}
|
|
|
|
|
2009-09-10 19:26:57 +02:00
|
|
|
function reloadWebCalendars () {
|
|
|
|
var url = ApplicationBaseURL + "reloadWebCalendars";
|
|
|
|
if (document.reloadWebCalAjaxRequest) {
|
|
|
|
document.reloadWebCalAjaxRequest.aborted = true;
|
|
|
|
document.reloadWebCalAjaxRequest.abort();
|
|
|
|
}
|
|
|
|
document.reloadWebCalAjaxRequest
|
|
|
|
= triggerAjaxRequest(url, reloadWebCalendarsCallback);
|
|
|
|
}
|
|
|
|
function reloadWebCalendarsCallback (http) {
|
|
|
|
changeCalendarDisplay(null, currentView);
|
|
|
|
}
|
|
|
|
|
2007-11-07 18:37:58 +01:00
|
|
|
function scrollDayView(scrollEvent) {
|
2009-08-18 20:23:13 +02:00
|
|
|
if (!preventAutoScroll) {
|
|
|
|
if (scrollEvent) {
|
|
|
|
var contentView;
|
|
|
|
var eventRow = $(scrollEvent);
|
|
|
|
var eventBlocks = selectCalendarEvent(eventRow.calendar, eventRow.cname, eventRow.recurrenceTime);
|
|
|
|
var firstEvent = eventBlocks.first();
|
|
|
|
|
|
|
|
if (currentView == "monthview")
|
|
|
|
contentView = firstEvent.up("DIV.day");
|
|
|
|
else
|
|
|
|
contentView = $("daysView");
|
|
|
|
|
|
|
|
var top = firstEvent.cumulativeOffset()[1] - contentView.scrollTop;
|
|
|
|
|
|
|
|
// Don't scroll if the event is visible to the user
|
|
|
|
if (top < contentView.cumulativeOffset()[1])
|
|
|
|
contentView.scrollTop = firstEvent.cumulativeOffset()[1] - contentView.cumulativeOffset()[1];
|
|
|
|
else if (top > contentView.cumulativeOffset()[1] + contentView.getHeight() - firstEvent.getHeight())
|
|
|
|
contentView.scrollTop = firstEvent.cumulativeOffset()[1] - contentView.cumulativeOffset()[1];
|
|
|
|
}
|
|
|
|
else if (currentView != "monthview") {
|
|
|
|
var contentView = $("daysView");
|
|
|
|
var hours = (contentView.childNodesWithTag("div")[0]).childNodesWithTag("div");
|
|
|
|
contentView.scrollTop = hours[dayStartHour].offsetTop;
|
|
|
|
}
|
2009-07-19 18:41:42 +02:00
|
|
|
}
|
2006-10-04 00:59:07 +02:00
|
|
|
}
|
|
|
|
|
2006-11-15 01:53:59 +01:00
|
|
|
function onClickableCellsDblClick(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
newEvent(this, 'event');
|
2006-11-15 18:59:47 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
Event.stop(event);
|
2006-11-15 01:53:59 +01:00
|
|
|
}
|
|
|
|
|
2007-11-16 20:38:49 +01:00
|
|
|
function refreshCalendarEvents(scrollEvent) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var todayDate = new Date();
|
|
|
|
var sd;
|
|
|
|
var ed;
|
2009-08-27 18:51:30 +02:00
|
|
|
|
|
|
|
if (!currentDay)
|
|
|
|
currentDay = todayDate.getDayString();
|
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (currentView == "dayview") {
|
2009-08-27 18:51:30 +02:00
|
|
|
sd = currentDay;
|
2009-07-19 18:41:42 +02:00
|
|
|
ed = sd;
|
|
|
|
}
|
|
|
|
else if (currentView == "weekview") {
|
|
|
|
var startDate;
|
2009-08-27 18:51:30 +02:00
|
|
|
startDate = currentDay.asDate();
|
2009-07-19 18:41:42 +02:00
|
|
|
startDate = startDate.beginOfWeek();
|
|
|
|
sd = startDate.getDayString();
|
|
|
|
var endDate = new Date();
|
|
|
|
endDate.setTime(startDate.getTime());
|
|
|
|
endDate.addDays(6);
|
|
|
|
ed = endDate.getDayString();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
var monthDate;
|
2009-08-27 18:51:30 +02:00
|
|
|
monthDate = currentDay.asDate();
|
2009-07-19 18:41:42 +02:00
|
|
|
monthDate.setDate(1);
|
|
|
|
sd = monthDate.beginOfWeek().getDayString();
|
|
|
|
|
|
|
|
var lastMonthDate = new Date();
|
|
|
|
lastMonthDate.setTime(monthDate.getTime());
|
|
|
|
lastMonthDate.setMonth(monthDate.getMonth() + 1);
|
|
|
|
lastMonthDate.addDays(-1);
|
|
|
|
ed = lastMonthDate.endOfWeek().getDayString();
|
|
|
|
}
|
|
|
|
if (document.refreshCalendarEventsAjaxRequest) {
|
|
|
|
document.refreshCalendarEventsAjaxRequest.aborted = true;
|
|
|
|
document.refreshCalendarEventsAjaxRequest.abort();
|
|
|
|
}
|
|
|
|
var url = (ApplicationBaseURL + "eventsblocks?sd=" + sd + "&ed=" + ed
|
|
|
|
+ "&view=" + currentView);
|
|
|
|
document.refreshCalendarEventsAjaxRequest
|
|
|
|
= triggerAjaxRequest(url, refreshCalendarEventsCallback,
|
|
|
|
{"startDate": sd, "endDate": ed,
|
|
|
|
"scrollEvent": scrollEvent});
|
2007-06-11 23:23:48 +02:00
|
|
|
}
|
|
|
|
|
2008-07-29 18:35:49 +02:00
|
|
|
function _parseEvents(list) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var newCalendarEvents = {};
|
|
|
|
|
|
|
|
for (var i = 0; i < list.length; i++) {
|
|
|
|
var event = list[i];
|
|
|
|
var cname = event[0];
|
|
|
|
var calendar = event[1];
|
|
|
|
// log("parsed cname: " + cname + "; calendar: " + calendar);
|
|
|
|
var calendarDict = newCalendarEvents[calendar];
|
|
|
|
if (!calendarDict) {
|
|
|
|
calendarDict = {};
|
|
|
|
newCalendarEvents[calendar] = calendarDict;
|
|
|
|
}
|
|
|
|
var occurences = calendarDict[cname];
|
|
|
|
if (!occurences) {
|
|
|
|
occurences = [];
|
|
|
|
calendarDict[cname] = occurences;
|
|
|
|
}
|
|
|
|
event.blocks = [];
|
|
|
|
occurences.push(event);
|
2008-07-29 18:35:49 +02:00
|
|
|
}
|
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return newCalendarEvents;
|
2008-07-29 18:35:49 +02:00
|
|
|
}
|
|
|
|
|
2007-06-11 23:23:48 +02:00
|
|
|
function refreshCalendarEventsCallback(http) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (http.readyState == 4
|
|
|
|
&& http.status == 200) {
|
|
|
|
if (http.responseText.length > 0) {
|
|
|
|
var eventsBlocks = http.responseText.evalJSON(true);
|
|
|
|
calendarEvents = _parseEvents(eventsBlocks[0]);
|
|
|
|
if (currentView == "monthview")
|
|
|
|
_drawMonthCalendarEvents(eventsBlocks[2], eventsBlocks[0]);
|
|
|
|
else {
|
|
|
|
_drawCalendarAllDayEvents(eventsBlocks[1], eventsBlocks[0]);
|
|
|
|
_drawCalendarEvents(eventsBlocks[2], eventsBlocks[0]);
|
|
|
|
}
|
|
|
|
onWindowResize(null);
|
|
|
|
}
|
|
|
|
scrollDayView(http.callbackData["scrollEvent"]);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
log("AJAX error when refreshing calendar events");
|
2008-07-16 04:12:18 +02:00
|
|
|
}
|
2008-04-15 22:12:51 +02:00
|
|
|
|
2008-07-17 23:12:43 +02:00
|
|
|
function newBaseEventDIV(eventRep, event, eventText) {
|
2009-07-19 18:41:42 +02:00
|
|
|
// log ("0 cname = " + event[0]);
|
|
|
|
// log ("1 calendar = " + event[1]);
|
|
|
|
// log ("2 status = " + event[2]);
|
|
|
|
// log ("3 title = " + event[3]);
|
|
|
|
// log ("4 start = " + event[4]);
|
|
|
|
// log ("5 end = " + event[5]);
|
|
|
|
// log ("6 location = " + event[6]);
|
|
|
|
// log ("7 isallday = " + event[7]);
|
|
|
|
// log ("8 classification = " + event[8]);
|
|
|
|
// log ("9 participants emails = " + event[9]);
|
|
|
|
// log ("10 participants states = " + event[10]);
|
|
|
|
// log ("11 owner = " + event[11]);
|
|
|
|
// log ("12 iscycle = " + event[12]);
|
|
|
|
// log ("13 nextalarm = " + event[13]);
|
|
|
|
// log ("14 recurrenceid = " + event[14]);
|
|
|
|
// log ("15 isexception = " + event[15]);
|
|
|
|
|
|
|
|
var eventDiv = $(document.createElement("div"));
|
|
|
|
eventDiv.cname = event[0];
|
|
|
|
eventDiv.calendar = event[1];
|
|
|
|
if (eventRep.recurrenceTime)
|
|
|
|
eventDiv.recurrenceTime = eventRep.recurrenceTime;
|
|
|
|
eventDiv.isException = event[15];
|
|
|
|
eventDiv.addClassName("event");
|
|
|
|
if (event[13] > 0)
|
|
|
|
eventDiv.addClassName("alarm");
|
|
|
|
|
|
|
|
var innerDiv = $(document.createElement("div"));
|
|
|
|
eventDiv.appendChild(innerDiv);
|
|
|
|
innerDiv.addClassName("eventInside");
|
|
|
|
innerDiv.addClassName("calendarFolder" + event[1]);
|
|
|
|
if (eventRep.userState >= 0 && userStates[eventRep.userState])
|
|
|
|
innerDiv.addClassName(userStates[eventRep.userState]);
|
|
|
|
|
|
|
|
var gradientDiv = $(document.createElement("div"));
|
|
|
|
innerDiv.appendChild(gradientDiv);
|
|
|
|
gradientDiv.addClassName("gradient");
|
|
|
|
|
|
|
|
var gradientImg = $(document.createElement("img"));
|
|
|
|
gradientDiv.appendChild(gradientImg);
|
|
|
|
gradientImg.src = ResourcesURL + "/event-gradient.png";
|
|
|
|
|
|
|
|
var textDiv = $(document.createElement("div"));
|
|
|
|
innerDiv.appendChild(textDiv);
|
|
|
|
textDiv.addClassName("text");
|
2009-07-22 00:53:15 +02:00
|
|
|
textDiv.update(eventText.replace(/(\\r)?\\n/g, "<BR/>"));
|
2009-07-19 18:41:42 +02:00
|
|
|
|
2009-07-27 21:30:05 +02:00
|
|
|
if (event[2] == null) {
|
|
|
|
eventDiv.observe("selectstart", listRowMouseDownHandler);
|
2009-08-20 21:30:06 +02:00
|
|
|
eventDiv.observe("click", onCalendarSelectEvent);
|
2009-10-14 21:44:46 +02:00
|
|
|
eventDiv.observe("dblclick", Event.stop);
|
2009-07-27 21:30:05 +02:00
|
|
|
}
|
|
|
|
else {
|
2009-07-19 18:41:42 +02:00
|
|
|
// Status field is defined -- user can read event
|
|
|
|
eventDiv.observe("mousedown", listRowMouseDownHandler);
|
|
|
|
eventDiv.observe("click", onCalendarSelectEvent);
|
|
|
|
eventDiv.observe("dblclick", editDoubleClickedEvent);
|
|
|
|
eventDiv.observe("click", onViewEvent);
|
|
|
|
}
|
|
|
|
event.blocks.push(eventDiv);
|
|
|
|
|
|
|
|
return eventDiv;
|
2008-07-16 04:12:18 +02:00
|
|
|
}
|
2008-07-17 23:12:43 +02:00
|
|
|
|
2008-07-29 18:35:49 +02:00
|
|
|
function _drawCalendarAllDayEvents(events, eventsData) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var daysView = $("calendarHeader");
|
|
|
|
var subdivs = daysView.childNodesWithTag("div");
|
|
|
|
var days = subdivs[1].childNodesWithTag("div");
|
|
|
|
for (var i = 0; i < days.length; i++) {
|
|
|
|
var parentDiv = days[i];
|
|
|
|
for (var j = 0; j < events[i].length; j++) {
|
|
|
|
var eventRep = events[i][j];
|
|
|
|
var nbr = eventRep.nbr;
|
|
|
|
var eventDiv = newAllDayEventDIV(eventRep, eventsData[nbr]);
|
|
|
|
parentDiv.appendChild(eventDiv);
|
|
|
|
}
|
2008-07-29 18:35:49 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function newAllDayEventDIV(eventRep, event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
// cname, calendar, starts, lasts,
|
|
|
|
// startHour, endHour, title) {
|
|
|
|
var eventDiv = newBaseEventDIV(eventRep, event, event[3]);
|
2008-07-17 23:12:43 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return eventDiv;
|
2008-07-17 23:12:43 +02:00
|
|
|
}
|
2008-07-16 04:12:18 +02:00
|
|
|
|
2008-07-29 18:35:49 +02:00
|
|
|
function _drawCalendarEvents(events, eventsData) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var daysView = $("daysView");
|
|
|
|
var subdivs = daysView.childNodesWithTag("div");
|
|
|
|
var days = subdivs[1].childNodesWithTag("div");
|
|
|
|
for (var i = 0; i < days.length; i++) {
|
|
|
|
var parentDiv = days[i].childNodesWithTag("div")[0];
|
|
|
|
for (var j = 0; j < events[i].length; j++) {
|
|
|
|
var eventRep = events[i][j];
|
|
|
|
var nbr = eventRep.nbr;
|
|
|
|
var eventDiv = newEventDIV(eventRep, eventsData[nbr]);
|
|
|
|
parentDiv.appendChild(eventDiv);
|
|
|
|
}
|
2008-04-15 22:12:51 +02:00
|
|
|
}
|
2008-07-16 04:12:18 +02:00
|
|
|
}
|
|
|
|
|
2008-07-29 18:35:49 +02:00
|
|
|
function newEventDIV(eventRep, event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var eventDiv = newBaseEventDIV(eventRep, event, event[3]);
|
2008-07-16 04:12:18 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var pc = 100 / eventRep.siblings;
|
|
|
|
eventDiv.style.width = pc + "%";
|
|
|
|
var left = eventRep.position * pc;
|
|
|
|
eventDiv.style.left = left + "%";
|
|
|
|
eventDiv.addClassName("starts" + eventRep.start);
|
|
|
|
eventDiv.addClassName("lasts" + eventRep.length);
|
2008-03-27 22:05:47 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return eventDiv;
|
2007-11-16 20:38:49 +01:00
|
|
|
}
|
2007-11-07 18:37:58 +01:00
|
|
|
|
2008-07-29 18:35:49 +02:00
|
|
|
function _drawMonthCalendarEvents(events, eventsData) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var daysView = $("monthDaysView");
|
|
|
|
var days = daysView.childNodesWithTag("div");
|
|
|
|
for (var i = 0; i < days.length; i++) {
|
|
|
|
var parentDiv = days[i];
|
|
|
|
for (var j = 0; j < events[i].length; j++) {
|
|
|
|
var eventRep = events[i][j];
|
|
|
|
var nbr = eventRep.nbr;
|
|
|
|
var eventDiv = newMonthEventDIV(eventRep, eventsData[nbr]);
|
|
|
|
parentDiv.appendChild(eventDiv);
|
|
|
|
}
|
2008-07-16 04:12:18 +02:00
|
|
|
}
|
2007-06-11 23:23:48 +02:00
|
|
|
}
|
|
|
|
|
2008-07-29 18:35:49 +02:00
|
|
|
function newMonthEventDIV(eventRep, event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var eventText;
|
|
|
|
if (event[7]) // all-day event
|
|
|
|
eventText = event[3];
|
|
|
|
else
|
|
|
|
eventText = eventRep.starthour + " - " + event[3];
|
2008-01-24 22:36:51 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var eventDiv = newBaseEventDIV(eventRep, event,
|
|
|
|
eventText);
|
2008-07-16 04:12:18 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return eventDiv;
|
2007-06-11 23:23:48 +02:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function calendarDisplayCallback(http) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var div = $("calendarView");
|
2009-08-18 20:23:13 +02:00
|
|
|
var daysView = $("daysView");
|
|
|
|
var position = -1;
|
|
|
|
|
2009-08-27 18:51:30 +02:00
|
|
|
// Check the previous view to restore the scrolling position
|
2009-08-18 20:23:13 +02:00
|
|
|
if (daysView)
|
|
|
|
position = daysView.scrollTop;
|
2009-08-27 18:51:30 +02:00
|
|
|
preventAutoScroll = (position != -1);
|
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (http.readyState == 4
|
|
|
|
&& http.status == 200) {
|
|
|
|
document.dayDisplayAjaxRequest = null;
|
|
|
|
div.update(http.responseText);
|
|
|
|
|
2009-08-18 20:23:13 +02:00
|
|
|
// DOM has changed
|
2009-08-20 19:27:08 +02:00
|
|
|
daysView = $("daysView");
|
|
|
|
if (preventAutoScroll && daysView)
|
|
|
|
daysView.scrollTop = position;
|
2009-08-18 20:23:13 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (http.callbackData["view"])
|
|
|
|
currentView = http.callbackData["view"];
|
|
|
|
if (http.callbackData["day"])
|
|
|
|
currentDay = http.callbackData["day"];
|
|
|
|
|
|
|
|
// Initialize contextual menu
|
|
|
|
var menu;
|
|
|
|
var observer;
|
|
|
|
if (currentView == 'dayview') {
|
|
|
|
menu = new Array(onMenuNewEventClick,
|
|
|
|
onMenuNewTaskClick,
|
|
|
|
"-",
|
|
|
|
loadPreviousView,
|
|
|
|
loadNextView);
|
|
|
|
observer = $("daysView");
|
|
|
|
}
|
|
|
|
else if (currentView == 'weekview') {
|
|
|
|
menu = new Array(onMenuNewEventClick,
|
|
|
|
onMenuNewTaskClick,
|
|
|
|
"-",
|
|
|
|
loadPreviousView,
|
|
|
|
loadNextView);
|
|
|
|
observer = $("daysView");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
menu = new Array(onMenuNewEventClick,
|
|
|
|
onMenuNewTaskClick,
|
|
|
|
"-",
|
|
|
|
loadPreviousView,
|
|
|
|
loadNextView);
|
|
|
|
observer = $("monthDaysView");
|
|
|
|
}
|
|
|
|
initMenu($("currentViewMenu"), menu);
|
2009-07-28 22:09:24 +02:00
|
|
|
observer.observe("contextmenu", onMenuCurrentView);
|
2009-07-15 20:26:08 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var contentView;
|
|
|
|
if (currentView == "monthview")
|
|
|
|
contentView = $("calendarContent");
|
|
|
|
else {
|
|
|
|
contentView = $("daysView");
|
|
|
|
contentView.observe("scroll", onBodyClickHandler);
|
|
|
|
}
|
2008-08-19 00:45:59 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
refreshCalendarEvents(http.callbackData.scrollEvent);
|
2007-11-16 20:38:49 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var days = contentView.select("DIV.day");
|
|
|
|
|
|
|
|
if (currentView == "monthview")
|
|
|
|
for (var i = 0; i < days.length; i++) {
|
|
|
|
days[i].observe("click", onCalendarSelectDay);
|
|
|
|
days[i].observe("dblclick", onClickableCellsDblClick);
|
|
|
|
days[i].observe("selectstart", listRowMouseDownHandler);
|
|
|
|
//days[i].down(".dayHeader").observe("selectstart", listRowMouseDownHandler);
|
|
|
|
if (currentView == "monthview")
|
|
|
|
days[i].observe("scroll", onBodyClickHandler);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
var calendarHeader = $("calendarHeader");
|
|
|
|
var headerDaysLabels = calendarHeader.select("DIV.dayLabels DIV.day");
|
|
|
|
var headerDays = calendarHeader.select("DIV.days DIV.day");
|
|
|
|
for (var i = 0; i < days.length; i++) {
|
|
|
|
headerDays[i].hour = "allday";
|
|
|
|
headerDaysLabels[i].observe("mousedown", listRowMouseDownHandler);
|
|
|
|
headerDays[i].observe("click", onCalendarSelectDay);
|
|
|
|
headerDays[i].observe("dblclick", onClickableCellsDblClick);
|
|
|
|
days[i].observe("click", onCalendarSelectDay);
|
|
|
|
|
|
|
|
var clickableCells = days[i].select("DIV.clickableHourCell");
|
|
|
|
for (var j = 0; j < clickableCells.length; j++)
|
|
|
|
clickableCells[j].observe("dblclick", onClickableCellsDblClick);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
log ("calendarDisplayCallback Ajax error ("
|
|
|
|
+ http.readyState + "/" + http.status + ")");
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2007-03-18 16:00:34 +01:00
|
|
|
function assignCalendar(name) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (typeof(skycalendar) != "undefined") {
|
|
|
|
var node = $(name);
|
2009-07-23 22:11:06 +02:00
|
|
|
if (node) {
|
|
|
|
node.calendar = new skycalendar(node);
|
|
|
|
node.calendar.setCalendarPage(ResourcesURL + "/skycalendar.html");
|
|
|
|
var dateFormat = node.getAttribute("dateFormat");
|
|
|
|
if (dateFormat)
|
2009-07-19 18:41:42 +02:00
|
|
|
node.calendar.setDateFormat(dateFormat);
|
2009-07-23 22:11:06 +02:00
|
|
|
}
|
2009-07-19 18:41:42 +02:00
|
|
|
}
|
2006-08-31 01:13:18 +02:00
|
|
|
}
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2007-03-18 16:00:34 +01:00
|
|
|
function popupCalendar(node) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var nodeId = $(node).readAttribute("inputId");
|
|
|
|
var input = $(nodeId);
|
|
|
|
input.calendar.popup();
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2007-06-08 01:23:07 +02:00
|
|
|
function onEventsSelectionChange() {
|
2009-07-19 18:41:42 +02:00
|
|
|
listOfSelection = this;
|
|
|
|
this.removeClassName("_unfocused");
|
|
|
|
$("tasksList").addClassName("_unfocused");
|
|
|
|
|
|
|
|
var rows = $(this.tBodies[0]).getSelectedNodes();
|
|
|
|
if (rows.length == 1) {
|
|
|
|
var row = rows[0];
|
|
|
|
changeCalendarDisplay( { "day": row.day,
|
|
|
|
"scrollEvent": row.getAttribute("id") } );
|
|
|
|
changeDateSelectorDisplay(row.day);
|
|
|
|
}
|
2006-10-12 23:05:32 +02:00
|
|
|
}
|
|
|
|
|
2006-11-09 23:55:04 +01:00
|
|
|
function onTasksSelectionChange() {
|
2009-07-19 18:41:42 +02:00
|
|
|
listOfSelection = this;
|
|
|
|
this.removeClassName("_unfocused");
|
|
|
|
$("eventsList").addClassName("_unfocused");
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2007-06-08 01:23:07 +02:00
|
|
|
function _loadEventHref(href) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (document.eventsListAjaxRequest) {
|
|
|
|
document.eventsListAjaxRequest.aborted = true;
|
|
|
|
document.eventsListAjaxRequest.abort();
|
|
|
|
}
|
|
|
|
var url = ApplicationBaseURL + href;
|
|
|
|
document.eventsListAjaxRequest
|
|
|
|
= triggerAjaxRequest(url, eventsListCallback, href);
|
2007-06-08 01:23:07 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var table = $("eventsList").tBodies[0];
|
|
|
|
while (table.rows.length > 0)
|
|
|
|
table.removeChild(table.rows[0]);
|
2006-08-19 00:40:04 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2006-10-11 20:12:02 +02:00
|
|
|
function _loadTasksHref(href) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (document.tasksListAjaxRequest) {
|
|
|
|
document.tasksListAjaxRequest.aborted = true;
|
|
|
|
document.tasksListAjaxRequest.abort();
|
|
|
|
}
|
|
|
|
url = ApplicationBaseURL + href;
|
2006-10-11 20:12:02 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var tasksList = $("tasksList");
|
|
|
|
var selectedIds;
|
|
|
|
if (tasksList)
|
|
|
|
selectedIds = tasksList.getSelectedNodesId();
|
|
|
|
else
|
|
|
|
selectedIds = null;
|
|
|
|
document.tasksListAjaxRequest
|
|
|
|
= triggerAjaxRequest(url, tasksListCallback, selectedIds);
|
2006-10-11 20:12:02 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
tasksList.previousScroll = tasksList.scrollTop;
|
|
|
|
while (tasksList.childNodes.length)
|
|
|
|
tasksList.removeChild(tasksList.childNodes[0]);
|
2007-06-08 01:23:07 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return true;
|
2006-10-11 20:12:02 +02:00
|
|
|
}
|
|
|
|
|
2006-11-09 23:55:04 +01:00
|
|
|
function onHeaderClick(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var headerId = this.getAttribute("id");
|
|
|
|
var newSortAttribute;
|
|
|
|
if (headerId == "titleHeader")
|
|
|
|
newSortAttribute = "title";
|
|
|
|
else if (headerId == "startHeader")
|
|
|
|
newSortAttribute = "start";
|
|
|
|
else if (headerId == "endHeader")
|
|
|
|
newSortAttribute = "end";
|
|
|
|
else if (headerId == "locationHeader")
|
|
|
|
newSortAttribute = "location";
|
|
|
|
else
|
|
|
|
newSortAttribute = "start";
|
2007-12-06 18:29:32 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (sorting["attribute"] == newSortAttribute)
|
|
|
|
sorting["ascending"] = !sorting["ascending"];
|
|
|
|
else {
|
|
|
|
sorting["attribute"] = newSortAttribute;
|
|
|
|
sorting["ascending"] = true;
|
|
|
|
}
|
|
|
|
refreshEvents();
|
2006-11-09 23:55:04 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
Event.stop(event);
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
|
|
|
|
2007-11-21 18:23:51 +01:00
|
|
|
function refreshCurrentFolder() {
|
2009-07-19 18:41:42 +02:00
|
|
|
refreshEvents();
|
2007-11-21 18:23:51 +01:00
|
|
|
}
|
|
|
|
|
2007-06-08 01:23:07 +02:00
|
|
|
function refreshEvents() {
|
2009-07-19 18:41:42 +02:00
|
|
|
var titleSearch;
|
|
|
|
var value = search["value"];
|
|
|
|
if (value && value.length)
|
|
|
|
titleSearch = "&search=" + escape(value.utf8encode());
|
|
|
|
else
|
|
|
|
titleSearch = "";
|
2009-04-22 23:02:11 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
refreshAlarms();
|
2009-04-22 23:02:11 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return _loadEventHref("eventslist?asc=" + sorting["ascending"]
|
|
|
|
+ "&sort=" + sorting["attribute"]
|
|
|
|
+ "&day=" + currentDay
|
|
|
|
+ titleSearch
|
|
|
|
+ "&filterpopup=" + listFilter);
|
2006-08-19 00:40:04 +02:00
|
|
|
}
|
2006-08-22 00:36:33 +02:00
|
|
|
|
2009-08-17 22:07:54 +02:00
|
|
|
function refreshTasks(setUserDefault) {
|
|
|
|
var url = "taskslist?show-completed=" + showCompletedTasks;
|
|
|
|
if (setUserDefault == 1)
|
|
|
|
url += "&setud=1";
|
2009-07-19 18:41:42 +02:00
|
|
|
refreshAlarms();
|
2009-08-17 22:07:54 +02:00
|
|
|
return _loadTasksHref(url);
|
2006-10-11 20:12:02 +02:00
|
|
|
}
|
|
|
|
|
2007-06-08 01:23:07 +02:00
|
|
|
function refreshEventsAndDisplay() {
|
2009-07-19 18:41:42 +02:00
|
|
|
refreshEvents();
|
|
|
|
changeCalendarDisplay();
|
2006-10-18 23:53:47 +02:00
|
|
|
}
|
|
|
|
|
2006-08-22 00:36:33 +02:00
|
|
|
function onListFilterChange() {
|
2009-07-19 18:41:42 +02:00
|
|
|
var node = $("filterpopup");
|
2006-08-22 00:36:33 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
listFilter = node.value;
|
|
|
|
// log ("listFilter = " + listFilter);
|
2006-08-22 00:36:33 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return refreshEvents();
|
2006-08-22 00:36:33 +02:00
|
|
|
}
|
2006-08-22 21:18:30 +02:00
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function selectMonthInMenu(menu, month) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var entries = $(menu).select("LI");
|
|
|
|
for (i = 0; i < entries.length; i++) {
|
|
|
|
var entry = entries[i];
|
|
|
|
var entryMonth = entry.getAttribute("month");
|
|
|
|
if (entryMonth == month)
|
|
|
|
entry.addClassName("currentMonth");
|
|
|
|
else
|
|
|
|
entry.removeClassName("currentMonth");
|
|
|
|
}
|
2006-08-22 21:18:30 +02:00
|
|
|
}
|
|
|
|
|
2008-12-11 18:25:19 +01:00
|
|
|
function selectYearInMenu(menu, year) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var entries = $(menu).select("LI");
|
|
|
|
for (i = 0; i < entries.length; i++) {
|
|
|
|
var entry = entries[i];
|
|
|
|
var entryYear = entry.innerHTML.strip();
|
|
|
|
if (entryYear == year)
|
|
|
|
entry.addClassName("currentMonth");
|
|
|
|
else
|
|
|
|
entry.removeClassName("currentMonth");
|
|
|
|
}
|
2006-08-22 21:18:30 +02:00
|
|
|
}
|
|
|
|
|
2007-07-05 21:13:59 +02:00
|
|
|
function popupMonthMenu(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (event.button == 0) {
|
|
|
|
var id = this.getAttribute("id");
|
|
|
|
if (id == "monthLabel")
|
|
|
|
menuId = "monthListMenu";
|
|
|
|
else
|
|
|
|
menuId = "yearListMenu";
|
|
|
|
|
|
|
|
var popup = $(menuId);
|
|
|
|
if (id == "monthLabel")
|
|
|
|
selectMonthInMenu(popup, this.getAttribute("month"));
|
|
|
|
else
|
|
|
|
selectYearInMenu(popup, this.innerHTML);
|
|
|
|
|
|
|
|
popupToolbarMenu(this, menuId);
|
|
|
|
Event.stop(event);
|
|
|
|
}
|
2006-08-22 21:18:30 +02:00
|
|
|
}
|
|
|
|
|
2007-05-22 16:38:54 +02:00
|
|
|
function onMonthMenuItemClick(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var month = '' + this.getAttribute("month");
|
|
|
|
var year = '' + $("yearLabel").innerHTML.strip();
|
2006-08-22 21:18:30 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
changeDateSelectorDisplay(year + month + "01", true);
|
2006-08-22 21:18:30 +02:00
|
|
|
}
|
|
|
|
|
2007-05-22 16:38:54 +02:00
|
|
|
function onYearMenuItemClick(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var month = '' + $("monthLabel").getAttribute("month");;
|
|
|
|
var year = '' + this.innerHTML.strip();
|
2006-08-22 21:18:30 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
changeDateSelectorDisplay(year + month + "01", true);
|
2006-08-22 21:18:30 +02:00
|
|
|
}
|
2006-08-31 01:13:18 +02:00
|
|
|
|
2008-07-29 18:35:49 +02:00
|
|
|
function _eventBlocksMatching(calendar, cname, recurrenceTime) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var blocks = null;
|
|
|
|
|
|
|
|
var events = calendarEvents[calendar];
|
|
|
|
if (events) {
|
|
|
|
var occurences = events[cname];
|
|
|
|
if (occurences) {
|
|
|
|
if (recurrenceTime) {
|
|
|
|
for (var i = 0; i < occurences.length; i++) {
|
|
|
|
var occurence = occurences[i];
|
|
|
|
if (occurence[14] == recurrenceTime)
|
|
|
|
blocks = occurence.blocks;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
blocks = [];
|
|
|
|
for (var i = 0; i < occurences.length; i++) {
|
|
|
|
var occurence = occurences[i];
|
|
|
|
blocks = blocks.concat(occurence.blocks);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return blocks;
|
2008-07-29 18:35:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function selectCalendarEvent(calendar, cname, recurrenceTime) {
|
2009-07-19 18:41:42 +02:00
|
|
|
// Select event in calendar view
|
|
|
|
if (selectedCalendarCell)
|
|
|
|
for (var i = 0; i < selectedCalendarCell.length; i++)
|
|
|
|
selectedCalendarCell[i].deselect();
|
|
|
|
|
|
|
|
var selection = _eventBlocksMatching(calendar, cname, recurrenceTime);
|
|
|
|
if (selection) {
|
|
|
|
for (var i = 0; i < selection.length; i++)
|
|
|
|
selection[i].selectElement();
|
|
|
|
selectedCalendarCell = selection;
|
|
|
|
}
|
2008-08-19 00:45:59 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return selection;
|
2007-11-19 18:09:14 +01:00
|
|
|
}
|
|
|
|
|
2009-10-14 21:44:46 +02:00
|
|
|
function onCalendarSelectEvent(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
selectCalendarEvent(this.calendar, this.cname, this.recurrenceTime);
|
|
|
|
|
|
|
|
// Select event in events list
|
|
|
|
var list = $("eventsList");
|
|
|
|
$(list.tBodies[0]).deselectAll();
|
|
|
|
var rowID = this.calendar + "-" + this.cname;
|
|
|
|
if (this.recurrenceTime)
|
|
|
|
rowID += "-" + this.recurrenceTime;
|
|
|
|
var row = $(rowID);
|
|
|
|
if (row) {
|
|
|
|
var div = row.parentNode.parentNode.parentNode;
|
|
|
|
div.scrollTop = row.offsetTop - (div.offsetHeight / 2);
|
|
|
|
row.selectElement();
|
|
|
|
}
|
2006-09-07 00:27:46 +02:00
|
|
|
}
|
|
|
|
|
2006-12-19 20:17:35 +01:00
|
|
|
function onCalendarSelectDay(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var day = this.getAttribute("day");
|
|
|
|
var needRefresh = (listFilter == 'view_selectedday'
|
|
|
|
&& day != currentDay);
|
|
|
|
|
|
|
|
if (currentView == 'weekview')
|
|
|
|
changeWeekCalendarDisplayOfSelectedDay(this);
|
|
|
|
else if (currentView == 'monthview')
|
|
|
|
changeMonthCalendarDisplayOfSelectedDay(this);
|
|
|
|
changeDateSelectorDisplay(day);
|
|
|
|
|
|
|
|
if (listOfSelection) {
|
|
|
|
listOfSelection.addClassName("_unfocused");
|
|
|
|
listOfSelection = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (needRefresh)
|
|
|
|
refreshEvents();
|
2009-08-20 20:35:55 +02:00
|
|
|
|
|
|
|
changeCalendarDisplay( { "day": currentDay } );
|
2006-09-07 00:27:46 +02:00
|
|
|
}
|
2006-10-11 20:12:02 +02:00
|
|
|
|
2006-12-19 20:17:35 +01:00
|
|
|
function changeWeekCalendarDisplayOfSelectedDay(node) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var daysView = $("daysView");
|
|
|
|
var daysDiv = daysView.childNodesWithTag("div");
|
|
|
|
var days = daysDiv[1].childNodesWithTag("div");
|
|
|
|
var headerDiv = $($("calendarHeader").childNodesWithTag("div")[1]);
|
|
|
|
var headerDays = headerDiv.childNodesWithTag("div");
|
|
|
|
|
|
|
|
for (var i = 0; i < days.length; i++) {
|
|
|
|
if (days[i] == node
|
|
|
|
|| headerDays[i] == node) {
|
|
|
|
headerDays[i].addClassName("selectedDay");
|
|
|
|
days[i].addClassName("selectedDay");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
headerDays[i].removeClassName("selectedDay");
|
|
|
|
days[i].removeClassName("selectedDay");
|
|
|
|
}
|
2008-07-16 04:12:18 +02:00
|
|
|
}
|
2006-10-31 23:59:57 +01:00
|
|
|
}
|
|
|
|
|
2007-03-13 00:06:48 +01:00
|
|
|
function findMonthCalendarSelectedCell(daysContainer) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var found = false;
|
|
|
|
var i = 0;
|
|
|
|
|
|
|
|
while (!found && i < daysContainer.childNodes.length) {
|
|
|
|
var currentNode = daysContainer.childNodes[i];
|
|
|
|
if (currentNode.tagName == 'DIV'
|
|
|
|
&& currentNode.hasClassName("selectedDay")) {
|
|
|
|
daysContainer.selectedCell = currentNode;
|
|
|
|
found = true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
i++;
|
2008-01-24 22:36:51 +01:00
|
|
|
}
|
2006-11-03 00:17:55 +01:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function changeMonthCalendarDisplayOfSelectedDay(node) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var daysContainer = node.parentNode;
|
|
|
|
if (!daysContainer.selectedCell)
|
|
|
|
findMonthCalendarSelectedCell(daysContainer);
|
2007-03-13 00:06:48 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (daysContainer.selectedCell)
|
|
|
|
daysContainer.selectedCell.removeClassName("selectedDay");
|
|
|
|
daysContainer.selectedCell = node;
|
|
|
|
node.addClassName("selectedDay");
|
2006-11-03 00:17:55 +01:00
|
|
|
}
|
|
|
|
|
2007-06-08 01:23:07 +02:00
|
|
|
function onShowCompletedTasks(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
showCompletedTasks = (this.checked ? 1 : 0);
|
2006-10-11 20:12:02 +02:00
|
|
|
|
2009-08-17 22:07:54 +02:00
|
|
|
return refreshTasks(1);
|
2006-10-11 20:12:02 +02:00
|
|
|
}
|
|
|
|
|
2007-06-06 23:09:39 +02:00
|
|
|
function updateTaskStatus(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var newStatus = (this.checked ? 1 : 0);
|
|
|
|
|
|
|
|
if (isSafari() && !isSafari3()) {
|
|
|
|
newStatus = (newStatus ? 0 : 1);
|
|
|
|
}
|
2009-08-25 19:34:37 +02:00
|
|
|
_updateTaskCompletion (this.parentNode, newStatus);
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2006-10-11 20:12:02 +02:00
|
|
|
}
|
2006-10-14 01:37:27 +02:00
|
|
|
|
2007-03-29 20:05:23 +02:00
|
|
|
function updateCalendarStatus(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var list = [];
|
|
|
|
var newStatus = (this.checked ? 1 : 0);
|
2007-10-02 17:29:16 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (isSafari() && !isSafari3()) {
|
|
|
|
newStatus = (newStatus ? 0 : 1);
|
|
|
|
this.checked = newStatus;
|
|
|
|
}
|
2006-10-14 01:37:27 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var nodes = $("calendarList").childNodesWithTag("li");
|
|
|
|
for (var i = 0; i < nodes.length; i++) {
|
|
|
|
var input = $(nodes[i]).childNodesWithTag("input")[0];
|
|
|
|
if (input.checked) {
|
|
|
|
var folderId = nodes[i].getAttribute("id");
|
|
|
|
var elems = folderId.split(":");
|
|
|
|
if (elems.length > 1)
|
|
|
|
list.push(elems[0]);
|
|
|
|
else
|
|
|
|
list.push(UserLogin);
|
|
|
|
}
|
|
|
|
}
|
2006-10-14 01:37:27 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
// if (!list.length) {
|
|
|
|
// list.push(UserLogin);
|
|
|
|
// nodes[0].childNodesWithTag("input")[0].checked = true;
|
|
|
|
// }
|
|
|
|
|
|
|
|
// ApplicationBaseURL = (UserFolderURL + "Groups/_custom_"
|
|
|
|
// + list.join(",") + "/Calendar/");
|
|
|
|
|
|
|
|
if (event) {
|
|
|
|
var folderID = this.parentNode.getAttribute("id");
|
|
|
|
var urlstr = URLForFolderID(folderID);
|
|
|
|
if (newStatus)
|
|
|
|
urlstr += "/activateFolder";
|
|
|
|
else
|
|
|
|
urlstr += "/deactivateFolder";
|
|
|
|
//log("updateCalendarStatus: ajax request = " + urlstr + ", folderID = " + folderID);
|
|
|
|
triggerAjaxRequest(urlstr, calendarStatusCallback, folderID);
|
2007-10-02 17:29:16 +02:00
|
|
|
}
|
|
|
|
else {
|
2009-07-19 18:41:42 +02:00
|
|
|
updateCalendarsList();
|
|
|
|
refreshEvents();
|
|
|
|
refreshTasks();
|
|
|
|
changeCalendarDisplay();
|
2007-10-02 17:29:16 +02:00
|
|
|
}
|
2009-07-19 18:41:42 +02:00
|
|
|
|
|
|
|
return false;
|
2006-10-14 01:37:27 +02:00
|
|
|
}
|
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
function calendarStatusCallback(http) {
|
|
|
|
if (http.readyState == 4) {
|
|
|
|
if (isHttpStatus204(http.status)) {
|
|
|
|
refreshEvents();
|
|
|
|
refreshTasks();
|
|
|
|
changeCalendarDisplay();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
var folder = $(http.callbackData);
|
|
|
|
var input = folder.childNodesWithTag("input")[0];
|
|
|
|
input.checked = (!input.checked);
|
|
|
|
}
|
|
|
|
}
|
2008-01-24 22:36:51 +01:00
|
|
|
else
|
2009-07-19 18:41:42 +02:00
|
|
|
log("calendarStatusCallback Ajax error");
|
|
|
|
}
|
|
|
|
|
|
|
|
function calendarEntryCallback(http) {
|
|
|
|
if (http.readyState == 4) {
|
|
|
|
var denied = !isHttpStatus204(http.status);
|
|
|
|
var entry = $(http.callbackData);
|
|
|
|
if (denied)
|
|
|
|
entry.addClassName("denied");
|
|
|
|
else
|
|
|
|
entry.removeClassName("denied");
|
|
|
|
}
|
2006-12-20 17:45:52 +01:00
|
|
|
}
|
|
|
|
|
2007-03-19 15:31:49 +01:00
|
|
|
function updateCalendarsList(method) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var list = $("calendarList").childNodesWithTag("li");
|
|
|
|
for (var i = 0; i < list.length; i++) {
|
|
|
|
var folderID = list[i].getAttribute("id");
|
|
|
|
var url = URLForFolderID(folderID) + "/canAccessContent";
|
|
|
|
triggerAjaxRequest(url, calendarEntryCallback, folderID);
|
|
|
|
}
|
2006-10-14 01:37:27 +02:00
|
|
|
}
|
|
|
|
|
2006-10-23 23:37:53 +02:00
|
|
|
function validateBrowseURL(input) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var button = $("browseURLBtn");
|
2006-10-23 23:37:53 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (input.value.length) {
|
|
|
|
if (!button.enabled)
|
|
|
|
enableAnchor(button);
|
|
|
|
} else if (!button.disabled)
|
|
|
|
disableAnchor(button);
|
2006-10-23 23:37:53 +02:00
|
|
|
}
|
|
|
|
|
2006-12-14 22:20:13 +01:00
|
|
|
function browseURL(anchor, event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (event.button == 0) {
|
|
|
|
var input = $("url");
|
|
|
|
var url = input.value;
|
|
|
|
if (url.length)
|
|
|
|
window.open(url, '_blank');
|
|
|
|
}
|
2006-10-23 23:37:53 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return false;
|
2006-10-23 23:37:53 +02:00
|
|
|
}
|
2006-11-09 23:55:04 +01:00
|
|
|
|
2007-11-19 23:19:17 +01:00
|
|
|
function onCalendarsMenuPrepareVisibility() {
|
2009-07-19 18:41:42 +02:00
|
|
|
var folders = $("calendarList");
|
|
|
|
var selected = folders.getSelectedNodes();
|
|
|
|
if (selected.length > 0) {
|
|
|
|
var folderOwner = selected[0].getAttribute("owner");
|
|
|
|
var sharingOption = $(this).down("ul").childElements().last();
|
|
|
|
// Disable the "Sharing" option when calendar is not owned by user
|
|
|
|
if (folderOwner == UserLogin || IsSuperUser)
|
|
|
|
sharingOption.removeClassName("disabled");
|
|
|
|
else
|
|
|
|
sharingOption.addClassName("disabled");
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
2007-11-19 23:19:17 +01:00
|
|
|
}
|
|
|
|
|
2007-05-28 21:19:17 +02:00
|
|
|
function getMenus() {
|
2009-07-19 18:41:42 +02:00
|
|
|
var menus = {};
|
2007-05-28 21:19:17 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var dateMenu = [];
|
|
|
|
for (var i = 0; i < 12; i++)
|
|
|
|
dateMenu.push(onMonthMenuItemClick);
|
|
|
|
menus["monthListMenu"] = dateMenu;
|
2007-05-22 16:38:54 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
dateMenu = [];
|
|
|
|
for (var i = 0; i < 11; i++)
|
|
|
|
dateMenu.push(onYearMenuItemClick);
|
|
|
|
menus["yearListMenu"] = dateMenu;
|
2007-05-22 16:38:54 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
menus["eventsListMenu"] = new Array(onMenuNewEventClick, "-",
|
|
|
|
onMenuNewTaskClick,
|
|
|
|
editEvent, deleteEvent, "-",
|
|
|
|
onSelectAll, "-",
|
|
|
|
null, null);
|
|
|
|
menus["calendarsMenu"] = new Array(onCalendarModify,
|
|
|
|
"-",
|
|
|
|
onCalendarNew, onCalendarRemove,
|
2009-09-02 21:14:15 +02:00
|
|
|
"-", onCalendarExport, onCalendarImport,
|
|
|
|
null, "-", null, "-", onMenuSharing);
|
2009-07-19 18:41:42 +02:00
|
|
|
menus["searchMenu"] = new Array(setSearchCriteria);
|
2007-05-22 16:38:54 +02:00
|
|
|
|
2009-08-25 19:34:37 +02:00
|
|
|
menus["tasksListMenu"] = new Array (editEvent, newTask, "-",
|
|
|
|
marksTasksAsCompleted, deleteEvent);
|
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var calendarsMenu = $("calendarsMenu");
|
|
|
|
if (calendarsMenu)
|
|
|
|
calendarsMenu.prepareVisibility = onCalendarsMenuPrepareVisibility;
|
2007-11-19 23:19:17 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
return menus;
|
2006-12-14 22:20:13 +01:00
|
|
|
}
|
|
|
|
|
2009-08-25 19:34:37 +02:00
|
|
|
function newTask () {
|
|
|
|
return newEvent(this, 'task');
|
|
|
|
}
|
|
|
|
|
|
|
|
function marksTasksAsCompleted () {
|
|
|
|
var selectedTasks = $$("UL#tasksList LI._selected");
|
|
|
|
|
|
|
|
for (var i = 0; i < selectedTasks.length; i++) {
|
|
|
|
var task = selectedTasks[i];
|
|
|
|
_updateTaskCompletion (task, 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function _updateTaskCompletion (task, value) {
|
|
|
|
var checkBox = task.down ("INPUT");
|
|
|
|
url = (ApplicationBaseURL + task.calendar
|
|
|
|
+ "/" + task.cname + "/changeStatus?status=" + value);
|
|
|
|
|
|
|
|
triggerAjaxRequest(url, refreshTasks, null);
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2007-05-19 03:12:23 +02:00
|
|
|
function onMenuSharing(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if ($(this).hasClassName("disabled"))
|
|
|
|
return;
|
|
|
|
|
|
|
|
var folders = $("calendarList");
|
|
|
|
var selected = folders.getSelectedNodes()[0];
|
|
|
|
/* FIXME: activation of the context menu should preferably select the entry
|
|
|
|
above which the event has occured */
|
|
|
|
if (selected) {
|
|
|
|
var folderID = selected.getAttribute("id");
|
|
|
|
var urlstr = URLForFolderID(folderID) + "/acls";
|
|
|
|
|
|
|
|
openAclWindow(urlstr);
|
|
|
|
}
|
2006-12-14 22:20:13 +01:00
|
|
|
}
|
|
|
|
|
2009-07-28 22:09:24 +02:00
|
|
|
function onMenuCurrentView(event) {
|
|
|
|
popupMenu(event, 'currentViewMenu', this);
|
|
|
|
}
|
|
|
|
|
2006-11-09 23:55:04 +01:00
|
|
|
function configureDragHandles() {
|
2009-07-19 18:41:42 +02:00
|
|
|
var handle = $("verticalDragHandle");
|
|
|
|
if (handle) {
|
|
|
|
handle.addInterface(SOGoDragHandlesInterface);
|
|
|
|
handle.leftBlock = $("leftPanel");
|
|
|
|
handle.rightBlock = $("rightPanel");
|
|
|
|
}
|
2006-11-09 23:55:04 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
handle = $("rightDragHandle");
|
|
|
|
if (handle) {
|
|
|
|
handle.addInterface(SOGoDragHandlesInterface);
|
|
|
|
handle.upperBlock = $("eventsListView");
|
|
|
|
handle.lowerBlock = $("calendarView");
|
|
|
|
}
|
2006-11-09 23:55:04 +01:00
|
|
|
}
|
2006-12-14 22:20:13 +01:00
|
|
|
|
2007-03-29 20:05:23 +02:00
|
|
|
function initCalendarSelector() {
|
2009-07-19 18:41:42 +02:00
|
|
|
var selector = $("calendarSelector");
|
2009-07-28 22:09:24 +02:00
|
|
|
updateCalendarStatus(); // triggers the initial events refresh
|
2009-07-19 18:41:42 +02:00
|
|
|
selector.changeNotification = updateCalendarsList;
|
|
|
|
|
|
|
|
var list = $("calendarList");
|
|
|
|
list.multiselect = true;
|
|
|
|
var items = list.childNodesWithTag("li");
|
|
|
|
for (var i = 0; i < items.length; i++) {
|
|
|
|
var input = items[i].childNodesWithTag("input")[0];
|
|
|
|
$(input).observe("click", updateCalendarStatus);
|
|
|
|
items[i].observe("mousedown", listRowMouseDownHandler);
|
|
|
|
items[i].observe("selectstart", listRowMouseDownHandler);
|
|
|
|
items[i].observe("click", onRowClick);
|
|
|
|
items[i].observe("dblclick", onCalendarModify);
|
|
|
|
}
|
|
|
|
|
|
|
|
var links = $("calendarSelectorButtons").childNodesWithTag("a");
|
|
|
|
$(links[0]).observe("click", onCalendarNew);
|
2009-09-10 19:26:57 +02:00
|
|
|
$(links[1]).observe("click", onCalendarWebAdd);
|
|
|
|
$(links[2]).observe("click", onCalendarAdd);
|
|
|
|
$(links[3]).observe("click", onCalendarRemove);
|
2007-03-29 20:05:23 +02:00
|
|
|
}
|
|
|
|
|
2008-04-15 21:48:48 +02:00
|
|
|
function onCalendarModify(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var folders = $("calendarList");
|
|
|
|
var selected = folders.getSelectedNodes()[0];
|
|
|
|
var calendarID = selected.getAttribute("id");
|
|
|
|
var url = ApplicationBaseURL + calendarID + "/properties";
|
|
|
|
var windowID = sanitizeWindowName(calendarID + " properties");
|
2009-09-23 20:45:16 +02:00
|
|
|
var width = 310;
|
|
|
|
var height = 270;
|
|
|
|
if (UserSettings['Calendar']
|
|
|
|
&& UserSettings['Calendar']['WebCalendars']) {
|
|
|
|
var webCalendars = UserSettings['Calendar']['WebCalendars'];
|
|
|
|
var realID = calendarID.substr (1, calendarID.length - 1);
|
|
|
|
if (webCalendars[realID]) {
|
|
|
|
width = 500;
|
|
|
|
height = 360;
|
|
|
|
}
|
|
|
|
}
|
2009-08-18 03:03:05 +02:00
|
|
|
if (calendarID == "/personal")
|
2009-09-23 20:45:16 +02:00
|
|
|
height = 250;
|
|
|
|
|
|
|
|
var properties = window.open(url, windowID,
|
|
|
|
"width="+width+",height="+height+",resizable=0");
|
2009-07-19 18:41:42 +02:00
|
|
|
properties.focus();
|
2007-09-15 04:31:34 +02:00
|
|
|
}
|
|
|
|
|
2008-04-22 01:03:48 +02:00
|
|
|
function updateCalendarProperties(calendarID, calendarName, calendarColor) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var idParts = calendarID.split(":");
|
|
|
|
var folderName = idParts[1].split("/")[1];
|
|
|
|
var nodeID;
|
|
|
|
|
|
|
|
if (idParts[0] != UserLogin)
|
|
|
|
nodeID = "/" + idParts[0].asCSSIdentifier() + "_" + folderName;
|
|
|
|
else {
|
|
|
|
nodeID = "/" + folderName;
|
2008-08-28 16:48:45 +02:00
|
|
|
// log("nodeID: " + nodeID);
|
2009-07-19 18:41:42 +02:00
|
|
|
var calendarNode = $(nodeID);
|
|
|
|
var childNodes = calendarNode.childNodes;
|
|
|
|
childNodes[childNodes.length-1].nodeValue = calendarName;
|
|
|
|
}
|
2008-04-22 01:03:48 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
appendStyleElement(nodeID, calendarColor);
|
2007-09-15 04:31:34 +02:00
|
|
|
}
|
|
|
|
|
2007-09-15 00:01:02 +02:00
|
|
|
function onCalendarNew(event) {
|
2009-09-16 22:25:47 +02:00
|
|
|
createFolder(window.prompt(getLabel("Name of the Calendar"), ""),
|
2009-07-19 18:41:42 +02:00
|
|
|
appendCalendar);
|
|
|
|
preventDefault(event);
|
2007-09-15 00:01:02 +02:00
|
|
|
}
|
2007-03-29 20:05:23 +02:00
|
|
|
|
2007-09-15 00:01:02 +02:00
|
|
|
function onCalendarAdd(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
openUserFolderSelector(onFolderSubscribeCB, "calendar");
|
|
|
|
preventDefault(event);
|
2007-03-29 20:05:23 +02:00
|
|
|
}
|
2009-09-10 19:26:57 +02:00
|
|
|
|
|
|
|
function onCalendarWebAdd(event) {
|
2009-09-16 22:25:47 +02:00
|
|
|
var calendarUrl = window.prompt(getLabel("URL of the Calendar"), "");
|
2009-09-10 19:26:57 +02:00
|
|
|
if (calendarUrl) {
|
|
|
|
if (document.addWebCalendarRequest) {
|
|
|
|
document.addWebCalendarRequest.aborted = true;
|
|
|
|
document.addWebCalendarRequest.abort ();
|
|
|
|
}
|
|
|
|
var url = ApplicationBaseURL + "/addWebCalendar?url=" + escape (calendarUrl);
|
|
|
|
document.addWebCalendarRequest =
|
|
|
|
triggerAjaxRequest (url, addWebCalendarCallback);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
function addWebCalendarCallback (http) {
|
|
|
|
var data = http.responseText.evalJSON(true);
|
2009-09-28 03:05:10 +02:00
|
|
|
if (data.imported >= 0) {
|
2009-09-10 19:49:07 +02:00
|
|
|
appendCalendar(data.displayname, "/" + data.name);
|
|
|
|
refreshEvents();
|
|
|
|
refreshTasks();
|
|
|
|
changeCalendarDisplay();
|
|
|
|
}
|
|
|
|
else {
|
2009-09-16 22:25:47 +02:00
|
|
|
alert (getLabel("An error occured while importing calendar."));
|
2009-09-10 19:49:07 +02:00
|
|
|
}
|
2009-09-10 19:26:57 +02:00
|
|
|
}
|
|
|
|
|
2009-09-02 15:24:02 +02:00
|
|
|
function onCalendarExport(event) {
|
|
|
|
var node = $("calendarList").getSelectedNodes().first();
|
|
|
|
var owner = node.getAttribute("owner");
|
|
|
|
var folderId = node.getAttribute("id");
|
|
|
|
if (owner == UserLogin) {
|
|
|
|
var folderIdElements = folderId.split(":");
|
|
|
|
var id = folderIdElements[0].replace (/^\/+/g, '');
|
|
|
|
var url = ApplicationBaseURL + "/" + id + "/export";
|
|
|
|
window.location.href = url;
|
|
|
|
}
|
|
|
|
}
|
2007-03-29 20:05:23 +02:00
|
|
|
|
2009-09-02 21:14:15 +02:00
|
|
|
function onCalendarImport(event) {
|
|
|
|
var node = $("calendarList").getSelectedNodes().first();
|
|
|
|
var folderId = node.getAttribute("id");
|
|
|
|
|
|
|
|
var url = ApplicationBaseURL + folderId + "/import";
|
|
|
|
$("uploadForm").action = url;
|
|
|
|
$("uploadCancel").onclick = hideCalendarImport;
|
|
|
|
$("calendarFile").value = "";
|
|
|
|
|
|
|
|
var cellPosition = node.cumulativeOffset();
|
|
|
|
var cellDimensions = node.getDimensions();
|
|
|
|
var left = cellDimensions['width'] - 20;
|
|
|
|
var top = cellPosition[1];
|
|
|
|
|
|
|
|
var div = $("uploadDialog");
|
2009-09-03 19:53:38 +02:00
|
|
|
var res = $("uploadResults");
|
2009-09-02 21:14:15 +02:00
|
|
|
div.style.top = top + "px";
|
2009-09-03 19:53:38 +02:00
|
|
|
res.style.top = top + "px";
|
2009-09-02 21:14:15 +02:00
|
|
|
div.style.left = left + "px";
|
2009-09-03 19:53:38 +02:00
|
|
|
res.style.left = left + "px";
|
2009-09-02 21:14:15 +02:00
|
|
|
div.style.display = "block";
|
|
|
|
}
|
|
|
|
function hideCalendarImport () {
|
|
|
|
$("uploadDialog").style.display = "none";
|
|
|
|
}
|
2009-09-03 19:53:38 +02:00
|
|
|
function hideImportResults () {
|
|
|
|
$("uploadResults").style.display = "none";
|
|
|
|
}
|
2009-09-02 21:14:15 +02:00
|
|
|
function validateUploadForm () {
|
|
|
|
rc = false;
|
|
|
|
if ($("calendarFile").value.length)
|
|
|
|
rc = true;
|
|
|
|
return rc;
|
|
|
|
}
|
2009-09-03 19:53:38 +02:00
|
|
|
function uploadCompleted (response) {
|
|
|
|
data = response.evalJSON (true);
|
|
|
|
|
|
|
|
var div = $("uploadResults");
|
|
|
|
$("uploadOK").onclick = hideImportResults;
|
2009-09-28 17:06:54 +02:00
|
|
|
if (data.imported < 0)
|
2009-09-16 22:25:47 +02:00
|
|
|
$("uploadResultsContent").update (getLabel("An error occured while importing calendar."));
|
2009-09-03 20:37:08 +02:00
|
|
|
else {
|
2009-09-16 22:25:47 +02:00
|
|
|
$("uploadResultsContent").update (getLabel("Imported events:") + " " + data.imported);
|
2009-09-09 15:31:45 +02:00
|
|
|
refreshEventsAndDisplay ();
|
2009-09-03 20:37:08 +02:00
|
|
|
}
|
2009-09-03 19:53:38 +02:00
|
|
|
|
|
|
|
hideCalendarImport ();
|
|
|
|
$("uploadResults").style.display = "block";
|
|
|
|
}
|
2009-09-02 21:14:15 +02:00
|
|
|
|
2008-04-15 21:48:48 +02:00
|
|
|
function setEventsOnCalendar(checkBox, li) {
|
2009-07-19 18:41:42 +02:00
|
|
|
li.observe("mousedown", listRowMouseDownHandler);
|
|
|
|
li.observe("selectstart", listRowMouseDownHandler);
|
|
|
|
li.observe("click", onRowClick);
|
|
|
|
li.observe("dblclick", onCalendarModify);
|
|
|
|
checkBox.observe("click", updateCalendarStatus);
|
2008-04-15 21:48:48 +02:00
|
|
|
}
|
|
|
|
|
2007-10-23 16:39:29 +02:00
|
|
|
function appendCalendar(folderName, folderPath) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var owner;
|
|
|
|
|
|
|
|
if (folderPath) {
|
|
|
|
owner = getSubscribedFolderOwner(folderPath);
|
|
|
|
folderPath = accessToSubscribedFolder(folderPath);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
folderPath = "/" + folderName;
|
|
|
|
|
|
|
|
if (!owner)
|
|
|
|
owner = UserLogin;
|
|
|
|
|
|
|
|
//log ("append name: " + folderName + "; path: " + folderPath + "; owner: " + owner);
|
|
|
|
|
|
|
|
if ($(folderPath))
|
2009-09-16 22:25:47 +02:00
|
|
|
window.alert(getLabel("You have already subscribed to that folder!"));
|
2009-07-19 18:41:42 +02:00
|
|
|
else {
|
|
|
|
var calendarList = $("calendarList");
|
|
|
|
var items = calendarList.select("li");
|
|
|
|
var li = document.createElement("li");
|
2007-10-23 16:39:29 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
// Add the calendar to the proper place
|
|
|
|
var i = getListIndexForFolder(items, owner, folderName);
|
|
|
|
if (i != items.length) // User is subscribed to other calendars of the same owner
|
|
|
|
calendarList.insertBefore(li, items[i]);
|
|
|
|
else
|
|
|
|
calendarList.appendChild(li);
|
|
|
|
$(li).writeAttribute("id", folderPath);
|
|
|
|
$(li).writeAttribute("owner", owner);
|
|
|
|
|
|
|
|
var checkBox = createElement("input", null, "checkBox", { checked: 1 },
|
|
|
|
{ type: "checkbox" }, li);
|
|
|
|
|
|
|
|
li.appendChild(document.createTextNode(" "));
|
2008-08-09 03:53:09 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var colorBox = document.createElement("div");
|
|
|
|
li.appendChild(colorBox);
|
|
|
|
li.appendChild(document.createTextNode(folderName
|
|
|
|
.replace("<", "<", "g")
|
|
|
|
.replace(">", ">", "g")));
|
|
|
|
colorBox.appendChild(document.createTextNode("OO"));
|
|
|
|
|
|
|
|
$(colorBox).addClassName("colorBox");
|
|
|
|
$(colorBox).addClassName('calendarFolder' + folderPath.substr(1));
|
2009-07-08 23:13:06 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
// Check the checkbox (required for IE)
|
|
|
|
li.getElementsByTagName("input")[0].checked = true;
|
2009-06-02 21:45:07 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
// Register events (doesn't work with Safari)
|
|
|
|
setEventsOnCalendar($(checkBox), $(li));
|
2007-10-02 17:29:16 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var url = URLForFolderID(folderPath) + "/canAccessContent";
|
|
|
|
triggerAjaxRequest(url, calendarEntryCallback, folderPath);
|
2007-09-15 03:54:23 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
// Update CSS for events color
|
|
|
|
appendStyleElement(folderPath, "#AAAAAA");
|
|
|
|
}
|
2008-04-22 01:03:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function appendStyleElement(folderPath, color) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (document.styleSheets) {
|
|
|
|
var fgColor = getContrastingTextColor(color);
|
|
|
|
var styleElement = document.createElement("style");
|
|
|
|
styleElement.type = "text/css";
|
|
|
|
var selectors = [
|
|
|
|
'DIV.calendarFolder' + folderPath.substr(1),
|
|
|
|
'LI.calendarFolder' + folderPath.substr(1),
|
|
|
|
'UL#calendarList DIV.calendarFolder' + folderPath.substr(1)
|
|
|
|
];
|
|
|
|
var rules = [
|
|
|
|
' { background-color: ' + color + ' !important;' + ' color: ' + fgColor + ' !important; }',
|
|
|
|
' { background-color: ' + color + ' !important;' + ' color: ' + fgColor + ' !important; }',
|
|
|
|
' { color: ' + color + ' !important; }'
|
|
|
|
];
|
|
|
|
for (var i = 0; i < rules.length; i++)
|
|
|
|
if (styleElement.styleSheet && styleElement.styleSheet.addRule)
|
|
|
|
styleElement.styleSheet.addRule(selectors[i], rules[i]); // IE
|
|
|
|
else
|
|
|
|
styleElement.appendChild(document.createTextNode(selectors[i] + rules[i])); // Mozilla + Safari
|
|
|
|
document.getElementsByTagName("head")[0].appendChild(styleElement);
|
|
|
|
}
|
2007-03-29 20:05:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function onFolderSubscribeCB(folderData) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var folder = $(folderData["folder"]);
|
|
|
|
if (!folder) {
|
|
|
|
appendCalendar(folderData["folderName"], folderData["folder"]);
|
|
|
|
refreshEvents();
|
|
|
|
refreshTasks();
|
|
|
|
changeCalendarDisplay();
|
|
|
|
}
|
2007-03-29 20:05:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function onFolderUnsubscribeCB(folderId) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var node = $(folderId);
|
|
|
|
node.parentNode.removeChild(node);
|
|
|
|
if (removeFolderRequestCount == 0) {
|
|
|
|
refreshEvents();
|
|
|
|
refreshTasks();
|
|
|
|
changeCalendarDisplay();
|
|
|
|
}
|
2007-03-29 20:05:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function onCalendarRemove(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (removeFolderRequestCount == 0) {
|
|
|
|
var nodes = $("calendarList").getSelectedNodes();
|
|
|
|
for (var i = 0; i < nodes.length; i++) {
|
|
|
|
nodes[i].deselect();
|
|
|
|
var owner = nodes[i].getAttribute("owner");
|
|
|
|
var folderId = nodes[i].getAttribute("id");
|
|
|
|
if (owner == UserLogin) {
|
|
|
|
if (folderId == "/personal") {
|
|
|
|
var label = labels["You cannot remove nor unsubscribe from your"
|
|
|
|
+ " personal calendar."];
|
|
|
|
window.alert(label);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
var folderIdElements = folderId.split(":");
|
|
|
|
deletePersonalCalendar(folderIdElements[0]);
|
|
|
|
}
|
|
|
|
}
|
2009-09-04 21:08:21 +02:00
|
|
|
else {
|
|
|
|
var folderUrl = ApplicationBaseURL + folderId;
|
|
|
|
unsubscribeFromFolder(folderUrl, owner,
|
2009-07-19 18:41:42 +02:00
|
|
|
onFolderUnsubscribeCB, folderId);
|
2009-09-04 21:08:21 +02:00
|
|
|
}
|
2009-07-19 18:41:42 +02:00
|
|
|
}
|
|
|
|
}
|
2007-10-23 16:39:29 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
preventDefault(event);
|
2006-12-14 22:20:13 +01:00
|
|
|
}
|
|
|
|
|
2007-10-24 17:52:08 +02:00
|
|
|
function deletePersonalCalendar(folderElement) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var folderId = folderElement.substr(1);
|
|
|
|
var label
|
|
|
|
= labels["Are you sure you want to delete the calendar \"%{0}\"?"].formatted($(folderElement).lastChild.nodeValue.strip());
|
|
|
|
if (window.confirm(label)) {
|
|
|
|
removeFolderRequestCount++;
|
|
|
|
var url = ApplicationBaseURL + "/" + folderId + "/delete";
|
|
|
|
triggerAjaxRequest(url, deletePersonalCalendarCallback, folderId);
|
|
|
|
}
|
2007-09-15 00:01:02 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function deletePersonalCalendarCallback(http) {
|
2009-07-19 18:41:42 +02:00
|
|
|
if (http.readyState == 4) {
|
|
|
|
if (isHttpStatus204(http.status)) {
|
|
|
|
var ul = $("calendarList");
|
|
|
|
var children = ul.childNodesWithTag("li");
|
|
|
|
var i = 0;
|
|
|
|
var done = false;
|
|
|
|
while (!done && i < children.length) {
|
|
|
|
var currentFolderId = children[i].getAttribute("id").substr(1);
|
|
|
|
if (currentFolderId == http.callbackData) {
|
|
|
|
ul.removeChild(children[i]);
|
|
|
|
done = true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
removeFolderRequestCount--;
|
|
|
|
if (removeFolderRequestCount == 0) {
|
|
|
|
refreshEvents();
|
|
|
|
refreshTasks();
|
|
|
|
changeCalendarDisplay();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
log ("ajax problem 5: " + http.status);
|
2007-09-15 00:01:02 +02:00
|
|
|
}
|
|
|
|
|
2007-06-08 01:23:07 +02:00
|
|
|
function configureLists() {
|
2009-07-19 18:41:42 +02:00
|
|
|
var list = $("tasksList");
|
|
|
|
list.multiselect = true;
|
|
|
|
list.observe("mousedown", onTasksSelectionChange);
|
|
|
|
list.observe("selectstart", listRowMouseDownHandler);
|
2007-06-08 01:23:07 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var input = $("showHideCompletedTasks");
|
|
|
|
input.observe("click", onShowCompletedTasks);
|
2009-08-17 22:07:54 +02:00
|
|
|
if (showCompletedTasks)
|
|
|
|
input.checked = true;
|
2007-06-08 01:23:07 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
list = $("eventsList");
|
|
|
|
list.multiselect = true;
|
|
|
|
configureSortableTableHeaders(list);
|
|
|
|
TableKit.Resizable.init(list, {'trueResize' : true, 'keepWidth' : true});
|
|
|
|
list.observe("mousedown", onEventsSelectionChange);
|
2007-06-08 01:23:07 +02:00
|
|
|
}
|
|
|
|
|
2007-07-05 21:13:59 +02:00
|
|
|
function initDateSelectorEvents() {
|
2009-07-19 18:41:42 +02:00
|
|
|
var arrow = $("rightArrow");
|
|
|
|
arrow.observe("click", onDateSelectorGotoMonth);
|
|
|
|
arrow = $("leftArrow");
|
|
|
|
arrow.observe("click", onDateSelectorGotoMonth);
|
2008-07-16 04:12:18 +02:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
var menuButton = $("monthLabel");
|
|
|
|
menuButton.observe("click", popupMonthMenu);
|
|
|
|
menuButton = $("yearLabel");
|
|
|
|
menuButton.observe("click", popupMonthMenu);
|
2007-07-05 21:13:59 +02:00
|
|
|
}
|
|
|
|
|
2008-08-19 00:45:59 +02:00
|
|
|
function onBodyClickHandler(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
$("eventDialog").hide();
|
2008-08-19 00:45:59 +02:00
|
|
|
}
|
|
|
|
|
2008-09-18 20:03:59 +02:00
|
|
|
function onWindowResize(event) {
|
2009-07-19 18:41:42 +02:00
|
|
|
var handle = $("verticalDragHandle");
|
|
|
|
if (handle)
|
|
|
|
handle.adjust();
|
|
|
|
handle = $("rightDragHandle");
|
|
|
|
if (handle)
|
|
|
|
handle.adjust();
|
|
|
|
|
|
|
|
if (Prototype.Browser.IE) {
|
|
|
|
var days = $$("DIV#daysView DIV.days");
|
|
|
|
var labels = $$("DIV#calendarHeader DIV.days");
|
|
|
|
if (days.length && labels.length) {
|
|
|
|
var day = days[0];
|
|
|
|
var label = labels[0];
|
|
|
|
day.setStyle({ width: (label.getWidth()-1) + "px" });
|
|
|
|
}
|
|
|
|
}
|
2009-07-29 19:54:48 +02:00
|
|
|
if (!$(document.body).hasClassName("popup"))
|
|
|
|
drawNowLine ();
|
2009-07-23 15:57:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function drawNowLine () {
|
|
|
|
var d = new Date();
|
|
|
|
var hours = d.getHours();
|
|
|
|
var minutes = d.getMinutes();
|
2009-07-29 16:47:14 +02:00
|
|
|
|
|
|
|
if (currentView == "dayview") {
|
2009-07-29 15:43:47 +02:00
|
|
|
var today = new Date ();
|
|
|
|
var m = parseInt(today.getMonth ()) + 1;
|
|
|
|
var d = today.getDate ();
|
|
|
|
if (m < 10)
|
|
|
|
m = "0" + m;
|
|
|
|
if (d < 10)
|
|
|
|
d = "0" + d;
|
|
|
|
var day = today.getFullYear () + "" + m + "" + d;
|
|
|
|
var targets = $$("DIV#daysView DIV.days DIV.day[day=" + day
|
|
|
|
+ "] DIV.events DIV.clickableHourCell");
|
|
|
|
}
|
2009-07-29 16:47:14 +02:00
|
|
|
else if (currentView == "weekview")
|
2009-07-23 15:57:35 +02:00
|
|
|
var targets = $$("DIV#daysView DIV.days DIV.dayOfToday DIV.events DIV.clickableHourCell");
|
|
|
|
|
2009-07-29 15:43:47 +02:00
|
|
|
if (targets) {
|
|
|
|
var target = targets[hours];
|
2009-07-23 15:57:35 +02:00
|
|
|
|
2009-07-29 15:43:47 +02:00
|
|
|
if (target) {
|
|
|
|
var div = $("nowLineDisplay");
|
|
|
|
if (!div)
|
|
|
|
div = new Element ("div", {'id': 'nowLineDisplay'});
|
2009-07-23 15:57:35 +02:00
|
|
|
|
2009-07-29 15:43:47 +02:00
|
|
|
div.style.top = parseInt (((minutes * target.offsetHeight) / 60) - 1) + "px";
|
|
|
|
target.appendChild (div);
|
2009-07-23 15:57:35 +02:00
|
|
|
|
2009-07-29 15:43:47 +02:00
|
|
|
setTimeout ("drawNowLine ();", 60000); // 1 min.
|
|
|
|
}
|
2009-07-23 15:57:35 +02:00
|
|
|
}
|
2008-09-18 20:03:59 +02:00
|
|
|
}
|
|
|
|
|
2006-12-14 22:20:13 +01:00
|
|
|
function initCalendars() {
|
2009-07-19 18:41:42 +02:00
|
|
|
sorting["attribute"] = "start";
|
|
|
|
sorting["ascending"] = true;
|
2009-08-17 22:07:54 +02:00
|
|
|
showCompletedTasks = UserDefaults['ShowCompletedTasks'];
|
2007-12-06 18:29:32 +01:00
|
|
|
|
2009-07-19 18:41:42 +02:00
|
|
|
if (!$(document.body).hasClassName("popup")) {
|
2009-07-19 18:42:04 +02:00
|
|
|
var node = $("filterpopup");
|
2009-07-19 18:51:50 +02:00
|
|
|
listFilter = node.value;
|
2009-07-19 18:41:42 +02:00
|
|
|
initDateSelectorEvents();
|
|
|
|
initCalendarSelector();
|
|
|
|
configureSearchField();
|
|
|
|
configureLists();
|
|
|
|
$("calendarList").attachMenu("calendarsMenu");
|
|
|
|
$(document.body).observe("click", onBodyClickHandler);
|
|
|
|
}
|
|
|
|
|
|
|
|
onWindowResize.defer();
|
|
|
|
Event.observe(window, "resize", onWindowResize);
|
2006-12-14 22:20:13 +01:00
|
|
|
}
|
|
|
|
|
2009-03-12 22:09:14 +01:00
|
|
|
document.observe("dom:loaded", initCalendars);
|