blob: 0aeda918a994231d60556adbf65df65fedb52b47 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
type MouseHandler = (evt: MouseEvent) => void;
type MoveHandler = (evt: MouseEvent, dx: number, dy: number) => void;
type CreateMoveHandler = (evt: MouseEvent) => MoveHandler;
type Dragger = {
initX: number,
initY: number,
moveHandler: MoveHandler;
}
const draggers: Dragger[] = [];
export function mouseDownHandler(
createMoveHandlerCb: CreateMoveHandler
): MouseHandler {
return evt => {
draggers.push({
initX: evt.screenX,
initY: evt.screenY,
moveHandler: createMoveHandlerCb(evt)
});
};
}
document.addEventListener('mousemove', evt => {
for (const dragger of draggers) {
const dx = evt.screenX - dragger.initX;
const dy = evt.screenY - dragger.initY;
dragger.moveHandler(evt, dx, dy);
}
});
document.addEventListener('mouseup', () => {
draggers.splice(0);
});
|