up pages rues et évolutions dans le temps
This commit is contained in:
parent
7355600e6b
commit
c8e3cf2ada
10 changed files with 329 additions and 14 deletions
|
@ -2079,6 +2079,7 @@ final class AdminController extends AbstractController
|
|||
]);
|
||||
}
|
||||
|
||||
#[Route('/admin/followup-graph/{insee_code}', name: 'admin_followup_graph', requirements: ['insee_code' => '\d+'])]
|
||||
public function followupGraph(Request $request, string $insee_code): Response
|
||||
{
|
||||
$stats = $this->entityManager->getRepository(Stats::class)->findOneBy(['zone' => $insee_code]);
|
||||
|
@ -2086,17 +2087,15 @@ final class AdminController extends AbstractController
|
|||
$this->addFlash('error', 'Aucune stats trouvée pour ce code INSEE.');
|
||||
return $this->redirectToRoute('app_admin');
|
||||
}
|
||||
|
||||
$themes = \App\Service\FollowUpService::getFollowUpThemes();
|
||||
// On ne vérifie pas ici un thème unique, on boucle sur tous les thèmes plus loin
|
||||
|
||||
// Ici, on ne prépare que les variables globales pour le template
|
||||
return $this->render('admin/followup_graph.html.twig', [
|
||||
'stats' => $stats,
|
||||
'completion_tags' => \App\Service\FollowUpService::getFollowUpCompletionTags(),
|
||||
'followup_labels' => \App\Service\FollowUpService::getFollowUpThemes(),
|
||||
'followup_icons' => \App\Service\FollowUpService::getFollowUpIcons(),
|
||||
// ... autres variables nécessaires ...
|
||||
|
||||
]);
|
||||
}
|
||||
|
||||
|
@ -2111,4 +2110,41 @@ final class AdminController extends AbstractController
|
|||
// Pour éviter l'erreur, on retourne une redirection par défaut si rien n'est fait
|
||||
return $this->redirectToRoute('admin_dashboard');
|
||||
}
|
||||
|
||||
#[Route('/admin/stats/{insee_code}/street-completion', name: 'admin_street_completion', requirements: ['insee_code' => '\d+'])]
|
||||
public function streetCompletion(string $insee_code): Response
|
||||
{
|
||||
$stats = $this->entityManager->getRepository(Stats::class)->findOneBy(['zone' => $insee_code]);
|
||||
if (!$stats) {
|
||||
$this->addFlash('error', 'Aucune stats trouvée pour ce code INSEE.');
|
||||
return $this->redirectToRoute('app_admin');
|
||||
}
|
||||
$places = $stats->getPlaces();
|
||||
$rues = [];
|
||||
foreach ($places as $place) {
|
||||
$rue = $place->getStreet() ?: '(sans nom)';
|
||||
if (!isset($rues[$rue])) {
|
||||
$rues[$rue] = [ 'places' => [], 'completion_sum' => 0 ];
|
||||
}
|
||||
$rues[$rue]['places'][] = $place;
|
||||
$rues[$rue]['completion_sum'] += $place->getCompletionPercentage();
|
||||
}
|
||||
$rues_data = [];
|
||||
foreach ($rues as $nom => $data) {
|
||||
$count = count($data['places']);
|
||||
$avg = $count > 0 ? round($data['completion_sum'] / $count, 1) : 0;
|
||||
$rues_data[] = [
|
||||
'name' => $nom,
|
||||
'count' => $count,
|
||||
'avg_completion' => $avg,
|
||||
];
|
||||
}
|
||||
// Tri décroissant par complétion moyenne
|
||||
usort($rues_data, fn($a, $b) => $b['avg_completion'] <=> $a['avg_completion']);
|
||||
return $this->render('admin/street_completion.html.twig', [
|
||||
'stats' => $stats,
|
||||
'rues' => $rues_data,
|
||||
'insee_code' => $insee_code,
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue