0.0.2 • Published 9 years ago

babel-plugin-transform-thea-jsx v0.0.2

Weekly downloads
1
License
MIT
Repository
-
Last release
9 years ago

babel-plugin-transform-thea-jsx

Turn JSX into Thea VDOM. By default, imports the base Thea library automatically.

Example

In

var profile = <div>
  <img src="avatar.png" class="profile" />
  <h3>{[user.firstName, user.lastName].join(' ')}</h3>
</div>;

Out

'use strict'

var TheaDom = require('thea/types/TheaDom'),
    TheaKeyedChildren = require('thea/types/KeyedChildren');

var profile = [
  TheaDom('div'), { children: [
    [TheaDom('img'), { src: "avatar.png", class: "profile" }],
    [TheaDom('h3'), { children: [[TheaKeyedChildren, [user.firstName, user.lastName].join(' ')]] }]
  ]}
]

Custom

In

/* @jsx T */
var profile = <div>
  <img src="avatar.png" class="profile" />
  <h3>{[user.firstName, user.lastName].join(' ')}</h3>
</div>;

Out

'use strict'

var profile = [
  T.TheaDom('div'), { children: [
    [T.TheaDom('img'), { src: "avatar.png", class: "profile" }],
    [T.TheaDom('h3'), { children: [[T.TheaKeyedChildren, [user.firstName, user.lastName].join(' ')]] }]
  ]}
]

NB: There is no automatic import if a custom name is set in the file.

Installation

npm install --save-dev babel-plugin-transform-thea-jsx

Usage

Via .babelrc (Recommended)

Without options:

{
  "plugins": ["transfrom-thea-jsx"]
}

With options:

{
  "plugins": [
    ["transfrom-thea-jsx", {
      "pragma": "Thea"
    }]
  ]
}

Via CLI

babel --plugins transform-thea-jsx script.js

Via Node API

require("babel-core").transform("code", {
  plugins: ["transform-thea-jsx"]
});

Options

  • pragma : the name to use for Thea. Defaults to ρ. Thea will be imported under this name.
  • import : boolean flag whether to automatically import thea,
  • useHelper: boolean flag whether to use the babel helper to polyfill Object.assign. Defaults to false.

References

This plugin is inspired by (transform-react-jsx)https://github.com/babel/babel/tree/master/packages/babel-plugin-transform-react-jsx.