diff options
Diffstat (limited to 'widgets/table/e-table-header.c')
-rw-r--r-- | widgets/table/e-table-header.c | 46 |
1 files changed, 41 insertions, 5 deletions
diff --git a/widgets/table/e-table-header.c b/widgets/table/e-table-header.c index aa12c54722..ad585bdc2b 100644 --- a/widgets/table/e-table-header.c +++ b/widgets/table/e-table-header.c @@ -41,6 +41,7 @@ enum { enum { STRUCTURE_CHANGE, DIMENSION_CHANGE, + EXPANSION_CHANGE, REQUEST_WIDTH, LAST_SIGNAL }; @@ -235,11 +236,12 @@ eth_get_arg (GtkObject *object, GtkArg *arg, guint arg_id) static void e_table_header_class_init (GtkObjectClass *object_class) { + ETableHeaderClass *klass = E_TABLE_HEADER_CLASS (object_class); + object_class->destroy = eth_destroy; object_class->set_arg = eth_set_arg; object_class->get_arg = eth_get_arg; - e_table_header_parent_class = (gtk_type_class (gtk_object_get_type ())); gtk_object_add_arg_type ("ETableHeader::width", GTK_TYPE_DOUBLE, @@ -263,6 +265,13 @@ e_table_header_class_init (GtkObjectClass *object_class) GTK_SIGNAL_OFFSET (ETableHeaderClass, dimension_change), gtk_marshal_NONE__INT, GTK_TYPE_NONE, 1, GTK_TYPE_INT); + eth_signals [EXPANSION_CHANGE] = + gtk_signal_new ("expansion_change", + GTK_RUN_LAST, + E_OBJECT_CLASS_TYPE (object_class), + GTK_SIGNAL_OFFSET (ETableHeaderClass, expansion_change), + gtk_marshal_NONE__NONE, + GTK_TYPE_NONE, 0); eth_signals [REQUEST_WIDTH] = gtk_signal_new ("request_width", GTK_RUN_LAST, @@ -272,6 +281,11 @@ e_table_header_class_init (GtkObjectClass *object_class) GTK_TYPE_INT, 1, GTK_TYPE_INT); E_OBJECT_CLASS_ADD_SIGNALS (object_class, eth_signals, LAST_SIGNAL); + + klass->structure_change = NULL; + klass->dimension_change = NULL; + klass->expansion_change = NULL; + klass->request_width = NULL; } static void @@ -677,6 +691,8 @@ eth_set_size (ETableHeader *eth, int idx, int size) for (i = idx + 1; i < eth->col_count; i++) { eth->columns[i]->expansion = 0; } + + gtk_signal_emit (GTK_OBJECT (eth), eth_signals [EXPANSION_CHANGE]); return; } @@ -686,6 +702,7 @@ eth_set_size (ETableHeader *eth, int idx, int size) for (i = idx; i < eth->col_count; i++) { eth->columns[i]->expansion = 0; } + gtk_signal_emit (GTK_OBJECT (eth), eth_signals [EXPANSION_CHANGE]); return; } @@ -702,6 +719,7 @@ eth_set_size (ETableHeader *eth, int idx, int size) for (i = idx + 1; i < eth->col_count; i++) { eth->columns[i]->expansion = 0; } + gtk_signal_emit (GTK_OBJECT (eth), eth_signals [EXPANSION_CHANGE]); return; } @@ -726,6 +744,7 @@ eth_set_size (ETableHeader *eth, int idx, int size) eth->columns[i]->expansion = expansion / expandable_count; } } + gtk_signal_emit (GTK_OBJECT (eth), eth_signals [EXPANSION_CHANGE]); return; } @@ -737,6 +756,7 @@ eth_set_size (ETableHeader *eth, int idx, int size) eth->columns[i]->expansion *= expansion / old_expansion; } } + gtk_signal_emit (GTK_OBJECT (eth), eth_signals [EXPANSION_CHANGE]); } /** @@ -782,6 +802,11 @@ eth_calc_widths (ETableHeader *eth) int last_position = 0; double next_position = 0; int last_resizable = -1; + int *widths; + gboolean changed; + + widths = g_new (int, eth->col_count); + /* - 1 to account for the last pixel border. */ extra = eth->width - 1; expansion = 0; @@ -790,21 +815,31 @@ eth_calc_widths (ETableHeader *eth) if (eth->columns[i]->resizable && eth->columns[i]->expansion > 0) last_resizable = i; expansion += eth->columns[i]->resizable ? eth->columns[i]->expansion : 0; - eth->columns[i]->width = eth->columns[i]->min_width + eth->width_extras; + widths[i] = eth->columns[i]->min_width + eth->width_extras; } if (eth->sort_info) extra -= e_table_sort_info_grouping_get_count(eth->sort_info) * GROUP_INDENT; if (expansion != 0 && extra > 0) { for (i = 0; i < last_resizable; i++) { next_position += extra * (eth->columns[i]->resizable ? eth->columns[i]->expansion : 0)/expansion; - eth->columns[i]->width += next_position - last_position; + widths[i] += next_position - last_position; last_position = next_position; } - eth->columns[i]->width += extra - last_position; + widths[i] += extra - last_position; } + changed = FALSE; + + for (i = 0; i < eth->col_count; i++) { + if (eth->columns[i]->width != widths[i]) { + changed = TRUE; + eth->columns[i]->width = widths[i]; + } + } + g_free (widths); + if (changed) + gtk_signal_emit (GTK_OBJECT (eth), eth_signals [DIMENSION_CHANGE]); eth_update_offsets (eth); - gtk_signal_emit (GTK_OBJECT (eth), eth_signals [DIMENSION_CHANGE]); } void @@ -825,6 +860,7 @@ e_table_header_update_horizontal (ETableHeader *eth) eth->columns[i]->expansion = 1; } enqueue(eth, -1, eth->nominal_width); + gtk_signal_emit (GTK_OBJECT (eth), eth_signals [EXPANSION_CHANGE]); } GtkType |