Skip to content

Latest commit

 

History

History
59 lines (43 loc) · 2.98 KB

README.md

File metadata and controls

59 lines (43 loc) · 2.98 KB

tsconfig

Standard TypeScript compiler configuration for Software Ventures Limited.

Install

npm install --save-dev @softwareventures/tsconfig

or for yarn users:

yarn add --dev @softwareventures/tsconfig

We recommend that all packages that use this configuration also add a dependency on tslib. tslib is needed to support a handful of languages features that are available in ES2018+ but not ES2017.

npm install --save tslib

or

yarn add tslib

Usage

Create a tsconfig.json file in the root of your project containing:

{
    "extends": "@softwareventures/tsconfig"
}

The above is the default configuration, which will include the ES2017 API and generate modules in ESM format (see advice for migrating to ESM modules). This configuration is suitable for projects that target node alone, or that target both node and the browser.

Several alternative configurations are also provided with settings suitable for other target environments or module formats. To use one of the alternative configurations, set the extends field to one of the values in the table below.

extends
@softwareventures/tsconfig The default configuration. Includes ES2017 API and generates modules in ESM format. Suitable for projects that either target node alone, or target both node and the browser.
@softwareventures/tsconfig/commonjs Same as default, but generates modules in CommonJS format instead of ESM.
@softwareventures/tsconfig/dom Includes DOM API in addition to ES2017. Suitable for use in code targeting browsers or for projects that include a DOM library such as jsdom.
@softwareventures/tsconfig/dom-commonjs Same as dom, but generates modules in CommonJS format instead of ESM.
@softwareventures/tsconfig/webworker Includes WebWorker API in addition to ES2017. Suitable for use in code that will run as a Web Worker.
@softwareventures/tsconfig/webworker-commonjs Same as webworker, but generates modules in CommonJS format instead of ESM.