style: scrollable tables

This commit is contained in:
Jacky Zhao 2023-11-11 11:39:56 -08:00
parent 134b6ed582
commit 50a87d0d86
2 changed files with 34 additions and 10 deletions
quartz/util

29
quartz/util/jsx.tsx Normal file
View file

@ -0,0 +1,29 @@
import { Components, toJsxRuntime } from "hast-util-to-jsx-runtime"
import { QuartzPluginData } from "../plugins/vfile"
import { Node, Root } from "hast"
import { Fragment, jsx, jsxs } from "preact/jsx-runtime"
import { trace } from "./trace"
import { type FilePath } from "./path"
const customComponents: Components = {
table: (props) => (
<div class="table-container">
<table {...props} />
</div>
),
}
export function htmlToJsx(fp: FilePath, tree: Node<QuartzPluginData>) {
try {
// @ts-ignore (preact makes it angry)
return toJsxRuntime(tree as Root, {
Fragment,
jsx,
jsxs,
elementAttributeNameCase: "html",
components: customComponents,
})
} catch (e) {
trace(`Failed to parse Markdown in \`${fp}\` into JSX`, e as Error)
}
}