修改lib 文件夹下util.js路径
This commit is contained in:
parent
acb1a72bb8
commit
67983948a9
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -1,6 +1,6 @@
|
||||||
import React, { Component } from "react";
|
import React, { Component } from "react";
|
||||||
import {compare} from './util';
|
import {compare} from './util';
|
||||||
import {ObjectAssign} from '../utils';
|
import {ObjectAssign} from '../util';
|
||||||
/**
|
/**
|
||||||
* 参数: 列拖拽
|
* 参数: 列拖拽
|
||||||
* @param {*} Table
|
* @param {*} Table
|
||||||
|
|
|
@ -1,14 +1,16 @@
|
||||||
import React, { Component } from "react";
|
import React, { Component } from "react";
|
||||||
import {compare} from './util';
|
import {compare} from './util';
|
||||||
import {ObjectAssign} from '../utils';
|
import {ObjectAssign} from '../util';
|
||||||
/**
|
/**
|
||||||
* 参数: 列拖拽
|
* 参数: 列拖拽
|
||||||
* @param {*} Table
|
* @param {*} Table
|
||||||
*/
|
*/
|
||||||
|
// 0、定义一个拖拽dom
|
||||||
|
// 1、当移动到表头可以显示当前操作列的move图标。
|
||||||
|
// 2、添加start、move事件、drop事件
|
||||||
|
export default function dragWidthColumn(Table) {
|
||||||
|
|
||||||
export default function dragColumn(Table) {
|
return class DragWidthColumn extends Component {
|
||||||
|
|
||||||
return class DragColumn extends Component {
|
|
||||||
|
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props);
|
super(props);
|
||||||
|
@ -47,46 +49,11 @@ export default function dragColumn(Table) {
|
||||||
}
|
}
|
||||||
|
|
||||||
onDragEnter=(event,data)=>{
|
onDragEnter=(event,data)=>{
|
||||||
if(data.key == "checkbox")return;
|
|
||||||
const {columns:_columns} = this.state;
|
|
||||||
let columns = [];
|
|
||||||
Object.assign(columns,_columns);
|
|
||||||
columns.forEach((da)=>da.drgHover = false)
|
|
||||||
let current = columns.find((da)=>da.key == data.key);
|
|
||||||
if(current.fixed)return;
|
|
||||||
current.drgHover = true;
|
|
||||||
this.setState({
|
|
||||||
columns
|
|
||||||
});
|
|
||||||
if(this.props.onDragEnter){
|
|
||||||
this.props.onDragEnter(event,data);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
onDrop=(event,data)=>{
|
onDrop=(event,data)=>{
|
||||||
if(data.key == "checkbox")return;
|
|
||||||
let {columns} = this.state;
|
|
||||||
const id = event.dataTransfer.getData("Text");
|
|
||||||
let objIndex = columns.findIndex((_da,i)=>_da.key == id);
|
|
||||||
let targetIndex = columns.findIndex((_da,i)=>_da.key == data.key);
|
|
||||||
if(columns[objIndex].fixed)return;//固定列不让拖拽
|
|
||||||
if(columns[targetIndex].fixed)return;//固定列不让拖拽
|
|
||||||
columns.forEach((da,i)=>{
|
|
||||||
da.drgHover = false;
|
|
||||||
if(da.key == id){//obj
|
|
||||||
da.dragIndex = targetIndex
|
|
||||||
}
|
|
||||||
if(da.key == data.key){//targetObj
|
|
||||||
da.dragIndex = objIndex;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
let _columns = columns.sort(compare('dragIndex'));
|
|
||||||
this.setState({
|
|
||||||
columns: JSON.parse(JSON.stringify(_columns)),
|
|
||||||
});
|
|
||||||
if(this.props.onDrop){
|
|
||||||
this.props.onDrop(event,data);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
getTarget=(evt)=>{
|
getTarget=(evt)=>{
|
||||||
|
@ -113,10 +80,10 @@ export default function dragColumn(Table) {
|
||||||
columns={this.state.columns}
|
columns={this.state.columns}
|
||||||
data={data}
|
data={data}
|
||||||
className={`${className} u-table-drag-border`}
|
className={`${className} u-table-drag-border`}
|
||||||
onDragStart={this.onDragStart}
|
onDragStart={this.onDragWidthStart}
|
||||||
onDragOver={this.onDragOver}
|
onDragOver={this.onDragWidthOver}
|
||||||
onDrop={this.onDrop}
|
onDrop={this.onDropWidth}
|
||||||
onDragEnter={this.onDragEnter}
|
onDragEnter={this.onDragWidthEnter}
|
||||||
draggable={draggable}
|
draggable={draggable}
|
||||||
// dragborder={dragborder}
|
// dragborder={dragborder}
|
||||||
dragborder={false}
|
dragborder={false}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import React, { Component } from "react";
|
import React, { Component } from "react";
|
||||||
import Checkbox from 'bee-checkbox';
|
import Checkbox from 'bee-checkbox';
|
||||||
import Icon from "bee-icon";
|
import Icon from "bee-icon";
|
||||||
import {ObjectAssign} from '../utils';
|
import {ObjectAssign} from './util';
|
||||||
function noop() {}
|
function noop() {}
|
||||||
/**
|
/**
|
||||||
* 参数: 过滤表头
|
* 参数: 过滤表头
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import React, { Component } from "react";
|
import React, { Component } from "react";
|
||||||
import Checkbox from 'bee-checkbox';
|
import Checkbox from 'bee-checkbox';
|
||||||
import {ObjectAssign} from '../utils';
|
import {ObjectAssign} from './util';
|
||||||
/**
|
/**
|
||||||
* 参数: 过滤表头
|
* 参数: 过滤表头
|
||||||
* @param {*} Table
|
* @param {*} Table
|
||||||
|
|
|
@ -48,3 +48,22 @@ export function compare(property){
|
||||||
return value1 - value2;
|
return value1 - value2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 简单数组数据对象拷贝
|
||||||
|
* @param {*} obj 要拷贝的对象
|
||||||
|
*/
|
||||||
|
export function ObjectAssign(obj){
|
||||||
|
let b = obj instanceof Array;
|
||||||
|
let tagObj = b?[]:{};
|
||||||
|
if(b){//数组
|
||||||
|
obj.forEach(da => {
|
||||||
|
let _da = {};
|
||||||
|
Object.assign(_da,da);
|
||||||
|
tagObj.push(_da);
|
||||||
|
});
|
||||||
|
}else{
|
||||||
|
Object.assign(tagObj,obj);
|
||||||
|
}
|
||||||
|
return tagObj;
|
||||||
|
}
|
Loading…
Reference in New Issue