From 41c769d4aba1e148bd1c02ad614ec45e47694c71 Mon Sep 17 00:00:00 2001
From: Adrian Hopek
Date: Fri, 4 Feb 2022 10:57:11 +0100
Subject: [PATCH 1/2] #40 - generate pdf for vacation request (#46)
* #40 - wip
* #40 - generate pdf
* #40 - fix
* Update resources/js/Pages/VacationRequest/Show.vue
Co-authored-by: Ewelina Lasowy <56546832+EwelinaLasowy@users.noreply.github.com>
* #40 - fix
Co-authored-by: EwelinaLasowy
Co-authored-by: Ewelina Lasowy <56546832+EwelinaLasowy@users.noreply.github.com>
---
app/Eloquent/Models/User.php | 1 +
app/Eloquent/Models/VacationRequest.php | 8 +
.../Controllers/VacationRequestController.php | 15 +-
.../Http/Requests/UserRequest.php | 2 +
.../Http/Requests/VacationRequestRequest.php | 7 +-
.../Http/Resources/UserFormDataResource.php | 1 +
.../Http/Resources/UserResource.php | 1 +
composer.json | 1 +
composer.lock | 289 +++++++++++++++++-
config/app.php | 1 +
database/factories/UserFactory.php | 1 +
database/factories/VacationRequestFactory.php | 25 +-
.../2014_10_12_000000_create_users_table.php | 1 +
..._100039_create_vacation_requests_table.php | 2 +
database/seeders/DatabaseSeeder.php | 13 +-
resources/js/Pages/Users/Create.vue | 24 ++
resources/js/Pages/Users/Edit.vue | 24 ++
resources/js/Pages/Users/Index.vue | 9 +
resources/js/Pages/VacationRequest/Show.vue | 26 ++
.../views/pdf/vacation-request.blade.php | 95 ++++++
routes/web.php | 2 +
tests/Feature/UserTest.php | 6 +
22 files changed, 544 insertions(+), 10 deletions(-)
create mode 100644 resources/views/pdf/vacation-request.blade.php
diff --git a/app/Eloquent/Models/User.php b/app/Eloquent/Models/User.php
index 7c6fd93..6a7c4db 100644
--- a/app/Eloquent/Models/User.php
+++ b/app/Eloquent/Models/User.php
@@ -22,6 +22,7 @@ use Toby\Domain\Enums\Role;
* @property string $last_name
* @property string $email
* @property string $avatar
+ * @property string $position
* @property Role $role
* @property EmploymentForm $employment_form
* @property Carbon $employment_date
diff --git a/app/Eloquent/Models/VacationRequest.php b/app/Eloquent/Models/VacationRequest.php
index 528759d..9c7ada0 100644
--- a/app/Eloquent/Models/VacationRequest.php
+++ b/app/Eloquent/Models/VacationRequest.php
@@ -23,7 +23,10 @@ use Toby\Domain\Enums\VacationType;
* @property Carbon $to
* @property string $comment
* @property User $user
+ * @property YearPeriod $yearPeriod
* @property Collection $activities
+ * @property Carbon $created_at
+ * @property Carbon $updated_at
*/
class VacationRequest extends Model
{
@@ -43,6 +46,11 @@ class VacationRequest extends Model
return $this->belongsTo(User::class);
}
+ public function yearPeriod(): BelongsTo
+ {
+ return $this->belongsTo(YearPeriod::class);
+ }
+
public function activities(): HasMany
{
return $this->hasMany(VacationRequestActivity::class);
diff --git a/app/Infrastructure/Http/Controllers/VacationRequestController.php b/app/Infrastructure/Http/Controllers/VacationRequestController.php
index a19b81b..3c2eaf8 100644
--- a/app/Infrastructure/Http/Controllers/VacationRequestController.php
+++ b/app/Infrastructure/Http/Controllers/VacationRequestController.php
@@ -4,13 +4,16 @@ declare(strict_types=1);
namespace Toby\Infrastructure\Http\Controllers;
+use Barryvdh\DomPDF\Facade\Pdf;
use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Request;
+use Illuminate\Http\Response as LaravelResponse;
use Inertia\Response;
use Toby\Domain\Enums\VacationRequestState;
use Toby\Domain\Enums\VacationType;
use Toby\Domain\VacationRequestStateManager;
use Toby\Domain\Validation\VacationRequestValidator;
+use Toby\Eloquent\Helpers\YearPeriodRetriever;
use Toby\Eloquent\Models\VacationRequest;
use Toby\Infrastructure\Http\Requests\VacationRequestRequest;
use Toby\Infrastructure\Http\Resources\VacationRequestActivityResource;
@@ -18,10 +21,11 @@ use Toby\Infrastructure\Http\Resources\VacationRequestResource;
class VacationRequestController extends Controller
{
- public function index(Request $request): Response
+ public function index(Request $request, YearPeriodRetriever $yearPeriodRetriever): Response
{
$vacationRequests = $request->user()
->vacationRequests()
+ ->where("year_period_id", $yearPeriodRetriever->selected()->id)
->latest()
->states(VacationRequestState::filterByStatus($request->query("status", "all")))
->paginate();
@@ -40,6 +44,15 @@ class VacationRequestController extends Controller
]);
}
+ public function download(VacationRequest $vacationRequest): LaravelResponse
+ {
+ $pdf = PDF::loadView("pdf.vacation-request", [
+ "vacationRequest" => $vacationRequest,
+ ]);
+
+ return $pdf->stream();
+ }
+
public function create(): Response
{
return inertia("VacationRequest/Create", [
diff --git a/app/Infrastructure/Http/Requests/UserRequest.php b/app/Infrastructure/Http/Requests/UserRequest.php
index 2f7ed8c..e46e5f0 100644
--- a/app/Infrastructure/Http/Requests/UserRequest.php
+++ b/app/Infrastructure/Http/Requests/UserRequest.php
@@ -19,6 +19,7 @@ class UserRequest extends FormRequest
"lastName" => ["required", "min:3", "max:80"],
"email" => ["required", "email", Rule::unique("users", "email")->ignore($this->user)],
"role" => ["required", new Enum(Role::class)],
+ "position" => ["required"],
"employmentForm" => ["required", new Enum(EmploymentForm::class)],
"employmentDate" => ["required", "date_format:Y-m-d"],
];
@@ -30,6 +31,7 @@ class UserRequest extends FormRequest
"first_name" => $this->get("firstName"),
"last_name" => $this->get("lastName"),
"email" => $this->get("email"),
+ "position" => $this->get("position"),
"role" => $this->get("role"),
"employment_form" => $this->get("employmentForm"),
"employment_date" => $this->get("employmentDate"),
diff --git a/app/Infrastructure/Http/Requests/VacationRequestRequest.php b/app/Infrastructure/Http/Requests/VacationRequestRequest.php
index eeea29b..3fd9e9f 100644
--- a/app/Infrastructure/Http/Requests/VacationRequestRequest.php
+++ b/app/Infrastructure/Http/Requests/VacationRequestRequest.php
@@ -5,8 +5,10 @@ declare(strict_types=1);
namespace Toby\Infrastructure\Http\Requests;
use Illuminate\Foundation\Http\FormRequest;
+use Illuminate\Support\Carbon;
use Illuminate\Validation\Rules\Enum;
use Toby\Domain\Enums\VacationType;
+use Toby\Eloquent\Models\YearPeriod;
use Toby\Infrastructure\Http\Rules\YearPeriodExists;
class VacationRequestRequest extends FormRequest
@@ -23,10 +25,13 @@ class VacationRequestRequest extends FormRequest
public function data(): array
{
+ $from = $this->get("from");
+
return [
"type" => $this->get("type"),
- "from" => $this->get("from"),
+ "from" => $from,
"to" => $this->get("to"),
+ "year_period_id" => YearPeriod::findByYear(Carbon::create($from)->year)->id,
"comment" => $this->get("comment"),
];
}
diff --git a/app/Infrastructure/Http/Resources/UserFormDataResource.php b/app/Infrastructure/Http/Resources/UserFormDataResource.php
index 451fda2..6847362 100644
--- a/app/Infrastructure/Http/Resources/UserFormDataResource.php
+++ b/app/Infrastructure/Http/Resources/UserFormDataResource.php
@@ -18,6 +18,7 @@ class UserFormDataResource extends JsonResource
"lastName" => $this->last_name,
"email" => $this->email,
"role" => $this->role,
+ "position" => $this->position,
"employmentForm" => $this->employment_form,
"employmentDate" => $this->employment_date->toDateString(),
];
diff --git a/app/Infrastructure/Http/Resources/UserResource.php b/app/Infrastructure/Http/Resources/UserResource.php
index bdff955..5e3107f 100644
--- a/app/Infrastructure/Http/Resources/UserResource.php
+++ b/app/Infrastructure/Http/Resources/UserResource.php
@@ -17,6 +17,7 @@ class UserResource extends JsonResource
"name" => $this->fullName,
"email" => $this->email,
"role" => $this->role->label(),
+ "position" => $this->position,
"avatar" => asset($this->avatar),
"deleted" => $this->trashed(),
"employmentForm" => $this->employment_form->label(),
diff --git a/composer.json b/composer.json
index f2962a5..ebd3f96 100644
--- a/composer.json
+++ b/composer.json
@@ -8,6 +8,7 @@
"php": "^8.1",
"ext-pdo": "*",
"azuyalabs/yasumi": "^2.4",
+ "barryvdh/laravel-dompdf": "^1.0",
"fruitcake/laravel-cors": "^2.0",
"guzzlehttp/guzzle": "^7.0.1",
"inertiajs/inertia-laravel": "^0.5.1",
diff --git a/composer.lock b/composer.lock
index 066cfc9..a7e5000 100644
--- a/composer.lock
+++ b/composer.lock
@@ -4,7 +4,7 @@
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
"This file is @generated automatically"
],
- "content-hash": "bf5f7d8f40ecadea64ae8564a3df3110",
+ "content-hash": "c2f475e65f84bdff45169e4443d9ef4f",
"packages": [
{
"name": "asm89/stack-cors",
@@ -135,6 +135,82 @@
],
"time": "2022-01-30T07:43:17+00:00"
},
+ {
+ "name": "barryvdh/laravel-dompdf",
+ "version": "v1.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/barryvdh/laravel-dompdf.git",
+ "reference": "e3f429e97087b2ef19b83e5ed313f080f2477685"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/barryvdh/laravel-dompdf/zipball/e3f429e97087b2ef19b83e5ed313f080f2477685",
+ "reference": "e3f429e97087b2ef19b83e5ed313f080f2477685",
+ "shasum": ""
+ },
+ "require": {
+ "dompdf/dompdf": "^1",
+ "illuminate/support": "^6|^7|^8|^9",
+ "php": "^7.2 || ^8.0"
+ },
+ "require-dev": {
+ "nunomaduro/larastan": "^1|^2",
+ "orchestra/testbench": "^4|^5|^6|^7",
+ "phpro/grumphp": "^1",
+ "squizlabs/php_codesniffer": "^3.5"
+ },
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0-dev"
+ },
+ "laravel": {
+ "providers": [
+ "Barryvdh\\DomPDF\\ServiceProvider"
+ ],
+ "aliases": {
+ "PDF": "Barryvdh\\DomPDF\\Facade\\Pdf"
+ }
+ }
+ },
+ "autoload": {
+ "psr-4": {
+ "Barryvdh\\DomPDF\\": "src"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Barry vd. Heuvel",
+ "email": "barryvdh@gmail.com"
+ }
+ ],
+ "description": "A DOMPDF Wrapper for Laravel",
+ "keywords": [
+ "dompdf",
+ "laravel",
+ "pdf"
+ ],
+ "support": {
+ "issues": "https://github.com/barryvdh/laravel-dompdf/issues",
+ "source": "https://github.com/barryvdh/laravel-dompdf/tree/v1.0.0"
+ },
+ "funding": [
+ {
+ "url": "https://fruitcake.nl",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/barryvdh",
+ "type": "github"
+ }
+ ],
+ "time": "2022-01-29T08:02:59+00:00"
+ },
{
"name": "brick/math",
"version": "0.9.3",
@@ -437,6 +513,73 @@
],
"time": "2022-01-12T08:27:12+00:00"
},
+ {
+ "name": "dompdf/dompdf",
+ "version": "v1.1.1",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/dompdf/dompdf.git",
+ "reference": "de4aad040737a89fae2129cdeb0f79c45513128d"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/dompdf/dompdf/zipball/de4aad040737a89fae2129cdeb0f79c45513128d",
+ "reference": "de4aad040737a89fae2129cdeb0f79c45513128d",
+ "shasum": ""
+ },
+ "require": {
+ "ext-dom": "*",
+ "ext-mbstring": "*",
+ "phenx/php-font-lib": "^0.5.2",
+ "phenx/php-svg-lib": "^0.3.3",
+ "php": "^7.1 || ^8.0"
+ },
+ "require-dev": {
+ "mockery/mockery": "^1.3",
+ "phpunit/phpunit": "^7.5 || ^8 || ^9",
+ "squizlabs/php_codesniffer": "^3.5"
+ },
+ "suggest": {
+ "ext-gd": "Needed to process images",
+ "ext-gmagick": "Improves image processing performance",
+ "ext-imagick": "Improves image processing performance",
+ "ext-zlib": "Needed for pdf stream compression"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Dompdf\\": "src/"
+ },
+ "classmap": [
+ "lib/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "LGPL-2.1"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Ménager",
+ "email": "fabien.menager@gmail.com"
+ },
+ {
+ "name": "Brian Sweeney",
+ "email": "eclecticgeek@gmail.com"
+ },
+ {
+ "name": "Gabriel Bull",
+ "email": "me@gabrielbull.com"
+ }
+ ],
+ "description": "DOMPDF is a CSS 2.1 compliant HTML to PDF converter",
+ "homepage": "https://github.com/dompdf/dompdf",
+ "support": {
+ "issues": "https://github.com/dompdf/dompdf/issues",
+ "source": "https://github.com/dompdf/dompdf/tree/v1.1.1"
+ },
+ "time": "2021-11-24T00:45:04+00:00"
+ },
{
"name": "dragonmantank/cron-expression",
"version": "v3.3.1",
@@ -2846,6 +2989,95 @@
],
"time": "2021-07-19T03:43:32+00:00"
},
+ {
+ "name": "phenx/php-font-lib",
+ "version": "0.5.4",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/dompdf/php-font-lib.git",
+ "reference": "dd448ad1ce34c63d09baccd05415e361300c35b4"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/dompdf/php-font-lib/zipball/dd448ad1ce34c63d09baccd05415e361300c35b4",
+ "reference": "dd448ad1ce34c63d09baccd05415e361300c35b4",
+ "shasum": ""
+ },
+ "require": {
+ "ext-mbstring": "*"
+ },
+ "require-dev": {
+ "symfony/phpunit-bridge": "^3 || ^4 || ^5"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "FontLib\\": "src/FontLib"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "LGPL-3.0"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Ménager",
+ "email": "fabien.menager@gmail.com"
+ }
+ ],
+ "description": "A library to read, parse, export and make subsets of different types of font files.",
+ "homepage": "https://github.com/PhenX/php-font-lib",
+ "support": {
+ "issues": "https://github.com/dompdf/php-font-lib/issues",
+ "source": "https://github.com/dompdf/php-font-lib/tree/0.5.4"
+ },
+ "time": "2021-12-17T19:44:54+00:00"
+ },
+ {
+ "name": "phenx/php-svg-lib",
+ "version": "0.3.4",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/PhenX/php-svg-lib.git",
+ "reference": "f627771eb854aa7f45f80add0f23c6c4d67ea0f2"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/PhenX/php-svg-lib/zipball/f627771eb854aa7f45f80add0f23c6c4d67ea0f2",
+ "reference": "f627771eb854aa7f45f80add0f23c6c4d67ea0f2",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^7.4 || ^8.0",
+ "sabberworm/php-css-parser": "^8.3"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^9.5"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Svg\\": "src/Svg"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "LGPL-3.0"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Ménager",
+ "email": "fabien.menager@gmail.com"
+ }
+ ],
+ "description": "A library to read, parse and export to PDF SVG files.",
+ "homepage": "https://github.com/PhenX/php-svg-lib",
+ "support": {
+ "issues": "https://github.com/PhenX/php-svg-lib/issues",
+ "source": "https://github.com/PhenX/php-svg-lib/tree/0.3.4"
+ },
+ "time": "2021-10-18T02:13:32+00:00"
+ },
{
"name": "phpoption/phpoption",
"version": "1.8.1",
@@ -3572,6 +3804,59 @@
],
"time": "2021-09-25T23:10:38+00:00"
},
+ {
+ "name": "sabberworm/php-css-parser",
+ "version": "8.4.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sabberworm/PHP-CSS-Parser.git",
+ "reference": "e41d2140031d533348b2192a83f02d8dd8a71d30"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sabberworm/PHP-CSS-Parser/zipball/e41d2140031d533348b2192a83f02d8dd8a71d30",
+ "reference": "e41d2140031d533348b2192a83f02d8dd8a71d30",
+ "shasum": ""
+ },
+ "require": {
+ "ext-iconv": "*",
+ "php": ">=5.6.20"
+ },
+ "require-dev": {
+ "codacy/coverage": "^1.4",
+ "phpunit/phpunit": "^4.8.36"
+ },
+ "suggest": {
+ "ext-mbstring": "for parsing UTF-8 CSS"
+ },
+ "type": "library",
+ "autoload": {
+ "psr-4": {
+ "Sabberworm\\CSS\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Raphael Schweikert"
+ }
+ ],
+ "description": "Parser for CSS Files written in PHP",
+ "homepage": "https://www.sabberworm.com/blog/2010/6/10/php-css-parser",
+ "keywords": [
+ "css",
+ "parser",
+ "stylesheet"
+ ],
+ "support": {
+ "issues": "https://github.com/sabberworm/PHP-CSS-Parser/issues",
+ "source": "https://github.com/sabberworm/PHP-CSS-Parser/tree/8.4.0"
+ },
+ "time": "2021-12-11T13:40:54+00:00"
+ },
{
"name": "swiftmailer/swiftmailer",
"version": "v6.3.0",
@@ -10027,5 +10312,5 @@
"ext-pdo": "*"
},
"platform-dev": [],
- "plugin-api-version": "2.1.0"
+ "plugin-api-version": "2.2.0"
}
diff --git a/config/app.php b/config/app.php
index cbd96cb..a5d12a9 100644
--- a/config/app.php
+++ b/config/app.php
@@ -43,5 +43,6 @@ return [
Toby\Architecture\Providers\RouteServiceProvider::class,
Toby\Architecture\Providers\TelescopeServiceProvider::class,
Toby\Architecture\Providers\ObserverServiceProvider::class,
+ Barryvdh\DomPDF\ServiceProvider::class,
],
];
diff --git a/database/factories/UserFactory.php b/database/factories/UserFactory.php
index 5e4086a..c6a5d93 100644
--- a/database/factories/UserFactory.php
+++ b/database/factories/UserFactory.php
@@ -22,6 +22,7 @@ class UserFactory extends Factory
"last_name" => $this->faker->lastName(),
"email" => $this->faker->unique()->safeEmail(),
"employment_form" => $this->faker->randomElement(EmploymentForm::cases()),
+ "position" => $this->faker->jobTitle(),
"role" => Role::EMPLOYEE,
"employment_date" => Carbon::createFromInterface($this->faker->dateTimeBetween("2020-10-27"))->toDateString(),
"remember_token" => Str::random(10),
diff --git a/database/factories/VacationRequestFactory.php b/database/factories/VacationRequestFactory.php
index 839e2b7..e8bec48 100644
--- a/database/factories/VacationRequestFactory.php
+++ b/database/factories/VacationRequestFactory.php
@@ -4,11 +4,13 @@ declare(strict_types=1);
namespace Database\Factories;
+use Carbon\CarbonImmutable;
use Illuminate\Database\Eloquent\Factories\Factory;
use Toby\Domain\Enums\VacationRequestState;
use Toby\Domain\Enums\VacationType;
use Toby\Eloquent\Models\User;
use Toby\Eloquent\Models\VacationRequest;
+use Toby\Eloquent\Models\YearPeriod;
class VacationRequestFactory extends Factory
{
@@ -16,17 +18,30 @@ class VacationRequestFactory extends Factory
public function definition(): array
{
- $number = $this->faker->numberBetween(1, 20);
- $year = $this->faker->year;
+ $from = CarbonImmutable::create($this->faker->dateTimeThisYear);
+ $days = $this->faker->numberBetween(0, 20);
return [
"user_id" => User::factory(),
- "name" => "{$number}/{$year}",
+ "year_period_id" => YearPeriod::factory(),
+ "name" => fn(array $attributes) => $this->generateName($attributes),
"type" => $this->faker->randomElement(VacationType::cases()),
"state" => $this->faker->randomElement(VacationRequestState::cases()),
- "from" => $this->faker->date,
- "to" => $this->faker->date,
+ "from" => $from,
+ "to" => $from->addDays($days),
"comment" => $this->faker->boolean ? $this->faker->paragraph() : null,
];
}
+
+ protected function generateName(array $attributes): string
+ {
+ $year = YearPeriod::find($attributes["year_period_id"])->year;
+ $user = User::find($attributes["user_id"]);
+
+ $number = $user->vacationRequests()
+ ->whereYear("from", $year)
+ ->count() + 1;
+
+ return "{$number}/{$year}";
+ }
}
diff --git a/database/migrations/2014_10_12_000000_create_users_table.php b/database/migrations/2014_10_12_000000_create_users_table.php
index cc11d89..5f09111 100644
--- a/database/migrations/2014_10_12_000000_create_users_table.php
+++ b/database/migrations/2014_10_12_000000_create_users_table.php
@@ -17,6 +17,7 @@ return new class() extends Migration {
$table->string("email")->unique();
$table->string("avatar")->nullable();
$table->string("role")->default(Role::EMPLOYEE->value);
+ $table->string("position");
$table->string("employment_form");
$table->date("employment_date");
$table->rememberToken();
diff --git a/database/migrations/2022_01_26_100039_create_vacation_requests_table.php b/database/migrations/2022_01_26_100039_create_vacation_requests_table.php
index a7e4cd7..f5270da 100644
--- a/database/migrations/2022_01_26_100039_create_vacation_requests_table.php
+++ b/database/migrations/2022_01_26_100039_create_vacation_requests_table.php
@@ -6,6 +6,7 @@ use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
use Toby\Eloquent\Models\User;
+use Toby\Eloquent\Models\YearPeriod;
return new class() extends Migration {
public function up(): void
@@ -14,6 +15,7 @@ return new class() extends Migration {
$table->id();
$table->string("name");
$table->foreignIdFor(User::class)->constrained()->cascadeOnDelete();
+ $table->foreignIdFor(YearPeriod::class)->constrained()->cascadeOnDelete();
$table->string("type");
$table->string("state")->nullable();
$table->date("from");
diff --git a/database/seeders/DatabaseSeeder.php b/database/seeders/DatabaseSeeder.php
index af9ac30..205246a 100644
--- a/database/seeders/DatabaseSeeder.php
+++ b/database/seeders/DatabaseSeeder.php
@@ -31,7 +31,6 @@ class DatabaseSeeder extends Seeder
User::factory([
"email" => env("LOCAL_EMAIL_FOR_LOGIN_VIA_GOOGLE"),
])
- ->hasVacationRequests(5)
->create();
$users = User::all();
@@ -70,6 +69,18 @@ class DatabaseSeeder extends Seeder
}
})
->create();
+
+ $yearPeriods = YearPeriod::all();
+
+ foreach ($users as $user) {
+ VacationRequest::factory()
+ ->count(10)
+ ->for($user)
+ ->sequence(fn() => [
+ "year_period_id" => $yearPeriods->random()->id,
+ ])
+ ->create();
+ }
}
protected function generateAvatarsForUsers(Collection $users): void
diff --git a/resources/js/Pages/Users/Create.vue b/resources/js/Pages/Users/Create.vue
index 5347b60..b871b93 100644
--- a/resources/js/Pages/Users/Create.vue
+++ b/resources/js/Pages/Users/Create.vue
@@ -82,6 +82,29 @@
+
+
+
+
+
+ {{ form.errors.position }}
+
+
+
+
+
+
+
+
+ {{ form.errors.position }}
+
+
+
role.value === props.user.role),
+ position: props.user.position,
employmentForm: props.employmentForms.find(form => form.value === props.user.employmentForm),
employmentDate: props.user.employmentDate,
})
diff --git a/resources/js/Pages/Users/Index.vue b/resources/js/Pages/Users/Index.vue
index 0565cc9..93e6f10 100644
--- a/resources/js/Pages/Users/Index.vue
+++ b/resources/js/Pages/Users/Index.vue
@@ -49,6 +49,12 @@
>
Rola
+
+ Stanowisko
+ |
{{ user.role }}
+ |
+ {{ user.position }}
+ |
{{ user.employmentForm }}
|
diff --git a/resources/js/Pages/VacationRequest/Show.vue b/resources/js/Pages/VacationRequest/Show.vue
index 77ec86e..6bee934 100644
--- a/resources/js/Pages/VacationRequest/Show.vue
+++ b/resources/js/Pages/VacationRequest/Show.vue
@@ -58,6 +58,30 @@
{{ request.comment }}
+
+
+ Załączniki
+
+
+
+ -
+
+
+
wniosek_urlopowy.pdf
+
+
+
+
+
+
@@ -196,11 +220,13 @@