mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-25 21:16:47 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			328 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			328 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php namespace FireflyIII\Http\Controllers;
 | |
| 
 | |
| use Amount;
 | |
| use Carbon\Carbon;
 | |
| use FireflyIII\Helpers\Report\ReportQueryInterface;
 | |
| use FireflyIII\Models\Account;
 | |
| use FireflyIII\Models\Bill;
 | |
| use FireflyIII\Repositories\Account\AccountRepositoryInterface;
 | |
| use FireflyIII\Repositories\Bill\BillRepositoryInterface;
 | |
| use FireflyIII\Repositories\Category\CategoryRepositoryInterface;
 | |
| use FireflyIII\Repositories\Journal\JournalRepositoryInterface;
 | |
| use FireflyIII\Repositories\Tag\TagRepositoryInterface;
 | |
| use FireflyIII\Support\CacheProperties;
 | |
| use Illuminate\Support\Collection;
 | |
| use Preferences;
 | |
| use Response;
 | |
| use Session;
 | |
| use Steam;
 | |
| 
 | |
| /**
 | |
|  * Class JsonController
 | |
|  *
 | |
|  * @package FireflyIII\Http\Controllers
 | |
|  */
 | |
| class JsonController extends Controller
 | |
| {
 | |
| 
 | |
|     /**
 | |
|      * @return \Illuminate\Http\JsonResponse
 | |
|      */
 | |
|     public function endTour()
 | |
|     {
 | |
|         Preferences::set('tour', false);
 | |
| 
 | |
|         return Response::json('true');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      *
 | |
|      */
 | |
|     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]);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param BillRepositoryInterface    $repository
 | |
|      *
 | |
|      * @param AccountRepositoryInterface $accountRepository
 | |
|      *
 | |
|      * @return \Symfony\Component\HttpFoundation\Response
 | |
|      */
 | |
|     public function boxBillsPaid(BillRepositoryInterface $repository, AccountRepositoryInterface $accountRepository)
 | |
|     {
 | |
|         $start  = Session::get('start', Carbon::now()->startOfMonth());
 | |
|         $end    = Session::get('end', Carbon::now()->endOfMonth());
 | |
|         $amount = 0;
 | |
|         bcscale(2);
 | |
| 
 | |
|         // works for json too!
 | |
|         $cache = new CacheProperties;
 | |
|         $cache->addProperty($start);
 | |
|         $cache->addProperty($end);
 | |
|         $cache->addProperty('box-bills-paid');
 | |
|         if ($cache->has()) {
 | |
|             return Response::json($cache->get()); // @codeCoverageIgnore
 | |
|         }
 | |
|         $bills = $repository->getActiveBills(); // these two functions are the same as the chart
 | |
| 
 | |
|         /** @var Bill $bill */
 | |
|         foreach ($bills as $bill) {
 | |
|             $amount = bcadd($amount, $repository->billPaymentsInRange($bill, $start, $end));
 | |
|         }
 | |
|         unset($bill, $bills);
 | |
| 
 | |
|         $creditCards = $accountRepository->getCreditCards(); // Find credit card accounts and possibly unpaid credit card bills.
 | |
|         /** @var Account $creditCard */
 | |
|         foreach ($creditCards as $creditCard) {
 | |
|             $balance = Steam::balance($creditCard, $end, true); // if the balance is not zero, the monthly payment is still underway.
 | |
|             if ($balance == 0) {
 | |
|                 // find a transfer TO the credit card which should account for
 | |
|                 // anything paid. If not, the CC is not yet used.
 | |
|                 $amount = bcadd($amount, $accountRepository->getTransfersInRange($creditCard, $start, $end)->sum('amount'));
 | |
|             }
 | |
|         }
 | |
|         $data = ['box' => 'bills-paid', 'amount' => Amount::format($amount, false), 'amount_raw' => $amount];
 | |
|         $cache->store($data);
 | |
| 
 | |
|         return Response::json($data);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param BillRepositoryInterface    $repository
 | |
|      * @param AccountRepositoryInterface $accountRepository
 | |
|      *
 | |
|      * @return \Symfony\Component\HttpFoundation\Response
 | |
|      */
 | |
|     public function boxBillsUnpaid(BillRepositoryInterface $repository, AccountRepositoryInterface $accountRepository)
 | |
|     {
 | |
|         $amount = 0;
 | |
|         $start  = Session::get('start', Carbon::now()->startOfMonth());
 | |
|         $end    = Session::get('end', Carbon::now()->endOfMonth());
 | |
|         bcscale(2);
 | |
| 
 | |
|         // works for json too!
 | |
|         $cache = new CacheProperties;
 | |
|         $cache->addProperty($start);
 | |
|         $cache->addProperty($end);
 | |
|         $cache->addProperty('box-bills-unpaid');
 | |
|         if ($cache->has()) {
 | |
|             return Response::json($cache->get()); // @codeCoverageIgnore
 | |
|         }
 | |
| 
 | |
|         $bills  = $repository->getActiveBills();
 | |
|         $unpaid = new Collection; // bills
 | |
| 
 | |
|         /** @var Bill $bill */
 | |
|         foreach ($bills as $bill) {
 | |
|             $ranges = $repository->getRanges($bill, $start, $end);
 | |
| 
 | |
|             foreach ($ranges as $range) {
 | |
|                 $journals = $repository->getJournalsInRange($bill, $range['start'], $range['end']);
 | |
|                 if ($journals->count() == 0) {
 | |
|                     $unpaid->push([$bill, $range['start']]);
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|         unset($bill, $bills, $range, $ranges);
 | |
| 
 | |
|         $creditCards = $accountRepository->getCreditCards();
 | |
|         foreach ($creditCards as $creditCard) {
 | |
|             $balance = Steam::balance($creditCard, $end, true);
 | |
|             $date    = new Carbon($creditCard->getMeta('ccMonthlyPaymentDate'));
 | |
|             if ($balance < 0) {
 | |
|                 // unpaid! create a fake bill that matches the amount.
 | |
|                 $description = $creditCard->name;
 | |
|                 $fakeAmount  = $balance * -1;
 | |
|                 $fakeBill    = $repository->createFakeBill($description, $date, $fakeAmount);
 | |
|                 $unpaid->push([$fakeBill, $date]);
 | |
|             }
 | |
|         }
 | |
|         /** @var Bill $entry */
 | |
|         foreach ($unpaid as $entry) {
 | |
|             $current = ($entry[0]->amount_max + $entry[0]->amount_min) / 2;
 | |
|             $amount  = bcadd($amount, $current);
 | |
|         }
 | |
| 
 | |
|         $data = ['box' => 'bills-unpaid', 'amount' => Amount::format($amount, false), 'amount_raw' => $amount];
 | |
|         $cache->store($data);
 | |
| 
 | |
|         return Response::json($data);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param ReportQueryInterface $reportQuery
 | |
|      *
 | |
|      * @return \Symfony\Component\HttpFoundation\Response
 | |
|      */
 | |
|     public function boxIn(ReportQueryInterface $reportQuery)
 | |
|     {
 | |
|         $start = Session::get('start', Carbon::now()->startOfMonth());
 | |
|         $end   = Session::get('end', Carbon::now()->endOfMonth());
 | |
| 
 | |
|         // works for json too!
 | |
|         $cache = new CacheProperties;
 | |
|         $cache->addProperty($start);
 | |
|         $cache->addProperty($end);
 | |
|         $cache->addProperty('box-in');
 | |
|         if ($cache->has()) {
 | |
|             return Response::json($cache->get()); // @codeCoverageIgnore
 | |
|         }
 | |
| 
 | |
|         $amount = $reportQuery->incomeInPeriodCorrected($start, $end, true)->sum('amount');
 | |
| 
 | |
|         $data = ['box' => 'in', 'amount' => Amount::format($amount, false), 'amount_raw' => $amount];
 | |
|         $cache->store($data);
 | |
| 
 | |
|         return Response::json($data);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param ReportQueryInterface $reportQuery
 | |
|      *
 | |
|      * @return \Symfony\Component\HttpFoundation\Response
 | |
|      */
 | |
|     public function boxOut(ReportQueryInterface $reportQuery)
 | |
|     {
 | |
|         $start = Session::get('start', Carbon::now()->startOfMonth());
 | |
|         $end   = Session::get('end', Carbon::now()->endOfMonth());
 | |
| 
 | |
| 
 | |
|         // works for json too!
 | |
|         $cache = new CacheProperties;
 | |
|         $cache->addProperty($start);
 | |
|         $cache->addProperty($end);
 | |
|         $cache->addProperty('box-out');
 | |
|         if ($cache->has()) {
 | |
|             return Response::json($cache->get()); // @codeCoverageIgnore
 | |
|         }
 | |
| 
 | |
|         $amount = $reportQuery->expenseInPeriodCorrected($start, $end, true)->sum('amount');
 | |
| 
 | |
|         $data = ['box' => 'out', 'amount' => Amount::format($amount, false), 'amount_raw' => $amount];
 | |
|         $cache->store($data);
 | |
| 
 | |
|         return Response::json($data);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Returns a list of categories.
 | |
|      *
 | |
|      * @param CategoryRepositoryInterface $repository
 | |
|      *
 | |
|      * @return \Illuminate\Http\JsonResponse
 | |
|      */
 | |
|     public function categories(CategoryRepositoryInterface $repository)
 | |
|     {
 | |
|         $list   = $repository->getCategories();
 | |
|         $return = [];
 | |
|         foreach ($list as $entry) {
 | |
|             $return[] = $entry->name;
 | |
|         }
 | |
|         sort($return);
 | |
| 
 | |
|         return Response::json($return);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Returns a JSON list of all beneficiaries.
 | |
|      *
 | |
|      * @param AccountRepositoryInterface $accountRepository
 | |
|      *
 | |
|      * @return \Illuminate\Http\JsonResponse
 | |
|      */
 | |
|     public function expenseAccounts(AccountRepositoryInterface $accountRepository)
 | |
|     {
 | |
|         $list   = $accountRepository->getAccounts(['Expense account', 'Beneficiary account']);
 | |
|         $return = [];
 | |
|         foreach ($list as $entry) {
 | |
|             $return[] = $entry->name;
 | |
|         }
 | |
| 
 | |
|         return Response::json($return);
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param AccountRepositoryInterface $accountRepository
 | |
|      *
 | |
|      * @return \Illuminate\Http\JsonResponse
 | |
|      */
 | |
|     public function revenueAccounts(AccountRepositoryInterface $accountRepository)
 | |
|     {
 | |
|         $list   = $accountRepository->getAccounts(['Revenue account']);
 | |
|         $return = [];
 | |
|         foreach ($list as $entry) {
 | |
|             $return[] = $entry->name;
 | |
|         }
 | |
| 
 | |
|         return Response::json($return);
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 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);
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param JournalRepositoryInterface $repository
 | |
|      * @param                            $what
 | |
|      *
 | |
|      * @return \Symfony\Component\HttpFoundation\Response
 | |
|      */
 | |
|     public function transactionJournals(JournalRepositoryInterface $repository, $what)
 | |
|     {
 | |
|         $descriptions = [];
 | |
|         $dbType       = $repository->getTransactionType($what);
 | |
| 
 | |
|         $journals = $repository->getJournalsOfType($dbType);
 | |
|         foreach ($journals as $j) {
 | |
|             $descriptions[] = $j->description;
 | |
|         }
 | |
| 
 | |
|         $descriptions = array_unique($descriptions);
 | |
|         sort($descriptions);
 | |
| 
 | |
|         return Response::json($descriptions);
 | |
| 
 | |
| 
 | |
|     }
 | |
| 
 | |
| }
 |