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

@@ -0,0 +1,58 @@
<?php
namespace Firefly\Storage\Piggybank;
/**
* Class EloquentLimitRepository
*
* @package Firefly\Storage\Limit
*/
class EloquentPiggybankRepository implements PiggybankRepositoryInterface
{
public function count()
{
return \Piggybank::leftJoin('accounts', 'accounts.id', '=', 'piggybanks.account_id')->where(
'accounts.user_id', \Auth::user()->id
)->count();
}
public function find($piggyBankId)
{
return \Piggybank::leftJoin('accounts', 'accounts.id', '=', 'piggybanks.account_id')->where(
'accounts.user_id', \Auth::user()->id
)->where('piggybanks.id', $piggyBankId)->first('piggybanks.*');
}
public function get()
{
return \Piggybank::with('account')->leftJoin('accounts', 'accounts.id', '=', 'piggybanks.account_id')->where(
'accounts.user_id', \Auth::user()->id
)->get(['piggybanks.*']);
}
public function store($data)
{
var_dump($data);
/** @var \Firefly\Storage\Account\AccountRepositoryInterface $accounts */
$accounts = \App::make('Firefly\Storage\Account\AccountRepositoryInterface');
$account = isset($data['account_id']) ? $accounts->find($data['account_id']) : null;
$piggyBank = new \Piggybank;
$piggyBank->account()->associate($account);
$piggyBank->targetdate
= isset($data['targetdate']) && strlen($data['targetdate']) > 0 ? $data['targetdate'] : null;
$piggyBank->name = isset($data['name']) ? $data['name'] : null;
$piggyBank->amount = 0;
$piggyBank->target = floatval($data['target']);
$piggyBank->order = 1;
if ($piggyBank->validate()) {
$piggyBank->save();
}
return $piggyBank;
}
}

View File

@@ -0,0 +1,18 @@
<?php
namespace Firefly\Storage\Piggybank;
/**
* Interface LimitRepositoryInterface
*
* @package Firefly\Storage\Limit
*/
interface PiggybankRepositoryInterface
{
public function find($piggyBankId);
public function count();
public function store($data);
public function get();
}

View File

@@ -26,6 +26,11 @@ class StorageServiceProvider extends ServiceProvider
'Firefly\Storage\Transaction\EloquentTransactionRepository'
);
$this->app->bind(
'Firefly\Storage\Piggybank\PiggybankRepositoryInterface',
'Firefly\Storage\Piggybank\EloquentPiggybankRepository'
);