mirror of
https://github.com/alrayyes/wiki.git
synced 2024-11-30 06:56:22 +00:00
29 lines
799 B
TypeScript
29 lines
799 B
TypeScript
|
import { PluggableList } from "unified"
|
||
|
import { QuartzTransformerPlugin } from "../types"
|
||
|
import rehypePrettyCode, { Options as CodeOptions } from "rehype-pretty-code"
|
||
|
|
||
|
export class SyntaxHighlighting extends QuartzTransformerPlugin {
|
||
|
name = "SyntaxHighlighting"
|
||
|
|
||
|
markdownPlugins(): PluggableList {
|
||
|
return []
|
||
|
}
|
||
|
|
||
|
htmlPlugins(): PluggableList {
|
||
|
return [[rehypePrettyCode, {
|
||
|
theme: 'css-variables',
|
||
|
onVisitLine(node) {
|
||
|
if (node.children.length === 0) {
|
||
|
node.children = [{ type: 'text', value: ' ' }]
|
||
|
}
|
||
|
},
|
||
|
onVisitHighlightedLine(node) {
|
||
|
node.properties.className.push('highlighted')
|
||
|
},
|
||
|
onVisitHighlightedWord(node) {
|
||
|
node.properties.className = ['word']
|
||
|
},
|
||
|
} satisfies Partial<CodeOptions>]]
|
||
|
}
|
||
|
}
|