_repository = $repository; View::share('title', 'Transactions'); View::share('mainTitleIcon', 'fa-repeat'); } /** * @param string $what * * @return \Illuminate\View\View */ public function create($what = 'deposit') { /** @var \Firefly\Helper\Toolkit\Toolkit $toolkit */ $toolkit = App::make('Firefly\Helper\Toolkit\Toolkit'); // get asset accounts with names and id's. /** @var \Firefly\Storage\Account\AccountRepositoryInterface $accountRepository */ $accountRepository = App::make('Firefly\Storage\Account\AccountRepositoryInterface'); $list = $accountRepository->getActiveDefault(); $assetAccounts = $toolkit->makeSelectList($list); // get budgets as a select list. /** @var \Firefly\Storage\Budget\BudgetRepositoryInterface $budgetRepository */ $budgetRepository = App::make('Firefly\Storage\Budget\BudgetRepositoryInterface'); $budgets = $toolkit->makeSelectList($budgetRepository->get()); $budgets[0] = '(no budget)'; // get the piggy banks. /** @var \Firefly\Storage\Piggybank\PiggybankRepositoryInterface $piggyRepository */ $piggyRepository = App::make('Firefly\Storage\Piggybank\PiggybankRepositoryInterface'); $piggies = $piggyRepository->get(); return View::make('transactions.create')->with('accounts', $assetAccounts)->with('budgets', $budgets)->with( 'what', $what )->with('piggies', $piggies)->with('subTitle', 'Add a new ' . $what)->with('title', 'Transactions'); } /** * @param TransactionJournal $transactionJournal * * @return $this */ public function delete(TransactionJournal $transactionJournal) { View::share( 'subTitle', 'Delete ' . strtolower($transactionJournal->transactionType->type) . ' "' . $transactionJournal->description . '"' ); return View::make('transactions.delete')->with('journal', $transactionJournal); } /** * @param TransactionJournal $transactionJournal * * @return \Illuminate\Http\RedirectResponse */ public function destroy(TransactionJournal $transactionJournal) { $transactionJournal->delete(); return Redirect::route('transactions.index'); } /** * @param TransactionJournal $journal * * @return $this */ public function edit(TransactionJournal $journal) { // type is useful for display: $what = strtolower($journal->transactiontype->type); // some lists prefilled: // get accounts with names and id's. /** @var \Firefly\Helper\Toolkit\Toolkit $toolkit */ $toolkit = App::make('Firefly\Helper\Toolkit\Toolkit'); // get asset accounts with names and id's. /** @var \Firefly\Storage\Account\AccountRepositoryInterface $accountRepository */ $accountRepository = App::make('Firefly\Storage\Account\AccountRepositoryInterface'); $list = $accountRepository->getActiveDefault(); $accounts = $toolkit->makeSelectList($list); View::share( 'subTitle', 'Edit ' . strtolower($journal->transactionType->type) . ' "' . $journal->description . '"' ); // get budgets as a select list. /** @var \Firefly\Storage\Budget\BudgetRepositoryInterface $budgetRepository */ $budgetRepository = App::make('Firefly\Storage\Budget\BudgetRepositoryInterface'); $budgets = $budgetRepository->getAsSelectList(); $budgets[0] = '(no budget)'; // get the piggy banks. /** @var \Firefly\Storage\Piggybank\PiggybankRepositoryInterface $piggyRepository */ $piggyRepository = App::make('Firefly\Storage\Piggybank\PiggybankRepositoryInterface'); $piggies = $piggyRepository->get(); // piggy bank id? $piggyBankId = null; foreach ($journal->transactions as $t) { $piggyBankId = $t->piggybank_id; } // data to properly display form: $data = [ 'date' => $journal->date->format('Y-m-d'), 'category' => '', 'budget_id' => 0, 'piggybank_id' => $piggyBankId ]; $category = $journal->categories()->first(); if (!is_null($category)) { $data['category'] = $category->name; } switch ($journal->transactiontype->type) { case 'Withdrawal': $data['account_id'] = $journal->transactions[0]->account->id; $data['beneficiary'] = $journal->transactions[1]->account->name; $data['amount'] = floatval($journal->transactions[1]->amount); $budget = $journal->budgets()->first(); if (!is_null($budget)) { $data['budget_id'] = $budget->id; } break; case 'Deposit': $data['account_id'] = $journal->transactions[1]->account->id; $data['beneficiary'] = $journal->transactions[0]->account->name; $data['amount'] = floatval($journal->transactions[1]->amount); break; case 'Transfer': $data['account_from_id'] = $journal->transactions[1]->account->id; $data['account_to_id'] = $journal->transactions[0]->account->id; $data['amount'] = floatval($journal->transactions[1]->amount); break; } return View::make('transactions.edit')->with('journal', $journal)->with('accounts', $accounts)->with( 'what', $what )->with('budgets', $budgets)->with('data', $data)->with('piggies', $piggies); } public function expenses() { $transactionType = $this->_repository->getTransactionType('Withdrawal'); $start = is_null(Input::get('startdate')) ? null : new Carbon(Input::get('startdate')); $end = is_null(Input::get('enddate')) ? null : new Carbon(Input::get('enddate')); if ($start <= $end && !is_null($start) && !is_null($end)) { $journals = $this->_repository->paginate($transactionType, 25, $start, $end); $filtered = true; $filters = ['start' => $start, 'end' => $end]; } else { $journals = $this->_repository->paginate($transactionType, 25); $filtered = false; $filters = null; } View::share('subTitleIcon', 'fa-long-arrow-left'); return View::make('transactions.index')->with('journals', $journals)->with('filtered', $filtered)->with( 'filters', $filters )->with('subTitle', 'Expenses'); } public function revenue() { $transactionType = $this->_repository->getTransactionType('Deposit'); $start = is_null(Input::get('startdate')) ? null : new Carbon(Input::get('startdate')); $end = is_null(Input::get('enddate')) ? null : new Carbon(Input::get('enddate')); if ($start <= $end && !is_null($start) && !is_null($end)) { $journals = $this->_repository->paginate($transactionType, 25, $start, $end); $filtered = true; $filters = ['start' => $start, 'end' => $end]; } else { $journals = $this->_repository->paginate($transactionType, 25); $filtered = false; $filters = null; } View::share('subTitleIcon', 'fa-long-arrow-right'); return View::make('transactions.index')->with('journals', $journals)->with('filtered', $filtered)->with( 'filters', $filters )->with('subTitle', 'Revenue'); } public function transfers() { $transactionType = $this->_repository->getTransactionType('Transfer'); $start = is_null(Input::get('startdate')) ? null : new Carbon(Input::get('startdate')); $end = is_null(Input::get('enddate')) ? null : new Carbon(Input::get('enddate')); if ($start <= $end && !is_null($start) && !is_null($end)) { $journals = $this->_repository->paginate($transactionType, 25, $start, $end); $filtered = true; $filters = ['start' => $start, 'end' => $end]; } else { $journals = $this->_repository->paginate($transactionType, 25); $filtered = false; $filters = null; } View::share('subTitleIcon', 'fa-arrows-h'); return View::make('transactions.index')->with('journals', $journals)->with('filtered', $filtered)->with( 'filters', $filters )->with('subTitle', 'Transfers'); } /** * @return $this|\Illuminate\View\View */ public function index() { $start = is_null(Input::get('startdate')) ? null : new Carbon(Input::get('startdate')); $end = is_null(Input::get('enddate')) ? null : new Carbon(Input::get('enddate')); if ($start <= $end && !is_null($start) && !is_null($end)) { $journals = $this->_repository->paginate(25, $start, $end); $filtered = true; $filters = ['start' => $start, 'end' => $end]; } else { $journals = $this->_repository->paginate(25); $filtered = false; $filters = null; } return View::make('transactions.index')->with('journals', $journals)->with('filtered', $filtered)->with( 'filters', $filters ); } /** * @param TransactionJournal $journal * * @return $this */ public function show(TransactionJournal $journal) { View::share('subTitle', $journal->transactionType->type . ' "' . $journal->description . '"'); return View::make('transactions.show')->with('journal', $journal); } /** * @param $what * * @return \Illuminate\Http\RedirectResponse */ public function store($what) { $journal = $this->_repository->store($what, Input::all()); if ($journal->errors()->count() > 0) { Session::flash('error', 'Could not save transaction: ' . $journal->errors()->first() . '!'); return Redirect::route('transactions.create', [$what])->withInput()->withErrors($journal->errors()); } if ($journal->validate() && !is_null($journal->id)) { Session::flash('success', 'Transaction "' . $journal->description . '" saved!'); // if reminder present, deactivate it: if (Input::get('reminder')) { /** @var \Firefly\Storage\Reminder\ReminderRepositoryInterface $reminders */ $reminders = App::make('Firefly\Storage\Reminder\ReminderRepositoryInterface'); $reminder = $reminders->find(Input::get('reminder')); $reminders->deactivate($reminder); } // trigger the creation for recurring transactions. Event::fire('journals.store', [$journal]); if (Input::get('create') == '1') { return Redirect::route('transactions.create', [$what])->withInput(); } else { switch ($what) { case 'withdrawal': return Redirect::route('transactions.expenses'); break; case 'deposit': return Redirect::route('transactions.revenue'); break; case 'transfer': return Redirect::route('transactions.transfers'); break; } } } else { Session::flash('error', 'Could not save transaction: ' . $journal->errors()->first() . '!'); return Redirect::route('transactions.create', [$what])->withInput()->withErrors($journal->errors()); } } /** * @param TransactionJournal $journal * * @return $this|\Illuminate\Http\RedirectResponse */ public function update(TransactionJournal $journal) { $journal = $this->_repository->update($journal, Input::all()); if ($journal->validate()) { // has been saved, return to index: Session::flash('success', 'Transaction updated!'); Event::fire('journals.update', [$journal]); return Redirect::route('transactions.index'); } else { Session::flash('error', 'Could not update transaction: ' . $journal->errors()->first()); return Redirect::route('transactions.edit', $journal->id)->withInput()->withErrors($journal->errors()); } } }