Git Product home page Git Product logo

laravel-world's Introduction

Laravel World

This package will allow you to add all Countries, States, Cities Data DB Migration & Seeder for Laravel

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

Numbers

Model Number of items
Country 250
State 4961
City 148059

Attributes

Common attributes:

  • name: Common name of Country(english).
  • iso2: ISO-3166-2 code.
  • iso2: ISO-3166-3 code.
  • numeric_code: Country Numeric code.
  • phonecode: Country Phone code.
  • capital: Capital of this country.
  • currency: ISO-4177 Currency Code, e.g. USD, CNY.
  • currency_name: Currency Name.
  • currency_symbol: Currency Symbol e.g. $, ¥.
  • tld: Country code top-level domain e.g. .uk.
  • native: Local name of the country.
  • region: region of the country.
  • subregion: Sub-region of the country.
  • timezones: timezones the country.
    • zoneName: Zone Name e.g. America/New_York.
    • gmtOffset: GMT offset e.g. -18000.
    • gmtOffsetName: GMT offset Name e.g. UTC-05:00.
    • abbreviation: abbreviation e.g. EST.
    • tzName: time zone Name e.g. Eastern Standard Time (North America).
  • translations: Country name translations e.g.
    • "ar": "الولايات المتحدة الأمريكية"
    • "kr": "미국"
    • "fr": "États-Unis"
  • latitude: latitude the country.
  • longitude: latitude the country.
  • emoji: Emoji flag of country e.g. 🇺🇸.
  • emojiU: Emoji Unicode flag of country e.g U+1F1FA U+1F1F8.
  • flag: Country has flag (boolean).
  • is_active: Country has active (boolean).

Installation

You can install the package via composer:

composer require altwaireb/laravel-world

Usage

Now run the following command to install .

php artisan world:install

Add seeder File in database\seeders\DatabaseSeeder.php add this line to use php artisan db:seed command.

public function run(): void
    {
    
        $this->call(WorldTableSeeder::class);
        ...
    }

Or you can Seeding Data of Countries States Cities, by run this command.

php artisan world:seeder

And you can refresh to re-seeding Data of Countries States Cities, by run this command.

php artisan world:seeder --refresh

You can specify the activation of countries through the country code ISO2 or ISO3, before processing the seed data in the config file. config/world.php

return [
    'countries' => [
        'activation' => [
            'default' => true,
            'only' => [
                'iso2' => ['SA','GB','DE'],
                'iso3' => ['USA','BRA','EGY'],
            ],
            'except' => [
                'iso2' => ['GA'],
                'iso3' => ['HTI'],
            ],
        ],
        'chunk_length' => 50,
    ],

    'states' => [
        'activation' => [
            'default' => true,
        ],
        'chunk_length' => 200,
    ],

    'cities' => [
        'activation' => [
            'default' => true,
        ],
        'chunk_length' => 200,
    ],
];

This means that only these two countries and the states and cities affiliated with them will be activated.

  • Note: If activation only iso2 an iso3 are empty, the column is_active take the default value in config file.
  • Note: If Country is active, all States and Cities are active.
  • Note: If activation except iso2 or iso3 the column is_active take FALSE value.
  • Note: If Country is not active, all States and Cities are not active.

Usage

you can get country by iso2 and iso3 or both.

if you want to get country by iso2 you can yes static function getByIso2

use App\Models\Country;

$sa = Country::getByIso2('SA');
$sa->name; // Saudi Arabia
$sa->iso2; // SA
$sa->iso3; // SAU
$sa->currency_symbol; // ﷼
$sa->native; // المملكة العربية السعودية

if you want to get country by iso3 you can use.

use App\Models\Country;

$bra = Country::getByIso3('BRA');
$bra->name; // Brazil
$bra->iso2; // BR
$bra->iso3; // BRA
$bra->currency_symbol; // R$
$bra->native; // Brasil

also if you want to get country by code iso2 ro iso3 you can use.

use App\Models\Country;

$bra = Country::getByCode('PT');
$bra->name; // Portugal
$bra->iso2; // PT
$bra->iso3; // PRT
$bra->currency_symbol; // €
$bra->native; // Portugal

Scope

you can use Scope to filter data is Active by use.

use App\Models\Country;

$countries = Country::active()->pluck('name','id');

Credits

License

The MIT License (MIT). Please see License File for more information.

laravel-world's People

Contributors

altwaireb avatar dependabot[bot] avatar github-actions[bot] avatar

Stargazers

Omar Pérez avatar jmrufo avatar Federico Castañeda Ortiz avatar Alejandro Jose Cabeza Sajaju avatar Andersson Pérez avatar Agustin Sanchez May avatar Benny Huaman avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.