2019-04-22 14:52:22 +08:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* @title 列合计(总计)
|
|
|
|
|
* @parent 列渲染 Custom Render
|
|
|
|
|
* @description 给需要计算合计的列(columns),设置sumCol值为true即可,支持动态设置数据源。
|
2019-04-23 20:11:38 +08:00
|
|
|
|
* demo0405
|
2019-04-22 14:52:22 +08:00
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
import React, { Component } from "react";
|
2019-04-25 10:03:41 +08:00
|
|
|
|
import {Checkbox} from "tinper-bee";
|
2020-10-14 15:25:17 +08:00
|
|
|
|
import Table from "../../src";
|
2019-04-22 14:52:22 +08:00
|
|
|
|
import sum from "../../src/lib/sum.js";
|
|
|
|
|
import multiSelect from "../../src/lib/multiSelect.js";
|
2020-10-14 15:25:17 +08:00
|
|
|
|
|
2019-04-22 14:52:22 +08:00
|
|
|
|
let ComplexTable = multiSelect(sum(Table), Checkbox);
|
2020-05-21 17:07:15 +08:00
|
|
|
|
//sum第二个参数可以设置精度,例如 sum(Table,4); 设计精度为4
|
2019-04-25 10:03:41 +08:00
|
|
|
|
let _sum = 0;
|
2019-04-22 14:52:22 +08:00
|
|
|
|
const columns = [
|
|
|
|
|
{
|
|
|
|
|
title: "单据编号",
|
|
|
|
|
dataIndex: "num",
|
|
|
|
|
key: "num",
|
|
|
|
|
width: 120,
|
|
|
|
|
fixed: "left"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "单据日期",
|
|
|
|
|
dataIndex: "date",
|
|
|
|
|
key: "date",
|
|
|
|
|
width: 200,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "业务类型",
|
|
|
|
|
dataIndex: "type",
|
|
|
|
|
key: "type",
|
|
|
|
|
width: 200
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "供应商",
|
|
|
|
|
dataIndex: "supplier",
|
|
|
|
|
key: "supplier",
|
|
|
|
|
width: 100
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "联系人",
|
|
|
|
|
dataIndex: "contact",
|
|
|
|
|
key: "contact",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "仓库",
|
|
|
|
|
dataIndex: "warehouse",
|
|
|
|
|
key: "warehouse",
|
|
|
|
|
width: 80,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "整单数量",
|
|
|
|
|
dataIndex: "total",
|
|
|
|
|
key: "total",
|
|
|
|
|
width: 100,
|
2020-10-14 15:25:17 +08:00
|
|
|
|
sumCol: true,
|
|
|
|
|
sumThousandth: true
|
2019-04-22 14:52:22 +08:00
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "金额",
|
|
|
|
|
dataIndex: "money",
|
|
|
|
|
key: "money",
|
|
|
|
|
width: 100,
|
2020-10-14 15:25:17 +08:00
|
|
|
|
sumCol: true,
|
|
|
|
|
sumThousandth: true
|
2019-04-22 14:52:22 +08:00
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
function getData(){
|
|
|
|
|
const data = [];
|
|
|
|
|
for (let i = 0; i < 5; i++) {
|
|
|
|
|
data.push({
|
|
|
|
|
key: i,
|
|
|
|
|
num: "NU039100"+i,
|
|
|
|
|
date: "2019-03-01",
|
|
|
|
|
type: "普通采购",
|
|
|
|
|
supplier: "gys"+i,
|
|
|
|
|
contact: "Tom",
|
|
|
|
|
warehouse: "普通仓",
|
|
|
|
|
total: i + Math.floor(Math.random()*10),
|
2020-10-14 15:25:17 +08:00
|
|
|
|
money: 2000 * Math.floor(Math.random()*10)
|
2019-04-22 14:52:22 +08:00
|
|
|
|
});
|
2019-04-25 10:03:41 +08:00
|
|
|
|
_sum += data[i].total;
|
|
|
|
|
_sum += data[i].money;
|
2019-04-22 14:52:22 +08:00
|
|
|
|
}
|
|
|
|
|
return data;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class Demo35 extends Component {
|
2020-10-14 15:25:17 +08:00
|
|
|
|
|
2019-04-22 14:52:22 +08:00
|
|
|
|
constructor(props) {
|
|
|
|
|
super(props);
|
|
|
|
|
this.state = {
|
2019-04-25 10:03:41 +08:00
|
|
|
|
data: getData(),
|
|
|
|
|
sum:_sum
|
2019-04-22 14:52:22 +08:00
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
render() {
|
|
|
|
|
const {data} = this.state;
|
|
|
|
|
return (
|
|
|
|
|
<div>
|
2020-10-14 15:25:17 +08:00
|
|
|
|
<ComplexTable
|
2019-04-22 14:52:22 +08:00
|
|
|
|
columns={columns}
|
|
|
|
|
data={data}
|
|
|
|
|
bordered
|
2019-04-25 10:03:41 +08:00
|
|
|
|
footer={currentData => <div>总计: {_sum}</div>}
|
2019-04-22 14:52:22 +08:00
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
export default Demo35;
|