aboutsummaryrefslogtreecommitdiff
path: root/src/lib/Markdown/Markdown.tsx
diff options
context:
space:
mode:
authorEug-VS <eug-vs@keemail.me>2020-04-04 20:43:00 +0300
committerEug-VS <eug-vs@keemail.me>2020-04-04 20:43:00 +0300
commit464b5fbef2f58cbcd134b7200c5f7c2f904202a0 (patch)
treeba93249a16b4a71a527ee031311afad3575a8ca1 /src/lib/Markdown/Markdown.tsx
parentfd0497b855ae03f8f1dfb65edca67ee53431712f (diff)
downloadreact-benzin-464b5fbef2f58cbcd134b7200c5f7c2f904202a0.tar.gz
feat: parse CodeBlocks
Diffstat (limited to 'src/lib/Markdown/Markdown.tsx')
-rw-r--r--src/lib/Markdown/Markdown.tsx30
1 files changed, 28 insertions, 2 deletions
diff --git a/src/lib/Markdown/Markdown.tsx b/src/lib/Markdown/Markdown.tsx
index 332d08c..8d93437 100644
--- a/src/lib/Markdown/Markdown.tsx
+++ b/src/lib/Markdown/Markdown.tsx
@@ -18,9 +18,35 @@ const header = (level: number): string => {
return `^#{${level}} .*$`;
}
+const CodeBlock: React.FC<{ rawLines: String[]}> = ({ rawLines }) => {
+ return (
+ <p style={{background: '#444444'}}>
+ {rawLines.map(line => <> {line} <br/> </>)}
+ </p>
+ );
+}
+
+
const Content: React.FC<RawLinesPropType> = ({ rawLines }) => {
- const plainText = rawLines.map(line => <p> {line} </p>);
- return <p> {plainText} </p>;
+ 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 (
+ <>
+ <CodeBlock rawLines={otherLines.slice(0, closeIndex)} />
+ <Content rawLines={otherLines.slice(closeIndex + 1)} />
+ </>
+ )
+ }
+ return (
+ <>
+ <p> {line} </p>
+ <Content rawLines={rawLines.slice(1)} />
+ </>
+ )
}
const Level: React.FC<RawLinesPropType> = ({ rawLines, level = 0 }) => {