X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=src%2Fgtk-glade%2Fmodest-ui.c;h=36f4f49da789c98dafea00757084f26e2eb4e53b;hp=5fbb3f83b259476717aecbc5558f58befef31497;hb=9381d2949de3c1268e83284bd39a8ffb865ec851;hpb=408bbdb12dbac9cd8703fc3f0bf9b6d213661ea0 diff --git a/src/gtk-glade/modest-ui.c b/src/gtk-glade/modest-ui.c index 5fbb3f8..36f4f49 100644 --- a/src/gtk-glade/modest-ui.c +++ b/src/gtk-glade/modest-ui.c @@ -13,10 +13,12 @@ /* TODO: put in auto* */ #include +#include #include "../modest-ui.h" #include "../modest-window-mgr.h" #include "../modest-account-mgr.h" +#include "../modest-account-mgr.h" #include "../modest-identity-mgr.h" #include "../modest-tny-account-store.h" @@ -24,51 +26,25 @@ #include "../modest-tny-header-tree-view.h" #include "../modest-tny-msg-view.h" #include "../modest-tny-transport-actions.h" +#include "../modest-tny-store-actions.h" #include "../modest-text-utils.h" #include "../modest-tny-msg-actions.h" -#define MODEST_GLADE PREFIX "/share/modest/glade/modest.glade" -#define MODEST_GLADE_MAIN_WIN "main" -#define MODEST_GLADE_EDIT_WIN "new_mail" +#include "../modest-editor-window.h" +#include "modest-ui-glade.h" +#include "modest-ui-wizard.h" /* 'private'/'protected' functions */ static void modest_ui_class_init (ModestUIClass *klass); static void modest_ui_init (ModestUI *obj); static void modest_ui_finalize (GObject *obj); -static void modest_ui_window_destroy (GtkWidget *win, gpointer data); -static void modest_ui_last_window_closed (GObject *obj, gpointer data); - -static GtkWidget* modest_main_window_toolbar (void); -static GtkWidget* modest_main_window_folder_tree (ModestAccountMgr *modest_acc_mgr, - TnyAccountStoreIface *account_store); -static GtkWidget* modest_main_window_header_tree (TnyMsgFolderIface *folder); - - -void on_account_settings1_activate (GtkMenuItem *, - gpointer); - -static void on_password_requested (ModestTnyAccountStore *account_store, - const gchar *account_name, gpointer user_data); - -static void on_folder_clicked (ModestTnyFolderTreeView *folder_tree, - TnyMsgFolderIface *folder, - gpointer data); -static void on_message_clicked (ModestTnyFolderTreeView *folder_tree, - TnyMsgIface *message, - gpointer data); -static void on_new_mail_clicked (GtkWidget *widget, ModestUI *modest_ui); - -static void on_reply_clicked (GtkWidget *widget, ModestUI *modest_ui); +static void modest_ui_window_destroy (GtkWidget *win, GdkEvent *event, gpointer data); +static void modest_ui_last_window_closed (GObject *obj, gpointer data); -static void on_send_button_clicked (GtkWidget *widget, ModestUI *modest_ui); - -static void register_toolbar_callbacks (ModestUI *modest_ui); - -static void reply_to_msg (ModestUI *modest_ui, TnyMsgHeaderIface *header, - ModestTnyMsgView *msg_view); +gchar *on_password_requested (TnyAccountIface *, const gchar *, gboolean *); /* list my signals */ enum { @@ -77,29 +53,9 @@ enum { LAST_SIGNAL }; - -typedef struct _ModestUIPrivate ModestUIPrivate; -struct _ModestUIPrivate { - - ModestConf *modest_conf; - ModestAccountMgr *modest_acc_mgr; - ModestIdentityMgr *modest_id_mgr; - ModestWindowMgr *modest_window_mgr; - TnyAccountStoreIface *account_store; - - GtkWindow *main_window; - GladeXML *glade_xml; - - -}; -#define MODEST_UI_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE((o), \ - MODEST_TYPE_UI, \ - ModestUIPrivate)) /* globals */ static GObjectClass *parent_class = NULL; -/* uncomment the following if you have defined any signals */ -/* static guint signals[LAST_SIGNAL] = {0}; */ GType modest_ui_get_type (void) @@ -124,6 +80,7 @@ modest_ui_get_type (void) return my_type; } + static void modest_ui_class_init (ModestUIClass *klass) { @@ -135,14 +92,9 @@ modest_ui_class_init (ModestUIClass *klass) g_type_class_add_private (gobject_class, sizeof(ModestUIPrivate)); - /* signal definitions go here, e.g.: */ -/* signals[MY_SIGNAL_1] = */ -/* g_signal_new ("my_signal_1",....); */ -/* signals[MY_SIGNAL_2] = */ -/* g_signal_new ("my_signal_2",....); */ -/* etc. */ } + static void modest_ui_init (ModestUI *obj) { @@ -153,9 +105,13 @@ modest_ui_init (ModestUI *obj) priv->modest_conf = NULL; priv->modest_window_mgr = NULL; priv->glade_xml = NULL; - + priv->folder_view = NULL; + priv->header_view = NULL; + priv->message_view = NULL; + priv->current_folder = NULL; } + static void modest_ui_finalize (GObject *obj) { @@ -164,7 +120,7 @@ modest_ui_finalize (GObject *obj) if (priv->modest_acc_mgr) g_object_unref (priv->modest_acc_mgr); priv->modest_acc_mgr = NULL; - + if (priv->modest_id_mgr) g_object_unref (priv->modest_id_mgr); priv->modest_id_mgr = NULL; @@ -178,6 +134,21 @@ modest_ui_finalize (GObject *obj) priv->modest_window_mgr = NULL; } + +static void +on_accounts_reloaded (ModestTnyAccountStore *account_store, gpointer user_data) +{ + ModestUIPrivate *priv = user_data; + + g_return_if_fail (MODEST_IS_TNY_FOLDER_TREE_VIEW (priv->folder_view)); + g_return_if_fail (MODEST_IS_TNY_HEADER_TREE_VIEW (priv->header_view)); + + modest_tny_header_tree_view_set_folder (priv->header_view, NULL); + + modest_tny_folder_tree_view_update_model(priv->folder_view, account_store); +} + + GObject* modest_ui_new (ModestConf *modest_conf) { @@ -186,22 +157,22 @@ modest_ui_new (ModestConf *modest_conf) ModestAccountMgr *modest_acc_mgr; ModestIdentityMgr *modest_id_mgr; TnyAccountStoreIface *account_store_iface; + GSList *account_names_list; + GSList *identities_list; g_return_val_if_fail (modest_conf, NULL); obj = g_object_new(MODEST_TYPE_UI, NULL); priv = MODEST_UI_GET_PRIVATE(obj); - modest_acc_mgr = - MODEST_ACCOUNT_MGR(modest_account_mgr_new (modest_conf)); + modest_acc_mgr = MODEST_ACCOUNT_MGR(modest_account_mgr_new (modest_conf)); if (!modest_acc_mgr) { g_warning ("could not create ModestAccountMgr instance"); g_object_unref (obj); return NULL; - } - - modest_id_mgr = - MODEST_IDENTITY_MGR(modest_identity_mgr_new (modest_conf)); + } + + modest_id_mgr = MODEST_IDENTITY_MGR(modest_identity_mgr_new (modest_conf)); if (!modest_id_mgr) { g_warning ("could not create ModestIdentityMgr instance"); g_object_unref (obj); @@ -213,13 +184,16 @@ modest_ui_new (ModestConf *modest_conf) if (!account_store_iface) { g_warning ("could not initialze ModestTnyAccountStore"); return NULL; - } - g_signal_connect (account_store_iface, "password_requested", - G_CALLBACK(on_password_requested), - NULL); - + } + + modest_tny_account_store_set_get_pass_func(MODEST_TNY_ACCOUNT_STORE(account_store_iface), + on_password_requested); + + g_signal_connect (account_store_iface, "accounts_reloaded", + G_CALLBACK(on_accounts_reloaded), priv); + glade_init (); - priv->glade_xml = glade_xml_new (MODEST_GLADE, NULL,NULL); + priv->glade_xml = glade_xml_new (MODEST_GLADE, NULL, NULL); if (!priv->glade_xml) { g_warning ("failed to do glade stuff"); g_object_unref (obj); @@ -240,348 +214,42 @@ modest_ui_new (ModestConf *modest_conf) g_signal_connect (priv->modest_window_mgr, "last_window_closed", G_CALLBACK(modest_ui_last_window_closed), NULL); - return obj; -} - - -gboolean -modest_ui_show_main_window (ModestUI *modest_ui) -{ - GtkWidget *win; - int height, width; - ModestUIPrivate *priv; - GtkWidget *folder_view, *header_view; - GtkWidget *message_view; - GtkWidget *account_settings_item; - - GtkWidget *folder_view_holder, - *header_view_holder, - *mail_paned; - - priv = MODEST_UI_GET_PRIVATE(modest_ui); - - height = modest_conf_get_int (priv->modest_conf, - MODEST_CONF_MAIN_WINDOW_HEIGHT,NULL); - width = modest_conf_get_int (priv->modest_conf, - MODEST_CONF_MAIN_WINDOW_WIDTH,NULL); - - win = glade_xml_get_widget (priv->glade_xml, "main"); - if (!win) { - g_warning ("could not create main window"); - return FALSE; - } - - folder_view = - GTK_WIDGET(modest_main_window_folder_tree(priv->modest_acc_mgr, - priv->account_store)); - folder_view_holder = glade_xml_get_widget (priv->glade_xml, "folders"); - if (!folder_view||!folder_view_holder) { - g_warning ("failed to create folder tree"); - return FALSE; - } - gtk_container_add (GTK_CONTAINER(folder_view_holder), folder_view); - - header_view = GTK_WIDGET(modest_main_window_header_tree (NULL)); - header_view_holder = glade_xml_get_widget (priv->glade_xml, "mail_list"); - if (!header_view) { - g_warning ("failed to create header tree"); - return FALSE; - } - gtk_container_add (GTK_CONTAINER(header_view_holder), header_view); - - g_signal_connect (G_OBJECT(folder_view), "folder_selected", - G_CALLBACK(on_folder_clicked), modest_ui); - - message_view = GTK_WIDGET(modest_tny_msg_view_new (NULL)); - if (!message_view) { - g_warning ("failed to create message view"); - return FALSE; - } - mail_paned = glade_xml_get_widget (priv->glade_xml, "mail_paned"); - gtk_paned_add2 (GTK_PANED(mail_paned), message_view); - - g_signal_connect (header_view, "message_selected", - G_CALLBACK(on_message_clicked), - modest_ui); - - account_settings_item = glade_xml_get_widget (priv->glade_xml, "account_settings1"); - if (!account_settings_item) - { - g_warning ("The account settings item isn't available!\n"); - return FALSE; - } - - g_signal_connect (account_settings_item, "activate", - G_CALLBACK(on_account_settings1_activate), - modest_ui); - - register_toolbar_callbacks (modest_ui); - - modest_window_mgr_register (priv->modest_window_mgr, - G_OBJECT(win), MODEST_MAIN_WINDOW, 0); - g_signal_connect (win, "destroy", G_CALLBACK(modest_ui_window_destroy), - modest_ui); - gtk_widget_set_usize (GTK_WIDGET(win), height, width); - gtk_window_set_title (GTK_WINDOW(win), PACKAGE_STRING); - - gtk_widget_show_all (win); - return TRUE; -} - - -static void -register_toolbar_callbacks (ModestUI *modest_ui) -{ - ModestUIPrivate *priv; - GtkWidget *button; - - g_return_if_fail (modest_ui); - - priv = MODEST_UI_GET_PRIVATE (modest_ui); - - button = glade_xml_get_widget (priv->glade_xml, "toolb_new_mail"); - if (button) - g_signal_connect (button, "clicked", - G_CALLBACK(on_new_mail_clicked), modest_ui); - - button = glade_xml_get_widget (priv->glade_xml, "toolb_reply"); - if (button) - g_signal_connect (button, "clicked", - G_CALLBACK(on_reply_clicked), modest_ui); -} - - - -static void -hide_edit_window (GtkWidget *win, gpointer data) -{ - gtk_widget_hide (win); -} - - - - -gboolean -modest_ui_show_edit_window (ModestUI *modest_ui, const gchar* to, - const gchar* cc, const gchar* bcc, - const gchar* subject, const gchar *body, - const GSList* att) -{ - GtkWidget *win, *to_entry, *subject_entry, *body_view; - - ModestUIPrivate *priv; - GtkWidget *btn; - GtkTextBuffer *buf; - - priv = MODEST_UI_GET_PRIVATE(modest_ui); - int height = modest_conf_get_int (priv->modest_conf, - MODEST_CONF_EDIT_WINDOW_HEIGHT,NULL); - int width = modest_conf_get_int (priv->modest_conf, - MODEST_CONF_EDIT_WINDOW_WIDTH,NULL); - - win = glade_xml_get_widget (priv->glade_xml, "new_mail"); - if (!win) { - g_warning ("could not create new mail window"); - return FALSE; - } - - modest_window_mgr_register (priv->modest_window_mgr, - G_OBJECT(win), MODEST_EDIT_WINDOW, 0); - to_entry = glade_xml_get_widget (priv->glade_xml, "to_entry"); - subject_entry = glade_xml_get_widget (priv->glade_xml, "subject_entry"); - body_view = glade_xml_get_widget (priv->glade_xml, "body_view"); - - gtk_entry_set_text(GTK_ENTRY(subject_entry), subject); - gtk_entry_set_text(GTK_ENTRY(to_entry), to); - - buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(body_view)); - if (body) { - gtk_text_buffer_set_text(buf, body, -1); - } else { - gtk_text_buffer_set_text(buf, "", -1); - } - g_signal_connect (win, "destroy", G_CALLBACK(hide_edit_window), - NULL); - - gtk_widget_set_usize (GTK_WIDGET(win), height, width); - gtk_window_set_title (GTK_WINDOW(win), - subject ? subject : "Untitled"); - - - btn = glade_xml_get_widget (priv->glade_xml, "toolb_send"); - g_signal_connect (btn, "clicked", G_CALLBACK(on_send_button_clicked), - modest_ui); - - gtk_widget_show_all (win); - return TRUE; -} - - -static void -modest_ui_window_destroy (GtkWidget *win, gpointer data) -{ - ModestUIPrivate *priv; + account_names_list = modest_account_mgr_server_account_names(modest_acc_mgr, + NULL, MODEST_PROTO_TYPE_ANY, NULL, FALSE); + identities_list = modest_identity_mgr_identity_names(modest_id_mgr, NULL); + if (!(account_names_list != NULL || identities_list != NULL)) + wizard_account_dialog(MODEST_UI(obj)); + g_slist_free(account_names_list); + g_slist_free(identities_list); - g_return_if_fail (data); - - priv = MODEST_UI_GET_PRIVATE((ModestUI*)data); - if (!modest_window_mgr_unregister (priv->modest_window_mgr, G_OBJECT(win))) - g_warning ("modest window mgr: failed to unregister %p", - G_OBJECT(win)); + return obj; } static void modest_ui_last_window_closed (GObject *obj, gpointer data) { + /* FIXME: Other cleanups todo? Finalize Tinymail? */ gtk_main_quit (); } -void -on_account_selector_selection_changed (GtkWidget *widget, - gpointer user_data) -{ - GtkTreeModel *model = gtk_combo_box_get_model(GTK_COMBO_BOX(widget)); - GtkTreeIter iter; - - gchar *account_name; - - if (gtk_combo_box_get_active_iter(GTK_COMBO_BOX(widget), &iter)) - { - gtk_tree_model_get(GTK_TREE_MODEL(model), - &iter, - 0, &account_name, - -1); - } - else - { - account_name="empty"; - } - - g_message("Value: '%s'\n", account_name); -} - -void -on_account_settings1_activate (GtkMenuItem *menuitem, - gpointer user_data) -{ - GladeXML *glade_xml; - GtkWidget *advanced_account_setup; - ModestUIPrivate *priv; - gint retval; - GSList *account_name_list; - GSList *account_name_list_iter; - GtkListStore *account_names; - GtkTreeIter account_names_iter; - GtkWidget *account_selector; - GtkCellRenderer *renderer; - - priv = MODEST_UI_GET_PRIVATE(MODEST_UI(user_data)); - - glade_xml = glade_xml_new(MODEST_GLADE, "mailbox_setup_advanced", NULL); - advanced_account_setup = glade_xml_get_widget(glade_xml, "mailbox_setup_advanced"); - - account_name_list=modest_account_mgr_account_names(priv->modest_acc_mgr, NULL); - account_names = gtk_list_store_new(1, G_TYPE_STRING); - - for (account_name_list_iter=account_name_list; - account_name_list_iter!=NULL; - account_name_list_iter=g_slist_next(account_name_list_iter)) - { - gtk_list_store_append(account_names, &account_names_iter); - gtk_list_store_set(account_names, &account_names_iter, - 0, account_name_list_iter->data, - -1); - } - - g_slist_free(account_name_list); - - account_selector = glade_xml_get_widget(glade_xml, "account_selector"); - gtk_combo_box_set_model(GTK_COMBO_BOX(account_selector), GTK_TREE_MODEL(account_names)); - - renderer = gtk_cell_renderer_text_new (); - gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (account_selector), renderer, TRUE); - gtk_cell_layout_set_attributes (GTK_CELL_LAYOUT (account_selector), renderer, - "text", 0, - NULL); - - g_signal_connect(GTK_WIDGET(account_selector), "changed", - G_CALLBACK(on_account_selector_selection_changed), - GTK_WIDGET(advanced_account_setup)); - - gtk_combo_box_set_active(GTK_COMBO_BOX(account_selector), 0); - - gtk_widget_show_all(GTK_WIDGET(advanced_account_setup)); - - retval=gtk_dialog_run(GTK_DIALOG(advanced_account_setup)); - - g_object_unref(account_names); - - gtk_widget_destroy(GTK_WIDGET(advanced_account_setup)); - - g_object_unref(glade_xml); -} - -static void -on_folder_clicked (ModestTnyFolderTreeView *folder_tree, - TnyMsgFolderIface *folder, - gpointer data) -{ - GtkWidget *win; - ModestTnyHeaderTreeView *tree_view; - ModestUIPrivate *priv; - GtkWidget *scrollview; - - g_return_if_fail (folder); - g_return_if_fail (data); - priv = MODEST_UI_GET_PRIVATE(data); - scrollview = glade_xml_get_widget (priv->glade_xml,"mail_list"); - - tree_view = MODEST_TNY_HEADER_TREE_VIEW( - gtk_bin_get_child(GTK_BIN(scrollview))); - win = glade_xml_get_widget (priv->glade_xml, "main"); - gtk_window_set_title (GTK_WINDOW(win), - tny_msg_folder_iface_get_name(folder)); - - modest_tny_header_tree_view_set_folder (tree_view, - folder); -} - - - -static void on_message_clicked (ModestTnyFolderTreeView *folder_tree, - TnyMsgIface *message, - gpointer data) -{ - GtkWidget *paned; - ModestTnyMsgView *msg_view; - ModestUIPrivate *priv; - - g_return_if_fail (data); - - priv = MODEST_UI_GET_PRIVATE(data); - paned = glade_xml_get_widget (priv->glade_xml,"mail_paned"); - msg_view = MODEST_TNY_MSG_VIEW(gtk_paned_get_child2 (GTK_PANED(paned))); - - modest_tny_msg_view_set_message (msg_view, - message); -} - -static void -on_password_requested (ModestTnyAccountStore *account_store, - const gchar *account_name, gpointer user_data) -{ +gchar * +on_password_requested (TnyAccountIface *account, + const gchar *prompt, + gboolean *cancel) { GtkWidget *passdialog; GtkWidget *vbox; + GtkWidget *infoscroll; GtkWidget *infolabel; GtkWidget *passentry; - gint retval; - const gchar *infostring=g_strconcat("Please enter the password for ", account_name, ".", NULL); + GtkTextBuffer *infobuffer; + gchar *retval; + gint result; - passdialog = gtk_dialog_new_with_buttons("MyDialog", + passdialog = gtk_dialog_new_with_buttons(_("Password"), NULL, GTK_DIALOG_MODAL|GTK_DIALOG_DESTROY_WITH_PARENT, GTK_STOCK_OK, @@ -590,247 +258,59 @@ on_password_requested (ModestTnyAccountStore *account_store, GTK_RESPONSE_REJECT, NULL); - vbox=gtk_vbox_new(FALSE, 0); + vbox = gtk_vbox_new(FALSE, 0); - infolabel=gtk_label_new(infostring); - passentry=gtk_entry_new(); + infobuffer = gtk_text_buffer_new (NULL); + gtk_text_buffer_set_text(infobuffer, prompt, -1); + infoscroll = gtk_scrolled_window_new(NULL, NULL); + infolabel = gtk_text_view_new_with_buffer(infobuffer); + gtk_container_add(GTK_CONTAINER(infoscroll), infolabel); + passentry = gtk_entry_new(); + gtk_entry_set_visibility(GTK_ENTRY(passentry), FALSE); - gtk_box_pack_start(GTK_BOX(GTK_DIALOG(passdialog)->vbox), infolabel, FALSE, FALSE, 0); + gtk_box_pack_start(GTK_BOX(GTK_DIALOG(passdialog)->vbox), infoscroll, FALSE, FALSE, 0); gtk_box_pack_start(GTK_BOX(GTK_DIALOG(passdialog)->vbox), passentry, FALSE, FALSE, 0); gtk_widget_show_all(passdialog); - retval = gtk_dialog_run (GTK_DIALOG(passdialog)); + result = gtk_dialog_run (GTK_DIALOG(passdialog)); - switch (retval) - { + switch (result) { case GTK_RESPONSE_ACCEPT: - modest_account_mgr_set_server_account_string(modest_tny_account_store_get_accout_mgr(account_store), - account_name, - "password", - gtk_entry_get_text(GTK_ENTRY(passentry)), - NULL); + retval = g_strdup(gtk_entry_get_text(GTK_ENTRY(passentry))); + *cancel=FALSE; break; - case GTK_RESPONSE_CANCEL: - /* FIXME: - * What happens, if canceled?" - */ + default: + retval = g_strdup("");; + *cancel=TRUE; break; } - gtk_widget_destroy (passdialog); -} - - - - - - -static GtkWidget* -modest_main_window_header_tree (TnyMsgFolderIface *folder) -{ - int i; - GSList *columns = NULL; - GtkWidget *header_tree; - ModestTnyHeaderTreeViewColumn cols[] = { - MODEST_TNY_HEADER_TREE_VIEW_COLUMN_MSGTYPE, - MODEST_TNY_HEADER_TREE_VIEW_COLUMN_ATTACH, - MODEST_TNY_HEADER_TREE_VIEW_COLUMN_COMPACT_HEADER - }; - - for (i = 0 ; i != sizeof(cols)/sizeof(ModestTnyHeaderTreeViewColumn); ++i) - columns = g_slist_append (columns, GINT_TO_POINTER(cols[i])); - - header_tree = GTK_WIDGET(modest_tny_header_tree_view_new(folder, columns, - MODEST_TNY_HEADER_TREE_VIEW_STYLE_NORMAL)); - g_slist_free (columns); - - if (!header_tree) { - g_warning ("could not create header tree"); - return NULL; + gtk_widget_hide(passdialog); + gtk_widget_destroy(passdialog); + while (gtk_events_pending()){ + gtk_main_iteration(); } - return GTK_WIDGET(header_tree); + return retval; } - -static GtkWidget* -modest_main_window_folder_tree (ModestAccountMgr *modest_acc_mgr, - TnyAccountStoreIface *account_store) -{ - GtkWidget *folder_tree; - - folder_tree = GTK_WIDGET(modest_tny_folder_tree_view_new (account_store)); - if (!folder_tree) { - g_warning ("could not create folder list"); - return NULL; - } - - return folder_tree; -} - - -static void -on_new_mail_clicked (GtkWidget *widget, ModestUI *modest_ui) -{ - g_return_if_fail (modest_ui); - modest_ui_show_edit_window (modest_ui, "", "", "", "", "", NULL); -} - -static void -reply_to_msg (ModestUI *modest_ui, TnyMsgHeaderIface *header, - ModestTnyMsgView *msg_view) { - const TnyMsgIface *msg; - const TnyMsgFolderIface *folder; - GString *re_sub; - const gchar *subject, *from; - gchar *unquoted, *quoted; - time_t sent_date; - gint line_limit = 76; - - if (!header) { - g_warning("no header"); - return; - } - folder = tny_msg_header_iface_get_folder (TNY_MSG_HEADER_IFACE(header)); - if (!folder) { - g_warning ("cannot find folder"); - return; - } - - msg = tny_msg_folder_iface_get_message (TNY_MSG_FOLDER_IFACE(folder), header); - if (!msg) { - g_warning ("cannot find msg"); - return; - } - subject = tny_msg_header_iface_get_subject(header); - re_sub = g_string_new(subject); - g_string_prepend(re_sub, "Re: "); - /* FIXME: honor replyto, cc */ - from = tny_msg_header_iface_get_from(header); - sent_date = tny_msg_header_iface_get_date_sent(header); - - unquoted = modest_tny_msg_view_get_selected_text(msg_view); - quoted = modest_tny_msg_actions_quote(msg, from, sent_date, line_limit, unquoted); - - modest_ui_show_edit_window (modest_ui, from, /* cc */ "", /* bcc */ "", re_sub->str, quoted, NULL); - g_free(quoted); - g_free(unquoted); - g_string_free(re_sub, TRUE); -} - - -static void -on_reply_clicked (GtkWidget *widget, ModestUI *modest_ui) +void +on_account_selector_selection_changed (GtkWidget *widget, gpointer user_data) { - GtkTreeSelection *sel; - GtkWidget *paned; - GtkTreeModel *model; + GtkTreeModel *model = gtk_combo_box_get_model(GTK_COMBO_BOX(widget)); GtkTreeIter iter; - GtkScrolledWindow *scroll; - - TnyMsgHeaderIface *header; - - ModestTnyHeaderTreeView *header_view; - ModestTnyMsgView *msg_view; - ModestUIPrivate *priv; - - g_return_if_fail (modest_ui); - - priv = MODEST_UI_GET_PRIVATE(modest_ui); - paned = glade_xml_get_widget (priv->glade_xml,"mail_paned"); - g_return_if_fail (paned); - - scroll = GTK_SCROLLED_WINDOW(gtk_paned_get_child1 (GTK_PANED(paned))); - g_return_if_fail (scroll); - - msg_view = MODEST_TNY_MSG_VIEW(gtk_paned_get_child2 (GTK_PANED(paned))); - g_return_if_fail (msg_view); - - header_view = MODEST_TNY_HEADER_TREE_VIEW(gtk_bin_get_child (GTK_BIN(scroll))); - g_return_if_fail (header_view); - - sel = gtk_tree_view_get_selection (GTK_TREE_VIEW(header_view)); - g_return_if_fail (sel); + gchar *account_name; - if (!gtk_tree_selection_get_selected (sel, &model, &iter)) { - /* no message was selected. TODO: disable reply button in this case */ - g_warning("nothing to reply to"); - return; + if (gtk_combo_box_get_active_iter(GTK_COMBO_BOX(widget), &iter)) { + gtk_tree_model_get(GTK_TREE_MODEL(model), &iter, + 0, &account_name, -1); + } else { + account_name="empty"; } - gtk_tree_model_get (model, &iter, - TNY_MSG_HEADER_LIST_MODEL_INSTANCE_COLUMN, - &header, -1); - - reply_to_msg (modest_ui, header, msg_view); + free(account_name); } -/* FIXME: truly evil --> we cannot really assume that - * there is only one edit window open... - */ -static void -on_send_button_clicked (GtkWidget *widget, ModestUI *modest_ui) -{ - ModestTnyTransportActions *actions; - ModestUIPrivate *priv; - GtkWidget *to_entry, *subject_entry, *body_view; - const gchar *to, *subject, *email_from; - gchar *body; - GtkTextIter start, end; - GtkTextBuffer *buf; - TnyAccountStoreIface *account_store; - const GList *transport_accounts; - TnyTransportAccountIface *transport_account; - ModestConf *conf; - ModestIdentityMgr *id_mgr; - - g_return_if_fail (modest_ui); - - actions = MODEST_TNY_TRANSPORT_ACTIONS - (modest_tny_transport_actions_new ()); - priv = MODEST_UI_GET_PRIVATE(modest_ui); - - account_store = priv->account_store; - transport_accounts = - tny_account_store_iface_get_transport_accounts (account_store); - if (!transport_accounts) { - g_message ("cannot send message: no transport account defined"); - return; - } else /* take the first one! */ - transport_account = - TNY_TRANSPORT_ACCOUNT_IFACE(transport_accounts->data); - - to_entry = glade_xml_get_widget (priv->glade_xml, "to_entry"); - subject_entry = glade_xml_get_widget (priv->glade_xml, "subject_entry"); - body_view = glade_xml_get_widget (priv->glade_xml, "body_view"); - - to = gtk_entry_get_text (GTK_ENTRY(to_entry)); - subject = gtk_entry_get_text (GTK_ENTRY(subject_entry)); - - buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(body_view)); - gtk_text_buffer_get_bounds (buf, &start, &end); - body = gtk_text_buffer_get_text (buf, &start, &end, FALSE); - - id_mgr = priv->modest_id_mgr; - email_from = modest_identity_mgr_get_identity_string(id_mgr, - MODEST_IDENTITY_DEFAULT_IDENTITY, - MODEST_IDENTITY_EMAIL, NULL); - - g_message("sending \"%s\" %s ==> %s", subject, email_from, to); - modest_tny_transport_actions_send_message (actions, - transport_account, - email_from, - to, "", "", subject, - body); - g_free (body); - g_object_unref (G_OBJECT(actions)); - - gtk_entry_set_text (GTK_ENTRY(to_entry), ""); - gtk_entry_set_text (GTK_ENTRY(subject_entry), ""); - gtk_text_buffer_set_text (buf, "", 0); - - gtk_widget_hide (glade_xml_get_widget (priv->glade_xml, "new_mail")); -}