From ec00a40aefca73596ab76e3ebe3a8e1129b43688 Mon Sep 17 00:00:00 2001
From: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Date: Tue, 27 Jan 2026 18:27:17 +0000
Subject: [PATCH] chore(deps): bump the production-dependencies group with 4 updates (#2289)
---
quartz/util/theme.ts | 59 +++++++++++++++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 55 insertions(+), 4 deletions(-)
diff --git a/quartz/util/theme.ts b/quartz/util/theme.ts
index 8381cc7..ff4453b 100644
--- a/quartz/util/theme.ts
+++ b/quartz/util/theme.ts
@@ -15,7 +15,7 @@
darkMode: ColorScheme
}
-type FontSpecification =
+export type FontSpecification =
| string
| {
name: string
@@ -25,6 +25,7 @@
export interface Theme {
typography: {
+ title?: FontSpecification
header: FontSpecification
body: FontSpecification
code: FontSpecification
@@ -48,7 +49,10 @@
return spec.name
}
-function formatFontSpecification(type: "header" | "body" | "code", spec: FontSpecification) {
+function formatFontSpecification(
+ type: "title" | "header" | "body" | "code",
+ spec: FontSpecification,
+) {
if (typeof spec === "string") {
spec = { name: spec }
}
@@ -82,12 +86,58 @@
}
export function googleFontHref(theme: Theme) {
- const { code, header, body } = theme.typography
+ const { header, body, code } = theme.typography
const headerFont = formatFontSpecification("header", header)
const bodyFont = formatFontSpecification("body", body)
const codeFont = formatFontSpecification("code", code)
- return `https://fonts.googleapis.com/css2?family=${bodyFont}&family=${headerFont}&family=${codeFont}&display=swap`
+ return `https://fonts.googleapis.com/css2?family=${headerFont}&family=${bodyFont}&family=${codeFont}&display=swap`
+}
+
+export function googleFontSubsetHref(theme: Theme, text: string) {
+ const title = theme.typography.title || theme.typography.header
+ const titleFont = formatFontSpecification("title", title)
+
+ return `https://fonts.googleapis.com/css2?family=${titleFont}&text=${encodeURIComponent(text)}&display=swap`
+}
+
+export interface GoogleFontFile {
+ url: string
+ filename: string
+ extension: string
+}
+
+const fontMimeMap: Record<string, string> = {
+ truetype: "ttf",
+ woff: "woff",
+ woff2: "woff2",
+ opentype: "otf",
+}
+
+export async function processGoogleFonts(
+ stylesheet: string,
+ baseUrl: string,
+): Promise<{
+ processedStylesheet: string
+ fontFiles: GoogleFontFile[]
+}> {
+ const fontSourceRegex =
+ /url\((https:\/\/fonts.gstatic.com\/.+(?:\/|(?:kit=))(.+?)[.&].+?)\)\sformat\('(\w+?)'\);/g
+ const fontFiles: GoogleFontFile[] = []
+ let processedStylesheet = stylesheet
+
+ let match
+ while ((match = fontSourceRegex.exec(stylesheet)) !== null) {
+ const url = match[1]
+ const filename = match[2]
+ const extension = fontMimeMap[match[3].toLowerCase()]
+ const staticUrl = `https://${baseUrl}/static/fonts/${filename}.${extension}`
+
+ processedStylesheet = processedStylesheet.replace(url, staticUrl)
+ fontFiles.push({ url, filename, extension })
+ }
+
+ return { processedStylesheet, fontFiles }
}
export function joinStyles(theme: Theme, ...stylesheet: string[]) {
@@ -105,6 +155,7 @@
--highlight: ${theme.colors.lightMode.highlight};
--textHighlight: ${theme.colors.lightMode.textHighlight};
+ --titleFont: "${getFontSpecificationName(theme.typography.title || theme.typography.header)}", ${DEFAULT_SANS_SERIF};
--headerFont: "${getFontSpecificationName(theme.typography.header)}", ${DEFAULT_SANS_SERIF};
--bodyFont: "${getFontSpecificationName(theme.typography.body)}", ${DEFAULT_SANS_SERIF};
--codeFont: "${getFontSpecificationName(theme.typography.code)}", ${DEFAULT_MONO};
--
Gitblit v1.10.0