2018-04-04 18:39:21 +08:00
|
|
|
<template>
|
2019-09-28 20:45:07 +08:00
|
|
|
<div class="markdown" v-html="marked(text)" />
|
2018-04-04 18:39:21 +08:00
|
|
|
</template>
|
|
|
|
<script>
|
2019-01-12 11:33:27 +08:00
|
|
|
import marked from 'marked';
|
|
|
|
import { isZhCN } from '../util';
|
|
|
|
const renderer = new marked.Renderer();
|
2019-09-28 20:45:07 +08:00
|
|
|
renderer.heading = function(text, level) {
|
|
|
|
return (
|
|
|
|
'<h' + level + ' id="' + text.replace(/[^\w]+/g, '-') + '">' + text + '</h' + level + '>\n'
|
|
|
|
);
|
2019-01-12 11:33:27 +08:00
|
|
|
};
|
2018-04-04 18:39:21 +08:00
|
|
|
marked.setOptions({
|
2018-04-07 17:38:39 +08:00
|
|
|
renderer,
|
2018-04-04 18:39:21 +08:00
|
|
|
gfm: true,
|
|
|
|
tables: true,
|
|
|
|
breaks: true,
|
|
|
|
pedantic: true,
|
|
|
|
sanitize: true,
|
|
|
|
smartLists: true,
|
|
|
|
smartypants: true,
|
2019-01-12 11:33:27 +08:00
|
|
|
});
|
2018-04-04 18:39:21 +08:00
|
|
|
export default {
|
2019-02-01 17:23:00 +08:00
|
|
|
name: 'Md',
|
2018-04-04 18:39:21 +08:00
|
|
|
props: {
|
|
|
|
cn: String,
|
|
|
|
us: String,
|
|
|
|
},
|
2018-07-13 21:55:29 +08:00
|
|
|
inject: {
|
2019-09-28 20:45:07 +08:00
|
|
|
demoContext: { default: {} },
|
2018-07-13 21:55:29 +08:00
|
|
|
},
|
2019-09-28 20:45:07 +08:00
|
|
|
data() {
|
2019-01-12 11:33:27 +08:00
|
|
|
let text = '';
|
|
|
|
const { cn, us } = this;
|
2018-04-04 18:39:21 +08:00
|
|
|
if (this.$slots.default && this.$slots.default[0] && this.$slots.default[0].text) {
|
2019-01-12 11:33:27 +08:00
|
|
|
text = this.$slots.default[0].text;
|
2018-04-04 18:39:21 +08:00
|
|
|
} else {
|
2019-01-12 11:33:27 +08:00
|
|
|
text = isZhCN(this.demoContext.name) ? cn : us;
|
2018-04-04 18:39:21 +08:00
|
|
|
}
|
2019-01-12 11:33:27 +08:00
|
|
|
text = text || '';
|
2019-09-28 20:45:07 +08:00
|
|
|
text = text
|
|
|
|
.split('\n')
|
|
|
|
.map(t => t.trim())
|
|
|
|
.join('\n');
|
2018-04-04 18:39:21 +08:00
|
|
|
return {
|
|
|
|
marked,
|
|
|
|
text,
|
2019-01-12 11:33:27 +08:00
|
|
|
};
|
2018-04-04 18:39:21 +08:00
|
|
|
},
|
2019-01-12 11:33:27 +08:00
|
|
|
};
|
2018-04-04 18:39:21 +08:00
|
|
|
</script>
|