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
67 lines
2.2 KiB
PHP
67 lines
2.2 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Legacy;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Services\ThumbnailPresenter;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\DB;
|
|
use Illuminate\View\View;
|
|
|
|
class StatisticsController extends Controller
|
|
{
|
|
public function index(Request $request): View
|
|
{
|
|
$userId = $request->user()->id;
|
|
|
|
$sort = (string) $request->query('sort', 'date');
|
|
$allowed = ['date', 'name', 'dls', 'category', 'comments'];
|
|
if (! in_array($sort, $allowed, true)) {
|
|
$sort = 'date';
|
|
}
|
|
|
|
$categorySub = DB::table('artwork_category as ac')
|
|
->join('categories as c', 'ac.category_id', '=', 'c.id')
|
|
->select('ac.artwork_id', DB::raw('MIN(c.name) as category_name'))
|
|
->groupBy('ac.artwork_id');
|
|
|
|
$query = DB::table('artworks as a')
|
|
->leftJoinSub($categorySub, 'cat', function ($join) {
|
|
$join->on('a.id', '=', 'cat.artwork_id');
|
|
})
|
|
->where('a.user_id', $userId)
|
|
->select([
|
|
'a.*',
|
|
DB::raw('cat.category_name as category_name'),
|
|
])
|
|
->selectRaw('(SELECT COUNT(*) FROM artwork_comments WHERE artwork_id = a.id) AS num_comments');
|
|
|
|
if ($sort === 'name') {
|
|
$query->orderBy('a.name', 'asc');
|
|
} elseif ($sort === 'dls') {
|
|
$query->orderByDesc('a.dls');
|
|
} elseif ($sort === 'category') {
|
|
$query->orderBy('cat.category_name', 'asc');
|
|
} elseif ($sort === 'comments') {
|
|
$query->orderByDesc('num_comments');
|
|
} else {
|
|
$query->orderByDesc('a.published_at')->orderByDesc('a.id');
|
|
}
|
|
|
|
$artworks = $query->paginate(20)->appends(['sort' => $sort]);
|
|
|
|
$artworks->getCollection()->transform(function ($row) {
|
|
$thumb = ThumbnailPresenter::present($row, 'sm');
|
|
$row->thumb_url = $thumb['url'] ?? '';
|
|
$row->thumb_srcset = $thumb['srcset'] ?? null;
|
|
return $row;
|
|
});
|
|
|
|
return view('legacy::statistics', [
|
|
'artworks' => $artworks,
|
|
'sort' => $sort,
|
|
'page_title' => 'Artwork Statistics',
|
|
]);
|
|
}
|
|
}
|