# Advanced Neutrino Customization No two JavaScript projects are ever the same, and as such there may be times when you will need to make modifications to the way your Neutrino preset is building your project. If you need more customization than can be afforded by augmenting your project's package.json, consider using this advanced configuration guide to modify your build as needed. ## Creating a project-specific preset Neutrino configurations are backed by [webpack-chain](https://github.com/mozilla-neutrino/webpack-chain/tree/v1.4.3), a library for making modifications to a Webpack configuration using a fluent or chained API. When your project needs more advanced build overrides, you will be interacting with this API in order to perform modifications. First, we need to create a project-specific preset to make these changes. This can either be a JS file or a directory with an `index.js` file. Since Neutrino uses Node.js and Webpack for interacting with presets, it is helpful to understand that this is a Node.js module. By exporting a function from your module, you will be provided with a Neutrino instance for modifying the build. Let's create a file called `neutrino-custom.js` in the root of our example project: ```js // neutrino-custom.js module.exports = neutrino => { // ... }; ``` At the moment our custom configurator isn't doing anything, but it does get us far enough to be able to tell Neutrino to use it for additional configuration. Modify your package.json and add `neutrino-custom.js` as an additional preset. _Note: Neutrino will attempt to load this module relative to the current working directory, which should be the root of your project._ ```json { "config": { "presets": [ "neutrino-preset-react", "neutrino-preset-karma", "neutrino-custom.js" ] }, "scripts": { "build": "neutrino build" } } ``` Other than actually changing the config, that is all the setup necessary for Neutrino to pick up your custom changes. ## Configuring The Neutrino instance provided to your custom configurator has a `config` property that is an instance of [webpack-chain](https://github.com/mozilla-neutrino/webpack-chain/tree/v1.4.3). We won't go in-depth of all the configuration possibilities here, but encourage you to check out the documentation for webpack-chain for instruction on your particular use case. This `neutrino.config` is an accumulation of all configuration set up to this moment. Every Neutrino preset interacts with and makes changes through this config, which is all available to you. For example, if you are using the presets `neutrino-preset-react` and `neutrino-preset-karma`, any options set can be extended, manipulated, or removed. _Example: Neutrino's React preset adds `.jsx` as a module extension. Let's remove it._ ```js module.exports = neutrino => { neutrino.config.resolve.extensions.delete('.jsx'); }; ``` _Example: Neutrino's Node.js preset uses `babel-preset-env` to support Node.js v6.9. Let's change it to support back to v4.2. This preset has a rule named "compile" and a loader named "babel"._ ```js module.exports = neutrino => { neutrino.config.module .rule('compile') .loader('babel', ({ options }) => { options.presets[0][1].targets.node = 4.2; return { options }; }); }; ``` Presets can also have their own custom data in addition to the Neutrino config. See your respective preset for details. Again, rather than reiterate the documentation for [webpack-chain](https://github.com/mozilla-neutrino/webpack-chain/tree/v1.4.3) here, please refer to its documentation for all ways you can modify a config instance to solve your use cases.