@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
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { debounce } from "../tools/debounce";
|
|
2
|
+
|
|
3
|
+
import { Env } from "../env";
|
|
4
|
+
|
|
5
|
+
let idCount = 1;
|
|
6
|
+
|
|
7
|
+
export class ResizeObserver {
|
|
8
|
+
constructor(element, cb, resizeTime) {
|
|
9
|
+
var _a;
|
|
10
|
+
if (this.resizeTime = 100, this.lastSize = {
|
|
11
|
+
width: 0,
|
|
12
|
+
height: 0
|
|
13
|
+
}, this.mutationResize = () => {
|
|
14
|
+
this.onResize();
|
|
15
|
+
}, this.callBack = () => {
|
|
16
|
+
const newSize = this.getSize();
|
|
17
|
+
let windowSizeNotChange = !1;
|
|
18
|
+
newSize.width === this.lastSize.width && newSize.height === this.lastSize.height && (windowSizeNotChange = !0),
|
|
19
|
+
this.lastSize = newSize, this.cb && this.cb(Object.assign(Object.assign({}, this.lastSize), {
|
|
20
|
+
windowSizeNotChange: windowSizeNotChange
|
|
21
|
+
}));
|
|
22
|
+
}, this.onResize = () => {
|
|
23
|
+
this.callBackDebounce();
|
|
24
|
+
}, this.element = element, this.cb = cb, this.lastSize = this.getSize(), resizeTime && (this.resizeTime = Math.max(resizeTime, 16)),
|
|
25
|
+
this.callBackDebounce = debounce(this.callBack, this.resizeTime), null === window || void 0 === window || window.addEventListener("resize", this.onResize),
|
|
26
|
+
"ResizeObserver" in window) {
|
|
27
|
+
const ResizeObserverWindow = window.ResizeObserver;
|
|
28
|
+
this.observer = new ResizeObserverWindow(this.mutationResize), null === (_a = this.observer) || void 0 === _a || _a.observe(this.element);
|
|
29
|
+
} else "MutationObserver" in window && (this.observer = new MutationObserver(this.mutationResize),
|
|
30
|
+
this.observer.observe(this.element, {
|
|
31
|
+
attributes: !0,
|
|
32
|
+
attributeFilter: [ "style" ]
|
|
33
|
+
}));
|
|
34
|
+
}
|
|
35
|
+
disConnect() {
|
|
36
|
+
window.removeEventListener("resize", this.onResize), this.observer && (this.observer.disconnect(),
|
|
37
|
+
this.observer = void 0);
|
|
38
|
+
}
|
|
39
|
+
setSize(size) {
|
|
40
|
+
this.lastSize = size;
|
|
41
|
+
}
|
|
42
|
+
checkSize() {
|
|
43
|
+
const newSize = this.getSize();
|
|
44
|
+
return newSize.width !== this.lastSize.width || newSize.height !== this.lastSize.height;
|
|
45
|
+
}
|
|
46
|
+
getSize() {
|
|
47
|
+
return this.element ? {
|
|
48
|
+
width: Math.floor(this.element.clientWidth),
|
|
49
|
+
height: Math.floor(this.element.clientHeight)
|
|
50
|
+
} : Object.assign({}, this.lastSize);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
export class EventHandler {
|
|
55
|
+
constructor() {
|
|
56
|
+
this.listeners = {}, this.reseizeListeners = {};
|
|
57
|
+
}
|
|
58
|
+
on(target, type, listener, ...options) {
|
|
59
|
+
if ("node" === Env.mode) return -1;
|
|
60
|
+
const id = idCount++;
|
|
61
|
+
if (null == target ? void 0 : target.addEventListener) if ("resize" !== type || target === window) null == target || target.addEventListener(type, listener, ...options); else {
|
|
62
|
+
const resizeObserver = new ResizeObserver(target, listener, this.resizeTime);
|
|
63
|
+
this.reseizeListeners[id] = resizeObserver;
|
|
64
|
+
}
|
|
65
|
+
const obj = {
|
|
66
|
+
target: target,
|
|
67
|
+
type: type,
|
|
68
|
+
listener: listener,
|
|
69
|
+
options: options
|
|
70
|
+
};
|
|
71
|
+
return this.listeners[id] = obj, id;
|
|
72
|
+
}
|
|
73
|
+
once(target, type, listener, ...options) {
|
|
74
|
+
if ("node" === Env.mode) return -1;
|
|
75
|
+
const id = this.on(target, type, ((...args) => {
|
|
76
|
+
this.off(id), listener(...args);
|
|
77
|
+
}), ...options);
|
|
78
|
+
return id;
|
|
79
|
+
}
|
|
80
|
+
off(id) {
|
|
81
|
+
var _a;
|
|
82
|
+
if ("node" === Env.mode) return;
|
|
83
|
+
if (null == id) return;
|
|
84
|
+
const obj = null === (_a = this.listeners) || void 0 === _a ? void 0 : _a[id];
|
|
85
|
+
obj && (delete this.listeners[id], obj.target.removeEventListener && obj.target.removeEventListener(obj.type, obj.listener, ...obj.options));
|
|
86
|
+
}
|
|
87
|
+
fire(target, type, ...args) {
|
|
88
|
+
if ("node" !== Env.mode) for (const key in this.listeners) {
|
|
89
|
+
const listener = this.listeners[key];
|
|
90
|
+
listener.target === target && listener.type === type && listener.listener.call(listener.target, ...args);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
hasListener(target, type) {
|
|
94
|
+
if ("node" === Env.mode) return !1;
|
|
95
|
+
let result = !1;
|
|
96
|
+
for (const key in this.listeners) {
|
|
97
|
+
const listener = this.listeners[key];
|
|
98
|
+
listener.target === target && listener.type === type && (result = !0);
|
|
99
|
+
}
|
|
100
|
+
return result;
|
|
101
|
+
}
|
|
102
|
+
clear() {
|
|
103
|
+
if ("node" !== Env.mode) {
|
|
104
|
+
for (const key in this.listeners) {
|
|
105
|
+
const listener = this.listeners[key];
|
|
106
|
+
listener.target.removeEventListener && listener.target.removeEventListener(listener.type, listener.listener, ...listener.options);
|
|
107
|
+
}
|
|
108
|
+
for (const key in this.reseizeListeners) {
|
|
109
|
+
const resizeObserver = this.reseizeListeners[key];
|
|
110
|
+
null == resizeObserver || resizeObserver.disConnect();
|
|
111
|
+
}
|
|
112
|
+
this.listeners = {};
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
release() {
|
|
116
|
+
"node" !== Env.mode && (this.clear(), this.listeners = {});
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
//# sourceMappingURL=EventHandler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/event/EventHandler.ts"],"names":[],"mappings":"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","file":"EventHandler.js","sourcesContent":["// import type { AnyFunction, EventListenerId } from '../ts-types';\nimport type { EventTarget as CustomEventTarget } from './EventTarget';\nimport { debounce } from '../tools/debounce';\nimport { Env } from '../env';\nexport type EventListenerId = any; //TODO 类型\nlet idCount = 1;\ntype EventHandlerTarget = EventTarget | CustomEventTarget;\ntype Listener = any; // AnyFunction; TODO 类型\ntype EventListenerObject = {\n target: EventHandlerTarget;\n type: string;\n listener: Listener;\n options: any[];\n};\n\nexport type ResizeObserverCallBack = ({\n width,\n height,\n windowSizeNotChange\n}: {\n width: number;\n height: number;\n windowSizeNotChange: boolean;\n}) => void;\n\nexport class ResizeObserver {\n resizeTime = 100;\n element: HTMLElement;\n cb: ResizeObserverCallBack;\n observer?: MutationObserver;\n lastSize: {\n width: number;\n height: number;\n } = {\n width: 0,\n height: 0\n };\n callBackDebounce: () => void;\n\n constructor(element: HTMLElement, cb: ResizeObserverCallBack, resizeTime?: number) {\n this.element = element;\n this.cb = cb;\n this.lastSize = this.getSize();\n if (resizeTime) {\n this.resizeTime = Math.max(resizeTime, 16);\n }\n\n this.callBackDebounce = debounce(this.callBack, this.resizeTime);\n //TODO: 这个地方的 addEventListener resize 应该更改到下面的else逻辑中,兼容ResizeObserver不存在的情况\n window?.addEventListener('resize', this.onResize);\n // 优先使用 ResizeObserver\n if ('ResizeObserver' in window) {\n // @ts-ignore\n const ResizeObserverWindow: any = window.ResizeObserver;\n this.observer = new ResizeObserverWindow(this.mutationResize);\n this.observer?.observe(this.element);\n } else if ('MutationObserver' in window) {\n this.observer = new MutationObserver(this.mutationResize);\n this.observer.observe(this.element, {\n attributes: true,\n attributeFilter: ['style']\n });\n }\n }\n\n mutationResize = () => {\n this.onResize();\n };\n\n disConnect() {\n window.removeEventListener('resize', this.onResize);\n if (this.observer) {\n this.observer.disconnect();\n this.observer = undefined;\n }\n }\n\n callBack = () => {\n const newSize = this.getSize();\n let windowSizeNotChange = false;\n if (newSize.width === this.lastSize.width && newSize.height === this.lastSize.height) {\n windowSizeNotChange = true;\n }\n this.lastSize = newSize;\n this.cb && this.cb({ ...this.lastSize, windowSizeNotChange });\n };\n\n setSize(size: { width: number; height: number }) {\n this.lastSize = size;\n }\n\n private onResize = () => {\n // if (this.checkSize()) {\n this.callBackDebounce();\n // }\n };\n\n private checkSize() {\n const newSize = this.getSize();\n if (newSize.width === this.lastSize.width && newSize.height === this.lastSize.height) {\n return false;\n }\n return true;\n }\n\n getSize() {\n if (!this.element) {\n return {\n ...this.lastSize\n };\n }\n return {\n width: Math.floor(this.element.clientWidth),\n height: Math.floor(this.element.clientHeight)\n };\n }\n}\n\nexport class EventHandler {\n resizeTime?: number;\n\n private listeners: {\n [key: string]: EventListenerObject;\n } = {};\n\n private reseizeListeners: {\n [key: string]: ResizeObserver;\n } = {};\n\n on(\n target: HTMLElement | Window | EventHandlerTarget,\n type: string,\n listener: Listener,\n ...options: any[]\n ): EventListenerId {\n if (Env.mode === 'node') {\n return -1;\n }\n const id = idCount++;\n if (target?.addEventListener) {\n if (type !== 'resize' || (target as Window) === window) {\n (target as EventTarget)?.addEventListener(type, listener, ...(options as []));\n } else {\n const resizeObserver = new ResizeObserver(target as HTMLElement, listener, this.resizeTime);\n this.reseizeListeners[id] = resizeObserver;\n }\n }\n const obj = { target, type, listener, options };\n this.listeners[id] = obj;\n return id;\n }\n once(\n target: EventHandlerTarget,\n type: string,\n listener: Listener,\n ...options: (boolean | AddEventListenerOptions)[]\n ): EventListenerId {\n if (Env.mode === 'node') {\n return -1;\n }\n const id = this.on(\n target,\n type,\n (...args: any[]) => {\n this.off(id);\n listener(...args);\n },\n ...options\n );\n return id;\n }\n off(id: EventListenerId | null | undefined): void {\n if (Env.mode === 'node') {\n return;\n }\n if (id == null) {\n return;\n }\n const obj = this.listeners?.[id];\n if (!obj) {\n return;\n }\n delete this.listeners[id];\n if (obj.target.removeEventListener) {\n obj.target.removeEventListener(obj.type, obj.listener, ...(obj.options as []));\n }\n }\n fire(target: EventTarget, type: string, ...args: any[]): void {\n if (Env.mode === 'node') {\n return;\n }\n for (const key in this.listeners) {\n const listener = this.listeners[key];\n if (listener.target === target && listener.type === type) {\n listener.listener.call(listener.target, ...args);\n }\n }\n }\n hasListener(target: EventTarget, type: string): boolean {\n if (Env.mode === 'node') {\n return false;\n }\n let result = false;\n for (const key in this.listeners) {\n const listener = this.listeners[key];\n if (listener.target === target && listener.type === type) {\n result = true;\n }\n }\n\n return result;\n }\n clear(): void {\n if (Env.mode === 'node') {\n return;\n }\n for (const key in this.listeners) {\n const listener = this.listeners[key];\n if (listener.target.removeEventListener) {\n listener.target.removeEventListener(listener.type, listener.listener, ...(listener.options as []));\n }\n }\n\n for (const key in this.reseizeListeners) {\n const resizeObserver: ResizeObserver = this.reseizeListeners[key];\n resizeObserver?.disConnect();\n }\n\n this.listeners = {};\n }\n release(): void {\n if (Env.mode === 'node') {\n return;\n }\n this.clear();\n (this as any).listeners = {};\n }\n}\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { TableEventListener, EventListenerId, TableEventHandlersEventArgumentMap, TableEventHandlersReturnMap } from '../ts-types';
|
|
2
|
+
export declare class EventTarget {
|
|
3
|
+
private listenersData;
|
|
4
|
+
on<TYPE extends keyof TableEventHandlersEventArgumentMap>(type: TYPE, listener: TableEventListener<TYPE>): EventListenerId;
|
|
5
|
+
off(type: string, listener: TableEventListener<keyof TableEventHandlersEventArgumentMap>): void;
|
|
6
|
+
off(id: EventListenerId): void;
|
|
7
|
+
addEventListener<TYPE extends keyof TableEventHandlersEventArgumentMap>(type: TYPE, listener: TableEventListener<TYPE>, option?: any): void;
|
|
8
|
+
removeEventListener(type: string, listener: TableEventListener<keyof TableEventHandlersEventArgumentMap>): void;
|
|
9
|
+
hasListeners(type: string): boolean;
|
|
10
|
+
fireListeners<TYPE extends keyof TableEventHandlersEventArgumentMap>(type: TYPE, event: TableEventHandlersEventArgumentMap[TYPE]): TableEventHandlersReturnMap[TYPE][];
|
|
11
|
+
release(): void;
|
|
12
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { isValid } from "@visactor/vutils";
|
|
2
|
+
|
|
3
|
+
let idCount = 1;
|
|
4
|
+
|
|
5
|
+
export class EventTarget {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.listenersData = {
|
|
8
|
+
listeners: {},
|
|
9
|
+
listenerData: {}
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
on(type, listener) {
|
|
13
|
+
const list = this.listenersData.listeners[type] || (this.listenersData.listeners[type] = []);
|
|
14
|
+
list.push(listener);
|
|
15
|
+
const id = idCount++;
|
|
16
|
+
return this.listenersData.listenerData[id] = {
|
|
17
|
+
type: type,
|
|
18
|
+
listener: listener,
|
|
19
|
+
remove: () => {
|
|
20
|
+
delete this.listenersData.listenerData[id];
|
|
21
|
+
const index = list.indexOf(listener);
|
|
22
|
+
list.splice(index, 1), this.listenersData.listeners[type].length || delete this.listenersData.listeners[type];
|
|
23
|
+
}
|
|
24
|
+
}, id;
|
|
25
|
+
}
|
|
26
|
+
off(idOrType, listener) {
|
|
27
|
+
var _a;
|
|
28
|
+
if (listener) {
|
|
29
|
+
const type = idOrType;
|
|
30
|
+
this.removeEventListener(type, listener);
|
|
31
|
+
} else {
|
|
32
|
+
const id = idOrType;
|
|
33
|
+
if (!this.listenersData) return;
|
|
34
|
+
null === (_a = this.listenersData.listenerData[id]) || void 0 === _a || _a.remove();
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
addEventListener(type, listener, option) {
|
|
38
|
+
this.on(type, listener);
|
|
39
|
+
}
|
|
40
|
+
removeEventListener(type, listener) {
|
|
41
|
+
if (this.listenersData) for (const key in this.listenersData.listenerData) {
|
|
42
|
+
const listenerData = this.listenersData.listenerData[key];
|
|
43
|
+
listenerData.type === type && listenerData.listener === listener && this.off(key);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
hasListeners(type) {
|
|
47
|
+
return !!this.listenersData && !!this.listenersData.listeners[type];
|
|
48
|
+
}
|
|
49
|
+
fireListeners(type, event) {
|
|
50
|
+
if (!this.listenersData) return [];
|
|
51
|
+
const list = this.listenersData.listeners[type];
|
|
52
|
+
return list ? list.map((listener => listener.call(this, event))).filter((r => isValid(r))) : [];
|
|
53
|
+
}
|
|
54
|
+
release() {
|
|
55
|
+
delete this.listenersData;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=EventTarget.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/event/EventTarget.ts"],"names":[],"mappings":"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","file":"EventTarget.js","sourcesContent":["/* Adapted from cheetah-grid by yosuke ota\n *url:https://github.com/future-architect/cheetah-grid/blob/master/packages/cheetah-grid/src/js/core/EventTarget.ts\n *License: https://github.com/future-architect/cheetah-grid/blob/master/LICENSE\n * @license\n */\nimport type {\n TableEventListener,\n EventListenerId,\n TableEventHandlersEventArgumentMap,\n TableEventHandlersReturnMap\n} from '../ts-types';\nimport { isValid } from '@visactor/vutils';\n\nlet idCount = 1;\n\nexport class EventTarget {\n private listenersData: {\n listeners: { [TYPE in keyof TableEventHandlersEventArgumentMap]?: TableEventListener<TYPE>[] };\n listenerData: {\n [id: number]: {\n type: string;\n listener: TableEventListener<keyof TableEventHandlersEventArgumentMap>;\n remove: () => void;\n };\n };\n } = {\n listeners: {},\n listenerData: {}\n };\n\n /**\n * 监听事件\n * @param type 事件类型\n * @param listener 事件监听器\n * @returns 事件监听器id\n */\n on<TYPE extends keyof TableEventHandlersEventArgumentMap>(\n type: TYPE,\n listener: TableEventListener<TYPE>\n ): EventListenerId {\n const list: TableEventListener<TYPE>[] =\n this.listenersData.listeners[type] || (this.listenersData.listeners[type] = []);\n list.push(listener);\n\n const id = idCount++;\n this.listenersData.listenerData[id] = {\n type,\n listener,\n remove: (): void => {\n delete this.listenersData.listenerData[id];\n const index = list.indexOf(listener);\n list.splice(index, 1);\n if (!this.listenersData.listeners[type].length) {\n delete this.listenersData.listeners[type];\n }\n }\n };\n return id;\n }\n\n off(type: string, listener: TableEventListener<keyof TableEventHandlersEventArgumentMap>): void;\n off(id: EventListenerId): void;\n off(\n idOrType: EventListenerId | string,\n listener?: TableEventListener<keyof TableEventHandlersEventArgumentMap>\n ): void {\n if (listener) {\n const type = idOrType as string;\n this.removeEventListener(type, listener);\n } else {\n const id = idOrType as EventListenerId;\n if (!this.listenersData) {\n return;\n }\n this.listenersData.listenerData[id]?.remove();\n }\n }\n\n addEventListener<TYPE extends keyof TableEventHandlersEventArgumentMap>(\n type: TYPE,\n listener: TableEventListener<TYPE>,\n option?: any\n ): void {\n this.on(type, listener);\n }\n\n removeEventListener(type: string, listener: TableEventListener<keyof TableEventHandlersEventArgumentMap>): void {\n if (!this.listenersData) {\n return;\n }\n for (const key in this.listenersData.listenerData) {\n const listenerData = this.listenersData.listenerData[key];\n if (listenerData.type === type && listenerData.listener === listener) {\n this.off(key as unknown as number);\n }\n }\n }\n\n hasListeners(type: string): boolean {\n if (!this.listenersData) {\n return false;\n }\n return !!this.listenersData.listeners[type];\n }\n\n // fireListeners(type: string, ...args: any[]): any {\n // if (!this.listenersData) {\n // return [];\n // }\n // const list = this.listenersData.listeners[type];\n // if (!list) {\n // return [];\n // }\n // return list.map(listener => listener.call(this, ...args)).filter(r => isValid(r));\n // }\n fireListeners<TYPE extends keyof TableEventHandlersEventArgumentMap>(\n type: TYPE,\n event: TableEventHandlersEventArgumentMap[TYPE]\n ): TableEventHandlersReturnMap[TYPE][] {\n if (!this.listenersData) {\n return [];\n }\n const list = this.listenersData.listeners[type];\n if (!list) {\n return [];\n }\n return list.map(listener => listener.call(this, event)).filter(r => isValid(r));\n }\n release(): void {\n delete this.listenersData;\n }\n}\n"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { Gantt } from '../Gantt';
|
|
2
|
+
import { EventHandler } from '../event/EventHandler';
|
|
3
|
+
export declare class EventManager {
|
|
4
|
+
_gantt: Gantt;
|
|
5
|
+
_eventHandler: EventHandler;
|
|
6
|
+
isDown: boolean;
|
|
7
|
+
isDraging: boolean;
|
|
8
|
+
lastDragPointerXYOnWindow: {
|
|
9
|
+
x: number;
|
|
10
|
+
y: number;
|
|
11
|
+
};
|
|
12
|
+
constructor(gantt: Gantt);
|
|
13
|
+
release(): void;
|
|
14
|
+
bindEvent(): void;
|
|
15
|
+
}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { VRender } from "@visactor/vtable";
|
|
2
|
+
|
|
3
|
+
import { EventHandler } from "../event/EventHandler";
|
|
4
|
+
|
|
5
|
+
import { handleWhell } from "../event/scroll";
|
|
6
|
+
|
|
7
|
+
import { InteractionState } from "../ts-types";
|
|
8
|
+
|
|
9
|
+
import { isValid } from "@visactor/vutils";
|
|
10
|
+
|
|
11
|
+
import { getPixelRatio } from "../tools/pixel-ratio";
|
|
12
|
+
|
|
13
|
+
export class EventManager {
|
|
14
|
+
constructor(gantt) {
|
|
15
|
+
this.isDown = !1, this.isDraging = !1, this._gantt = gantt, this._eventHandler = new EventHandler,
|
|
16
|
+
this.bindEvent();
|
|
17
|
+
}
|
|
18
|
+
release() {
|
|
19
|
+
this._eventHandler.release();
|
|
20
|
+
}
|
|
21
|
+
bindEvent() {
|
|
22
|
+
bindTableGroupListener(this), bindContainerDomListener(this);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
function bindTableGroupListener(event) {
|
|
27
|
+
const scene = event._gantt.scenegraph, gantt = event._gantt, stateManager = gantt.stateManager;
|
|
28
|
+
scene.tableGroup.addEventListener("pointerdown", (e => {
|
|
29
|
+
if (0 !== e.button) return;
|
|
30
|
+
const taskBarTarget = e.detailPath.find((pathNode => "task-bar" === pathNode.name));
|
|
31
|
+
taskBarTarget && ("task-bar-hover-shadow-left-icon" === e.target.name ? (stateManager.startResizeTaskBar(taskBarTarget, e.nativeEvent.x, e.nativeEvent.y, "left"),
|
|
32
|
+
stateManager.updateInteractionState(InteractionState.grabing)) : "task-bar-hover-shadow-right-icon" === e.target.name ? (stateManager.startResizeTaskBar(taskBarTarget, e.nativeEvent.x, e.nativeEvent.y, "right"),
|
|
33
|
+
stateManager.updateInteractionState(InteractionState.grabing)) : gantt.parsedOptions.taskBarMoveable && (stateManager.startMoveTaskBar(taskBarTarget, e.nativeEvent.x, e.nativeEvent.y),
|
|
34
|
+
stateManager.updateInteractionState(InteractionState.grabing)));
|
|
35
|
+
})), scene.tableGroup.addEventListener("pointermove", (e => {
|
|
36
|
+
if (stateManager.interactionState === InteractionState.default) {
|
|
37
|
+
e.detailPath.find((pathNode => "task-bar" === pathNode.name)) ? stateManager.showTaskBarHover(e) : stateManager.hideTaskBarHover();
|
|
38
|
+
}
|
|
39
|
+
})), scene.tableGroup.addEventListener("pointerenter", (e => {
|
|
40
|
+
(gantt.parsedOptions.scrollStyle.horizontalVisible && "focus" === gantt.parsedOptions.scrollStyle.horizontalVisible || !gantt.parsedOptions.scrollStyle.horizontalVisible && "focus" === gantt.parsedOptions.scrollStyle.visible) && scene.scrollbarComponent.showHorizontalScrollBar(),
|
|
41
|
+
(gantt.parsedOptions.scrollStyle.verticalVisible && "focus" === gantt.parsedOptions.scrollStyle.verticalVisible || !gantt.parsedOptions.scrollStyle.verticalVisible && "focus" === gantt.parsedOptions.scrollStyle.visible) && scene.scrollbarComponent.showVerticalScrollBar();
|
|
42
|
+
})), scene.tableGroup.addEventListener("pointerleave", (e => {
|
|
43
|
+
(gantt.parsedOptions.scrollStyle.horizontalVisible && "focus" === gantt.parsedOptions.scrollStyle.horizontalVisible || !gantt.parsedOptions.scrollStyle.horizontalVisible && "focus" === gantt.parsedOptions.scrollStyle.visible) && scene.scrollbarComponent.hideHorizontalScrollBar(),
|
|
44
|
+
(gantt.parsedOptions.scrollStyle.verticalVisible && "focus" === gantt.parsedOptions.scrollStyle.verticalVisible || !gantt.parsedOptions.scrollStyle.verticalVisible && "focus" === gantt.parsedOptions.scrollStyle.visible) && scene.scrollbarComponent.hideVerticalScrollBar();
|
|
45
|
+
}));
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
function bindContainerDomListener(eventManager) {
|
|
49
|
+
const gantt = eventManager._gantt, stateManager = (eventManager._gantt.scenegraph,
|
|
50
|
+
gantt.stateManager), handler = eventManager._eventHandler;
|
|
51
|
+
handler.on(gantt.getElement(), "wheel", (e => {
|
|
52
|
+
handleWhell(e, stateManager, eventManager._gantt);
|
|
53
|
+
})), handler.on(gantt.getContainer(), "resize", (e => {
|
|
54
|
+
0 === e.width && 0 === e.height || (isValid(gantt.options.pixelRatio) || gantt.setPixelRatio(getPixelRatio()),
|
|
55
|
+
e.windowSizeNotChange || gantt._resize());
|
|
56
|
+
})), handler.on(gantt.resizeLine, "mousedown", (e => {
|
|
57
|
+
stateManager.updateInteractionState(InteractionState.grabing), stateManager.startResizeTableWidth(e);
|
|
58
|
+
})), VRender.vglobal.addEventListener("mousedown", (e => {
|
|
59
|
+
gantt.eventManager.lastDragPointerXYOnWindow = {
|
|
60
|
+
x: e.x,
|
|
61
|
+
y: e.y
|
|
62
|
+
};
|
|
63
|
+
})), VRender.vglobal.addEventListener("mousemove", (e => {
|
|
64
|
+
var _a, _b, _c, _d;
|
|
65
|
+
if (stateManager.interactionState === InteractionState.grabing) {
|
|
66
|
+
const lastX = null !== (_b = null === (_a = gantt.eventManager.lastDragPointerXYOnWindow) || void 0 === _a ? void 0 : _a.x) && void 0 !== _b ? _b : e.x, lastY = null !== (_d = null === (_c = gantt.eventManager.lastDragPointerXYOnWindow) || void 0 === _c ? void 0 : _c.y) && void 0 !== _d ? _d : e.y;
|
|
67
|
+
Math.abs(lastX - e.x) + Math.abs(lastY - e.y) >= 1 && (stateManager.isResizingTableWidth() ? stateManager.dealResizeTableWidth(e) : stateManager.isMoveingTaskBar() ? stateManager.dealTaskBarMove(e) : stateManager.isResizingTaskBar() && stateManager.dealTaskBarResize(e),
|
|
68
|
+
gantt.eventManager.lastDragPointerXYOnWindow = {
|
|
69
|
+
x: e.x,
|
|
70
|
+
y: e.y
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
})), VRender.vglobal.addEventListener("mouseup", (e => {
|
|
74
|
+
"grabing" === stateManager.interactionState && (stateManager.updateInteractionState(InteractionState.default),
|
|
75
|
+
stateManager.isResizingTableWidth() ? stateManager.endResizeTableWidth() : stateManager.isMoveingTaskBar() ? stateManager.endMoveTaskBar(e.x) : stateManager.isResizingTaskBar() && stateManager.endResizeTaskBar(e.x));
|
|
76
|
+
}));
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=event-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/event/event-manager.ts"],"names":[],"mappings":"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","file":"event-manager.js","sourcesContent":["import { VRender } from '@visactor/vtable';\nimport type { Gantt } from '../Gantt';\nimport { EventHandler } from '../event/EventHandler';\nimport { handleWhell } from '../event/scroll';\nimport { throttle } from '../tools/util';\nimport { InteractionState } from '../ts-types';\nimport { isValid } from '@visactor/vutils';\nimport { getPixelRatio } from '../tools/pixel-ratio';\nimport type { GanttTaskBarNode } from '../scenegraph/ganttNode';\n\nexport class EventManager {\n _gantt: Gantt;\n _eventHandler: EventHandler;\n isDown: boolean = false;\n isDraging: boolean = false;\n lastDragPointerXYOnWindow: { x: number; y: number };\n\n // lastDragPointerXYOnResizeLine: { x: number; y: number };\n constructor(gantt: Gantt) {\n this._gantt = gantt;\n this._eventHandler = new EventHandler();\n this.bindEvent();\n }\n release() {\n this._eventHandler.release();\n }\n // 绑定DOM事件\n bindEvent() {\n bindTableGroupListener(this);\n bindContainerDomListener(this);\n // bindScrollBarListener(this);\n }\n}\nfunction bindTableGroupListener(event: EventManager) {\n const scene = event._gantt.scenegraph;\n const gantt = event._gantt;\n const stateManager = gantt.stateManager;\n scene.tableGroup.addEventListener('pointerdown', (e: VRender.FederatedPointerEvent) => {\n if (e.button !== 0) {\n // 只处理左键\n return;\n }\n const taskBarTarget = e.detailPath.find((pathNode: any) => {\n return pathNode.name === 'task-bar'; // || pathNode.name === 'task-bar-hover-shadow';\n }) as any as GanttTaskBarNode;\n if (taskBarTarget) {\n if (e.target.name === 'task-bar-hover-shadow-left-icon') {\n stateManager.startResizeTaskBar(taskBarTarget, (e.nativeEvent as any).x, (e.nativeEvent as any).y, 'left');\n stateManager.updateInteractionState(InteractionState.grabing);\n } else if (e.target.name === 'task-bar-hover-shadow-right-icon') {\n stateManager.startResizeTaskBar(taskBarTarget, (e.nativeEvent as any).x, (e.nativeEvent as any).y, 'right');\n stateManager.updateInteractionState(InteractionState.grabing);\n } else if (gantt.parsedOptions.taskBarMoveable) {\n stateManager.startMoveTaskBar(taskBarTarget, (e.nativeEvent as any).x, (e.nativeEvent as any).y);\n stateManager.updateInteractionState(InteractionState.grabing);\n }\n }\n });\n\n scene.tableGroup.addEventListener('pointermove', (e: VRender.FederatedPointerEvent) => {\n if (stateManager.interactionState === InteractionState.default) {\n const taksIndex = e.detailPath.find((pathNode: any) => {\n return pathNode.name === 'task-bar'; // || pathNode.name === 'task-bar-hover-shadow';\n });\n if (taksIndex) {\n stateManager.showTaskBarHover(e);\n } else {\n stateManager.hideTaskBarHover();\n }\n }\n });\n // scene.stage.addEventListener('pointerup', (e: FederatedPointerEvent) => {});\n\n scene.tableGroup.addEventListener('pointerenter', (e: VRender.FederatedPointerEvent) => {\n if (\n (gantt.parsedOptions.scrollStyle.horizontalVisible &&\n gantt.parsedOptions.scrollStyle.horizontalVisible === 'focus') ||\n (!gantt.parsedOptions.scrollStyle.horizontalVisible && gantt.parsedOptions.scrollStyle.visible === 'focus')\n ) {\n scene.scrollbarComponent.showHorizontalScrollBar();\n }\n if (\n (gantt.parsedOptions.scrollStyle.verticalVisible &&\n gantt.parsedOptions.scrollStyle.verticalVisible === 'focus') ||\n (!gantt.parsedOptions.scrollStyle.verticalVisible && gantt.parsedOptions.scrollStyle.visible === 'focus')\n ) {\n scene.scrollbarComponent.showVerticalScrollBar();\n }\n });\n\n scene.tableGroup.addEventListener('pointerleave', (e: VRender.FederatedPointerEvent) => {\n if (\n (gantt.parsedOptions.scrollStyle.horizontalVisible &&\n gantt.parsedOptions.scrollStyle.horizontalVisible === 'focus') ||\n (!gantt.parsedOptions.scrollStyle.horizontalVisible && gantt.parsedOptions.scrollStyle.visible === 'focus')\n ) {\n scene.scrollbarComponent.hideHorizontalScrollBar();\n }\n if (\n (gantt.parsedOptions.scrollStyle.verticalVisible &&\n gantt.parsedOptions.scrollStyle.verticalVisible === 'focus') ||\n (!gantt.parsedOptions.scrollStyle.verticalVisible && gantt.parsedOptions.scrollStyle.visible === 'focus')\n ) {\n scene.scrollbarComponent.hideVerticalScrollBar();\n }\n });\n}\n\nfunction bindContainerDomListener(eventManager: EventManager) {\n const gantt = eventManager._gantt;\n const scene = eventManager._gantt.scenegraph;\n const stateManager = gantt.stateManager;\n const handler = eventManager._eventHandler;\n handler.on(gantt.getElement(), 'wheel', (e: WheelEvent) => {\n handleWhell(e, stateManager, eventManager._gantt);\n });\n\n handler.on(gantt.getContainer(), 'resize', (e: any) => {\n // if (table.canvasSizeSeted) {\n // return;\n // }\n if (e.width === 0 && e.height === 0) {\n // 临时绕行解决因为display设置为none产生的问题\n return;\n }\n if (!isValid(gantt.options.pixelRatio)) {\n gantt.setPixelRatio(getPixelRatio());\n }\n if (!e.windowSizeNotChange) {\n gantt._resize();\n }\n });\n\n handler.on(gantt.resizeLine, 'mousedown', (e: MouseEvent) => {\n console.log('mousedown resizeLine');\n stateManager.updateInteractionState(InteractionState.grabing);\n stateManager.startResizeTableWidth(e);\n });\n\n VRender.vglobal.addEventListener('mousedown', (e: VRender.FederatedPointerEvent) => {\n gantt.eventManager.lastDragPointerXYOnWindow = { x: e.x, y: e.y };\n });\n VRender.vglobal.addEventListener('mousemove', (e: VRender.FederatedPointerEvent) => {\n if (stateManager.interactionState === InteractionState.grabing) {\n const lastX = gantt.eventManager.lastDragPointerXYOnWindow?.x ?? e.x;\n const lastY = gantt.eventManager.lastDragPointerXYOnWindow?.y ?? e.y;\n if (Math.abs(lastX - e.x) + Math.abs(lastY - e.y) >= 1) {\n if (stateManager.isResizingTableWidth()) {\n stateManager.dealResizeTableWidth(e);\n } else if (stateManager.isMoveingTaskBar()) {\n stateManager.dealTaskBarMove(e);\n } else if (stateManager.isResizingTaskBar()) {\n stateManager.dealTaskBarResize(e);\n }\n gantt.eventManager.lastDragPointerXYOnWindow = { x: e.x, y: e.y };\n }\n }\n });\n VRender.vglobal.addEventListener('mouseup', (e: MouseEvent) => {\n if (stateManager.interactionState === 'grabing') {\n stateManager.updateInteractionState(InteractionState.default);\n if (stateManager.isResizingTableWidth()) {\n stateManager.endResizeTableWidth();\n } else if (stateManager.isMoveingTaskBar()) {\n stateManager.endMoveTaskBar(e.x);\n } else if (stateManager.isResizingTaskBar()) {\n stateManager.endResizeTaskBar(e.x);\n }\n }\n });\n}\n"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { Gantt } from '../Gantt';
|
|
2
|
+
import type { EventManager } from './event-manager';
|
|
3
|
+
import type { StateManager } from '../state/state-manager';
|
|
4
|
+
export declare function handleWhell(event: WheelEvent, state: StateManager, gantt: Gantt, isWheelEvent?: boolean): void;
|
|
5
|
+
export declare function isVerticalScrollable(deltaY: number, state: StateManager): boolean;
|
|
6
|
+
export declare function isHorizontalScrollable(deltaX: number, state: StateManager): boolean;
|
|
7
|
+
export declare class InertiaScroll {
|
|
8
|
+
friction: number;
|
|
9
|
+
lastTime: number;
|
|
10
|
+
speedX: number;
|
|
11
|
+
speedY: number;
|
|
12
|
+
stateManager: StateManager;
|
|
13
|
+
runingId: number;
|
|
14
|
+
scrollHandle: (dx: number, dy: number) => void;
|
|
15
|
+
constructor(stateManager: StateManager);
|
|
16
|
+
setScrollHandle(scrollHandle: (dx: number, dy: number) => void): void;
|
|
17
|
+
startInertia(speedX: number, speedY: number, friction: number): void;
|
|
18
|
+
inertia(): void;
|
|
19
|
+
endInertia(): void;
|
|
20
|
+
isInertiaScrolling(): boolean;
|
|
21
|
+
}
|
|
22
|
+
export declare function bindScrollBarListener(eventManager: EventManager): void;
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { InteractionState } from "../ts-types";
|
|
2
|
+
|
|
3
|
+
import { throttle } from "../tools/util";
|
|
4
|
+
|
|
5
|
+
export function handleWhell(event, state, gantt, isWheelEvent = !0) {
|
|
6
|
+
let {deltaX: deltaX, deltaY: deltaY} = event;
|
|
7
|
+
event.shiftKey && event.deltaY && (deltaX = deltaY, deltaY = 0);
|
|
8
|
+
const [optimizedDeltaX, optimizedDeltaY] = optimizeScrollXY(deltaX, deltaY, {
|
|
9
|
+
horizontal: 1,
|
|
10
|
+
vertical: 1
|
|
11
|
+
});
|
|
12
|
+
optimizedDeltaX && (state.setScrollLeft(state.scroll.horizontalBarPos + optimizedDeltaX),
|
|
13
|
+
gantt.scenegraph.scrollbarComponent.showHorizontalScrollBar(!0)), optimizedDeltaY && (state.setScrollTop(state.scroll.verticalBarPos + optimizedDeltaY),
|
|
14
|
+
gantt.scenegraph.scrollbarComponent.showVerticalScrollBar(!0)), isWheelEvent && state.resetInteractionState(),
|
|
15
|
+
event.cancelable && ("none" === state._gantt.parsedOptions.overscrollBehavior || Math.abs(deltaY) >= Math.abs(deltaX) && 0 !== deltaY && isVerticalScrollable(deltaY, state) || Math.abs(deltaY) <= Math.abs(deltaX) && 0 !== deltaX && isHorizontalScrollable(deltaX, state)) && event.preventDefault();
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
function optimizeScrollXY(x, y, ratio) {
|
|
19
|
+
var _a, _b;
|
|
20
|
+
const angle = Math.abs(x / y), deltaX = angle <= .5 ? 0 : x, deltaY = angle > 2 ? 0 : y;
|
|
21
|
+
return [ Math.ceil(deltaX * (null !== (_a = ratio.horizontal) && void 0 !== _a ? _a : 0)), Math.ceil(deltaY * (null !== (_b = ratio.vertical) && void 0 !== _b ? _b : 0)) ];
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export function isVerticalScrollable(deltaY, state) {
|
|
25
|
+
return 0 != state._gantt.getAllRowsHeight() - state._gantt.scenegraph.height && (!isScrollToTop(deltaY, state) && !isScrollToBottom(deltaY, state));
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export function isHorizontalScrollable(deltaX, state) {
|
|
29
|
+
return 0 != state._gantt.getAllColsWidth() - state._gantt.scenegraph.width && (!isScrollToLeft(deltaX, state) && !isScrollToRight(deltaX, state));
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
function isScrollToTop(deltaY, state) {
|
|
33
|
+
return 0 !== state._gantt.getAllRowsHeight() - state._gantt.scenegraph.height && deltaY <= 0 && state.scroll.verticalBarPos < 1;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
function isScrollToBottom(deltaY, state) {
|
|
37
|
+
const totalHeight = state._gantt.getAllRowsHeight() - state._gantt.scenegraph.height;
|
|
38
|
+
return 0 !== totalHeight && deltaY >= 0 && Math.abs(state.scroll.verticalBarPos - totalHeight) < 1;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
function isScrollToLeft(deltaX, state) {
|
|
42
|
+
return 0 !== state._gantt.getAllColsWidth() - state._gantt.scenegraph.width && deltaX <= 0 && state.scroll.horizontalBarPos < 1;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function isScrollToRight(deltaX, state) {
|
|
46
|
+
const totalWidth = state._gantt.getAllColsWidth() - state._gantt.scenegraph.width;
|
|
47
|
+
return 0 !== totalWidth && deltaX >= 0 && Math.abs(state.scroll.horizontalBarPos - totalWidth) < 1;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
export class InertiaScroll {
|
|
51
|
+
constructor(stateManager) {
|
|
52
|
+
this.stateManager = stateManager;
|
|
53
|
+
}
|
|
54
|
+
setScrollHandle(scrollHandle) {
|
|
55
|
+
this.scrollHandle = scrollHandle;
|
|
56
|
+
}
|
|
57
|
+
startInertia(speedX, speedY, friction) {
|
|
58
|
+
this.lastTime = Date.now(), this.speedX = speedX, this.speedY = speedY, this.friction = friction,
|
|
59
|
+
this.runingId || (this.runingId = requestAnimationFrame(this.inertia.bind(this)));
|
|
60
|
+
}
|
|
61
|
+
inertia() {
|
|
62
|
+
var _a;
|
|
63
|
+
const now = Date.now(), dffTime = now - this.lastTime;
|
|
64
|
+
let stopped = !0;
|
|
65
|
+
const f = Math.pow(this.friction, dffTime / 16), newSpeedX = f * this.speedX, newSpeedY = f * this.speedY;
|
|
66
|
+
let dx = 0, dy = 0;
|
|
67
|
+
Math.abs(newSpeedX) > .05 && (stopped = !1, dx = (this.speedX + newSpeedX) / 2 * dffTime),
|
|
68
|
+
Math.abs(newSpeedY) > .05 && (stopped = !1, dy = (this.speedY + newSpeedY) / 2 * dffTime),
|
|
69
|
+
null === (_a = this.scrollHandle) || void 0 === _a || _a.call(this, dx, dy), stopped ? this.runingId = null : (this.lastTime = now,
|
|
70
|
+
this.speedX = newSpeedX, this.speedY = newSpeedY, this.runingId = requestAnimationFrame(this.inertia.bind(this)));
|
|
71
|
+
}
|
|
72
|
+
endInertia() {
|
|
73
|
+
cancelAnimationFrame(this.runingId), this.runingId = null;
|
|
74
|
+
}
|
|
75
|
+
isInertiaScrolling() {
|
|
76
|
+
return !!this.runingId;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
export function bindScrollBarListener(eventManager) {
|
|
81
|
+
const table = eventManager._gantt, stateManager = table.stateManager, scenegraph = table.scenegraph;
|
|
82
|
+
scenegraph.scrollbarComponent.vScrollBar.addEventListener("pointerover", (e => {
|
|
83
|
+
scenegraph.scrollbarComponent.showVerticalScrollBar();
|
|
84
|
+
})), scenegraph.scrollbarComponent.hScrollBar.addEventListener("pointerover", (e => {
|
|
85
|
+
scenegraph.scrollbarComponent.showHorizontalScrollBar();
|
|
86
|
+
})), scenegraph.scrollbarComponent.vScrollBar.addEventListener("pointerout", (e => {
|
|
87
|
+
stateManager.interactionState !== InteractionState.scrolling && scenegraph.scrollbarComponent.hideVerticalScrollBar();
|
|
88
|
+
})), scenegraph.scrollbarComponent.hScrollBar.addEventListener("pointerout", (e => {
|
|
89
|
+
stateManager.interactionState !== InteractionState.scrolling && scenegraph.scrollbarComponent.hideHorizontalScrollBar();
|
|
90
|
+
})), scenegraph.scrollbarComponent.vScrollBar.addEventListener("pointermove", (e => {
|
|
91
|
+
e.stopPropagation();
|
|
92
|
+
})), scenegraph.scrollbarComponent.vScrollBar.addEventListener("scrollDown", (e => {
|
|
93
|
+
scenegraph._gantt.eventManager.isDown = !0;
|
|
94
|
+
})), scenegraph.scrollbarComponent.vScrollBar.addEventListener("pointerup", (() => {
|
|
95
|
+
scenegraph._gantt.eventManager.isDraging = !1, stateManager.interactionState === InteractionState.scrolling && stateManager.updateInteractionState(InteractionState.default);
|
|
96
|
+
})), scenegraph.scrollbarComponent.vScrollBar.addEventListener("pointerupoutside", (() => {
|
|
97
|
+
stateManager.interactionState === InteractionState.scrolling && stateManager.updateInteractionState(InteractionState.default);
|
|
98
|
+
})), scenegraph.scrollbarComponent.vScrollBar.addEventListener("scrollUp", (e => {
|
|
99
|
+
scenegraph._gantt.eventManager.isDraging = !1;
|
|
100
|
+
})), scenegraph.scrollbarComponent.hScrollBar.addEventListener("pointermove", (e => {
|
|
101
|
+
e.stopPropagation();
|
|
102
|
+
})), scenegraph.scrollbarComponent.hScrollBar.addEventListener("pointerdown", (e => {
|
|
103
|
+
e.stopPropagation();
|
|
104
|
+
})), scenegraph.scrollbarComponent.hScrollBar.addEventListener("scrollDown", (e => {
|
|
105
|
+
scenegraph._gantt.eventManager.isDown = !0, stateManager.interactionState !== InteractionState.scrolling && stateManager.updateInteractionState(InteractionState.scrolling);
|
|
106
|
+
})), scenegraph.scrollbarComponent.hScrollBar.addEventListener("pointerup", (() => {
|
|
107
|
+
stateManager.interactionState === InteractionState.scrolling && stateManager.updateInteractionState(InteractionState.default);
|
|
108
|
+
})), scenegraph.scrollbarComponent.hScrollBar.addEventListener("pointerupoutside", (() => {
|
|
109
|
+
stateManager.interactionState === InteractionState.scrolling && stateManager.updateInteractionState(InteractionState.default);
|
|
110
|
+
})), scenegraph.scrollbarComponent.hScrollBar.addEventListener("scrollUp", (e => {
|
|
111
|
+
scenegraph._gantt.eventManager.isDraging = !1;
|
|
112
|
+
}));
|
|
113
|
+
const throttleVerticalWheel = throttle(stateManager.updateVerticalScrollBar, 20), throttleHorizontalWheel = throttle(stateManager.updateHorizontalScrollBar, 20);
|
|
114
|
+
scenegraph.scrollbarComponent.vScrollBar.addEventListener("scrollDrag", (e => {
|
|
115
|
+
scenegraph._gantt.eventManager.isDown && (scenegraph._gantt.eventManager.isDraging = !0),
|
|
116
|
+
stateManager.interactionState !== InteractionState.scrolling && stateManager.updateInteractionState(InteractionState.scrolling);
|
|
117
|
+
const ratio = e.detail.value[0] / (1 - e.detail.value[1] + e.detail.value[0]);
|
|
118
|
+
throttleVerticalWheel(ratio, e);
|
|
119
|
+
})), scenegraph.scrollbarComponent.hScrollBar.addEventListener("scrollDrag", (e => {
|
|
120
|
+
scenegraph._gantt.eventManager.isDown && (scenegraph._gantt.eventManager.isDraging = !0),
|
|
121
|
+
stateManager.fastScrolling = !0, stateManager.interactionState !== InteractionState.scrolling && stateManager.updateInteractionState(InteractionState.scrolling);
|
|
122
|
+
const ratio = e.detail.value[0] / (1 - e.detail.value[1] + e.detail.value[0]);
|
|
123
|
+
throttleHorizontalWheel(ratio);
|
|
124
|
+
}));
|
|
125
|
+
}
|
|
126
|
+
//# sourceMappingURL=scroll.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/event/scroll.ts"],"names":[],"mappings":"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","file":"scroll.js","sourcesContent":["import type { VRender } from '@visactor/vtable';\nimport type { Gantt } from '../Gantt';\nimport { InteractionState } from '../ts-types';\nimport type { EventManager } from './event-manager';\nimport { throttle } from '../tools/util';\nimport type { StateManager } from '../state/state-manager';\n/**\n *\n * @param event\n * @param state\n * @param isWheelEvent 是否是由鼠标或者触摸板原生滚动事件触发进入?\n */\nexport function handleWhell(event: WheelEvent, state: StateManager, gantt: Gantt, isWheelEvent: boolean = true) {\n let { deltaX, deltaY } = event;\n console.log('deltaX deltaY', deltaX, deltaY);\n // 如果按住了shift 则进行横向滚动 纵向不滚动\n if (event.shiftKey && event.deltaY) {\n //mac电脑按住shift 鼠标滚动deltaX和deltaY是自动互换的,所以此逻辑只针对windows电脑有效及mac触摸板有效\n deltaX = deltaY;\n deltaY = 0;\n }\n const [optimizedDeltaX, optimizedDeltaY] = optimizeScrollXY(deltaX, deltaY, { horizontal: 1, vertical: 1 });\n if (optimizedDeltaX || optimizedDeltaY) {\n // if (state.interactionState !== InteractionState.scrolling) {\n // state.updateInteractionState(InteractionState.scrolling);\n // }\n }\n\n if (optimizedDeltaX) {\n state.setScrollLeft(state.scroll.horizontalBarPos + optimizedDeltaX);\n gantt.scenegraph.scrollbarComponent.showHorizontalScrollBar(true);\n }\n if (optimizedDeltaY) {\n state.setScrollTop(state.scroll.verticalBarPos + optimizedDeltaY);\n gantt.scenegraph.scrollbarComponent.showVerticalScrollBar(true);\n }\n isWheelEvent && state.resetInteractionState();\n if (\n event.cancelable &&\n (state._gantt.parsedOptions.overscrollBehavior === 'none' ||\n (Math.abs(deltaY) >= Math.abs(deltaX) && deltaY !== 0 && isVerticalScrollable(deltaY, state)) ||\n (Math.abs(deltaY) <= Math.abs(deltaX) && deltaX !== 0 && isHorizontalScrollable(deltaX, state)))\n ) {\n event.preventDefault();\n }\n}\n\ninterface ScrollSpeedRatio {\n horizontal?: number;\n vertical?: number;\n}\n\n/**\n * 优化滚动方向,对于小角度的滚动,固定为一个方向\n * @param x\n * @param y\n * @param ratio\n */\nfunction optimizeScrollXY(x: number, y: number, ratio: ScrollSpeedRatio): [number, number] {\n const ANGLE = 2; // 调参 根据斜率来调整xy方向的划分\n const angle = Math.abs(x / y);\n\n // 经过滚动优化之后的 x, y\n const deltaX = angle <= 1 / ANGLE ? 0 : x;\n const deltaY = angle > ANGLE ? 0 : y;\n\n return [Math.ceil(deltaX * (ratio.horizontal ?? 0)), Math.ceil(deltaY * (ratio.vertical ?? 0))];\n}\n\nexport function isVerticalScrollable(deltaY: number, state: StateManager) {\n const totalHeight = state._gantt.getAllRowsHeight() - state._gantt.scenegraph.height;\n if (totalHeight === 0) {\n return false;\n }\n return !isScrollToTop(deltaY, state) && !isScrollToBottom(deltaY, state);\n}\n\nexport function isHorizontalScrollable(deltaX: number, state: StateManager) {\n const totalWidth = state._gantt.getAllColsWidth() - state._gantt.scenegraph.width;\n if (totalWidth === 0) {\n return false;\n }\n return !isScrollToLeft(deltaX, state) && !isScrollToRight(deltaX, state);\n}\n\nfunction isScrollToTop(deltaY: number, state: StateManager) {\n const totalHeight = state._gantt.getAllRowsHeight() - state._gantt.scenegraph.height;\n return totalHeight !== 0 && deltaY <= 0 && state.scroll.verticalBarPos < 1;\n}\n\nfunction isScrollToBottom(deltaY: number, state: StateManager) {\n const totalHeight = state._gantt.getAllRowsHeight() - state._gantt.scenegraph.height;\n return totalHeight !== 0 && deltaY >= 0 && Math.abs(state.scroll.verticalBarPos - totalHeight) < 1;\n}\n\nfunction isScrollToLeft(deltaX: number, state: StateManager) {\n const totalWidth = state._gantt.getAllColsWidth() - state._gantt.scenegraph.width;\n return totalWidth !== 0 && deltaX <= 0 && state.scroll.horizontalBarPos < 1;\n}\n\nfunction isScrollToRight(deltaX: number, state: StateManager) {\n const totalWidth = state._gantt.getAllColsWidth() - state._gantt.scenegraph.width;\n return totalWidth !== 0 && deltaX >= 0 && Math.abs(state.scroll.horizontalBarPos - totalWidth) < 1;\n}\n\nexport class InertiaScroll {\n friction: number;\n lastTime: number;\n speedX: number;\n speedY: number;\n stateManager: StateManager;\n runingId: number;\n scrollHandle: (dx: number, dy: number) => void;\n constructor(stateManager: StateManager) {\n this.stateManager = stateManager;\n }\n setScrollHandle(scrollHandle: (dx: number, dy: number) => void) {\n this.scrollHandle = scrollHandle;\n }\n\n startInertia(speedX: number, speedY: number, friction: number) {\n this.lastTime = Date.now();\n this.speedX = speedX;\n this.speedY = speedY;\n this.friction = friction;\n if (!this.runingId) {\n this.runingId = requestAnimationFrame(this.inertia.bind(this));\n }\n }\n inertia() {\n const now = Date.now();\n const dffTime = now - this.lastTime;\n let stopped = true;\n const f = Math.pow(this.friction, dffTime / 16);\n const newSpeedX = f * this.speedX;\n const newSpeedY = f * this.speedY;\n let dx = 0;\n let dy = 0;\n if (Math.abs(newSpeedX) > 0.05) {\n stopped = false;\n dx = ((this.speedX + newSpeedX) / 2) * dffTime;\n }\n if (Math.abs(newSpeedY) > 0.05) {\n stopped = false;\n dy = ((this.speedY + newSpeedY) / 2) * dffTime;\n }\n this.scrollHandle?.(dx, dy);\n if (stopped) {\n this.runingId = null;\n return;\n }\n this.lastTime = now;\n this.speedX = newSpeedX;\n this.speedY = newSpeedY;\n\n this.runingId = requestAnimationFrame(this.inertia.bind(this));\n }\n endInertia() {\n cancelAnimationFrame(this.runingId);\n this.runingId = null;\n }\n isInertiaScrolling() {\n return !!this.runingId;\n }\n}\n\nexport function bindScrollBarListener(eventManager: EventManager) {\n const table = eventManager._gantt;\n const stateManager = table.stateManager;\n const scenegraph = table.scenegraph;\n\n // 监听滚动条组件pointover事件\n scenegraph.scrollbarComponent.vScrollBar.addEventListener('pointerover', (e: any) => {\n scenegraph.scrollbarComponent.showVerticalScrollBar();\n });\n scenegraph.scrollbarComponent.hScrollBar.addEventListener('pointerover', (e: any) => {\n scenegraph.scrollbarComponent.showHorizontalScrollBar();\n });\n scenegraph.scrollbarComponent.vScrollBar.addEventListener('pointerout', (e: any) => {\n if (stateManager.interactionState === InteractionState.scrolling) {\n return;\n }\n scenegraph.scrollbarComponent.hideVerticalScrollBar();\n });\n scenegraph.scrollbarComponent.hScrollBar.addEventListener('pointerout', (e: any) => {\n if (stateManager.interactionState === InteractionState.scrolling) {\n return;\n }\n scenegraph.scrollbarComponent.hideHorizontalScrollBar();\n });\n scenegraph.scrollbarComponent.vScrollBar.addEventListener('pointermove', (e: VRender.FederatedPointerEvent) => {\n // scenegraph._gantt.stateManager.updateCursor('default');\n e.stopPropagation(); //防止冒泡到stage上 检测到挨着列间隔线判断成可拖拽\n });\n // scenegraph.scrollbarComponent.vScrollBar.addEventListener('pointerdown', (e: VRender.FederatedPointerEvent) => {\n // e.stopPropagation(); //防止冒泡到stage上 检测到挨着列间隔线判断成拖拽状态\n // if ((scenegraph._gantt as any).hasListeners(TABLE_EVENT_TYPE.MOUSEDOWN_TABLE)) {\n // scenegraph._gantt.fireListeners(TABLE_EVENT_TYPE.MOUSEDOWN_TABLE, {\n // event: e.nativeEvent\n // });\n // }\n // });\n scenegraph.scrollbarComponent.vScrollBar.addEventListener('scrollDown', (e: VRender.FederatedPointerEvent) => {\n // scenegraph._gantt.eventManager.LastBodyPointerXY = { x: e.x, y: e.y };\n scenegraph._gantt.eventManager.isDown = true;\n\n // if ((scenegraph._gantt as any).hasListeners(TABLE_EVENT_TYPE.MOUSEDOWN_TABLE)) {\n // scenegraph._gantt.fireListeners(TABLE_EVENT_TYPE.MOUSEDOWN_TABLE, {\n // event: e.nativeEvent\n // });\n // }\n });\n scenegraph.scrollbarComponent.vScrollBar.addEventListener('pointerup', () => {\n // stateManager.fastScrolling = false;\n scenegraph._gantt.eventManager.isDraging = false;\n if (stateManager.interactionState === InteractionState.scrolling) {\n stateManager.updateInteractionState(InteractionState.default);\n }\n });\n scenegraph.scrollbarComponent.vScrollBar.addEventListener('pointerupoutside', () => {\n // stateManager.fastScrolling = false;\n if (stateManager.interactionState === InteractionState.scrolling) {\n stateManager.updateInteractionState(InteractionState.default);\n }\n });\n scenegraph.scrollbarComponent.vScrollBar.addEventListener('scrollUp', (e: VRender.FederatedPointerEvent) => {\n scenegraph._gantt.eventManager.isDraging = false;\n });\n\n scenegraph.scrollbarComponent.hScrollBar.addEventListener('pointermove', (e: VRender.FederatedPointerEvent) => {\n // scenegraph._gantt.stateManager.updateCursor('default');\n e.stopPropagation(); //防止冒泡到stage上 检测到挨着列间隔线判断成可拖拽\n });\n scenegraph.scrollbarComponent.hScrollBar.addEventListener('pointerdown', (e: VRender.FederatedPointerEvent) => {\n e.stopPropagation(); //防止冒泡到stage上 检测到挨着列间隔线判断成拖拽状态\n // if ((scenegraph._gantt as any).hasListeners(TABLE_EVENT_TYPE.MOUSEDOWN_TABLE)) {\n // scenegraph._gantt.fireListeners(TABLE_EVENT_TYPE.MOUSEDOWN_TABLE, {\n // event: e.nativeEvent\n // });\n // }\n });\n scenegraph.scrollbarComponent.hScrollBar.addEventListener('scrollDown', (e: VRender.FederatedPointerEvent) => {\n // scenegraph._gantt.eventManager.LastBodyPointerXY = { x: e.x, y: e.y };\n scenegraph._gantt.eventManager.isDown = true;\n if (stateManager.interactionState !== InteractionState.scrolling) {\n stateManager.updateInteractionState(InteractionState.scrolling);\n }\n\n // if ((scenegraph._gantt as any).hasListeners(TABLE_EVENT_TYPE.MOUSEDOWN_TABLE)) {\n // scenegraph._gantt.fireListeners(TABLE_EVENT_TYPE.MOUSEDOWN_TABLE, {\n // event: e.nativeEvent\n // });\n // }\n });\n scenegraph.scrollbarComponent.hScrollBar.addEventListener('pointerup', () => {\n // stateManager.fastScrolling = false;\n // scenegraph._gantt.eventManager.isDraging = false;\n if (stateManager.interactionState === InteractionState.scrolling) {\n stateManager.updateInteractionState(InteractionState.default);\n }\n });\n scenegraph.scrollbarComponent.hScrollBar.addEventListener('pointerupoutside', () => {\n // stateManager.fastScrolling = false;\n if (stateManager.interactionState === InteractionState.scrolling) {\n stateManager.updateInteractionState(InteractionState.default);\n }\n });\n scenegraph.scrollbarComponent.hScrollBar.addEventListener('scrollUp', (e: VRender.FederatedPointerEvent) => {\n scenegraph._gantt.eventManager.isDraging = false;\n });\n const throttleVerticalWheel = throttle(stateManager.updateVerticalScrollBar, 20);\n const throttleHorizontalWheel = throttle(stateManager.updateHorizontalScrollBar, 20);\n\n // 监听滚动条组件scroll事件\n scenegraph.scrollbarComponent.vScrollBar.addEventListener('scrollDrag', (e: any) => {\n if (scenegraph._gantt.eventManager.isDown) {\n scenegraph._gantt.eventManager.isDraging = true;\n }\n // stateManager.fastScrolling = true;\n if (stateManager.interactionState !== InteractionState.scrolling) {\n stateManager.updateInteractionState(InteractionState.scrolling);\n }\n const ratio = e.detail.value[0] / (1 - e.detail.value[1] + e.detail.value[0]);\n throttleVerticalWheel(ratio, e);\n });\n\n scenegraph.scrollbarComponent.hScrollBar.addEventListener('scrollDrag', (e: any) => {\n if (scenegraph._gantt.eventManager.isDown) {\n scenegraph._gantt.eventManager.isDraging = true;\n }\n stateManager.fastScrolling = true;\n if (stateManager.interactionState !== InteractionState.scrolling) {\n stateManager.updateInteractionState(InteractionState.scrolling);\n }\n // stateManager._gantt.scenegraph.proxy.isSkipProgress = true;\n const ratio = e.detail.value[0] / (1 - e.detail.value[1] + e.detail.value[0]);\n throttleHorizontalWheel(ratio);\n });\n}\n"]}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { Gantt } from './Gantt';
|
|
2
|
+
import type { IMarkLine, IScrollStyle, ITimelineDateInfo, ITimelineScale } from './ts-types';
|
|
3
|
+
declare const isNode: boolean;
|
|
4
|
+
export declare const DayTimes: number;
|
|
5
|
+
export declare function getTaskIndexByY(y: number, gantt: Gantt): number;
|
|
6
|
+
export declare function generateMarkLine(markLine?: boolean | IMarkLine | IMarkLine[]): {
|
|
7
|
+
date: string;
|
|
8
|
+
style: {
|
|
9
|
+
lineColor: string;
|
|
10
|
+
lineWidth: number;
|
|
11
|
+
lineDash: number[];
|
|
12
|
+
};
|
|
13
|
+
}[] | {
|
|
14
|
+
date: string;
|
|
15
|
+
style: {
|
|
16
|
+
lineColor: string;
|
|
17
|
+
lineWidth: number;
|
|
18
|
+
};
|
|
19
|
+
}[];
|
|
20
|
+
export declare function getHorizontalScrollBarSize(scrollStyle?: IScrollStyle): number;
|
|
21
|
+
export declare function getVerticalScrollBarSize(scrollStyle?: IScrollStyle): number;
|
|
22
|
+
export { isNode };
|
|
23
|
+
export declare function initOptions(gantt: Gantt): void;
|
|
24
|
+
export declare function generateTimeLineDate(currentDate: Date, endDate: Date, scale: ITimelineScale): ITimelineDateInfo[];
|
|
25
|
+
export declare function getTextPos(padding: number[], textAlign: CanvasTextAlign, textBaseline: CanvasTextBaseline, width: number, height: number): {
|
|
26
|
+
x: number;
|
|
27
|
+
y: number;
|
|
28
|
+
};
|