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

@m5r/ts-eager

v2.1.0

Published

Fast TypeScript runner using esbuild for eager compilation

Downloads

106

Readme

ts-eager

Fast TypeScript runner and register hook with eager compilation.

Similar to ts-node, except it uses esbuild – an extremely fast TypeScript transpiler – to eagerly compile all included files from your tsconfig.json on startup. This makes a noticeable difference for tasks where you're likely to load a good portion of your TS files, eg running tests.

It falls back to lazy compilation if a file is require'd that's not in tsconfig.json, and will also fallback to ts-node (if it's installed) for any type-specific compilation that esbuild doesn't support (such as emitDecoratorMetadata). It will also optionally require tsconfig-paths for paths support if your tsconfig needs it.

Installation

npm install -D ts-eager

# Optional, but recommended: for determining files from tsconfig.json
npm install -D typescript

# Optional, if you need emitDecoratorMetadata support
npm install -D ts-node

# Optional, if you need paths support
npm install -D tsconfig-paths

Usage

ts-eager myfile.ts

Or as a require hook:

node -r ts-eager/register myfile.ts

Configuration

ts-eager doesn't have any specific command-line options – it invokes node and passes all command-line arguments through.

It supports these environment variables:

  • TS_EAGER_LOGLEVEL: 'error' (default), 'warning', 'info', 'silent'
  • TS_NODE_PROJECT: tsconfig file (default tsconfig.json)
  • TS_NODE_IGNORE: comma separated regexes to skip compilation completely

Examples

If you want to customize which files ts-eager compiles up-front, you can specify a different tsconfig.json using TS_NODE_PROJECT, and then use the standard TypeScript include/exclude options in your config.

For example, if this was in tsconfig.test.json:

{
  "extends": "./tsconfig.json",
  "include": ["test"],
  "exclude": ["**/*.template.ts"]
}

Then you could run mocha like this:

TS_NODE_PROJECT=tsconfig.test.json mocha -r ts-eager/register

And it would only eagerly compile files in test, and exclude any matching *.template.ts.

mocha also supports adding require hooks in .mocharc.json:

{
  "recursive": true,
  "require": ["ts-eager/register"],
  "timeout": 5000
}