Files
UNIT3D/app/Models/Playlist.php
Roardom 4bd74c8894 update: use table view for playlists on similar page
More condensed, requested by users, and matches the torrents and requests panels.
2025-06-04 06:50:12 +00:00

99 lines
3.0 KiB
PHP

<?php
declare(strict_types=1);
/**
* NOTICE OF LICENSE.
*
* UNIT3D Community Edition is open-sourced software licensed under the GNU Affero General Public License v3.0
* The details is bundled with this project in the file LICENSE.txt.
*
* @project UNIT3D Community Edition
*
* @author HDVinnie <hdinnovations@protonmail.com>
* @license https://www.gnu.org/licenses/agpl-3.0.en.html/ GNU Affero General Public License v3.0
*/
namespace App\Models;
use App\Traits\Auditable;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
/**
* App\Models\Playlist.
*
* @property int $id
* @property int $playlist_category_id
* @property int $user_id
* @property string $name
* @property string $description
* @property string|null $cover_image
* @property int|null $position
* @property int $is_private
* @property int $is_pinned
* @property int $is_featured
* @property \Illuminate\Support\Carbon|null $created_at
* @property \Illuminate\Support\Carbon|null $updated_at
*/
class Playlist extends Model
{
use Auditable;
/** @use HasFactory<\Database\Factories\PlaylistFactory> */
use HasFactory;
protected $guarded = [];
/**
* Belongs To A User.
*
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo<User, $this>
*/
public function user(): \Illuminate\Database\Eloquent\Relations\BelongsTo
{
return $this->belongsTo(User::class)->withDefault([
'username' => 'System',
'id' => User::SYSTEM_USER_ID,
]);
}
/**
* Belongs to a Category.
*
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo<PlaylistCategory, $this>
*/
public function playlistCategory(): \Illuminate\Database\Eloquent\Relations\BelongsTo
{
return $this->belongsTo(PlaylistCategory::class);
}
/**
* Has Many Torrents.
*
* @return \Illuminate\Database\Eloquent\Relations\BelongsToMany<Torrent, $this, PlaylistTorrent>
*/
public function torrents(): \Illuminate\Database\Eloquent\Relations\BelongsToMany
{
return $this->belongsToMany(Torrent::class, 'playlist_torrents')->using(PlaylistTorrent::class)->withPivot('id')->withTimestamps();
}
/**
* Has Many Torrents.
*
* @return \Illuminate\Database\Eloquent\Relations\HasMany<PlaylistSuggestion, $this>
*/
public function suggestions(): \Illuminate\Database\Eloquent\Relations\HasMany
{
return $this->hasMany(PlaylistSuggestion::class);
}
/**
* @return \Illuminate\Database\Eloquent\Relations\MorphMany<Comment, $this>
*/
public function comments(): \Illuminate\Database\Eloquent\Relations\MorphMany
{
return $this->morphMany(Comment::class, 'commentable');
}
}