aboutsummaryrefslogtreecommitdiffstats
path: root/widgets/misc
diff options
context:
space:
mode:
Diffstat (limited to 'widgets/misc')
-rw-r--r--widgets/misc/e-canvas.c55
-rw-r--r--widgets/misc/e-canvas.h8
2 files changed, 63 insertions, 0 deletions
diff --git a/widgets/misc/e-canvas.c b/widgets/misc/e-canvas.c
index 91fbca29b8..e48c6bb821 100644
--- a/widgets/misc/e-canvas.c
+++ b/widgets/misc/e-canvas.c
@@ -31,6 +31,10 @@ static void e_canvas_unrealize (GtkWidget *widget);
static gint e_canvas_key (GtkWidget *widget,
GdkEventKey *event);
+static gint e_canvas_visibility (GtkWidget *widget,
+ GdkEventVisibility *event,
+ ECanvas *canvas);
+
static gint e_canvas_focus_in (GtkWidget *widget,
GdkEventFocus *event);
static gint e_canvas_focus_out (GtkWidget *widget,
@@ -114,6 +118,7 @@ e_canvas_init (ECanvas *canvas)
canvas->cursor = NULL;
canvas->ic = NULL;
canvas->ic_attr = NULL;
+ canvas->tooltip_window = NULL;
}
static void
@@ -124,6 +129,16 @@ e_canvas_destroy (GtkObject *object)
if (canvas->idle_id)
g_source_remove(canvas->idle_id);
+ if (canvas->toplevel) {
+ if (canvas->visibility_notify_id)
+ gtk_signal_disconnect (GTK_OBJECT(canvas->toplevel),
+ canvas->visibility_notify_id);
+ canvas->visibility_notify_id = 0;
+
+ gtk_object_unref(GTK_OBJECT(canvas->toplevel));
+ canvas->toplevel = NULL;
+ }
+
if ((GTK_OBJECT_CLASS (parent_class))->destroy)
(*(GTK_OBJECT_CLASS (parent_class))->destroy) (object);
}
@@ -284,6 +299,18 @@ e_canvas_key (GtkWidget *widget, GdkEventKey *event)
return emit_event (canvas, &full_event);
}
+/* Key event handler for the canvas */
+static gint
+e_canvas_visibility (GtkWidget *widget, GdkEventVisibility *event, ECanvas *canvas)
+{
+ if (! canvas->visibility_first) {
+ e_canvas_hide_tooltip(canvas);
+ }
+ canvas->visibility_first = FALSE;
+
+ return FALSE;
+}
+
/**
* e_canvas_item_grab_focus:
@@ -703,3 +730,31 @@ e_canvas_item_remove_selection (GnomeCanvasItem *item, gpointer id)
}
}
}
+
+void e_canvas_popup_tooltip (ECanvas *canvas, GtkWidget *widget, int x, int y)
+{
+ if (canvas->tooltip_window && canvas->tooltip_window != widget) {
+ e_canvas_hide_tooltip(canvas);
+ }
+ canvas->tooltip_window = widget;
+ canvas->visibility_first = TRUE;
+ if (canvas->toplevel == NULL) {
+ canvas->toplevel = gtk_widget_get_toplevel (GTK_WIDGET(canvas));
+ if (canvas->toplevel) {
+ gtk_widget_add_events(canvas->toplevel, GDK_VISIBILITY_NOTIFY_MASK);
+ gtk_object_ref(GTK_OBJECT(canvas->toplevel));
+ canvas->visibility_notify_id =
+ gtk_signal_connect (GTK_OBJECT (canvas->toplevel), "visibility_notify_event",
+ GTK_SIGNAL_FUNC (e_canvas_visibility), canvas);
+ }
+ }
+ gtk_widget_popup (widget, x, y);
+}
+
+void e_canvas_hide_tooltip (ECanvas *canvas)
+{
+ if (canvas->tooltip_window) {
+ gtk_widget_destroy (canvas->tooltip_window);
+ canvas->tooltip_window = NULL;
+ }
+}
diff --git a/widgets/misc/e-canvas.h b/widgets/misc/e-canvas.h
index 212fda7c2f..820dcddc2e 100644
--- a/widgets/misc/e-canvas.h
+++ b/widgets/misc/e-canvas.h
@@ -79,6 +79,11 @@ struct _ECanvas
GList *selection;
ECanvasSelectionInfo *cursor;
+ GtkWidget *tooltip_window;
+ int visibility_notify_id;
+ GtkWidget *toplevel;
+ guint visibility_first : 1;
+
/* Input context for dead key support */
GdkIC *ic;
GdkICAttr *ic_attr;
@@ -113,6 +118,9 @@ void e_canvas_item_remove_selection (GnomeCanvasItem *item, gpointer id);
/* Not implemented yet. */
void e_canvas_item_set_cursor_end (GnomeCanvasItem *item, gpointer id);
+void e_canvas_popup_tooltip (ECanvas *canvas, GtkWidget *widget, int x, int y);
+void e_canvas_hide_tooltip (ECanvas *canvas);
+
#ifdef __cplusplus
}
#endif /* __cplusplus */