2017-09-14 19:21:00 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace App\Http\Controllers\Banking;
|
|
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
use App\Abstracts\Http\Controller;
|
2017-09-14 19:21:00 +00:00
|
|
|
use App\Http\Requests\Banking\Transfer as Request;
|
2020-10-01 15:20:32 +00:00
|
|
|
use App\Exports\Banking\Transfers as Export;
|
|
|
|
|
use App\Http\Requests\Common\Import as ImportRequest;
|
|
|
|
|
use App\Imports\Banking\Transfers as Import;
|
2019-11-16 07:21:14 +00:00
|
|
|
use App\Jobs\Banking\CreateTransfer;
|
|
|
|
|
use App\Jobs\Banking\UpdateTransfer;
|
|
|
|
|
use App\Jobs\Banking\DeleteTransfer;
|
2017-09-14 19:21:00 +00:00
|
|
|
use App\Models\Banking\Account;
|
|
|
|
|
use App\Models\Banking\Transfer;
|
|
|
|
|
use App\Models\Setting\Currency;
|
2017-10-11 12:47:07 +00:00
|
|
|
use App\Utilities\Modules;
|
2019-11-16 07:21:14 +00:00
|
|
|
use Date;
|
2017-10-11 12:47:07 +00:00
|
|
|
|
2017-09-14 19:21:00 +00:00
|
|
|
class Transfers extends Controller
|
|
|
|
|
{
|
|
|
|
|
/**
|
|
|
|
|
* Display a listing of the resource.
|
|
|
|
|
*
|
|
|
|
|
* @return Response
|
|
|
|
|
*/
|
|
|
|
|
public function index()
|
|
|
|
|
{
|
2021-02-10 22:57:17 +00:00
|
|
|
$transfers = Transfer::with(
|
2019-11-16 07:21:14 +00:00
|
|
|
'expense_transaction', 'expense_transaction.account', 'income_transaction', 'income_transaction.account'
|
2020-06-07 09:11:37 +00:00
|
|
|
)->collect(['expense_transaction.paid_at' => 'desc']);
|
2017-09-14 19:21:00 +00:00
|
|
|
|
2021-02-10 22:57:17 +00:00
|
|
|
return $this->response('banking.transfers.index', compact('transfers'));
|
2017-09-14 19:21:00 +00:00
|
|
|
}
|
|
|
|
|
|
2018-04-16 10:59:53 +00:00
|
|
|
/**
|
|
|
|
|
* Show the form for viewing the specified resource.
|
|
|
|
|
*
|
|
|
|
|
* @return Response
|
|
|
|
|
*/
|
|
|
|
|
public function show()
|
|
|
|
|
{
|
2019-11-16 07:21:14 +00:00
|
|
|
return redirect()->route('transfers.index');
|
2018-04-16 10:59:53 +00:00
|
|
|
}
|
|
|
|
|
|
2017-09-14 19:21:00 +00:00
|
|
|
/**
|
|
|
|
|
* Show the form for creating a new resource.
|
|
|
|
|
*
|
|
|
|
|
* @return Response
|
|
|
|
|
*/
|
|
|
|
|
public function create()
|
|
|
|
|
{
|
2018-06-29 11:42:15 +00:00
|
|
|
$accounts = Account::enabled()->orderBy('name')->pluck('name', 'id');
|
2017-09-14 19:21:00 +00:00
|
|
|
|
2017-10-11 12:47:07 +00:00
|
|
|
$payment_methods = Modules::getPaymentMethods();
|
|
|
|
|
|
2021-03-18 17:00:55 +00:00
|
|
|
$currencies = Currency::enabled()->orderBy('name')->get()->makeHidden(['id', 'company_id', 'created_at', 'updated_at', 'deleted_at']);
|
|
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
$currency = Currency::where('code', setting('default.currency'))->first();
|
2018-08-13 18:14:58 +00:00
|
|
|
|
2021-03-18 17:00:55 +00:00
|
|
|
return view('banking.transfers.create', compact('accounts', 'payment_methods', 'currencies', 'currency'));
|
2017-09-14 19:21:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Store a newly created resource in storage.
|
|
|
|
|
*
|
|
|
|
|
* @param Request $request
|
|
|
|
|
*
|
|
|
|
|
* @return Response
|
|
|
|
|
*/
|
|
|
|
|
public function store(Request $request)
|
|
|
|
|
{
|
2019-11-16 07:21:14 +00:00
|
|
|
$response = $this->ajaxDispatch(new CreateTransfer($request));
|
2018-08-07 16:58:24 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
if ($response['success']) {
|
|
|
|
|
$response['redirect'] = route('transfers.index');
|
2018-07-05 13:55:35 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
$message = trans('messages.success.added', ['type' => trans_choice('general.transfers', 1)]);
|
2018-07-05 13:55:35 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
flash($message)->success();
|
2018-07-05 13:55:35 +00:00
|
|
|
} else {
|
2019-11-16 07:21:14 +00:00
|
|
|
$response['redirect'] = route('transfers.create');
|
2018-07-09 09:01:16 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
$message = $response['message'];
|
2018-07-09 09:01:16 +00:00
|
|
|
|
2021-02-12 16:26:38 +00:00
|
|
|
flash($message)->error()->important();
|
2019-11-16 07:21:14 +00:00
|
|
|
}
|
2017-09-14 19:21:00 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
return response()->json($response);
|
2017-09-14 19:21:00 +00:00
|
|
|
}
|
|
|
|
|
|
2021-01-31 20:47:36 +00:00
|
|
|
/**
|
|
|
|
|
* Import the specified resource.
|
|
|
|
|
*
|
|
|
|
|
* @param ImportRequest $request
|
|
|
|
|
*
|
|
|
|
|
* @return Response
|
|
|
|
|
*/
|
|
|
|
|
public function import(ImportRequest $request)
|
|
|
|
|
{
|
2021-04-15 21:59:43 +00:00
|
|
|
$response = $this->importExcel(new Import, $request, trans_choice('general.transfers', 2));
|
2021-01-31 20:47:36 +00:00
|
|
|
|
2021-02-11 15:08:06 +00:00
|
|
|
if ($response['success']) {
|
|
|
|
|
$response['redirect'] = route('transfers.index');
|
2021-01-31 20:47:36 +00:00
|
|
|
|
2021-04-15 21:59:43 +00:00
|
|
|
flash($response['message'])->success();
|
2021-02-11 15:08:06 +00:00
|
|
|
} else {
|
|
|
|
|
$response['redirect'] = route('import.create', ['banking', 'transfers']);
|
|
|
|
|
|
2021-04-15 21:59:43 +00:00
|
|
|
flash($response['message'])->error()->important();
|
2021-02-11 15:08:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return response()->json($response);
|
2021-01-31 20:47:36 +00:00
|
|
|
}
|
|
|
|
|
|
2017-09-14 19:21:00 +00:00
|
|
|
/**
|
|
|
|
|
* Show the form for editing the specified resource.
|
|
|
|
|
*
|
2019-11-16 07:21:14 +00:00
|
|
|
* @param Transfer $transfer
|
2017-09-14 19:21:00 +00:00
|
|
|
*
|
|
|
|
|
* @return Response
|
|
|
|
|
*/
|
2018-05-21 13:47:35 +00:00
|
|
|
public function edit(Transfer $transfer)
|
2017-09-14 19:21:00 +00:00
|
|
|
{
|
2019-11-16 07:21:14 +00:00
|
|
|
$transfer['from_account_id'] = $transfer->expense_transaction->account_id;
|
2021-03-18 17:00:55 +00:00
|
|
|
$transfer['from_currency_code'] = $transfer->expense_transaction->currency_code;
|
|
|
|
|
$transfer['from_account_rate'] = $transfer->expense_transaction->currency_rate;
|
2019-11-16 07:21:14 +00:00
|
|
|
$transfer['to_account_id'] = $transfer->income_transaction->account_id;
|
2021-03-18 17:00:55 +00:00
|
|
|
$transfer['to_currency_code'] = $transfer->income_transaction->currency_code;
|
|
|
|
|
$transfer['to_account_rate'] = $transfer->income_transaction->currency_rate;
|
2019-11-16 07:21:14 +00:00
|
|
|
$transfer['transferred_at'] = Date::parse($transfer->expense_transaction->paid_at)->format('Y-m-d');
|
|
|
|
|
$transfer['description'] = $transfer->expense_transaction->description;
|
|
|
|
|
$transfer['amount'] = $transfer->expense_transaction->amount;
|
|
|
|
|
$transfer['payment_method'] = $transfer->expense_transaction->payment_method;
|
|
|
|
|
$transfer['reference'] = $transfer->expense_transaction->reference;
|
|
|
|
|
|
2018-06-29 11:42:15 +00:00
|
|
|
$accounts = Account::enabled()->orderBy('name')->pluck('name', 'id');
|
2017-09-14 19:21:00 +00:00
|
|
|
|
2017-10-11 12:47:07 +00:00
|
|
|
$payment_methods = Modules::getPaymentMethods();
|
|
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
$account = $transfer->expense_transaction->account;
|
|
|
|
|
|
2021-03-18 17:00:55 +00:00
|
|
|
$currencies = Currency::enabled()->orderBy('name')->get()->makeHidden(['id', 'company_id', 'created_at', 'updated_at', 'deleted_at']);
|
|
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
$currency = Currency::where('code', $account->currency_code)->first();
|
2018-08-13 18:14:58 +00:00
|
|
|
|
2021-03-18 17:00:55 +00:00
|
|
|
return view('banking.transfers.edit', compact('transfer', 'accounts', 'payment_methods', 'currencies', 'currency'));
|
2017-09-14 19:21:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Update the specified resource in storage.
|
|
|
|
|
*
|
2019-11-16 07:21:14 +00:00
|
|
|
* @param $id
|
2017-09-14 19:21:00 +00:00
|
|
|
* @param Request $request
|
|
|
|
|
*
|
|
|
|
|
* @return Response
|
|
|
|
|
*/
|
|
|
|
|
public function update(Transfer $transfer, Request $request)
|
|
|
|
|
{
|
2019-11-16 07:21:14 +00:00
|
|
|
$response = $this->ajaxDispatch(new UpdateTransfer($transfer, $request));
|
2018-07-09 09:01:16 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
if ($response['success']) {
|
|
|
|
|
$response['redirect'] = route('transfers.index');
|
2018-08-07 16:58:24 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
$message = trans('messages.success.updated', ['type' => trans_choice('general.transfers', 1)]);
|
2017-09-14 19:21:00 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
flash($message)->success();
|
2018-07-05 13:55:35 +00:00
|
|
|
} else {
|
2019-11-16 07:21:14 +00:00
|
|
|
$response['redirect'] = route('transfers.edit', $transfer->id);
|
2017-09-14 19:21:00 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
$message = $response['message'];
|
2017-09-14 19:21:00 +00:00
|
|
|
|
2021-02-12 16:26:38 +00:00
|
|
|
flash($message)->error()->important();
|
2019-11-16 07:21:14 +00:00
|
|
|
}
|
2017-09-14 19:21:00 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
return response()->json($response);
|
2017-09-14 19:21:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Remove the specified resource from storage.
|
|
|
|
|
*
|
2019-11-16 07:21:14 +00:00
|
|
|
* @param $id
|
2017-09-14 19:21:00 +00:00
|
|
|
*
|
|
|
|
|
* @return Response
|
|
|
|
|
*/
|
|
|
|
|
public function destroy(Transfer $transfer)
|
|
|
|
|
{
|
2019-11-16 07:21:14 +00:00
|
|
|
$response = $this->ajaxDispatch(new DeleteTransfer($transfer));
|
2017-09-14 19:21:00 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
$response['redirect'] = route('transfers.index');
|
2017-09-14 19:21:00 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
if ($response['success']) {
|
|
|
|
|
$message = trans('messages.success.deleted', ['type' => trans_choice('general.transfers', 1)]);
|
2017-09-14 19:21:00 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
flash($message)->success();
|
|
|
|
|
} else {
|
|
|
|
|
$message = $response['message'];
|
|
|
|
|
|
2021-02-12 16:26:38 +00:00
|
|
|
flash($message)->error()->important();
|
2019-11-16 07:21:14 +00:00
|
|
|
}
|
2017-09-14 19:21:00 +00:00
|
|
|
|
2019-11-16 07:21:14 +00:00
|
|
|
return response()->json($response);
|
2017-09-14 19:21:00 +00:00
|
|
|
}
|
2020-10-01 15:20:32 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Export the specified resource.
|
|
|
|
|
*
|
|
|
|
|
* @return Response
|
|
|
|
|
*/
|
|
|
|
|
public function export()
|
|
|
|
|
{
|
2021-01-31 20:47:36 +00:00
|
|
|
return $this->exportExcel(new Export, trans_choice('general.transfers', 2));
|
2020-10-01 15:20:32 +00:00
|
|
|
}
|
2017-09-14 19:21:00 +00:00
|
|
|
}
|