diff --git a/src/core/markdown/MarkdownParser.ts b/src/core/markdown/MarkdownParser.ts index 2654f2a1..34924925 100644 --- a/src/core/markdown/MarkdownParser.ts +++ b/src/core/markdown/MarkdownParser.ts @@ -186,13 +186,18 @@ export class MarkdownParser implements Parser { if (tokenSpec.noCloseToken) { this.openNode(schemaSpec, attrs); - let {content} = yfmToken; - if (tokenSpec.prepareContent) { - content = tokenSpec.prepareContent(content); + + if (tokenSpec.contentField === 'children' && yfmToken.children?.length) { + this.parseTokens(yfmToken.children); + } else { + let {content} = yfmToken; + if (tokenSpec.prepareContent) { + content = tokenSpec.prepareContent(content); + } + this.addText(content); } - this.addText(content); - this.closeNode(); + this.closeNode(); return; } diff --git a/src/core/types/parser.ts b/src/core/types/parser.ts index b2b24cff..3292d8c4 100644 --- a/src/core/types/parser.ts +++ b/src/core/types/parser.ts @@ -23,4 +23,9 @@ export interface ParserToken { code?: boolean; /** only for tokens with type=block */ prepareContent?: (content: string) => string; + /** + * only for tokens with type=block and noCloseToken=true + * @default 'content' + */ + contentField?: 'content' | 'children'; }