const path = require('path'); const loaderUtils = require('loader-utils'); const frontMatter = require('front-matter'); const parser = require('./md-parser'); const linkOpen = require('./link-open'); const cardWrapper = require('./card-wrapper'); const extractDemo = require('./extract-demo'); const sideEffectTags = require('./side-effect-tags'); function camelize(str) { return `-${str}`.replace(/-(\w)/g, (_, c) => (c ? c.toUpperCase() : '')); } const sharedVueOptions = `mounted() { const anchors = [].slice.call(this.$el.querySelectorAll('h2, h3, h4, h5')); anchors.forEach(anchor => { anchor.addEventListener('click', this.scrollToAnchor); }); }, methods: { scrollToAnchor(event) { if (event.target.id) { this.$router.push({ name: this.$route.name, hash: '#' + event.target.id }) } } }, `; function wrapper(content) { let demoLinks; [content, demoLinks] = extractDemo.call(this, content); content = cardWrapper(content); // 不包含 demo-code 的 md 文件,直接使绑定 HTML if (demoLinks.length === 0) { content = escape(content); return ` `; } // 包含 demo-code 的 md 文件,需要走模版渲染 let styles; [content, styles] = sideEffectTags(content); return ` ${styles.join('\n')} `; } module.exports = function (source) { let options = loaderUtils.getOptions(this) || {}; this.cacheable && this.cacheable(); options = { wrapper, linkOpen: true, ...options, }; let fm; if (options.enableMetaData) { fm = frontMatter(source); source = fm.body; } if (options.linkOpen) { linkOpen(parser); } return options.wrapper.call(this, parser.render(source), fm); };