2015-06-27 16:01:06 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace FireflyIII\Generator\Chart\Budget;
|
|
|
|
|
|
|
|
|
2015-06-27 20:39:50 +02:00
|
|
|
use Config;
|
2015-06-27 16:01:06 +02:00
|
|
|
use Illuminate\Support\Collection;
|
2015-06-27 20:39:50 +02:00
|
|
|
use Preferences;
|
2015-06-27 16:01:06 +02:00
|
|
|
|
2015-06-27 17:05:39 +02:00
|
|
|
/**
|
|
|
|
* Class ChartJsBudgetChartGenerator
|
|
|
|
*
|
|
|
|
* @package FireflyIII\Generator\Chart\Budget
|
|
|
|
*/
|
2015-06-27 16:01:06 +02:00
|
|
|
class ChartJsBudgetChartGenerator implements BudgetChartGenerator
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param Collection $entries
|
2015-07-01 11:04:08 +02:00
|
|
|
* @param string $dateFormat
|
2015-06-27 16:01:06 +02:00
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
2015-07-01 11:04:08 +02:00
|
|
|
public function budget(Collection $entries, $dateFormat = 'month')
|
2015-06-27 16:01:06 +02:00
|
|
|
{
|
2015-07-01 11:04:08 +02:00
|
|
|
// language:
|
2015-12-24 08:35:08 +01:00
|
|
|
$language = Preferences::get('language', env('DEFAULT_LANGUAGE', 'en_US'))->data;
|
2015-07-01 11:04:08 +02:00
|
|
|
$format = Config::get('firefly.' . $dateFormat . '.' . $language);
|
|
|
|
|
2015-06-27 20:39:50 +02:00
|
|
|
$data = [
|
|
|
|
'labels' => [],
|
|
|
|
'datasets' => [
|
|
|
|
[
|
|
|
|
'label' => 'Amount',
|
|
|
|
'data' => [],
|
2015-12-24 08:35:08 +01:00
|
|
|
],
|
2015-06-27 20:39:50 +02:00
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
/** @var array $entry */
|
|
|
|
foreach ($entries as $entry) {
|
2015-07-01 11:04:08 +02:00
|
|
|
$data['labels'][] = $entry[0]->formatLocalized($format);
|
2015-06-27 20:39:50 +02:00
|
|
|
$data['datasets'][0]['data'][] = $entry[1];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2015-07-06 17:45:59 +02:00
|
|
|
$data['count'] = count($data['datasets']);
|
|
|
|
|
2015-06-27 20:39:50 +02:00
|
|
|
return $data;
|
2015-06-27 16:01:06 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-06-28 12:41:58 +02:00
|
|
|
* @codeCoverageIgnore
|
2015-06-28 18:00:11 +02:00
|
|
|
*
|
2015-06-27 16:01:06 +02:00
|
|
|
* @param Collection $entries
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function budgetLimit(Collection $entries)
|
|
|
|
{
|
2015-07-01 11:04:08 +02:00
|
|
|
return $this->budget($entries, 'monthAndDay');
|
2015-06-27 16:01:06 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param Collection $entries
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function frontpage(Collection $entries)
|
|
|
|
{
|
2015-06-27 17:05:39 +02:00
|
|
|
$data = [
|
2015-06-28 18:00:11 +02:00
|
|
|
'count' => 0,
|
2015-06-27 17:05:39 +02:00
|
|
|
'labels' => [],
|
|
|
|
'datasets' => [],
|
|
|
|
];
|
|
|
|
// dataset: left
|
|
|
|
// dataset: spent
|
|
|
|
// dataset: overspent
|
|
|
|
$left = [];
|
|
|
|
$spent = [];
|
|
|
|
$overspent = [];
|
|
|
|
foreach ($entries as $entry) {
|
|
|
|
if ($entry[1] != 0 || $entry[2] != 0 || $entry[3] != 0) {
|
2015-06-28 08:33:23 +02:00
|
|
|
$data['labels'][] = $entry[0];
|
|
|
|
$left[] = round($entry[1], 2);
|
2015-12-27 21:26:44 +01:00
|
|
|
$spent[] = round($entry[2] * -1, 2); // spent is coming in negative, must be positive
|
|
|
|
$overspent[] = round($entry[3] * -1, 2); // same
|
2015-06-27 17:05:39 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$data['datasets'][] = [
|
2015-06-27 22:11:03 +02:00
|
|
|
'label' => trans('firefly.left'),
|
|
|
|
'data' => $left,
|
2015-06-27 17:05:39 +02:00
|
|
|
];
|
|
|
|
$data['datasets'][] = [
|
2015-06-27 22:11:03 +02:00
|
|
|
'label' => trans('firefly.spent'),
|
|
|
|
'data' => $spent,
|
|
|
|
];
|
|
|
|
$data['datasets'][] = [
|
|
|
|
'label' => trans('firefly.overspent'),
|
2015-10-17 21:15:16 +02:00
|
|
|
'data' => $overspent,
|
2015-06-27 17:05:39 +02:00
|
|
|
];
|
|
|
|
|
2015-06-27 22:11:03 +02:00
|
|
|
$data['count'] = count($data['datasets']);
|
|
|
|
|
2015-06-27 17:05:39 +02:00
|
|
|
return $data;
|
2015-06-27 16:01:06 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param Collection $budgets
|
|
|
|
* @param Collection $entries
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function year(Collection $budgets, Collection $entries)
|
|
|
|
{
|
2015-06-27 20:39:50 +02:00
|
|
|
// language:
|
2015-12-24 08:35:08 +01:00
|
|
|
$format = trans('config.month');
|
2015-06-27 20:39:50 +02:00
|
|
|
|
|
|
|
$data = [
|
|
|
|
'labels' => [],
|
|
|
|
'datasets' => [],
|
|
|
|
];
|
|
|
|
|
|
|
|
foreach ($budgets as $budget) {
|
|
|
|
$data['labels'][] = $budget->name;
|
|
|
|
}
|
|
|
|
/** @var array $entry */
|
|
|
|
foreach ($entries as $entry) {
|
|
|
|
$array = [
|
|
|
|
'label' => $entry[0]->formatLocalized($format),
|
2015-12-24 09:50:16 +01:00
|
|
|
'data' => [],
|
2015-06-27 20:39:50 +02:00
|
|
|
];
|
2015-12-24 09:50:16 +01:00
|
|
|
array_shift($entry);
|
|
|
|
$array['data'] = $entry;
|
2015-06-27 20:39:50 +02:00
|
|
|
$data['datasets'][] = $array;
|
|
|
|
|
|
|
|
}
|
2015-06-28 18:00:11 +02:00
|
|
|
$data['count'] = count($data['datasets']);
|
2015-06-27 20:39:50 +02:00
|
|
|
|
|
|
|
return $data;
|
2015-06-27 16:01:06 +02:00
|
|
|
}
|
2015-12-16 10:17:15 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param Collection $entries
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function multiYear(Collection $entries)
|
|
|
|
{
|
2015-12-16 10:54:56 +01:00
|
|
|
// dataset:
|
2015-12-16 10:17:15 +01:00
|
|
|
$data = [
|
|
|
|
'count' => 0,
|
|
|
|
'labels' => [],
|
|
|
|
'datasets' => [],
|
|
|
|
];
|
2015-12-16 10:54:56 +01:00
|
|
|
// get labels from one of the budgets (assuming there's at least one):
|
|
|
|
$first = $entries->first();
|
|
|
|
foreach ($first['budgeted'] as $year => $noInterest) {
|
|
|
|
$data['labels'][] = strval($year);
|
2015-12-16 10:17:15 +01:00
|
|
|
}
|
2015-12-16 10:54:56 +01:00
|
|
|
|
|
|
|
// then, loop all entries and create datasets:
|
|
|
|
foreach ($entries as $entry) {
|
|
|
|
$name = $entry['name'];
|
|
|
|
$spent = $entry['spent'];
|
|
|
|
$budgeted = $entry['budgeted'];
|
2015-12-16 12:13:01 +01:00
|
|
|
$data['datasets'][] = ['label' => 'Spent on ' . $name, 'data' => array_values($spent)];
|
|
|
|
$data['datasets'][] = ['label' => 'Budgeted for ' . $name, 'data' => array_values($budgeted)];
|
2015-12-16 10:17:15 +01:00
|
|
|
}
|
|
|
|
$data['count'] = count($data['datasets']);
|
|
|
|
|
2015-12-16 10:54:56 +01:00
|
|
|
return $data;
|
2015-12-16 10:17:15 +01:00
|
|
|
|
|
|
|
}
|
2015-06-28 08:24:12 +02:00
|
|
|
}
|