add visa/master module
This commit is contained in:
@@ -7,5 +7,5 @@ use Illuminate\Database\Eloquent\Model;
|
|||||||
|
|
||||||
class $CLASS_NAME$ extends Model
|
class $CLASS_NAME$ extends Model
|
||||||
{
|
{
|
||||||
use HasUuids;
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,10 +19,10 @@ class ApiAuthController extends Controller
|
|||||||
{
|
{
|
||||||
UserRepo::registerUser($request);
|
UserRepo::registerUser($request);
|
||||||
|
|
||||||
sendSMSVerification($request->phone_number);
|
sendSMSVerification($request->phone);
|
||||||
|
|
||||||
return response()->json([
|
return response()->json([
|
||||||
'message' => sprintf('%s: %s', __('Verification code sent to'), $request->phone_number),
|
'message' => sprintf('%s: %s', __('Verification code sent to'), $request->phone),
|
||||||
], 201);
|
], 201);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -31,10 +31,10 @@ class ApiAuthController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function login(AuthLoginRequest $request): JsonResponse
|
public function login(AuthLoginRequest $request): JsonResponse
|
||||||
{
|
{
|
||||||
sendSMSVerification($request->phone_number);
|
sendSMSVerification($request->phone);
|
||||||
|
|
||||||
return response()->json([
|
return response()->json([
|
||||||
'message' => sprintf('%s: %s', __('Verification code sent to'), $request->phone_number),
|
'message' => sprintf('%s: %s', __('Verification code sent to'), $request->phone),
|
||||||
], 201);
|
], 201);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -43,7 +43,7 @@ class ApiAuthController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function verify(AuthVerifyRequest $request): JsonResponse
|
public function verify(AuthVerifyRequest $request): JsonResponse
|
||||||
{
|
{
|
||||||
$user = User::where('phone_number', $request->phone_number)->firstOrFail();
|
$user = User::where('phone', $request->phone)->firstOrFail();
|
||||||
|
|
||||||
return response()->json([
|
return response()->json([
|
||||||
'message' => $user->createToken(bin2hex(random_bytes(20)))->plainTextToken,
|
'message' => $user->createToken(bin2hex(random_bytes(20)))->plainTextToken,
|
||||||
|
|||||||
@@ -20,7 +20,7 @@ class AuthLoginRequest extends FormRequest
|
|||||||
* @var int
|
* @var int
|
||||||
* @example 65707012
|
* @example 65707012
|
||||||
*/
|
*/
|
||||||
'phone_number' => ['required', 'integer', 'between:61000000,71999999'],
|
'phone' => ['required', 'integer', 'between:61000000,71999999'],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -20,7 +20,7 @@ class AuthRegisterRequest extends FormRequest
|
|||||||
* @var int
|
* @var int
|
||||||
* @example 65707012
|
* @example 65707012
|
||||||
*/
|
*/
|
||||||
'phone_number' => ['required', 'integer', 'between:61000000,71999999', 'unique:users,phone_number'],
|
'phone' => ['required', 'integer', 'between:61000000,71999999', 'unique:users,phone'],
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* User's name
|
* User's name
|
||||||
|
|||||||
@@ -18,18 +18,16 @@ class AuthVerifyRequest extends FormRequest
|
|||||||
/**
|
/**
|
||||||
* Phone number to authenticate
|
* Phone number to authenticate
|
||||||
*
|
*
|
||||||
* @var int
|
|
||||||
* @example 65707012
|
* @example 65707012
|
||||||
*/
|
*/
|
||||||
'phone_number' => ['required', 'integer', 'between:61000000,65999999'],
|
'phone' => ['required', 'integer', 'between:61000000,65999999'],
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verification code (OTP)
|
* Verification code (OTP)
|
||||||
*
|
*
|
||||||
* @var int
|
|
||||||
* @example 432123
|
* @example 432123
|
||||||
*/
|
*/
|
||||||
'code' => ['required', 'integer', new PhoneCodeVerification($this->phone_number)],
|
'code' => ['required', 'integer', new PhoneCodeVerification($this->phone)],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,48 @@
|
|||||||
|
<?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::create('visa_master_payment_orders', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->string('unique_id')->nullable()->unique();
|
||||||
|
|
||||||
|
$table->string('type')->nullable();
|
||||||
|
$table->string('passport_name')->nullable();
|
||||||
|
$table->string('passport_surname')->nullable();
|
||||||
|
$table->string('phone')->nullable();
|
||||||
|
$table->string('email')->nullable();
|
||||||
|
$table->string('region')->nullable();
|
||||||
|
|
||||||
|
$table->foreignId('branch_id')->nullable()->constrained('branches')->cascadeOnDelete();
|
||||||
|
$table->foreignId('user_id')->nullable()->constrained('users')->cascadeOnDelete();
|
||||||
|
|
||||||
|
$table->string('address')->nullable();
|
||||||
|
|
||||||
|
$table->json('sender_datas')->nullable();
|
||||||
|
$table->json('payment_reciever')->nullable();
|
||||||
|
|
||||||
|
$table->json('documents')->nullable();
|
||||||
|
|
||||||
|
$table->string('status')->nullable();
|
||||||
|
$table->string('notes')->nullable();
|
||||||
|
$table->timestamps();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('visa_master_payment_orders');
|
||||||
|
}
|
||||||
|
};
|
||||||
@@ -0,0 +1,76 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Modules\VisaMasterPaymentOrder\Models;
|
||||||
|
|
||||||
|
use App\Models\Branch\Branch;
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
||||||
|
use Spatie\MediaLibrary\HasMedia;
|
||||||
|
use Spatie\MediaLibrary\InteractsWithMedia;
|
||||||
|
use Spatie\MediaLibrary\MediaCollections\Models\Media;
|
||||||
|
|
||||||
|
class VisaMasterPaymentOrder extends Model implements HasMedia
|
||||||
|
{
|
||||||
|
use InteractsWithMedia;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Table
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $table = 'visa_master_payment_orders';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Guarded attributes
|
||||||
|
*/
|
||||||
|
protected $guarded = [];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The attributes that should be cast.
|
||||||
|
*
|
||||||
|
* @var array<string, string>
|
||||||
|
*/
|
||||||
|
protected $casts = [
|
||||||
|
'sender_datas' => 'array',
|
||||||
|
'payment_reciever' => 'array',
|
||||||
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Media conversions
|
||||||
|
*
|
||||||
|
* @param Media|null $media
|
||||||
|
*/
|
||||||
|
public function registerMediaConversions(?Media $media = null): void
|
||||||
|
{
|
||||||
|
$this->addMediaConversion('thumb')
|
||||||
|
->width(200)
|
||||||
|
->height(200);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Media collections
|
||||||
|
*/
|
||||||
|
public function registerMediaCollections(): void
|
||||||
|
{
|
||||||
|
$this->addMediaCollection('main');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Branch
|
||||||
|
*/
|
||||||
|
public function branch(): BelongsTo
|
||||||
|
{
|
||||||
|
return $this->belongsTo(Branch::class);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get applications types
|
||||||
|
*/
|
||||||
|
public static function applicationTypes(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'visa' => __('Visa'),
|
||||||
|
'master' => __('Master'),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,66 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Modules\VisaMasterPaymentOrder\Nova\Resources\Concerns;
|
||||||
|
|
||||||
|
use App\Modules\VisaMasterPaymentOrder\Models\VisaMasterPaymentOrder;
|
||||||
|
use App\Nova\Resources\Branch\Branch;
|
||||||
|
use App\Repos\Order\OrderRepo;
|
||||||
|
use App\Repos\System\Settings\Location\RegionRepo;
|
||||||
|
use Laravel\Nova\Fields\Badge;
|
||||||
|
use Laravel\Nova\Fields\BelongsTo;
|
||||||
|
use Laravel\Nova\Fields\DateTime;
|
||||||
|
use Laravel\Nova\Fields\ID;
|
||||||
|
use Laravel\Nova\Fields\Select;
|
||||||
|
use Laravel\Nova\Fields\Text;
|
||||||
|
|
||||||
|
class VisaMasterPaymentOrderFieldsForIndex
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Loan Order fields for "create"
|
||||||
|
*/
|
||||||
|
public static function make($resource): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
ID::make()->hide(),
|
||||||
|
|
||||||
|
Text::make(__('ID'), 'unique_id')->sortable(),
|
||||||
|
|
||||||
|
Select::make(__('Ýüztutmanyň görnüşi'), 'type')
|
||||||
|
->fullWidth()
|
||||||
|
->searchable()
|
||||||
|
->rules('required')
|
||||||
|
->displayUsingLabels()
|
||||||
|
->options(VisaMasterPaymentOrder::applicationTypes()),
|
||||||
|
|
||||||
|
DateTime::make(__('Created at'), 'created_at')
|
||||||
|
->turkmenDateTime(),
|
||||||
|
|
||||||
|
Select::make(__('Region'), 'region')
|
||||||
|
->displayUsingLabels()
|
||||||
|
->options(RegionRepo::values())
|
||||||
|
->canSeeWhen('isAdmin', $resource)
|
||||||
|
->sortable(),
|
||||||
|
|
||||||
|
BelongsTo::make(__('Branch'), 'branch', Branch::class)
|
||||||
|
->canSeeWhen('isAdmin', $resource)
|
||||||
|
->filterable()
|
||||||
|
->sortable(),
|
||||||
|
|
||||||
|
Text::make(__('Name'), 'passport_name'),
|
||||||
|
|
||||||
|
Text::make(__('Surname'), 'passport_surname'),
|
||||||
|
|
||||||
|
Text::make(__('Phone'), 'phone'),
|
||||||
|
|
||||||
|
Badge::make(__('Status'), 'status')
|
||||||
|
->map(OrderRepo::statusClasses())
|
||||||
|
->addTypes([
|
||||||
|
'primary' => 'dark:bg-gray-900 bg-gray-600 text-white',
|
||||||
|
])
|
||||||
|
->labels(OrderRepo::statusValues())
|
||||||
|
->withIcons()
|
||||||
|
->icons(OrderRepo::statusIcons())
|
||||||
|
->sortable(),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,241 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Modules\VisaMasterPaymentOrder\Nova\Resources;
|
||||||
|
|
||||||
|
use App\Models\Branch\Branch;
|
||||||
|
use App\Modules\VisaMasterPaymentOrder\Models\VisaMasterPaymentOrder;
|
||||||
|
use App\Modules\VisaMasterPaymentOrder\Nova\Resources\Concerns\VisaMasterPaymentOrderFieldsForIndex;
|
||||||
|
use App\Nova\Resource;
|
||||||
|
use App\Repos\Order\Card\CardOrderRepo;
|
||||||
|
use App\Repos\Order\OrderRepo;
|
||||||
|
use App\Repos\System\Nova\NovaRepo;
|
||||||
|
use App\Repos\System\Settings\Legal\PassportRepo;
|
||||||
|
use App\Repos\System\Settings\Location\RegionRepo;
|
||||||
|
use Ebess\AdvancedNovaMediaLibrary\Fields\Files;
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
use Illuminate\Support\Str;
|
||||||
|
use Laravel\Nova\Fields\Badge;
|
||||||
|
use Laravel\Nova\Fields\Hidden;
|
||||||
|
use Laravel\Nova\Fields\ID;
|
||||||
|
use Laravel\Nova\Fields\Select;
|
||||||
|
use Laravel\Nova\Fields\Text;
|
||||||
|
use Laravel\Nova\Http\Requests\NovaRequest;
|
||||||
|
use Laravel\Nova\Panel;
|
||||||
|
use Nurmuhammet\NovaInputmask\NovaInputmask;
|
||||||
|
use Outl1ne\NovaSimpleRepeatable\SimpleRepeatable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @template TModel of \App\Modules\VisaMasterPaymentOrder\Models\VisaMasterPaymentOrder
|
||||||
|
*/
|
||||||
|
class NovaVisaMasterPaymentOrder extends Resource
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The model the resource corresponds to.
|
||||||
|
*
|
||||||
|
* @var class-string<\App\Modules\VisaMasterPaymentOrder\Models\VisaMasterPaymentOrder>
|
||||||
|
*/
|
||||||
|
public static $model = \App\Modules\VisaMasterPaymentOrder\Models\VisaMasterPaymentOrder::class;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The single value that should be used to represent the resource when being displayed.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
public static $title = 'unique_id';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The columns that should be searched.
|
||||||
|
*
|
||||||
|
* @var array<int, string>
|
||||||
|
*/
|
||||||
|
public static $search = [
|
||||||
|
'unique_id', 'passport_name', 'passport_surname', 'phone',
|
||||||
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the displayable label of the resource.
|
||||||
|
*/
|
||||||
|
public static function label(): string
|
||||||
|
{
|
||||||
|
return sprintf(
|
||||||
|
'%s (%s)',
|
||||||
|
__('Visa/Master payments'),
|
||||||
|
Str::lower(__('For students'))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the displayable singular label of the resource.
|
||||||
|
*/
|
||||||
|
public static function singularLabel(): string
|
||||||
|
{
|
||||||
|
return sprintf(
|
||||||
|
'%s (%s)',
|
||||||
|
__('Visa/Master payment'),
|
||||||
|
Str::lower(__('For students'))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* After resource created
|
||||||
|
*
|
||||||
|
* @param \Laravel\Nova\Http\Requests\NovaRequest $request
|
||||||
|
* @param \Illuminate\Database\Eloquent\Model $model
|
||||||
|
*/
|
||||||
|
public static function afterCreate(NovaRequest $request, Model $model): void
|
||||||
|
{
|
||||||
|
$model->update(['unique_id' => CardOrderRepo::fillUniqueId($model)]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the fields for index.
|
||||||
|
*/
|
||||||
|
public function fieldsForIndex(): array
|
||||||
|
{
|
||||||
|
return VisaMasterPaymentOrderFieldsForIndex::make($this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the fields displayed by the resource.
|
||||||
|
*
|
||||||
|
* @param \Laravel\Nova\Http\Requests\NovaRequest $request
|
||||||
|
* @return array<int, \Laravel\Nova\Fields\FieldElement|\Laravel\Nova\Panel>
|
||||||
|
*/
|
||||||
|
public function fields(NovaRequest $request): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
ID::hidden(),
|
||||||
|
|
||||||
|
Hidden::make('user_id')
|
||||||
|
->default(auth()->id())
|
||||||
|
->hideWhenUpdating(),
|
||||||
|
|
||||||
|
new Panel(__('New :resource', ['resource' => $this->singularLabel()]), [
|
||||||
|
Text::make(__('ID'), 'unique_id')
|
||||||
|
->exceptOnForms(),
|
||||||
|
|
||||||
|
Select::make(__('Status'), 'status')
|
||||||
|
->displayUsingLabels()
|
||||||
|
->searchable()
|
||||||
|
->options(OrderRepo::statusValues())
|
||||||
|
->default(OrderRepo::defaultStatus())
|
||||||
|
->fullWidth()
|
||||||
|
->hideFromDetail()
|
||||||
|
->rules('required')
|
||||||
|
->canSeeWhen('systemUser', $this),
|
||||||
|
|
||||||
|
Badge::make(__('Status'), 'status')
|
||||||
|
->map(OrderRepo::statusClasses())
|
||||||
|
->addTypes([
|
||||||
|
'primary' => 'dark:bg-gray-900 bg-gray-600 text-white',
|
||||||
|
])
|
||||||
|
->labels(OrderRepo::statusValues())
|
||||||
|
->withIcons()
|
||||||
|
->icons(OrderRepo::statusIcons()),
|
||||||
|
|
||||||
|
Text::make(__('Note'), 'notes')
|
||||||
|
->fullWidth()
|
||||||
|
->canSeeWhen('systemUser', $this),
|
||||||
|
]),
|
||||||
|
|
||||||
|
new Panel(__('Application type'), [
|
||||||
|
Select::make(__('Application type'), 'type')
|
||||||
|
->fullWidth()
|
||||||
|
->searchable()
|
||||||
|
->rules('required')
|
||||||
|
->displayUsingLabels()
|
||||||
|
->options(VisaMasterPaymentOrder::applicationTypes()),
|
||||||
|
]),
|
||||||
|
|
||||||
|
new Panel(__('Location'), [
|
||||||
|
Select::make(__('Region'), 'region')
|
||||||
|
->fullWidth()
|
||||||
|
->displayUsingLabels()
|
||||||
|
->searchable()
|
||||||
|
->options(RegionRepo::values())
|
||||||
|
->default(RegionRepo::default())
|
||||||
|
->rules('required')
|
||||||
|
->sortable(),
|
||||||
|
|
||||||
|
Select::make(__('Branch'), 'branch_id')
|
||||||
|
->fullWidth()
|
||||||
|
->displayUsingLabels()
|
||||||
|
->searchable()
|
||||||
|
->dependsOn('region', NovaRepo::dependsOnRegion('region', Branch::class))
|
||||||
|
->rules('required')
|
||||||
|
->sortable(),
|
||||||
|
]),
|
||||||
|
|
||||||
|
new Panel(__('Personal data'), [
|
||||||
|
Text::make(__('Passport name'), 'passport_name')
|
||||||
|
->fullWidth()
|
||||||
|
->rules('required', 'string', 'max:255'),
|
||||||
|
|
||||||
|
Text::make(__('Passport surname'), 'passport_surname')
|
||||||
|
->fullWidth()
|
||||||
|
->rules('required', 'string', 'max:255'),
|
||||||
|
|
||||||
|
NovaInputmask::make(__('Phone'), 'phone')
|
||||||
|
->fullWidth()
|
||||||
|
->phonenumber('TM')
|
||||||
|
->rules('required', 'max:255')
|
||||||
|
->hideFromIndex(),
|
||||||
|
|
||||||
|
Text::make(__('Email'), 'email')
|
||||||
|
->fullWidth()
|
||||||
|
->rules('nullable', 'max:255', 'email')
|
||||||
|
->hideFromIndex(),
|
||||||
|
|
||||||
|
Text::make(__('Current Residence'), 'address')
|
||||||
|
->fullWidth()
|
||||||
|
->rules('required', 'string', 'max:255')
|
||||||
|
->hideFromIndex(),
|
||||||
|
]),
|
||||||
|
|
||||||
|
new Panel(__('Payment'), [
|
||||||
|
SimpleRepeatable::make(__('Payment sender data'), 'sender_datas', [
|
||||||
|
Select::make(__('Passport serie'), 'passport_serie')
|
||||||
|
->displayUsingLabels()
|
||||||
|
->searchable()
|
||||||
|
->options(PassportRepo::values())
|
||||||
|
->rules('required')
|
||||||
|
->sortable(),
|
||||||
|
|
||||||
|
NovaInputmask::make(__('Passport number'), 'passport_number')
|
||||||
|
->mask('999999')
|
||||||
|
->rules('required', 'max:255'),
|
||||||
|
|
||||||
|
Text::make(
|
||||||
|
name: sprintf('%s %s %s', __('Name'), __('Surname'), __('Patronic name')),
|
||||||
|
attribute: 'full_name'
|
||||||
|
)
|
||||||
|
->rules('required', 'max:255'),
|
||||||
|
])->minRows(1)->rules('required'),
|
||||||
|
|
||||||
|
SimpleRepeatable::make('Tölegi kabul edijiniň maglumatlary', 'payment_reciever', [
|
||||||
|
Select::make(__('Passport serie'), 'passport_serie')
|
||||||
|
->displayUsingLabels()
|
||||||
|
->searchable()
|
||||||
|
->options(PassportRepo::values())
|
||||||
|
->rules('required')
|
||||||
|
->sortable(),
|
||||||
|
|
||||||
|
NovaInputmask::make(__('Passport number'), 'passport_number')
|
||||||
|
->mask('999999')
|
||||||
|
->rules('required', 'max:255'),
|
||||||
|
|
||||||
|
Text::make(
|
||||||
|
name: sprintf('%s %s %s', __('Name'), __('Surname'), __('Patronic name')),
|
||||||
|
attribute: 'full_name'
|
||||||
|
),
|
||||||
|
])->maxRows(1)->minRows(1)->rules('required'),
|
||||||
|
|
||||||
|
Files::make('Talap edilýän resminamalar', 'main')
|
||||||
|
->conversionOnIndexView('thumb')
|
||||||
|
->rules('required')
|
||||||
|
->required()
|
||||||
|
->hideFromIndex(),
|
||||||
|
]),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -146,6 +146,7 @@ class NovaServiceProvider extends NovaApplicationServiceProvider
|
|||||||
public function setupAssets(): void
|
public function setupAssets(): void
|
||||||
{
|
{
|
||||||
Nova::style('additional', resource_path('css/vendor/nova/css/additional.css'));
|
Nova::style('additional', resource_path('css/vendor/nova/css/additional.css'));
|
||||||
|
Nova::script('additional', resource_path('js/vendor/nova/js/additional.js'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -3,6 +3,7 @@
|
|||||||
namespace App\Repos\System\Nova;
|
namespace App\Repos\System\Nova;
|
||||||
|
|
||||||
use App\Modules\Swiftpayment\Nova\Resources\NovaSwiftpayment;
|
use App\Modules\Swiftpayment\Nova\Resources\NovaSwiftpayment;
|
||||||
|
use App\Modules\VisaMasterPaymentOrder\Nova\Resources\NovaVisaMasterPaymentOrder;
|
||||||
use App\Nova\Dashboards\Main;
|
use App\Nova\Dashboards\Main;
|
||||||
use App\Nova\Resources\Branch\Branch;
|
use App\Nova\Resources\Branch\Branch;
|
||||||
use App\Nova\Resources\Order\Card\CardOrder;
|
use App\Nova\Resources\Order\Card\CardOrder;
|
||||||
@@ -52,6 +53,8 @@ class NovaMenuRepo
|
|||||||
MenuGroup::make(__('Swift payments'), [
|
MenuGroup::make(__('Swift payments'), [
|
||||||
MenuItem::resource(NovaSwiftpayment::class)
|
MenuItem::resource(NovaSwiftpayment::class)
|
||||||
->name(sprintf('%s (%s)', __('International payments'), __('Visa, Master, Sber, WU'))),
|
->name(sprintf('%s (%s)', __('International payments'), __('Visa, Master, Sber, WU'))),
|
||||||
|
|
||||||
|
MenuItem::resource(NovaVisaMasterPaymentOrder::class),
|
||||||
])->collapsedByDefault(),
|
])->collapsedByDefault(),
|
||||||
])->icon('ticket')->collapsedByDefault(),
|
])->icon('ticket')->collapsedByDefault(),
|
||||||
|
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ class UserRepo
|
|||||||
public static function registerUser(Request $request): User
|
public static function registerUser(Request $request): User
|
||||||
{
|
{
|
||||||
return User::create([
|
return User::create([
|
||||||
'phone_number' => $request->phone_number,
|
'phone' => $request->phone,
|
||||||
'name' => $request->name,
|
'name' => $request->name,
|
||||||
'username' => static::generateUsername($request->name),
|
'username' => static::generateUsername($request->name),
|
||||||
'locale' => app()->getLocale(),
|
'locale' => app()->getLocale(),
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ use Illuminate\Contracts\Validation\ValidationRule;
|
|||||||
class PhoneCodeVerification implements ValidationRule
|
class PhoneCodeVerification implements ValidationRule
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
protected int|string $phone,
|
protected null|int|string $phone,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -19,6 +19,12 @@ class PhoneCodeVerification implements ValidationRule
|
|||||||
*/
|
*/
|
||||||
public function validate(string $attribute, mixed $value, Closure $fail): void
|
public function validate(string $attribute, mixed $value, Closure $fail): void
|
||||||
{
|
{
|
||||||
|
if (is_null($this->phone)) {
|
||||||
|
$fail(__('Could not parse phone number'));
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
$verification = Verification::where('username', $this->phone)
|
$verification = Verification::where('username', $this->phone)
|
||||||
->where('code', $value)
|
->where('code', $value)
|
||||||
->first();
|
->first();
|
||||||
|
|||||||
14
lang/tk.json
14
lang/tk.json
@@ -126,9 +126,12 @@
|
|||||||
"Passport given by": "Kim tarapyndan berildi",
|
"Passport given by": "Kim tarapyndan berildi",
|
||||||
"Passport id": "Pasport belgisi",
|
"Passport id": "Pasport belgisi",
|
||||||
"Passport serie": "Pasport seriýasy",
|
"Passport serie": "Pasport seriýasy",
|
||||||
|
"Passport name": "Pasportdaky ady",
|
||||||
|
"Passport surname": "Pasportdaky familiýa",
|
||||||
"Password": "Açar sözi",
|
"Password": "Açar sözi",
|
||||||
"Patronic name": "Ataňyzyň ady",
|
"Patronic name": "Atasynyň ady",
|
||||||
"Payload Too Large": "Loadük gaty uly",
|
"Payload Too Large": "Loadük gaty uly",
|
||||||
|
"Payment": "Töleg",
|
||||||
"Payment Required": "Töleg talap edilýär",
|
"Payment Required": "Töleg talap edilýär",
|
||||||
"Pending": "Garaşylýar",
|
"Pending": "Garaşylýar",
|
||||||
"Permanent Redirect": "Hemişelik gönükdirme",
|
"Permanent Redirect": "Hemişelik gönükdirme",
|
||||||
@@ -176,7 +179,7 @@
|
|||||||
"Showing": "Görkezmek",
|
"Showing": "Görkezmek",
|
||||||
"Single": "Öýlenmedik/Durmuşa çykmadyk",
|
"Single": "Öýlenmedik/Durmuşa çykmadyk",
|
||||||
"SSL Handshake Failed": "SSL el çarpmak şowsuz boldy",
|
"SSL Handshake Failed": "SSL el çarpmak şowsuz boldy",
|
||||||
"Surname": "Familiýa",
|
"Surname": "Familiýasy",
|
||||||
"Switching Protocols": "Protokollary çalyşmak",
|
"Switching Protocols": "Protokollary çalyşmak",
|
||||||
"System": "Ulgam",
|
"System": "Ulgam",
|
||||||
"Tax": "Salgyt",
|
"Tax": "Salgyt",
|
||||||
@@ -287,5 +290,10 @@
|
|||||||
"Swift payments": "Swift tölegler",
|
"Swift payments": "Swift tölegler",
|
||||||
"Swift payment": "Swift töleg",
|
"Swift payment": "Swift töleg",
|
||||||
"International payments": "Halkara tölegler",
|
"International payments": "Halkara tölegler",
|
||||||
"Visa, Master, Sber, WU": "Visa, Master, Sber, WU"
|
"Visa, Master, Sber, WU": "Visa, Master, Sber, WU",
|
||||||
|
"Visa/Master payment": "Visa/Master tölegler",
|
||||||
|
"Visa/Master payments": "Visa/Master tölegleri",
|
||||||
|
"For students": "Talyplar üçin",
|
||||||
|
"Application type": "Ýüztutmanyň görnüşi",
|
||||||
|
"Payment sender data": "Tölegi ugradyjynyň maglumatlar"
|
||||||
}
|
}
|
||||||
|
|||||||
6
resources/css/vendor/nova/css/additional.css
vendored
6
resources/css/vendor/nova/css/additional.css
vendored
@@ -28,3 +28,9 @@ dialog a {
|
|||||||
/*div[data-popper-placement=bottom-start] {*/
|
/*div[data-popper-placement=bottom-start] {*/
|
||||||
/* display: contents;*/
|
/* display: contents;*/
|
||||||
/*}*/
|
/*}*/
|
||||||
|
|
||||||
|
|
||||||
|
button[dusk="update-and-continue-editing-button"],
|
||||||
|
button[dusk="create-and-add-another-button"] {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|||||||
0
resources/js/vendor/nova/js/additional.js
vendored
Normal file
0
resources/js/vendor/nova/js/additional.js
vendored
Normal file
@@ -20,3 +20,9 @@ Route::post('auth/login', [ApiAuthController::class, 'login']);
|
|||||||
Route::post('auth/verify', [ApiAuthController::class, 'verify']);
|
Route::post('auth/verify', [ApiAuthController::class, 'verify']);
|
||||||
Route::middleware('auth:sanctum')
|
Route::middleware('auth:sanctum')
|
||||||
->post('auth/delete-user', [ApiAuthController::class, 'delete']);
|
->post('auth/delete-user', [ApiAuthController::class, 'delete']);
|
||||||
|
|
||||||
|
Route::middleware(['auth:sanctum', 'banned'])->group(function () {
|
||||||
|
// Profile...
|
||||||
|
// Route::get('profile', [ProfileController::class, 'index']);
|
||||||
|
// Route::post('profile', [ProfileController::class, 'store']);
|
||||||
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user