import { QuartzComponentConstructor, QuartzComponentProps } from "./types" import legacyStyle from "./styles/legacyToc.scss" import modernStyle from "./styles/toc.scss" import { classNames } from "../util/lang" // @ts-ignore import script from "./scripts/toc.inline" import { i18n } from "../i18n" interface Options { layout: "modern" | "legacy" } const defaultOptions: Options = { layout: "modern", } function TableOfContents({ fileData, displayClass, cfg }: QuartzComponentProps) { if (!fileData.toc) { return null } return (
) } TableOfContents.css = modernStyle TableOfContents.afterDOMLoaded = script function LegacyTableOfContents({ fileData, cfg }: QuartzComponentProps) { if (!fileData.toc) { return null } return (

{i18n(cfg.locale).components.tableOfContents.title}

) } LegacyTableOfContents.css = legacyStyle export default ((opts?: Partial) => { const layout = opts?.layout ?? defaultOptions.layout return layout === "modern" ? TableOfContents : LegacyTableOfContents }) satisfies QuartzComponentConstructor