nexxtway/react-rainbow

View on GitHub
src/components/MarkdownOutput/renderers/index.js

Summary

Maintainability
D
2 days
Test Coverage
/* eslint-disable react/prop-types, id-length, react/jsx-props-no-spreading */
import React from 'react';
import {
    StyledHeading,
    StyledInlineHeading,
    StyledParagraph,
    StyledInlineParagraph,
    StyledCode,
    StyledInlineCode,
    StyledHR,
    StyledTable,
    StyledTableRow,
    StyledTableHeadindCell,
    StyledTableCell,
    StyledList,
    StyledOrderedList,
    StyledListItem,
    StyledBlockquote,
    StyledInlineBlockquote,
    StyledLink,
    StyledPre,
    StyledInlinePre,
} from './styled';

const Heading = ({ level, children }) => {
    return (
        <StyledHeading as={`h${level}`} level={level}>
            {children}
        </StyledHeading>
    );
};

const InlineHeading = ({ level, children }) => {
    return (
        <StyledInlineHeading as={`h${level}`} level={level}>
            {children}
        </StyledInlineHeading>
    );
};

export const defaultRenderer = {
    h1: props => <Heading level={1} {...props} />,
    h2: props => <Heading level={2} {...props} />,
    h3: props => <Heading level={3} {...props} />,
    h4: props => <Heading level={4} {...props} />,
    h5: props => <Heading level={5} {...props} />,
    h6: props => <Heading level={6} {...props} />,
    code: StyledCode,
    blockquote: StyledBlockquote,
    p: StyledParagraph,
    a: StyledLink,
    hr: StyledHR,
    ul: StyledList,
    ol: StyledOrderedList,
    li: StyledListItem,
    table: StyledTable,
    th: StyledTableHeadindCell,
    tr: StyledTableRow,
    td: StyledTableCell,
    pre: StyledPre,
};

export const inlineRenderer = {
    h1: props => <InlineHeading level={1} {...props} />,
    h2: props => <InlineHeading level={2} {...props} />,
    h3: props => <InlineHeading level={3} {...props} />,
    h4: props => <InlineHeading level={4} {...props} />,
    h5: props => <InlineHeading level={5} {...props} />,
    h6: props => <InlineHeading level={6} {...props} />,
    code: StyledInlineCode,
    blockquote: StyledInlineBlockquote,
    p: StyledInlineParagraph,
    a: StyledLink,
    hr: StyledHR,
    ul: StyledList,
    ol: StyledOrderedList,
    li: StyledListItem,
    table: StyledTable,
    th: StyledTableHeadindCell,
    tr: StyledTableRow,
    td: StyledTableCell,
    pre: StyledInlinePre,
};