aboutsummaryrefslogtreecommitdiffstats
path: root/widgets/table/e-table-item.c
diff options
context:
space:
mode:
Diffstat (limited to 'widgets/table/e-table-item.c')
-rw-r--r--widgets/table/e-table-item.c79
1 files changed, 37 insertions, 42 deletions
diff --git a/widgets/table/e-table-item.c b/widgets/table/e-table-item.c
index 59df09e5bb..0df506cfae 100644
--- a/widgets/table/e-table-item.c
+++ b/widgets/table/e-table-item.c
@@ -18,6 +18,7 @@
#include <math.h>
#include "e-table-item.h"
#include "e-cell.h"
+#include "e-util/e-canvas.h"
#define PARENT_OBJECT_TYPE gnome_canvas_item_get_type ()
@@ -27,7 +28,6 @@ static GnomeCanvasItemClass *eti_parent_class;
enum {
ROW_SELECTION,
- RESIZE,
LAST_SIGNAL
};
@@ -47,6 +47,8 @@ enum {
ARG_HAS_FOCUS
};
+static int eti_get_height (ETableItem *eti);
+
static gboolean
eti_editing (ETableItem *eti)
{
@@ -74,8 +76,6 @@ eti_realize_cell_views (ETableItem *eti)
eti->cell_views_realized = 1;
}
-static void eti_compute_height (ETableItem *eti);
-
static void
eti_attach_cell_views (ETableItem *eti)
{
@@ -96,7 +96,10 @@ eti_attach_cell_views (ETableItem *eti)
eti->cell_views [i] = e_cell_new_view (col->ecell, eti->table_model, eti);
}
- eti_compute_height (eti);
+ eti->needs_compute_height = 1;
+ e_canvas_item_request_reflow(GNOME_CANVAS_ITEM(eti));
+ eti->needs_redraw = 1;
+ gnome_canvas_item_request_update(GNOME_CANVAS_ITEM(eti));
}
/*
@@ -136,6 +139,19 @@ eti_bounds (GnomeCanvasItem *item, double *x1, double *y1, double *x2, double *y
{
}
+static void
+eti_reflow (GnomeCanvasItem *item, gint flags)
+{
+ ETableItem *eti = E_TABLE_ITEM (item);
+ if ( eti->needs_compute_height ) {
+ int new_height = eti_get_height (eti);
+ if ( new_height != eti->height ) {
+ eti->height = new_height;
+ e_canvas_item_request_parent_reflow(GNOME_CANVAS_ITEM(eti));
+ }
+ eti->needs_compute_height = 0;
+ }
+}
/*
* GnomeCanvasItem::update method
@@ -162,14 +178,14 @@ eti_update (GnomeCanvasItem *item, double *affine, ArtSVP *clip_path, int flags)
eti_bounds (item, &item->x1, &item->y1, &item->x2, &item->y2);
if ( item->x1 != c1.x ||
item->y1 != c1.y ||
- item->x2 != c2.x ||
- item->y2 != c2.y )
+ item->x2 != c2.x + 1 ||
+ item->y2 != c2.y + 1 )
{
gnome_canvas_request_redraw(item->canvas, item->x1, item->y1, item->x2, item->y2);
item->x1 = c1.x;
item->y1 = c1.y;
- item->x2 = c2.x;
- item->y2 = c2.y;
+ item->x2 = c2.x + 1;
+ item->y2 = c2.y + 1;
eti->needs_redraw = 1;
}
if ( eti->needs_redraw ) {
@@ -297,22 +313,6 @@ eti_get_height (ETableItem *eti)
}
static void
-eti_compute_height (ETableItem *eti)
-{
- int new_height = eti_get_height (eti);
-
- if (new_height != eti->height){
- /* double x1, y1, x2, y2;*/
- printf ("Emitting!\n");
-
- eti->height = new_height;
- eti_update (GNOME_CANVAS_ITEM (eti), NULL, NULL, 0);
-
- gtk_signal_emit (GTK_OBJECT (eti), eti_signals [RESIZE]);
- }
-}
-
-static void
eti_item_region_redraw (ETableItem *eti, int x0, int y0, int x1, int y1)
{
GnomeCanvasItem *item = GNOME_CANVAS_ITEM (eti);
@@ -342,12 +342,10 @@ eti_table_model_changed (ETableModel *table_model, ETableItem *eti)
eti->focused_row = eti->rows - 1;
}
- if (eti->cell_views)
- eti_compute_height (eti);
-
- eti_update (GNOME_CANVAS_ITEM (eti), NULL, NULL, 0);
-
- eti_item_region_redraw (eti, 0, 0, eti->width, eti->height);
+ eti->needs_compute_height = 1;
+ e_canvas_item_request_reflow(GNOME_CANVAS_ITEM(eti));
+ eti->needs_redraw = 1;
+ gnome_canvas_item_request_update(GNOME_CANVAS_ITEM(eti));
}
/* Unused. */
@@ -569,7 +567,8 @@ eti_set_arg (GtkObject *o, GtkArg *arg, guint arg_id)
eti->mode_spreadsheet = GTK_VALUE_BOOL (*arg);
break;
}
- eti_update (item, NULL, NULL, 0);
+ eti->needs_redraw = 1;
+ gnome_canvas_item_request_update(GNOME_CANVAS_ITEM(eti));
}
static void
@@ -610,6 +609,9 @@ eti_init (GnomeCanvasItem *item)
eti->selection_mode = GTK_SELECTION_SINGLE;
eti->needs_redraw = 0;
+ eti->needs_compute_height = 0;
+
+ e_canvas_item_set_reflow_callback(GNOME_CANVAS_ITEM(eti), eti_reflow);
}
#define gray50_width 2
@@ -655,9 +657,10 @@ eti_realize (GnomeCanvasItem *item)
eti_realize_cell_views (eti);
- eti_compute_height (eti);
-
- eti_update (item, NULL, NULL, 0);
+ eti->needs_compute_height = 1;
+ e_canvas_item_request_reflow (GNOME_CANVAS_ITEM(eti));
+ eti->needs_redraw = 1;
+ gnome_canvas_item_request_update(GNOME_CANVAS_ITEM(eti));
}
static void
@@ -1162,14 +1165,6 @@ eti_class_init (GtkObjectClass *object_class)
GTK_SIGNAL_OFFSET (ETableItemClass, row_selection),
gtk_marshal_NONE__INT_INT,
GTK_TYPE_NONE, 2, GTK_TYPE_INT, GTK_TYPE_INT);
-
- eti_signals [RESIZE] =
- gtk_signal_new ("resize",
- GTK_RUN_LAST,
- object_class->type,
- GTK_SIGNAL_OFFSET (ETableItemClass, resize),
- gtk_marshal_NONE__NONE,
- GTK_TYPE_NONE, 0);
gtk_object_class_add_signals (object_class, eti_signals, LAST_SIGNAL);