firefly-iii/app/Http/Controllers/TransactionController.php

358 lines
12 KiB
PHP
Raw Normal View History

2015-02-23 14:55:52 -06:00
<?php namespace FireflyIII\Http\Controllers;
use Auth;
2015-02-24 15:53:38 -06:00
use Carbon\Carbon;
2015-02-24 14:10:25 -06:00
use ExpandedForm;
2015-03-02 13:05:28 -06:00
use FireflyIII\Events\JournalCreated;
2015-03-01 01:34:59 -06:00
use FireflyIII\Events\JournalSaved;
2015-02-23 14:55:52 -06:00
use FireflyIII\Http\Requests;
2015-02-24 15:53:38 -06:00
use FireflyIII\Http\Requests\JournalFormRequest;
2015-02-25 14:19:06 -06:00
use FireflyIII\Models\Transaction;
use FireflyIII\Models\TransactionJournal;
2015-02-24 15:53:38 -06:00
use FireflyIII\Repositories\Journal\JournalRepositoryInterface;
2015-02-23 14:55:52 -06:00
use Illuminate\Pagination\LengthAwarePaginator;
2015-02-24 14:10:25 -06:00
use Input;
2015-02-24 15:53:38 -06:00
use Redirect;
2015-02-24 14:10:25 -06:00
use Session;
2015-02-23 14:55:52 -06:00
use View;
2015-03-27 01:29:01 -05:00
use Response;
2015-02-27 07:27:04 -06:00
2015-02-23 14:55:52 -06:00
/**
* Class TransactionController
*
* @package FireflyIII\Http\Controllers
*/
class TransactionController extends Controller
{
/**
*/
public function __construct()
{
View::share('title', 'Transactions');
View::share('mainTitleIcon', 'fa-repeat');
}
2015-02-24 14:10:25 -06:00
/**
* Shows the view helping the user to create a new transaction journal.
*
* @param string $what
*
* @return \Illuminate\View\View
*/
public function create($what = 'deposit')
{
$accounts = ExpandedForm::makeSelectList(
2015-03-10 11:26:31 -05:00
Auth::user()->accounts()->accountTypeIn(['Default account', 'Asset account'])->orderBy('accounts.name', 'ASC')->orderBy('name', 'ASC')->where(
'active', 1
)->orderBy('name', 'DESC')->get(['accounts.*'])
2015-02-24 14:10:25 -06:00
);
$budgets = ExpandedForm::makeSelectList(Auth::user()->budgets()->get());
$budgets[0] = '(no budget)';
$piggies = ExpandedForm::makeSelectList(Auth::user()->piggyBanks()->get());
$piggies[0] = '(no piggy bank)';
$preFilled = Session::has('preFilled') ? Session::get('preFilled') : [];
$respondTo = ['account_id', 'account_from_id'];
$subTitle = 'Add a new ' . e($what);
foreach ($respondTo as $r) {
if (!is_null(Input::get($r))) {
$preFilled[$r] = Input::get($r);
}
}
Session::put('preFilled', $preFilled);
asort($piggies);
return view('transactions.create', compact('accounts', 'budgets', 'what', 'piggies', 'subTitle'));
}
2015-02-27 07:27:04 -06:00
/**
* Shows the form that allows a user to delete a transaction journal.
*
* @param TransactionJournal $journal
*
* @return $this
*/
public function delete(TransactionJournal $journal)
{
$type = strtolower($journal->transactionType->type);
$subTitle = 'Delete ' . e($type) . ' "' . e($journal->description) . '"';
return View::make('transactions.delete', compact('journal', 'subTitle'));
}
/**
* @param TransactionJournal $transactionJournal
*
* @return \Illuminate\Http\RedirectResponse
*/
public function destroy(TransactionJournal $transactionJournal)
{
$type = $transactionJournal->transactionType->type;
$return = 'withdrawal';
Session::flash('success', 'Transaction "' . e($transactionJournal->description) . '" destroyed.');
$transactionJournal->delete();
switch ($type) {
case 'Deposit':
$return = 'deposit';
break;
case 'Transfer':
$return = 'transfers';
break;
}
return Redirect::route('transactions.index', $return);
}
/**
* Shows the view to edit a transaction.
*
* @param TransactionJournal $journal
*
* @return $this
*/
public function edit(TransactionJournal $journal, JournalRepositoryInterface $repository)
{
$what = strtolower($journal->transactiontype->type);
$accounts = ExpandedForm::makeSelectList(
2015-03-10 11:26:31 -05:00
Auth::user()->accounts()->accountTypeIn(['Default account', 'Asset account'])->orderBy('accounts.name', 'ASC')->where('active', 1)->orderBy(
'name', 'DESC'
)->get(['accounts.*'])
2015-02-27 07:27:04 -06:00
);
$budgets = ExpandedForm::makeSelectList(Auth::user()->budgets()->get());
$budgets[0] = '(no budget)';
$transactions = $journal->transactions()->orderBy('amount', 'DESC')->get();
$piggies = ExpandedForm::makeSelectList(Auth::user()->piggyBanks()->get());
$piggies[0] = '(no piggy bank)';
$preFilled = [
'date' => $journal->date->format('Y-m-d'),
'category' => '',
'budget_id' => 0,
'piggy_bank_id' => 0
];
$category = $journal->categories()->first();
if (!is_null($category)) {
$preFilled['category'] = $category->name;
}
$budget = $journal->budgets()->first();
if (!is_null($budget)) {
$preFilled['budget_id'] = $budget->id;
}
if ($journal->piggyBankEvents()->count() > 0) {
2015-03-02 13:05:28 -06:00
$preFilled['piggy_bank_id'] = $journal->piggyBankEvents()->orderBy('date', 'DESC')->first()->piggy_bank_id;
2015-02-27 07:27:04 -06:00
}
$preFilled['amount'] = 0;
/** @var Transaction $t */
foreach ($transactions as $t) {
if (floatval($t->amount) > 0) {
$preFilled['amount'] = floatval($t->amount);
}
}
$preFilled['account_id'] = $repository->getAssetAccount($journal);
$preFilled['expense_account'] = $transactions[0]->account->name;
$preFilled['revenue_account'] = $transactions[1]->account->name;
$preFilled['account_from_id'] = $transactions[1]->account->id;
$preFilled['account_to_id'] = $transactions[0]->account->id;
return View::make('transactions.edit', compact('journal', 'accounts', 'what', 'budgets', 'piggies', 'subTitle'))->with('data', $preFilled);
}
2015-02-23 14:55:52 -06:00
/**
* @param $what
*
* @return $this
*/
public function index($what)
{
switch ($what) {
case 'expenses':
case 'withdrawal':
$subTitleIcon = 'fa-long-arrow-left';
$subTitle = 'Expenses';
$types = ['Withdrawal'];
2015-02-23 14:55:52 -06:00
break;
case 'revenue':
case 'deposit':
$subTitleIcon = 'fa-long-arrow-right';
$subTitle = 'Revenue, income and deposits';
$types = ['Deposit'];
2015-02-23 14:55:52 -06:00
break;
case 'transfer':
case 'transfers':
$subTitleIcon = 'fa-exchange';
2015-02-23 14:55:52 -06:00
$subTitle = 'Transfers';
$types = ['Transfer'];
2015-02-23 14:55:52 -06:00
break;
}
$page = intval(\Input::get('page'));
$offset = $page > 0 ? ($page - 1) * 50 : 0;
2015-03-27 01:29:01 -05:00
$set = Auth::user()->
transactionJournals()->
transactionTypes($types)->
withRelevantData()->take(50)->offset($offset)
->orderBy('date', 'DESC')
->orderBy('order','ASC')
->orderBy('id','DESC')
->get(
2015-02-23 14:55:52 -06:00
['transaction_journals.*']
);
$count = Auth::user()->transactionJournals()->transactionTypes($types)->count();
$journals = new LengthAwarePaginator($set, $count, 50, $page);
$journals->setPath('transactions/' . $what);
2015-02-24 15:53:38 -06:00
return view('transactions.index', compact('subTitle', 'what', 'subTitleIcon', 'journals'));
}
/**
* Reorder transactions (which all must have the same date)
*/
public function reorder()
{
$ids = Input::get('items');
2015-03-27 01:29:01 -05:00
if (count($ids) > 0) {
$order = 0;
foreach ($ids as $id) {
$journal = Auth::user()->transactionjournals()->where('id', $id)->where('date', Input::get('date'))->first();
if($journal) {
$journal->order = $order;
$order++;
$journal->save();
}
}
}
return Response::json(true);
}
2015-02-25 14:19:06 -06:00
/**
* @param TransactionJournal $journal
*
* @return $this
*/
public function show(TransactionJournal $journal)
{
$journal->transactions->each(
function (Transaction $t) use ($journal) {
$t->before = floatval(
$t->account->transactions()->leftJoin(
'transaction_journals', 'transaction_journals.id', '=', 'transactions.transaction_journal_id'
2015-03-27 03:29:14 -05:00
)
->where('transaction_journals.date', '<=', $journal->date->format('Y-m-d'))
->where('transaction_journals.order','>=',$journal->order)
->where('transaction_journals.id', '!=', $journal->id)
->sum('transactions.amount')
2015-02-25 14:19:06 -06:00
);
$t->after = $t->before + $t->amount;
}
);
2015-03-04 02:42:47 -06:00
return view('transactions.show', compact('journal'))->with(
2015-02-27 07:27:04 -06:00
'subTitle', e($journal->transactiontype->type) . ' "' . e($journal->description) . '"'
2015-02-25 14:19:06 -06:00
);
}
/**
* @param JournalFormRequest $request
* @param JournalRepositoryInterface $repository
*
* @return $this|\Illuminate\Http\RedirectResponse
*/
2015-02-24 15:53:38 -06:00
public function store(JournalFormRequest $request, JournalRepositoryInterface $repository)
{
$journalData = [
'what' => $request->get('what'),
'description' => $request->get('description'),
'account_id' => intval($request->get('account_id')),
2015-02-25 14:19:06 -06:00
'account_from_id' => intval($request->get('account_from_id')),
'account_to_id' => intval($request->get('account_to_id')),
2015-02-24 15:53:38 -06:00
'expense_account' => $request->get('expense_account'),
'revenue_account' => $request->get('revenue_account'),
'amount' => floatval($request->get('amount')),
'user' => Auth::user()->id,
'amount_currency_id' => intval($request->get('amount_currency_id')),
'date' => new Carbon($request->get('date')),
'budget_id' => intval($request->get('budget_id')),
'category' => $request->get('category'),
];
$journal = $repository->store($journalData);
2015-03-01 01:34:59 -06:00
event(new JournalSaved($journal));
2015-03-02 13:05:28 -06:00
event(new JournalCreated($journal, intval($request->get('piggy_bank_id'))));
2015-03-01 01:34:59 -06:00
2015-03-10 11:26:31 -05:00
if (intval($request->get('reminder_id')) > 0) {
$reminder = Auth::user()->reminders()->find($request->get('reminder_id'));
2015-03-08 14:20:58 -05:00
$reminder->active = 0;
$reminder->save();
}
2015-02-24 15:53:38 -06:00
Session::flash('success', 'New transaction "' . $journal->description . '" stored!');
2015-03-02 13:05:28 -06:00
2015-03-01 03:44:10 -06:00
if (intval(Input::get('create_another')) === 1) {
return Redirect::route('transactions.create', $request->input('what'))->withInput();
2015-03-01 03:44:10 -06:00
}
2015-02-24 15:53:38 -06:00
return Redirect::route('transactions.index', $request->input('what'));
2015-02-23 14:55:52 -06:00
}
2015-02-27 07:27:04 -06:00
/**
* @param TransactionJournal $journal
*
* @SuppressWarnings("CyclomaticComplexity") // It's exactly 5. So I don't mind.
*
* @return $this
*/
public function update(TransactionJournal $journal, JournalFormRequest $request, JournalRepositoryInterface $repository)
{
2015-03-01 03:44:10 -06:00
2015-02-27 07:27:04 -06:00
$journalData = [
'what' => $request->get('what'),
'description' => $request->get('description'),
'account_id' => intval($request->get('account_id')),
'account_from_id' => intval($request->get('account_from_id')),
'account_to_id' => intval($request->get('account_to_id')),
'expense_account' => $request->get('expense_account'),
'revenue_account' => $request->get('revenue_account'),
'amount' => floatval($request->get('amount')),
'user' => Auth::user()->id,
'amount_currency_id' => intval($request->get('amount_currency_id')),
'date' => new Carbon($request->get('date')),
'budget_id' => intval($request->get('budget_id')),
'category' => $request->get('category'),
];
$repository->update($journal, $journalData);
2015-03-01 01:34:59 -06:00
event(new JournalSaved($journal));
2015-03-02 13:05:28 -06:00
// update, get events by date and sort DESC
2015-03-01 01:34:59 -06:00
2015-02-27 07:27:04 -06:00
Session::flash('success', 'Transaction "' . e($journalData['description']) . '" updated.');
2015-03-01 03:44:10 -06:00
if (intval(Input::get('return_to_edit')) === 1) {
return Redirect::route('transactions.edit', $journal->id);
}
2015-03-26 11:46:08 -05:00
2015-02-27 07:27:04 -06:00
return Redirect::route('transactions.index', $journalData['what']);
}
2015-02-23 14:55:52 -06:00
}