Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/marella/webpack-setup
[DEPRECATED] Webpack config simplified.
https://github.com/marella/webpack-setup
babel config react sass webpack
Last synced: about 1 month ago
JSON representation
[DEPRECATED] Webpack config simplified.
- Host: GitHub
- URL: https://github.com/marella/webpack-setup
- Owner: marella
- License: mit
- Created: 2017-07-16T15:50:56.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2021-06-08T20:59:58.000Z (over 3 years ago)
- Last Synced: 2024-12-07T18:28:20.861Z (about 2 months ago)
- Topics: babel, config, react, sass, webpack
- Language: JavaScript
- Homepage:
- Size: 27.3 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# webpack-setup
[Webpack config] simplified.
- [Installation](#installation)
- [Example](#example)
- [Documentation](#documentation)
- [Available Methods](#available-methods)
- [Custom Config](#custom-config)
- [License](#license)## Installation
```bash
npm install --save-dev webpack-setup
```## Example
*webpack.config.js*
```js
const setup = require('webpack-setup')setup
.init({
output: 'build',
})
.js('src/index.js', 'js')
.eslint('src', { 'extends': 'eslint:recommended' })
.babel('src', { presets: ['es2015'] })
.sass('src/styles', 'css')module.exports = setup.config
```## Documentation
The first method `init()` initializes the config object using the provided `settings`. Rest of the methods update the config object by adding rules, loaders, plugins etc. The `setup.config` is the webpack config object that should be exported at the end.
Default `settings`:
```js
{
base: '/', // base public path on server where you will host the application
bundles: [], // names passed to CommonsChunkPlugin
env: process.env.NODE_ENV, // 'development' or 'production'
main: 'app', // key name for main entry point NOT the actual file path
modules: [], // to resolve absolute imports
output: 'build', // directory to save the final build
polyfill: false, // when true uses 'babel-polyfill' or you can provide a file path to your custom polyfill
production: process.env.NODE_ENV === 'production', // when true runs some optimizations which can be slow for development
versioning: process.env.NODE_ENV === 'production', // when true adds [hash] to output filenames. useful for cache busting on production but can be slow for development
sourcemaps: process.env.NODE_ENV === 'production' ? false : 'cheap-module-source-map', // whether to generate sourcemaps or not
}
```### Available Methods
#### `babel(src, options = {})`
Configures `babel-loader` to compile JS files. `src` specifies the directory paths to include for compilation. `options` object is passed as `babel-loader` options.
```js
setup
.babel('src', { presets: ['es2015'] })
```#### `copy(patterns, options = {})`
Copies files and directories using `copy-webpack-plugin`. `patterns` array and `options` object are passed to the plugin.
```js
setup
.copy([{ from: 'public' }])
```#### `define(globals = {})`
List of globals passed to `DefinePlugin`. `process.env.NODE_ENV` is automatically set.
```js
setup
.define({
'process.env': { NODE_ENV: JSON.stringify(process.env.NODE_ENV) },
})
```#### `eslint(src, options = {})`
Configures `eslint-loader` for JS files. `src` specifies the directory paths to include for linting. `options` object is passed as `eslint-loader` options.
```js
setup
.eslint('src', { 'extends': 'eslint:recommended' })
```#### `externals(externals)`
Dependencies to exclude from output bundles.
```js
setup
.externals({
jquery: 'jQuery',
})
```#### `fonts(dst, options = {})`
Configures `file-loader` to load fonts. `dst` specifies the output directory of font files relative to the `settings.output` directory. `options` object is passed as `file-loader` options.
```js
setup
.fonts('fonts')
```#### `hot()`
Enables HMR using `HotModuleReplacementPlugin`.
```js
setup
.hot()
```#### `html(src, options = {})`
Specify the file using `src` that should be loaded using `html-webpack-plugin`. `options` object is passed to the plugin.
```js
setup
.html('public/index.html')
```#### `images(dst, options = {})`
Configures `file-loader` to load images. `dst` specifies the output directory of image files relative to the `settings.output` directory. `options` object is passed as `file-loader` options.
```js
setup
.images('img')
```#### `init(settings = {})`
The first method that should be called to initialize the config object.
```js
setup
.init({
output: 'build',
})
```#### `js(src, dst)`
Specify the entry point using `src` and output directory of compiled JS files using `dst`. Output directory is relative to the `settings.output` directory.
```js
setup
.js('src/index.js', 'js')
```#### `notify(options = {})`
Configures `WebpackNotifierPlugin` using `options` object. Displays a desktop notification after every compilation.
```js
setup
.notify()
```#### `react(src, options = {})`
Configures `babel-loader` to compile ES6 and JSX syntax. `src` specifies the directory paths to include for compilation. `options` object is passed as `babel-loader` options.
```js
setup
.react('src')
```#### `sass(src, dst, options = {})`
Configures `sass-loader` using `src` as `includePaths` and `dst` as output directory of compiled CSS files. Output directory is relative to the `settings.output` directory. `options` object is passed as `sass-loader` options. Styles are separated from `js` files using `extract-text-webpack-plugin`.
```js
setup
.sass('src/styles', 'css')
```#### `server(options = {})`
Configures `webpack-dev-server` using `options` object.
```js
setup
.server()
```#### `settings(values = {})`
Overrides the initial `settings` with provided `values`. Methods called before `settings()` are not affected.
```js
setup
.first()
.settings({
foo: 'bar'
})
// this affects only second() and third() NOT first() as it was already called
.second()
.third()
```#### `uglify(options = {})`
Configures `UglifyJsPlugin` using `options` object.
```js
setup
.uglify()
```#### `vendors(vendors = [])`
List of modules that should be bundled into a separate `vendor.js` file.
```js
setup
.vendors([
'react',
'react-dom',
])
```#### `when(env, match = true)`
Useful for writing environment specific config using `process.env.NODE_ENV`. `match` denotes whether it should match or shouldn't match.
```js
setup
.when('development')
.server() // called only when env is development
.hot() // called only when env is development.when('production')
.uglify() // called only when env is production.when('any')
.notify() // called always.when('production', false)
.notify() // called only when env is NOT production
```### Custom Config
You may modify the config object before exporting to add custom rules or plugins that are not provided by `webpack-setup`:
```js
const { config } = setup// Add custom rules or plugins here.
module.exports = config
```## License
[MIT][license]
[license]: /LICENSE
[Webpack config]: https://webpack.js.org/configuration/