Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/developit/modify-babel-preset
:dizzy: Create a modified babel preset based on an an existing preset.
https://github.com/developit/modify-babel-preset
babel babel-plugin babel-preset
Last synced: 1 day ago
JSON representation
:dizzy: Create a modified babel preset based on an an existing preset.
- Host: GitHub
- URL: https://github.com/developit/modify-babel-preset
- Owner: developit
- Created: 2016-01-10T03:22:30.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2018-07-04T11:46:01.000Z (over 6 years ago)
- Last Synced: 2025-01-20T02:56:15.669Z (4 days ago)
- Topics: babel, babel-plugin, babel-preset
- Language: JavaScript
- Homepage: http://npm.im/modify-babel-preset
- Size: 29.3 KB
- Stars: 85
- Watchers: 5
- Forks: 8
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# modify-babel-preset
[![npm](https://img.shields.io/npm/v/modify-babel-preset.svg)](http://npm.im/modify-babel-preset)
[![npm](https://img.shields.io/npm/dm/modify-babel-preset.svg)](http://npm.im/modify-babel-preset)
[![travis](https://travis-ci.org/developit/modify-babel-preset.svg?branch=master)](https://travis-ci.org/developit/modify-babel-preset)Create a modified babel preset based on an an existing preset.
> Works best with `npm 3`.
```sh
npm i -S modify-babel-preset
```---
- [API](#api)
- [Add/Update Plugins](#addupdate-plugins)
- [Remove Plugins](#remove-plugins)
- [Example](#example)---
## API
A single function that takes an existing preset name and a mapping of plugin modifications to apply to that preset. _Make sure you have the preset and any added plugins installed as dependencies._
```js
newPreset = modifyBabelPreset(
'existing-preset-name',
{
'plugin-name': false, // remove
'other-plugin': true, // add
'foo': { loose:true } // add + config
}
);
```> Modification keys are babel plugin names _(you can exclude the `babel-plugin-` prefix)._
### Add/Update Plugins
To add a plugin, pass `true`, or a configuration object:
```js
{
// just add a plugin without config:
'plugin-name': true,// add a plugin and set its config
'other-plugin': { loose:true }
}
```> **Note:** adding a plugin that is already provided by the preset just overwrites its configuration.
### Remove Plugins
To remove a plugin, pass `false`:
```js
{
'plugin-name': false
}
```---
## Example
Here's a simple preset. Just this `index.js` and a package.json pointing to it with the preset and plugin installed as dependencies.
```js
var modifyBabelPreset = require('modify-babel-preset');// just export the cloned, modified preset config:
module.exports = modifyBabelPreset('es2015', {// remove the typeof x==='symbol' transform:
'transform-es2015-typeof-symbol': false,// add the JSX transform:
'transform-react-jsx': true});
```