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:
@@ -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);
|
||||
}
|
||||
}
|
||||
@@ -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];
|
||||
|
||||
Reference in New Issue
Block a user