diff options
Diffstat (limited to 'widgets/table/e-table.c')
-rw-r--r-- | widgets/table/e-table.c | 60 |
1 files changed, 44 insertions, 16 deletions
diff --git a/widgets/table/e-table.c b/widgets/table/e-table.c index 88e305b88d..6da35fea39 100644 --- a/widgets/table/e-table.c +++ b/widgets/table/e-table.c @@ -41,6 +41,7 @@ static GtkObjectClass *e_table_parent_class; enum { CURSOR_CHANGE, + SELECTION_CHANGE, DOUBLE_CLICK, RIGHT_CLICK, CLICK, @@ -837,6 +838,12 @@ void e_table_save_state (ETable *e_table gtk_object_sink(GTK_OBJECT(state)); } +static void +et_selection_model_selection_change (ETableGroup *etg, ETable *et) +{ + gtk_signal_emit (GTK_OBJECT (et), + et_signals [SELECTION_CHANGE]); +} static ETable * et_real_construct (ETable *e_table, ETableModel *etm, ETableExtras *ete, @@ -880,6 +887,9 @@ et_real_construct (ETable *e_table, ETableModel *etm, ETableExtras *ete, "sorter", e_table->sorter, NULL); + gtk_signal_connect(GTK_OBJECT(e_table->selection), "selection_changed", + GTK_SIGNAL_FUNC(et_selection_model_selection_change), e_table); + if (!specification->no_headers) { e_table_setup_header (e_table); } @@ -1204,6 +1214,15 @@ e_table_selected_row_foreach (ETable *e_table, closure); } +gint +e_table_selected_count (ETable *e_table) +{ + g_return_val_if_fail(e_table != NULL, -1); + g_return_val_if_fail(E_IS_TABLE(e_table), -1); + + return e_table_selection_model_selected_count(e_table->selection); +} + void e_table_select_all (ETable *table) { @@ -1887,25 +1906,26 @@ e_table_class_init (GtkObjectClass *object_class) e_table_parent_class = gtk_type_class (PARENT_TYPE); - object_class->destroy = et_destroy; - object_class->set_arg = et_set_arg; - object_class->get_arg = et_get_arg; + object_class->destroy = et_destroy; + object_class->set_arg = et_set_arg; + object_class->get_arg = et_get_arg; - klass->cursor_change = NULL; - klass->double_click = NULL; - klass->right_click = NULL; - klass->click = NULL; - klass->key_press = NULL; + klass->cursor_change = NULL; + klass->selection_change = NULL; + klass->double_click = NULL; + klass->right_click = NULL; + klass->click = NULL; + klass->key_press = NULL; - klass->table_drag_begin = NULL; - klass->table_drag_end = NULL; - klass->table_drag_data_get = NULL; - klass->table_drag_data_delete = NULL; + klass->table_drag_begin = NULL; + klass->table_drag_end = NULL; + klass->table_drag_data_get = NULL; + klass->table_drag_data_delete = NULL; - klass->table_drag_leave = NULL; - klass->table_drag_motion = NULL; - klass->table_drag_drop = NULL; - klass->table_drag_data_received = NULL; + klass->table_drag_leave = NULL; + klass->table_drag_motion = NULL; + klass->table_drag_drop = NULL; + klass->table_drag_data_received = NULL; et_signals [CURSOR_CHANGE] = gtk_signal_new ("cursor_change", @@ -1915,6 +1935,14 @@ e_table_class_init (GtkObjectClass *object_class) gtk_marshal_NONE__INT, GTK_TYPE_NONE, 1, GTK_TYPE_INT); + et_signals [SELECTION_CHANGE] = + gtk_signal_new ("selection_change", + GTK_RUN_LAST, + object_class->type, + GTK_SIGNAL_OFFSET (ETableClass, selection_change), + gtk_marshal_NONE__NONE, + GTK_TYPE_NONE, 0); + et_signals [DOUBLE_CLICK] = gtk_signal_new ("double_click", GTK_RUN_LAST, |