You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ant-design-vue/site/components/md.vue

53 lines
1020 B

7 years ago
<template>
<div v-html="marked(text)" class="markdown" />
</template>
<script>
import marked from 'marked'
import { isZhCN } from '../util'
7 years ago
var renderer = new marked.Renderer();
renderer.heading = function(text, level) {
return '<h'
+ level
+ ' id="'
+ text.replace(/[^\w]+/g, '-')
+ '">'
+ text
+ '</h'
+ level
+ '>\n';
};
7 years ago
marked.setOptions({
7 years ago
renderer,
7 years ago
gfm: true,
tables: true,
breaks: true,
pedantic: true,
sanitize: true,
smartLists: true,
smartypants: true,
})
export default {
name: 'md',
props: {
cn: String,
us: String,
},
data () {
const { name } = this.$route.params
let text = ''
const { cn, us } = this
if (this.$slots.default && this.$slots.default[0] && this.$slots.default[0].text) {
text = this.$slots.default[0].text
} else {
text = isZhCN(name) ? cn : us
}
text = text || ''
text = text.split('\n').map(t => t.trim()).join('\n')
return {
marked,
text,
}
},
}
</script>