@kerebron/extension-odt 0.2.0 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/esm/editor/src/CoreEditor.d.ts +11 -5
  2. package/esm/editor/src/CoreEditor.d.ts.map +1 -1
  3. package/esm/editor/src/CoreEditor.js +62 -61
  4. package/esm/editor/src/DummyEditorView.d.ts +60 -0
  5. package/esm/editor/src/DummyEditorView.d.ts.map +1 -0
  6. package/esm/editor/src/DummyEditorView.js +277 -0
  7. package/esm/editor/src/Extension.d.ts +9 -9
  8. package/esm/editor/src/Extension.d.ts.map +1 -1
  9. package/esm/editor/src/Extension.js +2 -2
  10. package/esm/editor/src/ExtensionManager.d.ts +8 -7
  11. package/esm/editor/src/ExtensionManager.d.ts.map +1 -1
  12. package/esm/editor/src/ExtensionManager.js +58 -39
  13. package/esm/editor/src/Mark.d.ts +8 -6
  14. package/esm/editor/src/Mark.d.ts.map +1 -1
  15. package/esm/editor/src/Mark.js +8 -2
  16. package/esm/editor/src/Node.d.ts +14 -12
  17. package/esm/editor/src/Node.d.ts.map +1 -1
  18. package/esm/editor/src/Node.js +10 -4
  19. package/esm/editor/src/commands/CommandManager.d.ts +5 -9
  20. package/esm/editor/src/commands/CommandManager.d.ts.map +1 -1
  21. package/esm/editor/src/commands/CommandManager.js +7 -6
  22. package/esm/editor/src/commands/mod.d.ts +12 -6
  23. package/esm/editor/src/commands/mod.d.ts.map +1 -1
  24. package/esm/editor/src/commands/mod.js +0 -45
  25. package/esm/editor/src/mod.d.ts +1 -0
  26. package/esm/editor/src/mod.d.ts.map +1 -1
  27. package/esm/editor/src/mod.js +1 -0
  28. package/esm/editor/src/nodeToTreeString.d.ts.map +1 -1
  29. package/esm/editor/src/nodeToTreeString.js +23 -21
  30. package/esm/editor/src/plugins/input-rules/InputRulesPlugin.js +2 -2
  31. package/esm/editor/src/plugins/keymap/keymap.d.ts +11 -0
  32. package/esm/editor/src/plugins/keymap/keymap.d.ts.map +1 -0
  33. package/esm/editor/src/plugins/keymap/keymap.js +125 -0
  34. package/esm/editor/src/plugins/keymap/w3c-keyname.d.ts +4 -0
  35. package/esm/editor/src/plugins/keymap/w3c-keyname.d.ts.map +1 -0
  36. package/esm/editor/src/plugins/keymap/w3c-keyname.js +124 -0
  37. package/esm/editor/src/types.d.ts +10 -5
  38. package/esm/editor/src/types.d.ts.map +1 -1
  39. package/esm/editor/src/utilities/createNodeFromContent.d.ts +4 -3
  40. package/esm/editor/src/utilities/createNodeFromContent.d.ts.map +1 -1
  41. package/esm/editor/src/utilities/createNodeFromContent.js +4 -5
  42. package/esm/editor/src/utilities/getHtmlAttributes.d.ts +8 -3
  43. package/esm/editor/src/utilities/getHtmlAttributes.d.ts.map +1 -1
  44. package/esm/extension-odt/src/ExtensionOdt.d.ts +1 -1
  45. package/esm/extension-odt/src/ExtensionOdt.d.ts.map +1 -1
  46. package/esm/extension-odt/src/ExtensionOdt.js +3 -3
  47. package/package.json +2 -3
@@ -1,23 +1,29 @@
1
1
  import { EditorView } from 'prosemirror-view';
2
- import { Node as ProseMirrorNode, type Schema } from 'prosemirror-model';
2
+ import { Node as ProseMirrorNode, Schema } from 'prosemirror-model';
3
3
  import type { EditorOptions, JSONContent } from './types.js';
4
4
  import { EditorState, Transaction } from 'prosemirror-state';
5
- import { ChainedCommands } from './commands/CommandManager.js';
5
+ import { DummyEditorView } from './DummyEditorView.js';
6
+ import { ChainedCommands } from './commands/mod.js';
7
+ import { Extension } from './Extension.js';
6
8
  export declare class CoreEditor extends EventTarget {
7
9
  readonly options: Partial<EditorOptions>;
8
10
  private extensionManager;
9
11
  private commandManager;
10
- view: EditorView;
12
+ view: EditorView | DummyEditorView;
11
13
  state: EditorState;
12
14
  constructor(options?: Partial<EditorOptions>);
15
+ getExtension<T extends Extension>(name: string): T | undefined;
13
16
  get schema(): Schema<any, any>;
14
17
  chain(): ChainedCommands;
15
18
  can(): ChainedCommands;
16
19
  private createView;
17
20
  dispatchTransaction(transaction: Transaction): void;
18
21
  private setupPlugins;
19
- setDocument(content?: any, mediaType?: string): void;
20
- getDocument(mediaType?: string): void | ProseMirrorNode | JSONContent;
22
+ clearDocument(): void;
23
+ setDocument(content: any): void;
24
+ getDocument(): ProseMirrorNode;
25
+ loadDocument(mediaType: string, content: Uint8Array): Promise<void>;
26
+ saveDocument(mediaType: string): Promise<Uint8Array>;
21
27
  getJSON(): JSONContent;
22
28
  clone(options?: Partial<EditorOptions>): CoreEditor;
23
29
  debug(doc?: ProseMirrorNode): void;
@@ -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,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;IAgBX,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,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAGpE,OAAO,KAAK,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAG7D,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAEpD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAc3C,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,GAAG,eAAe,CAAC;IACpC,KAAK,EAAG,WAAW,CAAC;gBAEf,OAAO,GAAE,OAAO,CAAC,aAAa,CAAM;IA4BhD,YAAY,CAAC,CAAC,SAAS,SAAS,EAAE,IAAI,EAAE,MAAM,GAAG,CAAC,GAAG,SAAS;IAI9D,IAAW,MAAM,qBAEhB;IAEM,KAAK,IAAI,eAAe;IAIxB,GAAG,IAAI,eAAe;IAI7B,OAAO,CAAC,UAAU;IAqBX,mBAAmB,CAAC,WAAW,EAAE,WAAW;IAcnD,OAAO,CAAC,YAAY;IAcb,aAAa;IASb,WAAW,CAAC,OAAO,EAAE,GAAG;IAuBxB,WAAW;IAIL,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,UAAU;IA0BnD,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IAY1D,OAAO,IAAI,WAAW;IAItB,KAAK,CAAC,OAAO,GAAE,OAAO,CAAC,aAAa,CAAM,GAAG,UAAU;IAOvD,KAAK,CAAC,GAAG,CAAC,EAAE,eAAe;CAMnC"}
@@ -2,35 +2,16 @@ import { EditorView } from 'prosemirror-view';
2
2
  import { Node as ProseMirrorNode } from 'prosemirror-model';
3
3
  import { ExtensionManager } from './ExtensionManager.js';
4
4
  import { EditorState } from 'prosemirror-state';
5
- import { createNodeFromContent } from './utilities/createNodeFromContent.js';
6
5
  import { CommandManager } from './commands/CommandManager.js';
7
6
  import { nodeToTreeString } from './nodeToTreeString.js';
7
+ import { DummyEditorView } from './DummyEditorView.js';
8
+ import { createNodeFromObject } from './utilities/createNodeFromContent.js';
8
9
  function ensureDocSchema(doc, schema) {
9
- if (doc.type.schema != schema) {
10
- const findNode = (nodeName) => {
11
- if (!schema.nodes[nodeName]) {
12
- throw new Error(`Not able to rewrite schema for node '${nodeName}'`);
13
- }
14
- return schema.nodes[nodeName];
15
- };
16
- const findMark = (markName) => {
17
- if (!schema.marks[markName]) {
18
- throw new Error(`Not able to rewrite schema for mark '${markName}'`);
19
- }
20
- return schema.marks[markName];
21
- };
22
- // TODO fix readonly warnings
23
- doc.type = findNode(doc.type.name);
24
- doc.marks.forEach((mark) => {
25
- mark.type = findMark(mark.type.name);
26
- });
27
- doc.descendants((node) => {
28
- node.type = findNode(node.type.name);
29
- node.marks.forEach((mark) => {
30
- mark.type = findMark(mark.type.name);
31
- });
32
- });
10
+ if (doc.type.schema === schema) {
11
+ return doc;
33
12
  }
13
+ const json = doc.toJSON();
14
+ return ProseMirrorNode.fromJSON(schema, json);
34
15
  }
35
16
  export class CoreEditor extends EventTarget {
36
17
  constructor(options = {}) {
@@ -40,7 +21,7 @@ export class CoreEditor extends EventTarget {
40
21
  configurable: true,
41
22
  writable: true,
42
23
  value: {
43
- element: null, // document.createElement('div'),
24
+ element: undefined,
44
25
  extensions: [],
45
26
  }
46
27
  });
@@ -72,7 +53,7 @@ export class CoreEditor extends EventTarget {
72
53
  ...this.options,
73
54
  ...options,
74
55
  };
75
- this.extensionManager = new ExtensionManager(this.options.extensions, this);
56
+ this.extensionManager = new ExtensionManager(this.options.extensions || [], this);
76
57
  // const content = this.options.content ? this.options.content : {
77
58
  // type: this.extensionManager.schema.topNodeType.name,
78
59
  // content: this.extensionManager.schema.topNodeType.spec.EMPTY_DOC,
@@ -81,20 +62,23 @@ export class CoreEditor extends EventTarget {
81
62
  ? this.options.content
82
63
  : this.extensionManager.schema.topNodeType.spec.EMPTY_DOC;
83
64
  this.createView(content);
84
- this.commandManager = new CommandManager(this, this.extensionManager.commandConstructors);
65
+ this.commandManager = new CommandManager(this, this.extensionManager.commandFactories);
85
66
  this.setupPlugins();
86
67
  }
68
+ getExtension(name) {
69
+ return this.extensionManager.getExtension(name);
70
+ }
87
71
  get schema() {
88
72
  return this.extensionManager.schema;
89
73
  }
90
74
  chain() {
91
- return this.commandManager.chain();
75
+ return this.commandManager.createChain();
92
76
  }
93
77
  can() {
94
- return this.commandManager.can();
78
+ return this.commandManager.createCan();
95
79
  }
96
80
  createView(content) {
97
- const doc = createNodeFromContent(content, this.schema);
81
+ const doc = createNodeFromObject(content, this.schema);
98
82
  this.state = EditorState.create({ doc });
99
83
  if (this.options.element) {
100
84
  this.view = new EditorView(this.options.element, {
@@ -105,6 +89,12 @@ export class CoreEditor extends EventTarget {
105
89
  dispatchTransaction: (tx) => this.dispatchTransaction(tx),
106
90
  });
107
91
  }
92
+ else {
93
+ this.view = new DummyEditorView({
94
+ state: this.state,
95
+ dispatchTransaction: (tx) => this.dispatchTransaction(tx),
96
+ });
97
+ }
108
98
  }
109
99
  dispatchTransaction(transaction) {
110
100
  this.state = this.state.apply(transaction);
@@ -130,25 +120,41 @@ export class CoreEditor extends EventTarget {
130
120
  });
131
121
  }
132
122
  }
133
- setDocument(content, mediaType) {
134
- if (!content) {
135
- content = {
136
- type: this.extensionManager.schema.topNodeType.name,
137
- content: this.extensionManager.schema.topNodeType.spec.EMPTY_DOC.content,
138
- };
139
- mediaType = undefined;
140
- }
141
- let doc;
142
- if (mediaType) {
143
- const converter = this.extensionManager.converters[mediaType];
144
- if (converter) {
145
- doc = converter.toDoc(content);
146
- }
123
+ clearDocument() {
124
+ const content = {
125
+ type: this.extensionManager.schema.topNodeType.name,
126
+ content: this.extensionManager.schema.topNodeType.spec.EMPTY_DOC.content,
127
+ };
128
+ this.setDocument(content);
129
+ }
130
+ setDocument(content) {
131
+ let doc = createNodeFromObject(content, this.schema);
132
+ doc = ensureDocSchema(doc, this.schema);
133
+ this.state = EditorState.create({
134
+ doc,
135
+ plugins: this.state.plugins,
136
+ storedMarks: this.state.storedMarks,
137
+ });
138
+ if (this.view) {
139
+ this.view.updateState(this.state);
147
140
  }
148
- else {
149
- doc = createNodeFromContent(content, this.schema);
141
+ const event = new CustomEvent('doc:loaded', {
142
+ detail: {
143
+ editor: this,
144
+ doc,
145
+ },
146
+ });
147
+ this.dispatchEvent(event);
148
+ }
149
+ getDocument() {
150
+ return this.state.doc;
151
+ }
152
+ async loadDocument(mediaType, content) {
153
+ const converter = this.extensionManager.converters[mediaType];
154
+ if (!converter) {
155
+ throw new Error('Converter not found for: ' + mediaType);
150
156
  }
151
- ensureDocSchema(doc, this.schema);
157
+ const doc = await converter.toDoc(content);
152
158
  this.state = EditorState.create({
153
159
  doc,
154
160
  plugins: this.state.plugins,
@@ -165,19 +171,14 @@ export class CoreEditor extends EventTarget {
165
171
  });
166
172
  this.dispatchEvent(event);
167
173
  }
168
- getDocument(mediaType) {
169
- if (mediaType) {
170
- const converter = this.extensionManager.converters[mediaType];
171
- if (converter) {
172
- const json = this.state.doc.toJSON();
173
- const clonedDoc = ProseMirrorNode.fromJSON(this.state.schema, json);
174
- return converter.fromDoc(clonedDoc);
175
- }
176
- if (mediaType === 'text/json') {
177
- return this.getJSON();
178
- }
174
+ async saveDocument(mediaType) {
175
+ const converter = this.extensionManager.converters[mediaType];
176
+ if (!converter) {
177
+ throw new Error('Converter not found for: ' + mediaType);
179
178
  }
180
- return this.state.doc;
179
+ const json = this.state.doc.toJSON();
180
+ const clonedDoc = ProseMirrorNode.fromJSON(this.state.schema, json);
181
+ return await converter.fromDoc(clonedDoc);
181
182
  }
182
183
  getJSON() {
183
184
  return this.state.doc.toJSON();
@@ -185,7 +186,7 @@ export class CoreEditor extends EventTarget {
185
186
  clone(options = {}) {
186
187
  return new CoreEditor({
187
188
  ...options,
188
- extensions: [...this.options.extensions],
189
+ extensions: [...(this.options.extensions || [])],
189
190
  });
190
191
  }
191
192
  debug(doc) {
@@ -0,0 +1,60 @@
1
+ import { EditorState, Plugin, Transaction } from 'prosemirror-state';
2
+ import { Mark, Node } from 'prosemirror-model';
3
+ import { EditorView, MarkView, NodeView } from 'prosemirror-view';
4
+ import { Decoration, DecorationSource } from 'prosemirror-view';
5
+ export declare class DummyEditorView {
6
+ private _props;
7
+ private directPlugins;
8
+ private nodeViews;
9
+ private prevDirectPlugins;
10
+ private pluginViews;
11
+ state: EditorState;
12
+ constructor(props: DirectEditorProps);
13
+ editable: boolean;
14
+ get composing(): boolean;
15
+ get dom(): {
16
+ addEventListener(): void;
17
+ removeEventListener(): void;
18
+ };
19
+ get props(): DirectEditorProps;
20
+ update(props: DirectEditorProps): void;
21
+ setProps(props: Partial<DirectEditorProps>): void;
22
+ updateState(state: EditorState): void;
23
+ private updateStateInner;
24
+ scrollToSelection(): void;
25
+ private destroyPluginViews;
26
+ private updatePluginViews;
27
+ someProp<PropName extends keyof EditorProps, Result>(propName: PropName, f: (value: NonNullable<EditorProps[PropName]>) => Result): Result | undefined;
28
+ someProp<PropName extends keyof EditorProps>(propName: PropName): NonNullable<EditorProps[PropName]> | undefined;
29
+ hasFocus(): boolean;
30
+ focus(): void;
31
+ destroy(): void;
32
+ get isDestroyed(): boolean;
33
+ dispatchEvent(event: Event): void;
34
+ dispatch: (tr: Transaction) => void;
35
+ }
36
+ export type NodeViewConstructor = (node: Node, view: EditorView, getPos: () => number | undefined, decorations: readonly Decoration[], innerDecorations: DecorationSource) => NodeView;
37
+ export type MarkViewConstructor = (mark: Mark, view: EditorView, inline: boolean) => MarkView;
38
+ export interface DOMEventMap extends HTMLElementEventMap {
39
+ [event: string]: any;
40
+ }
41
+ export interface EditorProps<P = any> {
42
+ nodeViews?: {
43
+ [node: string]: NodeViewConstructor;
44
+ };
45
+ markViews?: {
46
+ [mark: string]: MarkViewConstructor;
47
+ };
48
+ editable?: (this: P, state: EditorState) => boolean;
49
+ attributes?: {
50
+ [name: string]: string;
51
+ } | ((state: EditorState) => {
52
+ [name: string]: string;
53
+ });
54
+ }
55
+ export interface DirectEditorProps extends EditorProps {
56
+ state: EditorState;
57
+ plugins?: readonly Plugin[];
58
+ dispatchTransaction?: (tr: Transaction) => void;
59
+ }
60
+ //# sourceMappingURL=DummyEditorView.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DummyEditorView.d.ts","sourceRoot":"","sources":["../../../src/editor/src/DummyEditorView.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,277 @@
1
+ // Headless View to be used on Server-side
2
+ // TODO: remove all unnecessary props and methods
3
+ /// An editor view manages the DOM structure that represents an
4
+ /// editable document. Its state and behavior are determined by its
5
+ /// [props](#view.DirectEditorProps).
6
+ export class DummyEditorView {
7
+ /// Create a view. `place` may be a DOM node that the editor should
8
+ /// be appended to, a function that will place it into the document,
9
+ /// or an object whose `mount` property holds the node to use as the
10
+ /// document container. If it is `null`, the editor will not be
11
+ /// added to the document.
12
+ constructor(props) {
13
+ /// @internal
14
+ Object.defineProperty(this, "_props", {
15
+ enumerable: true,
16
+ configurable: true,
17
+ writable: true,
18
+ value: void 0
19
+ });
20
+ Object.defineProperty(this, "directPlugins", {
21
+ enumerable: true,
22
+ configurable: true,
23
+ writable: true,
24
+ value: void 0
25
+ });
26
+ /// @internal
27
+ Object.defineProperty(this, "nodeViews", {
28
+ enumerable: true,
29
+ configurable: true,
30
+ writable: true,
31
+ value: void 0
32
+ });
33
+ Object.defineProperty(this, "prevDirectPlugins", {
34
+ enumerable: true,
35
+ configurable: true,
36
+ writable: true,
37
+ value: []
38
+ });
39
+ Object.defineProperty(this, "pluginViews", {
40
+ enumerable: true,
41
+ configurable: true,
42
+ writable: true,
43
+ value: []
44
+ });
45
+ /// The view's current [state](#state.EditorState).
46
+ Object.defineProperty(this, "state", {
47
+ enumerable: true,
48
+ configurable: true,
49
+ writable: true,
50
+ value: void 0
51
+ });
52
+ /// Indicates whether the editor is currently [editable](#view.EditorProps.editable).
53
+ Object.defineProperty(this, "editable", {
54
+ enumerable: true,
55
+ configurable: true,
56
+ writable: true,
57
+ value: void 0
58
+ });
59
+ this._props = props;
60
+ this.state = props.state;
61
+ this.directPlugins = props.plugins || [];
62
+ this.directPlugins.forEach(checkStateComponent);
63
+ this.dispatch = this.dispatch.bind(this);
64
+ this.editable = getEditable(this);
65
+ this.nodeViews = buildNodeViews(this);
66
+ // TODO initInput(this)
67
+ this.updatePluginViews();
68
+ }
69
+ /// Holds `true` when a
70
+ /// [composition](https://w3c.github.io/uievents/#events-compositionevents)
71
+ /// is active.
72
+ get composing() {
73
+ return false;
74
+ }
75
+ get dom() {
76
+ return {
77
+ addEventListener() { },
78
+ removeEventListener() { },
79
+ };
80
+ }
81
+ /// The view's current [props](#view.EditorProps).
82
+ get props() {
83
+ if (this._props.state != this.state) {
84
+ let prev = this._props;
85
+ this._props = {};
86
+ for (let name in prev)
87
+ this._props[name] = prev[name];
88
+ this._props.state = this.state;
89
+ }
90
+ return this._props;
91
+ }
92
+ /// Update the view's props. Will immediately cause an update to
93
+ /// the DOM.
94
+ update(props) {
95
+ let prevProps = this._props;
96
+ this._props = props;
97
+ if (props.plugins) {
98
+ props.plugins.forEach(checkStateComponent);
99
+ this.directPlugins = props.plugins;
100
+ }
101
+ this.updateStateInner(props.state, prevProps);
102
+ }
103
+ /// Update the view by updating existing props object with the object
104
+ /// given as argument. Equivalent to `view.update(Object.assign({},
105
+ /// view.props, props))`.
106
+ setProps(props) {
107
+ let updated = {};
108
+ for (let name in this._props) {
109
+ updated[name] = this._props[name];
110
+ }
111
+ updated.state = this.state;
112
+ for (let name in props)
113
+ updated[name] = props[name];
114
+ this.update(updated);
115
+ }
116
+ /// Update the editor's `state` prop, without touching any of the
117
+ /// other props.
118
+ updateState(state) {
119
+ this.updateStateInner(state, this._props);
120
+ }
121
+ updateStateInner(state, prevProps) {
122
+ let prev = this.state, redraw = false, updateSel = false;
123
+ // When stored marks are added, stop composition, so that they can
124
+ // be displayed.
125
+ if (state.storedMarks && this.composing) {
126
+ // TODO clearComposition(this)
127
+ updateSel = true;
128
+ }
129
+ this.state = state;
130
+ let pluginsChanged = prev.plugins != state.plugins ||
131
+ this._props.plugins != prevProps.plugins;
132
+ if (pluginsChanged || this._props.plugins != prevProps.plugins ||
133
+ this._props.nodeViews != prevProps.nodeViews) {
134
+ let nodeViews = buildNodeViews(this);
135
+ if (changedNodeViews(nodeViews, this.nodeViews)) {
136
+ this.nodeViews = nodeViews;
137
+ redraw = true;
138
+ }
139
+ }
140
+ this.editable = getEditable(this);
141
+ let updateDoc = redraw;
142
+ if (updateDoc || !state.selection.eq(prev.selection))
143
+ updateSel = true;
144
+ if (updateSel) {
145
+ // Work around an issue in Chrome, IE, and Edge where changing
146
+ // the DOM around an active selection puts it into a broken
147
+ // state where the thing the user sees differs from the
148
+ // selection reported by the Selection object (#710, #973,
149
+ // #1011, #1013, #1035).
150
+ let forceSelUpdate = false;
151
+ if (updateDoc) {
152
+ // If the node that the selection points into is written to,
153
+ // Chrome sometimes starts misreporting the selection, so this
154
+ // tracks that and forces a selection reset when our update
155
+ // did write to the node.
156
+ // TODO if (this.composing) this.input.compositionNode = findCompositionNode(this)
157
+ }
158
+ }
159
+ this.updatePluginViews(prev);
160
+ }
161
+ /// @internal
162
+ scrollToSelection() {
163
+ }
164
+ destroyPluginViews() {
165
+ let view;
166
+ while (view = this.pluginViews.pop())
167
+ if (view.destroy)
168
+ view.destroy();
169
+ }
170
+ updatePluginViews(prevState) {
171
+ if (!prevState || prevState.plugins != this.state.plugins ||
172
+ this.directPlugins != this.prevDirectPlugins) {
173
+ this.prevDirectPlugins = this.directPlugins;
174
+ this.destroyPluginViews();
175
+ for (let i = 0; i < this.directPlugins.length; i++) {
176
+ let plugin = this.directPlugins[i];
177
+ if (plugin.spec.view) {
178
+ this.pluginViews.push(plugin.spec.view(this));
179
+ }
180
+ }
181
+ for (let i = 0; i < this.state.plugins.length; i++) {
182
+ let plugin = this.state.plugins[i];
183
+ if (plugin.spec.view) {
184
+ this.pluginViews.push(plugin.spec.view(this));
185
+ }
186
+ }
187
+ }
188
+ else {
189
+ for (let i = 0; i < this.pluginViews.length; i++) {
190
+ let pluginView = this.pluginViews[i];
191
+ if (pluginView.update)
192
+ pluginView.update(this, prevState);
193
+ }
194
+ }
195
+ }
196
+ someProp(propName, f) {
197
+ let prop = this._props && this._props[propName], value;
198
+ if (prop != null && (value = f ? f(prop) : prop)) {
199
+ return value;
200
+ }
201
+ for (let i = 0; i < this.directPlugins.length; i++) {
202
+ let prop = this.directPlugins[i].props[propName];
203
+ if (prop != null && (value = f ? f(prop) : prop)) {
204
+ return value;
205
+ }
206
+ }
207
+ let plugins = this.state.plugins;
208
+ if (plugins) {
209
+ for (let i = 0; i < plugins.length; i++) {
210
+ let prop = plugins[i].props[propName];
211
+ if (prop != null && (value = f ? f(prop) : prop))
212
+ return value;
213
+ }
214
+ }
215
+ }
216
+ /// Query whether the view has focus.
217
+ hasFocus() {
218
+ return false;
219
+ }
220
+ /// Focus the editor.
221
+ focus() {
222
+ }
223
+ /// Removes the editor from the DOM and destroys all [node
224
+ /// views](#view.NodeView).
225
+ destroy() {
226
+ this.destroyPluginViews();
227
+ }
228
+ /// This is true when the view has been
229
+ /// [destroyed](#view.DummyEditorView.destroy) (and thus should not be
230
+ /// used anymore).
231
+ get isDestroyed() {
232
+ return false;
233
+ }
234
+ /// Used for testing.
235
+ dispatchEvent(event) {
236
+ }
237
+ }
238
+ DummyEditorView.prototype.dispatch = function (tr) {
239
+ let dispatchTransaction = this.props.dispatchTransaction;
240
+ if (dispatchTransaction)
241
+ dispatchTransaction.call(this, tr);
242
+ else
243
+ this.updateState(this.state.apply(tr));
244
+ };
245
+ function getEditable(view) {
246
+ return !view.someProp('editable', (value) => value(view.state) === false);
247
+ }
248
+ function buildNodeViews(view) {
249
+ let result = Object.create(null);
250
+ function add(obj) {
251
+ for (let prop in obj) {
252
+ if (!Object.prototype.hasOwnProperty.call(result, prop)) {
253
+ result[prop] = obj[prop];
254
+ }
255
+ }
256
+ }
257
+ view.someProp('nodeViews', add);
258
+ view.someProp('markViews', add);
259
+ return result;
260
+ }
261
+ function changedNodeViews(a, b) {
262
+ let nA = 0, nB = 0;
263
+ for (let prop in a) {
264
+ if (a[prop] != b[prop])
265
+ return true;
266
+ nA++;
267
+ }
268
+ for (let _ in b)
269
+ nB++;
270
+ return nA != nB;
271
+ }
272
+ function checkStateComponent(plugin) {
273
+ if (plugin.spec.state || plugin.spec.filterTransaction ||
274
+ plugin.spec.appendTransaction) {
275
+ throw new RangeError('Plugins passed directly to the view must not have a state component');
276
+ }
277
+ }
@@ -1,25 +1,25 @@
1
- import { Plugin } from 'prosemirror-state';
1
+ import type { Plugin } from 'prosemirror-state';
2
+ import type { Node, Schema, SchemaSpec } from 'prosemirror-model';
2
3
  import { type CoreEditor } from './CoreEditor.js';
3
- import { InputRule } from './plugins/input-rules/InputRulesPlugin.js';
4
- import { Commands, CommandShortcuts } from './commands/mod.js';
5
- import { Schema, type SchemaSpec } from 'prosemirror-model';
4
+ import type { InputRule } from './plugins/input-rules/InputRulesPlugin.js';
5
+ import { CommandFactories, CommandShortcuts } from './commands/mod.js';
6
6
  export interface ExtensionConfig {
7
7
  [key: string]: any;
8
8
  requires: Array<Extension | string>;
9
9
  }
10
10
  export interface Converter {
11
- fromDoc(document: unknown): void;
12
- toDoc(content: unknown): any;
11
+ fromDoc(document: Node): Promise<Uint8Array>;
12
+ toDoc(content: Uint8Array): Promise<Node>;
13
13
  }
14
14
  export declare abstract class Extension {
15
15
  protected config: Partial<ExtensionConfig>;
16
16
  readonly type = "extension";
17
17
  abstract name: string;
18
- protected constructor(config?: Partial<ExtensionConfig>);
18
+ constructor(config?: Partial<ExtensionConfig>);
19
19
  getInputRules(): InputRule[];
20
20
  getProseMirrorPlugins(editor: CoreEditor, schema: Schema): Plugin[];
21
- getCommands(editor: CoreEditor): Partial<Commands>;
22
- getKeyboardShortcuts(): Partial<CommandShortcuts>;
21
+ getCommandFactories(editor: CoreEditor): Partial<CommandFactories>;
22
+ getKeyboardShortcuts(editor: CoreEditor): Partial<CommandShortcuts>;
23
23
  getConverters(editor: CoreEditor, schema: Schema): Record<string, Converter>;
24
24
  setupSpec(spec: SchemaSpec): void;
25
25
  }
@@ -1 +1 @@
1
- {"version":3,"file":"Extension.d.ts","sourceRoot":"","sources":["../../../src/editor/src/Extension.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAE3C,OAAO,EAAE,KAAK,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,SAAS,EAAE,MAAM,2CAA2C,CAAC;AACtE,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAC/D,OAAO,EAAE,MAAM,EAAE,KAAK,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE5D,MAAM,WAAW,eAAe;IAE9B,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;IAEnB,QAAQ,EAAE,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC,CAAC;CACrC;AAED,MAAM,WAAW,SAAS;IACxB,OAAO,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI,CAAC;IACjC,KAAK,CAAC,OAAO,EAAE,OAAO,GAAG,GAAG,CAAC;CAC9B;AAED,8BAAsB,SAAS;IAIP,SAAS,CAAC,MAAM,EAAE,OAAO,CAAC,eAAe,CAAC;IAHhE,QAAQ,CAAC,IAAI,eAAe;IAC5B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IAEtB,SAAS,aAAuB,MAAM,GAAE,OAAO,CAAC,eAAe,CAAM;IAGrE,aAAa,IAAI,SAAS,EAAE;IAI5B,qBAAqB,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE;IAInE,WAAW,CAAC,MAAM,EAAE,UAAU,GAAG,OAAO,CAAC,QAAQ,CAAC;IAIlD,oBAAoB,IAAI,OAAO,CAAC,gBAAgB,CAAC;IAIjD,aAAa,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC;IAI5E,SAAS,CAAC,IAAI,EAAE,UAAU;CAE3B"}
1
+ {"version":3,"file":"Extension.d.ts","sourceRoot":"","sources":["../../../src/editor/src/Extension.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAElE,OAAO,EAAE,KAAK,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,2CAA2C,CAAC;AAC3E,OAAO,EACL,gBAAgB,EAChB,gBAAgB,EACjB,MAAM,mBAAmB,CAAC;AAE3B,MAAM,WAAW,eAAe;IAE9B,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;IAEnB,QAAQ,EAAE,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC,CAAC;CACrC;AAED,MAAM,WAAW,SAAS;IACxB,OAAO,CAAC,QAAQ,EAAE,IAAI,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IAC7C,KAAK,CAAC,OAAO,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC3C;AAED,8BAAsB,SAAS;IAIV,SAAS,CAAC,MAAM,EAAE,OAAO,CAAC,eAAe,CAAC;IAH7D,QAAQ,CAAC,IAAI,eAAe;IAC5B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;gBAEO,MAAM,GAAE,OAAO,CAAC,eAAe,CAAM;IAGlE,aAAa,IAAI,SAAS,EAAE;IAI5B,qBAAqB,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE;IAInE,mBAAmB,CAAC,MAAM,EAAE,UAAU,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAIlE,oBAAoB,CAAC,MAAM,EAAE,UAAU,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAInE,aAAa,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC;IAI5E,SAAS,CAAC,IAAI,EAAE,UAAU;CAE3B"}
@@ -19,10 +19,10 @@ export class Extension {
19
19
  getProseMirrorPlugins(editor, schema) {
20
20
  return [];
21
21
  }
22
- getCommands(editor) {
22
+ getCommandFactories(editor) {
23
23
  return {};
24
24
  }
25
- getKeyboardShortcuts() {
25
+ getKeyboardShortcuts(editor) {
26
26
  return {};
27
27
  }
28
28
  getConverters(editor, schema) {