@wimi/vtable-gantt 1.0.0

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 (317) hide show
  1. package/README.md +213 -0
  2. package/README.zh-CN.md +215 -0
  3. package/cjs/Gantt.d.ts +200 -0
  4. package/cjs/Gantt.js +582 -0
  5. package/cjs/Gantt.js.map +1 -0
  6. package/cjs/components/Menu.d.ts +1 -0
  7. package/cjs/components/Menu.js +1 -0
  8. package/cjs/components/Menu.js.map +1 -0
  9. package/cjs/components/MenuElementStyle.d.ts +1 -0
  10. package/cjs/components/MenuElementStyle.js +12 -0
  11. package/cjs/components/MenuElementStyle.js.map +1 -0
  12. package/cjs/data/DataSource.d.ts +9 -0
  13. package/cjs/data/DataSource.js +76 -0
  14. package/cjs/data/DataSource.js.map +1 -0
  15. package/cjs/env.d.ts +19 -0
  16. package/cjs/env.js +48 -0
  17. package/cjs/env.js.map +1 -0
  18. package/cjs/event/EventHandler.d.ts +47 -0
  19. package/cjs/event/EventHandler.js +128 -0
  20. package/cjs/event/EventHandler.js.map +1 -0
  21. package/cjs/event/EventTarget.d.ts +12 -0
  22. package/cjs/event/EventTarget.js +67 -0
  23. package/cjs/event/EventTarget.js.map +1 -0
  24. package/cjs/event/event-manager.d.ts +34 -0
  25. package/cjs/event/event-manager.js +369 -0
  26. package/cjs/event/event-manager.js.map +1 -0
  27. package/cjs/event/scroll.d.ts +8 -0
  28. package/cjs/event/scroll.js +112 -0
  29. package/cjs/event/scroll.js.map +1 -0
  30. package/cjs/event/touch.d.ts +2 -0
  31. package/cjs/event/touch.js +86 -0
  32. package/cjs/event/touch.js.map +1 -0
  33. package/cjs/gantt-helper.d.ts +63 -0
  34. package/cjs/gantt-helper.js +712 -0
  35. package/cjs/gantt-helper.js.map +1 -0
  36. package/cjs/index.d.ts +10 -0
  37. package/cjs/index.js +60 -0
  38. package/cjs/index.js.map +1 -0
  39. package/cjs/plugins/index.d.ts +2 -0
  40. package/cjs/plugins/index.js +15 -0
  41. package/cjs/plugins/index.js.map +1 -0
  42. package/cjs/plugins/interface.d.ts +10 -0
  43. package/cjs/plugins/interface.js +6 -0
  44. package/cjs/plugins/interface.js.map +1 -0
  45. package/cjs/plugins/plugin-manager.d.ts +16 -0
  46. package/cjs/plugins/plugin-manager.js +63 -0
  47. package/cjs/plugins/plugin-manager.js.map +1 -0
  48. package/cjs/register.d.ts +1 -0
  49. package/cjs/register.js +1 -0
  50. package/cjs/register.js.map +1 -0
  51. package/cjs/scenegraph/dependency-link.d.ts +48 -0
  52. package/cjs/scenegraph/dependency-link.js +480 -0
  53. package/cjs/scenegraph/dependency-link.js.map +1 -0
  54. package/cjs/scenegraph/drag-order-line.d.ts +12 -0
  55. package/cjs/scenegraph/drag-order-line.js +49 -0
  56. package/cjs/scenegraph/drag-order-line.js.map +1 -0
  57. package/cjs/scenegraph/frame-border.d.ts +10 -0
  58. package/cjs/scenegraph/frame-border.js +58 -0
  59. package/cjs/scenegraph/frame-border.js.map +1 -0
  60. package/cjs/scenegraph/gantt-node.d.ts +22 -0
  61. package/cjs/scenegraph/gantt-node.js +66 -0
  62. package/cjs/scenegraph/gantt-node.js.map +1 -0
  63. package/cjs/scenegraph/graphic/group-contribution-render.d.ts +12 -0
  64. package/cjs/scenegraph/graphic/group-contribution-render.js +37 -0
  65. package/cjs/scenegraph/graphic/group-contribution-render.js.map +1 -0
  66. package/cjs/scenegraph/graphic/index.d.ts +3 -0
  67. package/cjs/scenegraph/graphic/index.js +13 -0
  68. package/cjs/scenegraph/graphic/index.js.map +1 -0
  69. package/cjs/scenegraph/grid.d.ts +34 -0
  70. package/cjs/scenegraph/grid.js +316 -0
  71. package/cjs/scenegraph/grid.js.map +1 -0
  72. package/cjs/scenegraph/mark-line.d.ts +13 -0
  73. package/cjs/scenegraph/mark-line.js +109 -0
  74. package/cjs/scenegraph/mark-line.js.map +1 -0
  75. package/cjs/scenegraph/scenegraph.d.ts +59 -0
  76. package/cjs/scenegraph/scenegraph.js +240 -0
  77. package/cjs/scenegraph/scenegraph.js.map +1 -0
  78. package/cjs/scenegraph/scroll-bar.d.ts +19 -0
  79. package/cjs/scenegraph/scroll-bar.js +150 -0
  80. package/cjs/scenegraph/scroll-bar.js.map +1 -0
  81. package/cjs/scenegraph/task-bar.d.ts +40 -0
  82. package/cjs/scenegraph/task-bar.js +476 -0
  83. package/cjs/scenegraph/task-bar.js.map +1 -0
  84. package/cjs/scenegraph/task-creation-button.d.ts +13 -0
  85. package/cjs/scenegraph/task-creation-button.js +86 -0
  86. package/cjs/scenegraph/task-creation-button.js.map +1 -0
  87. package/cjs/scenegraph/timeline-header.d.ts +14 -0
  88. package/cjs/scenegraph/timeline-header.js +190 -0
  89. package/cjs/scenegraph/timeline-header.js.map +1 -0
  90. package/cjs/scenegraph/tooltip.d.ts +9 -0
  91. package/cjs/scenegraph/tooltip.js +59 -0
  92. package/cjs/scenegraph/tooltip.js.map +1 -0
  93. package/cjs/state/gantt-table-sync.d.ts +8 -0
  94. package/cjs/state/gantt-table-sync.js +96 -0
  95. package/cjs/state/gantt-table-sync.js.map +1 -0
  96. package/cjs/state/state-manager.d.ts +127 -0
  97. package/cjs/state/state-manager.js +634 -0
  98. package/cjs/state/state-manager.js.map +1 -0
  99. package/cjs/sub-tasks-inline-helper.d.ts +1 -0
  100. package/cjs/sub-tasks-inline-helper.js +1 -0
  101. package/cjs/sub-tasks-inline-helper.js.map +1 -0
  102. package/cjs/themes.d.ts +1 -0
  103. package/cjs/themes.js +1 -0
  104. package/cjs/themes.js.map +1 -0
  105. package/cjs/tools/debounce.d.ts +1 -0
  106. package/cjs/tools/debounce.js +51 -0
  107. package/cjs/tools/debounce.js.map +1 -0
  108. package/cjs/tools/dom.d.ts +1 -0
  109. package/cjs/tools/dom.js +11 -0
  110. package/cjs/tools/dom.js.map +1 -0
  111. package/cjs/tools/index.d.ts +2 -0
  112. package/cjs/tools/index.js +30 -0
  113. package/cjs/tools/index.js.map +1 -0
  114. package/cjs/tools/inertia.d.ts +15 -0
  115. package/cjs/tools/inertia.js +40 -0
  116. package/cjs/tools/inertia.js.map +1 -0
  117. package/cjs/tools/isx.d.ts +16 -0
  118. package/cjs/tools/isx.js +117 -0
  119. package/cjs/tools/isx.js.map +1 -0
  120. package/cjs/tools/pixel-ratio.d.ts +2 -0
  121. package/cjs/tools/pixel-ratio.js +16 -0
  122. package/cjs/tools/pixel-ratio.js.map +1 -0
  123. package/cjs/tools/util.d.ts +19 -0
  124. package/cjs/tools/util.js +404 -0
  125. package/cjs/tools/util.js.map +1 -0
  126. package/cjs/ts-types/EVENT_TYPE.d.ts +19 -0
  127. package/cjs/ts-types/EVENT_TYPE.js +22 -0
  128. package/cjs/ts-types/EVENT_TYPE.js.map +1 -0
  129. package/cjs/ts-types/common.d.ts +11 -0
  130. package/cjs/ts-types/common.js +10 -0
  131. package/cjs/ts-types/common.js.map +1 -0
  132. package/cjs/ts-types/events.d.ts +132 -0
  133. package/cjs/ts-types/events.js +6 -0
  134. package/cjs/ts-types/events.js.map +1 -0
  135. package/cjs/ts-types/gantt-engine.d.ts +344 -0
  136. package/cjs/ts-types/gantt-engine.js +18 -0
  137. package/cjs/ts-types/gantt-engine.js.map +1 -0
  138. package/cjs/ts-types/index.d.ts +5 -0
  139. package/cjs/ts-types/index.js +23 -0
  140. package/cjs/ts-types/index.js.map +1 -0
  141. package/cjs/ts-types/zoom-scale.d.ts +32 -0
  142. package/cjs/ts-types/zoom-scale.js +6 -0
  143. package/cjs/ts-types/zoom-scale.js.map +1 -0
  144. package/cjs/vrender.d.ts +1 -0
  145. package/cjs/vrender.js +60 -0
  146. package/cjs/vrender.js.map +1 -0
  147. package/cjs/vtable.d.ts +1 -0
  148. package/cjs/vtable.js +35 -0
  149. package/cjs/vtable.js.map +1 -0
  150. package/cjs/zoom-scale/DataZoomIntegration.d.ts +50 -0
  151. package/cjs/zoom-scale/DataZoomIntegration.js +261 -0
  152. package/cjs/zoom-scale/DataZoomIntegration.js.map +1 -0
  153. package/cjs/zoom-scale/ZoomScaleManager.d.ts +55 -0
  154. package/cjs/zoom-scale/ZoomScaleManager.js +328 -0
  155. package/cjs/zoom-scale/ZoomScaleManager.js.map +1 -0
  156. package/cjs/zoom-scale/index.d.ts +4 -0
  157. package/cjs/zoom-scale/index.js +24 -0
  158. package/cjs/zoom-scale/index.js.map +1 -0
  159. package/dist/vtable-gantt.js +76328 -0
  160. package/dist/vtable-gantt.min.js +15 -0
  161. package/es/Gantt.d.ts +200 -0
  162. package/es/Gantt.js +584 -0
  163. package/es/Gantt.js.map +1 -0
  164. package/es/components/Menu.d.ts +1 -0
  165. package/es/components/Menu.js +1 -0
  166. package/es/components/Menu.js.map +1 -0
  167. package/es/components/MenuElementStyle.d.ts +1 -0
  168. package/es/components/MenuElementStyle.js +6 -0
  169. package/es/components/MenuElementStyle.js.map +1 -0
  170. package/es/data/DataSource.d.ts +9 -0
  171. package/es/data/DataSource.js +63 -0
  172. package/es/data/DataSource.js.map +1 -0
  173. package/es/env.d.ts +19 -0
  174. package/es/env.js +42 -0
  175. package/es/env.js.map +1 -0
  176. package/es/event/EventHandler.d.ts +47 -0
  177. package/es/event/EventHandler.js +119 -0
  178. package/es/event/EventHandler.js.map +1 -0
  179. package/es/event/EventTarget.d.ts +12 -0
  180. package/es/event/EventTarget.js +58 -0
  181. package/es/event/EventTarget.js.map +1 -0
  182. package/es/event/event-manager.d.ts +34 -0
  183. package/es/event/event-manager.js +376 -0
  184. package/es/event/event-manager.js.map +1 -0
  185. package/es/event/scroll.d.ts +8 -0
  186. package/es/event/scroll.js +104 -0
  187. package/es/event/scroll.js.map +1 -0
  188. package/es/event/touch.d.ts +2 -0
  189. package/es/event/touch.js +78 -0
  190. package/es/event/touch.js.map +1 -0
  191. package/es/gantt-helper.d.ts +63 -0
  192. package/es/gantt-helper.js +683 -0
  193. package/es/gantt-helper.js.map +1 -0
  194. package/es/index.d.ts +10 -0
  195. package/es/index.js +16 -0
  196. package/es/index.js.map +1 -0
  197. package/es/plugins/index.d.ts +2 -0
  198. package/es/plugins/index.js +2 -0
  199. package/es/plugins/index.js.map +1 -0
  200. package/es/plugins/interface.d.ts +10 -0
  201. package/es/plugins/interface.js +2 -0
  202. package/es/plugins/interface.js.map +1 -0
  203. package/es/plugins/plugin-manager.d.ts +16 -0
  204. package/es/plugins/plugin-manager.js +55 -0
  205. package/es/plugins/plugin-manager.js.map +1 -0
  206. package/es/register.d.ts +1 -0
  207. package/es/register.js +1 -0
  208. package/es/register.js.map +1 -0
  209. package/es/scenegraph/dependency-link.d.ts +48 -0
  210. package/es/scenegraph/dependency-link.js +462 -0
  211. package/es/scenegraph/dependency-link.js.map +1 -0
  212. package/es/scenegraph/drag-order-line.d.ts +12 -0
  213. package/es/scenegraph/drag-order-line.js +40 -0
  214. package/es/scenegraph/drag-order-line.js.map +1 -0
  215. package/es/scenegraph/frame-border.d.ts +10 -0
  216. package/es/scenegraph/frame-border.js +51 -0
  217. package/es/scenegraph/frame-border.js.map +1 -0
  218. package/es/scenegraph/gantt-node.d.ts +22 -0
  219. package/es/scenegraph/gantt-node.js +64 -0
  220. package/es/scenegraph/gantt-node.js.map +1 -0
  221. package/es/scenegraph/graphic/group-contribution-render.d.ts +12 -0
  222. package/es/scenegraph/graphic/group-contribution-render.js +32 -0
  223. package/es/scenegraph/graphic/group-contribution-render.js.map +1 -0
  224. package/es/scenegraph/graphic/index.d.ts +3 -0
  225. package/es/scenegraph/graphic/index.js +8 -0
  226. package/es/scenegraph/graphic/index.js.map +1 -0
  227. package/es/scenegraph/grid.d.ts +34 -0
  228. package/es/scenegraph/grid.js +306 -0
  229. package/es/scenegraph/grid.js.map +1 -0
  230. package/es/scenegraph/mark-line.d.ts +13 -0
  231. package/es/scenegraph/mark-line.js +101 -0
  232. package/es/scenegraph/mark-line.js.map +1 -0
  233. package/es/scenegraph/scenegraph.d.ts +59 -0
  234. package/es/scenegraph/scenegraph.js +250 -0
  235. package/es/scenegraph/scenegraph.js.map +1 -0
  236. package/es/scenegraph/scroll-bar.d.ts +19 -0
  237. package/es/scenegraph/scroll-bar.js +144 -0
  238. package/es/scenegraph/scroll-bar.js.map +1 -0
  239. package/es/scenegraph/task-bar.d.ts +40 -0
  240. package/es/scenegraph/task-bar.js +475 -0
  241. package/es/scenegraph/task-bar.js.map +1 -0
  242. package/es/scenegraph/task-creation-button.d.ts +13 -0
  243. package/es/scenegraph/task-creation-button.js +78 -0
  244. package/es/scenegraph/task-creation-button.js.map +1 -0
  245. package/es/scenegraph/timeline-header.d.ts +14 -0
  246. package/es/scenegraph/timeline-header.js +186 -0
  247. package/es/scenegraph/timeline-header.js.map +1 -0
  248. package/es/scenegraph/tooltip.d.ts +9 -0
  249. package/es/scenegraph/tooltip.js +51 -0
  250. package/es/scenegraph/tooltip.js.map +1 -0
  251. package/es/state/gantt-table-sync.d.ts +8 -0
  252. package/es/state/gantt-table-sync.js +87 -0
  253. package/es/state/gantt-table-sync.js.map +1 -0
  254. package/es/state/state-manager.d.ts +127 -0
  255. package/es/state/state-manager.js +631 -0
  256. package/es/state/state-manager.js.map +1 -0
  257. package/es/sub-tasks-inline-helper.d.ts +1 -0
  258. package/es/sub-tasks-inline-helper.js +1 -0
  259. package/es/sub-tasks-inline-helper.js.map +1 -0
  260. package/es/themes.d.ts +1 -0
  261. package/es/themes.js +1 -0
  262. package/es/themes.js.map +1 -0
  263. package/es/tools/debounce.d.ts +1 -0
  264. package/es/tools/debounce.js +45 -0
  265. package/es/tools/debounce.js.map +1 -0
  266. package/es/tools/dom.d.ts +1 -0
  267. package/es/tools/dom.js +5 -0
  268. package/es/tools/dom.js.map +1 -0
  269. package/es/tools/index.d.ts +2 -0
  270. package/es/tools/index.js +4 -0
  271. package/es/tools/index.js.map +1 -0
  272. package/es/tools/inertia.d.ts +15 -0
  273. package/es/tools/inertia.js +31 -0
  274. package/es/tools/inertia.js.map +1 -0
  275. package/es/tools/isx.d.ts +16 -0
  276. package/es/tools/isx.js +80 -0
  277. package/es/tools/isx.js.map +1 -0
  278. package/es/tools/pixel-ratio.d.ts +2 -0
  279. package/es/tools/pixel-ratio.js +12 -0
  280. package/es/tools/pixel-ratio.js.map +1 -0
  281. package/es/tools/util.d.ts +19 -0
  282. package/es/tools/util.js +390 -0
  283. package/es/tools/util.js.map +1 -0
  284. package/es/ts-types/EVENT_TYPE.d.ts +19 -0
  285. package/es/ts-types/EVENT_TYPE.js +18 -0
  286. package/es/ts-types/EVENT_TYPE.js.map +1 -0
  287. package/es/ts-types/common.d.ts +11 -0
  288. package/es/ts-types/common.js +6 -0
  289. package/es/ts-types/common.js.map +1 -0
  290. package/es/ts-types/events.d.ts +132 -0
  291. package/es/ts-types/events.js +2 -0
  292. package/es/ts-types/events.js.map +1 -0
  293. package/es/ts-types/gantt-engine.d.ts +344 -0
  294. package/es/ts-types/gantt-engine.js +21 -0
  295. package/es/ts-types/gantt-engine.js.map +1 -0
  296. package/es/ts-types/index.d.ts +5 -0
  297. package/es/ts-types/index.js +10 -0
  298. package/es/ts-types/index.js.map +1 -0
  299. package/es/ts-types/zoom-scale.d.ts +32 -0
  300. package/es/ts-types/zoom-scale.js +2 -0
  301. package/es/ts-types/zoom-scale.js.map +1 -0
  302. package/es/vrender.d.ts +1 -0
  303. package/es/vrender.js +2 -0
  304. package/es/vrender.js.map +1 -0
  305. package/es/vtable.d.ts +1 -0
  306. package/es/vtable.js +2 -0
  307. package/es/vtable.js.map +1 -0
  308. package/es/zoom-scale/DataZoomIntegration.d.ts +50 -0
  309. package/es/zoom-scale/DataZoomIntegration.js +253 -0
  310. package/es/zoom-scale/DataZoomIntegration.js.map +1 -0
  311. package/es/zoom-scale/ZoomScaleManager.d.ts +55 -0
  312. package/es/zoom-scale/ZoomScaleManager.js +322 -0
  313. package/es/zoom-scale/ZoomScaleManager.js.map +1 -0
  314. package/es/zoom-scale/index.d.ts +4 -0
  315. package/es/zoom-scale/index.js +4 -0
  316. package/es/zoom-scale/index.js.map +1 -0
  317. package/package.json +124 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/ts-types/zoom-scale.ts"],"names":[],"mappings":"","file":"zoom-scale.js","sourcesContent":["import type { ITimelineScale } from './gantt-engine';\n\n/**\n * DataZoomAxis 配置接口\n */\nexport interface IDataZoomAxisConfig {\n /** 是否启用 DataZoomAxis */\n enabled?: boolean;\n /** DataZoomAxis 容器 ID(可选,如果不提供会自动从 Gantt 实例获取) */\n containerId?: string;\n /** DataZoomAxis 宽度(默认自动使用 Gantt 时间轴区域宽度,即容器宽度减去左侧表头宽度) */\n width?: number;\n /** DataZoomAxis 高度 */\n height?: number;\n /** X 坐标(相对于容器左侧,默认排除左侧表头宽度,与时间轴内容区域对齐) */\n x?: number;\n /** Y 坐标(相对于容器底边界的偏移,正值向下,默认 0) */\n y?: number;\n /** 事件触发延迟时间 */\n delayTime?: number;\n}\n\n/**\n * ZoomScale 配置接口\n * 用于定义多级别的时间轴缩放系统\n */\nexport interface IZoomScale {\n /** 是否启用 ZoomScale 功能 */\n enabled?: boolean;\n\n /** DataZoomAxis 集成配置 */\n dataZoomAxis?: IDataZoomAxisConfig;\n\n /** 最小 millisecondsPerPixel 值(毫秒/像素) */\n minMillisecondsPerPixel?: number;\n\n /** 最大 millisecondsPerPixel 值(毫秒/像素) */\n maxMillisecondsPerPixel?: number;\n\n /** 缩放步长:控制缩放的精细程度,现由系统自动计算 */\n step?: number;\n\n /**\n * 级别定义:二维数组,每个级别是完整的 scales 组合\n */\n levels: ITimelineScale[][];\n}\n\n/**\n * 级别阈值信息\n * 用于级别选择算法\n */\nexport interface ILevelThreshold {\n /** 级别索引 */\n levelIndex: number;\n\n /** 该级别可用的最小 millisecondsPerPixel 值 */\n minMillisecondsPerPixel: number;\n\n /** 该级别可用的最大 millisecondsPerPixel 值 */\n maxMillisecondsPerPixel: number;\n\n /** 最小时间单位描述 */\n minUnit: string;\n\n /** 最小时间单位的毫秒数 */\n minUnitMs: number;\n}\n\n/**\n * 缩放事件参数接口\n * 当 Gantt 发生缩放时触发的事件数据\n */\nexport interface IZoomEventArgs {\n /** 缩放前的列宽 */\n oldWidth: number;\n /** 缩放后的列宽 */\n newWidth: number;\n /** 缩放比例 (newWidth / oldWidth) */\n scale: number;\n /** 缩放前的millisecondsPerPixel */\n oldMillisecondsPerPixel?: number;\n /** 缩放后的millisecondsPerPixel */\n newMillisecondsPerPixel?: number;\n}\n"]}
@@ -0,0 +1 @@
1
+ export { Group, Text, Image, Arc, Area, Circle, Line, Path, Rect, RichText } from '@visactor/vtable/es/vrender';
package/cjs/vrender.js ADDED
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.RichText = exports.Rect = exports.Path = exports.Line = exports.Circle = exports.Area = exports.Arc = exports.Image = exports.Text = exports.Group = void 0;
6
+
7
+ var vrender_1 = require("@visactor/vtable/es/vrender");
8
+
9
+ Object.defineProperty(exports, "Group", {
10
+ enumerable: !0,
11
+ get: function() {
12
+ return vrender_1.Group;
13
+ }
14
+ }), Object.defineProperty(exports, "Text", {
15
+ enumerable: !0,
16
+ get: function() {
17
+ return vrender_1.Text;
18
+ }
19
+ }), Object.defineProperty(exports, "Image", {
20
+ enumerable: !0,
21
+ get: function() {
22
+ return vrender_1.Image;
23
+ }
24
+ }), Object.defineProperty(exports, "Arc", {
25
+ enumerable: !0,
26
+ get: function() {
27
+ return vrender_1.Arc;
28
+ }
29
+ }), Object.defineProperty(exports, "Area", {
30
+ enumerable: !0,
31
+ get: function() {
32
+ return vrender_1.Area;
33
+ }
34
+ }), Object.defineProperty(exports, "Circle", {
35
+ enumerable: !0,
36
+ get: function() {
37
+ return vrender_1.Circle;
38
+ }
39
+ }), Object.defineProperty(exports, "Line", {
40
+ enumerable: !0,
41
+ get: function() {
42
+ return vrender_1.Line;
43
+ }
44
+ }), Object.defineProperty(exports, "Path", {
45
+ enumerable: !0,
46
+ get: function() {
47
+ return vrender_1.Path;
48
+ }
49
+ }), Object.defineProperty(exports, "Rect", {
50
+ enumerable: !0,
51
+ get: function() {
52
+ return vrender_1.Rect;
53
+ }
54
+ }), Object.defineProperty(exports, "RichText", {
55
+ enumerable: !0,
56
+ get: function() {
57
+ return vrender_1.RichText;
58
+ }
59
+ });
60
+ //# sourceMappingURL=vrender.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/vrender.ts"],"names":[],"mappings":";;;AAAA,uDAAgH;AAAvG,gGAAA,KAAK,OAAA;AAAE,+FAAA,IAAI,OAAA;AAAE,gGAAA,KAAK,OAAA;AAAE,8FAAA,GAAG,OAAA;AAAE,+FAAA,IAAI,OAAA;AAAE,iGAAA,MAAM,OAAA;AAAE,+FAAA,IAAI,OAAA;AAAE,+FAAA,IAAI,OAAA;AAAE,+FAAA,IAAI,OAAA;AAAE,mGAAA,QAAQ,OAAA","file":"vrender.js","sourcesContent":["export { Group, Text, Image, Arc, Area, Circle, Line, Path, Rect, RichText } from '@visactor/vtable/es/vrender';\n"]}
@@ -0,0 +1 @@
1
+ export { register, themes, CustomLayout, TYPES, TABLE_EVENT_TYPE } from '@visactor/vtable';
package/cjs/vtable.js ADDED
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.TABLE_EVENT_TYPE = exports.TYPES = exports.CustomLayout = exports.themes = exports.register = void 0;
6
+
7
+ var vtable_1 = require("@visactor/vtable");
8
+
9
+ Object.defineProperty(exports, "register", {
10
+ enumerable: !0,
11
+ get: function() {
12
+ return vtable_1.register;
13
+ }
14
+ }), Object.defineProperty(exports, "themes", {
15
+ enumerable: !0,
16
+ get: function() {
17
+ return vtable_1.themes;
18
+ }
19
+ }), Object.defineProperty(exports, "CustomLayout", {
20
+ enumerable: !0,
21
+ get: function() {
22
+ return vtable_1.CustomLayout;
23
+ }
24
+ }), Object.defineProperty(exports, "TYPES", {
25
+ enumerable: !0,
26
+ get: function() {
27
+ return vtable_1.TYPES;
28
+ }
29
+ }), Object.defineProperty(exports, "TABLE_EVENT_TYPE", {
30
+ enumerable: !0,
31
+ get: function() {
32
+ return vtable_1.TABLE_EVENT_TYPE;
33
+ }
34
+ });
35
+ //# sourceMappingURL=vtable.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/vtable.ts"],"names":[],"mappings":";;;AAAA,2CAA2F;AAAlF,kGAAA,QAAQ,OAAA;AAAE,gGAAA,MAAM,OAAA;AAAE,sGAAA,YAAY,OAAA;AAAE,+FAAA,KAAK,OAAA;AAAE,0GAAA,gBAAgB,OAAA","file":"vtable.js","sourcesContent":["export { register, themes, CustomLayout, TYPES, TABLE_EVENT_TYPE } from '@visactor/vtable';\n"]}
@@ -0,0 +1,50 @@
1
+ import type { Gantt } from '../Gantt';
2
+ export interface DataZoomConfig {
3
+ containerId?: string;
4
+ start?: number;
5
+ end?: number;
6
+ width?: number;
7
+ height?: number;
8
+ x?: number;
9
+ y?: number;
10
+ delayTime?: number;
11
+ }
12
+ export interface DataZoomLimits {
13
+ minRangeRatio: number;
14
+ maxRangeRatio: number;
15
+ minMillisecondsPerPixel: number;
16
+ maxMillisecondsPerPixel: number;
17
+ }
18
+ export declare class DataZoomIntegration {
19
+ private gantt;
20
+ private dataZoomAxis;
21
+ private stage;
22
+ private canvas;
23
+ private isUpdatingFromDataZoom;
24
+ private isUpdatingFromGantt;
25
+ private lastDataZoomState;
26
+ private cleanupCallbacks;
27
+ private resizeTimeout;
28
+ private isInitializing;
29
+ constructor(gantt: Gantt, config: DataZoomConfig);
30
+ private getContainerId;
31
+ private initializeDataZoom;
32
+ private setupEventListeners;
33
+ private calculateDataZoomLimits;
34
+ private updateDataZoomLimits;
35
+ private getGanttViewBoundaries;
36
+ private applyDataZoomRangeToGantt;
37
+ private syncInitialPosition;
38
+ syncToGantt(): void;
39
+ syncToDataZoom(): void;
40
+ private syncToGanttWithState;
41
+ setRange(start: number, end: number): void;
42
+ getRange(): {
43
+ start: number;
44
+ end: number;
45
+ };
46
+ resize(width?: number, height?: number): void;
47
+ updateResponsive(): void;
48
+ updatePosition(x?: number, y?: number): void;
49
+ destroy(): void;
50
+ }
@@ -0,0 +1,261 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.DataZoomIntegration = void 0;
6
+
7
+ const vrender_1 = require("@visactor/vtable/es/vrender");
8
+
9
+ class DataZoomIntegration {
10
+ constructor(gantt, config) {
11
+ this.isUpdatingFromDataZoom = !1, this.isUpdatingFromGantt = !1, this.lastDataZoomState = {
12
+ start: .2,
13
+ end: .5
14
+ }, this.cleanupCallbacks = [], this.resizeTimeout = null, this.isInitializing = !0,
15
+ this.gantt = gantt, this.initializeDataZoom(config), this.setupEventListeners(),
16
+ this.updateDataZoomLimits();
17
+ }
18
+ getContainerId(providedId) {
19
+ if (providedId) return providedId;
20
+ const ganttContainer = this.gantt.container;
21
+ if (null == ganttContainer ? void 0 : ganttContainer.id) return ganttContainer.id;
22
+ const ganttElements = document.querySelectorAll('[id*="gantt"], [id*="table"], [class*="gantt"], [class*="vtable"]');
23
+ if (ganttElements.length > 0) {
24
+ const element = ganttElements[0];
25
+ if (element.id) return element.id;
26
+ }
27
+ return "vTable";
28
+ }
29
+ initializeDataZoom(config) {
30
+ var _a, _b;
31
+ const containerId = this.getContainerId(config.containerId);
32
+ if (!document.getElementById(containerId)) throw new Error(`DataZoom container with ID "${containerId}" not found`);
33
+ const ganttContainer = this.gantt.container;
34
+ if (!ganttContainer) throw new Error("Gantt container not found");
35
+ const taskTableWidth = this.gantt.taskTableWidth || 0, defaultWidth = (ganttContainer.offsetWidth || 1e3) - taskTableWidth, defaultX = this.gantt.taskTableWidth || 0, {start: start = .2, end: end = .5, width: width = defaultWidth, height: height = 30, x: x = defaultX, y: y = 0, delayTime: delayTime = 10} = config;
36
+ "static" === window.getComputedStyle(ganttContainer).position && (ganttContainer.style.position = "relative");
37
+ const dataZoomWrapper = document.createElement("div");
38
+ dataZoomWrapper.id = "dataZoomWrapper", dataZoomWrapper.style.cssText = `\n width: 100%;\n height: ${height}px;\n position: absolute;\n bottom: ${y}px;\n left: 0px;\n background: transparent;\n overflow: visible;\n pointer-events: none;\n z-index: 1000;\n `,
39
+ this.canvas = document.createElement("canvas"), this.canvas.id = "dataZoomCanvas",
40
+ this.canvas.width = width, this.canvas.height = height, this.canvas.style.cssText = `\n width: ${width}px;\n height: ${height}px;\n position: absolute;\n top: 0px;\n left: ${x}px;\n pointer-events: auto;\n `,
41
+ dataZoomWrapper.appendChild(this.canvas), ganttContainer.appendChild(dataZoomWrapper),
42
+ this.stage = (0, vrender_1.createStage)({
43
+ canvas: this.canvas,
44
+ width: width,
45
+ height: height,
46
+ autoRender: !0
47
+ }), this.dataZoomAxis = new vrender_1.DataZoom({
48
+ start: start,
49
+ end: end,
50
+ position: {
51
+ x: 0,
52
+ y: 0
53
+ },
54
+ size: {
55
+ width: width,
56
+ height: height - 1
57
+ },
58
+ showDetail: !1,
59
+ delayTime: delayTime,
60
+ brushSelect: !1,
61
+ backgroundChartStyle: {
62
+ line: {
63
+ visible: !0,
64
+ stroke: "#ddd"
65
+ },
66
+ area: {
67
+ visible: !0,
68
+ fill: "#f5f5f5"
69
+ }
70
+ },
71
+ startHandlerStyle: {
72
+ symbolType: "M-0.5-2.4h0.9c0.4,0,0.7,0.3,0.7,0.7v3.3c0,0.4-0.3,0.7-0.7,0.7h-0.9c-0.4,0-0.7-0.3-0.7-0.7v-3.3\nC-1.2-2-0.9-2.4-0.5-2.4z M-0.4-1.4L-0.4-1.4c0,0,0,0.1,0,0.1v2.6c0,0.1,0,0.1,0,0.1l0,0c0,0,0-0.1,0-0.1v-2.6\nC-0.4-1.4-0.4-1.4-0.4-1.4z M0.3-1.4L0.3-1.4c0,0,0,0.1,0,0.1v2.6c0,0.1,0,0.1,0,0.1l0,0c0,0,0-0.1,0-0.1v-2.6\nC0.3-1.4,0.3-1.4,0.3-1.4z;",
73
+ fill: "#fff",
74
+ size: null !== (_a = config.width) && void 0 !== _a ? _a : 30,
75
+ stroke: "#c2c8cf",
76
+ lineWidth: 1
77
+ },
78
+ endHandlerStyle: {
79
+ symbolType: "M-0.5-2.4h0.9c0.4,0,0.7,0.3,0.7,0.7v3.3c0,0.4-0.3,0.7-0.7,0.7h-0.9c-0.4,0-0.7-0.3-0.7-0.7v-3.3\nC-1.2-2-0.9-2.4-0.5-2.4z M-0.4-1.4L-0.4-1.4c0,0,0,0.1,0,0.1v2.6c0,0.1,0,0.1,0,0.1l0,0c0,0,0-0.1,0-0.1v-2.6\nC-0.4-1.4-0.4-1.4-0.4-1.4z M0.3-1.4L0.3-1.4c0,0,0,0.1,0,0.1v2.6c0,0.1,0,0.1,0,0.1l0,0c0,0,0-0.1,0-0.1v-2.6\nC0.3-1.4,0.3-1.4,0.3-1.4z;",
80
+ fill: "#fff",
81
+ size: null !== (_b = config.width) && void 0 !== _b ? _b : 30,
82
+ stroke: "#c2c8cf",
83
+ lineWidth: 1
84
+ },
85
+ middleHandlerStyle: {
86
+ visible: !1
87
+ }
88
+ }), this.stage.defaultLayer.add(this.dataZoomAxis), vrender_1.vglobal.getRequestAnimationFrame()((() => {
89
+ if (this.isInitializing) {
90
+ const boundaries = this.getGanttViewBoundaries();
91
+ this.dataZoomAxis.setStartAndEnd(boundaries.startRatio, boundaries.endRatio), this.isInitializing = !1;
92
+ }
93
+ this.stage.render();
94
+ })), this.lastDataZoomState = {
95
+ start: start,
96
+ end: end
97
+ };
98
+ }
99
+ setupEventListeners() {
100
+ const dataZoomChangeHandler = event => {
101
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
102
+ if (this.isUpdatingFromGantt) return;
103
+ this.isUpdatingFromDataZoom = !0;
104
+ let start = null !== (_c = null !== (_a = event.start) && void 0 !== _a ? _a : null === (_b = event.detail) || void 0 === _b ? void 0 : _b.start) && void 0 !== _c ? _c : null === (_e = null === (_d = event.currentTarget) || void 0 === _d ? void 0 : _d.attribute) || void 0 === _e ? void 0 : _e.start, end = null !== (_h = null !== (_f = event.end) && void 0 !== _f ? _f : null === (_g = event.detail) || void 0 === _g ? void 0 : _g.end) && void 0 !== _h ? _h : null === (_k = null === (_j = event.currentTarget) || void 0 === _j ? void 0 : _j.attribute) || void 0 === _k ? void 0 : _k.end;
105
+ void 0 !== start && void 0 !== end || (start = this.dataZoomAxis.attribute.start,
106
+ end = this.dataZoomAxis.attribute.end), void 0 === start || void 0 === end || isNaN(start) || isNaN(end) || this.applyDataZoomRangeToGantt(start, end),
107
+ setTimeout((() => {
108
+ this.isUpdatingFromDataZoom = !1;
109
+ }), 50);
110
+ };
111
+ this.dataZoomAxis.addEventListener("change", dataZoomChangeHandler), this.cleanupCallbacks.push((() => {
112
+ this.dataZoomAxis.removeEventListener("change", dataZoomChangeHandler);
113
+ }));
114
+ const ganttScrollHandler = event => {
115
+ if (this.isUpdatingFromDataZoom) return;
116
+ if ("horizontal" !== event.scrollDirection) return;
117
+ this.isUpdatingFromGantt = !0;
118
+ const boundaries = this.getGanttViewBoundaries();
119
+ this.dataZoomAxis.setStartAndEnd(boundaries.startRatio, boundaries.endRatio), this.stage.render(),
120
+ setTimeout((() => {
121
+ this.dataZoomAxis.setAttribute("disableTriggerEvent", !1), this.isUpdatingFromGantt = !1;
122
+ }), 10);
123
+ };
124
+ this.gantt.addEventListener("scroll", ganttScrollHandler), this.cleanupCallbacks.push((() => {
125
+ this.gantt.removeEventListener("scroll", ganttScrollHandler);
126
+ }));
127
+ const windowResizeHandler = () => {
128
+ clearTimeout(this.resizeTimeout), this.resizeTimeout = setTimeout((() => {
129
+ this.updateResponsive(), this.updateDataZoomLimits();
130
+ }), 50);
131
+ };
132
+ window.addEventListener("resize", windowResizeHandler), this.cleanupCallbacks.push((() => {
133
+ window.removeEventListener("resize", windowResizeHandler), this.resizeTimeout && clearTimeout(this.resizeTimeout);
134
+ }));
135
+ const ganttZoomHandler = () => {
136
+ setTimeout((() => {
137
+ this.updateDataZoomLimits(), this.isUpdatingFromDataZoom || this.syncToDataZoom();
138
+ }), 50);
139
+ };
140
+ this.gantt.addEventListener("zoom", ganttZoomHandler), this.cleanupCallbacks.push((() => {
141
+ this.gantt.removeEventListener("zoom", ganttZoomHandler);
142
+ }));
143
+ }
144
+ calculateDataZoomLimits() {
145
+ var _a, _b, _c, _d, _e, _f, _g, _h;
146
+ let minMillisecondsPerPixel, maxMillisecondsPerPixel;
147
+ this.gantt.zoomScaleManager ? (minMillisecondsPerPixel = (null === (_b = (_a = this.gantt.zoomScaleManager).getGlobalMinMillisecondsPerPixel) || void 0 === _b ? void 0 : _b.call(_a)) || 1e3,
148
+ maxMillisecondsPerPixel = (null === (_d = (_c = this.gantt.zoomScaleManager).getGlobalMaxMillisecondsPerPixel) || void 0 === _d ? void 0 : _d.call(_c)) || 6e6) : (minMillisecondsPerPixel = null !== (_f = null === (_e = this.gantt.parsedOptions.zoom) || void 0 === _e ? void 0 : _e.minMillisecondsPerPixel) && void 0 !== _f ? _f : 1e3,
149
+ maxMillisecondsPerPixel = null !== (_h = null === (_g = this.gantt.parsedOptions.zoom) || void 0 === _g ? void 0 : _g.maxMillisecondsPerPixel) && void 0 !== _h ? _h : 6e6);
150
+ const viewportWidth = this.gantt.tableNoFrameWidth, totalTimeRange = this.gantt.parsedOptions._maxDateTime - this.gantt.parsedOptions._minDateTime, minViewTimeRange = minMillisecondsPerPixel * viewportWidth, minRangeRatio = Math.min(1, minViewTimeRange / totalTimeRange), maxViewTimeRange = maxMillisecondsPerPixel * viewportWidth, maxRangeRatio = Math.min(1, maxViewTimeRange / totalTimeRange);
151
+ return {
152
+ minRangeRatio: Math.min(minRangeRatio, maxRangeRatio),
153
+ maxRangeRatio: Math.max(minRangeRatio, maxRangeRatio),
154
+ minMillisecondsPerPixel: minMillisecondsPerPixel,
155
+ maxMillisecondsPerPixel: maxMillisecondsPerPixel
156
+ };
157
+ }
158
+ updateDataZoomLimits() {
159
+ const limits = this.calculateDataZoomLimits();
160
+ this.dataZoomAxis.setAttributes({
161
+ minSpan: limits.minRangeRatio,
162
+ maxSpan: limits.maxRangeRatio
163
+ }), this.stage.render();
164
+ }
165
+ getGanttViewBoundaries() {
166
+ const scrollLeft = this.gantt.stateManager.scrollLeft, totalWidth = this.gantt.getAllDateColsWidth(), viewportWidth = this.gantt.tableNoFrameWidth;
167
+ return {
168
+ scrollLeft: scrollLeft,
169
+ totalWidth: totalWidth,
170
+ viewportWidth: viewportWidth,
171
+ startRatio: Math.max(0, Math.min(1, scrollLeft / totalWidth)),
172
+ endRatio: Math.max(0, Math.min(1, (scrollLeft + viewportWidth) / totalWidth))
173
+ };
174
+ }
175
+ applyDataZoomRangeToGantt(start, end) {
176
+ if (void 0 === start || void 0 === end || isNaN(start) || isNaN(end)) return;
177
+ this.lastDataZoomState = {
178
+ start: start,
179
+ end: end
180
+ };
181
+ const currentViewportWidth = this.gantt.tableNoFrameWidth, currentMillisecondsPerPixel = this.gantt.getCurrentMillisecondsPerPixel(), rangeRatio = end - start, targetMillisecondsPerPixel = (this.gantt.parsedOptions._maxDateTime - this.gantt.parsedOptions._minDateTime) * rangeRatio / currentViewportWidth;
182
+ if (Math.abs(targetMillisecondsPerPixel - currentMillisecondsPerPixel) > .01 * currentMillisecondsPerPixel) if (this.gantt.zoomScaleManager) {
183
+ const targetLevel = this.gantt.zoomScaleManager.findOptimalLevel(targetMillisecondsPerPixel);
184
+ targetLevel !== this.gantt.zoomScaleManager.getCurrentLevel() && this.gantt.zoomScaleManager.switchToLevel(targetLevel),
185
+ this.gantt.setMillisecondsPerPixel(targetMillisecondsPerPixel);
186
+ } else this.gantt.setMillisecondsPerPixel(targetMillisecondsPerPixel);
187
+ const targetScrollLeft = start * this.gantt.getAllDateColsWidth();
188
+ this.gantt.stateManager.setScrollLeft(targetScrollLeft);
189
+ }
190
+ syncInitialPosition() {
191
+ setTimeout((() => {
192
+ const boundaries = this.getGanttViewBoundaries();
193
+ (boundaries.startRatio > 0 || boundaries.endRatio < 1) && this.dataZoomAxis.setStartAndEnd(boundaries.startRatio, boundaries.endRatio);
194
+ }), 100);
195
+ }
196
+ syncToGantt() {
197
+ const start = this.dataZoomAxis.attribute.start || 0, end = this.dataZoomAxis.attribute.end || 1;
198
+ this.applyDataZoomRangeToGantt(start, end);
199
+ }
200
+ syncToDataZoom() {
201
+ const boundaries = this.getGanttViewBoundaries();
202
+ this.dataZoomAxis.setStartAndEnd(boundaries.startRatio, boundaries.endRatio);
203
+ }
204
+ syncToGanttWithState(start, end) {
205
+ this.isUpdatingFromDataZoom = !0, this.applyDataZoomRangeToGantt(start, end), setTimeout((() => {
206
+ this.isUpdatingFromDataZoom = !1;
207
+ }), 50);
208
+ }
209
+ setRange(start, end) {
210
+ this.dataZoomAxis.setStartAndEnd(start, end);
211
+ }
212
+ getRange() {
213
+ return {
214
+ start: this.dataZoomAxis.attribute.start || 0,
215
+ end: this.dataZoomAxis.attribute.end || 1
216
+ };
217
+ }
218
+ resize(width, height) {
219
+ if (void 0 === width) {
220
+ const ganttContainer = this.gantt.container;
221
+ if (ganttContainer) {
222
+ const taskTableWidth = this.gantt.taskTableWidth || 0;
223
+ width = ganttContainer.offsetWidth - taskTableWidth;
224
+ } else width = 1e3;
225
+ }
226
+ void 0 === height && (height = 30), this.canvas.width = width, this.canvas.height = height,
227
+ this.canvas.style.width = `${width}px`, this.canvas.style.height = `${height}px`,
228
+ this.stage.resize(width, height), this.dataZoomAxis.setAttributes({
229
+ size: {
230
+ width: width,
231
+ height: height - 1
232
+ }
233
+ }), this.stage.render();
234
+ }
235
+ updateResponsive() {
236
+ const ganttContainer = this.gantt.container;
237
+ if (!ganttContainer) return;
238
+ const taskTableWidth = this.gantt.taskTableWidth || 0, newWidth = ganttContainer.offsetWidth - taskTableWidth;
239
+ this.resize(newWidth);
240
+ const defaultX = this.gantt.taskTableWidth || 0;
241
+ this.updatePosition(defaultX, 0), setTimeout((() => {
242
+ this.syncToDataZoom();
243
+ }), 10);
244
+ }
245
+ updatePosition(x, y) {
246
+ var _a;
247
+ const xPos = null !== (_a = null != x ? x : this.gantt.taskTableWidth) && void 0 !== _a ? _a : 0;
248
+ this.canvas.style.left = `${xPos}px`;
249
+ }
250
+ destroy() {
251
+ if (this.cleanupCallbacks.forEach((cleanup => cleanup())), this.cleanupCallbacks = [],
252
+ this.canvas && this.canvas.parentNode) {
253
+ const wrapper = this.canvas.parentNode;
254
+ wrapper && "dataZoomWrapper" === wrapper.id && wrapper.parentNode ? wrapper.parentNode.removeChild(wrapper) : wrapper.removeChild(this.canvas);
255
+ }
256
+ this.stage && this.stage.release();
257
+ }
258
+ }
259
+
260
+ exports.DataZoomIntegration = DataZoomIntegration;
261
+ //# sourceMappingURL=DataZoomIntegration.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/zoom-scale/DataZoomIntegration.ts"],"names":[],"mappings":"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","file":"DataZoomIntegration.js","sourcesContent":["import type { Gantt } from '../Gantt';\nimport { DataZoom, createStage, vglobal } from '@visactor/vtable/es/vrender';\n\nexport interface DataZoomConfig {\n /** DataZoom 容器 ID(可选,如果不提供会自动从 Gantt 实例获取) */\n containerId?: string;\n /** DataZoom 初始开始位置 (0-1) */\n start?: number;\n /** DataZoom 初始结束位置 (0-1) */\n end?: number;\n /** DataZoom 宽度 */\n width?: number;\n /** DataZoom 高度 */\n height?: number;\n /** X 坐标 */\n x?: number;\n /** Y 坐标 */\n y?: number;\n /** 事件触发延迟时间 */\n delayTime?: number;\n}\n\nexport interface DataZoomLimits {\n minRangeRatio: number;\n maxRangeRatio: number;\n minMillisecondsPerPixel: number;\n maxMillisecondsPerPixel: number;\n}\n\n/**\n * DataZoom 与 Gantt 集成管理器\n * 负责 DataZoom 组件与 Gantt 图表的双向同步\n */\nexport class DataZoomIntegration {\n private gantt: Gantt;\n private dataZoomAxis: DataZoom;\n private stage: any;\n private canvas: HTMLCanvasElement;\n private isUpdatingFromDataZoom = false;\n private isUpdatingFromGantt = false;\n private lastDataZoomState = { start: 0.2, end: 0.5 };\n private cleanupCallbacks: (() => void)[] = [];\n private resizeTimeout: NodeJS.Timeout | null = null;\n private isInitializing = true;\n\n constructor(gantt: Gantt, config: DataZoomConfig) {\n this.gantt = gantt;\n this.initializeDataZoom(config);\n this.setupEventListeners();\n this.updateDataZoomLimits();\n }\n\n /**\n * 获取容器 ID\n */\n private getContainerId(providedId?: string): string {\n if (providedId) {\n return providedId;\n }\n\n // 尝试从 Gantt 实例获取容器 ID\n const ganttContainer = (this.gantt as any).container;\n if (ganttContainer?.id) {\n return ganttContainer.id;\n }\n\n const ganttElements = document.querySelectorAll(\n '[id*=\"gantt\"], [id*=\"table\"], [class*=\"gantt\"], [class*=\"vtable\"]'\n );\n if (ganttElements.length > 0) {\n const element = ganttElements[0] as HTMLElement;\n if (element.id) {\n return element.id;\n }\n }\n\n // 生成默认 ID\n return 'vTable';\n }\n\n /**\n * 初始化 DataZoom 组件\n */\n private initializeDataZoom(config: DataZoomConfig): void {\n // 自动获取容器 ID\n const containerId = this.getContainerId(config.containerId);\n const container = document.getElementById(containerId);\n if (!container) {\n throw new Error(`DataZoom container with ID \"${containerId}\" not found`);\n }\n\n // 获取甘特图容器(VTable 容器)\n const ganttContainer = this.gantt.container as HTMLElement;\n if (!ganttContainer) {\n throw new Error('Gantt container not found');\n }\n\n // 计算 DataZoom 的默认宽度:甘特图容器宽度减去左侧表头宽度\n const taskTableWidth = this.gantt.taskTableWidth || 0;\n const ganttContainerWidth = ganttContainer.offsetWidth || 1000;\n const defaultWidth = ganttContainerWidth - taskTableWidth;\n\n // 计算默认 x 坐标,排除左侧表头宽度\n const defaultX = this.gantt.taskTableWidth || 0;\n\n const {\n start = 0.2,\n end = 0.5,\n width = defaultWidth, // 默认使用容器宽度\n height = 30,\n x = defaultX, // 默认排除左侧表头宽度,与时间轴内容区域对齐\n y = 0, // 默认贴着容器底部\n delayTime = 10\n } = config;\n\n // 确保 VTable 容器有相对定位\n const containerStyle = window.getComputedStyle(ganttContainer);\n if (containerStyle.position === 'static') {\n ganttContainer.style.position = 'relative';\n }\n\n const dataZoomWrapper = document.createElement('div');\n dataZoomWrapper.id = 'dataZoomWrapper';\n dataZoomWrapper.style.cssText = `\n width: 100%;\n height: ${height}px;\n position: absolute;\n bottom: ${y}px;\n left: 0px;\n background: transparent;\n overflow: visible;\n pointer-events: none;\n z-index: 1000;\n `;\n\n // 创建独立的 Canvas 和 Stage\n this.canvas = document.createElement('canvas');\n this.canvas.id = 'dataZoomCanvas';\n this.canvas.width = width;\n this.canvas.height = height;\n\n this.canvas.style.cssText = `\n width: ${width}px;\n height: ${height}px;\n position: absolute;\n top: 0px;\n left: ${x}px;\n pointer-events: auto;\n `;\n\n // 将 Canvas 添加到包装器,再将包装器添加到 VTable 容器\n dataZoomWrapper.appendChild(this.canvas);\n ganttContainer.appendChild(dataZoomWrapper);\n\n this.stage = createStage({\n canvas: this.canvas,\n width,\n height,\n autoRender: true\n });\n\n // 创建 DataZoom 实例\n this.dataZoomAxis = new DataZoom({\n start,\n end,\n position: { x: 0, y: 0 },\n size: { width, height: height - 1 },\n showDetail: false,\n delayTime,\n brushSelect: false,\n backgroundChartStyle: {\n line: { visible: true, stroke: '#ddd' },\n area: { visible: true, fill: '#f5f5f5' }\n },\n startHandlerStyle: {\n symbolType:\n 'M-0.5-2.4h0.9c0.4,0,0.7,0.3,0.7,0.7v3.3c0,0.4-0.3,0.7-0.7,0.7h-0.9c-0.4,0-0.7-0.3-0.7-0.7v-3.3\\n' +\n 'C-1.2-2-0.9-2.4-0.5-2.4z M-0.4-1.4L-0.4-1.4c0,0,0,0.1,0,0.1v2.6c0,0.1,0,0.1,0,0.1l0,0c0,0,0-0.1,0-0.1' +\n 'v-2.6\\nC-0.4-1.4-0.4-1.4-0.4-1.4z M0.3-1.4L0.3-1.4c0,0,0,0.1,0,0.1v2.6c0,0.1,0,0.1,0,0.1l0,0c0,0,' +\n '0-0.1,0-0.1v-2.6\\nC0.3-1.4,0.3-1.4,0.3-1.4z;',\n fill: '#fff',\n size: config.width ?? 30,\n stroke: '#c2c8cf',\n lineWidth: 1\n },\n endHandlerStyle: {\n symbolType:\n 'M-0.5-2.4h0.9c0.4,0,0.7,0.3,0.7,0.7v3.3c0,0.4-0.3,0.7-0.7,0.7h-0.9c-0.4,0-0.7-0.3-0.7-0.7v-3.3\\n' +\n 'C-1.2-2-0.9-2.4-0.5-2.4z M-0.4-1.4L-0.4-1.4c0,0,0,0.1,0,0.1v2.6c0,0.1,0,0.1,0,0.1l0,0c0,0,0-0.1,0-0.1' +\n 'v-2.6\\nC-0.4-1.4-0.4-1.4-0.4-1.4z M0.3-1.4L0.3-1.4c0,0,0,0.1,0,0.1v2.6c0,0.1,0,0.1,0,0.1l0,0c0,0,' +\n '0-0.1,0-0.1v-2.6\\nC0.3-1.4,0.3-1.4,0.3-1.4z;',\n fill: '#fff',\n size: config.width ?? 30,\n stroke: '#c2c8cf',\n lineWidth: 1\n },\n middleHandlerStyle: {\n visible: false\n }\n });\n\n this.stage.defaultLayer.add(this.dataZoomAxis as any);\n\n vglobal.getRequestAnimationFrame()(() => {\n if (this.isInitializing) {\n const boundaries = this.getGanttViewBoundaries();\n this.dataZoomAxis.setStartAndEnd(boundaries.startRatio, boundaries.endRatio);\n this.isInitializing = false;\n }\n this.stage.render();\n });\n\n this.lastDataZoomState = { start, end };\n }\n\n /**\n * 设置事件监听器\n */\n private setupEventListeners(): void {\n // DataZoom 变化时同步到 Gantt\n const dataZoomChangeHandler = (event: any) => {\n if (this.isUpdatingFromGantt) {\n return;\n }\n\n this.isUpdatingFromDataZoom = true;\n\n let start = event.start ?? event.detail?.start ?? event.currentTarget?.attribute?.start;\n let end = event.end ?? event.detail?.end ?? event.currentTarget?.attribute?.end;\n\n if (start === undefined || end === undefined) {\n start = this.dataZoomAxis.attribute.start;\n end = this.dataZoomAxis.attribute.end;\n }\n\n if (start !== undefined && end !== undefined && !isNaN(start) && !isNaN(end)) {\n this.applyDataZoomRangeToGantt(start, end);\n }\n\n setTimeout(() => {\n this.isUpdatingFromDataZoom = false;\n }, 50);\n };\n\n this.dataZoomAxis.addEventListener('change', dataZoomChangeHandler);\n this.cleanupCallbacks.push(() => {\n this.dataZoomAxis.removeEventListener('change', dataZoomChangeHandler);\n });\n\n // Gantt 滚动时同步到 DataZoom\n const ganttScrollHandler = (event: any) => {\n if (this.isUpdatingFromDataZoom) {\n return;\n }\n if (event.scrollDirection !== 'horizontal') {\n return;\n }\n\n this.isUpdatingFromGantt = true;\n const boundaries = this.getGanttViewBoundaries();\n this.dataZoomAxis.setStartAndEnd(boundaries.startRatio, boundaries.endRatio);\n\n this.stage.render();\n\n setTimeout(() => {\n this.dataZoomAxis.setAttribute('disableTriggerEvent', false);\n this.isUpdatingFromGantt = false;\n }, 10);\n };\n\n this.gantt.addEventListener('scroll', ganttScrollHandler);\n this.cleanupCallbacks.push(() => {\n this.gantt.removeEventListener('scroll', ganttScrollHandler);\n });\n\n // 窗口大小变化时的响应式更新\n const windowResizeHandler = () => {\n clearTimeout(this.resizeTimeout);\n this.resizeTimeout = setTimeout(() => {\n this.updateResponsive();\n this.updateDataZoomLimits();\n }, 50);\n };\n\n window.addEventListener('resize', windowResizeHandler);\n this.cleanupCallbacks.push(() => {\n window.removeEventListener('resize', windowResizeHandler);\n if (this.resizeTimeout) {\n clearTimeout(this.resizeTimeout);\n }\n });\n\n // 监听 Gantt 的缩放事件,重新计算限制并同步 DataZoom 位置\n const ganttZoomHandler = () => {\n setTimeout(() => {\n this.updateDataZoomLimits();\n // 同步 DataZoom 位置到当前 Gantt 视图\n if (!this.isUpdatingFromDataZoom) {\n this.syncToDataZoom();\n }\n }, 50);\n };\n\n this.gantt.addEventListener('zoom', ganttZoomHandler);\n this.cleanupCallbacks.push(() => {\n this.gantt.removeEventListener('zoom', ganttZoomHandler);\n });\n }\n\n /**\n * 计算 DataZoom 的合理范围限制\n */\n private calculateDataZoomLimits(): DataZoomLimits {\n // 获取 Gantt 的缩放限制\n let minMillisecondsPerPixel: number;\n let maxMillisecondsPerPixel: number;\n\n if (this.gantt.zoomScaleManager) {\n minMillisecondsPerPixel = this.gantt.zoomScaleManager.getGlobalMinMillisecondsPerPixel?.() || 1000;\n maxMillisecondsPerPixel = this.gantt.zoomScaleManager.getGlobalMaxMillisecondsPerPixel?.() || 6000000;\n } else {\n minMillisecondsPerPixel = this.gantt.parsedOptions.zoom?.minMillisecondsPerPixel ?? 1000;\n maxMillisecondsPerPixel = this.gantt.parsedOptions.zoom?.maxMillisecondsPerPixel ?? 6000000;\n }\n\n // 获取关键参数\n const viewportWidth = this.gantt.tableNoFrameWidth; // 视口宽度(像素)\n const totalTimeRange = this.gantt.parsedOptions._maxDateTime - this.gantt.parsedOptions._minDateTime; // 总时间范围\n\n // 计算 minSpan:当使用 minMillisecondsPerPixel 时,视口能显示的时间范围占总时间的比例\n const minViewTimeRange = minMillisecondsPerPixel * viewportWidth; // 最小缩放时视口显示的时间范围\n const minRangeRatio = Math.min(1.0, minViewTimeRange / totalTimeRange);\n\n // 计算 maxSpan:当使用 maxMillisecondsPerPixel 时,视口能显示的时间范围占总时间的比例\n const maxViewTimeRange = maxMillisecondsPerPixel * viewportWidth; // 最大缩放时视口显示的时间范围\n const maxRangeRatio = Math.min(1.0, maxViewTimeRange / totalTimeRange);\n\n // 确保逻辑正确:minSpan < maxSpan\n const finalMinRangeRatio = Math.min(minRangeRatio, maxRangeRatio);\n const finalMaxRangeRatio = Math.max(minRangeRatio, maxRangeRatio);\n\n return {\n minRangeRatio: finalMinRangeRatio,\n maxRangeRatio: finalMaxRangeRatio,\n minMillisecondsPerPixel,\n maxMillisecondsPerPixel\n };\n }\n\n /**\n * 更新 DataZoom 的范围限制\n */\n private updateDataZoomLimits(): void {\n const limits = this.calculateDataZoomLimits();\n\n this.dataZoomAxis.setAttributes({\n minSpan: limits.minRangeRatio,\n maxSpan: limits.maxRangeRatio\n });\n\n this.stage.render();\n }\n\n /**\n * 获取 Gantt 视图边界信息\n */\n private getGanttViewBoundaries() {\n const scrollLeft = this.gantt.stateManager.scrollLeft;\n const totalWidth = this.gantt.getAllDateColsWidth();\n const viewportWidth = this.gantt.tableNoFrameWidth;\n\n const startRatio = Math.max(0, Math.min(1, scrollLeft / totalWidth));\n const endRatio = Math.max(0, Math.min(1, (scrollLeft + viewportWidth) / totalWidth));\n\n return {\n scrollLeft,\n totalWidth,\n viewportWidth,\n startRatio,\n endRatio\n };\n }\n\n /**\n * 将 DataZoom 范围应用到 Gantt 视图\n */\n private applyDataZoomRangeToGantt(start: number, end: number): void {\n if (start === undefined || end === undefined || isNaN(start) || isNaN(end)) {\n return;\n }\n\n // 更新状态记录\n this.lastDataZoomState = { start, end };\n\n // 获取当前 Gantt 的基础信息\n const currentViewportWidth = this.gantt.tableNoFrameWidth;\n const currentMillisecondsPerPixel = this.gantt.getCurrentMillisecondsPerPixel();\n const rangeRatio = end - start;\n\n // 根据 DataZoom 范围计算目标 millisecondsPerPixel\n const totalTimeRange = this.gantt.parsedOptions._maxDateTime - this.gantt.parsedOptions._minDateTime;\n const selectedTimeRange = totalTimeRange * rangeRatio;\n const targetMillisecondsPerPixel = selectedTimeRange / currentViewportWidth;\n\n // 应用新的 millisecondsPerPixel\n if (Math.abs(targetMillisecondsPerPixel - currentMillisecondsPerPixel) > currentMillisecondsPerPixel * 0.01) {\n if (this.gantt.zoomScaleManager) {\n const targetLevel = this.gantt.zoomScaleManager.findOptimalLevel(targetMillisecondsPerPixel);\n const currentLevel = this.gantt.zoomScaleManager.getCurrentLevel();\n\n if (targetLevel !== currentLevel) {\n this.gantt.zoomScaleManager.switchToLevel(targetLevel);\n }\n\n this.gantt.setMillisecondsPerPixel(targetMillisecondsPerPixel);\n } else {\n this.gantt.setMillisecondsPerPixel(targetMillisecondsPerPixel);\n }\n }\n\n // 重新计算滚动位置\n const newTotalWidth = this.gantt.getAllDateColsWidth();\n const targetScrollLeft = start * newTotalWidth;\n this.gantt.stateManager.setScrollLeft(targetScrollLeft);\n }\n\n /**\n * 同步初始位置\n */\n private syncInitialPosition(): void {\n setTimeout(() => {\n const boundaries = this.getGanttViewBoundaries();\n if (boundaries.startRatio > 0 || boundaries.endRatio < 1) {\n this.dataZoomAxis.setStartAndEnd(boundaries.startRatio, boundaries.endRatio);\n }\n }, 100);\n }\n\n /**\n * 手动同步 DataZoom 到 Gantt 当前视图\n */\n syncToGantt(): void {\n const start = this.dataZoomAxis.attribute.start || 0;\n const end = this.dataZoomAxis.attribute.end || 1;\n this.applyDataZoomRangeToGantt(start, end);\n }\n\n /**\n * 手动同步 Gantt 当前视图到 DataZoom\n */\n syncToDataZoom(): void {\n const boundaries = this.getGanttViewBoundaries();\n\n this.dataZoomAxis.setStartAndEnd(boundaries.startRatio, boundaries.endRatio);\n }\n\n /**\n * 私有方法:同步 DataZoom 范围到 Gantt\n */\n private syncToGanttWithState(start: number, end: number): void {\n this.isUpdatingFromDataZoom = true;\n this.applyDataZoomRangeToGantt(start, end);\n setTimeout(() => {\n this.isUpdatingFromDataZoom = false;\n }, 50);\n }\n\n /**\n * 设置 DataZoom 的范围\n */\n setRange(start: number, end: number): void {\n this.dataZoomAxis.setStartAndEnd(start, end);\n }\n\n /**\n * 获取 DataZoom 当前范围\n */\n getRange(): { start: number; end: number } {\n return {\n start: this.dataZoomAxis.attribute.start || 0,\n end: this.dataZoomAxis.attribute.end || 1\n };\n }\n\n /**\n * 更新 DataZoom 尺寸\n */\n resize(width?: number, height?: number): void {\n if (width === undefined) {\n // 使用甘特图容器而不是外部容器来计算宽度\n const ganttContainer = this.gantt.container as HTMLElement;\n if (ganttContainer) {\n const taskTableWidth = this.gantt.taskTableWidth || 0;\n width = ganttContainer.offsetWidth - taskTableWidth;\n } else {\n width = 1000;\n }\n }\n\n if (height === undefined) {\n height = 30;\n }\n\n this.canvas.width = width;\n this.canvas.height = height;\n this.canvas.style.width = `${width}px`;\n this.canvas.style.height = `${height}px`;\n\n this.stage.resize(width, height);\n this.dataZoomAxis.setAttributes({\n size: { width, height: height - 1 }\n });\n\n // 强制重新渲染\n this.stage.render();\n }\n\n /**\n * 响应式更新 DataZoom 大小和位置\n * 当容器大小或位置发生变化时调用\n */\n updateResponsive(): void {\n const ganttContainer = this.gantt.container as HTMLElement;\n if (!ganttContainer) {\n return;\n }\n\n // 计算新宽度:甘特图容器宽度减去左侧表头宽度\n const taskTableWidth = this.gantt.taskTableWidth || 0;\n const newWidth = ganttContainer.offsetWidth - taskTableWidth;\n\n this.resize(newWidth);\n\n // 更新位置(保持与时间轴内容区域对齐,排除左侧表头)\n const defaultX = this.gantt.taskTableWidth || 0;\n this.updatePosition(defaultX, 0);\n\n // 重新同步 DataZoom 状态,因为视图宽度变化会影响时间范围的显示比例\n setTimeout(() => {\n this.syncToDataZoom();\n }, 10);\n }\n\n /**\n * 更新 DataZoom 位置\n * 当容器位置发生变化时调用\n */\n updatePosition(x?: number, y?: number): void {\n const xPos = x ?? this.gantt.taskTableWidth ?? 0;\n this.canvas.style.left = `${xPos}px`;\n }\n\n /**\n * 销毁 DataZoom 集成\n */\n destroy(): void {\n this.cleanupCallbacks.forEach(cleanup => cleanup());\n this.cleanupCallbacks = [];\n\n // 清理包装器和 Canvas\n if (this.canvas && this.canvas.parentNode) {\n const wrapper = this.canvas.parentNode as HTMLElement;\n if (wrapper && wrapper.id === 'dataZoomWrapper' && wrapper.parentNode) {\n // 移除整个包装器\n wrapper.parentNode.removeChild(wrapper);\n } else {\n // 如果没有包装器,直接移除 Canvas\n wrapper.removeChild(this.canvas);\n }\n }\n\n if (this.stage) {\n this.stage.release();\n }\n }\n}\n"]}
@@ -0,0 +1,55 @@
1
+ import type { Gantt } from '../Gantt';
2
+ import type { IZoomScale } from '../ts-types/zoom-scale';
3
+ import type { ITimelineScale } from '../ts-types/gantt-engine';
4
+ import { DataZoomIntegration, type DataZoomConfig } from './DataZoomIntegration';
5
+ export declare class ZoomScaleManager {
6
+ private readonly gantt;
7
+ readonly config: IZoomScale;
8
+ private currentLevelIndex;
9
+ private levelBoundaries;
10
+ private globalMinMillisecondsPerPixel;
11
+ private globalMaxMillisecondsPerPixel;
12
+ private dataZoomIntegration;
13
+ constructor(gantt: Gantt, config: IZoomScale);
14
+ private initializeZoomLimits;
15
+ private initializeDataZoomIfNeeded;
16
+ handleTableWidthChange(): void;
17
+ private sortLevelsByCoarseness;
18
+ private calculateGlobalMillisecondsPerPixelRange;
19
+ private calculateLevelBoundaries;
20
+ updateZoomLimits(): void;
21
+ getGlobalMinMillisecondsPerPixel(): number;
22
+ getGlobalMaxMillisecondsPerPixel(): number;
23
+ private calculateInitialMillisecondsPerPixel;
24
+ private initializeWithMillisecondsPerPixel;
25
+ private setInitialLevel;
26
+ findOptimalLevel(millisecondsPerPixel: number): number;
27
+ switchToLevel(levelIndex: number): boolean;
28
+ findMinTimeUnit(scales: ITimelineScale[]): ITimelineScale;
29
+ private getUnitMilliseconds;
30
+ private getMinColWidthForUnit;
31
+ getCurrentLevel(): number;
32
+ getInitialMillisecondsPerPixel(): number;
33
+ getCurrentZoomState(): {
34
+ minUnit: "year" | "month" | "quarter" | "week" | "day" | "hour" | "minute" | "second";
35
+ step: number;
36
+ levelNum: number;
37
+ currentColWidth: number;
38
+ };
39
+ setZoomPosition(params: {
40
+ minUnit?: string;
41
+ step?: number;
42
+ levelNum?: number;
43
+ colWidth?: number;
44
+ }): boolean;
45
+ private findLevelByMinUnit;
46
+ zoomIn(factor?: number, center?: boolean, centerX?: number): void;
47
+ zoomOut(factor?: number, center?: boolean, centerX?: number): void;
48
+ zoomByPercentage(percentage: number, center?: boolean, centerX?: number): void;
49
+ getDataZoomIntegration(): DataZoomIntegration | null;
50
+ createDataZoomIntegration(config: DataZoomConfig): DataZoomIntegration;
51
+ destroyDataZoomIntegration(): void;
52
+ updateDataZoomResponsive(): void;
53
+ recalculateTimeScale(): void;
54
+ zoomByFactor(factor: number, keepCenter?: boolean, centerX?: number): void;
55
+ }