| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | namespace FireflyIII\Http\Controllers\Chart; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							|  |  |  | 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; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											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
										 |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |     /** @var  \FireflyIII\Generator\Chart\Report\ReportChartGenerator */ | 
					
						
							|  |  |  |     protected $generator; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-06-28 10:03:34 +02:00
										 |  |  |      * @codeCoverageIgnore | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  |         // create chart generator:
 | 
					
						
							| 
									
										
										
										
											2015-07-07 19:09:45 +02:00
										 |  |  |         $this->generator = app('FireflyIII\Generator\Chart\Report\ReportChartGenerator'); | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-12-12 19:04:30 +01:00
										 |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-12-28 20:04:54 +01:00
										 |  |  |     public function yearInOut(ReportQueryInterface $query, $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); | 
					
						
							| 
									
										
										
										
											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()) { | 
					
						
							| 
									
										
										
										
											2015-06-27 22:22:27 +02:00
										 |  |  |             return Response::json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-14 21:11:57 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // per year?
 | 
					
						
							|  |  |  |         if ($start->diffInMonths($end) > 12) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $entries = new Collection; | 
					
						
							|  |  |  |             while ($start < $end) { | 
					
						
							|  |  |  |                 $startOfYear = clone $start; | 
					
						
							|  |  |  |                 $startOfYear->startOfYear(); | 
					
						
							|  |  |  |                 $endOfYear = clone $startOfYear; | 
					
						
							|  |  |  |                 $endOfYear->endOfYear(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 // total income and total expenses:
 | 
					
						
							|  |  |  |                 $incomeSum  = $query->incomeInPeriod($startOfYear, $endOfYear, $accounts)->sum('amount_positive'); | 
					
						
							|  |  |  |                 $expenseSum = $query->expenseInPeriod($startOfYear, $endOfYear, $accounts)->sum('amount_positive'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 $entries->push([clone $start, $incomeSum, $expenseSum]); | 
					
						
							|  |  |  |                 $start->addYear(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $data = $this->generator->multiYearInOut($entries); | 
					
						
							|  |  |  |             $cache->store($data); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             // per month:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $entries = new Collection; | 
					
						
							|  |  |  |             while ($start < $end) { | 
					
						
							|  |  |  |                 $month = clone $start; | 
					
						
							|  |  |  |                 $month->endOfMonth(); | 
					
						
							|  |  |  |                 // total income and total expenses:
 | 
					
						
							|  |  |  |                 $incomeSum  = $query->incomeInPeriod($start, $month, $accounts)->sum('amount_positive'); | 
					
						
							|  |  |  |                 $expenseSum = $query->expenseInPeriod($start, $month, $accounts)->sum('amount_positive'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 $entries->push([clone $start, $incomeSum, $expenseSum]); | 
					
						
							|  |  |  |                 $start->addMonth(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $data = $this->generator->yearInOut($entries); | 
					
						
							|  |  |  |             $cache->store($data); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-12-28 20:04:54 +01:00
										 |  |  |     public function yearInOutSummarized(ReportQueryInterface $query, $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); | 
					
						
							|  |  |  |         $cache->addProperty($accounts); | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2015-06-27 22:22:27 +02:00
										 |  |  |             return Response::json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $income  = '0'; | 
					
						
							|  |  |  |         $expense = '0'; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |         $count   = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         bcscale(2); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-14 21:11:57 +01:00
										 |  |  |         if ($start->diffInMonths($end) > 12) { | 
					
						
							|  |  |  |             // per year
 | 
					
						
							|  |  |  |             while ($start < $end) { | 
					
						
							|  |  |  |                 $startOfYear = clone $start; | 
					
						
							|  |  |  |                 $startOfYear->startOfYear(); | 
					
						
							|  |  |  |                 $endOfYear = clone $startOfYear; | 
					
						
							|  |  |  |                 $endOfYear->endOfYear(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 // total income and total expenses:
 | 
					
						
							|  |  |  |                 $currentIncome  = $query->incomeInPeriod($startOfYear, $endOfYear, $accounts)->sum('amount_positive'); | 
					
						
							|  |  |  |                 $currentExpense = $query->expenseInPeriod($startOfYear, $endOfYear, $accounts)->sum('amount_positive'); | 
					
						
							|  |  |  |                 $income         = bcadd($income, $currentIncome); | 
					
						
							|  |  |  |                 $expense        = bcadd($expense, $currentExpense); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 $count++; | 
					
						
							|  |  |  |                 $start->addYear(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $data = $this->generator->multiYearInOutSummarized($income, $expense, $count); | 
					
						
							|  |  |  |             $cache->store($data); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             // per month!
 | 
					
						
							|  |  |  |             while ($start < $end) { | 
					
						
							|  |  |  |                 $month = clone $start; | 
					
						
							|  |  |  |                 $month->endOfMonth(); | 
					
						
							|  |  |  |                 // total income and total expenses:
 | 
					
						
							|  |  |  |                 $currentIncome  = $query->incomeInPeriod($start, $month, $accounts)->sum('amount_positive'); | 
					
						
							|  |  |  |                 $currentExpense = $query->expenseInPeriod($start, $month, $accounts)->sum('amount_positive'); | 
					
						
							|  |  |  |                 $income         = bcadd($income, $currentIncome); | 
					
						
							|  |  |  |                 $expense        = bcadd($expense, $currentExpense); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 $count++; | 
					
						
							|  |  |  |                 $start->addMonth(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $data = $this->generator->yearInOutSummarized($income, $expense, $count); | 
					
						
							|  |  |  |             $cache->store($data); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         return Response::json($data); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-05-20 19:56:14 +02:00
										 |  |  | } |