@plait/core 0.56.2 → 0.58.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.
@@ -5,7 +5,6 @@ import { PlaitHistory } from './history';
5
5
  import { PlaitOperation } from './operation';
6
6
  import { Selection } from './selection';
7
7
  import { Viewport } from './viewport';
8
- import { PlaitPluginElementComponent } from '../core/element/plugin-element';
9
8
  import { RoughSVG } from 'roughjs/bin/svg';
10
9
  import { BoardComponentInterface } from '../board/board.component.interface';
11
10
  import { Point } from './point';
@@ -15,6 +14,7 @@ import { PlaitNode } from './node';
15
14
  import { Path } from './path';
16
15
  import { PlaitTheme, ThemeColor } from './theme';
17
16
  import { ClipboardData, WritableClipboardContext, WritableClipboardOperationType } from '../utils';
17
+ import { ElementFlavour } from '../core/element/element-flavour';
18
18
  export interface PlaitBoard {
19
19
  viewport: Viewport;
20
20
  children: PlaitElement[];
@@ -45,7 +45,7 @@ export interface PlaitBoard {
45
45
  getDeletedFragment: (data: PlaitElement[]) => PlaitElement[];
46
46
  getRelatedFragment: (data: PlaitElement[], originData?: PlaitElement[]) => PlaitElement[];
47
47
  dblClick: (event: MouseEvent) => void;
48
- drawElement: (context: PlaitPluginElementContext) => ComponentType<PlaitPluginElementComponent>;
48
+ drawElement: (context: PlaitPluginElementContext) => ComponentType<ElementFlavour>;
49
49
  isRectangleHit: (element: PlaitElement, range: Selection) => boolean;
50
50
  isHit: (element: PlaitElement, point: Point) => boolean;
51
51
  isInsidePoint: (element: PlaitElement, point: Point) => boolean;
@@ -92,11 +92,13 @@ export declare const PlaitBoard: {
92
92
  isAlive(board: PlaitBoard): boolean;
93
93
  findPath(board: PlaitBoard, node: PlaitNode): Path;
94
94
  getHost(board: PlaitBoard): SVGSVGElement;
95
+ getElementLowerHost(board: PlaitBoard): SVGSVGElement;
95
96
  getElementHost(board: PlaitBoard): SVGSVGElement;
96
97
  getElementUpperHost(board: PlaitBoard): SVGSVGElement;
97
98
  getElementActiveHost(board: PlaitBoard): SVGSVGElement;
98
99
  getRoughSVG(board: PlaitBoard): RoughSVG;
99
100
  getComponent(board: PlaitBoard): BoardComponentInterface;
101
+ getViewContainerRef(board: PlaitBoard): import("@angular/core").ViewContainerRef;
100
102
  getBoardContainer(board: PlaitBoard): HTMLElement;
101
103
  getRectangle(board: PlaitBoard): RectangleClient;
102
104
  getViewportContainer(board: PlaitBoard): HTMLElement;
@@ -1,5 +1,3 @@
1
- import { PlaitPluginElementComponent } from '../core/element/plugin-element';
2
- import { PlaitBoard } from './board';
3
1
  import { Point } from './point';
4
2
  import { PlaitElementRef } from '../core/element/element-ref';
5
3
  export interface PlaitElement {
@@ -9,10 +7,10 @@ export interface PlaitElement {
9
7
  points?: Point[];
10
8
  type?: string;
11
9
  groupId?: string;
10
+ angle?: number;
12
11
  }
13
12
  export declare const PlaitElement: {
14
13
  isRootElement(value: PlaitElement): boolean;
15
- getComponent(value: PlaitElement): PlaitPluginElementComponent<PlaitElement, PlaitBoard, PlaitElementRef>;
16
14
  getElementRef<T extends PlaitElementRef = PlaitElementRef>(value: PlaitElement): T;
17
15
  getElementG(value: PlaitElement): SVGGElement;
18
16
  hasMounted(element: PlaitElement): boolean;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@plait/core",
3
- "version": "0.56.2",
3
+ "version": "0.58.0",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^17.2.4",
6
6
  "@angular/core": "^17.2.4",
package/public-api.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  export * from './board/board.component';
2
2
  export * from './constants';
3
- export * from './core/element/plugin-element';
4
3
  export * from './core/element/context-change';
4
+ export * from './core/element/element-flavour';
5
5
  export * from './core/island/island-base.component';
6
6
  export * from './core/element/element-ref';
7
7
  export * from './interfaces';
package/utils/angle.d.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  import { PlaitBoard, PlaitElement, Point, RectangleClient } from '../interfaces';
2
- export declare const rotatePoints: <T>(points: T, centerPoint: Point, angle: number) => T;
3
- export declare const getSelectionAngle: (elements: PlaitElement[]) => any;
2
+ export declare const rotatePoints: <T>(points: T, centerPoint: Point, angle?: number) => T;
3
+ export declare const getSelectionAngle: (elements: PlaitElement[]) => number;
4
4
  export declare const hasSameAngle: (elements: PlaitElement[]) => boolean;
5
5
  export declare const getRotatedBoundingRectangle: (rectanglesCornerPoints: [Point, Point, Point, Point][], angle: number) => RectangleClient;
6
6
  export declare const getOffsetAfterRotate: (rectangle: RectangleClient, rotateCenterPoint: Point, angle: number) => {
@@ -8,15 +8,15 @@ export declare const getOffsetAfterRotate: (rectangle: RectangleClient, rotateCe
8
8
  offsetY: number;
9
9
  };
10
10
  export declare const rotatedDataPoints: (points: Point[], rotateCenterPoint: Point, angle: number) => Point[];
11
- export declare const hasValidAngle: (node: PlaitElement) => any;
11
+ export declare const hasValidAngle: (node: PlaitElement) => boolean | 0 | undefined;
12
12
  export declare const rotatePointsByElement: <T>(points: T, element: PlaitElement) => T | null;
13
13
  export declare const rotateAntiPointsByElement: <T>(points: T, element: PlaitElement) => T | null;
14
- export declare const getRectangleByAngle: (rectangle: RectangleClient, angle: number) => RectangleClient | null;
14
+ export declare const getRectangleByAngle: (rectangle: RectangleClient, angle: number) => RectangleClient;
15
15
  export declare const isAxisChangedByAngle: (angle: number) => boolean;
16
16
  export declare function degreesToRadians(d: number): number;
17
17
  export declare function radiansToDegrees(r: number): number;
18
18
  export declare function rotateElements(board: PlaitBoard, elements: PlaitElement[], angle: number): void;
19
19
  export declare const normalizeAngle: (angle: number) => number;
20
20
  export declare const getAngleBetweenPoints: (startPoint: Point, endPoint: Point, centerPoint: Point) => number;
21
- export declare const getAngleByElement: (element: PlaitElement) => number;
21
+ export declare const getAngleByElement: (element: PlaitElement) => number | undefined;
22
22
  export declare const setAngleForG: (g: SVGGElement, centerPoint: Point, angle: number) => void;
@@ -1,5 +1,6 @@
1
1
  import { PlaitBoard, PlaitElement, RectangleClient } from '../interfaces';
2
2
  export declare function getRectangleByElements(board: PlaitBoard, elements: PlaitElement[], recursion: boolean): RectangleClient;
3
+ export declare function getBoundingRectangleByElements(board: PlaitBoard, elements: PlaitElement[], recursion: boolean): RectangleClient;
3
4
  export declare function getBoardRectangle(board: PlaitBoard): RectangleClient;
4
5
  export declare function getElementById<T extends PlaitElement = PlaitElement>(board: PlaitBoard, id: string, dataSource?: PlaitElement[]): T | undefined;
5
6
  export declare function findElements<T extends PlaitElement = PlaitElement>(board: PlaitBoard, options: {
@@ -13,3 +13,5 @@ export declare const removeSelectedElement: (board: PlaitBoard, element: PlaitEl
13
13
  export declare const clearSelectedElement: (board: PlaitBoard) => void;
14
14
  export declare const isSelectedElement: (board: PlaitBoard, element: PlaitElement) => boolean;
15
15
  export declare const temporaryDisableSelection: (board: PlaitOptionsBoard) => void;
16
+ export declare const isHitSelectedRectangle: (board: PlaitBoard, point: Point) => boolean;
17
+ export declare const isHitElement: (board: PlaitBoard, point: Point) => boolean;
@@ -20,6 +20,7 @@ export declare const BOARD_TO_ROUGH_SVG: WeakMap<PlaitBoard, RoughSVG>;
20
20
  export declare const BOARD_TO_HOST: WeakMap<PlaitBoard, SVGSVGElement>;
21
21
  export declare const IS_BOARD_ALIVE: WeakMap<PlaitBoard, boolean>;
22
22
  export declare const BOARD_TO_ELEMENT_HOST: WeakMap<PlaitBoard, {
23
+ lowerHost: SVGGElement;
23
24
  host: SVGGElement;
24
25
  upperHost: SVGGElement;
25
26
  activeHost: SVGGElement;
@@ -1,34 +0,0 @@
1
- import { ChangeDetectorRef, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';
2
- import { PlaitBoard, PlaitElement, PlaitPluginElementContext } from '../../interfaces';
3
- import { ListRender } from '../list-render';
4
- import { PlaitElementRef } from './element-ref';
5
- import * as i0 from "@angular/core";
6
- export declare abstract class PlaitPluginElementComponent<T extends PlaitElement = PlaitElement, K extends PlaitBoard = PlaitBoard, R extends PlaitElementRef = PlaitElementRef> implements OnInit, OnDestroy {
7
- private ref;
8
- viewContainerRef: ViewContainerRef;
9
- cdr: ChangeDetectorRef;
10
- private _g;
11
- private _containerG;
12
- private _rootContainerG?;
13
- initialized: boolean;
14
- protected _context: PlaitPluginElementContext<T, K>;
15
- get hasChildren(): boolean;
16
- set context(value: PlaitPluginElementContext<T, K>);
17
- get context(): PlaitPluginElementContext<T, K>;
18
- get element(): T;
19
- get board(): K;
20
- get selected(): boolean;
21
- listRender?: ListRender;
22
- getContainerG(): SVGGElement;
23
- getElementG(): SVGGElement;
24
- constructor(ref: R);
25
- ngOnInit(): void;
26
- initializeListRender(): void;
27
- getRef(): R;
28
- private updateListRender;
29
- private initializeChildrenContext;
30
- ngOnDestroy(): void;
31
- static ɵfac: i0.ɵɵFactoryDeclaration<PlaitPluginElementComponent<any, any, any>, never>;
32
- static ɵdir: i0.ɵɵDirectiveDeclaration<PlaitPluginElementComponent<any, any, any>, never, never, { "context": { "alias": "context"; "required": false; }; }, {}, never, never, false, never>;
33
- }
34
- export declare const ELEMENT_TO_COMPONENT: WeakMap<PlaitElement, PlaitPluginElementComponent<PlaitElement, PlaitBoard, PlaitElementRef>>;
@@ -1,151 +0,0 @@
1
- import { ChangeDetectorRef, Directive, Input, ViewContainerRef, inject } from '@angular/core';
2
- import { PlaitBoard, PlaitElement, PlaitNode } from '../../interfaces';
3
- import { removeSelectedElement } from '../../utils/selected-element';
4
- import { createG } from '../../utils/dom/common';
5
- import { hasBeforeContextChange, hasOnContextChanged } from './context-change';
6
- import { ListRender } from '../list-render';
7
- import { ELEMENT_TO_REF, NODE_TO_CONTAINER_G, NODE_TO_G } from '../../utils/weak-maps';
8
- import * as i0 from "@angular/core";
9
- export class PlaitPluginElementComponent {
10
- get hasChildren() {
11
- return !!this.element.children;
12
- }
13
- set context(value) {
14
- if (hasBeforeContextChange(this)) {
15
- this.beforeContextChange(value);
16
- }
17
- const previousContext = this._context;
18
- this._context = value;
19
- if (this.element) {
20
- ELEMENT_TO_COMPONENT.set(this.element, this);
21
- }
22
- if (this.initialized) {
23
- const elementG = this.getElementG();
24
- const containerG = this.getContainerG();
25
- NODE_TO_G.set(this.element, elementG);
26
- NODE_TO_CONTAINER_G.set(this.element, containerG);
27
- ELEMENT_TO_REF.set(this.element, this.ref);
28
- this.updateListRender();
29
- this.cdr.markForCheck();
30
- if (hasOnContextChanged(this)) {
31
- this.onContextChanged(value, previousContext);
32
- }
33
- }
34
- else {
35
- if (PlaitElement.isRootElement(this.element) && this.hasChildren) {
36
- this._g = createG();
37
- this._containerG = createG();
38
- this._containerG.append(this._g);
39
- }
40
- else {
41
- this._g = createG();
42
- this._containerG = this._g;
43
- }
44
- NODE_TO_G.set(this.element, this._g);
45
- NODE_TO_CONTAINER_G.set(this.element, this._containerG);
46
- ELEMENT_TO_REF.set(this.element, this.ref);
47
- }
48
- }
49
- get context() {
50
- return this._context;
51
- }
52
- get element() {
53
- return this.context && this.context.element;
54
- }
55
- get board() {
56
- return this.context && this.context.board;
57
- }
58
- get selected() {
59
- return this.context && this.context.selected;
60
- }
61
- getContainerG() {
62
- return this._containerG;
63
- }
64
- getElementG() {
65
- return this._g;
66
- }
67
- constructor(ref) {
68
- this.ref = ref;
69
- this.viewContainerRef = inject(ViewContainerRef);
70
- this.cdr = inject(ChangeDetectorRef);
71
- this.initialized = false;
72
- }
73
- ngOnInit() {
74
- if (this.element.type) {
75
- this.getContainerG().setAttribute(`plait-${this.element.type}`, 'true');
76
- }
77
- if (this.hasChildren) {
78
- if (PlaitElement.isRootElement(this.element)) {
79
- this._rootContainerG = this._containerG;
80
- }
81
- else {
82
- const path = PlaitBoard.findPath(this.board, this.element);
83
- const rootNode = PlaitNode.get(this.board, path.slice(0, 1));
84
- this._rootContainerG = PlaitElement.getContainerG(rootNode, { suppressThrow: false });
85
- }
86
- }
87
- this.getContainerG().setAttribute('plait-data-id', this.element.id);
88
- this.initialized = true;
89
- }
90
- initializeListRender() {
91
- if (this.hasChildren) {
92
- this.listRender = new ListRender(this.board, this.viewContainerRef);
93
- if (this.board.isExpanded(this.element)) {
94
- this.listRender.initialize(this.element.children, this.initializeChildrenContext());
95
- }
96
- }
97
- }
98
- getRef() {
99
- return this.ref;
100
- }
101
- updateListRender() {
102
- if (this.hasChildren) {
103
- if (!this.listRender) {
104
- throw new Error('incorrectly initialize list render');
105
- }
106
- if (this.board.isExpanded(this.element)) {
107
- this.listRender.update(this.element.children, this.initializeChildrenContext());
108
- }
109
- else {
110
- if (this.listRender.initialized) {
111
- this.listRender.destroy();
112
- }
113
- }
114
- }
115
- }
116
- initializeChildrenContext() {
117
- if (!this._rootContainerG) {
118
- throw new Error('can not resolve root container g');
119
- }
120
- return {
121
- board: this.board,
122
- parent: this.element,
123
- parentG: this._rootContainerG
124
- };
125
- }
126
- ngOnDestroy() {
127
- if (ELEMENT_TO_COMPONENT.get(this.element) === this) {
128
- ELEMENT_TO_COMPONENT.delete(this.element);
129
- }
130
- if (NODE_TO_G.get(this.element) === this._g) {
131
- NODE_TO_G.delete(this.element);
132
- }
133
- if (NODE_TO_CONTAINER_G.get(this.element) === this._containerG) {
134
- NODE_TO_CONTAINER_G.delete(this.element);
135
- }
136
- if (ELEMENT_TO_REF.get(this.element) === this.ref) {
137
- ELEMENT_TO_REF.set(this.element, this.ref);
138
- }
139
- removeSelectedElement(this.board, this.element);
140
- this.getContainerG().remove();
141
- }
142
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: PlaitPluginElementComponent, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive }); }
143
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.4", type: PlaitPluginElementComponent, inputs: { context: "context" }, ngImport: i0 }); }
144
- }
145
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: PlaitPluginElementComponent, decorators: [{
146
- type: Directive
147
- }], ctorParameters: () => [{ type: undefined }], propDecorators: { context: [{
148
- type: Input
149
- }] } });
150
- export const ELEMENT_TO_COMPONENT = new WeakMap();
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-element.js","sourceRoot":"","sources":["../../../../../packages/core/src/core/element/plugin-element.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Directive, Input, OnDestroy, OnInit, ViewContainerRef, inject } from '@angular/core';\nimport { PlaitBoard, PlaitChildrenContext, PlaitElement, PlaitNode, PlaitPluginElementContext } from '../../interfaces';\nimport { removeSelectedElement } from '../../utils/selected-element';\nimport { createG } from '../../utils/dom/common';\nimport { hasBeforeContextChange, hasOnContextChanged } from './context-change';\nimport { ListRender } from '../list-render';\nimport { ELEMENT_TO_REF, NODE_TO_CONTAINER_G, NODE_TO_G } from '../../utils/weak-maps';\nimport { PlaitElementRef } from './element-ref';\n\n@Directive()\nexport abstract class PlaitPluginElementComponent<\n    T extends PlaitElement = PlaitElement,\n    K extends PlaitBoard = PlaitBoard,\n    R extends PlaitElementRef = PlaitElementRef\n> implements OnInit, OnDestroy {\n    viewContainerRef = inject(ViewContainerRef);\n    cdr = inject(ChangeDetectorRef);\n\n    private _g!: SVGGElement;\n\n    private _containerG!: SVGGElement;\n\n    // children elements's render need rootContainerG\n    // the value of rootContainerG come from the containerG of root element\n    private _rootContainerG?: SVGGElement;\n\n    initialized = false;\n\n    protected _context!: PlaitPluginElementContext<T, K>;\n\n    get hasChildren() {\n        return !!this.element.children;\n    }\n\n    @Input()\n    set context(value: PlaitPluginElementContext<T, K>) {\n        if (hasBeforeContextChange<T, K>(this)) {\n            this.beforeContextChange(value);\n        }\n        const previousContext = this._context;\n        this._context = value;\n        if (this.element) {\n            ELEMENT_TO_COMPONENT.set(this.element, this);\n        }\n        if (this.initialized) {\n            const elementG = this.getElementG();\n            const containerG = this.getContainerG();\n            NODE_TO_G.set(this.element, elementG);\n            NODE_TO_CONTAINER_G.set(this.element, containerG);\n            ELEMENT_TO_REF.set(this.element, this.ref);\n            this.updateListRender();\n            this.cdr.markForCheck();\n            if (hasOnContextChanged<T>(this)) {\n                this.onContextChanged(value, previousContext);\n            }\n        } else {\n            if (PlaitElement.isRootElement(this.element) && this.hasChildren) {\n                this._g = createG();\n                this._containerG = createG();\n                this._containerG.append(this._g);\n            } else {\n                this._g = createG();\n                this._containerG = this._g;\n            }\n            NODE_TO_G.set(this.element, this._g);\n            NODE_TO_CONTAINER_G.set(this.element, this._containerG);\n            ELEMENT_TO_REF.set(this.element, this.ref);\n        }\n    }\n\n    get context() {\n        return this._context;\n    }\n\n    get element() {\n        return this.context && this.context.element;\n    }\n\n    get board() {\n        return this.context && this.context.board;\n    }\n\n    get selected() {\n        return this.context && this.context.selected;\n    }\n\n    listRender?: ListRender;\n\n    getContainerG() {\n        return this._containerG;\n    }\n\n    getElementG() {\n        return this._g;\n    }\n\n    constructor(private ref: R) {}\n\n    ngOnInit(): void {\n        if (this.element.type) {\n            this.getContainerG().setAttribute(`plait-${this.element.type}`, 'true');\n        }\n        if (this.hasChildren) {\n            if (PlaitElement.isRootElement(this.element)) {\n                this._rootContainerG = this._containerG;\n            } else {\n                const path = PlaitBoard.findPath(this.board, this.element);\n                const rootNode = PlaitNode.get(this.board, path.slice(0, 1));\n                this._rootContainerG = PlaitElement.getContainerG(rootNode, { suppressThrow: false });\n            }\n        }\n        this.getContainerG().setAttribute('plait-data-id', this.element.id);\n        this.initialized = true;\n    }\n\n    public initializeListRender() {\n        if (this.hasChildren) {\n            this.listRender = new ListRender(this.board, this.viewContainerRef);\n            if (this.board.isExpanded(this.element)) {\n                this.listRender.initialize(this.element.children!, this.initializeChildrenContext());\n            }\n        }\n    }\n\n    public getRef() {\n        return this.ref;\n    }\n\n    private updateListRender() {\n        if (this.hasChildren) {\n            if (!this.listRender) {\n                throw new Error('incorrectly initialize list render');\n            }\n            if (this.board.isExpanded(this.element)) {\n                this.listRender.update(this.element.children!, this.initializeChildrenContext());\n            } else {\n                if (this.listRender.initialized) {\n                    this.listRender.destroy();\n                }\n            }\n        }\n    }\n\n    private initializeChildrenContext(): PlaitChildrenContext {\n        if (!this._rootContainerG) {\n            throw new Error('can not resolve root container g');\n        }\n        return {\n            board: this.board,\n            parent: this.element,\n            parentG: this._rootContainerG\n        };\n    }\n\n    ngOnDestroy(): void {\n        if (ELEMENT_TO_COMPONENT.get(this.element) === this) {\n            ELEMENT_TO_COMPONENT.delete(this.element);\n        }\n        if (NODE_TO_G.get(this.element) === this._g) {\n            NODE_TO_G.delete(this.element);\n        }\n        if (NODE_TO_CONTAINER_G.get(this.element) === this._containerG) {\n            NODE_TO_CONTAINER_G.delete(this.element);\n        }\n        if (ELEMENT_TO_REF.get(this.element) === this.ref) {\n            ELEMENT_TO_REF.set(this.element, this.ref);\n        }\n        removeSelectedElement(this.board, this.element);\n        this.getContainerG().remove();\n    }\n}\n\nexport const ELEMENT_TO_COMPONENT = new WeakMap<PlaitElement, PlaitPluginElementComponent>();\n"]}