@plait/core 0.0.47 → 0.0.48
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 +2 -1
- package/esm2020/board/board.component.mjs +11 -13
- package/esm2020/plugins/with-move.mjs +4 -1
- package/fesm2015/plait-core.mjs +13 -12
- package/fesm2015/plait-core.mjs.map +1 -1
- package/fesm2020/plait-core.mjs +13 -12
- package/fesm2020/plait-core.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -17,6 +17,8 @@ export declare class PlaitBoardComponent implements OnInit, OnChanges, AfterView
|
|
|
17
17
|
destroy$: Subject<any>;
|
|
18
18
|
private autoFitPadding;
|
|
19
19
|
isMoving: boolean;
|
|
20
|
+
scrollLeft: number;
|
|
21
|
+
scrollTop: number;
|
|
20
22
|
plaitValue: PlaitElement[];
|
|
21
23
|
plaitViewport: Viewport;
|
|
22
24
|
plaitPlugins: PlaitPlugin[];
|
|
@@ -42,7 +44,6 @@ export declare class PlaitBoardComponent implements OnInit, OnChanges, AfterView
|
|
|
42
44
|
initContainerSize(): void;
|
|
43
45
|
resizeViewport(): void;
|
|
44
46
|
setScroll(left: number, top: number): void;
|
|
45
|
-
getScrollOffset(left: number, top: number): void;
|
|
46
47
|
viewportChange(): void;
|
|
47
48
|
updateViewport(): void;
|
|
48
49
|
trackBy: (index: number, element: PlaitElement) => number;
|
|
@@ -180,7 +180,7 @@ export class PlaitBoardComponent {
|
|
|
180
180
|
.subscribe((event) => {
|
|
181
181
|
const scrollLeft = event.target.scrollLeft;
|
|
182
182
|
const scrollTop = event.target.scrollTop;
|
|
183
|
-
this.
|
|
183
|
+
this.setScroll(scrollLeft, scrollTop);
|
|
184
184
|
});
|
|
185
185
|
window.onresize = () => {
|
|
186
186
|
this.updateViewport();
|
|
@@ -203,13 +203,8 @@ export class PlaitBoardComponent {
|
|
|
203
203
|
this.renderer2.setStyle(this.contentContainer.nativeElement, 'maxHeight', height);
|
|
204
204
|
}
|
|
205
205
|
setScroll(left, top) {
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
top,
|
|
209
|
-
left
|
|
210
|
-
});
|
|
211
|
-
}
|
|
212
|
-
getScrollOffset(left, top) {
|
|
206
|
+
this.scrollLeft = left;
|
|
207
|
+
this.scrollTop = top;
|
|
213
208
|
const viewportBox = getViewportClientBox(this.board);
|
|
214
209
|
const viewBox = getViewBox(this.board);
|
|
215
210
|
const scrollLeftRatio = left / (viewBox.viewportWidth - viewportBox.width);
|
|
@@ -226,16 +221,19 @@ export class PlaitBoardComponent {
|
|
|
226
221
|
const viewportBox = getViewportClientBox(this.board);
|
|
227
222
|
const { minX, minY, width, height, viewportWidth, viewportHeight } = viewBox;
|
|
228
223
|
const box = [minX, minY, width, height];
|
|
229
|
-
|
|
230
|
-
|
|
224
|
+
this.scrollLeft = (viewportWidth - viewportBox.width) * offsetXRatio;
|
|
225
|
+
this.scrollTop = (viewportHeight - viewportBox.height) * offsetYRatio;
|
|
231
226
|
this.renderer2.setStyle(this.host, 'display', 'block');
|
|
232
227
|
this.renderer2.setStyle(this.host, 'width', `${viewportWidth}px`);
|
|
233
228
|
this.renderer2.setStyle(this.host, 'height', `${viewportHeight}px`);
|
|
234
|
-
this.renderer2.setStyle(this.host, 'cursor', this.isMoveMode ? 'grab' : 'default');
|
|
235
229
|
if (width > 0 && height > 0) {
|
|
236
230
|
this.renderer2.setAttribute(this.host, 'viewBox', box.join());
|
|
237
231
|
}
|
|
238
|
-
this.
|
|
232
|
+
const container = this.contentContainer.nativeElement;
|
|
233
|
+
container.scrollTo({
|
|
234
|
+
top: this.scrollTop,
|
|
235
|
+
left: this.scrollLeft
|
|
236
|
+
});
|
|
239
237
|
}
|
|
240
238
|
updateViewport() {
|
|
241
239
|
this.resizeViewport();
|
|
@@ -392,4 +390,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
392
390
|
type: ViewChild,
|
|
393
391
|
args: ['container', { read: ElementRef, static: true }]
|
|
394
392
|
}] } });
|
|
395
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.component.js","sourceRoot":"","sources":["../../../../packages/plait/src/board/board.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    Renderer2,\n    SimpleChanges,\n    TemplateRef,\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 { SCROLL_BAR_WIDTH } from '../constants';\nimport { BaseCursorStatus, PlaitOperation } from '../interfaces';\nimport { PlaitBoard, PlaitBoardChangeEvent, PlaitBoardOptions } from '../interfaces/board';\nimport { PlaitElement } from '../interfaces/element';\nimport { PlaitPlugin } from '../interfaces/plugin';\nimport { Viewport } from '../interfaces/viewport';\nimport { createBoard } from '../plugins/create-board';\nimport { withBoard } from '../plugins/with-board';\nimport { withHistory } from '../plugins/with-history';\nimport { withMove } from '../plugins/with-move';\nimport { withSelection } from '../plugins/with-selection';\nimport { Transforms } from '../transfroms';\nimport { calculateZoom, getViewBox, getViewportClientBox, updateCursorStatus } from '../utils/board';\nimport { BOARD_TO_ON_CHANGE, HOST_TO_ROUGH_SVG, IS_TEXT_EDITABLE, PLAIT_BOARD_TO_COMPONENT } from '../utils/weak-maps';\n\n@Component({\n    selector: 'plait-board',\n    template: `\n        <div class=\"container\" #container>\n            <svg #svg width=\"100%\" height=\"100%\" style=\"position: relative\"></svg>\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        </div>\n        <plait-toolbar\n            *ngIf=\"isFocused && !toolbarTemplateRef\"\n            [cursorStatus]=\"board.cursor\"\n            [viewZoom]=\"board.viewport!.zoom\"\n            (moveHandle)=\"changeMoveMode($event)\"\n            (adaptHandle)=\"adaptHandle()\"\n            (zoomInHandle)=\"zoomInHandle()\"\n            (zoomOutHandle)=\"zoomOutHandle()\"\n            (resetZoomHandel)=\"resetZoomHandel()\"\n        ></plait-toolbar>\n        <ng-content></ng-content>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PlaitBoardComponent implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n    hasInitialized = false;\n\n    board!: PlaitBoard;\n\n    roughSVG!: RoughSVG;\n\n    destroy$: Subject<any> = new Subject();\n\n    private autoFitPadding = 8;\n\n    public isMoving: boolean = false;\n\n    @Input() plaitValue: PlaitElement[] = [];\n\n    @Input() plaitViewport!: Viewport;\n\n    @Input() plaitPlugins: PlaitPlugin[] = [];\n\n    @Input() plaitOptions!: PlaitBoardOptions;\n\n    @Output() plaitChange: EventEmitter<PlaitBoardChangeEvent> = new EventEmitter();\n\n    @Output() plaitBoardInitialized: EventEmitter<PlaitBoard> = new EventEmitter();\n\n    public get isMoveMode(): boolean {\n        return this.board.cursor === BaseCursorStatus.move;\n    }\n\n    get host(): SVGElement {\n        return this.svg.nativeElement;\n    }\n\n    get isFocused() {\n        return this.board?.selection;\n    }\n\n    @HostBinding('class')\n    get hostClass() {\n        return `plait-board-container ${this.board.cursor}`;\n    }\n\n    @HostBinding('class.readonly')\n    get readonly() {\n        return this.board.options.readonly;\n    }\n\n    @HostBinding('class.moving')\n    get moving() {\n        return this.board.cursor === BaseCursorStatus.move && this.isMoving;\n    }\n\n    @HostBinding('class.focused')\n    get focused() {\n        return this.isFocused;\n    }\n\n    @ViewChild('svg', { static: true })\n    svg!: ElementRef;\n\n    @ContentChild('plaitToolbar')\n    public toolbarTemplateRef!: TemplateRef<any>;\n\n    @ViewChild('container', { read: ElementRef, static: true })\n    contentContainer!: ElementRef;\n\n    constructor(public cdr: ChangeDetectorRef, private renderer2: Renderer2, private elementRef: ElementRef) {}\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        PLAIT_BOARD_TO_COMPONENT.set(this.board, this);\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            if (this.board.operations.some(op => PlaitOperation.isSetViewportOperation(op))) {\n                this.updateViewport();\n            }\n            this.plaitChange.emit(changeEvent);\n        });\n        this.hasInitialized = true;\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (this.hasInitialized) {\n            const valueChange = changes['plaitValue'];\n            const options = changes['plaitOptions'];\n\n            if (valueChange) this.board.children = valueChange.currentValue;\n            if (options) this.board.options = options.currentValue;\n            this.cdr.markForCheck();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.plaitBoardInitialized.emit(this.board);\n        this.initContainerSize();\n        this.updateViewport();\n    }\n\n    private initializePlugins() {\n        let board = withMove(withHistory(withSelection(withBoard(createBoard(this.host, this.plaitValue, this.plaitOptions)))));\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    private 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<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        fromEvent<WheelEvent>(this.contentContainer.nativeElement, 'wheel')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter((e: WheelEvent) => {\n                    if (!this.isFocused) {\n                        e.preventDefault();\n                        e.stopPropagation();\n                    }\n                    return !!this.isFocused;\n                })\n            )\n            .subscribe();\n\n        fromEvent<MouseEvent>(this.contentContainer.nativeElement, 'scroll')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter((e: MouseEvent) => {\n                    if (!this.isFocused) {\n                        e.preventDefault();\n                        e.stopPropagation();\n                    }\n                    return !!this.isFocused;\n                })\n            )\n            .subscribe((event: Event) => {\n                const scrollLeft = (event.target as HTMLElement).scrollLeft;\n                const scrollTop = (event.target as HTMLElement).scrollTop;\n                this.getScrollOffset(scrollLeft, scrollTop);\n            });\n\n        window.onresize = () => {\n            this.updateViewport();\n        };\n    }\n\n    initContainerSize() {\n        this.renderer2.setStyle(this.contentContainer.nativeElement, 'overflow', 'auto');\n        this.resizeViewport();\n    }\n\n    resizeViewport() {\n        const container = this.elementRef.nativeElement?.parentElement;\n        const containerRect = container?.getBoundingClientRect();\n        const hideScrollbar = this.board.options.hideScrollbar;\n        const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;\n        const width = `${containerRect.width + scrollBarWidth}px`;\n        const height = `${containerRect.height + scrollBarWidth}px`;\n\n        this.renderer2.setStyle(this.contentContainer.nativeElement, 'width', width);\n        this.renderer2.setStyle(this.contentContainer.nativeElement, 'height', height);\n        this.renderer2.setStyle(this.contentContainer.nativeElement, 'maxWidth', width);\n        this.renderer2.setStyle(this.contentContainer.nativeElement, 'maxHeight', height);\n    }\n\n    setScroll(left: number, top: number) {\n        const container = this.contentContainer.nativeElement as HTMLElement;\n        container.scrollTo({\n            top,\n            left\n        });\n    }\n\n    getScrollOffset(left: number, top: number) {\n        const viewportBox = getViewportClientBox(this.board);\n        const viewBox = getViewBox(this.board);\n        const scrollLeftRatio = left / (viewBox.viewportWidth - viewportBox.width);\n        const scrollTopRatio = top / (viewBox.viewportHeight - viewportBox.height);\n\n        this.setViewport({\n            offsetXRatio: scrollLeftRatio,\n            offsetYRatio: scrollTopRatio\n        });\n    }\n\n    viewportChange() {\n        const viewBox = getViewBox(this.board);\n        const offsetXRatio = this.board.viewport.offsetXRatio;\n        const offsetYRatio = this.board.viewport.offsetYRatio;\n        const viewportBox = getViewportClientBox(this.board);\n        const { minX, minY, width, height, viewportWidth, viewportHeight } = viewBox;\n        const box = [minX, minY, width, height];\n        const scrollLeft = (viewportWidth - viewportBox.width) * offsetXRatio;\n        const scrollTop = (viewportHeight - viewportBox.height) * offsetYRatio;\n\n        this.renderer2.setStyle(this.host, 'display', 'block');\n        this.renderer2.setStyle(this.host, 'width', `${viewportWidth}px`);\n        this.renderer2.setStyle(this.host, 'height', `${viewportHeight}px`);\n        this.renderer2.setStyle(this.host, 'cursor', this.isMoveMode ? 'grab' : 'default');\n\n        if (width > 0 && height > 0) {\n            this.renderer2.setAttribute(this.host, 'viewBox', box.join());\n        }\n        this.setScroll(scrollLeft, scrollTop);\n    }\n\n    updateViewport() {\n        this.resizeViewport();\n        this.viewportChange();\n    }\n\n    trackBy = (index: number, element: PlaitElement) => {\n        return index;\n    };\n\n    // 拖拽模式\n    changeMoveMode(cursorStatus: BaseCursorStatus) {\n        updateCursorStatus(this.board, cursorStatus);\n        this.cdr.markForCheck();\n    }\n\n    // 适应画布\n    adaptHandle() {\n        const viewportBox = getViewportClientBox(this.board);\n        const rootGroup = this.host.firstChild;\n        const rootGroupBox = (rootGroup as SVGGraphicsElement).getBBox();\n        const viewportWidth = viewportBox.width - 2 * this.autoFitPadding;\n        const viewportHeight = viewportBox.height - 2 * this.autoFitPadding;\n\n        let zoom = this.board.viewport.zoom;\n        if (viewportWidth < rootGroupBox.width || viewportHeight < rootGroupBox.height) {\n            zoom = Math.min(viewportWidth / rootGroupBox.width, viewportHeight / rootGroupBox.height);\n        } else {\n            zoom = 1;\n        }\n\n        this.setViewport({\n            zoom,\n            offsetXRatio: 0.5,\n            offsetYRatio: 0.5\n        });\n    }\n\n    // 放大\n    zoomInHandle() {\n        const zoom = this.board.viewport.zoom;\n        this.setViewport({\n            zoom: calculateZoom(zoom + 0.1)\n        });\n    }\n\n    // 缩小\n    zoomOutHandle() {\n        const zoom = this.board.viewport.zoom;\n        this.setViewport({\n            zoom: calculateZoom(zoom - 0.1)\n        });\n    }\n\n    resetZoomHandel() {\n        this.setViewport({\n            zoom: 1\n        });\n    }\n\n    setViewport(options: Partial<Viewport>) {\n        const viewport = this.board?.viewport;\n        Transforms.setViewport(this.board, {\n            ...viewport,\n            ...options\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n        HOST_TO_ROUGH_SVG.delete(this.host);\n    }\n\n    movingChange(isMoving: boolean) {\n        this.isMoving = isMoving;\n    }\n}\n"]}
|
|
393
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.component.js","sourceRoot":"","sources":["../../../../packages/plait/src/board/board.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    Renderer2,\n    SimpleChanges,\n    TemplateRef,\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 { SCROLL_BAR_WIDTH } from '../constants';\nimport { BaseCursorStatus, PlaitOperation } from '../interfaces';\nimport { PlaitBoard, PlaitBoardChangeEvent, PlaitBoardOptions } from '../interfaces/board';\nimport { PlaitElement } from '../interfaces/element';\nimport { PlaitPlugin } from '../interfaces/plugin';\nimport { Viewport } from '../interfaces/viewport';\nimport { createBoard } from '../plugins/create-board';\nimport { withBoard } from '../plugins/with-board';\nimport { withHistory } from '../plugins/with-history';\nimport { withMove } from '../plugins/with-move';\nimport { withSelection } from '../plugins/with-selection';\nimport { Transforms } from '../transfroms';\nimport { calculateZoom, getViewBox, getViewportClientBox, updateCursorStatus } from '../utils/board';\nimport { BOARD_TO_ON_CHANGE, HOST_TO_ROUGH_SVG, IS_TEXT_EDITABLE, PLAIT_BOARD_TO_COMPONENT } from '../utils/weak-maps';\n\n@Component({\n    selector: 'plait-board',\n    template: `\n        <div class=\"container\" #container>\n            <svg #svg width=\"100%\" height=\"100%\" style=\"position: relative\"></svg>\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        </div>\n        <plait-toolbar\n            *ngIf=\"isFocused && !toolbarTemplateRef\"\n            [cursorStatus]=\"board.cursor\"\n            [viewZoom]=\"board.viewport!.zoom\"\n            (moveHandle)=\"changeMoveMode($event)\"\n            (adaptHandle)=\"adaptHandle()\"\n            (zoomInHandle)=\"zoomInHandle()\"\n            (zoomOutHandle)=\"zoomOutHandle()\"\n            (resetZoomHandel)=\"resetZoomHandel()\"\n        ></plait-toolbar>\n        <ng-content></ng-content>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PlaitBoardComponent implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n    hasInitialized = false;\n\n    board!: PlaitBoard;\n\n    roughSVG!: RoughSVG;\n\n    destroy$: Subject<any> = new Subject();\n\n    private autoFitPadding = 8;\n\n    public isMoving: boolean = false;\n\n    scrollLeft!: number;\n\n    scrollTop!: number;\n\n    @Input() plaitValue: PlaitElement[] = [];\n\n    @Input() plaitViewport!: Viewport;\n\n    @Input() plaitPlugins: PlaitPlugin[] = [];\n\n    @Input() plaitOptions!: PlaitBoardOptions;\n\n    @Output() plaitChange: EventEmitter<PlaitBoardChangeEvent> = new EventEmitter();\n\n    @Output() plaitBoardInitialized: EventEmitter<PlaitBoard> = new EventEmitter();\n\n    public get isMoveMode(): boolean {\n        return this.board.cursor === BaseCursorStatus.move;\n    }\n\n    get host(): SVGElement {\n        return this.svg.nativeElement;\n    }\n\n    get isFocused() {\n        return this.board?.selection;\n    }\n\n    @HostBinding('class')\n    get hostClass() {\n        return `plait-board-container ${this.board.cursor}`;\n    }\n\n    @HostBinding('class.readonly')\n    get readonly() {\n        return this.board.options.readonly;\n    }\n\n    @HostBinding('class.moving')\n    get moving() {\n        return this.board.cursor === BaseCursorStatus.move && this.isMoving;\n    }\n\n    @HostBinding('class.focused')\n    get focused() {\n        return this.isFocused;\n    }\n\n    @ViewChild('svg', { static: true })\n    svg!: ElementRef;\n\n    @ContentChild('plaitToolbar')\n    public toolbarTemplateRef!: TemplateRef<any>;\n\n    @ViewChild('container', { read: ElementRef, static: true })\n    contentContainer!: ElementRef;\n\n    constructor(public cdr: ChangeDetectorRef, private renderer2: Renderer2, private elementRef: ElementRef) {}\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        PLAIT_BOARD_TO_COMPONENT.set(this.board, this);\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            if (this.board.operations.some(op => PlaitOperation.isSetViewportOperation(op))) {\n                this.updateViewport();\n            }\n            this.plaitChange.emit(changeEvent);\n        });\n        this.hasInitialized = true;\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (this.hasInitialized) {\n            const valueChange = changes['plaitValue'];\n            const options = changes['plaitOptions'];\n\n            if (valueChange) this.board.children = valueChange.currentValue;\n            if (options) this.board.options = options.currentValue;\n            this.cdr.markForCheck();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.plaitBoardInitialized.emit(this.board);\n        this.initContainerSize();\n        this.updateViewport();\n    }\n\n    private initializePlugins() {\n        let board = withMove(withHistory(withSelection(withBoard(createBoard(this.host, this.plaitValue, this.plaitOptions)))));\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    private 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<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        fromEvent<WheelEvent>(this.contentContainer.nativeElement, 'wheel')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter((e: WheelEvent) => {\n                    if (!this.isFocused) {\n                        e.preventDefault();\n                        e.stopPropagation();\n                    }\n                    return !!this.isFocused;\n                })\n            )\n            .subscribe();\n\n        fromEvent<MouseEvent>(this.contentContainer.nativeElement, 'scroll')\n            .pipe(\n                takeUntil(this.destroy$),\n                filter((e: MouseEvent) => {\n                    if (!this.isFocused) {\n                        e.preventDefault();\n                        e.stopPropagation();\n                    }\n                    return !!this.isFocused;\n                })\n            )\n            .subscribe((event: Event) => {\n                const scrollLeft = (event.target as HTMLElement).scrollLeft;\n                const scrollTop = (event.target as HTMLElement).scrollTop;\n                this.setScroll(scrollLeft, scrollTop);\n            });\n\n        window.onresize = () => {\n            this.updateViewport();\n        };\n    }\n\n    initContainerSize() {\n        this.renderer2.setStyle(this.contentContainer.nativeElement, 'overflow', 'auto');\n        this.resizeViewport();\n    }\n\n    resizeViewport() {\n        const container = this.elementRef.nativeElement?.parentElement;\n        const containerRect = container?.getBoundingClientRect();\n        const hideScrollbar = this.board.options.hideScrollbar;\n        const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;\n        const width = `${containerRect.width + scrollBarWidth}px`;\n        const height = `${containerRect.height + scrollBarWidth}px`;\n\n        this.renderer2.setStyle(this.contentContainer.nativeElement, 'width', width);\n        this.renderer2.setStyle(this.contentContainer.nativeElement, 'height', height);\n        this.renderer2.setStyle(this.contentContainer.nativeElement, 'maxWidth', width);\n        this.renderer2.setStyle(this.contentContainer.nativeElement, 'maxHeight', height);\n    }\n\n    setScroll(left: number, top: number) {\n        this.scrollLeft = left;\n        this.scrollTop = top;\n        const viewportBox = getViewportClientBox(this.board);\n        const viewBox = getViewBox(this.board);\n        const scrollLeftRatio = left / (viewBox.viewportWidth - viewportBox.width);\n        const scrollTopRatio = top / (viewBox.viewportHeight - viewportBox.height);\n\n        this.setViewport({\n            offsetXRatio: scrollLeftRatio,\n            offsetYRatio: scrollTopRatio\n        });\n    }\n\n    viewportChange() {\n        const viewBox = getViewBox(this.board);\n        const offsetXRatio = this.board.viewport.offsetXRatio;\n        const offsetYRatio = this.board.viewport.offsetYRatio;\n        const viewportBox = getViewportClientBox(this.board);\n        const { minX, minY, width, height, viewportWidth, viewportHeight } = viewBox;\n        const box = [minX, minY, width, height];\n        this.scrollLeft = (viewportWidth - viewportBox.width) * offsetXRatio;\n        this.scrollTop = (viewportHeight - viewportBox.height) * offsetYRatio;\n\n        this.renderer2.setStyle(this.host, 'display', 'block');\n        this.renderer2.setStyle(this.host, 'width', `${viewportWidth}px`);\n        this.renderer2.setStyle(this.host, 'height', `${viewportHeight}px`);\n\n        if (width > 0 && height > 0) {\n            this.renderer2.setAttribute(this.host, 'viewBox', box.join());\n        }\n        const container = this.contentContainer.nativeElement as HTMLElement;\n        container.scrollTo({\n            top: this.scrollTop,\n            left: this.scrollLeft\n        });\n    }\n\n    updateViewport() {\n        this.resizeViewport();\n        this.viewportChange();\n    }\n\n    trackBy = (index: number, element: PlaitElement) => {\n        return index;\n    };\n\n    // 拖拽模式\n    changeMoveMode(cursorStatus: BaseCursorStatus) {\n        updateCursorStatus(this.board, cursorStatus);\n        this.cdr.markForCheck();\n    }\n\n    // 适应画布\n    adaptHandle() {\n        const viewportBox = getViewportClientBox(this.board);\n        const rootGroup = this.host.firstChild;\n        const rootGroupBox = (rootGroup as SVGGraphicsElement).getBBox();\n        const viewportWidth = viewportBox.width - 2 * this.autoFitPadding;\n        const viewportHeight = viewportBox.height - 2 * this.autoFitPadding;\n\n        let zoom = this.board.viewport.zoom;\n        if (viewportWidth < rootGroupBox.width || viewportHeight < rootGroupBox.height) {\n            zoom = Math.min(viewportWidth / rootGroupBox.width, viewportHeight / rootGroupBox.height);\n        } else {\n            zoom = 1;\n        }\n\n        this.setViewport({\n            zoom,\n            offsetXRatio: 0.5,\n            offsetYRatio: 0.5\n        });\n    }\n\n    // 放大\n    zoomInHandle() {\n        const zoom = this.board.viewport.zoom;\n        this.setViewport({\n            zoom: calculateZoom(zoom + 0.1)\n        });\n    }\n\n    // 缩小\n    zoomOutHandle() {\n        const zoom = this.board.viewport.zoom;\n        this.setViewport({\n            zoom: calculateZoom(zoom - 0.1)\n        });\n    }\n\n    resetZoomHandel() {\n        this.setViewport({\n            zoom: 1\n        });\n    }\n\n    setViewport(options: Partial<Viewport>) {\n        const viewport = this.board?.viewport;\n        Transforms.setViewport(this.board, {\n            ...viewport,\n            ...options\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n        HOST_TO_ROUGH_SVG.delete(this.host);\n    }\n\n    movingChange(isMoving: boolean) {\n        this.isMoving = isMoving;\n    }\n}\n"]}
|
|
@@ -25,6 +25,9 @@ export function withMove(board) {
|
|
|
25
25
|
board.mousemove = (event) => {
|
|
26
26
|
const boardComponent = PLAIT_BOARD_TO_COMPONENT.get(board);
|
|
27
27
|
if (board.cursor === BaseCursorStatus.move && board.selection && boardComponent.isMoving) {
|
|
28
|
+
const left = event.x - plaitBoardMove.x;
|
|
29
|
+
const top = event.y - plaitBoardMove.y;
|
|
30
|
+
boardComponent.setScroll(boardComponent.scrollLeft - left, boardComponent.scrollTop - top);
|
|
28
31
|
plaitBoardMove.x = event.x;
|
|
29
32
|
plaitBoardMove.y = event.y;
|
|
30
33
|
}
|
|
@@ -60,4 +63,4 @@ export function withMove(board) {
|
|
|
60
63
|
};
|
|
61
64
|
return board;
|
|
62
65
|
}
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1tb3ZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3BsdWdpbnMvd2l0aC1tb3ZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBOEIsTUFBTSxlQUFlLENBQUM7QUFDN0UsT0FBTyxFQUFFLHdCQUF3QixFQUFFLGtCQUFrQixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRXhFLE1BQU0sVUFBVSxRQUFRLENBQXVCLEtBQVE7SUFDbkQsTUFBTSxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsYUFBYSxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsR0FBRyxLQUFLLENBQUM7SUFFdEUsTUFBTSxjQUFjLEdBQW1CO1FBQ25DLENBQUMsRUFBRSxDQUFDO1FBQ0osQ0FBQyxFQUFFLENBQUM7S0FDUCxDQUFDO0lBRUYsS0FBSyxDQUFDLFNBQVMsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtRQUNwQyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFO1lBQ3hCLGtCQUFrQixDQUFDLEtBQUssRUFBRSxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUNwRDthQUFNLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFO1lBQ3pCLGtCQUFrQixDQUFDLEtBQUssRUFBRSxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUN0RDtRQUNELElBQUksS0FBSyxDQUFDLE1BQU0sS0FBSyxnQkFBZ0IsQ0FBQyxJQUFJLElBQUksS0FBSyxDQUFDLFNBQVMsRUFBRTtZQUMzRCxNQUFNLGNBQWMsR0FBRyx3QkFBd0IsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUF3QixDQUFDO1lBQ2xGLGNBQWMsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDbEMsY0FBYyxDQUFDLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDO1lBQzNCLGNBQWMsQ0FB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dEJvYXJkQ29tcG9uZW50IH0gZnJvbSAnLi4vYm9hcmQvYm9hcmQuY29tcG9uZW50JztcbmltcG9ydCB7IEJhc2VDdXJzb3JTdGF0dXMsIFBsYWl0Qm9hcmQsIFBsYWl0Qm9hcmRNb3ZlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBQTEFJVF9CT0FSRF9UT19DT01QT05FTlQsIHVwZGF0ZUN1cnNvclN0YXR1cyB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGZ1bmN0aW9uIHdpdGhNb3ZlPFQgZXh0ZW5kcyBQbGFpdEJvYXJkPihib2FyZDogVCkge1xuICAgIGNvbnN0IHsgbW91c2Vkb3duLCBtb3VzZW1vdmUsIGdsb2JhbE1vdXNldXAsIGtleWRvd24sIGtleXVwIH0gPSBib2FyZDtcblxuICAgIGNvbnN0IHBsYWl0Qm9hcmRNb3ZlOiBQbGFpdEJvYXJkTW92ZSA9IHtcbiAgICAgICAgeDogMCxcbiAgICAgICAgeTogMFxuICAgIH07XG5cbiAgICBib2FyZC5tb3VzZWRvd24gPSAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHtcbiAgICAgICAgaWYgKGJvYXJkLm9wdGlvbnMucmVhZG9ubHkpIHtcbiAgICAgICAgICAgIHVwZGF0ZUN1cnNvclN0YXR1cyhib2FyZCwgQmFzZUN1cnNvclN0YXR1cy5tb3ZlKTtcbiAgICAgICAgfSBlbHNlIGlmICghYm9hcmQuc2VsZWN0aW9uKSB7XG4gICAgICAgICAgICB1cGRhdGVDdXJzb3JTdGF0dXMoYm9hcmQsIEJhc2VDdXJzb3JTdGF0dXMuc2VsZWN0KTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoYm9hcmQuY3Vyc29yID09PSBCYXNlQ3Vyc29yU3RhdHVzLm1vdmUgJiYgYm9hcmQuc2VsZWN0aW9uKSB7XG4gICAgICAgICAgICBjb25zdCBib2FyZENvbXBvbmVudCA9IFBMQUlUX0JPQVJEX1RPX0NPTVBPTkVOVC5nZXQoYm9hcmQpIGFzIFBsYWl0Qm9hcmRDb21wb25lbnQ7XG4gICAgICAgICAgICBib2FyZENvbXBvbmVudC5tb3ZpbmdDaGFuZ2UodHJ1ZSk7XG4gICAgICAgICAgICBwbGFpdEJvYXJkTW92ZS54ID0gZXZlbnQueDtcbiAgICAgICAgICAgIHBsYWl0Qm9hcmRNb3ZlLnkgPSBldmVudC55O1xuICAgICAgICAgICAgYm9hcmRDb21wb25lbnQuY2RyLm1hcmtGb3JDaGVjaygpO1xuICAgICAgICB9XG4gICAgICAgIG1vdXNlZG93bihldmVudCk7XG4gICAgfTtcblxuICAgIGJvYXJkLm1vdXNlbW92ZSA9IChldmVudDogTW91c2VFdmVudCkgPT4ge1xuICAgICAgICBjb25zdCBib2FyZENvbXBvbmVudCA9IFBMQUlUX0JPQVJEX1RPX0NPTVBPTkVOVC5nZXQoYm9hcmQpIGFzIFBsYWl0Qm9hcmRDb21wb25lbnQ7XG4gICAgICAgIGlmIChib2FyZC5jdXJzb3IgPT09IEJhc2VDdXJzb3JTdGF0dXMubW92ZSAmJiBib2FyZC5zZWxlY3Rpb24gJiYgYm9hcmRDb21wb25lbnQuaXNNb3ZpbmcpIHtcbiAgICAgICAgICAgIGNvbnN0IGxlZnQgPSBldmVudC54IC0gcGxhaXRCb2FyZE1vdmUueDtcbiAgICAgICAgICAgIGNvbnN0IHRvcCA9IGV2ZW50LnkgLSBwbGFpdEJvYXJkTW92ZS55O1xuICAgICAgICAgICAgYm9hcmRDb21wb25lbnQuc2V0U2Nyb2xsKGJvYXJkQ29tcG9uZW50LnNjcm9sbExlZnQgLSBsZWZ0LCBib2FyZENvbXBvbmVudC5zY3JvbGxUb3AgLSB0b3ApO1xuICAgICAgICAgICAgcGxhaXRCb2FyZE1vdmUueCA9IGV2ZW50Lng7XG4gICAgICAgICAgICBwbGFpdEJvYXJkTW92ZS55ID0gZXZlbnQueTtcbiAgICAgICAgfVxuICAgICAgICBtb3VzZW1vdmUoZXZlbnQpO1xuICAgIH07XG5cbiAgICBib2FyZC5nbG9iYWxNb3VzZXVwID0gKGV2ZW50OiBNb3VzZUV2ZW50KSA9PiB7XG4gICAgICAgIGlmIChib2FyZC5zZWxlY3Rpb24pIHtcbiAgICAgICAgICAgIGNvbnN0IGJvYXJkQ29tcG9uZW50ID0gUExBSVRfQk9BUkRfVE9fQ09NUE9ORU5ULmdldChib2FyZCkgYXMgUGxhaXRCb2FyZENvbXBvbmVudDtcbiAgICAgICAgICAgIGJvYXJkQ29tcG9uZW50Lm1vdmluZ0NoYW5nZShmYWxzZSk7XG4gICAgICAgICAgICBwbGFpdEJvYXJkTW92ZS54ID0gMDtcbiAgICAgICAgICAgIHBsYWl0Qm9hcmRNb3ZlLnkgPSAwO1xuICAgICAgICB9XG4gICAgICAgIGdsb2JhbE1vdXNldXAoZXZlbnQpO1xuICAgIH07XG5cbiAgICBib2FyZC5rZXlkb3duID0gKGV2ZW50OiBLZXlib2FyZEV2ZW50KSA9PiB7XG4gICAgICAgIGlmIChib2FyZC5zZWxlY3Rpb24gJiYgZXZlbnQuY29kZSA9PT0gJ1NwYWNlJykge1xuICAgICAgICAgICAgaWYgKGJvYXJkLmN1cnNvciAhPT0gQmFzZUN1cnNvclN0YXR1cy5tb3ZlKSB7XG4gICAgICAgICAgICAgICAgdXBkYXRlQ3Vyc29yU3RhdHVzKGJvYXJkLCBCYXNlQ3Vyc29yU3RhdHVzLm1vdmUpO1xuICAgICAgICAgICAgICAgIGNvbnN0IGJvYXJkQ29tcG9uZW50ID0gUExBSVRfQk9BUkRfVE9fQ09NUE9ORU5ULmdldChib2FyZCkgYXMgUGxhaXRCb2FyZENvbXBvbmVudDtcbiAgICAgICAgICAgICAgICBib2FyZENvbXBvbmVudC5jZHIubWFya0ZvckNoZWNrKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICB9XG4gICAgICAgIGtleWRvd24oZXZlbnQpO1xuICAgIH07XG5cbiAgICBib2FyZC5rZXl1cCA9IChldmVudDogS2V5Ym9hcmRFdmVudCkgPT4ge1xuICAgICAgICBpZiAoYm9hcmQuc2VsZWN0aW9uICYmICFib2FyZC5vcHRpb25zLnJlYWRvbmx5ICYmIGV2ZW50LmNvZGUgPT09ICdTcGFjZScpIHtcbiAgICAgICAgICAgIHVwZGF0ZUN1cnNvclN0YXR1cyhib2FyZCwgQmFzZUN1cnNvclN0YXR1cy5zZWxlY3QpO1xuICAgICAgICAgICAgY29uc3QgYm9hcmRDb21wb25lbnQgPSBQTEFJVF9CT0FSRF9UT19DT01QT05FTlQuZ2V0KGJvYXJkKSBhcyBQbGFpdEJvYXJkQ29tcG9uZW50O1xuICAgICAgICAgICAgYm9hcmRDb21wb25lbnQuY2RyLm1hcmtGb3JDaGVjaygpO1xuICAgICAgICB9XG4gICAgICAgIGtleXVwKGV2ZW50KTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIGJvYXJkO1xufVxuIl19
|
package/fesm2015/plait-core.mjs
CHANGED
|
@@ -971,6 +971,9 @@ function withMove(board) {
|
|
|
971
971
|
board.mousemove = (event) => {
|
|
972
972
|
const boardComponent = PLAIT_BOARD_TO_COMPONENT.get(board);
|
|
973
973
|
if (board.cursor === BaseCursorStatus.move && board.selection && boardComponent.isMoving) {
|
|
974
|
+
const left = event.x - plaitBoardMove.x;
|
|
975
|
+
const top = event.y - plaitBoardMove.y;
|
|
976
|
+
boardComponent.setScroll(boardComponent.scrollLeft - left, boardComponent.scrollTop - top);
|
|
974
977
|
plaitBoardMove.x = event.x;
|
|
975
978
|
plaitBoardMove.y = event.y;
|
|
976
979
|
}
|
|
@@ -1338,7 +1341,7 @@ class PlaitBoardComponent {
|
|
|
1338
1341
|
.subscribe((event) => {
|
|
1339
1342
|
const scrollLeft = event.target.scrollLeft;
|
|
1340
1343
|
const scrollTop = event.target.scrollTop;
|
|
1341
|
-
this.
|
|
1344
|
+
this.setScroll(scrollLeft, scrollTop);
|
|
1342
1345
|
});
|
|
1343
1346
|
window.onresize = () => {
|
|
1344
1347
|
this.updateViewport();
|
|
@@ -1362,13 +1365,8 @@ class PlaitBoardComponent {
|
|
|
1362
1365
|
this.renderer2.setStyle(this.contentContainer.nativeElement, 'maxHeight', height);
|
|
1363
1366
|
}
|
|
1364
1367
|
setScroll(left, top) {
|
|
1365
|
-
|
|
1366
|
-
|
|
1367
|
-
top,
|
|
1368
|
-
left
|
|
1369
|
-
});
|
|
1370
|
-
}
|
|
1371
|
-
getScrollOffset(left, top) {
|
|
1368
|
+
this.scrollLeft = left;
|
|
1369
|
+
this.scrollTop = top;
|
|
1372
1370
|
const viewportBox = getViewportClientBox(this.board);
|
|
1373
1371
|
const viewBox = getViewBox(this.board);
|
|
1374
1372
|
const scrollLeftRatio = left / (viewBox.viewportWidth - viewportBox.width);
|
|
@@ -1385,16 +1383,19 @@ class PlaitBoardComponent {
|
|
|
1385
1383
|
const viewportBox = getViewportClientBox(this.board);
|
|
1386
1384
|
const { minX, minY, width, height, viewportWidth, viewportHeight } = viewBox;
|
|
1387
1385
|
const box = [minX, minY, width, height];
|
|
1388
|
-
|
|
1389
|
-
|
|
1386
|
+
this.scrollLeft = (viewportWidth - viewportBox.width) * offsetXRatio;
|
|
1387
|
+
this.scrollTop = (viewportHeight - viewportBox.height) * offsetYRatio;
|
|
1390
1388
|
this.renderer2.setStyle(this.host, 'display', 'block');
|
|
1391
1389
|
this.renderer2.setStyle(this.host, 'width', `${viewportWidth}px`);
|
|
1392
1390
|
this.renderer2.setStyle(this.host, 'height', `${viewportHeight}px`);
|
|
1393
|
-
this.renderer2.setStyle(this.host, 'cursor', this.isMoveMode ? 'grab' : 'default');
|
|
1394
1391
|
if (width > 0 && height > 0) {
|
|
1395
1392
|
this.renderer2.setAttribute(this.host, 'viewBox', box.join());
|
|
1396
1393
|
}
|
|
1397
|
-
this.
|
|
1394
|
+
const container = this.contentContainer.nativeElement;
|
|
1395
|
+
container.scrollTo({
|
|
1396
|
+
top: this.scrollTop,
|
|
1397
|
+
left: this.scrollLeft
|
|
1398
|
+
});
|
|
1398
1399
|
}
|
|
1399
1400
|
updateViewport() {
|
|
1400
1401
|
this.resizeViewport();
|