148 lines
4.5 KiB
PHP
148 lines
4.5 KiB
PHP
<?php
|
|
|
|
namespace Database\Factories;
|
|
|
|
use App\Abstracts\Factory;
|
|
use App\Interfaces\Utility\TransactionNumber;
|
|
use App\Models\Banking\Transaction as Model;
|
|
use App\Models\Common\Contact;
|
|
use App\Traits\Transactions;
|
|
use App\Utilities\Date;
|
|
|
|
class Transaction extends Factory
|
|
{
|
|
use Transactions;
|
|
|
|
/**
|
|
* The name of the factory's corresponding model.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $model = Model::class;
|
|
|
|
/**
|
|
* The type of the model.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $type = 'income';
|
|
|
|
/**
|
|
* Define the model's default state.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function definition()
|
|
{
|
|
$types = array_merge($this->getIncomeTypes(), $this->getExpenseTypes());
|
|
$this->type = $this->faker->randomElement($types);
|
|
|
|
$category_type = in_array($this->type, $this->getIncomeTypes()) ? 'income' : 'expense';
|
|
|
|
return [
|
|
'company_id' => $this->company->id,
|
|
'type' => $this->type,
|
|
'number' => $this->getNumber($this->type),
|
|
'account_id' => setting('default.account'),
|
|
'paid_at' => $this->faker->dateTimeBetween(now()->startOfYear(), now()->endOfYear())->format('Y-m-d H:i:s'),
|
|
'amount' => $this->faker->randomFloat(2, 1, 1000),
|
|
'currency_code' => default_currency(),
|
|
'currency_rate' => '1.0',
|
|
'description' => $this->faker->text(5),
|
|
'category_id' => $this->company->categories()->$category_type()->get()->random(1)->pluck('id')->first(),
|
|
'reference' => $this->faker->text(5),
|
|
'payment_method' => setting('default.payment_method'),
|
|
'created_from' => 'core::factory',
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Indicate that the model type is income.
|
|
*
|
|
* @return \Illuminate\Database\Eloquent\Factories\Factory
|
|
*/
|
|
public function income()
|
|
{
|
|
return $this->state(function (array $attributes): array {
|
|
$contacts = Contact::customer()->enabled()->get();
|
|
|
|
if ($contacts->count()) {
|
|
$contact = $contacts->random(1)->first();
|
|
} else {
|
|
$contact = Contact::factory()->customer()->enabled()->create();
|
|
}
|
|
|
|
return [
|
|
'type' => 'income',
|
|
'number' => $this->getNumber('income', '', $contact),
|
|
'contact_id' => $contact->id,
|
|
'category_id' => $this->company->categories()->income()->get()->random(1)->pluck('id')->first(),
|
|
];
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Indicate that the model type is expense.
|
|
*
|
|
* @return \Illuminate\Database\Eloquent\Factories\Factory
|
|
*/
|
|
public function expense()
|
|
{
|
|
return $this->state(function (array $attributes): array {
|
|
$contacts = Contact::vendor()->enabled()->get();
|
|
|
|
if ($contacts->count()) {
|
|
$contact = $contacts->random(1)->first();
|
|
} else {
|
|
$contact = Contact::factory()->vendor()->enabled()->create();
|
|
}
|
|
|
|
return [
|
|
'type' => 'expense',
|
|
'number' => $this->getNumber('expense', '', $contact),
|
|
'contact_id' => $contact->id,
|
|
'category_id' => $this->company->categories()->expense()->get()->random(1)->pluck('id')->first(),
|
|
];
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Indicate that the model is recurring.
|
|
*
|
|
* @return \Illuminate\Database\Eloquent\Factories\Factory
|
|
*/
|
|
public function recurring()
|
|
{
|
|
$type = $this->getRawAttribute('type') . '-recurring';
|
|
|
|
return $this->state([
|
|
'type' => $type,
|
|
'number' => $this->getNumber($type, '-recurring'),
|
|
'recurring_started_at' => Date::now()->format('Y-m-d H:i:s'),
|
|
'recurring_frequency' => 'daily',
|
|
'recurring_custom_frequency' => 'daily',
|
|
'recurring_interval' => '1',
|
|
'recurring_limit' => 'date',
|
|
'recurring_limit_date' => Date::now()->addDay(7)->format('Y-m-d H:i:s'),
|
|
'disabled_transaction_paid' => "Auto-generated",
|
|
'disabled_transaction_number' => "Auto-generated",
|
|
'real_type' => $this->getRawAttribute('type'),
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Get transaction number
|
|
*
|
|
*/
|
|
public function getNumber($type, $suffix = '', $contact = null)
|
|
{
|
|
$utility = app(TransactionNumber::class);
|
|
|
|
$number = $utility->getNextNumber($type, $suffix, $contact);
|
|
|
|
$utility->increaseNextNumber($type, $suffix ,$contact);
|
|
|
|
return $number;
|
|
}
|
|
}
|