| 
									
										
										
										
											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-05-16 09:09:52 +02:00
										 |  |  | use Grumpydictator\Gchart\GChart; | 
					
						
							|  |  |  | 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
										 |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Summarizes all income and expenses, per month, for a given year. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param GChart               $chart | 
					
						
							|  |  |  |      * @param ReportQueryInterface $query | 
					
						
							|  |  |  |      * @param                      $year | 
					
						
							|  |  |  |      * @param bool                 $shared | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Symfony\Component\HttpFoundation\Response | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function yearInOut(GChart $chart, ReportQueryInterface $query, $year, $shared = false) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // get start and end of year
 | 
					
						
							|  |  |  |         $start  = new Carbon($year . '-01-01'); | 
					
						
							|  |  |  |         $end    = new Carbon($year . '-12-31'); | 
					
						
							|  |  |  |         $shared = $shared == 'shared' ? true : false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $chart->addColumn(trans('firefly.month'), 'date'); | 
					
						
							|  |  |  |         $chart->addColumn(trans('firefly.income'), 'number'); | 
					
						
							|  |  |  |         $chart->addColumn(trans('firefly.expenses'), 'number'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         while ($start < $end) { | 
					
						
							|  |  |  |             $month = clone $start; | 
					
						
							|  |  |  |             $month->endOfMonth(); | 
					
						
							|  |  |  |             // total income and total expenses:
 | 
					
						
							| 
									
										
										
										
											2015-05-20 06:49:22 +02:00
										 |  |  |             $incomeSum  = floatval($query->incomeInPeriodCorrected($start, $month, $shared)->sum('amount')); | 
					
						
							|  |  |  |             $expenseSum = floatval($query->expenseInPeriodCorrected($start, $month, $shared)->sum('amount')); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             $chart->addRow(clone $start, $incomeSum, $expenseSum); | 
					
						
							|  |  |  |             $start->addMonth(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $chart->generate(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Response::json($chart->getData()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Summarizes all income and expenses for a given year. Gives a total and an average. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param GChart               $chart | 
					
						
							|  |  |  |      * @param ReportQueryInterface $query | 
					
						
							|  |  |  |      * @param                      $year | 
					
						
							|  |  |  |      * @param bool                 $shared | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Symfony\Component\HttpFoundation\Response | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function yearInOutSummarized(GChart $chart, ReportQueryInterface $query, $year, $shared = false) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $start   = new Carbon($year . '-01-01'); | 
					
						
							|  |  |  |         $end     = new Carbon($year . '-12-31'); | 
					
						
							|  |  |  |         $shared  = $shared == 'shared' ? true : false; | 
					
						
							|  |  |  |         $income  = 0; | 
					
						
							|  |  |  |         $expense = 0; | 
					
						
							|  |  |  |         $count   = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $chart->addColumn(trans('firefly.summary'), 'string'); | 
					
						
							|  |  |  |         $chart->addColumn(trans('firefly.income'), 'number'); | 
					
						
							|  |  |  |         $chart->addColumn(trans('firefly.expenses'), 'number'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         while ($start < $end) { | 
					
						
							|  |  |  |             $month = clone $start; | 
					
						
							|  |  |  |             $month->endOfMonth(); | 
					
						
							|  |  |  |             // total income and total expenses:
 | 
					
						
							| 
									
										
										
										
											2015-05-20 06:49:22 +02:00
										 |  |  |             $income += floatval($query->incomeInPeriodCorrected($start, $month, $shared)->sum('amount')); | 
					
						
							|  |  |  |             $expense += floatval($query->expenseInPeriodCorrected($start, $month, $shared)->sum('amount')); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:09:52 +02:00
										 |  |  |             $count++; | 
					
						
							|  |  |  |             $start->addMonth(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // add total + average:
 | 
					
						
							|  |  |  |         $chart->addRow(trans('firefly.sum'), $income, $expense); | 
					
						
							|  |  |  |         $count = $count > 0 ? $count : 1; | 
					
						
							|  |  |  |         $chart->addRow(trans('firefly.average'), ($income / $count), ($expense / $count)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $chart->generate(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Response::json($chart->getData()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-05-20 19:56:14 +02:00
										 |  |  | } |