| | |
| | | import { FilePath, joinSegments, resolveRelative, simplifySlug } from "../../util/path" |
| | | import { resolveRelative, simplifySlug } from "../../util/path" |
| | | import { QuartzEmitterPlugin } from "../types" |
| | | import { write } from "./helpers" |
| | | import DepGraph from "../../depgraph" |
| | | import { getAliasSlugs } from "../transformers/frontmatter" |
| | | import { BuildCtx } from "../../util/ctx" |
| | | import { VFile } from "vfile" |
| | | |
| | | export const AliasRedirects: QuartzEmitterPlugin = () => ({ |
| | | name: "AliasRedirects", |
| | | async getDependencyGraph(ctx, content, _resources) { |
| | | const graph = new DepGraph<FilePath>() |
| | | |
| | | const { argv } = ctx |
| | | for (const [_tree, file] of content) { |
| | | for (const slug of getAliasSlugs(file.data.frontmatter?.aliases ?? [], argv, file)) { |
| | | graph.addEdge(file.data.filePath!, joinSegments(argv.output, slug + ".html") as FilePath) |
| | | } |
| | | } |
| | | |
| | | return graph |
| | | }, |
| | | async *emit(ctx, content, _resources) { |
| | | for (const [_tree, file] of content) { |
| | | async function* processFile(ctx: BuildCtx, file: VFile) { |
| | | const ogSlug = simplifySlug(file.data.slug!) |
| | | |
| | | for (const slug of file.data.aliases ?? []) { |
| | |
| | | }) |
| | | } |
| | | } |
| | | |
| | | export const AliasRedirects: QuartzEmitterPlugin = () => ({ |
| | | name: "AliasRedirects", |
| | | async *emit(ctx, content) { |
| | | for (const [_tree, file] of content) { |
| | | yield* processFile(ctx, file) |
| | | } |
| | | }, |
| | | async *partialEmit(ctx, _content, _resources, changeEvents) { |
| | | for (const changeEvent of changeEvents) { |
| | | if (!changeEvent.file) continue |
| | | if (changeEvent.type === "add" || changeEvent.type === "change") { |
| | | // add new ones if this file still exists |
| | | yield* processFile(ctx, changeEvent.file) |
| | | } |
| | | } |
| | | }, |
| | | }) |