@plait/core 0.3.0 → 0.5.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/board/board.component.d.ts +9 -8
- package/constants/index.d.ts +6 -0
- package/core/island/island-base.component.d.ts +16 -0
- package/esm2020/board/board.component.interface.mjs +1 -1
- package/esm2020/board/board.component.mjs +57 -56
- package/esm2020/constants/index.mjs +7 -1
- package/esm2020/core/children/children.component.mjs +3 -3
- package/esm2020/core/element/element.component.mjs +3 -3
- package/esm2020/core/element/plugin-element.mjs +3 -3
- package/esm2020/core/island/island-base.component.mjs +33 -0
- package/esm2020/interfaces/board.mjs +1 -1
- package/esm2020/interfaces/index.mjs +2 -1
- package/esm2020/interfaces/plugin-key.mjs +5 -0
- package/esm2020/plait.module.mjs +6 -7
- package/esm2020/plugins/create-board.mjs +3 -2
- package/esm2020/plugins/with-hand.mjs +7 -6
- package/esm2020/plugins/with-options.mjs +13 -0
- package/esm2020/plugins/with-selection.mjs +18 -7
- package/esm2020/public-api.mjs +3 -2
- package/esm2020/testing/core/create-board.mjs +2 -2
- package/esm2020/transforms/board.mjs +63 -4
- package/esm2020/utils/dom/common.mjs +12 -1
- package/esm2020/utils/draw/line.mjs +21 -1
- package/esm2020/utils/viewport.mjs +2 -55
- package/fesm2015/plait-core.mjs +548 -504
- package/fesm2015/plait-core.mjs.map +1 -1
- package/fesm2020/plait-core.mjs +562 -519
- package/fesm2020/plait-core.mjs.map +1 -1
- package/interfaces/board.d.ts +1 -0
- package/interfaces/index.d.ts +1 -0
- package/interfaces/plugin-key.d.ts +3 -0
- package/package.json +1 -1
- package/plait.module.d.ts +2 -3
- package/plugins/with-options.d.ts +9 -0
- package/plugins/with-selection.d.ts +5 -0
- package/public-api.d.ts +2 -1
- package/styles/styles.scss +7 -81
- package/transforms/board.d.ts +8 -1
- package/utils/dom/common.d.ts +3 -0
- package/utils/draw/line.d.ts +1 -0
- package/utils/viewport.d.ts +0 -3
- package/core/toolbar/toolbar.component.d.ts +0 -21
- package/esm2020/core/toolbar/toolbar.component.mjs +0 -60
- package/styles/theme.scss +0 -15
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, NgZone, OnChanges, OnDestroy, OnInit,
|
|
1
|
+
import { AfterContentInit, AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, NgZone, OnChanges, OnDestroy, OnInit, QueryList, SimpleChanges, ViewContainerRef } from '@angular/core';
|
|
2
2
|
import { RoughSVG } from 'roughjs/bin/svg';
|
|
3
3
|
import { Subject } from 'rxjs';
|
|
4
4
|
import { PlaitBoard, PlaitBoardChangeEvent, PlaitBoardOptions } from '../interfaces/board';
|
|
@@ -6,8 +6,9 @@ import { PlaitElement } from '../interfaces/element';
|
|
|
6
6
|
import { PlaitPlugin } from '../interfaces/plugin';
|
|
7
7
|
import { Viewport } from '../interfaces/viewport';
|
|
8
8
|
import { BoardComponentInterface } from './board.component.interface';
|
|
9
|
+
import { PlaitIslandBaseComponent } from '../core/island/island-base.component';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
|
-
export declare class PlaitBoardComponent implements BoardComponentInterface, OnInit, OnChanges, AfterViewInit, OnDestroy {
|
|
11
|
+
export declare class PlaitBoardComponent implements BoardComponentInterface, OnInit, OnChanges, AfterViewInit, AfterContentInit, OnDestroy {
|
|
11
12
|
cdr: ChangeDetectorRef;
|
|
12
13
|
viewContainerRef: ViewContainerRef;
|
|
13
14
|
private elementRef;
|
|
@@ -28,12 +29,14 @@ export declare class PlaitBoardComponent implements BoardComponentInterface, OnI
|
|
|
28
29
|
get hostClass(): string;
|
|
29
30
|
get readonly(): boolean;
|
|
30
31
|
get isFocused(): boolean;
|
|
32
|
+
get disabledScrollOnNonFocus(): boolean;
|
|
31
33
|
get nativeElement(): HTMLElement;
|
|
32
34
|
svg: ElementRef;
|
|
33
|
-
toolbarTemplateRef: TemplateRef<any>;
|
|
34
35
|
viewportContainer: ElementRef;
|
|
36
|
+
islands?: QueryList<PlaitIslandBaseComponent>;
|
|
35
37
|
constructor(cdr: ChangeDetectorRef, viewContainerRef: ViewContainerRef, elementRef: ElementRef<HTMLElement>, ngZone: NgZone);
|
|
36
38
|
ngOnInit(): void;
|
|
39
|
+
ngAfterContentInit(): void;
|
|
37
40
|
detect(): void;
|
|
38
41
|
ngOnChanges(changes: SimpleChanges): void;
|
|
39
42
|
ngAfterViewInit(): void;
|
|
@@ -42,13 +45,11 @@ export declare class PlaitBoardComponent implements BoardComponentInterface, OnI
|
|
|
42
45
|
private viewportScrollListener;
|
|
43
46
|
private elementResizeListener;
|
|
44
47
|
private mouseLeaveListener;
|
|
48
|
+
private initializeIslands;
|
|
49
|
+
private updateIslands;
|
|
45
50
|
trackBy: (index: number, element: PlaitElement) => string;
|
|
46
|
-
adaptHandle(): void;
|
|
47
|
-
zoomInHandle(isCenter?: boolean): void;
|
|
48
|
-
zoomOutHandle(): void;
|
|
49
|
-
resetZoomHandel(): void;
|
|
50
51
|
ngOnDestroy(): void;
|
|
51
52
|
markForCheck(): void;
|
|
52
53
|
static ɵfac: i0.ɵɵFactoryDeclaration<PlaitBoardComponent, never>;
|
|
53
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<PlaitBoardComponent, "plait-board", never, { "plaitValue": "plaitValue"; "plaitViewport": "plaitViewport"; "plaitPlugins": "plaitPlugins"; "plaitOptions": "plaitOptions"; }, { "plaitChange": "plaitChange"; "plaitBoardInitialized": "plaitBoardInitialized"; }, ["
|
|
54
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<PlaitBoardComponent, "plait-board", never, { "plaitValue": "plaitValue"; "plaitViewport": "plaitViewport"; "plaitPlugins": "plaitPlugins"; "plaitOptions": "plaitOptions"; }, { "plaitChange": "plaitChange"; "plaitBoardInitialized": "plaitBoardInitialized"; }, ["islands"], ["*"], false, never>;
|
|
54
55
|
}
|
package/constants/index.d.ts
CHANGED
|
@@ -1,3 +1,9 @@
|
|
|
1
1
|
export declare const CLIP_BOARD_FORMAT_KEY = "x-plait-fragment";
|
|
2
2
|
export declare const SCROLL_BAR_WIDTH = 20;
|
|
3
3
|
export declare const MAX_RADIUS = 16;
|
|
4
|
+
export declare const POINTER_BUTTON: {
|
|
5
|
+
readonly MAIN: 0;
|
|
6
|
+
readonly WHEEL: 1;
|
|
7
|
+
readonly SECONDARY: 2;
|
|
8
|
+
readonly TOUCH: -1;
|
|
9
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ChangeDetectorRef } from '@angular/core';
|
|
2
|
+
import { PlaitBoard } from '../../interfaces';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare abstract class PlaitIslandBaseComponent {
|
|
5
|
+
protected cdr: ChangeDetectorRef;
|
|
6
|
+
board: PlaitBoard;
|
|
7
|
+
constructor(cdr: ChangeDetectorRef);
|
|
8
|
+
initialize(board: PlaitBoard): void;
|
|
9
|
+
markForCheck(): void;
|
|
10
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<PlaitIslandBaseComponent, never>;
|
|
11
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<PlaitIslandBaseComponent, never, never, {}, {}, never, never, false, never>;
|
|
12
|
+
}
|
|
13
|
+
export interface OnBoardChange {
|
|
14
|
+
onBoardChange: () => void;
|
|
15
|
+
}
|
|
16
|
+
export declare const hasOnBoardChange: (value: any) => value is OnBoardChange;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9hcmQuY29tcG9uZW50LmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy9ib2FyZC9ib2FyZC5jb21wb25lbnQuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3RvclJlZiwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJvYXJkQ29tcG9uZW50SW50ZXJmYWNlIHtcbiAgICBtYXJrRm9yQ2hlY2s6ICgpID0+
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9hcmQuY29tcG9uZW50LmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy9ib2FyZC9ib2FyZC5jb21wb25lbnQuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3RvclJlZiwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJvYXJkQ29tcG9uZW50SW50ZXJmYWNlIHtcbiAgICBtYXJrRm9yQ2hlY2s6ICgpID0+IHZvaWQ7XG4gICAgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZjtcbiAgICBuYXRpdmVFbGVtZW50OiBIVE1MRWxlbWVudDtcbiAgICB2aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmO1xufVxuIl19
|
|
@@ -1,25 +1,26 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild } from '@angular/core';
|
|
2
2
|
import rough from 'roughjs/bin/rough';
|
|
3
3
|
import { fromEvent, Subject } from 'rxjs';
|
|
4
|
-
import { filter, takeUntil } from 'rxjs/operators';
|
|
4
|
+
import { filter, takeUntil, tap } from 'rxjs/operators';
|
|
5
5
|
import { PlaitBoard } from '../interfaces/board';
|
|
6
6
|
import { createBoard } from '../plugins/create-board';
|
|
7
7
|
import { withBoard } from '../plugins/with-board';
|
|
8
8
|
import { withHistory } from '../plugins/with-history';
|
|
9
9
|
import { withHandPointer } from '../plugins/with-hand';
|
|
10
10
|
import { withSelection } from '../plugins/with-selection';
|
|
11
|
-
import { toPoint, transformPoint
|
|
11
|
+
import { toPoint, transformPoint } from '../utils';
|
|
12
12
|
import { BOARD_TO_ON_CHANGE, BOARD_TO_COMPONENT, BOARD_TO_ELEMENT_HOST, BOARD_TO_HOST, BOARD_TO_ROUGH_SVG, BOARD_TO_MOVING_POINT } from '../utils/weak-maps';
|
|
13
|
-
import {
|
|
13
|
+
import { getViewBox, initializeViewportOffset, initializeViewBox, isFromViewportChange, setIsFromViewportChange, initializeViewportContainer, updateViewportOffset, setIsFromScrolling } from '../utils/viewport';
|
|
14
14
|
import { isHotkey } from 'is-hotkey';
|
|
15
15
|
import { withViewport } from '../plugins/with-viewport';
|
|
16
16
|
import { Point } from '../interfaces/point';
|
|
17
17
|
import { withMoving } from '../plugins/with-moving';
|
|
18
18
|
import { hasInputOrTextareaTarget } from '../utils/dom/common';
|
|
19
|
+
import { withOptions } from '../plugins/with-options';
|
|
20
|
+
import { PlaitIslandBaseComponent, hasOnBoardChange } from '../core/island/island-base.component';
|
|
21
|
+
import { BoardTransforms } from '../transforms/board';
|
|
19
22
|
import * as i0 from "@angular/core";
|
|
20
|
-
import * as i1 from "
|
|
21
|
-
import * as i2 from "../core/children/children.component";
|
|
22
|
-
import * as i3 from "../core/toolbar/toolbar.component";
|
|
23
|
+
import * as i1 from "../core/children/children.component";
|
|
23
24
|
const ElementHostClass = 'element-host';
|
|
24
25
|
export class PlaitBoardComponent {
|
|
25
26
|
get host() {
|
|
@@ -34,6 +35,9 @@ export class PlaitBoardComponent {
|
|
|
34
35
|
get isFocused() {
|
|
35
36
|
return PlaitBoard.isFocus(this.board);
|
|
36
37
|
}
|
|
38
|
+
get disabledScrollOnNonFocus() {
|
|
39
|
+
return this.board.options.disabledScrollOnNonFocus && !PlaitBoard.isFocus(this.board);
|
|
40
|
+
}
|
|
37
41
|
get nativeElement() {
|
|
38
42
|
return this.elementRef.nativeElement;
|
|
39
43
|
}
|
|
@@ -79,11 +83,15 @@ export class PlaitBoardComponent {
|
|
|
79
83
|
viewport: this.board.viewport,
|
|
80
84
|
selection: this.board.selection
|
|
81
85
|
};
|
|
86
|
+
this.updateIslands();
|
|
82
87
|
this.plaitChange.emit(changeEvent);
|
|
83
88
|
});
|
|
84
89
|
});
|
|
85
90
|
this.hasInitialized = true;
|
|
86
91
|
}
|
|
92
|
+
ngAfterContentInit() {
|
|
93
|
+
this.initializeIslands();
|
|
94
|
+
}
|
|
87
95
|
detect() {
|
|
88
96
|
this.effect = {};
|
|
89
97
|
this.cdr.detectChanges();
|
|
@@ -106,7 +114,7 @@ export class PlaitBoardComponent {
|
|
|
106
114
|
initializeViewportOffset(this.board);
|
|
107
115
|
}
|
|
108
116
|
initializePlugins() {
|
|
109
|
-
let board = withHandPointer(withHistory(withSelection(withMoving(withBoard(withViewport(createBoard(this.plaitValue, this.plaitOptions)))))));
|
|
117
|
+
let board = withHandPointer(withHistory(withSelection(withMoving(withBoard(withViewport(withOptions(createBoard(this.plaitValue, this.plaitOptions))))))));
|
|
110
118
|
this.plaitPlugins.forEach(plugin => {
|
|
111
119
|
board = plugin(board);
|
|
112
120
|
});
|
|
@@ -124,12 +132,12 @@ export class PlaitBoardComponent {
|
|
|
124
132
|
fromEvent(this.host, 'mousemove')
|
|
125
133
|
.pipe(takeUntil(this.destroy$))
|
|
126
134
|
.subscribe((event) => {
|
|
135
|
+
BOARD_TO_MOVING_POINT.set(this.board, [event.x, event.y]);
|
|
127
136
|
this.board.mousemove(event);
|
|
128
137
|
});
|
|
129
138
|
fromEvent(document, 'mousemove')
|
|
130
139
|
.pipe(takeUntil(this.destroy$))
|
|
131
140
|
.subscribe((event) => {
|
|
132
|
-
BOARD_TO_MOVING_POINT.set(this.board, [event.x, event.y]);
|
|
133
141
|
this.board.globalMousemove(event);
|
|
134
142
|
});
|
|
135
143
|
fromEvent(this.host, 'mouseup')
|
|
@@ -148,16 +156,19 @@ export class PlaitBoardComponent {
|
|
|
148
156
|
this.board.dblclick(event);
|
|
149
157
|
});
|
|
150
158
|
fromEvent(document, 'keydown')
|
|
151
|
-
.pipe(takeUntil(this.destroy$),
|
|
152
|
-
.
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
159
|
+
.pipe(takeUntil(this.destroy$), tap((event) => {
|
|
160
|
+
if (PlaitBoard.getMovingPoint(this.board)) {
|
|
161
|
+
if (isHotkey(['mod+=', 'mod++'], { byKey: true })(event)) {
|
|
162
|
+
event.preventDefault();
|
|
163
|
+
BoardTransforms.updateZoom(this.board, this.board.viewport.zoom + 0.1, false);
|
|
164
|
+
}
|
|
165
|
+
if (isHotkey('mod+-', { byKey: true })(event)) {
|
|
166
|
+
event.preventDefault();
|
|
167
|
+
BoardTransforms.updateZoom(this.board, this.board.viewport.zoom - 0.1);
|
|
168
|
+
}
|
|
160
169
|
}
|
|
170
|
+
}), filter(event => this.isFocused && !PlaitBoard.hasBeenTextEditing(this.board) && !hasInputOrTextareaTarget(event.target)))
|
|
171
|
+
.subscribe((event) => {
|
|
161
172
|
this.board?.keydown(event);
|
|
162
173
|
});
|
|
163
174
|
fromEvent(document, 'keyup')
|
|
@@ -175,8 +186,7 @@ export class PlaitBoardComponent {
|
|
|
175
186
|
.pipe(takeUntil(this.destroy$), filter(() => this.isFocused && !PlaitBoard.isReadonly(this.board) && !PlaitBoard.hasBeenTextEditing(this.board)))
|
|
176
187
|
.subscribe((clipboardEvent) => {
|
|
177
188
|
const mousePoint = PlaitBoard.getMovingPoint(this.board);
|
|
178
|
-
|
|
179
|
-
if (mousePoint && distanceBetweenPointAndRectangle(mousePoint[0], mousePoint[1], rect) === 0) {
|
|
189
|
+
if (mousePoint) {
|
|
180
190
|
const targetPoint = transformPoint(this.board, toPoint(mousePoint[0], mousePoint[1], this.host));
|
|
181
191
|
this.board.insertFragment(clipboardEvent.clipboardData, targetPoint);
|
|
182
192
|
}
|
|
@@ -197,7 +207,7 @@ export class PlaitBoardComponent {
|
|
|
197
207
|
setIsFromViewportChange(this.board, false);
|
|
198
208
|
return false;
|
|
199
209
|
}
|
|
200
|
-
return
|
|
210
|
+
return true;
|
|
201
211
|
}))
|
|
202
212
|
.subscribe((event) => {
|
|
203
213
|
const { scrollLeft, scrollTop } = event.target;
|
|
@@ -207,7 +217,7 @@ export class PlaitBoardComponent {
|
|
|
207
217
|
if (Point.isEquals(origination, this.board.viewport.origination)) {
|
|
208
218
|
return;
|
|
209
219
|
}
|
|
210
|
-
|
|
220
|
+
BoardTransforms.updateViewport(this.board, origination);
|
|
211
221
|
setIsFromScrolling(this.board, true);
|
|
212
222
|
});
|
|
213
223
|
});
|
|
@@ -227,17 +237,18 @@ export class PlaitBoardComponent {
|
|
|
227
237
|
BOARD_TO_MOVING_POINT.delete(this.board);
|
|
228
238
|
});
|
|
229
239
|
}
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
changeZoom(this.board, this.board.viewport.zoom + 0.1, isCenter);
|
|
235
|
-
}
|
|
236
|
-
zoomOutHandle() {
|
|
237
|
-
changeZoom(this.board, this.board.viewport.zoom - 0.1);
|
|
240
|
+
initializeIslands() {
|
|
241
|
+
this.islands?.forEach(island => {
|
|
242
|
+
island.initialize(this.board);
|
|
243
|
+
});
|
|
238
244
|
}
|
|
239
|
-
|
|
240
|
-
|
|
245
|
+
updateIslands() {
|
|
246
|
+
this.islands?.forEach(island => {
|
|
247
|
+
if (hasOnBoardChange(island)) {
|
|
248
|
+
island.onBoardChange();
|
|
249
|
+
}
|
|
250
|
+
island.markForCheck();
|
|
251
|
+
});
|
|
241
252
|
}
|
|
242
253
|
ngOnDestroy() {
|
|
243
254
|
this.destroy$.next();
|
|
@@ -252,25 +263,20 @@ export class PlaitBoardComponent {
|
|
|
252
263
|
}
|
|
253
264
|
markForCheck() {
|
|
254
265
|
this.cdr.markForCheck();
|
|
266
|
+
this.ngZone.run(() => {
|
|
267
|
+
this.updateIslands();
|
|
268
|
+
});
|
|
255
269
|
}
|
|
256
270
|
}
|
|
257
|
-
PlaitBoardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.
|
|
258
|
-
PlaitBoardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.
|
|
271
|
+
PlaitBoardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitBoardComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ViewContainerRef }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
272
|
+
PlaitBoardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: PlaitBoardComponent, selector: "plait-board", inputs: { plaitValue: "plaitValue", plaitViewport: "plaitViewport", plaitPlugins: "plaitPlugins", plaitOptions: "plaitOptions" }, outputs: { plaitChange: "plaitChange", plaitBoardInitialized: "plaitBoardInitialized" }, host: { properties: { "class": "this.hostClass", "class.readonly": "this.readonly", "class.focused": "this.isFocused", "class.disabled-scroll": "this.disabledScrollOnNonFocus" } }, queries: [{ propertyName: "islands", predicate: PlaitIslandBaseComponent, descendants: true }], viewQueries: [{ propertyName: "svg", first: true, predicate: ["svg"], descendants: true, static: true }, { propertyName: "viewportContainer", first: true, predicate: ["viewportContainer"], descendants: true, read: ElementRef, static: true }], usesOnChanges: true, ngImport: i0, template: `
|
|
259
273
|
<div class="viewport-container" #viewportContainer>
|
|
260
274
|
<svg #svg width="100%" height="100%" style="position: relative;"><g class="element-host"></g></svg>
|
|
261
275
|
<plait-children [board]="board" [effect]="effect"></plait-children>
|
|
262
276
|
</div>
|
|
263
|
-
<plait-toolbar
|
|
264
|
-
*ngIf="isFocused && !toolbarTemplateRef"
|
|
265
|
-
[board]="board"
|
|
266
|
-
(adaptHandle)="adaptHandle()"
|
|
267
|
-
(zoomInHandle)="zoomInHandle()"
|
|
268
|
-
(zoomOutHandle)="zoomOutHandle()"
|
|
269
|
-
(resetZoomHandel)="resetZoomHandel()"
|
|
270
|
-
></plait-toolbar>
|
|
271
277
|
<ng-content></ng-content>
|
|
272
|
-
`, isInline: true, dependencies: [{ kind: "
|
|
273
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.
|
|
278
|
+
`, isInline: true, dependencies: [{ kind: "component", type: i1.PlaitChildrenElement, selector: "plait-children", inputs: ["board", "parent", "effect", "parentG"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
279
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitBoardComponent, decorators: [{
|
|
274
280
|
type: Component,
|
|
275
281
|
args: [{
|
|
276
282
|
selector: 'plait-board',
|
|
@@ -279,14 +285,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImpor
|
|
|
279
285
|
<svg #svg width="100%" height="100%" style="position: relative;"><g class="element-host"></g></svg>
|
|
280
286
|
<plait-children [board]="board" [effect]="effect"></plait-children>
|
|
281
287
|
</div>
|
|
282
|
-
<plait-toolbar
|
|
283
|
-
*ngIf="isFocused && !toolbarTemplateRef"
|
|
284
|
-
[board]="board"
|
|
285
|
-
(adaptHandle)="adaptHandle()"
|
|
286
|
-
(zoomInHandle)="zoomInHandle()"
|
|
287
|
-
(zoomOutHandle)="zoomOutHandle()"
|
|
288
|
-
(resetZoomHandel)="resetZoomHandel()"
|
|
289
|
-
></plait-toolbar>
|
|
290
288
|
<ng-content></ng-content>
|
|
291
289
|
`,
|
|
292
290
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
@@ -312,14 +310,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImpor
|
|
|
312
310
|
}], isFocused: [{
|
|
313
311
|
type: HostBinding,
|
|
314
312
|
args: ['class.focused']
|
|
313
|
+
}], disabledScrollOnNonFocus: [{
|
|
314
|
+
type: HostBinding,
|
|
315
|
+
args: ['class.disabled-scroll']
|
|
315
316
|
}], svg: [{
|
|
316
317
|
type: ViewChild,
|
|
317
318
|
args: ['svg', { static: true }]
|
|
318
|
-
}], toolbarTemplateRef: [{
|
|
319
|
-
type: ContentChild,
|
|
320
|
-
args: ['plaitToolbar']
|
|
321
319
|
}], viewportContainer: [{
|
|
322
320
|
type: ViewChild,
|
|
323
321
|
args: ['viewportContainer', { read: ElementRef, static: true }]
|
|
322
|
+
}], islands: [{
|
|
323
|
+
type: ContentChildren,
|
|
324
|
+
args: [PlaitIslandBaseComponent, { descendants: true }]
|
|
324
325
|
}] } });
|
|
325
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.component.js","sourceRoot":"","sources":["../../../../packages/plait/src/board/board.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport rough from 'roughjs/bin/rough';\nimport { RoughSVG } from 'roughjs/bin/svg';\nimport { fromEvent, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { PlaitBoard, PlaitBoardChangeEvent, PlaitBoardOptions } from '../interfaces/board';\nimport { PlaitElement } from '../interfaces/element';\nimport { PlaitPlugin } from '../interfaces/plugin';\nimport { Viewport } from '../interfaces/viewport';\nimport { createBoard } from '../plugins/create-board';\nimport { withBoard } from '../plugins/with-board';\nimport { withHistory } from '../plugins/with-history';\nimport { withHandPointer } from '../plugins/with-hand';\nimport { withSelection } from '../plugins/with-selection';\nimport { toPoint, transformPoint, distanceBetweenPointAndRectangle } from '../utils';\nimport {\n    BOARD_TO_ON_CHANGE,\n    BOARD_TO_COMPONENT,\n    BOARD_TO_ELEMENT_HOST,\n    BOARD_TO_HOST,\n    BOARD_TO_ROUGH_SVG,\n    BOARD_TO_MOVING_POINT\n} from '../utils/weak-maps';\nimport { BoardComponentInterface } from './board.component.interface';\nimport {\n    fitViewport,\n    getViewBox,\n    initializeViewportOffset,\n    initializeViewBox,\n    setViewport,\n    changeZoom,\n    isFromViewportChange,\n    setIsFromViewportChange,\n    initializeViewportContainer,\n    updateViewportOffset,\n    setIsFromScrolling\n} from '../utils/viewport';\nimport { isHotkey } from 'is-hotkey';\nimport { withViewport } from '../plugins/with-viewport';\nimport { Point } from '../interfaces/point';\nimport { withMoving } from '../plugins/with-moving';\nimport { hasInputOrTextareaTarget } from '../utils/dom/common';\n\nconst ElementHostClass = 'element-host';\n\n@Component({\n    selector: 'plait-board',\n    template: `\n        <div class=\"viewport-container\" #viewportContainer>\n            <svg #svg width=\"100%\" height=\"100%\" style=\"position: relative;\"><g class=\"element-host\"></g></svg>\n            <plait-children [board]=\"board\" [effect]=\"effect\"></plait-children>\n        </div>\n        <plait-toolbar\n            *ngIf=\"isFocused && !toolbarTemplateRef\"\n            [board]=\"board\"\n            (adaptHandle)=\"adaptHandle()\"\n            (zoomInHandle)=\"zoomInHandle()\"\n            (zoomOutHandle)=\"zoomOutHandle()\"\n            (resetZoomHandel)=\"resetZoomHandel()\"\n        ></plait-toolbar>\n        <ng-content></ng-content>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PlaitBoardComponent implements BoardComponentInterface, OnInit, OnChanges, AfterViewInit, OnDestroy {\n    hasInitialized = false;\n\n    effect = {};\n\n    board!: PlaitBoard;\n\n    roughSVG!: RoughSVG;\n\n    destroy$ = new Subject<void>();\n\n    private resizeObserver!: ResizeObserver;\n\n    @Input() plaitValue: PlaitElement[] = [];\n\n    @Input() plaitViewport!: Viewport;\n\n    @Input() plaitPlugins: PlaitPlugin[] = [];\n\n    @Input() plaitOptions?: PlaitBoardOptions;\n\n    @Output() plaitChange: EventEmitter<PlaitBoardChangeEvent> = new EventEmitter();\n\n    @Output() plaitBoardInitialized: EventEmitter<PlaitBoard> = new EventEmitter();\n\n    get host(): SVGSVGElement {\n        return this.svg.nativeElement;\n    }\n\n    @HostBinding('class')\n    get hostClass() {\n        return `plait-board-container pointer-${this.board.pointer}`;\n    }\n\n    @HostBinding('class.readonly')\n    get readonly() {\n        return this.board.options.readonly;\n    }\n\n    @HostBinding('class.focused')\n    get isFocused() {\n        return PlaitBoard.isFocus(this.board);\n    }\n\n    get nativeElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    @ViewChild('svg', { static: true })\n    svg!: ElementRef;\n\n    @ContentChild('plaitToolbar')\n    public toolbarTemplateRef!: TemplateRef<any>;\n\n    @ViewChild('viewportContainer', { read: ElementRef, static: true })\n    viewportContainer!: ElementRef;\n\n    constructor(\n        public cdr: ChangeDetectorRef,\n        public viewContainerRef: ViewContainerRef,\n        private elementRef: ElementRef<HTMLElement>,\n        private ngZone: NgZone\n    ) {}\n\n    ngOnInit(): void {\n        const elementHost = this.host.querySelector(`.${ElementHostClass}`) as SVGGElement;\n        const roughSVG = rough.svg(this.host as SVGSVGElement, {\n            options: { roughness: 0, strokeWidth: 1 }\n        });\n        this.roughSVG = roughSVG;\n        this.initializePlugins();\n        this.ngZone.runOutsideAngular(() => {\n            this.initializeHookListener();\n            this.viewportScrollListener();\n            this.elementResizeListener();\n            this.mouseLeaveListener();\n        });\n        BOARD_TO_COMPONENT.set(this.board, this);\n        BOARD_TO_ROUGH_SVG.set(this.board, roughSVG);\n        BOARD_TO_HOST.set(this.board, this.host);\n        BOARD_TO_ELEMENT_HOST.set(this.board, elementHost);\n        BOARD_TO_ON_CHANGE.set(this.board, () => {\n            this.ngZone.run(() => {\n                this.detect();\n                const changeEvent: PlaitBoardChangeEvent = {\n                    children: this.board.children,\n                    operations: this.board.operations,\n                    viewport: this.board.viewport,\n                    selection: this.board.selection\n                };\n                this.plaitChange.emit(changeEvent);\n            });\n        });\n        this.hasInitialized = true;\n    }\n\n    detect() {\n        this.effect = {};\n        this.cdr.detectChanges();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (this.hasInitialized) {\n            const valueChange = changes['plaitValue'];\n            const options = changes['plaitOptions'];\n\n            if (valueChange) this.board.children = valueChange.currentValue;\n            if (options) this.board.options = options.currentValue;\n            this.cdr.markForCheck();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.plaitBoardInitialized.emit(this.board);\n        initializeViewportContainer(this.board);\n        initializeViewBox(this.board);\n        initializeViewportOffset(this.board);\n    }\n\n    private initializePlugins() {\n        let board = withHandPointer(\n            withHistory(withSelection(withMoving(withBoard(withViewport(createBoard(this.plaitValue, this.plaitOptions))))))\n        );\n        this.plaitPlugins.forEach(plugin => {\n            board = plugin(board);\n        });\n        this.board = board;\n\n        if (this.plaitViewport) {\n            this.board.viewport = this.plaitViewport;\n        }\n    }\n\n    private initializeHookListener() {\n        fromEvent<MouseEvent>(this.host, 'mousedown')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.mousedown(event);\n            });\n\n        fromEvent<MouseEvent>(this.host, 'mousemove')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.mousemove(event);\n            });\n\n        fromEvent<MouseEvent>(document, 'mousemove')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                BOARD_TO_MOVING_POINT.set(this.board, [event.x, event.y]);\n                this.board.globalMousemove(event);\n            });\n\n        fromEvent<MouseEvent>(this.host, 'mouseup')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.mouseup(event);\n            });\n\n        fromEvent<MouseEvent>(document, 'mouseup')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.globalMouseup(event);\n            });\n\n        fromEvent<MouseEvent>(this.host, 'dblclick')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => this.isFocused && !PlaitBoard.hasBeenTextEditing(this.board))\n            )\n            .subscribe((event: MouseEvent) => {\n                this.board.dblclick(event);\n            });\n\n        fromEvent<KeyboardEvent>(document, 'keydown')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(event => this.isFocused && !PlaitBoard.hasBeenTextEditing(this.board) && !hasInputOrTextareaTarget(event.target))\n            )\n            .subscribe((event: KeyboardEvent) => {\n                if (isHotkey(['mod+=', 'mod++'], { byKey: true })(event)) {\n                    event.preventDefault();\n                    this.zoomInHandle(false);\n                }\n                if (isHotkey('mod+-', { byKey: true })(event)) {\n                    this.zoomOutHandle();\n                    event.preventDefault();\n                }\n                this.board?.keydown(event);\n            });\n\n        fromEvent<KeyboardEvent>(document, 'keyup')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => this.isFocused && !PlaitBoard.hasBeenTextEditing(this.board))\n            )\n            .subscribe((event: KeyboardEvent) => {\n                this.board?.keyup(event);\n            });\n\n        fromEvent<ClipboardEvent>(document, 'copy')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => this.isFocused && !PlaitBoard.hasBeenTextEditing(this.board))\n            )\n            .subscribe((event: ClipboardEvent) => {\n                event.preventDefault();\n                this.board?.setFragment(event.clipboardData);\n            });\n\n        fromEvent<ClipboardEvent>(document, 'paste')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => this.isFocused && !PlaitBoard.isReadonly(this.board) && !PlaitBoard.hasBeenTextEditing(this.board))\n            )\n            .subscribe((clipboardEvent: ClipboardEvent) => {\n                const mousePoint = PlaitBoard.getMovingPoint(this.board);\n                const rect = this.nativeElement.getBoundingClientRect();\n                if (mousePoint && distanceBetweenPointAndRectangle(mousePoint[0], mousePoint[1], rect) === 0) {\n                    const targetPoint = transformPoint(this.board, toPoint(mousePoint[0], mousePoint[1], this.host));\n                    this.board.insertFragment(clipboardEvent.clipboardData, targetPoint);\n                }\n            });\n\n        fromEvent<ClipboardEvent>(document, 'cut')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => this.isFocused && !PlaitBoard.isReadonly(this.board) && !PlaitBoard.hasBeenTextEditing(this.board))\n            )\n            .subscribe((event: ClipboardEvent) => {\n                event.preventDefault();\n                this.board?.setFragment(event.clipboardData);\n                this.board?.deleteFragment(event.clipboardData);\n            });\n    }\n\n    private viewportScrollListener() {\n        this.ngZone.runOutsideAngular(() => {\n            fromEvent<MouseEvent>(this.viewportContainer.nativeElement, 'scroll')\n                .pipe(\n                    takeUntil(this.destroy$),\n                    filter(() => {\n                        if (isFromViewportChange(this.board)) {\n                            setIsFromViewportChange(this.board, false);\n                            return false;\n                        }\n                        return this.isFocused;\n                    })\n                )\n                .subscribe((event: Event) => {\n                    const { scrollLeft, scrollTop } = event.target as HTMLElement;\n                    const zoom = this.board.viewport.zoom;\n                    const viewBox = getViewBox(this.board, zoom);\n                    const origination = [scrollLeft / zoom + viewBox[0], scrollTop / zoom + viewBox[1]] as Point;\n                    if (Point.isEquals(origination, this.board.viewport.origination)) {\n                        return;\n                    }\n                    setViewport(this.board, origination);\n                    setIsFromScrolling(this.board, true);\n                });\n        });\n    }\n\n    private elementResizeListener() {\n        this.resizeObserver = new ResizeObserver(() => {\n            initializeViewportContainer(this.board);\n            initializeViewBox(this.board);\n            updateViewportOffset(this.board);\n        });\n        this.resizeObserver.observe(this.nativeElement);\n    }\n\n    private mouseLeaveListener() {\n        fromEvent<MouseEvent>(this.host, 'mouseleave')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                BOARD_TO_MOVING_POINT.delete(this.board);\n            });\n    }\n\n    trackBy = (index: number, element: PlaitElement) => {\n        return element.id;\n    };\n\n    adaptHandle() {\n        fitViewport(this.board);\n    }\n\n    zoomInHandle(isCenter = true) {\n        changeZoom(this.board, this.board.viewport.zoom + 0.1, isCenter);\n    }\n\n    zoomOutHandle() {\n        changeZoom(this.board, this.board.viewport.zoom - 0.1);\n    }\n\n    resetZoomHandel() {\n        changeZoom(this.board, 1);\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n        this.resizeObserver && this.resizeObserver?.disconnect();\n        BOARD_TO_ROUGH_SVG.delete(this.board);\n        BOARD_TO_COMPONENT.delete(this.board);\n        BOARD_TO_ROUGH_SVG.delete(this.board);\n        BOARD_TO_HOST.delete(this.board);\n        BOARD_TO_ELEMENT_HOST.delete(this.board);\n        BOARD_TO_ON_CHANGE.delete(this.board);\n    }\n\n    markForCheck() {\n        this.cdr.markForCheck();\n    }\n}\n"]}
|
|
326
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.component.js","sourceRoot":"","sources":["../../../../packages/plait/src/board/board.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    SimpleChanges,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport rough from 'roughjs/bin/rough';\nimport { RoughSVG } from 'roughjs/bin/svg';\nimport { fromEvent, Subject } from 'rxjs';\nimport { filter, takeUntil, tap } from 'rxjs/operators';\nimport { PlaitBoard, PlaitBoardChangeEvent, PlaitBoardOptions } from '../interfaces/board';\nimport { PlaitElement } from '../interfaces/element';\nimport { PlaitPlugin } from '../interfaces/plugin';\nimport { Viewport } from '../interfaces/viewport';\nimport { createBoard } from '../plugins/create-board';\nimport { withBoard } from '../plugins/with-board';\nimport { withHistory } from '../plugins/with-history';\nimport { withHandPointer } from '../plugins/with-hand';\nimport { withSelection } from '../plugins/with-selection';\nimport { toPoint, transformPoint } from '../utils';\nimport {\n    BOARD_TO_ON_CHANGE,\n    BOARD_TO_COMPONENT,\n    BOARD_TO_ELEMENT_HOST,\n    BOARD_TO_HOST,\n    BOARD_TO_ROUGH_SVG,\n    BOARD_TO_MOVING_POINT\n} from '../utils/weak-maps';\nimport { BoardComponentInterface } from './board.component.interface';\nimport {\n    getViewBox,\n    initializeViewportOffset,\n    initializeViewBox,\n    isFromViewportChange,\n    setIsFromViewportChange,\n    initializeViewportContainer,\n    updateViewportOffset,\n    setIsFromScrolling\n} from '../utils/viewport';\nimport { isHotkey } from 'is-hotkey';\nimport { withViewport } from '../plugins/with-viewport';\nimport { Point } from '../interfaces/point';\nimport { withMoving } from '../plugins/with-moving';\nimport { hasInputOrTextareaTarget } from '../utils/dom/common';\nimport { withOptions } from '../plugins/with-options';\nimport { PlaitIslandBaseComponent, hasOnBoardChange } from '../core/island/island-base.component';\nimport { BoardTransforms } from '../transforms/board';\n\nconst ElementHostClass = 'element-host';\n\n@Component({\n    selector: 'plait-board',\n    template: `\n        <div class=\"viewport-container\" #viewportContainer>\n            <svg #svg width=\"100%\" height=\"100%\" style=\"position: relative;\"><g class=\"element-host\"></g></svg>\n            <plait-children [board]=\"board\" [effect]=\"effect\"></plait-children>\n        </div>\n        <ng-content></ng-content>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PlaitBoardComponent implements BoardComponentInterface, OnInit, OnChanges, AfterViewInit, AfterContentInit, OnDestroy {\n    hasInitialized = false;\n\n    effect = {};\n\n    board!: PlaitBoard;\n\n    roughSVG!: RoughSVG;\n\n    destroy$ = new Subject<void>();\n\n    private resizeObserver!: ResizeObserver;\n\n    @Input() plaitValue: PlaitElement[] = [];\n\n    @Input() plaitViewport!: Viewport;\n\n    @Input() plaitPlugins: PlaitPlugin[] = [];\n\n    @Input() plaitOptions?: PlaitBoardOptions;\n\n    @Output() plaitChange: EventEmitter<PlaitBoardChangeEvent> = new EventEmitter();\n\n    @Output() plaitBoardInitialized: EventEmitter<PlaitBoard> = new EventEmitter();\n\n    get host(): SVGSVGElement {\n        return this.svg.nativeElement;\n    }\n\n    @HostBinding('class')\n    get hostClass() {\n        return `plait-board-container pointer-${this.board.pointer}`;\n    }\n\n    @HostBinding('class.readonly')\n    get readonly() {\n        return this.board.options.readonly;\n    }\n\n    @HostBinding('class.focused')\n    get isFocused() {\n        return PlaitBoard.isFocus(this.board);\n    }\n\n    @HostBinding('class.disabled-scroll')\n    get disabledScrollOnNonFocus() {\n        return this.board.options.disabledScrollOnNonFocus && !PlaitBoard.isFocus(this.board);\n    }\n\n    get nativeElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    @ViewChild('svg', { static: true })\n    svg!: ElementRef;\n\n    @ViewChild('viewportContainer', { read: ElementRef, static: true })\n    viewportContainer!: ElementRef;\n\n    @ContentChildren(PlaitIslandBaseComponent, { descendants: true }) islands?: QueryList<PlaitIslandBaseComponent>;\n\n    constructor(\n        public cdr: ChangeDetectorRef,\n        public viewContainerRef: ViewContainerRef,\n        private elementRef: ElementRef<HTMLElement>,\n        private ngZone: NgZone\n    ) {}\n\n    ngOnInit(): void {\n        const elementHost = this.host.querySelector(`.${ElementHostClass}`) as SVGGElement;\n        const roughSVG = rough.svg(this.host as SVGSVGElement, {\n            options: { roughness: 0, strokeWidth: 1 }\n        });\n        this.roughSVG = roughSVG;\n        this.initializePlugins();\n        this.ngZone.runOutsideAngular(() => {\n            this.initializeHookListener();\n            this.viewportScrollListener();\n            this.elementResizeListener();\n            this.mouseLeaveListener();\n        });\n        BOARD_TO_COMPONENT.set(this.board, this);\n        BOARD_TO_ROUGH_SVG.set(this.board, roughSVG);\n        BOARD_TO_HOST.set(this.board, this.host);\n        BOARD_TO_ELEMENT_HOST.set(this.board, elementHost);\n        BOARD_TO_ON_CHANGE.set(this.board, () => {\n            this.ngZone.run(() => {\n                this.detect();\n                const changeEvent: PlaitBoardChangeEvent = {\n                    children: this.board.children,\n                    operations: this.board.operations,\n                    viewport: this.board.viewport,\n                    selection: this.board.selection\n                };\n                this.updateIslands();\n                this.plaitChange.emit(changeEvent);\n            });\n        });\n        this.hasInitialized = true;\n    }\n\n    ngAfterContentInit(): void {\n        this.initializeIslands();\n    }\n\n    detect() {\n        this.effect = {};\n        this.cdr.detectChanges();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (this.hasInitialized) {\n            const valueChange = changes['plaitValue'];\n            const options = changes['plaitOptions'];\n\n            if (valueChange) this.board.children = valueChange.currentValue;\n            if (options) this.board.options = options.currentValue;\n            this.cdr.markForCheck();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.plaitBoardInitialized.emit(this.board);\n        initializeViewportContainer(this.board);\n        initializeViewBox(this.board);\n        initializeViewportOffset(this.board);\n    }\n\n    private initializePlugins() {\n        let board = withHandPointer(\n            withHistory(withSelection(withMoving(withBoard(withViewport(withOptions(createBoard(this.plaitValue, this.plaitOptions)))))))\n        );\n        this.plaitPlugins.forEach(plugin => {\n            board = plugin(board);\n        });\n        this.board = board;\n\n        if (this.plaitViewport) {\n            this.board.viewport = this.plaitViewport;\n        }\n    }\n\n    private initializeHookListener() {\n        fromEvent<MouseEvent>(this.host, 'mousedown')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.mousedown(event);\n            });\n\n        fromEvent<MouseEvent>(this.host, 'mousemove')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                BOARD_TO_MOVING_POINT.set(this.board, [event.x, event.y]);\n                this.board.mousemove(event);\n            });\n\n        fromEvent<MouseEvent>(document, 'mousemove')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.globalMousemove(event);\n            });\n\n        fromEvent<MouseEvent>(this.host, 'mouseup')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.mouseup(event);\n            });\n\n        fromEvent<MouseEvent>(document, 'mouseup')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.globalMouseup(event);\n            });\n\n        fromEvent<MouseEvent>(this.host, 'dblclick')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => this.isFocused && !PlaitBoard.hasBeenTextEditing(this.board))\n            )\n            .subscribe((event: MouseEvent) => {\n                this.board.dblclick(event);\n            });\n\n        fromEvent<KeyboardEvent>(document, 'keydown')\n            .pipe(\n                takeUntil(this.destroy$),\n                tap((event: KeyboardEvent) => {\n                    if (PlaitBoard.getMovingPoint(this.board)) {\n                        if (isHotkey(['mod+=', 'mod++'], { byKey: true })(event)) {\n                            event.preventDefault();\n                            BoardTransforms.updateZoom(this.board, this.board.viewport.zoom + 0.1, false);\n                        }\n                        if (isHotkey('mod+-', { byKey: true })(event)) {\n                            event.preventDefault();\n                            BoardTransforms.updateZoom(this.board, this.board.viewport.zoom - 0.1);\n                        }\n                    }\n                }),\n                filter(event => this.isFocused && !PlaitBoard.hasBeenTextEditing(this.board) && !hasInputOrTextareaTarget(event.target))\n            )\n            .subscribe((event: KeyboardEvent) => {\n                this.board?.keydown(event);\n            });\n\n        fromEvent<KeyboardEvent>(document, 'keyup')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => this.isFocused && !PlaitBoard.hasBeenTextEditing(this.board))\n            )\n            .subscribe((event: KeyboardEvent) => {\n                this.board?.keyup(event);\n            });\n\n        fromEvent<ClipboardEvent>(document, 'copy')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => this.isFocused && !PlaitBoard.hasBeenTextEditing(this.board))\n            )\n            .subscribe((event: ClipboardEvent) => {\n                event.preventDefault();\n                this.board?.setFragment(event.clipboardData);\n            });\n\n        fromEvent<ClipboardEvent>(document, 'paste')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => this.isFocused && !PlaitBoard.isReadonly(this.board) && !PlaitBoard.hasBeenTextEditing(this.board))\n            )\n            .subscribe((clipboardEvent: ClipboardEvent) => {\n                const mousePoint = PlaitBoard.getMovingPoint(this.board);\n                if (mousePoint) {\n                    const targetPoint = transformPoint(this.board, toPoint(mousePoint[0], mousePoint[1], this.host));\n                    this.board.insertFragment(clipboardEvent.clipboardData, targetPoint);\n                }\n            });\n\n        fromEvent<ClipboardEvent>(document, 'cut')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => this.isFocused && !PlaitBoard.isReadonly(this.board) && !PlaitBoard.hasBeenTextEditing(this.board))\n            )\n            .subscribe((event: ClipboardEvent) => {\n                event.preventDefault();\n                this.board?.setFragment(event.clipboardData);\n                this.board?.deleteFragment(event.clipboardData);\n            });\n    }\n\n    private viewportScrollListener() {\n        this.ngZone.runOutsideAngular(() => {\n            fromEvent<MouseEvent>(this.viewportContainer.nativeElement, 'scroll')\n                .pipe(\n                    takeUntil(this.destroy$),\n                    filter(() => {\n                        if (isFromViewportChange(this.board)) {\n                            setIsFromViewportChange(this.board, false);\n                            return false;\n                        }\n                        return true;\n                    })\n                )\n                .subscribe((event: Event) => {\n                    const { scrollLeft, scrollTop } = event.target as HTMLElement;\n                    const zoom = this.board.viewport.zoom;\n                    const viewBox = getViewBox(this.board, zoom);\n                    const origination = [scrollLeft / zoom + viewBox[0], scrollTop / zoom + viewBox[1]] as Point;\n                    if (Point.isEquals(origination, this.board.viewport.origination)) {\n                        return;\n                    }\n                    BoardTransforms.updateViewport(this.board, origination);\n                    setIsFromScrolling(this.board, true);\n                });\n        });\n    }\n\n    private elementResizeListener() {\n        this.resizeObserver = new ResizeObserver(() => {\n            initializeViewportContainer(this.board);\n            initializeViewBox(this.board);\n            updateViewportOffset(this.board);\n        });\n        this.resizeObserver.observe(this.nativeElement);\n    }\n\n    private mouseLeaveListener() {\n        fromEvent<MouseEvent>(this.host, 'mouseleave')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                BOARD_TO_MOVING_POINT.delete(this.board);\n            });\n    }\n\n    private initializeIslands() {\n        this.islands?.forEach(island => {\n            island.initialize(this.board);\n        });\n    }\n\n    private updateIslands() {\n        this.islands?.forEach(island => {\n            if (hasOnBoardChange(island)) {\n                island.onBoardChange();\n            }\n            island.markForCheck();\n        });\n    }\n\n    trackBy = (index: number, element: PlaitElement) => {\n        return element.id;\n    };\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n        this.resizeObserver && this.resizeObserver?.disconnect();\n        BOARD_TO_ROUGH_SVG.delete(this.board);\n        BOARD_TO_COMPONENT.delete(this.board);\n        BOARD_TO_ROUGH_SVG.delete(this.board);\n        BOARD_TO_HOST.delete(this.board);\n        BOARD_TO_ELEMENT_HOST.delete(this.board);\n        BOARD_TO_ON_CHANGE.delete(this.board);\n    }\n\n    markForCheck() {\n        this.cdr.markForCheck();\n        this.ngZone.run(() => {\n            this.updateIslands();\n        });\n    }\n}\n"]}
|
|
@@ -1,4 +1,10 @@
|
|
|
1
1
|
export const CLIP_BOARD_FORMAT_KEY = 'x-plait-fragment';
|
|
2
2
|
export const SCROLL_BAR_WIDTH = 20;
|
|
3
3
|
export const MAX_RADIUS = 16;
|
|
4
|
-
|
|
4
|
+
export const POINTER_BUTTON = {
|
|
5
|
+
MAIN: 0,
|
|
6
|
+
WHEEL: 1,
|
|
7
|
+
SECONDARY: 2,
|
|
8
|
+
TOUCH: -1,
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvY29uc3RhbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLGtCQUFrQixDQUFDO0FBRXhELE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLEVBQUUsQ0FBQztBQUVuQyxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsRUFBRSxDQUFDO0FBRTdCLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUMxQixJQUFJLEVBQUUsQ0FBQztJQUNQLEtBQUssRUFBRSxDQUFDO0lBQ1IsU0FBUyxFQUFFLENBQUM7SUFDWixLQUFLLEVBQUUsQ0FBQyxDQUFDO0NBQ0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBDTElQX0JPQVJEX0ZPUk1BVF9LRVkgPSAneC1wbGFpdC1mcmFnbWVudCc7XG5cbmV4cG9ydCBjb25zdCBTQ1JPTExfQkFSX1dJRFRIID0gMjA7XG5cbmV4cG9ydCBjb25zdCBNQVhfUkFESVVTID0gMTY7XG5cbmV4cG9ydCBjb25zdCBQT0lOVEVSX0JVVFRPTiA9IHtcbiAgICBNQUlOOiAwLFxuICAgIFdIRUVMOiAxLFxuICAgIFNFQ09OREFSWTogMixcbiAgICBUT1VDSDogLTEsXG4gIH0gYXMgY29uc3Q7Il19
|
|
@@ -18,8 +18,8 @@ export class PlaitChildrenElement {
|
|
|
18
18
|
}
|
|
19
19
|
}
|
|
20
20
|
}
|
|
21
|
-
PlaitChildrenElement.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.
|
|
22
|
-
PlaitChildrenElement.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.
|
|
21
|
+
PlaitChildrenElement.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitChildrenElement, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
22
|
+
PlaitChildrenElement.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: PlaitChildrenElement, selector: "plait-children", inputs: { board: "board", parent: "parent", effect: "effect", parentG: "parentG" }, ngImport: i0, template: `
|
|
23
23
|
<plait-element
|
|
24
24
|
*ngFor="let item of parent.children; let index = index; trackBy: trackBy"
|
|
25
25
|
[index]="index"
|
|
@@ -30,7 +30,7 @@ PlaitChildrenElement.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", v
|
|
|
30
30
|
[parentG]="parentG"
|
|
31
31
|
></plait-element>
|
|
32
32
|
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.PlaitElementComponent, selector: "plait-element", inputs: ["index", "element", "parent", "board", "effect", "parentG"] }] });
|
|
33
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.
|
|
33
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitChildrenElement, decorators: [{
|
|
34
34
|
type: Component,
|
|
35
35
|
args: [{
|
|
36
36
|
selector: 'plait-children',
|
|
@@ -79,9 +79,9 @@ export class PlaitElementComponent {
|
|
|
79
79
|
this.board.destroyElement(this.getContext());
|
|
80
80
|
}
|
|
81
81
|
}
|
|
82
|
-
PlaitElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.
|
|
83
|
-
PlaitElementComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.
|
|
84
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.
|
|
82
|
+
PlaitElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitElementComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
83
|
+
PlaitElementComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: PlaitElementComponent, selector: "plait-element", inputs: { index: "index", element: "element", parent: "parent", board: "board", effect: "effect", parentG: "parentG" }, usesOnChanges: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
84
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitElementComponent, decorators: [{
|
|
85
85
|
type: Component,
|
|
86
86
|
args: [{
|
|
87
87
|
selector: 'plait-element',
|
|
@@ -64,9 +64,9 @@ export class PlaitPluginElementComponent {
|
|
|
64
64
|
(this.rootG || this.g).remove();
|
|
65
65
|
}
|
|
66
66
|
}
|
|
67
|
-
PlaitPluginElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.
|
|
68
|
-
PlaitPluginElementComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.
|
|
69
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.
|
|
67
|
+
PlaitPluginElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitPluginElementComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
68
|
+
PlaitPluginElementComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.5", type: PlaitPluginElementComponent, inputs: { context: "context" }, ngImport: i0 });
|
|
69
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitPluginElementComponent, decorators: [{
|
|
70
70
|
type: Directive
|
|
71
71
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { context: [{
|
|
72
72
|
type: Input
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { Directive } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class PlaitIslandBaseComponent {
|
|
4
|
+
constructor(cdr) {
|
|
5
|
+
this.cdr = cdr;
|
|
6
|
+
}
|
|
7
|
+
initialize(board) {
|
|
8
|
+
this.board = board;
|
|
9
|
+
this.markForCheck();
|
|
10
|
+
}
|
|
11
|
+
markForCheck() {
|
|
12
|
+
this.cdr.markForCheck();
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
PlaitIslandBaseComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitIslandBaseComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
16
|
+
PlaitIslandBaseComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.5", type: PlaitIslandBaseComponent, host: { classAttribute: "plait-island-container" }, ngImport: i0 });
|
|
17
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitIslandBaseComponent, decorators: [{
|
|
18
|
+
type: Directive,
|
|
19
|
+
args: [{
|
|
20
|
+
host: {
|
|
21
|
+
class: 'plait-island-container'
|
|
22
|
+
}
|
|
23
|
+
}]
|
|
24
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; } });
|
|
25
|
+
export const hasOnBoardChange = (value) => {
|
|
26
|
+
if (value.onBoardChange) {
|
|
27
|
+
return true;
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
return false;
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXNsYW5kLWJhc2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL2NvcmUvaXNsYW5kL2lzbGFuZC1iYXNlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXFCLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFRN0QsTUFBTSxPQUFnQix3QkFBd0I7SUFHMUMsWUFBc0IsR0FBc0I7UUFBdEIsUUFBRyxHQUFILEdBQUcsQ0FBbUI7SUFBRyxDQUFDO0lBRWhELFVBQVUsQ0FBQyxLQUFpQjtRQUN4QixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVELFlBQVk7UUFDUixJQUFJLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQzVCLENBQUM7O3FIQVppQix3QkFBd0I7eUdBQXhCLHdCQUF3QjsyRkFBeEIsd0JBQXdCO2tCQUw3QyxTQUFTO21CQUFDO29CQUNQLElBQUksRUFBRTt3QkFDRixLQUFLLEVBQUUsd0JBQXdCO3FCQUNsQztpQkFDSjs7QUFvQkQsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxLQUFVLEVBQTBCLEVBQUU7SUFDbkUsSUFBSSxLQUFLLENBQUMsYUFBYSxFQUFFO1FBQ3JCLE9BQU8sSUFBSSxDQUFDO0tBQ2Y7U0FBTTtRQUNILE9BQU8sS0FBSyxDQUFDO0tBQ2hCO0FBQ0wsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0b3JSZWYsIERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBob3N0OiB7XG4gICAgICAgIGNsYXNzOiAncGxhaXQtaXNsYW5kLWNvbnRhaW5lcidcbiAgICB9XG59KVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFBsYWl0SXNsYW5kQmFzZUNvbXBvbmVudCB7XG4gICAgYm9hcmQhOiBQbGFpdEJvYXJkO1xuXG4gICAgY29uc3RydWN0b3IocHJvdGVjdGVkIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHt9XG5cbiAgICBpbml0aWFsaXplKGJvYXJkOiBQbGFpdEJvYXJkKSB7XG4gICAgICAgIHRoaXMuYm9hcmQgPSBib2FyZDtcbiAgICAgICAgdGhpcy5tYXJrRm9yQ2hlY2soKTtcbiAgICB9XG5cbiAgICBtYXJrRm9yQ2hlY2soKSB7XG4gICAgICAgIHRoaXMuY2RyLm1hcmtGb3JDaGVjaygpO1xuICAgIH1cbn1cblxuZXhwb3J0IGludGVyZmFjZSBPbkJvYXJkQ2hhbmdlIHtcbiAgICBvbkJvYXJkQ2hhbmdlOiAoKSA9PiB2b2lkO1xufVxuXG5leHBvcnQgY29uc3QgaGFzT25Cb2FyZENoYW5nZSA9ICh2YWx1ZTogYW55KTogdmFsdWUgaXMgT25Cb2FyZENoYW5nZSA9PiB7XG4gICAgaWYgKHZhbHVlLm9uQm9hcmRDaGFuZ2UpIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbn07XG4iXX0=
|