yapi/client/components/ProjectCard/ProjectCard.js

94 lines
2.7 KiB
JavaScript
Raw Normal View History

2017-08-11 19:30:12 +08:00
import './ProjectCard.scss';
import React, { Component } from 'react';
2017-08-19 15:18:55 +08:00
import { Card, Icon, Tooltip, message } from 'antd';
import { connect } from 'react-redux'
2017-08-22 20:04:15 +08:00
import { delFollow, addFollow } from '../../reducer/modules/follow';
2017-08-19 15:18:55 +08:00
// import { Link } from 'react-router-dom';
2017-08-11 19:30:12 +08:00
import PropTypes from 'prop-types';
2017-08-22 17:26:53 +08:00
import { withRouter } from 'react-router';
2017-08-22 20:44:16 +08:00
import { debounce } from '../../common';
2017-08-10 15:36:35 +08:00
2017-08-19 15:18:55 +08:00
@connect(
2017-08-22 20:04:15 +08:00
state => {
return {
uid: state.user.uid
}
2017-08-19 15:18:55 +08:00
},
{
2017-08-22 20:04:15 +08:00
delFollow,
addFollow
2017-08-19 15:18:55 +08:00
}
)
2017-08-20 17:22:04 +08:00
@withRouter
2017-08-11 17:47:25 +08:00
class ProjectCard extends Component {
2017-08-10 15:36:35 +08:00
constructor(props) {
super(props);
2017-08-22 20:44:16 +08:00
this.add = debounce(this.add, 400);
this.del = debounce(this.del, 400);
2017-08-10 15:36:35 +08:00
}
static propTypes = {
2017-08-19 15:18:55 +08:00
projectData: PropTypes.object,
2017-08-22 20:04:15 +08:00
uid: PropTypes.number,
inFollowPage: PropTypes.bool,
2017-08-19 15:18:55 +08:00
callbackResult: PropTypes.func,
2017-08-20 17:22:04 +08:00
history: PropTypes.object,
2017-08-22 20:04:15 +08:00
delFollow: PropTypes.func,
addFollow: PropTypes.func
2017-08-19 15:18:55 +08:00
}
del = () => {
2017-08-22 20:04:15 +08:00
const id = this.props.projectData.projectid || this.props.projectData._id;
2017-08-19 15:18:55 +08:00
this.props.delFollow(id).then((res) => {
if (res.payload.data.errcode === 0) {
this.props.callbackResult();
message.success('已取消关注!');
}
});
}
2017-08-22 20:04:15 +08:00
add = () => {
const { uid, projectData } = this.props;
const param = {
uid,
projectid: projectData._id,
projectname: projectData.name,
icon: 'star',
color: '#2395f1'
}
this.props.addFollow(param).then((res) => {
console.log(res);
if (res.payload.data.errcode === 0) {
this.props.callbackResult();
message.success('已添加关注!');
}
});
2017-08-10 15:36:35 +08:00
}
2017-08-19 15:18:55 +08:00
// <Link to={`/project/${projectData._id}`} className="card-link">
//
// </Link>
2017-08-10 15:36:35 +08:00
2017-08-19 15:18:55 +08:00
// <Popconfirm placement="leftBottom" title={<Icon type="up" />} onConfirm={confirm} okText="确认" cancelText="取消">
// <Icon type="star-o" className="icon" onClick={this.clickHandle}/>
// </Popconfirm>
2017-08-10 15:36:35 +08:00
render() {
2017-08-22 20:04:15 +08:00
const { projectData, inFollowPage } = this.props;
2017-08-10 15:36:35 +08:00
return (
2017-08-19 15:18:55 +08:00
<div className="card-container">
2017-08-22 16:03:39 +08:00
<Card bordered={false} className="m-card" onClick={() => this.props.history.push('/project/' + projectData._id)}>
<Icon type="area-chart" className="ui-logo" />
<h4 className="ui-title">{projectData.name || projectData.projectname}</h4>
2017-08-11 19:30:12 +08:00
</Card>
2017-08-22 20:08:21 +08:00
<div className="card-btns" onClick={projectData.follow || inFollowPage ? this.del : this.add}>
2017-08-22 20:04:15 +08:00
<Tooltip placement="rightTop" title={projectData.follow || inFollowPage ? '取消关注' : '添加关注'}>
2017-08-22 20:08:21 +08:00
<Icon type={projectData.follow || inFollowPage ? 'star' : 'star-o'} className="icon"/>
2017-08-19 15:18:55 +08:00
</Tooltip>
</div>
</div>
2017-08-10 15:36:35 +08:00
)
}
}
2017-08-11 17:47:25 +08:00
export default ProjectCard