解决switch拖拽,拖拽改成插入

This commit is contained in:
cw 2019-08-05 17:23:38 +08:00
parent 8e4d5b88e8
commit d067cce97b
11 changed files with 177424 additions and 172484 deletions

View File

@ -436,8 +436,8 @@
-moz-user-select: -moz-none; -moz-user-select: -moz-none;
-khtml-user-select: none; -khtml-user-select: none;
-webkit-user-select: none; -webkit-user-select: none;
/* /*
Introduced in IE 10. Introduced in IE 10.
*/ */
-ms-user-select: none; -ms-user-select: none;
user-select: none; } user-select: none; }

View File

@ -230,7 +230,16 @@ var Table = function (_Component) {
}; };
_this.swapArray = function (arr, index1, index2) { _this.swapArray = function (arr, index1, index2) {
arr[index1] = arr.splice(index2, 1, arr[index1])[0]; var value1 = arr[index1];
arr.splice(index1, 1);
if (index1 < index2) {
console.log('向下拖');
arr.splice(index2, 0, value1);
} else {
console.log('向上拖');
arr.splice(index2 + 1, 0, value1);
}
// arr[index1] = arr.splice(index2, 1, arr[index1])[0];
return arr; return arr;
}; };

View File

@ -90,7 +90,7 @@ var TableRow = function (_Component) {
{ key: 'dragstart', fun: _this.onDragStart }, //用户开始拖动元素时触发 { key: 'dragstart', fun: _this.onDragStart }, //用户开始拖动元素时触发
{ key: 'dragover', fun: _this.onDragOver }, //当某被拖动的对象在另一对象容器范围内拖动时触发此事件 { key: 'dragover', fun: _this.onDragOver }, //当某被拖动的对象在另一对象容器范围内拖动时触发此事件
{ key: 'drop', fun: _this.onDrop }, //在一个拖动过程中,释放鼠标键时触发此事件 { key: 'drop', fun: _this.onDrop }, //在一个拖动过程中,释放鼠标键时触发此事件
{ key: 'dragenter', fun: _this.onDragEnter }, { key: 'dragleave', fun: _this.onDragLeave }]; { key: 'dragenter', fun: _this.onDragEnter }, { key: 'dragleave', fun: _this.onDragLeave }];
_this.eventListen(events, '', _this.element); _this.eventListen(events, '', _this.element);
}; };
@ -102,7 +102,7 @@ var TableRow = function (_Component) {
{ key: 'dragstart', fun: _this.onDragStart }, //用户开始拖动元素时触发 { key: 'dragstart', fun: _this.onDragStart }, //用户开始拖动元素时触发
{ key: 'dragover', fun: _this.onDragOver }, //当某被拖动的对象在另一对象容器范围内拖动时触发此事件 { key: 'dragover', fun: _this.onDragOver }, //当某被拖动的对象在另一对象容器范围内拖动时触发此事件
{ key: 'drop', fun: _this.onDrop }, //在一个拖动过程中,释放鼠标键时触发此事件 { key: 'drop', fun: _this.onDrop }, //在一个拖动过程中,释放鼠标键时触发此事件
{ key: 'dragenter', fun: _this.onDragEnter }, { key: 'dragleave', fun: _this.onDragLeave }]; { key: 'dragenter', fun: _this.onDragEnter }, { key: 'dragleave', fun: _this.onDragLeave }];
_this.eventListen(events, 'remove', _this.element); _this.eventListen(events, 'remove', _this.element);
}; };
@ -117,7 +117,7 @@ var TableRow = function (_Component) {
_this._dragCurrent = target; _this._dragCurrent = target;
//TODO 自定义图像后续需要增加。 //TODO 自定义图像后续需要增加。
// let crt = this.synchronizeTableTrShadow(); // let crt = this.synchronizeTableTrShadow();
// document.getElementById(this.props.tableUid).appendChild(crt); // document.getElementById(this.props.tableUid).appendChild(crt);
// event.dataTransfer.setDragImage(crt, 0, 0); // event.dataTransfer.setDragImage(crt, 0, 0);
event.dataTransfer.effectAllowed = "move"; event.dataTransfer.effectAllowed = "move";
@ -165,6 +165,10 @@ var TableRow = function (_Component) {
var event = _utils.Event.getEvent(e), var event = _utils.Event.getEvent(e),
_target = _utils.Event.getTarget(event), _target = _utils.Event.getTarget(event),
target = _target.parentNode; target = _target.parentNode;
while (target.tagName != 'TR') {
target = target.parentNode;
}
_this.currentIndex = target.getAttribute("data-row-key"); _this.currentIndex = target.getAttribute("data-row-key");
onDragRowStart && onDragRowStart(_this.currentIndex); onDragRowStart && onDragRowStart(_this.currentIndex);
@ -276,7 +280,7 @@ var TableRow = function (_Component) {
if (target.nodeName.toUpperCase() === "TR") { if (target.nodeName.toUpperCase() === "TR") {
_this.synchronizeTableTr(currentIndex, true); _this.synchronizeTableTr(currentIndex, true);
// target.setAttribute("style","border-bottom:2px dashed rgba(5,0,0,0.25)"); // target.setAttribute("style","border-bottom:2px dashed rgba(5,0,0,0.25)");
// // target.style.backgroundColor = 'rgb(235, 236, 240)'; // // target.style.backgroundColor = 'rgb(235, 236, 240)';
} }
}; };

View File

@ -1,7 +1,7 @@
'use strict'; 'use strict';
Object.defineProperty(exports, "__esModule", { Object.defineProperty(exports, "__esModule", {
value: true value: true
}); });
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
@ -35,126 +35,126 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
function dragColumn(Table) { function dragColumn(Table) {
return function (_Component) { return function (_Component) {
_inherits(DragColumn, _Component); _inherits(DragColumn, _Component);
function DragColumn(props) { function DragColumn(props) {
_classCallCheck(this, DragColumn); _classCallCheck(this, DragColumn);
var _this = _possibleConstructorReturn(this, _Component.call(this, props)); var _this = _possibleConstructorReturn(this, _Component.call(this, props));
_this.setColumOrderByIndex = function (_column) { _this.setColumOrderByIndex = function (_column) {
_column.forEach(function (da, i) { _column.forEach(function (da, i) {
da.dragIndex = i; da.dragIndex = i;
da.drgHover = false; da.drgHover = false;
}); });
return _column; return _column;
}; };
_this.onDrop = function (event, data) { _this.onDrop = function (event, data) {
var dragSource = data.dragSource, var dragSource = data.dragSource,
dragTarg = data.dragTarg; dragTarg = data.dragTarg;
var columns = _this.state.columns; var columns = _this.state.columns;
var sourceIndex = -1, var sourceIndex = -1,
targetIndex = -1; targetIndex = -1;
sourceIndex = columns.findIndex(function (da, i) { sourceIndex = columns.findIndex(function (da, i) {
return da.key == dragSource.key; return da.key == dragSource.key;
}); });
targetIndex = columns.findIndex(function (da, i) { targetIndex = columns.findIndex(function (da, i) {
return da.key == dragTarg.key; return da.key == dragTarg.key;
}); });
// 向前移动 // 向前移动
if (targetIndex < sourceIndex) { if (targetIndex < sourceIndex) {
targetIndex = targetIndex + 1; targetIndex = targetIndex + 1;
}
columns.splice(targetIndex, 0, columns.splice(sourceIndex, 1)[0]);
var _newColumns = [];
columns.forEach(function (da, i) {
var newDate = _extends(da, {});
newDate.title = da.title;
_newColumns.push(newDate);
});
// console.log(" onDrop-------columns--- ",columns);
_this.setState({
columns: _newColumns //cloneDeep(columns)
});
// console.log(" onDrop-------columns--- ",_newColumns);
// console.log(columns === _newColumns);
if (_this.props.onDrop) {
_this.props.onDrop(event, data, columns);
}
};
_this.getTarget = function (evt) {
return evt.target || evt.srcElement;
};
_this.state = {
columns: _this.setColumOrderByIndex(props.columns)
};
return _this;
} }
columns.splice(targetIndex, 0, columns.splice(sourceIndex, 1)[0]);
var _newColumns = []; DragColumn.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {
columns.forEach(function (da, i) { if (nextProps.columns != this.props.columns) {
var newDate = _extends(da, {}); this.setState({
newDate.title = da.title; columns: this.setColumOrderByIndex(nextProps.columns)
_newColumns.push(newDate); });
}
};
DragColumn.prototype.recursion = function (_recursion) {
function recursion(_x) {
return _recursion.apply(this, arguments);
}
recursion.toString = function () {
return _recursion.toString();
};
return recursion;
}(function (obj) {
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
for (key in obj) {
if (_typeof(obj[key]) == 'object' && Object.keys(obj[key].length > 0)) {
data[key] = recursion(obj[key]);
} else {
data[key] = obj[key];
}
}
return data;
}); });
// console.log(" onDrop-------columns--- ",columns);
_this.setState({
columns: _newColumns //cloneDeep(columns)
});
// console.log(" onDrop-------columns--- ",_newColumns);
// console.log(columns === _newColumns);
if (_this.props.onDrop) {
_this.props.onDrop(event, data, columns);
}
};
_this.getTarget = function (evt) { DragColumn.prototype.render = function render() {
return evt.target || evt.srcElement; var _props = this.props,
}; data = _props.data,
dragborder = _props.dragborder,
draggable = _props.draggable,
className = _props.className,
columns = _props.columns,
onDragStart = _props.onDragStart,
onDragEnter = _props.onDragEnter,
onDragOver = _props.onDragOver,
onDrop = _props.onDrop,
others = _objectWithoutProperties(_props, ['data', 'dragborder', 'draggable', 'className', 'columns', 'onDragStart', 'onDragEnter', 'onDragOver', 'onDrop']);
_this.state = { return _react2["default"].createElement(Table, _extends({}, others, {
columns: _this.setColumOrderByIndex(props.columns) columns: this.state.columns,
}; data: data,
return _this; className: className + ' u-table-drag-border',
} onDragStart: this.onDragStart,
onDragOver: this.onDragOver,
onDrop: this.onDrop,
onDragEnter: this.onDragEnter,
draggable: draggable,
dragborder: dragborder
}));
};
DragColumn.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) { return DragColumn;
if (nextProps.columns != this.props.columns) { }(_react.Component);
this.setState({
columns: this.setColumOrderByIndex(nextProps.columns)
});
}
};
DragColumn.prototype.recursion = function (_recursion) {
function recursion(_x) {
return _recursion.apply(this, arguments);
}
recursion.toString = function () {
return _recursion.toString();
};
return recursion;
}(function (obj) {
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
for (key in obj) {
if (_typeof(obj[key]) == 'object' && Object.keys(obj[key].length > 0)) {
data[key] = recursion(obj[key]);
} else {
data[key] = obj[key];
}
}
return data;
});
DragColumn.prototype.render = function render() {
var _props = this.props,
data = _props.data,
dragborder = _props.dragborder,
draggable = _props.draggable,
className = _props.className,
columns = _props.columns,
onDragStart = _props.onDragStart,
onDragEnter = _props.onDragEnter,
onDragOver = _props.onDragOver,
onDrop = _props.onDrop,
others = _objectWithoutProperties(_props, ['data', 'dragborder', 'draggable', 'className', 'columns', 'onDragStart', 'onDragEnter', 'onDragOver', 'onDrop']);
return _react2["default"].createElement(Table, _extends({}, others, {
columns: this.state.columns,
data: data,
className: className + ' u-table-drag-border',
onDragStart: this.onDragStart,
onDragOver: this.onDragOver,
onDrop: this.onDrop,
onDragEnter: this.onDragEnter,
draggable: draggable,
dragborder: dragborder
}));
};
return DragColumn;
}(_react.Component);
} }
module.exports = exports['default']; module.exports = exports['default'];

View File

@ -1,7 +1,7 @@
'use strict'; 'use strict';
Object.defineProperty(exports, "__esModule", { Object.defineProperty(exports, "__esModule", {
value: true value: true
}); });
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
@ -20,29 +20,29 @@ exports.ObjectAssign = ObjectAssign;
*/ */
function sortBy(arr, prop, desc) { function sortBy(arr, prop, desc) {
var props = [], var props = [],
ret = [], ret = [],
i = 0, i = 0,
len = arr.length; len = arr.length;
if (typeof prop == 'string') { if (typeof prop == 'string') {
for (; i < len; i++) { for (; i < len; i++) {
var oI = arr[i]; var oI = arr[i];
(props[i] = new String(oI && oI[prop] || ''))._obj = oI; (props[i] = new String(oI && oI[prop] || ''))._obj = oI;
}
} else if (typeof prop == 'function') {
for (; i < len; i++) {
var _oI = arr[i];
(props[i] = new String(_oI && prop(_oI) || ''))._obj = _oI;
}
} else {
throw '参数类型错误';
} }
props.sort(); } else if (typeof prop == 'function') {
for (i = 0; i < len; i++) { for (; i < len; i++) {
ret[i] = props[i]._obj; var _oI = arr[i];
(props[i] = new String(_oI && prop(_oI) || ''))._obj = _oI;
} }
if (desc) ret.reverse(); } else {
return ret; throw '参数类型错误';
}
props.sort();
for (i = 0; i < len; i++) {
ret[i] = props[i]._obj;
}
if (desc) ret.reverse();
return ret;
}; };
/** /**
@ -51,11 +51,11 @@ function sortBy(arr, prop, desc) {
* @param {} property * @param {} property
*/ */
function compare(property) { function compare(property) {
return function (a, b) { return function (a, b) {
var value1 = a[property]; var value1 = a[property];
var value2 = b[property]; var value2 = b[property];
return value1 - value2; return value1 - value2;
}; };
} }
/** /**
@ -63,17 +63,17 @@ function compare(property) {
* @param {*} obj 要拷贝的对象 * @param {*} obj 要拷贝的对象
*/ */
function ObjectAssign(obj) { function ObjectAssign(obj) {
var b = obj instanceof Array; var b = obj instanceof Array;
var tagObj = b ? [] : {}; var tagObj = b ? [] : {};
if (b) { if (b) {
//数组 //数组
obj.forEach(function (da) { obj.forEach(function (da) {
var _da = {}; var _da = {};
_extends(_da, da); _extends(_da, da);
tagObj.push(_da); tagObj.push(_da);
}); });
} else { } else {
_extends(tagObj, obj); _extends(tagObj, obj);
} }
return tagObj; return tagObj;
} }

4
dist/demo.css vendored
View File

@ -428,8 +428,8 @@
background-clip: padding-box; background-clip: padding-box;
-moz-user-select: -moz-none; -moz-user-select: -moz-none;
-webkit-user-select: none; -webkit-user-select: none;
/* /*
Introduced in IE 10. Introduced in IE 10.
*/ */
-ms-user-select: none; -ms-user-select: none;
user-select: none; } user-select: none; }

2
dist/demo.css.map vendored

File diff suppressed because one or more lines are too long

349425
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

@ -214,7 +214,7 @@ class Table extends Component {
this.scrollbarWidth = measureScrollbar(); this.scrollbarWidth = measureScrollbar();
} }
// console.log('this.scrollTop**********',this.scrollTop); // console.log('this.scrollTop**********',this.scrollTop);
} }
@ -238,7 +238,7 @@ class Table extends Component {
if (prevProps.data.length === 0 || this.props.data.length === 0 ) { if (prevProps.data.length === 0 || this.props.data.length === 0 ) {
this.resetScrollX(); this.resetScrollX();
} }
// 是否传入 scroll中的y属性如果传入判断是否是整数如果是则进行比较 。bodyTable 的clientHeight进行判断 // 是否传入 scroll中的y属性如果传入判断是否是整数如果是则进行比较 。bodyTable 的clientHeight进行判断
this.isShowScrollY(); this.isShowScrollY();
} }
@ -272,7 +272,7 @@ class Table extends Component {
} }
computeTableWidth() { computeTableWidth() {
//如果用户传了scroll.x按用户传的为主 //如果用户传了scroll.x按用户传的为主
let setWidthParam = this.props.scroll.x let setWidthParam = this.props.scroll.x
@ -285,7 +285,7 @@ class Table extends Component {
this.contentDomWidth = this.contentTable.getBoundingClientRect().width//表格容器宽度 this.contentDomWidth = this.contentTable.getBoundingClientRect().width//表格容器宽度
this.contentWidth = this.contentDomWidth;//默认与容器宽度一样 this.contentWidth = this.contentDomWidth;//默认与容器宽度一样
} }
const computeObj = this.columnManager.getColumnWidth(this.contentWidth); const computeObj = this.columnManager.getColumnWidth(this.contentWidth);
let lastShowIndex = computeObj.lastShowIndex; let lastShowIndex = computeObj.lastShowIndex;
@ -320,7 +320,7 @@ class Table extends Component {
// const leftBodyTable = this.refs.fixedColumnsBodyLeft; // const leftBodyTable = this.refs.fixedColumnsBodyLeft;
const overflowy = bodyContentH <= bodyH ? 'auto':'scroll'; const overflowy = bodyContentH <= bodyH ? 'auto':'scroll';
this.bodyTable.style.overflowY = overflowy; this.bodyTable.style.overflowY = overflowy;
this.headTable.style.overflowY = overflowy; this.headTable.style.overflowY = overflowy;
rightBodyTable && (rightBodyTable.style.overflowY = overflowy); rightBodyTable && (rightBodyTable.style.overflowY = overflowy);
// 没有纵向滚动条时,表头横向滚动条根据内容动态显示 待验证 // 没有纵向滚动条时,表头横向滚动条根据内容动态显示 待验证
@ -329,8 +329,8 @@ class Table extends Component {
// rightBodyTable && (rightBodyTable.style.overflowX = 'auto'); // rightBodyTable && (rightBodyTable.style.overflowX = 'auto');
// leftBodyTable && (leftBodyTable.style.overflowX = 'auto'); // leftBodyTable && (leftBodyTable.style.overflowX = 'auto');
// } // }
} }
} }
onExpandedRowsChange(expandedRowKeys) { onExpandedRowsChange(expandedRowKeys) {
@ -386,7 +386,7 @@ class Table extends Component {
); );
return key; return key;
} }
getExpandedRows() { getExpandedRows() {
@ -561,7 +561,7 @@ class Table extends Component {
indent={1} indent={1}
expandable={false} expandable={false}
store={this.store} store={this.store}
dragborderKey={this.props.dragborderKey} dragborderKey={this.props.dragborderKey}
rowDraggAble={this.props.rowDraggAble} rowDraggAble={this.props.rowDraggAble}
onDragRow={this.onDragRow} onDragRow={this.onDragRow}
onDragRowStart={this.onDragRowStart} onDragRowStart={this.onDragRowStart}
@ -575,7 +575,7 @@ class Table extends Component {
*/ */
onDragRowStart = (currentKey) => { onDragRowStart = (currentKey) => {
let {data} = this.state,currentIndex,record; let {data} = this.state,currentIndex,record;
data.forEach((da,i)=>{ data.forEach((da,i)=>{
// tr 的唯一标识通过 data.key 或 rowKey 两种方式传进来 // tr 的唯一标识通过 data.key 或 rowKey 两种方式传进来
let trKey = da.key ? da.key : this.getRowKey(da, i); let trKey = da.key ? da.key : this.getRowKey(da, i);
if(trKey == currentKey){ if(trKey == currentKey){
@ -617,7 +617,17 @@ class Table extends Component {
* @param {number} index2 删除项目的位置 * @param {number} index2 删除项目的位置
*/ */
swapArray = (arr, index1, index2) => { swapArray = (arr, index1, index2) => {
arr[index1] = arr.splice(index2, 1, arr[index1])[0]; var value1 = arr[index1]
arr.splice(index1,1)
if(index1<index2){
console.log('向下拖')
arr.splice(index2,0,value1)
}else {
console.log('向上拖')
arr.splice(index2+1,0,value1)
}
return arr; return arr;
} }
@ -681,13 +691,13 @@ class Table extends Component {
if (expandedRowRender && typeof props.haveExpandIcon == 'function') { if (expandedRowRender && typeof props.haveExpandIcon == 'function') {
isHiddenExpandIcon = props.haveExpandIcon(record, i); isHiddenExpandIcon = props.haveExpandIcon(record, i);
} }
const onHoverProps = {}; const onHoverProps = {};
onHoverProps.onHover = this.handleRowHover; onHoverProps.onHover = this.handleRowHover;
if (props.height) { if (props.height) {
height = props.height height = props.height
@ -709,7 +719,7 @@ class Table extends Component {
if(i == data.length -1 && props.showSum){ if(i == data.length -1 && props.showSum){
className = className + ' sumrow'; className = className + ' sumrow';
} }
let paramRootIndex = rootIndex; let paramRootIndex = rootIndex;
//小于0说明为第一层节点她的子孙节点要保存自己的根节点 //小于0说明为第一层节点她的子孙节点要保存自己的根节点
if(paramRootIndex<0){ if(paramRootIndex<0){
@ -801,7 +811,7 @@ class Table extends Component {
getColGroup(columns, fixed) { getColGroup(columns, fixed) {
let cols = []; let cols = [];
let self = this; let self = this;
let { contentWidthDiff = 0, lastShowIndex = 0 } = this.state; let { contentWidthDiff = 0, lastShowIndex = 0 } = this.state;
if (this.props.expandIconAsCell && fixed !== 'right') { if (this.props.expandIconAsCell && fixed !== 'right') {
cols.push( cols.push(
@ -909,7 +919,7 @@ class Table extends Component {
//显示表头滚动条 //显示表头滚动条
if(headerScroll){ if(headerScroll){
if(fixed){ if(fixed){
if(this.domWidthDiff <= 0){ if(this.domWidthDiff <= 0){
headStyle.marginBottom = `${scrollbarWidth}px`; headStyle.marginBottom = `${scrollbarWidth}px`;
bodyStyle.marginBottom = `-${scrollbarWidth}px`; bodyStyle.marginBottom = `-${scrollbarWidth}px`;
@ -931,7 +941,7 @@ class Table extends Component {
}else{ }else{
bodyStyle.marginBottom = `-${scrollbarWidth}px`; bodyStyle.marginBottom = `-${scrollbarWidth}px`;
} }
}else{ }else{
// 没有数据时,表头滚动条隐藏问题 // 没有数据时,表头滚动条隐藏问题
if(data.length == 0 && this.domWidthDiff < 0){ if(data.length == 0 && this.domWidthDiff < 0){
@ -939,14 +949,14 @@ class Table extends Component {
}else{ }else{
headStyle.marginBottom = `-${scrollbarWidth}px`; headStyle.marginBottom = `-${scrollbarWidth}px`;
} }
} }
} }
} }
} }
if(data.length == 0 && hideHeaderScroll){ if(data.length == 0 && hideHeaderScroll){
//支持 NCC 需求:表格无数据时,去掉表头滚动条 (https://github.com/iuap-design/tinper-bee/issues/207) //支持 NCC 需求:表格无数据时,去掉表头滚动条 (https://github.com/iuap-design/tinper-bee/issues/207)
headStyle.marginBottom = `-${this.scrollbarWidth}px`; headStyle.marginBottom = `-${this.scrollbarWidth}px`;
} }
@ -1103,8 +1113,8 @@ class Table extends Component {
const leftBodyRows = this.refs.fixedColumnsBodyLeft && this.refs.fixedColumnsBodyLeft.querySelectorAll(`.${clsPrefix}-row`) || []; const leftBodyRows = this.refs.fixedColumnsBodyLeft && this.refs.fixedColumnsBodyLeft.querySelectorAll(`.${clsPrefix}-row`) || [];
const rightBodyRows = this.refs.fixedColumnsBodyRight && this.refs.fixedColumnsBodyRight.querySelectorAll(`.${clsPrefix}-row`) || []; const rightBodyRows = this.refs.fixedColumnsBodyRight && this.refs.fixedColumnsBodyRight.querySelectorAll(`.${clsPrefix}-row`) || [];
const fixedColumnsHeadRowsHeight = [].map.call( const fixedColumnsHeadRowsHeight = [].map.call(
headRows, row =>{ headRows, row =>{
let height = headerHeight; let height = headerHeight;
if(headerHeight){ if(headerHeight){
height = (getMaxColChildrenLength(columns)+1)*headerHeight; height = (getMaxColChildrenLength(columns)+1)*headerHeight;
} }
@ -1128,11 +1138,11 @@ class Table extends Component {
return row.getBoundingClientRect().height || 'auto' return row.getBoundingClientRect().height || 'auto'
} }
} }
} }
); );
if (shallowequal(this.state.fixedColumnsHeadRowsHeight, fixedColumnsHeadRowsHeight) && if (shallowequal(this.state.fixedColumnsHeadRowsHeight, fixedColumnsHeadRowsHeight) &&
shallowequal(this.state.fixedColumnsBodyRowsHeight, fixedColumnsBodyRowsHeight)) { shallowequal(this.state.fixedColumnsBodyRowsHeight, fixedColumnsBodyRowsHeight)) {
return; return;
@ -1172,10 +1182,10 @@ class Table extends Component {
hideHoverDom(e){ hideHoverDom(e){
if(this.hoverDom){ if(this.hoverDom){
this.hoverDom.style.display = 'none'; this.hoverDom.style.display = 'none';
} }
} }
handleBodyScroll(e) { handleBodyScroll(e) {
const headTable = this.headTable; const headTable = this.headTable;
@ -1233,9 +1243,9 @@ class Table extends Component {
handleScrollY(this.lastScrollTop,this.treeType), handleScrollY(this.lastScrollTop,this.treeType),
300) 300)
} }
} }
// Remember last scrollLeft for scroll direction detecting. // Remember last scrollLeft for scroll direction detecting.
this.lastScrollLeft = e.target.scrollLeft; this.lastScrollLeft = e.target.scrollLeft;
} }
@ -1259,7 +1269,7 @@ class Table extends Component {
const scrollTop = this.lastScrollTop ?this.lastScrollTop:0 const scrollTop = this.lastScrollTop ?this.lastScrollTop:0
let top = td.offsetTop - scrollTop; let top = td.offsetTop - scrollTop;
if(this.headTable){ if(this.headTable){
top = top + this.headTable.clientHeight; top = top + this.headTable.clientHeight;
} }
this.hoverDom.style.top = top + 'px'; this.hoverDom.style.top = top + 'px';
this.hoverDom.style.height = td.offsetHeight + 'px'; this.hoverDom.style.height = td.offsetHeight + 'px';
@ -1267,7 +1277,7 @@ class Table extends Component {
this.hoverDom.style.display = 'block'; this.hoverDom.style.display = 'block';
} }
} }
} }
onRowHover && onRowHover(currentIndex,record); onRowHover && onRowHover(currentIndex,record);
@ -1280,7 +1290,7 @@ class Table extends Component {
currentHoverKey: this.currentHoverKey, currentHoverKey: this.currentHoverKey,
}); });
this.hoverDom.style.display = 'block'; this.hoverDom.style.display = 'block';
} }
onRowHoverMouseLeave = () =>{ onRowHoverMouseLeave = () =>{
@ -1290,7 +1300,7 @@ class Table extends Component {
} }
onKeyDown=(e)=>{ onKeyDown=(e)=>{
let event = Event.getEvent(e); let event = Event.getEvent(e);
// event.preventDefault?event.preventDefault():event.returnValue = false; // event.preventDefault?event.preventDefault():event.returnValue = false;
if(event.keyCode === 38){//up if(event.keyCode === 38){//up
event.preventDefault&&event.preventDefault(); event.preventDefault&&event.preventDefault();
@ -1344,11 +1354,11 @@ class Table extends Component {
} }
return ( return (
<div className={className} style={props.style} ref={el => this.contentTable = el} <div className={className} style={props.style} ref={el => this.contentTable = el}
tabIndex={props.focusable && (props.tabIndex?props.tabIndex:'0')} > tabIndex={props.focusable && (props.tabIndex?props.tabIndex:'0')} >
{this.getTitle()} {this.getTitle()}
<div className={`${clsPrefix}-content`}> <div className={`${clsPrefix}-content`}>
<div className={isTableScroll ? `${clsPrefix}-scroll` : ''} > <div className={isTableScroll ? `${clsPrefix}-scroll` : ''} >
{this.getTable({ columns: this.columnManager.groupedColumns() })} {this.getTable({ columns: this.columnManager.groupedColumns() })}
{this.getEmptyText()} {this.getEmptyText()}

View File

@ -80,7 +80,7 @@ class TableRow extends Component{
this.setRowParentIndex(); this.setRowParentIndex();
} }
} }
/** /**
* 事件初始化 * 事件初始化
*/ */
@ -92,7 +92,7 @@ class TableRow extends Component{
{key:'dragstart',fun:this.onDragStart},//用户开始拖动元素时触发 {key:'dragstart',fun:this.onDragStart},//用户开始拖动元素时触发
{key:'dragover', fun:this.onDragOver},//当某被拖动的对象在另一对象容器范围内拖动时触发此事件 {key:'dragover', fun:this.onDragOver},//当某被拖动的对象在另一对象容器范围内拖动时触发此事件
{key:'drop', fun:this.onDrop}, //在一个拖动过程中,释放鼠标键时触发此事件 {key:'drop', fun:this.onDrop}, //在一个拖动过程中,释放鼠标键时触发此事件
{key:'dragenter', fun:this.onDragEnter}, {key:'dragenter', fun:this.onDragEnter},
{key:'dragleave', fun:this.onDragLeave}, {key:'dragleave', fun:this.onDragLeave},
]; ];
@ -110,7 +110,7 @@ class TableRow extends Component{
{key:'dragstart',fun:this.onDragStart},//用户开始拖动元素时触发 {key:'dragstart',fun:this.onDragStart},//用户开始拖动元素时触发
{key:'dragover', fun:this.onDragOver},//当某被拖动的对象在另一对象容器范围内拖动时触发此事件 {key:'dragover', fun:this.onDragOver},//当某被拖动的对象在另一对象容器范围内拖动时触发此事件
{key:'drop', fun:this.onDrop}, //在一个拖动过程中,释放鼠标键时触发此事件 {key:'drop', fun:this.onDrop}, //在一个拖动过程中,释放鼠标键时触发此事件
{key:'dragenter', fun:this.onDragEnter}, {key:'dragenter', fun:this.onDragEnter},
{key:'dragleave', fun:this.onDragLeave}, {key:'dragleave', fun:this.onDragLeave},
]; ];
@ -142,9 +142,9 @@ class TableRow extends Component{
target = Event.getTarget(event); target = Event.getTarget(event);
this.currentIndex = target.getAttribute("data-row-key"); this.currentIndex = target.getAttribute("data-row-key");
this._dragCurrent = target; this._dragCurrent = target;
//TODO 自定义图像后续需要增加。 //TODO 自定义图像后续需要增加。
// let crt = this.synchronizeTableTrShadow(); // let crt = this.synchronizeTableTrShadow();
// document.getElementById(this.props.tableUid).appendChild(crt); // document.getElementById(this.props.tableUid).appendChild(crt);
// event.dataTransfer.setDragImage(crt, 0, 0); // event.dataTransfer.setDragImage(crt, 0, 0);
event.dataTransfer.effectAllowed = "move"; event.dataTransfer.effectAllowed = "move";
@ -157,7 +157,7 @@ class TableRow extends Component{
let event = Event.getEvent(e); let event = Event.getEvent(e);
event.preventDefault(); event.preventDefault();
}; };
/** /**
* 在一个拖动过程中释放鼠标键时触发此事件目标事件 * 在一个拖动过程中释放鼠标键时触发此事件目标事件
* @memberof TableHeader * @memberof TableHeader
@ -167,13 +167,13 @@ class TableRow extends Component{
let event = Event.getEvent(e) , let event = Event.getEvent(e) ,
_target = Event.getTarget(event), _target = Event.getTarget(event),
target = _target.parentNode; target = _target.parentNode;
let currentKey = event.dataTransfer.getData("text"); let currentKey = event.dataTransfer.getData("text");
let targetKey = target.getAttribute("data-row-key"); let targetKey = target.getAttribute("data-row-key");
if(!targetKey || targetKey === currentKey)return; if(!targetKey || targetKey === currentKey)return;
if(target.nodeName.toUpperCase() === "TR"){ if(target.nodeName.toUpperCase() === "TR"){
this.synchronizeTableTr(currentKey,null); this.synchronizeTableTr(currentKey,null);
this.synchronizeTableTr(targetKey,null); this.synchronizeTableTr(targetKey,null);
// target.setAttribute("style",""); // target.setAttribute("style","");
// this.synchronizeTrStyle(this.currentIndex,false); // this.synchronizeTrStyle(this.currentIndex,false);
@ -198,6 +198,10 @@ class TableRow extends Component{
let event = Event.getEvent(e) , let event = Event.getEvent(e) ,
_target = Event.getTarget(event), _target = Event.getTarget(event),
target = _target.parentNode; target = _target.parentNode;
while (target.tagName != 'TR') {
target = target.parentNode
}
this.currentIndex = target.getAttribute("data-row-key"); this.currentIndex = target.getAttribute("data-row-key");
onDragRowStart && onDragRowStart(this.currentIndex); onDragRowStart && onDragRowStart(this.currentIndex);
@ -228,12 +232,12 @@ class TableRow extends Component{
touchTarget = this.getTouchDom(event), //当前触摸的DOM节点 touchTarget = this.getTouchDom(event), //当前触摸的DOM节点
target = touchTarget.parentNode, //目标位置的行 target = touchTarget.parentNode, //目标位置的行
targetKey = target.getAttribute("data-row-key"); //目标位置的行key targetKey = target.getAttribute("data-row-key"); //目标位置的行key
if(!targetKey || targetKey === currentKey)return; if(!targetKey || targetKey === currentKey)return;
if(target.nodeName.toUpperCase() === "TR"){ if(target.nodeName.toUpperCase() === "TR"){
this.synchronizeTableTr(currentKey,null); this.synchronizeTableTr(currentKey,null);
this.synchronizeTableTr(targetKey,null); this.synchronizeTableTr(targetKey,null);
} }
onDragRow && onDragRow(currentKey,targetKey); onDragRow && onDragRow(currentKey,targetKey);
} }
@ -242,7 +246,7 @@ class TableRow extends Component{
* @memberof TableRow * @memberof TableRow
*/ */
synchronizeTableTrShadow = ()=>{ synchronizeTableTrShadow = ()=>{
let {contentTable,index} = this.props; let {contentTable,index} = this.props;
let cont = contentTable.querySelector('.u-table-scroll table tbody').getElementsByTagName("tr")[index], let cont = contentTable.querySelector('.u-table-scroll table tbody').getElementsByTagName("tr")[index],
trs = cont.getBoundingClientRect(), trs = cont.getBoundingClientRect(),
@ -250,7 +254,7 @@ class TableRow extends Component{
fixed_right_trs = contentTable.querySelector('.u-table-fixed-right table tbody'); fixed_right_trs = contentTable.querySelector('.u-table-fixed-right table tbody');
fixed_left_trs = fixed_left_trs && fixed_left_trs.getElementsByTagName("tr")[index].getBoundingClientRect(); fixed_left_trs = fixed_left_trs && fixed_left_trs.getElementsByTagName("tr")[index].getBoundingClientRect();
fixed_right_trs = fixed_right_trs && fixed_right_trs.getElementsByTagName("tr")[index].getBoundingClientRect() fixed_right_trs = fixed_right_trs && fixed_right_trs.getElementsByTagName("tr")[index].getBoundingClientRect()
let div = document.createElement("div"); let div = document.createElement("div");
let style = "wdith:"+(trs.width + (fixed_left_trs ? fixed_left_trs.width : 0) + (fixed_right_trs ? fixed_right_trs.width : 0))+"px"; let style = "wdith:"+(trs.width + (fixed_left_trs ? fixed_left_trs.width : 0) + (fixed_right_trs ? fixed_right_trs.width : 0))+"px";
style += ";height:"+ trs.height+"px"; style += ";height:"+ trs.height+"px";
@ -265,13 +269,13 @@ class TableRow extends Component{
*/ */
synchronizeTableTr = (currentIndex,type)=>{ synchronizeTableTr = (currentIndex,type)=>{
if(type){ //同步 this.cacheCurrentIndex if(type){ //同步 this.cacheCurrentIndex
this.cacheCurrentIndex = currentIndex; this.cacheCurrentIndex = currentIndex;
} }
let {contentTable} = this.props; let {contentTable} = this.props;
let _table_trs = contentTable.querySelector('.u-table-scroll table tbody'), let _table_trs = contentTable.querySelector('.u-table-scroll table tbody'),
_table_fixed_left_trs = contentTable.querySelector('.u-table-fixed-left table tbody'), _table_fixed_left_trs = contentTable.querySelector('.u-table-fixed-left table tbody'),
_table_fixed_right_trs = contentTable.querySelector('.u-table-fixed-right table tbody'); _table_fixed_right_trs = contentTable.querySelector('.u-table-fixed-right table tbody');
_table_trs = _table_trs?_table_trs:contentTable.querySelector('.u-table table tbody'); _table_trs = _table_trs?_table_trs:contentTable.querySelector('.u-table table tbody');
this.synchronizeTrStyle(_table_trs,currentIndex,type); this.synchronizeTrStyle(_table_trs,currentIndex,type);
@ -289,7 +293,7 @@ class TableRow extends Component{
synchronizeTrStyle = (_elementBody,id,type)=>{ synchronizeTrStyle = (_elementBody,id,type)=>{
let {contentTable} = this.props, let {contentTable} = this.props,
trs = _elementBody.getElementsByTagName("tr"), trs = _elementBody.getElementsByTagName("tr"),
currentObj; currentObj;
for (let index = 0; index < trs.length; index++) { for (let index = 0; index < trs.length; index++) {
const element = trs[index]; const element = trs[index];
if(element.getAttribute("data-row-key") == id){ if(element.getAttribute("data-row-key") == id){
@ -311,16 +315,16 @@ class TableRow extends Component{
if(target.nodeName.toUpperCase() === "TR"){ if(target.nodeName.toUpperCase() === "TR"){
this.synchronizeTableTr(currentIndex,true); this.synchronizeTableTr(currentIndex,true);
// target.setAttribute("style","border-bottom:2px dashed rgba(5,0,0,0.25)"); // target.setAttribute("style","border-bottom:2px dashed rgba(5,0,0,0.25)");
// // target.style.backgroundColor = 'rgb(235, 236, 240)'; // // target.style.backgroundColor = 'rgb(235, 236, 240)';
} }
} }
onDragLeave = (e) => { onDragLeave = (e) => {
let event = Event.getEvent(e) , let event = Event.getEvent(e) ,
_target = Event.getTarget(event),target = _target.parentNode; _target = Event.getTarget(event),target = _target.parentNode;
let currentIndex = target.getAttribute("data-row-key"); let currentIndex = target.getAttribute("data-row-key");
if(!currentIndex || currentIndex === this.currentIndex)return; if(!currentIndex || currentIndex === this.currentIndex)return;
if(target.nodeName.toUpperCase() === "TR"){ if(target.nodeName.toUpperCase() === "TR"){
this.synchronizeTableTr(currentIndex,null); this.synchronizeTableTr(currentIndex,null);
} }
} }
@ -339,7 +343,7 @@ class TableRow extends Component{
} }
this.setRowHeight() this.setRowHeight()
} }
componentWillUnmount() { componentWillUnmount() {
const { record, onDestroy, index,rowDraggAble } = this.props; const { record, onDestroy, index,rowDraggAble } = this.props;
onDestroy(record, index); onDestroy(record, index);
@ -362,7 +366,7 @@ class TableRow extends Component{
setRowParentIndex(rootIndex<0?index:rootIndex,fixedIndex); setRowParentIndex(rootIndex<0?index:rootIndex,fixedIndex);
} }
onRowClick(event) { onRowClick(event) {
// fix: 解决 onRowClick 回调函数中,事件对象属性均为 null 的问题 // fix: 解决 onRowClick 回调函数中,事件对象属性均为 null 的问题
// 异步访问事件属性 // 异步访问事件属性
@ -381,7 +385,7 @@ class TableRow extends Component{
if (expandable && expandRowByClick) { if (expandable && expandRowByClick) {
onExpand(!expanded, record, fixedIndex,event); onExpand(!expanded, record, fixedIndex,event);
} }
this.set((e)=> { this.set((e)=> {
onRowClick(record, fixedIndex, event); onRowClick(record, fixedIndex, event);
}); });
} }
@ -411,19 +415,19 @@ class TableRow extends Component{
set =(fn)=> { set =(fn)=> {
this.clear(); this.clear();
this._timeout = window.setTimeout(fn, 300); this._timeout = window.setTimeout(fn, 300);
} }
clear =(event)=> { clear =(event)=> {
if (this._timeout) { if (this._timeout) {
window.clearTimeout(this._timeout); window.clearTimeout(this._timeout);
} }
} }
bindElement = (el)=> { bindElement = (el)=> {
this.element = el this.element = el
} }
render() { render() {
const { const {
clsPrefix, columns, record, height, visible, index, clsPrefix, columns, record, height, visible, index,
@ -492,7 +496,7 @@ class TableRow extends Component{
style.display = 'none'; style.display = 'none';
} }
return ( return (
<tr <tr
draggable={rowDraggAble} draggable={rowDraggAble}
onClick={this.onRowClick} onClick={this.onRowClick}