@plait/core 0.62.0-next.5 → 0.62.0-next.7

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.
@@ -102,4 +102,4 @@ export const PlaitBoard = {
102
102
  return (board.options.themeColors || ThemeColors);
103
103
  }
104
104
  };
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.js","sourceRoot":"","sources":["../../../../packages/core/src/interfaces/board.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitPointerType } from './pointer';\nimport { ComponentType, PlaitElement } from './element';\nimport { PlaitPluginElementContext } from '../core/element/context';\nimport { PlaitHistory } from './history';\nimport { PlaitOperation } from './operation';\nimport { Selection } from './selection';\nimport { Viewport } from './viewport';\nimport {\n    BOARD_TO_CONTEXT,\n    BOARD_TO_ELEMENT_HOST,\n    BOARD_TO_HOST,\n    BOARD_TO_MOVING_POINT,\n    BOARD_TO_MOVING_POINT_IN_BOARD,\n    BOARD_TO_ROUGH_SVG,\n    IS_BOARD_ALIVE,\n    IS_BOARD_CACHE,\n    IS_TEXT_EDITABLE,\n    NODE_TO_INDEX,\n    NODE_TO_PARENT\n} from '../utils/weak-maps';\nimport { RoughSVG } from 'roughjs/bin/svg';\nimport { Point } from './point';\nimport { RectangleClient } from './rectangle-client';\nimport { getRectangleByElements } from '../utils/element';\nimport { PathRef, PathRefOptions } from './path-ref';\nimport { Ancestor, PlaitNode } from './node';\nimport { Path } from './path';\nimport { PlaitTheme, ThemeColor, ThemeColors } from './theme';\nimport { distanceBetweenPointAndRectangle } from '../utils/math';\nimport { ClipboardData, WritableClipboardContext, WritableClipboardOperationType } from '../utils';\nimport { ElementFlavour } from '../core/element/element-flavour';\nimport { PlaitBoardContext } from '../context';\n\nexport interface PlaitBoard {\n    viewport: Viewport;\n    children: PlaitElement[];\n    theme: PlaitTheme;\n    operations: PlaitOperation[];\n    // record pointer selection or drag selection\n    // it will be dirty when board viewport change\n    selection: Selection | null;\n    pointer: PlaitPointerType | string;\n    history: PlaitHistory;\n    options: PlaitBoardOptions;\n    undo: () => void;\n    redo: () => void;\n    apply: (operation: PlaitOperation) => void;\n    onChange: () => void;\n    afterChange: () => void;\n    drawActiveRectangle: () => SVGGElement | null;\n    mousedown: (event: MouseEvent) => void;\n    mousemove: (event: MouseEvent) => void;\n    mouseleave: (event: MouseEvent) => void;\n    mouseup: (event: MouseEvent) => void;\n    globalMousemove: (event: MouseEvent) => void;\n    globalMouseup: (event: MouseEvent) => void;\n    keyDown: (event: KeyboardEvent) => void;\n    globalKeyDown: (event: KeyboardEvent) => void;\n    keyUp: (event: KeyboardEvent) => void;\n    buildFragment: (\n        clipboardContext: WritableClipboardContext | null,\n        rectangle: RectangleClient | null,\n        operationType: WritableClipboardOperationType,\n        originData?: PlaitElement[]\n    ) => WritableClipboardContext | null;\n    insertFragment: (clipboardData: ClipboardData | null, targetPoint: Point, operationType?: WritableClipboardOperationType) => void;\n    deleteFragment: (data: PlaitElement[]) => void;\n    getDeletedFragment: (data: PlaitElement[]) => PlaitElement[];\n    getRelatedFragment: (data: PlaitElement[], originData?: PlaitElement[]) => PlaitElement[];\n    dblClick: (event: MouseEvent) => void;\n    drawElement: (context: PlaitPluginElementContext) => ComponentType<ElementFlavour>;\n    isRectangleHit: (element: PlaitElement, range: Selection) => boolean;\n    // When the element has no fill color, it is considered a hit only if it hits the border.\n    isHit: (element: PlaitElement, point: Point) => boolean;\n    isInsidePoint: (element: PlaitElement, point: Point) => boolean;\n    isRecursion: (element: PlaitElement) => boolean;\n    isMovable: (element: PlaitElement) => boolean;\n    getRectangle: (element: PlaitElement) => RectangleClient | null;\n    isWithinSelection: (element: PlaitElement) => boolean;\n    pathRef: (path: Path, options?: PathRefOptions) => PathRef;\n    pathRefs: () => Set<PathRef>;\n    applyTheme: (element: PlaitElement) => void;\n    isAlign: (element: PlaitElement) => boolean;\n    isImageBindingAllowed: (element: PlaitElement) => boolean;\n    canAddToGroup: (element: PlaitElement) => boolean;\n    canSetZIndex: (element: PlaitElement) => boolean;\n    isExpanded: (element: PlaitElement) => boolean;\n    // pointer hook\n    pointerDown: (pointer: PointerEvent) => void;\n    pointerMove: (pointer: PointerEvent) => void;\n    pointerUp: (pointer: PointerEvent) => void;\n    pointerCancel: (pointer: PointerEvent) => void;\n    pointerOut: (pointer: PointerEvent) => void;\n    pointerLeave: (pointer: PointerEvent) => void;\n    globalPointerMove: (pointer: PointerEvent) => void;\n    globalPointerUp: (pointer: PointerEvent) => void;\n}\n\nexport interface PlaitBoardOptions {\n    readonly?: boolean;\n    hideScrollbar?: boolean;\n    disabledScrollOnNonFocus?: boolean;\n    themeColors?: ThemeColor[];\n}\n\nexport interface PlaitBoardMove {\n    x: number;\n    y: number;\n}\n\nexport const PlaitBoard = {\n    isBoard(value: any): value is PlaitBoard {\n        const cachedIsBoard = IS_BOARD_CACHE.get(value);\n        if (cachedIsBoard !== undefined) {\n            return cachedIsBoard;\n        }\n        const isBoard = typeof value.onChange === 'function' && typeof value.apply === 'function';\n        IS_BOARD_CACHE.set(value, isBoard);\n        return isBoard;\n    },\n    isAlive(board: PlaitBoard) {\n        const isAlive = IS_BOARD_ALIVE.get(board);\n        return !!isAlive;\n    },\n    findPath(board: PlaitBoard, node: PlaitNode): Path {\n        const path: Path = [];\n        let child: Ancestor = node;\n        while (true) {\n            const parent = NODE_TO_PARENT.get(child as PlaitElement);\n            if (parent == null) {\n                if (PlaitBoard.isBoard(child)) {\n                    return path;\n                } else {\n                    break;\n                }\n            }\n            const i = NODE_TO_INDEX.get(child as PlaitElement);\n            if (i == null) {\n                break;\n            }\n            path.unshift(i);\n            child = parent;\n        }\n        throw new Error(`Unable to find the path for Plait node: ${JSON.stringify(node)}`);\n    },\n    getHost(board: PlaitBoard) {\n        return BOARD_TO_HOST.get(board) as SVGSVGElement;\n    },\n    getElementLowerHost(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.lowerHost as SVGSVGElement;\n    },\n    getElementHost(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.host as SVGSVGElement;\n    },\n    getElementUpperHost(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.upperHost as SVGSVGElement;\n    },\n    getElementActiveHost(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.activeHost as SVGSVGElement;\n    },\n    getRoughSVG(board: PlaitBoard) {\n        return BOARD_TO_ROUGH_SVG.get(board) as RoughSVG;\n    },\n    getBoardContainer(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.container as HTMLElement;\n    },\n    getBoardContext(board: PlaitBoard) {\n        return BOARD_TO_CONTEXT.get(board) as PlaitBoardContext;\n    },\n    getRectangle(board: PlaitBoard) {\n        return getRectangleByElements(board, board.children, true);\n    },\n    getViewportContainer(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.viewportContainer as HTMLElement;\n    },\n    isFocus(board: PlaitBoard) {\n        return !!board.selection;\n    },\n    isReadonly(board: PlaitBoard) {\n        return board.options.readonly;\n    },\n    hasBeenTextEditing(board: PlaitBoard) {\n        return !!IS_TEXT_EDITABLE.get(board);\n    },\n    getPointer<T = PlaitPointerType>(board: PlaitBoard) {\n        return board.pointer as T;\n    },\n    isPointer<T = PlaitPointerType>(board: PlaitBoard, pointer: T) {\n        return board.pointer === pointer;\n    },\n    isInPointer<T = PlaitPointerType>(board: PlaitBoard, pointers: T[]) {\n        const point = board.pointer as T;\n        return pointers.includes(point);\n    },\n    getMovingPointInBoard(board: PlaitBoard) {\n        return BOARD_TO_MOVING_POINT_IN_BOARD.get(board);\n    },\n    isMovingPointInBoard(board: PlaitBoard) {\n        const point = BOARD_TO_MOVING_POINT.get(board);\n        const rect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n        if (point && distanceBetweenPointAndRectangle(point[0], point[1], rect) === 0) {\n            return true;\n        }\n        return false;\n    },\n    getThemeColors<T extends ThemeColor = ThemeColor>(board: PlaitBoard) {\n        return (board.options.themeColors || ThemeColors) as T[];\n    }\n};\n"]}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.js","sourceRoot":"","sources":["../../../../packages/core/src/interfaces/board.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitPointerType } from './pointer';\nimport { ComponentType, PlaitElement } from './element';\nimport { PlaitPluginElementContext } from '../core/element/context';\nimport { PlaitHistory } from './history';\nimport { PlaitOperation } from './operation';\nimport { Selection } from './selection';\nimport { Viewport } from './viewport';\nimport {\n    BOARD_TO_CONTEXT,\n    BOARD_TO_ELEMENT_HOST,\n    BOARD_TO_HOST,\n    BOARD_TO_MOVING_POINT,\n    BOARD_TO_MOVING_POINT_IN_BOARD,\n    BOARD_TO_ROUGH_SVG,\n    IS_BOARD_ALIVE,\n    IS_BOARD_CACHE,\n    IS_TEXT_EDITABLE,\n    NODE_TO_INDEX,\n    NODE_TO_PARENT\n} from '../utils/weak-maps';\nimport { RoughSVG } from 'roughjs/bin/svg';\nimport { Point } from './point';\nimport { RectangleClient } from './rectangle-client';\nimport { getRectangleByElements } from '../utils/element';\nimport { PathRef, PathRefOptions } from './path-ref';\nimport { Ancestor, PlaitNode } from './node';\nimport { Path } from './path';\nimport { PlaitTheme, ThemeColor, ThemeColors } from './theme';\nimport { distanceBetweenPointAndRectangle } from '../utils/math';\nimport { ClipboardData, WritableClipboardContext, WritableClipboardOperationType } from '../utils';\nimport { ElementFlavour } from '../core/element/element-flavour';\nimport { PlaitBoardContext } from '../context';\n\nexport interface PlaitBoard {\n    viewport: Viewport;\n    children: PlaitElement[];\n    theme: PlaitTheme;\n    operations: PlaitOperation[];\n    // record pointer selection or drag selection\n    // it will be dirty when board viewport change\n    selection: Selection | null;\n    pointer: PlaitPointerType | string;\n    history: PlaitHistory;\n    options: PlaitBoardOptions;\n    undo: () => void;\n    redo: () => void;\n    apply: (operation: PlaitOperation) => void;\n    onChange: () => void;\n    afterChange: () => void;\n    drawActiveRectangle: () => SVGGElement | null;\n    mousedown: (event: MouseEvent) => void;\n    mousemove: (event: MouseEvent) => void;\n    mouseleave: (event: MouseEvent) => void;\n    mouseup: (event: MouseEvent) => void;\n    globalMousemove: (event: MouseEvent) => void;\n    globalMouseup: (event: MouseEvent) => void;\n    keyDown: (event: KeyboardEvent) => void;\n    globalKeyDown: (event: KeyboardEvent) => void;\n    keyUp: (event: KeyboardEvent) => void;\n    buildFragment: (\n        clipboardContext: WritableClipboardContext | null,\n        rectangle: RectangleClient | null,\n        operationType: WritableClipboardOperationType,\n        originData?: PlaitElement[]\n    ) => WritableClipboardContext | null;\n    insertFragment: (clipboardData: ClipboardData | null, targetPoint: Point, operationType?: WritableClipboardOperationType) => void;\n    deleteFragment: (data: PlaitElement[]) => void;\n    getDeletedFragment: (data: PlaitElement[]) => PlaitElement[];\n    getRelatedFragment: (data: PlaitElement[], originData?: PlaitElement[]) => PlaitElement[];\n    dblClick: (event: MouseEvent) => void;\n    drawElement: (context: PlaitPluginElementContext) => ComponentType<ElementFlavour>;\n    isRectangleHit: (element: PlaitElement, range: Selection) => boolean;\n    // When the element has no fill color, it is considered a hit only if it hits the border.\n    isHit: (element: PlaitElement, point: Point) => boolean;\n    isInsidePoint: (element: PlaitElement, point: Point) => boolean;\n    getHitElement: (hitElements: PlaitElement[]) => PlaitElement;\n    isRecursion: (element: PlaitElement) => boolean;\n    isMovable: (element: PlaitElement) => boolean;\n    getRectangle: (element: PlaitElement) => RectangleClient | null;\n    isWithinSelection: (element: PlaitElement) => boolean;\n    pathRef: (path: Path, options?: PathRefOptions) => PathRef;\n    pathRefs: () => Set<PathRef>;\n    applyTheme: (element: PlaitElement) => void;\n    isAlign: (element: PlaitElement) => boolean;\n    isImageBindingAllowed: (element: PlaitElement) => boolean;\n    canAddToGroup: (element: PlaitElement) => boolean;\n    canSetZIndex: (element: PlaitElement) => boolean;\n    isExpanded: (element: PlaitElement) => boolean;\n    // pointer hook\n    pointerDown: (pointer: PointerEvent) => void;\n    pointerMove: (pointer: PointerEvent) => void;\n    pointerUp: (pointer: PointerEvent) => void;\n    pointerCancel: (pointer: PointerEvent) => void;\n    pointerOut: (pointer: PointerEvent) => void;\n    pointerLeave: (pointer: PointerEvent) => void;\n    globalPointerMove: (pointer: PointerEvent) => void;\n    globalPointerUp: (pointer: PointerEvent) => void;\n}\n\nexport interface PlaitBoardOptions {\n    readonly?: boolean;\n    hideScrollbar?: boolean;\n    disabledScrollOnNonFocus?: boolean;\n    themeColors?: ThemeColor[];\n}\n\nexport interface PlaitBoardMove {\n    x: number;\n    y: number;\n}\n\nexport const PlaitBoard = {\n    isBoard(value: any): value is PlaitBoard {\n        const cachedIsBoard = IS_BOARD_CACHE.get(value);\n        if (cachedIsBoard !== undefined) {\n            return cachedIsBoard;\n        }\n        const isBoard = typeof value.onChange === 'function' && typeof value.apply === 'function';\n        IS_BOARD_CACHE.set(value, isBoard);\n        return isBoard;\n    },\n    isAlive(board: PlaitBoard) {\n        const isAlive = IS_BOARD_ALIVE.get(board);\n        return !!isAlive;\n    },\n    findPath(board: PlaitBoard, node: PlaitNode): Path {\n        const path: Path = [];\n        let child: Ancestor = node;\n        while (true) {\n            const parent = NODE_TO_PARENT.get(child as PlaitElement);\n            if (parent == null) {\n                if (PlaitBoard.isBoard(child)) {\n                    return path;\n                } else {\n                    break;\n                }\n            }\n            const i = NODE_TO_INDEX.get(child as PlaitElement);\n            if (i == null) {\n                break;\n            }\n            path.unshift(i);\n            child = parent;\n        }\n        throw new Error(`Unable to find the path for Plait node: ${JSON.stringify(node)}`);\n    },\n    getHost(board: PlaitBoard) {\n        return BOARD_TO_HOST.get(board) as SVGSVGElement;\n    },\n    getElementLowerHost(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.lowerHost as SVGSVGElement;\n    },\n    getElementHost(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.host as SVGSVGElement;\n    },\n    getElementUpperHost(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.upperHost as SVGSVGElement;\n    },\n    getElementActiveHost(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.activeHost as SVGSVGElement;\n    },\n    getRoughSVG(board: PlaitBoard) {\n        return BOARD_TO_ROUGH_SVG.get(board) as RoughSVG;\n    },\n    getBoardContainer(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.container as HTMLElement;\n    },\n    getBoardContext(board: PlaitBoard) {\n        return BOARD_TO_CONTEXT.get(board) as PlaitBoardContext;\n    },\n    getRectangle(board: PlaitBoard) {\n        return getRectangleByElements(board, board.children, true);\n    },\n    getViewportContainer(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.viewportContainer as HTMLElement;\n    },\n    isFocus(board: PlaitBoard) {\n        return !!board.selection;\n    },\n    isReadonly(board: PlaitBoard) {\n        return board.options.readonly;\n    },\n    hasBeenTextEditing(board: PlaitBoard) {\n        return !!IS_TEXT_EDITABLE.get(board);\n    },\n    getPointer<T = PlaitPointerType>(board: PlaitBoard) {\n        return board.pointer as T;\n    },\n    isPointer<T = PlaitPointerType>(board: PlaitBoard, pointer: T) {\n        return board.pointer === pointer;\n    },\n    isInPointer<T = PlaitPointerType>(board: PlaitBoard, pointers: T[]) {\n        const point = board.pointer as T;\n        return pointers.includes(point);\n    },\n    getMovingPointInBoard(board: PlaitBoard) {\n        return BOARD_TO_MOVING_POINT_IN_BOARD.get(board);\n    },\n    isMovingPointInBoard(board: PlaitBoard) {\n        const point = BOARD_TO_MOVING_POINT.get(board);\n        const rect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n        if (point && distanceBetweenPointAndRectangle(point[0], point[1], rect) === 0) {\n            return true;\n        }\n        return false;\n    },\n    getThemeColors<T extends ThemeColor = ThemeColor>(board: PlaitBoard) {\n        return (board.options.themeColors || ThemeColors) as T[];\n    }\n};\n"]}
@@ -96,6 +96,7 @@ export function createBoard(children, options) {
96
96
  isRectangleHit: element => false,
97
97
  isHit: element => false,
98
98
  isInsidePoint: element => false,
99
+ getHitElement: (data) => data[0],
99
100
  isRecursion: element => true,
100
101
  isMovable: element => false,
101
102
  getRectangle: element => null,
@@ -116,4 +117,4 @@ export function createBoard(children, options) {
116
117
  };
117
118
  return board;
118
119
  }
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-board.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/create-board.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitBoardOptions } from '../interfaces/board';\nimport { PlaitPointerType } from '../interfaces/pointer';\nimport { PlaitElement } from '../interfaces/element';\nimport { PlaitPluginElementContext } from '../core/element/context';\nimport { PlaitOperation } from '../interfaces/operation';\nimport { Transforms } from '../transforms';\nimport { FLUSHING, PATH_REFS } from '../utils/weak-maps';\nimport { PathRef, PathRefOptions } from '../interfaces/path-ref';\nimport { Path } from '../interfaces/path';\nimport { ThemeColorMode } from '../interfaces/theme';\nimport { CoreTransforms } from '../transforms/element';\nimport { ClipboardData, WritableClipboardContext, WritableClipboardOperationType, drawEntireActiveRectangleG } from '../utils';\nimport { Point, RectangleClient } from '../interfaces';\n\nexport function createBoard(children: PlaitElement[], options?: PlaitBoardOptions): PlaitBoard {\n    const board: PlaitBoard = {\n        viewport: {\n            zoom: 1\n        },\n        children,\n        theme: { themeColorMode: ThemeColorMode.default },\n        operations: [],\n        history: {\n            redos: [],\n            undos: []\n        },\n        selection: null,\n        options: options || {\n            readonly: false,\n            hideScrollbar: false,\n            disabledScrollOnNonFocus: false\n        },\n        pointer: options?.readonly ? PlaitPointerType.hand : PlaitPointerType.selection,\n        undo: () => {},\n        redo: () => {},\n        apply: (operation: PlaitOperation) => {\n            for (const ref of board.pathRefs()) {\n                PathRef.transform(ref, operation);\n            }\n\n            board.operations.push(operation);\n\n            Transforms.transform(board, operation);\n\n            if (!FLUSHING.get(board)) {\n                FLUSHING.set(board, true);\n\n                Promise.resolve().then(() => {\n                    FLUSHING.set(board, false);\n                    board.onChange();\n                    board.afterChange();\n                    board.operations = [];\n                });\n            }\n        },\n        pathRef: (path: Path, options?: PathRefOptions) => {\n            const affinity = options?.affinity || 'forward';\n            const ref: PathRef = {\n                current: path,\n                affinity,\n                unref() {\n                    const { current } = ref;\n                    const pathRefs = board.pathRefs();\n                    pathRefs.delete(ref);\n                    ref.current = null;\n                    return current;\n                }\n            };\n\n            const refs = board.pathRefs();\n            refs.add(ref);\n            return ref;\n        },\n        pathRefs: () => {\n            let refs = PATH_REFS.get(board);\n\n            if (!refs) {\n                refs = new Set();\n                PATH_REFS.set(board, refs);\n            }\n\n            return refs;\n        },\n        onChange: () => {},\n        afterChange: () => {},\n        drawActiveRectangle: () => {\n            return drawEntireActiveRectangleG(board);\n        },\n        mousedown: (event: MouseEvent) => {},\n        mousemove: (event: MouseEvent) => {},\n        mouseleave: (event: MouseEvent) => {},\n        globalMousemove: (event: MouseEvent) => {},\n        mouseup: (event: MouseEvent) => {},\n        globalMouseup: (event: MouseEvent) => {},\n        keyDown: (event: KeyboardEvent) => {},\n        globalKeyDown: (event: KeyboardEvent) => {},\n        keyUp: (event: KeyboardEvent) => {},\n        dblClick: (event: MouseEvent) => {},\n        buildFragment: (\n            clipboardContext: WritableClipboardContext | null,\n            rectangle: RectangleClient | null,\n            operationType: WritableClipboardOperationType,\n            originData?: PlaitElement[]\n        ) => clipboardContext,\n        insertFragment: (clipboardData: ClipboardData | null, targetPoint: Point, operationType?: WritableClipboardOperationType) => {},\n        deleteFragment: (elements: PlaitElement[]) => {\n            CoreTransforms.removeElements(board, elements);\n        },\n        getDeletedFragment: (data: PlaitElement[]) => data,\n        getRelatedFragment: (data: PlaitElement[], originData?: PlaitElement[]) => data,\n        drawElement: (context: PlaitPluginElementContext) => {\n            throw new Error(`can not resolve plugin element component type: ${context.element.type}`);\n        },\n        isWithinSelection: element => false,\n        isRectangleHit: element => false,\n        isHit: element => false,\n        isInsidePoint: element => false,\n        isRecursion: element => true,\n        isMovable: element => false,\n        getRectangle: element => null,\n        applyTheme: (element: PlaitElement) => {},\n        isAlign: element => false,\n        pointerDown: pointer => {},\n        pointerMove: pointer => {},\n        pointerUp: pointer => {},\n        pointerCancel: pointer => {},\n        pointerOut: pointer => {},\n        pointerLeave: pointer => {},\n        globalPointerMove: pointer => {},\n        globalPointerUp: pointer => {},\n        isImageBindingAllowed: (element: PlaitElement) => false,\n        canAddToGroup: (element: PlaitElement) => true,\n        canSetZIndex: (element: PlaitElement) => true,\n        isExpanded: (element: PlaitElement) => true\n    };\n    return board;\n}\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-board.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/create-board.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAIzD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,OAAO,EAAkB,MAAM,wBAAwB,CAAC;AAEjE,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAA2E,0BAA0B,EAAE,MAAM,UAAU,CAAC;AAG/H,MAAM,UAAU,WAAW,CAAC,QAAwB,EAAE,OAA2B;IAC7E,MAAM,KAAK,GAAe;QACtB,QAAQ,EAAE;YACN,IAAI,EAAE,CAAC;SACV;QACD,QAAQ;QACR,KAAK,EAAE,EAAE,cAAc,EAAE,cAAc,CAAC,OAAO,EAAE;QACjD,UAAU,EAAE,EAAE;QACd,OAAO,EAAE;YACL,KAAK,EAAE,EAAE;YACT,KAAK,EAAE,EAAE;SACZ;QACD,SAAS,EAAE,IAAI;QACf,OAAO,EAAE,OAAO,IAAI;YAChB,QAAQ,EAAE,KAAK;YACf,aAAa,EAAE,KAAK;YACpB,wBAAwB,EAAE,KAAK;SAClC;QACD,OAAO,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,gBAAgB,CAAC,SAAS;QAC/E,IAAI,EAAE,GAAG,EAAE,GAAE,CAAC;QACd,IAAI,EAAE,GAAG,EAAE,GAAE,CAAC;QACd,KAAK,EAAE,CAAC,SAAyB,EAAE,EAAE;YACjC,KAAK,MAAM,GAAG,IAAI,KAAK,CAAC,QAAQ,EAAE,EAAE,CAAC;gBACjC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;YACtC,CAAC;YAED,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAEjC,UAAU,CAAC,SAAS,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;YAEvC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;gBACvB,QAAQ,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;gBAE1B,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;oBACxB,QAAQ,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;oBAC3B,KAAK,CAAC,QAAQ,EAAE,CAAC;oBACjB,KAAK,CAAC,WAAW,EAAE,CAAC;oBACpB,KAAK,CAAC,UAAU,GAAG,EAAE,CAAC;gBAC1B,CAAC,CAAC,CAAC;YACP,CAAC;QACL,CAAC;QACD,OAAO,EAAE,CAAC,IAAU,EAAE,OAAwB,EAAE,EAAE;YAC9C,MAAM,QAAQ,GAAG,OAAO,EAAE,QAAQ,IAAI,SAAS,CAAC;YAChD,MAAM,GAAG,GAAY;gBACjB,OAAO,EAAE,IAAI;gBACb,QAAQ;gBACR,KAAK;oBACD,MAAM,EAAE,OAAO,EAAE,GAAG,GAAG,CAAC;oBACxB,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC;oBAClC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;oBACrB,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC;oBACnB,OAAO,OAAO,CAAC;gBACnB,CAAC;aACJ,CAAC;YAEF,MAAM,IAAI,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC;YAC9B,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACd,OAAO,GAAG,CAAC;QACf,CAAC;QACD,QAAQ,EAAE,GAAG,EAAE;YACX,IAAI,IAAI,GAAG,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAEhC,IAAI,CAAC,IAAI,EAAE,CAAC;gBACR,IAAI,GAAG,IAAI,GAAG,EAAE,CAAC;gBACjB,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;YAC/B,CAAC;YAED,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC;QAClB,WAAW,EAAE,GAAG,EAAE,GAAE,CAAC;QACrB,mBAAmB,EAAE,GAAG,EAAE;YACtB,OAAO,0BAA0B,CAAC,KAAK,CAAC,CAAC;QAC7C,CAAC;QACD,SAAS,EAAE,CAAC,KAAiB,EAAE,EAAE,GAAE,CAAC;QACpC,SAAS,EAAE,CAAC,KAAiB,EAAE,EAAE,GAAE,CAAC;QACpC,UAAU,EAAE,CAAC,KAAiB,EAAE,EAAE,GAAE,CAAC;QACrC,eAAe,EAAE,CAAC,KAAiB,EAAE,EAAE,GAAE,CAAC;QAC1C,OAAO,EAAE,CAAC,KAAiB,EAAE,EAAE,GAAE,CAAC;QAClC,aAAa,EAAE,CAAC,KAAiB,EAAE,EAAE,GAAE,CAAC;QACxC,OAAO,EAAE,CAAC,KAAoB,EAAE,EAAE,GAAE,CAAC;QACrC,aAAa,EAAE,CAAC,KAAoB,EAAE,EAAE,GAAE,CAAC;QAC3C,KAAK,EAAE,CAAC,KAAoB,EAAE,EAAE,GAAE,CAAC;QACnC,QAAQ,EAAE,CAAC,KAAiB,EAAE,EAAE,GAAE,CAAC;QACnC,aAAa,EAAE,CACX,gBAAiD,EACjD,SAAiC,EACjC,aAA6C,EAC7C,UAA2B,EAC7B,EAAE,CAAC,gBAAgB;QACrB,cAAc,EAAE,CAAC,aAAmC,EAAE,WAAkB,EAAE,aAA8C,EAAE,EAAE,GAAE,CAAC;QAC/H,cAAc,EAAE,CAAC,QAAwB,EAAE,EAAE;YACzC,cAAc,CAAC,cAAc,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QACnD,CAAC;QACD,kBAAkB,EAAE,CAAC,IAAoB,EAAE,EAAE,CAAC,IAAI;QAClD,kBAAkB,EAAE,CAAC,IAAoB,EAAE,UAA2B,EAAE,EAAE,CAAC,IAAI;QAC/E,WAAW,EAAE,CAAC,OAAkC,EAAE,EAAE;YAChD,MAAM,IAAI,KAAK,CAAC,kDAAkD,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;QAC9F,CAAC;QACD,iBAAiB,EAAE,OAAO,CAAC,EAAE,CAAC,KAAK;QACnC,cAAc,EAAE,OAAO,CAAC,EAAE,CAAC,KAAK;QAChC,KAAK,EAAE,OAAO,CAAC,EAAE,CAAC,KAAK;QACvB,aAAa,EAAE,OAAO,CAAC,EAAE,CAAC,KAAK;QAC/B,aAAa,EAAE,CAAC,IAAoB,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;QAChD,WAAW,EAAE,OAAO,CAAC,EAAE,CAAC,IAAI;QAC5B,SAAS,EAAE,OAAO,CAAC,EAAE,CAAC,KAAK;QAC3B,YAAY,EAAE,OAAO,CAAC,EAAE,CAAC,IAAI;QAC7B,UAAU,EAAE,CAAC,OAAqB,EAAE,EAAE,GAAE,CAAC;QACzC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,KAAK;QACzB,WAAW,EAAE,OAAO,CAAC,EAAE,GAAE,CAAC;QAC1B,WAAW,EAAE,OAAO,CAAC,EAAE,GAAE,CAAC;QAC1B,SAAS,EAAE,OAAO,CAAC,EAAE,GAAE,CAAC;QACxB,aAAa,EAAE,OAAO,CAAC,EAAE,GAAE,CAAC;QAC5B,UAAU,EAAE,OAAO,CAAC,EAAE,GAAE,CAAC;QACzB,YAAY,EAAE,OAAO,CAAC,EAAE,GAAE,CAAC;QAC3B,iBAAiB,EAAE,OAAO,CAAC,EAAE,GAAE,CAAC;QAChC,eAAe,EAAE,OAAO,CAAC,EAAE,GAAE,CAAC;QAC9B,qBAAqB,EAAE,CAAC,OAAqB,EAAE,EAAE,CAAC,KAAK;QACvD,aAAa,EAAE,CAAC,OAAqB,EAAE,EAAE,CAAC,IAAI;QAC9C,YAAY,EAAE,CAAC,OAAqB,EAAE,EAAE,CAAC,IAAI;QAC7C,UAAU,EAAE,CAAC,OAAqB,EAAE,EAAE,CAAC,IAAI;KAC9C,CAAC;IACF,OAAO,KAAK,CAAC;AACjB,CAAC","sourcesContent":["import { PlaitBoard, PlaitBoardOptions } from '../interfaces/board';\nimport { PlaitPointerType } from '../interfaces/pointer';\nimport { PlaitElement } from '../interfaces/element';\nimport { PlaitPluginElementContext } from '../core/element/context';\nimport { PlaitOperation } from '../interfaces/operation';\nimport { Transforms } from '../transforms';\nimport { FLUSHING, PATH_REFS } from '../utils/weak-maps';\nimport { PathRef, PathRefOptions } from '../interfaces/path-ref';\nimport { Path } from '../interfaces/path';\nimport { ThemeColorMode } from '../interfaces/theme';\nimport { CoreTransforms } from '../transforms/element';\nimport { ClipboardData, WritableClipboardContext, WritableClipboardOperationType, drawEntireActiveRectangleG } from '../utils';\nimport { Point, RectangleClient } from '../interfaces';\n\nexport function createBoard(children: PlaitElement[], options?: PlaitBoardOptions): PlaitBoard {\n    const board: PlaitBoard = {\n        viewport: {\n            zoom: 1\n        },\n        children,\n        theme: { themeColorMode: ThemeColorMode.default },\n        operations: [],\n        history: {\n            redos: [],\n            undos: []\n        },\n        selection: null,\n        options: options || {\n            readonly: false,\n            hideScrollbar: false,\n            disabledScrollOnNonFocus: false\n        },\n        pointer: options?.readonly ? PlaitPointerType.hand : PlaitPointerType.selection,\n        undo: () => {},\n        redo: () => {},\n        apply: (operation: PlaitOperation) => {\n            for (const ref of board.pathRefs()) {\n                PathRef.transform(ref, operation);\n            }\n\n            board.operations.push(operation);\n\n            Transforms.transform(board, operation);\n\n            if (!FLUSHING.get(board)) {\n                FLUSHING.set(board, true);\n\n                Promise.resolve().then(() => {\n                    FLUSHING.set(board, false);\n                    board.onChange();\n                    board.afterChange();\n                    board.operations = [];\n                });\n            }\n        },\n        pathRef: (path: Path, options?: PathRefOptions) => {\n            const affinity = options?.affinity || 'forward';\n            const ref: PathRef = {\n                current: path,\n                affinity,\n                unref() {\n                    const { current } = ref;\n                    const pathRefs = board.pathRefs();\n                    pathRefs.delete(ref);\n                    ref.current = null;\n                    return current;\n                }\n            };\n\n            const refs = board.pathRefs();\n            refs.add(ref);\n            return ref;\n        },\n        pathRefs: () => {\n            let refs = PATH_REFS.get(board);\n\n            if (!refs) {\n                refs = new Set();\n                PATH_REFS.set(board, refs);\n            }\n\n            return refs;\n        },\n        onChange: () => {},\n        afterChange: () => {},\n        drawActiveRectangle: () => {\n            return drawEntireActiveRectangleG(board);\n        },\n        mousedown: (event: MouseEvent) => {},\n        mousemove: (event: MouseEvent) => {},\n        mouseleave: (event: MouseEvent) => {},\n        globalMousemove: (event: MouseEvent) => {},\n        mouseup: (event: MouseEvent) => {},\n        globalMouseup: (event: MouseEvent) => {},\n        keyDown: (event: KeyboardEvent) => {},\n        globalKeyDown: (event: KeyboardEvent) => {},\n        keyUp: (event: KeyboardEvent) => {},\n        dblClick: (event: MouseEvent) => {},\n        buildFragment: (\n            clipboardContext: WritableClipboardContext | null,\n            rectangle: RectangleClient | null,\n            operationType: WritableClipboardOperationType,\n            originData?: PlaitElement[]\n        ) => clipboardContext,\n        insertFragment: (clipboardData: ClipboardData | null, targetPoint: Point, operationType?: WritableClipboardOperationType) => {},\n        deleteFragment: (elements: PlaitElement[]) => {\n            CoreTransforms.removeElements(board, elements);\n        },\n        getDeletedFragment: (data: PlaitElement[]) => data,\n        getRelatedFragment: (data: PlaitElement[], originData?: PlaitElement[]) => data,\n        drawElement: (context: PlaitPluginElementContext) => {\n            throw new Error(`can not resolve plugin element component type: ${context.element.type}`);\n        },\n        isWithinSelection: element => false,\n        isRectangleHit: element => false,\n        isHit: element => false,\n        isInsidePoint: element => false,\n        getHitElement: (data: PlaitElement[]) => data[0],\n        isRecursion: element => true,\n        isMovable: element => false,\n        getRectangle: element => null,\n        applyTheme: (element: PlaitElement) => {},\n        isAlign: element => false,\n        pointerDown: pointer => {},\n        pointerMove: pointer => {},\n        pointerUp: pointer => {},\n        pointerCancel: pointer => {},\n        pointerOut: pointer => {},\n        pointerLeave: pointer => {},\n        globalPointerMove: pointer => {},\n        globalPointerUp: pointer => {},\n        isImageBindingAllowed: (element: PlaitElement) => false,\n        canAddToGroup: (element: PlaitElement) => true,\n        canSetZIndex: (element: PlaitElement) => true,\n        isExpanded: (element: PlaitElement) => true\n    };\n    return board;\n}\n"]}
@@ -124,6 +124,12 @@ export function withSelection(board) {
124
124
  setSelectedElementsWithGroup(board, elements, isShift);
125
125
  }
126
126
  else {
127
+ if (board.selection && Selection.isCollapsed(board.selection)) {
128
+ const element = board.getHitElement(elements);
129
+ if (element) {
130
+ elements = [element];
131
+ }
132
+ }
127
133
  if (isShift) {
128
134
  const newElements = [...selectedElements];
129
135
  if (board.selection && Selection.isCollapsed(board.selection)) {
@@ -198,4 +204,4 @@ export function withSelection(board) {
198
204
  });
199
205
  return board;
200
206
  }
201
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-selection.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-selection.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\nimport { Transforms } from '../transforms';\nimport { isMainPointer } from '../utils/dom/common';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport {\n    cacheSelectedElements,\n    clearSelectedElement,\n    getHitElementsBySelection,\n    getSelectedElements,\n    isHitElement,\n    removeSelectedElement\n} from '../utils/selected-element';\nimport { PlaitElement, PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';\nimport { ATTACHED_ELEMENT_CLASS_NAME } from '../constants/selection';\nimport {\n    clearSelectionMoving,\n    deleteTemporaryElements,\n    drawRectangle,\n    getTemporaryElements,\n    isDragging,\n    isHandleSelection,\n    isSelectionMoving,\n    preventTouchMove,\n    setSelectionMoving,\n    throttleRAF,\n    toHostPoint,\n    toViewBoxPoint,\n    setSelectedElementsWithGroup,\n    hasSetSelectionOperation\n} from '../utils';\nimport { PlaitOptionsBoard, PlaitPluginOptions } from './with-options';\nimport { PlaitPluginKey } from '../interfaces/plugin-key';\nimport { Selection } from '../interfaces/selection';\nimport { PRESS_AND_MOVE_BUFFER } from '../constants';\n\nexport interface WithPluginOptions extends PlaitPluginOptions {\n    isMultiple: boolean;\n    isDisabledSelect: boolean;\n}\n\nexport function withSelection(board: PlaitBoard) {\n    const { pointerDown, pointerUp, pointerMove, globalPointerUp, onChange, afterChange, drawActiveRectangle } = board;\n    let start: Point | null = null;\n    let end: Point | null = null;\n    let selectionMovingG: SVGGElement;\n    let selectionRectangleG: SVGGElement | null;\n    let previousSelectedElements: PlaitElement[];\n    let isShift = false;\n\n    board.pointerDown = (event: PointerEvent) => {\n        if (!isShift && event.shiftKey) {\n            isShift = true;\n        }\n        if (isShift && !event.shiftKey) {\n            isShift = false;\n        }\n        const isHitText = !!(event.target instanceof Element && event.target.closest('.plait-text-container'));\n\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const isHitTarget = isHitElement(board, point);\n        const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n        if (PlaitBoard.isPointer(board, PlaitPointerType.selection) && !isHitTarget && options.isMultiple && !options.isDisabledSelect) {\n            preventTouchMove(board, event, true);\n            // start rectangle selection\n            start = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        if (PlaitBoard.isPointer(board, PlaitPointerType.selection) && start) {\n            const movedTarget = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n            const rectangle = RectangleClient.getRectangleByPoints([start, movedTarget]);\n            selectionMovingG?.remove();\n            if (Math.hypot(rectangle.width, rectangle.height) > PRESS_AND_MOVE_BUFFER || isSelectionMoving(board)) {\n                end = movedTarget;\n                throttleRAF(board, 'with-selection', () => {\n                    if (start && end) {\n                        Transforms.setSelection(board, { anchor: start, focus: end });\n                    }\n                });\n                setSelectionMoving(board);\n                selectionMovingG = drawRectangle(board, rectangle, {\n                    stroke: SELECTION_BORDER_COLOR,\n                    strokeWidth: 1,\n                    fill: SELECTION_FILL_COLOR,\n                    fillStyle: 'solid'\n                });\n                PlaitBoard.getElementActiveHost(board).append(selectionMovingG);\n            }\n        }\n        pointerMove(event);\n    };\n\n    // handle the end of click select\n    board.pointerUp = (event: PointerEvent) => {\n        const isSetSelectionPointer =\n            PlaitBoard.isPointer(board, PlaitPointerType.selection) || PlaitBoard.isPointer(board, PlaitPointerType.hand);\n        const isSkip = !isMainPointer(event) || isDragging(board) || !isSetSelectionPointer;\n        if (isSkip) {\n            pointerUp(event);\n            return;\n        }\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const selection = { anchor: point, focus: point };\n        Transforms.setSelection(board, selection);\n        pointerUp(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        if (start && end) {\n            selectionMovingG?.remove();\n            clearSelectionMoving(board);\n            Transforms.setSelection(board, { anchor: start, focus: end });\n        }\n\n        if (PlaitBoard.isFocus(board)) {\n            const isInBoard = event.target instanceof Node && PlaitBoard.getBoardContainer(board).contains(event.target);\n            const isInDocument = event.target instanceof Node && document.contains(event.target);\n            const isAttachedElement = event.target instanceof Element && event.target.closest(`.${ATTACHED_ELEMENT_CLASS_NAME}`);\n            // Clear selection when mouse board outside area\n            // The framework needs to determine whether the board is focused through selection\n            if (!isInBoard && !start && !isAttachedElement && isInDocument) {\n                Transforms.setSelection(board, null);\n            }\n        }\n        start = null;\n        end = null;\n        preventTouchMove(board, event, false);\n        globalPointerUp(event);\n    };\n\n    board.onChange = () => {\n        const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n        if (options.isDisabledSelect) {\n            clearSelectedElement(board);\n        }\n        // remove selected element if include\n        board.operations.forEach(op => {\n            if (op.type === 'remove_node') {\n                removeSelectedElement(board, op.node, true);\n            }\n        });\n        if (isHandleSelection(board) && hasSetSelectionOperation(board)) {\n            try {\n                if (!isShift) {\n                    selectionRectangleG?.remove();\n                }\n                const temporaryElements = getTemporaryElements(board);\n                if (temporaryElements) {\n                    cacheSelectedElements(board, [...temporaryElements]);\n                } else {\n                    let elements = getHitElementsBySelection(board);\n                    if (!options.isMultiple && elements.length > 1) {\n                        elements = [elements[0]];\n                    }\n                    const isHitElementWithGroup = elements.some(item => item.groupId);\n                    const selectedElements = getSelectedElements(board);\n                    if (isHitElementWithGroup) {\n                        setSelectedElementsWithGroup(board, elements, isShift);\n                    } else {\n                        if (isShift) {\n                            const newElements = [...selectedElements];\n                            if (board.selection && Selection.isCollapsed(board.selection)) {\n                                elements.forEach(element => {\n                                    if (newElements.includes(element)) {\n                                        newElements.splice(newElements.indexOf(element), 1);\n                                    } else {\n                                        newElements.push(element);\n                                    }\n                                });\n                                cacheSelectedElements(board, newElements);\n                            } else {\n                                elements.forEach(element => {\n                                    if (!newElements.includes(element)) {\n                                        newElements.push(element);\n                                    }\n                                });\n                                cacheSelectedElements(board, [...newElements]);\n                            }\n                        } else {\n                            cacheSelectedElements(board, [...elements]);\n                        }\n                    }\n                }\n                const newElements = getSelectedElements(board);\n                previousSelectedElements = newElements;\n                deleteTemporaryElements(board);\n                if (!isSelectionMoving(board)) {\n                    selectionRectangleG?.remove();\n                    if (newElements.length > 1) {\n                        selectionRectangleG = board.drawActiveRectangle();\n                        PlaitBoard.getElementActiveHost(board).append(selectionRectangleG!);\n                    }\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        onChange();\n    };\n\n    board.afterChange = () => {\n        if (isHandleSelection(board) && !hasSetSelectionOperation(board)) {\n            try {\n                const currentSelectedElements = getSelectedElements(board);\n                if (currentSelectedElements.length && currentSelectedElements.length > 1) {\n                    if (\n                        previousSelectedElements &&\n                        (currentSelectedElements.length !== previousSelectedElements.length ||\n                            currentSelectedElements.some((c, index) => c !== previousSelectedElements[index]))\n                    ) {\n                        selectionRectangleG?.remove();\n                        selectionRectangleG = board.drawActiveRectangle();\n                        PlaitBoard.getElementActiveHost(board).append(selectionRectangleG!);\n                        previousSelectedElements = currentSelectedElements;\n                    }\n                } else {\n                    selectionRectangleG?.remove();\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        afterChange();\n    };\n\n    (board as PlaitOptionsBoard).setPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection, {\n        isMultiple: true,\n        isDisabledSelect: false\n    });\n\n    return board;\n}\n"]}
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-selection.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-selection.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\nimport { Transforms } from '../transforms';\nimport { isMainPointer } from '../utils/dom/common';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport {\n    cacheSelectedElements,\n    clearSelectedElement,\n    getHitElementsBySelection,\n    getSelectedElements,\n    isHitElement,\n    removeSelectedElement\n} from '../utils/selected-element';\nimport { PlaitElement, PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';\nimport { ATTACHED_ELEMENT_CLASS_NAME } from '../constants/selection';\nimport {\n    clearSelectionMoving,\n    deleteTemporaryElements,\n    drawRectangle,\n    getTemporaryElements,\n    isDragging,\n    isHandleSelection,\n    isSelectionMoving,\n    preventTouchMove,\n    setSelectionMoving,\n    throttleRAF,\n    toHostPoint,\n    toViewBoxPoint,\n    setSelectedElementsWithGroup,\n    hasSetSelectionOperation\n} from '../utils';\nimport { PlaitOptionsBoard, PlaitPluginOptions } from './with-options';\nimport { PlaitPluginKey } from '../interfaces/plugin-key';\nimport { Selection } from '../interfaces/selection';\nimport { PRESS_AND_MOVE_BUFFER } from '../constants';\n\nexport interface WithPluginOptions extends PlaitPluginOptions {\n    isMultiple: boolean;\n    isDisabledSelect: boolean;\n}\n\nexport function withSelection(board: PlaitBoard) {\n    const { pointerDown, pointerUp, pointerMove, globalPointerUp, onChange, afterChange, drawActiveRectangle } = board;\n    let start: Point | null = null;\n    let end: Point | null = null;\n    let selectionMovingG: SVGGElement;\n    let selectionRectangleG: SVGGElement | null;\n    let previousSelectedElements: PlaitElement[];\n    let isShift = false;\n\n    board.pointerDown = (event: PointerEvent) => {\n        if (!isShift && event.shiftKey) {\n            isShift = true;\n        }\n        if (isShift && !event.shiftKey) {\n            isShift = false;\n        }\n        const isHitText = !!(event.target instanceof Element && event.target.closest('.plait-text-container'));\n\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const isHitTarget = isHitElement(board, point);\n        const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n        if (PlaitBoard.isPointer(board, PlaitPointerType.selection) && !isHitTarget && options.isMultiple && !options.isDisabledSelect) {\n            preventTouchMove(board, event, true);\n            // start rectangle selection\n            start = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        if (PlaitBoard.isPointer(board, PlaitPointerType.selection) && start) {\n            const movedTarget = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n            const rectangle = RectangleClient.getRectangleByPoints([start, movedTarget]);\n            selectionMovingG?.remove();\n            if (Math.hypot(rectangle.width, rectangle.height) > PRESS_AND_MOVE_BUFFER || isSelectionMoving(board)) {\n                end = movedTarget;\n                throttleRAF(board, 'with-selection', () => {\n                    if (start && end) {\n                        Transforms.setSelection(board, { anchor: start, focus: end });\n                    }\n                });\n                setSelectionMoving(board);\n                selectionMovingG = drawRectangle(board, rectangle, {\n                    stroke: SELECTION_BORDER_COLOR,\n                    strokeWidth: 1,\n                    fill: SELECTION_FILL_COLOR,\n                    fillStyle: 'solid'\n                });\n                PlaitBoard.getElementActiveHost(board).append(selectionMovingG);\n            }\n        }\n        pointerMove(event);\n    };\n\n    // handle the end of click select\n    board.pointerUp = (event: PointerEvent) => {\n        const isSetSelectionPointer =\n            PlaitBoard.isPointer(board, PlaitPointerType.selection) || PlaitBoard.isPointer(board, PlaitPointerType.hand);\n        const isSkip = !isMainPointer(event) || isDragging(board) || !isSetSelectionPointer;\n        if (isSkip) {\n            pointerUp(event);\n            return;\n        }\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const selection = { anchor: point, focus: point };\n        Transforms.setSelection(board, selection);\n        pointerUp(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        if (start && end) {\n            selectionMovingG?.remove();\n            clearSelectionMoving(board);\n            Transforms.setSelection(board, { anchor: start, focus: end });\n        }\n\n        if (PlaitBoard.isFocus(board)) {\n            const isInBoard = event.target instanceof Node && PlaitBoard.getBoardContainer(board).contains(event.target);\n            const isInDocument = event.target instanceof Node && document.contains(event.target);\n            const isAttachedElement = event.target instanceof Element && event.target.closest(`.${ATTACHED_ELEMENT_CLASS_NAME}`);\n            // Clear selection when mouse board outside area\n            // The framework needs to determine whether the board is focused through selection\n            if (!isInBoard && !start && !isAttachedElement && isInDocument) {\n                Transforms.setSelection(board, null);\n            }\n        }\n        start = null;\n        end = null;\n        preventTouchMove(board, event, false);\n        globalPointerUp(event);\n    };\n\n    board.onChange = () => {\n        const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n        if (options.isDisabledSelect) {\n            clearSelectedElement(board);\n        }\n        // remove selected element if include\n        board.operations.forEach(op => {\n            if (op.type === 'remove_node') {\n                removeSelectedElement(board, op.node, true);\n            }\n        });\n        if (isHandleSelection(board) && hasSetSelectionOperation(board)) {\n            try {\n                if (!isShift) {\n                    selectionRectangleG?.remove();\n                }\n                const temporaryElements = getTemporaryElements(board);\n                if (temporaryElements) {\n                    cacheSelectedElements(board, [...temporaryElements]);\n                } else {\n                    let elements = getHitElementsBySelection(board);\n                    if (!options.isMultiple && elements.length > 1) {\n                        elements = [elements[0]];\n                    }\n                    const isHitElementWithGroup = elements.some(item => item.groupId);\n                    const selectedElements = getSelectedElements(board);\n                    if (isHitElementWithGroup) {\n                        setSelectedElementsWithGroup(board, elements, isShift);\n                    } else {\n                        if (board.selection && Selection.isCollapsed(board.selection)) {\n                            const element = board.getHitElement(elements);\n                            if (element) {\n                                elements = [element];\n                            }\n                        }\n                        if (isShift) {\n                            const newElements = [...selectedElements];\n                            if (board.selection && Selection.isCollapsed(board.selection)) {\n                                elements.forEach(element => {\n                                    if (newElements.includes(element)) {\n                                        newElements.splice(newElements.indexOf(element), 1);\n                                    } else {\n                                        newElements.push(element);\n                                    }\n                                });\n                                cacheSelectedElements(board, newElements);\n                            } else {\n                                elements.forEach(element => {\n                                    if (!newElements.includes(element)) {\n                                        newElements.push(element);\n                                    }\n                                });\n                                cacheSelectedElements(board, [...newElements]);\n                            }\n                        } else {\n                            cacheSelectedElements(board, [...elements]);\n                        }\n                    }\n                }\n                const newElements = getSelectedElements(board);\n                previousSelectedElements = newElements;\n                deleteTemporaryElements(board);\n                if (!isSelectionMoving(board)) {\n                    selectionRectangleG?.remove();\n                    if (newElements.length > 1) {\n                        selectionRectangleG = board.drawActiveRectangle();\n                        PlaitBoard.getElementActiveHost(board).append(selectionRectangleG!);\n                    }\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        onChange();\n    };\n\n    board.afterChange = () => {\n        if (isHandleSelection(board) && !hasSetSelectionOperation(board)) {\n            try {\n                const currentSelectedElements = getSelectedElements(board);\n                if (currentSelectedElements.length && currentSelectedElements.length > 1) {\n                    if (\n                        previousSelectedElements &&\n                        (currentSelectedElements.length !== previousSelectedElements.length ||\n                            currentSelectedElements.some((c, index) => c !== previousSelectedElements[index]))\n                    ) {\n                        selectionRectangleG?.remove();\n                        selectionRectangleG = board.drawActiveRectangle();\n                        PlaitBoard.getElementActiveHost(board).append(selectionRectangleG!);\n                        previousSelectedElements = currentSelectedElements;\n                    }\n                } else {\n                    selectionRectangleG?.remove();\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        afterChange();\n    };\n\n    (board as PlaitOptionsBoard).setPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection, {\n        isMultiple: true,\n        isDisabledSelect: false\n    });\n\n    return board;\n}\n"]}
@@ -1,14 +1,15 @@
1
1
  import { WritableClipboardType } from './types';
2
2
  export const buildPlaitHtml = (type, data) => {
3
- const stringifiedClipboard = JSON.stringify({
3
+ const stringifiedClipboard = replaceAngleBrackets(JSON.stringify({
4
4
  type,
5
5
  data
6
- });
6
+ }));
7
7
  return `<plait>${stringifiedClipboard}</plait>`;
8
8
  };
9
9
  export const getClipboardFromHtml = (html) => {
10
- const plaitString = html?.match(/<plait[^>]*>(.*)<\/plait>/)?.[1];
10
+ let plaitString = html?.match(/<plait[^>]*>(.*)<\/plait>/)?.[1];
11
11
  if (plaitString) {
12
+ plaitString = reverseReplaceAngleBrackets(plaitString);
12
13
  try {
13
14
  const plaitJson = JSON.parse(plaitString);
14
15
  if (plaitJson) {
@@ -64,4 +65,10 @@ export const addClipboardContext = (clipboardContext, addition) => {
64
65
  }
65
66
  return clipboardContext;
66
67
  };
67
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvdXRpbHMvY2xpcGJvYXJkL2NvbW1vbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWtFLHFCQUFxQixFQUFFLE1BQU0sU0FBUyxDQUFDO0FBRWhILE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxDQUFDLElBQTJCLEVBQUUsSUFBMkIsRUFBRSxFQUFFO0lBQ3ZGLE1BQU0sb0JBQW9CLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQztRQUN4QyxJQUFJO1FBQ0osSUFBSTtLQUNQLENBQUMsQ0FBQztJQUNILE9BQU8sVUFBVSxvQkFBb0IsVUFBVSxDQUFDO0FBQ3BELENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLENBQUMsSUFBWSxFQUF3QixFQUFFO0lBQ3ZFLE1BQU0sV0FBVyxHQUFHLElBQUksRUFBRSxLQUFLLENBQUMsMkJBQTJCLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2xFLElBQUksV0FBVyxFQUFFLENBQUM7UUFDZCxJQUFJLENBQUM7WUFDRCxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQzFDLElBQUksU0FBUyxFQUFFLENBQUM7Z0JBQ1osSUFBSSxTQUFTLENBQUMsSUFBSSxLQUFLLHFCQUFxQixDQUFDLFFBQVEsRUFBRSxDQUFDO29CQUNwRCxPQUFPO3dCQUNILFFBQVEsRUFBRSxTQUFTLENBQUMsSUFBSTtxQkFDM0IsQ0FBQztnQkFDTixDQUFDO3FCQUFNLElBQUksU0FBUyxDQUFDLElBQUksS0FBSyxxQkFBcUIsQ0FBQyxNQUFNLEVBQUUsQ0FBQztvQkFDekQsT0FBTzt3QkFDSCxNQUFNLEVBQUUsU0FBUyxDQUFDLElBQUk7cUJBQ3pCLENBQUM7Z0JBQ04sQ0FBQztZQUNMLENBQUM7UUFDTCxDQUFDO1FBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQztZQUNiLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDckIsT0FBTyxJQUFJLENBQUM7UUFDaEIsQ0FBQztJQUNMLENBQUM7SUFDRCxPQUFPLElBQUksQ0FBQztBQUNoQixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsQ0FBQyxJQUFZLEVBQUUsRUFBRTtJQUN0Qyw2SEFBNkg7SUFDN0gsTUFBTSxHQUFHLEdBQUcsUUFBUSxDQUFDLGNBQWMsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUMzRCxHQUFHLENBQUMsZUFBZSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDNUMsT0FBTyxHQUFHLENBQUMsSUFBSSxDQUFDLFdBQVcsSUFBSSxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsSUFBSSxFQUFFLENBQUM7QUFDNUQsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0saUNBQWlDLEdBQUcsR0FBRyxFQUFFO0lBQ2xELE9BQU8sV0FBVyxJQUFJLFNBQVMsSUFBSSxPQUFPLElBQUksU0FBUyxDQUFDLFNBQVMsQ0FBQztBQUN0RSxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxxQ0FBcUMsR0FBRyxHQUFHLEVBQUU7SUFDdEQsT0FBTyxXQUFXLElBQUksU0FBUyxJQUFJLFdBQVcsSUFBSSxTQUFTLENBQUMsU0FBUyxDQUFDO0FBQzFFLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGdDQUFnQyxHQUFHLEdBQUcsRUFBRTtJQUNqRCxPQUFPLFdBQVcsSUFBSSxTQUFTLElBQUksTUFBTSxJQUFJLFNBQVMsQ0FBQyxTQUFTLENBQUM7QUFDckUsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsQ0FDbEMsSUFBMkIsRUFDM0IsUUFBK0IsRUFDL0IsSUFBWSxFQUNZLEVBQUU7SUFDMUIsT0FBTztRQUNILElBQUk7UUFDSixRQUFRO1FBQ1IsSUFBSTtLQUNQLENBQUM7QUFDTixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxDQUMvQixnQkFBMEMsRUFDMUMsUUFBa0MsRUFDVixFQUFFO0lBQzFCLE1BQU0sRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxHQUFHLGdCQUFnQixDQUFDO0lBQ2xELElBQUksSUFBSSxLQUFLLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN6QixPQUFPO1lBQ0gsSUFBSTtZQUNKLFFBQVEsRUFBRSxRQUFRLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUM7WUFDNUMsSUFBSSxFQUFFLElBQUksR0FBRyxHQUFHLEdBQUcsUUFBUSxDQUFDLElBQUk7U0FDbkMsQ0FBQztJQUNOLENBQUM7SUFDRCxPQUFPLGdCQUFnQixDQUFDO0FBQzVCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsaXBib2FyZERhdGEsIFdyaXRhYmxlQ2xpcGJvYXJkQ29udGV4dCwgV3JpdGFibGVDbGlwYm9hcmREYXRhLCBXcml0YWJsZUNsaXBib2FyZFR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IGJ1aWxkUGxhaXRIdG1sID0gKHR5cGU6IFdyaXRhYmxlQ2xpcGJvYXJkVHlwZSwgZGF0YTogV3JpdGFibGVDbGlwYm9hcmREYXRhKSA9PiB7XG4gICAgY29uc3Qgc3RyaW5naWZpZWRDbGlwYm9hcmQgPSBKU09OLnN0cmluZ2lmeSh7XG4gICAgICAgIHR5cGUsXG4gICAgICAgIGRhdGFcbiAgICB9KTtcbiAgICByZXR1cm4gYDxwbGFpdD4ke3N0cmluZ2lmaWVkQ2xpcGJvYXJkfTwvcGxhaXQ+YDtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRDbGlwYm9hcmRGcm9tSHRtbCA9IChodG1sOiBzdHJpbmcpOiBDbGlwYm9hcmREYXRhIHwgbnVsbCA9PiB7XG4gICAgY29uc3QgcGxhaXRTdHJpbmcgPSBodG1sPy5tYXRjaCgvPHBsYWl0W14+XSo+KC4qKTxcXC9wbGFpdD4vKT8uWzFdO1xuICAgIGlmIChwbGFpdFN0cmluZykge1xuICAgICAgICB0cnkge1xuICAgICAgICAgICAgY29uc3QgcGxhaXRKc29uID0gSlNPTi5wYXJzZShwbGFpdFN0cmluZyk7XG4gICAgICAgICAgICBpZiAocGxhaXRKc29uKSB7XG4gICAgICAgICAgICAgICAgaWYgKHBsYWl0SnNvbi50eXBlID09PSBXcml0YWJsZUNsaXBib2FyZFR5cGUuZWxlbWVudHMpIHtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGVsZW1lbnRzOiBwbGFpdEpzb24uZGF0YVxuICAgICAgICAgICAgICAgICAgICB9O1xuICAgICAgICAgICAgICAgIH0gZWxzZSBpZiAocGxhaXRKc29uLnR5cGUgPT09IFdyaXRhYmxlQ2xpcGJvYXJkVHlwZS5tZWRpYXMpIHtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIG1lZGlhczogcGxhaXRKc29uLmRhdGFcbiAgICAgICAgICAgICAgICAgICAgfTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgICAgICBjb25zb2xlLmVycm9yKGVycm9yKTtcbiAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICB9XG4gICAgfVxuICAgIHJldHVybiBudWxsO1xufTtcblxuZXhwb3J0IGNvbnN0IHN0cmlwSHRtbCA9IChodG1sOiBzdHJpbmcpID0+IHtcbiAgICAvLyBTZWUgPGh0dHBzOi8vZ2l0aHViLmNvbS9kZXZlbG9waXQvcHJlYWN0LW1hcmt1cC9ibG9iLzQ3ODhiOGQ2MWI0ZTI0ZjgzNjg4NzEwNzQ2ZWUzNmU3NDY0ZjdiYmMvc3JjL3BhcnNlLW1hcmt1cC5qcyNMNjAtTDY5PlxuICAgIGNvbnN0IGRvYyA9IGRvY3VtZW50LmltcGxlbWVudGF0aW9uLmNyZWF0ZUhUTUxEb2N1bWVudCgnJyk7XG4gICAgZG9jLmRvY3VtZW50RWxlbWVudC5pbm5lckhUTUwgPSBodG1sLnRyaW0oKTtcbiAgICByZXR1cm4gZG9jLmJvZHkudGV4dENvbnRlbnQgfHwgZG9jLmJvZHkuaW5uZXJUZXh0IHx8ICcnO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFByb2JhYmx5U3VwcG9ydHNDbGlwYm9hcmRXcml0ZSA9ICgpID0+IHtcbiAgICByZXR1cm4gJ2NsaXBib2FyZCcgaW4gbmF2aWdhdG9yICYmICd3cml0ZScgaW4gbmF2aWdhdG9yLmNsaXBib2FyZDtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQcm9iYWJseVN1cHBvcnRzQ2xpcGJvYXJkV3JpdGVUZXh0ID0gKCkgPT4ge1xuICAgIHJldHVybiAnY2xpcGJvYXJkJyBpbiBuYXZpZ2F0b3IgJiYgJ3dyaXRlVGV4dCcgaW4gbmF2aWdhdG9yLmNsaXBib2FyZDtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQcm9iYWJseVN1cHBvcnRzQ2xpcGJvYXJkUmVhZCA9ICgpID0+IHtcbiAgICByZXR1cm4gJ2NsaXBib2FyZCcgaW4gbmF2aWdhdG9yICYmICdyZWFkJyBpbiBuYXZpZ2F0b3IuY2xpcGJvYXJkO1xufTtcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZUNsaXBib2FyZENvbnRleHQgPSAoXG4gICAgdHlwZTogV3JpdGFibGVDbGlwYm9hcmRUeXBlLFxuICAgIGVsZW1lbnRzOiBXcml0YWJsZUNsaXBib2FyZERhdGEsXG4gICAgdGV4dDogc3RyaW5nXG4pOiBXcml0YWJsZUNsaXBib2FyZENvbnRleHQgPT4ge1xuICAgIHJldHVybiB7XG4gICAgICAgIHR5cGUsXG4gICAgICAgIGVsZW1lbnRzLFxuICAgICAgICB0ZXh0XG4gICAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBhZGRDbGlwYm9hcmRDb250ZXh0ID0gKFxuICAgIGNsaXBib2FyZENvbnRleHQ6IFdyaXRhYmxlQ2xpcGJvYXJkQ29udGV4dCxcbiAgICBhZGRpdGlvbjogV3JpdGFibGVDbGlwYm9hcmRDb250ZXh0XG4pOiBXcml0YWJsZUNsaXBib2FyZENvbnRleHQgPT4ge1xuICAgIGNvbnN0IHsgdHlwZSwgZWxlbWVudHMsIHRleHQgfSA9IGNsaXBib2FyZENvbnRleHQ7XG4gICAgaWYgKHR5cGUgPT09IGFkZGl0aW9uLnR5cGUpIHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHR5cGUsXG4gICAgICAgICAgICBlbGVtZW50czogZWxlbWVudHMuY29uY2F0KGFkZGl0aW9uLmVsZW1lbnRzKSxcbiAgICAgICAgICAgIHRleHQ6IHRleHQgKyAnICcgKyBhZGRpdGlvbi50ZXh0XG4gICAgICAgIH07XG4gICAgfVxuICAgIHJldHVybiBjbGlwYm9hcmRDb250ZXh0O1xufTtcbiJdfQ==
68
+ export const replaceAngleBrackets = (str) => {
69
+ return str.replace(/</g, '&lt;').replace(/>/g, '&gt;');
70
+ };
71
+ export const reverseReplaceAngleBrackets = (str) => {
72
+ return str.replace(/&lt;/g, '<').replace(/&gt;/g, '>');
73
+ };
74
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvdXRpbHMvY2xpcGJvYXJkL2NvbW1vbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWtFLHFCQUFxQixFQUFFLE1BQU0sU0FBUyxDQUFDO0FBRWhILE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxDQUFDLElBQTJCLEVBQUUsSUFBMkIsRUFBRSxFQUFFO0lBQ3ZGLE1BQU0sb0JBQW9CLEdBQUcsb0JBQW9CLENBQzdDLElBQUksQ0FBQyxTQUFTLENBQUM7UUFDWCxJQUFJO1FBQ0osSUFBSTtLQUNQLENBQUMsQ0FDTCxDQUFDO0lBQ0YsT0FBTyxVQUFVLG9CQUFvQixVQUFVLENBQUM7QUFDcEQsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsQ0FBQyxJQUFZLEVBQXdCLEVBQUU7SUFDdkUsSUFBSSxXQUFXLEdBQUcsSUFBSSxFQUFFLEtBQUssQ0FBQywyQkFBMkIsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDaEUsSUFBSSxXQUFXLEVBQUUsQ0FBQztRQUNkLFdBQVcsR0FBRywyQkFBMkIsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN2RCxJQUFJLENBQUM7WUFDRCxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQzFDLElBQUksU0FBUyxFQUFFLENBQUM7Z0JBQ1osSUFBSSxTQUFTLENBQUMsSUFBSSxLQUFLLHFCQUFxQixDQUFDLFFBQVEsRUFBRSxDQUFDO29CQUNwRCxPQUFPO3dCQUNILFFBQVEsRUFBRSxTQUFTLENBQUMsSUFBSTtxQkFDM0IsQ0FBQztnQkFDTixDQUFDO3FCQUFNLElBQUksU0FBUyxDQUFDLElBQUksS0FBSyxxQkFBcUIsQ0FBQyxNQUFNLEVBQUUsQ0FBQztvQkFDekQsT0FBTzt3QkFDSCxNQUFNLEVBQUUsU0FBUyxDQUFDLElBQUk7cUJBQ3pCLENBQUM7Z0JBQ04sQ0FBQztZQUNMLENBQUM7UUFDTCxDQUFDO1FBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQztZQUNiLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDckIsT0FBTyxJQUFJLENBQUM7UUFDaEIsQ0FBQztJQUNMLENBQUM7SUFDRCxPQUFPLElBQUksQ0FBQztBQUNoQixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsQ0FBQyxJQUFZLEVBQUUsRUFBRTtJQUN0Qyw2SEFBNkg7SUFDN0gsTUFBTSxHQUFHLEdBQUcsUUFBUSxDQUFDLGNBQWMsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUMzRCxHQUFHLENBQUMsZUFBZSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDNUMsT0FBTyxHQUFHLENBQUMsSUFBSSxDQUFDLFdBQVcsSUFBSSxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsSUFBSSxFQUFFLENBQUM7QUFDNUQsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0saUNBQWlDLEdBQUcsR0FBRyxFQUFFO0lBQ2xELE9BQU8sV0FBVyxJQUFJLFNBQVMsSUFBSSxPQUFPLElBQUksU0FBUyxDQUFDLFNBQVMsQ0FBQztBQUN0RSxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxxQ0FBcUMsR0FBRyxHQUFHLEVBQUU7SUFDdEQsT0FBTyxXQUFXLElBQUksU0FBUyxJQUFJLFdBQVcsSUFBSSxTQUFTLENBQUMsU0FBUyxDQUFDO0FBQzFFLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGdDQUFnQyxHQUFHLEdBQUcsRUFBRTtJQUNqRCxPQUFPLFdBQVcsSUFBSSxTQUFTLElBQUksTUFBTSxJQUFJLFNBQVMsQ0FBQyxTQUFTLENBQUM7QUFDckUsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsQ0FDbEMsSUFBMkIsRUFDM0IsUUFBK0IsRUFDL0IsSUFBWSxFQUNZLEVBQUU7SUFDMUIsT0FBTztRQUNILElBQUk7UUFDSixRQUFRO1FBQ1IsSUFBSTtLQUNQLENBQUM7QUFDTixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxDQUMvQixnQkFBMEMsRUFDMUMsUUFBa0MsRUFDVixFQUFFO0lBQzFCLE1BQU0sRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxHQUFHLGdCQUFnQixDQUFDO0lBQ2xELElBQUksSUFBSSxLQUFLLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN6QixPQUFPO1lBQ0gsSUFBSTtZQUNKLFFBQVEsRUFBRSxRQUFRLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUM7WUFDNUMsSUFBSSxFQUFFLElBQUksR0FBRyxHQUFHLEdBQUcsUUFBUSxDQUFDLElBQUk7U0FDbkMsQ0FBQztJQUNOLENBQUM7SUFDRCxPQUFPLGdCQUFnQixDQUFDO0FBQzVCLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLENBQUMsR0FBVyxFQUFFLEVBQUU7SUFDaEQsT0FBTyxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0FBQzNELENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDJCQUEyQixHQUFHLENBQUMsR0FBVyxFQUFFLEVBQUU7SUFDdkQsT0FBTyxHQUFHLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxHQUFHLENBQUMsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0FBQzNELENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsaXBib2FyZERhdGEsIFdyaXRhYmxlQ2xpcGJvYXJkQ29udGV4dCwgV3JpdGFibGVDbGlwYm9hcmREYXRhLCBXcml0YWJsZUNsaXBib2FyZFR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IGJ1aWxkUGxhaXRIdG1sID0gKHR5cGU6IFdyaXRhYmxlQ2xpcGJvYXJkVHlwZSwgZGF0YTogV3JpdGFibGVDbGlwYm9hcmREYXRhKSA9PiB7XG4gICAgY29uc3Qgc3RyaW5naWZpZWRDbGlwYm9hcmQgPSByZXBsYWNlQW5nbGVCcmFja2V0cyhcbiAgICAgICAgSlNPTi5zdHJpbmdpZnkoe1xuICAgICAgICAgICAgdHlwZSxcbiAgICAgICAgICAgIGRhdGFcbiAgICAgICAgfSlcbiAgICApO1xuICAgIHJldHVybiBgPHBsYWl0PiR7c3RyaW5naWZpZWRDbGlwYm9hcmR9PC9wbGFpdD5gO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldENsaXBib2FyZEZyb21IdG1sID0gKGh0bWw6IHN0cmluZyk6IENsaXBib2FyZERhdGEgfCBudWxsID0+IHtcbiAgICBsZXQgcGxhaXRTdHJpbmcgPSBodG1sPy5tYXRjaCgvPHBsYWl0W14+XSo+KC4qKTxcXC9wbGFpdD4vKT8uWzFdO1xuICAgIGlmIChwbGFpdFN0cmluZykge1xuICAgICAgICBwbGFpdFN0cmluZyA9IHJldmVyc2VSZXBsYWNlQW5nbGVCcmFja2V0cyhwbGFpdFN0cmluZyk7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgICBjb25zdCBwbGFpdEpzb24gPSBKU09OLnBhcnNlKHBsYWl0U3RyaW5nKTtcbiAgICAgICAgICAgIGlmIChwbGFpdEpzb24pIHtcbiAgICAgICAgICAgICAgICBpZiAocGxhaXRKc29uLnR5cGUgPT09IFdyaXRhYmxlQ2xpcGJvYXJkVHlwZS5lbGVtZW50cykge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgZWxlbWVudHM6IHBsYWl0SnNvbi5kYXRhXG4gICAgICAgICAgICAgICAgICAgIH07XG4gICAgICAgICAgICAgICAgfSBlbHNlIGlmIChwbGFpdEpzb24udHlwZSA9PT0gV3JpdGFibGVDbGlwYm9hcmRUeXBlLm1lZGlhcykge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgbWVkaWFzOiBwbGFpdEpzb24uZGF0YVxuICAgICAgICAgICAgICAgICAgICB9O1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICAgIGNvbnNvbGUuZXJyb3IoZXJyb3IpO1xuICAgICAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIG51bGw7XG59O1xuXG5leHBvcnQgY29uc3Qgc3RyaXBIdG1sID0gKGh0bWw6IHN0cmluZykgPT4ge1xuICAgIC8vIFNlZSA8aHR0cHM6Ly9naXRodWIuY29tL2RldmVsb3BpdC9wcmVhY3QtbWFya3VwL2Jsb2IvNDc4OGI4ZDYxYjRlMjRmODM2ODg3MTA3NDZlZTM2ZTc0NjRmN2JiYy9zcmMvcGFyc2UtbWFya3VwLmpzI0w2MC1MNjk+XG4gICAgY29uc3QgZG9jID0gZG9jdW1lbnQuaW1wbGVtZW50YXRpb24uY3JlYXRlSFRNTERvY3VtZW50KCcnKTtcbiAgICBkb2MuZG9jdW1lbnRFbGVtZW50LmlubmVySFRNTCA9IGh0bWwudHJpbSgpO1xuICAgIHJldHVybiBkb2MuYm9keS50ZXh0Q29udGVudCB8fCBkb2MuYm9keS5pbm5lclRleHQgfHwgJyc7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0UHJvYmFibHlTdXBwb3J0c0NsaXBib2FyZFdyaXRlID0gKCkgPT4ge1xuICAgIHJldHVybiAnY2xpcGJvYXJkJyBpbiBuYXZpZ2F0b3IgJiYgJ3dyaXRlJyBpbiBuYXZpZ2F0b3IuY2xpcGJvYXJkO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFByb2JhYmx5U3VwcG9ydHNDbGlwYm9hcmRXcml0ZVRleHQgPSAoKSA9PiB7XG4gICAgcmV0dXJuICdjbGlwYm9hcmQnIGluIG5hdmlnYXRvciAmJiAnd3JpdGVUZXh0JyBpbiBuYXZpZ2F0b3IuY2xpcGJvYXJkO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFByb2JhYmx5U3VwcG9ydHNDbGlwYm9hcmRSZWFkID0gKCkgPT4ge1xuICAgIHJldHVybiAnY2xpcGJvYXJkJyBpbiBuYXZpZ2F0b3IgJiYgJ3JlYWQnIGluIG5hdmlnYXRvci5jbGlwYm9hcmQ7XG59O1xuXG5leHBvcnQgY29uc3QgY3JlYXRlQ2xpcGJvYXJkQ29udGV4dCA9IChcbiAgICB0eXBlOiBXcml0YWJsZUNsaXBib2FyZFR5cGUsXG4gICAgZWxlbWVudHM6IFdyaXRhYmxlQ2xpcGJvYXJkRGF0YSxcbiAgICB0ZXh0OiBzdHJpbmdcbik6IFdyaXRhYmxlQ2xpcGJvYXJkQ29udGV4dCA9PiB7XG4gICAgcmV0dXJuIHtcbiAgICAgICAgdHlwZSxcbiAgICAgICAgZWxlbWVudHMsXG4gICAgICAgIHRleHRcbiAgICB9O1xufTtcblxuZXhwb3J0IGNvbnN0IGFkZENsaXBib2FyZENvbnRleHQgPSAoXG4gICAgY2xpcGJvYXJkQ29udGV4dDogV3JpdGFibGVDbGlwYm9hcmRDb250ZXh0LFxuICAgIGFkZGl0aW9uOiBXcml0YWJsZUNsaXBib2FyZENvbnRleHRcbik6IFdyaXRhYmxlQ2xpcGJvYXJkQ29udGV4dCA9PiB7XG4gICAgY29uc3QgeyB0eXBlLCBlbGVtZW50cywgdGV4dCB9ID0gY2xpcGJvYXJkQ29udGV4dDtcbiAgICBpZiAodHlwZSA9PT0gYWRkaXRpb24udHlwZSkge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgdHlwZSxcbiAgICAgICAgICAgIGVsZW1lbnRzOiBlbGVtZW50cy5jb25jYXQoYWRkaXRpb24uZWxlbWVudHMpLFxuICAgICAgICAgICAgdGV4dDogdGV4dCArICcgJyArIGFkZGl0aW9uLnRleHRcbiAgICAgICAgfTtcbiAgICB9XG4gICAgcmV0dXJuIGNsaXBib2FyZENvbnRleHQ7XG59O1xuXG5leHBvcnQgY29uc3QgcmVwbGFjZUFuZ2xlQnJhY2tldHMgPSAoc3RyOiBzdHJpbmcpID0+IHtcbiAgICByZXR1cm4gc3RyLnJlcGxhY2UoLzwvZywgJyZsdDsnKS5yZXBsYWNlKC8+L2csICcmZ3Q7Jyk7XG59O1xuXG5leHBvcnQgY29uc3QgcmV2ZXJzZVJlcGxhY2VBbmdsZUJyYWNrZXRzID0gKHN0cjogc3RyaW5nKSA9PiB7XG4gICAgcmV0dXJuIHN0ci5yZXBsYWNlKC8mbHQ7L2csICc8JykucmVwbGFjZSgvJmd0Oy9nLCAnPicpO1xufTtcbiJdfQ==
@@ -15,9 +15,9 @@ export const getHitElementsBySelection = (board, selection, match = () => true)
15
15
  }
16
16
  const isCollapsed = Selection.isCollapsed(newSelection);
17
17
  if (isCollapsed) {
18
- const hitElement = getHitElementByPoint(board, newSelection.anchor, match);
19
- if (hitElement) {
20
- return [hitElement];
18
+ const hitElements = getHitElementsByPoint(board, newSelection.anchor, match);
19
+ if (hitElements?.length) {
20
+ return hitElements;
21
21
  }
22
22
  else {
23
23
  return [];
@@ -30,32 +30,23 @@ export const getHitElementsBySelection = (board, selection, match = () => true)
30
30
  }, getIsRecursionFunc(board), true);
31
31
  return rectangleHitElements;
32
32
  };
33
- export const getHitElementByPoint = (board, point, match = () => true) => {
34
- let hitElement = undefined;
35
- let hitInsideElement = undefined;
33
+ export const getHitElementsByPoint = (board, point, match = () => true) => {
34
+ let hitElements = [];
36
35
  depthFirstRecursion(board, node => {
37
- if (hitElement) {
38
- return;
39
- }
40
36
  if (PlaitBoard.isBoard(node) || !match(node) || !PlaitElement.hasMounted(node)) {
41
37
  return;
42
38
  }
43
39
  if (board.isHit(node, point)) {
44
- hitElement = node;
40
+ hitElements.push(node);
45
41
  return;
46
42
  }
47
- /**
48
- * 需要增加场景测试
49
- * hitInsideElement 存的是第一个符合 isInsidePoint 的元素
50
- * 当有元素符合 isHit 时结束遍历,并返回 hitElement
51
- * 当所有元素都不符合 isHit ,则返回第一个符合 isInsidePoint 的元素
52
- * 这样保证最上面的元素优先被探测到;
53
- */
54
- if (!hitInsideElement && board.isInsidePoint(node, point)) {
55
- hitInsideElement = node;
56
- }
57
43
  }, getIsRecursionFunc(board), true);
58
- return hitElement || hitInsideElement;
44
+ return hitElements;
45
+ };
46
+ export const getHitElementByPoint = (board, point, match = () => true) => {
47
+ const pointHitElements = getHitElementsByPoint(board, point, match);
48
+ const hitElement = board.getHitElement(pointHitElements);
49
+ return hitElement;
59
50
  };
60
51
  export const getHitSelectedElements = (board, point) => {
61
52
  const selectedElements = getSelectedElements(board);
@@ -126,4 +117,4 @@ export const isHitElement = (board, point) => {
126
117
  const hitElement = getHitElementByPoint(board, point);
127
118
  return !!hitElement || isHitSelectedRectangle(board, point);
128
119
  };
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selected-element.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/selected-element.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard } from '../interfaces/board';\nimport { Ancestor } from '../interfaces/node';\nimport { depthFirstRecursion, getIsRecursionFunc } from './tree';\nimport { BOARD_TO_SELECTED_ELEMENT } from './weak-maps';\nimport { Selection } from '../interfaces/selection';\nimport { PlaitElement } from '../interfaces/element';\nimport { Point } from '../interfaces/point';\nimport { sortElements } from './position';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport { getRectangleByElements } from './element';\nimport { PlaitOptionsBoard } from '../plugins/with-options';\nimport { PlaitPluginKey } from '../interfaces/plugin-key';\nimport { WithPluginOptions } from '../plugins/with-selection';\n\nexport const getHitElementsBySelection = (\n    board: PlaitBoard,\n    selection?: Selection,\n    match: (element: PlaitElement) => boolean = () => true\n) => {\n    const newSelection = selection || (board.selection as Selection);\n    const rectangleHitElements: PlaitElement[] = [];\n    if (!newSelection) {\n        return [];\n    }\n    const isCollapsed = Selection.isCollapsed(newSelection);\n    if (isCollapsed) {\n        const hitElement = getHitElementByPoint(board, newSelection.anchor, match);\n        if (hitElement) {\n            return [hitElement];\n        } else {\n            return [];\n        }\n    }\n    depthFirstRecursion<Ancestor>(\n        board,\n        node => {\n            if (!PlaitBoard.isBoard(node) && match(node) && board.isRectangleHit(node, newSelection)) {\n                rectangleHitElements.push(node);\n            }\n        },\n        getIsRecursionFunc(board),\n        true\n    );\n    return rectangleHitElements;\n};\n\nexport const getHitElementByPoint = (\n    board: PlaitBoard,\n    point: Point,\n    match: (element: PlaitElement) => boolean = () => true\n): undefined | PlaitElement => {\n    let hitElement: PlaitElement | undefined = undefined;\n    let hitInsideElement: PlaitElement | undefined = undefined;\n    depthFirstRecursion<Ancestor>(\n        board,\n        node => {\n            if (hitElement) {\n                return;\n            }\n            if (PlaitBoard.isBoard(node) || !match(node) || !PlaitElement.hasMounted(node)) {\n                return;\n            }\n            if (board.isHit(node, point)) {\n                hitElement = node;\n                return;\n            }\n\n            /**\n             * 需要增加场景测试\n             * hitInsideElement 存的是第一个符合 isInsidePoint 的元素\n             * 当有元素符合 isHit 时结束遍历，并返回 hitElement\n             * 当所有元素都不符合 isHit ，则返回第一个符合 isInsidePoint 的元素\n             * 这样保证最上面的元素优先被探测到；\n             */\n\n            if (!hitInsideElement && board.isInsidePoint(node, point)) {\n                hitInsideElement = node;\n            }\n        },\n        getIsRecursionFunc(board),\n        true\n    );\n    return hitElement || hitInsideElement;\n};\n\nexport const getHitSelectedElements = (board: PlaitBoard, point: Point) => {\n    const selectedElements = getSelectedElements(board);\n    const targetRectangle = selectedElements.length > 0 && getRectangleByElements(board, selectedElements, false);\n    const isInTargetRectangle = targetRectangle && RectangleClient.isPointInRectangle(targetRectangle, point);\n    if (isInTargetRectangle) {\n        return selectedElements;\n    } else {\n        return [];\n    }\n};\n\nexport const cacheSelectedElements = (board: PlaitBoard, selectedElements: PlaitElement[]) => {\n    const sortedElements = sortElements(board, selectedElements);\n    BOARD_TO_SELECTED_ELEMENT.set(board, sortedElements);\n};\n\nexport const getSelectedElements = (board: PlaitBoard) => {\n    return BOARD_TO_SELECTED_ELEMENT.get(board) || [];\n};\n\nexport const addSelectedElement = (board: PlaitBoard, element: PlaitElement | PlaitElement[]) => {\n    let elements = [];\n    if (Array.isArray(element)) {\n        elements.push(...element);\n    } else {\n        elements.push(element);\n    }\n    const selectedElements = getSelectedElements(board);\n    cacheSelectedElements(board, [...selectedElements, ...elements]);\n};\n\nexport const removeSelectedElement = (board: PlaitBoard, element: PlaitElement, isRemoveChildren = false) => {\n    const selectedElements = getSelectedElements(board);\n    if (selectedElements.includes(element)) {\n        const targetElements: PlaitElement[] = [];\n        if (board.isRecursion(element) && isRemoveChildren) {\n            depthFirstRecursion(\n                element,\n                node => {\n                    targetElements.push(node);\n                },\n                node => board.isRecursion(node)\n            );\n        } else {\n            targetElements.push(element);\n        }\n        const newSelectedElements = selectedElements.filter(value => !targetElements.includes(value));\n        cacheSelectedElements(board, newSelectedElements);\n    }\n};\n\nexport const clearSelectedElement = (board: PlaitBoard) => {\n    cacheSelectedElements(board, []);\n};\n\nexport const isSelectedElement = (board: PlaitBoard, element: PlaitElement) => {\n    const selectedElements = getSelectedElements(board);\n    return !!selectedElements.find(value => value === element);\n};\n\nexport const temporaryDisableSelection = (board: PlaitOptionsBoard) => {\n    const currentOptions = board.getPluginOptions(PlaitPluginKey.withSelection);\n    board.setPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection, {\n        isDisabledSelect: true\n    });\n    setTimeout(() => {\n        board.setPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection, { ...currentOptions });\n    }, 0);\n};\n\nexport const isHitSelectedRectangle = (board: PlaitBoard, point: Point) => {\n    const hitSelectedElements = getHitSelectedElements(board, point);\n    return hitSelectedElements.length > 0;\n};\n\nexport const isHitElement = (board: PlaitBoard, point: Point) => {\n    const hitElement = getHitElementByPoint(board, point);\n    return !!hitElement || isHitSelectedRectangle(board, point);\n};\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selected-element.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/selected-element.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard } from '../interfaces/board';\nimport { Ancestor } from '../interfaces/node';\nimport { depthFirstRecursion, getIsRecursionFunc } from './tree';\nimport { BOARD_TO_SELECTED_ELEMENT } from './weak-maps';\nimport { Selection } from '../interfaces/selection';\nimport { PlaitElement } from '../interfaces/element';\nimport { Point } from '../interfaces/point';\nimport { sortElements } from './position';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport { getRectangleByElements } from './element';\nimport { PlaitOptionsBoard } from '../plugins/with-options';\nimport { PlaitPluginKey } from '../interfaces/plugin-key';\nimport { WithPluginOptions } from '../plugins/with-selection';\n\nexport const getHitElementsBySelection = (\n    board: PlaitBoard,\n    selection?: Selection,\n    match: (element: PlaitElement) => boolean = () => true\n) => {\n    const newSelection = selection || (board.selection as Selection);\n    const rectangleHitElements: PlaitElement[] = [];\n    if (!newSelection) {\n        return [];\n    }\n    const isCollapsed = Selection.isCollapsed(newSelection);\n    if (isCollapsed) {\n        const hitElements = getHitElementsByPoint(board, newSelection.anchor, match);\n        if (hitElements?.length) {\n            return hitElements;\n        } else {\n            return [];\n        }\n    }\n    depthFirstRecursion<Ancestor>(\n        board,\n        node => {\n            if (!PlaitBoard.isBoard(node) && match(node) && board.isRectangleHit(node, newSelection)) {\n                rectangleHitElements.push(node);\n            }\n        },\n        getIsRecursionFunc(board),\n        true\n    );\n    return rectangleHitElements;\n};\n\nexport const getHitElementsByPoint = (\n    board: PlaitBoard,\n    point: Point,\n    match: (element: PlaitElement) => boolean = () => true\n): PlaitElement[] => {\n    let hitElements: PlaitElement[] = [];\n    depthFirstRecursion<Ancestor>(\n        board,\n        node => {\n            if (PlaitBoard.isBoard(node) || !match(node) || !PlaitElement.hasMounted(node)) {\n                return;\n            }\n            if (board.isHit(node, point)) {\n                hitElements.push(node);\n                return;\n            }\n        },\n        getIsRecursionFunc(board),\n        true\n    );\n    return hitElements;\n};\n\nexport const getHitElementByPoint = (\n    board: PlaitBoard,\n    point: Point,\n    match: (element: PlaitElement) => boolean = () => true\n): undefined | PlaitElement => {\n    const pointHitElements = getHitElementsByPoint(board, point, match);\n    const hitElement = board.getHitElement(pointHitElements);\n    return hitElement;\n};\n\nexport const getHitSelectedElements = (board: PlaitBoard, point: Point) => {\n    const selectedElements = getSelectedElements(board);\n    const targetRectangle = selectedElements.length > 0 && getRectangleByElements(board, selectedElements, false);\n    const isInTargetRectangle = targetRectangle && RectangleClient.isPointInRectangle(targetRectangle, point);\n    if (isInTargetRectangle) {\n        return selectedElements;\n    } else {\n        return [];\n    }\n};\n\nexport const cacheSelectedElements = (board: PlaitBoard, selectedElements: PlaitElement[]) => {\n    const sortedElements = sortElements(board, selectedElements);\n    BOARD_TO_SELECTED_ELEMENT.set(board, sortedElements);\n};\n\nexport const getSelectedElements = (board: PlaitBoard) => {\n    return BOARD_TO_SELECTED_ELEMENT.get(board) || [];\n};\n\nexport const addSelectedElement = (board: PlaitBoard, element: PlaitElement | PlaitElement[]) => {\n    let elements = [];\n    if (Array.isArray(element)) {\n        elements.push(...element);\n    } else {\n        elements.push(element);\n    }\n    const selectedElements = getSelectedElements(board);\n    cacheSelectedElements(board, [...selectedElements, ...elements]);\n};\n\nexport const removeSelectedElement = (board: PlaitBoard, element: PlaitElement, isRemoveChildren = false) => {\n    const selectedElements = getSelectedElements(board);\n    if (selectedElements.includes(element)) {\n        const targetElements: PlaitElement[] = [];\n        if (board.isRecursion(element) && isRemoveChildren) {\n            depthFirstRecursion(\n                element,\n                node => {\n                    targetElements.push(node);\n                },\n                node => board.isRecursion(node)\n            );\n        } else {\n            targetElements.push(element);\n        }\n        const newSelectedElements = selectedElements.filter(value => !targetElements.includes(value));\n        cacheSelectedElements(board, newSelectedElements);\n    }\n};\n\nexport const clearSelectedElement = (board: PlaitBoard) => {\n    cacheSelectedElements(board, []);\n};\n\nexport const isSelectedElement = (board: PlaitBoard, element: PlaitElement) => {\n    const selectedElements = getSelectedElements(board);\n    return !!selectedElements.find(value => value === element);\n};\n\nexport const temporaryDisableSelection = (board: PlaitOptionsBoard) => {\n    const currentOptions = board.getPluginOptions(PlaitPluginKey.withSelection);\n    board.setPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection, {\n        isDisabledSelect: true\n    });\n    setTimeout(() => {\n        board.setPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection, { ...currentOptions });\n    }, 0);\n};\n\nexport const isHitSelectedRectangle = (board: PlaitBoard, point: Point) => {\n    const hitSelectedElements = getHitSelectedElements(board, point);\n    return hitSelectedElements.length > 0;\n};\n\nexport const isHitElement = (board: PlaitBoard, point: Point) => {\n    const hitElement = getHitElementByPoint(board, point);\n    return !!hitElement || isHitSelectedRectangle(board, point);\n};\n"]}