| | |
| | | // @ts-ignore |
| | | import script from "./scripts/toc.inline" |
| | | import { i18n } from "../i18n" |
| | | import OverflowList from "./OverflowList" |
| | | import OverflowListFactory from "./OverflowList" |
| | | import { concatenateResources } from "../util/resources" |
| | | |
| | | interface Options { |
| | | layout: "modern" | "legacy" |
| | |
| | | layout: "modern", |
| | | } |
| | | |
| | | export default ((opts?: Partial<Options>) => { |
| | | const layout = opts?.layout ?? defaultOptions.layout |
| | | const { OverflowList, overflowListAfterDOMLoaded } = OverflowListFactory() |
| | | const TableOfContents: QuartzComponent = ({ |
| | | fileData, |
| | | displayClass, |
| | |
| | | </svg> |
| | | </button> |
| | | <div class={fileData.collapseToc ? "collapsed toc-content" : "toc-content"}> |
| | | <OverflowList id="toc-ul"> |
| | | <OverflowList> |
| | | {fileData.toc.map((tocEntry) => ( |
| | | <li key={tocEntry.slug} class={`depth-${tocEntry.depth}`}> |
| | | <a href={`#${tocEntry.slug}`} data-for={tocEntry.slug}> |
| | |
| | | </div> |
| | | ) |
| | | } |
| | | |
| | | TableOfContents.css = modernStyle |
| | | TableOfContents.afterDOMLoaded = script + OverflowList.afterDOMLoaded("toc-ul") |
| | | TableOfContents.afterDOMLoaded = concatenateResources(script, overflowListAfterDOMLoaded) |
| | | |
| | | const LegacyTableOfContents: QuartzComponent = ({ fileData, cfg }: QuartzComponentProps) => { |
| | | if (!fileData.toc) { |
| | |
| | | } |
| | | LegacyTableOfContents.css = legacyStyle |
| | | |
| | | export default ((opts?: Partial<Options>) => { |
| | | const layout = opts?.layout ?? defaultOptions.layout |
| | | return layout === "modern" ? TableOfContents : LegacyTableOfContents |
| | | }) satisfies QuartzComponentConstructor |