diff options
author | Michael Hunteman <michael@huntm.net> | 2024-03-03 10:43:24 -0800 |
---|---|---|
committer | Michael Hunteman <michael@huntm.net> | 2024-03-03 10:43:24 -0800 |
commit | 81b6ad9c4bee1bf5839f738bd3976dea8db3a30e (patch) | |
tree | c5acb9e62bf751de7737d4d6c334d573384be8eb | |
parent | cb2a110ae59636daa19321bac912eebec8520636 (diff) |
Use different navigation menus based on viewport
-rw-r--r-- | src/components/Desktop.tsx | 28 | ||||
-rw-r--r-- | src/components/Mobile.tsx | 54 | ||||
-rw-r--r-- | src/components/NavBar.tsx | 35 | ||||
-rw-r--r-- | src/components/pages.ts | 8 |
4 files changed, 98 insertions, 27 deletions
diff --git a/src/components/Desktop.tsx b/src/components/Desktop.tsx new file mode 100644 index 0000000..98cc1dd --- /dev/null +++ b/src/components/Desktop.tsx @@ -0,0 +1,28 @@ +import { useContext } from 'react'; +import { Link } from "react-router-dom"; +import { Stack, Button, IconButton } from "@mui/material"; +import DarkModeIcon from '@mui/icons-material/DarkMode'; +import LightModeIcon from '@mui/icons-material/LightMode'; +import { useTheme } from '@mui/material/styles'; +import { ThemeContext } from '../ThemeContextProvider'; +import pages from './pages'; + +function Desktop() { + const theme = useTheme(); + const { toggleColorMode } = useContext(ThemeContext); + + return ( + <Stack direction="row" sx={{ ml: "auto" }}> + {pages.map(page => ( + <Button color="inherit" component={Link} to={page?.to} key={page?.name}> + {page?.name} + </Button> + ))} + <IconButton color="inherit" onClick={toggleColorMode}> + {theme.palette.mode === 'dark' ? <DarkModeIcon /> : <LightModeIcon />} + </IconButton> + </Stack> + ); +} + +export default Desktop; diff --git a/src/components/Mobile.tsx b/src/components/Mobile.tsx new file mode 100644 index 0000000..02ec354 --- /dev/null +++ b/src/components/Mobile.tsx @@ -0,0 +1,54 @@ +import { useContext } from 'react'; +import { Link } from "react-router-dom"; +import { useState } from 'react'; +import { Button, IconButton, Menu, MenuItem } from "@mui/material"; +import DarkModeIcon from '@mui/icons-material/DarkMode'; +import LightModeIcon from '@mui/icons-material/LightMode'; +import { useTheme } from '@mui/material/styles'; +import { ThemeContext } from '../ThemeContextProvider'; +import MenuIcon from '@mui/icons-material/Menu'; +import pages from './pages'; + +function Mobile() { + const [anchorEl, setAnchorEl] = useState<null | HTMLElement>(null); + const theme = useTheme(); + const { toggleColorMode } = useContext(ThemeContext); + + const handleOpenNavMenu = (event: React.MouseEvent<HTMLElement>) => { + setAnchorEl(event.currentTarget); + }; + + const handleCloseNavMenu = () => { + setAnchorEl(null); + }; + + return ( + <> + <IconButton color="inherit" onClick={toggleColorMode}> + {theme.palette.mode === 'dark' ? <DarkModeIcon /> : <LightModeIcon />} + </IconButton> + <IconButton + color="inherit" + sx={{ ml: "auto" }} + onClick={handleOpenNavMenu} + > + <MenuIcon /> + </IconButton> + <Menu + anchorEl={anchorEl} + open={!!anchorEl} + onClose={handleCloseNavMenu} + > + {pages.map((page) => ( + <MenuItem key={page.name} onClick={handleCloseNavMenu}> + <Button color="inherit" component={Link} to={page?.to} key={page?.name}> + {page?.name} + </Button> + </MenuItem> + ))} + </Menu> + </> + ); +} + +export default Mobile; diff --git a/src/components/NavBar.tsx b/src/components/NavBar.tsx index de40b4f..4e35d95 100644 --- a/src/components/NavBar.tsx +++ b/src/components/NavBar.tsx @@ -1,21 +1,11 @@ -import { useContext } from 'react'; import { Link } from 'react-router-dom'; -import { AppBar, Button, IconButton, Stack, Toolbar, Typography } from '@mui/material'; -import DarkModeIcon from '@mui/icons-material/DarkMode'; -import LightModeIcon from '@mui/icons-material/LightMode'; -import { useTheme } from '@mui/material/styles'; -import { ThemeContext } from '../ThemeContextProvider'; +import { AppBar, Toolbar, Typography } from '@mui/material'; +import useMediaQuery from '@mui/material/useMediaQuery'; +import Desktop from './Desktop'; +import Mobile from './Mobile'; function NavBar() { - const theme = useTheme(); - const { toggleColorMode } = useContext(ThemeContext); - - const pages = [ - { name: 'Schedule', to: '/schedule'}, - { name: 'RSVP', to: '/guest-login' }, - { name: 'Registry', to: '/registry' }, - { name: 'Admin', to: '/admin' } - ]; + const isMobile = useMediaQuery('(max-width: 1000px)'); return ( <AppBar position="relative"> @@ -25,20 +15,11 @@ function NavBar() { component={Link} to="/" color="inherit" - sx={{ textDecoration: 'none' }} - > + sx={{ textDecoration: "none" }} + > Madison and Michael's Wedding </Typography> - <Stack direction="row" sx={{ marginLeft: 'auto' }}> - {pages.map(page => ( - <Button color="inherit" component={Link} to={page?.to} key={page?.name}> - {page?.name} - </Button> - ))} - <IconButton color="inherit" onClick={toggleColorMode}> - {theme.palette.mode === 'dark' ? <DarkModeIcon /> : <LightModeIcon />} - </IconButton> - </Stack> + {isMobile ? <Mobile /> : <Desktop />} </Toolbar> </AppBar> ); diff --git a/src/components/pages.ts b/src/components/pages.ts new file mode 100644 index 0000000..ce1d29e --- /dev/null +++ b/src/components/pages.ts @@ -0,0 +1,8 @@ +const pages = [ + { name: 'Schedule', to: '/schedule'}, + { name: 'RSVP', to: '/guest-login' }, + { name: 'Registry', to: '/registry' }, + { name: 'Admin', to: '/admin' } +]; + +export default pages; |