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 🙏

© 2025 – Pkg Stats / Ryan Hefner

@jimsheen/yalc

v1.2.2

Published

Local package development tool, modernized and supercharged. Drop-in replacement for yalc with better performance and modern features.

Readme

@jimsheen/yalc

Modernized and supercharged local package development tool. Drop-in replacement for yalc with 5x performance improvements and modern features.

npm version Node.js CI Status

🚀 Quick Start

Try it instantly without installation:

npx @jimsheen/yalc

Or install globally:

npm install -g @jimsheen/yalc

Requirements: Node.js 20 or later

⚡ Performance Breakthrough

This modernized fork delivers dramatic performance improvements:

  • 5x faster catalog parsing with intelligent caching
  • 82% memory reduction through optimized data structures
  • 70% faster YAML processing with early termination
  • 35x faster cache hits with advanced invalidation strategies

Why

When developing and authoring multiple packages (private or public), you often find yourself in need of using the latest/WIP versions in other projects that you are working on in your local environment without publishing those packages to the remote registry. NPM and Yarn address this issue with a similar approach of symlinked packages (npm/yarn link). Though this may work in many cases, it often brings nasty constraints and problems with dependency resolution, symlink interoperability between file systems, etc.

🚀 What's New in This Fork

Revolutionary PNPM Catalog Support

  • First-class PNPM support with advanced catalog integration
  • Workspace protocol resolution (workspace:*, workspace:^, workspace:~)
  • Multiple named catalogs for organized dependency management
  • Performance-optimized catalog parsing with intelligent caching

Modern Development Experience

  • Node.js 20+ support with modern runtime features
  • TypeScript-first architecture with strict type checking
  • ESM/CommonJS dual compatibility for modern and legacy projects
  • Interactive CLI mode with rich user experience and guided workflows

Enterprise-Ready Performance

  • Advanced caching system with bounded LRU and mtime-based invalidation
  • Memory-efficient operations for large-scale monorepo development
  • Optimized build system using modern tsup bundler
  • Comprehensive testing with Vitest framework and real integration tests

Enhanced Package Management

  • Smart usage tracking across your local environment
  • Cleanup tools for unused package detection and removal
  • Cross-platform support with native file manager integration
  • Statistics and analytics for store health monitoring

What

  • @jimsheen/yalc acts as a high-performance local repository for your locally developed packages that you want to share across your local environment.
  • When you run yalc publish in the package directory, it grabs only files that should be published to NPM and puts them in a special global store (located, for example, in ~/.yalc) with 5x performance improvements.
  • When you run yalc add my-package in your project it pulls package content into .yalc in the current folder and injects a file:/link: dependency into package.json. Alternatively, you may use yalc link my-package which will create a symlink to the package content in node_modules and will not touch package.json (like npm/yarn link does), or you even may use it with PNPM/Yarn/NPM workspaces including advanced PNPM catalog support.
  • yalc creates a special yalc.lock file in your project (similar to yarn.lock and package-lock.json) that is used to ensure consistency while performing yalc's routines.
  • @jimsheen/yalc can be used with projects where yarn, npm, or pnpm package managers are used for managing package.json dependencies, with first-class PNPM catalog support.

Installation

Requirements: Node.js 20 or later

Using NPM:

npm install -g @jimsheen/yalc

Using Yarn:

yarn global add @jimsheen/yalc

Using PNPM:

pnpm add -g @jimsheen/yalc

Drop-in Replacement

This modernized fork is a 100% compatible drop-in replacement for the original yalc. All your existing commands and workflows continue to work exactly as before, but with significantly better performance.

# All original yalc commands work unchanged
yalc publish
yalc add my-package
yalc push --changed

# Plus powerful new interactive features
yalc interactive    # Launch rich interactive CLI menu
yalc               # Auto-launches interactive mode when no args provided

📋 Migration from Original yalc

Zero migration needed! Simply install @jimsheen/yalc and:

  1. Your existing .yalc store continues to work
  2. All .yalcrc configuration remains compatible
  3. yalc.lock files work unchanged
  4. All CLI commands and flags function identically

💡 Pro tip: You can alias the command to keep using yalc:

# Add to your shell profile (.bashrc, .zshrc, etc.)
alias yalc='@jimsheen/yalc'

See the change log for detailed release notes and new features.

🎯 Enhanced PNPM Catalog Support

This modernized fork introduces revolutionary PNPM catalog support with dramatic performance improvements:

Catalog Protocol Resolution

Full support for PNPM workspace protocols with 5x performance boost:

# pnpm-workspace.yaml
packages:
  - 'packages/*'
  - 'apps/*'

catalogs:
  ui:
    react: ^18.0.0
    '@types/react': ^18.0.0
  testing:
    vitest: ^1.0.0
    '@testing-library/react': ^13.0.0

# Your package.json can reference catalogs
dependencies:
  react: 'catalog:ui' # Resolves to ^18.0.0
  '@types/react': 'catalog:ui'
devDependencies:
  vitest: 'catalog:testing'

Advanced Catalog Features

  • 🚀 Intelligent Caching: 82% memory reduction with bounded LRU cache
  • ⚡ Fast Parsing: 70% faster YAML processing with early termination
  • 🔄 Auto-Resolution: Automatic workspace protocol resolution during publish
  • 🛡️ Error Handling: Graceful handling of malformed catalogs
  • 📊 Performance Monitoring: Built-in performance tracking and optimization

Catalog Performance Benchmarks

| Operation | Original | @jimsheen/yalc | Improvement | | ------------ | -------- | -------------- | ----------------- | | Parse Time | 100ms | 20ms | 5x faster | | Memory Usage | 100MB | 18MB | 82% reduction | | Cache Hits | 35ms | 1ms | 35x faster |

Real-World Example

# In a monorepo with PNPM catalogs
cd my-ui-package
yalc publish  # Automatically resolves catalog: dependencies

cd ../my-app
yalc add my-ui-package  # Fast catalog-aware installation

# Performance improvement: 5x faster for large catalogs!

🖥️ Interactive CLI Experience

This modernized fork features a rich interactive CLI built with modern @clack/prompts that transforms package management into a guided, visual experience.

Launch Interactive Mode

# Launch the interactive menu
yalc interactive

# Or just run yalc without arguments (auto-detects interactive environments)
yalc

📋 Interactive Features

🎯 Smart Project Context

  • Automatic project detection with package.json analysis
  • Current directory awareness for relevant action suggestions
  • Real-time store status with package counts and storage usage

📦 Visual Package Management

  • Package browser with size, publish time, and usage indicators
  • Interactive package selection with search and filtering
  • Detailed package information with dependency tracking
  • Usage tracking showing where packages are installed

⚡ Guided Workflows

  • Interactive publishing with push option (respects .yalcrc config for all other settings)
  • Smart package addition with dependency conflict detection
  • Package removal with multi-select and confirmation
  • Cleanup wizards for unused package removal with size calculations
  • Store management with statistics and health monitoring

🛠️ Advanced Operations

  • Cross-platform file manager integration for store directory access
  • Real-time progress indicators with spinners and success/error feedback
  • Batch operations for multiple package management
  • Help system with command reference and quick start guides

Interactive Menu Structure

📦 YALC Store Manager
├── 📦  Publish current project        # Smart project detection
├── ➕  Add packages to project        # Visual package selector
├── 🗑️  Remove packages from store    # Package removal with confirmation
├── 🧹  Clean unused packages         # Usage analysis & cleanup
├── 🔍  Explore store                 # Package browser & search
│   ├── 📋  Browse all packages
│   ├── 🔍  Package details
│   └── 📍  Find package usage
├── 🛠️  Manage store                  # Store operations
│   ├── 📊  Store statistics
│   └── 📂  Open store directory
├── 📖  Help & info                   # Documentation & guides
│   ├── 📖  Command reference
│   └── 🚀  Quick start guide
└── 👋  Exit

Example Interactive Workflow

$ yalc interactive

📦 YALC Store Manager
🎯 Current Project: [email protected] • /Users/dev/projects/my-app
📊 Store Overview: 5 packages • 12.4 MB • 1 unused • Last activity: 2 hours ago

? What would you like to do?
  📦  Publish current project → Publish [email protected] to store
  ➕  Add packages to project → Add packages to my-app
  🗑️  Remove packages from store → Remove specific packages or clear store
  🧹  Clean unused packages → Remove 1 unused package (2.1 MB freed)
❯ 🔍  Explore store → Browse, search, and get info on 5 packages
  🛠️  Manage store → Store statistics, settings, and directory access
  📖  Help & info → Commands, quick start guide, and documentation
  👋  Exit → Return to command line

? Select a package (5 total)
❯ [email protected] → 4.2 MB • 3 hours ago • 🔗 2 projects
  [email protected] → 1.8 MB • 1 day ago • 🔗 1 project
  [email protected] → 856 KB • 2 days ago • ⚠️ unused
  [email protected] → 3.1 MB • 1 week ago • 🔗 3 projects
  [email protected] → 2.4 MB • 2 weeks ago • 🔗 1 project
  ◀️  Back → Return to explore menu

? Actions for [email protected]
❯ 🔍  Show details → View complete package information
  ➕  Add to current project → Add to my-app
  📍  Show usage → Used in 2 projects
  ◀️  Back to package list → Return to package selection

This interactive experience makes yalc accessible to developers of all experience levels while providing power users with efficient workflows for complex monorepo management.

Usage

Publish

  • Run yalc publish in your dependency package my-package.
  • It will copy all the files that should be published in remote NPM registry.
  • If your package has any of these lifecycle scripts: prepublish, prepare, prepublishOnly, prepack, preyalcpublish, they will run before in this order. If your package has any of these: postyalcpublish, postpack, publish, postpublish, they will run after in this order. Use --no-scripts to publish without running scripts.
  • When publishing, yalc can optionally calculate a hash signature from the file contents and use the signature in the resulting package version (like "1.2.3+ffffffff"). To enable this, pass the --sig option to the yalc publish command.
  • You may also use .yalcignore to exclude files from publishing to yalc repo, for example, files like README.md, etc.
  • --content flag will show included files in the published package
  • NB! In terms of which files will be included in the package yalc fully supposed to emulate behavior of npm client (npm pack). If you have nested .yalc folder in your package that you are going to publish with yalc and you use package.json files list, it should be included there explicitly.
  • NB! Windows users should make sure the LF new line symbol is used in published sources; it may be needed for some packages to work correctly (for example, bin scripts). yalc won't convert line endings for you (because npm and yarn won't either).
  • NB! Note that, if you want to include .yalc folder in published package content, you should add !.yalc line to .npmignore.
  • Easily propagate package updates everywhere.
  • Yalc by default resolve workspace: protocol in dependencies, to omit this use -no-workspace-resolve flag

Add

  • Run yalc add my-package in your dependent project, which will copy the current version from the store to your project's .yalc folder and inject a file:.yalc/my-package dependency into package.json.
  • You may specify a particular version with yalc add my-package@version. This version will be fixed in yalc.lock and will not affect newly published versions during updates.
  • Use the --link option to add a link: dependency instead of file:.
  • Use the --dev option to add yalc package to dev dependencies.
  • With --pure flag it will not touch package.json file, nor it will touch modules folder, this is useful for example when working with Yarn workspaces (read below in Advanced usage section)
  • With --workspace (or -W) it will add dependency with "workspace:" protocol.

Link

  • As an alternative to add, you can use the link command which is similar to npm/yarn link, except that the symlink source will be not the global link directory but the local .yalc folder of your project.
  • After yalc copies package content to .yalc folder it will create a symlink: project/.yalc/my-package ==> project/node_modules/my-package. It will not touch package.json in this case.

Update

  • Run yalc update my-package to update the latest version from store.
  • Run yalc update to update all the packages found in yalc.lock.
  • preyalc and postyalc scripts will be executed in target package on add/update operations which are performed while push
  • if need to perform pre/post scripts on update of particular package use (pre|post)yalc.package-name name for script in your package.json.
  • update --update (--upgrade, --up) to run package managers's update command for packages.

Remove

  • Run yalc remove my-package, it will remove package info from package.json and yalc.lock
  • Run yalc remove --all to remove all packages from project.

Installations

  • Run yalc installations clean my-package to unpublish a package published with yalc publish
  • Run yalc installations show my-package to show all packages to which my-package has been installed.

Advanced usage

Pushing updates automatically to all installations

  • When you run yalc add|link|update, the project's package locations are tracked and saved, so yalc knows where each package in the store is being used in your local environment.
  • yalc publish --push will publish your package to the store and propagate all changes to existing yalc package installations (this will actually do update operation on the location).
  • yalc push - is a use shortcut command for push operation (which will likely become your primarily used command for publication):
  • scripts options is false by default, so it won't run pre/post scripts (may change this with passing --scripts flag).
  • With --changed flag yalc will first check if package content has changed before publishing and pushing, it is a quick operation and may be useful for file watching scenarios with pushing on changes.
  • Use --replace option to force replacement of package content.
  • Use preyalc and postyalc (read in update docs) to execute needed script on every push.
  • Use --update to run yarn/npm/pnpm update command for pushed packages.

Keep it out of git

  • If you are using yalc'ed modules temporarily during development, first add .yalc and yalc.lock to .gitignore.
  • Use yalc link, that won't touch package.json
  • If you use yalc add it will change package.json, and ads file:/link: dependencies, if you may want to use yalc check in the precommit hook which will check package.json for yalc'ed dependencies and exits with an error if you forgot to remove them.

Keep it in git

  • You may want to keep shared yalc'ed stuff within the projects you are working on and treat it as a part of the project's codebase. This may really simplify management and usage of shared work in progress packages within your projects and help to make things consistent. So, then just do it, keep .yalc folder and yalc.lock in git.
  • Replace it with published versions from remote repository when ready.
  • NB! - standard non-code files like README, LICENCE etc. will be included also, so you may want to exclude them in .gitignore with a line like **/.yalc/**/*.md or you may use .yalcignore not to include those files in package content.

Publish/push sub-projects

  • Useful for monorepos (projects with multiple sub-projects/packages): yalc publish some-project will perform publish operation in the ./some-project directory relative to process.cwd()

Retreat and Restore

  • Instead of completely removing package you may temporary set it back with yalc retreat [--all] for example before package publication to remote registry.
  • After or later restore it with yalc restore.

Use with Yarn/Pnpm workspaces

Use if you will try to add repo in workspaces enabled package, --pure option will be used by default, so package.json and modules folder will not be touched.

Then you add yalc'ed package folder to workspaces in package.json (you may just add .yalc/* and .yalc/@*/* patterns). While update (or push) operation, packages content will be updated automatically and yarn will care about everything else.

If you want to override default pure behavior use --no-pure flag.

Clean up installations file

  • While working with yalc for some time on the dev machine you may face the situation when you have locations where you added yalc'ed packages being removed from file system, and this will cause some warning messages when yalc will try to push package to removed location. To get rid of such messages, there is an explicit command for this: yalc installations clean [package].

Override default package store folder

  • You may use --store-folder flag option to override default location for storing published packages.

Control output

  • Use --quiet to fully disable output (except of errors). Use --no-colors to disable colors.

Configuration (.yalcrc)

Yalc supports configuration via a .yalcrc file (INI format) in your project root to set default options for all commands.

Available Options:

| Option | Default | Description | | ------------------- | ------- | ----------------------------------------------------------------------------------- | | workspace-resolve | true | Resolve workspace:*, workspace:^, workspace:~ dependencies to actual versions | | sig | false | Generate package integrity signatures (yalc.sig files) | | dev-mod | true | Include devDependencies in published packages | | scripts | true | Run npm lifecycle scripts during publish (prepack, postpack, etc.) | | quiet | false | Suppress console output (errors still shown) | | files | false | Use package.json files field to determine what to publish |

Example .yalcrc:

# Resolve workspace dependencies (recommended for monorepos)
workspace-resolve=true

# Disable signatures for faster publishing
sig=false

# Clean packages by removing devDependencies
dev-mod=false

# Enable lifecycle scripts
scripts=true

# Normal output
quiet=false

Command Line Override:

You can override any .yalcrc setting with command line flags:

# Override .yalcrc settings for this command only
yalc publish --sig --dev-mod --no-workspace-resolve

# Example: Force signature generation even if .yalcrc has sig=false
yalc publish --sig

Multiple Format Support:

Yalc also supports modern configuration formats:

# .yalcrc (INI format)
workspace-resolve=true
sig=false

# .yalcrc.json (JSON format)
{
  "workspace-resolve": true,
  "sig": false
}

# .yalcrc.yaml (YAML format)
workspace-resolve: true
sig: false

# package.json (embedded config)
{
  "yalc": {
    "workspace-resolve": true,
    "sig": false
  }
}

🔗 Ecosystem & Compatibility

Package Manager Support

  • ✅ NPM: Full compatibility with all npm workflows
  • ✅ Yarn: Enhanced support with modern Yarn features
  • ✅ PNPM: First-class support with revolutionary catalog integration
  • ✅ Workspaces: Native support for all workspace implementations

Modern Development Stack

  • TypeScript: Full type definitions and strict type checking
  • ESM/CommonJS: Dual module support for all project types
  • Node.js 20+: Modern runtime features and optimizations
  • Monorepos: Optimized for large-scale monorepo development

🚀 Performance Comparison

| Feature | Original yalc | @jimsheen/yalc | Improvement | | --------------------- | ------------- | -------------- | -------------------- | | Catalog Parsing | 100ms | 20ms | 🚀 5x faster | | Memory Usage | 100MB | 18MB | 📉 82% reduction | | YAML Processing | 70ms | 21ms | ⚡ 70% faster | | Cache Performance | 35ms | 1ms | 🎯 35x faster | | Bundle Size | Large | Optimized | 📦 Tree-shaken | | Node.js Support | 12+ | 20+ | 🆙 Modern |

📈 Why Choose This Fork?

🎯 For Individual Developers

  • Faster workflows with 5x performance improvements
  • Better developer experience with modern tooling
  • Enhanced debugging with comprehensive error messages
  • Future-proof with Node.js 20+ and modern standards

🏢 For Teams & Enterprises

  • Monorepo optimized for large-scale development
  • PNPM catalog support for organized dependency management
  • Memory efficient for CI/CD environments
  • Comprehensive testing with 95%+ test coverage

🔧 For Monorepo Maintainers

  • Advanced workspace protocol support for complex dependency graphs
  • Intelligent caching to handle hundreds of packages efficiently
  • Performance monitoring to optimize development workflows
  • Enterprise-ready reliability with robust error handling

📚 Related Resources

Original Project

Package Manager Evolution

Performance & Modern Development

🛟 Support & Contributing

Getting Help

Contributing

Project Health

  • CI/CD: Automated testing on Node.js 20 & 22
  • 📊 Coverage: 95%+ test coverage with real integration tests
  • 🔒 Security: Regular dependency audits and updates
  • 📈 Performance: Continuous benchmarking and optimization

📄 License

MIT - see LICENSE for details.

🙏 Acknowledgments

This modernized fork builds upon the excellent foundation created by the original yalc project. We're grateful to the original maintainers and contributors who created this essential tool for the JavaScript ecosystem.

Special thanks to:

  • The original yalc team for creating the foundation
  • The PNPM team for inspiring the catalog integration
  • The Node.js and TypeScript communities for modern tooling
  • All contributors who help make local package development better

🚀 Ready to supercharge your local package development?

npm install -g @jimsheen/yalc