From dd4e14690d0b239616482b0c39618824bddc2ea0 Mon Sep 17 00:00:00 2001 From: Sidharth Vinod Date: Tue, 13 Jun 2023 11:26:25 +0530 Subject: [PATCH] Add types --- .../rendering-util/handle-markdown-text.ts | 30 +++++++------------ 1 file changed, 10 insertions(+), 20 deletions(-) diff --git a/packages/mermaid/src/rendering-util/handle-markdown-text.ts b/packages/mermaid/src/rendering-util/handle-markdown-text.ts index 5102429d3..04dbe5b76 100644 --- a/packages/mermaid/src/rendering-util/handle-markdown-text.ts +++ b/packages/mermaid/src/rendering-util/handle-markdown-text.ts @@ -1,11 +1,12 @@ +import type { Content } from 'mdast'; import { fromMarkdown } from 'mdast-util-from-markdown'; import { dedent } from 'ts-dedent'; /** - * @param {string} markdown markdown to process - * @returns {string} processed markdown + * @param markdown - markdown to process + * @returns processed markdown */ -function preprocessMarkdown(markdown) { +function preprocessMarkdown(markdown: string): string { // Replace multiple newlines with a single newline const withoutMultipleNewlines = markdown.replace(/\n{2,}/g, '\n'); // Remove extra spaces at the beginning of each line @@ -14,19 +15,15 @@ function preprocessMarkdown(markdown) { } /** - * @param {string} markdown markdown to split into lines + * @param markdown - markdown to split into lines */ -export function markdownToLines(markdown) { +export function markdownToLines(markdown: string) { const preprocessedMarkdown = preprocessMarkdown(markdown); const { children } = fromMarkdown(preprocessedMarkdown); - const lines = [[]]; + const lines: { content: string; type: string }[][] = [[]]; let currentLine = 0; - /** - * @param {import('mdast').Content} node - * @param {string} [parentType] - */ - function processNode(node, parentType = 'normal') { + function processNode(node: Content, parentType = 'normal') { if (node.type === 'text') { const textLines = node.value.split('\n'); textLines.forEach((textLine, index) => { @@ -58,17 +55,10 @@ export function markdownToLines(markdown) { return lines; } -/** - * @param {string} markdown markdown to convert to HTML - * @returns {string} HTML - */ -export function markdownToHTML(markdown) { +export function markdownToHTML(markdown: string) { const { children } = fromMarkdown(markdown); - /** - * @param {import('mdast').Content} node - */ - function output(node) { + function output(node: Content): string { if (node.type === 'text') { return node.value.replace(/\n/g, '
'); } else if (node.type === 'strong') {