aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVivek Jain <jvivek@novell.com>2005-07-20 20:25:00 +0800
committerJain Vivek <jvivek@src.gnome.org>2005-07-20 20:25:00 +0800
commit80ebb4eb9121a93b344907a8fe39db57b54b2bef (patch)
tree37924c7d951db461f46d3dbfed5be2b4fea190e3
parent53ef30545571eec7633f20adf60476b06c8da77c (diff)
downloadgsoc2013-evolution-80ebb4eb9121a93b344907a8fe39db57b54b2bef.tar.gz
gsoc2013-evolution-80ebb4eb9121a93b344907a8fe39db57b54b2bef.tar.zst
gsoc2013-evolution-80ebb4eb9121a93b344907a8fe39db57b54b2bef.zip
connect to sod-signal and get the input data in the callback
2005-07-20 Vivek Jain <jvivek@novell.com> * mail-send-options.c: connect to sod-signal and get the input data in the callback "feed_input_data" ** Fixes #310854 svn path=/trunk/; revision=29817
-rw-r--r--plugins/groupwise-features/ChangeLog6
-rw-r--r--plugins/groupwise-features/mail-send-options.c119
2 files changed, 73 insertions, 52 deletions
diff --git a/plugins/groupwise-features/ChangeLog b/plugins/groupwise-features/ChangeLog
index 49b5474239..662f48dc91 100644
--- a/plugins/groupwise-features/ChangeLog
+++ b/plugins/groupwise-features/ChangeLog
@@ -1,3 +1,9 @@
+2005-07-20 Vivek Jain <jvivek@novell.com>
+
+ * mail-send-options.c: connect to sod-signal and get the input data in
+ the callback "feed_input_data"
+ ** Fixes #310854
+
2005-07-20 Sankar P <psankar@novell.com>
* Consolidated the proxy and proxy-login plugins into the
diff --git a/plugins/groupwise-features/mail-send-options.c b/plugins/groupwise-features/mail-send-options.c
index 23a80e16fe..cb50b91f33 100644
--- a/plugins/groupwise-features/mail-send-options.c
+++ b/plugins/groupwise-features/mail-send-options.c
@@ -56,6 +56,69 @@ add_day_to_time (time_t time, int days)
}
static void
+feed_input_data(ESendOptionsDialog * dialog, gint state, gpointer data)
+{
+ EMsgComposer *comp;
+ char value [100];
+ char *temp = NULL;
+
+ comp = (EMsgComposer *) data;
+ /* we are bothered only for ok response: other cases are handled generally*/
+ if (state == GTK_RESPONSE_OK) {
+ if (dialog->data->gopts->reply_enabled) {
+ if (dialog->data->gopts->reply_convenient)
+ e_msg_composer_add_header (comp, X_REPLY_CONVENIENT ,"1" ) ;
+ else if (dialog->data->gopts->reply_within) {
+ time_t t;
+ t = add_day_to_time (time (NULL), dialog->data->gopts->reply_within);
+ strftime (value, 17, "%Y%m%dT%H%M%SZ", gmtime (&t));
+ e_msg_composer_add_header (comp, X_REPLY_WITHIN , value) ;
+ }
+ }
+
+ if (dialog->data->gopts->expiration_enabled) {
+ if (dialog->data->gopts->expire_after != 0) {
+ time_t t;
+ t = add_day_to_time (time (NULL), dialog->data->gopts->expire_after);
+ strftime (value, 17, "%Y%m%dT%H%M%SZ", gmtime (&t));
+ e_msg_composer_add_header (comp, X_EXPIRE_AFTER, value) ;
+ }
+ }
+ if (dialog->data->gopts->delay_enabled) {
+ strftime (value, 17, "%Y%m%dT%H%M%SZ", gmtime (&dialog->data->gopts->delay_until));
+ e_msg_composer_add_header (comp, X_DELAY_UNTIL, value) ;
+ }
+
+ /*Status Tracking Options*/
+ if (dialog->data->sopts->tracking_enabled) {
+ temp = g_strdup_printf ("%d",dialog->data->sopts->track_when) ;
+ e_msg_composer_add_header (comp, X_TRACK_WHEN, temp) ;
+ g_free (temp) ;
+ }
+
+ if (dialog->data->sopts->autodelete) {
+ e_msg_composer_add_header (comp, X_AUTODELETE, "1") ;
+ }
+ if (dialog->data->sopts->opened) {
+ temp = g_strdup_printf ("%d",dialog->data->sopts->opened) ;
+ e_msg_composer_add_header (comp, X_RETURN_NOTIFY_OPEN, temp) ;
+ g_free (temp) ;
+ }
+ if (dialog->data->sopts->declined) {
+ temp = g_strdup_printf ("%d",dialog->data->sopts->declined) ;
+ e_msg_composer_add_header (comp, X_RETURN_NOTIFY_DELETE, temp) ;
+ g_free (temp) ;
+ }
+
+ if (dialog->data->gopts->priority) {
+ temp = g_strdup_printf ("%d",dialog->data->gopts->priority);
+ e_msg_composer_add_header (comp, X_SEND_OPT_PRIORITY,temp);
+ g_free (temp);
+ }
+ }
+}
+
+static void
send_options_commit (EMsgComposer *comp, gpointer user_data)
{
if (!user_data && !E_IS_SENDOPTIONS_DIALOG (user_data))
@@ -71,12 +134,12 @@ void
org_gnome_compose_send_options (EPlugin *ep, EMMenuTargetWidget *t)
{
struct _EMenuTarget menu = t->target ;
+
EMsgComposer *comp = (struct _EMsgComposer *)menu.widget ;
EAccount *account = NULL;
char *temp = NULL;
char *url;
- char value [100];
-
+
account = e_msg_composer_get_preferred_account (comp) ;
url = g_strdup (account->transport->url) ;
temp = strstr (url, "groupwise") ;
@@ -92,57 +155,9 @@ org_gnome_compose_send_options (EPlugin *ep, EMMenuTargetWidget *t)
e_sendoptions_dialog_run (dialog, menu.widget, E_ITEM_MAIL) ;
- if (dialog->data->gopts->reply_enabled) {
- if (dialog->data->gopts->reply_convenient)
- e_msg_composer_add_header (comp, X_REPLY_CONVENIENT ,"1" ) ;
- else if (dialog->data->gopts->reply_within) {
- time_t t;
- t = add_day_to_time (time (NULL), dialog->data->gopts->reply_within);
- strftime (value, 17, "%Y%m%dT%H%M%SZ", gmtime (&t));
- e_msg_composer_add_header (comp, X_REPLY_WITHIN , value) ;
- }
- }
-
- if (dialog->data->gopts->expiration_enabled) {
- if (dialog->data->gopts->expire_after != 0) {
- time_t t;
- t = add_day_to_time (time (NULL), dialog->data->gopts->expire_after);
- strftime (value, 17, "%Y%m%dT%H%M%SZ", gmtime (&t));
- e_msg_composer_add_header (comp, X_EXPIRE_AFTER, value) ;
- }
- }
- if (dialog->data->gopts->delay_enabled) {
- strftime (value, 17, "%Y%m%dT%H%M%SZ", gmtime (&dialog->data->gopts->delay_until));
- e_msg_composer_add_header (comp, X_DELAY_UNTIL, value) ;
- }
+ g_signal_connect (dialog, "sod_response",
+ G_CALLBACK (feed_input_data), comp);
- /*Status Tracking Options*/
- if (dialog->data->sopts->tracking_enabled) {
- temp = g_strdup_printf ("%d",dialog->data->sopts->track_when) ;
- e_msg_composer_add_header (comp, X_TRACK_WHEN, temp) ;
- g_free (temp) ;
- }
-
- if (dialog->data->sopts->autodelete) {
- e_msg_composer_add_header (comp, X_AUTODELETE, "1") ;
- }
- if (dialog->data->sopts->opened) {
- temp = g_strdup_printf ("%d",dialog->data->sopts->opened) ;
- e_msg_composer_add_header (comp, X_RETURN_NOTIFY_OPEN, temp) ;
- g_free (temp) ;
- }
- if (dialog->data->sopts->declined) {
- temp = g_strdup_printf ("%d",dialog->data->sopts->declined) ;
- e_msg_composer_add_header (comp, X_RETURN_NOTIFY_DELETE, temp) ;
- g_free (temp) ;
- }
-
- if (dialog->data->gopts->priority) {
- temp = g_strdup_printf ("%d",dialog->data->gopts->priority);
- e_msg_composer_add_header (comp, X_SEND_OPT_PRIORITY,temp);
- g_free (temp);
- }
-
g_signal_connect (GTK_WIDGET (comp), "destroy",
G_CALLBACK (send_options_commit), dialog);
}