@plait/draw 0.44.0 → 0.45.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/geometry.mjs +2 -14
- package/esm2022/interfaces/line.mjs +2 -15
- package/esm2022/line.component.mjs +16 -17
- package/esm2022/plugins/with-draw.mjs +13 -2
- package/esm2022/plugins/with-geometry-create.mjs +4 -4
- package/esm2022/plugins/with-geometry-resize.mjs +3 -4
- package/esm2022/plugins/with-line-auto-complete.mjs +4 -4
- package/esm2022/plugins/with-line-create.mjs +4 -4
- package/esm2022/plugins/with-line-text-move.mjs +2 -2
- package/esm2022/plugins/with-line-text.mjs +3 -3
- package/esm2022/transforms/geometry-text.mjs +3 -3
- package/fesm2022/plait-draw.mjs +42 -57
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/interfaces/geometry.d.ts +1 -4
- package/interfaces/line.d.ts +0 -1
- package/line.component.d.ts +4 -5
- package/package.json +1 -1
- package/utils/clipboard.d.ts +1 -1
- package/utils/geometry.d.ts +1 -1
|
@@ -3,7 +3,7 @@ import { LineShape, PlaitDrawElement } from '../interfaces';
|
|
|
3
3
|
import { handleLineCreating, getAutoCompletePoints, getHitIndexOfAutoCompletePoint, getSelectedDrawElements } from '../utils';
|
|
4
4
|
export const WithLineAutoCompletePluginKey = 'plait-line-auto-complete-plugin-key';
|
|
5
5
|
export const withLineAutoComplete = (board) => {
|
|
6
|
-
const { pointerDown, pointerMove,
|
|
6
|
+
const { pointerDown, pointerMove, globalPointerUp } = board;
|
|
7
7
|
let startPoint = null;
|
|
8
8
|
let lineShapeG = null;
|
|
9
9
|
let sourceElement;
|
|
@@ -37,7 +37,7 @@ export const withLineAutoComplete = (board) => {
|
|
|
37
37
|
}
|
|
38
38
|
pointerMove(event);
|
|
39
39
|
};
|
|
40
|
-
board.
|
|
40
|
+
board.globalPointerUp = event => {
|
|
41
41
|
if (temporaryElement) {
|
|
42
42
|
Transforms.insertNode(board, temporaryElement, [board.children.length]);
|
|
43
43
|
clearSelectedElement(board);
|
|
@@ -54,8 +54,8 @@ export const withLineAutoComplete = (board) => {
|
|
|
54
54
|
lineShapeG = null;
|
|
55
55
|
sourceElement = null;
|
|
56
56
|
temporaryElement = null;
|
|
57
|
-
|
|
57
|
+
globalPointerUp(event);
|
|
58
58
|
};
|
|
59
59
|
return board;
|
|
60
60
|
};
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-line-auto-complete.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-line-auto-complete.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    BoardTransforms,\n    PRESS_AND_MOVE_BUFFER,\n    PlaitBoard,\n    PlaitOptionsBoard,\n    PlaitPointerType,\n    Point,\n    Transforms,\n    addSelectedElement,\n    clearSelectedElement,\n    createG,\n    distanceBetweenPointAndPoint,\n    temporaryDisableSelection,\n    toPoint,\n    transformPoint\n} from '@plait/core';\nimport { LineShape, PlaitDrawElement, PlaitLine, PlaitShape } from '../interfaces';\nimport { handleLineCreating, getAutoCompletePoints, getHitIndexOfAutoCompletePoint, getSelectedDrawElements } from '../utils';\n\nexport const WithLineAutoCompletePluginKey = 'plait-line-auto-complete-plugin-key';\n\nexport interface LineAutoCompleteOptions {\n    afterComplete: (element: PlaitLine) => {};\n}\n\nexport const withLineAutoComplete = (board: PlaitBoard) => {\n    const { pointerDown, pointerMove, globalPointerUp } = board;\n\n    let startPoint: Point | null = null;\n    let lineShapeG: SVGGElement | null = null;\n    let sourceElement: PlaitShape | null;\n    let temporaryElement: PlaitLine | null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        const selectedElements = getSelectedDrawElements(board);\n        const targetElement = selectedElements.length === 1 && selectedElements[0];\n        const clickPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        if (!PlaitBoard.isReadonly(board) && targetElement && PlaitDrawElement.isShape(targetElement)) {\n            const points = getAutoCompletePoints(targetElement);\n            const index = getHitIndexOfAutoCompletePoint(clickPoint, points);\n            const hitPoint = points[index];\n            if (hitPoint) {\n                temporaryDisableSelection(board as PlaitOptionsBoard);\n                startPoint = clickPoint;\n                sourceElement = targetElement;\n                BoardTransforms.updatePointerType(board, LineShape.elbow);\n            }\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        lineShapeG?.remove();\n        lineShapeG = createG();\n        let movingPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        if (startPoint && sourceElement) {\n            const distance = distanceBetweenPointAndPoint(...movingPoint, ...startPoint);\n            if (distance > PRESS_AND_MOVE_BUFFER) {\n                temporaryElement = handleLineCreating(board, LineShape.elbow, startPoint, movingPoint, sourceElement, lineShapeG);\n            }\n        }\n        pointerMove(event);\n    };\n\n    board.globalPointerUp = event => {\n        if (temporaryElement) {\n            Transforms.insertNode(board, temporaryElement, [board.children.length]);\n            clearSelectedElement(board);\n            addSelectedElement(board, temporaryElement);\n            const afterComplete = (board as PlaitOptionsBoard).getPluginOptions<LineAutoCompleteOptions>(WithLineAutoCompletePluginKey)\n                ?.afterComplete;\n            afterComplete && afterComplete(temporaryElement);\n        }\n        if (startPoint) {\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n            startPoint = null;\n        }\n        lineShapeG?.remove();\n        lineShapeG = null;\n        sourceElement = null;\n        temporaryElement = null;\n        globalPointerUp(event);\n    };\n\n    return board;\n};\n"]}
|
|
@@ -4,7 +4,7 @@ import { REACTION_MARGIN, getLinePointers } from '../constants';
|
|
|
4
4
|
import { getHitOutlineGeometry } from '../utils/position/geometry';
|
|
5
5
|
import { isDrawingMode } from '@plait/common';
|
|
6
6
|
export const withLineCreateByDraw = (board) => {
|
|
7
|
-
const { pointerDown, pointerMove,
|
|
7
|
+
const { pointerDown, pointerMove, globalPointerUp } = board;
|
|
8
8
|
let start = null;
|
|
9
9
|
let sourceElement;
|
|
10
10
|
let lineShapeG = null;
|
|
@@ -33,7 +33,7 @@ export const withLineCreateByDraw = (board) => {
|
|
|
33
33
|
}
|
|
34
34
|
pointerMove(event);
|
|
35
35
|
};
|
|
36
|
-
board.
|
|
36
|
+
board.globalPointerUp = (event) => {
|
|
37
37
|
if (temporaryElement) {
|
|
38
38
|
Transforms.insertNode(board, temporaryElement, [board.children.length]);
|
|
39
39
|
clearSelectedElement(board);
|
|
@@ -46,8 +46,8 @@ export const withLineCreateByDraw = (board) => {
|
|
|
46
46
|
start = null;
|
|
47
47
|
temporaryElement = null;
|
|
48
48
|
preventTouchMove(board, event, false);
|
|
49
|
-
|
|
49
|
+
globalPointerUp(event);
|
|
50
50
|
};
|
|
51
51
|
return board;
|
|
52
52
|
};
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1saW5lLWNyZWF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL3BsdWdpbnMvd2l0aC1saW5lLWNyZWF0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsZUFBZSxFQUNmLFVBQVUsRUFDVixnQkFBZ0IsRUFFaEIsVUFBVSxFQUNWLGtCQUFrQixFQUNsQixvQkFBb0IsRUFDcEIsT0FBTyxFQUNQLGdCQUFnQixFQUNoQixPQUFPLEVBQ1AsY0FBYyxFQUNqQixNQUFNLGFBQWEsQ0FBQztBQUVyQixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDOUMsT0FBTyxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDaEUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDbkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU5QyxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUN0RCxNQUFNLEVBQUUsV0FBVyxFQUFFLFdBQVcsRUFBRSxlQUFlLEVBQUUsR0FBRyxLQUFLLENBQUM7SUFFNUQsSUFBSSxLQUFLLEdBQWlCLElBQUksQ0FBQztJQUUvQixJQUFJLGFBQW1DLENBQUM7SUFFeEMsSUFBSSxVQUFVLEdBQXVCLElBQUksQ0FBQztJQUUxQyxJQUFJLGdCQUFnQixHQUFxQixJQUFJLENBQUM7SUFFOUMsS0FBSyxDQUFDLFdBQVcsR0FBRyxDQUFDLEtBQW1CLEVBQUUsRUFBRTtRQUN4QyxNQUFNLFlBQVksR0FBRyxlQUFlLEVBQUUsQ0FBQztRQUN2QyxNQUFNLGFBQWEsR0FBRyxVQUFVLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxZQUFZLENBQUMsQ0FBQztRQUNsRSxJQUFJLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsSUFBSSxhQUFhLElBQUksYUFBYSxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ3hFLE1BQU0sS0FBSyxHQUFHLGNBQWMsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUMsRUFBRSxVQUFVLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUMxRixLQUFLLEdBQUcsS0FBSyxDQUFDO1lBQ2QsTUFBTSxVQUFVLEdBQUcscUJBQXFCLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxlQUFlLENBQUMsQ0FBQztZQUN4RSxJQUFJLFVBQVUsRUFBRTtnQkFDWixhQUFhLEdBQUcsVUFBVSxDQUFDO2FBQzlCO1lBQ0QsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztTQUN4QztRQUNELFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2QixDQUFDLENBQUM7SUFFRixLQUFLLENBQUMsV0FBVyxHQUFHLENBQUMsS0FBbUIsRUFBRSxFQUFFO1FBQ3hDLFVBQVUsRUFBRSxNQUFNLEVBQUUsQ0FBQztRQUNyQixVQUFVLEdBQUcsT0FBTyxFQUFFLENBQUM7UUFDdkIsSUFBSSxXQUFXLEdBQUcsY0FBYyxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQyxFQUFFLFVBQVUsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzlGLElBQUksS0FBSyxFQUFFO1lBQ1AsTUFBTSxTQUFTLEdBQUcsVUFBVSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQWMsQ0FBQztZQUM1RCxnQkFBZ0IsR0FBRyxrQkFBa0IsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsYUFBYSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1NBQzFHO1FBRUQsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3ZCLENBQUMsQ0FBQztJQUVGLEtBQUssQ0FBQyxlQUFlLEdBQUcsQ0FBQyxLQUFtQixFQUFFLEVBQUU7UUFDNUMsSUFBSSxnQkFBZ0IsRUFBRTtZQUNsQixVQUFVLENBQUMsVUFBVSxDQUFDLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztZQUN4RSxvQkFBb0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUM1QixrQkFBa0IsQ0FBQyxLQUFLLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztZQUM1QyxlQUFlLENBQUMsaUJBQWlCLENBQUMsS0FBSyxFQUFFLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxDQUFDO1NBQ3hFO1FBQ0QsVUFBVSxFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQ3JCLFVBQVUsR0FBRyxJQUFJLENBQUM7UUFDbEIsYUFBYSxHQUFHLElBQUksQ0FBQztRQUNyQixLQUFLLEdBQUcsSUFBSSxDQUFDO1FBQ2IsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLGdCQUFnQixDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDdEMsZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNCLENBQUMsQ0FBQztJQUVGLE9BQU8sS0FBSyxDQUFDO0FBQ2pCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQm9hcmRUcmFuc2Zvcm1zLFxuICAgIFBsYWl0Qm9hcmQsXG4gICAgUGxhaXRQb2ludGVyVHlwZSxcbiAgICBQb2ludCxcbiAgICBUcmFuc2Zvcm1zLFxuICAgIGFkZFNlbGVjdGVkRWxlbWVudCxcbiAgICBjbGVhclNlbGVjdGVkRWxlbWVudCxcbiAgICBjcmVhdGVHLFxuICAgIHByZXZlbnRUb3VjaE1vdmUsXG4gICAgdG9Qb2ludCxcbiAgICB0cmFuc2Zvcm1Qb2ludFxufSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBMaW5lU2hhcGUsIFBsYWl0R2VvbWV0cnksIFBsYWl0TGluZSB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgaGFuZGxlTGluZUNyZWF0aW5nIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgUkVBQ1RJT05fTUFSR0lOLCBnZXRMaW5lUG9pbnRlcnMgfSBmcm9tICcuLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgZ2V0SGl0T3V0bGluZUdlb21ldHJ5IH0gZnJvbSAnLi4vdXRpbHMvcG9zaXRpb24vZ2VvbWV0cnknO1xuaW1wb3J0IHsgaXNEcmF3aW5nTW9kZSB9IGZyb20gJ0BwbGFpdC9jb21tb24nO1xuXG5leHBvcnQgY29uc3Qgd2l0aExpbmVDcmVhdGVCeURyYXcgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQpID0+IHtcbiAgICBjb25zdCB7IHBvaW50ZXJEb3duLCBwb2ludGVyTW92ZSwgZ2xvYmFsUG9pbnRlclVwIH0gPSBib2FyZDtcblxuICAgIGxldCBzdGFydDogUG9pbnQgfCBudWxsID0gbnVsbDtcblxuICAgIGxldCBzb3VyY2VFbGVtZW50OiBQbGFpdEdlb21ldHJ5IHwgbnVsbDtcblxuICAgIGxldCBsaW5lU2hhcGVHOiBTVkdHRWxlbWVudCB8IG51bGwgPSBudWxsO1xuXG4gICAgbGV0IHRlbXBvcmFyeUVsZW1lbnQ6IFBsYWl0TGluZSB8IG51bGwgPSBudWxsO1xuXG4gICAgYm9hcmQucG9pbnRlckRvd24gPSAoZXZlbnQ6IFBvaW50ZXJFdmVudCkgPT4ge1xuICAgICAgICBjb25zdCBsaW5lUG9pbnRlcnMgPSBnZXRMaW5lUG9pbnRlcnMoKTtcbiAgICAgICAgY29uc3QgaXNMaW5lUG9pbnRlciA9IFBsYWl0Qm9hcmQuaXNJblBvaW50ZXIoYm9hcmQsIGxpbmVQb2ludGVycyk7XG4gICAgICAgIGlmICghUGxhaXRCb2FyZC5pc1JlYWRvbmx5KGJvYXJkKSAmJiBpc0xpbmVQb2ludGVyICYmIGlzRHJhd2luZ01vZGUoYm9hcmQpKSB7XG4gICAgICAgICAgICBjb25zdCBwb2ludCA9IHRyYW5zZm9ybVBvaW50KGJvYXJkLCB0b1BvaW50KGV2ZW50LngsIGV2ZW50LnksIFBsYWl0Qm9hcmQuZ2V0SG9zdChib2FyZCkpKTtcbiAgICAgICAgICAgIHN0YXJ0ID0gcG9pbnQ7XG4gICAgICAgICAgICBjb25zdCBoaXRFbGVtZW50ID0gZ2V0SGl0T3V0bGluZUdlb21ldHJ5KGJvYXJkLCBwb2ludCwgUkVBQ1RJT05fTUFSR0lOKTtcbiAgICAgICAgICAgIGlmIChoaXRFbGVtZW50KSB7XG4gICAgICAgICAgICAgICAgc291cmNlRWxlbWVudCA9IGhpdEVsZW1lbnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBwcmV2ZW50VG91Y2hNb3ZlKGJvYXJkLCBldmVudCwgdHJ1ZSk7XG4gICAgICAgIH1cbiAgICAgICAgcG9pbnRlckRvd24oZXZlbnQpO1xuICAgIH07XG5cbiAgICBib2FyZC5wb2ludGVyTW92ZSA9IChldmVudDogUG9pbnRlckV2ZW50KSA9PiB7XG4gICAgICAgIGxpbmVTaGFwZUc/LnJlbW92ZSgpO1xuICAgICAgICBsaW5lU2hhcGVHID0gY3JlYXRlRygpO1xuICAgICAgICBsZXQgbW92aW5nUG9pbnQgPSB0cmFuc2Zvcm1Qb2ludChib2FyZCwgdG9Qb2ludChldmVudC54LCBldmVudC55LCBQbGFpdEJvYXJkLmdldEhvc3QoYm9hcmQpKSk7XG4gICAgICAgIGlmIChzdGFydCkge1xuICAgICAgICAgICAgY29uc3QgbGluZVNoYXBlID0gUGxhaXRCb2FyZC5nZXRQb2ludGVyKGJvYXJkKSBhcyBMaW5lU2hhcGU7XG4gICAgICAgICAgICB0ZW1wb3JhcnlFbGVtZW50ID0gaGFuZGxlTGluZUNyZWF0aW5nKGJvYXJkLCBsaW5lU2hhcGUsIHN0YXJ0LCBtb3ZpbmdQb2ludCwgc291cmNlRWxlbWVudCwgbGluZVNoYXBlRyk7XG4gICAgICAgIH1cblxuICAgICAgICBwb2ludGVyTW92ZShldmVudCk7XG4gICAgfTtcblxuICAgIGJvYXJkLmdsb2JhbFBvaW50ZXJVcCA9IChldmVudDogUG9pbnRlckV2ZW50KSA9PiB7XG4gICAgICAgIGlmICh0ZW1wb3JhcnlFbGVtZW50KSB7XG4gICAgICAgICAgICBUcmFuc2Zvcm1zLmluc2VydE5vZGUoYm9hcmQsIHRlbXBvcmFyeUVsZW1lbnQsIFtib2FyZC5jaGlsZHJlbi5sZW5ndGhdKTtcbiAgICAgICAgICAgIGNsZWFyU2VsZWN0ZWRFbGVtZW50KGJvYXJkKTtcbiAgICAgICAgICAgIGFkZFNlbGVjdGVkRWxlbWVudChib2FyZCwgdGVtcG9yYXJ5RWxlbWVudCk7XG4gICAgICAgICAgICBCb2FyZFRyYW5zZm9ybXMudXBkYXRlUG9pbnRlclR5cGUoYm9hcmQsIFBsYWl0UG9pbnRlclR5cGUuc2VsZWN0aW9uKTtcbiAgICAgICAgfVxuICAgICAgICBsaW5lU2hhcGVHPy5yZW1vdmUoKTtcbiAgICAgICAgbGluZVNoYXBlRyA9IG51bGw7XG4gICAgICAgIHNvdXJjZUVsZW1lbnQgPSBudWxsO1xuICAgICAgICBzdGFydCA9IG51bGw7XG4gICAgICAgIHRlbXBvcmFyeUVsZW1lbnQgPSBudWxsO1xuICAgICAgICBwcmV2ZW50VG91Y2hNb3ZlKGJvYXJkLCBldmVudCwgZmFsc2UpO1xuICAgICAgICBnbG9iYWxQb2ludGVyVXAoZXZlbnQpO1xuICAgIH07XG5cbiAgICByZXR1cm4gYm9hcmQ7XG59O1xuIl19
|
|
@@ -19,7 +19,7 @@ export const withLineTextMove = (board) => {
|
|
|
19
19
|
if (line) {
|
|
20
20
|
const index = getHitLineTextIndex(board, line, point);
|
|
21
21
|
const hitComponent = PlaitElement.getComponent(line);
|
|
22
|
-
const textManage = hitComponent.
|
|
22
|
+
const textManage = hitComponent.getTextManages()[index];
|
|
23
23
|
if (index !== -1 && !textManage.isEditing) {
|
|
24
24
|
textIndex = index;
|
|
25
25
|
return { element: line, handle: ResizeHandle.e };
|
|
@@ -49,4 +49,4 @@ export const withLineTextMove = (board) => {
|
|
|
49
49
|
withResize(board, options);
|
|
50
50
|
return board;
|
|
51
51
|
};
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1saW5lLXRleHQtbW92ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL3BsdWdpbnMvd2l0aC1saW5lLXRleHQtbW92ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUgsWUFBWSxFQUVaLCtCQUErQixFQUMvQixvQkFBb0IsRUFDcEIsc0NBQXNDLEVBQ3pDLE1BQU0sYUFBYSxDQUFDO0FBQ3JCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUM1RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsYUFBYSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQzlELE9BQU8sRUFBRSxZQUFZLEVBQTZDLGVBQWUsRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDckgsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUcvQyxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUNsRCxJQUFJLFNBQVMsR0FBRyxDQUFDLENBQUM7SUFDbEIsTUFBTSxhQUFhLEdBQUcsR0FBRyxDQUFDO0lBQzFCLE1BQU0sT0FBTyxHQUFpQztRQUMxQyxHQUFHLEVBQUUsV0FBVztRQUNoQixTQUFTLEVBQUUsR0FBRyxFQUFFO1lBQ1osT0FBTyxJQUFJLENBQUM7UUFDaEIsQ0FBQztRQUNELE1BQU0sRUFBRSxDQUFDLEtBQVksRUFBRSxFQUFFO1lBQ3JCLElBQUksTUFBTSxHQUFHLElBQUksQ0FBQztZQUNsQixNQUFNLElBQUksR0FBRyxvQkFBb0IsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLENBQUMsT0FBcUIsRUFBRSxFQUFFO2dCQUN0RSxPQUFPLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUM1QyxDQUFDLENBQTBCLENBQUM7WUFDNUIsSUFBSSxJQUFJLEVBQUU7Z0JBQ04sTUFBTSxLQUFLLEdBQUcsbUJBQW1CLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQztnQkFDdEQsTUFBTSxZQUFZLEdBQUcsWUFBWSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQWtCLENBQUM7Z0JBQ3RFLE1BQU0sVUFBVSxHQUFHLFlBQVksQ0FBQyxjQUFjLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDeEQsSUFBSSxLQUFLLEtBQUssQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxFQUFFO29CQUN2QyxTQUFTLEdBQUcsS0FBSyxDQUFDO29CQUNsQixPQUFPLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsWUFBWSxDQUFDLENBQUMsRUFBRSxDQUFDO2lCQUNwRDthQUNKO1lBQ0QsT0FBTyxNQUFNLENBQUM7UUFDbEIsQ0FBQztRQUNELFFBQVEsRUFBRSxDQUFDLFNBQStCLEVBQUUsV0FBd0IsRUFBRSxFQUFFO1lBQ3BFLE1BQU0sT0FBTyxHQUFHLFNBQVMsQ0FBQyxPQUFPLENBQUM7WUFDbEMsSUFBSSxPQUFPLEVBQUU7Z0JBQ1QsTUFBTSxXQUFXLEdBQUcsV0FBVyxDQUFDLGlCQUFpQixDQUFDO2dCQUNsRCxNQUFNLE1BQU0sR0FBRyxhQUFhLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO2dCQUM3QyxNQUFNLFFBQVEsR0FBRywrQkFBK0IsQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFDLENBQUM7Z0JBQ3RFLElBQUksUUFBUSxJQUFJLGFBQWEsRUFBRTtvQkFDM0IsTUFBTSxLQUFLLEdBQUcsc0NBQXNDLENBQUMsV0FBVyxFQUFFLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztvQkFDakYsTUFBTSxRQUFRLEdBQUcsZUFBZSxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztvQkFDaEQsTUFBTSxLQUFLLEdBQUcsQ0FBQyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztvQkFDakMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxHQUFHO3dCQUNmLEdBQUcsS0FBSyxDQUFDLFNBQVMsQ0FBQzt3QkFDbkIsUUFBUTtxQkFDWCxDQUFDO29CQUNGLGNBQWMsQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FBQztpQkFDdEQ7YUFDSjtRQUNMLENBQUM7S0FDSixDQUFDO0lBRUYsVUFBVSxDQUFZLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztJQUV0QyxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIFBsYWl0Qm9hcmQsXG4gICAgUGxhaXRFbGVtZW50LFxuICAgIFBvaW50LFxuICAgIGRpc3RhbmNlQmV0d2VlblBvaW50QW5kU2VnbWVudHMsXG4gICAgZ2V0SGl0RWxlbWVudEJ5UG9pbnQsXG4gICAgZ2V0TmVhcmVzdFBvaW50QmV0d2VlblBvaW50QW5kU2VnbWVudHNcbn0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgUGxhaXREcmF3RWxlbWVudCwgUGxhaXRMaW5lIH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBnZXRIaXRMaW5lVGV4dEluZGV4LCBnZXRMaW5lUG9pbnRzIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgUmVzaXplSGFuZGxlLCBSZXNpemVSZWYsIFJlc2l6ZVN0YXRlLCBXaXRoUmVzaXplT3B0aW9ucywgZ2V0UmF0aW9CeVBvaW50LCB3aXRoUmVzaXplIH0gZnJvbSAnQHBsYWl0L2NvbW1vbic7XG5pbXBvcnQgeyBEcmF3VHJhbnNmb3JtcyB9IGZyb20gJy4uL3RyYW5zZm9ybXMnO1xuaW1wb3J0IHsgTGluZUNvbXBvbmVudCB9IGZyb20gJy4uL2xpbmUuY29tcG9uZW50JztcblxuZXhwb3J0IGNvbnN0IHdpdGhMaW5lVGV4dE1vdmUgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQpID0+IHtcbiAgICBsZXQgdGV4dEluZGV4ID0gMDtcbiAgICBjb25zdCBtb3ZhYmxlQnVmZmVyID0gMTAwO1xuICAgIGNvbnN0IG9wdGlvbnM6IFdpdGhSZXNpemVPcHRpb25zPFBsYWl0TGluZT4gPSB7XG4gICAgICAgIGtleTogJ2xpbmUtdGV4dCcsXG4gICAgICAgIGNhblJlc2l6ZTogKCkgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgIH0sXG4gICAgICAgIGRldGVjdDogKHBvaW50OiBQb2ludCkgPT4ge1xuICAgICAgICAgICAgbGV0IHJlc3VsdCA9IG51bGw7XG4gICAgICAgICAgICBjb25zdCBsaW5lID0gZ2V0SGl0RWxlbWVudEJ5UG9pbnQoYm9hcmQsIHBvaW50LCAoZWxlbWVudDogUGxhaXRFbGVtZW50KSA9PiB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIFBsYWl0RHJhd0VsZW1lbnQuaXNMaW5lKGVsZW1lbnQpO1xuICAgICAgICAgICAgfSkgYXMgdW5kZWZpbmVkIHwgUGxhaXRMaW5lO1xuICAgICAgICAgICAgaWYgKGxpbmUpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBpbmRleCA9IGdldEhpdExpbmVUZXh0SW5kZXgoYm9hcmQsIGxpbmUsIHBvaW50KTtcbiAgICAgICAgICAgICAgICBjb25zdCBoaXRDb21wb25lbnQgPSBQbGFpdEVsZW1lbnQuZ2V0Q29tcG9uZW50KGxpbmUpIGFzIExpbmVDb21wb25lbnQ7XG4gICAgICAgICAgICAgICAgY29uc3QgdGV4dE1hbmFnZSA9IGhpdENvbXBvbmVudC5nZXRUZXh0TWFuYWdlcygpW2luZGV4XTtcbiAgICAgICAgICAgICAgICBpZiAoaW5kZXggIT09IC0xICYmICF0ZXh0TWFuYWdlLmlzRWRpdGluZykge1xuICAgICAgICAgICAgICAgICAgICB0ZXh0SW5kZXggPSBpbmRleDtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHsgZWxlbWVudDogbGluZSwgaGFuZGxlOiBSZXNpemVIYW5kbGUuZSB9O1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgICAgIH0sXG4gICAgICAgIG9uUmVzaXplOiAocmVzaXplUmVmOiBSZXNpemVSZWY8UGxhaXRMaW5lPiwgcmVzaXplU3RhdGU6IFJlc2l6ZVN0YXRlKSA9PiB7XG4gICAgICAgICAgICBjb25zdCBlbGVtZW50ID0gcmVzaXplUmVmLmVsZW1lbnQ7XG4gICAgICAgICAgICBpZiAoZWxlbWVudCkge1xuICAgICAgICAgICAgICAgIGNvbnN0IG1vdmluZ1BvaW50ID0gcmVzaXplU3RhdGUuZW5kVHJhbnNmb3JtUG9pbnQ7XG4gICAgICAgICAgICAgICAgY29uc3QgcG9pbnRzID0gZ2V0TGluZVBvaW50cyhib2FyZCwgZWxlbWVudCk7XG4gICAgICAgICAgICAgICAgY29uc3QgZGlzdGFuY2UgPSBkaXN0YW5jZUJldHdlZW5Qb2ludEFuZFNlZ21lbnRzKHBvaW50cywgbW92aW5nUG9pbnQpO1xuICAgICAgICAgICAgICAgIGlmIChkaXN0YW5jZSA8PSBtb3ZhYmxlQnVmZmVyKSB7XG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IHBvaW50ID0gZ2V0TmVhcmVzdFBvaW50QmV0d2VlblBvaW50QW5kU2VnbWVudHMobW92aW5nUG9pbnQsIHBvaW50cywgZmFsc2UpO1xuICAgICAgICAgICAgICAgICAgICBjb25zdCBwb3NpdGlvbiA9IGdldFJhdGlvQnlQb2ludChwb2ludHMsIHBvaW50KTtcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgdGV4dHMgPSBbLi4uZWxlbWVudC50ZXh0c107XG4gICAgICAgICAgICAgICAgICAgIHRleHRzW3RleHRJbmRleF0gPSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAuLi50ZXh0c1t0ZXh0SW5kZXhdLFxuICAgICAgICAgICAgICAgICAgICAgICAgcG9zaXRpb25cbiAgICAgICAgICAgICAgICAgICAgfTtcbiAgICAgICAgICAgICAgICAgICAgRHJhd1RyYW5zZm9ybXMuc2V0TGluZVRleHRzKGJvYXJkLCBlbGVtZW50LCB0ZXh0cyk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfTtcblxuICAgIHdpdGhSZXNpemU8UGxhaXRMaW5lPihib2FyZCwgb3B0aW9ucyk7XG5cbiAgICByZXR1cm4gYm9hcmQ7XG59O1xuIl19
|
|
@@ -33,7 +33,7 @@ export const withLineText = (board) => {
|
|
|
33
33
|
DrawTransforms.setLineTexts(board, hitTarget, texts);
|
|
34
34
|
setTimeout(() => {
|
|
35
35
|
const hitComponent = PlaitElement.getComponent(hitTarget);
|
|
36
|
-
editHandle(board, hitTarget, hitComponent.
|
|
36
|
+
editHandle(board, hitTarget, hitComponent.getTextManages().length - 1, true);
|
|
37
37
|
});
|
|
38
38
|
}
|
|
39
39
|
}
|
|
@@ -44,7 +44,7 @@ export const withLineText = (board) => {
|
|
|
44
44
|
};
|
|
45
45
|
function editHandle(board, element, manageIndex, isFirstEdit = false) {
|
|
46
46
|
const hitComponent = PlaitElement.getComponent(element);
|
|
47
|
-
const textManage = hitComponent.
|
|
47
|
+
const textManage = hitComponent.getTextManages()[manageIndex];
|
|
48
48
|
const originText = textManage.componentRef.instance.children;
|
|
49
49
|
textManage.edit((origin, descendant) => {
|
|
50
50
|
const text = Node.string(descendant[0]);
|
|
@@ -54,4 +54,4 @@ function editHandle(board, element, manageIndex, isFirstEdit = false) {
|
|
|
54
54
|
}
|
|
55
55
|
});
|
|
56
56
|
}
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1saW5lLXRleHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy9wbHVnaW5zL3dpdGgtbGluZS10ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCxVQUFVLEVBQ1YsWUFBWSxFQUNaLG9CQUFvQixFQUNwQixzQ0FBc0MsRUFDdEMsT0FBTyxFQUNQLGNBQWMsRUFDakIsTUFBTSxhQUFhLENBQUM7QUFDckIsT0FBTyxFQUFFLGdCQUFnQixFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxPQUFPLENBQUM7QUFDN0IsT0FBTyxFQUFFLG1CQUFtQixFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDN0UsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRXhDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFL0MsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO0lBQzlDLE1BQU0sRUFBRSxRQUFRLEVBQUUsR0FBRyxLQUFLLENBQUM7SUFFM0IsS0FBSyxDQUFDLFFBQVEsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtRQUNuQyxJQUFJLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUMvQixNQUFNLFVBQVUsR0FBRyxjQUFjLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDLEVBQUUsVUFBVSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDL0YsTUFBTSxTQUFTLEdBQUcsb0JBQW9CLENBQUMsS0FBSyxFQUFFLFVBQVUsRUFBRSxDQUFDLE9BQXFCLEVBQUUsRUFBRTtnQkFDaEYsT0FBTyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDNUMsQ0FBQyxDQUEwQixDQUFDO1lBQzVCLElBQUksU0FBUyxFQUFFO2dCQUNYLE1BQU0sTUFBTSxHQUFHLGFBQWEsQ0FBQyxLQUFLLEVBQUUsU0FBUyxDQUFDLENBQUM7Z0JBQy9DLE1BQU0sS0FBSyxHQUFHLHNDQUFzQyxDQUFDLFVBQVUsRUFBRSxNQUFNLENBQUMsQ0FBQztnQkFDekUsTUFBTSxLQUFLLEdBQUcsU0FBUyxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztnQkFDbEUsTUFBTSxTQUFTLEdBQUcsbUJBQW1CLENBQUMsS0FBSyxFQUFFLFNBQVMsRUFBRSxVQUFVLENBQUMsQ0FBQztnQkFDcEUsTUFBTSxTQUFTLEdBQUcsYUFBYSxDQUFDLEtBQUssRUFBRSxTQUFTLEVBQUUsVUFBVSxDQUFDLENBQUM7Z0JBQzlELElBQUksU0FBUyxFQUFFO29CQUNYLFVBQVUsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLFNBQVMsQ0FBQyxDQUFDO2lCQUMzQztxQkFBTTtvQkFDSCxNQUFNLEtBQUssR0FBRyxlQUFlLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxDQUFDO29CQUM3QyxLQUFLLENBQUMsSUFBSSxDQUFDO3dCQUNQLElBQUksRUFBRSxTQUFTLENBQUMsSUFBSSxDQUFDO3dCQUNyQixRQUFRLEVBQUUsS0FBSzt3QkFDZixLQUFLLEVBQUUsRUFBRTt3QkFDVCxNQUFNLEVBQUUsRUFBRTtxQkFDYixDQUFDLENBQUM7b0JBQ0gsY0FBYyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDO29CQUNyRCxVQUFVLENBQUMsR0FBRyxFQUFFO3dCQUNaLE1BQU0sWUFBWSxHQUFHLFlBQVksQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFrQixDQUFDO3dCQUMzRSxVQUFVLENBQUMsS0FBSyxFQUFFLFNBQVMsRUFBRSxZQUFZLENBQUMsY0FBYyxFQUFFLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztvQkFDakYsQ0FBQyxDQUFDLENBQUM7aUJBQ047YUFDSjtTQUNKO1FBQ0QsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3BCLENBQUMsQ0FBQztJQUVGLE9BQU8sS0FBSyxDQUFDO0FBQ2pCLENBQUMsQ0FBQztBQUVGLFNBQVMsVUFBVSxDQUFDLEtBQWlCLEVBQUUsT0FBa0IsRUFBRSxXQUFtQixFQUFFLGNBQXVCLEtBQUs7SUFDeEcsTUFBTSxZQUFZLEdBQUcsWUFBWSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQWtCLENBQUM7SUFDekUsTUFBTSxVQUFVLEdBQUcsWUFBWSxDQUFDLGNBQWMsRUFBRSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQzlELE1BQU0sVUFBVSxHQUFHLFVBQVUsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQztJQUU3RCxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBTSxFQUFFLFVBQVUsRUFBRSxFQUFFO1FBQ25DLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDeEMsTUFBTSxZQUFZLEdBQUcsQ0FBQyxXQUFXLElBQUksVUFBVSxLQUFLLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQ3pFLElBQUksWUFBWSxFQUFFO1lBQ2QsY0FBYyxDQUFDLGNBQWMsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLFdBQVcsQ0FBQyxDQUFDO1NBQzlEO0lBQ0wsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBQbGFpdEJvYXJkLFxuICAgIFBsYWl0RWxlbWVudCxcbiAgICBnZXRIaXRFbGVtZW50QnlQb2ludCxcbiAgICBnZXROZWFyZXN0UG9pbnRCZXR3ZWVuUG9pbnRBbmRTZWdtZW50cyxcbiAgICB0b1BvaW50LFxuICAgIHRyYW5zZm9ybVBvaW50XG59IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IFBsYWl0RHJhd0VsZW1lbnQsIFBsYWl0TGluZSB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgTm9kZSB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IGdldEhpdExpbmVUZXh0SW5kZXgsIGdldExpbmVQb2ludHMsIGlzSGl0TGluZVRleHQgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBnZXRSYXRpb0J5UG9pbnQgfSBmcm9tICdAcGxhaXQvY29tbW9uJztcbmltcG9ydCB7IGJ1aWxkVGV4dCB9IGZyb20gJ0BwbGFpdC90ZXh0JztcbmltcG9ydCB7IExpbmVDb21wb25lbnQgfSBmcm9tICcuLi9saW5lLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEcmF3VHJhbnNmb3JtcyB9IGZyb20gJy4uL3RyYW5zZm9ybXMnO1xuXG5leHBvcnQgY29uc3Qgd2l0aExpbmVUZXh0ID0gKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB7XG4gICAgY29uc3QgeyBkYmxjbGljayB9ID0gYm9hcmQ7XG5cbiAgICBib2FyZC5kYmxjbGljayA9IChldmVudDogTW91c2VFdmVudCkgPT4ge1xuICAgICAgICBpZiAoIVBsYWl0Qm9hcmQuaXNSZWFkb25seShib2FyZCkpIHtcbiAgICAgICAgICAgIGNvbnN0IGNsaWNrUG9pbnQgPSB0cmFuc2Zvcm1Qb2ludChib2FyZCwgdG9Qb2ludChldmVudC54LCBldmVudC55LCBQbGFpdEJvYXJkLmdldEhvc3QoYm9hcmQpKSk7XG4gICAgICAgICAgICBjb25zdCBoaXRUYXJnZXQgPSBnZXRIaXRFbGVtZW50QnlQb2ludChib2FyZCwgY2xpY2tQb2ludCwgKGVsZW1lbnQ6IFBsYWl0RWxlbWVudCkgPT4ge1xuICAgICAgICAgICAgICAgIHJldHVybiBQbGFpdERyYXdFbGVtZW50LmlzTGluZShlbGVtZW50KTtcbiAgICAgICAgICAgIH0pIGFzIHVuZGVmaW5lZCB8IFBsYWl0TGluZTtcbiAgICAgICAgICAgIGlmIChoaXRUYXJnZXQpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBwb2ludHMgPSBnZXRMaW5lUG9pbnRzKGJvYXJkLCBoaXRUYXJnZXQpO1xuICAgICAgICAgICAgICAgIGNvbnN0IHBvaW50ID0gZ2V0TmVhcmVzdFBvaW50QmV0d2VlblBvaW50QW5kU2VnbWVudHMoY2xpY2tQb2ludCwgcG9pbnRzKTtcbiAgICAgICAgICAgICAgICBjb25zdCB0ZXh0cyA9IGhpdFRhcmdldC50ZXh0cz8ubGVuZ3RoID8gWy4uLmhpdFRhcmdldC50ZXh0c10gOiBbXTtcbiAgICAgICAgICAgICAgICBjb25zdCB0ZXh0SW5kZXggPSBnZXRIaXRMaW5lVGV4dEluZGV4KGJvYXJkLCBoaXRUYXJnZXQsIGNsaWNrUG9pbnQpO1xuICAgICAgICAgICAgICAgIGNvbnN0IGlzSGl0VGV4dCA9IGlzSGl0TGluZVRleHQoYm9hcmQsIGhpdFRhcmdldCwgY2xpY2tQb2ludCk7XG4gICAgICAgICAgICAgICAgaWYgKGlzSGl0VGV4dCkge1xuICAgICAgICAgICAgICAgICAgICBlZGl0SGFuZGxlKGJvYXJkLCBoaXRUYXJnZXQsIHRleHRJbmRleCk7XG4gICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgcmF0aW8gPSBnZXRSYXRpb0J5UG9pbnQocG9pbnRzLCBwb2ludCk7XG4gICAgICAgICAgICAgICAgICAgIHRleHRzLnB1c2goe1xuICAgICAgICAgICAgICAgICAgICAgICAgdGV4dDogYnVpbGRUZXh0KCfmlofmnKwnKSxcbiAgICAgICAgICAgICAgICAgICAgICAgIHBvc2l0aW9uOiByYXRpbyxcbiAgICAgICAgICAgICAgICAgICAgICAgIHdpZHRoOiAyOCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGhlaWdodDogMjBcbiAgICAgICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgICAgIERyYXdUcmFuc2Zvcm1zLnNldExpbmVUZXh0cyhib2FyZCwgaGl0VGFyZ2V0LCB0ZXh0cyk7XG4gICAgICAgICAgICAgICAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3QgaGl0Q29tcG9uZW50ID0gUGxhaXRFbGVtZW50LmdldENvbXBvbmVudChoaXRUYXJnZXQpIGFzIExpbmVDb21wb25lbnQ7XG4gICAgICAgICAgICAgICAgICAgICAgICBlZGl0SGFuZGxlKGJvYXJkLCBoaXRUYXJnZXQsIGhpdENvbXBvbmVudC5nZXRUZXh0TWFuYWdlcygpLmxlbmd0aCAtIDEsIHRydWUpO1xuICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgZGJsY2xpY2soZXZlbnQpO1xuICAgIH07XG5cbiAgICByZXR1cm4gYm9hcmQ7XG59O1xuXG5mdW5jdGlvbiBlZGl0SGFuZGxlKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50OiBQbGFpdExpbmUsIG1hbmFnZUluZGV4OiBudW1iZXIsIGlzRmlyc3RFZGl0OiBib29sZWFuID0gZmFsc2UpIHtcbiAgICBjb25zdCBoaXRDb21wb25lbnQgPSBQbGFpdEVsZW1lbnQuZ2V0Q29tcG9uZW50KGVsZW1lbnQpIGFzIExpbmVDb21wb25lbnQ7XG4gICAgY29uc3QgdGV4dE1hbmFnZSA9IGhpdENvbXBvbmVudC5nZXRUZXh0TWFuYWdlcygpW21hbmFnZUluZGV4XTtcbiAgICBjb25zdCBvcmlnaW5UZXh0ID0gdGV4dE1hbmFnZS5jb21wb25lbnRSZWYuaW5zdGFuY2UuY2hpbGRyZW47XG5cbiAgICB0ZXh0TWFuYWdlLmVkaXQoKG9yaWdpbiwgZGVzY2VuZGFudCkgPT4ge1xuICAgICAgICBjb25zdCB0ZXh0ID0gTm9kZS5zdHJpbmcoZGVzY2VuZGFudFswXSk7XG4gICAgICAgIGNvbnN0IHNob3VsZFJlbW92ZSA9IChpc0ZpcnN0RWRpdCAmJiBvcmlnaW5UZXh0ID09PSBkZXNjZW5kYW50KSB8fCAhdGV4dDtcbiAgICAgICAgaWYgKHNob3VsZFJlbW92ZSkge1xuICAgICAgICAgICAgRHJhd1RyYW5zZm9ybXMucmVtb3ZlTGluZVRleHQoYm9hcmQsIGVsZW1lbnQsIG1hbmFnZUluZGV4KTtcbiAgICAgICAgfVxuICAgIH0pO1xufVxuIl19
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import { Point, Transforms } from '@plait/core';
|
|
2
|
-
import { PlaitGeometry } from '../interfaces';
|
|
3
2
|
import { ShapeDefaultSpace } from '../constants';
|
|
4
3
|
import { AlignEditor, Alignment } from '@plait/text';
|
|
4
|
+
import { getFirstTextEditor } from '@plait/common';
|
|
5
5
|
const normalizePoints = (board, element, width, textHeight) => {
|
|
6
6
|
let points = element.points;
|
|
7
7
|
let autoSize = element.autoSize;
|
|
8
8
|
const defaultSpace = ShapeDefaultSpace.rectangleAndText;
|
|
9
9
|
if (autoSize) {
|
|
10
|
-
const editor =
|
|
10
|
+
const editor = getFirstTextEditor(element);
|
|
11
11
|
if (AlignEditor.isActive(editor, Alignment.right)) {
|
|
12
12
|
points = [
|
|
13
13
|
[points[1][0] - (width + defaultSpace * 2), points[0][1]],
|
|
@@ -51,4 +51,4 @@ export const setTextSize = (board, element, textWidth, textHeight) => {
|
|
|
51
51
|
}
|
|
52
52
|
}
|
|
53
53
|
};
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VvbWV0cnktdGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL3RyYW5zZm9ybXMvZ2VvbWV0cnktdGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWMsS0FBSyxFQUFFLFVBQVUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUc1RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDakQsT0FBTyxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDckQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRW5ELE1BQU0sZUFBZSxHQUFHLENBQUMsS0FBaUIsRUFBRSxPQUFzQixFQUFFLEtBQWEsRUFBRSxVQUFrQixFQUFFLEVBQUU7SUFDckcsSUFBSSxNQUFNLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQztJQUM1QixJQUFJLFFBQVEsR0FBSSxPQUFxQixDQUFDLFFBQVEsQ0FBQztJQUMvQyxNQUFNLFlBQVksR0FBRyxpQkFBaUIsQ0FBQyxnQkFBZ0IsQ0FBQztJQUV4RCxJQUFJLFFBQVEsRUFBRTtRQUNWLE1BQU0sTUFBTSxHQUFHLGtCQUFrQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzNDLElBQUksV0FBVyxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQy9DLE1BQU0sR0FBRztnQkFDTCxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEtBQUssR0FBRyxZQUFZLEdBQUcsQ0FBQyxDQUFDLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUN6RCxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FB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QUFTLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLEtBQUssT0FBTyxDQUFDLENBQUM7WUFDbEUsVUFBVSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztTQUNqRDtLQUNKO0FBQ0wsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRCb2FyZCwgUG9pbnQsIFRyYW5zZm9ybXMgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBFbGVtZW50IH0gZnJvbSAnc2xhdGUnO1xuaW1wb3J0IHsgUGxhaXRHZW9tZXRyeSwgUGxhaXRUZXh0IH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBTaGFwZURlZmF1bHRTcGFjZSB9IGZyb20gJy4uL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBBbGlnbkVkaXRvciwgQWxpZ25tZW50IH0gZnJvbSAnQHBsYWl0L3RleHQnO1xuaW1wb3J0IHsgZ2V0Rmlyc3RUZXh0RWRpdG9yIH0gZnJvbSAnQHBsYWl0L2NvbW1vbic7XG5cbmNvbnN0IG5vcm1hbGl6ZVBvaW50cyA9IChib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudDogUGxhaXRHZW9tZXRyeSwgd2lkdGg6IG51bWJlciwgdGV4dEhlaWdodDogbnVtYmVyKSA9PiB7XG4gICAgbGV0IHBvaW50cyA9IGVsZW1lbnQucG9pbnRzO1xuICAgIGxldCBhdXRvU2l6ZSA9IChlbGVtZW50IGFzIFBsYWl0VGV4dCkuYXV0b1NpemU7XG4gICAgY29uc3QgZGVmYXVsdFNwYWNlID0gU2hhcGVEZWZhdWx0U3BhY2UucmVjdGFuZ2xlQW5kVGV4dDtcblxuICAgIGlmIChhdXRvU2l6ZSkge1xuICAgICAgICBjb25zdCBlZGl0b3IgPSBnZXRGaXJzdFRleHRFZGl0b3IoZWxlbWVudCk7XG4gICAgICAgIGlmIChBbGlnbkVkaXRvci5pc0FjdGl2ZShlZGl0b3IsIEFsaWdubWVudC5yaWdodCkpIHtcbiAgICAgICAgICAgIHBvaW50cyA9IFtcbiAgICAgICAgICAgICAgICBbcG9pbnRzWzFdWzBdIC0gKHdpZHRoICsgZGVmYXVsdFNwYWNlICogMiksIHBvaW50c1swXVsxXV0sXG4gICAgICAgICAgICAgICAgW3BvaW50c1sxXVswXSwgcG9pbnRzWzBdWzFdICsgdGV4dEhlaWdodF1cbiAgICAgICAgICAgIF07XG4gICAgICAgIH0gZWxzZSBpZiAoQWxpZ25FZGl0b3IuaXNBY3RpdmUoZWRpdG9yLCBBbGlnbm1lbnQuY2VudGVyKSkge1xuICAgICAgICAgICAgY29uc3Qgb2xkV2lkdGggPSBNYXRoLmFicyhwb2ludHNbMF1bMF0gLSBwb2ludHNbMV1bMF0pO1xuICAgICAgICAgICAgY29uc3Qgb2Zmc2V0ID0gKHdpZHRoIC0gb2xkV2lkdGgpIC8gMjtcbiAgICAgICAgICAgIHBvaW50cyA9IFtcbiAgICAgICAgICAgICAgICBbcG9pbnRzWzBdWzBdIC0gb2Zmc2V0IC0gZGVmYXVsdFNwYWNlLCBwb2ludHNbMF1bMV1dLFxuICAgICAgICAgICAgICAgIFtwb2ludHNbMV1bMF0gKyBvZmZzZXQgKyBkZWZhdWx0U3BhY2UsIHBvaW50c1swXVsxXSArIHRleHRIZWlnaHRdXG4gICAgICAgICAgICBdO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgcG9pbnRzID0gW3BvaW50c1swXSwgW3BvaW50c1swXVswXSArIHdpZHRoICsgZGVmYXVsdFNwYWNlICogMiwgcG9pbnRzWzBdWzFdICsgdGV4dEhlaWdodF1dO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHsgcG9pbnRzIH07XG59O1xuXG5leHBvcnQgY29uc3Qgc2V0VGV4dCA9IChib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudDogUGxhaXRHZW9tZXRyeSwgdGV4dDogRWxlbWVudCwgd2lkdGg6IG51bWJlciwgdGV4dEhlaWdodDogbnVtYmVyKSA9PiB7XG4gICAgY29uc3QgbmV3RWxlbWVudCA9IHtcbiAgICAgICAgdGV4dCxcbiAgICAgICAgdGV4dEhlaWdodCxcbiAgICAgICAgLi4ubm9ybWFsaXplUG9pbnRzKGJvYXJkLCBlbGVtZW50LCB3aWR0aCwgdGV4dEhlaWdodClcbiAgICB9O1xuXG4gICAgY29uc3QgcGF0aCA9IGJvYXJkLmNoaWxkcmVuLmZpbmRJbmRleChjaGlsZCA9PiBjaGlsZCA9PT0gZWxlbWVudCk7XG5cbiAgICBUcmFuc2Zvcm1zLnNldE5vZGUoYm9hcmQsIG5ld0VsZW1lbnQsIFtwYXRoXSk7XG59O1xuXG5leHBvcnQgY29uc3Qgc2V0VGV4dFNpemUgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnQ6IFBsYWl0R2VvbWV0cnksIHRleHRXaWR0aDogbnVtYmVyLCB0ZXh0SGVpZ2h0OiBudW1iZXIpID0+IHtcbiAgICBpZiAoKGVsZW1lbnQgYXMgUGxhaXRUZXh0KS5hdXRvU2l6ZSkge1xuICAgICAgICBjb25zdCBuZXdFbGVtZW50ID0ge1xuICAgICAgICAgICAgdGV4dEhlaWdodCxcbiAgICAgICAgICAgIC4uLm5vcm1hbGl6ZVBvaW50cyhib2FyZCwgZWxlbWVudCwgdGV4dFdpZHRoLCB0ZXh0SGVpZ2h0KVxuICAgICAgICB9O1xuICAgICAgICBjb25zdCBpc1BvaW50c0VxdWFsID1cbiAgICAgICAgICAgIFBvaW50LmlzRXF1YWxzKGVsZW1lbnQucG9pbnRzWzBdLCBuZXdFbGVtZW50LnBvaW50c1swXSkgJiYgUG9pbnQuaXNFcXVhbHMoZWxlbWVudC5wb2ludHNbMV0sIG5ld0VsZW1lbnQucG9pbnRzWzFdKTtcbiAgICAgICAgY29uc3QgaXNUZXh0SGVpZ2h0RXF1YWwgPSBNYXRoLnJvdW5kKHRleHRIZWlnaHQpID09PSBNYXRoLnJvdW5kKGVsZW1lbnQudGV4dEhlaWdodCk7XG4gICAgICAgIGlmICghaXNQb2ludHNFcXVhbCB8fCAhaXNUZXh0SGVpZ2h0RXF1YWwpIHtcbiAgICAgICAgICAgIGNvbnN0IHBhdGggPSBib2FyZC5jaGlsZHJlbi5maW5kSW5kZXgoY2hpbGQgPT4gY2hpbGQgPT09IGVsZW1lbnQpO1xuICAgICAgICAgICAgVHJhbnNmb3Jtcy5zZXROb2RlKGJvYXJkLCBuZXdFbGVtZW50LCBbcGF0aF0pO1xuICAgICAgICB9XG4gICAgfVxufTtcbiJdfQ==
|
package/fesm2022/plait-draw.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { getRectangleByPoints, getMemorizedLatest, memorizeLatest, RESIZE_HANDLE_DIAMETER, getExtendPoint, getFactorByPoints, Generator, getRectangleResizeHandleRefs, getDirectionByVector, getOppositeDirection, getDirectionFactor, getPointByVector, reduceRouteMargin, getNextPoint, generateElbowLineRoute, getPoints, removeDuplicatePoints, getPointOnPolyline, getDirectionByPointOfRectangle, rotateVectorAnti90, TRANSPARENT, normalizeShapePoints, PRIMARY_COLOR, CommonPluginElement, ActiveGenerator, WithTextPluginKey, isVirtualKey, isDelete, isSpaceHotkey, isDndMode, isDrawingMode, acceptImageTypes, getElementOfFocusedImage, buildImage, ResizeHandle, withResize, isResizingByCondition, getRatioByPoint, ImageGenerator } from '@plait/common';
|
|
1
|
+
import { ACTIVE_STROKE_WIDTH, ThemeColorMode, PlaitBoard, setStrokeLinecap, isPointInPolygon, getNearestPointBetweenPointAndSegments, RectangleClient, isPointInEllipse, drawRectangle, drawRoundRectangle, isPointInRoundRectangle, idCreator, createG, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, drawCircle, distanceBetweenPointAndSegment, Transforms, clearSelectedElement, addSelectedElement, BoardTransforms, PlaitPointerType, arrowPoints, createPath, distanceBetweenPointAndPoint, drawLinearPath, rotate, depthFirstRecursion, getIsRecursionFunc, getElementById, Direction, catmullRomFitting, distanceBetweenPointAndSegments, createMask, createRect, findElements, Point, getSelectedElements, isPolylineHitRectangle, Path, PlaitNode, BOARD_TO_HOST, transformPoint, toPoint, isSelectionMoving, RgbaToHEX, PlaitElement, preventTouchMove, setClipboardData, getDataFromClipboard, getHitElementByPoint, CursorClass, temporaryDisableSelection, PRESS_AND_MOVE_BUFFER } from '@plait/core';
|
|
2
|
+
import { getRectangleByPoints, getMemorizedLatest, memorizeLatest, RESIZE_HANDLE_DIAMETER, getExtendPoint, getFactorByPoints, Generator, getRectangleResizeHandleRefs, getDirectionByVector, getOppositeDirection, getDirectionFactor, getPointByVector, reduceRouteMargin, getNextPoint, generateElbowLineRoute, getPoints, removeDuplicatePoints, getPointOnPolyline, getDirectionByPointOfRectangle, rotateVectorAnti90, TRANSPARENT, normalizeShapePoints, getFirstTextEditor, PRIMARY_COLOR, CommonPluginElement, ActiveGenerator, WithTextPluginKey, isVirtualKey, isDelete, isSpaceHotkey, isDndMode, isDrawingMode, acceptImageTypes, getElementOfFocusedImage, buildImage, ResizeHandle, getFirstTextManage, withResize, isResizingByCondition, getRatioByPoint, ImageGenerator } from '@plait/common';
|
|
3
3
|
import { Alignment, buildText, DEFAULT_FONT_SIZE, getTextSize, AlignEditor, TextManage, getTextFromClipboard } from '@plait/text';
|
|
4
4
|
import { pointsOnBezierCurves } from 'points-on-curve';
|
|
5
5
|
import * as i0 from '@angular/core';
|
|
@@ -45,18 +45,7 @@ var FlowchartSymbols;
|
|
|
45
45
|
FlowchartSymbols["delay"] = "delay";
|
|
46
46
|
FlowchartSymbols["storedData"] = "storedData";
|
|
47
47
|
})(FlowchartSymbols || (FlowchartSymbols = {}));
|
|
48
|
-
const PlaitGeometry = {
|
|
49
|
-
getTextEditor(element) {
|
|
50
|
-
return PlaitGeometry.getTextManage(element).componentRef.instance.editor;
|
|
51
|
-
},
|
|
52
|
-
getTextManage(element) {
|
|
53
|
-
const component = PlaitElement.getComponent(element);
|
|
54
|
-
if (component) {
|
|
55
|
-
return component.textManage;
|
|
56
|
-
}
|
|
57
|
-
throw new Error('can not get correctly component in get text editor');
|
|
58
|
-
}
|
|
59
|
-
};
|
|
48
|
+
const PlaitGeometry = {};
|
|
60
49
|
|
|
61
50
|
const ShapeDefaultSpace = {
|
|
62
51
|
rectangleAndText: 4
|
|
@@ -2141,19 +2130,6 @@ var LineHandleKey;
|
|
|
2141
2130
|
LineHandleKey["target"] = "target";
|
|
2142
2131
|
})(LineHandleKey || (LineHandleKey = {}));
|
|
2143
2132
|
const PlaitLine = {
|
|
2144
|
-
getTextEditors(element) {
|
|
2145
|
-
const component = PlaitElement.getComponent(element);
|
|
2146
|
-
if (component) {
|
|
2147
|
-
const manage = component.textManages.find(manage => manage.isEditing);
|
|
2148
|
-
if (manage) {
|
|
2149
|
-
return [manage.componentRef.instance.editor];
|
|
2150
|
-
}
|
|
2151
|
-
else {
|
|
2152
|
-
return component.textManages.map(manage => manage.componentRef.instance.editor);
|
|
2153
|
-
}
|
|
2154
|
-
}
|
|
2155
|
-
throw new Error('can not get correctly component in get text editor');
|
|
2156
|
-
},
|
|
2157
2133
|
isSourceMarkOrTargetMark(line, markType, handleKey) {
|
|
2158
2134
|
if (handleKey === LineHandleKey.source) {
|
|
2159
2135
|
return line.source.marker === markType;
|
|
@@ -2396,7 +2372,7 @@ const normalizePoints = (board, element, width, textHeight) => {
|
|
|
2396
2372
|
let autoSize = element.autoSize;
|
|
2397
2373
|
const defaultSpace = ShapeDefaultSpace.rectangleAndText;
|
|
2398
2374
|
if (autoSize) {
|
|
2399
|
-
const editor =
|
|
2375
|
+
const editor = getFirstTextEditor(element);
|
|
2400
2376
|
if (AlignEditor.isActive(editor, Alignment.right)) {
|
|
2401
2377
|
points = [
|
|
2402
2378
|
[points[1][0] - (width + defaultSpace * 2), points[0][1]],
|
|
@@ -2752,19 +2728,18 @@ function getMiddlePoints(board, element) {
|
|
|
2752
2728
|
return result;
|
|
2753
2729
|
}
|
|
2754
2730
|
|
|
2755
|
-
class LineComponent extends
|
|
2731
|
+
class LineComponent extends CommonPluginElement {
|
|
2756
2732
|
constructor(viewContainerRef, cdr) {
|
|
2757
2733
|
super(cdr);
|
|
2758
2734
|
this.viewContainerRef = viewContainerRef;
|
|
2759
2735
|
this.cdr = cdr;
|
|
2760
2736
|
this.destroy$ = new Subject();
|
|
2761
|
-
this.textManages = [];
|
|
2762
2737
|
this.boundedElements = {};
|
|
2763
2738
|
}
|
|
2764
2739
|
initializeGenerator() {
|
|
2765
2740
|
this.shapeGenerator = new LineShapeGenerator(this.board);
|
|
2766
2741
|
this.activeGenerator = new LineActiveGenerator(this.board);
|
|
2767
|
-
this.
|
|
2742
|
+
this.initializeTextManagesByElement();
|
|
2768
2743
|
}
|
|
2769
2744
|
ngOnInit() {
|
|
2770
2745
|
this.initializeGenerator();
|
|
@@ -2814,22 +2789,19 @@ class LineComponent extends PlaitPluginElementComponent {
|
|
|
2814
2789
|
return;
|
|
2815
2790
|
}
|
|
2816
2791
|
}
|
|
2817
|
-
|
|
2792
|
+
initializeTextManagesByElement() {
|
|
2818
2793
|
if (this.element.texts?.length) {
|
|
2794
|
+
const textManages = [];
|
|
2819
2795
|
this.element.texts.forEach((text, index) => {
|
|
2820
2796
|
const manage = this.createTextManage(text, index);
|
|
2821
|
-
|
|
2797
|
+
textManages.push(manage);
|
|
2822
2798
|
});
|
|
2799
|
+
this.initializeTextManages(textManages);
|
|
2823
2800
|
}
|
|
2824
2801
|
}
|
|
2825
|
-
destroyTextManages() {
|
|
2826
|
-
this.textManages.forEach(manage => {
|
|
2827
|
-
manage.destroy();
|
|
2828
|
-
});
|
|
2829
|
-
}
|
|
2830
2802
|
drawText() {
|
|
2831
2803
|
if (this.element.texts?.length) {
|
|
2832
|
-
this.
|
|
2804
|
+
this.getTextManages().forEach((manage, index) => {
|
|
2833
2805
|
manage.draw(this.element.texts[index].text);
|
|
2834
2806
|
this.g.append(manage.g);
|
|
2835
2807
|
});
|
|
@@ -2861,22 +2833,23 @@ class LineComponent extends PlaitPluginElementComponent {
|
|
|
2861
2833
|
return;
|
|
2862
2834
|
const previousTextsLength = previousTexts.length;
|
|
2863
2835
|
const currentTextsLength = currentTexts.length;
|
|
2836
|
+
const textManages = this.getTextManages();
|
|
2864
2837
|
if (currentTextsLength === previousTextsLength) {
|
|
2865
2838
|
for (let i = 0; i < previousTextsLength; i++) {
|
|
2866
2839
|
if (previousTexts[i].text !== currentTexts[i].text) {
|
|
2867
|
-
|
|
2840
|
+
textManages[i].updateText(currentTexts[i].text);
|
|
2868
2841
|
}
|
|
2869
2842
|
}
|
|
2870
2843
|
}
|
|
2871
2844
|
else {
|
|
2872
2845
|
this.destroyTextManages();
|
|
2873
|
-
this.
|
|
2874
|
-
this.initializeTextManages();
|
|
2846
|
+
this.initializeTextManagesByElement();
|
|
2875
2847
|
this.drawText();
|
|
2876
2848
|
}
|
|
2877
2849
|
}
|
|
2878
2850
|
updateTextRectangle() {
|
|
2879
|
-
this.
|
|
2851
|
+
const textManages = this.getTextManages();
|
|
2852
|
+
textManages.forEach(manage => {
|
|
2880
2853
|
manage.updateRectangle();
|
|
2881
2854
|
});
|
|
2882
2855
|
}
|
|
@@ -2885,6 +2858,7 @@ class LineComponent extends PlaitPluginElementComponent {
|
|
|
2885
2858
|
this.activeGenerator.destroy();
|
|
2886
2859
|
this.destroy$.next();
|
|
2887
2860
|
this.destroy$.complete();
|
|
2861
|
+
this.destroyTextManages();
|
|
2888
2862
|
}
|
|
2889
2863
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LineComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2890
2864
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: LineComponent, isStandalone: true, selector: "plait-draw-line", usesInheritance: true, ngImport: i0, template: ``, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
@@ -2930,7 +2904,7 @@ const withDrawHotkey = (board) => {
|
|
|
2930
2904
|
};
|
|
2931
2905
|
|
|
2932
2906
|
const withGeometryCreateByDrag = (board) => {
|
|
2933
|
-
const { pointerMove,
|
|
2907
|
+
const { pointerMove, globalPointerUp } = board;
|
|
2934
2908
|
let geometryShapeG = null;
|
|
2935
2909
|
let temporaryElement = null;
|
|
2936
2910
|
let fakeCreateTextRef = null;
|
|
@@ -2981,7 +2955,7 @@ const withGeometryCreateByDrag = (board) => {
|
|
|
2981
2955
|
}
|
|
2982
2956
|
pointerMove(event);
|
|
2983
2957
|
};
|
|
2984
|
-
board.
|
|
2958
|
+
board.globalPointerUp = (event) => {
|
|
2985
2959
|
const geometryPointers = getGeometryPointers();
|
|
2986
2960
|
const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);
|
|
2987
2961
|
const dragMode = isGeometryPointer && isDndMode(board);
|
|
@@ -2994,7 +2968,7 @@ const withGeometryCreateByDrag = (board) => {
|
|
|
2994
2968
|
geometryShapeG?.remove();
|
|
2995
2969
|
geometryShapeG = null;
|
|
2996
2970
|
preventTouchMove(board, event, false);
|
|
2997
|
-
|
|
2971
|
+
globalPointerUp(event);
|
|
2998
2972
|
};
|
|
2999
2973
|
return board;
|
|
3000
2974
|
};
|
|
@@ -3205,7 +3179,7 @@ const getBoundedLineElements = (board, plaitShapes) => {
|
|
|
3205
3179
|
};
|
|
3206
3180
|
|
|
3207
3181
|
const withLineCreateByDraw = (board) => {
|
|
3208
|
-
const { pointerDown, pointerMove,
|
|
3182
|
+
const { pointerDown, pointerMove, globalPointerUp } = board;
|
|
3209
3183
|
let start = null;
|
|
3210
3184
|
let sourceElement;
|
|
3211
3185
|
let lineShapeG = null;
|
|
@@ -3234,7 +3208,7 @@ const withLineCreateByDraw = (board) => {
|
|
|
3234
3208
|
}
|
|
3235
3209
|
pointerMove(event);
|
|
3236
3210
|
};
|
|
3237
|
-
board.
|
|
3211
|
+
board.globalPointerUp = (event) => {
|
|
3238
3212
|
if (temporaryElement) {
|
|
3239
3213
|
Transforms.insertNode(board, temporaryElement, [board.children.length]);
|
|
3240
3214
|
clearSelectedElement(board);
|
|
@@ -3247,7 +3221,7 @@ const withLineCreateByDraw = (board) => {
|
|
|
3247
3221
|
start = null;
|
|
3248
3222
|
temporaryElement = null;
|
|
3249
3223
|
preventTouchMove(board, event, false);
|
|
3250
|
-
|
|
3224
|
+
globalPointerUp(event);
|
|
3251
3225
|
};
|
|
3252
3226
|
return board;
|
|
3253
3227
|
};
|
|
@@ -3317,7 +3291,7 @@ const withGeometryResize = (board) => {
|
|
|
3317
3291
|
}
|
|
3318
3292
|
}
|
|
3319
3293
|
if (PlaitDrawElement.isGeometry(resizeRef.element)) {
|
|
3320
|
-
const { height: textHeight } =
|
|
3294
|
+
const { height: textHeight } = getFirstTextManage(resizeRef.element).getSize();
|
|
3321
3295
|
DrawTransforms.resizeGeometry(board, points, textHeight, resizeRef.path);
|
|
3322
3296
|
}
|
|
3323
3297
|
else {
|
|
@@ -3538,7 +3512,7 @@ const withLineText = (board) => {
|
|
|
3538
3512
|
DrawTransforms.setLineTexts(board, hitTarget, texts);
|
|
3539
3513
|
setTimeout(() => {
|
|
3540
3514
|
const hitComponent = PlaitElement.getComponent(hitTarget);
|
|
3541
|
-
editHandle(board, hitTarget, hitComponent.
|
|
3515
|
+
editHandle(board, hitTarget, hitComponent.getTextManages().length - 1, true);
|
|
3542
3516
|
});
|
|
3543
3517
|
}
|
|
3544
3518
|
}
|
|
@@ -3549,7 +3523,7 @@ const withLineText = (board) => {
|
|
|
3549
3523
|
};
|
|
3550
3524
|
function editHandle(board, element, manageIndex, isFirstEdit = false) {
|
|
3551
3525
|
const hitComponent = PlaitElement.getComponent(element);
|
|
3552
|
-
const textManage = hitComponent.
|
|
3526
|
+
const textManage = hitComponent.getTextManages()[manageIndex];
|
|
3553
3527
|
const originText = textManage.componentRef.instance.children;
|
|
3554
3528
|
textManage.edit((origin, descendant) => {
|
|
3555
3529
|
const text = Node.string(descendant[0]);
|
|
@@ -3670,7 +3644,7 @@ const withLineAutoCompleteReaction = (board) => {
|
|
|
3670
3644
|
|
|
3671
3645
|
const WithLineAutoCompletePluginKey = 'plait-line-auto-complete-plugin-key';
|
|
3672
3646
|
const withLineAutoComplete = (board) => {
|
|
3673
|
-
const { pointerDown, pointerMove,
|
|
3647
|
+
const { pointerDown, pointerMove, globalPointerUp } = board;
|
|
3674
3648
|
let startPoint = null;
|
|
3675
3649
|
let lineShapeG = null;
|
|
3676
3650
|
let sourceElement;
|
|
@@ -3704,7 +3678,7 @@ const withLineAutoComplete = (board) => {
|
|
|
3704
3678
|
}
|
|
3705
3679
|
pointerMove(event);
|
|
3706
3680
|
};
|
|
3707
|
-
board.
|
|
3681
|
+
board.globalPointerUp = event => {
|
|
3708
3682
|
if (temporaryElement) {
|
|
3709
3683
|
Transforms.insertNode(board, temporaryElement, [board.children.length]);
|
|
3710
3684
|
clearSelectedElement(board);
|
|
@@ -3721,7 +3695,7 @@ const withLineAutoComplete = (board) => {
|
|
|
3721
3695
|
lineShapeG = null;
|
|
3722
3696
|
sourceElement = null;
|
|
3723
3697
|
temporaryElement = null;
|
|
3724
|
-
|
|
3698
|
+
globalPointerUp(event);
|
|
3725
3699
|
};
|
|
3726
3700
|
return board;
|
|
3727
3701
|
};
|
|
@@ -3742,7 +3716,7 @@ const withLineTextMove = (board) => {
|
|
|
3742
3716
|
if (line) {
|
|
3743
3717
|
const index = getHitLineTextIndex(board, line, point);
|
|
3744
3718
|
const hitComponent = PlaitElement.getComponent(line);
|
|
3745
|
-
const textManage = hitComponent.
|
|
3719
|
+
const textManage = hitComponent.getTextManages()[index];
|
|
3746
3720
|
if (index !== -1 && !textManage.isEditing) {
|
|
3747
3721
|
textIndex = index;
|
|
3748
3722
|
return { element: line, handle: ResizeHandle.e };
|
|
@@ -3774,7 +3748,7 @@ const withLineTextMove = (board) => {
|
|
|
3774
3748
|
};
|
|
3775
3749
|
|
|
3776
3750
|
const withDraw = (board) => {
|
|
3777
|
-
const { drawElement, getRectangle, isRectangleHit, isHit, isMovable, isAlign } = board;
|
|
3751
|
+
const { drawElement, getRectangle, isRectangleHit, isHit, isMovable, isAlign, getRelatedFragment } = board;
|
|
3778
3752
|
board.drawElement = (context) => {
|
|
3779
3753
|
if (PlaitDrawElement.isGeometry(context.element)) {
|
|
3780
3754
|
return GeometryComponent;
|
|
@@ -3842,6 +3816,17 @@ const withDraw = (board) => {
|
|
|
3842
3816
|
}
|
|
3843
3817
|
return isAlign(element);
|
|
3844
3818
|
};
|
|
3819
|
+
board.getRelatedFragment = (elements) => {
|
|
3820
|
+
const selectedElements = getSelectedElements(board);
|
|
3821
|
+
const lineElements = board.children.filter(element => PlaitDrawElement.isLine(element));
|
|
3822
|
+
const activeLines = lineElements.filter(line => {
|
|
3823
|
+
const source = selectedElements.find(element => element.id === line.source.boundId);
|
|
3824
|
+
const target = selectedElements.find(element => element.id === line.target.boundId);
|
|
3825
|
+
const isSelected = selectedElements.includes(line);
|
|
3826
|
+
return source && target && !isSelected;
|
|
3827
|
+
});
|
|
3828
|
+
return getRelatedFragment([...elements, ...activeLines]);
|
|
3829
|
+
};
|
|
3845
3830
|
return withLineTextMove(withLineAutoCompleteReaction(withLineText(withLineBoundReaction(withLineResize(withGeometryResize(withLineCreateByDraw(withLineAutoComplete(withGeometryCreateByDrag(withGeometryCreateByDrawing(withDrawFragment(withDrawHotkey(board))))))))))));
|
|
3846
3831
|
};
|
|
3847
3832
|
|