zmdms-webui 2.3.0 → 2.3.2

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 (283) hide show
  1. package/dist/es/canvastable/canvasTable.js +367 -0
  2. package/dist/es/canvastable/components/BadgePopover.js +27 -0
  3. package/dist/es/canvastable/components/CanvasTableMenu.js +74 -0
  4. package/dist/es/canvastable/components/CellOverlay.js +49 -0
  5. package/dist/es/canvastable/components/ColumnDynamic.js +12 -0
  6. package/dist/es/canvastable/components/EmptyPlaceholder.js +20 -0
  7. package/dist/es/canvastable/components/FilterPopover.js +274 -0
  8. package/dist/es/canvastable/components/HeaderOverlay.js +22 -0
  9. package/dist/es/canvastable/components/Tooltip.js +27 -0
  10. package/dist/es/canvastable/hooks/useClickOutside.js +30 -0
  11. package/dist/es/canvastable/hooks/useColumnResize.js +130 -0
  12. package/dist/es/canvastable/hooks/useContainerSize.js +40 -0
  13. package/dist/es/canvastable/hooks/useCopyToClipboard.js +150 -0
  14. package/dist/es/canvastable/hooks/useHeaderHeight.js +103 -0
  15. package/dist/es/canvastable/hooks/useMergeCells.js +111 -0
  16. package/dist/es/canvastable/hooks/useOverlays.js +364 -0
  17. package/dist/es/canvastable/hooks/usePopovers.js +93 -0
  18. package/dist/es/canvastable/hooks/useProcessedColumns.js +94 -0
  19. package/dist/es/canvastable/hooks/useScroll.js +251 -0
  20. package/dist/es/canvastable/hooks/useSummaryRow.js +81 -0
  21. package/dist/es/canvastable/hooks/useTableInteraction.js +804 -0
  22. package/dist/es/canvastable/hooks/useTableRender.js +1289 -0
  23. package/dist/es/canvastable/hooks/useTableSelection.js +57 -0
  24. package/dist/es/canvastable/hooks/useTableState.js +218 -0
  25. package/dist/es/canvastable/index.js +5 -0
  26. package/dist/es/canvastable/utils/canvasDrawHelpers.js +156 -0
  27. package/dist/es/canvastable/utils/cellHelpers.js +121 -0
  28. package/dist/es/canvastable/utils/columnHelpers.js +67 -0
  29. package/dist/es/canvastable/utils/constants.js +42 -0
  30. package/dist/es/canvastable/utils/formatHelpers.js +60 -0
  31. package/dist/es/canvastable/utils/interactionHelpers.js +176 -0
  32. package/dist/es/canvastable/utils/multiHeaderHelpers.js +82 -0
  33. package/dist/es/canvastable/utils/tableCalculations.js +100 -0
  34. package/dist/index.es.css +1 -1
  35. package/dist/index.es.js +1 -0
  36. package/package.json +1 -1
  37. package/dist/es/alert/alert.d.ts +0 -5
  38. package/dist/es/alert/index.css +0 -1
  39. package/dist/es/alert/index.d.ts +0 -5
  40. package/dist/es/alert/interface.d.ts +0 -14
  41. package/dist/es/applayout/appLayout.d.ts +0 -11
  42. package/dist/es/applayout/index.css +0 -1
  43. package/dist/es/applayout/index.d.ts +0 -5
  44. package/dist/es/applayoutheader/appLayoutHeader.d.ts +0 -16
  45. package/dist/es/applayoutheader/index.d.ts +0 -5
  46. package/dist/es/applayoutsider/appLayoutSider.d.ts +0 -57
  47. package/dist/es/applayoutsider/index.d.ts +0 -5
  48. package/dist/es/authloading/authLoading.d.ts +0 -5
  49. package/dist/es/authloading/index.css +0 -1
  50. package/dist/es/authloading/index.d.ts +0 -5
  51. package/dist/es/button/button.d.ts +0 -5
  52. package/dist/es/button/buttonDownload.d.ts +0 -25
  53. package/dist/es/button/buttonExport.d.ts +0 -15
  54. package/dist/es/button/buttonFullScreen.d.ts +0 -9
  55. package/dist/es/button/buttonPreview.d.ts +0 -26
  56. package/dist/es/button/index.css +0 -1
  57. package/dist/es/button/index.d.ts +0 -5
  58. package/dist/es/button/interface.d.ts +0 -34
  59. package/dist/es/calendar/index.d.ts +0 -7
  60. package/dist/es/cascader/index.css +0 -1
  61. package/dist/es/collapse/collapse.d.ts +0 -7
  62. package/dist/es/collapse/index.css +0 -1
  63. package/dist/es/collapse/index.d.ts +0 -5
  64. package/dist/es/collapse/interface.d.ts +0 -25
  65. package/dist/es/config/ZtxkContext.d.ts +0 -32
  66. package/dist/es/container/container.d.ts +0 -51
  67. package/dist/es/container/index.css +0 -1
  68. package/dist/es/container/index.d.ts +0 -5
  69. package/dist/es/datepicker/index.css +0 -1
  70. package/dist/es/datepicker/index.d.ts +0 -48
  71. package/dist/es/datepicker/interface.d.ts +0 -56
  72. package/dist/es/descriptions/descriptions.d.ts +0 -5
  73. package/dist/es/descriptions/index.css +0 -1
  74. package/dist/es/descriptions/index.d.ts +0 -5
  75. package/dist/es/descriptions/interface.d.ts +0 -12
  76. package/dist/es/detaillist/index.css +0 -1
  77. package/dist/es/detaillist/index.d.ts +0 -5
  78. package/dist/es/detaillist/item.d.ts +0 -35
  79. package/dist/es/detaillist/list.d.ts +0 -17
  80. package/dist/es/differences/differences.d.ts +0 -5
  81. package/dist/es/differences/index.css +0 -1
  82. package/dist/es/differences/index.d.ts +0 -5
  83. package/dist/es/differences/interface.d.ts +0 -17
  84. package/dist/es/dynamicsetting/dynamicSetting.d.ts +0 -6
  85. package/dist/es/dynamicsetting/index.css +0 -1
  86. package/dist/es/dynamicsetting/index.d.ts +0 -5
  87. package/dist/es/dynamicsetting/interface.d.ts +0 -43
  88. package/dist/es/electronsignatures/index.css +0 -1
  89. package/dist/es/electronsignatures/index.d.ts +0 -6
  90. package/dist/es/electronsignatures/interface.d.ts +0 -500
  91. package/dist/es/enhanceselect/enhance-select.d.ts +0 -6
  92. package/dist/es/enhanceselect/index.d.ts +0 -5
  93. package/dist/es/enhanceselect/interface.d.ts +0 -71
  94. package/dist/es/footer/footer.d.ts +0 -6
  95. package/dist/es/footer/index.css +0 -1
  96. package/dist/es/footer/index.d.ts +0 -5
  97. package/dist/es/footer/interface.d.ts +0 -34
  98. package/dist/es/form/form.d.ts +0 -18
  99. package/dist/es/form/index.css +0 -1
  100. package/dist/es/form/index.d.ts +0 -5
  101. package/dist/es/form/interface.d.ts +0 -91
  102. package/dist/es/formitem/formItem.d.ts +0 -115
  103. package/dist/es/formitem/index.css +0 -1
  104. package/dist/es/formitem/index.d.ts +0 -5
  105. package/dist/es/icon/icon-oss.d.ts +0 -6
  106. package/dist/es/icon/index.d.ts +0 -6
  107. package/dist/es/input/TextArea.d.ts +0 -13
  108. package/dist/es/input/index.css +0 -1
  109. package/dist/es/input/index.d.ts +0 -5
  110. package/dist/es/input/input.d.ts +0 -23
  111. package/dist/es/inputnumber/index.css +0 -1
  112. package/dist/es/inputnumber/index.d.ts +0 -5
  113. package/dist/es/inputnumber/inputNumber.d.ts +0 -28
  114. package/dist/es/inputnumber/interface.d.ts +0 -4
  115. package/dist/es/leftcontent/index.css +0 -1
  116. package/dist/es/leftcontent/index.d.ts +0 -5
  117. package/dist/es/leftcontent/leftContent.d.ts +0 -31
  118. package/dist/es/login/index.css +0 -1
  119. package/dist/es/login/index.d.ts +0 -37
  120. package/dist/es/message/index.css +0 -1
  121. package/dist/es/message/index.d.ts +0 -5
  122. package/dist/es/microloading/index.css +0 -1
  123. package/dist/es/microloading/index.d.ts +0 -5
  124. package/dist/es/microloading/micro-loading.d.ts +0 -8
  125. package/dist/es/modal/index.css +0 -1
  126. package/dist/es/modal/index.d.ts +0 -5
  127. package/dist/es/modal/interface.d.ts +0 -91
  128. package/dist/es/modal/modal.d.ts +0 -5
  129. package/dist/es/notauthpage/index.css +0 -0
  130. package/dist/es/notauthpage/index.d.ts +0 -5
  131. package/dist/es/notauthpage/notAuthPage.d.ts +0 -8
  132. package/dist/es/notroutepage/index.css +0 -0
  133. package/dist/es/notroutepage/index.d.ts +0 -5
  134. package/dist/es/notroutepage/notRoutePage.d.ts +0 -8
  135. package/dist/es/operationbtn/index.d.ts +0 -5
  136. package/dist/es/operationbtn/interface.d.ts +0 -34
  137. package/dist/es/operationbtn/operationBtn.d.ts +0 -6
  138. package/dist/es/pagination/index.css +0 -1
  139. package/dist/es/pagination/index.d.ts +0 -5
  140. package/dist/es/pagination/pagination.d.ts +0 -8
  141. package/dist/es/placeholder/index.css +0 -1
  142. package/dist/es/placeholder/index.d.ts +0 -5
  143. package/dist/es/placeholder/interface.d.ts +0 -12
  144. package/dist/es/placeholder/placeholder.d.ts +0 -5
  145. package/dist/es/print/index.css +0 -1
  146. package/dist/es/print/index.d.ts +0 -5
  147. package/dist/es/print/interface.d.ts +0 -69
  148. package/dist/es/print/print-page.d.ts +0 -6
  149. package/dist/es/print/print.d.ts +0 -5
  150. package/dist/es/protectedroute/index.d.ts +0 -24
  151. package/dist/es/select/hooks.d.ts +0 -16
  152. package/dist/es/select/index.css +0 -1
  153. package/dist/es/select/index.d.ts +0 -5
  154. package/dist/es/select/interface.d.ts +0 -82
  155. package/dist/es/select/select-render.d.ts +0 -31
  156. package/dist/es/select/select.d.ts +0 -5
  157. package/dist/es/sortable/index.d.ts +0 -5
  158. package/dist/es/sortable/sortable-item.d.ts +0 -14
  159. package/dist/es/sortable/sortable.d.ts +0 -13
  160. package/dist/es/suspensecomponent/index.d.ts +0 -10
  161. package/dist/es/table/components/Badge.d.ts +0 -24
  162. package/dist/es/table/components/TitleDirectionColumn.d.ts +0 -11
  163. package/dist/es/table/constant.d.ts +0 -3
  164. package/dist/es/table/index.css +0 -1
  165. package/dist/es/table/index.d.ts +0 -5
  166. package/dist/es/table/interface.d.ts +0 -613
  167. package/dist/es/table/table.d.ts +0 -11
  168. package/dist/es/tabs/index.css +0 -1
  169. package/dist/es/tabs/index.d.ts +0 -5
  170. package/dist/es/tabs/interface.d.ts +0 -52
  171. package/dist/es/tabs/tabs.d.ts +0 -5
  172. package/dist/es/tag/index.css +0 -1
  173. package/dist/es/tag/index.d.ts +0 -5
  174. package/dist/es/tag/interface.d.ts +0 -9
  175. package/dist/es/tag/tag.d.ts +0 -5
  176. package/dist/es/timepicker/index.d.ts +0 -19
  177. package/dist/es/title/index.css +0 -1
  178. package/dist/es/title/index.d.ts +0 -5
  179. package/dist/es/title/interface.d.ts +0 -35
  180. package/dist/es/title/title.d.ts +0 -5
  181. package/dist/es/tree/index.css +0 -1
  182. package/dist/es/tree/index.d.ts +0 -5
  183. package/dist/es/tree/interface.d.ts +0 -44
  184. package/dist/es/tree/tree.d.ts +0 -5
  185. package/dist/es/treeselect/index.css +0 -1
  186. package/dist/es/treeselect/index.d.ts +0 -5
  187. package/dist/es/treeselect/interface.d.ts +0 -32
  188. package/dist/es/treeselect/treeSelect.d.ts +0 -5
  189. package/dist/es/uploadlist/index.css +0 -1
  190. package/dist/es/uploadlist/index.d.ts +0 -5
  191. package/dist/es/uploadlist/interface.d.ts +0 -113
  192. package/dist/es/uploadlist/uploadList.d.ts +0 -5
  193. package/dist/es/watermark/index.css +0 -1
  194. package/dist/es/watermark/index.d.ts +0 -5
  195. package/dist/es/watermark/interface.d.ts +0 -23
  196. package/dist/es/watermark/watermark.d.ts +0 -5
  197. package/dist/es/zttransfer/index.css +0 -1
  198. package/dist/es/zttransfer/index.d.ts +0 -5
  199. package/dist/es/zttransfer/interface.d.ts +0 -38
  200. package/dist/es/zttransfer/zt-transfer.d.ts +0 -6
  201. package/dist/index.build.d.ts +0 -67
  202. package/dist/index.dark.css +0 -2
  203. package/dist/index.default.css +0 -2
  204. package/dist/less/components/Alert/style/index.less +0 -53
  205. package/dist/less/components/Alert/style/style.less +0 -4
  206. package/dist/less/components/AppLayout/style/index.less +0 -546
  207. package/dist/less/components/AppLayout/style/style.less +0 -2
  208. package/dist/less/components/AppLayout/style.less +0 -5
  209. package/dist/less/components/AuthLoading/style/index.less +0 -15
  210. package/dist/less/components/AuthLoading/style/style.less +0 -2
  211. package/dist/less/components/Button/style/index.less +0 -160
  212. package/dist/less/components/Button/style/style.less +0 -5
  213. package/dist/less/components/Cascader/style/index.less +0 -9
  214. package/dist/less/components/Cascader/style/style.less +0 -2
  215. package/dist/less/components/Collapse/style/index.less +0 -117
  216. package/dist/less/components/Collapse/style/style.less +0 -2
  217. package/dist/less/components/Container/style/index.less +0 -64
  218. package/dist/less/components/Container/style/style.less +0 -2
  219. package/dist/less/components/DatePicker/style/index.less +0 -7
  220. package/dist/less/components/DatePicker/style/style.less +0 -4
  221. package/dist/less/components/Descriptions/style/index.less +0 -32
  222. package/dist/less/components/Descriptions/style/style.less +0 -5
  223. package/dist/less/components/DetailList/style/index.less +0 -105
  224. package/dist/less/components/DetailList/style/style.less +0 -2
  225. package/dist/less/components/Differences/style/index.less +0 -5
  226. package/dist/less/components/Differences/style/style.less +0 -2
  227. package/dist/less/components/DynamicSetting/style/index.less +0 -96
  228. package/dist/less/components/DynamicSetting/style/style.less +0 -2
  229. package/dist/less/components/ElectronSignatures/style/index.less +0 -331
  230. package/dist/less/components/ElectronSignatures/style/style.less +0 -1
  231. package/dist/less/components/Footer/style/index.less +0 -28
  232. package/dist/less/components/Footer/style/style.less +0 -2
  233. package/dist/less/components/Form/style/index.less +0 -150
  234. package/dist/less/components/Form/style/style.less +0 -5
  235. package/dist/less/components/FormItem/style/index.less +0 -456
  236. package/dist/less/components/FormItem/style/style.less +0 -2
  237. package/dist/less/components/Input/style/index.less +0 -15
  238. package/dist/less/components/Input/style/style.less +0 -4
  239. package/dist/less/components/InputNumber/style/index.less +0 -30
  240. package/dist/less/components/InputNumber/style/style.less +0 -4
  241. package/dist/less/components/LeftContent/style/index.less +0 -62
  242. package/dist/less/components/LeftContent/style/style.less +0 -2
  243. package/dist/less/components/Login/style/index.less +0 -63
  244. package/dist/less/components/Login/style/style.less +0 -2
  245. package/dist/less/components/Message/style/index.less +0 -19
  246. package/dist/less/components/Message/style/style.less +0 -2
  247. package/dist/less/components/MicroLoading/style/index.less +0 -15
  248. package/dist/less/components/MicroLoading/style/style.less +0 -2
  249. package/dist/less/components/Modal/style/index.less +0 -43
  250. package/dist/less/components/Modal/style/style.less +0 -2
  251. package/dist/less/components/NotAuthPage/style/index.less +0 -0
  252. package/dist/less/components/NotAuthPage/style/style.less +0 -2
  253. package/dist/less/components/NotRoutePage/style/index.less +0 -0
  254. package/dist/less/components/NotRoutePage/style/style.less +0 -2
  255. package/dist/less/components/Pagination/style/index.less +0 -107
  256. package/dist/less/components/Pagination/style/style.less +0 -5
  257. package/dist/less/components/Placeholder/style/index.less +0 -3
  258. package/dist/less/components/Placeholder/style/style.less +0 -2
  259. package/dist/less/components/Print/style/index.less +0 -65
  260. package/dist/less/components/Print/style/style.less +0 -3
  261. package/dist/less/components/Select/style/index.less +0 -55
  262. package/dist/less/components/Select/style/style.less +0 -4
  263. package/dist/less/components/Table/style/index.less +0 -362
  264. package/dist/less/components/Table/style/style.less +0 -4
  265. package/dist/less/components/Tabs/style/index.less +0 -118
  266. package/dist/less/components/Tabs/style/style.less +0 -4
  267. package/dist/less/components/Tag/style/index.less +0 -3
  268. package/dist/less/components/Tag/style/style.less +0 -4
  269. package/dist/less/components/Title/style/index.less +0 -54
  270. package/dist/less/components/Title/style/style.less +0 -2
  271. package/dist/less/components/Tree/style/index.less +0 -58
  272. package/dist/less/components/Tree/style/style.less +0 -4
  273. package/dist/less/components/TreeSelect/style/index.less +0 -0
  274. package/dist/less/components/TreeSelect/style/style.less +0 -4
  275. package/dist/less/components/UploadList/style/index.less +0 -61
  276. package/dist/less/components/UploadList/style/style.less +0 -4
  277. package/dist/less/components/Watermark/style/index.less +0 -7
  278. package/dist/less/components/Watermark/style/style.less +0 -3
  279. package/dist/less/components/ZtTransfer/style/index.less +0 -136
  280. package/dist/less/components/ZtTransfer/style/style.less +0 -2
  281. package/dist/less/styles/default.less +0 -100
  282. package/dist/less/styles/index.less +0 -86
  283. package/dist/less/styles/reset.less +0 -189
@@ -0,0 +1,251 @@
1
+ import { __assign } from '../../_virtual/_tslib.js';
2
+ import { useMemo, useState, useRef, useEffect } from 'react';
3
+ import { SCROLLBAR_SIZE, MIN_SCROLLBAR_SIZE } from '../utils/constants.js';
4
+ import { calculateScrollbarMetrics } from '../utils/tableCalculations.js';
5
+ import 'dayjs';
6
+
7
+ /**
8
+ * 滚动管理 Hook - 统一管理所有滚动相关逻辑
9
+ *
10
+ * 包含功能:
11
+ * 1. 滚动条指标计算(useScrollbarMetrics)
12
+ * 2. 滚动事件处理(useTableScroll)
13
+ * 3. 滚动位置重置(useScrollReset)
14
+ */
15
+ // ==================== 工具函数 ====================
16
+ /**
17
+ * 检查两个对象是否相等(深度比较)
18
+ */
19
+ var isEqual = function (obj1, obj2) {
20
+ return JSON.stringify(obj1) === JSON.stringify(obj2);
21
+ };
22
+ // ==================== Hook 1: 滚动条指标计算 ====================
23
+ /**
24
+ * 滚动条指标计算 Hook
25
+ *
26
+ * 计算滚动条的各项指标,包括:
27
+ * - 基础指标(不依赖滚动位置)
28
+ * - 实际指标(包含当前滚动位置)
29
+ * - 最大滚动值
30
+ */
31
+ var useScrollbarMetrics = function (params) {
32
+ var containerWidth = params.containerWidth, containerHeight = params.containerHeight, totalWidth = params.totalWidth, totalHeight = params.totalHeight, headerHeight = params.headerHeight, scrollTop = params.scrollTop, scrollLeft = params.scrollLeft;
33
+ // 基础滚动条指标(不依赖滚动位置,用于计算最大滚动值)
34
+ var baseMetrics = useMemo(function () {
35
+ return calculateScrollbarMetrics({
36
+ containerWidth: containerWidth,
37
+ containerHeight: containerHeight,
38
+ totalWidth: totalWidth,
39
+ totalHeight: totalHeight,
40
+ headerHeight: headerHeight,
41
+ scrollbarSize: SCROLLBAR_SIZE,
42
+ minScrollbarSize: MIN_SCROLLBAR_SIZE,
43
+ scrollTop: 0,
44
+ scrollLeft: 0,
45
+ });
46
+ }, [containerWidth, containerHeight, totalWidth, totalHeight, headerHeight]);
47
+ // 实际滚动条指标(包含当前滚动位置,用于渲染)
48
+ var actualMetrics = useMemo(function () {
49
+ return calculateScrollbarMetrics({
50
+ containerWidth: containerWidth,
51
+ containerHeight: containerHeight,
52
+ totalWidth: totalWidth,
53
+ totalHeight: totalHeight,
54
+ headerHeight: headerHeight,
55
+ scrollbarSize: SCROLLBAR_SIZE,
56
+ minScrollbarSize: MIN_SCROLLBAR_SIZE,
57
+ scrollTop: scrollTop,
58
+ scrollLeft: scrollLeft,
59
+ });
60
+ }, [
61
+ containerWidth,
62
+ containerHeight,
63
+ totalWidth,
64
+ totalHeight,
65
+ headerHeight,
66
+ scrollTop,
67
+ scrollLeft,
68
+ ]);
69
+ return {
70
+ baseMetrics: baseMetrics,
71
+ actualMetrics: actualMetrics,
72
+ maxScrollTop: baseMetrics.maxScrollTop,
73
+ maxScrollLeft: baseMetrics.maxScrollLeft,
74
+ };
75
+ };
76
+ // ==================== Hook 2: 滚动事件处理 ====================
77
+ /**
78
+ * 表格滚动管理 Hook
79
+ *
80
+ * 处理滚动相关的所有事件:
81
+ * - Canvas 滚轮事件(使用 RAF 节流)
82
+ * - Container 滚轮事件(阻止默认行为)
83
+ * - 全局鼠标事件(拖拽滚动条)
84
+ */
85
+ var useTableScroll = function (params) {
86
+ var canvasRef = params.canvasRef, containerRef = params.containerRef, maxScrollTop = params.maxScrollTop, maxScrollLeft = params.maxScrollLeft, onScroll = params.onScroll;
87
+ var _a = useState({
88
+ scrollLeft: 0,
89
+ scrollTop: 0,
90
+ isDraggingVertical: false,
91
+ isDraggingHorizontal: false,
92
+ dragStartY: 0,
93
+ dragStartX: 0,
94
+ dragStartScrollTop: 0,
95
+ dragStartScrollLeft: 0,
96
+ }), scrollState = _a[0], setScrollState = _a[1];
97
+ // 用于节流滚轮事件的refs
98
+ var rafIdRef = useRef(null);
99
+ var pendingDeltaRef = useRef({ deltaX: 0, deltaY: 0 });
100
+ // 滚轮事件处理(Canvas)- 使用 requestAnimationFrame 节流
101
+ useEffect(function () {
102
+ var canvas = canvasRef.current;
103
+ if (!canvas)
104
+ return;
105
+ var handleNativeWheel = function (e) {
106
+ e.preventDefault();
107
+ e.stopPropagation();
108
+ // 累积滚动增量
109
+ pendingDeltaRef.current.deltaX += e.deltaX;
110
+ pendingDeltaRef.current.deltaY += e.deltaY;
111
+ // 如果已经有pending的动画帧,不需要再次请求
112
+ if (rafIdRef.current !== null) {
113
+ return;
114
+ }
115
+ // 使用 requestAnimationFrame 节流更新
116
+ rafIdRef.current = requestAnimationFrame(function () {
117
+ var deltaX = pendingDeltaRef.current.deltaX;
118
+ var deltaY = pendingDeltaRef.current.deltaY;
119
+ // 重置累积的增量
120
+ pendingDeltaRef.current.deltaX = 0;
121
+ pendingDeltaRef.current.deltaY = 0;
122
+ rafIdRef.current = null;
123
+ // 批量更新状态
124
+ setScrollState(function (prev) {
125
+ var newScrollTop = Math.max(0, Math.min(maxScrollTop, prev.scrollTop + deltaY));
126
+ var newScrollLeft = Math.max(0, Math.min(maxScrollLeft, prev.scrollLeft + deltaX));
127
+ if (newScrollTop !== prev.scrollTop ||
128
+ newScrollLeft !== prev.scrollLeft) {
129
+ onScroll === null || onScroll === void 0 ? void 0 : onScroll(newScrollLeft, newScrollTop);
130
+ return __assign(__assign({}, prev), { scrollTop: newScrollTop, scrollLeft: newScrollLeft });
131
+ }
132
+ return prev;
133
+ });
134
+ });
135
+ };
136
+ canvas.addEventListener("wheel", handleNativeWheel, { passive: false });
137
+ return function () {
138
+ canvas.removeEventListener("wheel", handleNativeWheel);
139
+ // 清理pending的动画帧
140
+ if (rafIdRef.current !== null) {
141
+ cancelAnimationFrame(rafIdRef.current);
142
+ rafIdRef.current = null;
143
+ }
144
+ };
145
+ }, [maxScrollTop, maxScrollLeft, onScroll, canvasRef, setScrollState]);
146
+ // 滚轮事件处理(Container)
147
+ useEffect(function () {
148
+ var container = containerRef.current;
149
+ if (!container)
150
+ return;
151
+ var handleNativeContainerWheel = function (e) {
152
+ // 检查事件是否来自过滤弹框,如果是,允许滚动
153
+ var target = e.target;
154
+ var isInFilterPopover = target.closest(".canvas-table-filter-popover");
155
+ if (isInFilterPopover) {
156
+ // 允许过滤弹框内部滚动
157
+ return;
158
+ }
159
+ e.preventDefault();
160
+ e.stopPropagation();
161
+ };
162
+ container.addEventListener("wheel", handleNativeContainerWheel, {
163
+ passive: false,
164
+ });
165
+ return function () {
166
+ container.removeEventListener("wheel", handleNativeContainerWheel);
167
+ };
168
+ }, [containerRef]);
169
+ // 全局鼠标事件处理(拖拽滚动条)
170
+ useEffect(function () {
171
+ var handleGlobalMouseUp = function () {
172
+ setScrollState(function (prev) { return (__assign(__assign({}, prev), { isDraggingVertical: false, isDraggingHorizontal: false })); });
173
+ };
174
+ var handleGlobalMouseMove = function (e) {
175
+ if (scrollState.isDraggingVertical || scrollState.isDraggingHorizontal) {
176
+ e.preventDefault();
177
+ }
178
+ };
179
+ if (scrollState.isDraggingVertical || scrollState.isDraggingHorizontal) {
180
+ document.addEventListener("mouseup", handleGlobalMouseUp);
181
+ document.addEventListener("mousemove", handleGlobalMouseMove);
182
+ return function () {
183
+ document.removeEventListener("mouseup", handleGlobalMouseUp);
184
+ document.removeEventListener("mousemove", handleGlobalMouseMove);
185
+ };
186
+ }
187
+ }, [scrollState.isDraggingVertical, scrollState.isDraggingHorizontal]);
188
+ return {
189
+ scrollState: scrollState,
190
+ setScrollState: setScrollState,
191
+ };
192
+ };
193
+ // ==================== Hook 3: 滚动位置重置 ====================
194
+ /**
195
+ * 滚动位置重置 Hook
196
+ *
197
+ * 当数据变化时自动重置滚动位置:
198
+ * - 数据长度变小时重置 Y 轴滚动
199
+ * - 筛选条件变化时重置 Y 轴滚动
200
+ * - 排序条件变化时重置 Y 轴滚动
201
+ *
202
+ * 注意:
203
+ * - X 轴滚动(scrollLeft)始终保持不变
204
+ * - 数据长度变大时不重置滚动位置
205
+ */
206
+ var useScrollReset = function (params) {
207
+ var dataSourceLength = params.dataSourceLength, processedDataLength = params.processedDataLength, filters = params.filters, sortField = params.sortField, sortOrder = params.sortOrder, setScrollState = params.setScrollState;
208
+ // 使用 ref 跟踪上一次的状态
209
+ var prevDataSourceLengthRef = useRef(dataSourceLength);
210
+ var prevProcessedLengthRef = useRef(processedDataLength);
211
+ var prevFiltersRef = useRef(filters);
212
+ var prevSortRef = useRef({ field: sortField, order: sortOrder });
213
+ useEffect(function () {
214
+ // 判断数据长度是否变小了
215
+ var dataLengthDecreased = prevDataSourceLengthRef.current > dataSourceLength ||
216
+ prevProcessedLengthRef.current > processedDataLength;
217
+ // 判断筛选或排序是否变化
218
+ var filtersChanged = !isEqual(prevFiltersRef.current, filters);
219
+ var sortChanged = prevSortRef.current.field !== sortField ||
220
+ prevSortRef.current.order !== sortOrder;
221
+ // 只在数据变小或筛选/排序变化时重置Y轴滚动
222
+ var shouldResetScrollTop = dataLengthDecreased || filtersChanged || sortChanged;
223
+ if (shouldResetScrollTop) {
224
+ // 更新 ref 保存的值
225
+ prevDataSourceLengthRef.current = dataSourceLength;
226
+ prevProcessedLengthRef.current = processedDataLength;
227
+ prevFiltersRef.current = filters;
228
+ prevSortRef.current = { field: sortField, order: sortOrder };
229
+ // 只重置垂直滚动位置到顶部,保持水平滚动位置不变
230
+ setScrollState(function (prev) { return (__assign(__assign({}, prev), { scrollTop: 0 })); });
231
+ }
232
+ else {
233
+ // 只是数据长度变大,不重置滚动,但更新 ref
234
+ var dataChanged = prevDataSourceLengthRef.current !== dataSourceLength ||
235
+ prevProcessedLengthRef.current !== processedDataLength;
236
+ if (dataChanged) {
237
+ prevDataSourceLengthRef.current = dataSourceLength;
238
+ prevProcessedLengthRef.current = processedDataLength;
239
+ }
240
+ }
241
+ }, [
242
+ dataSourceLength,
243
+ processedDataLength,
244
+ filters,
245
+ sortField,
246
+ sortOrder,
247
+ setScrollState,
248
+ ]);
249
+ };
250
+
251
+ export { useScrollReset, useScrollbarMetrics, useTableScroll };
@@ -0,0 +1,81 @@
1
+ import { __spreadArray } from '../../_virtual/_tslib.js';
2
+ import { useMemo } from 'react';
3
+ import { IS_SUMMARY } from '../../table/constant.js';
4
+ import 'lodash/isEqual';
5
+ import 'ahooks';
6
+ import '../../node_modules/immutability-helper/index.js';
7
+ import 'react/jsx-runtime';
8
+ import { plus } from 'zmdms-utils';
9
+ import '../../node_modules/exceljs/dist/exceljs.min.js';
10
+ import 'dayjs';
11
+
12
+ /**
13
+ * 合计行计算 Hook
14
+ */
15
+ var useSummaryRow = function (params) {
16
+ var columns = params.columns, dataSource = params.dataSource;
17
+ var summaryRow = useMemo(function () {
18
+ var hasSummary = columns.some(function (col) { return col.isSummary; });
19
+ if (!hasSummary)
20
+ return null;
21
+ var summaryRecord = {};
22
+ // 找到第一个数据列(非序号列、非选择框列)
23
+ var firstDataColIndex = -1;
24
+ for (var i = 0; i < columns.length; i++) {
25
+ var col = columns[i];
26
+ if (col.key !== "__index__" && col.key !== "__selection__") {
27
+ firstDataColIndex = i;
28
+ break;
29
+ }
30
+ }
31
+ columns.forEach(function (column, colIndex) {
32
+ var dataIndex = column.dataIndex || column.key;
33
+ if (column.isSummary) {
34
+ // 计算合计值
35
+ var sum_1 = 0;
36
+ dataSource.forEach(function (record) {
37
+ var value = record[dataIndex];
38
+ var num = typeof value === "string" ? parseFloat(value) : value;
39
+ if (!isNaN(num) &&
40
+ num !== null &&
41
+ num !== undefined &&
42
+ !record[IS_SUMMARY]) {
43
+ sum_1 = plus(sum_1, num);
44
+ }
45
+ });
46
+ // 应用格式化
47
+ var formattedSum = sum_1;
48
+ if (column.precision !== undefined) {
49
+ formattedSum = sum_1.toFixed(column.precision);
50
+ }
51
+ if (column.thousand) {
52
+ formattedSum = Number(formattedSum).toLocaleString("en-US");
53
+ }
54
+ summaryRecord[dataIndex] = formattedSum;
55
+ }
56
+ else if (colIndex === firstDataColIndex) {
57
+ // 第一个数据列显示"合计"
58
+ summaryRecord[dataIndex] = "合计";
59
+ }
60
+ else {
61
+ summaryRecord[dataIndex] = "";
62
+ }
63
+ });
64
+ summaryRecord[IS_SUMMARY] = true;
65
+ return summaryRecord;
66
+ }, [columns, dataSource]);
67
+ // 包含合计行的数据源
68
+ var finalDataSource = useMemo(function () {
69
+ if (summaryRow) {
70
+ return __spreadArray(__spreadArray([], dataSource, true), [summaryRow], false);
71
+ }
72
+ return dataSource;
73
+ }, [dataSource, summaryRow]);
74
+ return {
75
+ summaryRow: summaryRow,
76
+ finalDataSource: finalDataSource,
77
+ hasSummaryRow: !!summaryRow,
78
+ };
79
+ };
80
+
81
+ export { useSummaryRow };