Page carte interactive des relevés (Leaflet + OpenStreetMap)

- CarteController : index() + data() (JSON) — requête lieux géolocalisés
  ayant des sources avec relevés, agrégats par lieu
- Lieu model : relations sources() et releves() (hasManyThrough)
- Vue carte/index.blade.php : carte Leaflet pleine hauteur, marqueurs
  colorés par nombre de sources (taille/couleur proportionnels),
  popup par lieu avec liste des sources, statuts, années et lien recherche
- Tuiles OpenStreetMap inversées en mode sombre
- Route GET /carte + GET /carte/data
- Lien "Carte" dans la navigation desktop et mobile
- @stack('head') dans le layout pour injecter Leaflet uniquement sur la page carte

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-06-04 21:02:28 +02:00
parent 6f55663984
commit a1860e9462
6 changed files with 248 additions and 0 deletions
+56
View File
@@ -0,0 +1,56 @@
<?php
namespace App\Http\Controllers;
use App\Models\Lieu;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Illuminate\View\View;
class CarteController extends Controller
{
public function index(): View
{
return view('carte.index');
}
public function data(Request $request): JsonResponse
{
$lieux = Lieu::whereNotNull('latitude')
->whereNotNull('longitude')
->whereHas('sources.releves')
->with([
'sources' => function ($q) {
$q->withCount('releves')
->select('id', 'nom', 'lieu_id', 'status', 'annee_debut', 'annee_fin')
->orderBy('nom');
},
])
->get()
->map(function (Lieu $lieu) {
$relevesTotal = $lieu->sources->sum('releves_count');
return [
'id' => $lieu->id,
'nom' => $lieu->nom_long ?? $lieu->nom,
'lat' => (float) $lieu->latitude,
'lng' => (float) $lieu->longitude,
'sources_count' => $lieu->sources->count(),
'releves_count' => $relevesTotal,
'sources' => $lieu->sources->map(fn ($s) => [
'id' => $s->id,
'nom' => $s->nom,
'releves_count' => $s->releves_count,
'status' => $s->status->label(),
'status_value' => $s->status->value,
'annees' => $s->annee_debut
? ($s->annee_debut === $s->annee_fin || ! $s->annee_fin
? (string) $s->annee_debut
: "{$s->annee_debut}{$s->annee_fin}")
: null,
]),
];
});
return response()->json($lieux);
}
}
+11
View File
@@ -5,6 +5,7 @@ namespace App\Models;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\Relations\HasMany;
use Illuminate\Database\Eloquent\Relations\HasManyThrough;
class Lieu extends Model
{
@@ -32,6 +33,16 @@ class Lieu extends Model
return $this->hasMany(Section::class);
}
public function sources(): HasMany
{
return $this->hasMany(Source::class);
}
public function releves(): HasManyThrough
{
return $this->hasManyThrough(Releve::class, Source::class);
}
public function calculerNomLong(): string
{
$noms = [$this->nom];