| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 | 
							- <?php
 - 
 - namespace Database\Factories\Accounting;
 - 
 - use App\Models\Accounting\Account;
 - use App\Models\Accounting\Transaction;
 - use App\Models\Banking\BankAccount;
 - use App\Models\Company;
 - use Illuminate\Database\Eloquent\Factories\Factory;
 - 
 - /**
 -  * @extends Factory<Transaction>
 -  */
 - class TransactionFactory extends Factory
 - {
 -     /**
 -      * The name of the factory's corresponding model.
 -      */
 -     protected $model = Transaction::class;
 - 
 -     /**
 -      * Define the model's default state.
 -      *
 -      * @return array<string, mixed>
 -      */
 -     public function definition(): array
 -     {
 -         return [
 -             'company_id' => 1,
 -             'bank_account_id' => 1,
 -             'account_id' => $this->faker->numberBetween(2, 30),
 -             'type' => $this->faker->randomElement(['deposit', 'withdrawal', 'journal']),
 -             'payment_channel' => $this->faker->randomElement(['online', 'in store', 'other']),
 -             'description' => $this->faker->sentence,
 -             'notes' => $this->faker->paragraph,
 -             'reference' => $this->faker->word,
 -             'amount' => $this->faker->numberBetween(100, 5000),
 -             'pending' => $this->faker->boolean,
 -             'reviewed' => $this->faker->boolean,
 -             'posted_at' => $this->faker->dateTimeBetween('-2 years'),
 -             'created_by' => 1,
 -             'updated_by' => 1,
 -         ];
 -     }
 - 
 -     public function configure(): static
 -     {
 -         return $this->afterCreating(function (Transaction $transaction) {
 -             $chartAccount = $transaction->account;
 -             $bankAccount = $transaction->bankAccount->account;
 - 
 -             $debitAccount = $transaction->type->isWithdrawal() ? $chartAccount : $bankAccount;
 -             $creditAccount = $transaction->type->isWithdrawal() ? $bankAccount : $chartAccount;
 - 
 -             if ($debitAccount === null || $creditAccount === null) {
 -                 return;
 -             }
 - 
 -             $debitAccount->journalEntries()->create([
 -                 'company_id' => $transaction->company_id,
 -                 'transaction_id' => $transaction->id,
 -                 'type' => 'debit',
 -                 'amount' => $transaction->amount,
 -                 'description' => $transaction->description,
 -                 'created_by' => $transaction->created_by,
 -                 'updated_by' => $transaction->updated_by,
 -             ]);
 - 
 -             $creditAccount->journalEntries()->create([
 -                 'company_id' => $transaction->company_id,
 -                 'transaction_id' => $transaction->id,
 -                 'type' => 'credit',
 -                 'amount' => $transaction->amount,
 -                 'description' => $transaction->description,
 -                 'created_by' => $transaction->created_by,
 -                 'updated_by' => $transaction->updated_by,
 -             ]);
 -         });
 -     }
 - 
 -     public function forCompanyAndBankAccount(Company $company, BankAccount $bankAccount): static
 -     {
 -         return $this->state(function (array $attributes) use ($bankAccount, $company) {
 -             $type = $this->faker->randomElement(['deposit', 'withdrawal', 'journal']);
 - 
 -             $associatedAccountTypes = match ($type) {
 -                 'deposit' => ['asset', 'liability', 'equity', 'revenue'],
 -                 'withdrawal' => ['asset', 'liability', 'equity', 'expense'],
 -                 default => ['asset', 'liability', 'equity', 'revenue', 'expense'],
 -             };
 - 
 -             $accountIdForBankAccount = $bankAccount->account->id;
 - 
 -             $account = Account::where('category', $this->faker->randomElement($associatedAccountTypes))
 -                 ->where('company_id', $company->id)
 -                 ->where('id', '<>', $accountIdForBankAccount)
 -                 ->inRandomOrder()
 -                 ->firstOrFail();
 - 
 -             return [
 -                 'company_id' => $company->id,
 -                 'bank_account_id' => $bankAccount->id,
 -                 'account_id' => $account->id,
 -                 'type' => $type,
 -             ];
 -         });
 -     }
 - }
 
 
  |