GitXplorerGitXplorer
m

babel-plugin-angular-annotate

public
5 stars
4 forks
4 issues

Commits

List of commits on branch master.
Verified
d24a957f0d5da74b432ec8bbd07f5b78e92b1437

Update dependencies

mmarcioj committed 9 years ago
Unverified
5826631914a0ff489fd1fcc77cbfc36d6e31af21

Update README.md

mmarcioj committed 9 years ago
Unverified
36fcfd4ee5e00c81b6e8b9d8ad52787d10b47ce3

Add known issues in readme

mmarcioj committed 9 years ago
Unverified
b0d3a16ca599652277400e014590a3fe573eddf0

Remove node 0.10

mmarcioj committed 9 years ago
Unverified
7513d49ac50533d4987ca5032479792d15a3f04e

2.0.1

mmarcioj committed 9 years ago
Unverified
95750e01395b1f88f140aefb432899104cf20be5

Add npm-shrinkwrap.json

mmarcioj committed 9 years ago

README

The README file for this repository.

babel-plugin-angular-annotate

Make angular dependency annotation minification proof

Build Status

Compatibility

The version 2.x uses babel 6.x plugin API, for babel 5.x versions use the babel-plugin-angular-annotate 1.x

Installation

npm install babel-plugin-angular-annotate

Usage

Via .babelrc (Recommended)

.babelrc

{
  "plugins": [
    ["angular-annotate", [configurations...]]
  ]
}

Via CLI

$ babel --plugins angular-annotate script.js

Via Node API

require("babel-core").transform("code", {
  plugins: [
    ["angular-annotate", [configurations...]]
  ]
});

Known issues

  • Some injections wont work properly when using this plugin in conjuction with babel-preset-es2015. To get it working you need to use "passPerPreset": true in your .babelrc.

Configuration

angular-annotate accepts a json like injection configuration starting with an array containing two items in this format: [method call, args].

method call is expressed as a string with the service name and method call. For instance "$injector.invoke". You can also nest calls. For instance: "$httpProvider.interceptors.push".

args is where you map each param with the corresponding injection strategy. The two possible are: "$injectFunction" and "$injectObject". Any other value will be ignored.

$injectFunction will transform:

function (a, b, c) {
}

to

['a', 'b', 'c', function (a, b, c) {
}]

For instance to create a rule for $injector.invoke you can apply the following configuration: ["$injector.invoke", ["$injectFunction"]].

So the following will be transformed:

Before:

$injector.invoke(function($state) {
  $state.go('somewhere');
});

After:

$injector.invoke(['$state', function($state) {
  $state.go('somewhere');
}]);

$injectObject will apply $injectFunction for each object value. This is mainly used in the resolve property from some services. For example:

The $routeProvider.when configuration can be expressed with the following:

["$routeProvider.when", ["_", {
  "controller": "$injectFunction",
  "resolve": "$injectObject"
}]];

Before:

$routeProvider.when('/foo', {
  controller: function($scope) {
    $scope.message = 'foo';
  },
  templateUrl: 'foo.html',
  resolve: {
    store: function (foo) {
    }
  }
});

After:

$routeProvider.when('/foo', {
  controller: ['$scope', function($scope) {
    $scope.message = 'foo';
  }],
  templateUrl: 'foo.html',
  resolve: {
    store: ['foo', function (foo) {
    }]
  }
});

Note that since we don't want to do anything in the routeName we use a "_" to ignore it.

Presets

Since configuring each service injection can be tedius, this libray includes some presets like: "angular", "ngMaterial", "ngRoute" and "ui.router". So you can simple include the following in .babelrc:

{
  "plugins": [
    ["angular-annotate", ["angular", "ngMaterial", "ui.router"]]
  ]
}

Check the main file to see what injections are currently handled.

Running Tests

npm test

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request