diff options
Diffstat (limited to 'mail/mail-config.c')
-rw-r--r-- | mail/mail-config.c | 174 |
1 files changed, 130 insertions, 44 deletions
diff --git a/mail/mail-config.c b/mail/mail-config.c index 825ccc6b16..9223a9da75 100644 --- a/mail/mail-config.c +++ b/mail/mail-config.c @@ -2,8 +2,9 @@ /* mail-config.c: Mail configuration dialogs/wizard. */ /* - * Author: + * Authors: * Dan Winship <danw@helixcode.com> + * Jeffrey Stedfast <fejj@helixcode.com> * * Copyright 2000 Helix Code, Inc. (http://www.helixcode.com) * @@ -60,6 +61,7 @@ static void prepare_service (GnomeDruidPage *page, gpointer arg1, gpointer user_ static void auth_menuitem_activate (GtkObject *menuitem, GtkHTML *html); static void fill_auth_menu (GtkOptionMenu *optionmenu, GtkHTML *html, GList *authtypes); static char *get_service_url (GtkObject *table); +static void set_service_url (GtkObject *table, char *url_str); static void autodetect_cb (GtkWidget *button, GtkObject *table); static gboolean service_acceptable (GtkNotebook *notebook); static gboolean service_next (GnomeDruidPage *page, gpointer arg1, gpointer user_data); @@ -85,7 +87,6 @@ static void on_cmdSourcesAdd_clicked (GtkButton *button, gpointer user_data); static void on_cmdSourcesEdit_clicked (GtkButton *button, gpointer user_data); static void on_cmdSourcesDelete_clicked (GtkButton *button, gpointer user_data); static void on_cmdCamelServicesOK_clicked (GtkButton *button, gpointer user_data); -static void on_cmdCamelServicesApply_clicked (GtkButton *button, gpointer user_data); static void on_cmdCamelServicesCancel_clicked (GtkButton *button, gpointer user_data); @@ -390,8 +391,8 @@ prepare_service (GnomeDruidPage *page, gpointer arg1, gpointer user_data) GtkWidget *table; GtkEntry *entry; - table = gtk_notebook_get_nth_page ( - notebook, gtk_notebook_get_current_page (notebook)); + table = gtk_notebook_get_nth_page (notebook, + gtk_notebook_get_current_page (notebook)); if (username) { char *data = NULL; @@ -482,6 +483,56 @@ get_service_url (GtkObject *table) } static void +set_service_url (GtkObject *table, char *url_str) +{ + CamelURL *url; + GtkEditable *editable; + GtkOptionMenu *auth_optionmenu; + CamelException *ex; + + g_return_if_fail (table != NULL); + g_return_if_fail (url_str != NULL); + + ex = camel_exception_new (); + + url = camel_url_new (url_str, ex); + if (camel_exception_get_id (ex) != CAMEL_EXCEPTION_NONE) + return; + + editable = gtk_object_get_data (table, "user_entry"); + if (editable && url) + gtk_entry_set_text (GTK_ENTRY (editable), url->user); + + editable = gtk_object_get_data (table, "server_entry"); + if (editable && url) + gtk_entry_set_text (GTK_ENTRY (editable), url->host); + + editable = gtk_object_get_data (table, "path_entry"); + if (editable && url) + gtk_entry_set_text (GTK_ENTRY (editable), url->path); + + /* How are we gonna do this? */ +#if 0 + auth_optionmenu = gtk_object_get_data (table, "auth_optionmenu"); + if (auth_optionmenu) { + GtkWidget *menu, *item; + CamelServiceAuthType *authtype; + + menu = gtk_option_menu_get_menu (auth_optionmenu); + if (menu) { + item = gtk_menu_get_active (GTK_MENU (menu)); + authtype = gtk_object_get_data (GTK_OBJECT (item), + "authtype"); + if (*authtype->authproto) + url->authmech = g_strdup (authtype->authproto); + } + } +#endif + camel_exception_free (ex); + camel_url_free (url); +} + +static void autodetect_cb (GtkWidget *button, GtkObject *table) { char *url; @@ -508,6 +559,7 @@ autodetect_cb (GtkWidget *button, GtkObject *table) html = gtk_object_get_data (table, "auth_html"); optionmenu = gtk_object_get_data (table, "auth_optionmenu"); fill_auth_menu (optionmenu, html, authtypes); + camel_exception_free (ex); return; error: @@ -530,6 +582,7 @@ service_acceptable (GtkNotebook *notebook) page = gtk_notebook_get_current_page (notebook); table = gtk_notebook_get_nth_page (notebook, page); check = gtk_object_get_data (GTK_OBJECT (table), "check"); + if (!check || !gtk_toggle_button_get_active (check)) return TRUE; @@ -548,6 +601,8 @@ service_acceptable (GtkNotebook *notebook) camel_service_disconnect (service, ex); gtk_object_unref (GTK_OBJECT (service)); + camel_exception_free (ex); + if (ok) return TRUE; @@ -1169,14 +1224,21 @@ on_cmdSourcesDelete_clicked (GtkButton *button, gpointer user_data) static void on_cmdCamelServicesOK_clicked (GtkButton *button, gpointer user_data) { - on_cmdCamelServicesOK_clicked (button, user_data); - gtk_widget_destroy(GTK_WIDGET (user_data)); -} + GtkWidget *notebook, *interior_notebook; + GtkWidget *vbox; -static void -on_cmdCamelServicesApply_clicked (GtkButton *button, gpointer user_data) -{ - + notebook = gtk_object_get_data (GTK_OBJECT (user_data), "notebook"); + + /* switch to the third page which is the transport page */ + gtk_notebook_set_page (GTK_NOTEBOOK (notebook), 2); + + vbox = gtk_object_get_data (GTK_OBJECT (notebook), "transport_page_vbox"); + interior_notebook = gtk_object_get_data (GTK_OBJECT (vbox), "notebook"); + + if (service_acceptable (GTK_NOTEBOOK (interior_notebook))) { + destroy_service (GTK_OBJECT (interior_notebook), (gpointer) &transport); + gtk_widget_destroy(GTK_WIDGET (user_data)); + } } static void @@ -1190,7 +1252,7 @@ providers_config_new (void) { GtkWidget *providers_config; GtkWidget *dialog_vbox1; - GtkWidget *notebook1; + GtkWidget *notebook; GtkWidget *hbox1; GtkWidget *scrolledwindow1; GtkWidget *clistIdentities; @@ -1209,15 +1271,35 @@ providers_config_new (void) GtkWidget *cmdSourcesEdit; GtkWidget *cmdSourcesDelete; GtkWidget *lblProviders; - GtkWidget *empty_notebook_page; GtkWidget *lblTransports; GtkWidget *dialog_action_area1; GtkWidget *cmdCamelServicesOK; - GtkWidget *cmdCamelServicesApply; GtkWidget *cmdCamelServicesCancel; - GtkWidget *transport_page; - struct service_type st; + GtkWidget *transport_page_vbox; GList *providers, *p, *sources, *transports; + GtkWidget *table, *interior_notebook; + int page; + + + /* Fetch list of all providers. */ + providers = camel_session_list_providers (session, TRUE); + sources = transports = NULL; + for (p = providers; p; p = p->next) { + CamelProvider *prov = p->data; + + if (strcmp (prov->domain, "mail") != 0) + continue; + + if (prov->object_types[CAMEL_PROVIDER_STORE]) { + sources = add_service (sources, + CAMEL_PROVIDER_STORE, + prov); + } else if (prov->object_types[CAMEL_PROVIDER_TRANSPORT]) { + transports = add_service (transports, + CAMEL_PROVIDER_TRANSPORT, + prov); + } + } providers_config = gnome_dialog_new (_("Camel Providers Configuration"), NULL); gtk_window_set_modal (GTK_WINDOW (providers_config), TRUE); @@ -1230,13 +1312,13 @@ providers_config_new (void) gtk_object_set_data (GTK_OBJECT (providers_config), "dialog_vbox1", dialog_vbox1); gtk_widget_show (dialog_vbox1); - notebook1 = gtk_notebook_new (); - gtk_widget_set_name (notebook1, "notebook1"); - gtk_widget_ref (notebook1); - gtk_object_set_data_full (GTK_OBJECT (providers_config), "notebook1", notebook1, + notebook = gtk_notebook_new (); + gtk_widget_set_name (notebook, "notebook"); + gtk_widget_ref (notebook); + gtk_object_set_data_full (GTK_OBJECT (providers_config), "notebook", notebook, (GtkDestroyNotify) gtk_widget_unref); - gtk_widget_show (notebook1); - gtk_box_pack_start (GTK_BOX (dialog_vbox1), notebook1, TRUE, TRUE, 0); + gtk_widget_show (notebook); + gtk_box_pack_start (GTK_BOX (dialog_vbox1), notebook, TRUE, TRUE, 0); hbox1 = gtk_hbox_new (FALSE, 0); gtk_widget_set_name (hbox1, "hbox1"); @@ -1244,7 +1326,7 @@ providers_config_new (void) gtk_object_set_data_full (GTK_OBJECT (providers_config), "hbox1", hbox1, (GtkDestroyNotify) gtk_widget_unref); gtk_widget_show (hbox1); - gtk_container_add (GTK_CONTAINER (notebook1), hbox1); + gtk_container_add (GTK_CONTAINER (notebook), hbox1); scrolledwindow1 = gtk_scrolled_window_new (NULL, NULL); gtk_widget_set_name (scrolledwindow1, "scrolledwindow1"); @@ -1314,7 +1396,7 @@ providers_config_new (void) gtk_object_set_data_full (GTK_OBJECT (providers_config), "lblIdentity", lblIdentity, (GtkDestroyNotify) gtk_widget_unref); gtk_widget_show (lblIdentity); - gtk_notebook_set_tab_label (GTK_NOTEBOOK (notebook1), gtk_notebook_get_nth_page (GTK_NOTEBOOK (notebook1), 0), + gtk_notebook_set_tab_label (GTK_NOTEBOOK (notebook), gtk_notebook_get_nth_page (GTK_NOTEBOOK (notebook), 0), lblIdentity); hbox2 = gtk_hbox_new (FALSE, 0); @@ -1323,7 +1405,7 @@ providers_config_new (void) gtk_object_set_data_full (GTK_OBJECT (providers_config), "hbox2", hbox2, (GtkDestroyNotify) gtk_widget_unref); gtk_widget_show (hbox2); - gtk_container_add (GTK_CONTAINER (notebook1), hbox2); + gtk_container_add (GTK_CONTAINER (notebook), hbox2); scrolledwindow2 = gtk_scrolled_window_new (NULL, NULL); gtk_widget_set_name (scrolledwindow2, "scrolledwindow2"); @@ -1394,14 +1476,29 @@ providers_config_new (void) gtk_object_set_data_full (GTK_OBJECT (providers_config), "lblProviders", lblProviders, (GtkDestroyNotify) gtk_widget_unref); gtk_widget_show (lblProviders); - gtk_notebook_set_tab_label (GTK_NOTEBOOK (notebook1), gtk_notebook_get_nth_page (GTK_NOTEBOOK (notebook1), 1), + gtk_notebook_set_tab_label (GTK_NOTEBOOK (notebook), gtk_notebook_get_nth_page (GTK_NOTEBOOK (notebook), 1), lblProviders); -#if 0 - transport_page = create_transport (&st); - gtk_widget_show (transport_page); - gtk_container_add (GTK_CONTAINER (notebook1), transport_page); -#endif + + /* Setup the transport page */ + transport_page_vbox = gtk_vbox_new (FALSE, 0); + gtk_container_set_border_width (GTK_CONTAINER (transport_page_vbox), 8); + gtk_box_set_spacing (GTK_BOX (transport_page_vbox), 5); + gtk_widget_set_name (transport_page_vbox, "transport_page_vbox"); + gtk_object_set_data (GTK_OBJECT (notebook), "transport_page_vbox", transport_page_vbox); + gtk_widget_ref (transport_page_vbox); + gtk_object_set_data_full (GTK_OBJECT (providers_config), "transport_page_vbox", transport_page_vbox, + (GtkDestroyNotify) gtk_widget_unref); + gtk_widget_show (transport_page_vbox); + gtk_container_add (GTK_CONTAINER (notebook), transport_page_vbox); + create_transport_page (transport_page_vbox, transports, &transport); + + /* Set the data in the transports page */ + interior_notebook = gtk_object_get_data (GTK_OBJECT (transport_page_vbox), "notebook"); + page = gtk_notebook_get_current_page (GTK_NOTEBOOK (interior_notebook)); + table = gtk_notebook_get_nth_page (GTK_NOTEBOOK (interior_notebook), page); + set_service_url (GTK_OBJECT (table), transport); + lblTransports = gtk_label_new (_("Transports")); gtk_widget_set_name (lblTransports, "lblTransports"); @@ -1409,7 +1506,7 @@ providers_config_new (void) gtk_object_set_data_full (GTK_OBJECT (providers_config), "lblTransports", lblTransports, (GtkDestroyNotify) gtk_widget_unref); gtk_widget_show (lblTransports); - gtk_notebook_set_tab_label (GTK_NOTEBOOK (notebook1), gtk_notebook_get_nth_page (GTK_NOTEBOOK (notebook1), 2), + gtk_notebook_set_tab_label (GTK_NOTEBOOK (notebook), gtk_notebook_get_nth_page (GTK_NOTEBOOK (notebook), 2), lblTransports); dialog_action_area1 = GNOME_DIALOG (providers_config)->action_area; @@ -1428,15 +1525,6 @@ providers_config_new (void) gtk_widget_show (cmdCamelServicesOK); GTK_WIDGET_SET_FLAGS (cmdCamelServicesOK, GTK_CAN_DEFAULT); - gnome_dialog_append_button (GNOME_DIALOG (providers_config), GNOME_STOCK_BUTTON_APPLY); - cmdCamelServicesApply = g_list_last (GNOME_DIALOG (providers_config)->buttons)->data; - gtk_widget_set_name (cmdCamelServicesApply, "cmdCamelServicesApply"); - gtk_widget_ref (cmdCamelServicesApply); - gtk_object_set_data_full (GTK_OBJECT (providers_config), "cmdCamelServicesApply", cmdCamelServicesApply, - (GtkDestroyNotify) gtk_widget_unref); - gtk_widget_show (cmdCamelServicesApply); - GTK_WIDGET_SET_FLAGS (cmdCamelServicesApply, GTK_CAN_DEFAULT); - gnome_dialog_append_button (GNOME_DIALOG (providers_config), GNOME_STOCK_BUTTON_CANCEL); cmdCamelServicesCancel = g_list_last (GNOME_DIALOG (providers_config)->buttons)->data; gtk_widget_set_name (cmdCamelServicesCancel, "cmdCamelServicesCancel"); @@ -1467,9 +1555,6 @@ providers_config_new (void) gtk_signal_connect (GTK_OBJECT (cmdCamelServicesOK), "clicked", GTK_SIGNAL_FUNC (on_cmdCamelServicesOK_clicked), providers_config); - gtk_signal_connect (GTK_OBJECT (cmdCamelServicesApply), "clicked", - GTK_SIGNAL_FUNC (on_cmdCamelServicesApply_clicked), - providers_config); gtk_signal_connect (GTK_OBJECT (cmdCamelServicesCancel), "clicked", GTK_SIGNAL_FUNC (on_cmdCamelServicesCancel_clicked), providers_config); @@ -1481,3 +1566,4 @@ providers_config_new (void) + |