/webpack-bundler

Deprecated. A small wrapper for webpack.

Primary LanguageTypeScript

Webpack-Bundler

Deprecated.

A small package wrapped around webpack, used for dealing with bundling over bunches of webpack configurations.

This package contains some common code for starting webpack programatically. Webpack-dev-middleware & webpack-hot-middleware are integrated and middleware instances can be obtained easily.

Usage

In development mode, WebpackBundler uses webpack-dev-middleware & webpack-hot-middleware for any "non-node-targeted" configurations.

import WebpackBundler = require('bundler');
import webpackConf from '/path/to/webpack/configuration';

const bundler = new WebpackBundler({
  mode: 'development'
});

bundler.build()
  .then(() => {
    // webpack-dev-middleware & webpack-hot-middleware.
    const middlewares = builder.middlewares();
    // ...
  })

Options

  • mode - 'development' | 'production' | 'none'.

  • hot - True to enable webpack-hot-middleware.

  • logger - Defaults to webpack-log. Set to false to disable logging.

  • webpackConfs - A webpack configuration object or an array of webpack configs.

  • devMiddlewareOptions - Options that'll pass to webpack-dev-middleware.

  • hotMiddlewareOptions - Options that'll pass to webpack-hot-middleware.

  • hooks - Add your compiler hooks in this field, for example:

    new WebpackBundler({
      hooks: {
        compiler: {
          // Pass in an object here.
          done: {
            name: 'foo',        // Plugin name.
            tapType: 'tapAsync',// Tap type.
            handler(stats) {    // Handler.
              ...
            },
          },
    
          // Or simply just a handler.
          compile(compParam) {
            ...
          }
        }
      }
    });
    
    // which will be merged into compilation:
    compiler.hooks.done.tapAsync('foo', handler);
    compiler.hooks.compile.tap('a-random-string', afterEmit);

    If the given hooks do not exist, they'll fail silently.