ant-design-vue/site/components/md.vue

52 lines
1.0 KiB
Vue
Raw Normal View History

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>