2015-02-24 15:53:38 -06:00
|
|
|
<?php namespace FireflyIII\Http\Controllers;
|
|
|
|
|
2015-03-06 01:20:27 -06:00
|
|
|
use Amount;
|
2015-04-09 14:36:58 -05:00
|
|
|
use Carbon\Carbon;
|
2016-01-14 09:41:15 -06:00
|
|
|
use Config;
|
2015-04-09 14:27:35 -05:00
|
|
|
use FireflyIII\Helpers\Report\ReportQueryInterface;
|
2015-12-30 01:00:52 -06:00
|
|
|
use FireflyIII\Repositories\Account\AccountRepositoryInterface as ARI;
|
2015-03-06 01:20:27 -06:00
|
|
|
use FireflyIII\Repositories\Bill\BillRepositoryInterface;
|
2015-12-29 15:48:55 -06:00
|
|
|
use FireflyIII\Repositories\Category\CategoryRepositoryInterface as CRI;
|
2015-04-11 12:59:41 -05:00
|
|
|
use FireflyIII\Repositories\Journal\JournalRepositoryInterface;
|
2015-04-28 03:36:13 -05:00
|
|
|
use FireflyIII\Repositories\Tag\TagRepositoryInterface;
|
2015-06-03 11:22:47 -05:00
|
|
|
use FireflyIII\Support\CacheProperties;
|
2016-01-14 09:41:15 -06:00
|
|
|
use Input;
|
2015-07-12 05:45:41 -05:00
|
|
|
use Preferences;
|
2015-02-24 15:53:38 -06:00
|
|
|
use Response;
|
2015-03-29 00:51:56 -05:00
|
|
|
|
2015-02-24 15:53:38 -06:00
|
|
|
/**
|
|
|
|
* Class JsonController
|
|
|
|
*
|
|
|
|
* @package FireflyIII\Http\Controllers
|
|
|
|
*/
|
2015-03-06 01:20:27 -06:00
|
|
|
class JsonController extends Controller
|
|
|
|
{
|
2016-01-09 01:20:55 -06:00
|
|
|
/**
|
|
|
|
* JsonController constructor.
|
|
|
|
*/
|
2016-01-08 11:29:47 -06:00
|
|
|
public function __construct()
|
|
|
|
{
|
2016-01-08 13:40:48 -06:00
|
|
|
parent::__construct();
|
2016-01-08 11:29:47 -06:00
|
|
|
}
|
2015-03-06 01:20:27 -06:00
|
|
|
|
2016-01-14 09:41:15 -06:00
|
|
|
/**
|
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
2016-01-24 09:12:59 -06:00
|
|
|
public function action()
|
2016-01-14 09:41:15 -06:00
|
|
|
{
|
|
|
|
$count = intval(Input::get('count')) > 0 ? intval(Input::get('count')) : 1;
|
|
|
|
$keys = array_keys(Config::get('firefly.rule-actions'));
|
|
|
|
$actions = [];
|
|
|
|
foreach ($keys as $key) {
|
|
|
|
$actions[$key] = trans('firefly.rule_action_' . $key . '_choice');
|
|
|
|
}
|
2016-01-24 09:12:59 -06:00
|
|
|
$view = view('rules.partials.action', compact('actions', 'count'))->render();
|
2016-01-14 09:41:15 -06:00
|
|
|
|
|
|
|
|
|
|
|
return Response::json(['html' => $view]);
|
|
|
|
}
|
|
|
|
|
2015-03-06 01:20:27 -06:00
|
|
|
/**
|
2015-12-29 15:48:55 -06:00
|
|
|
* @param BillRepositoryInterface $repository
|
2015-05-03 05:58:55 -05:00
|
|
|
*
|
2015-04-11 00:24:07 -05:00
|
|
|
* @return \Symfony\Component\HttpFoundation\Response
|
2015-03-06 01:20:27 -06:00
|
|
|
*/
|
2015-12-28 01:00:42 -06:00
|
|
|
public function boxBillsPaid(BillRepositoryInterface $repository)
|
2015-03-06 01:20:27 -06:00
|
|
|
{
|
2016-02-04 00:27:03 -06:00
|
|
|
$start = session('start', Carbon::now()->startOfMonth());
|
|
|
|
$end = session('end', Carbon::now()->endOfMonth());
|
2015-07-06 11:04:13 -05:00
|
|
|
bcscale(2);
|
2015-06-02 11:05:42 -05:00
|
|
|
|
2015-12-27 10:29:41 -06:00
|
|
|
/*
|
|
|
|
* Since both this method and the chart use the exact same data, we can suffice
|
|
|
|
* with calling the one method in the bill repository that will get this amount.
|
|
|
|
*/
|
|
|
|
$amount = $repository->getBillsPaidInRange($start, $end); // will be a negative amount.
|
|
|
|
$creditCardDue = $repository->getCreditCardBill($start, $end);
|
|
|
|
if ($creditCardDue >= 0) {
|
|
|
|
$amount = bcadd($amount, $creditCardDue);
|
2015-04-11 00:24:07 -05:00
|
|
|
}
|
2016-02-05 08:41:40 -06:00
|
|
|
$amount = bcmul($amount, '-1');
|
2015-12-27 10:29:41 -06:00
|
|
|
|
2015-06-02 11:05:42 -05:00
|
|
|
$data = ['box' => 'bills-paid', 'amount' => Amount::format($amount, false), 'amount_raw' => $amount];
|
2015-06-03 14:25:11 -05:00
|
|
|
|
2015-06-02 11:05:42 -05:00
|
|
|
return Response::json($data);
|
2015-04-11 00:24:07 -05:00
|
|
|
}
|
2015-04-03 16:10:51 -05:00
|
|
|
|
2015-04-11 00:24:07 -05:00
|
|
|
/**
|
2015-12-28 00:55:09 -06:00
|
|
|
* @param BillRepositoryInterface $repository
|
2015-04-11 00:24:07 -05:00
|
|
|
*
|
2015-12-28 01:00:42 -06:00
|
|
|
* @return \Illuminate\Http\JsonResponse
|
2015-04-11 00:24:07 -05:00
|
|
|
*/
|
2015-12-27 10:29:41 -06:00
|
|
|
public function boxBillsUnpaid(BillRepositoryInterface $repository)
|
2015-04-11 00:24:07 -05:00
|
|
|
{
|
2015-07-06 11:04:13 -05:00
|
|
|
bcscale(2);
|
2016-02-04 00:27:03 -06:00
|
|
|
$start = session('start', Carbon::now()->startOfMonth());
|
|
|
|
$end = session('end', Carbon::now()->endOfMonth());
|
2015-12-27 10:29:41 -06:00
|
|
|
$amount = $repository->getBillsUnpaidInRange($start, $end); // will be a positive amount.
|
|
|
|
$creditCardDue = $repository->getCreditCardBill($start, $end);
|
|
|
|
|
|
|
|
if ($creditCardDue < 0) {
|
|
|
|
// expenses are negative (bill not yet paid),
|
|
|
|
$creditCardDue = bcmul($creditCardDue, '-1');
|
|
|
|
$amount = bcadd($amount, $creditCardDue);
|
2015-04-11 00:24:07 -05:00
|
|
|
}
|
|
|
|
|
2015-06-02 11:05:42 -05:00
|
|
|
$data = ['box' => 'bills-unpaid', 'amount' => Amount::format($amount, false), 'amount_raw' => $amount];
|
|
|
|
|
|
|
|
return Response::json($data);
|
2015-04-11 00:24:07 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-01-01 04:32:08 -06:00
|
|
|
* @param ReportQueryInterface $reportQuery
|
2015-12-28 00:55:09 -06:00
|
|
|
*
|
2016-01-01 04:32:08 -06:00
|
|
|
* @param ARI $accountRepository
|
2015-04-11 00:24:07 -05:00
|
|
|
*
|
|
|
|
* @return \Symfony\Component\HttpFoundation\Response
|
|
|
|
*/
|
2015-12-30 01:00:52 -06:00
|
|
|
public function boxIn(ReportQueryInterface $reportQuery, ARI $accountRepository)
|
2015-04-11 00:24:07 -05:00
|
|
|
{
|
2016-02-04 00:27:03 -06:00
|
|
|
$start = session('start', Carbon::now()->startOfMonth());
|
|
|
|
$end = session('end', Carbon::now()->endOfMonth());
|
2015-06-02 11:05:42 -05:00
|
|
|
|
|
|
|
// works for json too!
|
2015-06-03 14:25:11 -05:00
|
|
|
$cache = new CacheProperties;
|
|
|
|
$cache->addProperty($start);
|
|
|
|
$cache->addProperty($end);
|
|
|
|
$cache->addProperty('box-in');
|
|
|
|
if ($cache->has()) {
|
2015-06-04 14:35:36 -05:00
|
|
|
return Response::json($cache->get()); // @codeCoverageIgnore
|
2015-06-02 11:05:42 -05:00
|
|
|
}
|
2015-12-13 02:35:58 -06:00
|
|
|
$accounts = $accountRepository->getAccounts(['Default account', 'Asset account', 'Cash account']);
|
2016-01-01 04:32:08 -06:00
|
|
|
$amount = $reportQuery->income($accounts, $start, $end)->sum('journalAmount');
|
2015-04-11 00:24:07 -05:00
|
|
|
|
2015-06-02 11:05:42 -05:00
|
|
|
$data = ['box' => 'in', 'amount' => Amount::format($amount, false), 'amount_raw' => $amount];
|
2015-06-03 14:25:11 -05:00
|
|
|
$cache->store($data);
|
2015-06-02 11:05:42 -05:00
|
|
|
|
|
|
|
return Response::json($data);
|
2015-04-11 00:24:07 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-01-01 04:32:08 -06:00
|
|
|
* @param ReportQueryInterface $reportQuery
|
2015-12-28 00:55:09 -06:00
|
|
|
*
|
2016-01-01 04:32:08 -06:00
|
|
|
* @param ARI $accountRepository
|
2015-04-11 00:24:07 -05:00
|
|
|
*
|
|
|
|
* @return \Symfony\Component\HttpFoundation\Response
|
|
|
|
*/
|
2015-12-30 01:00:52 -06:00
|
|
|
public function boxOut(ReportQueryInterface $reportQuery, ARI $accountRepository)
|
2015-04-11 00:24:07 -05:00
|
|
|
{
|
2016-02-04 00:27:03 -06:00
|
|
|
$start = session('start', Carbon::now()->startOfMonth());
|
|
|
|
$end = session('end', Carbon::now()->endOfMonth());
|
2015-06-02 11:05:42 -05:00
|
|
|
|
2015-12-13 02:35:58 -06:00
|
|
|
$accounts = $accountRepository->getAccounts(['Default account', 'Asset account', 'Cash account']);
|
2015-06-02 11:05:42 -05:00
|
|
|
|
|
|
|
// works for json too!
|
2015-06-03 14:25:11 -05:00
|
|
|
$cache = new CacheProperties;
|
|
|
|
$cache->addProperty($start);
|
|
|
|
$cache->addProperty($end);
|
|
|
|
$cache->addProperty('box-out');
|
|
|
|
if ($cache->has()) {
|
2015-06-04 14:35:36 -05:00
|
|
|
return Response::json($cache->get()); // @codeCoverageIgnore
|
2015-06-02 11:05:42 -05:00
|
|
|
}
|
|
|
|
|
2016-01-01 04:32:08 -06:00
|
|
|
$amount = $reportQuery->expense($accounts, $start, $end)->sum('journalAmount');
|
2015-04-10 00:19:45 -05:00
|
|
|
|
2015-06-02 11:05:42 -05:00
|
|
|
$data = ['box' => 'out', 'amount' => Amount::format($amount, false), 'amount_raw' => $amount];
|
2015-06-03 14:25:11 -05:00
|
|
|
$cache->store($data);
|
2015-06-02 11:05:42 -05:00
|
|
|
|
|
|
|
return Response::json($data);
|
2015-03-06 01:20:27 -06:00
|
|
|
}
|
2015-02-24 15:53:38 -06:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a list of categories.
|
|
|
|
*
|
2015-12-29 15:48:55 -06:00
|
|
|
* @param CRI $repository
|
2015-05-03 05:58:55 -05:00
|
|
|
*
|
2015-02-24 15:53:38 -06:00
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
2015-12-29 15:48:55 -06:00
|
|
|
public function categories(CRI $repository)
|
2015-02-24 15:53:38 -06:00
|
|
|
{
|
2015-12-30 01:21:11 -06:00
|
|
|
$list = $repository->listCategories();
|
2015-03-06 01:20:27 -06:00
|
|
|
$return = [];
|
2015-02-24 15:53:38 -06:00
|
|
|
foreach ($list as $entry) {
|
|
|
|
$return[] = $entry->name;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Response::json($return);
|
|
|
|
}
|
|
|
|
|
2016-01-24 08:58:16 -06:00
|
|
|
/**
|
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
|
|
|
public function endTour()
|
|
|
|
{
|
|
|
|
Preferences::set('tour', false);
|
|
|
|
|
|
|
|
return Response::json('true');
|
|
|
|
}
|
|
|
|
|
2015-02-24 15:53:38 -06:00
|
|
|
/**
|
|
|
|
* Returns a JSON list of all beneficiaries.
|
|
|
|
*
|
2015-12-30 01:00:52 -06:00
|
|
|
* @param ARI $accountRepository
|
2015-05-03 05:58:55 -05:00
|
|
|
*
|
2015-02-24 15:53:38 -06:00
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
2015-12-30 01:00:52 -06:00
|
|
|
public function expenseAccounts(ARI $accountRepository)
|
2015-02-24 15:53:38 -06:00
|
|
|
{
|
2015-04-11 12:59:41 -05:00
|
|
|
$list = $accountRepository->getAccounts(['Expense account', 'Beneficiary account']);
|
2015-03-06 01:20:27 -06:00
|
|
|
$return = [];
|
2015-02-24 15:53:38 -06:00
|
|
|
foreach ($list as $entry) {
|
|
|
|
$return[] = $entry->name;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Response::json($return);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-12-30 01:00:52 -06:00
|
|
|
* @param ARI $accountRepository
|
2015-05-03 05:58:55 -05:00
|
|
|
*
|
2015-02-24 15:53:38 -06:00
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
2015-12-30 01:00:52 -06:00
|
|
|
public function revenueAccounts(ARI $accountRepository)
|
2015-02-24 15:53:38 -06:00
|
|
|
{
|
2015-04-11 12:59:41 -05:00
|
|
|
$list = $accountRepository->getAccounts(['Revenue account']);
|
2015-03-06 01:20:27 -06:00
|
|
|
$return = [];
|
2015-02-24 15:53:38 -06:00
|
|
|
foreach ($list as $entry) {
|
|
|
|
$return[] = $entry->name;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Response::json($return);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2015-05-05 05:57:27 -05:00
|
|
|
/**
|
|
|
|
* Returns a JSON list of all beneficiaries.
|
|
|
|
*
|
|
|
|
* @param TagRepositoryInterface $tagRepository
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
|
|
|
public function tags(TagRepositoryInterface $tagRepository)
|
|
|
|
{
|
|
|
|
$list = $tagRepository->get();
|
|
|
|
$return = [];
|
|
|
|
foreach ($list as $entry) {
|
|
|
|
$return[] = $entry->tag;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Response::json($return);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-01-24 08:58:16 -06:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function tour()
|
|
|
|
{
|
|
|
|
$pref = Preferences::get('tour', true);
|
|
|
|
if (!$pref) {
|
|
|
|
abort(404);
|
|
|
|
}
|
|
|
|
$headers = ['main-content', 'sidebar-toggle', 'account-menu', 'budget-menu', 'report-menu', 'transaction-menu', 'option-menu', 'main-content-end'];
|
|
|
|
$steps = [];
|
|
|
|
foreach ($headers as $header) {
|
|
|
|
$steps[] = [
|
|
|
|
'element' => '#' . $header,
|
|
|
|
'title' => trans('help.' . $header . '-title'),
|
|
|
|
'content' => trans('help.' . $header . '-text'),
|
|
|
|
];
|
|
|
|
}
|
|
|
|
$steps[0]['orphan'] = true;// orphan and backdrop for first element.
|
|
|
|
$steps[0]['backdrop'] = true;
|
|
|
|
$steps[1]['placement'] = 'left';// sidebar position left:
|
|
|
|
$steps[7]['orphan'] = true; // final in the center again.
|
|
|
|
$steps[7]['backdrop'] = true;
|
|
|
|
$template = view('json.tour')->render();
|
|
|
|
|
|
|
|
return Response::json(['steps' => $steps, 'template' => $template]);
|
|
|
|
}
|
|
|
|
|
2015-04-07 11:25:21 -05:00
|
|
|
/**
|
2015-05-03 05:54:39 -05:00
|
|
|
* @param JournalRepositoryInterface $repository
|
|
|
|
* @param $what
|
2015-04-07 11:25:21 -05:00
|
|
|
*
|
|
|
|
* @return \Symfony\Component\HttpFoundation\Response
|
|
|
|
*/
|
2015-05-03 05:54:39 -05:00
|
|
|
public function transactionJournals(JournalRepositoryInterface $repository, $what)
|
2015-03-27 07:16:14 -05:00
|
|
|
{
|
|
|
|
$descriptions = [];
|
2015-04-11 12:59:41 -05:00
|
|
|
$dbType = $repository->getTransactionType($what);
|
|
|
|
|
|
|
|
$journals = $repository->getJournalsOfType($dbType);
|
2015-03-29 00:51:56 -05:00
|
|
|
foreach ($journals as $j) {
|
|
|
|
$descriptions[] = $j->description;
|
|
|
|
}
|
2015-03-27 07:16:14 -05:00
|
|
|
|
|
|
|
$descriptions = array_unique($descriptions);
|
2015-03-27 07:25:46 -05:00
|
|
|
sort($descriptions);
|
2015-03-29 00:51:56 -05:00
|
|
|
|
2015-03-27 07:16:14 -05:00
|
|
|
return Response::json($descriptions);
|
2015-03-10 11:26:31 -05:00
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-01-24 08:58:16 -06:00
|
|
|
/**
|
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
2016-01-24 09:12:59 -06:00
|
|
|
public function trigger()
|
2016-01-24 08:58:16 -06:00
|
|
|
{
|
|
|
|
$count = intval(Input::get('count')) > 0 ? intval(Input::get('count')) : 1;
|
|
|
|
$keys = array_keys(Config::get('firefly.rule-triggers'));
|
|
|
|
$triggers = [];
|
|
|
|
foreach ($keys as $key) {
|
|
|
|
if ($key != 'user_action') {
|
|
|
|
$triggers[$key] = trans('firefly.rule_trigger_' . $key . '_choice');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-24 09:12:59 -06:00
|
|
|
$view = view('rules.partials.trigger', compact('triggers', 'count'))->render();
|
2016-01-24 08:58:16 -06:00
|
|
|
|
|
|
|
|
|
|
|
return Response::json(['html' => $view]);
|
|
|
|
}
|
|
|
|
|
2015-02-24 15:53:38 -06:00
|
|
|
}
|