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