Skip to content

usamamuneerchaudhary/country-city-state

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

39 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Country, City, State Data

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 [email protected] 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.

About

Laravel Country City State Data

Resources

License

Contributing

Stars

Watchers

Forks

Packages

No packages published

Languages