From e26658f4ed7068b6bec2563fd4aef82011d53a3b Mon Sep 17 00:00:00 2001
From: Jacky Zhao <j.zhao2k19@gmail.com>
Date: Thu, 13 Mar 2025 21:22:11 +0000
Subject: [PATCH] fix(description): calculate description properly when first sentence is longer than max
---
quartz/plugins/emitters/assets.ts | 37 ++++++++++++++++++++++++++++---------
1 files changed, 28 insertions(+), 9 deletions(-)
diff --git a/quartz/plugins/emitters/assets.ts b/quartz/plugins/emitters/assets.ts
index edc22d9..120d168 100644
--- a/quartz/plugins/emitters/assets.ts
+++ b/quartz/plugins/emitters/assets.ts
@@ -3,18 +3,39 @@
import path from "path"
import fs from "fs"
import { glob } from "../../util/glob"
+import DepGraph from "../../depgraph"
+import { Argv } from "../../util/ctx"
+import { QuartzConfig } from "../../cfg"
+
+const filesToCopy = async (argv: Argv, cfg: QuartzConfig) => {
+ // glob all non MD files in content folder and copy it over
+ return await glob("**", argv.directory, ["**/*.md", ...cfg.configuration.ignorePatterns])
+}
export const Assets: QuartzEmitterPlugin = () => {
return {
name: "Assets",
- getQuartzComponents() {
- return []
+ async getDependencyGraph(ctx, _content, _resources) {
+ const { argv, cfg } = ctx
+ const graph = new DepGraph<FilePath>()
+
+ const fps = await filesToCopy(argv, cfg)
+
+ for (const fp of fps) {
+ const ext = path.extname(fp)
+ const src = joinSegments(argv.directory, fp) as FilePath
+ const name = (slugifyFilePath(fp as FilePath, true) + ext) as FilePath
+
+ const dest = joinSegments(argv.output, name) as FilePath
+
+ graph.addEdge(src, dest)
+ }
+
+ return graph
},
- async emit({ argv, cfg }, _content, _resources, _emit): Promise<FilePath[]> {
- // glob all non MD/MDX/HTML files in content folder and copy it over
+ async *emit({ argv, cfg }, _content, _resources) {
const assetsPath = argv.output
- const fps = await glob("**", argv.directory, ["**/*.md", ...cfg.configuration.ignorePatterns])
- const res: FilePath[] = []
+ const fps = await filesToCopy(argv, cfg)
for (const fp of fps) {
const ext = path.extname(fp)
const src = joinSegments(argv.directory, fp) as FilePath
@@ -24,10 +45,8 @@
const dir = path.dirname(dest) as FilePath
await fs.promises.mkdir(dir, { recursive: true }) // ensure dir exists
await fs.promises.copyFile(src, dest)
- res.push(dest)
+ yield dest
}
-
- return res
},
}
}
--
Gitblit v1.10.0