Added policies, factories, seeder. Changed views

This commit is contained in:
m.zargarov 2024-01-18 16:41:28 +04:00
parent b6b892d195
commit f3e8f6aa44
26 changed files with 493 additions and 159 deletions

View File

@ -31,6 +31,8 @@ class CarController extends Controller
*/
public function create(User $user): View
{
$this->authorize('create', $user);
return view('cars.create', [
'user' => $user,
]);
@ -41,6 +43,7 @@ class CarController extends Controller
*/
public function store(CarPostRequest $request, User $user): RedirectResponse
{
$this->authorize('create', $user);
$this->carRepository->createCar($request->validated());
return redirect()->route('users.show', $user);
@ -62,6 +65,8 @@ class CarController extends Controller
*/
public function edit(User $user, Car $car): View
{
$this->authorize('update', $car);
return view('cars.edit', [
'car' => $car,
'user' => $user,
@ -73,6 +78,7 @@ class CarController extends Controller
*/
public function update(CarPostRequest $request, User $user, Car $car): RedirectResponse
{
$this->authorize('update', $car);
$this->carRepository->updateCar($car, $request->validated());
return redirect()->route('users.show', $user);
@ -83,6 +89,7 @@ class CarController extends Controller
*/
public function destroy(User $user, Car $car): RedirectResponse
{
$this->authorize('delete', $car);
$this->carRepository->deleteCar($car);
return redirect()->route('users.show', [

View File

@ -20,29 +20,29 @@ class DeliveryController extends Controller
/**
* Display a listing of the resource.
*/
public function index(User $user): View
public function index(): View
{
return view('deliveries.index', [
'deliveries' => $this->deliveryRepository->getAllDeliveries(),
'user' => $user,
'deliveries' => $this->deliveryRepository->getAllDeliveries()
]);
}
/**
* Show the form for creating a new resource.
*/
public function create(User $user): View
public function create(): View
{
return view('deliveries.create', [
'user' => $user,
]);
$this->authorize('create', Delivery::class);
return view('deliveries.create');
}
/**
* Store a newly created resource in storage.
*/
public function store(DeliveryPostRequest $request, User $user): RedirectResponse
public function store(DeliveryPostRequest $request): RedirectResponse
{
$this->authorize('create', Delivery::class);
$this->deliveryRepository->createDelivery($request->validated());
return redirect()->route('deliveries.index');
@ -53,6 +53,8 @@ class DeliveryController extends Controller
*/
public function show(Delivery $delivery): View
{
$this->authorize('view', $delivery);
return view('deliveries.show', [
'delivery' => $delivery,
]);
@ -61,11 +63,12 @@ class DeliveryController extends Controller
/**
* Show the form for editing the specified resource.
*/
public function edit(Delivery $delivery, User $user): View
public function edit(Delivery $delivery): View
{
$this->authorize('update', $delivery);
return view('deliveries.edit', [
'delivery' => $delivery,
'user' => $user,
]);
}
@ -74,6 +77,7 @@ class DeliveryController extends Controller
*/
public function update(DeliveryPostRequest $request, Delivery $delivery): RedirectResponse
{
$this->authorize('update', $delivery);
$this->deliveryRepository->updateDelivery($delivery, $request->validated());
return redirect()->route('deliveries.index');
@ -84,6 +88,7 @@ class DeliveryController extends Controller
*/
public function destroy(Delivery $delivery): RedirectResponse
{
$this->authorize('delete', $delivery);
$this->deliveryRepository->deleteDelivery($delivery);
return redirect()->route('deliveries.index');

View File

@ -30,6 +30,8 @@ class UserController extends Controller
*/
public function create(): View
{
$this->authorize('create', User::class);
return view('users.create');
}
@ -38,6 +40,7 @@ class UserController extends Controller
*/
public function store(UserPostRequest $request): RedirectResponse
{
$this->authorize('create', User::class);
$this->userRepository->createUser($request->validated());
return redirect()->route('users.index');
@ -48,6 +51,8 @@ class UserController extends Controller
*/
public function show(User $user): View
{
$this->authorize('view', $user);
return view('users.show', [
'user' => $user,
]);
@ -58,6 +63,8 @@ class UserController extends Controller
*/
public function edit(User $user): View
{
$this->authorize('update', $user);
return view('users.edit', [
'user' => $user,
]);
@ -68,6 +75,7 @@ class UserController extends Controller
*/
public function update(UserPostRequest $request, User $user): RedirectResponse
{
$this->authorize('update', $user);
$this->userRepository->updateUser($user, $request->validated());
return redirect()->route('users.index');
@ -78,6 +86,7 @@ class UserController extends Controller
*/
public function destroy(User $user): RedirectResponse
{
$this->authorize('delete', $user);
$this->userRepository->deleteUser($user);
return redirect()->route('users.index');

View File

@ -3,6 +3,7 @@
namespace App\Http\Controllers;
use App\Http\Requests\WarehousePostRequest;
use App\Models\User;
use App\Models\Warehouse;
use App\Repositories\Interfaces\WarehouseRepositoryInterface;
use Illuminate\Http\RedirectResponse;
@ -30,6 +31,8 @@ class WarehouseController extends Controller
*/
public function create(): View
{
$this->authorize('create', Warehouse::class);
return view('warehouses.create');
}
@ -38,6 +41,7 @@ class WarehouseController extends Controller
*/
public function store(WarehousePostRequest $request): RedirectResponse
{
$this->authorize('create', Warehouse::class);
$this->warehouseRepository->createWarehouse($request->validated());
return redirect()->route('warehouses.index');
@ -58,6 +62,8 @@ class WarehouseController extends Controller
*/
public function edit(Warehouse $warehouse): View
{
$this->authorize('update', $warehouse);
return view('warehouse.edit', [
'warehouse' => $warehouse,
]);
@ -68,6 +74,7 @@ class WarehouseController extends Controller
*/
public function update(WarehousePostRequest $request, Warehouse $warehouse): RedirectResponse
{
$this->authorize('update', $warehouse);
$this->warehouseRepository->updateWarehouse($warehouse, $request->validated());
return redirect()->route('warehouses.index');
@ -78,6 +85,7 @@ class WarehouseController extends Controller
*/
public function destroy(Warehouse $warehouse): RedirectResponse
{
$this->authorize('delete', $warehouse);
$this->warehouseRepository->deleteWarehouse($warehouse);
return redirect()->route('warehouses.index');

View File

@ -22,8 +22,8 @@ class DeliveryPostRequest extends FormRequest
'receiver' => 'required|string|max:255',
'receiver_phone' => 'required|regex:/^([0-9\s\-\+\(\)]*)$/|min:10',
'sender_phone' => 'required|regex:/^([0-9\s\-\+\(\)]*)$/|min:10',
'sending_date' => 'date',
'delivery_date' => 'date',
'sending_date' => 'date|nullable',
'delivery_date' => 'date|nullable',
'user_id' => 'required|exists:users,id',
'warehouse_id' => 'required|exists:warehouses,id',
];

View File

@ -0,0 +1,27 @@
<?php
namespace App\Policies;
use App\Enums\RoleEnum;
use App\Models\Car;
use App\Models\User;
class CarPolicy
{
public function create(User $user, User $carUser)
{
return $user->warehouse_id == $carUser->warehouse->id &&
($user->role == RoleEnum::DISPATCHER || $user->role == RoleEnum::ADMIN);
}
public function update(User $user, Car $car)
{
return $user->warehouse_id == $car->user->warehouse_id &&
($user->role == RoleEnum::DISPATCHER || $user->role == RoleEnum::ADMIN);
}
public function delete(User $user, Car $car)
{
return $user->warehouse_id == $car->user->warehouse_id && $user->role == RoleEnum::ADMIN;
}
}

View File

@ -0,0 +1,35 @@
<?php
namespace App\Policies;
use App\Enums\RoleEnum;
use App\Models\Delivery;
use App\Models\User;
class DeliveryPolicy
{
public function view(User $user, Delivery $delivery)
{
if($user->role == RoleEnum::DRIVER) {
return $delivery->user_id == $user->id && $delivery->warehouse_id == $user->warehouse_id;
}
return $user->warehouse_id == $delivery->warehouse_id;
}
public function create(User $user)
{
return $user->role == RoleEnum::ADMIN || $user->role == RoleEnum::DISPATCHER;
}
public function update(User $user, Delivery $delivery)
{
return ($user->role == RoleEnum::ADMIN || $user->role == RoleEnum::DISPATCHER) &&
$delivery->warehouse_id == $user->warehouse_id;
}
public function delete(User $user, Delivery $delivery)
{
return $user->role == RoleEnum::ADMIN && $delivery->warehouse_id == $user->warehouse_id;
}
}

View File

@ -0,0 +1,41 @@
<?php
namespace App\Policies;
use App\Enums\RoleEnum;
use App\Models\User;
class UserPolicy
{
public function view(User $user, User $showedUser)
{
if($user->role == RoleEnum::ADMIN) {
return true;
}
if($user->role == RoleEnum::DISPATCHER) {
return $user->warehouse_id == $showedUser->warehouse_id;
}
return $user->role == $showedUser->role && $user->warehouse_id == $showedUser->warehouse_id;
}
public function create(User $user)
{
return $user->role == RoleEnum::ADMIN;
}
public function update(User $user, User $updatedUser)
{
return $user->role == RoleEnum::ADMIN && $user->warehouse_id == $updatedUser->warehouse_id;
}
public function delete(User $user, User $deletedUser)
{
return $user->role == RoleEnum::ADMIN && $user->warehouse_id == $deletedUser->warehouse_id;
}
public function viewCar(User $user, User $carUser)
{
return $carUser->role == RoleEnum::DRIVER;
}
}

View File

@ -0,0 +1,25 @@
<?php
namespace App\Policies;
use App\Enums\RoleEnum;
use App\Models\User;
use App\Models\Warehouse;
class WarehousePolicy
{
public function update(User $user, Warehouse $warehouse)
{
return $warehouse->id == $user->warehouse_id && $user->role == RoleEnum::ADMIN;
}
public function create(User $user)
{
return $user->role == RoleEnum::ADMIN;
}
public function delete(User $user, Warehouse $warehouse)
{
return $warehouse->id == $user->warehouse_id && $user->role == RoleEnum::ADMIN;
}
}

View File

@ -2,6 +2,7 @@
namespace App\Providers;
use Illuminate\Pagination\Paginator;
use Illuminate\Support\ServiceProvider;
class AppServiceProvider extends ServiceProvider
@ -19,6 +20,6 @@ class AppServiceProvider extends ServiceProvider
*/
public function boot(): void
{
//
Paginator::useBootstrap();
}
}

View File

@ -10,7 +10,7 @@ class DeliveryRepository implements DeliveryRepositoryInterface
public function getAllDeliveries()
{
return Delivery::paginate(5);
return Delivery::orderBy('status', 'asc')->paginate(1000);
}
public function createDelivery(array $data)

View File

@ -2,6 +2,7 @@
namespace App\View\Components;
use App\Enums\RoleEnum;
use App\Models\User;
use Closure;
use Illuminate\Contracts\View\View;
@ -16,7 +17,9 @@ class SelectDriver extends Component
*/
public function __construct()
{
$this->users = User::where('warehouse_id', auth()->user()->warehouse_id)->get();
$this->users = User::where('warehouse_id', auth()->user()->warehouse_id)
->where('role', RoleEnum::DRIVER)
->get();
}
/**

View File

@ -0,0 +1,25 @@
<?php
namespace Database\Factories;
use Illuminate\Database\Eloquent\Factories\Factory;
/**
* @extends \Illuminate\Database\Eloquent\Factories\Factory<\App\Models\Car>
*/
class CarFactory extends Factory
{
/**
* Define the model's default state.
*
* @return array<string, mixed>
*/
public function definition(): array
{
return [
'name' => 'Автомобиль' . $this->faker->unique()->numberBetween(1,100),
'number' => fake()->randomLetter() . fake()->numberBetween(100, 999)
. fake()->randomLetter() . fake()->randomLetter()
];
}
}

View File

@ -0,0 +1,27 @@
<?php
namespace Database\Factories;
use Illuminate\Database\Eloquent\Factories\Factory;
/**
* @extends \Illuminate\Database\Eloquent\Factories\Factory<\App\Models\Delivery>
*/
class DeliveryFactory extends Factory
{
/**
* Define the model's default state.
*
* @return array<string, mixed>
*/
public function definition(): array
{
return [
'address' => fake()->city() . ', ' . fake()->streetName() . ', ' . fake()->numberBetween(1,200),
'receiver' => fake()->name() . ' ' . fake()->lastName() . ' ' . fake()->firstNameMale(),
'sender' => fake()->name() . ' ' . fake()->lastName() . ' ' . fake()->firstNameMale(),
'receiver_phone' => fake()->unique()->phoneNumber(),
'sender_phone' => fake()->unique()->phoneNumber(),
];
}
}

View File

@ -25,6 +25,9 @@ class UserFactory extends Factory
{
return [
'name' => fake()->name(),
'surname' => fake()->lastName(),
'patronymic' => fake()->firstNameMale(),
'phone_number' => fake()->unique()->phoneNumber(),
'email' => fake()->unique()->safeEmail(),
'email_verified_at' => now(),
'password' => static::$password ??= Hash::make('password'),

View File

@ -0,0 +1,24 @@
<?php
namespace Database\Factories;
use Illuminate\Database\Eloquent\Factories\Factory;
/**
* @extends \Illuminate\Database\Eloquent\Factories\Factory<\App\Models\Warehouse>
*/
class WarehouseFactory extends Factory
{
/**
* Define the model's default state.
*
* @return array<string, mixed>
*/
public function definition(): array
{
return [
'address' => fake()->city() . ', ' . fake()->streetName() . ', ' . fake()->numberBetween(1,200),
'phone_number' => fake()->unique()->phoneNumber(),
];
}
}

View File

@ -3,6 +3,13 @@
namespace Database\Seeders;
// use Illuminate\Database\Console\Seeds\WithoutModelEvents;
use App\Enums\RoleEnum;
use App\Enums\StatusEnum;
use App\Models\Car;
use App\Models\Delivery;
use App\Models\User;
use App\Models\Warehouse;
use Carbon\Carbon;
use Illuminate\Database\Seeder;
class DatabaseSeeder extends Seeder
@ -12,11 +19,61 @@ class DatabaseSeeder extends Seeder
*/
public function run(): void
{
// \App\Models\User::factory(10)->create();
$warehouses = Warehouse::factory()
->count(5)
->create();
// \App\Models\User::factory()->create([
// 'name' => 'Test User',
// 'email' => 'test@example.com',
// ]);
foreach ($warehouses as $warehouse) {
$drivers = User::factory()
->count(10)
->for($warehouse)
->create([
'role' => RoleEnum::DRIVER
]);
foreach ($drivers as $driver) {
Car::factory()
->for($driver)
->create();
}
User::factory()
->count(2)
->for($warehouse)
->create([
'role' => RoleEnum::DISPATCHER
]);
User::factory()
->for($warehouse)
->create([
'role' => RoleEnum::ADMIN
]);
foreach ($drivers as $driver) {
$rndYear = rand(1, 5);
$rndDays = rand(1, 7);
Delivery::factory()
->count(3)
->for($warehouse)
->for($driver)
->create([
'status' => StatusEnum::CREATED
]);
Delivery::factory()
->count(3)
->for($warehouse)
->for($driver)
->create([
'status' => StatusEnum::SENT,
'sending_date' => Carbon::now()->subDays($rndDays),
]);
Delivery::factory()
->count(200)
->for($warehouse)
->for($driver)
->create([
'status' => StatusEnum::DELIVERED,
'sending_date' => Carbon::now()->subYears($rndYear)->subDays($rndDays),
'delivery_date' => Carbon::now()->subYears($rndYear),
]);
}
}
}
}

View File

@ -1 +0,0 @@
<?php

View File

@ -16,36 +16,40 @@
<h5><strong>ФИО владельца: </strong>{{ $car->user->fio ?? "" }}</h5>
</div>
</div>
<div class="card-footer">
<a href="{{ route('cars.edit', $car) }}" class="btn btn-primary">Редактировать</a>
</div>
@can('update', $car)
<div class="card-footer">
<a href="{{ route('cars.edit', $car) }}" class="btn btn-primary">Редактировать</a>
</div>
@endcan
</div>
@if($user->role)
<div class="card mt-4">
<div class="card-header">{{__('Автомобиль')}}</div>
<div class="card-body">
@if ($user->car)
<table class="table table-striped">
<thead>
<th>Название</th>
<th>Номер</th>
<th>&nbsp;</th>
</thead>
<tbody>
<tr>
<td class="table-text">
<div>
{{ $user->car->name }}
</div>
</td>
<td>
<div>
{{ $user->car->number }}
</div>
</td>
<div class="card mt-4">
<div class="card-header">{{__('Автомобиль')}}</div>
<div class="card-body">
@if ($user->car)
<table class="table table-striped">
<thead>
<th>Название</th>
<th>Номер</th>
<th>&nbsp;</th>
</thead>
<tbody>
<tr>
<td class="table-text">
<div>
{{ $user->car->name }}
</div>
</td>
<td>
<div>
{{ $user->car->number }}
</div>
</td>
@can('update', $car)
<td>
<a href="{{ route('cars.edit', $user->car) }}" class="btn btn-warning">Редактировать</a>
</td>
@endcan
@can('delete', $car)
<td>
<form action="{{ route('cars.destroy', $user->car) }}" method="POST" style="display: inline-block;">
@csrf
@ -53,18 +57,18 @@
<button type="submit" class="btn btn-danger">Удалить</button>
</form>
</td>
</tr>
</tbody>
</table>
@else
<a href="{{ route('cars.create', $user) }}" class="btn btn-success">Добавить</a>
<div class="mt-4">
<label class="form-label"><strong>Автомобиль отсутствует</strong></label>
</div>
@endif
</div>
@endcan
</tr>
</tbody>
</table>
@else
<a href="{{ route('cars.create', $user) }}" class="btn btn-success">Добавить</a>
<div class="mt-4">
<label class="form-label"><strong>Автомобиль отсутствует</strong></label>
</div>
@endif
</div>
@endif
</div>
</div>
</div>
@endsection

View File

@ -27,7 +27,7 @@
</div>
<div class="mb-3">
<label for="sending_date" class="form-label">Дата отправки:</label>
<input type="date" id="sending_date" name="sending_date" class="form-control" value="{{ isset($delivery) ? $delivery->sending_date : '' }}" required>
<input type="date" id="sending_date" name="sending_date" class="form-control" value="{{ isset($delivery) ? $delivery->sending_date : '' }}">
</div>
<div class="mb-3">
<label for="receiver" class="form-label">ФИО получателя:</label>
@ -39,7 +39,7 @@
</div>
<div class="mb-3">
<label for="delivery_date" class="form-label">Дата получения:</label>
<input type="date" id="delivery_date" name="delivery_date" class="form-control" value="{{ isset($delivery) ? $delivery->delivery_date : '' }}" required>
<input type="date" id="delivery_date" name="delivery_date" class="form-control" value="{{ isset($delivery) ? $delivery->delivery_date : '' }}">
</div>
<input type="hidden" name="warehouse_id" value="{{ auth()->user()->warehouse_id }}">
<div>

View File

@ -3,12 +3,14 @@
@section('content')
<div class="container col-md-6">
<div class="row justify-content-center">
<div class="card">
<div class="card-header">{{__('Новая доставка')}}</div>
<div class="card-body">
<a href="{{ route('deliveries.create') }}" class="btn btn-success">Добавить</a>
@can('create', \App\Models\Delivery::class)
<div class="card">
<div class="card-header">{{__('Новая доставка')}}</div>
<div class="card-body">
<a href="{{ route('deliveries.create') }}" class="btn btn-success">Добавить</a>
</div>
</div>
</div>
@endcan
@if (count($deliveries))
<div class="card mt-4">
<div class="card-header">{{__('Доставки')}}</div>
@ -22,35 +24,41 @@
</thead>
<tbody>
@foreach ($deliveries as $delivery)
<tr>
<td class="table-text">
<div>
<a href="{{ route('deliveries.show', $delivery) }}" class="btn btn-block col-8">{{ $delivery->address }}</a>
</div>
</td>
<td>
<div>
<p>{{ $delivery->user->fio }}</p>
</div>
</td>
<td>
<div>
<p>{{ $delivery->status->description()}}</p>
</div>
</td>
<td>
<div>
<a href="{{ route('deliveries.edit', $delivery) }}" class="btn btn-warning">Редактировать</a>
</div>
</td>
<td>
<form action="{{ route('deliveries.destroy', $delivery) }}" method="POST" style="display: inline-block;">
@csrf
@method('DELETE')
<button type="submit" class="btn btn-danger">Удалить</button>
</form>
</td>
</tr>
@can('view', $delivery)
<tr>
<td class="table-text">
<div>
<a href="{{ route('deliveries.show', $delivery) }}" class="btn btn-block col-8">{{ $delivery->address }}</a>
</div>
</td>
<td>
<div>
<p>{{ $delivery->user->fio }}</p>
</div>
</td>
<td>
<div>
<p>{{ $delivery->status->description()}}</p>
</div>
</td>
<td>
@can('update', $delivery)
<div>
<a href="{{ route('deliveries.edit', $delivery) }}" class="btn btn-warning">Редактировать</a>
</div>
@endcan
</td>
<td>
@can('delete', $delivery)
<form action="{{ route('deliveries.destroy', $delivery) }}" method="POST" style="display: inline-block;">
@csrf
@method('DELETE')
<button type="submit" class="btn btn-danger">Удалить</button>
</form>
@endcan
</td>
</tr>
@endcan
@endforeach
</tbody>
</table>

View File

@ -34,9 +34,11 @@
<h5><strong>Дата получения: </strong> {{ $delivery->delivery_date ?? "" }} </h5>
</div>
</div>
<div class="card-footer">
<a href="{{ route('deliveries.edit', $delivery) }}" class="btn btn-primary">Редактировать</a>
</div>
@can('update', $delivery)
<div class="card-footer">
<a href="{{ route('deliveries.edit', $delivery) }}" class="btn btn-primary">Редактировать</a>
</div>
@endcan
</div>
</div>
</div>

View File

@ -3,12 +3,14 @@
@section('content')
<div class="container col-md-8">
<div class="row justify-content-center">
<div class="card">
<div class="card-header">{{__('Новый пользователь')}}</div>
<div class="card-body">
<a href="{{ route('users.create') }}" class="btn btn-success">Добавить</a>
@can('create', \App\Models\User::class)
<div class="card">
<div class="card-header">{{__('Новый пользователь')}}</div>
<div class="card-body">
<a href="{{ route('users.create') }}" class="btn btn-success">Добавить</a>
</div>
</div>
</div>
@endcan
@if (count($users))
<div class="card mt-4">
<div class="card-header">{{__('Пользователи')}}</div>
@ -20,30 +22,36 @@
</thead>
<tbody>
@foreach ($users as $user)
<tr>
<td class="table-text">
<div>
<a href="{{ route('users.show', $user) }}" class="btn btn-block col-8">{{ $user->fio }}</a>
</div>
</td>
<td class="table-text">
<div>
<p>{{ $user->role->description() }}</p>
</div>
</td>
<td>
<div>
<a href="{{ route('users.edit', $user) }}" class="btn btn-warning">Редактировать</a>
</div>
</td>
<td>
<form action="{{ route('users.destroy', $user) }}" method="POST" style="display: inline-block;">
@csrf
@method('DELETE')
<button type="submit" class="btn btn-danger">Удалить</button>
</form>
</td>
</tr>
@can('view', $user)
<tr>
<td class="table-text">
<div>
<a href="{{ route('users.show', $user) }}" class="btn btn-block col-8">{{ $user->fio }}</a>
</div>
</td>
<td class="table-text">
<div>
<p>{{ $user->role->description() }}</p>
</div>
</td>
@can('update', $user)
<td>
<div>
<a href="{{ route('users.edit', $user) }}" class="btn btn-warning">Редактировать</a>
</div>
</td>
@endcan
@can('delete', $user)
<td>
<form action="{{ route('users.destroy', $user) }}" method="POST" style="display: inline-block;">
@csrf
@method('DELETE')
<button type="submit" class="btn btn-danger">Удалить</button>
</form>
</td>
@endcan
</tr>
@endcan
@endforeach
</tbody>
</table>

View File

@ -22,11 +22,13 @@
<h5><strong>Телефон: </strong> {{ $user->phone_number ?? "" }} </h5>
</div>
</div>
<div class="card-footer">
<a href="{{ route('users.edit', $user) }}" class="btn btn-primary">Редактировать</a>
</div>
@can('update', $user)
<div class="card-footer">
<a href="{{ route('users.edit', $user) }}" class="btn btn-primary">Редактировать</a>
</div>
@endcan
</div>
@if($user->role)
@can('viewCar', $user)
<div class="card mt-4">
<div class="card-header">{{__('Автомобиль')}}</div>
<div class="card-body">
@ -49,28 +51,34 @@
{{ $user->car->number }}
</div>
</td>
<td>
<a href="{{ route('users.cars.edit', [$user, $user->car]) }}" class="btn btn-warning">Редактировать</a>
</td>
<td>
<form action="{{ route('users.cars.destroy', [$user, $user->car]) }}" method="POST" style="display: inline-block;">
@csrf
@method('DELETE')
<button type="submit" class="btn btn-danger">Удалить</button>
</form>
</td>
@can('update', [\App\Models\Car::class, $user->car])
<td>
<a href="{{ route('users.cars.edit', [$user, $user->car]) }}" class="btn btn-warning">Редактировать</a>
</td>
@endcan
@can('delete', [\App\Models\Car::class, $user->car])
<td>
<form action="{{ route('users.cars.destroy', [$user, $user->car]) }}" method="POST" style="display: inline-block;">
@csrf
@method('DELETE')
<button type="submit" class="btn btn-danger">Удалить</button>
</form>
</td>
@endcan
</tr>
</tbody>
</table>
@else
<a href="{{ route('users.cars.create', $user) }}" class="btn btn-success">Добавить</a>
@can('create', [App\Models\Car::class, $user])
<a href="{{ route('users.cars.create', $user) }}" class="btn btn-success">Добавить</a>
@endcan
<div class="mt-4">
<label class="form-label"><strong>Автомобиль отсутствует</strong></label>
</div>
@endif
@endif
</div>
</div>
@endif
@endcan
</div>
</div>
@endsection

View File

@ -3,12 +3,14 @@
@section('content')
<div class="container col-md-8">
<div class="row justify-content-center">
<div class="card">
<div class="card-header">{{__('Новый склад')}}</div>
<div class="card-body">
<a href="{{ route('warehouses.create') }}" class="btn btn-success">Добавить</a>
@can('create', \App\Models\Warehouse::class)
<div class="card">
<div class="card-header">{{__('Новый склад')}}</div>
<div class="card-body">
<a href="{{ route('warehouses.create') }}" class="btn btn-success">Добавить</a>
</div>
</div>
</div>
@endcan
@if (count($warehouses))
<div class="card mt-4">
<div class="card-header">{{__('Склады')}}</div>
@ -27,16 +29,20 @@
</div>
</td>
<td>
<div>
<a href="{{ route('warehouses.edit', $warehouse) }}" class="btn btn-warning">Редактировать</a>
</div>
@can('update', $warehouse)
<div>
<a href="{{ route('warehouses.edit', $warehouse) }}" class="btn btn-warning">Редактировать</a>
</div>
@endcan
</td>
<td>
<form action="{{ route('warehouses.destroy', $warehouse) }}" method="POST" style="display: inline-block;">
@csrf
@method('DELETE')
<button type="submit" class="btn btn-danger">Удалить</button>
</form>
@can('delete', $warehouse)
<form action="{{ route('warehouses.destroy', $warehouse) }}" method="POST" style="display: inline-block;">
@csrf
@method('DELETE')
<button type="submit" class="btn btn-danger">Удалить</button>
</form>
@endcan
</td>
</tr>
@endforeach

View File

@ -13,9 +13,11 @@
<h5><strong>Номер телефона: </strong> {{ $warehouse->phone_number ?? "" }} </h5>
</div>
</div>
<div class="card-footer">
<a href="{{ route('warehouses.edit', $warehouse) }}" class="btn btn-primary">Редактировать</a>
</div>
@can('update', $warehouse)
<div class="card-footer">
<a href="{{ route('warehouses.edit', $warehouse) }}" class="btn btn-primary">Редактировать</a>
</div>
@endcan
</div>
</div>
</div>