diff --git a/app/Models/Order/Loan/LoanPaidOffLetterOrder.php b/app/Models/Order/Loan/LoanPaidOffLetterOrder.php new file mode 100644 index 0000000..c021f39 --- /dev/null +++ b/app/Models/Order/Loan/LoanPaidOffLetterOrder.php @@ -0,0 +1,68 @@ + + */ + protected $fillable = [ + 'unique_id', + 'region', + 'branch_id', + 'customer_name', + 'customer_surname', + 'customer_patronic_name', + 'born_at', + 'phone', + 'passport_serie', + 'passport_id', + 'loan_contract_number', + 'loan_contract_date', + 'loan_amount', + 'loan_reason', + 'status', + 'notes', + 'user_id', + ]; + + /** + * The attributes that should be cast. + * + * @var array + */ + protected $casts = [ + 'born_at' => 'date', + ]; + + /** + * User + */ + public function user(): BelongsTo + { + return $this->belongsTo(User::class); + } + + /** + * Branch + */ + public function branch(): BelongsTo + { + return $this->belongsTo(Branch::class, 'branch_id'); + } +} diff --git a/app/Nova/Resources/Order/Card/Requisite/CardRequisite.php b/app/Nova/Resources/Order/Card/Requisite/CardRequisite.php index f7bd814..6ea94f9 100644 --- a/app/Nova/Resources/Order/Card/Requisite/CardRequisite.php +++ b/app/Nova/Resources/Order/Card/Requisite/CardRequisite.php @@ -8,7 +8,6 @@ use App\Nova\Filters\RegionFilter; use App\Nova\Filters\StatusFilter; use App\Nova\Nova; use App\Nova\Resource; -use App\Nova\Resources\Order\Card\Concerns\CardOrderFieldsForIndex; use App\Nova\Resources\Order\Card\Requisite\Concerns\CardRequisiteFieldsForDetail; use App\Nova\Resources\Order\Card\Requisite\Concerns\CardRequisiteFieldsForIndex; use App\Repos\Order\Card\CardOrderRepo; diff --git a/app/Nova/Resources/Order/Card/Requisite/Concerns/CardRequisiteFieldsForDetail.php b/app/Nova/Resources/Order/Card/Requisite/Concerns/CardRequisiteFieldsForDetail.php index d580b0e..3896e86 100644 --- a/app/Nova/Resources/Order/Card/Requisite/Concerns/CardRequisiteFieldsForDetail.php +++ b/app/Nova/Resources/Order/Card/Requisite/Concerns/CardRequisiteFieldsForDetail.php @@ -11,7 +11,6 @@ use App\Repos\System\Settings\Location\RegionRepo; use Laravel\Nova\Fields\Badge; use Laravel\Nova\Fields\BelongsTo; use Laravel\Nova\Fields\Date; -use Laravel\Nova\Fields\File; use Laravel\Nova\Fields\ID; use Laravel\Nova\Fields\Image; use Laravel\Nova\Fields\Number; @@ -24,7 +23,6 @@ class CardRequisiteFieldsForDetail { /** * Fields for index - * @param $resource */ public static function make($resource): array { @@ -78,7 +76,7 @@ class CardRequisiteFieldsForDetail NovaInputmask::make(__('Phone'), 'phone') ->mask('+(\\9\\93)-99-99-99-99') ->storeRawValue(), - ]), + ]), new Panel(__('Passport'), [ Select::make(__('Passport serie'), 'passport_serie') diff --git a/app/Nova/Resources/Order/Card/Requisite/Concerns/CardRequisiteFieldsForIndex.php b/app/Nova/Resources/Order/Card/Requisite/Concerns/CardRequisiteFieldsForIndex.php index 034ea39..3048e92 100644 --- a/app/Nova/Resources/Order/Card/Requisite/Concerns/CardRequisiteFieldsForIndex.php +++ b/app/Nova/Resources/Order/Card/Requisite/Concerns/CardRequisiteFieldsForIndex.php @@ -16,8 +16,6 @@ class CardRequisiteFieldsForIndex { /** * Fields for index - * @param $resource - * @param $request */ public static function make($resource, $request): array { diff --git a/app/Nova/Resources/Order/Loan/LoanPaidOffLetterOrder.php b/app/Nova/Resources/Order/Loan/LoanPaidOffLetterOrder.php new file mode 100644 index 0000000..05b0632 --- /dev/null +++ b/app/Nova/Resources/Order/Loan/LoanPaidOffLetterOrder.php @@ -0,0 +1,254 @@ +user(); + + if ($user->isAdmin()) { + return $query; + } + + if ($user->isOperator()) { + return $query->whereIn('branch_id', $user->branches()->pluck('branches.id')); + } + + return $query->where('user_id', $request->user()->id); + } + + /** + * 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 displayed by the resource. + * + * @return array + */ + public function fields(NovaRequest $request) + { + return [ + ID::make()->sortable(), + + ID::make()->sortable(), + + Hidden::make('user_id') + ->default(auth()->id()) + ->hideWhenUpdating(), + + Select::make(__('Status'), 'status') + ->displayUsingLabels() + ->searchable() + ->options(OrderRepo::statusValues()) + ->default(OrderRepo::defaultStatus()) + ->fullWidth() + ->rules('required') + ->canSeeWhen('systemUser', $this), + + Text::make(__('Note'), 'notes') + ->fullWidth() + ->canSeeWhen('systemUser', $this), + + new Panel(__('Location'), [ + Select::make(__('Region'), 'region') + ->displayUsingLabels() + ->searchable() + ->options(RegionRepo::values()) + ->default(RegionRepo::default()) + ->size('w-1/2') + ->rules('required'), + + Select::make(__('Branch'), 'branch_id') + ->displayUsingLabels() + ->searchable() + ->dependsOn('region', NovaRepo::dependsOnRegion('region', Branch::class)) + ->size('w-1/2') + ->rules('required'), + ]), + + new Panel(__('Personal data'), [ + Text::make(__('Name'), 'customer_name') + ->size('w-1/3') + ->rules('required', 'string', new OnlyLetters(), 'max:255'), + + Text::make(__('Surname'), 'customer_surname') + ->size('w-1/3') + ->rules('required', 'string', new OnlyLetters(), 'max:255'), + + Text::make(__('Patronic name'), 'customer_patronic_name') + ->size('w-1/3') + ->rules('required', 'string', new OnlyLetters(), 'max:255'), + + Date::make(__('Date of birth'), 'born_at') + ->size('w-1/2') + ->rules('required', 'before_or_equal:today'), + + NovaInputmask::make(__('Phone'), 'phone') + ->mask('+(\\9\\93)-99-99-99-99') + ->storeRawValue() + ->size('w-1/2') + ->rules('required', 'integer', 'between:61000000, 71999999'), + ]), + + new Panel(__('Karz barada maglumatlar'), [ + Text::make(__('Karz şertnamanyň belgisi'), 'loan_contract_number') + ->rules('required', 'string', 'max:255'), + + Text::make(__('Karz şertnamanyň senesi'), 'loan_contract_date') + ->rules('required', 'string', 'max:255'), + + Text::make(__('Karzyň möçberi'), 'loan_amount') + ->rules('required', 'string', 'max:255'), + + Text::make(__('Karzyň maksady'), 'loan_reason') + ->rules('required', 'string', 'max:255'), + ]), + ]; + } + + /** + * Get the cards available for the request. + * + * @return array + */ + public function cards(NovaRequest $request) + { + return []; + } + + /** + * Get the filters available for the resource. + * + * @return array + */ + public function filters(NovaRequest $request) + { + return [ + RegionFilter::make() + ->canSee(fn () => Gate::allows('isAdmin'), auth()->user()), + + new StatusFilter(), + ]; + } + + /** + * Get the lenses available for the resource. + * + * @return array + */ + public function lenses(NovaRequest $request) + { + return []; + } + + /** + * Get the actions available for the resource. + * + * @return array + */ + public function actions(NovaRequest $request) + { + return []; + } +} diff --git a/app/Providers/NovaServiceProvider.php b/app/Providers/NovaServiceProvider.php index 803fd68..9afd12a 100644 --- a/app/Providers/NovaServiceProvider.php +++ b/app/Providers/NovaServiceProvider.php @@ -10,6 +10,7 @@ use App\Nova\Resources\Order\Card\CardType; use App\Nova\Resources\Order\Card\Pin\CardPin; use App\Nova\Resources\Order\Card\Requisite\CardRequisite; use App\Nova\Resources\Order\Loan\LoanOrder; +use App\Nova\Resources\Order\Loan\LoanPaidOffLetterOrder; use App\Nova\Resources\Order\Loan\LoanType; use App\Nova\Resources\System\Location\Province; use App\Nova\Resources\System\Roles\Permission; @@ -120,6 +121,7 @@ class NovaServiceProvider extends NovaApplicationServiceProvider MenuSection::make(__('Orders'), [ MenuGroup::make(__('Loan department'), [ MenuItem::resource(LoanOrder::class), + MenuItem::resource(LoanPaidOffLetterOrder::class), ])->collapsedByDefault(), MenuGroup::make(__('Card department'), [ diff --git a/database/migrations/2024_03_11_020119_create_loan_paid_off_letter_orders_table.php b/database/migrations/2024_03_11_020119_create_loan_paid_off_letter_orders_table.php new file mode 100644 index 0000000..4b3083a --- /dev/null +++ b/database/migrations/2024_03_11_020119_create_loan_paid_off_letter_orders_table.php @@ -0,0 +1,55 @@ +id(); + + $table->string('unique_id')->nullable()->unique(); + $table->string('region', 2)->index(); + $table->foreignId('branch_id')->constrained('branches')->restrictOnDelete(); + + $table->string('customer_name')->index(); + $table->string('customer_surname')->index(); + $table->string('customer_patronic_name')->nullable(); + $table->date('born_at')->nullable(); + + $table->string('phone')->nullable()->index(); + + $table->string('passport_serie')->index(); + $table->string('passport_id')->index(); + + $table->string('status')->nullable()->default(OrderRepo::defaultStatus())->index(); + + $table->text('notes')->nullable(); + + $table->foreignId('user_id')->constrained('users')->restrictOnDelete(); + + $table->string('loan_contract_number')->nullable(); + $table->string('loan_contract_date')->nullable(); + $table->string('loan_amount')->nullable(); + $table->string('loan_reason')->nullable(); + + $table->timestamps(); + $table->softDeletes(); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + Schema::dropIfExists('loan_paid_off_letter_orders'); + } +};