File size: 1,018 Bytes
f56a29b | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 | import { EditorState } from 'prosemirror-state';
import { type DirectEditorProps, EditorView } from 'prosemirror-view';
import { Schema, DOMParser } from 'prosemirror-model';
import { buildPlugins, type PluginOptions } from './plugins/index';
import { schemaNodes, schemaMarks } from './schema/index';
const schema = new Schema({
nodes: schemaNodes,
marks: schemaMarks,
});
export const createDocument = (content: string) => {
const htmlString = `<div>${content}</div>`;
const parser = new window.DOMParser();
const element = parser.parseFromString(htmlString, 'text/html').body.firstElementChild;
return DOMParser.fromSchema(schema).parse(element as Element);
};
export const initProsemirrorEditor = (
dom: Element,
content: string,
props: Omit<DirectEditorProps, 'state'>,
pluginOptions?: PluginOptions,
) => {
return new EditorView(dom, {
state: EditorState.create({
doc: createDocument(content),
plugins: buildPlugins(schema, pluginOptions),
}),
...props,
});
};
|