aboutsummaryrefslogtreecommitdiff
path: root/src_js/dragger.ts
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);
});