@plait/core 0.77.3 → 0.78.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/fesm2022/plait-core.mjs.map +1 -1
- package/package.json +1 -3
- package/esm2022/constants/cursor.mjs +0 -13
- package/esm2022/constants/index.mjs +0 -20
- package/esm2022/constants/keycodes.mjs +0 -127
- package/esm2022/constants/selection.mjs +0 -6
- package/esm2022/constants/zoom.mjs +0 -4
- package/esm2022/context.mjs +0 -23
- package/esm2022/core/element/context-change.mjs +0 -13
- package/esm2022/core/element/context.mjs +0 -2
- package/esm2022/core/element/element-flavour.mjs +0 -140
- package/esm2022/core/element/element-ref.mjs +0 -2
- package/esm2022/core/list-render.mjs +0 -217
- package/esm2022/differs/default_iterable_differ.mjs +0 -614
- package/esm2022/differs/iterable_differs.mjs +0 -9
- package/esm2022/interfaces/board.mjs +0 -108
- package/esm2022/interfaces/custom-types.mjs +0 -5
- package/esm2022/interfaces/direction.mjs +0 -8
- package/esm2022/interfaces/element.mjs +0 -43
- package/esm2022/interfaces/group.mjs +0 -6
- package/esm2022/interfaces/history.mjs +0 -5
- package/esm2022/interfaces/index.mjs +0 -19
- package/esm2022/interfaces/node.mjs +0 -57
- package/esm2022/interfaces/operation.mjs +0 -96
- package/esm2022/interfaces/path-ref.mjs +0 -15
- package/esm2022/interfaces/path.mjs +0 -183
- package/esm2022/interfaces/plugin.mjs +0 -6
- package/esm2022/interfaces/point.mjs +0 -27
- package/esm2022/interfaces/pointer.mjs +0 -6
- package/esm2022/interfaces/rectangle-client.mjs +0 -171
- package/esm2022/interfaces/selection.mjs +0 -13
- package/esm2022/interfaces/svg-arc-command.mjs +0 -2
- package/esm2022/interfaces/theme.mjs +0 -49
- package/esm2022/interfaces/viewport.mjs +0 -7
- package/esm2022/plait-core.mjs +0 -5
- package/esm2022/plugins/create-board.mjs +0 -122
- package/esm2022/plugins/index.mjs +0 -11
- package/esm2022/plugins/with-board.mjs +0 -20
- package/esm2022/plugins/with-hand.mjs +0 -113
- package/esm2022/plugins/with-history.mjs +0 -91
- package/esm2022/plugins/with-hotkey.mjs +0 -96
- package/esm2022/plugins/with-i18n.mjs +0 -13
- package/esm2022/plugins/with-moving.mjs +0 -282
- package/esm2022/plugins/with-options.mjs +0 -13
- package/esm2022/plugins/with-related-fragment.mjs +0 -23
- package/esm2022/plugins/with-selection.mjs +0 -230
- package/esm2022/public-api.mjs +0 -16
- package/esm2022/testing/core/create-board.mjs +0 -15
- package/esm2022/testing/core/fake-weak-map.mjs +0 -18
- package/esm2022/testing/core/index.mjs +0 -3
- package/esm2022/testing/fake-events/event-objects.mjs +0 -131
- package/esm2022/testing/fake-events/index.mjs +0 -2
- package/esm2022/testing/index.mjs +0 -3
- package/esm2022/testing/test-element.mjs +0 -9
- package/esm2022/transforms/board.mjs +0 -137
- package/esm2022/transforms/element.mjs +0 -22
- package/esm2022/transforms/general.mjs +0 -146
- package/esm2022/transforms/group.mjs +0 -64
- package/esm2022/transforms/index.mjs +0 -17
- package/esm2022/transforms/node.mjs +0 -37
- package/esm2022/transforms/selection.mjs +0 -26
- package/esm2022/transforms/theme.mjs +0 -8
- package/esm2022/transforms/viewport.mjs +0 -8
- package/esm2022/transforms/z-index.mjs +0 -20
- package/esm2022/utils/angle.mjs +0 -164
- package/esm2022/utils/board.mjs +0 -18
- package/esm2022/utils/clipboard/clipboard.mjs +0 -40
- package/esm2022/utils/clipboard/common.mjs +0 -82
- package/esm2022/utils/clipboard/data-transfer.mjs +0 -33
- package/esm2022/utils/clipboard/index.mjs +0 -3
- package/esm2022/utils/clipboard/navigator-clipboard.mjs +0 -71
- package/esm2022/utils/clipboard/types.mjs +0 -13
- package/esm2022/utils/common.mjs +0 -79
- package/esm2022/utils/debug.mjs +0 -91
- package/esm2022/utils/dnd.mjs +0 -8
- package/esm2022/utils/dom/common.mjs +0 -75
- package/esm2022/utils/dom/environment.mjs +0 -2
- package/esm2022/utils/dom/foreign.mjs +0 -26
- package/esm2022/utils/dom/index.mjs +0 -4
- package/esm2022/utils/drawing/arrow.mjs +0 -23
- package/esm2022/utils/drawing/circle.mjs +0 -4
- package/esm2022/utils/drawing/line.mjs +0 -47
- package/esm2022/utils/drawing/rectangle.mjs +0 -36
- package/esm2022/utils/element.mjs +0 -90
- package/esm2022/utils/environment.mjs +0 -14
- package/esm2022/utils/fragment.mjs +0 -27
- package/esm2022/utils/group.mjs +0 -239
- package/esm2022/utils/helper.mjs +0 -68
- package/esm2022/utils/history.mjs +0 -96
- package/esm2022/utils/hotkeys.mjs +0 -109
- package/esm2022/utils/id-creator.mjs +0 -11
- package/esm2022/utils/index.mjs +0 -35
- package/esm2022/utils/iterable.mjs +0 -32
- package/esm2022/utils/math.mjs +0 -480
- package/esm2022/utils/mobile.mjs +0 -6
- package/esm2022/utils/moving-element.mjs +0 -17
- package/esm2022/utils/pointer.mjs +0 -13
- package/esm2022/utils/position.mjs +0 -9
- package/esm2022/utils/selected-element.mjs +0 -145
- package/esm2022/utils/selection.mjs +0 -151
- package/esm2022/utils/snap/snap-moving.mjs +0 -199
- package/esm2022/utils/snap/snap.mjs +0 -211
- package/esm2022/utils/to-image.mjs +0 -204
- package/esm2022/utils/to-point.mjs +0 -74
- package/esm2022/utils/tree.mjs +0 -22
- package/esm2022/utils/viewport.mjs +0 -227
- package/esm2022/utils/weak-maps.mjs +0 -27
- package/esm2022/utils/z-index.mjs +0 -166
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
export {};
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iterable_differs.js","sourceRoot":"","sources":["../../../../packages/core/src/differs/iterable_differs.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * A type describing supported iterable types.\n *\n * @publicApi\n */\nexport type CustomIterable<T> = Array<T>|Iterable<T>;\n\n/**\n * A strategy for tracking changes over time to an iterable. Used by {@link NgForOf} to\n * respond to changes in an iterable by effecting equivalent changes in the DOM.\n *\n * @publicApi\n */\nexport interface IterableDiffer<V> {\n  /**\n   * Compute a difference between the previous state and the new `object` state.\n   *\n   * @param object containing the new value.\n   * @returns an object describing the difference. The return value is only valid until the next\n   * `diff()` invocation.\n   */\n  diff(object: CustomIterable<V>|undefined|null): IterableChanges<V>|null;\n}\n\n/**\n * An object describing the changes in the `Iterable` collection since last time\n * `IterableDiffer#diff()` was invoked.\n *\n * @publicApi\n */\nexport interface IterableChanges<V> {\n  /**\n   * Iterate over all changes. `IterableChangeRecord` will contain information about changes\n   * to each item.\n   */\n  forEachItem(fn: (record: IterableChangeRecord<V>) => void): void;\n\n  /**\n   * Iterate over a set of operations which when applied to the original `Iterable` will produce the\n   * new `Iterable`.\n   *\n   * NOTE: These are not necessarily the actual operations which were applied to the original\n   * `Iterable`, rather these are a set of computed operations which may not be the same as the\n   * ones applied.\n   *\n   * @param record A change which needs to be applied\n   * @param previousIndex The `IterableChangeRecord#previousIndex` of the `record` refers to the\n   *        original `Iterable` location, where as `previousIndex` refers to the transient location\n   *        of the item, after applying the operations up to this point.\n   * @param currentIndex The `IterableChangeRecord#currentIndex` of the `record` refers to the\n   *        original `Iterable` location, where as `currentIndex` refers to the transient location\n   *        of the item, after applying the operations up to this point.\n   */\n  forEachOperation(\n      fn:\n          (record: IterableChangeRecord<V>, previousIndex: number|null,\n           currentIndex: number|null) => void): void;\n\n  /**\n   * Iterate over changes in the order of original `Iterable` showing where the original items\n   * have moved.\n   */\n  forEachPreviousItem(fn: (record: IterableChangeRecord<V>) => void): void;\n\n  /** Iterate over all added items. */\n  forEachAddedItem(fn: (record: IterableChangeRecord<V>) => void): void;\n\n  /** Iterate over all moved items. */\n  forEachMovedItem(fn: (record: IterableChangeRecord<V>) => void): void;\n\n  /** Iterate over all removed items. */\n  forEachRemovedItem(fn: (record: IterableChangeRecord<V>) => void): void;\n\n  /**\n   * Iterate over all items which had their identity (as computed by the `TrackByFunction`)\n   * changed.\n   */\n  forEachIdentityChange(fn: (record: IterableChangeRecord<V>) => void): void;\n}\n\n/**\n * Record representing the item change information.\n *\n * @publicApi\n */\nexport interface IterableChangeRecord<V> {\n  /** Current index of the item in `Iterable` or null if removed. */\n  readonly currentIndex: number|null;\n\n  /** Previous index of the item in `Iterable` or null if added. */\n  readonly previousIndex: number|null;\n\n  /** The item. */\n  readonly item: V;\n\n  /** Track by identity as computed by the `TrackByFunction`. */\n  readonly trackById: any;\n}\n\n/**\n * A function optionally passed into the `NgForOf` directive to customize how `NgForOf` uniquely\n * identifies items in an iterable.\n *\n * `NgForOf` needs to uniquely identify items in the iterable to correctly perform DOM updates\n * when items in the iterable are reordered, new items are added, or existing items are removed.\n *\n *\n * In all of these scenarios it is usually desirable to only update the DOM elements associated\n * with the items affected by the change. This behavior is important to:\n *\n * - preserve any DOM-specific UI state (like cursor position, focus, text selection) when the\n *   iterable is modified\n * - enable animation of item addition, removal, and iterable reordering\n * - preserve the value of the `<select>` element when nested `<option>` elements are dynamically\n *   populated using `NgForOf` and the bound iterable is updated\n *\n * A common use for custom `trackBy` functions is when the model that `NgForOf` iterates over\n * contains a property with a unique identifier. For example, given a model:\n *\n * ```ts\n * class User {\n *   id: number;\n *   name: string;\n *   ...\n * }\n * ```\n * a custom `trackBy` function could look like the following:\n * ```ts\n * function userTrackBy(index, user) {\n *   return user.id;\n * }\n * ```\n *\n * A custom `trackBy` function must have several properties:\n *\n * - be [idempotent](https://en.wikipedia.org/wiki/Idempotence) (be without side effects, and always\n * return the same value for a given input)\n * - return unique value for all unique inputs\n * - be fast\n *\n * @see [`NgForOf#ngForTrackBy`](api/common/NgForOf#ngForTrackBy)\n * @publicApi\n */\nexport interface TrackByFunction<T> {\n  // Note: the type parameter `U` enables more accurate template type checking in case a trackBy\n  // function is declared using a base type of the iterated type. The `U` type gives TypeScript\n  // additional freedom to infer a narrower type for the `item` parameter type, instead of imposing\n  // the trackBy's declared item type as the inferred type for `T`.\n  // See https://github.com/angular/angular/issues/40125\n\n  /**\n   * @param index The index of the item within the iterable.\n   * @param item The item in the iterable.\n   */\n  <U extends T>(index: number, item: T&U): any;\n}\n"]}
|
|
@@ -1,108 +0,0 @@
|
|
|
1
|
-
import { BOARD_TO_CONTEXT, BOARD_TO_ELEMENT_HOST, BOARD_TO_HOST, BOARD_TO_MOVING_POINT, BOARD_TO_MOVING_POINT_IN_BOARD, BOARD_TO_ROUGH_SVG, IS_BOARD_ALIVE, IS_BOARD_CACHE, IS_TEXT_EDITABLE, NODE_TO_INDEX, NODE_TO_PARENT } from '../utils/weak-maps';
|
|
2
|
-
import { getRectangleByElements } from '../utils/element';
|
|
3
|
-
import { ThemeColors } from './theme';
|
|
4
|
-
import { distanceBetweenPointAndRectangle } from '../utils/math';
|
|
5
|
-
export const PlaitBoard = {
|
|
6
|
-
isBoard(value) {
|
|
7
|
-
const cachedIsBoard = IS_BOARD_CACHE.get(value);
|
|
8
|
-
if (cachedIsBoard !== undefined) {
|
|
9
|
-
return cachedIsBoard;
|
|
10
|
-
}
|
|
11
|
-
const isBoard = typeof value.onChange === 'function' && typeof value.apply === 'function';
|
|
12
|
-
IS_BOARD_CACHE.set(value, isBoard);
|
|
13
|
-
return isBoard;
|
|
14
|
-
},
|
|
15
|
-
isAlive(board) {
|
|
16
|
-
const isAlive = IS_BOARD_ALIVE.get(board);
|
|
17
|
-
return !!isAlive;
|
|
18
|
-
},
|
|
19
|
-
findPath(board, node) {
|
|
20
|
-
const path = [];
|
|
21
|
-
let child = node;
|
|
22
|
-
while (true) {
|
|
23
|
-
const parent = NODE_TO_PARENT.get(child);
|
|
24
|
-
if (parent == null) {
|
|
25
|
-
if (PlaitBoard.isBoard(child)) {
|
|
26
|
-
return path;
|
|
27
|
-
}
|
|
28
|
-
else {
|
|
29
|
-
break;
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
const i = NODE_TO_INDEX.get(child);
|
|
33
|
-
if (i == null) {
|
|
34
|
-
break;
|
|
35
|
-
}
|
|
36
|
-
path.unshift(i);
|
|
37
|
-
child = parent;
|
|
38
|
-
}
|
|
39
|
-
throw new Error(`Unable to find the path for Plait node: ${JSON.stringify(node)}`);
|
|
40
|
-
},
|
|
41
|
-
getHost(board) {
|
|
42
|
-
return BOARD_TO_HOST.get(board);
|
|
43
|
-
},
|
|
44
|
-
getElementLowerHost(board) {
|
|
45
|
-
return BOARD_TO_ELEMENT_HOST.get(board)?.lowerHost;
|
|
46
|
-
},
|
|
47
|
-
getElementHost(board) {
|
|
48
|
-
return BOARD_TO_ELEMENT_HOST.get(board)?.host;
|
|
49
|
-
},
|
|
50
|
-
getElementUpperHost(board) {
|
|
51
|
-
return BOARD_TO_ELEMENT_HOST.get(board)?.upperHost;
|
|
52
|
-
},
|
|
53
|
-
getElementTopHost(board) {
|
|
54
|
-
return BOARD_TO_ELEMENT_HOST.get(board)?.topHost;
|
|
55
|
-
},
|
|
56
|
-
getActiveHost(board) {
|
|
57
|
-
return BOARD_TO_ELEMENT_HOST.get(board)?.activeHost;
|
|
58
|
-
},
|
|
59
|
-
getRoughSVG(board) {
|
|
60
|
-
return BOARD_TO_ROUGH_SVG.get(board);
|
|
61
|
-
},
|
|
62
|
-
getBoardContainer(board) {
|
|
63
|
-
return BOARD_TO_ELEMENT_HOST.get(board)?.container;
|
|
64
|
-
},
|
|
65
|
-
getBoardContext(board) {
|
|
66
|
-
return BOARD_TO_CONTEXT.get(board);
|
|
67
|
-
},
|
|
68
|
-
getRectangle(board) {
|
|
69
|
-
return getRectangleByElements(board, board.children, true);
|
|
70
|
-
},
|
|
71
|
-
getViewportContainer(board) {
|
|
72
|
-
return BOARD_TO_ELEMENT_HOST.get(board)?.viewportContainer;
|
|
73
|
-
},
|
|
74
|
-
isFocus(board) {
|
|
75
|
-
return !!board.selection;
|
|
76
|
-
},
|
|
77
|
-
isReadonly(board) {
|
|
78
|
-
return board.options.readonly;
|
|
79
|
-
},
|
|
80
|
-
hasBeenTextEditing(board) {
|
|
81
|
-
return !!IS_TEXT_EDITABLE.get(board);
|
|
82
|
-
},
|
|
83
|
-
getPointer(board) {
|
|
84
|
-
return board.pointer;
|
|
85
|
-
},
|
|
86
|
-
isPointer(board, pointer) {
|
|
87
|
-
return board.pointer === pointer;
|
|
88
|
-
},
|
|
89
|
-
isInPointer(board, pointers) {
|
|
90
|
-
const point = board.pointer;
|
|
91
|
-
return pointers.includes(point);
|
|
92
|
-
},
|
|
93
|
-
getMovingPointInBoard(board) {
|
|
94
|
-
return BOARD_TO_MOVING_POINT_IN_BOARD.get(board);
|
|
95
|
-
},
|
|
96
|
-
isMovingPointInBoard(board) {
|
|
97
|
-
const point = BOARD_TO_MOVING_POINT.get(board);
|
|
98
|
-
const rect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();
|
|
99
|
-
if (point && distanceBetweenPointAndRectangle(point[0], point[1], rect) === 0) {
|
|
100
|
-
return true;
|
|
101
|
-
}
|
|
102
|
-
return false;
|
|
103
|
-
},
|
|
104
|
-
getThemeColors(board) {
|
|
105
|
-
return (board.options.themeColors || ThemeColors);
|
|
106
|
-
}
|
|
107
|
-
};
|
|
108
|
-
//# 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    drawSelectionRectangle: () => 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    normalizeElement: (context: PlaitPluginElementContext) => 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, isStrict?: boolean) => boolean;\n    isInsidePoint: (element: PlaitElement, point: Point) => boolean;\n    // the hit element is determined by the plugin\n    getOneHitElement: (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    getElementTopHost(board: PlaitBoard) {\n        return BOARD_TO_ELEMENT_HOST.get(board)?.topHost as SVGSVGElement;\n    },\n    getActiveHost(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"]}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Extendable Custom Types Interface
|
|
3
|
-
*/
|
|
4
|
-
export {};
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvaW50ZXJmYWNlcy9jdXN0b20tdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUciLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVuZGFibGUgQ3VzdG9tIFR5cGVzIEludGVyZmFjZVxuICovXG5cbnR5cGUgRXh0ZW5kYWJsZVR5cGVzID0gJ1ZpZXdwb3J0JyB8ICdTZXRWaWV3cG9ydE9wZXJhdGlvbicgfCAnU2V0U2VsZWN0aW9uT3BlcmF0aW9uJztcblxuZXhwb3J0IGludGVyZmFjZSBDdXN0b21UeXBlcyB7XG4gICAgW2tleTogc3RyaW5nXTogdW5rbm93bjtcbn1cblxuZXhwb3J0IHR5cGUgRXh0ZW5kZWRUeXBlPEsgZXh0ZW5kcyBFeHRlbmRhYmxlVHlwZXMsIEI+ID0gdW5rbm93biBleHRlbmRzIEN1c3RvbVR5cGVzW0tdID8gQiA6IEN1c3RvbVR5cGVzW0tdO1xuIl19
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
export var Direction;
|
|
2
|
-
(function (Direction) {
|
|
3
|
-
Direction["left"] = "left";
|
|
4
|
-
Direction["top"] = "top";
|
|
5
|
-
Direction["right"] = "right";
|
|
6
|
-
Direction["bottom"] = "bottom";
|
|
7
|
-
})(Direction || (Direction = {}));
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvaW50ZXJmYWNlcy9kaXJlY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksU0FLWDtBQUxELFdBQVksU0FBUztJQUNqQiwwQkFBYSxDQUFBO0lBQ2Isd0JBQVcsQ0FBQTtJQUNYLDRCQUFlLENBQUE7SUFDZiw4QkFBaUIsQ0FBQTtBQUNyQixDQUFDLEVBTFcsU0FBUyxLQUFULFNBQVMsUUFLcEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBEaXJlY3Rpb24ge1xuICAgIGxlZnQgPSAnbGVmdCcsXG4gICAgdG9wID0gJ3RvcCcsXG4gICAgcmlnaHQgPSAncmlnaHQnLFxuICAgIGJvdHRvbSA9ICdib3R0b20nXG59XG5cbmV4cG9ydCB0eXBlIFZlY3RvciA9IFtudW1iZXIsIG51bWJlcl07XG5cbmV4cG9ydCB0eXBlIERpcmVjdGlvbkZhY3RvciA9IC0xIHwgMCB8IDE7XG5cbmV4cG9ydCB0eXBlIERpcmVjdGlvbkZhY3RvcnMgPSBbRGlyZWN0aW9uRmFjdG9yLCBEaXJlY3Rpb25GYWN0b3JdO1xuIl19
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
import { ELEMENT_TO_REF, NODE_TO_CONTAINER_G, NODE_TO_G, NODE_TO_PARENT } from '../utils';
|
|
2
|
-
import { PlaitBoard } from './board';
|
|
3
|
-
export const PlaitElement = {
|
|
4
|
-
isRootElement(value) {
|
|
5
|
-
const parent = NODE_TO_PARENT.get(value);
|
|
6
|
-
if (parent && PlaitBoard.isBoard(parent)) {
|
|
7
|
-
return true;
|
|
8
|
-
}
|
|
9
|
-
else {
|
|
10
|
-
return false;
|
|
11
|
-
}
|
|
12
|
-
},
|
|
13
|
-
getElementRef(value) {
|
|
14
|
-
return ELEMENT_TO_REF.get(value);
|
|
15
|
-
},
|
|
16
|
-
getElementG(value) {
|
|
17
|
-
const g = NODE_TO_G.get(value);
|
|
18
|
-
if (!g) {
|
|
19
|
-
throw new Error(`can not resolve element g: ${JSON.stringify(value)}`);
|
|
20
|
-
}
|
|
21
|
-
return g;
|
|
22
|
-
},
|
|
23
|
-
hasMounted(element) {
|
|
24
|
-
const containerG = PlaitElement.getContainerG(element, { suppressThrow: true });
|
|
25
|
-
if (containerG) {
|
|
26
|
-
return true;
|
|
27
|
-
}
|
|
28
|
-
else {
|
|
29
|
-
return false;
|
|
30
|
-
}
|
|
31
|
-
},
|
|
32
|
-
getContainerG(value, options) {
|
|
33
|
-
const containerG = NODE_TO_CONTAINER_G.get(value) || null;
|
|
34
|
-
if (!containerG) {
|
|
35
|
-
if (options.suppressThrow) {
|
|
36
|
-
return null;
|
|
37
|
-
}
|
|
38
|
-
throw new Error('can not resolve container g');
|
|
39
|
-
}
|
|
40
|
-
return containerG;
|
|
41
|
-
}
|
|
42
|
-
};
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL2ludGVyZmFjZXMvZWxlbWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLG1CQUFtQixFQUFFLFNBQVMsRUFBRSxjQUFjLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDMUYsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQWNyQyxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUc7SUFDeEIsYUFBYSxDQUFDLEtBQW1CO1FBQzdCLE1BQU0sTUFBTSxHQUFHLGNBQWMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDekMsSUFBSSxNQUFNLElBQUksVUFBVSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQ3ZDLE9BQU8sSUFBSSxDQUFDO1FBQ2hCLENBQUM7YUFBTSxDQUFDO1lBQ0osT0FBTyxLQUFLLENBQUM7UUFDakIsQ0FBQztJQUNMLENBQUM7SUFDRCxhQUFhLENBQThDLEtBQW1CO1FBQzFFLE9BQU8sY0FBYyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQU0sQ0FBQztJQUMxQyxDQUFDO0lBQ0QsV0FBVyxDQUFDLEtBQW1CO1FBQzNCLE1BQU0sQ0FBQyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0IsSUFBSSxDQUFDLENBQUMsRUFBRSxDQUFDO1lBQ0wsTUFBTSxJQUFJLEtBQUssQ0FBQyw4QkFBOEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDM0UsQ0FBQztRQUNELE9BQU8sQ0FBQyxDQUFDO0lBQ2IsQ0FBQztJQUNELFVBQVUsQ0FBQyxPQUFxQjtRQUM1QixNQUFNLFVBQVUsR0FBRyxZQUFZLENBQUMsYUFBYSxDQUFDLE9BQU8sRUFBRSxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQ2hGLElBQUksVUFBVSxFQUFFLENBQUM7WUFDYixPQUFPLElBQUksQ0FBQztRQUNoQixDQUFDO2FBQU0sQ0FBQztZQUNKLE9BQU8sS0FBSyxDQUFDO1FBQ2pCLENBQUM7SUFDTCxDQUFDO0lBQ0QsYUFBYSxDQUNULEtBQW1CLEVBQ25CLE9BRUM7UUFFRCxNQUFNLFVBQVUsR0FBRyxtQkFBbUIsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDO1FBQzFELElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUNkLElBQUksT0FBTyxDQUFDLGFBQWEsRUFBRSxDQUFDO2dCQUN4QixPQUFPLElBQXlELENBQUM7WUFDckUsQ0FBQztZQUNELE1BQU0sSUFBSSxLQUFLLENBQUMsNkJBQTZCLENBQUMsQ0FBQztRQUNuRCxDQUFDO1FBQ0QsT0FBTyxVQUFVLENBQUM7SUFDdEIsQ0FBQztDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFTEVNRU5UX1RPX1JFRiwgTk9ERV9UT19DT05UQUlORVJfRywgTk9ERV9UT19HLCBOT0RFX1RPX1BBUkVOVCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IFBsYWl0Qm9hcmQgfSBmcm9tICcuL2JvYXJkJztcbmltcG9ydCB7IFBvaW50IH0gZnJvbSAnLi9wb2ludCc7XG5pbXBvcnQgeyBQbGFpdEVsZW1lbnRSZWYgfSBmcm9tICcuLi9jb3JlL2VsZW1lbnQvZWxlbWVudC1yZWYnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBsYWl0RWxlbWVudCB7XG4gICAgW2tleTogc3RyaW5nXTogYW55O1xuICAgIGlkOiBzdHJpbmc7XG4gICAgY2hpbGRyZW4/OiBQbGFpdEVsZW1lbnRbXTtcbiAgICBwb2ludHM/OiBQb2ludFtdO1xuICAgIHR5cGU/OiBzdHJpbmc7XG4gICAgZ3JvdXBJZD86IHN0cmluZztcbiAgICBhbmdsZT86IG51bWJlcjtcbn1cblxuZXhwb3J0IGNvbnN0IFBsYWl0RWxlbWVudCA9IHtcbiAgICBpc1Jvb3RFbGVtZW50KHZhbHVlOiBQbGFpdEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3QgcGFyZW50ID0gTk9ERV9UT19QQVJFTlQuZ2V0KHZhbHVlKTtcbiAgICAgICAgaWYgKHBhcmVudCAmJiBQbGFpdEJvYXJkLmlzQm9hcmQocGFyZW50KSkge1xuICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cbiAgICB9LFxuICAgIGdldEVsZW1lbnRSZWY8VCBleHRlbmRzIFBsYWl0RWxlbWVudFJlZiA9IFBsYWl0RWxlbWVudFJlZj4odmFsdWU6IFBsYWl0RWxlbWVudCkge1xuICAgICAgICByZXR1cm4gRUxFTUVOVF9UT19SRUYuZ2V0KHZhbHVlKSBhcyBUO1xuICAgIH0sXG4gICAgZ2V0RWxlbWVudEcodmFsdWU6IFBsYWl0RWxlbWVudCkge1xuICAgICAgICBjb25zdCBnID0gTk9ERV9UT19HLmdldCh2YWx1ZSk7XG4gICAgICAgIGlmICghZykge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBjYW4gbm90IHJlc29sdmUgZWxlbWVudCBnOiAke0pTT04uc3RyaW5naWZ5KHZhbHVlKX1gKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gZztcbiAgICB9LFxuICAgIGhhc01vdW50ZWQoZWxlbWVudDogUGxhaXRFbGVtZW50KSB7XG4gICAgICAgIGNvbnN0IGNvbnRhaW5lckcgPSBQbGFpdEVsZW1lbnQuZ2V0Q29udGFpbmVyRyhlbGVtZW50LCB7IHN1cHByZXNzVGhyb3c6IHRydWUgfSk7XG4gICAgICAgIGlmIChjb250YWluZXJHKSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuICAgIH0sXG4gICAgZ2V0Q29udGFpbmVyRzxUIGV4dGVuZHMgYm9vbGVhbj4oXG4gICAgICAgIHZhbHVlOiBQbGFpdEVsZW1lbnQsXG4gICAgICAgIG9wdGlvbnM6IHtcbiAgICAgICAgICAgIHN1cHByZXNzVGhyb3c6IFQ7XG4gICAgICAgIH1cbiAgICApOiBUIGV4dGVuZHMgdHJ1ZSA/IFNWR0dFbGVtZW50IHwgbnVsbCA6IFNWR0dFbGVtZW50IHtcbiAgICAgICAgY29uc3QgY29udGFpbmVyRyA9IE5PREVfVE9fQ09OVEFJTkVSX0cuZ2V0KHZhbHVlKSB8fCBudWxsO1xuICAgICAgICBpZiAoIWNvbnRhaW5lckcpIHtcbiAgICAgICAgICAgIGlmIChvcHRpb25zLnN1cHByZXNzVGhyb3cpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gbnVsbCBhcyBUIGV4dGVuZHMgdHJ1ZSA/IFNWR0dFbGVtZW50IHwgbnVsbCA6IFNWR0dFbGVtZW50O1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdjYW4gbm90IHJlc29sdmUgY29udGFpbmVyIGcnKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY29udGFpbmVyRztcbiAgICB9XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbXBvbmVudFR5cGU8VD4ge1xuICAgIG5ldyAoLi4uYXJnczogYW55W10pOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEltYWdlRW50cnkge1xuICAgIHVybDogc3RyaW5nO1xuICAgIGZpbGU6IEZpbGU7XG59XG4iXX0=
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
export const PlaitGroupElement = {
|
|
2
|
-
isGroup: (value) => {
|
|
3
|
-
return value.type === 'group';
|
|
4
|
-
}
|
|
5
|
-
};
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy9pbnRlcmZhY2VzL2dyb3VwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1BLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHO0lBQzdCLE9BQU8sRUFBRSxDQUFDLEtBQVUsRUFBdUIsRUFBRTtRQUN6QyxPQUFPLEtBQUssQ0FBQyxJQUFJLEtBQUssT0FBTyxDQUFDO0lBQ2xDLENBQUM7Q0FDSixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRFbGVtZW50IH0gZnJvbSBcIi4vZWxlbWVudFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBsYWl0R3JvdXAgZXh0ZW5kcyBQbGFpdEVsZW1lbnQge1xuICAgIHR5cGU6ICdncm91cCc7XG59XG5cbmV4cG9ydCBjb25zdCBQbGFpdEdyb3VwRWxlbWVudCA9IHtcbiAgICBpc0dyb3VwOiAodmFsdWU6IGFueSk6IHZhbHVlIGlzIFBsYWl0R3JvdXAgPT4ge1xuICAgICAgICByZXR1cm4gdmFsdWUudHlwZSA9PT0gJ2dyb3VwJztcbiAgICB9XG59Il19
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
export const SAVING = new WeakMap();
|
|
2
|
-
export const MERGING = new WeakMap();
|
|
3
|
-
export const HISTORY = new WeakMap();
|
|
4
|
-
export const SPLITTING_ONCE = new WeakMap();
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGlzdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL2ludGVyZmFjZXMvaGlzdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRQSxNQUFNLENBQUMsTUFBTSxNQUFNLEdBQUcsSUFBSSxPQUFPLEVBQW1DLENBQUM7QUFDckUsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLElBQUksT0FBTyxFQUFtQyxDQUFDO0FBQ3RFLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxJQUFJLE9BQU8sRUFBdUIsQ0FBQztBQUMxRCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsSUFBSSxPQUFPLEVBQW1DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnLi9ib2FyZCc7XG5pbXBvcnQgeyBQbGFpdE9wZXJhdGlvbiB9IGZyb20gJy4vb3BlcmF0aW9uJztcblxuZXhwb3J0IGludGVyZmFjZSBQbGFpdEhpc3Rvcnkge1xuICAgIHJlZG9zOiBQbGFpdE9wZXJhdGlvbltdW107XG4gICAgdW5kb3M6IFBsYWl0T3BlcmF0aW9uW11bXTtcbn1cblxuZXhwb3J0IGNvbnN0IFNBVklORyA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIGJvb2xlYW4gfCB1bmRlZmluZWQ+KCk7XG5leHBvcnQgY29uc3QgTUVSR0lORyA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIGJvb2xlYW4gfCB1bmRlZmluZWQ+KCk7XG5leHBvcnQgY29uc3QgSElTVE9SWSA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIEhpc3Rvcnk+KCk7XG5leHBvcnQgY29uc3QgU1BMSVRUSU5HX09OQ0UgPSBuZXcgV2Vha01hcDxQbGFpdEJvYXJkLCBib29sZWFuIHwgdW5kZWZpbmVkPigpO1xuIl19
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
export * from './board';
|
|
2
|
-
export * from './pointer';
|
|
3
|
-
export * from '../core/element/context';
|
|
4
|
-
export * from './custom-types';
|
|
5
|
-
export * from './element';
|
|
6
|
-
export * from './rectangle-client';
|
|
7
|
-
export * from './node';
|
|
8
|
-
export * from './operation';
|
|
9
|
-
export * from './path';
|
|
10
|
-
export * from './plugin';
|
|
11
|
-
export * from './point';
|
|
12
|
-
export * from './selection';
|
|
13
|
-
export * from './viewport';
|
|
14
|
-
export * from './history';
|
|
15
|
-
export * from './theme';
|
|
16
|
-
export * from './direction';
|
|
17
|
-
export * from './group';
|
|
18
|
-
export * from './svg-arc-command';
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy9pbnRlcmZhY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsbUJBQW1CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2JvYXJkJztcbmV4cG9ydCAqIGZyb20gJy4vcG9pbnRlcic7XG5leHBvcnQgKiBmcm9tICcuLi9jb3JlL2VsZW1lbnQvY29udGV4dCc7XG5leHBvcnQgKiBmcm9tICcuL2N1c3RvbS10eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2VsZW1lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWN0YW5nbGUtY2xpZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbm9kZSc7XG5leHBvcnQgKiBmcm9tICcuL29wZXJhdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3BhdGgnO1xuZXhwb3J0ICogZnJvbSAnLi9wbHVnaW4nO1xuZXhwb3J0ICogZnJvbSAnLi9wb2ludCc7XG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3ZpZXdwb3J0JztcbmV4cG9ydCAqIGZyb20gJy4vaGlzdG9yeSc7XG5leHBvcnQgKiBmcm9tICcuL3RoZW1lJztcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vZ3JvdXAnO1xuZXhwb3J0ICogZnJvbSAnLi9zdmctYXJjLWNvbW1hbmQnO1xuIl19
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { Path } from './path';
|
|
2
|
-
export const PlaitNode = {
|
|
3
|
-
parent: (board, path) => {
|
|
4
|
-
const parentPath = Path.parent(path);
|
|
5
|
-
const p = PlaitNode.get(board, parentPath);
|
|
6
|
-
return p;
|
|
7
|
-
},
|
|
8
|
-
/**
|
|
9
|
-
* Return a generator of all the ancestor nodes above a specific path.
|
|
10
|
-
*
|
|
11
|
-
* By default the order is top-down, from highest to lowest ancestor in
|
|
12
|
-
* the tree, but you can pass the `reverse: true` option to go bottom-up.
|
|
13
|
-
*/
|
|
14
|
-
*parents(root, path, options = {}) {
|
|
15
|
-
for (const p of Path.ancestors(path, options)) {
|
|
16
|
-
const n = PlaitNode.get(root, p);
|
|
17
|
-
yield n;
|
|
18
|
-
}
|
|
19
|
-
},
|
|
20
|
-
get(root, path) {
|
|
21
|
-
let node = root;
|
|
22
|
-
for (let i = 0; i < path.length; i++) {
|
|
23
|
-
const p = path[i];
|
|
24
|
-
if (!node || !node.children || !node.children[p]) {
|
|
25
|
-
throw new Error(`Cannot find a descendant at path [${path}]`);
|
|
26
|
-
}
|
|
27
|
-
node = node.children[p];
|
|
28
|
-
}
|
|
29
|
-
return node;
|
|
30
|
-
},
|
|
31
|
-
last(board, path) {
|
|
32
|
-
let n = PlaitNode.get(board, path);
|
|
33
|
-
while (n && n.children && n.children.length > 0) {
|
|
34
|
-
const i = n.children.length - 1;
|
|
35
|
-
n = n.children[i];
|
|
36
|
-
}
|
|
37
|
-
return n;
|
|
38
|
-
},
|
|
39
|
-
first(board, path) {
|
|
40
|
-
const p = path.slice();
|
|
41
|
-
let n = PlaitNode.get(board, p);
|
|
42
|
-
if (!n.children || !board.isExpanded(n)) {
|
|
43
|
-
return n;
|
|
44
|
-
}
|
|
45
|
-
while (n) {
|
|
46
|
-
if (n.children.length === 0) {
|
|
47
|
-
break;
|
|
48
|
-
}
|
|
49
|
-
else {
|
|
50
|
-
n = n.children[0];
|
|
51
|
-
p.push(0);
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
return n;
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL2ludGVyZmFjZXMvbm9kZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBVTlCLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRztJQUNyQixNQUFNLEVBQUUsQ0FBQyxLQUFpQixFQUFFLElBQVUsRUFBRSxFQUFFO1FBQ3RDLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDckMsTUFBTSxDQUFDLEdBQUcsU0FBUyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFDM0MsT0FBTyxDQUFDLENBQUM7SUFDYixDQUFDO0lBQ0Q7Ozs7O09BS0c7SUFDSCxDQUFDLE9BQU8sQ0FBQyxJQUFnQixFQUFFLElBQVUsRUFBRSxVQUE4QixFQUFFO1FBQ25FLEtBQUssTUFBTSxDQUFDLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUM1QyxNQUFNLENBQUMsR0FBRyxTQUFTLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztZQUNqQyxNQUFNLENBQUMsQ0FBQztRQUNaLENBQUM7SUFDTCxDQUFDO0lBQ0QsR0FBRyxDQUFrQyxJQUFnQixFQUFFLElBQVU7UUFDN0QsSUFBSSxJQUFJLEdBQWEsSUFBSSxDQUFDO1FBQzFCLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7WUFDbkMsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2xCLElBQUksQ0FBQyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUMvQyxNQUFNLElBQUksS0FBSyxDQUFDLHFDQUFxQyxJQUFJLEdBQUcsQ0FBQyxDQUFDO1lBQ2xFLENBQUM7WUFDRCxJQUFJLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM1QixDQUFDO1FBQ0QsT0FBTyxJQUFTLENBQUM7SUFDckIsQ0FBQztJQUNELElBQUksQ0FBQyxLQUFpQixFQUFFLElBQVU7UUFDOUIsSUFBSSxDQUFDLEdBQUcsU0FBUyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDbkMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLFFBQVEsSUFBSSxDQUFDLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUM5QyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7WUFDaEMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdEIsQ0FBQztRQUNELE9BQU8sQ0FBQyxDQUFDO0lBQ2IsQ0FBQztJQUNELEtBQUssQ0FBQyxLQUFpQixFQUFFLElBQVU7UUFDL0IsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ2hDLElBQUksQ0FBQyxDQUFDLENBQUMsUUFBUSxJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1lBQ3RDLE9BQU8sQ0FBQyxDQUFDO1FBQ2IsQ0FBQztRQUNELE9BQU8sQ0FBQyxFQUFFLENBQUM7WUFDUCxJQUFJLENBQUMsQ0FBQyxRQUFTLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO2dCQUMzQixNQUFNO1lBQ1YsQ0FBQztpQkFBTSxDQUFDO2dCQUNKLENBQUMsR0FBRyxDQUFDLENBQUMsUUFBUyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUNuQixDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2QsQ0FBQztRQUNMLENBQUM7UUFDRCxPQUFPLENBQUMsQ0FBQztJQUNiLENBQUM7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRFbGVtZW50IH0gZnJvbSAnLi9lbGVtZW50JztcbmltcG9ydCB7IFBsYWl0Qm9hcmQgfSBmcm9tICcuL2JvYXJkJztcbmltcG9ydCB7IFBhdGggfSBmcm9tICcuL3BhdGgnO1xuXG5leHBvcnQgdHlwZSBQbGFpdE5vZGUgPSBQbGFpdEVsZW1lbnQ7XG5cbmV4cG9ydCB0eXBlIEFuY2VzdG9yID0gUGxhaXRCb2FyZCB8IFBsYWl0RWxlbWVudDtcblxuZXhwb3J0IGludGVyZmFjZSBOb2RlUGFyZW50c09wdGlvbnMge1xuICAgIHJldmVyc2U/OiBib29sZWFuO1xufVxuXG5leHBvcnQgY29uc3QgUGxhaXROb2RlID0ge1xuICAgIHBhcmVudDogKGJvYXJkOiBQbGFpdEJvYXJkLCBwYXRoOiBQYXRoKSA9PiB7XG4gICAgICAgIGNvbnN0IHBhcmVudFBhdGggPSBQYXRoLnBhcmVudChwYXRoKTtcbiAgICAgICAgY29uc3QgcCA9IFBsYWl0Tm9kZS5nZXQoYm9hcmQsIHBhcmVudFBhdGgpO1xuICAgICAgICByZXR1cm4gcDtcbiAgICB9LFxuICAgIC8qKlxuICAgICAqIFJldHVybiBhIGdlbmVyYXRvciBvZiBhbGwgdGhlIGFuY2VzdG9yIG5vZGVzIGFib3ZlIGEgc3BlY2lmaWMgcGF0aC5cbiAgICAgKlxuICAgICAqIEJ5IGRlZmF1bHQgdGhlIG9yZGVyIGlzIHRvcC1kb3duLCBmcm9tIGhpZ2hlc3QgdG8gbG93ZXN0IGFuY2VzdG9yIGluXG4gICAgICogdGhlIHRyZWUsIGJ1dCB5b3UgY2FuIHBhc3MgdGhlIGByZXZlcnNlOiB0cnVlYCBvcHRpb24gdG8gZ28gYm90dG9tLXVwLlxuICAgICAqL1xuICAgICpwYXJlbnRzKHJvb3Q6IFBsYWl0Qm9hcmQsIHBhdGg6IFBhdGgsIG9wdGlvbnM6IE5vZGVQYXJlbnRzT3B0aW9ucyA9IHt9KTogR2VuZXJhdG9yPFBsYWl0Tm9kZSwgdm9pZCwgdW5kZWZpbmVkPiB7XG4gICAgICAgIGZvciAoY29uc3QgcCBvZiBQYXRoLmFuY2VzdG9ycyhwYXRoLCBvcHRpb25zKSkge1xuICAgICAgICAgICAgY29uc3QgbiA9IFBsYWl0Tm9kZS5nZXQocm9vdCwgcCk7XG4gICAgICAgICAgICB5aWVsZCBuO1xuICAgICAgICB9XG4gICAgfSxcbiAgICBnZXQ8VCBleHRlbmRzIFBsYWl0Tm9kZSA9IFBsYWl0Tm9kZT4ocm9vdDogUGxhaXRCb2FyZCwgcGF0aDogUGF0aCk6IFQge1xuICAgICAgICBsZXQgbm9kZTogQW5jZXN0b3IgPSByb290O1xuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHBhdGgubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgICAgIGNvbnN0IHAgPSBwYXRoW2ldO1xuICAgICAgICAgICAgaWYgKCFub2RlIHx8ICFub2RlLmNoaWxkcmVuIHx8ICFub2RlLmNoaWxkcmVuW3BdKSB7XG4gICAgICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBDYW5ub3QgZmluZCBhIGRlc2NlbmRhbnQgYXQgcGF0aCBbJHtwYXRofV1gKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIG5vZGUgPSBub2RlLmNoaWxkcmVuW3BdO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBub2RlIGFzIFQ7XG4gICAgfSxcbiAgICBsYXN0KGJvYXJkOiBQbGFpdEJvYXJkLCBwYXRoOiBQYXRoKSB7XG4gICAgICAgIGxldCBuID0gUGxhaXROb2RlLmdldChib2FyZCwgcGF0aCk7XG4gICAgICAgIHdoaWxlIChuICYmIG4uY2hpbGRyZW4gJiYgbi5jaGlsZHJlbi5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICBjb25zdCBpID0gbi5jaGlsZHJlbi5sZW5ndGggLSAxO1xuICAgICAgICAgICAgbiA9IG4uY2hpbGRyZW5baV07XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG47XG4gICAgfSxcbiAgICBmaXJzdChib2FyZDogUGxhaXRCb2FyZCwgcGF0aDogUGF0aCkge1xuICAgICAgICBjb25zdCBwID0gcGF0aC5zbGljZSgpO1xuICAgICAgICBsZXQgbiA9IFBsYWl0Tm9kZS5nZXQoYm9hcmQsIHApO1xuICAgICAgICBpZiAoIW4uY2hpbGRyZW4gfHwgIWJvYXJkLmlzRXhwYW5kZWQobikpIHtcbiAgICAgICAgICAgIHJldHVybiBuO1xuICAgICAgICB9XG4gICAgICAgIHdoaWxlIChuKSB7XG4gICAgICAgICAgICBpZiAobi5jaGlsZHJlbiEubGVuZ3RoID09PSAwKSB7XG4gICAgICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIG4gPSBuLmNoaWxkcmVuIVswXTtcbiAgICAgICAgICAgICAgICBwLnB1c2goMCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG47XG4gICAgfVxufTtcbiJdfQ==
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
import { Path } from './path';
|
|
2
|
-
export const isSetViewportOperation = (value) => {
|
|
3
|
-
return value.type === 'set_viewport';
|
|
4
|
-
};
|
|
5
|
-
export const isSetSelectionOperation = (value) => {
|
|
6
|
-
return value.type === 'set_selection';
|
|
7
|
-
};
|
|
8
|
-
export const isSetThemeOperation = (value) => {
|
|
9
|
-
return value.type === 'set_theme';
|
|
10
|
-
};
|
|
11
|
-
export const inverse = (op) => {
|
|
12
|
-
switch (op.type) {
|
|
13
|
-
case 'insert_node': {
|
|
14
|
-
return { ...op, type: 'remove_node' };
|
|
15
|
-
}
|
|
16
|
-
case 'remove_node': {
|
|
17
|
-
return { ...op, type: 'insert_node' };
|
|
18
|
-
}
|
|
19
|
-
case 'move_node': {
|
|
20
|
-
const { newPath, path } = op;
|
|
21
|
-
// PERF: in this case the move operation is a no-op anyways.
|
|
22
|
-
if (Path.equals(newPath, path)) {
|
|
23
|
-
return op;
|
|
24
|
-
}
|
|
25
|
-
// when operation path is [0,0] -> [0,2], should exec Path.transform to get [0,1] -> [0,0]
|
|
26
|
-
// shoud not return [0,2] -> [0,0] #WIK-8981
|
|
27
|
-
// if (Path.isSibling(path, newPath)) {
|
|
28
|
-
// return { ...op, path: newPath, newPath: path };
|
|
29
|
-
// }
|
|
30
|
-
// If the move does not happen within a single parent it is possible
|
|
31
|
-
// for the move to impact the true path to the location where the node
|
|
32
|
-
// was removed from and where it was inserted. We have to adjust for this
|
|
33
|
-
// and find the original path. We can accomplish this (only in non-sibling)
|
|
34
|
-
// moves by looking at the impact of the move operation on the node
|
|
35
|
-
// after the original move path.
|
|
36
|
-
const inversePath = Path.transform(path, op);
|
|
37
|
-
const inverseNewPath = Path.transform(Path.next(path), op);
|
|
38
|
-
return { ...op, path: inversePath, newPath: inverseNewPath };
|
|
39
|
-
}
|
|
40
|
-
case 'set_node': {
|
|
41
|
-
const { properties, newProperties } = op;
|
|
42
|
-
return { ...op, properties: newProperties, newProperties: properties };
|
|
43
|
-
}
|
|
44
|
-
case 'set_selection': {
|
|
45
|
-
const { properties, newProperties } = op;
|
|
46
|
-
if (properties == null) {
|
|
47
|
-
return {
|
|
48
|
-
...op,
|
|
49
|
-
properties: newProperties,
|
|
50
|
-
newProperties: null
|
|
51
|
-
};
|
|
52
|
-
}
|
|
53
|
-
else if (newProperties == null) {
|
|
54
|
-
return {
|
|
55
|
-
...op,
|
|
56
|
-
properties: null,
|
|
57
|
-
newProperties: properties
|
|
58
|
-
};
|
|
59
|
-
}
|
|
60
|
-
else {
|
|
61
|
-
return { ...op, properties: newProperties, newProperties: properties };
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
case 'set_viewport': {
|
|
65
|
-
const { properties, newProperties } = op;
|
|
66
|
-
if (properties == null) {
|
|
67
|
-
return {
|
|
68
|
-
...op,
|
|
69
|
-
properties: newProperties,
|
|
70
|
-
newProperties: newProperties
|
|
71
|
-
};
|
|
72
|
-
}
|
|
73
|
-
else if (newProperties == null) {
|
|
74
|
-
return {
|
|
75
|
-
...op,
|
|
76
|
-
properties: properties,
|
|
77
|
-
newProperties: properties
|
|
78
|
-
};
|
|
79
|
-
}
|
|
80
|
-
else {
|
|
81
|
-
return { ...op, properties: newProperties, newProperties: properties };
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
case 'set_theme': {
|
|
85
|
-
const { properties, newProperties } = op;
|
|
86
|
-
return { ...op, properties: newProperties, newProperties: properties };
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
};
|
|
90
|
-
export const PlaitOperation = {
|
|
91
|
-
isSetViewportOperation,
|
|
92
|
-
isSetSelectionOperation,
|
|
93
|
-
isSetThemeOperation,
|
|
94
|
-
inverse
|
|
95
|
-
};
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"operation.js","sourceRoot":"","sources":["../../../../packages/core/src/interfaces/operation.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitNode } from './node';\nimport { Path } from './path';\nimport { Selection } from './selection';\nimport { PlaitTheme } from './theme';\nimport { Viewport } from './viewport';\n\nexport type InsertNodeOperation = {\n    type: 'insert_node';\n    path: Path;\n    node: PlaitNode;\n};\n\nexport type RemoveNodeOperation = {\n    type: 'remove_node';\n    path: Path;\n    node: PlaitNode;\n};\n\nexport type MoveNodeOperation = {\n    type: 'move_node';\n    path: Path;\n    newPath: Path;\n};\n\nexport type SetThemeOperation = {\n    type: 'set_theme';\n    properties: Partial<PlaitTheme>;\n    newProperties: Partial<PlaitTheme>;\n};\n\nexport type SetViewportOperation = {\n    type: 'set_viewport';\n    properties: Partial<Viewport>;\n    newProperties: Partial<Viewport>;\n};\n\nexport type SetSelectionOperation = {\n    type: 'set_selection';\n    properties: Selection | null;\n    newProperties: Selection | null;\n};\n\nexport type SetNodeOperation = {\n    type: 'set_node';\n    path: Path;\n    properties: Partial<PlaitNode>;\n    newProperties: Partial<PlaitNode>;\n};\n\nexport type PlaitOperation =\n    | InsertNodeOperation\n    | SetViewportOperation\n    | SetSelectionOperation\n    | SetNodeOperation\n    | RemoveNodeOperation\n    | MoveNodeOperation\n    | SetThemeOperation;\n\nexport interface PlaitOperationInterface {\n    inverse: (op: PlaitOperation) => PlaitOperation;\n    isSetViewportOperation: (value: PlaitOperation) => boolean;\n    isSetSelectionOperation: (value: PlaitOperation) => boolean;\n    isSetThemeOperation: (value: PlaitOperation) => boolean;\n}\n\nexport const isSetViewportOperation = (value: any): value is SetViewportOperation => {\n    return value.type === 'set_viewport';\n};\n\nexport const isSetSelectionOperation = (value: any): value is SetSelectionOperation => {\n    return value.type === 'set_selection';\n};\n\nexport const isSetThemeOperation = (value: any): value is SetThemeOperation => {\n    return value.type === 'set_theme';\n};\n\nexport const inverse = (op: PlaitOperation): PlaitOperation => {\n    switch (op.type) {\n        case 'insert_node': {\n            return { ...op, type: 'remove_node' };\n        }\n\n        case 'remove_node': {\n            return { ...op, type: 'insert_node' };\n        }\n\n        case 'move_node': {\n            const { newPath, path } = op;\n\n            // PERF: in this case the move operation is a no-op anyways.\n            if (Path.equals(newPath, path)) {\n                return op;\n            }\n\n            // when operation path is [0,0] -> [0,2], should exec Path.transform to get [0,1] -> [0,0]\n            // shoud not return [0,2] -> [0,0] #WIK-8981\n            // if (Path.isSibling(path, newPath)) {\n            //     return { ...op, path: newPath, newPath: path };\n            // }\n\n            // If the move does not happen within a single parent it is possible\n            // for the move to impact the true path to the location where the node\n            // was removed from and where it was inserted. We have to adjust for this\n            // and find the original path. We can accomplish this (only in non-sibling)\n            // moves by looking at the impact of the move operation on the node\n            // after the original move path.\n            const inversePath = Path.transform(path, op)!;\n            const inverseNewPath = Path.transform(Path.next(path), op)!;\n            return { ...op, path: inversePath, newPath: inverseNewPath };\n        }\n\n        case 'set_node': {\n            const { properties, newProperties } = op;\n            return { ...op, properties: newProperties, newProperties: properties };\n        }\n\n        case 'set_selection': {\n            const { properties, newProperties } = op;\n\n            if (properties == null) {\n                return {\n                    ...op,\n                    properties: newProperties,\n                    newProperties: null\n                };\n            } else if (newProperties == null) {\n                return {\n                    ...op,\n                    properties: null,\n                    newProperties: properties\n                };\n            } else {\n                return { ...op, properties: newProperties, newProperties: properties };\n            }\n        }\n\n        case 'set_viewport': {\n            const { properties, newProperties } = op;\n            if (properties == null) {\n                return {\n                    ...op,\n                    properties: newProperties,\n                    newProperties: newProperties\n                };\n            } else if (newProperties == null) {\n                return {\n                    ...op,\n                    properties: properties,\n                    newProperties: properties\n                };\n            } else {\n                return { ...op, properties: newProperties, newProperties: properties };\n            }\n        }\n\n        case 'set_theme': {\n            const { properties, newProperties } = op;\n            return { ...op, properties: newProperties, newProperties: properties };\n        }\n    }\n};\n\nexport const PlaitOperation: PlaitOperationInterface = {\n    isSetViewportOperation,\n    isSetSelectionOperation,\n    isSetThemeOperation,\n    inverse\n};\n"]}
|
|
@@ -1,15 +0,0 @@
|
|
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0aC1yZWYuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy9pbnRlcmZhY2VzL3BhdGgtcmVmLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFZOUIsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHO0lBQ25CLFNBQVMsQ0FBQyxHQUFZLEVBQUUsRUFBa0I7UUFDdEMsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLEdBQUcsQ0FBQztRQUV4QixJQUFJLE9BQU8sSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNsQixPQUFPO1FBQ1gsQ0FBQztRQUVELE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ3pDLEdBQUcsQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDO1FBRW5CLElBQUksSUFBSSxJQUFJLElBQUksRUFBRSxDQUFDO1lBQ2YsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2hCLENBQUM7SUFDTCxDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0T3BlcmF0aW9uIH0gZnJvbSAnLi9vcGVyYXRpb24nO1xuaW1wb3J0IHsgUGF0aCB9IGZyb20gJy4vcGF0aCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGF0aFJlZiB7XG4gICAgY3VycmVudDogUGF0aCB8IG51bGw7XG4gICAgYWZmaW5pdHk6ICdmb3J3YXJkJyB8ICdiYWNrd2FyZCcgfCBudWxsO1xuICAgIHVucmVmKCk6IFBhdGggfCBudWxsO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBhdGhSZWZPcHRpb25zIHtcbiAgICBhZmZpbml0eT86ICdmb3J3YXJkJyB8ICdiYWNrd2FyZCcgfCBudWxsO1xufVxuXG5leHBvcnQgY29uc3QgUGF0aFJlZiA9IHtcbiAgICB0cmFuc2Zvcm0ocmVmOiBQYXRoUmVmLCBvcDogUGxhaXRPcGVyYXRpb24pOiB2b2lkIHtcbiAgICAgICAgY29uc3QgeyBjdXJyZW50IH0gPSByZWY7XG5cbiAgICAgICAgaWYgKGN1cnJlbnQgPT0gbnVsbCkge1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgcGF0aCA9IFBhdGgudHJhbnNmb3JtKGN1cnJlbnQsIG9wKTtcbiAgICAgICAgcmVmLmN1cnJlbnQgPSBwYXRoO1xuXG4gICAgICAgIGlmIChwYXRoID09IG51bGwpIHtcbiAgICAgICAgICAgIHJlZi51bnJlZigpO1xuICAgICAgICB9XG4gICAgfVxufTtcbiJdfQ==
|