country-query
v2.0.3
Published
A javascript query API for world-countries data
Downloads
7,789
Maintainers
Readme
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 Österreich",
"common": "Österreich"
}
}
},
"tld": [".at"],
"cca2": "AT",
"ccn3": "040",
"cca3": "AUT",
"cioc": "AUT",
"independent": true,
"status": "officially-assigned",
"currencies": {
"EUR": { "name": "Euro", "symbol": "\u20ac" }
},
"idd": {
"root": "+4",
"suffixes": ["3"]
},
"capital": ["Vienna"],
"altSpellings": ["AT", "Osterreich", "Oesterreich"],
"region": "Europe",
"subregion": "Western Europe",
"languages": {
"bar": "Austro-Bavarian German"
},
"translations": {
"ces": {
"official": "Rakouská republika",
"common": "Rakousko"
},
"cym": {
"official": "Gweriniaeth Awstria",
"common": "Awstria"
},
"deu": {
"official": "Republik Österreich",
"common": "Österreich"
},
// ...snip...
},
"latlng": [47.33333333, 13.33333333],
"landlocked": true,
"borders": ["CZE", "DEU", "HUN", "ITA", "LIE", "SVK", "SVN", "CHE"],
"area": 83871,
"flag": "\ud83c\udde6\ud83c\uddf9",
"demonyms": {
"eng": {
"f": "Austrian",
"m": "Austrian"
},
"fra": {
"f": "Autrichienne",
"m": "Autrichien"
}
}
}
*/
var euroCountries = CountryQuery.find('currencies', 'EUR')
// euroCountries will be an array of country objects
Acceptable values for by
are:
tld
currencies
idd
altSpellings
latlng
borders
name.common
name.official
name.native
translations
languages
cca2
ccn3
cca3
capital
cioc
region
subregion
demonyms
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.
findByIdd(idd)
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 one of the demonyms 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 [email protected]
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.