@plait/core 0.0.2
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/README.md +1 -0
- package/board/board.component.d.ts +37 -0
- package/core/base/detector.d.ts +7 -0
- package/core/element/element.component.d.ts +27 -0
- package/esm2020/board/board.component.mjs +211 -0
- package/esm2020/core/base/detector.mjs +2 -0
- package/esm2020/core/element/element.component.mjs +70 -0
- package/esm2020/interfaces/board.mjs +2 -0
- package/esm2020/interfaces/cursor.mjs +6 -0
- package/esm2020/interfaces/custom-types.mjs +5 -0
- package/esm2020/interfaces/element-context.mjs +2 -0
- package/esm2020/interfaces/element.mjs +2 -0
- package/esm2020/interfaces/graph.mjs +2 -0
- package/esm2020/interfaces/index.mjs +14 -0
- package/esm2020/interfaces/node.mjs +20 -0
- package/esm2020/interfaces/operation.mjs +7 -0
- package/esm2020/interfaces/path.mjs +139 -0
- package/esm2020/interfaces/plugin.mjs +2 -0
- package/esm2020/interfaces/point.mjs +2 -0
- package/esm2020/interfaces/selection.mjs +2 -0
- package/esm2020/interfaces/viewport.mjs +10 -0
- package/esm2020/plait-core.mjs +5 -0
- package/esm2020/plait.module.mjs +19 -0
- package/esm2020/plugins/create-board.mjs +42 -0
- package/esm2020/plugins/with-board.mjs +13 -0
- package/esm2020/plugins/with-selection.mjs +39 -0
- package/esm2020/public-api.mjs +11 -0
- package/esm2020/transfroms/general.mjs +139 -0
- package/esm2020/transfroms/index.mjs +11 -0
- package/esm2020/transfroms/node.mjs +36 -0
- package/esm2020/transfroms/selection.mjs +8 -0
- package/esm2020/transfroms/viewport.mjs +8 -0
- package/esm2020/utils/board.mjs +25 -0
- package/esm2020/utils/dom.mjs +22 -0
- package/esm2020/utils/environment.mjs +13 -0
- package/esm2020/utils/graph.mjs +11 -0
- package/esm2020/utils/helper.mjs +4 -0
- package/esm2020/utils/hotkeys.mjs +99 -0
- package/esm2020/utils/id-creator.mjs +11 -0
- package/esm2020/utils/index.mjs +10 -0
- package/esm2020/utils/math.mjs +37 -0
- package/esm2020/utils/weak-maps.mjs +6 -0
- package/fesm2015/plait-core.mjs +969 -0
- package/fesm2015/plait-core.mjs.map +1 -0
- package/fesm2020/plait-core.mjs +984 -0
- package/fesm2020/plait-core.mjs.map +1 -0
- package/interfaces/board.d.ts +32 -0
- package/interfaces/cursor.d.ts +5 -0
- package/interfaces/custom-types.d.ts +9 -0
- package/interfaces/element-context.d.ts +4 -0
- package/interfaces/element.d.ts +6 -0
- package/interfaces/graph.d.ts +6 -0
- package/interfaces/index.d.ts +13 -0
- package/interfaces/node.d.ts +13 -0
- package/interfaces/operation.d.ts +39 -0
- package/interfaces/path.d.ts +32 -0
- package/interfaces/plugin.d.ts +2 -0
- package/interfaces/point.d.ts +1 -0
- package/interfaces/selection.d.ts +5 -0
- package/interfaces/viewport.d.ts +13 -0
- package/package.json +31 -0
- package/plait-core.d.ts +5 -0
- package/plait.module.d.ts +9 -0
- package/plugins/create-board.d.ts +3 -0
- package/plugins/with-board.d.ts +2 -0
- package/plugins/with-selection.d.ts +2 -0
- package/public-api.d.ts +7 -0
- package/transfroms/general.d.ts +6 -0
- package/transfroms/index.d.ts +5 -0
- package/transfroms/node.d.ts +14 -0
- package/transfroms/selection.d.ts +7 -0
- package/transfroms/viewport.d.ts +7 -0
- package/utils/board.d.ts +10 -0
- package/utils/dom.d.ts +6 -0
- package/utils/environment.d.ts +7 -0
- package/utils/graph.d.ts +3 -0
- package/utils/helper.d.ts +1 -0
- package/utils/hotkeys.d.ts +32 -0
- package/utils/id-creator.d.ts +1 -0
- package/utils/index.d.ts +9 -0
- package/utils/math.d.ts +2 -0
- package/utils/weak-maps.d.ts +6 -0
package/README.md
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
# Core/Board
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, OnDestroy, OnInit, Renderer2 } from '@angular/core';
|
|
2
|
+
import { PlaitBoardChangeEvent, PlaitBoard } from '../interfaces/board';
|
|
3
|
+
import { PlaitElement } from '../interfaces/element';
|
|
4
|
+
import { Subject } from 'rxjs';
|
|
5
|
+
import { PlaitPlugin } from '../interfaces/plugin';
|
|
6
|
+
import { RoughSVG } from 'roughjs/bin/svg';
|
|
7
|
+
import { Viewport } from '../interfaces/viewport';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export declare class PlaitBoardComponent implements OnInit, AfterViewInit, OnDestroy {
|
|
10
|
+
private cdr;
|
|
11
|
+
private renderer2;
|
|
12
|
+
zoom: number;
|
|
13
|
+
hostClass: string;
|
|
14
|
+
board: PlaitBoard;
|
|
15
|
+
roughSVG: RoughSVG;
|
|
16
|
+
destroy$: Subject<any>;
|
|
17
|
+
svg: ElementRef;
|
|
18
|
+
get host(): SVGElement;
|
|
19
|
+
plaitValue: PlaitElement[];
|
|
20
|
+
plaitViewport: Viewport;
|
|
21
|
+
plaitPlugins: PlaitPlugin[];
|
|
22
|
+
plaitChange: EventEmitter<PlaitBoardChangeEvent>;
|
|
23
|
+
plaitBoardInitialized: EventEmitter<PlaitBoard>;
|
|
24
|
+
constructor(cdr: ChangeDetectorRef, renderer2: Renderer2);
|
|
25
|
+
ngOnInit(): void;
|
|
26
|
+
ngAfterViewInit(): void;
|
|
27
|
+
initializePlugins(): void;
|
|
28
|
+
initializeEvents(): void;
|
|
29
|
+
updateViewport(): void;
|
|
30
|
+
zoomIn(event: MouseEvent): void;
|
|
31
|
+
zoomOut(event: MouseEvent): void;
|
|
32
|
+
resetZoom(event: MouseEvent): void;
|
|
33
|
+
trackBy: (index: number, element: PlaitElement) => number;
|
|
34
|
+
ngOnDestroy(): void;
|
|
35
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<PlaitBoardComponent, never>;
|
|
36
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<PlaitBoardComponent, "plait-board", never, { "plaitValue": "plaitValue"; "plaitViewport": "plaitViewport"; "plaitPlugins": "plaitPlugins"; }, { "plaitChange": "plaitChange"; "plaitBoardInitialized": "plaitBoardInitialized"; }, never, ["*"]>;
|
|
37
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Point } from '../../interfaces/point';
|
|
2
|
+
import { PlaitElement } from '../../interfaces/element';
|
|
3
|
+
import { Selection } from '../../interfaces/selection';
|
|
4
|
+
export interface BaseDetector {
|
|
5
|
+
contian: (selection: Selection, element: PlaitElement) => boolean;
|
|
6
|
+
hit: (point: Point, element: PlaitElement) => boolean;
|
|
7
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { PlaitElement } from '../../interfaces/element';
|
|
3
|
+
import { PlaitBoard } from '../../interfaces/board';
|
|
4
|
+
import { Selection } from '../../interfaces/selection';
|
|
5
|
+
import { Viewport } from '../../interfaces/viewport';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export declare class PlaitElementComponent implements OnInit, OnChanges, OnDestroy {
|
|
8
|
+
renderer2: Renderer2;
|
|
9
|
+
viewContainerRef: ViewContainerRef;
|
|
10
|
+
initialized: boolean;
|
|
11
|
+
groupG: SVGGElement;
|
|
12
|
+
index: number;
|
|
13
|
+
element: PlaitElement;
|
|
14
|
+
board: PlaitBoard;
|
|
15
|
+
viewport: Viewport;
|
|
16
|
+
selection: Selection | null;
|
|
17
|
+
host: SVGElement;
|
|
18
|
+
constructor(renderer2: Renderer2, viewContainerRef: ViewContainerRef);
|
|
19
|
+
ngOnInit(): void;
|
|
20
|
+
initialize(): void;
|
|
21
|
+
transform(first?: boolean): void;
|
|
22
|
+
drawElement(): void;
|
|
23
|
+
ngOnChanges(changes: SimpleChanges): void;
|
|
24
|
+
ngOnDestroy(): void;
|
|
25
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<PlaitElementComponent, never>;
|
|
26
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<PlaitElementComponent, "plait-element", never, { "index": "index"; "element": "element"; "board": "board"; "viewport": "viewport"; "selection": "selection"; "host": "host"; }, {}, never, never>;
|
|
27
|
+
}
|
|
@@ -0,0 +1,211 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { BOARD_TO_ON_CHANGE, HOST_TO_ROUGH_SVG, IS_TEXT_EDITABLE } from '../utils/weak-maps';
|
|
3
|
+
import { createBoard } from '../plugins/create-board';
|
|
4
|
+
import { withBoard } from '../plugins/with-board';
|
|
5
|
+
import { fromEvent, Subject } from 'rxjs';
|
|
6
|
+
import { filter, takeUntil } from 'rxjs/operators';
|
|
7
|
+
import rough from 'roughjs/bin/rough';
|
|
8
|
+
import { Transforms } from '../transfroms';
|
|
9
|
+
import { withSelection } from '../plugins/with-selection';
|
|
10
|
+
import { PlaitOperation } from '../interfaces/operation';
|
|
11
|
+
import { getViewBox } from '../utils/board';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "../core/element/element.component";
|
|
14
|
+
import * as i2 from "@angular/common";
|
|
15
|
+
export class PlaitBoardComponent {
|
|
16
|
+
constructor(cdr, renderer2) {
|
|
17
|
+
this.cdr = cdr;
|
|
18
|
+
this.renderer2 = renderer2;
|
|
19
|
+
this.zoom = 100;
|
|
20
|
+
this.hostClass = `plait-board-container`;
|
|
21
|
+
this.destroy$ = new Subject();
|
|
22
|
+
this.plaitValue = [];
|
|
23
|
+
this.plaitPlugins = [];
|
|
24
|
+
this.plaitChange = new EventEmitter();
|
|
25
|
+
this.plaitBoardInitialized = new EventEmitter();
|
|
26
|
+
this.trackBy = (index, element) => {
|
|
27
|
+
return index;
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
get host() {
|
|
31
|
+
return this.svg.nativeElement;
|
|
32
|
+
}
|
|
33
|
+
ngOnInit() {
|
|
34
|
+
const roughSVG = rough.svg(this.host, { options: { roughness: 0, strokeWidth: 1 } });
|
|
35
|
+
HOST_TO_ROUGH_SVG.set(this.host, roughSVG);
|
|
36
|
+
this.initializePlugins();
|
|
37
|
+
this.initializeEvents();
|
|
38
|
+
this.updateViewport();
|
|
39
|
+
BOARD_TO_ON_CHANGE.set(this.board, () => {
|
|
40
|
+
this.cdr.detectChanges();
|
|
41
|
+
const changeEvent = {
|
|
42
|
+
children: this.board.children,
|
|
43
|
+
operations: this.board.operations,
|
|
44
|
+
viewport: this.board.viewport,
|
|
45
|
+
selection: this.board.selection
|
|
46
|
+
};
|
|
47
|
+
this.plaitChange.emit(changeEvent);
|
|
48
|
+
// update viewBox
|
|
49
|
+
if (this.board.operations.some(op => PlaitOperation.isSetViewportOperation(op))) {
|
|
50
|
+
this.updateViewport();
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
ngAfterViewInit() {
|
|
55
|
+
this.plaitBoardInitialized.emit(this.board);
|
|
56
|
+
}
|
|
57
|
+
initializePlugins() {
|
|
58
|
+
let board = withSelection(withBoard(createBoard(this.host, this.plaitValue)));
|
|
59
|
+
this.plaitPlugins.forEach(plugin => {
|
|
60
|
+
board = plugin(board);
|
|
61
|
+
});
|
|
62
|
+
this.board = board;
|
|
63
|
+
if (this.plaitViewport) {
|
|
64
|
+
this.board.viewport = this.plaitViewport;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
initializeEvents() {
|
|
68
|
+
fromEvent(this.host, 'mousedown')
|
|
69
|
+
.pipe(takeUntil(this.destroy$))
|
|
70
|
+
.subscribe((event) => {
|
|
71
|
+
this.board.mousedown(event);
|
|
72
|
+
});
|
|
73
|
+
fromEvent(this.host, 'mousemove')
|
|
74
|
+
.pipe(takeUntil(this.destroy$))
|
|
75
|
+
.subscribe((event) => {
|
|
76
|
+
this.board.mousemove(event);
|
|
77
|
+
});
|
|
78
|
+
fromEvent(document, 'mouseup')
|
|
79
|
+
.pipe(takeUntil(this.destroy$))
|
|
80
|
+
.subscribe((event) => {
|
|
81
|
+
this.board.mouseup(event);
|
|
82
|
+
});
|
|
83
|
+
fromEvent(this.host, 'dblclick')
|
|
84
|
+
.pipe(takeUntil(this.destroy$))
|
|
85
|
+
.subscribe((event) => {
|
|
86
|
+
this.board.dblclick(event);
|
|
87
|
+
});
|
|
88
|
+
fromEvent(this.host, 'wheel')
|
|
89
|
+
.pipe(takeUntil(this.destroy$))
|
|
90
|
+
.subscribe((event) => {
|
|
91
|
+
event.preventDefault();
|
|
92
|
+
const viewport = this.board.viewport;
|
|
93
|
+
Transforms.setViewport(this.board, {
|
|
94
|
+
...viewport,
|
|
95
|
+
offsetX: viewport?.offsetX - event.deltaX,
|
|
96
|
+
offsetY: viewport?.offsetY - event.deltaY
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
fromEvent(document, 'keydown')
|
|
100
|
+
.pipe(takeUntil(this.destroy$), filter(() => {
|
|
101
|
+
return !IS_TEXT_EDITABLE.get(this.board);
|
|
102
|
+
}))
|
|
103
|
+
.subscribe((event) => {
|
|
104
|
+
this.board?.keydown(event);
|
|
105
|
+
});
|
|
106
|
+
fromEvent(document, 'keyup')
|
|
107
|
+
.pipe(takeUntil(this.destroy$))
|
|
108
|
+
.subscribe((event) => {
|
|
109
|
+
this.board?.keyup(event);
|
|
110
|
+
});
|
|
111
|
+
window.onresize = () => {
|
|
112
|
+
const viewBoxModel = getViewBox(this.board);
|
|
113
|
+
const viewBoxValues = this.host.getAttribute('viewBox')?.split(',');
|
|
114
|
+
this.renderer2.setAttribute(this.host, 'viewBox', `${viewBoxValues[0].trim()}, ${viewBoxValues[1].trim()}, ${viewBoxModel.width}, ${viewBoxModel.height}`);
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
updateViewport() {
|
|
118
|
+
this.zoom = Math.floor(this.board.viewport.zoom * 100);
|
|
119
|
+
const viewBox = getViewBox(this.board);
|
|
120
|
+
this.renderer2.setAttribute(this.host, 'viewBox', `${viewBox.minX}, ${viewBox.minY}, ${viewBox.width}, ${viewBox.height}`);
|
|
121
|
+
}
|
|
122
|
+
// 放大
|
|
123
|
+
zoomIn(event) {
|
|
124
|
+
const viewport = this.board?.viewport;
|
|
125
|
+
Transforms.setViewport(this.board, {
|
|
126
|
+
...viewport,
|
|
127
|
+
zoom: viewport.zoom + 0.1
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
// 缩小
|
|
131
|
+
zoomOut(event) {
|
|
132
|
+
const viewport = this.board?.viewport;
|
|
133
|
+
Transforms.setViewport(this.board, {
|
|
134
|
+
...viewport,
|
|
135
|
+
zoom: viewport.zoom - 0.1
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
resetZoom(event) {
|
|
139
|
+
const viewport = this.board?.viewport;
|
|
140
|
+
Transforms.setViewport(this.board, {
|
|
141
|
+
...viewport,
|
|
142
|
+
zoom: 1
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
ngOnDestroy() {
|
|
146
|
+
this.destroy$.next();
|
|
147
|
+
this.destroy$.complete();
|
|
148
|
+
HOST_TO_ROUGH_SVG.delete(this.host);
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
PlaitBoardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: PlaitBoardComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
|
|
152
|
+
PlaitBoardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: PlaitBoardComponent, selector: "plait-board", inputs: { plaitValue: "plaitValue", plaitViewport: "plaitViewport", plaitPlugins: "plaitPlugins" }, outputs: { plaitChange: "plaitChange", plaitBoardInitialized: "plaitBoardInitialized" }, host: { properties: { "class": "this.hostClass" } }, viewQueries: [{ propertyName: "svg", first: true, predicate: ["svg"], descendants: true, static: true }], ngImport: i0, template: `
|
|
153
|
+
<svg #svg width="100%" height="100%"></svg>
|
|
154
|
+
<div class="plait-toolbar island zoom-toolbar">
|
|
155
|
+
<button class="item" (mousedown)="zoomOut($event)">-</button>
|
|
156
|
+
<button class="item zoom-value" (mousedown)="resetZoom($event)">{{ zoom }}%</button>
|
|
157
|
+
<button class="item" (mousedown)="zoomIn($event)">+</button>
|
|
158
|
+
</div>
|
|
159
|
+
<plait-element
|
|
160
|
+
*ngFor="let item of board.children; let index = index; trackBy: trackBy"
|
|
161
|
+
[index]="index"
|
|
162
|
+
[element]="item"
|
|
163
|
+
[board]="board"
|
|
164
|
+
[viewport]="board.viewport"
|
|
165
|
+
[selection]="board.selection"
|
|
166
|
+
[host]="host"
|
|
167
|
+
></plait-element>
|
|
168
|
+
<ng-content></ng-content>
|
|
169
|
+
`, isInline: true, components: [{ type: i1.PlaitElementComponent, selector: "plait-element", inputs: ["index", "element", "board", "viewport", "selection", "host"] }], directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
170
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: PlaitBoardComponent, decorators: [{
|
|
171
|
+
type: Component,
|
|
172
|
+
args: [{
|
|
173
|
+
selector: 'plait-board',
|
|
174
|
+
template: `
|
|
175
|
+
<svg #svg width="100%" height="100%"></svg>
|
|
176
|
+
<div class="plait-toolbar island zoom-toolbar">
|
|
177
|
+
<button class="item" (mousedown)="zoomOut($event)">-</button>
|
|
178
|
+
<button class="item zoom-value" (mousedown)="resetZoom($event)">{{ zoom }}%</button>
|
|
179
|
+
<button class="item" (mousedown)="zoomIn($event)">+</button>
|
|
180
|
+
</div>
|
|
181
|
+
<plait-element
|
|
182
|
+
*ngFor="let item of board.children; let index = index; trackBy: trackBy"
|
|
183
|
+
[index]="index"
|
|
184
|
+
[element]="item"
|
|
185
|
+
[board]="board"
|
|
186
|
+
[viewport]="board.viewport"
|
|
187
|
+
[selection]="board.selection"
|
|
188
|
+
[host]="host"
|
|
189
|
+
></plait-element>
|
|
190
|
+
<ng-content></ng-content>
|
|
191
|
+
`,
|
|
192
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
193
|
+
}]
|
|
194
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }]; }, propDecorators: { hostClass: [{
|
|
195
|
+
type: HostBinding,
|
|
196
|
+
args: ['class']
|
|
197
|
+
}], svg: [{
|
|
198
|
+
type: ViewChild,
|
|
199
|
+
args: ['svg', { static: true }]
|
|
200
|
+
}], plaitValue: [{
|
|
201
|
+
type: Input
|
|
202
|
+
}], plaitViewport: [{
|
|
203
|
+
type: Input
|
|
204
|
+
}], plaitPlugins: [{
|
|
205
|
+
type: Input
|
|
206
|
+
}], plaitChange: [{
|
|
207
|
+
type: Output
|
|
208
|
+
}], plaitBoardInitialized: [{
|
|
209
|
+
type: Output
|
|
210
|
+
}] } });
|
|
211
|
+
//# 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    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewChild\n} from '@angular/core';\nimport { BOARD_TO_ON_CHANGE, HOST_TO_ROUGH_SVG, IS_TEXT_EDITABLE } from '../utils/weak-maps';\nimport { PlaitBoardChangeEvent, PlaitBoard } from '../interfaces/board';\nimport { PlaitElement } from '../interfaces/element';\nimport { createBoard } from '../plugins/create-board';\nimport { withBoard } from '../plugins/with-board';\nimport { fromEvent, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { PlaitPlugin } from '../interfaces/plugin';\nimport { RoughSVG } from 'roughjs/bin/svg';\nimport rough from 'roughjs/bin/rough';\nimport { Transforms } from '../transfroms';\nimport { withSelection } from '../plugins/with-selection';\nimport { PlaitOperation } from '../interfaces/operation';\nimport { getViewBox } from '../utils/board';\nimport { Viewport } from '../interfaces/viewport';\n\n@Component({\n    selector: 'plait-board',\n    template: `\n        <svg #svg width=\"100%\" height=\"100%\"></svg>\n        <div class=\"plait-toolbar island zoom-toolbar\">\n            <button class=\"item\" (mousedown)=\"zoomOut($event)\">-</button>\n            <button class=\"item zoom-value\" (mousedown)=\"resetZoom($event)\">{{ zoom }}%</button>\n            <button class=\"item\" (mousedown)=\"zoomIn($event)\">+</button>\n        </div>\n        <plait-element\n            *ngFor=\"let item of board.children; let index = index; trackBy: trackBy\"\n            [index]=\"index\"\n            [element]=\"item\"\n            [board]=\"board\"\n            [viewport]=\"board.viewport\"\n            [selection]=\"board.selection\"\n            [host]=\"host\"\n        ></plait-element>\n        <ng-content></ng-content>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PlaitBoardComponent implements OnInit, AfterViewInit, OnDestroy {\n    zoom = 100;\n\n    @HostBinding('class') hostClass = `plait-board-container`;\n\n    board!: PlaitBoard;\n\n    roughSVG!: RoughSVG;\n\n    destroy$: Subject<any> = new Subject();\n\n    @ViewChild('svg', { static: true })\n    svg!: ElementRef;\n\n    get host(): SVGElement {\n        return this.svg.nativeElement;\n    }\n\n    @Input() plaitValue: PlaitElement[] = [];\n\n    @Input() plaitViewport!: Viewport;\n\n    @Input() plaitPlugins: PlaitPlugin[] = [];\n\n    @Output() plaitChange: EventEmitter<PlaitBoardChangeEvent> = new EventEmitter();\n\n    @Output() plaitBoardInitialized: EventEmitter<PlaitBoard> = new EventEmitter();\n\n    constructor(private cdr: ChangeDetectorRef, private renderer2: Renderer2) {}\n\n    ngOnInit(): void {\n        const roughSVG = rough.svg(this.host as SVGSVGElement, { options: { roughness: 0, strokeWidth: 1 } });\n        HOST_TO_ROUGH_SVG.set(this.host, roughSVG);\n        this.initializePlugins();\n        this.initializeEvents();\n        this.updateViewport();\n        BOARD_TO_ON_CHANGE.set(this.board, () => {\n            this.cdr.detectChanges();\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            // update viewBox\n            if (this.board.operations.some(op => PlaitOperation.isSetViewportOperation(op))) {\n                this.updateViewport();\n            }\n        });\n    }\n\n    ngAfterViewInit(): void {\n        this.plaitBoardInitialized.emit(this.board);\n    }\n\n    initializePlugins() {\n        let board = withSelection(withBoard(createBoard(this.host, this.plaitValue)));\n        this.plaitPlugins.forEach(plugin => {\n            board = plugin(board);\n        });\n        this.board = board;\n        if (this.plaitViewport) {\n            this.board.viewport = this.plaitViewport;\n        }\n    }\n\n    initializeEvents() {\n        fromEvent<MouseEvent>(this.host, 'mousedown')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.mousedown(event);\n            });\n        fromEvent<MouseEvent>(this.host, 'mousemove')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.mousemove(event);\n            });\n        fromEvent<MouseEvent>(document, 'mouseup')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.mouseup(event);\n            });\n        fromEvent<MouseEvent>(this.host, 'dblclick')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.dblclick(event);\n            });\n        fromEvent<WheelEvent>(this.host, 'wheel')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: WheelEvent) => {\n                event.preventDefault();\n                const viewport = this.board.viewport;\n                Transforms.setViewport(this.board, {\n                    ...viewport,\n                    offsetX: viewport?.offsetX - event.deltaX,\n                    offsetY: viewport?.offsetY - event.deltaY\n                });\n            });\n        fromEvent<KeyboardEvent>(document, 'keydown')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => {\n                    return !IS_TEXT_EDITABLE.get(this.board as PlaitBoard);\n                })\n            )\n            .subscribe((event: KeyboardEvent) => {\n                this.board?.keydown(event);\n            });\n        fromEvent<KeyboardEvent>(document, 'keyup')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: KeyboardEvent) => {\n                this.board?.keyup(event);\n            });\n\n        window.onresize = () => {\n            const viewBoxModel = getViewBox(this.board);\n            const viewBoxValues = this.host.getAttribute('viewBox')?.split(',') as string[];\n            this.renderer2.setAttribute(\n                this.host,\n                'viewBox',\n                `${viewBoxValues[0].trim()}, ${viewBoxValues[1].trim()}, ${viewBoxModel.width}, ${viewBoxModel.height}`\n            );\n        };\n    }\n\n    updateViewport() {\n        this.zoom = Math.floor(this.board.viewport.zoom * 100);\n        const viewBox = getViewBox(this.board);\n        this.renderer2.setAttribute(this.host, 'viewBox', `${viewBox.minX}, ${viewBox.minY}, ${viewBox.width}, ${viewBox.height}`);\n    }\n\n    // 放大\n    zoomIn(event: MouseEvent) {\n        const viewport = this.board?.viewport as Viewport;\n        Transforms.setViewport(this.board, {\n            ...viewport,\n            zoom: viewport.zoom + 0.1\n        });\n    }\n\n    // 缩小\n    zoomOut(event: MouseEvent) {\n        const viewport = this.board?.viewport as Viewport;\n        Transforms.setViewport(this.board, {\n            ...viewport,\n            zoom: viewport.zoom - 0.1\n        });\n    }\n\n    resetZoom(event: MouseEvent) {\n        const viewport = this.board?.viewport as Viewport;\n        Transforms.setViewport(this.board, {\n            ...viewport,\n            zoom: 1\n        });\n    }\n\n    trackBy = (index: number, element: PlaitElement) => {\n        return index;\n    };\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n        HOST_TO_ROUGH_SVG.delete(this.host);\n    }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGV0ZWN0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvY29yZS9iYXNlL2RldGVjdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQb2ludCB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvcG9pbnQnO1xuaW1wb3J0IHsgUGxhaXRFbGVtZW50IH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcbmltcG9ydCB7IFNlbGVjdGlvbiB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvc2VsZWN0aW9uJztcblxuZXhwb3J0IGludGVyZmFjZSBCYXNlRGV0ZWN0b3Ige1xuICAgIGNvbnRpYW46IChzZWxlY3Rpb246IFNlbGVjdGlvbiwgZWxlbWVudDogUGxhaXRFbGVtZW50KSA9PiBib29sZWFuOyAvLyDmoYbpgIlcbiAgICBoaXQ6IChwb2ludDogUG9pbnQsIGVsZW1lbnQ6IFBsYWl0RWxlbWVudCkgPT4gYm9vbGVhbjtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { createG } from '../../utils/dom';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class PlaitElementComponent {
|
|
5
|
+
constructor(renderer2, viewContainerRef) {
|
|
6
|
+
this.renderer2 = renderer2;
|
|
7
|
+
this.viewContainerRef = viewContainerRef;
|
|
8
|
+
this.initialized = false;
|
|
9
|
+
this.selection = null;
|
|
10
|
+
}
|
|
11
|
+
ngOnInit() {
|
|
12
|
+
this.initialize();
|
|
13
|
+
this.transform(true);
|
|
14
|
+
this.drawElement();
|
|
15
|
+
}
|
|
16
|
+
initialize() {
|
|
17
|
+
this.initialized = true;
|
|
18
|
+
this.groupG = createG();
|
|
19
|
+
this.renderer2.setAttribute(this.groupG, 'plait-element-group', this.index.toString());
|
|
20
|
+
this.host.append(this.groupG);
|
|
21
|
+
}
|
|
22
|
+
transform(first = false) {
|
|
23
|
+
if (first && this.viewport.offsetX === 0 && this.viewport.offsetY === 0) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
this.renderer2.setAttribute(this.groupG, 'transform', `translate(${this.viewport.offsetX} ${this.viewport.offsetY})`);
|
|
27
|
+
}
|
|
28
|
+
drawElement() {
|
|
29
|
+
const gArray = this.board.drawElement({ elementInstance: this });
|
|
30
|
+
gArray.forEach(g => {
|
|
31
|
+
this.groupG.appendChild(g);
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
ngOnChanges(changes) {
|
|
35
|
+
const viewport = changes['viewport'];
|
|
36
|
+
if (this.initialized && viewport) {
|
|
37
|
+
this.transform();
|
|
38
|
+
}
|
|
39
|
+
if (this.initialized) {
|
|
40
|
+
this.board.redrawElement({ elementInstance: this }, changes);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
ngOnDestroy() {
|
|
44
|
+
this.board.destroyElement();
|
|
45
|
+
this.groupG.remove();
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
PlaitElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: PlaitElementComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
49
|
+
PlaitElementComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: PlaitElementComponent, selector: "plait-element", inputs: { index: "index", element: "element", board: "board", viewport: "viewport", selection: "selection", host: "host" }, usesOnChanges: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
50
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: PlaitElementComponent, decorators: [{
|
|
51
|
+
type: Component,
|
|
52
|
+
args: [{
|
|
53
|
+
selector: 'plait-element',
|
|
54
|
+
template: '',
|
|
55
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
56
|
+
}]
|
|
57
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ViewContainerRef }]; }, propDecorators: { index: [{
|
|
58
|
+
type: Input
|
|
59
|
+
}], element: [{
|
|
60
|
+
type: Input
|
|
61
|
+
}], board: [{
|
|
62
|
+
type: Input
|
|
63
|
+
}], viewport: [{
|
|
64
|
+
type: Input
|
|
65
|
+
}], selection: [{
|
|
66
|
+
type: Input
|
|
67
|
+
}], host: [{
|
|
68
|
+
type: Input
|
|
69
|
+
}] } });
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvY29yZS9lbGVtZW50L2VsZW1lbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULEtBQUssRUFPUixNQUFNLGVBQWUsQ0FBQztBQUl2QixPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBUTFDLE1BQU0sT0FBTyxxQkFBcUI7SUFpQjlCLFlBQW1CLFNBQW9CLEVBQVMsZ0JBQWtDO1FBQS9ELGNBQVMsR0FBVCxTQUFTLENBQVc7UUFBUyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBaEJsRixnQkFBVyxHQUFHLEtBQUssQ0FBQztRQVlYLGNBQVMsR0FBcUIsSUFBSSxDQUFDO0lBSXlDLENBQUM7SUFFdEYsUUFBUTtRQUNKLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUNsQixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRUQsVUFBVTtRQUNOLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxNQUFNLEdBQUcsT0FBTyxFQUFFLENBQUM7UUFDeEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxxQkFBcUIsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7UUFDdkYsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFFRCxTQUFTLENBQUMsS0FBSyxHQUFHLEtBQUs7UUFDbkIsSUFBSSxLQUFLLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLEtBQUssQ0FBQyxJQUFJLElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxLQUFLLENBQUMsRUFBRTtZQUNyRSxPQUFPO1NBQ1Y7UUFDRCxJQUFJLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLFdBQVcsRUFBRSxhQUFhLElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxHQUFHLENBQUMsQ0FBQztJQUMxSCxDQUFDO0lBRUQsV0FBVztRQUNQLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLEVBQUUsZUFBZSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7UUFDakUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUNmLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQy9CLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUM5QixNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDckMsSUFBSSxJQUFJLENBQUMsV0FBVyxJQUFJLFFBQVEsRUFBRTtZQUM5QixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7U0FDcEI7UUFDRCxJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUU7WUFDbEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxhQUFhLENBQUMsRUFBRSxlQUFlLEVBQUUsSUFBSSxFQUFFLEVBQUUsT0FBTyxDQUFDLENBQUM7U0FDaEU7SUFDTCxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksQ0FBQyxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDNUIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUN6QixDQUFDOzttSEEzRFEscUJBQXFCO3VHQUFyQixxQkFBcUIsc01BSHBCLEVBQUU7NEZBR0gscUJBQXFCO2tCQUxqQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxlQUFlO29CQUN6QixRQUFRLEVBQUUsRUFBRTtvQkFDWixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDbEQ7K0hBTVksS0FBSztzQkFBYixLQUFLO2dCQUVHLE9BQU87c0JBQWYsS0FBSztnQkFFRyxLQUFLO3NCQUFiLEtBQUs7Z0JBRUcsUUFBUTtzQkFBaEIsS0FBSztnQkFFRyxTQUFTO3NCQUFqQixLQUFLO2dCQUVHLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIElucHV0LFxuICAgIE9uQ2hhbmdlcyxcbiAgICBPbkRlc3Ryb3ksXG4gICAgT25Jbml0LFxuICAgIFJlbmRlcmVyMixcbiAgICBTaW1wbGVDaGFuZ2VzLFxuICAgIFZpZXdDb250YWluZXJSZWZcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQbGFpdEVsZW1lbnQgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL2VsZW1lbnQnO1xuaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvYm9hcmQnO1xuaW1wb3J0IHsgU2VsZWN0aW9uIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9zZWxlY3Rpb24nO1xuaW1wb3J0IHsgY3JlYXRlRyB9IGZyb20gJy4uLy4uL3V0aWxzL2RvbSc7XG5pbXBvcnQgeyBWaWV3cG9ydCB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvdmlld3BvcnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3BsYWl0LWVsZW1lbnQnLFxuICAgIHRlbXBsYXRlOiAnJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBQbGFpdEVsZW1lbnRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcywgT25EZXN0cm95IHtcbiAgICBpbml0aWFsaXplZCA9IGZhbHNlO1xuXG4gICAgZ3JvdXBHITogU1ZHR0VsZW1lbnQ7XG5cbiAgICBASW5wdXQoKSBpbmRleCE6IG51bWJlcjtcblxuICAgIEBJbnB1dCgpIGVsZW1lbnQhOiBQbGFpdEVsZW1lbnQ7XG5cbiAgICBASW5wdXQoKSBib2FyZCE6IFBsYWl0Qm9hcmQ7XG5cbiAgICBASW5wdXQoKSB2aWV3cG9ydCE6IFZpZXdwb3J0O1xuXG4gICAgQElucHV0KCkgc2VsZWN0aW9uOiBTZWxlY3Rpb24gfCBudWxsID0gbnVsbDtcblxuICAgIEBJbnB1dCgpIGhvc3QhOiBTVkdFbGVtZW50O1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIHJlbmRlcmVyMjogUmVuZGVyZXIyLCBwdWJsaWMgdmlld0NvbnRhaW5lclJlZjogVmlld0NvbnRhaW5lclJlZikge31cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmluaXRpYWxpemUoKTtcbiAgICAgICAgdGhpcy50cmFuc2Zvcm0odHJ1ZSk7XG4gICAgICAgIHRoaXMuZHJhd0VsZW1lbnQoKTtcbiAgICB9XG5cbiAgICBpbml0aWFsaXplKCkge1xuICAgICAgICB0aGlzLmluaXRpYWxpemVkID0gdHJ1ZTtcbiAgICAgICAgdGhpcy5ncm91cEcgPSBjcmVhdGVHKCk7XG4gICAgICAgIHRoaXMucmVuZGVyZXIyLnNldEF0dHJpYnV0ZSh0aGlzLmdyb3VwRywgJ3BsYWl0LWVsZW1lbnQtZ3JvdXAnLCB0aGlzLmluZGV4LnRvU3RyaW5nKCkpO1xuICAgICAgICB0aGlzLmhvc3QuYXBwZW5kKHRoaXMuZ3JvdXBHKTtcbiAgICB9XG5cbiAgICB0cmFuc2Zvcm0oZmlyc3QgPSBmYWxzZSkge1xuICAgICAgICBpZiAoZmlyc3QgJiYgdGhpcy52aWV3cG9ydC5vZmZzZXRYID09PSAwICYmIHRoaXMudmlld3BvcnQub2Zmc2V0WSA9PT0gMCkge1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMucmVuZGVyZXIyLnNldEF0dHJpYnV0ZSh0aGlzLmdyb3VwRywgJ3RyYW5zZm9ybScsIGB0cmFuc2xhdGUoJHt0aGlzLnZpZXdwb3J0Lm9mZnNldFh9ICR7dGhpcy52aWV3cG9ydC5vZmZzZXRZfSlgKTtcbiAgICB9XG5cbiAgICBkcmF3RWxlbWVudCgpIHtcbiAgICAgICAgY29uc3QgZ0FycmF5ID0gdGhpcy5ib2FyZC5kcmF3RWxlbWVudCh7IGVsZW1lbnRJbnN0YW5jZTogdGhpcyB9KTtcbiAgICAgICAgZ0FycmF5LmZvckVhY2goZyA9PiB7XG4gICAgICAgICAgICB0aGlzLmdyb3VwRy5hcHBlbmRDaGlsZChnKTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuICAgICAgICBjb25zdCB2aWV3cG9ydCA9IGNoYW5nZXNbJ3ZpZXdwb3J0J107XG4gICAgICAgIGlmICh0aGlzLmluaXRpYWxpemVkICYmIHZpZXdwb3J0KSB7XG4gICAgICAgICAgICB0aGlzLnRyYW5zZm9ybSgpO1xuICAgICAgICB9XG4gICAgICAgIGlmICh0aGlzLmluaXRpYWxpemVkKSB7XG4gICAgICAgICAgICB0aGlzLmJvYXJkLnJlZHJhd0VsZW1lbnQoeyBlbGVtZW50SW5zdGFuY2U6IHRoaXMgfSwgY2hhbmdlcyk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5ib2FyZC5kZXN0cm95RWxlbWVudCgpO1xuICAgICAgICB0aGlzLmdyb3VwRy5yZW1vdmUoKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9hcmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvaW50ZXJmYWNlcy9ib2FyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ3Vyc29yU3RhdHVzIH0gZnJvbSAnLi9jdXJzb3InO1xuaW1wb3J0IHsgUGxhaXRFbGVtZW50IH0gZnJvbSAnLi9lbGVtZW50JztcbmltcG9ydCB7IFBsYWl0RWxlbWVudENvbnRleHQgfSBmcm9tICcuL2VsZW1lbnQtY29udGV4dCc7XG5pbXBvcnQgeyBQbGFpdE9wZXJhdGlvbiB9IGZyb20gJy4vb3BlcmF0aW9uJztcbmltcG9ydCB7IFNlbGVjdGlvbiB9IGZyb20gJy4vc2VsZWN0aW9uJztcbmltcG9ydCB7IFZpZXdwb3J0IH0gZnJvbSAnLi92aWV3cG9ydCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRCb2FyZCB7XG4gICAgaG9zdDogU1ZHRWxlbWVudDtcbiAgICB2aWV3cG9ydDogVmlld3BvcnQ7XG4gICAgY2hpbGRyZW46IFBsYWl0RWxlbWVudFtdO1xuICAgIG9wZXJhdGlvbnM6IFBsYWl0T3BlcmF0aW9uW107XG4gICAgc2VsZWN0aW9uOiBTZWxlY3Rpb24gfCBudWxsO1xuICAgIGN1cnNvcjogQ3Vyc29yU3RhdHVzO1xuICAgIGFwcGx5OiAob3BlcmF0aW9uOiBQbGFpdE9wZXJhdGlvbikgPT4gdm9pZDtcbiAgICBvbkNoYW5nZTogKCkgPT4gdm9pZDtcbiAgICBtb3VzZWRvd246IChldmVudDogTW91c2VFdmVudCkgPT4gdm9pZDtcbiAgICBtb3VzZXVwOiAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHZvaWQ7XG4gICAgbW91c2Vtb3ZlOiAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHZvaWQ7XG4gICAga2V5ZG93bjogKGV2ZW50OiBLZXlib2FyZEV2ZW50KSA9PiB2b2lkO1xuICAgIGtleXVwOiAoZXZlbnQ6IEtleWJvYXJkRXZlbnQpID0+IHZvaWQ7XG4gICAgZGJsY2xpY2s6IChldmVudDogTW91c2VFdmVudCkgPT4gdm9pZDtcbiAgICBkcmF3RWxlbWVudDogKGNvbnRleHQ6IFBsYWl0RWxlbWVudENvbnRleHQpID0+IFNWR0dFbGVtZW50W107XG4gICAgcmVkcmF3RWxlbWVudDogKGNvbnRleHQ6IFBsYWl0RWxlbWVudENvbnRleHQsIGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpID0+IFNWR0dFbGVtZW50W107XG4gICAgZGVzdHJveUVsZW1lbnQ6ICgpID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRCb2FyZENoYW5nZUV2ZW50IHtcbiAgICBjaGlsZHJlbjogUGxhaXRFbGVtZW50W107XG4gICAgb3BlcmF0aW9uczogUGxhaXRPcGVyYXRpb25bXTtcbiAgICB2aWV3cG9ydDogVmlld3BvcnQ7XG4gICAgc2VsZWN0aW9uOiBTZWxlY3Rpb24gfCBudWxsO1xufSJdfQ==
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export var BaseCursorStatus;
|
|
2
|
+
(function (BaseCursorStatus) {
|
|
3
|
+
BaseCursorStatus["move"] = "move";
|
|
4
|
+
BaseCursorStatus["select"] = "select";
|
|
5
|
+
})(BaseCursorStatus || (BaseCursorStatus = {}));
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3Vyc29yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL2ludGVyZmFjZXMvY3Vyc29yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE1BQU0sQ0FBTixJQUFZLGdCQUdYO0FBSEQsV0FBWSxnQkFBZ0I7SUFDeEIsaUNBQWUsQ0FBQTtJQUNmLHFDQUFtQixDQUFBO0FBQ3ZCLENBQUMsRUFIVyxnQkFBZ0IsS0FBaEIsZ0JBQWdCLFFBRzNCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgQ3Vyc29yU3RhdHVzID0gQmFzZUN1cnNvclN0YXR1cyB8IHN0cmluZztcbmV4cG9ydCBlbnVtIEJhc2VDdXJzb3JTdGF0dXMge1xuICAgICdtb3ZlJyA9ICdtb3ZlJyxcbiAgICAnc2VsZWN0JyA9ICdzZWxlY3QnXG59XG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Extendable Custom Types Interface
|
|
3
|
+
*/
|
|
4
|
+
export {};
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL2ludGVyZmFjZXMvY3VzdG9tLXR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlbmRhYmxlIEN1c3RvbSBUeXBlcyBJbnRlcmZhY2VcbiAqL1xuXG50eXBlIEV4dGVuZGFibGVUeXBlcyA9ICdWaWV3cG9ydCcgfCAnU2V0Vmlld3BvcnRPcGVyYXRpb24nIHwgJ1NldFNlbGVjdGlvbk9wZXJhdGlvbic7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ3VzdG9tVHlwZXMge1xuICAgIFtrZXk6IHN0cmluZ106IHVua25vd247XG59XG5cbmV4cG9ydCB0eXBlIEV4dGVuZGVkVHlwZTxLIGV4dGVuZHMgRXh0ZW5kYWJsZVR5cGVzLCBCPiA9IHVua25vd24gZXh0ZW5kcyBDdXN0b21UeXBlc1tLXSA/IEIgOiBDdXN0b21UeXBlc1tLXTtcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC1jb250ZXh0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL2ludGVyZmFjZXMvZWxlbWVudC1jb250ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEVsZW1lbnRDb21wb25lbnQgfSBmcm9tICcuLi9jb3JlL2VsZW1lbnQvZWxlbWVudC5jb21wb25lbnQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBsYWl0RWxlbWVudENvbnRleHQge1xuICAgIGVsZW1lbnRJbnN0YW5jZTogUGxhaXRFbGVtZW50Q29tcG9uZW50O1xufVxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy9pbnRlcmZhY2VzL2VsZW1lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Tm9kZSB9IGZyb20gJy4vbm9kZSc7XG5pbXBvcnQgeyBQb2ludCB9IGZyb20gJy4vcG9pbnQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBsYWl0RWxlbWVudCBleHRlbmRzIFBsYWl0Tm9kZSB7XG4gICAgcG9pbnRzOiBQb2ludFtdO1xuICAgIHR5cGU6IHN0cmluZztcbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvaW50ZXJmYWNlcy9ncmFwaC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBSZWN0YW5nbGVDbGllbnQge1xuICAgIHg6IG51bWJlcjtcbiAgICB5OiBudW1iZXI7XG4gICAgd2lkdGg6IG51bWJlcjtcbiAgICBoZWlnaHQ6IG51bWJlcjtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export * from './board';
|
|
2
|
+
export * from './cursor';
|
|
3
|
+
export * from './element-context';
|
|
4
|
+
export * from './custom-types';
|
|
5
|
+
export * from './element';
|
|
6
|
+
export * from './graph';
|
|
7
|
+
export * from './node';
|
|
8
|
+
export * from './operation';
|
|
9
|
+
export * from './path';
|
|
10
|
+
export * from './plugin';
|
|
11
|
+
export * from './point';
|
|
12
|
+
export * from './selection';
|
|
13
|
+
export * from './viewport';
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvaW50ZXJmYWNlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2JvYXJkJztcbmV4cG9ydCAqIGZyb20gJy4vY3Vyc29yJztcbmV4cG9ydCAqIGZyb20gJy4vZWxlbWVudC1jb250ZXh0JztcbmV4cG9ydCAqIGZyb20gJy4vY3VzdG9tLXR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vZWxlbWVudCc7XG5leHBvcnQgKiBmcm9tICcuL2dyYXBoJztcbmV4cG9ydCAqIGZyb20gJy4vbm9kZSc7XG5leHBvcnQgKiBmcm9tICcuL29wZXJhdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3BhdGgnO1xuZXhwb3J0ICogZnJvbSAnLi9wbHVnaW4nO1xuZXhwb3J0ICogZnJvbSAnLi9wb2ludCc7XG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3ZpZXdwb3J0JzsiXX0=
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Path } from './path';
|
|
2
|
+
export const PlaitNode = {
|
|
3
|
+
parent: (board, path) => {
|
|
4
|
+
const parentPath = Path.parent(path);
|
|
5
|
+
const p = PlaitNode.get(board, parentPath);
|
|
6
|
+
return p;
|
|
7
|
+
},
|
|
8
|
+
get(board, path) {
|
|
9
|
+
let node = board;
|
|
10
|
+
for (let i = 0; i < path.length; i++) {
|
|
11
|
+
const p = path[i];
|
|
12
|
+
if (!node || !node.children || !node.children[p]) {
|
|
13
|
+
throw new Error(`Cannot find a descendant at path [${path}]`);
|
|
14
|
+
}
|
|
15
|
+
node = node.children[p];
|
|
16
|
+
}
|
|
17
|
+
return node;
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy9pbnRlcmZhY2VzL25vZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLFFBQVEsQ0FBQztBQWU5QixNQUFNLENBQUMsTUFBTSxTQUFTLEdBQXVCO0lBQ3pDLE1BQU0sRUFBRSxDQUFDLEtBQWlCLEVBQUUsSUFBVSxFQUFFLEVBQUU7UUFDdEMsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNyQyxNQUFNLENBQUMsR0FBRyxTQUFTLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxVQUFVLENBQUMsQ0FBQztRQUMzQyxPQUFPLENBQUMsQ0FBQztJQUNiLENBQUM7SUFDRCxHQUFHLENBQUMsS0FBaUIsRUFBRSxJQUFVO1FBQzdCLElBQUksSUFBSSxHQUEyQixLQUFLLENBQUM7UUFFekMsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7WUFDbEMsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBRWxCLElBQUksQ0FBQyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsRUFBRTtnQkFDOUMsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQ0FBcUMsSUFBSSxHQUFHLENBQUMsQ0FBQzthQUNqRTtZQUVELElBQUksR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQzNCO1FBRUQsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQztDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnLi9ib2FyZCc7XG5pbXBvcnQgeyBQYXRoIH0gZnJvbSAnLi9wYXRoJztcblxuZXhwb3J0IGludGVyZmFjZSBQbGFpdE5vZGUge1xuICAgIFtrZXk6IHN0cmluZ106IGFueTtcbiAgICBjaGlsZHJlbj86IFBsYWl0Tm9kZVtdO1xuICAgIGlkPzogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBBbmNlc3RvciA9IFBsYWl0Qm9hcmQgfCBQbGFpdE5vZGU7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXROb2RlSW50ZXJmYWNlIHtcbiAgICBwYXJlbnQ6IChib2FyZDogUGxhaXRCb2FyZCwgcGF0aDogUGF0aCkgPT4gQW5jZXN0b3I7XG4gICAgZ2V0OiAoYm9hcmQ6IFBsYWl0Qm9hcmQsIHBhdGg6IFBhdGgpID0+IFBsYWl0Tm9kZTtcbn1cblxuZXhwb3J0IGNvbnN0IFBsYWl0Tm9kZTogUGxhaXROb2RlSW50ZXJmYWNlID0ge1xuICAgIHBhcmVudDogKGJvYXJkOiBQbGFpdEJvYXJkLCBwYXRoOiBQYXRoKSA9PiB7XG4gICAgICAgIGNvbnN0IHBhcmVudFBhdGggPSBQYXRoLnBhcmVudChwYXRoKTtcbiAgICAgICAgY29uc3QgcCA9IFBsYWl0Tm9kZS5nZXQoYm9hcmQsIHBhcmVudFBhdGgpO1xuICAgICAgICByZXR1cm4gcDtcbiAgICB9LFxuICAgIGdldChib2FyZDogUGxhaXRCb2FyZCwgcGF0aDogUGF0aCk6IEFuY2VzdG9yIHtcbiAgICAgICAgbGV0IG5vZGU6IFBsYWl0Qm9hcmQgfCBQbGFpdE5vZGUgPSBib2FyZDtcblxuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHBhdGgubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgICAgIGNvbnN0IHAgPSBwYXRoW2ldO1xuXG4gICAgICAgICAgICBpZiAoIW5vZGUgfHwgIW5vZGUuY2hpbGRyZW4gfHwgIW5vZGUuY2hpbGRyZW5bcF0pIHtcbiAgICAgICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYENhbm5vdCBmaW5kIGEgZGVzY2VuZGFudCBhdCBwYXRoIFske3BhdGh9XWApO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBub2RlID0gbm9kZS5jaGlsZHJlbltwXTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBub2RlO1xuICAgIH1cbn07XG4iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export const isSetViewportOperation = (value) => {
|
|
2
|
+
return value.type === 'set_viewport';
|
|
3
|
+
};
|
|
4
|
+
export const PlaitOperation = {
|
|
5
|
+
isSetViewportOperation
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3BlcmF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL2ludGVyZmFjZXMvb3BlcmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJDQSxNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRyxDQUFDLEtBQVUsRUFBaUMsRUFBRTtJQUNoRixPQUFPLEtBQUssQ0FBQyxJQUFJLEtBQUssY0FBYyxDQUFDO0FBQ3pDLENBQUMsQ0FBQztBQUdGLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUMxQixzQkFBc0I7Q0FDekIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Tm9kZSB9IGZyb20gJy4vbm9kZSc7XG5pbXBvcnQgeyBQYXRoIH0gZnJvbSAnLi9wYXRoJztcbmltcG9ydCB7IFNlbGVjdGlvbiB9IGZyb20gJy4vc2VsZWN0aW9uJztcbmltcG9ydCB7IFZpZXdwb3J0IH0gZnJvbSAnLi92aWV3cG9ydCc7XG5cbmV4cG9ydCB0eXBlIEluc2VydE5vZGVPcGVyYXRpb24gPSB7XG4gICAgdHlwZTogJ2luc2VydF9ub2RlJztcbiAgICBwYXRoOiBQYXRoO1xuICAgIG5vZGU6IFBsYWl0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFJlbW92ZU5vZGVPcGVyYXRpb24gPSB7XG4gICAgdHlwZTogJ3JlbW92ZV9ub2RlJztcbiAgICBwYXRoOiBQYXRoO1xufTtcblxuZXhwb3J0IHR5cGUgTW92ZU5vZGVPcGVyYXRpb24gPSB7XG4gICAgdHlwZTogJ21vdmVfbm9kZSc7XG4gICAgcGF0aDogUGF0aDtcbiAgICBuZXdQYXRoOiBQYXRoO1xufTtcblxuZXhwb3J0IHR5cGUgU2V0Vmlld3BvcnRPcGVyYXRpb24gPSB7XG4gICAgdHlwZTogJ3NldF92aWV3cG9ydCc7XG4gICAgcHJvcGVydGllczogUGFydGlhbDxWaWV3cG9ydD47XG4gICAgbmV3UHJvcGVydGllczogUGFydGlhbDxWaWV3cG9ydD47XG59O1xuXG5leHBvcnQgdHlwZSBTZXRTZWxlY3Rpb25PcGVyYXRpb24gPSB7XG4gICAgdHlwZTogJ3NldF9zZWxlY3Rpb24nO1xuICAgIHByb3BlcnRpZXM6IFNlbGVjdGlvbiB8IG51bGw7XG4gICAgbmV3UHJvcGVydGllczogU2VsZWN0aW9uIHwgbnVsbDtcbn07XG5cbmV4cG9ydCB0eXBlIFNldE5vZGVPcGVyYXRpb24gPSB7XG4gICAgdHlwZTogJ3NldF9ub2RlJztcbiAgICBwYXRoOiBQYXRoO1xuICAgIHByb3BlcnRpZXM6IFBhcnRpYWw8UGxhaXROb2RlPjtcbiAgICBuZXdQcm9wZXJ0aWVzOiBQYXJ0aWFsPFBsYWl0Tm9kZT47XG59O1xuXG5leHBvcnQgdHlwZSBQbGFpdE9wZXJhdGlvbiA9IEluc2VydE5vZGVPcGVyYXRpb24gfCBTZXRWaWV3cG9ydE9wZXJhdGlvbiB8IFNldFNlbGVjdGlvbk9wZXJhdGlvbiB8IFNldE5vZGVPcGVyYXRpb24gfCBSZW1vdmVOb2RlT3BlcmF0aW9uIHwgTW92ZU5vZGVPcGVyYXRpb247XG5cbmV4cG9ydCBjb25zdCBpc1NldFZpZXdwb3J0T3BlcmF0aW9uID0gKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBTZXRWaWV3cG9ydE9wZXJhdGlvbiA9PiB7XG4gICAgcmV0dXJuIHZhbHVlLnR5cGUgPT09ICdzZXRfdmlld3BvcnQnO1xufTtcblxuXG5leHBvcnQgY29uc3QgUGxhaXRPcGVyYXRpb24gPSB7XG4gICAgaXNTZXRWaWV3cG9ydE9wZXJhdGlvblxufTsiXX0=
|