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

@ianwalter/release

v5.0.2

Published

CLI workflow for releasing JavaScript packages

Downloads

68

Readme

@ianwalter/release

CLI workflow for releasing JavaScript packages

npm page CI

Screenshot

About

HEAVILY inspired by np but with the following features:

  • Better support for yarn
  • A release branch workflow to help with GitHub master branch protections
  • Support for multiple (and external) registries

Workflow

  • [x] Check and fail if there are uncommited changes in the working directory
  • [x] Check and fail if upstream has new commits
  • [x] Display commits and prompt for a new semantic version if one wasn't specified as the first arugment
  • [x] Check and fail if version tag already exists locally or on remote
  • [x] Re-install dependencies
  • [x] Run linting if there's a lint script
  • [x] Run tests if there's a test script
  • [x] If --branch is specified, create a release branch, push it, link to a new PR, and prompt for a confirmation to publish
  • [x] Update the version in package.json and commit the version bump
  • [x] Create a tag and push it up
  • [x] Publish the package and display a link to create a new GitHub release with the tag from the previous step
  • [x] If --yolo is specified, most of checks are skipped and the last 3 steps are executed

Installation

yarn add @ianwalter/release --dev

CLI Usage

If you've installed release as a develoment dependency you can run it like:

yarn release [version]

The version number is optional. If not specified, you will be prompted for one.

Multiple Registries

You can specify that your package be published to multiple registries by configuring release in your package.json, for example:

{
  "release": {
    "registries": [
      "npm",
      "github",
      "https://some.other.registry.com/"
    ]
  }
}

You can specify npm for npm and github for GitHub Package Registry. Otherwise, specify the registry URL.

Release Branch Workflow

GitHub branch protections can make it difficult to commit version updates to your package.json before publishing. In order to get around this, you can specify the --branch flag and release will automatically create a release branch, commit the version update, and link to the pull request creation page on GitHub. It will then prompt you to confirm before publishing (unless you added the --yolo flag) so that you can get the PR reviewed. You can also supply a branch name to --branch if you don't want to use the generated one.

License

Hippocratic License - See LICENSE

 

Created by Ian Walter