firefly-iii/app/Helpers/Collection/Expense.php

101 lines
2.2 KiB
PHP
Raw Normal View History

2015-05-16 06:06:38 -05:00
<?php
namespace FireflyIII\Helpers\Collection;
use FireflyIII\Models\TransactionJournal;
use Illuminate\Support\Collection;
use stdClass;
/**
2015-05-16 12:08:54 -05:00
* @codeCoverageIgnore
2015-05-17 02:04:55 -05:00
*
2015-05-16 06:06:38 -05:00
* Class Expense
*
* @package FireflyIII\Helpers\Collection
*/
class Expense
{
/** @var Collection */
protected $expenses;
2015-05-24 01:00:40 -05:00
/** @var string */
protected $total = '0';
2015-05-16 06:06:38 -05:00
/**
*
*/
public function __construct()
{
$this->expenses = new Collection;
}
/**
* @param TransactionJournal $entry
*/
public function addOrCreateExpense(TransactionJournal $entry)
{
bcscale(2);
2015-05-17 03:30:18 -05:00
$accountId = $entry->account_id;
$amount = strval(round($entry->amount, 2));
if (bccomp('0', $amount) === 1) {
$amount = bcmul($amount, '-1');
}
2015-05-17 03:30:18 -05:00
if (!$this->expenses->has($accountId)) {
2015-05-16 06:06:38 -05:00
$newObject = new stdClass;
$newObject->amount = $amount;
2015-05-16 06:06:38 -05:00
$newObject->name = $entry->name;
$newObject->count = 1;
2015-05-17 03:30:18 -05:00
$newObject->id = $accountId;
$this->expenses->put($accountId, $newObject);
2015-05-16 06:06:38 -05:00
} else {
2015-05-24 01:00:40 -05:00
$existing = $this->expenses->get($accountId);
$existing->amount = bcadd($existing->amount, $amount);
2015-05-16 06:06:38 -05:00
$existing->count++;
2015-05-17 03:30:18 -05:00
$this->expenses->put($accountId, $existing);
2015-05-16 06:06:38 -05:00
}
}
/**
* @param $add
*/
public function addToTotal($add)
{
2015-05-24 01:00:40 -05:00
bcscale(2);
2015-12-12 13:16:30 -06:00
2015-12-12 13:16:30 -06:00
$add = strval(round($add, 2));
if (bccomp('0', $add) === 1) {
$add = bcmul($add, '-1');
}
// if amount is positive, the original transaction
// was a transfer. But since this is an expense report,
// that amount must be negative.
2015-05-24 01:00:40 -05:00
$this->total = bcadd($this->total, $add);
2015-05-16 06:06:38 -05:00
}
/**
* @return Collection
*/
public function getExpenses()
{
2015-12-11 11:31:15 -06:00
$set = $this->expenses->sortBy(
2015-06-06 16:09:12 -05:00
function (stdClass $object) {
2015-05-16 06:06:38 -05:00
return $object->amount;
}
);
2015-06-16 23:11:35 -05:00
return $set;
2015-05-16 06:06:38 -05:00
}
/**
2015-05-24 01:00:40 -05:00
* @return string
2015-05-16 06:06:38 -05:00
*/
public function getTotal()
{
2015-05-24 01:00:40 -05:00
return strval(round($this->total, 2));
2015-05-16 06:06:38 -05:00
}
2015-05-20 12:56:14 -05:00
}