From e0ebee5aa9b3646de722f139f1d8d15591df538e Mon Sep 17 00:00:00 2001
From: Jacky Zhao <j.zhao2k19@gmail.com>
Date: Sun, 02 Jul 2023 20:08:29 +0000
Subject: [PATCH] various polish
---
quartz/path.ts | 25 ++++++++++++++++++++-----
1 files changed, 20 insertions(+), 5 deletions(-)
diff --git a/quartz/path.ts b/quartz/path.ts
index 87f1a9d..81cdb3a 100644
--- a/quartz/path.ts
+++ b/quartz/path.ts
@@ -5,6 +5,23 @@
return s.replace(/\s/g, '-')
}
+// on the client, 'index' isn't ever rendered so we should clean it up
+export function clientSideSlug(fp: string): string {
+ if (fp.endsWith("index")) {
+ fp = fp.slice(0, -"index".length)
+ }
+
+ return fp
+}
+
+export function trimPathSuffix(fp: string): string {
+ fp = clientSideSlug(fp)
+ let [cleanPath, anchor] = fp.split("#", 2)
+ anchor = anchor === undefined ? "" : "#" + anchor
+
+ return cleanPath + anchor
+}
+
export function slugify(s: string): string {
const [fp, anchor] = s.split("#", 2)
const sluggedAnchor = anchor === undefined ? "" : "#" + slugAnchor(anchor)
@@ -19,10 +36,7 @@
// resolve /a/b/c to ../../
export function resolveToRoot(slug: string): string {
- let fp = slug
- if (fp.endsWith("index")) {
- fp = fp.slice(0, -"index".length)
- }
+ let fp = trimPathSuffix(slug)
if (fp === "") {
return "."
@@ -40,7 +54,8 @@
}
export function relative(src: string, dest: string): string {
- return path.relative(src, dest)
+ return "./" + path.relative(src, dest)
+
}
export const QUARTZ = "quartz"
--
Gitblit v1.10.0