/lasso-babel-transform

Lasso.js transform that uses Babel to transpile code

Primary LanguageJavaScript

lasso-babel-transform

Lasso.js transform that uses Babel to transpile ES6 code to ES5.

Prerequisites

This transform requires Lasso v2+

Installation

lasso 2.x/3.x, babel 7.x, lasso-babel-transform 2.x

npm install lasso-babel-transform @babel/core

lasso 2.x/3.x, babel 6.x, lasso-babel-transform 1.x

npm install lasso-babel-transform@1

Usage

By default, this plugin will look for a .babelrc while traversing up the root directory of the packages and will transpile any files that have the .js or .es6 extension. If a .babelrc file does not exist, it will attempt to look for a .babelrc-browser file. If neither of those files exist, this plugin will look in the package.json for a babel property.

You can specify different file extensions with the extensions option in the transform's config (shown below).

require('lasso').configure({
    require: {
        transforms: [
            {
                transform: 'lasso-babel-transform',
                config: {
                    extensions: ['.js', '.es6'] // Enabled file extensions. Default: ['.js', '.es6']
                }
            }
        ]
    }
});

Global babel options

Alternatively, babel options can be provided directly via the config. Note: Specifying babel options directly will cause all files to be transpiled with these options (regardless of what is specified in the package's .babelrc, .babelrc-browser, or babel property in the package.json).

require('lasso').configure({
    require: {
        transforms: [
            {
                transform: 'lasso-babel-transform',
                config: {
                    // directly specify babel options
                    babelOptions: {
                        presets: [ "@babel/preset-env" ]
                    }
                }
            }
        ]
    }
});

Configuring Babel

You will want to put a .babelrc or .babelrc-browser file at the root of each package that has any JavaScript files that should be transpiled by Babel. For example:

my-module/.babelrc:

{
    "exclude": ["excluded/**"],
    "presets": [ "@babel/preset-env" ]
}

As mentioned above, you can also opt to use the babel property to the package.json.

my-module/package.json:

{
    "name": "my-module",
    ...
    "babel": {
        // babel config goes here
    }
}

You will need to install any Babel plugins enabled in your babel config. For example:

npm install @babel/preset-env --save