58 lines
2.0 KiB
PHP
58 lines
2.0 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\User;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\DB;
|
|
use App\Models\Artwork;
|
|
use App\Models\ArtworkStats;
|
|
use App\Models\User;
|
|
|
|
class TopAuthorsController extends Controller
|
|
{
|
|
public function index(Request $request)
|
|
{
|
|
$perPage = 20;
|
|
$metric = strtolower($request->query('metric', 'views'));
|
|
|
|
if (! in_array($metric, ['views', 'downloads'])) {
|
|
$metric = 'views';
|
|
}
|
|
|
|
$sub = Artwork::query()
|
|
->select('artworks.user_id')
|
|
->join('artwork_stats', 'artwork_stats.artwork_id', '=', 'artworks.id')
|
|
->where('artworks.is_public', true)
|
|
->where('artworks.is_approved', true)
|
|
->whereNotNull('artworks.published_at')
|
|
->where('artworks.published_at', '<=', now())
|
|
->whereNull('artworks.deleted_at')
|
|
->selectRaw('artworks.user_id, SUM(artwork_stats.' . $metric . ') as total_metric, MAX(artworks.published_at) as latest_published')
|
|
->groupBy('artworks.user_id');
|
|
|
|
$query = DB::table(DB::raw('(' . $sub->toSql() . ') as t'))
|
|
->mergeBindings($sub->getQuery())
|
|
->join('users as u', 'u.id', '=', 't.user_id')
|
|
->select('u.id as user_id', 'u.name as uname', 'u.username', 't.total_metric', 't.latest_published')
|
|
->orderByDesc('t.total_metric')
|
|
->orderByDesc('t.latest_published');
|
|
|
|
$authors = $query->paginate($perPage)->withQueryString();
|
|
|
|
$authors->getCollection()->transform(function ($row) use ($metric) {
|
|
return (object) [
|
|
'user_id' => $row->user_id,
|
|
'uname' => $row->uname,
|
|
'username' => $row->username,
|
|
'total' => (int) $row->total_metric,
|
|
'metric' => $metric,
|
|
];
|
|
});
|
|
|
|
$page_title = 'Top Authors';
|
|
|
|
return view('user.top-authors', compact('page_title', 'authors', 'metric'));
|
|
}
|
|
}
|