2014-07-14 23:58:08 -05:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
|
|
use Firefly\Storage\Account\AccountRepositoryInterface as ARI;
|
2014-07-15 04:04:53 -05:00
|
|
|
use Firefly\Storage\Budget\BudgetRepositoryInterface as Bud;
|
|
|
|
use Firefly\Storage\Category\CategoryRepositoryInterface as Cat;
|
|
|
|
use Firefly\Storage\TransactionJournal\TransactionJournalRepositoryInterface as TJRI;
|
2014-07-14 23:58:08 -05:00
|
|
|
|
2014-07-15 15:16:29 -05:00
|
|
|
/**
|
|
|
|
* Class TransactionController
|
|
|
|
*/
|
2014-07-15 04:04:53 -05:00
|
|
|
class TransactionController extends BaseController
|
|
|
|
{
|
2014-07-14 23:58:08 -05:00
|
|
|
|
2014-07-15 15:16:29 -05:00
|
|
|
protected $_accounts;
|
|
|
|
protected $_budgets;
|
|
|
|
protected $_categories;
|
|
|
|
protected $_journal;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param ARI $accounts
|
|
|
|
* @param Bud $budgets
|
|
|
|
* @param Cat $categories
|
|
|
|
* @param TJRI $journal
|
|
|
|
*/
|
|
|
|
public function __construct(ARI $accounts, Bud $budgets, Cat $categories, TJRI $journal)
|
2014-07-15 04:04:53 -05:00
|
|
|
{
|
2014-07-15 15:16:29 -05:00
|
|
|
$this->_accounts = $accounts;
|
|
|
|
$this->_budgets = $budgets;
|
|
|
|
$this->_categories = $categories;
|
|
|
|
$this->_journal = $journal;
|
2014-07-14 23:58:08 -05:00
|
|
|
|
|
|
|
|
2014-07-15 04:04:53 -05:00
|
|
|
View::share('menu', 'home');
|
2014-07-14 23:58:08 -05:00
|
|
|
}
|
|
|
|
|
2014-07-16 14:11:43 -05:00
|
|
|
public function create($what)
|
2014-07-15 13:58:35 -05:00
|
|
|
{
|
|
|
|
// get accounts with names and id's.
|
2014-07-15 15:16:29 -05:00
|
|
|
$accounts = $this->_accounts->getActiveDefaultAsSelectList();
|
2014-07-15 13:58:35 -05:00
|
|
|
|
2014-07-15 15:16:29 -05:00
|
|
|
$budgets = $this->_budgets->getAsSelectList();
|
2014-07-15 13:58:35 -05:00
|
|
|
|
|
|
|
$budgets[0] = '(no budget)';
|
|
|
|
|
2014-07-25 05:12:08 -05:00
|
|
|
|
|
|
|
|
2014-07-16 14:11:43 -05:00
|
|
|
return View::make('transactions.create')->with('accounts', $accounts)->with('budgets', $budgets)->with(
|
|
|
|
'what', $what
|
|
|
|
);
|
2014-07-15 13:58:35 -05:00
|
|
|
}
|
|
|
|
|
2014-07-16 14:11:43 -05:00
|
|
|
public function store($what)
|
2014-07-15 13:58:35 -05:00
|
|
|
{
|
2014-07-16 14:11:43 -05:00
|
|
|
// $fromAccount and $toAccount are found
|
|
|
|
// depending on the $what
|
|
|
|
|
|
|
|
$fromAccount = null;
|
|
|
|
$toAccount = null;
|
|
|
|
|
|
|
|
switch ($what) {
|
|
|
|
case 'withdrawal':
|
|
|
|
$fromAccount = $this->_accounts->find(intval(Input::get('account_id')));
|
|
|
|
$toAccount = $this->_accounts->createOrFindBeneficiary(Input::get('beneficiary'));
|
|
|
|
break;
|
|
|
|
case 'deposit':
|
|
|
|
$fromAccount = $this->_accounts->createOrFindBeneficiary(Input::get('beneficiary'));
|
|
|
|
$toAccount = $this->_accounts->find(intval(Input::get('account_id')));
|
|
|
|
break;
|
|
|
|
case 'transfer':
|
|
|
|
$fromAccount = $this->_accounts->find(intval(Input::get('account_from_id')));
|
|
|
|
$toAccount = $this->_accounts->find(intval(Input::get('account_to_id')));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
// fall back to cash if necessary:
|
|
|
|
if (is_null($fromAccount)) {
|
|
|
|
$fromAccount = $this->_accounts->getCashAccount();
|
|
|
|
}
|
|
|
|
if (is_null($toAccount)) {
|
|
|
|
$toAccount = $this->_accounts->getCashAccount();
|
2014-07-15 13:58:35 -05:00
|
|
|
}
|
|
|
|
|
2014-07-15 04:04:53 -05:00
|
|
|
// create or find category:
|
2014-07-15 15:16:29 -05:00
|
|
|
$category = $this->_categories->createOrFind(Input::get('category'));
|
2014-07-15 04:04:53 -05:00
|
|
|
|
|
|
|
// find budget:
|
2014-07-15 15:16:29 -05:00
|
|
|
$budget = $this->_budgets->find(intval(Input::get('budget_id')));
|
2014-07-15 04:04:53 -05:00
|
|
|
|
|
|
|
// find amount & description:
|
|
|
|
$description = trim(Input::get('description'));
|
|
|
|
$amount = floatval(Input::get('amount'));
|
|
|
|
$date = new \Carbon\Carbon(Input::get('date'));
|
|
|
|
|
|
|
|
// create journal
|
|
|
|
/** @var \TransactionJournal $journal */
|
2014-07-15 13:58:35 -05:00
|
|
|
try {
|
2014-07-16 14:11:43 -05:00
|
|
|
$journal = $this->_journal->createSimpleJournal($fromAccount, $toAccount, $description, $amount, $date);
|
2014-07-15 13:58:35 -05:00
|
|
|
} catch (\Firefly\Exception\FireflyException $e) {
|
2014-07-16 14:11:43 -05:00
|
|
|
return Redirect::route('transactions.create', $what)->withInput();
|
2014-07-15 13:58:35 -05:00
|
|
|
}
|
2014-07-15 04:04:53 -05:00
|
|
|
|
|
|
|
// attach bud/cat (?)
|
2014-07-15 10:09:59 -05:00
|
|
|
if (!is_null($budget)) {
|
|
|
|
$journal->budgets()->save($budget);
|
|
|
|
}
|
|
|
|
if (!is_null($category)) {
|
|
|
|
$journal->categories()->save($category);
|
|
|
|
}
|
|
|
|
|
|
|
|
Session::flash('success', 'Transaction saved');
|
2014-07-25 05:12:08 -05:00
|
|
|
|
|
|
|
if(Input::get('create') == '1') {
|
|
|
|
return Redirect::route('transactions.create',$what)->withInput();
|
|
|
|
} else {
|
|
|
|
return Redirect::route('index');
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-07-15 13:58:35 -05:00
|
|
|
|
|
|
|
|
2014-07-16 14:11:43 -05:00
|
|
|
}
|
2014-07-15 13:58:35 -05:00
|
|
|
|
2014-07-25 05:12:08 -05:00
|
|
|
public function index()
|
|
|
|
{
|
2014-07-25 00:17:56 -05:00
|
|
|
$transactions = $this->_journal->paginate(25);
|
2014-07-25 05:12:08 -05:00
|
|
|
return View::make('transactions.index')->with('transactions', $transactions);
|
2014-07-25 00:17:56 -05:00
|
|
|
}
|
|
|
|
|
2014-07-16 14:11:43 -05:00
|
|
|
public function show($journalId)
|
|
|
|
{
|
|
|
|
$journal = $this->_journal->find($journalId);
|
|
|
|
if ($journal) {
|
|
|
|
return View::make('transactions.show')->with('journal', $journal);
|
2014-07-15 13:58:35 -05:00
|
|
|
}
|
2014-07-16 14:11:43 -05:00
|
|
|
return View::make('error')->with('message', 'Invalid journal');
|
2014-07-15 13:58:35 -05:00
|
|
|
}
|
|
|
|
|
2014-07-16 14:11:43 -05:00
|
|
|
public function edit($journalId)
|
2014-07-15 13:58:35 -05:00
|
|
|
{
|
2014-07-16 14:11:43 -05:00
|
|
|
$journal = $this->_journal->find($journalId);
|
|
|
|
if ($journal) {
|
|
|
|
$accounts = $this->_accounts->getActiveDefaultAsSelectList();
|
|
|
|
return View::make('transactions.edit')->with('journal', $journal)->with('accounts', $accounts);
|
2014-07-15 13:58:35 -05:00
|
|
|
}
|
2014-07-16 14:11:43 -05:00
|
|
|
return View::make('error')->with('message', 'Invalid journal');
|
2014-07-15 13:58:35 -05:00
|
|
|
}
|
|
|
|
|
2014-07-14 23:58:08 -05:00
|
|
|
}
|