diff --git a/frontend/src/app/commonComponents/ChangeUser.tsx b/frontend/src/app/commonComponents/ChangeUser.tsx
index b787d2a2c70..2b50d807087 100644
--- a/frontend/src/app/commonComponents/ChangeUser.tsx
+++ b/frontend/src/app/commonComponents/ChangeUser.tsx
@@ -4,12 +4,14 @@ const ChangeUser = () => {
}
const getLink = (email: string, name: string) => (
-
- Login as {name}
-
+
+
+ Login as {name}
+
+
);
return (
diff --git a/frontend/src/app/commonComponents/Dropdown.tsx b/frontend/src/app/commonComponents/Dropdown.tsx
index 356c348418c..0216ac30840 100644
--- a/frontend/src/app/commonComponents/Dropdown.tsx
+++ b/frontend/src/app/commonComponents/Dropdown.tsx
@@ -16,6 +16,7 @@ export interface Option {
interface Props {
options: Option[];
label?: string | React.ReactNode;
+ ariaLabel?: string;
name?: string;
onChange?: (e: React.ChangeEvent) => void;
selectedValue: string;
@@ -36,6 +37,7 @@ type SelectProps = JSX.IntrinsicElements["select"];
const Dropdown: React.FC = ({
options,
label,
+ ariaLabel,
name,
onChange,
disabled,
@@ -91,6 +93,7 @@ const Dropdown: React.FC = ({
)}
name={name}
id={id}
+ aria-label={ariaLabel}
aria-required={required || "false"}
onChange={onChange}
value={selectedValue || defaultOption || ""}
diff --git a/frontend/src/app/commonComponents/Header.scss b/frontend/src/app/commonComponents/Header.scss
index 998964f2e40..123c73e7752 100644
--- a/frontend/src/app/commonComponents/Header.scss
+++ b/frontend/src/app/commonComponents/Header.scss
@@ -26,8 +26,10 @@
.role-tag {
// $theme-color-prime-gray:
+ padding-bottom: 1rem;
color: #71767a;
margin-top: 0.5rem;
+ border-bottom: 1px #dfe1e2 solid;
}
.header-link-icon {
@@ -100,7 +102,7 @@
.navlink__support {
display: flex;
align-items: center;
- margin-top: 0.75rem !important;
+ margin-top: 0.75rem;
button {
color: #005ea2;
diff --git a/frontend/src/app/commonComponents/Header.test.tsx b/frontend/src/app/commonComponents/Header.test.tsx
new file mode 100644
index 00000000000..9e8dbfb5d1a
--- /dev/null
+++ b/frontend/src/app/commonComponents/Header.test.tsx
@@ -0,0 +1,56 @@
+import { render } from "@testing-library/react";
+import "../../i18n";
+import { Provider } from "react-redux";
+import { MemoryRouter } from "react-router-dom";
+import { MockedProvider } from "@apollo/client/testing";
+import configureStore from "redux-mock-store";
+import { configureAxe } from "jest-axe";
+
+import Header from "./Header";
+
+const axe = configureAxe({
+ rules: {
+ // disable landmark rules when testing isolated components.
+ region: { enabled: false },
+ },
+});
+const mockStore = configureStore([]);
+const store = mockStore({
+ organization: {
+ name: "Organization Name",
+ },
+ user: {
+ firstName: "Kim",
+ lastName: "Mendoza",
+ roleDescription: "Admin user",
+ },
+ facilities: [
+ { id: "1", name: "Facility One" },
+ { id: "2", name: "Facility Two" },
+ ],
+});
+
+const mockNavigate = jest.fn();
+jest.mock("react-router-dom", () => {
+ const original = jest.requireActual("react-router-dom");
+ return {
+ ...original,
+ useNavigate: () => mockNavigate,
+ };
+});
+
+describe("Header", () => {
+ it("displays correctly", async () => {
+ render(
+
+
+
+
+
+
+
+ );
+ expect(document.body).toMatchSnapshot();
+ expect(await axe(document.body)).toHaveNoViolations();
+ });
+});
diff --git a/frontend/src/app/commonComponents/Header.tsx b/frontend/src/app/commonComponents/Header.tsx
index 02a52f922c4..98a1bdc6714 100644
--- a/frontend/src/app/commonComponents/Header.tsx
+++ b/frontend/src/app/commonComponents/Header.tsx
@@ -230,7 +230,6 @@ const Header: React.FC<{}> = () => {
{formatRole(user.roleDescription)}
-
= () => {
className={item.className}
data-testid={`${deviceType}-${item.dataTestId}`}
id={`${deviceType}-${item.dataTestId}`}
+ role={item.hasSubmenu ? "button" : "link"}
+ aria-expanded={item.hasSubmenu ? staffDetailsVisible : undefined}
+ aria-controls={
+ item.hasSubmenu
+ ? `${deviceType}-${item.dataTestId}-submenu`
+ : undefined
+ }
>
{deviceType === "desktop" ? item.icon : item.mobileDisplayText}
@@ -288,8 +294,9 @@ const Header: React.FC<{}> = () => {
staffDetailsVisible &&
deviceType === "desktop" ? (