@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.
Files changed (199) hide show
  1. package/LICENSE +568 -568
  2. package/README.md +111 -111
  3. package/dist/@kdcloudjs/table.css +1 -1
  4. package/dist/@kdcloudjs/table.css.map +0 -0
  5. package/dist/@kdcloudjs/table.js +4095 -2984
  6. package/dist/@kdcloudjs/table.js.map +1 -1
  7. package/dist/@kdcloudjs/table.min.css +1 -1
  8. package/dist/@kdcloudjs/table.min.js +12 -10
  9. package/dist/@kdcloudjs/table.min.js.map +1 -1
  10. package/dist/default-theme.js +0 -0
  11. package/dist/kd-ui-complete.less +777 -777
  12. package/dist/kd-ui.less +0 -0
  13. package/dist/theme.js +0 -0
  14. package/es/_utils/formatUtil.js +1 -5
  15. package/es/_utils/hooks.js +3 -3
  16. package/es/_utils/usePopper.js +13 -13
  17. package/es/locale/locale.js +6 -7
  18. package/es/style/color/colors.less +1 -1
  19. package/es/style/core/index.less +1 -1
  20. package/es/style/core/motion/other.less +27 -27
  21. package/es/style/core/motion/slide.less +53 -53
  22. package/es/style/core/motion.less +1 -1
  23. package/es/style/core/reset.less +185 -185
  24. package/es/style/index.less +1 -1
  25. package/es/style/mixins/index.less +18 -18
  26. package/es/style/mixins/overlay.less +21 -21
  27. package/es/style/mixins/reset.less +12 -12
  28. package/es/style/themes/default.less +445 -445
  29. package/es/table/base/calculations.js +3 -3
  30. package/es/table/base/empty.js +2 -2
  31. package/es/table/base/globalStyleComponent.d.ts +4 -0
  32. package/es/table/base/globalStyleComponent.js +24 -0
  33. package/es/table/base/header.js +5 -7
  34. package/es/table/base/helpers/SpanManager.js +1 -2
  35. package/es/table/base/helpers/TableDOMUtils.js +5 -6
  36. package/es/table/base/html-table.js +3 -4
  37. package/es/table/base/loading.js +2 -2
  38. package/es/table/base/renderTemplates.js +16 -16
  39. package/es/table/base/styles.d.ts +11 -0
  40. package/es/table/base/styles.js +18 -7
  41. package/es/table/base/table.js +18 -20
  42. package/es/table/base/utils.js +3 -3
  43. package/es/table/interfaces.d.ts +41 -0
  44. package/es/table/pipeline/const.d.ts +3 -0
  45. package/es/table/pipeline/const.js +3 -0
  46. package/es/table/pipeline/features/columnDrag.js +0 -1
  47. package/es/table/pipeline/features/columnFilter.js +1 -3
  48. package/es/table/pipeline/features/columnResizeWidth.js +2 -2
  49. package/es/table/pipeline/features/contextMenu.js +4 -6
  50. package/es/table/pipeline/features/featureApi/RowDragApi.d.ts +15 -0
  51. package/es/table/pipeline/features/featureApi/RowDragApi.js +66 -0
  52. package/es/table/pipeline/features/featureApi/utils.d.ts +2 -0
  53. package/es/table/pipeline/features/featureApi/utils.js +10 -0
  54. package/es/table/pipeline/features/filter/DefaultFilterContent.js +4 -5
  55. package/es/table/pipeline/features/filter/Filter.js +2 -3
  56. package/es/table/pipeline/features/rangeSelection.js +10 -10
  57. package/es/table/pipeline/features/rowDetail.js +2 -2
  58. package/es/table/pipeline/features/rowDrag.d.ts +12 -12
  59. package/es/table/pipeline/features/rowDrag.js +605 -192
  60. package/es/table/pipeline/features/rowGrouping.js +2 -2
  61. package/es/table/pipeline/features/sort.js +6 -7
  62. package/es/table/pipeline/features/tips.js +4 -4
  63. package/es/table/pipeline/features/treeMode.d.ts +1 -0
  64. package/es/table/pipeline/features/treeMode.js +39 -12
  65. package/es/table/pipeline/features/treeSelect.js +2 -2
  66. package/es/table/pipeline/pipeline.d.ts +3 -0
  67. package/es/table/pipeline/pipeline.js +24 -3
  68. package/es/table/pivot/cross-table/buildCrossTable.js +6 -8
  69. package/es/table/pivot/cross-table/cross-table.js +1 -3
  70. package/es/table/pivot/cross-tree-table/buildCrossTreeTable.js +8 -10
  71. package/es/table/pivot/cross-tree-table/cross-tree-table.js +8 -11
  72. package/es/table/pivot/pivot-utils/builders.js +3 -3
  73. package/es/table/pivot/pivot-utils/convert-utils.js +3 -3
  74. package/es/table/style/index.less +1 -1
  75. package/es/table/transforms/autoWidth.js +3 -3
  76. package/es/table/transforms/columnResize.js +3 -5
  77. package/es/table/transforms/sort.js +6 -8
  78. package/es/table/transforms/tips.js +4 -4
  79. package/es/table/transforms/treeMode.js +6 -8
  80. package/es/table/utils/buildTree.js +3 -3
  81. package/es/table/utils/collectNodes.js +3 -3
  82. package/es/table/utils/exportTableAsExcel.js +3 -3
  83. package/es/table/utils/getTreeDepth.js +3 -3
  84. package/es/table/utils/groupBy.js +3 -3
  85. package/es/table/utils/makeRecursiveMapper.js +3 -3
  86. package/es/table/utils/mergeCellProps.js +0 -1
  87. package/es/table/utils/others.js +3 -3
  88. package/es/table/utils/traverseColumn.js +3 -3
  89. package/es/table/utils/tree-data-helpers/StrictTreeDataHelper.js +7 -8
  90. package/es/table/utils/tree-data-helpers/TreeDataHelper.js +4 -5
  91. package/lib/_utils/arrayUtil.js +2 -3
  92. package/lib/_utils/formatUtil.js +1 -5
  93. package/lib/_utils/hooks.js +3 -3
  94. package/lib/_utils/index.js +2 -3
  95. package/lib/_utils/type.js +3 -5
  96. package/lib/_utils/usePopper.js +18 -21
  97. package/lib/config-provider/ConfigContext.js +1 -2
  98. package/lib/config-provider/compDefaultProps.js +1 -2
  99. package/lib/config-provider/configProvider.js +3 -4
  100. package/lib/config-provider/defaultConfig.js +1 -2
  101. package/lib/config-provider/index.js +1 -2
  102. package/lib/locale/index.js +3 -4
  103. package/lib/locale/locale.js +10 -14
  104. package/lib/locale/zh-CN.js +1 -2
  105. package/lib/style/color/colors.less +2 -0
  106. package/lib/style/components.less +1 -1
  107. package/lib/style/core/index.less +2 -0
  108. package/lib/style/core/motion/other.less +28 -0
  109. package/lib/style/core/motion/slide.less +53 -0
  110. package/lib/style/core/motion.less +2 -0
  111. package/lib/style/core/reset.less +186 -0
  112. package/lib/style/index.css +410 -0
  113. package/lib/style/index.less +2 -0
  114. package/lib/style/mixins/index.less +19 -0
  115. package/lib/style/mixins/overlay.less +22 -0
  116. package/lib/style/mixins/reset.less +13 -0
  117. package/lib/style/themes/default.less +445 -0
  118. package/lib/style/themes/index.less +1 -0
  119. package/lib/table/base/calculations.js +3 -3
  120. package/lib/table/base/empty.js +4 -4
  121. package/lib/table/base/globalStyleComponent.d.ts +4 -0
  122. package/lib/table/base/globalStyleComponent.js +35 -0
  123. package/lib/table/base/header.js +5 -7
  124. package/lib/table/base/helpers/SpanManager.js +3 -5
  125. package/lib/table/base/helpers/TableDOMUtils.js +7 -9
  126. package/lib/table/base/helpers/getRichVisibleRectsStream.js +2 -2
  127. package/lib/table/base/html-table.js +3 -4
  128. package/lib/table/base/loading.js +2 -2
  129. package/lib/table/base/renderTemplates.js +18 -18
  130. package/lib/table/base/styles.d.ts +11 -0
  131. package/lib/table/base/styles.js +25 -21
  132. package/lib/table/base/table.js +30 -31
  133. package/lib/table/base/utils.js +13 -20
  134. package/lib/table/common-views.js +4 -8
  135. package/lib/table/interfaces.d.ts +41 -0
  136. package/lib/table/internals.js +2 -3
  137. package/lib/table/pipeline/const.d.ts +3 -0
  138. package/lib/table/pipeline/const.js +9 -0
  139. package/lib/table/pipeline/features/autoFill.js +3 -6
  140. package/lib/table/pipeline/features/colGroupExtendable.js +2 -3
  141. package/lib/table/pipeline/features/columnDrag.js +0 -1
  142. package/lib/table/pipeline/features/columnFilter.js +1 -3
  143. package/lib/table/pipeline/features/columnResizeWidth.js +7 -10
  144. package/lib/table/pipeline/features/contextMenu.js +6 -8
  145. package/lib/table/pipeline/features/featureApi/RowDragApi.d.ts +15 -0
  146. package/lib/table/pipeline/features/featureApi/RowDragApi.js +72 -0
  147. package/lib/table/pipeline/features/featureApi/utils.d.ts +2 -0
  148. package/lib/table/pipeline/features/featureApi/utils.js +17 -0
  149. package/lib/table/pipeline/features/filter/DefaultFilterContent.js +7 -9
  150. package/lib/table/pipeline/features/filter/Filter.js +5 -7
  151. package/lib/table/pipeline/features/filter/FilterPanel.js +3 -4
  152. package/lib/table/pipeline/features/filter/util.js +2 -3
  153. package/lib/table/pipeline/features/footerDataSource.js +1 -2
  154. package/lib/table/pipeline/features/rangeSelection.js +12 -14
  155. package/lib/table/pipeline/features/rowDetail.js +2 -2
  156. package/lib/table/pipeline/features/rowDrag.d.ts +12 -12
  157. package/lib/table/pipeline/features/rowDrag.js +608 -197
  158. package/lib/table/pipeline/features/rowGrouping.js +2 -2
  159. package/lib/table/pipeline/features/sort.js +6 -7
  160. package/lib/table/pipeline/features/tips.js +4 -4
  161. package/lib/table/pipeline/features/treeMode.d.ts +1 -0
  162. package/lib/table/pipeline/features/treeMode.js +41 -14
  163. package/lib/table/pipeline/features/treeSelect.js +2 -2
  164. package/lib/table/pipeline/index.js +2 -2
  165. package/lib/table/pipeline/pipeline.d.ts +3 -0
  166. package/lib/table/pipeline/pipeline.js +25 -5
  167. package/lib/table/pivot/cross-table/buildCrossTable.js +6 -8
  168. package/lib/table/pivot/cross-table/constants.js +1 -2
  169. package/lib/table/pivot/cross-table/cross-table.js +3 -6
  170. package/lib/table/pivot/cross-tree-table/buildCrossTreeTable.js +8 -10
  171. package/lib/table/pivot/cross-tree-table/cross-tree-table.js +9 -13
  172. package/lib/table/pivot/pivot-utils/builders.js +3 -3
  173. package/lib/table/pivot/pivot-utils/convert-utils.js +3 -3
  174. package/lib/table/style/index.css +0 -0
  175. package/lib/table/style/index.less +1 -0
  176. package/lib/table/transforms/autoWidth.js +5 -5
  177. package/lib/table/transforms/columnResize.js +5 -7
  178. package/lib/table/transforms/sort.js +8 -10
  179. package/lib/table/transforms/tips.js +4 -4
  180. package/lib/table/transforms/treeMode.js +8 -10
  181. package/lib/table/use/useResizeObserver.js +1 -2
  182. package/lib/table/utils/browserType.js +2 -4
  183. package/lib/table/utils/buildTree.js +3 -3
  184. package/lib/table/utils/collectNodes.js +3 -3
  185. package/lib/table/utils/console.js +2 -3
  186. package/lib/table/utils/copyToClipboard.js +1 -2
  187. package/lib/table/utils/exportTableAsExcel.js +3 -3
  188. package/lib/table/utils/getTreeDepth.js +3 -3
  189. package/lib/table/utils/groupBy.js +3 -3
  190. package/lib/table/utils/keyCode.js +1 -2
  191. package/lib/table/utils/makeRecursiveMapper.js +3 -3
  192. package/lib/table/utils/mergeCellProps.js +0 -1
  193. package/lib/table/utils/others.js +4 -5
  194. package/lib/table/utils/proto.js +1 -2
  195. package/lib/table/utils/selectColumn.js +2 -4
  196. package/lib/table/utils/traverseColumn.js +3 -3
  197. package/lib/table/utils/tree-data-helpers/StrictTreeDataHelper.js +9 -11
  198. package/lib/table/utils/tree-data-helpers/TreeDataHelper.js +6 -8
  199. 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 rowHeight = (opt === null || opt === void 0 ? void 0 : opt.rowHeight) || 48;
46
- var handleDragStrat = function handleDragStrat(event) {
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
- artTable.classList.add(cx(Classes.rowDragging));
50
- (_a = opt === null || opt === void 0 ? void 0 : opt.onDragStart) === null || _a === void 0 ? void 0 : _a.call(opt, event);
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 handleDragMove = function handleDragMove(event) {
109
+ var onDragStop = function onDragStop(event) {
53
110
  var _a;
54
- (_a = opt === null || opt === void 0 ? void 0 : opt.onDragMove) === null || _a === void 0 ? void 0 : _a.call(opt, event);
55
- pipeline.setStateAtKey(rowDragKey, event);
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 handleDragEnd = function handleDragEnd(event, isValid) {
115
+ var onDragStart = function onDragStart(event) {
58
116
  var _a;
59
- artTable.classList.remove(cx(Classes.rowDragging));
60
- pipeline.setStateAtKey(rowDragKey, event);
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 getDragEvent = function getDragEvent(startRowInfo, endRowInfo, _ref) {
67
- var isFinished = _ref.isFinished,
68
- _ref$dragPosition = _ref.dragPosition,
69
- dragPosition = _ref$dragPosition === void 0 ? 'bottom' : _ref$dragPosition;
70
- return {
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 updateScrollPosition = function updateScrollPosition(mouseMoveEvent) {
80
- if (opt === null || opt === void 0 ? void 0 : opt.suppressScrollMove) return;
81
- var clientY = mouseMoveEvent.clientY;
82
- var tableBodyClientRect = tableBody.getBoundingClientRect();
83
- var top = tableBodyClientRect.top,
84
- height = tableBodyClientRect.height;
85
- if (clientY + SCROLL_OFFSET >= top + height) {
86
- pipeline.ref.current.domHelper.tableBody.scrollTop += SCROLL_OFFSET;
87
- }
88
- if (clientY + SCROLL_OFFSET <= top) {
89
- pipeline.ref.current.domHelper.tableBody.scrollTop -= SCROLL_OFFSET;
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(mouseDownEvent) {
157
+ var onMouseDown = function onMouseDown(event) {
93
158
  var _a;
94
- var startRowInfo = getTargetRowInfo(mouseDownEvent.target, tableBody, dataSource);
95
- var endRowInfo = startRowInfo;
96
- if (!startRowInfo || startRowInfo.code !== rowDragColumn.code) return;
97
- if ((_a = opt === null || opt === void 0 ? void 0 : opt.isDisabled) === null || _a === void 0 ? void 0 : _a.call(opt, startRowInfo.row, startRowInfo.rowIndex)) return;
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 dragStartEvent = getDragEvent(startRowInfo, endRowInfo, {
103
- isFinished: false,
104
- dragPosition: 'bottom'
105
- });
106
- handleDragStrat(dragStartEvent);
107
- var tableWidth = tableBody.clientWidth;
108
- var startRowRects = startRowInfo.cell.getBoundingClientRect();
109
- // 光标位置距离初始拖拽行的偏移量
110
- var mouseDownClientY = mouseDownEvent.clientY;
111
- var startOffset = mouseDownEvent.clientY - startRowRects.top;
112
- var dragElement = createDragElement(startRowRects, tableWidth, rowHeight);
113
- // 可拖拽的范围
114
- var dragRange = getDragRange(tableBody, {
115
- startOffset: startOffset,
116
- rowHeight: rowHeight
117
- });
118
- var mousePosition = {
119
- x: mouseDownEvent.clientX,
120
- y: mouseDownEvent.clientY
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 mousemove$ = fromEvent(window, 'mousemove');
123
- var mouseup$ = fromEvent(window, 'mouseup');
124
- var scrollCallback = function scrollCallback(event) {
125
- // 在当前表格内滚动不处理
126
- if (event.target === tableBody) return;
127
- dragRange = getDragRange(tableBody, {
128
- startOffset: startOffset,
129
- rowHeight: rowHeight
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
- var isOutOfRange = isOutOfDragRange(mousePosition, dragRange);
132
- updateCurSorStyle(isOutOfRange);
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
- document.addEventListener('scroll', scrollCallback, true);
135
- var rowDrag$ = mousemove$.pipe(filter(function (mouseMoveEvent) {
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
- var clientX = mouseMoveEvent.clientX,
144
- clientY = mouseMoveEvent.clientY;
145
- var tagretRow = getTargetRowInfo(mouseMoveEvent.target, tableBody, dataSource);
146
- if (tagretRow) {
147
- endRowInfo = tagretRow;
329
+ if (!isDragging) {
330
+ isDragging = true;
331
+ handleDragStart(mouseDownEvent);
332
+ handleDragMove(mouseDownEvent);
148
333
  }
149
- var targetRowRects = endRowInfo.cell.getBoundingClientRect();
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
- rowDrag$.subscribe({
175
- next: function next(_ref2) {
176
- var startRowInfo = _ref2.startRowInfo,
177
- endRowInfo = _ref2.endRowInfo,
178
- dragPosition = _ref2.dragPosition;
179
- var dragMoveEvent = getDragEvent(startRowInfo, endRowInfo, {
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
- if (isFooterCell || isFinished || rowIndex !== startRowIndex && rowIndex !== endRowIndex) return;
215
- var className = cx((_cx = {}, _defineProperty(_cx, Classes.rowDragStart, rowIndex === startRowIndex), _defineProperty(_cx, Classes.rowDragEnd, rowIndex === endRowIndex), _defineProperty(_cx, Classes.rowDragEndToTop, rowIndex === endRowIndex && dragPosition === 'top'), _defineProperty(_cx, Classes.rowDragEndToBottom, rowIndex === endRowIndex && dragPosition === 'bottom'), _cx));
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 getTargetRowInfo(target, tableBody, record) {
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(rects, tableWidth, rowHeight) {
252
- var _context2, _context3, _context4;
253
- var x = rects.x,
254
- y = rects.y;
255
- var dragMoveElement = document.createElement('div');
256
- dragMoveElement.className = cx(Classes.rowDragElement);
257
- dragMoveElement.style.cssText = _concatInstanceProperty(_context2 = _concatInstanceProperty(_context3 = _concatInstanceProperty(_context4 = "position:fixed;z-index:9999;left:".concat(x, "px;top:")).call(_context4, y, "px;pointer-events:none;width:")).call(_context3, tableWidth, "px;height:")).call(_context2, rowHeight, "px;background:var(--primary-color);opacity: 0.1;");
258
- document.body.appendChild(dragMoveElement);
259
- return dragMoveElement;
260
- }
261
- function updateDragElementPosition(element, dragRange, _ref3) {
262
- var x = _ref3.x,
263
- y = _ref3.y,
264
- startOffset = _ref3.startOffset;
265
- var validPosition = getValidPosition({
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 removeDragElement(element) {
273
- document.body.removeChild(element);
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 updateCurSorStyle(isOutOfRange) {
276
- if (isOutOfRange) {
277
- document.body.style.cursor = 'no-drop';
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
- document.body.style.cursor = 'move';
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 removeCurSorStyle() {
283
- document.body.style.cursor = 'default';
524
+ function showDragLine(lineElement) {
525
+ lineElement.style.display = 'block';
284
526
  }
285
- function getDragRange(tableBody, _ref4) {
286
- var startOffset = _ref4.startOffset,
287
- rowHeight = _ref4.rowHeight;
288
- var tableBodyClientRect = tableBody.getBoundingClientRect();
289
- var height = tableBodyClientRect.height,
290
- width = tableBodyClientRect.width,
291
- top = tableBodyClientRect.top,
292
- left = tableBodyClientRect.left;
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
- minX: left,
295
- maxX: left + width,
296
- minY: top - rowHeight + startOffset,
297
- maxY: top + height + startOffset
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 getValidPosition(position, dragRange) {
301
- var x = position.x,
302
- y = position.y;
303
- var minX = dragRange.minX,
304
- maxX = dragRange.maxX,
305
- minY = dragRange.minY,
306
- maxY = dragRange.maxY;
307
- var newX = x < minX ? minX : x > maxX ? maxX : x;
308
- var newY = y < minY ? minY : y > maxY ? maxY : y;
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
- x: newX,
311
- y: newY
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 isOutOfDragRange(position, dragRange) {
315
- var x = position.x,
316
- y = position.y;
317
- var minX = dragRange.minX,
318
- maxX = dragRange.maxX,
319
- minY = dragRange.minY,
320
- maxY = dragRange.maxY;
321
- return x > maxX || x < minX || y > maxY || y < minY;
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
+ };