2022-01-07 22:22:07 +01:00
|
|
|
import {MarkdownSerializer, defaultMarkdownSerializer} from "prosemirror-markdown";
|
|
|
|
import {docToHtml} from "./util";
|
|
|
|
|
|
|
|
const nodes = defaultMarkdownSerializer.nodes;
|
|
|
|
const marks = defaultMarkdownSerializer.marks;
|
|
|
|
|
2022-01-12 11:18:06 +01:00
|
|
|
|
2022-01-07 22:22:07 +01:00
|
|
|
nodes.callout = function(state, node) {
|
2022-01-10 14:38:32 +01:00
|
|
|
writeNodeAsHtml(state, node);
|
|
|
|
};
|
|
|
|
|
2022-01-12 11:18:06 +01:00
|
|
|
|
2022-01-10 14:38:32 +01:00
|
|
|
marks.underline = {
|
|
|
|
open: '<span style="text-decoration: underline;">',
|
|
|
|
close: '</span>',
|
|
|
|
};
|
|
|
|
|
2022-01-11 17:00:57 +01:00
|
|
|
marks.strike = {
|
|
|
|
open: '<span style="text-decoration: line-through;">',
|
|
|
|
close: '</span>',
|
|
|
|
};
|
|
|
|
|
|
|
|
marks.superscript = {
|
|
|
|
open: '<sup>',
|
|
|
|
close: '</sup>',
|
|
|
|
};
|
|
|
|
|
|
|
|
marks.subscript = {
|
|
|
|
open: '<sub>',
|
|
|
|
close: '</sub>',
|
|
|
|
};
|
|
|
|
|
2022-01-12 16:33:59 +01:00
|
|
|
marks.text_color = {
|
|
|
|
open(state, mark, parent, index) {
|
|
|
|
return `<span style="color: ${mark.attrs.color};">`
|
|
|
|
},
|
|
|
|
close: '</span>',
|
|
|
|
};
|
|
|
|
|
|
|
|
marks.background_color = {
|
|
|
|
open(state, mark, parent, index) {
|
|
|
|
return `<span style="background-color: ${mark.attrs.color};">`
|
|
|
|
},
|
|
|
|
close: '</span>',
|
|
|
|
};
|
|
|
|
|
2022-01-12 11:18:06 +01:00
|
|
|
|
2022-01-10 14:38:32 +01:00
|
|
|
function writeNodeAsHtml(state, node) {
|
2022-01-07 22:22:07 +01:00
|
|
|
const html = docToHtml({ content: [node] });
|
|
|
|
state.write(html);
|
2022-01-12 11:18:06 +01:00
|
|
|
state.ensureNewLine();
|
|
|
|
state.write('\n');
|
2022-01-07 22:22:07 +01:00
|
|
|
state.closeBlock();
|
2022-01-10 14:38:32 +01:00
|
|
|
}
|
|
|
|
|
2022-01-12 11:18:06 +01:00
|
|
|
// Update serializers to just write out as HTML if we have an attribute
|
|
|
|
// or element that cannot be represented in commonmark without losing
|
|
|
|
// formatting or content.
|
|
|
|
for (const [nodeType, serializerFunction] of Object.entries(nodes)) {
|
2022-01-12 16:33:59 +01:00
|
|
|
nodes[nodeType] = function(state, node, parent, index) {
|
2022-01-12 11:18:06 +01:00
|
|
|
if (node.attrs.align) {
|
|
|
|
writeNodeAsHtml(state, node);
|
|
|
|
} else {
|
2022-01-12 16:33:59 +01:00
|
|
|
serializerFunction(state, node, parent, index);
|
2022-01-12 11:18:06 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-01-07 22:22:07 +01:00
|
|
|
|
|
|
|
const serializer = new MarkdownSerializer(nodes, marks);
|
|
|
|
|
|
|
|
export default serializer;
|