')
.replace('', '')
}
};
const md = require('markdown-it')('default', {
html: true,
breaks: true,
highlight: renderHighlight,
})
// md.renderer.rules.fence = wrap(md.renderer.rules.fence)
const cnReg = new RegExp('<(cn)(?:[^<]|<)+\\1>', 'g')
const usReg = new RegExp('<(us)(?:[^<]|<)+\\1>', 'g')
md.core.ruler.push('update_template', function replace ({ tokens }) {
let cn = ''
let us = ''
let template = ''
let script = ''
let style = ''
let code = ''
tokens.forEach(token => {
if (token.type === 'html_block') {
if (token.content.match(cnReg)) {
cn = fetch(token.content, 'cn')
token.content = ''
}
if (token.content.match(usReg)) {
us = fetch(token.content, 'us')
token.content = ''
}
}
if (token.type === 'fence' && token.info === 'html' && token.markup === '```') {
code = '````html\n' + token.content + '````'
template = fetch(token.content, 'template')
script = fetch(token.content, 'script')
style = fetch(token.content, 'style')
token.content = ''
token.type = 'html_block'
}
})
if (template) {
let jsfiddle = {
html: template,
script,
style,
}
jsfiddle = md.utils.escapeHtml(JSON.stringify(jsfiddle))
const codeHtml = code ? md.render(code) : ''
const cnHtml = cn ? md.render(cn) : ''
const newContent = `
${template}
${cnHtml}
${us ? md.render(us) : ''}
${codeHtml}
`
const t = new Token('html_block', '', 0)
t.content = newContent
tokens.push(t)
}
})
module.exports = {
entry: {
index: [
'./examples/index.js',
],
},
module: {
rules: [
{
test: /\.md/,
use: [
{
loader: 'vue-antd-md-loader',
options: Object.assign(md, { wrapper: 'div' }),
},
],
},
{
test: /\.vue$/,
loader: 'vue-loader',
},
{
test: /\.js$/,
loader: 'babel-loader', exclude: /node_modules/,
},
{
test: /\.(png|jpg|gif|svg)$/,
loader: 'file-loader',
options: {
name: '[name].[ext]?[hash]',
},
},
],
},
resolve: {
extensions: ['.js', '.vue', '.md'],
alias: {
'vue$': 'vue/dist/vue.esm.js',
'antd': path.join(__dirname, 'components'),
'@': path.join(__dirname, ''),
},
},
}