personal-website/components/server/CodeSnippet.tsx
Filipe Medeiros 5ff4edc634
feat: lots of stuff sorry
Signed-off-by: Filipe Medeiros <hello@filipesm.eu>
2023-12-03 12:25:54 +01:00

37 lines
981 B
TypeScript

import Prism, { highlight } from 'prismjs'
import { type PropsWithChildren } from 'react'
import { RichText } from '@/lib/notion/types'
import richTextAsPlainText from '@/lib/notion/utils/richTextToPlainText'
export interface Props {
language: string
codeRichText: RichText
}
export default async function CodeSnippet({
language,
codeRichText,
}: PropsWithChildren<Props>) {
await import(`prismjs/components/prism-${language}.min.js`)
// @ts-expect-error CSS not JS
await import('prismjs/themes/prism-tomorrow.min.css')
// @ts-expect-error CSS not JS
await import('prismjs/themes/prism.min.css')
const highlightedCodeHtml = highlight(
richTextAsPlainText(codeRichText),
Prism.languages[language],
language,
)
return (
<pre className="rounded border border-neutral-500 bg-neutral-800 p-4">
<code
className={`language-${language}`}
dangerouslySetInnerHTML={{ __html: highlightedCodeHtml }}
/>
</pre>
)
}