2023-05-30 08:02:20 -07:00
|
|
|
import remarkGfm from "remark-gfm"
|
2023-07-22 17:27:41 -07:00
|
|
|
import smartypants from "remark-smartypants"
|
2023-05-30 08:02:20 -07:00
|
|
|
import { QuartzTransformerPlugin } from "../types"
|
2023-06-01 19:48:38 -04:00
|
|
|
import rehypeSlug from "rehype-slug"
|
2023-06-04 12:35:45 -04:00
|
|
|
import rehypeAutolinkHeadings from "rehype-autolink-headings"
|
2023-05-30 08:02:20 -07:00
|
|
|
|
|
|
|
export interface Options {
|
|
|
|
enableSmartyPants: boolean
|
2023-06-01 19:48:38 -04:00
|
|
|
linkHeadings: boolean
|
2023-05-30 08:02:20 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
const defaultOptions: Options = {
|
2023-06-01 19:48:38 -04:00
|
|
|
enableSmartyPants: true,
|
2023-07-22 17:27:41 -07:00
|
|
|
linkHeadings: true,
|
2023-05-30 08:02:20 -07:00
|
|
|
}
|
|
|
|
|
2023-07-22 17:27:41 -07:00
|
|
|
export const GitHubFlavoredMarkdown: QuartzTransformerPlugin<Partial<Options> | undefined> = (
|
|
|
|
userOpts,
|
|
|
|
) => {
|
2023-06-11 23:26:43 -07:00
|
|
|
const opts = { ...defaultOptions, ...userOpts }
|
|
|
|
return {
|
|
|
|
name: "GitHubFlavoredMarkdown",
|
|
|
|
markdownPlugins() {
|
2023-07-02 13:08:29 -07:00
|
|
|
return opts.enableSmartyPants ? [remarkGfm, smartypants] : [remarkGfm]
|
2023-06-11 23:26:43 -07:00
|
|
|
},
|
|
|
|
htmlPlugins() {
|
|
|
|
if (opts.linkHeadings) {
|
2023-07-22 17:27:41 -07:00
|
|
|
return [
|
|
|
|
rehypeSlug,
|
|
|
|
[
|
|
|
|
rehypeAutolinkHeadings,
|
|
|
|
{
|
|
|
|
behavior: "append",
|
2024-01-05 17:29:34 +09:00
|
|
|
properties: {
|
|
|
|
ariaHidden: true,
|
|
|
|
tabIndex: -1,
|
|
|
|
"data-no-popover": true,
|
|
|
|
},
|
2023-07-22 17:27:41 -07:00
|
|
|
content: {
|
|
|
|
type: "text",
|
|
|
|
value: " §",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
]
|
2023-06-11 23:26:43 -07:00
|
|
|
} else {
|
|
|
|
return []
|
|
|
|
}
|
2023-07-22 17:27:41 -07:00
|
|
|
},
|
2023-05-30 08:02:20 -07:00
|
|
|
}
|
|
|
|
}
|