mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-01-22 06:23:12 -06:00
348 lines
13 KiB
PHP
348 lines
13 KiB
PHP
<?php
|
|
|
|
|
|
use Carbon\Carbon;
|
|
use Firefly\Storage\TransactionJournal\TransactionJournalRepositoryInterface as TJRI;
|
|
|
|
/**
|
|
* Class TransactionController
|
|
*
|
|
* @SuppressWarnings(PHPMD.CamelCasePropertyName)
|
|
*
|
|
*/
|
|
class TransactionController extends BaseController
|
|
{
|
|
|
|
protected $_repository;
|
|
|
|
/**
|
|
* @param TJRI $repository
|
|
*/
|
|
public function __construct(TJRI $repository)
|
|
{
|
|
$this->_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());
|
|
}
|
|
|
|
|
|
}
|
|
|
|
}
|