Files
coder/site/src/components/CodeBlock/CodeBlock.tsx
2022-05-06 13:23:03 -05:00

40 lines
992 B
TypeScript

import { makeStyles } from "@material-ui/core/styles"
import React from "react"
import { MONOSPACE_FONT_FAMILY } from "../../theme/constants"
import { combineClasses } from "../../util/combineClasses"
export interface CodeBlockProps {
lines: string[]
className?: string
}
export const CodeBlock: React.FC<CodeBlockProps> = ({ lines, className = "" }) => {
const styles = useStyles()
return (
<div className={combineClasses([styles.root, className])}>
{lines.map((line, idx) => (
<div className={styles.line} key={idx}>
{line}
</div>
))}
</div>
)
}
const useStyles = makeStyles((theme) => ({
root: {
minHeight: 156,
background: theme.palette.background.default,
color: theme.palette.codeBlock.contrastText,
fontFamily: MONOSPACE_FONT_FAMILY,
fontSize: 13,
wordBreak: "break-all",
padding: theme.spacing(2),
borderRadius: theme.shape.borderRadius,
},
line: {
whiteSpace: "pre-wrap",
},
}))