| 
									
										
										
										
											2017-11-15 06:29:49 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * ReconcileController.php | 
					
						
							|  |  |  |  * Copyright (c) 2017 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of Firefly III. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with Firefly III.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Controllers\Account; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							|  |  |  | use FireflyIII\Helpers\Collector\JournalCollectorInterface; | 
					
						
							|  |  |  | use FireflyIII\Http\Controllers\Controller; | 
					
						
							|  |  |  | use FireflyIII\Models\Account; | 
					
						
							|  |  |  | use FireflyIII\Models\AccountType; | 
					
						
							|  |  |  | use FireflyIII\Repositories\Currency\CurrencyRepositoryInterface; | 
					
						
							|  |  |  | use Illuminate\Http\Request; | 
					
						
							|  |  |  | use Illuminate\Support\Collection; | 
					
						
							|  |  |  | use Navigation; | 
					
						
							|  |  |  | use Preferences; | 
					
						
							|  |  |  | use Response; | 
					
						
							|  |  |  | use View; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |  * Class ReconcileController. | 
					
						
							| 
									
										
										
										
											2017-11-15 06:29:49 +01:00
										 |  |  |  */ | 
					
						
							|  |  |  | class ReconcileController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // translations:
 | 
					
						
							|  |  |  |         $this->middleware( | 
					
						
							|  |  |  |             function ($request, $next) { | 
					
						
							|  |  |  |                 View::share('mainTitleIcon', 'fa-credit-card'); | 
					
						
							|  |  |  |                 View::share('title', trans('firefly.accounts')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return $next($request); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Request $request | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * @param Carbon  $start | 
					
						
							|  |  |  |      * @param Carbon  $end | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function overview(Request $request, Account $account, Carbon $start, Carbon $end) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $startBalance = $request->get('startBalance'); | 
					
						
							|  |  |  |         $endBalance   = $request->get('endBalance'); | 
					
						
							|  |  |  |         $transactions = $request->get('transactions'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $return         = [ | 
					
						
							|  |  |  |             'is_zero'  => false, | 
					
						
							|  |  |  |             'post_uri' => route('accounts.reconcile.submit', [$account->id, $start->format('Ymd'), $end->format('Ymd')]), | 
					
						
							|  |  |  |             'html'     => '', | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         $return['html'] = view('accounts.reconcile.overview', compact('account', 'start', 'end'))->render(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Response::json($return); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Account     $account | 
					
						
							|  |  |  |      * @param Carbon|null $start | 
					
						
							|  |  |  |      * @param Carbon|null $end | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function reconcile(Account $account, Carbon $start = null, Carbon $end = null) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |         if (AccountType::INITIAL_BALANCE === $account->accountType->type) { | 
					
						
							| 
									
										
										
										
											2017-11-15 06:29:49 +01:00
										 |  |  |             return $this->redirectToOriginalAccount($account); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         /** @var CurrencyRepositoryInterface $currencyRepos */ | 
					
						
							|  |  |  |         $currencyRepos = app(CurrencyRepositoryInterface::class); | 
					
						
							|  |  |  |         $currencyId    = intval($account->getMeta('currency_id')); | 
					
						
							|  |  |  |         $currency      = $currencyRepos->find($currencyId); | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |         if (0 === $currencyId) { | 
					
						
							| 
									
										
										
										
											2017-11-15 06:29:49 +01:00
										 |  |  |             $currency = app('amount')->getDefaultCurrency(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // no start or end:
 | 
					
						
							|  |  |  |         $range = Preferences::get('viewRange', '1M')->data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // get start and end
 | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |         if (null === $start && null === $end) { | 
					
						
							| 
									
										
										
										
											2017-11-15 06:29:49 +01:00
										 |  |  |             $start = clone session('start', Navigation::startOfPeriod(new Carbon, $range)); | 
					
						
							|  |  |  |             $end   = clone session('end', Navigation::endOfPeriod(new Carbon, $range)); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |         if (null === $end) { | 
					
						
							| 
									
										
										
										
											2017-11-15 06:29:49 +01:00
										 |  |  |             $end = Navigation::endOfPeriod($start, $range); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $startDate = clone $start; | 
					
						
							|  |  |  |         $startDate->subDays(1); | 
					
						
							|  |  |  |         $startBalance = round(app('steam')->balance($account, $startDate), $currency->decimal_places); | 
					
						
							|  |  |  |         $endBalance   = round(app('steam')->balance($account, $end), $currency->decimal_places); | 
					
						
							|  |  |  |         $subTitleIcon = config('firefly.subIconsByIdentifier.' . $account->accountType->type); | 
					
						
							|  |  |  |         $subTitle     = trans('firefly.reconcile_account', ['account' => $account->name]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // various links
 | 
					
						
							|  |  |  |         $transactionsUri = route('accounts.reconcile.transactions', [$account->id, '%start%', '%end%']); | 
					
						
							|  |  |  |         $overviewUri     = route('accounts.reconcile.overview', [$account->id, '%start%', '%end%']); | 
					
						
							|  |  |  |         $indexUri        = route('accounts.reconcile', [$account->id, '%start%', '%end%']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return view( | 
					
						
							| 
									
										
										
										
											2017-11-15 10:52:29 +01:00
										 |  |  |             'accounts.reconcile.index', | 
					
						
							|  |  |  |             compact( | 
					
						
							| 
									
										
										
										
											2017-11-15 11:33:07 +01:00
										 |  |  |                 'account', | 
					
						
							| 
									
										
										
										
											2017-11-15 10:52:29 +01:00
										 |  |  |                 'currency', | 
					
						
							|  |  |  |                 'subTitleIcon', | 
					
						
							|  |  |  |                 'start', | 
					
						
							|  |  |  |                 'end', | 
					
						
							|  |  |  |                 'subTitle', | 
					
						
							|  |  |  |                 'startBalance', | 
					
						
							|  |  |  |                 'endBalance', | 
					
						
							|  |  |  |                 'transactionsUri', | 
					
						
							| 
									
										
										
										
											2017-11-15 11:33:07 +01:00
										 |  |  |                 'selectionStart', | 
					
						
							| 
									
										
										
										
											2017-11-15 10:52:29 +01:00
										 |  |  |                 'selectionEnd', | 
					
						
							|  |  |  |                 'overviewUri', | 
					
						
							|  |  |  |                 'indexUri' | 
					
						
							| 
									
										
										
										
											2017-11-15 11:33:07 +01:00
										 |  |  |             ) | 
					
						
							| 
									
										
										
										
											2017-11-15 06:29:49 +01:00
										 |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Account $account | 
					
						
							|  |  |  |      * @param Carbon  $start | 
					
						
							|  |  |  |      * @param Carbon  $end | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function transactions(Account $account, Carbon $start, Carbon $end) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |         if (AccountType::INITIAL_BALANCE === $account->accountType->type) { | 
					
						
							| 
									
										
										
										
											2017-11-15 06:29:49 +01:00
										 |  |  |             return $this->redirectToOriginalAccount($account); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // get the transactions
 | 
					
						
							|  |  |  |         $selectionStart = clone $start; | 
					
						
							|  |  |  |         $selectionStart->subDays(3); | 
					
						
							|  |  |  |         $selectionEnd = clone $end; | 
					
						
							|  |  |  |         $selectionEnd->addDays(3); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // grab transactions:
 | 
					
						
							|  |  |  |         /** @var JournalCollectorInterface $collector */ | 
					
						
							|  |  |  |         $collector = app(JournalCollectorInterface::class); | 
					
						
							|  |  |  |         $collector->setAccounts(new Collection([$account])) | 
					
						
							|  |  |  |                   ->setRange($selectionStart, $selectionEnd)->withBudgetInformation()->withOpposingAccount()->withCategoryInformation(); | 
					
						
							|  |  |  |         $transactions = $collector->getJournals(); | 
					
						
							|  |  |  |         $html         = view('accounts.reconcile.transactions', compact('account', 'transactions', 'start', 'end', 'selectionStart', 'selectionEnd'))->render(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Response::json(['html' => $html]); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-11-15 10:52:29 +01:00
										 |  |  | } |