aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui
diff options
context:
space:
mode:
Diffstat (limited to 'calendar/gui')
-rw-r--r--calendar/gui/event-editor.c102
1 files changed, 89 insertions, 13 deletions
diff --git a/calendar/gui/event-editor.c b/calendar/gui/event-editor.c
index 1f93687819..531bdc24d8 100644
--- a/calendar/gui/event-editor.c
+++ b/calendar/gui/event-editor.c
@@ -28,6 +28,7 @@
#include <widgets/misc/e-dateedit.h>
#include <gal/widgets/e-unicode.h>
#include <cal-util/timeutil.h>
+#include "calendar-config.h"
#include "event-editor.h"
#include "e-meeting-edit.h"
#include "tag-calendar.h"
@@ -331,6 +332,16 @@ make_title_from_comp (CalComponent *comp)
}
}
+/* Callback used when the recurrence weekday picker changes */
+static void
+recur_weekday_picker_changed_cb (WeekdayPicker *wp, gpointer data)
+{
+ EventEditor *ee;
+
+ ee = EVENT_EDITOR (data);
+ preview_recur (ee);
+}
+
/* Creates the special contents for weekly recurrences */
static void
make_recur_weekly_special (EventEditor *ee)
@@ -364,6 +375,9 @@ make_recur_weekly_special (EventEditor *ee)
weekday_picker_set_week_starts_on_monday (wp, week_starts_on_monday);
weekday_picker_set_days (wp, priv->recurrence_weekday_day_mask);
+
+ gtk_signal_connect (GTK_OBJECT (wp), "changed",
+ GTK_SIGNAL_FUNC (recur_weekday_picker_changed_cb), ee);
}
/* Creates the option menu for the monthly recurrence days */
@@ -462,6 +476,17 @@ month_day_menu_selection_done_cb (GtkMenuShell *menu_shell, gpointer data)
ee = EVENT_EDITOR (data);
adjust_day_index_spin (ee);
+ preview_recur (ee);
+}
+
+/* Callback used when the month index value changes. */
+static void
+recur_month_index_value_changed_cb (GtkAdjustment *adj, gpointer data)
+{
+ EventEditor *ee;
+
+ ee = EVENT_EDITOR (data);
+ preview_recur (ee);
}
/* Creates the special contents for monthly recurrences */
@@ -496,11 +521,6 @@ make_recur_monthly_special (EventEditor *ee)
gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
priv->recurrence_month_day_menu = make_recur_month_menu ();
-
- menu = gtk_option_menu_get_menu (GTK_OPTION_MENU (priv->recurrence_month_day_menu));
- gtk_signal_connect (GTK_OBJECT (menu), "selection_done",
- GTK_SIGNAL_FUNC (month_day_menu_selection_done_cb), ee);
-
gtk_box_pack_start (GTK_BOX (hbox), priv->recurrence_month_day_menu, FALSE, FALSE, 0);
gtk_widget_show_all (hbox);
@@ -512,6 +532,13 @@ make_recur_monthly_special (EventEditor *ee)
priv->recurrence_month_day,
month_day_options_map);
adjust_day_index_spin (ee);
+
+ gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
+ GTK_SIGNAL_FUNC (recur_month_index_value_changed_cb), ee);
+
+ menu = gtk_option_menu_get_menu (GTK_OPTION_MENU (priv->recurrence_month_day_menu));
+ gtk_signal_connect (GTK_OBJECT (menu), "selection_done",
+ GTK_SIGNAL_FUNC (month_day_menu_selection_done_cb), ee);
}
static const int recur_freq_map[] = {
@@ -571,6 +598,16 @@ make_recurrence_special (EventEditor *ee)
}
}
+/* Callback used when the ending-until date editor changes */
+static void
+recur_ending_until_changed_cb (EDateEdit *de, gpointer data)
+{
+ EventEditor *ee;
+
+ ee = EVENT_EDITOR (data);
+ preview_recur (ee);
+}
+
/* Creates the special contents for "ending until" (end date) recurrences */
static void
make_recur_ending_until_special (EventEditor *ee)
@@ -596,6 +633,19 @@ make_recur_ending_until_special (EventEditor *ee)
/* Set the value */
e_date_edit_set_time (de, priv->recurrence_ending_date);
+
+ gtk_signal_connect (GTK_OBJECT (de), "changed",
+ GTK_SIGNAL_FUNC (recur_ending_until_changed_cb), ee);
+}
+
+/* Callback used when the ending-count value changes */
+static void
+recur_ending_count_value_changed_cb (GtkAdjustment *adj, gpointer data)
+{
+ EventEditor *ee;
+
+ ee = EVENT_EDITOR (data);
+ preview_recur (ee);
}
/* Creates the special contents for the ocurrence count case */
@@ -630,6 +680,9 @@ make_recur_ending_count_special (EventEditor *ee)
e_dialog_spin_set (priv->recurrence_ending_count_spin,
priv->recurrence_ending_count);
+
+ gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
+ GTK_SIGNAL_FUNC (recur_ending_count_value_changed_cb), ee);
}
enum ending_type {
@@ -940,6 +993,18 @@ start_date_changed_cb (EDateEdit *de, gpointer data)
sync_date_edits (de, E_DATE_EDIT (data));
}
+/* Callback used when the displayed date range in the recurrence preview
+ * calendar changes.
+ */
+static void
+recur_preview_date_range_changed_cb (ECalendarItem *item, gpointer data)
+{
+ EventEditor *ee;
+
+ ee = EVENT_EDITOR (data);
+ preview_recur (ee);
+}
+
/* Hooks the widget signals */
static void
init_widgets (EventEditor *ee)
@@ -947,6 +1012,8 @@ init_widgets (EventEditor *ee)
EventEditorPrivate *priv;
GtkWidget *menu;
GtkAdjustment *adj;
+ ECalendar *ecal;
+ int week_start_day;
priv = ee->priv;
@@ -985,6 +1052,22 @@ init_widgets (EventEditor *ee)
gtk_signal_connect (GTK_OBJECT (priv->alarm_mail), "toggled",
GTK_SIGNAL_FUNC (alarm_toggle), ee);
+ /* Recurrence preview */
+
+ week_start_day = calendar_config_get_week_start_day ();
+
+ priv->recurrence_preview_calendar = e_calendar_new ();
+ ecal = E_CALENDAR (priv->recurrence_preview_calendar);
+ gtk_signal_connect (GTK_OBJECT (ecal->calitem), "date_range_changed",
+ GTK_SIGNAL_FUNC (recur_preview_date_range_changed_cb), ee);
+ gnome_canvas_item_set (GNOME_CANVAS_ITEM (ecal->calitem),
+ "maximum_days_selected", 0,
+ "week_start_day", (week_start_day + 6) % 7,
+ NULL);
+ gtk_container_add (GTK_CONTAINER (priv->recurrence_preview_bin),
+ priv->recurrence_preview_calendar);
+ gtk_widget_show (priv->recurrence_preview_calendar);
+
/* Recurrence types */
gtk_signal_connect (GTK_OBJECT (priv->recurrence_none), "toggled",
@@ -1020,13 +1103,6 @@ init_widgets (EventEditor *ee)
GTK_SIGNAL_FUNC (recurrence_exception_modify_cb), ee);
gtk_signal_connect (GTK_OBJECT (priv->recurrence_exception_delete), "clicked",
GTK_SIGNAL_FUNC (recurrence_exception_delete_cb), ee);
-
- /* Recurrence preview */
-
- priv->recurrence_preview_calendar = e_calendar_new ();
- gtk_container_add (GTK_CONTAINER (priv->recurrence_preview_bin),
- priv->recurrence_preview_calendar);
- gtk_widget_show (priv->recurrence_preview_calendar);
}
static const int classification_map[] = {
@@ -1153,7 +1229,7 @@ clear_widgets (EventEditor *ee)
gtk_signal_handler_block_by_data (GTK_OBJECT (menu), ee);
e_dialog_option_menu_set (priv->recurrence_ending_menu, ENDING_FOREVER,
ending_types_map);
- gtk_signal_handler_block_by_data (GTK_OBJECT (menu), ee);
+ gtk_signal_handler_unblock_by_data (GTK_OBJECT (menu), ee);
/* Exceptions list */