Skip to content
This repository has been archived by the owner on Jan 8, 2025. It is now read-only.

A tool to create user-defined helpers that can be used in your babel plugin.

License

Notifications You must be signed in to change notification settings

yukihirop/babel-udf-helpers

Repository files navigation

babel-udf-helpers

npm version deploy docs CircleCI

A tool to create user-defined helpers that can be used in your babel plugin.
The usability is like that of @babel/helpers.

image

📦 Installation

npm install --save-dev babel-udf-helpers

❤️ Support Version

  • node.js (>=10.15)
  • typescript target (ES2018)

📖 Usage

Use in your babel plugin as follows.
It works the same as babel-helpers addHelper, so you can use it anywhere in your visitor.

import { useDangerousUDFHelpers } from 'babel-udf-helpers';
import helpers from './helpers';

export default function({types: t}){
  pre(){
    useDangerousUDFHelpers(this, { helpers });
  },
  visitor: {
    Program(path){
      this.addUDFHelper("programHelper")
    },
    ImportDeclaration(path) {
      this.addUDFHelper("importHelper")
    }
  }
}

helpers.js looks like the following.

import { helper } from 'babel-udf-helpers';

const helpers = Object.create(null);
export default helpers;

helpers.programHelper = helper`
  export default function _programHelper(){
    return "programHelper";
  };
`

helpers.importHelper = helper`
  export default function _importHelper(){
    return "importHelper";
  };
`

📚 Documents

Full docs are available at https://yukihirop.github.io/babel-udf-helpers

⚽ Example

Run the plugin test with babel-udf-helpers in typescript and javascript.

{
  make all-deps
  make example-test
}

📝 License

The gem is available as open source under the terms of the MIT License.

🤝 Contributing

  1. Fork it ( http://github.com/yukihirop/babel-udf-helpers/fork )
  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