@plait/core 0.52.0 → 0.53.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/board/board.component.d.ts +1 -1
- package/constants/cursor.d.ts +1 -0
- package/esm2022/board/board.component.mjs +3 -3
- package/esm2022/constants/cursor.mjs +2 -1
- package/esm2022/interfaces/board.mjs +1 -1
- package/esm2022/interfaces/path.mjs +2 -2
- package/esm2022/plugins/create-board.mjs +3 -2
- package/esm2022/plugins/with-moving.mjs +36 -17
- package/esm2022/plugins/with-related-fragment.mjs +20 -0
- package/esm2022/plugins/with-selection.mjs +32 -98
- package/esm2022/public-api.mjs +2 -1
- package/esm2022/transforms/group.mjs +47 -0
- package/esm2022/transforms/index.mjs +2 -1
- package/esm2022/utils/angle.mjs +75 -0
- package/esm2022/utils/debug.mjs +76 -0
- package/esm2022/utils/element.mjs +17 -5
- package/esm2022/utils/group.mjs +79 -84
- package/esm2022/utils/helper.mjs +10 -1
- package/esm2022/utils/index.mjs +2 -1
- package/esm2022/utils/math.mjs +11 -1
- package/esm2022/utils/selection.mjs +89 -3
- package/esm2022/utils/touch.mjs +15 -4
- package/fesm2022/plait-core.mjs +1332 -1073
- package/fesm2022/plait-core.mjs.map +1 -1
- package/interfaces/board.d.ts +1 -0
- package/package.json +1 -1
- package/plugins/with-moving.d.ts +1 -1
- package/plugins/with-related-fragment.d.ts +2 -0
- package/public-api.d.ts +1 -0
- package/transforms/group.d.ts +7 -0
- package/transforms/index.d.ts +1 -0
- package/utils/angle.d.ts +13 -0
- package/utils/debug.d.ts +13 -0
- package/utils/group.d.ts +15 -15
- package/utils/helper.d.ts +2 -0
- package/utils/index.d.ts +1 -0
- package/utils/math.d.ts +8 -0
- package/utils/selection.d.ts +6 -3
- package/utils/touch.d.ts +1 -1
- package/esm2022/plugins/with-group.mjs +0 -27
- package/plugins/with-group.d.ts +0 -2
|
@@ -1,10 +1,15 @@
|
|
|
1
|
-
import { getSelectedElements } from '.';
|
|
2
1
|
import { ACTIVE_STROKE_WIDTH, SELECTION_RECTANGLE_CLASS_NAME } from '../constants';
|
|
3
2
|
import { PlaitBoard, PlaitPluginKey, PlaitPointerType, RectangleClient, SELECTION_BORDER_COLOR } from '../interfaces';
|
|
4
|
-
import { drawRectangle } from '../public-api';
|
|
5
3
|
import { setDragging } from './dnd';
|
|
6
4
|
import { getRectangleByElements } from './element';
|
|
7
5
|
import { BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_TEMPORARY_ELEMENTS } from './weak-maps';
|
|
6
|
+
import { drawRectangle } from './drawing/rectangle';
|
|
7
|
+
import { cacheSelectedElements, getSelectedElements } from './selected-element';
|
|
8
|
+
import { getSelectionAngle } from './angle';
|
|
9
|
+
import { setAngleForG } from './dom';
|
|
10
|
+
import { filterSelectedGroups, getAllElementsInGroup, getElementsInGroup, getElementsInGroupByElement, getGroupByElement } from './group';
|
|
11
|
+
import { uniqueById } from './helper';
|
|
12
|
+
import { Selection } from '../interfaces/selection';
|
|
8
13
|
export function isSelectionMoving(board) {
|
|
9
14
|
return !!BOARD_TO_IS_SELECTION_MOVING.get(board);
|
|
10
15
|
}
|
|
@@ -51,8 +56,89 @@ export function createSelectionRectangleG(board) {
|
|
|
51
56
|
});
|
|
52
57
|
selectionRectangleG.classList.add(SELECTION_RECTANGLE_CLASS_NAME);
|
|
53
58
|
PlaitBoard.getElementActiveHost(board).append(selectionRectangleG);
|
|
59
|
+
const angle = getSelectionAngle(elements);
|
|
60
|
+
if (angle) {
|
|
61
|
+
setAngleForG(selectionRectangleG, RectangleClient.getCenterPoint(rectangle), angle);
|
|
62
|
+
}
|
|
54
63
|
return selectionRectangleG;
|
|
55
64
|
}
|
|
56
65
|
return null;
|
|
57
66
|
}
|
|
58
|
-
|
|
67
|
+
export function setSelectedElementsWithGroup(board, elements, isShift) {
|
|
68
|
+
if (!board.selection) {
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
const selectedElements = getSelectedElements(board);
|
|
72
|
+
if (!Selection.isCollapsed(board.selection)) {
|
|
73
|
+
let newElements = [...selectedElements];
|
|
74
|
+
elements.forEach(item => {
|
|
75
|
+
if (!item.groupId) {
|
|
76
|
+
newElements.push(item);
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
newElements.push(...getElementsInGroupByElement(board, item));
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
cacheSelectedElements(board, uniqueById(newElements));
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
if (Selection.isCollapsed(board.selection)) {
|
|
86
|
+
const hitElement = elements[0];
|
|
87
|
+
const hitElementGroups = getGroupByElement(board, hitElement, true);
|
|
88
|
+
if (hitElementGroups.length) {
|
|
89
|
+
const elementsInHighestGroup = getElementsInGroup(board, hitElementGroups[hitElementGroups.length - 1], true) || [];
|
|
90
|
+
const isSelectGroupElement = selectedElements.some(element => elementsInHighestGroup.map(item => item.id).includes(element.id));
|
|
91
|
+
if (isShift) {
|
|
92
|
+
cacheSelectedElementsWithGroupOnShift(board, elements, isSelectGroupElement, elementsInHighestGroup);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
cacheSelectedElementsWithGroup(board, elements, isSelectGroupElement, hitElementGroups);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
export function cacheSelectedElementsWithGroupOnShift(board, elements, isSelectGroupElement, elementsInHighestGroup) {
|
|
101
|
+
const selectedElements = getSelectedElements(board);
|
|
102
|
+
let newElements = [...selectedElements];
|
|
103
|
+
const hitElement = elements[0];
|
|
104
|
+
let pendingElements = [];
|
|
105
|
+
if (!isSelectGroupElement) {
|
|
106
|
+
pendingElements = elementsInHighestGroup;
|
|
107
|
+
}
|
|
108
|
+
else {
|
|
109
|
+
const isHitSelectedElement = selectedElements.some(item => item.id === hitElement.id);
|
|
110
|
+
const selectedElementsInGroup = elementsInHighestGroup.filter(item => selectedElements.includes(item));
|
|
111
|
+
if (isHitSelectedElement) {
|
|
112
|
+
pendingElements = selectedElementsInGroup.filter(item => item.id !== hitElement.id);
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
pendingElements.push(...selectedElementsInGroup, ...elements);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
elementsInHighestGroup.forEach(element => {
|
|
119
|
+
if (newElements.includes(element)) {
|
|
120
|
+
newElements.splice(newElements.indexOf(element), 1);
|
|
121
|
+
}
|
|
122
|
+
});
|
|
123
|
+
if (pendingElements.length) {
|
|
124
|
+
newElements.push(...pendingElements);
|
|
125
|
+
}
|
|
126
|
+
cacheSelectedElements(board, uniqueById(newElements));
|
|
127
|
+
}
|
|
128
|
+
export function cacheSelectedElementsWithGroup(board, elements, isSelectGroupElement, hitElementGroups) {
|
|
129
|
+
let newElements = [...elements];
|
|
130
|
+
const selectedGroups = filterSelectedGroups(board, hitElementGroups);
|
|
131
|
+
if (selectedGroups.length > 0) {
|
|
132
|
+
if (selectedGroups.length > 1) {
|
|
133
|
+
newElements = getAllElementsInGroup(board, selectedGroups[selectedGroups.length - 2], true);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
const elementsInGroup = getAllElementsInGroup(board, hitElementGroups[hitElementGroups.length - 1], true);
|
|
138
|
+
if (!isSelectGroupElement) {
|
|
139
|
+
newElements = elementsInGroup;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
cacheSelectedElements(board, uniqueById(newElements));
|
|
143
|
+
}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/selection.ts"],"names":[],"mappings":"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","sourcesContent":["import { ACTIVE_STROKE_WIDTH, SELECTION_RECTANGLE_CLASS_NAME } from '../constants';\nimport { PlaitBoard, PlaitElement, PlaitGroup, PlaitPluginKey, PlaitPointerType, RectangleClient, SELECTION_BORDER_COLOR } from '../interfaces';\nimport { setDragging } from './dnd';\nimport { getRectangleByElements } from './element';\nimport { BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_TEMPORARY_ELEMENTS } from './weak-maps';\nimport { drawRectangle } from './drawing/rectangle';\nimport { cacheSelectedElements, getSelectedElements } from './selected-element';\nimport { getSelectionAngle } from './angle';\nimport { setAngleForG } from './dom';\nimport { filterSelectedGroups, getAllElementsInGroup, getElementsInGroup, getElementsInGroupByElement, getGroupByElement } from './group';\nimport { uniqueById } from './helper';\nimport { Selection } from '../interfaces/selection';\nimport { PlaitOptionsBoard } from '../plugins/with-options';\nimport { WithPluginOptions } from '../plugins/with-selection';\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    setDragging(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    setDragging(board, false);\n}\n\nexport function isHandleSelection(board: PlaitBoard) {\n    const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n    return board.pointer !== PlaitPointerType.hand && !options.isDisabledSelect && !PlaitBoard.isReadonly(board);\n}\n\nexport function isSetSelectionOperation(board: PlaitBoard) {\n    return !!board.operations.find(value => value.type === 'set_selection');\n}\n\nexport function getTemporaryElements(board: PlaitBoard) {\n    const ref = BOARD_TO_TEMPORARY_ELEMENTS.get(board);\n    if (ref) {\n        return ref.elements;\n    } else {\n        return undefined;\n    }\n}\n\nexport function getTemporaryRef(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 createSelectionRectangleG(board: PlaitBoard) {\n    const elements = getSelectedElements(board);\n    const rectangle = getRectangleByElements(board, elements, false);\n    if (rectangle.width > 0 && rectangle.height > 0 && elements.length > 1) {\n        const selectionRectangleG = drawRectangle(board, RectangleClient.inflate(rectangle, ACTIVE_STROKE_WIDTH), {\n            stroke: SELECTION_BORDER_COLOR,\n            strokeWidth: ACTIVE_STROKE_WIDTH,\n            fillStyle: 'solid'\n        });\n        selectionRectangleG.classList.add(SELECTION_RECTANGLE_CLASS_NAME);\n        PlaitBoard.getElementActiveHost(board).append(selectionRectangleG);\n        const angle = getSelectionAngle(elements);\n        if (angle) {\n            setAngleForG(selectionRectangleG, RectangleClient.getCenterPoint(rectangle), angle);\n        }\n        return selectionRectangleG;\n    }\n    return null;\n}\n\nexport function setSelectedElementsWithGroup(board: PlaitBoard, elements: PlaitElement[], isShift: boolean) {\n    if (!board.selection) {\n        return;\n    }\n    const selectedElements = getSelectedElements(board);\n    if (!Selection.isCollapsed(board.selection)) {\n        let newElements = [...selectedElements];\n        elements.forEach(item => {\n            if (!item.groupId) {\n                newElements.push(item);\n            } else {\n                newElements.push(...getElementsInGroupByElement(board, item));\n            }\n        });\n        cacheSelectedElements(board, uniqueById(newElements));\n        return;\n    }\n    if (Selection.isCollapsed(board.selection)) {\n        const hitElement = elements[0];\n        const hitElementGroups = getGroupByElement(board, hitElement, true) as PlaitGroup[];\n        if (hitElementGroups.length) {\n            const elementsInHighestGroup = getElementsInGroup(board, hitElementGroups[hitElementGroups.length - 1], true) || [];\n            const isSelectGroupElement = selectedElements.some(element => elementsInHighestGroup.map(item => item.id).includes(element.id));\n            if (isShift) {\n                cacheSelectedElementsWithGroupOnShift(board, elements, isSelectGroupElement, elementsInHighestGroup);\n            } else {\n                cacheSelectedElementsWithGroup(board, elements, isSelectGroupElement, hitElementGroups);\n            }\n        }\n    }\n}\n\nexport function cacheSelectedElementsWithGroupOnShift(\n    board: PlaitBoard,\n    elements: PlaitElement[],\n    isSelectGroupElement: boolean,\n    elementsInHighestGroup: PlaitElement[]\n) {\n    const selectedElements = getSelectedElements(board);\n    let newElements = [...selectedElements];\n    const hitElement = elements[0];\n    let pendingElements: PlaitElement[] = [];\n    if (!isSelectGroupElement) {\n        pendingElements = elementsInHighestGroup;\n    } else {\n        const isHitSelectedElement = selectedElements.some(item => item.id === hitElement.id);\n        const selectedElementsInGroup = elementsInHighestGroup.filter(item => selectedElements.includes(item));\n        if (isHitSelectedElement) {\n            pendingElements = selectedElementsInGroup.filter(item => item.id !== hitElement.id);\n        } else {\n            pendingElements.push(...selectedElementsInGroup, ...elements);\n        }\n    }\n    elementsInHighestGroup.forEach(element => {\n        if (newElements.includes(element)) {\n            newElements.splice(newElements.indexOf(element), 1);\n        }\n    });\n    if (pendingElements.length) {\n        newElements.push(...pendingElements);\n    }\n    cacheSelectedElements(board, uniqueById(newElements));\n}\n\nexport function cacheSelectedElementsWithGroup(\n    board: PlaitBoard,\n    elements: PlaitElement[],\n    isSelectGroupElement: boolean,\n    hitElementGroups: PlaitGroup[]\n) {\n    let newElements = [...elements];\n    const selectedGroups = filterSelectedGroups(board, hitElementGroups);\n    if (selectedGroups.length > 0) {\n        if (selectedGroups.length > 1) {\n            newElements = getAllElementsInGroup(board, selectedGroups[selectedGroups.length - 2], true);\n        }\n    } else {\n        const elementsInGroup = getAllElementsInGroup(board, hitElementGroups[hitElementGroups.length - 1], true);\n        if (!isSelectGroupElement) {\n            newElements = elementsInGroup;\n        }\n    }\n    cacheSelectedElements(board, uniqueById(newElements));\n}\n"]}
|
package/esm2022/utils/touch.mjs
CHANGED
|
@@ -5,8 +5,16 @@ export const isPreventTouchMove = (board) => {
|
|
|
5
5
|
return !!BOARD_TO_TOUCH_REF.get(board);
|
|
6
6
|
};
|
|
7
7
|
export const preventTouchMove = (board, event, state) => {
|
|
8
|
-
|
|
9
|
-
|
|
8
|
+
const hostElement = PlaitBoard.getElementHost(board);
|
|
9
|
+
const activeHostElement = PlaitBoard.getElementActiveHost(board);
|
|
10
|
+
if (state) {
|
|
11
|
+
if ((event.target instanceof HTMLElement || event.target instanceof SVGElement) &&
|
|
12
|
+
(hostElement.contains(event.target) || activeHostElement.contains(event.target))) {
|
|
13
|
+
BOARD_TO_TOUCH_REF.set(board, { state, target: event.target instanceof SVGElement ? event.target : undefined });
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
BOARD_TO_TOUCH_REF.set(board, { state, target: undefined });
|
|
17
|
+
}
|
|
10
18
|
}
|
|
11
19
|
else {
|
|
12
20
|
const ref = BOARD_TO_TOUCH_REF.get(board);
|
|
@@ -24,7 +32,10 @@ export const preventTouchMove = (board, event, state) => {
|
|
|
24
32
|
*/
|
|
25
33
|
export const handleTouchTarget = (board) => {
|
|
26
34
|
const touchRef = BOARD_TO_TOUCH_REF.get(board);
|
|
27
|
-
if (touchRef &&
|
|
35
|
+
if (touchRef &&
|
|
36
|
+
touchRef.target &&
|
|
37
|
+
!PlaitBoard.getElementHost(board).contains(touchRef.target) &&
|
|
38
|
+
!PlaitBoard.getElementActiveHost(board).contains(touchRef.target)) {
|
|
28
39
|
touchRef.target.style.opacity = '0';
|
|
29
40
|
const host = createG();
|
|
30
41
|
host.appendChild(touchRef.target);
|
|
@@ -33,4 +44,4 @@ export const handleTouchTarget = (board) => {
|
|
|
33
44
|
PlaitBoard.getElementActiveHost(board).append(host);
|
|
34
45
|
}
|
|
35
46
|
};
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG91Y2guanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy91dGlscy90b3VjaC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDakQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGNBQWMsQ0FBQztBQVF2QyxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLE9BQU8sRUFBd0IsQ0FBQztBQUV0RSxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUNwRCxPQUFPLENBQUMsQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7QUFDM0MsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxLQUFpQixFQUFFLEtBQW1CLEVBQUUsS0FBYyxFQUFFLEVBQUU7SUFDdkYsTUFBTSxXQUFXLEdBQUcsVUFBVSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNyRCxNQUFNLGlCQUFpQixHQUFHLFVBQVUsQ0FBQyxvQkFBb0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNqRSxJQUFJLEtBQUssRUFBRSxDQUFDO1FBQ1IsSUFDSSxDQUFDLEtBQUssQ0FBQyxNQUFNLFlBQVksV0FBVyxJQUFJLEtBQUssQ0FBQyxNQUFNLFlBQVksVUFBVSxDQUFDO1lBQzNFLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLElBQUksaUJBQWlCLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUNsRixDQUFDO1lBQ0Msa0JBQWtCLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU0sWUFBWSxVQUFVLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUM7UUFDcEgsQ0FBQzthQUFNLENBQUM7WUFDSixrQkFBa0IsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO1FBQ2hFLENBQUM7SUFDTCxDQUFDO1NBQU0sQ0FBQztRQUNKLE1BQU0sR0FBRyxHQUFHLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMxQyxJQUFJLEdBQUcsRUFBRSxDQUFDO1lBQ04sa0JBQWtCLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2pDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUM7UUFDdkIsQ0FBQztJQUNMLENBQUM7QUFDTCxDQUFDLENBQUM7QUFFRjs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO0lBQ25ELE1BQU0sUUFBUSxHQUFHLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMvQyxJQUNJLFFBQVE7UUFDUixRQUFRLENBQUMsTUFBTTtRQUNmLENBQUMsVUFBVSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQztRQUMzRCxDQUFDLFVBQVUsQ0FBQyxvQkFBb0IsQ0FBQyxLQUFLLENBQUMsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxFQUNuRSxDQUFDO1FBQ0MsUUFBUSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUFHLEdBQUcsQ0FBQztRQUNwQyxNQUFNLElBQUksR0FBRyxPQUFPLEVBQUUsQ0FBQztRQUN2QixJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNsQyxRQUFRLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztRQUNyQixJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUNuQyxVQUFVLENBQUMsb0JBQW9CLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3hELENBQUM7QUFDTCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ib2FyZCc7XG5pbXBvcnQgeyBjcmVhdGVHIH0gZnJvbSAnLi9kb20vY29tbW9uJztcblxuZXhwb3J0IGludGVyZmFjZSBUb3VjaFJlZiB7XG4gICAgdGFyZ2V0PzogSFRNTEVsZW1lbnQgfCBTVkdFbGVtZW50O1xuICAgIHN0YXRlOiBib29sZWFuO1xuICAgIGhvc3Q/OiBTVkdHRWxlbWVudDtcbn1cblxuZXhwb3J0IGNvbnN0IEJPQVJEX1RPX1RPVUNIX1JFRiA9IG5ldyBXZWFrTWFwPFBsYWl0Qm9hcmQsIFRvdWNoUmVmPigpO1xuXG5leHBvcnQgY29uc3QgaXNQcmV2ZW50VG91Y2hNb3ZlID0gKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB7XG4gICAgcmV0dXJuICEhQk9BUkRfVE9fVE9VQ0hfUkVGLmdldChib2FyZCk7XG59O1xuXG5leHBvcnQgY29uc3QgcHJldmVudFRvdWNoTW92ZSA9IChib2FyZDogUGxhaXRCb2FyZCwgZXZlbnQ6IFBvaW50ZXJFdmVudCwgc3RhdGU6IGJvb2xlYW4pID0+IHtcbiAgICBjb25zdCBob3N0RWxlbWVudCA9IFBsYWl0Qm9hcmQuZ2V0RWxlbWVudEhvc3QoYm9hcmQpO1xuICAgIGNvbnN0IGFjdGl2ZUhvc3RFbGVtZW50ID0gUGxhaXRCb2FyZC5nZXRFbGVtZW50QWN0aXZlSG9zdChib2FyZCk7XG4gICAgaWYgKHN0YXRlKSB7XG4gICAgICAgIGlmIChcbiAgICAgICAgICAgIChldmVudC50YXJnZXQgaW5zdGFuY2VvZiBIVE1MRWxlbWVudCB8fCBldmVudC50YXJnZXQgaW5zdGFuY2VvZiBTVkdFbGVtZW50KSAmJlxuICAgICAgICAgICAgKGhvc3RFbGVtZW50LmNvbnRhaW5zKGV2ZW50LnRhcmdldCkgfHwgYWN0aXZlSG9zdEVsZW1lbnQuY29udGFpbnMoZXZlbnQudGFyZ2V0KSlcbiAgICAgICAgKSB7XG4gICAgICAgICAgICBCT0FSRF9UT19UT1VDSF9SRUYuc2V0KGJvYXJkLCB7IHN0YXRlLCB0YXJnZXQ6IGV2ZW50LnRhcmdldCBpbnN0YW5jZW9mIFNWR0VsZW1lbnQgPyBldmVudC50YXJnZXQgOiB1bmRlZmluZWQgfSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBCT0FSRF9UT19UT1VDSF9SRUYuc2V0KGJvYXJkLCB7IHN0YXRlLCB0YXJnZXQ6IHVuZGVmaW5lZCB9KTtcbiAgICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnN0IHJlZiA9IEJPQVJEX1RPX1RPVUNIX1JFRi5nZXQoYm9hcmQpO1xuICAgICAgICBpZiAocmVmKSB7XG4gICAgICAgICAgICBCT0FSRF9UT19UT1VDSF9SRUYuZGVsZXRlKGJvYXJkKTtcbiAgICAgICAgICAgIHJlZi5ob3N0Py5yZW1vdmUoKTtcbiAgICAgICAgfVxuICAgIH1cbn07XG5cbi8qKlxuICogc29tZSBpbnRlcnNlY3Rpb24gbWF5YmUgY2F1c2UgdGFyZ2V0IGlzIHJlbW92ZWQgZnJvbSBjdXJyZW50IGJyb3dzZXIgd2luZG93LFxuICogYWZ0ZXIgaXQgd2FzIHJlbW92ZWQgdG91Y2ggbW92ZSBldmVudCB3aWxsIG5vdCBiZSBmaXJlZFxuICogc28gc2Nyb2xsIGJlaGF2aW9yIHdpbGwgY2FuIG5vdCBiZSBwcmV2ZW50ZWQgaW4gbW9iaWxlIGJyb3dzZXIgZGV2aWNlXG4gKiB0aGlzIGZ1bmN0aW9uIHdpbGwgcHJldmVudCB0YXJnZXQgZWxlbWVudCBiZWluZyByZW1vdmUuXG4gKi9cbmV4cG9ydCBjb25zdCBoYW5kbGVUb3VjaFRhcmdldCA9IChib2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IHRvdWNoUmVmID0gQk9BUkRfVE9fVE9VQ0hfUkVGLmdldChib2FyZCk7XG4gICAgaWYgKFxuICAgICAgICB0b3VjaFJlZiAmJlxuICAgICAgICB0b3VjaFJlZi50YXJnZXQgJiZcbiAgICAgICAgIVBsYWl0Qm9hcmQuZ2V0RWxlbWVudEhvc3QoYm9hcmQpLmNvbnRhaW5zKHRvdWNoUmVmLnRhcmdldCkgJiZcbiAgICAgICAgIVBsYWl0Qm9hcmQuZ2V0RWxlbWVudEFjdGl2ZUhvc3QoYm9hcmQpLmNvbnRhaW5zKHRvdWNoUmVmLnRhcmdldClcbiAgICApIHtcbiAgICAgICAgdG91Y2hSZWYudGFyZ2V0LnN0eWxlLm9wYWNpdHkgPSAnMCc7XG4gICAgICAgIGNvbnN0IGhvc3QgPSBjcmVhdGVHKCk7XG4gICAgICAgIGhvc3QuYXBwZW5kQ2hpbGQodG91Y2hSZWYudGFyZ2V0KTtcbiAgICAgICAgdG91Y2hSZWYuaG9zdCA9IGhvc3Q7XG4gICAgICAgIGhvc3QuY2xhc3NMaXN0LmFkZCgndG91Y2gtdGFyZ2V0Jyk7XG4gICAgICAgIFBsYWl0Qm9hcmQuZ2V0RWxlbWVudEFjdGl2ZUhvc3QoYm9hcmQpLmFwcGVuZChob3N0KTtcbiAgICB9XG59O1xuIl19
|