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

Add aria-invalid attribute to all required fields (LG-3531) #4309

Merged
merged 8 commits into from
Oct 19, 2020

Conversation

zachmargolis
Copy link
Contributor

I opted to enforce this in our accessibility specs by adding my own custom RSpec matcher.

Another option would be to upgrade axe-matchers (which has been replaced)

@@ -14,7 +14,7 @@
<%= validated_form_for(@password_reset_email_form,
url: user_password_path,
html: { autocomplete: 'off', method: :post, role: 'form' }) do |f| %>
<%= f.input :email, required: true, input_html: { 'aria-describedby': 'email-description' } %>
<%= f.input :email, required: true, input_html: { aria: { invalid: true, describedby: 'email-description' } } %>
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For some reason, doing 'aria-invalid': true just never rendered to the DOM, so I had to do this syntax, similar to how data- prefixed keys work

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Curious if 'aria-invalid': 'true' would have worked (i.e. maybe boolean values only treated specially for aria and data groupings?).

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No dice! That did not seem to work. I have a feeling that this is due to how the input_html is passed through various translation layers to ActionView, but haven't dug deep enough to confirm

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🤷 IMO, the object form seems quite nice as it is anyhow.

@aduth
Copy link
Member

aduth commented Oct 15, 2020

From related resources, I think we want the default value to be aria-invalid="false", and then switch it to true if and when we want to signal the field is invalid.

To stop form controls from announcing as invalid by default, one can add aria-invalid="false" to any necessary element. [...] When its time to mark a form control as invalid, the attribute’s value should be set to “true”. Ideally, a control should be set to invalid only after a required control has been focused, and then blurred, without a proper string being entered.

https://developer.paciellogroup.com/blog/2019/02/required-attribute-requirements/

Guidance around when to trigger the switch is mixed, but blur seems to be a reasonable default:

Note that it is not necessary to validate the fields immediately on blur; the application could wait until the form is submitted (though this is not necessarily recommended).

https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Techniques/Using_the_aria-invalid_attribute#Example_1_Simple_form_validation

In our case, we might be able to handle this as part of the existing form-validation.js logic. This only applies to fields with the field class, but that should cover most of the validated_form_for usage.

@zachmargolis
Copy link
Contributor Author

From related resources, I think we want the default value to be aria-invalid="false", and then switch it to true if and when we want to signal the field is invalid.

Ah, whoops, thanks!

In our case, we might be able to handle this as part of the existing form-validation.js logic. This only applies to fields with the field class, but that should cover most of the validated_form_for usage.

Good point -- I'll take a shot at adding the logic there

@zachmargolis
Copy link
Contributor Author

From related resources, I think we want the default value to be aria-invalid="false", and then switch it to true if and when we want to signal the field is invalid.

Ah, whoops, thanks!

Updated in 069dc7f

In our case, we might be able to handle this as part of the existing form-validation.js logic. This only applies to fields with the field class, but that should cover most of the validated_form_for usage.

Good point -- I'll take a shot at adding the logic there

Added in 4d75bc4

before after
Blank form is invalid before it is interacted with Screen Shot 2020-10-16 at 9 58 56 AM Blank form is just "required" not "invalid" Screen Shot 2020-10-16 at 9 59 49 AM
After form labeled as invalid after interacted with (expected) Screen Shot 2020-10-16 at 10 03 44 AM After interacting, invalid form still labeled as invalid Screen Shot 2020-10-16 at 9 58 41 AM

Copy link
Member

@aduth aduth left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good 👍

@zachmargolis zachmargolis merged commit 1abcb81 into master Oct 19, 2020
@zachmargolis zachmargolis deleted the margolis-aria-invalid branch October 19, 2020 14:39
mitchellhenke added a commit that referenced this pull request Oct 22, 2020
* Log the user UUID in the image uploads controller (#4286)

**Why**: The image uploads controller does not have a current user, so by default the logs won't include the UUID we use to lookup events for a user.

* Async phone proofing calls (LG-3275) (#4273)

* refactor proofing document capture session result

* async phone proofing calls

* fix step specs

* fix controller specs

* fix bad translation reference

* use lambda runner for address proofing

* add timed_out test

* add retries gem

* use lambda

* temporary lambda ref update

* lint

* use Agent in lambda controller spec

* add in progress spec

* strong parameters

* lint

* do not return idv result in lambda callback

* use constants for magic phone numbers

* remove retries from Gemfile

* move job class logic into proofer

* update lambda version

* reorder spec expectations

* LG-3512: Apply link button styling to link element (#4290)

**Why**: As a user, I expect that I can click anywhere within a visual button to trigger the button's behavior, so that I can proceed with the action I intended and expected.

* Hide "+" character from screen readers via aria-hidden (LG-3560) (#4291)

* Fix intermittent IAA Billing Report test failures by sorting SPs (#4289)

**Why**: Ensure tests pass consistently

* Remove unused Webpack loaders (#4279)

* Remove unused Webpack loaders

**Why**: Build performance, improved compatibility with future Webpacker v6 release, improved interoperability with future addition of loaders e.g. source-map-loader

* Upgrade focus-trap from 6.1.0 to 6.1.3

**Why**: Fix syntax errors in Internet Explorer

* Add source-map-loader to Webpack configuration (#4280)

* Add source-map-loader to Webpack configuration

**Why**: Improved debuggability of vendor dependencies by respecting any available sourcemaps provided (for example, `identity-style-guide`).

* Configure devtool as eval-source-map in development

**Why** Improved sourcemap respect

* LG-3423: Refactor doc capture (hybrid) polling to own endpoint (#4293)

* LG-3423: Refactor doc capture (hybrid) polling to own endpoint

**Why**: Isolate standalone polling behavior for easier disambiguation of controller as exclusively responding to JSON, improved ability to implement test specs for controller in isolation.

* Revert capture doc status URL to original path

See: #4293 (comment)

* Use existing user helper value for stubbed sign in

* Async proofing for recovery flow (#4294)

* make recovery flow use async proofing

* remove unused method

* securely compare all pii on recovery

* Remove unused profile step (#4297)

* Add CircleCI lint step to verify ES5 syntax for Internet Explorer (#4296)

* Add 18f/identity-es5-safe package

* Add es5-safe script

* Configure CircleCI to check ES5 safeness

* Add JSDoc type annotations

* Cast stream file value to string

* Remove unnecessary eslint-disable

Configured in eslintrc

* Bump Mocha to latest version

**Why**: ESM compat

* Add test specs for identity-es5-safe

* Generate desktop selfie as JPEG at original (constrained) capture size (#4295)

**Why**: Higher-quality images in a format more aligned with how selfies are generated by Acuant SDK in mobile contexts.

* Remove explicit dependency to identity-es5-safe (#4298)

**Why**: Appears to cause issues with Yarn integrity, and not strictly necessary

* fix warning from i18n update (#4300)

* Fixes a bug where canceling identity proofing would leave the user in an endless loop (LG-3520) (#4301)

* Use default USWDS pseudo-class for banner collapse button (#4277)

**Why**: Consistency with USWDS, eliminate redundant (duplicate) button controls, reduce localization string maintenance overhead, eliminate jQuery dependency from application JavaScript pack

* Convert more slim templates (#4304)

* convert idv phone new template to erb

* convert idv address template to erb

* convert piv cac login error template to erb

* convert saml_test decode response template to erb

* normalize yaml

* Update app/views/idv/address/new.html.erb

Co-authored-by: Zach Margolis <zachmargolis@users.noreply.github.com>

Co-authored-by: Zach Margolis <zachmargolis@users.noreply.github.com>

* LG-3576 Update the piv/cac chooser page with new graphics, layout, content, and translations. (#4302)

LG-3576 Update the piv/cac chooser page with new graphics, layout, content, and translations.

Co-authored-by: Andrew Duthie <andrew.duthie@gsa.gov>

* Fixing 2FA SMS code not autocompleting in Safari (#4303)

**Why**:
- 2FA code field does not sugguest the code received via SMS
in Safari browser both on mobile and on desktop. This is to fix
the issue by adding the recommended autocomplete attribute.

**How**:
- Setting autocomplete to one-time-code as recommended on Apple's website
https://developer.apple.com/documentation/security/password_autofill/enabling_password_autofill_on_an_html_input_element and on Mozilla https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete

* One liner to fix local docker building.  (#4306)

With the async work being done there was a file dependency added to the gemfile. Bundle install is run in the container before the directory tree is copied into the container.

* ensure input has associated label (#4311)

* fix bottom margin on label (#4312)

* async proofing for cac flow (#4299)

* add wait step to cac flow

* add async to cac proofing flow

* refactor how verify steps use document capture by consolidating

* remove old comments

* fix bad method call

* fix bad method call

* lint

* add specs

* lint

* Async resolution proofing in USPS flow (#4305)

* add wait step to cac flow

* add async to cac proofing flow

* refactor how verify steps use document capture by consolidating

* remove old comments

* fix bad method call

* fix bad method call

* lint

* add specs

* lint

* convert usps to async proofing

* add meta refresh

* remove comments

* use pii method

* clear uuid on done

* Use lambdas for async resolution proofing calls (#4308)

* add wait step to cac flow

* add async to cac proofing flow

* refactor how verify steps use document capture by consolidating

* remove old comments

* fix bad method call

* fix bad method call

* lint

* add specs

* lint

* convert usps to async proofing

* add meta refresh

* remove comments

* use pii method

* clear uuid on done

* track exception on lambda callback

* replace VendorProofJob with lambda call

* update lambda version

* convert cac verify step to lambda

* use lambdas for usps resolution proofing

* analytics on optional show steps

* use better text on waiting pages

* add meta refresh tags

* do not enqueue if already in document capture session

* delete proofer mocks

* Update app/services/flow/flow_state_machine.rb

Co-authored-by: Zach Margolis <zachmargolis@users.noreply.github.com>

* Update spec/controllers/lambda_callback/resolution_proof_result_controller_spec.rb

Co-authored-by: Zach Margolis <zachmargolis@users.noreply.github.com>

* remove unused methods

Co-authored-by: Zach Margolis <zachmargolis@users.noreply.github.com>

* Convert more slim templates (#4316)

* convert backup code setup create template to erb

* convert two factor auth options index template to erb

* convert reactivate account index template to erb

* Update app/views/two_factor_authentication/options/index.html.erb

Co-authored-by: Zach Margolis <zachmargolis@users.noreply.github.com>

Co-authored-by: Zach Margolis <zachmargolis@users.noreply.github.com>

* Add aria-invalid attribute to all required fields (LG-3531) (#4309)

* Set aria-invalid based on input validity in form-validation.js

* LG-3419: Add background upload for images in document capture (#4314)

* Disable restricted syntax ESLint rule

**Why**: Used by AirBnB ruleset to forbid use of awaited loops due to need for regenerator-runtime. We already use regenerator-runtime, so its addition is not unwarranted or unexpected.

* Await promise payload values in submission

* LG-3419: Add background upload for images in document capture

**Why**: In anticipation to support async upload to S3, use presigned URLs (if available) to upload images at time of value change. Submission will only occur once all images have completed uploading, and will error appropriately if async upload fails.

* Omit undefined values from upload toFormData

**Why**: If promise form data resolves to undefined, expect to not be included in upload payload.

* Resolve background upload to undefined

**Why**: Avoid including in submission payload

* Add test spec for withBackgroundEncryptedUpload

* Implement submission series utility as variadic function

See: #4314 (comment)

* DocAuth: Move it to a gem (#4307)

* LG-3589: List supported MIME types for file input accept pattern (#4317)

* List supported MIME types for Acuant accept pattern

**Why**: As a user, I expect that if I attempt to upload a file (image or otherwise) that will not be supported by the proofing vendor, that I am made aware of this as soon as possible. I also expect that the types of files accepted by the file input match those which are described in the line above, so that the types of files which are accepted are exactly the same as those expected to be allowed to be accepted (no more, no fewer).

* Fix test spec typo on JPG MIME type

See: https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types

* Show improved error message for unexpected file type

**Why**: Per text recommendation in LG-3589. Selfie text is not entirely accurate, both verbiage and semantics. Also easier to port FileInput to reusable component as standalone string.

* Update string usage from doc auth gem (#4320)

* Add additional used strings from doc auth gem

* Remove unused selfie string from JS configuration

* LG-3672 Fix overall success rate reporting when doc capture step enabled (#4318)

* LG-3645 Fix authentication costing for SAML (#4319)

* Ensure advance warning of links opening new window (LG-3528) (#4310)

* convert registration pii accordion to erb and add new window warning to external link

* convert users emails show template to erb and add new window warning to external links

* update translations

* add new window warning to external links

* use partial for rendering links that open new window

* automatically apply external link icon

* helper function and CSS update

* indenting

* link helper

* set target=_blank

* Update styles to not conflict

Co-authored-by: Andrew Duthie <andrew.duthie@gsa.gov>

* comment

* support block form in new_window_link_to

* use new link helper

* fix a couple bugs

* Update app/views/idv/doc_auth/overview.html.erb

Co-authored-by: Andrew Duthie <andrew.duthie@gsa.gov>

* Update app/views/sign_up/registrations/new.html.erb

Co-authored-by: Andrew Duthie <andrew.duthie@gsa.gov>

* Update app/views/sign_up/registrations/new.html.erb

Co-authored-by: Andrew Duthie <andrew.duthie@gsa.gov>

* lint

* update helper to behave more like link_to

* remove convert_options_to_data_attributes

* maintain footer colors

* fix double footer link spec

Co-authored-by: Andrew Duthie <andrew.duthie@gsa.gov>

* LG-3416 API to verify documents (#4313)

* Bump identity-idp-functions (#4328)

* Bump identity-idp-functions

**Why**: Removes eager ENV.fetch that caused issues for
inline job execution

* Update Gemfile.lock too

Co-authored-by: Jonathan Hooper <jonathan.hooper@gsa.gov>
Co-authored-by: Andrew Duthie <andrew.duthie@gsa.gov>
Co-authored-by: Zach Margolis <zachmargolis@users.noreply.github.com>
Co-authored-by: Doug Price <douglas.price@gsa.gov>
Co-authored-by: Alex Mathews <44584810+amathews-fs@users.noreply.github.com>
Co-authored-by: Ankur Patel <ankur.patel@ymail.com>
Co-authored-by: Steve Urciuoli <steve.urciuoli@gsa.gov>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants