From 9b3243b75752209943af5b247f5d38e641d4ff6d Mon Sep 17 00:00:00 2001 From: Evan You Date: Thu, 6 Jan 2022 18:23:01 +0800 Subject: [PATCH] fix: prioritize vue installed in user project root --- src/node/alias.ts | 15 +++++++++++++-- src/node/build/render.ts | 14 +++++++++++++- src/node/config.ts | 2 +- 3 files changed, 27 insertions(+), 4 deletions(-) diff --git a/src/node/alias.ts b/src/node/alias.ts index 7b7aff211503..f7ef31a64011 100644 --- a/src/node/alias.ts +++ b/src/node/alias.ts @@ -14,13 +14,24 @@ export const DEFAULT_THEME_PATH = path.join(DIST_CLIENT_PATH, 'theme-default') export const SITE_DATA_ID = '@siteData' export const SITE_DATA_REQUEST_PATH = '/' + SITE_DATA_ID -export function resolveAliases(themeDir: string): AliasOptions { +const vueRuntimePath = 'vue/dist/vue.runtime.esm-bundler.js' + +export function resolveAliases(root: string, themeDir: string): AliasOptions { const paths: Record = { '/@theme': themeDir, '/@shared': SHARED_PATH, [SITE_DATA_ID]: SITE_DATA_REQUEST_PATH } + // prioritize vue installed in project root and fallback to + // vue that comes with vitepress itself. + let vuePath + try { + vuePath = require.resolve(vueRuntimePath, { paths: [root] }) + } catch (e) { + vuePath = require.resolve(vueRuntimePath) + } + const aliases: Alias[] = [ ...Object.keys(paths).map((p) => ({ find: p, @@ -40,7 +51,7 @@ export function resolveAliases(themeDir: string): AliasOptions { // vitepress itself { find: /^vue$/, - replacement: require.resolve('vue/dist/vue.runtime.esm-bundler.js') + replacement: vuePath } ] diff --git a/src/node/build/render.ts b/src/node/build/render.ts index 8bfe54d5beb7..e5e226e376e6 100644 --- a/src/node/build/render.ts +++ b/src/node/build/render.ts @@ -21,8 +21,20 @@ export async function renderPage( const routePath = `/${page.replace(/\.md$/, '')}` const siteData = resolveSiteDataByRoute(config.site, routePath) router.go(routePath) + // lazy require server-renderer for production build - const content = await require('vue/server-renderer').renderToString(app) + // prioritize project root over vitepress' own dep + let rendererPath + try { + rendererPath = require.resolve('vue/server-renderer', { + paths: [config.root] + }) + } catch (e) { + rendererPath = require.resolve('vue/server-renderer') + } + + // render page + const content = await require(rendererPath).renderToString(app) const pageName = page.replace(/\//g, '_') // server build doesn't need hash diff --git a/src/node/config.ts b/src/node/config.ts index 7a01377b20b6..7b337f547c5e 100644 --- a/src/node/config.ts +++ b/src/node/config.ts @@ -139,7 +139,7 @@ export async function resolveConfig( outDir, tempDir: resolve(root, '.temp'), markdown: userConfig.markdown, - alias: resolveAliases(themeDir), + alias: resolveAliases(root, themeDir), vue: userConfig.vue, vite: userConfig.vite, shouldPreload: userConfig.shouldPreload,