diff options
author | Jason Leach <jleach@ximian.com> | 2001-08-04 07:08:38 +0800 |
---|---|---|
committer | Jacob Leach <jleach@src.gnome.org> | 2001-08-04 07:08:38 +0800 |
commit | 385ba85d425e59a0a254abef620a90bd563cdeb8 (patch) | |
tree | 53fd4b38568a19463f8c33d4706c729f4febb7f7 /shell/e-shell-folder-commands.c | |
parent | 308aaf47ea788683b47a600d6c6f31563d7ee070 (diff) | |
download | gsoc2013-evolution-385ba85d425e59a0a254abef620a90bd563cdeb8.tar.gz gsoc2013-evolution-385ba85d425e59a0a254abef620a90bd563cdeb8.tar.zst gsoc2013-evolution-385ba85d425e59a0a254abef620a90bd563cdeb8.zip |
[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
Diffstat (limited to 'shell/e-shell-folder-commands.c')
-rw-r--r-- | shell/e-shell-folder-commands.c | 119 |
1 files changed, 112 insertions, 7 deletions
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); } |