@plait/core 0.1.0 → 0.1.1
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/esm2020/plugins/with-selection.mjs +16 -6
- package/esm2020/public-api.mjs +2 -1
- package/esm2020/transforms/selection.mjs +10 -2
- package/esm2020/utils/weak-maps.mjs +3 -1
- package/fesm2015/plait-core.mjs +36 -18
- package/fesm2015/plait-core.mjs.map +1 -1
- package/fesm2020/plait-core.mjs +36 -18
- package/fesm2020/plait-core.mjs.map +1 -1
- package/package.json +1 -1
- package/plugins/with-selection.d.ts +2 -0
- package/public-api.d.ts +1 -0
- package/transforms/selection.d.ts +3 -0
- package/utils/weak-maps.d.ts +1 -0
|
@@ -6,6 +6,7 @@ import { RectangleClient } from '../interfaces/rectangle-client';
|
|
|
6
6
|
import { cacheSelectedElements, calcElementIntersectionSelection } from '../utils/selected-element';
|
|
7
7
|
import { SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';
|
|
8
8
|
import { getRectangleByElements } from '../utils/element';
|
|
9
|
+
import { BOARD_TO_TEMPORARY_ELEMENTS } from '../utils/weak-maps';
|
|
9
10
|
export function withSelection(board) {
|
|
10
11
|
const { mousedown, globalMousemove, globalMouseup, onChange } = board;
|
|
11
12
|
let start = null;
|
|
@@ -28,8 +29,8 @@ export function withSelection(board) {
|
|
|
28
29
|
const { x, y, width, height } = RectangleClient.toRectangleClient([start, movedTarget]);
|
|
29
30
|
if (Math.hypot(width, height) > 5) {
|
|
30
31
|
end = movedTarget;
|
|
31
|
-
if (
|
|
32
|
-
Transforms.setSelection(board, { ranges: [{ anchor: start, focus:
|
|
32
|
+
if (end) {
|
|
33
|
+
Transforms.setSelection(board, { ranges: [{ anchor: start, focus: end }] });
|
|
33
34
|
}
|
|
34
35
|
PlaitBoard.getBoardNativeElement(board).classList.add('selection-moving');
|
|
35
36
|
selectionMovingG?.remove();
|
|
@@ -58,11 +59,13 @@ export function withSelection(board) {
|
|
|
58
59
|
// calc selected elements entry
|
|
59
60
|
try {
|
|
60
61
|
if (board.operations.find(value => value.type === 'set_selection')) {
|
|
61
|
-
const
|
|
62
|
-
|
|
63
|
-
|
|
62
|
+
const temporaryElements = getTemporaryElements(board);
|
|
63
|
+
const elements = temporaryElements ? temporaryElements : calcElementIntersectionSelection(board);
|
|
64
|
+
cacheSelectedElements(board, elements);
|
|
65
|
+
const { x, y, width, height } = getRectangleByElements(board, elements, false);
|
|
64
66
|
if (width > 0 && height > 0) {
|
|
65
67
|
const rough = PlaitBoard.getRoughSVG(board);
|
|
68
|
+
selectionOuterG?.remove();
|
|
66
69
|
selectionOuterG = rough.rectangle(x - 2, y - 2, width + 4, height + 4, {
|
|
67
70
|
stroke: SELECTION_BORDER_COLOR,
|
|
68
71
|
strokeWidth: 1,
|
|
@@ -71,6 +74,7 @@ export function withSelection(board) {
|
|
|
71
74
|
PlaitBoard.getHost(board).append(selectionOuterG);
|
|
72
75
|
}
|
|
73
76
|
}
|
|
77
|
+
deleteTemporaryElements(board);
|
|
74
78
|
}
|
|
75
79
|
catch (error) {
|
|
76
80
|
console.error(error);
|
|
@@ -79,4 +83,10 @@ export function withSelection(board) {
|
|
|
79
83
|
};
|
|
80
84
|
return board;
|
|
81
85
|
}
|
|
82
|
-
|
|
86
|
+
export function getTemporaryElements(board) {
|
|
87
|
+
return BOARD_TO_TEMPORARY_ELEMENTS.get(board);
|
|
88
|
+
}
|
|
89
|
+
export function deleteTemporaryElements(board) {
|
|
90
|
+
BOARD_TO_TEMPORARY_ELEMENTS.delete(board);
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-selection.js","sourceRoot":"","sources":["../../../../packages/plait/src/plugins/with-selection.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\nimport { Transforms } from '../transforms';\nimport { transformPoint } from '../utils/board';\nimport { toPoint } from '../utils/dom';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport { cacheSelectedElements, calcElementIntersectionSelection } from '../utils/selected-element';\nimport { SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';\nimport { getRectangleByElements } from '../utils/element';\nimport { BOARD_TO_TEMPORARY_ELEMENTS } from '../utils/weak-maps';\n\nexport function withSelection<T extends PlaitBoard>(board: T) {\n    const { mousedown, globalMousemove, globalMouseup, onChange } = board;\n\n    let start: Point | null = null;\n    let end: Point | null = null;\n    let selectionMovingG: SVGGElement;\n    let selectionOuterG: SVGGElement;\n\n    board.mousedown = (event: MouseEvent) => {\n        selectionOuterG?.remove();\n        if (event.button === 0) {\n            start = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        }\n        if (start) {\n            Transforms.setSelection(board, { ranges: [{ anchor: start, focus: start }] });\n        }\n        mousedown(event);\n    };\n\n    board.globalMousemove = (event: MouseEvent) => {\n        if (start) {\n            const movedTarget = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const { x, y, width, height } = RectangleClient.toRectangleClient([start, movedTarget]);\n            if (Math.hypot(width, height) > 5) {\n                end = movedTarget;\n                if (end) {\n                    Transforms.setSelection(board, { ranges: [{ anchor: start, focus: end }] });\n                }\n                PlaitBoard.getBoardNativeElement(board).classList.add('selection-moving');\n                selectionMovingG?.remove();\n                const rough = PlaitBoard.getRoughSVG(board);\n                selectionMovingG = rough.rectangle(x, y, width, height, {\n                    stroke: SELECTION_BORDER_COLOR,\n                    strokeWidth: 1,\n                    fill: SELECTION_FILL_COLOR,\n                    fillStyle: 'solid'\n                });\n                PlaitBoard.getHost(board).append(selectionMovingG);\n            }\n        }\n        globalMousemove(event);\n    };\n\n    board.globalMouseup = (event: MouseEvent) => {\n        if (start && end) {\n            PlaitBoard.getBoardNativeElement(board).classList.remove('selection-moving');\n            selectionMovingG?.remove();\n        }\n\n        start = null;\n        end = null;\n        globalMouseup(event);\n    };\n\n    board.onChange = () => {\n        // calc selected elements entry\n        try {\n            if (board.operations.find(value => value.type === 'set_selection')) {\n                const temporaryElements = getTemporaryElements(board);\n                const elements = temporaryElements ? temporaryElements : calcElementIntersectionSelection(board);\n\n                cacheSelectedElements(board, elements);\n                const { x, y, width, height } = getRectangleByElements(board, elements, false);\n                if (width > 0 && height > 0) {\n                    const rough = PlaitBoard.getRoughSVG(board);\n                    selectionOuterG?.remove();\n                    selectionOuterG = rough.rectangle(x - 2, y - 2, width + 4, height + 4, {\n                        stroke: SELECTION_BORDER_COLOR,\n                        strokeWidth: 1,\n                        fillStyle: 'solid'\n                    });\n                    PlaitBoard.getHost(board).append(selectionOuterG);\n                }\n            }\n            deleteTemporaryElements(board);\n        } catch (error) {\n            console.error(error);\n        }\n        onChange();\n    };\n\n    return board;\n}\n\nexport function getTemporaryElements(board: PlaitBoard) {\n    return BOARD_TO_TEMPORARY_ELEMENTS.get(board);\n}\n\nexport function deleteTemporaryElements(board: PlaitBoard) {\n    BOARD_TO_TEMPORARY_ELEMENTS.delete(board);\n}\n"]}
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -12,4 +12,5 @@ export * from './interfaces';
|
|
|
12
12
|
export * from './plait.module';
|
|
13
13
|
export * from './transforms';
|
|
14
14
|
export * from './utils';
|
|
15
|
-
|
|
15
|
+
export * from './plugins/with-selection';
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBwbGFpdFxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vYm9hcmQvYm9hcmQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29uc3RhbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vY29yZS9iYXNlL2RldGVjdG9yJztcbmV4cG9ydCAqIGZyb20gJy4vY29yZS9lbGVtZW50L3BsdWdpbi1lbGVtZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29yZS9lbGVtZW50L2VsZW1lbnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29yZS9lbGVtZW50L2JlZm9yZS1jb250ZXh0LWNoYW5nZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvcmUvdG9vbGJhci90b29sYmFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2ludGVyZmFjZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9wbGFpdC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi90cmFuc2Zvcm1zJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9wbHVnaW5zL3dpdGgtc2VsZWN0aW9uJztcbiJdfQ==
|
|
@@ -1,8 +1,16 @@
|
|
|
1
|
+
import { BOARD_TO_TEMPORARY_ELEMENTS } from '../utils/weak-maps';
|
|
1
2
|
export function setSelection(board, selection) {
|
|
2
3
|
const operation = { type: 'set_selection', properties: board.selection, newProperties: selection };
|
|
3
4
|
board.apply(operation);
|
|
4
5
|
}
|
|
5
6
|
export const SelectionTransforms = {
|
|
6
|
-
setSelection
|
|
7
|
+
setSelection,
|
|
8
|
+
setSelectionWithTemporaryElements
|
|
7
9
|
};
|
|
8
|
-
|
|
10
|
+
export function setSelectionWithTemporaryElements(board, elements) {
|
|
11
|
+
setTimeout(() => {
|
|
12
|
+
BOARD_TO_TEMPORARY_ELEMENTS.set(board, elements);
|
|
13
|
+
setSelection(board, { ranges: [] });
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3RyYW5zZm9ybXMvc2VsZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBR2pFLE1BQU0sVUFBVSxZQUFZLENBQUMsS0FBaUIsRUFBRSxTQUEyQjtJQUN2RSxNQUFNLFNBQVMsR0FBMEIsRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFLFVBQVUsRUFBRSxLQUFLLENBQUMsU0FBUyxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsQ0FBQztJQUMxSCxLQUFLLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQzNCLENBQUM7QUFPRCxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBd0I7SUFDcEQsWUFBWTtJQUNaLGlDQUFpQztDQUNwQyxDQUFDO0FBR0YsTUFBTSxVQUFVLGlDQUFpQyxDQUFDLEtBQWlCLEVBQUUsUUFBd0I7SUFDekYsVUFBVSxDQUFDLEdBQUcsRUFBRTtRQUNaLDJCQUEyQixDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDakQsWUFBWSxDQUFDLEtBQUssRUFBRSxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3hDLENBQUMsQ0FBQyxDQUFDO0FBQ1AsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNldFNlbGVjdGlvbk9wZXJhdGlvbiB9IGZyb20gJy4uL2ludGVyZmFjZXMvb3BlcmF0aW9uJztcbmltcG9ydCB7IFBsYWl0Qm9hcmQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2JvYXJkJztcbmltcG9ydCB7IFNlbGVjdGlvbiB9IGZyb20gJy4uL2ludGVyZmFjZXMvc2VsZWN0aW9uJztcbmltcG9ydCB7IEJPQVJEX1RPX1RFTVBPUkFSWV9FTEVNRU5UUyB9IGZyb20gJy4uL3V0aWxzL3dlYWstbWFwcyc7XG5pbXBvcnQgeyBQbGFpdEVsZW1lbnQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2VsZW1lbnQnO1xuXG5leHBvcnQgZnVuY3Rpb24gc2V0U2VsZWN0aW9uKGJvYXJkOiBQbGFpdEJvYXJkLCBzZWxlY3Rpb246IFNlbGVjdGlvbiB8IG51bGwpIHtcbiAgICBjb25zdCBvcGVyYXRpb246IFNldFNlbGVjdGlvbk9wZXJhdGlvbiA9IHsgdHlwZTogJ3NldF9zZWxlY3Rpb24nLCBwcm9wZXJ0aWVzOiBib2FyZC5zZWxlY3Rpb24sIG5ld1Byb3BlcnRpZXM6IHNlbGVjdGlvbiB9O1xuICAgIGJvYXJkLmFwcGx5KG9wZXJhdGlvbik7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VsZWN0aW9uVHJhbnNmb3JtcyB7XG4gICAgc2V0U2VsZWN0aW9uOiAoYm9hcmQ6IFBsYWl0Qm9hcmQsIHNlbGVjdGlvbjogU2VsZWN0aW9uIHwgbnVsbCkgPT4gdm9pZDtcbiAgICBzZXRTZWxlY3Rpb25XaXRoVGVtcG9yYXJ5RWxlbWVudHM6IChib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudHM6IFBsYWl0RWxlbWVudFtdKSA9PiB2b2lkO1xufVxuXG5leHBvcnQgY29uc3QgU2VsZWN0aW9uVHJhbnNmb3JtczogU2VsZWN0aW9uVHJhbnNmb3JtcyA9IHtcbiAgICBzZXRTZWxlY3Rpb24sXG4gICAgc2V0U2VsZWN0aW9uV2l0aFRlbXBvcmFyeUVsZW1lbnRzXG59O1xuXG5cbmV4cG9ydCBmdW5jdGlvbiBzZXRTZWxlY3Rpb25XaXRoVGVtcG9yYXJ5RWxlbWVudHMoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnRzOiBQbGFpdEVsZW1lbnRbXSkge1xuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICBCT0FSRF9UT19URU1QT1JBUllfRUxFTUVOVFMuc2V0KGJvYXJkLCBlbGVtZW50cyk7XG4gICAgICAgIHNldFNlbGVjdGlvbihib2FyZCwgeyByYW5nZXM6IFtdIH0pO1xuICAgIH0pO1xufSJdfQ==
|
|
@@ -8,4 +8,6 @@ export const BOARD_TO_HOST = new WeakMap();
|
|
|
8
8
|
export const BOARD_TO_ELEMENT_HOST = new WeakMap();
|
|
9
9
|
export const BOARD_TO_SELECTED_ELEMENT = new WeakMap();
|
|
10
10
|
export const BOARD_TO_MOVING_POINT = new WeakMap();
|
|
11
|
-
|
|
11
|
+
// save no standard selected elements
|
|
12
|
+
export const BOARD_TO_TEMPORARY_ELEMENTS = new WeakMap();
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2Vhay1tYXBzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3V0aWxzL3dlYWstbWFwcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNQSw4QkFBOEI7QUFDOUIsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFpQyxJQUFJLE9BQU8sRUFBRSxDQUFDO0FBRXBFLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLElBQUksT0FBTyxFQUF1QixDQUFDO0FBRW5FLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksT0FBTyxFQUEwQixDQUFDO0FBRXhFLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksT0FBTyxFQUF1QyxDQUFDO0FBRXJGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksT0FBTyxFQUF3QixDQUFDO0FBRXRFLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxJQUFJLE9BQU8sRUFBNkIsQ0FBQztBQUV0RSxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLE9BQU8sRUFBMkIsQ0FBQztBQUU1RSxNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRyxJQUFJLE9BQU8sRUFBOEIsQ0FBQztBQUVuRixNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLE9BQU8sRUFBcUIsQ0FBQztBQUV0RSxxQ0FBcUM7QUFDckMsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQUcsSUFBSSxPQUFPLEVBQThCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSb3VnaFNWRyB9IGZyb20gJ3JvdWdoanMvYmluL3N2Zyc7XG5pbXBvcnQgeyBCb2FyZENvbXBvbmVudEludGVyZmFjZSB9IGZyb20gJy4uL2JvYXJkL2JvYXJkLmNvbXBvbmVudC5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgUGxhaXRFbGVtZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcbmltcG9ydCB7IFBsYWl0Qm9hcmQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2JvYXJkJztcbmltcG9ydCB7IFBvaW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9wb2ludCc7XG5cbi8vIHJlY29yZCByaWNodGV4dCB0eXBlIHN0YXR1c1xuZXhwb3J0IGNvbnN0IEZMVVNISU5HOiBXZWFrTWFwPFBsYWl0Qm9hcmQsIGJvb2xlYW4+ID0gbmV3IFdlYWtNYXAoKTtcblxuZXhwb3J0IGNvbnN0IElTX1RFWFRfRURJVEFCTEUgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBib29sZWFuPigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fT05fQ0hBTkdFID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgKCkgPT4gdm9pZD4oKTtcblxuZXhwb3J0IGNvbnN0IEJPQVJEX1RPX0NPTVBPTkVOVCA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIEJvYXJkQ29tcG9uZW50SW50ZXJmYWNlPigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fUk9VR0hfU1ZHID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgUm91Z2hTVkc+KCk7XG5cbmV4cG9ydCBjb25zdCBCT0FSRF9UT19IT1NUID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgU1ZHU1ZHRWxlbWVudD4oKTtcblxuZXhwb3J0IGNvbnN0IEJPQVJEX1RPX0VMRU1FTlRfSE9TVCA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIFNWR0dFbGVtZW50PigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fU0VMRUNURURfRUxFTUVOVCA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIFBsYWl0RWxlbWVudFtdPigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fTU9WSU5HX1BPSU5UID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgUG9pbnQ+KCk7XG5cbi8vIHNhdmUgbm8gc3RhbmRhcmQgc2VsZWN0ZWQgZWxlbWVudHNcbmV4cG9ydCBjb25zdCBCT0FSRF9UT19URU1QT1JBUllfRUxFTUVOVFMgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBQbGFpdEVsZW1lbnRbXT4oKTtcbiJdfQ==
|
package/fesm2015/plait-core.mjs
CHANGED
|
@@ -356,13 +356,33 @@ const NodeTransforms = {
|
|
|
356
356
|
moveNode
|
|
357
357
|
};
|
|
358
358
|
|
|
359
|
+
// record richtext type status
|
|
360
|
+
const FLUSHING = new WeakMap();
|
|
361
|
+
const IS_TEXT_EDITABLE = new WeakMap();
|
|
362
|
+
const BOARD_TO_ON_CHANGE = new WeakMap();
|
|
363
|
+
const BOARD_TO_COMPONENT = new WeakMap();
|
|
364
|
+
const BOARD_TO_ROUGH_SVG = new WeakMap();
|
|
365
|
+
const BOARD_TO_HOST = new WeakMap();
|
|
366
|
+
const BOARD_TO_ELEMENT_HOST = new WeakMap();
|
|
367
|
+
const BOARD_TO_SELECTED_ELEMENT = new WeakMap();
|
|
368
|
+
const BOARD_TO_MOVING_POINT = new WeakMap();
|
|
369
|
+
// save no standard selected elements
|
|
370
|
+
const BOARD_TO_TEMPORARY_ELEMENTS = new WeakMap();
|
|
371
|
+
|
|
359
372
|
function setSelection(board, selection) {
|
|
360
373
|
const operation = { type: 'set_selection', properties: board.selection, newProperties: selection };
|
|
361
374
|
board.apply(operation);
|
|
362
375
|
}
|
|
363
376
|
const SelectionTransforms = {
|
|
364
|
-
setSelection
|
|
377
|
+
setSelection,
|
|
378
|
+
setSelectionWithTemporaryElements
|
|
365
379
|
};
|
|
380
|
+
function setSelectionWithTemporaryElements(board, elements) {
|
|
381
|
+
setTimeout(() => {
|
|
382
|
+
BOARD_TO_TEMPORARY_ELEMENTS.set(board, elements);
|
|
383
|
+
setSelection(board, { ranges: [] });
|
|
384
|
+
});
|
|
385
|
+
}
|
|
366
386
|
|
|
367
387
|
function setViewport(board, viewport) {
|
|
368
388
|
const operation = { type: 'set_viewport', properties: board.viewport, newProperties: viewport };
|
|
@@ -372,17 +392,6 @@ const ViewportTransforms = {
|
|
|
372
392
|
setViewport
|
|
373
393
|
};
|
|
374
394
|
|
|
375
|
-
// record richtext type status
|
|
376
|
-
const FLUSHING = new WeakMap();
|
|
377
|
-
const IS_TEXT_EDITABLE = new WeakMap();
|
|
378
|
-
const BOARD_TO_ON_CHANGE = new WeakMap();
|
|
379
|
-
const BOARD_TO_COMPONENT = new WeakMap();
|
|
380
|
-
const BOARD_TO_ROUGH_SVG = new WeakMap();
|
|
381
|
-
const BOARD_TO_HOST = new WeakMap();
|
|
382
|
-
const BOARD_TO_ELEMENT_HOST = new WeakMap();
|
|
383
|
-
const BOARD_TO_SELECTED_ELEMENT = new WeakMap();
|
|
384
|
-
const BOARD_TO_MOVING_POINT = new WeakMap();
|
|
385
|
-
|
|
386
395
|
function depthFirstRecursion(node, callback) {
|
|
387
396
|
var _a;
|
|
388
397
|
(_a = node.children) === null || _a === void 0 ? void 0 : _a.forEach(child => {
|
|
@@ -1332,8 +1341,8 @@ function withSelection(board) {
|
|
|
1332
1341
|
const { x, y, width, height } = RectangleClient.toRectangleClient([start, movedTarget]);
|
|
1333
1342
|
if (Math.hypot(width, height) > 5) {
|
|
1334
1343
|
end = movedTarget;
|
|
1335
|
-
if (
|
|
1336
|
-
Transforms.setSelection(board, { ranges: [{ anchor: start, focus:
|
|
1344
|
+
if (end) {
|
|
1345
|
+
Transforms.setSelection(board, { ranges: [{ anchor: start, focus: end }] });
|
|
1337
1346
|
}
|
|
1338
1347
|
PlaitBoard.getBoardNativeElement(board).classList.add('selection-moving');
|
|
1339
1348
|
selectionMovingG === null || selectionMovingG === void 0 ? void 0 : selectionMovingG.remove();
|
|
@@ -1362,11 +1371,13 @@ function withSelection(board) {
|
|
|
1362
1371
|
// calc selected elements entry
|
|
1363
1372
|
try {
|
|
1364
1373
|
if (board.operations.find(value => value.type === 'set_selection')) {
|
|
1365
|
-
const
|
|
1366
|
-
|
|
1367
|
-
|
|
1374
|
+
const temporaryElements = getTemporaryElements(board);
|
|
1375
|
+
const elements = temporaryElements ? temporaryElements : calcElementIntersectionSelection(board);
|
|
1376
|
+
cacheSelectedElements(board, elements);
|
|
1377
|
+
const { x, y, width, height } = getRectangleByElements(board, elements, false);
|
|
1368
1378
|
if (width > 0 && height > 0) {
|
|
1369
1379
|
const rough = PlaitBoard.getRoughSVG(board);
|
|
1380
|
+
selectionOuterG === null || selectionOuterG === void 0 ? void 0 : selectionOuterG.remove();
|
|
1370
1381
|
selectionOuterG = rough.rectangle(x - 2, y - 2, width + 4, height + 4, {
|
|
1371
1382
|
stroke: SELECTION_BORDER_COLOR,
|
|
1372
1383
|
strokeWidth: 1,
|
|
@@ -1375,6 +1386,7 @@ function withSelection(board) {
|
|
|
1375
1386
|
PlaitBoard.getHost(board).append(selectionOuterG);
|
|
1376
1387
|
}
|
|
1377
1388
|
}
|
|
1389
|
+
deleteTemporaryElements(board);
|
|
1378
1390
|
}
|
|
1379
1391
|
catch (error) {
|
|
1380
1392
|
console.error(error);
|
|
@@ -1383,6 +1395,12 @@ function withSelection(board) {
|
|
|
1383
1395
|
};
|
|
1384
1396
|
return board;
|
|
1385
1397
|
}
|
|
1398
|
+
function getTemporaryElements(board) {
|
|
1399
|
+
return BOARD_TO_TEMPORARY_ELEMENTS.get(board);
|
|
1400
|
+
}
|
|
1401
|
+
function deleteTemporaryElements(board) {
|
|
1402
|
+
BOARD_TO_TEMPORARY_ELEMENTS.delete(board);
|
|
1403
|
+
}
|
|
1386
1404
|
|
|
1387
1405
|
class PlaitElementComponent {
|
|
1388
1406
|
constructor(renderer2, viewContainerRef) {
|
|
@@ -2123,5 +2141,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
2123
2141
|
* Generated bundle index. Do not edit.
|
|
2124
2142
|
*/
|
|
2125
2143
|
|
|
2126
|
-
export { BOARD_TO_COMPONENT, BOARD_TO_ELEMENT_HOST, BOARD_TO_HOST, BOARD_TO_MOVING_POINT, BOARD_TO_ON_CHANGE, BOARD_TO_ROUGH_SVG, BOARD_TO_SELECTED_ELEMENT, BoardTransforms, CLIP_BOARD_FORMAT_KEY, ELEMENT_TO_PLUGIN_COMPONENT, FLUSHING, IS_APPLE, IS_CHROME, IS_CHROME_LEGACY, IS_EDGE_LEGACY, IS_FIREFOX, IS_IOS, IS_SAFARI, IS_TEXT_EDITABLE, MAX_RADIUS, MERGING, NS, Path, PlaitBoard, PlaitBoardComponent, PlaitElement, PlaitElementComponent, PlaitHistoryBoard, PlaitModule, PlaitNode, PlaitOperation, PlaitPluginElementComponent, PlaitPointerType, PlaitToolbarComponent, RectangleClient, SAVING, SCROLL_BAR_WIDTH, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, Selection, Transforms, Viewport, addSelectedElement, arrowPoints, cacheSelectedElements, calcElementIntersectionSelection, clampZoomLevel, convertToViewportCoordinates, createG, createSVG, createText, depthFirstRecursion, distanceBetweenPointAndPoint, distanceBetweenPointAndRectangle, distanceBetweenPointAndSegment, drawArrow, drawRoundRectangle, getBoardClientBox, getBoardRectangle, getRectangleByElements, getRootGroupBBox, getSelectedElements, getViewportContainerBox, hasBeforeContextChange, hotkeys, idCreator, inverse, invertMatrix, invertViewportCoordinates, isNoSelectionElement, isNullOrUndefined, isSelectedElement, isSetViewportOperation, normalizePoint, removeSelectedElement, rotate, shouldClear, shouldMerge, shouldSave, toPoint, transformMat3, transformPoint, transformPoints };
|
|
2144
|
+
export { BOARD_TO_COMPONENT, BOARD_TO_ELEMENT_HOST, BOARD_TO_HOST, BOARD_TO_MOVING_POINT, BOARD_TO_ON_CHANGE, BOARD_TO_ROUGH_SVG, BOARD_TO_SELECTED_ELEMENT, BOARD_TO_TEMPORARY_ELEMENTS, BoardTransforms, CLIP_BOARD_FORMAT_KEY, ELEMENT_TO_PLUGIN_COMPONENT, FLUSHING, IS_APPLE, IS_CHROME, IS_CHROME_LEGACY, IS_EDGE_LEGACY, IS_FIREFOX, IS_IOS, IS_SAFARI, IS_TEXT_EDITABLE, MAX_RADIUS, MERGING, NS, Path, PlaitBoard, PlaitBoardComponent, PlaitElement, PlaitElementComponent, PlaitHistoryBoard, PlaitModule, PlaitNode, PlaitOperation, PlaitPluginElementComponent, PlaitPointerType, PlaitToolbarComponent, RectangleClient, SAVING, SCROLL_BAR_WIDTH, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, Selection, Transforms, Viewport, addSelectedElement, arrowPoints, cacheSelectedElements, calcElementIntersectionSelection, clampZoomLevel, convertToViewportCoordinates, createG, createSVG, createText, deleteTemporaryElements, depthFirstRecursion, distanceBetweenPointAndPoint, distanceBetweenPointAndRectangle, distanceBetweenPointAndSegment, drawArrow, drawRoundRectangle, getBoardClientBox, getBoardRectangle, getRectangleByElements, getRootGroupBBox, getSelectedElements, getTemporaryElements, getViewportContainerBox, hasBeforeContextChange, hotkeys, idCreator, inverse, invertMatrix, invertViewportCoordinates, isNoSelectionElement, isNullOrUndefined, isSelectedElement, isSetViewportOperation, normalizePoint, removeSelectedElement, rotate, shouldClear, shouldMerge, shouldSave, toPoint, transformMat3, transformPoint, transformPoints, withSelection };
|
|
2127
2145
|
//# sourceMappingURL=plait-core.mjs.map
|