Jacky Zhao
2023-05-31 3636c052eb054d93a8a3ddfb9fdd873d5fe83a5d
quartz/plugins/transformers/links.ts
@@ -29,7 +29,7 @@
  markdownPlugins(): PluggableList {
    return [[remarkWikiLink, {
      pathFormat: this.opts.markdownLinkResolution === "absolute" ? 'obsidian-absolute' : 'raw'
      pathFormat: this.opts.markdownLinkResolution === "absolute" ? 'obsidian-absolute' : 'raw',
    }]]
  }
@@ -38,7 +38,7 @@
      return (tree, file) => {
        const curSlug = file.data.slug! 
        const transformLink = (target: string) => {
          const targetSlug = slugify(decodeURI(target))
          const targetSlug = slugify(decodeURI(target).trim())
          if (this.opts.markdownLinkResolution === 'relative' && !path.isAbsolute(targetSlug)) {
            return './' + relative(curSlug, targetSlug)
          } else {
@@ -46,8 +46,8 @@
          }
        }
        // rewrite all links
        visit(tree, 'element', (node, _index, _parent) => {
          // rewrite all links
          if (
            node.tagName === 'a' &&
            node.properties &&
@@ -60,14 +60,13 @@
              node.properties.href = transformLink(node.properties.href)
            }
            // rewrite link internals if prettylinks is on
            if (this.opts.prettyLinks && node.children.length === 1 && node.children[0].type === 'text') {
              node.children[0].value = path.basename(node.children[0].value)
            }
          }
        })
        // transform all images
        visit(tree, 'element', (node, _index, _parent) => {
          if (
            node.tagName === 'img' &&
            node.properties &&
@@ -75,7 +74,7 @@
          ) {
            if (!isAbsoluteUrl(node.properties.src)) {
              const ext = path.extname(node.properties.src)
              node.properties.src = transformLink("/assets/" + node.properties.src) + ext
              node.properties.src = transformLink(path.join("assets", node.properties.src)) + ext
            }
          }
        })