Skip to content

Webpack plugin to filter output files based on the entry points.

Notifications You must be signed in to change notification settings

m3g4p0p/filter-entry-output-plugin

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 

Repository files navigation

filter-entry-output-plugin

Webpack plugin to filter output files based on the entry points.

Installation

yarn add filter-entry-output-plugin -D

Usage

Use the plugin to remove unwanted output files, such as JS stubs that are getting created when abusing webpack as a pure SASS compiler. For example, in the following scenario normally not only a theme.css but also a theme.js file would get emitted for the theme entry point; the plugin can be used to remove those unnecessary webpack bootstrap files from SCSS-only entry points:

// webpack.config.js
const MiniCssExtractPlugin = require('mini-css-extract-plugin')
const FilterEntryOutputPlugin = require('filter-entry-output-plugin')
const path = require('path')

module.exports = {
  entry: {
    main: './src/index.js',
    theme: './src/theme.scss'
  },
  output: {
    filename: '[name].js',
    path: path.join(__dirname, 'dist')
  },
  module: {
    rules: [{
      test: /\.scss$/,
      use: [
        MiniCssExtractPlugin.loader,
        'css-loader',
        'sass-loader'
      ]
    }]
  },
  plugins: [
    new MiniCssExtractPlugin({
      filename: '[name].css'
    }),
    new FilterEntryOutputPlugin({
      test: /\.scss$/,
      remove: /\.js$/,
    })
  ],
}

Options

  • test -- The entry files for which the output should get filtered.
    Type: RegExp
    Default: /\.(c|sc|sa)ss$/
  • remove -- The output files that should get removed, as specified in the filename options of the output and plugin configurations etc.
    Type: RegExp
    Default: /\.js$/
  • exclude -- Exclude entry files (overrides test).
    Type: RegExp|boolean
    Default: false
  • keep -- Output files to keep (overrides remove).
    Type: RegExp|boolean
    Default: false
  • multi -- Whether multi-main entry points should get filtered too.
    Type: boolean
    Default: false

Alternatives

You might also have a look at the FilterChunkWebpackPlugin for another approach based purely on output file patterns.

License

MIT @ m3g4p0p

About

Webpack plugin to filter output files based on the entry points.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published