No commit activity in last 3 years
No release in over 3 years
Transpile your ES6 files into ES5 using the Illusionist node module and Sprockets
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.7
>= 0
~> 10.0
= 0.27.1

Runtime

< 3.0, >= 2.10.1
 Project Readme

sprockets-illusionist

Gem Version Code Climate

sprockets-illusionist makes it possible to transpile your ES6 files into ES5 using the Illusionist node module and Sprockets.

This entire guide assumes that you have node and npm already installed on your local machine.

Deprecation notice

⚠️ This repository is now deprecated in favor of sprockets-es6.

Installation

First, you will need the Illusionist node package:

$ npm install -g illusionist

Add this line to your application’s Gemfile:

gem 'sprockets-illusionist'

And then execute:

$ bundle

Usage

Options

  • module_type

    The module type you want to use.

    Available options: amd, cjs and globals

    Default: amd

  • base_path (only applies to AMD modules)

    The base_path setting is used to name modules. Module names are relative paths to base_path, if you don’t set it, only the file name is used.

  • node_path

    The path to the node executable.

  • illusionist_path

    The path to the illusionist executable.

Integrating with Rails

Create an initializer:

# sprockets_illusionist.rb
SprocketsIllusionist::Config.configure do |config|
  config.base_path = Rails.root.join('app', 'assets', 'javascripts')

  # You can also choose which module format you want.
  # 'amd' is the default, other options are: 'cjs' and 'globals'
  config.module_type = 'amd'
end

With this configuration, a file named:

/projects/MyApp/app/assets/javascripts/controllers/foo_controller.js.es6

will yield a module named:

controllers/foo_controller

Writing ES6 files

With sprockets-illusionist just write your JavaScript files with the extension .js.es6 and everything will be transpiled for you.

Deploying on Heroku

  1. You will need to use heroku-buildpack-multi to install node and Ruby.

    Tell Heroku to use the right buildpack:

    $ heroku config:add BUILDPACK_URL=https://github.com/heroku/heroku-buildpack-multi.git

    Create a .buildpacks file with the following content:

    https://github.com/heroku/heroku-buildpack-nodejs.git
    https://github.com/heroku/heroku-buildpack-ruby.git
    
  2. You will need to include illusionist as a dependency of your project.

    Create a package.json file with the following content:

    {
      "name": "Your-Project",
      "version": "0.0.1",
      "dependencies": {
        "illusionist": "~<insert latest version>"
      }
    }

    Install the dependencies on your local machine for development:

    $ npm install

    Note that heroku-buildpack-nodejs does that for you at deploy time.

  3. You will need to link to the local installation of illusionist and node to get the latest version.

    Your initializer should look like this:

    SprocketsIllusionist::Config.configure do |config|
      config.node_path = ENV['NODE_BIN_PATH']
      config.illusionist_path = ENV['ILLUSIONIST_BIN_PATH']
      config.base_path = Rails.root.join('app', 'assets', 'javascripts')
      config.module_type = 'amd'
    end

    Then in .env on your local machine:

    NODE_BIN_PATH=node
    ILLUSIONIST_BIN_PATH=./node_modules/.bin/illusionist
    

    Finally, set these environment variables on Heroku:

    $ heroku config:set NODE_BIN_PATH=./.heroku/node/bin/node
    $ heroku config:set ILLUSIONIST_BIN_PATH=./node_modules/.bin/illusionist

Contributors

License

sprockets-illusionist is © 2014-2015 Mirego and may be freely distributed under the New BSD license. See the LICENSE.md file.

About Mirego

Mirego is a team of passionate people who believe that work is a place where you can innovate and have fun. We’re a team of talented people who imagine and build beautiful Web and mobile applications. We come together to share ideas and change the world.

We also love open-source software and we try to give back to the community as much as we can.