diff --git a/src/components/SideNavigation/SideNavigationLink/SideNavigationLink.test.tsx b/src/components/SideNavigation/SideNavigationLink/SideNavigationLink.test.tsx index 8990982b..d161c8ed 100644 --- a/src/components/SideNavigation/SideNavigationLink/SideNavigationLink.test.tsx +++ b/src/components/SideNavigation/SideNavigationLink/SideNavigationLink.test.tsx @@ -1,6 +1,5 @@ import React from "react"; import { render, screen } from "@testing-library/react"; -import type { ButtonHTMLAttributes } from "react"; import SideNavigationLink from "./SideNavigationLink"; @@ -32,11 +31,11 @@ it("displays a dark icon", () => { }); it("can use a custom link component", () => { - const Link = ({ ...props }: ButtonHTMLAttributes) => ( - ); const label = "Test content"; - render(); + render(); expect(screen.getByRole("button", { name: label })).toHaveClass( "p-side-navigation__link", ); diff --git a/src/components/SideNavigation/SideNavigationLink/SideNavigationLink.tsx b/src/components/SideNavigation/SideNavigationLink/SideNavigationLink.tsx index 15493174..310cda34 100644 --- a/src/components/SideNavigation/SideNavigationLink/SideNavigationLink.tsx +++ b/src/components/SideNavigation/SideNavigationLink/SideNavigationLink.tsx @@ -1,4 +1,4 @@ -import React, { forwardRef } from "react"; +import React from "react"; import classNames from "classnames"; import type { HTMLProps } from "react"; @@ -16,22 +16,30 @@ export type Props = Omit< * @default a */ component?: SideNavigationBaseProps["component"]; + /** + * A ref to pass to the link element. + */ + forwardRef?: React.Ref | null; +}; + +const SideNavigationLink = ({ + component, + forwardRef, + ...props +}: Props) => { + let className: string | null = null; + if ("className" in props && typeof props.className === "string") { + className = props.className; + delete props.className; + } + return ( + + ); }; -const SideNavigationLink = forwardRef( - ({ component, ...props }: Props) => { - let className: string | null = null; - if ("className" in props && typeof props.className === "string") { - className = props.className; - delete props.className; - } - return ( - - ); - }, -); export default SideNavigationLink;