mirror of
https://github.com/YMFE/yapi.git
synced 2025-01-24 13:14:16 +08:00
100 lines
2.2 KiB
JavaScript
100 lines
2.2 KiB
JavaScript
import React, { Component } from 'react'
|
|
import { Table, Button } from 'antd'
|
|
import PropTypes from 'prop-types'
|
|
import axios from 'axios'
|
|
import { connect } from 'react-redux'
|
|
import { Link } from 'react-router-dom'
|
|
import { deleteInterfaceData } from '../../../actions/interfaceAction.js'
|
|
|
|
@connect(
|
|
state => {
|
|
return {
|
|
interfaceData: state.Interface.interfaceData
|
|
}
|
|
},
|
|
{
|
|
deleteInterfaceData
|
|
}
|
|
)
|
|
|
|
class InterfaceTable extends Component {
|
|
static propTypes = {
|
|
interfaceData: PropTypes.array,
|
|
data: PropTypes.array,
|
|
projectId: PropTypes.string,
|
|
deleteInterfaceData: PropTypes.func
|
|
}
|
|
|
|
constructor(props) {
|
|
super(props)
|
|
}
|
|
|
|
deleteInterfaceData (interfaceId) {
|
|
let interfaceArr = []
|
|
let { interfaceData } = this.props
|
|
interfaceData.forEach(value => {
|
|
if (value._id !== interfaceId) {
|
|
interfaceArr.push(value)
|
|
}
|
|
})
|
|
this.props.deleteInterfaceData(interfaceArr)
|
|
}
|
|
|
|
deleteInterface (interfaceId) {
|
|
const params = {
|
|
id: interfaceId
|
|
}
|
|
axios.post('/interface/del', params)
|
|
.then(() => {
|
|
this.deleteInterfaceData(interfaceId)
|
|
})
|
|
.catch(err => {
|
|
console.log(err)
|
|
})
|
|
}
|
|
|
|
render () {
|
|
const columns = [{
|
|
title: '接口名称',
|
|
dataIndex: 'title',
|
|
key: 'title'
|
|
}, {
|
|
title: '接口URL',
|
|
dataIndex: 'path',
|
|
key: 'path'
|
|
},{
|
|
title: '更新日期',
|
|
dataIndex: 'add_time',
|
|
key: 'add_time'
|
|
}, {
|
|
title: '功能',
|
|
'key': 'action',
|
|
render: (data) => {
|
|
const deleteInterface = this.deleteInterface.bind(this, data._id)
|
|
console.log(data)
|
|
return (
|
|
<span>
|
|
<Button type="primary">
|
|
<Link to={`/AddInterface/edit/${data._id}`}>编辑</Link>
|
|
</Button>
|
|
<Button type="primary">
|
|
<Link to={`/AddInterface/edit/${data._id}`}>测试</Link>
|
|
</Button>
|
|
<Button type="danger" onClick={deleteInterface}>删除</Button>
|
|
</span>
|
|
)
|
|
}
|
|
}]
|
|
|
|
const data = this.props.data;
|
|
|
|
return (
|
|
<section className="interface-table">
|
|
<Table columns={columns} dataSource={data} />
|
|
</section>
|
|
)
|
|
}
|
|
}
|
|
|
|
export default InterfaceTable
|