diff --git a/.tool-versions b/.tool-versions
new file mode 100644
index 000000000..a2e778299
--- /dev/null
+++ b/.tool-versions
@@ -0,0 +1 @@
+ruby 3.0.2
diff --git a/package.json b/package.json
index 6fb9a9e7e..1b72c5ee7 100644
--- a/package.json
+++ b/package.json
@@ -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",
@@ -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"
diff --git a/src/_about/accessibility/focus-management.md b/src/_about/accessibility/focus-management.md
new file mode 100644
index 000000000..ad82329a8
--- /dev/null
+++ b/src/_about/accessibility/focus-management.md
@@ -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.
diff --git a/src/_about/accessibility/index.md b/src/_about/accessibility/index.md
index c6e182924..03e86d406 100644
--- a/src/_about/accessibility/index.md
+++ b/src/_about/accessibility/index.md
@@ -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 %}
diff --git a/src/_data/margins.yml b/src/_data/margins.yml
index ecde2f7b2..5c48907f1 100644
--- a/src/_data/margins.yml
+++ b/src/_data/margins.yml
@@ -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
@@ -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
@@ -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
diff --git a/src/_patterns/help-users-to/know-when-their-information-is-prefilled.md b/src/_patterns/help-users-to/know-when-their-information-is-prefilled.md
new file mode 100644
index 000000000..d94f55705
--- /dev/null
+++ b/src/_patterns/help-users-to/know-when-their-information-is-prefilled.md
@@ -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
+
+
+
+
+
+#### 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.
+
+
+
+#### 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.
+
+
+
+## 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.
\ No newline at end of file
diff --git a/src/images/about/accessibility/focus-management/focus-indicator.png b/src/images/about/accessibility/focus-management/focus-indicator.png
new file mode 100644
index 000000000..a8901d1f3
Binary files /dev/null and b/src/images/about/accessibility/focus-management/focus-indicator.png differ
diff --git a/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/content-authenticated-alert-for-intro.png b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/content-authenticated-alert-for-intro.png
new file mode 100644
index 000000000..2aad36788
Binary files /dev/null and b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/content-authenticated-alert-for-intro.png differ
diff --git a/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/content-authenticated-alert-for-page.png b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/content-authenticated-alert-for-page.png
new file mode 100644
index 000000000..b601ed221
Binary files /dev/null and b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/content-authenticated-alert-for-page.png differ
diff --git a/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/content-unauthenticated-alert.png b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/content-unauthenticated-alert.png
new file mode 100644
index 000000000..5f65cb951
Binary files /dev/null and b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/content-unauthenticated-alert.png differ
diff --git a/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/editable-prefill-information.png b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/editable-prefill-information.png
new file mode 100644
index 000000000..049b18a33
Binary files /dev/null and b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/editable-prefill-information.png differ
diff --git a/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/intro-page-authenticated-alert.png b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/intro-page-authenticated-alert.png
new file mode 100644
index 000000000..b315a6c0b
Binary files /dev/null and b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/intro-page-authenticated-alert.png differ
diff --git a/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/intro-page-unauthenticated-alert.png b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/intro-page-unauthenticated-alert.png
new file mode 100644
index 000000000..5f65cb951
Binary files /dev/null and b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/intro-page-unauthenticated-alert.png differ
diff --git a/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/uneditable-prefill-information.png b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/uneditable-prefill-information.png
new file mode 100644
index 000000000..cc42b6057
Binary files /dev/null and b/src/images/patterns/help-users-to/know-when-their-information-is-prefilled/uneditable-prefill-information.png differ
diff --git a/yarn.lock b/yarn.lock
index 1cad62d69..117f96e00 100644
--- a/yarn.lock
+++ b/yarn.lock
@@ -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"
@@ -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"