shimadotdev/iran-regions

A Laravel package containing province and city data of Iran, including calling codes, along with geolocation functionality. Ideal for managing location-based information within Laravel apps.

Installs: 39

Dependents: 0

Suggesters: 0

Security: 0

Stars: 17

Watchers: 1

Forks: 0

Open Issues: 0

Type:laravel-package

1.2.1 2024-07-17 14:13 UTC

This package is not auto-updated.

Last update: 2024-11-20 16:14:43 UTC


README

Latest Stable Version Total Downloads Tests License PHP Version Require

Iran Regions Laravel Package

A Laravel package containing province and city data of Iran, including calling codes, along with geolocation functionality. Ideal for managing location-based information within Laravel apps.

Installation

You can install the package via Composer by running:

composer require shimadotdev/iran-regions

After installing the package, run the following Artisan command to set up the necessary migrations and seed the database with provided data:

php artisan iran-regions:install

This command will create two tables named cities and provinces in your database, seeded with the required data.

Usage

Once the package is installed and migrations are run, you can start using the provided functionality.

Example Usage

You can access province and city data using the Iran Class:

use Shimadotdev\IranRegions\Iran;;

// Get a province by its slug
$province = Iran::province()->where('slug', '=', 'tehran')->first();

// Get all provinces with their slugs and calling codes
$provinces = Iran::province()->get(['slug', 'calling_code']);

//Update a city
$provinces = Iran::city()->where('slug', '=', 'qom')->update(['is_active'=> 0]);

//Relations
Iran::province()->with('cities')->get();

Iran::province()->find(3)->cities;

Iran::City()->with('province')->get();

Iran::City()->where('slug', 'naeen')->first()?->province->slug;

As you see, you can also utilize Laravel's Eloquent ORM to create custom queries and interact with the data as usual.

Localization Support

The package supports two languages: English (en) and Persian (fa) for all city and province names. You can access them using their respective slugs:

trans('iranRegions::slug.' . $province->slug);

Database Structure

The package creates the following tables in your database:

cities Table

provinces Table

Testing

You can run the automated tests for the package using PHPUnit:

phpunit

Contributing

Contributions are welcome! If you have any ideas for improvements or find any issues, please submit them through GitHub issues or create a pull request.

Security Vulnerabilities

If you discover any security vulnerabilities, please report them via email to hi@shima.dev

Credits

This package is developed and maintained by Shima.Dev

License

This package is open-source software licensed under the MIT licensev.