import React, { useState } from 'react'; import axios from 'axios'; import ContentSection from '../ContentSection/ContentSection'; interface PropTypes { data?: string; url?: string; } interface RawLinesPropType { rawLines: string[]; level?: number; } const header = (level: number): string => { return `^#{${level}} .*$`; } const CodeBlock: React.FC<{ rawLines: String[]}> = ({ rawLines }) => { return (

{rawLines.map(line => <> {line}
)}

); } const Content: React.FC = ({ rawLines }) => { if (!rawLines.length) return <>; const line = rawLines[0]; const otherLines = rawLines.slice(1); if (line.slice(0, 3) === '```') { const closeIndex = otherLines.findIndex(line => line.slice(0, 3) === '```'); console.log({ line, otherLines, closeIndex }); return ( <> ) } return ( <>

{line}

) } const Level: React.FC = ({ rawLines, level = 0 }) => { const name = rawLines[0].slice(level); const contentSize = rawLines.findIndex(line => line.match(header(level + 1))); const rawContent = (contentSize > 0) ? rawLines.slice(1, contentSize) : rawLines.slice(1); const rawChildren = rawLines.slice(contentSize); const childrenLineGroups = rawChildren.reduce((acc: string[][], cur: string) => { if (cur.match(header(level + 1))) acc.push([]); if (acc.length) acc[acc.length - 1].push(cur); return acc; }, []); const children = childrenLineGroups.map(lineGroup => ) return level ? ( {children} ) : ( <> {children} ); } const Markdown: React.FC = ({ data, url }) => { const [markdown, setMarkdown] = useState(data || ''); if (url) axios.get(url).then(response => setMarkdown(response.data)); return }; export default Markdown;