| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * ReportController.php | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * Copyright (c) 2017 thegrumpydictator@gmail.com | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * This file is part of Firefly III. | 
					
						
							| 
									
										
										
										
											2016-10-05 06:52:15 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * Firefly III is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with Firefly III.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-04-09 07:44:22 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | namespace FireflyIII\Http\Controllers\Chart; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  | use FireflyIII\Generator\Chart\Basic\GeneratorInterface; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | use FireflyIII\Http\Controllers\Controller; | 
					
						
							| 
									
										
										
										
											2017-04-17 08:31:42 +02:00
										 |  |  | use FireflyIII\Repositories\Account\AccountTaskerInterface; | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  | use FireflyIII\Support\CacheProperties; | 
					
						
							|  |  |  | use Illuminate\Support\Collection; | 
					
						
							| 
									
										
										
										
											2017-04-16 22:15:05 +02:00
										 |  |  | use Log; | 
					
						
							| 
									
										
										
										
											2016-05-14 14:02:12 +02:00
										 |  |  | use Navigation; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | use Response; | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  | use Steam; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |  * Class ReportController. | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | class ReportController extends Controller | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |     /** @var GeneratorInterface */ | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |     protected $generator; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-02-04 07:28:39 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  |         // create chart generator:
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $this->generator = app(GeneratorInterface::class); | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * This chart, by default, is shown on the multi-year and year report pages, | 
					
						
							|  |  |  |      * which means that giving it a 2 week "period" should be enough granularity. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-02-18 10:12:07 +01:00
										 |  |  |      * @param Collection $accounts | 
					
						
							| 
									
										
										
										
											2016-12-14 18:59:12 +01:00
										 |  |  |      * @param Carbon     $start | 
					
						
							| 
									
										
										
										
											2016-12-06 08:15:53 +01:00
										 |  |  |      * @param Carbon     $end | 
					
						
							| 
									
										
										
										
											2016-12-14 18:59:12 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-06 08:15:53 +01:00
										 |  |  |     public function netWorth(Collection $accounts, Carbon $start, Carbon $end) | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         // chart properties for cache:
 | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $cache->addProperty('chart.report.net-worth'); | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($accounts); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2017-03-04 11:19:44 +01:00
										 |  |  |             return Response::json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $current   = clone $start; | 
					
						
							|  |  |  |         $chartData = []; | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  |         while ($current < $end) { | 
					
						
							| 
									
										
										
										
											2017-06-05 22:11:54 +02:00
										 |  |  |             $balances          = Steam::balancesByAccounts($accounts, $current); | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |             $sum               = $this->arraySum($balances); | 
					
						
							|  |  |  |             $label             = $current->formatLocalized(strval(trans('config.month_and_day'))); | 
					
						
							|  |  |  |             $chartData[$label] = $sum; | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  |             $current->addDays(7); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $data = $this->generator->singleSet(strval(trans('firefly.net_worth')), $chartData); | 
					
						
							| 
									
										
										
										
											2016-02-18 10:12:07 +01:00
										 |  |  |         $cache->store($data); | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return Response::json($data); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |      * Shows income and expense, debet/credit: operations. | 
					
						
							| 
									
										
										
										
											2016-12-06 08:15:53 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @param Collection $accounts | 
					
						
							| 
									
										
										
										
											2016-11-12 19:22:03 +01:00
										 |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							| 
									
										
										
										
											2016-12-06 08:15:53 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-12-12 19:04:30 +01:00
										 |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-06 08:15:53 +01:00
										 |  |  |     public function operations(Collection $accounts, Carbon $start, Carbon $end) | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         // chart properties for cache:
 | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $cache->addProperty('chart.report.operations'); | 
					
						
							| 
									
										
										
										
											2015-12-12 19:04:30 +01:00
										 |  |  |         $cache->addProperty($start); | 
					
						
							| 
									
										
										
										
											2015-12-12 21:20:20 +01:00
										 |  |  |         $cache->addProperty($accounts); | 
					
						
							| 
									
										
										
										
											2015-12-12 19:04:30 +01:00
										 |  |  |         $cache->addProperty($end); | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2017-06-05 11:12:50 +02:00
										 |  |  |             return Response::json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-04-16 22:15:05 +02:00
										 |  |  |         Log::debug('Going to do operations for accounts ', $accounts->pluck('id')->toArray()); | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $format    = Navigation::preferredCarbonLocalizedFormat($start, $end); | 
					
						
							|  |  |  |         $source    = $this->getChartData($accounts, $start, $end); | 
					
						
							|  |  |  |         $chartData = [ | 
					
						
							|  |  |  |             [ | 
					
						
							|  |  |  |                 'label'   => trans('firefly.income'), | 
					
						
							|  |  |  |                 'type'    => 'bar', | 
					
						
							|  |  |  |                 'entries' => [], | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             [ | 
					
						
							|  |  |  |                 'label'   => trans('firefly.expenses'), | 
					
						
							|  |  |  |                 'type'    => 'bar', | 
					
						
							|  |  |  |                 'entries' => [], | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         foreach ($source['earned'] as $date => $amount) { | 
					
						
							|  |  |  |             $carbon                          = new Carbon($date); | 
					
						
							|  |  |  |             $label                           = $carbon->formatLocalized($format); | 
					
						
							|  |  |  |             $earned                          = $chartData[0]['entries'][$label] ?? '0'; | 
					
						
							|  |  |  |             $chartData[0]['entries'][$label] = bcadd($earned, $amount); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         foreach ($source['spent'] as $date => $amount) { | 
					
						
							|  |  |  |             $carbon                          = new Carbon($date); | 
					
						
							|  |  |  |             $label                           = $carbon->formatLocalized($format); | 
					
						
							|  |  |  |             $spent                           = $chartData[1]['entries'][$label] ?? '0'; | 
					
						
							|  |  |  |             $chartData[1]['entries'][$label] = bcadd($spent, $amount); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $data = $this->generator->multiSet($chartData); | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |         $cache->store($data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         return Response::json($data); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |      * Shows sum income and expense, debet/credit: operations. | 
					
						
							| 
									
										
										
										
											2016-12-14 18:59:12 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-11-20 11:43:19 +01:00
										 |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							|  |  |  |      * @param Collection $accounts | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-12-12 19:04:30 +01:00
										 |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-06 08:15:53 +01:00
										 |  |  |     public function sum(Collection $accounts, Carbon $start, Carbon $end) | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         // chart properties for cache:
 | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $cache->addProperty('chart.report.sum'); | 
					
						
							| 
									
										
										
										
											2015-12-12 19:04:30 +01:00
										 |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							|  |  |  |         $cache->addProperty($accounts); | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2017-03-04 11:19:44 +01:00
										 |  |  |             return Response::json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-04-17 08:31:42 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $source  = $this->getChartData($accounts, $start, $end); | 
					
						
							|  |  |  |         $numbers = [ | 
					
						
							|  |  |  |             'sum_earned'   => '0', | 
					
						
							|  |  |  |             'avg_earned'   => '0', | 
					
						
							|  |  |  |             'count_earned' => 0, | 
					
						
							|  |  |  |             'sum_spent'    => '0', | 
					
						
							|  |  |  |             'avg_spent'    => '0', | 
					
						
							|  |  |  |             'count_spent'  => 0, | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         foreach ($source['earned'] as $amount) { | 
					
						
							|  |  |  |             $numbers['sum_earned'] = bcadd($amount, $numbers['sum_earned']); | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |             ++$numbers['count_earned']; | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         if ($numbers['count_earned'] > 0) { | 
					
						
							|  |  |  |             $numbers['avg_earned'] = $numbers['sum_earned'] / $numbers['count_earned']; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         foreach ($source['spent'] as $amount) { | 
					
						
							|  |  |  |             $numbers['sum_spent'] = bcadd($amount, $numbers['sum_spent']); | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |             ++$numbers['count_spent']; | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         if ($numbers['count_spent'] > 0) { | 
					
						
							|  |  |  |             $numbers['avg_spent'] = $numbers['sum_spent'] / $numbers['count_spent']; | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $chartData = [ | 
					
						
							|  |  |  |             [ | 
					
						
							|  |  |  |                 'label'   => strval(trans('firefly.income')), | 
					
						
							|  |  |  |                 'type'    => 'bar', | 
					
						
							|  |  |  |                 'entries' => [ | 
					
						
							|  |  |  |                     strval(trans('firefly.sum_of_period'))     => $numbers['sum_earned'], | 
					
						
							|  |  |  |                     strval(trans('firefly.average_in_period')) => $numbers['avg_earned'], | 
					
						
							|  |  |  |                 ], | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             [ | 
					
						
							|  |  |  |                 'label'   => trans('firefly.expenses'), | 
					
						
							|  |  |  |                 'type'    => 'bar', | 
					
						
							|  |  |  |                 'entries' => [ | 
					
						
							|  |  |  |                     strval(trans('firefly.sum_of_period'))     => $numbers['sum_spent'], | 
					
						
							|  |  |  |                     strval(trans('firefly.average_in_period')) => $numbers['avg_spent'], | 
					
						
							|  |  |  |                 ], | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2015-12-31 08:26:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $data = $this->generator->multiSet($chartData); | 
					
						
							|  |  |  |         $cache->store($data); | 
					
						
							| 
									
										
										
										
											2015-12-31 08:26:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         return Response::json($data); | 
					
						
							| 
									
										
										
										
											2015-12-31 08:26:04 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param $array | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-14 18:59:12 +01:00
										 |  |  |     private function arraySum($array): string | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         $sum = '0'; | 
					
						
							|  |  |  |         foreach ($array as $entry) { | 
					
						
							|  |  |  |             $sum = bcadd($sum, $entry); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $sum; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-12 19:22:03 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |      * Collects the incomes and expenses for the given periods, grouped per month. Will cache its results. | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-11-12 19:22:03 +01:00
										 |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |     private function getChartData(Collection $accounts, Carbon $start, Carbon $end): array | 
					
						
							| 
									
										
										
										
											2016-11-12 19:22:03 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty('chart.report.get-chart-data'); | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($accounts); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2017-06-05 11:12:50 +02:00
										 |  |  |             return $cache->get(); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-12 19:22:03 +01:00
										 |  |  |         $currentStart = clone $start; | 
					
						
							|  |  |  |         $spentArray   = []; | 
					
						
							|  |  |  |         $earnedArray  = []; | 
					
						
							| 
									
										
										
										
											2017-04-17 08:31:42 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         /** @var AccountTaskerInterface $tasker */ | 
					
						
							|  |  |  |         $tasker = app(AccountTaskerInterface::class); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-12 19:22:03 +01:00
										 |  |  |         while ($currentStart <= $end) { | 
					
						
							| 
									
										
										
										
											2017-04-16 22:15:05 +02:00
										 |  |  |             $currentEnd = Navigation::endOfPeriod($currentStart, '1M'); | 
					
						
							| 
									
										
										
										
											2017-04-17 08:31:42 +02:00
										 |  |  |             $earned     = strval( | 
					
						
							|  |  |  |                 array_sum( | 
					
						
							|  |  |  |                     array_map( | 
					
						
							|  |  |  |                         function ($item) { | 
					
						
							|  |  |  |                             return $item['sum']; | 
					
						
							| 
									
										
										
										
											2017-11-15 10:52:29 +01:00
										 |  |  |                         }, | 
					
						
							|  |  |  |                         $tasker->getIncomeReport($currentStart, $currentEnd, $accounts) | 
					
						
							| 
									
										
										
										
											2017-04-17 08:31:42 +02:00
										 |  |  |                     ) | 
					
						
							|  |  |  |                 ) | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $spent = strval( | 
					
						
							|  |  |  |                 array_sum( | 
					
						
							|  |  |  |                     array_map( | 
					
						
							|  |  |  |                         function ($item) { | 
					
						
							|  |  |  |                             return $item['sum']; | 
					
						
							| 
									
										
										
										
											2017-11-15 10:52:29 +01:00
										 |  |  |                         }, | 
					
						
							|  |  |  |                         $tasker->getExpenseReport($currentStart, $currentEnd, $accounts) | 
					
						
							| 
									
										
										
										
											2017-04-17 08:31:42 +02:00
										 |  |  |                     ) | 
					
						
							|  |  |  |                 ) | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2017-04-16 22:15:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |             $label               = $currentStart->format('Y-m') . '-01'; | 
					
						
							|  |  |  |             $spentArray[$label]  = bcmul($spent, '-1'); | 
					
						
							|  |  |  |             $earnedArray[$label] = $earned; | 
					
						
							|  |  |  |             $currentStart        = Navigation::addPeriod($currentStart, '1M', 0); | 
					
						
							| 
									
										
										
										
											2016-11-12 19:22:03 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $result = [ | 
					
						
							| 
									
										
										
										
											2016-11-12 19:22:03 +01:00
										 |  |  |             'spent'  => $spentArray, | 
					
						
							|  |  |  |             'earned' => $earnedArray, | 
					
						
							|  |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2016-12-15 14:38:05 +01:00
										 |  |  |         $cache->store($result); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $result; | 
					
						
							| 
									
										
										
										
											2016-11-12 19:22:03 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-05-20 19:56:14 +02:00
										 |  |  | } |