aboutsummaryrefslogtreecommitdiffstats
path: root/mail
diff options
context:
space:
mode:
Diffstat (limited to 'mail')
-rw-r--r--mail/ChangeLog15
-rw-r--r--mail/mail-config-druid.c30
-rw-r--r--mail/mail-config-druid.h6
-rw-r--r--mail/mail-config.c17
-rw-r--r--mail/mail-config.glade66
-rw-r--r--mail/mail-config.glade.h2
-rw-r--r--mail/mail-config.h2
-rw-r--r--mail/mail-display.c2
8 files changed, 139 insertions, 1 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index 39b1c20ed4..71ebcc3a15 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,18 @@
+2001-02-08 Jeffrey Stedfast <fejj@ximian.com>
+
+ * mail-display.c (on_object_requested): Cast the CamelMedium to a
+ CamelMimePart before performing actions on it as if it were a
+ CamelMimePart.
+
+ * mail-config-druid.c (druid_finish): Save the auto-check settings.
+ (construct): Initialize auto-check widgets.
+ (mail_config_druid_get_auto_check): New function
+ (mail_config_druid_get_auto_check_minutes): New functions
+
+ * mail-config.c (config_read): Read in whether or not to check
+ every x minutes.
+ (mail_config_write): Save auto-check config data and SSL.
+
2001-02-07 Jeffrey Stedfast <fejj@ximian.com>
* mail-autofilter.c (rule_add_subject): Use "contains" because the
diff --git a/mail/mail-config-druid.c b/mail/mail-config-druid.c
index d33247d33a..748506ff80 100644
--- a/mail/mail-config-druid.c
+++ b/mail/mail-config-druid.c
@@ -203,6 +203,8 @@ druid_finish (GnomeDruidPage *page, gpointer arg1, gpointer user_data)
/* construct the source */
source = g_new0 (MailConfigService, 1);
source->keep_on_server = mail_config_druid_get_keep_mail_on_server (druid);
+ source->auto_check = mail_config_druid_get_auto_check (druid);
+ source->auto_check_time = mail_config_druid_get_auto_check_minutes (druid);
source->save_passwd = mail_config_druid_get_save_password (druid);
str = mail_config_druid_get_source_url (druid);
if (str) {
@@ -318,6 +320,14 @@ incoming_check (MailConfigDruid *druid)
}
static void
+auto_check_toggled (GtkToggleButton *button, gpointer data)
+{
+ MailConfigDruid *druid = data;
+
+ gtk_widget_set_sensitive (GTK_WIDGET (druid->incoming_auto_check_min), button->active);
+}
+
+static void
incoming_changed (GtkWidget *widget, gpointer data)
{
MailConfigDruid *druid = data;
@@ -1076,6 +1086,9 @@ construct (MailConfigDruid *druid)
druid->incoming_path = GTK_ENTRY (glade_xml_get_widget (gui, "txtIncomingPath"));
gtk_signal_connect (GTK_OBJECT (druid->incoming_path), "changed", incoming_changed, druid);
druid->incoming_keep_mail = GTK_CHECK_BUTTON (glade_xml_get_widget (gui, "chkIncomingKeepMail"));
+ druid->incoming_auto_check = GTK_CHECK_BUTTON (glade_xml_get_widget (gui, "chkAutoCheck"));
+ gtk_signal_connect (GTK_OBJECT (druid->incoming_auto_check), "toggled", auto_check_toggled, druid);
+ druid->incoming_auto_check_min = GTK_SPIN_BUTTON (glade_xml_get_widget (gui, "spinAutoCheckMinutes"));
druid->incoming_check_settings = GTK_CHECK_BUTTON (glade_xml_get_widget (gui, "chkIncomingCheckSettings"));
druid->have_auth_page = TRUE;
@@ -1217,6 +1230,23 @@ mail_config_druid_get_keep_mail_on_server (MailConfigDruid *druid)
gboolean
+mail_config_druid_get_auto_check (MailConfigDruid *druid)
+{
+ g_return_val_if_fail (IS_MAIL_CONFIG_DRUID (druid), FALSE);
+
+ return GTK_TOGGLE_BUTTON (druid->incoming_auto_check)->active;
+}
+
+
+gint
+mail_config_druid_get_auto_check_minutes (MailConfigDruid *druid)
+{
+ g_return_val_if_fail (IS_MAIL_CONFIG_DRUID (druid), 0);
+
+ return gtk_spin_button_get_value_as_int (druid->incoming_auto_check_min);
+}
+
+gboolean
mail_config_druid_get_save_password (MailConfigDruid *druid)
{
g_return_val_if_fail (IS_MAIL_CONFIG_DRUID (druid), FALSE);
diff --git a/mail/mail-config-druid.h b/mail/mail-config-druid.h
index 836e00a6ae..9f3fed8547 100644
--- a/mail/mail-config-druid.h
+++ b/mail/mail-config-druid.h
@@ -69,6 +69,8 @@ struct _MailConfigDruid {
GtkEntry *incoming_username;
GtkEntry *incoming_path;
GtkCheckButton *incoming_keep_mail;
+ GtkCheckButton *incoming_auto_check;
+ GtkSpinButton *incoming_auto_check_min;
GtkCheckButton *incoming_check_settings;
/* authentication */
@@ -122,6 +124,10 @@ gboolean mail_config_druid_get_keep_mail_on_server (MailConfigDruid *druid);
gboolean mail_config_druid_get_save_password (MailConfigDruid *druid);
+gboolean mail_config_druid_get_auto_check (MailConfigDruid *druid);
+
+gint mail_config_druid_get_auto_check_minutes (MailConfigDruid *druid);
+
char *mail_config_druid_get_transport_url (MailConfigDruid *druid);
gboolean mail_config_druid_get_transport_requires_auth (MailConfigDruid *druid);
diff --git a/mail/mail-config.c b/mail/mail-config.c
index a4f9c15a86..3076ebacef 100644
--- a/mail/mail-config.c
+++ b/mail/mail-config.c
@@ -99,6 +99,8 @@ service_copy (const MailConfigService *source)
new = g_new0 (MailConfigService, 1);
new->url = g_strdup (source->url);
new->keep_on_server = source->keep_on_server;
+ new->auto_check = source->auto_check;
+ new->auto_check_time = source->auto_check_time;
new->save_passwd = source->save_passwd;
new->use_ssl = source->use_ssl;
@@ -260,6 +262,12 @@ config_read (void)
path = g_strdup_printf ("source_keep_on_server_%d", i);
source->keep_on_server = gnome_config_get_bool (path);
g_free (path);
+ path = g_strdup_printf ("source_auto_check_%d", i);
+ source->auto_check = gnome_config_get_bool (path);
+ g_free (path);
+ path = g_strdup_printf ("source_auto_check_time_%d", i);
+ source->auto_check_time = gnome_config_get_int (path);
+ g_free (path);
path = g_strdup_printf ("source_save_passwd_%d", i);
source->save_passwd = gnome_config_get_bool (path);
g_free (path);
@@ -402,9 +410,18 @@ mail_config_write (void)
path = g_strdup_printf ("source_keep_on_server_%d", i);
gnome_config_set_bool (path, account->source->keep_on_server);
g_free (path);
+ path = g_strdup_printf ("source_auto_check_%d", i);
+ gnome_config_set_bool (path, account->source->auto_check);
+ g_free (path);
+ path = g_strdup_printf ("source_auto_check_time_%d", i);
+ gnome_config_set_int (path, account->source->auto_check_time);
+ g_free (path);
path = g_strdup_printf ("source_save_passwd_%d", i);
gnome_config_set_bool (path, account->source->save_passwd);
g_free (path);
+ path = g_strdup_printf ("source_use_ssl_%d", i);
+ gnome_config_set_bool (path, account->source->use_ssl);
+ g_free (path);
/* transport info */
path = g_strdup_printf ("transport_url_%d", i);
diff --git a/mail/mail-config.glade b/mail/mail-config.glade
index 9f481a8adb..9c67cd60a0 100644
--- a/mail/mail-config.glade
+++ b/mail/mail-config.glade
@@ -711,6 +711,72 @@ Click &quot;Next&quot; to begin. </text>
</widget>
<widget>
+ <class>GtkHBox</class>
+ <name>hbox39</name>
+ <homogeneous>False</homogeneous>
+ <spacing>0</spacing>
+ <child>
+ <padding>0</padding>
+ <expand>False</expand>
+ <fill>False</fill>
+ </child>
+
+ <widget>
+ <class>GtkCheckButton</class>
+ <name>chkAutoCheck</name>
+ <can_focus>True</can_focus>
+ <label>Automatically check mail every</label>
+ <active>False</active>
+ <draw_indicator>True</draw_indicator>
+ <child>
+ <padding>0</padding>
+ <expand>False</expand>
+ <fill>False</fill>
+ </child>
+ </widget>
+
+ <widget>
+ <class>GtkSpinButton</class>
+ <name>spinAutoCheckMinutes</name>
+ <can_focus>True</can_focus>
+ <climb_rate>1</climb_rate>
+ <digits>0</digits>
+ <numeric>True</numeric>
+ <update_policy>GTK_UPDATE_ALWAYS</update_policy>
+ <snap>False</snap>
+ <wrap>False</wrap>
+ <value>1440</value>
+ <lower>0</lower>
+ <upper>1440</upper>
+ <step>1</step>
+ <page>10</page>
+ <page_size>10</page_size>
+ <child>
+ <padding>2</padding>
+ <expand>False</expand>
+ <fill>True</fill>
+ </child>
+ </widget>
+
+ <widget>
+ <class>GtkLabel</class>
+ <name>lblMinutes</name>
+ <label>minutes.</label>
+ <justify>GTK_JUSTIFY_CENTER</justify>
+ <wrap>False</wrap>
+ <xalign>0.5</xalign>
+ <yalign>0.5</yalign>
+ <xpad>0</xpad>
+ <ypad>0</ypad>
+ <child>
+ <padding>0</padding>
+ <expand>False</expand>
+ <fill>False</fill>
+ </child>
+ </widget>
+ </widget>
+
+ <widget>
<class>GtkCheckButton</class>
<name>chkIncomingCheckSettings</name>
<can_focus>True</can_focus>
diff --git a/mail/mail-config.glade.h b/mail/mail-config.glade.h
index f5660ebe7c..81d686570a 100644
--- a/mail/mail-config.glade.h
+++ b/mail/mail-config.glade.h
@@ -23,6 +23,8 @@ gchar *s = N_("Host:");
gchar *s = N_("Username:");
gchar *s = N_("Path:");
gchar *s = N_("Keep mail on server");
+gchar *s = N_("Automatically check mail every");
+gchar *s = N_("minutes.");
gchar *s = N_("Check settings");
gchar *s = N_("Authentication");
gchar *s = N_("Authentication");
diff --git a/mail/mail-config.h b/mail/mail-config.h
index 5a3cda5c42..ee9191a4c8 100644
--- a/mail/mail-config.h
+++ b/mail/mail-config.h
@@ -42,6 +42,8 @@ typedef struct {
typedef struct {
gchar *url;
gboolean keep_on_server;
+ gboolean auto_check;
+ gint auto_check_time;
gboolean save_passwd;
gboolean use_ssl;
} MailConfigService;
diff --git a/mail/mail-display.c b/mail/mail-display.c
index 404dc9f3ed..9f599bc797 100644
--- a/mail/mail-display.c
+++ b/mail/mail-display.c
@@ -696,7 +696,7 @@ on_object_requested (GtkHTML *html, GtkHTMLEmbedded *eb, gpointer data)
hbox = gtk_hbox_new (FALSE, 2);
gtk_container_set_border_width (GTK_CONTAINER (hbox), 2);
- if (mail_part_is_inline (medium)) {
+ if (mail_part_is_inline (CAMEL_MIME_PART (medium))) {
arrow = gnome_stock_new_with_icon (GNOME_STOCK_PIXMAP_DOWN);
} else {
arrow = gnome_stock_new_with_icon (GNOME_STOCK_PIXMAP_FORWARD);