aboutsummaryrefslogtreecommitdiffstats
path: root/shell/evolution-storage.c
diff options
context:
space:
mode:
authorEttore Perazzoli <ettore@src.gnome.org>2002-08-07 00:27:48 +0800
committerEttore Perazzoli <ettore@src.gnome.org>2002-08-07 00:27:48 +0800
commitf312a007fd4b8aaf36a74aa6f40b30ab5bce5a04 (patch)
treefdfbc7af64b9d417ddc36d7d1af7a2d07f74bc14 /shell/evolution-storage.c
parent8f6536de284ed25c263ac7ac2a4b1c840e71da7f (diff)
downloadgsoc2013-evolution-f312a007fd4b8aaf36a74aa6f40b30ab5bce5a04.tar.gz
gsoc2013-evolution-f312a007fd4b8aaf36a74aa6f40b30ab5bce5a04.tar.zst
gsoc2013-evolution-f312a007fd4b8aaf36a74aa6f40b30ab5bce5a04.zip
New callback for the show_folder_properties signal.
* evolution-test-component.c (storage_show_folder_properties_callback): New callback for the show_folder_properties signal. (setup_custom_storage): Add two property items, and connect the callback to the signal. * e-storage-set-view.c: Renamed private member container into ui_container; new member ui_component. (init): Initialize ui_component to NULL. (impl_destroy): Unref if not NULL. (e_storage_set_view_construct): If @ui_container is not NULL, weakref it and create a new ui_component that uses it as its container. (ui_container_destroy_notify): New, weakref destroy callback for priv->ui_container. (remove_property_items): New helper function. (setup_folder_properties_items_if_corba_storage_clicked): New helper function. (folder_property_item_verb_callback): New callback for the verbs associated to the folder property items. (popup_folder_menu): Set up the per-storage folder property items using setup_folder_properties_items_if_corba_storage_clicked() and remove them with remove_property_items() after the menu has been popped down. Don't invoke populate_folder_context_menu if there is no handler for this node [this avoids a spurious warning]. * e-corba-storage.c (e_corba_storage_show_folder_properties): New. (e_corba_storage_get_folder_property_items): New. (e_corba_storage_free_property_items_list): New. * evolution-storage.c: New private member folder_property_items. (init): Init to NULL. (destroy): Free. (impl_showFolderProperties): New, implementation for the Storage::showFolderProperties CORBA method. (class_init): Set up the "show_folder_properties" signal here. (impl_Storage__get_propertyItems): New, getter for the Storage::propertyItems property. (corba_class_init): Install the new methods. (evolution_storage_add_property_item): New function to add property items to the storage. * evolution-storage.h: New signal show_folder_properties. * e-storage-set.c (e_storage_set_create_new_view): Renamed from e_storage_set_new_view(). * Evolution-Storage.idl: Added attribute folderPropertyItems and method ::showFolderProperties. svn path=/trunk/; revision=17714
Diffstat (limited to 'shell/evolution-storage.c')
-rw-r--r--shell/evolution-storage.c129
1 files changed, 121 insertions, 8 deletions
diff --git a/shell/evolution-storage.c b/shell/evolution-storage.c
index 2ef04cdc2c..2f55fbbae4 100644
--- a/shell/evolution-storage.c
+++ b/shell/evolution-storage.c
@@ -24,26 +24,34 @@
#include <config.h>
#endif
-#include <glib.h>
-#include <gtk/gtksignal.h>
-#include <bonobo/bonobo-object.h>
-#include <bonobo/bonobo-exception.h>
-
-#include <gal/util/e-util.h>
+#include "evolution-storage.h"
#include "Evolution.h"
#include "e-folder.h"
#include "e-folder-tree.h"
+#include "e-shell-constants.h"
+#include "e-shell-corba-icon-utils.h"
-#include "evolution-storage.h"
+#include <gal/util/e-util.h>
-#include "e-shell-constants.h"
+#include <gtk/gtksignal.h>
+#include <bonobo/bonobo-object.h>
+#include <bonobo/bonobo-exception.h>
+#include <gdk-pixbuf/gdk-pixbuf.h>
+#include <glib.h>
#define PARENT_TYPE BONOBO_OBJECT_TYPE
static BonoboObjectClass *parent_class = NULL;
+struct _FolderPropertyItem {
+ char *label;
+ char *tooltip;
+ GdkPixbuf *icon;
+};
+typedef struct _FolderPropertyItem FolderPropertyItem;
+
struct _EvolutionStoragePrivate {
/* Name of the storage. */
char *name;
@@ -62,6 +70,9 @@ struct _EvolutionStoragePrivate {
/* The listener registered on this storage. */
GList *corba_storage_listeners;
+
+ /* The property items. */
+ GSList *folder_property_items;
};
@@ -72,6 +83,7 @@ enum {
UPDATE_FOLDER,
OPEN_FOLDER,
DISCOVER_SHARED_FOLDER,
+ SHOW_FOLDER_PROPERTIES,
LAST_SIGNAL
};
@@ -522,6 +534,55 @@ impl_Storage_removeListener (PortableServer_Servant servant,
CORBA_exception_set (ev, CORBA_USER_EXCEPTION, ex_GNOME_Evolution_Storage_NotFound, NULL);
}
+static void
+impl_Storage_showFolderProperties (PortableServer_Servant servant,
+ const CORBA_char *path,
+ const CORBA_short item_number,
+ const CORBA_long parent_window_id,
+ CORBA_Environment *ev)
+{
+ EvolutionStorage *storage;
+
+ storage = EVOLUTION_STORAGE (bonobo_object_from_servant (servant));
+ gtk_signal_emit (GTK_OBJECT (storage), signals[SHOW_FOLDER_PROPERTIES],
+ path, item_number, parent_window_id);
+}
+
+static GNOME_Evolution_Storage_FolderPropertyItemList *
+impl_Storage__get_folderPropertyItems (PortableServer_Servant servant,
+ CORBA_Environment *ev)
+{
+ EvolutionStorage *storage;
+ EvolutionStoragePrivate *priv;
+ GNOME_Evolution_Storage_FolderPropertyItemList *list;
+ GSList *p;
+ int count;
+ int i;
+
+ storage = EVOLUTION_STORAGE (bonobo_object_from_servant (servant));
+ priv = storage->priv;
+
+ count = g_slist_length (priv->folder_property_items);
+
+ list = GNOME_Evolution_Storage_FolderPropertyItemList__alloc ();
+ list->_length = list->_maximum = count;
+ list->_buffer = CORBA_sequence_GNOME_Evolution_Storage_FolderPropertyItem_allocbuf (list->_maximum);
+
+ for (i = 0, p = priv->folder_property_items; p != NULL; i ++, p = p->next) {
+ const FolderPropertyItem *item;
+
+ item = (const FolderPropertyItem *) p->data;
+
+ list->_buffer[i].label = CORBA_string_dup (item->label);
+ list->_buffer[i].tooltip = CORBA_string_dup (item->tooltip);
+ e_store_corba_icon_from_pixbuf (item->icon, & list->_buffer[i].icon);
+ }
+
+ CORBA_sequence_set_release (list, TRUE);
+
+ return list;
+}
+
/* GtkObject methods. */
@@ -539,6 +600,7 @@ destroy (GtkObject *object)
EvolutionStoragePrivate *priv;
CORBA_Environment ev;
GList *p;
+ GSList *sp;
storage = EVOLUTION_STORAGE (object);
priv = storage->priv;
@@ -568,6 +630,19 @@ destroy (GtkObject *object)
CORBA_exception_free (&ev);
+ for (sp = priv->folder_property_items; p != NULL; p = p->next) {
+ FolderPropertyItem *item;
+
+ item = (FolderPropertyItem *) p->data;
+
+ g_free (item->label);
+ g_free (item->tooltip);
+ if (item->icon != NULL)
+ gdk_pixbuf_unref (item->icon);
+ g_free (item);
+ }
+ g_slist_free (priv->folder_property_items);
+
g_free (priv);
(* GTK_OBJECT_CLASS (parent_class)->destroy) (object);
@@ -711,6 +786,17 @@ class_init (EvolutionStorageClass *klass)
GTK_TYPE_STRING,
GTK_TYPE_POINTER);
+ signals[SHOW_FOLDER_PROPERTIES] = gtk_signal_new ("show_folder_properties",
+ GTK_RUN_LAST,
+ object_class->type,
+ GTK_SIGNAL_OFFSET (EvolutionStorageClass,
+ show_folder_properties),
+ gtk_marshal_NONE__POINTER_INT_INT,
+ GTK_TYPE_NONE, 3,
+ GTK_TYPE_STRING,
+ GTK_TYPE_INT,
+ GTK_TYPE_INT);
+
gtk_object_class_add_signals (object_class, signals, LAST_SIGNAL);
corba_class_init ();
@@ -727,6 +813,7 @@ init (EvolutionStorage *storage)
priv->folder_tree = e_folder_tree_new (folder_destroy_notify, storage);
priv->uri_to_path = g_hash_table_new (g_str_hash, g_str_equal);
priv->corba_storage_listeners = NULL;
+ priv->folder_property_items = NULL;
storage->priv = priv;
}
@@ -750,6 +837,8 @@ evolution_storage_get_epv (void)
epv->asyncDiscoverSharedFolder = impl_Storage_asyncDiscoverSharedFolder;
epv->addListener = impl_Storage_addListener;
epv->removeListener = impl_Storage_removeListener;
+ epv->showFolderProperties = impl_Storage_showFolderProperties;
+ epv->_get_folderPropertyItems = impl_Storage__get_folderPropertyItems;
return epv;
}
@@ -1267,6 +1356,30 @@ evolution_storage_has_subfolders (EvolutionStorage *evolution_storage,
return result;
}
+
+/* Setting up property items. */
+
+void
+evolution_storage_add_property_item (EvolutionStorage *evolution_storage,
+ const char *label,
+ const char *tooltip,
+ GdkPixbuf *icon)
+{
+ FolderPropertyItem *item;
+
+ g_return_if_fail (EVOLUTION_IS_STORAGE (evolution_storage));
+ g_return_if_fail (label != NULL);
+
+ item = g_new (FolderPropertyItem, 1);
+ item->label = g_strdup (label);
+ item->tooltip = g_strdup (tooltip);
+ item->icon = icon;
+ if (icon != NULL)
+ gdk_pixbuf_ref (icon);
+
+ evolution_storage->priv->folder_property_items = g_slist_append (evolution_storage->priv->folder_property_items,
+ item);
+}
E_MAKE_TYPE (evolution_storage, "EvolutionStorage", EvolutionStorage, class_init, init, PARENT_TYPE)