@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.
Files changed (108) hide show
  1. package/fesm2022/plait-core.mjs.map +1 -1
  2. package/package.json +1 -3
  3. package/esm2022/constants/cursor.mjs +0 -13
  4. package/esm2022/constants/index.mjs +0 -20
  5. package/esm2022/constants/keycodes.mjs +0 -127
  6. package/esm2022/constants/selection.mjs +0 -6
  7. package/esm2022/constants/zoom.mjs +0 -4
  8. package/esm2022/context.mjs +0 -23
  9. package/esm2022/core/element/context-change.mjs +0 -13
  10. package/esm2022/core/element/context.mjs +0 -2
  11. package/esm2022/core/element/element-flavour.mjs +0 -140
  12. package/esm2022/core/element/element-ref.mjs +0 -2
  13. package/esm2022/core/list-render.mjs +0 -217
  14. package/esm2022/differs/default_iterable_differ.mjs +0 -614
  15. package/esm2022/differs/iterable_differs.mjs +0 -9
  16. package/esm2022/interfaces/board.mjs +0 -108
  17. package/esm2022/interfaces/custom-types.mjs +0 -5
  18. package/esm2022/interfaces/direction.mjs +0 -8
  19. package/esm2022/interfaces/element.mjs +0 -43
  20. package/esm2022/interfaces/group.mjs +0 -6
  21. package/esm2022/interfaces/history.mjs +0 -5
  22. package/esm2022/interfaces/index.mjs +0 -19
  23. package/esm2022/interfaces/node.mjs +0 -57
  24. package/esm2022/interfaces/operation.mjs +0 -96
  25. package/esm2022/interfaces/path-ref.mjs +0 -15
  26. package/esm2022/interfaces/path.mjs +0 -183
  27. package/esm2022/interfaces/plugin.mjs +0 -6
  28. package/esm2022/interfaces/point.mjs +0 -27
  29. package/esm2022/interfaces/pointer.mjs +0 -6
  30. package/esm2022/interfaces/rectangle-client.mjs +0 -171
  31. package/esm2022/interfaces/selection.mjs +0 -13
  32. package/esm2022/interfaces/svg-arc-command.mjs +0 -2
  33. package/esm2022/interfaces/theme.mjs +0 -49
  34. package/esm2022/interfaces/viewport.mjs +0 -7
  35. package/esm2022/plait-core.mjs +0 -5
  36. package/esm2022/plugins/create-board.mjs +0 -122
  37. package/esm2022/plugins/index.mjs +0 -11
  38. package/esm2022/plugins/with-board.mjs +0 -20
  39. package/esm2022/plugins/with-hand.mjs +0 -113
  40. package/esm2022/plugins/with-history.mjs +0 -91
  41. package/esm2022/plugins/with-hotkey.mjs +0 -96
  42. package/esm2022/plugins/with-i18n.mjs +0 -13
  43. package/esm2022/plugins/with-moving.mjs +0 -282
  44. package/esm2022/plugins/with-options.mjs +0 -13
  45. package/esm2022/plugins/with-related-fragment.mjs +0 -23
  46. package/esm2022/plugins/with-selection.mjs +0 -230
  47. package/esm2022/public-api.mjs +0 -16
  48. package/esm2022/testing/core/create-board.mjs +0 -15
  49. package/esm2022/testing/core/fake-weak-map.mjs +0 -18
  50. package/esm2022/testing/core/index.mjs +0 -3
  51. package/esm2022/testing/fake-events/event-objects.mjs +0 -131
  52. package/esm2022/testing/fake-events/index.mjs +0 -2
  53. package/esm2022/testing/index.mjs +0 -3
  54. package/esm2022/testing/test-element.mjs +0 -9
  55. package/esm2022/transforms/board.mjs +0 -137
  56. package/esm2022/transforms/element.mjs +0 -22
  57. package/esm2022/transforms/general.mjs +0 -146
  58. package/esm2022/transforms/group.mjs +0 -64
  59. package/esm2022/transforms/index.mjs +0 -17
  60. package/esm2022/transforms/node.mjs +0 -37
  61. package/esm2022/transforms/selection.mjs +0 -26
  62. package/esm2022/transforms/theme.mjs +0 -8
  63. package/esm2022/transforms/viewport.mjs +0 -8
  64. package/esm2022/transforms/z-index.mjs +0 -20
  65. package/esm2022/utils/angle.mjs +0 -164
  66. package/esm2022/utils/board.mjs +0 -18
  67. package/esm2022/utils/clipboard/clipboard.mjs +0 -40
  68. package/esm2022/utils/clipboard/common.mjs +0 -82
  69. package/esm2022/utils/clipboard/data-transfer.mjs +0 -33
  70. package/esm2022/utils/clipboard/index.mjs +0 -3
  71. package/esm2022/utils/clipboard/navigator-clipboard.mjs +0 -71
  72. package/esm2022/utils/clipboard/types.mjs +0 -13
  73. package/esm2022/utils/common.mjs +0 -79
  74. package/esm2022/utils/debug.mjs +0 -91
  75. package/esm2022/utils/dnd.mjs +0 -8
  76. package/esm2022/utils/dom/common.mjs +0 -75
  77. package/esm2022/utils/dom/environment.mjs +0 -2
  78. package/esm2022/utils/dom/foreign.mjs +0 -26
  79. package/esm2022/utils/dom/index.mjs +0 -4
  80. package/esm2022/utils/drawing/arrow.mjs +0 -23
  81. package/esm2022/utils/drawing/circle.mjs +0 -4
  82. package/esm2022/utils/drawing/line.mjs +0 -47
  83. package/esm2022/utils/drawing/rectangle.mjs +0 -36
  84. package/esm2022/utils/element.mjs +0 -90
  85. package/esm2022/utils/environment.mjs +0 -14
  86. package/esm2022/utils/fragment.mjs +0 -27
  87. package/esm2022/utils/group.mjs +0 -239
  88. package/esm2022/utils/helper.mjs +0 -68
  89. package/esm2022/utils/history.mjs +0 -96
  90. package/esm2022/utils/hotkeys.mjs +0 -109
  91. package/esm2022/utils/id-creator.mjs +0 -11
  92. package/esm2022/utils/index.mjs +0 -35
  93. package/esm2022/utils/iterable.mjs +0 -32
  94. package/esm2022/utils/math.mjs +0 -480
  95. package/esm2022/utils/mobile.mjs +0 -6
  96. package/esm2022/utils/moving-element.mjs +0 -17
  97. package/esm2022/utils/pointer.mjs +0 -13
  98. package/esm2022/utils/position.mjs +0 -9
  99. package/esm2022/utils/selected-element.mjs +0 -145
  100. package/esm2022/utils/selection.mjs +0 -151
  101. package/esm2022/utils/snap/snap-moving.mjs +0 -199
  102. package/esm2022/utils/snap/snap.mjs +0 -211
  103. package/esm2022/utils/to-image.mjs +0 -204
  104. package/esm2022/utils/to-point.mjs +0 -74
  105. package/esm2022/utils/tree.mjs +0 -22
  106. package/esm2022/utils/viewport.mjs +0 -227
  107. package/esm2022/utils/weak-maps.mjs +0 -27
  108. package/esm2022/utils/z-index.mjs +0 -166
@@ -1,217 +0,0 @@
1
- import { PlaitBoard, PlaitElement, PlaitNode } from '../interfaces';
2
- import { NODE_TO_INDEX, NODE_TO_PARENT } from '../utils/weak-maps';
3
- import { isSelectedElement, replaceSelectedElement } from '../utils/selected-element';
4
- import { DefaultIterableDiffer } from '../differs/default_iterable_differ';
5
- import { isDebug } from '../utils/debug';
6
- export class ListRender {
7
- constructor(board) {
8
- this.board = board;
9
- this.children = [];
10
- this.instances = [];
11
- this.contexts = [];
12
- this.differ = null;
13
- this.initialized = false;
14
- }
15
- initialize(children, childrenContext) {
16
- this.initialized = true;
17
- this.children = children;
18
- children.forEach((descendant, index) => {
19
- NODE_TO_INDEX.set(descendant, index);
20
- NODE_TO_PARENT.set(descendant, childrenContext.parent);
21
- const context = getContext(this.board, descendant, index, childrenContext.parent);
22
- const componentType = getComponentType(this.board, context);
23
- const instance = createPluginComponent(this.board, componentType, context, childrenContext);
24
- this.instances.push(instance);
25
- this.contexts.push(context);
26
- });
27
- this.differ = new DefaultIterableDiffer(trackBy);
28
- this.differ.diff(children);
29
- }
30
- update(children, childrenContext) {
31
- if (!this.initialized) {
32
- this.initialize(children, childrenContext);
33
- return;
34
- }
35
- if (!this.differ) {
36
- throw new Error('Exception: Can not find differ ');
37
- }
38
- const { board, parent } = childrenContext;
39
- const diffResult = this.differ.diff(children);
40
- if (diffResult) {
41
- const newContexts = [];
42
- const newInstances = [];
43
- // for moving scene: the current index for first element before moving
44
- let currentIndexForFirstElement = null;
45
- diffResult.forEachItem((record) => {
46
- NODE_TO_INDEX.set(record.item, record.currentIndex);
47
- NODE_TO_PARENT.set(record.item, childrenContext.parent);
48
- const previousContext = record.previousIndex === null ? undefined : this.contexts[record.previousIndex];
49
- const context = getContext(board, record.item, record.currentIndex, parent, previousContext);
50
- if (record.previousIndex === null) {
51
- const componentType = getComponentType(board, context);
52
- const componentRef = createPluginComponent(board, componentType, context, childrenContext);
53
- newContexts.push(context);
54
- newInstances.push(componentRef);
55
- }
56
- else {
57
- const instance = this.instances[record.previousIndex];
58
- instance.context = context;
59
- newInstances.push(instance);
60
- newContexts.push(context);
61
- }
62
- // item might has been changed, so need to compare the id
63
- if (record.item === this.children[0] || record.item.id === this.children[0]?.id) {
64
- currentIndexForFirstElement = record.currentIndex;
65
- }
66
- });
67
- diffResult.forEachOperation(record => {
68
- // removed
69
- if (record.currentIndex === null) {
70
- const componentRef = this.instances[record.previousIndex];
71
- componentRef?.destroy();
72
- }
73
- // moved
74
- if (record.previousIndex !== null && record.currentIndex !== null) {
75
- mountOnItemMove(record.item, record.currentIndex, childrenContext, currentIndexForFirstElement);
76
- }
77
- });
78
- this.instances = newInstances;
79
- this.contexts = newContexts;
80
- this.children = children;
81
- }
82
- else {
83
- const newContexts = [];
84
- this.children.forEach((element, index) => {
85
- NODE_TO_INDEX.set(element, index);
86
- NODE_TO_PARENT.set(element, childrenContext.parent);
87
- const previousContext = this.contexts[index];
88
- const previousInstance = this.instances[index];
89
- const context = getContext(board, element, index, parent, previousContext);
90
- previousInstance.context = context;
91
- newContexts.push(context);
92
- });
93
- this.contexts = newContexts;
94
- }
95
- }
96
- destroy() {
97
- this.children.forEach((element, index) => {
98
- if (this.instances[index]) {
99
- this.instances[index].destroy();
100
- }
101
- });
102
- this.instances = [];
103
- this.children = [];
104
- this.contexts = [];
105
- this.initialized = false;
106
- this.differ = null;
107
- }
108
- }
109
- const trackBy = (index, element) => {
110
- return element.id;
111
- };
112
- const createPluginComponent = (board, componentType, context, childrenContext) => {
113
- const instance = new componentType();
114
- instance.context = context;
115
- board.normalizeElement(context);
116
- try {
117
- instance.initialize();
118
- }
119
- catch (error) {
120
- if (isDebug()) {
121
- console.error('list-render-initialize', error, 'context', context);
122
- }
123
- }
124
- const g = instance.getContainerG();
125
- mountElementG(context.index, g, childrenContext);
126
- instance.initializeListRender();
127
- return instance;
128
- };
129
- const getComponentType = (board, context) => {
130
- const result = board.drawElement(context);
131
- return result;
132
- };
133
- const getContext = (board, element, index, parent, previousContext) => {
134
- let isSelected = isSelectedElement(board, element);
135
- const previousElement = previousContext && previousContext.element;
136
- if (previousElement && previousElement !== element && isSelectedElement(board, previousElement)) {
137
- isSelected = true;
138
- replaceSelectedElement(board, previousElement, element);
139
- }
140
- const context = {
141
- element: element,
142
- parent: parent,
143
- board: board,
144
- selected: isSelected,
145
- index,
146
- hasThemeChanged: !!board.operations?.find(op => op.type === 'set_theme')
147
- };
148
- return context;
149
- };
150
- // the g depth of root element:[1]-[2]-[3]-[4]
151
- // the g depth of root element and children element(the [2] element has children):
152
- // [1]-
153
- // [2]([2-1-1][2-1-2][2-1][2-2][2-3-1][2-3-2][2-3][2])-
154
- // [3]-
155
- // [4]
156
- export const mountElementG = (index, g, childrenContext,
157
- // for moving scene: the current index for first element before moving
158
- currentIndexForFirstElement = null) => {
159
- const { parent, parentG } = childrenContext;
160
- if (PlaitBoard.isBoard(parent)) {
161
- if (index > 0) {
162
- const previousElement = parent.children[index - 1];
163
- const previousContainerG = PlaitElement.getContainerG(previousElement, { suppressThrow: false });
164
- previousContainerG.insertAdjacentElement('afterend', g);
165
- }
166
- else {
167
- if (currentIndexForFirstElement !== null) {
168
- const firstElement = parent.children[currentIndexForFirstElement];
169
- const firstContainerG = firstElement && PlaitElement.getContainerG(firstElement, { suppressThrow: true });
170
- if (firstElement && firstContainerG) {
171
- parentG.insertBefore(g, firstContainerG);
172
- }
173
- else {
174
- throw new Error('fail to mount container on moving');
175
- }
176
- }
177
- else {
178
- parentG.append(g);
179
- }
180
- }
181
- }
182
- else {
183
- if (index > 0) {
184
- const previousElement = parent.children[index - 1];
185
- const previousElementG = PlaitElement.getElementG(previousElement);
186
- previousElementG.insertAdjacentElement('afterend', g);
187
- }
188
- else {
189
- if (currentIndexForFirstElement) {
190
- const nextElement = parent.children[currentIndexForFirstElement];
191
- const nextPath = nextElement && PlaitBoard.findPath(childrenContext.board, nextElement);
192
- const first = nextPath && PlaitNode.first(childrenContext.board, nextPath);
193
- const firstContainerG = first && PlaitElement.getContainerG(first, { suppressThrow: false });
194
- if (firstContainerG) {
195
- parentG.insertBefore(g, firstContainerG);
196
- }
197
- else {
198
- throw new Error('fail to mount container on moving');
199
- }
200
- }
201
- else {
202
- let parentElementG = PlaitElement.getElementG(parent);
203
- parentG.insertBefore(g, parentElementG);
204
- }
205
- }
206
- }
207
- };
208
- const mountOnItemMove = (element, index, childrenContext, currentIndexForFirstElement) => {
209
- const containerG = PlaitElement.getContainerG(element, { suppressThrow: false });
210
- mountElementG(index, containerG, childrenContext, currentIndexForFirstElement);
211
- if (element.children && !PlaitElement.isRootElement(element) && childrenContext.board.isExpanded(element)) {
212
- element.children.forEach((child, index) => {
213
- mountOnItemMove(child, index, { ...childrenContext, parent: element }, null);
214
- });
215
- }
216
- };
217
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-render.js","sourceRoot":"","sources":["../../../../packages/core/src/core/list-render.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Ancestor,\n    ComponentType,\n    PlaitBoard,\n    PlaitChildrenContext,\n    PlaitElement,\n    PlaitNode,\n    PlaitPluginElementContext\n} from '../interfaces';\nimport { NODE_TO_INDEX, NODE_TO_PARENT } from '../utils/weak-maps';\nimport { isSelectedElement, replaceSelectedElement } from '../utils/selected-element';\nimport { ElementFlavour } from './element/element-flavour';\nimport { DefaultIterableDiffer } from '../differs/default_iterable_differ';\nimport { IterableChangeRecord, IterableDiffer } from '../differs/iterable_differs';\nimport { isDebug } from '../utils/debug';\n\nexport class ListRender {\n    private children: PlaitElement[] = [];\n    private instances: ElementFlavour[] = [];\n    private contexts: PlaitPluginElementContext[] = [];\n    private differ: IterableDiffer<PlaitElement> | null = null;\n    public initialized = false;\n\n    constructor(private board: PlaitBoard) {}\n\n    public initialize(children: PlaitElement[], childrenContext: PlaitChildrenContext) {\n        this.initialized = true;\n        this.children = children;\n        children.forEach((descendant, index) => {\n            NODE_TO_INDEX.set(descendant, index);\n            NODE_TO_PARENT.set(descendant, childrenContext.parent);\n            const context = getContext(this.board, descendant, index, childrenContext.parent);\n            const componentType = getComponentType(this.board, context);\n            const instance = createPluginComponent(this.board, componentType, context, childrenContext);\n            this.instances.push(instance);\n            this.contexts.push(context);\n        });\n        this.differ = new DefaultIterableDiffer<PlaitElement>(trackBy);\n        this.differ.diff(children);\n    }\n\n    public update(children: PlaitElement[], childrenContext: PlaitChildrenContext) {\n        if (!this.initialized) {\n            this.initialize(children, childrenContext);\n            return;\n        }\n        if (!this.differ) {\n            throw new Error('Exception: Can not find differ ');\n        }\n        const { board, parent } = childrenContext;\n        const diffResult = this.differ.diff(children);\n        if (diffResult) {\n            const newContexts: PlaitPluginElementContext[] = [];\n            const newInstances: ElementFlavour[] = [];\n            // for moving scene: the current index for first element before moving\n            let currentIndexForFirstElement: number | null = null;\n            diffResult.forEachItem((record: IterableChangeRecord<PlaitElement>) => {\n                NODE_TO_INDEX.set(record.item, record.currentIndex as number);\n                NODE_TO_PARENT.set(record.item, childrenContext.parent);\n                const previousContext = record.previousIndex === null ? undefined : this.contexts[record.previousIndex];\n                const context = getContext(board, record.item, record.currentIndex as number, parent, previousContext);\n                if (record.previousIndex === null) {\n                    const componentType = getComponentType(board, context);\n                    const componentRef = createPluginComponent(board, componentType, context, childrenContext);\n                    newContexts.push(context);\n                    newInstances.push(componentRef);\n                } else {\n                    const instance = this.instances[record.previousIndex];\n                    instance.context = context;\n                    newInstances.push(instance);\n                    newContexts.push(context);\n                }\n                // item might has been changed, so need to compare the id\n                if (record.item === this.children[0] || record.item.id === this.children[0]?.id) {\n                    currentIndexForFirstElement = record.currentIndex;\n                }\n            });\n            diffResult.forEachOperation(record => {\n                // removed\n                if (record.currentIndex === null) {\n                    const componentRef = this.instances[record.previousIndex as number];\n                    componentRef?.destroy();\n                }\n                // moved\n                if (record.previousIndex !== null && record.currentIndex !== null) {\n                    mountOnItemMove(record.item, record.currentIndex, childrenContext, currentIndexForFirstElement);\n                }\n            });\n            this.instances = newInstances;\n            this.contexts = newContexts;\n            this.children = children;\n        } else {\n            const newContexts: PlaitPluginElementContext[] = [];\n            this.children.forEach((element, index) => {\n                NODE_TO_INDEX.set(element, index);\n                NODE_TO_PARENT.set(element, childrenContext.parent);\n                const previousContext = this.contexts[index];\n                const previousInstance = this.instances[index];\n                const context = getContext(board, element, index, parent, previousContext);\n                previousInstance.context = context;\n                newContexts.push(context);\n            });\n            this.contexts = newContexts;\n        }\n    }\n\n    public destroy() {\n        this.children.forEach((element: PlaitElement, index: number) => {\n            if (this.instances[index]) {\n                this.instances[index].destroy();\n            }\n        });\n        this.instances = [];\n        this.children = [];\n        this.contexts = [];\n        this.initialized = false;\n        this.differ = null;\n    }\n}\n\nconst trackBy = (index: number, element: PlaitElement) => {\n    return element.id;\n};\n\nconst createPluginComponent = (\n    board: PlaitBoard,\n    componentType: ComponentType<ElementFlavour>,\n    context: PlaitPluginElementContext,\n    childrenContext: PlaitChildrenContext\n) => {\n    const instance = new componentType();\n    instance.context = context;\n    board.normalizeElement(context);\n    try {\n        instance.initialize();\n    } catch (error) {\n        if (isDebug()) {\n            console.error('list-render-initialize', error, 'context', context);\n        }\n    }\n    const g = instance.getContainerG();\n    mountElementG(context.index, g, childrenContext);\n    instance.initializeListRender();\n    return instance;\n};\n\nconst getComponentType = (board: PlaitBoard, context: PlaitPluginElementContext) => {\n    const result = board.drawElement(context);\n    return result;\n};\n\nconst getContext = (\n    board: PlaitBoard,\n    element: PlaitElement,\n    index: number,\n    parent: Ancestor,\n    previousContext?: PlaitPluginElementContext\n): PlaitPluginElementContext => {\n    let isSelected = isSelectedElement(board, element);\n    const previousElement = previousContext && previousContext.element;\n    if (previousElement && previousElement !== element && isSelectedElement(board, previousElement)) {\n        isSelected = true;\n        replaceSelectedElement(board, previousElement, element);\n    }\n    const context: PlaitPluginElementContext = {\n        element: element,\n        parent: parent,\n        board: board,\n        selected: isSelected,\n        index,\n        hasThemeChanged: !!board.operations?.find(op => op.type === 'set_theme')\n    };\n    return context;\n};\n\n// the g depth of root element：[1]-[2]-[3]-[4]\n// the g depth of root element and children element（the [2] element has children）：\n// [1]-\n// [2]([2-1-1][2-1-2][2-1][2-2][2-3-1][2-3-2][2-3][2])-\n// [3]-\n// [4]\nexport const mountElementG = (\n    index: number,\n    g: SVGGElement,\n    childrenContext: PlaitChildrenContext,\n    // for moving scene: the current index for first element before moving\n    currentIndexForFirstElement: number | null = null\n) => {\n    const { parent, parentG } = childrenContext;\n    if (PlaitBoard.isBoard(parent)) {\n        if (index > 0) {\n            const previousElement = parent.children[index - 1];\n            const previousContainerG = PlaitElement.getContainerG(previousElement, { suppressThrow: false });\n            previousContainerG.insertAdjacentElement('afterend', g);\n        } else {\n            if (currentIndexForFirstElement !== null) {\n                const firstElement = parent.children[currentIndexForFirstElement];\n                const firstContainerG = firstElement && PlaitElement.getContainerG(firstElement, { suppressThrow: true });\n                if (firstElement && firstContainerG) {\n                    parentG.insertBefore(g, firstContainerG);\n                } else {\n                    throw new Error('fail to mount container on moving');\n                }\n            } else {\n                parentG.append(g);\n            }\n        }\n    } else {\n        if (index > 0) {\n            const previousElement = (parent.children as PlaitElement[])[index - 1];\n            const previousElementG = PlaitElement.getElementG(previousElement);\n            previousElementG.insertAdjacentElement('afterend', g);\n        } else {\n            if (currentIndexForFirstElement) {\n                const nextElement = (parent.children as PlaitElement[])[currentIndexForFirstElement];\n                const nextPath = nextElement && PlaitBoard.findPath(childrenContext.board, nextElement);\n                const first = nextPath && PlaitNode.first(childrenContext.board, nextPath);\n                const firstContainerG = first && PlaitElement.getContainerG(first, { suppressThrow: false });\n                if (firstContainerG) {\n                    parentG.insertBefore(g, firstContainerG);\n                } else {\n                    throw new Error('fail to mount container on moving');\n                }\n            } else {\n                let parentElementG = PlaitElement.getElementG(parent);\n                parentG.insertBefore(g, parentElementG);\n            }\n        }\n    }\n};\n\nconst mountOnItemMove = (\n    element: PlaitElement,\n    index: number,\n    childrenContext: PlaitChildrenContext,\n    currentIndexForFirstElement: number | null\n) => {\n    const containerG = PlaitElement.getContainerG(element, { suppressThrow: false });\n    mountElementG(index, containerG, childrenContext, currentIndexForFirstElement);\n    if (element.children && !PlaitElement.isRootElement(element) && childrenContext.board.isExpanded(element)) {\n        element.children.forEach((child, index) => {\n            mountOnItemMove(child, index, { ...childrenContext, parent: element }, null);\n        });\n    }\n};\n"]}