@plait/core 0.24.0-next.1 → 0.24.0-next.10

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.
Files changed (133) hide show
  1. package/board/board.component.d.ts +1 -1
  2. package/board/board.component.interface.d.ts +3 -1
  3. package/constants/selection.d.ts +2 -0
  4. package/core/children/children.component.d.ts +1 -1
  5. package/core/element/element.component.d.ts +1 -1
  6. package/core/element/plugin-element.d.ts +1 -1
  7. package/core/island/island-base.component.d.ts +4 -2
  8. package/esm2022/board/board.component.interface.mjs +2 -0
  9. package/esm2022/board/board.component.mjs +405 -0
  10. package/esm2022/constants/selection.mjs +4 -0
  11. package/{esm2020 → esm2022}/core/children/children.component.mjs +6 -6
  12. package/{esm2020 → esm2022}/core/element/element.component.mjs +4 -4
  13. package/{esm2020 → esm2022}/core/element/plugin-element.mjs +4 -4
  14. package/esm2022/core/island/island-base.component.mjs +72 -0
  15. package/{esm2020 → esm2022}/interfaces/board.mjs +1 -1
  16. package/esm2022/interfaces/rectangle-client.mjs +65 -0
  17. package/{esm2020 → esm2022}/plait.module.mjs +5 -5
  18. package/esm2022/plugins/create-board.mjs +106 -0
  19. package/esm2022/plugins/with-hotkey.mjs +62 -0
  20. package/esm2022/plugins/with-moving.mjs +116 -0
  21. package/esm2022/plugins/with-selection.mjs +193 -0
  22. package/{esm2020 → esm2022}/services/image-context.service.mjs +4 -4
  23. package/esm2022/transforms/element.mjs +22 -0
  24. package/esm2022/transforms/index.mjs +13 -0
  25. package/esm2022/transforms/selection.mjs +26 -0
  26. package/esm2022/utils/dom/common.mjs +76 -0
  27. package/esm2022/utils/dom/foreign.mjs +25 -0
  28. package/esm2022/utils/draw/line.mjs +47 -0
  29. package/esm2022/utils/draw/rectangle.mjs +34 -0
  30. package/esm2022/utils/element.mjs +71 -0
  31. package/esm2022/utils/math.mjs +176 -0
  32. package/esm2022/utils/reaction-manager.mjs +185 -0
  33. package/esm2022/utils/touch.mjs +35 -0
  34. package/esm2022/utils/weak-maps.mjs +21 -0
  35. package/{fesm2020 → fesm2022}/plait-core.mjs +2427 -1938
  36. package/fesm2022/plait-core.mjs.map +1 -0
  37. package/interfaces/board.d.ts +2 -1
  38. package/interfaces/rectangle-client.d.ts +8 -0
  39. package/package.json +14 -14
  40. package/plugins/with-selection.d.ts +5 -1
  41. package/styles/styles.scss +1 -1
  42. package/transforms/element.d.ts +6 -0
  43. package/transforms/index.d.ts +1 -0
  44. package/transforms/selection.d.ts +2 -2
  45. package/utils/dom/common.d.ts +6 -0
  46. package/utils/dom/foreign.d.ts +2 -1
  47. package/utils/draw/line.d.ts +1 -1
  48. package/utils/draw/rectangle.d.ts +3 -0
  49. package/utils/element.d.ts +5 -0
  50. package/utils/math.d.ts +9 -0
  51. package/utils/reaction-manager.d.ts +25 -0
  52. package/utils/touch.d.ts +14 -1
  53. package/utils/weak-maps.d.ts +4 -2
  54. package/esm2020/board/board.component.interface.mjs +0 -2
  55. package/esm2020/board/board.component.mjs +0 -407
  56. package/esm2020/constants/selection.mjs +0 -2
  57. package/esm2020/core/island/island-base.component.mjs +0 -69
  58. package/esm2020/interfaces/rectangle-client.mjs +0 -40
  59. package/esm2020/plugins/create-board.mjs +0 -101
  60. package/esm2020/plugins/with-hotkey.mjs +0 -57
  61. package/esm2020/plugins/with-moving.mjs +0 -97
  62. package/esm2020/plugins/with-selection.mjs +0 -183
  63. package/esm2020/transforms/index.mjs +0 -12
  64. package/esm2020/transforms/selection.mjs +0 -16
  65. package/esm2020/utils/dom/common.mjs +0 -53
  66. package/esm2020/utils/dom/foreign.mjs +0 -19
  67. package/esm2020/utils/draw/line.mjs +0 -43
  68. package/esm2020/utils/draw/rectangle.mjs +0 -26
  69. package/esm2020/utils/element.mjs +0 -44
  70. package/esm2020/utils/math.mjs +0 -48
  71. package/esm2020/utils/touch.mjs +0 -8
  72. package/esm2020/utils/weak-maps.mjs +0 -22
  73. package/fesm2015/plait-core.mjs +0 -3454
  74. package/fesm2015/plait-core.mjs.map +0 -1
  75. package/fesm2020/plait-core.mjs.map +0 -1
  76. /package/{esm2020 → esm2022}/constants/index.mjs +0 -0
  77. /package/{esm2020 → esm2022}/constants/keycodes.mjs +0 -0
  78. /package/{esm2020 → esm2022}/constants/resize.mjs +0 -0
  79. /package/{esm2020 → esm2022}/core/children/effect.mjs +0 -0
  80. /package/{esm2020 → esm2022}/core/element/context-change.mjs +0 -0
  81. /package/{esm2020 → esm2022}/core/element/context.mjs +0 -0
  82. /package/{esm2020 → esm2022}/interfaces/custom-types.mjs +0 -0
  83. /package/{esm2020 → esm2022}/interfaces/element.mjs +0 -0
  84. /package/{esm2020 → esm2022}/interfaces/history.mjs +0 -0
  85. /package/{esm2020 → esm2022}/interfaces/index.mjs +0 -0
  86. /package/{esm2020 → esm2022}/interfaces/node.mjs +0 -0
  87. /package/{esm2020 → esm2022}/interfaces/operation.mjs +0 -0
  88. /package/{esm2020 → esm2022}/interfaces/path-ref.mjs +0 -0
  89. /package/{esm2020 → esm2022}/interfaces/path.mjs +0 -0
  90. /package/{esm2020 → esm2022}/interfaces/plugin-key.mjs +0 -0
  91. /package/{esm2020 → esm2022}/interfaces/plugin.mjs +0 -0
  92. /package/{esm2020 → esm2022}/interfaces/point.mjs +0 -0
  93. /package/{esm2020 → esm2022}/interfaces/pointer.mjs +0 -0
  94. /package/{esm2020 → esm2022}/interfaces/selection.mjs +0 -0
  95. /package/{esm2020 → esm2022}/interfaces/theme.mjs +0 -0
  96. /package/{esm2020 → esm2022}/interfaces/viewport.mjs +0 -0
  97. /package/{esm2020 → esm2022}/plait-core.mjs +0 -0
  98. /package/{esm2020 → esm2022}/plugins/with-board.mjs +0 -0
  99. /package/{esm2020 → esm2022}/plugins/with-hand.mjs +0 -0
  100. /package/{esm2020 → esm2022}/plugins/with-history.mjs +0 -0
  101. /package/{esm2020 → esm2022}/plugins/with-options.mjs +0 -0
  102. /package/{esm2020 → esm2022}/plugins/with-viewport.mjs +0 -0
  103. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
  104. /package/{esm2020 → esm2022}/testing/core/create-board.mjs +0 -0
  105. /package/{esm2020 → esm2022}/testing/core/fake-weak-map.mjs +0 -0
  106. /package/{esm2020 → esm2022}/testing/core/index.mjs +0 -0
  107. /package/{esm2020 → esm2022}/testing/fake-events/event-objects.mjs +0 -0
  108. /package/{esm2020 → esm2022}/testing/fake-events/index.mjs +0 -0
  109. /package/{esm2020 → esm2022}/testing/index.mjs +0 -0
  110. /package/{esm2020 → esm2022}/testing/test-element.mjs +0 -0
  111. /package/{esm2020 → esm2022}/transforms/board.mjs +0 -0
  112. /package/{esm2020 → esm2022}/transforms/general.mjs +0 -0
  113. /package/{esm2020 → esm2022}/transforms/node.mjs +0 -0
  114. /package/{esm2020 → esm2022}/transforms/theme.mjs +0 -0
  115. /package/{esm2020 → esm2022}/transforms/viewport.mjs +0 -0
  116. /package/{esm2020 → esm2022}/utils/board.mjs +0 -0
  117. /package/{esm2020 → esm2022}/utils/clipboard.mjs +0 -0
  118. /package/{esm2020 → esm2022}/utils/common.mjs +0 -0
  119. /package/{esm2020 → esm2022}/utils/dom/environment.mjs +0 -0
  120. /package/{esm2020 → esm2022}/utils/dom/index.mjs +0 -0
  121. /package/{esm2020 → esm2022}/utils/draw/arrow.mjs +0 -0
  122. /package/{esm2020 → esm2022}/utils/draw/circle.mjs +0 -0
  123. /package/{esm2020 → esm2022}/utils/environment.mjs +0 -0
  124. /package/{esm2020 → esm2022}/utils/helper.mjs +0 -0
  125. /package/{esm2020 → esm2022}/utils/history.mjs +0 -0
  126. /package/{esm2020 → esm2022}/utils/hotkeys.mjs +0 -0
  127. /package/{esm2020 → esm2022}/utils/id-creator.mjs +0 -0
  128. /package/{esm2020 → esm2022}/utils/index.mjs +0 -0
  129. /package/{esm2020 → esm2022}/utils/moving-element.mjs +0 -0
  130. /package/{esm2020 → esm2022}/utils/selected-element.mjs +0 -0
  131. /package/{esm2020 → esm2022}/utils/to-image.mjs +0 -0
  132. /package/{esm2020 → esm2022}/utils/tree.mjs +0 -0
  133. /package/{esm2020 → esm2022}/utils/viewport.mjs +0 -0
@@ -1,101 +0,0 @@
1
- import { PlaitPointerType } from '../interfaces/pointer';
2
- import { Transforms } from '../transforms';
3
- import { FLUSHING, PATH_REFS } from '../utils/weak-maps';
4
- import { PathRef } from '../interfaces/path-ref';
5
- import { ThemeColorMode } from '../interfaces/theme';
6
- export function createBoard(children, options) {
7
- const board = {
8
- viewport: {
9
- zoom: 1
10
- },
11
- children,
12
- theme: { themeColorMode: ThemeColorMode.default },
13
- operations: [],
14
- history: {
15
- redos: [],
16
- undos: []
17
- },
18
- selection: null,
19
- options: options || {
20
- readonly: false,
21
- hideScrollbar: false,
22
- disabledScrollOnNonFocus: false
23
- },
24
- pointer: options?.readonly ? PlaitPointerType.hand : PlaitPointerType.selection,
25
- undo: () => { },
26
- redo: () => { },
27
- apply: (operation) => {
28
- for (const ref of board.pathRefs()) {
29
- PathRef.transform(ref, operation);
30
- }
31
- board.operations.push(operation);
32
- Transforms.transform(board, operation);
33
- if (!FLUSHING.get(board)) {
34
- FLUSHING.set(board, true);
35
- Promise.resolve().then(() => {
36
- FLUSHING.set(board, false);
37
- board.onChange();
38
- board.operations = [];
39
- });
40
- }
41
- },
42
- pathRef: (path, options) => {
43
- const affinity = options?.affinity || 'forward';
44
- const ref = {
45
- current: path,
46
- affinity,
47
- unref() {
48
- const { current } = ref;
49
- const pathRefs = board.pathRefs();
50
- pathRefs.delete(ref);
51
- ref.current = null;
52
- return current;
53
- }
54
- };
55
- const refs = board.pathRefs();
56
- refs.add(ref);
57
- return ref;
58
- },
59
- pathRefs: () => {
60
- let refs = PATH_REFS.get(board);
61
- if (!refs) {
62
- refs = new Set();
63
- PATH_REFS.set(board, refs);
64
- }
65
- return refs;
66
- },
67
- onChange: () => { },
68
- mousedown: (event) => { },
69
- mousemove: (event) => { },
70
- mouseleave: (event) => { },
71
- globalMousemove: (event) => { },
72
- mouseup: (event) => { },
73
- globalMouseup: (event) => { },
74
- keydown: (event) => { },
75
- globalKeydown: (event) => { },
76
- keyup: (event) => { },
77
- dblclick: (event) => { },
78
- setFragment: (data) => { },
79
- insertFragment: (data) => { },
80
- deleteFragment: (data) => { },
81
- drawElement: (context) => [],
82
- redrawElement: (context, previousContext) => { },
83
- destroyElement: (context) => { },
84
- isWithinSelection: element => false,
85
- isHitSelection: element => false,
86
- isRecursion: element => true,
87
- isMovable: element => false,
88
- getRectangle: element => null,
89
- applyTheme: (element) => { },
90
- pointerDown: (pointer) => { },
91
- pointerMove: (pointer) => { },
92
- pointerUp: (pointer) => { },
93
- pointerCancel: (pointer) => { },
94
- pointerOut: (pointer) => { },
95
- pointerLeave: (pointer) => { },
96
- globalPointerMove: (pointer) => { },
97
- globalPointerUp: (pointer) => { },
98
- };
99
- return board;
100
- }
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-board.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/create-board.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitBoardOptions } from '../interfaces/board';\nimport { PlaitPointerType } from '../interfaces/pointer';\nimport { PlaitElement } from '../interfaces/element';\nimport { PlaitPluginElementContext } from '../core/element/context';\nimport { PlaitOperation } from '../interfaces/operation';\nimport { Transforms } from '../transforms';\nimport { FLUSHING, PATH_REFS } from '../utils/weak-maps';\nimport { PathRef, PathRefOptions } from '../interfaces/path-ref';\nimport { Path } from '../interfaces/path';\nimport { ThemeColorMode } from '../interfaces/theme';\n\nexport function createBoard(children: PlaitElement[], options?: PlaitBoardOptions): PlaitBoard {\n    const board: PlaitBoard = {\n        viewport: {\n            zoom: 1\n        },\n        children,\n        theme: { themeColorMode: ThemeColorMode.default },\n        operations: [],\n        history: {\n            redos: [],\n            undos: []\n        },\n        selection: null,\n        options: options || {\n            readonly: false,\n            hideScrollbar: false,\n            disabledScrollOnNonFocus: false\n        },\n        pointer: options?.readonly ? PlaitPointerType.hand : PlaitPointerType.selection,\n        undo: () => {},\n        redo: () => {},\n        apply: (operation: PlaitOperation) => {\n            for (const ref of board.pathRefs()) {\n                PathRef.transform(ref, operation);\n            }\n\n            board.operations.push(operation);\n\n            Transforms.transform(board, operation);\n\n            if (!FLUSHING.get(board)) {\n                FLUSHING.set(board, true);\n\n                Promise.resolve().then(() => {\n                    FLUSHING.set(board, false);\n                    board.onChange();\n                    board.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        mouseleave: (event: MouseEvent) => {},\n        globalMousemove: (event: MouseEvent) => {},\n        mouseup: (event: MouseEvent) => {},\n        globalMouseup: (event: MouseEvent) => {},\n        keydown: (event: KeyboardEvent) => {},\n        globalKeydown: (event: KeyboardEvent) => {},\n        keyup: (event: KeyboardEvent) => {},\n        dblclick: (event: MouseEvent) => {},\n        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        applyTheme: (element: PlaitElement) => {},\n        pointerDown: (pointer) => {},\n        pointerMove: (pointer) => {},\n        pointerUp: (pointer) => {},\n        pointerCancel: (pointer) => {},\n        pointerOut: (pointer) => {},\n        pointerLeave: (pointer) => {},\n        globalPointerMove: (pointer) => {},\n        globalPointerUp: (pointer) => {},\n    };\n    return board;\n}\n"]}
@@ -1,57 +0,0 @@
1
- import { isHotkey } from 'is-hotkey';
2
- import { PlaitBoard, PlaitPluginKey } from '../interfaces';
3
- import { BoardTransforms, Transforms } from '../transforms';
4
- import { depthFirstRecursion } from '../utils';
5
- export const withHotkey = (board) => {
6
- const { keydown, globalKeydown } = board;
7
- board.keydown = (event) => {
8
- const options = board.getPluginOptions(PlaitPluginKey.withSelection);
9
- if (!PlaitBoard.isReadonly(board) && options.isMultiple && isHotkey('mod+a', event)) {
10
- event.preventDefault();
11
- let elements = [];
12
- depthFirstRecursion(board, node => {
13
- if (PlaitBoard.isBoard(node)) {
14
- return;
15
- }
16
- elements.push(node);
17
- }, node => {
18
- if (PlaitBoard.isBoard(node) || board.isRecursion(node)) {
19
- return true;
20
- }
21
- else {
22
- return false;
23
- }
24
- }, true);
25
- Transforms.setSelectionWithTemporaryElements(board, elements);
26
- return;
27
- }
28
- keydown(event);
29
- };
30
- board.globalKeydown = (event) => {
31
- if (PlaitBoard.getMovingPointInBoard(board) || PlaitBoard.isMovingPointInBoard(board)) {
32
- if (isHotkey(['mod+=', 'mod++'], { byKey: true })(event)) {
33
- event.preventDefault();
34
- BoardTransforms.updateZoom(board, board.viewport.zoom + 0.1, false);
35
- return;
36
- }
37
- if (isHotkey(['mod+shift+=', 'mod+shift++'], { byKey: true })(event)) {
38
- event.preventDefault();
39
- BoardTransforms.fitViewport(board);
40
- return;
41
- }
42
- if (isHotkey(['mod+-', 'mod+shift+-'])(event)) {
43
- event.preventDefault();
44
- BoardTransforms.updateZoom(board, board.viewport.zoom - 0.1);
45
- return;
46
- }
47
- if (isHotkey(['mod+0', 'mod+shift+0'], { byKey: true })(event)) {
48
- event.preventDefault();
49
- BoardTransforms.updateZoom(board, 1);
50
- return;
51
- }
52
- }
53
- globalKeydown(event);
54
- };
55
- return board;
56
- };
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1ob3RrZXkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy9wbHVnaW5zL3dpdGgtaG90a2V5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDckMsT0FBTyxFQUFZLFVBQVUsRUFBZ0IsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25GLE9BQU8sRUFBRSxlQUFlLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUkvQyxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsQ0FBQyxLQUFpQixFQUFFLEVBQUU7SUFDNUMsTUFBTSxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsR0FBRyxLQUFLLENBQUM7SUFFekMsS0FBSyxDQUFDLE9BQU8sR0FBRyxDQUFDLEtBQW9CLEVBQUUsRUFBRTtRQUNyQyxNQUFNLE9BQU8sR0FBSSxLQUEyQixDQUFDLGdCQUFnQixDQUFvQixjQUFjLENBQUMsYUFBYSxDQUFDLENBQUM7UUFFL0csSUFBSSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLElBQUksT0FBTyxDQUFDLFVBQVUsSUFBSSxRQUFRLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxFQUFFO1lBQ2pGLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUN2QixJQUFJLFFBQVEsR0FBbUIsRUFBRSxDQUFDO1lBQ2xDLG1CQUFtQixDQUNmLEtBQUssRUFDTCxJQUFJLENBQUMsRUFBRTtnQkFDSCxJQUFJLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUU7b0JBQzFCLE9BQU87aUJBQ1Y7Z0JBQ0QsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFvQixDQUFDLENBQUM7WUFDeEMsQ0FBQyxFQUNELElBQUksQ0FBQyxFQUFFO2dCQUNILElBQUksVUFBVSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxLQUFLLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxFQUFFO29CQUNyRCxPQUFPLElBQUksQ0FBQztpQkFDZjtxQkFBTTtvQkFDSCxPQUFPLEtBQUssQ0FBQztpQkFDaEI7WUFDTCxDQUFDLEVBQ0QsSUFBSSxDQUNQLENBQUM7WUFFRixVQUFVLENBQUMsaUNBQWlDLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1lBQzlELE9BQU87U0FDVjtRQUNELE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNuQixDQUFDLENBQUM7SUFFRixLQUFLLENBQUMsYUFBYSxHQUFHLENBQUMsS0FBb0IsRUFBRSxFQUFFO1FBQzNDLElBQUksVUFBVSxDQUFDLHFCQUFxQixDQUFDLEtBQUssQ0FBQyxJQUFJLFVBQVUsQ0FBQyxvQkFBb0IsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNuRixJQUFJLFFBQVEsQ0FBQyxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsRUFBRSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxFQUFFO2dCQUN0RCxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7Z0JBQ3ZCLGVBQWUsQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxHQUFHLEdBQUcsRUFBRSxLQUFLLENBQUMsQ0FBQztnQkFDcEUsT0FBTzthQUNWO1lBQ0QsSUFBSSxRQUFRLENBQUMsQ0FBQyxhQUFhLEVBQUUsYUFBYSxDQUFDLEVBQUUsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFBRTtnQkFDbEUsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO2dCQUN2QixlQUFlLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUNuQyxPQUFPO2FBQ1Y7WUFDRCxJQUFJLFFBQVEsQ0FBQyxDQUFDLE9BQU8sRUFBRSxhQUFhLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxFQUFFO2dCQUMzQyxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7Z0JBQ3ZCLGVBQWUsQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQyxDQUFDO2dCQUM3RCxPQUFPO2FBQ1Y7WUFDRCxJQUFJLFFBQVEsQ0FBQyxDQUFDLE9BQU8sRUFBRSxhQUFhLENBQUMsRUFBRSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxFQUFFO2dCQUM1RCxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7Z0JBQ3ZCLGVBQWUsQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO2dCQUNyQyxPQUFPO2FBQ1Y7U0FDSjtRQUNELGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN6QixDQUFDLENBQUM7SUFFRixPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc0hvdGtleSB9IGZyb20gJ2lzLWhvdGtleSc7XG5pbXBvcnQgeyBBbmNlc3RvciwgUGxhaXRCb2FyZCwgUGxhaXRFbGVtZW50LCBQbGFpdFBsdWdpbktleSB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgQm9hcmRUcmFuc2Zvcm1zLCBUcmFuc2Zvcm1zIH0gZnJvbSAnLi4vdHJhbnNmb3Jtcyc7XG5pbXBvcnQgeyBkZXB0aEZpcnN0UmVjdXJzaW9uIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgUGxhaXRPcHRpb25zQm9hcmQgfSBmcm9tICcuL3dpdGgtb3B0aW9ucyc7XG5pbXBvcnQgeyBXaXRoUGx1Z2luT3B0aW9ucyB9IGZyb20gJy4vd2l0aC1zZWxlY3Rpb24nO1xuXG5leHBvcnQgY29uc3Qgd2l0aEhvdGtleSA9IChib2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IHsga2V5ZG93biwgZ2xvYmFsS2V5ZG93biB9ID0gYm9hcmQ7XG5cbiAgICBib2FyZC5rZXlkb3duID0gKGV2ZW50OiBLZXlib2FyZEV2ZW50KSA9PiB7XG4gICAgICAgIGNvbnN0IG9wdGlvbnMgPSAoYm9hcmQgYXMgUGxhaXRPcHRpb25zQm9hcmQpLmdldFBsdWdpbk9wdGlvbnM8V2l0aFBsdWdpbk9wdGlvbnM+KFBsYWl0UGx1Z2luS2V5LndpdGhTZWxlY3Rpb24pO1xuXG4gICAgICAgIGlmICghUGxhaXRCb2FyZC5pc1JlYWRvbmx5KGJvYXJkKSAmJiBvcHRpb25zLmlzTXVsdGlwbGUgJiYgaXNIb3RrZXkoJ21vZCthJywgZXZlbnQpKSB7XG4gICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgbGV0IGVsZW1lbnRzOiBQbGFpdEVsZW1lbnRbXSA9IFtdO1xuICAgICAgICAgICAgZGVwdGhGaXJzdFJlY3Vyc2lvbjxBbmNlc3Rvcj4oXG4gICAgICAgICAgICAgICAgYm9hcmQsXG4gICAgICAgICAgICAgICAgbm9kZSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGlmIChQbGFpdEJvYXJkLmlzQm9hcmQobm9kZSkpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICBlbGVtZW50cy5wdXNoKG5vZGUgYXMgUGxhaXRFbGVtZW50KTtcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIG5vZGUgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoUGxhaXRCb2FyZC5pc0JvYXJkKG5vZGUpIHx8IGJvYXJkLmlzUmVjdXJzaW9uKG5vZGUpKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgdHJ1ZVxuICAgICAgICAgICAgKTtcblxuICAgICAgICAgICAgVHJhbnNmb3Jtcy5zZXRTZWxlY3Rpb25XaXRoVGVtcG9yYXJ5RWxlbWVudHMoYm9hcmQsIGVsZW1lbnRzKTtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICBrZXlkb3duKGV2ZW50KTtcbiAgICB9O1xuXG4gICAgYm9hcmQuZ2xvYmFsS2V5ZG93biA9IChldmVudDogS2V5Ym9hcmRFdmVudCkgPT4ge1xuICAgICAgICBpZiAoUGxhaXRCb2FyZC5nZXRNb3ZpbmdQb2ludEluQm9hcmQoYm9hcmQpIHx8IFBsYWl0Qm9hcmQuaXNNb3ZpbmdQb2ludEluQm9hcmQoYm9hcmQpKSB7XG4gICAgICAgICAgICBpZiAoaXNIb3RrZXkoWydtb2QrPScsICdtb2QrKyddLCB7IGJ5S2V5OiB0cnVlIH0pKGV2ZW50KSkge1xuICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgQm9hcmRUcmFuc2Zvcm1zLnVwZGF0ZVpvb20oYm9hcmQsIGJvYXJkLnZpZXdwb3J0Lnpvb20gKyAwLjEsIGZhbHNlKTtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAoaXNIb3RrZXkoWydtb2Qrc2hpZnQrPScsICdtb2Qrc2hpZnQrKyddLCB7IGJ5S2V5OiB0cnVlIH0pKGV2ZW50KSkge1xuICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgQm9hcmRUcmFuc2Zvcm1zLmZpdFZpZXdwb3J0KGJvYXJkKTtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAoaXNIb3RrZXkoWydtb2QrLScsICdtb2Qrc2hpZnQrLSddKShldmVudCkpIHtcbiAgICAgICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgIEJvYXJkVHJhbnNmb3Jtcy51cGRhdGVab29tKGJvYXJkLCBib2FyZC52aWV3cG9ydC56b29tIC0gMC4xKTtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAoaXNIb3RrZXkoWydtb2QrMCcsICdtb2Qrc2hpZnQrMCddLCB7IGJ5S2V5OiB0cnVlIH0pKGV2ZW50KSkge1xuICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgQm9hcmRUcmFuc2Zvcm1zLnVwZGF0ZVpvb20oYm9hcmQsIDEpO1xuICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBnbG9iYWxLZXlkb3duKGV2ZW50KTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIGJvYXJkO1xufTtcbiJdfQ==
@@ -1,97 +0,0 @@
1
- import { BOARD_TO_HOST } from '../utils/weak-maps';
2
- import { PlaitBoard } from '../interfaces/board';
3
- import { isInPlaitBoard, transformPoint } from '../utils/board';
4
- import { toPoint } from '../utils/dom/common';
5
- import { Transforms } from '../transforms';
6
- import { getHitElementOfRoot, getSelectedElements } from '../utils/selected-element';
7
- import { PlaitNode } from '../interfaces/node';
8
- import { throttleRAF } from '../utils/common';
9
- import { addMovingElements, removeMovingElements } from '../utils/moving-element';
10
- import { MERGING } from '../interfaces/history';
11
- export function withMoving(board) {
12
- const { mousedown, mousemove, globalMouseup, globalMousemove } = board;
13
- let offsetX = 0;
14
- let offsetY = 0;
15
- let isPreventDefault = false;
16
- let startPoint;
17
- let activeElements = [];
18
- board.mousedown = event => {
19
- const host = BOARD_TO_HOST.get(board);
20
- const point = transformPoint(board, toPoint(event.x, event.y, host));
21
- const range = { anchor: point, focus: point };
22
- let movableElements = board.children.filter(item => board.isMovable(item));
23
- if (movableElements.length) {
24
- startPoint = point;
25
- const selectedRootElements = getSelectedElements(board).filter(item => movableElements.includes(item));
26
- const hitElement = getHitElementOfRoot(board, movableElements, range);
27
- if (hitElement && selectedRootElements.includes(hitElement)) {
28
- activeElements = selectedRootElements;
29
- }
30
- else if (hitElement) {
31
- activeElements = [hitElement];
32
- }
33
- }
34
- mousedown(event);
35
- };
36
- board.mousemove = event => {
37
- if (startPoint && activeElements.length && !PlaitBoard.hasBeenTextEditing(board)) {
38
- if (!isPreventDefault) {
39
- isPreventDefault = true;
40
- }
41
- const host = BOARD_TO_HOST.get(board);
42
- const endPoint = transformPoint(board, toPoint(event.x, event.y, host));
43
- offsetX = endPoint[0] - startPoint[0];
44
- offsetY = endPoint[1] - startPoint[1];
45
- const offsetBuffer = 5;
46
- if (Math.abs(offsetX) > offsetBuffer || Math.abs(offsetY) > offsetBuffer) {
47
- throttleRAF(() => {
48
- const currentElements = activeElements.map(activeElement => {
49
- const points = activeElement.points || [];
50
- const [x, y] = activeElement.points[0];
51
- const newPoints = points.map(p => [p[0] + offsetX, p[1] + offsetY]);
52
- const index = board.children.findIndex(item => item.id === activeElement.id);
53
- Transforms.setNode(board, {
54
- points: newPoints
55
- }, [index]);
56
- MERGING.set(board, true);
57
- return PlaitNode.get(board, [index]);
58
- });
59
- PlaitBoard.getBoardContainer(board).classList.add('element-moving');
60
- addMovingElements(board, currentElements);
61
- });
62
- }
63
- }
64
- if (isPreventDefault) {
65
- // 阻止 move 过程中触发画布滚动行为
66
- event.preventDefault();
67
- }
68
- mousemove(event);
69
- };
70
- board.globalMousemove = event => {
71
- if (startPoint) {
72
- const inPlaitBoardElement = isInPlaitBoard(board, event.x, event.y);
73
- if (!inPlaitBoardElement) {
74
- cancelMove(board);
75
- }
76
- }
77
- globalMousemove(event);
78
- };
79
- board.globalMouseup = event => {
80
- isPreventDefault = false;
81
- if (startPoint) {
82
- cancelMove(board);
83
- }
84
- globalMouseup(event);
85
- };
86
- function cancelMove(board) {
87
- startPoint = null;
88
- offsetX = 0;
89
- offsetY = 0;
90
- activeElements = [];
91
- removeMovingElements(board);
92
- MERGING.set(board, false);
93
- PlaitBoard.getBoardContainer(board).classList.remove('element-moving');
94
- }
95
- return board;
96
- }
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-moving.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-moving.ts"],"names":[],"mappings":"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","sourcesContent":["import { BOARD_TO_HOST } from '../utils/weak-maps';\nimport { PlaitBoard } from '../interfaces/board';\nimport { isInPlaitBoard, transformPoint } from '../utils/board';\nimport { toPoint } from '../utils/dom/common';\nimport { Point } from '../interfaces/point';\nimport { Transforms } from '../transforms';\nimport { PlaitElement } from '../interfaces/element';\nimport { getHitElementOfRoot, getSelectedElements, isHitElements } from '../utils/selected-element';\nimport { PlaitNode } from '../interfaces/node';\nimport { throttleRAF } from '../utils/common';\nimport { addMovingElements, removeMovingElements } from '../utils/moving-element';\nimport { MERGING } from '../interfaces/history';\nimport { Range } from '../interfaces';\n\nexport function withMoving(board: PlaitBoard) {\n    const { mousedown, mousemove, globalMouseup, globalMousemove } = board;\n\n    let offsetX = 0;\n    let offsetY = 0;\n    let isPreventDefault = false;\n    let startPoint: Point | null;\n    let activeElements: PlaitElement[] = [];\n\n    board.mousedown = event => {\n        const host = BOARD_TO_HOST.get(board);\n        const point = transformPoint(board, toPoint(event.x, event.y, host!));\n        const range = { anchor: point, focus: point } as Range;\n        let movableElements = board.children.filter(item => board.isMovable(item));\n        if (movableElements.length) {\n            startPoint = point;\n            const selectedRootElements = getSelectedElements(board).filter(item => movableElements.includes(item));\n            const hitElement = getHitElementOfRoot(board, movableElements, range);\n            if (hitElement && selectedRootElements.includes(hitElement)) {\n                activeElements = selectedRootElements;\n            } else if (hitElement) {\n                activeElements = [hitElement];\n            }\n        }\n\n        mousedown(event);\n    };\n\n    board.mousemove = event => {\n        if (startPoint && activeElements.length && !PlaitBoard.hasBeenTextEditing(board)) {\n            if (!isPreventDefault) {\n                isPreventDefault = true;\n            }\n            const host = BOARD_TO_HOST.get(board);\n            const endPoint = transformPoint(board, toPoint(event.x, event.y, host!));\n            offsetX = endPoint[0] - startPoint[0];\n            offsetY = endPoint[1] - startPoint[1];\n            const offsetBuffer = 5;\n            if (Math.abs(offsetX) > offsetBuffer || Math.abs(offsetY) > offsetBuffer) {\n                throttleRAF(() => {\n                    const currentElements = activeElements.map(activeElement => {\n                        const points = activeElement.points || [];\n                        const [x, y] = activeElement.points![0];\n                        const newPoints = points.map(p => [p[0] + offsetX, p[1] + offsetY]) as Point[];\n                        const index = board.children.findIndex(item => item.id === activeElement.id);\n                        Transforms.setNode(\n                            board,\n                            {\n                                points: newPoints\n                            },\n                            [index]\n                        );\n                        MERGING.set(board, true);\n                        return PlaitNode.get(board, [index]);\n                    });\n                    PlaitBoard.getBoardContainer(board).classList.add('element-moving');\n                    addMovingElements(board, currentElements as PlaitElement[]);\n                });\n            }\n        }\n        if (isPreventDefault) {\n            // 阻止 move 过程中触发画布滚动行为\n            event.preventDefault();\n        }\n        mousemove(event);\n    };\n\n    board.globalMousemove = event => {\n        if (startPoint) {\n            const inPlaitBoardElement = isInPlaitBoard(board, event.x, event.y);\n            if (!inPlaitBoardElement) {\n                cancelMove(board);\n            }\n        }\n        globalMousemove(event);\n    };\n\n    board.globalMouseup = event => {\n        isPreventDefault = false;\n        if (startPoint) {\n            cancelMove(board);\n        }\n        globalMouseup(event);\n    };\n\n    function cancelMove(board: PlaitBoard) {\n        startPoint = null;\n        offsetX = 0;\n        offsetY = 0;\n        activeElements = [];\n        removeMovingElements(board);\n        MERGING.set(board, false);\n        PlaitBoard.getBoardContainer(board).classList.remove('element-moving');\n    }\n\n    return board;\n}\n"]}
@@ -1,183 +0,0 @@
1
- import { PlaitBoard } from '../interfaces/board';
2
- import { Transforms } from '../transforms';
3
- import { transformPoint } from '../utils/board';
4
- import { isMainPointer, toPoint } from '../utils/dom/common';
5
- import { RectangleClient } from '../interfaces/rectangle-client';
6
- import { cacheSelectedElements, clearSelectedElement, getHitElements, getSelectedElements } from '../utils/selected-element';
7
- import { PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';
8
- import { getRectangleByElements } from '../utils/element';
9
- import { BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_TEMPORARY_ELEMENTS } from '../utils/weak-maps';
10
- import { ATTACHED_ELEMENT_CLASS_NAME } from '../constants/selection';
11
- import { preventTouchMove, throttleRAF } from '../utils';
12
- import { PlaitPluginKey } from '../interfaces/plugin-key';
13
- export function withSelection(board) {
14
- const { pointerDown, globalPointerMove, globalPointerUp, onChange } = board;
15
- let start = null;
16
- let end = null;
17
- let selectionMovingG;
18
- let selectionOuterG;
19
- let previousSelectedElements;
20
- // prevent text from being selected when user pressed main pointer and is moving
21
- let needPreventNativeSelectionWhenMoving = false;
22
- board.pointerDown = (event) => {
23
- if (event.target instanceof Element && !event.target.closest('.plait-richtext-container')) {
24
- needPreventNativeSelectionWhenMoving = true;
25
- }
26
- if (!isMainPointer(event)) {
27
- pointerDown(event);
28
- return;
29
- }
30
- const options = board.getPluginOptions(PlaitPluginKey.withSelection);
31
- const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
32
- const range = { anchor: point, focus: point };
33
- const hitElements = getHitElements(board, { ranges: [range] });
34
- const selectedElements = getSelectedElements(board);
35
- if (hitElements.length === 1 && selectedElements.includes(hitElements[0]) && !options.isDisabledSelect) {
36
- pointerDown(event);
37
- return;
38
- }
39
- if (PlaitBoard.isPointer(board, PlaitPointerType.selection) &&
40
- hitElements.length === 0 &&
41
- options.isMultiple &&
42
- !options.isDisabledSelect) {
43
- start = point;
44
- preventTouchMove(board, true);
45
- }
46
- Transforms.setSelection(board, { ranges: [range] });
47
- pointerDown(event);
48
- };
49
- board.globalPointerMove = (event) => {
50
- if (needPreventNativeSelectionWhenMoving) {
51
- // prevent text from being selected
52
- event.preventDefault();
53
- }
54
- if (start) {
55
- const movedTarget = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
56
- const { x, y, width, height } = RectangleClient.toRectangleClient([start, movedTarget]);
57
- selectionMovingG?.remove();
58
- if (Math.hypot(width, height) > 5) {
59
- end = movedTarget;
60
- throttleRAF(() => {
61
- if (start && end) {
62
- Transforms.setSelection(board, { ranges: [{ anchor: start, focus: end }] });
63
- }
64
- });
65
- setSelectionMoving(board);
66
- const rough = PlaitBoard.getRoughSVG(board);
67
- selectionMovingG = rough.rectangle(x, y, width, height, {
68
- stroke: SELECTION_BORDER_COLOR,
69
- strokeWidth: 1,
70
- fill: SELECTION_FILL_COLOR,
71
- fillStyle: 'solid'
72
- });
73
- PlaitBoard.getHost(board).append(selectionMovingG);
74
- }
75
- }
76
- globalPointerMove(event);
77
- };
78
- board.globalPointerUp = (event) => {
79
- if (start && end) {
80
- selectionMovingG?.remove();
81
- clearSelectionMoving(board);
82
- Transforms.setSelection(board, { ranges: [{ anchor: start, focus: end }] });
83
- }
84
- if (PlaitBoard.isFocus(board)) {
85
- const isInBoard = event.target instanceof Node && PlaitBoard.getBoardContainer(board).contains(event.target);
86
- const isInDocument = event.target instanceof Node && document.contains(event.target);
87
- const isAttachedElement = event.target instanceof Element && event.target.closest(`.${ATTACHED_ELEMENT_CLASS_NAME}`);
88
- // Clear selection when mouse board outside area
89
- // The framework needs to determine whether the board is focused through selection
90
- if (!isInBoard && !start && !isAttachedElement && isInDocument) {
91
- Transforms.setSelection(board, null);
92
- }
93
- }
94
- start = null;
95
- end = null;
96
- needPreventNativeSelectionWhenMoving = false;
97
- preventTouchMove(board, false);
98
- globalPointerUp(event);
99
- };
100
- board.onChange = () => {
101
- const options = board.getPluginOptions(PlaitPluginKey.withSelection);
102
- if (options.isDisabledSelect) {
103
- selectionOuterG?.remove();
104
- clearSelectedElement(board);
105
- }
106
- // calc selected elements entry
107
- if (board.pointer !== PlaitPointerType.hand && !options.isDisabledSelect) {
108
- try {
109
- if (board.operations.find(value => value.type === 'set_selection')) {
110
- selectionOuterG?.remove();
111
- const temporaryElements = getTemporaryElements(board);
112
- let elements = temporaryElements ? temporaryElements : getHitElements(board);
113
- if (!options.isMultiple && elements.length > 1) {
114
- elements = [elements[0]];
115
- }
116
- cacheSelectedElements(board, elements);
117
- previousSelectedElements = elements;
118
- const { width, height } = getRectangleByElements(board, elements, false);
119
- if (width > 0 && height > 0 && elements.length > 1) {
120
- selectionOuterG = createSelectionOuterG(board, elements);
121
- selectionOuterG.classList.add('selection-outer');
122
- PlaitBoard.getHost(board).append(selectionOuterG);
123
- }
124
- deleteTemporaryElements(board);
125
- }
126
- else {
127
- // wait node destroy and remove selected element state
128
- setTimeout(() => {
129
- const currentSelectedElements = getSelectedElements(board);
130
- if (currentSelectedElements.length && currentSelectedElements.length > 1) {
131
- const selectedElementChange = currentSelectedElements.some(item => !previousSelectedElements.includes(item));
132
- if (selectedElementChange) {
133
- selectionOuterG?.remove();
134
- selectionOuterG = createSelectionOuterG(board, currentSelectedElements);
135
- selectionOuterG.classList.add('selection-outer');
136
- PlaitBoard.getHost(board).append(selectionOuterG);
137
- }
138
- }
139
- else {
140
- selectionOuterG?.remove();
141
- }
142
- });
143
- }
144
- }
145
- catch (error) {
146
- console.error(error);
147
- }
148
- }
149
- onChange();
150
- };
151
- board.setPluginOptions(PlaitPluginKey.withSelection, {
152
- isMultiple: true,
153
- isDisabledSelect: false
154
- });
155
- return board;
156
- }
157
- export function getTemporaryElements(board) {
158
- return BOARD_TO_TEMPORARY_ELEMENTS.get(board);
159
- }
160
- export function deleteTemporaryElements(board) {
161
- BOARD_TO_TEMPORARY_ELEMENTS.delete(board);
162
- }
163
- export function isSelectionMoving(board) {
164
- return !!BOARD_TO_IS_SELECTION_MOVING.get(board);
165
- }
166
- export function setSelectionMoving(board) {
167
- PlaitBoard.getBoardContainer(board).classList.add('selection-moving');
168
- BOARD_TO_IS_SELECTION_MOVING.set(board, true);
169
- }
170
- export function clearSelectionMoving(board) {
171
- PlaitBoard.getBoardContainer(board).classList.remove('selection-moving');
172
- BOARD_TO_IS_SELECTION_MOVING.delete(board);
173
- }
174
- export function createSelectionOuterG(board, selectElements) {
175
- const { x, y, width, height } = getRectangleByElements(board, selectElements, false);
176
- const rough = PlaitBoard.getRoughSVG(board);
177
- return rough.rectangle(x - 2.5, y - 2.5, width + 5, height + 5, {
178
- stroke: SELECTION_BORDER_COLOR,
179
- strokeWidth: 1,
180
- fillStyle: 'solid'
181
- });
182
- }
183
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-selection.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-selection.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\nimport { Transforms } from '../transforms';\nimport { transformPoint } from '../utils/board';\nimport { isMainPointer, toPoint } from '../utils/dom/common';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport { cacheSelectedElements, clearSelectedElement, getHitElements, getSelectedElements } from '../utils/selected-element';\nimport { PlaitElement, PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } 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 { preventTouchMove, 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    isDisabledSelect: boolean;\n}\n\nexport function withSelection(board: PlaitBoard) {\n    const { pointerDown, globalPointerMove, globalPointerUp, 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    // prevent text from being selected when user pressed main pointer and is moving\n    let needPreventNativeSelectionWhenMoving = false;\n\n    board.pointerDown = (event: PointerEvent) => {\n        if (event.target instanceof Element && !event.target.closest('.plait-richtext-container')) {\n            needPreventNativeSelectionWhenMoving = true;\n        }\n\n        if (!isMainPointer(event)) {\n            pointerDown(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 range = { anchor: point, focus: point };\n        const hitElements = getHitElements(board, { ranges: [range] });\n        const selectedElements = getSelectedElements(board);\n\n        if (hitElements.length === 1 && selectedElements.includes(hitElements[0]) && !options.isDisabledSelect) {\n            pointerDown(event);\n            return;\n        }\n\n        if (\n            PlaitBoard.isPointer(board, PlaitPointerType.selection) &&\n            hitElements.length === 0 &&\n            options.isMultiple &&\n            !options.isDisabledSelect\n        ) {\n            start = point;\n            preventTouchMove(board, true);\n        }\n\n        Transforms.setSelection(board, { ranges: [range] });\n\n        pointerDown(event);\n    };\n\n    board.globalPointerMove = (event: PointerEvent) => {\n        if (needPreventNativeSelectionWhenMoving) {\n            // prevent text from being selected\n            event.preventDefault();\n        }\n\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        globalPointerMove(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\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.getBoardContainer(board).contains(event.target);\n            const isInDocument = event.target instanceof Node && document.contains(event.target);\n            const isAttachedElement = event.target instanceof Element && event.target.closest(`.${ATTACHED_ELEMENT_CLASS_NAME}`);\n            // Clear selection when mouse board outside area\n            // The framework needs to determine whether the board is focused through selection\n            if (!isInBoard && !start && !isAttachedElement && isInDocument) {\n                Transforms.setSelection(board, null);\n            }\n        }\n\n        start = null;\n        end = null;\n        needPreventNativeSelectionWhenMoving = false;\n        preventTouchMove(board, false);\n        globalPointerUp(event);\n    };\n\n    board.onChange = () => {\n        const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n        if (options.isDisabledSelect) {\n            selectionOuterG?.remove();\n            clearSelectedElement(board);\n        }\n\n        // calc selected elements entry\n        if (board.pointer !== PlaitPointerType.hand && !options.isDisabledSelect) {\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                    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, {\n        isMultiple: true,\n        isDisabledSelect: false\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.getBoardContainer(board).classList.add('selection-moving');\n    BOARD_TO_IS_SELECTION_MOVING.set(board, true);\n}\n\nexport function clearSelectionMoving(board: PlaitBoard) {\n    PlaitBoard.getBoardContainer(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"]}
@@ -1,12 +0,0 @@
1
- import { GeneralTransforms } from './general';
2
- import { NodeTransforms } from './node';
3
- import { SelectionTransforms } from './selection';
4
- import { ViewportTransforms } from './viewport';
5
- export { BoardTransforms } from './board';
6
- export const Transforms = {
7
- ...GeneralTransforms,
8
- ...ViewportTransforms,
9
- ...SelectionTransforms,
10
- ...NodeTransforms
11
- };
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy90cmFuc2Zvcm1zL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUM5QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ3hDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUNsRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFFaEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUMxQyxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQWtGO0lBQ3JHLEdBQUcsaUJBQWlCO0lBQ3BCLEdBQUcsa0JBQWtCO0lBQ3JCLEdBQUcsbUJBQW1CO0lBQ3RCLEdBQUcsY0FBYztDQUNwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR2VuZXJhbFRyYW5zZm9ybXMgfSBmcm9tICcuL2dlbmVyYWwnO1xuaW1wb3J0IHsgTm9kZVRyYW5zZm9ybXMgfSBmcm9tICcuL25vZGUnO1xuaW1wb3J0IHsgU2VsZWN0aW9uVHJhbnNmb3JtcyB9IGZyb20gJy4vc2VsZWN0aW9uJztcbmltcG9ydCB7IFZpZXdwb3J0VHJhbnNmb3JtcyB9IGZyb20gJy4vdmlld3BvcnQnO1xuXG5leHBvcnQgeyBCb2FyZFRyYW5zZm9ybXMgfSBmcm9tICcuL2JvYXJkJztcbmV4cG9ydCBjb25zdCBUcmFuc2Zvcm1zOiBHZW5lcmFsVHJhbnNmb3JtcyAmIFZpZXdwb3J0VHJhbnNmb3JtcyAmIFNlbGVjdGlvblRyYW5zZm9ybXMgJiBOb2RlVHJhbnNmb3JtcyA9IHtcbiAgICAuLi5HZW5lcmFsVHJhbnNmb3JtcyxcbiAgICAuLi5WaWV3cG9ydFRyYW5zZm9ybXMsXG4gICAgLi4uU2VsZWN0aW9uVHJhbnNmb3JtcyxcbiAgICAuLi5Ob2RlVHJhbnNmb3Jtc1xufTtcbiJdfQ==
@@ -1,16 +0,0 @@
1
- import { BOARD_TO_TEMPORARY_ELEMENTS } from '../utils/weak-maps';
2
- export function setSelection(board, selection) {
3
- const operation = { type: 'set_selection', properties: board.selection, newProperties: selection };
4
- board.apply(operation);
5
- }
6
- export const SelectionTransforms = {
7
- setSelection,
8
- setSelectionWithTemporaryElements
9
- };
10
- export function setSelectionWithTemporaryElements(board, elements) {
11
- setTimeout(() => {
12
- BOARD_TO_TEMPORARY_ELEMENTS.set(board, elements);
13
- setSelection(board, { ranges: [] });
14
- });
15
- }
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvdHJhbnNmb3Jtcy9zZWxlY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFHakUsTUFBTSxVQUFVLFlBQVksQ0FBQyxLQUFpQixFQUFFLFNBQTJCO0lBQ3ZFLE1BQU0sU0FBUyxHQUEwQixFQUFFLElBQUksRUFBRSxlQUFlLEVBQUUsVUFBVSxFQUFFLEtBQUssQ0FBQyxTQUFTLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxDQUFDO0lBQzFILEtBQUssQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDM0IsQ0FBQztBQU9ELE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUF3QjtJQUNwRCxZQUFZO0lBQ1osaUNBQWlDO0NBQ3BDLENBQUM7QUFHRixNQUFNLFVBQVUsaUNBQWlDLENBQUMsS0FBaUIsRUFBRSxRQUF3QjtJQUN6RixVQUFVLENBQUMsR0FBRyxFQUFFO1FBQ1osMkJBQTJCLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxRQUFRLENBQUMsQ0FBQztRQUNqRCxZQUFZLENBQUMsS0FBSyxFQUFFLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDeEMsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2V0U2VsZWN0aW9uT3BlcmF0aW9uIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9vcGVyYXRpb24nO1xuaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJy4uL2ludGVyZmFjZXMvYm9hcmQnO1xuaW1wb3J0IHsgU2VsZWN0aW9uIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9zZWxlY3Rpb24nO1xuaW1wb3J0IHsgQk9BUkRfVE9fVEVNUE9SQVJZX0VMRU1FTlRTIH0gZnJvbSAnLi4vdXRpbHMvd2Vhay1tYXBzJztcbmltcG9ydCB7IFBsYWl0RWxlbWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMvZWxlbWVudCc7XG5cbmV4cG9ydCBmdW5jdGlvbiBzZXRTZWxlY3Rpb24oYm9hcmQ6IFBsYWl0Qm9hcmQsIHNlbGVjdGlvbjogU2VsZWN0aW9uIHwgbnVsbCkge1xuICAgIGNvbnN0IG9wZXJhdGlvbjogU2V0U2VsZWN0aW9uT3BlcmF0aW9uID0geyB0eXBlOiAnc2V0X3NlbGVjdGlvbicsIHByb3BlcnRpZXM6IGJvYXJkLnNlbGVjdGlvbiwgbmV3UHJvcGVydGllczogc2VsZWN0aW9uIH07XG4gICAgYm9hcmQuYXBwbHkob3BlcmF0aW9uKTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTZWxlY3Rpb25UcmFuc2Zvcm1zIHtcbiAgICBzZXRTZWxlY3Rpb246IChib2FyZDogUGxhaXRCb2FyZCwgc2VsZWN0aW9uOiBTZWxlY3Rpb24gfCBudWxsKSA9PiB2b2lkO1xuICAgIHNldFNlbGVjdGlvbldpdGhUZW1wb3JhcnlFbGVtZW50czogKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50czogUGxhaXRFbGVtZW50W10pID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBjb25zdCBTZWxlY3Rpb25UcmFuc2Zvcm1zOiBTZWxlY3Rpb25UcmFuc2Zvcm1zID0ge1xuICAgIHNldFNlbGVjdGlvbixcbiAgICBzZXRTZWxlY3Rpb25XaXRoVGVtcG9yYXJ5RWxlbWVudHNcbn07XG5cblxuZXhwb3J0IGZ1bmN0aW9uIHNldFNlbGVjdGlvbldpdGhUZW1wb3JhcnlFbGVtZW50cyhib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudHM6IFBsYWl0RWxlbWVudFtdKSB7XG4gICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgIEJPQVJEX1RPX1RFTVBPUkFSWV9FTEVNRU5UUy5zZXQoYm9hcmQsIGVsZW1lbnRzKTtcbiAgICAgICAgc2V0U2VsZWN0aW9uKGJvYXJkLCB7IHJhbmdlczogW10gfSk7XG4gICAgfSk7XG59Il19
@@ -1,53 +0,0 @@
1
- import { POINTER_BUTTON } from '../../constants';
2
- export const NS = 'http://www.w3.org/2000/svg';
3
- export function toPoint(x, y, container) {
4
- const rect = container.getBoundingClientRect();
5
- return [x - rect.x, y - rect.y];
6
- }
7
- export function createG() {
8
- const newG = document.createElementNS(NS, 'g');
9
- return newG;
10
- }
11
- export function createPath() {
12
- const newG = document.createElementNS(NS, 'path');
13
- return newG;
14
- }
15
- export function createSVG() {
16
- const svg = document.createElementNS(NS, 'svg');
17
- return svg;
18
- }
19
- export function createText(x, y, fill, textContent) {
20
- var text = document.createElementNS(NS, 'text');
21
- text.setAttribute('x', `${x}`);
22
- text.setAttribute('y', `${y}`);
23
- text.setAttribute('fill', fill);
24
- text.textContent = textContent;
25
- return text;
26
- }
27
- /**
28
- * Check if a DOM node is an element node.
29
- */
30
- export const isDOMElement = (value) => {
31
- return isDOMNode(value) && value.nodeType === 1;
32
- };
33
- /**
34
- * Check if a value is a DOM node.
35
- */
36
- export const isDOMNode = (value) => {
37
- return value instanceof window.Node;
38
- };
39
- export const hasInputOrTextareaTarget = (target) => {
40
- if (isDOMElement(target)) {
41
- if (target.tagName === 'INPUT' || target.tagName === 'TEXTAREA') {
42
- return true;
43
- }
44
- }
45
- return false;
46
- };
47
- export const isSecondaryPointer = (event) => {
48
- return event.button === POINTER_BUTTON.SECONDARY;
49
- };
50
- export const isMainPointer = (event) => {
51
- return event.button === POINTER_BUTTON.MAIN;
52
- };
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvdXRpbHMvZG9tL2NvbW1vbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFHakQsTUFBTSxDQUFDLE1BQU0sRUFBRSxHQUFHLDRCQUE0QixDQUFDO0FBRS9DLE1BQU0sVUFBVSxPQUFPLENBQUMsQ0FBUyxFQUFFLENBQVMsRUFBRSxTQUFxQjtJQUMvRCxNQUFNLElBQUksR0FBRyxTQUFTLENBQUMscUJBQXFCLEVBQUUsQ0FBQztJQUMvQyxPQUFPLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNwQyxDQUFDO0FBRUQsTUFBTSxVQUFVLE9BQU87SUFDbkIsTUFBTSxJQUFJLEdBQUcsUUFBUSxDQUFDLGVBQWUsQ0FBQyxFQUFFLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDL0MsT0FBTyxJQUFJLENBQUM7QUFDaEIsQ0FBQztBQUVELE1BQU0sVUFBVSxVQUFVO0lBQ3RCLE1BQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxlQUFlLENBQUMsRUFBRSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ2xELE9BQU8sSUFBSSxDQUFDO0FBQ2hCLENBQUM7QUFFRCxNQUFNLFVBQVUsU0FBUztJQUNyQixNQUFNLEdBQUcsR0FBRyxRQUFRLENBQUMsZUFBZSxDQUFDLEVBQUUsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNoRCxPQUFPLEdBQUcsQ0FBQztBQUNmLENBQUM7QUFFRCxNQUFNLFVBQVUsVUFBVSxDQUFDLENBQVMsRUFBRSxDQUFTLEVBQUUsSUFBWSxFQUFFLFdBQW1CO0lBQzlFLElBQUksSUFBSSxHQUFHLFFBQVEsQ0FBQyxlQUFlLENBQUMsRUFBRSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ2hELElBQUksQ0FBQyxZQUFZLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUMvQixJQUFJLENBQUMsWUFBWSxDQUFDLEdBQUcsRUFBRSxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDL0IsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDaEMsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUM7SUFDL0IsT0FBTyxJQUFJLENBQUM7QUFDaEIsQ0FBQztBQUVEOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLENBQUMsS0FBVSxFQUFvQixFQUFFO0lBQ3pELE9BQU8sU0FBUyxDQUFDLEtBQUssQ0FBQyxJQUFJLEtBQUssQ0FBQyxRQUFRLEtBQUssQ0FBQyxDQUFDO0FBQ3BELENBQUMsQ0FBQztBQUVGOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUFHLENBQUMsS0FBVSxFQUFpQixFQUFFO0lBQ25ELE9BQU8sS0FBSyxZQUFZLE1BQU0sQ0FBQyxJQUFJLENBQUM7QUFDeEMsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcsQ0FBQyxNQUEwQixFQUFFLEVBQUU7SUFDbkUsSUFBSSxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUU7UUFDdEIsSUFBSSxNQUFNLENBQUMsT0FBTyxLQUFLLE9BQU8sSUFBSSxNQUFNLENBQUMsT0FBTyxLQUFLLFVBQVUsRUFBRTtZQUM3RCxPQUFPLElBQUksQ0FBQztTQUNmO0tBQ0o7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUNwRCxPQUFPLEtBQUssQ0FBQyxNQUFNLEtBQUssY0FBYyxDQUFDLFNBQVMsQ0FBQztBQUNyRCxDQUFDLENBQUE7QUFFRCxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUcsQ0FBQyxLQUFpQixFQUFFLEVBQUU7SUFDL0MsT0FBTyxLQUFLLENBQUMsTUFBTSxLQUFLLGNBQWMsQ0FBQyxJQUFJLENBQUM7QUFDaEQsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUE9JTlRFUl9CVVRUT04gfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgUG9pbnQgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL3BvaW50JztcblxuZXhwb3J0IGNvbnN0IE5TID0gJ2h0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnJztcblxuZXhwb3J0IGZ1bmN0aW9uIHRvUG9pbnQoeDogbnVtYmVyLCB5OiBudW1iZXIsIGNvbnRhaW5lcjogU1ZHRWxlbWVudCk6IFBvaW50IHtcbiAgICBjb25zdCByZWN0ID0gY29udGFpbmVyLmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xuICAgIHJldHVybiBbeCAtIHJlY3QueCwgeSAtIHJlY3QueV07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVHKCkge1xuICAgIGNvbnN0IG5ld0cgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50TlMoTlMsICdnJyk7XG4gICAgcmV0dXJuIG5ld0c7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVQYXRoKCkge1xuICAgIGNvbnN0IG5ld0cgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50TlMoTlMsICdwYXRoJyk7XG4gICAgcmV0dXJuIG5ld0c7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTVkcoKSB7XG4gICAgY29uc3Qgc3ZnID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudE5TKE5TLCAnc3ZnJyk7XG4gICAgcmV0dXJuIHN2Zztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVRleHQoeDogbnVtYmVyLCB5OiBudW1iZXIsIGZpbGw6IHN0cmluZywgdGV4dENvbnRlbnQ6IHN0cmluZykge1xuICAgIHZhciB0ZXh0ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudE5TKE5TLCAndGV4dCcpO1xuICAgIHRleHQuc2V0QXR0cmlidXRlKCd4JywgYCR7eH1gKTtcbiAgICB0ZXh0LnNldEF0dHJpYnV0ZSgneScsIGAke3l9YCk7XG4gICAgdGV4dC5zZXRBdHRyaWJ1dGUoJ2ZpbGwnLCBmaWxsKTtcbiAgICB0ZXh0LnRleHRDb250ZW50ID0gdGV4dENvbnRlbnQ7XG4gICAgcmV0dXJuIHRleHQ7XG59XG5cbi8qKlxuICogQ2hlY2sgaWYgYSBET00gbm9kZSBpcyBhbiBlbGVtZW50IG5vZGUuXG4gKi9cbmV4cG9ydCBjb25zdCBpc0RPTUVsZW1lbnQgPSAodmFsdWU6IGFueSk6IHZhbHVlIGlzIEVsZW1lbnQgPT4ge1xuICAgIHJldHVybiBpc0RPTU5vZGUodmFsdWUpICYmIHZhbHVlLm5vZGVUeXBlID09PSAxO1xufTtcblxuLyoqXG4gKiBDaGVjayBpZiBhIHZhbHVlIGlzIGEgRE9NIG5vZGUuXG4gKi9cbmV4cG9ydCBjb25zdCBpc0RPTU5vZGUgPSAodmFsdWU6IGFueSk6IHZhbHVlIGlzIE5vZGUgPT4ge1xuICAgIHJldHVybiB2YWx1ZSBpbnN0YW5jZW9mIHdpbmRvdy5Ob2RlO1xufTtcblxuZXhwb3J0IGNvbnN0IGhhc0lucHV0T3JUZXh0YXJlYVRhcmdldCA9ICh0YXJnZXQ6IEV2ZW50VGFyZ2V0IHwgbnVsbCkgPT4ge1xuICAgIGlmIChpc0RPTUVsZW1lbnQodGFyZ2V0KSkge1xuICAgICAgICBpZiAodGFyZ2V0LnRhZ05hbWUgPT09ICdJTlBVVCcgfHwgdGFyZ2V0LnRhZ05hbWUgPT09ICdURVhUQVJFQScpIHtcbiAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICB9XG4gICAgfVxuICAgIHJldHVybiBmYWxzZTtcbn07XG5cbmV4cG9ydCBjb25zdCBpc1NlY29uZGFyeVBvaW50ZXIgPSAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHtcbiAgICByZXR1cm4gZXZlbnQuYnV0dG9uID09PSBQT0lOVEVSX0JVVFRPTi5TRUNPTkRBUlk7XG59XG5cbmV4cG9ydCBjb25zdCBpc01haW5Qb2ludGVyID0gKGV2ZW50OiBNb3VzZUV2ZW50KSA9PiB7XG4gICAgcmV0dXJuIGV2ZW50LmJ1dHRvbiA9PT0gUE9JTlRFUl9CVVRUT04uTUFJTjtcbn1cbiJdfQ==