Home

Awesome

@ladjs/country-language

build status code coverage code style styled with prettier made with lass license

Maintained fork of country-language with zero-dependencies. Query any country's spoken languages or countries where a language is spoken.

Table of Contents

Install

npm:

npm install @ladjs/country-language

Usage

Once you require @ladjs/country-language, the following API will be available.

const CountryLanguage = require('@ladjs/country-language');

.getLanguageCodes (languageCodeType, cb)

Acceptable language code type parameter values: 1, 2, 3 for returning ISO-639-1, ISO-639-2, ISO-639-3 codes respectively. If not provided, ISO-639-1 codes will be returned.

const allLanguageCodes = CountryLanguage.getLanguageCodes(2);

.getCountryCodes (countryCodeType, cb)

Acceptable country code type parameter values: 1, 2, 3 for returning numerical code, alpha-2, alpha-3 codes respectively. If not provided, alpha-2 codes will be returned.

const allCountryCodes = CountryLanguage.getCountryCodes(2);

.languageCodeExists (languageCode)

Returns Boolean indicating language existance. Language code parameter can be either a ISO-639-1, ISO-639-2 or ISO-639-3 code.

const languageExists = CountryLanguage.languageCodeExists('en');

.countryCodeExists (countryCode)

Returns Boolean indicating country existance. Country code parameter can be either an alpha-2, alpha-3 or numerical code.

const countryExists = CountryLanguage.countryCodeExists('GB');

.getCountry (code, cb)

Country code can be either an Alpha-2 or Alpha-3 code. The returned object includes the following info:

Each language object in languages property includes the following info:

Each Microsoft© language culture object in langCultureMs property icludes the following info:

CountryLanguage.getCountry('GB', function (err, country) {
  if (err) {
    console.log(err);
  } else {
    const languagesInGB = country.languages;
  }
});

.getLanguage (code, cb)

Language code can be either iso639-1, iso639-2, iso639-2en or iso639-3 code. Contents of the returned language object are described in .getCountry method.

CountryLanguage.getLanguage('en', function (err, language) {
  if (err) {
    console.log(err);
  } else {
    const countriesSpeakingEN = language.countries;
  }
});

.getCountryLanguages (code, cb)

Country code can be either an Alpha-2 or Alpha-3 code. Each language object contains the following info:

CountryLanguage.getCountryLanguages('GB', function (err, languages) {
  if (err) {
    console.log(err);
  } else {
    languages.forEach(function (languageCodes) {
      console.log(languageCodes.iso639_1);
    });
  }
});

.getLanguageCountries (code, cb)

Language code can be either iso639-1, iso639-2, iso639-2en or iso639-3 code. Each Country object contains the following info:

CountryLanguage.getLanguageCountries('en', function (err, countries) {
  if (err) {
    console.log(err);
  } else {
    countries.forEach(function (countryCodes) {
      console.log(countryCodes.code_3);
    });
  }
});

.getCountryMsLocales (code, cb)

Country code can be either an Alpha-2 or Alpha-3 code. Contents of each Language Culture object are described in .getCountry method.

CountryLanguage.getCountryMsLocales('GB', function (err, locales) {
  if (err) {
    console.log(err);
  } else {
    locales.forEach(function (locale) {
      console.log(locale.langCultureName);
    });
  }
});

.getLanguageMsLocales (code, cb)

Language code can be either iso639-1, iso639-2, iso639-2en or iso639-3 code. Contents of each Language Culture object are described in .getCountry method.

CountryLanguage.getLanguageMsLocales('en', function (err, locales) {
  if (err) {
    console.log(err);
  } else {
    locales.forEach(function (locale) {
      console.log(locale.langCultureName);
    });
  }
});

.getCountries ()

Returns an array object with info for every country in the world having an ISO 3166 code. Contents of each country object in the array is described in .getCountry method.

const allCountries = CountryLanguage.getCountries();

.getLanguages ()

Returns an array object with info for every language in the world having an ISO 639-2 code (and a few more). Contents of each language object in the array is described in .getCountry method.

const allLanguages = CountryLanguage.getLanguages();

.getLanguageFamilies ()

Returns an array of strings with the names of each language family.

const allLanguageFamilies = CountryLanguage.getLanguageFamilies();

.getLocales (mode)

Returns an array of strings with all locale codes. If mode ommited or false, locales with 3 parts will be returned like: az-Cyrl-AZ

const localesSymbols = CountryLanguage.getLocales();

If mode is set to true, they will be returned like: az-AZ-Cyrl

const localesSymbols = CountryLanguage.getLocales(true);

.getLanguageFamilyMembers (family, cb)

Returns an array object with info for every language in the world having an ISO 639-2 code (and a few more). Contents of each language object in the array is described in .getCountry method.

Contents of the returned language object are described in .getCountry method.

CountryLanguage.getLanguageFamilyMembers('Indo-European', function (err, languages) {
  if (err) {
    console.log(err);
  } else {
    languages.forEach(function (language) {
      console.log(language.name);
    });
  }
});
<br /> ## Notes

For the following methods:

the cb parameter is optional. When not provided, each method returns either an Object when there is no error, or a String in case of an error.

Any input parameter (country code, language code, language family name) is case insensitive.

Language#nativeName string is not displayed correclty on the console for Right-to-Left (RTL) languages. However, there is no issue on string rendering (either on the browser or any text editor).

Contributors

Name
titanism

License

MIT © Tassos Diamantidis