- Delete old Vite+Svelte frontend - Initialize new SvelteKit project with TypeScript - Configure Tailwind CSS v4 + DaisyUI - Implement JWT authentication with auto-refresh - Create login page with form validation (Zod) - Add protected route guards - Update Docker configuration for single-stage build - Add E2E tests with Playwright (6/11 passing) - Fix Svelte 5 reactivity with $state() runes Known issues: - 5 E2E tests failing (timing/async issues) - Token refresh implementation needs debugging - Validation error display timing
47 lines
918 B
PHP
47 lines
918 B
PHP
<?php
|
|
|
|
namespace App\Models;
|
|
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Database\Eloquent\Concerns\HasUuids;
|
|
|
|
class Actual extends Model
|
|
{
|
|
use HasFactory, HasUuids;
|
|
|
|
protected $primaryKey = 'id';
|
|
public $incrementing = false;
|
|
protected $keyType = 'string';
|
|
|
|
protected $table = 'actuals';
|
|
|
|
protected $fillable = [
|
|
'project_id',
|
|
'team_member_id',
|
|
'month',
|
|
'hours_logged',
|
|
];
|
|
|
|
protected $casts = [
|
|
'month' => 'date',
|
|
'hours_logged' => 'decimal:2',
|
|
];
|
|
|
|
/**
|
|
* Get the project that owns the actual.
|
|
*/
|
|
public function project()
|
|
{
|
|
return $this->belongsTo(Project::class);
|
|
}
|
|
|
|
/**
|
|
* Get the team member that owns the actual.
|
|
*/
|
|
public function teamMember()
|
|
{
|
|
return $this->belongsTo(TeamMember::class);
|
|
}
|
|
}
|