From 5d4b606a3bffd2ed111ed040d7a191bb4d866531 Mon Sep 17 00:00:00 2001 From: Nils Faerber Date: Mon, 12 Jun 2006 11:05:47 +0000 Subject: [PATCH] * split up gtk-glade/modest-ui.c into several modules for functional element * code cleanups while splitting * added documentation for modest-editor-window object pmo-trunk-r226 --- src/gtk-glade/Makefile.am | 6 + src/gtk-glade/modest-ui-main-view.c | 517 +++++++++++++ src/gtk-glade/modest-ui-message-editor.c | 593 +++++++++++++++ src/gtk-glade/modest-ui-message-editor.h | 15 + src/gtk-glade/modest-ui-message-viewer.c | 33 + src/gtk-glade/modest-ui.c | 1209 ++---------------------------- src/modest-editor-window.h | 121 ++- 7 files changed, 1326 insertions(+), 1168 deletions(-) create mode 100644 src/gtk-glade/modest-ui-main-view.c create mode 100644 src/gtk-glade/modest-ui-main-view.h create mode 100644 src/gtk-glade/modest-ui-message-editor.c create mode 100644 src/gtk-glade/modest-ui-message-editor.h create mode 100644 src/gtk-glade/modest-ui-message-viewer.c create mode 100644 src/gtk-glade/modest-ui-message-viewer.h diff --git a/src/gtk-glade/Makefile.am b/src/gtk-glade/Makefile.am index 9eb8290..82dac97 100644 --- a/src/gtk-glade/Makefile.am +++ b/src/gtk-glade/Makefile.am @@ -26,6 +26,12 @@ libmodest_ui_la_SOURCES=\ modest-ui.c\ modest-ui-glade.h\ modest-icon-names.h\ + modest-ui-main-view.c\ + modest-ui-main-view.h\ + modest-ui-message-editor.c\ + modest-ui-message-editor.h\ + modest-ui-message-viewer.c\ + modest-ui-message-viewer.h\ modest-ui-wizard.h\ modest-ui-wizard.c diff --git a/src/gtk-glade/modest-ui-main-view.c b/src/gtk-glade/modest-ui-main-view.c new file mode 100644 index 0000000..f1f108a --- /dev/null +++ b/src/gtk-glade/modest-ui-main-view.c @@ -0,0 +1,517 @@ +#include +#include +#include +#include + +#ifdef HAVE_CONFIG_H +#include +#endif /*HAVE_CONFIG_H*/ + +/* 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" +#include "../modest-tny-folder-tree-view.h" +#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" + +#include "../modest-editor-window.h" + +#include "modest-ui-glade.h" +#include "modest-ui-wizard.h" + +#include "modest-ui-main-view.h" +#include "modest-ui-message-editor.h" +#include "modest-ui-message-viewer.h" + + +static GtkWidget* modest_main_window_folder_tree (ModestAccountMgr *modest_acc_mgr, + TnyAccountStoreIface *account_store); + +static GtkWidget* modest_main_window_header_tree (TnyMsgFolderIface *folder); + +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_reply_clicked (GtkWidget *widget, ModestUI *modest_ui); + +static void on_forward_clicked (GtkWidget *widget, ModestUI *modest_ui); + +static void on_delete_clicked (GtkWidget *widget, ModestUI *modest_ui); + +static void on_view_attachments_toggled(GtkWidget *widget, ModestUI *modest_ui); + +static void on_sendreceive_button_clicked (GtkWidget *widget, ModestUI *modest_ui); + +static void register_toolbar_callbacks (ModestUI *modest_ui); + + +static void +modest_ui_main_view_destroy (GtkWidget *win, GdkEvent *event, gpointer data) +{ + ModestUIPrivate *priv; + + g_return_if_fail (data); + g_return_if_fail(MODEST_IS_UI(data)); + priv = MODEST_UI_GET_PRIVATE((ModestUI *)data); + g_return_if_fail(priv); + if (!modest_window_mgr_unregister (priv->modest_window_mgr, G_OBJECT(win))) + g_warning ("modest window mgr: failed to unregister %p", + G_OBJECT(win)); + else + gtk_widget_hide(win); +} + + +gboolean +modest_ui_show_main_window (ModestUI *modest_ui) +{ + GtkWidget *win; + gint height, width; + ModestUIPrivate *priv; + GtkWidget *folder_view, *header_view; + GtkWidget *message_view; + GtkWidget *account_settings_item; + GtkWidget *delete_item; + GtkWidget *view_attachments_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)); + priv->folder_view = folder_view; + 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)); + priv->header_view = header_view; + 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, priv->modest_conf)); + 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, "AccountSettingsMenuItem"); + 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); + */ +#if 0 + new_account_item = glade_xml_get_widget (priv->glade_xml, "NewAccountWizardMenuItem"); + if (!new_account_item) { + g_warning ("The new account item isn't available!\n"); + return FALSE; + } + + g_signal_connect (new_account_item, "activate", + G_CALLBACK(new_wizard_account), modest_ui); +#endif + delete_item = glade_xml_get_widget (priv->glade_xml, "delete1"); + if (!delete_item) { + g_warning ("The delete item isn't available!\n"); + return FALSE; + } + + g_signal_connect (delete_item, "activate", G_CALLBACK(on_delete_clicked), + modest_ui); + + view_attachments_item = glade_xml_get_widget (priv->glade_xml, "menu_view_attachments"); + if (!view_attachments_item) { + g_warning ("The view_attachments_item isn't available!"); + return FALSE; + } + + gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(view_attachments_item), + modest_conf_get_bool(priv->modest_conf, + MODEST_CONF_MSG_VIEW_SHOW_ATTACHMENTS_INLINE, + NULL)); + + g_signal_connect (view_attachments_item, + "toggled", + G_CALLBACK(on_view_attachments_toggled), + 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-event", G_CALLBACK(modest_ui_main_view_destroy), + modest_ui); + g_signal_connect (win, "delete-event", G_CALLBACK(modest_ui_main_view_destroy), + modest_ui); + gtk_widget_set_usize (GTK_WIDGET(win), width, height); + 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); + gtk_widget_set_sensitive(button, FALSE); + } + + button = glade_xml_get_widget (priv->glade_xml, "toolb_reply_all"); + if (button) { + //g_signal_connect (button, "clicked", + // G_CALLBACK(on_reply_all_clicked), modest_ui); + gtk_widget_set_sensitive(button, FALSE); + } + + button = glade_xml_get_widget (priv->glade_xml, "toolb_forward"); + if (button) { + g_signal_connect (button, "clicked", + G_CALLBACK(on_forward_clicked), modest_ui); + gtk_widget_set_sensitive(button, FALSE); + } + + button = glade_xml_get_widget (priv->glade_xml, "toolb_move_to"); + if (button) { + //g_signal_connect (button, "clicked", + // G_CALLBACK(on_move_to_clicked), modest_ui); + gtk_widget_set_sensitive(button, FALSE); + } + + button = glade_xml_get_widget (priv->glade_xml, "toolb_delete"); + if (button) { + g_signal_connect (button, "clicked", + G_CALLBACK(on_delete_clicked), modest_ui); + gtk_widget_set_sensitive(button, FALSE); + } + + button = glade_xml_get_widget (priv->glade_xml, "toolb_send_receive"); + if (button) { + g_signal_connect (button, "clicked", + G_CALLBACK(on_sendreceive_button_clicked), modest_ui); + gtk_widget_set_sensitive(button, TRUE); + } +} + + +static void +on_folder_clicked (ModestTnyFolderTreeView *folder_tree, + TnyMsgFolderIface *folder, + gpointer data) +{ + GtkWidget *win; + GtkWidget *button; + GtkWidget *paned; + ModestTnyHeaderTreeView *tree_view; + ModestTnyMsgView *msg_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); + + button = glade_xml_get_widget (priv->glade_xml, "toolb_reply"); + if (button) { + gtk_widget_set_sensitive(button, FALSE); + } + + button = glade_xml_get_widget (priv->glade_xml, "toolb_forward"); + if (button) { + gtk_widget_set_sensitive(button, FALSE); + } + + button = glade_xml_get_widget (priv->glade_xml, "toolb_delete"); + if (button) { + gtk_widget_set_sensitive(button, FALSE); + } + + paned = glade_xml_get_widget (priv->glade_xml,"mail_paned"); + g_return_if_fail (paned); + + msg_view = MODEST_TNY_MSG_VIEW(gtk_paned_get_child2 (GTK_PANED(paned))); + g_return_if_fail (msg_view); + + modest_tny_msg_view_set_message (msg_view, NULL); +} + + +static void +on_message_clicked (ModestTnyFolderTreeView *folder_tree, + TnyMsgIface *message, + gpointer data) +{ + GtkWidget *paned; + GtkWidget *button; + 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); + button = glade_xml_get_widget (priv->glade_xml, "toolb_reply"); + if (button) { + gtk_widget_set_sensitive(button, TRUE); + } + button = glade_xml_get_widget (priv->glade_xml, "toolb_forward"); + if (button) { + gtk_widget_set_sensitive(button, TRUE); + } + button = glade_xml_get_widget (priv->glade_xml, "toolb_delete"); + if (button) { + gtk_widget_set_sensitive(button, TRUE); + } +} + + +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_FROM, + MODEST_TNY_HEADER_TREE_VIEW_COLUMN_SUBJECT, + MODEST_TNY_HEADER_TREE_VIEW_COLUMN_RECEIVED_DATE + }; + + 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; + } + + return GTK_WIDGET(header_tree); +} + + +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_reply_clicked (GtkWidget *widget, ModestUI *modest_ui) +{ + quoted_send_msg (modest_ui, QUOTED_SEND_REPLY); +} + + +static void +on_forward_clicked (GtkWidget *widget, ModestUI *modest_ui) +{ + quoted_send_msg (modest_ui, QUOTED_SEND_FORWARD); +} + + +static void +on_view_attachments_toggled(GtkWidget *widget, ModestUI *modest_ui) +{ + GtkWidget *view_attachments_item, *paned; + ModestTnyMsgView *msg_view; + ModestUIPrivate *priv; + + priv = MODEST_UI_GET_PRIVATE(modest_ui); + view_attachments_item = glade_xml_get_widget (priv->glade_xml, "menu_view_attachments"); + g_return_if_fail(view_attachments_item); + + modest_conf_set_bool(priv->modest_conf, + MODEST_CONF_MSG_VIEW_SHOW_ATTACHMENTS_INLINE, + gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(view_attachments_item)), + NULL); + + /* refresh message view */ + 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_redraw(MODEST_TNY_MSG_VIEW(msg_view)); +} + + +static void +on_delete_clicked (GtkWidget *widget, ModestUI *modest_ui) +{ + GtkTreeSelection *sel; + GtkWidget *paned; + GtkTreeModel *model; + GtkTreeIter iter; + GtkScrolledWindow *scroll; + GtkTreeModel *mymodel; + + 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); + + /* get all selected mails */ + if (G_LIKELY (gtk_tree_selection_get_selected (sel, &model, &iter))) { + TnyMsgHeaderIface *header; + + gtk_tree_model_get (model, &iter, TNY_MSG_HEADER_LIST_MODEL_INSTANCE_COLUMN, + &header, -1); + + if (G_LIKELY (header)) { + TnyMsgFolderIface *folder; + // const TnyMsgIface *msg; + + if (GTK_IS_TREE_MODEL_SORT (model)) { + mymodel = gtk_tree_model_sort_get_model + (GTK_TREE_MODEL_SORT (model)); + } else + mymodel = model; + + folder = (TnyMsgFolderIface*)tny_msg_header_iface_get_folder (header); + + /* this will make the message as deleted */ + /* tny_msg_folder_iface_expunge (folder); will finally delete messages */ + if (TNY_IS_MSG_FOLDER (folder)) + tny_msg_folder_iface_remove_message (folder, header); + gtk_widget_queue_draw (GTK_WIDGET (header_view)); + } + } +} + + +static void +on_sendreceive_button_clicked (GtkWidget *widget, ModestUI *modest_ui) +{ + ModestUIPrivate *priv; + // ModestTnyStoreActions *store_actions; + TnyAccountStoreIface *account_store; + const GList *store_accounts; + const GList *iter; + + g_return_if_fail (modest_ui); + + // store_actions = MODEST_TNY_STORE_ACTIONS (modest_tny_store_actions_new ()); + priv = MODEST_UI_GET_PRIVATE(modest_ui); + + account_store = priv->account_store; + store_accounts = + tny_account_store_iface_get_store_accounts (account_store); + + for (iter = store_accounts; iter; iter = iter->next) { + modest_tny_store_actions_update_folders (TNY_STORE_ACCOUNT_IFACE (iter->data)); + // modest_tny_store_actions_update_folders (store_actions, TNY_STORE_ACCOUNT_IFACE (iter->data)); + } + // g_object_unref (store_actions); +} diff --git a/src/gtk-glade/modest-ui-main-view.h b/src/gtk-glade/modest-ui-main-view.h new file mode 100644 index 0000000..e69de29 diff --git a/src/gtk-glade/modest-ui-message-editor.c b/src/gtk-glade/modest-ui-message-editor.c new file mode 100644 index 0000000..1458614 --- /dev/null +++ b/src/gtk-glade/modest-ui-message-editor.c @@ -0,0 +1,593 @@ +#include +#include +#include +#include + +#ifdef HAVE_CONFIG_H +#include +#endif /*HAVE_CONFIG_H*/ + +/* 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" +#include "../modest-tny-folder-tree-view.h" +#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" + +#include "../modest-editor-window.h" + +#include "modest-ui-glade.h" +#include "modest-ui-wizard.h" + +#include "modest-ui-message-editor.h" + + +static void on_attach_button_clicked (GtkWidget *widget, ModestEditorWindow *modest_editwin); + +static void on_send_button_clicked (GtkWidget *widget, ModestEditorWindow *modest_editwin); + + +typedef struct { + ModestUI *modest_ui; + ModestEditorWindow *edit_win; + GladeXML *glade_xml; + GList *attachments; +} EditWinData; + + +static gboolean close_edit_confirm_dialog(ModestEditorWindow *edit_win) +{ + GtkWidget *mdialog; + gint res; + + mdialog = gtk_message_dialog_new(GTK_WINDOW(edit_win), + GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_MESSAGE_QUESTION, + GTK_BUTTONS_YES_NO, + _("Message was modified.\nDiscard Changes?")); + gtk_widget_show_all (mdialog); + + res=gtk_dialog_run(GTK_DIALOG(mdialog)); + gtk_widget_destroy (mdialog); + if (res == GTK_RESPONSE_YES) + return TRUE; + else + return FALSE; +} + +static void +close_edit_window (GtkWidget *win, GdkEvent *event, gpointer data) +{ + ModestEditorWindow *edit_win; + ModestUIPrivate *priv; + EditWinData *win_data; + + edit_win = (ModestEditorWindow *)data; + win_data = modest_editor_window_get_data(edit_win); + priv = MODEST_UI_GET_PRIVATE(win_data->modest_ui); + + // g_message("window was %s modified", modest_editor_window_get_modified(edit_win) ? "" : "not"); + + if (modest_editor_window_get_modified(edit_win)) { + if (close_edit_confirm_dialog(edit_win)) { + gtk_widget_hide (GTK_WIDGET(edit_win)); + modest_window_mgr_unregister(priv->modest_window_mgr, G_OBJECT(edit_win)); + gtk_widget_destroy(GTK_WIDGET(edit_win)); + g_message("closing window"); + } else { + g_message("not closing window"); + } + } +} + + +GtkContainer +*modest_ui_new_editor_window (ModestUI *modest_ui, gpointer *user_data) +{ + GtkWidget *top_container; + + GladeXML *glade_xml; + EditWinData *win_data; + + glade_xml = glade_xml_new(MODEST_GLADE, "new_mail_top_container", NULL); + if (!glade_xml) + return NULL; + + win_data = g_malloc(sizeof(EditWinData)); + win_data->modest_ui = modest_ui; + win_data->glade_xml = glade_xml; + *user_data = win_data; + + top_container = glade_xml_get_widget(glade_xml, "new_mail_top_container"); + if (!top_container) { + g_object_unref(G_OBJECT(glade_xml)); + return NULL; + } + + win_data->attachments = NULL; /* redundant */ + + return GTK_CONTAINER(top_container); +} + + +gboolean +modest_ui_editor_window_set_to_header(const gchar *to, gpointer window_data) +{ + GladeXML *glade_xml; + GtkWidget *w; + EditWinData *win_data; + + win_data = (EditWinData *)window_data; + glade_xml = win_data->glade_xml; + w = glade_xml_get_widget(glade_xml, "to_entry"); + gtk_entry_set_text(GTK_ENTRY(w), to); + + return TRUE; +} + + +gboolean +modest_ui_editor_window_set_cc_header(const gchar *cc, gpointer window_data) +{ + GladeXML *glade_xml; + // GtkWidget *w; + EditWinData *win_data; + + win_data = (EditWinData *)window_data; + glade_xml = win_data->glade_xml; +/* + w = glade_xml_get_widget(glade_xml, "cc_entry"); + gtk_entry_set_text(GTK_ENTRY(w), cc); +*/ + return TRUE; +} + + +gboolean +modest_ui_editor_window_set_bcc_header(const gchar *bcc, gpointer window_data) +{ + GladeXML *glade_xml; + // GtkWidget *w; + EditWinData *win_data; + + win_data = (EditWinData *)window_data; + glade_xml = win_data->glade_xml; +/* + w = glade_xml_get_widget(glade_xml, "bcc_entry"); + gtk_entry_set_text(GTK_ENTRY(w), bcc); +*/ + return TRUE; +} + + +gboolean +modest_ui_editor_window_set_subject_header(const gchar *subject, gpointer window_data) +{ + GladeXML *glade_xml; + GtkWidget *w; + EditWinData *win_data; + + win_data = (EditWinData *)window_data; + glade_xml = win_data->glade_xml; + + w = glade_xml_get_widget(glade_xml, "subject_entry"); + gtk_entry_set_text(GTK_ENTRY(w), subject); + + return TRUE; +} + + +gboolean +modest_ui_editor_window_set_body(const gchar *body, gpointer window_data) +{ + GladeXML *glade_xml; + GtkWidget *body_view; + GtkTextBuffer *buf; + EditWinData *win_data; + + win_data = (EditWinData *)window_data; + glade_xml = win_data->glade_xml; + + body_view = glade_xml_get_widget(glade_xml, "body_view"); + buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(body_view)); + + gtk_text_buffer_set_text(GTK_TEXT_BUFFER(buf), body, -1); + + return TRUE; +} + + +gboolean +modest_ui_editor_window_update_attachments(gpointer window_data) +{ + GladeXML *glade_xml; + + glade_xml = ((EditWinData *) window_data)->glade_xml; + + //body_view = glade_xml_get_widget(glade_xml, "body_view"); + + return TRUE; +} + + +static void on_editor_entry_changed(GtkEditable *editable, + gpointer user_data) +{ + GtkWidget *edit_win; + EditWinData *windata; + + edit_win = (GtkWidget *)user_data; + windata = (EditWinData *)modest_editor_window_get_data(MODEST_EDITOR_WINDOW(edit_win)); + + modest_editor_window_set_modified(MODEST_EDITOR_WINDOW(edit_win), TRUE); +} + + +static void on_editor_buffer_changed (GtkTextBuffer *textbuffer, + gpointer user_data) +{ + GtkWidget *edit_win; + + edit_win = (GtkWidget *)user_data; + modest_editor_window_set_modified(MODEST_EDITOR_WINDOW(edit_win), TRUE); +} + + +static void +new_editor_with_presets (ModestUI *modest_ui, const gchar *to_header, + const gchar *cc_header, const gchar *bcc_header, + const gchar *subject_header, const gchar *body) +{ + GtkWidget *edit_win; + GladeXML *glade_xml; + GtkWidget *btn, *w; + GtkTextBuffer *buf; + EditWinData *windata; + ModestUIPrivate *priv; + gint height, width; + + g_return_if_fail (modest_ui); + + edit_win = modest_editor_window_new(modest_ui); + windata = (EditWinData *)modest_editor_window_get_data(MODEST_EDITOR_WINDOW(edit_win)); + g_return_if_fail(windata); + + glade_xml = windata->glade_xml; + btn = glade_xml_get_widget (glade_xml, "toolb_send"); + g_signal_connect (btn, "clicked", G_CALLBACK(on_send_button_clicked), + edit_win); + btn = glade_xml_get_widget (glade_xml, "toolb_attach"); + g_signal_connect (btn, "clicked", G_CALLBACK(on_attach_button_clicked), + edit_win); + + w = glade_xml_get_widget (glade_xml, "to_entry"); + g_signal_connect(w, "changed", G_CALLBACK(on_editor_entry_changed), edit_win); + w = glade_xml_get_widget (glade_xml, "subject_entry"); + g_signal_connect(w, "changed", G_CALLBACK(on_editor_entry_changed), edit_win); + w = glade_xml_get_widget (glade_xml, "body_view"); + buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(w)); + g_signal_connect(buf, "changed", G_CALLBACK(on_editor_buffer_changed), edit_win); + + g_signal_connect (edit_win, "destroy-event", G_CALLBACK(close_edit_window), + edit_win); + g_signal_connect (edit_win, "delete-event", G_CALLBACK(close_edit_window), + edit_win); + + priv = MODEST_UI_GET_PRIVATE(windata->modest_ui); + height = modest_conf_get_int (priv->modest_conf, + MODEST_CONF_EDIT_WINDOW_HEIGHT, NULL); + width = modest_conf_get_int (priv->modest_conf, + MODEST_CONF_EDIT_WINDOW_WIDTH, NULL); + + // g_message("new editor win@%dx%d", width, height); + + gtk_widget_set_usize (GTK_WIDGET(edit_win), width, height); + if (strlen(subject_header) > 0) + gtk_window_set_title (GTK_WINDOW(edit_win), subject_header); + else + gtk_window_set_title (GTK_WINDOW(edit_win), _("Untitled")); + modest_window_mgr_register(priv->modest_window_mgr, G_OBJECT(edit_win), MODEST_EDIT_WINDOW, 0); + + modest_editor_window_set_to_header(MODEST_EDITOR_WINDOW(edit_win), to_header); + modest_editor_window_set_cc_header(MODEST_EDITOR_WINDOW(edit_win), cc_header); + modest_editor_window_set_bcc_header(MODEST_EDITOR_WINDOW(edit_win), bcc_header); + modest_editor_window_set_subject_header(MODEST_EDITOR_WINDOW(edit_win), subject_header); + modest_editor_window_set_body(MODEST_EDITOR_WINDOW(edit_win), body); + + modest_editor_window_set_modified(MODEST_EDITOR_WINDOW(edit_win), FALSE); + + gtk_widget_show(edit_win); +} + +#if 1 +void +on_new_mail_clicked (GtkWidget *widget, ModestUI *modest_ui) +{ + new_editor_with_presets(modest_ui, "", "", "", "", ""); +} +#else +void +on_new_mail_clicked (GtkWidget *widget, ModestUI *modest_ui) +{ + GtkWidget *edit_win; + GladeXML *glade_xml; + GtkWidget *btn, *w; + GtkTextBuffer *buf; + EditWinData *windata; + ModestUIPrivate *priv; + gint height, width; + + g_return_if_fail (modest_ui); + //modest_ui_new_edit_window (modest_ui, "", "", "", "", "", NULL); + + edit_win = modest_editor_window_new(modest_ui); + windata = (EditWinData *)modest_editor_window_get_data(MODEST_EDITOR_WINDOW(edit_win)); + g_return_if_fail(windata); + + windata->edit_win = MODEST_EDITOR_WINDOW(edit_win); + glade_xml = windata->glade_xml; + btn = glade_xml_get_widget (glade_xml, "toolb_send"); + g_signal_connect (btn, "clicked", G_CALLBACK(on_send_button_clicked), + edit_win); + btn = glade_xml_get_widget (glade_xml, "toolb_attach"); + g_signal_connect (btn, "clicked", G_CALLBACK(on_attach_button_clicked), + edit_win); + + w = glade_xml_get_widget (glade_xml, "to_entry"); + g_signal_connect(w, "changed", G_CALLBACK(on_editor_entry_changed), edit_win); + w = glade_xml_get_widget (glade_xml, "subject_entry"); + g_signal_connect(w, "changed", G_CALLBACK(on_editor_entry_changed), edit_win); + w = glade_xml_get_widget (glade_xml, "body_view"); + buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(w)); + gtk_text_buffer_set_text(buf, "", -1); + g_signal_connect(buf, "changed", G_CALLBACK(on_editor_buffer_changed), edit_win); + + g_signal_connect (edit_win, "destroy-event", G_CALLBACK(close_edit_window), + edit_win); + g_signal_connect (edit_win, "delete-event", G_CALLBACK(close_edit_window), + edit_win); + + priv = MODEST_UI_GET_PRIVATE(windata->modest_ui); + height = modest_conf_get_int (priv->modest_conf, + MODEST_CONF_EDIT_WINDOW_HEIGHT, NULL); + width = modest_conf_get_int (priv->modest_conf, + MODEST_CONF_EDIT_WINDOW_WIDTH, NULL); + + // g_message("new editor win@%dx%d", width, height); + + gtk_widget_set_usize (GTK_WIDGET(edit_win), width, height); + gtk_window_set_title (GTK_WINDOW(edit_win), _("Untitled")); + modest_window_mgr_register(priv->modest_window_mgr, G_OBJECT(edit_win), MODEST_EDIT_WINDOW, 0); + gtk_widget_show(edit_win); +} +#endif + +void +quoted_send_msg (ModestUI *modest_ui, quoted_send_type qstype) +{ + GtkTreeSelection *sel; + GtkWidget *paned; + GtkTreeModel *model; + GtkTreeIter iter; + GtkScrolledWindow *scroll; + + TnyMsgHeaderIface *header; + + ModestTnyHeaderTreeView *header_view; + ModestTnyMsgView *msg_view; + ModestUIPrivate *priv; + + const TnyMsgIface *msg; + const TnyMsgFolderIface *folder; + GString *re_sub; + const gchar *subject, *from; + gchar *unquoted, *quoted; + time_t sent_date; + gint line_limit = 76; + + 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); + + if (!gtk_tree_selection_get_selected (sel, &model, &iter)) { + g_warning("nothing to reply to"); + return; + } + + gtk_tree_model_get (model, &iter, + TNY_MSG_HEADER_LIST_MODEL_INSTANCE_COLUMN, + &header, -1); + + 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); + /* 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); + + switch (qstype) { + case QUOTED_SEND_REPLY: + g_string_prepend(re_sub, _("Re: ")); + new_editor_with_presets(modest_ui, from, /* cc */ "", /* bcc */ "", re_sub->str, quoted); + break; + case QUOTED_SEND_FORWARD: + g_string_prepend(re_sub, _("Fwd: ")); + new_editor_with_presets(modest_ui, /* from */ "", /* cc */ "", /* bcc */ "", re_sub->str, quoted); + break; + default: + break; + } + g_free(quoted); + g_free(unquoted); + g_string_free(re_sub, TRUE); +} + + +static void +on_attach_button_clicked (GtkWidget *widget, ModestEditorWindow *modest_editwin) +{ + /* open file selector */ + GtkWidget *dialog; + gchar *mime_type; + gchar *filename = NULL; + + dialog = gtk_file_chooser_dialog_new ("Open File", + GTK_WINDOW(modest_editwin), + GTK_FILE_CHOOSER_ACTION_OPEN, + GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, + GTK_STOCK_OPEN, GTK_RESPONSE_ACCEPT, + NULL); + + if (gtk_dialog_run (GTK_DIALOG (dialog)) == GTK_RESPONSE_ACCEPT) + { + + filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dialog)); + printf ("file:%s\n", filename); + } + gtk_widget_destroy (dialog); + + /* check file */ + if (!filename) + return; + + g_return_if_fail(g_str_has_suffix(filename, ".jpg")); /* for now... */ + + /* get mime type */ + mime_type = "image/jpeg"; + + /* attach file */ + + modest_editor_window_attach_file(modest_editwin, filename); + + g_free (filename); +} + + +static void +on_send_button_clicked (GtkWidget *widget, ModestEditorWindow *modest_editwin) +{ + ModestTnyTransportActions *actions; + ModestUI *modest_ui; + 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; + ModestIdentityMgr *id_mgr; + EditWinData *win_data; + GList * attachments; + + + win_data = modest_editor_window_get_data(modest_editwin); + modest_ui = win_data->modest_ui; + + 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 (win_data->glade_xml, "to_entry"); + subject_entry = glade_xml_get_widget (win_data->glade_xml, "subject_entry"); + body_view = glade_xml_get_widget (win_data->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); + attachments = modest_editor_window_get_attachments(modest_editwin); + /* while (attachments) { + printf("att: %s\n", (gchar *) attachments->data); + attachments = attachments->next; + } */ + if (!email_from) + email_from = ""; + + g_message("sending \"%s\" %s ==> %s", subject, email_from, to); + + modest_tny_transport_actions_send_message (actions, + transport_account, + email_from, + to, "", "", subject, + body, + attachments); + + g_free (body); + g_object_unref (G_OBJECT(actions)); + + gtk_widget_hide (GTK_WIDGET(modest_editwin)); + modest_window_mgr_unregister(priv->modest_window_mgr, G_OBJECT(modest_editwin)); + if (GTK_IS_WIDGET(modest_editwin)) { + gtk_widget_destroy(GTK_WIDGET(modest_editwin)); + } else + g_warning("editor window has vanished!"); +} diff --git a/src/gtk-glade/modest-ui-message-editor.h b/src/gtk-glade/modest-ui-message-editor.h new file mode 100644 index 0000000..695f1b9 --- /dev/null +++ b/src/gtk-glade/modest-ui-message-editor.h @@ -0,0 +1,15 @@ +#ifndef _MODEST_UI_MESSAGE_EDITOR_H +#define _MODEST_UI_MESSAGE_EDITOR_H + +typedef enum { + QUOTED_SEND_REPLY, + QUOTED_SEND_REPLY_ALL, + QUOTED_SEND_FORWARD +} quoted_send_type; + + +void quoted_send_msg (ModestUI *modest_ui, quoted_send_type qstype); + +void on_new_mail_clicked (GtkWidget *widget, ModestUI *modest_ui); + +#endif /* _MODEST_UI_MESSAGE_EDITOR_H */ diff --git a/src/gtk-glade/modest-ui-message-viewer.c b/src/gtk-glade/modest-ui-message-viewer.c new file mode 100644 index 0000000..7a19b73 --- /dev/null +++ b/src/gtk-glade/modest-ui-message-viewer.c @@ -0,0 +1,33 @@ +#include +#include +#include +#include + +#ifdef HAVE_CONFIG_H +#include +#endif /*HAVE_CONFIG_H*/ + +/* 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" +#include "../modest-tny-folder-tree-view.h" +#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" + +#include "../modest-editor-window.h" + +#include "modest-ui-glade.h" +#include "modest-ui-wizard.h" diff --git a/src/gtk-glade/modest-ui-message-viewer.h b/src/gtk-glade/modest-ui-message-viewer.h new file mode 100644 index 0000000..e69de29 diff --git a/src/gtk-glade/modest-ui.c b/src/gtk-glade/modest-ui.c index cfbbc63..a181921 100644 --- a/src/gtk-glade/modest-ui.c +++ b/src/gtk-glade/modest-ui.c @@ -41,63 +41,15 @@ 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, GdkEvent *event, gpointer data); -static void modest_ui_last_window_closed (GObject *obj, gpointer data); +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_password_requested (ModestTnyAccountStore *account_store, const gchar *account_name, gpointer user_data); -static GtkWidget* modest_main_window_folder_tree (ModestAccountMgr *modest_acc_mgr, - TnyAccountStoreIface *account_store); -static GtkWidget* modest_main_window_header_tree (TnyMsgFolderIface *folder); //static 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 on_forward_clicked (GtkWidget *widget, ModestUI *modest_ui); - -static void on_delete_clicked (GtkWidget *widget, ModestUI *modest_ui); - -static void on_view_attachments_toggled(GtkWidget *widget, ModestUI *modest_ui); - -static void on_attach_button_clicked (GtkWidget *widget, ModestEditorWindow *modest_editwin); - -#if 1 -static void on_send_button_clicked (GtkWidget *widget, ModestEditorWindow *modest_editwin); -#else -static void on_send_button_clicked (GtkWidget *widget, ModestUI *modest_ui); -#endif - -static void on_sendreceive_button_clicked (GtkWidget *widget, ModestUI *modest_ui); - -static void register_toolbar_callbacks (ModestUI *modest_ui); - -typedef enum { - QUOTED_SEND_REPLY, - QUOTED_SEND_REPLY_ALL, - QUOTED_SEND_FORWARD -} quoted_send_type; - -static void quoted_send_msg (ModestUI *modest_ui, quoted_send_type qstype); - - -typedef struct { - ModestUI *modest_ui; - ModestEditorWindow *edit_win; - GladeXML *glade_xml; - GList *attachments; -} EditWinData; - /* list my signals */ enum { @@ -109,8 +61,6 @@ enum { /* 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) @@ -211,16 +161,14 @@ modest_ui_new (ModestConf *modest_conf) 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); @@ -271,468 +219,63 @@ modest_ui_new (ModestConf *modest_conf) } -gboolean -modest_ui_show_main_window (ModestUI *modest_ui) -{ - GtkWidget *win; - gint height, width; - ModestUIPrivate *priv; - GtkWidget *folder_view, *header_view; - GtkWidget *message_view; - GtkWidget *account_settings_item; - GtkWidget *delete_item; - GtkWidget *view_attachments_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)); - priv->folder_view = folder_view; - 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)); - priv->header_view = header_view; - 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, priv->modest_conf)); - 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, "AccountSettingsMenuItem"); - 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); - */ - -// new_account_item = glade_xml_get_widget (priv->glade_xml, "NewAccountWizardMenuItem"); -// if (!new_account_item) -// { -// g_warning ("The new account item isn't available!\n"); -// return FALSE; -// } - -// g_signal_connect (new_account_item, "activate", -// G_CALLBACK(new_wizard_account), -// modest_ui); -// - delete_item = glade_xml_get_widget (priv->glade_xml, "delete1"); - if (!delete_item) - { - g_warning ("The delete item isn't available!\n"); - return FALSE; - } - - g_signal_connect (delete_item, "activate", G_CALLBACK(on_delete_clicked), - modest_ui); - - view_attachments_item = glade_xml_get_widget (priv->glade_xml, "menu_view_attachments"); - if (!view_attachments_item) - { - g_warning ("The view_attachments_item isn't available!"); - return FALSE; - } - - gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(view_attachments_item), - modest_conf_get_bool(priv->modest_conf, - MODEST_CONF_MSG_VIEW_SHOW_ATTACHMENTS_INLINE, - NULL) - ); - - g_signal_connect (view_attachments_item, - "toggled", - G_CALLBACK(on_view_attachments_toggled), - 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-event", G_CALLBACK(modest_ui_window_destroy), - modest_ui); - g_signal_connect (win, "delete-event", G_CALLBACK(modest_ui_window_destroy), - modest_ui); - gtk_widget_set_usize (GTK_WIDGET(win), width, height); - 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); - gtk_widget_set_sensitive(button, FALSE); - } - - button = glade_xml_get_widget (priv->glade_xml, "toolb_reply_all"); - if (button) { - //g_signal_connect (button, "clicked", - // G_CALLBACK(on_reply_all_clicked), modest_ui); - gtk_widget_set_sensitive(button, FALSE); - } - - button = glade_xml_get_widget (priv->glade_xml, "toolb_forward"); - if (button) { - g_signal_connect (button, "clicked", - G_CALLBACK(on_forward_clicked), modest_ui); - gtk_widget_set_sensitive(button, FALSE); - } - - button = glade_xml_get_widget (priv->glade_xml, "toolb_move_to"); - if (button) { - //g_signal_connect (button, "clicked", - // G_CALLBACK(on_move_to_clicked), modest_ui); - gtk_widget_set_sensitive(button, FALSE); - } - - button = glade_xml_get_widget (priv->glade_xml, "toolb_delete"); - if (button) { - g_signal_connect (button, "clicked", - G_CALLBACK(on_delete_clicked), modest_ui); - gtk_widget_set_sensitive(button, FALSE); - } - - button = glade_xml_get_widget (priv->glade_xml, "toolb_send_receive"); - if (button) { - g_signal_connect (button, "clicked", - G_CALLBACK(on_sendreceive_button_clicked), modest_ui); - gtk_widget_set_sensitive(button, TRUE); - } -} - -#if 0 static void -hide_edit_window (GtkWidget *win, GdkEvent *event, gpointer data) +modest_ui_last_window_closed (GObject *obj, gpointer data) { - ModestUIPrivate *priv; - - priv = MODEST_UI_GET_PRIVATE(data); - gtk_widget_hide (win); - modest_window_mgr_unregister(priv->modest_window_mgr, G_OBJECT(win)); + /* FIXME: Other cleanups todo? Finalize Tinymail? */ + gtk_main_quit (); } -#endif -static gboolean close_edit_confirm_dialog(ModestEditorWindow *edit_win) -{ - GtkWidget *mdialog; - gint res; - - mdialog = gtk_message_dialog_new(GTK_WINDOW(edit_win), - GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, - GTK_MESSAGE_QUESTION, - GTK_BUTTONS_YES_NO, - _("Message was modified.\nDiscard Changes?")); - gtk_widget_show_all (mdialog); - - res=gtk_dialog_run(GTK_DIALOG(mdialog)); - gtk_widget_destroy (mdialog); - if (res == GTK_RESPONSE_YES) - return TRUE; - else - return FALSE; -} - static void -close_edit_window (GtkWidget *win, GdkEvent *event, gpointer data) -{ - ModestEditorWindow *edit_win; - ModestUIPrivate *priv; - EditWinData *win_data; - - edit_win = (ModestEditorWindow *)data; - win_data = modest_editor_window_get_data(edit_win); - priv = MODEST_UI_GET_PRIVATE(win_data->modest_ui); - - // g_message("window was %s modified", modest_editor_window_get_modified(edit_win) ? "" : "not"); - - if (modest_editor_window_get_modified(edit_win)) { - if (close_edit_confirm_dialog(edit_win)) { - gtk_widget_hide (GTK_WIDGET(edit_win)); - modest_window_mgr_unregister(priv->modest_window_mgr, G_OBJECT(edit_win)); - gtk_widget_destroy(GTK_WIDGET(edit_win)); - g_message("closing window"); - } else { - g_message("not closing window"); - } - } -} - - -GtkContainer -*modest_ui_new_editor_window (ModestUI *modest_ui, gpointer *user_data) -{ - GtkWidget *top_container; - - GladeXML *glade_xml; - EditWinData *win_data; - - glade_xml = glade_xml_new(MODEST_GLADE, "new_mail_top_container", NULL); - if (!glade_xml) - return NULL; - - win_data = g_malloc(sizeof(EditWinData)); - win_data->modest_ui = modest_ui; - win_data->glade_xml = glade_xml; - *user_data = win_data; - - top_container = glade_xml_get_widget(glade_xml, "new_mail_top_container"); - if (!top_container) { - g_object_unref(G_OBJECT(glade_xml)); - return NULL; - } - - win_data->attachments = NULL; /* redundant */ - - return GTK_CONTAINER(top_container); -} - - -gboolean -modest_ui_editor_window_set_to_header(const gchar *to, gpointer window_data) -{ - GladeXML *glade_xml; - GtkWidget *w; - EditWinData *win_data; - - win_data = (EditWinData *)window_data; - glade_xml = win_data->glade_xml; - w = glade_xml_get_widget(glade_xml, "to_entry"); - gtk_entry_set_text(GTK_ENTRY(w), to); - - return TRUE; -} - - -gboolean -modest_ui_editor_window_set_cc_header(const gchar *cc, gpointer window_data) -{ - GladeXML *glade_xml; - // GtkWidget *w; - EditWinData *win_data; - - win_data = (EditWinData *)window_data; - glade_xml = win_data->glade_xml; -/* - w = glade_xml_get_widget(glade_xml, "cc_entry"); - gtk_entry_set_text(GTK_ENTRY(w), cc); -*/ - return TRUE; -} - - -gboolean -modest_ui_editor_window_set_bcc_header(const gchar *bcc, gpointer window_data) -{ - GladeXML *glade_xml; - // GtkWidget *w; - EditWinData *win_data; - - win_data = (EditWinData *)window_data; - glade_xml = win_data->glade_xml; -/* - w = glade_xml_get_widget(glade_xml, "bcc_entry"); - gtk_entry_set_text(GTK_ENTRY(w), bcc); -*/ - return TRUE; -} - - -gboolean -modest_ui_editor_window_set_subject_header(const gchar *subject, gpointer window_data) -{ - GladeXML *glade_xml; - GtkWidget *w; - EditWinData *win_data; - - win_data = (EditWinData *)window_data; - glade_xml = win_data->glade_xml; - - w = glade_xml_get_widget(glade_xml, "subject_entry"); - gtk_entry_set_text(GTK_ENTRY(w), subject); - - return TRUE; -} - - -gboolean -modest_ui_editor_window_set_body(const gchar *body, gpointer window_data) +on_password_requested (ModestTnyAccountStore *account_store, + const gchar *account_name, gpointer user_data) { - GladeXML *glade_xml; - GtkWidget *body_view; - GtkTextBuffer *buf; - EditWinData *win_data; - - win_data = (EditWinData *)window_data; - glade_xml = win_data->glade_xml; - - body_view = glade_xml_get_widget(glade_xml, "body_view"); - buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(body_view)); - - gtk_text_buffer_set_text(GTK_TEXT_BUFFER(buf), body, -1); - - return TRUE; -} - -gboolean -modest_ui_editor_window_update_attachments(gpointer window_data) -{ - GladeXML *glade_xml; - - glade_xml = ((EditWinData *) window_data)->glade_xml; + GtkWidget *passdialog; + GtkWidget *vbox; + GtkWidget *infolabel; + GtkWidget *passentry; + gint retval; + const gchar *infostring=g_strconcat("Please enter the password for ", account_name, ".", NULL); - //body_view = glade_xml_get_widget(glade_xml, "body_view"); - - return TRUE; -} -#if 0 -gboolean -modest_ui_new_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; + passdialog = gtk_dialog_new_with_buttons("MyDialog", + NULL, + GTK_DIALOG_MODAL|GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_STOCK_OK, + GTK_RESPONSE_ACCEPT, + GTK_STOCK_CANCEL, + GTK_RESPONSE_REJECT, + NULL); - 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; - } + vbox=gtk_vbox_new(FALSE, 0); - /* FIXME: this also assumes that there can be only one edit window! */ - if (!modest_window_mgr_find_by_type(priv->modest_window_mgr, MODEST_EDIT_WINDOW)) { - /* there already is one edit win, maybe we should preserver its contents */ - modest_window_mgr_register (priv->modest_window_mgr, - G_OBJECT(win), MODEST_EDIT_WINDOW, 0); - } + infolabel=gtk_label_new(infostring); + passentry=gtk_entry_new(); - 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_box_pack_start(GTK_BOX(GTK_DIALOG(passdialog)->vbox), infolabel, FALSE, FALSE, 0); + gtk_box_pack_start(GTK_BOX(GTK_DIALOG(passdialog)->vbox), passentry, FALSE, FALSE, 0); + gtk_widget_show_all(passdialog); - gtk_entry_set_text(GTK_ENTRY(subject_entry), subject); - gtk_entry_set_text(GTK_ENTRY(to_entry), to); + retval = gtk_dialog_run (GTK_DIALOG(passdialog)); - 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); + switch (retval) + { + 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); + break; + case GTK_RESPONSE_CANCEL: + /* FIXME: + * What happens, if canceled?" + */ + break; } - g_signal_connect (win, "destroy-event", G_CALLBACK(hide_edit_window), - modest_ui); - g_signal_connect (win, "delete-event", G_CALLBACK(hide_edit_window), - modest_ui); - - 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; -} -#endif - -static void -modest_ui_window_destroy (GtkWidget *win, GdkEvent *event, gpointer data) -{ - ModestUIPrivate *priv; - - g_return_if_fail (data); - g_return_if_fail(MODEST_IS_UI(data)); - priv = MODEST_UI_GET_PRIVATE((ModestUI *)data); - g_return_if_fail(priv); - if (!modest_window_mgr_unregister (priv->modest_window_mgr, G_OBJECT(win))) - g_warning ("modest window mgr: failed to unregister %p", - G_OBJECT(win)); - else - gtk_widget_hide(win); -} - - -static void -modest_ui_last_window_closed (GObject *obj, gpointer data) -{ - /* FIXME: Other cleanups todo? Finalize Tinymail? */ - gtk_main_quit (); + gtk_widget_destroy (passdialog); } @@ -826,661 +369,3 @@ on_account_settings1_activate (GtkMenuItem *menuitem, g_object_unref(glade_xml); } #endif - - -static void -on_folder_clicked (ModestTnyFolderTreeView *folder_tree, - TnyMsgFolderIface *folder, - gpointer data) -{ - GtkWidget *win; - GtkWidget *button; - GtkWidget *paned; - ModestTnyHeaderTreeView *tree_view; - ModestTnyMsgView *msg_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); - - button = glade_xml_get_widget (priv->glade_xml, "toolb_reply"); - if (button) { - gtk_widget_set_sensitive(button, FALSE); - } - - button = glade_xml_get_widget (priv->glade_xml, "toolb_forward"); - if (button) { - gtk_widget_set_sensitive(button, FALSE); - } - - button = glade_xml_get_widget (priv->glade_xml, "toolb_delete"); - if (button) { - gtk_widget_set_sensitive(button, FALSE); - } - - paned = glade_xml_get_widget (priv->glade_xml,"mail_paned"); - g_return_if_fail (paned); - - msg_view = MODEST_TNY_MSG_VIEW(gtk_paned_get_child2 (GTK_PANED(paned))); - g_return_if_fail (msg_view); - - modest_tny_msg_view_set_message (msg_view, NULL); -} - - -static void -on_message_clicked (ModestTnyFolderTreeView *folder_tree, - TnyMsgIface *message, - gpointer data) -{ - GtkWidget *paned; - GtkWidget *button; - 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); - button = glade_xml_get_widget (priv->glade_xml, "toolb_reply"); - if (button) { - gtk_widget_set_sensitive(button, TRUE); - } - button = glade_xml_get_widget (priv->glade_xml, "toolb_forward"); - if (button) { - gtk_widget_set_sensitive(button, TRUE); - } - button = glade_xml_get_widget (priv->glade_xml, "toolb_delete"); - if (button) { - gtk_widget_set_sensitive(button, TRUE); - } -} - - -static void -on_password_requested (ModestTnyAccountStore *account_store, - const gchar *account_name, gpointer user_data) -{ - - GtkWidget *passdialog; - GtkWidget *vbox; - GtkWidget *infolabel; - GtkWidget *passentry; - gint retval; - const gchar *infostring=g_strconcat("Please enter the password for ", account_name, ".", NULL); - - passdialog = gtk_dialog_new_with_buttons("MyDialog", - NULL, - GTK_DIALOG_MODAL|GTK_DIALOG_DESTROY_WITH_PARENT, - GTK_STOCK_OK, - GTK_RESPONSE_ACCEPT, - GTK_STOCK_CANCEL, - GTK_RESPONSE_REJECT, - NULL); - - vbox=gtk_vbox_new(FALSE, 0); - - infolabel=gtk_label_new(infostring); - passentry=gtk_entry_new(); - - gtk_box_pack_start(GTK_BOX(GTK_DIALOG(passdialog)->vbox), infolabel, 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)); - - switch (retval) - { - 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); - break; - case GTK_RESPONSE_CANCEL: - /* FIXME: - * What happens, if canceled?" - */ - 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_FROM, - MODEST_TNY_HEADER_TREE_VIEW_COLUMN_SUBJECT, - MODEST_TNY_HEADER_TREE_VIEW_COLUMN_RECEIVED_DATE - }; - - 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; - } - - return GTK_WIDGET(header_tree); -} - - -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_editor_entry_changed(GtkEditable *editable, - gpointer user_data) -{ - GtkWidget *edit_win; - EditWinData *windata; - - edit_win = (GtkWidget *)user_data; - windata = (EditWinData *)modest_editor_window_get_data(MODEST_EDITOR_WINDOW(edit_win)); - - modest_editor_window_set_modified(MODEST_EDITOR_WINDOW(edit_win), TRUE); -} - -static void on_editor_buffer_changed (GtkTextBuffer *textbuffer, - gpointer user_data) -{ - GtkWidget *edit_win; - - edit_win = (GtkWidget *)user_data; - modest_editor_window_set_modified(MODEST_EDITOR_WINDOW(edit_win), TRUE); -} - -static void -on_new_mail_clicked (GtkWidget *widget, ModestUI *modest_ui) -{ - GtkWidget *edit_win; - GladeXML *glade_xml; - GtkWidget *btn, *w; - GtkTextBuffer *buf; - EditWinData *windata; - ModestUIPrivate *priv; - gint height, width; - - g_return_if_fail (modest_ui); - //modest_ui_new_edit_window (modest_ui, "", "", "", "", "", NULL); - - edit_win = modest_editor_window_new(modest_ui); - windata = (EditWinData *)modest_editor_window_get_data(MODEST_EDITOR_WINDOW(edit_win)); - g_return_if_fail(windata); - - windata->edit_win = MODEST_EDITOR_WINDOW(edit_win); - glade_xml = windata->glade_xml; - btn = glade_xml_get_widget (glade_xml, "toolb_send"); - g_signal_connect (btn, "clicked", G_CALLBACK(on_send_button_clicked), - edit_win); - btn = glade_xml_get_widget (glade_xml, "toolb_attach"); - g_signal_connect (btn, "clicked", G_CALLBACK(on_attach_button_clicked), - edit_win); - - w = glade_xml_get_widget (glade_xml, "to_entry"); - g_signal_connect(w, "changed", G_CALLBACK(on_editor_entry_changed), edit_win); - w = glade_xml_get_widget (glade_xml, "subject_entry"); - g_signal_connect(w, "changed", G_CALLBACK(on_editor_entry_changed), edit_win); - w = glade_xml_get_widget (glade_xml, "body_view"); - buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(w)); - gtk_text_buffer_set_text(buf, "", -1); - g_signal_connect(buf, "changed", G_CALLBACK(on_editor_buffer_changed), edit_win); - - g_signal_connect (edit_win, "destroy-event", G_CALLBACK(close_edit_window), - edit_win); - g_signal_connect (edit_win, "delete-event", G_CALLBACK(close_edit_window), - edit_win); - - priv = MODEST_UI_GET_PRIVATE(windata->modest_ui); - height = modest_conf_get_int (priv->modest_conf, - MODEST_CONF_EDIT_WINDOW_HEIGHT, NULL); - width = modest_conf_get_int (priv->modest_conf, - MODEST_CONF_EDIT_WINDOW_WIDTH, NULL); - - // g_message("new editor win@%dx%d", width, height); - - gtk_widget_set_usize (GTK_WIDGET(edit_win), width, height); - gtk_window_set_title (GTK_WINDOW(edit_win), _("Untitled")); - modest_window_mgr_register(priv->modest_window_mgr, G_OBJECT(edit_win), MODEST_EDIT_WINDOW, 0); - gtk_widget_show(edit_win); -} - - -static void -new_editor_with_presets (ModestUI *modest_ui, const gchar *to_header, - const gchar *cc_header, const gchar *bcc_header, - const gchar *subject_header, const gchar *body) -{ - GtkWidget *edit_win; - GladeXML *glade_xml; - GtkWidget *btn, *w; - GtkTextBuffer *buf; - EditWinData *windata; - ModestUIPrivate *priv; - gint height, width; - - g_return_if_fail (modest_ui); - - edit_win = modest_editor_window_new(modest_ui); - windata = (EditWinData *)modest_editor_window_get_data(MODEST_EDITOR_WINDOW(edit_win)); - g_return_if_fail(windata); - - glade_xml = windata->glade_xml; - btn = glade_xml_get_widget (glade_xml, "toolb_send"); - g_signal_connect (btn, "clicked", G_CALLBACK(on_send_button_clicked), - edit_win); - btn = glade_xml_get_widget (glade_xml, "toolb_attach"); - g_signal_connect (btn, "clicked", G_CALLBACK(on_attach_button_clicked), - edit_win); - - w = glade_xml_get_widget (glade_xml, "to_entry"); - g_signal_connect(w, "changed", G_CALLBACK(on_editor_entry_changed), edit_win); - w = glade_xml_get_widget (glade_xml, "subject_entry"); - g_signal_connect(w, "changed", G_CALLBACK(on_editor_entry_changed), edit_win); - w = glade_xml_get_widget (glade_xml, "body_view"); - buf = gtk_text_view_get_buffer(GTK_TEXT_VIEW(w)); - g_signal_connect(buf, "changed", G_CALLBACK(on_editor_buffer_changed), edit_win); - - g_signal_connect (edit_win, "destroy-event", G_CALLBACK(close_edit_window), - edit_win); - g_signal_connect (edit_win, "delete-event", G_CALLBACK(close_edit_window), - edit_win); - - priv = MODEST_UI_GET_PRIVATE(windata->modest_ui); - height = modest_conf_get_int (priv->modest_conf, - MODEST_CONF_EDIT_WINDOW_HEIGHT, NULL); - width = modest_conf_get_int (priv->modest_conf, - MODEST_CONF_EDIT_WINDOW_WIDTH, NULL); - - // g_message("new editor win@%dx%d", width, height); - - gtk_widget_set_usize (GTK_WIDGET(edit_win), width, height); - gtk_window_set_title (GTK_WINDOW(edit_win), _("Untitled")); - modest_window_mgr_register(priv->modest_window_mgr, G_OBJECT(edit_win), MODEST_EDIT_WINDOW, 0); - - modest_editor_window_set_to_header(MODEST_EDITOR_WINDOW(edit_win), to_header); - modest_editor_window_set_cc_header(MODEST_EDITOR_WINDOW(edit_win), cc_header); - modest_editor_window_set_bcc_header(MODEST_EDITOR_WINDOW(edit_win), bcc_header); - modest_editor_window_set_subject_header(MODEST_EDITOR_WINDOW(edit_win), subject_header); - modest_editor_window_set_body(MODEST_EDITOR_WINDOW(edit_win), body); - - modest_editor_window_set_modified(MODEST_EDITOR_WINDOW(edit_win), FALSE); - - gtk_widget_show(edit_win); -} - - -static void -quoted_send_msg (ModestUI *modest_ui, quoted_send_type qstype) { - GtkTreeSelection *sel; - GtkWidget *paned; - GtkTreeModel *model; - GtkTreeIter iter; - GtkScrolledWindow *scroll; - - TnyMsgHeaderIface *header; - - ModestTnyHeaderTreeView *header_view; - ModestTnyMsgView *msg_view; - ModestUIPrivate *priv; - - const TnyMsgIface *msg; - const TnyMsgFolderIface *folder; - GString *re_sub; - const gchar *subject, *from; - gchar *unquoted, *quoted; - time_t sent_date; - gint line_limit = 76; - - 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); - - if (!gtk_tree_selection_get_selected (sel, &model, &iter)) { - g_warning("nothing to reply to"); - return; - } - - gtk_tree_model_get (model, &iter, - TNY_MSG_HEADER_LIST_MODEL_INSTANCE_COLUMN, - &header, -1); - - 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); - /* 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); - - switch (qstype) { - case QUOTED_SEND_REPLY: - g_string_prepend(re_sub, _("Re: ")); - new_editor_with_presets(modest_ui, from, /* cc */ "", /* bcc */ "", re_sub->str, quoted); - break; - case QUOTED_SEND_FORWARD: - g_string_prepend(re_sub, _("Fwd: ")); - new_editor_with_presets(modest_ui, /* from */ "", /* cc */ "", /* bcc */ "", re_sub->str, quoted); - break; - default: - break; - } - g_free(quoted); - g_free(unquoted); - g_string_free(re_sub, TRUE); -} - - -static void -on_reply_clicked (GtkWidget *widget, ModestUI *modest_ui) -{ - quoted_send_msg (modest_ui, QUOTED_SEND_REPLY); -} - - -static void -on_forward_clicked (GtkWidget *widget, ModestUI *modest_ui) -{ - quoted_send_msg (modest_ui, QUOTED_SEND_FORWARD); -} - - -static void -on_attach_button_clicked (GtkWidget *widget, ModestEditorWindow *modest_editwin) -{ - /* open file selector */ - GtkWidget *dialog; - gchar *mime_type; - gchar *filename = NULL; - - dialog = gtk_file_chooser_dialog_new ("Open File", - GTK_WINDOW(modest_editwin), - GTK_FILE_CHOOSER_ACTION_OPEN, - GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, - GTK_STOCK_OPEN, GTK_RESPONSE_ACCEPT, - NULL); - - if (gtk_dialog_run (GTK_DIALOG (dialog)) == GTK_RESPONSE_ACCEPT) - { - - filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dialog)); - printf ("file:%s\n", filename); - } - gtk_widget_destroy (dialog); - - /* check file */ - if (!filename) - return; - - g_return_if_fail(g_str_has_suffix(filename, ".jpg")); /* for now... */ - - /* get mime type */ - mime_type = "image/jpeg"; - - /* attach file */ - - modest_editor_window_attach_file(modest_editwin, filename); - - g_free (filename); -} - - -static void -on_send_button_clicked (GtkWidget *widget, ModestEditorWindow *modest_editwin) -{ - ModestTnyTransportActions *actions; - ModestUI *modest_ui; - 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; - ModestIdentityMgr *id_mgr; - EditWinData *win_data; - GList * attachments; - - - win_data = modest_editor_window_get_data(modest_editwin); - modest_ui = win_data->modest_ui; - - 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 (win_data->glade_xml, "to_entry"); - subject_entry = glade_xml_get_widget (win_data->glade_xml, "subject_entry"); - body_view = glade_xml_get_widget (win_data->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); - attachments = modest_editor_window_get_attachments(modest_editwin); - /* while (attachments) { - printf("att: %s\n", (gchar *) attachments->data); - attachments = attachments->next; - } */ - if (!email_from) - email_from = ""; - - g_message("sending \"%s\" %s ==> %s", subject, email_from, to); - - modest_tny_transport_actions_send_message (actions, - transport_account, - email_from, - to, "", "", subject, - body, - attachments); - - g_free (body); - g_object_unref (G_OBJECT(actions)); - - gtk_widget_hide (GTK_WIDGET(modest_editwin)); - modest_window_mgr_unregister(priv->modest_window_mgr, G_OBJECT(modest_editwin)); - if (GTK_IS_WIDGET(modest_editwin)) { - gtk_widget_destroy(GTK_WIDGET(modest_editwin)); - } else - g_warning("editor window has vanished!"); -} - -static void -on_view_attachments_toggled(GtkWidget *widget, ModestUI *modest_ui) -{ - GtkWidget *view_attachments_item, *paned; - ModestTnyMsgView *msg_view; - ModestUIPrivate *priv; - - priv = MODEST_UI_GET_PRIVATE(modest_ui); - view_attachments_item = glade_xml_get_widget (priv->glade_xml, "menu_view_attachments"); - g_return_if_fail(view_attachments_item); - - modest_conf_set_bool(priv->modest_conf, - MODEST_CONF_MSG_VIEW_SHOW_ATTACHMENTS_INLINE, - gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(view_attachments_item)), - NULL); - - /* refresh message view */ - 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_redraw(MODEST_TNY_MSG_VIEW(msg_view)); -} -static void -on_delete_clicked (GtkWidget *widget, ModestUI *modest_ui) -{ - GtkTreeSelection *sel; - GtkWidget *paned; - GtkTreeModel *model; - GtkTreeIter iter; - GtkScrolledWindow *scroll; - GtkTreeModel *mymodel; - - 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); - - /* get all selected mails */ - if (G_LIKELY (gtk_tree_selection_get_selected (sel, &model, &iter))) - { - TnyMsgHeaderIface *header; - - gtk_tree_model_get (model, &iter, TNY_MSG_HEADER_LIST_MODEL_INSTANCE_COLUMN, - &header, -1); - - if (G_LIKELY (header)) - { - TnyMsgFolderIface *folder; - // const TnyMsgIface *msg; - - if (GTK_IS_TREE_MODEL_SORT (model)) - { - mymodel = gtk_tree_model_sort_get_model - (GTK_TREE_MODEL_SORT (model)); - } else - mymodel = model; - - folder = (TnyMsgFolderIface*)tny_msg_header_iface_get_folder (header); - - /* this will make the message as deleted */ - /* tny_msg_folder_iface_expunge (folder); will finally delete messages */ - if (TNY_IS_MSG_FOLDER (folder)) - tny_msg_folder_iface_remove_message (folder, header); - gtk_widget_queue_draw (GTK_WIDGET (header_view)); - } - } -} - -static void -on_sendreceive_button_clicked (GtkWidget *widget, ModestUI *modest_ui) -{ - ModestUIPrivate *priv; - TnyAccountStoreIface *account_store; - const GList *store_accounts; - const GList *iter; - - g_return_if_fail (modest_ui); - priv = MODEST_UI_GET_PRIVATE(modest_ui); - - account_store = priv->account_store; - store_accounts = - tny_account_store_iface_get_store_accounts (account_store); - - for (iter = store_accounts; iter; iter = iter->next) - modest_tny_store_actions_update_folders (TNY_STORE_ACCOUNT_IFACE (iter->data)); -} diff --git a/src/modest-editor-window.h b/src/modest-editor-window.h index 9c9befc..b47a351 100644 --- a/src/modest-editor-window.h +++ b/src/modest-editor-window.h @@ -30,40 +30,149 @@ struct _ModestEditorWindow { struct _ModestEditorWindowClass { GtkWindowClass parent_class; - /* insert signal callback declarations, eg. */ - /* void (* my_event) (ModestEditorWindow* obj); */ }; /* member functions */ GType modest_editor_window_get_type (void) G_GNUC_CONST; +/** + * modest_editor_window_new: + * @ui: a ModestUI instance + * + * Creates a new editor window instance which is a subclass of GtkWindow and + * lives in the ModestUI context *ui + * It uses an interface function modest_ui_new_editor_window() to create the + * the actual window contents (see its documentation for the interface specification) + * + * Returns: a GtkWindow* to show and populate + */ GtkWidget *modest_editor_window_new (ModestUI *ui); +/** + * modest_editor_window_get_data: + * @edit_win: a ModestEditorWindow instance + * + * Retrieves the generic data pointer from the ModestEditorWindow (which + * the UI interface code can use to store arbitrary (state-)data in the + * ModestEditorWindow widget. + * + * Returns: a gpointer to the ModestEditorWindow's data store + */ gpointer modest_editor_window_get_data(ModestEditorWindow *edit_win); +/** + * modest_editor_window_set_modified: + * @edit_win: a ModestEditorWindow instance + * @modified: the modified flag for this instance + * + * Set/reset the modified flag for the instance. This flag can be used to store + * information whether the contents of the editor window was modified by the + * user or not. If it was modified (see also modest_editor_window_get_modified()) + * a dialog can be presented to ask the user for confirmation. + * + * Returns: gboolean the new state of the modified flag + */ gboolean modest_editor_window_set_modified(ModestEditorWindow *edit_win, gboolean modified); +/** + * modest_editor_window_get_modified: + * @edit_win: a ModestEditorWindow instance + * + * Gets the state of the modified-flag of this instance. This flag can be used to store + * information whether the contents of the editor window was modified by the + * user or not. If it was modified (see also modest_editor_window_get_modified()) + * a dialog can be presented to ask the user for confirmation. + * + * Returns: gboolean the new state of the modified flag + */ gboolean modest_editor_window_get_modified(ModestEditorWindow *edit_win); -/* fill in other public functions, eg.: */ -/* void modest_editor_window_do_something (ModestEditorWindow *self, const gchar* param); */ -/* gboolean modest_editor_window_has_foo (ModestEditorWindow *self, gint value); */ - +/** + * modest_editor_window_set_to_header: + * @edit_win: a ModestEditorWindow instance + * @to: The "To:" header string for this editor instance + * + * Sets the "To:" header to the string *to + * + * Returns: TRUE on success, FALSE otherwise + */ gboolean modest_editor_window_set_to_header(ModestEditorWindow *edit_win, const gchar *to); +/** + * modest_editor_window_set_cc_header: + * @edit_win: a ModestEditorWindow instance + * @cc: The "CC:" header string for this editor instance + * + * Sets the "CC:" header to the string *cc + * + * Returns: TRUE on success, FALSE otherwise + */ gboolean modest_editor_window_set_cc_header(ModestEditorWindow *edit_win, const gchar *cc); +/** + * modest_editor_window_set_bcc_header: + * @edit_win: a ModestEditorWindow instance + * @bcc: The "BCC:" header string for this editor instance + * + * Sets the "BCC:" header to the string *bcc + * + * Returns: TRUE on success, FALSE otherwise + */ gboolean modest_editor_window_set_bcc_header(ModestEditorWindow *edit_win, const gchar *bcc); +/** + * modest_editor_window_set_subject_header: + * @edit_win: a ModestEditorWindow instance + * @subject: The "Subject:" header string for this editor instance + * + * Sets the "Subject:" header to the string *subject + * + * Returns: TRUE on success, FALSE otherwise + */ gboolean modest_editor_window_set_subject_header(ModestEditorWindow *edit_win, const gchar *subject); +/** + * modest_editor_window_set_body: + * @edit_win: a ModestEditorWindow instance + * @body: The message body string for this editor instance + * + * Sets the message body to the string *body + * + * Returns: TRUE on success, FALSE otherwise + */ gboolean modest_editor_window_set_body(ModestEditorWindow *edit_win, const gchar *body); +/** + * modest_editor_window_attach_file: + * @edit_win: a ModestEditorWindow instance + * @filename: The name of the file to attach + * + * Attaches the file "filename" to the message contents + * + * Returns: TRUE on success, FALSE otherwise + */ gboolean modest_editor_window_attach_file(ModestEditorWindow *edit_win, const gchar *filename); +/** + * modest_editor_window_set_attachments: + * @edit_win: a ModestEditorWindow instance + * @attachments: a list of attachments + * + * Sets the list of attachments to *attachments + * + * Returns: The new GList* of attachments. + */ GList * modest_editor_window_set_attachments(ModestEditorWindow *edit_win, GList* attachments); +/** + * modest_editor_window_get_attachments: + * @edit_win: a ModestEditorWindow instance + * + * Gets the GList* of attachments of this instance + * + * Returns: The GList* of attachments of this instance + */ GList * modest_editor_window_get_attachments(ModestEditorWindow *edit_win); G_END_DECLS -- 1.7.9.5