join('artworks as a', 'f.artwork_id', '=', 'a.id') ->where('a.is_approved', true) ->where('a.is_public', true) ->whereNull('a.deleted_at') ->whereRaw('MONTH(f.post_date) = ?', [$today->month]) ->whereRaw('DAY(f.post_date) = ?', [$today->day]) ->select('a.id', 'a.title as name', 'a.slug', 'a.hash', 'a.thumb_ext', DB::raw('f.post_date as featured_date')) ->orderBy('f.post_date', 'desc') ->paginate($perPage); } catch (\Throwable $e) { $artworks = null; } } // ── Strategy 2: new artwork_features table ─────────────────────────────── if (!$artworks || $artworks->total() === 0) { try { $artworks = DB::table('artwork_features as f') ->join('artworks as a', 'f.artwork_id', '=', 'a.id') ->where('f.is_active', true) ->where('a.is_approved', true) ->where('a.is_public', true) ->whereNull('a.deleted_at') ->whereNotNull('a.published_at') ->whereRaw('MONTH(f.featured_at) = ?', [$today->month]) ->whereRaw('DAY(f.featured_at) = ?', [$today->day]) ->select('a.id', 'a.title as name', 'a.slug', 'a.hash', 'a.thumb_ext', DB::raw('f.featured_at as featured_date')) ->orderBy('f.featured_at', 'desc') ->paginate($perPage); } catch (\Throwable $e) { $artworks = null; } } // ── Enrich with CDN thumbnails (batch load to avoid N+1) ───────────────── if ($artworks && method_exists($artworks, 'getCollection') && $artworks->count() > 0) { $ids = $artworks->getCollection()->pluck('id')->filter()->map(fn ($id) => (int) $id)->all(); $modelsById = Artwork::query() ->with([ 'user:id,name,username', 'categories' => function ($query) { $query->select('categories.id', 'categories.name', 'categories.slug', 'categories.sort_order'); }, ]) ->whereIn('id', $ids) ->get() ->keyBy('id'); $artworks->getCollection()->transform(function ($row) use ($modelsById) { /** @var ?Artwork $art */ $art = $modelsById->get($row->id); $row->slug = $row->slug ?? Str::slug($row->name ?? ''); if ($art) { $primaryCategory = $art->categories?->sortBy('sort_order')->first(); $author = $art->user; try { $present = \App\Services\ThumbnailPresenter::present($art, 'md'); $row->thumb_url = $present['url']; $row->thumb_srcset = $present['srcset'] ?? $present['url']; } catch (\Throwable $e) { $row->thumb_url = $art->thumbUrl('md') ?? 'https://files.skinbase.org/default/missing_md.webp'; $row->thumb_srcset = $row->thumb_url; } $row->url = url('/art/' . $art->id . '/' . ($art->slug ?: Str::slug($art->title ?: ($row->name ?? 'artwork')))); $row->art_url = $row->url; $row->name = $art->title ?: ($row->name ?? 'Untitled'); $row->slug = $art->slug ?: $row->slug; $row->width = $art->width; $row->height = $art->height; $row->content_type_name = $primaryCategory?->contentType?->name ?? ''; $row->content_type_slug = $primaryCategory?->contentType?->slug ?? ''; $row->category_name = $primaryCategory->name ?? ''; $row->category_slug = $primaryCategory->slug ?? ''; $row->uname = $author->name ?? 'Skinbase'; $row->username = $author->username ?? $author->name ?? ''; $row->avatar_url = $author ? AvatarUrl::forUser((int) $author->getKey(), null, 64) : AvatarUrl::default(); } else { $row->thumb_url = 'https://files.skinbase.org/default/missing_md.webp'; $row->thumb_srcset = $row->thumb_url; $row->url = url('/art/' . $row->id . '/' . ($row->slug ?: Str::slug($row->name ?? 'artwork'))); $row->art_url = $row->url; $row->name = $row->name ?? 'Untitled'; $row->content_type_name = $row->content_type_name ?? ''; $row->content_type_slug = $row->content_type_slug ?? ''; $row->category_name = $row->category_name ?? ''; $row->category_slug = $row->category_slug ?? ''; $row->uname = $row->uname ?? 'Skinbase'; $row->username = $row->username ?? ''; $row->avatar_url = $row->avatar_url ?? AvatarUrl::default(); $row->width = $row->width ?? null; $row->height = $row->height ?? null; } return $row; }); } return view('legacy::today-in-history', [ 'artworks' => $artworks, 'page_title' => 'Popular on this day in history', 'todayLabel' => $today->format('F j'), ]); } }