CodeBlock.tsx 970 B

1234567891011121314151617181920212223242526272829303132
  1. import { type JSX, splitProps, createResource } from "solid-js"
  2. import { codeToHtml } from "shiki"
  3. import styles from "./codeblock.module.css"
  4. import { transformerNotationDiff } from "@shikijs/transformers"
  5. interface CodeBlockProps extends JSX.HTMLAttributes<HTMLDivElement> {
  6. code: string
  7. lang?: string
  8. }
  9. function CodeBlock(props: CodeBlockProps) {
  10. const [local, rest] = splitProps(props, ["code", "lang"])
  11. const [html] = createResource(
  12. () => [local.code, local.lang],
  13. async ([code, lang]) => {
  14. // TODO: For testing delays
  15. // await new Promise((resolve) => setTimeout(resolve, 3000))
  16. return (await codeToHtml(code || "", {
  17. lang: lang || "text",
  18. themes: {
  19. light: "github-light",
  20. dark: "github-dark",
  21. },
  22. transformers: [transformerNotationDiff()],
  23. })) as string
  24. },
  25. )
  26. return <div innerHTML={html()} class={styles.codeblock} {...rest}></div>
  27. }
  28. export default CodeBlock