aboutsummaryrefslogtreecommitdiffstats
path: root/my-evolution/e-summary-table.c
diff options
context:
space:
mode:
Diffstat (limited to 'my-evolution/e-summary-table.c')
-rw-r--r--my-evolution/e-summary-table.c26
1 files changed, 21 insertions, 5 deletions
diff --git a/my-evolution/e-summary-table.c b/my-evolution/e-summary-table.c
index 888b777bbd..da2bf64f5b 100644
--- a/my-evolution/e-summary-table.c
+++ b/my-evolution/e-summary-table.c
@@ -49,6 +49,7 @@
#include <libgnomeui/gnome-init.h>
#include "e-summary-table.h"
+#include "e-cell-tri.h"
#define COLS 2
@@ -60,7 +61,7 @@ char *headers[COLS] = {
#endif
#define SPEC "<ETableSpecification cursor-mode=\"line\" draw-focus=\"true\"> \
-<ETableColumn model_col=\"0\" _title=\"Shown\" resizable=\"true\" cell=\"checkbox\" compare=\"integer\"/> \
+<ETableColumn model_col=\"0\" _title=\"Shown\" resizable=\"true\" cell=\"tricell\" compare=\"integer\"/> \
<ETableColumn model_col=\"1\" _title=\"Name\" minimum_width=\"20\" resizable=\"true\" cell=\"render-name\" compare=\"string\"/> \
<ETableState> \
<column source=\"0\"/> \
@@ -214,7 +215,11 @@ value_at (ETreeModel *etm,
return entry->name;
} else {
- return GINT_TO_POINTER (entry->shown);
+ if (entry->editable == TRUE) {
+ return GINT_TO_POINTER (entry->shown ? 2 : 1);
+ } else {
+ return GINT_TO_POINTER (0);
+ }
}
}
}
@@ -243,7 +248,7 @@ set_value_at (ETreeModel *etm,
g_return_if_fail (entry != NULL);
if (entry->editable == TRUE) {
- entry->shown = GPOINTER_TO_INT (val);
+ entry->shown = GPOINTER_TO_INT (val) == 1 ? FALSE : TRUE;
gtk_signal_emit (GTK_OBJECT (est), table_signals[ITEM_CHANGED], path);
}
}
@@ -370,7 +375,8 @@ e_summary_table_init (ESummaryTable *est)
cell = e_cell_text_new (NULL, GTK_JUSTIFY_LEFT);
priv->extras = e_table_extras_new ();
e_table_extras_add_cell (priv->extras, "render-name", e_cell_tree_new (NULL, NULL, FALSE, cell));
-
+ e_table_extras_add_cell (priv->extras, "tricell", e_cell_tri_new ());
+
priv->etable = e_tree_scrolled_new (priv->etm, priv->extras, SPEC, NULL);
if (priv->etable == NULL) {
g_warning ("Could not create ETable for ESummaryTable");
@@ -420,4 +426,14 @@ e_summary_table_add_node (ESummaryTable *table,
return p;
}
-
+guint
+e_summary_table_get_num_children (ESummaryTable *table,
+ ETreePath path)
+{
+ if (path == NULL) {
+ return e_tree_model_node_get_children (table->priv->etm,
+ table->priv->root_node, NULL);
+ } else {
+ return e_tree_model_node_get_children (table->priv->etm, path, NULL);
+ }
+}