| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-02-05 12:08:25 +01: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-05-02 20:49:19 +02:00
										 |  |  | use FireflyIII\Generator\Chart\Report\ReportChartGeneratorInterface; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | use FireflyIII\Helpers\Report\ReportQueryInterface; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | use FireflyIII\Http\Controllers\Controller; | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  | use FireflyIII\Support\CacheProperties; | 
					
						
							|  |  |  | use Illuminate\Support\Collection; | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |  * Class ReportController | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |  * @package FireflyIII\Http\Controllers\Chart | 
					
						
							| 
									
										
										
										
											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-05-02 20:49:19 +02:00
										 |  |  |     /** @var ReportChartGeneratorInterface */ | 
					
						
							| 
									
										
										
										
											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-05-02 20:49:19 +02:00
										 |  |  |         $this->generator = app(ReportChartGeneratorInterface::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 string     $reportType | 
					
						
							|  |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							|  |  |  |      * @param Collection $accounts | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-18 10:12:07 +01:00
										 |  |  |     public function netWorth(string $reportType, Carbon $start, Carbon $end, Collection $accounts) | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         // chart properties for cache:
 | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty('netWorth'); | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($reportType); | 
					
						
							|  |  |  |         $cache->addProperty($accounts); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2016-04-06 09:27:45 +02:00
										 |  |  |             return Response::json($cache->get()); | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  |         } | 
					
						
							|  |  |  |         $ids     = $accounts->pluck('id')->toArray(); | 
					
						
							|  |  |  |         $current = clone $start; | 
					
						
							|  |  |  |         $entries = new Collection; | 
					
						
							|  |  |  |         while ($current < $end) { | 
					
						
							|  |  |  |             $balances = Steam::balancesById($ids, $current); | 
					
						
							| 
									
										
										
										
											2016-03-14 20:52:08 +01:00
										 |  |  |             $sum      = $this->arraySum($balances); | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  |             $entries->push( | 
					
						
							|  |  |  |                 [ | 
					
						
							|  |  |  |                     'date'      => clone $current, | 
					
						
							|  |  |  |                     'net-worth' => $sum, | 
					
						
							|  |  |  |                 ] | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $current->addDays(7); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $data = $this->generator->netWorth($entries); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Summarizes all income and expenses, per month, for a given year. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param ReportQueryInterface $query | 
					
						
							| 
									
										
										
										
											2015-12-28 20:04:54 +01:00
										 |  |  |      * @param                      $reportType | 
					
						
							| 
									
										
										
										
											2015-12-12 19:04:30 +01:00
										 |  |  |      * @param Carbon               $start | 
					
						
							|  |  |  |      * @param Carbon               $end | 
					
						
							|  |  |  |      * @param Collection           $accounts | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-15 18:21:59 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-12-12 19:04:30 +01:00
										 |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-05 09:25:15 +01:00
										 |  |  |     public function yearInOut(ReportQueryInterface $query, string $reportType, Carbon $start, Carbon $end, Collection $accounts) | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         // chart properties for cache:
 | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty('yearInOut'); | 
					
						
							| 
									
										
										
										
											2015-12-12 19:04:30 +01:00
										 |  |  |         $cache->addProperty($start); | 
					
						
							| 
									
										
										
										
											2016-01-01 21:49:27 +01:00
										 |  |  |         $cache->addProperty($reportType); | 
					
						
							| 
									
										
										
										
											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()) { | 
					
						
							| 
									
										
										
										
											2016-04-06 09:27:45 +02:00
										 |  |  |             return Response::json($cache->get()); | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-31 08:26:04 +01:00
										 |  |  |         // spent per month, and earned per month. For a specific set of accounts
 | 
					
						
							|  |  |  |         // grouped by month
 | 
					
						
							|  |  |  |         $spentArray  = $query->spentPerMonth($accounts, $start, $end); | 
					
						
							|  |  |  |         $earnedArray = $query->earnedPerMonth($accounts, $start, $end); | 
					
						
							| 
									
										
										
										
											2015-12-14 21:11:57 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if ($start->diffInMonths($end) > 12) { | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |             // data = method X
 | 
					
						
							|  |  |  |             $data = $this->multiYearInOut($earnedArray, $spentArray, $start, $end); | 
					
						
							| 
									
										
										
										
											2015-12-14 21:11:57 +01:00
										 |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |             // data = method Y
 | 
					
						
							|  |  |  |             $data = $this->singleYearInOut($earnedArray, $spentArray, $start, $end); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Summarizes all income and expenses for a given year. Gives a total and an average. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param ReportQueryInterface $query | 
					
						
							| 
									
										
										
										
											2015-12-28 20:04:54 +01:00
										 |  |  |      * @param                      $reportType | 
					
						
							| 
									
										
										
										
											2015-12-12 19:04:30 +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-02-05 09:25:15 +01:00
										 |  |  |     public function yearInOutSummarized(ReportQueryInterface $query, string $reportType, Carbon $start, Carbon $end, Collection $accounts) | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // chart properties for cache:
 | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty('yearInOutSummarized'); | 
					
						
							| 
									
										
										
										
											2015-12-12 19:04:30 +01:00
										 |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							| 
									
										
										
										
											2016-01-01 21:49:27 +01:00
										 |  |  |         $cache->addProperty($reportType); | 
					
						
							| 
									
										
										
										
											2015-12-12 19:04:30 +01:00
										 |  |  |         $cache->addProperty($accounts); | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2016-04-06 09:27:45 +02:00
										 |  |  |             return Response::json($cache->get()); | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-12-31 08:36:01 +01:00
										 |  |  |         // spent per month, and earned per month. For a specific set of accounts
 | 
					
						
							|  |  |  |         // grouped by month
 | 
					
						
							|  |  |  |         $spentArray  = $query->spentPerMonth($accounts, $start, $end); | 
					
						
							|  |  |  |         $earnedArray = $query->earnedPerMonth($accounts, $start, $end); | 
					
						
							| 
									
										
										
										
											2015-12-14 21:11:57 +01:00
										 |  |  |         if ($start->diffInMonths($end) > 12) { | 
					
						
							|  |  |  |             // per year
 | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |             $data = $this->multiYearInOutSummarized($earnedArray, $spentArray, $start, $end); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             // per month!
 | 
					
						
							|  |  |  |             $data = $this->singleYearInOutSummarized($earnedArray, $spentArray, $start, $end); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $cache->store($data); | 
					
						
							| 
									
										
										
										
											2015-12-14 21:11:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |         return Response::json($data); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-12-14 21:11:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param array  $earned | 
					
						
							|  |  |  |      * @param array  $spent | 
					
						
							|  |  |  |      * @param Carbon $start | 
					
						
							|  |  |  |      * @param Carbon $end | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |     protected function multiYearInOut(array $earned, array $spent, Carbon $start, Carbon $end) | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |         $entries = new Collection; | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |         while ($start < $end) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |             $incomeSum  = $this->pluckFromArray($start->year, $earned); | 
					
						
							|  |  |  |             $expenseSum = $this->pluckFromArray($start->year, $spent) * -1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $entries->push([clone $start, $incomeSum, $expenseSum]); | 
					
						
							|  |  |  |             $start->addYear(); | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-12-14 21:11:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |         $data = $this->generator->multiYearInOut($entries); | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return $data; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-12-14 21:11:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param array  $earned | 
					
						
							|  |  |  |      * @param array  $spent | 
					
						
							|  |  |  |      * @param Carbon $start | 
					
						
							|  |  |  |      * @param Carbon $end | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function multiYearInOutSummarized(array $earned, array $spent, Carbon $start, Carbon $end) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $income  = '0'; | 
					
						
							|  |  |  |         $expense = '0'; | 
					
						
							|  |  |  |         $count   = 0; | 
					
						
							|  |  |  |         while ($start < $end) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $currentIncome  = $this->pluckFromArray($start->year, $earned); | 
					
						
							| 
									
										
										
										
											2016-02-08 21:07:11 +01:00
										 |  |  |             $currentExpense = bcmul($this->pluckFromArray($start->year, $spent), '-1'); | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |             $income         = bcadd($income, $currentIncome); | 
					
						
							|  |  |  |             $expense        = bcadd($expense, $currentExpense); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $count++; | 
					
						
							|  |  |  |             $start->addYear(); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |         $data = $this->generator->multiYearInOutSummarized($income, $expense, $count); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |         return $data; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |      * @param int   $year | 
					
						
							|  |  |  |      * @param array $set | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |      * @return string | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |     protected function pluckFromArray($year, array $set) | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |         $sum = '0'; | 
					
						
							|  |  |  |         foreach ($set as $date => $amount) { | 
					
						
							|  |  |  |             if (substr($date, 0, 4) == $year) { | 
					
						
							|  |  |  |                 $sum = bcadd($sum, $amount); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |         return $sum; | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param array  $earned | 
					
						
							|  |  |  |      * @param array  $spent | 
					
						
							|  |  |  |      * @param Carbon $start | 
					
						
							|  |  |  |      * @param Carbon $end | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function singleYearInOut(array $earned, array $spent, Carbon $start, Carbon $end) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // per month? simply use each month.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $entries = new Collection; | 
					
						
							|  |  |  |         while ($start < $end) { | 
					
						
							|  |  |  |             // total income and total expenses:
 | 
					
						
							|  |  |  |             $date       = $start->format('Y-m'); | 
					
						
							| 
									
										
										
										
											2016-02-05 08:03:26 +01:00
										 |  |  |             $incomeSum  = $earned[$date] ?? 0; | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |             $expenseSum = isset($spent[$date]) ? ($spent[$date] * -1) : 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $entries->push([clone $start, $incomeSum, $expenseSum]); | 
					
						
							|  |  |  |             $start->addMonth(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $data = $this->generator->yearInOut($entries); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-02 16:57:31 +01:00
										 |  |  |         return $data; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-12-31 08:26:04 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |      * @param array  $earned | 
					
						
							|  |  |  |      * @param array  $spent | 
					
						
							|  |  |  |      * @param Carbon $start | 
					
						
							|  |  |  |      * @param Carbon $end | 
					
						
							| 
									
										
										
										
											2015-12-31 08:26:04 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |      * @return array | 
					
						
							| 
									
										
										
										
											2015-12-31 08:26:04 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |     protected function singleYearInOutSummarized(array $earned, array $spent, Carbon $start, Carbon $end) | 
					
						
							| 
									
										
										
										
											2015-12-31 08:26:04 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |         $income  = '0'; | 
					
						
							|  |  |  |         $expense = '0'; | 
					
						
							|  |  |  |         $count   = 0; | 
					
						
							|  |  |  |         while ($start < $end) { | 
					
						
							|  |  |  |             $date           = $start->format('Y-m'); | 
					
						
							|  |  |  |             $currentIncome  = $earned[$date] ?? '0'; | 
					
						
							|  |  |  |             $currentExpense = isset($spent[$date]) ? bcmul($spent[$date], '-1') : '0'; | 
					
						
							|  |  |  |             $income         = bcadd($income, $currentIncome); | 
					
						
							|  |  |  |             $expense        = bcadd($expense, $currentExpense); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $count++; | 
					
						
							|  |  |  |             $start->addMonth(); | 
					
						
							| 
									
										
										
										
											2015-12-31 08:26:04 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |         $data = $this->generator->yearInOutSummarized($income, $expense, $count); | 
					
						
							| 
									
										
										
										
											2015-12-31 08:26:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-05 12:28:05 +01:00
										 |  |  |         return $data; | 
					
						
							| 
									
										
										
										
											2015-12-31 08:26:04 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-18 10:04:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param $array | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-03-14 20:52:08 +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; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-05-20 19:56:14 +02:00
										 |  |  | } |