mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-11-04 16:15:25 +00:00
200 lines
6.7 KiB
JavaScript
200 lines
6.7 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;
|
|
|
|
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);
|
|
}
|
|
|
|
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;
|
|
}
|
|
|
|
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;
|
|
}
|
|
}
|