aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui/dialogs
diff options
context:
space:
mode:
authorEttore Perazzoli <ettore@src.gnome.org>2002-03-13 12:55:04 +0800
committerEttore Perazzoli <ettore@src.gnome.org>2002-03-13 12:55:04 +0800
commitd5ba94f758a5206dc7cd5b0cd222bb2c3d348ebe (patch)
treef0ed1da36d11d0d6a12183a9f8f13bb3434e94d0 /calendar/gui/dialogs
parent9a3b0141daad42713cdeae13ffb0d2e8af786540 (diff)
downloadgsoc2013-evolution-d5ba94f758a5206dc7cd5b0cd222bb2c3d348ebe.tar
gsoc2013-evolution-d5ba94f758a5206dc7cd5b0cd222bb2c3d348ebe.tar.gz
gsoc2013-evolution-d5ba94f758a5206dc7cd5b0cd222bb2c3d348ebe.tar.bz2
gsoc2013-evolution-d5ba94f758a5206dc7cd5b0cd222bb2c3d348ebe.tar.lz
gsoc2013-evolution-d5ba94f758a5206dc7cd5b0cd222bb2c3d348ebe.tar.xz
gsoc2013-evolution-d5ba94f758a5206dc7cd5b0cd222bb2c3d348ebe.tar.zst
gsoc2013-evolution-d5ba94f758a5206dc7cd5b0cd222bb2c3d348ebe.zip
Add <visible>False</visible> to cal-prefs-dialog so it doesn't get shown
* gui/dialogs/cal-prefs-dialog.glade: Add <visible>False</visible> to cal-prefs-dialog so it doesn't get shown when we load the Glade file with libglade. * gui/component-factory.c (owner_set_cb): Register the ConfigControl factory. * gui/tasks-control.c: Removed verb "TaskSettings". (tasks_control_settings_cmd): Removed. * gui/calendar-commands.c: Removed verb "CalendarSettings". (settings_cmd): Removed. * gui/dialogs/cal-prefs-dialog.c: Renamed `CalPrefsDialogPrivate' to `DialogData'. Replace `dialog' member with a `page' member. Remove `toplevel_notebook' member. (init_widgets): Renamed from `cal_prefs_dialog_init_widgets'. Just get a DialogData. (get_widgets): Get a DialogData pointer. (cal_prefs_dialog_destroy): Removed. (config_control_destroy_callback): New, signal handler for ::destroy for ConfigControl. (cal_prefs_dialog_new): Create a new DialogData, connect all the signal handlers. (create_time_edit): Renamed from `cal_prefs_dialog_create_time_edit'. (cal_prefs_dialog_show): Removed. (cal_prefs_dialog_button_clicked): Removed. (show_task_list_config): Get a DialogData. (show_config): Renamed from `cal_prefs_dialog_show_config'. Likewise. (update_task_list_config): Likewise. (update_config): Renamed from `cal_prefs_dialog_update_config'. Likewise. (color_set_callback): New callback, makes the dialog report changes when the setting in any of the color widgets is changed. (widget_changed_callback): New callback, makes the dialog report changes when any of the widgets changes status. (connect_changed): New utility function to connect this callback to all the widgets. (setup_widgets): Connect all the widgets. (cal_prefs_dialog_new): Call `setup_widgets'. * gui/config-control-factory.c: New. * gui/config-control-factory.h: New. * gui/GNOME_Evolution_Calendar.oaf.in: Add OAFIID:GNOME_Evolution_Calendar_ConfigControl and OAFIID:GNOME_Evolution_Calendar_ConfigControlFactory. svn path=/trunk/; revision=16135
Diffstat (limited to 'calendar/gui/dialogs')
-rw-r--r--calendar/gui/dialogs/cal-prefs-dialog.c586
-rw-r--r--calendar/gui/dialogs/cal-prefs-dialog.glade1
-rw-r--r--calendar/gui/dialogs/cal-prefs-dialog.h41
3 files changed, 267 insertions, 361 deletions
diff --git a/calendar/gui/dialogs/cal-prefs-dialog.c b/calendar/gui/dialogs/cal-prefs-dialog.c
index fc8d7b0c91..2e61fc0bd5 100644
--- a/calendar/gui/dialogs/cal-prefs-dialog.c
+++ b/calendar/gui/dialogs/cal-prefs-dialog.c
@@ -1,11 +1,11 @@
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
/*
- * Author :
+ * Authors :
* Damon Chaplin <damon@ximian.com>
+ * Ettore Perazzoli <ettore@ximian.com>
*
- * Copyright 2000, Ximian, Inc.
- * Copyright 2000, Ximian, Inc.
+ * Copyright 2000, 2001, 2002 Ximian, Inc.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of version 2 of the GNU General Public
@@ -27,26 +27,28 @@
* to edit the calendar preference settings.
*/
+#ifdef HAVE_CONFIG_H
#include <config.h>
-#include <libgnomeui/gnome-color-picker.h>
-#include <glade/glade.h>
-#include <gal/util/e-util.h>
-#include <e-util/e-dialog-widgets.h>
-#include <widgets/misc/e-dateedit.h>
+#endif
+
#include "../e-timezone-entry.h"
#include "cal-prefs-dialog.h"
#include "../calendar-config.h"
#include "../calendar-commands.h"
#include "../e-tasks.h"
+#include <libgnomeui/gnome-color-picker.h>
+#include <glade/glade.h>
+#include <gal/util/e-util.h>
+#include <e-util/e-dialog-widgets.h>
+#include <widgets/misc/e-dateedit.h>
+
-struct _CalPrefsDialogPrivate {
+struct _DialogData {
/* Glade XML data */
GladeXML *xml;
- GtkWidget *dialog;
-
- GtkWidget *toplevel_notebook;
+ GtkWidget *page;
GtkWidget *timezone;
GtkWidget *working_days[7];
@@ -74,6 +76,7 @@ struct _CalPrefsDialogPrivate {
GtkWidget *default_reminder_interval;
GtkWidget *default_reminder_units;
};
+typedef struct _DialogData DialogData;
static const int week_start_day_map[] = {
1, 2, 3, 4, 5, 6, 0, -1
@@ -93,217 +96,242 @@ static const int default_reminder_units_map[] = {
};
-static void cal_prefs_dialog_class_init (CalPrefsDialogClass *class);
-static void cal_prefs_dialog_init (CalPrefsDialog *prefs);
-static gboolean get_widgets (CalPrefsDialog *prefs);
-static void cal_prefs_dialog_destroy (GtkObject *object);
-static void cal_prefs_dialog_init_widgets (CalPrefsDialog *prefs);
-static void cal_prefs_dialog_button_clicked (GtkWidget *dialog,
- gint button,
- CalPrefsDialog *prefs);
-static void cal_prefs_dialog_use_24_hour_toggled(GtkWidget *button,
- CalPrefsDialog *prefs);
-static void cal_prefs_dialog_hide_completed_tasks_toggled (GtkWidget *button,
- CalPrefsDialog *prefs);
-static void cal_prefs_dialog_show_config (CalPrefsDialog *prefs);
-static void cal_prefs_dialog_update_config (CalPrefsDialog *prefs);
+static gboolean get_widgets (DialogData *data);
-GtkWidget* cal_prefs_dialog_create_time_edit (void);
+static void widget_changed_callback (GtkWidget *, void *data);
+static void connect_changed (GtkWidget *widget, const char *signal_name, EvolutionConfigControl *config_control);
+static void setup_changes (DialogData *data, EvolutionConfigControl *config_control);
-static GtkObjectClass *parent_class;
+static void init_widgets (DialogData *data);
+static void show_config (DialogData *data);
+static void update_config (DialogData *dialog_data);
-E_MAKE_TYPE (cal_prefs_dialog, "CalPrefsDialog", CalPrefsDialog,
- cal_prefs_dialog_class_init, cal_prefs_dialog_init,
- GTK_TYPE_OBJECT)
+static void config_control_apply_callback (EvolutionConfigControl *config_control, void *data);
+static void config_control_destroy_callback (GtkObject *object, void *data);
+static void cal_prefs_dialog_use_24_hour_toggled(GtkWidget *button, void *data);
+static void cal_prefs_dialog_hide_completed_tasks_toggled (GtkWidget *button, void *data);
-static void
-cal_prefs_dialog_class_init (CalPrefsDialogClass *class)
+GtkWidget *cal_prefs_dialog_create_time_edit (void);
+
+
+/**
+ * cal_prefs_dialog_new:
+ *
+ * Creates a new #CalPrefsDialog.
+ *
+ * Return value: a new #CalPrefsDialog.
+ **/
+EvolutionConfigControl *
+cal_prefs_dialog_new (void)
{
- GtkObjectClass *object_class;
+ DialogData *dialog_data;
+ EvolutionConfigControl *config_control;
- object_class = (GtkObjectClass *) class;
+ dialog_data = g_new0 (DialogData, 1);
- parent_class = gtk_type_class (GTK_TYPE_OBJECT);
+ /* Load the content widgets */
- object_class->destroy = cal_prefs_dialog_destroy;
-}
+ dialog_data->xml = glade_xml_new (EVOLUTION_GLADEDIR "/cal-prefs-dialog.glade", NULL);
+ if (!dialog_data->xml) {
+ g_message ("cal_prefs_dialog_construct(): Could not load the Glade XML file!");
+ return NULL;
+ }
+
+ if (!get_widgets (dialog_data)) {
+ g_message ("cal_prefs_dialog_construct(): Could not find all widgets in the XML file!");
+ return NULL;
+ }
+
+ init_widgets (dialog_data);
+ show_config (dialog_data);
+
+ gtk_widget_ref (dialog_data->page);
+ gtk_container_remove (GTK_CONTAINER (dialog_data->page->parent), dialog_data->page);
+ config_control = evolution_config_control_new (dialog_data->page);
+ gtk_widget_unref (dialog_data->page);
+ gtk_signal_connect (GTK_OBJECT (config_control), "apply",
+ GTK_SIGNAL_FUNC (config_control_apply_callback), dialog_data);
+ gtk_signal_connect (GTK_OBJECT (config_control), "destroy",
+ GTK_SIGNAL_FUNC (config_control_destroy_callback), dialog_data);
+
+ setup_changes (dialog_data, config_control);
+
+ return config_control;
+}
static void
-cal_prefs_dialog_init (CalPrefsDialog *prefs)
+widget_changed_callback (GtkWidget *widget,
+ void *data)
{
- CalPrefsDialogPrivate *priv;
+ EvolutionConfigControl *config_control;
- priv = g_new0 (CalPrefsDialogPrivate, 1);
- prefs->priv = priv;
+ config_control = EVOLUTION_CONFIG_CONTROL (data);
+ evolution_config_control_changed (config_control);
}
-
-/**
- * cal_prefs_dialog_new:
- * @page: Page to show when the dialog is popped up.
- *
- * Creates a new #CalPrefsDialog.
- *
- * Return value: a new #CalPrefsDialog.
- **/
-CalPrefsDialog *
-cal_prefs_dialog_new (CalPrefsDialogPage page)
+/* ^*&%!!#! GnomeColorPicker. */
+static void
+color_set_callback (GnomeColorPicker *cp,
+ guint r,
+ guint g,
+ guint b,
+ guint a,
+ void *data)
{
- CalPrefsDialog *prefs;
+ EvolutionConfigControl *config_control;
- prefs = CAL_PREFS_DIALOG (gtk_type_new (cal_prefs_dialog_get_type ()));
- return cal_prefs_dialog_construct (prefs, page);
-}
+ config_control = EVOLUTION_CONFIG_CONTROL (data);
+ evolution_config_control_changed (config_control);
+}
-/**
- * cal_prefs_dialog_construct:
- * @prefs: A #CalPrefsDialog.
- * @page: Page to show when the dialog is popped up.
- *
- * Constructs a task editor by loading its Glade XML file.
- *
- * Return value: The same object as @prefs, or NULL if the widgets could not be
- * created. In the latter case, the task editor will automatically be
- * destroyed.
- **/
-CalPrefsDialog *
-cal_prefs_dialog_construct (CalPrefsDialog *prefs, CalPrefsDialogPage page)
+static void
+connect_changed (GtkWidget *widget,
+ const char *signal_name,
+ EvolutionConfigControl *config_control)
{
- CalPrefsDialogPrivate *priv;
+ gtk_signal_connect (GTK_OBJECT (widget), signal_name,
+ GTK_SIGNAL_FUNC (widget_changed_callback), config_control);
+}
- g_return_val_if_fail (IS_CAL_PREFS_DIALOG (prefs), NULL);
+static void
+setup_changes (DialogData *dialog_data,
+ EvolutionConfigControl *config_control)
+{
+ int i;
- priv = prefs->priv;
+ for (i = 0; i < 7; i ++)
+ connect_changed (dialog_data->working_days[i], "toggled", config_control);
- /* Load the content widgets */
+ connect_changed (dialog_data->timezone, "changed", config_control);
- priv->xml = glade_xml_new (EVOLUTION_GLADEDIR "/cal-prefs-dialog.glade", NULL);
- if (!priv->xml) {
- g_message ("cal_prefs_dialog_construct(): Could not load the Glade XML file!");
- goto error;
- }
+ connect_changed (dialog_data->start_of_day, "changed", config_control);
+ connect_changed (dialog_data->end_of_day, "changed", config_control);
- if (!get_widgets (prefs)) {
- g_message ("cal_prefs_dialog_construct(): Could not find all widgets in the XML file!");
- goto error;
- }
+ connect_changed (GTK_OPTION_MENU (dialog_data->week_start_day)->menu, "selection_done", config_control);
- cal_prefs_dialog_init_widgets (prefs);
+ connect_changed (dialog_data->use_12_hour, "toggled", config_control);
- cal_prefs_dialog_show_config (prefs);
+ connect_changed (GTK_OPTION_MENU (dialog_data->time_divisions)->menu, "selection_done", config_control);
- cal_prefs_dialog_show (prefs, page);
+ connect_changed (dialog_data->show_end_times, "toggled", config_control);
+ connect_changed (dialog_data->compress_weekend, "toggled", config_control);
+ connect_changed (dialog_data->dnav_show_week_no, "toggled", config_control);
- return prefs;
+ connect_changed (dialog_data->tasks_hide_completed_checkbutton, "toggled", config_control);
+ connect_changed (dialog_data->tasks_hide_completed_spinbutton, "changed", config_control);
+ connect_changed (GTK_OPTION_MENU (dialog_data->tasks_hide_completed_spinbutton)->menu, "selection_done", config_control);
- error:
+ connect_changed (dialog_data->confirm_delete, "toggled", config_control);
+ connect_changed (dialog_data->default_reminder, "toggled", config_control);
+ connect_changed (dialog_data->default_reminder_interval, "changed", config_control);
+ connect_changed (GTK_OPTION_MENU (dialog_data->default_reminder_units)->menu, "selection_done", config_control);
- gtk_object_unref (GTK_OBJECT (prefs));
- return NULL;
+ /* These use GnomeColorPicker so we have to use a different signal. */
+ gtk_signal_connect (GTK_OBJECT (dialog_data->tasks_due_today_color), "color_set",
+ GTK_SIGNAL_FUNC (color_set_callback), config_control);
+ gtk_signal_connect (GTK_OBJECT (dialog_data->tasks_overdue_color), "color_set",
+ GTK_SIGNAL_FUNC (color_set_callback), config_control);
}
-
/* Gets the widgets from the XML file and returns if they are all available.
*/
static gboolean
-get_widgets (CalPrefsDialog *prefs)
+get_widgets (DialogData *data)
{
- CalPrefsDialogPrivate *priv;
-
- priv = prefs->priv;
-
-#define GW(name) glade_xml_get_widget (priv->xml, name)
+#define GW(name) glade_xml_get_widget (data->xml, name)
- priv->dialog = GW ("cal-prefs-dialog");
-
- priv->toplevel_notebook = GW ("toplevel-notebook");
+ data->page = GW ("toplevel-notebook");
/* The indices must be 0 (Sun) to 6 (Sat). */
- priv->working_days[0] = GW ("sun_button");
- priv->working_days[1] = GW ("mon_button");
- priv->working_days[2] = GW ("tue_button");
- priv->working_days[3] = GW ("wed_button");
- priv->working_days[4] = GW ("thu_button");
- priv->working_days[5] = GW ("fri_button");
- priv->working_days[6] = GW ("sat_button");
-
- priv->timezone = GW ("timezone");
- priv->week_start_day = GW ("first_day_of_week");
- priv->start_of_day = GW ("start_of_day");
- priv->end_of_day = GW ("end_of_day");
- priv->use_12_hour = GW ("use_12_hour");
- priv->use_24_hour = GW ("use_24_hour");
- priv->time_divisions = GW ("time_divisions");
- priv->show_end_times = GW ("show_end_times");
- priv->compress_weekend = GW ("compress_weekend");
- priv->dnav_show_week_no = GW ("dnav_show_week_no");
-
- priv->tasks_due_today_color = GW ("tasks_due_today_color");
- priv->tasks_overdue_color = GW ("tasks_overdue_color");
-
- priv->tasks_hide_completed_checkbutton = GW ("tasks-hide-completed-checkbutton");
- priv->tasks_hide_completed_spinbutton = GW ("tasks-hide-completed-spinbutton");
- priv->tasks_hide_completed_optionmenu = GW ("tasks-hide-completed-optionmenu");
-
- priv->confirm_delete = GW ("confirm-delete");
- priv->default_reminder = GW ("default-reminder");
- priv->default_reminder_interval = GW ("default-reminder-interval");
- priv->default_reminder_units = GW ("default-reminder-units");
+ data->working_days[0] = GW ("sun_button");
+ data->working_days[1] = GW ("mon_button");
+ data->working_days[2] = GW ("tue_button");
+ data->working_days[3] = GW ("wed_button");
+ data->working_days[4] = GW ("thu_button");
+ data->working_days[5] = GW ("fri_button");
+ data->working_days[6] = GW ("sat_button");
+
+ data->timezone = GW ("timezone");
+ data->week_start_day = GW ("first_day_of_week");
+ data->start_of_day = GW ("start_of_day");
+ data->end_of_day = GW ("end_of_day");
+ data->use_12_hour = GW ("use_12_hour");
+ data->use_24_hour = GW ("use_24_hour");
+ data->time_divisions = GW ("time_divisions");
+ data->show_end_times = GW ("show_end_times");
+ data->compress_weekend = GW ("compress_weekend");
+ data->dnav_show_week_no = GW ("dnav_show_week_no");
+
+ data->tasks_due_today_color = GW ("tasks_due_today_color");
+ data->tasks_overdue_color = GW ("tasks_overdue_color");
+
+ data->tasks_hide_completed_checkbutton = GW ("tasks-hide-completed-checkbutton");
+ data->tasks_hide_completed_spinbutton = GW ("tasks-hide-completed-spinbutton");
+ data->tasks_hide_completed_optionmenu = GW ("tasks-hide-completed-optionmenu");
+
+ data->confirm_delete = GW ("confirm-delete");
+ data->default_reminder = GW ("default-reminder");
+ data->default_reminder_interval = GW ("default-reminder-interval");
+ data->default_reminder_units = GW ("default-reminder-units");
#undef GW
- return (priv->dialog
- && priv->toplevel_notebook
- && priv->timezone
- && priv->working_days[0]
- && priv->working_days[1]
- && priv->working_days[2]
- && priv->working_days[3]
- && priv->working_days[4]
- && priv->working_days[5]
- && priv->working_days[6]
- && priv->week_start_day
- && priv->start_of_day
- && priv->end_of_day
- && priv->use_12_hour
- && priv->use_24_hour
- && priv->time_divisions
- && priv->show_end_times
- && priv->compress_weekend
- && priv->dnav_show_week_no
- && priv->tasks_due_today_color
- && priv->tasks_overdue_color
- && priv->tasks_hide_completed_checkbutton
- && priv->tasks_hide_completed_spinbutton
- && priv->tasks_hide_completed_optionmenu
- && priv->confirm_delete
- && priv->default_reminder
- && priv->default_reminder_interval
- && priv->default_reminder_units);
+ return (data->page
+ && data->timezone
+ && data->working_days[0]
+ && data->working_days[1]
+ && data->working_days[2]
+ && data->working_days[3]
+ && data->working_days[4]
+ && data->working_days[5]
+ && data->working_days[6]
+ && data->week_start_day
+ && data->start_of_day
+ && data->end_of_day
+ && data->use_12_hour
+ && data->use_24_hour
+ && data->time_divisions
+ && data->show_end_times
+ && data->compress_weekend
+ && data->dnav_show_week_no
+ && data->tasks_due_today_color
+ && data->tasks_overdue_color
+ && data->tasks_hide_completed_checkbutton
+ && data->tasks_hide_completed_spinbutton
+ && data->tasks_hide_completed_optionmenu
+ && data->confirm_delete
+ && data->default_reminder
+ && data->default_reminder_interval
+ && data->default_reminder_units);
}
static void
-cal_prefs_dialog_destroy (GtkObject *object)
+config_control_destroy_callback (GtkObject *object,
+ void *data)
{
- CalPrefsDialog *prefs;
- CalPrefsDialogPrivate *priv;
+ DialogData *dialog_data;
- g_return_if_fail (IS_CAL_PREFS_DIALOG (object));
+ dialog_data = (DialogData *) data;
- prefs = CAL_PREFS_DIALOG (object);
- priv = prefs->priv;
+ /* (Nothing to free in the struct.) */
+ g_free (dialog_data);
+}
- g_free (priv);
- prefs->priv = NULL;
+static void
+config_control_apply_callback (EvolutionConfigControl *control,
+ void *data)
+{
+ DialogData *dialog_data;
+
+ dialog_data = (DialogData *) data;
- if (GTK_OBJECT_CLASS (parent_class)->destroy)
- (* GTK_OBJECT_CLASS (parent_class)->destroy) (object);
+ update_config (dialog_data);
}
@@ -322,122 +350,49 @@ cal_prefs_dialog_create_time_edit (void)
}
-void
-cal_prefs_dialog_show (CalPrefsDialog *prefs, CalPrefsDialogPage page)
-{
- CalPrefsDialogPrivate *priv;
- int page_num;
-
- g_return_if_fail (IS_CAL_PREFS_DIALOG (prefs));
-
- priv = prefs->priv;
-
- /* If the dialog is already show just raise it, otherwise refresh the
- config settings and show it. */
- if (GTK_WIDGET_MAPPED (priv->dialog)) {
- gdk_window_raise (priv->dialog->window);
- } else {
- cal_prefs_dialog_show_config (prefs);
- gtk_widget_show (priv->dialog);
- }
-
- switch (page) {
- case CAL_PREFS_DIALOG_PAGE_CALENDAR:
- page_num = 0;
- break;
-
- case CAL_PREFS_DIALOG_PAGE_TASKS:
- page_num = 2;
- break;
-
- default:
- g_assert_not_reached ();
- return;
- }
-
- gtk_notebook_set_page (GTK_NOTEBOOK (priv->toplevel_notebook), page_num);
-}
-
-
/* Connects any necessary signal handlers. */
static void
-cal_prefs_dialog_init_widgets (CalPrefsDialog *prefs)
+init_widgets (DialogData *dialog_data)
{
- CalPrefsDialogPrivate *priv;
-
- priv = prefs->priv;
-
- gtk_signal_connect (GTK_OBJECT (priv->dialog), "clicked",
- GTK_SIGNAL_FUNC (cal_prefs_dialog_button_clicked),
- prefs);
-
- gtk_signal_connect (GTK_OBJECT (priv->use_24_hour), "toggled",
+ gtk_signal_connect (GTK_OBJECT (dialog_data->use_24_hour), "toggled",
GTK_SIGNAL_FUNC (cal_prefs_dialog_use_24_hour_toggled),
- prefs);
+ dialog_data);
- gtk_signal_connect (GTK_OBJECT (priv->tasks_hide_completed_checkbutton),
+ gtk_signal_connect (GTK_OBJECT (dialog_data->tasks_hide_completed_checkbutton),
"toggled",
GTK_SIGNAL_FUNC (cal_prefs_dialog_hide_completed_tasks_toggled),
- prefs);
+ dialog_data);
}
static void
-cal_prefs_dialog_button_clicked (GtkWidget *dialog,
- gint button,
- CalPrefsDialog *prefs)
+cal_prefs_dialog_use_24_hour_toggled (GtkWidget *button,
+ void *data)
{
- CalPrefsDialogPrivate *priv;
-
- g_return_if_fail (IS_CAL_PREFS_DIALOG (prefs));
-
- priv = prefs->priv;
-
- /* OK & Apply buttons update the config settings. */
- if (button == 0 || button == 1)
- cal_prefs_dialog_update_config (prefs);
-
- /* OK & Close buttons close the dialog. */
- if (button == 0 || button == 2)
- gtk_widget_hide (priv->dialog);
-
- /* FIXME: Handle button 3 (Help). */
-
-}
-
-
-static void
-cal_prefs_dialog_use_24_hour_toggled (GtkWidget *button,
- CalPrefsDialog *prefs)
-{
- CalPrefsDialogPrivate *priv;
+ DialogData *dialog_data;
gboolean use_24_hour;
- priv = prefs->priv;
+ dialog_data = (DialogData *) data;
- use_24_hour = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (priv->use_24_hour));
+ use_24_hour = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (dialog_data->use_24_hour));
- e_date_edit_set_use_24_hour_format (E_DATE_EDIT (priv->start_of_day),
- use_24_hour);
- e_date_edit_set_use_24_hour_format (E_DATE_EDIT (priv->end_of_day),
- use_24_hour);
+ e_date_edit_set_use_24_hour_format (E_DATE_EDIT (dialog_data->start_of_day), use_24_hour);
+ e_date_edit_set_use_24_hour_format (E_DATE_EDIT (dialog_data->end_of_day), use_24_hour);
}
static void
-cal_prefs_dialog_hide_completed_tasks_toggled (GtkWidget *button,
- CalPrefsDialog *prefs)
+cal_prefs_dialog_hide_completed_tasks_toggled (GtkWidget *button,
+ void *data)
{
- CalPrefsDialogPrivate *priv;
+ DialogData *dialog_data;
gboolean hide_completed_tasks;
- priv = prefs->priv;
+ dialog_data = (DialogData *) data;
- hide_completed_tasks = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (priv->tasks_hide_completed_checkbutton));
+ hide_completed_tasks = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (dialog_data->tasks_hide_completed_checkbutton));
- gtk_widget_set_sensitive (priv->tasks_hide_completed_spinbutton,
- hide_completed_tasks);
- gtk_widget_set_sensitive (priv->tasks_hide_completed_optionmenu,
- hide_completed_tasks);
+ gtk_widget_set_sensitive (dialog_data->tasks_hide_completed_spinbutton, hide_completed_tasks);
+ gtk_widget_set_sensitive (dialog_data->tasks_hide_completed_optionmenu, hide_completed_tasks);
}
/* Sets the color in a color picker from an X color spec */
@@ -462,117 +417,111 @@ set_color_picker (GtkWidget *picker, const char *spec)
/* Shows the current task list settings in the dialog */
static void
-show_task_list_config (CalPrefsDialog *prefs)
+show_task_list_config (DialogData *dialog_data)
{
- CalPrefsDialogPrivate *priv;
CalUnits units;
gboolean hide_completed_tasks;
- priv = prefs->priv;
-
- set_color_picker (priv->tasks_due_today_color, calendar_config_get_tasks_due_today_color ());
- set_color_picker (priv->tasks_overdue_color, calendar_config_get_tasks_overdue_color ());
+ set_color_picker (dialog_data->tasks_due_today_color, calendar_config_get_tasks_due_today_color ());
+ set_color_picker (dialog_data->tasks_overdue_color, calendar_config_get_tasks_overdue_color ());
/* Hide Completed Tasks. */
hide_completed_tasks = calendar_config_get_hide_completed_tasks ();
- e_dialog_toggle_set (priv->tasks_hide_completed_checkbutton,
+ e_dialog_toggle_set (dialog_data->tasks_hide_completed_checkbutton,
hide_completed_tasks);
/* Hide Completed Tasks Units. */
units = calendar_config_get_hide_completed_tasks_units ();
- e_dialog_option_menu_set (priv->tasks_hide_completed_optionmenu,
+ e_dialog_option_menu_set (dialog_data->tasks_hide_completed_optionmenu,
units, hide_completed_units_map);
/* Hide Completed Tasks Value. */
- e_dialog_spin_set (priv->tasks_hide_completed_spinbutton,
+ e_dialog_spin_set (dialog_data->tasks_hide_completed_spinbutton,
calendar_config_get_hide_completed_tasks_value ());
- gtk_widget_set_sensitive (priv->tasks_hide_completed_spinbutton,
+ gtk_widget_set_sensitive (dialog_data->tasks_hide_completed_spinbutton,
hide_completed_tasks);
- gtk_widget_set_sensitive (priv->tasks_hide_completed_optionmenu,
+ gtk_widget_set_sensitive (dialog_data->tasks_hide_completed_optionmenu,
hide_completed_tasks);
}
/* Shows the current config settings in the dialog. */
static void
-cal_prefs_dialog_show_config (CalPrefsDialog *prefs)
+show_config (DialogData *dialog_data)
{
- CalPrefsDialogPrivate *priv;
CalWeekdays working_days;
gint mask, day, week_start_day, time_divisions;
char *zone_name;
icaltimezone *zone;
gboolean sensitive;
- priv = prefs->priv;
-
/* Timezone. */
zone_name = calendar_config_get_timezone ();
zone = icaltimezone_get_builtin_timezone (zone_name);
- e_timezone_entry_set_timezone (E_TIMEZONE_ENTRY (priv->timezone),
+ e_timezone_entry_set_timezone (E_TIMEZONE_ENTRY (dialog_data->timezone),
zone);
/* Working Days. */
working_days = calendar_config_get_working_days ();
mask = 1 << 0;
for (day = 0; day < 7; day++) {
- e_dialog_toggle_set (priv->working_days[day], (working_days & mask) ? TRUE : FALSE);
+ e_dialog_toggle_set (dialog_data->working_days[day], (working_days & mask) ? TRUE : FALSE);
mask <<= 1;
}
/* Week Start Day. */
week_start_day = calendar_config_get_week_start_day ();
- e_dialog_option_menu_set (priv->week_start_day, week_start_day,
+ e_dialog_option_menu_set (dialog_data->week_start_day, week_start_day,
week_start_day_map);
/* Start of Day. */
- e_date_edit_set_time_of_day (E_DATE_EDIT (priv->start_of_day),
+ e_date_edit_set_time_of_day (E_DATE_EDIT (dialog_data->start_of_day),
calendar_config_get_day_start_hour (),
calendar_config_get_day_start_minute ());
/* End of Day. */
- e_date_edit_set_time_of_day (E_DATE_EDIT (priv->end_of_day),
+ e_date_edit_set_time_of_day (E_DATE_EDIT (dialog_data->end_of_day),
calendar_config_get_day_end_hour (),
calendar_config_get_day_end_minute ());
/* 12/24 Hour Format. */
if (calendar_config_get_24_hour_format ())
- e_dialog_toggle_set (priv->use_24_hour, TRUE);
+ e_dialog_toggle_set (dialog_data->use_24_hour, TRUE);
else
- e_dialog_toggle_set (priv->use_12_hour, TRUE);
+ e_dialog_toggle_set (dialog_data->use_12_hour, TRUE);
sensitive = calendar_config_locale_supports_12_hour_format ();
- gtk_widget_set_sensitive (priv->use_12_hour, sensitive);
- gtk_widget_set_sensitive (priv->use_24_hour, sensitive);
+ gtk_widget_set_sensitive (dialog_data->use_12_hour, sensitive);
+ gtk_widget_set_sensitive (dialog_data->use_24_hour, sensitive);
/* Time Divisions. */
time_divisions = calendar_config_get_time_divisions ();
- e_dialog_option_menu_set (priv->time_divisions, time_divisions,
+ e_dialog_option_menu_set (dialog_data->time_divisions, time_divisions,
time_division_map);
/* Show Appointment End Times. */
- e_dialog_toggle_set (priv->show_end_times, calendar_config_get_show_event_end ());
+ e_dialog_toggle_set (dialog_data->show_end_times, calendar_config_get_show_event_end ());
/* Compress Weekend. */
- e_dialog_toggle_set (priv->compress_weekend, calendar_config_get_compress_weekend ());
+ e_dialog_toggle_set (dialog_data->compress_weekend, calendar_config_get_compress_weekend ());
/* Date Navigator - Show Week Numbers. */
- e_dialog_toggle_set (priv->dnav_show_week_no, calendar_config_get_dnav_show_week_no ());
+ e_dialog_toggle_set (dialog_data->dnav_show_week_no, calendar_config_get_dnav_show_week_no ());
/* Task list */
- show_task_list_config (prefs);
+ show_task_list_config (dialog_data);
/* Other page */
- e_dialog_toggle_set (priv->confirm_delete, calendar_config_get_confirm_delete ());
+ e_dialog_toggle_set (dialog_data->confirm_delete, calendar_config_get_confirm_delete ());
- e_dialog_toggle_set (priv->default_reminder,
+ e_dialog_toggle_set (dialog_data->default_reminder,
calendar_config_get_use_default_reminder ());
- e_dialog_spin_set (priv->default_reminder_interval,
+ e_dialog_spin_set (dialog_data->default_reminder_interval,
calendar_config_get_default_reminder_interval ());
- e_dialog_option_menu_set (priv->default_reminder_units,
+ e_dialog_option_menu_set (dialog_data->default_reminder_units,
calendar_config_get_default_reminder_units (),
default_reminder_units_map);
}
@@ -594,89 +543,82 @@ spec_from_picker (GtkWidget *picker)
/* Updates the task list config values from the settings in the dialog */
static void
-update_task_list_config (CalPrefsDialog *prefs)
+update_task_list_config (DialogData *dialog_data)
{
- CalPrefsDialogPrivate *priv;
+ calendar_config_set_tasks_due_today_color (spec_from_picker (dialog_data->tasks_due_today_color));
+ calendar_config_set_tasks_overdue_color (spec_from_picker (dialog_data->tasks_overdue_color));
- priv = prefs->priv;
-
- calendar_config_set_tasks_due_today_color (spec_from_picker (priv->tasks_due_today_color));
- calendar_config_set_tasks_overdue_color (spec_from_picker (priv->tasks_overdue_color));
-
- calendar_config_set_hide_completed_tasks (e_dialog_toggle_get (priv->tasks_hide_completed_checkbutton));
- calendar_config_set_hide_completed_tasks_units (e_dialog_option_menu_get (priv->tasks_hide_completed_optionmenu, hide_completed_units_map));
- calendar_config_set_hide_completed_tasks_value (e_dialog_spin_get_int (priv->tasks_hide_completed_spinbutton));
+ calendar_config_set_hide_completed_tasks (e_dialog_toggle_get (dialog_data->tasks_hide_completed_checkbutton));
+ calendar_config_set_hide_completed_tasks_units (e_dialog_option_menu_get (dialog_data->tasks_hide_completed_optionmenu, hide_completed_units_map));
+ calendar_config_set_hide_completed_tasks_value (e_dialog_spin_get_int (dialog_data->tasks_hide_completed_spinbutton));
}
/* Updates the config values based on the settings in the dialog. */
static void
-cal_prefs_dialog_update_config (CalPrefsDialog *prefs)
+update_config (DialogData *dialog_data)
{
- CalPrefsDialogPrivate *priv;
CalWeekdays working_days;
gint mask, day, week_start_day, time_divisions, hour, minute;
icaltimezone *zone;
- priv = prefs->priv;
-
/* Timezone. */
- zone = e_timezone_entry_get_timezone (E_TIMEZONE_ENTRY (priv->timezone));
+ zone = e_timezone_entry_get_timezone (E_TIMEZONE_ENTRY (dialog_data->timezone));
calendar_config_set_timezone (icaltimezone_get_location (zone));
/* Working Days. */
working_days = 0;
mask = 1 << 0;
for (day = 0; day < 7; day++) {
- if (e_dialog_toggle_get (priv->working_days[day]))
+ if (e_dialog_toggle_get (dialog_data->working_days[day]))
working_days |= mask;
mask <<= 1;
}
calendar_config_set_working_days (working_days);
/* Week Start Day. */
- week_start_day = e_dialog_option_menu_get (priv->week_start_day, week_start_day_map);
+ week_start_day = e_dialog_option_menu_get (dialog_data->week_start_day, week_start_day_map);
calendar_config_set_week_start_day (week_start_day);
/* Start of Day. */
- e_date_edit_get_time_of_day (E_DATE_EDIT (priv->start_of_day), &hour, &minute);
+ e_date_edit_get_time_of_day (E_DATE_EDIT (dialog_data->start_of_day), &hour, &minute);
calendar_config_set_day_start_hour (hour);
calendar_config_set_day_start_minute (minute);
/* End of Day. */
- e_date_edit_get_time_of_day (E_DATE_EDIT (priv->end_of_day), &hour, &minute);
+ e_date_edit_get_time_of_day (E_DATE_EDIT (dialog_data->end_of_day), &hour, &minute);
calendar_config_set_day_end_hour (hour);
calendar_config_set_day_end_minute (minute);
/* 12/24 Hour Format. */
- calendar_config_set_24_hour_format (e_dialog_toggle_get (priv->use_24_hour));
+ calendar_config_set_24_hour_format (e_dialog_toggle_get (dialog_data->use_24_hour));
/* Time Divisions. */
- time_divisions = e_dialog_option_menu_get (priv->time_divisions, time_division_map);
+ time_divisions = e_dialog_option_menu_get (dialog_data->time_divisions, time_division_map);
calendar_config_set_time_divisions (time_divisions);
/* Show Appointment End Times. */
- calendar_config_set_show_event_end (e_dialog_toggle_get (priv->show_end_times));
+ calendar_config_set_show_event_end (e_dialog_toggle_get (dialog_data->show_end_times));
/* Compress Weekend. */
- calendar_config_set_compress_weekend (e_dialog_toggle_get (priv->compress_weekend));
+ calendar_config_set_compress_weekend (e_dialog_toggle_get (dialog_data->compress_weekend));
/* Date Navigator - Show Week Numbers. */
- calendar_config_set_dnav_show_week_no (e_dialog_toggle_get (priv->dnav_show_week_no));
+ calendar_config_set_dnav_show_week_no (e_dialog_toggle_get (dialog_data->dnav_show_week_no));
/* Task list */
- update_task_list_config (prefs);
+ update_task_list_config (dialog_data);
/* Other page */
- calendar_config_set_confirm_delete (e_dialog_toggle_get (priv->confirm_delete));
+ calendar_config_set_confirm_delete (e_dialog_toggle_get (dialog_data->confirm_delete));
- calendar_config_set_use_default_reminder (e_dialog_toggle_get (priv->default_reminder));
+ calendar_config_set_use_default_reminder (e_dialog_toggle_get (dialog_data->default_reminder));
calendar_config_set_default_reminder_interval (
- e_dialog_spin_get_int (priv->default_reminder_interval));
+ e_dialog_spin_get_int (dialog_data->default_reminder_interval));
calendar_config_set_default_reminder_units (
- e_dialog_option_menu_get (priv->default_reminder_units, default_reminder_units_map));
+ e_dialog_option_menu_get (dialog_data->default_reminder_units, default_reminder_units_map));
/* Done */
diff --git a/calendar/gui/dialogs/cal-prefs-dialog.glade b/calendar/gui/dialogs/cal-prefs-dialog.glade
index 6a14f50ec3..20b2c5e363 100644
--- a/calendar/gui/dialogs/cal-prefs-dialog.glade
+++ b/calendar/gui/dialogs/cal-prefs-dialog.glade
@@ -15,6 +15,7 @@
<widget>
<class>GnomeDialog</class>
<name>cal-prefs-dialog</name>
+ <visible>False</visible>
<title>Calendar and Tasks Settings</title>
<type>GTK_WINDOW_TOPLEVEL</type>
<position>GTK_WIN_POS_NONE</position>
diff --git a/calendar/gui/dialogs/cal-prefs-dialog.h b/calendar/gui/dialogs/cal-prefs-dialog.h
index 063341c18a..ce3f46736c 100644
--- a/calendar/gui/dialogs/cal-prefs-dialog.h
+++ b/calendar/gui/dialogs/cal-prefs-dialog.h
@@ -30,46 +30,9 @@
#ifndef _CAL_PREFS_DIALOG_H_
#define _CAL_PREFS_DIALOG_H_
-#include <gtk/gtkobject.h>
-#include <libgnome/gnome-defs.h>
+#include "evolution-config-control.h"
-BEGIN_GNOME_DECLS
-
-
-#define CAL_PREFS_DIALOG(obj) GTK_CHECK_CAST (obj, cal_prefs_dialog_get_type (), CalPrefsDialog)
-#define CAL_PREFS_DIALOG_CLASS(klass) GTK_CHECK_CLASS_CAST (klass, cal_prefs_dialog_get_type (), CalPrefsDialogClass)
-#define IS_CAL_PREFS_DIALOG(obj) GTK_CHECK_TYPE (obj, cal_prefs_dialog_get_type ())
-
-
-typedef struct _CalPrefsDialog CalPrefsDialog;
-typedef struct _CalPrefsDialogClass CalPrefsDialogClass;
-
-typedef struct _CalPrefsDialogPrivate CalPrefsDialogPrivate;
-
-typedef enum {
- CAL_PREFS_DIALOG_PAGE_CALENDAR,
- CAL_PREFS_DIALOG_PAGE_TASKS
-} CalPrefsDialogPage;
-
-struct _CalPrefsDialog
-{
- GtkObject object;
-
- /*< private >*/
- CalPrefsDialogPrivate *priv;
-};
-
-struct _CalPrefsDialogClass
-{
- GtkObjectClass parent_class;
-};
-
-
-GtkType cal_prefs_dialog_get_type (void);
-CalPrefsDialog* cal_prefs_dialog_construct (CalPrefsDialog *prefs, CalPrefsDialogPage page);
-CalPrefsDialog* cal_prefs_dialog_new (CalPrefsDialogPage page);
-
-void cal_prefs_dialog_show (CalPrefsDialog *prefs, CalPrefsDialogPage page);
+EvolutionConfigControl *cal_prefs_dialog_new (void);
END_GNOME_DECLS