@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.
Files changed (58) hide show
  1. package/esm/editor/src/CoreEditor.d.ts.map +1 -1
  2. package/esm/editor/src/CoreEditor.js +5 -5
  3. package/esm/editor/src/nodeToTreeString.d.ts.map +1 -1
  4. package/esm/editor/src/nodeToTreeString.js +5 -2
  5. package/esm/editor/src/utilities/createNodeFromContent.d.ts.map +1 -1
  6. package/esm/editor/src/utilities/createNodeFromContent.js +1 -1
  7. package/esm/extension-basic-editor/src/ExtensionHtml.d.ts.map +1 -1
  8. package/esm/extension-basic-editor/src/ExtensionHtml.js +3 -2
  9. package/esm/extension-basic-editor/src/MarkChange.d.ts.map +1 -1
  10. package/esm/extension-basic-editor/src/NodeImage.d.ts +1 -19
  11. package/esm/extension-basic-editor/src/NodeImage.d.ts.map +1 -1
  12. package/esm/extension-basic-editor/src/NodeImage.js +0 -22
  13. package/package.json +1 -4
  14. package/esm/extension-automerge/src/CursorPlugin.d.ts +0 -16
  15. package/esm/extension-automerge/src/CursorPlugin.d.ts.map +0 -1
  16. package/esm/extension-automerge/src/CursorPlugin.js +0 -114
  17. package/esm/extension-automerge/src/ExtensionAutomerge.d.ts +0 -26
  18. package/esm/extension-automerge/src/ExtensionAutomerge.d.ts.map +0 -1
  19. package/esm/extension-automerge/src/ExtensionAutomerge.js +0 -136
  20. package/esm/extension-automerge/src/MarkUnknown.d.ts +0 -8
  21. package/esm/extension-automerge/src/MarkUnknown.d.ts.map +0 -1
  22. package/esm/extension-automerge/src/MarkUnknown.js +0 -26
  23. package/esm/extension-automerge/src/NodeUnknown.d.ts +0 -8
  24. package/esm/extension-automerge/src/NodeUnknown.d.ts.map +0 -1
  25. package/esm/extension-automerge/src/NodeUnknown.js +0 -28
  26. package/esm/extension-automerge/src/NodeUnknownBlock.d.ts +0 -11
  27. package/esm/extension-automerge/src/NodeUnknownBlock.d.ts.map +0 -1
  28. package/esm/extension-automerge/src/NodeUnknownBlock.js +0 -36
  29. package/esm/extension-automerge/src/SchemaAdapter.d.ts +0 -70
  30. package/esm/extension-automerge/src/SchemaAdapter.d.ts.map +0 -1
  31. package/esm/extension-automerge/src/SchemaAdapter.js +0 -188
  32. package/esm/extension-automerge/src/SyncPlugin.d.ts +0 -16
  33. package/esm/extension-automerge/src/SyncPlugin.d.ts.map +0 -1
  34. package/esm/extension-automerge/src/SyncPlugin.js +0 -147
  35. package/esm/extension-automerge/src/amToPm.d.ts +0 -9
  36. package/esm/extension-automerge/src/amToPm.d.ts.map +0 -1
  37. package/esm/extension-automerge/src/amToPm.js +0 -245
  38. package/esm/extension-automerge/src/amTraversal.d.ts +0 -62
  39. package/esm/extension-automerge/src/amTraversal.d.ts.map +0 -1
  40. package/esm/extension-automerge/src/amTraversal.js +0 -688
  41. package/esm/extension-automerge/src/loader.d.ts +0 -8
  42. package/esm/extension-automerge/src/loader.d.ts.map +0 -1
  43. package/esm/extension-automerge/src/loader.js +0 -54
  44. package/esm/extension-automerge/src/maintainSpans.d.ts +0 -9
  45. package/esm/extension-automerge/src/maintainSpans.d.ts.map +0 -1
  46. package/esm/extension-automerge/src/maintainSpans.js +0 -464
  47. package/esm/extension-automerge/src/pmToAm.d.ts +0 -6
  48. package/esm/extension-automerge/src/pmToAm.d.ts.map +0 -1
  49. package/esm/extension-automerge/src/pmToAm.js +0 -183
  50. package/esm/extension-automerge/src/pmTraversal.d.ts +0 -26
  51. package/esm/extension-automerge/src/pmTraversal.d.ts.map +0 -1
  52. package/esm/extension-automerge/src/pmTraversal.js +0 -102
  53. package/esm/extension-automerge/src/types.d.ts +0 -42
  54. package/esm/extension-automerge/src/types.d.ts.map +0 -1
  55. package/esm/extension-automerge/src/types.js +0 -94
  56. package/esm/extension-automerge/src/utils.d.ts +0 -3
  57. package/esm/extension-automerge/src/utils.d.ts.map +0 -1
  58. 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,EACL,IAAI,IAAI,eAAe,EACvB,KAAK,MAAM,EACZ,MAAM,mBAAmB,CAAC;AAG3B,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
+ {"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, } from 'prosemirror-model';
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,EAAC,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAYvC,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,EAAE,GAAG,SAAS,IAAI,EAAE,EAAE,KAAK,SAAI,EAAE,UAAU,SAAI,UAmDhG;AAED,wBAAgB,SAAS,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,EAAE,QAE5C"}
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 + nodeToTreeString(child, level + 1, currentPos).replace(/\s+$/gm, '') + '\n';
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 += nodeToTreeString(child, level + 1, currentPos + offset + 1).replace(/\s+$/gm, '') + '\n'; // + (node.isLeaf ? 1 : 2)
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,EACL,QAAQ,EACR,IAAI,IAAI,eAAe,EACvB,MAAM,EACP,MAAM,mBAAmB,CAAC;AAE3B,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
+ {"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, } from 'prosemirror-model';
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,EAEL,QAAQ,EACR,IAAI,EACJ,KAAK,YAAY,EACjB,MAAM,EAEP,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,CAgBV;AAGD,qBAAa,aAAc,SAAQ,SAAS;IAC1C,IAAI,SAAU;IAEL,aAAa,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC;CAatF"}
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, Schema, DOMSerializer, } from 'prosemirror-model';
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).content;
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;CASxB"}
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 Node as PmNode, type NodeSpec } from 'prosemirror-model';
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,EAAE,KAAK,IAAI,IAAI,MAAM,EAAE,KAAK,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AACvE,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAC/C,OAAO,EAAE,IAAI,IAAI,SAAS,EAAE,MAAM,2BAA2B,CAAC;AAE9D,OAAO,EAAE,WAAW,EAAE,MAAM,qDAAqD,CAAC;AAElF,qBAAa,SAAU,SAAQ,IAAI;IACxB,IAAI,SAAW;IACxB,QAAQ,WAAW;IAEnB,SAAS;;;;mCAIkB,WAAW;;;;;oCAKV,MAAM;;;;;;MAMhC;IAEO,WAAW,IAAI,QAAQ;CA4BjC"}
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.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,8 +0,0 @@
1
- import { MarkSpec } from 'prosemirror-model';
2
- import { Mark } from '../../editor/src/mod.js';
3
- export declare class MarkUnknown extends Mark {
4
- name: string;
5
- requires: string[];
6
- getMarkSpec(): MarkSpec;
7
- }
8
- //# sourceMappingURL=MarkUnknown.d.ts.map
@@ -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,8 +0,0 @@
1
- import { NodeSpec } from 'prosemirror-model';
2
- import { Node } from '../../editor/src/mod.js';
3
- export declare class NodeUnknown extends Node {
4
- name: string;
5
- requires: string[];
6
- getNodeSpec(): NodeSpec;
7
- }
8
- //# sourceMappingURL=NodeUnknown.d.ts.map
@@ -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
- }