From c35e3b1727fb603277eafd15ffabb9bf8ebf97ce Mon Sep 17 00:00:00 2001 From: "qingwei.li" Date: Sat, 10 Feb 2018 19:31:49 +0800 Subject: [PATCH] refactor: embed files feature, resolve #383, resolve #333, resolve #134 --- src/core/render/compiler.js | 47 +++++++++++++++++++++---------------- 1 file changed, 27 insertions(+), 20 deletions(-) diff --git a/src/core/render/compiler.js b/src/core/render/compiler.js index c3704a9aa..a569bfde7 100644 --- a/src/core/render/compiler.js +++ b/src/core/render/compiler.js @@ -58,7 +58,7 @@ const compileMedia = { const id = `docsify-get-${uid++}` let ext = url.match(/\.(\w+)$/) - ext = config.ext || (ext && ext[1]) + ext = config.lang || (ext && ext[1]) if (ext === 'md') ext = 'markdown' if (!process.env.SSR) { @@ -182,6 +182,32 @@ export class Compiler { const { str, config } = getAndRemoveConfig(title) title = str + if (config.include) { + if (!isAbsolutePath(href)) { + href = getPath(contentBase, href) + } + + let media + if (config.type && (media = compileMedia[config.type])) { + return media.call(_self, href, title) + } + + let type = null + if (/\.(md|markdown)/.test(href)) { + type = 'markdown' + } else if (/\.html?/.test(href)) { + type = 'html' + } else if (/\.(mp4|ogg)/.test(href)) { + type = 'video' + } else if (/\.mp3/.test(href)) { + type = 'audio' + } + console.log(href) + if (type) { + return compileMedia[type].call(_self, href, title) + } + } + if ( !/:|(\/{2})/.test(href) && !_self.matchNotCompileLink(href) && @@ -235,25 +261,6 @@ export class Compiler { url = getPath(contentBase, href) } - let media - if (config.type && (media = compileMedia[config.type])) { - return media.call(_self, url, title) - } - - let type = null - if (/\.(md|markdown)/.test(url)) { - type = 'markdown' - } else if (/\.html?/.test(url)) { - type = 'html' - } else if (/\.(mp4|ogg)/.test(url)) { - type = 'video' - } else if (/\.mp3/.test(url)) { - type = 'audio' - } - if (type) { - return compileMedia[type].call(_self, url, title) - } - return `${text}` }