metalsmith-uglify v2.4.3
metalsmith-uglify
This is an UglifyJS plugin for Metalsmith and is a successor to the original plugin written by Keith Smith.
Usage
Install the package:
npm install metalsmith-uglifyAdd the plugin to your Metalsmith build chain:
const metalsmith = require('metalsmith');
const uglify = require('metalsmith-uglify');
metalsmith(__dirname)
    .source('./src')
    .destination('./public')
    .use(uglify());
    .build(function (err) {
        if (err) {
            throw err;
        }
        console.log('Build complete');
    });Options
The plugin function accepts a configuration object as the first argument.
- {boolean} - options.es- Set to use- terserpackage instead of- uglify-js. It will set also set- options.uglify.ecma = 6by default.
- {object} - options.concat- Set to concatenate to a single bundle file.- {string} - options.concat.file- Name of the bundle file. Default is- scripts.min.js.
- {string} - options.concat.root- Directory where the bundle file will be placed. This option overrides- options.root.
 
- {Arraystring} - options.files- List of files to be processed. If- options.concatis set, files will be passed to UglifyJS in that order. This option is only needed for bundling badly written code (e.g. jQuery) that relies on files being processed in a certain order. This option overrides- options.filter.
- {function} - options.filter- Function to filter the list of JavaScript files. By default- .min.jsfiles are excluded.
- {string} - options.root- Set to limit the plugin to a specific source directory.
- {boolean} - options.removeOriginal- Set to exclude the original (unminified) file from the output directory.
- {boolean} - options.sameName- Set to keep minified name as is without adding- .min. This option overrides- options.removeOriginaland is ignored if- options.concatis set.
- {object} - options.uglify- UglifyJS configuration (see UglifyJS docs). Default is- { sourceMap: { includeSources: true } }.
- {boolean} - options.windows- Set this if you are using the plugin on Windows. If you are using any of the- rootoptions, you will need to use- \\instead of- /in the path.
Upgrading from version 1.x
Version 2 is a rewrite of the plugin with significant breaking changes to the options object.
Please refer to the upgrade document for more information.
Example
To build the example page run:
make exampleInspect files in example/ for more information.
Debug Logging
Set the DEBUG variable to see what the plugin is doing.
If you are troubleshooting the plugin itself then the following should be enough:
DEBUG=metalsmith-uglify:info:* node build.jsIf you think the problem is actually related to something UglifyJS does then you can get more detail:
DEBUG=metalsmith-uglify:* node build.js1 year ago
2 years ago
3 years ago
4 years ago
6 years ago
6 years ago
7 years ago
7 years ago
7 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
9 years ago
9 years ago
9 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
11 years ago
11 years ago
12 years ago
12 years ago
12 years ago
12 years ago
12 years ago
12 years ago