From da1b6b37fe2ee09359b532f0d2669975b4476c95 Mon Sep 17 00:00:00 2001
From: Jacky Zhao <j.zhao2k19@gmail.com>
Date: Fri, 14 Mar 2025 17:05:26 +0000
Subject: [PATCH] fix(explorer): fix incorrect recursive case for folder rendering
---
quartz/plugins/emitters/static.ts | 20 +++++++++++---------
1 files changed, 11 insertions(+), 9 deletions(-)
diff --git a/quartz/plugins/emitters/static.ts b/quartz/plugins/emitters/static.ts
index c52c628..7c0ecfd 100644
--- a/quartz/plugins/emitters/static.ts
+++ b/quartz/plugins/emitters/static.ts
@@ -3,12 +3,10 @@
import fs from "fs"
import { glob } from "../../util/glob"
import DepGraph from "../../depgraph"
+import { dirname } from "path"
export const Static: QuartzEmitterPlugin = () => ({
name: "Static",
- getQuartzComponents() {
- return []
- },
async getDependencyGraph({ argv, cfg }, _content, _resources) {
const graph = new DepGraph<FilePath>()
@@ -23,13 +21,17 @@
return graph
},
- async emit({ argv, cfg }, _content, _resources): Promise<FilePath[]> {
+ async *emit({ argv, cfg }, _content) {
const staticPath = joinSegments(QUARTZ, "static")
const fps = await glob("**", staticPath, cfg.configuration.ignorePatterns)
- await fs.promises.cp(staticPath, joinSegments(argv.output, "static"), {
- recursive: true,
- dereference: true,
- })
- return fps.map((fp) => joinSegments(argv.output, "static", fp)) as FilePath[]
+ const outputStaticPath = joinSegments(argv.output, "static")
+ await fs.promises.mkdir(outputStaticPath, { recursive: true })
+ for (const fp of fps) {
+ const src = joinSegments(staticPath, fp) as FilePath
+ const dest = joinSegments(outputStaticPath, fp) as FilePath
+ await fs.promises.mkdir(dirname(dest), { recursive: true })
+ await fs.promises.copyFile(src, dest)
+ yield dest
+ }
},
})
--
Gitblit v1.10.0