personal-website/components/SuspendedCodeSnippet.tsx

39 lines
878 B
TypeScript
Raw Normal View History

'use client'
import { type FC, type PropsWithChildren, useEffect, useRef } from 'react'
import 'prismjs/themes/prism-okaidia.min.css'
export interface Props {
language: string
}
const SuspendedCodeSnippet: FC<PropsWithChildren<Props>> = ({
children,
language,
}) => {
const codeRef = useRef<HTMLElement>(null)
useEffect(() => {
const highlight = async () => {
const highlightElement = (await import('prismjs')).highlightElement
// @ts-expect-error
await import('prismjs/components/prism-javascript.min.js')
// @ts-expect-error
await import('prismjs/components/prism-typescript.min.js')
highlightElement(codeRef.current!)
}
highlight()
}, [])
return (
<pre>
<code className={`language-${language}`} ref={codeRef}>
{children}
</code>
</pre>
)
}
export default SuspendedCodeSnippet