Beautiful formatting for Webpack messages; ported from Create React App!
npm install webpack-format-messages> Beautiful formatting for Webpack messages; ported from Create React App!
The console output from CRA is very well-done! Unfortunately, the only way to use it is to install _all_ of react-dev-utils, which is quite a module-rich tree. While there is nothing wrong with this, many times I'd prefer a quick install for my custom Webpack configs (which aren't always React-related).
If you are already using react-dev-utils, you do not need this module and should do this instead:
``js`
const formatMessages = require('react-dev-utils/formatWebpackMessages');
#### Differences
The source code of this module is (nearly) a direct copy-paste of the original file. Only two modifications have been made:
1. The code has been tailored to run in a Node-specific environment --- the original can also be run in the browser.
2. The module input expects a Webpack stats object --- the original required a toJson() transformation
``
$ npm install webpack-format-messages --save-dev
`js
const webpack = require('webpack');
const formatMessages = require('webpack-format-messages');
// or
const { formatMessages } = require('webpack-format-messages');
const compiler = webpack(/ config /);
compiler.hooks.invalid.tap('invalid', function() {
console.log('Compiling...');
});
compiler.hooks.done.tap('done', (stats) => {
const messages = formatMessages(stats);
if (!messages.errors.length && !messages.warnings.length) {
console.log('Compiled successfully!');
}
if (messages.errors.length) {
console.log('Failed to compile.');
messages.errors.forEach(e => console.log(e));
return;
}
if (messages.warnings.length) {
console.log('Compiled with warnings.');
messages.warnings.forEach(w => console.log(w));
}
});
`
Extracts & prettifies warning and error messages from Webpack.
> Note: This is also the
default export.#### stats
Type:
Objectstats object.
$3
Returns: stringTransforms an individual webpack
stats message object into a string.> Note: You probably don't want to use this directly! It's used by
formatMessages for you.Related
webpack-messages -- Wraps this module as a Webpack plugin, with lifecycle hooks
Credits
react-dev-utils`, provided by Facebook Incubator.This package exists solely as a standalone install~!