@plait/core 0.0.25 → 0.0.28
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 +4 -3
- package/esm2020/board/board.component.mjs +15 -9
- package/esm2020/utils/history.mjs +2 -2
- package/fesm2015/plait-core.mjs +178 -172
- package/fesm2015/plait-core.mjs.map +1 -1
- package/fesm2020/plait-core.mjs +197 -191
- package/fesm2020/plait-core.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, OnDestroy, OnInit, Renderer2 } from '@angular/core';
|
|
2
|
-
import {
|
|
3
|
-
import { PlaitElement } from '../interfaces/element';
|
|
2
|
+
import { RoughSVG } from 'roughjs/bin/svg';
|
|
4
3
|
import { Subject } from 'rxjs';
|
|
4
|
+
import { PlaitBoard, PlaitBoardChangeEvent } from '../interfaces/board';
|
|
5
|
+
import { PlaitElement } from '../interfaces/element';
|
|
5
6
|
import { PlaitPlugin } from '../interfaces/plugin';
|
|
6
|
-
import { RoughSVG } from 'roughjs/bin/svg';
|
|
7
7
|
import { Viewport } from '../interfaces/viewport';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
export declare class PlaitBoardComponent implements OnInit, AfterViewInit, OnDestroy {
|
|
@@ -24,6 +24,7 @@ export declare class PlaitBoardComponent implements OnInit, AfterViewInit, OnDes
|
|
|
24
24
|
plaitAllowClearBoard: boolean;
|
|
25
25
|
plaitChange: EventEmitter<PlaitBoardChangeEvent>;
|
|
26
26
|
plaitBoardInitialized: EventEmitter<PlaitBoard>;
|
|
27
|
+
get focused(): import("@plait/core").Selection | null;
|
|
27
28
|
constructor(cdr: ChangeDetectorRef, renderer2: Renderer2);
|
|
28
29
|
ngOnInit(): void;
|
|
29
30
|
ngAfterViewInit(): void;
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
-
import
|
|
3
|
-
import { createBoard } from '../plugins/create-board';
|
|
4
|
-
import { withBoard } from '../plugins/with-board';
|
|
2
|
+
import rough from 'roughjs/bin/rough';
|
|
5
3
|
import { fromEvent, Subject } from 'rxjs';
|
|
6
4
|
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
5
|
import { PlaitOperation } from '../interfaces/operation';
|
|
11
|
-
import {
|
|
6
|
+
import { createBoard } from '../plugins/create-board';
|
|
7
|
+
import { withBoard } from '../plugins/with-board';
|
|
12
8
|
import { withHistroy } from '../plugins/with-history';
|
|
9
|
+
import { withSelection } from '../plugins/with-selection';
|
|
10
|
+
import { Transforms } from '../transfroms';
|
|
11
|
+
import { getViewBox } from '../utils/board';
|
|
12
|
+
import { BOARD_TO_ON_CHANGE, HOST_TO_ROUGH_SVG, IS_TEXT_EDITABLE } from '../utils/weak-maps';
|
|
13
13
|
import * as i0 from "@angular/core";
|
|
14
14
|
import * as i1 from "../core/element/element.component";
|
|
15
15
|
import * as i2 from "@angular/common";
|
|
@@ -36,6 +36,9 @@ export class PlaitBoardComponent {
|
|
|
36
36
|
get isFocused() {
|
|
37
37
|
return this.board?.selection;
|
|
38
38
|
}
|
|
39
|
+
get focused() {
|
|
40
|
+
return this.isFocused;
|
|
41
|
+
}
|
|
39
42
|
ngOnInit() {
|
|
40
43
|
const roughSVG = rough.svg(this.host, { options: { roughness: 0, strokeWidth: 1 } });
|
|
41
44
|
HOST_TO_ROUGH_SVG.set(this.host, roughSVG);
|
|
@@ -187,7 +190,7 @@ export class PlaitBoardComponent {
|
|
|
187
190
|
}
|
|
188
191
|
}
|
|
189
192
|
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 });
|
|
190
|
-
PlaitBoardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: PlaitBoardComponent, selector: "plait-board", inputs: { plaitValue: "plaitValue", plaitViewport: "plaitViewport", plaitPlugins: "plaitPlugins", plaitReadonly: "plaitReadonly", plaitAllowClearBoard: "plaitAllowClearBoard" }, outputs: { plaitChange: "plaitChange", plaitBoardInitialized: "plaitBoardInitialized" }, host: { properties: { "class": "this.hostClass" } }, viewQueries: [{ propertyName: "svg", first: true, predicate: ["svg"], descendants: true, static: true }], ngImport: i0, template: `
|
|
193
|
+
PlaitBoardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: PlaitBoardComponent, selector: "plait-board", inputs: { plaitValue: "plaitValue", plaitViewport: "plaitViewport", plaitPlugins: "plaitPlugins", plaitReadonly: "plaitReadonly", plaitAllowClearBoard: "plaitAllowClearBoard" }, outputs: { plaitChange: "plaitChange", plaitBoardInitialized: "plaitBoardInitialized" }, host: { properties: { "class": "this.hostClass", "class.focused": "this.focused" } }, viewQueries: [{ propertyName: "svg", first: true, predicate: ["svg"], descendants: true, static: true }], ngImport: i0, template: `
|
|
191
194
|
<svg #svg width="100%" height="100%" style="position: relative"></svg>
|
|
192
195
|
<div *ngIf="isFocused" class="plait-toolbar island zoom-toolbar plait-board-attached">
|
|
193
196
|
<button class="item" (mousedown)="zoomOut($event)">-</button>
|
|
@@ -249,5 +252,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
249
252
|
type: Output
|
|
250
253
|
}], plaitBoardInitialized: [{
|
|
251
254
|
type: Output
|
|
255
|
+
}], focused: [{
|
|
256
|
+
type: HostBinding,
|
|
257
|
+
args: ['class.focused']
|
|
252
258
|
}] } });
|
|
253
|
-
//# 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, PlaitBoardOptions } 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, isNoSelectionElement } from '../utils/board';\nimport { Viewport } from '../interfaces/viewport';\nimport { withHistroy } from '../plugins/with-history';\n\n@Component({\n    selector: 'plait-board',\n    template: `\n        <svg #svg width=\"100%\" height=\"100%\" style=\"position: relative\"></svg>\n        <div *ngIf=\"isFocused\" class=\"plait-toolbar island zoom-toolbar plait-board-attached\">\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    get isFocused() {\n        return this.board?.selection;\n    }\n\n    @Input() plaitValue: PlaitElement[] = [];\n\n    @Input() plaitViewport!: Viewport;\n\n    @Input() plaitPlugins: PlaitPlugin[] = [];\n\n    @Input() plaitReadonly = false;\n\n    @Input() plaitAllowClearBoard = false;\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            // update viewBox\n            if (this.board.operations.some(op => PlaitOperation.isSetViewportOperation(op))) {\n                this.updateViewport();\n            }\n            this.plaitChange.emit(changeEvent);\n        });\n    }\n\n    ngAfterViewInit(): void {\n        this.plaitBoardInitialized.emit(this.board);\n    }\n\n    initializePlugins() {\n        const options: PlaitBoardOptions = { readonly: this.plaitReadonly, allowClearBoard: this.plaitAllowClearBoard };\n        let board = withHistroy(withSelection(withBoard(createBoard(this.host, this.plaitValue, options))));\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\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, '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(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.dblclick(event);\n            });\n\n        fromEvent<WheelEvent>(this.host, 'wheel')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: WheelEvent) => {\n                if (this.isFocused) {\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            });\n\n        fromEvent<KeyboardEvent>(document, 'keydown')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => {\n                    return !IS_TEXT_EDITABLE.get(this.board) && !!this.board.selection;\n                })\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(() => {\n                    return !IS_TEXT_EDITABLE.get(this.board) && !!this.board.selection;\n                })\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(() => {\n                    return !IS_TEXT_EDITABLE.get(this.board) && !!this.board.selection;\n                })\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(() => {\n                    return !IS_TEXT_EDITABLE.get(this.board) && !!this.board.selection;\n                })\n            )\n            .subscribe((event: ClipboardEvent) => {\n                this.board?.insertFragment(event.clipboardData);\n            });\n\n        fromEvent<ClipboardEvent>(document, 'cut')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => {\n                    return !IS_TEXT_EDITABLE.get(this.board) && !!this.board.selection;\n                })\n            )\n            .subscribe((event: ClipboardEvent) => {\n                event.preventDefault();\n                this.board?.setFragment(event.clipboardData);\n                this.board?.deleteFragment(event.clipboardData);\n            });\n\n        window.onresize = () => {\n            this.refreshViewport();\n        };\n    }\n\n    refreshViewport() {\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    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"]}
|
|
259
|
+
//# 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 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 { PlaitOperation } from '../interfaces/operation';\nimport { PlaitPlugin } from '../interfaces/plugin';\nimport { Viewport } from '../interfaces/viewport';\nimport { createBoard } from '../plugins/create-board';\nimport { withBoard } from '../plugins/with-board';\nimport { withHistroy } from '../plugins/with-history';\nimport { withSelection } from '../plugins/with-selection';\nimport { Transforms } from '../transfroms';\nimport { getViewBox } from '../utils/board';\nimport { BOARD_TO_ON_CHANGE, HOST_TO_ROUGH_SVG, IS_TEXT_EDITABLE } from '../utils/weak-maps';\n\n@Component({\n    selector: 'plait-board',\n    template: `\n        <svg #svg width=\"100%\" height=\"100%\" style=\"position: relative\"></svg>\n        <div *ngIf=\"isFocused\" class=\"plait-toolbar island zoom-toolbar plait-board-attached\">\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    get isFocused() {\n        return this.board?.selection;\n    }\n\n    @Input() plaitValue: PlaitElement[] = [];\n\n    @Input() plaitViewport!: Viewport;\n\n    @Input() plaitPlugins: PlaitPlugin[] = [];\n\n    @Input() plaitReadonly = false;\n\n    @Input() plaitAllowClearBoard = false;\n\n    @Output() plaitChange: EventEmitter<PlaitBoardChangeEvent> = new EventEmitter();\n\n    @Output() plaitBoardInitialized: EventEmitter<PlaitBoard> = new EventEmitter();\n\n    @HostBinding('class.focused')\n    get focused() {\n        return this.isFocused;\n    }\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            // update viewBox\n            if (this.board.operations.some(op => PlaitOperation.isSetViewportOperation(op))) {\n                this.updateViewport();\n            }\n            this.plaitChange.emit(changeEvent);\n        });\n    }\n\n    ngAfterViewInit(): void {\n        this.plaitBoardInitialized.emit(this.board);\n    }\n\n    initializePlugins() {\n        const options: PlaitBoardOptions = { readonly: this.plaitReadonly, allowClearBoard: this.plaitAllowClearBoard };\n        let board = withHistroy(withSelection(withBoard(createBoard(this.host, this.plaitValue, options))));\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\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, '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(takeUntil(this.destroy$))\n            .subscribe((event: MouseEvent) => {\n                this.board.dblclick(event);\n            });\n\n        fromEvent<WheelEvent>(this.host, 'wheel')\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((event: WheelEvent) => {\n                if (this.isFocused) {\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            });\n\n        fromEvent<KeyboardEvent>(document, 'keydown')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => {\n                    return !IS_TEXT_EDITABLE.get(this.board) && !!this.board.selection;\n                })\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(() => {\n                    return !IS_TEXT_EDITABLE.get(this.board) && !!this.board.selection;\n                })\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(() => {\n                    return !IS_TEXT_EDITABLE.get(this.board) && !!this.board.selection;\n                })\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(() => {\n                    return !IS_TEXT_EDITABLE.get(this.board) && !!this.board.selection;\n                })\n            )\n            .subscribe((event: ClipboardEvent) => {\n                this.board?.insertFragment(event.clipboardData);\n            });\n\n        fromEvent<ClipboardEvent>(document, 'cut')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter(() => {\n                    return !IS_TEXT_EDITABLE.get(this.board) && !!this.board.selection;\n                })\n            )\n            .subscribe((event: ClipboardEvent) => {\n                event.preventDefault();\n                this.board?.setFragment(event.clipboardData);\n                this.board?.deleteFragment(event.clipboardData);\n            });\n\n        window.onresize = () => {\n            this.refreshViewport();\n        };\n    }\n\n    refreshViewport() {\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    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"]}
|
|
@@ -12,7 +12,7 @@ export const shouldMerge = (op, prev) => {
|
|
|
12
12
|
* Check whether an operation needs to be saved to the history.
|
|
13
13
|
*/
|
|
14
14
|
export const shouldSave = (op, prev) => {
|
|
15
|
-
if (op.type === 'set_selection') {
|
|
15
|
+
if (op.type === 'set_selection' || op.type === 'set_viewport') {
|
|
16
16
|
return false;
|
|
17
17
|
}
|
|
18
18
|
return true;
|
|
@@ -60,4 +60,4 @@ export const PlaitHistoryBoard = {
|
|
|
60
60
|
SAVING.set(board, prev);
|
|
61
61
|
}
|
|
62
62
|
};
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGlzdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy91dGlscy9oaXN0b3J5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQThCLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU1RTs7R0FFRztBQUVILE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxDQUFDLEVBQWtCLEVBQUUsSUFBZ0MsRUFBVyxFQUFFO0lBQ3pGLElBQUksRUFBRSxDQUFDLElBQUksS0FBSyxjQUFjLElBQUksRUFBRSxDQUFDLElBQUksS0FBSyxJQUFJLEVBQUUsSUFBSSxFQUFFO1FBQ3RELE9BQU8sSUFBSSxDQUFDO0tBQ2Y7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDLENBQUM7QUFFRjs7R0FFRztBQUVILE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRyxDQUFDLEVBQWtCLEVBQUUsSUFBZ0MsRUFBVyxFQUFFO0lBQ3hGLElBQUksRUFBRSxDQUFDLElBQUksS0FBSyxlQUFlLElBQUksRUFBRSxDQUFDLElBQUksS0FBSyxjQUFjLEVBQUU7UUFDM0QsT0FBTyxLQUFLLENBQUM7S0FDaEI7SUFFRCxPQUFPLElBQUksQ0FBQztBQUNoQixDQUFDLENBQUM7QUFFRjs7R0FFRztBQUVILE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxDQUFDLEVBQWtCLEVBQVcsRUFBRTtJQUN2RCxJQUFJLEVBQUUsQ0FBQyxJQUFJLEtBQUssZUFBZSxFQUFFO1FBQzdCLE9BQU8sS0FBSyxDQUFDO0tBQ2hCO0lBRUQsT0FBTyxJQUFJLENBQUM7QUFDaEIsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUc7SUFDN0I7O09BRUc7SUFDSCxRQUFRLENBQUMsS0FBaUI7UUFDdEIsT0FBTyxNQUFNLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUFFRDs7T0FFRztJQUVILFNBQVMsQ0FBQyxLQUFpQjtRQUN2QixPQUFPLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQUVEOzs7T0FHRztJQUVILGNBQWMsQ0FBQyxLQUFpQixFQUFFLEVBQWM7UUFDNUMsTUFBTSxJQUFJLEdBQUcsaUJBQWlCLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2hELE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQzFCLEVBQUUsRUFBRSxDQUFDO1FBQ0wsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUNEOzs7T0FHRztJQUVILGFBQWEsQ0FBQyxLQUFpQixFQUFFLEVBQWM7UUFDM0MsTUFBTSxJQUFJLEdBQUcsaUJBQWlCLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9DLE1BQU0sQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ3pCLEVBQUUsRUFBRSxDQUFDO1FBQ0wsTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDNUIsQ0FBQztDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNRVJHSU5HLCBQbGFpdEJvYXJkLCBQbGFpdE9wZXJhdGlvbiwgU0FWSU5HIH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5cbi8qKlxuICogQ2hlY2sgd2hldGhlciB0byBtZXJnZSBhbiBvcGVyYXRpb24gaW50byB0aGUgcHJldmlvdXMgb3BlcmF0aW9uLlxuICovXG5cbmV4cG9ydCBjb25zdCBzaG91bGRNZXJnZSA9IChvcDogUGxhaXRPcGVyYXRpb24sIHByZXY6IFBsYWl0T3BlcmF0aW9uIHwgdW5kZWZpbmVkKTogYm9vbGVhbiA9PiB7XG4gICAgaWYgKG9wLnR5cGUgPT09ICdzZXRfdmlld3BvcnQnICYmIG9wLnR5cGUgPT09IHByZXY/LnR5cGUpIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICAgIHJldHVybiBmYWxzZTtcbn07XG5cbi8qKlxuICogQ2hlY2sgd2hldGhlciBhbiBvcGVyYXRpb24gbmVlZHMgdG8gYmUgc2F2ZWQgdG8gdGhlIGhpc3RvcnkuXG4gKi9cblxuZXhwb3J0IGNvbnN0IHNob3VsZFNhdmUgPSAob3A6IFBsYWl0T3BlcmF0aW9uLCBwcmV2OiBQbGFpdE9wZXJhdGlvbiB8IHVuZGVmaW5lZCk6IGJvb2xlYW4gPT4ge1xuICAgIGlmIChvcC50eXBlID09PSAnc2V0X3NlbGVjdGlvbicgfHwgb3AudHlwZSA9PT0gJ3NldF92aWV3cG9ydCcpIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIHJldHVybiB0cnVlO1xufTtcblxuLyoqXG4gKiBDaGVjayB3aGV0aGVyIGFuIG9wZXJhdGlvbiBzaG91bGQgY2xlYXIgdGhlIHJlZG9zIHN0YWNrLlxuICovXG5cbmV4cG9ydCBjb25zdCBzaG91bGRDbGVhciA9IChvcDogUGxhaXRPcGVyYXRpb24pOiBib29sZWFuID0+IHtcbiAgICBpZiAob3AudHlwZSA9PT0gJ3NldF9zZWxlY3Rpb24nKSB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICByZXR1cm4gdHJ1ZTtcbn07XG5cbmV4cG9ydCBjb25zdCBQbGFpdEhpc3RvcnlCb2FyZCA9IHtcbiAgICAvKipcbiAgICAgKiBHZXQgdGhlIHNhdmluZyBmbGFnJ3MgY3VycmVudCB2YWx1ZS5cbiAgICAgKi9cbiAgICBpc1NhdmluZyhib2FyZDogUGxhaXRCb2FyZCk6IGJvb2xlYW4gfCB1bmRlZmluZWQge1xuICAgICAgICByZXR1cm4gU0FWSU5HLmdldChib2FyZCk7XG4gICAgfSxcblxuICAgIC8qKlxuICAgICAqIEdldCB0aGUgbWVyZ2UgZmxhZydzIGN1cnJlbnQgdmFsdWUuXG4gICAgICovXG5cbiAgICBpc01lcmdpbmcoYm9hcmQ6IFBsYWl0Qm9hcmQpOiBib29sZWFuIHwgdW5kZWZpbmVkIHtcbiAgICAgICAgcmV0dXJuIE1FUkdJTkcuZ2V0KGJvYXJkKTtcbiAgICB9LFxuXG4gICAgLyoqXG4gICAgICogQXBwbHkgYSBzZXJpZXMgb2YgY2hhbmdlcyBpbnNpZGUgYSBzeW5jaHJvbm91cyBgZm5gLCB3aXRob3V0IG1lcmdpbmcgYW55IG9mXG4gICAgICogdGhlIG5ldyBvcGVyYXRpb25zIGludG8gcHJldmlvdXMgc2F2ZSBwb2ludCBpbiB0aGUgaGlzdG9yeS5cbiAgICAgKi9cblxuICAgIHdpdGhvdXRNZXJnaW5nKGJvYXJkOiBQbGFpdEJvYXJkLCBmbjogKCkgPT4gdm9pZCk6IHZvaWQge1xuICAgICAgICBjb25zdCBwcmV2ID0gUGxhaXRIaXN0b3J5Qm9hcmQuaXNNZXJnaW5nKGJvYXJkKTtcbiAgICAgICAgTUVSR0lORy5zZXQoYm9hcmQsIGZhbHNlKTtcbiAgICAgICAgZm4oKTtcbiAgICAgICAgTUVSR0lORy5zZXQoYm9hcmQsIHByZXYpO1xuICAgIH0sXG4gICAgLyoqXG4gICAgICogQXBwbHkgYSBzZXJpZXMgb2YgY2hhbmdlcyBpbnNpZGUgYSBzeW5jaHJvbm91cyBgZm5gLCB3aXRob3V0IHNhdmluZyBhbnkgb2ZcbiAgICAgKiB0aGVpciBvcGVyYXRpb25zIGludG8gdGhlIGhpc3RvcnkuXG4gICAgICovXG5cbiAgICB3aXRob3V0U2F2aW5nKGJvYXJkOiBQbGFpdEJvYXJkLCBmbjogKCkgPT4gdm9pZCk6IHZvaWQge1xuICAgICAgICBjb25zdCBwcmV2ID0gUGxhaXRIaXN0b3J5Qm9hcmQuaXNTYXZpbmcoYm9hcmQpO1xuICAgICAgICBTQVZJTkcuc2V0KGJvYXJkLCBmYWxzZSk7XG4gICAgICAgIGZuKCk7XG4gICAgICAgIFNBVklORy5zZXQoYm9hcmQsIHByZXYpO1xuICAgIH1cbn07XG4iXX0=
|
package/fesm2015/plait-core.mjs
CHANGED
|
@@ -1,32 +1,13 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { Component, ChangeDetectionStrategy, Input, EventEmitter, HostBinding, ViewChild, Output, NgModule } from '@angular/core';
|
|
3
|
-
import
|
|
3
|
+
import rough from 'roughjs/bin/rough';
|
|
4
4
|
import { Subject, fromEvent } from 'rxjs';
|
|
5
5
|
import { takeUntil, filter } from 'rxjs/operators';
|
|
6
|
-
import
|
|
6
|
+
import produce, { createDraft, finishDraft, isDraft } from 'immer';
|
|
7
7
|
import { isKeyHotkey, isHotkey } from 'is-hotkey';
|
|
8
8
|
import * as i2 from '@angular/common';
|
|
9
9
|
import { BrowserModule } from '@angular/platform-browser';
|
|
10
10
|
|
|
11
|
-
// record richtext type status
|
|
12
|
-
const FLUSHING = new WeakMap();
|
|
13
|
-
const IS_TEXT_EDITABLE = new WeakMap();
|
|
14
|
-
const BOARD_TO_ON_CHANGE = new WeakMap();
|
|
15
|
-
const HOST_TO_ROUGH_SVG = new WeakMap();
|
|
16
|
-
|
|
17
|
-
function isNullOrUndefined(value) {
|
|
18
|
-
return value === null || value === undefined;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
const Viewport = {
|
|
22
|
-
isViewport: (value) => {
|
|
23
|
-
return (!isNullOrUndefined(value.offsetX) &&
|
|
24
|
-
!isNullOrUndefined(value.offsetY) &&
|
|
25
|
-
!isNullOrUndefined(value.zoom) &&
|
|
26
|
-
!isNullOrUndefined(value.viewBackgroundColor));
|
|
27
|
-
}
|
|
28
|
-
};
|
|
29
|
-
|
|
30
11
|
const Path = {
|
|
31
12
|
parent(path) {
|
|
32
13
|
if (path.length === 0) {
|
|
@@ -165,6 +146,92 @@ const Path = {
|
|
|
165
146
|
}
|
|
166
147
|
};
|
|
167
148
|
|
|
149
|
+
const isSetViewportOperation = (value) => {
|
|
150
|
+
return value.type === 'set_viewport';
|
|
151
|
+
};
|
|
152
|
+
const inverse = (op) => {
|
|
153
|
+
switch (op.type) {
|
|
154
|
+
case 'insert_node': {
|
|
155
|
+
return Object.assign(Object.assign({}, op), { type: 'remove_node' });
|
|
156
|
+
}
|
|
157
|
+
case 'remove_node': {
|
|
158
|
+
return Object.assign(Object.assign({}, op), { type: 'insert_node' });
|
|
159
|
+
}
|
|
160
|
+
case 'move_node': {
|
|
161
|
+
const { newPath, path } = op;
|
|
162
|
+
// PERF: in this case the move operation is a no-op anyways.
|
|
163
|
+
if (Path.equals(newPath, path)) {
|
|
164
|
+
return op;
|
|
165
|
+
}
|
|
166
|
+
// If the move happens completely within a single parent the path and
|
|
167
|
+
// newPath are stable with respect to each other.
|
|
168
|
+
if (Path.isSibling(path, newPath)) {
|
|
169
|
+
return Object.assign(Object.assign({}, op), { path: newPath, newPath: path });
|
|
170
|
+
}
|
|
171
|
+
// If the move does not happen within a single parent it is possible
|
|
172
|
+
// for the move to impact the true path to the location where the node
|
|
173
|
+
// was removed from and where it was inserted. We have to adjust for this
|
|
174
|
+
// and find the original path. We can accomplish this (only in non-sibling)
|
|
175
|
+
// moves by looking at the impact of the move operation on the node
|
|
176
|
+
// after the original move path.
|
|
177
|
+
const inversePath = Path.transform(path, op);
|
|
178
|
+
const inverseNewPath = Path.transform(Path.next(path), op);
|
|
179
|
+
return Object.assign(Object.assign({}, op), { path: inversePath, newPath: inverseNewPath });
|
|
180
|
+
}
|
|
181
|
+
case 'set_node': {
|
|
182
|
+
const { properties, newProperties } = op;
|
|
183
|
+
return Object.assign(Object.assign({}, op), { properties: newProperties, newProperties: properties });
|
|
184
|
+
}
|
|
185
|
+
case 'set_selection': {
|
|
186
|
+
const { properties, newProperties } = op;
|
|
187
|
+
if (properties == null) {
|
|
188
|
+
return Object.assign(Object.assign({}, op), { properties: newProperties, newProperties: null });
|
|
189
|
+
}
|
|
190
|
+
else if (newProperties == null) {
|
|
191
|
+
return Object.assign(Object.assign({}, op), { properties: null, newProperties: properties });
|
|
192
|
+
}
|
|
193
|
+
else {
|
|
194
|
+
return Object.assign(Object.assign({}, op), { properties: newProperties, newProperties: properties });
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
case 'set_viewport': {
|
|
198
|
+
const { properties, newProperties } = op;
|
|
199
|
+
if (properties == null) {
|
|
200
|
+
return Object.assign(Object.assign({}, op), { properties: newProperties, newProperties: newProperties });
|
|
201
|
+
}
|
|
202
|
+
else if (newProperties == null) {
|
|
203
|
+
return Object.assign(Object.assign({}, op), { properties: properties, newProperties: properties });
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
return Object.assign(Object.assign({}, op), { properties: newProperties, newProperties: properties });
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
};
|
|
211
|
+
const PlaitOperation = {
|
|
212
|
+
isSetViewportOperation,
|
|
213
|
+
inverse
|
|
214
|
+
};
|
|
215
|
+
|
|
216
|
+
// record richtext type status
|
|
217
|
+
const FLUSHING = new WeakMap();
|
|
218
|
+
const IS_TEXT_EDITABLE = new WeakMap();
|
|
219
|
+
const BOARD_TO_ON_CHANGE = new WeakMap();
|
|
220
|
+
const HOST_TO_ROUGH_SVG = new WeakMap();
|
|
221
|
+
|
|
222
|
+
function isNullOrUndefined(value) {
|
|
223
|
+
return value === null || value === undefined;
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
const Viewport = {
|
|
227
|
+
isViewport: (value) => {
|
|
228
|
+
return (!isNullOrUndefined(value.offsetX) &&
|
|
229
|
+
!isNullOrUndefined(value.offsetY) &&
|
|
230
|
+
!isNullOrUndefined(value.zoom) &&
|
|
231
|
+
!isNullOrUndefined(value.viewBackgroundColor));
|
|
232
|
+
}
|
|
233
|
+
};
|
|
234
|
+
|
|
168
235
|
const PlaitNode = {
|
|
169
236
|
parent: (board, path) => {
|
|
170
237
|
const parentPath = Path.parent(path);
|
|
@@ -442,6 +509,9 @@ function withBoard(board) {
|
|
|
442
509
|
return board;
|
|
443
510
|
}
|
|
444
511
|
|
|
512
|
+
const SAVING = new WeakMap();
|
|
513
|
+
const MERGING = new WeakMap();
|
|
514
|
+
|
|
445
515
|
const NS = 'http://www.w3.org/2000/svg';
|
|
446
516
|
function toPoint(x, y, container) {
|
|
447
517
|
const rect = container.getBoundingClientRect();
|
|
@@ -464,155 +534,6 @@ function createText(x, y, fill, textContent) {
|
|
|
464
534
|
return text;
|
|
465
535
|
}
|
|
466
536
|
|
|
467
|
-
function toRectangleClient(points) {
|
|
468
|
-
const xArray = points.map(ele => ele[0]);
|
|
469
|
-
const yArray = points.map(ele => ele[1]);
|
|
470
|
-
const xMin = Math.min(...xArray);
|
|
471
|
-
const xMax = Math.max(...xArray);
|
|
472
|
-
const yMin = Math.min(...yArray);
|
|
473
|
-
const yMax = Math.max(...yArray);
|
|
474
|
-
const rect = { x: xMin, y: yMin, width: xMax - xMin, height: yMax - yMin };
|
|
475
|
-
return rect;
|
|
476
|
-
}
|
|
477
|
-
|
|
478
|
-
function transformPoints(board, points) {
|
|
479
|
-
const newPoints = points.map(point => {
|
|
480
|
-
return transformPoint(board, point);
|
|
481
|
-
});
|
|
482
|
-
return newPoints;
|
|
483
|
-
}
|
|
484
|
-
function transformPoint(board, point) {
|
|
485
|
-
const { width, height } = board.host.getBoundingClientRect();
|
|
486
|
-
const viewBox = getViewBox(board);
|
|
487
|
-
let x = (point[0] / width) * viewBox.width + viewBox.minX;
|
|
488
|
-
let y = (point[1] / height) * viewBox.height + viewBox.minY;
|
|
489
|
-
const newPoint = [x - board.viewport.offsetX, y - board.viewport.offsetY];
|
|
490
|
-
return newPoint;
|
|
491
|
-
}
|
|
492
|
-
function getViewBox(board) {
|
|
493
|
-
const { width, height } = board.host.getBoundingClientRect();
|
|
494
|
-
const scaleWidth = (board.viewport.zoom - 1) * width;
|
|
495
|
-
const scaleHeight = (board.viewport.zoom - 1) * height;
|
|
496
|
-
const viewBoxWidth = width - scaleWidth;
|
|
497
|
-
const viewBoxHeight = height - scaleHeight;
|
|
498
|
-
const minX = scaleWidth / 2;
|
|
499
|
-
const minY = scaleHeight / 2;
|
|
500
|
-
return { minX, minY: minY, width: viewBoxWidth, height: viewBoxHeight };
|
|
501
|
-
}
|
|
502
|
-
function isNoSelectionElement(e) {
|
|
503
|
-
var _a;
|
|
504
|
-
return (_a = e.target) === null || _a === void 0 ? void 0 : _a.closest('.plait-board-attached');
|
|
505
|
-
}
|
|
506
|
-
|
|
507
|
-
function withSelection(board) {
|
|
508
|
-
const { mousedown, mousemove, globalMouseup } = board;
|
|
509
|
-
let start = null;
|
|
510
|
-
let end = null;
|
|
511
|
-
board.mousedown = (event) => {
|
|
512
|
-
mousedown(event);
|
|
513
|
-
};
|
|
514
|
-
board.mousemove = (event) => {
|
|
515
|
-
const movedTarget = toPoint(event.x, event.y, board.host);
|
|
516
|
-
if (start) {
|
|
517
|
-
const rectangleClient = toRectangleClient([start, movedTarget]);
|
|
518
|
-
if (start && Math.hypot(rectangleClient.width, rectangleClient.height) > 5) {
|
|
519
|
-
end = movedTarget;
|
|
520
|
-
}
|
|
521
|
-
}
|
|
522
|
-
mousemove(event);
|
|
523
|
-
};
|
|
524
|
-
board.globalMouseup = (event) => {
|
|
525
|
-
if (isNoSelectionElement(event)) {
|
|
526
|
-
return globalMouseup(event);
|
|
527
|
-
}
|
|
528
|
-
else {
|
|
529
|
-
if (!start && event.target instanceof Node && board.host.contains(event.target)) {
|
|
530
|
-
start = toPoint(event.x, event.y, board.host);
|
|
531
|
-
}
|
|
532
|
-
}
|
|
533
|
-
if (start) {
|
|
534
|
-
Transforms.setSelection(board, { anchor: start, focus: start });
|
|
535
|
-
}
|
|
536
|
-
else {
|
|
537
|
-
Transforms.setSelection(board, null);
|
|
538
|
-
}
|
|
539
|
-
start = null;
|
|
540
|
-
end = null;
|
|
541
|
-
globalMouseup(event);
|
|
542
|
-
};
|
|
543
|
-
return board;
|
|
544
|
-
}
|
|
545
|
-
|
|
546
|
-
const isSetViewportOperation = (value) => {
|
|
547
|
-
return value.type === 'set_viewport';
|
|
548
|
-
};
|
|
549
|
-
const inverse = (op) => {
|
|
550
|
-
switch (op.type) {
|
|
551
|
-
case 'insert_node': {
|
|
552
|
-
return Object.assign(Object.assign({}, op), { type: 'remove_node' });
|
|
553
|
-
}
|
|
554
|
-
case 'remove_node': {
|
|
555
|
-
return Object.assign(Object.assign({}, op), { type: 'insert_node' });
|
|
556
|
-
}
|
|
557
|
-
case 'move_node': {
|
|
558
|
-
const { newPath, path } = op;
|
|
559
|
-
// PERF: in this case the move operation is a no-op anyways.
|
|
560
|
-
if (Path.equals(newPath, path)) {
|
|
561
|
-
return op;
|
|
562
|
-
}
|
|
563
|
-
// If the move happens completely within a single parent the path and
|
|
564
|
-
// newPath are stable with respect to each other.
|
|
565
|
-
if (Path.isSibling(path, newPath)) {
|
|
566
|
-
return Object.assign(Object.assign({}, op), { path: newPath, newPath: path });
|
|
567
|
-
}
|
|
568
|
-
// If the move does not happen within a single parent it is possible
|
|
569
|
-
// for the move to impact the true path to the location where the node
|
|
570
|
-
// was removed from and where it was inserted. We have to adjust for this
|
|
571
|
-
// and find the original path. We can accomplish this (only in non-sibling)
|
|
572
|
-
// moves by looking at the impact of the move operation on the node
|
|
573
|
-
// after the original move path.
|
|
574
|
-
const inversePath = Path.transform(path, op);
|
|
575
|
-
const inverseNewPath = Path.transform(Path.next(path), op);
|
|
576
|
-
return Object.assign(Object.assign({}, op), { path: inversePath, newPath: inverseNewPath });
|
|
577
|
-
}
|
|
578
|
-
case 'set_node': {
|
|
579
|
-
const { properties, newProperties } = op;
|
|
580
|
-
return Object.assign(Object.assign({}, op), { properties: newProperties, newProperties: properties });
|
|
581
|
-
}
|
|
582
|
-
case 'set_selection': {
|
|
583
|
-
const { properties, newProperties } = op;
|
|
584
|
-
if (properties == null) {
|
|
585
|
-
return Object.assign(Object.assign({}, op), { properties: newProperties, newProperties: null });
|
|
586
|
-
}
|
|
587
|
-
else if (newProperties == null) {
|
|
588
|
-
return Object.assign(Object.assign({}, op), { properties: null, newProperties: properties });
|
|
589
|
-
}
|
|
590
|
-
else {
|
|
591
|
-
return Object.assign(Object.assign({}, op), { properties: newProperties, newProperties: properties });
|
|
592
|
-
}
|
|
593
|
-
}
|
|
594
|
-
case 'set_viewport': {
|
|
595
|
-
const { properties, newProperties } = op;
|
|
596
|
-
if (properties == null) {
|
|
597
|
-
return Object.assign(Object.assign({}, op), { properties: newProperties, newProperties: newProperties });
|
|
598
|
-
}
|
|
599
|
-
else if (newProperties == null) {
|
|
600
|
-
return Object.assign(Object.assign({}, op), { properties: properties, newProperties: properties });
|
|
601
|
-
}
|
|
602
|
-
else {
|
|
603
|
-
return Object.assign(Object.assign({}, op), { properties: newProperties, newProperties: properties });
|
|
604
|
-
}
|
|
605
|
-
}
|
|
606
|
-
}
|
|
607
|
-
};
|
|
608
|
-
const PlaitOperation = {
|
|
609
|
-
isSetViewportOperation,
|
|
610
|
-
inverse
|
|
611
|
-
};
|
|
612
|
-
|
|
613
|
-
const SAVING = new WeakMap();
|
|
614
|
-
const MERGING = new WeakMap();
|
|
615
|
-
|
|
616
537
|
const IS_IOS = typeof navigator !== 'undefined' &&
|
|
617
538
|
typeof window !== 'undefined' &&
|
|
618
539
|
/iPad|iPhone|iPod/.test(navigator.userAgent) &&
|
|
@@ -626,6 +547,17 @@ const IS_CHROME = typeof navigator !== 'undefined' && /Chrome/i.test(navigator.u
|
|
|
626
547
|
// Native beforeInput events don't work well with react on Chrome 75 and older, Chrome 76+ can use beforeInput
|
|
627
548
|
const IS_CHROME_LEGACY = typeof navigator !== 'undefined' && /Chrome?\/(?:[0-7][0-5]|[0-6][0-9])/i.test(navigator.userAgent);
|
|
628
549
|
|
|
550
|
+
function toRectangleClient(points) {
|
|
551
|
+
const xArray = points.map(ele => ele[0]);
|
|
552
|
+
const yArray = points.map(ele => ele[1]);
|
|
553
|
+
const xMin = Math.min(...xArray);
|
|
554
|
+
const xMax = Math.max(...xArray);
|
|
555
|
+
const yMin = Math.min(...yArray);
|
|
556
|
+
const yMax = Math.max(...yArray);
|
|
557
|
+
const rect = { x: xMin, y: yMin, width: xMax - xMin, height: yMax - yMin };
|
|
558
|
+
return rect;
|
|
559
|
+
}
|
|
560
|
+
|
|
629
561
|
/**
|
|
630
562
|
* Hotkey mappings for each platform.
|
|
631
563
|
*/
|
|
@@ -769,6 +701,35 @@ function rotate(x1, y1, x2, y2, angle) {
|
|
|
769
701
|
return [(x1 - x2) * Math.cos(angle) - (y1 - y2) * Math.sin(angle) + x2, (x1 - x2) * Math.sin(angle) + (y1 - y2) * Math.cos(angle) + y2];
|
|
770
702
|
}
|
|
771
703
|
|
|
704
|
+
function transformPoints(board, points) {
|
|
705
|
+
const newPoints = points.map(point => {
|
|
706
|
+
return transformPoint(board, point);
|
|
707
|
+
});
|
|
708
|
+
return newPoints;
|
|
709
|
+
}
|
|
710
|
+
function transformPoint(board, point) {
|
|
711
|
+
const { width, height } = board.host.getBoundingClientRect();
|
|
712
|
+
const viewBox = getViewBox(board);
|
|
713
|
+
let x = (point[0] / width) * viewBox.width + viewBox.minX;
|
|
714
|
+
let y = (point[1] / height) * viewBox.height + viewBox.minY;
|
|
715
|
+
const newPoint = [x - board.viewport.offsetX, y - board.viewport.offsetY];
|
|
716
|
+
return newPoint;
|
|
717
|
+
}
|
|
718
|
+
function getViewBox(board) {
|
|
719
|
+
const { width, height } = board.host.getBoundingClientRect();
|
|
720
|
+
const scaleWidth = (board.viewport.zoom - 1) * width;
|
|
721
|
+
const scaleHeight = (board.viewport.zoom - 1) * height;
|
|
722
|
+
const viewBoxWidth = width - scaleWidth;
|
|
723
|
+
const viewBoxHeight = height - scaleHeight;
|
|
724
|
+
const minX = scaleWidth / 2;
|
|
725
|
+
const minY = scaleHeight / 2;
|
|
726
|
+
return { minX, minY: minY, width: viewBoxWidth, height: viewBoxHeight };
|
|
727
|
+
}
|
|
728
|
+
function isNoSelectionElement(e) {
|
|
729
|
+
var _a;
|
|
730
|
+
return (_a = e.target) === null || _a === void 0 ? void 0 : _a.closest('.plait-board-attached');
|
|
731
|
+
}
|
|
732
|
+
|
|
772
733
|
/**
|
|
773
734
|
* Check whether to merge an operation into the previous operation.
|
|
774
735
|
*/
|
|
@@ -782,7 +743,7 @@ const shouldMerge = (op, prev) => {
|
|
|
782
743
|
* Check whether an operation needs to be saved to the history.
|
|
783
744
|
*/
|
|
784
745
|
const shouldSave = (op, prev) => {
|
|
785
|
-
if (op.type === 'set_selection') {
|
|
746
|
+
if (op.type === 'set_selection' || op.type === 'set_viewport') {
|
|
786
747
|
return false;
|
|
787
748
|
}
|
|
788
749
|
return true;
|
|
@@ -915,6 +876,45 @@ function withHistroy(board) {
|
|
|
915
876
|
return board;
|
|
916
877
|
}
|
|
917
878
|
|
|
879
|
+
function withSelection(board) {
|
|
880
|
+
const { mousedown, mousemove, globalMouseup } = board;
|
|
881
|
+
let start = null;
|
|
882
|
+
let end = null;
|
|
883
|
+
board.mousedown = (event) => {
|
|
884
|
+
mousedown(event);
|
|
885
|
+
};
|
|
886
|
+
board.mousemove = (event) => {
|
|
887
|
+
const movedTarget = toPoint(event.x, event.y, board.host);
|
|
888
|
+
if (start) {
|
|
889
|
+
const rectangleClient = toRectangleClient([start, movedTarget]);
|
|
890
|
+
if (start && Math.hypot(rectangleClient.width, rectangleClient.height) > 5) {
|
|
891
|
+
end = movedTarget;
|
|
892
|
+
}
|
|
893
|
+
}
|
|
894
|
+
mousemove(event);
|
|
895
|
+
};
|
|
896
|
+
board.globalMouseup = (event) => {
|
|
897
|
+
if (isNoSelectionElement(event)) {
|
|
898
|
+
return globalMouseup(event);
|
|
899
|
+
}
|
|
900
|
+
else {
|
|
901
|
+
if (!start && event.target instanceof Node && board.host.contains(event.target)) {
|
|
902
|
+
start = toPoint(event.x, event.y, board.host);
|
|
903
|
+
}
|
|
904
|
+
}
|
|
905
|
+
if (start) {
|
|
906
|
+
Transforms.setSelection(board, { anchor: start, focus: start });
|
|
907
|
+
}
|
|
908
|
+
else {
|
|
909
|
+
Transforms.setSelection(board, null);
|
|
910
|
+
}
|
|
911
|
+
start = null;
|
|
912
|
+
end = null;
|
|
913
|
+
globalMouseup(event);
|
|
914
|
+
};
|
|
915
|
+
return board;
|
|
916
|
+
}
|
|
917
|
+
|
|
918
918
|
class PlaitElementComponent {
|
|
919
919
|
constructor(renderer2, viewContainerRef) {
|
|
920
920
|
this.renderer2 = renderer2;
|
|
@@ -1006,6 +1006,9 @@ class PlaitBoardComponent {
|
|
|
1006
1006
|
var _a;
|
|
1007
1007
|
return (_a = this.board) === null || _a === void 0 ? void 0 : _a.selection;
|
|
1008
1008
|
}
|
|
1009
|
+
get focused() {
|
|
1010
|
+
return this.isFocused;
|
|
1011
|
+
}
|
|
1009
1012
|
ngOnInit() {
|
|
1010
1013
|
const roughSVG = rough.svg(this.host, { options: { roughness: 0, strokeWidth: 1 } });
|
|
1011
1014
|
HOST_TO_ROUGH_SVG.set(this.host, roughSVG);
|
|
@@ -1153,7 +1156,7 @@ class PlaitBoardComponent {
|
|
|
1153
1156
|
}
|
|
1154
1157
|
}
|
|
1155
1158
|
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 });
|
|
1156
|
-
PlaitBoardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: PlaitBoardComponent, selector: "plait-board", inputs: { plaitValue: "plaitValue", plaitViewport: "plaitViewport", plaitPlugins: "plaitPlugins", plaitReadonly: "plaitReadonly", plaitAllowClearBoard: "plaitAllowClearBoard" }, outputs: { plaitChange: "plaitChange", plaitBoardInitialized: "plaitBoardInitialized" }, host: { properties: { "class": "this.hostClass" } }, viewQueries: [{ propertyName: "svg", first: true, predicate: ["svg"], descendants: true, static: true }], ngImport: i0, template: `
|
|
1159
|
+
PlaitBoardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: PlaitBoardComponent, selector: "plait-board", inputs: { plaitValue: "plaitValue", plaitViewport: "plaitViewport", plaitPlugins: "plaitPlugins", plaitReadonly: "plaitReadonly", plaitAllowClearBoard: "plaitAllowClearBoard" }, outputs: { plaitChange: "plaitChange", plaitBoardInitialized: "plaitBoardInitialized" }, host: { properties: { "class": "this.hostClass", "class.focused": "this.focused" } }, viewQueries: [{ propertyName: "svg", first: true, predicate: ["svg"], descendants: true, static: true }], ngImport: i0, template: `
|
|
1157
1160
|
<svg #svg width="100%" height="100%" style="position: relative"></svg>
|
|
1158
1161
|
<div *ngIf="isFocused" class="plait-toolbar island zoom-toolbar plait-board-attached">
|
|
1159
1162
|
<button class="item" (mousedown)="zoomOut($event)">-</button>
|
|
@@ -1215,6 +1218,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
1215
1218
|
type: Output
|
|
1216
1219
|
}], plaitBoardInitialized: [{
|
|
1217
1220
|
type: Output
|
|
1221
|
+
}], focused: [{
|
|
1222
|
+
type: HostBinding,
|
|
1223
|
+
args: ['class.focused']
|
|
1218
1224
|
}] } });
|
|
1219
1225
|
|
|
1220
1226
|
class PlaitModule {
|