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
40 lines
1.2 KiB
PHP
40 lines
1.2 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Legacy;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\DB;
|
|
|
|
class MonthlyCommentatorsController extends Controller
|
|
{
|
|
public function index(Request $request)
|
|
{
|
|
$hits = 30;
|
|
$page = max(1, (int) $request->query('page', 1));
|
|
|
|
$query = DB::table('artwork_comments as t1')
|
|
->leftJoin('users as t2', 't1.user_id', '=', 't2.user_id')
|
|
->leftJoin('country as c', 't2.country', '=', 'c.id')
|
|
->where('t1.user_id', '>', 0)
|
|
->whereRaw("DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= t1.date")
|
|
->select(
|
|
't2.user_id',
|
|
't2.uname',
|
|
't2.user_type',
|
|
't2.country',
|
|
'c.name as country_name',
|
|
'c.flag as country_flag',
|
|
DB::raw('COUNT(*) as num_comments')
|
|
)
|
|
->groupBy('t1.user_id')
|
|
->orderByDesc('num_comments');
|
|
|
|
$rows = $query->paginate($hits)->withQueryString();
|
|
|
|
$page_title = 'Monthly Top Commentators';
|
|
|
|
return view('legacy::monthly-commentators', compact('page_title', 'rows'));
|
|
}
|
|
}
|