first commit
Some checks failed
Build / run (push) Has been cancelled

This commit is contained in:
maher
2025-10-29 11:42:25 +01:00
commit 703f50a09d
4595 changed files with 385164 additions and 0 deletions

View File

@@ -0,0 +1,137 @@
<?php
namespace App\Actions\Plays;
use App\Models\Episode;
use App\Models\Season;
use App\Models\Title;
use App\Models\User;
use Common\Admin\Analytics\Actions\BuildDemoAnalyticsReport;
use Common\Admin\Analytics\Actions\DemoTrend;
use Common\Database\Metrics\MetricDateRange;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Support\Str;
class GenerateFakePlaysData
{
public function playsTrend(Builder $builder, MetricDateRange $range): array
{
return (new DemoTrend($builder, dateRange: $range))->count();
}
public function partitionMetric(string $groupBy): array
{
$method =
'build' .
Str::of($groupBy)
->ucfirst()
->plural()
->toString() .
'Metric';
return (new BuildDemoAnalyticsReport())->$method();
}
public function titles(bool $isSeries = null): array
{
return Title::orderBy('popularity', 'desc')
->when(
!is_null($isSeries),
fn($query) => $query->where('is_series', $isSeries),
)
->where('language', 'en')
->limit(30)
->compact()
->get()
->map(
fn(Title $title) => [
'label' => $title->name,
'value' => random_int(50, 1654),
'percentage' => random_int(1, 100),
'model' => $title,
],
)
->sortByDesc('value')
->values()
->toArray();
}
public function seasons(int $titleId): array
{
return Season::where('title_id', $titleId)
->with(['title' => fn($query) => $query->compact()])
->get()
->map(function (Season $season) {
return [
'label' => $season['name'],
'value' => random_int(50, 1654),
'percentage' => random_int(1, 100),
'model' => $season,
];
})
->sortByDesc('value')
->values()
->toArray();
}
public function episodes(int $titleId): array
{
return Episode::where('title_id', $titleId)
->with(['title' => fn($query) => $query->compact()])
->get()
->map(function (Episode $episode) {
return [
'label' => $episode['name'],
'value' => random_int(50, 1654),
'percentage' => random_int(1, 100),
'model' => $episode,
];
})
->sortByDesc('value')
->values()
->toArray();
}
public function videos(): array
{
return Title::orderBy('popularity', 'desc')
->where('language', 'en')
->limit(30)
->compact()
->with('videos')
->get()
->filter(fn(Title $title) => $title->videos->isNotEmpty())
->map(function (Title $title) {
$video = $title->videos->random()->toArray();
$title->unsetRelation('videos');
$video['title'] = $title->toArray();
return [
'label' => $video['name'],
'value' => random_int(50, 1654),
'percentage' => random_int(1, 100),
'model' => $video,
];
})
->sortByDesc('value')
->values()
->toArray();
}
public function users(): array
{
return User::inRandomOrder()
->limit(30)
->compact()
->get()
->map(
fn(User $user) => [
'label' => $user->display_name,
'value' => random_int(50, 1654),
'percentage' => random_int(1, 100),
'model' => $user,
],
)
->sortByDesc('value')
->values()
->toArray();
}
}