@builder.io/ts-transform-optional-chaining

0.0.4 • Public • Published

ts-transform-optional-chaining

A TypeScript custom transformer that enables optional chaining (aka existential operator, safe navigation) support in TypeScript via the non-null assertion operator.

npm version

Usage

With this plugin

foo!.bar!.baz

compiles to

foo && foo.bar && foo.bar.baz

so you can get that madness out of your code!

Requirement

TypeScript >= 2.4.1

How to use the custom transformer

Unfortunately, TypeScript itself does not currently provide any easy way to use custom transformers (See https://github.com/Microsoft/TypeScript/issues/14419). The followings are the example usage of the custom transformer.

webpack (with ts-loader or awesome-typescript-loader)

// webpack.config.js
const optionalChainingTransformer = require('@builder.io/ts-transform-optional-chaining/transformer').default;

module.exports = {
  // ...
  module: {
    rules: [
      {
        test: /\.ts$/,
        loader: 'ts-loader', // or 'awesome-typescript-loader'
        options: {
          getCustomTransformers: program => ({
              before: [
                  optionalChainingTransformer(program)
              ]
          })
        }
      }
    ]
  }
};

Rollup (with rollup-plugin-typescript2)

// rollup.config.js
import typescript from 'rollup-plugin-typescript2';
import optionalChainingTransformer from '@builder.io/ts-transform-optional-chaining/transformer';

export default {
  // ...
  plugins: [
    typescript({ transformers: [service => ({
      before: [ optionalChainingTransformer(service.getProgram()) ],
      after: []
    })] })
  ]
};

ttypescript

See ttypescript's README for how to use this with module bundlers such as webpack or Rollup.

// tsconfig.json
{
  "compilerOptions": {
    // ...
    "plugins": [
      { "transform": "@builder.io/ts-transform-optional-chaining/transformer" }
    ]
  },
  // ...
}

TypeScript API

See test for detail. You can try it with $ npm test.

const ts = require('typescript');
const optionalChainingTransformer = require('@builder.io/ts-transform-optional-chaining/transformer').default;

const program = ts.createProgram([/* your files to compile */], {
  strict: true,
  noEmitOnError: true,
  target: ts.ScriptTarget.ES5
});

const transformers = {
  before: [optionalChainingTransformer(program)],
  after: []
};
const { emitSkipped, diagnostics } = program.emit(undefined, undefined, undefined, false, transformers);

if (emitSkipped) {
  throw new Error(diagnostics.map(diagnostic => diagnostic.messageText).join('\n'));
}

License

MIT

Readme

Keywords

Package Sidebar

Install

npm i @builder.io/ts-transform-optional-chaining

Weekly Downloads

8

Version

0.0.4

License

MIT

Unpacked Size

9.91 kB

Total Files

7

Last publish

Collaborators

  • sidmohanty11
  • anaghavarhade
  • harmeet.builder
  • armela
  • strd6
  • murtaza-haveliwala
  • gustavohgs
  • sanyamkamat
  • shyam-builder
  • manucorporat
  • steve8708
  • samijaber
  • teleaziz123
  • mrkoreye
  • mhevery
  • adamdbradley