aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui/event-editor.c
diff options
context:
space:
mode:
Diffstat (limited to 'calendar/gui/event-editor.c')
-rw-r--r--calendar/gui/event-editor.c121
1 files changed, 118 insertions, 3 deletions
diff --git a/calendar/gui/event-editor.c b/calendar/gui/event-editor.c
index 50d6c8a346..f4e0255375 100644
--- a/calendar/gui/event-editor.c
+++ b/calendar/gui/event-editor.c
@@ -20,11 +20,14 @@ extern int am_pm_flag;
extern int week_starts_on_monday;
+static void append_exception (EventEditorDialog *dialog, time_t t);
+
static void
fill_in_dialog_from_ical (EventEditorDialog *dialog)
{
iCalObject *ical = dialog->ical;
GladeXML *gui = dialog->gui;
+ GList *list;
store_to_editable (gui, "general-owner",
dialog->ical->organizer->addr ?
@@ -130,6 +133,11 @@ fill_in_dialog_from_ical (EventEditorDialog *dialog)
store_to_gnome_dateedit (gui, "recurrence-ending-date-end-on-date", ical->recur->enddate - 86400);
}
/* else repeat forever */
+
+
+ /* fill the exceptions list */
+ for (list = ical->exdate; list; list = list->next)
+ append_exception (dialog, *((time_t *) list->data));
}
@@ -262,6 +270,18 @@ dialog_to_ical (EventEditorDialog *dialog)
ical->recur->duration = extract_from_spin (gui, "recurrence-ending-date-end-after-count");
ical_object_compute_end (ical);
}
+
+
+ /* get exceptions from clist into ical->exdate */
+ {
+ int i;
+ time_t *t;
+ GtkCList *exception_list = GTK_CLIST (glade_xml_get_widget (dialog->gui, "recurrence-exceptions-list"));
+ for (i = 0; i < exception_list->rows; i++) {
+ t = gtk_clist_get_row_data (exception_list, i);
+ ical->exdate = g_list_prepend (ical->exdate, t);
+ }
+ }
}
@@ -314,6 +334,90 @@ recurrence_toggled (GtkWidget *radio, EventEditorDialog *dialog)
}
+static char *
+get_exception_string (time_t t)
+{
+ static char buf[256];
+
+ strftime (buf, sizeof(buf), _("%a %b %d %Y"), localtime (&t));
+ return buf;
+}
+
+
+static void
+append_exception (EventEditorDialog *dialog, time_t t)
+{
+ time_t *tt;
+ char *c[1];
+ int i;
+ GtkCList *exception_list = GTK_CLIST (glade_xml_get_widget (dialog->gui, "recurrence-exceptions-list"));
+
+ c[0] = get_exception_string (t);
+
+ tt = g_new (time_t, 1);
+ *tt = t;
+
+ i = gtk_clist_append (exception_list, c);
+ gtk_clist_set_row_data (exception_list, i, tt);
+ gtk_clist_select_row (exception_list, i, 0);
+
+ //gtk_widget_set_sensitive (ee->recur_ex_vbox, TRUE);
+}
+
+
+static void
+recurrence_exception_added (GtkWidget *widget, EventEditorDialog *dialog)
+{
+ //GtkWidget *exception_date = glade_xml_get_widget (dialog->gui, "recurrence-exceptions-date");
+ time_t t = extract_from_gnome_dateedit (dialog->gui, "recurrence-exceptions-date");
+ append_exception (dialog, t);
+}
+
+
+static void
+recurrence_exception_deleted (GtkWidget *widget, EventEditorDialog *dialog)
+{
+ GtkCList *clist;
+ int sel, length;
+
+ clist = GTK_CLIST (glade_xml_get_widget (dialog->gui, "recurrence-exceptions-list"));
+ if (! clist->selection)
+ return;
+ sel = GPOINTER_TO_INT(clist->selection->data);
+
+ g_free (gtk_clist_get_row_data (clist, sel)); /* free the time_t stored there */
+
+ gtk_clist_remove (clist, sel);
+ length = g_list_length(clist->row_list);
+ if (sel >= length)
+ sel--;
+ gtk_clist_select_row (clist, sel, 0);
+
+ //if (clist->rows == 0)
+ // gtk_widget_set_sensitive (ee->recur_ex_vbox, FALSE);
+}
+
+
+static void
+recurrence_exception_changed (GtkWidget *widget, EventEditorDialog *dialog)
+{
+ GtkCList *clist;
+ time_t *t;
+ int sel;
+
+ clist = GTK_CLIST (glade_xml_get_widget (dialog->gui, "recurrence-exceptions-list"));
+ if (! clist->selection)
+ return;
+
+ sel = GPOINTER_TO_INT(clist->selection->data);
+
+ t = gtk_clist_get_row_data (clist, sel);
+ *t = extract_from_gnome_dateedit (dialog->gui, "recurrence-exceptions-date");
+
+ gtk_clist_set_text (clist, sel, 0, get_exception_string (*t));
+}
+
+
GtkWidget *event_editor_new (GnomeCalendar *gcal, iCalObject *ical)
{
@@ -359,6 +463,20 @@ GtkWidget *event_editor_new (GnomeCalendar *gcal, iCalObject *ical)
}
+ {
+ GtkWidget *recurrence_exception_add = glade_xml_get_widget (dialog->gui, "recurrence-exceptions-add");
+ GtkWidget *recurrence_exception_delete = glade_xml_get_widget (dialog->gui, "recurrence-exceptions-delete");
+ GtkWidget *recurrence_exception_change = glade_xml_get_widget (dialog->gui, "recurrence-exceptions-change");
+
+ gtk_signal_connect (GTK_OBJECT (recurrence_exception_add), "clicked",
+ GTK_SIGNAL_FUNC (recurrence_exception_added), dialog);
+ gtk_signal_connect (GTK_OBJECT (recurrence_exception_delete), "clicked",
+ GTK_SIGNAL_FUNC (recurrence_exception_deleted), dialog);
+ gtk_signal_connect (GTK_OBJECT (recurrence_exception_change), "clicked",
+ GTK_SIGNAL_FUNC (recurrence_exception_changed), dialog);
+ }
+
+
if (ical->new)
fill_in_dialog_from_defaults (dialog);
@@ -431,8 +549,5 @@ make_spin_button (int val, int low, int high)
figure out why alarm units aren't sticking between edits
extract from and store to the ending date in the recurrence rule stuff
-
- finish the recurrence rule exceptions
-
*/