* some changes in the account-dialog in modest.glade, for better handling
[modest] / src / gtk-glade / modest-ui-wizard.c
index 9ec2514..b323495 100644 (file)
 #endif /*HAVE_CONFIG_H*/
 
 #include "../modest-account-mgr.h"
+#include "../modest-identity-mgr.h"
 
 #include "modest-ui-glade.h"
 #include "modest-ui-wizard.h"
 
-void wizard_missing_notification(GtkWindow *parent, gchar *info_message)
-{
+
+static void wizard_incoming_button_toggled(GtkWidget *button,
+                                          gpointer userdata) {
+       GtkWidget *awidget;
+       if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON(button))==TRUE) {
+               awidget=glade_xml_get_widget(GLADE_XML(userdata), "AWOutUserNameEntry");
+               gtk_widget_set_sensitive(GTK_WIDGET(awidget), FALSE);
+               awidget=glade_xml_get_widget(GLADE_XML(userdata), "AWOutPasswordEntry");
+               gtk_widget_set_sensitive(GTK_WIDGET(awidget), FALSE);
+       }
+       else {
+               awidget=glade_xml_get_widget(GLADE_XML(userdata), "AWOutUserNameEntry");
+               gtk_widget_set_sensitive(GTK_WIDGET(awidget), TRUE);
+               awidget=glade_xml_get_widget(GLADE_XML(userdata), "AWOutPasswordEntry");
+               gtk_widget_set_sensitive(GTK_WIDGET(awidget), TRUE);
+       }
+}
+
+void wizard_missing_notification(GtkWindow *parent, gchar *info_message) {
         GtkWidget *DenyDialog;
 
         DenyDialog=gtk_message_dialog_new(parent,
@@ -32,8 +50,7 @@ void wizard_missing_notification(GtkWindow *parent, gchar *info_message)
         gtk_widget_destroy(DenyDialog);
 }
 
-gchar *gtk_combo_box_get_entry_text (GtkWidget *combobox)
-{
+gchar *get_text_from_combobox (GtkWidget *combobox){
         /* Remember to free the returned variable after usage! */
 
        GtkTreeModel *model = gtk_combo_box_get_model(GTK_COMBO_BOX(combobox));
@@ -41,8 +58,7 @@ gchar *gtk_combo_box_get_entry_text (GtkWidget *combobox)
 
        gchar *value;
 
-       if (gtk_combo_box_get_active_iter(GTK_COMBO_BOX(combobox), &iter))
-       {
+       if (gtk_combo_box_get_active_iter(GTK_COMBO_BOX(combobox), &iter)) {
                gtk_tree_model_get(GTK_TREE_MODEL(model),
                                   &iter,
                                   0, &value,
@@ -53,53 +69,161 @@ gchar *gtk_combo_box_get_entry_text (GtkWidget *combobox)
 }
 
 
-gboolean advance_sanity_check(GtkWindow *parent, GladeXML *glade_xml, gint cp)
-{
-        GtkDialog *DenyDialog;
-        gchar *bla;
-
-        switch (cp)
-        {
-        case 0:
-                if (strlen(gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWMailboxnameEntry"))))==0)
-                {
-                        /* FIXME:
-                         * all calls to wizard_missing_notification lack the parent window.
-                         */
-                        wizard_missing_notification(NULL, "Please enter mailbox name");
-                        return FALSE;
-                }
-                bla=gtk_combo_box_get_active_text(GTK_COMBO_BOX(glade_xml_get_widget(glade_xml, "AWMailboxtypeComboBox")));
-                if (bla==NULL)
-                {
-                        wizard_missing_notification(NULL, "Please select mailbox type");
-                        return FALSE;
-                }
+gboolean advance_sanity_check(GladeXML *glade_xml, gint cp) {
+        gchar *tmptext;
+
+       /* FIXME:
+        * all calls to wizard_missing_notification lack the parent window.
+        */
+
+        switch (cp) {
+       case 1:
+               /* Only needed if the "mailbox name" field is used in the first page of the wizard.
+                 * if (strlen(gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWMailboxnameEntry"))))==0)
+                 * {
+                 *         wizard_missing_notification(NULL, "Please enter mailbox name");
+                 *         return FALSE;
+                * }
+                */
+               if (strlen(gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWEMailAddressEntry"))))==0) {
+                       wizard_missing_notification(NULL, "Please enter the E-Mail address.");
+                       return FALSE;
+               }
                 return TRUE;
-                break;
-
+               break;
+       case 2:
+                tmptext=gtk_combo_box_get_active_text(GTK_COMBO_BOX(glade_xml_get_widget(glade_xml, "AWMailboxtypeComboBox")));
+                if (tmptext==NULL) {
+                        wizard_missing_notification(NULL, "Please select mailbox type.");
+                        return FALSE;
+               }
+               g_free(tmptext);
+               if (strlen(gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWInServerComboEntry"))))==0) {
+                       wizard_missing_notification(NULL, "Please specify incoming server adress.");
+                       return FALSE;
+               }
+               if (strlen(gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWUserNameEntry"))))==0) {
+                       wizard_missing_notification(NULL, "Please enter user name.");
+                       return FALSE;
+               }
+               return TRUE;
+               break;
+       case 3:
+               if (strlen(gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWOutServerComboEntry"))))==0) {
+                       wizard_missing_notification(NULL, "Please specify outgoing server address.");
+                       return FALSE;
+               }
+               /* smtp servers may work without a username
+               if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(glade_xml_get_widget(glade_xml, "AWUseIncomingCheckButton")))==FALSE
+                   && strlen(gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWOutUserNameEntry"))))==0) {
+                       wizard_missing_notification(NULL, "Please enter user name.");
+                       return FALSE;
+               } */
+
+               return TRUE;
+               break;
         }
 
         return FALSE;
 }
 
-void on_new_account1_activate (GtkMenuItem *menuitem,
-                               gpointer user_data)
+gchar *search_unused_account_or_identity_name(gpointer mgr, gchar *draft) {
+       GString *tmpaccount_name;
+       gint counter;
+
+       tmpaccount_name=g_string_new("");
+       g_string_printf(tmpaccount_name, "%s", draft);
+       if(MODEST_IS_ACCOUNT_MGR(mgr)) {
+               for(counter=0; modest_account_mgr_server_account_exists(mgr, tmpaccount_name->str, NULL); counter++)
+                       g_string_printf(tmpaccount_name, "%s%d", draft, counter);
+       }
+       else
+               for(counter=0;      modest_identity_mgr_identity_exists(mgr, tmpaccount_name->str, NULL); counter++)
+                       g_string_printf(tmpaccount_name, "%s%d", draft, counter);
+
+       return g_string_free(tmpaccount_name, FALSE);
+}
+
+gboolean wizard_account_add(GladeXML *glade_xml, ModestUI *modest_ui)
+{
+       ModestAccountMgr *acc_mgr;
+       ModestIdentityMgr *id_mgr;
+        gchar *store;
+        gchar *transport;
+        gchar *identity;
+       ModestUIPrivate *priv;
+       ModestConf *conf;
+       gchar *tmptext;
+       gchar *tmptext2;
+
+       g_return_val_if_fail (MODEST_IS_UI(modest_ui), FALSE);
+       priv = MODEST_UI_GET_PRIVATE(MODEST_UI(modest_ui));
+       conf = priv->modest_conf;
+
+       acc_mgr = priv->modest_acc_mgr;
+       id_mgr = priv->modest_id_mgr;
+
+       tmptext2=get_text_from_combobox(glade_xml_get_widget(glade_xml, "AWMailboxtypeComboBox"));
+       tmptext=g_utf8_strdown(tmptext2, -1);
+       g_free(tmptext2);
+
+       store=search_unused_account_or_identity_name(acc_mgr, "incoming");
+       modest_account_mgr_add_server_account (acc_mgr,
+                                              store,
+                                              gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWInServerComboEntry"))),
+                                              gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWUserNameEntry"))),
+                                              gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWPasswordEntry"))),
+                                              tmptext);
+       g_free(store);
+       g_free(tmptext);
+
+        transport=search_unused_account_or_identity_name(acc_mgr, "outgoing");
+       if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(glade_xml_get_widget(glade_xml, "AWUseIncomingCheckButton")))==TRUE)
+               modest_account_mgr_add_server_account (acc_mgr,
+                                                      transport,
+                                                      gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWOutServerComboEntry"))),
+                                                      gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWUserNameEntry"))),
+                                                      gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWPasswordEntry"))),
+                                                      "smtp");
+       else
+               modest_account_mgr_add_server_account (acc_mgr,
+                                                      transport,
+                                                      gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWOutServerComboEntry"))),
+                                                      gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWOutUserNameEntry"))),
+                                                      gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWOutPasswordEntry"))),
+                                                      "smtp");
+
+       identity=search_unused_account_or_identity_name(id_mgr, MODEST_IDENTITY_DEFAULT_IDENTITY);
+       if (!modest_identity_mgr_add_identity (id_mgr,
+                                               identity,
+                                              gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWRealNameEntry"))),
+                                              gtk_entry_get_text(GTK_ENTRY(glade_xml_get_widget(glade_xml, "AWEMailAddressEntry"))),
+                                              "", "", FALSE, transport, FALSE ))
+               g_warning ("failed to add default identity");
+
+       g_free(transport);
+       g_free(identity);
+       return TRUE;
+}
+
+
+void wizard_account_dialog(ModestUI *modest_ui)
 {
        GladeXML *glade_xml;
        GtkWidget *dialog;
         ModestUIPrivate *priv;
-        GtkWidget *FinishButton;
-        GtkWidget *BackButton;
-        GtkWidget *NextButton;
-        GtkWidget *CancelButton;
-        GtkWidget *Notebook;
-        GtkWidget *awidget;
+        GtkWidget *finish_button;
+        GtkWidget *back_button;
+        GtkWidget *next_button;
+        GtkWidget *cancel_button;
+       GtkWidget *notebook;
+       GtkWidget *use_incoming_button;
         gint cp;
         gint result;
-        gint finishallowed=0;
+       gboolean account_added_successfully=FALSE;
 
-       priv = MODEST_UI_GET_PRIVATE(MODEST_UI(user_data));
+       g_return_if_fail(MODEST_IS_UI(modest_ui));
+       priv = MODEST_UI_GET_PRIVATE(MODEST_UI(modest_ui));
 
        glade_xml = glade_xml_new(MODEST_GLADE, "account_wizard", NULL);
 
@@ -107,59 +231,73 @@ void on_new_account1_activate (GtkMenuItem *menuitem,
 
         gtk_widget_show_all(dialog);
 
-        FinishButton=glade_xml_get_widget(glade_xml, "AWFinishButton");
-        BackButton=glade_xml_get_widget(glade_xml, "AWBackButton");
-        NextButton=glade_xml_get_widget(glade_xml, "AWNextButton");
-        CancelButton=glade_xml_get_widget(glade_xml, "AWCancelButton");
-        Notebook=glade_xml_get_widget(glade_xml, "AWNotebook");
-
-        gtk_widget_set_sensitive(FinishButton, FALSE);
-
-        do
-        {
-                cp=gtk_notebook_get_current_page(GTK_NOTEBOOK(Notebook));
-                switch (cp)
-                {
-                case 0:
-                        gtk_widget_set_sensitive(BackButton, FALSE);
-                        break;
+        finish_button=glade_xml_get_widget(glade_xml, "AWFinishButton");
+        back_button=glade_xml_get_widget(glade_xml, "AWBackButton");
+        next_button=glade_xml_get_widget(glade_xml, "AWNextButton");
+        cancel_button=glade_xml_get_widget(glade_xml, "AWCancelButton");
+        notebook=glade_xml_get_widget(glade_xml, "AWNotebook");
+
+       gtk_widget_set_sensitive(finish_button, FALSE);
+
+       use_incoming_button=glade_xml_get_widget(glade_xml, "AWUseIncomingCheckButton");
+       g_signal_connect(use_incoming_button,
+                        "toggled",
+                        G_CALLBACK(wizard_incoming_button_toggled),
+                        glade_xml);
+
+       /* First page not used currently. It's reserved for the account preset. */
+       gtk_notebook_set_current_page (GTK_NOTEBOOK(notebook), 1);
+
+        do {
+                cp=gtk_notebook_get_current_page(GTK_NOTEBOOK(notebook));
+                switch (cp) {
                 case 1:
-                        gtk_widget_set_sensitive(BackButton, TRUE);
+                        gtk_widget_set_sensitive(back_button, FALSE);
                         break;
                 case 2:
-                        gtk_widget_set_sensitive(FinishButton, FALSE);
-                        gtk_widget_set_sensitive(NextButton, TRUE);
+                        gtk_widget_set_sensitive(back_button, TRUE);
                         break;
                 case 3:
-                        gtk_widget_set_sensitive(FinishButton, TRUE);
-                        gtk_widget_set_sensitive(NextButton, FALSE);
+                        gtk_widget_set_sensitive(finish_button, FALSE);
+                        gtk_widget_set_sensitive(next_button, TRUE);
+                        break;
+                case 4:
+                        gtk_widget_set_sensitive(finish_button, TRUE);
+                        gtk_widget_set_sensitive(next_button, FALSE);
                         break;
                 default:
-                        g_error("I'm on page %d of notebook AWNotebook, which shouldn't have happened. Pulling Emeregency breaks.", cp);
+                        g_error("I'm on page %d of notebook AWNotebook, which shouldn't have happened. Pulling emergency breaks.", cp);
                         break;
                 }
 
                 result=gtk_dialog_run(GTK_DIALOG(dialog));
 
-                switch (result)
-                {
+                switch (result) {
                 case 1:
-                        if (advance_sanity_check(NULL, glade_xml, cp)==TRUE)
-                                gtk_notebook_next_page(GTK_NOTEBOOK(Notebook));
+                        if (advance_sanity_check(glade_xml, cp)==TRUE)
+                                gtk_notebook_next_page(GTK_NOTEBOOK(notebook));
                         break;
                 case 2:
-                        gtk_notebook_prev_page(GTK_NOTEBOOK(Notebook));
-                        break;
+                        gtk_notebook_prev_page(GTK_NOTEBOOK(notebook));
+                       break;
+               case GTK_RESPONSE_ACCEPT:
+                       account_added_successfully=wizard_account_add(glade_xml, modest_ui);
+                       break;
+               default:
+                       account_added_successfully=FALSE;
                 }
         }
-        while(result!=GTK_RESPONSE_DELETE_EVENT && result!=GTK_RESPONSE_ACCEPT && result!=GTK_RESPONSE_CANCEL);
-
-        if (result==GTK_RESPONSE_ACCEPT)
-        {
-                /* Do someting with the DATA from the widget */
-        }
+        while(result!=GTK_RESPONSE_DELETE_EVENT && result!=GTK_RESPONSE_CANCEL && account_added_successfully!=TRUE);
 
        gtk_widget_destroy(dialog);
        g_object_unref(glade_xml);
 }
 
+void new_wizard_account (GtkWidget *widget,
+                        gpointer user_data)
+{
+       /* This will probably never be used to modify any existing account. */
+       wizard_account_dialog(MODEST_UI(user_data));
+}
+
+