Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/kachkaev/njt

njt (npm jump to): a quick navigation tool for npm packages
https://github.com/kachkaev/njt

frog jump meta njt npm npmjs productivity search search-engine shortcuts vercel vercel-deployment

Last synced: 3 days ago
JSON representation

njt (npm jump to): a quick navigation tool for npm packages

Awesome Lists containing this project

README

        

🐸 njt 🐸


🐸 npm jump to 🐸

njt.vercel.app

Do you type package names in your search engine and then navigate to their source, homepage, changelog and so on? πŸ•πŸ•‘πŸ•’πŸ•“πŸ•”

[Save five seconds thousands of times](https://xkcd.com/1205/) by quickly jumping to the right URL:

```txt
🐸✨🐸✨🐸
njt [destination]
🐸✨🐸✨🐸
```

## Available destinations

- `b` β†’ package cost estimation on [bundlephobia.com](https://bundlephobia.com)
- `c` β†’ changelog
- `g` β†’ github (gitlab, etc.) repository root
- `h` β†’ homepage (aliased as `w` for website or `d` for docs)
- `i` β†’ issues
- `n` β†’ package info on [npmjs.com](https://www.npmjs.com)
- `p` β†’ pull requests (aliased as `m` for merge requests)
- `r` β†’ list of github releases
- `s` β†’ source (often same as repository root, but can be its subdirectory in case of a monorepo)
- `t` β†’ list of git tags
- `u` β†’ package contents preview on [unpkg.com](https://unpkg.com)
- `v` β†’ list of package versions with dates on [npmjs.com](https://www.npmjs.com)
- `y` β†’ package page on [yarnpkg.com](https://yarnpkg.com) (mirror registry for [npmjs.com](https://www.npmjs.com))
- `.` β†’ browse GitHub / GitLab code

Omitting the destination or entering an non-existing one takes you to the package page on [npmjs.com](https://www.npmjs.com) as if you used `n`.

## Examples

`njt prettier` (no specified destination)
🐸 β†’

`njt prettier h` (homepage)
🐸 β†’

`njt prettier s` (source)
🐸 β†’

`njt prettier r` (releases)
🐸 β†’

`njt prettier y` (yarn)
🐸 β†’

## Getting `njt`

There are several environments in which you can access `njt`.
Pick your favourite or use ’em all!

### 🟒 Command-line tool

Install `njt` globally [from npm](https://www.npmjs.com/package/njt) by running this command in your terminal:

```bash
npm install --global njt
```

You are all set.
Now try executing `njt [destination]` with some real arguments.
For example, these two commands will take you to the Lodash **g**ithub repo and **h**omepage, respectively:

```bash
njt lodash g
njt lodash h
```

A list of supported destinations will be shown if you launch `njt` without arguments.

To uninstall, run `npm remove --global njt`.
To reinstall or upgrade, run `npm install --global njt` again.

**Pro tip πŸ’‘** When you specify `.` instead of a package name, `njt` takes the name from the nearest `package.json` file.

**Pro tip πŸ’‘** To customise which browser you want to open, set an environment variable called `NJT_BROWSER` (or just `BROWSER`) with the app name of your choice.
The value [may vary](https://www.npmjs.com/package/open#app) based on your OS.
Note that setting `BROWSER` instead of `NJT_BROWSER` can affect other tools, which may or may not be desired.

### 🟒 Custom search engine in Chrome

1. Open Chrome settings, e.g. by navigating to `chrome://settings`
1. Navigate to _Manage search engines_ section (e.g. by typing its name in the _Search settings_ field)
1. Click _Add_ next to _Other search engines_
1. Fill in the _Add search engine_ form:

| Field | Value |
| ----------------------------- | ----------------------------------------------- |
| Search engine | `njt (npm jump to)` |
| Keyword | `njt` |
| Url with %s in place of query | `https://njt.vercel.app/jump?from=chrome&to=%s` |

1. Press _Add_

From now on, typing `njt [destination]` in the address bar will take you directly to a page you want.
For example, `njt react h` will take you to the [React.js homepage](https://reactjs.org).

To uninstall, open _Manage search engines_ section in Chrome settings, click on three dots next to _Other search engines β†’ njt_ and hit _Remove from list_.

**Pro tip πŸ’‘** You can use `n` instead of `njt` as a keyword to avoid typing two extra characters each time.
The command to type in Chrome address bar will become `n [destination]` πŸš€

### 🟒 Search bookmark in Firefox

You can use `njt` right from the address bar in Firefox.

1. Open [njt.vercel.app](https://njt.vercel.app)
1. Right-click on the search input field
1. In the context menu, select _Add Keyword for this Search..._
1. You’ll see a small form; type `njt` into the _Keyword_ field
1. Press _Save_

From now on, typing `njt [destination]` in the address bar will take you directly to a page you want.
For example, `njt react h` will take you to the [React.js homepage](https://reactjs.org).

To uninstall, open Firefox bookmarks from the main menu, search for `njt` and remove the bookmark.

**Pro tip πŸ’‘** You can use `n` instead of `njt` as a search keyword to avoid typing two extra characters each time.
The command to type in Firefox address bar will become `n [destination]` πŸš€

### 🟒 Alfred web search

Want to hop directly from [Alfred launcher](https://www.alfredapp.com/)?

1. Open _Preferences_ β†’ _Features_ β†’ _Web Search_
1. Click _Add Custom Search_
1. Fill in the form:

| Field | Value |
| ---------- | ---------------------------------------------------- |
| Search URL | `https://njt.vercel.app/jump?from=alfred&to={query}` |
| Title | `Search njt for '{query}'` |
| Keyword | `njt` |
| Icon | drag from |

1. Press _Save_

Alternatively, copy and open this special Alfred link to get all the above steps done for you:

```txt
alfred://customsearch/Search%20njt%20for%20%27%7Bquery%7D%27/njt/utf8/nospace/https%3A%2F%2Fnjt.vercel.app%2Fjump%3Ffrom%3Dalfred%26to%3D%7Bquery%7D
```

**Pro tip πŸ’‘** You can use `n` instead of `njt` as a search keyword to avoid typing two extra characters each time.
The command to type in Alfred address bar will become `n [destination]` πŸš€

You can also create variants with your favorite `njt` suffixes to jump to your favorite locations in even fewer characters.
For example, keyword `ng` can be a shortcut to `njt {query} g`.

### 🟒 VSCode

If you use Visual Studio Code, you can add njt to the command palette via [LaunchX](https://marketplace.visualstudio.com/items?itemName=neibla.launchx) extension.

1. [Install the extension](vscode:extension/neibla.launchx)

1. Open the command palette

1. Type `njt` and press Enter

![njt in VSCode command palette](assets/vscode-launchx.png)

1. Type your search and press Enter again

**Pro tip πŸ’‘** Use `ctrl+alt+n` to bypass the command palette.

### 🟒 DuckDuckGo bang

> DuckDuckGo bang is awaiting approval (please help if you know how to speed up the process).

If you use [duckduckgo.com](https://duckduckgo.com) as your primary search engine, type `!njt [destination]` in its search field (note the leading exclamation mark).
This trick is possible thanks to DuckDuckGo’s awesome [bang feature](https://duckduckgo.com/bang).

### 🟒 Online search field on the `njt`’s mini-website

Open [njt.vercel.app](https://njt.vercel.app), type your query, press Enter.
This method is a bit slower than the other ones because it involves opening a web page with an input form.
On the plus side, it works everywhere and does not require setup.

Thanks to [Vercel](https://vercel.com) for hosting [njt.vercel.app](https://njt.vercel.app) πŸ’š

### ❓More ways

Are you a search shortcut guru?
Feel free [to suggest](https://github.com/kachkaev/njt/issues/new?title=New+entry+point+suggestion) another entry point to `njt` and save people’s time around the world!

## How `njt` works

### Query resolution

The logic of `njt` is centralized and located within the `njt.vercel.app/jump` endpoint ([source](pages/api/jump.handler.ts)).

All `njt` interfaces submit user queries to `https://njt.vercel.app/jump?from=UI_ID&to=USER_QUERY`, from which you are redirected to the destination.

For queries like `njt ` or `njt y`, the redirects are straightforward: `https://www.npmjs.com/package/` or `https://yarnpkg.com/package/`.

Most other cases involve a look into `package.json` for the latest version of the searched package.
This file is fetched from [www.npmjs.com](https://www.npmjs.com).
It contains the location of the repository, the homepage and some other fields which are used to construct the destination URL.

### Privacy

Official `njt` interfaces and the `njt.vercel.app/jump` endpoint do not store submitted queries.
Since [njt.vercel.app](https://njt.vercel.app) is hosted by Vercel, performance and usage data is logged by the infrastructure (see [Vercel Analytics](https://vercel.com/analytics)).

When `njt` navigates to `https://njt.vercel.app/jump?from=UI_ID&to=USER_QUERY`, parameter `from=UI_ID` is sent to the endpoint alongside the user query.
The value is currently ignored but it may be used in the future for resolving queries or for analysing the popularity of `njt` interfaces.

## Prior art

Shortcuts to some of the `njt` destinations are built into `npm` cli:

πŸ“¦ [`npm home ` or `npm docs `](https://docs.npmjs.com/cli/docs)
β­₯
🐸 `njt h` (homepage)

---

πŸ“¦ [`npm issues ` or `npm bugs `](https://docs.npmjs.com/cli/bugs)
β­₯
🐸 `njt i` (issues)

---

πŸ“¦ [`npm repo `](https://docs.npmjs.com/cli/repo)
β­₯
🐸 `njt g` (github, gitlab, etc. repo)

With `njt`, you have access to more shortcuts in multiple environments, which makes you more productive day to day.