@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.
- package/esm/editor/src/CoreEditor.d.ts +11 -5
- package/esm/editor/src/CoreEditor.d.ts.map +1 -1
- package/esm/editor/src/CoreEditor.js +62 -61
- package/esm/editor/src/DummyEditorView.d.ts +60 -0
- package/esm/editor/src/DummyEditorView.d.ts.map +1 -0
- package/esm/editor/src/DummyEditorView.js +277 -0
- package/esm/editor/src/Extension.d.ts +9 -9
- package/esm/editor/src/Extension.d.ts.map +1 -1
- package/esm/editor/src/Extension.js +2 -2
- package/esm/editor/src/ExtensionManager.d.ts +8 -7
- package/esm/editor/src/ExtensionManager.d.ts.map +1 -1
- package/esm/editor/src/ExtensionManager.js +58 -39
- package/esm/editor/src/Mark.d.ts +8 -6
- package/esm/editor/src/Mark.d.ts.map +1 -1
- package/esm/editor/src/Mark.js +8 -2
- package/esm/editor/src/Node.d.ts +14 -12
- package/esm/editor/src/Node.d.ts.map +1 -1
- package/esm/editor/src/Node.js +10 -4
- package/esm/editor/src/commands/CommandManager.d.ts +5 -9
- package/esm/editor/src/commands/CommandManager.d.ts.map +1 -1
- package/esm/editor/src/commands/CommandManager.js +7 -6
- package/esm/editor/src/commands/mod.d.ts +12 -6
- package/esm/editor/src/commands/mod.d.ts.map +1 -1
- package/esm/editor/src/commands/mod.js +0 -45
- package/esm/editor/src/mod.d.ts +1 -0
- package/esm/editor/src/mod.d.ts.map +1 -1
- package/esm/editor/src/mod.js +1 -0
- package/esm/editor/src/nodeToTreeString.d.ts.map +1 -1
- package/esm/editor/src/nodeToTreeString.js +23 -21
- package/esm/editor/src/plugins/input-rules/InputRulesPlugin.js +2 -2
- package/esm/editor/src/plugins/keymap/keymap.d.ts +11 -0
- package/esm/editor/src/plugins/keymap/keymap.d.ts.map +1 -0
- package/esm/editor/src/plugins/keymap/keymap.js +125 -0
- package/esm/editor/src/plugins/keymap/w3c-keyname.d.ts +4 -0
- package/esm/editor/src/plugins/keymap/w3c-keyname.d.ts.map +1 -0
- package/esm/editor/src/plugins/keymap/w3c-keyname.js +124 -0
- package/esm/editor/src/types.d.ts +10 -5
- package/esm/editor/src/types.d.ts.map +1 -1
- package/esm/editor/src/utilities/createNodeFromContent.d.ts +4 -3
- package/esm/editor/src/utilities/createNodeFromContent.d.ts.map +1 -1
- package/esm/editor/src/utilities/createNodeFromContent.js +4 -5
- package/esm/editor/src/utilities/getHtmlAttributes.d.ts +8 -3
- package/esm/editor/src/utilities/getHtmlAttributes.d.ts.map +1 -1
- package/esm/extension-odt/src/ExtensionOdt.d.ts +1 -1
- package/esm/extension-odt/src/ExtensionOdt.d.ts.map +1 -1
- package/esm/extension-odt/src/ExtensionOdt.js +3 -3
- package/package.json +2 -3
|
@@ -1,23 +1,29 @@
|
|
|
1
1
|
import { EditorView } from 'prosemirror-view';
|
|
2
|
-
import { Node as ProseMirrorNode,
|
|
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 {
|
|
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
|
-
|
|
20
|
-
|
|
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,
|
|
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
|
|
10
|
-
|
|
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:
|
|
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.
|
|
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.
|
|
75
|
+
return this.commandManager.createChain();
|
|
92
76
|
}
|
|
93
77
|
can() {
|
|
94
|
-
return this.commandManager.
|
|
78
|
+
return this.commandManager.createCan();
|
|
95
79
|
}
|
|
96
80
|
createView(content) {
|
|
97
|
-
const doc =
|
|
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
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
let doc;
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
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
|
-
|
|
149
|
-
|
|
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
|
-
|
|
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
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
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
|
-
|
|
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 {
|
|
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:
|
|
12
|
-
toDoc(content:
|
|
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
|
-
|
|
18
|
+
constructor(config?: Partial<ExtensionConfig>);
|
|
19
19
|
getInputRules(): InputRule[];
|
|
20
20
|
getProseMirrorPlugins(editor: CoreEditor, schema: Schema): Plugin[];
|
|
21
|
-
|
|
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;
|
|
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
|
-
|
|
22
|
+
getCommandFactories(editor) {
|
|
23
23
|
return {};
|
|
24
24
|
}
|
|
25
|
-
getKeyboardShortcuts() {
|
|
25
|
+
getKeyboardShortcuts(editor) {
|
|
26
26
|
return {};
|
|
27
27
|
}
|
|
28
28
|
getConverters(editor, schema) {
|