| 
									
										
										
										
											2015-02-22 09:46:21 +01:00
										 |  |  | <?php namespace FireflyIII\Http\Controllers; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Auth; | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							|  |  |  | use FireflyIII\Http\Requests; | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  | use FireflyIII\Http\Requests\BudgetFormRequest; | 
					
						
							| 
									
										
										
										
											2015-02-22 09:46:21 +01:00
										 |  |  | use FireflyIII\Models\Budget; | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  | use FireflyIII\Models\LimitRepetition; | 
					
						
							| 
									
										
										
										
											2015-02-22 09:46:21 +01:00
										 |  |  | use FireflyIII\Repositories\Budget\BudgetRepositoryInterface; | 
					
						
							|  |  |  | use Input; | 
					
						
							|  |  |  | use Preferences; | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  | use Redirect; | 
					
						
							|  |  |  | use Response; | 
					
						
							| 
									
										
										
										
											2015-02-22 09:46:21 +01:00
										 |  |  | use Session; | 
					
						
							|  |  |  | use View; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class BudgetController | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package FireflyIII\Http\Controllers | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class BudgetController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         View::share('title', 'Budgets'); | 
					
						
							|  |  |  |         View::share('mainTitleIcon', 'fa-tasks'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Budget $budget | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							|  |  |  |      * @throws Exception | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function amount(Budget $budget, BudgetRepositoryInterface $repository) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $amount          = intval(Input::get('amount')); | 
					
						
							|  |  |  |         $date            = Session::get('start', Carbon::now()->startOfMonth()); | 
					
						
							|  |  |  |         $limitRepetition = $repository->updateLimitAmount($budget, $date, $amount); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Response::json(['name' => $budget->name, 'repetition' => $limitRepetition ? $limitRepetition->id : 0]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return $this | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function create() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-02-22 16:19:32 +01:00
										 |  |  |         return view('budgets.create')->with('subTitle', 'Create a new budget'); | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Budget $budget | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\View\View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function delete(Budget $budget) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $subTitle = 'Delete budget' . e($budget->name) . '"'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-22 16:19:32 +01:00
										 |  |  |         return view('budgets.delete', compact('budget', 'subTitle')); | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Budget $budget | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function destroy(Budget $budget, BudgetRepositoryInterface $repository) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $name = $budget->name; | 
					
						
							|  |  |  |         $repository->destroy($budget); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Session::flash('success', 'The  budget "' . e($name) . '" was deleted.'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Redirect::route('budgets.index'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Budget $budget | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return $this | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function edit(Budget $budget) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $subTitle = 'Edit budget "' . e($budget->name) . '"'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-22 16:19:32 +01:00
										 |  |  |         return view('budgets.edit', compact('budget', 'subTitle')); | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-22 09:46:21 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function index(BudgetRepositoryInterface $repository) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $budgets = Auth::user()->budgets()->get(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // loop the budgets:
 | 
					
						
							|  |  |  |         $budgets->each( | 
					
						
							|  |  |  |             function (Budget $budget) use ($repository) { | 
					
						
							|  |  |  |                 $date               = Session::get('start', Carbon::now()->startOfMonth()); | 
					
						
							|  |  |  |                 $budget->spent      = $repository->spentInMonth($budget, $date); | 
					
						
							|  |  |  |                 $budget->currentRep = $budget->limitrepetitions()->where('limit_repetitions.startdate', $date)->first(['limit_repetitions.*']); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $date          = Session::get('start', Carbon::now()->startOfMonth())->format('FY'); | 
					
						
							|  |  |  |         $spent         = $budgets->sum('spent'); | 
					
						
							|  |  |  |         $amount        = Preferences::get('budgetIncomeTotal' . $date, 1000)->data; | 
					
						
							|  |  |  |         $overspent     = $spent > $amount; | 
					
						
							|  |  |  |         $spentPCT      = $overspent ? ceil($amount / $spent * 100) : ceil($spent / $amount * 100); | 
					
						
							|  |  |  |         $budgetMax     = Preferences::get('budgetMaximum', 1000); | 
					
						
							|  |  |  |         $budgetMaximum = $budgetMax->data; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-22 16:19:32 +01:00
										 |  |  |         return view('budgets.index', compact('budgetMaximum', 'budgets', 'spent', 'spentPCT', 'overspent', 'amount')); | 
					
						
							| 
									
										
										
										
											2015-02-22 09:46:21 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return \Illuminate\View\View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function noBudget() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $start    = \Session::get('start', Carbon::now()->startOfMonth()); | 
					
						
							|  |  |  |         $end      = \Session::get('end', Carbon::now()->startOfMonth()); | 
					
						
							|  |  |  |         $list     = Auth::user() | 
					
						
							|  |  |  |                         ->transactionjournals() | 
					
						
							|  |  |  |                         ->leftJoin('budget_transaction_journal', 'budget_transaction_journal.transaction_journal_id', '=', 'transaction_journals.id') | 
					
						
							|  |  |  |                         ->whereNull('budget_transaction_journal.id') | 
					
						
							|  |  |  |                         ->before($end) | 
					
						
							|  |  |  |                         ->after($start) | 
					
						
							| 
									
										
										
										
											2015-03-27 07:32:06 +01:00
										 |  |  |             ->orderBy('transaction_journals.date', 'DESC') | 
					
						
							|  |  |  |             ->orderBy('transaction_journals.order','ASC') | 
					
						
							|  |  |  |             ->orderBy('transaction_journals.id','DESC') | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  |                         ->get(['transaction_journals.*']); | 
					
						
							|  |  |  |         $subTitle = 'Transactions without a budget in ' . $start->format('F Y'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-22 16:19:32 +01:00
										 |  |  |         return view('budgets.noBudget', compact('list', 'subTitle')); | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function postUpdateIncome() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $date = Session::get('start', Carbon::now()->startOfMonth())->format('FY'); | 
					
						
							|  |  |  |         Preferences::set('budgetIncomeTotal' . $date, intval(Input::get('amount'))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Redirect::route('budgets.index'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-26 17:45:03 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param BudgetFormRequest         $request | 
					
						
							|  |  |  |      * @param BudgetRepositoryInterface $repository | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  |     public function store(BudgetFormRequest $request, BudgetRepositoryInterface $repository) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $budgetData = [ | 
					
						
							|  |  |  |             'name' => $request->input('name'), | 
					
						
							|  |  |  |             'user' => Auth::user()->id, | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         $budget     = $repository->store($budgetData); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Session::flash('success', 'New budget "' . $budget->name . '" stored!'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-28 18:22:36 +01:00
										 |  |  |         if (intval(Input::get('create_another')) === 1) { | 
					
						
							|  |  |  |             return Redirect::route('budgets.create')->withInput(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  |         return Redirect::route('budgets.index'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Budget          $budget | 
					
						
							|  |  |  |      * @param LimitRepetition $repetition | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\View\View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function show(Budget $budget, LimitRepetition $repetition = null, BudgetRepositoryInterface $repository) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!is_null($repetition->id) && $repetition->budgetLimit->budget->id != $budget->id) { | 
					
						
							| 
									
										
										
										
											2015-02-22 16:19:32 +01:00
										 |  |  |             return view('error')->with('message', 'Invalid selection.'); | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $hideBudget = true; // used in transaction list.
 | 
					
						
							|  |  |  |         $journals   = $repository->getJournals($budget, $repetition); | 
					
						
							|  |  |  |         $limits     = !is_null($repetition->id) ? [$repetition->budgetLimit] : $budget->budgetLimits()->orderBy('startdate', 'DESC')->get(); | 
					
						
							|  |  |  |         $subTitle   = !is_null($repetition->id) ? e($budget->name) . ' in ' . $repetition->startdate->format('F Y') : e($budget->name); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-22 16:19:32 +01:00
										 |  |  |         return view('budgets.show', compact('limits', 'budget', 'repetition', 'journals', 'subTitle', 'hideBudget')); | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Budget                    $budget | 
					
						
							|  |  |  |      * @param BudgetFormRequest         $request | 
					
						
							|  |  |  |      * @param BudgetRepositoryInterface $repository | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function update(Budget $budget, BudgetFormRequest $request, BudgetRepositoryInterface $repository) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $budgetData = [ | 
					
						
							|  |  |  |             'name' => $request->input('name'), | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $repository->update($budget, $budgetData); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Session::flash('success', 'Budget "' . $budget->name . '" updated.'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-26 17:45:03 +01:00
										 |  |  |         if (intval(Input::get('return_to_edit')) === 1) { | 
					
						
							|  |  |  |             return Redirect::route('budgets.edit', $budget->id); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  |         return Redirect::route('budgets.index'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return $this | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function updateIncome() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $date         = Session::get('start', Carbon::now()->startOfMonth())->format('FY'); | 
					
						
							|  |  |  |         $budgetAmount = Preferences::get('budgetIncomeTotal' . $date, 1000); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-22 16:19:32 +01:00
										 |  |  |         return view('budgets.income')->with('amount', $budgetAmount); | 
					
						
							| 
									
										
										
										
											2015-02-22 15:40:13 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-22 09:46:21 +01:00
										 |  |  | } |