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-shortcuts-view-model.c | |
parent | 308aaf47ea788683b47a600d6c6f31563d7ee070 (diff) | |
download | gsoc2013-evolution-385ba85d425e59a0a254abef620a90bd563cdeb8.tar gsoc2013-evolution-385ba85d425e59a0a254abef620a90bd563cdeb8.tar.gz gsoc2013-evolution-385ba85d425e59a0a254abef620a90bd563cdeb8.tar.bz2 gsoc2013-evolution-385ba85d425e59a0a254abef620a90bd563cdeb8.tar.lz gsoc2013-evolution-385ba85d425e59a0a254abef620a90bd563cdeb8.tar.xz 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-shortcuts-view-model.c')
-rw-r--r-- | shell/e-shortcuts-view-model.c | 24 |
1 files changed, 21 insertions, 3 deletions
diff --git a/shell/e-shortcuts-view-model.c b/shell/e-shortcuts-view-model.c index 8936d24242..03fd22a239 100644 --- a/shell/e-shortcuts-view-model.c +++ b/shell/e-shortcuts-view-model.c @@ -47,6 +47,15 @@ struct _EShortcutsViewModelPrivate { /* View initialization. */ +static char * +get_name_with_unread (const EShortcutItem *item) +{ + if (item->unread_count > 0) + return g_strdup_printf ("%s (%d)", item->name, item->unread_count); + else + return g_strdup (item->name); +} + static void load_group_into_model (EShortcutsViewModel *shortcuts_view_model, int group_num) @@ -67,9 +76,12 @@ load_group_into_model (EShortcutsViewModel *shortcuts_view_model, for (p = shortcut_list; p != NULL; p = p->next) { const EShortcutItem *item; + char *name_with_unread; item = (const EShortcutItem *) p->data; - e_shortcut_model_add_item (E_SHORTCUT_MODEL (shortcuts_view_model), group_num, -1, item->uri, item->name); + name_with_unread = get_name_with_unread (item); + e_shortcut_model_add_item (E_SHORTCUT_MODEL (shortcuts_view_model), group_num, -1, item->uri, name_with_unread); + g_free (name_with_unread); } } @@ -153,6 +165,7 @@ shortcuts_new_shortcut_cb (EShortcuts *shortcuts, EShortcutsViewModel *shortcuts_view_model; EShortcutsViewModelPrivate *priv; const EShortcutItem *shortcut_item; + char *name_with_unread; shortcuts_view_model = E_SHORTCUTS_VIEW_MODEL (data); priv = shortcuts_view_model->priv; @@ -160,10 +173,12 @@ shortcuts_new_shortcut_cb (EShortcuts *shortcuts, shortcut_item = e_shortcuts_get_shortcut (priv->shortcuts, group_num, item_num); g_assert (shortcut_item != NULL); + name_with_unread = get_name_with_unread (shortcut_item); e_shortcut_model_add_item (E_SHORTCUT_MODEL (shortcuts_view_model), group_num, item_num, shortcut_item->uri, - shortcut_item->name); + name_with_unread); + g_free (name_with_unread); } static void @@ -187,6 +202,7 @@ shortcuts_update_shortcut_cb (EShortcuts *shortcuts, EShortcutsViewModel *shortcuts_view_model; EShortcutsViewModelPrivate *priv; const EShortcutItem *shortcut_item; + char *name_with_unread; shortcuts_view_model = E_SHORTCUTS_VIEW_MODEL (data); priv = shortcuts_view_model->priv; @@ -194,10 +210,12 @@ shortcuts_update_shortcut_cb (EShortcuts *shortcuts, shortcut_item = e_shortcuts_get_shortcut (priv->shortcuts, group_num, item_num); g_assert (shortcut_item != NULL); + name_with_unread = get_name_with_unread (shortcut_item); e_shortcut_model_update_item (E_SHORTCUT_MODEL (shortcuts_view_model), group_num, item_num, shortcut_item->uri, - shortcut_item->name); + name_with_unread); + g_free (name_with_unread); } |