aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui/e-timezone-entry.c
diff options
context:
space:
mode:
authorLi Yuan <li.yuan@sun.com>2006-06-05 17:40:25 +0800
committerLi Yuan <liyuan@src.gnome.org>2006-06-05 17:40:25 +0800
commit7b66244b517d5d6cba73e41e37c10f09ab2e506b (patch)
treef1b2dab5c196d9ebd9cc0a98c87121c0f10e9d2d /calendar/gui/e-timezone-entry.c
parent64f2944a027279c9554c229319b38a6c07ac96e4 (diff)
downloadgsoc2013-evolution-7b66244b517d5d6cba73e41e37c10f09ab2e506b.tar.gz
gsoc2013-evolution-7b66244b517d5d6cba73e41e37c10f09ab2e506b.tar.zst
gsoc2013-evolution-7b66244b517d5d6cba73e41e37c10f09ab2e506b.zip
add labelled by relationship between label and e-timezone-entry. add
2006-06-05 Li Yuan <li.yuan@sun.com> * gui/dialogs/cal-prefs-dialog.glade: add labelled by relationship between label and e-timezone-entry. * gui/e-timezone-entry.c: (add_relation), (e_timezone_entry_set_timezone): add relationship between label and entry. svn path=/trunk/; revision=32078
Diffstat (limited to 'calendar/gui/e-timezone-entry.c')
-rw-r--r--calendar/gui/e-timezone-entry.c44
1 files changed, 44 insertions, 0 deletions
diff --git a/calendar/gui/e-timezone-entry.c b/calendar/gui/e-timezone-entry.c
index fe57453540..e708a03618 100644
--- a/calendar/gui/e-timezone-entry.c
+++ b/calendar/gui/e-timezone-entry.c
@@ -71,6 +71,8 @@ static void on_entry_changed (GtkEntry *entry,
ETimezoneEntry *tentry);
static void on_button_clicked (GtkWidget *widget,
ETimezoneEntry *tentry);
+static void add_relation (ETimezoneEntry *tentry,
+ GtkWidget *widget);
static void e_timezone_entry_set_entry (ETimezoneEntry *tentry);
@@ -224,6 +226,46 @@ e_timezone_entry_get_timezone (ETimezoneEntry *tentry)
return priv->zone;
}
+static void
+add_relation (ETimezoneEntry *tentry,
+ GtkWidget *widget)
+{
+ AtkObject *a11ytentry, *a11yWidget;
+ AtkRelationSet *set;
+ AtkRelation *relation;
+ GPtrArray *target;
+ gpointer target_object;
+
+ /* add a labelled_by relation for widget for accessibility */
+
+ a11ytentry = gtk_widget_get_accessible (GTK_WIDGET (tentry));
+ a11yWidget = gtk_widget_get_accessible (widget);
+
+ set = atk_object_ref_relation_set (a11yWidget);
+ if (set != NULL) {
+ relation = atk_relation_set_get_relation_by_type (set,
+ ATK_RELATION_LABELLED_BY);
+ /* check whether has a labelled_by relation already */
+ if (relation != NULL)
+ return;
+ }
+
+ set = atk_object_ref_relation_set (a11ytentry);
+ if (!set)
+ return;
+
+ relation = atk_relation_set_get_relation_by_type (set,
+ ATK_RELATION_LABELLED_BY);
+ if (relation != NULL) {
+ target = atk_relation_get_target (relation);
+ target_object = g_ptr_array_index (target, 0);
+ if (ATK_IS_OBJECT (target_object)) {
+ atk_object_add_relationship (a11yWidget,
+ ATK_RELATION_LABELLED_BY,
+ ATK_OBJECT (target_object));
+ }
+ }
+}
void
e_timezone_entry_set_timezone (ETimezoneEntry *tentry,
@@ -238,6 +280,8 @@ e_timezone_entry_set_timezone (ETimezoneEntry *tentry,
priv->zone = zone;
e_timezone_entry_set_entry (tentry);
+
+ add_relation (tentry, priv->entry);
}