2015-06-27 09:01:06 -05:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace FireflyIII\Generator\Chart\Account;
|
|
|
|
|
|
|
|
use Carbon\Carbon;
|
|
|
|
use Config;
|
|
|
|
use FireflyIII\Models\Account;
|
|
|
|
use Illuminate\Support\Collection;
|
|
|
|
use Preferences;
|
|
|
|
use Steam;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class ChartJsAccountChartGenerator
|
|
|
|
*
|
|
|
|
* @package FireflyIII\Generator\Chart\Account
|
|
|
|
*/
|
|
|
|
class ChartJsAccountChartGenerator implements AccountChartGenerator
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2015-06-28 05:41:58 -05:00
|
|
|
* @codeCoverageIgnore
|
2015-07-06 09:52:18 -05:00
|
|
|
*
|
2015-06-27 09:01:06 -05:00
|
|
|
* @param Collection $accounts
|
|
|
|
* @param Carbon $start
|
|
|
|
* @param Carbon $end
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function all(Collection $accounts, Carbon $start, Carbon $end)
|
|
|
|
{
|
|
|
|
return $this->frontpage($accounts, $start, $end);
|
|
|
|
}
|
|
|
|
|
2015-08-01 00:04:41 -05:00
|
|
|
/**
|
|
|
|
* @param Collection $accounts
|
|
|
|
* @param Carbon $start
|
|
|
|
* @param Carbon $end
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function expenseAccounts(Collection $accounts, Carbon $start, Carbon $end)
|
|
|
|
{
|
|
|
|
$data = [
|
|
|
|
'count' => 1,
|
2015-08-16 13:26:11 -05:00
|
|
|
'labels' => [], 'datasets' => [[
|
|
|
|
'label' => trans('firefly.spent'),
|
|
|
|
'data' => []]]];
|
2015-08-01 00:04:41 -05:00
|
|
|
|
2015-08-16 13:26:11 -05:00
|
|
|
bcscale(2);
|
2015-08-01 00:12:03 -05:00
|
|
|
$start->subDay();
|
2015-08-16 13:26:11 -05:00
|
|
|
$ids = $this->getIdsFromCollection($accounts);
|
2015-08-01 00:04:41 -05:00
|
|
|
$startBalances = Steam::balancesById($ids, $start);
|
|
|
|
$endBalances = Steam::balancesById($ids, $end);
|
|
|
|
|
2015-08-02 00:41:47 -05:00
|
|
|
$accounts->each(
|
|
|
|
function (Account $account) use ($startBalances, $endBalances) {
|
|
|
|
$id = $account->id;
|
2015-08-16 13:26:11 -05:00
|
|
|
$startBalance = $this->isInArray($startBalances, $id);
|
|
|
|
$endBalance = $this->isInArray($endBalances, $id);
|
|
|
|
$diff = bcsub($endBalance, $startBalance);
|
2015-08-02 00:41:47 -05:00
|
|
|
$account->difference = round($diff, 2);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
$accounts = $accounts->sortByDesc(
|
|
|
|
function (Account $account) {
|
|
|
|
return $account->difference;
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2015-08-01 00:04:41 -05:00
|
|
|
foreach ($accounts as $account) {
|
2015-08-02 00:41:47 -05:00
|
|
|
if ($account->difference > 0) {
|
2015-08-01 00:04:41 -05:00
|
|
|
$data['labels'][] = $account->name;
|
2015-08-02 00:41:47 -05:00
|
|
|
$data['datasets'][0]['data'][] = $account->difference;
|
2015-08-01 00:04:41 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
}
|
|
|
|
|
2015-08-16 13:26:11 -05:00
|
|
|
/**
|
|
|
|
* @param $array
|
|
|
|
* @param $entryId
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
protected function isInArray($array, $entryId)
|
|
|
|
{
|
|
|
|
if (isset($array[$entryId])) {
|
|
|
|
return $array[$entryId];
|
|
|
|
}
|
|
|
|
|
|
|
|
return '0';
|
|
|
|
}
|
|
|
|
|
2015-08-01 00:04:41 -05:00
|
|
|
|
2015-06-27 09:01:06 -05:00
|
|
|
/**
|
|
|
|
* @param Collection $accounts
|
|
|
|
* @param Carbon $start
|
|
|
|
* @param Carbon $end
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function frontpage(Collection $accounts, Carbon $start, Carbon $end)
|
|
|
|
{
|
|
|
|
// language:
|
|
|
|
$language = Preferences::get('language', 'en')->data;
|
|
|
|
$format = Config::get('firefly.monthAndDay.' . $language);
|
|
|
|
$data = [
|
|
|
|
'count' => 0,
|
|
|
|
'labels' => [],
|
|
|
|
'datasets' => [],
|
|
|
|
];
|
|
|
|
$current = clone $start;
|
|
|
|
while ($current <= $end) {
|
|
|
|
$data['labels'][] = $current->formatLocalized($format);
|
|
|
|
$current->addDay();
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach ($accounts as $account) {
|
|
|
|
$set = [
|
|
|
|
'label' => $account->name,
|
|
|
|
'fillColor' => 'rgba(220,220,220,0.2)',
|
|
|
|
'strokeColor' => 'rgba(220,220,220,1)',
|
|
|
|
'pointColor' => 'rgba(220,220,220,1)',
|
|
|
|
'pointStrokeColor' => '#fff',
|
|
|
|
'pointHighlightFill' => '#fff',
|
|
|
|
'pointHighlightStroke' => 'rgba(220,220,220,1)',
|
|
|
|
'data' => [],
|
|
|
|
];
|
|
|
|
$current = clone $start;
|
|
|
|
while ($current <= $end) {
|
|
|
|
$set['data'][] = Steam::balance($account, $current);
|
|
|
|
$current->addDay();
|
|
|
|
}
|
|
|
|
$data['datasets'][] = $set;
|
|
|
|
}
|
2015-06-28 09:20:14 -05:00
|
|
|
$data['count'] = count($data['datasets']);
|
2015-06-27 09:01:06 -05:00
|
|
|
|
|
|
|
return $data;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param Account $account
|
|
|
|
* @param Carbon $start
|
|
|
|
* @param Carbon $end
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function single(Account $account, Carbon $start, Carbon $end)
|
|
|
|
{
|
2015-06-27 10:38:16 -05:00
|
|
|
// language:
|
|
|
|
$language = Preferences::get('language', 'en')->data;
|
|
|
|
$format = Config::get('firefly.monthAndDay.' . $language);
|
|
|
|
|
|
|
|
$data = [
|
|
|
|
'count' => 1,
|
|
|
|
'labels' => [],
|
|
|
|
'datasets' => [
|
|
|
|
[
|
|
|
|
'label' => $account->name,
|
|
|
|
'data' => []
|
|
|
|
]
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
$current = clone $start;
|
|
|
|
|
|
|
|
while ($end >= $current) {
|
|
|
|
$data['labels'][] = $current->formatLocalized($format);
|
|
|
|
$data['datasets'][0]['data'][] = Steam::balance($account, $current);
|
|
|
|
$current->addDay();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $data;
|
2015-06-27 09:01:06 -05:00
|
|
|
}
|
2015-08-16 13:26:11 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param Collection $collection
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
protected function getIdsFromCollection(Collection $collection)
|
|
|
|
{
|
|
|
|
$ids = [];
|
|
|
|
foreach ($collection as $entry) {
|
|
|
|
$ids[] = $entry->id;
|
|
|
|
}
|
|
|
|
|
|
|
|
return array_unique($ids);
|
|
|
|
|
|
|
|
}
|
2015-06-28 01:24:12 -05:00
|
|
|
}
|