Delegate options to parsers

This commit is contained in:
Emile Bangma 2024-09-19 10:16:38 +00:00
parent 03f4cb8b8a
commit e697696a20
2 changed files with 26 additions and 17 deletions

View File

@ -3,6 +3,14 @@ import { ReplaceFunction, findAndReplace as mdastFindReplace } from "mdast-util-
import { SKIP } from "unist-util-visit"
import { Root } from "mdast"
interface Options {
enabled: Boolean
}
const defaultOptions: Options = {
enabled: true,
}
const arrowMapping: Record<string, string> = {
"->": "&rarr;",
"-->": "&rArr;",
@ -16,25 +24,28 @@ const arrowMapping: Record<string, string> = {
const arrowRegex = new RegExp(/(-{1,2}>|={1,2}>|<-{1,2}|<={1,2})/g)
export const ObsidianMarkdownArrow: QuartzTransformerPlugin = () => {
export const ObsidianMarkdownArrow: QuartzTransformerPlugin<Partial<Options>> = (userOpts) => {
const opts: Options = { ...defaultOptions, ...userOpts }
return {
name: "ObsidianMarkdownArrow",
markdownPlugins() {
return [
(tree: Root) => {
const replacements: [RegExp, string | ReplaceFunction][] = []
replacements.push([
arrowRegex,
(value: string, ..._capture: string[]) => {
const maybeArrow = arrowMapping[value]
if (maybeArrow === undefined) return SKIP
return {
type: "html",
value: `<span>${maybeArrow}</span>`,
}
},
])
mdastFindReplace(tree, replacements)
if (opts.enabled) {
const replacements: [RegExp, string | ReplaceFunction][] = []
replacements.push([
arrowRegex,
(value: string, ..._capture: string[]) => {
const maybeArrow = arrowMapping[value]
if (maybeArrow === undefined) return SKIP
return {
type: "html",
value: `<span>${maybeArrow}</span>`,
}
},
])
mdastFindReplace(tree, replacements)
}
},
]
},

View File

@ -183,9 +183,7 @@ export const ObsidianFlavoredMarkdown: QuartzTransformerPlugin<Partial<ObsidianO
//const replacements: [RegExp, string | ReplaceFunction][] = []
//const base = pathToRoot(file.data.slug!)
if (opts.parseArrows) {
ObsidianMarkdownArrow()
}
ObsidianMarkdownArrow({ enabled: opts.parseArrows })
//mdastFindReplace(tree, replacements)
}