@sebastianowy/builder-guard

"BuilderGuard" organizes promises execution

Usage no npm install needed!

<script type="module">
  import sebastianowyBuilderGuard from 'https://cdn.skypack.dev/@sebastianowy/builder-guard';
</script>

README

Builder Guard

Uses TypeScript to guard builders when providing data

npm latest version Build states semantic-release

Installation

npm install --save @sebastianowy/builder-guard
# or
yarn add @sebastianowy/builder-guard

Usage

Examples

  • examples with timeouts
import createBuilderGuard, { Builder } from '@sebastianowy/builder-guard';

interface ICarData {
  color: 'red' | 'green' | 'blue';
  doors: 3 | 5;
  engine: 'V6' | 'V8';
}

interface ICarTypeResult {
  carType: 'sport' | 'van';
}

class CarTypeBuilder extends Builder<ICarData, ICarTypeResult> {
  build(): ICarTypeResult {
    if (this.isSportCar()) {
      return { carType: 'sport' };
    }
    return { carType: 'van' };
  }

  private isSportCar(): boolean {
    return this._data.color === 'red' && this._data.engine === 'V8' && this._data.doors === 3;
  }
}

const builder = createBuilderGuard(CarTypeBuilder);
const carTypeResult = builder
  .color('red')
  .doors(3)
  .engine('V8')
  // build method is not available until all properties are set
  .build();