2024-01-30 14:46:01 +00:00
|
|
|
<template>
|
|
|
|
<!-- eslint-disable-next-line vue/no-v-html -->
|
|
|
|
<div v-html="render" />
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import showdown from 'showdown'
|
|
|
|
|
2024-01-30 15:36:16 +00:00
|
|
|
const classMap = {
|
2024-01-30 15:46:57 +00:00
|
|
|
blockquote: 'blockquote',
|
2024-01-30 15:36:16 +00:00
|
|
|
table: 'table',
|
|
|
|
}
|
|
|
|
|
|
|
|
const htmlClassBindings = Object.keys(classMap)
|
|
|
|
.map(key => ({
|
|
|
|
regex: new RegExp(`<${key}(.*)>`, 'g'),
|
|
|
|
replace: `<${key} class="${classMap[key]}" $1>`,
|
|
|
|
type: 'output',
|
|
|
|
}))
|
|
|
|
|
2024-01-30 14:46:01 +00:00
|
|
|
export default {
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
render: '',
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
emits: ['rendered'],
|
|
|
|
|
|
|
|
name: 'WikiMarkdown',
|
|
|
|
|
|
|
|
props: {
|
|
|
|
content: {
|
|
|
|
default: '',
|
|
|
|
type: String,
|
|
|
|
},
|
|
|
|
|
|
|
|
prerender: {
|
|
|
|
default: null,
|
|
|
|
type: Function,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
watch: {
|
|
|
|
content(to) {
|
|
|
|
let content = to
|
|
|
|
if (this.prerender) {
|
|
|
|
content = this.prerender(content)
|
|
|
|
}
|
|
|
|
|
2024-01-30 15:01:13 +00:00
|
|
|
const converter = new showdown.Converter({
|
2024-01-30 15:36:16 +00:00
|
|
|
extensions: [...htmlClassBindings],
|
2024-01-30 15:01:13 +00:00
|
|
|
tables: true,
|
|
|
|
})
|
|
|
|
converter.setFlavor('github')
|
2024-01-30 14:46:01 +00:00
|
|
|
this.render = converter.makeHtml(content)
|
|
|
|
this.$emit('rendered')
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
</script>
|
2024-01-30 15:46:57 +00:00
|
|
|
|
|
|
|
<style>
|
|
|
|
.blockquote {
|
|
|
|
margin-bottom: 1rem;
|
|
|
|
font-size: 1rem;
|
|
|
|
border-left: 3px solid rgb(var(--bs-secondary-bg-rgb));
|
|
|
|
padding-left: 0.5rem;
|
|
|
|
}
|
|
|
|
</style>
|