-
-
Notifications
You must be signed in to change notification settings - Fork 1.5k
/
Copy pathNavDropdownMenu.jsx
59 lines (49 loc) · 1.49 KB
/
NavDropdownMenu.jsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
import classNames from 'classnames';
import PropTypes from 'prop-types';
import React, { useContext, useMemo } from 'react';
import TriangleIcon from '../../images/down-filled-triangle.svg';
import { MenuOpenContext, NavBarContext, ParentMenuContext } from './contexts';
export function useMenuProps(id) {
const activeMenu = useContext(MenuOpenContext);
const isOpen = id === activeMenu;
const { createDropdownHandlers } = useContext(NavBarContext);
const handlers = useMemo(() => createDropdownHandlers(id), [
createDropdownHandlers,
id
]);
return { isOpen, handlers };
}
function NavDropdownMenu({ id, title, children }) {
const { isOpen, handlers } = useMenuProps(id);
return (
<li className={classNames('nav__item', isOpen && 'nav__item--open')}>
<button
{...handlers}
role="menuitem"
aria-haspopup="menu"
aria-expanded={isOpen}
>
<span className="nav__item-header">{title}</span>
<TriangleIcon
className="nav__item-header-triangle"
focusable="false"
aria-hidden="true"
/>
</button>
<ul className="nav__dropdown" role="menu">
<ParentMenuContext.Provider value={id}>
{children}
</ParentMenuContext.Provider>
</ul>
</li>
);
}
NavDropdownMenu.propTypes = {
id: PropTypes.string.isRequired,
title: PropTypes.node.isRequired,
children: PropTypes.node
};
NavDropdownMenu.defaultProps = {
children: null
};
export default NavDropdownMenu;