Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/ladjs/mandarin

Automatic i18n phrase translation using Google Translate
https://github.com/ladjs/mandarin

api automatic convert google i10n i18n javascript keywords localization localize mandarin node phrase phrases sentences service translate translation

Last synced: 3 months ago
JSON representation

Automatic i18n phrase translation using Google Translate

Awesome Lists containing this project

README

        

# mandarin

[![build status](https://github.com/ladjs/mandarin/actions/workflows/ci.yml/badge.svg)](https://github.com/ladjs/mandarin/actions/workflows/ci.yml)
[![code style](https://img.shields.io/badge/code_style-XO-5ed9c7.svg)](https://github.com/sindresorhus/xo)
[![styled with prettier](https://img.shields.io/badge/styled_with-prettier-ff69b4.svg)](https://github.com/prettier/prettier)
[![made with lass](https://img.shields.io/badge/made_with-lass-95CC28.svg)](https://lass.js.org)
[![license](https://img.shields.io/github/license/ladjs/mandarin.svg)](LICENSE)

> Automatic i18n markdown translation and i18n phrase translation using Google Translate

## Table of Contents

* [Install](#install)
* [Requirements](#requirements)
* [Redis](#redis)
* [Google Application Credentials](#google-application-credentials)
* [Usage](#usage)
* [Contributors](#contributors)
* [License](#license)

## Install

[npm][]:

```sh
npm install mandarin
```

## Requirements

### Redis

You will need to have [Redis][] installed in order for caching to work properly.

If you do not plan to use Redis, then set `redis: false` as an option.

### Google Application Credentials

You will also need Google Application Credentials, and you will need to set them as environment variables (e.g. `GOOGLE_APPLICATION_CREDENTIALS=/home/user/Downloads/service-account-file.json`).

For more information on Google Application credentials, see .

## Usage

1. Implement Mandarin and pass it an instance of [i18n][]

```js
const Mandarin = require('mandarin');
const I18N = require('@ladjs/i18n');

const i18n = new I18N();

// you can also pass a custom `logger` option (it defaults to `console`)
const mandarin = new Mandarin({

// REQUIRED:
i18n

// OPTIONAL:
// logger: console,

// OPTIONAL (see index.js for defaults):
// redis: ...

// OPTIONAL (see index.js for defaults):
// redisMonitor: ...

// OPTIONAL:
// see all commented options from this following link:
//
//
// clientConfig: {},

// OPTIONAL (see index.js for defaults):
// Files to convert from `index.md` to `index-es.md`
// Or `README.md` to `README-ZH.md` for example
//
//
// markdown: ... (note we expose `Mandarin.DEFAULT_PATTERNS` for you)
});

//
// Translate Phrases
//
// with async/await
(async () => {
try {
await mandarin.translate();
} catch (err) {
console.log(err);
}
})();

// with promises and then/catch
mandarin
.translate()
.then(() => {
console.log('done');
})
.catch(console.error);

// with callbacks
mandarin.translate(err => {
if (err) throw err;
console.log('done');
});

//
// Translate Markdown Files
//
// with async/await
(async () => {
try {
await mandarin.markdown();
} catch (err) {
console.log(err);
}
})();

// with promises and then/catch
mandarin
.markdown()
.then(() => {
console.log('done');
})
.catch(console.error);

// with callbacks
mandarin.markdown(err => {
if (err) throw err;
console.log('done');
});
```

2. This assumes that you have locale files already and a default locale file (e.g. `./locales/en.json` with phrases that need translated to other languages you support). Based off the defaults from [i18n][], you would automatically get your `en.json` file translated to the locales `es` (Spanish) and `zh` (Chinese).

3. Follow the "Before you begin" steps here (basically you download a JSON file after creating a Google Cloud Project with Cloud Translation API enabled).

4. Specify the path to the JSON file and run your script that uses `mandarin`:

```sh
GOOGLE_APPLICATION_CREDENTIALS="/home/user/Downloads/[FILE_NAME].json" node app.js
```

## Contributors

| Name | Website |
| -------------- | -------------------------- |
| **Nick Baugh** | |

## License

[MIT](LICENSE) © [Nick Baugh](http://niftylettuce.com/)

##

[npm]: https://www.npmjs.com/

[i18n]: https://github.com/ladjs/i18n

[redis]: https://redis.io/