npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

country-language

v0.1.7

Published

Query languages spoken to a country or countries where people speak a language.

Downloads

45,464

Readme

country-language

Query any country's spoken languages or countries where a language is spoken.

Installation

Node.js

country-language is available on npm.

$ npm install country-language

Usage

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

var CountryLanguage = require('country-language');

.getLanguageCodes (languageCodeType, cb)

  • @param {String} language code type. Acceptable values: 1, 2 or 3.
  • @param {Function} callback on complete or error
  • @cb {Error|null} if error
  • @cb {Object} array String with language codes

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.

var allLanguageCodes = CountryLanguage.getLanguageCodes(2);

.getCountryCodes (countryCodeType, cb)

  • @param {String} country code type. Acceptable values: 1, 2 or 3.
  • @param {Function} callback on complete or error
  • @cb {Error|null} if error
  • @cb {Object} array String with country codes

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.

var allCountryCodes = CountryLanguage.getCountryCodes(2);

.languageCodeExists (languageCode)

  • @param {String} language code to check.

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

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

.countryCodeExists (countryCode)

  • @param {String} country code to check.

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

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

.getCountry (code, cb)

  • @param {String} country code
  • @param {Function} callback on complete or error
  • @cb {Error|null} if error
  • @cb {Object} object containing country info

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

  • code_2: Country alpha-2 code (2 letters)
  • code_3: Country alpha-3 code (3 letters)
  • numCode: Country numeric code
  • name: Country name
  • languages: Array of language objects for each language spoken in the country
  • langCultureMs: Array of language cultures for the country supported by Microsoft©

Each language object in languages property includes the following info:

  • iso639_1: language iso639-1 code (2 letters)
  • iso639_2: language iso639-2 code (3 letters)
  • iso639_2en: language iso639-2 code with some codes derived from English names rather than native names of languages (3 letters)
  • iso639_3: language iso639-3 code (3 letters)
  • name: String array with one or more language names (in English)
  • nativeName: String array with one or more language names (in native language)
  • direction: Language script direction (either 'LTR' or 'RTL') - Left-to-Right, Right-to-Left
  • family: language family
  • countries: Array of country objects where this language is spoken

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

  • langCultureName: language culture name
  • displayName: language culture dispaly name
  • cultureCode: language culture code
CountryLanguage.getCountry('GB', function (err, country) {
  if (err) {
    console.log(err);
  } else {
    var languagesInGB = country.languages;
  }
});

.getLanguage (code, cb)

  • @param {String} language code
  • @param {Function} callback on complete or error
  • @cb {Error|null} if error
  • @cb {Object} object containing language info

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 {
    var countriesSpeakingEN = language.countries;
  }
});

.getCountryLanguages (code, cb)

  • @param {String} country code
  • @param {Function} callback on complete or error
  • @cb {Error|null} if error
  • @cb {Object} object array containing country languages info

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

  • iso639_1: language iso639-1 code (2 letters)
  • iso639_2: language iso639-2 code with some codes derived from English names rather than native names of languages (3 letters)
  • iso639_3: language iso639-3 code (3 letters)
CountryLanguage.getCountryLanguages('GB', function (err, languages) {
  if (err) {
    console.log(err);
  } else {
    languages.forEach(function (languageCodes) {
      console.log(languageCodes.iso639_1);
    });
  }
});

.getLanguageCountries (code, cb)

  • @param {String} language code
  • @param {Function} callback on complete or error
  • @cb {Error|null} if error
  • @cb {Object} object array containing country info

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

  • code_2: Country alpha-2 code (2 letters)
  • code_3: Country alpha-3 code (3 letters)
  • numCode: Country numeric code
CountryLanguage.getLanguageCountries('en', function (err, countries) {
  if (err) {
    console.log(err);
  } else {
    countries.forEach(function (countryCodes) {
      console.log(countryCodes.code_3);
    });
  }
});

.getCountryMsLocales (code, cb)

  • @param {String} country code
  • @param {Function} callback on complete or error
  • @cb {Error|null} if error
  • @cb {Object} object array containing Language Cultures info for the country

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)

  • @param {String} language code
  • @param {Function} callback on complete or error
  • @cb {Error|null} if error
  • @cb {Object} object array containing Language Cultures info for the language

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.

var 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.

var allLanguages = CountryLanguage.getLanguages();

.getLanguageFamilies ()

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

var allLanguageFamilies = CountryLanguage.getLanguageFamilies();

.getLocales (mode)

  • @param {Boolean} locale symbols 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

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

var localesSymbols = CountryLanguage.getLocales();
var 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.

  • @param {String} language family name (
  • @param {Function} callback on complete or error
  • @cb {Error|null} if error
  • @cb {Object} object array containing languages info for each language member in the family.

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);
    });
  }
});

For the following methods:

  • .getLanguageCodes
  • .getCountryCodes
  • .getCountry
  • .getLanguage
  • .getCountryLanguages
  • .getLanguageCountries
  • .getCountryMsLocales
  • .getLanguageMsLocales
  • .getLanguageFamilyMembers

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).

License

Copyright (c) 2014 BDSwiss

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.