aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--shell/ChangeLog10
-rw-r--r--shell/e-shell-folder-selection-dialog.c116
2 files changed, 69 insertions, 57 deletions
diff --git a/shell/ChangeLog b/shell/ChangeLog
index 34a6dd85cd..29c61274e3 100644
--- a/shell/ChangeLog
+++ b/shell/ChangeLog
@@ -1,3 +1,13 @@
+2002-07-18 Ettore Perazzoli <ettore@ximian.com>
+
+ * e-shell-folder-selection-dialog.c (double_click_cb): Renamed
+ from `dbl_click_cb'.
+ (check_folder_type): Don't pop up an error dialog anymore.
+ (check_folder_type_valid): Renamed from check_folder_type().
+ (folder_selected_cb): Make the OK button sensitive only if the
+ type of the selected folder is in the list of valid types;
+ otherwise, make it insensitive. [#848]
+
2002-07-18 Rodrigo Moya <rodrigo@ximian.com>
* e-shell-importer.c (start_import): removed check for local folders,
diff --git a/shell/e-shell-folder-selection-dialog.c b/shell/e-shell-folder-selection-dialog.c
index e767ffd743..11d6493d0d 100644
--- a/shell/e-shell-folder-selection-dialog.c
+++ b/shell/e-shell-folder-selection-dialog.c
@@ -62,8 +62,10 @@ enum {
static guint signals[LAST_SIGNAL] = { 0 };
+/* Utility functions. */
+
static gboolean
-check_folder_type (EShellFolderSelectionDialog *folder_selection_dialog)
+check_folder_type_valid (EShellFolderSelectionDialog *folder_selection_dialog)
{
EShellFolderSelectionDialogPrivate *priv;
const char *selected_path;
@@ -93,13 +95,35 @@ check_folder_type (EShellFolderSelectionDialog *folder_selection_dialog)
return TRUE;
}
- e_notice (GTK_WINDOW (folder_selection_dialog), GNOME_MESSAGE_BOX_ERROR,
- _("The type of the selected folder is not valid for\n"
- "the requested operation."));
-
return FALSE;
}
+static void
+set_default_folder (EShellFolderSelectionDialog *shell_folder_selection_dialog,
+ const char *default_uri)
+{
+ EShellFolderSelectionDialogPrivate *priv;
+ char *default_path;
+
+ g_assert (default_uri != NULL);
+
+ priv = shell_folder_selection_dialog->priv;
+
+ if (strncmp (default_uri, E_SHELL_URI_PREFIX, E_SHELL_URI_PREFIX_LEN) == 0) {
+ /* `evolution:' URI. */
+ default_path = g_strdup (default_uri + E_SHELL_URI_PREFIX_LEN);
+ } else {
+ /* Physical URI. */
+ default_path = e_storage_set_get_path_for_physical_uri (priv->storage_set,
+ default_uri);
+ }
+
+ e_storage_set_view_set_current_folder (E_STORAGE_SET_VIEW (priv->storage_set_view),
+ default_path);
+
+ g_free (default_path);
+}
+
/* Folder creation dialog callback. */
@@ -165,30 +189,6 @@ impl_destroy (GtkObject *object)
}
-/* ETable callback */
-static void
-dbl_click_cb (EStorageSetView *essv,
- int row,
- ETreePath path,
- int col,
- GdkEvent *event,
- EShellFolderSelectionDialog *folder_selection_dialog)
-{
- EShellFolderSelectionDialogPrivate *priv;
-
- g_return_if_fail (folder_selection_dialog != NULL);
-
- priv = folder_selection_dialog->priv;
- if (check_folder_type (folder_selection_dialog)) {
- gtk_signal_emit (GTK_OBJECT (folder_selection_dialog),
- signals[FOLDER_SELECTED],
- e_shell_folder_selection_dialog_get_selected_path (folder_selection_dialog));
- }
-
- gnome_dialog_close (GNOME_DIALOG (folder_selection_dialog));
-}
-
-
/* GnomeDialog methods. */
static void
@@ -206,7 +206,7 @@ impl_clicked (GnomeDialog *dialog,
switch (button_number) {
case 0: /* OK */
- if (check_folder_type (folder_selection_dialog)) {
+ if (check_folder_type_valid (folder_selection_dialog)) {
gtk_signal_emit (GTK_OBJECT (folder_selection_dialog), signals[FOLDER_SELECTED],
e_shell_folder_selection_dialog_get_selected_path (folder_selection_dialog));
gnome_dialog_close (GNOME_DIALOG (dialog));
@@ -291,44 +291,46 @@ init (EShellFolderSelectionDialog *shell_folder_selection_dialog)
}
+/* ETable callbacks. */
+
static void
-set_default_folder (EShellFolderSelectionDialog *shell_folder_selection_dialog,
- const char *default_uri)
+folder_selected_cb (EStorageSetView *storage_set_view,
+ const char *path,
+ void *data)
{
- EShellFolderSelectionDialogPrivate *priv;
- char *default_path;
-
- g_assert (default_uri != NULL);
-
- priv = shell_folder_selection_dialog->priv;
-
- if (strncmp (default_uri, E_SHELL_URI_PREFIX, E_SHELL_URI_PREFIX_LEN) == 0) {
- /* `evolution:' URI. */
- default_path = g_strdup (default_uri + E_SHELL_URI_PREFIX_LEN);
- } else {
- /* Physical URI. */
- default_path = e_storage_set_get_path_for_physical_uri (priv->storage_set,
- default_uri);
- }
+ EShellFolderSelectionDialog *dialog;
- e_storage_set_view_set_current_folder (E_STORAGE_SET_VIEW (priv->storage_set_view),
- default_path);
+ dialog = E_SHELL_FOLDER_SELECTION_DIALOG (data);
- g_free (default_path);
+ if (check_folder_type_valid (dialog))
+ gnome_dialog_set_sensitive (GNOME_DIALOG (dialog), 0, TRUE);
+ else
+ gnome_dialog_set_sensitive (GNOME_DIALOG (dialog), 0, FALSE);
}
static void
-folder_selected_cb (EStorageSetView *storage_set_view,
- const char *path,
- void *data)
+double_click_cb (EStorageSetView *essv,
+ int row,
+ ETreePath path,
+ int col,
+ GdkEvent *event,
+ EShellFolderSelectionDialog *folder_selection_dialog)
{
- GnomeDialog *dialog;
+ EShellFolderSelectionDialogPrivate *priv;
+
+ g_return_if_fail (folder_selection_dialog != NULL);
- dialog = GNOME_DIALOG (data);
+ priv = folder_selection_dialog->priv;
+ if (check_folder_type_valid (folder_selection_dialog)) {
+ gtk_signal_emit (GTK_OBJECT (folder_selection_dialog),
+ signals[FOLDER_SELECTED],
+ e_shell_folder_selection_dialog_get_selected_path (folder_selection_dialog));
+ }
- gnome_dialog_set_sensitive (dialog, 0, TRUE);
+ gnome_dialog_close (GNOME_DIALOG (folder_selection_dialog));
}
+
/**
* e_shell_folder_selection_dialog_construct:
* @folder_selection_dialog: A folder selection dialog widget
@@ -411,7 +413,7 @@ e_shell_folder_selection_dialog_construct (EShellFolderSelectionDialog *folder_s
g_free (filename);
gtk_signal_connect (GTK_OBJECT (priv->storage_set_view), "double_click",
- GTK_SIGNAL_FUNC (dbl_click_cb),
+ GTK_SIGNAL_FUNC (double_click_cb),
folder_selection_dialog);
gtk_signal_connect (GTK_OBJECT (priv->storage_set_view), "folder_selected",
GTK_SIGNAL_FUNC (folder_selected_cb),