aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mail/ChangeLog24
-rw-r--r--mail/mail-callbacks.c144
-rw-r--r--mail/mail-config.c21
-rw-r--r--mail/mail-config.h3
4 files changed, 161 insertions, 31 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index 42fae44eac..644ecd1174 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,27 @@
+2001-09-08 Jon Trowbridge <trow@gnu.org>
+
+ * mail-callbacks.c (ask_confirm_for_unwanted_html_mail): Added.
+ Shows a (hopefully) informative dialog warning you that some
+ recipients might not want HTML mail (who are listed), and gives
+ the option to cancel sending. (FIXME: The wording of this dialog
+ could use some work.)
+ (composer_get_message): Check if we are sending HTML to someone
+ who might not want it, and raise the dialog if we are. Use our
+ new destination-vector based api when talking to the composer.
+ Touch our destinations here, boosting their use scores. This is
+ the right place for this to happen --- closer to the end of the
+ sending process, where incorrect/artificial use score inflation is
+ less likely to occur.
+
+ * mail-config.c (config_read): Added
+ /Mail/Format/confirm_unwanted_html key. This flag determines
+ whether or not we want to see the warning dialog when we send HTML
+ mail to contacts who don't want it. Default is TRUE.
+ (mail_config_write_on_exit): Write out the confirm_unwanted_html
+ key.
+ (mail_config_get_confirm_unwanted_html): Added.
+ (mail_config_set_confirm_unwanted_html): Added.
+
2001-09-08 Dan Winship <danw@ximian.com>
* mail-display.c (mail_display_destroy): Unref the invisible,
diff --git a/mail/mail-callbacks.c b/mail/mail-callbacks.c
index dc01bb0f78..18c2126355 100644
--- a/mail/mail-callbacks.c
+++ b/mail/mail-callbacks.c
@@ -200,6 +200,56 @@ msgbox_destroyed (GtkWidget *widget, gpointer data)
}
static gboolean
+ask_confirm_for_unwanted_html_mail (EMsgComposer *composer, EDestination **recipients)
+{
+ gboolean show_again = TRUE;
+ GString *str;
+ GtkWidget *mbox;
+ gint i, button;
+
+ if (! mail_config_get_confirm_unwanted_html ()) {
+ g_message ("doesn't want to see confirm html messages!");
+ return TRUE;
+ }
+
+ /* FIXME: this wording sucks */
+ str = g_string_new (_("You are sending an HTML-formatted mail, but the following recipients' "
+ "contact records do not indicate that they want to receive such messages:\n"));
+ for (i = 0; recipients[i] != NULL; ++i) {
+ if (! e_destination_get_html_mail_pref (recipients[i])) {
+ gchar *name = g_strdup_printf (" %s\n", e_destination_get_textrep (recipients[i]));
+ g_string_append (str, name);
+ g_free (name);
+ }
+ }
+
+ g_string_append (str, _("Send anyway?"));
+
+ mbox = e_message_box_new (str->str,
+ E_MESSAGE_BOX_QUESTION,
+ GNOME_STOCK_BUTTON_YES,
+ GNOME_STOCK_BUTTON_NO,
+ NULL);
+
+ g_string_free (str, 0);
+
+ gtk_signal_connect (GTK_OBJECT (mbox), "destroy",
+ msgbox_destroyed, &show_again);
+
+ button = gnome_dialog_run_and_close (GNOME_DIALOG (mbox));
+
+ if (! show_again) {
+ mail_config_set_confirm_unwanted_html (show_again);
+ g_message ("don't show HTML warning again");
+ }
+
+ if (button == 0)
+ return TRUE;
+ else
+ return FALSE;
+}
+
+static gboolean
ask_confirm_for_empty_subject (EMsgComposer *composer)
{
/* FIXME: EMessageBox should really handle this stuff
@@ -341,8 +391,9 @@ composer_get_message (EMsgComposer *composer)
CamelMimeMessage *message;
const char *subject;
int num_addrs, i;
+ EDestination **recipients;
- message = e_msg_composer_get_message (composer, TRUE /* yes, we are sending this baby! */ );
+ message = e_msg_composer_get_message (composer);
if (message == NULL)
return NULL;
@@ -389,6 +440,29 @@ composer_get_message (EMsgComposer *composer)
return NULL;
}
}
+
+ /* Only show this warning if our default is to send html. If it isn't, we've
+ manually switched into html mode in the composer and (presumably) had a good
+ reason for doing this. */
+ if (e_msg_composer_get_send_html (composer)
+ && mail_config_get_send_html ()
+ && mail_config_get_confirm_unwanted_html ()) {
+ gboolean html_problem = FALSE;
+ recipients = e_msg_composer_get_recipients (composer);
+ for (i = 0; recipients[i] != NULL && !html_problem; ++i) {
+ if (! e_destination_get_html_mail_pref (recipients[i]))
+ html_problem = TRUE;
+ }
+
+ if (html_problem) {
+ html_problem = ! ask_confirm_for_unwanted_html_mail (composer, recipients);
+ e_destination_freev (recipients);
+ if (html_problem) {
+ camel_object_unref (CAMEL_OBJECT (message));
+ return NULL;
+ }
+ }
+ }
/* Check for no subject */
subject = camel_mime_message_get_subject (message);
@@ -406,6 +480,11 @@ composer_get_message (EMsgComposer *composer)
camel_medium_set_header (CAMEL_MEDIUM (message), "X-Evolution-Transport", account->transport->url);
camel_medium_set_header (CAMEL_MEDIUM (message), "X-Evolution-Fcc", account->sent_folder_uri);
}
+
+ /* Get the message recipients and 'touch' them, boosting their use scores */
+ recipients = e_msg_composer_get_recipients (composer);
+ e_destination_touchv (recipients);
+ e_destination_freev (recipients);
return message;
}
@@ -545,17 +624,11 @@ list_add_addresses (GList *list, const CamelInternetAddress *cia, const GSList *
const char *name, *addr;
const GSList *l;
gboolean notme;
- char *full;
int i;
for (i = 0; camel_internet_address_get (cia, i, &name, &addr); i++) {
/* Make sure we don't want to ignore this address */
if (!ignore_addr || g_strcasecmp (ignore_addr, addr)) {
- /* now, we format this, as if for display, but does the composer
- then use it as a real address? If so, very broken. */
- /* we should probably pass around CamelAddresse's if thats what
- we mean */
- full = camel_internet_address_format_address (name, addr);
/* Here I'll check to see if the cc:'d address is the address
of the sender, and if so, don't add it to the cc: list; this
@@ -576,10 +649,12 @@ list_add_addresses (GList *list, const CamelInternetAddress *cia, const GSList *
}
if (notme && !g_hash_table_lookup (rcpt_hash, addr)) {
+ EDestination *dest = e_destination_new ();
+ e_destination_set_name (dest, name);
+ e_destination_set_email (dest, addr);
+ list = g_list_append (list, dest);
g_hash_table_insert (rcpt_hash, (char *) addr, GINT_TO_POINTER (1));
- list = g_list_append (list, full);
- } else
- g_free (full);
+ }
}
}
@@ -632,16 +707,6 @@ guess_me (const CamelInternetAddress *to, const CamelInternetAddress *cc, const
return NULL;
}
-static void
-free_recipients (GList *list)
-{
- GList *l;
-
- for (l = list; l; l = l->next)
- g_free (l->data);
- g_list_free (list);
-}
-
static EMsgComposer *
mail_generate_reply (CamelFolder *folder, CamelMimeMessage *message, const char *uid, int mode)
{
@@ -652,6 +717,7 @@ mail_generate_reply (CamelFolder *folder, CamelMimeMessage *message, const char
const MailConfigAccount *me = NULL;
const GSList *accounts = NULL;
GList *to = NULL, *cc = NULL;
+ EDestination **tov, **ccv;
EMsgComposer *composer;
time_t date;
@@ -700,7 +766,7 @@ mail_generate_reply (CamelFolder *folder, CamelMimeMessage *message, const char
to_addrs = camel_mime_message_get_recipients (message, CAMEL_RECIPIENT_TYPE_TO);
max = camel_address_length (CAMEL_ADDRESS (to_addrs));
for (i = 0; i < max; i++) {
- camel_internet_address_get (to_addrs, i, NULL, &address);
+ camel_internet_address_get (to_addrs, i, &name, &address);
if (!g_strncasecmp (address, mlist, len))
break;
}
@@ -709,14 +775,18 @@ mail_generate_reply (CamelFolder *folder, CamelMimeMessage *message, const char
cc_addrs = camel_mime_message_get_recipients (message, CAMEL_RECIPIENT_TYPE_CC);
max = camel_address_length (CAMEL_ADDRESS (cc_addrs));
for (i = 0; i < max; i++) {
- camel_internet_address_get (cc_addrs, i, NULL, &address);
+ camel_internet_address_get (cc_addrs, i, &name, &address);
if (!g_strncasecmp (address, mlist, len))
break;
}
}
-
- /* We only want to reply to the list address - if it even exists */
- to = address && i != max ? g_list_append (to, g_strdup (address)) : to;
+
+ if (address && i != max) {
+ EDestination *dest = e_destination_new ();
+ e_destination_set_name (dest, name);
+ e_destination_set_email (dest, address);
+ to = g_list_append (to, dest);
+ }
}
me = guess_me (to_addrs, cc_addrs, accounts);
@@ -730,9 +800,13 @@ mail_generate_reply (CamelFolder *folder, CamelMimeMessage *message, const char
reply_to = camel_mime_message_get_from (message);
if (reply_to) {
/* Get the Reply-To address so we can ignore references to it in the Cc: list */
- if (camel_internet_address_get (reply_to, 0, NULL, &reply_addr)) {
+ if (camel_internet_address_get (reply_to, 0, &name, &reply_addr)) {
+ EDestination *dest = e_destination_new ();
+ e_destination_set_name (dest, name);
+ e_destination_set_email (dest, reply_addr);
+ g_message (">>>>>>>>>> [%s] [%s]", name, reply_addr);
+ to = g_list_append (to, dest);
g_hash_table_insert (rcpt_hash, (char *) reply_addr, GINT_TO_POINTER (1));
- to = g_list_append (to, camel_address_format (CAMEL_ADDRESS (reply_to)));
}
}
@@ -763,10 +837,18 @@ mail_generate_reply (CamelFolder *folder, CamelMimeMessage *message, const char
else
subject = g_strdup_printf ("Re: %s", subject);
}
-
- e_msg_composer_set_headers (composer, me ? me->name : NULL, to, cc, NULL, subject);
- free_recipients (to);
- free_recipients (cc);
+
+ tov = e_destination_list_to_vector (to);
+ ccv = e_destination_list_to_vector (cc);
+
+ g_list_free (to);
+ g_list_free (cc);
+
+ e_msg_composer_set_headers (composer, me ? me->name : NULL, tov, ccv, NULL, subject);
+
+ e_destination_freev (tov);
+ e_destination_freev (ccv);
+
g_free (subject);
/* Add In-Reply-To and References. */
diff --git a/mail/mail-config.c b/mail/mail-config.c
index 68b310daa0..fc8290948b 100644
--- a/mail/mail-config.c
+++ b/mail/mail-config.c
@@ -62,6 +62,7 @@ typedef struct {
gboolean hide_deleted;
gint paned_size;
gboolean send_html;
+ gboolean confirm_unwanted_html;
gboolean citation_highlight;
guint32 citation_color;
gboolean prompt_empty_subject;
@@ -489,6 +490,10 @@ config_read (void)
/* Format */
config->send_html = bonobo_config_get_boolean_with_default (config->db,
"/Mail/Format/send_html", FALSE, NULL);
+
+ /* Confirm Sending Unwanted HTML */
+ config->confirm_unwanted_html = bonobo_config_get_boolean_with_default (config->db,
+ "/Mail/Format/confirm_unwanted_html", TRUE, NULL);
/* Citation */
config->citation_highlight = bonobo_config_get_boolean_with_default (
@@ -798,6 +803,10 @@ mail_config_write_on_exit (void)
/* Format */
bonobo_config_set_boolean (config->db, "/Mail/Format/send_html",
config->send_html, NULL);
+
+ /* Confirm Sending Unwanted HTML */
+ bonobo_config_set_boolean (config->db, "/Mail/Format/confirm_unwanted_html",
+ config->confirm_unwanted_html, NULL);
/* Citation */
bonobo_config_set_boolean (config->db,
@@ -1096,6 +1105,18 @@ mail_config_set_send_html (gboolean send_html)
}
gboolean
+mail_config_get_confirm_unwanted_html (void)
+{
+ return config->confirm_unwanted_html;
+}
+
+void
+mail_config_set_confirm_unwanted_html (gboolean confirm)
+{
+ config->confirm_unwanted_html = confirm;
+}
+
+gboolean
mail_config_get_citation_highlight (void)
{
return config->citation_highlight;
diff --git a/mail/mail-config.h b/mail/mail-config.h
index 76aa3b60cd..d223ba1eda 100644
--- a/mail/mail-config.h
+++ b/mail/mail-config.h
@@ -130,6 +130,9 @@ void mail_config_set_paned_size (gint size);
gboolean mail_config_get_send_html (void);
void mail_config_set_send_html (gboolean send_html);
+gboolean mail_config_get_confirm_unwanted_html (void);
+void mail_config_set_confirm_unwanted_html (gboolean html_warning);
+
gboolean mail_config_get_citation_highlight (void);
void mail_config_set_citation_highlight (gboolean);