JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 25415
  • Score
    100M100P100Q136911F
  • License MIT

The smallest update notifier for NPM packages, useful for CLI apps.

Package Exports

  • tiny-updater

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (tiny-updater) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Tiny Updater

The smallest update notifier for NPM packages, useful for CLI apps.

Pros & Cons

This is basically a bare-bones alternative to update-notifier, with all the pros and cons of that.

  • Tiny: This library weighs ~5kb once bundled, and has only a handful of tiny and reliable dependencies. update-notifier on the other hand requires ~1mb of stuff, that's ~200x more stuff.
  • Bundler-ready: This library can be bundled, which is important for achieving the best startup times. update-notifier on the other hand uses highly dyanmic imports and spawns a child process, if you are using it you can't bundle your CLI app.
  • Fast: Startup performance is paramount for CLI apps, in order to improve that you need to bundle your app and make the bundle as small as possible, using this library won't compromise your startup times.
  • Bare-bones: Being lightweight comes at a cost, that cost is mainly less visually-sophisticated update messages written to the console compared to update-notifier, but still I think the output is pretty good.
  • Work in progress: While this library should suit most use cases it's currently less flexible than update-notifier, if you need something fancy this may not work for you.

Install

npm install --save tiny-updater

Usage

import updater from 'tiny-updater';
import {name, version} from './package.json';

await updater ({ name, version });

// If there are no updates available:
// 1. `false` is returned
// 2. Nothing is logged to the console

// If there is an update available:
// 1. `true` is returned
// 2. Right before the process exists a message like the following is logged to the console:
// 📦 Update available for example-package: 0.1.0 → 1.0.0

License

MIT © Fabio Spampinato