Homepage
- Add HomepageService with hero, trending (award-weighted), fresh uploads,
popular tags, creator spotlight (weekly uploads ranking), and news sections
- Add React components: HomePage, HomeHero, HomeTrending, HomeFresh,
HomeTags, HomeCreators, HomeNews (lazy-loaded below the fold)
- Wire home.blade.php with JSON props, SEO meta, JSON-LD, and hero preload
- Add HomePage.jsx to vite.config.js inputs
Profile page
- Hero banner with random user artwork as background + dark gradient overlay
- Favourites section uses real Artwork models + <x-artwork-card> for CDN URLs
- Newest artworks grid: gallery-grid → grid grid-cols-2 gap-4
Edit Profile page (user.blade.php)
- Add hero banner (featured wallpaper/photography via artwork_features,
content_type_id IN [2,3]) sourced in UserController
- Remove bg-deep from outer wrapper; card backgrounds: bg-panel → bg-nova-800
- Remove stray AI-generated tag fragment from template
Author profile links
- Fix all /@username routes in: HomepageService, MonthlyCommentatorsController,
LatestCommentsController, MyBuddiesController and corresponding blade views
Legacy view namespace
- Register View::addNamespace('legacy', resource_path('views/_legacy'))
in AppServiceProvider::boot()
- Convert all view('legacy.x') and @include('legacy.x') calls to legacy::x
- Migrate legacy views to resources/views/_legacy/ with namespace support
61 lines
2.2 KiB
PHP
61 lines
2.2 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Legacy;
|
|
|
|
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';
|
|
}
|
|
|
|
// Aggregate artwork_stats grouped by artwork.user_id, filtering only public+approved+published artworks
|
|
$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');
|
|
|
|
// Join with users to fetch profile info
|
|
$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();
|
|
|
|
// Map to legacy view shape
|
|
$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('legacy::top-authors', compact('page_title', 'authors', 'metric'));
|
|
}
|
|
}
|