| @@ -8,6 +8,7 @@ import { sharedPageComponents } from "../../../quartz.layout" | ||||
| import { NotFound } from "../../components" | ||||
| import { defaultProcessedContent } from "../vfile" | ||||
| import { write } from "./helpers" | ||||
| import { i18n } from "../../i18n" | ||||
|  | ||||
| export const NotFoundPage: QuartzEmitterPlugin = () => { | ||||
|   const opts: FullPageLayout = { | ||||
| @@ -33,11 +34,12 @@ export const NotFoundPage: QuartzEmitterPlugin = () => { | ||||
|       const url = new URL(`https://${cfg.baseUrl ?? "example.com"}`) | ||||
|       const path = url.pathname as FullSlug | ||||
|       const externalResources = pageResources(path, resources) | ||||
|       const notFound = i18n(cfg.locale).pages.error.title | ||||
|       const [tree, vfile] = defaultProcessedContent({ | ||||
|         slug, | ||||
|         text: "Not Found", | ||||
|         description: "Not Found", | ||||
|         frontmatter: { title: "Not Found", tags: [] }, | ||||
|         text: notFound, | ||||
|         description: notFound, | ||||
|         frontmatter: { title: notFound, tags: [] }, | ||||
|       }) | ||||
|       const componentData: QuartzComponentProps = { | ||||
|         fileData: vfile.data, | ||||
| @@ -51,7 +53,7 @@ export const NotFoundPage: QuartzEmitterPlugin = () => { | ||||
|       return [ | ||||
|         await write({ | ||||
|           ctx, | ||||
|           content: renderPage(slug, componentData, opts, externalResources), | ||||
|           content: renderPage(cfg, slug, componentData, opts, externalResources), | ||||
|           slug, | ||||
|           ext: ".html", | ||||
|         }), | ||||
|   | ||||
| @@ -6,6 +6,7 @@ import { FilePath, FullSlug, SimpleSlug, joinSegments, simplifySlug } from "../. | ||||
| import { QuartzEmitterPlugin } from "../types" | ||||
| import { toHtml } from "hast-util-to-html" | ||||
| import { write } from "./helpers" | ||||
| import { i18n } from "../../i18n" | ||||
|  | ||||
| export type ContentIndex = Map<FullSlug, ContentDetails> | ||||
| export type ContentDetails = { | ||||
| @@ -38,7 +39,7 @@ function generateSiteMap(cfg: GlobalConfiguration, idx: ContentIndex): string { | ||||
|   const base = cfg.baseUrl ?? "" | ||||
|   const createURLEntry = (slug: SimpleSlug, content: ContentDetails): string => `<url> | ||||
|     <loc>https://${joinSegments(base, encodeURI(slug))}</loc> | ||||
|     <lastmod>${content.date?.toISOString()}</lastmod> | ||||
|     ${content.date && `<lastmod>${content.date.toISOString()}</lastmod>`} | ||||
|   </url>` | ||||
|   const urls = Array.from(idx) | ||||
|     .map(([slug, content]) => createURLEntry(simplifySlug(slug), content)) | ||||
| @@ -78,7 +79,7 @@ function generateRSSFeed(cfg: GlobalConfiguration, idx: ContentIndex, limit?: nu | ||||
|     <channel> | ||||
|       <title>${escapeHTML(cfg.pageTitle)}</title> | ||||
|       <link>https://${base}</link> | ||||
|       <description>${!!limit ? `Last ${limit} notes` : "Recent notes"} on ${escapeHTML( | ||||
|       <description>${!!limit ? i18n(cfg.locale).pages.rss.lastFewNotes({ count: limit }) : i18n(cfg.locale).pages.rss.recentNotes} on ${escapeHTML( | ||||
|         cfg.pageTitle, | ||||
|       )}</description> | ||||
|       <generator>Quartz -- quartz.jzhao.xyz</generator> | ||||
|   | ||||
| @@ -49,7 +49,7 @@ export const ContentPage: QuartzEmitterPlugin<Partial<FullPageLayout>> = (userOp | ||||
|           allFiles, | ||||
|         } | ||||
|  | ||||
|         const content = renderPage(slug, componentData, opts, externalResources) | ||||
|         const content = renderPage(cfg, slug, componentData, opts, externalResources) | ||||
|         const fp = await write({ | ||||
|           ctx, | ||||
|           content, | ||||
|   | ||||
| @@ -18,6 +18,7 @@ import { | ||||
| import { defaultListPageLayout, sharedPageComponents } from "../../../quartz.layout" | ||||
| import { FolderContent } from "../../components" | ||||
| import { write } from "./helpers" | ||||
| import { i18n } from "../../i18n" | ||||
|  | ||||
| export const FolderPage: QuartzEmitterPlugin<Partial<FullPageLayout>> = (userOpts) => { | ||||
|   const opts: FullPageLayout = { | ||||
| @@ -57,7 +58,10 @@ export const FolderPage: QuartzEmitterPlugin<Partial<FullPageLayout>> = (userOpt | ||||
|           folder, | ||||
|           defaultProcessedContent({ | ||||
|             slug: joinSegments(folder, "index") as FullSlug, | ||||
|             frontmatter: { title: `Folder: ${folder}`, tags: [] }, | ||||
|             frontmatter: { | ||||
|               title: `${i18n(cfg.locale).pages.folderContent.folder}: ${folder}`, | ||||
|               tags: [], | ||||
|             }, | ||||
|           }), | ||||
|         ]), | ||||
|       ) | ||||
| @@ -82,7 +86,7 @@ export const FolderPage: QuartzEmitterPlugin<Partial<FullPageLayout>> = (userOpt | ||||
|           allFiles, | ||||
|         } | ||||
|  | ||||
|         const content = renderPage(slug, componentData, opts, externalResources) | ||||
|         const content = renderPage(cfg, slug, componentData, opts, externalResources) | ||||
|         const fp = await write({ | ||||
|           ctx, | ||||
|           content, | ||||
|   | ||||
| @@ -15,6 +15,7 @@ import { | ||||
| import { defaultListPageLayout, sharedPageComponents } from "../../../quartz.layout" | ||||
| import { TagContent } from "../../components" | ||||
| import { write } from "./helpers" | ||||
| import { i18n } from "../../i18n" | ||||
|  | ||||
| export const TagPage: QuartzEmitterPlugin<Partial<FullPageLayout>> = (userOpts) => { | ||||
|   const opts: FullPageLayout = { | ||||
| @@ -47,7 +48,10 @@ export const TagPage: QuartzEmitterPlugin<Partial<FullPageLayout>> = (userOpts) | ||||
|  | ||||
|       const tagDescriptions: Record<string, ProcessedContent> = Object.fromEntries( | ||||
|         [...tags].map((tag) => { | ||||
|           const title = tag === "index" ? "Tag Index" : `Tag: #${tag}` | ||||
|           const title = | ||||
|             tag === "index" | ||||
|               ? i18n(cfg.locale).pages.tagContent.tagIndex | ||||
|               : `${i18n(cfg.locale).pages.tagContent.tag}: #${tag}` | ||||
|           return [ | ||||
|             tag, | ||||
|             defaultProcessedContent({ | ||||
| @@ -81,7 +85,7 @@ export const TagPage: QuartzEmitterPlugin<Partial<FullPageLayout>> = (userOpts) | ||||
|           allFiles, | ||||
|         } | ||||
|  | ||||
|         const content = renderPage(slug, componentData, opts, externalResources) | ||||
|         const content = renderPage(cfg, slug, componentData, opts, externalResources) | ||||
|         const fp = await write({ | ||||
|           ctx, | ||||
|           content, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user