Files
crewli/api/app/Models/Organisation.php
bert.hausmans 9ccf1eaceb feat(timetable): Artist domain — 7 enums + 9 Eloquent models
Enums under App\Enums\Artist\ (PascalCase per FormBuilder convention,
snake_case wire values per RFC):
- ArtistEngagementStatus (D9, 9 states + Dutch labels)
- BumaHandledBy (D26)
- FeeType, PaymentStatus
- AdvanceSectionType, AdvanceSectionSubmissionStatus, AdvanceSubmissionStatus

Models:
- Artist (org-scoped, slug-unique-per-org via creating boot hook)
- ArtistEngagement (per-event booking, denorm organisation_id)
- Genre, Stage (event-scoped, ordered scope), StageDay (Pivot, int PK)
- Performance (engagement-scoped, isParked() helper)
- AdvanceSection, AdvanceSubmission, ArtistContact (primary scope)

OrganisationScope wired:
- Direct organisation_id: Artist, Genre, ArtistEngagement
- FK-chain via tenantScopeStrategy(): Stage→Event, Performance→Engagement,
  AdvanceSection→Engagement, AdvanceSubmission→Section→Engagement,
  ArtistContact→Artist, StageDay→Stage→Event

Soft-deletes: Artist, ArtistEngagement, Performance (per RFC §5.4).
LogsActivity baseline (logFillable+dontSubmitEmptyLogs) on all business
models — actual mutation surfaces wire LogOptions in Session 2+.

Inverse relations added on Organisation, Event, Company.
companies.handles_buma cast added.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-08 18:00:28 +02:00

119 lines
2.8 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Models;
use Illuminate\Database\Eloquent\Concerns\HasUlids;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
use Illuminate\Database\Eloquent\Relations\HasMany;
use Illuminate\Database\Eloquent\Relations\HasOne;
use Illuminate\Database\Eloquent\SoftDeletes;
use Spatie\Activitylog\Models\Concerns\LogsActivity;
use Spatie\Activitylog\Support\LogOptions;
final class Organisation extends Model
{
use HasFactory;
use HasUlids;
use LogsActivity;
use SoftDeletes;
protected $fillable = [
'name',
'slug',
'contact_name',
'contact_email',
'phone',
'website',
'billing_status',
'settings',
'email_logo_url',
'email_primary_color',
'email_reply_to',
'email_sender_name',
'email_footer_text',
];
protected function casts(): array
{
return [
'settings' => 'array',
];
}
public function getActivitylogOptions(): LogOptions
{
return LogOptions::defaults()
->logOnly(['name', 'slug', 'contact_name', 'contact_email', 'phone', 'website'])
->logOnlyDirty()
->dontLogEmptyChanges()
->useLogName('organisation');
}
public function users(): BelongsToMany
{
return $this->belongsToMany(User::class, 'organisation_user')
->using(\App\Models\Pivots\OrganisationUser::class)
->withPivot('role')
->withTimestamps();
}
public function events(): HasMany
{
return $this->hasMany(Event::class);
}
public function invitations(): HasMany
{
return $this->hasMany(UserInvitation::class);
}
public function crowdTypes(): HasMany
{
return $this->hasMany(CrowdType::class);
}
public function companies(): HasMany
{
return $this->hasMany(Company::class);
}
public function personTags(): HasMany
{
return $this->hasMany(PersonTag::class);
}
public function emailSettings(): HasOne
{
return $this->hasOne(OrganisationEmailSettings::class);
}
public function emailTemplates(): HasMany
{
return $this->hasMany(OrganisationEmailTemplate::class);
}
public function emailLogs(): HasMany
{
return $this->hasMany(EmailLog::class);
}
public function artists(): HasMany
{
return $this->hasMany(Artist::class);
}
public function genres(): HasMany
{
return $this->hasMany(Genre::class);
}
public function artistEngagements(): HasMany
{
return $this->hasMany(ArtistEngagement::class);
}
}