wip
This commit is contained in:
@@ -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'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -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,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -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();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -10,6 +10,29 @@ use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
|||||||
use Illuminate\Database\Eloquent\SoftDeletes;
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
||||||
use Laravel\Nova\Actions\Actionable;
|
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
|
class LoanPaidOffLetterOrder extends Model
|
||||||
{
|
{
|
||||||
use Actionable;
|
use Actionable;
|
||||||
|
|||||||
@@ -89,7 +89,6 @@ class MakePaymentNovaVisaMaster extends Action
|
|||||||
}
|
}
|
||||||
|
|
||||||
$total_amount = floatval(number_format($payment_amount, 2, '.', '')) + 23;
|
$total_amount = floatval(number_format($payment_amount, 2, '.', '')) + 23;
|
||||||
$total_amount = 0.10;
|
|
||||||
|
|
||||||
$payment = $this->order($resource, $total_amount);
|
$payment = $this->order($resource, $total_amount);
|
||||||
|
|
||||||
|
|||||||
@@ -23,7 +23,10 @@ use App\Rules\DowranAgaAllowed;
|
|||||||
use App\Rules\OnlyLetters;
|
use App\Rules\OnlyLetters;
|
||||||
use Illuminate\Database\Eloquent\Builder;
|
use Illuminate\Database\Eloquent\Builder;
|
||||||
use Illuminate\Database\Eloquent\Model;
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
use Illuminate\Support\Collection;
|
||||||
use Illuminate\Support\Facades\Gate;
|
use Illuminate\Support\Facades\Gate;
|
||||||
|
use Laravel\Nova\Actions\Action;
|
||||||
|
use Laravel\Nova\Fields\ActionFields;
|
||||||
use Laravel\Nova\Fields\Date;
|
use Laravel\Nova\Fields\Date;
|
||||||
use Laravel\Nova\Fields\Hidden;
|
use Laravel\Nova\Fields\Hidden;
|
||||||
use Laravel\Nova\Fields\ID;
|
use Laravel\Nova\Fields\ID;
|
||||||
@@ -377,4 +380,26 @@ class CardOrder extends Resource
|
|||||||
new StatusFilter,
|
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(),
|
||||||
|
];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
@@ -5,9 +5,9 @@
|
|||||||
**completed**
|
**completed**
|
||||||
**cancelled**
|
**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'],
|
'name' => $column['name'],
|
||||||
'type' => ($column['nullable'] ? 'null|' : '') . dbTypeToPhp($column['type']),
|
'type' => ($column['nullable'] ? 'null|' : '') . dbTypeToPhp($column['type']),
|
||||||
])->pluck('type', 'name')
|
])->pluck('type', 'name')
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
use App\Http\Controllers\AlertController;
|
use App\Http\Controllers\AlertController;
|
||||||
use App\Http\Controllers\Api\FetchLoanHistoryController;
|
use App\Http\Controllers\Api\FetchLoanHistoryController;
|
||||||
|
use App\Http\Controllers\Api\LoanPaidOffLetterOrderController;
|
||||||
use App\Http\Controllers\FetchCardHistoryController;
|
use App\Http\Controllers\FetchCardHistoryController;
|
||||||
use App\Http\Controllers\FetchLoanRemainingController;
|
use App\Http\Controllers\FetchLoanRemainingController;
|
||||||
use App\Http\Controllers\MetricsController;
|
use App\Http\Controllers\MetricsController;
|
||||||
@@ -73,6 +74,13 @@ Route::middleware(['auth:sanctum', 'not_banned'])->group(function () {
|
|||||||
// Loan remaning...
|
// Loan remaning...
|
||||||
Route::get('loan-remaining', [LoanRemainingOrderController::class, 'index']);
|
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...
|
// Alerts...
|
||||||
Route::get('alerts', [AlertController::class, 'index']);
|
Route::get('alerts', [AlertController::class, 'index']);
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user