mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-25 08:09:23 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			173 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			173 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| use Illuminate\Database\Eloquent\Model as Eloquent;
 | |
| use App\Models\Country;
 | |
| 
 | |
| class CountriesSeeder extends Seeder {
 | |
| 
 | |
|     /**
 | |
|      * Run the database seeds.
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function run()
 | |
|     {
 | |
|         //Empty the countries table
 | |
|         DB::table('countries')->delete();
 | |
| 
 | |
|         if (DB::table('countries')->count() == 0) {
 | |
|             //Get all of the countries
 | |
|             $countries = Countries::getList();
 | |
|             foreach ($countries as $countryId => $country){
 | |
|                 DB::table('countries')->insert(array(
 | |
|                     'id' => $countryId,
 | |
|                     'capital' => ((isset($country['capital'])) ? $country['capital'] : null),
 | |
|                     'citizenship' => ((isset($country['citizenship'])) ? $country['citizenship'] : null),
 | |
|                     'country_code' => $country['country-code'],
 | |
|                     'currency' => ((isset($country['currency'])) ? $country['currency'] : null),
 | |
|                     'currency_code' => ((isset($country['currency_code'])) ? $country['currency_code'] : null),
 | |
|                     'currency_sub_unit' => ((isset($country['currency_sub_unit'])) ? $country['currency_sub_unit'] : null),
 | |
|                     'full_name' => ((isset($country['full_name'])) ? $country['full_name'] : null),
 | |
|                     'iso_3166_2' => $country['iso_3166_2'],
 | |
|                     'iso_3166_3' => $country['iso_3166_3'],
 | |
|                     'name' => $country['name'],
 | |
|                     'region_code' => $country['region-code'],
 | |
|                     'sub_region_code' => $country['sub-region-code'],
 | |
|                     'eea' => (bool)$country['eea']
 | |
|                 ));
 | |
|             }
 | |
|         }
 | |
|         
 | |
|         // Source: http://www.bitboost.com/ref/international-address-formats.html
 | |
|         // Source: https://en.wikipedia.org/wiki/Linguistic_issues_concerning_the_euro
 | |
|         $countries = [
 | |
|             'AR' => [
 | |
|                 'swap_postal_code' => true,
 | |
|             ],
 | |
|             'AT' => [ // Austria
 | |
|                 'swap_postal_code' => true,
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'BE' => [
 | |
|                 'swap_postal_code' => true,
 | |
|             ],
 | |
|             'BG' => [ // Belgium
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'CH' => [
 | |
|                 'swap_postal_code' => true,
 | |
|             ],
 | |
|             'CZ' => [ // Czech Republic
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'DE' => [ // Germany
 | |
|                 'swap_postal_code' => true,
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'DK' => [
 | |
|                 'swap_postal_code' => true,
 | |
|             ],
 | |
|             'EE' => [ // Estonia
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'ES' => [ // Spain
 | |
|                 'swap_postal_code' => true,
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'FI' => [ // Finland
 | |
|                 'swap_postal_code' => true,
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'FR' => [ // France
 | |
|                 'swap_postal_code' => true,
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'GR' => [ // Greece
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'HR' => [ // Croatia
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'HU' => [ // Hungary
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'GL' => [
 | |
|                 'swap_postal_code' => true,
 | |
|             ],
 | |
|             'IE' => [ // Ireland
 | |
|                 'thousand_separator' => ',',
 | |
|                 'decimal_separator' => '.',
 | |
|             ],
 | |
|             'IL' => [
 | |
|                 'swap_postal_code' => true,
 | |
|             ],
 | |
|             'IS' => [ // Iceland
 | |
|                 'swap_postal_code' => true,
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'IT' => [ // Italy
 | |
|                 'swap_postal_code' => true,
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'JP' => [ // Japan
 | |
|                 'swap_postal_code' => true,
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'LT' => [ // Lithuania
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'LU' => [
 | |
|                 'swap_postal_code' => true,
 | |
|             ],
 | |
|             'MY' => [
 | |
|                 'swap_postal_code' => true,
 | |
|             ],
 | |
|             'MX' => [
 | |
|                 'swap_postal_code' => true,
 | |
|             ],
 | |
|             'NL' => [
 | |
|                 'swap_postal_code' => true,
 | |
|             ],
 | |
|             'PL' => [ // Poland
 | |
|                 'swap_postal_code' => true,
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'PT' => [ // Portugal
 | |
|                 'swap_postal_code' => true,
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'RO' => [ // Romania
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'SE' => [ // Sweden
 | |
|                 'swap_postal_code' => true,
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'SI' => [ // Slovenia
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'SK' => [ // Slovakia
 | |
|                 'swap_currency_symbol' => true,
 | |
|             ],
 | |
|             'UY' => [
 | |
|                 'swap_postal_code' => true,
 | |
|             ],
 | |
|         ];
 | |
| 
 | |
|         foreach ($countries as $code => $data) {
 | |
|             $country = Country::where('iso_3166_2', '=', $code)->first();
 | |
|             if (isset($data['swap_postal_code'])) {
 | |
|                 $country->swap_postal_code = true;
 | |
|             }
 | |
|             if (isset($data['swap_currency_symbol'])) {
 | |
|                 $country->swap_currency_symbol = true;
 | |
|             }
 | |
|             if (isset($data['thousand_separator'])) {
 | |
|                 $country->thousand_separator = $data['thousand_separator'];
 | |
|             }
 | |
|             if (isset($data['decimal_separator'])) {
 | |
|                 $country->decimal_separator = $data['decimal_separator'];
 | |
|             }
 | |
|             $country->save();
 | |
|         }
 | |
|     }
 | |
| } |