| | |
| | | import { QuartzConfig } from "./quartz/cfg" |
| | | import { PageLayout, QuartzConfig } from "./quartz/cfg" |
| | | import * as Component from "./quartz/components" |
| | | import * as Plugin from "./quartz/plugins" |
| | | |
| | | const sharedPageComponents = { |
| | | head: Component.Head(), |
| | | header: [], |
| | | footer: Component.Footer({ |
| | | authorName: "Jacky", |
| | | links: { |
| | | "GitHub": "https://github.com/jackyzha0", |
| | | "Twitter": "https://twitter.com/_jzhao" |
| | | } |
| | | }) |
| | | } |
| | | |
| | | const contentPageLayout: PageLayout = { |
| | | beforeBody: [ |
| | | Component.ArticleTitle(), |
| | | Component.ReadingTime(), |
| | | Component.TagList(), |
| | | ], |
| | | left: [ |
| | | Component.PageTitle(), |
| | | Component.MobileOnly(Component.Spacer()), |
| | | Component.Search(), |
| | | Component.Darkmode(), |
| | | Component.DesktopOnly(Component.TableOfContents()), |
| | | ], |
| | | right: [ |
| | | Component.Graph(), |
| | | Component.Backlinks(), |
| | | ], |
| | | } |
| | | |
| | | const listPageLayout: PageLayout = { |
| | | beforeBody: [ |
| | | Component.ArticleTitle() |
| | | ], |
| | | left: [ |
| | | Component.PageTitle(), |
| | | Component.MobileOnly(Component.Spacer()), |
| | | Component.Search(), |
| | | Component.Darkmode() |
| | | ], |
| | | right: [], |
| | | } |
| | | |
| | | const config: QuartzConfig = { |
| | | configuration: { |
| | | pageTitle: "🪴 Quartz 4.0", |
| | | enableSPA: true, |
| | | enablePopovers: true, |
| | | analytics: { |
| | | provider: 'plausible', |
| | | }, |
| | | canonicalUrl: "quartz.jzhao.xyz", |
| | | ignorePatterns: ["private", "templates"], |
| | | theme: { |
| | | typography: { // loaded from Google Fonts |
| | |
| | | colors: { |
| | | lightMode: { |
| | | light: '#faf8f8', |
| | | lightgray: '#e8e8e8', |
| | | gray: '#dadada', |
| | | lightgray: '#e5e5e5', |
| | | gray: '#b8b8b8', |
| | | darkgray: '#4e4e4e', |
| | | dark: '#141021', |
| | | secondary: '#284b63', |
| | |
| | | }, |
| | | darkMode: { |
| | | light: '#161618', |
| | | lightgray: '#292629', |
| | | gray: '#343434', |
| | | lightgray: '#393639', |
| | | gray: '#646464', |
| | | darkgray: '#d4d4d4', |
| | | dark: '#fbfffe', |
| | | secondary: '#7b97aa', |
| | |
| | | Plugin.Description(), |
| | | ], |
| | | filters: [ |
| | | Plugin.RemoveDrafts() |
| | | Plugin.RemoveDrafts(), |
| | | ], |
| | | emitters: [ |
| | | Plugin.AliasRedirects(), |
| | | Plugin.ContentPage({ |
| | | head: Component.Head(), |
| | | header: [ |
| | | Component.PageTitle({ title: "🪴 Quartz 4.0" }), |
| | | Component.Spacer(), |
| | | Component.Search(), |
| | | Component.Darkmode() |
| | | ], |
| | | beforeBody: [ |
| | | Component.ArticleTitle(), |
| | | Component.ReadingTime(), |
| | | Component.TagList(), |
| | | ], |
| | | content: Component.Content(), |
| | | left: [ |
| | | ], |
| | | right: [ |
| | | Component.Graph(), |
| | | Component.TableOfContents(), |
| | | Component.Backlinks() |
| | | ], |
| | | footer: [] |
| | | ...sharedPageComponents, |
| | | ...contentPageLayout, |
| | | pageBody: Component.Content(), |
| | | }), |
| | | Plugin.ContentIndex(), // you can exclude this if you don't plan on using popovers, graph, or backlinks, |
| | | Plugin.CNAME({ domain: "yoursite.xyz" }) // set this to your final deployed domain |
| | | Plugin.FolderPage({ |
| | | ...sharedPageComponents, |
| | | ...listPageLayout, |
| | | pageBody: Component.FolderContent(), |
| | | }), |
| | | Plugin.TagPage({ |
| | | ...sharedPageComponents, |
| | | ...listPageLayout, |
| | | pageBody: Component.TagContent(), |
| | | }), |
| | | Plugin.ContentIndex({ |
| | | enableSiteMap: true, |
| | | enableRSS: true, |
| | | }), |
| | | ] |
| | | }, |
| | | } |