2015-02-07 01:23:44 -06:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace FireflyIII\Support;
|
|
|
|
|
|
|
|
use Carbon\Carbon;
|
|
|
|
use FireflyIII\Models\Account;
|
2015-02-23 13:25:48 -06:00
|
|
|
use Illuminate\Support\Collection;
|
2015-02-07 01:23:44 -06:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Class Steam
|
|
|
|
*
|
|
|
|
* @package FireflyIII\Support
|
|
|
|
*/
|
|
|
|
class Steam
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param Account $account
|
2015-02-11 00:35:10 -06:00
|
|
|
* @param Carbon $date
|
2015-02-07 01:23:44 -06:00
|
|
|
*
|
|
|
|
* @return float
|
|
|
|
*/
|
|
|
|
public function balance(Account $account, Carbon $date = null)
|
|
|
|
{
|
|
|
|
$date = is_null($date) ? Carbon::now() : $date;
|
|
|
|
$balance = floatval(
|
|
|
|
$account->transactions()->leftJoin(
|
|
|
|
'transaction_journals', 'transaction_journals.id', '=', 'transactions.transaction_journal_id'
|
|
|
|
)->where('transaction_journals.date', '<=', $date->format('Y-m-d'))->sum('transactions.amount')
|
|
|
|
);
|
|
|
|
|
|
|
|
return $balance;
|
|
|
|
}
|
|
|
|
|
2015-02-23 13:25:48 -06:00
|
|
|
/**
|
|
|
|
* Turns a collection into an array. Needs the field 'id' for the key,
|
|
|
|
* and saves only 'name' and 'amount' as a sub array.
|
|
|
|
*
|
|
|
|
* @param Collection $collection
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function makeArray(Collection $collection)
|
|
|
|
{
|
|
|
|
$array = [];
|
|
|
|
foreach ($collection as $entry) {
|
|
|
|
$entry->spent = isset($entry->spent) ? floatval($entry->spent) : 0.0;
|
|
|
|
$id = intval($entry->id);
|
|
|
|
if (isset($array[$id])) {
|
|
|
|
$array[$id]['amount'] += floatval($entry->amount);
|
|
|
|
$array[$id]['spent'] += floatval($entry->spent);
|
|
|
|
} else {
|
|
|
|
$array[$id] = [
|
|
|
|
'amount' => floatval($entry->amount),
|
|
|
|
'spent' => floatval($entry->spent),
|
|
|
|
'name' => $entry->name
|
|
|
|
];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $array;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Merges two of the arrays as defined above. Can't handle more (yet)
|
|
|
|
*
|
|
|
|
* @param array $one
|
|
|
|
* @param array $two
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function mergeArrays(array $one, array $two)
|
|
|
|
{
|
|
|
|
foreach ($two as $id => $value) {
|
|
|
|
// $otherId also exists in $one:
|
|
|
|
if (isset($one[$id])) {
|
|
|
|
$one[$id]['amount'] += $value['amount'];
|
|
|
|
$one[$id]['spent'] += $value['spent'];
|
|
|
|
} else {
|
|
|
|
$one[$id] = $value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $one;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sort an array where all 'amount' keys are positive floats.
|
|
|
|
*
|
|
|
|
* @param array $array
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function sortArray(array $array)
|
|
|
|
{
|
|
|
|
uasort(
|
|
|
|
$array, function ($left, $right) {
|
|
|
|
if ($left['amount'] == $right['amount']) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
return ($left['amount'] < $right['amount']) ? 1 : -1;
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
return $array;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Only return the top X entries, group the rest by amount
|
|
|
|
* and described as 'Others'. id = 0 as well
|
|
|
|
*
|
|
|
|
* @param array $array
|
|
|
|
* @param int $limit
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function limitArray(array $array, $limit = 10)
|
|
|
|
{
|
|
|
|
$others = [
|
|
|
|
'name' => 'Others',
|
|
|
|
'amount' => 0
|
|
|
|
];
|
|
|
|
$return = [];
|
|
|
|
$count = 0;
|
|
|
|
foreach ($array as $id => $entry) {
|
|
|
|
if ($count < ($limit - 1)) {
|
|
|
|
$return[$id] = $entry;
|
|
|
|
} else {
|
|
|
|
$others['amount'] += $entry['amount'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$count++;
|
|
|
|
}
|
|
|
|
$return[0] = $others;
|
|
|
|
|
|
|
|
return $return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sort an array where all 'amount' keys are negative floats.
|
|
|
|
*
|
|
|
|
* @param array $array
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function sortNegativeArray(array $array)
|
|
|
|
{
|
|
|
|
uasort(
|
|
|
|
$array, function ($left, $right) {
|
|
|
|
if ($left['amount'] == $right['amount']) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
return ($left['amount'] < $right['amount']) ? -1 : 1;
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
return $array;
|
|
|
|
}
|
|
|
|
|
2015-02-07 01:23:44 -06:00
|
|
|
}
|