2024-03-13 08:59:37 +01:00
|
|
|
import rehypeCitation from "rehype-citation"
|
|
|
|
import { PluggableList } from "unified"
|
|
|
|
import { visit } from "unist-util-visit"
|
|
|
|
import { QuartzTransformerPlugin } from "../types"
|
|
|
|
|
|
|
|
export interface Options {
|
|
|
|
bibliographyFile: string
|
|
|
|
suppressBibliography: boolean
|
|
|
|
linkCitations: boolean
|
|
|
|
csl: string
|
|
|
|
}
|
|
|
|
|
|
|
|
const defaultOptions: Options = {
|
|
|
|
bibliographyFile: "./bibliography.bib",
|
|
|
|
suppressBibliography: false,
|
|
|
|
linkCitations: false,
|
|
|
|
csl: "apa",
|
|
|
|
}
|
|
|
|
|
2024-11-16 23:07:50 +01:00
|
|
|
export const Citations: QuartzTransformerPlugin<Partial<Options> | undefined> = (userOpts) => {
|
2024-03-13 08:59:37 +01:00
|
|
|
const opts = { ...defaultOptions, ...userOpts }
|
|
|
|
return {
|
|
|
|
name: "Citations",
|
2024-11-16 23:07:50 +01:00
|
|
|
htmlPlugins() {
|
2024-03-13 08:59:37 +01:00
|
|
|
const plugins: PluggableList = []
|
|
|
|
|
|
|
|
// Add rehype-citation to the list of plugins
|
|
|
|
plugins.push([
|
|
|
|
rehypeCitation,
|
|
|
|
{
|
|
|
|
bibliography: opts.bibliographyFile,
|
|
|
|
suppressBibliography: opts.suppressBibliography,
|
|
|
|
linkCitations: opts.linkCitations,
|
|
|
|
},
|
|
|
|
])
|
|
|
|
|
|
|
|
// Transform the HTML of the citattions; add data-no-popover property to the citation links
|
|
|
|
// using https://github.com/syntax-tree/unist-util-visit as they're just anochor links
|
|
|
|
plugins.push(() => {
|
|
|
|
return (tree, _file) => {
|
2024-11-16 23:07:50 +01:00
|
|
|
visit(tree, "element", (node, index, parent) => {
|
2024-03-13 08:59:37 +01:00
|
|
|
if (node.tagName === "a" && node.properties?.href?.startsWith("#bib")) {
|
|
|
|
node.properties["data-no-popover"] = true
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
return plugins
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|