v2 first commit
This commit is contained in:
@ -2,18 +2,16 @@
|
||||
|
||||
namespace App\Http\Controllers\Api\Banking;
|
||||
|
||||
use App\Http\Controllers\ApiController;
|
||||
use App\Abstracts\Http\ApiController;
|
||||
use App\Http\Requests\Banking\Transfer as Request;
|
||||
use App\Jobs\Banking\CreateTransfer;
|
||||
use App\Jobs\Banking\UpdateTransfer;
|
||||
use App\Jobs\Banking\DeleteTransfer;
|
||||
use App\Models\Banking\Transfer;
|
||||
use App\Models\Expense\Payment;
|
||||
use App\Models\Income\Revenue;
|
||||
use App\Transformers\Banking\Transfer as Transformer;
|
||||
use Dingo\Api\Routing\Helpers;
|
||||
|
||||
class Transfers extends ApiController
|
||||
{
|
||||
use Helpers;
|
||||
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
@ -21,7 +19,37 @@ class Transfers extends ApiController
|
||||
*/
|
||||
public function index()
|
||||
{
|
||||
$transfers = Transfer::with(['payment', 'revenue'])->collect('payment.paid_at');
|
||||
$transfers = Transfer::with([
|
||||
'expense_transaction', 'expense_transaction.account', 'income_transaction', 'income_transaction.account'
|
||||
])->collect('expense_transaction.paid_at');
|
||||
|
||||
$special_key = [
|
||||
'expense_transaction.name' => 'from_account',
|
||||
'income_transaction.name' => 'to_account',
|
||||
];
|
||||
|
||||
$request = request();
|
||||
if (isset($request['sort']) && array_key_exists($request['sort'], $special_key)) {
|
||||
$items = $transfers->items();
|
||||
|
||||
$sort_order = [];
|
||||
|
||||
foreach ($items as $key => $value) {
|
||||
$sort = $request['sort'];
|
||||
|
||||
if (array_key_exists($request['sort'], $special_key)) {
|
||||
$sort = $special_key[$request['sort']];
|
||||
}
|
||||
|
||||
$sort_order[$key] = $value->{$sort};
|
||||
}
|
||||
|
||||
$sort_type = (isset($request['order']) && $request['order'] == 'asc') ? SORT_ASC : SORT_DESC;
|
||||
|
||||
array_multisort($sort_order, $sort_type, $items);
|
||||
|
||||
$transfers->setCollection(collect($items));
|
||||
}
|
||||
|
||||
return $this->response->paginator($transfers, new Transformer());
|
||||
}
|
||||
@ -45,9 +73,9 @@ class Transfers extends ApiController
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
$transfer = Transfer::create($request->all());
|
||||
$transfer = $this->dispatch(new CreateTransfer($request));
|
||||
|
||||
return $this->response->created(url('api/transfers/'.$transfer->id));
|
||||
return $this->response->created(url('api/transfers/' . $transfer->id));
|
||||
}
|
||||
|
||||
/**
|
||||
@ -59,9 +87,9 @@ class Transfers extends ApiController
|
||||
*/
|
||||
public function update(Transfer $transfer, Request $request)
|
||||
{
|
||||
$transfer->update($request->all());
|
||||
$transfer = $this->dispatch(new UpdateTransfer($transfer, $request));
|
||||
|
||||
return $this->response->item($transfer->fresh(), new Transformer());
|
||||
return $this->item($transfer->fresh(), new Transformer());
|
||||
}
|
||||
|
||||
/**
|
||||
@ -72,13 +100,12 @@ class Transfers extends ApiController
|
||||
*/
|
||||
public function destroy(Transfer $transfer)
|
||||
{
|
||||
$payment = Payment::findOrFail($transfer['payment_id']);
|
||||
$revenue = Revenue::findOrFail($transfer['revenue_id']);
|
||||
try {
|
||||
$this->dispatch(new DeleteTransfer($transfer));
|
||||
|
||||
$transfer->delete();
|
||||
$payment->delete();
|
||||
$revenue->delete();
|
||||
|
||||
return $this->response->noContent();
|
||||
return $this->response->noContent();
|
||||
} catch(\Exception $e) {
|
||||
$this->response->errorUnauthorized($e->getMessage());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user