mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-01-07 06:33:57 -06:00
87 lines
2.3 KiB
PHP
87 lines
2.3 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace FireflyIII\Generator\Chart\Report;
|
||
|
|
||
|
use Config;
|
||
|
use Grumpydictator\Gchart\GChart;
|
||
|
use Illuminate\Support\Collection;
|
||
|
use Preferences;
|
||
|
|
||
|
/**
|
||
|
* Class GoogleReportChartGenerator
|
||
|
*
|
||
|
* @package FireflyIII\Generator\Chart\Report
|
||
|
*/
|
||
|
class ChartJsReportChartGenerator implements ReportChartGenerator
|
||
|
{
|
||
|
|
||
|
/**
|
||
|
* @param Collection $entries
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function yearInOut(Collection $entries)
|
||
|
{
|
||
|
// language:
|
||
|
$language = Preferences::get('language', 'en')->data;
|
||
|
$format = Config::get('firefly.month.' . $language);
|
||
|
|
||
|
$data = [
|
||
|
'count' => 2,
|
||
|
'labels' => [],
|
||
|
'datasets' => [
|
||
|
[
|
||
|
'label' => trans('firefly.income'),
|
||
|
'data' => []
|
||
|
],
|
||
|
[
|
||
|
'label' => trans('firefly.expenses'),
|
||
|
'data' => []
|
||
|
]
|
||
|
],
|
||
|
];
|
||
|
|
||
|
foreach ($entries as $entry) {
|
||
|
$data['labels'][] = $entry[0]->formatLocalized($format);
|
||
|
$data['datasets'][0]['data'][] = round($entry[1], 2);
|
||
|
$data['datasets'][1]['data'][] = round($entry[2], 2);
|
||
|
}
|
||
|
|
||
|
return $data;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $income
|
||
|
* @param string $expense
|
||
|
* @param int $count
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function yearInOutSummarized($income, $expense, $count)
|
||
|
{
|
||
|
|
||
|
// language:
|
||
|
$language = Preferences::get('language', 'en')->data;
|
||
|
$format = Config::get('firefly.month.' . $language);
|
||
|
|
||
|
$data = [
|
||
|
'count' => 2,
|
||
|
'labels' => [],
|
||
|
'datasets' => [
|
||
|
[
|
||
|
'label' => trans('firefly.income'),
|
||
|
'data' => []
|
||
|
],
|
||
|
[
|
||
|
'label' => trans('firefly.expenses'),
|
||
|
'data' => []
|
||
|
]
|
||
|
],
|
||
|
];
|
||
|
$data['datasets'][0]['data'][] = round($income, 2);
|
||
|
$data['datasets'][1]['data'][] = round($expense, 2);
|
||
|
$data['datasets'][0]['data'][] = round(($income / $count), 2);
|
||
|
$data['datasets'][1]['data'][] = round(($expense / $count), 2);
|
||
|
return $data;
|
||
|
}
|
||
|
}
|