firefly-iii/app/Http/Controllers/ReportController.php

270 lines
8.0 KiB
PHP
Raw Normal View History

2015-02-23 13:25:48 -06:00
<?php namespace FireflyIII\Http\Controllers;
use Carbon\Carbon;
use FireflyIII\Helpers\Report\ReportHelperInterface;
use FireflyIII\Helpers\Report\ReportQueryInterface;
use FireflyIII\Models\Account;
2015-03-29 05:25:46 -05:00
use FireflyIII\Models\Preference;
use FireflyIII\Models\TransactionJournal;
use Session;
2015-02-23 13:25:48 -06:00
use Steam;
use View;
2015-02-23 13:25:48 -06:00
/**
* Class ReportController
*
* @package FireflyIII\Http\Controllers
*/
class ReportController extends Controller
{
2015-03-29 05:25:46 -05:00
/** @var ReportHelperInterface */
protected $helper;
/** @var ReportQueryInterface */
protected $query;
2015-02-23 13:25:48 -06:00
/**
2015-03-29 05:25:46 -05:00
* @param ReportHelperInterface $helper
* @param ReportQueryInterface $query
2015-02-23 13:25:48 -06:00
*/
2015-03-29 05:25:46 -05:00
public function __construct(ReportHelperInterface $helper, ReportQueryInterface $query)
2015-02-23 13:25:48 -06:00
{
2015-03-29 05:25:46 -05:00
$this->query = $query;
$this->helper = $helper;
2015-02-23 13:25:48 -06:00
View::share('title', 'Reports');
View::share('mainTitleIcon', 'fa-line-chart');
}
/**
* @return View
2015-05-03 05:58:55 -05:00
* @internal param ReportHelperInterface $helper
*
2015-02-23 13:25:48 -06:00
*/
2015-03-29 05:25:46 -05:00
public function index()
2015-02-23 13:25:48 -06:00
{
2015-03-02 08:27:36 -06:00
$start = Session::get('first');
2015-03-29 05:25:46 -05:00
$months = $this->helper->listOfMonths($start);
2015-02-23 13:25:48 -06:00
$title = 'Reports';
$mainTitleIcon = 'fa-line-chart';
return view('reports.index', compact('months', 'title', 'mainTitleIcon'));
2015-02-23 13:25:48 -06:00
}
/**
* @param Account $account
* @param string $year
* @param string $month
*
* @return \Illuminate\View\View
*/
2015-03-29 05:25:46 -05:00
public function modalBalancedTransfers(Account $account, $year = '2014', $month = '1')
{
$start = new Carbon($year . '-' . $month . '-01');
$end = clone $start;
$end->endOfMonth();
2015-03-29 05:25:46 -05:00
$journals = $this->query->balancedTransactionsList($account, $start, $end);
return view('reports.modal-journal-list', compact('journals'));
}
/**
2015-05-03 05:58:55 -05:00
* @param Account $account
* @param string $year
* @param string $month
*
* @return View
2015-05-03 05:58:55 -05:00
* @internal param ReportQueryInterface $query
*
*/
2015-03-29 05:25:46 -05:00
public function modalLeftUnbalanced(Account $account, $year = '2014', $month = '1')
{
$start = new Carbon($year . '-' . $month . '-01');
$end = clone $start;
$end->endOfMonth();
2015-03-29 05:25:46 -05:00
$set = $this->query->getTransactionsWithoutBudget($account, $start, $end);
$journals = $set->filter(
function (TransactionJournal $journal) {
$count = $journal->transactiongroups()->where('relation', 'balance')->count();
if ($count == 0) {
return $journal;
}
2015-05-03 05:58:55 -05:00
return null;
}
);
return view('reports.modal-journal-list', compact('journals'));
}
/**
* @param Account $account
* @param string $year
* @param string $month
*
* @return \Illuminate\View\View
*/
2015-03-29 05:25:46 -05:00
public function modalNoBudget(Account $account, $year = '2014', $month = '1')
{
$start = new Carbon($year . '-' . $month . '-01');
$end = clone $start;
$end->endOfMonth();
2015-03-29 05:25:46 -05:00
$journals = $this->query->getTransactionsWithoutBudget($account, $start, $end);
return view('reports.modal-journal-list', compact('journals'));
}
2015-02-23 13:25:48 -06:00
/**
* @param string $year
* @param string $month
*
* @return \Illuminate\View\View
*/
2015-05-15 13:38:39 -05:00
public function month($year = '2014', $month = '1', $shared = false)
2015-02-23 13:25:48 -06:00
{
2015-05-15 13:38:39 -05:00
$date = new Carbon($year . '-' . $month . '-01');
$subTitle = 'Report for ' . $date->format('F Y');
$subTitleIcon = 'fa-calendar';
$displaySum = true; // to show sums in report.
$end = clone $date;
$start = clone $date;
if ($shared == 'shared') {
$shared = true;
}
// set start and end.
$start->startOfMonth();
$end->endOfMonth();
// get all income and expenses. it's OK.
2015-05-15 13:38:39 -05:00
$income = $this->query->incomeInPeriod($start, $end, $shared);
$expensesSet = $this->query->journalsByExpenseAccount($start, $end, $shared);
2015-02-23 13:25:48 -06:00
/**
* INCLUDE ORIGINAL BUDGET REPORT HERE:
2015-02-23 13:25:48 -06:00
*/
// should show shared reports?
/** @var Preference $pref */
$accountAmounts = []; // array with sums of spent amounts on each account.
2015-05-15 13:38:39 -05:00
$accounts = $this->query->getAllAccounts($start, $end, $shared); // all accounts and some data.
2015-02-23 13:25:48 -06:00
foreach ($accounts as $account) {
2015-02-23 13:25:48 -06:00
$budgets = $this->query->getBudgetSummary($account, $start, $end);// get budget summary for this account:
$balancedAmount = $this->query->balancedTransactionsSum($account, $start, $end);
$accountAmounts[$account->id] = $balancedAmount;
// balance out the transactions (see transaction groups & tags) ^^
2015-03-31 14:18:22 -05:00
// array with budget information for each account:
$array = [];
// should always hide account
$hide = true;
// loop all budgets
/** @var \FireflyIII\Models\Budget $budget */
foreach ($budgets as $budget) {
$id = intval($budget->id);
$data = $budget->toArray();
$array[$id] = $data;
// no longer hide account if any budget has money in it.
if (floatval($data['queryAmount']) != 0) {
$hide = false;
}
$accountAmounts[$account->id] += $data['queryAmount'];
}
$account->hide = $hide;
$account->budgetInformation = $array;
$account->balancedAmount = $balancedAmount;
}
2015-02-23 13:25:48 -06:00
/**
* END ORIGINAL BUDGET REPORT
2015-02-23 13:25:48 -06:00
*/
2015-02-23 13:25:48 -06:00
/**
* Start getBudgetsForMonth DONE
*/
2015-05-15 13:38:39 -05:00
$budgets = $this->helper->getBudgetsForMonth($date, $shared);
2015-02-23 13:25:48 -06:00
/**
* End getBudgetsForMonth DONE
*/
/**
* Start getCategoriesForMonth DONE
*/
// all categories.
2015-03-29 05:25:46 -05:00
$result = $this->query->journalsByCategory($start, $end);
2015-02-23 13:25:48 -06:00
$categories = Steam::makeArray($result);
2015-03-31 14:18:22 -05:00
2015-02-23 13:25:48 -06:00
// all transfers
2015-05-15 13:38:39 -05:00
if ($shared === false) {
2015-03-29 05:25:46 -05:00
$result = $this->query->sharedExpensesByCategory($start, $end);
$transfers = Steam::makeArray($result);
$merged = Steam::mergeArrays($categories, $transfers);
} else {
$merged = $categories;
}
2015-02-23 13:25:48 -06:00
2015-03-31 14:18:22 -05:00
2015-02-23 13:25:48 -06:00
// sort.
$sorted = Steam::sortNegativeArray($merged);
// limit to $limit:
$categories = Steam::limitArray($sorted, 10);
2015-02-23 13:25:48 -06:00
/**
* End getCategoriesForMonth DONE
*/
// clean up and sort expenses:
$expenses = Steam::makeArray($expensesSet);
$expenses = Steam::sortArray($expenses);
$expenses = Steam::limitArray($expenses, 10);
2015-02-23 13:25:48 -06:00
2015-02-24 15:53:38 -06:00
return view(
2015-02-23 13:25:48 -06:00
'reports.month',
compact(
'income', 'expenses', 'budgets', 'accounts', 'categories',
'date', 'subTitle', 'displaySum', 'subTitleIcon'
)
);
}
/**
* @param $year
*
* @return $this
*/
2015-05-15 13:38:39 -05:00
public function year($year, $shared = false)
2015-02-23 13:25:48 -06:00
{
2015-05-15 13:38:39 -05:00
if ($shared == 'shared') {
$shared = true;
}
$date = new Carbon('01-01-' . $year);
$end = clone $date;
2015-02-23 13:25:48 -06:00
$end->endOfYear();
$title = 'Reports';
$subTitle = $year;
$subTitleIcon = 'fa-bar-chart';
$mainTitleIcon = 'fa-line-chart';
2015-05-15 13:38:39 -05:00
$balances = $this->helper->yearBalanceReport($date, $shared);
$groupedIncomes = $this->query->journalsByRevenueAccount($date, $end, $shared);
$groupedExpenses = $this->query->journalsByExpenseAccount($date, $end, $shared);
2015-02-23 13:25:48 -06:00
2015-02-24 15:53:38 -06:00
return view(
2015-02-23 13:25:48 -06:00
'reports.year', compact('date', 'groupedIncomes', 'groupedExpenses', 'year', 'balances', 'title', 'subTitle', 'subTitleIcon', 'mainTitleIcon')
);
}
}