Skip to content

Commit

Permalink
feat(#2177): add click event for app header toggle menu
Browse files Browse the repository at this point in the history
  • Loading branch information
vanessatran-ddi committed Oct 23, 2024
1 parent 716d000 commit 5a61aeb
Show file tree
Hide file tree
Showing 6 changed files with 66 additions and 8 deletions.
11 changes: 11 additions & 0 deletions libs/react-components/src/lib/app-header/app-header.spec.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,4 +10,15 @@ describe("GoAAppHeader", () => {
const header = baseElement.querySelector("goa-app-header");
expect(header).toBeTruthy();
});
it("should dispatch onMobileMenuClick if provided", () => {
const onMobileMenuClick = vi.fn();
const { baseElement } = render(
<GoAAppHeader heading="Test heading" url="test" onMenuClick={onMobileMenuClick} />
);

const header = baseElement.querySelector("goa-app-header");
expect(header).toBeTruthy();
header?.dispatchEvent(new Event("_menuClick"));
expect(onMobileMenuClick).toHaveBeenCalled();
})
});
27 changes: 27 additions & 0 deletions libs/react-components/src/lib/app-header/app-header.tsx
Original file line number Diff line number Diff line change
@@ -1,8 +1,12 @@
import { useEffect, useRef } from "react";

interface WCProps {
heading?: string;
url?: string;
maxcontentwidth?: string;
fullmenubreakpoint?: number;
hasmenuclickhandler?: boolean;
ref: React.RefObject<HTMLElement>;
testid?: string;
}

Expand All @@ -21,6 +25,7 @@ export interface GoAAppHeaderProps {
maxContentWidth?: string;
fullMenuBreakpoint?: number;
children?: React.ReactNode;
onMenuClick?: () => void;
testId?: string;
}

Expand All @@ -31,14 +36,36 @@ export function GoAAppHeader({
fullMenuBreakpoint,
testId,
children,
onMenuClick,
}: GoAAppHeaderProps): JSX.Element {
const el = useRef<HTMLElement>(null);

useEffect(() => {
if (!el.current) {
return;
}
if (!onMenuClick) {
return;
}
const current = el.current;
const listener = () => {
onMenuClick();
}
current.addEventListener("_menuClick", listener);
return () => {
current.removeEventListener("_menuClick", listener);
}
}, [el, onMenuClick]);

return (
<goa-app-header
ref={el}
heading={heading}
url={url}
fullmenubreakpoint={fullMenuBreakpoint}
maxcontentwidth={maxContentWidth}
testid={testId}
hasmenuclickhandler={!!onMenuClick}
>
{children}
</goa-app-header>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,4 +10,12 @@ describe("SideMenuGroup", () => {
expect(el?.getAttribute("heading")).toBe("some header");
expect(el?.getAttribute("testid")).toBe("foo");
});
it("should render icon if provided", () => {
const { baseElement } = render(
<SideMenuGroup heading={"Some header"} testId={"foo"} icon={"accessibility"} />,
);

const el = baseElement.querySelector("goa-side-menu-group");
expect(el?.getAttribute("icon")).toBe("accessibility");
})
});
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ describe("ThreeColumnLayout", () => {
expect(baseElement.innerHTML).toContain(
"Lorem ipsum dolor sit amet, qui minim labore adipisicing minim sint cillum sint consectetur cupidatat."
);
expect(baseElement.innerHTML).toContain("<goa-app-header>");
expect(baseElement.querySelector("goa-app-header")).toBeTruthy();
expect(baseElement.innerHTML).toContain("<goa-app-footer>");
expect(baseElement.querySelectorAll("[slot=nav] a").length).toEqual(5);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ describe("TwoColumnLayout", () => {
expect(baseElement.innerHTML).toContain(
"Lorem ipsum dolor sit amet, qui minim labore adipisicing minim sint cillum sint consectetur cupidatat."
);
expect(baseElement.innerHTML).toContain("<goa-app-header>");
expect(baseElement.querySelector("goa-app-header")).toBeTruthy();
expect(baseElement.innerHTML).toContain("<goa-app-footer>");
expect(baseElement.querySelectorAll("[slot=nav] a").length).toEqual(5);
});
Expand Down
24 changes: 18 additions & 6 deletions libs/web-components/src/components/app-header/AppHeader.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
<script lang="ts">
import { onDestroy, onMount, tick } from "svelte";
import { MOBILE_BP, TABLET_BP } from "../../common/breakpoints";
import { getSlottedChildren, styles } from "../../common/utils";
import { getSlottedChildren, styles, toBoolean } from "../../common/utils";
import { isUrlMatch, getMatchedLink } from "../../common/urls";
import { AppHeaderMenuProps } from "../app-header-menu/AppHeaderMenu.svelte";
Expand All @@ -15,6 +15,7 @@
export let testid: string = "";
export let maxcontentwidth = "";
export let fullmenubreakpoint: number = TABLET_BP; // minimum window width to show all menu links
export let hasmenuclickhandler: string = "false"; // If this is yes, we will not expand menu when clicking a toggle button
// Private
Expand All @@ -31,6 +32,7 @@
let _appHeaderLinks: Element[] = [];
let _appHeaderMenuItems: AppHeaderMenuProps[] = [];
let _menuButton: HTMLButtonElement;
// Reactive
Expand All @@ -41,6 +43,7 @@
_showToggleMenu = _desktop ? false : ((await hasChildren()) as boolean);
onShowToggleMenuChange();
})();
$: _hasMenuClickHandler = toBoolean(hasmenuclickhandler);
// Hooks
Expand All @@ -58,6 +61,11 @@
const toggleMenu = () => (_showMenu = !_showMenu);
const hideMenu = () => (_showMenu = false);
const dispatchMenuClick = () => {
if (_hasMenuClickHandler) {
_menuButton.dispatchEvent(new CustomEvent("_menuClick", { composed: true, bubbles: true }));
}
}
function getChildren() {
if (!_slotParentEl) return;
Expand Down Expand Up @@ -202,9 +210,11 @@
<!-- Menu button for mobile -->
{#if _showToggleMenu && _mobile}
<div class="menu-toggle-area">
<button on:click={toggleMenu} data-testid="menu-toggle">
<button on:click={_hasMenuClickHandler ? dispatchMenuClick : toggleMenu} data-testid="menu-toggle" bind:this={_menuButton}>
Menu
<goa-icon type={_showMenu ? "chevron-up" : "chevron-down"} mt="1" />
{#if !_hasMenuClickHandler}
<goa-icon type={_showMenu ? "chevron-up" : "chevron-down"} mt="1" />
{/if}
</button>
</div>
{/if}
Expand All @@ -229,9 +239,11 @@
style={styles("height: 100%")}
class="menu-toggle-area"
>
<button on:click={toggleMenu} data-testid="menu-toggle">
<button on:click={_hasMenuClickHandler ? dispatchMenuClick : toggleMenu} data-testid="menu-toggle" bind:this={_menuButton}>
Menu
<goa-icon type={_showMenu ? "chevron-up" : "chevron-down"} mt="1" />
{#if !_hasMenuClickHandler}
<goa-icon type={_showMenu ? "chevron-up" : "chevron-down"} mt="1" />
{/if}
</button>
</div>

Expand All @@ -255,7 +267,7 @@
{/if}

<!-- Mobile and desktop slot content -->
{#if (_showMenu && _mobile) || _desktop}
{#if (_showMenu && _mobile && !_hasMenuClickHandler) || _desktop}
<div bind:this={_slotParentEl} data-testid="slot" class="content-area">
<slot />
</div>
Expand Down

0 comments on commit 5a61aeb

Please sign in to comment.