All Projects → nnjeim → world

nnjeim / world

Licence: MIT license
A Laravel package which provides a list of the countries, states, cities, currencies, timezones and languages.

Programming Languages

PHP
23972 projects - #3 most used programming language

Projects that are alternatives of or similar to world

Countries
Laravel countries and currencies
Stars: ✭ 1,564 (+226.51%)
Mutual labels:  countries, states, timezones
geo-sql-database
Continents, Sub-Continents, Countries, States, Cities, Timezones, Currencies SQL database.
Stars: ✭ 30 (-93.74%)
Mutual labels:  countries, cities, currencies
hdx-python-country
Utilities to map between country and region codes and names and to match administrative level names from different sources. Also utilities for foreign exchange enabling obtaining current and historic FX rates for different currencies
Stars: ✭ 16 (-96.66%)
Mutual labels:  countries, currencies, countries-api
graphcountries
An easy to use GraphQL API to query country-related data for free and without restrictions
Stars: ✭ 61 (-87.27%)
Mutual labels:  currencies, timezones, countries-api
oracle-geo-data
demo.insum.ca/ords/f?p=131
Stars: ✭ 20 (-95.82%)
Mutual labels:  countries, states, cities
Nager.Country
Worldwide Country Informations (ISO-3166-1 Alpha2, ISO-3166-1 Alpha3, ISO 639-1)
Stars: ✭ 68 (-85.8%)
Mutual labels:  country, countries, currencies
Countries
Countries, Languages & Continents data (capital and currency, native name, calling codes).
Stars: ✭ 656 (+36.95%)
Mutual labels:  countries, currencies
Countries
Countries - ISO 3166 (ISO3166-1, ISO3166, Digit, Alpha-2 and Alpha-3) countries codes and names (on eng and rus), ISO 4217 currency designators, ITU-T E.164 IDD calling phone codes, countries capitals, UN M.49 regions codes, ccTLD countries domains, IOC/NOC and FIFA letters codes, VERY FAST, NO maps[], NO slices[], NO init() funcs, NO external links/files/data, NO interface{}, NO specific dependencies, Databases/JSON/GOB/XML/CSV compatible, Emoji countries flags and currencies support, full support ISO-3166-1, ISO-4217, ITU-T E.164, Unicode CLDR and ccTLD standarts.
Stars: ✭ 85 (-82.25%)
Mutual labels:  countries, currencies
react-vector-maps
🗺 A React component for interactive vector maps of the world and 100+ countries
Stars: ✭ 112 (-76.62%)
Mutual labels:  country, countries
Laravel Country State
A helper to list countries & states in English in Laravel 5.1+
Stars: ✭ 77 (-83.92%)
Mutual labels:  country, countries
Country Json
A simple data of the world by country each in JSON format.
Stars: ✭ 688 (+43.63%)
Mutual labels:  country, countries
Country Ip Blocks
CIDR country-level IP data, straight from the Regional Internet Registries, updated hourly.
Stars: ✭ 100 (-79.12%)
Mutual labels:  country, countries
countriesNowAPI
CountriesNow is an Open source API for retrieving geo-information for countries, including their states, cities, population, etc. 🌎
Stars: ✭ 78 (-83.72%)
Mutual labels:  countries, cities
geonamescache
geonamescache - a Python library for quick access to a subset of GeoNames data.
Stars: ✭ 76 (-84.13%)
Mutual labels:  countries, states
top-regional-repositories
🌍 The most-relevant repositories for all countries and many cities worldwide.
Stars: ✭ 18 (-96.24%)
Mutual labels:  countries, cities
jbanking
A Java banking API
Stars: ✭ 58 (-87.89%)
Mutual labels:  countries, currencies
Countries States Cities Database
🌍 World countries, states, regions, provinces, cities, towns in JSON, SQL, XML, PLIST, YAML, and CSV. All Countries, States, Cities with ISO2, ISO3, Country Code, Phone Code, Capital, Native Language, Timezones, Latitude, Longitude, Region, Subregion, Flag Emoji, and Currency. #countries #states #cities
Stars: ✭ 1,130 (+135.91%)
Mutual labels:  country, countries
china regions
Ruby Library for China Regions
Stars: ✭ 23 (-95.2%)
Mutual labels:  countries, cities
Circle Flags
A collection of 300+ minimal circular SVG country flags
Stars: ✭ 139 (-70.98%)
Mutual labels:  country, countries
world-cities-mongodb
A free world cities database
Stars: ✭ 29 (-93.95%)
Mutual labels:  countries, cities

Laravel world

The World is a Laravel package which provides a list of the countries, states, cities, timezones, currencies and languages.

It can be consumed with the World Facade or the defined Api routes.

Installation

composer require nnjeim/world

php artisan vendor:publish --tag=world

php artisan migrate

php artisan db:seed --class=WorldSeeder (requires ~15min)

Upgrading to v1.1.15?

  • Support for the italian locale (it).
  • New addition: search query argument.
  • New addition: The allowed countries and disallowed countries arrays in config. This new addition by @aeq-dev is to help restrict the seeding of the countries and their dependencies.
  • If you are upgrading from a version older than 1.1.10 and due to the changes in the routes and config files, re-publish the package assets by issuing the command php artisan vendor:publish --tag=world --force
  • If needed, customize the table names and enable or disabled the optional database fields in the world.php config file.
  • The counties table sub_region field was renamed to subregion. It is advisable to refresh the migrations and seed the db tables.

Changelog

Please read CHANGELOG for more information of what was changed recently.

Contributing

Please read CONTRIBUTING for more details.

Demo

Please feel free to query https://laravel-world.com

Examples
https://laravel-world.com/api/countries
https://laravel-world.com/api/countries?search=rom https://laravel-world.com/api/states?filters[country_code]=RO&fields=cities

Usage

List all the countries.

Use the World facade

use Nnjeim\World\World;

$action =  World::countries();

if ($action->success) {

	$countries = $action->data;
}

response 
{
	"success": true,
	"message": "countries",
	"data": [
		{
			"id": 1,
			"name": "Afghanistan"
		},
		{
			"id": 2,
			"name": "Åland Islands"
		},
		.
		.
		.
	],
}

Use the Api countries endpoint

https://myDomain.local/api/countries

Fetch a country with its states and cities.

Use the World facade

use Nnjeim\World\World;

$action =  World::countries([
	'fields' => 'states,cities',
	'filters' => [
		'iso2' => 'FR',
	]
]);

if ($action->success) {

	$countries = $action->data;
}

response 
{
	"success": true,
	"message": "countries",
	"data": [
		"id": 77,
		"name": "France",
		"states": [
			 {
				"id": 1271,
				"name": "Alo"
			},
			{
				"id": 1272,
				"name": "Alsace"
			},
			.
			.
			.
		],
		"cities": [
			{
				"id": 25148,
				"name": "Abondance"
			},
			{
				"id": 25149,
				"name": "Abrest"
			},
			.
			.
			.
		]
	],
}

Use the Api countries endpoint

https://myDomain.local/api/countries?fields=states,cities&filters[iso2]=FR

List all the cities by country id.

use Nnjeim\World\WorldHelper;

protected $world;

public function __construct(WorldHelper $world) {

	$this->world = $world;
}

$action = $this->world->cities([
	'filters' => [
		'country_id' => 182,
	],
]);

if ($action->success) {

	$cities = $action->data;
}

Use the Api cities endpoint

https://myDomain.local/api/cities?filters[country_code]=RO 

Available actions

Name Description
countries lists all the world countries
states lists all the states
cities lists all the cities
timezones lists all the timezones
currencies lists all the currencies
languages lists all the languages

An action response is formed as below:

  • success (boolean)
  • message (string)
  • data (instance of Illuminate\Support\Collection)
  • errors (array)

Countries action

  • fields*: comma seperated string(countries table fields in addition to states, cities, currency and timezones).
  • filters*: array of keys(countries table fields) and their corresponding values.
  • search*: string.

States action

  • fields*: comma seperated string(states table fields in addition to country and states).
  • filters*: array of keys(states table fields) and their corresponding values.
  • search*: string.

Cities action

  • fields*: comma seperated string(cities table fields in addition to country and state).
  • filters*: array of keys(cities table fields) and their corresponding values.
  • search*: string.

Timezones action

  • fields*: comma seperated string(timezones table fields in addition to country).
  • filters*: array of keys(timezones table fields) and their corresponding values.
  • search*: string.

Currencies action

  • fields*: comma seperated string(currencies table fields in addition to country).
  • filters*: array of keys(currencies table fields) and their corresponding values.
  • search*: string.

Languages action

  • fields*: comma seperated string(languages table fields).
  • filters*: array of keys(languages table fields) and their corresponding values.
  • search*: string.

Available Api routes

All routes can be prefixed by any string. Ex admin, api, api ...

Countries

Method GET
Route /{prefix}/countries
Parameters* comma seperated fields(countries table fields in addition to states, cities, currency and timezones), array filters, string search
Example /api/countries?fields=iso2,cities&filters[phone_code]=44
response success, message, data

States

Method GET
Route /{prefix}/states
Parameters* comma seperated fields(states table fields in addition to country and cities), array filters, string search
Example /api/states?fields=country,cities&filters[country_code]=RO
response success, message, data

Cities

Method GET
Route /{prefix}/cities
Parameters* comma seperated fields(states table fields in addition to country and state), array filters, string search
Example /api/cities?fields=country,state&filters[country_code]=RO
response success, message, data

Timezones

Method GET
Route /{prefix}/timezones
Parameters* comma seperated fields(states table fields in addition to the country), array filters, string search
Example /api/timezones?fields=country&filters[country_code]=RO
response success, message, data

Currencies

Method GET
Route /{prefix}/currencies
Parameters* comma seperated fields(states table fields in addition to the country), array filters, string search
Example /api/timezones?fields=country&filters[country_code]=RO
response success, message, data

Languages

Method GET
Route /{prefix}/languages
Parameters* comma seperated fields, string search
Example /api/languages?fields=dir
response success, message, data

Localization

The available locales are ar, bn, br, de, en, es, fr, it, ja, kr, nl, pl, pt, ro, ru, tr and zh.
The default locale is en.
Include in the request header

accept-language=locale

Alternativley, you can use specific locale with the World Facade setLocale('locale') helper method. Example:

World::setLocale('zh')->countries();

Schema

Configuration

The configuration of the world package is in the world.php config file.
If you are upgrading from a previous version, you should consider re-publishing the file by issuing:

php artisan vendor:publish --tag=world --force

Countries restrictitions

Countries can be restricted while seeding the database either by adding the iso2 country codes in the allowed_countries or dissallowed_countries array lists.

Supported Locales

A list of the accepted locales which relate to the localized lang files.

Modules enablement

The states, cities, timezones, currencies and languages modules can be optionally disabled.
Please note that the cities module depends on the states module.

Routes

If you don't wish to use the packages as an api service, you can disable all the routes by assigning false to routes.

Migrations

It offers the ability to enable or disable the database fields.
When changing this configuration the database should be dropped and the seeder should be re-run.

Testing

Requirements

  • The database is seeded.
  • The database connection is defined in the .env file.

Browse to the package root folder and run:

composer install //installs the package dev dependencies
composer test

* optional

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].