akaunting/database/seeds/Categories.php
Denis Duliçi 997492fae7 formatting
2021-04-23 17:12:38 +03:00

92 lines
2.4 KiB
PHP

<?php
namespace Database\Seeds;
use App\Abstracts\Model;
use App\Models\Setting\Category;
use Illuminate\Database\Seeder;
class Categories extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
Model::unguard();
$this->create();
Model::reguard();
}
private function create()
{
$company_id = $this->command->argument('company');
$rows = [
[
'company_id' => $company_id,
'name' => trans_choice('general.transfers', 1),
'type' => 'other',
'color' => '#3c3f72',
'enabled' => '1',
],
[
'company_id' => $company_id,
'name' => trans('demo.categories.deposit'),
'type' => 'income',
'color' => '#efad32',
'enabled' => '1',
],
[
'company_id' => $company_id,
'name' => trans('demo.categories.sales'),
'type' => 'income',
'color' => '#6da252',
'enabled' => '1',
],
[
'company_id' => $company_id,
'name' => trans_choice('general.others', 1),
'type' => 'expense',
'color' => '#e5e5e5',
'enabled' => '1',
],
[
'company_id' => $company_id,
'name' => trans('general.general'),
'type' => 'item',
'color' => '#328aef',
'enabled' => '1',
],
];
$income_category_id = $expense_category_id = 0;
foreach ($rows as $row) {
$category = Category::create($row);
switch ($category->type) {
case 'income':
if (empty($income_category_id)) {
$income_category_id = $category->id;
}
break;
case 'expense':
if (empty($expense_category_id)) {
$expense_category_id = $category->id;
}
break;
}
}
setting()->set('default.income_category', $income_category_id);
setting()->set('default.expense_category', $expense_category_id);
}
}