aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui
diff options
context:
space:
mode:
Diffstat (limited to 'calendar/gui')
-rw-r--r--calendar/gui/dialogs/alarm-options.c61
1 files changed, 58 insertions, 3 deletions
diff --git a/calendar/gui/dialogs/alarm-options.c b/calendar/gui/dialogs/alarm-options.c
index c201e66979..ef13b78b13 100644
--- a/calendar/gui/dialogs/alarm-options.c
+++ b/calendar/gui/dialogs/alarm-options.c
@@ -28,6 +28,7 @@
#include <gtk/gtkmain.h>
#include <gtk/gtkcheckbutton.h>
#include <gtk/gtkdialog.h>
+#include <gtk/gtkentry.h>
#include <gtk/gtksignal.h>
#include <gtk/gtkwindow.h>
#include <gtk/gtkhbox.h>
@@ -49,6 +50,9 @@ typedef struct {
/* Glade XML data */
GladeXML *xml;
+ /* The alarm action selected */
+ CalAlarmAction action;
+
/* Toplevel */
GtkWidget *toplevel;
@@ -185,6 +189,18 @@ setup_select_names (Dialog *dialog)
return TRUE;
}
+static void
+palarm_options_changed_cb (GtkEditable *entry, gpointer user_data)
+{
+ const gchar *text;
+ Dialog *dialog = user_data;
+
+ text = gtk_entry_get_text (GTK_ENTRY (dialog->palarm_program));
+ if (text && *text)
+ gtk_dialog_set_response_sensitive (GTK_DIALOG (dialog->toplevel), GTK_RESPONSE_OK, TRUE);
+ else
+ gtk_dialog_set_response_sensitive (GTK_DIALOG (dialog->toplevel), GTK_RESPONSE_OK, FALSE);
+}
/* Callback used when the repeat toggle button is toggled. We sensitize the
* repeat group options as appropriate.
@@ -200,6 +216,29 @@ repeat_toggle_toggled_cb (GtkToggleButton *toggle, gpointer data)
active = gtk_toggle_button_get_active (toggle);
gtk_widget_set_sensitive (dialog->repeat_group, active);
+
+ /* activate the 'OK' button */
+ if (dialog->action == CAL_ALARM_PROCEDURE)
+ palarm_options_changed_cb (GTK_EDITABLE (dialog->palarm_program), dialog);
+}
+
+static void
+repeat_spin_button_changed_cb (GtkWidget *spin, gpointer user_data)
+{
+ Dialog *dialog = user_data;
+
+ if (dialog->action == CAL_ALARM_PROCEDURE)
+ palarm_options_changed_cb (GTK_EDITABLE (dialog->palarm_program), dialog);
+}
+
+
+static void
+repeat_unit_changed_cb (GtkWidget *option_menu, gpointer user_data)
+{
+ Dialog *dialog = user_data;
+
+ if (dialog->action == CAL_ALARM_PROCEDURE)
+ palarm_options_changed_cb (GTK_EDITABLE (dialog->palarm_program), dialog);
}
/* Hooks the widget signals */
@@ -208,8 +247,16 @@ init_widgets (Dialog *dialog)
{
/* Alarm repeat */
- g_signal_connect((dialog->repeat_toggle), "toggled",
- G_CALLBACK (repeat_toggle_toggled_cb), dialog);
+ g_signal_connect (G_OBJECT (dialog->repeat_toggle), "toggled",
+ G_CALLBACK (repeat_toggle_toggled_cb), dialog);
+
+ g_signal_connect (G_OBJECT (dialog->repeat_quantity), "value_changed",
+ G_CALLBACK (repeat_spin_button_changed_cb), dialog);
+ g_signal_connect (G_OBJECT (dialog->repeat_value), "value_changed",
+ G_CALLBACK (repeat_spin_button_changed_cb), dialog);
+
+ g_signal_connect (G_OBJECT (dialog->repeat_unit), "changed",
+ G_CALLBACK (repeat_unit_changed_cb), dialog);
}
/* Fills the audio alarm widgets with the values from the alarm component */
@@ -400,7 +447,6 @@ alarm_to_repeat_widgets (Dialog *dialog, CalComponentAlarm *alarm)
e_dialog_option_menu_set (dialog->repeat_unit, units, duration_units_map);
}
-
/* Fills the widgets with the values from the alarm component */
static void
alarm_to_dialog (Dialog *dialog, CalComponentAlarm *alarm)
@@ -450,6 +496,13 @@ alarm_to_dialog (Dialog *dialog, CalComponentAlarm *alarm)
gtk_widget_hide (dialog->malarm_group);
gtk_widget_show (dialog->palarm_group);
alarm_to_palarm_widgets (dialog, alarm);
+
+ /* make sure the 'OK' button is disabled while the program entry is empty */
+ gtk_dialog_set_response_sensitive (GTK_DIALOG (dialog->toplevel), GTK_RESPONSE_OK, FALSE);
+ g_signal_connect (G_OBJECT (dialog->palarm_program), "changed",
+ G_CALLBACK (palarm_options_changed_cb), dialog);
+ g_signal_connect (G_OBJECT (dialog->palarm_args), "changed",
+ G_CALLBACK (palarm_options_changed_cb), dialog);
break;
case CAL_ALARM_UNKNOWN:
@@ -460,6 +513,8 @@ alarm_to_dialog (Dialog *dialog, CalComponentAlarm *alarm)
g_assert_not_reached ();
return;
}
+
+ dialog->action = action;
}