@visactor/vtable-gantt 1.5.4

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 (190) hide show
  1. package/README.md +151 -0
  2. package/cjs/Gantt.d.ts +111 -0
  3. package/cjs/Gantt.js +244 -0
  4. package/cjs/Gantt.js.map +1 -0
  5. package/cjs/data/DataSource.d.ts +9 -0
  6. package/cjs/data/DataSource.js +30 -0
  7. package/cjs/data/DataSource.js.map +1 -0
  8. package/cjs/env.d.ts +19 -0
  9. package/cjs/env.js +48 -0
  10. package/cjs/env.js.map +1 -0
  11. package/cjs/event/EventHandler.d.ts +47 -0
  12. package/cjs/event/EventHandler.js +128 -0
  13. package/cjs/event/EventHandler.js.map +1 -0
  14. package/cjs/event/EventTarget.d.ts +12 -0
  15. package/cjs/event/EventTarget.js +67 -0
  16. package/cjs/event/EventTarget.js.map +1 -0
  17. package/cjs/event/event-manager.d.ts +15 -0
  18. package/cjs/event/event-manager.js +76 -0
  19. package/cjs/event/event-manager.js.map +1 -0
  20. package/cjs/event/scroll.d.ts +22 -0
  21. package/cjs/event/scroll.js +136 -0
  22. package/cjs/event/scroll.js.map +1 -0
  23. package/cjs/gantt-helper.d.ts +28 -0
  24. package/cjs/gantt-helper.js +225 -0
  25. package/cjs/gantt-helper.js.map +1 -0
  26. package/cjs/index.d.ts +7 -0
  27. package/cjs/index.js +48 -0
  28. package/cjs/index.js.map +1 -0
  29. package/cjs/register.d.ts +1 -0
  30. package/cjs/register.js +1 -0
  31. package/cjs/register.js.map +1 -0
  32. package/cjs/scenegraph/frame-border.d.ts +9 -0
  33. package/cjs/scenegraph/frame-border.js +42 -0
  34. package/cjs/scenegraph/frame-border.js.map +1 -0
  35. package/cjs/scenegraph/ganttNode.d.ts +7 -0
  36. package/cjs/scenegraph/ganttNode.js +16 -0
  37. package/cjs/scenegraph/ganttNode.js.map +1 -0
  38. package/cjs/scenegraph/grid.d.ts +30 -0
  39. package/cjs/scenegraph/grid.js +130 -0
  40. package/cjs/scenegraph/grid.js.map +1 -0
  41. package/cjs/scenegraph/mark-line.d.ts +15 -0
  42. package/cjs/scenegraph/mark-line.js +66 -0
  43. package/cjs/scenegraph/mark-line.js.map +1 -0
  44. package/cjs/scenegraph/scenegraph.d.ts +41 -0
  45. package/cjs/scenegraph/scenegraph.js +109 -0
  46. package/cjs/scenegraph/scenegraph.js.map +1 -0
  47. package/cjs/scenegraph/scroll-bar.d.ts +19 -0
  48. package/cjs/scenegraph/scroll-bar.js +150 -0
  49. package/cjs/scenegraph/scroll-bar.js.map +1 -0
  50. package/cjs/scenegraph/task-bar.d.ts +24 -0
  51. package/cjs/scenegraph/task-bar.js +188 -0
  52. package/cjs/scenegraph/task-bar.js.map +1 -0
  53. package/cjs/scenegraph/timeline-header.d.ts +10 -0
  54. package/cjs/scenegraph/timeline-header.js +134 -0
  55. package/cjs/scenegraph/timeline-header.js.map +1 -0
  56. package/cjs/state/gantt-table-sync.d.ts +7 -0
  57. package/cjs/state/gantt-table-sync.js +60 -0
  58. package/cjs/state/gantt-table-sync.js.map +1 -0
  59. package/cjs/state/state-manager.d.ts +58 -0
  60. package/cjs/state/state-manager.js +223 -0
  61. package/cjs/state/state-manager.js.map +1 -0
  62. package/cjs/themes.d.ts +1 -0
  63. package/cjs/themes.js +1 -0
  64. package/cjs/themes.js.map +1 -0
  65. package/cjs/tools/debounce.d.ts +1 -0
  66. package/cjs/tools/debounce.js +51 -0
  67. package/cjs/tools/debounce.js.map +1 -0
  68. package/cjs/tools/index.d.ts +2 -0
  69. package/cjs/tools/index.js +20 -0
  70. package/cjs/tools/index.js.map +1 -0
  71. package/cjs/tools/isx.d.ts +16 -0
  72. package/cjs/tools/isx.js +117 -0
  73. package/cjs/tools/isx.js.map +1 -0
  74. package/cjs/tools/pixel-ratio.d.ts +2 -0
  75. package/cjs/tools/pixel-ratio.js +16 -0
  76. package/cjs/tools/pixel-ratio.js.map +1 -0
  77. package/cjs/tools/util.d.ts +7 -0
  78. package/cjs/tools/util.js +87 -0
  79. package/cjs/tools/util.js.map +1 -0
  80. package/cjs/ts-types/EVENT_TYPE.d.ts +5 -0
  81. package/cjs/ts-types/EVENT_TYPE.js +9 -0
  82. package/cjs/ts-types/EVENT_TYPE.js.map +1 -0
  83. package/cjs/ts-types/common.d.ts +13 -0
  84. package/cjs/ts-types/common.js +14 -0
  85. package/cjs/ts-types/common.js.map +1 -0
  86. package/cjs/ts-types/events.d.ts +14 -0
  87. package/cjs/ts-types/events.js +6 -0
  88. package/cjs/ts-types/events.js.map +1 -0
  89. package/cjs/ts-types/gantt-engine.d.ts +163 -0
  90. package/cjs/ts-types/gantt-engine.js +6 -0
  91. package/cjs/ts-types/gantt-engine.js.map +1 -0
  92. package/cjs/ts-types/index.d.ts +4 -0
  93. package/cjs/ts-types/index.js +22 -0
  94. package/cjs/ts-types/index.js.map +1 -0
  95. package/dist/vtable-gantt.js +53942 -0
  96. package/dist/vtable-gantt.min.js +1 -0
  97. package/es/Gantt.d.ts +111 -0
  98. package/es/Gantt.js +246 -0
  99. package/es/Gantt.js.map +1 -0
  100. package/es/data/DataSource.d.ts +9 -0
  101. package/es/data/DataSource.js +22 -0
  102. package/es/data/DataSource.js.map +1 -0
  103. package/es/env.d.ts +19 -0
  104. package/es/env.js +42 -0
  105. package/es/env.js.map +1 -0
  106. package/es/event/EventHandler.d.ts +47 -0
  107. package/es/event/EventHandler.js +119 -0
  108. package/es/event/EventHandler.js.map +1 -0
  109. package/es/event/EventTarget.d.ts +12 -0
  110. package/es/event/EventTarget.js +58 -0
  111. package/es/event/EventTarget.js.map +1 -0
  112. package/es/event/event-manager.d.ts +15 -0
  113. package/es/event/event-manager.js +78 -0
  114. package/es/event/event-manager.js.map +1 -0
  115. package/es/event/scroll.d.ts +22 -0
  116. package/es/event/scroll.js +126 -0
  117. package/es/event/scroll.js.map +1 -0
  118. package/es/gantt-helper.d.ts +28 -0
  119. package/es/gantt-helper.js +220 -0
  120. package/es/gantt-helper.js.map +1 -0
  121. package/es/index.d.ts +7 -0
  122. package/es/index.js +10 -0
  123. package/es/index.js.map +1 -0
  124. package/es/register.d.ts +1 -0
  125. package/es/register.js +1 -0
  126. package/es/register.js.map +1 -0
  127. package/es/scenegraph/frame-border.d.ts +9 -0
  128. package/es/scenegraph/frame-border.js +34 -0
  129. package/es/scenegraph/frame-border.js.map +1 -0
  130. package/es/scenegraph/ganttNode.d.ts +7 -0
  131. package/es/scenegraph/ganttNode.js +8 -0
  132. package/es/scenegraph/ganttNode.js.map +1 -0
  133. package/es/scenegraph/grid.d.ts +30 -0
  134. package/es/scenegraph/grid.js +122 -0
  135. package/es/scenegraph/grid.js.map +1 -0
  136. package/es/scenegraph/mark-line.d.ts +15 -0
  137. package/es/scenegraph/mark-line.js +58 -0
  138. package/es/scenegraph/mark-line.js.map +1 -0
  139. package/es/scenegraph/scenegraph.d.ts +41 -0
  140. package/es/scenegraph/scenegraph.js +116 -0
  141. package/es/scenegraph/scenegraph.js.map +1 -0
  142. package/es/scenegraph/scroll-bar.d.ts +19 -0
  143. package/es/scenegraph/scroll-bar.js +144 -0
  144. package/es/scenegraph/scroll-bar.js.map +1 -0
  145. package/es/scenegraph/task-bar.d.ts +24 -0
  146. package/es/scenegraph/task-bar.js +188 -0
  147. package/es/scenegraph/task-bar.js.map +1 -0
  148. package/es/scenegraph/timeline-header.d.ts +10 -0
  149. package/es/scenegraph/timeline-header.js +130 -0
  150. package/es/scenegraph/timeline-header.js.map +1 -0
  151. package/es/state/gantt-table-sync.d.ts +7 -0
  152. package/es/state/gantt-table-sync.js +51 -0
  153. package/es/state/gantt-table-sync.js.map +1 -0
  154. package/es/state/state-manager.d.ts +58 -0
  155. package/es/state/state-manager.js +219 -0
  156. package/es/state/state-manager.js.map +1 -0
  157. package/es/themes.d.ts +1 -0
  158. package/es/themes.js +1 -0
  159. package/es/themes.js.map +1 -0
  160. package/es/tools/debounce.d.ts +1 -0
  161. package/es/tools/debounce.js +43 -0
  162. package/es/tools/debounce.js.map +1 -0
  163. package/es/tools/index.d.ts +2 -0
  164. package/es/tools/index.js +4 -0
  165. package/es/tools/index.js.map +1 -0
  166. package/es/tools/isx.d.ts +16 -0
  167. package/es/tools/isx.js +80 -0
  168. package/es/tools/isx.js.map +1 -0
  169. package/es/tools/pixel-ratio.d.ts +2 -0
  170. package/es/tools/pixel-ratio.js +12 -0
  171. package/es/tools/pixel-ratio.js.map +1 -0
  172. package/es/tools/util.d.ts +7 -0
  173. package/es/tools/util.js +78 -0
  174. package/es/tools/util.js.map +1 -0
  175. package/es/ts-types/EVENT_TYPE.d.ts +5 -0
  176. package/es/ts-types/EVENT_TYPE.js +5 -0
  177. package/es/ts-types/EVENT_TYPE.js.map +1 -0
  178. package/es/ts-types/common.d.ts +13 -0
  179. package/es/ts-types/common.js +13 -0
  180. package/es/ts-types/common.js.map +1 -0
  181. package/es/ts-types/events.d.ts +14 -0
  182. package/es/ts-types/events.js +2 -0
  183. package/es/ts-types/events.js.map +1 -0
  184. package/es/ts-types/gantt-engine.d.ts +163 -0
  185. package/es/ts-types/gantt-engine.js +2 -0
  186. package/es/ts-types/gantt-engine.js.map +1 -0
  187. package/es/ts-types/index.d.ts +4 -0
  188. package/es/ts-types/index.js +8 -0
  189. package/es/ts-types/index.js.map +1 -0
  190. package/package.json +122 -0
package/README.md ADDED
@@ -0,0 +1,151 @@
1
+ <div align="center">
2
+ <a href="" target="_blank">
3
+ <img alt="VisActor Logo" width="200" src="https://github.com/VisActor/.github/blob/main/profile/500_200.svg"/>
4
+ </a>
5
+ </div>
6
+
7
+ <div align="center">
8
+ <h1>VTable</h1>
9
+ </div>
10
+
11
+ <div align="center">
12
+
13
+ VTable is not just a high-performance multidimensional data analysis table, but also a grid artist that creates art between rows and columns.
14
+
15
+ <p align="center">
16
+ <a href="">Introduction</a> •
17
+ <a href="">demo</a> •
18
+ <a href="">Tutorial</a> •
19
+ <a href="">API</a>•
20
+ </p>
21
+
22
+ [![npm Version](https://img.shields.io/npm/v/@visactor/vtable.svg)](https://www.npmjs.com/package/@visactor/vtable)
23
+ [![npm Download](https://img.shields.io/npm/dm/@visactor/vtable.svg)](https://www.npmjs.com/package/@visactor/vtable)
24
+ [![license](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/visactor/vtable/blob/main/LICENSE)
25
+
26
+ </div>
27
+
28
+ <div align="center">
29
+
30
+ English| [简体中文](./README.zh-CN.md)
31
+
32
+ </div>
33
+
34
+ <div align="center">
35
+
36
+ (video)
37
+
38
+ </div>
39
+
40
+ # Introduction
41
+
42
+ VTable is a canvas table library based on visual rendering engine [VRender](https://github.com/VisActor/VRender).
43
+
44
+ The core capabilities are as follows:
45
+
46
+ 1. Extreme performance: Supports fast computation and rendering of millions of data points.
47
+ 2. Multidimensional analysis: Automatically analyzes and presents multidimensional data.
48
+ 3. Strong expressiveness: Provides flexible and powerful graphic capabilities, seamlessly integrating with charts of [VChart](https://github.com/VisActor/VChart).
49
+
50
+ # Repo Intro
51
+
52
+ This repository includes the following packages:
53
+
54
+ 1. vtable: VTable components
55
+ 2. vtable-docs: VTable documentation
56
+
57
+ # Usage
58
+
59
+ ## Installation
60
+
61
+ [npm package](https://www.npmjs.com/package/@visactor/vtable)
62
+
63
+ ```bash
64
+ // npm
65
+ npm install @visactor/vtable
66
+
67
+ // yarn
68
+ yarn add @visactor/vtable
69
+ ```
70
+
71
+ ## Quick Start
72
+
73
+ ```javascript
74
+ import * as VTable from '@visactor/vtable';
75
+
76
+ const columns =[
77
+ {
78
+ "field": "Order ID",
79
+ "caption": "Order ID",
80
+ },
81
+ {
82
+ "field": "Customer ID",
83
+ "caption": "Customer ID",
84
+ },
85
+ {
86
+ "field": "Product Name",
87
+ "caption": "Product Name",
88
+ },
89
+ {
90
+ "field": "Sales",
91
+ "caption": "Sales",
92
+ },
93
+ {
94
+ "field": "Profit",
95
+ "caption": "Profit",
96
+ }
97
+ ];
98
+
99
+ const option = {
100
+ records:[
101
+ {
102
+ "Order ID": "CA-2018-156720",
103
+ "Customer ID": "JM-15580",
104
+ "Product Name": "Bagged Rubber Bands",
105
+ "Sales": "3.024",
106
+ "Profit": "-0.605"
107
+ },
108
+ {
109
+ "Order ID": "CA-2018-115427",
110
+ "Customer ID": "EB-13975",
111
+ "Product Name": "GBC Binding covers",
112
+ "Sales": "20.72",
113
+ "Profit": "6.475"
114
+ },
115
+ ...
116
+ ],
117
+ columns,
118
+ widthMode:'standard'
119
+ };
120
+ const tableInstance = new VTable.ListTable(document.getElementById(CONTAINER_ID), option);
121
+
122
+
123
+
124
+
125
+ ```
126
+
127
+ ##
128
+
129
+ [More demos and detailed tutorials](https://visactor.io/vtable)
130
+
131
+ # Related Links
132
+
133
+ - [Official website](https://visactor.io/vtable)
134
+
135
+ # Ecosystem
136
+
137
+ | Project | Description |
138
+ | ----------------------------------------------------------- | -------------------------------------------------------------------------------------- |
139
+ | [AI-generated Components](https://visactor.io/ai-vtable) | AI-generated table component. |
140
+
141
+ # Contribution
142
+
143
+ If you would like to contribute, please read the [Code of Conduct ](./CODE_OF_CONDUCT.md) 和 [ Guide](./CONTRIBUTING.zh-CN.md) first。
144
+
145
+ Small streams converge to make great rivers and seas!
146
+
147
+ <a href="https://github.com/visactor/vtable/graphs/contributors"><img src="https://contrib.rocks/image?repo=visactor/vtable" /></a>
148
+
149
+ # License
150
+
151
+ [MIT License](./LICENSE)
package/cjs/Gantt.d.ts ADDED
@@ -0,0 +1,111 @@
1
+ import { Scenegraph } from './scenegraph/scenegraph';
2
+ import type { ITaskBarStyle, GanttConstructorOptions, IGridStyle, ITimelineHeaderStyle, IMarkLine, ITaskBarLabelText, ITaskBarLabelTextStyle, IScrollStyle, IFrameStyle, ITableColumnsDefine, IResizeLineStyle, ITaskBarCustomLayout, ITimelineDateInfo, ITimelineScale, ILineStyle } from './ts-types';
3
+ import type { ListTableConstructorOptions } from '@visactor/vtable';
4
+ import { ListTable } from '@visactor/vtable';
5
+ import { EventManager } from './event/event-manager';
6
+ import { StateManager } from './state/state-manager';
7
+ import { EventTarget } from './event/EventTarget';
8
+ import { DataSource } from './data/DataSource';
9
+ export declare function createRootElement(padding: any, className?: string): HTMLElement;
10
+ export declare class Gantt extends EventTarget {
11
+ options: GanttConstructorOptions;
12
+ container: HTMLElement;
13
+ canvasWidth?: number;
14
+ canvasHeight?: number;
15
+ tableNoFrameWidth: number;
16
+ tableNoFrameHeight: number;
17
+ tableX: number;
18
+ tableY: number;
19
+ scenegraph: Scenegraph;
20
+ stateManager: StateManager;
21
+ eventManager: EventManager;
22
+ taskListTableInstance?: ListTable;
23
+ canvas: HTMLCanvasElement;
24
+ element: HTMLElement;
25
+ resizeLine: HTMLDivElement;
26
+ context: CanvasRenderingContext2D;
27
+ sortedTimelineScales: (ITimelineScale & {
28
+ timelineDates?: ITimelineDateInfo[];
29
+ })[];
30
+ reverseSortedTimelineScales: (ITimelineScale & {
31
+ timelineDates?: ITimelineDateInfo[];
32
+ })[];
33
+ headerLevel: number;
34
+ itemCount: number;
35
+ drawHeight: number;
36
+ headerHeight: number;
37
+ gridHeight: number;
38
+ parsedOptions: {
39
+ headerRowHeight: number | number[];
40
+ rowHeight: number;
41
+ timelineColWidth: number;
42
+ colWidthPerDay: number;
43
+ scrollStyle: IScrollStyle;
44
+ timelineHeaderVerticalLineStyle: ILineStyle;
45
+ timelineHeaderHorizontalLineStyle: ILineStyle;
46
+ timelineHeaderBackgroundColor: string;
47
+ timelineHeaderStyles: ITimelineHeaderStyle[];
48
+ gridStyle: IGridStyle;
49
+ taskBarStyle: ITaskBarStyle;
50
+ taskBarLabelText: ITaskBarLabelText;
51
+ taskBarMoveable: boolean;
52
+ taskBarResizable: boolean;
53
+ taskBarHoverColor: string;
54
+ taskBarLabelStyle: ITaskBarLabelTextStyle;
55
+ taskBarCustomLayout: ITaskBarCustomLayout;
56
+ frameStyle: IFrameStyle;
57
+ pixelRatio: number;
58
+ startDateField: string;
59
+ endDateField: string;
60
+ progressField: string;
61
+ minDate: Date;
62
+ maxDate: Date;
63
+ _minDateTime: number;
64
+ _maxDateTime: number;
65
+ markLine: IMarkLine[];
66
+ resizeLineStyle: IResizeLineStyle;
67
+ overscrollBehavior: 'auto' | 'none';
68
+ };
69
+ taskTableWidth: number;
70
+ taskTableColumns: ITableColumnsDefine;
71
+ records: any[];
72
+ data: DataSource;
73
+ constructor(container: HTMLElement, options?: GanttConstructorOptions);
74
+ renderTaskTable(): void;
75
+ _updateSize(): void;
76
+ _generateListTable(): void;
77
+ _generateListTableOptions(): ListTableConstructorOptions;
78
+ _createResizeLine(): void;
79
+ getElement(): HTMLElement;
80
+ getContainer(): HTMLElement;
81
+ _sortScales(): void;
82
+ _generateTimeLineDateMap(): void;
83
+ getAllRowsHeight(): number;
84
+ getAllHeaderRowsHeight(): number;
85
+ getAllColsWidth(): number;
86
+ getAllGridHeight(): number;
87
+ getRecordByIndex(index: number): any;
88
+ redrawRecord(index: number): void;
89
+ updateRecordToListTable(record: any, index: number): void;
90
+ getTaskInfoByTaskListIndex(index: number): {
91
+ taskDays: number;
92
+ taskRecord?: undefined;
93
+ startDate?: undefined;
94
+ endDate?: undefined;
95
+ progress?: undefined;
96
+ } | {
97
+ taskRecord: any;
98
+ taskDays: number;
99
+ startDate: Date;
100
+ endDate: Date;
101
+ progress: any;
102
+ };
103
+ updateDateToTaskRecord(updateDateType: 'move' | 'start-move' | 'end-move', days: number, index: number): void;
104
+ updateTaskRecord(index: number): void;
105
+ setPixelRatio(pixelRatio: number): void;
106
+ _resize(): void;
107
+ _syncPropsFromTable(): void;
108
+ getContext(): CanvasRenderingContext2D;
109
+ release(): void;
110
+ setRecords(records: any[]): void;
111
+ }
package/cjs/Gantt.js ADDED
@@ -0,0 +1,244 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.Gantt = exports.createRootElement = void 0;
6
+
7
+ const scenegraph_1 = require("./scenegraph/scenegraph"), env_1 = require("./env"), vtable_1 = require("@visactor/vtable"), event_manager_1 = require("./event/event-manager"), state_manager_1 = require("./state/state-manager"), gantt_helper_1 = require("./gantt-helper"), EventTarget_1 = require("./event/EventTarget"), util_1 = require("./tools/util"), DataSource_1 = require("./data/DataSource");
8
+
9
+ function createRootElement(padding, className = "vtable-gantt") {
10
+ var _a, _b;
11
+ const element = document.createElement("div");
12
+ element.setAttribute("tabindex", "0"), element.classList.add(className), element.style.outline = "none",
13
+ element.style.margin = `${padding.top}px ${padding.right}px ${padding.bottom}px ${padding.left}px`;
14
+ const width = (element.offsetWidth || (null === (_a = element.parentElement) || void 0 === _a ? void 0 : _a.offsetWidth) || 1) - 1, height = (element.offsetHeight || (null === (_b = element.parentElement) || void 0 === _b ? void 0 : _b.offsetHeight) || 1) - 1;
15
+ return element.style.width = width && width - padding.left - padding.right + "px" || "0px",
16
+ element.style.height = height && height - padding.top - padding.bottom + "px" || "0px",
17
+ element;
18
+ }
19
+
20
+ exports.createRootElement = createRootElement;
21
+
22
+ class Gantt extends EventTarget_1.EventTarget {
23
+ constructor(container, options) {
24
+ var _a, _b, _c, _d, _e;
25
+ super(), this.parsedOptions = {}, this.container = container, this.options = options,
26
+ this.taskTableWidth = "number" == typeof (null === (_a = null == options ? void 0 : options.taskListTable) || void 0 === _a ? void 0 : _a.width) ? null === (_b = null == options ? void 0 : options.taskListTable) || void 0 === _b ? void 0 : _b.width : 100,
27
+ this.taskTableColumns = null !== (_d = null === (_c = null == options ? void 0 : options.taskListTable) || void 0 === _c ? void 0 : _c.columns) && void 0 !== _d ? _d : [],
28
+ this.records = null !== (_e = null == options ? void 0 : options.records) && void 0 !== _e ? _e : [],
29
+ (0, gantt_helper_1.initOptions)(this), this.data = new DataSource_1.DataSource(this),
30
+ this._sortScales(), this._generateTimeLineDateMap(), this.headerLevel = this.sortedTimelineScales.length,
31
+ this.element = createRootElement({
32
+ top: 0,
33
+ right: 0,
34
+ left: 0,
35
+ bottom: 0
36
+ }, "vtable-gantt"), this.element.style.top = "0px", this.element.style.left = this.taskTableWidth ? `${this.taskTableWidth}px` : "0px",
37
+ this.canvas = document.createElement("canvas"), this.element.appendChild(this.canvas),
38
+ this.context = this.canvas.getContext("2d"), container ? (container.appendChild(this.element),
39
+ this._updateSize()) : this._updateSize(), this._generateListTable(), this._syncPropsFromTable(),
40
+ this._createResizeLine(), this.scenegraph = new scenegraph_1.Scenegraph(this), this.stateManager = new state_manager_1.StateManager(this),
41
+ this.eventManager = new event_manager_1.EventManager(this), this.scenegraph.afterCreateSceneGraph();
42
+ }
43
+ renderTaskTable() {
44
+ this.scenegraph.updateNextFrame();
45
+ }
46
+ _updateSize() {
47
+ var _a, _b, _c, _d, _e, _f;
48
+ let widthP = 0, heightP = 0;
49
+ if ("browser" === env_1.Env.mode) {
50
+ const element = this.getElement();
51
+ let widthWithoutPadding = 0, heightWithoutPadding = 0;
52
+ if (element.parentElement) {
53
+ const computedStyle = element.parentElement.style || window.getComputedStyle(element.parentElement);
54
+ widthWithoutPadding = element.parentElement.offsetWidth - parseInt(computedStyle.paddingLeft || "0px", 10) - parseInt(computedStyle.paddingRight || "0px", 10),
55
+ heightWithoutPadding = element.parentElement.offsetHeight - parseInt(computedStyle.paddingTop || "0px", 10) - parseInt(computedStyle.paddingBottom || "0px", 20);
56
+ }
57
+ const width1 = (null != widthWithoutPadding ? widthWithoutPadding : 1) - 1 - this.taskTableWidth, height1 = (null != heightWithoutPadding ? heightWithoutPadding : 1) - 1;
58
+ element.style.width = width1 && `${width1}px` || "0px", element.style.height = height1 && `${height1}px` || "0px";
59
+ const {canvas: canvas} = this;
60
+ widthP = null !== (_b = null === (_a = canvas.parentElement) || void 0 === _a ? void 0 : _a.offsetWidth) && void 0 !== _b ? _b : 1,
61
+ heightP = null !== (_d = null === (_c = canvas.parentElement) || void 0 === _c ? void 0 : _c.offsetHeight) && void 0 !== _d ? _d : 1,
62
+ (null === (_e = null == this ? void 0 : this.scenegraph) || void 0 === _e ? void 0 : _e.stage) ? this.scenegraph.stage.resize(widthP, heightP) : (canvas.style.width = "",
63
+ canvas.style.height = "", canvas.width = widthP, canvas.height = heightP, canvas.style.width = `${widthP}px`,
64
+ canvas.style.height = `${heightP}px`);
65
+ } else "node" === env_1.Env.mode && (widthP = this.canvasWidth - 1, heightP = this.canvasHeight - 1);
66
+ const width = Math.floor(widthP - (0, gantt_helper_1.getVerticalScrollBarSize)(this.parsedOptions.scrollStyle)), height = Math.floor(heightP - (0,
67
+ gantt_helper_1.getHorizontalScrollBarSize)(this.parsedOptions.scrollStyle));
68
+ if (this.tableNoFrameWidth = widthP, this.tableNoFrameHeight = Math.floor(heightP),
69
+ this.parsedOptions.frameStyle) {
70
+ const lineWidth = null === (_f = this.parsedOptions.frameStyle) || void 0 === _f ? void 0 : _f.borderLineWidth;
71
+ this.tableX = lineWidth, this.tableY = lineWidth, this.tableNoFrameWidth = width - lineWidth,
72
+ this.tableNoFrameHeight = height - 2 * lineWidth;
73
+ }
74
+ }
75
+ _generateListTable() {
76
+ var _a, _b;
77
+ if (this.taskTableColumns.length >= 1) {
78
+ const listTableOption = this._generateListTableOptions();
79
+ if (this.taskListTableInstance = new vtable_1.ListTable(this.container, listTableOption),
80
+ "auto" === (null === (_b = null === (_a = this.options) || void 0 === _a ? void 0 : _a.taskListTable) || void 0 === _b ? void 0 : _b.width) && (this.taskTableWidth = this.taskListTableInstance.getAllColsWidth() + 2 * this.taskListTableInstance.tableX,
81
+ this.element.style.left = this.taskTableWidth ? `${this.taskTableWidth}px` : "0px",
82
+ this.taskListTableInstance.setCanvasSize(this.taskTableWidth, this.tableNoFrameHeight + 2 * this.parsedOptions.frameStyle.borderLineWidth),
83
+ this._updateSize()), this.taskListTableInstance.columnHeaderLevelCount > 1) if (Array.isArray(this.parsedOptions.headerRowHeight) && this.taskListTableInstance.columnHeaderLevelCount === this.parsedOptions.headerRowHeight.length) for (let i = 0; i < this.taskListTableInstance.columnHeaderLevelCount; i++) this.taskListTableInstance.setRowHeight(i, this.parsedOptions.headerRowHeight[i]); else {
84
+ const newRowHeight = this.getAllHeaderRowsHeight() / this.taskListTableInstance.columnHeaderLevelCount;
85
+ for (let i = 0; i < this.taskListTableInstance.columnHeaderLevelCount; i++) this.taskListTableInstance.setRowHeight(i, newRowHeight);
86
+ }
87
+ }
88
+ }
89
+ _generateListTableOptions() {
90
+ var _a;
91
+ const listTable_options = {}, needPutInListTableKeys = [ "container", "records", "pixelRatio", "overscrollBehavior", "pixelRatio" ];
92
+ for (const key in this.options) needPutInListTableKeys.indexOf(key) >= 0 && (listTable_options[key] = this.options[key]);
93
+ for (const key in this.options.taskListTable) listTable_options[key] = this.options.taskListTable[key];
94
+ return listTable_options.theme = {
95
+ scrollStyle: Object.assign({}, this.parsedOptions.scrollStyle, {
96
+ verticalVisible: "none"
97
+ }),
98
+ headerStyle: Object.assign({}, vtable_1.themes.DEFAULT.headerStyle, {
99
+ bgColor: this.parsedOptions.timelineHeaderBackgroundColor
100
+ }, this.options.taskListTable.headerStyle),
101
+ cellInnerBorder: !1,
102
+ frameStyle: Object.assign({}, this.parsedOptions.frameStyle, {
103
+ cornerRadius: this.parsedOptions.frameStyle.cornerRadius,
104
+ borderLineWidth: [ this.parsedOptions.frameStyle.borderLineWidth, 0, this.parsedOptions.frameStyle.borderLineWidth, this.parsedOptions.frameStyle.borderLineWidth ]
105
+ }),
106
+ bodyStyle: Object.assign({}, vtable_1.themes.DEFAULT.bodyStyle, this.options.taskListTable.bodyStyle)
107
+ }, listTable_options.canvasWidth = this.taskTableWidth, listTable_options.canvasHeight = null !== (_a = this.canvasHeight) && void 0 !== _a ? _a : this.canvas.height,
108
+ listTable_options.defaultHeaderRowHeight = this.getAllHeaderRowsHeight(), listTable_options.defaultRowHeight = this.parsedOptions.rowHeight,
109
+ listTable_options.clearDOM = !1, listTable_options;
110
+ }
111
+ _createResizeLine() {
112
+ if (this.taskListTableInstance && "auto" !== this.options.taskListTable.width) {
113
+ this.resizeLine = document.createElement("div"), this.resizeLine.style.position = "absolute",
114
+ this.resizeLine.style.top = this.tableY + "px", this.resizeLine.style.left = this.taskTableWidth ? this.taskTableWidth - 7 + "px" : "0px",
115
+ this.resizeLine.style.width = "14px", this.resizeLine.style.height = this.drawHeight + "px",
116
+ this.resizeLine.style.backgroundColor = "rgba(0,0,0,0)", this.resizeLine.style.zIndex = "100",
117
+ this.resizeLine.style.cursor = "col-resize", this.resizeLine.style.userSelect = "none",
118
+ this.resizeLine.style.opacity = "1";
119
+ const highlightLine = document.createElement("div");
120
+ highlightLine.style.position = "absolute", highlightLine.style.top = "0px", highlightLine.style.left = "5px",
121
+ highlightLine.style.width = this.parsedOptions.resizeLineStyle.lineWidth + "px",
122
+ highlightLine.style.height = "100%", highlightLine.style.backgroundColor = this.parsedOptions.resizeLineStyle.lineColor,
123
+ highlightLine.style.zIndex = "100", highlightLine.style.cursor = "col-resize", highlightLine.style.userSelect = "none",
124
+ highlightLine.style.pointerEvents = "none", highlightLine.style.opacity = "0", highlightLine.style.transition = "background-color 0.3s",
125
+ this.resizeLine.appendChild(highlightLine), this.resizeLine.addEventListener("mouseover", (() => {
126
+ highlightLine.style.opacity = "1";
127
+ })), this.resizeLine.addEventListener("mouseout", (() => {
128
+ highlightLine.style.opacity = "0";
129
+ })), this.container.appendChild(this.resizeLine);
130
+ }
131
+ }
132
+ getElement() {
133
+ return this.element;
134
+ }
135
+ getContainer() {
136
+ return this.element.parentElement;
137
+ }
138
+ _sortScales() {
139
+ const {timelineHeader: timelineHeader} = this.options;
140
+ if (timelineHeader) {
141
+ const timelineScales = timelineHeader.scales, sortOrder = [ "year", "quarter", "month", "week", "day" ], orderedScales = timelineScales.slice().sort(((a, b) => {
142
+ const indexA = sortOrder.indexOf(a.unit), indexB = sortOrder.indexOf(b.unit);
143
+ return -1 === indexA ? 1 : -1 === indexB ? -1 : indexA - indexB;
144
+ })), reverseOrderedScales = timelineScales.slice().sort(((a, b) => {
145
+ const indexA = sortOrder.indexOf(a.unit), indexB = sortOrder.indexOf(b.unit);
146
+ return -1 === indexA ? 1 : -1 === indexB ? -1 : indexB - indexA;
147
+ }));
148
+ this.sortedTimelineScales = orderedScales, this.reverseSortedTimelineScales = reverseOrderedScales;
149
+ }
150
+ }
151
+ _generateTimeLineDateMap() {
152
+ const startDate = new Date(this.parsedOptions.minDate), endDate = new Date(this.parsedOptions.maxDate);
153
+ let colWidthIncludeDays = 1e6;
154
+ for (const scale of this.reverseSortedTimelineScales) {
155
+ const currentDate = new Date(startDate);
156
+ scale.timelineDates = (0, gantt_helper_1.generateTimeLineDate)(currentDate, endDate, scale);
157
+ }
158
+ const firstScale = this.reverseSortedTimelineScales[0], {unit: unit, step: step} = firstScale;
159
+ "day" === unit ? colWidthIncludeDays = step : "month" === unit ? colWidthIncludeDays = 30 : "week" === unit ? colWidthIncludeDays = 7 : "quarter" === unit ? colWidthIncludeDays = 90 : "year" === unit && (colWidthIncludeDays = 365),
160
+ this.parsedOptions.colWidthPerDay = this.parsedOptions.timelineColWidth / colWidthIncludeDays;
161
+ }
162
+ getAllRowsHeight() {
163
+ return this.getAllHeaderRowsHeight() + this.itemCount * this.parsedOptions.rowHeight;
164
+ }
165
+ getAllHeaderRowsHeight() {
166
+ return Array.isArray(this.parsedOptions.headerRowHeight) ? this.parsedOptions.headerRowHeight.reduce(((acc, curr, index) => acc + curr), 0) : this.parsedOptions.headerRowHeight * this.headerLevel;
167
+ }
168
+ getAllColsWidth() {
169
+ return this.parsedOptions.colWidthPerDay * (Math.ceil(Math.abs(new Date(this.parsedOptions.maxDate).getTime() - new Date(this.parsedOptions.minDate).getTime()) / 864e5) + 1);
170
+ }
171
+ getAllGridHeight() {
172
+ return this.itemCount * this.parsedOptions.rowHeight;
173
+ }
174
+ getRecordByIndex(index) {
175
+ return this.taskListTableInstance ? this.taskListTableInstance.getRecordByRowCol(0, index + this.taskListTableInstance.columnHeaderLevelCount) : this.records[index];
176
+ }
177
+ redrawRecord(index) {
178
+ this.scenegraph.taskBar.updateTaskBarNode(index), this.scenegraph.updateNextFrame();
179
+ }
180
+ updateRecordToListTable(record, index) {
181
+ this.taskListTableInstance.updateRecords([ record ], [ index ]);
182
+ }
183
+ getTaskInfoByTaskListIndex(index) {
184
+ const taskRecord = this.getRecordByIndex(index), startDateField = this.parsedOptions.startDateField, endDateField = this.parsedOptions.endDateField, progressField = this.parsedOptions.progressField, rawDateStartDateTime = new Date(taskRecord[startDateField]).getTime(), rawDateEndDateTime = new Date(taskRecord[endDateField]).getTime();
185
+ if (rawDateEndDateTime < this.parsedOptions._minDateTime || rawDateStartDateTime > this.parsedOptions._maxDateTime) return {
186
+ taskDays: 0
187
+ };
188
+ const startDate = new Date(Math.min(Math.max(this.parsedOptions._minDateTime, rawDateStartDateTime), this.parsedOptions._maxDateTime)), endDate = new Date(Math.max(Math.min(this.parsedOptions._maxDateTime, rawDateEndDateTime), this.parsedOptions._minDateTime)), progress = taskRecord[progressField];
189
+ return {
190
+ taskRecord: taskRecord,
191
+ taskDays: Math.ceil(Math.abs(endDate.getTime() - startDate.getTime()) / 864e5) + 1,
192
+ startDate: startDate,
193
+ endDate: endDate,
194
+ progress: progress
195
+ };
196
+ }
197
+ updateDateToTaskRecord(updateDateType, days, index) {
198
+ const taskRecord = this.getRecordByIndex(index), startDateField = this.parsedOptions.startDateField, endDateField = this.parsedOptions.endDateField, dateFormat = (0,
199
+ util_1.parseDateFormat)(taskRecord[startDateField]), startDate = new Date(taskRecord[startDateField]), endDate = new Date(taskRecord[endDateField]);
200
+ if ("move" === updateDateType) {
201
+ const newStartDate = (0, util_1.formatDate)(new Date(days * gantt_helper_1.DayTimes + startDate.getTime()), dateFormat), newEndDate = (0,
202
+ util_1.formatDate)(new Date(days * gantt_helper_1.DayTimes + endDate.getTime()), dateFormat);
203
+ taskRecord[startDateField] = newStartDate, taskRecord[endDateField] = newEndDate;
204
+ } else if ("start-move" === updateDateType) {
205
+ const newStartDate = (0, util_1.formatDate)(new Date(days * gantt_helper_1.DayTimes + startDate.getTime()), dateFormat);
206
+ taskRecord[startDateField] = newStartDate;
207
+ } else if ("end-move" === updateDateType) {
208
+ const newEndDate = (0, util_1.formatDate)(new Date(days * gantt_helper_1.DayTimes + endDate.getTime()), dateFormat);
209
+ taskRecord[endDateField] = newEndDate;
210
+ }
211
+ this.updateRecordToListTable(taskRecord, index);
212
+ }
213
+ updateTaskRecord(index) {
214
+ const taskRecord = this.getRecordByIndex(index);
215
+ this.updateRecordToListTable(taskRecord, index);
216
+ }
217
+ setPixelRatio(pixelRatio) {
218
+ this.parsedOptions.pixelRatio = pixelRatio, this.scenegraph.setPixelRatio(pixelRatio);
219
+ }
220
+ _resize() {
221
+ this._updateSize(), this.taskListTableInstance.setCanvasSize(this.taskTableWidth, this.tableNoFrameHeight + 2 * this.parsedOptions.frameStyle.borderLineWidth),
222
+ this._syncPropsFromTable(), this.scenegraph.resize();
223
+ }
224
+ _syncPropsFromTable() {
225
+ this.itemCount = this.taskListTableInstance ? this.taskListTableInstance.rowCount - this.taskListTableInstance.columnHeaderLevelCount : this.records.length,
226
+ this.headerHeight = this.getAllHeaderRowsHeight(), this.drawHeight = Math.min(this.headerHeight + this.parsedOptions.rowHeight * this.itemCount, this.tableNoFrameHeight),
227
+ this.gridHeight = this.drawHeight - this.headerHeight;
228
+ }
229
+ getContext() {
230
+ return this.context;
231
+ }
232
+ release() {
233
+ var _a, _b;
234
+ null === (_a = super.release) || void 0 === _a || _a.call(this), this.eventManager.release(),
235
+ null === (_b = this.taskListTableInstance) || void 0 === _b || _b.release();
236
+ const {parentElement: parentElement} = this.element;
237
+ parentElement && parentElement.removeChild(this.element), this.scenegraph = null;
238
+ }
239
+ setRecords(records) {
240
+ this.records = records;
241
+ }
242
+ }
243
+
244
+ exports.Gantt = Gantt;
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/Gantt.ts"],"names":[],"mappings":"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","file":"Gantt.js","sourcesContent":["// import themes from './themes';\n// import { createRootElement } from './core/tableHelper';\nimport { Scenegraph } from './scenegraph/scenegraph';\nimport { Env } from './env';\nimport type {\n ITaskBarStyle,\n GanttConstructorOptions,\n IGridStyle,\n ITimelineHeaderStyle,\n IMarkLine,\n ITaskBarLabelText,\n ITaskBarLabelTextStyle,\n IScrollStyle,\n IFrameStyle,\n ITableColumnsDefine,\n IResizeLineStyle,\n ITaskBarCustomLayout,\n ITimelineDateInfo,\n ITimelineScale,\n ILineStyle\n} from './ts-types';\nimport type { ListTableConstructorOptions, TYPES } from '@visactor/vtable';\nimport { ListTable, themes } from '@visactor/vtable';\nimport { EventManager } from './event/event-manager';\nimport { StateManager } from './state/state-manager';\nimport {\n DayTimes,\n generateMarkLine,\n generateTimeLineDate,\n getHorizontalScrollBarSize,\n getVerticalScrollBarSize,\n initOptions\n} from './gantt-helper';\nimport { EventTarget } from './event/EventTarget';\nimport { formatDate, getWeekNumber, parseDateFormat, toBoxArray } from './tools/util';\nimport { DataSource } from './data/DataSource';\n// import { generateGanttChartColumns } from './gantt-helper';\nexport function createRootElement(padding: any, className: string = 'vtable-gantt'): HTMLElement {\n const element = document.createElement('div');\n element.setAttribute('tabindex', '0');\n element.classList.add(className);\n element.style.outline = 'none';\n element.style.margin = `${padding.top}px ${padding.right}px ${padding.bottom}px ${padding.left}px`;\n\n const width = (element.offsetWidth || element.parentElement?.offsetWidth || 1) - 1;\n const height = (element.offsetHeight || element.parentElement?.offsetHeight || 1) - 1;\n\n element.style.width = (width && `${width - padding.left - padding.right}px`) || '0px';\n element.style.height = (height && `${height - padding.top - padding.bottom}px`) || '0px';\n\n return element;\n}\nexport class Gantt extends EventTarget {\n options: GanttConstructorOptions;\n container: HTMLElement;\n canvasWidth?: number;\n canvasHeight?: number;\n tableNoFrameWidth: number;\n tableNoFrameHeight: number;\n tableX: number;\n tableY: number;\n scenegraph: Scenegraph;\n stateManager: StateManager;\n eventManager: EventManager;\n\n taskListTableInstance?: ListTable;\n\n canvas: HTMLCanvasElement;\n element: HTMLElement;\n resizeLine: HTMLDivElement;\n context: CanvasRenderingContext2D;\n\n sortedTimelineScales: (ITimelineScale & { timelineDates?: ITimelineDateInfo[] })[];\n reverseSortedTimelineScales: (ITimelineScale & { timelineDates?: ITimelineDateInfo[] })[];\n headerLevel: number;\n itemCount: number;\n drawHeight: number;\n headerHeight: number;\n gridHeight: number;\n\n parsedOptions: {\n headerRowHeight: number | number[];\n rowHeight: number;\n timelineColWidth: number;\n colWidthPerDay: number; //分配给每日的宽度\n\n scrollStyle: IScrollStyle;\n // timelineHeaderStyle: ITimelineHeaderStyle;\n timelineHeaderVerticalLineStyle: ILineStyle;\n timelineHeaderHorizontalLineStyle: ILineStyle;\n timelineHeaderBackgroundColor: string;\n timelineHeaderStyles: ITimelineHeaderStyle[];\n gridStyle: IGridStyle;\n taskBarStyle: ITaskBarStyle;\n taskBarLabelText: ITaskBarLabelText;\n taskBarMoveable: boolean;\n taskBarResizable: boolean;\n taskBarHoverColor: string;\n taskBarLabelStyle: ITaskBarLabelTextStyle;\n taskBarCustomLayout: ITaskBarCustomLayout;\n frameStyle: IFrameStyle;\n pixelRatio: number;\n\n startDateField: string;\n endDateField: string;\n progressField: string;\n minDate: Date;\n maxDate: Date;\n _minDateTime: number;\n _maxDateTime: number;\n markLine: IMarkLine[];\n resizeLineStyle: IResizeLineStyle;\n overscrollBehavior: 'auto' | 'none';\n } = {} as any;\n\n taskTableWidth: number;\n taskTableColumns: ITableColumnsDefine;\n\n records: any[];\n data: DataSource;\n constructor(container: HTMLElement, options?: GanttConstructorOptions) {\n super();\n this.container = container;\n this.options = options;\n\n this.taskTableWidth = typeof options?.taskListTable?.width === 'number' ? options?.taskListTable?.width : 100;\n this.taskTableColumns = options?.taskListTable?.columns ?? [];\n this.records = options?.records ?? [];\n\n initOptions(this);\n this.data = new DataSource(this);\n this._sortScales();\n this._generateTimeLineDateMap();\n this.headerLevel = this.sortedTimelineScales.length;\n this.element = createRootElement({ top: 0, right: 0, left: 0, bottom: 0 }, 'vtable-gantt');\n this.element.style.top = '0px';\n this.element.style.left = this.taskTableWidth ? `${this.taskTableWidth}px` : '0px';\n\n this.canvas = document.createElement('canvas');\n this.element.appendChild(this.canvas);\n this.context = this.canvas.getContext('2d')!;\n if (container) {\n (container as HTMLElement).appendChild(this.element);\n this._updateSize();\n } else {\n this._updateSize();\n }\n this._generateListTable();\n this._syncPropsFromTable();\n\n this._createResizeLine();\n this.scenegraph = new Scenegraph(this);\n this.stateManager = new StateManager(this);\n this.eventManager = new EventManager(this);\n\n this.scenegraph.afterCreateSceneGraph();\n }\n\n renderTaskTable() {\n this.scenegraph.updateNextFrame();\n }\n /**\n * 窗口尺寸发生变化 或者像数比变化\n * @return {void}\n */\n _updateSize(): void {\n let widthP = 0;\n let heightP = 0;\n\n if (Env.mode === 'browser') {\n const element = this.getElement();\n let widthWithoutPadding = 0;\n let heightWithoutPadding = 0;\n if (element.parentElement) {\n const computedStyle = element.parentElement.style || window.getComputedStyle(element.parentElement); // 兼容性处理\n widthWithoutPadding =\n element.parentElement.offsetWidth -\n parseInt(computedStyle.paddingLeft || '0px', 10) -\n parseInt(computedStyle.paddingRight || '0px', 10);\n heightWithoutPadding =\n element.parentElement.offsetHeight -\n parseInt(computedStyle.paddingTop || '0px', 10) -\n parseInt(computedStyle.paddingBottom || '0px', 20);\n }\n const width1 = (widthWithoutPadding ?? 1) - 1 - this.taskTableWidth;\n const height1 = (heightWithoutPadding ?? 1) - 1;\n\n element.style.width = (width1 && `${width1}px`) || '0px';\n element.style.height = (height1 && `${height1}px`) || '0px';\n\n const { canvas } = this;\n\n widthP = canvas.parentElement?.offsetWidth ?? 1;\n heightP = canvas.parentElement?.offsetHeight ?? 1;\n\n //style 与 width,height相同\n if (this?.scenegraph?.stage) {\n this.scenegraph.stage.resize(widthP, heightP);\n } else {\n canvas.style.width = '';\n canvas.style.height = '';\n canvas.width = widthP;\n canvas.height = heightP;\n\n canvas.style.width = `${widthP}px`;\n canvas.style.height = `${heightP}px`;\n }\n } else if (Env.mode === 'node') {\n widthP = this.canvasWidth - 1;\n heightP = this.canvasHeight - 1;\n }\n const width = Math.floor(widthP - getVerticalScrollBarSize(this.parsedOptions.scrollStyle));\n const height = Math.floor(heightP - getHorizontalScrollBarSize(this.parsedOptions.scrollStyle));\n\n this.tableNoFrameWidth = widthP;\n this.tableNoFrameHeight = Math.floor(heightP);\n if (this.parsedOptions.frameStyle) {\n //考虑表格整体边框的问题\n const lineWidth = this.parsedOptions.frameStyle?.borderLineWidth; // toBoxArray(this.parsedOptions.frameStyle?.borderLineWidth ?? [null]);\n this.tableX = lineWidth;\n this.tableY = lineWidth;\n this.tableNoFrameWidth = width - lineWidth;\n\n this.tableNoFrameHeight = height - lineWidth * 2;\n }\n }\n _generateListTable() {\n if (this.taskTableColumns.length >= 1) {\n const listTableOption = this._generateListTableOptions();\n this.taskListTableInstance = new ListTable(this.container, listTableOption);\n\n if (this.options?.taskListTable?.width === 'auto') {\n this.taskTableWidth = this.taskListTableInstance.getAllColsWidth() + this.taskListTableInstance.tableX * 2;\n this.element.style.left = this.taskTableWidth ? `${this.taskTableWidth}px` : '0px';\n this.taskListTableInstance.setCanvasSize(\n this.taskTableWidth,\n this.tableNoFrameHeight + this.parsedOptions.frameStyle.borderLineWidth * 2\n );\n this._updateSize();\n }\n\n if (this.taskListTableInstance.columnHeaderLevelCount > 1) {\n if (\n Array.isArray(this.parsedOptions.headerRowHeight) &&\n this.taskListTableInstance.columnHeaderLevelCount === this.parsedOptions.headerRowHeight.length\n ) {\n for (let i = 0; i < this.taskListTableInstance.columnHeaderLevelCount; i++) {\n this.taskListTableInstance.setRowHeight(i, this.parsedOptions.headerRowHeight[i]);\n }\n } else {\n const newRowHeight = this.getAllHeaderRowsHeight() / this.taskListTableInstance.columnHeaderLevelCount;\n for (let i = 0; i < this.taskListTableInstance.columnHeaderLevelCount; i++) {\n this.taskListTableInstance.setRowHeight(i, newRowHeight);\n }\n }\n }\n }\n }\n _generateListTableOptions() {\n const listTable_options: ListTableConstructorOptions = {};\n const needPutInListTableKeys = ['container', 'records', 'pixelRatio', 'overscrollBehavior', 'pixelRatio'];\n for (const key in this.options) {\n if (needPutInListTableKeys.indexOf(key) >= 0) {\n listTable_options[key] = this.options[key];\n }\n }\n for (const key in this.options.taskListTable) {\n listTable_options[key] = this.options.taskListTable[key];\n }\n // lineWidthArr[1] = 0;\n listTable_options.theme = {\n scrollStyle: Object.assign({}, this.parsedOptions.scrollStyle, {\n verticalVisible: 'none'\n }),\n headerStyle: Object.assign(\n {},\n themes.DEFAULT.headerStyle,\n {\n bgColor: this.parsedOptions.timelineHeaderBackgroundColor\n },\n this.options.taskListTable.headerStyle\n ),\n cellInnerBorder: false,\n frameStyle: Object.assign({}, this.parsedOptions.frameStyle, {\n cornerRadius: this.parsedOptions.frameStyle.cornerRadius, //[this.parsedOptions.frameStyle.cornerRadius, 0, 0, this.parsedOptions.frameStyle.cornerRadius],\n borderLineWidth: [\n this.parsedOptions.frameStyle.borderLineWidth,\n 0,\n this.parsedOptions.frameStyle.borderLineWidth,\n this.parsedOptions.frameStyle.borderLineWidth\n ]\n }),\n bodyStyle: Object.assign({}, themes.DEFAULT.bodyStyle, this.options.taskListTable.bodyStyle)\n };\n listTable_options.canvasWidth = this.taskTableWidth as number;\n listTable_options.canvasHeight = this.canvasHeight ?? this.canvas.height;\n listTable_options.defaultHeaderRowHeight = this.getAllHeaderRowsHeight();\n listTable_options.defaultRowHeight = this.parsedOptions.rowHeight;\n listTable_options.clearDOM = false;\n return listTable_options;\n }\n _createResizeLine() {\n if (this.taskListTableInstance && this.options.taskListTable.width !== 'auto') {\n this.resizeLine = document.createElement('div');\n this.resizeLine.style.position = 'absolute';\n this.resizeLine.style.top = this.tableY + 'px';\n this.resizeLine.style.left = this.taskTableWidth ? `${this.taskTableWidth - 7}px` : '0px';\n this.resizeLine.style.width = '14px';\n this.resizeLine.style.height = this.drawHeight + 'px'; //'100%';\n this.resizeLine.style.backgroundColor = 'rgba(0,0,0,0)';\n this.resizeLine.style.zIndex = '100';\n this.resizeLine.style.cursor = 'col-resize';\n this.resizeLine.style.userSelect = 'none';\n this.resizeLine.style.opacity = '1';\n\n const highlightLine = document.createElement('div');\n highlightLine.style.position = 'absolute';\n highlightLine.style.top = '0px';\n highlightLine.style.left = '5px';\n highlightLine.style.width = this.parsedOptions.resizeLineStyle.lineWidth + 'px';\n highlightLine.style.height = '100%';\n highlightLine.style.backgroundColor = this.parsedOptions.resizeLineStyle.lineColor;\n highlightLine.style.zIndex = '100';\n highlightLine.style.cursor = 'col-resize';\n highlightLine.style.userSelect = 'none';\n highlightLine.style.pointerEvents = 'none';\n highlightLine.style.opacity = '0';\n highlightLine.style.transition = 'background-color 0.3s';\n this.resizeLine.appendChild(highlightLine);\n // 添加鼠标悬停时的高亮效果\n this.resizeLine.addEventListener('mouseover', () => {\n // highlightLine.style.backgroundColor = '#ffcc00';\n highlightLine.style.opacity = '1';\n });\n\n // 添加鼠标移出时恢复初始样式\n this.resizeLine.addEventListener('mouseout', () => {\n // highlightLine.style.backgroundColor = '#e1e4e8';\n highlightLine.style.opacity = '0';\n });\n (this.container as HTMLElement).appendChild(this.resizeLine);\n }\n }\n /**\n * 获取表格创建的DOM根节点\n */\n getElement(): HTMLElement {\n return this.element;\n }\n\n /**\n * 获取创建gantt传入的容器\n */\n getContainer(): HTMLElement {\n return this.element.parentElement;\n }\n\n _sortScales() {\n const { timelineHeader } = this.options;\n if (timelineHeader) {\n const timelineScales = timelineHeader.scales;\n const sortOrder = ['year', 'quarter', 'month', 'week', 'day'];\n const orderedScales = timelineScales.slice().sort((a, b) => {\n const indexA = sortOrder.indexOf(a.unit);\n const indexB = sortOrder.indexOf(b.unit);\n if (indexA === -1) {\n return 1;\n } else if (indexB === -1) {\n return -1;\n }\n return indexA - indexB;\n });\n const reverseOrderedScales = timelineScales.slice().sort((a, b) => {\n const indexA = sortOrder.indexOf(a.unit);\n const indexB = sortOrder.indexOf(b.unit);\n if (indexA === -1) {\n return 1;\n } else if (indexB === -1) {\n return -1;\n }\n return indexB - indexA;\n });\n\n this.sortedTimelineScales = orderedScales;\n this.reverseSortedTimelineScales = reverseOrderedScales;\n }\n }\n\n _generateTimeLineDateMap() {\n const startDate = new Date(this.parsedOptions.minDate);\n const endDate = new Date(this.parsedOptions.maxDate);\n let colWidthIncludeDays = 1000000;\n // Iterate over each scale\n for (const scale of this.reverseSortedTimelineScales) {\n // Generate the sub-columns for each step within the scale\n const currentDate = new Date(startDate);\n // const timelineDates: any[] = [];\n scale.timelineDates = generateTimeLineDate(currentDate, endDate, scale);\n }\n\n const firstScale = this.reverseSortedTimelineScales[0];\n const { unit, step } = firstScale;\n if (unit === 'day') {\n colWidthIncludeDays = step;\n } else if (unit === 'month') {\n colWidthIncludeDays = 30;\n } else if (unit === 'week') {\n colWidthIncludeDays = 7;\n } else if (unit === 'quarter') {\n colWidthIncludeDays = 90;\n } else if (unit === 'year') {\n colWidthIncludeDays = 365;\n }\n this.parsedOptions.colWidthPerDay = this.parsedOptions.timelineColWidth / colWidthIncludeDays;\n }\n getAllRowsHeight() {\n return this.getAllHeaderRowsHeight() + this.itemCount * this.parsedOptions.rowHeight;\n }\n getAllHeaderRowsHeight() {\n if (Array.isArray(this.parsedOptions.headerRowHeight)) {\n return this.parsedOptions.headerRowHeight.reduce((acc, curr, index) => {\n return acc + curr;\n }, 0);\n }\n return (this.parsedOptions.headerRowHeight as number) * this.headerLevel;\n }\n getAllColsWidth() {\n return (\n this.parsedOptions.colWidthPerDay *\n (Math.ceil(\n Math.abs(new Date(this.parsedOptions.maxDate).getTime() - new Date(this.parsedOptions.minDate).getTime()) /\n (1000 * 60 * 60 * 24)\n ) +\n 1)\n );\n }\n\n getAllGridHeight() {\n return this.itemCount * this.parsedOptions.rowHeight;\n }\n\n getRecordByIndex(index: number) {\n if (this.taskListTableInstance) {\n return this.taskListTableInstance.getRecordByRowCol(0, index + this.taskListTableInstance.columnHeaderLevelCount);\n }\n return this.records[index];\n }\n\n redrawRecord(index: number) {\n // this.listTableInstance.updateRecords([record], [index]);\n this.scenegraph.taskBar.updateTaskBarNode(index);\n this.scenegraph.updateNextFrame();\n }\n updateRecordToListTable(record: any, index: number) {\n this.taskListTableInstance.updateRecords([record], [index]);\n }\n getTaskInfoByTaskListIndex(index: number) {\n const taskRecord = this.getRecordByIndex(index);\n const startDateField = this.parsedOptions.startDateField;\n const endDateField = this.parsedOptions.endDateField;\n const progressField = this.parsedOptions.progressField;\n const rawDateStartDateTime = new Date(taskRecord[startDateField]).getTime();\n const rawDateEndDateTime = new Date(taskRecord[endDateField]).getTime();\n if (\n rawDateEndDateTime < this.parsedOptions._minDateTime ||\n rawDateStartDateTime > this.parsedOptions._maxDateTime\n ) {\n return {\n taskDays: 0\n };\n }\n const startDate = new Date(\n Math.min(Math.max(this.parsedOptions._minDateTime, rawDateStartDateTime), this.parsedOptions._maxDateTime)\n );\n const endDate = new Date(\n Math.max(Math.min(this.parsedOptions._maxDateTime, rawDateEndDateTime), this.parsedOptions._minDateTime)\n );\n const progress = taskRecord[progressField];\n const taskDays = Math.ceil(Math.abs(endDate.getTime() - startDate.getTime()) / (1000 * 60 * 60 * 24)) + 1;\n return {\n taskRecord,\n taskDays,\n startDate,\n endDate,\n progress\n };\n }\n\n updateDateToTaskRecord(updateDateType: 'move' | 'start-move' | 'end-move', days: number, index: number) {\n const taskRecord = this.getRecordByIndex(index);\n const startDateField = this.parsedOptions.startDateField;\n const endDateField = this.parsedOptions.endDateField;\n const dateFormat = parseDateFormat(taskRecord[startDateField]);\n const startDate = new Date(taskRecord[startDateField]);\n const endDate = new Date(taskRecord[endDateField]);\n if (updateDateType === 'move') {\n const newStartDate = formatDate(new Date(days * DayTimes + startDate.getTime()), dateFormat);\n const newEndDate = formatDate(new Date(days * DayTimes + endDate.getTime()), dateFormat);\n taskRecord[startDateField] = newStartDate;\n taskRecord[endDateField] = newEndDate;\n } else if (updateDateType === 'start-move') {\n const newStartDate = formatDate(new Date(days * DayTimes + startDate.getTime()), dateFormat);\n taskRecord[startDateField] = newStartDate;\n } else if (updateDateType === 'end-move') {\n const newEndDate = formatDate(new Date(days * DayTimes + endDate.getTime()), dateFormat);\n taskRecord[endDateField] = newEndDate;\n }\n this.updateRecordToListTable(taskRecord, index);\n }\n updateTaskRecord(index: number) {\n const taskRecord = this.getRecordByIndex(index);\n this.updateRecordToListTable(taskRecord, index);\n }\n\n /**\n * 设置像数比\n * @param pixelRatio\n */\n setPixelRatio(pixelRatio: number) {\n this.parsedOptions.pixelRatio = pixelRatio;\n this.scenegraph.setPixelRatio(pixelRatio);\n }\n\n _resize() {\n this._updateSize();\n this.taskListTableInstance.setCanvasSize(\n this.taskTableWidth,\n this.tableNoFrameHeight + this.parsedOptions.frameStyle.borderLineWidth * 2\n );\n this._syncPropsFromTable();\n this.scenegraph.resize();\n }\n _syncPropsFromTable() {\n this.itemCount = this.taskListTableInstance\n ? this.taskListTableInstance.rowCount - this.taskListTableInstance.columnHeaderLevelCount\n : this.records.length;\n this.headerHeight = this.getAllHeaderRowsHeight();\n this.drawHeight = Math.min(\n this.headerHeight + this.parsedOptions.rowHeight * this.itemCount,\n this.tableNoFrameHeight\n );\n this.gridHeight = this.drawHeight - this.headerHeight;\n }\n /** 获取绘制画布的canvas上下文 */\n getContext(): CanvasRenderingContext2D {\n return this.context;\n }\n\n release(): void {\n super.release?.();\n this.eventManager.release();\n this.taskListTableInstance?.release();\n const { parentElement } = this.element;\n if (parentElement) {\n parentElement.removeChild(this.element);\n }\n this.scenegraph = null;\n }\n setRecords(records: any[]) {\n this.records = records;\n }\n}\n"]}
@@ -0,0 +1,9 @@
1
+ import type { Gantt } from '../Gantt';
2
+ export declare class DataSource {
3
+ records: any[];
4
+ minDate: Date;
5
+ maxDate: Date;
6
+ _gantt: Gantt;
7
+ constructor(_gantt: Gantt);
8
+ processRecords(): void;
9
+ }
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: !0
5
+ }), exports.DataSource = void 0;
6
+
7
+ class DataSource {
8
+ constructor(_gantt) {
9
+ this._gantt = _gantt, this.records = _gantt.records, this.minDate = _gantt.parsedOptions.minDate,
10
+ this.maxDate = _gantt.parsedOptions.maxDate, this.processRecords();
11
+ }
12
+ processRecords() {
13
+ const needMinDate = !this.minDate, needMaxDate = !this.maxDate;
14
+ let minDate = Number.MAX_SAFE_INTEGER, maxDate = Number.MIN_SAFE_INTEGER;
15
+ if (needMinDate || needMaxDate) {
16
+ for (let i = 0; i < this.records.length; i++) {
17
+ const record = this.records[i];
18
+ needMinDate && (minDate = Math.min(minDate, new Date(record[this._gantt.parsedOptions.startDateField]).getTime())),
19
+ needMaxDate && (maxDate = Math.max(maxDate, new Date(record[this._gantt.parsedOptions.endDateField]).getTime()));
20
+ }
21
+ needMinDate && (this.minDate = new Date(minDate)), needMaxDate && (this.maxDate = new Date(maxDate)),
22
+ this._gantt.parsedOptions.minDate = this.minDate, this._gantt.parsedOptions.maxDate = this.maxDate,
23
+ this._gantt.parsedOptions._minDateTime = this._gantt.parsedOptions.minDate.getTime(),
24
+ this._gantt.parsedOptions._maxDateTime = this._gantt.parsedOptions.maxDate.getTime();
25
+ }
26
+ }
27
+ }
28
+
29
+ exports.DataSource = DataSource;
30
+ //# sourceMappingURL=DataSource.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/data/DataSource.ts"],"names":[],"mappings":";;;AAEA,MAAa,UAAU;IAKrB,YAAY,MAAa;QACvB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC;QAC9B,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC;QAC5C,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC;QAC5C,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IACD,cAAc;QACZ,MAAM,WAAW,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC;QAClC,MAAM,WAAW,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC;QAElC,IAAI,OAAO,GAAG,MAAM,CAAC,gBAAgB,CAAC;QACtC,IAAI,OAAO,GAAG,MAAM,CAAC,gBAAgB,CAAC;QACtC,IAAI,WAAW,IAAI,WAAW,EAAE;YAC9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC5C,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC/B,WAAW;oBACT,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;gBACtG,WAAW;oBACT,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;aACrG;YAED,WAAW,IAAI,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;YAClD,WAAW,IAAI,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;YAElD,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;YACjD,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;YACjD,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACrF,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;SACtF;IACH,CAAC;CACF;AApCD,gCAoCC","file":"DataSource.js","sourcesContent":["import type { Gantt } from '../Gantt';\n\nexport class DataSource {\n records: any[];\n minDate: Date;\n maxDate: Date;\n _gantt: Gantt;\n constructor(_gantt: Gantt) {\n this._gantt = _gantt;\n this.records = _gantt.records;\n this.minDate = _gantt.parsedOptions.minDate;\n this.maxDate = _gantt.parsedOptions.maxDate;\n this.processRecords();\n }\n processRecords() {\n const needMinDate = !this.minDate;\n const needMaxDate = !this.maxDate;\n\n let minDate = Number.MAX_SAFE_INTEGER;\n let maxDate = Number.MIN_SAFE_INTEGER;\n if (needMinDate || needMaxDate) {\n for (let i = 0; i < this.records.length; i++) {\n const record = this.records[i];\n needMinDate &&\n (minDate = Math.min(minDate, new Date(record[this._gantt.parsedOptions.startDateField]).getTime()));\n needMaxDate &&\n (maxDate = Math.max(maxDate, new Date(record[this._gantt.parsedOptions.endDateField]).getTime()));\n }\n\n needMinDate && (this.minDate = new Date(minDate));\n needMaxDate && (this.maxDate = new Date(maxDate));\n\n this._gantt.parsedOptions.minDate = this.minDate;\n this._gantt.parsedOptions.maxDate = this.maxDate;\n this._gantt.parsedOptions._minDateTime = this._gantt.parsedOptions.minDate.getTime();\n this._gantt.parsedOptions._maxDateTime = this._gantt.parsedOptions.maxDate.getTime();\n }\n }\n}\n"]}