aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--plugins/exchange-account-setup/ChangeLog7
-rw-r--r--plugins/exchange-account-setup/exchange-ask-password.c68
-rw-r--r--plugins/exchange-account-setup/org-gnome-exchange-account-setup.eplug.in18
3 files changed, 38 insertions, 55 deletions
diff --git a/plugins/exchange-account-setup/ChangeLog b/plugins/exchange-account-setup/ChangeLog
index 8d12a4ec5d..c86787d10d 100644
--- a/plugins/exchange-account-setup/ChangeLog
+++ b/plugins/exchange-account-setup/ChangeLog
@@ -1,5 +1,12 @@
2005-01-11 Not Zed <NotZed@Ximian.com>
+ * org-gnome-exchange-account-setup.eplug.in: Removed page check plugin
+
+ * exchange-ask-password.c: Added a button to prompt for password
+ instead of listening on page next signal
+
+2005-01-11 Not Zed <NotZed@Ximian.com>
+
* Makefile.am: fix LDFLAGS variable name.
2005-01-10 Sushma Rai <rsushma@novell.com>
diff --git a/plugins/exchange-account-setup/exchange-ask-password.c b/plugins/exchange-account-setup/exchange-ask-password.c
index 31e12e98a4..a5da9ccdf4 100644
--- a/plugins/exchange-account-setup/exchange-ask-password.c
+++ b/plugins/exchange-account-setup/exchange-ask-password.c
@@ -39,13 +39,13 @@
int e_plugin_lib_enable (EPluginLib *ep, int enable);
-gboolean org_gnome_exchange_ask_password (EPlugin *epl, EConfigHookPageCheckData *data);
+//gboolean org_gnome_exchange_ask_password (EPlugin *epl, EConfigHookPageCheckData *data);
GtkWidget *org_gnome_exchange_read_url(EPlugin *epl, EConfigHookItemFactoryData *data);
char *owa_entry_text = NULL;
static gboolean
-validate_exchange_user (EConfig *ec, const char *pageid, void *data)
+validate_exchange_user (void *data)
{
EMConfigTargetAccount *target_account = data;
CamelURL *url=NULL;
@@ -75,26 +75,49 @@ validate_exchange_user (EConfig *ec, const char *pageid, void *data)
}
static void
+ok_button_clicked (GtkWidget *button, void *data)
+{
+ validate_exchange_user (data); // FIXME: return value
+}
+
+static void
owa_entry_changed (GtkWidget *entry, void *data)
{
+ GtkWidget *button = data;
+
/* FIXME: return owa_entry_text instead of making it global */
owa_entry_text = gtk_entry_get_text (GTK_ENTRY (entry));
+ if (owa_entry_text)
+ gtk_widget_set_sensitive (button, TRUE);
}
static GtkWidget *
-add_owa_entry (GtkWidget *parent)
+add_owa_entry (GtkWidget *parent, EConfig *config, EMConfigTargetAccount *target_account)
{
GtkWidget *section, *owa_entry;
+ GtkWidget *hbox, *button, *label;
section = gtk_vbox_new (FALSE, 0);
gtk_widget_show (section);
gtk_box_pack_start (GTK_BOX (parent), section, FALSE, FALSE, 0);
+ hbox = gtk_hbox_new (FALSE, 6);
+ gtk_widget_show(hbox);
+ gtk_box_pack_start (GTK_BOX (section), hbox, FALSE, FALSE, 0);
+ label = gtk_label_new_with_mnemonic(_("_Url:"));
+ gtk_widget_show (label);
owa_entry = gtk_entry_new ();
gtk_widget_show (owa_entry);
- gtk_box_pack_start (GTK_BOX (section), owa_entry, FALSE, FALSE, 0);
+ button = gtk_button_new_from_stock (GTK_STOCK_OK);
+ gtk_widget_set_sensitive (button, FALSE);
+ gtk_widget_show (button);
+
+ gtk_box_pack_start (GTK_BOX (hbox), label, TRUE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (hbox), owa_entry, TRUE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- g_signal_connect (owa_entry, "changed", G_CALLBACK(owa_entry_changed), NULL);
+ g_signal_connect (owa_entry, "changed", G_CALLBACK(owa_entry_changed), button);
+ g_signal_connect (button, "clicked", G_CALLBACK(ok_button_clicked), target_account);
return section; /* FIXME: return entry */
}
@@ -111,6 +134,7 @@ GtkWidget *
org_gnome_exchange_read_url(EPlugin *epl, EConfigHookItemFactoryData *data)
{
EMConfigTargetAccount *target_account;
+ EConfig *config;
char *account_url = NULL, *exchange_url = NULL, *temp_url;
GtkWidget *owa_entry, *parent;
CamelURL *url=NULL;
@@ -118,6 +142,7 @@ org_gnome_exchange_read_url(EPlugin *epl, EConfigHookItemFactoryData *data)
target_account = (EMConfigTargetAccount *)data->config->target;
account_url = g_strdup (target_account->account->source->url);
exchange_url = g_strrstr (account_url, "exchange");
+ config = data->config;
if (exchange_url) {
printf ("org_gnome_exchange_read_url \n");
@@ -136,7 +161,7 @@ org_gnome_exchange_read_url(EPlugin *epl, EConfigHookItemFactoryData *data)
}
parent = data->parent;
- owa_entry = add_owa_entry(parent);
+ owa_entry = add_owa_entry(parent, config, target_account);
g_free (account_url);
return owa_entry;
}
@@ -145,34 +170,3 @@ org_gnome_exchange_read_url(EPlugin *epl, EConfigHookItemFactoryData *data)
return NULL;
}
}
-
-gboolean
-org_gnome_exchange_ask_password(EPlugin *epl, EConfigHookPageCheckData *data)
-{
- EMConfigTargetAccount *target_account;
- EConfig *config;
- char *account_url = NULL, *exchange_url = NULL;
- GtkWidget *page;
-
- if (strcmp (data->pageid, "10.receive"))
- return TRUE;
-
- config = data->config;
- target_account = (EMConfigTargetAccount *)data->config->target;
- account_url = g_strdup (target_account->account->source->url);
- exchange_url = g_strrstr (account_url, "exchange");
-
- /* On page next signal, authenticate user and allow
- * to go to receive options page only if user is a valid user */
-
- if (exchange_url) {
- page = e_config_get_druid_page (config);
- g_signal_connect (page, "next", G_CALLBACK(validate_exchange_user), target_account);
- g_free (account_url);
- return TRUE;
- }
- else {
- g_free (account_url);
- return TRUE;
- }
-}
diff --git a/plugins/exchange-account-setup/org-gnome-exchange-account-setup.eplug.in b/plugins/exchange-account-setup/org-gnome-exchange-account-setup.eplug.in
index 299ad6f9b7..a463cfa3dd 100644
--- a/plugins/exchange-account-setup/org-gnome-exchange-account-setup.eplug.in
+++ b/plugins/exchange-account-setup/org-gnome-exchange-account-setup.eplug.in
@@ -41,22 +41,4 @@
</group>
</hook>
</e-plugin>
-
- <e-plugin
- type="shlib"
- id="org.gnome.evolution.plugin.exchange-ask-password"
- location="@PLUGINDIR@/liborg-gnome-exchange-account-settings.so"
- load-on-startup="true"
- name="Exchange User Authentication"
- description="A pluign to read password once the user enters identity information">
-
- <hook class="org.gnome.evolution.mail.config:1.0">
- <group
- target="account"
- id="org.gnome.evolution.mail.config.accountDruid"
- check="org_gnome_exchange_ask_password">
- <item path="90.dummy"/>
- </group>
- </hook>
- </e-plugin>
</e-plugin-list>