2018-10-08 16:33:28 +08:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* @title 组合过滤和其他功能使用
|
2018-10-15 14:59:53 +08:00
|
|
|
|
* @description 在过滤数据行的基础上增加列拖拽、动态菜单显示、下拉条件动态传入自定义等
|
2018-10-08 16:33:28 +08:00
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2018-10-09 19:56:19 +08:00
|
|
|
|
/**
|
|
|
|
|
* @description
|
|
|
|
|
*/
|
2018-10-08 16:33:28 +08:00
|
|
|
|
|
|
|
|
|
import React, { Component } from 'react';
|
|
|
|
|
import Table from '../../src';
|
2018-10-09 19:56:19 +08:00
|
|
|
|
import multiSelect from '../../src/lib/MultiSelect';
|
|
|
|
|
import sort from '../../src/lib/sort';
|
|
|
|
|
import Checkbox from 'bee-checkbox';
|
|
|
|
|
import Icon from 'bee-icon';
|
|
|
|
|
import Menu from 'bee-menus';
|
|
|
|
|
import Dropdown from 'bee-dropdown';
|
2018-10-08 16:33:28 +08:00
|
|
|
|
|
|
|
|
|
|
2018-10-09 19:56:19 +08:00
|
|
|
|
const { Item } = Menu;
|
|
|
|
|
const SubMenu = Menu.SubMenu;
|
|
|
|
|
const MenuItemGroup = Menu.ItemGroup;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const dataList = [
|
|
|
|
|
{ "key": "1", value: "库存明细", id: "a" },
|
|
|
|
|
{ "key": "2", value: "订单明细", id: "v" },
|
|
|
|
|
{ "key": "3", value: "发货明细", id: "c" }
|
|
|
|
|
]
|
2018-10-08 16:33:28 +08:00
|
|
|
|
|
|
|
|
|
const data27 = [
|
|
|
|
|
{
|
|
|
|
|
key: "1",
|
|
|
|
|
name: "John Brown",
|
|
|
|
|
age: 32,
|
|
|
|
|
date: "2018-09-19",
|
|
|
|
|
address: "朝阳区",
|
|
|
|
|
mark: "无"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
key: "2",
|
|
|
|
|
name: "Jim Green",
|
|
|
|
|
age: 40,
|
|
|
|
|
date: "2018-09-18",
|
|
|
|
|
address: "朝阳区",
|
|
|
|
|
mark: "无"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
key: "3",
|
|
|
|
|
name: "Jim Green",
|
|
|
|
|
age: 40,
|
|
|
|
|
date: "2018-09-18",
|
|
|
|
|
address: "东城区",
|
|
|
|
|
mark: "无"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
key: "4",
|
|
|
|
|
name: "Jim Green",
|
|
|
|
|
age: 40,
|
|
|
|
|
date: "2018-09-18",
|
|
|
|
|
address: "东城区",
|
|
|
|
|
mark: "无"
|
|
|
|
|
}, {
|
|
|
|
|
key: "5",
|
|
|
|
|
name: "John Brown",
|
|
|
|
|
age: 32,
|
|
|
|
|
date: "2018-09-18",
|
|
|
|
|
address: "海淀区",
|
|
|
|
|
mark: "无"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
key: "6",
|
|
|
|
|
name: "Jim Green",
|
|
|
|
|
age: 48,
|
|
|
|
|
date: "2018-09-18",
|
|
|
|
|
address: "海淀区",
|
|
|
|
|
mark: "无"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
key: "7",
|
|
|
|
|
name: "Jim Green",
|
|
|
|
|
age: 40,
|
|
|
|
|
date: "2018-09-18",
|
|
|
|
|
address: "海淀区",
|
|
|
|
|
mark: "无"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
key: "8",
|
|
|
|
|
name: "Jim Green",
|
|
|
|
|
age: 38,
|
|
|
|
|
date: "2018-09-18",
|
|
|
|
|
address: "海淀区",
|
|
|
|
|
mark: "无"
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
|
2018-10-09 19:56:19 +08:00
|
|
|
|
const MultiSelectTable = multiSelect(Table, Checkbox);
|
|
|
|
|
const ComplexTable = sort(MultiSelectTable, Icon);
|
2018-10-08 16:33:28 +08:00
|
|
|
|
class Demo27 extends Component {
|
2018-10-15 14:59:53 +08:00
|
|
|
|
constructor(props) {
|
|
|
|
|
super(props);
|
|
|
|
|
this.state = {
|
|
|
|
|
dropdownvalue: []
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-10-08 16:33:28 +08:00
|
|
|
|
handlerFilterRowsChange = (key, val) => {
|
|
|
|
|
console.log('准备构建AJAX请求,接收参数:key=', key, ' value=', val);
|
|
|
|
|
}
|
2018-10-09 19:56:19 +08:00
|
|
|
|
|
2018-10-08 16:33:28 +08:00
|
|
|
|
handlerFilterRowsDropChange = (key, val) => {
|
|
|
|
|
console.log('过滤条件类型:', key, val);
|
|
|
|
|
}
|
2018-10-09 19:56:19 +08:00
|
|
|
|
getSelectedDataFunc = data => {
|
|
|
|
|
console.log(data);
|
|
|
|
|
}
|
|
|
|
|
onClick = (item) => {
|
|
|
|
|
console.log(item);
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-08 16:33:28 +08:00
|
|
|
|
render() {
|
2018-10-09 19:56:19 +08:00
|
|
|
|
const menu1 = (
|
|
|
|
|
<Menu onClick={this.onClick} style={{ width: 240 }} mode="vertical" >
|
|
|
|
|
<SubMenu key="sub1" title={<span><span>组织 1</span></span>}>
|
|
|
|
|
<MenuItemGroup title="Item 1">
|
|
|
|
|
<Menu.Item key="1">选项 1</Menu.Item>
|
|
|
|
|
<Menu.Item key="2">选项 2</Menu.Item>
|
|
|
|
|
</MenuItemGroup>
|
|
|
|
|
<MenuItemGroup title="Iteom 2">
|
|
|
|
|
<Menu.Item key="3">选项 3</Menu.Item>
|
|
|
|
|
<Menu.Item key="4">选项 4</Menu.Item>
|
|
|
|
|
</MenuItemGroup>
|
|
|
|
|
</SubMenu>
|
|
|
|
|
</Menu>)
|
|
|
|
|
let multiObj = {
|
|
|
|
|
type: "checkbox"
|
|
|
|
|
};
|
|
|
|
|
let columns27 = [
|
|
|
|
|
{
|
|
|
|
|
title: "", width: 40, dataIndex: "key", key: "key", render: (text, record, index) => {
|
|
|
|
|
return <Dropdown
|
|
|
|
|
trigger={['click']}
|
|
|
|
|
overlay={menu1}
|
|
|
|
|
animation="slide-up"
|
|
|
|
|
>
|
|
|
|
|
<Icon style={{ "visibility": "hidden" }} type="uf-eye" />
|
|
|
|
|
</Dropdown>
|
|
|
|
|
}
|
|
|
|
|
},
|
2018-11-26 17:59:53 +08:00
|
|
|
|
{
|
|
|
|
|
title: "姓名",
|
|
|
|
|
width: 180,
|
|
|
|
|
dataIndex: "name",
|
|
|
|
|
key: "name",
|
|
|
|
|
filterType: "text",//输入框类型
|
|
|
|
|
filterDropdown: "show",//显示条件
|
|
|
|
|
filterDropdownType: "string"//字符条件
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "区间",
|
|
|
|
|
width: 150,
|
|
|
|
|
dataIndex: "mark",
|
|
|
|
|
key: "mark",
|
|
|
|
|
filterType: "text",//输入框类型
|
|
|
|
|
filterDropdownType: "number"//数值类条件
|
|
|
|
|
},
|
2018-10-11 20:15:00 +08:00
|
|
|
|
{
|
|
|
|
|
title: "年龄",
|
2018-11-26 15:32:46 +08:00
|
|
|
|
width: 180,
|
2018-10-11 20:15:00 +08:00
|
|
|
|
sorter: (a, b) => a.age - b.age,
|
|
|
|
|
dataIndex: "age",
|
|
|
|
|
key: "age",
|
|
|
|
|
filterType: "dropdown",
|
2018-11-26 17:59:53 +08:00
|
|
|
|
filterDropdown: "hide",//不显示条件
|
2018-10-11 20:15:00 +08:00
|
|
|
|
filterDropdownAuto: "manual",//切换手动传入模式
|
2018-10-15 14:59:53 +08:00
|
|
|
|
filterDropdownData: this.state.dropdownvalue,
|
|
|
|
|
filterDropdownFocus: () => {
|
|
|
|
|
this.setState({
|
|
|
|
|
dropdownvalue: [{ key: "自定义数据1", value: "1" }, { key: "自定义数据2", value: "2" }]
|
|
|
|
|
});
|
|
|
|
|
}
|
2018-10-11 20:15:00 +08:00
|
|
|
|
},
|
|
|
|
|
{ title: "居住地址", width: 150, dataIndex: "address", key: "address", filterType: "dropdown", filterDropdown: "hide" },
|
2018-10-09 19:56:19 +08:00
|
|
|
|
];
|
|
|
|
|
return <ComplexTable
|
2018-10-08 16:33:28 +08:00
|
|
|
|
onFilterRowsDropChange={this.handlerFilterRowsDropChange}//下拉条件的回调(key,val)=>()
|
|
|
|
|
onFilterRowsChange={this.handlerFilterRowsChange}//触发输入操作以及其他的回调(key,val)=>()
|
|
|
|
|
filterDelay={500}//输入文本多少ms触发回调函数,默认300ms
|
|
|
|
|
filterable={true}//是否开启过滤数据功能
|
2018-10-09 19:56:19 +08:00
|
|
|
|
getSelectedDataFunc={this.getSelectedDataFunc}
|
2018-10-08 16:33:28 +08:00
|
|
|
|
bordered
|
2018-10-09 19:56:19 +08:00
|
|
|
|
multiSelect={multiObj}
|
2018-10-08 16:33:28 +08:00
|
|
|
|
columns={columns27}
|
|
|
|
|
data={data27} />;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default Demo27;
|