@kdcloudjs/table 1.2.1-canary.7 → 1.2.2-canary.10

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 (589) 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 +1405 -470
  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 +17 -7
  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/arrayUtil.d.ts +0 -0
  15. package/es/_utils/arrayUtil.js +0 -0
  16. package/es/_utils/devwarning.d.ts +0 -0
  17. package/es/_utils/devwarning.js +0 -0
  18. package/es/_utils/formatUtil.d.ts +0 -0
  19. package/es/_utils/formatUtil.js +0 -0
  20. package/es/_utils/hooks.d.ts +0 -0
  21. package/es/_utils/hooks.js +0 -0
  22. package/es/_utils/index.d.ts +0 -0
  23. package/es/_utils/index.js +0 -0
  24. package/es/_utils/numberUtil.d.ts +0 -0
  25. package/es/_utils/numberUtil.js +0 -0
  26. package/es/_utils/omit.d.ts +0 -0
  27. package/es/_utils/omit.js +0 -0
  28. package/es/_utils/react-children.d.ts +0 -0
  29. package/es/_utils/react-children.js +0 -0
  30. package/es/_utils/type.d.ts +0 -0
  31. package/es/_utils/type.js +0 -0
  32. package/es/_utils/usePopper.d.ts +0 -0
  33. package/es/_utils/usePopper.js +0 -0
  34. package/es/config-provider/ConfigContext.d.ts +0 -0
  35. package/es/config-provider/ConfigContext.js +0 -0
  36. package/es/config-provider/compDefaultProps.d.ts +0 -0
  37. package/es/config-provider/compDefaultProps.js +0 -0
  38. package/es/config-provider/configProvider.d.ts +0 -0
  39. package/es/config-provider/configProvider.js +0 -0
  40. package/es/config-provider/defaultConfig.d.ts +0 -0
  41. package/es/config-provider/defaultConfig.js +0 -0
  42. package/es/config-provider/index.d.ts +0 -0
  43. package/es/config-provider/index.js +0 -0
  44. package/es/index.d.ts +0 -0
  45. package/es/index.js +0 -0
  46. package/es/locale/index.d.ts +0 -0
  47. package/es/locale/index.js +0 -0
  48. package/es/locale/locale.d.ts +0 -0
  49. package/es/locale/locale.js +2 -2
  50. package/es/locale/zh-CN.d.ts +0 -0
  51. package/es/locale/zh-CN.js +0 -0
  52. package/es/style/color/colors.less +1 -1
  53. package/es/style/core/index.less +1 -1
  54. package/es/style/core/motion/other.less +27 -27
  55. package/es/style/core/motion/slide.less +53 -53
  56. package/es/style/core/motion.less +1 -1
  57. package/es/style/core/reset.less +185 -185
  58. package/es/style/css.js +0 -0
  59. package/es/style/index.css +0 -0
  60. package/es/style/index.d.ts +0 -0
  61. package/es/style/index.js +0 -0
  62. package/es/style/index.less +1 -1
  63. package/es/style/mixins/index.less +18 -18
  64. package/es/style/mixins/overlay.less +21 -21
  65. package/es/style/mixins/reset.less +12 -12
  66. package/es/style/themes/default.less +445 -445
  67. package/es/style/themes/index.less +0 -0
  68. package/es/table/base/calculations.d.ts +0 -0
  69. package/es/table/base/calculations.js +0 -0
  70. package/es/table/base/colgroup.d.ts +0 -0
  71. package/es/table/base/colgroup.js +0 -0
  72. package/es/table/base/empty.d.ts +0 -0
  73. package/es/table/base/empty.js +1 -1
  74. package/es/table/base/globalStyleComponent.d.ts +4 -0
  75. package/es/table/base/globalStyleComponent.js +24 -0
  76. package/es/table/base/header.d.ts +0 -0
  77. package/es/table/base/header.js +0 -0
  78. package/es/table/base/helpers/SpanManager.d.ts +0 -0
  79. package/es/table/base/helpers/SpanManager.js +0 -0
  80. package/es/table/base/helpers/TableDOMUtils.d.ts +0 -0
  81. package/es/table/base/helpers/TableDOMUtils.js +0 -0
  82. package/es/table/base/helpers/__test__/SpanManager.test.d.ts +0 -0
  83. package/es/table/base/helpers/__test__/SpanManager.test.js +0 -0
  84. package/es/table/base/helpers/__test__/TableDOMUtils.test.d.ts +0 -0
  85. package/es/table/base/helpers/__test__/TableDOMUtils.test.js +0 -0
  86. package/es/table/base/helpers/__test__/rowHeightManager.test.d.ts +0 -0
  87. package/es/table/base/helpers/__test__/rowHeightManager.test.js +0 -0
  88. package/es/table/base/helpers/getRichVisibleRectsStream.d.ts +0 -0
  89. package/es/table/base/helpers/getRichVisibleRectsStream.js +0 -0
  90. package/es/table/base/helpers/rowHeightManager.d.ts +0 -0
  91. package/es/table/base/helpers/rowHeightManager.js +0 -0
  92. package/es/table/base/html-table.d.ts +0 -0
  93. package/es/table/base/html-table.js +0 -0
  94. package/es/table/base/index.d.ts +0 -0
  95. package/es/table/base/index.js +0 -0
  96. package/es/table/base/interfaces.d.ts +0 -0
  97. package/es/table/base/interfaces.js +0 -0
  98. package/es/table/base/loading.d.ts +0 -0
  99. package/es/table/base/loading.js +1 -1
  100. package/es/table/base/renderTemplates.d.ts +0 -0
  101. package/es/table/base/renderTemplates.js +11 -11
  102. package/es/table/base/styles.d.ts +11 -0
  103. package/es/table/base/styles.js +18 -7
  104. package/es/table/base/table.d.ts +0 -0
  105. package/es/table/base/table.js +5 -4
  106. package/es/table/base/utils.d.ts +0 -0
  107. package/es/table/base/utils.js +0 -0
  108. package/es/table/common-views.d.ts +0 -0
  109. package/es/table/common-views.js +0 -0
  110. package/es/table/index.d.ts +0 -0
  111. package/es/table/index.js +0 -0
  112. package/es/table/interfaces.d.ts +41 -0
  113. package/es/table/interfaces.js +0 -0
  114. package/es/table/internals.d.ts +0 -0
  115. package/es/table/internals.js +0 -0
  116. package/es/table/pipeline/const.d.ts +3 -0
  117. package/es/table/pipeline/const.js +3 -0
  118. package/es/table/pipeline/features/autoFill.d.ts +0 -0
  119. package/es/table/pipeline/features/autoFill.js +0 -0
  120. package/es/table/pipeline/features/autoRowSpan.d.ts +0 -0
  121. package/es/table/pipeline/features/autoRowSpan.js +0 -0
  122. package/es/table/pipeline/features/buildTree.d.ts +0 -0
  123. package/es/table/pipeline/features/buildTree.js +0 -0
  124. package/es/table/pipeline/features/colGroupExtendable.d.ts +0 -0
  125. package/es/table/pipeline/features/colGroupExtendable.js +0 -0
  126. package/es/table/pipeline/features/columnDrag.d.ts +0 -0
  127. package/es/table/pipeline/features/columnDrag.js +0 -0
  128. package/es/table/pipeline/features/columnFilter.d.ts +0 -0
  129. package/es/table/pipeline/features/columnFilter.js +0 -0
  130. package/es/table/pipeline/features/columnHover.d.ts +0 -0
  131. package/es/table/pipeline/features/columnHover.js +0 -0
  132. package/es/table/pipeline/features/columnRangeHover.d.ts +0 -0
  133. package/es/table/pipeline/features/columnRangeHover.js +0 -0
  134. package/es/table/pipeline/features/columnResizeWidth.d.ts +0 -0
  135. package/es/table/pipeline/features/columnResizeWidth.js +1 -1
  136. package/es/table/pipeline/features/contextMenu.d.ts +0 -0
  137. package/es/table/pipeline/features/contextMenu.js +0 -0
  138. package/es/table/pipeline/features/featureApi/RowDragApi.d.ts +15 -0
  139. package/es/table/pipeline/features/featureApi/RowDragApi.js +66 -0
  140. package/es/table/pipeline/features/featureApi/utils.d.ts +2 -0
  141. package/es/table/pipeline/features/featureApi/utils.js +10 -0
  142. package/es/table/pipeline/features/filter/DefaultFilterContent.d.ts +0 -0
  143. package/es/table/pipeline/features/filter/DefaultFilterContent.js +1 -1
  144. package/es/table/pipeline/features/filter/DefaultFilterIcon.d.ts +0 -0
  145. package/es/table/pipeline/features/filter/DefaultFilterIcon.js +0 -0
  146. package/es/table/pipeline/features/filter/Filter.d.ts +0 -0
  147. package/es/table/pipeline/features/filter/Filter.js +1 -1
  148. package/es/table/pipeline/features/filter/FilterPanel.d.ts +0 -0
  149. package/es/table/pipeline/features/filter/FilterPanel.js +0 -0
  150. package/es/table/pipeline/features/filter/index.d.ts +0 -0
  151. package/es/table/pipeline/features/filter/index.js +0 -0
  152. package/es/table/pipeline/features/filter/util.d.ts +0 -0
  153. package/es/table/pipeline/features/filter/util.js +0 -0
  154. package/es/table/pipeline/features/footerDataSource.d.ts +0 -0
  155. package/es/table/pipeline/features/footerDataSource.js +0 -0
  156. package/es/table/pipeline/features/index.d.ts +0 -0
  157. package/es/table/pipeline/features/index.js +0 -0
  158. package/es/table/pipeline/features/mergeCellHover.d.ts +0 -0
  159. package/es/table/pipeline/features/mergeCellHover.js +0 -0
  160. package/es/table/pipeline/features/multiSelect.d.ts +0 -0
  161. package/es/table/pipeline/features/multiSelect.js +0 -0
  162. package/es/table/pipeline/features/rangeSelection.d.ts +0 -0
  163. package/es/table/pipeline/features/rangeSelection.js +0 -0
  164. package/es/table/pipeline/features/rowDetail.d.ts +0 -0
  165. package/es/table/pipeline/features/rowDetail.js +1 -1
  166. package/es/table/pipeline/features/rowDrag.d.ts +12 -12
  167. package/es/table/pipeline/features/rowDrag.js +605 -191
  168. package/es/table/pipeline/features/rowGrouping.d.ts +0 -0
  169. package/es/table/pipeline/features/rowGrouping.js +1 -1
  170. package/es/table/pipeline/features/singleSelect.d.ts +0 -0
  171. package/es/table/pipeline/features/singleSelect.js +0 -0
  172. package/es/table/pipeline/features/sort.d.ts +0 -0
  173. package/es/table/pipeline/features/sort.js +1 -1
  174. package/es/table/pipeline/features/tips.d.ts +0 -0
  175. package/es/table/pipeline/features/tips.js +1 -1
  176. package/es/table/pipeline/features/treeMode.d.ts +1 -0
  177. package/es/table/pipeline/features/treeMode.js +41 -11
  178. package/es/table/pipeline/features/treeSelect.d.ts +0 -0
  179. package/es/table/pipeline/features/treeSelect.js +0 -0
  180. package/es/table/pipeline/index.d.ts +0 -0
  181. package/es/table/pipeline/index.js +0 -0
  182. package/es/table/pipeline/pipeline.d.ts +3 -0
  183. package/es/table/pipeline/pipeline.js +23 -1
  184. package/es/table/pivot/cross-table/buildCrossTable.d.ts +0 -0
  185. package/es/table/pivot/cross-table/buildCrossTable.js +0 -0
  186. package/es/table/pivot/cross-table/constants.d.ts +0 -0
  187. package/es/table/pivot/cross-table/constants.js +0 -0
  188. package/es/table/pivot/cross-table/cross-table.d.ts +0 -0
  189. package/es/table/pivot/cross-table/cross-table.js +0 -0
  190. package/es/table/pivot/cross-table/index.d.ts +0 -0
  191. package/es/table/pivot/cross-table/index.js +0 -0
  192. package/es/table/pivot/cross-table/interfaces.d.ts +0 -0
  193. package/es/table/pivot/cross-table/interfaces.js +0 -0
  194. package/es/table/pivot/cross-table/internals.d.ts +0 -0
  195. package/es/table/pivot/cross-table/internals.js +0 -0
  196. package/es/table/pivot/cross-tree-table/buildCrossTreeTable.d.ts +0 -0
  197. package/es/table/pivot/cross-tree-table/buildCrossTreeTable.js +0 -0
  198. package/es/table/pivot/cross-tree-table/cross-tree-table.d.ts +0 -0
  199. package/es/table/pivot/cross-tree-table/cross-tree-table.js +0 -0
  200. package/es/table/pivot/cross-tree-table/index.d.ts +0 -0
  201. package/es/table/pivot/cross-tree-table/index.js +0 -0
  202. package/es/table/pivot/pivot-utils/buildDrillTree.d.ts +0 -0
  203. package/es/table/pivot/pivot-utils/buildDrillTree.js +0 -0
  204. package/es/table/pivot/pivot-utils/builders.d.ts +0 -0
  205. package/es/table/pivot/pivot-utils/builders.js +0 -0
  206. package/es/table/pivot/pivot-utils/convert-utils.d.ts +0 -0
  207. package/es/table/pivot/pivot-utils/convert-utils.js +0 -0
  208. package/es/table/pivot/pivot-utils/index.d.ts +0 -0
  209. package/es/table/pivot/pivot-utils/index.js +0 -0
  210. package/es/table/pivot/pivot-utils/interfaces.d.ts +0 -0
  211. package/es/table/pivot/pivot-utils/interfaces.js +0 -0
  212. package/es/table/pivot/pivot-utils/simpleEncode.d.ts +0 -0
  213. package/es/table/pivot/pivot-utils/simpleEncode.js +0 -0
  214. package/es/table/style/css.js +0 -0
  215. package/es/table/style/index.css +0 -0
  216. package/es/table/style/index.d.ts +0 -0
  217. package/es/table/style/index.js +0 -0
  218. package/es/table/style/index.less +1 -1
  219. package/es/table/transforms/autoRowSpan.d.ts +0 -0
  220. package/es/table/transforms/autoRowSpan.js +0 -0
  221. package/es/table/transforms/autoWidth.d.ts +0 -0
  222. package/es/table/transforms/autoWidth.js +0 -0
  223. package/es/table/transforms/buildTree.d.ts +0 -0
  224. package/es/table/transforms/buildTree.js +0 -0
  225. package/es/table/transforms/columnHover.d.ts +0 -0
  226. package/es/table/transforms/columnHover.js +0 -0
  227. package/es/table/transforms/columnRangeHover.d.ts +0 -0
  228. package/es/table/transforms/columnRangeHover.js +0 -0
  229. package/es/table/transforms/columnResize.d.ts +0 -0
  230. package/es/table/transforms/columnResize.js +1 -1
  231. package/es/table/transforms/flatten.d.ts +0 -0
  232. package/es/table/transforms/flatten.js +0 -0
  233. package/es/table/transforms/index.d.ts +0 -0
  234. package/es/table/transforms/index.js +0 -0
  235. package/es/table/transforms/orderField.d.ts +0 -0
  236. package/es/table/transforms/orderField.js +0 -0
  237. package/es/table/transforms/sort.d.ts +0 -0
  238. package/es/table/transforms/sort.js +1 -1
  239. package/es/table/transforms/tips.d.ts +0 -0
  240. package/es/table/transforms/tips.js +1 -1
  241. package/es/table/transforms/treeMode.d.ts +0 -0
  242. package/es/table/transforms/treeMode.js +1 -1
  243. package/es/table/transforms/visible.d.ts +0 -0
  244. package/es/table/transforms/visible.js +0 -0
  245. package/es/table/transforms/warnTransformsDeprecated.d.ts +0 -0
  246. package/es/table/transforms/warnTransformsDeprecated.js +0 -0
  247. package/es/table/use/useResizeObserver.d.ts +0 -0
  248. package/es/table/use/useResizeObserver.js +0 -0
  249. package/es/table/utils/applyTransforms.d.ts +0 -0
  250. package/es/table/utils/applyTransforms.js +0 -0
  251. package/es/table/utils/browserType.d.ts +0 -0
  252. package/es/table/utils/browserType.js +0 -0
  253. package/es/table/utils/buildTree.d.ts +0 -0
  254. package/es/table/utils/buildTree.js +0 -0
  255. package/es/table/utils/collectNodes.d.ts +0 -0
  256. package/es/table/utils/collectNodes.js +0 -0
  257. package/es/table/utils/console.d.ts +0 -0
  258. package/es/table/utils/console.js +0 -0
  259. package/es/table/utils/copyToClipboard.d.ts +0 -0
  260. package/es/table/utils/copyToClipboard.js +0 -0
  261. package/es/table/utils/element.d.ts +0 -0
  262. package/es/table/utils/element.js +0 -0
  263. package/es/table/utils/exportTableAsExcel.d.ts +0 -0
  264. package/es/table/utils/exportTableAsExcel.js +0 -0
  265. package/es/table/utils/getTreeDepth.d.ts +0 -0
  266. package/es/table/utils/getTreeDepth.js +0 -0
  267. package/es/table/utils/groupBy.d.ts +0 -0
  268. package/es/table/utils/groupBy.js +0 -0
  269. package/es/table/utils/index.d.ts +0 -0
  270. package/es/table/utils/index.js +0 -0
  271. package/es/table/utils/isGroupColumn.d.ts +0 -0
  272. package/es/table/utils/isGroupColumn.js +0 -0
  273. package/es/table/utils/isLeafNode.d.ts +0 -0
  274. package/es/table/utils/isLeafNode.js +0 -0
  275. package/es/table/utils/keyCode.d.ts +0 -0
  276. package/es/table/utils/keyCode.js +0 -0
  277. package/es/table/utils/layeredFilter.d.ts +0 -0
  278. package/es/table/utils/layeredFilter.js +0 -0
  279. package/es/table/utils/layeredSort.d.ts +0 -0
  280. package/es/table/utils/layeredSort.js +0 -0
  281. package/es/table/utils/makeRecursiveMapper.d.ts +0 -0
  282. package/es/table/utils/makeRecursiveMapper.js +0 -0
  283. package/es/table/utils/mergeCellProps.d.ts +0 -0
  284. package/es/table/utils/mergeCellProps.js +0 -0
  285. package/es/table/utils/others.d.ts +0 -0
  286. package/es/table/utils/others.js +0 -0
  287. package/es/table/utils/proto.d.ts +0 -0
  288. package/es/table/utils/proto.js +0 -0
  289. package/es/table/utils/selectColumn.d.ts +0 -0
  290. package/es/table/utils/selectColumn.js +0 -0
  291. package/es/table/utils/smartCompare.d.ts +0 -0
  292. package/es/table/utils/smartCompare.js +0 -0
  293. package/es/table/utils/traverseColumn.d.ts +0 -0
  294. package/es/table/utils/traverseColumn.js +0 -0
  295. package/es/table/utils/tree-data-helpers/StrictTreeDataHelper.d.ts +0 -0
  296. package/es/table/utils/tree-data-helpers/StrictTreeDataHelper.js +0 -0
  297. package/es/table/utils/tree-data-helpers/TreeDataHelper.d.ts +0 -0
  298. package/es/table/utils/tree-data-helpers/TreeDataHelper.js +0 -0
  299. package/es/table/utils/uiDegrade.d.ts +0 -0
  300. package/es/table/utils/uiDegrade.js +0 -0
  301. package/lib/_utils/arrayUtil.d.ts +0 -0
  302. package/lib/_utils/arrayUtil.js +0 -0
  303. package/lib/_utils/devwarning.d.ts +0 -0
  304. package/lib/_utils/devwarning.js +0 -0
  305. package/lib/_utils/formatUtil.d.ts +0 -0
  306. package/lib/_utils/formatUtil.js +0 -0
  307. package/lib/_utils/hooks.d.ts +0 -0
  308. package/lib/_utils/hooks.js +0 -0
  309. package/lib/_utils/index.d.ts +0 -0
  310. package/lib/_utils/index.js +0 -0
  311. package/lib/_utils/numberUtil.d.ts +0 -0
  312. package/lib/_utils/numberUtil.js +0 -0
  313. package/lib/_utils/omit.d.ts +0 -0
  314. package/lib/_utils/omit.js +0 -0
  315. package/lib/_utils/react-children.d.ts +0 -0
  316. package/lib/_utils/react-children.js +0 -0
  317. package/lib/_utils/type.d.ts +0 -0
  318. package/lib/_utils/type.js +0 -0
  319. package/lib/_utils/usePopper.d.ts +0 -0
  320. package/lib/_utils/usePopper.js +0 -0
  321. package/lib/config-provider/ConfigContext.d.ts +0 -0
  322. package/lib/config-provider/ConfigContext.js +0 -0
  323. package/lib/config-provider/compDefaultProps.d.ts +0 -0
  324. package/lib/config-provider/compDefaultProps.js +0 -0
  325. package/lib/config-provider/configProvider.d.ts +0 -0
  326. package/lib/config-provider/configProvider.js +0 -0
  327. package/lib/config-provider/defaultConfig.d.ts +0 -0
  328. package/lib/config-provider/defaultConfig.js +0 -0
  329. package/lib/config-provider/index.d.ts +0 -0
  330. package/lib/config-provider/index.js +0 -0
  331. package/lib/index.d.ts +0 -0
  332. package/lib/index.js +0 -0
  333. package/lib/locale/index.d.ts +0 -0
  334. package/lib/locale/index.js +0 -0
  335. package/lib/locale/locale.d.ts +0 -0
  336. package/lib/locale/locale.js +2 -2
  337. package/lib/locale/zh-CN.d.ts +0 -0
  338. package/lib/locale/zh-CN.js +0 -0
  339. package/lib/style/color/colors.less +1 -1
  340. package/lib/style/components.less +1 -1
  341. package/lib/style/core/index.less +1 -1
  342. package/lib/style/core/motion/other.less +27 -27
  343. package/lib/style/core/motion/slide.less +53 -53
  344. package/lib/style/core/motion.less +1 -1
  345. package/lib/style/core/reset.less +185 -185
  346. package/lib/style/css.js +0 -0
  347. package/lib/style/index.css +0 -0
  348. package/lib/style/index.d.ts +0 -0
  349. package/lib/style/index.js +0 -0
  350. package/lib/style/index.less +1 -1
  351. package/lib/style/mixins/index.less +18 -18
  352. package/lib/style/mixins/overlay.less +21 -21
  353. package/lib/style/mixins/reset.less +12 -12
  354. package/lib/style/themes/default.less +445 -445
  355. package/lib/style/themes/index.less +0 -0
  356. package/lib/table/base/calculations.d.ts +0 -0
  357. package/lib/table/base/calculations.js +0 -0
  358. package/lib/table/base/colgroup.d.ts +0 -0
  359. package/lib/table/base/colgroup.js +0 -0
  360. package/lib/table/base/empty.d.ts +0 -0
  361. package/lib/table/base/empty.js +1 -1
  362. package/lib/table/base/globalStyleComponent.d.ts +4 -0
  363. package/lib/table/base/globalStyleComponent.js +35 -0
  364. package/lib/table/base/header.d.ts +0 -0
  365. package/lib/table/base/header.js +0 -0
  366. package/lib/table/base/helpers/SpanManager.d.ts +0 -0
  367. package/lib/table/base/helpers/SpanManager.js +0 -0
  368. package/lib/table/base/helpers/TableDOMUtils.d.ts +0 -0
  369. package/lib/table/base/helpers/TableDOMUtils.js +0 -0
  370. package/lib/table/base/helpers/__test__/SpanManager.test.d.ts +0 -0
  371. package/lib/table/base/helpers/__test__/SpanManager.test.js +0 -0
  372. package/lib/table/base/helpers/__test__/TableDOMUtils.test.d.ts +0 -0
  373. package/lib/table/base/helpers/__test__/TableDOMUtils.test.js +0 -0
  374. package/lib/table/base/helpers/__test__/rowHeightManager.test.d.ts +0 -0
  375. package/lib/table/base/helpers/__test__/rowHeightManager.test.js +0 -0
  376. package/lib/table/base/helpers/getRichVisibleRectsStream.d.ts +0 -0
  377. package/lib/table/base/helpers/getRichVisibleRectsStream.js +0 -0
  378. package/lib/table/base/helpers/rowHeightManager.d.ts +0 -0
  379. package/lib/table/base/helpers/rowHeightManager.js +0 -0
  380. package/lib/table/base/html-table.d.ts +0 -0
  381. package/lib/table/base/html-table.js +0 -0
  382. package/lib/table/base/index.d.ts +0 -0
  383. package/lib/table/base/index.js +0 -0
  384. package/lib/table/base/interfaces.d.ts +0 -0
  385. package/lib/table/base/interfaces.js +0 -0
  386. package/lib/table/base/loading.d.ts +0 -0
  387. package/lib/table/base/loading.js +1 -1
  388. package/lib/table/base/renderTemplates.d.ts +0 -0
  389. package/lib/table/base/renderTemplates.js +11 -11
  390. package/lib/table/base/styles.d.ts +11 -0
  391. package/lib/table/base/styles.js +18 -7
  392. package/lib/table/base/table.d.ts +0 -0
  393. package/lib/table/base/table.js +5 -4
  394. package/lib/table/base/utils.d.ts +0 -0
  395. package/lib/table/base/utils.js +0 -0
  396. package/lib/table/common-views.d.ts +0 -0
  397. package/lib/table/common-views.js +0 -0
  398. package/lib/table/index.d.ts +0 -0
  399. package/lib/table/index.js +0 -0
  400. package/lib/table/interfaces.d.ts +41 -0
  401. package/lib/table/interfaces.js +0 -0
  402. package/lib/table/internals.d.ts +0 -0
  403. package/lib/table/internals.js +0 -0
  404. package/lib/table/pipeline/const.d.ts +3 -0
  405. package/lib/table/pipeline/const.js +9 -0
  406. package/lib/table/pipeline/features/autoFill.d.ts +0 -0
  407. package/lib/table/pipeline/features/autoFill.js +0 -0
  408. package/lib/table/pipeline/features/autoRowSpan.d.ts +0 -0
  409. package/lib/table/pipeline/features/autoRowSpan.js +0 -0
  410. package/lib/table/pipeline/features/buildTree.d.ts +0 -0
  411. package/lib/table/pipeline/features/buildTree.js +0 -0
  412. package/lib/table/pipeline/features/colGroupExtendable.d.ts +0 -0
  413. package/lib/table/pipeline/features/colGroupExtendable.js +0 -0
  414. package/lib/table/pipeline/features/columnDrag.d.ts +0 -0
  415. package/lib/table/pipeline/features/columnDrag.js +0 -0
  416. package/lib/table/pipeline/features/columnFilter.d.ts +0 -0
  417. package/lib/table/pipeline/features/columnFilter.js +0 -0
  418. package/lib/table/pipeline/features/columnHover.d.ts +0 -0
  419. package/lib/table/pipeline/features/columnHover.js +0 -0
  420. package/lib/table/pipeline/features/columnRangeHover.d.ts +0 -0
  421. package/lib/table/pipeline/features/columnRangeHover.js +0 -0
  422. package/lib/table/pipeline/features/columnResizeWidth.d.ts +0 -0
  423. package/lib/table/pipeline/features/columnResizeWidth.js +1 -1
  424. package/lib/table/pipeline/features/contextMenu.d.ts +0 -0
  425. package/lib/table/pipeline/features/contextMenu.js +0 -0
  426. package/lib/table/pipeline/features/featureApi/RowDragApi.d.ts +15 -0
  427. package/lib/table/pipeline/features/featureApi/RowDragApi.js +72 -0
  428. package/lib/table/pipeline/features/featureApi/utils.d.ts +2 -0
  429. package/lib/table/pipeline/features/featureApi/utils.js +17 -0
  430. package/lib/table/pipeline/features/filter/DefaultFilterContent.d.ts +0 -0
  431. package/lib/table/pipeline/features/filter/DefaultFilterContent.js +1 -1
  432. package/lib/table/pipeline/features/filter/DefaultFilterIcon.d.ts +0 -0
  433. package/lib/table/pipeline/features/filter/DefaultFilterIcon.js +0 -0
  434. package/lib/table/pipeline/features/filter/Filter.d.ts +0 -0
  435. package/lib/table/pipeline/features/filter/Filter.js +1 -1
  436. package/lib/table/pipeline/features/filter/FilterPanel.d.ts +0 -0
  437. package/lib/table/pipeline/features/filter/FilterPanel.js +0 -0
  438. package/lib/table/pipeline/features/filter/index.d.ts +0 -0
  439. package/lib/table/pipeline/features/filter/index.js +0 -0
  440. package/lib/table/pipeline/features/filter/util.d.ts +0 -0
  441. package/lib/table/pipeline/features/filter/util.js +0 -0
  442. package/lib/table/pipeline/features/footerDataSource.d.ts +0 -0
  443. package/lib/table/pipeline/features/footerDataSource.js +0 -0
  444. package/lib/table/pipeline/features/index.d.ts +0 -0
  445. package/lib/table/pipeline/features/index.js +0 -0
  446. package/lib/table/pipeline/features/mergeCellHover.d.ts +0 -0
  447. package/lib/table/pipeline/features/mergeCellHover.js +0 -0
  448. package/lib/table/pipeline/features/multiSelect.d.ts +0 -0
  449. package/lib/table/pipeline/features/multiSelect.js +0 -0
  450. package/lib/table/pipeline/features/rangeSelection.d.ts +0 -0
  451. package/lib/table/pipeline/features/rangeSelection.js +0 -0
  452. package/lib/table/pipeline/features/rowDetail.d.ts +0 -0
  453. package/lib/table/pipeline/features/rowDetail.js +1 -1
  454. package/lib/table/pipeline/features/rowDrag.d.ts +12 -12
  455. package/lib/table/pipeline/features/rowDrag.js +606 -192
  456. package/lib/table/pipeline/features/rowGrouping.d.ts +0 -0
  457. package/lib/table/pipeline/features/rowGrouping.js +1 -1
  458. package/lib/table/pipeline/features/singleSelect.d.ts +0 -0
  459. package/lib/table/pipeline/features/singleSelect.js +0 -0
  460. package/lib/table/pipeline/features/sort.d.ts +0 -0
  461. package/lib/table/pipeline/features/sort.js +1 -1
  462. package/lib/table/pipeline/features/tips.d.ts +0 -0
  463. package/lib/table/pipeline/features/tips.js +1 -1
  464. package/lib/table/pipeline/features/treeMode.d.ts +1 -0
  465. package/lib/table/pipeline/features/treeMode.js +42 -11
  466. package/lib/table/pipeline/features/treeSelect.d.ts +0 -0
  467. package/lib/table/pipeline/features/treeSelect.js +0 -0
  468. package/lib/table/pipeline/index.d.ts +0 -0
  469. package/lib/table/pipeline/index.js +0 -0
  470. package/lib/table/pipeline/pipeline.d.ts +3 -0
  471. package/lib/table/pipeline/pipeline.js +23 -1
  472. package/lib/table/pivot/cross-table/buildCrossTable.d.ts +0 -0
  473. package/lib/table/pivot/cross-table/buildCrossTable.js +0 -0
  474. package/lib/table/pivot/cross-table/constants.d.ts +0 -0
  475. package/lib/table/pivot/cross-table/constants.js +0 -0
  476. package/lib/table/pivot/cross-table/cross-table.d.ts +0 -0
  477. package/lib/table/pivot/cross-table/cross-table.js +0 -0
  478. package/lib/table/pivot/cross-table/index.d.ts +0 -0
  479. package/lib/table/pivot/cross-table/index.js +0 -0
  480. package/lib/table/pivot/cross-table/interfaces.d.ts +0 -0
  481. package/lib/table/pivot/cross-table/interfaces.js +0 -0
  482. package/lib/table/pivot/cross-table/internals.d.ts +0 -0
  483. package/lib/table/pivot/cross-table/internals.js +0 -0
  484. package/lib/table/pivot/cross-tree-table/buildCrossTreeTable.d.ts +0 -0
  485. package/lib/table/pivot/cross-tree-table/buildCrossTreeTable.js +0 -0
  486. package/lib/table/pivot/cross-tree-table/cross-tree-table.d.ts +0 -0
  487. package/lib/table/pivot/cross-tree-table/cross-tree-table.js +0 -0
  488. package/lib/table/pivot/cross-tree-table/index.d.ts +0 -0
  489. package/lib/table/pivot/cross-tree-table/index.js +0 -0
  490. package/lib/table/pivot/pivot-utils/buildDrillTree.d.ts +0 -0
  491. package/lib/table/pivot/pivot-utils/buildDrillTree.js +0 -0
  492. package/lib/table/pivot/pivot-utils/builders.d.ts +0 -0
  493. package/lib/table/pivot/pivot-utils/builders.js +0 -0
  494. package/lib/table/pivot/pivot-utils/convert-utils.d.ts +0 -0
  495. package/lib/table/pivot/pivot-utils/convert-utils.js +0 -0
  496. package/lib/table/pivot/pivot-utils/index.d.ts +0 -0
  497. package/lib/table/pivot/pivot-utils/index.js +0 -0
  498. package/lib/table/pivot/pivot-utils/interfaces.d.ts +0 -0
  499. package/lib/table/pivot/pivot-utils/interfaces.js +0 -0
  500. package/lib/table/pivot/pivot-utils/simpleEncode.d.ts +0 -0
  501. package/lib/table/pivot/pivot-utils/simpleEncode.js +0 -0
  502. package/lib/table/style/css.js +0 -0
  503. package/lib/table/style/index.css +0 -0
  504. package/lib/table/style/index.d.ts +0 -0
  505. package/lib/table/style/index.js +0 -0
  506. package/lib/table/style/index.less +1 -1
  507. package/lib/table/transforms/autoRowSpan.d.ts +0 -0
  508. package/lib/table/transforms/autoRowSpan.js +0 -0
  509. package/lib/table/transforms/autoWidth.d.ts +0 -0
  510. package/lib/table/transforms/autoWidth.js +0 -0
  511. package/lib/table/transforms/buildTree.d.ts +0 -0
  512. package/lib/table/transforms/buildTree.js +0 -0
  513. package/lib/table/transforms/columnHover.d.ts +0 -0
  514. package/lib/table/transforms/columnHover.js +0 -0
  515. package/lib/table/transforms/columnRangeHover.d.ts +0 -0
  516. package/lib/table/transforms/columnRangeHover.js +0 -0
  517. package/lib/table/transforms/columnResize.d.ts +0 -0
  518. package/lib/table/transforms/columnResize.js +1 -1
  519. package/lib/table/transforms/flatten.d.ts +0 -0
  520. package/lib/table/transforms/flatten.js +0 -0
  521. package/lib/table/transforms/index.d.ts +0 -0
  522. package/lib/table/transforms/index.js +0 -0
  523. package/lib/table/transforms/orderField.d.ts +0 -0
  524. package/lib/table/transforms/orderField.js +0 -0
  525. package/lib/table/transforms/sort.d.ts +0 -0
  526. package/lib/table/transforms/sort.js +1 -1
  527. package/lib/table/transforms/tips.d.ts +0 -0
  528. package/lib/table/transforms/tips.js +1 -1
  529. package/lib/table/transforms/treeMode.d.ts +0 -0
  530. package/lib/table/transforms/treeMode.js +1 -1
  531. package/lib/table/transforms/visible.d.ts +0 -0
  532. package/lib/table/transforms/visible.js +0 -0
  533. package/lib/table/transforms/warnTransformsDeprecated.d.ts +0 -0
  534. package/lib/table/transforms/warnTransformsDeprecated.js +0 -0
  535. package/lib/table/use/useResizeObserver.d.ts +0 -0
  536. package/lib/table/use/useResizeObserver.js +0 -0
  537. package/lib/table/utils/applyTransforms.d.ts +0 -0
  538. package/lib/table/utils/applyTransforms.js +0 -0
  539. package/lib/table/utils/browserType.d.ts +0 -0
  540. package/lib/table/utils/browserType.js +0 -0
  541. package/lib/table/utils/buildTree.d.ts +0 -0
  542. package/lib/table/utils/buildTree.js +0 -0
  543. package/lib/table/utils/collectNodes.d.ts +0 -0
  544. package/lib/table/utils/collectNodes.js +0 -0
  545. package/lib/table/utils/console.d.ts +0 -0
  546. package/lib/table/utils/console.js +0 -0
  547. package/lib/table/utils/copyToClipboard.d.ts +0 -0
  548. package/lib/table/utils/copyToClipboard.js +0 -0
  549. package/lib/table/utils/element.d.ts +0 -0
  550. package/lib/table/utils/element.js +0 -0
  551. package/lib/table/utils/exportTableAsExcel.d.ts +0 -0
  552. package/lib/table/utils/exportTableAsExcel.js +0 -0
  553. package/lib/table/utils/getTreeDepth.d.ts +0 -0
  554. package/lib/table/utils/getTreeDepth.js +0 -0
  555. package/lib/table/utils/groupBy.d.ts +0 -0
  556. package/lib/table/utils/groupBy.js +0 -0
  557. package/lib/table/utils/index.d.ts +0 -0
  558. package/lib/table/utils/index.js +0 -0
  559. package/lib/table/utils/isGroupColumn.d.ts +0 -0
  560. package/lib/table/utils/isGroupColumn.js +0 -0
  561. package/lib/table/utils/isLeafNode.d.ts +0 -0
  562. package/lib/table/utils/isLeafNode.js +0 -0
  563. package/lib/table/utils/keyCode.d.ts +0 -0
  564. package/lib/table/utils/keyCode.js +0 -0
  565. package/lib/table/utils/layeredFilter.d.ts +0 -0
  566. package/lib/table/utils/layeredFilter.js +0 -0
  567. package/lib/table/utils/layeredSort.d.ts +0 -0
  568. package/lib/table/utils/layeredSort.js +0 -0
  569. package/lib/table/utils/makeRecursiveMapper.d.ts +0 -0
  570. package/lib/table/utils/makeRecursiveMapper.js +0 -0
  571. package/lib/table/utils/mergeCellProps.d.ts +0 -0
  572. package/lib/table/utils/mergeCellProps.js +0 -0
  573. package/lib/table/utils/others.d.ts +0 -0
  574. package/lib/table/utils/others.js +0 -0
  575. package/lib/table/utils/proto.d.ts +0 -0
  576. package/lib/table/utils/proto.js +0 -0
  577. package/lib/table/utils/selectColumn.d.ts +0 -0
  578. package/lib/table/utils/selectColumn.js +0 -0
  579. package/lib/table/utils/smartCompare.d.ts +0 -0
  580. package/lib/table/utils/smartCompare.js +0 -0
  581. package/lib/table/utils/traverseColumn.d.ts +0 -0
  582. package/lib/table/utils/traverseColumn.js +0 -0
  583. package/lib/table/utils/tree-data-helpers/StrictTreeDataHelper.d.ts +0 -0
  584. package/lib/table/utils/tree-data-helpers/StrictTreeDataHelper.js +0 -0
  585. package/lib/table/utils/tree-data-helpers/TreeDataHelper.d.ts +0 -0
  586. package/lib/table/utils/tree-data-helpers/TreeDataHelper.js +0 -0
  587. package/lib/table/utils/uiDegrade.d.ts +0 -0
  588. package/lib/table/utils/uiDegrade.js +0 -0
  589. package/package.json +218 -218
@@ -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);
@@ -205,13 +353,27 @@ export function rowDrag(opt) {
205
353
  });
206
354
  pipeline.appendRowPropsGetter(function (row, rowIndex) {
207
355
  var rowDragEvent = pipeline.getStateAtKey(rowDragKey) || {};
356
+ var dragStatus = rowDragApi.getDragStatus();
208
357
  var startRowIndex = rowDragEvent.startRowIndex,
209
358
  endRowIndex = rowDragEvent.endRowIndex,
359
+ endRow = rowDragEvent.endRow,
210
360
  isFinished = rowDragEvent.isFinished,
211
361
  dragPosition = rowDragEvent.dragPosition;
212
362
  var isFooterCell = row[pipeline.getFeatureOptions('footerRowMetaKey')];
213
- if (isFooterCell || isFinished || rowIndex !== startRowIndex && rowIndex !== endRowIndex) return;
214
- var className = cx(_defineProperty(_defineProperty(_defineProperty(_defineProperty({}, Classes.rowDragStart, rowIndex === startRowIndex), Classes.rowDragEnd, rowIndex === endRowIndex), Classes.rowDragEndToTop, rowIndex === endRowIndex && dragPosition === 'top'), Classes.rowDragEndToBottom, rowIndex === endRowIndex && dragPosition === 'bottom'));
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'));
215
377
  return {
216
378
  className: className
217
379
  };
@@ -219,7 +381,7 @@ export function rowDrag(opt) {
219
381
  return pipeline;
220
382
  };
221
383
  }
222
- function getTargetRowInfo(target, tableBody, record) {
384
+ function getDragRowItem(target, tableBody, record) {
223
385
  while (target && tableBody.contains(target)) {
224
386
  if (target.getAttribute('data-role') === 'table-cell') {
225
387
  var code = target.getAttribute('data-code');
@@ -238,6 +400,15 @@ function getTargetRowInfo(target, tableBody, record) {
238
400
  }
239
401
  return null;
240
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
+ }
241
412
  function isEleInFooter(target) {
242
413
  while (target && !target.classList.contains(Classes.artTable)) {
243
414
  if (target.classList.contains(Classes.tableFooter)) {
@@ -247,75 +418,318 @@ function isEleInFooter(target) {
247
418
  }
248
419
  return false;
249
420
  }
250
- function createDragElement(rects, tableWidth, rowHeight) {
251
- var _context2, _context3, _context4;
252
- var x = rects.x,
253
- y = rects.y;
254
- var dragMoveElement = document.createElement('div');
255
- dragMoveElement.className = cx(Classes.rowDragElement);
256
- 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;");
257
- document.body.appendChild(dragMoveElement);
258
- return dragMoveElement;
259
- }
260
- function updateDragElementPosition(element, dragRange, _ref3) {
261
- var x = _ref3.x,
262
- y = _ref3.y,
263
- startOffset = _ref3.startOffset;
264
- var validPosition = getValidPosition({
265
- x: x,
266
- y: y
267
- }, dragRange);
268
- element.style.top = validPosition.y - startOffset + 'px';
269
- 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;
270
436
  }
271
- function removeDragElement(element) {
272
- 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;
273
445
  }
274
- function updateCurSorStyle(isOutOfRange) {
275
- if (isOutOfRange) {
276
- 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';
277
466
  } else {
278
- 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';
279
522
  }
280
523
  }
281
- function removeCurSorStyle() {
282
- document.body.style.cursor = 'default';
524
+ function showDragLine(lineElement) {
525
+ lineElement.style.display = 'block';
283
526
  }
284
- function getDragRange(tableBody, _ref4) {
285
- var startOffset = _ref4.startOffset,
286
- rowHeight = _ref4.rowHeight;
287
- var tableBodyClientRect = tableBody.getBoundingClientRect();
288
- var height = tableBodyClientRect.height,
289
- width = tableBodyClientRect.width,
290
- top = tableBodyClientRect.top,
291
- 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;
292
560
  return {
293
- minX: left,
294
- maxX: left + width,
295
- minY: top - rowHeight + startOffset,
296
- 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)
297
565
  };
298
566
  }
299
- function getValidPosition(position, dragRange) {
300
- var x = position.x,
301
- y = position.y;
302
- var minX = dragRange.minX,
303
- maxX = dragRange.maxX,
304
- minY = dragRange.minY,
305
- maxY = dragRange.maxY;
306
- var newX = x < minX ? minX : x > maxX ? maxX : x;
307
- 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;
308
584
  return {
309
- x: newX,
310
- 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
311
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;
312
685
  }
313
- function isOutOfDragRange(position, dragRange) {
314
- var x = position.x,
315
- y = position.y;
316
- var minX = dragRange.minX,
317
- maxX = dragRange.maxX,
318
- minY = dragRange.minY,
319
- maxY = dragRange.maxY;
320
- return x > maxX || x < minX || y > maxY || y < minY;
321
- }
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
+ };