@plait/core 0.0.6 → 0.0.11
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/esm2020/board/board.component.mjs +12 -8
- package/esm2020/plugins/with-selection.mjs +6 -6
- package/esm2020/utils/board.mjs +4 -1
- package/fesm2015/plait-core.mjs +44 -37
- package/fesm2015/plait-core.mjs.map +1 -1
- package/fesm2020/plait-core.mjs +43 -37
- package/fesm2020/plait-core.mjs.map +1 -1
- package/package.json +1 -1
- package/styles/styles.scss +5 -0
- package/utils/board.d.ts +1 -0
|
@@ -8,7 +8,7 @@ import rough from 'roughjs/bin/rough';
|
|
|
8
8
|
import { Transforms } from '../transfroms';
|
|
9
9
|
import { withSelection } from '../plugins/with-selection';
|
|
10
10
|
import { PlaitOperation } from '../interfaces/operation';
|
|
11
|
-
import { getViewBox } from '../utils/board';
|
|
11
|
+
import { getViewBox, isNoSelectionElement } from '../utils/board';
|
|
12
12
|
import * as i0 from "@angular/core";
|
|
13
13
|
import * as i1 from "../core/element/element.component";
|
|
14
14
|
import * as i2 from "@angular/common";
|
|
@@ -73,7 +73,9 @@ export class PlaitBoardComponent {
|
|
|
73
73
|
fromEvent(this.host, 'mousedown')
|
|
74
74
|
.pipe(takeUntil(this.destroy$))
|
|
75
75
|
.subscribe((event) => {
|
|
76
|
-
|
|
76
|
+
if (!isNoSelectionElement(event)) {
|
|
77
|
+
this.board.mousedown(event);
|
|
78
|
+
}
|
|
77
79
|
});
|
|
78
80
|
fromEvent(this.host, 'mousemove')
|
|
79
81
|
.pipe(takeUntil(this.destroy$))
|
|
@@ -83,7 +85,9 @@ export class PlaitBoardComponent {
|
|
|
83
85
|
fromEvent(document, 'mouseup')
|
|
84
86
|
.pipe(takeUntil(this.destroy$))
|
|
85
87
|
.subscribe((event) => {
|
|
86
|
-
|
|
88
|
+
if (!isNoSelectionElement(event)) {
|
|
89
|
+
this.board.mouseup(event);
|
|
90
|
+
}
|
|
87
91
|
});
|
|
88
92
|
fromEvent(this.host, 'dblclick')
|
|
89
93
|
.pipe(takeUntil(this.destroy$))
|
|
@@ -159,8 +163,8 @@ export class PlaitBoardComponent {
|
|
|
159
163
|
}
|
|
160
164
|
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 });
|
|
161
165
|
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" }, outputs: { plaitChange: "plaitChange", plaitBoardInitialized: "plaitBoardInitialized" }, host: { properties: { "class": "this.hostClass" } }, viewQueries: [{ propertyName: "svg", first: true, predicate: ["svg"], descendants: true, static: true }], ngImport: i0, template: `
|
|
162
|
-
<svg #svg width="100%" height="100%"></svg>
|
|
163
|
-
<div *ngIf="isFocused" class="plait-toolbar island zoom-toolbar">
|
|
166
|
+
<svg #svg width="100%" height="100%" style="position: relative"></svg>
|
|
167
|
+
<div *ngIf="isFocused" class="plait-toolbar island zoom-toolbar plait-board-attached">
|
|
164
168
|
<button class="item" (mousedown)="zoomOut($event)">-</button>
|
|
165
169
|
<button class="item zoom-value" (mousedown)="resetZoom($event)">{{ zoom }}%</button>
|
|
166
170
|
<button class="item" (mousedown)="zoomIn($event)">+</button>
|
|
@@ -181,8 +185,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
181
185
|
args: [{
|
|
182
186
|
selector: 'plait-board',
|
|
183
187
|
template: `
|
|
184
|
-
<svg #svg width="100%" height="100%"></svg>
|
|
185
|
-
<div *ngIf="isFocused" class="plait-toolbar island zoom-toolbar">
|
|
188
|
+
<svg #svg width="100%" height="100%" style="position: relative"></svg>
|
|
189
|
+
<div *ngIf="isFocused" class="plait-toolbar island zoom-toolbar plait-board-attached">
|
|
186
190
|
<button class="item" (mousedown)="zoomOut($event)">-</button>
|
|
187
191
|
<button class="item zoom-value" (mousedown)="resetZoom($event)">{{ zoom }}%</button>
|
|
188
192
|
<button class="item" (mousedown)="zoomIn($event)">+</button>
|
|
@@ -219,4 +223,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
219
223
|
}], plaitBoardInitialized: [{
|
|
220
224
|
type: Output
|
|
221
225
|
}] } });
|
|
222
|
-
//# 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 } 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 *ngIf=\"isFocused\" 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    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    @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        const options: PlaitBoardOptions = { readonly: this.plaitReadonly };\n        let board = 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.mouseup(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        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"]}
|
|
226
|
+
//# 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';\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    @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        const options: PlaitBoardOptions = { readonly: this.plaitReadonly };\n        let board = 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                if (!isNoSelectionElement(event)) {\n                    this.board.mousedown(event);\n                }\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                if (!isNoSelectionElement(event)) {\n                    this.board.mouseup(event);\n                }\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        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"]}
|
|
@@ -2,16 +2,13 @@ import { BaseCursorStatus } from '../interfaces/cursor';
|
|
|
2
2
|
import { Transforms } from '../transfroms';
|
|
3
3
|
import { toPoint } from '../utils/dom';
|
|
4
4
|
import { toRectangleClient } from '../utils/graph';
|
|
5
|
+
import { isNoSelectionElement } from '../utils/board';
|
|
5
6
|
export function withSelection(board) {
|
|
6
7
|
const { mousedown, mousemove, mouseup } = board;
|
|
7
8
|
let start = null;
|
|
8
9
|
let end = null;
|
|
9
10
|
board.mousedown = (event) => {
|
|
10
|
-
|
|
11
|
-
if (!(event.target instanceof HTMLElement && event.target.closest('.richtext'))) {
|
|
12
|
-
event.preventDefault();
|
|
13
|
-
}
|
|
14
|
-
if (board.cursor === BaseCursorStatus.select) {
|
|
11
|
+
if (!isNoSelectionElement(event) && board.cursor === BaseCursorStatus.select) {
|
|
15
12
|
start = toPoint(event.x, event.y, board.host);
|
|
16
13
|
}
|
|
17
14
|
mousedown(event);
|
|
@@ -27,6 +24,9 @@ export function withSelection(board) {
|
|
|
27
24
|
mousemove(event);
|
|
28
25
|
};
|
|
29
26
|
board.mouseup = (event) => {
|
|
27
|
+
if (isNoSelectionElement(event)) {
|
|
28
|
+
return mouseup(event);
|
|
29
|
+
}
|
|
30
30
|
if (start) {
|
|
31
31
|
Transforms.setSelection(board, { anchor: start, focus: start });
|
|
32
32
|
}
|
|
@@ -39,4 +39,4 @@ export function withSelection(board) {
|
|
|
39
39
|
};
|
|
40
40
|
return board;
|
|
41
41
|
}
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1zZWxlY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvcGx1Z2lucy93aXRoLXNlbGVjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUd4RCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDdkMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbkQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFdEQsTUFBTSxVQUFVLGFBQWEsQ0FBdUIsS0FBUTtJQUN4RCxNQUFNLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsR0FBRyxLQUFLLENBQUM7SUFFaEQsSUFBSSxLQUFLLEdBQWlCLElBQUksQ0FBQztJQUMvQixJQUFJLEdBQUcsR0FBaUIsSUFBSSxDQUFDO0lBRTdCLEtBQUssQ0FBQyxTQUFTLEdBQUcsQ0FBQyxLQUFpQixFQUFFLEVBQUU7UUFDcEMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLEtBQUssQ0FBQyxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssZ0JBQWdCLENBQUMsTUFBTSxFQUFFO1lBQzFFLEtBQUssR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUNqRDtRQUNELFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNyQixDQUFDLENBQUM7SUFFRixLQUFLLENBQUMsU0FBUyxHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO1FBQ3BDLE1BQU0sV0FBVyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzFELElBQUksS0FBSyxFQUFFO1lBQ1AsTUFBTSxlQUFlLEdBQUcsaUJBQWlCLENBQUMsQ0FBQyxLQUFLLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQztZQUNoRSxJQUFJLEtBQUssSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBQyxLQUFLLEVBQUUsZUFBZSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRTtnQkFDeEUsR0FBRyxHQUFHLFdBQVcsQ0FBQzthQUNyQjtTQUNKO1FBQ0QsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3JCLENBQUMsQ0FBQztJQUVGLEtBQUssQ0FBQyxPQUFPLEdBQUcsQ0FBQyxLQUFpQixFQUFFLEVBQUU7UUFDbEMsSUFBSSxvQkFBb0IsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUM3QixPQUFPLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUN6QjtRQUVELElBQUksS0FBSyxFQUFFO1lBQ1AsVUFBVSxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO1NBQ25FO2FBQU07WUFDSCxVQUFVLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztTQUN4QztRQUNELEtBQUssR0FBRyxJQUFJLENBQUM7UUFDYixHQUFHLEdBQUcsSUFBSSxDQUFDO1FBRVgsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ25CLENBQUMsQ0FBQztJQUVGLE9BQU8sS0FBSyxDQUFDO0FBQ2pCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYXNlQ3Vyc29yU3RhdHVzIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9jdXJzb3InO1xuaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJy4uL2ludGVyZmFjZXMvYm9hcmQnO1xuaW1wb3J0IHsgUG9pbnQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL3BvaW50JztcbmltcG9ydCB7IFRyYW5zZm9ybXMgfSBmcm9tICcuLi90cmFuc2Zyb21zJztcbmltcG9ydCB7IHRvUG9pbnQgfSBmcm9tICcuLi91dGlscy9kb20nO1xuaW1wb3J0IHsgdG9SZWN0YW5nbGVDbGllbnQgfSBmcm9tICcuLi91dGlscy9ncmFwaCc7XG5pbXBvcnQgeyBpc05vU2VsZWN0aW9uRWxlbWVudCB9IGZyb20gJy4uL3V0aWxzL2JvYXJkJztcblxuZXhwb3J0IGZ1bmN0aW9uIHdpdGhTZWxlY3Rpb248VCBleHRlbmRzIFBsYWl0Qm9hcmQ+KGJvYXJkOiBUKSB7XG4gICAgY29uc3QgeyBtb3VzZWRvd24sIG1vdXNlbW92ZSwgbW91c2V1cCB9ID0gYm9hcmQ7XG5cbiAgICBsZXQgc3RhcnQ6IFBvaW50IHwgbnVsbCA9IG51bGw7XG4gICAgbGV0IGVuZDogUG9pbnQgfCBudWxsID0gbnVsbDtcblxuICAgIGJvYXJkLm1vdXNlZG93biA9IChldmVudDogTW91c2VFdmVudCkgPT4ge1xuICAgICAgICBpZiAoIWlzTm9TZWxlY3Rpb25FbGVtZW50KGV2ZW50KSAmJiBib2FyZC5jdXJzb3IgPT09IEJhc2VDdXJzb3JTdGF0dXMuc2VsZWN0KSB7XG4gICAgICAgICAgICBzdGFydCA9IHRvUG9pbnQoZXZlbnQueCwgZXZlbnQueSwgYm9hcmQuaG9zdCk7XG4gICAgICAgIH1cbiAgICAgICAgbW91c2Vkb3duKGV2ZW50KTtcbiAgICB9O1xuXG4gICAgYm9hcmQubW91c2Vtb3ZlID0gKGV2ZW50OiBNb3VzZUV2ZW50KSA9PiB7XG4gICAgICAgIGNvbnN0IG1vdmVkVGFyZ2V0ID0gdG9Qb2ludChldmVudC54LCBldmVudC55LCBib2FyZC5ob3N0KTtcbiAgICAgICAgaWYgKHN0YXJ0KSB7XG4gICAgICAgICAgICBjb25zdCByZWN0YW5nbGVDbGllbnQgPSB0b1JlY3RhbmdsZUNsaWVudChbc3RhcnQsIG1vdmVkVGFyZ2V0XSk7XG4gICAgICAgICAgICBpZiAoc3RhcnQgJiYgTWF0aC5oeXBvdChyZWN0YW5nbGVDbGllbnQud2lkdGgsIHJlY3RhbmdsZUNsaWVudC5oZWlnaHQpID4gNSkge1xuICAgICAgICAgICAgICAgIGVuZCA9IG1vdmVkVGFyZ2V0O1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIG1vdXNlbW92ZShldmVudCk7XG4gICAgfTtcblxuICAgIGJvYXJkLm1vdXNldXAgPSAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHtcbiAgICAgICAgaWYgKGlzTm9TZWxlY3Rpb25FbGVtZW50KGV2ZW50KSkge1xuICAgICAgICAgICAgcmV0dXJuIG1vdXNldXAoZXZlbnQpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKHN0YXJ0KSB7XG4gICAgICAgICAgICBUcmFuc2Zvcm1zLnNldFNlbGVjdGlvbihib2FyZCwgeyBhbmNob3I6IHN0YXJ0LCBmb2N1czogc3RhcnQgfSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBUcmFuc2Zvcm1zLnNldFNlbGVjdGlvbihib2FyZCwgbnVsbCk7XG4gICAgICAgIH1cbiAgICAgICAgc3RhcnQgPSBudWxsO1xuICAgICAgICBlbmQgPSBudWxsO1xuXG4gICAgICAgIG1vdXNldXAoZXZlbnQpO1xuICAgIH07XG5cbiAgICByZXR1cm4gYm9hcmQ7XG59XG4iXX0=
|
package/esm2020/utils/board.mjs
CHANGED
|
@@ -22,4 +22,7 @@ export function getViewBox(board) {
|
|
|
22
22
|
const minY = scaleHeight / 2;
|
|
23
23
|
return { minX, minY: minY, width: viewBoxWidth, height: viewBoxHeight };
|
|
24
24
|
}
|
|
25
|
-
|
|
25
|
+
export function isNoSelectionElement(e) {
|
|
26
|
+
return e.target?.closest('.plait-board-attached');
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9hcmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvdXRpbHMvYm9hcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxVQUFVLGVBQWUsQ0FBQyxLQUFpQixFQUFFLE1BQWU7SUFDOUQsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRTtRQUNqQyxPQUFPLGNBQWMsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDeEMsQ0FBQyxDQUFDLENBQUM7SUFDSCxPQUFPLFNBQVMsQ0FBQztBQUNyQixDQUFDO0FBRUQsTUFBTSxVQUFVLGNBQWMsQ0FBQyxLQUFpQixFQUFFLEtBQVk7SUFDMUQsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLHFCQUFxQixFQUFFLENBQUM7SUFDN0QsTUFBTSxPQUFPLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xDLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxHQUFHLE9BQU8sQ0FBQyxLQUFLLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQztJQUMxRCxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsR0FBRyxNQUFNLENBQUMsR0FBRyxPQUFPLENBQUMsTUFBTSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUM7SUFDNUQsTUFBTSxRQUFRLEdBQUcsQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxHQUFHLEtBQUssQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFVLENBQUM7SUFDbkYsT0FBTyxRQUFRLENBQUM7QUFDcEIsQ0FBQztBQUVELE1BQU0sVUFBVSxVQUFVLENBQUMsS0FBaUI7SUFDeEMsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLHFCQUFxQixFQUFhLENBQUM7SUFDeEUsTUFBTSxVQUFVLEdBQUcsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsR0FBRyxLQUFLLENBQUM7SUFDckQsTUFBTSxXQUFXLEdBQUcsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsR0FBRyxNQUFNLENBQUM7SUFDdkQsTUFBTSxZQUFZLEdBQUcsS0FBSyxHQUFHLFVBQVUsQ0FBQztJQUN4QyxNQUFNLGFBQWEsR0FBRyxNQUFNLEdBQUcsV0FBVyxDQUFDO0lBQzNDLE1BQU0sSUFBSSxHQUFHLFVBQVUsR0FBRyxDQUFDLENBQUM7SUFDNUIsTUFBTSxJQUFJLEdBQUcsV0FBVyxHQUFHLENBQUMsQ0FBQztJQUM3QixPQUFPLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsYUFBYSxFQUFFLENBQUM7QUFDNUUsQ0FBQztBQUVELE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxDQUFRO0lBQ3pDLE9BQVEsQ0FBQyxDQUFDLE1BQXNCLEVBQUUsT0FBTyxDQUFDLHVCQUF1QixDQUFDLENBQUM7QUFDdkUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Qm9hcmQsIFBvaW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiB0cmFuc2Zvcm1Qb2ludHMoYm9hcmQ6IFBsYWl0Qm9hcmQsIHBvaW50czogUG9pbnRbXSkge1xuICAgIGNvbnN0IG5ld1BvaW50cyA9IHBvaW50cy5tYXAocG9pbnQgPT4ge1xuICAgICAgICByZXR1cm4gdHJhbnNmb3JtUG9pbnQoYm9hcmQsIHBvaW50KTtcbiAgICB9KTtcbiAgICByZXR1cm4gbmV3UG9pbnRzO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdHJhbnNmb3JtUG9pbnQoYm9hcmQ6IFBsYWl0Qm9hcmQsIHBvaW50OiBQb2ludCkge1xuICAgIGNvbnN0IHsgd2lkdGgsIGhlaWdodCB9ID0gYm9hcmQuaG9zdC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcbiAgICBjb25zdCB2aWV3Qm94ID0gZ2V0Vmlld0JveChib2FyZCk7XG4gICAgbGV0IHggPSAocG9pbnRbMF0gLyB3aWR0aCkgKiB2aWV3Qm94LndpZHRoICsgdmlld0JveC5taW5YO1xuICAgIGxldCB5ID0gKHBvaW50WzFdIC8gaGVpZ2h0KSAqIHZpZXdCb3guaGVpZ2h0ICsgdmlld0JveC5taW5ZO1xuICAgIGNvbnN0IG5ld1BvaW50ID0gW3ggLSBib2FyZC52aWV3cG9ydC5vZmZzZXRYLCB5IC0gYm9hcmQudmlld3BvcnQub2Zmc2V0WV0gYXMgUG9pbnQ7XG4gICAgcmV0dXJuIG5ld1BvaW50O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0Vmlld0JveChib2FyZDogUGxhaXRCb2FyZCk6IFZpZXdCb3gge1xuICAgIGNvbnN0IHsgd2lkdGgsIGhlaWdodCB9ID0gYm9hcmQuaG9zdC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKSBhcyBET01SZWN0O1xuICAgIGNvbnN0IHNjYWxlV2lkdGggPSAoYm9hcmQudmlld3BvcnQuem9vbSAtIDEpICogd2lkdGg7XG4gICAgY29uc3Qgc2NhbGVIZWlnaHQgPSAoYm9hcmQudmlld3BvcnQuem9vbSAtIDEpICogaGVpZ2h0O1xuICAgIGNvbnN0IHZpZXdCb3hXaWR0aCA9IHdpZHRoIC0gc2NhbGVXaWR0aDtcbiAgICBjb25zdCB2aWV3Qm94SGVpZ2h0ID0gaGVpZ2h0IC0gc2NhbGVIZWlnaHQ7XG4gICAgY29uc3QgbWluWCA9IHNjYWxlV2lkdGggLyAyO1xuICAgIGNvbnN0IG1pblkgPSBzY2FsZUhlaWdodCAvIDI7XG4gICAgcmV0dXJuIHsgbWluWCwgbWluWTogbWluWSwgd2lkdGg6IHZpZXdCb3hXaWR0aCwgaGVpZ2h0OiB2aWV3Qm94SGVpZ2h0IH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc05vU2VsZWN0aW9uRWxlbWVudChlOiBFdmVudCkge1xuICAgIHJldHVybiAoZS50YXJnZXQgYXMgSFRNTEVsZW1lbnQpPy5jbG9zZXN0KCcucGxhaXQtYm9hcmQtYXR0YWNoZWQnKTtcbn1cblxuZXhwb3J0IHR5cGUgVmlld0JveCA9IHtcbiAgICBtaW5YOiBudW1iZXI7XG4gICAgbWluWTogbnVtYmVyO1xuICAgIHdpZHRoOiBudW1iZXI7XG4gICAgaGVpZ2h0OiBudW1iZXI7XG59O1xuIl19
|
package/fesm2015/plait-core.mjs
CHANGED
|
@@ -464,16 +464,41 @@ function toRectangleClient(points) {
|
|
|
464
464
|
return rect;
|
|
465
465
|
}
|
|
466
466
|
|
|
467
|
+
function transformPoints(board, points) {
|
|
468
|
+
const newPoints = points.map(point => {
|
|
469
|
+
return transformPoint(board, point);
|
|
470
|
+
});
|
|
471
|
+
return newPoints;
|
|
472
|
+
}
|
|
473
|
+
function transformPoint(board, point) {
|
|
474
|
+
const { width, height } = board.host.getBoundingClientRect();
|
|
475
|
+
const viewBox = getViewBox(board);
|
|
476
|
+
let x = (point[0] / width) * viewBox.width + viewBox.minX;
|
|
477
|
+
let y = (point[1] / height) * viewBox.height + viewBox.minY;
|
|
478
|
+
const newPoint = [x - board.viewport.offsetX, y - board.viewport.offsetY];
|
|
479
|
+
return newPoint;
|
|
480
|
+
}
|
|
481
|
+
function getViewBox(board) {
|
|
482
|
+
const { width, height } = board.host.getBoundingClientRect();
|
|
483
|
+
const scaleWidth = (board.viewport.zoom - 1) * width;
|
|
484
|
+
const scaleHeight = (board.viewport.zoom - 1) * height;
|
|
485
|
+
const viewBoxWidth = width - scaleWidth;
|
|
486
|
+
const viewBoxHeight = height - scaleHeight;
|
|
487
|
+
const minX = scaleWidth / 2;
|
|
488
|
+
const minY = scaleHeight / 2;
|
|
489
|
+
return { minX, minY: minY, width: viewBoxWidth, height: viewBoxHeight };
|
|
490
|
+
}
|
|
491
|
+
function isNoSelectionElement(e) {
|
|
492
|
+
var _a;
|
|
493
|
+
return (_a = e.target) === null || _a === void 0 ? void 0 : _a.closest('.plait-board-attached');
|
|
494
|
+
}
|
|
495
|
+
|
|
467
496
|
function withSelection(board) {
|
|
468
497
|
const { mousedown, mousemove, mouseup } = board;
|
|
469
498
|
let start = null;
|
|
470
499
|
let end = null;
|
|
471
500
|
board.mousedown = (event) => {
|
|
472
|
-
|
|
473
|
-
if (!(event.target instanceof HTMLElement && event.target.closest('.richtext'))) {
|
|
474
|
-
event.preventDefault();
|
|
475
|
-
}
|
|
476
|
-
if (board.cursor === BaseCursorStatus.select) {
|
|
501
|
+
if (!isNoSelectionElement(event) && board.cursor === BaseCursorStatus.select) {
|
|
477
502
|
start = toPoint(event.x, event.y, board.host);
|
|
478
503
|
}
|
|
479
504
|
mousedown(event);
|
|
@@ -489,6 +514,9 @@ function withSelection(board) {
|
|
|
489
514
|
mousemove(event);
|
|
490
515
|
};
|
|
491
516
|
board.mouseup = (event) => {
|
|
517
|
+
if (isNoSelectionElement(event)) {
|
|
518
|
+
return mouseup(event);
|
|
519
|
+
}
|
|
492
520
|
if (start) {
|
|
493
521
|
Transforms.setSelection(board, { anchor: start, focus: start });
|
|
494
522
|
}
|
|
@@ -509,31 +537,6 @@ const PlaitOperation = {
|
|
|
509
537
|
isSetViewportOperation
|
|
510
538
|
};
|
|
511
539
|
|
|
512
|
-
function transformPoints(board, points) {
|
|
513
|
-
const newPoints = points.map(point => {
|
|
514
|
-
return transformPoint(board, point);
|
|
515
|
-
});
|
|
516
|
-
return newPoints;
|
|
517
|
-
}
|
|
518
|
-
function transformPoint(board, point) {
|
|
519
|
-
const { width, height } = board.host.getBoundingClientRect();
|
|
520
|
-
const viewBox = getViewBox(board);
|
|
521
|
-
let x = (point[0] / width) * viewBox.width + viewBox.minX;
|
|
522
|
-
let y = (point[1] / height) * viewBox.height + viewBox.minY;
|
|
523
|
-
const newPoint = [x - board.viewport.offsetX, y - board.viewport.offsetY];
|
|
524
|
-
return newPoint;
|
|
525
|
-
}
|
|
526
|
-
function getViewBox(board) {
|
|
527
|
-
const { width, height } = board.host.getBoundingClientRect();
|
|
528
|
-
const scaleWidth = (board.viewport.zoom - 1) * width;
|
|
529
|
-
const scaleHeight = (board.viewport.zoom - 1) * height;
|
|
530
|
-
const viewBoxWidth = width - scaleWidth;
|
|
531
|
-
const viewBoxHeight = height - scaleHeight;
|
|
532
|
-
const minX = scaleWidth / 2;
|
|
533
|
-
const minY = scaleHeight / 2;
|
|
534
|
-
return { minX, minY: minY, width: viewBoxWidth, height: viewBoxHeight };
|
|
535
|
-
}
|
|
536
|
-
|
|
537
540
|
class PlaitElementComponent {
|
|
538
541
|
constructor(renderer2, viewContainerRef) {
|
|
539
542
|
this.renderer2 = renderer2;
|
|
@@ -663,7 +666,9 @@ class PlaitBoardComponent {
|
|
|
663
666
|
fromEvent(this.host, 'mousedown')
|
|
664
667
|
.pipe(takeUntil(this.destroy$))
|
|
665
668
|
.subscribe((event) => {
|
|
666
|
-
|
|
669
|
+
if (!isNoSelectionElement(event)) {
|
|
670
|
+
this.board.mousedown(event);
|
|
671
|
+
}
|
|
667
672
|
});
|
|
668
673
|
fromEvent(this.host, 'mousemove')
|
|
669
674
|
.pipe(takeUntil(this.destroy$))
|
|
@@ -673,7 +678,9 @@ class PlaitBoardComponent {
|
|
|
673
678
|
fromEvent(document, 'mouseup')
|
|
674
679
|
.pipe(takeUntil(this.destroy$))
|
|
675
680
|
.subscribe((event) => {
|
|
676
|
-
|
|
681
|
+
if (!isNoSelectionElement(event)) {
|
|
682
|
+
this.board.mouseup(event);
|
|
683
|
+
}
|
|
677
684
|
});
|
|
678
685
|
fromEvent(this.host, 'dblclick')
|
|
679
686
|
.pipe(takeUntil(this.destroy$))
|
|
@@ -742,8 +749,8 @@ class PlaitBoardComponent {
|
|
|
742
749
|
}
|
|
743
750
|
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 });
|
|
744
751
|
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" }, outputs: { plaitChange: "plaitChange", plaitBoardInitialized: "plaitBoardInitialized" }, host: { properties: { "class": "this.hostClass" } }, viewQueries: [{ propertyName: "svg", first: true, predicate: ["svg"], descendants: true, static: true }], ngImport: i0, template: `
|
|
745
|
-
<svg #svg width="100%" height="100%"></svg>
|
|
746
|
-
<div *ngIf="isFocused" class="plait-toolbar island zoom-toolbar">
|
|
752
|
+
<svg #svg width="100%" height="100%" style="position: relative"></svg>
|
|
753
|
+
<div *ngIf="isFocused" class="plait-toolbar island zoom-toolbar plait-board-attached">
|
|
747
754
|
<button class="item" (mousedown)="zoomOut($event)">-</button>
|
|
748
755
|
<button class="item zoom-value" (mousedown)="resetZoom($event)">{{ zoom }}%</button>
|
|
749
756
|
<button class="item" (mousedown)="zoomIn($event)">+</button>
|
|
@@ -764,8 +771,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
764
771
|
args: [{
|
|
765
772
|
selector: 'plait-board',
|
|
766
773
|
template: `
|
|
767
|
-
<svg #svg width="100%" height="100%"></svg>
|
|
768
|
-
<div *ngIf="isFocused" class="plait-toolbar island zoom-toolbar">
|
|
774
|
+
<svg #svg width="100%" height="100%" style="position: relative"></svg>
|
|
775
|
+
<div *ngIf="isFocused" class="plait-toolbar island zoom-toolbar plait-board-attached">
|
|
769
776
|
<button class="item" (mousedown)="zoomOut($event)">-</button>
|
|
770
777
|
<button class="item zoom-value" (mousedown)="resetZoom($event)">{{ zoom }}%</button>
|
|
771
778
|
<button class="item" (mousedown)="zoomIn($event)">+</button>
|
|
@@ -981,5 +988,5 @@ function rotate(x1, y1, x2, y2, angle) {
|
|
|
981
988
|
* Generated bundle index. Do not edit.
|
|
982
989
|
*/
|
|
983
990
|
|
|
984
|
-
export { BOARD_TO_ON_CHANGE, BaseCursorStatus, FLUSHING, HOST_TO_ROUGH_SVG, IS_APPLE, IS_CHROME, IS_CHROME_LEGACY, IS_EDGE_LEGACY, IS_FIREFOX, IS_IOS, IS_SAFARI, IS_TEXT_EDITABLE, NS, Path, PlaitBoardComponent, PlaitElementComponent, PlaitModule, PlaitNode, PlaitOperation, Transforms, Viewport, createG, createSVG, createText, distanceBetweenPointAndSegment, getViewBox, hotkeys, idCreator, isNullOrUndefined, isSetViewportOperation, rotate, toPoint, toRectangleClient, transformPoint, transformPoints };
|
|
991
|
+
export { BOARD_TO_ON_CHANGE, BaseCursorStatus, FLUSHING, HOST_TO_ROUGH_SVG, IS_APPLE, IS_CHROME, IS_CHROME_LEGACY, IS_EDGE_LEGACY, IS_FIREFOX, IS_IOS, IS_SAFARI, IS_TEXT_EDITABLE, NS, Path, PlaitBoardComponent, PlaitElementComponent, PlaitModule, PlaitNode, PlaitOperation, Transforms, Viewport, createG, createSVG, createText, distanceBetweenPointAndSegment, getViewBox, hotkeys, idCreator, isNoSelectionElement, isNullOrUndefined, isSetViewportOperation, rotate, toPoint, toRectangleClient, transformPoint, transformPoints };
|
|
985
992
|
//# sourceMappingURL=plait-core.mjs.map
|