a11y: Set an accessible role for GtkSearchEntry

Use the searchbox accessible role for GtkSearchEntry.
And set properties as appropriate.

Update the documentation and add a test.
This commit is contained in:
Matthias Clasen 2020-07-28 18:15:01 -04:00
parent 2040b7ecdf
commit a610bb89a0
5 changed files with 66 additions and 4 deletions

View File

@ -56,6 +56,7 @@ Each role name is part of the #GtkAccessibleRole enumeration.
| `PROGRESS_BAR` | An element that display progress | #GtkProgressBar | | `PROGRESS_BAR` | An element that display progress | #GtkProgressBar |
| `RADIO` | A checkable input in a group of radio roles | #GtkRadioButton | | `RADIO` | A checkable input in a group of radio roles | #GtkRadioButton |
| `SCROLLBAR` | A graphical object controlling the scolling of content | #GtkScrollbar | | `SCROLLBAR` | A graphical object controlling the scolling of content | #GtkScrollbar |
| `SEARCH_BOX` | A text box for entering search criteria | #GtkSearchEntry |
| `SEPARATOR` | A divider that separates sections of content or groups of items | #GtkSeparator | | `SEPARATOR` | A divider that separates sections of content or groups of items | #GtkSeparator |
| `SPIN_BUTTON` | A range control that allows seelcting among discrete choices | #GtkSpinButton | | `SPIN_BUTTON` | A range control that allows seelcting among discrete choices | #GtkSpinButton |
| `SWITCH` | A control that represents on/off values | #GtkSwitch | | `SWITCH` | A control that represents on/off values | #GtkSwitch |

View File

@ -1217,7 +1217,8 @@ typedef enum {
* of content within a viewing area, regardless of whether the content is fully * of content within a viewing area, regardless of whether the content is fully
* displayed within the viewing area. * displayed within the viewing area.
* @GTK_ACCESSIBLE_ROLE_SEARCH: Unused * @GTK_ACCESSIBLE_ROLE_SEARCH: Unused
* @GTK_ACCESSIBLE_ROLE_SEARCH_BOX: Unused * @GTK_ACCESSIBLE_ROLE_SEARCH_BOX: A type of textbox intended for specifying
* search criteria.
* @GTK_ACCESSIBLE_ROLE_SECTION: Unused * @GTK_ACCESSIBLE_ROLE_SECTION: Unused
* @GTK_ACCESSIBLE_ROLE_SECTION_HEAD: Unused * @GTK_ACCESSIBLE_ROLE_SECTION_HEAD: Unused
* @GTK_ACCESSIBLE_ROLE_SELECT: Unused * @GTK_ACCESSIBLE_ROLE_SELECT: Unused

View File

@ -79,7 +79,10 @@
* *
* GtkSearchEntry has a single CSS node with name entry that carries * GtkSearchEntry has a single CSS node with name entry that carries
* a .sarch style class, and the text node is a child of that. * a .sarch style class, and the text node is a child of that.
*
* # Accessibility
*
* GtkSearchEntry uses the #GTK_ACCESSIBLE_ROLE_SEARCH_BOX role.
*/ */
enum { enum {
@ -177,14 +180,28 @@ gtk_search_entry_set_property (GObject *object,
GParamSpec *pspec) GParamSpec *pspec)
{ {
GtkSearchEntry *entry = GTK_SEARCH_ENTRY (object); GtkSearchEntry *entry = GTK_SEARCH_ENTRY (object);
const char *text;
if (gtk_editable_delegate_set_property (object, prop_id, value, pspec)) if (gtk_editable_delegate_set_property (object, prop_id, value, pspec))
return; {
if (prop_id == NUM_PROPERTIES + GTK_EDITABLE_PROP_EDITABLE)
{
gtk_accessible_update_property (GTK_ACCESSIBLE (entry),
GTK_ACCESSIBLE_PROPERTY_READ_ONLY, !g_value_get_boolean (value),
-1);
}
return;
}
switch (prop_id) switch (prop_id)
{ {
case PROP_PLACEHOLDER_TEXT: case PROP_PLACEHOLDER_TEXT:
gtk_text_set_placeholder_text (GTK_TEXT (entry->entry), g_value_get_string (value)); text = g_value_get_string (value);
gtk_text_set_placeholder_text (GTK_TEXT (entry->entry), text);
gtk_accessible_update_property (GTK_ACCESSIBLE (entry),
GTK_ACCESSIBLE_PROPERTY_PLACEHOLDER, text,
-1);
break; break;
case PROP_ACTIVATES_DEFAULT: case PROP_ACTIVATES_DEFAULT:
@ -398,6 +415,7 @@ gtk_search_entry_class_init (GtkSearchEntryClass *klass)
gtk_widget_class_set_layout_manager_type (widget_class, GTK_TYPE_BOX_LAYOUT); gtk_widget_class_set_layout_manager_type (widget_class, GTK_TYPE_BOX_LAYOUT);
gtk_widget_class_set_css_name (widget_class, I_("entry")); gtk_widget_class_set_css_name (widget_class, I_("entry"));
gtk_widget_class_set_accessible_role (widget_class, GTK_ACCESSIBLE_ROLE_SEARCH_BOX);
} }
static GtkEditable * static GtkEditable *

View File

@ -19,6 +19,7 @@ tests = [
{ 'name': 'label' }, { 'name': 'label' },
{ 'name': 'progressbar' }, { 'name': 'progressbar' },
{ 'name': 'scrollbar' }, { 'name': 'scrollbar' },
{ 'name': 'searchentry' },
{ 'name': 'separator' }, { 'name': 'separator' },
{ 'name': 'spinbutton' }, { 'name': 'spinbutton' },
{ 'name': 'switch' }, { 'name': 'switch' },

View File

@ -0,0 +1,41 @@
#include <gtk/gtk.h>
static void
search_entry_role (void)
{
GtkWidget *widget = gtk_search_entry_new ();
g_object_ref_sink (widget);
gtk_test_accessible_assert_role (widget, GTK_ACCESSIBLE_ROLE_SEARCH_BOX);
g_object_unref (widget);
}
static void
search_entry_properties (void)
{
GtkWidget *widget = gtk_search_entry_new ();
g_object_ref_sink (widget);
gtk_test_accessible_assert_property (widget, GTK_ACCESSIBLE_PROPERTY_PLACEHOLDER, NULL);
gtk_test_accessible_assert_property (widget, GTK_ACCESSIBLE_PROPERTY_READ_ONLY, FALSE);
g_object_set (widget, "placeholder-text", "Hello", NULL);
gtk_editable_set_editable (GTK_EDITABLE (widget), FALSE);
gtk_test_accessible_assert_property (widget, GTK_ACCESSIBLE_PROPERTY_PLACEHOLDER, "Hello");
gtk_test_accessible_assert_property (widget, GTK_ACCESSIBLE_PROPERTY_READ_ONLY, TRUE);
g_object_unref (widget);
}
int
main (int argc, char *argv[])
{
gtk_test_init (&argc, &argv, NULL);
g_test_add_func ("/a11y/searchentry/role", search_entry_role);
g_test_add_func ("/a11y/searchentry/properties", search_entry_properties);
return g_test_run ();
}