usamamuneerchaudhary/country-city-state

Country City State Data Provider for Laravel 12+

v3.0 2025-08-16 01:07 UTC

This package is auto-updated.

Last update: 2025-08-16 01:13:23 UTC


README

World's Country City State Data for Laravel ^12.0 with PHP ^8.3|^8.4 and phone codes support as per ISO standards.

Latest Version on Packagist Total Downloads Monthly Downloads License PHP Version Laravel Version

๐Ÿš€ Requirements

  • PHP: ^8.3|^8.4
  • Laravel: ^12.0

๐Ÿ“ฆ Installation

You can install the package via composer:

composer require usamamuneerchaudhary/country-city-state

๐Ÿ”ง Setup

1. Publish Assets

# Publish migrations, models, helpers, and seeders
php artisan vendor:publish --tag=CountryCityState

# Publish configuration file
php artisan vendor:publish --tag=config

2. Run Migrations

php artisan migrate

3. (Optional) Run Seeder

php artisan db:seed --class=UsamaMuneerChaudhary\\CountryCityState\\seeds\\CountryCityStateTableSeeder

๐Ÿ’ก Usage

Using the Facade

use UsamaMuneerChaudhary\CountryCityState\Facades\CountryCityState;

// Get all active countries
$countries = CountryCityState::getCountries();

// Get states by country ID
$states = CountryCityState::getStatesByCountry(1);

// Get cities by state ID
$cities = CountryCityState::getCitiesByState(1);

// Get phone codes by country ID
$phoneCodes = CountryCityState::getPhoneCodesByCountry(1);

// Find country by ISO code
$country = CountryCityState::findCountryByIso('US');

Using the Service Container

$service = app('country-city-state');
$countries = $service->getCountries();

Direct Model Usage

use UsamaMuneerChaudhary\CountryCityState\Models\Country;
use UsamaMuneerChaudhary\CountryCityState\Models\State;
use UsamaMuneerChaudhary\CountryCityState\Models\City;

// Find country by ISO code
$country = Country::where('iso_code2', 'US')->first();

// Get all states for a country
$states = $country->states;

// Get all cities for a state
$cities = $states->first()->cities;

// Find state by name
$state = State::where('name', 'California')->first();

// Find city by name
$city = City::where('name', 'Los Angeles')->first();

Working with Relationships

// Country -> States -> Cities
$country = Country::find(1);
$states = $country->states; // HasMany relationship

$state = $states->first();
$cities = $state->cities; // HasMany relationship

// Reverse relationships
$city = City::find(1);
$state = $city->state; // BelongsTo relationship
$country = $state->country; // BelongsTo relationship

โš™๏ธ Configuration

The package configuration file will be published to config/country-city-state.php. You can customize:

  • Default Status: Set default status for new records (active/inactive)
  • Table Names: Customize database table names if needed
  • Cache Settings: Enable/disable caching and set TTL
  • Seeder Behavior: Control seeder truncation behavior
return [
    'default_status' => 'active',
    'tables' => [
        'countries' => 'countries',
        'states' => 'states',
        'cities' => 'cities',
        'country_phone_codes' => 'country_phone_codes',
    ],
    'cache' => [
        'enabled' => true,
        'ttl' => 3600, // 1 hour
    ],
    'seeder' => [
        'truncate_before_seeding' => false,
    ],
];

๐Ÿ—„๏ธ Database Structure

The package creates the following tables:

Countries Table

  • id - Primary key
  • name - Country name
  • iso_code2 - 2-letter ISO code (e.g., US, GB)
  • iso_code3 - 3-letter ISO code (e.g., USA, GBR)
  • num_code - Numeric ISO code
  • status - Active/Inactive status
  • created_at, updated_at - Timestamps
  • deleted_at - Soft delete timestamp

States Table

  • id - Primary key
  • country_id - Foreign key to countries table
  • name - State/Province name
  • status - Active/Inactive status
  • created_at, updated_at - Timestamps
  • deleted_at - Soft delete timestamp

Cities Table

  • id - Primary key
  • state_id - Foreign key to states table
  • name - City name
  • status - Active/Inactive status
  • created_at, updated_at - Timestamps
  • deleted_at - Soft delete timestamp

Country Phone Codes Table

  • id - Primary key
  • phone_code - Country calling code
  • intl_dialing_prefix - International dialing prefix
  • country_id - Foreign key to countries table
  • created_at, updated_at - Timestamps

๐Ÿงช Testing

composer test

๐Ÿ“ What's New in v3.0

  • โœ… PHP 8.3+ Support - Modern PHP features and performance
  • โœ… Laravel 12+ Support - Latest Laravel framework compatibility
  • โœ… Modern Migration Syntax - Anonymous classes and improved foreign keys
  • โœ… Enhanced Service Class - Useful methods for common operations
  • โœ… Proper Type Hints - Better IDE support and code quality
  • โœ… Configuration Support - Customizable package settings
  • โœ… Improved Namespaces - Better package organization
  • โœ… PHPUnit 11 - Latest testing framework

๐Ÿ”„ Upgrading from v1.x

If you're upgrading from version 1.x, please note:

  1. PHP 8.3+ Required - Update your PHP version
  2. Laravel 12+ Required - Update your Laravel version
  3. Model Namespaces Changed - Update any direct model references
  4. Migration Updates - May need to rollback and re-run migrations

See UPGRADE_GUIDE.md for detailed upgrade instructions.

๐Ÿค Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email hello@usamamuneer.me instead of using the issue tracker.

๐Ÿ“„ License

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

๐Ÿ‘จโ€๐Ÿ’ป Credits

Note: This package is now fully compatible with PHP 8.3+ and Laravel 12+. For older versions, please use v1.x of the package.