Skip to content

Commit

Permalink
Merge branch 'main' into dependabot/bundler/bundler-00f0729802
Browse files Browse the repository at this point in the history
  • Loading branch information
humancompanion-usds authored Oct 8, 2024
2 parents 1c245fc + 8f1fa6b commit 79c58b3
Show file tree
Hide file tree
Showing 15 changed files with 210 additions and 28 deletions.
1 change: 1 addition & 0 deletions .tool-versions
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
ruby 3.0.2
4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@
},
"homepage": "https://github.com/department-of-veterans-affairs/vets-design-system-documentation#readme",
"devDependencies": {
"@department-of-veterans-affairs/component-library": "^46.4.0",
"@department-of-veterans-affairs/component-library": "^47.1.0",
"gulp": "^4.0.2",
"gulp-clean": "^0.4.0",
"gulp-rename": "^2.0.0",
Expand All @@ -38,7 +38,7 @@
},
"dependencies": {
"@department-of-veterans-affairs/formation": "^11.0.12",
"@department-of-veterans-affairs/css-library": "^0.12.0"
"@department-of-veterans-affairs/css-library": "^0.12.2"
},
"engines": {
"npm": "6.14.8"
Expand Down
51 changes: 51 additions & 0 deletions src/_about/accessibility/focus-management.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
---
layout: documentation
title: Focus management
permalink: /about/accessibility/focus-management
has-parent: /about/accessibility/
intro-text: Focus is the element on a page that is ready for you to interact with. It's important for making websites accessible, especially for people who use keyboards or other assistive technology to use the site.
anchors:
- anchor: Focus indicator
- anchor: Focus order
- anchor: Focus management

---

Testing is crucial to ensure that focus on your page functions as expected across different scenarios. Below are some things to look out for.

## Focus indicator

Sighted keyboard users must always be able to see where the keyboard focus is. If they tab through a website without knowing which element is focused, navigating can be unpredictable.

Browsers handle displaying the keyboard focus automatically, but each displays it in a different way and may be just enough to pass accessibility guidelines. VA.gov has enhanced this outline to make it more visible.

![visual focus indicator screenshot]({{ site.baseurl }}/images/about/accessibility/focus-management/focus-indicator.png)

We advise against disabling the focus outline using `outline: 0` or `outline: none` in CSS. This practice can impair navigation for users who rely on keyboard navigation, especially those with visual impairments. Without a visible focus outline, sighted users may struggle to identify the currently focused element, making navigation difficult.

## Focus order

The programmatic focus order should match the visual focus order. Focus typically follows the order in which objects appear in the page source, but may not match the order which users expect to interact with elements on the page.

This can occur when the order of elements in the source is wrong. If an element's position is moved via CSS, it can move that element from where it would normally be positioned. Elements could also be hidden on a page, typically through moving it off-screen or changing it's opacity, but not taken out of the tab order. This makes them focusable even if the focus indicator cannot be seen. Because of that, be sure to test that focus is not placed on an element that is not visible.

## Focus management

Manually managing focus is necessary in some scenarios to provide a seamless and accessible user experience, especially for keyboard and screen reader users. Below are key things to know when setting focus manually.

### The focus should be intentionally set to the appropriate element when a user action requires a change of context or location

- When content is added to the screen in response to a user-triggered event, the focus should be moved to the new content.
- When content is removed from the screen in response to a user-triggered event, focus should be set to the next logical place in the interaction.
- Example: When opening a dialog, focus should be sent to that dialog. When the dialog is closed, focus is sent back to the original element that triggered it.

### Focus should not be lost or reset to the top of the page, except when the page is reloaded

- If focus is reset, keyboard users will have to start again from the beginning of the page. Screen reader users could also become disoriented and unsure if they are on a different page or if the current page reloaded.
- Example: If focus gets lost after closing a dialog. The focus should be set to the original element that triggered it.

### When setting focus, the target element must contain text that can be programmatically determined

- If you must set focus to a non-interactive element, it should have text to allow screen readers to read the text inside the container.
- When setting focus to a non-interactive element, the element should _not_ be added to the tab order of the page through `tabindex="0"`, the focus only needs to be set via JavaScript.
- If focus is set to an empty container, screen readers will have nothing to read, so this should be avoided.
1 change: 1 addition & 0 deletions src/_about/accessibility/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ intro-text: How to follow accessibility standards when using or contributing to
sub-pages:
- sub-page: Accessibility testing for design system components
- sub-page: Accessibility annotations
- sub-page: Focus management
---

{% include _site-in-this-section.html %}
Expand Down
6 changes: 3 additions & 3 deletions src/_data/margins.yml
Original file line number Diff line number Diff line change
Expand Up @@ -456,7 +456,7 @@ x:
show_square2: 1
outer_classes: vads-u-margin-left--yikes site-u-height--2square
- class: margin-x--auto
value: -1px
value: auto
grid_cols: 12
outer_classes: width-100

Expand Down Expand Up @@ -548,7 +548,7 @@ right:
show_square2: 1
outer_classes: vads-u-margin-left--yikes site-u-height--2square
- class: margin-right--auto
value: -1px
value: auto
grid_cols: 12
outer_classes: width-100

Expand Down Expand Up @@ -626,7 +626,7 @@ left:
value: -1px
outer_classes: vads-u-margin-left--yikes site-u-height--2square
- class: margin-left--auto
value: -1px
value: auto
grid_cols: 12
outer_classes: width-100

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,138 @@
---
layout: pattern
title: Know when their information is prefilled
draft: true
permalink: /patterns/help-users-to/know-when-their-information-is-prefilled
sub-section: help-users-to
intro-text: Follow this pattern to help users know when their information will be prefilled for them in an application.
research-title: Help users know when their info is prefilled
status: use-with-caution-candidate
anchors:
- anchor: Usage
- anchor: How to design and build
- anchor: Examples
- anchor: Code usage
- anchor: Content considerations
- anchor: Research findings
---

## Usage

### When to use this pattern

- **When you prefill the user's data into an application, like a form.** When using this pattern, clearly inform the user of where their data is being pulled from to prefill for them.
- **When users can update prefilled information.** View [Help users to... Know how their information is updated](https://design.va.gov/patterns/help-users-to/know-how-their-information-is-updated) for guidance on helping users update this prefilled information.

#### Design Principals
- **Visibility of system status.** This pattern demonstrates the usability principle of communicating the current state to help users feel in control and take appropriate action. [Learn more about Visibility of system status](https://www.nngroup.com/articles/visibility-system-status/).
- **User control and freedom.** This pattern also gives users control over their own information. [Learn more about User Control and Freedom](https://www.nngroup.com/articles/user-control-and-freedom/).

### When not to use this pattern
- **For unauthenticated users**. Users who aren't signed in shouldn't see their information prefilled when they interact with an application. However, when forms don't require users to be signed in, they should see an information alert describing benefits to signing in. [View the unauthenticated intro page alert](#unauthenticated-intro-page-alert) later described on this page.

### When to use caution
- **When prefilling data from a source other than VA Profile.** It is crucial to explain to the user exactly where the data is coming from so that if there are any errors in the data, it is clear how to correct them.

## How to design and build
### Anatomy or layout details
This pattern involves these types of pages found in VA.gov forms:
- **Introduction page**: The first page of a form. Introduces the process the Veteran or other beneficiary will follow to apply for a benefit or to complete a supporting form. Changes slightly after a user signs in.
- **Personal information page**: Usually the first page of a form after the user signs in. Has personal details that cannot be edited online, like name, date of birth, Social Security Number, etc.
- **Prefill check page**: Any page of a form that displays prefilled information users can edit within the form.

#### Introduction page
There are two states of an introduction page: Authenticated and Unauthenticated.

{% include component-example.html alt="Authenticated introduction page alert on the introduction page." file="/images/patterns/help-users-to/know-when-their-information-is-prefilled/intro-page-authenticated-alert.png" caption="Authenticated introduction page alert on the introduction page." class="x2" %}

{% include component-example.html alt="Unauthenticated introduction page alert on the introduction page." file="/images/patterns/help-users-to/know-when-their-information-is-prefilled/intro-page-unauthenticated-alert.png" caption="Unauthenticated introduction page alert on the introduction page." class="x2" %}

#### Personal information page
{% include component-example.html alt="Uneditable prefilled information on the personal information page." file="/images/patterns/help-users-to/know-when-their-information-is-prefilled/uneditable-prefill-information.png" caption="Uneditable prefilled information on the personal information page." class="x2" %}

#### Prefill check page
{% include component-example.html alt="" file="/images/patterns/help-users-to/know-when-their-information-is-prefilled/editable-prefill-information.png" caption="Editable prefilled information displayed on the Prefill check page. This is the proposed style to display data that is editable." class="x2" %}

### How this pattern works

#### Communicate when and why information will be prefilled
This pattern communicates when and why information will be prefilled with:
- **Unauthenticated intro page alert.**. This tells users they should expect prefilled information in a form after they sign in.
- **Authenticated intro page alert.** This alert tells users that some of their information may be prefilled for them because they are signed in.

#### Communicate information that cannot be edited
This pattern communicates information that cannot be edited with:
- **Uneditable prefilled information displayed in a card.** Prefilled information (such as legal name, date of birth, and Social Security Number) is displayed in a card component.
- **Directions for updating uneditable information.** Helper text is added under the card that has the bolded word 'Note" and directions to update this information offline. For additional guidance on helping users update prefilled information, see the ["Help users to... Know how their information is updated"](https://design.va.gov/patterns/help-users-to/know-how-their-information-is-updated) pattern which will be updated soon.

#### Communicate information that can be edited
This pattern communicates information that can be edited with:
- **Editable prefilled information displayed in a card with an edit link.** Prefilled information the is editable is displayed in a card component with a link to edit the information. For additional guidance on helping users update prefilled information, see the ["Help users to... Know how their information is updated"](https://design.va.gov/patterns/help-users-to/know-how-their-information-is-updated) pattern which will be updated soon.

### Components used in this pattern

- [Alert](https://design.va.gov/components/alert/)
- [Card](https://design.va.gov/components/card)


### Page templates available for this pattern

List of links to page templates or layouts used to build any pages for this pattern.

## Examples

Examples of this pattern. May contain reference or links to:

### Examples in production
Coming soon!

## Code usage
Coming soon!


## Content considerations
### Directions for updating uneditable information
Directions for updating information that can't be updated online within the form varies and should be updated based on the context of the form or application being used. CAIA is currently working on finalizing some base language to be included, but general guidelines are:
- If it's benefits related, include the content that has the VA benefits hotline
- If it's health related, include the content that has the VA benefits hotline AND the content to contact your local medical center


### Contextual Alert content
Each alert has specific content requirements. You can find each content scenario below.
- Unauthenticated intro page alert
- Authenticated intro page alert
- Authenticated contextual alert

#### Unauthenticated intro page alert
...[Draft guidance from CAIA](https://github.com/department-of-veterans-affairs/va.gov-team/blob/master/products/content/content-patterns-and-standards/sign-in-alerts.md) on sign in alerts?

> [heading] Sign in with a verified account
>
> [content] Here’s how signing in with an identity-verified account helps you:
> - We can fill in some of your information for you to save you time.
> - You can save your work in progress. You’ll have {time limit} from when you start or make changes to submit your form.
>
> After you sign in, we’ll tell you if you need to verify your identity for your account.
>
> **Note:** You can sign in after you start filling out your form. But you'll lose any information you already filled in.
>
> [button] Sign in or create an account
>
> [text link] Start your form without signing in

<img src="/images/patterns/help-users-to/know-when-their-information-is-prefilled/content-unauthenticated-alert.png" width="600" alt="Unauthenticated introduction page alert">


#### Authenticated intro page alert
> [content] **Note:** Since you’re signed in to your account, we can prefill part of your form based on your account details. You can also save your form in progress and come back later to finish filling it out.
<img src="/images/patterns/help-users-to/know-when-their-information-is-prefilled/content-authenticated-alert-for-intro.png" width="600" alt="Authenticated alert for introduction page">

#### Authenticated contextual alert
> [content] **Note:** We've prefilled some of your information from your account. If you need to correct anything, you can select edit below. All updates will be made only to this form.
<img src="/images/patterns/help-users-to/know-when-their-information-is-prefilled/content-authenticated-alert-for-page.png" width="600" alt="Authenticated alert for a form application page">

## Research findings
The Authenticated Experience Design Patterns team conducted [user research](https://github.com/department-of-veterans-affairs/va.gov-team/tree/master/products/authenticated-patterns/Design%20and%20Research/2024-07-Research%20Initiative-One-Prefill) to gather validation about this pattern.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
37 changes: 14 additions & 23 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -9,31 +9,22 @@
dependencies:
regenerator-runtime "^0.14.0"

"@department-of-veterans-affairs/component-library@^46.4.0":
version "46.4.0"
resolved "https://registry.yarnpkg.com/@department-of-veterans-affairs/component-library/-/component-library-46.4.0.tgz#e656e6b3e0c45a63f31256fc4e2cd4c301c542dd"
integrity sha512-gHMsFj5uJ8tSlL2QnDIHkMROYn+cDgoYCGsCwNpvk5p9swla8aVio/DCB3O2a9ueMhuxawvQpggG70KmawvRqw==
"@department-of-veterans-affairs/component-library@^47.1.0":
version "47.1.0"
resolved "https://registry.yarnpkg.com/@department-of-veterans-affairs/component-library/-/component-library-47.1.0.tgz#2162d343b38614057632af42e444c658bf68d908"
integrity sha512-ZKTDY8kiQ3F3i3hL3OLQ+fyv9B4Xi1qQkUnBegu8TC6KjXDNed3PxAuVO+5iJXYi604cgBW72gXYZYbi63ITFQ==
dependencies:
"@department-of-veterans-affairs/react-components" "28.1.0"
"@department-of-veterans-affairs/web-components" "14.4.0"
"@department-of-veterans-affairs/web-components" "15.1.0"
i18next "^21.6.14"
i18next-browser-languagedetector "^6.1.4"
react-focus-on "^3.5.1"
react-transition-group "^1.0.0"

"@department-of-veterans-affairs/css-library@^0.11.1":
version "0.11.1"
resolved "https://registry.yarnpkg.com/@department-of-veterans-affairs/css-library/-/css-library-0.11.1.tgz#6f00091e90a3476dc90ff99e80a0d8eca7edae1f"
integrity sha512-OAwcKvEE62shIXutqqadAQ1VyE0oADLfybgSzKr4W5d6uUVRR5cu8zUx0aztZSGJj11yUcsgrWxnq3O0MEgZ0A==
dependencies:
"@divriots/style-dictionary-to-figma" "^0.4.0"
"@uswds/uswds" "^3.8.1"
rimraf "^5.0.5"

"@department-of-veterans-affairs/css-library@^0.12.0":
version "0.12.0"
resolved "https://registry.yarnpkg.com/@department-of-veterans-affairs/css-library/-/css-library-0.12.0.tgz#41ac17420b1dcd13332b22cf0c4fa562bb067b3a"
integrity sha512-j7r9QADrf35ki0Nn8WiUhlCB6pRBZ/CPG/giJV6hwNi8PQ4X6AldgSnJ+mnZprSuswq4LAw9Sq3dKE4ezGT//Q==
"@department-of-veterans-affairs/css-library@^0.12.2":
version "0.12.2"
resolved "https://registry.yarnpkg.com/@department-of-veterans-affairs/css-library/-/css-library-0.12.2.tgz#da2554d1d71c1927b7462fa70d9cc8b482f8206e"
integrity sha512-nkrgeEGPWLEuoAfCdfFFPNIWIc9BDnxXZZ3HxZrKjL3yIAgNZYB+gm02JbYUHNXZZfXdfHxseaBY4M5C+Z3Iqg==
dependencies:
"@divriots/style-dictionary-to-figma" "^0.4.0"
"@uswds/uswds" "^3.8.1"
Expand All @@ -60,12 +51,12 @@
react-transition-group "1"
recast "^0.14.4"

"@department-of-veterans-affairs/web-components@14.4.0":
version "14.4.0"
resolved "https://registry.yarnpkg.com/@department-of-veterans-affairs/web-components/-/web-components-14.4.0.tgz#c4d4aceb91dbc80b596e24c9a9f90c1031a5d6b8"
integrity sha512-TGEvokHsMqQMuon34IAL5BFMByiQzsiKzmN1S66aRktNZOWN7v9OTNpAlBSuQBs976KidZD/Ac12b7vn4692Lw==
"@department-of-veterans-affairs/web-components@15.1.0":
version "15.1.0"
resolved "https://registry.yarnpkg.com/@department-of-veterans-affairs/web-components/-/web-components-15.1.0.tgz#ec0a6952a591f9ed0a7d3ddea2211047a3471d71"
integrity sha512-/kUPjVJb+Ira1rekD3suBNDJqYFzW1rsF5xT6d2NLe58kY6JnbMV+/w9KH1fG1uCIaXV5RaKVK0bDjSjMhRxAw==
dependencies:
"@department-of-veterans-affairs/css-library" "^0.11.1"
"@department-of-veterans-affairs/css-library" "^0.12.2"
"@stencil/core" "4.20.0"
aria-hidden "^1.1.3"
body-scroll-lock "^4.0.0-beta.0"
Expand Down

0 comments on commit 79c58b3

Please sign in to comment.