Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/haltcase/namesake
Find available & relevant npm package names for your project.
https://github.com/haltcase/namesake
authors generator hacktoberfest helper list maintainers names utility
Last synced: 2 days ago
JSON representation
Find available & relevant npm package names for your project.
- Host: GitHub
- URL: https://github.com/haltcase/namesake
- Owner: haltcase
- License: mit
- Created: 2017-04-04T21:52:33.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2020-06-22T01:28:00.000Z (over 4 years ago)
- Last Synced: 2024-12-01T17:11:46.058Z (about 1 month ago)
- Topics: authors, generator, hacktoberfest, helper, list, maintainers, names, utility
- Language: JavaScript
- Homepage:
- Size: 22.5 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- Changelog: changelog.md
- License: license
Awesome Lists containing this project
README
# namesake · [![Version](https://flat.badgen.net/npm/v/namesake)](https://www.npmjs.com/package/namesake) [![License](https://flat.badgen.net/npm/license/namesake)](https://www.npmjs.com/package/namesake)
> Find available & relevant npm package names for your project.
Supposedly:
> There are only three hard things in Computer Science:
> cache invalidation, naming things, off-by-one errors,
> and being original.
> - Phil Karlton et al.¹¹ original quote is becoming lost to history / legend
`namesake` can do absolutely nothing to help you with cache invalidation and
off-by-one errors but it _can_ help you with naming things. Being original is
still up to you.Check out the [command line frontend](https://github.com/citycide/namesake-cli)
if you want to use this easily from your terminal.## installation
```sh
yarn add namesake# or
npm i namesake
```## usage
```js
import namesake from "namesake"namesake("worth").then(names => {
// `names` is an array of available package names
// they're all guaranteed to be available on npm at time of use
console.log(names)
})/*
[ "dollar-bill",
"price-floor",
"cheaper",
"billion",
"richest",
"doable",
... ]
*/
```## api
### namesake
```ts
namesake(keyword?: string, options = {})
```> **Arguments**
* `{string} [keyword]`: optional keyword to find related terms
* `{NamesakeOptions} [options = {}]`:| key | type | default | description |
| :-------: | :-------: | :-----: | -------------------------------- |
| `limit` | `number` | 50¹ | Max number of results to return. |If `keyword` is not provided, a random word will be chosen to which
all results will be related.¹ The max number of words returned isn't guaranteed to be equal to `limit`, since
the word list is pulled and then filtered based on npm name availability. The
absolute maximum is 1000, which is imposed by the [API](http://www.datamuse.com/api/).
`namesake` will always request more than your desired maximum to try to meet the
provided limit after checking for availability.> **Returns** `Promise`
## see also
- [`namesake-cli`](https://github.com/citycide/namesake-cli) – the command line frontend to this module
- [Datamuse API](http://www.datamuse.com/api/) – powers the related word search capabilities
- [`english-words`](https://github.com/dwyl/english-words) – word list used here for random word selection## contributing
Pull requests and any [issues](https://github.com/citycide/namesake/issues)
found are always welcome.1. Fork the project, and preferably create a branch named something like `feat/make-better`
2. Modify the source files as needed
3. Make sure all tests continue to pass, and it never hurts to have more tests
4. Push & pull request! :tada:## license
MIT © [Bo Lingen / citycide](https://github.com/citycide)