218 lines
6.2 KiB
PHP
Raw Normal View History

2017-09-14 22:21:00 +03:00
<?php
namespace App\Http\Controllers\Expenses;
use App\Http\Controllers\Controller;
use App\Http\Requests\Expense\Payment as Request;
use App\Models\Banking\Account;
use App\Models\Expense\Payment;
use App\Models\Expense\Vendor;
use App\Models\Setting\Category;
use App\Models\Setting\Currency;
use App\Traits\Uploads;
2017-11-30 11:47:56 +03:00
use App\Utilities\ImportFile;
use App\Utilities\Modules;
2017-09-14 22:21:00 +03:00
class Payments extends Controller
{
use Uploads;
/**
* Display a listing of the resource.
*
* @return Response
*/
public function index()
{
2018-03-08 11:51:29 +03:00
$payments = Payment::with(['vendor', 'account', 'category'])->isNotTransfer()->collect(['paid_at'=> 'desc']);
2017-09-14 22:21:00 +03:00
2017-09-27 21:40:25 +03:00
$vendors = collect(Vendor::enabled()->pluck('name', 'id'))
->prepend(trans('general.all_type', ['type' => trans_choice('general.vendors', 2)]), '');
2017-09-14 22:21:00 +03:00
$categories = collect(Category::enabled()->type('expense')->pluck('name', 'id'))
2017-09-27 21:40:25 +03:00
->prepend(trans('general.all_type', ['type' => trans_choice('general.categories', 2)]), '');
2017-09-14 22:21:00 +03:00
$accounts = collect(Account::enabled()->pluck('name', 'id'))
2017-09-27 21:40:25 +03:00
->prepend(trans('general.all_type', ['type' => trans_choice('general.accounts', 2)]), '');
2017-09-14 22:21:00 +03:00
2017-12-05 18:31:18 +03:00
$transfer_cat_id = Category::transfer();
return view('expenses.payments.index', compact('payments', 'vendors', 'categories', 'accounts', 'transfer_cat_id'));
2017-09-14 22:21:00 +03:00
}
/**
* Show the form for creating a new resource.
*
* @return Response
*/
public function create()
{
$accounts = Account::enabled()->pluck('name', 'id');
$currencies = Currency::enabled()->pluck('name', 'code')->toArray();
$account_currency_code = Account::where('id', setting('general.default_account'))->pluck('currency_code')->first();
$vendors = Vendor::enabled()->pluck('name', 'id');
$categories = Category::enabled()->type('expense')->pluck('name', 'id');
$payment_methods = Modules::getPaymentMethods();
return view('expenses.payments.create', compact('accounts', 'currencies', 'account_currency_code', 'vendors', 'categories', 'payment_methods'));
2017-09-14 22:21:00 +03:00
}
/**
* Store a newly created resource in storage.
*
* @param Request $request
*
* @return Response
*/
public function store(Request $request)
{
// Get currency object
$currency = Currency::where('code', $request['currency_code'])->first();
$request['currency_code'] = $currency->code;
$request['currency_rate'] = $currency->rate;
2017-12-28 17:20:16 +03:00
$payment = Payment::create($request->input());
2017-09-14 22:21:00 +03:00
// Upload attachment
2017-12-28 17:20:16 +03:00
$media = $this->getMedia($request->file('attachment'), 'payments');
2017-09-14 22:21:00 +03:00
2017-12-28 17:20:16 +03:00
if ($media) {
$payment->attachMedia($media, 'attachment');
}
2017-09-14 22:21:00 +03:00
$message = trans('messages.success.added', ['type' => trans_choice('general.payments', 1)]);
flash($message)->success();
return redirect('expenses/payments');
}
2017-11-26 15:20:17 +03:00
/**
* Duplicate the specified resource.
*
* @param Payment $payment
*
* @return Response
*/
public function duplicate(Payment $payment)
{
$clone = $payment->duplicate();
$message = trans('messages.success.duplicated', ['type' => trans_choice('general.payments', 1)]);
flash($message)->success();
return redirect('expenses/payments/' . $clone->id . '/edit');
}
2017-11-30 11:47:56 +03:00
/**
* Import the specified resource.
*
* @param ImportFile $import
*
* @return Response
*/
public function import(ImportFile $import)
{
$rows = $import->all();
foreach ($rows as $row) {
$data = $row->toArray();
$data['company_id'] = session('company_id');
Payment::create($data);
}
$message = trans('messages.success.imported', ['type' => trans_choice('general.payments', 2)]);
flash($message)->success();
return redirect('expenses/payments');
}
2017-09-14 22:21:00 +03:00
/**
* Show the form for editing the specified resource.
*
* @param Payment $payment
*
* @return Response
*/
public function edit(Payment $payment)
{
$accounts = Account::enabled()->pluck('name', 'id');
$currencies = Currency::enabled()->pluck('name', 'code')->toArray();
$account_currency_code = Account::where('id', $payment->account_id)->pluck('currency_code')->first();
$vendors = Vendor::enabled()->pluck('name', 'id');
$categories = Category::enabled()->type('expense')->pluck('name', 'id');
$payment_methods = Modules::getPaymentMethods();
return view('expenses.payments.edit', compact('payment', 'accounts', 'currencies', 'account_currency_code', 'vendors', 'categories', 'payment_methods'));
2017-09-14 22:21:00 +03:00
}
/**
* Update the specified resource in storage.
*
* @param Payment $payment
* @param Request $request
*
* @return Response
*/
public function update(Payment $payment, Request $request)
{
// Get currency object
$currency = Currency::where('code', $request['currency_code'])->first();
$request['currency_code'] = $currency->code;
$request['currency_rate'] = $currency->rate;
2017-12-28 17:20:16 +03:00
$payment->update($request->input());
2017-09-14 22:21:00 +03:00
// Upload attachment
2017-12-28 17:20:16 +03:00
if ($request->file('attachment')) {
$media = $this->getMedia($request->file('attachment'), 'payments');
2017-09-14 22:21:00 +03:00
2018-01-02 17:54:10 +03:00
$payment->attachMedia($media, 'attachment');
2017-12-28 17:20:16 +03:00
}
2017-09-14 22:21:00 +03:00
$message = trans('messages.success.updated', ['type' => trans_choice('general.payments', 1)]);
flash($message)->success();
return redirect('expenses/payments');
}
/**
* Remove the specified resource from storage.
*
* @param Payment $payment
*
* @return Response
*/
public function destroy(Payment $payment)
{
2017-12-05 18:31:18 +03:00
// Can't delete transfer payment
if ($payment->category->id == Category::transfer()) {
return redirect('expenses/payments');
}
2017-09-14 22:21:00 +03:00
$payment->delete();
$message = trans('messages.success.deleted', ['type' => trans_choice('general.payments', 1)]);
flash($message)->success();
return redirect('expenses/payments');
}
}