diff --git a/src/applications/personalization/profile/components/direct-deposit/AccountInfoView.jsx b/src/applications/personalization/profile/components/direct-deposit/AccountInfoView.jsx
index b73449c3fe72..e205c11d3dd4 100644
--- a/src/applications/personalization/profile/components/direct-deposit/AccountInfoView.jsx
+++ b/src/applications/personalization/profile/components/direct-deposit/AccountInfoView.jsx
@@ -1,4 +1,4 @@
-import React, { useRef } from 'react';
+import React, { forwardRef } from 'react';
import PropTypes from 'prop-types';
import { TransitionGroup, CSSTransition } from 'react-transition-group';
@@ -10,63 +10,59 @@ import recordEvent from '~/platform/monitoring/record-event';
import { toggleDirectDepositEdit } from '../../actions/directDeposit';
import { DIRECT_DEPOSIT_ALERT_SETTINGS } from '../../constants';
-const AccountWithInfo = ({
- paymentAccount,
- showUpdateSuccess,
- editButtonRef,
- toggleEdit,
- recordEventImpl,
-}) => {
- return (
-
-
- - Bank name:
- - {paymentAccount?.name}
- - Bank account number:
- - {paymentAccount?.accountNumber}
- - Bank account type:
- - {`${paymentAccount?.accountType} account`}
-
+const AccountWithInfo = forwardRef(
+ ({ paymentAccount, showUpdateSuccess, toggleEdit, recordEventImpl }, ref) => {
+ return (
+
+
+ - Bank name:
+ - {paymentAccount?.name}
+ - Bank account number:
+ - {paymentAccount?.accountNumber}
+ - Bank account type:
+ - {`${paymentAccount?.accountType} account`}
+
-
-
- {!!showUpdateSuccess && (
-
-
-
-
-
- )}
-
+
+
+ {!!showUpdateSuccess && (
+
+
+
+
+
+ )}
+
+
+
{
+ recordEventImpl({
+ event: 'profile-navigation',
+ 'profile-action': 'edit-link',
+ 'profile-section': `direct-deposit-information`,
+ });
+ toggleEdit();
+ }}
+ />
-
{
- recordEventImpl({
- event: 'profile-navigation',
- 'profile-action': 'edit-link',
- 'profile-section': `direct-deposit-information`,
- });
- toggleEdit();
- }}
- />
-
- );
-};
+ );
+ },
+);
AccountWithInfo.propTypes = {
paymentAccount: PropTypes.shape({
@@ -76,7 +72,6 @@ AccountWithInfo.propTypes = {
}).isRequired,
showUpdateSuccess: PropTypes.bool.isRequired,
toggleEdit: PropTypes.func.isRequired,
- editButtonRef: PropTypes.shape({ current: PropTypes.instanceOf(Element) }),
recordEventImpl: PropTypes.func,
};
@@ -84,7 +79,7 @@ AccountWithInfo.defaultProps = {
recordEventImpl: recordEvent,
};
-const NoAccountInfo = ({ editButtonRef, toggleEdit, recordEventImpl }) => {
+const NoAccountInfo = forwardRef(({ toggleEdit, recordEventImpl }, ref) => {
return (
@@ -95,7 +90,7 @@ const NoAccountInfo = ({ editButtonRef, toggleEdit, recordEventImpl }) => {
text="Edit"
data-testid="edit-bank-info-button"
aria-label="Edit your direct deposit bank information"
- ref={editButtonRef}
+ ref={ref}
onClick={() => {
recordEventImpl({
event: 'profile-navigation',
@@ -107,11 +102,10 @@ const NoAccountInfo = ({ editButtonRef, toggleEdit, recordEventImpl }) => {
/>
);
-};
+});
NoAccountInfo.propTypes = {
toggleEdit: PropTypes.func.isRequired,
- editButtonRef: PropTypes.shape({ current: PropTypes.instanceOf(Element) }),
recordEventImpl: PropTypes.func,
};
@@ -119,30 +113,27 @@ NoAccountInfo.defaultProps = {
recordEventImpl: recordEvent,
};
-export const AccountInfoView = ({
- paymentAccount,
- showUpdateSuccess,
- recordEventImpl,
-}) => {
- const editButtonRef = useRef();
- const dispatch = useDispatch();
- const toggleEdit = () => dispatch(toggleDirectDepositEdit());
- return paymentAccount?.accountNumber ? (
-
- ) : (
-
- );
-};
+export const AccountInfoView = forwardRef(
+ ({ paymentAccount, showUpdateSuccess, recordEventImpl }, ref) => {
+ const dispatch = useDispatch();
+ const toggleEdit = () => dispatch(toggleDirectDepositEdit());
+ return paymentAccount?.accountNumber ? (
+
+ ) : (
+
+ );
+ },
+);
AccountInfoView.propTypes = {
showUpdateSuccess: PropTypes.bool.isRequired,
diff --git a/src/applications/personalization/profile/components/direct-deposit/DirectDeposit.jsx b/src/applications/personalization/profile/components/direct-deposit/DirectDeposit.jsx
index 73edbb34b1f6..ef337fce36ba 100644
--- a/src/applications/personalization/profile/components/direct-deposit/DirectDeposit.jsx
+++ b/src/applications/personalization/profile/components/direct-deposit/DirectDeposit.jsx
@@ -144,7 +144,11 @@ export const DirectDeposit = () => {
{...directDepositHookResult}
/>
) : (
-
+
);
return (
diff --git a/src/applications/personalization/profile/hooks/useDirectDepositEffects.js b/src/applications/personalization/profile/hooks/useDirectDepositEffects.js
index 97e60c4edbd0..c22a9c04f2fc 100644
--- a/src/applications/personalization/profile/hooks/useDirectDepositEffects.js
+++ b/src/applications/personalization/profile/hooks/useDirectDepositEffects.js
@@ -80,7 +80,7 @@ export const useDirectDepositEffects = ({
useEffect(
() => {
if (wasEditing && !ui.isEditing) {
- focusElement('button', {}, '#edit-bank-info-button');
+ focusElement('button', {}, editButtonRef.current);
}
},
[wasEditing, ui.isEditing, editButtonRef],
diff --git a/src/applications/personalization/profile/tests/e2e/direct-deposit/focus-accessibility.cypress.spec.js b/src/applications/personalization/profile/tests/e2e/direct-deposit/focus-accessibility.cypress.spec.js
new file mode 100644
index 000000000000..cdd7b7c94d3c
--- /dev/null
+++ b/src/applications/personalization/profile/tests/e2e/direct-deposit/focus-accessibility.cypress.spec.js
@@ -0,0 +1,53 @@
+import directDepositMocks from '@@profile/mocks/endpoints/direct-deposits';
+import DirectDepositPage from './page-objects/DirectDeposit';
+
+const directDeposit = new DirectDepositPage();
+
+describe('Direct Deposit', () => {
+ beforeEach(() => {
+ directDeposit.setup();
+ });
+
+ it('should open the bank account information form and return to the original state on cancel', () => {
+ const editButton = 'va-button[text="Edit"]';
+ const cancelButton = 'va-button[text="Cancel"]';
+ // Mock the API response for direct deposits eligibility
+ cy.intercept(
+ 'GET',
+ 'v0/profile/direct_deposits',
+ directDepositMocks.isEligible,
+ );
+ directDeposit.visitPage();
+ cy.injectAxeThenAxeCheck();
+
+ // Verify initial prompt to add bank information is visible
+ cy.contains('p', 'Edit your profile to add your bank information.').should(
+ 'be.visible',
+ );
+ cy.get(editButton)
+ .should('exist')
+ .should('not.be.focused');
+
+ // Click the Edit button and ensure it is removed from the DOM
+ cy.get(editButton).click();
+ cy.get(editButton).should('not.exist');
+
+ // Verify the bank account information form appears and is focused
+ cy.contains(
+ 'p',
+ 'Provide your account type, routing number, and account number.',
+ ).should('be.visible');
+ cy.get('#bank-account-information').should('be.focused');
+
+ // Click the Cancel button to close the form
+ cy.get(cancelButton)
+ .should('exist')
+ .click();
+
+ // Verify the page returns to the original state and Edit button is focused
+ cy.findByRole('heading', { name: 'Direct deposit information' }).should(
+ 'exist',
+ );
+ cy.get(editButton).should('be.focused');
+ });
+});