ts-classname-plugin

A TypeScript custom transformer for referencing parent className like & in Sass(Less).

Usage no npm install needed!

<script type="module">
  import tsClassnamePlugin from 'https://cdn.skypack.dev/ts-classname-plugin';
</script>

README

ts-classname-plugin

A TypeScript custom transformer for referencing parent className like & in Sass(Less).

Requirement

Typescript >= 2.4.1

Install

yarn add ts-classname-plugin --dev

Configuration

option

Option can be a object with properties below:

  • flag: the string will be replaced by parent className. default: '&'

webpack

const pluginFactory = require('ts-classname-plugin');
module.exports = {
  // ...
  module: {
    rules: [
      {
        test: /\.(ts|tsx)$/,
        use: [
          {
            loader: require.resolve('ts-loader'),
            options: {
              // ...
              getCustomTransformers: () => ({
                before: [pluginFactory(/** options */)]
              })
            }
          }
        ]
      }
    ]
  }
}

Usage

Concepts

1. replaceable className

only the className of type string and includes the flag in option will be transformed by this plugin. for example:

// flag: '&'
// before
<div className="test">
  <div className"&-1"/>
</div>

// after
<div className="test">
  <div className"test-1"/>
</div>

2. lowest ancestor className

className of the lowest ancestor element which has a className attribute and the value of className attribute is a string or jsx expression in AST. for example:

// before
<div className="lowest">
  <div>
    <div className="&-1"/>
  </div>
</div>

// after
<div className="lowest">
  <div>
    <div className="lowest-1"/>
  </div>
</div>

How it works

We can describe the working process of this plugin with those two concepts above. Encounter the jsx element with a replaceable className in the AST traversal, then replace the flag with the lowest ancestor className. So, enjoy it.

Test

You can clone this project, the place your source code in demo/source, then run yarn demo. The resule code file will be generated in demo/target.