This commit is contained in:
2025-03-26 13:55:16 +05:00
parent 2785f4afdf
commit 619895cb6f
9 changed files with 292 additions and 3 deletions

View File

@@ -0,0 +1,106 @@
<?php
namespace App\Http\Controllers\Api\LoanPaidOffLetterOrder\Requests;
use App\Repos\System\Settings\Legal\PassportRepo;
use App\Repos\System\Settings\Location\RegionRepo;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Validation\Rule;
class LoanPaidOffLetterOrderStoreRequest extends FormRequest
{
/**
* Get the validation rules that apply to the request.
*
* @return array<string, \Illuminate\Contracts\Validation\ValidationRule|array<int, string>|string>
*/
public function rules(): array
{
return [
/**
* Region (https://online.tbbank.gov.tm/api/base-app-enums)
*/
'region' => ['required', 'string', Rule::in(array_keys(RegionRepo::values()))],
/**
* Branch id (https://online.tbbank.gov.tm/api/branches)
*/
'branch_id' => ['required', 'integer', Rule::exists('branches', 'id')],
/**
* Customer name
*
* @example Mahmyt
*/
'customer_name' => ['required', 'string', 'max:255'],
/**
* Customer surname
*
* @example Allaberdiyev
*/
'customer_surname' => ['required', 'string', 'max:255'],
/**
* Customer patronic name
*
* @example Öwezowiç
*/
'customer_patronic_name' => ['nullable', 'string', 'max:255'],
/**
* Passport serie
*/
'passport_serie' => ['required', 'string', Rule::in(PassportRepo::values())],
/**
* Passport number
*
* @example 100999
*/
'passport_id' => ['required', 'numeric', 'digits:6'],
/**
* Date of birth
*
* @example 2000
*/
'born_at' => ['required', 'before_or_equal:today'],
/**
* Phone number
*
* @example 65999990
*/
'phone' => ['required', 'integer', 'between:61000000, 71999999'],
/**
* Contract number
*
* @example 3242358989234
*/
'loan_contract_number' => ['required', 'string', 'max:255'],
/**
* Contract date
*
* @example 20.34.23
*/
'loan_contract_date' => ['required', 'string', 'max:255'],
/**
* Loan amount
*
* @example 20000
*/
'loan_amount' => ['required', 'string', 'max:255'],
/**
* Loan reason
*
* @example Puldan pul yasamak ucin
*/
'loan_reason' => ['required', 'string', 'max:255'],
];
}
}

View File

@@ -0,0 +1,53 @@
<?php
namespace App\Http\Controllers\Api\LoanPaidOffLetterOrder\Resources;
use App\Repos\Order\OrderRepo;
use App\Repos\System\Settings\Location\RegionRepo;
use Illuminate\Http\Request;
use Illuminate\Http\Resources\Json\JsonResource;
/**
* @mixin \App\Models\Order\Loan\LoanPaidOffLetterOrder
*/
class LoanPaidOffLetterOrderIndexResource extends JsonResource
{
/**
* Transform the resource into an array.
*
* @return array<string, mixed>
*/
public function toArray(Request $request): array
{
return [
'id' => $this->id,
'unique_id' => $this->unique_id,
'user_id' => $this->user_id,
'region' => RegionRepo::label($this->region),
'branch_id' => $this->branch?->name,
'customer_name' => $this->customer_name,
'customer_surname' => $this->customer_surname,
'customer_patronic_name' => $this->customer_patronic_name,
'born_at' => $this->born_at,
'phone' => $this->phone,
'passport_serie' => $this->passport_serie,
'passport_id' => $this->passport_id,
'status' => OrderRepo::statusFormatted($this->status),
'notes' => $this->notes,
'loan_contract_number' => $this->loan_contract_number,
'loan_contract_date' => $this->loan_contract_date,
'loan_amount' => $this->loan_amount,
'loan_reason' => $this->loan_reason,
'created_at' => $this->created_at,
'updated_at' => $this->updated_at,
];
}
}

View File

@@ -0,0 +1,47 @@
<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Api\LoanPaidOffLetterOrder\Requests\LoanPaidOffLetterOrderStoreRequest;
use App\Http\Controllers\Api\LoanPaidOffLetterOrder\Resources\LoanPaidOffLetterOrderIndexResource;
use App\Http\Controllers\Controller;
use App\Models\Order\Loan\LoanPaidOffLetterOrder;
use App\Repos\Order\OrderRepo;
use Illuminate\Http\JsonResponse;
use Illuminate\Support\Facades\Log;
class LoanPaidOffLetterOrderController extends Controller
{
/**
* LIST* Loan paid off letters
*/
public function index(): JsonResponse
{
return response()->json(LoanPaidOffLetterOrderIndexResource::collection(
LoanPaidOffLetterOrder::query()
->with('branch')
->where('user_id', auth()->id())
->paginate()
));
}
/**
* SAVE* Loan order.
*/
public function store(LoanPaidOffLetterOrderStoreRequest $request): JsonResponse
{
Log::channel('form_logs')->info('loan-order-store-request', $request->all());
$data = $request->validated();
LoanPaidOffLetterOrder::forceCreate([
...$data,
...[
'user_id' => auth()->id(),
'status' => OrderRepo::PENDING,
'source' => OrderRepo::MOBILE_DEVICE,
],
]);
return response()->json();
}
}

View File

@@ -10,6 +10,29 @@ use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\SoftDeletes;
use Laravel\Nova\Actions\Actionable;
/**
* @property int $id
* @property null|string $unique_id
* @property string $region
* @property int $branch_id
* @property string $customer_name
* @property string $customer_surname
* @property null|string $customer_patronic_name
* @property null|string $born_at
* @property null|string $phone
* @property string $passport_serie
* @property string $passport_id
* @property null|string $status
* @property null|string $notes
* @property int $user_id
* @property null|string $loan_contract_number
* @property null|string $loan_contract_date
* @property null|string $loan_amount
* @property null|string $loan_reason
* @property \Illuminate\Support\Carbon $created_at
* @property \Illuminate\Support\Carbon $updated_at
* @property \Illuminate\Support\Carbon $deleted_at
*/
class LoanPaidOffLetterOrder extends Model
{
use Actionable;

View File

@@ -89,7 +89,6 @@ class MakePaymentNovaVisaMaster extends Action
}
$total_amount = floatval(number_format($payment_amount, 2, '.', '')) + 23;
$total_amount = 0.10;
$payment = $this->order($resource, $total_amount);

View File

@@ -23,7 +23,10 @@ use App\Rules\DowranAgaAllowed;
use App\Rules\OnlyLetters;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\Collection;
use Illuminate\Support\Facades\Gate;
use Laravel\Nova\Actions\Action;
use Laravel\Nova\Fields\ActionFields;
use Laravel\Nova\Fields\Date;
use Laravel\Nova\Fields\Hidden;
use Laravel\Nova\Fields\ID;
@@ -377,4 +380,26 @@ class CardOrder extends Resource
new StatusFilter,
];
}
/**
* Actions
*
* @return array<int, \Laravel\Nova\Actions\Action>
*/
public function actions(NovaRequest $request): array
{
return [
Action::using('Deactivate User', function (ActionFields $fields, Collection $models) {
$resource = $models->first();
$payment = (new OnlinePaymentRepo)->payCardOrder($resource);
return $payment['status'] === 'success'
? URL::remote($payment['url'])
: sprintf('resources/%s/%s', static::uriKey(), $resource->getKey());
})
->icon('credit-card')
->sole(),
];
}
}

View File

@@ -0,0 +1,28 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::table('loan_paid_off_letter_orders', function (Blueprint $table) {
$table->string('loan_paid_off_letter_orders')->nullable();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::table('loan_paid_off_letter_orders', function (Blueprint $table) {
$table->dropColumn('loan_paid_off_letter_orders');
});
}
};

View File

@@ -5,9 +5,9 @@
**completed**
**cancelled**
Schema::getColumnListing('branches')
Schema::getColumnListing('loan_paid_off_letter_orders')
$a = collect(Schema::getColumns('users'))->map(fn ($column) => [
$a = collect(Schema::getColumns('loan_paid_off_letter_orders'))->map(fn ($column) => [
'name' => $column['name'],
'type' => ($column['nullable'] ? 'null|' : '') . dbTypeToPhp($column['type']),
])->pluck('type', 'name')

View File

@@ -2,6 +2,7 @@
use App\Http\Controllers\AlertController;
use App\Http\Controllers\Api\FetchLoanHistoryController;
use App\Http\Controllers\Api\LoanPaidOffLetterOrderController;
use App\Http\Controllers\FetchCardHistoryController;
use App\Http\Controllers\FetchLoanRemainingController;
use App\Http\Controllers\MetricsController;
@@ -73,6 +74,13 @@ Route::middleware(['auth:sanctum', 'not_banned'])->group(function () {
// Loan remaning...
Route::get('loan-remaining', [LoanRemainingOrderController::class, 'index']);
// Loan paid off letters...
Route::get('loan-paid-off-letter-orders', [LoanPaidOffLetterOrderController::class, 'index']);
Route::get('loan-paid-off-letter-orders/{order}', [LoanPaidOffLetterOrderController::class, 'show']);
Route::post('loan-paid-off-letter-orders', [LoanPaidOffLetterOrderController::class, 'store']);
Route::post('loan-paid-off-letter-orders/{order}', [LoanPaidOffLetterOrderController::class, 'update']);
Route::delete('loan-paid-off-letter-orders/{order}', [LoanPaidOffLetterOrderController::class, 'destory']);
// Alerts...
Route::get('alerts', [AlertController::class, 'index']);
});