import React from 'react'; import CodeBlock from './CodeBlock'; import Text from './Text'; import { ParserPropTypes } from './types'; const denotesCodeBlock = (line: string): boolean => { return line.match(/^\s*```.*$/) !== null; } const denotesDottedList = (line: string): boolean => { return line.match(/^ ?[-*] .*$/) !== null; } const denotesOpenHtml= (line: string): string => { const regex = /<([^/\s]*)[^<]*[^/]>/g; const match = regex.exec(line); return match ? match[1] : ''; } const denotesClosingHtml= (line: string, tag: string): boolean => { const regex = new RegExp(``); return line.match(regex) !== null; } const denotesSelfClosingHtml = (line: string): string[] | null => { const regex = /(<[^/\s]*[^<]*\/>)/g; return line.match(regex); } const declaresNoLineBreak = (line: string): boolean => { return line.match(/\\\|$/) !== null; } const Content: React.FC = ({ rawLines }) => { if (!rawLines.length) return null; const line = rawLines.splice(0, 1)[0]; let buffer; if (denotesCodeBlock(line)) { const closeIndex = rawLines.findIndex(line => denotesCodeBlock(line)); const codeBlockLines = rawLines.splice(0, closeIndex + 1).slice(0, closeIndex); buffer = } else if (denotesDottedList(line)) { const closeIndex = rawLines.findIndex(line => !denotesDottedList(line)); const dottedListLines = rawLines.splice(0, closeIndex).slice(0, closeIndex); dottedListLines.unshift(line); buffer = ; } else if ((buffer = denotesOpenHtml(line))) { const tag = buffer; const closeIndex = rawLines.findIndex(line => denotesClosingHtml(line, tag)); const htmlLines = rawLines.splice(0, closeIndex + 1); htmlLines.unshift(line); buffer =
; } else if ((buffer = denotesSelfClosingHtml(line)) !== null) { const match = buffer[0]; const [before, after] = line.split(match); buffer = ( <>
); } else if (declaresNoLineBreak(line)) { const closeIndex = rawLines.findIndex(line => !declaresNoLineBreak(line)); const lineBreakLines = rawLines.splice(0, closeIndex).map(line => line.slice(0, -2)); lineBreakLines.unshift(line.slice(0, -2)); lineBreakLines.push(rawLines.splice(0, 1)[0]); buffer =

{lineBreakLines.map(lineBreakLine => )}

; } else if (denotesClosingHtml(line, '')) { buffer = null; } else { buffer =

} return ( <> { buffer } ); } export default Content;