mirror of
https://github.com/phuoc-ng/csslayout.git
synced 2025-10-23 10:46:13 +02:00
25 lines
960 B
TypeScript
25 lines
960 B
TypeScript
import * as React from 'react';
|
|
import Highlight, { defaultProps, Language } from 'prism-react-renderer';
|
|
import theme from 'prism-react-renderer/themes/vsDark';
|
|
|
|
export const Code: React.FC<{
|
|
children: string;
|
|
language: Language;
|
|
}> = ({ children, language }) => {
|
|
return (
|
|
<Highlight {...defaultProps} theme={theme} code={children.trim()} language={language}>
|
|
{({ className, style, tokens, getLineProps, getTokenProps }) => (
|
|
<pre className={`block-code ${className}`} style={{ ...style }}>
|
|
{tokens.map((line, i) => (
|
|
<div key={i} {...getLineProps({ line, key: i })}>
|
|
{line.map((token, key) => (
|
|
<span key={key} {...getTokenProps({ token, key })} />
|
|
))}
|
|
</div>
|
|
))}
|
|
</pre>
|
|
)}
|
|
</Highlight>
|
|
);
|
|
};
|