gecko-dev/calendar/base/content/calendar-item-editing.js

217 lines
7.3 KiB
JavaScript

/* -*- Mode: javascript; tab-width: 20; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is Oracle Corporation code.
*
* The Initial Developer of the Original Code is Oracle Corporation
* Portions created by the Initial Developer are Copyright (C) 2005
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
* Stuart Parmenter <stuart.parmenter@oracle.com>
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** */
/* all params are optional */
function createEventWithDialog(calendar, startDate, endDate, summary, event)
{
const kDefaultTimezone = calendarDefaultTimezone();
var onNewEvent = function(event, calendar, originalEvent) {
calendar.addItem(event, null);
}
if (event) {
openEventDialog(event, calendar, "new", onNewEvent);
return;
}
event = createEvent();
if (!startDate) {
startDate = jsDateToDateTime(new Date());
startDate.second = 0;
startDate.normalize();
} else if (startDate.isDate) {
startDate = startDate.clone();
startDate.isDate = false;
event.startDate.isDate = false;
/* set the hour/minute of startDate to "right now"
if the day is the same */
var now = jsDateToDateTime(new Date()).getInTimezone(kDefaultTimezone).clone();
var nowDate = now.clone();
nowDate.isDate = true;
nowDate.normalize();
if (startDate.compare(nowDate) == 0) {
/* they're the same, so set now's seconds to 0,
normalize and change startDate to be now. */
now.second = 0;
now.normalize();
startDate = now;
}
}
event.startDate = startDate.clone();
event.startDate.isDate = false;
if (!endDate) {
endDate = startDate.clone();
endDate.hour = endDate.hour + 1; // XXX we should get a default duration from prefs
endDate.normalize();
}
event.endDate = endDate.clone();
if (calendar) {
event.calendar = calendar;
}
if (summary)
event.title = summary;
setDefaultAlarmValues(event);
openEventDialog(event, calendar, "new", onNewEvent);
}
function createTodoWithDialog(calendar, dueDate, summary, todo)
{
const kDefaultTimezone = calendarDefaultTimezone();
var onNewItem = function(item, calendar, originalItem) {
calendar.addItem(item, null);
}
if (todo) {
openEventDialog(todo, calendar, "new", onNewItem);
return;
}
todo = createToDo();
if (calendar) {
todo.calendar = calendar;
}
if (summary)
todo.title = summary;
if (dueDate)
todo.dueDate = dueDate;
var onNewItem = function(item, calendar, originalItem) {
calendar.addItem(item, null);
}
setDefaultAlarmValues(todo);
openEventDialog(todo, calendar, "new", onNewItem);
}
function modifyEventWithDialog(item)
{
var onModifyItem = function(item, calendar, originalItem) {
// compare cal.uri because there may be multiple instances of
// calICalendar or uri for the same spec, and those instances are
// not ==.
if (!originalItem.calendar ||
(originalItem.calendar.uri.equals(calendar.uri)))
calendar.modifyItem(item, originalItem, null);
else {
originalItem.calendar.deleteItem(item, null);
calendar.addItem(item, null);
}
}
openEventDialog(item, item.calendar, "modify", onModifyItem);
}
function openEventDialog(calendarItem, calendar, mode, callback)
{
var args = new Object();
args.calendarEvent = calendarItem;
args.calendar = calendar;
args.mode = mode;
args.onOk = callback;
// the dialog will reset this to auto when it is done loading.
window.setCursor("wait");
// open the dialog modally
openDialog("chrome://calendar/content/calendar-event-dialog.xul", "_blank",
"chrome,titlebar,modal,resizable", args);
}
// When editing a single instance of a recurring event, we need to figure out
// whether the user wants to edit all instances, or just this one. This
// function prompts this question (if the item is actually an instance of a
// recurring event) and returns the appropriate item that should be modified.
function getOccurrenceOrParent(occurrence) {
// Check if this actually is an instance of a recurring event
if (occurrence == occurrence.parentItem) {
return occurrence;
}
// if the user wants to edit an occurrence which is already
// an exception, always edit this single item.
var parentItem = occurrence.parentItem;
var rec = parentItem.recurrenceInfo;
if (rec) {
var exceptions = rec.getExceptionIds({});
if (exceptions.some(function (exid) {
return exid.compare(occurrence.recurrenceId) == 0;
})) {
return occurrence;
}
}
var promptService =
Components.classes["@mozilla.org/embedcomp/prompt-service;1"]
.getService(Components.interfaces.nsIPromptService);
var sbs = Components.classes["@mozilla.org/intl/stringbundle;1"]
.getService(Components.interfaces.nsIStringBundleService);
var props = sbs.createBundle("chrome://calendar/locale/calendar.properties");
var promptTitle = props.GetStringFromName("editRecurTitle");
var promptMessage = props.GetStringFromName("editRecurMessage");
var buttonLabel1 = props.GetStringFromName("editRecurAll");
var buttonLabel2 = props.GetStringFromName("editRecurSingle");
var flags = promptService.BUTTON_TITLE_IS_STRING * promptService.BUTTON_POS_0 +
promptService.BUTTON_TITLE_IS_STRING * promptService.BUTTON_POS_1;
if (promptService.confirmEx(null, promptTitle, promptMessage, flags,
buttonLabel1, buttonLabel2, null, null, {})) {
return occurrence;
} else {
return occurrence.parentItem;
}
}