import React, { Component } from 'react' import { formatTime } from '../../common.js' import { Link } from 'react-router-dom' //import PropTypes from 'prop-types' import { connect } from 'react-redux' import PropTypes from 'prop-types' import { Table, Popconfirm, message } from 'antd' import axios from 'axios'; const limit = 10; @connect( state => { return { curUserRole: state.user.role } } ) class List extends Component { constructor(props) { super(props) this.state = { data: [], total: null, current: 1 } } static propTypes = { curUserRole: PropTypes.string } changePage =(current)=>{ this.setState({ current: current }, this.getUserList) } getUserList() { axios.get('/api/user/list?page=' + this.state.current).then((res) => { let result = res.data; if (result.errcode === 0) { let list = result.data.list; let total = result.data.total * limit; list.map((item, index) => { item.key = index; item.up_time = formatTime(item.up_time) }) this.setState({ data: list, total: total }); } }) } componentDidMount() { this.getUserList() } confirm = (uid) =>{ axios.post('/api/user/del', { id: uid }).then( (res)=>{ if(res.data.errcode === 0){ message.success('已删除此用户'); let userlist = this.state.data; userlist = userlist.filter( (item)=>{ return item._id != uid } ) this.setState({ data: userlist }) }else{ message.error(res.data.errmsg); } }, (err) => { message.error(err.message); } ) } render() { const role = this.props.curUserRole; let data = []; if(role === 'admin'){ data = this.state.data; } let columns = [{ title: 'UID', dataIndex: '_id', key: '_id', width: 100 }, { title: '用户名', dataIndex: 'username', key: 'username', width: 180 }, { title: 'Email', dataIndex: 'email', key: 'email' }, { title: '用户角色', dataIndex: 'role', key: 'role', width:150 }, { title: '更新日期', dataIndex: 'up_time', key: 'up_time', width: 150 }, { title: '功能', key: 'action', width:"90px", render: (item) => { return ( 查看 {this.confirm(item._id)}} okText="确定" cancelText="取消"> 删除 ) } }] columns = columns.filter( (item)=>{ if(item.key === 'action' && role !== 'admin'){ return false; } return true; } ) const pageConfig = { total: this.state.total, pageSize: limit, current: this.state.current, onChange: this.changePage } return (
) } } export default List