Commit f0e45ece authored by NGPixel's avatar NGPixel

refactor: dev mode

parent 1be3234b
...@@ -19,10 +19,8 @@ module.exports = { ...@@ -19,10 +19,8 @@ module.exports = {
}, },
output: { output: {
path: path.join(process.cwd(), 'assets'), path: path.join(process.cwd(), 'assets'),
pathinfo: true,
filename: 'js/[name].js', filename: 'js/[name].js',
chunkFilename: 'js/[name].chunk.js', chunkFilename: 'js/[name].chunk.js'
publicPath: '/'
}, },
module: { module: {
rules: [ rules: [
...@@ -86,6 +84,7 @@ module.exports = { ...@@ -86,6 +84,7 @@ module.exports = {
loader: 'vue-loader', loader: 'vue-loader',
options: { options: {
extractCSS: true, extractCSS: true,
postcss: postCSSConfig,
loaders: { loaders: {
css: [ css: [
{ {
...@@ -93,10 +92,6 @@ module.exports = { ...@@ -93,10 +92,6 @@ module.exports = {
}, },
{ {
loader: 'css-loader' loader: 'css-loader'
},
{
loader: 'postcss-loader',
options: postCSSConfig
} }
], ],
scss: [ scss: [
...@@ -107,10 +102,6 @@ module.exports = { ...@@ -107,10 +102,6 @@ module.exports = {
loader: 'css-loader' loader: 'css-loader'
}, },
{ {
loader: 'postcss-loader',
options: postCSSConfig
},
{
loader: 'sass-loader', loader: 'sass-loader',
options: { options: {
sourceMap: false sourceMap: false
......
const webpack = require('webpack') const webpack = require('webpack')
const merge = require('webpack-merge') const merge = require('webpack-merge')
const path = require('path')
const ExtractTextPlugin = require('extract-text-webpack-plugin') const ExtractTextPlugin = require('extract-text-webpack-plugin')
const common = require('./webpack.common.js') const common = require('./webpack.common.js')
module.exports = merge(common, { module.exports = merge(common, {
module: { entry: {
rules: [] client: ['./client/index.js', 'webpack-hot-middleware/client']
},
output: {
pathinfo: true,
publicPath: '/'
}, },
plugins: [ plugins: [
new webpack.DefinePlugin({ new webpack.DefinePlugin({
'process.env.NODE_ENV': JSON.stringify('development') 'process.env.NODE_ENV': JSON.stringify('development')
}), }),
new ExtractTextPlugin({ disable: true }) new ExtractTextPlugin({ disable: true }),
new webpack.HotModuleReplacementPlugin(),
new webpack.WatchIgnorePlugin([
/node_modules/
])
], ],
resolve: {} watch: true
}) })
...@@ -7,10 +7,9 @@ ...@@ -7,10 +7,9 @@
"start": "node wiki start", "start": "node wiki start",
"stop": "node wiki stop", "stop": "node wiki stop",
"restart": "node wiki restart", "restart": "node wiki restart",
"build": "webpack --config dev/webpack/webpack.prod.js", "dev": "node wiki dev",
"build:analyze": "poi build --analyze", "build": "webpack --profile --config dev/webpack/webpack.prod.js",
"dev:client": "webpack --config dev/webpack/webpack.dev.js", "watch": "webpack --config dev/webpack/webpack.dev.js",
"dev:server": "nodemon",
"test": "eslint --ext .js,.vue . && jest" "test": "eslint --ext .js,.vue . && jest"
}, },
"bin": { "bin": {
...@@ -204,6 +203,7 @@ ...@@ -204,6 +203,7 @@
"vuex-persistedstate": "2.4.2", "vuex-persistedstate": "2.4.2",
"webpack": "3.10.0", "webpack": "3.10.0",
"webpack-bundle-analyzer": "2.9.2", "webpack-bundle-analyzer": "2.9.2",
"webpack-hot-middleware": "2.21.0",
"webpack-merge": "4.1.1", "webpack-merge": "4.1.1",
"whatwg-fetch": "2.0.3" "whatwg-fetch": "2.0.3"
}, },
......
...@@ -17,8 +17,6 @@ let wiki = { ...@@ -17,8 +17,6 @@ let wiki = {
} }
global.wiki = wiki global.wiki = wiki
process.env.VIPS_WARNING = false
// if (wiki.IS_DEBUG) { // if (wiki.IS_DEBUG) {
// require('@glimpse/glimpse').init() // require('@glimpse/glimpse').init()
// } // }
......
...@@ -152,10 +152,10 @@ module.exports = async () => { ...@@ -152,10 +152,10 @@ module.exports = async () => {
wiki.logger.info(`HTTP Server on port: [ ${wiki.config.port} ]`) wiki.logger.info(`HTTP Server on port: [ ${wiki.config.port} ]`)
app.set('port', wiki.config.port) app.set('port', wiki.config.port)
let server = http.createServer(app) wiki.server = http.createServer(app)
server.listen(wiki.config.port) wiki.server.listen(wiki.config.port)
server.on('error', (error) => { wiki.server.on('error', (error) => {
if (error.syscall !== 'listen') { if (error.syscall !== 'listen') {
throw error throw error
} }
...@@ -173,7 +173,7 @@ module.exports = async () => { ...@@ -173,7 +173,7 @@ module.exports = async () => {
} }
}) })
server.on('listening', () => { wiki.server.on('listening', () => {
wiki.logger.info('HTTP Server: [ RUNNING ]') wiki.logger.info('HTTP Server: [ RUNNING ]')
}) })
......
...@@ -64,7 +64,9 @@ module.exports = { ...@@ -64,7 +64,9 @@ module.exports = {
}) })
cluster.on('exit', (worker, code, signal) => { cluster.on('exit', (worker, code, signal) => {
wiki.logger.info(`Background Worker #${worker.id} was terminated.`) if (!global.DEV) {
wiki.logger.info(`Background Worker #${worker.id} was terminated.`)
}
}) })
}, },
/** /**
......
...@@ -61,7 +61,6 @@ module.exports = Promise.join( ...@@ -61,7 +61,6 @@ module.exports = Promise.join(
// ---------------------------------------- // ----------------------------------------
process.on('disconnect', () => { process.on('disconnect', () => {
wiki.logger.warn('Lost connection to Master. Exiting...')
process.exit() process.exit()
}) })
}) })
...@@ -11,6 +11,7 @@ const fs = Promise.promisifyAll(require('fs-extra')) ...@@ -11,6 +11,7 @@ const fs = Promise.promisifyAll(require('fs-extra'))
const pm2 = Promise.promisifyAll(require('pm2')) const pm2 = Promise.promisifyAll(require('pm2'))
const ora = require('ora') const ora = require('ora')
const path = require('path') const path = require('path')
const cluster = require('cluster')
const ROOTPATH = process.cwd() const ROOTPATH = process.cwd()
...@@ -61,10 +62,47 @@ const init = { ...@@ -61,10 +62,47 @@ const init = {
* Restart Wiki.js process(es) * Restart Wiki.js process(es)
*/ */
restart: function () { restart: function () {
let self = this return this.stop().delay(1000).then(() => {
return self.stop().delay(1000).then(() => { this.start()
self.startDetect()
}) })
},
dev() {
if (cluster.isMaster) {
const webpackConfig = require('./dev/webpack/webpack.dev.js')
const webpack = require('webpack')
const chokidar = require('chokidar')
let isWebpackInit = false
global.DEV = true
global.WP = webpack(webpackConfig, (err, stats) => {
if (!isWebpackInit) {
isWebpackInit = true
require('./server')
const devWatcher = chokidar.watch('./server')
devWatcher.on('ready', () => {
devWatcher.on('all', () => {
console.warn('--- >>>>>>>>>>>>>>>>>>>>>>>>>>>> ---')
console.warn('--- Changes detected: Restarting ---')
console.warn('--- <<<<<<<<<<<<<<<<<<<<<<<<<<<< ---')
global.wiki.server.close(() => {
global.wiki = {}
for (const workerId in cluster.workers) {
cluster.workers[workerId].kill()
}
Object.keys(require.cache).forEach(function(id) {
if (/[/\\]server[/\\]/.test(id)) delete require.cache[id]
})
require('./server')
})
})
})
}
})
} else {
require('./server')
}
} }
} }
...@@ -94,6 +132,13 @@ require('yargs') // eslint-disable-line no-unused-expressions ...@@ -94,6 +132,13 @@ require('yargs') // eslint-disable-line no-unused-expressions
init.restart() init.restart()
} }
}) })
.command({
command: 'dev',
desc: 'Start in Developer Mode',
handler: argv => {
init.dev()
}
})
.recommendCommands() .recommendCommands()
.demandCommand(1, 'You must provide one of the accepted commands above.') .demandCommand(1, 'You must provide one of the accepted commands above.')
.help() .help()
......
This diff was suppressed by a .gitattributes entry.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment