WIP on loan order
This commit is contained in:
@@ -2,6 +2,19 @@
|
||||
|
||||
namespace App\Nova\Resources\Order\Loan\Concerns;
|
||||
|
||||
use App\Models\Branch\Branch;
|
||||
use Closure;
|
||||
|
||||
class LoanOrderNovaRepo
|
||||
{
|
||||
public function fillUniqueId(): Closure
|
||||
{
|
||||
return function ($request, $model, $attribute, $requestAttribute) {
|
||||
$model->{$attribute} = mb_strtoupper(sprintf(
|
||||
'%s-%s',
|
||||
Branch::find($request->branch_id)->unique_code,
|
||||
$request->id
|
||||
)) ?? uniqid();
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
@@ -5,6 +5,7 @@ namespace App\Nova\Resources\Order\Loan;
|
||||
use App\Models\Order\Loan\LoanOrder as LoanOrderModel;
|
||||
use App\Nova\Resource;
|
||||
use App\Nova\Resources\Branch\Concerns\BranchNovaRepo;
|
||||
use App\Nova\Resources\Order\Loan\Concerns\LoanOrderNovaRepo;
|
||||
use App\Repos\Order\Loan\BranchRepo;
|
||||
use App\Repos\Order\Loan\LoanTypeRepo;
|
||||
use App\Repos\System\Settings\Legal\EducationRepo;
|
||||
@@ -12,13 +13,17 @@ use App\Repos\System\Settings\Legal\MarriageRepo;
|
||||
use App\Repos\System\Settings\Legal\PassportRepo;
|
||||
use App\Repos\System\Settings\Location\RegionRepo;
|
||||
use Illuminate\Http\Request;
|
||||
use Konsulting\NovaTarget\NovaTarget;
|
||||
use Laravel\Nova\Fields\Date;
|
||||
use Laravel\Nova\Fields\Email;
|
||||
use Laravel\Nova\Fields\File;
|
||||
use Laravel\Nova\Fields\ID;
|
||||
use Laravel\Nova\Fields\Number;
|
||||
use Laravel\Nova\Fields\Select;
|
||||
use Laravel\Nova\Fields\Slug;
|
||||
use Laravel\Nova\Fields\Text;
|
||||
use Laravel\Nova\Http\Requests\NovaRequest;
|
||||
use Laravel\Nova\Panel;
|
||||
use Nurmuhammet\NovaInputmask\NovaInputmask;
|
||||
|
||||
class LoanOrder extends Resource
|
||||
@@ -62,134 +67,186 @@ class LoanOrder extends Resource
|
||||
return __('Loan order');
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the fields for create.
|
||||
*/
|
||||
// public function fieldsForCreate(NovaRequest $request): array
|
||||
// {
|
||||
|
||||
// }
|
||||
|
||||
/**
|
||||
* Get the fields displayed by the resource.
|
||||
*/
|
||||
public function fields(NovaRequest $request): array
|
||||
{
|
||||
return [
|
||||
ID::make()->sortable(),
|
||||
ID::hidden()->sortable(),
|
||||
|
||||
// $table->string('unique_id')->unique();
|
||||
new Panel(__('Loan'), [
|
||||
Select::make(__('Loan type'), 'loan_type')
|
||||
->displayUsingLabels()
|
||||
->fullWidth()
|
||||
->searchable()
|
||||
->options(LoanTypeRepo::values())
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
]),
|
||||
|
||||
Select::make(__('Region'), 'region')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(RegionRepo::values())
|
||||
->default(RegionRepo::default())
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
new Panel(__('Location'), [
|
||||
Select::make(__('Region'), 'region')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(RegionRepo::values())
|
||||
->default(RegionRepo::default())
|
||||
->size('w-1/2')
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
|
||||
Select::make(__('Branch'), 'branch_id')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(BranchRepo::values())
|
||||
->dependsOn('region', BranchNovaRepo::dependsOnRegion())
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
Select::make(__('Branch'), 'branch_id')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(BranchRepo::values())
|
||||
->dependsOn('region', BranchNovaRepo::dependsOnRegion())
|
||||
->size('w-1/2')
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
]),
|
||||
|
||||
Select::make(__('Loan type'), 'loan_type')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(LoanTypeRepo::values())
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
new Panel(__('Personal data'), [
|
||||
Text::make(__('Customer name'), 'customer_name')
|
||||
->size('w-1/3')
|
||||
->rules('required', 'string', 'max:255'),
|
||||
|
||||
Text::make(__('Customer name'), 'customer_name')
|
||||
->rules('required', 'string', 'max:255'),
|
||||
Text::make(__('Customer surname'), 'customer_surname')
|
||||
->size('w-1/3')
|
||||
->rules('required', 'string', 'max:255'),
|
||||
|
||||
Text::make(__('Customer surname'), 'customer_surname')
|
||||
->rules('required', 'string', 'max:255'),
|
||||
Text::make(__('Customer patronic name'), 'customer_patronic_name')
|
||||
->size('w-1/3')
|
||||
->rules('required', 'string', 'max:255'),
|
||||
|
||||
Text::make(__('Customer patronic name'), 'customer_patronic_name')
|
||||
->rules('required', 'string', 'max:255'),
|
||||
Select::make(__('Education'), 'education')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(EducationRepo::values())
|
||||
->default(EducationRepo::default())
|
||||
->size('w-1/3')
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
|
||||
Text::make(__('Residence (passport)'), 'passport_address')
|
||||
->rules('required', 'string', 'max:255'),
|
||||
Select::make(__('Marriage status'), 'marriage_status')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(MarriageRepo::values())
|
||||
->default(MarriageRepo::default())
|
||||
->size('w-1/3')
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
|
||||
Text::make(__('Current Residence'), 'real_address')
|
||||
->rules('required', 'string', 'max:255'),
|
||||
Date::make(__('Date of birth'), 'born_at')
|
||||
->size('w-1/3')
|
||||
->rules('required'),
|
||||
|
||||
Select::make(__('Passport serie'), 'passport_serie')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(PassportRepo::values())
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
Text::make(__('Residence (passport)'), 'passport_address')
|
||||
->size('w-1/2')
|
||||
->rules('required', 'string', 'max:255'),
|
||||
|
||||
Number::make(__('Passport id'), 'passport_id')
|
||||
->rules('required'),
|
||||
Text::make(__('Current Residence'), 'real_address')
|
||||
->size('w-1/2')
|
||||
->rules('required', 'string', 'max:255'),
|
||||
]),
|
||||
|
||||
Date::make(__('Passport date of issue'), 'passport_given_at')
|
||||
->rules('required'),
|
||||
new Panel(__('Passport'), [
|
||||
Select::make(__('Passport serie'), 'passport_serie')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(PassportRepo::values())
|
||||
->size('w-1/3')
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
|
||||
Text::make(__('Passport given by'), 'passport_given_by')
|
||||
->rules('required'),
|
||||
Number::make(__('Passport id'), 'passport_id')
|
||||
->size('w-1/3')
|
||||
->rules('required'),
|
||||
|
||||
Text::make(__('Born place (passport)'), 'born_place')
|
||||
->rules('required'),
|
||||
Date::make(__('Passport date of issue'), 'passport_given_at')
|
||||
->size('w-1/3')
|
||||
->rules('required'),
|
||||
|
||||
Date::make(__('Date of birth'), 'born_at')
|
||||
->rules('required'),
|
||||
Text::make(__('Passport given by'), 'passport_given_by')
|
||||
->size('w-1/2')
|
||||
->rules('required'),
|
||||
|
||||
Email::make(__('Email'), 'email')
|
||||
->rules('nullable', 'email'),
|
||||
Text::make(__('Born place (passport)'), 'born_place')
|
||||
->size('w-1/2')
|
||||
->rules('required'),
|
||||
]),
|
||||
|
||||
NovaInputmask::make(__('Phone'), 'phone')
|
||||
->phonenumber('TM')
|
||||
->rules('required'),
|
||||
new Panel(__('Contact data'), [
|
||||
Email::make(__('Email'), 'email')
|
||||
->size('w-1/4')
|
||||
->rules('nullable', 'email'),
|
||||
|
||||
NovaInputmask::make(__('Phone Additional'), 'phone_additional')
|
||||
->phonenumber('TM')
|
||||
->rules('required'),
|
||||
NovaInputmask::make(__('Phone'), 'phone')
|
||||
->phonenumber('TM')
|
||||
->size('w-1/4')
|
||||
->rules('required'),
|
||||
|
||||
NovaInputmask::make(__('Home phone'), 'phone_home')
|
||||
->rules('required'),
|
||||
NovaInputmask::make(__('Phone Additional'), 'phone_additional')
|
||||
->phonenumber('TM')
|
||||
->size('w-1/4')
|
||||
->rules('required'),
|
||||
|
||||
Select::make(__('Work region'), 'work_region')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(RegionRepo::values())
|
||||
->default(RegionRepo::default())
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
NovaInputmask::make(__('Home phone'), 'phone_home')
|
||||
->size('w-1/4')
|
||||
->rules('required'),
|
||||
]),
|
||||
|
||||
Select::make(__('Work province'), 'work_province')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->dependsOn('region', BranchNovaRepo::dependsOnRegion('work_region')),
|
||||
new Panel(__('Job'), [
|
||||
Text::make(__('Work company name'), 'work_company')
|
||||
->rules('required', 'string', 'max:255')
|
||||
->size('w-1/2'),
|
||||
|
||||
Text::make(__('Work company name'), 'work_company')
|
||||
->rules('required', 'string', 'max:255'),
|
||||
NovaInputmask::make(__('HR department work number'), 'work_company_accountant_number')
|
||||
->size('w-1/2')
|
||||
->rules('required'),
|
||||
|
||||
NovaInputmask::make(__('HR department work number'), 'work_company_accountant_number'),
|
||||
Select::make(__('Work region'), 'work_region')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(RegionRepo::values())
|
||||
->default(RegionRepo::default())
|
||||
->size('w-1/2')
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
|
||||
Date::make(__('Work started at'), 'work_started_at')
|
||||
->rules('required'),
|
||||
Select::make(__('Work province'), 'work_province')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->dependsOn('region', BranchNovaRepo::dependsOnRegion('work_region'))
|
||||
->size('w-1/2')
|
||||
->rules('required'),
|
||||
|
||||
Text::make(__('Salary'), 'work_salary')
|
||||
->rules('required'),
|
||||
Text::make(__('Position'), 'work_position')
|
||||
->rules('required'),
|
||||
Text::make(__('Position'), 'work_position')
|
||||
->size('w-1/2')
|
||||
->rules('required'),
|
||||
|
||||
Select::make(__('Education'), 'education')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(EducationRepo::values())
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
Text::make(__('Salary'), 'work_salary')
|
||||
->size('w-1/4')
|
||||
->rules('required'),
|
||||
|
||||
Select::make(__('Marriage status'), 'marriage_status')
|
||||
->displayUsingLabels()
|
||||
->searchable()
|
||||
->options(MarriageRepo::values())
|
||||
->rules('required')
|
||||
->sortable(),
|
||||
Date::make(__('Work started at'), 'work_started_at')
|
||||
->size('w-1/4')
|
||||
->rules('required'),
|
||||
]),
|
||||
|
||||
// $table->text('passport_one');
|
||||
// $table->text('passport_two');
|
||||
// $table->text('passport_three');
|
||||
// $table->text('passport_four');
|
||||
new Panel(__('Passport'), [
|
||||
File::make(__('Passport (page 1)'), 'passport_one'),
|
||||
File::make(__('Passport (page 2-3)'), 'passport_two'),
|
||||
File::make(__('Passport (page 8-9)'), 'passport_three'),
|
||||
File::make(__('Passport (page 32)'), 'passport_four'),
|
||||
]),
|
||||
|
||||
// $table->foreignId('filled_by')->constrained('users')->restrictOnDelete();
|
||||
// $table->foreignId('user_id')->constrained('users')->restrictOnDelete();
|
||||
|
||||
@@ -45,8 +45,6 @@ class User extends Resource
|
||||
return [
|
||||
ID::make()->sortable(),
|
||||
|
||||
Gravatar::make()->maxWidth(50),
|
||||
|
||||
Text::make('Name')
|
||||
->sortable()
|
||||
->rules('required', 'max:255'),
|
||||
|
||||
@@ -1,90 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace App\Nova\Wizards;
|
||||
|
||||
use App\Models\User;
|
||||
use Laravel\Nova\Fields\Number;
|
||||
use Laravel\Nova\Fields\Text;
|
||||
use Laravel\Nova\Fields\Textarea;
|
||||
use Wdelfuego\NovaWizard\AbstractWizard;
|
||||
|
||||
class AddUserWizard extends AbstractWizard
|
||||
{
|
||||
public function wizardViewData(): array
|
||||
{
|
||||
return [
|
||||
'steps' => [
|
||||
[
|
||||
'title' => 'Step 1/2',
|
||||
'fields' => [
|
||||
Text::make(__('Username'), 'username'),
|
||||
Text::make(__('Text field'), 'myText'),
|
||||
Textarea::make(__('Longer text'), 'myLongerText')
|
||||
->help("You can use Help texts on Nova fields like you're used to"),
|
||||
Number::make(__('Some number'), 'myNumber')
|
||||
->rules('required')
|
||||
->withMeta(['value' => 60])
|
||||
->min(1)
|
||||
->step(1),
|
||||
],
|
||||
],
|
||||
[
|
||||
'title' => 'Step 2/2',
|
||||
'fields' => [
|
||||
Text::make(__('Text field 2'), 'myText2'),
|
||||
Textarea::make(__('Longer text 2'), 'myLongerText2')
|
||||
->help("You can use Help texts on Nova fields like you're used to"),
|
||||
Number::make(__('Some number 2'), 'myNumber2')
|
||||
->rules('required')
|
||||
->withMeta(['value' => 60])
|
||||
->min(1)
|
||||
->step(1),
|
||||
],
|
||||
],
|
||||
[
|
||||
'title' => 'Step 2/2',
|
||||
'fields' => [
|
||||
Text::make(__('Text field 2'), 'myText2'),
|
||||
Textarea::make(__('Longer text 2'), 'myLongerText2')
|
||||
->help("You can use Help texts on Nova fields like you're used to"),
|
||||
Number::make(__('Some number 2'), 'myNumber2')
|
||||
->rules('required')
|
||||
->withMeta(['value' => 60])
|
||||
->min(1)
|
||||
->step(1),
|
||||
],
|
||||
],
|
||||
],
|
||||
];
|
||||
}
|
||||
|
||||
public function onSubmit($formData, &$context): bool
|
||||
{
|
||||
//
|
||||
// When this method gets called, a valid and complete wizard was submitted.
|
||||
//
|
||||
// $formData is an array that contains the data submitted by the user.
|
||||
//
|
||||
// $context is an empty array that you can store arbitrary info in;
|
||||
// it will be passed to the next method so you can use it
|
||||
// to display specific context info to the user on success.
|
||||
|
||||
// Parse submitted wizard data somehow
|
||||
$user = User::create(['name' => $formData['username']]);
|
||||
$context['newUserId'] = $user->id;
|
||||
|
||||
// Return true at the end of this method to indicate success
|
||||
return true;
|
||||
|
||||
// Or return false if the data can not be parsed successfully;
|
||||
// the user will then stay in the form view and have a chance
|
||||
// to revise the data before resubmitting.
|
||||
}
|
||||
|
||||
public function successViewData($context): array
|
||||
{
|
||||
return [
|
||||
'message' => 'Successfully created user with id: '.$context['newUserId'],
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -21,7 +21,6 @@ use Laravel\Nova\Menu\MenuItem;
|
||||
use Laravel\Nova\Menu\MenuSection;
|
||||
use Laravel\Nova\Nova;
|
||||
use Laravel\Nova\NovaApplicationServiceProvider;
|
||||
use Wdelfuego\NovaWizard\NovaWizard;
|
||||
|
||||
class NovaServiceProvider extends NovaApplicationServiceProvider
|
||||
{
|
||||
@@ -38,6 +37,7 @@ class NovaServiceProvider extends NovaApplicationServiceProvider
|
||||
$this->setupNavigation();
|
||||
$this->setupUserNavigation();
|
||||
$this->setupUserSettings();
|
||||
$this->setupAssets();
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -84,7 +84,6 @@ class NovaServiceProvider extends NovaApplicationServiceProvider
|
||||
LocaleSwitcher::make()
|
||||
->setLocales(config('app.locales'))
|
||||
->onSwitchLocale(NovaRepo::localeSwitcherSave()),
|
||||
// new NovaWizard('add-user'),
|
||||
];
|
||||
}
|
||||
|
||||
@@ -107,7 +106,6 @@ class NovaServiceProvider extends NovaApplicationServiceProvider
|
||||
|
||||
MenuSection::make(__('Orders'), [
|
||||
MenuItem::resource(LoanOrder::class),
|
||||
// MenuItem::link('Add a user', NovaWizard::pathToWizard('add-user'))
|
||||
])->icon('collection')->collapsable(),
|
||||
|
||||
MenuSection::make(__('System'), [
|
||||
@@ -117,7 +115,7 @@ class NovaServiceProvider extends NovaApplicationServiceProvider
|
||||
MenuItem::resource(Permission::class),
|
||||
])->collapsable(),
|
||||
|
||||
MenuGroup::make(__('Loans'), [
|
||||
MenuGroup::make(__('Loan'), [
|
||||
MenuItem::resource(LoanType::class),
|
||||
])->collapsable(),
|
||||
|
||||
@@ -149,4 +147,12 @@ class NovaServiceProvider extends NovaApplicationServiceProvider
|
||||
{
|
||||
Nova::serving(fn (ServingNova $event) => NovaRepo::serving($event));
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup Assets
|
||||
*/
|
||||
public function setupAssets(): void
|
||||
{
|
||||
Nova::style('additional', resource_path('css/vendor/nova/css/additional.css'));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -23,7 +23,7 @@ class NovaRepo
|
||||
{
|
||||
$user = $event->request->user();
|
||||
|
||||
if (array_key_exists($user->locale, config('app.locales'))) {
|
||||
if (array_key_exists($user?->locale, config('app.locales'))) {
|
||||
app()->setLocale($user->locale);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -33,4 +33,12 @@ class EducationRepo
|
||||
self::PHD => __('PHD'),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Default education status
|
||||
*/
|
||||
public static function default(): string
|
||||
{
|
||||
return self::HIGH_EDUCATION;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -27,4 +27,12 @@ class MarriageRepo
|
||||
self::SINGLE => __('Single'),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Default marriage value
|
||||
*/
|
||||
public static function default(): string
|
||||
{
|
||||
return self::MARRIED;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user