fix: add missing markdown converter for code block and divider

This commit is contained in:
Lucas.Xu 2022-12-06 17:24:10 +08:00
parent 64ee3140a3
commit 29952bc7fd
4 changed files with 19 additions and 1 deletions

View File

@ -80,6 +80,8 @@ class DocumentMarkdownDecoder extends Converter<String, Document> {
BuiltInAttributeKey.subtype: BuiltInAttributeKey.quote,
},
);
} else if (RegExp(r'^-*').stringMatch(text) == text) {
return Node(type: 'divider');
}
if (text.isNotEmpty) {

View File

@ -1,6 +1,7 @@
import 'dart:convert';
import 'package:appflowy_editor/src/core/document/document.dart';
import 'package:appflowy_editor/src/plugins/markdown/encoder/parser/divider_node_parser.dart';
import 'package:appflowy_editor/src/plugins/markdown/encoder/parser/image_node_parser.dart';
import 'package:appflowy_editor/src/plugins/markdown/encoder/parser/node_parser.dart';
import 'package:appflowy_editor/src/plugins/markdown/encoder/parser/text_node_parser.dart';
@ -10,6 +11,7 @@ class DocumentMarkdownEncoder extends Converter<Document, String> {
this.parsers = const [
TextNodeParser(),
ImageNodeParser(),
DividerNodeParser(),
],
});

View File

@ -0,0 +1,14 @@
import 'package:appflowy_editor/src/core/document/node.dart';
import 'package:appflowy_editor/src/plugins/markdown/encoder/parser/node_parser.dart';
class DividerNodeParser extends NodeParser {
const DividerNodeParser();
@override
String get id => 'divider';
@override
String transform(Node node) {
return '---\n';
}
}

View File

@ -40,7 +40,7 @@ class TextNodeParser extends NodeParser {
}
} else if (subtype == 'quote') {
result = '> $markdown';
} else if (subtype == 'code-block') {
} else if (subtype == 'code_block') {
result = '```\n$markdown\n```';
} else if (subtype == 'bulleted-list') {
result = '* $markdown';