This package is intended to help bootstrap and easily edit your Webpack config. I created it when I got annoyed reading webpack documenation every time I bootstrap a new project or need to update the configuration of the existing one.
Call the exported function webpackConfig()
with simple set of options (description TBD) and it will return a webpack configuration object which you can export from your webpack.config.js
to build a project with minimum efforts.
The in-depth documentation is on the way. In the meantime please read through the source code.
webpackConfig(options)
- options webpack target configuration options (see below)
Returns webpack target
Relative path to webpack target entry point. The value of this options is passed to webpack target entry
property as is.
See webpack docs for details
Type of target. This value is copied to target
property of resulting webpack target config. Besides that, it has
several other side effects:
"web"
in this type of target you can specify dependencies to be excluded from the output bundle usingoptions.externals
property."node"
automatically excludes allnode_modules
from output bundle using webpack-node-externals library. Seeoptions.whitelistNodeModules
for details on whitelisting some modules if needed. Also, setsconfig.node = {__dirname: false}
to preserve__dirname
constant values. See node.__dirname config for details.
Determines where to store resulting bundles.
The output directory path relative to CWD (current working directory).
Name of main output bundle e.g. "index.js"
Supports JSX files. Currently only works in TypeScript mode
If set to true, webpack is configured to build a TypeScript project, e.g. compile .ts
/.tsx
files using
awesome-typescript-loader
If specified, webpack is configured to process .css
files using css-loader
plugin. By default bundle file will contain code that will automatically insert compiled styles into DOM when needed.
As a result, all CSS styles will be packed into the same bundle with the rest of the code.
If set to "scss"
, webpack is configured to process .scss
files using
sass-loader plugin.
Name for extracted CSS style bundle. If specified, all CSS styles will be extract to a separated bundle file e.g.
"style.css"
and you would have to reference this bundle from your HTML code manually.
If set to true, will ignore any .css
/.scss
files. This option is useful if you want to build SSR (server-side
rendering) application on the backend side but don't want to compile same style twice in both client and server targets
This options determines the node_modules
which should not be excluded from output bundle in case of "node"
target type.
See webpack-node-externals
options.allowlist
documentation for details.
This options allows to copy certain files to output folder "as is". Expected value is a hash map where keys
represent from property and values could be either
to strings or
pattern objects with from
property omitted.
Example:
webpackConfig({
// ...
copy: {
"./ssl/server.{crt,key}": {to: "./ssl", flatten: true},
"./firebase/firebase-admin-cert.json": "./"
}
});
Hash map of dependencies which need to be excluded from the bundle. This options is available only for "web"
targets
and is handy when you want to include 3rd party (vendor) dependencies from CDN as already built assets. Under the hood
it utilizes webpack config externals
property in the following way (using
string values):
{
...
externals: [options.externals]
}
jsx
only works ints
mode e.g. whenoptions.ts === true