Jacky Zhao
2023-10-22 7c01e8dde06abb1a80118b5eddce3e238830ede0
feat: openLinksInNewTab option for link transformer
2 files modified
7 ■■■■■ changed files
quartz/components/scripts/spa.inline.ts 1 ●●●● patch | view | raw | blame | history
quartz/plugins/transformers/links.ts 6 ●●●●● patch | view | raw | blame | history
quartz/components/scripts/spa.inline.ts
@@ -20,6 +20,7 @@
const getOpts = ({ target }: Event): { url: URL; scroll?: boolean } | undefined => {
  if (!isElement(target)) return
  if (target.attributes.getNamedItem("target")?.value === "_blank") return
  const a = target.closest("a")
  if (!a) return
  if ("routerIgnore" in a.dataset) return
quartz/plugins/transformers/links.ts
@@ -18,11 +18,13 @@
  markdownLinkResolution: TransformOptions["strategy"]
  /** Strips folders from a link so that it looks nice */
  prettyLinks: boolean
  openLinksInNewTab: boolean
}
const defaultOptions: Options = {
  markdownLinkResolution: "absolute",
  prettyLinks: true,
  openLinksInNewTab: false,
}
export const CrawlLinks: QuartzTransformerPlugin<Partial<Options> | undefined> = (userOpts) => {
@@ -52,6 +54,10 @@
                node.properties.className ??= []
                node.properties.className.push(isAbsoluteUrl(dest) ? "external" : "internal")
                if (opts.openLinksInNewTab) {
                  node.properties.target = "_blank"
                }
                // don't process external links or intra-document anchors
                const isInternal = !(isAbsoluteUrl(dest) || dest.startsWith("#"))
                if (isInternal) {