mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-26 21:43:53 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			223 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			223 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php namespace FireflyIII\Http\Controllers;
 | |
| 
 | |
| use Auth;
 | |
| use Carbon\Carbon;
 | |
| use FireflyIII\Http\Requests;
 | |
| use FireflyIII\Http\Requests\BudgetFormRequest;
 | |
| use FireflyIII\Models\Budget;
 | |
| use FireflyIII\Models\LimitRepetition;
 | |
| use FireflyIII\Repositories\Budget\BudgetRepositoryInterface;
 | |
| use Input;
 | |
| use Preferences;
 | |
| use Redirect;
 | |
| use Response;
 | |
| 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]);
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @return $this
 | |
|      */
 | |
|     public function create()
 | |
|     {
 | |
|         return view('budgets.create')->with('subTitle', 'Create a new budget');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param Budget $budget
 | |
|      *
 | |
|      * @return \Illuminate\View\View
 | |
|      */
 | |
|     public function delete(Budget $budget)
 | |
|     {
 | |
|         $subTitle = 'Delete budget' . e($budget->name) . '"';
 | |
| 
 | |
|         return view('budgets.delete', compact('budget', 'subTitle'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @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) . '"';
 | |
| 
 | |
|         return view('budgets.edit', compact('budget', 'subTitle'));
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @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;
 | |
| 
 | |
|         return view('budgets.index', compact('budgetMaximum', 'budgets', 'spent', 'spentPCT', 'overspent', 'amount'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @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)
 | |
|                         ->orderBy('transaction_journals.date')
 | |
|                         ->get(['transaction_journals.*']);
 | |
|         $subTitle = 'Transactions without a budget in ' . $start->format('F Y');
 | |
| 
 | |
|         return view('budgets.noBudget', compact('list', 'subTitle'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @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');
 | |
|     }
 | |
| 
 | |
|     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!');
 | |
| 
 | |
|         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) {
 | |
|             return view('error')->with('message', 'Invalid selection.');
 | |
|         }
 | |
| 
 | |
|         $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);
 | |
| 
 | |
|         return view('budgets.show', compact('limits', 'budget', 'repetition', 'journals', 'subTitle', 'hideBudget'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @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.');
 | |
| 
 | |
|         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);
 | |
| 
 | |
|         return view('budgets.income')->with('amount', $budgetAmount);
 | |
|     }
 | |
| 
 | |
| }
 |