Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

country-query

Package Overview
Dependencies
Maintainers
1
Versions
14
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

country-query

A javascript query API for world-countries data

  • 1.0.2
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

country-query

A javascript query API for world-countries data.

Table of contents

API

find(by, value)

Finds data for one or more countries matching some search value.

Takes a property name to search by and a value to search for. If the value matches a single country, an object containing that country's data will be returned. If the value matches more than one country, an array of country objects will be returned. If no countries match, or an invalid property name is used, returns null.

This function is not case-sensitive, i.e the input values German, german and gErMaN would all match the language German.

var CountryQuery = require('country-query');

var austria = CountryQuery.find('cca2', 'AT');
var germany = CountryQuery.find('demonym', 'German');

// austria and germany will both be objects with this structure:
/*
    {
        "name": {
            "common": "Austria",
            "official": "Republic of Austria",
            "native": {
                "bar": {
                    "official": "Republik \u00d6sterreich",
                    "common": "\u00d6sterreich"
                }
            }
        },
        "tld": [".at"],
        "cca2": "AT",
        "ccn3": "040",
        "cca3": "AUT",
        "cioc": "AUT",
        "currency": ["EUR"],
        "callingCode": ["43"],
        "capital": "Vienna",
        "altSpellings": ["AT", "Osterreich", "Oesterreich"],
        "region": "Europe",
        "subregion": "Western Europe",
        "languages": {
            "bar": "Austro-Bavarian German"
        },
        "translations": {
            "cym": {"official": "Republic of Austria", "common": "Awstria"},
            "deu": {"official": "Republik \u00d6sterreich", "common": "\u00d6sterreich"},
            // ...snip...
        },
        "latlng": [47.33333333, 13.33333333],
        "demonym": "Austrian",
        "landlocked": true,
        "borders": ["CZE", "DEU", "HUN", "ITA", "LIE", "SVK", "SVN", "CHE"],
        "area": 83871
    }

 */

var euroCountries = CountryQuery.find('currency', 'EUR');

// euroCountries will be an array of country objects

Acceptable values for by are:

  • tld
  • currency
  • callingCode
  • altSpellings
  • latlng
  • borders
  • name.common
  • name.official
  • name.native
  • translations
  • languages
  • cca2
  • ccn3
  • cca3
  • capital
  • cioc
  • region
  • subregion
  • demonym
  • landlocked
  • area

findByArea(area)

Find country by its area.

Return value is the same as find.

findByAltSpelling(altSpelling)

Find country by alternative spellings of its name.

Return value is the same as find.

findByBorders(borders)

Find country by countries that it borders

Return value is the same as find.

findByCallingCode(callingCode)

Find country by telephone calling code.

Return value is the same as find.

findByCapital(capital)

Find country by its capital city.

Return value is the same as find.

findByCca2(cca2)

Find country by 2-letter country code.

Return value is the same as find.

findByCca3(cca3)

Find country by 3-letter country code.

Return value is the same as find.

findByCcn3(ccn3)

Find country by numeric country code.

Return value is the same as find.

findByCioc(cioc)

Find country by 3-letter International Olympic Commitee country code.

Return value is the same as find.

findByCurrency(currency)

Find country by currency.

Return value is the same as find.

findByDemonym(demonym)

Find country by the demonym used for its citizens.

Return value is the same as find.

findByLandlocked(landlocked)

Find country by whether or not it is landlocked.

Return value is the same as find.

findByLanguage(language)

Find country by its language.

Return value is the same as find.

findByNameCommon(name)

Find country by its common name.

Return value is the same as find.

findByNameNative(name)

Find country by its native name.

Return value is the same as find.

findByNameOfficial(name)

Find country by its official name.

Return value is the same as find.

findByRegion(region)

Find country by the region it is located in.

Return value is the same as find.

findBySubregion(subregion)

Find country by subregion it is located in.

Return value is the same as find.

findByTld(tld)

Find country by top level domain.

Return value is the same as find.

findByTranslation(translation)

Find country by translations of its name.

Return value is the same as find.

Thanks

This project would not exist without the work of the contributors to the world-countries data set.

License

Copyright (C) 2015, Peter Thompson peter.thompson@dunelm.org.uk

Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies.

THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.

Keywords

FAQs

Package last updated on 02 Nov 2019

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc