From 245e51201e3238e6f19061f389850c7db304c8f3 Mon Sep 17 00:00:00 2001 From: hiro Date: Thu, 1 Sep 2005 08:02:49 +0000 Subject: separated UI code from account.c. git-svn-id: svn://sylpheed.sraoss.jp/sylpheed/trunk@537 ee746299-78ed-0310-b773-934348b2243d --- src/Makefile.am | 1 + src/account.c | 717 +--------------------------------------------- src/account.h | 11 +- src/account_dialog.c | 791 +++++++++++++++++++++++++++++++++++++++++++++++++++ src/account_dialog.h | 35 +++ src/folderview.c | 1 + src/main.c | 3 + src/mainwindow.c | 1 + 8 files changed, 842 insertions(+), 718 deletions(-) create mode 100644 src/account_dialog.c create mode 100644 src/account_dialog.h (limited to 'src') diff --git a/src/Makefile.am b/src/Makefile.am index 9be8d52b..c23dfaf6 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -41,6 +41,7 @@ sylpheed_SOURCES = \ prefs_template.c prefs_template.h \ prefs_actions.c prefs_actions.h \ account.c account.h \ + account_dialog.c account_dialog.h \ displayheader.c displayheader.h \ customheader.c customheader.h \ template.c template.h \ diff --git a/src/account.c b/src/account.c index 77b604eb..9986d61a 100644 --- a/src/account.c +++ b/src/account.c @@ -25,40 +25,17 @@ #include #include -#include -#include #include #include #include "main.h" -#include "mainwindow.h" -#include "folderview.h" #include "folder.h" #include "account.h" #include "prefs.h" #include "prefs_account.h" -#include "prefs_account_dialog.h" #include "procmsg.h" #include "procheader.h" -#include "compose.h" -#include "manage_window.h" -#include "stock_pixmap.h" -#include "statusbar.h" -#include "inc.h" -#include "gtkutils.h" #include "utils.h" -#include "alertpanel.h" - -enum -{ - COL_DEFAULT, - COL_GETALL, - COL_NAME, - COL_PROTOCOL, - COL_SERVER, - COL_ACCOUNT, - N_COLS -}; #define PREFSBUFSIZE 1024 @@ -66,66 +43,6 @@ PrefsAccount *cur_account; static GList *account_list = NULL; -static struct EditAccount { - GtkWidget *window; - - GtkWidget *treeview; - GtkListStore *store; - GtkTreeSelection *selection; - - GtkWidget *close_btn; -} edit_account; - -static void account_edit_create (void); - -static void account_edit_prefs (void); -static void account_delete (void); - -static void account_up (void); -static void account_down (void); - -static void account_set_default (void); - -static void account_edit_close (void); - -static gboolean account_selected (GtkTreeSelection *selection, - GtkTreeModel *model, - GtkTreePath *path, - gboolean cur_selected, - gpointer data); - -static void account_default_toggled (GtkCellRenderer *cell, - gchar *path, - gpointer data); -static void account_getall_toggled (GtkCellRenderer *cell, - gchar *path, - gpointer data); - -static void account_row_activated (GtkTreeView *treeview, - GtkTreePath *path, - GtkTreeViewColumn *column, - gpointer data); -static void account_row_reordered (GtkTreeModel *model, - GtkTreePath *path, - GtkTreeIter *iter, - gpointer data); - -static gint account_delete_event (GtkWidget *widget, - GdkEventAny *event, - gpointer data); -static gboolean account_key_pressed (GtkWidget *widget, - GdkEventKey *event, - gpointer data); - -static void account_set_row (PrefsAccount *ac_prefs, - GtkTreeIter *iter, - GtkTreeIter *new, - gboolean move_view); -static void account_set_dialog (void); -static void account_update_dialog (void); - -static void account_set_list (void); - void account_read_config_all(void) { @@ -173,9 +90,6 @@ void account_read_config_all(void) cur_account = ac_prefs; } - account_set_menu(); - main_window_reflect_prefs_all(); - while (ac_label_list) { g_free(ac_label_list->data); ac_label_list = g_slist_remove(ac_label_list, @@ -331,11 +245,6 @@ PrefsAccount *account_find_from_msginfo(MsgInfo *msginfo) return ac; } -void account_set_menu(void) -{ - main_window_set_account_menu(account_list); -} - void account_foreach(AccountFunc func, gpointer user_data) { GList *cur; @@ -350,96 +259,15 @@ GList *account_get_list(void) return account_list; } -void account_edit_open(void) +void account_list_free(void) { - inc_lock(); - - if (compose_get_compose_list()) { - alertpanel_notice(_("Some composing windows are open.\n" - "Please close all the composing windows before editing the accounts.")); - inc_unlock(); - return; - } - - debug_print(_("Opening account edit window...\n")); - - if (!edit_account.window) - account_edit_create(); - - account_set_dialog(); - - manage_window_set_transient(GTK_WINDOW(edit_account.window)); - gtk_widget_grab_focus(edit_account.close_btn); - gtk_widget_show(edit_account.window); - - manage_window_focus_in(edit_account.window, NULL, NULL); + g_list_free(account_list); + account_list = NULL; } -void account_add(void) +void account_append(PrefsAccount *ac_prefs) { - PrefsAccount *ac_prefs; - - ac_prefs = prefs_account_open(NULL); - - if (!ac_prefs) return; - account_list = g_list_append(account_list, ac_prefs); - - if (ac_prefs->is_default) - account_set_as_default(ac_prefs); - - account_set_row(ac_prefs, NULL, NULL, TRUE); - - if (ac_prefs->protocol == A_IMAP4 || ac_prefs->protocol == A_NNTP) { - Folder *folder; - - if (ac_prefs->protocol == A_IMAP4) { - folder = folder_new(F_IMAP, ac_prefs->account_name, - ac_prefs->recv_server); - } else { - folder = folder_new(F_NEWS, ac_prefs->account_name, - ac_prefs->nntp_server); - } - - folder->account = ac_prefs; - ac_prefs->folder = REMOTE_FOLDER(folder); - folder_add(folder); - if (ac_prefs->protocol == A_IMAP4) { - if (main_window_toggle_online_if_offline - (main_window_get())) { - folder->klass->create_tree(folder); - statusbar_pop_all(); - } - } - folderview_set_all(); - } -} - -void account_open(PrefsAccount *ac_prefs) -{ - gboolean prev_default; - gchar *ac_name; - - g_return_if_fail(ac_prefs != NULL); - - prev_default = ac_prefs->is_default; - Xstrdup_a(ac_name, ac_prefs->account_name ? ac_prefs->account_name : "", - return); - - prefs_account_open(ac_prefs); - - if (!prev_default && ac_prefs->is_default) - account_set_as_default(ac_prefs); - - if (ac_prefs->folder && strcmp2(ac_name, ac_prefs->account_name) != 0) { - folder_set_name(FOLDER(ac_prefs->folder), - ac_prefs->account_name); - folderview_set_all(); - } - - account_write_config_all(); - account_set_menu(); - main_window_reflect_prefs_all(); } void account_set_as_default(PrefsAccount *ac_prefs) @@ -470,6 +298,7 @@ PrefsAccount *account_get_default(void) return NULL; } +#if 0 void account_set_missing_folder(void) { PrefsAccount *ap; @@ -502,6 +331,7 @@ void account_set_missing_folder(void) } } } +#endif FolderItem *account_get_special_folder(PrefsAccount *ac_prefs, SpecialFolderItemType type) @@ -585,538 +415,3 @@ void account_destroy(PrefsAccount *ac_prefs) } } } - - -static void account_edit_create(void) -{ - GtkWidget *window; - GtkWidget *vbox; - GtkWidget *label; - GtkWidget *hbox; - GtkWidget *scrolledwin; - GtkWidget *treeview; - GtkListStore *store; - GtkTreeSelection *selection; - GtkTreeViewColumn *column; - GtkCellRenderer *renderer; - - GtkWidget *vbox2; - GtkWidget *add_btn; - GtkWidget *edit_btn; - GtkWidget *del_btn; - GtkWidget *up_btn; - GtkWidget *down_btn; - - GtkWidget *default_btn; - - GtkWidget *hbbox; - GtkWidget *close_btn; - - debug_print(_("Creating account edit window...\n")); - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_widget_set_size_request (window, 500, 320); - gtk_container_set_border_width (GTK_CONTAINER (window), 8); - gtk_window_set_title (GTK_WINDOW (window), _("Edit accounts")); - gtk_window_set_modal (GTK_WINDOW (window), TRUE); - g_signal_connect (G_OBJECT (window), "delete_event", - G_CALLBACK (account_delete_event), NULL); - g_signal_connect (G_OBJECT (window), "key_press_event", - G_CALLBACK (account_key_pressed), NULL); - MANAGE_WINDOW_SIGNALS_CONNECT (window); - gtk_widget_realize(window); - - vbox = gtk_vbox_new (FALSE, 10); - gtk_widget_show (vbox); - gtk_container_add (GTK_CONTAINER (window), vbox); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_widget_show (hbox); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); - - label = gtk_label_new - (_("New messages will be checked in this order. Check the boxes\n" - "on the `G' column to enable message retrieval by `Get all'.")); - gtk_widget_show (label); - gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 4); - gtk_label_set_justify(GTK_LABEL(label), GTK_JUSTIFY_LEFT); - - hbox = gtk_hbox_new (FALSE, 8); - gtk_widget_show (hbox); - gtk_box_pack_start (GTK_BOX (vbox), hbox, TRUE, TRUE, 0); - gtk_container_set_border_width (GTK_CONTAINER (hbox), 2); - - scrolledwin = gtk_scrolled_window_new(NULL, NULL); - gtk_widget_show(scrolledwin); - gtk_box_pack_start(GTK_BOX(hbox), scrolledwin, TRUE, TRUE, 0); - gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolledwin), - GTK_POLICY_AUTOMATIC, - GTK_POLICY_AUTOMATIC); - gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(scrolledwin), - GTK_SHADOW_IN); - - store = gtk_list_store_new - (N_COLS, G_TYPE_BOOLEAN, G_TYPE_BOOLEAN, G_TYPE_STRING, - G_TYPE_STRING, G_TYPE_STRING, G_TYPE_POINTER); - - treeview = gtk_tree_view_new_with_model(GTK_TREE_MODEL(store)); - g_object_unref(G_OBJECT(store)); - gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(treeview), TRUE); - gtk_tree_view_set_rules_hint(GTK_TREE_VIEW(treeview), TRUE); - gtk_tree_view_set_search_column(GTK_TREE_VIEW(treeview), COL_NAME); - gtk_tree_view_set_reorderable(GTK_TREE_VIEW(treeview), TRUE); - - selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(treeview)); - gtk_tree_selection_set_mode(selection, GTK_SELECTION_BROWSE); - gtk_tree_selection_set_select_function(selection, account_selected, - NULL, NULL); - - renderer = gtk_cell_renderer_toggle_new(); - gtk_cell_renderer_toggle_set_radio(GTK_CELL_RENDERER_TOGGLE(renderer), - TRUE); - g_signal_connect(renderer, "toggled", - G_CALLBACK(account_default_toggled), NULL); - column = gtk_tree_view_column_new_with_attributes - ("D", renderer, "active", COL_DEFAULT, NULL); - gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column); - - renderer = gtk_cell_renderer_toggle_new(); - g_signal_connect(renderer, "toggled", - G_CALLBACK(account_getall_toggled), NULL); - column = gtk_tree_view_column_new_with_attributes - ("G", renderer, "active", COL_GETALL, NULL); - gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column); - - renderer = gtk_cell_renderer_text_new(); - column = gtk_tree_view_column_new_with_attributes - (_("Name"), renderer, "text", COL_NAME, NULL); - gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column); - - renderer = gtk_cell_renderer_text_new(); - column = gtk_tree_view_column_new_with_attributes - (_("Protocol"), renderer, "text", COL_PROTOCOL, NULL); - gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column); - - renderer = gtk_cell_renderer_text_new(); - column = gtk_tree_view_column_new_with_attributes - (_("Server"), renderer, "text", COL_SERVER, NULL); - gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column); - - gtk_widget_show(treeview); - gtk_container_add(GTK_CONTAINER(scrolledwin), treeview); - - g_signal_connect(G_OBJECT(treeview), "row-activated", - G_CALLBACK(account_row_activated), NULL); - g_signal_connect_after(G_OBJECT(store), "rows-reordered", - G_CALLBACK(account_row_reordered), NULL); - - vbox2 = gtk_vbox_new (FALSE, 0); - gtk_widget_show (vbox2); - gtk_box_pack_start (GTK_BOX (hbox), vbox2, FALSE, FALSE, 0); - - add_btn = gtk_button_new_from_stock (GTK_STOCK_ADD); - gtk_widget_show (add_btn); - gtk_box_pack_start (GTK_BOX (vbox2), add_btn, FALSE, FALSE, 4); - g_signal_connect (G_OBJECT(add_btn), "clicked", - G_CALLBACK (account_add), NULL); - -#ifdef GTK_STOCK_EDIT - edit_btn = gtk_button_new_from_stock (GTK_STOCK_EDIT); -#else - edit_btn = gtk_button_new_with_label (_("Edit")); -#endif - gtk_widget_show (edit_btn); - gtk_box_pack_start (GTK_BOX (vbox2), edit_btn, FALSE, FALSE, 4); - g_signal_connect (G_OBJECT(edit_btn), "clicked", - G_CALLBACK (account_edit_prefs), NULL); - - del_btn = gtk_button_new_from_stock (GTK_STOCK_DELETE); - gtk_widget_show (del_btn); - gtk_box_pack_start (GTK_BOX (vbox2), del_btn, FALSE, FALSE, 4); - g_signal_connect (G_OBJECT(del_btn), "clicked", - G_CALLBACK (account_delete), NULL); - - down_btn = gtk_button_new_from_stock (GTK_STOCK_GO_DOWN); - gtk_widget_show (down_btn); - gtk_box_pack_end (GTK_BOX (vbox2), down_btn, FALSE, FALSE, 4); - g_signal_connect (G_OBJECT(down_btn), "clicked", - G_CALLBACK (account_down), NULL); - - up_btn = gtk_button_new_from_stock (GTK_STOCK_GO_UP); - gtk_widget_show (up_btn); - gtk_box_pack_end (GTK_BOX (vbox2), up_btn, FALSE, FALSE, 4); - g_signal_connect (G_OBJECT(up_btn), "clicked", - G_CALLBACK (account_up), NULL); - - hbox = gtk_hbox_new (FALSE, 8); - gtk_widget_show (hbox); - gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); - - vbox2 = gtk_vbox_new(FALSE, 0); - gtk_widget_show (vbox2); - gtk_box_pack_start (GTK_BOX (hbox), vbox2, FALSE, FALSE, 0); - - default_btn = gtk_button_new_with_mnemonic - (_(" _Set as default account ")); - gtk_widget_show (default_btn); - gtk_box_pack_start (GTK_BOX (vbox2), default_btn, TRUE, FALSE, 0); - g_signal_connect (G_OBJECT(default_btn), "clicked", - G_CALLBACK (account_set_default), NULL); - - gtkut_stock_button_set_create(&hbbox, &close_btn, GTK_STOCK_CLOSE, - NULL, NULL, NULL, NULL); - gtk_widget_show(hbbox); - gtk_box_pack_end (GTK_BOX (hbox), hbbox, FALSE, FALSE, 0); - gtk_widget_grab_default (close_btn); - - g_signal_connect (G_OBJECT (close_btn), "clicked", - G_CALLBACK (account_edit_close), NULL); - - edit_account.window = window; - edit_account.treeview = treeview; - edit_account.store = store; - edit_account.selection = selection; - edit_account.close_btn = close_btn; -} - -static void account_edit_prefs(void) -{ - GtkTreeIter iter; - PrefsAccount *ac_prefs; - - if (!gtk_tree_selection_get_selected(edit_account.selection, - NULL, &iter)) - return; - - gtk_tree_model_get(GTK_TREE_MODEL(edit_account.store), &iter, - COL_ACCOUNT, &ac_prefs, -1); - account_open(ac_prefs); - - account_set_row(ac_prefs, &iter, NULL, FALSE); -} - -static void account_delete(void) -{ - GtkTreeIter iter; - PrefsAccount *ac_prefs; - gchar buf[BUFFSIZE]; - - if (!gtk_tree_selection_get_selected(edit_account.selection, - NULL, &iter)) - return; - - gtk_tree_model_get(GTK_TREE_MODEL(edit_account.store), &iter, - COL_ACCOUNT, &ac_prefs, -1); - g_return_if_fail(ac_prefs != NULL); - - g_snprintf(buf, sizeof(buf), - _("Do you really want to delete the account '%s'?"), - ac_prefs->account_name ? ac_prefs->account_name : - _("(Untitled)")); - if (alertpanel_full(_("Delete account"), buf, - ALERT_QUESTION, G_ALERTALTERNATE, FALSE, - GTK_STOCK_YES, GTK_STOCK_NO, NULL) - != G_ALERTDEFAULT) - return; - - if (ac_prefs->folder) { - FolderItem *item; - - item = main_window_get()->summaryview->folder_item; - if (item && item->folder == FOLDER(ac_prefs->folder)) - summary_clear_all(main_window_get()->summaryview); - folder_destroy(FOLDER(ac_prefs->folder)); - folderview_set_all(); - } - - account_destroy(ac_prefs); - gtk_list_store_remove(edit_account.store, &iter); - account_update_dialog(); -} - -static void account_up(void) -{ - GtkTreeModel *model = GTK_TREE_MODEL(edit_account.store); - GtkTreeIter iter, prev; - GtkTreePath *path; - - if (!gtk_tree_selection_get_selected(edit_account.selection, - NULL, &iter)) - return; - - path = gtk_tree_model_get_path(model, &iter); - if (gtk_tree_path_prev(path)) { - gtk_tree_model_get_iter(model, &prev, path); - gtk_list_store_swap(edit_account.store, &iter, &prev); - } - gtk_tree_path_free(path); -} - -static void account_down(void) -{ - GtkTreeIter iter, next; - - if (!gtk_tree_selection_get_selected(edit_account.selection, - NULL, &iter)) - return; - - next = iter; - if (gtk_tree_model_iter_next(GTK_TREE_MODEL(edit_account.store), - &next)) - gtk_list_store_swap(edit_account.store, &iter, &next); -} - -static void account_set_default(void) -{ - GtkTreeIter iter; - PrefsAccount *ac_prefs; - - if (!gtk_tree_selection_get_selected(edit_account.selection, - NULL, &iter)) - return; - - gtk_tree_model_get(GTK_TREE_MODEL(edit_account.store), &iter, - COL_ACCOUNT, &ac_prefs, -1); - g_return_if_fail(ac_prefs != NULL); - - account_set_as_default(ac_prefs); - account_update_dialog(); - - cur_account = ac_prefs; - account_set_menu(); - main_window_reflect_prefs_all(); -} - -static void account_edit_close(void) -{ - account_set_list(); - account_write_config_all(); - - if (!cur_account && account_list) { - PrefsAccount *ac_prefs = (PrefsAccount *)account_list->data; - account_set_as_default(ac_prefs); - cur_account = ac_prefs; - } - - account_set_menu(); - main_window_reflect_prefs_all(); - - gtk_widget_hide(edit_account.window); - - inc_unlock(); -} - -static gint account_delete_event(GtkWidget *widget, GdkEventAny *event, - gpointer data) -{ - account_edit_close(); - return TRUE; -} - -static gboolean account_selected(GtkTreeSelection *selection, - GtkTreeModel *model, GtkTreePath *path, - gboolean cur_selected, gpointer data) -{ - return TRUE; -} - -static void account_default_toggled(GtkCellRenderer *cell, gchar *path_str, - gpointer data) -{ - GtkTreeIter iter; - PrefsAccount *ac; - GtkTreePath *path; - - path = gtk_tree_path_new_from_string(path_str); - gtk_tree_model_get_iter(GTK_TREE_MODEL(edit_account.store), - &iter, path); - gtk_tree_path_free(path); - gtk_tree_model_get(GTK_TREE_MODEL(edit_account.store), &iter, - COL_ACCOUNT, &ac, -1); - - account_set_as_default(ac); - account_update_dialog(); -} - -static void account_getall_toggled(GtkCellRenderer *cell, gchar *path_str, - gpointer data) -{ - GtkTreeIter iter; - PrefsAccount *ac; - GtkTreePath *path; - - path = gtk_tree_path_new_from_string(path_str); - gtk_tree_model_get_iter(GTK_TREE_MODEL(edit_account.store), - &iter, path); - gtk_tree_path_free(path); - gtk_tree_model_get(GTK_TREE_MODEL(edit_account.store), &iter, - COL_ACCOUNT, &ac, -1); - - if (ac->protocol == A_POP3 || ac->protocol == A_IMAP4 || - ac->protocol == A_NNTP) { - ac->recv_at_getall ^= TRUE; - account_set_row(ac, &iter, NULL, FALSE); - } -} - -static void account_row_activated(GtkTreeView *treeview, GtkTreePath *path, - GtkTreeViewColumn *column, gpointer data) -{ - account_edit_prefs(); -} - -static void account_row_reordered (GtkTreeModel *model, - GtkTreePath *path, - GtkTreeIter *iter, - gpointer data) -{ - GtkTreeIter iter_; - GtkTreePath *path_; - - if (!gtk_tree_selection_get_selected(edit_account.selection, - NULL, &iter_)) - return; - path_ = gtk_tree_model_get_path - (GTK_TREE_MODEL(edit_account.store), &iter_); - gtk_tree_view_scroll_to_cell(GTK_TREE_VIEW(edit_account.treeview), - path_, NULL, FALSE, 0.0, 0.0); - gtk_tree_path_free(path_); -} - -static gboolean account_key_pressed(GtkWidget *widget, GdkEventKey *event, - gpointer data) -{ - if (event && event->keyval == GDK_Escape) - account_edit_close(); - return FALSE; -} - -static void account_set_row(PrefsAccount *ac_prefs, GtkTreeIter *iter, - GtkTreeIter *new, gboolean move_view) -{ - GtkListStore *store = edit_account.store; - GtkTreeIter iter_; - const gchar *protocol, *server; - gboolean has_getall; - - g_return_if_fail(ac_prefs != NULL); - -#if USE_SSL - protocol = ac_prefs->protocol == A_POP3 ? - (ac_prefs->ssl_pop == SSL_TUNNEL ? - "POP3 (SSL)" : - ac_prefs->ssl_pop == SSL_STARTTLS ? - "POP3 (TLS)" : "POP3") : - ac_prefs->protocol == A_IMAP4 ? - (ac_prefs->ssl_imap == SSL_TUNNEL ? - "IMAP4 (SSL)" : - ac_prefs->ssl_imap == SSL_STARTTLS ? - "IMAP4 (TLS)" : "IMAP4") : - ac_prefs->protocol == A_NNTP ? - (ac_prefs->ssl_nntp == SSL_TUNNEL ? - "NNTP (SSL)" : "NNTP") : - ""; -#else - protocol = ac_prefs->protocol == A_POP3 ? "POP3" : - ac_prefs->protocol == A_IMAP4 ? "IMAP4" : - ac_prefs->protocol == A_NNTP ? "NNTP" : ""; -#endif - server = ac_prefs->protocol == A_NNTP ? - ac_prefs->nntp_server : ac_prefs->recv_server; - - has_getall = (ac_prefs->protocol == A_POP3 || - ac_prefs->protocol == A_IMAP4 || - ac_prefs->protocol == A_NNTP); - - if (!iter) - gtk_list_store_append(store, &iter_); - else - iter_ = *iter; - - gtk_list_store_set(store, &iter_, - COL_DEFAULT, ac_prefs->is_default, - COL_GETALL, has_getall && ac_prefs->recv_at_getall, - COL_NAME, ac_prefs->account_name, - COL_PROTOCOL, protocol, - COL_SERVER, server, - COL_ACCOUNT, ac_prefs, - -1); - - if (new) - *new = iter_; - - if (move_view) { - GtkTreePath *path; - - path = gtk_tree_model_get_path - (GTK_TREE_MODEL(edit_account.store), &iter_); - gtk_tree_view_scroll_to_cell - (GTK_TREE_VIEW(edit_account.treeview), - path, NULL, TRUE, 0.5, 0.0); - gtk_tree_path_free(path); - } -} - -/* set dialog from account list */ -static void account_set_dialog(void) -{ - GList *cur; - GtkTreeIter iter; - GtkTreePath *path; - - gtk_list_store_clear(edit_account.store); - - for (cur = account_list; cur != NULL; cur = cur->next) { - account_set_row((PrefsAccount *)cur->data, NULL, &iter, FALSE); - if ((PrefsAccount *)cur->data == cur_account) { - gtk_tree_selection_select_iter(edit_account.selection, - &iter); - } - } - - if (!gtk_tree_selection_get_selected(edit_account.selection, NULL, - &iter)) - return; - path = gtk_tree_model_get_path(GTK_TREE_MODEL(edit_account.store), - &iter); - gtk_tree_view_scroll_to_cell(GTK_TREE_VIEW(edit_account.treeview), - path, NULL, FALSE, 0.0, 0.0); - gtk_tree_path_free(path); -} - -/* update dialog to the latest state */ -static void account_update_dialog(void) -{ - GtkTreeIter iter; - GtkTreeModel *model = GTK_TREE_MODEL(edit_account.store); - PrefsAccount *ac; - - if (!gtk_tree_model_get_iter_first(model, &iter)) - return; - - do { - gtk_tree_model_get(model, &iter, COL_ACCOUNT, &ac, -1); - if (ac) - account_set_row(ac, &iter, NULL, FALSE); - } while (gtk_tree_model_iter_next(model, &iter)); -} - -/* set account list from dialog */ -static void account_set_list(void) -{ - GtkTreeIter iter; - GtkTreeModel *model = GTK_TREE_MODEL(edit_account.store); - PrefsAccount *ac; - - g_list_free(account_list); - account_list = NULL; - - if (!gtk_tree_model_get_iter_first(model, &iter)) - return; - - do { - gtk_tree_model_get(model, &iter, COL_ACCOUNT, &ac, -1); - if (ac) - account_list = g_list_append(account_list, ac); - } while (gtk_tree_model_iter_next(model, &iter)); -} diff --git a/src/account.h b/src/account.h index 2ec2a384..0cef7c50 100644 --- a/src/account.h +++ b/src/account.h @@ -1,6 +1,6 @@ /* * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client - * Copyright (C) 1999-2002 Hiroyuki Yamamoto + * Copyright (C) 1999-2005 Hiroyuki Yamamoto * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -43,19 +43,16 @@ PrefsAccount *account_find_from_item (FolderItem *item); PrefsAccount *account_find_from_message_file (const gchar *file); PrefsAccount *account_find_from_msginfo (MsgInfo *msginfo); -void account_set_menu (void); - void account_foreach (AccountFunc func, gpointer user_data); GList *account_get_list (void); +void account_list_free (void); +void account_append (PrefsAccount *ac_prefs); -void account_edit_open (void); -void account_add (void); -void account_open (PrefsAccount *ac_prefs); void account_set_as_default (PrefsAccount *ac_prefs); PrefsAccount *account_get_default (void); -void account_set_missing_folder(void); +//void account_set_missing_folder(void); FolderItem *account_get_special_folder(PrefsAccount *ac_prefs, SpecialFolderItemType type); diff --git a/src/account_dialog.c b/src/account_dialog.c new file mode 100644 index 00000000..44de22a5 --- /dev/null +++ b/src/account_dialog.c @@ -0,0 +1,791 @@ +/* + * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client + * Copyright (C) 1999-2005 Hiroyuki Yamamoto + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + */ + +#ifdef HAVE_CONFIG_H +# include "config.h" +#endif + +#include "defs.h" + +#include +#include +#include +#include +#include +#include + +#include "main.h" +#include "mainwindow.h" +#include "folderview.h" +#include "folder.h" +#include "account.h" +#include "prefs.h" +#include "prefs_account.h" +#include "prefs_account_dialog.h" +#include "procmsg.h" +#include "procheader.h" +#include "compose.h" +#include "manage_window.h" +#include "stock_pixmap.h" +#include "statusbar.h" +#include "inc.h" +#include "gtkutils.h" +#include "utils.h" +#include "alertpanel.h" + +enum +{ + COL_DEFAULT, + COL_GETALL, + COL_NAME, + COL_PROTOCOL, + COL_SERVER, + COL_ACCOUNT, + N_COLS +}; + +#define PREFSBUFSIZE 1024 + +static struct EditAccount { + GtkWidget *window; + + GtkWidget *treeview; + GtkListStore *store; + GtkTreeSelection *selection; + + GtkWidget *close_btn; +} edit_account; + +static void account_edit_create (void); + +static void account_edit_prefs (void); +static void account_delete (void); + +static void account_up (void); +static void account_down (void); + +static void account_set_default (void); + +static void account_edit_close (void); + +static gboolean account_selected (GtkTreeSelection *selection, + GtkTreeModel *model, + GtkTreePath *path, + gboolean cur_selected, + gpointer data); + +static void account_default_toggled (GtkCellRenderer *cell, + gchar *path, + gpointer data); +static void account_getall_toggled (GtkCellRenderer *cell, + gchar *path, + gpointer data); + +static void account_row_activated (GtkTreeView *treeview, + GtkTreePath *path, + GtkTreeViewColumn *column, + gpointer data); +static void account_row_reordered (GtkTreeModel *model, + GtkTreePath *path, + GtkTreeIter *iter, + gpointer data); + +static gint account_delete_event (GtkWidget *widget, + GdkEventAny *event, + gpointer data); +static gboolean account_key_pressed (GtkWidget *widget, + GdkEventKey *event, + gpointer data); + +static void account_set_row (PrefsAccount *ac_prefs, + GtkTreeIter *iter, + GtkTreeIter *new, + gboolean move_view); +static void account_set_dialog (void); +static void account_update_dialog (void); + +static void account_set_list (void); + + +void account_set_menu(void) +{ + main_window_set_account_menu(account_get_list()); +} + +void account_edit_open(void) +{ + inc_lock(); + + if (compose_get_compose_list()) { + alertpanel_notice(_("Some composing windows are open.\n" + "Please close all the composing windows before editing the accounts.")); + inc_unlock(); + return; + } + + debug_print(_("Opening account edit window...\n")); + + if (!edit_account.window) + account_edit_create(); + + account_set_dialog(); + + manage_window_set_transient(GTK_WINDOW(edit_account.window)); + gtk_widget_grab_focus(edit_account.close_btn); + gtk_widget_show(edit_account.window); + + manage_window_focus_in(edit_account.window, NULL, NULL); +} + +void account_add(void) +{ + PrefsAccount *ac_prefs; + + ac_prefs = prefs_account_open(NULL); + + if (!ac_prefs) return; + + account_append(ac_prefs); + + if (ac_prefs->is_default) + account_set_as_default(ac_prefs); + + account_set_row(ac_prefs, NULL, NULL, TRUE); + + if (ac_prefs->protocol == A_IMAP4 || ac_prefs->protocol == A_NNTP) { + Folder *folder; + + if (ac_prefs->protocol == A_IMAP4) { + folder = folder_new(F_IMAP, ac_prefs->account_name, + ac_prefs->recv_server); + } else { + folder = folder_new(F_NEWS, ac_prefs->account_name, + ac_prefs->nntp_server); + } + + folder->account = ac_prefs; + ac_prefs->folder = REMOTE_FOLDER(folder); + folder_add(folder); + if (ac_prefs->protocol == A_IMAP4) { + if (main_window_toggle_online_if_offline + (main_window_get())) { + folder->klass->create_tree(folder); + statusbar_pop_all(); + } + } + folderview_set_all(); + } +} + +void account_open(PrefsAccount *ac_prefs) +{ + gboolean prev_default; + gchar *ac_name; + + g_return_if_fail(ac_prefs != NULL); + + prev_default = ac_prefs->is_default; + Xstrdup_a(ac_name, ac_prefs->account_name ? ac_prefs->account_name : "", + return); + + prefs_account_open(ac_prefs); + + if (!prev_default && ac_prefs->is_default) + account_set_as_default(ac_prefs); + + if (ac_prefs->folder && strcmp2(ac_name, ac_prefs->account_name) != 0) { + folder_set_name(FOLDER(ac_prefs->folder), + ac_prefs->account_name); + folderview_set_all(); + } + + account_write_config_all(); + account_set_menu(); + main_window_reflect_prefs_all(); +} + +void account_set_missing_folder(void) +{ + PrefsAccount *ap; + GList *cur; + + for (cur = account_get_list(); cur != NULL; cur = cur->next) { + ap = (PrefsAccount *)cur->data; + if ((ap->protocol == A_IMAP4 || ap->protocol == A_NNTP) && + !ap->folder) { + Folder *folder; + + if (ap->protocol == A_IMAP4) { + folder = folder_new(F_IMAP, ap->account_name, + ap->recv_server); + } else { + folder = folder_new(F_NEWS, ap->account_name, + ap->nntp_server); + } + + folder->account = ap; + ap->folder = REMOTE_FOLDER(folder); + folder_add(folder); + if (ap->protocol == A_IMAP4) { + if (main_window_toggle_online_if_offline + (main_window_get())) { + folder->klass->create_tree(folder); + statusbar_pop_all(); + } + } + } + } +} + +static void account_edit_create(void) +{ + GtkWidget *window; + GtkWidget *vbox; + GtkWidget *label; + GtkWidget *hbox; + GtkWidget *scrolledwin; + GtkWidget *treeview; + GtkListStore *store; + GtkTreeSelection *selection; + GtkTreeViewColumn *column; + GtkCellRenderer *renderer; + + GtkWidget *vbox2; + GtkWidget *add_btn; + GtkWidget *edit_btn; + GtkWidget *del_btn; + GtkWidget *up_btn; + GtkWidget *down_btn; + + GtkWidget *default_btn; + + GtkWidget *hbbox; + GtkWidget *close_btn; + + debug_print(_("Creating account edit window...\n")); + + window = gtk_window_new (GTK_WINDOW_TOPLEVEL); + gtk_widget_set_size_request (window, 500, 320); + gtk_container_set_border_width (GTK_CONTAINER (window), 8); + gtk_window_set_title (GTK_WINDOW (window), _("Edit accounts")); + gtk_window_set_modal (GTK_WINDOW (window), TRUE); + g_signal_connect (G_OBJECT (window), "delete_event", + G_CALLBACK (account_delete_event), NULL); + g_signal_connect (G_OBJECT (window), "key_press_event", + G_CALLBACK (account_key_pressed), NULL); + MANAGE_WINDOW_SIGNALS_CONNECT (window); + gtk_widget_realize(window); + + vbox = gtk_vbox_new (FALSE, 10); + gtk_widget_show (vbox); + gtk_container_add (GTK_CONTAINER (window), vbox); + + hbox = gtk_hbox_new (FALSE, 0); + gtk_widget_show (hbox); + gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); + + label = gtk_label_new + (_("New messages will be checked in this order. Check the boxes\n" + "on the `G' column to enable message retrieval by `Get all'.")); + gtk_widget_show (label); + gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 4); + gtk_label_set_justify(GTK_LABEL(label), GTK_JUSTIFY_LEFT); + + hbox = gtk_hbox_new (FALSE, 8); + gtk_widget_show (hbox); + gtk_box_pack_start (GTK_BOX (vbox), hbox, TRUE, TRUE, 0); + gtk_container_set_border_width (GTK_CONTAINER (hbox), 2); + + scrolledwin = gtk_scrolled_window_new(NULL, NULL); + gtk_widget_show(scrolledwin); + gtk_box_pack_start(GTK_BOX(hbox), scrolledwin, TRUE, TRUE, 0); + gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolledwin), + GTK_POLICY_AUTOMATIC, + GTK_POLICY_AUTOMATIC); + gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(scrolledwin), + GTK_SHADOW_IN); + + store = gtk_list_store_new + (N_COLS, G_TYPE_BOOLEAN, G_TYPE_BOOLEAN, G_TYPE_STRING, + G_TYPE_STRING, G_TYPE_STRING, G_TYPE_POINTER); + + treeview = gtk_tree_view_new_with_model(GTK_TREE_MODEL(store)); + g_object_unref(G_OBJECT(store)); + gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(treeview), TRUE); + gtk_tree_view_set_rules_hint(GTK_TREE_VIEW(treeview), TRUE); + gtk_tree_view_set_search_column(GTK_TREE_VIEW(treeview), COL_NAME); + gtk_tree_view_set_reorderable(GTK_TREE_VIEW(treeview), TRUE); + + selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(treeview)); + gtk_tree_selection_set_mode(selection, GTK_SELECTION_BROWSE); + gtk_tree_selection_set_select_function(selection, account_selected, + NULL, NULL); + + renderer = gtk_cell_renderer_toggle_new(); + gtk_cell_renderer_toggle_set_radio(GTK_CELL_RENDERER_TOGGLE(renderer), + TRUE); + g_signal_connect(renderer, "toggled", + G_CALLBACK(account_default_toggled), NULL); + column = gtk_tree_view_column_new_with_attributes + ("D", renderer, "active", COL_DEFAULT, NULL); + gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column); + + renderer = gtk_cell_renderer_toggle_new(); + g_signal_connect(renderer, "toggled", + G_CALLBACK(account_getall_toggled), NULL); + column = gtk_tree_view_column_new_with_attributes + ("G", renderer, "active", COL_GETALL, NULL); + gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column); + + renderer = gtk_cell_renderer_text_new(); + column = gtk_tree_view_column_new_with_attributes + (_("Name"), renderer, "text", COL_NAME, NULL); + gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column); + + renderer = gtk_cell_renderer_text_new(); + column = gtk_tree_view_column_new_with_attributes + (_("Protocol"), renderer, "text", COL_PROTOCOL, NULL); + gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column); + + renderer = gtk_cell_renderer_text_new(); + column = gtk_tree_view_column_new_with_attributes + (_("Server"), renderer, "text", COL_SERVER, NULL); + gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column); + + gtk_widget_show(treeview); + gtk_container_add(GTK_CONTAINER(scrolledwin), treeview); + + g_signal_connect(G_OBJECT(treeview), "row-activated", + G_CALLBACK(account_row_activated), NULL); + g_signal_connect_after(G_OBJECT(store), "rows-reordered", + G_CALLBACK(account_row_reordered), NULL); + + vbox2 = gtk_vbox_new (FALSE, 0); + gtk_widget_show (vbox2); + gtk_box_pack_start (GTK_BOX (hbox), vbox2, FALSE, FALSE, 0); + + add_btn = gtk_button_new_from_stock (GTK_STOCK_ADD); + gtk_widget_show (add_btn); + gtk_box_pack_start (GTK_BOX (vbox2), add_btn, FALSE, FALSE, 4); + g_signal_connect (G_OBJECT(add_btn), "clicked", + G_CALLBACK (account_add), NULL); + +#ifdef GTK_STOCK_EDIT + edit_btn = gtk_button_new_from_stock (GTK_STOCK_EDIT); +#else + edit_btn = gtk_button_new_with_label (_("Edit")); +#endif + gtk_widget_show (edit_btn); + gtk_box_pack_start (GTK_BOX (vbox2), edit_btn, FALSE, FALSE, 4); + g_signal_connect (G_OBJECT(edit_btn), "clicked", + G_CALLBACK (account_edit_prefs), NULL); + + del_btn = gtk_button_new_from_stock (GTK_STOCK_DELETE); + gtk_widget_show (del_btn); + gtk_box_pack_start (GTK_BOX (vbox2), del_btn, FALSE, FALSE, 4); + g_signal_connect (G_OBJECT(del_btn), "clicked", + G_CALLBACK (account_delete), NULL); + + down_btn = gtk_button_new_from_stock (GTK_STOCK_GO_DOWN); + gtk_widget_show (down_btn); + gtk_box_pack_end (GTK_BOX (vbox2), down_btn, FALSE, FALSE, 4); + g_signal_connect (G_OBJECT(down_btn), "clicked", + G_CALLBACK (account_down), NULL); + + up_btn = gtk_button_new_from_stock (GTK_STOCK_GO_UP); + gtk_widget_show (up_btn); + gtk_box_pack_end (GTK_BOX (vbox2), up_btn, FALSE, FALSE, 4); + g_signal_connect (G_OBJECT(up_btn), "clicked", + G_CALLBACK (account_up), NULL); + + hbox = gtk_hbox_new (FALSE, 8); + gtk_widget_show (hbox); + gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); + + vbox2 = gtk_vbox_new(FALSE, 0); + gtk_widget_show (vbox2); + gtk_box_pack_start (GTK_BOX (hbox), vbox2, FALSE, FALSE, 0); + + default_btn = gtk_button_new_with_mnemonic + (_(" _Set as default account ")); + gtk_widget_show (default_btn); + gtk_box_pack_start (GTK_BOX (vbox2), default_btn, TRUE, FALSE, 0); + g_signal_connect (G_OBJECT(default_btn), "clicked", + G_CALLBACK (account_set_default), NULL); + + gtkut_stock_button_set_create(&hbbox, &close_btn, GTK_STOCK_CLOSE, + NULL, NULL, NULL, NULL); + gtk_widget_show(hbbox); + gtk_box_pack_end (GTK_BOX (hbox), hbbox, FALSE, FALSE, 0); + gtk_widget_grab_default (close_btn); + + g_signal_connect (G_OBJECT (close_btn), "clicked", + G_CALLBACK (account_edit_close), NULL); + + edit_account.window = window; + edit_account.treeview = treeview; + edit_account.store = store; + edit_account.selection = selection; + edit_account.close_btn = close_btn; +} + +static void account_edit_prefs(void) +{ + GtkTreeIter iter; + PrefsAccount *ac_prefs; + + if (!gtk_tree_selection_get_selected(edit_account.selection, + NULL, &iter)) + return; + + gtk_tree_model_get(GTK_TREE_MODEL(edit_account.store), &iter, + COL_ACCOUNT, &ac_prefs, -1); + account_open(ac_prefs); + + account_set_row(ac_prefs, &iter, NULL, FALSE); +} + +static void account_delete(void) +{ + GtkTreeIter iter; + PrefsAccount *ac_prefs; + gchar buf[BUFFSIZE]; + + if (!gtk_tree_selection_get_selected(edit_account.selection, + NULL, &iter)) + return; + + gtk_tree_model_get(GTK_TREE_MODEL(edit_account.store), &iter, + COL_ACCOUNT, &ac_prefs, -1); + g_return_if_fail(ac_prefs != NULL); + + g_snprintf(buf, sizeof(buf), + _("Do you really want to delete the account '%s'?"), + ac_prefs->account_name ? ac_prefs->account_name : + _("(Untitled)")); + if (alertpanel_full(_("Delete account"), buf, + ALERT_QUESTION, G_ALERTALTERNATE, FALSE, + GTK_STOCK_YES, GTK_STOCK_NO, NULL) + != G_ALERTDEFAULT) + return; + + if (ac_prefs->folder) { + FolderItem *item; + + item = main_window_get()->summaryview->folder_item; + if (item && item->folder == FOLDER(ac_prefs->folder)) + summary_clear_all(main_window_get()->summaryview); + folder_destroy(FOLDER(ac_prefs->folder)); + folderview_set_all(); + } + + account_destroy(ac_prefs); + gtk_list_store_remove(edit_account.store, &iter); + account_update_dialog(); +} + +static void account_up(void) +{ + GtkTreeModel *model = GTK_TREE_MODEL(edit_account.store); + GtkTreeIter iter, prev; + GtkTreePath *path; + + if (!gtk_tree_selection_get_selected(edit_account.selection, + NULL, &iter)) + return; + + path = gtk_tree_model_get_path(model, &iter); + if (gtk_tree_path_prev(path)) { + gtk_tree_model_get_iter(model, &prev, path); + gtk_list_store_swap(edit_account.store, &iter, &prev); + } + gtk_tree_path_free(path); +} + +static void account_down(void) +{ + GtkTreeIter iter, next; + + if (!gtk_tree_selection_get_selected(edit_account.selection, + NULL, &iter)) + return; + + next = iter; + if (gtk_tree_model_iter_next(GTK_TREE_MODEL(edit_account.store), + &next)) + gtk_list_store_swap(edit_account.store, &iter, &next); +} + +static void account_set_default(void) +{ + GtkTreeIter iter; + PrefsAccount *ac_prefs; + + if (!gtk_tree_selection_get_selected(edit_account.selection, + NULL, &iter)) + return; + + gtk_tree_model_get(GTK_TREE_MODEL(edit_account.store), &iter, + COL_ACCOUNT, &ac_prefs, -1); + g_return_if_fail(ac_prefs != NULL); + + account_set_as_default(ac_prefs); + account_update_dialog(); + + cur_account = ac_prefs; + account_set_menu(); + main_window_reflect_prefs_all(); +} + +static void account_edit_close(void) +{ + GList *account_list; + + account_set_list(); + account_write_config_all(); + + account_list = account_get_list(); + + if (!cur_account && account_list) { + PrefsAccount *ac_prefs = (PrefsAccount *)account_list->data; + account_set_as_default(ac_prefs); + cur_account = ac_prefs; + } + + account_set_menu(); + main_window_reflect_prefs_all(); + + gtk_widget_hide(edit_account.window); + + inc_unlock(); +} + +static gint account_delete_event(GtkWidget *widget, GdkEventAny *event, + gpointer data) +{ + account_edit_close(); + return TRUE; +} + +static gboolean account_selected(GtkTreeSelection *selection, + GtkTreeModel *model, GtkTreePath *path, + gboolean cur_selected, gpointer data) +{ + return TRUE; +} + +static void account_default_toggled(GtkCellRenderer *cell, gchar *path_str, + gpointer data) +{ + GtkTreeIter iter; + PrefsAccount *ac; + GtkTreePath *path; + + path = gtk_tree_path_new_from_string(path_str); + gtk_tree_model_get_iter(GTK_TREE_MODEL(edit_account.store), + &iter, path); + gtk_tree_path_free(path); + gtk_tree_model_get(GTK_TREE_MODEL(edit_account.store), &iter, + COL_ACCOUNT, &ac, -1); + + account_set_as_default(ac); + account_update_dialog(); +} + +static void account_getall_toggled(GtkCellRenderer *cell, gchar *path_str, + gpointer data) +{ + GtkTreeIter iter; + PrefsAccount *ac; + GtkTreePath *path; + + path = gtk_tree_path_new_from_string(path_str); + gtk_tree_model_get_iter(GTK_TREE_MODEL(edit_account.store), + &iter, path); + gtk_tree_path_free(path); + gtk_tree_model_get(GTK_TREE_MODEL(edit_account.store), &iter, + COL_ACCOUNT, &ac, -1); + + if (ac->protocol == A_POP3 || ac->protocol == A_IMAP4 || + ac->protocol == A_NNTP) { + ac->recv_at_getall ^= TRUE; + account_set_row(ac, &iter, NULL, FALSE); + } +} + +static void account_row_activated(GtkTreeView *treeview, GtkTreePath *path, + GtkTreeViewColumn *column, gpointer data) +{ + account_edit_prefs(); +} + +static void account_row_reordered (GtkTreeModel *model, + GtkTreePath *path, + GtkTreeIter *iter, + gpointer data) +{ + GtkTreeIter iter_; + GtkTreePath *path_; + + if (!gtk_tree_selection_get_selected(edit_account.selection, + NULL, &iter_)) + return; + path_ = gtk_tree_model_get_path + (GTK_TREE_MODEL(edit_account.store), &iter_); + gtk_tree_view_scroll_to_cell(GTK_TREE_VIEW(edit_account.treeview), + path_, NULL, FALSE, 0.0, 0.0); + gtk_tree_path_free(path_); +} + +static gboolean account_key_pressed(GtkWidget *widget, GdkEventKey *event, + gpointer data) +{ + if (event && event->keyval == GDK_Escape) + account_edit_close(); + return FALSE; +} + +static void account_set_row(PrefsAccount *ac_prefs, GtkTreeIter *iter, + GtkTreeIter *new, gboolean move_view) +{ + GtkListStore *store = edit_account.store; + GtkTreeIter iter_; + const gchar *protocol, *server; + gboolean has_getall; + + g_return_if_fail(ac_prefs != NULL); + +#if USE_SSL + protocol = ac_prefs->protocol == A_POP3 ? + (ac_prefs->ssl_pop == SSL_TUNNEL ? + "POP3 (SSL)" : + ac_prefs->ssl_pop == SSL_STARTTLS ? + "POP3 (TLS)" : "POP3") : + ac_prefs->protocol == A_IMAP4 ? + (ac_prefs->ssl_imap == SSL_TUNNEL ? + "IMAP4 (SSL)" : + ac_prefs->ssl_imap == SSL_STARTTLS ? + "IMAP4 (TLS)" : "IMAP4") : + ac_prefs->protocol == A_NNTP ? + (ac_prefs->ssl_nntp == SSL_TUNNEL ? + "NNTP (SSL)" : "NNTP") : + ""; +#else + protocol = ac_prefs->protocol == A_POP3 ? "POP3" : + ac_prefs->protocol == A_IMAP4 ? "IMAP4" : + ac_prefs->protocol == A_NNTP ? "NNTP" : ""; +#endif + server = ac_prefs->protocol == A_NNTP ? + ac_prefs->nntp_server : ac_prefs->recv_server; + + has_getall = (ac_prefs->protocol == A_POP3 || + ac_prefs->protocol == A_IMAP4 || + ac_prefs->protocol == A_NNTP); + + if (!iter) + gtk_list_store_append(store, &iter_); + else + iter_ = *iter; + + gtk_list_store_set(store, &iter_, + COL_DEFAULT, ac_prefs->is_default, + COL_GETALL, has_getall && ac_prefs->recv_at_getall, + COL_NAME, ac_prefs->account_name, + COL_PROTOCOL, protocol, + COL_SERVER, server, + COL_ACCOUNT, ac_prefs, + -1); + + if (new) + *new = iter_; + + if (move_view) { + GtkTreePath *path; + + path = gtk_tree_model_get_path + (GTK_TREE_MODEL(edit_account.store), &iter_); + gtk_tree_view_scroll_to_cell + (GTK_TREE_VIEW(edit_account.treeview), + path, NULL, TRUE, 0.5, 0.0); + gtk_tree_path_free(path); + } +} + +/* set dialog from account list */ +static void account_set_dialog(void) +{ + GList *cur; + GtkTreeIter iter; + GtkTreePath *path; + + gtk_list_store_clear(edit_account.store); + + for (cur = account_get_list(); cur != NULL; cur = cur->next) { + account_set_row((PrefsAccount *)cur->data, NULL, &iter, FALSE); + if ((PrefsAccount *)cur->data == cur_account) { + gtk_tree_selection_select_iter(edit_account.selection, + &iter); + } + } + + if (!gtk_tree_selection_get_selected(edit_account.selection, NULL, + &iter)) + return; + path = gtk_tree_model_get_path(GTK_TREE_MODEL(edit_account.store), + &iter); + gtk_tree_view_scroll_to_cell(GTK_TREE_VIEW(edit_account.treeview), + path, NULL, FALSE, 0.0, 0.0); + gtk_tree_path_free(path); +} + +/* update dialog to the latest state */ +static void account_update_dialog(void) +{ + GtkTreeIter iter; + GtkTreeModel *model = GTK_TREE_MODEL(edit_account.store); + PrefsAccount *ac; + + if (!gtk_tree_model_get_iter_first(model, &iter)) + return; + + do { + gtk_tree_model_get(model, &iter, COL_ACCOUNT, &ac, -1); + if (ac) + account_set_row(ac, &iter, NULL, FALSE); + } while (gtk_tree_model_iter_next(model, &iter)); +} + +/* set account list from dialog */ +static void account_set_list(void) +{ + GtkTreeIter iter; + GtkTreeModel *model = GTK_TREE_MODEL(edit_account.store); + PrefsAccount *ac; + + account_list_free(); + + if (!gtk_tree_model_get_iter_first(model, &iter)) + return; + + do { + gtk_tree_model_get(model, &iter, COL_ACCOUNT, &ac, -1); + if (ac) + account_append(ac); + } while (gtk_tree_model_iter_next(model, &iter)); +} diff --git a/src/account_dialog.h b/src/account_dialog.h new file mode 100644 index 00000000..c9521240 --- /dev/null +++ b/src/account_dialog.h @@ -0,0 +1,35 @@ +/* + * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client + * Copyright (C) 1999-2005 Hiroyuki Yamamoto + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + */ + +#ifndef __ACCOUNT_DIALOG_H__ +#define __ACCOUNT_DIALOG_H__ + +#include + +#include "prefs_account.h" + +void account_set_menu (void); + +void account_edit_open (void); +void account_add (void); +void account_open (PrefsAccount *ac_prefs); + +void account_set_missing_folder(void); + +#endif /* __ACCOUNT_DIALOG_H__ */ diff --git a/src/folderview.c b/src/folderview.c index a93402f0..dabbdb18 100644 --- a/src/folderview.c +++ b/src/folderview.c @@ -62,6 +62,7 @@ #include "prefs_filter.h" #include "prefs_folder_item.h" #include "account.h" +#include "account_dialog.h" #include "folder.h" #include "inc.h" diff --git a/src/main.c b/src/main.c index d5484fe7..5bb948ae 100644 --- a/src/main.c +++ b/src/main.c @@ -59,6 +59,7 @@ #include "prefs_actions.h" #include "prefs_display_header.h" #include "account.h" +#include "account_dialog.h" #include "procmsg.h" #include "filter.h" #include "inc.h" @@ -222,6 +223,8 @@ int main(int argc, char *argv[]) #endif account_read_config_all(); + account_set_menu(); + main_window_reflect_prefs_all(); if (folder_read_list() < 0) { setup(mainwin); diff --git a/src/mainwindow.c b/src/mainwindow.c index e1493359..169ae208 100644 --- a/src/mainwindow.c +++ b/src/mainwindow.c @@ -72,6 +72,7 @@ #include "prefs_template.h" #include "action.h" #include "account.h" +#include "account_dialog.h" #include "addressbook.h" #include "logwindow.h" #include "manage_window.h" -- cgit v1.2.3