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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
import React, { Component } from "react";
import { withRouter } from "react-router-dom";
import compose from "recompose/compose";
import { withStyles } from "@material-ui/core/styles";
import { connect } from "react-redux";
import { setUser } from "../../actions/user";
import {
Button,
Divider,
IconButton,
AppBar,
Toolbar,
Typography,
Link
} from "@material-ui/core";
import AccountCircle from "@material-ui/icons/AccountCircle";
import AddPhotoAlternateIcon from "@material-ui/icons/AddPhotoAlternate";
import MailOutlineIcon from "@material-ui/icons/MailOutline";
import VpnKeyIcon from "@material-ui/icons/VpnKey";
import MenuIcon from "@material-ui/icons/Menu";
import axios from "axios";
const styles = theme => ({
root: {
flexGrow: 1
},
menuButton: {
marginRight: theme.spacing(2)
},
title: {
flexGrow: 1
}
});
class AppHeader extends Component {
render() {
const { classes, userInfo } = this.props;
return (
<div className={classes.root}>
<AppBar position="static">
<Toolbar>
<IconButton
edge="start"
className={classes.menuButton}
color="inherit"
aria-label="menu"
Link
href="/"
>
<img src={require("../../image/icon.png")}></img>
</IconButton>
<Typography variant="h6" className={classes.title}></Typography>
{!userInfo ? (
[
<Button color="inherit" Link href="/LoginPage">
Login
</Button>,
<Button color="inherit" Link href="/RigisterPage">
rigister
</Button>,
<Button color="inherit" Link href="/RigisterShopPage">
rigistershop
</Button>
]
) : (
<div>
{userInfo.name}
<Button
color="inherit"
onClick={() => {
localStorage.removeItem("token");
this.props.history.push("/");
this.props.removeUser();
}}
>
Logout
</Button>
</div>
)}
</Toolbar>
</AppBar>
</div>
);
}
}
const mapStateToProps = (state) => ({
userInfo: state.user
})
const mapDispatchToProps = dispatch => {
return {
removeUser: () => dispatch(setUser(null)),
}
}
export default connect(mapStateToProps, mapDispatchToProps)(compose(withStyles(styles), withRouter)(AppHeader));
// Redux