npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

tsc-multi

v1.1.0

Published

Compile multiple TypeScript projects into multiple targets.

Downloads

318,136

Readme

tsc-multi

Test

Compile multiple TypeScript projects into multiple targets.

Features

Multiple targets

tsc-multi can compile your TypeScript projects into multiple modules (e.g. CommonJS, ESM) or targets (e.g. ES6, ES2018) in parallel.

Project references

tsc-multi supports project references, which are very useful for monorepo. It works just like tsc --build. File watching is also supported.

Rewrite import paths

tsc-multi rewrites all import paths in output files to maximize the compatibility across different platforms such as Node.js, web browser and Deno, because import paths are more strict in ESM.

Example:

// Input
import dir from "./dir";
import file from "./file";

// Output
import dir from "./dir/index.js";
import file from "./file.js";

Installation

npm install tsc-multi --save-dev

Usage

Create a tsc-multi.json in the folder.

{
  "targets": [
    { "extname": ".cjs", "module": "commonjs" },
    { "extname": ".mjs", "module": "esnext" }
  ],
  "projects": ["packages/*/tsconfig.json"]
}

Build TypeScript files.

tsc-multi

Watch changes and rebuild TypeScript files.

tsc-multi --watch

Delete built files.

tsc-multi --clean

Configuration

targets

Build targets. All options except extname will override compilerOptions in tsconfig.json.

{
  // Rename the extension of output files
  extname: ".js",
  // Skip type-checking (Experimental)
  transpileOnly: false,
  // Compiler options
  module: "esnext",
  target: "es2018",
}

projects

Path to TypeScript projects. It can be either a folder which contains tsconfig.json, or the path to tsconfig.json. This option can be set in either config file or CLI.

[
  // CWD
  ".",
  // Folder
  "pkg-a",
  // tsconfig.json path
  "tsconfig.custom.json",
  // Glob
  "packages/*/tsconfig.json",
];

compiler

Specify a custom TypeScript compiler (e.g. ttypescript).

maxWorkers

Specify the maximum number of concurrent workers.

CLI Options

--watch

Watch input files and rebuild when they are changed.

--clean

Delete built files. Only available when compilerOptions.rootDir is specified in tsconfig.json.

--verbose

Print debug logs.

--cwd

Specify the current working directory (CWD).

--config

Specify the path of the config file. The path can be either a relative path or an absolute path. Default to $CWD/tsc-multi.json.

--compiler

Specify a custom TypeScript compiler.

--dry

Show what would be done but doesn't actually build anything.

--force

Rebuild all projects.

--maxWorkers

Specify the maximum number of concurrent workers.

Caveats

  • Only file extension can be renamed currently.
  • Only CommonJS and ESM are tested currently, AMD, UMD or SystemJS modules may have issues.
  • When workers read/write type declaration files (.d.ts), there are few chances that TypeScript compiler might read files that is writing by other workers. This usually only happens on machines with poor IO performance. Set maxWorkers to 1 may help.

License

MIT