From eed8b034552759424d3ad15cbea8cd968006006a Mon Sep 17 00:00:00 2001 From: Dan Freeman Date: Mon, 10 Jul 2017 16:18:26 -0400 Subject: [PATCH] Include examples for where to put options Stemming from a conversation with @turbo87 in Slack last week, this updates the README to include specific examples of how to configure Babel options in an app, an engine, or a regular addon. --- README.md | 53 ++++++++++++++++++++++++++++++++++------------------- 1 file changed, 34 insertions(+), 19 deletions(-) diff --git a/README.md b/README.md index ff38ead6..75ceaab4 100755 --- a/README.md +++ b/README.md @@ -58,7 +58,7 @@ var app = new EmberApp({ ### Options There are a few different options that may be provided to ember-cli-babel. These options -are typically set in an apps `ember-cli-build.js` file, or in an addons `index.js`. +are typically set in an apps `ember-cli-build.js` file, or in an addon or engine's `index.js`. ```ts type BabelPlugin = string | [string, any] | [any, any]; @@ -91,6 +91,39 @@ interface EmberCLIBabelConfig { } ``` +The exact location you specify these options varies depending on the type of project you're working on. As a concrete example, to add `babel-plugin-transform-object-rest-spread` so that your project can use object rest/spread syntax, you would do something like this in an app: + +```js +// ember-cli-build.js +var app = new EmberApp(defaults, { + babel: { + plugins: ['transform-object-rest-spread'] + } +}); +``` + +In an engine: +```js +// index.js +module.exports = EngineAddon.extend({ + babel: { + plugins: ['transform-object-rest-spread'] + } +}); +``` + +In an addon: +```js +// index.js +module.exports = { + options: { + babel: { + plugins: ['transform-object-rest-spread'] + } + } +}; +``` + #### Polyfill Babel comes with a polyfill that includes a custom [regenerator runtime](https://github.com/facebook/regenerator/blob/master/runtime.js) @@ -160,24 +193,6 @@ You can add custom plugins to be used during transpilation of the `addon/` or `a trees by ensuring that your addon's `options.babel` is properly populated (as mentioned above in the `Options` section). -For example, to add `babel-plugin-transform-object-rest-spread` so that your addon can use object -rest/spread you would do something like this: - -```js -module.exports = { - name: 'my-special-addon', - - init() { - this._super && this._super.init.apply(this, arguments); - - this.options = this.options || {}; - this.options.babel = this.options.babel || {}; - this.options.babel.plugins = this.options.babel.plugins || []; - this.options.babel.plugins.push('transform-object-rest-spread'); - }; -} -``` - #### Additional Trees For addons which want additional customizations, they are able to interact with