Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

@cospired/i18n-iso-languages

cospired179.7kMIT4.2.0TypeScript support: included

i18n for ISO 639 language codes

i18n, iso, 639, iso 639, iso 639-1, iso 639-2, iso 639-2T, iso 639-2B, alpha, alpha-2, alpha-3, language, languages, ar, bg, br, cs, da, de, en, es, fi, fr, he, hu, id, is, it, ja, ko, lt, lv, ms, nl, no, pl, pt, ro, ru, sk, sv, th, uk, vi, zh

readme

Build Status npm version Maintainability Test Coverage

i18n-iso-languages

i18n for ISO 639 language codes. We support Alpha-2, Alpha-3 B and T codes from https://en.wikipedia.org/wiki/List_of_ISO_639-1_codes

This packages is heavily based on i18n-iso-countries.

We intent to keep the interface of i18n-iso-languages as close as possible to i18n-iso-countries.

Installing

Install it using npm: npm install @cospired/i18n-iso-languages

If used in a browser environment, you will need to manually install the local you wish to support.

var languages = require("@cospired/i18n-iso-languages");

// Support german & english languages.
languages.registerLocale(require("@cospired/i18n-iso-languages/langs/en.json"));
languages.registerLocale(require("@cospired/i18n-iso-languages/langs/de.json"));

Code to Language

Get the name of a language by it's ISO 639-1 (Alpha-2), ISO 639-2/T or B (Alpha-3) code

var languages = require("@cospired/i18n-iso-languages");
console.log("de (639-1/Alpha-2) => " + languages.getName("de", "en")); // German
console.log("en (639-1/Alpha-2) => " + languages.getName("de", "de")); // Deutsch
console.log("de (639-2T/Alpha-3) => " + languages.getName("deu", "en")); // German
console.log("de (639-2B/Alpha-3) => " + languages.getName("ger", "en")); // German

Get all names by their ISO 639-1 code

var languages = require("@cospired/i18n-iso-languages");
console.log(languages.getNames("en")); // { 'ab': 'Abkhazian', 'aa': 'Afar', [...], 'za': 'Zhuang', 'zu': 'Zulu' }

Supported languages (ISO 639-1)

List of ISO 639-1 codes

Language to Code

var languages = require("@cospired/i18n-iso-languages");
console.log("German => " + languages.getAlpha2Code('German', 'en'));
// German => de

console.log("German => " + languages.getAlpha3TCode('German', 'en'));
// German => deu

console.log("German => " + languages.getAlpha3BCode('German', 'en'));
// German => ger

Codes

Convert ISO 639-2 (Alpha-3) to ISO 639-1 (Alpha-2) code

var languages = require("@cospired/i18n-iso-languages");
console.log("deu (Alpha-3) => " + languages.alpha3ToAlpha2("deu") + " (Alpha-2)");
// deu (Alpha-3 T) => de (Alpha-2)

var languages = require("@cospired/i18n-iso-languages");
console.log("ger (Alpha-3 B) => " + languages.alpha3ToAlpha2("ger") + " (Alpha-2)");
// ger (Alpha-3 B) => de (Alpha-2)

Convert ISO 639-1 (Alpha-2) to ISO 639-2 (Alpha-3) code

var languages = require("@cospired/i18n-iso-languages");
console.log("de (Alpha-2) => " + languages.alpha2ToAlpha3T("de") + " (Alpha-3 T)");
// de (Alpha-2) => deu (Alpha-3 T)

var languages = require("@cospired/i18n-iso-languages");
console.log("de (Alpha-2) => " + languages.alpha2ToAlpha3B("de") + " (Alpha-3 B)");
// de (Alpha-2) => ger (Alpha-3 B)

Get all ISO 639-1 (Alpha-2) codes

var languages = require("@cospired/i18n-iso-languages");
console.log(languages.getAlpha2Codes());
// { 'aa': 'aar', 'ab': 'abk', [...], 'za': 'zha', 'zu': 'zul' }

Get all ISO 639-2 (Alpha-3) codes

var languages = require("@cospired/i18n-iso-languages");
console.log(languages.getAlpha3TCodes());
// { 'aar': 'aa', 'abk': 'ab', [...], 'zha': 'za', 'zul': 'zu' }

var languages = require("@cospired/i18n-iso-languages");
console.log(languages.getAlpha3BCodes());
// { 'aar': 'aa', 'abk': 'ab', [...], 'zha': 'za', 'zul': 'zu' }

Validate language code

var languages = require("@cospired/i18n-iso-languages");
console.log(languages.isValid("de"), languages.isValid("ger"), languages.isValid("xx")));
// true, true, false

Contribution

To add a language:

  • add a json file under langs/ (in alphabetical order)
  • add the language to the data object in enty-node.js at the top (in alphabetical order)
  • add language to section Supported languages in README.md (in alphabetical order)
  • add language to keywords in package.json (in alphabetical order)
  • add language to the "unreleased" section of the changelog
  • run npm install && make test to make sure that tests are passing
  • open a PR on GitHub

Please do not change the version in package.json, package-lock.json or changelog.md.

changelog

Changelog

[Unreleased]

4.2.0

  • added Arabic translations
  • added Bulgarian translations
  • added Korean translations
  • added Slovak translations

4.1.0

  • added Hebrew translations

4.0.1

  • dependabot dependency updates

4.0.0

  • breaking: dropping support for node 10
  • 100% test coverage
  • updated outdated tooling

3.2.0

  • added Ukrainian translations
  • update contribution doc
  • cleanup: remove jshint config

3.1.1

  • fix: destructured isValid didn't work (#41)

3.1.0

  • added indonesian translations
  • added malay translations
  • added thai translations
  • added vietnamese translations

3.0.0

  • breaking: dropping support for node 6 and node 8 (EOL since 2019)
  • fix: security fixes in dependencies

2.2.0

  • fix: make ts spec and tests match (might be breaking tests)
  • fix: typos and more common used language names for 'de'

2.1.2

  • added romanian translations
  • fixed hungarian translations

2.1.1

  • added chinese translations
  • added japanes translations

2.1.0

  • added norwegian translations
  • added danish translations
  • updated swedish translations

2.0.6

  • add .npmignore to build git-free packages

2.0.6

  • add .npmignore to build git-free packages

2.0.5

  • added italian translations

2.0.4

  • maintenance (deps and such)
  • fix: bug in russian translations

2.0.3

  • maintenance (deps and such)
  • added russian translations
  • added finish translations
  • added dutch translations

2.0.2

  • maintenance (deps and such)

2.0.1

  • add spanish translations

2.0.0

  • drop support for node 4

1.0.5

  • added polish translations

1.0.4

  • added portugese translations