Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/kachkaev/njt
- Owner: kachkaev
- License: bsd-3-clause
- Created: 2019-12-05T19:34:22.000Z (about 5 years ago)
- Default Branch: main
- Last Pushed: 2024-10-29T17:16:53.000Z (3 months ago)
- Last Synced: 2024-10-29T17:24:23.744Z (3 months ago)
- Topics: frog, jump, meta, njt, npm, npmjs, productivity, search, search-engine, shortcuts, vercel, vercel-deployment
- Language: TypeScript
- Homepage: https://njt.vercel.app
- Size: 15.1 MB
- Stars: 314
- Watchers: 4
- Forks: 8
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
πΈ njt πΈ
πΈ npm jump to πΈ
njt.vercel.appDo 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 codeOmitting 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.