expenses = new Collection; } /** * @param TransactionJournal $entry */ public function addOrCreateExpense(TransactionJournal $entry) { $accountId = $entry->account_id; if (!$this->expenses->has($accountId)) { $newObject = new stdClass; $newObject->amount = floatval($entry->queryAmount); $newObject->name = $entry->name; $newObject->count = 1; $newObject->id = $accountId; $this->expenses->put($accountId, $newObject); } else { $existing = $this->expenses->get($accountId); $existing->amount += floatval($entry->queryAmount); $existing->count++; $this->expenses->put($accountId, $existing); } } /** * @param $add */ public function addToTotal($add) { $this->total += floatval($add); } /** * @return Collection */ public function getExpenses() { $this->expenses->sortBy( function (stdClass $object) { return $object->amount; } ); return $this->expenses; } /** * @return float */ public function getTotal() { return $this->total; } }