| | |
| | | import { QuartzTransformerPlugin } from "../types" |
| | | import yaml from "js-yaml" |
| | | import toml from "toml" |
| | | import { slugTag } from "../../util/path" |
| | | import { FilePath, FullSlug, getFileExtension, slugifyFilePath, slugTag } from "../../util/path" |
| | | import { QuartzPluginData } from "../vfile" |
| | | import { i18n } from "../../i18n" |
| | | |
| | |
| | | .map((tag: string | number) => tag.toString()) |
| | | } |
| | | |
| | | export const FrontMatter: QuartzTransformerPlugin<Partial<Options> | undefined> = (userOpts) => { |
| | | function getAliasSlugs(aliases: string[]): FullSlug[] { |
| | | const res: FullSlug[] = [] |
| | | for (const alias of aliases) { |
| | | const isMd = getFileExtension(alias) === "md" |
| | | const mockFp = isMd ? alias : alias + ".md" |
| | | const slug = slugifyFilePath(mockFp as FilePath) |
| | | res.push(slug) |
| | | } |
| | | |
| | | return res |
| | | } |
| | | |
| | | export const FrontMatter: QuartzTransformerPlugin<Partial<Options>> = (userOpts) => { |
| | | const opts = { ...defaultOptions, ...userOpts } |
| | | return { |
| | | name: "FrontMatter", |
| | | markdownPlugins({ cfg }) { |
| | | markdownPlugins(ctx) { |
| | | const { cfg, allSlugs } = ctx |
| | | return [ |
| | | [remarkFrontmatter, ["yaml", "toml"]], |
| | | () => { |
| | | return (_, file) => { |
| | | const { data } = matter(Buffer.from(file.value), { |
| | | const fileData = Buffer.from(file.value as Uint8Array) |
| | | const { data } = matter(fileData, { |
| | | ...opts, |
| | | engines: { |
| | | yaml: (s) => yaml.load(s, { schema: yaml.JSON_SCHEMA }) as object, |
| | |
| | | }, |
| | | }) |
| | | |
| | | if (data.title) { |
| | | if (data.title != null && data.title.toString() !== "") { |
| | | data.title = data.title.toString() |
| | | } else if (data.title === null || data.title === undefined) { |
| | | } else { |
| | | data.title = file.stem ?? i18n(cfg.configuration.locale).propertyDefaults.title |
| | | } |
| | | |
| | |
| | | if (tags) data.tags = [...new Set(tags.map((tag: string) => slugTag(tag)))] |
| | | |
| | | const aliases = coerceToArray(coalesceAliases(data, ["aliases", "alias"])) |
| | | if (aliases) data.aliases = aliases |
| | | if (aliases) { |
| | | data.aliases = aliases // frontmatter |
| | | file.data.aliases = getAliasSlugs(aliases) |
| | | allSlugs.push(...file.data.aliases) |
| | | } |
| | | |
| | | if (data.permalink != null && data.permalink.toString() !== "") { |
| | | data.permalink = data.permalink.toString() as FullSlug |
| | | const aliases = file.data.aliases ?? [] |
| | | aliases.push(data.permalink) |
| | | file.data.aliases = aliases |
| | | allSlugs.push(data.permalink) |
| | | } |
| | | |
| | | const cssclasses = coerceToArray(coalesceAliases(data, ["cssclasses", "cssclass"])) |
| | | if (cssclasses) data.cssclasses = cssclasses |
| | | |
| | | const socialImage = coalesceAliases(data, ["socialImage", "image", "cover"]) |
| | | |
| | | const created = coalesceAliases(data, ["created", "date"]) |
| | | if (created) data.created = created |
| | | const modified = coalesceAliases(data, [ |
| | | "modified", |
| | | "lastmod", |
| | | "updated", |
| | | "last-modified", |
| | | ]) |
| | | if (modified) data.modified = modified |
| | | const published = coalesceAliases(data, ["published", "publishDate", "date"]) |
| | | if (published) data.published = published |
| | | |
| | | if (socialImage) data.socialImage = socialImage |
| | | |
| | | // fill in frontmatter |
| | | file.data.frontmatter = data as QuartzPluginData["frontmatter"] |
| | | } |
| | |
| | | |
| | | declare module "vfile" { |
| | | interface DataMap { |
| | | aliases: FullSlug[] |
| | | frontmatter: { [key: string]: unknown } & { |
| | | title: string |
| | | } & Partial<{ |
| | | tags: string[] |
| | | aliases: string[] |
| | | modified: string |
| | | created: string |
| | | published: string |
| | | description: string |
| | | publish: boolean |
| | | draft: boolean |
| | | socialDescription: string |
| | | publish: boolean | string |
| | | draft: boolean | string |
| | | lang: string |
| | | enableToc: string |
| | | cssclasses: string[] |
| | | socialImage: string |
| | | comments: boolean | string |
| | | }> |
| | | } |
| | | } |