
* fix css focuses * #90 - wip * #90 - fix to generate PDF * #90 - wip * #90 - wip * #90 - wip * #90 - wip * #90 - fix to calendar * #90 - wip * #90 - fix * #90 - fix lint * #90 - fix * Apply suggestions from code review Co-authored-by: Krzysztof Rewak <krzysztof.rewak@gmail.com> Co-authored-by: Ewelina Lasowy <56546832+EwelinaLasowy@users.noreply.github.com> * #90 - cr fixes * #90 - fix Co-authored-by: EwelinaLasowy <ewelina.lasowy@blumilk.pl> Co-authored-by: Krzysztof Rewak <krzysztof.rewak@gmail.com> Co-authored-by: Ewelina Lasowy <56546832+EwelinaLasowy@users.noreply.github.com>
128 lines
3.2 KiB
PHP
128 lines
3.2 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Toby\Eloquent\Models;
|
|
|
|
use Database\Factories\UserFactory;
|
|
use Illuminate\Database\Eloquent\Builder;
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
use Illuminate\Database\Eloquent\Relations\HasMany;
|
|
use Illuminate\Database\Eloquent\Relations\HasOne;
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
use Illuminate\Foundation\Auth\User as Authenticatable;
|
|
use Illuminate\Notifications\Notifiable;
|
|
use Illuminate\Support\Collection;
|
|
use Toby\Domain\Enums\EmploymentForm;
|
|
use Toby\Domain\Enums\Role;
|
|
|
|
/**
|
|
* @property int $id
|
|
* @property string $email
|
|
* @property string $password
|
|
* @property Role $role
|
|
* @property Profile $profile
|
|
* @property Collection $vacationLimits
|
|
* @property Collection $vacationRequests
|
|
* @property Collection $vacations
|
|
*/
|
|
class User extends Authenticatable
|
|
{
|
|
use HasFactory;
|
|
use Notifiable;
|
|
use SoftDeletes;
|
|
|
|
protected $guarded = [];
|
|
|
|
protected $casts = [
|
|
"role" => Role::class,
|
|
"last_active_at" => "datetime",
|
|
"employment_form" => EmploymentForm::class,
|
|
"employment_date" => "date",
|
|
];
|
|
|
|
protected $hidden = [
|
|
"remember_token",
|
|
];
|
|
|
|
protected $with = [
|
|
"profile",
|
|
];
|
|
|
|
public function profile(): HasOne
|
|
{
|
|
return $this->hasOne(Profile::class);
|
|
}
|
|
|
|
public function vacationLimits(): HasMany
|
|
{
|
|
return $this->hasMany(VacationLimit::class);
|
|
}
|
|
|
|
public function vacationRequests(): HasMany
|
|
{
|
|
return $this->hasMany(VacationRequest::class);
|
|
}
|
|
|
|
public function createdVacationRequests(): HasMany
|
|
{
|
|
return $this->hasMany(VacationRequest::class, "creator_id");
|
|
}
|
|
|
|
public function vacations(): HasMany
|
|
{
|
|
return $this->hasMany(Vacation::class);
|
|
}
|
|
|
|
public function hasRole(Role $role): bool
|
|
{
|
|
return $this->role === $role;
|
|
}
|
|
|
|
public function hasVacationLimit(YearPeriod $yearPeriod): bool
|
|
{
|
|
return $this->vacationLimits()
|
|
->whereBelongsTo($yearPeriod)
|
|
->whereNotNull("days")
|
|
->exists();
|
|
}
|
|
|
|
public function scopeSearch(Builder $query, ?string $text): Builder
|
|
{
|
|
if ($text === null) {
|
|
return $query;
|
|
}
|
|
|
|
return $query
|
|
->where("email", "ILIKE", "%{$text}%")
|
|
->orWhereRelation(
|
|
"profile",
|
|
fn(Builder $query) => $query
|
|
->where("first_name", "ILIKE", "%{$text}%")
|
|
->orWhere("last_name", "ILIKE", "%{$text}%"),
|
|
);
|
|
}
|
|
|
|
public function scopeOrderByProfileField(Builder $query, string $field): Builder
|
|
{
|
|
$profileQuery = Profile::query()->select($field)->whereColumn("users.id", "profiles.user_id");
|
|
|
|
return $query->orderBy($profileQuery);
|
|
}
|
|
|
|
public function scopeWithVacationLimitIn(Builder $query, YearPeriod $yearPeriod): Builder
|
|
{
|
|
return $query->whereRelation(
|
|
"vacationlimits",
|
|
fn(Builder $query): Builder => $query
|
|
->whereBelongsTo($yearPeriod)
|
|
->whereNotNull("days"),
|
|
);
|
|
}
|
|
|
|
protected static function newFactory(): UserFactory
|
|
{
|
|
return UserFactory::new();
|
|
}
|
|
}
|