blob: 97fece6b2519e4a0f8c0ca62ec1f69991a97b3f9 (
plain) (
blame)
| 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
 | import type { FunctionalComponent } from 'preact';
import { h, Fragment } from 'preact';
import { useState, useEffect } from 'preact/hooks';
const MenuToggle: FunctionalComponent = () => {
  const [sidebarShown, setSidebarShown] = useState(false);
  useEffect(() => {
    const body = document.getElementsByTagName('body')[0];
    if (sidebarShown) {
      body.classList.add('mobile-sidebar-toggle');
    } else {
      body.classList.remove('mobile-sidebar-toggle');
    }
  }, [sidebarShown]);
  return (
    <button type="button" aria-pressed={sidebarShown ? 'true' : 'false'} id="menu-toggle" onClick={() => setSidebarShown(!sidebarShown)}>
      <svg xmlns="http://www.w3.org/2000/svg" width="1em" height="1em" fill="none" viewBox="0 0 24 24" stroke="currentColor">
        <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4 6h16M4 12h16M4 18h16" />
      </svg>
      <span className="sr-only">Toggle sidebar</span>
    </button>
  );
};
export default MenuToggle;
 |