aboutsummaryrefslogtreecommitdiffstats
path: root/composer/e-msg-composer-hdrs.c
diff options
context:
space:
mode:
Diffstat (limited to 'composer/e-msg-composer-hdrs.c')
-rw-r--r--composer/e-msg-composer-hdrs.c266
1 files changed, 245 insertions, 21 deletions
diff --git a/composer/e-msg-composer-hdrs.c b/composer/e-msg-composer-hdrs.c
index 4e222b0bfd..fe64e96c5f 100644
--- a/composer/e-msg-composer-hdrs.c
+++ b/composer/e-msg-composer-hdrs.c
@@ -50,7 +50,10 @@
#include <camel/camel.h>
#include "e-msg-composer-hdrs.h"
#include "mail/mail-config.h"
-#include "mail/em-folder-selection-button.h"
+/*#include "mail/em-folder-selection-button.h"*/
+#include "mail/em-folder-selector.h"
+#include "mail/mail-component.h"
+#include "mail/em-folder-tree.h"
@@ -82,6 +85,8 @@ struct _EMsgComposerHdrsPrivate {
EAccountList *accounts;
GSList *from_options;
+ gboolean post_custom;
+
/* Standard headers. */
EMsgComposerHdrPair from, reply_to, to, cc, bcc, post_to, subject;
};
@@ -179,6 +184,11 @@ from_changed (GtkWidget *item, gpointer data)
{
EMsgComposerHdrs *hdrs = E_MSG_COMPOSER_HDRS (data);
const char *reply_to;
+ GList *post_items = NULL;
+
+ /* this will retrieve items relative to the previous account */
+ if (!hdrs->priv->post_custom)
+ post_items = e_msg_composer_hdrs_get_post_to(hdrs);
hdrs->account = g_object_get_data ((GObject *) item, "account");
@@ -187,6 +197,13 @@ from_changed (GtkWidget *item, gpointer data)
reply_to = hdrs->account->id->reply_to;
gtk_entry_set_text (GTK_ENTRY (hdrs->priv->reply_to.entry), reply_to ? reply_to : "");
+ /* folders should be made relative to the new from */
+ if (!hdrs->priv->post_custom) {
+ e_msg_composer_hdrs_set_post_to_list (hdrs, post_items);
+ g_list_foreach (post_items, (GFunc)g_free, NULL);
+ g_list_free(post_items);
+ }
+
g_signal_emit (hdrs, signals [FROM_CHANGED], 0);
}
@@ -460,6 +477,51 @@ create_addressbook_entry (EMsgComposerHdrs *hdrs, const char *name)
return control_widget;
}
+static void
+post_browser_response (EMFolderSelector *emfs, int response, EMsgComposerHdrs *hdrs)
+{
+ if (response == GTK_RESPONSE_OK) {
+ GList *uris = em_folder_selector_get_selected_uris (emfs);
+ e_msg_composer_hdrs_set_post_to_list (hdrs, uris);
+ hdrs->priv->post_custom = FALSE;
+ g_list_foreach (uris, (GFunc) g_free, NULL);
+ g_list_free (uris);
+ }
+
+ gtk_widget_destroy ((GtkWidget *) emfs);
+}
+
+static void
+post_browser_clicked_cb (GtkButton *button, EMsgComposerHdrs *hdrs)
+{
+ EMFolderTreeModel *model;
+ EMFolderTree *emft;
+ GtkWidget *dialog;
+ GList *post_items;
+
+ model = mail_component_peek_tree_model (mail_component_peek ());
+ emft = (EMFolderTree *) em_folder_tree_new_with_model (model);
+ em_folder_tree_set_multiselect (emft, TRUE);
+
+ dialog = em_folder_selector_new (emft, EM_FOLDER_SELECTOR_CAN_CREATE,
+ _("Posting destination"),
+ _("Choose folders to post the message to."));
+
+ post_items = e_msg_composer_hdrs_get_post_to (hdrs);
+ em_folder_selector_set_selected_list ((EMFolderSelector *) dialog, post_items);
+ g_list_foreach (post_items, (GFunc) g_free, NULL);
+ g_list_free (post_items);
+
+ g_signal_connect (dialog, "response", G_CALLBACK (post_browser_response), hdrs);
+ gtk_widget_show (dialog);
+}
+
+static void
+post_entry_changed_cb (GtkButton *button, EMsgComposerHdrs *hdrs)
+{
+ hdrs->priv->post_custom = TRUE;
+}
+
static EMsgComposerHdrPair
header_new_recipient (EMsgComposerHdrs *hdrs, const char *name, const char *tip)
{
@@ -544,8 +606,17 @@ create_headers (EMsgComposerHdrs *hdrs)
/*
* Post-To
*/
- priv->post_to.label = gtk_label_new (_("Post To:"));
- priv->post_to.entry = em_folder_selection_button_new (_("Posting destination"), _("Choose a folder to post the message to."));
+ priv->post_to.label = gtk_button_new_with_label (_("Post To:"));
+ GTK_OBJECT_UNSET_FLAGS (priv->post_to.label, GTK_CAN_FOCUS);
+ g_signal_connect (priv->post_to.label, "clicked",
+ G_CALLBACK (post_browser_clicked_cb), hdrs);
+ gtk_tooltips_set_tip (hdrs->priv->tooltips, priv->post_to.label,
+ _("Click here to select folders to post to"),
+ NULL);
+
+ priv->post_to.entry = gtk_entry_new ();
+ g_signal_connect(priv->post_to.entry, "changed",
+ G_CALLBACK (post_entry_changed_cb), hdrs);
}
static void
@@ -579,7 +650,7 @@ attach_headers (EMsgComposerHdrs *hdrs)
static void
set_pair_visibility (EMsgComposerHdrs *h, EMsgComposerHdrPair *pair, int visible)
{
- if (visible & h->visible_mask) {
+ if (visible /*& h->visible_mask*/) {
gtk_widget_show (pair->label);
gtk_widget_show (pair->entry);
} else {
@@ -611,21 +682,14 @@ headers_set_visibility (EMsgComposerHdrs *h, int visible_flags)
static void
headers_set_sensitivity (EMsgComposerHdrs *h)
{
+ /* these ones are always on */
bonobo_ui_component_set_prop (
- h->priv->uic, "/commands/ViewFrom", "sensitive",
- h->visible_mask & E_MSG_COMPOSER_VISIBLE_FROM ? "1" : "0", NULL);
+ h->priv->uic, "/commands/ViewTo", "sensitive",
+ h->visible_mask & E_MSG_COMPOSER_VISIBLE_TO ? "0" : "1", NULL);
bonobo_ui_component_set_prop (
- h->priv->uic, "/commands/ViewReplyTo", "sensitive",
- h->visible_mask & E_MSG_COMPOSER_VISIBLE_REPLYTO ? "1" : "0", NULL);
-
- bonobo_ui_component_set_prop (
- h->priv->uic, "/commands/ViewCC", "sensitive",
- h->visible_mask & E_MSG_COMPOSER_VISIBLE_CC ? "1" : "0", NULL);
-
- bonobo_ui_component_set_prop (
- h->priv->uic, "/commands/ViewBCC", "sensitive",
- h->visible_mask & E_MSG_COMPOSER_VISIBLE_BCC ? "1" : "0", NULL);
+ h->priv->uic, "/commands/ViewPostTo", "sensitive",
+ h->visible_mask & E_MSG_COMPOSER_VISIBLE_POSTTO ? "0" : "1", NULL);
}
void
@@ -775,6 +839,8 @@ init (EMsgComposerHdrs *hdrs)
priv->accounts = mail_config_get_accounts ();
g_object_ref (priv->accounts);
+
+ priv->post_custom = FALSE;
hdrs->priv = priv;
}
@@ -958,11 +1024,13 @@ e_msg_composer_hdrs_to_message_internal (EMsgComposerHdrs *hdrs,
eab_destination_freev (bcc_destv);
}
+#if 0
if (hdrs->visible_mask & E_MSG_COMPOSER_VISIBLE_POSTTO) {
header = e_msg_composer_hdrs_get_post_to (hdrs);
camel_medium_set_header (CAMEL_MEDIUM (msg), "X-Evolution-PostTo", header);
g_free (header);
}
+#endif
}
@@ -1096,12 +1164,144 @@ void
e_msg_composer_hdrs_set_post_to (EMsgComposerHdrs *hdrs,
const char *post_to)
{
+ GList *list;
+
g_return_if_fail (E_IS_MSG_COMPOSER_HDRS (hdrs));
g_return_if_fail (post_to != NULL);
- em_folder_selection_button_set_selection ((EMFolderSelectionButton *) hdrs->priv->post_to.entry, post_to);
+ list = g_list_append (NULL, g_strdup (post_to));
+
+ e_msg_composer_hdrs_set_post_to_list (hdrs, list);
+
+ g_free (list->data)
+ g_list_free (list);
}
+static GList *
+newsgroups_list_split (const char *list)
+{
+ GList *lst = NULL;
+ char *tmp;
+ char **items, **cur_ptr;
+
+ cur_ptr = items = g_strsplit (list, ",", 0);
+
+ while ((tmp = *cur_ptr) != NULL) {
+ g_strstrip (tmp);
+
+ if (tmp[0])
+ lst = g_list_append (lst, g_strdup (tmp));
+
+ cur_ptr++;
+ }
+
+ g_strfreev (items);
+
+ return lst;
+}
+
+static char *
+get_account_store_url (EMsgComposerHdrs *hdrs)
+{
+ CamelURL *url;
+ char *ret = NULL;
+
+ if (hdrs->account->source && hdrs->account->source->url) {
+ url = camel_url_new (hdrs->account->source->url, NULL);
+ ret = camel_url_to_string (url, CAMEL_URL_HIDE_ALL);
+ camel_url_free (url);
+ }
+
+ return ret;
+}
+
+static char *
+folder_name_to_string (EMsgComposerHdrs *hdrs, const char *uri)
+{
+ char *storeurl = get_account_store_url (hdrs);
+ int len;
+
+ if (storeurl) {
+ len = strlen (storeurl);
+
+ if (g_ascii_strncasecmp (uri, storeurl, len) == 0) {
+ g_free (storeurl);
+ return g_strdup (uri + len);
+ }
+
+ g_free (storeurl);
+ }
+
+ return g_strdup (uri);
+}
+
+void
+e_msg_composer_hdrs_set_post_to_list (EMsgComposerHdrs *hdrs, GList *urls)
+{
+ /* compile the name */
+ char *caption, *tmp, *tmp2;
+ gboolean post_custom;
+
+ if (hdrs->priv->post_to.entry == NULL)
+ return;
+
+ caption = g_strdup ("");
+
+ while (urls) {
+ tmp = folder_name_to_string (hdrs, (char *)urls->data);
+ if (tmp) {
+ tmp2 = g_strconcat (caption, ", ", tmp, NULL);
+ g_free (caption);
+ caption = tmp2;
+ g_free (tmp);
+ }
+
+ urls = g_list_next (urls);
+ }
+
+ post_custom = hdrs->priv->post_custom;
+ gtk_entry_set_text (GTK_ENTRY (hdrs->priv->post_to.entry), caption[0] ? caption + 2 : "");
+ hdrs->priv->post_custom = post_custom;
+ g_free (caption);
+}
+
+void
+e_msg_composer_hdrs_set_post_to_base (EMsgComposerHdrs *hdrs,
+ const char *base, const char *post_to)
+{
+ GList *lst, *curlist;
+ char *hdr_copy = g_strdup (post_to), *caption, *tmp, *tmp2;
+ gboolean post_custom;
+
+ /* split to newsgroup names */
+ lst = newsgroups_list_split (hdr_copy);
+ curlist = lst;
+
+ /* compile the name */
+ caption = g_strdup ("");
+
+ while (curlist) {
+ tmp2 = g_strdup_printf ("%s/%s", base, (char *)curlist->data);
+ tmp = folder_name_to_string (hdrs, tmp2);
+ g_free (tmp2);
+ if (tmp) {
+ tmp2 = g_strconcat (caption, ", ", tmp, NULL);
+ g_free (caption);
+ caption = tmp2;
+ g_free (tmp);
+ }
+ curlist = g_list_next (curlist);
+ }
+
+ post_custom = hdrs->priv->post_custom;
+ gtk_entry_set_text (GTK_ENTRY (hdrs->priv->post_to.entry), caption[0] ? caption + 2 : "");
+ hdrs->priv->post_custom = post_custom;
+ g_free (caption);
+
+ g_list_foreach (lst, (GFunc) g_free, NULL);
+ g_list_free (lst);
+ g_free (hdr_copy);
+}
void
e_msg_composer_hdrs_set_subject (EMsgComposerHdrs *hdrs,
@@ -1255,16 +1455,40 @@ e_msg_composer_hdrs_get_recipients (EMsgComposerHdrs *hdrs)
}
-char *
+GList *
e_msg_composer_hdrs_get_post_to (EMsgComposerHdrs *hdrs)
{
- const char *uri;
+ GList *uris, *cur;
+ char *storeurl = NULL, *tmp;
g_return_val_if_fail (E_IS_MSG_COMPOSER_HDRS (hdrs), NULL);
- uri = em_folder_selection_button_get_selection ((EMFolderSelectionButton *) hdrs->priv->post_to.entry);
+ if (hdrs->priv->post_to.entry == NULL)
+ return NULL;
- return g_strdup (uri);
+ tmp = g_strdup (gtk_entry_get_text (GTK_ENTRY (hdrs->priv->post_to.entry)));
+ uris = newsgroups_list_split (tmp);
+ g_free (tmp);
+
+ cur = uris;
+ while (cur) {
+ if (strstr ((char *) cur->data, "://") == NULL) {
+ /* relative folder name: convert to absolute */
+ if (!storeurl)
+ storeurl = get_account_store_url (hdrs);
+ if (!storeurl)
+ break;
+ tmp = g_strconcat (storeurl, cur->data, NULL);
+ g_free (cur->data);
+ cur->data = tmp;
+ }
+
+ cur = cur->next;
+ }
+
+ g_free (storeurl);
+
+ return uris;
}