@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.
- package/README.md +151 -0
- package/cjs/Gantt.d.ts +111 -0
- package/cjs/Gantt.js +244 -0
- package/cjs/Gantt.js.map +1 -0
- package/cjs/data/DataSource.d.ts +9 -0
- package/cjs/data/DataSource.js +30 -0
- package/cjs/data/DataSource.js.map +1 -0
- package/cjs/env.d.ts +19 -0
- package/cjs/env.js +48 -0
- package/cjs/env.js.map +1 -0
- package/cjs/event/EventHandler.d.ts +47 -0
- package/cjs/event/EventHandler.js +128 -0
- package/cjs/event/EventHandler.js.map +1 -0
- package/cjs/event/EventTarget.d.ts +12 -0
- package/cjs/event/EventTarget.js +67 -0
- package/cjs/event/EventTarget.js.map +1 -0
- package/cjs/event/event-manager.d.ts +15 -0
- package/cjs/event/event-manager.js +76 -0
- package/cjs/event/event-manager.js.map +1 -0
- package/cjs/event/scroll.d.ts +22 -0
- package/cjs/event/scroll.js +136 -0
- package/cjs/event/scroll.js.map +1 -0
- package/cjs/gantt-helper.d.ts +28 -0
- package/cjs/gantt-helper.js +225 -0
- package/cjs/gantt-helper.js.map +1 -0
- package/cjs/index.d.ts +7 -0
- package/cjs/index.js +48 -0
- package/cjs/index.js.map +1 -0
- package/cjs/register.d.ts +1 -0
- package/cjs/register.js +1 -0
- package/cjs/register.js.map +1 -0
- package/cjs/scenegraph/frame-border.d.ts +9 -0
- package/cjs/scenegraph/frame-border.js +42 -0
- package/cjs/scenegraph/frame-border.js.map +1 -0
- package/cjs/scenegraph/ganttNode.d.ts +7 -0
- package/cjs/scenegraph/ganttNode.js +16 -0
- package/cjs/scenegraph/ganttNode.js.map +1 -0
- package/cjs/scenegraph/grid.d.ts +30 -0
- package/cjs/scenegraph/grid.js +130 -0
- package/cjs/scenegraph/grid.js.map +1 -0
- package/cjs/scenegraph/mark-line.d.ts +15 -0
- package/cjs/scenegraph/mark-line.js +66 -0
- package/cjs/scenegraph/mark-line.js.map +1 -0
- package/cjs/scenegraph/scenegraph.d.ts +41 -0
- package/cjs/scenegraph/scenegraph.js +109 -0
- package/cjs/scenegraph/scenegraph.js.map +1 -0
- package/cjs/scenegraph/scroll-bar.d.ts +19 -0
- package/cjs/scenegraph/scroll-bar.js +150 -0
- package/cjs/scenegraph/scroll-bar.js.map +1 -0
- package/cjs/scenegraph/task-bar.d.ts +24 -0
- package/cjs/scenegraph/task-bar.js +188 -0
- package/cjs/scenegraph/task-bar.js.map +1 -0
- package/cjs/scenegraph/timeline-header.d.ts +10 -0
- package/cjs/scenegraph/timeline-header.js +134 -0
- package/cjs/scenegraph/timeline-header.js.map +1 -0
- package/cjs/state/gantt-table-sync.d.ts +7 -0
- package/cjs/state/gantt-table-sync.js +60 -0
- package/cjs/state/gantt-table-sync.js.map +1 -0
- package/cjs/state/state-manager.d.ts +58 -0
- package/cjs/state/state-manager.js +223 -0
- package/cjs/state/state-manager.js.map +1 -0
- package/cjs/themes.d.ts +1 -0
- package/cjs/themes.js +1 -0
- package/cjs/themes.js.map +1 -0
- package/cjs/tools/debounce.d.ts +1 -0
- package/cjs/tools/debounce.js +51 -0
- package/cjs/tools/debounce.js.map +1 -0
- package/cjs/tools/index.d.ts +2 -0
- package/cjs/tools/index.js +20 -0
- package/cjs/tools/index.js.map +1 -0
- package/cjs/tools/isx.d.ts +16 -0
- package/cjs/tools/isx.js +117 -0
- package/cjs/tools/isx.js.map +1 -0
- package/cjs/tools/pixel-ratio.d.ts +2 -0
- package/cjs/tools/pixel-ratio.js +16 -0
- package/cjs/tools/pixel-ratio.js.map +1 -0
- package/cjs/tools/util.d.ts +7 -0
- package/cjs/tools/util.js +87 -0
- package/cjs/tools/util.js.map +1 -0
- package/cjs/ts-types/EVENT_TYPE.d.ts +5 -0
- package/cjs/ts-types/EVENT_TYPE.js +9 -0
- package/cjs/ts-types/EVENT_TYPE.js.map +1 -0
- package/cjs/ts-types/common.d.ts +13 -0
- package/cjs/ts-types/common.js +14 -0
- package/cjs/ts-types/common.js.map +1 -0
- package/cjs/ts-types/events.d.ts +14 -0
- package/cjs/ts-types/events.js +6 -0
- package/cjs/ts-types/events.js.map +1 -0
- package/cjs/ts-types/gantt-engine.d.ts +163 -0
- package/cjs/ts-types/gantt-engine.js +6 -0
- package/cjs/ts-types/gantt-engine.js.map +1 -0
- package/cjs/ts-types/index.d.ts +4 -0
- package/cjs/ts-types/index.js +22 -0
- package/cjs/ts-types/index.js.map +1 -0
- package/dist/vtable-gantt.js +53942 -0
- package/dist/vtable-gantt.min.js +1 -0
- package/es/Gantt.d.ts +111 -0
- package/es/Gantt.js +246 -0
- package/es/Gantt.js.map +1 -0
- package/es/data/DataSource.d.ts +9 -0
- package/es/data/DataSource.js +22 -0
- package/es/data/DataSource.js.map +1 -0
- package/es/env.d.ts +19 -0
- package/es/env.js +42 -0
- package/es/env.js.map +1 -0
- package/es/event/EventHandler.d.ts +47 -0
- package/es/event/EventHandler.js +119 -0
- package/es/event/EventHandler.js.map +1 -0
- package/es/event/EventTarget.d.ts +12 -0
- package/es/event/EventTarget.js +58 -0
- package/es/event/EventTarget.js.map +1 -0
- package/es/event/event-manager.d.ts +15 -0
- package/es/event/event-manager.js +78 -0
- package/es/event/event-manager.js.map +1 -0
- package/es/event/scroll.d.ts +22 -0
- package/es/event/scroll.js +126 -0
- package/es/event/scroll.js.map +1 -0
- package/es/gantt-helper.d.ts +28 -0
- package/es/gantt-helper.js +220 -0
- package/es/gantt-helper.js.map +1 -0
- package/es/index.d.ts +7 -0
- package/es/index.js +10 -0
- package/es/index.js.map +1 -0
- package/es/register.d.ts +1 -0
- package/es/register.js +1 -0
- package/es/register.js.map +1 -0
- package/es/scenegraph/frame-border.d.ts +9 -0
- package/es/scenegraph/frame-border.js +34 -0
- package/es/scenegraph/frame-border.js.map +1 -0
- package/es/scenegraph/ganttNode.d.ts +7 -0
- package/es/scenegraph/ganttNode.js +8 -0
- package/es/scenegraph/ganttNode.js.map +1 -0
- package/es/scenegraph/grid.d.ts +30 -0
- package/es/scenegraph/grid.js +122 -0
- package/es/scenegraph/grid.js.map +1 -0
- package/es/scenegraph/mark-line.d.ts +15 -0
- package/es/scenegraph/mark-line.js +58 -0
- package/es/scenegraph/mark-line.js.map +1 -0
- package/es/scenegraph/scenegraph.d.ts +41 -0
- package/es/scenegraph/scenegraph.js +116 -0
- package/es/scenegraph/scenegraph.js.map +1 -0
- package/es/scenegraph/scroll-bar.d.ts +19 -0
- package/es/scenegraph/scroll-bar.js +144 -0
- package/es/scenegraph/scroll-bar.js.map +1 -0
- package/es/scenegraph/task-bar.d.ts +24 -0
- package/es/scenegraph/task-bar.js +188 -0
- package/es/scenegraph/task-bar.js.map +1 -0
- package/es/scenegraph/timeline-header.d.ts +10 -0
- package/es/scenegraph/timeline-header.js +130 -0
- package/es/scenegraph/timeline-header.js.map +1 -0
- package/es/state/gantt-table-sync.d.ts +7 -0
- package/es/state/gantt-table-sync.js +51 -0
- package/es/state/gantt-table-sync.js.map +1 -0
- package/es/state/state-manager.d.ts +58 -0
- package/es/state/state-manager.js +219 -0
- package/es/state/state-manager.js.map +1 -0
- package/es/themes.d.ts +1 -0
- package/es/themes.js +1 -0
- package/es/themes.js.map +1 -0
- package/es/tools/debounce.d.ts +1 -0
- package/es/tools/debounce.js +43 -0
- package/es/tools/debounce.js.map +1 -0
- package/es/tools/index.d.ts +2 -0
- package/es/tools/index.js +4 -0
- package/es/tools/index.js.map +1 -0
- package/es/tools/isx.d.ts +16 -0
- package/es/tools/isx.js +80 -0
- package/es/tools/isx.js.map +1 -0
- package/es/tools/pixel-ratio.d.ts +2 -0
- package/es/tools/pixel-ratio.js +12 -0
- package/es/tools/pixel-ratio.js.map +1 -0
- package/es/tools/util.d.ts +7 -0
- package/es/tools/util.js +78 -0
- package/es/tools/util.js.map +1 -0
- package/es/ts-types/EVENT_TYPE.d.ts +5 -0
- package/es/ts-types/EVENT_TYPE.js +5 -0
- package/es/ts-types/EVENT_TYPE.js.map +1 -0
- package/es/ts-types/common.d.ts +13 -0
- package/es/ts-types/common.js +13 -0
- package/es/ts-types/common.js.map +1 -0
- package/es/ts-types/events.d.ts +14 -0
- package/es/ts-types/events.js +2 -0
- package/es/ts-types/events.js.map +1 -0
- package/es/ts-types/gantt-engine.d.ts +163 -0
- package/es/ts-types/gantt-engine.js +2 -0
- package/es/ts-types/gantt-engine.js.map +1 -0
- package/es/ts-types/index.d.ts +4 -0
- package/es/ts-types/index.js +8 -0
- package/es/ts-types/index.js.map +1 -0
- 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
|
+
}
|
package/es/Gantt.js.map
ADDED
|
@@ -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,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 {};
|