import { connect } from 'dva/index';
import React, { Component, Fragment } from 'react';
import { Form, Spin, Modal, Rate } from 'antd';
import {
failTip,
sucTip,
dragSldTableColumn,
sldHandlePaginationData,
list_com_page_size_10,
getTableNum, dateFormat, sldComLanguage, sldtbaleOpeBtnText,
sldPopConfirmDiy,
} from '@/utils/utils';
import global from '@/global.less';
import StandardTable from '@/components/StandardTable';
import Search from '@/components/Search/Search';
import styles from '@/assets/css/manage.less';
let pageSize = list_com_page_size_10;
let sthis = '';
@connect(({ evaluate }) => ({
evaluate,
}))
@Form.create()
export default class EvaluateStore extends Component {
constructor(props) {
super(props);
sthis = this;
this.state = {
loading: false,
submiting: false,
modalVisible: false,
modalvisibleImg: false,
previewImage: '',
data: {},
selectedRows: [],
selectedRowKeys: [],//selectedRows的key
title: '',
type: 'add',//'add'新增 'edit'编辑
params: { pageSize: pageSize },//搜索条件
curData: {},//编辑的数据
searchHeight: 0,
operateData: [],
addData: [{
type: 'textarea',
label: `${sldComLanguage('回复')}`,//描述
name: 'replyContent',
maxLength:100,
placeholder: `${sldComLanguage('请输入')}${sldComLanguage('描述')}`,//请输入描述
rules: [{
required: true,
whitespace: true,
message: `${sldComLanguage('请输入')}${sldComLanguage('描述')}`,//请输入描述
}
],
},
],//modal框-积分经验值数据
search_data: [{
type: 'input',
label: `${sldComLanguage('评价人')}`,//评价人
name: 'memberName',
placeholder: `${sldComLanguage('请输入')}${sldComLanguage('评价人')}`,//请输入评价人
},{
type: 'input',
label: `${sldComLanguage('店铺名称')}`,//店铺名称
name: 'storeName',
placeholder: `${sldComLanguage('请输入店铺名称')}`,//请输入店铺名称
}, {
type: 'rangepicker',
label: `${sldComLanguage('评价时间')}`,//评价时间
name: 'search_create_time',
placeholder1: `${sldComLanguage('开始时间')}`,//开始时间
placeholder2: `${sldComLanguage('结束时间')}`,//结束时间
},
],
formValues: {},//搜索条件
columns: [
{
title: '序号',
dataIndex: 'commentId',
align: 'center',
width: 55,
render: (text, record, index) => getTableNum(this.state.params, pageSize, index),
},
{
title: `${sldComLanguage('店铺名称')}`,//店铺名称
dataIndex: 'storeName',
align: 'center',
width: 150,
},
{
title: `${sldComLanguage('订单号')}`,//订单号
dataIndex: 'orderSn',
align: 'center',
width: 150,
},
{
title: `${sldComLanguage('评价人')}`,//评价人
dataIndex: 'memberName',
align: 'center',
width: 100,
},
{
title: `${sldComLanguage('评分')}`,
dataIndex: 'deliverSpeed',
align: 'center',
width: 150,
render: function(text, record, index) {
return
{sldComLanguage('描述相符')}:
{sldComLanguage('服务态度')}:
{sldComLanguage('发货速度')}:
;
},
},
{
title: `${sldComLanguage('评价时间')}`,//评价时间
dataIndex: 'createTime',
align: 'center',
width: 150,
},
{
title: `${sldComLanguage('操作')}`,//操作
align: 'center',
width: 120,
render: (text, record) => (
{/*删除后不可恢复,是否确定删除?*/}
{sldPopConfirmDiy('leftBottom', `${sldComLanguage('删除后不可恢复,是否确定删除')}`, () => this.del(record.commentId), `${sldComLanguage('确定')}`, `${sldComLanguage('取消')}`,
sldtbaleOpeBtnText(`${sldComLanguage('删除')}`, () => null))}
),
},
],
};
}
componentDidMount() {
this.get_list({ pageSize: pageSize });
}
//获取数据列表
get_list = (params) => {
this.setState({ loading: true });
const { dispatch } = this.props;
dispatch({
type: 'evaluate/get_store_comment_list',
payload: { ...params },
callback: (res) => {
this.setState({ loading: false });
if (res.state == 200) {
if (res.data.length == 0 && this.state.params.current > 1) {
params.current = params.current - 1;
this.get_list(params);
} else {
this.setState({
data: res.data,
});
}
}
},
});
};
del = (id) => {
this.props.dispatch({
type: 'evaluate/store_comment_del',
payload: {
commentIds: id,
},
callback: res => {
if (res.state == 200) {
sucTip(res.msg);
this.get_list({ pageSize: pageSize });
} else {
failTip(res.msg);
}
},
});
};
handlePreview = (imgurl) => {
this.setState({
modalvisibleImg: true,
previewImage: imgurl,
});
};
handleSelectRows = (rows, rowkeys) => {
this.setState({
selectedRows: rows,
selectedRowKeys: rowkeys,
});
};
handleTablePagination = (pagination, filtersArg, sorter, type = 'main') => {
if (type == 'main') {
const { formValues } = this.state;
const params = sldHandlePaginationData(pagination, filtersArg, sorter, formValues);
pageSize = params.pageSize;
this.setState({
params: params,
});
this.get_list(params);
}
};
//搜索事件
search = (data) => {
const values = { ...data };
//时间处理
if (values.search_create_time) {
values.startTime = values.search_create_time[0] ? values.search_create_time[0].format(dateFormat) + ' 00:00:00' : '';
values.endTime = values.search_create_time[1] ? values.search_create_time[1].format(dateFormat) + ' 23:59:59' : '';
values.search_create_time = '';
}
for (let i in values) {
if (values[i] == '') {
delete values[i];
}
}
this.setState({
formValues: values,
params: { pageSize: pageSize }
});
this.get_list({ pageSize: pageSize, ...values });
};
//搜索重置事件
seaReset = () => {
//搜索条件置为空
this.setState({
formValues: {},
params: { pageSize: pageSize }
});
this.get_list({ pageSize: pageSize });
};
//表格拖动
resizeTable = (index, size, type, data) => {
let datas = dragSldTableColumn(index, size, data);
this.setState({ [type]: datas });
};
sldHandleCancle = () => {
this.setState({ modalVisible: false });
};
//图片预览关闭功能
handleModalVisible = () => {
this.setState({
modalvisibleImg: false,
});
};
render() {
const {
selectedRows, search_data, columns, data, loading, operateData, submiting, title, modalVisible, modalvisibleImg, previewImage,
} = this.state;
return (
this.search(data)} seaReset={() => this.seaReset()}
/>
{/*标准表格-start*/}
this.handleTablePagination(pagination, filtersArg, sorter, 'main')}
resizeTable={(index, size) => this.resizeTable(index, size, 'columns', columns)}
isColumnResize={true}
showMarkColor={true}
/>
{/*标准表格-end*/}
{/*图片预览功能*/}
);
}
}