aboutsummaryrefslogtreecommitdiff
path: root/src/components/CodeBlock.js
blob: 0c21984c1c6d2e8ec034c16bf7a31b03bb8a233c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/** @jsx jsx */
import { jsx, Styled } from "theme-ui";
import Highlight, { defaultProps } from "prism-react-renderer";
import theme from "../codeTheme";

function CodeBlock({ code, language }) {
  return (
    <Highlight {...defaultProps} theme={theme} code={code} language={language}>
      {({ className, style, tokens, getLineProps, getTokenProps }) => (
        <Styled.pre className={className} style={style}>
          {tokens.map((line, i) => (
            <div {...getLineProps({ line, key: i })}>
              {line.map((token, key) => (
                <span {...getTokenProps({ token, key })} />
              ))}
            </div>
          ))}
        </Styled.pre>
      )}
    </Highlight>
  );
}

export default CodeBlock;