@plait/core 0.13.0 → 0.15.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/constants/index.d.ts +1 -0
- package/core/island/island-base.component.d.ts +18 -1
- package/esm2020/board/board.component.mjs +17 -29
- package/esm2020/constants/index.mjs +2 -1
- package/esm2020/core/island/island-base.component.mjs +38 -2
- package/esm2020/interfaces/board.mjs +13 -4
- package/esm2020/plugins/create-board.mjs +2 -1
- package/esm2020/plugins/with-hotkey.mjs +54 -0
- package/esm2020/transforms/board.mjs +2 -2
- package/esm2020/utils/draw/line.mjs +20 -1
- package/esm2020/utils/weak-maps.mjs +2 -1
- package/fesm2015/plait-core.mjs +182 -79
- package/fesm2015/plait-core.mjs.map +1 -1
- package/fesm2020/plait-core.mjs +182 -79
- package/fesm2020/plait-core.mjs.map +1 -1
- package/interfaces/board.d.ts +3 -1
- package/package.json +1 -1
- package/plugins/with-hotkey.d.ts +2 -0
- package/utils/draw/line.d.ts +1 -0
- package/utils/weak-maps.d.ts +1 -0
|
@@ -23,7 +23,7 @@ const updatePointerType = (board, pointer) => {
|
|
|
23
23
|
};
|
|
24
24
|
function updateZoom(board, newZoom, isCenter = true) {
|
|
25
25
|
newZoom = clampZoomLevel(newZoom);
|
|
26
|
-
const mousePoint = PlaitBoard.
|
|
26
|
+
const mousePoint = PlaitBoard.getMovingPointInBoard(board);
|
|
27
27
|
const nativeElement = PlaitBoard.getBoardContainer(board);
|
|
28
28
|
const nativeElementRect = nativeElement.getBoundingClientRect();
|
|
29
29
|
const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();
|
|
@@ -116,4 +116,4 @@ export const BoardTransforms = {
|
|
|
116
116
|
updateThemeColor,
|
|
117
117
|
fitViewportWidth
|
|
118
118
|
};
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.js","sourceRoot":"","sources":["../../../../packages/plait/src/transforms/board.ts"],"names":[],"mappings":"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","sourcesContent":["import { ThemeColorMode } from '../interfaces/theme';\nimport { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\nimport { PlaitPointerType } from '../interfaces/pointer';\nimport { toPoint } from '../utils/dom/common';\nimport { getRectangleByElements } from '../utils/element';\nimport { distanceBetweenPointAndRectangle } from '../utils/math';\nimport {\n    clampZoomLevel,\n    clearViewportOrigination,\n    getViewBoxCenterPoint,\n    getViewportOrigination,\n    initializeViewportContainer\n} from '../utils/viewport';\nimport { BOARD_TO_COMPONENT } from '../utils/weak-maps';\nimport { setViewport } from './viewport';\nimport { depthFirstRecursion, getRealScrollBarWidth } from '../utils';\nimport { PlaitElement } from '../interfaces/element';\nimport { setTheme } from './theme';\nimport { FitViewportOptions } from '../interfaces/viewport';\n\nfunction updateViewport(board: PlaitBoard, origination: Point, zoom?: number) {\n    zoom = zoom ?? board.viewport.zoom;\n    setViewport(board, {\n        ...board.viewport,\n        zoom,\n        origination\n    });\n    clearViewportOrigination(board);\n}\n\nconst updatePointerType = <T extends string = PlaitPointerType>(board: PlaitBoard, pointer: T) => {\n    board.pointer = pointer;\n    const boardComponent = BOARD_TO_COMPONENT.get(board);\n    boardComponent?.markForCheck();\n};\n\nfunction updateZoom(board: PlaitBoard, newZoom: number, isCenter = true) {\n    newZoom = clampZoomLevel(newZoom);\n\n    const mousePoint = PlaitBoard.getMovingPoint(board);\n    const nativeElement = PlaitBoard.getBoardContainer(board);\n    const nativeElementRect = nativeElement.getBoundingClientRect();\n    const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    let focusPoint = [boardContainerRect.width / 2, boardContainerRect.height / 2];\n\n    if (!isCenter && mousePoint && distanceBetweenPointAndRectangle(mousePoint[0], mousePoint[1], nativeElementRect) === 0) {\n        focusPoint = toPoint(mousePoint[0], mousePoint[1], (nativeElement as unknown) as SVGElement);\n    }\n\n    const zoom = board.viewport.zoom;\n    const origination = getViewportOrigination(board);\n    const centerX = origination![0] + focusPoint[0] / zoom;\n    const centerY = origination![1] + focusPoint[1] / zoom;\n    const newOrigination = [centerX - focusPoint[0] / newZoom, centerY - focusPoint[1] / newZoom] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\nfunction fitViewport(board: PlaitBoard) {\n    let scrollBarWidth = getRealScrollBarWidth(board);\n\n    const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    const elementHostBox = getRectangleByElements(board, board.children, true);\n    const zoom = board.viewport.zoom;\n    const autoFitPadding = 16;\n    const viewportWidth = boardContainerRect.width - 2 * autoFitPadding;\n    const viewportHeight = boardContainerRect.height - 2 * autoFitPadding;\n\n    let newZoom = zoom;\n    if (viewportWidth < elementHostBox.width || viewportHeight < elementHostBox.height) {\n        newZoom = Math.min(viewportWidth / elementHostBox.width, viewportHeight / elementHostBox.height);\n    } else {\n        newZoom = 1;\n    }\n\n    const centerPoint = getViewBoxCenterPoint(board);\n    const newOrigination = [\n        centerPoint[0] - boardContainerRect.width / 2 / newZoom + scrollBarWidth / 2 / zoom,\n        centerPoint[1] - boardContainerRect.height / 2 / newZoom + scrollBarWidth / 2 / zoom\n    ] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\nfunction fitViewportWidth(board: PlaitBoard, options: FitViewportOptions) {\n    let scrollBarWidth = getRealScrollBarWidth(board);\n\n    const boardContainer = PlaitBoard.getBoardContainer(board);\n    const boardContainerRectangle = boardContainer.getBoundingClientRect();\n\n    let finalWidth = 0;\n    if (options.maxWidth) {\n        finalWidth = options.maxWidth;\n    } else {\n        finalWidth = boardContainerRectangle.width;\n    }\n\n    const elementHostBox = getRectangleByElements(board, board.children, true);\n    const contentWidth = finalWidth - 2 * options.autoFitPadding;\n    let newZoom = 0;\n    if (contentWidth < elementHostBox.width) {\n        newZoom = Math.min(contentWidth / elementHostBox.width);\n    } else {\n        newZoom = 1;\n    }\n\n    let finalHeight = elementHostBox.height * newZoom + 2 * options.autoFitPadding;\n    if (finalHeight > options.limitHeight) {\n        const containerEl = boardContainer.closest(`.${options.containerClass}`) as HTMLElement;\n        containerEl.style.height = `${finalHeight}px`;\n        initializeViewportContainer(board);\n    } else {\n        finalHeight = options.limitHeight;\n    }\n\n    const centerX = elementHostBox.x + elementHostBox.width / 2;\n    const centerY = elementHostBox.y + elementHostBox.height / 2;\n    const newOrigination = [\n        centerX - finalWidth / 2 / newZoom + scrollBarWidth / 2 / newZoom,\n        centerY - finalHeight / 2 / newZoom + scrollBarWidth / 2 / newZoom\n    ] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\n/**\n * apply theme to every element (remove element custom properties)\n * invoke applyThemeColor\n */\nfunction updateThemeColor(board: PlaitBoard, mode: ThemeColorMode) {\n    mode = mode ?? board.theme.themeColorMode;\n    setTheme(board, { themeColorMode: mode });\n\n    depthFirstRecursion((board as unknown) as PlaitElement, element => {\n        board.applyTheme(element);\n    });\n}\n\nexport const BoardTransforms = {\n    updatePointerType,\n    updateViewport,\n    fitViewport,\n    updateZoom,\n    updateThemeColor,\n    fitViewportWidth\n};\n"]}
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.js","sourceRoot":"","sources":["../../../../packages/plait/src/transforms/board.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAGjD,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,sBAAsB,EAAE,MAAM,kBAAkB,CAAC;AAC1D,OAAO,EAAE,gCAAgC,EAAE,MAAM,eAAe,CAAC;AACjE,OAAO,EACH,cAAc,EACd,wBAAwB,EACxB,qBAAqB,EACrB,sBAAsB,EACtB,2BAA2B,EAC9B,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AAEtE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAGnC,SAAS,cAAc,CAAC,KAAiB,EAAE,WAAkB,EAAE,IAAa;IACxE,IAAI,GAAG,IAAI,IAAI,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC;IACnC,WAAW,CAAC,KAAK,EAAE;QACf,GAAG,KAAK,CAAC,QAAQ;QACjB,IAAI;QACJ,WAAW;KACd,CAAC,CAAC;IACH,wBAAwB,CAAC,KAAK,CAAC,CAAC;AACpC,CAAC;AAED,MAAM,iBAAiB,GAAG,CAAsC,KAAiB,EAAE,OAAU,EAAE,EAAE;IAC7F,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;IACxB,MAAM,cAAc,GAAG,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACrD,cAAc,EAAE,YAAY,EAAE,CAAC;AACnC,CAAC,CAAC;AAEF,SAAS,UAAU,CAAC,KAAiB,EAAE,OAAe,EAAE,QAAQ,GAAG,IAAI;IACnE,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC,CAAC;IAElC,MAAM,UAAU,GAAG,UAAU,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAC3D,MAAM,aAAa,GAAG,UAAU,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;IAC1D,MAAM,iBAAiB,GAAG,aAAa,CAAC,qBAAqB,EAAE,CAAC;IAChE,MAAM,kBAAkB,GAAG,UAAU,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,qBAAqB,EAAE,CAAC;IACvF,IAAI,UAAU,GAAG,CAAC,kBAAkB,CAAC,KAAK,GAAG,CAAC,EAAE,kBAAkB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAE/E,IAAI,CAAC,QAAQ,IAAI,UAAU,IAAI,gCAAgC,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,iBAAiB,CAAC,KAAK,CAAC,EAAE;QACpH,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAG,aAAuC,CAAC,CAAC;KAChG;IAED,MAAM,IAAI,GAAG,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC;IACjC,MAAM,WAAW,GAAG,sBAAsB,CAAC,KAAK,CAAC,CAAC;IAClD,MAAM,OAAO,GAAG,WAAY,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACvD,MAAM,OAAO,GAAG,WAAY,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACvD,MAAM,cAAc,GAAG,CAAC,OAAO,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,OAAO,EAAE,OAAO,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,OAAO,CAAU,CAAC;IACvG,cAAc,CAAC,KAAK,EAAE,cAAc,EAAE,OAAO,CAAC,CAAC;AACnD,CAAC;AAED,SAAS,WAAW,CAAC,KAAiB;IAClC,IAAI,cAAc,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAElD,MAAM,kBAAkB,GAAG,UAAU,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,qBAAqB,EAAE,CAAC;IACvF,MAAM,cAAc,GAAG,sBAAsB,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC3E,MAAM,IAAI,GAAG,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC;IACjC,MAAM,cAAc,GAAG,EAAE,CAAC;IAC1B,MAAM,aAAa,GAAG,kBAAkB,CAAC,KAAK,GAAG,CAAC,GAAG,cAAc,CAAC;IACpE,MAAM,cAAc,GAAG,kBAAkB,CAAC,MAAM,GAAG,CAAC,GAAG,cAAc,CAAC;IAEtE,IAAI,OAAO,GAAG,IAAI,CAAC;IACnB,IAAI,aAAa,GAAG,cAAc,CAAC,KAAK,IAAI,cAAc,GAAG,cAAc,CAAC,MAAM,EAAE;QAChF,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,GAAG,cAAc,CAAC,KAAK,EAAE,cAAc,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;KACpG;SAAM;QACH,OAAO,GAAG,CAAC,CAAC;KACf;IAED,MAAM,WAAW,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACjD,MAAM,cAAc,GAAG;QACnB,WAAW,CAAC,CAAC,CAAC,GAAG,kBAAkB,CAAC,KAAK,GAAG,CAAC,GAAG,OAAO,GAAG,cAAc,GAAG,CAAC,GAAG,IAAI;QACnF,WAAW,CAAC,CAAC,CAAC,GAAG,kBAAkB,CAAC,MAAM,GAAG,CAAC,GAAG,OAAO,GAAG,cAAc,GAAG,CAAC,GAAG,IAAI;KAC9E,CAAC;IACX,cAAc,CAAC,KAAK,EAAE,cAAc,EAAE,OAAO,CAAC,CAAC;AACnD,CAAC;AAED,SAAS,gBAAgB,CAAC,KAAiB,EAAE,OAA2B;IACpE,IAAI,cAAc,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAElD,MAAM,cAAc,GAAG,UAAU,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;IAC3D,MAAM,uBAAuB,GAAG,cAAc,CAAC,qBAAqB,EAAE,CAAC;IAEvE,IAAI,UAAU,GAAG,CAAC,CAAC;IACnB,IAAI,OAAO,CAAC,QAAQ,EAAE;QAClB,UAAU,GAAG,OAAO,CAAC,QAAQ,CAAC;KACjC;SAAM;QACH,UAAU,GAAG,uBAAuB,CAAC,KAAK,CAAC;KAC9C;IAED,MAAM,cAAc,GAAG,sBAAsB,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC3E,MAAM,YAAY,GAAG,UAAU,GAAG,CAAC,GAAG,OAAO,CAAC,cAAc,CAAC;IAC7D,IAAI,OAAO,GAAG,CAAC,CAAC;IAChB,IAAI,YAAY,GAAG,cAAc,CAAC,KAAK,EAAE;QACrC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;KAC3D;SAAM;QACH,OAAO,GAAG,CAAC,CAAC;KACf;IAED,IAAI,WAAW,GAAG,cAAc,CAAC,MAAM,GAAG,OAAO,GAAG,CAAC,GAAG,OAAO,CAAC,cAAc,CAAC;IAC/E,IAAI,WAAW,GAAG,OAAO,CAAC,WAAW,EAAE;QACnC,MAAM,WAAW,GAAG,cAAc,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,cAAc,EAAE,CAAgB,CAAC;QACxF,WAAW,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,WAAW,IAAI,CAAC;QAC9C,2BAA2B,CAAC,KAAK,CAAC,CAAC;KACtC;SAAM;QACH,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC;KACrC;IAED,MAAM,OAAO,GAAG,cAAc,CAAC,CAAC,GAAG,cAAc,CAAC,KAAK,GAAG,CAAC,CAAC;IAC5D,MAAM,OAAO,GAAG,cAAc,CAAC,CAAC,GAAG,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC;IAC7D,MAAM,cAAc,GAAG;QACnB,OAAO,GAAG,UAAU,GAAG,CAAC,GAAG,OAAO,GAAG,cAAc,GAAG,CAAC,GAAG,OAAO;QACjE,OAAO,GAAG,WAAW,GAAG,CAAC,GAAG,OAAO,GAAG,cAAc,GAAG,CAAC,GAAG,OAAO;KAC5D,CAAC;IACX,cAAc,CAAC,KAAK,EAAE,cAAc,EAAE,OAAO,CAAC,CAAC;AACnD,CAAC;AAED;;;GAGG;AACH,SAAS,gBAAgB,CAAC,KAAiB,EAAE,IAAoB;IAC7D,IAAI,GAAG,IAAI,IAAI,KAAK,CAAC,KAAK,CAAC,cAAc,CAAC;IAC1C,QAAQ,CAAC,KAAK,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE,CAAC,CAAC;IAE1C,mBAAmB,CAAE,KAAiC,EAAE,OAAO,CAAC,EAAE;QAC9D,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;AACP,CAAC;AAED,MAAM,CAAC,MAAM,eAAe,GAAG;IAC3B,iBAAiB;IACjB,cAAc;IACd,WAAW;IACX,UAAU;IACV,gBAAgB;IAChB,gBAAgB;CACnB,CAAC","sourcesContent":["import { ThemeColorMode } from '../interfaces/theme';\nimport { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\nimport { PlaitPointerType } from '../interfaces/pointer';\nimport { toPoint } from '../utils/dom/common';\nimport { getRectangleByElements } from '../utils/element';\nimport { distanceBetweenPointAndRectangle } from '../utils/math';\nimport {\n    clampZoomLevel,\n    clearViewportOrigination,\n    getViewBoxCenterPoint,\n    getViewportOrigination,\n    initializeViewportContainer\n} from '../utils/viewport';\nimport { BOARD_TO_COMPONENT } from '../utils/weak-maps';\nimport { setViewport } from './viewport';\nimport { depthFirstRecursion, getRealScrollBarWidth } from '../utils';\nimport { PlaitElement } from '../interfaces/element';\nimport { setTheme } from './theme';\nimport { FitViewportOptions } from '../interfaces/viewport';\n\nfunction updateViewport(board: PlaitBoard, origination: Point, zoom?: number) {\n    zoom = zoom ?? board.viewport.zoom;\n    setViewport(board, {\n        ...board.viewport,\n        zoom,\n        origination\n    });\n    clearViewportOrigination(board);\n}\n\nconst updatePointerType = <T extends string = PlaitPointerType>(board: PlaitBoard, pointer: T) => {\n    board.pointer = pointer;\n    const boardComponent = BOARD_TO_COMPONENT.get(board);\n    boardComponent?.markForCheck();\n};\n\nfunction updateZoom(board: PlaitBoard, newZoom: number, isCenter = true) {\n    newZoom = clampZoomLevel(newZoom);\n\n    const mousePoint = PlaitBoard.getMovingPointInBoard(board);\n    const nativeElement = PlaitBoard.getBoardContainer(board);\n    const nativeElementRect = nativeElement.getBoundingClientRect();\n    const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    let focusPoint = [boardContainerRect.width / 2, boardContainerRect.height / 2];\n\n    if (!isCenter && mousePoint && distanceBetweenPointAndRectangle(mousePoint[0], mousePoint[1], nativeElementRect) === 0) {\n        focusPoint = toPoint(mousePoint[0], mousePoint[1], (nativeElement as unknown) as SVGElement);\n    }\n\n    const zoom = board.viewport.zoom;\n    const origination = getViewportOrigination(board);\n    const centerX = origination![0] + focusPoint[0] / zoom;\n    const centerY = origination![1] + focusPoint[1] / zoom;\n    const newOrigination = [centerX - focusPoint[0] / newZoom, centerY - focusPoint[1] / newZoom] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\nfunction fitViewport(board: PlaitBoard) {\n    let scrollBarWidth = getRealScrollBarWidth(board);\n\n    const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    const elementHostBox = getRectangleByElements(board, board.children, true);\n    const zoom = board.viewport.zoom;\n    const autoFitPadding = 16;\n    const viewportWidth = boardContainerRect.width - 2 * autoFitPadding;\n    const viewportHeight = boardContainerRect.height - 2 * autoFitPadding;\n\n    let newZoom = zoom;\n    if (viewportWidth < elementHostBox.width || viewportHeight < elementHostBox.height) {\n        newZoom = Math.min(viewportWidth / elementHostBox.width, viewportHeight / elementHostBox.height);\n    } else {\n        newZoom = 1;\n    }\n\n    const centerPoint = getViewBoxCenterPoint(board);\n    const newOrigination = [\n        centerPoint[0] - boardContainerRect.width / 2 / newZoom + scrollBarWidth / 2 / zoom,\n        centerPoint[1] - boardContainerRect.height / 2 / newZoom + scrollBarWidth / 2 / zoom\n    ] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\nfunction fitViewportWidth(board: PlaitBoard, options: FitViewportOptions) {\n    let scrollBarWidth = getRealScrollBarWidth(board);\n\n    const boardContainer = PlaitBoard.getBoardContainer(board);\n    const boardContainerRectangle = boardContainer.getBoundingClientRect();\n\n    let finalWidth = 0;\n    if (options.maxWidth) {\n        finalWidth = options.maxWidth;\n    } else {\n        finalWidth = boardContainerRectangle.width;\n    }\n\n    const elementHostBox = getRectangleByElements(board, board.children, true);\n    const contentWidth = finalWidth - 2 * options.autoFitPadding;\n    let newZoom = 0;\n    if (contentWidth < elementHostBox.width) {\n        newZoom = Math.min(contentWidth / elementHostBox.width);\n    } else {\n        newZoom = 1;\n    }\n\n    let finalHeight = elementHostBox.height * newZoom + 2 * options.autoFitPadding;\n    if (finalHeight > options.limitHeight) {\n        const containerEl = boardContainer.closest(`.${options.containerClass}`) as HTMLElement;\n        containerEl.style.height = `${finalHeight}px`;\n        initializeViewportContainer(board);\n    } else {\n        finalHeight = options.limitHeight;\n    }\n\n    const centerX = elementHostBox.x + elementHostBox.width / 2;\n    const centerY = elementHostBox.y + elementHostBox.height / 2;\n    const newOrigination = [\n        centerX - finalWidth / 2 / newZoom + scrollBarWidth / 2 / newZoom,\n        centerY - finalHeight / 2 / newZoom + scrollBarWidth / 2 / newZoom\n    ] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\n/**\n * apply theme to every element (remove element custom properties)\n * invoke applyThemeColor\n */\nfunction updateThemeColor(board: PlaitBoard, mode: ThemeColorMode) {\n    mode = mode ?? board.theme.themeColorMode;\n    setTheme(board, { themeColorMode: mode });\n\n    depthFirstRecursion((board as unknown) as PlaitElement, element => {\n        board.applyTheme(element);\n    });\n}\n\nexport const BoardTransforms = {\n    updatePointerType,\n    updateViewport,\n    fitViewport,\n    updateZoom,\n    updateThemeColor,\n    fitViewportWidth\n};\n"]}
|
|
@@ -21,4 +21,23 @@ export function drawLinearPath(points, options) {
|
|
|
21
21
|
g.appendChild(path);
|
|
22
22
|
return g;
|
|
23
23
|
}
|
|
24
|
-
|
|
24
|
+
export function drawBezierPath(points, options) {
|
|
25
|
+
const g = createG();
|
|
26
|
+
const path = createPath();
|
|
27
|
+
let polylinePath = '';
|
|
28
|
+
for (let i = 0; i < points.length - 3; i += 3) {
|
|
29
|
+
if (i === 0) {
|
|
30
|
+
polylinePath += `M ${points[0][0]} ${points[0][1]} `;
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
polylinePath += `C ${points[i + 1][0]} ${points[i + 1][1]}, ${points[i + 2][0]} ${points[i + 2][1]}, ${points[i + 3][0]} ${points[i + 3][1]}`;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
path.setAttribute('d', polylinePath);
|
|
37
|
+
path.setAttribute('stroke', `${options?.stroke}`);
|
|
38
|
+
path.setAttribute('stroke-width', `${options?.strokeWidth}`);
|
|
39
|
+
path.setAttribute('fill', `none`);
|
|
40
|
+
g.appendChild(path);
|
|
41
|
+
return g;
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy91dGlscy9kcmF3L2xpbmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsT0FBTyxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFcEQsTUFBTSxVQUFVLFFBQVEsQ0FBQyxFQUFZLEVBQUUsS0FBWSxFQUFFLEdBQVUsRUFBRSxPQUFnQjtJQUM3RSxPQUFPLEVBQUUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDaEQsQ0FBQztBQUVELE1BQU0sVUFBVSxjQUFjLENBQUMsTUFBZSxFQUFFLE9BQWlCO0lBQzdELE1BQU0sQ0FBQyxHQUFHLE9BQU8sRUFBRSxDQUFDO0lBQ3BCLE1BQU0sSUFBSSxHQUFHLFVBQVUsRUFBRSxDQUFDO0lBRTFCLElBQUksWUFBWSxHQUFHLEVBQUUsQ0FBQztJQUN0QixNQUFNLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFO1FBQzVCLElBQUksS0FBSyxLQUFLLENBQUMsRUFBRTtZQUNiLFlBQVksSUFBSSxLQUFLLEtBQUssQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQztTQUNoRDthQUFNO1lBQ0gsWUFBWSxJQUFJLEtBQUssS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDO1NBQ2hEO0lBQ0wsQ0FBQyxDQUFDLENBQUM7SUFFSCxJQUFJLENBQUMsWUFBWSxDQUFDLEdBQUcsRUFBRSxZQUFZLENBQUMsQ0FBQztJQUNyQyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsRUFBRSxHQUFHLE9BQU8sRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDO0lBQ2xELElBQUksQ0FBQyxZQUFZLENBQUMsY0FBYyxFQUFFLEdBQUcsT0FBTyxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDN0QsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDbEMsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUVwQixPQUFPLENBQUMsQ0FBQztBQUNiLENBQUM7QUFFRCxNQUFNLFVBQVUsY0FBYyxDQUFDLE1BQWUsRUFBRSxPQUFpQjtJQUM3RCxNQUFNLENBQUMsR0FBRyxPQUFPLEVBQUUsQ0FBQztJQUNwQixNQUFNLElBQUksR0FBRyxVQUFVLEVBQUUsQ0FBQztJQUUxQixJQUFJLFlBQVksR0FBRyxFQUFFLENBQUM7SUFDdEIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUU7UUFDM0MsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ1QsWUFBWSxJQUFJLEtBQUssTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDO1NBQ3hEO2FBQU07WUFDSCxZQUFZLElBQUksS0FBSyxNQUFNLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssTUFBTSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxNQUFNLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLE1BQU0sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQ25ILE1BQU0sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUNuQixFQUFFLENBQUM7U0FDTjtLQUNKO0lBRUQsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLEVBQUUsWUFBWSxDQUFDLENBQUM7SUFDckMsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsR0FBRyxPQUFPLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUNsRCxJQUFJLENBQUMsWUFBWSxDQUFDLGNBQWMsRUFBRSxHQUFHLE9BQU8sRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDO0lBQzdELElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ2xDLENBQUMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7SUFFcEIsT0FBTyxDQUFDLENBQUM7QUFDYixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUm91Z2hTVkcgfSBmcm9tICdyb3VnaGpzL2Jpbi9zdmcnO1xuaW1wb3J0IHsgUG9pbnQgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL3BvaW50JztcbmltcG9ydCB7IE9wdGlvbnMgfSBmcm9tICdyb3VnaGpzL2Jpbi9jb3JlJztcbmltcG9ydCB7IGNyZWF0ZUcsIGNyZWF0ZVBhdGggfSBmcm9tICcuLi9kb20vY29tbW9uJztcblxuZXhwb3J0IGZ1bmN0aW9uIGRyYXdMaW5lKHJzOiBSb3VnaFNWRywgc3RhcnQ6IFBvaW50LCBlbmQ6IFBvaW50LCBvcHRpb25zOiBPcHRpb25zKTogU1ZHR0VsZW1lbnQge1xuICAgIHJldHVybiBycy5saW5lYXJQYXRoKFtzdGFydCwgZW5kXSwgb3B0aW9ucyk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBkcmF3TGluZWFyUGF0aChwb2ludHM6IFBvaW50W10sIG9wdGlvbnM/OiBPcHRpb25zKSB7XG4gICAgY29uc3QgZyA9IGNyZWF0ZUcoKTtcbiAgICBjb25zdCBwYXRoID0gY3JlYXRlUGF0aCgpO1xuXG4gICAgbGV0IHBvbHlsaW5lUGF0aCA9ICcnO1xuICAgIHBvaW50cy5mb3JFYWNoKChwb2ludCwgaW5kZXgpID0+IHtcbiAgICAgICAgaWYgKGluZGV4ID09PSAwKSB7XG4gICAgICAgICAgICBwb2x5bGluZVBhdGggKz0gYE0gJHtwb2ludFswXX0gJHtwb2ludFsxXX0gYDtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHBvbHlsaW5lUGF0aCArPSBgTCAke3BvaW50WzBdfSAke3BvaW50WzFdfSBgO1xuICAgICAgICB9XG4gICAgfSk7XG5cbiAgICBwYXRoLnNldEF0dHJpYnV0ZSgnZCcsIHBvbHlsaW5lUGF0aCk7XG4gICAgcGF0aC5zZXRBdHRyaWJ1dGUoJ3N0cm9rZScsIGAke29wdGlvbnM/LnN0cm9rZX1gKTtcbiAgICBwYXRoLnNldEF0dHJpYnV0ZSgnc3Ryb2tlLXdpZHRoJywgYCR7b3B0aW9ucz8uc3Ryb2tlV2lkdGh9YCk7XG4gICAgcGF0aC5zZXRBdHRyaWJ1dGUoJ2ZpbGwnLCBgbm9uZWApO1xuICAgIGcuYXBwZW5kQ2hpbGQocGF0aCk7XG5cbiAgICByZXR1cm4gZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRyYXdCZXppZXJQYXRoKHBvaW50czogUG9pbnRbXSwgb3B0aW9ucz86IE9wdGlvbnMpIHtcbiAgICBjb25zdCBnID0gY3JlYXRlRygpO1xuICAgIGNvbnN0IHBhdGggPSBjcmVhdGVQYXRoKCk7XG5cbiAgICBsZXQgcG9seWxpbmVQYXRoID0gJyc7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBwb2ludHMubGVuZ3RoIC0gMzsgaSArPSAzKSB7XG4gICAgICAgIGlmIChpID09PSAwKSB7XG4gICAgICAgICAgICBwb2x5bGluZVBhdGggKz0gYE0gJHtwb2ludHNbMF1bMF19ICR7cG9pbnRzWzBdWzFdfSBgO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgcG9seWxpbmVQYXRoICs9IGBDICR7cG9pbnRzW2kgKyAxXVswXX0gJHtwb2ludHNbaSArIDFdWzFdfSwgJHtwb2ludHNbaSArIDJdWzBdfSAke3BvaW50c1tpICsgMl1bMV19LCAke3BvaW50c1tpICsgM11bMF19ICR7XG4gICAgICAgICAgICAgICAgcG9pbnRzW2kgKyAzXVsxXVxuICAgICAgICAgICAgfWA7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwYXRoLnNldEF0dHJpYnV0ZSgnZCcsIHBvbHlsaW5lUGF0aCk7XG4gICAgcGF0aC5zZXRBdHRyaWJ1dGUoJ3N0cm9rZScsIGAke29wdGlvbnM/LnN0cm9rZX1gKTtcbiAgICBwYXRoLnNldEF0dHJpYnV0ZSgnc3Ryb2tlLXdpZHRoJywgYCR7b3B0aW9ucz8uc3Ryb2tlV2lkdGh9YCk7XG4gICAgcGF0aC5zZXRBdHRyaWJ1dGUoJ2ZpbGwnLCBgbm9uZWApO1xuICAgIGcuYXBwZW5kQ2hpbGQocGF0aCk7XG5cbiAgICByZXR1cm4gZztcbn1cbiJdfQ==
|
|
@@ -10,6 +10,7 @@ export const BOARD_TO_ROUGH_SVG = new WeakMap();
|
|
|
10
10
|
export const BOARD_TO_HOST = new WeakMap();
|
|
11
11
|
export const BOARD_TO_ELEMENT_HOST = new WeakMap();
|
|
12
12
|
export const BOARD_TO_SELECTED_ELEMENT = new WeakMap();
|
|
13
|
+
export const BOARD_TO_MOVING_POINT_IN_BOARD = new WeakMap();
|
|
13
14
|
export const BOARD_TO_MOVING_POINT = new WeakMap();
|
|
14
15
|
export const BOARD_TO_VIEWPORT_ORIGINATION = new WeakMap();
|
|
15
16
|
export const BOARD_TO_IS_SELECTION_MOVING = new WeakMap();
|
|
@@ -17,4 +18,4 @@ export const BOARD_TO_IS_SELECTION_MOVING = new WeakMap();
|
|
|
17
18
|
export const BOARD_TO_TEMPORARY_ELEMENTS = new WeakMap();
|
|
18
19
|
export const BOARD_TO_MOVING_ELEMENT = new WeakMap();
|
|
19
20
|
export const PATH_REFS = new WeakMap();
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2Vhay1tYXBzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3V0aWxzL3dlYWstbWFwcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRQSw4QkFBOEI7QUFDOUIsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLElBQUksT0FBTyxFQUFtQixDQUFDO0FBRTdELE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRyxJQUFJLE9BQU8sRUFBdUIsQ0FBQztBQUUzRCxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUcsSUFBSSxPQUFPLEVBQXFCLENBQUM7QUFFOUQsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLElBQUksT0FBTyxFQUF1QixDQUFDO0FBRWpFLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLElBQUksT0FBTyxFQUF1QixDQUFDO0FBRW5FLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksT0FBTyxFQUEwQixDQUFDO0FBRXhFLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksT0FBTyxFQUF1QyxDQUFDO0FBRXJGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksT0FBTyxFQUF3QixDQUFDO0FBRXRFLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxJQUFJLE9BQU8sRUFBNkIsQ0FBQztBQUV0RSxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLE9BQU8sRUFBMkIsQ0FBQztBQUU1RSxNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRyxJQUFJLE9BQU8sRUFBOEIsQ0FBQztBQUVuRixNQUFNLENBQUMsTUFBTSw4QkFBOEIsR0FBRyxJQUFJLE9BQU8sRUFBcUIsQ0FBQztBQUUvRSxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLE9BQU8sRUFBcUIsQ0FBQztBQUV0RSxNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBRyxJQUFJLE9BQU8sRUFBcUIsQ0FBQztBQUU5RSxNQUFNLENBQUMsTUFBTSw0QkFBNEIsR0FBRyxJQUFJLE9BQU8sRUFBdUIsQ0FBQztBQUUvRSxxQ0FBcUM7QUFDckMsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQUcsSUFBSSxPQUFPLEVBQThCLENBQUM7QUFFckYsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUcsSUFBSSxPQUFPLEVBQThCLENBQUM7QUFFakYsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUFzQyxJQUFJLE9BQU8sRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUm91Z2hTVkcgfSBmcm9tICdyb3VnaGpzL2Jpbi9zdmcnO1xuaW1wb3J0IHsgQm9hcmRDb21wb25lbnRJbnRlcmZhY2UgfSBmcm9tICcuLi9ib2FyZC9ib2FyZC5jb21wb25lbnQuaW50ZXJmYWNlJztcbmltcG9ydCB7IFBsYWl0RWxlbWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMvZWxlbWVudCc7XG5pbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ib2FyZCc7XG5pbXBvcnQgeyBQb2ludCB9IGZyb20gJy4uL2ludGVyZmFjZXMvcG9pbnQnO1xuaW1wb3J0IHsgQW5jZXN0b3IsIFBsYWl0Tm9kZSB9IGZyb20gJy4uL2ludGVyZmFjZXMvbm9kZSc7XG5pbXBvcnQgeyBQYXRoUmVmIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9wYXRoLXJlZic7XG5cbi8vIHJlY29yZCByaWNodGV4dCB0eXBlIHN0YXR1c1xuZXhwb3J0IGNvbnN0IElTX0JPQVJEX0NBQ0hFID0gbmV3IFdlYWtNYXA8T2JqZWN0LCBib29sZWFuPigpO1xuXG5leHBvcnQgY29uc3QgRkxVU0hJTkcgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBib29sZWFuPigpO1xuXG5leHBvcnQgY29uc3QgTk9ERV9UT19JTkRFWCA9IG5ldyBXZWFrTWFwPFBsYWl0Tm9kZSwgbnVtYmVyPigpO1xuXG5leHBvcnQgY29uc3QgTk9ERV9UT19QQVJFTlQgPSBuZXcgV2Vha01hcDxQbGFpdE5vZGUsIEFuY2VzdG9yPigpO1xuXG5leHBvcnQgY29uc3QgSVNfVEVYVF9FRElUQUJMRSA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIGJvb2xlYW4+KCk7XG5cbmV4cG9ydCBjb25zdCBCT0FSRF9UT19PTl9DSEFOR0UgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCAoKSA9PiB2b2lkPigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fQ09NUE9ORU5UID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgQm9hcmRDb21wb25lbnRJbnRlcmZhY2U+KCk7XG5cbmV4cG9ydCBjb25zdCBCT0FSRF9UT19ST1VHSF9TVkcgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBSb3VnaFNWRz4oKTtcblxuZXhwb3J0IGNvbnN0IEJPQVJEX1RPX0hPU1QgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBTVkdTVkdFbGVtZW50PigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fRUxFTUVOVF9IT1NUID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgU1ZHR0VsZW1lbnQ+KCk7XG5cbmV4cG9ydCBjb25zdCBCT0FSRF9UT19TRUxFQ1RFRF9FTEVNRU5UID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgUGxhaXRFbGVtZW50W10+KCk7XG5cbmV4cG9ydCBjb25zdCBCT0FSRF9UT19NT1ZJTkdfUE9JTlRfSU5fQk9BUkQgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBQb2ludD4oKTtcblxuZXhwb3J0IGNvbnN0IEJPQVJEX1RPX01PVklOR19QT0lOVCA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIFBvaW50PigpO1xuXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fVklFV1BPUlRfT1JJR0lOQVRJT04gPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBQb2ludD4oKTtcblxuZXhwb3J0IGNvbnN0IEJPQVJEX1RPX0lTX1NFTEVDVElPTl9NT1ZJTkcgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBib29sZWFuPigpO1xuXG4vLyBzYXZlIG5vIHN0YW5kYXJkIHNlbGVjdGVkIGVsZW1lbnRzXG5leHBvcnQgY29uc3QgQk9BUkRfVE9fVEVNUE9SQVJZX0VMRU1FTlRTID0gbmV3IFdlYWtNYXA8UGxhaXRCb2FyZCwgUGxhaXRFbGVtZW50W10+KCk7XG5cbmV4cG9ydCBjb25zdCBCT0FSRF9UT19NT1ZJTkdfRUxFTUVOVCA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIFBsYWl0RWxlbWVudFtdPigpO1xuXG5leHBvcnQgY29uc3QgUEFUSF9SRUZTOiBXZWFrTWFwPFBsYWl0Qm9hcmQsIFNldDxQYXRoUmVmPj4gPSBuZXcgV2Vha01hcCgpO1xuIl19
|
package/fesm2015/plait-core.mjs
CHANGED
|
@@ -4,7 +4,7 @@ import rough from 'roughjs/bin/rough';
|
|
|
4
4
|
import { timer, Subject, fromEvent } from 'rxjs';
|
|
5
5
|
import { takeUntil, filter, tap } from 'rxjs/operators';
|
|
6
6
|
import produce, { createDraft, finishDraft, isDraft } from 'immer';
|
|
7
|
-
import { isKeyHotkey, isHotkey } from 'is-hotkey';
|
|
7
|
+
import isHotkey$1, { isKeyHotkey, isHotkey } from 'is-hotkey';
|
|
8
8
|
import { __awaiter } from 'tslib';
|
|
9
9
|
import * as i1 from '@angular/common';
|
|
10
10
|
import { CommonModule } from '@angular/common';
|
|
@@ -21,6 +21,7 @@ const BOARD_TO_ROUGH_SVG = new WeakMap();
|
|
|
21
21
|
const BOARD_TO_HOST = new WeakMap();
|
|
22
22
|
const BOARD_TO_ELEMENT_HOST = new WeakMap();
|
|
23
23
|
const BOARD_TO_SELECTED_ELEMENT = new WeakMap();
|
|
24
|
+
const BOARD_TO_MOVING_POINT_IN_BOARD = new WeakMap();
|
|
24
25
|
const BOARD_TO_MOVING_POINT = new WeakMap();
|
|
25
26
|
const BOARD_TO_VIEWPORT_ORIGINATION = new WeakMap();
|
|
26
27
|
const BOARD_TO_IS_SELECTION_MOVING = new WeakMap();
|
|
@@ -134,6 +135,54 @@ const ThemeColors = [
|
|
|
134
135
|
StarryThemeColor
|
|
135
136
|
];
|
|
136
137
|
|
|
138
|
+
// https://stackoverflow.com/a/6853926/232122
|
|
139
|
+
function distanceBetweenPointAndSegment(x, y, x1, y1, x2, y2) {
|
|
140
|
+
const A = x - x1;
|
|
141
|
+
const B = y - y1;
|
|
142
|
+
const C = x2 - x1;
|
|
143
|
+
const D = y2 - y1;
|
|
144
|
+
const dot = A * C + B * D;
|
|
145
|
+
const lenSquare = C * C + D * D;
|
|
146
|
+
let param = -1;
|
|
147
|
+
if (lenSquare !== 0) {
|
|
148
|
+
// in case of 0 length line
|
|
149
|
+
param = dot / lenSquare;
|
|
150
|
+
}
|
|
151
|
+
let xx, yy;
|
|
152
|
+
if (param < 0) {
|
|
153
|
+
xx = x1;
|
|
154
|
+
yy = y1;
|
|
155
|
+
}
|
|
156
|
+
else if (param > 1) {
|
|
157
|
+
xx = x2;
|
|
158
|
+
yy = y2;
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
xx = x1 + param * C;
|
|
162
|
+
yy = y1 + param * D;
|
|
163
|
+
}
|
|
164
|
+
const dx = x - xx;
|
|
165
|
+
const dy = y - yy;
|
|
166
|
+
return Math.hypot(dx, dy);
|
|
167
|
+
}
|
|
168
|
+
function rotate(x1, y1, x2, y2, angle) {
|
|
169
|
+
// 𝑎′𝑥=(𝑎𝑥−𝑐𝑥)cos𝜃−(𝑎𝑦−𝑐𝑦)sin𝜃+𝑐𝑥
|
|
170
|
+
// 𝑎′𝑦=(𝑎𝑥−𝑐𝑥)sin𝜃+(𝑎𝑦−𝑐𝑦)cos𝜃+𝑐𝑦.
|
|
171
|
+
// https://math.stackexchange.com/questions/2204520/how-do-i-rotate-a-line-segment-in-a-specific-point-on-the-line
|
|
172
|
+
return [(x1 - x2) * Math.cos(angle) - (y1 - y2) * Math.sin(angle) + x2, (x1 - x2) * Math.sin(angle) + (y1 - y2) * Math.cos(angle) + y2];
|
|
173
|
+
}
|
|
174
|
+
function distanceBetweenPointAndPoint(x1, y1, x2, y2) {
|
|
175
|
+
const dx = x1 - x2;
|
|
176
|
+
const dy = y1 - y2;
|
|
177
|
+
return Math.hypot(dx, dy);
|
|
178
|
+
}
|
|
179
|
+
// https://stackoverflow.com/questions/5254838/calculating-distance-between-a-point-and-a-rectangular-box-nearest-point
|
|
180
|
+
function distanceBetweenPointAndRectangle(x, y, rect) {
|
|
181
|
+
var dx = Math.max(rect.x - x, 0, x - (rect.x + rect.width));
|
|
182
|
+
var dy = Math.max(rect.y - y, 0, y - (rect.y + rect.height));
|
|
183
|
+
return Math.sqrt(dx * dx + dy * dy);
|
|
184
|
+
}
|
|
185
|
+
|
|
137
186
|
const PlaitBoard = {
|
|
138
187
|
isBoard(value) {
|
|
139
188
|
const cachedIsBoard = IS_BOARD_CACHE.get(value);
|
|
@@ -202,8 +251,16 @@ const PlaitBoard = {
|
|
|
202
251
|
isPointer(board, pointer) {
|
|
203
252
|
return board.pointer === pointer;
|
|
204
253
|
},
|
|
205
|
-
|
|
206
|
-
return
|
|
254
|
+
getMovingPointInBoard(board) {
|
|
255
|
+
return BOARD_TO_MOVING_POINT_IN_BOARD.get(board);
|
|
256
|
+
},
|
|
257
|
+
isMovingPointInBoard(board) {
|
|
258
|
+
const point = BOARD_TO_MOVING_POINT.get(board);
|
|
259
|
+
const rect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();
|
|
260
|
+
if (point && distanceBetweenPointAndRectangle(point[0], point[1], rect) === 0) {
|
|
261
|
+
return true;
|
|
262
|
+
}
|
|
263
|
+
return false;
|
|
207
264
|
},
|
|
208
265
|
getThemeColors(board) {
|
|
209
266
|
return (board.options.themeColors || ThemeColors);
|
|
@@ -788,6 +845,7 @@ const SINGLE_QUOTE = 222;
|
|
|
788
845
|
const MAC_META = 224;
|
|
789
846
|
|
|
790
847
|
const CLIP_BOARD_FORMAT_KEY = 'x-plait-fragment';
|
|
848
|
+
const HOST_CLASS_NAME = 'plait-board-container';
|
|
791
849
|
const SCROLL_BAR_WIDTH = 20;
|
|
792
850
|
const MAX_RADIUS = 16;
|
|
793
851
|
const POINTER_BUTTON = {
|
|
@@ -849,54 +907,6 @@ const isMainPointer = (event) => {
|
|
|
849
907
|
return event.button === POINTER_BUTTON.MAIN;
|
|
850
908
|
};
|
|
851
909
|
|
|
852
|
-
// https://stackoverflow.com/a/6853926/232122
|
|
853
|
-
function distanceBetweenPointAndSegment(x, y, x1, y1, x2, y2) {
|
|
854
|
-
const A = x - x1;
|
|
855
|
-
const B = y - y1;
|
|
856
|
-
const C = x2 - x1;
|
|
857
|
-
const D = y2 - y1;
|
|
858
|
-
const dot = A * C + B * D;
|
|
859
|
-
const lenSquare = C * C + D * D;
|
|
860
|
-
let param = -1;
|
|
861
|
-
if (lenSquare !== 0) {
|
|
862
|
-
// in case of 0 length line
|
|
863
|
-
param = dot / lenSquare;
|
|
864
|
-
}
|
|
865
|
-
let xx, yy;
|
|
866
|
-
if (param < 0) {
|
|
867
|
-
xx = x1;
|
|
868
|
-
yy = y1;
|
|
869
|
-
}
|
|
870
|
-
else if (param > 1) {
|
|
871
|
-
xx = x2;
|
|
872
|
-
yy = y2;
|
|
873
|
-
}
|
|
874
|
-
else {
|
|
875
|
-
xx = x1 + param * C;
|
|
876
|
-
yy = y1 + param * D;
|
|
877
|
-
}
|
|
878
|
-
const dx = x - xx;
|
|
879
|
-
const dy = y - yy;
|
|
880
|
-
return Math.hypot(dx, dy);
|
|
881
|
-
}
|
|
882
|
-
function rotate(x1, y1, x2, y2, angle) {
|
|
883
|
-
// 𝑎′𝑥=(𝑎𝑥−𝑐𝑥)cos𝜃−(𝑎𝑦−𝑐𝑦)sin𝜃+𝑐𝑥
|
|
884
|
-
// 𝑎′𝑦=(𝑎𝑥−𝑐𝑥)sin𝜃+(𝑎𝑦−𝑐𝑦)cos𝜃+𝑐𝑦.
|
|
885
|
-
// https://math.stackexchange.com/questions/2204520/how-do-i-rotate-a-line-segment-in-a-specific-point-on-the-line
|
|
886
|
-
return [(x1 - x2) * Math.cos(angle) - (y1 - y2) * Math.sin(angle) + x2, (x1 - x2) * Math.sin(angle) + (y1 - y2) * Math.cos(angle) + y2];
|
|
887
|
-
}
|
|
888
|
-
function distanceBetweenPointAndPoint(x1, y1, x2, y2) {
|
|
889
|
-
const dx = x1 - x2;
|
|
890
|
-
const dy = y1 - y2;
|
|
891
|
-
return Math.hypot(dx, dy);
|
|
892
|
-
}
|
|
893
|
-
// https://stackoverflow.com/questions/5254838/calculating-distance-between-a-point-and-a-rectangular-box-nearest-point
|
|
894
|
-
function distanceBetweenPointAndRectangle(x, y, rect) {
|
|
895
|
-
var dx = Math.max(rect.x - x, 0, x - (rect.x + rect.width));
|
|
896
|
-
var dy = Math.max(rect.y - y, 0, y - (rect.y + rect.height));
|
|
897
|
-
return Math.sqrt(dx * dx + dy * dy);
|
|
898
|
-
}
|
|
899
|
-
|
|
900
910
|
const SELECTION_BORDER_COLOR = '#6698FF';
|
|
901
911
|
const SELECTION_FILL_COLOR = '#6698FF19'; // 主色 0.1 透明度
|
|
902
912
|
const Selection = {
|
|
@@ -1403,6 +1413,25 @@ function drawLinearPath(points, options) {
|
|
|
1403
1413
|
g.appendChild(path);
|
|
1404
1414
|
return g;
|
|
1405
1415
|
}
|
|
1416
|
+
function drawBezierPath(points, options) {
|
|
1417
|
+
const g = createG();
|
|
1418
|
+
const path = createPath();
|
|
1419
|
+
let polylinePath = '';
|
|
1420
|
+
for (let i = 0; i < points.length - 3; i += 3) {
|
|
1421
|
+
if (i === 0) {
|
|
1422
|
+
polylinePath += `M ${points[0][0]} ${points[0][1]} `;
|
|
1423
|
+
}
|
|
1424
|
+
else {
|
|
1425
|
+
polylinePath += `C ${points[i + 1][0]} ${points[i + 1][1]}, ${points[i + 2][0]} ${points[i + 2][1]}, ${points[i + 3][0]} ${points[i + 3][1]}`;
|
|
1426
|
+
}
|
|
1427
|
+
}
|
|
1428
|
+
path.setAttribute('d', polylinePath);
|
|
1429
|
+
path.setAttribute('stroke', `${options === null || options === void 0 ? void 0 : options.stroke}`);
|
|
1430
|
+
path.setAttribute('stroke-width', `${options === null || options === void 0 ? void 0 : options.strokeWidth}`);
|
|
1431
|
+
path.setAttribute('fill', `none`);
|
|
1432
|
+
g.appendChild(path);
|
|
1433
|
+
return g;
|
|
1434
|
+
}
|
|
1406
1435
|
|
|
1407
1436
|
let timerId = null;
|
|
1408
1437
|
const throttleRAF = (fn) => {
|
|
@@ -1875,7 +1904,7 @@ const updatePointerType = (board, pointer) => {
|
|
|
1875
1904
|
};
|
|
1876
1905
|
function updateZoom(board, newZoom, isCenter = true) {
|
|
1877
1906
|
newZoom = clampZoomLevel(newZoom);
|
|
1878
|
-
const mousePoint = PlaitBoard.
|
|
1907
|
+
const mousePoint = PlaitBoard.getMovingPointInBoard(board);
|
|
1879
1908
|
const nativeElement = PlaitBoard.getBoardContainer(board);
|
|
1880
1909
|
const nativeElementRect = nativeElement.getBoundingClientRect();
|
|
1881
1910
|
const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();
|
|
@@ -2054,6 +2083,7 @@ function createBoard(children, options) {
|
|
|
2054
2083
|
mouseup: (event) => { },
|
|
2055
2084
|
globalMouseup: (event) => { },
|
|
2056
2085
|
keydown: (event) => { },
|
|
2086
|
+
globalKeydown: (event) => { },
|
|
2057
2087
|
keyup: (event) => { },
|
|
2058
2088
|
dblclick: (event) => { },
|
|
2059
2089
|
setFragment: (data) => { },
|
|
@@ -2531,6 +2561,42 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImpor
|
|
|
2531
2561
|
}
|
|
2532
2562
|
}]
|
|
2533
2563
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; } });
|
|
2564
|
+
class PlaitIslandPopoverBaseComponent {
|
|
2565
|
+
initialize(board) {
|
|
2566
|
+
this.board = board;
|
|
2567
|
+
const onChange = board.onChange;
|
|
2568
|
+
board.onChange = () => {
|
|
2569
|
+
onChange();
|
|
2570
|
+
if (hasOnBoardChange(this)) {
|
|
2571
|
+
this.onBoardChange();
|
|
2572
|
+
}
|
|
2573
|
+
};
|
|
2574
|
+
this.onChange = onChange;
|
|
2575
|
+
}
|
|
2576
|
+
ngOnInit() {
|
|
2577
|
+
if (!this.board) {
|
|
2578
|
+
throw new Error('can not find board instance');
|
|
2579
|
+
}
|
|
2580
|
+
this.initialize(this.board);
|
|
2581
|
+
this.islandOnInit();
|
|
2582
|
+
}
|
|
2583
|
+
ngOnDestroy() {
|
|
2584
|
+
this.board.onChange = this.onChange;
|
|
2585
|
+
this.islandOnDestroy();
|
|
2586
|
+
}
|
|
2587
|
+
}
|
|
2588
|
+
PlaitIslandPopoverBaseComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitIslandPopoverBaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
2589
|
+
PlaitIslandPopoverBaseComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.5", type: PlaitIslandPopoverBaseComponent, inputs: { board: "board" }, host: { classAttribute: "plait-island-popover-container" }, ngImport: i0 });
|
|
2590
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitIslandPopoverBaseComponent, decorators: [{
|
|
2591
|
+
type: Directive,
|
|
2592
|
+
args: [{
|
|
2593
|
+
host: {
|
|
2594
|
+
class: 'plait-island-popover-container'
|
|
2595
|
+
}
|
|
2596
|
+
}]
|
|
2597
|
+
}], propDecorators: { board: [{
|
|
2598
|
+
type: Input
|
|
2599
|
+
}] } });
|
|
2534
2600
|
const hasOnBoardChange = (value) => {
|
|
2535
2601
|
if (value.onBoardChange) {
|
|
2536
2602
|
return true;
|
|
@@ -2540,6 +2606,56 @@ const hasOnBoardChange = (value) => {
|
|
|
2540
2606
|
}
|
|
2541
2607
|
};
|
|
2542
2608
|
|
|
2609
|
+
const withHotkey = (board) => {
|
|
2610
|
+
const { keydown, globalKeydown } = board;
|
|
2611
|
+
board.keydown = (event) => {
|
|
2612
|
+
const options = board.getPluginOptions(PlaitPluginKey.withSelection);
|
|
2613
|
+
if (!PlaitBoard.isReadonly(board) && options.isMultiple && isHotkey$1('mod+a', event)) {
|
|
2614
|
+
event.preventDefault();
|
|
2615
|
+
let elements = [];
|
|
2616
|
+
depthFirstRecursion(board, node => {
|
|
2617
|
+
elements.push(node);
|
|
2618
|
+
}, node => {
|
|
2619
|
+
if (PlaitBoard.isBoard(node) || board.isRecursion(node)) {
|
|
2620
|
+
return true;
|
|
2621
|
+
}
|
|
2622
|
+
else {
|
|
2623
|
+
return false;
|
|
2624
|
+
}
|
|
2625
|
+
}, true);
|
|
2626
|
+
Transforms.setSelectionWithTemporaryElements(board, elements);
|
|
2627
|
+
return;
|
|
2628
|
+
}
|
|
2629
|
+
keydown(event);
|
|
2630
|
+
};
|
|
2631
|
+
board.globalKeydown = (event) => {
|
|
2632
|
+
if (PlaitBoard.getMovingPointInBoard(board) || PlaitBoard.isMovingPointInBoard(board)) {
|
|
2633
|
+
if (isHotkey$1(['mod+=', 'mod++'], { byKey: true })(event)) {
|
|
2634
|
+
event.preventDefault();
|
|
2635
|
+
BoardTransforms.updateZoom(board, board.viewport.zoom + 0.1, false);
|
|
2636
|
+
return;
|
|
2637
|
+
}
|
|
2638
|
+
if (isHotkey$1(['mod+shift+=', 'mod+shift++'], { byKey: true })(event)) {
|
|
2639
|
+
event.preventDefault();
|
|
2640
|
+
BoardTransforms.fitViewport(board);
|
|
2641
|
+
return;
|
|
2642
|
+
}
|
|
2643
|
+
if (isHotkey$1(['mod+-', 'mod+shift+-'])(event)) {
|
|
2644
|
+
event.preventDefault();
|
|
2645
|
+
BoardTransforms.updateZoom(board, board.viewport.zoom - 0.1);
|
|
2646
|
+
return;
|
|
2647
|
+
}
|
|
2648
|
+
if (isHotkey$1(['mod+0', 'mod+shift+0'], { byKey: true })(event)) {
|
|
2649
|
+
event.preventDefault();
|
|
2650
|
+
BoardTransforms.updateZoom(board, 1);
|
|
2651
|
+
return;
|
|
2652
|
+
}
|
|
2653
|
+
}
|
|
2654
|
+
globalKeydown(event);
|
|
2655
|
+
};
|
|
2656
|
+
return board;
|
|
2657
|
+
};
|
|
2658
|
+
|
|
2543
2659
|
class PlaitElementComponent {
|
|
2544
2660
|
constructor(renderer2, viewContainerRef) {
|
|
2545
2661
|
this.renderer2 = renderer2;
|
|
@@ -2696,7 +2812,7 @@ class PlaitBoardComponent {
|
|
|
2696
2812
|
return this.svg.nativeElement;
|
|
2697
2813
|
}
|
|
2698
2814
|
get hostClass() {
|
|
2699
|
-
return
|
|
2815
|
+
return `${HOST_CLASS_NAME} pointer-${this.board.pointer} theme-${this.board.theme.themeColorMode}`;
|
|
2700
2816
|
}
|
|
2701
2817
|
get readonly() {
|
|
2702
2818
|
return this.board.options.readonly;
|
|
@@ -2737,6 +2853,11 @@ class PlaitBoardComponent {
|
|
|
2737
2853
|
this.initializeHookListener();
|
|
2738
2854
|
this.viewportScrollListener();
|
|
2739
2855
|
this.elementResizeListener();
|
|
2856
|
+
fromEvent(document, 'mouseleave')
|
|
2857
|
+
.pipe(takeUntil(this.destroy$))
|
|
2858
|
+
.subscribe((event) => {
|
|
2859
|
+
BOARD_TO_MOVING_POINT.delete(this.board);
|
|
2860
|
+
});
|
|
2740
2861
|
});
|
|
2741
2862
|
BOARD_TO_COMPONENT.set(this.board, this);
|
|
2742
2863
|
BOARD_TO_ROUGH_SVG.set(this.board, roughSVG);
|
|
@@ -2783,7 +2904,7 @@ class PlaitBoardComponent {
|
|
|
2783
2904
|
initializeViewportOffset(this.board);
|
|
2784
2905
|
}
|
|
2785
2906
|
initializePlugins() {
|
|
2786
|
-
let board = withHandPointer(withHistory(withSelection(withMoving(withBoard(withViewport(withOptions(createBoard(this.plaitValue, this.plaitOptions))))))));
|
|
2907
|
+
let board = withHotkey(withHandPointer(withHistory(withSelection(withMoving(withBoard(withViewport(withOptions(createBoard(this.plaitValue, this.plaitOptions)))))))));
|
|
2787
2908
|
this.plaitPlugins.forEach(plugin => {
|
|
2788
2909
|
board = plugin(board);
|
|
2789
2910
|
});
|
|
@@ -2804,18 +2925,19 @@ class PlaitBoardComponent {
|
|
|
2804
2925
|
fromEvent(this.host, 'mousemove')
|
|
2805
2926
|
.pipe(takeUntil(this.destroy$))
|
|
2806
2927
|
.subscribe((event) => {
|
|
2807
|
-
|
|
2928
|
+
BOARD_TO_MOVING_POINT_IN_BOARD.set(this.board, [event.x, event.y]);
|
|
2808
2929
|
this.board.mousemove(event);
|
|
2809
2930
|
});
|
|
2810
2931
|
fromEvent(this.host, 'mouseleave')
|
|
2811
2932
|
.pipe(takeUntil(this.destroy$))
|
|
2812
2933
|
.subscribe((event) => {
|
|
2813
|
-
|
|
2934
|
+
BOARD_TO_MOVING_POINT_IN_BOARD.delete(this.board);
|
|
2814
2935
|
this.board.mouseleave(event);
|
|
2815
2936
|
});
|
|
2816
2937
|
fromEvent(document, 'mousemove')
|
|
2817
2938
|
.pipe(takeUntil(this.destroy$))
|
|
2818
2939
|
.subscribe((event) => {
|
|
2940
|
+
BOARD_TO_MOVING_POINT.set(this.board, [event.x, event.y]);
|
|
2819
2941
|
this.board.globalMousemove(event);
|
|
2820
2942
|
});
|
|
2821
2943
|
fromEvent(this.host, 'mouseup')
|
|
@@ -2834,27 +2956,8 @@ class PlaitBoardComponent {
|
|
|
2834
2956
|
this.board.dblclick(event);
|
|
2835
2957
|
});
|
|
2836
2958
|
fromEvent(document, 'keydown')
|
|
2837
|
-
.pipe(takeUntil(this.destroy$), tap(
|
|
2838
|
-
|
|
2839
|
-
if (isHotkey(['mod+=', 'mod++'], { byKey: true })(event)) {
|
|
2840
|
-
event.preventDefault();
|
|
2841
|
-
BoardTransforms.updateZoom(this.board, this.board.viewport.zoom + 0.1, false);
|
|
2842
|
-
}
|
|
2843
|
-
if (isHotkey('mod+-', { byKey: true })(event)) {
|
|
2844
|
-
event.preventDefault();
|
|
2845
|
-
BoardTransforms.updateZoom(this.board, this.board.viewport.zoom - 0.1);
|
|
2846
|
-
}
|
|
2847
|
-
if (isHotkey('mod+0', { byKey: true })(event)) {
|
|
2848
|
-
event.preventDefault();
|
|
2849
|
-
BoardTransforms.updateZoom(this.board, 1);
|
|
2850
|
-
return;
|
|
2851
|
-
}
|
|
2852
|
-
if (isHotkey('mod+shift+=', { byKey: true })(event)) {
|
|
2853
|
-
event.preventDefault();
|
|
2854
|
-
BoardTransforms.fitViewport(this.board);
|
|
2855
|
-
return;
|
|
2856
|
-
}
|
|
2857
|
-
}
|
|
2959
|
+
.pipe(takeUntil(this.destroy$), tap(event => {
|
|
2960
|
+
this.board.globalKeydown(event);
|
|
2858
2961
|
}), filter(event => this.isFocused && !PlaitBoard.hasBeenTextEditing(this.board) && !hasInputOrTextareaTarget(event.target)))
|
|
2859
2962
|
.subscribe((event) => {
|
|
2860
2963
|
var _a;
|
|
@@ -2876,7 +2979,7 @@ class PlaitBoardComponent {
|
|
|
2876
2979
|
fromEvent(document, 'paste')
|
|
2877
2980
|
.pipe(takeUntil(this.destroy$), filter(() => this.isFocused && !PlaitBoard.isReadonly(this.board) && !PlaitBoard.hasBeenTextEditing(this.board)))
|
|
2878
2981
|
.subscribe((clipboardEvent) => {
|
|
2879
|
-
const mousePoint = PlaitBoard.
|
|
2982
|
+
const mousePoint = PlaitBoard.getMovingPointInBoard(this.board);
|
|
2880
2983
|
if (mousePoint) {
|
|
2881
2984
|
const targetPoint = transformPoint(this.board, toPoint(mousePoint[0], mousePoint[1], this.host));
|
|
2882
2985
|
this.board.insertFragment(clipboardEvent.clipboardData, targetPoint);
|
|
@@ -3190,5 +3293,5 @@ function createModModifierKeys() {
|
|
|
3190
3293
|
* Generated bundle index. Do not edit.
|
|
3191
3294
|
*/
|
|
3192
3295
|
|
|
3193
|
-
export { A, ALT, APOSTROPHE, AT_SIGN, B, BACKSLASH, BACKSPACE, BOARD_TO_COMPONENT, BOARD_TO_ELEMENT_HOST, BOARD_TO_HOST, BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_MOVING_ELEMENT, BOARD_TO_MOVING_POINT, BOARD_TO_ON_CHANGE, BOARD_TO_ROUGH_SVG, BOARD_TO_SELECTED_ELEMENT, BOARD_TO_TEMPORARY_ELEMENTS, BOARD_TO_VIEWPORT_ORIGINATION, BoardTransforms, C, CAPS_LOCK, CLIP_BOARD_FORMAT_KEY, CLOSE_SQUARE_BRACKET, COMMA, CONTEXT_MENU, CONTROL, ColorfulThemeColor, D, DASH, DELETE, DOWN_ARROW, DarkThemeColor, DefaultThemeColor, E, EIGHT, ELEMENT_TO_COMPONENT, END, ENTER, EQUALS, ESCAPE, F, F1, F10, F11, F12, F2, F3, F4, F5, F6, F7, F8, F9, FF_EQUALS, FF_MINUS, FF_MUTE, FF_SEMICOLON, FF_VOLUME_DOWN, FF_VOLUME_UP, FIRST_MEDIA, FIVE, FLUSHING, FOUR, G, H, HOME, I, INSERT, IS_APPLE, IS_BOARD_CACHE, IS_CHROME, IS_CHROME_LEGACY, IS_EDGE_LEGACY, IS_FIREFOX, IS_IOS, IS_MAC, IS_SAFARI, IS_TEXT_EDITABLE, J, K, L, LAST_MEDIA, LEFT_ARROW, M, MAC_ENTER, MAC_META, MAC_WK_CMD_LEFT, MAC_WK_CMD_RIGHT, MAX_RADIUS, MERGING, META, MUTE, N, NINE, NODE_TO_INDEX, NODE_TO_PARENT, NS, NUMPAD_DIVIDE, NUMPAD_EIGHT, NUMPAD_FIVE, NUMPAD_FOUR, NUMPAD_MINUS, NUMPAD_MULTIPLY, NUMPAD_NINE, NUMPAD_ONE, NUMPAD_PERIOD, NUMPAD_PLUS, NUMPAD_SEVEN, NUMPAD_SIX, NUMPAD_THREE, NUMPAD_TWO, NUMPAD_ZERO, NUM_CENTER, NUM_LOCK, O, ONE, OPEN_SQUARE_BRACKET, P, PAGE_DOWN, PAGE_UP, PATH_REFS, PAUSE, PERIOD, PLUS_SIGN, POINTER_BUTTON, PRINT_SCREEN, Path, PlaitBoard, PlaitBoardComponent, PlaitChildrenElement, PlaitElement, PlaitElementComponent, PlaitHistoryBoard, PlaitIslandBaseComponent, PlaitModule, PlaitNode, PlaitOperation, PlaitPluginElementComponent, PlaitPluginKey, PlaitPointerType, Point, Q, QUESTION_MARK, R, RIGHT_ARROW, RectangleClient, RetroThemeColor, S, SAVING, SCROLL_BAR_WIDTH, SCROLL_LOCK, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, SEMICOLON, SEVEN, SHIFT, SINGLE_QUOTE, SIX, SLASH, SPACE, Selection, SoftThemeColor, StarryThemeColor, T, TAB, THREE, TILDE, TWO, ThemeColorMode, ThemeColors, Transforms, U, UP_ARROW, V, VOLUME_DOWN, VOLUME_UP, Viewport, W, X, Y, Z, ZERO, addMovingElements, addSelectedElement, arrowPoints, cacheMovingElements, cacheSelectedElements, clampZoomLevel, clearNodeWeakMap, clearSelectedElement, clearSelectionMoving, clearViewportOrigination, createFakeEvent, createForeignObject, createG, createKeyboardEvent, createModModifierKeys, createMouseEvent, createPath, createPointerEvent, createSVG, createSelectionOuterG, createTestingBoard, createText, createTouchEvent, debounce, deleteTemporaryElements, depthFirstRecursion, distanceBetweenPointAndPoint, distanceBetweenPointAndRectangle, distanceBetweenPointAndSegment, downloadImage, drawAbstractRoundRectangle, drawArrow, drawCircle, drawLine, drawLinearPath, drawRoundRectangle, fakeNodeWeakMap, getBoardRectangle, getElementHostBBox, getHitElementOfRoot, getHitElements, getMovingElements, getRealScrollBarWidth, getRectangleByElements, getSelectedElements, getTemporaryElements, getViewBox, getViewBoxCenterPoint, getViewportContainerRect, getViewportOrigination, hasBeforeContextChange, hasInputOrTextareaTarget, hasOnBoardChange, hasOnContextChanged, hotkeys, idCreator, initializeViewBox, initializeViewportContainer, initializeViewportOffset, inverse, isDOMElement, isDOMNode, isFromScrolling, isFromViewportChange, isHitElements, isInPlaitBoard, isMainPointer, isNullOrUndefined, isSecondaryPointer, isSelectedElement, isSelectionMoving, isSetViewportOperation, normalizePoint, removeMovingElements, removeSelectedElement, rotate, scrollToRectangle, setIsFromScrolling, setIsFromViewportChange, setSVGViewBox, setSelectionMoving, shouldClear, shouldMerge, shouldSave, throttleRAF, toImage, toPoint, transformPoint, transformPoints, updateForeignObject, updateViewportContainerScroll, updateViewportOffset, updateViewportOrigination, withMoving, withOptions, withSelection };
|
|
3296
|
+
export { A, ALT, APOSTROPHE, AT_SIGN, B, BACKSLASH, BACKSPACE, BOARD_TO_COMPONENT, BOARD_TO_ELEMENT_HOST, BOARD_TO_HOST, BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_MOVING_ELEMENT, BOARD_TO_MOVING_POINT, BOARD_TO_MOVING_POINT_IN_BOARD, BOARD_TO_ON_CHANGE, BOARD_TO_ROUGH_SVG, BOARD_TO_SELECTED_ELEMENT, BOARD_TO_TEMPORARY_ELEMENTS, BOARD_TO_VIEWPORT_ORIGINATION, BoardTransforms, C, CAPS_LOCK, CLIP_BOARD_FORMAT_KEY, CLOSE_SQUARE_BRACKET, COMMA, CONTEXT_MENU, CONTROL, ColorfulThemeColor, D, DASH, DELETE, DOWN_ARROW, DarkThemeColor, DefaultThemeColor, E, EIGHT, ELEMENT_TO_COMPONENT, END, ENTER, EQUALS, ESCAPE, F, F1, F10, F11, F12, F2, F3, F4, F5, F6, F7, F8, F9, FF_EQUALS, FF_MINUS, FF_MUTE, FF_SEMICOLON, FF_VOLUME_DOWN, FF_VOLUME_UP, FIRST_MEDIA, FIVE, FLUSHING, FOUR, G, H, HOME, HOST_CLASS_NAME, I, INSERT, IS_APPLE, IS_BOARD_CACHE, IS_CHROME, IS_CHROME_LEGACY, IS_EDGE_LEGACY, IS_FIREFOX, IS_IOS, IS_MAC, IS_SAFARI, IS_TEXT_EDITABLE, J, K, L, LAST_MEDIA, LEFT_ARROW, M, MAC_ENTER, MAC_META, MAC_WK_CMD_LEFT, MAC_WK_CMD_RIGHT, MAX_RADIUS, MERGING, META, MUTE, N, NINE, NODE_TO_INDEX, NODE_TO_PARENT, NS, NUMPAD_DIVIDE, NUMPAD_EIGHT, NUMPAD_FIVE, NUMPAD_FOUR, NUMPAD_MINUS, NUMPAD_MULTIPLY, NUMPAD_NINE, NUMPAD_ONE, NUMPAD_PERIOD, NUMPAD_PLUS, NUMPAD_SEVEN, NUMPAD_SIX, NUMPAD_THREE, NUMPAD_TWO, NUMPAD_ZERO, NUM_CENTER, NUM_LOCK, O, ONE, OPEN_SQUARE_BRACKET, P, PAGE_DOWN, PAGE_UP, PATH_REFS, PAUSE, PERIOD, PLUS_SIGN, POINTER_BUTTON, PRINT_SCREEN, Path, PlaitBoard, PlaitBoardComponent, PlaitChildrenElement, PlaitElement, PlaitElementComponent, PlaitHistoryBoard, PlaitIslandBaseComponent, PlaitIslandPopoverBaseComponent, PlaitModule, PlaitNode, PlaitOperation, PlaitPluginElementComponent, PlaitPluginKey, PlaitPointerType, Point, Q, QUESTION_MARK, R, RIGHT_ARROW, RectangleClient, RetroThemeColor, S, SAVING, SCROLL_BAR_WIDTH, SCROLL_LOCK, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, SEMICOLON, SEVEN, SHIFT, SINGLE_QUOTE, SIX, SLASH, SPACE, Selection, SoftThemeColor, StarryThemeColor, T, TAB, THREE, TILDE, TWO, ThemeColorMode, ThemeColors, Transforms, U, UP_ARROW, V, VOLUME_DOWN, VOLUME_UP, Viewport, W, X, Y, Z, ZERO, addMovingElements, addSelectedElement, arrowPoints, cacheMovingElements, cacheSelectedElements, clampZoomLevel, clearNodeWeakMap, clearSelectedElement, clearSelectionMoving, clearViewportOrigination, createFakeEvent, createForeignObject, createG, createKeyboardEvent, createModModifierKeys, createMouseEvent, createPath, createPointerEvent, createSVG, createSelectionOuterG, createTestingBoard, createText, createTouchEvent, debounce, deleteTemporaryElements, depthFirstRecursion, distanceBetweenPointAndPoint, distanceBetweenPointAndRectangle, distanceBetweenPointAndSegment, downloadImage, drawAbstractRoundRectangle, drawArrow, drawBezierPath, drawCircle, drawLine, drawLinearPath, drawRoundRectangle, fakeNodeWeakMap, getBoardRectangle, getElementHostBBox, getHitElementOfRoot, getHitElements, getMovingElements, getRealScrollBarWidth, getRectangleByElements, getSelectedElements, getTemporaryElements, getViewBox, getViewBoxCenterPoint, getViewportContainerRect, getViewportOrigination, hasBeforeContextChange, hasInputOrTextareaTarget, hasOnBoardChange, hasOnContextChanged, hotkeys, idCreator, initializeViewBox, initializeViewportContainer, initializeViewportOffset, inverse, isDOMElement, isDOMNode, isFromScrolling, isFromViewportChange, isHitElements, isInPlaitBoard, isMainPointer, isNullOrUndefined, isSecondaryPointer, isSelectedElement, isSelectionMoving, isSetViewportOperation, normalizePoint, removeMovingElements, removeSelectedElement, rotate, scrollToRectangle, setIsFromScrolling, setIsFromViewportChange, setSVGViewBox, setSelectionMoving, shouldClear, shouldMerge, shouldSave, throttleRAF, toImage, toPoint, transformPoint, transformPoints, updateForeignObject, updateViewportContainerScroll, updateViewportOffset, updateViewportOrigination, withMoving, withOptions, withSelection };
|
|
3194
3297
|
//# sourceMappingURL=plait-core.mjs.map
|