toDateString(); $query = ArtworkDownload::with([ 'artwork.user:id,name,username', 'artwork.user.profile:user_id,avatar_hash', 'artwork.categories:id,name,slug', ]) ->whereDate('created_at', $today) ->whereHas('artwork', function ($q) { $q->public()->published()->whereNull('deleted_at'); }) ->selectRaw('artwork_id, COUNT(*) as num_downloads') ->groupBy('artwork_id') ->orderByDesc('num_downloads'); $paginator = $query->paginate($hits)->withQueryString(); $paginator->getCollection()->transform(function ($row) { $art = $row->artwork ?? null; if (! $art && isset($row->artwork_id)) { $art = \App\Models\Artwork::find($row->artwork_id); } if (! $art) { return (object) [ 'id' => null, 'name' => 'Artwork', 'slug' => 'artwork', 'thumb' => 'https://files.skinbase.org/default/missing_md.webp', 'thumb_url' => 'https://files.skinbase.org/default/missing_md.webp', 'thumb_srcset' => 'https://files.skinbase.org/default/missing_md.webp', 'category_name' => '', 'category_slug' => '', 'num_downloads' => $row->num_downloads ?? 0, ]; } $name = $art->title ?? null; $picture = $art->file_name ?? null; $ext = pathinfo($picture ?? '', PATHINFO_EXTENSION) ?: 'jpg'; $encoded = null; $present = $art ? \App\Services\ThumbnailPresenter::present($art, 'md') : null; $thumb = $present ? $present['url'] : 'https://files.skinbase.org/default/missing_md.webp'; $primaryCategory = $art->categories->first(); $categoryId = $primaryCategory->id ?? null; $categoryName = $primaryCategory->name ?? ''; $categorySlug = $primaryCategory->slug ?? ''; $avatarHash = $art->user->profile->avatar_hash ?? null; return (object) [ 'id' => $art->id ?? null, 'name' => $name, 'picture' => $picture, 'slug' => $art->slug ?? Str::slug($name ?? ''), 'ext' => $ext, 'encoded' => $encoded, 'thumb' => $thumb, 'thumb_url' => $thumb, 'thumb_srcset' => $thumb, 'category' => $categoryId, 'category_name' => $categoryName, 'category_slug' => $categorySlug, 'uname' => $art->user->name ?? 'Skinbase', 'username' => $art->user->username ?? '', 'avatar_url' => \App\Support\AvatarUrl::forUser((int) ($art->user->id ?? 0), $avatarHash, 64), 'width' => $art->width, 'height' => $art->height, 'published_at' => $art->published_at, 'num_downloads' => $row->num_downloads ?? 0, 'gid_num' => $categoryId ? ((int) $categoryId % 5) * 5 : 0, ]; }); $page_title = 'Today Downloaded Artworks'; return view('web.downloads.today', ['page_title' => $page_title, 'artworks' => $paginator]); } }