Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/laget-se/narp
A workflow utility to ease localization in JS(X) apps
https://github.com/laget-se/narp
npm
Last synced: about 2 months ago
JSON representation
A workflow utility to ease localization in JS(X) apps
- Host: GitHub
- URL: https://github.com/laget-se/narp
- Owner: laget-se
- License: apache-2.0
- Created: 2016-04-19T08:58:47.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2023-03-09T17:26:40.000Z (almost 2 years ago)
- Last Synced: 2024-11-09T18:47:44.989Z (3 months ago)
- Topics: npm
- Language: JavaScript
- Homepage:
- Size: 188 KB
- Stars: 13
- Watchers: 6
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# narp ![narp](narp.png)
A workflow utility to ease localization in JS(X) apps by automizing the following steps:
**`narp push`**
1. Extraction of strings from source code ([react-gettext-parser](https://github.com/alexanderwallin/react-gettext-parser))
2. Merging upstream and local translations in order to support translations in branches ([pot-merge](https://github.com/laget-se/pot-merge))
3. Uploading POT resources to the translation service you use (Transifex or POEditor)**`narp pull`**
1. Download PO translations from the translation service
2. Converting PO to JSON ([gettext-parser](https://github.com/andris9/gettext-parser))
3. Writing the JSON translations to where you want itThe JSON translations are formatted for [node-gettext](https://github.com/andris9/node-gettext).
Table of Contents
* [Installation](#installation)
* [Usage](#usage)
* [Using the CLI](#using-the-cli)
* [Using the API](#using-the-api)
* [Configuration](#configuration)
* [Options](#options)
* [How to provide credentials](#how-to-provide-credentials)
* [Authorizing to Transifex](#authorizing-to-transifex)
* [Authorizing to POEditor](#authorizing-to-poeditor)
* [.narprc](#narprc)
* [Migrations](#migrations)
* [Migrating from v2 to v3](#migrating-from-v2-to-v3)
* [Development](#development)
* [Creating builds](#creating-builds)
* [Making it globally available while testing](#making-it-globally-available-while-testing)
* [Releases](#releases)## Installation
To use it easily, install narp globally with:
```sh
npm install -g narp
```To use it in an automatization pipeline in your project, install it as a dev dependency:
```sh
npm install --save-dev narp
```## Usage
### Using the CLI
```sh
# get help
narp -h
``````sh
# extract + merge pots + upload pot
narp push [] [--fresh]
``````sh
# download po's + convert to json + write to file
narp pull []
``````sh
# extract messages to stdout (no password required)
narp extract [./path/to/comps]
```Optionally put a path as arg 2 to just extract from the folder.
Protip, pipe to file if you want to use it.### Using the API
```js
import { push, pull } from 'narp';const configs = {
/* all the configs */
};push(configs).then(/* ... */).catch(/* ... */);
pull(configs).then(/* ... */).catch(/* ... */);
```## Configuration
### Options
This is the shape of narp's configuration. It can be provided as an object to the `pull()` and `push()` functions, or defined as a JSON object in `.narprc`.
```js
{
// The vendor object differs depending on the vendor
"vendor": {
// The name of the translation service you use.
// Must be "transifex" or "poeditor"
"name": "pick one"// Credentials used to make authorized HTTP requests.
// See the section below on how to provide passwords
// and tokens.
"credentials": {
// POEditor/Transifex token
"token": "do not store this in a file"
},// The vendor.options object contain project specific
// options, some of which differ depending on the vendor
"options": {
// Transifex only: The organization slug
"organization": "organization-slug",// Project ID.
"project": "project-id",// The source language code. This corresponds to whatever
// the vendor is naming it as.
"sourceLanguage": "en",
// Transifex only: The slug of the resource
"resource": null,
}
},// Configs that are passed to react-gettext-parser
"extract": {// A glob string (npmjs.com/glob) that matches all source files
// that may contain translatable strings.
"source": null,// The rest of the `extract` configs are passed directly to
// react-gettext-parser, see the react-gettext-parser readme.
"componentPropsMap": { /* react-gettext-parser defaults */ },
"funcArgumentsMap": { /* react-gettext-parser defaults */ },
"trim": false,
"trimLines": false,
"trimNewlines": false,
},// Where to put all the translations
"output": "messages.json",// Whether the extracted strings should be uploaded without
// being merged with the current upstream source strings,
// thus replacing it
"fresh": false,// If true, will output debug information to the console
"verbose": false
}
```### How to provide credentials
You will have to provide different credentials depending on the translation service you use. Transifex requires a username and password, whilst POEditor requires an API token.
#### Authorizing to Transifex
There are three ways of providing an API token:
a. Via the `--token` argument
b. Via the `NARP_VENDOR_TOKEN` environment variable
c. Via the `vendor.credentials.token` config passed to the API functions*Never store secret tokens in your code!*
#### Authorizing to POEditor
There are three ways of providing an API token:
a. Via the `--token` argument
b. Via the `NARP_VENDOR_TOKEN` environment variable
c. Via the `vendor.credentials.token` config passed to the API functions*Never store secret tokens in your code!*
### .narprc
`.narprc` is narp's configuration file. Any configurations you put there will be parsed and applied whenever you use narp.
## Migrations
### Migrating from v2 to v3
v3 introduced vendors, which replaces the hard-coded Transifex support with a modularised vendor support, adding POEditor into the mix. To transition your Transifex configuration, you change `.narprc` from
```js
{
"transifex": {
"username": "yourusername",
"project": "yourproject",
"resource": "yourresource",
"sourceLang": "xx"
},
// More configs...
}
```to
```js
{
"vendor": {
"name": "transifex",
"credentials": {
"username": "yourusername"
},
"options": {
"project": "yourproject",
"resource": "yourresource",
"sourceLanguage": "xx" // Note that this key is different
}
},
// More configs...
}
```### Migrating from v3 to v5
Updated to use the new Transifex API. Change `.narprc` from```js
{
"vendor": {
"name": "transifex",
"credentials": {
"username": "yourusername"
},
"options": {
"project": "yourproject",
"resource": "yourresource",
"sourceLanguage": "xx" // Note that this key is different
}
},
// More configs...
}
```to
```js
{
"vendor": {
"name": "transifex",
"options": {
"organization": "yourorganization",
"project": "yourproject",
"resource": "yourresource",
"sourceLanguage": "xx" // Note that this key is different
}
},
// More configs...
}
```## Development
### Creating builds
```sh
# Create a build from source
npm run build# Build continuously as you save files
npm run build -- --watch
```### Making it globally available while testing
```sh
cd path/to/narp && npm link
```### Releases
Follow semver when bumping the version number, commit it and run
```sh
npm publish
```