123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- <?php
-
- namespace App\Observers;
-
- use App\Enums\Accounting\TransactionType;
- use App\Models\Accounting\Account;
- use App\Models\Accounting\JournalEntry;
- use App\Models\Accounting\Transaction;
- use Illuminate\Support\Facades\DB;
-
- class TransactionObserver
- {
- /**
- * Handle the Transaction "created" event.
- */
- public function created(Transaction $transaction): void
- {
- if ($transaction->type === TransactionType::Journal) {
- return;
- }
-
- $chartAccount = $transaction->account;
- $bankAccount = $transaction->bankAccount->account;
-
- $debitAccount = $transaction->type === TransactionType::Withdrawal ? $chartAccount : $bankAccount;
- $creditAccount = $transaction->type === TransactionType::Withdrawal ? $bankAccount : $chartAccount;
-
- $this->createJournalEntries($transaction, $debitAccount, $creditAccount);
- }
-
- private function createJournalEntries(Transaction $transaction, Account $debitAccount, Account $creditAccount): void
- {
- $debitAccount->journalEntries()->create([
- 'company_id' => $transaction->company_id,
- 'transaction_id' => $transaction->id,
- 'type' => 'debit',
- 'amount' => $transaction->amount,
- 'description' => $transaction->description,
- ]);
-
- $creditAccount->journalEntries()->create([
- 'company_id' => $transaction->company_id,
- 'transaction_id' => $transaction->id,
- 'type' => 'credit',
- 'amount' => $transaction->amount,
- 'description' => $transaction->description,
- ]);
- }
-
- /**
- * Handle the Transaction "updated" event.
- */
- public function updated(Transaction $transaction): void
- {
- $changes = $transaction->getChanges();
-
- $relevantChanges = array_intersect_key($changes, array_flip(['amount', 'description', 'account_id', 'bank_account_id', 'type']));
-
- if (empty($relevantChanges)) {
- return;
- }
-
- $chartAccount = $transaction->account;
- $bankAccount = $transaction->bankAccount->account;
-
- $journalEntries = $transaction->journalEntries;
-
- $debitEntry = $journalEntries->where('type', 'debit')->first();
- $creditEntry = $journalEntries->where('type', 'credit')->first();
-
- $debitAccount = $transaction->type === TransactionType::Withdrawal ? $chartAccount : $bankAccount;
- $creditAccount = $transaction->type === TransactionType::Withdrawal ? $bankAccount : $chartAccount;
-
- $debitEntry?->update([
- 'account_id' => $debitAccount->id,
- 'amount' => $transaction->amount,
- 'description' => $transaction->description,
- ]);
-
- $creditEntry?->update([
- 'account_id' => $creditAccount->id,
- 'amount' => $transaction->amount,
- 'description' => $transaction->description,
- ]);
- }
-
- /**
- * Handle the Transaction "deleting" event.
- */
- public function deleting(Transaction $transaction): void
- {
- DB::transaction(static function () use ($transaction) {
- $transaction->journalEntries()->each(fn (JournalEntry $entry) => $entry->delete());
- });
- }
-
- /**
- * Handle the Transaction "deleted" event.
- */
- public function deleted(Transaction $transaction): void
- {
- //
- }
-
- /**
- * Handle the Transaction "restored" event.
- */
- public function restored(Transaction $transaction): void
- {
- //
- }
-
- /**
- * Handle the Transaction "force deleted" event.
- */
- public function forceDeleted(Transaction $transaction): void
- {
- //
- }
- }
|