mirror of
https://github.com/YMFE/yapi.git
synced 2025-01-12 12:54:48 +08:00
136 lines
3.5 KiB
JavaScript
136 lines
3.5 KiB
JavaScript
import './Header.scss'
|
|
import React, { Component } from 'react'
|
|
import PropTypes from 'prop-types'
|
|
import { connect } from 'react-redux'
|
|
import { Link } from 'react-router-dom'
|
|
import { Icon, Layout, Menu} from 'antd'
|
|
import { checkLoginState, logoutActions, loginTypeAction} from '../../actions/login'
|
|
import { withRouter } from 'react-router';
|
|
|
|
const { Header } = Layout;
|
|
const ToolUser = (props)=> (
|
|
<ul>
|
|
<li><Link to="/user" onClick={props.relieveLink}><Icon type="user" />{ props.user }</Link></li>
|
|
<li><Link to="/News" onClick={props.relieveLink}><Icon type="mail" />{ props.msg }</Link></li>
|
|
<li onClick={props.logout}>退出</li>
|
|
</ul>
|
|
);
|
|
ToolUser.propTypes={
|
|
user:PropTypes.string,
|
|
msg:PropTypes.string,
|
|
relieveLink:PropTypes.func,
|
|
logout:PropTypes.func
|
|
};
|
|
|
|
@withRouter
|
|
class HeaderCom extends Component {
|
|
constructor(props) {
|
|
super(props);
|
|
this.state = {
|
|
current : window.location.hash.split("#")[1]
|
|
}
|
|
}
|
|
static propTypes ={
|
|
router: PropTypes.object,
|
|
user: PropTypes.string,
|
|
msg: PropTypes.string,
|
|
login:PropTypes.bool,
|
|
relieveLink:PropTypes.func,
|
|
logoutActions:PropTypes.func,
|
|
checkLoginState:PropTypes.func,
|
|
loginTypeAction:PropTypes.func,
|
|
history: PropTypes.object,
|
|
location: PropTypes.object
|
|
}
|
|
componentDidMount() {
|
|
// const { router } = this.props;
|
|
}
|
|
linkTo = (e) =>{
|
|
this.setState({
|
|
current : e.key
|
|
})
|
|
}
|
|
relieveLink = () => {
|
|
this.setState({
|
|
current : ""
|
|
})
|
|
}
|
|
logout = (e) => {
|
|
e.preventDefault();
|
|
this.props.logoutActions();
|
|
}
|
|
handleLogin = (e) => {
|
|
e.preventDefault();
|
|
this.props.loginTypeAction("1");
|
|
}
|
|
handleReg = (e)=>{
|
|
e.preventDefault();
|
|
this.props.loginTypeAction("2");
|
|
}
|
|
checkLoginState = () => {
|
|
this.props.checkLoginState().then((res) => {
|
|
if (res.payload.data.errcode !== 0) {
|
|
this.props.history.push('/');
|
|
}
|
|
}).catch((err) => {
|
|
console.log(err);
|
|
})
|
|
}
|
|
render () {
|
|
this.checkLoginState();
|
|
const { login, user, msg } = this.props;
|
|
return (
|
|
<acticle className="header-box">
|
|
<Layout className="'layout">
|
|
<Header>
|
|
<div className="content">
|
|
<div className="logo">
|
|
YAPI
|
|
</div>
|
|
<Menu
|
|
mode="horizontal"
|
|
className="nav-toolbar"
|
|
theme="dark"
|
|
style={{ lineHeight : '.64rem'}}
|
|
onClick={this.linkTo}
|
|
selectedKeys={[this.state.current]}
|
|
>
|
|
<Menu.Item key="/">
|
|
<Link to="/">首页</Link>
|
|
</Menu.Item>
|
|
<Menu.Item key="/ProjectGroups">
|
|
<Link to="/ProjectGroups">分组</Link>
|
|
</Menu.Item>
|
|
<Menu.Item key="/Interface">
|
|
<Link to="/Interface">接口</Link>
|
|
</Menu.Item>
|
|
<Menu.Item key="/doc">
|
|
<a>文档</a>
|
|
</Menu.Item>
|
|
</Menu>
|
|
<div className="user-toolbar">
|
|
{login?<ToolUser user={user} msg={msg} relieveLink={this.relieveLink} logout={this.logout}/>:""}
|
|
</div>
|
|
</div>
|
|
</Header>
|
|
</Layout>
|
|
</acticle>
|
|
)
|
|
}
|
|
}
|
|
|
|
export default connect(
|
|
(state) => {
|
|
return{
|
|
user: state.login.userName,
|
|
msg: null,
|
|
login:state.login.isLogin
|
|
}
|
|
},
|
|
{
|
|
loginTypeAction,
|
|
logoutActions,
|
|
checkLoginState
|
|
}
|
|
)(HeaderCom)
|