55 lines
1.2 KiB
TypeScript
55 lines
1.2 KiB
TypeScript
|
import { PluggableList } from "unified"
|
||
|
import { Root as HTMLRoot } from 'hast'
|
||
|
import { toString } from "hast-util-to-string"
|
||
|
import { QuartzTransformerPlugin } from "../types"
|
||
|
|
||
|
export interface Options {
|
||
|
descriptionLength: number
|
||
|
}
|
||
|
|
||
|
const defaultOptions: Options = {
|
||
|
descriptionLength: 150
|
||
|
}
|
||
|
|
||
|
export class Description extends QuartzTransformerPlugin {
|
||
|
name = "Description"
|
||
|
opts: Options
|
||
|
|
||
|
constructor(opts?: Options) {
|
||
|
super()
|
||
|
this.opts = { ...defaultOptions, ...opts }
|
||
|
}
|
||
|
|
||
|
markdownPlugins(): PluggableList {
|
||
|
return []
|
||
|
}
|
||
|
|
||
|
htmlPlugins(): PluggableList {
|
||
|
return [
|
||
|
() => {
|
||
|
return async (tree: HTMLRoot, file) => {
|
||
|
const frontMatterDescription = file.data.frontmatter?.description
|
||
|
const desc = frontMatterDescription ?? toString(tree)
|
||
|
const sentences = desc.replace(/\s+/g, ' ').split('.')
|
||
|
let finalDesc = ""
|
||
|
let sentenceIdx = 0
|
||
|
const len = this.opts.descriptionLength
|
||
|
while (finalDesc.length < len) {
|
||
|
finalDesc += sentences[sentenceIdx] + '.'
|
||
|
sentenceIdx++
|
||
|
}
|
||
|
|
||
|
file.data.description = finalDesc
|
||
|
}
|
||
|
}
|
||
|
]
|
||
|
}
|
||
|
}
|
||
|
|
||
|
declare module 'vfile' {
|
||
|
interface DataMap {
|
||
|
description: string
|
||
|
}
|
||
|
}
|
||
|
|