拖拽支持字符串宽度

This commit is contained in:
wanghaoo 2018-09-30 11:02:04 +08:00
parent 0bf01c8070
commit cefc17f534
10 changed files with 67 additions and 109 deletions

View File

@ -12,7 +12,7 @@ const columns16 = [
{ {
title: "操作", title: "操作",
dataIndex: "d", dataIndex: "d",
key: "d", key: "d",
fixed:'left', fixed:'left',
width:200, width:200,
render(text, record, index) { render(text, record, index) {
@ -28,7 +28,7 @@ const columns16 = [
); );
} }
}, },
{ title: "用户名", dataIndex: "a", key: "a", width: 100 }, { title: "用户名", dataIndex: "a", key: "a", width: 1500 },
{ id: "123", title: "性别", dataIndex: "b", key: "b", width: 100 }, { id: "123", title: "性别", dataIndex: "b", key: "b", width: 100 },
{ title: "年龄", dataIndex: "c", key: "c", width: 200 }, { title: "年龄", dataIndex: "c", key: "c", width: 200 },
@ -120,6 +120,7 @@ class Demo16 extends Component {
data={data16} data={data16}
onExpand={this.getData} onExpand={this.getData}
expandedRowRender={this.expandedRowRender} expandedRowRender={this.expandedRowRender}
scroll={{x:true}}
title={currentData => <div>标题: 这是一个标题</div>} title={currentData => <div>标题: 这是一个标题</div>}
footer={currentData => <div>表尾: 我是小尾巴</div>} footer={currentData => <div>表尾: 我是小尾巴</div>}
/> />

View File

@ -14,19 +14,19 @@ const columns23 = [
title: "名字", title: "名字",
dataIndex: "a", dataIndex: "a",
key: "a", key: "a",
width: 100 width: '10%'
}, },
{ {
title: "性别", title: "性别",
dataIndex: "b", dataIndex: "b",
key: "b", key: "b",
width: 200 width: '200'
}, },
{ {
title: "年龄", title: "年龄",
dataIndex: "c", dataIndex: "c",
key: "c", key: "c",
width: 200, width: '200',
sumCol: true, sumCol: true,
sorter: (a, b) => a.c - b.c sorter: (a, b) => a.c - b.c
}, },
@ -34,6 +34,7 @@ const columns23 = [
title: "武功级别", title: "武功级别",
dataIndex: "d", dataIndex: "d",
key: "d", key: "d",
fixed:'right',
width: 200, width: 200,
} }
]; ];

View File

@ -118,54 +118,10 @@ const dataList = [
voucherDate:"kkkk", voucherDate:"kkkk",
approvalState_name:"vvvv", approvalState_name:"vvvv",
confirmState_name:"aaaa", confirmState_name:"aaaa",
closeState_name:"vnnnnn", closeState_name:"vnnnnnvnnnnnvnnnnnvnnnnnvnnnnnvnnnnnvnnnnnvnnnnnvnnnnnvnnnnnvnnnnnvnnnnn",
d:"操作", d:"操作",
key: "1" key: "1"
}, }
{
index: 2,
_checked:true,
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",
_disabled:true,
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 DragColumnTable = filterColumn(dragColumn(multiSelect(Table, Checkbox)),Popover);
@ -191,6 +147,12 @@ class Demo25 extends Component {
console.log("sum",sum); console.log("sum",sum);
return (sum); return (sum);
} }
onExpand = (expandedKeys) => {
this.setState({
expandedKeys,
autoExpandParent: false,
});
}
selectedRow=(record, index)=>{ selectedRow=(record, index)=>{
@ -207,7 +169,7 @@ class Demo25 extends Component {
checkMinSize={7} checkMinSize={7}
draggable={true} draggable={true}
multiSelect={{type: "checkbox"}} multiSelect={{type: "checkbox"}}
scroll={{x:"130%", y: 100}} scroll={{x:"130%", y: true}}
selectedRow={this.selectedRow} selectedRow={this.selectedRow}
// scroll={{x:this.getCloumnsScroll(columns), y: 150}} // scroll={{x:this.getCloumnsScroll(columns), y: 150}}
/></div> /></div>

File diff suppressed because one or more lines are too long

5
dist/demo.css vendored
View File

@ -8470,7 +8470,7 @@ ul {
padding-right: 0px; } padding-right: 0px; }
.u-table-fixed-header .u-table-body-inner { .u-table-fixed-header .u-table-body-inner {
height: 100%; height: 100%;
overflow: auto; } overflow: scroll; }
.u-table-fixed-header .u-table-scroll .u-table-header { .u-table-fixed-header .u-table-scroll .u-table-header {
overflow-x: scroll; overflow-x: scroll;
padding-bottom: 20px; padding-bottom: 20px;
@ -8642,6 +8642,9 @@ ul {
.u-table-thead-th .th-drag-gap-hover { .u-table-thead-th .th-drag-gap-hover {
background: #ccc; background: #ccc;
cursor: col-resize; } cursor: col-resize; }
.u-table-thead-th.th-can-not-drag .th-drag-gap-hover {
cursor: none;
width: 0px; }
.u-table-thead-th:last-child-drag-gap { .u-table-thead-th:last-child-drag-gap {
border: none; } border: none; }
.u-table-filter-column-pop-cont { .u-table-filter-column-pop-cont {

2
dist/demo.css.map vendored

File diff suppressed because one or more lines are too long

76
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

@ -113,7 +113,7 @@ $table-move-in-color: $bg-color-base;
&-fixed-header &-body-inner { &-fixed-header &-body-inner {
height: 100%; height: 100%;
overflow: auto; overflow: scroll;
} }
@ -379,6 +379,12 @@ $table-move-in-color: $bg-color-base;
background: #ccc; background: #ccc;
cursor: col-resize; cursor: col-resize;
} }
&.th-can-not-drag{
.th-drag-gap-hover{
cursor: none;
width: 0px;
}
}
} }
&-th:last-child { &-th:last-child {
&-drag-gap{ &-drag-gap{

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);
this.drag.width = this.drag.data[this.drag.currIndex].width;
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'))) {
@ -109,6 +109,13 @@ class TableHeader extends Component {
} else { } else {
this.contentTableWidth = parseInt(contentTableDom.scrollWidth) this.contentTableWidth = parseInt(contentTableDom.scrollWidth)
} }
const dragColWidth = this.drag.data[this.drag.currIndex].width;
if(typeof(dragColWidth)=='string' && dragColWidth.indexOf('%')){
this.drag.width = this.contentTableWidth * parseInt(dragColWidth) /100
}else{
this.drag.width = parseInt(this.drag.data[this.drag.currIndex].width);
}
} }
onMouseUp = (event, data) => { onMouseUp = (event, data) => {
this.border = false; this.border = false;
@ -288,11 +295,13 @@ class TableHeader extends Component {
let thHover = da.drgHover ? ` ${clsPrefix}-thead th-drag-hover` : ""; let thHover = da.drgHover ? ` ${clsPrefix}-thead th-drag-hover` : "";
delete da.drgHover; delete da.drgHover;
let fixedStyle = ''; let fixedStyle = '';
let canDotDrag = '';
if (!fixed && da.fixed) { if (!fixed && da.fixed) {
fixedStyle = `${clsPrefix}-row-fixed-columns-in-body`; fixedStyle = `${clsPrefix}-row-fixed-columns-in-body`;
} }
if (lastShowIndex == i) { if (lastShowIndex == i) {
da.width = parseInt(da.width) + contentWidthDiff; da.width = parseInt(da.width) + contentWidthDiff;
canDotDrag = 'th-can-not-drag'
} }
if (draggable) { if (draggable) {
return (<th {...da} return (<th {...da}
@ -309,7 +318,7 @@ class TableHeader extends Component {
style={{ width: da.width }} style={{ width: da.width }}
onMouseMove={(event) => { this.onThMouseMove(event, da) }} onMouseMove={(event) => { this.onThMouseMove(event, da) }}
onMouseUp={(event) => { this.onThMouseUp(event, da) }} onMouseUp={(event) => { this.onThMouseUp(event, da) }}
className={`${da.className} ${clsPrefix}-thead-th ${fixedStyle}`} className={`${da.className} ${clsPrefix}-thead-th ${canDotDrag} ${fixedStyle}`}
key={i} > key={i} >
{da.children} {da.children}
<div ref={el => this.gap = el} <div ref={el => this.gap = el}