feat(md): allow customizing container titles globally (#3044)

pull/3054/head
Jason Dai 1 year ago committed by GitHub
parent 2bf0d0b954
commit bdb080093f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -20,7 +20,7 @@ import attrsPlugin from 'markdown-it-attrs'
import emojiPlugin from 'markdown-it-emoji' import emojiPlugin from 'markdown-it-emoji'
import type { ILanguageRegistration, IThemeRegistration } from 'shiki' import type { ILanguageRegistration, IThemeRegistration } from 'shiki'
import type { Logger } from 'vite' import type { Logger } from 'vite'
import { containerPlugin } from './plugins/containers' import { containerPlugin, type ContainerOptions } from './plugins/containers'
import { highlight } from './plugins/highlight' import { highlight } from './plugins/highlight'
import { highlightLinePlugin } from './plugins/highlightLines' import { highlightLinePlugin } from './plugins/highlightLines'
import { imagePlugin } from './plugins/image' import { imagePlugin } from './plugins/image'
@ -57,6 +57,7 @@ export interface MarkdownOptions extends MarkdownIt.Options {
cache?: boolean cache?: boolean
component?: ComponentPluginOptions component?: ComponentPluginOptions
math?: boolean | any math?: boolean | any
container?: ContainerOptions
} }
export type MarkdownRenderer = MarkdownIt export type MarkdownRenderer = MarkdownIt
@ -95,7 +96,7 @@ export const createMarkdownRenderer = async (
.use(highlightLinePlugin) .use(highlightLinePlugin)
.use(preWrapperPlugin, { hasSingleTheme }) .use(preWrapperPlugin, { hasSingleTheme })
.use(snippetPlugin, srcDir) .use(snippetPlugin, srcDir)
.use(containerPlugin, { hasSingleTheme }) .use(containerPlugin, { hasSingleTheme }, options.container)
.use(imagePlugin) .use(imagePlugin)
.use( .use(
linkPlugin, linkPlugin,

@ -9,12 +9,34 @@ import {
type Options type Options
} from './preWrapper' } from './preWrapper'
export const containerPlugin = (md: MarkdownIt, options: Options) => { export const containerPlugin = (
md.use(...createContainer('tip', 'TIP', md)) md: MarkdownIt,
.use(...createContainer('info', 'INFO', md)) options: Options,
.use(...createContainer('warning', 'WARNING', md)) containerOptions?: ContainerOptions
.use(...createContainer('danger', 'DANGER', md)) ) => {
.use(...createContainer('details', 'Details', md)) md.use(...createContainer('tip', containerOptions?.tipLabel || 'TIP', md))
.use(...createContainer('info', containerOptions?.infoLabel || 'INFO', md))
.use(
...createContainer(
'warning',
containerOptions?.warningLabel || 'WARNING',
md
)
)
.use(
...createContainer(
'danger',
containerOptions?.dangerLabel || 'DANGER',
md
)
)
.use(
...createContainer(
'details',
containerOptions?.detailsLabel || 'Details',
md
)
)
// explicitly escape Vue syntax // explicitly escape Vue syntax
.use(container, 'v-pre', { .use(container, 'v-pre', {
render: (tokens: Token[], idx: number) => render: (tokens: Token[], idx: number) =>
@ -104,3 +126,11 @@ function createCodeGroup(options: Options): ContainerArgs {
} }
] ]
} }
export interface ContainerOptions {
infoLabel?: string
tipLabel?: string
warningLabel?: string
dangerLabel?: string
detailsLabel?: string
}

Loading…
Cancel
Save