slate-angular 18.0.1 → 19.0.0-next.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/fesm2022/slate-angular.mjs +120 -130
- package/fesm2022/slate-angular.mjs.map +1 -1
- package/package.json +1 -3
- package/view/base.d.ts +4 -4
- package/view/container-item.d.ts +1 -1
- package/view/container.d.ts +1 -1
- package/esm2022/components/block-card/block-card.component.mjs +0 -33
- package/esm2022/components/children/children-outlet.component.mjs +0 -22
- package/esm2022/components/children/children.component.mjs +0 -23
- package/esm2022/components/editable/editable.component.mjs +0 -1266
- package/esm2022/components/element/default-element.component.mjs +0 -19
- package/esm2022/components/element/default-element.component.token.mjs +0 -3
- package/esm2022/components/element/element.component.mjs +0 -19
- package/esm2022/components/leaf/default-leaf.component.mjs +0 -30
- package/esm2022/components/leaf/token.mjs +0 -3
- package/esm2022/components/leaves/leaves.component.mjs +0 -25
- package/esm2022/components/string/default-string.component.mjs +0 -75
- package/esm2022/components/string/string.component.mjs +0 -108
- package/esm2022/components/string/template.component.mjs +0 -20
- package/esm2022/components/text/default-text.component.mjs +0 -22
- package/esm2022/components/text/token.mjs +0 -4
- package/esm2022/components/text/void-text.component.mjs +0 -32
- package/esm2022/custom-event/BeforeInputEventPlugin.mjs +0 -251
- package/esm2022/custom-event/DOMTopLevelEventTypes.mjs +0 -13
- package/esm2022/custom-event/FallbackCompositionState.mjs +0 -62
- package/esm2022/custom-event/before-input-polyfill.mjs +0 -13
- package/esm2022/module.mjs +0 -69
- package/esm2022/plugins/angular-editor.mjs +0 -610
- package/esm2022/plugins/with-angular.mjs +0 -217
- package/esm2022/public-api.mjs +0 -20
- package/esm2022/slate-angular.mjs +0 -5
- package/esm2022/types/clipboard.mjs +0 -2
- package/esm2022/types/error.mjs +0 -12
- package/esm2022/types/feature.mjs +0 -2
- package/esm2022/types/index.mjs +0 -5
- package/esm2022/types/view.mjs +0 -2
- package/esm2022/utils/block-card.mjs +0 -25
- package/esm2022/utils/clipboard/clipboard.mjs +0 -78
- package/esm2022/utils/clipboard/common.mjs +0 -42
- package/esm2022/utils/clipboard/data-transfer.mjs +0 -44
- package/esm2022/utils/clipboard/index.mjs +0 -5
- package/esm2022/utils/clipboard/navigator-clipboard.mjs +0 -59
- package/esm2022/utils/constants.mjs +0 -2
- package/esm2022/utils/dom.mjs +0 -165
- package/esm2022/utils/environment.mjs +0 -34
- package/esm2022/utils/global-normalize.mjs +0 -11
- package/esm2022/utils/hotkeys.mjs +0 -99
- package/esm2022/utils/index.mjs +0 -12
- package/esm2022/utils/key.mjs +0 -14
- package/esm2022/utils/lines.mjs +0 -46
- package/esm2022/utils/range-list.mjs +0 -29
- package/esm2022/utils/restore-dom.mjs +0 -33
- package/esm2022/utils/throttle.mjs +0 -18
- package/esm2022/utils/view.mjs +0 -8
- package/esm2022/utils/weak-maps.mjs +0 -40
- package/esm2022/view/base.mjs +0 -273
- package/esm2022/view/container-item.mjs +0 -108
- package/esm2022/view/container.mjs +0 -22
- package/esm2022/view/context-change.mjs +0 -13
- package/esm2022/view/context.mjs +0 -2
- package/esm2022/view/render/leaves-render.mjs +0 -107
- package/esm2022/view/render/list-render.mjs +0 -302
- package/esm2022/view/render/utils.mjs +0 -110
|
@@ -1,217 +0,0 @@
|
|
|
1
|
-
import { Editor, Element, Node, Path, Range, Transforms } from 'slate';
|
|
2
|
-
import { completeTable, EDITOR_TO_ON_CHANGE, getPlainText, isDOMText, isInvalidTable, NODE_TO_KEY } from '../utils';
|
|
3
|
-
import { getClipboardData, setClipboardData } from '../utils/clipboard/clipboard';
|
|
4
|
-
import { findCurrentLineRange } from '../utils/lines';
|
|
5
|
-
import { AngularEditor } from './angular-editor';
|
|
6
|
-
export const withAngular = (editor, clipboardFormatKey = 'x-slate-fragment') => {
|
|
7
|
-
const e = editor;
|
|
8
|
-
const { apply, onChange, deleteBackward } = e;
|
|
9
|
-
e.deleteBackward = unit => {
|
|
10
|
-
if (unit !== 'line') {
|
|
11
|
-
return deleteBackward(unit);
|
|
12
|
-
}
|
|
13
|
-
if (editor.selection && Range.isCollapsed(editor.selection)) {
|
|
14
|
-
const parentBlockEntry = Editor.above(editor, {
|
|
15
|
-
match: n => Element.isElement(n) && Editor.isBlock(editor, n),
|
|
16
|
-
at: editor.selection
|
|
17
|
-
});
|
|
18
|
-
if (parentBlockEntry) {
|
|
19
|
-
const [, parentBlockPath] = parentBlockEntry;
|
|
20
|
-
const parentElementRange = Editor.range(editor, parentBlockPath, editor.selection.anchor);
|
|
21
|
-
const currentLineRange = findCurrentLineRange(e, parentElementRange);
|
|
22
|
-
if (!Range.isCollapsed(currentLineRange)) {
|
|
23
|
-
Transforms.delete(editor, { at: currentLineRange });
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
};
|
|
28
|
-
e.apply = (op) => {
|
|
29
|
-
const matches = [];
|
|
30
|
-
switch (op.type) {
|
|
31
|
-
case 'insert_text':
|
|
32
|
-
case 'remove_text':
|
|
33
|
-
case 'set_node': {
|
|
34
|
-
for (const [node, path] of Editor.levels(e, { at: op.path })) {
|
|
35
|
-
const key = AngularEditor.findKey(e, node);
|
|
36
|
-
matches.push([path, key]);
|
|
37
|
-
}
|
|
38
|
-
break;
|
|
39
|
-
}
|
|
40
|
-
case 'insert_node':
|
|
41
|
-
case 'remove_node':
|
|
42
|
-
case 'merge_node':
|
|
43
|
-
case 'split_node': {
|
|
44
|
-
for (const [node, path] of Editor.levels(e, {
|
|
45
|
-
at: Path.parent(op.path)
|
|
46
|
-
})) {
|
|
47
|
-
const key = AngularEditor.findKey(e, node);
|
|
48
|
-
matches.push([path, key]);
|
|
49
|
-
}
|
|
50
|
-
break;
|
|
51
|
-
}
|
|
52
|
-
case 'move_node': {
|
|
53
|
-
const commonPath = Path.common(Path.parent(op.path), Path.parent(op.newPath));
|
|
54
|
-
for (const [node, path] of Editor.levels(e, {
|
|
55
|
-
at: Path.parent(op.path)
|
|
56
|
-
})) {
|
|
57
|
-
const key = AngularEditor.findKey(e, node);
|
|
58
|
-
matches.push([Editor.pathRef(editor, path), key]);
|
|
59
|
-
}
|
|
60
|
-
for (const [node, path] of Editor.levels(e, {
|
|
61
|
-
at: Path.parent(op.newPath)
|
|
62
|
-
})) {
|
|
63
|
-
if (path.length > commonPath.length) {
|
|
64
|
-
const key = AngularEditor.findKey(e, node);
|
|
65
|
-
matches.push([Editor.pathRef(editor, path), key]);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
break;
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
apply(op);
|
|
72
|
-
for (const [source, key] of matches) {
|
|
73
|
-
const [node] = Editor.node(e, Path.isPath(source) ? source : source.current);
|
|
74
|
-
NODE_TO_KEY.set(node, key);
|
|
75
|
-
}
|
|
76
|
-
};
|
|
77
|
-
e.onChange = () => {
|
|
78
|
-
const onContextChange = EDITOR_TO_ON_CHANGE.get(e);
|
|
79
|
-
if (onContextChange) {
|
|
80
|
-
onContextChange();
|
|
81
|
-
}
|
|
82
|
-
onChange();
|
|
83
|
-
};
|
|
84
|
-
e.setFragmentData = (dataTransfer, originEvent) => {
|
|
85
|
-
const { selection } = e;
|
|
86
|
-
if (!selection) {
|
|
87
|
-
return;
|
|
88
|
-
}
|
|
89
|
-
const [start, end] = Range.edges(selection);
|
|
90
|
-
const startVoid = Editor.void(e, { at: start.path });
|
|
91
|
-
const endVoid = Editor.void(e, { at: end.path });
|
|
92
|
-
if (Range.isCollapsed(selection) && !startVoid) {
|
|
93
|
-
return;
|
|
94
|
-
}
|
|
95
|
-
// Create a fake selection so that we can add a Base64-encoded copy of the
|
|
96
|
-
// fragment to the HTML, to decode on future pastes.
|
|
97
|
-
const domRange = AngularEditor.toDOMRange(e, selection);
|
|
98
|
-
let contents = domRange.cloneContents();
|
|
99
|
-
let attach = contents.childNodes[0];
|
|
100
|
-
// Make sure attach is non-empty, since empty nodes will not get copied.
|
|
101
|
-
const contentsArray = Array.from(contents.children);
|
|
102
|
-
contentsArray.forEach(node => {
|
|
103
|
-
if (node.textContent && node.textContent.trim() !== '') {
|
|
104
|
-
attach = node;
|
|
105
|
-
}
|
|
106
|
-
});
|
|
107
|
-
// COMPAT: If the end node is a void node, we need to move the end of the
|
|
108
|
-
// range from the void node's spacer span, to the end of the void node's
|
|
109
|
-
// content, since the spacer is before void's content in the DOM.
|
|
110
|
-
if (endVoid) {
|
|
111
|
-
const [voidNode] = endVoid;
|
|
112
|
-
const r = domRange.cloneRange();
|
|
113
|
-
const domNode = AngularEditor.toDOMNode(e, voidNode);
|
|
114
|
-
r.setEndAfter(domNode);
|
|
115
|
-
contents = r.cloneContents();
|
|
116
|
-
}
|
|
117
|
-
// COMPAT: If the start node is a void node, we need to attach the encoded
|
|
118
|
-
// fragment to the void node's content node instead of the spacer, because
|
|
119
|
-
// attaching it to empty `<div>/<span>` nodes will end up having it erased by
|
|
120
|
-
// most browsers. (2018/04/27)
|
|
121
|
-
if (startVoid) {
|
|
122
|
-
attach = contents.querySelector('[data-slate-spacer]');
|
|
123
|
-
}
|
|
124
|
-
// Remove any zero-width space spans from the cloned DOM so that they don't
|
|
125
|
-
// show up elsewhere when pasted.
|
|
126
|
-
Array.from(contents.querySelectorAll('[data-slate-zero-width]')).forEach(zw => {
|
|
127
|
-
const isNewline = zw.getAttribute('data-slate-zero-width') === 'n';
|
|
128
|
-
zw.textContent = isNewline ? '\n' : '';
|
|
129
|
-
});
|
|
130
|
-
// Set a `data-slate-fragment` attribute on a non-empty node, so it shows up
|
|
131
|
-
// in the HTML, and can be used for intra-Slate pasting. If it's a text
|
|
132
|
-
// node, wrap it in a `<span>` so we have something to set an attribute on.
|
|
133
|
-
if (isDOMText(attach)) {
|
|
134
|
-
const span = attach.ownerDocument.createElement('span');
|
|
135
|
-
// COMPAT: In Chrome and Safari, if we don't add the `white-space` style
|
|
136
|
-
// then leading and trailing spaces will be ignored. (2017/09/21)
|
|
137
|
-
span.style.whiteSpace = 'pre';
|
|
138
|
-
span.appendChild(attach);
|
|
139
|
-
contents.appendChild(span);
|
|
140
|
-
attach = span;
|
|
141
|
-
}
|
|
142
|
-
const fragment = e.getFragment();
|
|
143
|
-
// Add the content to a <div> so that we can get its inner HTML.
|
|
144
|
-
const div = contents.ownerDocument.createElement('div');
|
|
145
|
-
const attachWrapper = document.createElement('div');
|
|
146
|
-
const elements = Array.from(contents.children);
|
|
147
|
-
if (isInvalidTable(elements)) {
|
|
148
|
-
contents = completeTable(contents.cloneNode(true));
|
|
149
|
-
}
|
|
150
|
-
attachWrapper.appendChild(contents);
|
|
151
|
-
div.appendChild(attachWrapper);
|
|
152
|
-
div.setAttribute('hidden', 'true');
|
|
153
|
-
contents.ownerDocument.body.appendChild(div);
|
|
154
|
-
setClipboardData({ text: getPlainText(div), elements: fragment }, div, attachWrapper, dataTransfer);
|
|
155
|
-
contents.ownerDocument.body.removeChild(div);
|
|
156
|
-
};
|
|
157
|
-
e.deleteCutData = () => {
|
|
158
|
-
const { selection } = editor;
|
|
159
|
-
if (selection) {
|
|
160
|
-
if (Range.isExpanded(selection)) {
|
|
161
|
-
Editor.deleteFragment(editor);
|
|
162
|
-
}
|
|
163
|
-
else {
|
|
164
|
-
const node = Node.parent(editor, selection.anchor.path);
|
|
165
|
-
if (Element.isElement(node) && Editor.isVoid(editor, node)) {
|
|
166
|
-
Transforms.delete(editor);
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
};
|
|
171
|
-
e.insertData = async (data) => {
|
|
172
|
-
if (!(await e.insertFragmentData(data))) {
|
|
173
|
-
e.insertTextData(data);
|
|
174
|
-
}
|
|
175
|
-
};
|
|
176
|
-
e.insertFragmentData = async (data) => {
|
|
177
|
-
/**
|
|
178
|
-
* Checking copied fragment from application/x-slate-fragment or data-slate-fragment
|
|
179
|
-
*/
|
|
180
|
-
const clipboardData = await getClipboardData(data);
|
|
181
|
-
if (clipboardData && clipboardData.elements) {
|
|
182
|
-
e.insertFragment(clipboardData.elements);
|
|
183
|
-
return true;
|
|
184
|
-
}
|
|
185
|
-
return false;
|
|
186
|
-
};
|
|
187
|
-
e.insertTextData = async (data) => {
|
|
188
|
-
const clipboardData = await getClipboardData(data);
|
|
189
|
-
if (clipboardData && clipboardData.text) {
|
|
190
|
-
const lines = clipboardData.text.split(/\r\n|\r|\n/);
|
|
191
|
-
let split = false;
|
|
192
|
-
for (const line of lines) {
|
|
193
|
-
if (split) {
|
|
194
|
-
Transforms.splitNodes(e, { always: true });
|
|
195
|
-
}
|
|
196
|
-
e.insertText(line);
|
|
197
|
-
split = true;
|
|
198
|
-
}
|
|
199
|
-
return true;
|
|
200
|
-
}
|
|
201
|
-
return false;
|
|
202
|
-
};
|
|
203
|
-
e.onKeydown = () => { };
|
|
204
|
-
e.onClick = () => { };
|
|
205
|
-
e.isBlockCard = element => false;
|
|
206
|
-
e.isExpanded = element => true;
|
|
207
|
-
e.onError = (errorData) => {
|
|
208
|
-
if (errorData.nativeError) {
|
|
209
|
-
console.error(errorData.nativeError);
|
|
210
|
-
}
|
|
211
|
-
else {
|
|
212
|
-
console.error(errorData);
|
|
213
|
-
}
|
|
214
|
-
};
|
|
215
|
-
return e;
|
|
216
|
-
};
|
|
217
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-angular.js","sourceRoot":"","sources":["../../../packages/src/plugins/with-angular.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAa,IAAI,EAAW,KAAK,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAG3F,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,YAAY,EAAE,SAAS,EAAE,cAAc,EAAO,WAAW,EAAE,MAAM,UAAU,CAAC;AACzH,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAClF,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEjD,MAAM,CAAC,MAAM,WAAW,GAAG,CAAmB,MAAS,EAAE,kBAAkB,GAAG,kBAAkB,EAAE,EAAE;IAChG,MAAM,CAAC,GAAG,MAA2B,CAAC;IACtC,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAE,GAAG,CAAC,CAAC;IAE9C,CAAC,CAAC,cAAc,GAAG,IAAI,CAAC,EAAE;QACtB,IAAI,IAAI,KAAK,MAAM,EAAE,CAAC;YAClB,OAAO,cAAc,CAAC,IAAI,CAAC,CAAC;QAChC,CAAC;QAED,IAAI,MAAM,CAAC,SAAS,IAAI,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC;YAC1D,MAAM,gBAAgB,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE;gBAC1C,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;gBAC7D,EAAE,EAAE,MAAM,CAAC,SAAS;aACvB,CAAC,CAAC;YAEH,IAAI,gBAAgB,EAAE,CAAC;gBACnB,MAAM,CAAC,EAAE,eAAe,CAAC,GAAG,gBAAgB,CAAC;gBAC7C,MAAM,kBAAkB,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE,eAAe,EAAE,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;gBAE1F,MAAM,gBAAgB,GAAG,oBAAoB,CAAC,CAAC,EAAE,kBAAkB,CAAC,CAAC;gBAErE,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,gBAAgB,CAAC,EAAE,CAAC;oBACvC,UAAU,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE,gBAAgB,EAAE,CAAC,CAAC;gBACxD,CAAC;YACL,CAAC;QACL,CAAC;IACL,CAAC,CAAC;IAEF,CAAC,CAAC,KAAK,GAAG,CAAC,EAAa,EAAE,EAAE;QACxB,MAAM,OAAO,GAA4B,EAAE,CAAC;QAE5C,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC;YACd,KAAK,aAAa,CAAC;YACnB,KAAK,aAAa,CAAC;YACnB,KAAK,UAAU,CAAC,CAAC,CAAC;gBACd,KAAK,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC;oBAC3D,MAAM,GAAG,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;oBAC3C,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC;gBAC9B,CAAC;gBAED,MAAM;YACV,CAAC;YAED,KAAK,aAAa,CAAC;YACnB,KAAK,aAAa,CAAC;YACnB,KAAK,YAAY,CAAC;YAClB,KAAK,YAAY,CAAC,CAAC,CAAC;gBAChB,KAAK,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE;oBACxC,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC;iBAC3B,CAAC,EAAE,CAAC;oBACD,MAAM,GAAG,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;oBAC3C,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC;gBAC9B,CAAC;gBAED,MAAM;YACV,CAAC;YAED,KAAK,WAAW,CAAC,CAAC,CAAC;gBACf,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;gBAC9E,KAAK,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE;oBACxC,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC;iBAC3B,CAAC,EAAE,CAAC;oBACD,MAAM,GAAG,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;oBAC3C,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;gBACtD,CAAC;gBACD,KAAK,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE;oBACxC,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC;iBAC9B,CAAC,EAAE,CAAC;oBACD,IAAI,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC;wBAClC,MAAM,GAAG,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;wBAC3C,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;oBACtD,CAAC;gBACL,CAAC;gBACD,MAAM;YACV,CAAC;QACL,CAAC;QAED,KAAK,CAAC,EAAE,CAAC,CAAC;QAEV,KAAK,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,IAAI,OAAO,EAAE,CAAC;YAClC,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;YAC7E,WAAW,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC/B,CAAC;IACL,CAAC,CAAC;IAEF,CAAC,CAAC,QAAQ,GAAG,GAAG,EAAE;QACd,MAAM,eAAe,GAAG,mBAAmB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAEnD,IAAI,eAAe,EAAE,CAAC;YAClB,eAAe,EAAE,CAAC;QACtB,CAAC;QAED,QAAQ,EAAE,CAAC;IACf,CAAC,CAAC;IAEF,CAAC,CAAC,eAAe,GAAG,CAAC,YAAwD,EAAE,WAAyB,EAAE,EAAE;QACxG,MAAM,EAAE,SAAS,EAAE,GAAG,CAAC,CAAC;QAExB,IAAI,CAAC,SAAS,EAAE,CAAC;YACb,OAAO;QACX,CAAC;QAED,MAAM,CAAC,KAAK,EAAE,GAAG,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAC5C,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QACrD,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;QAEjD,IAAI,KAAK,CAAC,WAAW,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YAC7C,OAAO;QACX,CAAC;QAED,0EAA0E;QAC1E,oDAAoD;QACpD,MAAM,QAAQ,GAAG,aAAa,CAAC,UAAU,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;QACxD,IAAI,QAAQ,GAAG,QAAQ,CAAC,aAAa,EAAE,CAAC;QACxC,IAAI,MAAM,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAgB,CAAC;QAEnD,wEAAwE;QACxE,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACpD,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACzB,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;gBACrD,MAAM,GAAG,IAAmB,CAAC;YACjC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,yEAAyE;QACzE,wEAAwE;QACxE,iEAAiE;QACjE,IAAI,OAAO,EAAE,CAAC;YACV,MAAM,CAAC,QAAQ,CAAC,GAAG,OAAO,CAAC;YAC3B,MAAM,CAAC,GAAG,QAAQ,CAAC,UAAU,EAAE,CAAC;YAChC,MAAM,OAAO,GAAG,aAAa,CAAC,SAAS,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;YACrD,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YACvB,QAAQ,GAAG,CAAC,CAAC,aAAa,EAAE,CAAC;QACjC,CAAC;QAED,0EAA0E;QAC1E,0EAA0E;QAC1E,6EAA6E;QAC7E,8BAA8B;QAC9B,IAAI,SAAS,EAAE,CAAC;YACZ,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,qBAAqB,CAAiB,CAAC;QAC3E,CAAC;QAED,2EAA2E;QAC3E,iCAAiC;QACjC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,yBAAyB,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;YAC1E,MAAM,SAAS,GAAG,EAAE,CAAC,YAAY,CAAC,uBAAuB,CAAC,KAAK,GAAG,CAAC;YACnE,EAAE,CAAC,WAAW,GAAG,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QAC3C,CAAC,CAAC,CAAC;QAEH,4EAA4E;QAC5E,uEAAuE;QACvE,2EAA2E;QAC3E,IAAI,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC;YACpB,MAAM,IAAI,GAAG,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YACxD,wEAAwE;YACxE,iEAAiE;YACjE,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,KAAK,CAAC;YAC9B,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YACzB,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAC3B,MAAM,GAAG,IAAI,CAAC;QAClB,CAAC;QAED,MAAM,QAAQ,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;QAEjC,gEAAgE;QAChE,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACxD,MAAM,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACpD,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAC/C,IAAI,cAAc,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC3B,QAAQ,GAAG,aAAa,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAqB,CAAC,CAAC;QAC3E,CAAC;QAED,aAAa,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QACpC,GAAG,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAC/B,GAAG,CAAC,YAAY,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QACnC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAC7C,gBAAgB,CAAC,EAAE,IAAI,EAAE,YAAY,CAAC,GAAG,CAAC,EAAE,QAAQ,EAAE,QAAqB,EAAE,EAAE,GAAG,EAAE,aAAa,EAAE,YAAY,CAAC,CAAC;QACjH,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IACjD,CAAC,CAAC;IAEF,CAAC,CAAC,aAAa,GAAG,GAAG,EAAE;QACnB,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,IAAI,SAAS,EAAE,CAAC;YACZ,IAAI,KAAK,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;gBAC9B,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;YAClC,CAAC;iBAAM,CAAC;gBACJ,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;gBACxD,IAAI,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC;oBACzD,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBAC9B,CAAC;YACL,CAAC;QACL,CAAC;IACL,CAAC,CAAC;IAEF,CAAC,CAAC,UAAU,GAAG,KAAK,EAAE,IAAkB,EAAE,EAAE;QACxC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;YACtC,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAC3B,CAAC;IACL,CAAC,CAAC;IAEF,CAAC,CAAC,kBAAkB,GAAG,KAAK,EAAE,IAAkB,EAAoB,EAAE;QAClE;;WAEG;QACH,MAAM,aAAa,GAAG,MAAM,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACnD,IAAI,aAAa,IAAI,aAAa,CAAC,QAAQ,EAAE,CAAC;YAC1C,CAAC,CAAC,cAAc,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YACzC,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,OAAO,KAAK,CAAC;IACjB,CAAC,CAAC;IAEF,CAAC,CAAC,cAAc,GAAG,KAAK,EAAE,IAAkB,EAAoB,EAAE;QAC9D,MAAM,aAAa,GAAG,MAAM,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAEnD,IAAI,aAAa,IAAI,aAAa,CAAC,IAAI,EAAE,CAAC;YACtC,MAAM,KAAK,GAAG,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YACrD,IAAI,KAAK,GAAG,KAAK,CAAC;YAElB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBACvB,IAAI,KAAK,EAAE,CAAC;oBACR,UAAU,CAAC,UAAU,CAAC,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;gBAC/C,CAAC;gBAED,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBACnB,KAAK,GAAG,IAAI,CAAC;YACjB,CAAC;YACD,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,OAAO,KAAK,CAAC;IACjB,CAAC,CAAC;IAEF,CAAC,CAAC,SAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;IAEvB,CAAC,CAAC,OAAO,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;IAErB,CAAC,CAAC,WAAW,GAAG,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC;IAEjC,CAAC,CAAC,UAAU,GAAG,OAAO,CAAC,EAAE,CAAC,IAAI,CAAC;IAE/B,CAAC,CAAC,OAAO,GAAG,CAAC,SAAqB,EAAE,EAAE;QAClC,IAAI,SAAS,CAAC,WAAW,EAAE,CAAC;YACxB,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QACzC,CAAC;aAAM,CAAC;YACJ,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAC7B,CAAC;IACL,CAAC,CAAC;IAEF,OAAO,CAAC,CAAC;AACb,CAAC,CAAC","sourcesContent":["import { Editor, Element, Node, Operation, Path, PathRef, Range, Transforms } from 'slate';\nimport { OriginEvent } from '../types/clipboard';\nimport { SlateError } from '../types/error';\nimport { completeTable, EDITOR_TO_ON_CHANGE, getPlainText, isDOMText, isInvalidTable, Key, NODE_TO_KEY } from '../utils';\nimport { getClipboardData, setClipboardData } from '../utils/clipboard/clipboard';\nimport { findCurrentLineRange } from '../utils/lines';\nimport { AngularEditor } from './angular-editor';\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 => Element.isElement(n) && Editor.isBlock(editor, n),\n                at: editor.selection\n            });\n\n            if (parentBlockEntry) {\n                const [, parentBlockPath] = parentBlockEntry;\n                const parentElementRange = Editor.range(editor, parentBlockPath, editor.selection.anchor);\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 | PathRef, 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, {\n                    at: Path.parent(op.path)\n                })) {\n                    const key = AngularEditor.findKey(e, node);\n                    matches.push([Editor.pathRef(editor, path), key]);\n                }\n                for (const [node, path] of Editor.levels(e, {\n                    at: Path.parent(op.newPath)\n                })) {\n                    if (path.length > commonPath.length) {\n                        const key = AngularEditor.findKey(e, node);\n                        matches.push([Editor.pathRef(editor, path), key]);\n                    }\n                }\n                break;\n            }\n        }\n\n        apply(op);\n\n        for (const [source, key] of matches) {\n            const [node] = Editor.node(e, Path.isPath(source) ? source : source.current);\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 = (dataTransfer?: Pick<DataTransfer, 'getData' | 'setData'>, originEvent?: OriginEvent) => {\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(zw => {\n            const isNewline = zw.getAttribute('data-slate-zero-width') === 'n';\n            zw.textContent = isNewline ? '\\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\n        // Add the content to a <div> so that we can get its inner HTML.\n        const div = contents.ownerDocument.createElement('div');\n        const attachWrapper = document.createElement('div');\n        const elements = Array.from(contents.children);\n        if (isInvalidTable(elements)) {\n            contents = completeTable(contents.cloneNode(true) as DocumentFragment);\n        }\n\n        attachWrapper.appendChild(contents);\n        div.appendChild(attachWrapper);\n        div.setAttribute('hidden', 'true');\n        contents.ownerDocument.body.appendChild(div);\n        setClipboardData({ text: getPlainText(div), elements: fragment as Element[] }, div, attachWrapper, dataTransfer);\n        contents.ownerDocument.body.removeChild(div);\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 (Element.isElement(node) && Editor.isVoid(editor, node)) {\n                    Transforms.delete(editor);\n                }\n            }\n        }\n    };\n\n    e.insertData = async (data: DataTransfer) => {\n        if (!(await e.insertFragmentData(data))) {\n            e.insertTextData(data);\n        }\n    };\n\n    e.insertFragmentData = async (data: DataTransfer): Promise<boolean> => {\n        /**\n         * Checking copied fragment from application/x-slate-fragment or data-slate-fragment\n         */\n        const clipboardData = await getClipboardData(data);\n        if (clipboardData && clipboardData.elements) {\n            e.insertFragment(clipboardData.elements);\n            return true;\n        }\n        return false;\n    };\n\n    e.insertTextData = async (data: DataTransfer): Promise<boolean> => {\n        const clipboardData = await getClipboardData(data);\n\n        if (clipboardData && clipboardData.text) {\n            const lines = clipboardData.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.isExpanded = element => true;\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"]}
|
package/esm2022/public-api.mjs
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Public API Surface of slate-angular
|
|
3
|
-
*/
|
|
4
|
-
export * from './plugins/angular-editor';
|
|
5
|
-
export * from './plugins/with-angular';
|
|
6
|
-
export * from './components/editable/editable.component';
|
|
7
|
-
export * from './components/element/element.component';
|
|
8
|
-
export * from './components/string/string.component';
|
|
9
|
-
export * from './components/string/default-string.component';
|
|
10
|
-
export * from './components/children/children.component';
|
|
11
|
-
export * from './components/children/children-outlet.component';
|
|
12
|
-
export * from './components/leaves/leaves.component';
|
|
13
|
-
export * from './module';
|
|
14
|
-
export * from './types/error';
|
|
15
|
-
export * from './view/base';
|
|
16
|
-
export * from './view/context';
|
|
17
|
-
export * from './view/context-change';
|
|
18
|
-
export * from './utils';
|
|
19
|
-
export * from './types';
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3BhY2thZ2VzL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBzbGF0ZS1hbmd1bGFyXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vcGx1Z2lucy9hbmd1bGFyLWVkaXRvcic7XG5leHBvcnQgKiBmcm9tICcuL3BsdWdpbnMvd2l0aC1hbmd1bGFyJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9lZGl0YWJsZS9lZGl0YWJsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2VsZW1lbnQvZWxlbWVudC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL3N0cmluZy9zdHJpbmcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9zdHJpbmcvZGVmYXVsdC1zdHJpbmcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9jaGlsZHJlbi9jaGlsZHJlbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2NoaWxkcmVuL2NoaWxkcmVuLW91dGxldC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2xlYXZlcy9sZWF2ZXMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMvZXJyb3InO1xuZXhwb3J0ICogZnJvbSAnLi92aWV3L2Jhc2UnO1xuZXhwb3J0ICogZnJvbSAnLi92aWV3L2NvbnRleHQnO1xuZXhwb3J0ICogZnJvbSAnLi92aWV3L2NvbnRleHQtY2hhbmdlJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG4iXX0=
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './public-api';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xhdGUtYW5ndWxhci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3BhY2thZ2VzL3NyYy9zbGF0ZS1hbmd1bGFyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpcGJvYXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGFja2FnZXMvc3JjL3R5cGVzL2NsaXBib2FyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWxlbWVudCB9IGZyb20gJ3NsYXRlJztcblxuZXhwb3J0IGludGVyZmFjZSBDbGlwYm9hcmREYXRhIHtcbiAgICBmaWxlcz86IEZpbGVbXTtcbiAgICBlbGVtZW50cz86IEVsZW1lbnRbXTtcbiAgICB0ZXh0Pzogc3RyaW5nO1xuICAgIGh0bWw/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCB0eXBlIE9yaWdpbkV2ZW50ID0gJ2RyYWcnIHwgJ2NvcHknIHwgJ2N1dCc7Il19
|
package/esm2022/types/error.mjs
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
export var SlateErrorCode;
|
|
2
|
-
(function (SlateErrorCode) {
|
|
3
|
-
SlateErrorCode[SlateErrorCode["ToNativeSelectionError"] = 2100] = "ToNativeSelectionError";
|
|
4
|
-
SlateErrorCode[SlateErrorCode["ToSlateSelectionError"] = 2101] = "ToSlateSelectionError";
|
|
5
|
-
SlateErrorCode[SlateErrorCode["OnDOMBeforeInputError"] = 2102] = "OnDOMBeforeInputError";
|
|
6
|
-
SlateErrorCode[SlateErrorCode["OnSyntheticBeforeInputError"] = 2103] = "OnSyntheticBeforeInputError";
|
|
7
|
-
SlateErrorCode[SlateErrorCode["OnDOMKeydownError"] = 2104] = "OnDOMKeydownError";
|
|
8
|
-
SlateErrorCode[SlateErrorCode["GetStartPointError"] = 2105] = "GetStartPointError";
|
|
9
|
-
SlateErrorCode[SlateErrorCode["NotFoundPreviousRootNodeError"] = 3100] = "NotFoundPreviousRootNodeError";
|
|
10
|
-
SlateErrorCode[SlateErrorCode["InvalidValueError"] = 4100] = "InvalidValueError";
|
|
11
|
-
})(SlateErrorCode || (SlateErrorCode = {}));
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9zcmMvdHlwZXMvZXJyb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFOLElBQVksY0FTWDtBQVRELFdBQVksY0FBYztJQUN0QiwwRkFBNkIsQ0FBQTtJQUM3Qix3RkFBNEIsQ0FBQTtJQUM1Qix3RkFBNEIsQ0FBQTtJQUM1QixvR0FBa0MsQ0FBQTtJQUNsQyxnRkFBd0IsQ0FBQTtJQUN4QixrRkFBeUIsQ0FBQTtJQUN6Qix3R0FBb0MsQ0FBQTtJQUNwQyxnRkFBd0IsQ0FBQTtBQUM1QixDQUFDLEVBVFcsY0FBYyxLQUFkLGNBQWMsUUFTekIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEZXNjZW5kYW50IH0gZnJvbSAnc2xhdGUnO1xuXG5leHBvcnQgZW51bSBTbGF0ZUVycm9yQ29kZSB7XG4gICAgVG9OYXRpdmVTZWxlY3Rpb25FcnJvciA9IDIxMDAsXG4gICAgVG9TbGF0ZVNlbGVjdGlvbkVycm9yID0gMjEwMSxcbiAgICBPbkRPTUJlZm9yZUlucHV0RXJyb3IgPSAyMTAyLFxuICAgIE9uU3ludGhldGljQmVmb3JlSW5wdXRFcnJvciA9IDIxMDMsXG4gICAgT25ET01LZXlkb3duRXJyb3IgPSAyMTA0LFxuICAgIEdldFN0YXJ0UG9pbnRFcnJvciA9IDIxMDUsXG4gICAgTm90Rm91bmRQcmV2aW91c1Jvb3ROb2RlRXJyb3IgPSAzMTAwLFxuICAgIEludmFsaWRWYWx1ZUVycm9yID0gNDEwMFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNsYXRlRXJyb3Ige1xuICAgIGNvZGU/OiBTbGF0ZUVycm9yQ29kZSB8IG51bWJlcjtcbiAgICBuYW1lPzogc3RyaW5nO1xuICAgIG5hdGl2ZUVycm9yPzogRXJyb3I7XG4gICAgZGF0YT86IERlc2NlbmRhbnRbXTtcbn1cbiJdfQ==
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmVhdHVyZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL3NyYy90eXBlcy9mZWF0dXJlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYXNlUmFuZ2UgfSBmcm9tICdzbGF0ZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2xhdGVQbGFjZWhvbGRlciBleHRlbmRzIEJhc2VSYW5nZSB7XG4gICAgcGxhY2Vob2xkZXI6IHN0cmluZztcbn1cbiJdfQ==
|
package/esm2022/types/index.mjs
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
export * from './error';
|
|
2
|
-
export * from './view';
|
|
3
|
-
export * from './feature';
|
|
4
|
-
export * from './clipboard';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9zcmMvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Vycm9yJztcbmV4cG9ydCAqIGZyb20gJy4vdmlldyc7XG5leHBvcnQgKiBmcm9tICcuL2ZlYXR1cmUnO1xuZXhwb3J0ICogZnJvbSAnLi9jbGlwYm9hcmQnO1xuXG5leHBvcnQgdHlwZSBTYWZlQW55ID0gYW55O1xuIl19
|
package/esm2022/types/view.mjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlldy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL3NyYy90eXBlcy92aWV3LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbXBvbmVudFR5cGU8VD4ge1xuICAgIG5ldyAoLi4uYXJnczogYW55W10pOiBUO1xufVxuXG5leHBvcnQgdHlwZSBWaWV3VHlwZSA9IFRlbXBsYXRlUmVmPGFueT4gfCBDb21wb25lbnRUeXBlPGFueT47XG4iXX0=
|
|
@@ -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?.anchorNode) || hasBlockCardWithNode(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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2stY2FyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL3NyYy91dGlscy9ibG9jay1jYXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLDJCQUEyQixHQUFHLENBQUMsQ0FBQyxDQUFDO0FBRTlDLE1BQU0sQ0FBQyxNQUFNLDRCQUE0QixHQUFHLENBQUMsQ0FBQyxDQUFDO0FBRS9DLE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxJQUFhO0lBQzlDLE9BQU8sSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLFlBQVksV0FBVyxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ3pJLENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLFNBQXVCO0lBQ2hELE9BQU8sb0JBQW9CLENBQUMsU0FBUyxFQUFFLFVBQVUsQ0FBQyxJQUFJLG9CQUFvQixDQUFDLFNBQVMsRUFBRSxTQUFTLENBQUMsQ0FBQztBQUNyRyxDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUFDLElBQWE7SUFDaEQsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksWUFBWSxXQUFXLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO0FBQzNILENBQUM7QUFFRCxNQUFNLFVBQVUsVUFBVSxDQUFDLElBQWE7SUFDcEMsTUFBTSxVQUFVLEdBQUcsc0JBQXNCLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDaEQsT0FBTyxVQUFVLElBQUksVUFBVSxDQUFDLFNBQVMsS0FBSyxXQUFXLENBQUM7QUFDOUQsQ0FBQztBQUVELE1BQU0sVUFBVSxzQkFBc0IsQ0FBQyxVQUFlO0lBQ2xELE9BQU8sVUFBVSxJQUFJLFVBQVUsQ0FBQyxTQUFTLEtBQUssV0FBVyxDQUFDO0FBQzlELENBQUM7QUFFRCxNQUFNLFVBQVUsdUJBQXVCLENBQUMsVUFBZTtJQUNuRCxPQUFPLFVBQVUsSUFBSSxVQUFVLENBQUMsU0FBUyxLQUFLLFlBQVksQ0FBQztBQUMvRCxDQUFDO0FBRUQsTUFBTSxVQUFVLHdCQUF3QixDQUFDLFVBQWU7SUFDcEQsT0FBTyxVQUFVLElBQUksVUFBVSxDQUFDLFNBQVMsS0FBSyxhQUFhLENBQUM7QUFDaEUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERPTU5vZGUsIERPTVNlbGVjdGlvbiB9IGZyb20gJy4vZG9tJztcblxuZXhwb3J0IGNvbnN0IEZBS0VfTEVGVF9CTE9DS19DQVJEX09GRlNFVCA9IC0xO1xuXG5leHBvcnQgY29uc3QgRkFLRV9SSUdIVF9CTE9DS19DQVJEX09GRlNFVCA9IC0yO1xuXG5leHBvcnQgZnVuY3Rpb24gaGFzQmxvY2tDYXJkV2l0aE5vZGUobm9kZTogRE9NTm9kZSkge1xuICAgIHJldHVybiBub2RlICYmIChub2RlLnBhcmVudEVsZW1lbnQuaGFzQXR0cmlidXRlKCdjYXJkLXRhcmdldCcpIHx8IChub2RlIGluc3RhbmNlb2YgSFRNTEVsZW1lbnQgJiYgbm9kZS5oYXNBdHRyaWJ1dGUoJ2NhcmQtdGFyZ2V0JykpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGhhc0Jsb2NrQ2FyZChzZWxlY3Rpb246IERPTVNlbGVjdGlvbikge1xuICAgIHJldHVybiBoYXNCbG9ja0NhcmRXaXRoTm9kZShzZWxlY3Rpb24/LmFuY2hvck5vZGUpIHx8IGhhc0Jsb2NrQ2FyZFdpdGhOb2RlKHNlbGVjdGlvbj8uZm9jdXNOb2RlKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldENhcmRUYXJnZXRBdHRyaWJ1dGUobm9kZTogRE9NTm9kZSkge1xuICAgIHJldHVybiBub2RlLnBhcmVudEVsZW1lbnQuYXR0cmlidXRlc1snY2FyZC10YXJnZXQnXSB8fCAobm9kZSBpbnN0YW5jZW9mIEhUTUxFbGVtZW50ICYmIG5vZGUuYXR0cmlidXRlc1snY2FyZC10YXJnZXQnXSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0NhcmRMZWZ0KG5vZGU6IERPTU5vZGUpIHtcbiAgICBjb25zdCBjYXJkVGFyZ2V0ID0gZ2V0Q2FyZFRhcmdldEF0dHJpYnV0ZShub2RlKTtcbiAgICByZXR1cm4gY2FyZFRhcmdldCAmJiBjYXJkVGFyZ2V0Lm5vZGVWYWx1ZSA9PT0gJ2NhcmQtbGVmdCc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0NhcmRMZWZ0QnlUYXJnZXRBdHRyKHRhcmdldEF0dHI6IGFueSkge1xuICAgIHJldHVybiB0YXJnZXRBdHRyICYmIHRhcmdldEF0dHIubm9kZVZhbHVlID09PSAnY2FyZC1sZWZ0Jztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ2FyZFJpZ2h0QnlUYXJnZXRBdHRyKHRhcmdldEF0dHI6IGFueSkge1xuICAgIHJldHVybiB0YXJnZXRBdHRyICYmIHRhcmdldEF0dHIubm9kZVZhbHVlID09PSAnY2FyZC1yaWdodCc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0NhcmRDZW50ZXJCeVRhcmdldEF0dHIodGFyZ2V0QXR0cjogYW55KSB7XG4gICAgcmV0dXJuIHRhcmdldEF0dHIgJiYgdGFyZ2V0QXR0ci5ub2RlVmFsdWUgPT09ICdjYXJkLWNlbnRlcic7XG59XG4iXX0=
|
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
import { SlateFragmentAttributeKey, getSlateFragmentAttribute } from '../dom';
|
|
2
|
-
import { isClipboardReadSupported, isClipboardWriteSupported, isClipboardWriteTextSupported } from './common';
|
|
3
|
-
import { getDataTransferClipboard, setDataTransferClipboard, setDataTransferClipboardText } from './data-transfer';
|
|
4
|
-
import { getNavigatorClipboard, setNavigatorClipboard } from './navigator-clipboard';
|
|
5
|
-
export const buildHTMLText = (wrapper, attach, data) => {
|
|
6
|
-
const stringObj = JSON.stringify(data);
|
|
7
|
-
const encoded = window.btoa(encodeURIComponent(stringObj));
|
|
8
|
-
attach.setAttribute(SlateFragmentAttributeKey, encoded);
|
|
9
|
-
return wrapper.innerHTML;
|
|
10
|
-
};
|
|
11
|
-
export const getClipboardFromHTMLText = (html) => {
|
|
12
|
-
const fragmentAttribute = getSlateFragmentAttribute(html);
|
|
13
|
-
if (fragmentAttribute) {
|
|
14
|
-
try {
|
|
15
|
-
const decoded = decodeURIComponent(window.atob(fragmentAttribute));
|
|
16
|
-
const result = JSON.parse(decoded);
|
|
17
|
-
if (result && Array.isArray(result) && result.length > 0) {
|
|
18
|
-
return {
|
|
19
|
-
elements: result
|
|
20
|
-
};
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
catch (error) {
|
|
24
|
-
console.error(error);
|
|
25
|
-
return null;
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
return null;
|
|
29
|
-
};
|
|
30
|
-
export const createClipboardData = (html, elements, text, files) => {
|
|
31
|
-
const data = { elements, text, html, files };
|
|
32
|
-
return data;
|
|
33
|
-
};
|
|
34
|
-
export const getClipboardData = async (dataTransfer) => {
|
|
35
|
-
let clipboardData = null;
|
|
36
|
-
if (dataTransfer) {
|
|
37
|
-
let filesData = {};
|
|
38
|
-
if (dataTransfer.files.length) {
|
|
39
|
-
filesData = { ...filesData, files: Array.from(dataTransfer.files) };
|
|
40
|
-
}
|
|
41
|
-
clipboardData = getDataTransferClipboard(dataTransfer);
|
|
42
|
-
return { ...clipboardData, ...filesData };
|
|
43
|
-
}
|
|
44
|
-
if (isClipboardReadSupported()) {
|
|
45
|
-
return await getNavigatorClipboard();
|
|
46
|
-
}
|
|
47
|
-
return clipboardData;
|
|
48
|
-
};
|
|
49
|
-
/**
|
|
50
|
-
* @param wrapper get wrapper.innerHTML string which will be written in clipboard
|
|
51
|
-
* @param attach attach must be child element of wrapper which will be attached json data
|
|
52
|
-
* @returns void
|
|
53
|
-
*/
|
|
54
|
-
export const setClipboardData = async (clipboardData, wrapper, attach, dataTransfer) => {
|
|
55
|
-
if (!clipboardData) {
|
|
56
|
-
return;
|
|
57
|
-
}
|
|
58
|
-
const { elements, text } = clipboardData;
|
|
59
|
-
if (isClipboardWriteSupported()) {
|
|
60
|
-
const htmlText = buildHTMLText(wrapper, attach, elements);
|
|
61
|
-
// TODO
|
|
62
|
-
// maybe fail to write when copy some cell in table
|
|
63
|
-
return await setNavigatorClipboard(htmlText, elements, text);
|
|
64
|
-
}
|
|
65
|
-
if (dataTransfer) {
|
|
66
|
-
const htmlText = buildHTMLText(wrapper, attach, elements);
|
|
67
|
-
setDataTransferClipboard(dataTransfer, htmlText);
|
|
68
|
-
setDataTransferClipboardText(dataTransfer, text);
|
|
69
|
-
return;
|
|
70
|
-
}
|
|
71
|
-
// Compatible with situations where navigator.clipboard.write is not supported and dataTransfer is empty
|
|
72
|
-
// Such as contextmenu copy in Firefox.
|
|
73
|
-
if (isClipboardWriteTextSupported()) {
|
|
74
|
-
const htmlText = buildHTMLText(wrapper, attach, elements);
|
|
75
|
-
return await navigator.clipboard.writeText(htmlText);
|
|
76
|
-
}
|
|
77
|
-
};
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clipboard.js","sourceRoot":"","sources":["../../../../packages/src/utils/clipboard/clipboard.ts"],"names":[],"mappings":"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","sourcesContent":["import { Element } from 'slate';\nimport { ClipboardData } from '../../types/clipboard';\nimport { SlateFragmentAttributeKey, getSlateFragmentAttribute } from '../dom';\nimport { isClipboardReadSupported, isClipboardWriteSupported, isClipboardWriteTextSupported } from './common';\nimport { getDataTransferClipboard, setDataTransferClipboard, setDataTransferClipboardText } from './data-transfer';\nimport { getNavigatorClipboard, setNavigatorClipboard } from './navigator-clipboard';\n\nexport const buildHTMLText = (wrapper: HTMLElement, attach: HTMLElement, data: Element[]) => {\n    const stringObj = JSON.stringify(data);\n    const encoded = window.btoa(encodeURIComponent(stringObj));\n    attach.setAttribute(SlateFragmentAttributeKey, encoded);\n    return wrapper.innerHTML;\n};\n\nexport const getClipboardFromHTMLText = (html: string): ClipboardData => {\n    const fragmentAttribute = getSlateFragmentAttribute(html);\n    if (fragmentAttribute) {\n        try {\n            const decoded = decodeURIComponent(window.atob(fragmentAttribute));\n            const result = JSON.parse(decoded);\n            if (result && Array.isArray(result) && result.length > 0) {\n                return {\n                    elements: result\n                };\n            }\n        } catch (error) {\n            console.error(error);\n            return null;\n        }\n    }\n    return null;\n};\n\nexport const createClipboardData = (html: string, elements: Element[], text: string, files: File[]): ClipboardData => {\n    const data = { elements, text, html, files };\n    return data;\n};\n\nexport const getClipboardData = async (dataTransfer?: DataTransfer): Promise<ClipboardData> => {\n    let clipboardData = null;\n    if (dataTransfer) {\n        let filesData = {};\n        if (dataTransfer.files.length) {\n            filesData = { ...filesData, files: Array.from(dataTransfer.files) };\n        }\n        clipboardData = getDataTransferClipboard(dataTransfer);\n        return { ...clipboardData, ...filesData };\n    }\n    if (isClipboardReadSupported()) {\n        return await getNavigatorClipboard();\n    }\n    return clipboardData;\n};\n\n/**\n * @param wrapper get wrapper.innerHTML string which will be written in clipboard\n * @param attach attach must be child element of wrapper which will be attached json data\n * @returns void\n */\nexport const setClipboardData = async (\n    clipboardData: ClipboardData,\n    wrapper: HTMLElement,\n    attach: HTMLElement,\n    dataTransfer?: Pick<DataTransfer, 'getData' | 'setData'>\n) => {\n    if (!clipboardData) {\n        return;\n    }\n    const { elements, text } = clipboardData;\n    if (isClipboardWriteSupported()) {\n        const htmlText = buildHTMLText(wrapper, attach, elements);\n        // TODO\n        // maybe fail to write when copy some cell in table\n        return await setNavigatorClipboard(htmlText, elements, text);\n    }\n\n    if (dataTransfer) {\n        const htmlText = buildHTMLText(wrapper, attach, elements);\n        setDataTransferClipboard(dataTransfer, htmlText);\n        setDataTransferClipboardText(dataTransfer, text);\n        return;\n    }\n\n    // Compatible with situations where navigator.clipboard.write is not supported and dataTransfer is empty\n    // Such as contextmenu copy in Firefox.\n    if (isClipboardWriteTextSupported()) {\n        const htmlText = buildHTMLText(wrapper, attach, elements);\n        return await navigator.clipboard.writeText(htmlText);\n    }\n};\n"]}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
export const isClipboardReadSupported = () => {
|
|
2
|
-
return 'clipboard' in navigator && 'read' in navigator.clipboard;
|
|
3
|
-
};
|
|
4
|
-
export const isClipboardWriteSupported = () => {
|
|
5
|
-
return 'clipboard' in navigator && 'write' in navigator.clipboard;
|
|
6
|
-
};
|
|
7
|
-
export const isClipboardWriteTextSupported = () => {
|
|
8
|
-
return 'clipboard' in navigator && 'writeText' in navigator.clipboard;
|
|
9
|
-
};
|
|
10
|
-
export const isClipboardFile = (item) => {
|
|
11
|
-
return item.types.find(i => i.match(/^image\//));
|
|
12
|
-
};
|
|
13
|
-
export const isInvalidTable = (nodes = []) => {
|
|
14
|
-
return nodes.some(node => node.tagName.toLowerCase() === 'tr');
|
|
15
|
-
};
|
|
16
|
-
export const stripHtml = (html) => {
|
|
17
|
-
// See <https://github.com/developit/preact-markup/blob/4788b8d61b4e24f83688710746ee36e7464f7bbc/src/parse-markup.js#L60-L69>
|
|
18
|
-
const doc = document.implementation.createHTMLDocument('');
|
|
19
|
-
doc.documentElement.innerHTML = html.trim();
|
|
20
|
-
return doc.body.textContent || doc.body.innerText || '';
|
|
21
|
-
};
|
|
22
|
-
export const blobAsString = (blob) => {
|
|
23
|
-
return new Promise((resolve, reject) => {
|
|
24
|
-
const reader = new FileReader();
|
|
25
|
-
reader.addEventListener('loadend', () => {
|
|
26
|
-
const text = reader.result;
|
|
27
|
-
resolve(text);
|
|
28
|
-
});
|
|
29
|
-
reader.addEventListener('error', () => {
|
|
30
|
-
reject(reader.error);
|
|
31
|
-
});
|
|
32
|
-
reader.readAsText(blob);
|
|
33
|
-
});
|
|
34
|
-
};
|
|
35
|
-
export const completeTable = (fragment) => {
|
|
36
|
-
const result = document.createDocumentFragment();
|
|
37
|
-
const table = document.createElement('table');
|
|
38
|
-
result.appendChild(table);
|
|
39
|
-
table.appendChild(fragment);
|
|
40
|
-
return result;
|
|
41
|
-
};
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3V0aWxzL2NsaXBib2FyZC9jb21tb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcsR0FBRyxFQUFFO0lBQ3pDLE9BQU8sV0FBVyxJQUFJLFNBQVMsSUFBSSxNQUFNLElBQUksU0FBUyxDQUFDLFNBQVMsQ0FBQztBQUNyRSxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRyxHQUFHLEVBQUU7SUFDMUMsT0FBTyxXQUFXLElBQUksU0FBUyxJQUFJLE9BQU8sSUFBSSxTQUFTLENBQUMsU0FBUyxDQUFDO0FBQ3RFLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDZCQUE2QixHQUFHLEdBQUcsRUFBRTtJQUM5QyxPQUFPLFdBQVcsSUFBSSxTQUFTLElBQUksV0FBVyxJQUFJLFNBQVMsQ0FBQyxTQUFTLENBQUM7QUFDMUUsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLENBQUMsSUFBbUIsRUFBRSxFQUFFO0lBQ25ELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7QUFDckQsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLENBQUMsUUFBbUIsRUFBRSxFQUFFLEVBQUU7SUFDcEQsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsS0FBSyxJQUFJLENBQUMsQ0FBQztBQUNuRSxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsQ0FBQyxJQUFZLEVBQUUsRUFBRTtJQUN0Qyw2SEFBNkg7SUFDN0gsTUFBTSxHQUFHLEdBQUcsUUFBUSxDQUFDLGNBQWMsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUMzRCxHQUFHLENBQUMsZUFBZSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDNUMsT0FBTyxHQUFHLENBQUMsSUFBSSxDQUFDLFdBQVcsSUFBSSxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsSUFBSSxFQUFFLENBQUM7QUFDNUQsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLENBQUMsSUFBVSxFQUFFLEVBQUU7SUFDdkMsT0FBTyxJQUFJLE9BQU8sQ0FBUyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtRQUMzQyxNQUFNLE1BQU0sR0FBRyxJQUFJLFVBQVUsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLEVBQUUsR0FBRyxFQUFFO1lBQ3BDLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUM7WUFDM0IsT0FBTyxDQUFDLElBQWMsQ0FBQyxDQUFDO1FBQzVCLENBQUMsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUU7WUFDbEMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN6QixDQUFDLENBQUMsQ0FBQztRQUNILE1BQU0sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDNUIsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUcsQ0FBQyxRQUEwQixFQUFFLEVBQUU7SUFDeEQsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLHNCQUFzQixFQUFFLENBQUM7SUFDakQsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUM5QyxNQUFNLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzFCLEtBQUssQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDNUIsT0FBTyxNQUFNLENBQUM7QUFDbEIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGlzQ2xpcGJvYXJkUmVhZFN1cHBvcnRlZCA9ICgpID0+IHtcbiAgICByZXR1cm4gJ2NsaXBib2FyZCcgaW4gbmF2aWdhdG9yICYmICdyZWFkJyBpbiBuYXZpZ2F0b3IuY2xpcGJvYXJkO1xufTtcblxuZXhwb3J0IGNvbnN0IGlzQ2xpcGJvYXJkV3JpdGVTdXBwb3J0ZWQgPSAoKSA9PiB7XG4gICAgcmV0dXJuICdjbGlwYm9hcmQnIGluIG5hdmlnYXRvciAmJiAnd3JpdGUnIGluIG5hdmlnYXRvci5jbGlwYm9hcmQ7XG59O1xuXG5leHBvcnQgY29uc3QgaXNDbGlwYm9hcmRXcml0ZVRleHRTdXBwb3J0ZWQgPSAoKSA9PiB7XG4gICAgcmV0dXJuICdjbGlwYm9hcmQnIGluIG5hdmlnYXRvciAmJiAnd3JpdGVUZXh0JyBpbiBuYXZpZ2F0b3IuY2xpcGJvYXJkO1xufTtcblxuZXhwb3J0IGNvbnN0IGlzQ2xpcGJvYXJkRmlsZSA9IChpdGVtOiBDbGlwYm9hcmRJdGVtKSA9PiB7XG4gICAgcmV0dXJuIGl0ZW0udHlwZXMuZmluZChpID0+IGkubWF0Y2goL15pbWFnZVxcLy8pKTtcbn07XG5cbmV4cG9ydCBjb25zdCBpc0ludmFsaWRUYWJsZSA9IChub2RlczogRWxlbWVudFtdID0gW10pID0+IHtcbiAgICByZXR1cm4gbm9kZXMuc29tZShub2RlID0+IG5vZGUudGFnTmFtZS50b0xvd2VyQ2FzZSgpID09PSAndHInKTtcbn07XG5cbmV4cG9ydCBjb25zdCBzdHJpcEh0bWwgPSAoaHRtbDogc3RyaW5nKSA9PiB7XG4gICAgLy8gU2VlIDxodHRwczovL2dpdGh1Yi5jb20vZGV2ZWxvcGl0L3ByZWFjdC1tYXJrdXAvYmxvYi80Nzg4YjhkNjFiNGUyNGY4MzY4ODcxMDc0NmVlMzZlNzQ2NGY3YmJjL3NyYy9wYXJzZS1tYXJrdXAuanMjTDYwLUw2OT5cbiAgICBjb25zdCBkb2MgPSBkb2N1bWVudC5pbXBsZW1lbnRhdGlvbi5jcmVhdGVIVE1MRG9jdW1lbnQoJycpO1xuICAgIGRvYy5kb2N1bWVudEVsZW1lbnQuaW5uZXJIVE1MID0gaHRtbC50cmltKCk7XG4gICAgcmV0dXJuIGRvYy5ib2R5LnRleHRDb250ZW50IHx8IGRvYy5ib2R5LmlubmVyVGV4dCB8fCAnJztcbn07XG5cbmV4cG9ydCBjb25zdCBibG9iQXNTdHJpbmcgPSAoYmxvYjogQmxvYikgPT4ge1xuICAgIHJldHVybiBuZXcgUHJvbWlzZTxzdHJpbmc+KChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgICAgY29uc3QgcmVhZGVyID0gbmV3IEZpbGVSZWFkZXIoKTtcbiAgICAgICAgcmVhZGVyLmFkZEV2ZW50TGlzdGVuZXIoJ2xvYWRlbmQnLCAoKSA9PiB7XG4gICAgICAgICAgICBjb25zdCB0ZXh0ID0gcmVhZGVyLnJlc3VsdDtcbiAgICAgICAgICAgIHJlc29sdmUodGV4dCBhcyBzdHJpbmcpO1xuICAgICAgICB9KTtcbiAgICAgICAgcmVhZGVyLmFkZEV2ZW50TGlzdGVuZXIoJ2Vycm9yJywgKCkgPT4ge1xuICAgICAgICAgICAgcmVqZWN0KHJlYWRlci5lcnJvcik7XG4gICAgICAgIH0pO1xuICAgICAgICByZWFkZXIucmVhZEFzVGV4dChibG9iKTtcbiAgICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBjb21wbGV0ZVRhYmxlID0gKGZyYWdtZW50OiBEb2N1bWVudEZyYWdtZW50KSA9PiB7XG4gICAgY29uc3QgcmVzdWx0ID0gZG9jdW1lbnQuY3JlYXRlRG9jdW1lbnRGcmFnbWVudCgpO1xuICAgIGNvbnN0IHRhYmxlID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgndGFibGUnKTtcbiAgICByZXN1bHQuYXBwZW5kQ2hpbGQodGFibGUpO1xuICAgIHRhYmxlLmFwcGVuZENoaWxkKGZyYWdtZW50KTtcbiAgICByZXR1cm4gcmVzdWx0O1xufTtcbiJdfQ==
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
import { getClipboardFromHTMLText } from './clipboard';
|
|
2
|
-
export const setDataTransferClipboard = (dataTransfer, htmlText) => {
|
|
3
|
-
dataTransfer?.setData(`text/html`, htmlText);
|
|
4
|
-
};
|
|
5
|
-
export const setDataTransferClipboardText = (data, text) => {
|
|
6
|
-
data?.setData(`text/plain`, text);
|
|
7
|
-
};
|
|
8
|
-
export const getDataTransferClipboard = (data) => {
|
|
9
|
-
const html = data?.getData(`text/html`);
|
|
10
|
-
if (html) {
|
|
11
|
-
const htmlClipboardData = getClipboardFromHTMLText(html);
|
|
12
|
-
if (htmlClipboardData) {
|
|
13
|
-
return htmlClipboardData;
|
|
14
|
-
}
|
|
15
|
-
const textData = getDataTransferClipboardText(data);
|
|
16
|
-
if (textData) {
|
|
17
|
-
return {
|
|
18
|
-
html,
|
|
19
|
-
...textData
|
|
20
|
-
};
|
|
21
|
-
}
|
|
22
|
-
else {
|
|
23
|
-
return { html };
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
else {
|
|
27
|
-
const textData = getDataTransferClipboardText(data);
|
|
28
|
-
return textData;
|
|
29
|
-
}
|
|
30
|
-
};
|
|
31
|
-
export const getDataTransferClipboardText = (data) => {
|
|
32
|
-
if (!data) {
|
|
33
|
-
return null;
|
|
34
|
-
}
|
|
35
|
-
const text = data?.getData(`text/plain`);
|
|
36
|
-
if (text) {
|
|
37
|
-
const htmlClipboardData = getClipboardFromHTMLText(text);
|
|
38
|
-
if (htmlClipboardData) {
|
|
39
|
-
return htmlClipboardData;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
return { text };
|
|
43
|
-
};
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10cmFuc2Zlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy91dGlscy9jbGlwYm9hcmQvZGF0YS10cmFuc2Zlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFHdkQsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcsQ0FBQyxZQUE4RCxFQUFFLFFBQWdCLEVBQUUsRUFBRTtJQUN6SCxZQUFZLEVBQUUsT0FBTyxDQUFDLFdBQVcsRUFBRSxRQUFRLENBQUMsQ0FBQztBQUNqRCxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSw0QkFBNEIsR0FBRyxDQUFDLElBQXNELEVBQUUsSUFBWSxFQUFFLEVBQUU7SUFDakgsSUFBSSxFQUFFLE9BQU8sQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDdEMsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcsQ0FBQyxJQUFzRCxFQUFpQixFQUFFO0lBQzlHLE1BQU0sSUFBSSxHQUFHLElBQUksRUFBRSxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDeEMsSUFBSSxJQUFJLEVBQUUsQ0FBQztRQUNQLE1BQU0saUJBQWlCLEdBQUcsd0JBQXdCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDekQsSUFBSSxpQkFBaUIsRUFBRSxDQUFDO1lBQ3BCLE9BQU8saUJBQWlCLENBQUM7UUFDN0IsQ0FBQztRQUNELE1BQU0sUUFBUSxHQUFHLDRCQUE0QixDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3BELElBQUksUUFBUSxFQUFFLENBQUM7WUFDWCxPQUFPO2dCQUNILElBQUk7Z0JBQ0osR0FBRyxRQUFRO2FBQ2QsQ0FBQztRQUNOLENBQUM7YUFBTSxDQUFDO1lBQ0osT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDO1FBQ3BCLENBQUM7SUFDTCxDQUFDO1NBQU0sQ0FBQztRQUNKLE1BQU0sUUFBUSxHQUFHLDRCQUE0QixDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3BELE9BQU8sUUFBUSxDQUFDO0lBQ3BCLENBQUM7QUFDTCxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSw0QkFBNEIsR0FBRyxDQUFDLElBQXNELEVBQWlCLEVBQUU7SUFDbEgsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ1IsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQztJQUNELE1BQU0sSUFBSSxHQUFHLElBQUksRUFBRSxPQUFPLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDekMsSUFBSSxJQUFJLEVBQUUsQ0FBQztRQUNQLE1BQU0saUJBQWlCLEdBQUcsd0JBQXdCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDekQsSUFBSSxpQkFBaUIsRUFBRSxDQUFDO1lBQ3BCLE9BQU8saUJBQWlCLENBQUM7UUFDN0IsQ0FBQztJQUNMLENBQUM7SUFDRCxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUM7QUFDcEIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0Q2xpcGJvYXJkRnJvbUhUTUxUZXh0IH0gZnJvbSAnLi9jbGlwYm9hcmQnO1xuaW1wb3J0IHsgQ2xpcGJvYXJkRGF0YSB9IGZyb20gJy4uLy4uL3R5cGVzL2NsaXBib2FyZCc7XG5cbmV4cG9ydCBjb25zdCBzZXREYXRhVHJhbnNmZXJDbGlwYm9hcmQgPSAoZGF0YVRyYW5zZmVyOiBQaWNrPERhdGFUcmFuc2ZlciwgJ2dldERhdGEnIHwgJ3NldERhdGEnPiB8IG51bGwsIGh0bWxUZXh0OiBzdHJpbmcpID0+IHtcbiAgICBkYXRhVHJhbnNmZXI/LnNldERhdGEoYHRleHQvaHRtbGAsIGh0bWxUZXh0KTtcbn07XG5cbmV4cG9ydCBjb25zdCBzZXREYXRhVHJhbnNmZXJDbGlwYm9hcmRUZXh0ID0gKGRhdGE6IFBpY2s8RGF0YVRyYW5zZmVyLCAnZ2V0RGF0YScgfCAnc2V0RGF0YSc+IHwgbnVsbCwgdGV4dDogc3RyaW5nKSA9PiB7XG4gICAgZGF0YT8uc2V0RGF0YShgdGV4dC9wbGFpbmAsIHRleHQpO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldERhdGFUcmFuc2ZlckNsaXBib2FyZCA9IChkYXRhOiBQaWNrPERhdGFUcmFuc2ZlciwgJ2dldERhdGEnIHwgJ3NldERhdGEnPiB8IG51bGwpOiBDbGlwYm9hcmREYXRhID0+IHtcbiAgICBjb25zdCBodG1sID0gZGF0YT8uZ2V0RGF0YShgdGV4dC9odG1sYCk7XG4gICAgaWYgKGh0bWwpIHtcbiAgICAgICAgY29uc3QgaHRtbENsaXBib2FyZERhdGEgPSBnZXRDbGlwYm9hcmRGcm9tSFRNTFRleHQoaHRtbCk7XG4gICAgICAgIGlmIChodG1sQ2xpcGJvYXJkRGF0YSkge1xuICAgICAgICAgICAgcmV0dXJuIGh0bWxDbGlwYm9hcmREYXRhO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IHRleHREYXRhID0gZ2V0RGF0YVRyYW5zZmVyQ2xpcGJvYXJkVGV4dChkYXRhKTtcbiAgICAgICAgaWYgKHRleHREYXRhKSB7XG4gICAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgICAgIGh0bWwsXG4gICAgICAgICAgICAgICAgLi4udGV4dERhdGFcbiAgICAgICAgICAgIH07XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICByZXR1cm4geyBodG1sIH07XG4gICAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgICBjb25zdCB0ZXh0RGF0YSA9IGdldERhdGFUcmFuc2ZlckNsaXBib2FyZFRleHQoZGF0YSk7XG4gICAgICAgIHJldHVybiB0ZXh0RGF0YTtcbiAgICB9XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0RGF0YVRyYW5zZmVyQ2xpcGJvYXJkVGV4dCA9IChkYXRhOiBQaWNrPERhdGFUcmFuc2ZlciwgJ2dldERhdGEnIHwgJ3NldERhdGEnPiB8IG51bGwpOiBDbGlwYm9hcmREYXRhID0+IHtcbiAgICBpZiAoIWRhdGEpIHtcbiAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxuICAgIGNvbnN0IHRleHQgPSBkYXRhPy5nZXREYXRhKGB0ZXh0L3BsYWluYCk7XG4gICAgaWYgKHRleHQpIHtcbiAgICAgICAgY29uc3QgaHRtbENsaXBib2FyZERhdGEgPSBnZXRDbGlwYm9hcmRGcm9tSFRNTFRleHQodGV4dCk7XG4gICAgICAgIGlmIChodG1sQ2xpcGJvYXJkRGF0YSkge1xuICAgICAgICAgICAgcmV0dXJuIGh0bWxDbGlwYm9hcmREYXRhO1xuICAgICAgICB9XG4gICAgfVxuICAgIHJldHVybiB7IHRleHQgfTtcbn07XG4iXX0=
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
export * from './clipboard';
|
|
2
|
-
export * from './data-transfer';
|
|
3
|
-
export * from './navigator-clipboard';
|
|
4
|
-
export * from './common';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvdXRpbHMvY2xpcGJvYXJkL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLFVBQVUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2xpcGJvYXJkJztcbmV4cG9ydCAqIGZyb20gJy4vZGF0YS10cmFuc2Zlcic7XG5leHBvcnQgKiBmcm9tICcuL25hdmlnYXRvci1jbGlwYm9hcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tb24nO1xuIl19
|