2017-07-10 11:50:56 +08:00
|
|
|
import './Header.scss'
|
2017-07-07 17:26:31 +08:00
|
|
|
import React, { Component } from 'react'
|
2017-07-12 16:27:06 +08:00
|
|
|
import PropTypes from 'prop-types'
|
|
|
|
import { connect } from 'react-redux'
|
2017-07-10 21:29:03 +08:00
|
|
|
import { Link } from 'react-router-dom'
|
2017-08-11 17:49:47 +08:00
|
|
|
import { Icon, Layout, Menu, Dropdown, message, Tooltip, Avatar } from 'antd'
|
2017-08-10 20:08:23 +08:00
|
|
|
import { checkLoginState, logoutActions, loginTypeAction} from '../../reducer/modules/user'
|
2017-08-08 10:07:55 +08:00
|
|
|
import { changeMenuItem } from '../../reducer/modules/menu'
|
2017-07-19 12:20:07 +08:00
|
|
|
import { withRouter } from 'react-router';
|
2017-07-20 19:59:49 +08:00
|
|
|
import Srch from './Search/Search'
|
2017-07-17 21:11:58 +08:00
|
|
|
const { Header } = Layout;
|
2017-07-20 19:59:49 +08:00
|
|
|
|
|
|
|
const MenuUser = (props) => (
|
2017-08-11 14:22:20 +08:00
|
|
|
<Menu className="user-menu" >
|
2017-07-27 14:45:51 +08:00
|
|
|
<Menu.Item key="0">
|
2017-07-26 16:06:54 +08:00
|
|
|
<Link to={`/user/profile/${props.uid}`} onClick={props.relieveLink}><Icon type="user"/>个人中心</Link>
|
2017-07-20 19:59:49 +08:00
|
|
|
</Menu.Item>
|
2017-07-27 14:45:51 +08:00
|
|
|
<Menu.Item key="1">
|
2017-07-26 16:06:54 +08:00
|
|
|
<a onClick={props.logout}><Icon type="logout" />退出</a>
|
2017-07-20 19:59:49 +08:00
|
|
|
</Menu.Item>
|
|
|
|
</Menu>
|
|
|
|
);
|
2017-08-08 20:27:18 +08:00
|
|
|
|
2017-07-20 19:59:49 +08:00
|
|
|
MenuUser.propTypes={
|
2017-08-08 20:27:18 +08:00
|
|
|
user: PropTypes.string,
|
|
|
|
msg: PropTypes.string,
|
2017-07-20 19:59:49 +08:00
|
|
|
uid: PropTypes.number,
|
2017-08-08 20:27:18 +08:00
|
|
|
relieveLink: PropTypes.func,
|
|
|
|
logout: PropTypes.func
|
2017-07-20 19:59:49 +08:00
|
|
|
}
|
|
|
|
|
2017-07-12 16:27:06 +08:00
|
|
|
const ToolUser = (props)=> (
|
|
|
|
<ul>
|
2017-08-08 20:27:18 +08:00
|
|
|
<li className="toolbar-li item-search">
|
2017-07-20 19:59:49 +08:00
|
|
|
<Srch groupList={props.groupList}/>
|
|
|
|
</li>
|
2017-08-10 18:26:35 +08:00
|
|
|
<Link to="/add-project">
|
2017-08-08 20:27:18 +08:00
|
|
|
<Tooltip placement="bottom" title={'新建项目'}>
|
|
|
|
<li className="toolbar-li">
|
|
|
|
<Icon className="dropdown-link" style={{ fontSize: 16 }} type="plus-circle" />
|
|
|
|
</li>
|
|
|
|
</Tooltip>
|
|
|
|
</Link>
|
|
|
|
<Tooltip placement="bottom" title={'使用文档'}>
|
|
|
|
<li className="toolbar-li">
|
2017-08-11 10:31:26 +08:00
|
|
|
<a target="_blank" href="/doc/index.html"><Icon className="dropdown-link" style={{ fontSize: 16 }} type="question-circle" /></a>
|
2017-08-08 20:27:18 +08:00
|
|
|
</li>
|
|
|
|
</Tooltip>
|
2017-07-20 19:59:49 +08:00
|
|
|
<li className="toolbar-li">
|
2017-07-26 16:06:54 +08:00
|
|
|
<Dropdown
|
|
|
|
placement = "bottomRight"
|
|
|
|
overlay={
|
|
|
|
<MenuUser
|
|
|
|
user={props.user}
|
|
|
|
msg={props.msg}
|
|
|
|
uid={props.uid}
|
|
|
|
relieveLink={props.relieveLink}
|
|
|
|
logout={props.logout}
|
|
|
|
/>
|
2017-07-20 19:59:49 +08:00
|
|
|
}>
|
|
|
|
<a className="dropdown-link">
|
2017-08-11 17:49:47 +08:00
|
|
|
<Avatar src={`/api/user/avatar?uid=${props.uid}`} />
|
|
|
|
{/*<img style={{width:24,height:24}} src={`/api/user/avatar?uid=${props.uid}`} />*/}
|
|
|
|
<span className="name">{props.user}</span>
|
2017-08-11 10:31:26 +08:00
|
|
|
|
2017-07-20 19:59:49 +08:00
|
|
|
</a>
|
|
|
|
</Dropdown>
|
|
|
|
</li>
|
2017-07-12 16:27:06 +08:00
|
|
|
</ul>
|
|
|
|
);
|
|
|
|
ToolUser.propTypes={
|
2017-08-08 20:27:18 +08:00
|
|
|
user: PropTypes.string,
|
|
|
|
msg: PropTypes.string,
|
2017-07-20 19:59:49 +08:00
|
|
|
uid: PropTypes.number,
|
2017-08-08 20:27:18 +08:00
|
|
|
relieveLink: PropTypes.func,
|
|
|
|
logout: PropTypes.func,
|
2017-07-20 19:59:49 +08:00
|
|
|
groupList: PropTypes.array
|
2017-07-12 16:27:06 +08:00
|
|
|
};
|
|
|
|
|
2017-07-20 19:59:49 +08:00
|
|
|
|
2017-07-26 21:24:02 +08:00
|
|
|
|
|
|
|
@connect(
|
|
|
|
(state) => {
|
|
|
|
return{
|
2017-08-10 20:08:23 +08:00
|
|
|
user: state.user.userName,
|
|
|
|
uid: state.user.uid,
|
2017-07-26 21:24:02 +08:00
|
|
|
msg: null,
|
2017-08-10 20:08:23 +08:00
|
|
|
login:state.user.isLogin
|
2017-07-26 21:24:02 +08:00
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
loginTypeAction,
|
|
|
|
logoutActions,
|
|
|
|
checkLoginState,
|
|
|
|
changeMenuItem
|
|
|
|
}
|
|
|
|
)
|
2017-07-19 14:08:24 +08:00
|
|
|
@withRouter
|
2017-07-26 21:24:02 +08:00
|
|
|
export default class HeaderCom extends Component {
|
2017-07-07 17:26:31 +08:00
|
|
|
constructor(props) {
|
2017-07-12 16:27:06 +08:00
|
|
|
super(props);
|
2017-07-18 18:25:53 +08:00
|
|
|
}
|
2017-07-19 10:38:29 +08:00
|
|
|
static propTypes ={
|
2017-07-19 12:20:07 +08:00
|
|
|
router: PropTypes.object,
|
2017-07-19 10:38:29 +08:00
|
|
|
user: PropTypes.string,
|
|
|
|
msg: PropTypes.string,
|
2017-07-20 19:59:49 +08:00
|
|
|
uid: PropTypes.number,
|
2017-07-19 10:38:29 +08:00
|
|
|
login:PropTypes.bool,
|
|
|
|
relieveLink:PropTypes.func,
|
|
|
|
logoutActions:PropTypes.func,
|
2017-07-19 12:20:07 +08:00
|
|
|
checkLoginState:PropTypes.func,
|
|
|
|
loginTypeAction:PropTypes.func,
|
2017-07-20 21:30:35 +08:00
|
|
|
changeMenuItem:PropTypes.func,
|
2017-07-19 12:20:07 +08:00
|
|
|
history: PropTypes.object,
|
|
|
|
location: PropTypes.object
|
2017-07-19 10:38:29 +08:00
|
|
|
}
|
2017-07-18 18:25:53 +08:00
|
|
|
linkTo = (e) =>{
|
2017-07-28 21:19:45 +08:00
|
|
|
if(e.key != '/doc'){
|
|
|
|
this.props.changeMenuItem(e.key);
|
|
|
|
if(!this.props.login){
|
|
|
|
message.info('请先登录',1);
|
|
|
|
}
|
2017-07-26 17:22:09 +08:00
|
|
|
}
|
2017-07-18 18:25:53 +08:00
|
|
|
}
|
2017-07-19 10:38:29 +08:00
|
|
|
relieveLink = () => {
|
2017-07-20 21:30:35 +08:00
|
|
|
this.props.changeMenuItem("");
|
2017-07-12 21:13:22 +08:00
|
|
|
}
|
2017-07-19 10:38:29 +08:00
|
|
|
logout = (e) => {
|
|
|
|
e.preventDefault();
|
2017-07-23 18:24:46 +08:00
|
|
|
this.props.logoutActions().then((res) => {
|
|
|
|
if (res.payload.data.errcode == 0) {
|
|
|
|
this.props.history.push('/');
|
|
|
|
this.props.changeMenuItem("/");
|
|
|
|
message.success('退出成功! ');
|
|
|
|
} else {
|
|
|
|
message.error(res.payload.data.errmsg);
|
|
|
|
}
|
|
|
|
}).catch((err) => {
|
|
|
|
message.error(err);
|
|
|
|
});
|
2017-07-19 10:38:29 +08:00
|
|
|
}
|
2017-07-12 21:13:22 +08:00
|
|
|
handleLogin = (e) => {
|
|
|
|
e.preventDefault();
|
|
|
|
this.props.loginTypeAction("1");
|
|
|
|
}
|
|
|
|
handleReg = (e)=>{
|
|
|
|
e.preventDefault();
|
|
|
|
this.props.loginTypeAction("2");
|
2017-07-07 17:26:31 +08:00
|
|
|
}
|
2017-07-19 12:20:07 +08:00
|
|
|
checkLoginState = () => {
|
2017-07-23 18:24:46 +08:00
|
|
|
this.props.checkLoginState.then((res) => {
|
2017-07-19 12:20:07 +08:00
|
|
|
if (res.payload.data.errcode !== 0) {
|
|
|
|
this.props.history.push('/');
|
|
|
|
}
|
|
|
|
}).catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
})
|
|
|
|
}
|
2017-08-10 21:20:23 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
2017-07-07 17:26:31 +08:00
|
|
|
render () {
|
2017-08-08 20:27:18 +08:00
|
|
|
const { login, user, msg, uid } = this.props;
|
2017-07-07 17:26:31 +08:00
|
|
|
return (
|
2017-08-11 14:22:20 +08:00
|
|
|
<Header className="header-box m-header">
|
2017-08-08 20:27:18 +08:00
|
|
|
<div className="content g-row">
|
|
|
|
<div className="logo">
|
2017-08-08 20:46:19 +08:00
|
|
|
<Link to="/" onClick={this.relieveLink} className="href">
|
2017-08-11 10:31:26 +08:00
|
|
|
<img className="img" src="/image/logo_header@1x.png" /><span className="logo-name">YAPI<span className="ui-badge"></span></span>
|
2017-08-08 20:27:18 +08:00
|
|
|
</Link>
|
|
|
|
</div>
|
|
|
|
<div className="user-toolbar">
|
|
|
|
{login?
|
|
|
|
<ToolUser
|
|
|
|
user = { user }
|
|
|
|
msg = { msg }
|
|
|
|
uid = { uid }
|
|
|
|
relieveLink = { this.relieveLink }
|
|
|
|
logout = { this.logout }
|
|
|
|
/>
|
|
|
|
:""}
|
2017-07-26 16:06:54 +08:00
|
|
|
</div>
|
2017-08-08 20:27:18 +08:00
|
|
|
</div>
|
|
|
|
</Header>
|
2017-07-07 17:26:31 +08:00
|
|
|
)
|
|
|
|
}
|
2017-07-27 14:35:27 +08:00
|
|
|
}
|