diff options
author | Eugene Sokolov <eug-vs@keemail.me> | 2021-01-14 19:27:47 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-01-14 19:27:47 +0200 |
commit | e1d1bb966cca5e1541d5703505cfa83e6ae12ec0 (patch) | |
tree | d803e0e891fc6c14ff2a390beeabbe59d0ad8485 /src/lib/Markdown/Section.tsx | |
parent | d23df805ed5d0e78c604d5c9f81f21bbc6a06288 (diff) | |
parent | ef9dfdacf17c62254331140a40a508549aa725b4 (diff) | |
download | react-benzin-master.tar.gz |
Release 4.1.0
Diffstat (limited to 'src/lib/Markdown/Section.tsx')
-rw-r--r-- | src/lib/Markdown/Section.tsx | 61 |
1 files changed, 0 insertions, 61 deletions
diff --git a/src/lib/Markdown/Section.tsx b/src/lib/Markdown/Section.tsx deleted file mode 100644 index fb2933d..0000000 --- a/src/lib/Markdown/Section.tsx +++ /dev/null @@ -1,61 +0,0 @@ -import React from 'react'; -import { Typography } from '@material-ui/core'; -import ContentSection from '../ContentSection/ContentSection'; -import Content from './Content'; -import { ParserPropTypes } from './types'; - -interface PropTypes extends ParserPropTypes { - level?: number; -} - -interface MapperPropTypes extends PropTypes { - SectionComponent: React.FC<PropTypes>; -} - -const getHeaderLevel = (header: string): number => { - if (!header) return 0; - let level = 0; - while (header[level] === '#') level += 1; - return level; -}; - -const SectionMapper: React.FC<MapperPropTypes> = ({ rawLines, level = 0, SectionComponent }) => { - const children = rawLines - .reduce((sections: string[][], line: string) => { - if (line) { - if (getHeaderLevel(line) === level) sections.push([]); - if (sections.length) sections[sections.length - 1].push(line); - } - return sections; - }, []) - .map(sectionLines => <SectionComponent rawLines={sectionLines} level={level} />); - - return <>{children}</>; -}; - - -const Section: React.FC<PropTypes> = ({ rawLines, level = 0 }) => { - const deeperLevelIndex = rawLines.findIndex(line => line.match(`^#{${level + 1},} .*$`)); - const rawContent = rawLines.splice(0, (deeperLevelIndex < 0) ? rawLines.length : deeperLevelIndex); - - if (!level) { - return ( - <> - <Typography><Content rawLines={rawContent} /></Typography> - <SectionMapper rawLines={rawLines} level={getHeaderLevel(rawLines[0])} SectionComponent={Section} /> - </> - ); - } - - const sectionName = rawContent.splice(0, 1)[0].slice(level).trim(); - const deeperLevel = getHeaderLevel(rawLines[0]); - return ( - <ContentSection sectionName={sectionName} level={level}> - <Content rawLines={rawContent} /> - <SectionMapper rawLines={rawLines} level={deeperLevel} SectionComponent={Section} /> - </ContentSection> - ); -}; - -export default Section; - |