mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-07-07 19:04:41 -04:00
Broke up seeders
This commit is contained in:
parent
ab2693ad52
commit
92e5bf60d8
@ -251,7 +251,11 @@ class AppController extends BaseController
|
|||||||
'PaymentLibraries',
|
'PaymentLibraries',
|
||||||
'Fonts',
|
'Fonts',
|
||||||
'Banks',
|
'Banks',
|
||||||
'InvoiceStatus'
|
'InvoiceStatus',
|
||||||
|
'Currencies',
|
||||||
|
'DateFormats',
|
||||||
|
'InvoiceDesigns',
|
||||||
|
'PaymentTerms',
|
||||||
] as $seeder) {
|
] as $seeder) {
|
||||||
Artisan::call('db:seed', array('--force' => true, '--class' => "{$seeder}Seeder"));
|
Artisan::call('db:seed', array('--force' => true, '--class' => "{$seeder}Seeder"));
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
<?php
|
<?php
|
||||||
use Illuminate\Database\Eloquent\Model as Eloquent;
|
use Illuminate\Database\Eloquent\Model as Eloquent;
|
||||||
|
use App\Models\Country;
|
||||||
|
|
||||||
class CountriesSeeder extends Seeder {
|
class CountriesSeeder extends Seeder {
|
||||||
|
|
||||||
@ -13,25 +14,156 @@ class CountriesSeeder extends Seeder {
|
|||||||
//Empty the countries table
|
//Empty the countries table
|
||||||
DB::table('countries')->delete();
|
DB::table('countries')->delete();
|
||||||
|
|
||||||
//Get all of the countries
|
if (DB::table('countries')->count() == 0) {
|
||||||
$countries = Countries::getList();
|
//Get all of the countries
|
||||||
foreach ($countries as $countryId => $country){
|
$countries = Countries::getList();
|
||||||
DB::table('countries')->insert(array(
|
foreach ($countries as $countryId => $country){
|
||||||
'id' => $countryId,
|
DB::table('countries')->insert(array(
|
||||||
'capital' => ((isset($country['capital'])) ? $country['capital'] : null),
|
'id' => $countryId,
|
||||||
'citizenship' => ((isset($country['citizenship'])) ? $country['citizenship'] : null),
|
'capital' => ((isset($country['capital'])) ? $country['capital'] : null),
|
||||||
'country_code' => $country['country-code'],
|
'citizenship' => ((isset($country['citizenship'])) ? $country['citizenship'] : null),
|
||||||
'currency' => ((isset($country['currency'])) ? $country['currency'] : null),
|
'country_code' => $country['country-code'],
|
||||||
'currency_code' => ((isset($country['currency_code'])) ? $country['currency_code'] : null),
|
'currency' => ((isset($country['currency'])) ? $country['currency'] : null),
|
||||||
'currency_sub_unit' => ((isset($country['currency_sub_unit'])) ? $country['currency_sub_unit'] : null),
|
'currency_code' => ((isset($country['currency_code'])) ? $country['currency_code'] : null),
|
||||||
'full_name' => ((isset($country['full_name'])) ? $country['full_name'] : null),
|
'currency_sub_unit' => ((isset($country['currency_sub_unit'])) ? $country['currency_sub_unit'] : null),
|
||||||
'iso_3166_2' => $country['iso_3166_2'],
|
'full_name' => ((isset($country['full_name'])) ? $country['full_name'] : null),
|
||||||
'iso_3166_3' => $country['iso_3166_3'],
|
'iso_3166_2' => $country['iso_3166_2'],
|
||||||
'name' => $country['name'],
|
'iso_3166_3' => $country['iso_3166_3'],
|
||||||
'region_code' => $country['region-code'],
|
'name' => $country['name'],
|
||||||
'sub_region_code' => $country['sub-region-code'],
|
'region_code' => $country['region-code'],
|
||||||
'eea' => (bool)$country['eea']
|
'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,
|
||||||
|
],
|
||||||
|
'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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -19,5 +19,9 @@ class DatabaseSeeder extends Seeder
|
|||||||
$this->call('FontsSeeder');
|
$this->call('FontsSeeder');
|
||||||
$this->call('BanksSeeder');
|
$this->call('BanksSeeder');
|
||||||
$this->call('InvoiceStatusSeeder');
|
$this->call('InvoiceStatusSeeder');
|
||||||
|
$this->call('CurrenciesSeeder');
|
||||||
|
$this->call('DateFormatsSeeder');
|
||||||
|
$this->call('InvoiceDesignsSeeder');
|
||||||
|
$this->call('PaymentTermsSeeder');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -14,16 +14,6 @@ class PaymentLibrariesSeeder extends Seeder
|
|||||||
{
|
{
|
||||||
Eloquent::unguard();
|
Eloquent::unguard();
|
||||||
|
|
||||||
$this->createGateways();
|
|
||||||
$this->createPaymentTerms();
|
|
||||||
$this->createDateFormats();
|
|
||||||
$this->createDatetimeFormats();
|
|
||||||
$this->createInvoiceDesigns();
|
|
||||||
$this->updateLocalization();
|
|
||||||
}
|
|
||||||
|
|
||||||
private function createGateways() {
|
|
||||||
|
|
||||||
$gateways = [
|
$gateways = [
|
||||||
['name' => 'BeanStream', 'provider' => 'BeanStream', 'payment_library_id' => 2],
|
['name' => 'BeanStream', 'provider' => 'BeanStream', 'payment_library_id' => 2],
|
||||||
['name' => 'Psigate', 'provider' => 'Psigate', 'payment_library_id' => 2],
|
['name' => 'Psigate', 'provider' => 'Psigate', 'payment_library_id' => 2],
|
||||||
@ -71,334 +61,4 @@ class PaymentLibrariesSeeder extends Seeder
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private function createPaymentTerms() {
|
|
||||||
|
|
||||||
$paymentTerms = [
|
|
||||||
['num_days' => -1, 'name' => 'Net 0'],
|
|
||||||
];
|
|
||||||
|
|
||||||
foreach ($paymentTerms as $paymentTerm) {
|
|
||||||
if (!DB::table('payment_terms')->where('name', '=', $paymentTerm['name'])->get()) {
|
|
||||||
PaymentTerm::create($paymentTerm);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$currencies = [
|
|
||||||
['name' => 'US Dollar', 'code' => 'USD', 'symbol' => '$', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Pound Sterling', 'code' => 'GBP', 'symbol' => '£', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Euro', 'code' => 'EUR', 'symbol' => '€', 'precision' => '2', 'thousand_separator' => '.', 'decimal_separator' => ','],
|
|
||||||
['name' => 'South African Rand', 'code' => 'ZAR', 'symbol' => 'R', 'precision' => '2', 'thousand_separator' => '.', 'decimal_separator' => ','],
|
|
||||||
['name' => 'Danish Krone', 'code' => 'DKK', 'symbol' => 'kr ', 'precision' => '2', 'thousand_separator' => '.', 'decimal_separator' => ','],
|
|
||||||
['name' => 'Israeli Shekel', 'code' => 'ILS', 'symbol' => 'NIS ', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Swedish Krona', 'code' => 'SEK', 'symbol' => 'kr ', 'precision' => '2', 'thousand_separator' => '.', 'decimal_separator' => ','],
|
|
||||||
['name' => 'Kenyan Shilling', 'code' => 'KES', 'symbol' => 'KSh ', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Canadian Dollar', 'code' => 'CAD', 'symbol' => 'C$', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Philippine Peso', 'code' => 'PHP', 'symbol' => 'P ', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Indian Rupee', 'code' => 'INR', 'symbol' => 'Rs. ', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Australian Dollar', 'code' => 'AUD', 'symbol' => '$', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Singapore Dollar', 'code' => 'SGD', 'symbol' => '', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Norske Kroner', 'code' => 'NOK', 'symbol' => 'kr ', 'precision' => '2', 'thousand_separator' => '.', 'decimal_separator' => ','],
|
|
||||||
['name' => 'New Zealand Dollar', 'code' => 'NZD', 'symbol' => '$', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Vietnamese Dong', 'code' => 'VND', 'symbol' => '', 'precision' => '0', 'thousand_separator' => '.', 'decimal_separator' => ','],
|
|
||||||
['name' => 'Swiss Franc', 'code' => 'CHF', 'symbol' => '', 'precision' => '2', 'thousand_separator' => '\'', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Guatemalan Quetzal', 'code' => 'GTQ', 'symbol' => 'Q', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Malaysian Ringgit', 'code' => 'MYR', 'symbol' => 'RM', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Brazilian Real', 'code' => 'BRL', 'symbol' => 'R$', 'precision' => '2', 'thousand_separator' => '.', 'decimal_separator' => ','],
|
|
||||||
['name' => 'Thai Baht', 'code' => 'THB', 'symbol' => '', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Nigerian Naira', 'code' => 'NGN', 'symbol' => '', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Argentine Peso', 'code' => 'ARS', 'symbol' => '$', 'precision' => '2', 'thousand_separator' => '.', 'decimal_separator' => ','],
|
|
||||||
['name' => 'Bangladeshi Taka', 'code' => 'BDT', 'symbol' => 'Tk', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'United Arab Emirates Dirham', 'code' => 'AED', 'symbol' => 'DH ', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Hong Kong Dollar', 'code' => 'HKD', 'symbol' => '', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Indonesian Rupiah', 'code' => 'IDR', 'symbol' => 'Rp', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Mexican Peso', 'code' => 'MXN', 'symbol' => '$', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Egyptian Pound', 'code' => 'EGP', 'symbol' => 'E£', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Colombian Peso', 'code' => 'COP', 'symbol' => '$', 'precision' => '2', 'thousand_separator' => '.', 'decimal_separator' => ','],
|
|
||||||
['name' => 'West African Franc', 'code' => 'XOF', 'symbol' => 'CFA ', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Chinese Renminbi', 'code' => 'CNY', 'symbol' => 'RMB ', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Rwandan Franc', 'code' => 'RWF', 'symbol' => 'RF ', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Tanzanian Shilling', 'code' => 'TZS', 'symbol' => 'TSh ', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Netherlands Antillean Guilder', 'code' => 'ANG', 'symbol' => '', 'precision' => '2', 'thousand_separator' => '.', 'decimal_separator' => ','],
|
|
||||||
['name' => 'Trinidad and Tobago Dollar', 'code' => 'TTD', 'symbol' => 'TT$', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'East Caribbean Dollar', 'code' => 'XCD', 'symbol' => 'EC$', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Ghanaian Cedi', 'code' => 'GHS', 'symbol' => '', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Bulgarian Lev', 'code' => 'BGN', 'symbol' => '', 'precision' => '2', 'thousand_separator' => ' ', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Aruban Florin', 'code' => 'AWG', 'symbol' => 'Afl. ', 'precision' => '2', 'thousand_separator' => ' ', 'decimal_separator' => '.'],
|
|
||||||
['name' => 'Turkish Lira', 'code' => 'TRY', 'symbol' => 'TL ', 'precision' => '2', 'thousand_separator' => '.', 'decimal_separator' => ','],
|
|
||||||
['name' => 'Romanian New Leu', 'code' => 'RON', 'symbol' => '', 'precision' => '2', 'thousand_separator' => ',', 'decimal_separator' => '.'],
|
|
||||||
];
|
|
||||||
|
|
||||||
foreach ($currencies as $currency) {
|
|
||||||
$record = Currency::whereCode($currency['code'])->first();
|
|
||||||
if ($record) {
|
|
||||||
$record->name = $currency['name'];
|
|
||||||
$record->symbol = $currency['symbol'];
|
|
||||||
$record->thousand_separator = $currency['thousand_separator'];
|
|
||||||
$record->decimal_separator = $currency['decimal_separator'];
|
|
||||||
$record->save();
|
|
||||||
} else {
|
|
||||||
Currency::create($currency);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private function createDateFormats() {
|
|
||||||
|
|
||||||
$formats = [
|
|
||||||
['format' => 'd/M/Y', 'picker_format' => 'dd/M/yyyy', 'label' => '10/Mar/2013'],
|
|
||||||
['format' => 'd-M-Y', 'picker_format' => 'dd-M-yyyy', 'label' => '10-Mar-2013'],
|
|
||||||
['format' => 'd/F/Y', 'picker_format' => 'dd/MM/yyyy', 'label' => '10/March/2013'],
|
|
||||||
['format' => 'd-F-Y', 'picker_format' => 'dd-MM-yyyy', 'label' => '10-March-2013'],
|
|
||||||
['format' => 'M j, Y', 'picker_format' => 'M d, yyyy', 'label' => 'Mar 10, 2013'],
|
|
||||||
['format' => 'F j, Y', 'picker_format' => 'MM d, yyyy', 'label' => 'March 10, 2013'],
|
|
||||||
['format' => 'D M j, Y', 'picker_format' => 'D MM d, yyyy', 'label' => 'Mon March 10, 2013'],
|
|
||||||
['format' => 'Y-m-d', 'picker_format' => 'yyyy-mm-dd', 'label' => '2013-03-10'],
|
|
||||||
['format' => 'd-m-Y', 'picker_format' => 'dd-mm-yyyy', 'label' => '20-03-2013'],
|
|
||||||
['format' => 'm/d/Y', 'picker_format' => 'mm/dd/yyyy', 'label' => '03/20/2013']
|
|
||||||
];
|
|
||||||
|
|
||||||
foreach ($formats as $format) {
|
|
||||||
$record = DateFormat::whereLabel($format['label'])->first();
|
|
||||||
if ($record) {
|
|
||||||
$record->format = $format['format'];
|
|
||||||
$record->picker_format = $format['picker_format'];
|
|
||||||
$record->save();
|
|
||||||
} else {
|
|
||||||
DateFormat::create($format);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private function createDatetimeFormats() {
|
|
||||||
|
|
||||||
$formats = [
|
|
||||||
[
|
|
||||||
'format' => 'd/M/Y g:i a',
|
|
||||||
'format_moment' => 'DD/MMM/YYYY h:mm:ss a',
|
|
||||||
'label' => '10/Mar/2013'
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'format' => 'd-M-Y g:i a',
|
|
||||||
'format_moment' => 'DD-MMM-YYYY h:mm:ss a',
|
|
||||||
'label' => '10-Mar-2013'
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'format' => 'd/F/Y g:i a',
|
|
||||||
'format_moment' => 'DD/MMMM/YYYY h:mm:ss a',
|
|
||||||
'label' => '10/March/2013'
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'format' => 'd-F-Y g:i a',
|
|
||||||
'format_moment' => 'DD-MMMM-YYYY h:mm:ss a',
|
|
||||||
'label' => '10-March-2013'
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'format' => 'M j, Y g:i a',
|
|
||||||
'format_moment' => 'MMM D, YYYY h:mm:ss a',
|
|
||||||
'label' => 'Mar 10, 2013 6:15 pm'
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'format' => 'F j, Y g:i a',
|
|
||||||
'format_moment' => 'MMMM D, YYYY h:mm:ss a',
|
|
||||||
'label' => 'March 10, 2013 6:15 pm'
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'format' => 'D M jS, Y g:i a',
|
|
||||||
'format_moment' => 'ddd MMM Do, YYYY h:mm:ss a',
|
|
||||||
'label' => 'Mon March 10th, 2013 6:15 pm'
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'format' => 'Y-m-d g:i a',
|
|
||||||
'format_moment' => 'YYYY-MMM-DD h:mm:ss a',
|
|
||||||
'label' => '2013-03-10 6:15 pm'
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'format' => 'd-m-Y g:i a',
|
|
||||||
'format_moment' => 'DD-MM-YYYY h:mm:ss a',
|
|
||||||
'label' => '20-03-2013 6:15 pm'
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'format' => 'm/d/Y g:i a',
|
|
||||||
'format_moment' => 'MM/DD/YYYY h:mm:ss a',
|
|
||||||
'label' => '03/20/2013 6:15 pm'
|
|
||||||
]
|
|
||||||
];
|
|
||||||
|
|
||||||
foreach ($formats as $format) {
|
|
||||||
$record = DatetimeFormat::whereLabel($format['label'])->first();
|
|
||||||
if ($record) {
|
|
||||||
$record->format = $format['format'];
|
|
||||||
$record->format_moment = $format['format_moment'];
|
|
||||||
$record->save();
|
|
||||||
} else {
|
|
||||||
DatetimeFormat::create($format);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private function createInvoiceDesigns() {
|
|
||||||
$designs = [
|
|
||||||
'Clean',
|
|
||||||
'Bold',
|
|
||||||
'Modern',
|
|
||||||
'Plain',
|
|
||||||
'Business',
|
|
||||||
'Creative',
|
|
||||||
'Elegant',
|
|
||||||
'Hipster',
|
|
||||||
'Playful',
|
|
||||||
'Photo',
|
|
||||||
];
|
|
||||||
|
|
||||||
for ($i=0; $i<count($designs); $i++) {
|
|
||||||
$design = $designs[$i];
|
|
||||||
$fileName = storage_path() . '/templates/' . strtolower($design) . '.js';
|
|
||||||
if (file_exists($fileName)) {
|
|
||||||
$pdfmake = file_get_contents($fileName);
|
|
||||||
if ($pdfmake) {
|
|
||||||
$record = InvoiceDesign::whereName($design)->first();
|
|
||||||
if (!$record) {
|
|
||||||
$record = new InvoiceDesign;
|
|
||||||
$record->id = $i + 1;
|
|
||||||
$record->name = $design;
|
|
||||||
}
|
|
||||||
$record->pdfmake = $pdfmake;
|
|
||||||
$record->save();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private function updateLocalization() {
|
|
||||||
// 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,
|
|
||||||
],
|
|
||||||
'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();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
* [Softaculous](https://www.softaculous.com/apps/ecommerce/Invoice_Ninja) - $30
|
* [Softaculous](https://www.softaculous.com/apps/ecommerce/Invoice_Ninja) - $30
|
||||||
|
|
||||||
### Requirements
|
### Requirements
|
||||||
* PHP >= 5.4.0
|
* PHP >= 5.5.9
|
||||||
* MCrypt PHP Extension
|
* MCrypt PHP Extension
|
||||||
* MySQL
|
* MySQL
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user