Work on piggy banks [skip ci]

This commit is contained in:
James Cole
2014-07-31 22:01:52 +02:00
parent 50cfcb8905
commit 706d853b04
12 changed files with 394 additions and 2 deletions

View File

@@ -1,7 +1,30 @@
<?php
class PiggybankController extends BaseController {
use Firefly\Storage\Account\AccountRepositoryInterface as ARI;
use Firefly\Storage\Piggybank\PiggybankRepositoryInterface as PRI;
/**
* Class PiggybankController
*/
class PiggybankController extends BaseController
{
protected $_repository;
protected $_accounts;
public function __construct(PRI $repository, ARI $accounts)
{
$this->_repository = $repository;
$this->_accounts = $accounts;
View::share('menu', 'home');
}
public function create()
{
$accounts = $this->_accounts->getActiveDefaultAsSelectList();
return View::make('piggybanks.create')->with('accounts', $accounts);
}
public function delete()
@@ -18,6 +41,25 @@ class PiggybankController extends BaseController {
public function index()
{
$count = $this->_repository->count();
$piggybanks = $this->_repository->get();
$accounts = [];
// get accounts:
foreach($piggybanks as $piggyBank) {
$account = $piggyBank->account;
$id = $account->id;
if(!isset($accounts[$id])) {
$account->balance = $account->balance();
$account->left = $account->balance;
} else {
$account->left -= $piggyBank->amount;
}
$accounts[$id] = $account;
}
return View::make('piggybanks.index')->with('count', $count)->with('accounts',$accounts)->with('piggybanks',$piggybanks);
}
public function show()
@@ -26,6 +68,15 @@ class PiggybankController extends BaseController {
public function store()
{
$piggyBank = $this->_repository->store(Input::all());
if(!$piggyBank->id) {
Session::flash('error','Could not save piggy bank: ' . $piggyBank->errors()->first());
return Redirect::route('piggybanks.create')->withInput();
} else {
Session::flash('success','New piggy bank created!');
return Redirect::route('piggybanks.index');
}
}
public function update()