opnform-host-nginx/api/app/Http/Controllers/Forms/FormStatsController.php

62 lines
2.3 KiB
PHP
Raw Normal View History

2022-09-20 21:59:52 +02:00
<?php
namespace App\Http\Controllers\Forms;
use App\Http\Controllers\Controller;
use App\Http\Requests\FormStatsRequest;
2022-09-20 21:59:52 +02:00
use Carbon\CarbonPeriod;
use Carbon\CarbonInterval;
use Illuminate\Http\Request;
2022-09-20 21:59:52 +02:00
class FormStatsController extends Controller
{
public function __construct()
{
$this->middleware('auth');
}
public function getFormStats(FormStatsRequest $request)
2022-09-20 21:59:52 +02:00
{
$form = $request->form; // Added by ProForm middleware
2022-09-20 21:59:52 +02:00
$this->authorize('view', $form);
$formStats = $form->statistics()->whereBetween('date', [$request->date_from, $request->date_to])->get();
2024-02-23 11:54:12 +01:00
$periodStats = ['views' => [], 'submissions' => []];
foreach (CarbonPeriod::create($request->date_from, $request->date_to) as $dateObj) {
2022-09-20 21:59:52 +02:00
$date = $dateObj->format('d-m-Y');
$statisticData = $formStats->where('date', $dateObj->format('Y-m-d'))->first();
2024-02-23 11:54:12 +01:00
$periodStats['views'][$date] = $statisticData->data['views'] ?? 0;
$periodStats['submissions'][$date] = $form->submissions()->whereDate('created_at', $dateObj)->count();
2022-09-20 21:59:52 +02:00
2024-02-23 11:54:12 +01:00
if ($dateObj->toDateString() === now()->toDateString()) {
$periodStats['views'][$date] += $form->views()->count();
2022-09-20 21:59:52 +02:00
}
}
2024-02-23 11:54:12 +01:00
2022-09-20 21:59:52 +02:00
return $periodStats;
}
public function getFormStatsDetails(Request $request)
{
$form = $request->form; // Added by ProForm middleware
$this->authorize('view', $form);
2024-09-30 15:13:40 +02:00
$totalViews = $form->views_count;
$totalSubmissions = $form->submissions_count;
$averageDuration = \Cache::remember('form_stats_average_duration_' . $form->id, 1800, function () use ($form) {
$submissionsWithDuration = $form->submissions()->whereNotNull('completion_time')->count() ?? 0;
$totalDuration = $form->submissions()->whereNotNull('completion_time')->sum('completion_time') ?? 0;
return $submissionsWithDuration > 0 ? round($totalDuration / $submissionsWithDuration) : null;
});
return [
'views' => $totalViews,
'submissions' => $totalSubmissions,
'completion_rate' => $totalViews > 0 ? round(($totalSubmissions / $totalViews) * 100, 2) : 0,
2024-09-30 15:13:40 +02:00
'average_duration' => $averageDuration ? CarbonInterval::seconds($averageDuration)->cascade()->forHumans(null, true) : null
];
}
2022-09-20 21:59:52 +02:00
}