. */ namespace App\Models; use DB; use Illuminate\Database\Eloquent\Model; /** * App\Models\ShowSong * * @property integer $id * @property string $title * @property string $lyrics * @property string $slug * @property \Carbon\Carbon $created_at * @property \Carbon\Carbon $updated_at * @property string $deleted_at * @property-read \Illuminate\Database\Eloquent\Collection|\App\Models\Track[] $trackCountRelation * @property-read \Illuminate\Database\Eloquent\Collection|\App\Models\Track[] $tracks * @method static \Illuminate\Database\Query\Builder|\App\Models\ShowSong whereId($value) * @method static \Illuminate\Database\Query\Builder|\App\Models\ShowSong whereTitle($value) * @method static \Illuminate\Database\Query\Builder|\App\Models\ShowSong whereLyrics($value) * @method static \Illuminate\Database\Query\Builder|\App\Models\ShowSong whereSlug($value) * @method static \Illuminate\Database\Query\Builder|\App\Models\ShowSong whereCreatedAt($value) * @method static \Illuminate\Database\Query\Builder|\App\Models\ShowSong whereUpdatedAt($value) * @method static \Illuminate\Database\Query\Builder|\App\Models\ShowSong whereDeletedAt($value) * @mixin \Eloquent */ class ShowSong extends Model { protected $table = 'show_songs'; protected $fillable = ['title', 'slug', 'lyrics']; public function trackCountRelation() { return $this->belongsToMany(Track::class) ->select(['show_song_id', DB::raw('count(*) as track_count')]) ->groupBy('show_song_id', 'track_id'); } public function tracks() { return $this->belongsToMany(Track::class); } }