journal; $piggyBankId = $event->piggyBankId; Log::debug('JournalCreated event: ' . $journal->id . ', ' . $piggyBankId); /** @var PiggyBank $piggyBank */ $piggyBank = Auth::user()->piggybanks()->where('piggy_banks.id', $piggyBankId)->first(['piggy_banks.*']); if (is_null($piggyBank) || $journal->transactionType->type != 'Transfer') { return; } Log::debug('Found a piggy bank'); $amount = 0; /** @var Transaction $transaction */ foreach ($journal->transactions()->get() as $transaction) { if ($transaction->account_id === $piggyBank->account_id) { // this transaction is the relevant one. $amount = floatval($transaction->amount); } } Log::debug('Amount: ' . $amount); if ($amount == 0) { return; } // update piggy bank rep for date of transaction journal. $repetition = $piggyBank->piggyBankRepetitions()->relevantOnDate($journal->date)->first(); if (is_null($repetition)) { return; } Log::debug('Found rep! ' . $repetition->id); $repetition->currentamount += $amount; $repetition->save(); PiggyBankEvent::create( [ 'piggy_bank_id' => $piggyBank->id, 'transaction_journal_id' => $journal->id, 'date' => $journal->date, 'amount' => $amount ] ); } }