Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Better accessibility #74

Closed
lionel-bijaoui opened this issue Sep 22, 2016 · 10 comments
Closed

Better accessibility #74

lionel-bijaoui opened this issue Sep 22, 2016 · 10 comments

Comments

@lionel-bijaoui
Copy link
Member

Let's not forget about this, the web is for everybody.
I don't have experience with this, it could be nice to have someone who know about these stuff on board to help.
We could start with labels.

Documentation and information:

@icebob
Copy link
Member

icebob commented Sep 22, 2016

Good idea.

@icebob
Copy link
Member

icebob commented Dec 27, 2016

Some tool: https://github.com/addyosmani/a11y/

@dflock
Copy link
Collaborator

dflock commented Jan 13, 2017

I have experience in this area and have started work on this. As I'm fairly new to Vue, I wanted to validate my approach before I go to much further. I started with labels:

Labels

Associate with Control

To make labels accessible, you need to associate them with 'their' control. The best way to do this is to use a for attribute on the label, along with an id attribute on the control, like this:

<label for="first-name">First Name</label>
<input id="first-name" ... />

This means that we need an id on every input - which is a good idea for lots of reasons. My approach to solving this was to add a getFieldID function to abstractField.js:

getFieldID(schema) {
  if (typeof schema.id !== 'undefined') {
    // If an ID's been explicitly set, use it unchanged
    return schema.id
  } else {
    // Try to get a reasonable default id from the schema, then slugify it.
    return (schema.inputName || schema.label || schema.model)
      .toString()
      .trim()
      .toLowerCase()
      // Spaces to dashes
      .replace(/ /g, '-')
      // Multiple dashes to one
      .replace(/-{2,}/g, '-')
      // Remove leading & trailing dashes
      .replace(/^-+|-+$/g, '')
      // Remove anything that isn't a (English/ASCII) letter or number.
      .replace(/([^a-zA-Z0-9\._-]+)/g, '')
    ;
  }
}

This can then be used in every field*.vue component to set an id - for example, in fieldInput.vue:

<template lang="jade">
.wrapper
  input.form-control(
    :id="getFieldID(schema)",
    :type="schema.inputType",
    ...

Then, in formGenerator.vue, output the for attribute in the appropriate place:

label(v-if="fieldTypeHasLabel(field)", :for="getFieldID(field)")
  | {{ field.label }}

Don't output labels for buttons

I also noticed that labels were being output for buttons, which isn't the correct thing to do. I added a fieldTypeHasLabel function to formGenerator.vue (referenced in the above template):

fieldTypeHasLabel(field) {
  switch (field.type) {
    case 'button':
    case 'submit':
      return false;
    default:
      return true;
  }
},

This is all working fine for me locally, using the test/dev app. I'll push a fork/branch tomorrow and link it here - but in the meantime - does this sound like the correct way to go about these changes - and should I carry on?

@dflock
Copy link
Collaborator

dflock commented Jan 13, 2017

You could simplify this by setting the input's id to the same value as it's name - this is very common when creating forms manually.

But I think you'd want to add a form-level prefix to the inputs id - they need to be unique in the DOM, so you'd have potential for collisions if you had two forms in the DOM at the same time. (This isn't currently implemented, but would probably be a good idea).

You could leave this all to the user - and make them fill in a schema.id property, but I'd rather that things just worked, without lots of extra config required.

@icebob
Copy link
Member

icebob commented Jan 13, 2017

@dflock Thanks your suggestion. I think it is good way. Please make a PR and I will test it.

@jmverges
Copy link
Contributor

What is the status on this? @dflock ?

@dflock
Copy link
Collaborator

dflock commented Mar 22, 2017

Just about freed myself up to start working on this again. Hope to have an updated version of #105 pushed by this evening.

@dflock
Copy link
Collaborator

dflock commented Mar 22, 2017

After that, I want to work on sorting out the current <fieldset> and <legend> issues, as part of this accessibility thread.

@lionel-bijaoui
Copy link
Member Author

Some resources : http://inclusive-components.club/toggle-button/

@icebob
Copy link
Member

icebob commented May 25, 2017

Closed by #201

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants