| 
									
										
										
										
											2016-05-01 06:37:47 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |  * TransactionController.php | 
					
						
							| 
									
										
										
										
											2016-05-01 06:37:47 +02:00
										 |  |  |  * Copyright (C) 2016 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-10-05 06:52:15 +02:00
										 |  |  |  * This software may be modified and distributed under the terms of the | 
					
						
							|  |  |  |  * Creative Commons Attribution-ShareAlike 4.0 International License. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * See the LICENSE file for details. | 
					
						
							| 
									
										
										
										
											2016-05-01 06:37:47 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-24 15:01:53 +01:00
										 |  |  | declare(strict_types=1); | 
					
						
							| 
									
										
										
										
											2016-05-20 12:27:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  | namespace FireflyIII\Http\Controllers; | 
					
						
							| 
									
										
										
										
											2015-02-23 21:55:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2016-11-20 12:51:33 +01:00
										 |  |  | use FireflyIII\Helpers\Collector\JournalCollectorInterface; | 
					
						
							| 
									
										
										
										
											2017-04-28 20:08:25 +02:00
										 |  |  | use FireflyIII\Helpers\Filter\InternalTransferFilter; | 
					
						
							| 
									
										
										
										
											2017-08-30 07:40:39 +02:00
										 |  |  | use FireflyIII\Models\Transaction; | 
					
						
							| 
									
										
										
										
											2015-02-25 21:19:06 +01:00
										 |  |  | use FireflyIII\Models\TransactionJournal; | 
					
						
							| 
									
										
										
										
											2015-02-24 22:53:38 +01:00
										 |  |  | use FireflyIII\Repositories\Journal\JournalRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2016-10-15 12:39:34 +02:00
										 |  |  | use FireflyIII\Repositories\Journal\JournalTaskerInterface; | 
					
						
							| 
									
										
										
										
											2017-08-21 07:13:03 +02:00
										 |  |  | use FireflyIII\Repositories\LinkType\LinkTypeRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  | use FireflyIII\Support\CacheProperties; | 
					
						
							| 
									
										
										
										
											2016-05-15 12:08:41 +02:00
										 |  |  | use Illuminate\Http\Request; | 
					
						
							| 
									
										
										
										
											2016-11-20 12:51:33 +01:00
										 |  |  | use Illuminate\Support\Collection; | 
					
						
							| 
									
										
										
										
											2016-11-19 12:57:35 +01:00
										 |  |  | use Log; | 
					
						
							| 
									
										
										
										
											2016-11-20 12:51:33 +01:00
										 |  |  | use Navigation; | 
					
						
							| 
									
										
										
										
											2015-06-02 17:44:50 +02:00
										 |  |  | use Preferences; | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  | use Response; | 
					
						
							| 
									
										
										
										
											2015-04-01 09:16:41 +02:00
										 |  |  | use View; | 
					
						
							| 
									
										
										
										
											2015-02-27 14:27:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-23 21:55:52 +01:00
										 |  |  | /** | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |  * Class TransactionController | 
					
						
							| 
									
										
										
										
											2015-02-23 21:55:52 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |  * @package FireflyIII\Http\Controllers | 
					
						
							| 
									
										
										
										
											2015-02-23 21:55:52 +01:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  | class TransactionController extends Controller | 
					
						
							| 
									
										
										
										
											2015-02-23 21:55:52 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-10-21 19:20:03 +02:00
										 |  |  |      * TransactionController constructor. | 
					
						
							| 
									
										
										
										
											2015-02-23 21:55:52 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-04-28 15:26:30 +02:00
										 |  |  |         parent::__construct(); | 
					
						
							| 
									
										
										
										
											2016-10-29 07:44:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->middleware( | 
					
						
							|  |  |  |             function ($request, $next) { | 
					
						
							|  |  |  |                 View::share('title', trans('firefly.transactions')); | 
					
						
							|  |  |  |                 View::share('mainTitleIcon', 'fa-repeat'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return $next($request); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2016-09-09 11:19:40 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-27 14:27:04 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-11-26 09:16:06 +01:00
										 |  |  |      * @param Request                    $request | 
					
						
							|  |  |  |      * @param JournalRepositoryInterface $repository | 
					
						
							|  |  |  |      * @param string                     $what | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2017-04-09 07:56:46 +02:00
										 |  |  |      * @param string                     $moment | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-05-15 12:08:41 +02:00
										 |  |  |      * @return View | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |     public function index(Request $request, JournalRepositoryInterface $repository, string $what, string $moment = '') | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |         // default values:
 | 
					
						
							| 
									
										
										
										
											2016-11-05 11:47:21 +01:00
										 |  |  |         $subTitleIcon = config('firefly.transactionIconsByWhat.' . $what); | 
					
						
							|  |  |  |         $types        = config('firefly.transactionTypesByWhat.' . $what); | 
					
						
							| 
									
										
										
										
											2017-07-30 13:42:30 +02:00
										 |  |  |         $page         = intval($request->get('page')); | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |         $pageSize     = intval(Preferences::get('transactionPageSize', 50)->data); | 
					
						
							| 
									
										
										
										
											2016-11-20 12:51:33 +01:00
										 |  |  |         $range        = Preferences::get('viewRange', '1M')->data; | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |         $start        = null; | 
					
						
							|  |  |  |         $end          = null; | 
					
						
							|  |  |  |         $periods      = new Collection; | 
					
						
							| 
									
										
										
										
											2017-07-26 16:40:00 +02:00
										 |  |  |         $path         = route('transactions.index', [$what]); | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // prep for "all" view.
 | 
					
						
							|  |  |  |         if ($moment === 'all') { | 
					
						
							|  |  |  |             $subTitle = trans('firefly.all_' . $what); | 
					
						
							|  |  |  |             $first    = $repository->first(); | 
					
						
							|  |  |  |             $start    = $first->date ?? new Carbon; | 
					
						
							|  |  |  |             $end      = new Carbon; | 
					
						
							| 
									
										
										
										
											2017-07-26 16:40:00 +02:00
										 |  |  |             $path     = route('transactions.index', [$what, 'all']); | 
					
						
							| 
									
										
										
										
											2016-11-20 12:51:33 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |         // prep for "specific date" view.
 | 
					
						
							|  |  |  |         if (strlen($moment) > 0 && $moment !== 'all') { | 
					
						
							|  |  |  |             $start    = new Carbon($moment); | 
					
						
							|  |  |  |             $end      = Navigation::endOfPeriod($start, $range); | 
					
						
							| 
									
										
										
										
											2017-07-30 13:42:30 +02:00
										 |  |  |             $path     = route('transactions.index', [$what, $moment]); | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |             $subTitle = trans( | 
					
						
							|  |  |  |                 'firefly.title_' . $what . '_between', | 
					
						
							|  |  |  |                 ['start' => $start->formatLocalized($this->monthAndDayFormat), 'end' => $end->formatLocalized($this->monthAndDayFormat)] | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2017-03-18 08:09:14 +01:00
										 |  |  |             $periods  = $this->getPeriodOverview($what); | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-11-20 12:51:33 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |         // prep for current period
 | 
					
						
							|  |  |  |         if (strlen($moment) === 0) { | 
					
						
							|  |  |  |             $start    = clone session('start', Navigation::startOfPeriod(new Carbon, $range)); | 
					
						
							|  |  |  |             $end      = clone session('end', Navigation::endOfPeriod(new Carbon, $range)); | 
					
						
							| 
									
										
										
										
											2017-03-18 08:09:14 +01:00
										 |  |  |             $periods  = $this->getPeriodOverview($what); | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |             $subTitle = trans( | 
					
						
							|  |  |  |                 'firefly.title_' . $what . '_between', | 
					
						
							|  |  |  |                 ['start' => $start->formatLocalized($this->monthAndDayFormat), 'end' => $end->formatLocalized($this->monthAndDayFormat)] | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-11-20 12:51:33 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-30 13:53:04 +02:00
										 |  |  |         /** @var JournalCollectorInterface $collector */ | 
					
						
							|  |  |  |         $collector = app(JournalCollectorInterface::class); | 
					
						
							|  |  |  |         $collector->setAllAssetAccounts()->setRange($start, $end)->setTypes($types)->setLimit($pageSize)->setPage($page)->withOpposingAccount(); | 
					
						
							|  |  |  |         $collector->removeFilter(InternalTransferFilter::class); | 
					
						
							|  |  |  |         $journals = $collector->getPaginatedJournals(); | 
					
						
							|  |  |  |         $journals->setPath($path); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-20 12:51:33 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |         return view('transactions.index', compact('subTitle', 'what', 'subTitleIcon', 'journals', 'periods', 'start', 'end', 'moment')); | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-05-15 12:08:41 +02:00
										 |  |  |      * @param Request                    $request | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |      * @param JournalRepositoryInterface $repository | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-05-15 12:08:41 +02:00
										 |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-05-15 12:08:41 +02:00
										 |  |  |     public function reorder(Request $request, JournalRepositoryInterface $repository) | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-05-15 12:08:41 +02:00
										 |  |  |         $ids  = $request->get('items'); | 
					
						
							|  |  |  |         $date = new Carbon($request->get('date')); | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |         if (count($ids) > 0) { | 
					
						
							|  |  |  |             $order = 0; | 
					
						
							| 
									
										
										
										
											2016-10-10 07:49:39 +02:00
										 |  |  |             $ids   = array_unique($ids); | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |             foreach ($ids as $id) { | 
					
						
							| 
									
										
										
										
											2016-06-15 09:58:33 +02:00
										 |  |  |                 $journal = $repository->find(intval($id)); | 
					
						
							| 
									
										
										
										
											2017-03-24 15:01:53 +01:00
										 |  |  |                 if ($journal && $journal->date->isSameDay($date)) { | 
					
						
							|  |  |  |                     $repository->setOrder($journal, $order); | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  |                     $order++; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         Preferences::mark(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Response::json([true]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-25 21:19:06 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2017-09-09 06:41:45 +02:00
										 |  |  |      * @param TransactionJournal          $journal | 
					
						
							|  |  |  |      * @param JournalTaskerInterface      $tasker | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param LinkTypeRepositoryInterface $linkTypeRepository | 
					
						
							| 
									
										
										
										
											2015-02-25 21:19:06 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2017-07-23 08:16:11 +02:00
										 |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector|View | 
					
						
							| 
									
										
										
										
											2015-02-25 21:19:06 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-08-21 07:13:03 +02:00
										 |  |  |     public function show(TransactionJournal $journal, JournalTaskerInterface $tasker, LinkTypeRepositoryInterface $linkTypeRepository) | 
					
						
							| 
									
										
										
										
											2015-02-25 21:19:06 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-11-22 19:10:17 +01:00
										 |  |  |         if ($this->isOpeningBalance($journal)) { | 
					
						
							|  |  |  |             return $this->redirectToAccount($journal); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-08-21 18:16:15 +02:00
										 |  |  |         $linkTypes    = $linkTypeRepository->get(); | 
					
						
							|  |  |  |         $links        = $linkTypeRepository->getLinks($journal); | 
					
						
							| 
									
										
										
										
											2017-06-05 11:12:50 +02:00
										 |  |  |         $events       = $tasker->getPiggyBankEvents($journal); | 
					
						
							|  |  |  |         $transactions = $tasker->getTransactionsOverview($journal); | 
					
						
							|  |  |  |         $what         = strtolower($journal->transaction_type_type ?? $journal->transactionType->type); | 
					
						
							|  |  |  |         $subTitle     = trans('firefly.' . $what) . ' "' . e($journal->description) . '"'; | 
					
						
							| 
									
										
										
										
											2017-04-14 14:37:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-30 07:40:39 +02:00
										 |  |  |         return view('transactions.show', compact('journal', 'events', 'subTitle', 'what', 'transactions', 'linkTypes', 'links')); | 
					
						
							| 
									
										
										
										
											2016-05-13 09:55:06 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-25 21:19:06 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-22 19:10:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param string $what | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      * @throws FireflyException | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-03-18 08:09:14 +01:00
										 |  |  |     private function getPeriodOverview(string $what): Collection | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         $repository = app(JournalRepositoryInterface::class); | 
					
						
							|  |  |  |         $first      = $repository->first(); | 
					
						
							|  |  |  |         $start      = $first->date ?? new Carbon; | 
					
						
							|  |  |  |         $range      = Preferences::get('viewRange', '1M')->data; | 
					
						
							|  |  |  |         $start      = Navigation::startOfPeriod($start, $range); | 
					
						
							| 
									
										
										
										
											2017-07-26 16:40:25 +02:00
										 |  |  |         $end        = Navigation::endOfX(new Carbon, $range, null); | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |         $entries    = new Collection; | 
					
						
							|  |  |  |         $types      = config('firefly.transactionTypesByWhat.' . $what); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // properties for cache
 | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							|  |  |  |         $cache->addProperty($what); | 
					
						
							|  |  |  |         $cache->addProperty('transaction-list-entries'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2017-09-09 06:41:45 +02:00
										 |  |  |             return $cache->get(); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-17 16:34:57 +01:00
										 |  |  |         Log::debug(sprintf('Going to get period expenses and incomes between %s and %s.', $start->format('Y-m-d'), $end->format('Y-m-d'))); | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |         while ($end >= $start) { | 
					
						
							| 
									
										
										
										
											2017-03-17 16:34:57 +01:00
										 |  |  |             Log::debug('Loop start!'); | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |             $end        = Navigation::startOfPeriod($end, $range); | 
					
						
							|  |  |  |             $currentEnd = Navigation::endOfPeriod($end, $range); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // count journals without budget in this period:
 | 
					
						
							|  |  |  |             /** @var JournalCollectorInterface $collector */ | 
					
						
							|  |  |  |             $collector = app(JournalCollectorInterface::class); | 
					
						
							| 
									
										
										
										
											2017-04-28 20:08:25 +02:00
										 |  |  |             $collector->setAllAssetAccounts()->setRange($end, $currentEnd)->withOpposingAccount()->setTypes($types); | 
					
						
							|  |  |  |             $collector->removeFilter(InternalTransferFilter::class); | 
					
						
							| 
									
										
										
										
											2017-08-30 07:40:39 +02:00
										 |  |  |             $journals = $collector->getJournals(); | 
					
						
							|  |  |  |             $sum      = $journals->sum('transaction_amount'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // count per currency:
 | 
					
						
							|  |  |  |             $sums     = $this->sumPerCurrency($journals); | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |             $dateStr  = $end->format('Y-m-d'); | 
					
						
							|  |  |  |             $dateName = Navigation::periodShow($end, $range); | 
					
						
							|  |  |  |             $array    = [ | 
					
						
							| 
									
										
										
										
											2017-08-30 07:40:39 +02:00
										 |  |  |                 'string' => $dateStr, | 
					
						
							|  |  |  |                 'name'   => $dateName, | 
					
						
							|  |  |  |                 'sum'    => $sum, | 
					
						
							|  |  |  |                 'sums'   => $sums, | 
					
						
							|  |  |  |                 'date'   => clone $end, | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |             ]; | 
					
						
							| 
									
										
										
										
											2017-03-17 16:34:57 +01:00
										 |  |  |             Log::debug(sprintf('What is %s', $what)); | 
					
						
							| 
									
										
										
										
											2017-08-30 07:40:39 +02:00
										 |  |  |             if ($journals->count() > 0) { | 
					
						
							|  |  |  |                 $entries->push($array); | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |             $end = Navigation::subtractPeriod($end, $range, 1); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-03-17 16:34:57 +01:00
										 |  |  |         Log::debug('End of loop'); | 
					
						
							| 
									
										
										
										
											2017-03-11 07:41:26 +01:00
										 |  |  |         $cache->store($entries); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $entries; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-30 07:40:39 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Collection $collection | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function sumPerCurrency(Collection $collection): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $return = []; | 
					
						
							|  |  |  |         /** @var Transaction $transaction */ | 
					
						
							|  |  |  |         foreach ($collection as $transaction) { | 
					
						
							|  |  |  |             $currencyId = $transaction->transaction_currency_id; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // save currency information:
 | 
					
						
							|  |  |  |             if (!isset($return[$currencyId])) { | 
					
						
							|  |  |  |                 $currencySymbol      = $transaction->transaction_currency_symbol; | 
					
						
							|  |  |  |                 $decimalPlaces       = $transaction->transaction_currency_dp; | 
					
						
							|  |  |  |                 $currencyCode        = $transaction->transaction_currency_code; | 
					
						
							|  |  |  |                 $return[$currencyId] = [ | 
					
						
							|  |  |  |                     'currency' => [ | 
					
						
							|  |  |  |                         'id'     => $currencyId, | 
					
						
							|  |  |  |                         'code'   => $currencyCode, | 
					
						
							|  |  |  |                         'symbol' => $currencySymbol, | 
					
						
							|  |  |  |                         'dp'     => $decimalPlaces, | 
					
						
							|  |  |  |                     ], | 
					
						
							|  |  |  |                     'sum'      => '0', | 
					
						
							|  |  |  |                     'count'    => 0, | 
					
						
							|  |  |  |                 ]; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             // save amount:
 | 
					
						
							|  |  |  |             $return[$currencyId]['sum'] = bcadd($return[$currencyId]['sum'], $transaction->transaction_amount); | 
					
						
							|  |  |  |             $return[$currencyId]['count']++; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         asort($return); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-01 06:59:08 +02:00
										 |  |  | } |