yapi/client/containers/Project/Interface/InterfaceList/InterfaceList.js

133 lines
3.1 KiB
JavaScript
Raw Normal View History

2017-08-20 22:13:46 +08:00
import React, { Component } from 'react'
2017-08-21 12:05:18 +08:00
import { connect } from 'react-redux';
2017-08-18 20:35:31 +08:00
import PropTypes from 'prop-types'
import axios from 'axios'
import {
2017-08-20 22:13:46 +08:00
Table, Tag
2017-08-18 20:35:31 +08:00
} from 'antd';
2017-08-20 22:13:46 +08:00
import { formatTime } from '../../../../common.js'
2017-08-21 12:05:18 +08:00
@connect(
state => {
return {
curProject: state.project.currProject
}
})
2017-08-20 22:13:46 +08:00
class InterfaceList extends Component {
constructor(props) {
2017-08-18 20:35:31 +08:00
super(props)
this.state = {
2017-08-20 22:13:46 +08:00
data: [],
2017-08-18 20:35:31 +08:00
sortedInfo: {
2017-08-20 22:13:46 +08:00
order: 'ascend',
2017-08-18 20:35:31 +08:00
columnKey: 'title'
}
}
}
static propTypes = {
2017-08-21 12:05:18 +08:00
match: PropTypes.object,
curProject: PropTypes.object
2017-08-18 20:35:31 +08:00
}
2017-08-20 22:13:46 +08:00
handleRequest = async (props) => {
const { params } = props.match;
if (!params.actionId) {
2017-08-18 20:35:31 +08:00
let projectId = params.id;
let r = await axios.get('/api/interface/list?project_id=' + projectId);
this.setState({
data: r.data.data
})
2017-08-20 22:13:46 +08:00
} else if (isNaN(params.actionId)) {
2017-08-18 20:35:31 +08:00
let catid = params.actionId.substr(4)
let r = await axios.get('/api/interface/list_cat?catid=' + catid);
this.setState({
data: r.data.data
})
}
}
handleChange = (pagination, filters, sorter) => {
this.setState({
sortedInfo: sorter
});
}
2017-08-20 22:13:46 +08:00
componentWillMount() {
2017-08-18 20:35:31 +08:00
this.actionId = this.props.match.params.actionId;
this.handleRequest(this.props)
}
2017-08-20 22:13:46 +08:00
componentWillReceiveProps(nextProps) {
2017-08-18 20:35:31 +08:00
let _actionId = nextProps.match.params.actionId;
2017-08-20 22:13:46 +08:00
if (this.actionId !== _actionId) {
this.actionId = _actionId;
2017-08-18 20:35:31 +08:00
this.handleRequest(nextProps)
}
}
2017-08-20 22:13:46 +08:00
render() {
2017-08-18 20:35:31 +08:00
let { sortedInfo } = this.state;
sortedInfo = sortedInfo || {};
const columns = [{
title: '接口名称',
dataIndex: 'title',
key: 'title',
2017-08-20 22:13:46 +08:00
sorter: (a, b) => {
return a.title.localeCompare(b.title) === 1
},
2017-08-18 20:35:31 +08:00
sortOrder: sortedInfo.columnKey === 'title' && sortedInfo.order
2017-08-20 22:13:46 +08:00
}, {
2017-08-21 12:05:18 +08:00
title: '接口路径',
2017-08-18 20:35:31 +08:00
dataIndex: 'path',
2017-08-21 12:05:18 +08:00
key: 'path',
render: (item)=>{
return <span>{this.props.curProject.basepath + item}</span>
}
2017-08-20 22:13:46 +08:00
}, {
2017-08-18 20:35:31 +08:00
title: '请求方式',
dataIndex: 'method',
key: 'method'
2017-08-20 22:13:46 +08:00
}, {
title: '状态',
dataIndex: 'status',
key: 'status',
render: (item) => {
return <div>{item === 'done' ?
<Tag color="#87d068">完成</Tag>
:
<Tag color="#f50">未完成</Tag>
}</div>
},
filters: [{
text: '完成',
value: 'done'
}, {
text: '未完成',
value: 'undone'
}],
onFilter: (value, record) => record.status.indexOf(value) === 0
}, {
2017-08-28 16:42:24 +08:00
title: '更新时间',
2017-08-21 12:05:18 +08:00
dataIndex: 'up_time',
key: 'up_time',
2017-08-20 22:13:46 +08:00
render: (item) => {
return <span>{formatTime(item)}</span>
}
2017-08-18 20:35:31 +08:00
}]
2017-08-20 22:13:46 +08:00
const data = this.state.data.map(item => {
2017-08-18 20:35:31 +08:00
item.key = item._id;
return item;
});
2017-08-20 22:13:46 +08:00
2017-08-18 20:35:31 +08:00
return (
2017-08-20 22:13:46 +08:00
<div style={{padding:"15px"}}>
<h2 style={{marginBottom: '10px'}}>接口列表</h2>
<Table pagination={false} columns={columns} onChange={this.handleChange} dataSource={data} />
</div>
2017-08-18 20:35:31 +08:00
)
}
}
export default InterfaceList