diff --git a/app/Modules/VisaMasterPaymentOrder/Database/Migrations/2024_11_22_000637_create_visa_master_payment_order_items_table.php b/app/Modules/VisaMasterPaymentOrder/Database/Migrations/2024_11_22_000637_create_visa_master_payment_order_items_table.php new file mode 100644 index 0000000..506e4a9 --- /dev/null +++ b/app/Modules/VisaMasterPaymentOrder/Database/Migrations/2024_11_22_000637_create_visa_master_payment_order_items_table.php @@ -0,0 +1,39 @@ +id(); + $table->foreignId('visa_master_payment_order_id')->constrained('visa_master_payment_orders')->nullOnDelete(); + $table->foreignId('online_payment_history_id')->nullable()->constrained('online_payment_histories')->nullOnDelete(); + + $table->string('payer_name')->nullable(); + $table->string('payer_card')->nullable(); + + $table->string('payment_order_number')->nullable(); + + $table->string('tmt_payment_amount'); + $table->string('usd_payment_amount'); + $table->boolean('paid')->default(false); + + $table->timestamps(); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + Schema::dropIfExists('visa_master_payment_order_items'); + } +}; diff --git a/app/Modules/VisaMasterPaymentOrder/Models/VisaMasterPaymentOrder.php b/app/Modules/VisaMasterPaymentOrder/Models/VisaMasterPaymentOrder.php index b8f54e8..05a3aa6 100644 --- a/app/Modules/VisaMasterPaymentOrder/Models/VisaMasterPaymentOrder.php +++ b/app/Modules/VisaMasterPaymentOrder/Models/VisaMasterPaymentOrder.php @@ -8,6 +8,7 @@ use App\Repos\Order\Loan\LoanOrderRepo; use App\Repos\Order\OrderRepo; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Relations\BelongsTo; +use Illuminate\Database\Eloquent\Relations\HasMany; use Spatie\MediaLibrary\HasMedia; use Spatie\MediaLibrary\InteractsWithMedia; use Spatie\MediaLibrary\MediaCollections\Models\Media; @@ -89,6 +90,14 @@ class VisaMasterPaymentOrder extends Model implements HasMedia return $this->belongsTo(Branch::class); } + /** + * Payment itmes + */ + public function paymentItems(): HasMany + { + return $this->hasMany(VisaMasterPaymentOrderItem::class, 'visa_master_payment_order_id'); + } + /** * Get applications types */ diff --git a/app/Modules/VisaMasterPaymentOrder/Models/VisaMasterPaymentOrderItem.php b/app/Modules/VisaMasterPaymentOrder/Models/VisaMasterPaymentOrderItem.php new file mode 100644 index 0000000..b86cc12 --- /dev/null +++ b/app/Modules/VisaMasterPaymentOrder/Models/VisaMasterPaymentOrderItem.php @@ -0,0 +1,38 @@ +belongsTo(VisaMasterPaymentOrder::class, 'visa_master_payment_order_id'); + } +} diff --git a/app/Modules/VisaMasterPaymentOrder/Nova/Resources/NovaVisaMasterPaymentOrder.php b/app/Modules/VisaMasterPaymentOrder/Nova/Resources/NovaVisaMasterPaymentOrder.php index 918e25b..ea2bd51 100644 --- a/app/Modules/VisaMasterPaymentOrder/Nova/Resources/NovaVisaMasterPaymentOrder.php +++ b/app/Modules/VisaMasterPaymentOrder/Nova/Resources/NovaVisaMasterPaymentOrder.php @@ -19,6 +19,7 @@ use Illuminate\Database\Eloquent\Builder; use Illuminate\Database\Eloquent\Model; use Illuminate\Support\Str; use Laravel\Nova\Fields\Badge; +use Laravel\Nova\Fields\HasMany; use Laravel\Nova\Fields\Hidden; use Laravel\Nova\Fields\ID; use Laravel\Nova\Fields\Select; @@ -342,6 +343,8 @@ class NovaVisaMasterPaymentOrder extends Resource 'sender_passport_local_old_replacement' ), ]), + + // HasMany::make(__('Payment items'), 'paymentItems', ), ]; } diff --git a/app/Nova/Actions/MakePaymentNovaVisaMaster.php b/app/Nova/Actions/MakePaymentNovaVisaMaster.php index 411f348..aa1324a 100644 --- a/app/Nova/Actions/MakePaymentNovaVisaMaster.php +++ b/app/Nova/Actions/MakePaymentNovaVisaMaster.php @@ -5,6 +5,7 @@ namespace App\Nova\Actions; use App\Models\CurrencyRate; use App\Models\Payment\OnlinePaymentHistory; use App\Modules\VisaMasterPaymentOrder\Models\VisaMasterPaymentOrder; +use App\Modules\VisaMasterPaymentOrder\Models\VisaMasterPaymentOrderItem; use App\Modules\VisaMasterSettings\Models\VisaMasterSettings; use App\Repos\Payment\OnlinePaymentRepo; use Illuminate\Bus\Queueable; @@ -17,6 +18,7 @@ use Laravel\Nova\Actions\Action; use Laravel\Nova\Actions\ActionResponse; use Laravel\Nova\Fields\ActionFields; use Laravel\Nova\Fields\Heading; +use Laravel\Nova\Fields\Hidden; use Laravel\Nova\Fields\Text; use Laravel\Nova\Http\Requests\NovaRequest; @@ -41,12 +43,6 @@ class MakePaymentNovaVisaMaster extends Action */ public function handle(ActionFields $fields, Collection $models) { - $usd_to_tmt = CurrencyRate::where('currency_from', 'USD')->where('currency_to', 'TMT')->first('value'); - - if (! $usd_to_tmt) { - return ActionResponse::danger('Walýuta hasaby girizilmedik, operator bilen habarlaşmagyňyzy haýyş edýärin.'); - } - $resource = $models->first(); if (! $resource->branch || ! $resource->branch->billing_visa_master_username) { @@ -57,9 +53,13 @@ class MakePaymentNovaVisaMaster extends Action $payment = $this->order($resource, $total_amount); - return $payment['status'] === 'success' - ? ActionResponse::openInNewTab($payment['url']) - : ActionResponse::danger('Töleg ýerinde näsazlyk!'); + if ($payment['status'] !== 'success') { + return ActionResponse::danger('Töleg ýerinde näsazlyk!'); + } + + $this->createPaymentRecord($payment, $resource, $total_amount, $fields->usd_payment); + + return ActionResponse::openInNewTab($payment['url']); } /** @@ -87,6 +87,11 @@ class MakePaymentNovaVisaMaster extends Action