@plait/common 0.77.3 → 0.78.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/fesm2022/plait-common.mjs.map +1 -1
- package/package.json +1 -3
- package/esm2022/algorithms/a-star.mjs +0 -58
- package/esm2022/algorithms/data-structures/graph.mjs +0 -47
- package/esm2022/algorithms/data-structures/index.mjs +0 -3
- package/esm2022/algorithms/data-structures/priority-queue.mjs +0 -13
- package/esm2022/algorithms/index.mjs +0 -3
- package/esm2022/constants/default.mjs +0 -11
- package/esm2022/constants/index.mjs +0 -5
- package/esm2022/constants/media.mjs +0 -8
- package/esm2022/constants/property.mjs +0 -7
- package/esm2022/constants/resize.mjs +0 -12
- package/esm2022/core/element-flavour.mjs +0 -8
- package/esm2022/core/element-ref.mjs +0 -32
- package/esm2022/core/group.component.mjs +0 -39
- package/esm2022/core/index.mjs +0 -5
- package/esm2022/core/render-component.mjs +0 -2
- package/esm2022/generators/active.generator.mjs +0 -50
- package/esm2022/generators/generator.mjs +0 -70
- package/esm2022/generators/group.generator.mjs +0 -21
- package/esm2022/generators/index.mjs +0 -4
- package/esm2022/image/image-base.component.mjs +0 -9
- package/esm2022/image/image.generator.mjs +0 -98
- package/esm2022/image/index.mjs +0 -4
- package/esm2022/image/with-image.mjs +0 -8
- package/esm2022/plait-common.mjs +0 -5
- package/esm2022/plugins/index.mjs +0 -3
- package/esm2022/plugins/with-group.mjs +0 -198
- package/esm2022/plugins/with-resize.mjs +0 -111
- package/esm2022/public-api.mjs +0 -16
- package/esm2022/shapes/common.mjs +0 -14
- package/esm2022/shapes/index.mjs +0 -2
- package/esm2022/text/index.mjs +0 -5
- package/esm2022/text/text-manage.mjs +0 -147
- package/esm2022/text/text-measure.mjs +0 -59
- package/esm2022/text/types.mjs +0 -7
- package/esm2022/text/with-text.mjs +0 -8
- package/esm2022/transforms/align.mjs +0 -116
- package/esm2022/transforms/index.mjs +0 -3
- package/esm2022/transforms/property.mjs +0 -40
- package/esm2022/types/index.mjs +0 -3
- package/esm2022/types/resize.mjs +0 -2
- package/esm2022/types/rotate.mjs +0 -2
- package/esm2022/utils/animate.mjs +0 -38
- package/esm2022/utils/clipboard.mjs +0 -30
- package/esm2022/utils/creation-mode.mjs +0 -19
- package/esm2022/utils/default-orthogonal-routing.mjs +0 -87
- package/esm2022/utils/direction.mjs +0 -93
- package/esm2022/utils/drawing/index.mjs +0 -3
- package/esm2022/utils/drawing/resize-handle.mjs +0 -25
- package/esm2022/utils/drawing/rotate-handle.mjs +0 -22
- package/esm2022/utils/elbow-line-route.mjs +0 -256
- package/esm2022/utils/elements.mjs +0 -19
- package/esm2022/utils/hot-key.mjs +0 -29
- package/esm2022/utils/image.mjs +0 -50
- package/esm2022/utils/index.mjs +0 -19
- package/esm2022/utils/line-path.mjs +0 -80
- package/esm2022/utils/math.mjs +0 -24
- package/esm2022/utils/memorize.mjs +0 -10
- package/esm2022/utils/resize.mjs +0 -137
- package/esm2022/utils/rotate.mjs +0 -16
- package/esm2022/utils/stroke.mjs +0 -12
- package/esm2022/utils/text.mjs +0 -105
- package/esm2022/utils/vector.mjs +0 -43
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
import { ACTIVE_STROKE_WIDTH, PlaitBoard, RectangleClient, createForeignObject, createG, getSelectedElements, isSelectionMoving, setAngleForG, updateForeignObject } from '@plait/core';
|
|
2
|
-
import { Generator } from '../generators/generator';
|
|
3
|
-
import { hasResizeHandle, getElementOfFocusedImage } from '../utils';
|
|
4
|
-
import { createActiveGenerator } from '../generators/active.generator';
|
|
5
|
-
export const FOREIGN_OBJECT_IMAGE_CLASS_NAME = 'foreign-object-image';
|
|
6
|
-
export class ImageGenerator extends Generator {
|
|
7
|
-
static { this.key = 'image-generator'; }
|
|
8
|
-
constructor(board, options) {
|
|
9
|
-
super(board, options);
|
|
10
|
-
this.board = board;
|
|
11
|
-
this.options = options;
|
|
12
|
-
this.isFocus = false;
|
|
13
|
-
}
|
|
14
|
-
canDraw(element) {
|
|
15
|
-
return !!this.options.getImageItem(element);
|
|
16
|
-
}
|
|
17
|
-
draw(element) {
|
|
18
|
-
this.element = element;
|
|
19
|
-
const g = createG();
|
|
20
|
-
const foreignRectangle = this.options.getRectangle(element);
|
|
21
|
-
this.foreignObject = createForeignObject(foreignRectangle.x, foreignRectangle.y, foreignRectangle.width, foreignRectangle.height);
|
|
22
|
-
this.foreignObject.classList.add(FOREIGN_OBJECT_IMAGE_CLASS_NAME);
|
|
23
|
-
g.append(this.foreignObject);
|
|
24
|
-
const props = {
|
|
25
|
-
board: this.board,
|
|
26
|
-
imageItem: this.options.getImageItem(element),
|
|
27
|
-
element,
|
|
28
|
-
getRectangle: () => {
|
|
29
|
-
return this.options.getRectangle(element);
|
|
30
|
-
}
|
|
31
|
-
};
|
|
32
|
-
this.imageComponentRef = this.board.renderImage(this.foreignObject, props);
|
|
33
|
-
this.activeGenerator = createActiveGenerator(this.board, {
|
|
34
|
-
getStrokeWidth: () => {
|
|
35
|
-
const selectedElements = getSelectedElements(this.board);
|
|
36
|
-
if (!(selectedElements.length === 1 && !isSelectionMoving(this.board))) {
|
|
37
|
-
return ACTIVE_STROKE_WIDTH;
|
|
38
|
-
}
|
|
39
|
-
else {
|
|
40
|
-
return ACTIVE_STROKE_WIDTH;
|
|
41
|
-
}
|
|
42
|
-
},
|
|
43
|
-
getStrokeOpacity: () => {
|
|
44
|
-
const selectedElements = getSelectedElements(this.board);
|
|
45
|
-
if ((selectedElements.length === 1 && !isSelectionMoving(this.board)) || !selectedElements.length) {
|
|
46
|
-
return 1;
|
|
47
|
-
}
|
|
48
|
-
else {
|
|
49
|
-
return 0.5;
|
|
50
|
-
}
|
|
51
|
-
},
|
|
52
|
-
getRectangle: () => {
|
|
53
|
-
return this.options.getRectangle(this.element);
|
|
54
|
-
},
|
|
55
|
-
hasResizeHandle: () => {
|
|
56
|
-
const isSelectedImageElement = hasResizeHandle(this.board, this.element);
|
|
57
|
-
const isSelectedImage = !!getElementOfFocusedImage(this.board);
|
|
58
|
-
return isSelectedImage || isSelectedImageElement;
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
|
-
return g;
|
|
62
|
-
}
|
|
63
|
-
updateImage(nodeG, previous, current) {
|
|
64
|
-
this.element = current;
|
|
65
|
-
if (previous !== current && this.imageComponentRef) {
|
|
66
|
-
const props = {
|
|
67
|
-
imageItem: this.options.getImageItem(current),
|
|
68
|
-
element: current,
|
|
69
|
-
getRectangle: () => {
|
|
70
|
-
return this.options.getRectangle(current);
|
|
71
|
-
}
|
|
72
|
-
};
|
|
73
|
-
this.imageComponentRef.update(props);
|
|
74
|
-
}
|
|
75
|
-
const currentForeignObject = this.options.getRectangle(current);
|
|
76
|
-
updateForeignObject(this.g, currentForeignObject.width, currentForeignObject.height, currentForeignObject.x, currentForeignObject.y);
|
|
77
|
-
if (currentForeignObject && current.angle !== undefined) {
|
|
78
|
-
setAngleForG(this.g, RectangleClient.getCenterPoint(currentForeignObject), current.angle);
|
|
79
|
-
}
|
|
80
|
-
const activeG = PlaitBoard.getActiveHost(this.board);
|
|
81
|
-
this.activeGenerator.processDrawing(current, activeG, { selected: this.isFocus });
|
|
82
|
-
}
|
|
83
|
-
setFocus(element, isFocus) {
|
|
84
|
-
this.isFocus = isFocus;
|
|
85
|
-
const activeG = PlaitBoard.getActiveHost(this.board);
|
|
86
|
-
this.activeGenerator.processDrawing(element, activeG, { selected: isFocus });
|
|
87
|
-
const props = {
|
|
88
|
-
isFocus
|
|
89
|
-
};
|
|
90
|
-
this.imageComponentRef.update(props);
|
|
91
|
-
}
|
|
92
|
-
destroy() {
|
|
93
|
-
super.destroy();
|
|
94
|
-
this.imageComponentRef?.destroy();
|
|
95
|
-
this.activeGenerator?.destroy();
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.generator.js","sourceRoot":"","sources":["../../../../packages/common/src/image/image.generator.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ACTIVE_STROKE_WIDTH,\n    PlaitBoard,\n    PlaitElement,\n    RectangleClient,\n    createForeignObject,\n    createG,\n    getSelectedElements,\n    isSelectionMoving,\n    setAngleForG,\n    updateForeignObject\n} from '@plait/core';\nimport { Generator, GeneratorExtraData, GeneratorOptions } from '../generators/generator';\nimport { CommonImageItem, hasResizeHandle, getElementOfFocusedImage } from '../utils';\nimport { ActiveGenerator, createActiveGenerator } from '../generators/active.generator';\nimport { PlaitImageBoard, ImageComponentRef, ImageProps } from './with-image';\n\nexport const FOREIGN_OBJECT_IMAGE_CLASS_NAME = 'foreign-object-image';\n\nexport interface ImageGeneratorOptions<T> {\n    getRectangle: (element: T) => RectangleClient;\n    getImageItem: (element: T) => CommonImageItem;\n}\n\nexport class ImageGenerator<T extends PlaitElement = PlaitElement> extends Generator<\n    T,\n    GeneratorExtraData,\n    ImageGeneratorOptions<T> & GeneratorOptions\n> {\n    static key = 'image-generator';\n\n    foreignObject!: SVGForeignObjectElement;\n\n    imageComponentRef!: ImageComponentRef;\n\n    activeGenerator!: ActiveGenerator;\n\n    isFocus = false;\n\n    element!: T;\n\n    constructor(public board: PlaitBoard, public options: ImageGeneratorOptions<T>) {\n        super(board, options);\n    }\n\n    canDraw(element: T): boolean {\n        return !!this.options.getImageItem(element);\n    }\n\n    draw(element: T): SVGGElement {\n        this.element = element;\n        const g = createG();\n        const foreignRectangle = this.options.getRectangle(element);\n        this.foreignObject = createForeignObject(foreignRectangle.x, foreignRectangle.y, foreignRectangle.width, foreignRectangle.height);\n        this.foreignObject.classList.add(FOREIGN_OBJECT_IMAGE_CLASS_NAME);\n        g.append(this.foreignObject);\n        const props: ImageProps = {\n            board: this.board,\n            imageItem: this.options.getImageItem(element),\n            element,\n            getRectangle: () => {\n                return this.options.getRectangle(element);\n            }\n        };\n        this.imageComponentRef = (this.board as unknown as PlaitImageBoard).renderImage(this.foreignObject, props);\n\n        this.activeGenerator = createActiveGenerator(this.board, {\n            getStrokeWidth: () => {\n                const selectedElements = getSelectedElements(this.board);\n                if (!(selectedElements.length === 1 && !isSelectionMoving(this.board))) {\n                    return ACTIVE_STROKE_WIDTH;\n                } else {\n                    return ACTIVE_STROKE_WIDTH;\n                }\n            },\n            getStrokeOpacity: () => {\n                const selectedElements = getSelectedElements(this.board);\n                if ((selectedElements.length === 1 && !isSelectionMoving(this.board)) || !selectedElements.length) {\n                    return 1;\n                } else {\n                    return 0.5;\n                }\n            },\n            getRectangle: () => {\n                return this.options.getRectangle(this.element);\n            },\n            hasResizeHandle: () => {\n                const isSelectedImageElement = hasResizeHandle(this.board, this.element);\n                const isSelectedImage = !!getElementOfFocusedImage(this.board);\n                return isSelectedImage || isSelectedImageElement;\n            }\n        });\n        return g;\n    }\n\n    updateImage(nodeG: SVGGElement, previous: T, current: T) {\n        this.element = current;\n        if (previous !== current && this.imageComponentRef) {\n            const props = {\n                imageItem: this.options.getImageItem(current),\n                element: current,\n                getRectangle: () => {\n                    return this.options.getRectangle(current);\n                }\n            };\n            this.imageComponentRef.update(props);\n        }\n        const currentForeignObject = this.options.getRectangle(current);\n        updateForeignObject(\n            this.g!,\n            currentForeignObject.width,\n            currentForeignObject.height,\n            currentForeignObject.x,\n            currentForeignObject.y\n        );\n        if (currentForeignObject && current.angle !== undefined) {\n            setAngleForG(this.g!, RectangleClient.getCenterPoint(currentForeignObject), current.angle);\n        }\n        const activeG = PlaitBoard.getActiveHost(this.board);\n        this.activeGenerator.processDrawing(current, activeG, { selected: this.isFocus });\n    }\n\n    setFocus(element: PlaitElement, isFocus: boolean) {\n        this.isFocus = isFocus;\n        const activeG = PlaitBoard.getActiveHost(this.board);\n        this.activeGenerator.processDrawing(element, activeG, { selected: isFocus });\n        const props: Partial<ImageProps> = {\n            isFocus\n        };\n        this.imageComponentRef.update(props);\n    }\n\n    destroy(): void {\n        super.destroy();\n        this.imageComponentRef?.destroy();\n        this.activeGenerator?.destroy();\n    }\n}\n"]}
|
package/esm2022/image/index.mjs
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
export * from './image-base.component';
|
|
2
|
-
export * from './image.generator';
|
|
3
|
-
export * from './with-image';
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21tb24vc3JjL2ltYWdlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vaW1hZ2UtYmFzZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9pbWFnZS5nZW5lcmF0b3InO1xuZXhwb3J0ICogZnJvbSAnLi93aXRoLWltYWdlJztcbiJdfQ==
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
export const withImage = (board) => {
|
|
2
|
-
const newBoard = board;
|
|
3
|
-
newBoard.renderImage = (container, props) => {
|
|
4
|
-
throw new Error('No implementation for renderImage method.');
|
|
5
|
-
};
|
|
6
|
-
return newBoard;
|
|
7
|
-
};
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1pbWFnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbW1vbi9zcmMvaW1hZ2Uvd2l0aC1pbWFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRQSxNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsQ0FBb0MsS0FBUSxFQUFFLEVBQUU7SUFDckUsTUFBTSxRQUFRLEdBQUcsS0FBNEIsQ0FBQztJQUU5QyxRQUFRLENBQUMsV0FBVyxHQUFHLENBQUMsU0FBcUMsRUFBRSxLQUFpQixFQUFFLEVBQUU7UUFDaEYsTUFBTSxJQUFJLEtBQUssQ0FBQywyQ0FBMkMsQ0FBQyxDQUFDO0lBQ2pFLENBQUMsQ0FBQztJQUNGLE9BQU8sUUFBUSxDQUFDO0FBQ3BCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Qm9hcmQsIFBsYWl0RWxlbWVudCwgUmVjdGFuZ2xlQ2xpZW50IH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgUmVuZGVyQ29tcG9uZW50UmVmIH0gZnJvbSAnLi4vY29yZS9yZW5kZXItY29tcG9uZW50JztcbmltcG9ydCB7IENvbW1vbkltYWdlSXRlbSB9IGZyb20gJy4uL3V0aWxzL2ltYWdlJztcblxuZXhwb3J0IGludGVyZmFjZSBQbGFpdEltYWdlQm9hcmQge1xuICAgIHJlbmRlckltYWdlOiAoY29udGFpbmVyOiBFbGVtZW50IHwgRG9jdW1lbnRGcmFnbWVudCwgcHJvcHM6IEltYWdlUHJvcHMpID0+IEltYWdlQ29tcG9uZW50UmVmO1xufVxuXG5leHBvcnQgY29uc3Qgd2l0aEltYWdlID0gPFQgZXh0ZW5kcyBQbGFpdEJvYXJkID0gUGxhaXRCb2FyZD4oYm9hcmQ6IFQpID0+IHtcbiAgICBjb25zdCBuZXdCb2FyZCA9IGJvYXJkIGFzIFQgJiBQbGFpdEltYWdlQm9hcmQ7XG5cbiAgICBuZXdCb2FyZC5yZW5kZXJJbWFnZSA9IChjb250YWluZXI6IEVsZW1lbnQgfCBEb2N1bWVudEZyYWdtZW50LCBwcm9wczogSW1hZ2VQcm9wcykgPT4ge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ05vIGltcGxlbWVudGF0aW9uIGZvciByZW5kZXJJbWFnZSBtZXRob2QuJyk7XG4gICAgfTtcbiAgICByZXR1cm4gbmV3Qm9hcmQ7XG59O1xuXG5leHBvcnQgdHlwZSBJbWFnZUNvbXBvbmVudFJlZiA9IFJlbmRlckNvbXBvbmVudFJlZjxJbWFnZVByb3BzPjtcblxuZXhwb3J0IGludGVyZmFjZSBJbWFnZVByb3BzIHtcbiAgICBib2FyZDogUGxhaXRCb2FyZDtcbiAgICBpbWFnZUl0ZW06IENvbW1vbkltYWdlSXRlbTtcbiAgICBlbGVtZW50OiBQbGFpdEVsZW1lbnQ7XG4gICAgaXNGb2N1cz86IGJvb2xlYW47XG4gICAgZ2V0UmVjdGFuZ2xlOiAoKSA9PiBSZWN0YW5nbGVDbGllbnQ7XG59XG4iXX0=
|
package/esm2022/plait-common.mjs
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './public-api';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhaXQtY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGFja2FnZXMvY29tbW9uL3NyYy9wbGFpdC1jb21tb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
export * from './with-resize';
|
|
2
|
-
export * from './with-group';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21tb24vc3JjL3BsdWdpbnMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3dpdGgtcmVzaXplJztcbmV4cG9ydCAqIGZyb20gJy4vd2l0aC1ncm91cCc7XG4iXX0=
|
|
@@ -1,198 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard, PlaitGroupElement, toViewBoxPoint, toHostPoint, getHitElementsBySelection, createGroupRectangleG, getHighestSelectedGroups, getSelectedIsolatedElements, getSelectedGroups, Selection, Transforms, idCreator, getGroupByElement, getSelectedIsolatedElementsCanAddToGroup, getElementsInGroup, getRectangleByGroup, PlaitPointerType, throttleRAF, isMovingElements } from '@plait/core';
|
|
2
|
-
import { GroupComponent } from '../core/group.component';
|
|
3
|
-
import { isKeyHotkey } from 'is-hotkey';
|
|
4
|
-
import { isResizing } from '../utils';
|
|
5
|
-
export function withGroup(board) {
|
|
6
|
-
let groupRectangleG;
|
|
7
|
-
let removeGroups;
|
|
8
|
-
const { drawElement, pointerMove, globalPointerUp, insertFragment, getDeletedFragment, deleteFragment, getRelatedFragment, getRectangle, keyDown } = board;
|
|
9
|
-
board.drawElement = (context) => {
|
|
10
|
-
if (PlaitGroupElement.isGroup(context.element)) {
|
|
11
|
-
return GroupComponent;
|
|
12
|
-
}
|
|
13
|
-
return drawElement(context);
|
|
14
|
-
};
|
|
15
|
-
board.pointerMove = (event) => {
|
|
16
|
-
throttleRAF(board, 'with-group', () => {
|
|
17
|
-
groupRectangleG?.remove();
|
|
18
|
-
const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
19
|
-
let selection = { anchor: point, focus: point };
|
|
20
|
-
if (board.selection && !Selection.isCollapsed(board.selection)) {
|
|
21
|
-
selection = board.selection;
|
|
22
|
-
}
|
|
23
|
-
const pointer = PlaitBoard.getPointer(board);
|
|
24
|
-
if (!isResizing(board) && !isMovingElements(board) && pointer === PlaitPointerType.selection) {
|
|
25
|
-
const hitElements = getHitElementsBySelection(board, selection);
|
|
26
|
-
if (hitElements.length) {
|
|
27
|
-
groupRectangleG = createGroupRectangleG(board, hitElements);
|
|
28
|
-
groupRectangleG && PlaitBoard.getElementTopHost(board).append(groupRectangleG);
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
});
|
|
32
|
-
pointerMove(event);
|
|
33
|
-
};
|
|
34
|
-
board.globalPointerUp = (event) => {
|
|
35
|
-
groupRectangleG?.remove();
|
|
36
|
-
groupRectangleG = null;
|
|
37
|
-
globalPointerUp(event);
|
|
38
|
-
};
|
|
39
|
-
board.getRelatedFragment = (elements, originData) => {
|
|
40
|
-
const groups = getSelectedGroups(board, elements, originData);
|
|
41
|
-
return getRelatedFragment([...elements, ...groups], originData);
|
|
42
|
-
};
|
|
43
|
-
board.insertFragment = (clipboardData, targetPoint, operationType) => {
|
|
44
|
-
let elements = [];
|
|
45
|
-
if (clipboardData?.elements?.length) {
|
|
46
|
-
elements = new Array(clipboardData?.elements?.length);
|
|
47
|
-
const groups = getHighestSelectedGroups(board, clipboardData?.elements);
|
|
48
|
-
const selectedIsolatedElements = getSelectedIsolatedElements(board, clipboardData?.elements);
|
|
49
|
-
selectedIsolatedElements.forEach((item) => {
|
|
50
|
-
const index = clipboardData.elements.map((element) => element.id).indexOf(item.id);
|
|
51
|
-
elements.splice(index, 1, !item.groupId ? item : updateGroupId(item, undefined));
|
|
52
|
-
});
|
|
53
|
-
if (groups.length) {
|
|
54
|
-
groups.forEach((item) => {
|
|
55
|
-
const index = clipboardData.elements.map((element) => element.id).indexOf(item.id);
|
|
56
|
-
const newGroup = { ...updateGroupId(item, undefined), id: idCreator() };
|
|
57
|
-
elements.splice(index, 1, newGroup);
|
|
58
|
-
updateElementsGroupId(item, clipboardData.elements, newGroup.id, elements);
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
clipboardData.elements = elements;
|
|
62
|
-
}
|
|
63
|
-
insertFragment(clipboardData, targetPoint, operationType);
|
|
64
|
-
const groupElements = elements?.filter((value) => PlaitGroupElement.isGroup(value));
|
|
65
|
-
groupElements.forEach((element) => {
|
|
66
|
-
Transforms.insertNode(board, element, [board.children.length]);
|
|
67
|
-
});
|
|
68
|
-
};
|
|
69
|
-
board.getDeletedFragment = (data) => {
|
|
70
|
-
removeGroups = getRemoveGroups(board);
|
|
71
|
-
if (removeGroups && removeGroups.length) {
|
|
72
|
-
data.push(...removeGroups);
|
|
73
|
-
}
|
|
74
|
-
return getDeletedFragment(data);
|
|
75
|
-
};
|
|
76
|
-
board.deleteFragment = (elements) => {
|
|
77
|
-
if (removeGroups?.length) {
|
|
78
|
-
updateSiblingElementGroupId(board, removeGroups);
|
|
79
|
-
}
|
|
80
|
-
deleteFragment(elements);
|
|
81
|
-
removeGroups = null;
|
|
82
|
-
};
|
|
83
|
-
board.getRectangle = (element) => {
|
|
84
|
-
if (PlaitGroupElement.isGroup(element)) {
|
|
85
|
-
return getRectangleByGroup(board, element, true);
|
|
86
|
-
}
|
|
87
|
-
return getRectangle(element);
|
|
88
|
-
};
|
|
89
|
-
board.keyDown = (event) => {
|
|
90
|
-
if (!PlaitBoard.isReadonly(board)) {
|
|
91
|
-
if (isKeyHotkey('mod+g', event)) {
|
|
92
|
-
event.preventDefault();
|
|
93
|
-
Transforms.addGroup(board);
|
|
94
|
-
return;
|
|
95
|
-
}
|
|
96
|
-
if (isKeyHotkey('mod+shift+g', event)) {
|
|
97
|
-
event.preventDefault();
|
|
98
|
-
Transforms.removeGroup(board);
|
|
99
|
-
return;
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
keyDown(event);
|
|
103
|
-
};
|
|
104
|
-
return board;
|
|
105
|
-
}
|
|
106
|
-
const updateGroupId = (element, groupId) => {
|
|
107
|
-
return {
|
|
108
|
-
...element,
|
|
109
|
-
groupId: groupId
|
|
110
|
-
};
|
|
111
|
-
};
|
|
112
|
-
const updateElementsGroupId = (group, clipboardDataElements, newGroupId, elements) => {
|
|
113
|
-
const elementsInGroup = clipboardDataElements.filter((item) => item.groupId === group.id);
|
|
114
|
-
if (elementsInGroup.length) {
|
|
115
|
-
elementsInGroup.forEach((item) => {
|
|
116
|
-
const index = clipboardDataElements.map((item) => item.id).indexOf(item.id);
|
|
117
|
-
if (PlaitGroupElement.isGroup(item)) {
|
|
118
|
-
const newGroup = { ...updateGroupId(item, newGroupId), id: idCreator() };
|
|
119
|
-
elements.splice(index, 1, newGroup);
|
|
120
|
-
updateElementsGroupId(item, clipboardDataElements, newGroup.id, elements);
|
|
121
|
-
}
|
|
122
|
-
else {
|
|
123
|
-
elements.splice(index, 1, updateGroupId(item, newGroupId));
|
|
124
|
-
}
|
|
125
|
-
});
|
|
126
|
-
}
|
|
127
|
-
return elements;
|
|
128
|
-
};
|
|
129
|
-
const getRemoveGroups = (board) => {
|
|
130
|
-
const selectedGroups = board.getRelatedFragment([]);
|
|
131
|
-
const removeGroups = [...selectedGroups];
|
|
132
|
-
const highestSelectedGroups = getHighestSelectedGroups(board);
|
|
133
|
-
const selectedIsolatedElements = getSelectedIsolatedElementsCanAddToGroup(board);
|
|
134
|
-
const removeNodes = [...highestSelectedGroups, ...selectedIsolatedElements];
|
|
135
|
-
removeNodes.forEach((item) => {
|
|
136
|
-
const hitElementGroups = getGroupByElement(board, item, true);
|
|
137
|
-
if (hitElementGroups.length) {
|
|
138
|
-
const elementsInGroup = getElementsInGroup(board, hitElementGroups[0], false, true);
|
|
139
|
-
const siblingElements = elementsInGroup.filter((element) => ![...removeNodes, ...removeGroups].map((item) => item.id).includes(element.id));
|
|
140
|
-
if (siblingElements.length === 1 || siblingElements.length === 0) {
|
|
141
|
-
if (!removeGroups.includes(hitElementGroups[0])) {
|
|
142
|
-
removeGroups.push(hitElementGroups[0]);
|
|
143
|
-
}
|
|
144
|
-
if (siblingElements.length === 1) {
|
|
145
|
-
if (hitElementGroups.length > 1) {
|
|
146
|
-
const aboveGroup = findAboveGroupWithAnotherElement(board, hitElementGroups.slice(1, hitElementGroups.length), [
|
|
147
|
-
...removeNodes,
|
|
148
|
-
...removeGroups
|
|
149
|
-
]);
|
|
150
|
-
let index = hitElementGroups.length;
|
|
151
|
-
if (aboveGroup) {
|
|
152
|
-
index = hitElementGroups.findIndex((item) => item.id === aboveGroup.id);
|
|
153
|
-
}
|
|
154
|
-
[...hitElementGroups.slice(1, index)].forEach((item) => {
|
|
155
|
-
if (!removeGroups.includes(item)) {
|
|
156
|
-
removeGroups.push(item);
|
|
157
|
-
}
|
|
158
|
-
});
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
});
|
|
164
|
-
return removeGroups;
|
|
165
|
-
};
|
|
166
|
-
const findAboveGroupWithAnotherElement = (board, groups, excludeNodes) => {
|
|
167
|
-
let group = null;
|
|
168
|
-
for (let i = 0; i < groups.length; i++) {
|
|
169
|
-
const elementsInGroup = getElementsInGroup(board, groups[i], false, true);
|
|
170
|
-
const siblingElements = elementsInGroup.filter((element) => !excludeNodes.map((item) => item.id).includes(element.id));
|
|
171
|
-
if (siblingElements.length > 0) {
|
|
172
|
-
group = groups[i];
|
|
173
|
-
break;
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
return group;
|
|
177
|
-
};
|
|
178
|
-
const updateSiblingElementGroupId = (board, removeGroups) => {
|
|
179
|
-
const selectedIsolatedElements = getSelectedIsolatedElementsCanAddToGroup(board);
|
|
180
|
-
const highestSelectedGroups = getHighestSelectedGroups(board);
|
|
181
|
-
const isolatedElementsInGroup = selectedIsolatedElements.filter((item) => item.groupId);
|
|
182
|
-
[...highestSelectedGroups, ...isolatedElementsInGroup].forEach((item) => {
|
|
183
|
-
const hitElementGroups = getGroupByElement(board, item, true);
|
|
184
|
-
if (hitElementGroups.length) {
|
|
185
|
-
const elementsInGroup = getElementsInGroup(board, hitElementGroups[0], false, true);
|
|
186
|
-
const siblingElements = elementsInGroup.filter((element) => element.id !== item.id);
|
|
187
|
-
if (siblingElements.length === 1) {
|
|
188
|
-
const removeGroupIds = removeGroups.map((item) => item.id);
|
|
189
|
-
if (hitElementGroups.some((group) => removeGroupIds.includes(group.id))) {
|
|
190
|
-
const group = hitElementGroups.find((group) => !removeGroupIds.includes(group.id));
|
|
191
|
-
const path = PlaitBoard.findPath(board, siblingElements[0]);
|
|
192
|
-
Transforms.setNode(board, { groupId: group?.id || undefined }, path);
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
});
|
|
197
|
-
};
|
|
198
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-group.js","sourceRoot":"","sources":["../../../../packages/common/src/plugins/with-group.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    PlaitPluginElementContext,\n    PlaitGroupElement,\n    toViewBoxPoint,\n    toHostPoint,\n    getHitElementsBySelection,\n    createGroupRectangleG,\n    ClipboardData,\n    getHighestSelectedGroups,\n    getSelectedIsolatedElements,\n    PlaitElement,\n    PlaitGroup,\n    getSelectedGroups,\n    Selection,\n    Point,\n    Transforms,\n    idCreator,\n    getGroupByElement,\n    getSelectedIsolatedElementsCanAddToGroup,\n    getElementsInGroup,\n    getRectangleByGroup,\n    PlaitPointerType,\n    WritableClipboardOperationType,\n    throttleRAF,\n    isMovingElements\n} from '@plait/core';\nimport { GroupComponent } from '../core/group.component';\nimport { isKeyHotkey } from 'is-hotkey';\nimport { isResizing } from '../utils';\n\nexport function withGroup(board: PlaitBoard) {\n    let groupRectangleG: SVGGElement | null;\n    let removeGroups: PlaitGroup[] | null;\n\n    const {\n        drawElement,\n        pointerMove,\n        globalPointerUp,\n        insertFragment,\n        getDeletedFragment,\n        deleteFragment,\n        getRelatedFragment,\n        getRectangle,\n        keyDown\n    } = board;\n\n    board.drawElement = (context: PlaitPluginElementContext) => {\n        if (PlaitGroupElement.isGroup(context.element)) {\n            return GroupComponent;\n        }\n        return drawElement(context);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        throttleRAF(board, 'with-group', () => {\n            groupRectangleG?.remove();\n            const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n            let selection: Selection = { anchor: point, focus: point };\n            if (board.selection && !Selection.isCollapsed(board.selection)) {\n                selection = board.selection;\n            }\n            const pointer = PlaitBoard.getPointer(board);\n            if (!isResizing(board) && !isMovingElements(board) && pointer === PlaitPointerType.selection) {\n                const hitElements = getHitElementsBySelection(board, selection);\n                if (hitElements.length) {\n                    groupRectangleG = createGroupRectangleG(board, hitElements);\n                    groupRectangleG && PlaitBoard.getElementTopHost(board).append(groupRectangleG);\n                }\n            }\n        });\n        pointerMove(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        groupRectangleG?.remove();\n        groupRectangleG = null;\n        globalPointerUp(event);\n    };\n\n    board.getRelatedFragment = (elements: PlaitElement[], originData?: PlaitElement[]) => {\n        const groups = getSelectedGroups(board, elements, originData);\n        return getRelatedFragment([...elements, ...groups], originData);\n    };\n\n    board.insertFragment = (clipboardData: ClipboardData | null, targetPoint: Point, operationType?: WritableClipboardOperationType) => {\n        let elements: PlaitElement[] = [];\n        if (clipboardData?.elements?.length) {\n            elements = new Array(clipboardData?.elements?.length);\n            const groups = getHighestSelectedGroups(board, clipboardData?.elements);\n            const selectedIsolatedElements = getSelectedIsolatedElements(board, clipboardData?.elements);\n            selectedIsolatedElements.forEach((item) => {\n                const index = clipboardData.elements!.map((element) => element.id).indexOf(item.id);\n                elements.splice(index, 1, !item.groupId ? item : updateGroupId(item, undefined));\n            });\n            if (groups.length) {\n                groups.forEach((item) => {\n                    const index = clipboardData.elements!.map((element) => element.id).indexOf(item.id);\n                    const newGroup = { ...updateGroupId(item, undefined), id: idCreator() };\n                    elements.splice(index, 1, newGroup);\n                    updateElementsGroupId(item, clipboardData.elements!, newGroup.id, elements);\n                });\n            }\n            clipboardData.elements = elements;\n        }\n        insertFragment(clipboardData, targetPoint, operationType);\n        const groupElements = elements?.filter((value) => PlaitGroupElement.isGroup(value)) as PlaitElement[];\n        groupElements.forEach((element) => {\n            Transforms.insertNode(board, element, [board.children.length]);\n        });\n    };\n\n    board.getDeletedFragment = (data: PlaitElement[]) => {\n        removeGroups = getRemoveGroups(board);\n        if (removeGroups && removeGroups.length) {\n            data.push(...removeGroups);\n        }\n        return getDeletedFragment(data);\n    };\n\n    board.deleteFragment = (elements: PlaitElement[]) => {\n        if (removeGroups?.length) {\n            updateSiblingElementGroupId(board, removeGroups);\n        }\n        deleteFragment(elements);\n        removeGroups = null;\n    };\n\n    board.getRectangle = (element: PlaitElement) => {\n        if (PlaitGroupElement.isGroup(element)) {\n            return getRectangleByGroup(board, element, true);\n        }\n        return getRectangle(element);\n    };\n\n    board.keyDown = (event: KeyboardEvent) => {\n        if (!PlaitBoard.isReadonly(board)) {\n            if (isKeyHotkey('mod+g', event)) {\n                event.preventDefault();\n                Transforms.addGroup(board);\n                return;\n            }\n            if (isKeyHotkey('mod+shift+g', event)) {\n                event.preventDefault();\n                Transforms.removeGroup(board);\n                return;\n            }\n        }\n        keyDown(event);\n    };\n\n    return board;\n}\n\nconst updateGroupId = (element: PlaitElement, groupId?: string) => {\n    return {\n        ...element,\n        groupId: groupId\n    };\n};\n\nconst updateElementsGroupId = (group: PlaitGroup, clipboardDataElements: PlaitElement[], newGroupId: string, elements: PlaitElement[]) => {\n    const elementsInGroup = clipboardDataElements.filter((item) => item.groupId === group.id);\n    if (elementsInGroup.length) {\n        elementsInGroup.forEach((item) => {\n            const index = clipboardDataElements.map((item) => item.id).indexOf(item.id);\n            if (PlaitGroupElement.isGroup(item)) {\n                const newGroup = { ...updateGroupId(item, newGroupId), id: idCreator() };\n                elements.splice(index, 1, newGroup);\n                updateElementsGroupId(item, clipboardDataElements, newGroup.id, elements);\n            } else {\n                elements.splice(index, 1, updateGroupId(item, newGroupId));\n            }\n        });\n    }\n    return elements;\n};\n\nconst getRemoveGroups = (board: PlaitBoard) => {\n    const selectedGroups = board.getRelatedFragment([]) as PlaitGroup[];\n    const removeGroups = [...selectedGroups];\n    const highestSelectedGroups = getHighestSelectedGroups(board);\n    const selectedIsolatedElements = getSelectedIsolatedElementsCanAddToGroup(board);\n    const removeNodes = [...highestSelectedGroups, ...selectedIsolatedElements];\n    removeNodes.forEach((item) => {\n        const hitElementGroups = getGroupByElement(board, item, true) as PlaitGroup[];\n        if (hitElementGroups.length) {\n            const elementsInGroup = getElementsInGroup(board, hitElementGroups[0], false, true);\n            const siblingElements = elementsInGroup.filter(\n                (element) => ![...removeNodes, ...removeGroups].map((item) => item.id).includes(element.id)\n            );\n            if (siblingElements.length === 1 || siblingElements.length === 0) {\n                if (!removeGroups.includes(hitElementGroups[0])) {\n                    removeGroups.push(hitElementGroups[0]);\n                }\n                if (siblingElements.length === 1) {\n                    if (hitElementGroups.length > 1) {\n                        const aboveGroup = findAboveGroupWithAnotherElement(board, hitElementGroups.slice(1, hitElementGroups.length), [\n                            ...removeNodes,\n                            ...removeGroups\n                        ]);\n                        let index = hitElementGroups.length;\n                        if (aboveGroup) {\n                            index = hitElementGroups.findIndex((item) => item.id === aboveGroup.id);\n                        }\n                        [...hitElementGroups.slice(1, index)].forEach((item) => {\n                            if (!removeGroups.includes(item)) {\n                                removeGroups.push(item);\n                            }\n                        });\n                    }\n                }\n            }\n        }\n    });\n    return removeGroups;\n};\n\nconst findAboveGroupWithAnotherElement = (board: PlaitBoard, groups: PlaitGroup[], excludeNodes: PlaitElement[]) => {\n    let group: PlaitGroup | null = null;\n    for (let i = 0; i < groups.length; i++) {\n        const elementsInGroup = getElementsInGroup(board, groups[i], false, true);\n        const siblingElements = elementsInGroup.filter((element) => !excludeNodes.map((item) => item.id).includes(element.id));\n        if (siblingElements.length > 0) {\n            group = groups[i];\n            break;\n        }\n    }\n    return group;\n};\n\nconst updateSiblingElementGroupId = (board: PlaitBoard, removeGroups: PlaitGroup[]) => {\n    const selectedIsolatedElements = getSelectedIsolatedElementsCanAddToGroup(board);\n    const highestSelectedGroups = getHighestSelectedGroups(board);\n    const isolatedElementsInGroup = selectedIsolatedElements.filter((item) => item.groupId);\n    [...highestSelectedGroups, ...isolatedElementsInGroup].forEach((item) => {\n        const hitElementGroups = getGroupByElement(board, item, true) as PlaitGroup[];\n        if (hitElementGroups.length) {\n            const elementsInGroup = getElementsInGroup(board, hitElementGroups[0], false, true);\n            const siblingElements = elementsInGroup.filter((element) => element.id !== item.id);\n            if (siblingElements.length === 1) {\n                const removeGroupIds = removeGroups.map((item) => item.id);\n                if (hitElementGroups.some((group) => removeGroupIds.includes(group.id))) {\n                    const group = hitElementGroups.find((group) => !removeGroupIds.includes(group.id));\n                    const path = PlaitBoard.findPath(board, siblingElements[0]);\n                    Transforms.setNode(board, { groupId: group?.id || undefined }, path);\n                }\n            }\n        }\n    });\n};\n"]}
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
import { MERGING, PRESS_AND_MOVE_BUFFER, PlaitBoard, PlaitPointerType, distanceBetweenPointAndPoint, isMainPointer, throttleRAF, toViewBoxPoint, toHostPoint, isDragging } from '@plait/core';
|
|
2
|
-
import { addResizing, isResizing, removeResizing } from '../utils/resize';
|
|
3
|
-
const generalCanResize = (board, event) => {
|
|
4
|
-
return (!PlaitBoard.isReadonly(board) && !PlaitBoard.hasBeenTextEditing(board) && PlaitBoard.isPointer(board, PlaitPointerType.selection));
|
|
5
|
-
};
|
|
6
|
-
export const withResize = (board, options) => {
|
|
7
|
-
const { pointerDown, pointerMove, globalPointerUp } = board;
|
|
8
|
-
let resizeHitTestRef = null;
|
|
9
|
-
let resizeRef = null;
|
|
10
|
-
let startPoint = null;
|
|
11
|
-
let hoverHitTestRef = null;
|
|
12
|
-
board.pointerDown = (event) => {
|
|
13
|
-
if (!options.canResize() || !generalCanResize(board, event) || !isMainPointer(event)) {
|
|
14
|
-
pointerDown(event);
|
|
15
|
-
return;
|
|
16
|
-
}
|
|
17
|
-
const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
18
|
-
resizeHitTestRef = options.hitTest(point);
|
|
19
|
-
if (resizeHitTestRef) {
|
|
20
|
-
if (resizeHitTestRef.cursorClass) {
|
|
21
|
-
PlaitBoard.getBoardContainer(board).classList.add(`${resizeHitTestRef.cursorClass}`);
|
|
22
|
-
}
|
|
23
|
-
startPoint = [event.x, event.y];
|
|
24
|
-
const path = Array.isArray(resizeHitTestRef.element)
|
|
25
|
-
? resizeHitTestRef.element.map(el => PlaitBoard.findPath(board, el))
|
|
26
|
-
: PlaitBoard.findPath(board, resizeHitTestRef.element);
|
|
27
|
-
resizeRef = {
|
|
28
|
-
path,
|
|
29
|
-
element: resizeHitTestRef.element,
|
|
30
|
-
handle: resizeHitTestRef.handle,
|
|
31
|
-
handleIndex: resizeHitTestRef.handleIndex,
|
|
32
|
-
rectangle: resizeHitTestRef.rectangle,
|
|
33
|
-
options: resizeHitTestRef.options
|
|
34
|
-
};
|
|
35
|
-
return;
|
|
36
|
-
}
|
|
37
|
-
pointerDown(event);
|
|
38
|
-
};
|
|
39
|
-
board.pointerMove = (event) => {
|
|
40
|
-
if (!options.canResize() || !generalCanResize(board, event)) {
|
|
41
|
-
clearHoverHitTestRef();
|
|
42
|
-
pointerMove(event);
|
|
43
|
-
return;
|
|
44
|
-
}
|
|
45
|
-
if (startPoint && resizeHitTestRef && !isResizing(board)) {
|
|
46
|
-
const endPoint = [event.x, event.y];
|
|
47
|
-
const distance = distanceBetweenPointAndPoint(startPoint[0], startPoint[1], endPoint[0], endPoint[1]);
|
|
48
|
-
if (distance > PRESS_AND_MOVE_BUFFER) {
|
|
49
|
-
addResizing(board, resizeRef, options.key);
|
|
50
|
-
MERGING.set(board, true);
|
|
51
|
-
options.beforeResize && options.beforeResize(resizeRef);
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
if (!isResizing(board) && !isDragging(board)) {
|
|
55
|
-
const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
56
|
-
throttleRAF(board, options.key + '-common-resize-hit-test', () => {
|
|
57
|
-
const hitTestRef = options.hitTest(point);
|
|
58
|
-
if (hitTestRef) {
|
|
59
|
-
if (hoverHitTestRef && hitTestRef.cursorClass !== hoverHitTestRef.cursorClass) {
|
|
60
|
-
PlaitBoard.getBoardContainer(board).classList.remove(`${hoverHitTestRef.cursorClass}`);
|
|
61
|
-
}
|
|
62
|
-
hoverHitTestRef = hitTestRef;
|
|
63
|
-
if (hoverHitTestRef.cursorClass) {
|
|
64
|
-
PlaitBoard.getBoardContainer(board).classList.add(`${hoverHitTestRef.cursorClass}`);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
68
|
-
clearHoverHitTestRef();
|
|
69
|
-
}
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
else {
|
|
73
|
-
if (startPoint && isResizing(board)) {
|
|
74
|
-
event.preventDefault();
|
|
75
|
-
const endPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
76
|
-
throttleRAF(board, 'with-common-resize', () => {
|
|
77
|
-
if (startPoint && resizeRef) {
|
|
78
|
-
options.onResize(resizeRef, {
|
|
79
|
-
startPoint: toViewBoxPoint(board, toHostPoint(board, startPoint[0], startPoint[1])),
|
|
80
|
-
endPoint,
|
|
81
|
-
isShift: !!event.shiftKey
|
|
82
|
-
});
|
|
83
|
-
}
|
|
84
|
-
});
|
|
85
|
-
return;
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
pointerMove(event);
|
|
89
|
-
};
|
|
90
|
-
board.globalPointerUp = (event) => {
|
|
91
|
-
globalPointerUp(event);
|
|
92
|
-
if (isResizing(board) || resizeHitTestRef) {
|
|
93
|
-
options.afterResize && options.afterResize(resizeRef);
|
|
94
|
-
removeResizing(board, options.key);
|
|
95
|
-
startPoint = null;
|
|
96
|
-
resizeHitTestRef = null;
|
|
97
|
-
resizeRef = null;
|
|
98
|
-
MERGING.set(board, false);
|
|
99
|
-
}
|
|
100
|
-
};
|
|
101
|
-
const clearHoverHitTestRef = () => {
|
|
102
|
-
if (hoverHitTestRef) {
|
|
103
|
-
if (hoverHitTestRef.cursorClass) {
|
|
104
|
-
PlaitBoard.getBoardContainer(board).classList.remove(`${hoverHitTestRef.cursorClass}`);
|
|
105
|
-
}
|
|
106
|
-
hoverHitTestRef = null;
|
|
107
|
-
}
|
|
108
|
-
};
|
|
109
|
-
return board;
|
|
110
|
-
};
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-resize.js","sourceRoot":"","sources":["../../../../packages/common/src/plugins/with-resize.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    MERGING,\n    PRESS_AND_MOVE_BUFFER,\n    PlaitBoard,\n    PlaitPointerType,\n    Point,\n    distanceBetweenPointAndPoint,\n    isMainPointer,\n    throttleRAF,\n    toViewBoxPoint,\n    toHostPoint,\n    isDragging\n} from '@plait/core';\nimport { ResizeHandle } from '../constants/resize';\nimport { addResizing, isResizing, removeResizing } from '../utils/resize';\nimport { PlaitElementOrArray, ResizeOptions, ResizeHitTestRef, ResizeRef, WithResizeOptions } from '../types/resize';\n\nconst generalCanResize = (board: PlaitBoard, event: PointerEvent) => {\n    return (\n        !PlaitBoard.isReadonly(board) && !PlaitBoard.hasBeenTextEditing(board) && PlaitBoard.isPointer(board, PlaitPointerType.selection)\n    );\n};\n\nexport const withResize = <T extends PlaitElementOrArray = PlaitElementOrArray, K = ResizeHandle, P = ResizeOptions>(\n    board: PlaitBoard,\n    options: WithResizeOptions<T, K, P>\n) => {\n    const { pointerDown, pointerMove, globalPointerUp } = board;\n    let resizeHitTestRef: ResizeHitTestRef<T, K, P> | null = null;\n    let resizeRef: ResizeRef<T, K, P> | null = null;\n    let startPoint: Point | null = null;\n    let hoverHitTestRef: ResizeHitTestRef<T, K, P> | null = null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        if (!options.canResize() || !generalCanResize(board, event) || !isMainPointer(event)) {\n            pointerDown(event);\n            return;\n        }\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        resizeHitTestRef = options.hitTest(point);\n        if (resizeHitTestRef) {\n            if (resizeHitTestRef.cursorClass) {\n                PlaitBoard.getBoardContainer(board).classList.add(`${resizeHitTestRef.cursorClass}`);\n            }\n            startPoint = [event.x, event.y];\n            const path = Array.isArray(resizeHitTestRef.element)\n                ? resizeHitTestRef.element.map(el => PlaitBoard.findPath(board, el))\n                : PlaitBoard.findPath(board, resizeHitTestRef.element);\n            resizeRef = {\n                path,\n                element: resizeHitTestRef.element,\n                handle: resizeHitTestRef.handle,\n                handleIndex: resizeHitTestRef.handleIndex,\n                rectangle: resizeHitTestRef.rectangle,\n                options: resizeHitTestRef.options\n            };\n            return;\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        if (!options.canResize() || !generalCanResize(board, event)) {\n            clearHoverHitTestRef();\n            pointerMove(event);\n            return;\n        }\n        if (startPoint && resizeHitTestRef && !isResizing(board)) {\n            const endPoint = [event.x, event.y];\n            const distance = distanceBetweenPointAndPoint(startPoint[0], startPoint[1], endPoint[0], endPoint[1]);\n            if (distance > PRESS_AND_MOVE_BUFFER) {\n                addResizing(board, resizeRef!, options.key);\n                MERGING.set(board, true);\n                options.beforeResize && options.beforeResize(resizeRef!);\n            }\n        }\n        if (!isResizing(board) && !isDragging(board)) {\n            const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n            throttleRAF(board, options.key + '-common-resize-hit-test', () => {\n                const hitTestRef = options.hitTest(point);\n                if (hitTestRef) {\n                    if (hoverHitTestRef && hitTestRef.cursorClass !== hoverHitTestRef.cursorClass) {\n                        PlaitBoard.getBoardContainer(board).classList.remove(`${hoverHitTestRef.cursorClass}`);\n                    }\n                    hoverHitTestRef = hitTestRef;\n                    if (hoverHitTestRef.cursorClass) {\n                        PlaitBoard.getBoardContainer(board).classList.add(`${hoverHitTestRef.cursorClass}`);\n                    }\n                } else {\n                    clearHoverHitTestRef();\n                }\n            });\n        } else {\n            if (startPoint && isResizing(board)) {\n                event.preventDefault();\n                const endPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n                throttleRAF(board, 'with-common-resize', () => {\n                    if (startPoint && resizeRef) {\n                        options.onResize(resizeRef, {\n                            startPoint: toViewBoxPoint(board, toHostPoint(board, startPoint[0], startPoint[1])),\n                            endPoint,\n                            isShift: !!event.shiftKey\n                        });\n                    }\n                });\n                return;\n            }\n        }\n        pointerMove(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        globalPointerUp(event);\n        if (isResizing(board) || resizeHitTestRef) {\n            options.afterResize && options.afterResize(resizeRef!);\n            removeResizing(board, options.key);\n            startPoint = null;\n            resizeHitTestRef = null;\n            resizeRef = null;\n            MERGING.set(board, false);\n        }\n    };\n\n    const clearHoverHitTestRef = () => {\n        if (hoverHitTestRef) {\n            if (hoverHitTestRef.cursorClass) {\n                PlaitBoard.getBoardContainer(board).classList.remove(`${hoverHitTestRef.cursorClass}`);\n            }\n            hoverHitTestRef = null;\n        }\n    };\n\n    return board;\n};\n"]}
|
package/esm2022/public-api.mjs
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Public API Surface of utils
|
|
3
|
-
*/
|
|
4
|
-
export * from './constants';
|
|
5
|
-
export * from './generators';
|
|
6
|
-
export * from './transforms';
|
|
7
|
-
export * from './shapes';
|
|
8
|
-
export * from './plugins';
|
|
9
|
-
export * from './utils';
|
|
10
|
-
export * from './image/image-base.component';
|
|
11
|
-
export * from './core';
|
|
12
|
-
export * from './algorithms';
|
|
13
|
-
export * from './text';
|
|
14
|
-
export * from './image';
|
|
15
|
-
export * from './types';
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL2NvbW1vbi9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHV0aWxzXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9jb25zdGFudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9nZW5lcmF0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vdHJhbnNmb3Jtcyc7XG5leHBvcnQgKiBmcm9tICcuL3NoYXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL3BsdWdpbnMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL2ltYWdlL2ltYWdlLWJhc2UuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29yZSc7XG5leHBvcnQgKiBmcm9tICcuL2FsZ29yaXRobXMnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0JztcbmV4cG9ydCAqIGZyb20gJy4vaW1hZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG4iXX0=
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
export const normalizeShapePoints = (points, shift = false) => {
|
|
2
|
-
let start = points[0];
|
|
3
|
-
let end = points[1];
|
|
4
|
-
if (shift) {
|
|
5
|
-
const width = Math.abs(start[0] - end[0]);
|
|
6
|
-
const height = Math.abs(start[1] - end[1]);
|
|
7
|
-
const edge = Math.max(height, width);
|
|
8
|
-
end = [start[0] + (end[0] > start[0] ? edge : -edge), start[1] + (end[1] > start[1] ? edge : -edge)];
|
|
9
|
-
}
|
|
10
|
-
const leftTopPoint = [Math.min(start[0], end[0]), Math.min(start[1], end[1])];
|
|
11
|
-
let rightBottomPoint = [Math.max(start[0], end[0]), Math.max(start[1], end[1])];
|
|
12
|
-
return [leftTopPoint, rightBottomPoint];
|
|
13
|
-
};
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tbW9uL3NyYy9zaGFwZXMvY29tbW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLENBQUMsTUFBc0IsRUFBRSxRQUFpQixLQUFLLEVBQWtCLEVBQUU7SUFDbkcsSUFBSSxLQUFLLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3RCLElBQUksR0FBRyxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNwQixJQUFJLEtBQUssRUFBRSxDQUFDO1FBQ1IsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDMUMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDM0MsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDckMsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQ3pHLENBQUM7SUFFRCxNQUFNLFlBQVksR0FBVSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDckYsSUFBSSxnQkFBZ0IsR0FBVSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFFdkYsT0FBTyxDQUFDLFlBQVksRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO0FBQzVDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBvaW50IH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuXG5leHBvcnQgY29uc3Qgbm9ybWFsaXplU2hhcGVQb2ludHMgPSAocG9pbnRzOiBbUG9pbnQsIFBvaW50XSwgc2hpZnQ6IGJvb2xlYW4gPSBmYWxzZSk6IFtQb2ludCwgUG9pbnRdID0+IHtcbiAgICBsZXQgc3RhcnQgPSBwb2ludHNbMF07XG4gICAgbGV0IGVuZCA9IHBvaW50c1sxXTtcbiAgICBpZiAoc2hpZnQpIHtcbiAgICAgICAgY29uc3Qgd2lkdGggPSBNYXRoLmFicyhzdGFydFswXSAtIGVuZFswXSk7XG4gICAgICAgIGNvbnN0IGhlaWdodCA9IE1hdGguYWJzKHN0YXJ0WzFdIC0gZW5kWzFdKTtcbiAgICAgICAgY29uc3QgZWRnZSA9IE1hdGgubWF4KGhlaWdodCwgd2lkdGgpO1xuICAgICAgICBlbmQgPSBbc3RhcnRbMF0gKyAoZW5kWzBdID4gc3RhcnRbMF0gPyBlZGdlIDogLWVkZ2UpLCBzdGFydFsxXSArIChlbmRbMV0gPiBzdGFydFsxXSA/IGVkZ2UgOiAtZWRnZSldO1xuICAgIH1cblxuICAgIGNvbnN0IGxlZnRUb3BQb2ludDogUG9pbnQgPSBbTWF0aC5taW4oc3RhcnRbMF0sIGVuZFswXSksIE1hdGgubWluKHN0YXJ0WzFdLCBlbmRbMV0pXTtcbiAgICBsZXQgcmlnaHRCb3R0b21Qb2ludDogUG9pbnQgPSBbTWF0aC5tYXgoc3RhcnRbMF0sIGVuZFswXSksIE1hdGgubWF4KHN0YXJ0WzFdLCBlbmRbMV0pXTtcblxuICAgIHJldHVybiBbbGVmdFRvcFBvaW50LCByaWdodEJvdHRvbVBvaW50XTtcbn07XG4iXX0=
|
package/esm2022/shapes/index.mjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export * from './common';
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21tb24vc3JjL3NoYXBlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFVBQVUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29tbW9uJztcbiJdfQ==
|
package/esm2022/text/index.mjs
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
export * from './text-manage';
|
|
2
|
-
export * from './with-text';
|
|
3
|
-
export * from './text-measure';
|
|
4
|
-
export * from './types';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21tb24vc3JjL3RleHQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vdGV4dC1tYW5hZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi93aXRoLXRleHQnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0LW1lYXN1cmUnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG4iXX0=
|