mirror of
https://github.com/Einundzwanzig-Podcast/einundzwanzig-portal.git
synced 2025-12-11 06:46:47 +00:00
Shift automatically applies the Laravel coding style - which uses the PSR-12 coding style as a base with some minor additions. You may customize the code style applied by configuring [Pint](https://laravel.com/docs/pint), [PHP CS Fixer](https://github.com/FriendsOfPHP/PHP-CS-Fixer), or [PHP CodeSniffer](https://github.com/squizlabs/PHP_CodeSniffer) for your project root. For more information on customizing the code style applied by Shift, [watch this short video](https://laravelshift.com/videos/shift-code-style).
72 lines
1.6 KiB
PHP
72 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace App\Models;
|
|
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
|
use Spatie\Comments\Models\Concerns\HasComments;
|
|
|
|
class MeetupEvent extends Model
|
|
{
|
|
use HasFactory;
|
|
use HasComments;
|
|
|
|
/**
|
|
* The attributes that aren't mass assignable.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $guarded = [];
|
|
|
|
/**
|
|
* The attributes that should be cast to native types.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $casts = [
|
|
'id' => 'integer',
|
|
'meetup_id' => 'integer',
|
|
'start' => 'datetime',
|
|
'attendees' => 'array',
|
|
'might_attendees' => 'array',
|
|
];
|
|
|
|
protected static function booted()
|
|
{
|
|
static::creating(function ($model) {
|
|
if (! $model->created_by) {
|
|
$model->created_by = auth()->id();
|
|
}
|
|
});
|
|
}
|
|
|
|
public function createdBy(): BelongsTo
|
|
{
|
|
return $this->belongsTo(User::class, 'created_by');
|
|
}
|
|
|
|
public function meetup(): BelongsTo
|
|
{
|
|
return $this->belongsTo(Meetup::class);
|
|
}
|
|
|
|
/*
|
|
* This string will be used in notifications on what a new comment
|
|
* was made.
|
|
*/
|
|
public function commentableName(): string
|
|
{
|
|
return __('Meetup Event');
|
|
}
|
|
|
|
/*
|
|
* This URL will be used in notifications to let the user know
|
|
* where the comment itself can be read.
|
|
*/
|
|
public function commentUrl(): string
|
|
{
|
|
return url()->route('meetup.event.landing', ['country' => $this->meetup->city->country, 'meetupEvent' => $this]);
|
|
}
|
|
}
|