mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2024-11-30 20:54:04 -06:00
208 lines
5.4 KiB
PHP
208 lines
5.4 KiB
PHP
<?php
|
|
|
|
namespace FireflyIII\Support;
|
|
|
|
use Carbon\Carbon;
|
|
use FireflyIII\Models\Account;
|
|
use FireflyIII\Models\PiggyBank;
|
|
use FireflyIII\Models\PiggyBankRepetition;
|
|
use Illuminate\Support\Collection;
|
|
|
|
/**
|
|
* Class Steam
|
|
*
|
|
* @package FireflyIII\Support
|
|
*/
|
|
class Steam
|
|
{
|
|
/**
|
|
*
|
|
* @param Account $account
|
|
* @param Carbon $date
|
|
* @param bool $ignoreVirtualBalance
|
|
*
|
|
* @return float
|
|
*/
|
|
public function balance(Account $account, Carbon $date = null, $ignoreVirtualBalance = false)
|
|
{
|
|
$date = is_null($date) ? Carbon::now() : $date;
|
|
|
|
// find the first known transaction on this account:
|
|
//
|
|
$firstDateObject = $account
|
|
->transactions()
|
|
->leftJoin('transaction_journals', 'transaction_journals.id', '=', 'transactions.transaction_journal_id')
|
|
->orderBy('transaction_journals.date', 'ASC')->first(['transaction_journals.date']);
|
|
|
|
$firstDate = is_null($firstDateObject) ? clone $date : new Carbon($firstDateObject->date);
|
|
$date = $date < $firstDate ? $firstDate : $date;
|
|
|
|
/**
|
|
*select * from transactions
|
|
* left join transaction_journals ON transaction_journals.id = transactions.transaction_journal_id
|
|
* order by date ASC
|
|
*/
|
|
|
|
$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')
|
|
);
|
|
if (!$ignoreVirtualBalance) {
|
|
$balance += floatval($account->virtual_balance);
|
|
}
|
|
|
|
return $balance;
|
|
}
|
|
|
|
/**
|
|
* 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;
|
|
|
|
}
|
|
|
|
/**
|
|
* 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);
|
|
$array[$id]['encrypted'] = intval($entry->encrypted);
|
|
} else {
|
|
$array[$id] = [
|
|
'amount' => floatval($entry->amount),
|
|
'spent' => floatval($entry->spent),
|
|
'encrypted' => intval($entry->encrypted),
|
|
'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;
|
|
}
|
|
|
|
/**
|
|
* @param PiggyBank $piggyBank
|
|
* @param PiggyBankRepetition $repetition
|
|
*
|
|
* @return int
|
|
*/
|
|
public function percentage(PiggyBank $piggyBank, PiggyBankRepetition $repetition)
|
|
{
|
|
$pct = $repetition->currentamount / $piggyBank->targetamount * 100;
|
|
if ($pct > 100) {
|
|
// @codeCoverageIgnoreStart
|
|
return 100;
|
|
// @codeCoverageIgnoreEnd
|
|
} else {
|
|
return floor($pct);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 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;
|
|
|
|
}
|
|
|
|
/**
|
|
* 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;
|
|
}
|
|
|
|
}
|