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 🙏

© 2026 – Pkg Stats / Ryan Hefner

@ms-cloudpack/esm-stub-utilities

v0.15.49

Published

Generates ESM stubs for CommonJS entry files.

Downloads

1,789

Readme

@ms-cloudpack/esm-stub-utilities

This library contains utilities for generating ESM stubs for CommonJS modules. Some bundlers require this for extracting named exports needed to produce a browser-compatible ESM bundle.

Usage

Call writeESMStubsInWorker to generate stubs for CJS entries of a package:

import { writeESMStubsInWorker } from '@ms-cloudpack/esm-stub-utilities';

const esmStub = await writeESMStubsInWorker({
  inputPath: '/path/to/package',
  entries: {
    './entry1': './cjsEntry1.js',
    './entry2': './cjsEntry2.js',
  },
});

What is an ESM stub?

"ESM stubs" are a workaround for issues presented by CommonJS modules for Cloudpack's ESM library mode approach. The biggest problem is that CJS has many possible ways to declare exports, some of which are nontrivial or even impossible to find through static analysis. This isn't a problem in a monolithic bundle, but for an ESM bundle in library mode, all the export names must be declared in the bundle output so they can be imported by name in consuming packages. Some bundlers may attempt to convert common patterns to named exports, but others will just provide a default export.

The utilities in this package are used to run the package code, detect the actual exported names, and create an ES module format stub file with the proper exports (which can then be used as the bundler entry point). For example:

// Original file: index.js
module.exports.default = { value: 'I am the default export' };
// Example of a pattern that can't be statically analyzed (suppose it returns "a")
module.exports[computePropertyName()] = 'why';
module.exports.b = 'b';

// Generated stub file: index-stub.mjs
import moduleExport from './index.js';
const { a, b } = moduleExport;
const defaultExport = moduleExport?.default?.default ?? moduleExport?.default;
export default defaultExport;
export { a, b };

Currently, our primary approach for detecting export names is to run the code in a worker thread, with a browser-like environment provided for packages that need it. This has multiple significant downsides and we're actively considering other options (tracking issue), but running the code is the only way to approach 100% accuracy.

Special considerations

When evaluating named entries in the exports of the cjs file, the library is loaded in the Node process. A few libraries are used to simulate the browser environment in order for the script to load. (e.g. some libraries will reference window on load, and therefore must be run in an environment that accommodates this.)

Libraries which include a default entry in their exports will have that value preserved as the default export in the stub. However, libraries which export an object that doesn't have a default key will have the entire object exported as the default.

Libraries which export a function or literal value as the exports result will have a default export for that entry.

Some libraries don't export anything. In this case, the stub will simply import the entry.

Exported members that are keywords will be ignored. (e.g. module.exports = { 'delete': "foo" }; would be considered an empty export.)