aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--composer/ChangeLog11
-rw-r--r--composer/e-msg-composer-hdrs.c45
2 files changed, 54 insertions, 2 deletions
diff --git a/composer/ChangeLog b/composer/ChangeLog
index e544968ed9..69262acb33 100644
--- a/composer/ChangeLog
+++ b/composer/ChangeLog
@@ -1,3 +1,14 @@
+2007-10-11 Milan Crha <mcrha@redhat.com>
+
+ ** Fix for bug #412360
+
+ * e-msg-composer-hdrs.c: (entry_query_tooltip):
+ New callback to query tooltip over GtkEntry.
+ * e-msg-composer-hdrs.c: (connect_entry_for_tooltip):
+ New function to connect GtkEntry to previous function and let it works.
+ * e-msg-composer-hdrs.c: (create_addressbook_entry), (create_headers):
+ Connect entries for tooltips.
+
2007-10-03 Matthew Barnes <mbarnes@redhat.com>
* e-msg-cmposer.c:
diff --git a/composer/e-msg-composer-hdrs.c b/composer/e-msg-composer-hdrs.c
index 144b9bd1b2..83a5cc3046 100644
--- a/composer/e-msg-composer-hdrs.c
+++ b/composer/e-msg-composer-hdrs.c
@@ -477,6 +477,44 @@ addressbook_entry_changed (GtkWidget *entry,
g_signal_emit (hdrs, signals[HDRS_CHANGED], 0);
}
+static gboolean
+entry_query_tooltip (GtkWidget *widget, gint x, gint y, gboolean keyboard_mode, GtkTooltip *tooltip, gpointer user_data)
+{
+ const char *text;
+
+ g_return_val_if_fail (widget != NULL, FALSE);
+ g_return_val_if_fail (GTK_IS_ENTRY (widget), FALSE);
+ g_return_val_if_fail (tooltip != NULL, FALSE);
+
+ if (keyboard_mode)
+ return FALSE;
+
+ text = gtk_entry_get_text (GTK_ENTRY (widget));
+
+ if (!text || !*text)
+ return FALSE;
+
+ gtk_tooltip_set_text (tooltip, text);
+
+ return TRUE;
+}
+
+/**
+ * connect_entry_for_tooltip
+ * This connects "tooltip" callback to entry.
+ * If entry has tooltip depends on the length of the text inside it.
+ * @param entry GtkEntry widget, to connect to.
+ **/
+static void
+connect_entry_for_tooltip (GtkWidget *entry)
+{
+ g_return_if_fail (entry != NULL);
+ g_return_if_fail (GTK_IS_ENTRY (entry));
+
+ g_signal_connect (G_OBJECT (entry), "query-tooltip", G_CALLBACK (entry_query_tooltip), NULL);
+ gtk_widget_set_has_tooltip (entry, TRUE);
+}
+
static GtkWidget *
create_addressbook_entry (EMsgComposerHdrs *hdrs, const char *name)
{
@@ -490,8 +528,8 @@ create_addressbook_entry (EMsgComposerHdrs *hdrs, const char *name)
e_name_selector_model_add_section (name_selector_model, name, name, NULL);
name_selector_entry = (ENameSelectorEntry *)e_name_selector_peek_section_list (priv->name_selector, name);
- g_signal_connect (name_selector_entry, "changed",
- G_CALLBACK (addressbook_entry_changed), hdrs);
+ g_signal_connect (name_selector_entry, "changed", G_CALLBACK (addressbook_entry_changed), hdrs);
+ connect_entry_for_tooltip (GTK_WIDGET (name_selector_entry));
e_name_selector_entry_set_contact_editor_func (name_selector_entry, e_contact_editor_new);
e_name_selector_entry_set_contact_list_editor_func (name_selector_entry, e_contact_list_editor_new);
@@ -649,6 +687,7 @@ create_headers (EMsgComposerHdrs *hdrs)
priv->subject.entry = gtk_entry_new ();
gtk_label_set_mnemonic_widget((GtkLabel *)priv->subject.label, priv->subject.entry);
g_signal_connect(priv->subject.entry, "changed", G_CALLBACK(entry_changed), hdrs);
+ connect_entry_for_tooltip (priv->subject.entry);
/*
* To, CC, and Bcc
@@ -684,6 +723,8 @@ create_headers (EMsgComposerHdrs *hdrs)
g_signal_connect(priv->post_to.entry, "changed",
G_CALLBACK (post_entry_changed_cb), hdrs);
+
+ connect_entry_for_tooltip (priv->post_to.entry);
}
static void