import MarkdownIt from 'markdown-it' import Token from 'markdown-it/lib/token' const container = require('markdown-it-container') export const containerPlugin = (md: MarkdownIt) => { md.use(...createContainer('tip', 'TIP')) .use(...createContainer('warning', 'WARNING')) .use(...createContainer('danger', 'WARNING')) // explicitly escape Vue syntax .use(container, 'v-pre', { render: (tokens: Token[], idx: number) => tokens[idx].nesting === 1 ? `
\n` : `
\n` }) } type ContainerArgs = [ typeof container, string, { render(tokens: Token[], idx: number): string } ] function createContainer(klass: string, defaultTitle: string): ContainerArgs { return [ container, klass, { render(tokens, idx) { const token = tokens[idx] const info = token.info.trim().slice(klass.length).trim() if (token.nesting === 1) { return `

${ info || defaultTitle }

\n` } else { return `
\n` } } } ] }