212 lines
5.0 KiB
JavaScript
212 lines
5.0 KiB
JavaScript
/**
|
||
* @title 根据列进行过滤、拖拽交换列综合使用案例
|
||
* @description 新增属性【checkMinSize 当前表格显示最少列数 】 1. 当所有列都设置了width属性后,需要给table增加checkMinSize属性 2. 所有列不设置width。
|
||
*/
|
||
|
||
/**注:
|
||
* 在使用过滤列的时候,如果每一列都设置了width属性,勾选的时候回出现重复列问题。当表格的宽度小于合计宽度的时候,就会出现此问题。
|
||
* 必须有个别列不设置width属性,即可避免此问题。
|
||
*/
|
||
import React, { Component } from 'react';
|
||
import Table from '../../src';
|
||
import multiSelect from '../../src/lib/newMultiSelect';
|
||
import filterColumn from '../../src/lib/filterColumn';
|
||
import dragColumn from "../../src/lib/dragColumn";
|
||
|
||
import sum from '../../src/lib/sum';
|
||
import Icon from "bee-icon";
|
||
import Checkbox from 'bee-checkbox';
|
||
import Popover from 'bee-popover';
|
||
|
||
//Cloumns1
|
||
function getCloumns(){
|
||
const column = [
|
||
{
|
||
title: "序号",
|
||
dataIndex: "index",
|
||
key: "index",
|
||
width: 100,
|
||
},
|
||
{
|
||
title: "订单编号",
|
||
dataIndex: "orderCode",
|
||
key: "orderCode",
|
||
width: 100,
|
||
},
|
||
{
|
||
title: "供应商名称",
|
||
dataIndex: "supplierName",
|
||
key: "supplierName",
|
||
width: 100
|
||
},
|
||
{
|
||
title: "类型",
|
||
dataIndex: "type_name",
|
||
key: "type_name",
|
||
width: 100
|
||
},
|
||
{
|
||
title: "采购组织",
|
||
dataIndex: "purchasing",
|
||
key: "purchasing",
|
||
width: 100
|
||
},
|
||
{
|
||
title: "采购组",
|
||
dataIndex: "purchasingGroup",
|
||
key: "purchasingGroup",
|
||
width: 300
|
||
},
|
||
{
|
||
title: "凭证日期",
|
||
dataIndex: "voucherDate",
|
||
key: "voucherDate",
|
||
width: 100,
|
||
|
||
},
|
||
{
|
||
title: "审批状态",
|
||
dataIndex: "approvalState_name",
|
||
key: "approvalState_name",
|
||
width: 100
|
||
},
|
||
{
|
||
title: "确认状态",
|
||
dataIndex: "confirmState_name",
|
||
key: "confirmState_name",
|
||
width: 100
|
||
},
|
||
{
|
||
title: "关闭状态",
|
||
dataIndex: "closeState_name",
|
||
key: "closeState_name",
|
||
width: 100
|
||
},
|
||
{
|
||
title: "操作",
|
||
dataIndex: "d",
|
||
key: "d",
|
||
width:100,
|
||
fixed: "right",
|
||
render(text, record, index) {
|
||
return (
|
||
<div className='operation-btn'>
|
||
<a href="#"
|
||
tooltip={text}
|
||
onClick={() => {
|
||
alert('这是第'+index+'列,内容为:'+text);
|
||
}}
|
||
>
|
||
一些操作
|
||
</a>
|
||
</div>
|
||
)
|
||
}
|
||
}
|
||
];
|
||
return column;
|
||
}
|
||
|
||
const dataList = [
|
||
{
|
||
index: 1,
|
||
orderCode:"2343",
|
||
supplierName: "xxx",
|
||
type_name: "123",
|
||
purchasing:'内行',
|
||
purchasingGroup:"323",
|
||
voucherDate:"kkkk",
|
||
approvalState_name:"vvvv",
|
||
confirmState_name:"aaaa",
|
||
closeState_name:"vnnnnn",
|
||
d:"操作",
|
||
key: "1"
|
||
},
|
||
{
|
||
index: 2,
|
||
orderCode:"222",
|
||
supplierName: "22xxx",
|
||
type_name: "1223",
|
||
purchasing:'内行2',
|
||
purchasingGroup:"3223",
|
||
voucherDate:"222kk",
|
||
approvalState_name:"22vvvv",
|
||
confirmState_name:"2aaaa",
|
||
closeState_name:"2vnnnnn",
|
||
d:"2操作",
|
||
key: "2"
|
||
},
|
||
{
|
||
index: 3,
|
||
orderCode:"222",
|
||
supplierName: "22xxx",
|
||
type_name: "1223",
|
||
purchasing:'内行2',
|
||
purchasingGroup:"3223",
|
||
voucherDate:"222kk",
|
||
approvalState_name:"22vvvv",
|
||
confirmState_name:"2aaaa",
|
||
closeState_name:"2vnnnnn",
|
||
d:"3操作",
|
||
key: "3"
|
||
},
|
||
{
|
||
index: 4,
|
||
orderCode:"222",
|
||
supplierName: "22xxx",
|
||
type_name: "1223",
|
||
purchasing:'内行2',
|
||
purchasingGroup:"3223",
|
||
voucherDate:"222kk",
|
||
approvalState_name:"22vvvv",
|
||
confirmState_name:"2aaaa",
|
||
closeState_name:"2vnnnnn",
|
||
d:"4操作",
|
||
key: "4"
|
||
},
|
||
]
|
||
|
||
const DragColumnTable = filterColumn(dragColumn(multiSelect(Table, Checkbox)),Popover);
|
||
|
||
const defaultProps25 = {
|
||
prefixCls: "bee-table"
|
||
};
|
||
|
||
class Demo25 extends Component {
|
||
constructor(props) {
|
||
super(props);
|
||
}
|
||
|
||
getSelectedDataFunc=(data)=>{
|
||
console.log("data",data);
|
||
}
|
||
|
||
getCloumnsScroll=(columns)=>{
|
||
let sum = 0;
|
||
columns.forEach((da)=>{
|
||
sum += da.width;
|
||
})
|
||
console.log("sum",sum);
|
||
return (sum);
|
||
}
|
||
|
||
render() {
|
||
let columns = getCloumns();
|
||
|
||
return <div className="demo25"><DragColumnTable
|
||
columns={columns}
|
||
data={dataList}
|
||
getSelectedDataFunc={this.getSelectedDataFunc}
|
||
bordered
|
||
checkMinSize={7}
|
||
draggable={true}
|
||
multiSelect={{type: "checkbox"}}
|
||
scroll={{x:"130%", y: 100}}
|
||
// scroll={{x:this.getCloumnsScroll(columns), y: 150}}
|
||
/></div>
|
||
}
|
||
}
|
||
Demo25.defaultProps = defaultProps25;
|
||
|
||
|
||
export default Demo25; |