fix tag pages to emit to tag/index.html to override content and folder pages
| | |
| | | ] |
| | | })) |
| | | |
| | | // 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) { |
| | |
| | | ) |
| | | } |
| | | |
| | | // 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") |
| | | let configContent = await fs.promises.readFile(configFilePath, { encoding: 'utf-8' }) |
| | |
| | | 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) |
| | |
| | | const folders: Set<CanonicalSlug> = 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<string, ProcessedContent> = Object.fromEntries([...folders].map(folder => ([ |
| | | folder, defaultProcessedContent({ slug: joinSegments(folder, "index") as ServerSlug, frontmatter: { title: `Folder: ${folder}`, tags: [] } }) |
| | | ]))) |
| | |
| | | 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<FullPageLayout> = (opts) => { |
| | | if (!opts) { |
| | |
| | | |
| | | const tags: Set<string> = new Set(allFiles.flatMap(data => data.frontmatter?.tags ?? [])) |
| | | const tagDescriptions: Record<string, ProcessedContent> = 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] |
| | | } |
| | |
| | | } |
| | | |
| | | 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 = { |