add:Demo27 过滤行与拖拽兼容使用.

This commit is contained in:
kvkens 2018-10-08 16:33:28 +08:00
parent e374da6180
commit 66f9bdd34e
7 changed files with 1183 additions and 1417 deletions

108
demo/demolist/Demo27.js Normal file
View File

@ -0,0 +1,108 @@
/**
*
* @title 组合过滤和其他功能使用
* @description 在过滤的基础上增加列拖拽列排序等一系列功能
*
*/
import React, { Component } from 'react';
import Table from '../../src';
import dragColumn from '../../src/lib/dragColumn';
const columns27 = [
{ title: "姓名", width: 180, dataIndex: "name", key: "name", filterType: "text", filterDropdown: "show" },
{ title: "年龄", width: 150, dataIndex: "age", key: "age", filterType: "dropdown", filterDropdown: "show" },
{ title: "居住地址", width: 150, dataIndex: "address", key: "address", filterType: "dropdown", filterDropdown: "show" },
];
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: "无"
}
];
const DragColumnTable = dragColumn(Table);
class Demo27 extends Component {
handlerFilterRowsChange = (key, val) => {
console.log('准备构建AJAX请求接收参数key=', key, ' value=', val);
}
handlerFilterRowsDropChange = (key, val) => {
console.log('过滤条件类型:', key, val);
}
render() {
return <DragColumnTable
onFilterRowsDropChange={this.handlerFilterRowsDropChange}//下拉条件的回调(key,val)=>()
onFilterRowsChange={this.handlerFilterRowsChange}//触发输入操作以及其他的回调(key,val)=>()
filterDelay={500}//输入文本多少ms触发回调函数默认300ms
filterable={true}//是否开启过滤数据功能
bordered
draggable={true}
columns={columns27}
data={data27} />;
}
}
export default Demo27;

File diff suppressed because one or more lines are too long

4
dist/demo.css vendored
View File

@ -2553,9 +2553,9 @@ a, .mdl-accordion, .mdl-button, .mdl-card, .mdl-checkbox, .mdl-dropdown-menu,
@font-face { @font-face {
font-family: "uf"; font-family: "uf";
src: url("../style/utils/iconfont.eot"); src: url("../node_modules/tinper-bee-core/scss/iconfont.eot?t=1483429573920");
/* IE9*/ /* IE9*/
src: url("../style/utils/iconfont.eot") format("embedded-opentype"), url("../style/utils/iconfont.woff") format("woff"), url("../style/utils/iconfont.ttf") format("truetype"), url("../style/utils/iconfont.svg") format("svg"); src: url("../node_modules/tinper-bee-core/scss/iconfont.eot?t=1483429573920#iefix") format("embedded-opentype"), url("../node_modules/tinper-bee-core/scss/iconfont.woff?t=1483429573920") format("woff"), url("../node_modules/tinper-bee-core/scss/iconfont.ttf?t=1483429573920") format("truetype"), url("../node_modules/tinper-bee-core/scss/iconfont.svg?t=1483429573920#uf") format("svg");
/* iOS 4.1- */ } /* iOS 4.1- */ }
.uf { .uf {

2
dist/demo.css.map vendored

File diff suppressed because one or more lines are too long

2462
dist/demo.js vendored

File diff suppressed because one or more lines are too long

2
dist/demo.js.map vendored

File diff suppressed because one or more lines are too long

View File

@ -101,7 +101,7 @@ class TableHeader extends Component {
this.drag.initLeft = tryParseInt(event.target.style.left); this.drag.initLeft = tryParseInt(event.target.style.left);
this.drag.x = this.drag.initLeft; this.drag.x = this.drag.initLeft;
this.drag.currIndex = this.props.rows[0].findIndex(da => da.key == data.key); this.drag.currIndex = this.props.rows[0].findIndex(da => da.key == data.key);
let contentTableDom = document.getElementById("u-table-drag-thead-" + this.theadKey).parentNode; let contentTableDom = document.getElementById("u-table-drag-thead-" + this.theadKey).parentNode;
const styleWidth = contentTableDom.style.width; const styleWidth = contentTableDom.style.width;
if (styleWidth && (typeof (styleWidth) == 'number' || styleWidth.includes('px'))) { if (styleWidth && (typeof (styleWidth) == 'number' || styleWidth.includes('px'))) {
@ -110,12 +110,12 @@ class TableHeader extends Component {
this.contentTableWidth = parseInt(contentTableDom.scrollWidth) this.contentTableWidth = parseInt(contentTableDom.scrollWidth)
} }
const dragColWidth = this.drag.data[this.drag.currIndex].width; const dragColWidth = this.drag.data[this.drag.currIndex].width;
if(typeof(dragColWidth)=='string' && dragColWidth.indexOf('%')>-1){ if (typeof (dragColWidth) == 'string' && dragColWidth.indexOf('%') > -1) {
this.drag.width = this.contentTableWidth * parseInt(dragColWidth) /100 this.drag.width = this.contentTableWidth * parseInt(dragColWidth) / 100
}else{ } else {
this.drag.width = parseInt(this.drag.data[this.drag.currIndex].width); this.drag.width = parseInt(this.drag.data[this.drag.currIndex].width);
} }
} }
onMouseUp = (event, data) => { onMouseUp = (event, data) => {
this.border = false; this.border = false;
@ -303,6 +303,9 @@ class TableHeader extends Component {
da.width = parseInt(da.width) + contentWidthDiff; da.width = parseInt(da.width) + contentWidthDiff;
canDotDrag = 'th-can-not-drag' canDotDrag = 'th-can-not-drag'
} }
if (filterable && index == rows.length - 1) {
da.children = this.filterRenderType(da['filtertype'], da.dataindex, i);
}
if (draggable) { if (draggable) {
return (<th {...da} return (<th {...da}
onDragStart={(event) => { this.onDragStart(event, da) }} onDragStart={(event) => { this.onDragStart(event, da) }}
@ -331,12 +334,7 @@ class TableHeader extends Component {
</th>) </th>)
} else { } else {
let th; let th;
if (filterable && index == rows.length - 1) { th = da.onClick ? (<th {...da} className={`${da.className} ${fixedStyle}`} key={i} onClick={(event) => { da.onClick(da, event) }} />) : (<th {...da} key={i} className={`${da.className} ${fixedStyle}`} />);
da.children = this.filterRenderType(da['filtertype'], da.dataindex, i);
th = <th {...da} key={i} className={`${da.className} ${fixedStyle}`} />;
} else {
th = da.onClick ? (<th {...da} className={`${da.className} ${fixedStyle}`} key={i} onClick={(event) => { da.onClick(da, event) }} />) : (<th {...da} key={i} className={`${da.className} ${fixedStyle}`} />);
}
return (th); return (th);
} }
})} })}