2015-02-23 14:55:52 -06:00
|
|
|
<?php namespace FireflyIII\Http\Controllers;
|
|
|
|
|
2015-02-25 12:32:33 -06:00
|
|
|
use Amount;
|
|
|
|
use Auth;
|
|
|
|
use Carbon\Carbon;
|
|
|
|
use Config;
|
|
|
|
use ExpandedForm;
|
2015-02-23 14:55:52 -06:00
|
|
|
use FireflyIII\Http\Requests;
|
2015-02-25 12:32:33 -06:00
|
|
|
use FireflyIII\Http\Requests\PiggyBankFormRequest;
|
|
|
|
use FireflyIII\Models\Account;
|
|
|
|
use FireflyIII\Models\PiggyBank;
|
2015-03-03 01:46:14 -06:00
|
|
|
use FireflyIII\Models\PiggyBankEvent;
|
2015-02-24 14:10:25 -06:00
|
|
|
use FireflyIII\Repositories\Account\AccountRepositoryInterface;
|
2015-02-25 12:32:33 -06:00
|
|
|
use FireflyIII\Repositories\PiggyBank\PiggyBankRepositoryInterface;
|
2015-02-24 14:10:25 -06:00
|
|
|
use Illuminate\Support\Collection;
|
2015-02-25 12:32:33 -06:00
|
|
|
use Input;
|
|
|
|
use Redirect;
|
|
|
|
use Session;
|
2015-02-24 14:10:25 -06:00
|
|
|
use Steam;
|
2015-02-25 12:32:33 -06:00
|
|
|
use View;
|
2015-02-23 14:55:52 -06:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Class PiggyBankController
|
|
|
|
*
|
|
|
|
* @package FireflyIII\Http\Controllers
|
|
|
|
*/
|
2015-02-25 12:32:33 -06:00
|
|
|
class PiggyBankController extends Controller
|
|
|
|
{
|
2015-02-23 14:55:52 -06:00
|
|
|
|
2015-02-24 14:10:25 -06:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
View::share('title', 'Piggy banks');
|
|
|
|
View::share('mainTitleIcon', 'fa-sort-amount-asc');
|
|
|
|
}
|
|
|
|
|
2015-02-25 12:32:33 -06:00
|
|
|
/**
|
|
|
|
* Add money to piggy bank
|
|
|
|
*
|
|
|
|
* @param PiggyBank $piggyBank
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function add(PiggyBank $piggyBank, AccountRepositoryInterface $repository)
|
|
|
|
{
|
|
|
|
$leftOnAccount = $repository->leftOnAccount($piggyBank->account);
|
|
|
|
$savedSoFar = $piggyBank->currentRelevantRep()->currentamount;
|
|
|
|
$leftToSave = $piggyBank->targetamount - $savedSoFar;
|
|
|
|
$maxAmount = min($leftOnAccount, $leftToSave);
|
|
|
|
|
|
|
|
|
|
|
|
\Log::debug('Now going to view for piggy bank #' . $piggyBank->id . ' (' . $piggyBank->name . ')');
|
|
|
|
|
2015-02-27 04:09:23 -06:00
|
|
|
return view('piggy-banks.add', compact('piggyBank', 'maxAmount'));
|
2015-02-25 12:32:33 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function create()
|
|
|
|
{
|
|
|
|
|
|
|
|
$periods = Config::get('firefly.piggy_bank_periods');
|
2015-03-10 11:26:31 -05:00
|
|
|
$accounts = ExpandedForm::makeSelectList(
|
|
|
|
Auth::user()->accounts()->orderBy('accounts.name', 'ASC')->accountTypeIn(['Default account', 'Asset account'])->get(['accounts.*'])
|
|
|
|
);
|
2015-02-25 12:32:33 -06:00
|
|
|
$subTitle = 'Create new piggy bank';
|
|
|
|
$subTitleIcon = 'fa-plus';
|
|
|
|
|
2015-02-27 04:09:23 -06:00
|
|
|
return view('piggy-banks.create', compact('accounts', 'periods', 'subTitle', 'subTitleIcon'));
|
2015-02-25 12:32:33 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param PiggyBank $piggyBank
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function delete(PiggyBank $piggyBank)
|
|
|
|
{
|
|
|
|
$subTitle = 'Delete "' . e($piggyBank->name) . '"';
|
|
|
|
|
2015-03-01 12:26:30 -06:00
|
|
|
return view('piggy-banks.delete', compact('piggyBank', 'subTitle'));
|
2015-02-25 12:32:33 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param PiggyBank $piggyBank
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
|
|
*/
|
|
|
|
public function destroy(PiggyBank $piggyBank)
|
|
|
|
{
|
|
|
|
|
|
|
|
Session::flash('success', 'Piggy bank "' . e($piggyBank->name) . '" deleted.');
|
2015-03-01 12:26:30 -06:00
|
|
|
$piggyBank->delete();
|
2015-02-25 12:32:33 -06:00
|
|
|
|
2015-03-01 12:26:30 -06:00
|
|
|
return Redirect::route('piggy-banks.index');
|
2015-02-25 12:32:33 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @SuppressWarnings("CyclomaticComplexity") // It's exactly 5. So I don't mind.
|
|
|
|
*
|
|
|
|
* @param PiggyBank $piggyBank
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function edit(PiggyBank $piggyBank)
|
|
|
|
{
|
|
|
|
|
|
|
|
$periods = Config::get('firefly.piggy_bank_periods');
|
2015-03-10 11:26:31 -05:00
|
|
|
$accounts = ExpandedForm::makeSelectList(
|
|
|
|
Auth::user()->accounts()->orderBy('accounts.name', 'ASC')->accountTypeIn(['Default account', 'Asset account'])->get(['accounts.*'])
|
|
|
|
);
|
2015-02-25 12:32:33 -06:00
|
|
|
$subTitle = 'Edit piggy bank "' . e($piggyBank->name) . '"';
|
|
|
|
$subTitleIcon = 'fa-pencil';
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Flash some data to fill the form.
|
|
|
|
*/
|
|
|
|
if (is_null($piggyBank->targetdate) || $piggyBank->targetdate == '') {
|
|
|
|
$targetDate = null;
|
|
|
|
} else {
|
|
|
|
$targetDate = new Carbon($piggyBank->targetdate);
|
|
|
|
$targetDate = $targetDate->format('Y-m-d');
|
|
|
|
}
|
|
|
|
$preFilled = ['name' => $piggyBank->name,
|
|
|
|
'account_id' => $piggyBank->account_id,
|
|
|
|
'targetamount' => $piggyBank->targetamount,
|
|
|
|
'targetdate' => $targetDate,
|
|
|
|
'reminder' => $piggyBank->reminder,
|
2015-03-06 08:26:21 -06:00
|
|
|
'remind_me' => intval($piggyBank->remind_me) == 1 && !is_null($piggyBank->reminder) ? true : false
|
2015-02-25 12:32:33 -06:00
|
|
|
];
|
|
|
|
Session::flash('preFilled', $preFilled);
|
|
|
|
|
2015-02-27 04:09:23 -06:00
|
|
|
return view('piggy-banks.edit', compact('subTitle', 'subTitleIcon', 'piggyBank', 'accounts', 'periods', 'preFilled'));
|
2015-02-25 12:32:33 -06:00
|
|
|
}
|
|
|
|
|
2015-02-24 14:10:25 -06:00
|
|
|
/**
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function index(AccountRepositoryInterface $repository)
|
|
|
|
{
|
|
|
|
/** @var Collection $piggyBanks */
|
2015-03-15 12:00:33 -05:00
|
|
|
$piggyBanks = Auth::user()->piggyBanks()->where('repeats', 0)->orderBy('order', 'ASC')->get();
|
2015-02-24 14:10:25 -06:00
|
|
|
|
|
|
|
$accounts = [];
|
|
|
|
/** @var PiggyBank $piggyBank */
|
|
|
|
foreach ($piggyBanks as $piggyBank) {
|
|
|
|
$piggyBank->savedSoFar = floatval($piggyBank->currentRelevantRep()->currentamount);
|
|
|
|
$piggyBank->percentage = intval($piggyBank->savedSoFar / $piggyBank->targetamount * 100);
|
|
|
|
$piggyBank->leftToSave = $piggyBank->targetamount - $piggyBank->savedSoFar;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Fill account information:
|
|
|
|
*/
|
|
|
|
$account = $piggyBank->account;
|
|
|
|
if (!isset($accounts[$account->id])) {
|
|
|
|
$accounts[$account->id] = [
|
|
|
|
'name' => $account->name,
|
|
|
|
'balance' => Steam::balance($account),
|
|
|
|
'leftForPiggyBanks' => $repository->leftOnAccount($account),
|
|
|
|
'sumOfSaved' => $piggyBank->savedSoFar,
|
|
|
|
'sumOfTargets' => floatval($piggyBank->targetamount),
|
|
|
|
'leftToSave' => $piggyBank->leftToSave
|
|
|
|
];
|
|
|
|
} else {
|
|
|
|
$accounts[$account->id]['sumOfSaved'] += $piggyBank->savedSoFar;
|
|
|
|
$accounts[$account->id]['sumOfTargets'] += floatval($piggyBank->targetamount);
|
|
|
|
$accounts[$account->id]['leftToSave'] += $piggyBank->leftToSave;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-02-24 15:53:38 -06:00
|
|
|
return view('piggy-banks.index', compact('piggyBanks', 'accounts'));
|
2015-02-24 14:10:25 -06:00
|
|
|
}
|
2015-02-23 14:55:52 -06:00
|
|
|
|
2015-03-15 12:00:33 -05:00
|
|
|
/**
|
|
|
|
* Allow user to order piggy banks.
|
|
|
|
*/
|
|
|
|
public function order(PiggyBankRepositoryInterface $repository)
|
|
|
|
{
|
|
|
|
$data = Input::get('order');
|
|
|
|
|
|
|
|
// set all users piggy banks to zero:
|
|
|
|
$repository->reset();
|
|
|
|
|
|
|
|
if (is_array($data)) {
|
|
|
|
foreach ($data as $order => $id) {
|
|
|
|
$repository->setOrder(intval($id), (intval($order) + 1));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-02-25 08:19:14 -06:00
|
|
|
|
2015-02-25 12:32:33 -06:00
|
|
|
/**
|
|
|
|
* POST add money to piggy bank
|
|
|
|
*
|
|
|
|
* @param PiggyBank $piggyBank
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
|
|
*/
|
|
|
|
public function postAdd(PiggyBank $piggyBank, PiggyBankRepositoryInterface $repository, AccountRepositoryInterface $accounts)
|
|
|
|
{
|
|
|
|
$amount = round(floatval(Input::get('amount')), 2);
|
|
|
|
$leftOnAccount = $accounts->leftOnAccount($piggyBank->account);
|
|
|
|
$savedSoFar = $piggyBank->currentRelevantRep()->currentamount;
|
|
|
|
$leftToSave = $piggyBank->targetamount - $savedSoFar;
|
|
|
|
$maxAmount = round(min($leftOnAccount, $leftToSave), 2);
|
|
|
|
|
|
|
|
if ($amount <= $maxAmount) {
|
|
|
|
$repetition = $piggyBank->currentRelevantRep();
|
|
|
|
$repetition->currentamount += $amount;
|
|
|
|
$repetition->save();
|
|
|
|
|
2015-03-03 01:46:14 -06:00
|
|
|
// create event.
|
|
|
|
PiggyBankEvent::create(['date' => Carbon::now(), 'amount' => $amount, 'piggy_bank_id' => $piggyBank->id]);
|
|
|
|
|
2015-02-25 12:32:33 -06:00
|
|
|
/*
|
|
|
|
* Create event!
|
|
|
|
*/
|
|
|
|
//Event::fire('piggy_bank.addMoney', [$piggyBank, $amount]); // new and used.
|
|
|
|
|
|
|
|
Session::flash('success', 'Added ' . Amount::format($amount, false) . ' to "' . e($piggyBank->name) . '".');
|
|
|
|
} else {
|
|
|
|
Session::flash('error', 'Could not add ' . Amount::format($amount, false) . ' to "' . e($piggyBank->name) . '".');
|
|
|
|
}
|
|
|
|
|
|
|
|
return Redirect::route('piggy-banks.index');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param PiggyBank $piggyBank
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
|
|
*/
|
|
|
|
public function postRemove(PiggyBank $piggyBank)
|
|
|
|
{
|
|
|
|
$amount = floatval(Input::get('amount'));
|
|
|
|
|
|
|
|
$savedSoFar = $piggyBank->currentRelevantRep()->currentamount;
|
|
|
|
|
|
|
|
if ($amount <= $savedSoFar) {
|
|
|
|
$repetition = $piggyBank->currentRelevantRep();
|
|
|
|
$repetition->currentamount -= $amount;
|
|
|
|
$repetition->save();
|
|
|
|
|
2015-03-03 01:46:14 -06:00
|
|
|
PiggyBankEvent::create(['date' => Carbon::now(), 'amount' => $amount * -1, 'piggy_bank_id' => $piggyBank->id]);
|
|
|
|
|
2015-02-25 12:32:33 -06:00
|
|
|
/*
|
|
|
|
* Create event!
|
|
|
|
*/
|
|
|
|
//Event::fire('piggy_bank.removeMoney', [$piggyBank, $amount]); // new and used.
|
|
|
|
|
|
|
|
Session::flash('success', 'Removed ' . Amount::format($amount, false) . ' from "' . e($piggyBank->name) . '".');
|
|
|
|
} else {
|
|
|
|
Session::flash('error', 'Could not remove ' . Amount::format($amount, false) . ' from "' . e($piggyBank->name) . '".');
|
|
|
|
}
|
|
|
|
|
|
|
|
return Redirect::route('piggy-banks.index');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param PiggyBank $piggyBank
|
|
|
|
*
|
|
|
|
* @SuppressWarnings("Unused")
|
|
|
|
*
|
|
|
|
* @return \Illuminate\View\View
|
|
|
|
*/
|
|
|
|
public function remove(PiggyBank $piggyBank)
|
|
|
|
{
|
2015-02-27 04:09:23 -06:00
|
|
|
return view('piggy-banks.remove', compact('piggyBank'));
|
2015-02-25 12:32:33 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param PiggyBank $piggyBank
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function show(PiggyBank $piggyBank)
|
|
|
|
{
|
|
|
|
|
|
|
|
$events = $piggyBank->piggyBankEvents()->orderBy('date', 'DESC')->orderBy('id', 'DESC')->get();
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Number of reminders:
|
|
|
|
*/
|
|
|
|
|
|
|
|
$subTitle = e($piggyBank->name);
|
|
|
|
|
2015-02-27 04:09:23 -06:00
|
|
|
return view('piggy-banks.show', compact('piggyBank', 'events', 'subTitle'));
|
2015-02-25 12:32:33 -06:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-03-26 11:45:03 -05:00
|
|
|
* @param PiggyBankFormRequest $request
|
|
|
|
* @param PiggyBankRepositoryInterface $repository
|
2015-02-25 12:32:33 -06:00
|
|
|
*
|
2015-03-26 11:45:03 -05:00
|
|
|
* @return $this|\Illuminate\Http\RedirectResponse
|
2015-02-25 12:32:33 -06:00
|
|
|
*/
|
|
|
|
public function store(PiggyBankFormRequest $request, PiggyBankRepositoryInterface $repository)
|
|
|
|
{
|
|
|
|
$piggyBankData = [
|
|
|
|
'repeats' => false,
|
|
|
|
'name' => $request->get('name'),
|
2015-03-06 08:12:07 -06:00
|
|
|
'startdate' => new Carbon,
|
2015-02-25 12:32:33 -06:00
|
|
|
'account_id' => intval($request->get('account_id')),
|
|
|
|
'targetamount' => floatval($request->get('targetamount')),
|
|
|
|
'targetdate' => strlen($request->get('targetdate')) > 0 ? new Carbon($request->get('targetdate')) : null,
|
|
|
|
'reminder' => $request->get('reminder'),
|
2015-03-06 08:12:07 -06:00
|
|
|
'remind_me' => $request->get('remind_me'),
|
2015-02-25 12:32:33 -06:00
|
|
|
];
|
|
|
|
|
|
|
|
$piggyBank = $repository->store($piggyBankData);
|
|
|
|
|
|
|
|
Session::flash('success', 'Stored piggy bank "' . e($piggyBank->name) . '".');
|
|
|
|
|
2015-03-06 08:12:07 -06:00
|
|
|
if (intval(Input::get('create_another')) === 1) {
|
|
|
|
return Redirect::route('piggy-banks.create')->withInput();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-02-25 12:32:33 -06:00
|
|
|
return Redirect::route('piggy-banks.index');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param PiggyBank $piggyBank
|
|
|
|
*
|
|
|
|
* @SuppressWarnings("CyclomaticComplexity") // It's exactly 5. So I don't mind.
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function update(PiggyBank $piggyBank, PiggyBankRepositoryInterface $repository, PiggyBankFormRequest $request)
|
|
|
|
{
|
|
|
|
$piggyBankData = [
|
|
|
|
'repeats' => false,
|
|
|
|
'name' => $request->get('name'),
|
2015-03-06 08:12:07 -06:00
|
|
|
'startdate' => is_null($piggyBank->startdate) ? $piggyBank->created_at : $piggyBank->startdate,
|
2015-02-25 12:32:33 -06:00
|
|
|
'account_id' => intval($request->get('account_id')),
|
|
|
|
'targetamount' => floatval($request->get('targetamount')),
|
|
|
|
'targetdate' => strlen($request->get('targetdate')) > 0 ? new Carbon($request->get('targetdate')) : null,
|
|
|
|
'reminder' => $request->get('reminder'),
|
2015-03-06 08:21:44 -06:00
|
|
|
'remind_me' => $request->get('remind_me')
|
2015-02-25 12:32:33 -06:00
|
|
|
];
|
|
|
|
|
2015-03-06 08:24:36 -06:00
|
|
|
|
2015-02-25 12:32:33 -06:00
|
|
|
$piggyBank = $repository->update($piggyBank, $piggyBankData);
|
|
|
|
|
|
|
|
Session::flash('success', 'Updated piggy bank "' . e($piggyBank->name) . '".');
|
|
|
|
|
2015-03-06 08:12:07 -06:00
|
|
|
if (intval(Input::get('return_to_edit')) === 1) {
|
|
|
|
return Redirect::route('piggy-banks.edit', $piggyBank->id);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-02-25 12:32:33 -06:00
|
|
|
return Redirect::route('piggy-banks.index');
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-02-23 14:55:52 -06:00
|
|
|
}
|