| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | <?php namespace FireflyIII\Http\Controllers; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							|  |  |  | use Exception; | 
					
						
							|  |  |  | use FireflyIII\Helpers\Report\ReportHelperInterface; | 
					
						
							|  |  |  | use FireflyIII\Helpers\Report\ReportQueryInterface; | 
					
						
							|  |  |  | use FireflyIII\Models\Account; | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  | use FireflyIII\Models\Preference; | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  | use FireflyIII\Models\TransactionJournal; | 
					
						
							| 
									
										
										
										
											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-04 20:47:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Class ReportController | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package FireflyIII\Http\Controllers | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class ReportController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |     /** @var ReportHelperInterface */ | 
					
						
							|  |  |  |     protected $helper; | 
					
						
							|  |  |  |     /** @var ReportQueryInterface */ | 
					
						
							|  |  |  |     protected $query; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |      * @param ReportHelperInterface $helper | 
					
						
							|  |  |  |      * @param ReportQueryInterface  $query | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |     public function __construct(ReportHelperInterface $helper, ReportQueryInterface $query) | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |         $this->query  = $query; | 
					
						
							|  |  |  |         $this->helper = $helper; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         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 | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |     public function budget($year = '2014', $month = '1') | 
					
						
							| 
									
										
										
										
											2015-02-23 21:19:16 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         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-29 12:25:46 +02:00
										 |  |  |         /** @var Preference $pref */ | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |         $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-29 12:25:46 +02:00
										 |  |  |         $accounts     = $this->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( | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |             function (Account $account) use ($start, $end) { | 
					
						
							|  |  |  |                 $budgets        = $this->query->getBudgetSummary($account, $start, $end); | 
					
						
							|  |  |  |                 $balancedAmount = $this->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-04-09 21:14:15 +02:00
										 |  |  |                     if (floatval($data['queryAmount']) != 0) { | 
					
						
							| 
									
										
										
										
											2015-03-27 13:36:33 +01:00
										 |  |  |                         $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 getBudgetsForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |         $budgets = $this->helper->getBudgetsForMonth($date, $showSharedReports); | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |     public function index() | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-03-02 15:27:36 +01:00
										 |  |  |         $start         = Session::get('first'); | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |         $months        = $this->helper->listOfMonths($start); | 
					
						
							|  |  |  |         $years         = $this->helper->listOfYears($start); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         $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 | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |     public function modalBalancedTransfers(Account $account, $year = '2014', $month = '1') | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  |     { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         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(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |         $journals = $this->query->balancedTransactionsList($account, $start, $end); | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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-29 12:25:46 +02:00
										 |  |  |     public function modalLeftUnbalanced(Account $account, $year = '2014', $month = '1') | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         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(); | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |         $set = $this->query->getTransactionsWithoutBudget($account, $start, $end); | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $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 | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |     public function modalNoBudget(Account $account, $year = '2014', $month = '1') | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         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(); | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |         $journals = $this->query->getTransactionsWithoutBudget($account, $start, $end); | 
					
						
							| 
									
										
										
										
											2015-03-04 20:47:00 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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 | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |     public function month($year = '2014', $month = '1') | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         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-29 12:25:46 +02:00
										 |  |  |         /** @var Preference $pref */ | 
					
						
							| 
									
										
										
										
											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-29 12:25:46 +02:00
										 |  |  |         $income = $this->query->incomeByPeriod($start, $end, $showSharedReports); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         /** | 
					
						
							|  |  |  |          * End getIncomeForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * Start getExpenseGroupedForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							| 
									
										
										
										
											2015-04-07 18:26:14 +02:00
										 |  |  |         $set = $this->query->journalsByExpenseAccount($start, $end, $showSharedReports); | 
					
						
							| 
									
										
										
										
											2015-03-31 21:18:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  |          */ | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |         $budgets = $this->helper->getBudgetsForMonth($date, $showSharedReports); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * End getBudgetsForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * Start getCategoriesForMonth DONE | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         // all categories.
 | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |         $result     = $this->query->journalsByCategory($start, $end); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         $categories = Steam::makeArray($result); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-31 21:18:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |         // all transfers
 | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |         if ($showSharedReports === false) { | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |             $result    = $this->query->sharedExpensesByCategory($start, $end); | 
					
						
							| 
									
										
										
										
											2015-03-10 19:51:24 +01:00
										 |  |  |             $transfers = Steam::makeArray($result); | 
					
						
							|  |  |  |             $merged    = Steam::mergeArrays($categories, $transfers); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             $merged = $categories; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-31 21:18:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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-29 12:25:46 +02:00
										 |  |  |         $list     = $this->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 | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-03-29 12:25:46 +02:00
										 |  |  |     public function year($year) | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         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-29 12:25:46 +02:00
										 |  |  |         $balances        = $this->helper->yearBalanceReport($date, $showSharedReports); | 
					
						
							|  |  |  |         $groupedIncomes  = $this->query->journalsByRevenueAccount($date, $end, $showSharedReports); | 
					
						
							|  |  |  |         $groupedExpenses = $this->query->journalsByExpenseAccount($date, $end, $showSharedReports); | 
					
						
							| 
									
										
										
										
											2015-02-23 20:25:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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') | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |