aboutsummaryrefslogtreecommitdiffstats
path: root/mail/mail-config.c
diff options
context:
space:
mode:
Diffstat (limited to 'mail/mail-config.c')
-rw-r--r--mail/mail-config.c95
1 files changed, 85 insertions, 10 deletions
diff --git a/mail/mail-config.c b/mail/mail-config.c
index 8b6692f64e..16c4bef88b 100644
--- a/mail/mail-config.c
+++ b/mail/mail-config.c
@@ -1012,7 +1012,7 @@ prepare_first (GnomeDruidPage *page, GnomeDruid *druid, gpointer user_data)
}
static struct identity_record idrec;
-static char *source, *transport;
+static char *source = NULL, *transport = NULL;
static void
cancel (GnomeDruid *druid, gpointer window)
@@ -1215,7 +1215,9 @@ mail_config_druid (void)
}
static gint identity_row = -1;
+static gint identity_max_row = -1;
static gint source_row = -1;
+static gint source_max_row = -1;
struct identity_dialog_data {
GtkWidget *clist;
@@ -1254,7 +1256,9 @@ on_cmdIdentityConfigDialogCancel_clicked (GtkWidget *dialog, gpointer user_data)
if (data && data->new_entry) {
gtk_clist_remove (GTK_CLIST (data->clist), identity_row);
- identity_row = -1;
+ identity_max_row--;
+ identity_row = identity_row > identity_max_row ? identity_max_row : identity_row;
+ gtk_clist_select_row (GTK_CLIST (data->clist), identity_row, 0);
}
}
@@ -1386,7 +1390,9 @@ on_SourceConfigDialogButton_clicked (GnomeDialog *dialog, int button, gpointer u
g_print ("Cancel clicked\n");
if (data && data->new_entry) {
gtk_clist_remove (GTK_CLIST (data->clist), source_row);
- source_row = -1;
+ source_max_row--;
+ source_row = source_row > source_max_row ? source_max_row : source_row;
+ gtk_clist_select_row (GTK_CLIST (data->clist), source_row, 0);
}
break;
}
@@ -1515,9 +1521,12 @@ on_cmdIdentityAdd_clicked (GtkWidget *widget, gpointer user_data)
char *text[] = { "", "", "", "" };
gtk_clist_append (GTK_CLIST (user_data), text);
+
if (identity_row > -1)
gtk_clist_unselect_row (GTK_CLIST (user_data), identity_row, 0);
- gtk_clist_select_row (GTK_CLIST (user_data), identity_row + 1, 0);
+
+ identity_max_row++;
+ gtk_clist_select_row (GTK_CLIST (user_data), identity_max_row, 0);
/* now create the editing dialog */
dialog = create_identity_config_dialog (FALSE, &idrec, GTK_WIDGET (user_data));
@@ -1570,11 +1579,12 @@ on_cmdSourcesAdd_clicked (GtkWidget *widget, gpointer user_data)
char *text[] = { "" };
gtk_clist_append (GTK_CLIST (user_data), text);
+ source_max_row++;
if (source_row > -1)
gtk_clist_unselect_row (GTK_CLIST (user_data), source_row, 0);
- gtk_clist_select_row (GTK_CLIST (user_data), source_row + 1, 0);
+ gtk_clist_select_row (GTK_CLIST (user_data), source_max_row, 0);
/* now create the editing dialog */
dialog = create_source_config_dialog (FALSE, &source, GTK_WIDGET (user_data));
@@ -1670,6 +1680,8 @@ providers_config_new (void)
GList *providers, *p, *sources, *transports;
GtkWidget *table, *interior_notebook;
char *titles[] = { _("Name"), _("Address"), _("Organization"), _("Signature file") };
+ char *path;
+ gboolean configured;
int page;
@@ -1739,11 +1751,50 @@ providers_config_new (void)
gtk_clist_set_column_width (GTK_CLIST (clistIdentities), 0, 80);
gtk_clist_column_titles_show (GTK_CLIST (clistIdentities));
- /* TODO: we should really have a GList of identities */
- idrec.name = NULL;
- idrec.address = NULL;
- idrec.organization = NULL;
- idrec.sigfile = NULL;
+ /* Find out if stuff has been configured */
+ path = g_strdup_printf ("=%s/config=/mail/configured", evolution_dir);
+ configured = gnome_config_get_bool (path);
+ g_free (path);
+
+ identity_row = -1;
+ if (configured) {
+ char *text[] = { "", "", "", "" };
+ struct identity_record *data;
+
+ /* add an entry to the identity clist */
+ gtk_clist_append (GTK_CLIST (clistIdentities), text);
+ identity_max_row = 0;
+
+ path = g_strdup_printf ("=%s/config=/mail/id_name", evolution_dir);
+ idrec.name = gnome_config_get_string (path);
+ gtk_clist_set_text (GTK_CLIST (clistIdentities), 0, 0, idrec.name);
+ g_free (path);
+
+ path = g_strdup_printf ("=%s/config=/mail/id_addr", evolution_dir);
+ idrec.address = gnome_config_get_string (path);
+ gtk_clist_set_text (GTK_CLIST (clistIdentities), 0, 1, idrec.address);
+ g_free (path);
+
+ path = g_strdup_printf ("=%s/config=/mail/id_org", evolution_dir);
+ idrec.organization = gnome_config_get_string (path);
+ gtk_clist_set_text (GTK_CLIST (clistIdentities), 0, 2, idrec.organization);
+ g_free (path);
+
+ path = g_strdup_printf ("=%s/config=/mail/id_sig", evolution_dir);
+ idrec.sigfile = gnome_config_get_string (path);
+ gtk_clist_set_text (GTK_CLIST (clistIdentities), 0, 3, idrec.sigfile);
+ g_free (path);
+
+ data = g_malloc0 (sizeof (struct identity_record));
+ data->name = g_strdup (idrec.name);
+ data->address = g_strdup (idrec.address);
+ data->organization = g_strdup (idrec.organization);
+ data->sigfile = g_strdup (idrec.sigfile);
+ gtk_clist_set_row_data (GTK_CLIST (clistIdentities), 0, data);
+ } else {
+ identity_max_row = -1;
+ }
+
lblIdentities = gtk_label_new (_("Identities"));
gtk_widget_set_name (lblIdentities, "lblIdentities");
@@ -1825,6 +1876,25 @@ providers_config_new (void)
gtk_clist_set_column_width (GTK_CLIST (clistSources), 0, 80);
gtk_clist_column_titles_show (GTK_CLIST (clistSources));
+ if (configured && !source) {
+ path = g_strdup_printf ("=%s/config=/mail/source", evolution_dir);
+ source = gnome_config_get_string (path);
+ g_free (path);
+ }
+
+ source_row = -1;
+ if (source) {
+ char *text[] = { "" };
+
+ gtk_clist_append (GTK_CLIST (clistSources), text);
+ source_max_row = 0;
+
+ gtk_clist_set_text (GTK_CLIST (clistSources), 0, 0, source);
+ gtk_clist_set_row_data (GTK_CLIST (clistSources), 0, g_strdup(source));
+ } else {
+ source_max_row = -1;
+ }
+
lblMailSources = gtk_label_new (_("Mail sources"));
gtk_widget_set_name (lblMailSources, "lblMailSources");
gtk_widget_ref (lblMailSources);
@@ -1889,6 +1959,11 @@ providers_config_new (void)
(GtkDestroyNotify) gtk_widget_unref);
gtk_widget_show (transport_page_vbox);
gtk_container_add (GTK_CONTAINER (notebook), transport_page_vbox);
+ if (configured && !transport) {
+ path = g_strdup_printf ("=%s/config=/mail/transport", evolution_dir);
+ transport = gnome_config_get_string (path);
+ g_free (path);
+ }
create_transport_page (transport_page_vbox, transports, &transport);
/* Set the data in the transports page */