From 08f8e3b4a4879dd7c91c16fbce80c4f2bc5e357f Mon Sep 17 00:00:00 2001
From: Jacky Zhao <j.zhao2k19@gmail.com>
Date: Mon, 10 Jul 2023 02:32:24 +0000
Subject: [PATCH] docs + various polish
---
quartz/path.ts | 28 ++++++++++++++++++----------
1 files changed, 18 insertions(+), 10 deletions(-)
diff --git a/quartz/path.ts b/quartz/path.ts
index 4efd748..0332584 100644
--- a/quartz/path.ts
+++ b/quartz/path.ts
@@ -5,23 +5,31 @@
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 {
+ // remove index
+ if (fp.endsWith("index")) {
+ fp = fp.slice(0, -"index".length)
+ }
+
+ // remove trailing slash
+ if (fp.endsWith("/")) {
+ fp = fp.slice(0, -1)
+ }
+
+ return fp
+}
+
export function trimPathSuffix(fp: string): string {
+ fp = clientSideSlug(fp)
let [cleanPath, anchor] = fp.split("#", 2)
anchor = anchor === undefined ? "" : "#" + anchor
- if (cleanPath.endsWith("index")) {
- cleanPath = cleanPath.slice(0, -"index".length)
- }
-
- if (cleanPath === "") {
- cleanPath = "./"
- }
-
return cleanPath + anchor
}
export function slugify(s: string): string {
- const [fp, anchor] = s.split("#", 2)
+ let [fp, anchor] = s.split("#", 2)
const sluggedAnchor = anchor === undefined ? "" : "#" + slugAnchor(anchor)
const withoutFileExt = fp.replace(new RegExp(path.extname(fp) + '$'), '')
const rawSlugSegments = withoutFileExt.split(path.sep)
@@ -36,7 +44,7 @@
export function resolveToRoot(slug: string): string {
let fp = trimPathSuffix(slug)
- if (fp === "./") {
+ if (fp === "") {
return "."
}
--
Gitblit v1.10.0