aboutsummaryrefslogtreecommitdiffstats
path: root/shell/e-storage-set-view.c
diff options
context:
space:
mode:
Diffstat (limited to 'shell/e-storage-set-view.c')
-rw-r--r--shell/e-storage-set-view.c140
1 files changed, 133 insertions, 7 deletions
diff --git a/shell/e-storage-set-view.c b/shell/e-storage-set-view.c
index b989fd0824..f924c19cc4 100644
--- a/shell/e-storage-set-view.c
+++ b/shell/e-storage-set-view.c
@@ -97,6 +97,8 @@ struct _EStorageSetViewPrivate {
/* The data. */
GNOME_Evolution_ShellComponentDnd_Data *drag_corba_data;
+
+ GHashTable *checkboxes;
};
@@ -622,6 +624,12 @@ impl_destroy (GtkObject *object)
g_hash_table_foreach (priv->type_name_to_pixbuf, pixbuf_free_func, NULL);
g_hash_table_destroy (priv->type_name_to_pixbuf);
+ if (priv->checkboxes) {
+ g_hash_table_foreach (priv->checkboxes, (GHFunc) g_free, NULL);
+ g_hash_table_destroy (priv->checkboxes);
+ priv->checkboxes = NULL;
+ }
+
gtk_object_unref (GTK_OBJECT (priv->storage_set));
if (priv->drag_corba_source_interface != CORBA_OBJECT_NIL) {
@@ -1142,6 +1150,7 @@ etree_value_at (ETreeModel *etree,
void *model_data)
{
EStorageSetView *storage_set_view;
+ EStorageSetViewPrivate *priv;
EStorageSet *storage_set;
EFolder *folder;
char *path;
@@ -1149,7 +1158,8 @@ etree_value_at (ETreeModel *etree,
int unread_count;
storage_set_view = E_STORAGE_SET_VIEW (model_data);
- storage_set = storage_set_view->priv->storage_set;
+ priv = storage_set_view->priv;
+ storage_set = priv->storage_set;
/* Storages are always highlighted. */
if (path_is_storage (etree, tree_path) && col == 1)
@@ -1180,10 +1190,13 @@ etree_value_at (ETreeModel *etree,
return (void *) folder_name;
case 1: /* bold */
if (folder == NULL)
- return (void *) FALSE;
- return (void *) e_folder_get_highlighted (folder);
+ return GINT_TO_POINTER (FALSE);
+ return GINT_TO_POINTER (e_folder_get_highlighted (folder));
case 2: /* checkbox */
- return (void *) FALSE; /* FIXME: Yo danw, here's the whatnot, ya know. */
+ if (priv->checkboxes == NULL)
+ return GINT_TO_POINTER (FALSE);
+ return GINT_TO_POINTER(!!g_hash_table_lookup (priv->checkboxes,
+ path));
default:
return NULL;
}
@@ -1213,12 +1226,56 @@ etree_fill_in_children (ETreeModel *etree,
static void
etree_set_value_at (ETreeModel *etree,
- ETreePath path,
+ ETreePath tree_path,
int col,
const void *val,
void *model_data)
{
- /* nada */
+ gboolean value;
+ char *path;
+ EStorageSetView *storage_set_view;
+ EStorageSetViewPrivate *priv;
+
+ storage_set_view = E_STORAGE_SET_VIEW (model_data);
+ priv = storage_set_view->priv;
+
+ switch (col) {
+ case 2: /* checkbox */
+ value = GPOINTER_TO_INT (val);
+ path = (char *) e_tree_memory_node_get_data (E_TREE_MEMORY(etree), tree_path);
+ e_tree_model_pre_change (etree);
+ if (value) {
+ if (!priv->checkboxes) {
+ priv->checkboxes = g_hash_table_new (g_str_hash, g_str_equal);
+ } else {
+ if (g_hash_table_lookup (priv->checkboxes, path)) {
+ e_tree_model_no_change (etree);
+ return;
+ }
+ }
+
+ path = g_strdup (path);
+ g_hash_table_insert (priv->checkboxes, path, path);
+ } else {
+ char *temp;
+
+ if (!priv->checkboxes) {
+ e_tree_model_no_change (etree);
+ return;
+ } else {
+ if (!g_hash_table_lookup (priv->checkboxes, path)) {
+ e_tree_model_no_change (etree);
+ return;
+ }
+ }
+
+ temp = g_hash_table_lookup (priv->checkboxes, path);
+ g_hash_table_remove (priv->checkboxes, path);
+ g_free (temp);
+ }
+ e_tree_model_node_col_changed (etree, tree_path, col);
+ break;
+ }
}
static gboolean
@@ -1227,7 +1284,10 @@ etree_is_editable (ETreeModel *etree,
int col,
void *model_data)
{
- return FALSE;
+ if (col == 2)
+ return TRUE;
+ else
+ return FALSE;
}
@@ -1553,6 +1613,8 @@ init (EStorageSetView *storage_set_view)
priv->drag_corba_source_context = NULL;
priv->drag_corba_data = NULL;
+ priv->checkboxes = NULL;
+
storage_set_view->priv = priv;
}
@@ -1902,6 +1964,8 @@ e_storage_set_view_set_show_checkboxes (EStorageSetView *storage_set_view,
priv = storage_set_view->priv;
+ show = !! show;
+
if (show == priv->show_checkboxes)
return;
@@ -1922,6 +1986,68 @@ e_storage_set_view_get_show_checkboxes (EStorageSetView *storage_set_view)
return storage_set_view->priv->show_checkboxes;
}
+void
+e_storage_set_view_set_checkboxes_list (EStorageSetView *storage_set_view,
+ GList *checkboxes)
+{
+ gboolean changed = FALSE;
+ EStorageSetViewPrivate *priv = storage_set_view->priv;
+
+ e_tree_model_pre_change (priv->etree_model);
+ if (priv->checkboxes) {
+ g_hash_table_foreach (priv->checkboxes, (GHFunc) g_free, NULL);
+ g_hash_table_destroy (priv->checkboxes);
+ changed = TRUE;
+ }
+
+ if (checkboxes) {
+ priv->checkboxes = g_hash_table_new (g_str_hash, g_str_equal);
+ for (; checkboxes; checkboxes = g_list_next (checkboxes)) {
+ char *path = checkboxes->data;
+ if (g_hash_table_lookup (priv->checkboxes, path))
+ continue;
+ path = g_strdup (path);
+ g_hash_table_insert (priv->checkboxes, path, path);
+ }
+ changed = TRUE;
+ }
+
+ if (changed)
+ e_tree_model_node_changed (priv->etree_model,
+ e_tree_model_get_root (priv->etree_model));
+ else
+ e_tree_model_no_change (priv->etree_model);
+}
+
+static void
+essv_add_to_list (ETreePath tree_path, void **temp)
+{
+ EStorageSetView *storage_set_view = temp[0];
+ EStorageSetViewPrivate *priv = storage_set_view->priv;
+ GList **list = temp[1];
+
+ if (priv->checkboxes) {
+ char *path = (char*)e_tree_memory_node_get_data(E_TREE_MEMORY(priv->etree_model), tree_path);
+ if (path && g_hash_table_lookup (priv->checkboxes, path)) {
+ *list = g_list_prepend (*list, path);
+ }
+ }
+}
+
+/* g_list_free this list, but don't free the strings within. */
+GList *
+e_storage_set_view_get_checkboxes_list (EStorageSetView *storage_set_view)
+{
+ void *temp[2];
+ GList *list = NULL;
+ temp[0] = storage_set_view;
+ temp[1] = &list;
+
+ e_tree_path_foreach (E_TREE (storage_set_view), (ETreeForeachFunc) essv_add_to_list, temp);
+ list = g_list_reverse (list);
+ return list;
+}
+
void
e_storage_set_view_set_allow_dnd (EStorageSetView *storage_set_view,