aboutsummaryrefslogtreecommitdiff
path: root/node_modules/vuepress/lib/webpack/createServerConfig.js
diff options
context:
space:
mode:
Diffstat (limited to 'node_modules/vuepress/lib/webpack/createServerConfig.js')
-rw-r--r--node_modules/vuepress/lib/webpack/createServerConfig.js58
1 files changed, 58 insertions, 0 deletions
diff --git a/node_modules/vuepress/lib/webpack/createServerConfig.js b/node_modules/vuepress/lib/webpack/createServerConfig.js
new file mode 100644
index 00000000..e9f09835
--- /dev/null
+++ b/node_modules/vuepress/lib/webpack/createServerConfig.js
@@ -0,0 +1,58 @@
+module.exports = function createServerConfig (options, cliOptions) {
+ const fs = require('fs')
+ const path = require('path')
+ const WebpackBar = require('webpackbar')
+ const createBaseConfig = require('./createBaseConfig')
+ const VueSSRServerPlugin = require('vue-server-renderer/server-plugin')
+ const CopyPlugin = require('copy-webpack-plugin')
+
+ const config = createBaseConfig(options, cliOptions, true /* isServer */)
+ const { sourceDir, outDir } = options
+
+ config
+ .target('node')
+ .externals([/^vue|vue-router$/])
+ .devtool('source-map')
+
+ // no need to minimize server build
+ config.optimization.minimize(false)
+
+ config
+ .entry('app')
+ .add(path.resolve(__dirname, '../app/serverEntry.js'))
+
+ config.output
+ .filename('server-bundle.js')
+ .libraryTarget('commonjs2')
+
+ config
+ .plugin('ssr-server')
+ .use(VueSSRServerPlugin, [{
+ filename: 'manifest/server.json'
+ }])
+
+ const publicDir = path.resolve(sourceDir, '.vuepress/public')
+ if (fs.existsSync(publicDir)) {
+ config
+ .plugin('copy')
+ .use(CopyPlugin, [[
+ { from: publicDir, to: outDir }
+ ]])
+ }
+
+ if (!cliOptions.debug) {
+ config
+ .plugin('bar')
+ .use(WebpackBar, [{
+ name: 'Server',
+ color: 'blue',
+ compiledIn: false
+ }])
+ }
+
+ if (options.siteConfig.chainWebpack) {
+ options.siteConfig.chainWebpack(config, true /* isServer */)
+ }
+
+ return config
+}