mirror of
https://github.com/facebook/docusaurus.git
synced 2025-05-28 08:27:03 +02:00
feat(webpack): add better log output
This commit is contained in:
parent
0bbe7fd999
commit
56dfec19ea
2 changed files with 49 additions and 18 deletions
38
lib/dev.js
38
lib/dev.js
|
@ -12,6 +12,7 @@ const serveStatic = require('koa-static');
|
||||||
const history = require('connect-history-api-fallback');
|
const history = require('connect-history-api-fallback');
|
||||||
const load = require('./loader');
|
const load = require('./loader');
|
||||||
const createDevConfig = require('./webpack/dev');
|
const createDevConfig = require('./webpack/dev');
|
||||||
|
const logPlugin = require('./webpack/plugin/log')
|
||||||
|
|
||||||
module.exports = async function dev(sourceDir, cliOptions = {}) {
|
module.exports = async function dev(sourceDir, cliOptions = {}) {
|
||||||
const logger = ora(chalk.blue('Start development server')).start();
|
const logger = ora(chalk.blue('Start development server')).start();
|
||||||
|
@ -19,21 +20,11 @@ module.exports = async function dev(sourceDir, cliOptions = {}) {
|
||||||
// load site props from preprocessed files in source directory
|
// load site props from preprocessed files in source directory
|
||||||
const props = await load(sourceDir);
|
const props = await load(sourceDir);
|
||||||
|
|
||||||
// Reload for any add/remove of file
|
// Reload for any add/change/remove of file
|
||||||
const reload = () => {
|
const reload = () => {
|
||||||
const reloadLogger = ora({
|
load(sourceDir).catch(err => {
|
||||||
color: 'green',
|
console.error(chalk.red(err.stack));
|
||||||
text: chalk.green('Reloading files')
|
});
|
||||||
}).start();
|
|
||||||
load(sourceDir)
|
|
||||||
.then(() => {
|
|
||||||
setTimeout(() => {
|
|
||||||
reloadLogger.stop();
|
|
||||||
}, 1000);
|
|
||||||
})
|
|
||||||
.catch(err => {
|
|
||||||
console.error(chalk.red(err.stack));
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
const fsWatcher = chokidar.watch(['**/*.md'], {
|
const fsWatcher = chokidar.watch(['**/*.md'], {
|
||||||
cwd: sourceDir,
|
cwd: sourceDir,
|
||||||
|
@ -48,20 +39,31 @@ module.exports = async function dev(sourceDir, cliOptions = {}) {
|
||||||
// resolve webpack config
|
// resolve webpack config
|
||||||
let config = createDevConfig(props);
|
let config = createDevConfig(props);
|
||||||
|
|
||||||
|
const port = cliOptions.port || 8080;
|
||||||
|
|
||||||
|
config
|
||||||
|
.plugin('blogi-log')
|
||||||
|
.use(logPlugin, [{
|
||||||
|
port,
|
||||||
|
publicPath: props.publicPath
|
||||||
|
}]);
|
||||||
|
|
||||||
// create compiler from generated webpack config
|
// create compiler from generated webpack config
|
||||||
config = config.toConfig();
|
config = config.toConfig();
|
||||||
const compiler = webpack(config);
|
const compiler = webpack(config);
|
||||||
logger.succeed();
|
logger.succeed();
|
||||||
|
|
||||||
// webpack-serve
|
// webpack-serve
|
||||||
const serveContentDir = path.resolve(__dirname, 'serveContent');
|
|
||||||
const port = cliOptions.port || 8080;
|
|
||||||
await serve(
|
await serve(
|
||||||
{},
|
{},
|
||||||
{
|
{
|
||||||
content: [serveContentDir],
|
content: [path.resolve(__dirname, 'serveContent')],
|
||||||
compiler,
|
compiler,
|
||||||
devWare: {logLevel: 'warn'},
|
open: true,
|
||||||
|
devMiddleware: {
|
||||||
|
logLevel: 'warn',
|
||||||
|
publicPath: props.publicPath
|
||||||
|
},
|
||||||
hotClient: {
|
hotClient: {
|
||||||
port: port + 1,
|
port: port + 1,
|
||||||
logLevel: 'error'
|
logLevel: 'error'
|
||||||
|
|
29
lib/webpack/plugin/log.js
Normal file
29
lib/webpack/plugin/log.js
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
const chalk = require('chalk');
|
||||||
|
const ora = require('ora');
|
||||||
|
module.exports = class LogPlugin {
|
||||||
|
constructor (options) {
|
||||||
|
this.options = options
|
||||||
|
}
|
||||||
|
|
||||||
|
apply (compiler) {
|
||||||
|
const logger = ora();
|
||||||
|
let isFirst = true
|
||||||
|
compiler.hooks.done.tap('blogi-log', stats => {
|
||||||
|
clearScreen()
|
||||||
|
|
||||||
|
const { port, publicPath } = this.options
|
||||||
|
const time = new Date().toTimeString().match(/^[\d:]+/)[0]
|
||||||
|
|
||||||
|
logger.succeed(`${chalk.gray(`[${time}]`)} Build ${chalk.yellow(stats.hash.slice(0, 6))} finished in ${chalk.green(stats.endTime - stats.startTime)} ms!`)
|
||||||
|
if (isFirst) {
|
||||||
|
isFirst = false
|
||||||
|
console.log(`\n${chalk.gray('>')} Blogi dev server listening at ${chalk.cyan(`http://localhost:${port}${publicPath}`)}`)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
compiler.hooks.invalid.tap('blogi-log', clearScreen)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function clearScreen () {
|
||||||
|
process.stdout.write('\x1Bc')
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue