personal-website/components/server/TeX.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

56 lines
1.3 KiB
TypeScript

import katex, { type KatexOptions, ParseError } from 'katex'
import { type ComponentProps, type ReactElement } from 'react'
export type Props<T extends keyof JSX.IntrinsicElements = 'div'> =
ComponentProps<T> &
Partial<{
as: T
block: boolean
errorColor: string
renderError: (error: ParseError | TypeError) => ReactElement
settings: KatexOptions
}> & {
math: string
}
export default async function TeX({
children,
math,
block,
errorColor,
renderError,
settings,
as: asComponent,
...props
}: Props) {
// @ts-expect-error CSS not JS
await import('katex/dist/katex.min.css')
const Component = asComponent || (block ? 'div' : 'span')
const content = (children ?? math) as string
let innerHtml: string
try {
innerHtml = katex.renderToString(content, {
displayMode: !!block,
errorColor,
throwOnError: !!renderError,
...settings,
})
} catch (error) {
if (error instanceof ParseError || error instanceof TypeError) {
if (renderError) {
return renderError(error)
} else {
innerHtml = error.message
}
} else {
throw error
}
}
return (
<Component {...props} dangerouslySetInnerHTML={{ __html: innerHtml }} />
)
}