firefly-iii/app/lib/FireflyIII/Database/Budget.php

267 lines
7.1 KiB
PHP
Raw Normal View History

2014-10-29 04:30:52 -05:00
<?php
namespace FireflyIII\Database;
use Carbon\Carbon;
2014-11-12 15:21:48 -06:00
use FireflyIII\Database\Ifaces\BudgetInterface;
use FireflyIII\Database\Ifaces\CommonDatabaseCalls;
use FireflyIII\Database\Ifaces\CUD;
use FireflyIII\Exception\NotImplementedException;
2014-11-12 15:21:48 -06:00
use Illuminate\Support\Collection;
2014-10-29 04:30:52 -05:00
use Illuminate\Support\MessageBag;
use LaravelBook\Ardent\Ardent;
2014-10-29 04:30:52 -05:00
/**
* Class Budget
*
* @package FireflyIII\Database
*/
class Budget implements CUD, CommonDatabaseCalls, BudgetInterface
{
use SwitchUser;
/**
*
*/
public function __construct()
{
$this->setUser(\Auth::user());
}
/**
2014-11-12 15:37:09 -06:00
* @param Ardent $model
2014-10-29 04:30:52 -05:00
*
2014-11-12 15:37:09 -06:00
* @return bool
2014-10-29 04:30:52 -05:00
*/
2014-11-12 15:37:09 -06:00
public function destroy(Ardent $model)
2014-10-29 04:30:52 -05:00
{
2014-11-12 15:37:09 -06:00
$model->delete();
return true;
}
/**
* @param array $data
*
* @return Ardent
*/
public function store(array $data)
{
$data['user_id'] = $this->getUser()->id;
$budget = new \Budget($data);
$budget->class = 'Budget';
if (!$budget->validate()) {
var_dump($budget->errors()->all());
exit;
}
$budget->save();
return $budget;
2014-10-29 04:30:52 -05:00
}
/**
* @param Ardent $model
2014-11-12 15:37:09 -06:00
* @param array $data
2014-10-29 04:30:52 -05:00
*
* @return bool
*/
2014-11-12 15:37:09 -06:00
public function update(Ardent $model, array $data)
2014-10-29 04:30:52 -05:00
{
2014-11-12 15:37:09 -06:00
$model->name = $data['name'];
if (!$model->validate()) {
var_dump($model->errors()->all());
exit;
}
$model->save();
2014-11-06 00:38:15 -06:00
return true;
2014-10-29 04:30:52 -05:00
}
/**
* Validates an array. Returns an array containing MessageBags
* errors/warnings/successes.
*
* @param array $model
*
* @return array
*/
public function validate(array $model)
{
2014-11-12 15:37:09 -06:00
$warnings = new MessageBag;
2014-11-06 00:38:15 -06:00
$successes = new MessageBag;
2014-11-12 15:37:09 -06:00
$errors = new MessageBag;
2014-11-06 00:38:15 -06:00
if (isset($model['name'])) {
if (strlen($model['name']) < 1) {
2014-11-06 00:38:15 -06:00
$errors->add('name', 'Name is too short');
}
if (strlen($model['name']) > 200) {
2014-11-06 00:38:15 -06:00
$errors->add('name', 'Name is too long');
}
} else {
$errors->add('name', 'Name is mandatory');
}
2014-11-06 13:33:37 -06:00
$validator = \Validator::make($model, \Component::$rules);
2014-11-06 00:38:15 -06:00
if ($validator->invalid()) {
2014-11-06 13:33:37 -06:00
$errors->merge($validator->errors());
2014-11-06 00:38:15 -06:00
}
2014-11-06 13:33:37 -06:00
if (!$errors->has('name')) {
$successes->add('name', 'OK');
2014-11-06 00:38:15 -06:00
}
2014-11-12 15:37:09 -06:00
return ['errors' => $errors, 'warnings' => $warnings, 'successes' => $successes];
2014-10-29 04:30:52 -05:00
}
/**
2014-11-12 15:37:09 -06:00
* Validates a model. Returns an array containing MessageBags
* errors/warnings/successes.
2014-10-29 04:30:52 -05:00
*
2014-11-12 15:37:09 -06:00
* @param Ardent $model
2014-10-29 04:30:52 -05:00
*
2014-11-12 15:37:09 -06:00
* @return array
2014-10-29 04:30:52 -05:00
*/
2014-11-12 15:37:09 -06:00
public function validateObject(Ardent $model)
2014-10-29 04:30:52 -05:00
{
2014-11-12 15:37:09 -06:00
// TODO: Implement validateObject() method.
throw new NotImplementedException;
2014-11-04 13:37:00 -06:00
}
/**
2014-11-12 15:37:09 -06:00
* Returns an object with id $id.
*
2014-11-12 15:37:09 -06:00
* @param int $id
*
* @return Ardent
2014-11-04 13:37:00 -06:00
*/
2014-11-12 15:37:09 -06:00
public function find($id)
{
2014-11-14 12:33:50 -06:00
return $this->getUser()->budgets()->find($id);
2014-10-29 04:30:52 -05:00
}
/**
2014-11-12 15:37:09 -06:00
* Finds an account type using one of the "$what"'s: expense, asset, revenue, opening, etc.
2014-10-29 04:30:52 -05:00
*
2014-11-12 15:37:09 -06:00
* @param $what
*
* @return \AccountType|null
2014-10-29 04:30:52 -05:00
*/
2014-11-12 15:37:09 -06:00
public function findByWhat($what)
2014-10-29 04:30:52 -05:00
{
2014-11-12 15:37:09 -06:00
// TODO: Implement findByWhat() method.
throw new NotImplementedException;
2014-10-29 04:30:52 -05:00
}
/**
2014-11-12 15:37:09 -06:00
* Returns all objects.
*
2014-11-12 15:37:09 -06:00
* @return Collection
*/
2014-11-12 15:37:09 -06:00
public function get()
{
2014-11-12 15:37:09 -06:00
$budgets = $this->getUser()->budgets()->get();
2014-11-06 00:38:15 -06:00
2014-11-12 15:37:09 -06:00
return $budgets;
}
2014-11-12 15:21:48 -06:00
/**
2014-11-12 15:37:09 -06:00
* @param array $ids
2014-11-12 15:21:48 -06:00
*
2014-11-12 15:37:09 -06:00
* @return Collection
2014-11-12 15:21:48 -06:00
*/
2014-11-12 15:37:09 -06:00
public function getByIds(array $ids)
2014-11-12 15:21:48 -06:00
{
2014-11-12 15:37:09 -06:00
// TODO: Implement getByIds() method.
2014-11-12 15:21:48 -06:00
throw new NotImplementedException;
}
public function getTransactionJournals(\Budget $budget, $limit = 50)
{
$offset = intval(\Input::get('page')) > 0 ? intval(\Input::get('page')) * $limit : 0;
$set = $budget->transactionJournals()->withRelevantData()->take($limit)->offset($offset)->orderBy('date', 'DESC')->get(['transaction_journals.*']);
$count = $budget->transactionJournals()->count();
$items = [];
foreach ($set as $entry) {
$items[] = $entry;
}
return \Paginator::make($items, $count, $limit);
}
public function getTransactionJournalsInRepetition(\Budget $budget, \LimitRepetition $repetition, $limit = 50)
{
$start = $repetition->startdate;
2014-11-17 00:33:18 -06:00
$end = $repetition->enddate;
$offset = intval(\Input::get('page')) > 0 ? intval(\Input::get('page')) * $limit : 0;
2014-11-17 00:33:18 -06:00
$set = $budget->transactionJournals()->withRelevantData()->before($end)->after($start)->take($limit)->offset($offset)->orderBy('date', 'DESC')->get(
['transaction_journals.*']
);
$count = $budget->transactionJournals()->before($end)->after($start)->count();
$items = [];
foreach ($set as $entry) {
$items[] = $entry;
}
return \Paginator::make($items, $count, $limit);
}
2014-11-12 15:21:48 -06:00
/**
2014-11-12 15:37:09 -06:00
* @param \Budget $budget
* @param Carbon $date
2014-11-12 15:21:48 -06:00
*
2014-11-12 15:37:09 -06:00
* @return \LimitRepetition|null
2014-11-12 15:21:48 -06:00
*/
2014-11-12 15:37:09 -06:00
public function repetitionOnStartingOnDate(\Budget $budget, Carbon $date)
2014-11-12 15:21:48 -06:00
{
2014-11-12 15:37:09 -06:00
return \LimitRepetition::
leftJoin('limits', 'limit_repetitions.limit_id', '=', 'limits.id')->leftJoin(
'components', 'limits.component_id', '=', 'components.id'
)->where('limit_repetitions.startdate', $date->format('Y-m-d'))->where(
'components.id', $budget->id
)->first(['limit_repetitions.*']);
2014-11-12 15:21:48 -06:00
}
/**
2014-11-12 15:37:09 -06:00
* @param Carbon $start
* @param Carbon $end
2014-11-12 15:21:48 -06:00
*
* @return Collection
*/
2014-11-12 15:37:09 -06:00
public function transactionsWithoutBudgetInDateRange(Carbon $start, Carbon $end)
2014-11-12 15:21:48 -06:00
{
2014-11-12 15:37:09 -06:00
// Add expenses that have no budget:
return \Auth::user()->transactionjournals()->whereNotIn(
'transaction_journals.id', function ($query) use ($start, $end) {
$query->select('transaction_journals.id')->from('transaction_journals')->leftJoin(
'component_transaction_journal', 'component_transaction_journal.transaction_journal_id', '=', 'transaction_journals.id'
)->leftJoin('components', 'components.id', '=', 'component_transaction_journal.component_id')->where(
'transaction_journals.date', '>=', $start->format('Y-m-d')
)->where('transaction_journals.date', '<=', $end->format('Y-m-d'))->where('components.class', 'Budget');
2014-11-12 15:37:09 -06:00
}
)->before($end)->after($start)->lessThan(0)->transactionTypes(['Withdrawal'])->get();
2014-11-12 15:21:48 -06:00
}
/**
2014-11-12 15:37:09 -06:00
* @param \Budget $budget
* @param Carbon $date
2014-11-12 15:21:48 -06:00
*
2014-11-12 15:37:09 -06:00
* @return float
2014-11-12 15:21:48 -06:00
*/
2014-11-12 15:37:09 -06:00
public function spentInMonth(\Budget $budget, Carbon $date)
2014-11-12 15:21:48 -06:00
{
2014-11-12 15:37:09 -06:00
$end = clone $date;
$date->startOfMonth();
$end->endOfMonth();
$sum = floatval($budget->transactionjournals()->before($end)->after($date)->lessThan(0)->sum('amount')) * -1;
return $sum;
2014-11-12 15:21:48 -06:00
}
2014-10-29 04:30:52 -05:00
}