diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/Header/Header.tsx | 70 | ||||
-rw-r--r-- | src/Header/SearchBar.tsx | 31 | ||||
-rw-r--r-- | src/index.tsx | 7 |
3 files changed, 77 insertions, 31 deletions
diff --git a/src/Header/Header.tsx b/src/Header/Header.tsx index 8e8a301..0ee6b5f 100644 --- a/src/Header/Header.tsx +++ b/src/Header/Header.tsx @@ -2,45 +2,63 @@ import React from 'react'; import { AppBar, Toolbar, - Tabs, - Tab + IconButton, + Typography } from '@material-ui/core'; import { makeStyles } from '@material-ui/core/styles'; +import AccountCircle from '@material-ui/icons/AccountCircle'; +import NotificationsIcon from '@material-ui/icons/Notifications'; +import HomeIcon from '@material-ui/icons/Home'; + +import SearchBar from './SearchBar'; interface PropTypes { - page: string; setPage: (newPage: string) => void; } -const useStyles = makeStyles(theme => ({ - tab: { - '& .MuiTab-wrapper': { - padding: theme.spacing(2), - flexDirection: 'row', - fontSize: '0.8125rem' - } +const useStyles = makeStyles({ + root: { + display: 'flex', + justifyContent: 'space-around', + width: '60%', + margin: 'auto' + }, + logo: { + fontWeight: 'bold' } -})); - -const tabs = ['Profile', 'Feed']; +}); -const Header: React.FC<PropTypes> = ({ page /* , setPage */ }) => { +const Header: React.FC<PropTypes> = ({ setPage }) => { const classes = useStyles(); - const handleChange = () => {}; + const handleHome = (): void => { + setPage('feed'); + }; + + const handleProfile = (): void => { + setPage('profile'); + }; + + const handleNotifications = (): void => {}; return ( - <AppBar position="static"> - <Toolbar> - <Tabs onChange={handleChange} value={page}> - {tabs.map((tab: string) => ( - <Tab - label={tab} - key={tab} - className={classes.tab} - /> - ))} - </Tabs> + <AppBar position="fixed"> + <Toolbar className={classes.root}> + <Typography variant="h5" className={classes.logo}> + Which + </Typography> + <SearchBar /> + <div> + <IconButton onClick={handleHome}> + <HomeIcon /> + </IconButton> + <IconButton onClick={handleNotifications}> + <NotificationsIcon /> + </IconButton> + <IconButton onClick={handleProfile}> + <AccountCircle /> + </IconButton> + </div> </Toolbar> </AppBar> ); diff --git a/src/Header/SearchBar.tsx b/src/Header/SearchBar.tsx new file mode 100644 index 0000000..182a1a4 --- /dev/null +++ b/src/Header/SearchBar.tsx @@ -0,0 +1,31 @@ +import React from 'react'; +import SearchIcon from '@material-ui/icons/Search'; +import { InputBase } from '@material-ui/core'; +import { makeStyles } from '@material-ui/core/styles'; + +const useStyles = makeStyles(theme => ({ + root: { + background: 'rgba(255, 255, 255, 0.5)', + borderRadius: '2px', + padding: theme.spacing(0.5), + display: 'flex', + alignItems: 'center' + } +})); + +const SearchBar: React.FC = () => { + const classes = useStyles(); + + return ( + <div className={classes.root}> + <SearchIcon /> + <InputBase + placeholder="Search..." + /> + </div> + ); +}; + + +export default SearchBar; + diff --git a/src/index.tsx b/src/index.tsx index d7efbf7..48bad48 100644 --- a/src/index.tsx +++ b/src/index.tsx @@ -13,10 +13,6 @@ const theme = createMuiTheme({ palette: { primary: { main: teal[700] - }, - text: { - primary: '#000000', - secondary: 'rgba(255, 255, 255, 0.6)' } } }); @@ -47,8 +43,9 @@ const App: React.FC = () => { return ( <ThemeProvider theme={theme}> <CssBaseline /> - <Header page={page} setPage={setPage} /> + <Header setPage={setPage} /> <PollCard author={pollProps.author} contents={pollProps.contents} /> + <h1> We are on page {page}! </h1> </ThemeProvider> ); }; |