Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up

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

License

NotificationsYou must be signed in to change notification settings

nnjeim/world

Repository files navigation

Laravel world

The World is a Laravel package that provides a comprehensive list of countries, states, cities, timezones, currencies, and languages. You can access the data using theWorld Facade or through defined API routes.

Table of Contents

Installation

First, set your application environment to local:

set APP_ENV=local

Then, install the package via composer:

composer require nnjeim/world

Optionally, set the WORLD_DB_CONNECTION environment variable to your desired database connection.

Automated Installation

Run the following Artisan command to automate the installation process:

php artisan world:install

Manual Installation

If you prefer to install the package manually, follow these steps:

  1. Publish the package configuration file:
php artisan vendor:publish --tag=world --force
  1. Run the migrations:
php artisan migrate
  1. Seed the database:
php artisan db:seed --class=WorldSeeder

What's new in v1.1.34?

  • Tested with Laravel 11 and php 8.3/8.4
  • Tested with Laravel 12 and php 8.3/8.4
  • Minor code improvements

Changelog

For detailed information on recent changes, please see theCHANGELOG.

Contributing

We welcome contributions! For details on how to get started, please review ourCONTRIBUTING guidlines.

Examples

Explore the API examples on our live site:

List all countries:
https://laravel-world.com/api/countries
Search for a country:
https://laravel-world.com/api/countries?search=rom
Get states by country code:
https://laravel-world.com/api/states?filters[country_code]=RO&fields=cities

Usage

List all the countries

Use theWorld facade:

useNnjeim\World\World;$action =  World::countries();if ($action->success) {$countries =$action->data;}response (object){"success": true,"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 theWorld facade:

useNnjeim\World\World;$action =  World::countries(['fields' =>'states,cities','filters' => ['iso2' =>'FR',]]);if ($action->success) {$countries =$action->data;}

Response:

(object){  "success": true,  "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

useNnjeim\World\WorldHelper;newclass {protected$world;publicfunction__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

NameDescription
countrieslists all the world countries
stateslists all the states
citieslists all the cities
timezoneslists all the timezones
currencieslists all the currencies
languageslists all the languages

An action response is formed as below:

  • success (boolean)
  • message (string)
  • data (instance ofIlluminate\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...

Countries

MethodGET
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
responsesuccess, message, data

States

MethodGET
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
responsesuccess, message, data

Cities

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

Timezones

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

Currencies

MethodGET
Route/{prefix}/currencies
Parameters*comma seperated fields (currencies table fields in addition to the country), array filters, string search
Example/api/currencies?fields=code&filters[country_code]=RO
responsesuccess, message, data

Languages

MethodGET
Route/{prefix}/languages
Parameters*comma seperated fields, string search
Example/api/languages?fields=dir
responsesuccess, 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.

Header option

accept-language=locale

Alternatively, you can use specific locale with theWorld FacadesetLocale('locale') helper method. Example:

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

Schema

Configuration

The configuration for the World package is located in the world.php file.
If you're upgrading from a previous version, you may want to re-publish the config file:

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

Customizing database connection

By default, this package uses the default database connection, but it's possible to customize itusing theWORLD_DB_CONNECTION variable in your.env file.

Countries restrictions

Countries can be restricted while seeding the database either by adding the ISO2 country codes in theallowed_countries ordisallowed_countries array lists.

Supported Locales

A list of the accepted locales which relate to the localizedlang/ 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 assigningfalse toroutes.

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 dependenciescomposertest

* optional


[8]ページ先頭

©2009-2025 Movatter.jp