From 385ba85d425e59a0a254abef620a90bd563cdeb8 Mon Sep 17 00:00:00 2001
From: Jason Leach <jleach@ximian.com>
Date: Fri, 3 Aug 2001 23:08:38 +0000
Subject: [Removing Evolution::LocalStorage interface, abstracting the unread
 counts

2001-08-03  Jason Leach  <jleach@ximian.com>

        [Removing Evolution::LocalStorage interface, abstracting the
        unread counts from a folder's name, also abstract unread counts
        from a shortcut's name.  Fixes #4489 and #5497]

        * e-shortcuts.c (shortcut_item_new): Take an unread_count argument
        now.
        (shortcut_item_update): Ditto.

        * e-shortcuts-view-model.c (get_name_with_unread): Get a string
        containing a shortcut name and it's unread, because these are
        abstracted now.
        (load_group_into_model): Use the above function to make shortcuts
        that have unread counts.

        * e-storage-set-view.c (update_folder_with_unread_hash): Keep a
        hash of folder names with unread counts, because the folder name
        and it's unread count are to be separated, only the ETree is
        supposed to present it as one string.

        * e-shell-view.c: Renamed EShellView::view_title_bar to
        folder_title_bar, to closer match the

        * e-shell-view-menu.c (new_shortcut_dialog_folder_selected_cb):
        Make a shortcut with the unread count.

        * e-shell-folder-commands.c (e_shell_command_add_to_shortcut_bar):
        Make a shortcut with the unread count.

        * e-local-storage.c: Updated for API changes.

        * e-folder.c (e_folder_get_unread_count): New function, does what
        it says.
        (e_folder_set_unread_count): Ditto.

        * e-corba-storage.c (impl_StorageListener_new_folder): Renamed to
        match the IDL function name.
        (impl_StorageListener_update_folder): Ditto.
        (impl_StorageListener_removed_folder): Ditto.

        * Evolution-Storage.idl (struct Folder): Replace the boolean
        highlighted with a long unread_count.
        (updateFolder): Brought in from the now dead
        Evolution::LocalStorage.

        * Evolution-Shell.idl (getLocalStorage): Return a Storage instead
        of a LocalStorage.

        * Evolution-LocalStorage.idl: Removed, no longer needed, only used
        function, updateFolder, has been moved into Evolution::Storage
        interface.

        * evolution-local-storage.[ch]: Ditto.

        * evolution-storage.c (impl_Storage_updateFolder): Implementation
        of the updateFolder taken from ::LocalStorage.
        (class_init): New "update_folder" signal, taken from
        evolution-local-storage.c too.
        (evolution_storage_update_folder): Take an @unread_count int
        instead of a @highlighted boolean.
        (evolution_storage_new_folder): Same for here.
        (evolution_storage_update_folder_by_uri): And here.

        * evolution-storage-listener.h: "update_folder" signal no longer
        sends a @highlighted boolean.

2001-08-03  Jason Leach  <jleach@ximian.com>

        * e-shell-view-menu.c (update_offline_menu_item): Use Jakub's new
        "Work Online" icon and fix a typo.

svn path=/trunk/; revision=11633
---
 shell/e-shell-folder-commands.c | 119 +++++++++++++++++++++++++++++++++++++---
 1 file changed, 112 insertions(+), 7 deletions(-)

(limited to 'shell/e-shell-folder-commands.c')

diff --git a/shell/e-shell-folder-commands.c b/shell/e-shell-folder-commands.c
index 1f4b473e17..bf9cda678b 100644
--- a/shell/e-shell-folder-commands.c
+++ b/shell/e-shell-folder-commands.c
@@ -37,6 +37,7 @@
 
 #include <gtk/gtklabel.h>
 #include <gtk/gtksignal.h>
+#include <gtk/gtkentry.h>
 
 #include "e-shell-constants.h"
 #include "e-shell-folder-creation-dialog.h"
@@ -58,6 +59,19 @@ get_folder_name (EShell *shell,
 	return e_folder_get_name (folder);
 }
 
+static int
+get_folder_unread (EShell *shell,
+		   const char *path)
+{
+	EStorageSet *storage_set;
+	EFolder *folder;
+
+	storage_set = e_shell_get_storage_set (shell);
+	folder = e_storage_set_get_folder (storage_set, path);
+
+	return e_folder_get_unread_count (folder);
+}
+
 
 /* The data passed to the signals handled during the execution of the folder
    commands.  */
@@ -348,7 +362,6 @@ delete_dialog (EShellView *shell_view, const char *utf8_folder)
 
 	/* Popup a dialog asking if they are sure they want to delete
            the folder */
-
 	folder_name = e_utf8_to_gtk_string (GTK_WIDGET (shell_view), 
 					    (char *)utf8_folder);
 	title = g_strdup_printf (_("Delete folder '%s'"), folder_name);
@@ -360,6 +373,7 @@ delete_dialog (EShellView *shell_view, const char *utf8_folder)
 	g_free (title);
 	gnome_dialog_set_parent (dialog, GTK_WINDOW (shell_view));
 
+	/* "Are you sure..." label */
 	question = g_strdup_printf (_("Are you sure you want to remove the '%s' folder?"),
 				    folder_name);
 	question_label = gtk_label_new (question);	
@@ -407,6 +421,16 @@ e_shell_command_delete_folder (EShell *shell,
 	g_free (path);
 }
 
+static void
+rename_clicked (GtkWidget *dialog, gint button_num, void *data)
+{
+	char **retval = data;
+	GtkWidget *entry;
+
+	entry = gtk_object_get_data (GTK_OBJECT (dialog), "entry");
+	*retval = g_strdup (gtk_entry_get_text (GTK_ENTRY (entry)));
+}
+
 #if 0
 static char *
 rename_dialog (char *folder_name)
@@ -414,35 +438,113 @@ rename_dialog (char *folder_name)
 	GnomeDialog *dialog;
 	int result;
 	char *title;
-	GtkWidget *question_label;
+	GtkWidget *hbox;
+	char *label;
+	GtkWidget *prompt_label;
 	GtkWidget *entry;
 	char *question;
+	char *retval;
 
-
+	/* Popup a dialog asking what the user would like to rename
+           the folder to */
 	title = g_strdup_printf (_("Rename folder '%s'"),
 				 folder_name);
 
 	dialog = GNOME_DIALOG (gnome_dialog_new (title,
-						 GNOME_STOCK_BUTTON_OK,
+						 _("Rename"),
 						 GNOME_STOCK_BUTTON_CANCEL,
 						 NULL));
 	g_free (title);
 
-	/* FIXME: Finish then make command_rename_folder use it */
+	hbox = gtk_hbox_new (FALSE, 2);
+
+	/* Make, pack the label */
+	label = g_strdup_printf (_("Folder name:"));
+	prompt_label = gtk_label_new (label);
+	gtk_box_pack_start (GTK_BOX (hbox), prompt_label, FALSE, TRUE, 2);
+
+	/* Make, setup, pack the entry */
+	entry = gtk_entry_new ();
+	gtk_entry_set_text (GTK_ENTRY (entry), folder_name);
+	gtk_box_pack_start (GTK_BOX (hbox), entry, FALSE, TRUE, 2);
+
+	gtk_widget_show (GTK_WIDGET (prompt_label));
+	gtk_widget_show (GTK_WIDGET (entry));
+	gtk_widget_show (GTK_WIDGET (hbox));
+
+	gtk_box_pack_start (GTK_BOX (dialog->vbox), hbox, FALSE, TRUE, 2);
+
+	gtk_object_set_data (GTK_OBJECT (dialog), "entry", entry);
+
+	gtk_signal_connect (GTK_OBJECT (dialog), "clicked",
+			    rename_clicked, &retval);
+
+	gnome_dialog_set_default (dialog, 1);
+
+	result = gnome_dialog_run_and_close (dialog);
+       
+	return retval;
 }
 #endif
 
 
+
+static void
+rename_cb (EStorageSet *storage_set,
+	   EStorageResult result,
+	   void *data)
+{
+	/* FIXME: Do something? */
+}
+
 void
 e_shell_command_rename_folder (EShell *shell,
 			       EShellView *shell_view)
 {
+	EStorageSet *storage_set;
+	char *oldname;
+	char *newname;
+
+	char *path;
+	char *newpath;
+
 	g_return_if_fail (shell != NULL);
 	g_return_if_fail (E_IS_SHELL (shell));
 	g_return_if_fail (shell_view != NULL);
 	g_return_if_fail (E_IS_SHELL_VIEW (shell_view));
 
-	g_warning ("To be implemented");
+	storage_set = e_shell_get_storage_set (shell);
+	path = g_strdup (e_shell_view_get_current_path (shell_view));
+
+	oldname = get_folder_name (shell, path);
+	newname = rename_dialog (oldname);
+
+	if (strcmp (oldname, newname)) {
+		/* FIXME: Doing strstr isn't robust enough, will fail
+                   when path is /blah/blah, do looped strchr for '/' */
+		char *tmp = strstr (path, oldname);
+		char *tmp2;
+
+		tmp2 = g_strndup (path, strlen (path) - strlen (tmp));
+
+		newpath = g_strconcat (tmp2, newname, NULL);
+
+		printf ("newpath: %s\n", newpath);
+
+		g_free (tmp2);
+		g_free (tmp);
+
+/* FIXME: newpath needs to be correct
+		e_storage_set_async_xfer_folder (storage_set,
+						 oldpath,
+						 newpath,
+						 TRUE,
+						 rename_cb,
+						 NULL);
+*/
+	}
+
+	g_free (path);
 }
 
 
@@ -453,6 +555,7 @@ e_shell_command_add_to_shortcut_bar (EShell *shell,
 	EShortcuts *shortcuts;
 	int group_num;
 	const char *uri;
+	int unread_count;
 
 	g_return_if_fail (shell != NULL);
 	g_return_if_fail (E_IS_SHELL (shell));
@@ -463,5 +566,7 @@ e_shell_command_add_to_shortcut_bar (EShell *shell,
 	group_num = e_shell_view_get_current_shortcuts_group_num (shell_view);
 	uri = e_shell_view_get_current_uri (shell_view);
 
-	e_shortcuts_add_shortcut (shortcuts, group_num, -1, uri, NULL, NULL);
+	unread_count = get_folder_unread (shell, e_shell_view_get_current_path (shell_view));
+
+	e_shortcuts_add_shortcut (shortcuts, group_num, -1, uri, NULL, unread_count, NULL);
 }
-- 
cgit