2019-12-22 15:31:04 +08:00
|
|
|
const hljs = require('highlight.js')
|
|
|
|
const marked = require('marked')
|
|
|
|
|
2019-12-22 23:19:08 +08:00
|
|
|
function createRenderer (wrapCodeWithCard = true) {
|
|
|
|
const renderer = new marked.Renderer()
|
|
|
|
const overrides = {
|
2020-02-20 16:26:34 +08:00
|
|
|
table (header, body) {
|
|
|
|
if (body) body = '<tbody class="n-table__tbody">' + body + '</tbody>'
|
2020-12-24 00:29:04 +08:00
|
|
|
return (
|
|
|
|
'<n-table single-column class="md-table">\n' +
|
2020-02-20 16:26:34 +08:00
|
|
|
'<thead class="n-table__thead">\n' +
|
|
|
|
header +
|
|
|
|
'</thead>\n' +
|
|
|
|
body +
|
|
|
|
'</n-table>\n'
|
2020-12-24 00:29:04 +08:00
|
|
|
)
|
2020-02-20 16:26:34 +08:00
|
|
|
},
|
|
|
|
|
|
|
|
tablerow (content) {
|
|
|
|
return '<tr class="n-table__tr">\n' + content + '</tr>\n'
|
|
|
|
},
|
|
|
|
|
|
|
|
tablecell (content, flags) {
|
|
|
|
const type = flags.header ? 'th' : 'td'
|
|
|
|
const tag = flags.align
|
2020-12-24 00:29:04 +08:00
|
|
|
? '<' +
|
|
|
|
type +
|
|
|
|
` class="n-table__${type}"` +
|
|
|
|
' align="' +
|
|
|
|
flags.align +
|
|
|
|
'">'
|
2020-02-20 16:26:34 +08:00
|
|
|
: '<' + type + ` class="n-table__${type}"` + '>'
|
|
|
|
return tag + content + '</' + type + '>\n'
|
|
|
|
},
|
|
|
|
|
2019-12-22 23:19:08 +08:00
|
|
|
code: (code, language) => {
|
|
|
|
const isLanguageValid = !!(language && hljs.getLanguage(language))
|
|
|
|
if (!isLanguageValid) {
|
2020-12-24 00:29:04 +08:00
|
|
|
throw new Error(
|
|
|
|
`MdRendererError: ${language} is not valid for code - ${code}`
|
|
|
|
)
|
2019-12-22 23:19:08 +08:00
|
|
|
}
|
2021-03-29 01:15:08 +08:00
|
|
|
const highlighted = hljs.highlight(code, { language }).value
|
2021-01-21 16:35:58 +08:00
|
|
|
const content = `<n-code><pre v-pre>${highlighted}</pre></n-code>`
|
2021-01-04 01:03:09 +08:00
|
|
|
return wrapCodeWithCard
|
|
|
|
? `<n-card size="small" class="md-card">${content}</n-card>`
|
|
|
|
: content
|
2019-12-22 23:19:08 +08:00
|
|
|
},
|
|
|
|
heading: (text, level) => {
|
|
|
|
const id = text.replace(/ /g, '-')
|
|
|
|
return `<n-h${level} id="${id}">${text}</n-h${level}>`
|
|
|
|
},
|
2020-12-24 00:29:04 +08:00
|
|
|
blockquote: (quote) => {
|
2019-12-22 23:19:08 +08:00
|
|
|
return `<n-blockquote>${quote}</n-blockquote>`
|
|
|
|
},
|
2020-11-03 15:10:29 +08:00
|
|
|
hr: () => '<n-hr />',
|
2020-12-24 00:29:04 +08:00
|
|
|
paragraph: (text) => {
|
2019-12-22 23:19:08 +08:00
|
|
|
return `<n-p>${text}</n-p>`
|
|
|
|
},
|
|
|
|
link (href, title, text) {
|
2021-01-02 16:33:23 +08:00
|
|
|
if (/^(http:|https:)/.test(href)) {
|
|
|
|
return `<n-a href="${href}" target="_blank">${text}</n-a>`
|
|
|
|
}
|
2020-01-23 17:24:48 +08:00
|
|
|
return `<n-a to="${href}" >${text}</n-a>`
|
2019-12-22 23:19:08 +08:00
|
|
|
},
|
|
|
|
list (body, ordered, start) {
|
2019-12-23 21:40:45 +08:00
|
|
|
const type = ordered ? 'n-ol' : 'n-ul'
|
2020-12-24 00:29:04 +08:00
|
|
|
const startatt = ordered && start !== 1 ? ' start="' + start + '"' : ''
|
2019-12-22 23:19:08 +08:00
|
|
|
return `<${type}${startatt}>\n` + body + `</${type}>\n`
|
|
|
|
},
|
|
|
|
listitem (text) {
|
|
|
|
return `<n-li>${text}</n-li>`
|
|
|
|
},
|
|
|
|
codespan (code) {
|
|
|
|
return `<n-text code>${code}</n-text>`
|
2020-01-30 23:35:57 +08:00
|
|
|
},
|
|
|
|
strong (text) {
|
|
|
|
return `<n-text strong>${text}</n-text>`
|
2020-11-16 02:12:03 +08:00
|
|
|
},
|
|
|
|
checkbox (checked) {
|
|
|
|
return `<n-checkbox :checked="${checked}" style="vertical-align: -2px; margin-right: 8px;" />`
|
2019-12-22 15:31:04 +08:00
|
|
|
}
|
|
|
|
}
|
2019-12-22 23:19:08 +08:00
|
|
|
|
2020-12-24 00:29:04 +08:00
|
|
|
Object.keys(overrides).forEach((key) => {
|
2019-12-23 21:40:45 +08:00
|
|
|
renderer[key] = overrides[key]
|
|
|
|
})
|
2019-12-22 23:19:08 +08:00
|
|
|
return renderer
|
2019-12-22 15:31:04 +08:00
|
|
|
}
|
|
|
|
|
2019-12-23 21:40:45 +08:00
|
|
|
module.exports = createRenderer
|