@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/es/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/es/Gantt.js ADDED
@@ -0,0 +1,246 @@
1
+ import { Scenegraph } from "./scenegraph/scenegraph";
2
+
3
+ import { Env } from "./env";
4
+
5
+ import { ListTable, themes } from "@visactor/vtable";
6
+
7
+ import { EventManager } from "./event/event-manager";
8
+
9
+ import { StateManager } from "./state/state-manager";
10
+
11
+ import { DayTimes, generateTimeLineDate, getHorizontalScrollBarSize, getVerticalScrollBarSize, initOptions } from "./gantt-helper";
12
+
13
+ import { EventTarget } from "./event/EventTarget";
14
+
15
+ import { formatDate, parseDateFormat } from "./tools/util";
16
+
17
+ import { DataSource } from "./data/DataSource";
18
+
19
+ export function createRootElement(padding, className = "vtable-gantt") {
20
+ var _a, _b;
21
+ const element = document.createElement("div");
22
+ element.setAttribute("tabindex", "0"), element.classList.add(className), element.style.outline = "none",
23
+ element.style.margin = `${padding.top}px ${padding.right}px ${padding.bottom}px ${padding.left}px`;
24
+ 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;
25
+ return element.style.width = width && width - padding.left - padding.right + "px" || "0px",
26
+ element.style.height = height && height - padding.top - padding.bottom + "px" || "0px",
27
+ element;
28
+ }
29
+
30
+ export class Gantt extends EventTarget {
31
+ constructor(container, options) {
32
+ var _a, _b, _c, _d, _e;
33
+ super(), this.parsedOptions = {}, this.container = container, this.options = options,
34
+ 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,
35
+ this.taskTableColumns = null !== (_d = null === (_c = null == options ? void 0 : options.taskListTable) || void 0 === _c ? void 0 : _c.columns) && void 0 !== _d ? _d : [],
36
+ this.records = null !== (_e = null == options ? void 0 : options.records) && void 0 !== _e ? _e : [],
37
+ initOptions(this), this.data = new DataSource(this), this._sortScales(), this._generateTimeLineDateMap(),
38
+ this.headerLevel = this.sortedTimelineScales.length, this.element = createRootElement({
39
+ top: 0,
40
+ right: 0,
41
+ left: 0,
42
+ bottom: 0
43
+ }, "vtable-gantt"), this.element.style.top = "0px", this.element.style.left = this.taskTableWidth ? `${this.taskTableWidth}px` : "0px",
44
+ this.canvas = document.createElement("canvas"), this.element.appendChild(this.canvas),
45
+ this.context = this.canvas.getContext("2d"), container ? (container.appendChild(this.element),
46
+ this._updateSize()) : this._updateSize(), this._generateListTable(), this._syncPropsFromTable(),
47
+ this._createResizeLine(), this.scenegraph = new Scenegraph(this), this.stateManager = new StateManager(this),
48
+ this.eventManager = new EventManager(this), this.scenegraph.afterCreateSceneGraph();
49
+ }
50
+ renderTaskTable() {
51
+ this.scenegraph.updateNextFrame();
52
+ }
53
+ _updateSize() {
54
+ var _a, _b, _c, _d, _e, _f;
55
+ let widthP = 0, heightP = 0;
56
+ if ("browser" === Env.mode) {
57
+ const element = this.getElement();
58
+ let widthWithoutPadding = 0, heightWithoutPadding = 0;
59
+ if (element.parentElement) {
60
+ const computedStyle = element.parentElement.style || window.getComputedStyle(element.parentElement);
61
+ widthWithoutPadding = element.parentElement.offsetWidth - parseInt(computedStyle.paddingLeft || "0px", 10) - parseInt(computedStyle.paddingRight || "0px", 10),
62
+ heightWithoutPadding = element.parentElement.offsetHeight - parseInt(computedStyle.paddingTop || "0px", 10) - parseInt(computedStyle.paddingBottom || "0px", 20);
63
+ }
64
+ const width1 = (null != widthWithoutPadding ? widthWithoutPadding : 1) - 1 - this.taskTableWidth, height1 = (null != heightWithoutPadding ? heightWithoutPadding : 1) - 1;
65
+ element.style.width = width1 && `${width1}px` || "0px", element.style.height = height1 && `${height1}px` || "0px";
66
+ const {canvas: canvas} = this;
67
+ widthP = null !== (_b = null === (_a = canvas.parentElement) || void 0 === _a ? void 0 : _a.offsetWidth) && void 0 !== _b ? _b : 1,
68
+ heightP = null !== (_d = null === (_c = canvas.parentElement) || void 0 === _c ? void 0 : _c.offsetHeight) && void 0 !== _d ? _d : 1,
69
+ (null === (_e = null == this ? void 0 : this.scenegraph) || void 0 === _e ? void 0 : _e.stage) ? this.scenegraph.stage.resize(widthP, heightP) : (canvas.style.width = "",
70
+ canvas.style.height = "", canvas.width = widthP, canvas.height = heightP, canvas.style.width = `${widthP}px`,
71
+ canvas.style.height = `${heightP}px`);
72
+ } else "node" === Env.mode && (widthP = this.canvasWidth - 1, heightP = this.canvasHeight - 1);
73
+ const width = Math.floor(widthP - getVerticalScrollBarSize(this.parsedOptions.scrollStyle)), height = Math.floor(heightP - getHorizontalScrollBarSize(this.parsedOptions.scrollStyle));
74
+ if (this.tableNoFrameWidth = widthP, this.tableNoFrameHeight = Math.floor(heightP),
75
+ this.parsedOptions.frameStyle) {
76
+ const lineWidth = null === (_f = this.parsedOptions.frameStyle) || void 0 === _f ? void 0 : _f.borderLineWidth;
77
+ this.tableX = lineWidth, this.tableY = lineWidth, this.tableNoFrameWidth = width - lineWidth,
78
+ this.tableNoFrameHeight = height - 2 * lineWidth;
79
+ }
80
+ }
81
+ _generateListTable() {
82
+ var _a, _b;
83
+ if (this.taskTableColumns.length >= 1) {
84
+ const listTableOption = this._generateListTableOptions();
85
+ if (this.taskListTableInstance = new ListTable(this.container, listTableOption),
86
+ "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,
87
+ this.element.style.left = this.taskTableWidth ? `${this.taskTableWidth}px` : "0px",
88
+ this.taskListTableInstance.setCanvasSize(this.taskTableWidth, this.tableNoFrameHeight + 2 * this.parsedOptions.frameStyle.borderLineWidth),
89
+ 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 {
90
+ const newRowHeight = this.getAllHeaderRowsHeight() / this.taskListTableInstance.columnHeaderLevelCount;
91
+ for (let i = 0; i < this.taskListTableInstance.columnHeaderLevelCount; i++) this.taskListTableInstance.setRowHeight(i, newRowHeight);
92
+ }
93
+ }
94
+ }
95
+ _generateListTableOptions() {
96
+ var _a;
97
+ const listTable_options = {}, needPutInListTableKeys = [ "container", "records", "pixelRatio", "overscrollBehavior", "pixelRatio" ];
98
+ for (const key in this.options) needPutInListTableKeys.indexOf(key) >= 0 && (listTable_options[key] = this.options[key]);
99
+ for (const key in this.options.taskListTable) listTable_options[key] = this.options.taskListTable[key];
100
+ return listTable_options.theme = {
101
+ scrollStyle: Object.assign({}, this.parsedOptions.scrollStyle, {
102
+ verticalVisible: "none"
103
+ }),
104
+ headerStyle: Object.assign({}, themes.DEFAULT.headerStyle, {
105
+ bgColor: this.parsedOptions.timelineHeaderBackgroundColor
106
+ }, this.options.taskListTable.headerStyle),
107
+ cellInnerBorder: !1,
108
+ frameStyle: Object.assign({}, this.parsedOptions.frameStyle, {
109
+ cornerRadius: this.parsedOptions.frameStyle.cornerRadius,
110
+ borderLineWidth: [ this.parsedOptions.frameStyle.borderLineWidth, 0, this.parsedOptions.frameStyle.borderLineWidth, this.parsedOptions.frameStyle.borderLineWidth ]
111
+ }),
112
+ bodyStyle: Object.assign({}, themes.DEFAULT.bodyStyle, this.options.taskListTable.bodyStyle)
113
+ }, listTable_options.canvasWidth = this.taskTableWidth, listTable_options.canvasHeight = null !== (_a = this.canvasHeight) && void 0 !== _a ? _a : this.canvas.height,
114
+ listTable_options.defaultHeaderRowHeight = this.getAllHeaderRowsHeight(), listTable_options.defaultRowHeight = this.parsedOptions.rowHeight,
115
+ listTable_options.clearDOM = !1, listTable_options;
116
+ }
117
+ _createResizeLine() {
118
+ if (this.taskListTableInstance && "auto" !== this.options.taskListTable.width) {
119
+ this.resizeLine = document.createElement("div"), this.resizeLine.style.position = "absolute",
120
+ this.resizeLine.style.top = this.tableY + "px", this.resizeLine.style.left = this.taskTableWidth ? this.taskTableWidth - 7 + "px" : "0px",
121
+ this.resizeLine.style.width = "14px", this.resizeLine.style.height = this.drawHeight + "px",
122
+ this.resizeLine.style.backgroundColor = "rgba(0,0,0,0)", this.resizeLine.style.zIndex = "100",
123
+ this.resizeLine.style.cursor = "col-resize", this.resizeLine.style.userSelect = "none",
124
+ this.resizeLine.style.opacity = "1";
125
+ const highlightLine = document.createElement("div");
126
+ highlightLine.style.position = "absolute", highlightLine.style.top = "0px", highlightLine.style.left = "5px",
127
+ highlightLine.style.width = this.parsedOptions.resizeLineStyle.lineWidth + "px",
128
+ highlightLine.style.height = "100%", highlightLine.style.backgroundColor = this.parsedOptions.resizeLineStyle.lineColor,
129
+ highlightLine.style.zIndex = "100", highlightLine.style.cursor = "col-resize", highlightLine.style.userSelect = "none",
130
+ highlightLine.style.pointerEvents = "none", highlightLine.style.opacity = "0", highlightLine.style.transition = "background-color 0.3s",
131
+ this.resizeLine.appendChild(highlightLine), this.resizeLine.addEventListener("mouseover", (() => {
132
+ highlightLine.style.opacity = "1";
133
+ })), this.resizeLine.addEventListener("mouseout", (() => {
134
+ highlightLine.style.opacity = "0";
135
+ })), this.container.appendChild(this.resizeLine);
136
+ }
137
+ }
138
+ getElement() {
139
+ return this.element;
140
+ }
141
+ getContainer() {
142
+ return this.element.parentElement;
143
+ }
144
+ _sortScales() {
145
+ const {timelineHeader: timelineHeader} = this.options;
146
+ if (timelineHeader) {
147
+ const timelineScales = timelineHeader.scales, sortOrder = [ "year", "quarter", "month", "week", "day" ], orderedScales = timelineScales.slice().sort(((a, b) => {
148
+ const indexA = sortOrder.indexOf(a.unit), indexB = sortOrder.indexOf(b.unit);
149
+ return -1 === indexA ? 1 : -1 === indexB ? -1 : indexA - indexB;
150
+ })), reverseOrderedScales = timelineScales.slice().sort(((a, b) => {
151
+ const indexA = sortOrder.indexOf(a.unit), indexB = sortOrder.indexOf(b.unit);
152
+ return -1 === indexA ? 1 : -1 === indexB ? -1 : indexB - indexA;
153
+ }));
154
+ this.sortedTimelineScales = orderedScales, this.reverseSortedTimelineScales = reverseOrderedScales;
155
+ }
156
+ }
157
+ _generateTimeLineDateMap() {
158
+ const startDate = new Date(this.parsedOptions.minDate), endDate = new Date(this.parsedOptions.maxDate);
159
+ let colWidthIncludeDays = 1e6;
160
+ for (const scale of this.reverseSortedTimelineScales) {
161
+ const currentDate = new Date(startDate);
162
+ scale.timelineDates = generateTimeLineDate(currentDate, endDate, scale);
163
+ }
164
+ const firstScale = this.reverseSortedTimelineScales[0], {unit: unit, step: step} = firstScale;
165
+ "day" === unit ? colWidthIncludeDays = step : "month" === unit ? colWidthIncludeDays = 30 : "week" === unit ? colWidthIncludeDays = 7 : "quarter" === unit ? colWidthIncludeDays = 90 : "year" === unit && (colWidthIncludeDays = 365),
166
+ this.parsedOptions.colWidthPerDay = this.parsedOptions.timelineColWidth / colWidthIncludeDays;
167
+ }
168
+ getAllRowsHeight() {
169
+ return this.getAllHeaderRowsHeight() + this.itemCount * this.parsedOptions.rowHeight;
170
+ }
171
+ getAllHeaderRowsHeight() {
172
+ return Array.isArray(this.parsedOptions.headerRowHeight) ? this.parsedOptions.headerRowHeight.reduce(((acc, curr, index) => acc + curr), 0) : this.parsedOptions.headerRowHeight * this.headerLevel;
173
+ }
174
+ getAllColsWidth() {
175
+ return this.parsedOptions.colWidthPerDay * (Math.ceil(Math.abs(new Date(this.parsedOptions.maxDate).getTime() - new Date(this.parsedOptions.minDate).getTime()) / 864e5) + 1);
176
+ }
177
+ getAllGridHeight() {
178
+ return this.itemCount * this.parsedOptions.rowHeight;
179
+ }
180
+ getRecordByIndex(index) {
181
+ return this.taskListTableInstance ? this.taskListTableInstance.getRecordByRowCol(0, index + this.taskListTableInstance.columnHeaderLevelCount) : this.records[index];
182
+ }
183
+ redrawRecord(index) {
184
+ this.scenegraph.taskBar.updateTaskBarNode(index), this.scenegraph.updateNextFrame();
185
+ }
186
+ updateRecordToListTable(record, index) {
187
+ this.taskListTableInstance.updateRecords([ record ], [ index ]);
188
+ }
189
+ getTaskInfoByTaskListIndex(index) {
190
+ 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();
191
+ if (rawDateEndDateTime < this.parsedOptions._minDateTime || rawDateStartDateTime > this.parsedOptions._maxDateTime) return {
192
+ taskDays: 0
193
+ };
194
+ 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];
195
+ return {
196
+ taskRecord: taskRecord,
197
+ taskDays: Math.ceil(Math.abs(endDate.getTime() - startDate.getTime()) / 864e5) + 1,
198
+ startDate: startDate,
199
+ endDate: endDate,
200
+ progress: progress
201
+ };
202
+ }
203
+ updateDateToTaskRecord(updateDateType, days, index) {
204
+ const taskRecord = this.getRecordByIndex(index), startDateField = this.parsedOptions.startDateField, endDateField = this.parsedOptions.endDateField, dateFormat = parseDateFormat(taskRecord[startDateField]), startDate = new Date(taskRecord[startDateField]), endDate = new Date(taskRecord[endDateField]);
205
+ if ("move" === updateDateType) {
206
+ const newStartDate = formatDate(new Date(days * DayTimes + startDate.getTime()), dateFormat), newEndDate = formatDate(new Date(days * DayTimes + endDate.getTime()), dateFormat);
207
+ taskRecord[startDateField] = newStartDate, taskRecord[endDateField] = newEndDate;
208
+ } else if ("start-move" === updateDateType) {
209
+ const newStartDate = formatDate(new Date(days * DayTimes + startDate.getTime()), dateFormat);
210
+ taskRecord[startDateField] = newStartDate;
211
+ } else if ("end-move" === updateDateType) {
212
+ const newEndDate = formatDate(new Date(days * DayTimes + endDate.getTime()), dateFormat);
213
+ taskRecord[endDateField] = newEndDate;
214
+ }
215
+ this.updateRecordToListTable(taskRecord, index);
216
+ }
217
+ updateTaskRecord(index) {
218
+ const taskRecord = this.getRecordByIndex(index);
219
+ this.updateRecordToListTable(taskRecord, index);
220
+ }
221
+ setPixelRatio(pixelRatio) {
222
+ this.parsedOptions.pixelRatio = pixelRatio, this.scenegraph.setPixelRatio(pixelRatio);
223
+ }
224
+ _resize() {
225
+ this._updateSize(), this.taskListTableInstance.setCanvasSize(this.taskTableWidth, this.tableNoFrameHeight + 2 * this.parsedOptions.frameStyle.borderLineWidth),
226
+ this._syncPropsFromTable(), this.scenegraph.resize();
227
+ }
228
+ _syncPropsFromTable() {
229
+ this.itemCount = this.taskListTableInstance ? this.taskListTableInstance.rowCount - this.taskListTableInstance.columnHeaderLevelCount : this.records.length,
230
+ this.headerHeight = this.getAllHeaderRowsHeight(), this.drawHeight = Math.min(this.headerHeight + this.parsedOptions.rowHeight * this.itemCount, this.tableNoFrameHeight),
231
+ this.gridHeight = this.drawHeight - this.headerHeight;
232
+ }
233
+ getContext() {
234
+ return this.context;
235
+ }
236
+ release() {
237
+ var _a, _b;
238
+ null === (_a = super.release) || void 0 === _a || _a.call(this), this.eventManager.release(),
239
+ null === (_b = this.taskListTableInstance) || void 0 === _b || _b.release();
240
+ const {parentElement: parentElement} = this.element;
241
+ parentElement && parentElement.removeChild(this.element), this.scenegraph = null;
242
+ }
243
+ setRecords(records) {
244
+ this.records = records;
245
+ }
246
+ }
@@ -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,22 @@
1
+ export class DataSource {
2
+ constructor(_gantt) {
3
+ this._gantt = _gantt, this.records = _gantt.records, this.minDate = _gantt.parsedOptions.minDate,
4
+ this.maxDate = _gantt.parsedOptions.maxDate, this.processRecords();
5
+ }
6
+ processRecords() {
7
+ const needMinDate = !this.minDate, needMaxDate = !this.maxDate;
8
+ let minDate = Number.MAX_SAFE_INTEGER, maxDate = Number.MIN_SAFE_INTEGER;
9
+ if (needMinDate || needMaxDate) {
10
+ for (let i = 0; i < this.records.length; i++) {
11
+ const record = this.records[i];
12
+ needMinDate && (minDate = Math.min(minDate, new Date(record[this._gantt.parsedOptions.startDateField]).getTime())),
13
+ needMaxDate && (maxDate = Math.max(maxDate, new Date(record[this._gantt.parsedOptions.endDateField]).getTime()));
14
+ }
15
+ needMinDate && (this.minDate = new Date(minDate)), needMaxDate && (this.maxDate = new Date(maxDate)),
16
+ this._gantt.parsedOptions.minDate = this.minDate, this._gantt.parsedOptions.maxDate = this.maxDate,
17
+ this._gantt.parsedOptions._minDateTime = this._gantt.parsedOptions.minDate.getTime(),
18
+ this._gantt.parsedOptions._maxDateTime = this._gantt.parsedOptions.maxDate.getTime();
19
+ }
20
+ }
21
+ }
22
+ //# sourceMappingURL=DataSource.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/data/DataSource.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,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","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"]}
package/es/env.d.ts ADDED
@@ -0,0 +1,19 @@
1
+ export type EnvMode = 'browser' | 'node' | 'worker' | 'miniApp' | 'desktop-miniApp';
2
+ export type LooseFunction = (...args: any) => any;
3
+ export declare class Env {
4
+ static _mode: EnvMode;
5
+ static get mode(): EnvMode;
6
+ static set mode(mode: EnvMode);
7
+ static dpr: number;
8
+ static CreateCanvas?: LooseFunction;
9
+ static LoadImage?: LooseFunction;
10
+ static RequestAnimationFrame?: LooseFunction;
11
+ static CancelAnimationFrame?: LooseFunction;
12
+ static RegisterCreateCanvas(func: LooseFunction): void;
13
+ static RegisterLoadImage(func: LooseFunction): void;
14
+ static GetCreateCanvasFunc(): LooseFunction | undefined;
15
+ static RegisterRequestAnimationFrame(func: LooseFunction): void;
16
+ static GetRequestAnimationFrame(): LooseFunction;
17
+ static RegisterCancelAnimationFrame(func: LooseFunction): void;
18
+ static GetCancelAnimationFrame(): LooseFunction;
19
+ }
package/es/env.js ADDED
@@ -0,0 +1,42 @@
1
+ export class Env {
2
+ static get mode() {
3
+ return Env._mode || (Env._mode = defaultMode()), Env._mode;
4
+ }
5
+ static set mode(mode) {
6
+ Env._mode = mode;
7
+ }
8
+ static RegisterCreateCanvas(func) {
9
+ Env.CreateCanvas = func;
10
+ }
11
+ static RegisterLoadImage(func) {
12
+ Env.LoadImage = func;
13
+ }
14
+ static GetCreateCanvasFunc() {
15
+ return Env.CreateCanvas ? Env.CreateCanvas : "worker" === Env.mode ? (width = 200, height = 200) => new OffscreenCanvas(width, height) : void 0;
16
+ }
17
+ static RegisterRequestAnimationFrame(func) {
18
+ Env.RequestAnimationFrame = func();
19
+ }
20
+ static GetRequestAnimationFrame() {
21
+ if (Env.RequestAnimationFrame) return Env.RequestAnimationFrame;
22
+ }
23
+ static RegisterCancelAnimationFrame(func) {
24
+ Env.CancelAnimationFrame = func();
25
+ }
26
+ static GetCancelAnimationFrame() {
27
+ if (Env.CancelAnimationFrame) return Env.CancelAnimationFrame;
28
+ }
29
+ }
30
+
31
+ function defaultMode() {
32
+ let mode = "browser";
33
+ try {
34
+ "node" === window.type ? mode = "node" : "undefined" == typeof window || window.performance ? "undefined" == typeof window && (mode = "node") : mode = "miniApp";
35
+ } catch (err) {
36
+ mode = "node";
37
+ }
38
+ return mode;
39
+ }
40
+
41
+ //# sourceMappingURL=env.js.map
42
+ Env.dpr = 0;
package/es/env.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/env.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,GAAG;IAEP,MAAM,KAAK,IAAI;QACpB,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE;YACd,GAAG,CAAC,KAAK,GAAG,WAAW,EAAE,CAAC;SAC3B;QACD,OAAO,GAAG,CAAC,KAAK,CAAC;IACnB,CAAC;IACM,MAAM,KAAK,IAAI,CAAC,IAAa;QAClC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC;IACnB,CAAC;IAYD,MAAM,CAAC,oBAAoB,CAAC,IAAmB;QAC7C,GAAG,CAAC,YAAY,GAAG,IAAI,CAAC;IAC1B,CAAC;IAED,MAAM,CAAC,iBAAiB,CAAC,IAAmB;QAC1C,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,mBAAmB;QACxB,IAAI,GAAG,CAAC,YAAY,EAAE;YACpB,OAAO,GAAG,CAAC,YAAY,CAAC;SACzB;QACD,IAAI,GAAG,CAAC,IAAI,KAAK,QAAQ,EAAE;YACzB,OAAO,CAAC,KAAK,GAAG,GAAG,EAAE,MAAM,GAAG,GAAG,EAAE,EAAE,CAAC,IAAI,eAAe,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;SAC1E;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,6BAA6B,CAAC,IAAmB;QACtD,GAAG,CAAC,qBAAqB,GAAG,IAAI,EAAE,CAAC;IACrC,CAAC;IAED,MAAM,CAAC,wBAAwB;QAC7B,IAAI,GAAG,CAAC,qBAAqB,EAAE;YAC7B,OAAO,GAAG,CAAC,qBAAqB,CAAC;SAClC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,4BAA4B,CAAC,IAAmB;QACrD,GAAG,CAAC,oBAAoB,GAAG,IAAI,EAAE,CAAC;IACpC,CAAC;IAED,MAAM,CAAC,uBAAuB;QAC5B,IAAI,GAAG,CAAC,oBAAoB,EAAE;YAC5B,OAAO,GAAG,CAAC,oBAAoB,CAAC;SACjC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;;AAhDM,OAAG,GAAG,CAAC,CAAC;AAwDjB,SAAS,WAAW;IAClB,IAAI,IAAI,GAAY,SAAS,CAAC;IAC9B,IAAI;QACF,IAAK,MAAc,CAAC,IAAI,KAAK,MAAM,EAAE;YACnC,IAAI,GAAG,MAAM,CAAC;SACf;aAAM,IAAI,OAAO,MAAM,KAAK,WAAW,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;YAC/D,IAAI,GAAG,SAAS,CAAC;SAClB;aAAM,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;YACxC,IAAI,GAAG,MAAM,CAAC;SACf;KACF;IAAC,OAAO,GAAG,EAAE;QACZ,IAAI,GAAG,MAAM,CAAC;KACf;IACD,OAAO,IAAI,CAAC;AACd,CAAC","file":"env.js","sourcesContent":["export type EnvMode = 'browser' | 'node' | 'worker' | 'miniApp' | 'desktop-miniApp';\nexport type LooseFunction = (...args: any) => any;\n\nexport class Env {\n static _mode: EnvMode;\n public static get mode() {\n if (!Env._mode) {\n Env._mode = defaultMode();\n }\n return Env._mode;\n }\n public static set mode(mode: EnvMode) {\n Env._mode = mode;\n }\n\n static dpr = 0;\n\n static CreateCanvas?: LooseFunction;\n\n static LoadImage?: LooseFunction;\n\n static RequestAnimationFrame?: LooseFunction;\n\n static CancelAnimationFrame?: LooseFunction;\n\n static RegisterCreateCanvas(func: LooseFunction) {\n Env.CreateCanvas = func;\n }\n\n static RegisterLoadImage(func: LooseFunction) {\n Env.LoadImage = func;\n }\n\n static GetCreateCanvasFunc(): LooseFunction | undefined {\n if (Env.CreateCanvas) {\n return Env.CreateCanvas;\n }\n if (Env.mode === 'worker') {\n return (width = 200, height = 200) => new OffscreenCanvas(width, height);\n }\n return undefined;\n }\n\n static RegisterRequestAnimationFrame(func: LooseFunction) {\n Env.RequestAnimationFrame = func();\n }\n\n static GetRequestAnimationFrame() {\n if (Env.RequestAnimationFrame) {\n return Env.RequestAnimationFrame;\n }\n return undefined;\n }\n\n static RegisterCancelAnimationFrame(func: LooseFunction) {\n Env.CancelAnimationFrame = func();\n }\n\n static GetCancelAnimationFrame() {\n if (Env.CancelAnimationFrame) {\n return Env.CancelAnimationFrame;\n }\n return undefined;\n }\n}\n\n/**\n *\n * 这个默认的判断方法并不能区分出不同的环境,所以这里采用是否判断\n * 满足条件为 'browser',不满足则为 'node'\n */\nfunction defaultMode(): EnvMode {\n let mode: EnvMode = 'browser';\n try {\n if ((window as any).type === 'node') {\n mode = 'node';\n } else if (typeof window !== 'undefined' && !window.performance) {\n mode = 'miniApp';\n } else if (typeof window === 'undefined') {\n mode = 'node';\n }\n } catch (err) {\n mode = 'node';\n }\n return mode;\n}\n"]}
@@ -0,0 +1,47 @@
1
+ import type { EventTarget as CustomEventTarget } from './EventTarget';
2
+ export type EventListenerId = any;
3
+ type EventHandlerTarget = EventTarget | CustomEventTarget;
4
+ type Listener = any;
5
+ export type ResizeObserverCallBack = ({ width, height, windowSizeNotChange }: {
6
+ width: number;
7
+ height: number;
8
+ windowSizeNotChange: boolean;
9
+ }) => void;
10
+ export declare class ResizeObserver {
11
+ resizeTime: number;
12
+ element: HTMLElement;
13
+ cb: ResizeObserverCallBack;
14
+ observer?: MutationObserver;
15
+ lastSize: {
16
+ width: number;
17
+ height: number;
18
+ };
19
+ callBackDebounce: () => void;
20
+ constructor(element: HTMLElement, cb: ResizeObserverCallBack, resizeTime?: number);
21
+ mutationResize: () => void;
22
+ disConnect(): void;
23
+ callBack: () => void;
24
+ setSize(size: {
25
+ width: number;
26
+ height: number;
27
+ }): void;
28
+ private onResize;
29
+ private checkSize;
30
+ getSize(): {
31
+ width: number;
32
+ height: number;
33
+ };
34
+ }
35
+ export declare class EventHandler {
36
+ resizeTime?: number;
37
+ private listeners;
38
+ private reseizeListeners;
39
+ on(target: HTMLElement | Window | EventHandlerTarget, type: string, listener: Listener, ...options: any[]): EventListenerId;
40
+ once(target: EventHandlerTarget, type: string, listener: Listener, ...options: (boolean | AddEventListenerOptions)[]): EventListenerId;
41
+ off(id: EventListenerId | null | undefined): void;
42
+ fire(target: EventTarget, type: string, ...args: any[]): void;
43
+ hasListener(target: EventTarget, type: string): boolean;
44
+ clear(): void;
45
+ release(): void;
46
+ }
47
+ export {};