Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

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.

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)