slate-angular 1.9.1 → 13.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/descendant/descendant.component.d.ts +2 -3
- package/{esm2015/components/block-card/block-card.component.js → esm2020/components/block-card/block-card.component.mjs} +5 -8
- package/{esm2015/components/children/children.component.js → esm2020/components/children/children.component.mjs} +3 -3
- package/esm2020/components/descendant/descendant.component.mjs +183 -0
- package/esm2020/components/editable/editable.component.mjs +1057 -0
- package/{esm2015/components/element/default-element.component.js → esm2020/components/element/default-element.component.mjs} +3 -3
- package/{esm2015/components/element/default-element.component.token.js → esm2020/components/element/default-element.component.token.mjs} +0 -0
- package/{esm2015/components/element/element.component.js → esm2020/components/element/element.component.mjs} +3 -3
- package/{esm2015/components/leaf/default-leaf.component.js → esm2020/components/leaf/default-leaf.component.mjs} +3 -3
- package/{esm2015/components/leaf/leaf.component.js → esm2020/components/leaf/leaf.component.mjs} +3 -3
- package/{esm2015/components/leaves/leaves.component.js → esm2020/components/leaves/leaves.component.mjs} +3 -3
- package/esm2020/components/string/string.component.mjs +73 -0
- package/esm2020/components/string/template.component.mjs +26 -0
- package/{esm2015/components/text/default-text.component.js → esm2020/components/text/default-text.component.mjs} +3 -3
- package/{esm2015/components/text/void-text.component.js → esm2020/components/text/void-text.component.mjs} +3 -3
- package/{esm2015/custom-event/BeforeInputEventPlugin.js → esm2020/custom-event/BeforeInputEventPlugin.mjs} +0 -0
- package/{esm2015/custom-event/DOMTopLevelEventTypes.js → esm2020/custom-event/DOMTopLevelEventTypes.mjs} +0 -0
- package/{esm2015/custom-event/FallbackCompositionState.js → esm2020/custom-event/FallbackCompositionState.mjs} +0 -0
- package/{esm2015/custom-event/before-input-polyfill.js → esm2020/custom-event/before-input-polyfill.mjs} +0 -0
- package/{esm2015/module.js → esm2020/module.mjs} +5 -6
- package/esm2020/plugins/angular-editor.mjs +565 -0
- package/esm2020/plugins/with-angular.mjs +214 -0
- package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
- package/{esm2015/slate-angular.js → esm2020/slate-angular.mjs} +0 -0
- package/{esm2015/types/error.js → esm2020/types/error.mjs} +0 -0
- package/{esm2015/types/feature.js → esm2020/types/feature.mjs} +0 -0
- package/{esm2015/types/index.js → esm2020/types/index.mjs} +1 -1
- package/{esm2015/types/view.js → esm2020/types/view.mjs} +0 -0
- package/esm2020/utils/block-card.mjs +25 -0
- package/{esm2015/utils/dom.js → esm2020/utils/dom.mjs} +0 -0
- package/esm2020/utils/environment.mjs +38 -0
- package/{esm2015/utils/global-normalize.js → esm2020/utils/global-normalize.mjs} +0 -0
- package/{esm2015/utils/hotkeys.js → esm2020/utils/hotkeys.mjs} +0 -0
- package/{esm2015/utils/index.js → esm2020/utils/index.mjs} +0 -0
- package/{esm2015/utils/key.js → esm2020/utils/key.mjs} +0 -0
- package/{esm2015/utils/lines.js → esm2020/utils/lines.mjs} +0 -0
- package/esm2020/utils/range-list.mjs +29 -0
- package/{esm2015/utils/view.js → esm2020/utils/view.mjs} +0 -0
- package/{esm2015/utils/weak-maps.js → esm2020/utils/weak-maps.mjs} +0 -0
- package/{esm2015/view/base.js → esm2020/view/base.mjs} +12 -12
- package/{esm2015/view/before-context-change.js → esm2020/view/before-context-change.mjs} +0 -0
- package/esm2020/view/container-item.mjs +102 -0
- package/{esm2015/view/container.js → esm2020/view/container.mjs} +3 -3
- package/{esm2015/view/context.js → esm2020/view/context.mjs} +0 -0
- package/fesm2015/{slate-angular.js → slate-angular.mjs} +88 -103
- package/fesm2015/slate-angular.mjs.map +1 -0
- package/fesm2020/slate-angular.mjs +3643 -0
- package/fesm2020/slate-angular.mjs.map +1 -0
- package/package.json +26 -6
- package/styles/index.scss +1 -1
- package/types/index.d.ts +1 -0
- package/view/container-item.d.ts +2 -3
- package/bundles/slate-angular.umd.js +0 -4296
- package/bundles/slate-angular.umd.js.map +0 -1
- package/esm2015/components/descendant/descendant.component.js +0 -179
- package/esm2015/components/editable/editable.component.js +0 -1063
- package/esm2015/components/string/string.component.js +0 -73
- package/esm2015/components/string/template.component.js +0 -30
- package/esm2015/plugins/angular-editor.js +0 -565
- package/esm2015/plugins/with-angular.js +0 -214
- package/esm2015/utils/block-card.js +0 -25
- package/esm2015/utils/environment.js +0 -36
- package/esm2015/utils/range-list.js +0 -30
- package/esm2015/view/container-item.js +0 -105
- package/fesm2015/slate-angular.js.map +0 -1
|
@@ -1,214 +0,0 @@
|
|
|
1
|
-
import { Editor, Node, Transforms, Range, Path } from 'slate';
|
|
2
|
-
import { EDITOR_TO_ON_CHANGE, NODE_TO_KEY, isDOMText, getPlainText, getSlateFragmentAttribute } from '../utils';
|
|
3
|
-
import { AngularEditor } from './angular-editor';
|
|
4
|
-
import { findCurrentLineRange } from '../utils/lines';
|
|
5
|
-
export const withAngular = (editor, clipboardFormatKey = 'x-slate-fragment') => {
|
|
6
|
-
const e = editor;
|
|
7
|
-
const { apply, onChange, deleteBackward } = e;
|
|
8
|
-
e.deleteBackward = unit => {
|
|
9
|
-
if (unit !== 'line') {
|
|
10
|
-
return deleteBackward(unit);
|
|
11
|
-
}
|
|
12
|
-
if (editor.selection && Range.isCollapsed(editor.selection)) {
|
|
13
|
-
const parentBlockEntry = Editor.above(editor, {
|
|
14
|
-
match: n => Editor.isBlock(editor, n),
|
|
15
|
-
at: editor.selection,
|
|
16
|
-
});
|
|
17
|
-
if (parentBlockEntry) {
|
|
18
|
-
const [, parentBlockPath] = parentBlockEntry;
|
|
19
|
-
const parentElementRange = Editor.range(editor, parentBlockPath, editor.selection.anchor);
|
|
20
|
-
const currentLineRange = findCurrentLineRange(e, parentElementRange);
|
|
21
|
-
if (!Range.isCollapsed(currentLineRange)) {
|
|
22
|
-
Transforms.delete(editor, { at: currentLineRange });
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
};
|
|
27
|
-
e.apply = (op) => {
|
|
28
|
-
const matches = [];
|
|
29
|
-
switch (op.type) {
|
|
30
|
-
case 'insert_text':
|
|
31
|
-
case 'remove_text':
|
|
32
|
-
case 'set_node': {
|
|
33
|
-
for (const [node, path] of Editor.levels(e, { at: op.path })) {
|
|
34
|
-
const key = AngularEditor.findKey(e, node);
|
|
35
|
-
matches.push([path, key]);
|
|
36
|
-
}
|
|
37
|
-
break;
|
|
38
|
-
}
|
|
39
|
-
case 'insert_node':
|
|
40
|
-
case 'remove_node':
|
|
41
|
-
case 'merge_node':
|
|
42
|
-
case 'split_node': {
|
|
43
|
-
for (const [node, path] of Editor.levels(e, {
|
|
44
|
-
at: Path.parent(op.path),
|
|
45
|
-
})) {
|
|
46
|
-
const key = AngularEditor.findKey(e, node);
|
|
47
|
-
matches.push([path, key]);
|
|
48
|
-
}
|
|
49
|
-
break;
|
|
50
|
-
}
|
|
51
|
-
case 'move_node': {
|
|
52
|
-
const commonPath = Path.common(Path.parent(op.path), Path.parent(op.newPath));
|
|
53
|
-
for (const [node, path] of Editor.levels(e, { at: Path.parent(op.path) })) {
|
|
54
|
-
const key = AngularEditor.findKey(e, node);
|
|
55
|
-
matches.push([path, key]);
|
|
56
|
-
}
|
|
57
|
-
for (const [node, path] of Editor.levels(e, { at: Path.parent(op.newPath) })) {
|
|
58
|
-
if (path.length > commonPath.length) {
|
|
59
|
-
const key = AngularEditor.findKey(e, node);
|
|
60
|
-
matches.push([path, key]);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
break;
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
apply(op);
|
|
67
|
-
for (const [path, key] of matches) {
|
|
68
|
-
const [node] = Editor.node(e, path);
|
|
69
|
-
NODE_TO_KEY.set(node, key);
|
|
70
|
-
}
|
|
71
|
-
};
|
|
72
|
-
e.onChange = () => {
|
|
73
|
-
const onContextChange = EDITOR_TO_ON_CHANGE.get(e);
|
|
74
|
-
if (onContextChange) {
|
|
75
|
-
onContextChange();
|
|
76
|
-
}
|
|
77
|
-
onChange();
|
|
78
|
-
};
|
|
79
|
-
e.setFragmentData = (data) => {
|
|
80
|
-
const { selection } = e;
|
|
81
|
-
if (!selection) {
|
|
82
|
-
return;
|
|
83
|
-
}
|
|
84
|
-
const [start, end] = Range.edges(selection);
|
|
85
|
-
const startVoid = Editor.void(e, { at: start.path });
|
|
86
|
-
const endVoid = Editor.void(e, { at: end.path });
|
|
87
|
-
if (Range.isCollapsed(selection) && !startVoid) {
|
|
88
|
-
return;
|
|
89
|
-
}
|
|
90
|
-
// Create a fake selection so that we can add a Base64-encoded copy of the
|
|
91
|
-
// fragment to the HTML, to decode on future pastes.
|
|
92
|
-
const domRange = AngularEditor.toDOMRange(e, selection);
|
|
93
|
-
let contents = domRange.cloneContents();
|
|
94
|
-
let attach = contents.childNodes[0];
|
|
95
|
-
// Make sure attach is non-empty, since empty nodes will not get copied.
|
|
96
|
-
const contentsArray = Array.from(contents.children);
|
|
97
|
-
contentsArray.forEach(node => {
|
|
98
|
-
if (node.textContent && node.textContent.trim() !== '') {
|
|
99
|
-
attach = node;
|
|
100
|
-
}
|
|
101
|
-
});
|
|
102
|
-
// COMPAT: If the end node is a void node, we need to move the end of the
|
|
103
|
-
// range from the void node's spacer span, to the end of the void node's
|
|
104
|
-
// content, since the spacer is before void's content in the DOM.
|
|
105
|
-
if (endVoid) {
|
|
106
|
-
const [voidNode] = endVoid;
|
|
107
|
-
const r = domRange.cloneRange();
|
|
108
|
-
const domNode = AngularEditor.toDOMNode(e, voidNode);
|
|
109
|
-
r.setEndAfter(domNode);
|
|
110
|
-
contents = r.cloneContents();
|
|
111
|
-
}
|
|
112
|
-
// COMPAT: If the start node is a void node, we need to attach the encoded
|
|
113
|
-
// fragment to the void node's content node instead of the spacer, because
|
|
114
|
-
// attaching it to empty `<div>/<span>` nodes will end up having it erased by
|
|
115
|
-
// most browsers. (2018/04/27)
|
|
116
|
-
if (startVoid) {
|
|
117
|
-
attach = contents.querySelector('[data-slate-spacer]');
|
|
118
|
-
}
|
|
119
|
-
// Remove any zero-width space spans from the cloned DOM so that they don't
|
|
120
|
-
// show up elsewhere when pasted.
|
|
121
|
-
Array.from(contents.querySelectorAll('[data-slate-zero-width]')).forEach(zw => {
|
|
122
|
-
const isNewline = zw.getAttribute('data-slate-zero-width') === 'n';
|
|
123
|
-
zw.textContent = isNewline ? '\n' : '';
|
|
124
|
-
});
|
|
125
|
-
// Set a `data-slate-fragment` attribute on a non-empty node, so it shows up
|
|
126
|
-
// in the HTML, and can be used for intra-Slate pasting. If it's a text
|
|
127
|
-
// node, wrap it in a `<span>` so we have something to set an attribute on.
|
|
128
|
-
if (isDOMText(attach)) {
|
|
129
|
-
const span = attach.ownerDocument.createElement('span');
|
|
130
|
-
// COMPAT: In Chrome and Safari, if we don't add the `white-space` style
|
|
131
|
-
// then leading and trailing spaces will be ignored. (2017/09/21)
|
|
132
|
-
span.style.whiteSpace = 'pre';
|
|
133
|
-
span.appendChild(attach);
|
|
134
|
-
contents.appendChild(span);
|
|
135
|
-
attach = span;
|
|
136
|
-
}
|
|
137
|
-
const fragment = e.getFragment();
|
|
138
|
-
const stringObj = JSON.stringify(fragment);
|
|
139
|
-
const encoded = window.btoa(encodeURIComponent(stringObj));
|
|
140
|
-
attach.setAttribute('data-slate-fragment', encoded);
|
|
141
|
-
data.setData(`application/${clipboardFormatKey}`, encoded);
|
|
142
|
-
// Add the content to a <div> so that we can get its inner HTML.
|
|
143
|
-
const div = contents.ownerDocument.createElement('div');
|
|
144
|
-
div.appendChild(contents);
|
|
145
|
-
div.setAttribute('hidden', 'true');
|
|
146
|
-
contents.ownerDocument.body.appendChild(div);
|
|
147
|
-
data.setData('text/html', div.innerHTML);
|
|
148
|
-
data.setData('text/plain', getPlainText(div));
|
|
149
|
-
contents.ownerDocument.body.removeChild(div);
|
|
150
|
-
return data;
|
|
151
|
-
};
|
|
152
|
-
e.deleteCutData = () => {
|
|
153
|
-
const { selection } = editor;
|
|
154
|
-
if (selection) {
|
|
155
|
-
if (Range.isExpanded(selection)) {
|
|
156
|
-
Editor.deleteFragment(editor);
|
|
157
|
-
}
|
|
158
|
-
else {
|
|
159
|
-
const node = Node.parent(editor, selection.anchor.path);
|
|
160
|
-
if (Editor.isVoid(editor, node)) {
|
|
161
|
-
Transforms.delete(editor);
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
};
|
|
166
|
-
e.insertData = (data) => {
|
|
167
|
-
if (!e.insertFragmentData(data)) {
|
|
168
|
-
e.insertTextData(data);
|
|
169
|
-
}
|
|
170
|
-
};
|
|
171
|
-
e.insertFragmentData = (data) => {
|
|
172
|
-
/**
|
|
173
|
-
* Checking copied fragment from application/x-slate-fragment or data-slate-fragment
|
|
174
|
-
*/
|
|
175
|
-
const fragment = data.getData(`application/${clipboardFormatKey}`) ||
|
|
176
|
-
getSlateFragmentAttribute(data);
|
|
177
|
-
if (fragment) {
|
|
178
|
-
const decoded = decodeURIComponent(window.atob(fragment));
|
|
179
|
-
const parsed = JSON.parse(decoded);
|
|
180
|
-
e.insertFragment(parsed);
|
|
181
|
-
return true;
|
|
182
|
-
}
|
|
183
|
-
return false;
|
|
184
|
-
};
|
|
185
|
-
e.insertTextData = (data) => {
|
|
186
|
-
const text = data.getData('text/plain');
|
|
187
|
-
if (text) {
|
|
188
|
-
const lines = text.split(/\r\n|\r|\n/);
|
|
189
|
-
let split = false;
|
|
190
|
-
for (const line of lines) {
|
|
191
|
-
if (split) {
|
|
192
|
-
Transforms.splitNodes(e, { always: true });
|
|
193
|
-
}
|
|
194
|
-
e.insertText(line);
|
|
195
|
-
split = true;
|
|
196
|
-
}
|
|
197
|
-
return true;
|
|
198
|
-
}
|
|
199
|
-
return false;
|
|
200
|
-
};
|
|
201
|
-
e.onKeydown = () => { };
|
|
202
|
-
e.onClick = () => { };
|
|
203
|
-
e.isBlockCard = (element) => false;
|
|
204
|
-
e.onError = (errorData) => {
|
|
205
|
-
if (errorData.nativeError) {
|
|
206
|
-
console.error(errorData.nativeError);
|
|
207
|
-
}
|
|
208
|
-
else {
|
|
209
|
-
console.error(errorData);
|
|
210
|
-
}
|
|
211
|
-
};
|
|
212
|
-
return e;
|
|
213
|
-
};
|
|
214
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-angular.js","sourceRoot":"","sources":["../../../packages/src/plugins/with-angular.ts"],"names":[],"mappings":"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","sourcesContent":["import { Editor, Node, Transforms, Range, Path, Operation } from 'slate';\nimport { EDITOR_TO_ON_CHANGE, NODE_TO_KEY, isDOMText, getPlainText, Key, getSlateFragmentAttribute } from '../utils';\nimport { AngularEditor } from './angular-editor';\nimport { SlateError } from '../types/error';\nimport { findCurrentLineRange } from '../utils/lines';\n\nexport const withAngular = <T extends Editor>(editor: T, clipboardFormatKey = 'x-slate-fragment') => {\n  const e = editor as T & AngularEditor;\n  const { apply, onChange, deleteBackward } = e;\n\n  e.deleteBackward = unit => {\n    if (unit !== 'line') {\n      return deleteBackward(unit);\n    }\n\n    if (editor.selection && Range.isCollapsed(editor.selection)) {\n      const parentBlockEntry = Editor.above(editor, {\n        match: n => Editor.isBlock(editor, n),\n        at: editor.selection,\n      });\n\n      if (parentBlockEntry) {\n        const [, parentBlockPath] = parentBlockEntry;\n        const parentElementRange = Editor.range(\n          editor,\n          parentBlockPath,\n          editor.selection.anchor\n        );\n\n        const currentLineRange = findCurrentLineRange(e, parentElementRange);\n\n        if (!Range.isCollapsed(currentLineRange)) {\n          Transforms.delete(editor, { at: currentLineRange });\n        }\n      }\n    }\n  };\n\n  e.apply = (op: Operation) => {\n    const matches: [Path, Key][] = [];\n\n    switch (op.type) {\n      case 'insert_text':\n      case 'remove_text':\n      case 'set_node': {\n        for (const [node, path] of Editor.levels(e, { at: op.path })) {\n          const key = AngularEditor.findKey(e, node);\n          matches.push([path, key]);\n        }\n\n        break;\n      }\n\n      case 'insert_node':\n      case 'remove_node':\n      case 'merge_node':\n      case 'split_node': {\n        for (const [node, path] of Editor.levels(e, {\n          at: Path.parent(op.path),\n        })) {\n          const key = AngularEditor.findKey(e, node);\n          matches.push([path, key]);\n        }\n\n        break;\n      }\n\n      case 'move_node': {\n        const commonPath = Path.common(Path.parent(op.path), Path.parent(op.newPath));\n        for (const [node, path] of Editor.levels(e, { at: Path.parent(op.path) })) {\n            const key = AngularEditor.findKey(e, node);\n            matches.push([path, key]);\n        }\n        for (const [node, path] of Editor.levels(e, { at: Path.parent(op.newPath) })) {\n            if(path.length > commonPath.length){\n                const key = AngularEditor.findKey(e, node);\n                matches.push([path, key]);\n            }\n        }\n        break;\n      }\n    }\n\n    apply(op);\n\n    for (const [path, key] of matches) {\n      const [node] = Editor.node(e, path);\n      NODE_TO_KEY.set(node, key);\n    }\n  };\n\n  e.onChange = () => {\n    const onContextChange = EDITOR_TO_ON_CHANGE.get(e);\n\n    if (onContextChange) {\n      onContextChange();\n    }\n\n    onChange();\n  };\n\n  e.setFragmentData = (data: Pick<DataTransfer, 'getData' | 'setData'>) => {\n    const { selection } = e;\n\n    if (!selection) {\n      return;\n    }\n\n    const [start, end] = Range.edges(selection);\n    const startVoid = Editor.void(e, { at: start.path });\n    const endVoid = Editor.void(e, { at: end.path });\n\n    if (Range.isCollapsed(selection) && !startVoid) {\n      return;\n    }\n\n    // Create a fake selection so that we can add a Base64-encoded copy of the\n    // fragment to the HTML, to decode on future pastes.\n    const domRange = AngularEditor.toDOMRange(e, selection);\n    let contents = domRange.cloneContents();\n    let attach = contents.childNodes[0] as HTMLElement;\n\n    // Make sure attach is non-empty, since empty nodes will not get copied.\n    const contentsArray = Array.from(contents.children);\n    contentsArray.forEach(node => {\n      if (node.textContent && node.textContent.trim() !== '') {\n        attach = node as HTMLElement;\n      }\n    });\n\n    // COMPAT: If the end node is a void node, we need to move the end of the\n    // range from the void node's spacer span, to the end of the void node's\n    // content, since the spacer is before void's content in the DOM.\n    if (endVoid) {\n      const [voidNode] = endVoid;\n      const r = domRange.cloneRange();\n      const domNode = AngularEditor.toDOMNode(e, voidNode);\n      r.setEndAfter(domNode);\n      contents = r.cloneContents();\n    }\n\n    // COMPAT: If the start node is a void node, we need to attach the encoded\n    // fragment to the void node's content node instead of the spacer, because\n    // attaching it to empty `<div>/<span>` nodes will end up having it erased by\n    // most browsers. (2018/04/27)\n    if (startVoid) {\n      attach = contents.querySelector('[data-slate-spacer]')! as HTMLElement;\n    }\n\n    // Remove any zero-width space spans from the cloned DOM so that they don't\n    // show up elsewhere when pasted.\n    Array.from(contents.querySelectorAll('[data-slate-zero-width]')).forEach(\n      zw => {\n        const isNewline = zw.getAttribute('data-slate-zero-width') === 'n';\n        zw.textContent = isNewline ? '\\n' : '';\n      }\n    );\n\n    // Set a `data-slate-fragment` attribute on a non-empty node, so it shows up\n    // in the HTML, and can be used for intra-Slate pasting. If it's a text\n    // node, wrap it in a `<span>` so we have something to set an attribute on.\n    if (isDOMText(attach)) {\n      const span = attach.ownerDocument.createElement('span');\n      // COMPAT: In Chrome and Safari, if we don't add the `white-space` style\n      // then leading and trailing spaces will be ignored. (2017/09/21)\n      span.style.whiteSpace = 'pre';\n      span.appendChild(attach);\n      contents.appendChild(span);\n      attach = span;\n    }\n\n    const fragment = e.getFragment();\n    const stringObj = JSON.stringify(fragment);\n    const encoded = window.btoa(encodeURIComponent(stringObj));\n    attach.setAttribute('data-slate-fragment', encoded);\n    data.setData(`application/${clipboardFormatKey}`, encoded);\n\n    // Add the content to a <div> so that we can get its inner HTML.\n    const div = contents.ownerDocument.createElement('div');\n    div.appendChild(contents);\n    div.setAttribute('hidden', 'true');\n    contents.ownerDocument.body.appendChild(div);\n    data.setData('text/html', div.innerHTML);\n    data.setData('text/plain', getPlainText(div));\n    contents.ownerDocument.body.removeChild(div);\n    return data;\n  };\n\n  e.deleteCutData = () => {\n    const { selection } = editor;\n    if (selection) {\n      if (Range.isExpanded(selection)) {\n        Editor.deleteFragment(editor);\n      } else {\n        const node = Node.parent(editor, selection.anchor.path);\n        if (Editor.isVoid(editor, node)) {\n          Transforms.delete(editor);\n        }\n      }\n    }\n  };\n\n  e.insertData = (data: DataTransfer) => {\n    if (!e.insertFragmentData(data)) {\n      e.insertTextData(data);\n    }\n  };\n\n  e.insertFragmentData = (data: DataTransfer): boolean => {\n    /**\n     * Checking copied fragment from application/x-slate-fragment or data-slate-fragment\n     */\n    const fragment =\n      data.getData(`application/${clipboardFormatKey}`) ||\n      getSlateFragmentAttribute(data)\n\n    if (fragment) {\n      const decoded = decodeURIComponent(window.atob(fragment))\n      const parsed = JSON.parse(decoded) as Node[]\n      e.insertFragment(parsed)\n      return true\n    }\n    return false\n  }\n\n  e.insertTextData = (data: DataTransfer): boolean => {\n    const text = data.getData('text/plain')\n\n    if (text) {\n      const lines = text.split(/\\r\\n|\\r|\\n/)\n      let split = false\n\n      for (const line of lines) {\n        if (split) {\n          Transforms.splitNodes(e, { always: true })\n        }\n\n        e.insertText(line)\n        split = true\n      }\n      return true\n    }\n    return false\n  }\n\n  e.onKeydown = () => { };\n\n  e.onClick = () => { };\n\n  e.isBlockCard = (element) => false;\n\n  e.onError = (errorData: SlateError) => {\n    if (errorData.nativeError) {\n      console.error(errorData.nativeError);\n    } else {\n      console.error(errorData);\n    }\n  };\n\n  return e;\n};\n"]}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
export const FAKE_LEFT_BLOCK_CARD_OFFSET = -1;
|
|
2
|
-
export const FAKE_RIGHT_BLOCK_CARD_OFFSET = -2;
|
|
3
|
-
export function hasBlockCardWithNode(node) {
|
|
4
|
-
return node && (node.parentElement.hasAttribute('card-target') || (node instanceof HTMLElement && node.hasAttribute('card-target')));
|
|
5
|
-
}
|
|
6
|
-
export function hasBlockCard(selection) {
|
|
7
|
-
return hasBlockCardWithNode(selection === null || selection === void 0 ? void 0 : selection.anchorNode) || hasBlockCardWithNode(selection === null || selection === void 0 ? void 0 : selection.focusNode);
|
|
8
|
-
}
|
|
9
|
-
export function getCardTargetAttribute(node) {
|
|
10
|
-
return node.parentElement.attributes['card-target'] || (node instanceof HTMLElement && node.attributes['card-target']);
|
|
11
|
-
}
|
|
12
|
-
export function isCardLeft(node) {
|
|
13
|
-
const cardTarget = getCardTargetAttribute(node);
|
|
14
|
-
return cardTarget && cardTarget.nodeValue === 'card-left';
|
|
15
|
-
}
|
|
16
|
-
export function isCardLeftByTargetAttr(targetAttr) {
|
|
17
|
-
return targetAttr && targetAttr.nodeValue === 'card-left';
|
|
18
|
-
}
|
|
19
|
-
export function isCardRightByTargetAttr(targetAttr) {
|
|
20
|
-
return targetAttr && targetAttr.nodeValue === 'card-right';
|
|
21
|
-
}
|
|
22
|
-
export function isCardCenterByTargetAttr(targetAttr) {
|
|
23
|
-
return targetAttr && targetAttr.nodeValue === 'card-center';
|
|
24
|
-
}
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2stY2FyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL3NyYy91dGlscy9ibG9jay1jYXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLDJCQUEyQixHQUFHLENBQUMsQ0FBQyxDQUFDO0FBRTlDLE1BQU0sQ0FBQyxNQUFNLDRCQUE0QixHQUFHLENBQUMsQ0FBQyxDQUFDO0FBRS9DLE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxJQUFhO0lBQzlDLE9BQU8sSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLFlBQVksV0FBVyxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ3pJLENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLFNBQXVCO0lBQ2hELE9BQU8sb0JBQW9CLENBQUMsU0FBUyxhQUFULFNBQVMsdUJBQVQsU0FBUyxDQUFFLFVBQVUsQ0FBQyxJQUFJLG9CQUFvQixDQUFDLFNBQVMsYUFBVCxTQUFTLHVCQUFULFNBQVMsQ0FBRSxTQUFTLENBQUMsQ0FBQztBQUNyRyxDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUFDLElBQWE7SUFDaEQsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksWUFBWSxXQUFXLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO0FBQzNILENBQUM7QUFFRCxNQUFNLFVBQVUsVUFBVSxDQUFDLElBQWE7SUFDcEMsTUFBTSxVQUFVLEdBQUcsc0JBQXNCLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDaEQsT0FBTyxVQUFVLElBQUksVUFBVSxDQUFDLFNBQVMsS0FBSyxXQUFXLENBQUM7QUFDOUQsQ0FBQztBQUVELE1BQU0sVUFBVSxzQkFBc0IsQ0FBQyxVQUFlO0lBQ2xELE9BQU8sVUFBVSxJQUFJLFVBQVUsQ0FBQyxTQUFTLEtBQUssV0FBVyxDQUFDO0FBQzlELENBQUM7QUFFRCxNQUFNLFVBQVUsdUJBQXVCLENBQUMsVUFBZTtJQUNuRCxPQUFPLFVBQVUsSUFBSSxVQUFVLENBQUMsU0FBUyxLQUFLLFlBQVksQ0FBQztBQUMvRCxDQUFDO0FBRUQsTUFBTSxVQUFVLHdCQUF3QixDQUFDLFVBQWU7SUFDcEQsT0FBTyxVQUFVLElBQUksVUFBVSxDQUFDLFNBQVMsS0FBSyxhQUFhLENBQUM7QUFDaEUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERPTU5vZGUsIERPTVNlbGVjdGlvbiB9IGZyb20gXCIuL2RvbVwiO1xuXG5leHBvcnQgY29uc3QgRkFLRV9MRUZUX0JMT0NLX0NBUkRfT0ZGU0VUID0gLTE7XG5cbmV4cG9ydCBjb25zdCBGQUtFX1JJR0hUX0JMT0NLX0NBUkRfT0ZGU0VUID0gLTI7XG5cbmV4cG9ydCBmdW5jdGlvbiBoYXNCbG9ja0NhcmRXaXRoTm9kZShub2RlOiBET01Ob2RlKSB7XG4gICAgcmV0dXJuIG5vZGUgJiYgKG5vZGUucGFyZW50RWxlbWVudC5oYXNBdHRyaWJ1dGUoJ2NhcmQtdGFyZ2V0JykgfHwgKG5vZGUgaW5zdGFuY2VvZiBIVE1MRWxlbWVudCAmJiBub2RlLmhhc0F0dHJpYnV0ZSgnY2FyZC10YXJnZXQnKSkpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaGFzQmxvY2tDYXJkKHNlbGVjdGlvbjogRE9NU2VsZWN0aW9uKSB7XG4gICAgcmV0dXJuIGhhc0Jsb2NrQ2FyZFdpdGhOb2RlKHNlbGVjdGlvbj8uYW5jaG9yTm9kZSkgfHwgaGFzQmxvY2tDYXJkV2l0aE5vZGUoc2VsZWN0aW9uPy5mb2N1c05vZGUpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0Q2FyZFRhcmdldEF0dHJpYnV0ZShub2RlOiBET01Ob2RlKSB7XG4gICAgcmV0dXJuIG5vZGUucGFyZW50RWxlbWVudC5hdHRyaWJ1dGVzWydjYXJkLXRhcmdldCddIHx8IChub2RlIGluc3RhbmNlb2YgSFRNTEVsZW1lbnQgJiYgbm9kZS5hdHRyaWJ1dGVzWydjYXJkLXRhcmdldCddKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ2FyZExlZnQobm9kZTogRE9NTm9kZSkge1xuICAgIGNvbnN0IGNhcmRUYXJnZXQgPSBnZXRDYXJkVGFyZ2V0QXR0cmlidXRlKG5vZGUpO1xuICAgIHJldHVybiBjYXJkVGFyZ2V0ICYmIGNhcmRUYXJnZXQubm9kZVZhbHVlID09PSAnY2FyZC1sZWZ0Jztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ2FyZExlZnRCeVRhcmdldEF0dHIodGFyZ2V0QXR0cjogYW55KSB7XG4gICAgcmV0dXJuIHRhcmdldEF0dHIgJiYgdGFyZ2V0QXR0ci5ub2RlVmFsdWUgPT09ICdjYXJkLWxlZnQnO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNDYXJkUmlnaHRCeVRhcmdldEF0dHIodGFyZ2V0QXR0cjogYW55KSB7XG4gICAgcmV0dXJuIHRhcmdldEF0dHIgJiYgdGFyZ2V0QXR0ci5ub2RlVmFsdWUgPT09ICdjYXJkLXJpZ2h0Jztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ2FyZENlbnRlckJ5VGFyZ2V0QXR0cih0YXJnZXRBdHRyOiBhbnkpIHtcbiAgICByZXR1cm4gdGFyZ2V0QXR0ciAmJiB0YXJnZXRBdHRyLm5vZGVWYWx1ZSA9PT0gJ2NhcmQtY2VudGVyJztcbn1cbiJdfQ==
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
export const IS_IOS = typeof navigator !== 'undefined' &&
|
|
2
|
-
typeof window !== 'undefined' &&
|
|
3
|
-
/iPad|iPhone|iPod/.test(navigator.userAgent) &&
|
|
4
|
-
!window.MSStream;
|
|
5
|
-
export const IS_APPLE = typeof navigator !== 'undefined' && /Mac OS X/.test(navigator.userAgent);
|
|
6
|
-
export const IS_ANDROID = typeof navigator !== 'undefined' && /Android/.test(navigator.userAgent);
|
|
7
|
-
export const IS_FIREFOX = typeof navigator !== 'undefined' &&
|
|
8
|
-
/^(?!.*Seamonkey)(?=.*Firefox).*/i.test(navigator.userAgent);
|
|
9
|
-
export const IS_SAFARI = typeof navigator !== 'undefined' &&
|
|
10
|
-
/Version\/[\d\.]+.*Safari/.test(navigator.userAgent);
|
|
11
|
-
// "modern" Edge was released at 79.x
|
|
12
|
-
export const IS_EDGE_LEGACY = typeof navigator !== 'undefined' &&
|
|
13
|
-
/Edge?\/(?:[0-6][0-9]|[0-7][0-8])/i.test(navigator.userAgent);
|
|
14
|
-
export const IS_CHROME = typeof navigator !== 'undefined' && /Chrome/i.test(navigator.userAgent);
|
|
15
|
-
// Native beforeInput events don't work well with react on Chrome 75 and older, Chrome 76+ can use beforeInput
|
|
16
|
-
export const IS_CHROME_LEGACY = typeof navigator !== 'undefined' &&
|
|
17
|
-
/Chrome?\/(?:[0-7][0-5]|[0-6][0-9])/i.test(navigator.userAgent);
|
|
18
|
-
// Firefox did not support `beforeInput` until `v87`.
|
|
19
|
-
export const IS_FIREFOX_LEGACY = typeof navigator !== 'undefined' &&
|
|
20
|
-
/^(?!.*Seamonkey)(?=.*Firefox\/(?:[0-7][0-9]|[0-8][0-6])).*/i.test(navigator.userAgent);
|
|
21
|
-
// qq browser
|
|
22
|
-
export const IS_QQBROWSER = typeof navigator !== 'undefined' && /.*QQBrowser/.test(navigator.userAgent);
|
|
23
|
-
// UC mobile browser
|
|
24
|
-
export const IS_UC_MOBILE = typeof navigator !== 'undefined' && /.*UCBrowser/.test(navigator.userAgent);
|
|
25
|
-
// Wechat browser
|
|
26
|
-
export const IS_WECHATBROWSER = typeof navigator !== 'undefined' && /.*Wechat/.test(navigator.userAgent);
|
|
27
|
-
// COMPAT: Firefox/Edge Legacy don't support the `beforeinput` event
|
|
28
|
-
// Chrome Legacy doesn't support `beforeinput` correctly
|
|
29
|
-
export const HAS_BEFORE_INPUT_SUPPORT = !IS_CHROME_LEGACY &&
|
|
30
|
-
!IS_EDGE_LEGACY &&
|
|
31
|
-
// globalThis is undefined in older browsers
|
|
32
|
-
typeof globalThis !== 'undefined' &&
|
|
33
|
-
globalThis.InputEvent &&
|
|
34
|
-
// @ts-ignore The `getTargetRanges` property isn't recognized.
|
|
35
|
-
typeof globalThis.InputEvent.prototype.getTargetRanges === 'function';
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXJvbm1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9zcmMvdXRpbHMvZW52aXJvbm1lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUNmLE9BQU8sU0FBUyxLQUFLLFdBQVc7SUFDaEMsT0FBTyxNQUFNLEtBQUssV0FBVztJQUM3QixrQkFBa0IsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQztJQUM1QyxDQUFFLE1BQWMsQ0FBQyxRQUFRLENBQUM7QUFFOUIsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUNqQixPQUFPLFNBQVMsS0FBSyxXQUFXLElBQUksVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFN0UsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUNuQixPQUFPLFNBQVMsS0FBSyxXQUFXLElBQUksU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUE7QUFFM0UsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUNuQixPQUFPLFNBQVMsS0FBSyxXQUFXO0lBQ2hDLGtDQUFrQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFakUsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUNsQixPQUFPLFNBQVMsS0FBSyxXQUFXO0lBQ2hDLDBCQUEwQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFekQscUNBQXFDO0FBQ3JDLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FDdkIsT0FBTyxTQUFTLEtBQUssV0FBVztJQUNoQyxtQ0FBbUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRWxFLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FDbEIsT0FBTyxTQUFTLEtBQUssV0FBVyxJQUFJLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRTVFLDhHQUE4RztBQUM5RyxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FDekIsT0FBTyxTQUFTLEtBQUssV0FBVztJQUNoQyxxQ0FBcUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBR3BFLHFEQUFxRDtBQUNyRCxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FDMUIsT0FBTyxTQUFTLEtBQUssV0FBVztJQUNoQyw2REFBNkQsQ0FBQyxJQUFJLENBQzlELFNBQVMsQ0FBQyxTQUFTLENBQ3RCLENBQUM7QUFFTixhQUFhO0FBQ2IsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUNyQixPQUFPLFNBQVMsS0FBSyxXQUFXLElBQUksYUFBYSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFaEYsb0JBQW9CO0FBQ3BCLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FDckIsT0FBTyxTQUFTLEtBQUssV0FBVyxJQUFJLGFBQWEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRWhGLGlCQUFpQjtBQUNqQixNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FDekIsT0FBTyxTQUFTLEtBQUssV0FBVyxJQUFJLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRTdFLG9FQUFvRTtBQUNwRSx3REFBd0Q7QUFDeEQsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQ2pDLENBQUMsZ0JBQWdCO0lBQ2pCLENBQUMsY0FBYztJQUNmLDRDQUE0QztJQUM1QyxPQUFPLFVBQVUsS0FBSyxXQUFXO0lBQ2pDLFVBQVUsQ0FBQyxVQUFVO0lBQ3JCLDhEQUE4RDtJQUM5RCxPQUFPLFVBQVUsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLGVBQWUsS0FBSyxVQUFVLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgSVNfSU9TID1cbiAgICB0eXBlb2YgbmF2aWdhdG9yICE9PSAndW5kZWZpbmVkJyAmJlxuICAgIHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnICYmXG4gICAgL2lQYWR8aVBob25lfGlQb2QvLnRlc3QobmF2aWdhdG9yLnVzZXJBZ2VudCkgJiZcbiAgICAhKHdpbmRvdyBhcyBhbnkpLk1TU3RyZWFtO1xuXG5leHBvcnQgY29uc3QgSVNfQVBQTEUgPVxuICAgIHR5cGVvZiBuYXZpZ2F0b3IgIT09ICd1bmRlZmluZWQnICYmIC9NYWMgT1MgWC8udGVzdChuYXZpZ2F0b3IudXNlckFnZW50KTtcblxuZXhwb3J0IGNvbnN0IElTX0FORFJPSUQgPVxuICAgIHR5cGVvZiBuYXZpZ2F0b3IgIT09ICd1bmRlZmluZWQnICYmIC9BbmRyb2lkLy50ZXN0KG5hdmlnYXRvci51c2VyQWdlbnQpXG5cbmV4cG9ydCBjb25zdCBJU19GSVJFRk9YID1cbiAgICB0eXBlb2YgbmF2aWdhdG9yICE9PSAndW5kZWZpbmVkJyAmJlxuICAgIC9eKD8hLipTZWFtb25rZXkpKD89LipGaXJlZm94KS4qL2kudGVzdChuYXZpZ2F0b3IudXNlckFnZW50KTtcblxuZXhwb3J0IGNvbnN0IElTX1NBRkFSSSA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiZcbiAgICAvVmVyc2lvblxcL1tcXGRcXC5dKy4qU2FmYXJpLy50ZXN0KG5hdmlnYXRvci51c2VyQWdlbnQpO1xuXG4vLyBcIm1vZGVyblwiIEVkZ2Ugd2FzIHJlbGVhc2VkIGF0IDc5LnhcbmV4cG9ydCBjb25zdCBJU19FREdFX0xFR0FDWSA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiZcbiAgICAvRWRnZT9cXC8oPzpbMC02XVswLTldfFswLTddWzAtOF0pL2kudGVzdChuYXZpZ2F0b3IudXNlckFnZW50KTtcblxuZXhwb3J0IGNvbnN0IElTX0NIUk9NRSA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiYgL0Nocm9tZS9pLnRlc3QobmF2aWdhdG9yLnVzZXJBZ2VudCk7XG5cbi8vIE5hdGl2ZSBiZWZvcmVJbnB1dCBldmVudHMgZG9uJ3Qgd29yayB3ZWxsIHdpdGggcmVhY3Qgb24gQ2hyb21lIDc1IGFuZCBvbGRlciwgQ2hyb21lIDc2KyBjYW4gdXNlIGJlZm9yZUlucHV0XG5leHBvcnQgY29uc3QgSVNfQ0hST01FX0xFR0FDWSA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiZcbiAgICAvQ2hyb21lP1xcLyg/OlswLTddWzAtNV18WzAtNl1bMC05XSkvaS50ZXN0KG5hdmlnYXRvci51c2VyQWdlbnQpO1xuXG5cbi8vIEZpcmVmb3ggZGlkIG5vdCBzdXBwb3J0IGBiZWZvcmVJbnB1dGAgdW50aWwgYHY4N2AuXG5leHBvcnQgY29uc3QgSVNfRklSRUZPWF9MRUdBQ1kgPVxuICAgIHR5cGVvZiBuYXZpZ2F0b3IgIT09ICd1bmRlZmluZWQnICYmXG4gICAgL14oPyEuKlNlYW1vbmtleSkoPz0uKkZpcmVmb3hcXC8oPzpbMC03XVswLTldfFswLThdWzAtNl0pKS4qL2kudGVzdChcbiAgICAgICAgbmF2aWdhdG9yLnVzZXJBZ2VudFxuICAgICk7XG5cbi8vIHFxIGJyb3dzZXJcbmV4cG9ydCBjb25zdCBJU19RUUJST1dTRVIgPVxuICAgIHR5cGVvZiBuYXZpZ2F0b3IgIT09ICd1bmRlZmluZWQnICYmIC8uKlFRQnJvd3Nlci8udGVzdChuYXZpZ2F0b3IudXNlckFnZW50KTtcblxuLy8gVUMgbW9iaWxlIGJyb3dzZXJcbmV4cG9ydCBjb25zdCBJU19VQ19NT0JJTEUgPVxuICAgIHR5cGVvZiBuYXZpZ2F0b3IgIT09ICd1bmRlZmluZWQnICYmIC8uKlVDQnJvd3Nlci8udGVzdChuYXZpZ2F0b3IudXNlckFnZW50KTtcblxuLy8gV2VjaGF0IGJyb3dzZXJcbmV4cG9ydCBjb25zdCBJU19XRUNIQVRCUk9XU0VSID1cbiAgICB0eXBlb2YgbmF2aWdhdG9yICE9PSAndW5kZWZpbmVkJyAmJiAvLipXZWNoYXQvLnRlc3QobmF2aWdhdG9yLnVzZXJBZ2VudCk7XG5cbi8vIENPTVBBVDogRmlyZWZveC9FZGdlIExlZ2FjeSBkb24ndCBzdXBwb3J0IHRoZSBgYmVmb3JlaW5wdXRgIGV2ZW50XG4vLyBDaHJvbWUgTGVnYWN5IGRvZXNuJ3Qgc3VwcG9ydCBgYmVmb3JlaW5wdXRgIGNvcnJlY3RseVxuZXhwb3J0IGNvbnN0IEhBU19CRUZPUkVfSU5QVVRfU1VQUE9SVCA9XG4gICAgIUlTX0NIUk9NRV9MRUdBQ1kgJiZcbiAgICAhSVNfRURHRV9MRUdBQ1kgJiZcbiAgICAvLyBnbG9iYWxUaGlzIGlzIHVuZGVmaW5lZCBpbiBvbGRlciBicm93c2Vyc1xuICAgIHR5cGVvZiBnbG9iYWxUaGlzICE9PSAndW5kZWZpbmVkJyAmJlxuICAgIGdsb2JhbFRoaXMuSW5wdXRFdmVudCAmJlxuICAgIC8vIEB0cy1pZ25vcmUgVGhlIGBnZXRUYXJnZXRSYW5nZXNgIHByb3BlcnR5IGlzbid0IHJlY29nbml6ZWQuXG4gICAgdHlwZW9mIGdsb2JhbFRoaXMuSW5wdXRFdmVudC5wcm90b3R5cGUuZ2V0VGFyZ2V0UmFuZ2VzID09PSAnZnVuY3Rpb24nIl19
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { __rest } from "tslib";
|
|
2
|
-
import { Range } from 'slate';
|
|
3
|
-
import { PLACEHOLDER_SYMBOL } from './weak-maps';
|
|
4
|
-
export const shallowCompare = (obj1, obj2) => Object.keys(obj1).length === Object.keys(obj2).length &&
|
|
5
|
-
Object.keys(obj1).every(key => obj2.hasOwnProperty(key) && obj1[key] === obj2[key]);
|
|
6
|
-
/**
|
|
7
|
-
* Check if a list of decorator ranges are equal to another.
|
|
8
|
-
*
|
|
9
|
-
* PERF: this requires the two lists to also have the ranges inside them in the
|
|
10
|
-
* same order, but this is an okay constraint for us since decorations are
|
|
11
|
-
* kept in order, and the odd case where they aren't is okay to re-render for.
|
|
12
|
-
*/
|
|
13
|
-
export const isDecoratorRangeListEqual = (list, another) => {
|
|
14
|
-
if (list.length !== another.length) {
|
|
15
|
-
return false;
|
|
16
|
-
}
|
|
17
|
-
for (let i = 0; i < list.length; i++) {
|
|
18
|
-
const range = list[i];
|
|
19
|
-
const other = another[i];
|
|
20
|
-
const { anchor: rangeAnchor, focus: rangeFocus } = range, rangeOwnProps = __rest(range, ["anchor", "focus"]);
|
|
21
|
-
const { anchor: otherAnchor, focus: otherFocus } = other, otherOwnProps = __rest(other, ["anchor", "focus"]);
|
|
22
|
-
if (!Range.equals(range, other) ||
|
|
23
|
-
range[PLACEHOLDER_SYMBOL] !== other[PLACEHOLDER_SYMBOL] ||
|
|
24
|
-
!shallowCompare(rangeOwnProps, otherOwnProps)) {
|
|
25
|
-
return false;
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
return true;
|
|
29
|
-
};
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2UtbGlzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL3NyYy91dGlscy9yYW5nZS1saXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sT0FBTyxDQUFBO0FBQzdCLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGFBQWEsQ0FBQTtBQUVoRCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsQ0FBQyxJQUFRLEVBQUUsSUFBUSxFQUFFLEVBQUUsQ0FDakQsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUssTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNO0lBQ3JELE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsS0FBSyxDQUNuQixHQUFHLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FDN0QsQ0FBQTtBQUVMOzs7Ozs7R0FNRztBQUVILE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLENBQ3JDLElBQWEsRUFDYixPQUFnQixFQUNULEVBQUU7SUFDVCxJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssT0FBTyxDQUFDLE1BQU0sRUFBRTtRQUNoQyxPQUFPLEtBQUssQ0FBQTtLQUNmO0lBRUQsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7UUFDbEMsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFBO1FBQ3JCLE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQTtRQUV4QixNQUFNLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsVUFBVSxLQUF1QixLQUFLLEVBQXZCLGFBQWEsVUFBSyxLQUFLLEVBQXBFLG1CQUE0RCxDQUFRLENBQUE7UUFDMUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLFVBQVUsS0FBdUIsS0FBSyxFQUF2QixhQUFhLFVBQUssS0FBSyxFQUFwRSxtQkFBNEQsQ0FBUSxDQUFBO1FBRTFFLElBQ0ksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUM7WUFDM0IsS0FBSyxDQUFDLGtCQUFrQixDQUFDLEtBQUssS0FBSyxDQUFDLGtCQUFrQixDQUFDO1lBQ3ZELENBQUMsY0FBYyxDQUFDLGFBQWEsRUFBRSxhQUFhLENBQUMsRUFDL0M7WUFDRSxPQUFPLEtBQUssQ0FBQTtTQUNmO0tBQ0o7SUFFRCxPQUFPLElBQUksQ0FBQTtBQUNmLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJhbmdlIH0gZnJvbSAnc2xhdGUnXG5pbXBvcnQgeyBQTEFDRUhPTERFUl9TWU1CT0wgfSBmcm9tICcuL3dlYWstbWFwcydcblxuZXhwb3J0IGNvbnN0IHNoYWxsb3dDb21wYXJlID0gKG9iajE6IHt9LCBvYmoyOiB7fSkgPT5cbiAgICBPYmplY3Qua2V5cyhvYmoxKS5sZW5ndGggPT09IE9iamVjdC5rZXlzKG9iajIpLmxlbmd0aCAmJlxuICAgIE9iamVjdC5rZXlzKG9iajEpLmV2ZXJ5KFxuICAgICAgICBrZXkgPT4gb2JqMi5oYXNPd25Qcm9wZXJ0eShrZXkpICYmIG9iajFba2V5XSA9PT0gb2JqMltrZXldXG4gICAgKVxuXG4vKipcbiAqIENoZWNrIGlmIGEgbGlzdCBvZiBkZWNvcmF0b3IgcmFuZ2VzIGFyZSBlcXVhbCB0byBhbm90aGVyLlxuICpcbiAqIFBFUkY6IHRoaXMgcmVxdWlyZXMgdGhlIHR3byBsaXN0cyB0byBhbHNvIGhhdmUgdGhlIHJhbmdlcyBpbnNpZGUgdGhlbSBpbiB0aGVcbiAqIHNhbWUgb3JkZXIsIGJ1dCB0aGlzIGlzIGFuIG9rYXkgY29uc3RyYWludCBmb3IgdXMgc2luY2UgZGVjb3JhdGlvbnMgYXJlXG4gKiBrZXB0IGluIG9yZGVyLCBhbmQgdGhlIG9kZCBjYXNlIHdoZXJlIHRoZXkgYXJlbid0IGlzIG9rYXkgdG8gcmUtcmVuZGVyIGZvci5cbiAqL1xuXG5leHBvcnQgY29uc3QgaXNEZWNvcmF0b3JSYW5nZUxpc3RFcXVhbCA9IChcbiAgICBsaXN0OiBSYW5nZVtdLFxuICAgIGFub3RoZXI6IFJhbmdlW11cbik6IGJvb2xlYW4gPT4ge1xuICAgIGlmIChsaXN0Lmxlbmd0aCAhPT0gYW5vdGhlci5sZW5ndGgpIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlXG4gICAgfVxuXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBsaXN0Lmxlbmd0aDsgaSsrKSB7XG4gICAgICAgIGNvbnN0IHJhbmdlID0gbGlzdFtpXVxuICAgICAgICBjb25zdCBvdGhlciA9IGFub3RoZXJbaV1cblxuICAgICAgICBjb25zdCB7IGFuY2hvcjogcmFuZ2VBbmNob3IsIGZvY3VzOiByYW5nZUZvY3VzLCAuLi5yYW5nZU93blByb3BzIH0gPSByYW5nZVxuICAgICAgICBjb25zdCB7IGFuY2hvcjogb3RoZXJBbmNob3IsIGZvY3VzOiBvdGhlckZvY3VzLCAuLi5vdGhlck93blByb3BzIH0gPSBvdGhlclxuXG4gICAgICAgIGlmIChcbiAgICAgICAgICAgICFSYW5nZS5lcXVhbHMocmFuZ2UsIG90aGVyKSB8fFxuICAgICAgICAgICAgcmFuZ2VbUExBQ0VIT0xERVJfU1lNQk9MXSAhPT0gb3RoZXJbUExBQ0VIT0xERVJfU1lNQk9MXSB8fFxuICAgICAgICAgICAgIXNoYWxsb3dDb21wYXJlKHJhbmdlT3duUHJvcHMsIG90aGVyT3duUHJvcHMpXG4gICAgICAgICkge1xuICAgICAgICAgICAgcmV0dXJuIGZhbHNlXG4gICAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gdHJ1ZVxufVxuIl19
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
import { Directive, Input } from "@angular/core";
|
|
2
|
-
import { isComponentType, isDOMElement, isTemplateRef } from "../utils";
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
/**
|
|
5
|
-
* Dynamically create/update components or templates
|
|
6
|
-
* Provide rootNodes for the view container
|
|
7
|
-
* If the dynamically created component uses onpush mode, then it must call markForCheck when setting the context
|
|
8
|
-
*/
|
|
9
|
-
export class ViewContainerItem {
|
|
10
|
-
constructor(viewContainerRef, componentFactoryResolver) {
|
|
11
|
-
this.viewContainerRef = viewContainerRef;
|
|
12
|
-
this.componentFactoryResolver = componentFactoryResolver;
|
|
13
|
-
this.initialized = false;
|
|
14
|
-
}
|
|
15
|
-
get rootNodes() {
|
|
16
|
-
return this.getRootNodes();
|
|
17
|
-
}
|
|
18
|
-
getRootNodes() {
|
|
19
|
-
if (this.embeddedViewRef) {
|
|
20
|
-
return this.embeddedViewRef.rootNodes.filter((rootNode) => isDOMElement(rootNode));
|
|
21
|
-
}
|
|
22
|
-
if (this.componentRef) {
|
|
23
|
-
return [this.componentRef.instance.nativeElement];
|
|
24
|
-
}
|
|
25
|
-
return [];
|
|
26
|
-
}
|
|
27
|
-
destroyView() {
|
|
28
|
-
if (this.embeddedViewRef) {
|
|
29
|
-
this.embeddedViewRef.destroy();
|
|
30
|
-
this.embeddedViewRef = null;
|
|
31
|
-
}
|
|
32
|
-
if (this.componentRef) {
|
|
33
|
-
this.componentRef.destroy();
|
|
34
|
-
this.componentRef = null;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
createView() {
|
|
38
|
-
this.initialized = true;
|
|
39
|
-
this.viewType = this.getViewType();
|
|
40
|
-
const context = this.getContext();
|
|
41
|
-
if (isTemplateRef(this.viewType)) {
|
|
42
|
-
this.embeddedViewContext = { context, viewContext: this.viewContext };
|
|
43
|
-
const embeddedViewRef = this.viewContainerRef.createEmbeddedView(this.viewType, this.embeddedViewContext);
|
|
44
|
-
this.embeddedViewRef = embeddedViewRef;
|
|
45
|
-
}
|
|
46
|
-
if (isComponentType(this.viewType)) {
|
|
47
|
-
const componentFactory = this.componentFactoryResolver.resolveComponentFactory(this.viewType);
|
|
48
|
-
const componentRef = this.viewContainerRef.createComponent(componentFactory);
|
|
49
|
-
componentRef.instance.context = context;
|
|
50
|
-
componentRef.instance.viewContext = this.viewContext;
|
|
51
|
-
this.componentRef = componentRef;
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
updateView() {
|
|
55
|
-
const viewType = this.getViewType();
|
|
56
|
-
const context = this.getContext();
|
|
57
|
-
if (this.viewType === viewType) {
|
|
58
|
-
if (this.componentRef) {
|
|
59
|
-
if (this.memoizedContext(this.componentRef.instance.context, context)) {
|
|
60
|
-
return;
|
|
61
|
-
}
|
|
62
|
-
this.componentRef.instance.context = context;
|
|
63
|
-
}
|
|
64
|
-
if (this.embeddedViewRef) {
|
|
65
|
-
if (this.memoizedContext(this.embeddedViewContext.context, context)) {
|
|
66
|
-
return;
|
|
67
|
-
}
|
|
68
|
-
this.embeddedViewContext.context = context;
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
else {
|
|
72
|
-
this.viewType = viewType;
|
|
73
|
-
const firstRootNode = this.rootNodes[0];
|
|
74
|
-
if (isTemplateRef(this.viewType)) {
|
|
75
|
-
this.embeddedViewContext = { context, viewContext: this.viewContext };
|
|
76
|
-
const embeddedViewRef = this.viewContainerRef.createEmbeddedView(this.viewType, this.embeddedViewContext);
|
|
77
|
-
firstRootNode.replaceWith(...embeddedViewRef.rootNodes.filter((rootNode) => isDOMElement(rootNode)));
|
|
78
|
-
this.destroyView();
|
|
79
|
-
this.embeddedViewRef = embeddedViewRef;
|
|
80
|
-
}
|
|
81
|
-
if (isComponentType(this.viewType)) {
|
|
82
|
-
const componentFactory = this.componentFactoryResolver.resolveComponentFactory(this.viewType);
|
|
83
|
-
const componentRef = this.viewContainerRef.createComponent(componentFactory);
|
|
84
|
-
componentRef.instance.context = context;
|
|
85
|
-
componentRef.instance.viewContext = this.viewContext;
|
|
86
|
-
firstRootNode.replaceWith(componentRef.instance.nativeElement);
|
|
87
|
-
this.destroyView();
|
|
88
|
-
this.componentRef = componentRef;
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
appendBlockCardElement() {
|
|
93
|
-
if (this.blockCardComponentRef) {
|
|
94
|
-
this.blockCardComponentRef.instance.append();
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
ViewContainerItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: ViewContainerItem, deps: [{ token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive });
|
|
99
|
-
ViewContainerItem.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.7", type: ViewContainerItem, inputs: { viewContext: "viewContext" }, ngImport: i0 });
|
|
100
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: ViewContainerItem, decorators: [{
|
|
101
|
-
type: Directive
|
|
102
|
-
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }]; }, propDecorators: { viewContext: [{
|
|
103
|
-
type: Input
|
|
104
|
-
}] } });
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container-item.js","sourceRoot":"","sources":["../../../packages/src/view/container-item.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Directive, EmbeddedViewRef, Input, ViewContainerRef } from \"@angular/core\";\nimport { SlateBlockCardComponent } from \"../components/block-card/block-card.component\";\nimport { ViewType } from \"../types/view\";\nimport { isComponentType, isDOMElement, isTemplateRef } from \"../utils\";\nimport { BaseComponent, BaseEmbeddedView } from \"./base\";\nimport { SlateElementContext, SlateLeafContext, SlateStringContext, SlateTextContext, SlateViewContext } from \"./context\";\n\n/**\n * Dynamically create/update components or templates\n * Provide rootNodes for the view container\n * If the dynamically created component uses onpush mode, then it must call markForCheck when setting the context\n */\n@Directive()\nexport abstract class ViewContainerItem<T = SlateElementContext | SlateTextContext | SlateLeafContext | SlateStringContext, K extends BaseComponent<T> = BaseComponent<T>> {\n    initialized = false;\n    embeddedViewRef: EmbeddedViewRef<BaseEmbeddedView<T>>;\n    embeddedViewContext: BaseEmbeddedView<T>;\n    blockCardComponentRef: ComponentRef<SlateBlockCardComponent>;\n    componentRef: ComponentRef<K>;\n    viewType: ViewType;\n\n    @Input() viewContext: SlateViewContext;\n\n    get rootNodes() {\n        return this.getRootNodes();\n    }\n\n    getRootNodes(): HTMLElement[] {\n        if (this.embeddedViewRef) {\n            return this.embeddedViewRef.rootNodes.filter((rootNode) => isDOMElement(rootNode));\n        }\n        if (this.componentRef) {\n            return [this.componentRef.instance.nativeElement];\n        }\n        return [];\n    }\n\n    constructor(\n        protected viewContainerRef: ViewContainerRef,\n        protected componentFactoryResolver: ComponentFactoryResolver\n    ) { }\n\n    destroyView() {\n        if (this.embeddedViewRef) {\n            this.embeddedViewRef.destroy();\n            this.embeddedViewRef = null;\n        }\n        if (this.componentRef) {\n            this.componentRef.destroy();\n            this.componentRef = null;\n        }\n    }\n\n    abstract getContext(): T;\n\n    abstract getViewType(): ViewType;\n\n    abstract memoizedContext(prev: T, next: T): boolean;\n\n    createView() {\n        this.initialized = true;\n        this.viewType = this.getViewType();\n        const context = this.getContext();\n        if (isTemplateRef(this.viewType)) {\n            this.embeddedViewContext = { context, viewContext: this.viewContext };\n            const embeddedViewRef = this.viewContainerRef.createEmbeddedView<BaseEmbeddedView<T>>(this.viewType, this.embeddedViewContext);\n            this.embeddedViewRef = embeddedViewRef;\n        }\n        if (isComponentType(this.viewType)) {\n            const componentFactory = this.componentFactoryResolver.resolveComponentFactory<K>(this.viewType);\n            const componentRef = this.viewContainerRef.createComponent(componentFactory);\n            componentRef.instance.context = context;\n            componentRef.instance.viewContext = this.viewContext;\n            this.componentRef = componentRef;\n        }\n    }\n\n    updateView() {\n        const viewType = this.getViewType();\n        const context = this.getContext();\n        if (this.viewType === viewType) {\n            if (this.componentRef) {\n                if (this.memoizedContext(this.componentRef.instance.context, context)) {\n                    return;\n                }\n                this.componentRef.instance.context = context;\n            }\n            if (this.embeddedViewRef) {\n                if (this.memoizedContext(this.embeddedViewContext.context, context)) {\n                    return;\n                }\n                this.embeddedViewContext.context = context;\n            }\n        } else {\n            this.viewType = viewType;\n            const firstRootNode = this.rootNodes[0];\n            if (isTemplateRef(this.viewType)) {\n                this.embeddedViewContext = { context, viewContext: this.viewContext };\n                const embeddedViewRef = this.viewContainerRef.createEmbeddedView<BaseEmbeddedView<T>>(this.viewType, this.embeddedViewContext);\n                firstRootNode.replaceWith(...embeddedViewRef.rootNodes.filter((rootNode) => isDOMElement(rootNode)));\n                this.destroyView();\n                this.embeddedViewRef = embeddedViewRef;\n            }\n            if (isComponentType(this.viewType)) {\n                const componentFactory = this.componentFactoryResolver.resolveComponentFactory<K>(this.viewType);\n                const componentRef = this.viewContainerRef.createComponent(componentFactory);\n                componentRef.instance.context = context;\n                componentRef.instance.viewContext = this.viewContext;\n                firstRootNode.replaceWith(componentRef.instance.nativeElement);\n                this.destroyView();\n                this.componentRef = componentRef;\n            }\n        }\n    }\n\n    appendBlockCardElement() {\n        if (this.blockCardComponentRef) {\n            this.blockCardComponentRef.instance.append();\n        }\n    }\n}"]}
|