From fcaec298e9f654a0730a737739f506e9ceed6bc8 Mon Sep 17 00:00:00 2001 From: Jacky Zhao Date: Wed, 19 Jul 2023 23:03:59 -0700 Subject: [PATCH] fix tag pages to emit to tag/index.html to override content and folder pages --- quartz/bootstrap-cli.mjs | 20 ++++++++++---------- quartz/build.ts | 6 +++++- quartz/plugins/emitters/folderPage.tsx | 5 +---- quartz/plugins/emitters/tagPage.tsx | 8 ++++---- 4 files changed, 20 insertions(+), 19 deletions(-) diff --git a/quartz/bootstrap-cli.mjs b/quartz/bootstrap-cli.mjs index f6f5543e..db53ccf5 100755 --- a/quartz/bootstrap-cli.mjs +++ b/quartz/bootstrap-cli.mjs @@ -128,16 +128,6 @@ yargs(hideBin(process.argv)) ] })) - // TODO - const linkResolutionStrategy = exitIfCancel(await select({ - message: `Choose how Quartz should resolve links in your content. You can change this later in \`quartz.config.ts\`.`, - options: [ - { value: 'absolute', label: "Treat links as absolute path", hint: "for content made for Quartz 3 and Hugo" }, - { value: 'shortest', label: "Treat links as shortest path", hint: "for most Obsidian vaults" }, - { value: 'relative', label: "Treat links as relative paths", hint: "for just normal Markdown files" }, - ] - })) - async function rmContentFolder() { const contentStat = await fs.promises.lstat(contentFolder) if (contentStat) { @@ -182,6 +172,16 @@ See the [documentation](https://quartz.jzhao.xyz) for how to get started. ` ) } + + // get a prefered link resolution strategy + const linkResolutionStrategy = exitIfCancel(await select({ + message: `Choose how Quartz should resolve links in your content. You can change this later in \`quartz.config.ts\`.`, + options: [ + { value: 'absolute', label: "Treat links as absolute path", hint: "for content made for Quartz 3 and Hugo" }, + { value: 'shortest', label: "Treat links as shortest path", hint: "for most Obsidian vaults" }, + { value: 'relative', label: "Treat links as relative paths", hint: "for just normal Markdown files" }, + ] + })) // now, do config changes const configFilePath = path.join(cwd, "quartz.config.ts") diff --git a/quartz/build.ts b/quartz/build.ts index 6926d681..de3f5479 100644 --- a/quartz/build.ts +++ b/quartz/build.ts @@ -61,7 +61,11 @@ export default async function buildQuartz(argv: Argv, version: string) { directoryListing: false, }) const status = res.statusCode - const statusString = status === 200 ? chalk.green(`[${status}]`) : chalk.red(`[${status}]`) + const statusString = (status >= 200 && status < 300) ? + chalk.green(`[${status}]`) : + (status >= 300 && status < 400) ? + chalk.yellow(`[${status}]`) : + chalk.red(`[${status}]`) console.log(statusString + chalk.grey(` ${req.url}`)) }) server.listen(argv.port) diff --git a/quartz/plugins/emitters/folderPage.tsx b/quartz/plugins/emitters/folderPage.tsx index 7ac6d81c..2f6bcbf9 100644 --- a/quartz/plugins/emitters/folderPage.tsx +++ b/quartz/plugins/emitters/folderPage.tsx @@ -29,15 +29,12 @@ export const FolderPage: QuartzEmitterPlugin = (opts) => { const folders: Set = new Set(allFiles.flatMap(data => { const slug = data.slug const folderName = path.dirname(slug ?? "") as CanonicalSlug - if (slug && folderName !== ".") { + if (slug && folderName !== "." && folderName !== "tags") { return [folderName] } return [] })) - // remove special prefixes - folders.delete("tags" as CanonicalSlug) - const folderDescriptions: Record = Object.fromEntries([...folders].map(folder => ([ folder, defaultProcessedContent({ slug: joinSegments(folder, "index") as ServerSlug, frontmatter: { title: `Folder: ${folder}`, tags: [] } }) ]))) diff --git a/quartz/plugins/emitters/tagPage.tsx b/quartz/plugins/emitters/tagPage.tsx index 30717fa3..62bfe111 100644 --- a/quartz/plugins/emitters/tagPage.tsx +++ b/quartz/plugins/emitters/tagPage.tsx @@ -5,7 +5,7 @@ import BodyConstructor from "../../components/Body" import { pageResources, renderPage } from "../../components/renderPage" import { ProcessedContent, defaultProcessedContent } from "../vfile" import { FullPageLayout } from "../../cfg" -import { CanonicalSlug, FilePath, ServerSlug } from "../../path" +import { CanonicalSlug, FilePath, ServerSlug, joinSegments } from "../../path" export const TagPage: QuartzEmitterPlugin = (opts) => { if (!opts) { @@ -27,13 +27,13 @@ export const TagPage: QuartzEmitterPlugin = (opts) => { const tags: Set = new Set(allFiles.flatMap(data => data.frontmatter?.tags ?? [])) const tagDescriptions: Record = Object.fromEntries([...tags].map(tag => ([ - tag, defaultProcessedContent({ slug: `tags/${tag}` as ServerSlug, frontmatter: { title: `Tag: ${tag}`, tags: [] } }) + tag, defaultProcessedContent({ slug: `tags/${tag}/index` as ServerSlug, frontmatter: { title: `Tag: ${tag}`, tags: [] } }) ]))) for (const [tree, file] of content) { const slug = file.data.slug! if (slug.startsWith("tags/")) { - const tag = slug.slice("tags/".length) + const tag = joinSegments(slug.slice("tags/".length), "index") if (tags.has(tag)) { tagDescriptions[tag] = [tree, file] } @@ -41,7 +41,7 @@ export const TagPage: QuartzEmitterPlugin = (opts) => { } for (const tag of tags) { - const slug = `tags/${tag}` as CanonicalSlug + const slug = `tags/${tag}/index` as CanonicalSlug const externalResources = pageResources(slug, resources) const [tree, file] = tagDescriptions[tag] const componentData: QuartzComponentProps = {