. */ namespace App\Http\Controllers\Api\Web; use App\Http\Controllers\ApiControllerBase; use App\Models\Genre; use App\Models\License; use App\Models\ShowSong; use App\Models\TrackType; use Illuminate\Support\Facades\DB; class TaxonomiesController extends ApiControllerBase { public function getAll() { return \Response::json([ 'licenses' => License::all()->toArray(), 'genres' => Genre::with('trackCountRelation') ->orderBy('name') ->get() ->toArray(), 'track_types' => TrackType::select( 'track_types.*', DB::raw('(SELECT COUNT(id) FROM tracks WHERE tracks.track_type_id = track_types.id AND tracks.published_at IS NOT NULL) AS track_count') ) ->where('id', '!=', TrackType::UNCLASSIFIED_TRACK) ->get()->toArray(), 'show_songs' => ShowSong::select( 'title', 'id', 'slug', DB::raw('(SELECT COUNT(tracks.id) FROM show_song_track INNER JOIN tracks ON tracks.id = show_song_track.track_id WHERE show_song_track.show_song_id = show_songs.id AND tracks.published_at IS NOT NULL) AS track_count') )->orderBy('title')->get()->toArray(), ], 200); } }