58 lines
1.8 KiB
TypeScript
Raw Normal View History

import { FilePath, FullSlug, joinSegments, resolveRelative, simplifySlug } from "../../util/path"
2023-06-16 19:41:59 -07:00
import { QuartzEmitterPlugin } from "../types"
2023-07-22 17:27:41 -07:00
import path from "path"
2023-06-16 19:41:59 -07:00
export const AliasRedirects: QuartzEmitterPlugin = () => ({
name: "AliasRedirects",
getQuartzComponents() {
return []
},
2023-07-23 17:09:12 -07:00
async emit({ argv }, content, _resources, emit): Promise<FilePath[]> {
2023-07-13 00:19:35 -07:00
const fps: FilePath[] = []
2023-06-16 19:41:59 -07:00
for (const [_tree, file] of content) {
const ogSlug = simplifySlug(file.data.slug!)
const dir = path.posix.relative(argv.directory, path.dirname(file.data.filePath!))
2023-06-16 19:41:59 -07:00
let aliases: FullSlug[] = file.data.frontmatter?.aliases ?? file.data.frontmatter?.alias ?? []
if (typeof aliases === "string") {
aliases = [aliases]
2023-06-16 19:41:59 -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)
}
for (let slug of slugs) {
// fix any slugs that have trailing slash
if (slug.endsWith("/")) {
slug = joinSegments(slug, "index") as FullSlug
}
const redirUrl = resolveRelative(slug, file.data.slug!)
2023-08-10 21:16:07 -07:00
const fp = await emit({
2023-06-16 19: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-22 17:27:41 -07:00
},
2023-06-16 19:41:59 -07:00
})