feat: implement getDependencyGraph for AliasRedirects emitter (#860)
This commit is contained in:
		| @@ -9,9 +9,30 @@ export const AliasRedirects: QuartzEmitterPlugin = () => ({ | ||||
|   getQuartzComponents() { | ||||
|     return [] | ||||
|   }, | ||||
|   async getDependencyGraph(_ctx, _content, _resources) { | ||||
|     // TODO implement | ||||
|     return new DepGraph<FilePath>() | ||||
|   async getDependencyGraph(ctx, content, _resources) { | ||||
|     const graph = new DepGraph<FilePath>() | ||||
|  | ||||
|     const { argv } = ctx | ||||
|     for (const [_tree, file] of content) { | ||||
|       const dir = path.posix.relative(argv.directory, path.dirname(file.data.filePath!)) | ||||
|       const aliases = file.data.frontmatter?.aliases ?? [] | ||||
|       const slugs = aliases.map((alias) => path.posix.join(dir, alias) as FullSlug) | ||||
|       const permalink = file.data.frontmatter?.permalink | ||||
|       if (typeof permalink === "string") { | ||||
|         slugs.push(permalink as FullSlug) | ||||
|       } | ||||
|  | ||||
|       for (let slug of slugs) { | ||||
|         // fix any slugs that have trailing slash | ||||
|         if (slug.endsWith("/")) { | ||||
|           slug = joinSegments(slug, "index") as FullSlug | ||||
|         } | ||||
|  | ||||
|         graph.addEdge(file.data.filePath!, joinSegments(argv.output, slug + ".html") as FilePath) | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     return graph | ||||
|   }, | ||||
|   async emit(ctx, content, _resources): Promise<FilePath[]> { | ||||
|     const { argv } = ctx | ||||
|   | ||||
		Reference in New Issue
	
	Block a user