. */ namespace FireflyIII\TransactionRules\Actions; use FireflyIII\Models\Note; use FireflyIII\Models\TransactionJournal; use FireflyIII\Support\Request\ConvertsDataTypes; use FireflyIII\Support\Steam; use Illuminate\Support\Facades\Log; /** * Class AppendNotesToDescription */ class AppendNotesToDescription implements ActionInterface { use ConvertsDataTypes; /** * @inheritDoc */ public function actOnArray(array $journal): bool { Log::debug('Now in AppendNotesToDescription'); /** @var TransactionJournal $journal */ $journal = TransactionJournal::where('user_id', $journal['user_id'])->find($journal['transaction_journal_id']); if (null === $journal) { Log::error(sprintf('No journal #%d belongs to user #%d.', $journal['transaction_journal_id'], $journal['user_id'])); return false; } $note = $journal->notes()->first(); if (null === $note) { Log::debug('Journal has no notes.'); $note = new Note; $note->noteable()->associate($journal); $note->text = ''; } // only append if there is something to append if ('' !== $note->text) { $journal->description = trim(sprintf("%s %s", $journal->description, (string) $this->clearString($note->text, false))); $journal->save(); Log::debug(sprintf('Journal description is updated to "%s".', $journal->description)); return true; } return false; } }