| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | <?php namespace FireflyIII\Http\Controllers; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Auth; | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							|  |  |  | use Exception; | 
					
						
							|  |  |  | use FireflyIII\Helpers\Report\ReportHelperInterface; | 
					
						
							|  |  |  | use FireflyIII\Helpers\Report\ReportQueryInterface; | 
					
						
							|  |  |  | use FireflyIII\Http\Requests; | 
					
						
							|  |  |  | use FireflyIII\Models\Account; | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  | use FireflyIII\Models\TransactionJournal; | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | use Illuminate\Database\Query\JoinClause; | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  | use Preferences; | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  | use Session; | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | use Steam; | 
					
						
							|  |  |  | use View; | 
					
						
							| 
									
										
										
										
											2015-03-27 19:34:37 +01:00
										 |  |  | use FireflyIII\Models\Preference; | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Class ReportController | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package FireflyIII\Http\Controllers | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class ReportController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         View::share('title', 'Reports'); | 
					
						
							|  |  |  |         View::share('mainTitleIcon', 'fa-line-chart'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param string $year | 
					
						
							|  |  |  |      * @param string $month | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\View\View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function budget($year = '2014', $month = '1', ReportQueryInterface $query) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |             new Carbon($year . '-' . $month . '-01'); | 
					
						
							|  |  |  |         } catch (Exception $e) { | 
					
						
							|  |  |  |             return view('error')->with('message', 'Invalid date'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $date  = new Carbon($year . '-' . $month . '-01'); | 
					
						
							|  |  |  |         $start = clone $date; | 
					
						
							|  |  |  |         $start->startOfMonth(); | 
					
						
							|  |  |  |         $end = clone $date; | 
					
						
							|  |  |  |         $end->endOfMonth(); | 
					
						
							| 
									
										
										
										
											2015-02-27 12:55:24 +01:00
										 |  |  |         $start->subDay(); | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |         // shared accounts preference:
 | 
					
						
							|  |  |  |         $pref              = Preferences::get('showSharedReports', false); | 
					
						
							|  |  |  |         $showSharedReports = $pref->data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  |         $dayEarly     = clone $date; | 
					
						
							|  |  |  |         $subTitle     = 'Budget report for ' . $date->format('F Y'); | 
					
						
							|  |  |  |         $subTitleIcon = 'fa-calendar'; | 
					
						
							|  |  |  |         $dayEarly     = $dayEarly->subDay(); | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |         $accounts     = $query->getAllAccounts($start, $end, $showSharedReports); | 
					
						
							| 
									
										
										
										
											2015-02-27 12:55:24 +01:00
										 |  |  |         $start->addDay(); | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $accounts->each( | 
					
						
							|  |  |  |             function (Account $account) use ($start, $end, $query) { | 
					
						
							|  |  |  |                 $budgets        = $query->getBudgetSummary($account, $start, $end); | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  |                 $balancedAmount = $query->balancedTransactionsSum($account, $start, $end); | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  |                 $array          = []; | 
					
						
							| 
									
										
										
										
											2015-03-27 13:36:33 +01:00
										 |  |  |                 $hide           = true; | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  |                 foreach ($budgets as $budget) { | 
					
						
							|  |  |  |                     $id         = intval($budget->id); | 
					
						
							|  |  |  |                     $data       = $budget->toArray(); | 
					
						
							|  |  |  |                     $array[$id] = $data; | 
					
						
							| 
									
										
										
										
											2015-03-27 13:36:33 +01:00
										 |  |  |                     if (floatval($data['amount']) != 0) { | 
					
						
							|  |  |  |                         $hide = false; | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2015-03-27 13:36:33 +01:00
										 |  |  |                 $account->hide              = $hide; | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  |                 $account->budgetInformation = $array; | 
					
						
							|  |  |  |                 $account->balancedAmount    = $balancedAmount; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $start = clone $date; | 
					
						
							|  |  |  |         $start->startOfMonth(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * Start getBudgetsForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							| 
									
										
										
										
											2015-02-27 12:02:14 +01:00
										 |  |  |         $set                  = Auth::user()->budgets()->orderBy('budgets.name', 'ASC') | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  |                                     ->leftJoin( | 
					
						
							|  |  |  |                                         'budget_limits', function (JoinClause $join) use ($date) { | 
					
						
							|  |  |  |                                         $join->on('budget_limits.budget_id', '=', 'budgets.id')->where('budget_limits.startdate', '=', $date->format('Y-m-d')); | 
					
						
							|  |  |  |                                     } | 
					
						
							|  |  |  |                                     ) | 
					
						
							|  |  |  |                                     ->get(['budgets.*', 'budget_limits.amount as amount']); | 
					
						
							|  |  |  |         $budgets              = Steam::makeArray($set); | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |         $amountSet            = $query->journalsByBudget($start, $end, $showSharedReports); | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  |         $amounts              = Steam::makeArray($amountSet); | 
					
						
							|  |  |  |         $budgets              = Steam::mergeArrays($budgets, $amounts); | 
					
						
							|  |  |  |         $budgets[0]['spent']  = isset($budgets[0]['spent']) ? $budgets[0]['spent'] : 0.0; | 
					
						
							|  |  |  |         $budgets[0]['amount'] = isset($budgets[0]['amount']) ? $budgets[0]['amount'] : 0.0; | 
					
						
							|  |  |  |         $budgets[0]['name']   = 'No budget'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |         // find transactions to shared asset accounts, which are without a budget by default:
 | 
					
						
							|  |  |  |         // which is only relevant when shared asset accounts are hidden.
 | 
					
						
							|  |  |  |         if ($showSharedReports === false) { | 
					
						
							|  |  |  |             $transfers = $query->sharedExpenses($start, $end); | 
					
						
							|  |  |  |             foreach ($transfers as $transfer) { | 
					
						
							|  |  |  |                 $budgets[0]['spent'] += floatval($transfer->amount) * -1; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * End getBudgetsForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  |         return view('reports.budget', compact('subTitle', 'year', 'month', 'subTitleIcon', 'date', 'accounts', 'budgets', 'dayEarly')); | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param ReportHelperInterface $helper | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function index(ReportHelperInterface $helper) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-03-02 15:27:36 +01:00
										 |  |  |         $start         = Session::get('first'); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         $months        = $helper->listOfMonths($start); | 
					
						
							|  |  |  |         $years         = $helper->listOfYears($start); | 
					
						
							|  |  |  |         $title         = 'Reports'; | 
					
						
							|  |  |  |         $mainTitleIcon = 'fa-line-chart'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return view('reports.index', compact('years', 'months', 'title', 'mainTitleIcon')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * @param string  $year | 
					
						
							|  |  |  |      * @param string  $month | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\View\View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function modalBalancedTransfers(Account $account, $year = '2014', $month = '1', ReportQueryInterface $query) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |             new Carbon($year . '-' . $month . '-01'); | 
					
						
							|  |  |  |         } catch (Exception $e) { | 
					
						
							|  |  |  |             return view('error')->with('message', 'Invalid date'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $start = new Carbon($year . '-' . $month . '-01'); | 
					
						
							|  |  |  |         $end   = clone $start; | 
					
						
							|  |  |  |         $end->endOfMonth(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $journals = $query->balancedTransactionsList($account, $start, $end); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return view('reports.modal-journal-list', compact('journals')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Account              $account | 
					
						
							|  |  |  |      * @param string               $year | 
					
						
							|  |  |  |      * @param string               $month | 
					
						
							|  |  |  |      * @param ReportQueryInterface $query | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return View | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  |     public function modalLeftUnbalanced(Account $account, $year = '2014', $month = '1', ReportQueryInterface $query) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |             new Carbon($year . '-' . $month . '-01'); | 
					
						
							|  |  |  |         } catch (Exception $e) { | 
					
						
							|  |  |  |             return view('error')->with('message', 'Invalid date'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $start = new Carbon($year . '-' . $month . '-01'); | 
					
						
							|  |  |  |         $end   = clone $start; | 
					
						
							|  |  |  |         $end->endOfMonth(); | 
					
						
							|  |  |  |         $set = $query->getTransactionsWithoutBudget($account, $start, $end); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $journals = $set->filter( | 
					
						
							|  |  |  |             function (TransactionJournal $journal) { | 
					
						
							|  |  |  |                 $count = $journal->transactiongroups()->where('relation', 'balance')->count(); | 
					
						
							|  |  |  |                 if ($count == 0) { | 
					
						
							|  |  |  |                     return $journal; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return view('reports.modal-journal-list', compact('journals')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * @param string  $year | 
					
						
							|  |  |  |      * @param string  $month | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\View\View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function modalNoBudget(Account $account, $year = '2014', $month = '1', ReportQueryInterface $query) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |             new Carbon($year . '-' . $month . '-01'); | 
					
						
							|  |  |  |         } catch (Exception $e) { | 
					
						
							|  |  |  |             return view('error')->with('message', 'Invalid date'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $start = new Carbon($year . '-' . $month . '-01'); | 
					
						
							|  |  |  |         $end   = clone $start; | 
					
						
							|  |  |  |         $end->endOfMonth(); | 
					
						
							|  |  |  |         $journals = $query->getTransactionsWithoutBudget($account, $start, $end); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return view('reports.modal-journal-list', compact('journals')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param string $year | 
					
						
							|  |  |  |      * @param string $month | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\View\View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function month($year = '2014', $month = '1', ReportQueryInterface $query) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |             new Carbon($year . '-' . $month . '-01'); | 
					
						
							|  |  |  |         } catch (Exception $e) { | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  |             return view('error')->with('message', 'Invalid date.'); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         } | 
					
						
							|  |  |  |         $date         = new Carbon($year . '-' . $month . '-01'); | 
					
						
							|  |  |  |         $subTitle     = 'Report for ' . $date->format('F Y'); | 
					
						
							|  |  |  |         $subTitleIcon = 'fa-calendar'; | 
					
						
							|  |  |  |         $displaySum   = true; // to show sums in report.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |         $pref              = Preferences::get('showSharedReports', false); | 
					
						
							|  |  |  |         $showSharedReports = $pref->data; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * | 
					
						
							|  |  |  |          * get income for month (date) | 
					
						
							|  |  |  |          * | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $start = clone $date; | 
					
						
							|  |  |  |         $start->startOfMonth(); | 
					
						
							|  |  |  |         $end = clone $date; | 
					
						
							|  |  |  |         $end->endOfMonth(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * Start getIncomeForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |         $income = $query->incomeByPeriod($start, $end, $showSharedReports); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         /** | 
					
						
							|  |  |  |          * End getIncomeForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * Start getExpenseGroupedForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |         $set      = $query->journalsByExpenseAccount($start, $end, $showSharedReports); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         $expenses = Steam::makeArray($set); | 
					
						
							|  |  |  |         $expenses = Steam::sortArray($expenses); | 
					
						
							|  |  |  |         $expenses = Steam::limitArray($expenses, 10); | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * End getExpenseGroupedForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * Start getBudgetsForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         $set                  = Auth::user()->budgets() | 
					
						
							|  |  |  |                                     ->leftJoin( | 
					
						
							|  |  |  |                                         'budget_limits', function (JoinClause $join) use ($date) { | 
					
						
							|  |  |  |                                         $join->on('budget_limits.budget_id', '=', 'budgets.id')->where('budget_limits.startdate', '=', $date->format('Y-m-d')); | 
					
						
							|  |  |  |                                     } | 
					
						
							|  |  |  |                                     ) | 
					
						
							|  |  |  |                                     ->get(['budgets.*', 'budget_limits.amount as amount']); | 
					
						
							|  |  |  |         $budgets              = Steam::makeArray($set); | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |         $amountSet            = $query->journalsByBudget($start, $end, $showSharedReports); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         $amounts              = Steam::makeArray($amountSet); | 
					
						
							|  |  |  |         $budgets              = Steam::mergeArrays($budgets, $amounts); | 
					
						
							|  |  |  |         $budgets[0]['spent']  = isset($budgets[0]['spent']) ? $budgets[0]['spent'] : 0.0; | 
					
						
							|  |  |  |         $budgets[0]['amount'] = isset($budgets[0]['amount']) ? $budgets[0]['amount'] : 0.0; | 
					
						
							|  |  |  |         $budgets[0]['name']   = 'No budget'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // find transactions to shared expense accounts, which are without a budget by default:
 | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |         if ($showSharedReports === false) { | 
					
						
							|  |  |  |             $transfers = $query->sharedExpenses($start, $end); | 
					
						
							|  |  |  |             foreach ($transfers as $transfer) { | 
					
						
							|  |  |  |                 $budgets[0]['spent'] += floatval($transfer->amount) * -1; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * End getBudgetsForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * Start getCategoriesForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         // all categories.
 | 
					
						
							|  |  |  |         $result     = $query->journalsByCategory($start, $end); | 
					
						
							|  |  |  |         $categories = Steam::makeArray($result); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // all transfers
 | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |         if ($showSharedReports === false) { | 
					
						
							|  |  |  |             $result    = $query->sharedExpensesByCategory($start, $end); | 
					
						
							|  |  |  |             $transfers = Steam::makeArray($result); | 
					
						
							|  |  |  |             $merged    = Steam::mergeArrays($categories, $transfers); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             $merged = $categories; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // sort.
 | 
					
						
							|  |  |  |         $sorted = Steam::sortNegativeArray($merged); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // limit to $limit:
 | 
					
						
							|  |  |  |         $categories = Steam::limitArray($sorted, 10); | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * End getCategoriesForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * Start getAccountsForMonth | 
					
						
							|  |  |  |          */ | 
					
						
							| 
									
										
										
										
											2015-03-10 20:07:02 +01:00
										 |  |  |         $list     = $query->accountList($showSharedReports); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         $accounts = []; | 
					
						
							|  |  |  |         /** @var Account $account */ | 
					
						
							|  |  |  |         foreach ($list as $account) { | 
					
						
							|  |  |  |             $id = intval($account->id); | 
					
						
							|  |  |  |             /** @noinspection PhpParamsInspection */ | 
					
						
							|  |  |  |             $accounts[$id] = [ | 
					
						
							|  |  |  |                 'name'         => $account->name, | 
					
						
							|  |  |  |                 'startBalance' => Steam::balance($account, $start), | 
					
						
							|  |  |  |                 'endBalance'   => Steam::balance($account, $end) | 
					
						
							|  |  |  |             ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $accounts[$id]['difference'] = $accounts[$id]['endBalance'] - $accounts[$id]['startBalance']; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * End getAccountsForMonth | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |         return view( | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |             'reports.month', | 
					
						
							|  |  |  |             compact( | 
					
						
							|  |  |  |                 'income', 'expenses', 'budgets', 'accounts', 'categories', | 
					
						
							|  |  |  |                 'date', 'subTitle', 'displaySum', 'subTitleIcon' | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param $year | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return $this | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function year($year, ReportHelperInterface $helper, ReportQueryInterface $query) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |             new Carbon('01-01-' . $year); | 
					
						
							|  |  |  |         } catch (Exception $e) { | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |             return view('error')->with('message', 'Invalid date.'); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-03-27 19:34:37 +01:00
										 |  |  |         /** @var Preference $pref */ | 
					
						
							| 
									
										
										
										
											2015-03-10 19:57:20 +01:00
										 |  |  |         $pref              = Preferences::get('showSharedReports', false); | 
					
						
							|  |  |  |         $showSharedReports = $pref->data; | 
					
						
							|  |  |  |         $date              = new Carbon('01-01-' . $year); | 
					
						
							|  |  |  |         $end               = clone $date; | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         $end->endOfYear(); | 
					
						
							|  |  |  |         $title           = 'Reports'; | 
					
						
							|  |  |  |         $subTitle        = $year; | 
					
						
							|  |  |  |         $subTitleIcon    = 'fa-bar-chart'; | 
					
						
							|  |  |  |         $mainTitleIcon   = 'fa-line-chart'; | 
					
						
							| 
									
										
										
										
											2015-03-10 19:57:20 +01:00
										 |  |  |         $balances        = $helper->yearBalanceReport($date, $showSharedReports); | 
					
						
							|  |  |  |         $groupedIncomes  = $query->journalsByRevenueAccount($date, $end, $showSharedReports); | 
					
						
							|  |  |  |         $groupedExpenses = $query->journalsByExpenseAccount($date, $end, $showSharedReports); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         //$groupedExpenses = $helper-> expensesGroupedByAccount($date, $end, 15);
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  |         return view( | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |             'reports.year', compact('date', 'groupedIncomes', 'groupedExpenses', 'year', 'balances', 'title', 'subTitle', 'subTitleIcon', 'mainTitleIcon') | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |