@plait/core 0.29.0 → 0.30.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/esm2022/interfaces/board.mjs +1 -1
- package/esm2022/interfaces/rectangle-client.mjs +33 -2
- package/esm2022/interfaces/selection.mjs +1 -1
- package/esm2022/plugins/create-board.mjs +5 -3
- package/esm2022/plugins/with-moving.mjs +11 -10
- package/esm2022/plugins/with-selection.mjs +10 -10
- package/esm2022/transforms/general.mjs +2 -2
- package/esm2022/transforms/selection.mjs +2 -2
- package/esm2022/utils/selected-element.mjs +35 -33
- package/fesm2022/plait-core.mjs +90 -54
- package/fesm2022/plait-core.mjs.map +1 -1
- package/interfaces/board.d.ts +4 -2
- package/interfaces/rectangle-client.d.ts +11 -1
- package/interfaces/selection.d.ts +2 -5
- package/package.json +1 -1
- package/utils/selected-element.d.ts +4 -4
|
@@ -102,7 +102,7 @@ const applyToDraft = (board, selection, viewport, theme, op) => {
|
|
|
102
102
|
selection = op.newProperties;
|
|
103
103
|
}
|
|
104
104
|
else {
|
|
105
|
-
selection
|
|
105
|
+
selection = newProperties;
|
|
106
106
|
}
|
|
107
107
|
}
|
|
108
108
|
break;
|
|
@@ -143,4 +143,4 @@ export const GeneralTransforms = {
|
|
|
143
143
|
}
|
|
144
144
|
}
|
|
145
145
|
};
|
|
146
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"general.js","sourceRoot":"","sources":["../../../../packages/core/src/transforms/general.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitOperation } from '../interfaces/operation';\nimport { PlaitBoard } from '../interfaces/board';\nimport { createDraft, finishDraft, isDraft } from 'immer';\nimport { Viewport } from '../interfaces/viewport';\nimport { Selection } from '../interfaces/selection';\nimport { Ancestor, PlaitNode } from '../interfaces/node';\nimport { Path } from '../interfaces/path';\nimport { PlaitTheme } from '../interfaces/theme';\n\nexport interface GeneralTransforms {\n    transform: (board: PlaitBoard, op: PlaitOperation) => void;\n}\n\nconst applyToDraft = (board: PlaitBoard, selection: Selection | null, viewport: Viewport, theme: PlaitTheme, op: PlaitOperation) => {\n    switch (op.type) {\n        case 'insert_node': {\n            const { path, node } = op;\n            const parent = PlaitNode.parent(board, path);\n            const index = path[path.length - 1];\n\n            if (!parent.children || index > parent.children.length) {\n                throw new Error(\n                    `Cannot apply an \"insert_node\" operation at path [${path}] because the destination is past the end of the node.`\n                );\n            }\n\n            parent.children.splice(index, 0, node);\n            break;\n        }\n        case 'remove_node': {\n            const { path } = op;\n            const parent = PlaitNode.parent(board, path);\n            const index = path[path.length - 1];\n\n            if (!parent.children || index > parent.children.length) {\n                throw new Error(\n                    `Cannot apply an \"insert_node\" operation at path [${path}] because the destination is past the end of the node.`\n                );\n            }\n            parent.children.splice(index, 1);\n            break;\n        }\n        case 'move_node': {\n            const { path, newPath } = op;\n\n            if (Path.isAncestor(path, newPath)) {\n                throw new Error(`Cannot move a path [${path}] to new path [${newPath}] because the destination is inside itself.`);\n            }\n\n            const node = PlaitNode.get(board, path);\n            const parent = PlaitNode.parent(board, path);\n            const index = path[path.length - 1];\n\n            // This is tricky, but since the `path` and `newPath` both refer to\n            // the same snapshot in time, there's a mismatch. After either\n            // removing the original position, the second step's path can be out\n            // of date. So instead of using the `op.newPath` directly, we\n            // transform `op.path` to ascertain what the `newPath` would be after\n            // the operation was applied.\n            parent.children?.splice(index, 1);\n            const truePath = Path.transform(path, op)!;\n            const newParent = PlaitNode.get(board, Path.parent(truePath)) as Ancestor;\n            const newIndex = truePath[truePath.length - 1];\n\n            newParent.children?.splice(newIndex, 0, node);\n            break;\n        }\n        case 'set_node': {\n            const { path, properties, newProperties } = op;\n\n            if (path.length === 0) {\n                throw new Error(`Cannot set properties on the root node!`);\n            }\n\n            const node = PlaitNode.get(board, path);\n\n            for (const key in newProperties) {\n                const value = newProperties[key];\n\n                if (value == null) {\n                    delete node[key];\n                } else {\n                    node[key] = value;\n                }\n            }\n\n            // properties that were previously defined, but are now missing, must be deleted\n            for (const key in properties) {\n                if (!newProperties.hasOwnProperty(key)) {\n                    delete node[key];\n                }\n            }\n\n            break;\n        }\n        case 'set_viewport': {\n            const { newProperties } = op;\n            if (newProperties == null) {\n                viewport = newProperties;\n            } else {\n                if (viewport == null) {\n                    if (!Viewport.isViewport(newProperties)) {\n                        throw new Error(\n                            `Cannot apply an incomplete \"set_viewport\" operation properties ${JSON.stringify(\n                                newProperties\n                            )} when there is no current viewport.`\n                        );\n                    }\n                    viewport = { ...newProperties };\n                }\n\n                for (const key in newProperties) {\n                    const value = newProperties[key];\n\n                    if (value == null) {\n                        delete viewport[key];\n                    } else {\n                        viewport[key] = value;\n                    }\n                }\n            }\n            break;\n        }\n        case 'set_selection': {\n            const { newProperties } = op;\n            if (newProperties == null) {\n                selection = newProperties;\n            } else {\n                if (selection === null) {\n                    selection = op.newProperties;\n                } else {\n                    selection.ranges = newProperties.ranges;\n                }\n            }\n            break;\n        }\n        case 'set_theme': {\n            const { newProperties } = op;\n            theme = newProperties as PlaitTheme;\n            break;\n        }\n    }\n    return { selection, viewport, theme };\n};\n\nexport const GeneralTransforms: GeneralTransforms = {\n    /**\n     * Transform the board by an operation.\n     */\n    transform(board: PlaitBoard, op: PlaitOperation): void {\n        board.children = createDraft(board.children);\n        let viewport = board.viewport && createDraft(board.viewport);\n        let selection = board.selection && createDraft(board.selection);\n        let theme = board.theme && createDraft(board.theme);\n\n        try {\n            const state = applyToDraft(board, selection, viewport, theme, op);\n            viewport = state.viewport;\n            selection = state.selection;\n            theme = state.theme;\n        } finally {\n            board.children = finishDraft(board.children);\n\n            if (selection) {\n                board.selection = isDraft(selection) ? (finishDraft(selection) as Selection) : selection;\n            } else {\n                board.selection = null;\n            }\n\n            board.viewport = isDraft(viewport) ? (finishDraft(viewport) as Viewport) : viewport;\n            board.theme = isDraft(theme) ? finishDraft(theme) : theme;\n        }\n    }\n};\n"]}
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"general.js","sourceRoot":"","sources":["../../../../packages/core/src/transforms/general.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitOperation } from '../interfaces/operation';\nimport { PlaitBoard } from '../interfaces/board';\nimport { createDraft, finishDraft, isDraft } from 'immer';\nimport { Viewport } from '../interfaces/viewport';\nimport { Selection } from '../interfaces/selection';\nimport { Ancestor, PlaitNode } from '../interfaces/node';\nimport { Path } from '../interfaces/path';\nimport { PlaitTheme } from '../interfaces/theme';\n\nexport interface GeneralTransforms {\n    transform: (board: PlaitBoard, op: PlaitOperation) => void;\n}\n\nconst applyToDraft = (board: PlaitBoard, selection: Selection | null, viewport: Viewport, theme: PlaitTheme, op: PlaitOperation) => {\n    switch (op.type) {\n        case 'insert_node': {\n            const { path, node } = op;\n            const parent = PlaitNode.parent(board, path);\n            const index = path[path.length - 1];\n\n            if (!parent.children || index > parent.children.length) {\n                throw new Error(\n                    `Cannot apply an \"insert_node\" operation at path [${path}] because the destination is past the end of the node.`\n                );\n            }\n\n            parent.children.splice(index, 0, node);\n            break;\n        }\n        case 'remove_node': {\n            const { path } = op;\n            const parent = PlaitNode.parent(board, path);\n            const index = path[path.length - 1];\n\n            if (!parent.children || index > parent.children.length) {\n                throw new Error(\n                    `Cannot apply an \"insert_node\" operation at path [${path}] because the destination is past the end of the node.`\n                );\n            }\n            parent.children.splice(index, 1);\n            break;\n        }\n        case 'move_node': {\n            const { path, newPath } = op;\n\n            if (Path.isAncestor(path, newPath)) {\n                throw new Error(`Cannot move a path [${path}] to new path [${newPath}] because the destination is inside itself.`);\n            }\n\n            const node = PlaitNode.get(board, path);\n            const parent = PlaitNode.parent(board, path);\n            const index = path[path.length - 1];\n\n            // This is tricky, but since the `path` and `newPath` both refer to\n            // the same snapshot in time, there's a mismatch. After either\n            // removing the original position, the second step's path can be out\n            // of date. So instead of using the `op.newPath` directly, we\n            // transform `op.path` to ascertain what the `newPath` would be after\n            // the operation was applied.\n            parent.children?.splice(index, 1);\n            const truePath = Path.transform(path, op)!;\n            const newParent = PlaitNode.get(board, Path.parent(truePath)) as Ancestor;\n            const newIndex = truePath[truePath.length - 1];\n\n            newParent.children?.splice(newIndex, 0, node);\n            break;\n        }\n        case 'set_node': {\n            const { path, properties, newProperties } = op;\n\n            if (path.length === 0) {\n                throw new Error(`Cannot set properties on the root node!`);\n            }\n\n            const node = PlaitNode.get(board, path);\n\n            for (const key in newProperties) {\n                const value = newProperties[key];\n\n                if (value == null) {\n                    delete node[key];\n                } else {\n                    node[key] = value;\n                }\n            }\n\n            // properties that were previously defined, but are now missing, must be deleted\n            for (const key in properties) {\n                if (!newProperties.hasOwnProperty(key)) {\n                    delete node[key];\n                }\n            }\n\n            break;\n        }\n        case 'set_viewport': {\n            const { newProperties } = op;\n            if (newProperties == null) {\n                viewport = newProperties;\n            } else {\n                if (viewport == null) {\n                    if (!Viewport.isViewport(newProperties)) {\n                        throw new Error(\n                            `Cannot apply an incomplete \"set_viewport\" operation properties ${JSON.stringify(\n                                newProperties\n                            )} when there is no current viewport.`\n                        );\n                    }\n                    viewport = { ...newProperties };\n                }\n\n                for (const key in newProperties) {\n                    const value = newProperties[key];\n\n                    if (value == null) {\n                        delete viewport[key];\n                    } else {\n                        viewport[key] = value;\n                    }\n                }\n            }\n            break;\n        }\n        case 'set_selection': {\n            const { newProperties } = op;\n            if (newProperties == null) {\n                selection = newProperties;\n            } else {\n                if (selection === null) {\n                    selection = op.newProperties;\n                } else {\n                    selection = newProperties;\n                }\n            }\n            break;\n        }\n        case 'set_theme': {\n            const { newProperties } = op;\n            theme = newProperties as PlaitTheme;\n            break;\n        }\n    }\n    return { selection, viewport, theme };\n};\n\nexport const GeneralTransforms: GeneralTransforms = {\n    /**\n     * Transform the board by an operation.\n     */\n    transform(board: PlaitBoard, op: PlaitOperation): void {\n        board.children = createDraft(board.children);\n        let viewport = board.viewport && createDraft(board.viewport);\n        let selection = board.selection && createDraft(board.selection);\n        let theme = board.theme && createDraft(board.theme);\n\n        try {\n            const state = applyToDraft(board, selection, viewport, theme, op);\n            viewport = state.viewport;\n            selection = state.selection;\n            theme = state.theme;\n        } finally {\n            board.children = finishDraft(board.children);\n\n            if (selection) {\n                board.selection = isDraft(selection) ? (finishDraft(selection) as Selection) : selection;\n            } else {\n                board.selection = null;\n            }\n\n            board.viewport = isDraft(viewport) ? (finishDraft(viewport) as Viewport) : viewport;\n            board.theme = isDraft(theme) ? finishDraft(theme) : theme;\n        }\n    }\n};\n"]}
|
|
@@ -10,7 +10,7 @@ export const SelectionTransforms = {
|
|
|
10
10
|
};
|
|
11
11
|
export function addSelectionWithTemporaryElements(board, elements) {
|
|
12
12
|
const timeoutId = setTimeout(() => {
|
|
13
|
-
setSelection(board,
|
|
13
|
+
setSelection(board, null);
|
|
14
14
|
}, 0);
|
|
15
15
|
let ref = getTemporaryRef(board);
|
|
16
16
|
if (ref) {
|
|
@@ -23,4 +23,4 @@ export function addSelectionWithTemporaryElements(board, elements) {
|
|
|
23
23
|
BOARD_TO_TEMPORARY_ELEMENTS.set(board, { timeoutId, elements });
|
|
24
24
|
}
|
|
25
25
|
}
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvdHJhbnNmb3Jtcy9zZWxlY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFakUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBRTVELE1BQU0sVUFBVSxZQUFZLENBQUMsS0FBaUIsRUFBRSxTQUEyQjtJQUN2RSxNQUFNLFNBQVMsR0FBMEIsRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFLFVBQVUsRUFBRSxLQUFLLENBQUMsU0FBUyxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsQ0FBQztJQUMxSCxLQUFLLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQzNCLENBQUM7QUFPRCxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBd0I7SUFDcEQsWUFBWTtJQUNaLGlDQUFpQztDQUNwQyxDQUFDO0FBRUYsTUFBTSxVQUFVLGlDQUFpQyxDQUFDLEtBQWlCLEVBQUUsUUFBd0I7SUFDekYsTUFBTSxTQUFTLEdBQUcsVUFBVSxDQUFDLEdBQUcsRUFBRTtRQUM5QixZQUFZLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzlCLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUNOLElBQUksR0FBRyxHQUFHLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNqQyxJQUFJLEdBQUcsRUFBRTtRQUNMLFlBQVksQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDNUIsTUFBTSxlQUFlLEdBQUcsR0FBRyxDQUFDLFFBQVEsQ0FBQztRQUNyQyxHQUFHLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxHQUFHLFFBQVEsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3JGLEdBQUcsQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO0tBQzdCO1NBQU07UUFDSCwyQkFBMkIsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUM7S0FDbkU7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2V0U2VsZWN0aW9uT3BlcmF0aW9uIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9vcGVyYXRpb24nO1xuaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJy4uL2ludGVyZmFjZXMvYm9hcmQnO1xuaW1wb3J0IHsgU2VsZWN0aW9uIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9zZWxlY3Rpb24nO1xuaW1wb3J0IHsgQk9BUkRfVE9fVEVNUE9SQVJZX0VMRU1FTlRTIH0gZnJvbSAnLi4vdXRpbHMvd2Vhay1tYXBzJztcbmltcG9ydCB7IFBsYWl0RWxlbWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMvZWxlbWVudCc7XG5pbXBvcnQgeyBnZXRUZW1wb3JhcnlSZWYgfSBmcm9tICcuLi9wbHVnaW5zL3dpdGgtc2VsZWN0aW9uJztcblxuZXhwb3J0IGZ1bmN0aW9uIHNldFNlbGVjdGlvbihib2FyZDogUGxhaXRCb2FyZCwgc2VsZWN0aW9uOiBTZWxlY3Rpb24gfCBudWxsKSB7XG4gICAgY29uc3Qgb3BlcmF0aW9uOiBTZXRTZWxlY3Rpb25PcGVyYXRpb24gPSB7IHR5cGU6ICdzZXRfc2VsZWN0aW9uJywgcHJvcGVydGllczogYm9hcmQuc2VsZWN0aW9uLCBuZXdQcm9wZXJ0aWVzOiBzZWxlY3Rpb24gfTtcbiAgICBib2FyZC5hcHBseShvcGVyYXRpb24pO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNlbGVjdGlvblRyYW5zZm9ybXMge1xuICAgIHNldFNlbGVjdGlvbjogKGJvYXJkOiBQbGFpdEJvYXJkLCBzZWxlY3Rpb246IFNlbGVjdGlvbiB8IG51bGwpID0+IHZvaWQ7XG4gICAgYWRkU2VsZWN0aW9uV2l0aFRlbXBvcmFyeUVsZW1lbnRzOiAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnRzOiBQbGFpdEVsZW1lbnRbXSkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGNvbnN0IFNlbGVjdGlvblRyYW5zZm9ybXM6IFNlbGVjdGlvblRyYW5zZm9ybXMgPSB7XG4gICAgc2V0U2VsZWN0aW9uLFxuICAgIGFkZFNlbGVjdGlvbldpdGhUZW1wb3JhcnlFbGVtZW50c1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIGFkZFNlbGVjdGlvbldpdGhUZW1wb3JhcnlFbGVtZW50cyhib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudHM6IFBsYWl0RWxlbWVudFtdKSB7XG4gICAgY29uc3QgdGltZW91dElkID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgIHNldFNlbGVjdGlvbihib2FyZCwgbnVsbCk7XG4gICAgfSwgMCk7XG4gICAgbGV0IHJlZiA9IGdldFRlbXBvcmFyeVJlZihib2FyZCk7XG4gICAgaWYgKHJlZikge1xuICAgICAgICBjbGVhclRpbWVvdXQocmVmLnRpbWVvdXRJZCk7XG4gICAgICAgIGNvbnN0IGN1cnJlbnRFbGVtZW50cyA9IHJlZi5lbGVtZW50cztcbiAgICAgICAgcmVmLmVsZW1lbnRzLnB1c2goLi4uZWxlbWVudHMuZmlsdGVyKGVsZW1lbnQgPT4gIWN1cnJlbnRFbGVtZW50cy5pbmNsdWRlcyhlbGVtZW50KSkpO1xuICAgICAgICByZWYudGltZW91dElkID0gdGltZW91dElkO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIEJPQVJEX1RPX1RFTVBPUkFSWV9FTEVNRU5UUy5zZXQoYm9hcmQsIHsgdGltZW91dElkLCBlbGVtZW50cyB9KTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -2,43 +2,45 @@ import { PlaitBoard } from '../interfaces/board';
|
|
|
2
2
|
import { depthFirstRecursion, getIsRecursionFunc } from './tree';
|
|
3
3
|
import { BOARD_TO_SELECTED_ELEMENT } from './weak-maps';
|
|
4
4
|
import { Selection } from '../interfaces/selection';
|
|
5
|
-
export const
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
const isCollapsed =
|
|
5
|
+
export const getHitElementsBySelection = (board, selection, match = () => true) => {
|
|
6
|
+
const newSelection = selection || board.selection;
|
|
7
|
+
const rectangleHitElements = [];
|
|
8
|
+
const isCollapsed = newSelection && Selection.isCollapsed(newSelection);
|
|
9
|
+
if (isCollapsed) {
|
|
10
|
+
const hitElement = getHitElementByPoint(board, newSelection.anchor, match);
|
|
11
|
+
if (hitElement) {
|
|
12
|
+
return [hitElement];
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
return [];
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
depthFirstRecursion(board, node => {
|
|
19
|
+
if (!PlaitBoard.isBoard(node) && match(node) && board.isRectangleHit(node, newSelection)) {
|
|
20
|
+
rectangleHitElements.push(node);
|
|
21
|
+
}
|
|
22
|
+
}, getIsRecursionFunc(board), true);
|
|
23
|
+
return rectangleHitElements;
|
|
24
|
+
};
|
|
25
|
+
export const getHitElementByPoint = (board, point, match = () => true) => {
|
|
26
|
+
let rectangleHitElement = undefined;
|
|
27
|
+
let hitElement = undefined;
|
|
9
28
|
depthFirstRecursion(board, node => {
|
|
10
|
-
if (
|
|
29
|
+
if (hitElement) {
|
|
11
30
|
return;
|
|
12
31
|
}
|
|
13
|
-
if (
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
32
|
+
if (PlaitBoard.isBoard(node) || !match(node)) {
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
if (board.isHit(node, point)) {
|
|
36
|
+
hitElement = node;
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
if (!rectangleHitElement && board.isRectangleHit(node, { anchor: point, focus: point })) {
|
|
40
|
+
rectangleHitElement = node;
|
|
20
41
|
}
|
|
21
42
|
}, getIsRecursionFunc(board), true);
|
|
22
|
-
return
|
|
23
|
-
};
|
|
24
|
-
export const getHitElementOfRoot = (board, rootElements, range) => {
|
|
25
|
-
const newRootElements = [...rootElements].reverse();
|
|
26
|
-
return newRootElements.find(item => {
|
|
27
|
-
return board.isHitSelection(item, range);
|
|
28
|
-
});
|
|
29
|
-
};
|
|
30
|
-
export const isHitElements = (board, elements, ranges) => {
|
|
31
|
-
let isIntersectionElements = false;
|
|
32
|
-
if (elements.length) {
|
|
33
|
-
elements.map(item => {
|
|
34
|
-
if (!isIntersectionElements) {
|
|
35
|
-
isIntersectionElements = ranges.some(range => {
|
|
36
|
-
return board.isHitSelection(item, range);
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
});
|
|
40
|
-
}
|
|
41
|
-
return isIntersectionElements;
|
|
43
|
+
return hitElement || rectangleHitElement;
|
|
42
44
|
};
|
|
43
45
|
export const cacheSelectedElements = (board, selectedElements) => {
|
|
44
46
|
BOARD_TO_SELECTED_ELEMENT.set(board, selectedElements);
|
|
@@ -62,4 +64,4 @@ export const isSelectedElement = (board, element) => {
|
|
|
62
64
|
const selectedElements = getSelectedElements(board);
|
|
63
65
|
return !!selectedElements.find(value => value === element);
|
|
64
66
|
};
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selected-element.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/selected-element.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard } from '../interfaces/board';\nimport { Ancestor } from '../interfaces/node';\nimport { depthFirstRecursion, getIsRecursionFunc } from './tree';\nimport { BOARD_TO_SELECTED_ELEMENT } from './weak-maps';\nimport { Selection } from '../interfaces/selection';\nimport { PlaitElement } from '../interfaces/element';\nimport { Point } from '../interfaces/point';\n\nexport const getHitElementsBySelection = (\n    board: PlaitBoard,\n    selection?: Selection,\n    match: (element: PlaitElement) => boolean = () => true\n) => {\n    const newSelection = selection || board.selection as Selection;\n    const rectangleHitElements: PlaitElement[] = [];\n    const isCollapsed = newSelection && Selection.isCollapsed(newSelection);\n    if (isCollapsed) {\n        const hitElement = getHitElementByPoint(board, newSelection.anchor, match);\n        if (hitElement) {\n            return [hitElement];\n        } else {\n            return [];\n        }\n    }\n    depthFirstRecursion<Ancestor>(\n        board,\n        node => {\n            if (!PlaitBoard.isBoard(node) && match(node) && board.isRectangleHit(node, newSelection)) {\n                rectangleHitElements.push(node);\n            }\n        },\n        getIsRecursionFunc(board),\n        true\n    );\n    return rectangleHitElements;\n};\n\nexport const getHitElementByPoint = (\n    board: PlaitBoard,\n    point: Point,\n    match: (element: PlaitElement) => boolean = () => true\n): undefined | PlaitElement => {\n    let rectangleHitElement: PlaitElement | undefined = undefined;\n    let hitElement: PlaitElement | undefined = undefined;\n    depthFirstRecursion<Ancestor>(\n        board,\n        node => {\n            if (hitElement) {\n                return;\n            }\n            if (PlaitBoard.isBoard(node) || !match(node)) {\n                return;\n            }\n            if (board.isHit(node, point)) {\n                hitElement = node;\n                return;\n            }\n            if (!rectangleHitElement && board.isRectangleHit(node, { anchor: point, focus: point })) {\n                rectangleHitElement = node;\n            }\n        },\n        getIsRecursionFunc(board),\n        true\n    );\n    return hitElement || rectangleHitElement;\n};\n\nexport const cacheSelectedElements = (board: PlaitBoard, selectedElements: PlaitElement[]) => {\n    BOARD_TO_SELECTED_ELEMENT.set(board, selectedElements);\n};\n\nexport const getSelectedElements = (board: PlaitBoard) => {\n    return BOARD_TO_SELECTED_ELEMENT.get(board) || [];\n};\n\nexport const addSelectedElement = (board: PlaitBoard, element: PlaitElement) => {\n    const selectedElements = getSelectedElements(board);\n    cacheSelectedElements(board, [...selectedElements, element]);\n};\n\nexport const removeSelectedElement = (board: PlaitBoard, element: PlaitElement) => {\n    const selectedElements = getSelectedElements(board);\n    const newSelectedElements = selectedElements.filter(value => value !== element);\n    cacheSelectedElements(board, newSelectedElements);\n};\n\nexport const clearSelectedElement = (board: PlaitBoard) => {\n    cacheSelectedElements(board, []);\n};\n\nexport const isSelectedElement = (board: PlaitBoard, element: PlaitElement) => {\n    const selectedElements = getSelectedElements(board);\n    return !!selectedElements.find(value => value === element);\n};\n"]}
|
package/fesm2022/plait-core.mjs
CHANGED
|
@@ -75,43 +75,45 @@ const Selection = {
|
|
|
75
75
|
}
|
|
76
76
|
};
|
|
77
77
|
|
|
78
|
-
const
|
|
79
|
-
const
|
|
80
|
-
const
|
|
81
|
-
const isCollapsed =
|
|
78
|
+
const getHitElementsBySelection = (board, selection, match = () => true) => {
|
|
79
|
+
const newSelection = selection || board.selection;
|
|
80
|
+
const rectangleHitElements = [];
|
|
81
|
+
const isCollapsed = newSelection && Selection.isCollapsed(newSelection);
|
|
82
|
+
if (isCollapsed) {
|
|
83
|
+
const hitElement = getHitElementByPoint(board, newSelection.anchor, match);
|
|
84
|
+
if (hitElement) {
|
|
85
|
+
return [hitElement];
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
return [];
|
|
89
|
+
}
|
|
90
|
+
}
|
|
82
91
|
depthFirstRecursion(board, node => {
|
|
83
|
-
if (
|
|
92
|
+
if (!PlaitBoard.isBoard(node) && match(node) && board.isRectangleHit(node, newSelection)) {
|
|
93
|
+
rectangleHitElements.push(node);
|
|
94
|
+
}
|
|
95
|
+
}, getIsRecursionFunc(board), true);
|
|
96
|
+
return rectangleHitElements;
|
|
97
|
+
};
|
|
98
|
+
const getHitElementByPoint = (board, point, match = () => true) => {
|
|
99
|
+
let rectangleHitElement = undefined;
|
|
100
|
+
let hitElement = undefined;
|
|
101
|
+
depthFirstRecursion(board, node => {
|
|
102
|
+
if (hitElement) {
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
if (PlaitBoard.isBoard(node) || !match(node)) {
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
if (board.isHit(node, point)) {
|
|
109
|
+
hitElement = node;
|
|
84
110
|
return;
|
|
85
111
|
}
|
|
86
|
-
if (!
|
|
87
|
-
|
|
88
|
-
realSelection &&
|
|
89
|
-
realSelection.ranges.some(range => {
|
|
90
|
-
return board.isHitSelection(node, range);
|
|
91
|
-
})) {
|
|
92
|
-
selectedElements.push(node);
|
|
112
|
+
if (!rectangleHitElement && board.isRectangleHit(node, { anchor: point, focus: point })) {
|
|
113
|
+
rectangleHitElement = node;
|
|
93
114
|
}
|
|
94
115
|
}, getIsRecursionFunc(board), true);
|
|
95
|
-
return
|
|
96
|
-
};
|
|
97
|
-
const getHitElementOfRoot = (board, rootElements, range) => {
|
|
98
|
-
const newRootElements = [...rootElements].reverse();
|
|
99
|
-
return newRootElements.find(item => {
|
|
100
|
-
return board.isHitSelection(item, range);
|
|
101
|
-
});
|
|
102
|
-
};
|
|
103
|
-
const isHitElements = (board, elements, ranges) => {
|
|
104
|
-
let isIntersectionElements = false;
|
|
105
|
-
if (elements.length) {
|
|
106
|
-
elements.map(item => {
|
|
107
|
-
if (!isIntersectionElements) {
|
|
108
|
-
isIntersectionElements = ranges.some(range => {
|
|
109
|
-
return board.isHitSelection(item, range);
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
return isIntersectionElements;
|
|
116
|
+
return hitElement || rectangleHitElement;
|
|
115
117
|
};
|
|
116
118
|
const cacheSelectedElements = (board, selectedElements) => {
|
|
117
119
|
BOARD_TO_SELECTED_ELEMENT.set(board, selectedElements);
|
|
@@ -443,12 +445,24 @@ const ELEMENT_TO_COMPONENT = new WeakMap();
|
|
|
443
445
|
|
|
444
446
|
const RectangleClient = {
|
|
445
447
|
isHit: (origin, target) => {
|
|
448
|
+
return RectangleClient.isHitX(origin, target) && RectangleClient.isHitY(origin, target);
|
|
449
|
+
},
|
|
450
|
+
isHitX: (origin, target) => {
|
|
446
451
|
const minX = origin.x < target.x ? origin.x : target.x;
|
|
447
452
|
const maxX = origin.x + origin.width > target.x + target.width ? origin.x + origin.width : target.x + target.width;
|
|
453
|
+
// float calculate error( eg: 1.4210854715202004e-14 > 0)
|
|
454
|
+
if (Math.floor(maxX - minX - origin.width - target.width) <= 0) {
|
|
455
|
+
return true;
|
|
456
|
+
}
|
|
457
|
+
else {
|
|
458
|
+
return false;
|
|
459
|
+
}
|
|
460
|
+
},
|
|
461
|
+
isHitY: (origin, target) => {
|
|
448
462
|
const minY = origin.y < target.y ? origin.y : target.y;
|
|
449
463
|
const maxY = origin.y + origin.height > target.y + target.height ? origin.y + origin.height : target.y + target.height;
|
|
450
464
|
// float calculate error( eg: 1.4210854715202004e-14 > 0)
|
|
451
|
-
if (Math.floor(
|
|
465
|
+
if (Math.floor(maxY - minY - origin.height - target.height) <= 0) {
|
|
452
466
|
return true;
|
|
453
467
|
}
|
|
454
468
|
else {
|
|
@@ -506,6 +520,25 @@ const RectangleClient = {
|
|
|
506
520
|
},
|
|
507
521
|
getConnectionPoint: (rectangle, point) => {
|
|
508
522
|
return [rectangle.x + rectangle.width * point[0], rectangle.y + rectangle.height * point[1]];
|
|
523
|
+
},
|
|
524
|
+
expand(rectangle, left, top = left, right = left, bottom = top) {
|
|
525
|
+
return {
|
|
526
|
+
x: rectangle.x - left,
|
|
527
|
+
y: rectangle.y - top,
|
|
528
|
+
width: rectangle.width + left + right,
|
|
529
|
+
height: rectangle.height + top + bottom
|
|
530
|
+
};
|
|
531
|
+
},
|
|
532
|
+
getGapCenter(rectangle1, rectangle2, isHorizontal) {
|
|
533
|
+
const axis = isHorizontal ? 'y' : 'x';
|
|
534
|
+
const side = isHorizontal ? 'height' : 'width';
|
|
535
|
+
const align = [rectangle1[axis], rectangle1[axis] + rectangle1[side], rectangle2[axis], rectangle2[axis] + rectangle2[side]];
|
|
536
|
+
const sortArr = align.sort((a, b) => a - b);
|
|
537
|
+
return (sortArr[1] + sortArr[2]) / 2;
|
|
538
|
+
},
|
|
539
|
+
isPointInRectangle(rectangle, point) {
|
|
540
|
+
const x = point[0], y = point[1];
|
|
541
|
+
return x > rectangle.x && x < rectangle.x + rectangle.width && y > rectangle.y && y < rectangle.y + rectangle.height;
|
|
509
542
|
}
|
|
510
543
|
};
|
|
511
544
|
|
|
@@ -2160,7 +2193,7 @@ const applyToDraft = (board, selection, viewport, theme, op) => {
|
|
|
2160
2193
|
selection = op.newProperties;
|
|
2161
2194
|
}
|
|
2162
2195
|
else {
|
|
2163
|
-
selection
|
|
2196
|
+
selection = newProperties;
|
|
2164
2197
|
}
|
|
2165
2198
|
}
|
|
2166
2199
|
break;
|
|
@@ -2257,22 +2290,22 @@ function withSelection(board) {
|
|
|
2257
2290
|
}
|
|
2258
2291
|
const options = board.getPluginOptions(PlaitPluginKey.withSelection);
|
|
2259
2292
|
const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
2260
|
-
const
|
|
2261
|
-
const
|
|
2293
|
+
const selection = { anchor: point, focus: point };
|
|
2294
|
+
const hitElement = getHitElementByPoint(board, point);
|
|
2262
2295
|
const selectedElements = getSelectedElements(board);
|
|
2263
|
-
if (
|
|
2296
|
+
if (hitElement && selectedElements.includes(hitElement) && !options.isDisabledSelect) {
|
|
2264
2297
|
pointerDown(event);
|
|
2265
2298
|
return;
|
|
2266
2299
|
}
|
|
2267
2300
|
if (PlaitBoard.isPointer(board, PlaitPointerType.selection) &&
|
|
2268
|
-
|
|
2301
|
+
!hitElement &&
|
|
2269
2302
|
options.isMultiple &&
|
|
2270
2303
|
!options.isDisabledSelect) {
|
|
2271
2304
|
selectionRectangleG?.remove();
|
|
2272
2305
|
start = point;
|
|
2273
2306
|
preventTouchMove(board, event, true);
|
|
2274
2307
|
}
|
|
2275
|
-
Transforms.setSelection(board,
|
|
2308
|
+
Transforms.setSelection(board, selection);
|
|
2276
2309
|
pointerDown(event);
|
|
2277
2310
|
};
|
|
2278
2311
|
board.globalPointerMove = (event) => {
|
|
@@ -2288,7 +2321,7 @@ function withSelection(board) {
|
|
|
2288
2321
|
end = movedTarget;
|
|
2289
2322
|
throttleRAF(() => {
|
|
2290
2323
|
if (start && end) {
|
|
2291
|
-
Transforms.setSelection(board, {
|
|
2324
|
+
Transforms.setSelection(board, { anchor: start, focus: end });
|
|
2292
2325
|
}
|
|
2293
2326
|
});
|
|
2294
2327
|
setSelectionMoving(board);
|
|
@@ -2307,7 +2340,7 @@ function withSelection(board) {
|
|
|
2307
2340
|
if (start && end) {
|
|
2308
2341
|
selectionMovingG?.remove();
|
|
2309
2342
|
clearSelectionMoving(board);
|
|
2310
|
-
Transforms.setSelection(board, {
|
|
2343
|
+
Transforms.setSelection(board, { anchor: start, focus: end });
|
|
2311
2344
|
}
|
|
2312
2345
|
if (PlaitBoard.isFocus(board)) {
|
|
2313
2346
|
const isInBoard = event.target instanceof Node && PlaitBoard.getBoardContainer(board).contains(event.target);
|
|
@@ -2336,7 +2369,7 @@ function withSelection(board) {
|
|
|
2336
2369
|
if (board.operations.find(value => value.type === 'set_selection')) {
|
|
2337
2370
|
selectionRectangleG?.remove();
|
|
2338
2371
|
const temporaryElements = getTemporaryElements(board);
|
|
2339
|
-
let elements = temporaryElements ? temporaryElements :
|
|
2372
|
+
let elements = temporaryElements ? temporaryElements : getHitElementsBySelection(board);
|
|
2340
2373
|
if (!options.isMultiple && elements.length > 1) {
|
|
2341
2374
|
elements = [elements[0]];
|
|
2342
2375
|
}
|
|
@@ -2429,7 +2462,7 @@ const SelectionTransforms = {
|
|
|
2429
2462
|
};
|
|
2430
2463
|
function addSelectionWithTemporaryElements(board, elements) {
|
|
2431
2464
|
const timeoutId = setTimeout(() => {
|
|
2432
|
-
setSelection(board,
|
|
2465
|
+
setSelection(board, null);
|
|
2433
2466
|
}, 0);
|
|
2434
2467
|
let ref = getTemporaryRef(board);
|
|
2435
2468
|
if (ref) {
|
|
@@ -2692,7 +2725,8 @@ function createBoard(children, options) {
|
|
|
2692
2725
|
redrawElement: (context, previousContext) => { },
|
|
2693
2726
|
destroyElement: (context) => { },
|
|
2694
2727
|
isWithinSelection: element => false,
|
|
2695
|
-
|
|
2728
|
+
isRectangleHit: element => false,
|
|
2729
|
+
isHit: element => false,
|
|
2696
2730
|
isRecursion: element => true,
|
|
2697
2731
|
isMovable: element => false,
|
|
2698
2732
|
getRectangle: element => null,
|
|
@@ -2705,7 +2739,8 @@ function createBoard(children, options) {
|
|
|
2705
2739
|
pointerOut: pointer => { },
|
|
2706
2740
|
pointerLeave: pointer => { },
|
|
2707
2741
|
globalPointerMove: pointer => { },
|
|
2708
|
-
globalPointerUp: pointer => { }
|
|
2742
|
+
globalPointerUp: pointer => { },
|
|
2743
|
+
isImageBindingAllowed: (element) => false,
|
|
2709
2744
|
};
|
|
2710
2745
|
return board;
|
|
2711
2746
|
}
|
|
@@ -3265,17 +3300,18 @@ function withMoving(board) {
|
|
|
3265
3300
|
board.pointerDown = (event) => {
|
|
3266
3301
|
const host = BOARD_TO_HOST.get(board);
|
|
3267
3302
|
const point = transformPoint(board, toPoint(event.x, event.y, host));
|
|
3268
|
-
const range = { anchor: point, focus: point };
|
|
3269
3303
|
let movableElements = board.children.filter(item => board.isMovable(item));
|
|
3270
3304
|
if (movableElements.length && !isPreventTouchMove(board)) {
|
|
3271
3305
|
startPoint = point;
|
|
3272
|
-
const
|
|
3273
|
-
const hitElement =
|
|
3274
|
-
if (hitElement &&
|
|
3275
|
-
|
|
3276
|
-
|
|
3277
|
-
|
|
3278
|
-
|
|
3306
|
+
const selectedMovableElements = getSelectedElements(board).filter(item => movableElements.includes(item));
|
|
3307
|
+
const hitElement = getHitElementByPoint(board, point);
|
|
3308
|
+
if (hitElement && movableElements.includes(hitElement)) {
|
|
3309
|
+
if (selectedMovableElements.includes(hitElement)) {
|
|
3310
|
+
activeElements = selectedMovableElements;
|
|
3311
|
+
}
|
|
3312
|
+
else {
|
|
3313
|
+
activeElements = [hitElement];
|
|
3314
|
+
}
|
|
3279
3315
|
}
|
|
3280
3316
|
if (activeElements.length > 0) {
|
|
3281
3317
|
preventTouchMove(board, event, true);
|
|
@@ -4222,5 +4258,5 @@ function createModModifierKeys() {
|
|
|
4222
4258
|
* Generated bundle index. Do not edit.
|
|
4223
4259
|
*/
|
|
4224
4260
|
|
|
4225
|
-
export { A, ACTIVE_STROKE_WIDTH, ALT, APOSTROPHE, ATTACHED_ELEMENT_CLASS_NAME, AT_SIGN, B, BACKSLASH, BACKSPACE, BOARD_TO_COMPONENT, BOARD_TO_ELEMENT_HOST, BOARD_TO_HOST, BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_MOVING_ELEMENT, BOARD_TO_MOVING_POINT, BOARD_TO_MOVING_POINT_IN_BOARD, BOARD_TO_ON_CHANGE, BOARD_TO_ROUGH_SVG, BOARD_TO_SELECTED_ELEMENT, BOARD_TO_TEMPORARY_ELEMENTS, BOARD_TO_TOUCH_REF, BOARD_TO_VIEWPORT_ORIGINATION, BoardTransforms, C, CAPS_LOCK, CLIP_BOARD_FORMAT_KEY, CLOSE_SQUARE_BRACKET, COMMA, CONTEXT_MENU, CONTROL, ColorfulThemeColor, CoreTransforms, D, DASH, DELETE, DOWN_ARROW, DarkThemeColor, DefaultThemeColor, Direction, E, EIGHT, ELEMENT_TO_COMPONENT, END, ENTER, EQUALS, ESCAPE, F, F1, F10, F11, F12, F2, F3, F4, F5, F6, F7, F8, F9, FF_EQUALS, FF_MINUS, FF_MUTE, FF_SEMICOLON, FF_VOLUME_DOWN, FF_VOLUME_UP, FIRST_MEDIA, FIVE, FLUSHING, FOUR, G, H, HOME, HOST_CLASS_NAME, I, INSERT, IS_APPLE, IS_BOARD_CACHE, IS_CHROME, IS_CHROME_LEGACY, IS_EDGE_LEGACY, IS_FIREFOX, IS_IOS, IS_MAC, IS_SAFARI, IS_TEXT_EDITABLE, J, K, L, LAST_MEDIA, LEFT_ARROW, M, MAC_ENTER, MAC_META, MAC_WK_CMD_LEFT, MAC_WK_CMD_RIGHT, MAX_RADIUS, MERGING, META, MUTE, N, NINE, NODE_TO_INDEX, NODE_TO_PARENT, NS, NUMPAD_DIVIDE, NUMPAD_EIGHT, NUMPAD_FIVE, NUMPAD_FOUR, NUMPAD_MINUS, NUMPAD_MULTIPLY, NUMPAD_NINE, NUMPAD_ONE, NUMPAD_PERIOD, NUMPAD_PLUS, NUMPAD_SEVEN, NUMPAD_SIX, NUMPAD_THREE, NUMPAD_TWO, NUMPAD_ZERO, NUM_CENTER, NUM_LOCK, O, ONE, OPEN_SQUARE_BRACKET, P, PAGE_DOWN, PAGE_UP, PATH_REFS, PAUSE, PERIOD, PLUS_SIGN, POINTER_BUTTON, PRESS_AND_MOVE_BUFFER, PRINT_SCREEN, Path, PlaitBoard, PlaitBoardComponent, PlaitChildrenElementComponent, PlaitContextService, PlaitElement, PlaitElementComponent, PlaitHistoryBoard, PlaitIslandBaseComponent, PlaitIslandPopoverBaseComponent, PlaitNode, PlaitOperation, PlaitPluginElementComponent, PlaitPluginKey, PlaitPointerType, Point, Q, QUESTION_MARK, R, RIGHT_ARROW, RectangleClient, ResizeCursorClass, RetroThemeColor, S, SAVING, SCROLL_BAR_WIDTH, SCROLL_LOCK, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, SELECTION_RECTANGLE_CLASS_NAME, SEMICOLON, SEVEN, SHIFT, SINGLE_QUOTE, SIX, SLASH, SPACE, Selection, SoftThemeColor, StarryThemeColor, T, TAB, THREE, TILDE, TWO, ThemeColorMode, ThemeColors, Transforms, U, UP_ARROW, V, VOLUME_DOWN, VOLUME_UP, Viewport, W, X, Y, Z, ZERO, addMovingElements, addSelectedElement, arrowPoints, cacheMovingElements, cacheSelectedElements, clampZoomLevel, clearNodeWeakMap, clearSelectedElement, clearSelectionMoving, clearViewportOrigination, createFakeEvent, createForeignObject, createG, createKeyboardEvent, createMask, createModModifierKeys, createMouseEvent, createPath, createPointerEvent, createRect, createSVG, createSelectionRectangleG, createTestingBoard, createText, createTouchEvent, debounce, deleteTemporaryElements, depthFirstRecursion, distanceBetweenPointAndPoint, distanceBetweenPointAndRectangle, distanceBetweenPointAndSegment, distanceBetweenPointAndSegments, downloadImage, drawArrow, drawBezierPath, drawCircle, drawLine, drawLinearPath, drawRectangle, drawRoundRectangle, fakeNodeWeakMap, findElements, getBoardRectangle, getClipboardByKey, getClipboardDataByMedia, getDataFromClipboard, getElementById, getElementHostBBox,
|
|
4261
|
+
export { A, ACTIVE_STROKE_WIDTH, ALT, APOSTROPHE, ATTACHED_ELEMENT_CLASS_NAME, AT_SIGN, B, BACKSLASH, BACKSPACE, BOARD_TO_COMPONENT, BOARD_TO_ELEMENT_HOST, BOARD_TO_HOST, BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_MOVING_ELEMENT, BOARD_TO_MOVING_POINT, BOARD_TO_MOVING_POINT_IN_BOARD, BOARD_TO_ON_CHANGE, BOARD_TO_ROUGH_SVG, BOARD_TO_SELECTED_ELEMENT, BOARD_TO_TEMPORARY_ELEMENTS, BOARD_TO_TOUCH_REF, BOARD_TO_VIEWPORT_ORIGINATION, BoardTransforms, C, CAPS_LOCK, CLIP_BOARD_FORMAT_KEY, CLOSE_SQUARE_BRACKET, COMMA, CONTEXT_MENU, CONTROL, ColorfulThemeColor, CoreTransforms, D, DASH, DELETE, DOWN_ARROW, DarkThemeColor, DefaultThemeColor, Direction, E, EIGHT, ELEMENT_TO_COMPONENT, END, ENTER, EQUALS, ESCAPE, F, F1, F10, F11, F12, F2, F3, F4, F5, F6, F7, F8, F9, FF_EQUALS, FF_MINUS, FF_MUTE, FF_SEMICOLON, FF_VOLUME_DOWN, FF_VOLUME_UP, FIRST_MEDIA, FIVE, FLUSHING, FOUR, G, H, HOME, HOST_CLASS_NAME, I, INSERT, IS_APPLE, IS_BOARD_CACHE, IS_CHROME, IS_CHROME_LEGACY, IS_EDGE_LEGACY, IS_FIREFOX, IS_IOS, IS_MAC, IS_SAFARI, IS_TEXT_EDITABLE, J, K, L, LAST_MEDIA, LEFT_ARROW, M, MAC_ENTER, MAC_META, MAC_WK_CMD_LEFT, MAC_WK_CMD_RIGHT, MAX_RADIUS, MERGING, META, MUTE, N, NINE, NODE_TO_INDEX, NODE_TO_PARENT, NS, NUMPAD_DIVIDE, NUMPAD_EIGHT, NUMPAD_FIVE, NUMPAD_FOUR, NUMPAD_MINUS, NUMPAD_MULTIPLY, NUMPAD_NINE, NUMPAD_ONE, NUMPAD_PERIOD, NUMPAD_PLUS, NUMPAD_SEVEN, NUMPAD_SIX, NUMPAD_THREE, NUMPAD_TWO, NUMPAD_ZERO, NUM_CENTER, NUM_LOCK, O, ONE, OPEN_SQUARE_BRACKET, P, PAGE_DOWN, PAGE_UP, PATH_REFS, PAUSE, PERIOD, PLUS_SIGN, POINTER_BUTTON, PRESS_AND_MOVE_BUFFER, PRINT_SCREEN, Path, PlaitBoard, PlaitBoardComponent, PlaitChildrenElementComponent, PlaitContextService, PlaitElement, PlaitElementComponent, PlaitHistoryBoard, PlaitIslandBaseComponent, PlaitIslandPopoverBaseComponent, PlaitNode, PlaitOperation, PlaitPluginElementComponent, PlaitPluginKey, PlaitPointerType, Point, Q, QUESTION_MARK, R, RIGHT_ARROW, RectangleClient, ResizeCursorClass, RetroThemeColor, S, SAVING, SCROLL_BAR_WIDTH, SCROLL_LOCK, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, SELECTION_RECTANGLE_CLASS_NAME, SEMICOLON, SEVEN, SHIFT, SINGLE_QUOTE, SIX, SLASH, SPACE, Selection, SoftThemeColor, StarryThemeColor, T, TAB, THREE, TILDE, TWO, ThemeColorMode, ThemeColors, Transforms, U, UP_ARROW, V, VOLUME_DOWN, VOLUME_UP, Viewport, W, X, Y, Z, ZERO, addMovingElements, addSelectedElement, arrowPoints, cacheMovingElements, cacheSelectedElements, clampZoomLevel, clearNodeWeakMap, clearSelectedElement, clearSelectionMoving, clearViewportOrigination, createFakeEvent, createForeignObject, createG, createKeyboardEvent, createMask, createModModifierKeys, createMouseEvent, createPath, createPointerEvent, createRect, createSVG, createSelectionRectangleG, createTestingBoard, createText, createTouchEvent, debounce, deleteTemporaryElements, depthFirstRecursion, distanceBetweenPointAndPoint, distanceBetweenPointAndRectangle, distanceBetweenPointAndSegment, distanceBetweenPointAndSegments, downloadImage, drawArrow, drawBezierPath, drawCircle, drawLine, drawLinearPath, drawRectangle, drawRoundRectangle, fakeNodeWeakMap, findElements, getBoardRectangle, getClipboardByKey, getClipboardDataByMedia, getDataFromClipboard, getElementById, getElementHostBBox, getHitElementByPoint, getHitElementsBySelection, getIsRecursionFunc, getMovingElements, getNearestPointBetweenPointAndSegment, getNearestPointBetweenPointAndSegments, getRealScrollBarWidth, getRectangleByElements, getSelectedElements, getTemporaryElements, getTemporaryRef, getTextFromClipboard, getViewBox, getViewBoxCenterPoint, getViewportContainerRect, getViewportOrigination, handleTouchTarget, hasBeforeContextChange, hasInputOrTextareaTarget, hasOnBoardChange, hasOnContextChanged, hotkeys, idCreator, initializeViewBox, initializeViewportContainer, initializeViewportOffset, inverse, isDOMElement, isDOMNode, isFromScrolling, isFromViewportChange, isInPlaitBoard, isLineHitLine, isMainPointer, isNullOrUndefined, isPointInEllipse, isPointInPolygon, isPointInRoundRectangle, isPolylineHitRectangle, isPreventTouchMove, isSecondaryPointer, isSelectedElement, isSelectionMoving, isSetViewportOperation, normalizePoint, preventTouchMove, removeMovingElements, removeSelectedElement, rotate, scrollToRectangle, setClipboardData, setClipboardDataByMedia, setClipboardDataByText, setIsFromScrolling, setIsFromViewportChange, setPathStrokeLinecap, setSVGViewBox, setSelectionMoving, setStrokeLinecap, shouldClear, shouldMerge, shouldSave, throttleRAF, toImage, toPoint, transformPoint, transformPoints, updateForeignObject, updateForeignObjectWidth, updateViewportContainerScroll, updateViewportOffset, updateViewportOrigination, withMoving, withOptions, withSelection };
|
|
4226
4262
|
//# sourceMappingURL=plait-core.mjs.map
|