@plait/core 0.77.3 → 0.78.0
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/fesm2022/plait-core.mjs.map +1 -1
- package/package.json +1 -3
- package/esm2022/constants/cursor.mjs +0 -13
- package/esm2022/constants/index.mjs +0 -20
- package/esm2022/constants/keycodes.mjs +0 -127
- package/esm2022/constants/selection.mjs +0 -6
- package/esm2022/constants/zoom.mjs +0 -4
- package/esm2022/context.mjs +0 -23
- package/esm2022/core/element/context-change.mjs +0 -13
- package/esm2022/core/element/context.mjs +0 -2
- package/esm2022/core/element/element-flavour.mjs +0 -140
- package/esm2022/core/element/element-ref.mjs +0 -2
- package/esm2022/core/list-render.mjs +0 -217
- package/esm2022/differs/default_iterable_differ.mjs +0 -614
- package/esm2022/differs/iterable_differs.mjs +0 -9
- package/esm2022/interfaces/board.mjs +0 -108
- package/esm2022/interfaces/custom-types.mjs +0 -5
- package/esm2022/interfaces/direction.mjs +0 -8
- package/esm2022/interfaces/element.mjs +0 -43
- package/esm2022/interfaces/group.mjs +0 -6
- package/esm2022/interfaces/history.mjs +0 -5
- package/esm2022/interfaces/index.mjs +0 -19
- package/esm2022/interfaces/node.mjs +0 -57
- package/esm2022/interfaces/operation.mjs +0 -96
- package/esm2022/interfaces/path-ref.mjs +0 -15
- package/esm2022/interfaces/path.mjs +0 -183
- package/esm2022/interfaces/plugin.mjs +0 -6
- package/esm2022/interfaces/point.mjs +0 -27
- package/esm2022/interfaces/pointer.mjs +0 -6
- package/esm2022/interfaces/rectangle-client.mjs +0 -171
- package/esm2022/interfaces/selection.mjs +0 -13
- package/esm2022/interfaces/svg-arc-command.mjs +0 -2
- package/esm2022/interfaces/theme.mjs +0 -49
- package/esm2022/interfaces/viewport.mjs +0 -7
- package/esm2022/plait-core.mjs +0 -5
- package/esm2022/plugins/create-board.mjs +0 -122
- package/esm2022/plugins/index.mjs +0 -11
- package/esm2022/plugins/with-board.mjs +0 -20
- package/esm2022/plugins/with-hand.mjs +0 -113
- package/esm2022/plugins/with-history.mjs +0 -91
- package/esm2022/plugins/with-hotkey.mjs +0 -96
- package/esm2022/plugins/with-i18n.mjs +0 -13
- package/esm2022/plugins/with-moving.mjs +0 -282
- package/esm2022/plugins/with-options.mjs +0 -13
- package/esm2022/plugins/with-related-fragment.mjs +0 -23
- package/esm2022/plugins/with-selection.mjs +0 -230
- package/esm2022/public-api.mjs +0 -16
- package/esm2022/testing/core/create-board.mjs +0 -15
- package/esm2022/testing/core/fake-weak-map.mjs +0 -18
- package/esm2022/testing/core/index.mjs +0 -3
- package/esm2022/testing/fake-events/event-objects.mjs +0 -131
- package/esm2022/testing/fake-events/index.mjs +0 -2
- package/esm2022/testing/index.mjs +0 -3
- package/esm2022/testing/test-element.mjs +0 -9
- package/esm2022/transforms/board.mjs +0 -137
- package/esm2022/transforms/element.mjs +0 -22
- package/esm2022/transforms/general.mjs +0 -146
- package/esm2022/transforms/group.mjs +0 -64
- package/esm2022/transforms/index.mjs +0 -17
- package/esm2022/transforms/node.mjs +0 -37
- package/esm2022/transforms/selection.mjs +0 -26
- package/esm2022/transforms/theme.mjs +0 -8
- package/esm2022/transforms/viewport.mjs +0 -8
- package/esm2022/transforms/z-index.mjs +0 -20
- package/esm2022/utils/angle.mjs +0 -164
- package/esm2022/utils/board.mjs +0 -18
- package/esm2022/utils/clipboard/clipboard.mjs +0 -40
- package/esm2022/utils/clipboard/common.mjs +0 -82
- package/esm2022/utils/clipboard/data-transfer.mjs +0 -33
- package/esm2022/utils/clipboard/index.mjs +0 -3
- package/esm2022/utils/clipboard/navigator-clipboard.mjs +0 -71
- package/esm2022/utils/clipboard/types.mjs +0 -13
- package/esm2022/utils/common.mjs +0 -79
- package/esm2022/utils/debug.mjs +0 -91
- package/esm2022/utils/dnd.mjs +0 -8
- package/esm2022/utils/dom/common.mjs +0 -75
- package/esm2022/utils/dom/environment.mjs +0 -2
- package/esm2022/utils/dom/foreign.mjs +0 -26
- package/esm2022/utils/dom/index.mjs +0 -4
- package/esm2022/utils/drawing/arrow.mjs +0 -23
- package/esm2022/utils/drawing/circle.mjs +0 -4
- package/esm2022/utils/drawing/line.mjs +0 -47
- package/esm2022/utils/drawing/rectangle.mjs +0 -36
- package/esm2022/utils/element.mjs +0 -90
- package/esm2022/utils/environment.mjs +0 -14
- package/esm2022/utils/fragment.mjs +0 -27
- package/esm2022/utils/group.mjs +0 -239
- package/esm2022/utils/helper.mjs +0 -68
- package/esm2022/utils/history.mjs +0 -96
- package/esm2022/utils/hotkeys.mjs +0 -109
- package/esm2022/utils/id-creator.mjs +0 -11
- package/esm2022/utils/index.mjs +0 -35
- package/esm2022/utils/iterable.mjs +0 -32
- package/esm2022/utils/math.mjs +0 -480
- package/esm2022/utils/mobile.mjs +0 -6
- package/esm2022/utils/moving-element.mjs +0 -17
- package/esm2022/utils/pointer.mjs +0 -13
- package/esm2022/utils/position.mjs +0 -9
- package/esm2022/utils/selected-element.mjs +0 -145
- package/esm2022/utils/selection.mjs +0 -151
- package/esm2022/utils/snap/snap-moving.mjs +0 -199
- package/esm2022/utils/snap/snap.mjs +0 -211
- package/esm2022/utils/to-image.mjs +0 -204
- package/esm2022/utils/to-point.mjs +0 -74
- package/esm2022/utils/tree.mjs +0 -22
- package/esm2022/utils/viewport.mjs +0 -227
- package/esm2022/utils/weak-maps.mjs +0 -27
- package/esm2022/utils/z-index.mjs +0 -166
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
import { PlaitPointerType } from '../interfaces/pointer';
|
|
2
|
-
import { Transforms } from '../transforms';
|
|
3
|
-
import { FLUSHING, PATH_REFS } from '../utils/weak-maps';
|
|
4
|
-
import { PathRef } from '../interfaces/path-ref';
|
|
5
|
-
import { ThemeColorMode } from '../interfaces/theme';
|
|
6
|
-
import { CoreTransforms } from '../transforms/element';
|
|
7
|
-
import { drawSelectionRectangleG } from '../utils';
|
|
8
|
-
export function createBoard(children, options) {
|
|
9
|
-
const board = {
|
|
10
|
-
viewport: {
|
|
11
|
-
zoom: 1
|
|
12
|
-
},
|
|
13
|
-
children,
|
|
14
|
-
theme: { themeColorMode: ThemeColorMode.default },
|
|
15
|
-
operations: [],
|
|
16
|
-
history: {
|
|
17
|
-
redos: [],
|
|
18
|
-
undos: []
|
|
19
|
-
},
|
|
20
|
-
selection: null,
|
|
21
|
-
options: options || {
|
|
22
|
-
readonly: false,
|
|
23
|
-
hideScrollbar: false,
|
|
24
|
-
disabledScrollOnNonFocus: false
|
|
25
|
-
},
|
|
26
|
-
pointer: options?.readonly ? PlaitPointerType.hand : PlaitPointerType.selection,
|
|
27
|
-
undo: () => { },
|
|
28
|
-
redo: () => { },
|
|
29
|
-
apply: (operation) => {
|
|
30
|
-
for (const ref of board.pathRefs()) {
|
|
31
|
-
PathRef.transform(ref, operation);
|
|
32
|
-
}
|
|
33
|
-
board.operations.push(operation);
|
|
34
|
-
Transforms.transform(board, operation);
|
|
35
|
-
if (!FLUSHING.get(board)) {
|
|
36
|
-
FLUSHING.set(board, true);
|
|
37
|
-
Promise.resolve().then(() => {
|
|
38
|
-
FLUSHING.set(board, false);
|
|
39
|
-
board.onChange();
|
|
40
|
-
board.afterChange();
|
|
41
|
-
board.operations = [];
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
},
|
|
45
|
-
pathRef: (path, options) => {
|
|
46
|
-
const affinity = options?.affinity || 'forward';
|
|
47
|
-
const ref = {
|
|
48
|
-
current: path,
|
|
49
|
-
affinity,
|
|
50
|
-
unref() {
|
|
51
|
-
const { current } = ref;
|
|
52
|
-
const pathRefs = board.pathRefs();
|
|
53
|
-
pathRefs.delete(ref);
|
|
54
|
-
ref.current = null;
|
|
55
|
-
return current;
|
|
56
|
-
}
|
|
57
|
-
};
|
|
58
|
-
const refs = board.pathRefs();
|
|
59
|
-
refs.add(ref);
|
|
60
|
-
return ref;
|
|
61
|
-
},
|
|
62
|
-
pathRefs: () => {
|
|
63
|
-
let refs = PATH_REFS.get(board);
|
|
64
|
-
if (!refs) {
|
|
65
|
-
refs = new Set();
|
|
66
|
-
PATH_REFS.set(board, refs);
|
|
67
|
-
}
|
|
68
|
-
return refs;
|
|
69
|
-
},
|
|
70
|
-
onChange: () => { },
|
|
71
|
-
afterChange: () => { },
|
|
72
|
-
drawSelectionRectangle: () => {
|
|
73
|
-
return drawSelectionRectangleG(board);
|
|
74
|
-
},
|
|
75
|
-
mousedown: (event) => { },
|
|
76
|
-
mousemove: (event) => { },
|
|
77
|
-
mouseleave: (event) => { },
|
|
78
|
-
globalMousemove: (event) => { },
|
|
79
|
-
mouseup: (event) => { },
|
|
80
|
-
globalMouseup: (event) => { },
|
|
81
|
-
keyDown: (event) => { },
|
|
82
|
-
globalKeyDown: (event) => { },
|
|
83
|
-
keyUp: (event) => { },
|
|
84
|
-
dblClick: (event) => { },
|
|
85
|
-
buildFragment: (clipboardContext, rectangle, operationType, originData) => clipboardContext,
|
|
86
|
-
insertFragment: (clipboardData, targetPoint, operationType) => { },
|
|
87
|
-
deleteFragment: (elements) => {
|
|
88
|
-
CoreTransforms.removeElements(board, elements);
|
|
89
|
-
},
|
|
90
|
-
getDeletedFragment: (data) => data,
|
|
91
|
-
getRelatedFragment: (data, originData) => data,
|
|
92
|
-
normalizeElement: (context) => {
|
|
93
|
-
},
|
|
94
|
-
drawElement: (context) => {
|
|
95
|
-
throw new Error(`can not resolve plugin element component type: ${context.element.type}`);
|
|
96
|
-
},
|
|
97
|
-
isWithinSelection: element => false,
|
|
98
|
-
isRectangleHit: element => false,
|
|
99
|
-
isHit: element => false,
|
|
100
|
-
isInsidePoint: element => false,
|
|
101
|
-
getOneHitElement: (data) => data[0],
|
|
102
|
-
isRecursion: element => true,
|
|
103
|
-
isMovable: element => false,
|
|
104
|
-
getRectangle: element => null,
|
|
105
|
-
applyTheme: (element) => { },
|
|
106
|
-
isAlign: element => false,
|
|
107
|
-
pointerDown: pointer => { },
|
|
108
|
-
pointerMove: pointer => { },
|
|
109
|
-
pointerUp: pointer => { },
|
|
110
|
-
pointerCancel: pointer => { },
|
|
111
|
-
pointerOut: pointer => { },
|
|
112
|
-
pointerLeave: pointer => { },
|
|
113
|
-
globalPointerMove: pointer => { },
|
|
114
|
-
globalPointerUp: pointer => { },
|
|
115
|
-
isImageBindingAllowed: (element) => false,
|
|
116
|
-
canAddToGroup: (element) => true,
|
|
117
|
-
canSetZIndex: (element) => true,
|
|
118
|
-
isExpanded: (element) => true
|
|
119
|
-
};
|
|
120
|
-
return board;
|
|
121
|
-
}
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-board.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/create-board.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitBoardOptions } from '../interfaces/board';\nimport { PlaitPointerType } from '../interfaces/pointer';\nimport { PlaitElement } from '../interfaces/element';\nimport { PlaitPluginElementContext } from '../core/element/context';\nimport { PlaitOperation } from '../interfaces/operation';\nimport { Transforms } from '../transforms';\nimport { FLUSHING, PATH_REFS } from '../utils/weak-maps';\nimport { PathRef, PathRefOptions } from '../interfaces/path-ref';\nimport { Path } from '../interfaces/path';\nimport { ThemeColorMode } from '../interfaces/theme';\nimport { CoreTransforms } from '../transforms/element';\nimport { ClipboardData, WritableClipboardContext, WritableClipboardOperationType, drawSelectionRectangleG } from '../utils';\nimport { Point, RectangleClient } from '../interfaces';\n\nexport function createBoard(children: PlaitElement[], options?: PlaitBoardOptions): PlaitBoard {\n    const board: PlaitBoard = {\n        viewport: {\n            zoom: 1\n        },\n        children,\n        theme: { themeColorMode: ThemeColorMode.default },\n        operations: [],\n        history: {\n            redos: [],\n            undos: []\n        },\n        selection: null,\n        options: options || {\n            readonly: false,\n            hideScrollbar: false,\n            disabledScrollOnNonFocus: false\n        },\n        pointer: options?.readonly ? PlaitPointerType.hand : PlaitPointerType.selection,\n        undo: () => {},\n        redo: () => {},\n        apply: (operation: PlaitOperation) => {\n            for (const ref of board.pathRefs()) {\n                PathRef.transform(ref, operation);\n            }\n\n            board.operations.push(operation);\n\n            Transforms.transform(board, operation);\n\n            if (!FLUSHING.get(board)) {\n                FLUSHING.set(board, true);\n\n                Promise.resolve().then(() => {\n                    FLUSHING.set(board, false);\n                    board.onChange();\n                    board.afterChange();\n                    board.operations = [];\n                });\n            }\n        },\n        pathRef: (path: Path, options?: PathRefOptions) => {\n            const affinity = options?.affinity || 'forward';\n            const ref: PathRef = {\n                current: path,\n                affinity,\n                unref() {\n                    const { current } = ref;\n                    const pathRefs = board.pathRefs();\n                    pathRefs.delete(ref);\n                    ref.current = null;\n                    return current;\n                }\n            };\n\n            const refs = board.pathRefs();\n            refs.add(ref);\n            return ref;\n        },\n        pathRefs: () => {\n            let refs = PATH_REFS.get(board);\n\n            if (!refs) {\n                refs = new Set();\n                PATH_REFS.set(board, refs);\n            }\n\n            return refs;\n        },\n        onChange: () => {},\n        afterChange: () => {},\n        drawSelectionRectangle: () => {\n            return drawSelectionRectangleG(board);\n        },\n        mousedown: (event: MouseEvent) => {},\n        mousemove: (event: MouseEvent) => {},\n        mouseleave: (event: MouseEvent) => {},\n        globalMousemove: (event: MouseEvent) => {},\n        mouseup: (event: MouseEvent) => {},\n        globalMouseup: (event: MouseEvent) => {},\n        keyDown: (event: KeyboardEvent) => {},\n        globalKeyDown: (event: KeyboardEvent) => {},\n        keyUp: (event: KeyboardEvent) => {},\n        dblClick: (event: MouseEvent) => {},\n        buildFragment: (\n            clipboardContext: WritableClipboardContext | null,\n            rectangle: RectangleClient | null,\n            operationType: WritableClipboardOperationType,\n            originData?: PlaitElement[]\n        ) => clipboardContext,\n        insertFragment: (clipboardData: ClipboardData | null, targetPoint: Point, operationType?: WritableClipboardOperationType) => {},\n        deleteFragment: (elements: PlaitElement[]) => {\n            CoreTransforms.removeElements(board, elements);\n        },\n        getDeletedFragment: (data: PlaitElement[]) => data,\n        getRelatedFragment: (data: PlaitElement[], originData?: PlaitElement[]) => data,\n        normalizeElement: (context: PlaitPluginElementContext) => {\n        },\n        drawElement: (context: PlaitPluginElementContext) => {\n            throw new Error(`can not resolve plugin element component type: ${context.element.type}`);\n        },\n        isWithinSelection: element => false,\n        isRectangleHit: element => false,\n        isHit: element => false,\n        isInsidePoint: element => false,\n        getOneHitElement: (data: PlaitElement[]) => data[0],\n        isRecursion: element => true,\n        isMovable: element => false,\n        getRectangle: element => null,\n        applyTheme: (element: PlaitElement) => {},\n        isAlign: element => false,\n        pointerDown: pointer => {},\n        pointerMove: pointer => {},\n        pointerUp: pointer => {},\n        pointerCancel: pointer => {},\n        pointerOut: pointer => {},\n        pointerLeave: pointer => {},\n        globalPointerMove: pointer => {},\n        globalPointerUp: pointer => {},\n        isImageBindingAllowed: (element: PlaitElement) => false,\n        canAddToGroup: (element: PlaitElement) => true,\n        canSetZIndex: (element: PlaitElement) => true,\n        isExpanded: (element: PlaitElement) => true\n    };\n    return board;\n}\n"]}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
export * from './create-board';
|
|
2
|
-
export * from './with-board';
|
|
3
|
-
export * from './with-hand';
|
|
4
|
-
export * from './with-history';
|
|
5
|
-
export * from './with-hotkey';
|
|
6
|
-
export * from './with-moving';
|
|
7
|
-
export * from './with-options';
|
|
8
|
-
export * from './with-related-fragment';
|
|
9
|
-
export * from './with-selection';
|
|
10
|
-
export * from './with-i18n';
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy9wbHVnaW5zL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY3JlYXRlLWJvYXJkJztcbmV4cG9ydCAqIGZyb20gJy4vd2l0aC1ib2FyZCc7XG5leHBvcnQgKiBmcm9tICcuL3dpdGgtaGFuZCc7XG5leHBvcnQgKiBmcm9tICcuL3dpdGgtaGlzdG9yeSc7XG5leHBvcnQgKiBmcm9tICcuL3dpdGgtaG90a2V5JztcbmV4cG9ydCAqIGZyb20gJy4vd2l0aC1tb3ZpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi93aXRoLW9wdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi93aXRoLXJlbGF0ZWQtZnJhZ21lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi93aXRoLXNlbGVjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3dpdGgtaTE4bic7Il19
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { BOARD_TO_ON_CHANGE, BOARD_TO_AFTER_CHANGE } from '../utils/weak-maps';
|
|
2
|
-
export function withBoard(board) {
|
|
3
|
-
const { onChange, afterChange } = board;
|
|
4
|
-
board.onChange = () => {
|
|
5
|
-
const onContextChange = BOARD_TO_ON_CHANGE.get(board);
|
|
6
|
-
if (onContextChange) {
|
|
7
|
-
onContextChange();
|
|
8
|
-
}
|
|
9
|
-
onChange();
|
|
10
|
-
};
|
|
11
|
-
board.afterChange = () => {
|
|
12
|
-
const afterContextChange = BOARD_TO_AFTER_CHANGE.get(board);
|
|
13
|
-
if (afterContextChange) {
|
|
14
|
-
afterContextChange();
|
|
15
|
-
}
|
|
16
|
-
afterChange();
|
|
17
|
-
};
|
|
18
|
-
return board;
|
|
19
|
-
}
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1ib2FyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL3BsdWdpbnMvd2l0aC1ib2FyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUcvRSxNQUFNLFVBQVUsU0FBUyxDQUFDLEtBQWlCO0lBQ3ZDLE1BQU0sRUFBRSxRQUFRLEVBQUUsV0FBVyxFQUFFLEdBQUcsS0FBSyxDQUFDO0lBRXhDLEtBQUssQ0FBQyxRQUFRLEdBQUcsR0FBRyxFQUFFO1FBQ2xCLE1BQU0sZUFBZSxHQUFHLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN0RCxJQUFJLGVBQWUsRUFBRSxDQUFDO1lBQ2xCLGVBQWUsRUFBRSxDQUFDO1FBQ3RCLENBQUM7UUFDRCxRQUFRLEVBQUUsQ0FBQztJQUNmLENBQUMsQ0FBQztJQUVGLEtBQUssQ0FBQyxXQUFXLEdBQUcsR0FBRyxFQUFFO1FBQ3JCLE1BQU0sa0JBQWtCLEdBQUcscUJBQXFCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzVELElBQUksa0JBQWtCLEVBQUUsQ0FBQztZQUNyQixrQkFBa0IsRUFBRSxDQUFDO1FBQ3pCLENBQUM7UUFDRCxXQUFXLEVBQUUsQ0FBQztJQUNsQixDQUFDLENBQUE7SUFFRCxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQk9BUkRfVE9fT05fQ0hBTkdFLCBCT0FSRF9UT19BRlRFUl9DSEFOR0UgfSBmcm9tICcuLi91dGlscy93ZWFrLW1hcHMnO1xuaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJy4uL2ludGVyZmFjZXMvYm9hcmQnO1xuXG5leHBvcnQgZnVuY3Rpb24gd2l0aEJvYXJkKGJvYXJkOiBQbGFpdEJvYXJkKSB7XG4gICAgY29uc3QgeyBvbkNoYW5nZSwgYWZ0ZXJDaGFuZ2UgfSA9IGJvYXJkO1xuXG4gICAgYm9hcmQub25DaGFuZ2UgPSAoKSA9PiB7XG4gICAgICAgIGNvbnN0IG9uQ29udGV4dENoYW5nZSA9IEJPQVJEX1RPX09OX0NIQU5HRS5nZXQoYm9hcmQpO1xuICAgICAgICBpZiAob25Db250ZXh0Q2hhbmdlKSB7XG4gICAgICAgICAgICBvbkNvbnRleHRDaGFuZ2UoKTtcbiAgICAgICAgfVxuICAgICAgICBvbkNoYW5nZSgpO1xuICAgIH07XG5cbiAgICBib2FyZC5hZnRlckNoYW5nZSA9ICgpID0+IHtcbiAgICAgICAgY29uc3QgYWZ0ZXJDb250ZXh0Q2hhbmdlID0gQk9BUkRfVE9fQUZURVJfQ0hBTkdFLmdldChib2FyZCk7XG4gICAgICAgIGlmIChhZnRlckNvbnRleHRDaGFuZ2UpIHtcbiAgICAgICAgICAgIGFmdGVyQ29udGV4dENoYW5nZSgpO1xuICAgICAgICB9XG4gICAgICAgIGFmdGVyQ2hhbmdlKCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGJvYXJkO1xufVxuIl19
|
|
@@ -1,113 +0,0 @@
|
|
|
1
|
-
import { DRAG_SELECTION_PRESS_AND_MOVE_BUFFER } from '../constants';
|
|
2
|
-
import { PlaitPointerType, PlaitBoard, PlaitPluginKey } from '../interfaces';
|
|
3
|
-
import { distanceBetweenPointAndPoint, isHitElement, isMovingElements, isSelectionMoving, toHostPoint, toViewBoxPoint } from '../utils';
|
|
4
|
-
import { isMainPointer, isWheelPointer } from '../utils/dom/common';
|
|
5
|
-
import { isSmartHand } from '../utils/mobile';
|
|
6
|
-
import { updateViewportContainerScroll } from '../utils/viewport';
|
|
7
|
-
const ShortcutKey = 'Space';
|
|
8
|
-
export function withHandPointer(board) {
|
|
9
|
-
const { pointerDown, pointerMove, globalPointerUp, keyDown, keyUp, pointerUp } = board;
|
|
10
|
-
let isHandMoving = false;
|
|
11
|
-
let movingPoint = null;
|
|
12
|
-
let pointerDownEvent = null;
|
|
13
|
-
let hasWheelPressed = false;
|
|
14
|
-
let beingPressedShortcutKey = false;
|
|
15
|
-
board.pointerDown = (event) => {
|
|
16
|
-
const options = board.getPluginOptions(PlaitPluginKey.withHand);
|
|
17
|
-
const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
18
|
-
const isHitTarget = isHitElement(board, point);
|
|
19
|
-
const canEnterHandMode = options?.isHandMode(board, event) ||
|
|
20
|
-
PlaitBoard.isPointer(board, PlaitPointerType.hand) ||
|
|
21
|
-
(isSmartHand(board, event) && !isHitTarget) ||
|
|
22
|
-
beingPressedShortcutKey;
|
|
23
|
-
if (canEnterHandMode && isMainPointer(event)) {
|
|
24
|
-
movingPoint = {
|
|
25
|
-
x: event.x,
|
|
26
|
-
y: event.y
|
|
27
|
-
};
|
|
28
|
-
if (!PlaitBoard.isPointer(board, PlaitPointerType.hand)) {
|
|
29
|
-
PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
else if (isWheelPointer(event)) {
|
|
33
|
-
hasWheelPressed = true;
|
|
34
|
-
// Prevent the browser's default behavior of scrolling the page when the mouse wheel is pressed.
|
|
35
|
-
event.preventDefault();
|
|
36
|
-
movingPoint = {
|
|
37
|
-
x: event.x,
|
|
38
|
-
y: event.y
|
|
39
|
-
};
|
|
40
|
-
isHandMoving = true;
|
|
41
|
-
PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');
|
|
42
|
-
}
|
|
43
|
-
pointerDownEvent = event;
|
|
44
|
-
pointerDown(event);
|
|
45
|
-
};
|
|
46
|
-
board.pointerMove = (event) => {
|
|
47
|
-
const options = board.getPluginOptions(PlaitPluginKey.withHand);
|
|
48
|
-
// 阈值必须大于 withSelection 中 pointerMove 的 PRESS_AND_MOVE_BUFFER:
|
|
49
|
-
// 1. 首先检测是否满足进入拖选状态的条件
|
|
50
|
-
// 2. 仅当不满足拖选条件时,才会考虑触发 withHand 行为
|
|
51
|
-
// Must exceed the DRAG_SELECTION_PRESS_AND_MOVE_BUFFER threshold defined in withSelection's pointerMove.
|
|
52
|
-
// The system first checks for drag selection state eligibility
|
|
53
|
-
// withHand behavior is only triggered if drag selection state is not initiated.
|
|
54
|
-
const triggerDistance = DRAG_SELECTION_PRESS_AND_MOVE_BUFFER + 4;
|
|
55
|
-
if (movingPoint &&
|
|
56
|
-
!isHandMoving &&
|
|
57
|
-
!isSelectionMoving(board) &&
|
|
58
|
-
pointerDownEvent &&
|
|
59
|
-
distanceBetweenPointAndPoint(pointerDownEvent.x, pointerDownEvent.y, event.x, event.y) > triggerDistance &&
|
|
60
|
-
!isMovingElements(board)) {
|
|
61
|
-
isHandMoving = true;
|
|
62
|
-
PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');
|
|
63
|
-
}
|
|
64
|
-
const canEnterHandMode = options?.isHandMode(board, event) ||
|
|
65
|
-
PlaitBoard.isPointer(board, PlaitPointerType.hand) ||
|
|
66
|
-
isSmartHand(board, event) ||
|
|
67
|
-
hasWheelPressed ||
|
|
68
|
-
beingPressedShortcutKey;
|
|
69
|
-
if (canEnterHandMode && isHandMoving && movingPoint && !isSelectionMoving(board) && !isMovingElements(board)) {
|
|
70
|
-
const viewportContainer = PlaitBoard.getViewportContainer(board);
|
|
71
|
-
const left = viewportContainer.scrollLeft - (event.x - movingPoint.x);
|
|
72
|
-
const top = viewportContainer.scrollTop - (event.y - movingPoint.y);
|
|
73
|
-
updateViewportContainerScroll(board, left, top, false);
|
|
74
|
-
movingPoint.x = event.x;
|
|
75
|
-
movingPoint.y = event.y;
|
|
76
|
-
}
|
|
77
|
-
pointerMove(event);
|
|
78
|
-
};
|
|
79
|
-
board.pointerUp = (event) => {
|
|
80
|
-
if (isHandMoving) {
|
|
81
|
-
return;
|
|
82
|
-
}
|
|
83
|
-
pointerUp(event);
|
|
84
|
-
};
|
|
85
|
-
board.globalPointerUp = (event) => {
|
|
86
|
-
if (movingPoint) {
|
|
87
|
-
movingPoint = null;
|
|
88
|
-
}
|
|
89
|
-
isHandMoving = false;
|
|
90
|
-
PlaitBoard.getBoardContainer(board).classList.remove('viewport-moving');
|
|
91
|
-
hasWheelPressed = false;
|
|
92
|
-
globalPointerUp(event);
|
|
93
|
-
};
|
|
94
|
-
board.keyDown = (event) => {
|
|
95
|
-
if (event.code === ShortcutKey) {
|
|
96
|
-
if (!PlaitBoard.isPointer(board, PlaitPointerType.hand)) {
|
|
97
|
-
beingPressedShortcutKey = true;
|
|
98
|
-
PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');
|
|
99
|
-
}
|
|
100
|
-
event.preventDefault();
|
|
101
|
-
}
|
|
102
|
-
keyDown(event);
|
|
103
|
-
};
|
|
104
|
-
board.keyUp = (event) => {
|
|
105
|
-
if (!board.options.readonly && event.code === ShortcutKey) {
|
|
106
|
-
beingPressedShortcutKey = true;
|
|
107
|
-
PlaitBoard.getBoardContainer(board).classList.remove('viewport-moving');
|
|
108
|
-
}
|
|
109
|
-
keyUp(event);
|
|
110
|
-
};
|
|
111
|
-
return board;
|
|
112
|
-
}
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-hand.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-hand.ts"],"names":[],"mappings":"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","sourcesContent":["import { DRAG_SELECTION_PRESS_AND_MOVE_BUFFER } from '../constants';\nimport { PlaitPointerType, PlaitBoard, PlaitBoardMove, WithHandPluginOptions, PlaitPluginKey } from '../interfaces';\nimport { distanceBetweenPointAndPoint, isHitElement, isMovingElements, isSelectionMoving, toHostPoint, toViewBoxPoint } from '../utils';\nimport { isMainPointer, isWheelPointer } from '../utils/dom/common';\nimport { isSmartHand } from '../utils/mobile';\nimport { updateViewportContainerScroll } from '../utils/viewport';\nimport { PlaitOptionsBoard } from './with-options';\n\nconst ShortcutKey = 'Space';\n\nexport function withHandPointer<T extends PlaitBoard>(board: T) {\n    const { pointerDown, pointerMove, globalPointerUp, keyDown, keyUp, pointerUp } = board;\n    let isHandMoving: boolean = false;\n    let movingPoint: PlaitBoardMove | null = null;\n    let pointerDownEvent: PointerEvent | null = null;\n    let hasWheelPressed = false;\n    let beingPressedShortcutKey = false;\n\n    board.pointerDown = (event: PointerEvent) => {\n        const options = (board as unknown as PlaitOptionsBoard).getPluginOptions<WithHandPluginOptions>(PlaitPluginKey.withHand);\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const isHitTarget = isHitElement(board, point);\n        const canEnterHandMode =\n            options?.isHandMode(board, event) ||\n            PlaitBoard.isPointer(board, PlaitPointerType.hand) ||\n            (isSmartHand(board, event) && !isHitTarget) ||\n            beingPressedShortcutKey;\n        if (canEnterHandMode && isMainPointer(event)) {\n            movingPoint = {\n                x: event.x,\n                y: event.y\n            };\n            if (!PlaitBoard.isPointer(board, PlaitPointerType.hand)) {\n                PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');\n            }\n        } else if (isWheelPointer(event)) {\n            hasWheelPressed = true;\n            // Prevent the browser's default behavior of scrolling the page when the mouse wheel is pressed.\n            event.preventDefault();\n            movingPoint = {\n                x: event.x,\n                y: event.y\n            };\n            isHandMoving = true;\n            PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');\n        }\n        pointerDownEvent = event;\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        const options = (board as unknown as PlaitOptionsBoard).getPluginOptions<WithHandPluginOptions>(PlaitPluginKey.withHand);\n        // 阈值必须大于 withSelection 中 pointerMove 的 PRESS_AND_MOVE_BUFFER：\n        // 1. 首先检测是否满足进入拖选状态的条件\n        // 2. 仅当不满足拖选条件时，才会考虑触发 withHand 行为\n        // Must exceed the DRAG_SELECTION_PRESS_AND_MOVE_BUFFER threshold defined in withSelection's pointerMove.\n        // The system first checks for drag selection state eligibility\n        // withHand behavior is only triggered if drag selection state is not initiated.\n        const triggerDistance = DRAG_SELECTION_PRESS_AND_MOVE_BUFFER + 4;\n        if (\n            movingPoint &&\n            !isHandMoving &&\n            !isSelectionMoving(board) &&\n            pointerDownEvent &&\n            distanceBetweenPointAndPoint(pointerDownEvent.x, pointerDownEvent.y, event.x, event.y) > triggerDistance &&\n            !isMovingElements(board)\n        ) {\n            isHandMoving = true;\n            PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');\n        }\n        const canEnterHandMode =\n            options?.isHandMode(board, event) ||\n            PlaitBoard.isPointer(board, PlaitPointerType.hand) ||\n            isSmartHand(board, event) ||\n            hasWheelPressed ||\n            beingPressedShortcutKey;\n        if (canEnterHandMode && isHandMoving && movingPoint && !isSelectionMoving(board) && !isMovingElements(board)) {\n            const viewportContainer = PlaitBoard.getViewportContainer(board);\n            const left = viewportContainer.scrollLeft - (event.x - movingPoint.x);\n            const top = viewportContainer.scrollTop - (event.y - movingPoint.y);\n            updateViewportContainerScroll(board, left, top, false);\n            movingPoint.x = event.x;\n            movingPoint.y = event.y;\n        }\n        pointerMove(event);\n    };\n\n    board.pointerUp = (event: PointerEvent) => {\n        if (isHandMoving) {\n            return;\n        }\n        pointerUp(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        if (movingPoint) {\n            movingPoint = null;\n        }\n        isHandMoving = false;\n        PlaitBoard.getBoardContainer(board).classList.remove('viewport-moving');\n        hasWheelPressed = false;\n        globalPointerUp(event);\n    };\n\n    board.keyDown = (event: KeyboardEvent) => {\n        if (event.code === ShortcutKey) {\n            if (!PlaitBoard.isPointer(board, PlaitPointerType.hand)) {\n                beingPressedShortcutKey = true;\n                PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');\n            }\n            event.preventDefault();\n        }\n        keyDown(event);\n    };\n\n    board.keyUp = (event: KeyboardEvent) => {\n        if (!board.options.readonly && event.code === ShortcutKey) {\n            beingPressedShortcutKey = true;\n            PlaitBoard.getBoardContainer(board).classList.remove('viewport-moving');\n        }\n        keyUp(event);\n    };\n\n    return board;\n}\n"]}
|
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
import { PlaitOperation } from '../interfaces';
|
|
2
|
-
import { isHotkey } from 'is-hotkey';
|
|
3
|
-
import { PlaitHistoryBoard, shouldClear, shouldMerge, shouldSave } from '../utils';
|
|
4
|
-
export function withHistory(board) {
|
|
5
|
-
const { apply, keyDown } = board;
|
|
6
|
-
board.history = { undos: [], redos: [] };
|
|
7
|
-
board.redo = () => {
|
|
8
|
-
const { history } = board;
|
|
9
|
-
const { redos } = history;
|
|
10
|
-
if (redos.length > 0) {
|
|
11
|
-
const batch = redos[redos.length - 1];
|
|
12
|
-
PlaitHistoryBoard.withoutSaving(board, () => {
|
|
13
|
-
for (const op of batch) {
|
|
14
|
-
board.apply(op);
|
|
15
|
-
}
|
|
16
|
-
});
|
|
17
|
-
history.redos.pop();
|
|
18
|
-
history.undos.push(batch);
|
|
19
|
-
}
|
|
20
|
-
};
|
|
21
|
-
board.undo = () => {
|
|
22
|
-
const { history } = board;
|
|
23
|
-
const { undos } = history;
|
|
24
|
-
if (undos.length > 0) {
|
|
25
|
-
const batch = undos[undos.length - 1];
|
|
26
|
-
PlaitHistoryBoard.withoutSaving(board, () => {
|
|
27
|
-
const inverseOps = batch.map(PlaitOperation.inverse).reverse();
|
|
28
|
-
for (const op of inverseOps) {
|
|
29
|
-
board.apply(op);
|
|
30
|
-
}
|
|
31
|
-
});
|
|
32
|
-
history.redos.push(batch);
|
|
33
|
-
history.undos.pop();
|
|
34
|
-
}
|
|
35
|
-
};
|
|
36
|
-
board.apply = (op) => {
|
|
37
|
-
const { operations, history } = board;
|
|
38
|
-
const { undos } = history;
|
|
39
|
-
const lastBatch = undos[undos.length - 1];
|
|
40
|
-
const lastOp = lastBatch && lastBatch[lastBatch.length - 1];
|
|
41
|
-
let save = PlaitHistoryBoard.isSaving(board);
|
|
42
|
-
let merge = PlaitHistoryBoard.isMerging(board);
|
|
43
|
-
if (save == null) {
|
|
44
|
-
save = shouldSave(op, lastOp);
|
|
45
|
-
}
|
|
46
|
-
if (save) {
|
|
47
|
-
if (!merge) {
|
|
48
|
-
if (lastBatch == null) {
|
|
49
|
-
merge = false;
|
|
50
|
-
}
|
|
51
|
-
else if (operations.length !== 0) {
|
|
52
|
-
merge = true;
|
|
53
|
-
}
|
|
54
|
-
else {
|
|
55
|
-
merge = shouldMerge(op, lastOp);
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
if (PlaitHistoryBoard.isSplittingOnce(board)) {
|
|
59
|
-
merge = false;
|
|
60
|
-
PlaitHistoryBoard.setSplittingOnce(board, undefined);
|
|
61
|
-
}
|
|
62
|
-
if (lastBatch && merge) {
|
|
63
|
-
lastBatch.push(op);
|
|
64
|
-
}
|
|
65
|
-
else {
|
|
66
|
-
const batch = [op];
|
|
67
|
-
undos.push(batch);
|
|
68
|
-
}
|
|
69
|
-
while (undos.length > 100) {
|
|
70
|
-
undos.shift();
|
|
71
|
-
}
|
|
72
|
-
if (shouldClear(op)) {
|
|
73
|
-
history.redos = [];
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
apply(op);
|
|
77
|
-
};
|
|
78
|
-
board.keyDown = (event) => {
|
|
79
|
-
if (isHotkey('mod+z', event)) {
|
|
80
|
-
board.undo();
|
|
81
|
-
return;
|
|
82
|
-
}
|
|
83
|
-
if (isHotkey('mod+shift+z', event)) {
|
|
84
|
-
board.redo();
|
|
85
|
-
return;
|
|
86
|
-
}
|
|
87
|
-
keyDown(event);
|
|
88
|
-
};
|
|
89
|
-
return board;
|
|
90
|
-
}
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-history.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-history.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitOperation } from '../interfaces';\nimport { isHotkey } from 'is-hotkey';\nimport { PlaitHistoryBoard, shouldClear, shouldMerge, shouldSave } from '../utils';\n\nexport function withHistory<T extends PlaitBoard>(board: T) {\n    const { apply, keyDown } = board;\n    board.history = { undos: [], redos: [] };\n\n    board.redo = () => {\n        const { history } = board;\n        const { redos } = history;\n\n        if (redos.length > 0) {\n            const batch = redos[redos.length - 1];\n\n            PlaitHistoryBoard.withoutSaving(board, () => {\n                for (const op of batch) {\n                    board.apply(op);\n                }\n            });\n\n            history.redos.pop();\n            history.undos.push(batch);\n        }\n    };\n\n    board.undo = () => {\n        const { history } = board;\n        const { undos } = history;\n\n        if (undos.length > 0) {\n            const batch = undos[undos.length - 1];\n\n            PlaitHistoryBoard.withoutSaving(board, () => {\n                const inverseOps = batch.map(PlaitOperation.inverse).reverse();\n                for (const op of inverseOps) {\n                    board.apply(op);\n                }\n            });\n\n            history.redos.push(batch);\n            history.undos.pop();\n        }\n    };\n\n    board.apply = (op: PlaitOperation) => {\n        const { operations, history } = board;\n        const { undos } = history;\n        const lastBatch = undos[undos.length - 1];\n        const lastOp = lastBatch && lastBatch[lastBatch.length - 1];\n        let save = PlaitHistoryBoard.isSaving(board);\n        let merge = PlaitHistoryBoard.isMerging(board);\n\n        if (save == null) {\n            save = shouldSave(op, lastOp);\n        }\n\n        if (save) {\n            if (!merge) {\n                if (lastBatch == null) {\n                    merge = false;\n                } else if (operations.length !== 0) {\n                    merge = true;\n                } else {\n                    merge = shouldMerge(op, lastOp);\n                }\n            }\n\n            if (PlaitHistoryBoard.isSplittingOnce(board)) {\n                merge = false;\n                PlaitHistoryBoard.setSplittingOnce(board, undefined);\n            }\n\n            if (lastBatch && merge) {\n                lastBatch.push(op);\n            } else {\n                const batch = [op];\n                undos.push(batch);\n            }\n\n            while (undos.length > 100) {\n                undos.shift();\n            }\n\n            if (shouldClear(op)) {\n                history.redos = [];\n            }\n        }\n        apply(op);\n    };\n\n    board.keyDown = (event: KeyboardEvent) => {\n        if (isHotkey('mod+z', event)) {\n            board.undo();\n            return;\n        }\n        if (isHotkey('mod+shift+z', event)) {\n            board.redo();\n            return;\n        }\n        keyDown(event);\n    };\n\n    return board;\n}\n"]}
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
import { isHotkey, isKeyHotkey } from 'is-hotkey';
|
|
2
|
-
import { PlaitBoard, PlaitPluginKey } from '../interfaces';
|
|
3
|
-
import { BoardTransforms, Transforms } from '../transforms';
|
|
4
|
-
import { deleteFragment, depthFirstRecursion, duplicateElements, getSelectedElements, hotkeys } from '../utils';
|
|
5
|
-
export const withHotkey = (board) => {
|
|
6
|
-
const { keyDown, keyUp, globalKeyDown } = board;
|
|
7
|
-
board.keyDown = (event) => {
|
|
8
|
-
const options = board.getPluginOptions(PlaitPluginKey.withSelection);
|
|
9
|
-
if (!PlaitBoard.isReadonly(board) && options.isMultipleSelection && isHotkey('mod+a', event)) {
|
|
10
|
-
event.preventDefault();
|
|
11
|
-
let elements = [];
|
|
12
|
-
depthFirstRecursion(board, node => {
|
|
13
|
-
if (PlaitBoard.isBoard(node)) {
|
|
14
|
-
return;
|
|
15
|
-
}
|
|
16
|
-
elements.push(node);
|
|
17
|
-
}, node => {
|
|
18
|
-
if (PlaitBoard.isBoard(node) || board.isRecursion(node)) {
|
|
19
|
-
return true;
|
|
20
|
-
}
|
|
21
|
-
else {
|
|
22
|
-
return false;
|
|
23
|
-
}
|
|
24
|
-
}, true);
|
|
25
|
-
Transforms.addSelectionWithTemporaryElements(board, elements);
|
|
26
|
-
return;
|
|
27
|
-
}
|
|
28
|
-
if (!PlaitBoard.isReadonly(board)) {
|
|
29
|
-
if (isKeyHotkey('mod+]', event)) {
|
|
30
|
-
event.preventDefault();
|
|
31
|
-
Transforms.moveUp(board);
|
|
32
|
-
return;
|
|
33
|
-
}
|
|
34
|
-
if (isKeyHotkey('mod+[', event)) {
|
|
35
|
-
event.preventDefault();
|
|
36
|
-
Transforms.moveDown(board);
|
|
37
|
-
return;
|
|
38
|
-
}
|
|
39
|
-
if (isKeyHotkey('mod+option+‘', event)) {
|
|
40
|
-
event.preventDefault();
|
|
41
|
-
Transforms.moveToTop(board);
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
if (isKeyHotkey('mod+option+“', event)) {
|
|
45
|
-
event.preventDefault();
|
|
46
|
-
Transforms.moveToBottom(board);
|
|
47
|
-
return;
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
const selectedElements = getSelectedElements(board);
|
|
51
|
-
if (!PlaitBoard.isReadonly(board) && selectedElements.length > 0) {
|
|
52
|
-
if (isKeyHotkey('mod+d', event)) {
|
|
53
|
-
event.preventDefault();
|
|
54
|
-
duplicateElements(board);
|
|
55
|
-
return;
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
if (!PlaitBoard.isReadonly(board) &&
|
|
59
|
-
selectedElements.length > 0 &&
|
|
60
|
-
(hotkeys.isDeleteBackward(event) || hotkeys.isDeleteForward(event))) {
|
|
61
|
-
event.preventDefault();
|
|
62
|
-
deleteFragment(board);
|
|
63
|
-
}
|
|
64
|
-
keyDown(event);
|
|
65
|
-
};
|
|
66
|
-
board.keyUp = (event) => {
|
|
67
|
-
keyUp(event);
|
|
68
|
-
};
|
|
69
|
-
board.globalKeyDown = (event) => {
|
|
70
|
-
if (PlaitBoard.getMovingPointInBoard(board) || PlaitBoard.isMovingPointInBoard(board)) {
|
|
71
|
-
if (isHotkey(['mod+=', 'mod++'], { byKey: true })(event)) {
|
|
72
|
-
event.preventDefault();
|
|
73
|
-
BoardTransforms.updateZoom(board, board.viewport.zoom + 0.1);
|
|
74
|
-
return;
|
|
75
|
-
}
|
|
76
|
-
if (isHotkey(['mod+shift+=', 'mod+shift++'], { byKey: true })(event)) {
|
|
77
|
-
event.preventDefault();
|
|
78
|
-
BoardTransforms.fitViewport(board);
|
|
79
|
-
return;
|
|
80
|
-
}
|
|
81
|
-
if (isHotkey(['mod+-', 'mod+shift+-'])(event)) {
|
|
82
|
-
event.preventDefault();
|
|
83
|
-
BoardTransforms.updateZoom(board, board.viewport.zoom - 0.1);
|
|
84
|
-
return;
|
|
85
|
-
}
|
|
86
|
-
if (isHotkey(['mod+0', 'mod+shift+0'], { byKey: true })(event)) {
|
|
87
|
-
event.preventDefault();
|
|
88
|
-
BoardTransforms.updateZoom(board, 1);
|
|
89
|
-
return;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
globalKeyDown(event);
|
|
93
|
-
};
|
|
94
|
-
return board;
|
|
95
|
-
};
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-hotkey.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-hotkey.ts"],"names":[],"mappings":"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","sourcesContent":["import { isHotkey, isKeyHotkey } from 'is-hotkey';\nimport { Ancestor, PlaitBoard, PlaitElement, PlaitPluginKey, WithSelectionPluginOptions } from '../interfaces';\nimport { BoardTransforms, Transforms } from '../transforms';\nimport { deleteFragment, depthFirstRecursion, duplicateElements, getSelectedElements, hotkeys } from '../utils';\nimport { PlaitOptionsBoard } from './with-options';\n\nexport const withHotkey = (board: PlaitBoard) => {\n    const { keyDown, keyUp, globalKeyDown } = board;\n\n    board.keyDown = (event: KeyboardEvent) => {\n        const options = (board as PlaitOptionsBoard).getPluginOptions<WithSelectionPluginOptions>(PlaitPluginKey.withSelection);\n        if (!PlaitBoard.isReadonly(board) && options.isMultipleSelection && isHotkey('mod+a', event)) {\n            event.preventDefault();\n            let elements: PlaitElement[] = [];\n            depthFirstRecursion<Ancestor>(\n                board,\n                node => {\n                    if (PlaitBoard.isBoard(node)) {\n                        return;\n                    }\n                    elements.push(node as PlaitElement);\n                },\n                node => {\n                    if (PlaitBoard.isBoard(node) || board.isRecursion(node)) {\n                        return true;\n                    } else {\n                        return false;\n                    }\n                },\n                true\n            );\n            Transforms.addSelectionWithTemporaryElements(board, elements);\n            return;\n        }\n        if (!PlaitBoard.isReadonly(board)) {\n            if (isKeyHotkey('mod+]', event)) {\n                event.preventDefault();\n                Transforms.moveUp(board);\n                return;\n            }\n            if (isKeyHotkey('mod+[', event)) {\n                event.preventDefault();\n                Transforms.moveDown(board);\n                return;\n            }\n            if (isKeyHotkey('mod+option+‘', event)) {\n                event.preventDefault();\n                Transforms.moveToTop(board);\n                return;\n            }\n            if (isKeyHotkey('mod+option+“', event)) {\n                event.preventDefault();\n                Transforms.moveToBottom(board);\n                return;\n            }\n        }\n\n        const selectedElements = getSelectedElements(board);\n        if (!PlaitBoard.isReadonly(board) && selectedElements.length > 0) {\n            if (isKeyHotkey('mod+d', event)) {\n                event.preventDefault();\n                duplicateElements(board);\n                return;\n            }\n        }\n        if (\n            !PlaitBoard.isReadonly(board) &&\n            selectedElements.length > 0 &&\n            (hotkeys.isDeleteBackward(event) || hotkeys.isDeleteForward(event))\n        ) {\n            event.preventDefault();\n            deleteFragment(board);\n        }\n\n        keyDown(event);\n    };\n\n    board.keyUp = (event: KeyboardEvent) => {\n        keyUp(event);\n    };\n\n    board.globalKeyDown = (event: KeyboardEvent) => {\n        if (PlaitBoard.getMovingPointInBoard(board) || PlaitBoard.isMovingPointInBoard(board)) {\n            if (isHotkey(['mod+=', 'mod++'], { byKey: true })(event)) {\n                event.preventDefault();\n                BoardTransforms.updateZoom(board, board.viewport.zoom + 0.1);\n                return;\n            }\n            if (isHotkey(['mod+shift+=', 'mod+shift++'], { byKey: true })(event)) {\n                event.preventDefault();\n                BoardTransforms.fitViewport(board);\n                return;\n            }\n            if (isHotkey(['mod+-', 'mod+shift+-'])(event)) {\n                event.preventDefault();\n                BoardTransforms.updateZoom(board, board.viewport.zoom - 0.1);\n                return;\n            }\n            if (isHotkey(['mod+0', 'mod+shift+0'], { byKey: true })(event)) {\n                event.preventDefault();\n                BoardTransforms.updateZoom(board, 1);\n                return;\n            }\n        }\n        globalKeyDown(event);\n    };\n\n    return board;\n};\n"]}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
export const withI18n = (board) => {
|
|
2
|
-
const newBoard = board;
|
|
3
|
-
newBoard.getI18nValue = (key) => {
|
|
4
|
-
console.warn(`I18n key "${key}" is not found.`);
|
|
5
|
-
return null;
|
|
6
|
-
};
|
|
7
|
-
return newBoard;
|
|
8
|
-
};
|
|
9
|
-
export const getI18nValue = (board, key, defaultValue = '') => {
|
|
10
|
-
const i18nBoard = board;
|
|
11
|
-
return i18nBoard.getI18nValue(key) || defaultValue;
|
|
12
|
-
};
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1pMThuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvcGx1Z2lucy93aXRoLWkxOG4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTUEsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO0lBQzFDLE1BQU0sUUFBUSxHQUFHLEtBQXVCLENBQUM7SUFFekMsUUFBUSxDQUFDLFlBQVksR0FBRyxDQUFDLEdBQUcsRUFBRSxFQUFFO1FBQzVCLE9BQU8sQ0FBQyxJQUFJLENBQUMsYUFBYSxHQUFHLGlCQUFpQixDQUFDLENBQUM7UUFDaEQsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQyxDQUFDO0lBRUYsT0FBTyxRQUFRLENBQUM7QUFDcEIsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLENBQUMsS0FBaUIsRUFBRSxHQUFXLEVBQUUsWUFBWSxHQUFHLEVBQUUsRUFBRSxFQUFFO0lBQzlFLE1BQU0sU0FBUyxHQUFHLEtBQXVCLENBQUM7SUFDMUMsT0FBTyxTQUFTLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxJQUFJLFlBQVksQ0FBQztBQUN2RCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ib2FyZCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRJMThuQm9hcmQgZXh0ZW5kcyBQbGFpdEJvYXJkIHtcbiAgICBnZXRJMThuVmFsdWU6IChrZXk6IHN0cmluZykgPT4gc3RyaW5nIHwgbnVsbDtcbn1cblxuZXhwb3J0IGNvbnN0IHdpdGhJMThuID0gKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB7XG4gICAgY29uc3QgbmV3Qm9hcmQgPSBib2FyZCBhcyBQbGFpdEkxOG5Cb2FyZDtcblxuICAgIG5ld0JvYXJkLmdldEkxOG5WYWx1ZSA9IChrZXkpID0+IHtcbiAgICAgICAgY29uc29sZS53YXJuKGBJMThuIGtleSBcIiR7a2V5fVwiIGlzIG5vdCBmb3VuZC5gKTtcbiAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgfTtcblxuICAgIHJldHVybiBuZXdCb2FyZDtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRJMThuVmFsdWUgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGtleTogc3RyaW5nLCBkZWZhdWx0VmFsdWUgPSAnJykgPT4ge1xuICAgIGNvbnN0IGkxOG5Cb2FyZCA9IGJvYXJkIGFzIFBsYWl0STE4bkJvYXJkO1xuICAgIHJldHVybiBpMThuQm9hcmQuZ2V0STE4blZhbHVlKGtleSkgfHwgZGVmYXVsdFZhbHVlO1xufTtcbiJdfQ==
|