add nova loan remaingin

This commit is contained in:
2025-06-11 13:04:33 +05:00
parent bdfd550f4e
commit 589a3ed988
6 changed files with 215 additions and 41 deletions

View File

@@ -0,0 +1,13 @@
<?php
namespace App\Http\Controllers\Api\CardOrder;
use App\Http\Controllers\Controller;
use Dedoc\Scramble\Attributes\Group;
use Illuminate\Http\Request;
#[Group('Sargytlar - Kart - Täze kart')]
class CardOrderController extends Controller
{
//
}

View File

@@ -0,0 +1,125 @@
<?php
namespace App\Http\Controllers\Api\LoanOrder\Remaining;
use App\Http\Controllers\Controller;
use App\Modules\LoanRemainingOrder\Models\LoanRemainingOrder;
use App\Repos\System\Settings\Legal\PassportRepo;
use Dedoc\Scramble\Attributes\Group;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Illuminate\Validation\Rule;
#[Group('Sargytlar - Karz - Karzyň galyndysy')]
class LoanOrderRemainingOrderController extends Controller
{
/**
* LIST*
*/
public function index(): JsonResponse
{
return response()->json(
LoanRemainingOrder::query()
->where('user_id', auth()->id())
->get()
);
}
/**
* SAVE*
*/
public function store(Request $request): JsonResponse
{
$data = $request->validate([
/**
* @example I-AS
*/
'passport_serie' => ['required', Rule::in(array_keys(PassportRepo::values()))],
/**
* @example 379514
*/
'passport_id' => ['required', 'numeric', 'digits:6'],
/**
* @example 14208934130700002997232
*/
'account_number' => ['required', 'string'],
]);
LoanRemainingOrder::forceCreate([
...$data,
...[
'user_id' => auth()->id(),
],
]);
return response()->json([
'message' => __('Successfully created'),
], 201);
}
/**
* SHOW*
*
* ID ugradyp alyan route -da.
*/
public function show(LoanRemainingOrder $order): JsonResponse
{
if ($order->user_id != auth()->id()) {
return response()->json(status: 403);
}
return response()->json($order);
}
/**
* UPDATE*
*
* ID ugradyp `route`-da update edip bilyan. Base App Enum-lardan peydalan. Panelkadan gor.
*/
public function update(Request $request, LoanRemainingOrder $order): JsonResponse
{
$data = $request->validate([
/**
* @example I-AS
*/
'passport_serie' => ['sometimes', Rule::in(array_keys(PassportRepo::values()))],
/**
* @example 379514
*/
'passport_id' => ['sometimes', 'numeric', 'digits:6'],
/**
* @example 14208934130700002997232
*/
'account_number' => ['sometimes', 'string'],
]);
Model::unguarded(function () use ($order, $data) {
$order->update($data);
});
return response()->json([
'message' => __('Successfully updated'),
]);
}
/**
* DELETE*
*/
public function destroy(LoanRemainingOrder $order): JsonResponse
{
if ($order->user_id != auth()->id()) {
return response()->json(status: 403);
}
$order->delete();
return response()->json([
'message' => __('Successfully deleted')
]);
}
}

View File

@@ -7,13 +7,17 @@ use App\Http\Controllers\Api\LoanPaidOffLetterOrder\Resources\LoanPaidOffLetterO
use App\Http\Controllers\Controller;
use App\Models\Order\Loan\LoanPaidOffLetterOrder;
use App\Repos\Order\OrderRepo;
use Dedoc\Scramble\Attributes\Group;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Log;
#[Group('Sargytlar - Karz - Karzyň ýapylandygy barada güwanama')]
class LoanPaidOffLetterOrderController extends Controller
{
/**
* LIST* Loan paid off letters
* LIST*
*/
public function index(): JsonResponse
{
@@ -21,12 +25,12 @@ class LoanPaidOffLetterOrderController extends Controller
LoanPaidOffLetterOrder::query()
->with('branch')
->where('user_id', auth()->id())
->paginate()
->get()
));
}
/**
* SAVE* Loan order.
* SAVE*
*/
public function store(LoanPaidOffLetterOrderStoreRequest $request): JsonResponse
{
@@ -42,6 +46,54 @@ class LoanPaidOffLetterOrderController extends Controller
],
]);
return response()->json([
'message' => __('Successfully created'),
], 201);
}
/**
* SHOW*
*
* ID ugradyp alyan route -da.
*/
public function show(LoanPaidOffLetterOrder $loanPaidOffLetter): JsonResponse
{
if ($loanPaidOffLetter->user_id != auth()->id()) {
return response()->json(status: 403);
}
return response()->json(new LoanPaidOffLetterOrderIndexResource($loanPaidOffLetter));
}
/**
* UPDATE*
*
* ID ugradyp `route`-da update edip bilyan. Base App Enum-lardan peydalan. Panelkadan gor.
*/
public function update(Request $request, LoanPaidOffLetterOrder $loanPaidOffLetter): JsonResponse
{
$data = $request->all();
Model::unguarded(function () use ($loanPaidOffLetter, $data) {
$loanPaidOffLetter->update($data);
});
return response()->json([
'message' => __('Successfully updated'),
]);
}
/**
* DELETE*
*/
public function destroy(LoanPaidOffLetterOrder $loanPaidOffLetter): JsonResponse
{
if ($loanPaidOffLetter->user_id === auth()->id()) {
return response()->json(status: 403);
}
$loanPaidOffLetter->delete();
return response()->json();
}
}