2023-11-12 00:56:30 +07:00
|
|
|
import { FilePath, FullSlug, joinSegments, resolveRelative, simplifySlug } from "../../util/path"
|
2023-06-17 09:41:59 +07:00
|
|
|
import { QuartzEmitterPlugin } from "../types"
|
2023-07-23 07:27:41 +07:00
|
|
|
import path from "path"
|
2024-01-19 01:56:14 +07:00
|
|
|
import { write } from "./helpers"
|
2024-02-09 22:07:32 +07:00
|
|
|
import DepGraph from "../../depgraph"
|
2023-06-17 09:41:59 +07:00
|
|
|
|
|
|
|
export const AliasRedirects: QuartzEmitterPlugin = () => ({
|
|
|
|
name: "AliasRedirects",
|
|
|
|
getQuartzComponents() {
|
|
|
|
return []
|
|
|
|
},
|
2024-02-16 07:50:48 +07:00
|
|
|
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
|
2024-02-09 22:07:32 +07:00
|
|
|
},
|
2024-01-19 01:56:14 +07:00
|
|
|
async emit(ctx, content, _resources): Promise<FilePath[]> {
|
|
|
|
const { argv } = ctx
|
2023-07-13 14:19:35 +07:00
|
|
|
const fps: FilePath[] = []
|
2023-06-17 09:41:59 +07:00
|
|
|
|
|
|
|
for (const [_tree, file] of content) {
|
2023-08-20 05:52:25 +07:00
|
|
|
const ogSlug = simplifySlug(file.data.slug!)
|
2023-08-30 00:37:00 +07:00
|
|
|
const dir = path.posix.relative(argv.directory, path.dirname(file.data.filePath!))
|
2024-01-28 12:39:16 +07:00
|
|
|
const aliases = file.data.frontmatter?.aliases ?? []
|
2023-08-30 00:37:00 +07:00
|
|
|
const slugs: FullSlug[] = 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)
|
|
|
|
}
|
|
|
|
|
2023-11-12 00:56:30 +07:00
|
|
|
for (let slug of slugs) {
|
|
|
|
// fix any slugs that have trailing slash
|
|
|
|
if (slug.endsWith("/")) {
|
|
|
|
slug = joinSegments(slug, "index") as FullSlug
|
|
|
|
}
|
|
|
|
|
2023-08-20 05:52:25 +07:00
|
|
|
const redirUrl = resolveRelative(slug, file.data.slug!)
|
2024-01-19 01:56:14 +07:00
|
|
|
const fp = await write({
|
|
|
|
ctx,
|
2023-06-17 09:41:59 +07:00
|
|
|
content: `
|
|
|
|
<!DOCTYPE html>
|
|
|
|
<html lang="en-us">
|
|
|
|
<head>
|
|
|
|
<title>${ogSlug}</title>
|
|
|
|
<link rel="canonical" href="${redirUrl}">
|
|
|
|
<meta name="robots" content="noindex">
|
|
|
|
<meta charset="utf-8">
|
|
|
|
<meta http-equiv="refresh" content="0; url=${redirUrl}">
|
|
|
|
</head>
|
|
|
|
</html>
|
|
|
|
`,
|
|
|
|
slug,
|
|
|
|
ext: ".html",
|
|
|
|
})
|
|
|
|
|
|
|
|
fps.push(fp)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return fps
|
2023-07-23 07:27:41 +07:00
|
|
|
},
|
2023-06-17 09:41:59 +07:00
|
|
|
})
|