@kerebron/extension-basic-editor 0.1.1 → 0.1.3
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/esm/editor/src/CoreEditor.d.ts.map +1 -1
- package/esm/editor/src/CoreEditor.js +5 -5
- package/esm/editor/src/nodeToTreeString.d.ts.map +1 -1
- package/esm/editor/src/nodeToTreeString.js +5 -2
- package/esm/editor/src/utilities/createNodeFromContent.d.ts.map +1 -1
- package/esm/editor/src/utilities/createNodeFromContent.js +1 -1
- package/esm/extension-basic-editor/src/ExtensionHtml.d.ts.map +1 -1
- package/esm/extension-basic-editor/src/ExtensionHtml.js +3 -2
- package/esm/extension-basic-editor/src/MarkChange.d.ts.map +1 -1
- package/esm/extension-basic-editor/src/NodeImage.d.ts +1 -19
- package/esm/extension-basic-editor/src/NodeImage.d.ts.map +1 -1
- package/esm/extension-basic-editor/src/NodeImage.js +0 -22
- package/package.json +1 -4
- package/esm/extension-automerge/src/CursorPlugin.d.ts +0 -16
- package/esm/extension-automerge/src/CursorPlugin.d.ts.map +0 -1
- package/esm/extension-automerge/src/CursorPlugin.js +0 -114
- package/esm/extension-automerge/src/ExtensionAutomerge.d.ts +0 -26
- package/esm/extension-automerge/src/ExtensionAutomerge.d.ts.map +0 -1
- package/esm/extension-automerge/src/ExtensionAutomerge.js +0 -136
- package/esm/extension-automerge/src/MarkUnknown.d.ts +0 -8
- package/esm/extension-automerge/src/MarkUnknown.d.ts.map +0 -1
- package/esm/extension-automerge/src/MarkUnknown.js +0 -26
- package/esm/extension-automerge/src/NodeUnknown.d.ts +0 -8
- package/esm/extension-automerge/src/NodeUnknown.d.ts.map +0 -1
- package/esm/extension-automerge/src/NodeUnknown.js +0 -28
- package/esm/extension-automerge/src/NodeUnknownBlock.d.ts +0 -11
- package/esm/extension-automerge/src/NodeUnknownBlock.d.ts.map +0 -1
- package/esm/extension-automerge/src/NodeUnknownBlock.js +0 -36
- package/esm/extension-automerge/src/SchemaAdapter.d.ts +0 -70
- package/esm/extension-automerge/src/SchemaAdapter.d.ts.map +0 -1
- package/esm/extension-automerge/src/SchemaAdapter.js +0 -188
- package/esm/extension-automerge/src/SyncPlugin.d.ts +0 -16
- package/esm/extension-automerge/src/SyncPlugin.d.ts.map +0 -1
- package/esm/extension-automerge/src/SyncPlugin.js +0 -147
- package/esm/extension-automerge/src/amToPm.d.ts +0 -9
- package/esm/extension-automerge/src/amToPm.d.ts.map +0 -1
- package/esm/extension-automerge/src/amToPm.js +0 -245
- package/esm/extension-automerge/src/amTraversal.d.ts +0 -62
- package/esm/extension-automerge/src/amTraversal.d.ts.map +0 -1
- package/esm/extension-automerge/src/amTraversal.js +0 -688
- package/esm/extension-automerge/src/loader.d.ts +0 -8
- package/esm/extension-automerge/src/loader.d.ts.map +0 -1
- package/esm/extension-automerge/src/loader.js +0 -54
- package/esm/extension-automerge/src/maintainSpans.d.ts +0 -9
- package/esm/extension-automerge/src/maintainSpans.d.ts.map +0 -1
- package/esm/extension-automerge/src/maintainSpans.js +0 -464
- package/esm/extension-automerge/src/pmToAm.d.ts +0 -6
- package/esm/extension-automerge/src/pmToAm.d.ts.map +0 -1
- package/esm/extension-automerge/src/pmToAm.js +0 -183
- package/esm/extension-automerge/src/pmTraversal.d.ts +0 -26
- package/esm/extension-automerge/src/pmTraversal.d.ts.map +0 -1
- package/esm/extension-automerge/src/pmTraversal.js +0 -102
- package/esm/extension-automerge/src/types.d.ts +0 -42
- package/esm/extension-automerge/src/types.d.ts.map +0 -1
- package/esm/extension-automerge/src/types.js +0 -94
- package/esm/extension-automerge/src/utils.d.ts +0 -3
- package/esm/extension-automerge/src/utils.d.ts.map +0 -1
- package/esm/extension-automerge/src/utils.js +0 -18
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CoreEditor.d.ts","sourceRoot":"","sources":["../../../src/editor/src/CoreEditor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,
|
|
1
|
+
{"version":3,"file":"CoreEditor.d.ts","sourceRoot":"","sources":["../../../src/editor/src/CoreEditor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,IAAI,IAAI,eAAe,EAAE,KAAK,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAGzE,OAAO,KAAK,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAE7D,OAAO,EAAE,eAAe,EAAkB,MAAM,8BAA8B,CAAC;AAgC/E,qBAAa,UAAW,SAAQ,WAAW;IACzC,SAAgB,OAAO,EAAE,OAAO,CAAC,aAAa,CAAC,CAG7C;IACF,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,cAAc,CAAiB;IAChC,IAAI,EAAG,UAAU,CAAC;IAClB,KAAK,EAAG,WAAW,CAAC;gBAEf,OAAO,GAAE,OAAO,CAAC,aAAa,CAAM;IAyBhD,IAAW,MAAM,qBAEhB;IAEM,KAAK,IAAI,eAAe;IAIxB,GAAG,IAAI,eAAe;IAI7B,OAAO,CAAC,UAAU;IAaX,mBAAmB,CAAC,WAAW,EAAE,WAAW;IAcnD,OAAO,CAAC,YAAY;IAcb,WAAW,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,EAAE,MAAM;IAwC7C,WAAW,CAAC,SAAS,CAAC,EAAE,MAAM;IAkB9B,OAAO,IAAI,WAAW;IAItB,KAAK,CAAC,OAAO,GAAE,OAAO,CAAC,aAAa,CAAM,GAAG,UAAU;IAOvD,KAAK,CAAC,GAAG,CAAC,EAAE,eAAe;CAMnC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { EditorView } from 'prosemirror-view';
|
|
2
|
-
import { Node as ProseMirrorNode
|
|
2
|
+
import { Node as ProseMirrorNode } from 'prosemirror-model';
|
|
3
3
|
import { ExtensionManager } from './ExtensionManager.js';
|
|
4
4
|
import { EditorState } from 'prosemirror-state';
|
|
5
5
|
import { createNodeFromContent } from './utilities/createNodeFromContent.js';
|
|
@@ -21,12 +21,12 @@ function ensureDocSchema(doc, schema) {
|
|
|
21
21
|
};
|
|
22
22
|
// TODO fix readonly warnings
|
|
23
23
|
doc.type = findNode(doc.type.name);
|
|
24
|
-
doc.marks.forEach(mark => {
|
|
24
|
+
doc.marks.forEach((mark) => {
|
|
25
25
|
mark.type = findMark(mark.type.name);
|
|
26
26
|
});
|
|
27
|
-
doc.descendants(node => {
|
|
27
|
+
doc.descendants((node) => {
|
|
28
28
|
node.type = findNode(node.type.name);
|
|
29
|
-
node.marks.forEach(mark => {
|
|
29
|
+
node.marks.forEach((mark) => {
|
|
30
30
|
mark.type = findMark(mark.type.name);
|
|
31
31
|
});
|
|
32
32
|
});
|
|
@@ -182,7 +182,7 @@ export class CoreEditor extends EventTarget {
|
|
|
182
182
|
clone(options = {}) {
|
|
183
183
|
return new CoreEditor({
|
|
184
184
|
...options,
|
|
185
|
-
extensions: [...this.options.extensions]
|
|
185
|
+
extensions: [...this.options.extensions],
|
|
186
186
|
});
|
|
187
187
|
}
|
|
188
188
|
debug(doc) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"nodeToTreeString.d.ts","sourceRoot":"","sources":["../../../src/editor/src/nodeToTreeString.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"nodeToTreeString.d.ts","sourceRoot":"","sources":["../../../src/editor/src/nodeToTreeString.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAC;AAYzC,wBAAgB,gBAAgB,CAC9B,IAAI,EAAE,IAAI,GAAG,IAAI,EAAE,GAAG,SAAS,IAAI,EAAE,EACrC,KAAK,SAAI,EACT,UAAU,SAAI,UA0Df;AAED,wBAAgB,SAAS,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,EAAE,QAE5C"}
|
|
@@ -13,7 +13,9 @@ export function nodeToTreeString(node, level = 0, currentPos = 0) {
|
|
|
13
13
|
let output = '';
|
|
14
14
|
if (Array.isArray(node)) {
|
|
15
15
|
for (const child of node) {
|
|
16
|
-
output += delim +
|
|
16
|
+
output += delim +
|
|
17
|
+
nodeToTreeString(child, level + 1, currentPos).replace(/\s+$/gm, '') +
|
|
18
|
+
'\n';
|
|
17
19
|
}
|
|
18
20
|
return output;
|
|
19
21
|
}
|
|
@@ -44,7 +46,8 @@ export function nodeToTreeString(node, level = 0, currentPos = 0) {
|
|
|
44
46
|
output += (delim + ' "' + trimText(node.text) + '"') + '\n';
|
|
45
47
|
}
|
|
46
48
|
node.forEach((child, offset) => {
|
|
47
|
-
output +=
|
|
49
|
+
output +=
|
|
50
|
+
nodeToTreeString(child, level + 1, currentPos + offset + 1).replace(/\s+$/gm, '') + '\n'; // + (node.isLeaf ? 1 : 2)
|
|
48
51
|
});
|
|
49
52
|
return output;
|
|
50
53
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createNodeFromContent.d.ts","sourceRoot":"","sources":["../../../../src/editor/src/utilities/createNodeFromContent.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"createNodeFromContent.d.ts","sourceRoot":"","sources":["../../../../src/editor/src/utilities/createNodeFromContent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,IAAI,IAAI,eAAe,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAE9E,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,MAAM,4BAA4B,GAAG;IACzC,qBAAqB,CAAC,EAAE,OAAO,CAAC;CACjC,CAAC;AAEF,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,OAAO,GAAG,eAAe,GAAG,QAAQ,EAC7C,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,4BAA4B,GACrC,eAAe,GAAG,QAAQ,CAiC5B;AAED,wBAAgB,qBAAqB,CACnC,OAAO,EAAE,OAAO,GAAG,eAAe,GAAG,QAAQ,EAC7C,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,4BAA4B,GACrC,eAAe,GAAG,QAAQ,CAY5B"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Fragment, Node as ProseMirrorNode
|
|
1
|
+
import { Fragment, Node as ProseMirrorNode } from 'prosemirror-model';
|
|
2
2
|
export function createNodeFromObject(content, schema, options) {
|
|
3
3
|
try {
|
|
4
4
|
// if the JSON Content is an array of nodes, create a fragment for each node
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ExtensionHtml.d.ts","sourceRoot":"","sources":["../../../src/extension-basic-editor/src/ExtensionHtml.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"ExtensionHtml.d.ts","sourceRoot":"","sources":["../../../src/extension-basic-editor/src/ExtensionHtml.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,QAAQ,EACR,IAAI,EACJ,KAAK,YAAY,EACjB,MAAM,EACP,MAAM,mBAAmB,CAAC;AAE3B,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,UAAU,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAErF,MAAM,MAAM,4BAA4B,GAAG;IACzC,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,qBAAqB,CAAC,EAAE,OAAO,CAAC;CACjC,CAAC;AAEF,wBAAgB,mBAAmB,CACjC,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,MAAM,GACb,MAAM,CAWR;AAqBD,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW,CAQ5D;AA+BD,wBAAgB,kBAAkB,CAChC,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,4BAA4B,GACrC,IAAI,CAgBN;AAED,wBAAgB,sBAAsB,CACpC,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,4BAA4B,GACrC,QAAQ,CAiBV;AAED,qBAAa,aAAc,SAAQ,SAAS;IAC1C,IAAI,SAAU;IAEL,aAAa,CACpB,MAAM,EAAE,UAAU,EAClB,MAAM,EAAE,MAAM,GACb,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC;CAa7B"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { DOMParser,
|
|
1
|
+
import { DOMParser, DOMSerializer, Schema, } from 'prosemirror-model';
|
|
2
2
|
import { Extension } from '../../editor/src/mod.js';
|
|
3
3
|
export function getHTMLFromFragment(fragment, schema) {
|
|
4
4
|
const documentFragment = DOMSerializer.fromSchema(schema).serializeFragment(fragment);
|
|
@@ -76,7 +76,8 @@ export function createFragmentFromHTML(content, schema, options) {
|
|
|
76
76
|
DOMParser.fromSchema(contentCheckSchema).parseSlice(elementFromString(content), options.parseOptions);
|
|
77
77
|
}
|
|
78
78
|
const parser = DOMParser.fromSchema(schema);
|
|
79
|
-
return parser.parseSlice(elementFromString(content), options.parseOptions)
|
|
79
|
+
return parser.parseSlice(elementFromString(content), options.parseOptions)
|
|
80
|
+
.content;
|
|
80
81
|
}
|
|
81
82
|
export class ExtensionHtml extends Extension {
|
|
82
83
|
constructor() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MarkChange.d.ts","sourceRoot":"","sources":["../../../src/extension-basic-editor/src/MarkChange.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAE/C,qBAAa,UAAW,SAAQ,IAAI;IACzB,IAAI,SAAY;IACzB,QAAQ,WAAW;IAEnB,WAAW,IAAI,QAAQ;
|
|
1
|
+
{"version":3,"file":"MarkChange.d.ts","sourceRoot":"","sources":["../../../src/extension-basic-editor/src/MarkChange.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAE/C,qBAAa,UAAW,SAAQ,IAAI;IACzB,IAAI,SAAY;IACzB,QAAQ,WAAW;IAEnB,WAAW,IAAI,QAAQ;CAQxB"}
|
|
@@ -1,26 +1,8 @@
|
|
|
1
|
-
import { type
|
|
1
|
+
import { type NodeSpec } from 'prosemirror-model';
|
|
2
2
|
import { Node } from '../../editor/src/mod.js';
|
|
3
|
-
import { next as automerge } from '@automerge/automerge/slim';
|
|
4
|
-
import { BlockMarker } from '../../extension-automerge/src/ExtensionAutomerge.js';
|
|
5
3
|
export declare class NodeImage extends Node {
|
|
6
4
|
name: string;
|
|
7
5
|
requires: string[];
|
|
8
|
-
automerge: {
|
|
9
|
-
block: string;
|
|
10
|
-
isEmbed: boolean;
|
|
11
|
-
attrParsers: {
|
|
12
|
-
fromAutomerge: (block: BlockMarker) => {
|
|
13
|
-
src: any;
|
|
14
|
-
alt: any;
|
|
15
|
-
title: any;
|
|
16
|
-
};
|
|
17
|
-
fromProsemirror: (node: PmNode) => {
|
|
18
|
-
src: automerge.RawString;
|
|
19
|
-
alt: any;
|
|
20
|
-
title: any;
|
|
21
|
-
};
|
|
22
|
-
};
|
|
23
|
-
};
|
|
24
6
|
getNodeSpec(): NodeSpec;
|
|
25
7
|
}
|
|
26
8
|
//# sourceMappingURL=NodeImage.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NodeImage.d.ts","sourceRoot":"","sources":["../../../src/extension-basic-editor/src/NodeImage.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"NodeImage.d.ts","sourceRoot":"","sources":["../../../src/extension-basic-editor/src/NodeImage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAuB,KAAK,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AACvE,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAE/C,qBAAa,SAAU,SAAQ,IAAI;IACxB,IAAI,SAAW;IACxB,QAAQ,WAAW;IAEV,WAAW,IAAI,QAAQ;CA4BjC"}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { Node } from '../../editor/src/mod.js';
|
|
2
|
-
import { next as automerge } from '@automerge/automerge/slim';
|
|
3
2
|
export class NodeImage extends Node {
|
|
4
3
|
constructor() {
|
|
5
4
|
super(...arguments);
|
|
@@ -15,27 +14,6 @@ export class NodeImage extends Node {
|
|
|
15
14
|
writable: true,
|
|
16
15
|
value: ['doc']
|
|
17
16
|
});
|
|
18
|
-
Object.defineProperty(this, "automerge", {
|
|
19
|
-
enumerable: true,
|
|
20
|
-
configurable: true,
|
|
21
|
-
writable: true,
|
|
22
|
-
value: {
|
|
23
|
-
block: 'image',
|
|
24
|
-
isEmbed: true,
|
|
25
|
-
attrParsers: {
|
|
26
|
-
fromAutomerge: (block) => ({
|
|
27
|
-
src: block.attrs.src?.toString() || null,
|
|
28
|
-
alt: block.attrs.alt,
|
|
29
|
-
title: block.attrs.title,
|
|
30
|
-
}),
|
|
31
|
-
fromProsemirror: (node) => ({
|
|
32
|
-
src: new automerge.RawString(node.attrs.src),
|
|
33
|
-
alt: node.attrs.alt,
|
|
34
|
-
title: node.attrs.title,
|
|
35
|
-
}),
|
|
36
|
-
},
|
|
37
|
-
}
|
|
38
|
-
});
|
|
39
17
|
}
|
|
40
18
|
getNodeSpec() {
|
|
41
19
|
return {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kerebron/extension-basic-editor",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.3",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"module": "./esm/extension-basic-editor/src/ExtensionBasicEditor.js",
|
|
6
6
|
"exports": {
|
|
@@ -73,9 +73,6 @@
|
|
|
73
73
|
},
|
|
74
74
|
"scripts": {},
|
|
75
75
|
"dependencies": {
|
|
76
|
-
"@automerge/automerge": "2.2.4",
|
|
77
|
-
"@automerge/automerge-repo": "1.1.9",
|
|
78
|
-
"prosemirror-changeset": "2.2.1",
|
|
79
76
|
"prosemirror-dropcursor": "1.8.1",
|
|
80
77
|
"prosemirror-gapcursor": "1.3.2",
|
|
81
78
|
"prosemirror-history": "1.4.1",
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { Plugin, PluginKey } from 'prosemirror-state';
|
|
2
|
-
import { DecorationSet } from 'prosemirror-view';
|
|
3
|
-
import { DocHandleChangePayload } from './types.js';
|
|
4
|
-
export declare const cursorPluginKey: PluginKey<any>;
|
|
5
|
-
export declare const createDecorations: (state: any, createCursor: any, createSelection: any) => DecorationSet;
|
|
6
|
-
export declare const defaultSelectionBuilder: (user: any) => {
|
|
7
|
-
style: string;
|
|
8
|
-
class: string;
|
|
9
|
-
};
|
|
10
|
-
export declare const defaultCursorBuilder: (user: any) => any;
|
|
11
|
-
export declare class CursorPlugin extends Plugin {
|
|
12
|
-
ignoreTr: boolean;
|
|
13
|
-
onAutoMergeChange: (args: DocHandleChangePayload<unknown>) => void;
|
|
14
|
-
constructor();
|
|
15
|
-
}
|
|
16
|
-
//# sourceMappingURL=CursorPlugin.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CursorPlugin.d.ts","sourceRoot":"","sources":["../../../src/extension-automerge/src/CursorPlugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,SAAS,EAAa,MAAM,mBAAmB,CAAC;AACjE,OAAO,EAAc,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAE7D,OAAO,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AAEpD,eAAO,MAAM,eAAe,gBAAoC,CAAC;AAIjE,eAAO,MAAM,iBAAiB,wEAmB7B,CAAC;AAEF,eAAO,MAAM,uBAAuB;;;CAMnC,CAAC;AAEF,eAAO,MAAM,oBAAoB,oBAahC,CAAC;AAKF,qBAAa,YAAa,SAAQ,MAAM;IACtC,QAAQ,UAAS;IACjB,iBAAiB,EAAG,CAAC,IAAI,EAAE,sBAAsB,CAAC,OAAO,CAAC,KAAK,IAAI,CAAC;;CAkErE"}
|
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
import { Plugin, PluginKey } from 'prosemirror-state';
|
|
2
|
-
import { Decoration, DecorationSet } from 'prosemirror-view'; // eslint-disable-line
|
|
3
|
-
export const cursorPluginKey = new PluginKey('automerge-cursor');
|
|
4
|
-
const getSelection = (state) => state.selection;
|
|
5
|
-
export const createDecorations = (state,
|
|
6
|
-
// awareness,
|
|
7
|
-
// awarenessFilter,
|
|
8
|
-
createCursor, createSelection) => {
|
|
9
|
-
const decorations = [];
|
|
10
|
-
const user = { color: '#FF00' };
|
|
11
|
-
decorations.push(Decoration.inline(1, 2, createSelection(user), {
|
|
12
|
-
inclusiveEnd: true,
|
|
13
|
-
inclusiveStart: false,
|
|
14
|
-
}));
|
|
15
|
-
return DecorationSet.create(state.doc, decorations);
|
|
16
|
-
};
|
|
17
|
-
export const defaultSelectionBuilder = (user) => {
|
|
18
|
-
return {
|
|
19
|
-
style: `background-color: ${user.color}70`,
|
|
20
|
-
// assets: `border-left: 1px solid ${user.color}70`,
|
|
21
|
-
class: 'ProseMirror-yjs-selection',
|
|
22
|
-
};
|
|
23
|
-
};
|
|
24
|
-
export const defaultCursorBuilder = (user) => {
|
|
25
|
-
const cursor = document.createElement('span');
|
|
26
|
-
cursor.classList.add('ProseMirror-yjs-cursor');
|
|
27
|
-
cursor.setAttribute('style', `border-color: ${user.color}`);
|
|
28
|
-
const userDiv = document.createElement('div');
|
|
29
|
-
userDiv.setAttribute('style', `background-color: ${user.color}`);
|
|
30
|
-
userDiv.insertBefore(document.createTextNode(user.name), null);
|
|
31
|
-
const nonbreakingSpace1 = document.createTextNode('\u2060');
|
|
32
|
-
const nonbreakingSpace2 = document.createTextNode('\u2060');
|
|
33
|
-
cursor.insertBefore(nonbreakingSpace1, null);
|
|
34
|
-
cursor.insertBefore(userDiv, null);
|
|
35
|
-
cursor.insertBefore(nonbreakingSpace2, null);
|
|
36
|
-
return cursor;
|
|
37
|
-
};
|
|
38
|
-
const cursorBuilder = defaultCursorBuilder;
|
|
39
|
-
const selectionBuilder = defaultSelectionBuilder;
|
|
40
|
-
export class CursorPlugin extends Plugin {
|
|
41
|
-
constructor() {
|
|
42
|
-
super({
|
|
43
|
-
key: cursorPluginKey,
|
|
44
|
-
state: {
|
|
45
|
-
init(_, state) {
|
|
46
|
-
return createDecorations(state,
|
|
47
|
-
// awareness,
|
|
48
|
-
// awarenessStateFilter,
|
|
49
|
-
cursorBuilder, selectionBuilder);
|
|
50
|
-
},
|
|
51
|
-
apply(tr, prevState, _oldState, newState) {
|
|
52
|
-
// const ystate = ySyncPluginKey.getState(newState)
|
|
53
|
-
// const yCursorState = tr.getMeta(yCursorPluginKey)
|
|
54
|
-
// if (
|
|
55
|
-
// (ystate && ystate.isChangeOrigin) ||
|
|
56
|
-
// (yCursorState && yCursorState.awarenessUpdated)
|
|
57
|
-
// ) {
|
|
58
|
-
// return createDecorations(
|
|
59
|
-
// newState,
|
|
60
|
-
// awareness,
|
|
61
|
-
// awarenessStateFilter,
|
|
62
|
-
// cursorBuilder,
|
|
63
|
-
// selectionBuilder
|
|
64
|
-
// )
|
|
65
|
-
// }
|
|
66
|
-
return prevState.map(tr.mapping, tr.doc);
|
|
67
|
-
},
|
|
68
|
-
},
|
|
69
|
-
props: {
|
|
70
|
-
decorations: (state) => {
|
|
71
|
-
return cursorPluginKey.getState(state);
|
|
72
|
-
},
|
|
73
|
-
},
|
|
74
|
-
view: (view) => {
|
|
75
|
-
// const awarenessListener = () => {
|
|
76
|
-
// if (view.docView) {
|
|
77
|
-
// setMeta(view, yCursorPluginKey, { awarenessUpdated: true })
|
|
78
|
-
// }
|
|
79
|
-
// }
|
|
80
|
-
const updateCursorInfo = () => {
|
|
81
|
-
// @note We make implicit checks when checking for the cursor property
|
|
82
|
-
// const current = awareness.getLocalState() || {}
|
|
83
|
-
if (view.hasFocus()) {
|
|
84
|
-
const selection = getSelection(view.state);
|
|
85
|
-
}
|
|
86
|
-
};
|
|
87
|
-
// awareness.on('change', awarenessListener)
|
|
88
|
-
view.dom.addEventListener('focusin', updateCursorInfo);
|
|
89
|
-
view.dom.addEventListener('focusout', updateCursorInfo);
|
|
90
|
-
return {
|
|
91
|
-
update: updateCursorInfo,
|
|
92
|
-
destroy: () => {
|
|
93
|
-
view.dom.removeEventListener('focusin', updateCursorInfo);
|
|
94
|
-
view.dom.removeEventListener('focusout', updateCursorInfo);
|
|
95
|
-
// awareness.off('change', awarenessListener)
|
|
96
|
-
// awareness.setLocalStateField(cursorStateField, null)
|
|
97
|
-
},
|
|
98
|
-
};
|
|
99
|
-
},
|
|
100
|
-
});
|
|
101
|
-
Object.defineProperty(this, "ignoreTr", {
|
|
102
|
-
enumerable: true,
|
|
103
|
-
configurable: true,
|
|
104
|
-
writable: true,
|
|
105
|
-
value: false
|
|
106
|
-
});
|
|
107
|
-
Object.defineProperty(this, "onAutoMergeChange", {
|
|
108
|
-
enumerable: true,
|
|
109
|
-
configurable: true,
|
|
110
|
-
writable: true,
|
|
111
|
-
value: void 0
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { Schema, type SchemaSpec } from 'prosemirror-model';
|
|
2
|
-
import { DocHandle, Repo } from '@automerge/automerge-repo';
|
|
3
|
-
import { CoreEditor, Extension } from '../../editor/src/mod.js';
|
|
4
|
-
import { NodeUnknown } from './NodeUnknown.js';
|
|
5
|
-
import { MarkUnknown } from './MarkUnknown.js';
|
|
6
|
-
import { NodeUnknownBlock } from './NodeUnknownBlock.js';
|
|
7
|
-
import { SchemaAdapter } from './SchemaAdapter.js';
|
|
8
|
-
import { SyncPlugin } from './SyncPlugin.js';
|
|
9
|
-
export declare class ExtensionAutomerge extends Extension {
|
|
10
|
-
name: string;
|
|
11
|
-
requires: (NodeUnknown | MarkUnknown | NodeUnknownBlock)[];
|
|
12
|
-
schemaSpec: {};
|
|
13
|
-
repo: Repo;
|
|
14
|
-
editor: CoreEditor;
|
|
15
|
-
schemaAdapter: SchemaAdapter;
|
|
16
|
-
syncPlugin: SyncPlugin<{
|
|
17
|
-
text: string;
|
|
18
|
-
}>;
|
|
19
|
-
constructor(config: any);
|
|
20
|
-
setupSpec(actualSpec: SchemaSpec): void;
|
|
21
|
-
loadFromAutoMerge(docUrl: any): void;
|
|
22
|
-
setupDebug<T>(handle: DocHandle<T>): void;
|
|
23
|
-
notifyNewUrl(url: string): void;
|
|
24
|
-
getProseMirrorPlugins(editor: CoreEditor, schema: Schema): Plugin[];
|
|
25
|
-
}
|
|
26
|
-
//# sourceMappingURL=ExtensionAutomerge.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ExtensionAutomerge.d.ts","sourceRoot":"","sources":["../../../src/extension-automerge/src/ExtensionAutomerge.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,KAAK,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAG5D,OAAO,EACL,SAAS,EAET,IAAI,EACL,MAAM,2BAA2B,CAAC;AAEnC,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAChE,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,OAAO,EAAwB,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACzE,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAM7C,qBAAa,kBAAmB,SAAQ,SAAS;IAC/C,IAAI,SAAe;IAEnB,QAAQ,mDAAkE;IAE1E,UAAU,KAAM;IAChB,IAAI,EAAE,IAAI,CAAC;IACX,MAAM,EAAE,UAAU,CAAC;IACnB,aAAa,EAAE,aAAa,CAAC;IAC7B,UAAU,EAAE,UAAU,CAAC;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;gBAE7B,MAAM,KAAA;IAUT,SAAS,CAAC,UAAU,EAAE,UAAU;IAKzC,iBAAiB,CAAC,MAAM,KAAA;IAWxB,UAAU,CAAC,CAAC,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;IAmBlC,YAAY,CAAC,GAAG,EAAE,MAAM;IAUf,qBAAqB,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE;CAyC7E"}
|
|
@@ -1,136 +0,0 @@
|
|
|
1
|
-
import { next as automerge } from '@automerge/automerge/slim';
|
|
2
|
-
import { isValidAutomergeUrl, Repo, } from '@automerge/automerge-repo';
|
|
3
|
-
import { Extension } from '../../editor/src/mod.js';
|
|
4
|
-
import { NodeUnknown } from './NodeUnknown.js';
|
|
5
|
-
import { MarkUnknown } from './MarkUnknown.js';
|
|
6
|
-
import { NodeUnknownBlock } from './NodeUnknownBlock.js';
|
|
7
|
-
import { addAmgNodeStateAttrs, SchemaAdapter } from './SchemaAdapter.js';
|
|
8
|
-
import { SyncPlugin } from './SyncPlugin.js';
|
|
9
|
-
import { CursorPlugin } from './CursorPlugin.js';
|
|
10
|
-
import { pmDocToAmHandle } from './loader.js';
|
|
11
|
-
const pathToTextField = ['text'];
|
|
12
|
-
export class ExtensionAutomerge extends Extension {
|
|
13
|
-
constructor(config) {
|
|
14
|
-
super(config);
|
|
15
|
-
Object.defineProperty(this, "name", {
|
|
16
|
-
enumerable: true,
|
|
17
|
-
configurable: true,
|
|
18
|
-
writable: true,
|
|
19
|
-
value: 'automerge'
|
|
20
|
-
});
|
|
21
|
-
Object.defineProperty(this, "requires", {
|
|
22
|
-
enumerable: true,
|
|
23
|
-
configurable: true,
|
|
24
|
-
writable: true,
|
|
25
|
-
value: [new NodeUnknown(), new MarkUnknown(), new NodeUnknownBlock()]
|
|
26
|
-
});
|
|
27
|
-
Object.defineProperty(this, "schemaSpec", {
|
|
28
|
-
enumerable: true,
|
|
29
|
-
configurable: true,
|
|
30
|
-
writable: true,
|
|
31
|
-
value: {}
|
|
32
|
-
});
|
|
33
|
-
Object.defineProperty(this, "repo", {
|
|
34
|
-
enumerable: true,
|
|
35
|
-
configurable: true,
|
|
36
|
-
writable: true,
|
|
37
|
-
value: void 0
|
|
38
|
-
});
|
|
39
|
-
Object.defineProperty(this, "editor", {
|
|
40
|
-
enumerable: true,
|
|
41
|
-
configurable: true,
|
|
42
|
-
writable: true,
|
|
43
|
-
value: void 0
|
|
44
|
-
});
|
|
45
|
-
Object.defineProperty(this, "schemaAdapter", {
|
|
46
|
-
enumerable: true,
|
|
47
|
-
configurable: true,
|
|
48
|
-
writable: true,
|
|
49
|
-
value: void 0
|
|
50
|
-
});
|
|
51
|
-
Object.defineProperty(this, "syncPlugin", {
|
|
52
|
-
enumerable: true,
|
|
53
|
-
configurable: true,
|
|
54
|
-
writable: true,
|
|
55
|
-
value: void 0
|
|
56
|
-
});
|
|
57
|
-
this.repo = new Repo({
|
|
58
|
-
storage: this.config.storage,
|
|
59
|
-
// storage: new IndexedDBStorageAdapter("automerge"),
|
|
60
|
-
network: [this.config.networkAdapter],
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
setupSpec(actualSpec) {
|
|
64
|
-
addAmgNodeStateAttrs(actualSpec.nodes);
|
|
65
|
-
this.schemaSpec = actualSpec;
|
|
66
|
-
}
|
|
67
|
-
loadFromAutoMerge(docUrl) {
|
|
68
|
-
let handle;
|
|
69
|
-
if (docUrl && isValidAutomergeUrl(docUrl)) {
|
|
70
|
-
handle = this.repo.find(docUrl);
|
|
71
|
-
this.syncPlugin.changeHandle(handle);
|
|
72
|
-
//pmDocToAmHandle(this.schemaAdapter, handle, pmDoc);
|
|
73
|
-
this.setupDebug(handle, this.editor);
|
|
74
|
-
this.notifyNewUrl(handle.url);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
setupDebug(handle) {
|
|
78
|
-
handle.on('change', (event) => {
|
|
79
|
-
if (!handle.isReady()) {
|
|
80
|
-
return;
|
|
81
|
-
}
|
|
82
|
-
const doc = handle.docSync();
|
|
83
|
-
if (doc) {
|
|
84
|
-
const event = new CustomEvent('automerge:change', {
|
|
85
|
-
detail: {
|
|
86
|
-
editor: this.editor,
|
|
87
|
-
getSpans: () => automerge.spans(doc, pathToTextField),
|
|
88
|
-
getMarks: () => automerge.marks(doc, pathToTextField),
|
|
89
|
-
},
|
|
90
|
-
});
|
|
91
|
-
this.editor.dispatchEvent(event);
|
|
92
|
-
}
|
|
93
|
-
});
|
|
94
|
-
}
|
|
95
|
-
notifyNewUrl(url) {
|
|
96
|
-
const event = new CustomEvent('automerge:url', {
|
|
97
|
-
detail: {
|
|
98
|
-
editor: this.editor,
|
|
99
|
-
url,
|
|
100
|
-
},
|
|
101
|
-
});
|
|
102
|
-
this.editor.dispatchEvent(event);
|
|
103
|
-
}
|
|
104
|
-
getProseMirrorPlugins(editor, schema) {
|
|
105
|
-
this.editor = editor;
|
|
106
|
-
const schemaAdapter = new SchemaAdapter(schema);
|
|
107
|
-
this.schemaAdapter = schemaAdapter;
|
|
108
|
-
let handle;
|
|
109
|
-
handle = this.repo.create({ text: '' });
|
|
110
|
-
const syncPlugin = new SyncPlugin(schemaAdapter, pathToTextField, handle);
|
|
111
|
-
this.syncPlugin = syncPlugin;
|
|
112
|
-
editor.addEventListener('doc:loaded', (event) => {
|
|
113
|
-
const pmDoc = event.detail.doc;
|
|
114
|
-
// const handle = this.repo.create({ text: '' });
|
|
115
|
-
handle.whenReady()
|
|
116
|
-
.then(() => {
|
|
117
|
-
syncPlugin.changeHandle(handle);
|
|
118
|
-
pmDocToAmHandle(schemaAdapter, handle, pmDoc);
|
|
119
|
-
this.setupDebug(handle);
|
|
120
|
-
});
|
|
121
|
-
});
|
|
122
|
-
handle.whenReady()
|
|
123
|
-
.then(() => {
|
|
124
|
-
this.notifyNewUrl(handle.url);
|
|
125
|
-
const doc = handle.docSync();
|
|
126
|
-
if (!doc) {
|
|
127
|
-
throw new Error('cannot initialize ProseMirror document when handle is not ready');
|
|
128
|
-
}
|
|
129
|
-
this.setupDebug(handle);
|
|
130
|
-
});
|
|
131
|
-
return [
|
|
132
|
-
syncPlugin,
|
|
133
|
-
new CursorPlugin(),
|
|
134
|
-
];
|
|
135
|
-
}
|
|
136
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MarkUnknown.d.ts","sourceRoot":"","sources":["../../../src/extension-automerge/src/MarkUnknown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAE/C,qBAAa,WAAY,SAAQ,IAAI;IAC1B,IAAI,SAAiB;IAC9B,QAAQ,WAAW;IAEnB,WAAW,IAAI,QAAQ;CAQxB"}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { Mark } from '../../editor/src/mod.js';
|
|
2
|
-
export class MarkUnknown extends Mark {
|
|
3
|
-
constructor() {
|
|
4
|
-
super(...arguments);
|
|
5
|
-
Object.defineProperty(this, "name", {
|
|
6
|
-
enumerable: true,
|
|
7
|
-
configurable: true,
|
|
8
|
-
writable: true,
|
|
9
|
-
value: 'unknownMark'
|
|
10
|
-
});
|
|
11
|
-
Object.defineProperty(this, "requires", {
|
|
12
|
-
enumerable: true,
|
|
13
|
-
configurable: true,
|
|
14
|
-
writable: true,
|
|
15
|
-
value: ['doc']
|
|
16
|
-
});
|
|
17
|
-
}
|
|
18
|
-
getMarkSpec() {
|
|
19
|
-
return {
|
|
20
|
-
attrs: { unknownMarks: { default: null } },
|
|
21
|
-
toDOM() {
|
|
22
|
-
return ['span', { 'data-unknown-mark': true }];
|
|
23
|
-
},
|
|
24
|
-
};
|
|
25
|
-
}
|
|
26
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"NodeUnknown.d.ts","sourceRoot":"","sources":["../../../src/extension-automerge/src/NodeUnknown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAE/C,qBAAa,WAAY,SAAQ,IAAI;IAC1B,IAAI,SAAiB;IAC9B,QAAQ,WAAW;IAEV,WAAW,IAAI,QAAQ;CAUjC"}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import { Node } from '../../editor/src/mod.js';
|
|
2
|
-
export class NodeUnknown extends Node {
|
|
3
|
-
constructor() {
|
|
4
|
-
super(...arguments);
|
|
5
|
-
Object.defineProperty(this, "name", {
|
|
6
|
-
enumerable: true,
|
|
7
|
-
configurable: true,
|
|
8
|
-
writable: true,
|
|
9
|
-
value: 'unknownLeaf'
|
|
10
|
-
});
|
|
11
|
-
Object.defineProperty(this, "requires", {
|
|
12
|
-
enumerable: true,
|
|
13
|
-
configurable: true,
|
|
14
|
-
writable: true,
|
|
15
|
-
value: ['doc']
|
|
16
|
-
});
|
|
17
|
-
}
|
|
18
|
-
getNodeSpec() {
|
|
19
|
-
return {
|
|
20
|
-
inline: true,
|
|
21
|
-
attrs: { isAmgBlock: { default: true }, unknownBlock: { default: null } },
|
|
22
|
-
group: 'inline',
|
|
23
|
-
toDOM() {
|
|
24
|
-
return document.createTextNode('u{fffc}');
|
|
25
|
-
},
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { NodeSpec } from 'prosemirror-model';
|
|
2
|
-
import { Node } from '../../editor/src/mod.js';
|
|
3
|
-
export declare class NodeUnknownBlock extends Node {
|
|
4
|
-
name: string;
|
|
5
|
-
requires: string[];
|
|
6
|
-
automerge: {
|
|
7
|
-
unknownBlock: boolean;
|
|
8
|
-
};
|
|
9
|
-
getNodeSpec(): NodeSpec;
|
|
10
|
-
}
|
|
11
|
-
//# sourceMappingURL=NodeUnknownBlock.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"NodeUnknownBlock.d.ts","sourceRoot":"","sources":["../../../src/extension-automerge/src/NodeUnknownBlock.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAE/C,qBAAa,gBAAiB,SAAQ,IAAI;IAC/B,IAAI,SAAkB;IAC/B,QAAQ,WAAW;IAEnB,SAAS;;MAEP;IAEO,WAAW,IAAI,QAAQ;CAUjC"}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { Node } from '../../editor/src/mod.js';
|
|
2
|
-
export class NodeUnknownBlock extends Node {
|
|
3
|
-
constructor() {
|
|
4
|
-
super(...arguments);
|
|
5
|
-
Object.defineProperty(this, "name", {
|
|
6
|
-
enumerable: true,
|
|
7
|
-
configurable: true,
|
|
8
|
-
writable: true,
|
|
9
|
-
value: 'unknownBlock'
|
|
10
|
-
});
|
|
11
|
-
Object.defineProperty(this, "requires", {
|
|
12
|
-
enumerable: true,
|
|
13
|
-
configurable: true,
|
|
14
|
-
writable: true,
|
|
15
|
-
value: ['doc']
|
|
16
|
-
});
|
|
17
|
-
Object.defineProperty(this, "automerge", {
|
|
18
|
-
enumerable: true,
|
|
19
|
-
configurable: true,
|
|
20
|
-
writable: true,
|
|
21
|
-
value: {
|
|
22
|
-
unknownBlock: true,
|
|
23
|
-
}
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
getNodeSpec() {
|
|
27
|
-
return {
|
|
28
|
-
group: 'block',
|
|
29
|
-
content: 'block+',
|
|
30
|
-
parseDOM: [{ tag: 'div', attrs: { 'data-unknown-block': 'true' } }],
|
|
31
|
-
toDOM() {
|
|
32
|
-
return ['div', { 'data-unknown-block': 'true' }, 0];
|
|
33
|
-
},
|
|
34
|
-
};
|
|
35
|
-
}
|
|
36
|
-
}
|