aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui
diff options
context:
space:
mode:
authorLarry Ewing <lewing@ximian.com>2004-05-05 02:52:10 +0800
committerLarry Ewing <lewing@src.gnome.org>2004-05-05 02:52:10 +0800
commitc5168397e97f5ea4fd10ed44654c951c12b0323a (patch)
tree6c6be49a51755348ecce8c94e69c87ea2852a946 /calendar/gui
parent00e4bc50fcc71dbfdc9a45561bcc099107dc4830 (diff)
downloadgsoc2013-evolution-c5168397e97f5ea4fd10ed44654c951c12b0323a.tar
gsoc2013-evolution-c5168397e97f5ea4fd10ed44654c951c12b0323a.tar.gz
gsoc2013-evolution-c5168397e97f5ea4fd10ed44654c951c12b0323a.tar.bz2
gsoc2013-evolution-c5168397e97f5ea4fd10ed44654c951c12b0323a.tar.lz
gsoc2013-evolution-c5168397e97f5ea4fd10ed44654c951c12b0323a.tar.xz
gsoc2013-evolution-c5168397e97f5ea4fd10ed44654c951c12b0323a.tar.zst
gsoc2013-evolution-c5168397e97f5ea4fd10ed44654c951c12b0323a.zip
convert units. (dialog_to_source): convert time units.
2004-05-04 Larry Ewing <lewing@ximian.com> * gui/dialogs/calendar-setup.c (source_to_dialog): convert units. (dialog_to_source): convert time units. * gui/dialogs/calendar-setup.glade. name the unit option menus. svn path=/trunk/; revision=25791
Diffstat (limited to 'calendar/gui')
-rw-r--r--calendar/gui/dialogs/calendar-setup.c68
-rw-r--r--calendar/gui/dialogs/calendar-setup.glade4
2 files changed, 63 insertions, 9 deletions
diff --git a/calendar/gui/dialogs/calendar-setup.c b/calendar/gui/dialogs/calendar-setup.c
index d841150e48..2ffffcd667 100644
--- a/calendar/gui/dialogs/calendar-setup.c
+++ b/calendar/gui/dialogs/calendar-setup.c
@@ -74,6 +74,7 @@ typedef struct
GtkWidget *uri_hbox;
GtkWidget *refresh_label;
GtkWidget *refresh_hbox;
+ GtkWidget *refresh_optionmenu;
GtkWidget *add_button;
}
SourceDialog;
@@ -396,6 +397,62 @@ colorpicker_get_color (GnomeColorPicker *color)
return rgb;
}
+static char *
+get_refresh_minutes (SourceDialog *source_dialog)
+{
+ int setting = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (source_dialog->refresh_spin));
+
+ if (source_dialog->refresh_optionmenu)
+ switch (gtk_option_menu_get_history (GTK_OPTION_MENU (source_dialog->refresh_optionmenu))){
+ case 0: /* minutes */
+ break;
+ case 1: /* hours */
+ setting *= 60;
+ break;
+ case 2: /* days */
+ setting *= 1440;
+ break;
+ case 3: /* weeks wtf? why so long */
+ setting *= 10080;
+ break;
+ default:
+ g_warning ("Time unit out of range");
+ break;
+ }
+
+ return g_strdup_printf ("%d", setting);
+}
+
+static void
+set_refresh_time (SourceDialog *source_dialog) {
+ int time;
+ int item_num = 0;
+
+ const char *refresh_str = e_source_get_property (source_dialog->source, "refresh");
+ time = refresh_str ? atoi (refresh_str) : 30;
+
+ if (source_dialog->refresh_optionmenu) {
+ if (time && time % 10080) {
+ /* weeks */
+ item_num = 3;
+ time /= 10080;
+ } else if (time && time % 1440) {
+ /* days */
+ item_num = 2;
+ time /= 1440;
+ } else if (time && time % 60) {
+ /* days */
+ item_num = 1;
+ time /= 60;
+ }
+
+ gtk_option_menu_set_history (GTK_OPTION_MENU (source_dialog->refresh_optionmenu), item_num);
+ }
+
+ gtk_spin_button_set_value (GTK_SPIN_BUTTON (source_dialog->refresh_spin), time);
+ return;
+}
+
static void
source_to_dialog (SourceDialog *source_dialog)
{
@@ -417,7 +474,6 @@ source_to_dialog (SourceDialog *source_dialog)
if (source && source_is_remote (source)) {
gchar *uri_str;
- const gchar *refresh_str;
remote = TRUE;
@@ -425,9 +481,7 @@ source_to_dialog (SourceDialog *source_dialog)
gtk_entry_set_text (GTK_ENTRY (source_dialog->uri_entry), uri_str);
g_free (uri_str);
- refresh_str = e_source_get_property (source, "refresh");
- gtk_spin_button_set_value (GTK_SPIN_BUTTON (source_dialog->refresh_spin),
- refresh_str ? atoi (refresh_str) : 30);
+ set_refresh_time (source_dialog);
} else {
if (source_dialog->uri_entry)
gtk_entry_set_text (GTK_ENTRY (source_dialog->uri_entry), "");
@@ -482,9 +536,7 @@ dialog_to_source (SourceDialog *source_dialog)
g_free (relative_uri);
e_uri_free (uri);
- refresh_str = g_strdup_printf ("%d",
- gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (source_dialog->refresh_spin)));
-
+ refresh_str = get_refresh_minutes (source_dialog);
e_source_set_property (source, "refresh", refresh_str);
g_free (refresh_str);
}
@@ -624,6 +676,7 @@ calendar_setup_new_calendar (GtkWindow *parent)
G_CALLBACK (general_entry_modified), source_dialog);
source_dialog->refresh_spin = glade_xml_get_widget (source_dialog->gui_xml, "refresh-spin");
+ source_dialog->refresh_optionmenu = glade_xml_get_widget (source_dialog->gui_xml, "refresh-optionmenu");
source_dialog->refresh_label = glade_xml_get_widget (source_dialog->gui_xml, "refresh-label");
source_dialog->refresh_hbox = glade_xml_get_widget (source_dialog->gui_xml, "refresh-hbox");
@@ -786,6 +839,7 @@ calendar_setup_new_task_list (GtkWindow *parent)
G_CALLBACK (general_entry_modified), source_dialog);
source_dialog->refresh_spin = glade_xml_get_widget (source_dialog->gui_xml, "refresh-spin");
+ source_dialog->refresh_optionmenu = glade_xml_get_widget (source_dialog->gui_xml, "refresh-optionmenu");
source_dialog->refresh_label = glade_xml_get_widget (source_dialog->gui_xml, "refresh-label");
source_dialog->refresh_hbox = glade_xml_get_widget (source_dialog->gui_xml, "refresh-hbox");
diff --git a/calendar/gui/dialogs/calendar-setup.glade b/calendar/gui/dialogs/calendar-setup.glade
index 758759b8e4..bd13ff5f71 100644
--- a/calendar/gui/dialogs/calendar-setup.glade
+++ b/calendar/gui/dialogs/calendar-setup.glade
@@ -131,7 +131,7 @@
</child>
<child>
- <widget class="GtkOptionMenu" id="optionmenu3">
+ <widget class="GtkOptionMenu" id="refresh-optionmenu">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="history">0</property>
@@ -1485,7 +1485,7 @@
</child>
<child>
- <widget class="GtkOptionMenu" id="optionmenu6">
+ <widget class="GtkOptionMenu" id="refresh-optionmenu">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="history">0</property>