Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

rollup-plugin-ts

wessberg136kMITdeprecated3.4.5TypeScript support: included

please use @rollup/plugin-typescript and rollup-plugin-dts instead

A TypeScript Rollup plugin that bundles declarations, respects Browserslists, and enables seamless integration with transpilers such as babel and swc

rollup, typescript, declaration, declarations, bundling, merging, treeshaking, plugin, babel, browserslist

readme

Logo

A TypeScript Rollup plugin that bundles declarations, respects Browserslists, and enables seamless integration with transpilers such as babel and swc

Downloads per month NPM version Dependencies Contributors code style: prettier License: MIT Support on Patreon

Description

This is first and foremost a TypeScript plugin for Rollup that brings the best of both together in a package that also respects Browserslists, bundles declaration files, and enables seamless integration with other transpilers such as Babel and swc.

One of the most powerful features of rollup-plugin-ts is declaration bundling and tree-shaking that works seamlessly with code splitting. That means you'll always get the smallest possible declaration files that match exactly what you're exporting, without any superflous type information.

Tooling in the JavaScript ecosystem can often be complex, and this is very much the case when intending to combine TypeScript with other tools such as Babel and Browserslists while still maintaining the unique emit capabilities of tsc. rollup-plugin-ts differs from other TypeScript plugins in being opiniated about how some of these tools integrate in order to achieve the most optimal behavior with the smallest possible computational overhead. For example, when combined with another transpiler such as Babel, TypeScript handles diagnostics and declarations, while Babel is used for part of or all of the syntax transformations. You can even configure which transpiler takes care of the TypeScript-specific syntax, and which transpiler takes care of the remaining syntax. For example, you can let the TypeScript compiler strip away type information, while handling the rest of the syntax transformation with babel or swc.

At the same time, rollup-plugin-ts has a very robust test suite that runs tests across all minor versions of TypeScript since v3.4 to ensure that everything works no matter which version of TypeScript you or your team is using.

Features

  • Enables you to bundle your TypeScript applications and libraries with Rollup
  • Generates, bundles, and tree-shakes declaration files (.d.ts) and fully supports code splitting.
  • Integrates seamlessly with other transpilers such as Babel and swc, such that TypeScript handles diagnostics, declarations, and another transpiler is used for parts of or the entire syntax transformation.
  • Emits Compiler diagnostics and brings them into the Rollup build lifecycle
  • Correctly handles Emit-less types
  • Supports Incremental compilation.
  • A Browserslist can be provided instead of a target version of ECMAScript such that your code is transpiled in relation to the baseline of browsers defined in your Browserslist instead.
  • Robust, with a comprehensive test suite that runs against all minor versions of TypeScript from v3.4 and up.

Backers

Become a sponsor/backer and get your logo listed here.

Trent Raymond scrubtheweb
Trent Raymond scrubtheweb

Patreon

Patrons on Patreon

Table of Contents

Install

npm

$ npm install rollup-plugin-ts --save-dev

Yarn

$ yarn add rollup-plugin-ts --dev

pnpm

$ pnpm add rollup-plugin-ts --save-dev

Peer Dependencies

rollup-plugin-ts depends on rollup and typescript, so you need to manually install these as development dependencies as well.

You may also need to install additional peer dependencies such as @babel/core, @babel/runtime, @babel/preset-env, @babel/preset-typescript, @babel/plugin-transform-runtime, @swc/core, or @swc/helpers depending on the features you are going to use. Refer to the documentation for the specific cases where any of these may be relevant.

Usage

Using the plugin is as simple as it can be. Here's an example within a Rollup config:

import ts from "rollup-plugin-ts";
export default {
    // ...
    plugins: [
        ts({
            /* Plugin options */
        })
    ]
};

Without any options, the plugin will "just work":

  • The tsconfig.json file closest to the current working directory will be resolved, if any. Otherwise, the default Typescript options will be used.
  • The .browserslistrc file or browserslist property within the package.json file closest to the current working directory will be resolved and used to decide the Typescript ECMAScript version target, if any. Otherwise, the declared target within the resolved tsconfig.json file will be used, if any such file exists, and if not, the default Typescript target will be used.

Using it with just Typescript

This plugin works very well with just Typescript. The tsconfig.json file closest to your project will be resolved and used in combination with Rollup. If your config has a different name, or if you use different configs dynamically depending on the environment, you can provide the location for the tsconfig in the plugin options:

ts({
    tsconfig: PRODUCTION ? "tsconfig.prod.json" : "tsconfig.json"
});

You an also pass in CompilerOptions directly, rather than provide the path to a tsconfig:

ts({
    tsconfig: {
        target: ScriptTarget.ES2018,
        allowSyntheticDefaultImports: true,
        allowJs: true
    }
});

You can also pass in a function that receives whatever CompilerOptions that could be resolved relative to the current working directory, but then allow you to override the options:

ts({
    tsconfig: resolvedConfig => ({...resolvedConfig, allowJs: false})
});

The above example is based on the assumption that a file can be resolved with the name tsconfig.json, and if not, the Typescript's default CompilerOptions will be used. But if you want to provide the name of the tsconfig to override, you can also pass in an object following the following form:

ts({
    tsconfig: {
        fileName: "my-awesome-tsconfig.json",
        hook: resolvedConfig => ({...resolvedConfig, allowJs: false})
    }
});

If there is a .browserslistrc file or the nearest package.json contains a Browserslist configuration, a target ECMAScript version will be decided based on that one, rather than respecting the target property of the matched tsconfig. If you do not want this behavior, you can disable it as described here.

Typescript and tslib helpers

This plugin makes sure that the helper functions that may be emitted within the output generated by Typescript will not be duplicated across files and chunks. Instead, they will automatically be divided into chunks and imported across Rollup chunks. You don't have to do anything!

Combining Typescript with a Browserslist

If there is a .browserslistrc file or the nearest package.json contains a Browserslist configuration, this is the default behavior! Rather than use the target property of the nearest tsconfig, it will be decided based on the Browserslist.

You can explicitly pass in Browserslist options. Here's an example with a raw Browserslist query:

ts({
    browserslist: ["last 1 version", "> 1%"]
});

You can also provide a configuration object instead of a raw query. Here's one with a baked-in query:

ts({
    browserslist: {
        query: ["last 1 version", "> 1%"]
    }
});

...And here's one with a path property pointing to a file that contains a Browserslist:

ts({
    browserslist: {
        path: ".mybrowserslistrc"
    }
});

Using the plugin with Typescript, but without Browserslists

If no Browserslist can be found, or if you simply don't want to use one, that's completely OK! In such cases, the target property of the nearest tsconfig will be used (or use the Typescript default setting if no such file exists).

You can explicitly request that no Browserslist will be used by setting the browserslist property to false in the plugin options:

ts({
    browserslist: false
});

Combining Typescript with Babel

This plugin makes it really easy to use Typescript for reporting diagnostics and generating declaration files, but then using Babel for all syntax transformations. One very strong use case for this is to use @babel/preset-env. Another one is that you get the entire ecosystem of Babel plugins at your disposal.

To use Babel, first set the transpiler plugin option to "babel":

ts({
    transpiler: "babel"
});

Now, all that remains is to simply install the peer dependencies relevant to babel. Please install @babel/core, @babel/runtime, @babel/plugin-transform-runtime, @babel/preset-typescript, and @babel/preset-env as well with your package manager:

npm

$ npm install @babel/core @babel/runtime @babel/plugin-transform-runtime @babel/preset-typescript @babel/preset-env --save-dev

Yarn

$ yarn add @babel/core @babel/runtime @babel/plugin-transform-runtime @babel/preset-typescript @babel/preset-env --dev

pnpm

$ pnpm add @babel/core @babel/runtime @babel/plugin-transform-runtime @babel/preset-typescript @babel/preset-env --save-dev

Don't worry if you don't, rollup-plugin-ts will warn you about exactly which dependencies are missing once you run it.

Once you're done installing peer dependencies, that's it! The plugin will attempt to locate a babel.config.js file or a .babelrc file and use the options, plugins, and presets found there. By default, some combination of presets and plugins will be applied depending on the config options you provide, while others will be forced at all times for interoperability reasons. See this section for more details.

@babel/preset-env behavior (and how to opt out)

By default, when using Babel as the transpiler, @babel/preset-env will be used as a preset that respects the browserslist that was either provided directly as a plugin option, or was resolved inside the root of your project, or was computed based on your tsconfig.json file.

If you don't want this behavior, simply pass the browserslist: false option to the plugin. Doing so will never apply @babel/preset-env and not apply any additional syntax transformations:

ts({
    transpiler: "babel",
    browserslist: false
});

Special handling for minification plugins/presets

This plugin will apply syntax transformations from Babel presets and plugins on a file-by-file basis. However, if a minification-related plugin or preset such as babel-preset-minify is found within the Babel options, these transformations will be applied per chunk. This enables the minification presets and plugins to perform better as it can now mangle in relation to the entire chunk and better remove unwanted characters such as whitespace. All of this works automatically.

@babel/runtime and external helpers

This plugin will automatically make sure to avoid duplication of emitted Babel helpers. Rollup will automatically split these into chunks and re-use them across the chunks that Rollup generates. You don't have to do anything.

@babel/runtime and polyfills

Babel supports injecting polyfills where needed and in relation to the target environment. By default, this plugin will not add polyfills to your chunks since there are arguably better ways of applying polyfills such as lazy-loading depending on feature support or using something like Polyfill.app. If you would like this behavior, simply add either @babel/plugin-transform-runtime to your Babel config with the corejs option set to true, or add @babel/preset-env to your Babel config with the useBuiltIns option set to usage.

Combining Typescript with swc

Just like with Babel, this plugin makes it trivial to use TypeScript for reporting diagnostics, generating declaration files, and stripping types, but then using swc for all other syntax transformations.

Swc is a much faster alternative to Babel, built in Rust, that attempts to be as close to a drop-in replacement for Babel as possible. It is not nearly as mature and doesn't have as big a plugin ecosystem yet, but can often be much faster than Babel. And like Babel, it also has first-class support for Browserslists which will be used to decide which syntax transformations to apply depending on language support in the target environments.

To use swc, first set the transpiler plugin option to "swc":

ts({
    transpiler: "swc"
});

Now, all that remains is to simply install the peer dependencies relevant to swc. Please install @swc/core and @swc/helpers as well with your package manager:

npm

$ npm install @swc/core @swc/helpers --save-dev

Yarn

$ yarn add @swc/core @swc/helpers --dev

pnpm

$ pnpm add @swc/core @swc/helpers --save-dev

Don't worry if you don't, rollup-plugin-ts will warn you about exactly which dependencies are missing once you run it.

Once you're done installing peer dependencies, that's it! The plugin will attempt to locate a .swcrc file and use the options found there. By default, some combination of options will be applied depending on the config options you provide, while others will be forced at all times for interoperability reasons. See this section for more details.

Mixing transpilers

By default, the transpiler you select, such as typescript, babel, or swc, is used for the entire syntax transformation. However, you may want to mix these. There can be quite good reasons why you may want that, as described here. In short, you may find value in using the TypeScript compiler for stripping away the TypeScript specific syntax, and then delegate the remaining syntax transformations to swc or babel.

To accomplish this, the transpiler option also allows for an options record:

ts({
    transpiler: {
        typescriptSyntax: "typescript",
        otherSyntax: "babel"
    }
});

In this example, the TypeScript compiler will first remove features such as types, type-only imports, enums, and decorators. Babel will then be used for all other syntax transformation from then on, depending on the combination of default, provided, and forced presets and plugins.

Using Custom Transformers

This plugin enables you to pass in Custom Transformers which allows you to transform the Typescript AST during code transpilation. This enables you to very efficiently transform Typescript before code generation and additionally enables you to use this plugin with tools that leverage this, such as some modern web frameworks and libraries do.

Please note that if you want to combine Custom Transformers with other transpilers such as babel, you must mix them such that the typeScript transpiler is used for the typescriptSyntax option as described above.

Declaration files

Typescript declaration files are normally distributed in a folder structure that resembles the structure of the source folder. With tsc, you would get something like this:

TSC emitted code

Rollup is a bundler, and with it, we can produce clean, small files that are easy to distribute. With rollup-plugin-ts, declaration files will be bundled, tree-shaken and emitted alongside the chunks emitted by Rollup:

Plugin emitted code

And, it even works in complex code splitting scenarios:

Plugin emitted code with code splitting

if you're using TypeScript v4.7 or newer, the extension of your declaration files will depend on the extensions of your output files as controlled by your Rollup config:

  • .js output files will produce .d.ts and optionally .d.ts.map files
  • .mjs output files will produce .d.mts and optionally .d.mts.map files
  • .cjs output files will produce .d.cts and optionally .d.cts.map files

Examples

Pure Typescript example

ts({
    // If your tsconfig is already called 'tsconfig.json', this option can be left out
    tsconfig: "tsconfig.json",
    // If there is no .browserslistrc within your project, and if your package.json doesn't include a Browserslist property, this option can be left out
    browserslist: false
});

Typescript with Browserslist example

As described here, by default, the plugin will attempt to locate a Browserslist automatically. This example shows how you can provide one explicitly

ts({
    browserslist: ["last 1 version", "> 1%"]
});

// or
ts({
    browserslist: {path: ".mybrowserslistrc"}
});

Typescript, Babel, and Browserslist example

As described here, a babel.config.js or .babelrc file will automatically be found by the plugin if available. This example shows how you can provide one explicitly. And, as described here, the same goes for Browserslists.

ts({
    transpiler: "babel",
    browserslist: ["last 1 version", "> 1%"],
    babelConfig: {
        plugins: ["my-babel-plugin"]
    }
});

Typescript, Babel, and Browserslist example with mixed transpilers

This is like the example above, but with the addition of mixing transpilers.

ts({
    transpiler: {
        typescriptSyntax: "typescript",
        otherSyntax: "babel"
    },
    browserslist: ["last 1 version", "> 1%"],
    babelConfig: {
        plugins: ["my-babel-plugin"]
    }
});

Typescript, swc, and Browserslist example

As described here, a .swcrc file will automatically be found by the plugin if available. This example shows how you can provide one explicitly. And, as described here, the same goes for Browserslists.

ts({
    transpiler: "swc",
    browserslist: ["last 1 version", "> 1%"],
    swcConfig: {
        minify: true
    }
});

Typescript, swc, and Browserslist example with mixed transpilers

This is like the example above, but with the addition of mixing transpilers.

ts({
    transpiler: {
        typescriptSyntax: "typescript",
        otherSyntax: "swc"
    },
    browserslist: ["last 1 version", "> 1%"],
    swcConfig: {
        minify: true
    }
});

Pure Typescript with Custom Transformers

ts({
    transformers: {
        before: [myTransformer1, myTransformer2],
        after: [myTransformer3, myTransformer4],
        afterDeclarations: [myTransformer5, myTransformer6]
    }
});

Advanced example of using Typescript, Babel, and Browserslists together

This example shows how you can use this plugin to accomplish quite advanced things:

const IS_PRODUCTION = process.env.NODE_ENV === "production";
const BUNDLE_TARGET = process.env.BUNDLE_TARGET;
const APP_ROOT = "/some/project/root/folder";
const awesomeFrameworkTransformers = getAwesomeFrameworkCustomTransformers();

ts({
    // Use TypeScript for stripping away types and other TypeScript-specific features,
    // and then use babel for the remaining transformation.
    transpiler: {
        typescriptSyntax: "typescript",
        otherSyntax: "babel"
    },
    // Don't use process.cwd(), but instead another root directory
    cwd: APP_ROOT,
    // Load a different tsconfig file in production
    tsconfig: IS_PRODUCTION ? "tsconfig.prod.json" : "tsconfig.json",
    // Load a different browserslist if currently targeting a modern environment
    browserslist: {
        path: BUNDLE_TARGET === "modern" ? ".browserslistrc-modern" : ".browserslistrc-legacy"
    },
    // Load a different babel config file in production
    babelConfig: IS_PRODUCTION ? "babel.config.prod.js" : "babel.config.js",

    // Exclude files within node_modules when not in production
    exclude: IS_PRODUCTION ? [] : ["node_modules/**/*.*"],

    // Apply CustomTransformers, for example to transform the Source Code with a framework that uses some
    transformers: awesomeFrameworkTransformers
});

Passing a specific TypeScript version

You can use pass a specific TypeScript to use as an option. This may be useful if you are using different TypeScript versions across packages inside a monorepo and you want to use a specific one with rollup-plugin-ts:

ts({
    typescript: specialTypescriptVersion
});

Hooks

rollup-plugin-ts provides a few hooks that allow you to hook into and augment the internal behavior of the plugin.

These can be provided in the plugin options for the hook property:

ts({
    hook: {
        // Add hooks here
    }
});

The next few subsections describe the different hooks that can be provided

The outputPath hook

Type: (path: string, kind: "declaration" | "declarationMap" | "buildInfo") => string | undefined

The outputPath hook can be used to rewrite the location on the filesystem that assets produced by rollup-plugin-ts are written to. It is invoked immediately before assets such as declarations or declaration maps are emitted.

The hook is invoked with the output path as well as the kind of asset the path represents as arguments. If you return a string from the hook, the alternative location will be used instead. If you return undefined, the current path will be used.

ts({
    hook: {
        outputPath: (path, kind) => rewritePathSomehow(path, kind)
    }
});

For example, the path may be /some/path/index.d.ts, and kind be declaration, and you might want to rewrite this to /some/path/my-typings.d.ts.

The diagnostics hook

Type: (diagnostics: readonly Diagnostic[]) => readonly Diagnostic[]|undefined

The diagnostics hook can be used to read, alter, and extend the diagnostics generated by TypeScript immediately before they are emitted as errors via Rollup. Normally, Rollup will crash on the first discovered error, but there may be several diagnostics, all of which may be of interest to you. This hook gives you access to all of them.

You can also use this hook if you want to silence specific kinds of Diagnostics or even add your own.

The declarationStats hook

Type: (stats: DeclarationStats) => DeclarationStats|undefined

The declarationStats hook can be used to get relevant stats produced while bundling declarations. The hook calls the given callback with a stats object as the first argument. The stats object has the following type information:

// A Record from chunk file names to their stats
type DeclarationStats = Record<string, DeclarationChunkStats>;

interface DeclarationChunkStats {
    // An array of the external type dependencies for a declaration chunk
    externalTypes: ExternalType[];
}

interface ExternalType {
    // The name of the external library that provides the typings. For example, "typescript" or "@types/node"
    library: string;
    // The version of the referenced external library
    version: string;
}
The externalTypes property for DeclarationChunkStats

The externalTypes property of declaration chunk stats objects can be useful, for example, if you want to get a hook into which external type dependencies that remain after bundling and tree-shaking and that you should declare as dependencies of your library.

Here's an example of how you might use the hook:

ts({
    hook: {
        declarationStats: declarationStats => console.log(declarationStats)
    }
});

The example above could log something like the following to the console:

{
  "index.d.ts": {
    externalTypes: [
      { library: "typescript", version: "3.9.2" },
      { library: "@types/node", version: "14.0.26" }
    ]
  },
  "some-other-chunk.d.ts": {
    externalTypes: [
      { library: "some-other-external-library", version: "1.2.3" }
    ]
  }
}

This gives you an easy way to track which external type dependencies remain in your bundled and tree-shaken declarations and that should be declared as dependencies of your library.

Full list of plugin options

The plugin options are documented in more detail across this README, but the full list of options is:

transpiler

Type: "typescript" | "babel" | "swc"| {typescriptSyntax: "typescript" | "babel" | "swc"; otherSyntax: "typescript" | "babel" | "swc"}

Can be any of "babel", "swc", or "typescript" (default: "typescript"). Alternatively, it can be an options object with properties typescriptSyntax and otherSyntax, where any of the aforementioned transpilers can be used in combination. See this section for details on how to combine transpilers.

babelConfig

Type: string | Partial<BabelConfig>

This option will only be respected when "babel" is being used as the transpiler and can be used to provide a Babel config or a path to one.

swcConfig

Type: string | Partial<SwcConfig>

This option will only be respected when "swc" is being used as the transpiler and can be used to provide a swc config or a path to one.

tsconfig

Type: string | Partial<CompilerOptions> | Partial<Record<keyof CompilerOptions, string | number | boolean>> | ParsedCommandLine | TsConfigResolver | TsConfigResolverWithFileName

Provide the TypeScript CompilerOptions to use, or a path to a tsconfig with this property. See this section for details on the many ways this property can be configured.

browserslist

Type: false | string[] | string | BrowserslistConfig

Provide the Browserslist to use, or a path to a .browserslistrc with this property. See this section for details on the many ways this property can be configured.

cwd

Type: string

Use this property to overwrite whatever is considered the root directory. The default value is process.cwd().

typescript

Type: typeof import("typescript")

Use this property to pass a specific version of TypeScript to use.

transformers

Type: (CustomTransformers | CustomTransformersFunction)[] | CustomTransformers | CustomTransformersFunction

Use this property to provide TypeScript CustomTransformers. See this section for more details on how to configure this property.

include

Type: string[]|string

This option takes a minimatch pattern or an array of minimatch patterns and only transforms files with filenames that the pattern matches.

exclude

Type: string[]|string

This option takes a minimatch pattern or an array of minimatch patterns and only transforms files with filenames that the pattern doesn't match.

transpileOnly

Type: boolean

If this option is true, diagnostics won't be generated. This will improve performance since TypeScript but ignores all syntactical and semantic errors or warnings that may arise.

fileSystem

Optionally the FileSystem to use. This is useful for example when you want to provide a virtual FileSystem to read from or write to. Note that this must conform with the System interface declared by TypeScript, rather than the fs module.

hook

Use this property to get hooks into the internals of rollup-plugin-ts. See this section for more details.

Ignored/overridden options

TypeScript and Babel are powerful tools in their own right. Combined with Rollup, they become even more powerful. To provide a seamless experience, Rollup always take precedence when conflicts arise. As a natural consequence of this, some options provided to TypeScript and Babel will be ignored or overridden.

Ignored/overridden TypeScript options

The following CompilerOptions from a tsconfig will be ignored:

Property Reason
outDir Rollup, not TypeScript, will decide where to emit chunks.
module Rollup, not TypeScript, is the decider of which module system(s) to target based on your Rollup configuration.
outFile This option produces flat output and only works with the module formats AMD and SystemJS. Rollup will be the decider of how to split code.
sourceMap TypeScript will always be instructed to produce SourceMaps. Rollup then decides whether or not to include them (and if they should be inlined).
inlineSourceMap TypeScript will always be instructed to produce SourceMaps. Rollup then decides whether or not to include them (and if they should be inlined).
inlineSources Since inlineSourceMap is ignored, this option won't take effect.
importHelpers Helpers will always be imported. This makes it possible for Rollup to code-split properly and share TypeScript helpers across chunks.
moduleResolution Node-module resolution will always be used. This is required for importHelpers to work and in general, to make TypeScript able to resolve external libraries. Note that you still need to add the nodeResolve plugin in order to include external libraries within your bundle unless allowJs is true within your tsconfig
noEmit TypeScript should always be able to emit assets, but those will be delegated to Rollup.
noEmitOnError See above.
emitDeclarationOnly See above.
noEmitHelpers TypeScript should always be able to emit helpers, since the importHelpers option is forced
noResolve TypeScript should always be able to resolve things. Otherwise, compilation might break.
watch Rollup, not TypeScript, will watch files if run in watch mode. Efficient caching will still be used for optimum performance.
preserveWatchOutput See above

The following additional options will also be ignored:

Property Reason
include Rollup itself will decide which files to include in the transformation process based on your code. This plugin itself takes a include property which you should use instead if you want to explicitly allow specific files or globs.
exclude See above.

Behavior of esModuleInterop

Given that Rollup, not TypeScript, is the decider of which module system(s) to target based on your Rollup configuration, TypeScript will always emit ES modules that Rollup can understand and work with.

The esModuleInterop option to TypeScript is respected, but its emit-characteristics won't have an impact on your bundle. Instead, you may consult the Rollup documentation for the interop option to achieve the same thing with Rollup.

Ignored/overridden Babel options

The following Babel options will be ignored:

Property Reason
sourceMaps Babel will always be instructed to produce SourceMaps. Rollup then decides whether or not to include them (and if they should be inlined).
cwd The cwd option provided to the plugin will always be used.
include Rollup itself will decide which files to include in the transformation process based on your code. This plugin itself takes a include property which you should use instead if you want to explicitly allow specific files or globs.
exclude See above
ignore See above
only See above
sourceType Will always use module. Rollup will then decide what to do based on the output format

Ignored/overridden swc options

The following Babel options will be ignored:

Property Reason
sourceMaps swc will always be instructed to produce SourceMaps. Rollup then decides whether or not to include them (and if they should be inlined).
cwd The cwd option provided to the plugin will always be used.
cwd See above.
test Rollup itself will decide which files to include in the transformation process based on your code. This plugin itself takes a include property which you should use instead if you want to explicitly allow specific files or globs.
exclude See above
isModule Will always use true. Rollup will then decide what to do based on the output format

Default Babel plugins

If you decide to use Babel as the transpiler with the transpiler plugin option set to "babel", some best-practice default plugins and presets will be applied such that you don't have to configure anything on your own. By default, the plugin will conditionally apply the @babel/preset-env preset if a Browserslist is provided or located, as well as plugins for handling shipped proposals. And, the @babel/plugin-runtime plugin will be used for extracting Babel helpers and reusing them across your chunks to avoid code duplication.

If you provide these presets or plugins yourself through the found or provided Babel config, your config options will take precedence.

Here's table with a full overview of the specifics:

Preset/Plugin Condition Reason
@babel/preset-env A Browserslist is provided or found automatically, and you don't provide this preset yourself within your Babel config This preset enables you to base your syntax transformations on the specific browsers/environment you want your application or library to target. It will "Just Work"
@babel/preset-typescript Babel is being used for transforming TypeScript-specific syntax. This preset enables you to transform TypeScript-specific syntax. If you declare this in your own babel config, your configuration options will still be respected.
@babel/plugin-transform-runtime You don't provide this plugin yourself within your Babel config Depending on your configuration, async functions may be rewritten to use Regenerator Runtime, and there may be one or more Babel helpers injected within your code. @babel/plugin-runtime allows this plugin to avoid duplicating these helpers, and instead make them shared across Chunks seamlessly via Rollup.

Contributing

Do you want to contribute? Awesome! Please follow these recommendations.

Maintainers

Frederik Wessberg
Frederik Wessberg
Twitter: @FredWessberg
Github: @wessberg
Lead Developer

FAQ

Does this plugin work with Code Splitting?

Absolutely, even with Declaration files. Things will work seamlessly.

Why wouldn't you use just TypeScript?

The TypeScript compiler, while extremely powerful, has the restriction that it can only target a specific ECMAScript version. In reality, browsers and other ECMAScript environments has varying support for newer language features. Some browsers support even those features that haven't been publicized yet, while others support only parts of the latest language features.

In effect, a browser may support a lot of modern features such as classes and proper lexical scoping, but lack others. With TypeScript, it's "all-or-nothing": If you want to support a Browser with partial support, you must target the latest publicized ECMAScript version that the browser fully supports.

Babel, on the other hand, is far more granular in its design and applies syntax transformations on a feature-by-feature basis. Combined with something like @babel/preset-env, individual transformations can be applied for only those language features that are missing. This means that you can use things like classes and lexical scoping in browsers that otherwise doesn't fully support all of the ES2015 specification.

Okay, then why wouldn't you use just babel?

Babel has support for parsing and transforming TypeScript. While Babel can be used for everything, there are some caveats:

The Babel compiler works on a file-by-file basis, meaning it is simple to use and reason about, whereas the TypeScript compiler works with Programs, or in other words sets of related SourceFiles. This gives TypeScript the advantage over Babel that it has a greater understanding of your codebase in general and can understand your types across files.

When combined with Babel, what does TypeScript do, and what does Babel do?

When you use Babel as a transpiler in its default configuration, the TypeScript Compiler will have the responsibility of:

  • Emitting TypeScript diagnostics
  • Emitting TypeScript declaration (.d.ts) files and TypeScript declaration map (.d.ts.map) files.

Babel will then purely perform syntax transformations based on your configuration.

You can also opt in to using the TypeScript compiler to remove TypeScript specific syntax from your code when combined with babel. This grants you the power to combine the strengths of the TypeScript compiler, which understands the structure of your codebase, with the flexibility and plugin ecosystem of Babel.

Please read this section for details on how you can mix transpilers to achieve that. In such a setup, TypeScript is also responsible for:

  • Removing TypeScript-specific features such as types, type-only imports, enums, and TypeScript decorators.
  • Other TypeScript features that may require understanding the relationship between your files.

Babel will then be used for all other syntax transformation from then on, depending on the combination of default, provided, and forced presets and plugins.

When combined with swc, what does TypeScript do, and what does Babel do?

This FAQ answer applies to swc as well.

Additionally, if swc is instructed to apply minification, it will do that for every generated chunk, rather than on a per-file basis, to ensure the most optimal optimizations and smallest possible output.

Why is @babel/plugin-transform-runtime and tslib included by default?

See this explainer.

Starter templates

The following is an evolving list of starter templates for new projects using Rollup, TypeScript, and rollup-plugin-ts that you can take a look at and draw inspiration from.

License

MIT © Frederik Wessberg (@FredWessberg) (Website)

changelog

3.4.5 (2023-09-07)

Bug Fixes

  • improve error handling inside transpiler-loader (c36f7e8)

3.4.4 (2023-08-08)

Bug Fixes

  • incorrect type reference directives can sometimes be produced when a type root is a relative path (2fd4bda)

3.4.3 (2023-08-06)

Bug Fixes

  • babel peer dependencies versions (0ac3cea)
  • migrate to lint-staged from pretty-quick, which isn't compatible with Prettier v3 (104c28d)
  • resolve @babel/plugin-syntax-dynamic-import from @babel/preset-env (66cb727)

3.4.2 (2023-08-04)

3.4.1 (2023-08-03)

Bug Fixes

3.4.0 (2023-08-03)

Features

  • add support for the 'allowImportingTsExtensions' tsconfig option. Fixes #210 (c62f708)

3.3.1 (2023-08-03)

Bug Fixes

  • don't preserve dynamic import() expression in cjs bundle. Fixes #212 (08209ae)

3.3.0 (2023-08-03)

Bug Fixes

Features

  • add TypeScript v5.1 support. Add support for Node16 and NodeNext Module resolution (0d5aaa0)

3.2.0 (2023-01-23)

Features

  • add .js extensions to code splitted declaration chunks to support Node16 and NodeNext ModuleResolution (0b727a0)

3.1.1 (2023-01-09)

3.1.0 (2023-01-09)

Features

  • add TypeScript v4.9 support (1bd7601)

3.0.2 (2022-06-07)

Bug Fixes

  • don't call addWatchFile outside of allowed Rollup phase (8b3e7e8)

Features

  • add support for ESM-based Babel configs. Closes #167 (15e8edd)
  • add support for multiple swc configs. Closes #177. Don't enforce importHelpers: true to avoid a potential tslib error when babel or swc is used for all types of syntax (5ba4c9c)

3.0.1 (2022-05-31)

Bug Fixes

  • use ansi-colors instead of Chalk for better CJS fallback support (eac318e)

3.0.0 (2022-05-30)

Bug Fixes

  • use correct import binding (e693665)

Features

  • add TypeScript v4.7 support (aae4588)

2.0.7 (2022-04-15)

Bug Fixes

  • fix a regression when a Rollup cache is being used where unsupported files would be attempted to be added to the CompilerHost and crash the compilation. Fixes #178 (630d5ae)

2.0.6 (2022-04-15)

Bug Fixes

  • correctly add aliased re-exported bindings to lexical environment at all times. Fixes #109 (16d24fa)
  • correctly alias re-exported bindings which themselves may be aliased from other source files from the same chunk. Closes #176 (364b50b)

Features

  • add support for target ES2022 (6eec842)
  • add TypeScript v4.6 support (c387ff7)
  • generate correct declarations, diagnostics, and .tsbuildinfo when a Rollup cache is being used. Fixes #140 (afa76ed)

2.0.5 (2022-01-03)

Bug Fixes

  • don't break when another plugin declares an asset that only later receives a source. Fixes #162 (3ec4c86)
  • swc reject when set parser to typescript (3770470)

Features

  • when using swc and no browserslist could be resolved, pass the ecma version directly as a target instead of generating a browserslist based on it. Closes #163 (a2e88e5)

2.0.4 (2021-11-19)

Bug Fixes

  • regression in v2.0.3 on TypeScript <= 3.7 where ExportDeclarations could be dropped (f56c91c)

2.0.3 (2021-11-18)

Bug Fixes

  • group ExportDeclarations by not just module specifiers but also whether or not they or their individual ExportSpecifiers are 'isTypeOnly'. Fixes #153 (493014c)

2.0.2 (2021-11-17)

Features

  • add TypeScript v4.5 support (dffc8b7)

2.0.1 (2021-11-17)

Bug Fixes

  • fix a problem with resolving swc configs (677c928)

2.0.0 (2021-11-16)

Bug Fixes

  • add support for shimming regenerator-runtime when using swc as a transpiler (1513fc5)
  • ensure that the drive letter is prefixed to absolute paths on Windows when getSourceFile is called internally from TypeScript (f368af3)
  • ensure that the drive letter is prefixed to absolute paths on Windows when getSourceFile is called internally from TypeScript (cf6d3cc)
  • when emiting declarations, always use define for class fields to work around limitations introduced in TypeScript 4.3 for when bundling declarations when a subclass overrides a property from the parent class but doesn't provide an initializer (b25a494)

Features

  • add support for swc as a transpiler as an alternative to babel. #155 (e84d21c)
  • no longer depend on @babel/core types in npm package (d91ec74)

1.4.7 (2021-09-24)

Bug Fixes

  • remove unused dependency (e7a4c83)

Features

  • avoid duplicating inlined module-/namespace declarations and hoist nested ones. #149 (b21b20c)

1.4.6 (2021-09-21)

1.4.5 (2021-09-21)

1.4.4 (2021-09-21)

1.4.3 (2021-09-21)

Bug Fixes

  • fix an issue where exporting ArrayTypeNodes from other files could lead to corruption of declaration files. Closes #151 (27537be)

1.4.2 (2021-09-16)

Bug Fixes

  • work around incorrect imports in some @babel/runtime/helpers/esm files that may break when using babel as a transpiler without the commonjs plugin or something similar (d3daf35)

1.4.1 (2021-08-31)

1.4.0 (2021-06-03)

Tests

  • rewrite test runner to always work with virtual files. (3e64a92)

BREAKING CHANGES

  • update signature of the fileSystem option to expect a TypeScript System rather than a subset of it.

1.3.14 (2021-04-14)

Bug Fixes

  • declarations: fix TypeScript backwards compatibility (4f09009)

1.3.13 (2021-04-14)

Bug Fixes

  • logging: don't console log ModuleDeclarations (a513caa)

1.3.12 (2021-04-13)

Bug Fixes

  • deconflicting: add support for CallSignatures in deconflicting logic (3699a4e)
  • deconflicting: fix issue where ModuleDeclarations could sometimes not be traced back to an original SourceFile, leading to invalid deconflicting. Closes #129 (064b0c7)
  • namespace-exports: fix problem where ExportDeclarations- and/or ImportDeclarations are sometimes lost when inlining ModuleDeclarations. Closes #130 (deec007)
  • namespace: same import in multiple namespaces (9f69855)
  • tree-shaking: Correctly deconflict ExportDeclaration inside module wrappers and add support for deconflicting QualifiedNames. Closes #136 (6623ca2)

1.3.11 (2021-03-25)

1.3.10 (2021-03-16)

Bug Fixes

  • tree-shaking: update ImportEqualsDeclaration visitor to support TypeScript 4.2 (8e899ad)

Features

  • typescript: add support for TypeScript 4.2 (5239f59)

1.3.8 (2020-11-06)

1.3.7 (2020-10-26)

Bug Fixes

  • multi-entry: add interoperability with @rollup/plugin-multi-entry. Fixes #121 (1bd94f5)

1.3.6 (2020-10-21)

Features

  • add TypeScript 4.1 support (7292e78)

1.3.5 (2020-09-30)

Bug Fixes

  • declarations: fix issue where Namespace would not be created for ImportTypeNodes with no qualifiers (980e1da)

1.3.4 (2020-09-02)

Bug Fixes

  • declarations: add workaround for TypeScript issue 40361 for older TypeScript versions. Closes #108 (659775f)

1.3.3 (2020-08-23)

Bug Fixes

  • declarations: don't throw for JSDocDeprecatedTags. Closes #111 (4adb49d)

1.3.2 (2020-08-05)

1.3.1 (2020-07-31)

Bug Fixes

  • allowJs: don't attempt to include .mjs files in a TypeScript program to align with tsc behavior. Fixes #106 (f567d6c)

1.3.0 (2020-07-31)

Bug Fixes

  • external: respect 'external' option provided to Rollup and don't inline typings from modules matched by it (06f453a)

1.2.34 (2020-07-29)

Bug Fixes

  • hook: fix declarationPaths type signature (b8d6e7e)

1.2.33 (2020-07-29)

Features

  • hook: add 'declarationStats' hook. Fixes #92 (bcb7084)

1.2.32 (2020-07-29)

Bug Fixes

  • ensure that includedSourceFiles are always empty when allowDuplicate: true is passed as an option to includeSourceFile in moduleMerger. Fixes #90 (796b92a)

1.2.31 (2020-07-28)

Bug Fixes

  • cache: invalidate cached Programs if SourceFiles are added while it is being generated. Closes #83 (d1e9777)

1.2.30 (2020-07-28)

Bug Fixes

  • babel: babel configs cannot be resolved correctly. Closes #101. Closes #95 (044588e)

1.2.29 (2020-07-28)

Bug Fixes

  • add missing return statement (ded2524)
  • comments: improve bundling and tree-shaking of comments. Fixes #104 (559c420)
  • declarations are sometimes empty. Closes #105 (0e41f7c)

1.2.28 (2020-07-09)

Bug Fixes

  • path-mapping: fix an issue where path mapping for other baseUrls than '.' didn't work. Fixes #96 (7f6c429)

Features

  • add Christopher Blanchard as sponsor (a70d0e6)
  • typescript: add TypeScript v4 support. (165b366)

1.2.27 (2020-07-01)

Bug Fixes

  • Augment and merge non-namespace ModuleDeclarations. Closes #99 (c78bc52)
  • generate new lexical environment for ConstructorDeclaration body. Closes #100 (fe0aa94)

1.2.26 (2020-06-22)

1.2.25 (2020-06-10)

Bug Fixes

  • fix incompatibility with Windows (f3a1045)
  • fixed incorrect base path of tsconfig.json if it's inside a subdirectory (0cfbf70)
  • test: fixed the glob filter of the virtual file system (46ee07f)
  • use nativeDirname instead of dirname (9efe47d)

1.2.24 (2020-04-06)

Bug Fixes

  • regenerator: update inlined regenerator-runtime code to align with v0.13.5 (ab869f2)

1.2.23 (2020-03-30)

Bug Fixes

  • deconflicting: fix issue where local symbols could conflict with external ones under some circumstances. #88 (1f837f3)

1.2.22 (2020-03-28)

Features

  • typescript: add TypeScript v3.9 support (785dfa1)

1.2.21 (2020-03-06)

Bug Fixes

  • type-directive: fix an issue with generating type directives when declaration files are nested inside @types folder (e23a571)

1.2.20 (2020-03-06)

1.2.19 (2020-03-01)

Bug Fixes

  • make sure to respect entryFileNames and chunkFileNames when naming common declaration chunks (a98fe69)

1.2.18 (2020-02-29)

Bug Fixes

  • add 'isTypeOnly' to 'updateImportClause' helpers (9688e0e)
  • namespace-export: add support for named namespace exports (8aece24)

1.2.17 (2020-02-13)

Bug Fixes

  • respect declaration merging when identifiers are declared in the same SourceFile. Closes #81 (7e44925)
  • use statement merger on nested namespace declarations to remove binding-less imports/exports for prettier declaration output under some circumstances (d23a86e)

1.2.16 (2020-02-08)

Bug Fixes

  • don't force drive letter on relative paths (69350c7)
  • ensure that absolute paths on Windows always include the drive letter before passing it on to TypeScript (6713cb1)
  • fix bug on windows where paths weren't always normalized (c0b136b)

1.2.15 (2020-01-29)

1.2.14 (2020-01-27)

Bug Fixes

  • babel: unpin babel dependencies (9ea5335)

1.2.13 (2020-01-14)

Bug Fixes

  • stop relying on babel/core internals for finding configs and instead rely on the public API at all times (3b73419)

1.2.12 (2020-01-13)

Bug Fixes

  • Ensure that the Qualifier for ImportTypeNodes preserve the original binding name from external modules (c7db633)

1.2.11 (2020-01-13)

Bug Fixes

  • fix bug where ImportTypeNodes inside other ImportTypeNodes weren't tracked correctly (4369f0c)
  • fix bug where ImportTypeNodes would lose their type arguments (8ced5c9)

1.2.10 (2020-01-13)

Features

  • json: improve interoperability with @rollup/plugin-json (e9a64a7)

1.2.9 (2020-01-13)

1.2.8 (2020-01-12)

1.2.7 (2020-01-12)

Bug Fixes

  • fix issue with type aliasing classes. Closes #68 (e00fc5a)

1.2.6 (2020-01-11)

Bug Fixes

  • tree-shaking: fix issue where computed property names inside Property- and MethodSignatures would not count as a reference to a symbol. Make sure to create a new lexical environment for FunctionTypeNodes. Closes #69. (b7a0bd1)

1.2.5 (2020-01-10)

Bug Fixes

  • fix bug where ambient sources were mistakenly added to the Rollup graph. Closes #71. Improve JSDoc support. Closes #64 (5b9e7d7)
  • fix core-js self-referencing transformations when preset-env is combined with useBuiltIns: 'usage'. Closes #55 (b31478c)

1.2.4 (2020-01-07)

Bug Fixes

  • add support for incremental compilation. Closes #67. Closes #66 (c1e4dcc)

1.2.3 (2020-01-05)

Bug Fixes

  • allow generating SourceFiles for files matched by a user-provided 'exclude' glob. Closes #65 (c54c1e6)

1.2.2 (2020-01-05)

Bug Fixes

Performance Improvements

1.2.1 (2020-01-03)

Bug Fixes

  • fix issue with cloning MethodSignatures with modifiers. Closes #62 (bbffc35)

Performance Improvements

1.2.0 (2019-12-31)

Bug Fixes

  • babel: add @babel/plugin-syntax-dynamic-import as top-level dependency to improve pnpm support that relies on a nested dependency tree (387d4d1)
  • spread out tests to avoid memory issues on Node 8 on CI (ebec44c)
  • spread out tests to avoid memory issues on Node 8 on CI (3cc8021)

1.1.83 (2019-11-28)

Bug Fixes

  • bug: fix multiple aliased exports from same module (db29b86)

1.1.82 (2019-11-28)

Bug Fixes

  • bug: fix multiple aliased exports from same module (d7e7ec5)

1.1.81 (2019-11-28)

Bug Fixes

  • bug: fix with multiple duplicate reexports (294d7c5)

1.1.80 (2019-11-17)

Bug Fixes

  • builtins: fix issue where packages with identical names to built in modules wasn't resolvable. Closes #46 (fe266f6)

1.1.79 (2019-11-17)

Features

  • hook: add 'diagnostics' hook. Closes #50 (75fb907)

1.1.78 (2019-11-13)

Bug Fixes

  • bug: always use LF line endings when formatting with Prettier inside test runner (1a98dff)
  • bug: fix bug where paths could be POSIX on Windows in the modularizing phase (6401151)
  • bug: fix issue on Windows with generating declaration maps (3e971bc)
  • bug: support multiple environments inside code splitting tests (ca5aa78)

1.1.77 (2019-11-13)

Bug Fixes

  • bug: fix regression with same-chunk default exports. Closes #48 (0831af7)

1.1.76 (2019-11-11)

Features

  • statement merging: add support for merging type- and lib reference directives (92122b1)

1.1.75 (2019-11-11)

Bug Fixes

  • bug: fix bug that could lead to conflicting local symbols (de41822)
  • bug: fix bug where multiple rollup configs inside a compilation unit could lead to faulty cashes (2ad464b)

1.1.74 (2019-11-09)

Bug Fixes

  • ensure no needless identical propertyNames and names in ExportSpecifiers (eb448ec)

Features

  • allow to override the search base of the LIB_DIRECTORY lookup (26326a4)
  • declarations: declaration generation refactoring (ee3bfa0)
  • declarations: more refactoring work (25b21cb)

1.1.73 (2019-10-19)

Bug Fixes

  • bug: fix issue with generating declarations for files containing '.' in their file names (f1be238)
  • bug: fix issues with directory imports (implicit /index files) (5d329cd)

1.1.72 (2019-10-16)

Bug Fixes

  • bug: add missing TypeQueryNode wrapper when reassigning imported bindings to VariableDeclarations when bundling declarations. Fixes #36 (dcd2be4)

1.1.71 (2019-10-15)

Bug Fixes

  • bug: fix issue where exporting bindings from external libraries could lead to issues. Fixes #33 (7520fcf)

1.1.70 (2019-10-15)

1.1.69 (2019-10-15)

1.1.68 (2019-10-15)

1.1.67 (2019-10-15)

1.1.66 (2019-10-10)

Bug Fixes

  • declarations: makes sure to use 'declare' keyword where required, and to never use it for declarations within a namespace in an already ambient context. Fixes #24. Fixes #32 (b71e594)

1.1.65 (2019-09-30)

Features

  • hook: add hook that can rewrite output paths before files are emitted. (4ec63ba)

1.1.64 (2019-08-29)

1.1.63 (2019-08-12)

Features

  • declarations: mark export-less declaration files as modules (26ffe4b)

1.1.62 (2019-07-15)

Bug Fixes

  • bug: fixes an issue with resolving .babelrc files when no explicit path has been given. Closes #25 (be1c80b)

1.1.61 (2019-07-10)

Bug Fixes

  • bug: fixes an issue on Windows that could lead to duplicate symbols. Closes #23 (2183af2)

1.1.60 (2019-07-09)

1.1.59 (2019-06-21)

Bug Fixes

  • declaration maps: fixes issue with generating declaration maps (d45e5e1)

1.1.58 (2019-06-21)

1.1.57 (2019-06-20)

Bug Fixes

  • bug: rollback on Caniuse version to 4.6.2 which doesn't include a dependency on the bad version of caniuse-lite (78cbca4)
  • bug: rollback on Caniuse version to 4.6.2 which doesn't include a dependency on the bad version of caniuse-lite (0160ea9)

1.1.56 (2019-06-20)

Bug Fixes

  • bug: updates dependencies (15ed99c)

1.1.55 (2019-06-06)

Bug Fixes

  • windows: fixes issues with building and generating declarations on Windows. Fixes #19, #21. Fixes issue with transitive barrel exports. Fixes #10 (d41f915)

1.1.54 (2019-05-29)

Bug Fixes

  • bug: fixes regression with find-up (b2ef2de)

1.1.53 (2019-05-29)

Features

  • tsconfig: adds support for providing a function as argument to 'tsconfig' which receives CompilerOptions and allows you to override them. (6ff8fed)

1.1.52 (2019-04-26)

1.1.51 (2019-04-23)

Bug Fixes

  • bug: fixes a bug that could lead to infinite recursion when some runtime babel helpers would transform themselves (4f2eb9e)

1.1.50 (2019-04-22)

Features

  • options: makes it possible to pass in both proper CompilerOptions as well as raw, JSON-esque compiler options when giving the tsconfig as an option (0607b6d)

1.1.49 (2019-04-22)

Bug Fixes

  • bug: fixes a bug that could lead to missing exports (b52a245)

1.1.48 (2019-04-22)

Bug Fixes

  • bug: fixes a bug where the 'transpileOnly' option would never be respected (7bfe829)

1.1.47 (2019-04-17)

Bug Fixes

  • bug: fixes bug when producing declaration with namespace imports (808e59e)
  • bug: fixes issue with default exports of varying types (d9bdd2a)
  • bug: fixes issue with default exports of varying types (b01f4be)
  • bug: fixes issues where aliased imports could cause conflicts with merged symbols with name clashes (c5c97cb)
  • bug: fixes issues with aliased types with type parameters (702e108)
  • bug: refined handling of default exports of unnamed classes (0782f57)
  • bug: refined handling of default exports of unnamed functions (8efdaf7)

1.1.46 (2019-04-11)

Bug Fixes

  • bug: fixes issue where babel helpers would force ESM variants even though they were marked as external. Fixes #15 (f981b17)

Features

  • format: adds support for 'commonjs' and 'module' aliases for 'cjs' and 'esm' respectively (16153b9)

1.1.45 (2019-03-30)

1.1.44 (2019-03-30)

Bug Fixes

  • bug: fixes an issue with an injected identifier not being found at all times (1381c5e)

Features

  • EcmaVersion: adds support for generating browserslists for browsers with support for ES2019 (2c8ea0c)
  • typescript: makes it possible to detect and Ecma version for the ScriptTarget ES2019 (b336547)

1.1.43 (2019-03-28)

Bug Fixes

  • multi-entry: fixes an interoperability issue with rollup-plugin-multi-entry where declarations wouldn't be able to detect the entry modules for multi entry chunks (5c9c244)

1.1.42 (2019-03-28)

Bug Fixes

  • babel: fixes various issues with applying babel configs with glob/RegExp matching patterns as well as deduping and merging of config options. #13 (1b8f2ee)

1.1.41 (2019-03-27)

Bug Fixes

  • bug: fixes an issue with resolving regenerator-runtime (a7039ca)
  • bug: fixes bugs when 'allowJs' is true. Fixes bugs with providing tsconfig options directly (40d2152)

1.1.40 (2019-03-19)

Bug Fixes

  • bug: removes a console.log (1450fa7)

1.1.39 (2019-03-19)

Bug Fixes

  • bug: fixes an issue with babel where applying minification-related plugins could lead to syntax errors (2a91b7f)

1.1.38 (2019-03-19)

Bug Fixes

  • babel: made it possible to babel to use the 'target' of a tsconfig without a browserslist. Made it possible to resolve tslib and babel helpers without additional resolver plugins (76fd8a3)

1.1.37 (2019-03-18)

1.1.36 (2019-03-18)

Features

  • option: adds a new option 'transpileOnly' that can be toggled on to skip emitting (and checking for) diagnostics (1a916d5)
  • option: adds a new option 'transpileOnly' that can be toggled on to skip emitting (and checking for) diagnostics (90aaf8d)

1.1.35 (2019-03-14)

1.1.34 (2019-02-26)

Bug Fixes

  • bug: don't treeshake module declarations (a022c5d)
  • bug: fixed an issue with declarations (fb7e2ec)

1.1.33 (2019-02-26)

Bug Fixes

  • bug: fixes a bug where files with identical basenames, but varying extensions could lead to false positives when matching the cache under some circumstances (28f7a09)

1.1.32 (2019-02-26)

Bug Fixes

  • bug: fixes a bug where files with identical basenames, but varying extensions could lead to false positives when matching the cache under some circumstances (b560c03)

1.1.31 (2019-02-25)

1.1.30 (2019-02-25)

1.1.29 (2019-02-25)

Bug Fixes

  • bug: adds support for missing node types (b5de5ee)
  • bug: adds support for missing node types (608d38d)
  • bug: adds support for missing node types (9079f2d)
  • bug: adds support for missing node types (6a90228)
  • bug: fixes an issue where named exports could be removed under some circumstances (322df0c)
  • bug: fixes an issue with ExportAssignmens (cafa7ad)

Features

  • declarations: far improved support for default exports/imports while bundling declarations across chunks (4ad18d2)

1.1.28 (2019-02-06)

Bug Fixes

  • declarations: fixes an issue with generating declarations (1f93b05)

1.1.27 (2019-02-06)

1.1.26 (2019-02-06)

Bug Fixes

  • declarations: fixes an issue with detecting the entry file name for a chunk (7786000)

1.1.25 (2019-02-06)

Bug Fixes

  • declarations: fixes an issue with detecting the entry file name for a chunk (01cc892)

1.1.24 (2019-02-06)

Bug Fixes

  • bug: fixes a bug that could lead to misaligned content replacements (d40ddbf)

1.1.23 (2019-02-06)

Bug Fixes

  • declarations: fixes a variety of issues with generating declarations related to type-only files not being parsed in the declaration-emition phase (50310ae)
  • declarations: fixes an issue that arose with Rollup v1 where type-only files would not be part of the modules of emitted chunks. (043ae50)

1.1.22 (2019-02-04)

Bug Fixes

  • declarations: fixes an issue with generating declarations when ImportTypeNodes are being used (493d8b1)
  • dependencies: updates dependencies (ff72436)

1.1.21 (2019-01-27)

Bug Fixes

  • package: adds back tslib as a hard dependency (e6bcf1c)

1.1.20 (2019-01-24)

Bug Fixes

  • package: removes unneeded scripts (43a4c0d)

1.1.19 (2019-01-24)

Bug Fixes

  • bug: fixes an issue where default exports would be removed from declaration files (c2c18ed)
  • package: adds pretty-quick to commit hooks (c07c616)
  • package: removes unneeded scripts (4275919)

1.1.18 (2019-01-17)

Bug Fixes

  • bug: fixes an issue where 'default' keywords would not be stripped from nodes for which the 'export' keyword had been removed (ff0233e)

1.1.17 (2019-01-02)

1.1.16 (2018-12-30)

1.1.15 (2018-12-30)

Bug Fixes

  • chore: updated to Rollup v1.0.0 (e20e5b0)

1.1.14 (2018-12-21)

1.1.13 (2018-12-21)

1.1.12 (2018-12-20)

1.1.11 (2018-12-17)

1.1.10 (2018-12-13)

1.1.9 (2018-12-06)

1.1.8 (2018-12-05)

1.1.7 (2018-11-29)

1.1.6 (2018-11-28)

1.1.5 (2018-11-28)

1.1.4 (2018-11-14)

1.1.3 (2018-11-14)

1.1.2 (2018-11-13)

1.1.1 (2018-11-13)

1.1.0 (2018-11-12)

Features

  • performance and interoperability: improves performance and interoperability (53e1eba)

1.0.12 (2018-10-28)

1.0.11 (2018-10-28)

Features

  • declarations: improves declaration (.d.ts) generation by a huge margin. (348ff9f)

1.0.10 (2018-10-24)

1.0.9 (2018-10-23)

Bug Fixes

  • fixes issues with tracking type-only files via Rollup (da20aa2), closes #5

1.0.8 (2018-10-18)

1.0.7 (2018-10-18)

1.0.6 (2018-10-18)

Bug Fixes

  • release: Added 'files' array to package.json (b5f16bf)

1.0.5 (2018-10-18)

Bug Fixes

  • bug: Fixed an issue where declaration files found within a project directory wouldn't be discovered. (719d5bd)

1.0.4 (2018-10-18)

Features

  • interface: Interfaces for Plugin input options are now exported (b50683d)

1.0.3 (2018-10-18)

Features

  • interface: Interfaces for Plugin input options are now exported (a594de5)

1.0.2 (2018-10-18)

Features

  • interface: Interfaces for Plugin input options are now exported (9a93738)

1.0.1 (2018-10-17)

Bug Fixes

  • lint: Fixed linting issues (178499c)

1.0.0 (2018-10-17)

Features

  • Made JavaScript files resolved from the paths property inside a tsconfig be passed on to Rollup (a1c990c)
  • release: ground-up rewrite and some changes to the public API (e43045c), closes #2

BREAKING CHANGES

  • release: The 'babel' config option has been removed in favor of 'babelConfig' which may point to a file on disk (such as a '.babelrc' or a 'babel.config.js') or be a dictionary of Babel options.
  • release: The 'parseExternalModules' config option has been removed.

0.0.44 (2018-10-05)

0.0.43 (2018-09-28)

0.0.42 (2018-09-28)

0.0.41 (2018-09-26)

0.0.40 (2018-08-30)

0.0.39 (2018-08-30)

0.0.38 (2018-08-30)

0.0.37 (2018-08-25)

0.0.36 (2018-08-14)

0.0.35 (2018-08-09)

0.0.34 (2018-08-08)

0.0.33 (2018-08-08)

0.0.32 (2018-07-18)

0.0.31 (2018-07-18)

0.0.30 (2018-06-30)

0.0.29 (2018-06-27)

0.0.28 (2018-06-27)

0.0.27 (2018-06-25)

0.0.26 (2018-06-21)

0.0.25 (2018-06-13)

0.0.24 (2018-06-13)

0.0.23 (2018-06-12)

0.0.22 (2018-06-08)

0.0.21 (2018-06-08)

0.0.20 (2018-06-07)

0.0.19 (2018-06-07)

0.0.18 (2018-06-01)

0.0.17 (2018-05-30)

0.0.16 (2018-05-28)

0.0.15 (2018-05-01)

0.0.14 (2018-04-30)

0.0.13 (2018-04-30)

0.0.12 (2018-04-29)

0.0.11 (2018-04-29)

0.0.10 (2018-04-25)

0.0.9 (2018-04-18)

0.0.8 (2018-04-04)

0.0.7 (2018-03-31)

0.0.6 (2018-03-30)

0.0.5 (2018-03-30)

0.0.4 (2018-03-29)

0.0.3 (2018-03-29)

0.0.2 (2018-03-29)

0.0.1 (2018-03-29)