Skip to content

ungap/plugin-transform-static-jsx

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

@ungap/plugin-transform-hinted-jsx

This plugin is a follow up of this post and it can be used together with @babel/plugin-transform-react-jsx.

A huge thanks to Nicolò Ribaudo for helping out.

babel.config.json

{
  "plugins": [
    ["@babel/plugin-transform-react-jsx"],
    ["module:@ungap/plugin-transform-hinted-jsx"]
  ]
}

npm install

npm i --save-dev @babel/cli
npm i --save-dev @babel/core
npm i --save-dev @babel/plugin-transform-react-jsx
npm i --save-dev @ungap/plugin-transform-hinted-jsx

What is it / How to use it

This produces a slightly different JSX transform.

const div = (
  <div>
    <p className="static" runtime={'prop'}/>
    {<p />}
  </div>
);

// becomes
const div = React.createElement``(
  'div',
  null,
  React.createElement(
    'p',
    {
      className: 'static',
      runtime: React.interpolation('prop')
    }
  ),
  React.interpolation(
    React.createElement``(
      'p',
      null
    )
  )
);