@plait/core 0.2.4 → 0.4.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/board/board.component.d.ts +11 -10
- package/board/board.component.interface.d.ts +2 -1
- package/constants/index.d.ts +6 -0
- package/core/island/island-base.component.d.ts +16 -0
- package/esm2020/board/board.component.interface.mjs +1 -1
- package/esm2020/board/board.component.mjs +52 -55
- package/esm2020/constants/index.mjs +7 -1
- package/esm2020/core/element/plugin-element.mjs +2 -2
- package/esm2020/core/island/island-base.component.mjs +33 -0
- package/esm2020/interfaces/board.mjs +11 -2
- package/esm2020/interfaces/index.mjs +2 -1
- package/esm2020/interfaces/node.mjs +1 -1
- package/esm2020/interfaces/path-ref.mjs +15 -0
- package/esm2020/interfaces/plugin-key.mjs +5 -0
- package/esm2020/plait.module.mjs +3 -4
- package/esm2020/plugins/create-board.mjs +32 -3
- package/esm2020/plugins/with-hand.mjs +10 -15
- package/esm2020/plugins/with-options.mjs +13 -0
- package/esm2020/plugins/with-selection.mjs +27 -17
- package/esm2020/public-api.mjs +4 -2
- package/esm2020/testing/core/create-board.mjs +13 -0
- package/esm2020/testing/core/fake-weak-map.mjs +18 -0
- package/esm2020/testing/core/index.mjs +3 -0
- package/esm2020/testing/index.mjs +2 -0
- package/esm2020/transforms/board.mjs +63 -4
- package/esm2020/utils/dom/common.mjs +12 -1
- package/esm2020/utils/draw/line.mjs +21 -1
- package/esm2020/utils/selected-element.mjs +5 -3
- package/esm2020/utils/viewport.mjs +2 -55
- package/esm2020/utils/weak-maps.mjs +2 -1
- package/fesm2015/plait-core.mjs +621 -507
- package/fesm2015/plait-core.mjs.map +1 -1
- package/fesm2020/plait-core.mjs +635 -521
- package/fesm2020/plait-core.mjs.map +1 -1
- package/interfaces/board.d.ts +8 -2
- package/interfaces/index.d.ts +1 -0
- package/interfaces/node.d.ts +1 -1
- package/interfaces/path-ref.d.ts +13 -0
- package/interfaces/plugin-key.d.ts +3 -0
- package/package.json +3 -3
- package/plait.module.d.ts +2 -3
- package/plugins/create-board.d.ts +1 -1
- package/plugins/with-options.d.ts +9 -0
- package/plugins/with-selection.d.ts +4 -0
- package/public-api.d.ts +3 -1
- package/styles/styles.scss +0 -73
- package/testing/core/create-board.d.ts +6 -0
- package/testing/core/fake-weak-map.d.ts +4 -0
- package/testing/core/index.d.ts +2 -0
- package/testing/index.d.ts +1 -0
- package/transforms/board.d.ts +9 -2
- package/utils/dom/common.d.ts +3 -0
- package/utils/draw/line.d.ts +1 -0
- package/utils/selected-element.d.ts +2 -2
- package/utils/viewport.d.ts +0 -3
- package/utils/weak-maps.d.ts +2 -0
- package/core/toolbar/toolbar.component.d.ts +0 -21
- package/esm2020/core/toolbar/toolbar.component.mjs +0 -60
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { BOARD_TO_COMPONENT, BOARD_TO_ELEMENT_HOST, BOARD_TO_HOST, BOARD_TO_ROUGH_SVG, IS_BOARD_CACHE, IS_TEXT_EDITABLE, NODE_TO_INDEX, NODE_TO_PARENT } from '../utils/weak-maps';
|
|
1
|
+
import { BOARD_TO_COMPONENT, BOARD_TO_ELEMENT_HOST, BOARD_TO_HOST, BOARD_TO_MOVING_POINT, BOARD_TO_ROUGH_SVG, IS_BOARD_CACHE, IS_TEXT_EDITABLE, NODE_TO_INDEX, NODE_TO_PARENT } from '../utils/weak-maps';
|
|
2
2
|
import { getRectangleByElements } from '../utils/element';
|
|
3
3
|
export const PlaitBoard = {
|
|
4
4
|
isBoard(value) {
|
|
@@ -61,6 +61,15 @@ export const PlaitBoard = {
|
|
|
61
61
|
},
|
|
62
62
|
hasBeenTextEditing(board) {
|
|
63
63
|
return !!IS_TEXT_EDITABLE.get(board);
|
|
64
|
+
},
|
|
65
|
+
getPointer(board) {
|
|
66
|
+
return board.pointer;
|
|
67
|
+
},
|
|
68
|
+
isPointer(board, pointer) {
|
|
69
|
+
return board.pointer === pointer;
|
|
70
|
+
},
|
|
71
|
+
getMovingPoint(board) {
|
|
72
|
+
return BOARD_TO_MOVING_POINT.get(board);
|
|
64
73
|
}
|
|
65
74
|
};
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.js","sourceRoot":"","sources":["../../../../packages/plait/src/interfaces/board.ts"],"names":[],"mappings":"AAQA,OAAO,EACH,kBAAkB,EAClB,qBAAqB,EACrB,aAAa,EACb,kBAAkB,EAClB,cAAc,EACd,gBAAgB,EAChB,aAAa,EACb,cAAc,EACjB,MAAM,oBAAoB,CAAC;AAK5B,OAAO,EAAE,sBAAsB,EAAE,MAAM,kBAAkB,CAAC;AAwD1D,MAAM,CAAC,MAAM,UAAU,GAAG;IACtB,OAAO,CAAC,KAAU;QACd,MAAM,aAAa,GAAG,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAChD,IAAI,aAAa,KAAK,SAAS,EAAE;YAC7B,OAAO,aAAa,CAAC;SACxB;QACD,MAAM,OAAO,GAAG,OAAO,KAAK,CAAC,QAAQ,KAAK,UAAU,IAAI,OAAO,KAAK,CAAC,KAAK,KAAK,UAAU,CAAC;QAC1F,cAAc,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QACnC,OAAO,OAAO,CAAC;IACnB,CAAC;IACD,QAAQ,CAAC,KAAiB,EAAE,IAAe;QACvC,MAAM,IAAI,GAAS,EAAE,CAAC;QACtB,IAAI,KAAK,GAAa,IAAI,CAAC;QAC3B,OAAO,IAAI,EAAE;YACT,MAAM,MAAM,GAAG,cAAc,CAAC,GAAG,CAAC,KAAqB,CAAC,CAAC;YACzD,IAAI,MAAM,IAAI,IAAI,EAAE;gBAChB,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oBAC3B,OAAO,IAAI,CAAC;iBACf;qBAAM;oBACH,MAAM;iBACT;aACJ;YACD,MAAM,CAAC,GAAG,aAAa,CAAC,GAAG,CAAC,KAAqB,CAAC,CAAC;YACnD,IAAI,CAAC,IAAI,IAAI,EAAE;gBACX,MAAM;aACT;YACD,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAChB,KAAK,GAAG,MAAM,CAAC;SAClB;QACD,MAAM,IAAI,KAAK,CAAC,2CAA2C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACvF,CAAC;IACD,OAAO,CAAC,KAAiB;QACrB,OAAO,aAAa,CAAC,GAAG,CAAC,KAAK,CAAkB,CAAC;IACrD,CAAC;IACD,cAAc,CAAC,KAAiB;QAC5B,OAAO,qBAAqB,CAAC,GAAG,CAAC,KAAK,CAAgB,CAAC;IAC3D,CAAC;IACD,WAAW,CAAC,KAAiB;QACzB,OAAO,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAa,CAAC;IACrD,CAAC;IACD,YAAY,CAAC,KAAiB;QAC1B,OAAO,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAA4B,CAAC;IACpE,CAAC;IACD,qBAAqB,CAAC,KAAiB;QACnC,OAAO,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,aAAa,CAAC;IACxD,CAAC;IACD,YAAY,CAAC,KAAiB;QAC1B,OAAO,sBAAsB,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC/D,CAAC;IACD,oBAAoB,CAAC,KAAiB;QAClC,OAAO,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,aAA4B,CAAC;IAClE,CAAC;IACD,OAAO,CAAC,KAAiB;QACrB,OAAO,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC;IAC7B,CAAC;IACD,UAAU,CAAC,KAAiB;QACxB,OAAO,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC;IAClC,CAAC;IACD,kBAAkB,CAAC,KAAiB;QAChC,OAAO,CAAC,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;CACJ,CAAC","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, Range } from './selection';\nimport { Viewport } from './viewport';\nimport { PlaitPluginElementComponent } from '../core/element/plugin-element';\nimport {\n    BOARD_TO_COMPONENT,\n    BOARD_TO_ELEMENT_HOST,\n    BOARD_TO_HOST,\n    BOARD_TO_ROUGH_SVG,\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 { BoardComponentInterface } from '../board/board.component.interface';\nimport { Point } from './point';\nimport { RectangleClient } from './rectangle-client';\nimport { getRectangleByElements } from '../utils/element';\nimport { Path } from './path';\nimport { Ancestor, PlaitNode } from './node';\n\nexport interface PlaitBoard {\n    viewport: Viewport;\n    children: PlaitElement[];\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;\n    history: PlaitHistory;\n    options: PlaitBoardOptions;\n    undo: () => void;\n    redo: () => void;\n    apply: (operation: PlaitOperation) => void;\n    onChange: () => void;\n    mousedown: (event: MouseEvent) => void;\n    mousemove: (event: MouseEvent) => void;\n    globalMousemove: (event: MouseEvent) => void;\n    mouseup: (event: MouseEvent) => void;\n    globalMouseup: (event: MouseEvent) => void;\n    keydown: (event: KeyboardEvent) => void;\n    keyup: (event: KeyboardEvent) => void;\n    setFragment: (data: DataTransfer | null) => void;\n    insertFragment: (data: DataTransfer | null, targetPoint?: Point) => void;\n    deleteFragment: (data: DataTransfer | null) => void;\n    dblclick: (event: MouseEvent) => void;\n    drawElement: (context: PlaitPluginElementContext) => SVGGElement[] | ComponentType<PlaitPluginElementComponent>;\n    redrawElement: (context: PlaitPluginElementContext, previousContext?: PlaitPluginElementContext) => SVGGElement[] | void;\n    destroyElement: (context: PlaitPluginElementContext) => void;\n    isHitSelection: (element: PlaitElement, range: Range) => boolean;\n    isRecursion: (element: PlaitElement) => boolean;\n    isMovable: (element: PlaitElement) => boolean;\n    getRectangle: (element: PlaitElement) => RectangleClient | null;\n    isWithinSelection: (element: PlaitElement) => boolean;\n}\n\nexport interface PlaitBoardChangeEvent {\n    children: PlaitElement[];\n    operations: PlaitOperation[];\n    viewport: Viewport;\n    selection: Selection | null;\n}\n\nexport interface PlaitBoardOptions {\n    readonly: boolean;\n    hideScrollbar: boolean;\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    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    getElementHost(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board) as SVGGElement;\n    },\n    getRoughSVG(board: PlaitBoard) {\n        return BOARD_TO_ROUGH_SVG.get(board) as RoughSVG;\n    },\n    getComponent(board: PlaitBoard) {\n        return BOARD_TO_COMPONENT.get(board) as BoardComponentInterface;\n    },\n    getBoardNativeElement(board: PlaitBoard) {\n        return PlaitBoard.getComponent(board).nativeElement;\n    },\n    getRectangle(board: PlaitBoard) {\n        return getRectangleByElements(board, board.children, true);\n    },\n    getViewportContainer(board: PlaitBoard) {\n        return PlaitBoard.getHost(board).parentElement 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};\n"]}
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.js","sourceRoot":"","sources":["../../../../packages/plait/src/interfaces/board.ts"],"names":[],"mappings":"AAQA,OAAO,EACH,kBAAkB,EAClB,qBAAqB,EACrB,aAAa,EACb,qBAAqB,EACrB,kBAAkB,EAClB,cAAc,EACd,gBAAgB,EAChB,aAAa,EACb,cAAc,EACjB,MAAM,oBAAoB,CAAC;AAK5B,OAAO,EAAE,sBAAsB,EAAE,MAAM,kBAAkB,CAAC;AA2D1D,MAAM,CAAC,MAAM,UAAU,GAAG;IACtB,OAAO,CAAC,KAAU;QACd,MAAM,aAAa,GAAG,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAChD,IAAI,aAAa,KAAK,SAAS,EAAE;YAC7B,OAAO,aAAa,CAAC;SACxB;QACD,MAAM,OAAO,GAAG,OAAO,KAAK,CAAC,QAAQ,KAAK,UAAU,IAAI,OAAO,KAAK,CAAC,KAAK,KAAK,UAAU,CAAC;QAC1F,cAAc,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QACnC,OAAO,OAAO,CAAC;IACnB,CAAC;IACD,QAAQ,CAAC,KAAiB,EAAE,IAAe;QACvC,MAAM,IAAI,GAAS,EAAE,CAAC;QACtB,IAAI,KAAK,GAAa,IAAI,CAAC;QAC3B,OAAO,IAAI,EAAE;YACT,MAAM,MAAM,GAAG,cAAc,CAAC,GAAG,CAAC,KAAqB,CAAC,CAAC;YACzD,IAAI,MAAM,IAAI,IAAI,EAAE;gBAChB,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oBAC3B,OAAO,IAAI,CAAC;iBACf;qBAAM;oBACH,MAAM;iBACT;aACJ;YACD,MAAM,CAAC,GAAG,aAAa,CAAC,GAAG,CAAC,KAAqB,CAAC,CAAC;YACnD,IAAI,CAAC,IAAI,IAAI,EAAE;gBACX,MAAM;aACT;YACD,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAChB,KAAK,GAAG,MAAM,CAAC;SAClB;QACD,MAAM,IAAI,KAAK,CAAC,2CAA2C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACvF,CAAC;IACD,OAAO,CAAC,KAAiB;QACrB,OAAO,aAAa,CAAC,GAAG,CAAC,KAAK,CAAkB,CAAC;IACrD,CAAC;IACD,cAAc,CAAC,KAAiB;QAC5B,OAAO,qBAAqB,CAAC,GAAG,CAAC,KAAK,CAAgB,CAAC;IAC3D,CAAC;IACD,WAAW,CAAC,KAAiB;QACzB,OAAO,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAa,CAAC;IACrD,CAAC;IACD,YAAY,CAAC,KAAiB;QAC1B,OAAO,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAA4B,CAAC;IACpE,CAAC;IACD,qBAAqB,CAAC,KAAiB;QACnC,OAAO,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,aAAa,CAAC;IACxD,CAAC;IACD,YAAY,CAAC,KAAiB;QAC1B,OAAO,sBAAsB,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC/D,CAAC;IACD,oBAAoB,CAAC,KAAiB;QAClC,OAAO,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,aAA4B,CAAC;IAClE,CAAC;IACD,OAAO,CAAC,KAAiB;QACrB,OAAO,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC;IAC7B,CAAC;IACD,UAAU,CAAC,KAAiB;QACxB,OAAO,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC;IAClC,CAAC;IACD,kBAAkB,CAAC,KAAiB;QAChC,OAAO,CAAC,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IACD,UAAU,CAAuB,KAAiB;QAC9C,OAAO,KAAK,CAAC,OAAY,CAAC;IAC9B,CAAC;IACD,SAAS,CAAuB,KAAiB,EAAE,OAAU;QACzD,OAAO,KAAK,CAAC,OAAO,KAAK,OAAO,CAAC;IACrC,CAAC;IACD,cAAc,CAAC,KAAiB;QAC5B,OAAO,qBAAqB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC5C,CAAC;CACJ,CAAC","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, Range } from './selection';\nimport { Viewport } from './viewport';\nimport { PlaitPluginElementComponent } from '../core/element/plugin-element';\nimport {\n    BOARD_TO_COMPONENT,\n    BOARD_TO_ELEMENT_HOST,\n    BOARD_TO_HOST,\n    BOARD_TO_MOVING_POINT,\n    BOARD_TO_ROUGH_SVG,\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 { BoardComponentInterface } from '../board/board.component.interface';\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';\n\nexport interface PlaitBoard {\n    viewport: Viewport;\n    children: PlaitElement[];\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    mousedown: (event: MouseEvent) => void;\n    mousemove: (event: MouseEvent) => void;\n    globalMousemove: (event: MouseEvent) => void;\n    mouseup: (event: MouseEvent) => void;\n    globalMouseup: (event: MouseEvent) => void;\n    keydown: (event: KeyboardEvent) => void;\n    keyup: (event: KeyboardEvent) => void;\n    setFragment: (data: DataTransfer | null) => void;\n    insertFragment: (data: DataTransfer | null, targetPoint?: Point) => void;\n    deleteFragment: (data: DataTransfer | null) => void;\n    dblclick: (event: MouseEvent) => void;\n    drawElement: (context: PlaitPluginElementContext) => SVGGElement[] | ComponentType<PlaitPluginElementComponent>;\n    redrawElement: (context: PlaitPluginElementContext, previousContext?: PlaitPluginElementContext) => SVGGElement[] | void;\n    destroyElement: (context: PlaitPluginElementContext) => void;\n    isHitSelection: (element: PlaitElement, range: Range) => 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}\n\nexport interface PlaitBoardChangeEvent {\n    children: PlaitElement[];\n    operations: PlaitOperation[];\n    viewport: Viewport;\n    selection: Selection | null;\n}\n\nexport interface PlaitBoardOptions {\n    readonly: boolean;\n    hideScrollbar: boolean;\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    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    getElementHost(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board) as SVGGElement;\n    },\n    getRoughSVG(board: PlaitBoard) {\n        return BOARD_TO_ROUGH_SVG.get(board) as RoughSVG;\n    },\n    getComponent(board: PlaitBoard) {\n        return BOARD_TO_COMPONENT.get(board) as BoardComponentInterface;\n    },\n    getBoardNativeElement(board: PlaitBoard) {\n        return PlaitBoard.getComponent(board).nativeElement;\n    },\n    getRectangle(board: PlaitBoard) {\n        return getRectangleByElements(board, board.children, true);\n    },\n    getViewportContainer(board: PlaitBoard) {\n        return PlaitBoard.getHost(board).parentElement 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    getMovingPoint(board: PlaitBoard) {\n        return BOARD_TO_MOVING_POINT.get(board);\n    }\n};\n"]}
|
|
@@ -12,4 +12,5 @@ export * from './point';
|
|
|
12
12
|
export * from './selection';
|
|
13
13
|
export * from './viewport';
|
|
14
14
|
export * from './history';
|
|
15
|
-
|
|
15
|
+
export * from './plugin-key';
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvaW50ZXJmYWNlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLFFBQVEsQ0FBQztBQUN2QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLFFBQVEsQ0FBQztBQUN2QixjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYm9hcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9wb2ludGVyJztcbmV4cG9ydCAqIGZyb20gJy4uL2NvcmUvZWxlbWVudC9jb250ZXh0JztcbmV4cG9ydCAqIGZyb20gJy4vY3VzdG9tLXR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vZWxlbWVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JlY3RhbmdsZS1jbGllbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ub2RlJztcbmV4cG9ydCAqIGZyb20gJy4vb3BlcmF0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vcGF0aCc7XG5leHBvcnQgKiBmcm9tICcuL3BsdWdpbic7XG5leHBvcnQgKiBmcm9tICcuL3BvaW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vdmlld3BvcnQnO1xuZXhwb3J0ICogZnJvbSAnLi9oaXN0b3J5JztcbmV4cG9ydCAqIGZyb20gJy4vcGx1Z2luLWtleSc7XG4iXX0=
|
|
@@ -37,4 +37,4 @@ export const PlaitNode = {
|
|
|
37
37
|
return n;
|
|
38
38
|
}
|
|
39
39
|
};
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy9pbnRlcmZhY2VzL25vZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLFFBQVEsQ0FBQztBQVU5QixNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUc7SUFDckIsTUFBTSxFQUFFLENBQUMsS0FBaUIsRUFBRSxJQUFVLEVBQUUsRUFBRTtRQUN0QyxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JDLE1BQU0sQ0FBQyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQzNDLE9BQU8sQ0FBQyxDQUFDO0lBQ2IsQ0FBQztJQUNEOzs7OztPQUtHO0lBQ0gsQ0FBQyxPQUFPLENBQUMsSUFBZ0IsRUFBRSxJQUFVLEVBQUUsVUFBOEIsRUFBRTtRQUNuRSxLQUFLLE1BQU0sQ0FBQyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxFQUFFO1lBQzNDLE1BQU0sQ0FBQyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ2pDLE1BQU0sQ0FBQyxDQUFDO1NBQ1g7SUFDTCxDQUFDO0lBQ0QsR0FBRyxDQUFrQyxJQUFnQixFQUFFLElBQVU7UUFDN0QsSUFBSSxJQUFJLEdBQWEsSUFBSSxDQUFDO1FBQzFCLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQ2xDLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNsQixJQUFJLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUU7Z0JBQzlDLE1BQU0sSUFBSSxLQUFLLENBQUMscUNBQXFDLElBQUksR0FBRyxDQUFDLENBQUM7YUFDakU7WUFDRCxJQUFJLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUMzQjtRQUNELE9BQU8sSUFBUyxDQUFDO0lBQ3JCLENBQUM7SUFDRCxJQUFJLENBQUMsS0FBaUIsRUFBRSxJQUFVO1FBQzlCLElBQUksQ0FBQyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ25DLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUFRLElBQUksQ0FBQyxDQUFDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQzdDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFRLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztZQUNoQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUNyQjtRQUNELE9BQU8sQ0FBQyxDQUFDO0lBQ2IsQ0FBQztDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEVsZW1lbnQgfSBmcm9tICcuL2VsZW1lbnQnO1xuaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJy4vYm9hcmQnO1xuaW1wb3J0IHsgUGF0aCB9IGZyb20gJy4vcGF0aCc7XG5cbmV4cG9ydCB0eXBlIFBsYWl0Tm9kZSA9IFBsYWl0RWxlbWVudDtcblxuZXhwb3J0IHR5cGUgQW5jZXN0b3IgPSBQbGFpdEJvYXJkIHwgUGxhaXRFbGVtZW50O1xuXG5leHBvcnQgaW50ZXJmYWNlIE5vZGVQYXJlbnRzT3B0aW9ucyB7XG4gICAgcmV2ZXJzZT86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjb25zdCBQbGFpdE5vZGUgPSB7XG4gICAgcGFyZW50OiAoYm9hcmQ6IFBsYWl0Qm9hcmQsIHBhdGg6IFBhdGgpID0+IHtcbiAgICAgICAgY29uc3QgcGFyZW50UGF0aCA9IFBhdGgucGFyZW50KHBhdGgpO1xuICAgICAgICBjb25zdCBwID0gUGxhaXROb2RlLmdldChib2FyZCwgcGFyZW50UGF0aCk7XG4gICAgICAgIHJldHVybiBwO1xuICAgIH0sXG4gICAgLyoqXG4gICAgICogUmV0dXJuIGEgZ2VuZXJhdG9yIG9mIGFsbCB0aGUgYW5jZXN0b3Igbm9kZXMgYWJvdmUgYSBzcGVjaWZpYyBwYXRoLlxuICAgICAqXG4gICAgICogQnkgZGVmYXVsdCB0aGUgb3JkZXIgaXMgdG9wLWRvd24sIGZyb20gaGlnaGVzdCB0byBsb3dlc3QgYW5jZXN0b3IgaW5cbiAgICAgKiB0aGUgdHJlZSwgYnV0IHlvdSBjYW4gcGFzcyB0aGUgYHJldmVyc2U6IHRydWVgIG9wdGlvbiB0byBnbyBib3R0b20tdXAuXG4gICAgICovXG4gICAgKnBhcmVudHMocm9vdDogUGxhaXRCb2FyZCwgcGF0aDogUGF0aCwgb3B0aW9uczogTm9kZVBhcmVudHNPcHRpb25zID0ge30pOiBHZW5lcmF0b3I8UGxhaXROb2RlLCB2b2lkLCB1bmRlZmluZWQ+IHtcbiAgICAgICAgZm9yIChjb25zdCBwIG9mIFBhdGguYW5jZXN0b3JzKHBhdGgsIG9wdGlvbnMpKSB7XG4gICAgICAgICAgICBjb25zdCBuID0gUGxhaXROb2RlLmdldChyb290LCBwKTtcbiAgICAgICAgICAgIHlpZWxkIG47XG4gICAgICAgIH1cbiAgICB9LFxuICAgIGdldDxUIGV4dGVuZHMgUGxhaXROb2RlID0gUGxhaXROb2RlPihyb290OiBQbGFpdEJvYXJkLCBwYXRoOiBQYXRoKTogVCB7XG4gICAgICAgIGxldCBub2RlOiBBbmNlc3RvciA9IHJvb3Q7XG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgcGF0aC5sZW5ndGg7IGkrKykge1xuICAgICAgICAgICAgY29uc3QgcCA9IHBhdGhbaV07XG4gICAgICAgICAgICBpZiAoIW5vZGUgfHwgIW5vZGUuY2hpbGRyZW4gfHwgIW5vZGUuY2hpbGRyZW5bcF0pIHtcbiAgICAgICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYENhbm5vdCBmaW5kIGEgZGVzY2VuZGFudCBhdCBwYXRoIFske3BhdGh9XWApO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgbm9kZSA9IG5vZGUuY2hpbGRyZW5bcF07XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG5vZGUgYXMgVDtcbiAgICB9LFxuICAgIGxhc3QoYm9hcmQ6IFBsYWl0Qm9hcmQsIHBhdGg6IFBhdGgpIHtcbiAgICAgICAgbGV0IG4gPSBQbGFpdE5vZGUuZ2V0KGJvYXJkLCBwYXRoKTtcbiAgICAgICAgd2hpbGUgKG4gJiYgbi5jaGlsZHJlbiAmJiBuLmNoaWxkcmVuLmxlbmd0aCA+IDApIHtcbiAgICAgICAgICAgIGNvbnN0IGkgPSBuLmNoaWxkcmVuLmxlbmd0aCAtIDE7XG4gICAgICAgICAgICBuID0gbi5jaGlsZHJlbltpXTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gbjtcbiAgICB9XG59O1xuIl19
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Path } from './path';
|
|
2
|
+
export const PathRef = {
|
|
3
|
+
transform(ref, op) {
|
|
4
|
+
const { current } = ref;
|
|
5
|
+
if (current == null) {
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
const path = Path.transform(current, op);
|
|
9
|
+
ref.current = path;
|
|
10
|
+
if (path == null) {
|
|
11
|
+
ref.unref();
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0aC1yZWYuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvaW50ZXJmYWNlcy9wYXRoLXJlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBWTlCLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRztJQUNuQixTQUFTLENBQUMsR0FBWSxFQUFFLEVBQWtCO1FBQ3RDLE1BQU0sRUFBRSxPQUFPLEVBQUUsR0FBRyxHQUFHLENBQUM7UUFFeEIsSUFBSSxPQUFPLElBQUksSUFBSSxFQUFFO1lBQ2pCLE9BQU87U0FDVjtRQUVELE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ3pDLEdBQUcsQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDO1FBRW5CLElBQUksSUFBSSxJQUFJLElBQUksRUFBRTtZQUNkLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUNmO0lBQ0wsQ0FBQztDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdE9wZXJhdGlvbiB9IGZyb20gJy4vb3BlcmF0aW9uJztcbmltcG9ydCB7IFBhdGggfSBmcm9tICcuL3BhdGgnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBhdGhSZWYge1xuICAgIGN1cnJlbnQ6IFBhdGggfCBudWxsO1xuICAgIGFmZmluaXR5OiAnZm9yd2FyZCcgfCAnYmFja3dhcmQnIHwgbnVsbDtcbiAgICB1bnJlZigpOiBQYXRoIHwgbnVsbDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQYXRoUmVmT3B0aW9ucyB7XG4gICAgYWZmaW5pdHk/OiAnZm9yd2FyZCcgfCAnYmFja3dhcmQnIHwgbnVsbDtcbn1cblxuZXhwb3J0IGNvbnN0IFBhdGhSZWYgPSB7XG4gICAgdHJhbnNmb3JtKHJlZjogUGF0aFJlZiwgb3A6IFBsYWl0T3BlcmF0aW9uKTogdm9pZCB7XG4gICAgICAgIGNvbnN0IHsgY3VycmVudCB9ID0gcmVmO1xuXG4gICAgICAgIGlmIChjdXJyZW50ID09IG51bGwpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHBhdGggPSBQYXRoLnRyYW5zZm9ybShjdXJyZW50LCBvcCk7XG4gICAgICAgIHJlZi5jdXJyZW50ID0gcGF0aDtcblxuICAgICAgICBpZiAocGF0aCA9PSBudWxsKSB7XG4gICAgICAgICAgICByZWYudW5yZWYoKTtcbiAgICAgICAgfVxuICAgIH1cbn07XG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export var PlaitPluginKey;
|
|
2
|
+
(function (PlaitPluginKey) {
|
|
3
|
+
PlaitPluginKey["withSelection"] = "withSelection";
|
|
4
|
+
})(PlaitPluginKey || (PlaitPluginKey = {}));
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGx1Z2luLWtleS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy9pbnRlcmZhY2VzL3BsdWdpbi1rZXkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksY0FFWDtBQUZELFdBQVksY0FBYztJQUN0QixpREFBaUMsQ0FBQTtBQUNyQyxDQUFDLEVBRlcsY0FBYyxLQUFkLGNBQWMsUUFFekIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBQbGFpdFBsdWdpbktleSB7XG4gICAgJ3dpdGhTZWxlY3Rpb24nID0gJ3dpdGhTZWxlY3Rpb24nXG59Il19
|
package/esm2020/plait.module.mjs
CHANGED
|
@@ -2,14 +2,13 @@ import { NgModule } from '@angular/core';
|
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { PlaitBoardComponent } from './board/board.component';
|
|
4
4
|
import { PlaitElementComponent } from './core/element/element.component';
|
|
5
|
-
import { PlaitToolbarComponent } from './core/toolbar/toolbar.component';
|
|
6
5
|
import { PlaitChildrenElement } from './core/children/children.component';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
8
|
-
const COMPONENTS = [PlaitBoardComponent, PlaitChildrenElement, PlaitElementComponent
|
|
7
|
+
const COMPONENTS = [PlaitBoardComponent, PlaitChildrenElement, PlaitElementComponent];
|
|
9
8
|
export class PlaitModule {
|
|
10
9
|
}
|
|
11
10
|
PlaitModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
12
|
-
PlaitModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.5", ngImport: i0, type: PlaitModule, declarations: [PlaitBoardComponent, PlaitChildrenElement, PlaitElementComponent
|
|
11
|
+
PlaitModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.5", ngImport: i0, type: PlaitModule, declarations: [PlaitBoardComponent, PlaitChildrenElement, PlaitElementComponent], imports: [CommonModule], exports: [PlaitBoardComponent, PlaitChildrenElement, PlaitElementComponent] });
|
|
13
12
|
PlaitModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitModule, imports: [CommonModule] });
|
|
14
13
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitModule, decorators: [{
|
|
15
14
|
type: NgModule,
|
|
@@ -19,4 +18,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImpor
|
|
|
19
18
|
exports: [...COMPONENTS]
|
|
20
19
|
}]
|
|
21
20
|
}] });
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhaXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3BsYWl0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN6RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQzs7QUFFMUUsTUFBTSxVQUFVLEdBQUcsQ0FBQyxtQkFBbUIsRUFBRSxvQkFBb0IsRUFBRSxxQkFBcUIsQ0FBQyxDQUFDO0FBT3RGLE1BQU0sT0FBTyxXQUFXOzt3R0FBWCxXQUFXO3lHQUFYLFdBQVcsaUJBUEosbUJBQW1CLEVBQUUsb0JBQW9CLEVBQUUscUJBQXFCLGFBSXRFLFlBQVksYUFKTixtQkFBbUIsRUFBRSxvQkFBb0IsRUFBRSxxQkFBcUI7eUdBT3ZFLFdBQVcsWUFIVixZQUFZOzJGQUdiLFdBQVc7a0JBTHZCLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFLENBQUMsR0FBRyxVQUFVLENBQUM7b0JBQzdCLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsT0FBTyxFQUFFLENBQUMsR0FBRyxVQUFVLENBQUM7aUJBQzNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBQbGFpdEJvYXJkQ29tcG9uZW50IH0gZnJvbSAnLi9ib2FyZC9ib2FyZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgUGxhaXRFbGVtZW50Q29tcG9uZW50IH0gZnJvbSAnLi9jb3JlL2VsZW1lbnQvZWxlbWVudC5jb21wb25lbnQnO1xuaW1wb3J0IHsgUGxhaXRDaGlsZHJlbkVsZW1lbnQgfSBmcm9tICcuL2NvcmUvY2hpbGRyZW4vY2hpbGRyZW4uY29tcG9uZW50JztcblxuY29uc3QgQ09NUE9ORU5UUyA9IFtQbGFpdEJvYXJkQ29tcG9uZW50LCBQbGFpdENoaWxkcmVuRWxlbWVudCwgUGxhaXRFbGVtZW50Q29tcG9uZW50XTtcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFsuLi5DT01QT05FTlRTXSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgICBleHBvcnRzOiBbLi4uQ09NUE9ORU5UU11cbn0pXG5leHBvcnQgY2xhc3MgUGxhaXRNb2R1bGUge31cbiJdfQ==
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { PlaitPointerType } from '../interfaces/pointer';
|
|
2
2
|
import { Transforms } from '../transforms';
|
|
3
|
-
import { FLUSHING } from '../utils/weak-maps';
|
|
3
|
+
import { FLUSHING, PATH_REFS } from '../utils/weak-maps';
|
|
4
|
+
import { PathRef } from '../interfaces/path-ref';
|
|
4
5
|
export function createBoard(children, options) {
|
|
5
6
|
const board = {
|
|
6
7
|
viewport: {
|
|
@@ -14,14 +15,17 @@ export function createBoard(children, options) {
|
|
|
14
15
|
undos: []
|
|
15
16
|
},
|
|
16
17
|
selection: null,
|
|
17
|
-
pointer: PlaitPointerType.selection,
|
|
18
18
|
options: options || {
|
|
19
19
|
readonly: false,
|
|
20
20
|
hideScrollbar: false
|
|
21
21
|
},
|
|
22
|
+
pointer: options?.readonly ? PlaitPointerType.hand : PlaitPointerType.selection,
|
|
22
23
|
undo: () => { },
|
|
23
24
|
redo: () => { },
|
|
24
25
|
apply: (operation) => {
|
|
26
|
+
for (const ref of board.pathRefs()) {
|
|
27
|
+
PathRef.transform(ref, operation);
|
|
28
|
+
}
|
|
25
29
|
board.operations.push(operation);
|
|
26
30
|
Transforms.transform(board, operation);
|
|
27
31
|
if (!FLUSHING.get(board)) {
|
|
@@ -33,6 +37,31 @@ export function createBoard(children, options) {
|
|
|
33
37
|
});
|
|
34
38
|
}
|
|
35
39
|
},
|
|
40
|
+
pathRef: (path, options) => {
|
|
41
|
+
const affinity = options?.affinity || 'forward';
|
|
42
|
+
const ref = {
|
|
43
|
+
current: path,
|
|
44
|
+
affinity,
|
|
45
|
+
unref() {
|
|
46
|
+
const { current } = ref;
|
|
47
|
+
const pathRefs = board.pathRefs();
|
|
48
|
+
pathRefs.delete(ref);
|
|
49
|
+
ref.current = null;
|
|
50
|
+
return current;
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
const refs = board.pathRefs();
|
|
54
|
+
refs.add(ref);
|
|
55
|
+
return ref;
|
|
56
|
+
},
|
|
57
|
+
pathRefs: () => {
|
|
58
|
+
let refs = PATH_REFS.get(board);
|
|
59
|
+
if (!refs) {
|
|
60
|
+
refs = new Set();
|
|
61
|
+
PATH_REFS.set(board, refs);
|
|
62
|
+
}
|
|
63
|
+
return refs;
|
|
64
|
+
},
|
|
36
65
|
onChange: () => { },
|
|
37
66
|
mousedown: (event) => { },
|
|
38
67
|
mousemove: (event) => { },
|
|
@@ -56,4 +85,4 @@ export function createBoard(children, options) {
|
|
|
56
85
|
};
|
|
57
86
|
return board;
|
|
58
87
|
}
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-board.js","sourceRoot":"","sources":["../../../../packages/plait/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';\n\nexport function createBoard(children: PlaitElement[], options?: PlaitBoardOptions): PlaitBoard {\n    const board: PlaitBoard = {\n        viewport: {\n            zoom: 1,\n            viewBackgroundColor: '#000'\n        },\n        children,\n        operations: [],\n        history: {\n            redos: [],\n            undos: []\n        },\n        selection: null,\n        options: options || {\n            readonly: false,\n            hideScrollbar: 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.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        mousedown: (event: MouseEvent) => {},\n        mousemove: (event: MouseEvent) => {},\n        globalMousemove: (event: MouseEvent) => {},\n        mouseup: (event: MouseEvent) => {},\n        globalMouseup: (event: MouseEvent) => {},\n        keydown: (event: KeyboardEvent) => {},\n        keyup: (event: KeyboardEvent) => {},\n        dblclick: (event: MouseEvent) => {},\n        setFragment: (data: DataTransfer | null) => {},\n        insertFragment: (data: DataTransfer | null) => {},\n        deleteFragment: (data: DataTransfer | null) => {},\n        drawElement: (context: PlaitPluginElementContext) => [],\n        redrawElement: (context: PlaitPluginElementContext, previousContext) => {},\n        destroyElement: (context: PlaitPluginElementContext) => {},\n        isWithinSelection: element => false,\n        isHitSelection: element => false,\n        isRecursion: element => true,\n        isMovable: element => false,\n        getRectangle: element => null\n    };\n    return board;\n}\n"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { PlaitPointerType, PlaitBoard } from '../interfaces';
|
|
2
|
-
import {
|
|
2
|
+
import { BoardTransforms } from '../transforms';
|
|
3
|
+
import { isMainPointer } from '../utils/dom/common';
|
|
3
4
|
import { updateViewportContainerScroll } from '../utils/viewport';
|
|
4
5
|
export function withHandPointer(board) {
|
|
5
6
|
const { mousedown, mousemove, globalMouseup, keydown, keyup } = board;
|
|
@@ -9,13 +10,7 @@ export function withHandPointer(board) {
|
|
|
9
10
|
y: 0
|
|
10
11
|
};
|
|
11
12
|
board.mousedown = (event) => {
|
|
12
|
-
if (board.
|
|
13
|
-
updatePointerType(board, PlaitPointerType.hand);
|
|
14
|
-
}
|
|
15
|
-
else if (!board.selection) {
|
|
16
|
-
updatePointerType(board, PlaitPointerType.selection);
|
|
17
|
-
}
|
|
18
|
-
if (board.pointer === PlaitPointerType.hand && board.selection) {
|
|
13
|
+
if (PlaitBoard.isPointer(board, PlaitPointerType.hand) && isMainPointer(event)) {
|
|
19
14
|
isMoving = true;
|
|
20
15
|
PlaitBoard.getBoardNativeElement(board).classList.add('viewport-moving');
|
|
21
16
|
plaitBoardMove.x = event.x;
|
|
@@ -24,7 +19,7 @@ export function withHandPointer(board) {
|
|
|
24
19
|
mousedown(event);
|
|
25
20
|
};
|
|
26
21
|
board.mousemove = (event) => {
|
|
27
|
-
if (board
|
|
22
|
+
if (PlaitBoard.isPointer(board, PlaitPointerType.hand) && board.selection && isMoving) {
|
|
28
23
|
const viewportContainer = PlaitBoard.getViewportContainer(board);
|
|
29
24
|
const left = viewportContainer.scrollLeft - (event.x - plaitBoardMove.x);
|
|
30
25
|
const top = viewportContainer.scrollTop - (event.y - plaitBoardMove.y);
|
|
@@ -44,20 +39,20 @@ export function withHandPointer(board) {
|
|
|
44
39
|
globalMouseup(event);
|
|
45
40
|
};
|
|
46
41
|
board.keydown = (event) => {
|
|
47
|
-
if (
|
|
48
|
-
if (board
|
|
49
|
-
updatePointerType(board, PlaitPointerType.hand);
|
|
42
|
+
if (event.code === 'Space') {
|
|
43
|
+
if (!PlaitBoard.isPointer(board, PlaitPointerType.hand)) {
|
|
44
|
+
BoardTransforms.updatePointerType(board, PlaitPointerType.hand);
|
|
50
45
|
}
|
|
51
46
|
event.preventDefault();
|
|
52
47
|
}
|
|
53
48
|
keydown(event);
|
|
54
49
|
};
|
|
55
50
|
board.keyup = (event) => {
|
|
56
|
-
if (
|
|
57
|
-
updatePointerType(board, PlaitPointerType.selection);
|
|
51
|
+
if (!board.options.readonly && event.code === 'Space') {
|
|
52
|
+
BoardTransforms.updatePointerType(board, PlaitPointerType.selection);
|
|
58
53
|
}
|
|
59
54
|
keyup(event);
|
|
60
55
|
};
|
|
61
56
|
return board;
|
|
62
57
|
}
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1oYW5kLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3BsdWdpbnMvd2l0aC1oYW5kLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxVQUFVLEVBQWtCLE1BQU0sZUFBZSxDQUFDO0FBQzdFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3BELE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRWxFLE1BQU0sVUFBVSxlQUFlLENBQXVCLEtBQVE7SUFDMUQsTUFBTSxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsYUFBYSxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsR0FBRyxLQUFLLENBQUM7SUFDdEUsSUFBSSxRQUFRLEdBQVksS0FBSyxDQUFDO0lBQzlCLE1BQU0sY0FBYyxHQUFtQjtRQUNuQyxDQUFDLEVBQUUsQ0FBQztRQUNKLENBQUMsRUFBRSxDQUFDO0tBQ1AsQ0FBQztJQUVGLEtBQUssQ0FBQyxTQUFTLEdBQUcsQ0FBQyxLQUFpQixFQUFFLEVBQUU7UUFDcEMsSUFBSSxVQUFVLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxhQUFhLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDNUUsUUFBUSxHQUFHLElBQUksQ0FBQztZQUNoQixVQUFVLENBQUMscUJBQXFCLENBQUMsS0FBSyxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1lBQ3pFLGNBQWMsQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQztZQUMzQixjQUFjLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDOUI7UUFDRCxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckIsQ0FBQyxDQUFDO0lBRUYsS0FBSyxDQUFDLFNBQVMsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtRQUNwQyxJQUFJLFVBQVUsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLEtBQUssQ0FBQyxTQUFTLElBQUksUUFBUSxFQUFFO1lBQ25GLE1BQU0saUJBQWlCLEdBQUcsVUFBVSxDQUFDLG9CQUFvQixDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2pFLE1BQU0sSUFBSSxHQUFHLGlCQUFpQixDQUFDLFVBQVUsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3pFLE1BQU0sR0FBRyxHQUFHLGlCQUFpQixDQUFDLFNBQVMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3ZFLDZCQUE2QixDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQ3ZELGNBQWMsQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQztZQUMzQixjQUFjLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDOUI7UUFDRCxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckIsQ0FBQyxDQUFDO0lBRUYsS0FBSyxDQUFDLGFBQWEsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtRQUN4QyxJQUFJLEtBQUssQ0FBQyxTQUFTLEVBQUU7WUFDakIsUUFBUSxHQUFHLEtBQUssQ0FBQztZQUNqQixVQUFVLENBQUMscUJBQXFCLENBQUMsS0FBSyxDQUFDLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1lBQzVFLGNBQWMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ3JCLGNBQWMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQ3hCO1FBQ0QsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3pCLENBQUMsQ0FBQztJQUVGLEtBQUssQ0FBQyxPQUFPLEdBQUcsQ0FBQyxLQUFvQixFQUFFLEVBQUU7UUFDckMsSUFBSSxLQUFLLENBQUMsSUFBSSxLQUFLLE9BQU8sRUFBRTtZQUN4QixJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLEVBQUU7Z0JBQ3JELGVBQWUsQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLEVBQUUsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLENBQUM7YUFDbkU7WUFDRCxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7U0FDMUI7UUFDRCxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDbkIsQ0FBQyxDQUFDO0lBRUYsS0FBSyxDQUFDLEtBQUssR0FBRyxDQUFDLEtBQW9CLEVBQUUsRUFBRTtRQUNuQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxRQUFRLElBQUksS0FBSyxDQUFDLElBQUksS0FBSyxPQUFPLEVBQUU7WUFDbkQsZUFBZSxDQUFDLGlCQUFpQixDQUFDLEtBQUssRUFBRSxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsQ0FBQztTQUN4RTtRQUNELEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNqQixDQUFDLENBQUM7SUFFRixPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRQb2ludGVyVHlwZSwgUGxhaXRCb2FyZCwgUGxhaXRCb2FyZE1vdmUgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IEJvYXJkVHJhbnNmb3JtcyB9IGZyb20gJy4uL3RyYW5zZm9ybXMnO1xuaW1wb3J0IHsgaXNNYWluUG9pbnRlciB9IGZyb20gJy4uL3V0aWxzL2RvbS9jb21tb24nO1xuaW1wb3J0IHsgdXBkYXRlVmlld3BvcnRDb250YWluZXJTY3JvbGwgfSBmcm9tICcuLi91dGlscy92aWV3cG9ydCc7XG5cbmV4cG9ydCBmdW5jdGlvbiB3aXRoSGFuZFBvaW50ZXI8VCBleHRlbmRzIFBsYWl0Qm9hcmQ+KGJvYXJkOiBUKSB7XG4gICAgY29uc3QgeyBtb3VzZWRvd24sIG1vdXNlbW92ZSwgZ2xvYmFsTW91c2V1cCwga2V5ZG93biwga2V5dXAgfSA9IGJvYXJkO1xuICAgIGxldCBpc01vdmluZzogYm9vbGVhbiA9IGZhbHNlO1xuICAgIGNvbnN0IHBsYWl0Qm9hcmRNb3ZlOiBQbGFpdEJvYXJkTW92ZSA9IHtcbiAgICAgICAgeDogMCxcbiAgICAgICAgeTogMFxuICAgIH07XG5cbiAgICBib2FyZC5tb3VzZWRvd24gPSAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHtcbiAgICAgICAgaWYgKFBsYWl0Qm9hcmQuaXNQb2ludGVyKGJvYXJkLCBQbGFpdFBvaW50ZXJUeXBlLmhhbmQpICYmIGlzTWFpblBvaW50ZXIoZXZlbnQpKSB7XG4gICAgICAgICAgICBpc01vdmluZyA9IHRydWU7XG4gICAgICAgICAgICBQbGFpdEJvYXJkLmdldEJvYXJkTmF0aXZlRWxlbWVudChib2FyZCkuY2xhc3NMaXN0LmFkZCgndmlld3BvcnQtbW92aW5nJyk7XG4gICAgICAgICAgICBwbGFpdEJvYXJkTW92ZS54ID0gZXZlbnQueDtcbiAgICAgICAgICAgIHBsYWl0Qm9hcmRNb3ZlLnkgPSBldmVudC55O1xuICAgICAgICB9XG4gICAgICAgIG1vdXNlZG93bihldmVudCk7XG4gICAgfTtcblxuICAgIGJvYXJkLm1vdXNlbW92ZSA9IChldmVudDogTW91c2VFdmVudCkgPT4ge1xuICAgICAgICBpZiAoUGxhaXRCb2FyZC5pc1BvaW50ZXIoYm9hcmQsIFBsYWl0UG9pbnRlclR5cGUuaGFuZCkgJiYgYm9hcmQuc2VsZWN0aW9uICYmIGlzTW92aW5nKSB7XG4gICAgICAgICAgICBjb25zdCB2aWV3cG9ydENvbnRhaW5lciA9IFBsYWl0Qm9hcmQuZ2V0Vmlld3BvcnRDb250YWluZXIoYm9hcmQpO1xuICAgICAgICAgICAgY29uc3QgbGVmdCA9IHZpZXdwb3J0Q29udGFpbmVyLnNjcm9sbExlZnQgLSAoZXZlbnQueCAtIHBsYWl0Qm9hcmRNb3ZlLngpO1xuICAgICAgICAgICAgY29uc3QgdG9wID0gdmlld3BvcnRDb250YWluZXIuc2Nyb2xsVG9wIC0gKGV2ZW50LnkgLSBwbGFpdEJvYXJkTW92ZS55KTtcbiAgICAgICAgICAgIHVwZGF0ZVZpZXdwb3J0Q29udGFpbmVyU2Nyb2xsKGJvYXJkLCBsZWZ0LCB0b3AsIGZhbHNlKTtcbiAgICAgICAgICAgIHBsYWl0Qm9hcmRNb3ZlLnggPSBldmVudC54O1xuICAgICAgICAgICAgcGxhaXRCb2FyZE1vdmUueSA9IGV2ZW50Lnk7XG4gICAgICAgIH1cbiAgICAgICAgbW91c2Vtb3ZlKGV2ZW50KTtcbiAgICB9O1xuXG4gICAgYm9hcmQuZ2xvYmFsTW91c2V1cCA9IChldmVudDogTW91c2VFdmVudCkgPT4ge1xuICAgICAgICBpZiAoYm9hcmQuc2VsZWN0aW9uKSB7XG4gICAgICAgICAgICBpc01vdmluZyA9IGZhbHNlO1xuICAgICAgICAgICAgUGxhaXRCb2FyZC5nZXRCb2FyZE5hdGl2ZUVsZW1lbnQoYm9hcmQpLmNsYXNzTGlzdC5yZW1vdmUoJ3ZpZXdwb3J0LW1vdmluZycpO1xuICAgICAgICAgICAgcGxhaXRCb2FyZE1vdmUueCA9IDA7XG4gICAgICAgICAgICBwbGFpdEJvYXJkTW92ZS55ID0gMDtcbiAgICAgICAgfVxuICAgICAgICBnbG9iYWxNb3VzZXVwKGV2ZW50KTtcbiAgICB9O1xuXG4gICAgYm9hcmQua2V5ZG93biA9IChldmVudDogS2V5Ym9hcmRFdmVudCkgPT4ge1xuICAgICAgICBpZiAoZXZlbnQuY29kZSA9PT0gJ1NwYWNlJykge1xuICAgICAgICAgICAgaWYgKCFQbGFpdEJvYXJkLmlzUG9pbnRlcihib2FyZCwgUGxhaXRQb2ludGVyVHlwZS5oYW5kKSkge1xuICAgICAgICAgICAgICAgIEJvYXJkVHJhbnNmb3Jtcy51cGRhdGVQb2ludGVyVHlwZShib2FyZCwgUGxhaXRQb2ludGVyVHlwZS5oYW5kKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgIH1cbiAgICAgICAga2V5ZG93bihldmVudCk7XG4gICAgfTtcblxuICAgIGJvYXJkLmtleXVwID0gKGV2ZW50OiBLZXlib2FyZEV2ZW50KSA9PiB7XG4gICAgICAgIGlmICghYm9hcmQub3B0aW9ucy5yZWFkb25seSAmJiBldmVudC5jb2RlID09PSAnU3BhY2UnKSB7XG4gICAgICAgICAgICBCb2FyZFRyYW5zZm9ybXMudXBkYXRlUG9pbnRlclR5cGUoYm9hcmQsIFBsYWl0UG9pbnRlclR5cGUuc2VsZWN0aW9uKTtcbiAgICAgICAgfVxuICAgICAgICBrZXl1cChldmVudCk7XG4gICAgfTtcblxuICAgIHJldHVybiBib2FyZDtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export const withOptions = (board) => {
|
|
2
|
+
const pluginOptions = new Map();
|
|
3
|
+
const newBoard = board;
|
|
4
|
+
newBoard.getPluginOptions = key => {
|
|
5
|
+
return pluginOptions.get(key);
|
|
6
|
+
};
|
|
7
|
+
newBoard.setPluginOptions = (key, options) => {
|
|
8
|
+
const oldOptions = newBoard.getPluginOptions(key) || {};
|
|
9
|
+
pluginOptions.set(key, { ...oldOptions, ...options });
|
|
10
|
+
};
|
|
11
|
+
return newBoard;
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3BsdWdpbnMvd2l0aC1vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVlBLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUM3QyxNQUFNLGFBQWEsR0FBRyxJQUFJLEdBQUcsRUFBZSxDQUFDO0lBQzdDLE1BQU0sUUFBUSxHQUFHLEtBQTBCLENBQUM7SUFDNUMsUUFBUSxDQUFDLGdCQUFnQixHQUFHLEdBQUcsQ0FBQyxFQUFFO1FBQzlCLE9BQU8sYUFBYSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsQyxDQUFDLENBQUM7SUFDRixRQUFRLENBQUMsZ0JBQWdCLEdBQUcsQ0FBQyxHQUFHLEVBQUUsT0FBTyxFQUFFLEVBQUU7UUFDekMsTUFBTSxVQUFVLEdBQUcsUUFBUSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN4RCxhQUFhLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxFQUFFLEdBQUcsVUFBVSxFQUFFLEdBQUcsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUMxRCxDQUFDLENBQUM7SUFDRixPQUFPLFFBQVEsQ0FBQztBQUNwQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ib2FyZCc7XG5pbXBvcnQgeyBQbGFpdFBsdWdpbktleSB9IGZyb20gJy4uL2ludGVyZmFjZXMvcGx1Z2luLWtleSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRQbHVnaW5PcHRpb25zIHtcbiAgICBkaXNhYmxlZD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRPcHRpb25zQm9hcmQgZXh0ZW5kcyBQbGFpdEJvYXJkIHtcbiAgICBnZXRQbHVnaW5PcHRpb25zOiA8SyA9IFBsYWl0UGx1Z2luT3B0aW9ucz4oa2V5OiBzdHJpbmcpID0+IEs7XG4gICAgc2V0UGx1Z2luT3B0aW9uczogPEsgPSBQbGFpdFBsdWdpbk9wdGlvbnM+KGtleTogc3RyaW5nLCB2YWx1ZTogSykgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGNvbnN0IHdpdGhPcHRpb25zID0gKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB7XG4gICAgY29uc3QgcGx1Z2luT3B0aW9ucyA9IG5ldyBNYXA8c3RyaW5nLCBhbnk+KCk7XG4gICAgY29uc3QgbmV3Qm9hcmQgPSBib2FyZCBhcyBQbGFpdE9wdGlvbnNCb2FyZDtcbiAgICBuZXdCb2FyZC5nZXRQbHVnaW5PcHRpb25zID0ga2V5ID0+IHtcbiAgICAgICAgcmV0dXJuIHBsdWdpbk9wdGlvbnMuZ2V0KGtleSk7XG4gICAgfTtcbiAgICBuZXdCb2FyZC5zZXRQbHVnaW5PcHRpb25zID0gKGtleSwgb3B0aW9ucykgPT4ge1xuICAgICAgICBjb25zdCBvbGRPcHRpb25zID0gbmV3Qm9hcmQuZ2V0UGx1Z2luT3B0aW9ucyhrZXkpIHx8IHt9O1xuICAgICAgICBwbHVnaW5PcHRpb25zLnNldChrZXksIHsgLi4ub2xkT3B0aW9ucywgLi4ub3B0aW9ucyB9KTtcbiAgICB9O1xuICAgIHJldHVybiBuZXdCb2FyZDtcbn07XG4iXX0=
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { PlaitBoard } from '../interfaces/board';
|
|
2
2
|
import { Transforms } from '../transforms';
|
|
3
3
|
import { transformPoint } from '../utils/board';
|
|
4
|
-
import { toPoint } from '../utils/dom/common';
|
|
4
|
+
import { isMainPointer, toPoint } from '../utils/dom/common';
|
|
5
5
|
import { RectangleClient } from '../interfaces/rectangle-client';
|
|
6
6
|
import { cacheSelectedElements, getHitElements, getSelectedElements, isIntersectionElements } from '../utils/selected-element';
|
|
7
7
|
import { PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';
|
|
@@ -9,6 +9,7 @@ import { getRectangleByElements } from '../utils/element';
|
|
|
9
9
|
import { BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_TEMPORARY_ELEMENTS } from '../utils/weak-maps';
|
|
10
10
|
import { ATTACHED_ELEMENT_CLASS_NAME } from '../constants/selection';
|
|
11
11
|
import { throttleRAF } from '../utils';
|
|
12
|
+
import { PlaitPluginKey } from '../interfaces/plugin-key';
|
|
12
13
|
export function withSelection(board) {
|
|
13
14
|
const { mousedown, globalMousemove, globalMouseup, onChange } = board;
|
|
14
15
|
let start = null;
|
|
@@ -17,22 +18,26 @@ export function withSelection(board) {
|
|
|
17
18
|
let selectionOuterG;
|
|
18
19
|
let previousSelectedElements;
|
|
19
20
|
board.mousedown = (event) => {
|
|
20
|
-
if (event
|
|
21
|
-
|
|
21
|
+
if (!isMainPointer(event)) {
|
|
22
|
+
mousedown(event);
|
|
23
|
+
return;
|
|
22
24
|
}
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
}
|
|
31
|
-
Transforms.setSelection(board, { ranges: ranges });
|
|
32
|
-
if (board.pointer === PlaitPointerType.hand || getHitElements(board).length) {
|
|
33
|
-
start = null;
|
|
34
|
-
}
|
|
25
|
+
const options = board.getPluginOptions(PlaitPluginKey.withSelection);
|
|
26
|
+
const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
27
|
+
const ranges = [{ anchor: point, focus: point }];
|
|
28
|
+
const selectedElements = getSelectedElements(board);
|
|
29
|
+
if (isIntersectionElements(board, selectedElements, ranges)) {
|
|
30
|
+
mousedown(event);
|
|
31
|
+
return;
|
|
35
32
|
}
|
|
33
|
+
const range = { anchor: point, focus: point };
|
|
34
|
+
if (PlaitBoard.isPointer(board, PlaitPointerType.selection) &&
|
|
35
|
+
PlaitBoard.isFocus(board) &&
|
|
36
|
+
getHitElements(board, { ranges: [range] }).length === 0 &&
|
|
37
|
+
options.isMultiple) {
|
|
38
|
+
start = point;
|
|
39
|
+
}
|
|
40
|
+
Transforms.setSelection(board, { ranges: ranges });
|
|
36
41
|
mousedown(event);
|
|
37
42
|
};
|
|
38
43
|
board.globalMousemove = (event) => {
|
|
@@ -87,7 +92,11 @@ export function withSelection(board) {
|
|
|
87
92
|
if (board.operations.find(value => value.type === 'set_selection')) {
|
|
88
93
|
selectionOuterG?.remove();
|
|
89
94
|
const temporaryElements = getTemporaryElements(board);
|
|
90
|
-
|
|
95
|
+
let elements = temporaryElements ? temporaryElements : getHitElements(board);
|
|
96
|
+
const options = board.getPluginOptions(PlaitPluginKey.withSelection);
|
|
97
|
+
if (!options.isMultiple && elements.length > 1) {
|
|
98
|
+
elements = [elements[0]];
|
|
99
|
+
}
|
|
91
100
|
cacheSelectedElements(board, elements);
|
|
92
101
|
previousSelectedElements = elements;
|
|
93
102
|
const { width, height } = getRectangleByElements(board, elements, false);
|
|
@@ -123,6 +132,7 @@ export function withSelection(board) {
|
|
|
123
132
|
}
|
|
124
133
|
onChange();
|
|
125
134
|
};
|
|
135
|
+
board.setPluginOptions(PlaitPluginKey.withSelection, { isMultiple: true });
|
|
126
136
|
return board;
|
|
127
137
|
}
|
|
128
138
|
export function getTemporaryElements(board) {
|
|
@@ -151,4 +161,4 @@ export function createSelectionOuterG(board, selectElements) {
|
|
|
151
161
|
fillStyle: 'solid'
|
|
152
162
|
});
|
|
153
163
|
}
|
|
154
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-selection.js","sourceRoot":"","sources":["../../../../packages/plait/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 { transformPoint } from '../utils/board';\nimport { toPoint } from '../utils/dom/common';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport {\n    cacheSelectedElements,\n    getHitElements,\n    getSelectedElements,\n    isIntersectionElements\n} from '../utils/selected-element';\nimport { PlaitElement, PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, Selection } from '../interfaces';\nimport { getRectangleByElements } from '../utils/element';\nimport { BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_TEMPORARY_ELEMENTS } from '../utils/weak-maps';\nimport { ATTACHED_ELEMENT_CLASS_NAME } from '../constants/selection';\nimport { throttleRAF } from '../utils';\n\nexport function withSelection(board: PlaitBoard) {\n    const { mousedown, globalMousemove, globalMouseup, onChange } = board;\n\n    let start: Point | null = null;\n    let end: Point | null = null;\n    let selectionMovingG: SVGGElement;\n    let selectionOuterG: SVGGElement;\n    let previousSelectedElements: PlaitElement[];\n\n    board.mousedown = (event: MouseEvent) => {\n        if (event.button === 0) {\n            start = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        }\n\n        if (start) {\n            const ranges = [{ anchor: start, focus: start }];\n            const selectedElements = getSelectedElements(board);\n\n            if (isIntersectionElements(board, selectedElements, ranges)) {\n                start = null;\n                mousedown(event);\n                return;\n            }\n\n            Transforms.setSelection(board, { ranges: ranges });\n\n            if (board.pointer === PlaitPointerType.hand || getHitElements(board).length) {\n                start = null;\n            }\n        }\n\n        mousedown(event);\n    };\n\n    board.globalMousemove = (event: MouseEvent) => {\n        if (start) {\n            const movedTarget = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const { x, y, width, height } = RectangleClient.toRectangleClient([start, movedTarget]);\n            selectionMovingG?.remove();\n            if (Math.hypot(width, height) > 5) {\n                end = movedTarget;\n                throttleRAF(() => {\n                    if (start && end) {\n                        Transforms.setSelection(board, { ranges: [{ anchor: start, focus: end }] });\n                    }\n                });\n                setSelectionMoving(board);\n                const rough = PlaitBoard.getRoughSVG(board);\n                selectionMovingG = rough.rectangle(x, y, width, height, {\n                    stroke: SELECTION_BORDER_COLOR,\n                    strokeWidth: 1,\n                    fill: SELECTION_FILL_COLOR,\n                    fillStyle: 'solid'\n                });\n                PlaitBoard.getHost(board).append(selectionMovingG);\n            }\n        }\n        globalMousemove(event);\n    };\n\n    board.globalMouseup = (event: MouseEvent) => {\n        if (start && end) {\n            selectionMovingG?.remove();\n            clearSelectionMoving(board);\n            Transforms.setSelection(board, { ranges: [{ anchor: start, focus: end }] });\n        }\n\n        if (PlaitBoard.isFocus(board)) {\n            const isInBoard = event.target instanceof Node && PlaitBoard.getBoardNativeElement(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\n        start = null;\n        end = null;\n        globalMouseup(event);\n    };\n\n    board.onChange = () => {\n        // calc selected elements entry\n        if (board.pointer !== PlaitPointerType.hand) {\n            try {\n                if (board.operations.find(value => value.type === 'set_selection')) {\n                    selectionOuterG?.remove();\n                    const temporaryElements = getTemporaryElements(board);\n                    const elements = temporaryElements ? temporaryElements : getHitElements(board);\n                    cacheSelectedElements(board, elements);\n                    previousSelectedElements = elements;\n                    const { width, height } = getRectangleByElements(board, elements, false);\n                    if (width > 0 && height > 0 && elements.length > 1) {\n                        selectionOuterG = createSelectionOuterG(board, elements);\n                        selectionOuterG.classList.add('selection-outer');\n                        PlaitBoard.getHost(board).append(selectionOuterG);\n                    }\n                    deleteTemporaryElements(board);\n                } else {\n                    // wait node destroy and remove selected element state\n                    setTimeout(() => {\n                        const currentSelectedElements = getSelectedElements(board);\n                        if (currentSelectedElements.length && currentSelectedElements.length > 1) {\n                            const selectedElementChange = currentSelectedElements.some(item => !previousSelectedElements.includes(item));\n                            if (selectedElementChange) {\n                                selectionOuterG?.remove();\n                                selectionOuterG = createSelectionOuterG(board, currentSelectedElements);\n                                selectionOuterG.classList.add('selection-outer');\n                                PlaitBoard.getHost(board).append(selectionOuterG);\n                            }\n                        } else {\n                            selectionOuterG?.remove();\n                        }\n                    });\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        onChange();\n    };\n\n    return board;\n}\n\nexport function getTemporaryElements(board: PlaitBoard) {\n    return BOARD_TO_TEMPORARY_ELEMENTS.get(board);\n}\n\nexport function deleteTemporaryElements(board: PlaitBoard) {\n    BOARD_TO_TEMPORARY_ELEMENTS.delete(board);\n}\n\nexport function isSelectionMoving(board: PlaitBoard) {\n    return !!BOARD_TO_IS_SELECTION_MOVING.get(board);\n}\n\nexport function setSelectionMoving(board: PlaitBoard) {\n    PlaitBoard.getBoardNativeElement(board).classList.add('selection-moving');\n    BOARD_TO_IS_SELECTION_MOVING.set(board, true);\n}\n\nexport function clearSelectionMoving(board: PlaitBoard) {\n    PlaitBoard.getBoardNativeElement(board).classList.remove('selection-moving');\n    BOARD_TO_IS_SELECTION_MOVING.delete(board);\n}\n\nexport function createSelectionOuterG(board: PlaitBoard, selectElements: PlaitElement[]) {\n    const { x, y, width, height } = getRectangleByElements(board, selectElements, false);\n    const rough = PlaitBoard.getRoughSVG(board);\n    return rough.rectangle(x - 2.5, y - 2.5, width + 5, height + 5, {\n        stroke: SELECTION_BORDER_COLOR,\n        strokeWidth: 1,\n        fillStyle: 'solid'\n    });\n}\n"]}
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-selection.js","sourceRoot":"","sources":["../../../../packages/plait/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 { transformPoint } from '../utils/board';\nimport { isMainPointer, toPoint } from '../utils/dom/common';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport { cacheSelectedElements, getHitElements, getSelectedElements, isIntersectionElements } from '../utils/selected-element';\nimport { PlaitElement, PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, Selection } from '../interfaces';\nimport { getRectangleByElements } from '../utils/element';\nimport { BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_TEMPORARY_ELEMENTS } from '../utils/weak-maps';\nimport { ATTACHED_ELEMENT_CLASS_NAME } from '../constants/selection';\nimport { throttleRAF } from '../utils';\nimport { PlaitOptionsBoard, PlaitPluginOptions } from './with-options';\nimport { PlaitPluginKey } from '../interfaces/plugin-key';\n\nexport interface WithPluginOptions extends PlaitPluginOptions {\n    isMultiple: boolean;\n}\n\nexport function withSelection(board: PlaitBoard) {\n    const { mousedown, globalMousemove, globalMouseup, onChange } = board;\n\n    let start: Point | null = null;\n    let end: Point | null = null;\n    let selectionMovingG: SVGGElement;\n    let selectionOuterG: SVGGElement;\n    let previousSelectedElements: PlaitElement[];\n\n    board.mousedown = (event: MouseEvent) => {\n        if (!isMainPointer(event)) {\n            mousedown(event);\n            return;\n        }\n\n        const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n\n        const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const ranges = [{ anchor: point, focus: point }];\n        const selectedElements = getSelectedElements(board);\n        if (isIntersectionElements(board, selectedElements, ranges)) {\n            mousedown(event);\n            return;\n        }\n\n        const range = { anchor: point, focus: point };\n        if (\n            PlaitBoard.isPointer(board, PlaitPointerType.selection) &&\n            PlaitBoard.isFocus(board) &&\n            getHitElements(board, { ranges: [range] }).length === 0 &&\n            options.isMultiple\n        ) {\n            start = point;\n        }\n\n        Transforms.setSelection(board, { ranges: ranges });\n\n        mousedown(event);\n    };\n\n    board.globalMousemove = (event: MouseEvent) => {\n        if (start) {\n            const movedTarget = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const { x, y, width, height } = RectangleClient.toRectangleClient([start, movedTarget]);\n            selectionMovingG?.remove();\n            if (Math.hypot(width, height) > 5) {\n                end = movedTarget;\n                throttleRAF(() => {\n                    if (start && end) {\n                        Transforms.setSelection(board, { ranges: [{ anchor: start, focus: end }] });\n                    }\n                });\n                setSelectionMoving(board);\n                const rough = PlaitBoard.getRoughSVG(board);\n                selectionMovingG = rough.rectangle(x, y, width, height, {\n                    stroke: SELECTION_BORDER_COLOR,\n                    strokeWidth: 1,\n                    fill: SELECTION_FILL_COLOR,\n                    fillStyle: 'solid'\n                });\n                PlaitBoard.getHost(board).append(selectionMovingG);\n            }\n        }\n        globalMousemove(event);\n    };\n\n    board.globalMouseup = (event: MouseEvent) => {\n        if (start && end) {\n            selectionMovingG?.remove();\n            clearSelectionMoving(board);\n            Transforms.setSelection(board, { ranges: [{ anchor: start, focus: end }] });\n        }\n\n        if (PlaitBoard.isFocus(board)) {\n            const isInBoard = event.target instanceof Node && PlaitBoard.getBoardNativeElement(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\n        start = null;\n        end = null;\n        globalMouseup(event);\n    };\n\n    board.onChange = () => {\n        // calc selected elements entry\n        if (board.pointer !== PlaitPointerType.hand) {\n            try {\n                if (board.operations.find(value => value.type === 'set_selection')) {\n                    selectionOuterG?.remove();\n                    const temporaryElements = getTemporaryElements(board);\n                    let elements = temporaryElements ? temporaryElements : getHitElements(board);\n\n                    const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n\n                    if (!options.isMultiple && elements.length > 1) {\n                        elements = [elements[0]];\n                    }\n                    cacheSelectedElements(board, elements);\n                    previousSelectedElements = elements;\n                    const { width, height } = getRectangleByElements(board, elements, false);\n                    if (width > 0 && height > 0 && elements.length > 1) {\n                        selectionOuterG = createSelectionOuterG(board, elements);\n                        selectionOuterG.classList.add('selection-outer');\n                        PlaitBoard.getHost(board).append(selectionOuterG);\n                    }\n                    deleteTemporaryElements(board);\n                } else {\n                    // wait node destroy and remove selected element state\n                    setTimeout(() => {\n                        const currentSelectedElements = getSelectedElements(board);\n                        if (currentSelectedElements.length && currentSelectedElements.length > 1) {\n                            const selectedElementChange = currentSelectedElements.some(item => !previousSelectedElements.includes(item));\n                            if (selectedElementChange) {\n                                selectionOuterG?.remove();\n                                selectionOuterG = createSelectionOuterG(board, currentSelectedElements);\n                                selectionOuterG.classList.add('selection-outer');\n                                PlaitBoard.getHost(board).append(selectionOuterG);\n                            }\n                        } else {\n                            selectionOuterG?.remove();\n                        }\n                    });\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        onChange();\n    };\n\n    (board as PlaitOptionsBoard).setPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection, { isMultiple: true });\n\n    return board;\n}\n\nexport function getTemporaryElements(board: PlaitBoard) {\n    return BOARD_TO_TEMPORARY_ELEMENTS.get(board);\n}\n\nexport function deleteTemporaryElements(board: PlaitBoard) {\n    BOARD_TO_TEMPORARY_ELEMENTS.delete(board);\n}\n\nexport function isSelectionMoving(board: PlaitBoard) {\n    return !!BOARD_TO_IS_SELECTION_MOVING.get(board);\n}\n\nexport function setSelectionMoving(board: PlaitBoard) {\n    PlaitBoard.getBoardNativeElement(board).classList.add('selection-moving');\n    BOARD_TO_IS_SELECTION_MOVING.set(board, true);\n}\n\nexport function clearSelectionMoving(board: PlaitBoard) {\n    PlaitBoard.getBoardNativeElement(board).classList.remove('selection-moving');\n    BOARD_TO_IS_SELECTION_MOVING.delete(board);\n}\n\nexport function createSelectionOuterG(board: PlaitBoard, selectElements: PlaitElement[]) {\n    const { x, y, width, height } = getRectangleByElements(board, selectElements, false);\n    const rough = PlaitBoard.getRoughSVG(board);\n    return rough.rectangle(x - 2.5, y - 2.5, width + 5, height + 5, {\n        stroke: SELECTION_BORDER_COLOR,\n        strokeWidth: 1,\n        fillStyle: 'solid'\n    });\n}\n"]}
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -7,11 +7,13 @@ export * from './core/element/plugin-element';
|
|
|
7
7
|
export * from './core/element/element.component';
|
|
8
8
|
export * from './core/children/children.component';
|
|
9
9
|
export * from './core/element/context-change';
|
|
10
|
-
export * from './core/
|
|
10
|
+
export * from './core/island/island-base.component';
|
|
11
11
|
export * from './interfaces';
|
|
12
12
|
export * from './plait.module';
|
|
13
13
|
export * from './transforms';
|
|
14
14
|
export * from './utils';
|
|
15
15
|
export * from './plugins/with-selection';
|
|
16
16
|
export * from './plugins/with-moving';
|
|
17
|
-
|
|
17
|
+
export * from './plugins/with-options';
|
|
18
|
+
export * from './testing';
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLFdBQVcsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgcGxhaXRcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2JvYXJkL2JvYXJkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbnN0YW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2NvcmUvZWxlbWVudC9wbHVnaW4tZWxlbWVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvcmUvZWxlbWVudC9lbGVtZW50LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvcmUvY2hpbGRyZW4vY2hpbGRyZW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29yZS9lbGVtZW50L2NvbnRleHQtY2hhbmdlJztcbmV4cG9ydCAqIGZyb20gJy4vY29yZS9pc2xhbmQvaXNsYW5kLWJhc2UuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL3BsYWl0Lm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3RyYW5zZm9ybXMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL3BsdWdpbnMvd2l0aC1zZWxlY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9wbHVnaW5zL3dpdGgtbW92aW5nJztcbmV4cG9ydCAqIGZyb20gJy4vcGx1Z2lucy93aXRoLW9wdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXN0aW5nJztcbiJdfQ==
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { createBoard } from '../../plugins/create-board';
|
|
2
|
+
/**
|
|
3
|
+
* 1.create board instance
|
|
4
|
+
* 2.build fake node weak map
|
|
5
|
+
*/
|
|
6
|
+
export const createTestingBoard = (plugins, children, options = { readonly: false, hideScrollbar: true }) => {
|
|
7
|
+
let board = createBoard(children, options);
|
|
8
|
+
plugins.forEach(plugin => {
|
|
9
|
+
board = plugin(board);
|
|
10
|
+
});
|
|
11
|
+
return board;
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWJvYXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3Rlc3RpbmcvY29yZS9jcmVhdGUtYm9hcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBRXpEOzs7R0FHRztBQUNILE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLENBQzlCLE9BQXNCLEVBQ3RCLFFBQXdCLEVBQ3hCLFVBQTZCLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxhQUFhLEVBQUUsSUFBSSxFQUFFLEVBQ3ZFLEVBQUU7SUFDQSxJQUFJLEtBQUssR0FBRyxXQUFXLENBQUMsUUFBUSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzNDLE9BQU8sQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEVBQUU7UUFDckIsS0FBSyxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMxQixDQUFDLENBQUMsQ0FBQztJQUNILE9BQU8sS0FBSyxDQUFDO0FBQ2pCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Qm9hcmRPcHRpb25zLCBQbGFpdEVsZW1lbnQsIFBsYWl0UGx1Z2luIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBjcmVhdGVCb2FyZCB9IGZyb20gJy4uLy4uL3BsdWdpbnMvY3JlYXRlLWJvYXJkJztcblxuLyoqXG4gKiAxLmNyZWF0ZSBib2FyZCBpbnN0YW5jZVxuICogMi5idWlsZCBmYWtlIG5vZGUgd2VhayBtYXBcbiAqL1xuZXhwb3J0IGNvbnN0IGNyZWF0ZVRlc3RpbmdCb2FyZCA9IChcbiAgICBwbHVnaW5zOiBQbGFpdFBsdWdpbltdLFxuICAgIGNoaWxkcmVuOiBQbGFpdEVsZW1lbnRbXSxcbiAgICBvcHRpb25zOiBQbGFpdEJvYXJkT3B0aW9ucyA9IHsgcmVhZG9ubHk6IGZhbHNlLCBoaWRlU2Nyb2xsYmFyOiB0cnVlIH1cbikgPT4ge1xuICAgIGxldCBib2FyZCA9IGNyZWF0ZUJvYXJkKGNoaWxkcmVuLCBvcHRpb25zKTtcbiAgICBwbHVnaW5zLmZvckVhY2gocGx1Z2luID0+IHtcbiAgICAgICAgYm9hcmQgPSBwbHVnaW4oYm9hcmQpO1xuICAgIH0pO1xuICAgIHJldHVybiBib2FyZDtcbn07XG4iXX0=
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { NODE_TO_INDEX, NODE_TO_PARENT } from "../../utils/weak-maps";
|
|
2
|
+
export const fakeNodeWeakMap = (object) => {
|
|
3
|
+
const children = object.children || [];
|
|
4
|
+
children.forEach((value, index) => {
|
|
5
|
+
NODE_TO_PARENT.set(value, object);
|
|
6
|
+
NODE_TO_INDEX.set(value, index);
|
|
7
|
+
fakeNodeWeakMap(value);
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
export const clearNodeWeakMap = (object) => {
|
|
11
|
+
const children = object.children || [];
|
|
12
|
+
children.forEach(value => {
|
|
13
|
+
NODE_TO_PARENT.delete(value);
|
|
14
|
+
NODE_TO_INDEX.delete(value);
|
|
15
|
+
clearNodeWeakMap(value);
|
|
16
|
+
});
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFrZS13ZWFrLW1hcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYWl0L3NyYy90ZXN0aW5nL2NvcmUvZmFrZS13ZWFrLW1hcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRXRFLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxDQUFDLE1BQThCLEVBQUUsRUFBRTtJQUM5RCxNQUFNLFFBQVEsR0FBRyxNQUFNLENBQUMsUUFBUSxJQUFJLEVBQUUsQ0FBQztJQUN2QyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLEtBQWEsRUFBRSxFQUFFO1FBQ3RDLGNBQWMsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ2xDLGFBQWEsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ2hDLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMzQixDQUFDLENBQUMsQ0FBQztBQUNQLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLENBQUMsTUFBOEIsRUFBRSxFQUFFO0lBQy9ELE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLElBQUksRUFBRSxDQUFDO0lBQ3ZDLFFBQVEsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUU7UUFDckIsY0FBYyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM3QixhQUFhLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzVCLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzVCLENBQUMsQ0FBQyxDQUFDO0FBQ1AsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gXCIuLi8uLi9pbnRlcmZhY2VzL2JvYXJkXCI7XG5pbXBvcnQgeyBQbGFpdE5vZGUgfSBmcm9tIFwiLi4vLi4vaW50ZXJmYWNlcy9ub2RlXCI7XG5pbXBvcnQgeyBOT0RFX1RPX0lOREVYLCBOT0RFX1RPX1BBUkVOVCB9IGZyb20gXCIuLi8uLi91dGlscy93ZWFrLW1hcHNcIjtcblxuZXhwb3J0IGNvbnN0IGZha2VOb2RlV2Vha01hcCA9IChvYmplY3Q6IFBsYWl0Tm9kZSB8IFBsYWl0Qm9hcmQpID0+IHtcbiAgICBjb25zdCBjaGlsZHJlbiA9IG9iamVjdC5jaGlsZHJlbiB8fCBbXTtcbiAgICBjaGlsZHJlbi5mb3JFYWNoKCh2YWx1ZSwgaW5kZXg6IG51bWJlcikgPT4ge1xuICAgICAgICBOT0RFX1RPX1BBUkVOVC5zZXQodmFsdWUsIG9iamVjdCk7XG4gICAgICAgIE5PREVfVE9fSU5ERVguc2V0KHZhbHVlLCBpbmRleCk7XG4gICAgICAgIGZha2VOb2RlV2Vha01hcCh2YWx1ZSk7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgY2xlYXJOb2RlV2Vha01hcCA9IChvYmplY3Q6IFBsYWl0Tm9kZSB8IFBsYWl0Qm9hcmQpID0+IHtcbiAgICBjb25zdCBjaGlsZHJlbiA9IG9iamVjdC5jaGlsZHJlbiB8fCBbXTtcbiAgICBjaGlsZHJlbi5mb3JFYWNoKHZhbHVlID0+IHtcbiAgICAgICAgTk9ERV9UT19QQVJFTlQuZGVsZXRlKHZhbHVlKTtcbiAgICAgICAgTk9ERV9UT19JTkRFWC5kZWxldGUodmFsdWUpO1xuICAgICAgICBjbGVhck5vZGVXZWFrTWFwKHZhbHVlKTtcbiAgICB9KTtcbn07XG4iXX0=
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './create-board';
|
|
2
|
+
export * from './fake-weak-map';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvdGVzdGluZy9jb3JlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY3JlYXRlLWJvYXJkJztcbmV4cG9ydCAqIGZyb20gJy4vZmFrZS13ZWFrLW1hcCc7Il19
|