Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/remarkablemark/phonetic-alphabet-converter
:memo: Converts string to NATO phonetic alphabet words.
https://github.com/remarkablemark/phonetic-alphabet-converter
alphabet converter nato nodejs npm phonetic phonetic-alphabet-converter typescript
Last synced: 3 months ago
JSON representation
:memo: Converts string to NATO phonetic alphabet words.
- Host: GitHub
- URL: https://github.com/remarkablemark/phonetic-alphabet-converter
- Owner: remarkablemark
- License: mit
- Created: 2020-01-31T05:15:33.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2023-10-14T04:43:23.000Z (over 1 year ago)
- Last Synced: 2024-10-11T15:13:01.248Z (4 months ago)
- Topics: alphabet, converter, nato, nodejs, npm, phonetic, phonetic-alphabet-converter, typescript
- Language: TypeScript
- Homepage: https://b.remarkabl.org/phonetic-alphabet-converter
- Size: 54.7 KB
- Stars: 5
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# phonetic-alphabet-converter
[![NPM](https://nodei.co/npm/phonetic-alphabet-converter.png)](https://nodei.co/npm/phonetic-alphabet-converter/)
[![NPM version](https://img.shields.io/npm/v/phonetic-alphabet-converter.svg)](https://www.npmjs.com/package/phonetic-alphabet-converter)
[![Build Status](https://github.com/remarkablemark/phonetic-alphabet-converter/workflows/build/badge.svg?branch=master)](https://github.com/remarkablemark/phonetic-alphabet-converter/actions?query=workflow%3Abuild)
[![Coverage Status](https://coveralls.io/repos/github/remarkablemark/phonetic-alphabet-converter/badge.svg?branch=master)](https://coveralls.io/github/remarkablemark/phonetic-alphabet-converter?branch=master)Converts string to [NATO phonetic alphabet](https://en.wikipedia.org/wiki/NATO_phonetic_alphabet) words:
```
PhoneticAlphabetConverter(string[, alphabet])
```#### Example
```js
import converter from 'phonetic-alphabet-converter';
converter('abc'); // ['alpha', 'bravo', 'charlie']
```[Site](https://b.remarkabl.org/phonetic-alphabet-converter) | [JSFiddle](https://jsfiddle.net/remarkablemark/g4r6fu7j/) | [Repl.it](https://repl.it/@remarkablemark/phonetic-alphabet-converter)
## Install
[NPM](https://www.npmjs.com/package/phonetic-alphabet-converter):
```sh
npm install phonetic-alphabet-converter --save
```[Yarn](https://yarnpkg.com/package/phonetic-alphabet-converter):
```sh
yarn add phonetic-alphabet-converter
```[CDN](https://unpkg.com/phonetic-alphabet-converter/):
```html
window.PhoneticAlphabetConverter.default(/* string */);
```
## Usage
Import module:
```js
// ES Modules
import converter from 'phonetic-alphabet-converter';// CommonJS
const converter = require('phonetic-alphabet-converter').default;
```Parse string:
```js
converter('Hello, world!');
// ['hotel', 'echo', 'lima', 'lima', 'oscar', 'whiskey', 'oscar', 'romeo', 'lima', 'delta']
```> The string is **lowercased** and characters not found on the alphabet map are **ignored**.
If the string is blank, an empty array is returned:
```js
converter('');
// []
```If the first argument is not a string, then an error will be thrown:
```js
converter();
// TypeError: First argument must be a string
```### Second Argument
By default, the converter uses a mapping of the NATO phonetic alphabet:
```js
import { NATO_PHONETIC_ALPHABET } from 'phonetic-alphabet-converter';
```To override that, you can pass a custom object to the second argument:
```js
converter('abc', {
a: 'Amsterdam',
b: 'Baltimore',
c: 'Casablanca',
});
// ['Amsterdam', 'Baltimore', 'Casablanca']
```Or you can assign values to the default alphabet map:
```js
import { NATO_PHONETIC_ALPHABET } from 'phonetic-alphabet-converter';converter('abc', {
...NATO_PHONETIC_ALPHABET,
a: 'alfa',
});
// ['alfa', 'bravo', 'charlie']
```## Testing
Run tests with coverage:
```sh
npm test
```Run tests in watch mode:
```sh
npm run test:watch
```Lint files:
```sh
npm run lint
```Fix lint errors:
```sh
npm run lint:fix
```## Release
Only collaborators with credentials can release and publish:
```sh
npm run release
git push --follow-tags && npm publish
```## License
[MIT](https://github.com/remarkablemark/phonetic-alphabet-converter/blob/master/LICENSE)