layout: show navmenu in drawer on mobile
This commit is contained in:
parent
5dd356f4db
commit
1565b1cf4a
@ -1,11 +1,12 @@
|
|||||||
import * as React from "react"
|
import React, { useState } from "react"
|
||||||
import { Link as GatsbyLink } from "gatsby"
|
import { Link as GatsbyLink } from "gatsby"
|
||||||
import { AppBar, Box, Container, CssBaseline, Grid, IconButton, Link, ThemeProvider, Toolbar } from "@mui/material"
|
import { AppBar, Box, Container, CssBaseline, Drawer, Grid, IconButton, Link, ThemeProvider, Toolbar } from "@mui/material"
|
||||||
import NavMenu from "./nav-menu"
|
import NavMenu from "./nav-menu"
|
||||||
import theme from "./theme"
|
import theme from "./theme"
|
||||||
import Footer from "./footer"
|
import Footer from "./footer"
|
||||||
import flower from "../images/flower.png"
|
import flower from "../images/flower.png"
|
||||||
import MenuIcon from "@mui/icons-material/Menu"
|
import MenuIcon from "@mui/icons-material/Menu"
|
||||||
|
import CloseIcon from "@mui/icons-material/Close"
|
||||||
|
|
||||||
const Layout = ({ location, title, children, noHeader }) => {
|
const Layout = ({ location, title, children, noHeader }) => {
|
||||||
// const rootPath = `${__PATH_PREFIX__}/`
|
// const rootPath = `${__PATH_PREFIX__}/`
|
||||||
@ -26,6 +27,8 @@ const Layout = ({ location, title, children, noHeader }) => {
|
|||||||
// )
|
// )
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
const [showDrawer, setShowDrawer] = useState(false)
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ThemeProvider theme={theme}>
|
<ThemeProvider theme={theme}>
|
||||||
@ -52,6 +55,7 @@ const Layout = ({ location, title, children, noHeader }) => {
|
|||||||
<IconButton
|
<IconButton
|
||||||
color="primary"
|
color="primary"
|
||||||
sx={{ display: { xs: "inline-flex", md: "none" } }}
|
sx={{ display: { xs: "inline-flex", md: "none" } }}
|
||||||
|
onClick={() => setShowDrawer(!showDrawer)}
|
||||||
>
|
>
|
||||||
<MenuIcon />
|
<MenuIcon />
|
||||||
</IconButton>
|
</IconButton>
|
||||||
@ -85,6 +89,20 @@ const Layout = ({ location, title, children, noHeader }) => {
|
|||||||
</Grid>
|
</Grid>
|
||||||
</Container>
|
</Container>
|
||||||
<Footer />
|
<Footer />
|
||||||
|
<Drawer
|
||||||
|
anchor="right"
|
||||||
|
open={showDrawer}
|
||||||
|
onClose={() => setShowDrawer(false)}
|
||||||
|
>
|
||||||
|
<Box minWidth={240}>
|
||||||
|
<Box display="flex" justifyContent="flex-end" height={56} pr={2}>
|
||||||
|
<IconButton color="primary" onClick={() => setShowDrawer(false)}>
|
||||||
|
<CloseIcon />
|
||||||
|
</IconButton>
|
||||||
|
</Box>
|
||||||
|
<NavMenu location={location} />
|
||||||
|
</Box>
|
||||||
|
</Drawer>
|
||||||
</ThemeProvider>
|
</ThemeProvider>
|
||||||
</>
|
</>
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user