aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--composer/ChangeLog9
-rw-r--r--composer/e-msg-composer.c88
-rw-r--r--composer/e-msg-composer.h7
3 files changed, 100 insertions, 4 deletions
diff --git a/composer/ChangeLog b/composer/ChangeLog
index 84ea1b988e..2a79f4508d 100644
--- a/composer/ChangeLog
+++ b/composer/ChangeLog
@@ -1,3 +1,12 @@
+2007-01-18 Raghavendran R<raghavguru7@gmail.com>
+ * e-msg-composer.[c,h]:
+ (e_msg_composer_modify_header): ,
+ (e_msg_composer_remove_header):
+ Added code for modifying and removing camel
+ mime message header .
+ (menu_send_options_cb):Creates and emits the event
+ when send options is clicked .
+
2006-08-24 Ushveen Kaur <kushveen@novell.com>
** Fixes bug #261062
diff --git a/composer/e-msg-composer.c b/composer/e-msg-composer.c
index 1d00c759b5..2a83924d95 100644
--- a/composer/e-msg-composer.c
+++ b/composer/e-msg-composer.c
@@ -86,6 +86,7 @@
#include "misc/e-expander.h"
#include "e-util/e-error.h"
#include "e-util/e-util-private.h"
+#include <mail/em-event.h>
#include <camel/camel-session.h>
#include <camel/camel-charset-map.h>
@@ -215,12 +216,13 @@ struct _EMsgComposerPrivate {
CamelMimeMessage *redirect;
guint notify_id;
-
+
+ gboolean send_invoked;
EMMenu *menu;
GtkWidget *saveas; /* saveas async file requester */
GtkWidget *load; /* same for load - not used */
-
+
};
enum {
@@ -1872,11 +1874,26 @@ menu_edit_paste_cb (BonoboUIComponent *uic, void *data, const char *path)
}
static void
+menu_send_options_cb (BonoboUIComponent *component, void *data, const char *path)
+{
+ EMEvent *e = em_event_peek();
+ EMEventTargetComposer *target;
+ EMsgComposer *composer = data;
+
+ target = em_event_target_new_composer (e, composer, EM_EVENT_COMPOSER_SEND_OPTION);
+ e_msg_composer_set_send_options (composer, FALSE);
+ e_event_emit((EEvent *)e, "composer.selectsendoption", (EEventTarget *)target);
+ if (!composer->priv->send_invoked) {
+ e_error_run ((GtkWindow *)composer, "mail-composer:send-options-support", NULL);
+ }
+}
+
+static void
menu_edit_select_all_cb (BonoboUIComponent *uic, void *data, const char *path)
{
EMsgComposer *composer = data;
EMsgComposerPrivate *p = composer->priv;
-
+
g_return_if_fail (p->focused_entry != NULL);
if (GTK_IS_ENTRY (p->focused_entry)) {
@@ -2128,6 +2145,7 @@ static BonoboUIVerb verbs [] = {
BONOBO_UI_VERB ("FileSend", menu_file_send_cb),
BONOBO_UI_VERB ("DeleteAll", menu_edit_delete_all_cb),
+ BONOBO_UI_VERB ("InsertXSendOptions", menu_send_options_cb),
BONOBO_UI_VERB_END
};
@@ -2417,6 +2435,14 @@ setup_ui (EMsgComposer *composer)
p->uic, "RequestReceipt",
menu_insert_receipt_cb, composer);
+ /* Insert/Exchange Send Options */
+/* bonobo_ui_component_set_prop (
+ p->uic, "/commands/XSendOptions",
+ "state", "1", NULL);
+ bonobo_ui_component_add_listener (
+ p->uic, "XSendOptions",
+ menu_send_options_cb, composer);*/
+
/* Insert/Set Priority*/
bonobo_ui_component_set_prop (
p->uic, "/commands/SetPriority",
@@ -3317,7 +3343,7 @@ init (EMsgComposer *composer)
p->autosaved = FALSE;
p->redirect = FALSE;
-
+ p->send_invoked = FALSE;
p->charset = NULL;
p->enable_autosave = TRUE;
@@ -5044,8 +5070,53 @@ e_msg_composer_add_header (EMsgComposer *composer, const char *name,
g_ptr_array_add (p->extra_hdr_names, g_strdup (name));
g_ptr_array_add (p->extra_hdr_values, g_strdup (value));
}
+/**
+ * e_msg_composer_modify_header :
+ * @composer : a composer object
+ * @name: the header name
+ * @change_value: the header value to put in place of the previous
+ * value
+ *
+ * Searches for a header with name=@name ,if found it removes
+ * that header and adds a new header with the @name and @change_value .
+ * If not found then it creates a new header with @name and @change_value .
+ **/
+void
+e_msg_composer_modify_header (EMsgComposer *composer, const char *name,
+ const char *change_value)
+{
+ g_return_if_fail (E_IS_MSG_COMPOSER (composer));
+ g_return_if_fail (name != NULL);
+ g_return_if_fail (change_value != NULL);
+
+ e_msg_composer_remove_header (composer, name);
+ e_msg_composer_add_header (composer, name, change_value);
+}
+
+/**
+ * e_msg_composer_modify_header :
+ * @composer : a composer object
+ * @name: the header name
+ *
+ * Searches for the header and if found it removes it .
+ **/
+void
+e_msg_composer_remove_header (EMsgComposer *composer, const char *name)
+{
+ g_return_if_fail (E_IS_MSG_COMPOSER (composer));
+ g_return_if_fail (name != NULL);
+ int i;
+ EMsgComposerPrivate *p = composer->priv;
+ for (i = 0; i < p->extra_hdr_names->len; i++) {
+ if (strcmp (p->extra_hdr_names->pdata[i], name) == 0) {
+ g_print ("Hit : %s",name);
+ g_ptr_array_remove_index (p->extra_hdr_names, i);
+ g_ptr_array_remove_index (p->extra_hdr_values, i);
+ }
+ }
+}
/**
* e_msg_composer_attach:
* @composer: a composer object
@@ -6408,3 +6479,12 @@ e_msg_composer_set_saved (EMsgComposer *composer)
GNOME_GtkHTML_Editor_Engine_runCommand (p->eeditor_engine, "saved", &ev);
CORBA_exception_free (&ev);
}
+
+void
+e_msg_composer_set_send_options (EMsgComposer *composer, gboolean send_enable)
+{
+ EMsgComposerPrivate *priv;
+ priv = composer->priv;
+
+ priv->send_invoked = send_enable;
+}
diff --git a/composer/e-msg-composer.h b/composer/e-msg-composer.h
index dde9f9fb71..08b744d632 100644
--- a/composer/e-msg-composer.h
+++ b/composer/e-msg-composer.h
@@ -88,6 +88,11 @@ void e_msg_composer_set_body (EMsgCo
void e_msg_composer_add_header (EMsgComposer *composer,
const char *name,
const char *value);
+void e_msg_composer_modify_header (EMsgComposer *composer,
+ const char *name,
+ const char *value);
+void e_msg_composer_remove_header (EMsgComposer *composer,
+ const char *name);
void e_msg_composer_attach (EMsgComposer *composer,
CamelMimePart *attachment);
CamelMimePart *e_msg_composer_add_inline_image_from_file (EMsgComposer *composer,
@@ -185,6 +190,8 @@ CamelMimePart* e_msg_composer_url_requested (EMsgComposer *composer, gchar
EMsgComposerHdrs* e_msg_composer_get_hdrs (EMsgComposer *composer);
void e_msg_composer_set_saved (EMsgComposer *composer);
+void e_msg_composer_set_send_options (EMsgComposer *composer,
+ gboolean send_enable);
#ifdef __cplusplus
}