@kdcloudjs/table 1.2.1-canary.7-hotfix.1 → 1.2.2-canary.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +568 -568
- package/README.md +111 -111
- package/dist/@kdcloudjs/table.css +1 -1
- package/dist/@kdcloudjs/table.css.map +0 -0
- package/dist/@kdcloudjs/table.js +4095 -2984
- package/dist/@kdcloudjs/table.js.map +1 -1
- package/dist/@kdcloudjs/table.min.css +1 -1
- package/dist/@kdcloudjs/table.min.js +12 -10
- package/dist/@kdcloudjs/table.min.js.map +1 -1
- package/dist/default-theme.js +0 -0
- package/dist/kd-ui-complete.less +777 -777
- package/dist/kd-ui.less +0 -0
- package/dist/theme.js +0 -0
- package/es/_utils/formatUtil.js +1 -5
- package/es/_utils/hooks.js +3 -3
- package/es/_utils/usePopper.js +13 -13
- package/es/locale/locale.js +6 -7
- package/es/style/color/colors.less +1 -1
- package/es/style/core/index.less +1 -1
- package/es/style/core/motion/other.less +27 -27
- package/es/style/core/motion/slide.less +53 -53
- package/es/style/core/motion.less +1 -1
- package/es/style/core/reset.less +185 -185
- package/es/style/index.less +1 -1
- package/es/style/mixins/index.less +18 -18
- package/es/style/mixins/overlay.less +21 -21
- package/es/style/mixins/reset.less +12 -12
- package/es/style/themes/default.less +445 -445
- package/es/table/base/calculations.js +3 -3
- package/es/table/base/empty.js +2 -2
- package/es/table/base/globalStyleComponent.d.ts +4 -0
- package/es/table/base/globalStyleComponent.js +24 -0
- package/es/table/base/header.js +5 -7
- package/es/table/base/helpers/SpanManager.js +1 -2
- package/es/table/base/helpers/TableDOMUtils.js +5 -6
- package/es/table/base/html-table.js +3 -4
- package/es/table/base/loading.js +2 -2
- package/es/table/base/renderTemplates.js +16 -16
- package/es/table/base/styles.d.ts +11 -0
- package/es/table/base/styles.js +18 -7
- package/es/table/base/table.js +18 -20
- package/es/table/base/utils.js +3 -3
- package/es/table/interfaces.d.ts +41 -0
- package/es/table/pipeline/const.d.ts +3 -0
- package/es/table/pipeline/const.js +3 -0
- package/es/table/pipeline/features/columnDrag.js +0 -1
- package/es/table/pipeline/features/columnFilter.js +1 -3
- package/es/table/pipeline/features/columnResizeWidth.js +2 -2
- package/es/table/pipeline/features/contextMenu.js +4 -6
- package/es/table/pipeline/features/featureApi/RowDragApi.d.ts +15 -0
- package/es/table/pipeline/features/featureApi/RowDragApi.js +66 -0
- package/es/table/pipeline/features/featureApi/utils.d.ts +2 -0
- package/es/table/pipeline/features/featureApi/utils.js +10 -0
- package/es/table/pipeline/features/filter/DefaultFilterContent.js +4 -5
- package/es/table/pipeline/features/filter/Filter.js +2 -3
- package/es/table/pipeline/features/rangeSelection.js +10 -10
- package/es/table/pipeline/features/rowDetail.js +2 -2
- package/es/table/pipeline/features/rowDrag.d.ts +12 -12
- package/es/table/pipeline/features/rowDrag.js +605 -192
- package/es/table/pipeline/features/rowGrouping.js +2 -2
- package/es/table/pipeline/features/sort.js +6 -7
- package/es/table/pipeline/features/tips.js +4 -4
- package/es/table/pipeline/features/treeMode.d.ts +1 -0
- package/es/table/pipeline/features/treeMode.js +39 -12
- package/es/table/pipeline/features/treeSelect.js +2 -2
- package/es/table/pipeline/pipeline.d.ts +3 -0
- package/es/table/pipeline/pipeline.js +24 -3
- package/es/table/pivot/cross-table/buildCrossTable.js +6 -8
- package/es/table/pivot/cross-table/cross-table.js +1 -3
- package/es/table/pivot/cross-tree-table/buildCrossTreeTable.js +8 -10
- package/es/table/pivot/cross-tree-table/cross-tree-table.js +8 -11
- package/es/table/pivot/pivot-utils/builders.js +3 -3
- package/es/table/pivot/pivot-utils/convert-utils.js +3 -3
- package/es/table/style/index.less +1 -1
- package/es/table/transforms/autoWidth.js +3 -3
- package/es/table/transforms/columnResize.js +3 -5
- package/es/table/transforms/sort.js +6 -8
- package/es/table/transforms/tips.js +4 -4
- package/es/table/transforms/treeMode.js +6 -8
- package/es/table/utils/buildTree.js +3 -3
- package/es/table/utils/collectNodes.js +3 -3
- package/es/table/utils/exportTableAsExcel.js +3 -3
- package/es/table/utils/getTreeDepth.js +3 -3
- package/es/table/utils/groupBy.js +3 -3
- package/es/table/utils/makeRecursiveMapper.js +3 -3
- package/es/table/utils/mergeCellProps.js +0 -1
- package/es/table/utils/others.js +3 -3
- package/es/table/utils/traverseColumn.js +3 -3
- package/es/table/utils/tree-data-helpers/StrictTreeDataHelper.js +7 -8
- package/es/table/utils/tree-data-helpers/TreeDataHelper.js +4 -5
- package/lib/_utils/arrayUtil.js +2 -3
- package/lib/_utils/formatUtil.js +1 -5
- package/lib/_utils/hooks.js +3 -3
- package/lib/_utils/index.js +2 -3
- package/lib/_utils/type.js +3 -5
- package/lib/_utils/usePopper.js +18 -21
- package/lib/config-provider/ConfigContext.js +1 -2
- package/lib/config-provider/compDefaultProps.js +1 -2
- package/lib/config-provider/configProvider.js +3 -4
- package/lib/config-provider/defaultConfig.js +1 -2
- package/lib/config-provider/index.js +1 -2
- package/lib/locale/index.js +3 -4
- package/lib/locale/locale.js +10 -14
- package/lib/locale/zh-CN.js +1 -2
- package/lib/style/color/colors.less +2 -0
- package/lib/style/components.less +1 -1
- package/lib/style/core/index.less +2 -0
- package/lib/style/core/motion/other.less +28 -0
- package/lib/style/core/motion/slide.less +53 -0
- package/lib/style/core/motion.less +2 -0
- package/lib/style/core/reset.less +186 -0
- package/lib/style/index.css +410 -0
- package/lib/style/index.less +2 -0
- package/lib/style/mixins/index.less +19 -0
- package/lib/style/mixins/overlay.less +22 -0
- package/lib/style/mixins/reset.less +13 -0
- package/lib/style/themes/default.less +445 -0
- package/lib/style/themes/index.less +1 -0
- package/lib/table/base/calculations.js +3 -3
- package/lib/table/base/empty.js +4 -4
- package/lib/table/base/globalStyleComponent.d.ts +4 -0
- package/lib/table/base/globalStyleComponent.js +35 -0
- package/lib/table/base/header.js +5 -7
- package/lib/table/base/helpers/SpanManager.js +3 -5
- package/lib/table/base/helpers/TableDOMUtils.js +7 -9
- package/lib/table/base/helpers/getRichVisibleRectsStream.js +2 -2
- package/lib/table/base/html-table.js +3 -4
- package/lib/table/base/loading.js +2 -2
- package/lib/table/base/renderTemplates.js +18 -18
- package/lib/table/base/styles.d.ts +11 -0
- package/lib/table/base/styles.js +25 -21
- package/lib/table/base/table.js +30 -31
- package/lib/table/base/utils.js +13 -20
- package/lib/table/common-views.js +4 -8
- package/lib/table/interfaces.d.ts +41 -0
- package/lib/table/internals.js +2 -3
- package/lib/table/pipeline/const.d.ts +3 -0
- package/lib/table/pipeline/const.js +9 -0
- package/lib/table/pipeline/features/autoFill.js +3 -6
- package/lib/table/pipeline/features/colGroupExtendable.js +2 -3
- package/lib/table/pipeline/features/columnDrag.js +0 -1
- package/lib/table/pipeline/features/columnFilter.js +1 -3
- package/lib/table/pipeline/features/columnResizeWidth.js +7 -10
- package/lib/table/pipeline/features/contextMenu.js +6 -8
- package/lib/table/pipeline/features/featureApi/RowDragApi.d.ts +15 -0
- package/lib/table/pipeline/features/featureApi/RowDragApi.js +72 -0
- package/lib/table/pipeline/features/featureApi/utils.d.ts +2 -0
- package/lib/table/pipeline/features/featureApi/utils.js +17 -0
- package/lib/table/pipeline/features/filter/DefaultFilterContent.js +7 -9
- package/lib/table/pipeline/features/filter/Filter.js +5 -7
- package/lib/table/pipeline/features/filter/FilterPanel.js +3 -4
- package/lib/table/pipeline/features/filter/util.js +2 -3
- package/lib/table/pipeline/features/footerDataSource.js +1 -2
- package/lib/table/pipeline/features/rangeSelection.js +12 -14
- package/lib/table/pipeline/features/rowDetail.js +2 -2
- package/lib/table/pipeline/features/rowDrag.d.ts +12 -12
- package/lib/table/pipeline/features/rowDrag.js +608 -197
- package/lib/table/pipeline/features/rowGrouping.js +2 -2
- package/lib/table/pipeline/features/sort.js +6 -7
- package/lib/table/pipeline/features/tips.js +4 -4
- package/lib/table/pipeline/features/treeMode.d.ts +1 -0
- package/lib/table/pipeline/features/treeMode.js +41 -14
- package/lib/table/pipeline/features/treeSelect.js +2 -2
- package/lib/table/pipeline/index.js +2 -2
- package/lib/table/pipeline/pipeline.d.ts +3 -0
- package/lib/table/pipeline/pipeline.js +25 -5
- package/lib/table/pivot/cross-table/buildCrossTable.js +6 -8
- package/lib/table/pivot/cross-table/constants.js +1 -2
- package/lib/table/pivot/cross-table/cross-table.js +3 -6
- package/lib/table/pivot/cross-tree-table/buildCrossTreeTable.js +8 -10
- package/lib/table/pivot/cross-tree-table/cross-tree-table.js +9 -13
- package/lib/table/pivot/pivot-utils/builders.js +3 -3
- package/lib/table/pivot/pivot-utils/convert-utils.js +3 -3
- package/lib/table/style/index.css +0 -0
- package/lib/table/style/index.less +1 -0
- package/lib/table/transforms/autoWidth.js +5 -5
- package/lib/table/transforms/columnResize.js +5 -7
- package/lib/table/transforms/sort.js +8 -10
- package/lib/table/transforms/tips.js +4 -4
- package/lib/table/transforms/treeMode.js +8 -10
- package/lib/table/use/useResizeObserver.js +1 -2
- package/lib/table/utils/browserType.js +2 -4
- package/lib/table/utils/buildTree.js +3 -3
- package/lib/table/utils/collectNodes.js +3 -3
- package/lib/table/utils/console.js +2 -3
- package/lib/table/utils/copyToClipboard.js +1 -2
- package/lib/table/utils/exportTableAsExcel.js +3 -3
- package/lib/table/utils/getTreeDepth.js +3 -3
- package/lib/table/utils/groupBy.js +3 -3
- package/lib/table/utils/keyCode.js +1 -2
- package/lib/table/utils/makeRecursiveMapper.js +3 -3
- package/lib/table/utils/mergeCellProps.js +0 -1
- package/lib/table/utils/others.js +4 -5
- package/lib/table/utils/proto.js +1 -2
- package/lib/table/utils/selectColumn.js +2 -4
- package/lib/table/utils/traverseColumn.js +3 -3
- package/lib/table/utils/tree-data-helpers/StrictTreeDataHelper.js +9 -11
- package/lib/table/utils/tree-data-helpers/TreeDataHelper.js +6 -8
- package/package.json +218 -219
|
@@ -1,14 +1,20 @@
|
|
|
1
1
|
import _defineProperty from "@babel/runtime-corejs3/helpers/defineProperty";
|
|
2
|
-
import _sliceInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/slice";
|
|
3
2
|
import _concatInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/concat";
|
|
3
|
+
import _findInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/find";
|
|
4
|
+
import _sliceInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/slice";
|
|
5
|
+
import _findIndexInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/find-index";
|
|
4
6
|
import React from 'react';
|
|
5
7
|
import { fromEvent } from 'rxjs';
|
|
6
8
|
import { map, takeUntil, filter } from 'rxjs/operators';
|
|
7
9
|
import cx from 'classnames';
|
|
8
10
|
import { Classes } from '../../base/styles';
|
|
11
|
+
import { FeatureName } from '../const';
|
|
12
|
+
import { internals } from '../../internals';
|
|
9
13
|
export var ROW_DRAG_COLUMN_CODE = '$_row_drag_column_&';
|
|
10
14
|
export var rowDragKey = 'rowDragKey';
|
|
15
|
+
export var rowDragOptionsKey = 'rowDragOptions';
|
|
11
16
|
var SCROLL_OFFSET = 30;
|
|
17
|
+
var SCROLL_START_OFFSET = 20;
|
|
12
18
|
var defaultRowDragColumn = {
|
|
13
19
|
name: '拖拽列',
|
|
14
20
|
code: ROW_DRAG_COLUMN_CODE,
|
|
@@ -40,163 +46,305 @@ export function rowDrag(opt) {
|
|
|
40
46
|
var _context;
|
|
41
47
|
var tableBody = pipeline.ref.current.domHelper && pipeline.ref.current.domHelper.tableBody;
|
|
42
48
|
var artTable = pipeline.ref.current.domHelper && pipeline.ref.current.domHelper.artTable;
|
|
49
|
+
var rowDragApi = pipeline.addFeatureApi(FeatureName.rowDrag);
|
|
50
|
+
pipeline.setFeatureOptions(rowDragOptionsKey, opt);
|
|
43
51
|
if (!tableBody) return pipeline;
|
|
44
52
|
var dataSource = pipeline.getDataSource();
|
|
45
|
-
var
|
|
46
|
-
|
|
53
|
+
var getRowDragEvent = function getRowDragEvent(dropTargetEvent, isFinished) {
|
|
54
|
+
var dragItem = dropTargetEvent.dragItem,
|
|
55
|
+
x = dropTargetEvent.x,
|
|
56
|
+
y = dropTargetEvent.y,
|
|
57
|
+
dropZoneTarget = dropTargetEvent.dropZoneTarget,
|
|
58
|
+
startDropZoneTagret = dropTargetEvent.startDropZoneTagret,
|
|
59
|
+
commonParams = dropTargetEvent.commonParams,
|
|
60
|
+
startCommonParams = dropTargetEvent.startCommonParams,
|
|
61
|
+
event = dropTargetEvent.event,
|
|
62
|
+
dropZoneTableParams = dropTargetEvent.dropZoneTableParams;
|
|
63
|
+
var getDataSource = dropZoneTableParams.getDataSource,
|
|
64
|
+
getTreeModeOptions = dropZoneTableParams.getTreeModeOptions,
|
|
65
|
+
getRowDragOptions = dropZoneTableParams.getRowDragOptions;
|
|
66
|
+
var dataSource = getDataSource();
|
|
67
|
+
var treeModeOptions = getTreeModeOptions();
|
|
68
|
+
var rowDragOptions = getRowDragOptions();
|
|
69
|
+
var allowDragIntoRow = !!treeModeOptions && (rowDragOptions === null || rowDragOptions === void 0 ? void 0 : rowDragOptions.allowDragIntoRow);
|
|
70
|
+
var isLeave = !isMouseOnDropTarget(event, dropZoneTarget);
|
|
71
|
+
var overIndex = -1;
|
|
72
|
+
var direction = 'bottom';
|
|
73
|
+
if (!isLeave && dataSource.length > 0) {
|
|
74
|
+
var overDragItem = getDragRowItem(event.target, dropZoneTarget, dataSource);
|
|
75
|
+
if (overDragItem) {
|
|
76
|
+
var rowIndex = overDragItem.rowIndex,
|
|
77
|
+
cell = overDragItem.cell;
|
|
78
|
+
overIndex = rowIndex;
|
|
79
|
+
direction = getDirection(cell, event.clientY, allowDragIntoRow);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
if (overIndex === -1 && dataSource.length > 0 && dropZoneTarget.contains(event.target)) {
|
|
83
|
+
overIndex = dataSource.length - 1;
|
|
84
|
+
direction = 'bottom';
|
|
85
|
+
}
|
|
86
|
+
var overRow = overIndex >= 0 ? dataSource[overIndex] : null;
|
|
87
|
+
return {
|
|
88
|
+
startRowIndex: dragItem.rowIndex,
|
|
89
|
+
startRow: dragItem.row,
|
|
90
|
+
endRowIndex: overIndex,
|
|
91
|
+
endRow: overRow,
|
|
92
|
+
startDropZoneTagret: startDropZoneTagret,
|
|
93
|
+
startCommonParams: startCommonParams,
|
|
94
|
+
commonParams: commonParams,
|
|
95
|
+
dropZoneTarget: dropZoneTarget,
|
|
96
|
+
event: event,
|
|
97
|
+
dragPosition: direction,
|
|
98
|
+
isFinished: isFinished,
|
|
99
|
+
x: x,
|
|
100
|
+
y: y
|
|
101
|
+
};
|
|
102
|
+
};
|
|
103
|
+
var onDragging = function onDragging(event) {
|
|
47
104
|
var _a;
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
105
|
+
var rowDragEvent = getRowDragEvent(event, false);
|
|
106
|
+
(_a = opt === null || opt === void 0 ? void 0 : opt.onDragMove) === null || _a === void 0 ? void 0 : _a.call(opt, rowDragEvent);
|
|
107
|
+
pipeline.setStateAtKey(rowDragKey, rowDragEvent);
|
|
51
108
|
};
|
|
52
|
-
var
|
|
109
|
+
var onDragStop = function onDragStop(event) {
|
|
53
110
|
var _a;
|
|
54
|
-
|
|
55
|
-
pipeline.setStateAtKey(rowDragKey,
|
|
111
|
+
var rowDragEvent = getRowDragEvent(event, true);
|
|
112
|
+
pipeline.setStateAtKey(rowDragKey, rowDragEvent);
|
|
113
|
+
(_a = opt === null || opt === void 0 ? void 0 : opt.onDragEnd) === null || _a === void 0 ? void 0 : _a.call(opt, rowDragEvent);
|
|
56
114
|
};
|
|
57
|
-
var
|
|
115
|
+
var onDragStart = function onDragStart(event) {
|
|
58
116
|
var _a;
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
// 超出拖拽范围不触发dragend事件
|
|
62
|
-
if (isValid) {
|
|
63
|
-
(_a = opt === null || opt === void 0 ? void 0 : opt.onDragEnd) === null || _a === void 0 ? void 0 : _a.call(opt, event);
|
|
64
|
-
}
|
|
117
|
+
var rowDragEvent = getRowDragEvent(event, false);
|
|
118
|
+
(_a = opt === null || opt === void 0 ? void 0 : opt.onDragStart) === null || _a === void 0 ? void 0 : _a.call(opt, rowDragEvent);
|
|
65
119
|
};
|
|
66
|
-
var
|
|
67
|
-
var
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
startRowIndex: startRowInfo.rowIndex,
|
|
72
|
-
startRow: startRowInfo.row,
|
|
73
|
-
endRowIndex: endRowInfo.rowIndex,
|
|
74
|
-
endRow: endRowInfo.row,
|
|
75
|
-
dragPosition: dragPosition,
|
|
76
|
-
isFinished: isFinished
|
|
77
|
-
};
|
|
120
|
+
var onDragLeave = function onDragLeave(event) {
|
|
121
|
+
var _a;
|
|
122
|
+
var rowDragEvent = getRowDragEvent(event, false);
|
|
123
|
+
pipeline.setStateAtKey(rowDragKey, rowDragEvent);
|
|
124
|
+
(_a = opt === null || opt === void 0 ? void 0 : opt.onDragLeave) === null || _a === void 0 ? void 0 : _a.call(opt, rowDragEvent);
|
|
78
125
|
};
|
|
79
|
-
var
|
|
80
|
-
|
|
81
|
-
var
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
126
|
+
var onDragEnter = function onDragEnter(event) {
|
|
127
|
+
var _a;
|
|
128
|
+
var rowDragEvent = getRowDragEvent(event, false);
|
|
129
|
+
pipeline.setStateAtKey(rowDragKey, rowDragEvent);
|
|
130
|
+
(_a = opt === null || opt === void 0 ? void 0 : opt.onDragEnter) === null || _a === void 0 ? void 0 : _a.call(opt, rowDragEvent);
|
|
131
|
+
};
|
|
132
|
+
var currentDropZone = {
|
|
133
|
+
getContainer: function getContainer() {
|
|
134
|
+
var lastPipeline = pipeline.getLastPipeline();
|
|
135
|
+
return lastPipeline.ref.current.domHelper.tableBody;
|
|
136
|
+
},
|
|
137
|
+
onDragEnter: onDragEnter,
|
|
138
|
+
onDragLeave: onDragLeave,
|
|
139
|
+
onDragging: onDragging,
|
|
140
|
+
onDragStop: onDragStop,
|
|
141
|
+
isTable: true,
|
|
142
|
+
tableParams: {
|
|
143
|
+
getDataSource: function getDataSource() {
|
|
144
|
+
var lastPipeline = pipeline.getLastPipeline();
|
|
145
|
+
return lastPipeline.getDataSource();
|
|
146
|
+
},
|
|
147
|
+
getTreeModeOptions: function getTreeModeOptions() {
|
|
148
|
+
var lastPipeline = pipeline.getLastPipeline();
|
|
149
|
+
return lastPipeline.getFeatureOptions('treeModeOptions');
|
|
150
|
+
},
|
|
151
|
+
getRowDragOptions: function getRowDragOptions() {
|
|
152
|
+
var lastPipeline = pipeline.getLastPipeline();
|
|
153
|
+
return lastPipeline.getFeatureOptions('rowDragOptions');
|
|
154
|
+
}
|
|
90
155
|
}
|
|
91
156
|
};
|
|
92
|
-
var onMouseDown = function onMouseDown(
|
|
157
|
+
var onMouseDown = function onMouseDown(event) {
|
|
93
158
|
var _a;
|
|
94
|
-
var
|
|
95
|
-
var
|
|
96
|
-
if (!
|
|
97
|
-
if ((_a = opt === null || opt === void 0 ? void 0 : opt.isDisabled) === null || _a === void 0 ? void 0 : _a.call(opt,
|
|
98
|
-
// 默认拖拽插入的位置是向下
|
|
99
|
-
var dragPosition = 'bottom';
|
|
100
|
-
var isOutOfRange = false;
|
|
159
|
+
var mouseDownEvent = event.nativeEvent;
|
|
160
|
+
var startDataItem = getDragRowItem(mouseDownEvent.target, tableBody, dataSource);
|
|
161
|
+
if (!startDataItem || startDataItem.code !== rowDragColumn.code) return;
|
|
162
|
+
if ((_a = opt === null || opt === void 0 ? void 0 : opt.isDisabled) === null || _a === void 0 ? void 0 : _a.call(opt, startDataItem.row, startDataItem.rowIndex)) return;
|
|
101
163
|
var isValidDrag = false;
|
|
102
|
-
var
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
var
|
|
108
|
-
var
|
|
109
|
-
|
|
110
|
-
var
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
164
|
+
var isDragging = false;
|
|
165
|
+
var dragElement = null;
|
|
166
|
+
var dragLine = null;
|
|
167
|
+
var lastDropTarget = null;
|
|
168
|
+
var timeoutId = null;
|
|
169
|
+
var intervalId = null;
|
|
170
|
+
var expandRowTimeoutId = null;
|
|
171
|
+
var expandRowCallBackList = [];
|
|
172
|
+
var updateScrollPosition = function updateScrollPosition(tableBody, mouseMoveEvent) {
|
|
173
|
+
if (opt === null || opt === void 0 ? void 0 : opt.suppressScrollMove) return;
|
|
174
|
+
if (timeoutId) {
|
|
175
|
+
clearTimeout(timeoutId);
|
|
176
|
+
}
|
|
177
|
+
if (intervalId) {
|
|
178
|
+
clearInterval(intervalId);
|
|
179
|
+
}
|
|
180
|
+
if (!tableBody) return;
|
|
181
|
+
var moveOffset = getScrollMoveOffset(tableBody, mouseMoveEvent);
|
|
182
|
+
if (moveOffset === 0) {
|
|
183
|
+
return;
|
|
184
|
+
}
|
|
185
|
+
timeoutId = setTimeout(function () {
|
|
186
|
+
intervalId = setInterval(function () {
|
|
187
|
+
tableBody.scrollTop += moveOffset;
|
|
188
|
+
}, 50);
|
|
189
|
+
}, 500);
|
|
121
190
|
};
|
|
122
|
-
var
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
191
|
+
var handleDragStart = function handleDragStart(mouseDownEvent) {
|
|
192
|
+
var _a;
|
|
193
|
+
dragElement = createDragElement(mouseDownEvent, tableBody); // 创建拖拽悬浮框
|
|
194
|
+
var isTreeTable = !!pipeline.getFeatureOptions('treeModeOptions');
|
|
195
|
+
dragLine = createDragLine(isTreeTable); // 创建拖拽插入指示线
|
|
196
|
+
var dragText = (opt === null || opt === void 0 ? void 0 : opt.rowDragText) ? (_a = opt === null || opt === void 0 ? void 0 : opt.rowDragText) === null || _a === void 0 ? void 0 : _a.call(opt, startDataItem.row, startDataItem.rowIndex) : "\u7B2C".concat(startDataItem.rowIndex, "\u884C\u5185\u5BB9");
|
|
197
|
+
setDragText(dragElement, dragText); // 设置悬浮框显示文本
|
|
198
|
+
artTable.classList.add(cx(Classes.rowDragging));
|
|
199
|
+
rowDragApi.setDragStatus('start');
|
|
200
|
+
var dragEvent = createDropTargetEvent(currentDropZone, mouseDownEvent, startDataItem, currentDropZone);
|
|
201
|
+
onDragStart(dragEvent);
|
|
202
|
+
};
|
|
203
|
+
var handleDragMove = function handleDragMove(mouseMoveEvent) {
|
|
204
|
+
var _a;
|
|
205
|
+
positionDragElemment(dragElement, mouseMoveEvent); // 更新拖拽悬浮框位置
|
|
206
|
+
rowDragApi.setDragStatus('dragging');
|
|
207
|
+
setDragElementIcon(dragElement, 'move');
|
|
208
|
+
var rowDropZones = rowDragApi.getRowDropZone();
|
|
209
|
+
var validDropZones = _concatInstanceProperty(rowDropZones).call(rowDropZones, currentDropZone); // 可放置区域加上自身
|
|
210
|
+
var dropTarget = _findInstanceProperty(validDropZones).call(validDropZones, function (zone) {
|
|
211
|
+
return isMouseOnDropTarget(mouseMoveEvent, zone.getContainer());
|
|
212
|
+
}) || null;
|
|
213
|
+
updateScrollPosition(dropTarget === null || dropTarget === void 0 ? void 0 : dropTarget.getContainer(), mouseMoveEvent); // 拖拽到底时让滚动条可以滚动
|
|
214
|
+
if (dropTarget !== lastDropTarget) {
|
|
215
|
+
// 拖拽离开表格
|
|
216
|
+
if (lastDropTarget !== null && dropTarget === null) {
|
|
217
|
+
if (lastDropTarget.onDragLeave) {
|
|
218
|
+
setDragElementIcon(dragElement, 'notAllowed');
|
|
219
|
+
hiddenDragLine(dragLine);
|
|
220
|
+
lastDropTarget.getContainer().classList.remove(Classes.rowDragNoData);
|
|
221
|
+
var dragEvent = createDropTargetEvent(lastDropTarget, mouseMoveEvent, startDataItem, currentDropZone);
|
|
222
|
+
lastDropTarget.onDragLeave(dragEvent);
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
// 拖拽进入表格
|
|
226
|
+
if (lastDropTarget === null && dropTarget !== null) {
|
|
227
|
+
if (dropTarget.onDragEnter) {
|
|
228
|
+
setDragElementIcon(dragElement, 'move');
|
|
229
|
+
if (dropTarget.isTable) {
|
|
230
|
+
showDragLine(dragLine);
|
|
231
|
+
var getTreeModeOptions = dropTarget.tableParams.getTreeModeOptions;
|
|
232
|
+
var treeModeOptions = getTreeModeOptions();
|
|
233
|
+
var isTreeTable = !!treeModeOptions;
|
|
234
|
+
// 判断拖拽进入的表格是否是树形表格,控制指示线样式
|
|
235
|
+
if (isTreeTable) {
|
|
236
|
+
dragLine.classList.add(Classes.treeTableRowDragLine);
|
|
237
|
+
} else {
|
|
238
|
+
dragLine.classList.remove(Classes.treeTableRowDragLine);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
var _dragEvent = createDropTargetEvent(dropTarget, mouseMoveEvent, startDataItem, currentDropZone);
|
|
242
|
+
dropTarget.onDragEnter(_dragEvent);
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
lastDropTarget = dropTarget;
|
|
246
|
+
}
|
|
247
|
+
if (dropTarget) {
|
|
248
|
+
// 拖拽区域在表格中,更新拖拽插入指示线位置
|
|
249
|
+
if (dropTarget.isTable) {
|
|
250
|
+
positionDragLine({
|
|
251
|
+
lineElement: dragLine,
|
|
252
|
+
dragZone: dropTarget,
|
|
253
|
+
event: mouseMoveEvent
|
|
254
|
+
});
|
|
255
|
+
}
|
|
256
|
+
// 树形表格悬停1s展开对应行节点
|
|
257
|
+
if ((_a = dropTarget === null || dropTarget === void 0 ? void 0 : dropTarget.tableParams) === null || _a === void 0 ? void 0 : _a.getTreeModeOptions()) {
|
|
258
|
+
if (expandRowTimeoutId) {
|
|
259
|
+
clearTimeout(expandRowTimeoutId);
|
|
260
|
+
}
|
|
261
|
+
expandRowTimeoutId = setTimeout(function () {
|
|
262
|
+
var treeModeOptions = dropTarget.tableParams.getTreeModeOptions();
|
|
263
|
+
var treeMetaKey = treeModeOptions.treeMetaKey,
|
|
264
|
+
onExpand = treeModeOptions.onExpand,
|
|
265
|
+
isExpanded = treeModeOptions.isExpanded,
|
|
266
|
+
onCollapse = treeModeOptions.onCollapse;
|
|
267
|
+
// 鼠标悬停所在的拖拽行信息
|
|
268
|
+
var dataSource = dropTarget.tableParams.getDataSource();
|
|
269
|
+
var dragItem = getDragRowItem(mouseMoveEvent.target, dropTarget.getContainer(), dataSource);
|
|
270
|
+
if (!dragItem) return;
|
|
271
|
+
var row = dragItem.row;
|
|
272
|
+
var _row$treeMetaKey = row[treeMetaKey],
|
|
273
|
+
rowKey = _row$treeMetaKey.rowKey,
|
|
274
|
+
isLeaf = _row$treeMetaKey.isLeaf;
|
|
275
|
+
if (!isLeaf && !isExpanded(rowKey)) {
|
|
276
|
+
onExpand(rowKey);
|
|
277
|
+
expandRowCallBackList.push(function () {
|
|
278
|
+
return onCollapse(rowKey);
|
|
279
|
+
});
|
|
280
|
+
}
|
|
281
|
+
}, 1000);
|
|
282
|
+
}
|
|
283
|
+
if (dropTarget.onDragging) {
|
|
284
|
+
var _dragEvent2 = createDropTargetEvent(dropTarget, mouseMoveEvent, startDataItem, currentDropZone);
|
|
285
|
+
dropTarget.onDragging(_dragEvent2);
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
};
|
|
289
|
+
var handleDragStop = function handleDragStop(mouseUpEvent) {
|
|
290
|
+
if (!isValidDrag) {
|
|
291
|
+
return;
|
|
292
|
+
}
|
|
293
|
+
removeElement(dragElement);
|
|
294
|
+
removeElement(dragLine);
|
|
295
|
+
artTable.classList.remove(cx(Classes.rowDragging));
|
|
296
|
+
rowDragApi.setDragStatus('finished');
|
|
297
|
+
clearTimeout(timeoutId);
|
|
298
|
+
clearInterval(intervalId);
|
|
299
|
+
clearTimeout(expandRowTimeoutId);
|
|
300
|
+
var rowDropZones = rowDragApi.getRowDropZone();
|
|
301
|
+
rowDropZones.forEach(function (dropzone) {
|
|
302
|
+
var container = dropzone.getContainer();
|
|
303
|
+
container && container.classList.remove(Classes.rowDragNoData);
|
|
304
|
+
});
|
|
305
|
+
var validDropZones = _concatInstanceProperty(rowDropZones).call(rowDropZones, currentDropZone);
|
|
306
|
+
var dropTarget = _findInstanceProperty(validDropZones).call(validDropZones, function (zone) {
|
|
307
|
+
return isMouseOnDropTarget(mouseUpEvent, zone.getContainer());
|
|
130
308
|
});
|
|
131
|
-
|
|
132
|
-
|
|
309
|
+
if (dropTarget && dropTarget.onDragStop) {
|
|
310
|
+
var dragEvent = createDropTargetEvent(dropTarget, mouseUpEvent, startDataItem, currentDropZone);
|
|
311
|
+
dropTarget.onDragStop(dragEvent);
|
|
312
|
+
}
|
|
313
|
+
while (expandRowCallBackList.length > 0) {
|
|
314
|
+
var callback = expandRowCallBackList.pop();
|
|
315
|
+
callback();
|
|
316
|
+
}
|
|
133
317
|
};
|
|
134
|
-
|
|
135
|
-
var
|
|
318
|
+
var mousemove$ = fromEvent(window, 'mousemove');
|
|
319
|
+
var mouseup$ = fromEvent(window, 'mouseup');
|
|
320
|
+
var rowDragMove$ = mousemove$.pipe(filter(function (mouseMoveEvent) {
|
|
136
321
|
var mouseMoveClientY = mouseMoveEvent.clientY;
|
|
322
|
+
var mouseDownClientY = mouseDownEvent.clientY;
|
|
137
323
|
// 上下移动偏移量大于5才是有效的拖拽
|
|
138
324
|
if (Math.abs(mouseMoveClientY - mouseDownClientY) > 5) {
|
|
139
325
|
isValidDrag = true;
|
|
140
326
|
}
|
|
141
327
|
return isValidDrag;
|
|
142
328
|
}), map(function (mouseMoveEvent) {
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
endRowInfo = tagretRow;
|
|
329
|
+
if (!isDragging) {
|
|
330
|
+
isDragging = true;
|
|
331
|
+
handleDragStart(mouseDownEvent);
|
|
332
|
+
handleDragMove(mouseDownEvent);
|
|
148
333
|
}
|
|
149
|
-
|
|
150
|
-
// 判断拖拽插入的位置,拖拽框上边框位于目标行之上则向上插入,否则向下插入
|
|
151
|
-
var isMoveToTop = clientY - startOffset < targetRowRects.top;
|
|
152
|
-
dragPosition = isMoveToTop ? 'top' : 'bottom';
|
|
153
|
-
isOutOfRange = isOutOfDragRange({
|
|
154
|
-
x: clientX,
|
|
155
|
-
y: clientY
|
|
156
|
-
}, dragRange);
|
|
157
|
-
mousePosition = {
|
|
158
|
-
x: clientX,
|
|
159
|
-
y: clientY
|
|
160
|
-
};
|
|
161
|
-
updateScrollPosition(mouseMoveEvent); // 拖拽到底时让滚动条可以滚动
|
|
162
|
-
updateDragElementPosition(dragElement, dragRange, {
|
|
163
|
-
x: clientX,
|
|
164
|
-
y: clientY,
|
|
165
|
-
startOffset: startOffset
|
|
166
|
-
});
|
|
167
|
-
updateCurSorStyle(isOutOfRange);
|
|
168
|
-
return {
|
|
169
|
-
startRowInfo: startRowInfo,
|
|
170
|
-
endRowInfo: endRowInfo,
|
|
171
|
-
dragPosition: dragPosition
|
|
172
|
-
};
|
|
334
|
+
handleDragMove(mouseMoveEvent);
|
|
173
335
|
}), takeUntil(mouseup$));
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
isFinished: false,
|
|
181
|
-
dragPosition: dragPosition
|
|
182
|
-
});
|
|
183
|
-
handleDragMove(dragMoveEvent);
|
|
184
|
-
},
|
|
185
|
-
complete: function complete() {
|
|
186
|
-
var dragEndEvent = getDragEvent(startRowInfo, endRowInfo, {
|
|
187
|
-
isFinished: true,
|
|
188
|
-
dragPosition: dragPosition
|
|
189
|
-
});
|
|
190
|
-
var isValid = isValidDrag && !isOutOfRange;
|
|
191
|
-
handleDragEnd(dragEndEvent, isValid);
|
|
192
|
-
removeDragElement(dragElement);
|
|
193
|
-
removeCurSorStyle();
|
|
194
|
-
document.removeEventListener('scroll', scrollCallback, true);
|
|
336
|
+
rowDragMove$.subscribe();
|
|
337
|
+
var rowDragEnd$ = mouseup$.pipe(map(function (mouseUpEvent) {
|
|
338
|
+
handleDragStop(mouseUpEvent);
|
|
339
|
+
})).subscribe({
|
|
340
|
+
next: function next() {
|
|
341
|
+
rowDragEnd$.unsubscribe();
|
|
195
342
|
}
|
|
196
343
|
});
|
|
197
344
|
};
|
|
198
345
|
var rowDragColumn = (opt === null || opt === void 0 ? void 0 : opt.rowDragColumn) || defaultRowDragColumn;
|
|
199
346
|
pipeline.setFeatureOptions('rowDragColumnKey', rowDragColumn.code);
|
|
347
|
+
rowDragApi.setRowDropZoneParams(currentDropZone);
|
|
200
348
|
var nextColumns = _sliceInstanceProperty(_context = pipeline.getColumns()).call(_context);
|
|
201
349
|
nextColumns.unshift(rowDragColumn);
|
|
202
350
|
pipeline.columns(nextColumns);
|
|
@@ -204,15 +352,28 @@ export function rowDrag(opt) {
|
|
|
204
352
|
onMouseDown: onMouseDown
|
|
205
353
|
});
|
|
206
354
|
pipeline.appendRowPropsGetter(function (row, rowIndex) {
|
|
207
|
-
var _cx;
|
|
208
355
|
var rowDragEvent = pipeline.getStateAtKey(rowDragKey) || {};
|
|
356
|
+
var dragStatus = rowDragApi.getDragStatus();
|
|
209
357
|
var startRowIndex = rowDragEvent.startRowIndex,
|
|
210
358
|
endRowIndex = rowDragEvent.endRowIndex,
|
|
359
|
+
endRow = rowDragEvent.endRow,
|
|
211
360
|
isFinished = rowDragEvent.isFinished,
|
|
212
361
|
dragPosition = rowDragEvent.dragPosition;
|
|
213
362
|
var isFooterCell = row[pipeline.getFeatureOptions('footerRowMetaKey')];
|
|
214
|
-
|
|
215
|
-
var
|
|
363
|
+
var treeModeOptions = pipeline.getFeatureOptions('treeModeOptions');
|
|
364
|
+
var isTreeTable = !!treeModeOptions;
|
|
365
|
+
if (isFooterCell || isFinished || !isTreeTable && rowIndex !== startRowIndex && rowIndex !== endRowIndex) return;
|
|
366
|
+
var parentRowKeyIndex = -1;
|
|
367
|
+
if (isTreeTable && endRow) {
|
|
368
|
+
var _context2;
|
|
369
|
+
var treeMetaKey = treeModeOptions.treeMetaKey;
|
|
370
|
+
var parentRowKey = endRow[treeMetaKey].parentRowKey;
|
|
371
|
+
var primaryKey = pipeline.ensurePrimaryKey('rowDrag');
|
|
372
|
+
parentRowKeyIndex = _findIndexInstanceProperty(_context2 = pipeline.getDataSource()).call(_context2, function (row) {
|
|
373
|
+
return internals.safeGetRowKey(primaryKey, row, -1) === parentRowKey;
|
|
374
|
+
});
|
|
375
|
+
}
|
|
376
|
+
var className = cx(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({}, Classes.rowDragStart, rowIndex === startRowIndex && dragStatus !== 'finished'), Classes.rowDragEnd, rowIndex === endRowIndex), Classes.rowDragEndParent, isTreeTable && rowIndex === parentRowKeyIndex && dragPosition !== 'into'), Classes.rowDragEndInto, rowIndex === endRowIndex && dragPosition === 'into'), Classes.rowDragEndToTop, rowIndex === endRowIndex && dragPosition === 'top'), Classes.rowDragEndToBottom, rowIndex === endRowIndex && dragPosition === 'bottom'));
|
|
216
377
|
return {
|
|
217
378
|
className: className
|
|
218
379
|
};
|
|
@@ -220,7 +381,7 @@ export function rowDrag(opt) {
|
|
|
220
381
|
return pipeline;
|
|
221
382
|
};
|
|
222
383
|
}
|
|
223
|
-
function
|
|
384
|
+
function getDragRowItem(target, tableBody, record) {
|
|
224
385
|
while (target && tableBody.contains(target)) {
|
|
225
386
|
if (target.getAttribute('data-role') === 'table-cell') {
|
|
226
387
|
var code = target.getAttribute('data-code');
|
|
@@ -239,6 +400,15 @@ function getTargetRowInfo(target, tableBody, record) {
|
|
|
239
400
|
}
|
|
240
401
|
return null;
|
|
241
402
|
}
|
|
403
|
+
function findTargetRow(target, tableBody) {
|
|
404
|
+
while (target && tableBody.contains(target)) {
|
|
405
|
+
if (target.getAttribute('data-role') === 'table-row') {
|
|
406
|
+
return target;
|
|
407
|
+
}
|
|
408
|
+
target = target.parentElement;
|
|
409
|
+
}
|
|
410
|
+
return null;
|
|
411
|
+
}
|
|
242
412
|
function isEleInFooter(target) {
|
|
243
413
|
while (target && !target.classList.contains(Classes.artTable)) {
|
|
244
414
|
if (target.classList.contains(Classes.tableFooter)) {
|
|
@@ -248,75 +418,318 @@ function isEleInFooter(target) {
|
|
|
248
418
|
}
|
|
249
419
|
return false;
|
|
250
420
|
}
|
|
251
|
-
function createDragElement(
|
|
252
|
-
var
|
|
253
|
-
var
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
var
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
x: x,
|
|
267
|
-
y: y
|
|
268
|
-
}, dragRange);
|
|
269
|
-
element.style.top = validPosition.y - startOffset + 'px';
|
|
270
|
-
return element;
|
|
421
|
+
function createDragElement(mouseDownEvent, tableBody) {
|
|
422
|
+
var _context3, _context4;
|
|
423
|
+
var ELEMENT_TEMPLATE = _concatInstanceProperty(_context3 = _concatInstanceProperty(_context4 = "<div class='".concat(Classes.rowDragElement, "'>\n <span class='")).call(_context4, Classes.rowDragElementIcon, "'></span>\n <div class='")).call(_context3, Classes.rowDragElementLabel, "'></div>\n </div>");
|
|
424
|
+
var element = document.createElement('div');
|
|
425
|
+
element.innerHTML = ELEMENT_TEMPLATE;
|
|
426
|
+
var dragElement = element.firstChild;
|
|
427
|
+
var targetRow = findTargetRow(mouseDownEvent.target, tableBody);
|
|
428
|
+
if (targetRow) {
|
|
429
|
+
var rect = targetRow.getBoundingClientRect();
|
|
430
|
+
dragElement.style.height = rect.height + 'px';
|
|
431
|
+
}
|
|
432
|
+
var bodyRect = tableBody.getBoundingClientRect();
|
|
433
|
+
dragElement.style.maxWidth = bodyRect.width + 'px';
|
|
434
|
+
document.body.appendChild(dragElement);
|
|
435
|
+
return dragElement;
|
|
271
436
|
}
|
|
272
|
-
function
|
|
273
|
-
document.
|
|
437
|
+
function createDragLine(isTreeTable) {
|
|
438
|
+
var dragLine = document.createElement('div');
|
|
439
|
+
dragLine.classList.add(Classes.rowDragLine);
|
|
440
|
+
if (isTreeTable) {
|
|
441
|
+
dragLine.classList.add(Classes.treeTableRowDragLine);
|
|
442
|
+
}
|
|
443
|
+
document.body.appendChild(dragLine);
|
|
444
|
+
return dragLine;
|
|
274
445
|
}
|
|
275
|
-
function
|
|
276
|
-
|
|
277
|
-
|
|
446
|
+
function positionDragLine(_ref) {
|
|
447
|
+
var _context7;
|
|
448
|
+
var lineElement = _ref.lineElement,
|
|
449
|
+
dragZone = _ref.dragZone,
|
|
450
|
+
event = _ref.event;
|
|
451
|
+
var tableContainer = dragZone.getContainer();
|
|
452
|
+
var _dragZone$tableParams = dragZone.tableParams,
|
|
453
|
+
getDataSource = _dragZone$tableParams.getDataSource,
|
|
454
|
+
getTreeModeOptions = _dragZone$tableParams.getTreeModeOptions,
|
|
455
|
+
getRowDragOptions = _dragZone$tableParams.getRowDragOptions;
|
|
456
|
+
var dataSource = getDataSource();
|
|
457
|
+
var treeModeOptions = getTreeModeOptions();
|
|
458
|
+
var rowDragOptions = getRowDragOptions() || {};
|
|
459
|
+
var allowDragIntoRow = rowDragOptions.allowDragIntoRow;
|
|
460
|
+
var isTreeTable = !!treeModeOptions;
|
|
461
|
+
var bodyRect = tableContainer.getBoundingClientRect();
|
|
462
|
+
var offsetParentSize = getElementRectWithOffset(document.body);
|
|
463
|
+
if (dataSource.length === 0) {
|
|
464
|
+
tableContainer.classList.add(Classes.rowDragNoData);
|
|
465
|
+
lineElement.style.display = 'none';
|
|
278
466
|
} else {
|
|
279
|
-
|
|
467
|
+
tableContainer.classList.remove(Classes.rowDragNoData);
|
|
468
|
+
lineElement.style.display = 'block';
|
|
469
|
+
}
|
|
470
|
+
// 鼠标悬停所在的拖拽行信息
|
|
471
|
+
var dragItem = getDragRowItem(event.target, tableContainer, dataSource);
|
|
472
|
+
if (!dragItem) {
|
|
473
|
+
if (dataSource.length > 0 && tableContainer.contains(event.target)) {
|
|
474
|
+
var _context5, _context6;
|
|
475
|
+
var _rowIndex = dataSource.length - 1;
|
|
476
|
+
var _row = dataSource[_rowIndex];
|
|
477
|
+
var _direction = 'bottom';
|
|
478
|
+
var _targetCell = isTreeTable ? tableContainer.querySelector(_concatInstanceProperty(_context5 = "tr[data-rowindex=\"".concat(_rowIndex, "\"] .")).call(_context5, Classes.tableExtendCell)) : tableContainer.querySelector(_concatInstanceProperty(_context6 = "tr[data-rowindex=\"".concat(_rowIndex, "\"] .")).call(_context6, Classes.rowDragCell));
|
|
479
|
+
if (!_targetCell) return;
|
|
480
|
+
var _getLinePosition = getLinePosition({
|
|
481
|
+
treeModeOptions: treeModeOptions,
|
|
482
|
+
cell: _targetCell,
|
|
483
|
+
row: _row,
|
|
484
|
+
direction: _direction,
|
|
485
|
+
offsetParentSize: offsetParentSize,
|
|
486
|
+
bodyRect: bodyRect
|
|
487
|
+
}),
|
|
488
|
+
_top = _getLinePosition.top,
|
|
489
|
+
_left = _getLinePosition.left,
|
|
490
|
+
_width = _getLinePosition.width;
|
|
491
|
+
lineElement.style.left = "".concat(_left, "px");
|
|
492
|
+
lineElement.style.top = "".concat(_top, "px");
|
|
493
|
+
lineElement.style.width = "".concat(_width, "px");
|
|
494
|
+
}
|
|
495
|
+
return;
|
|
496
|
+
}
|
|
497
|
+
var cell = dragItem.cell,
|
|
498
|
+
rowIndex = dragItem.rowIndex,
|
|
499
|
+
row = dragItem.row;
|
|
500
|
+
var allowDragInto = isTreeTable && allowDragIntoRow;
|
|
501
|
+
var direction = getDirection(cell, event.clientY, allowDragInto);
|
|
502
|
+
var targetCell = isTreeTable ? tableContainer.querySelector(_concatInstanceProperty(_context7 = "tr[data-rowindex=\"".concat(rowIndex, "\"] .")).call(_context7, Classes.tableExtendCell)) : cell;
|
|
503
|
+
if (!targetCell) return;
|
|
504
|
+
var _getLinePosition2 = getLinePosition({
|
|
505
|
+
treeModeOptions: treeModeOptions,
|
|
506
|
+
cell: targetCell,
|
|
507
|
+
row: row,
|
|
508
|
+
direction: direction,
|
|
509
|
+
offsetParentSize: offsetParentSize,
|
|
510
|
+
bodyRect: bodyRect
|
|
511
|
+
}),
|
|
512
|
+
top = _getLinePosition2.top,
|
|
513
|
+
left = _getLinePosition2.left,
|
|
514
|
+
width = _getLinePosition2.width;
|
|
515
|
+
lineElement.style.left = "".concat(left, "px");
|
|
516
|
+
lineElement.style.top = "".concat(top, "px");
|
|
517
|
+
lineElement.style.width = "".concat(width, "px");
|
|
518
|
+
if (direction === 'into') {
|
|
519
|
+
lineElement.style.display = 'none';
|
|
520
|
+
} else {
|
|
521
|
+
lineElement.style.display = 'block';
|
|
280
522
|
}
|
|
281
523
|
}
|
|
282
|
-
function
|
|
283
|
-
|
|
524
|
+
function showDragLine(lineElement) {
|
|
525
|
+
lineElement.style.display = 'block';
|
|
284
526
|
}
|
|
285
|
-
function
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
var
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
527
|
+
function hiddenDragLine(lineElement) {
|
|
528
|
+
lineElement.style.display = 'none';
|
|
529
|
+
}
|
|
530
|
+
function positionDragElemment(element, event) {
|
|
531
|
+
var _a, _b, _c, _d, _e, _f;
|
|
532
|
+
if (!element) return;
|
|
533
|
+
var elementRect = element.getBoundingClientRect();
|
|
534
|
+
var eleHeight = elementRect.height;
|
|
535
|
+
var browserWidth = (_b = (_a = document.body) === null || _a === void 0 ? void 0 : _a.clientWidth) !== null && _b !== void 0 ? _b : window.innerHeight || ((_c = document.documentElement) === null || _c === void 0 ? void 0 : _c.clientWidth) || 0;
|
|
536
|
+
var browserHeight = (_e = (_d = document.body) === null || _d === void 0 ? void 0 : _d.clientHeight) !== null && _e !== void 0 ? _e : window.innerHeight || ((_f = document.documentElement) === null || _f === void 0 ? void 0 : _f.clientHeight) || 0;
|
|
537
|
+
var offsetParentSize = getElementRectWithOffset(element.offsetParent);
|
|
538
|
+
var clientX = event.clientX,
|
|
539
|
+
clientY = event.clientY;
|
|
540
|
+
var top = clientY - offsetParentSize.top - eleHeight / 2;
|
|
541
|
+
var left = clientX - offsetParentSize.left;
|
|
542
|
+
var windowScrollX = window.pageXOffset;
|
|
543
|
+
var windowScrollY = window.pageYOffset;
|
|
544
|
+
if (browserWidth > 0 && left + element.clientWidth > browserWidth + windowScrollX) {
|
|
545
|
+
left = Math.max(browserWidth + windowScrollX - element.clientWidth, 0);
|
|
546
|
+
}
|
|
547
|
+
if (browserHeight > 0 && top + element.clientHeight > browserHeight + windowScrollY) {
|
|
548
|
+
top = Math.max(browserHeight + windowScrollY - element.clientHeight, 0);
|
|
549
|
+
}
|
|
550
|
+
element.style.left = "".concat(left, "px");
|
|
551
|
+
element.style.top = "".concat(top, "px");
|
|
552
|
+
}
|
|
553
|
+
function getElementRectWithOffset(el) {
|
|
554
|
+
var offsetElementRect = el.getBoundingClientRect();
|
|
555
|
+
var _getElementSize2 = _getElementSize(el),
|
|
556
|
+
borderTopWidth = _getElementSize2.borderTopWidth,
|
|
557
|
+
borderLeftWidth = _getElementSize2.borderLeftWidth,
|
|
558
|
+
borderRightWidth = _getElementSize2.borderRightWidth,
|
|
559
|
+
borderBottomWidth = _getElementSize2.borderBottomWidth;
|
|
293
560
|
return {
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
561
|
+
top: offsetElementRect.top + (borderTopWidth || 0),
|
|
562
|
+
left: offsetElementRect.left + (borderLeftWidth || 0),
|
|
563
|
+
right: offsetElementRect.right + (borderRightWidth || 0),
|
|
564
|
+
bottom: offsetElementRect.bottom + (borderBottomWidth || 0)
|
|
298
565
|
};
|
|
299
566
|
}
|
|
300
|
-
function
|
|
301
|
-
var
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
567
|
+
function _getElementSize(el) {
|
|
568
|
+
var _window$getComputedSt = window.getComputedStyle(el),
|
|
569
|
+
height = _window$getComputedSt.height,
|
|
570
|
+
width = _window$getComputedSt.width,
|
|
571
|
+
borderTopWidth = _window$getComputedSt.borderTopWidth,
|
|
572
|
+
borderRightWidth = _window$getComputedSt.borderRightWidth,
|
|
573
|
+
borderBottomWidth = _window$getComputedSt.borderBottomWidth,
|
|
574
|
+
borderLeftWidth = _window$getComputedSt.borderLeftWidth,
|
|
575
|
+
paddingTop = _window$getComputedSt.paddingTop,
|
|
576
|
+
paddingRight = _window$getComputedSt.paddingRight,
|
|
577
|
+
paddingBottom = _window$getComputedSt.paddingBottom,
|
|
578
|
+
paddingLeft = _window$getComputedSt.paddingLeft,
|
|
579
|
+
marginTop = _window$getComputedSt.marginTop,
|
|
580
|
+
marginRight = _window$getComputedSt.marginRight,
|
|
581
|
+
marginBottom = _window$getComputedSt.marginBottom,
|
|
582
|
+
marginLeft = _window$getComputedSt.marginLeft,
|
|
583
|
+
boxSizing = _window$getComputedSt.boxSizing;
|
|
309
584
|
return {
|
|
310
|
-
|
|
311
|
-
|
|
585
|
+
height: parseFloat(height || '0'),
|
|
586
|
+
width: parseFloat(width || '0'),
|
|
587
|
+
borderTopWidth: parseFloat(borderTopWidth || '0'),
|
|
588
|
+
borderRightWidth: parseFloat(borderRightWidth || '0'),
|
|
589
|
+
borderBottomWidth: parseFloat(borderBottomWidth || '0'),
|
|
590
|
+
borderLeftWidth: parseFloat(borderLeftWidth || '0'),
|
|
591
|
+
paddingTop: parseFloat(paddingTop || '0'),
|
|
592
|
+
paddingRight: parseFloat(paddingRight || '0'),
|
|
593
|
+
paddingBottom: parseFloat(paddingBottom || '0'),
|
|
594
|
+
paddingLeft: parseFloat(paddingLeft || '0'),
|
|
595
|
+
marginTop: parseFloat(marginTop || '0'),
|
|
596
|
+
marginRight: parseFloat(marginRight || '0'),
|
|
597
|
+
marginBottom: parseFloat(marginBottom || '0'),
|
|
598
|
+
marginLeft: parseFloat(marginLeft || '0'),
|
|
599
|
+
boxSizing: boxSizing
|
|
600
|
+
};
|
|
601
|
+
}
|
|
602
|
+
function removeElement(element) {
|
|
603
|
+
document.body.removeChild(element);
|
|
604
|
+
}
|
|
605
|
+
function setDragElementIcon(element, iconName) {
|
|
606
|
+
var elementIcon = element.querySelector(".".concat(Classes.rowDragElementIcon));
|
|
607
|
+
clearElementChildren(elementIcon);
|
|
608
|
+
iconName = iconName || 'notAllowed';
|
|
609
|
+
var iconElement = document.createElement('span');
|
|
610
|
+
if (iconName === 'move') {
|
|
611
|
+
iconElement.classList.add(Classes.iconMove);
|
|
612
|
+
} else if (iconName === 'notAllowed') {
|
|
613
|
+
iconElement.classList.add(Classes.iconNotAllowed);
|
|
614
|
+
}
|
|
615
|
+
elementIcon.appendChild(iconElement);
|
|
616
|
+
}
|
|
617
|
+
function clearElementChildren(element) {
|
|
618
|
+
while (element && element.firstChild) {
|
|
619
|
+
element.removeChild(element.firstChild);
|
|
620
|
+
}
|
|
621
|
+
}
|
|
622
|
+
function getScrollMoveOffset(tableBody, mouseMoveEvent) {
|
|
623
|
+
var clientY = mouseMoveEvent.clientY;
|
|
624
|
+
var tableBodyClientRect = tableBody.getBoundingClientRect();
|
|
625
|
+
var top = tableBodyClientRect.top,
|
|
626
|
+
height = tableBodyClientRect.height;
|
|
627
|
+
if (clientY >= top + height - SCROLL_START_OFFSET && clientY <= top + height) {
|
|
628
|
+
return SCROLL_OFFSET;
|
|
629
|
+
}
|
|
630
|
+
if (clientY >= top && clientY <= top + SCROLL_START_OFFSET) {
|
|
631
|
+
return -SCROLL_OFFSET;
|
|
632
|
+
}
|
|
633
|
+
return 0;
|
|
634
|
+
}
|
|
635
|
+
function setDragText(element, dragText) {
|
|
636
|
+
var dragTextString = dragText.toString();
|
|
637
|
+
var elementIcon = element.querySelector(".".concat(Classes.rowDragElementLabel));
|
|
638
|
+
var stringNode = document.createTextNode(dragTextString);
|
|
639
|
+
elementIcon.appendChild(stringNode);
|
|
640
|
+
}
|
|
641
|
+
function isMouseOnDropTarget(mouseEvent, target) {
|
|
642
|
+
return target.contains(mouseEvent.target);
|
|
643
|
+
}
|
|
644
|
+
function createDropTargetEvent(dropZone, event, dragItem, startDropZone) {
|
|
645
|
+
var dropZoneTarget = dropZone.getContainer();
|
|
646
|
+
var startDropZoneTagret = startDropZone.getContainer();
|
|
647
|
+
var rect = dropZoneTarget.getBoundingClientRect();
|
|
648
|
+
var x = event.clientX - rect.left;
|
|
649
|
+
var y = event.clientY - rect.top;
|
|
650
|
+
var startDropZoneOptions = startDropZone.tableParams.getRowDragOptions();
|
|
651
|
+
var startCommonParams = startDropZoneOptions === null || startDropZoneOptions === void 0 ? void 0 : startDropZoneOptions.commonParams;
|
|
652
|
+
var targetEvent = {
|
|
653
|
+
dragItem: dragItem,
|
|
654
|
+
startDropZoneTagret: startDropZoneTagret,
|
|
655
|
+
startCommonParams: startCommonParams,
|
|
656
|
+
dropZoneTarget: dropZoneTarget,
|
|
657
|
+
event: event,
|
|
658
|
+
x: x,
|
|
659
|
+
y: y
|
|
312
660
|
};
|
|
661
|
+
if (dropZone.isTable) {
|
|
662
|
+
var dropZoneOptions = dropZone.tableParams.getRowDragOptions();
|
|
663
|
+
var commonParams = dropZoneOptions === null || dropZoneOptions === void 0 ? void 0 : dropZoneOptions.commonParams;
|
|
664
|
+
targetEvent.dropZoneTableParams = dropZone.tableParams;
|
|
665
|
+
targetEvent.commonParams = commonParams;
|
|
666
|
+
}
|
|
667
|
+
return targetEvent;
|
|
668
|
+
}
|
|
669
|
+
function getDirection(cell, clientY) {
|
|
670
|
+
var isTreeTable = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
671
|
+
var _cell$getBoundingClie = cell.getBoundingClientRect(),
|
|
672
|
+
height = _cell$getBoundingClie.height,
|
|
673
|
+
y = _cell$getBoundingClie.y;
|
|
674
|
+
var direction = 'bottom';
|
|
675
|
+
if (isTreeTable) {
|
|
676
|
+
if (y + height / 4 > clientY) {
|
|
677
|
+
direction = 'top';
|
|
678
|
+
} else if (y + height * 3 / 4 > clientY) {
|
|
679
|
+
direction = 'into';
|
|
680
|
+
}
|
|
681
|
+
} else if (y + height / 2 > clientY) {
|
|
682
|
+
direction = 'top';
|
|
683
|
+
}
|
|
684
|
+
return direction;
|
|
313
685
|
}
|
|
314
|
-
function
|
|
315
|
-
var
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
686
|
+
var getLinePosition = function getLinePosition(_ref2) {
|
|
687
|
+
var treeModeOptions = _ref2.treeModeOptions,
|
|
688
|
+
cell = _ref2.cell,
|
|
689
|
+
row = _ref2.row,
|
|
690
|
+
direction = _ref2.direction,
|
|
691
|
+
offsetParentSize = _ref2.offsetParentSize,
|
|
692
|
+
bodyRect = _ref2.bodyRect;
|
|
693
|
+
var isTreeTable = !!treeModeOptions;
|
|
694
|
+
if (isTreeTable) {
|
|
695
|
+
var iconWidth = treeModeOptions.iconWidth,
|
|
696
|
+
iconIndent = treeModeOptions.iconIndent,
|
|
697
|
+
iconGap = treeModeOptions.iconGap,
|
|
698
|
+
indentSize = treeModeOptions.indentSize,
|
|
699
|
+
treeMetaKey = treeModeOptions.treeMetaKey;
|
|
700
|
+
var _getElementSize3 = _getElementSize(cell),
|
|
701
|
+
paddingLeft = _getElementSize3.paddingLeft;
|
|
702
|
+
var expandCellRect = cell.getBoundingClientRect();
|
|
703
|
+
var _row$treeMetaKey2 = row[treeMetaKey],
|
|
704
|
+
rowKey = _row$treeMetaKey2.rowKey,
|
|
705
|
+
depth = _row$treeMetaKey2.depth,
|
|
706
|
+
isLeaf = _row$treeMetaKey2.isLeaf,
|
|
707
|
+
expanded = _row$treeMetaKey2.expanded;
|
|
708
|
+
var addWidth = isLeaf ? iconWidth + iconGap : 0;
|
|
709
|
+
var indent = iconIndent + depth * indentSize + addWidth;
|
|
710
|
+
var x = expandCellRect.x,
|
|
711
|
+
_y = expandCellRect.y,
|
|
712
|
+
_height = expandCellRect.height;
|
|
713
|
+
var _top2 = direction === 'bottom' ? _y + _height - offsetParentSize.top : _y - offsetParentSize.top;
|
|
714
|
+
var offsetX = Math.max(x + paddingLeft + indent - bodyRect.x, 0);
|
|
715
|
+
var _left2 = bodyRect.x + offsetX - offsetParentSize.left;
|
|
716
|
+
var _width2 = bodyRect.width - offsetX;
|
|
717
|
+
return {
|
|
718
|
+
top: _top2,
|
|
719
|
+
left: _left2,
|
|
720
|
+
width: _width2
|
|
721
|
+
};
|
|
722
|
+
}
|
|
723
|
+
// 根据鼠标悬停位置所在单元格和显示位置计算拖拽线的位置
|
|
724
|
+
var rect = cell.getBoundingClientRect();
|
|
725
|
+
var y = rect.y,
|
|
726
|
+
height = rect.height;
|
|
727
|
+
var top = direction === 'bottom' ? y + height - offsetParentSize.top : y - offsetParentSize.top;
|
|
728
|
+
var left = bodyRect.x - offsetParentSize.left;
|
|
729
|
+
var width = bodyRect.width;
|
|
730
|
+
return {
|
|
731
|
+
top: top,
|
|
732
|
+
left: left,
|
|
733
|
+
width: width
|
|
734
|
+
};
|
|
735
|
+
};
|