79 lines
3.1 KiB
PHP
79 lines
3.1 KiB
PHP
<?php include("core.php"); ?>
|
|
|
|
<!DOCTYPE html>
|
|
<html>
|
|
|
|
<head>
|
|
<title>Carte OpenStreetMap</title>
|
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/leaflet/1.7.1/leaflet.css" />
|
|
<link rel="stylesheet" href="style.css" />
|
|
</head>
|
|
|
|
<body>
|
|
<div class="header">
|
|
<h1>GÉOLOCALISATION DES BROCANTES RÉFÉRENCÉES</h1>
|
|
<p>SUR LE SITE <a href="https://www.sabradou.com/" target="_blank">SABRADOU.COM</a></p>
|
|
</div>
|
|
<div class="container">
|
|
<div class="left-column">
|
|
<form class="form" action="#" method="GET">
|
|
<label for="calendrier-list">Sélectionnez une date :</label>
|
|
<select name="calendrier" id="calendrier-list">
|
|
<?php $calendrier = getCalendrier(); ?>
|
|
<?php foreach ($calendrier as $item): ?>
|
|
<option value="<?php echo $item['url']; ?>"><?php echo $item['node']; ?></option>
|
|
<?php endforeach; ?>
|
|
</select>
|
|
<input type="submit" value="Localiser">
|
|
</form>
|
|
<div class="cities-list">
|
|
<ul>
|
|
<?php $citiesList = getCities('https://www.sabradou.com/index.php'); ?>
|
|
<?php foreach ($citiesList as $city): ?>
|
|
<li>
|
|
<?php echo $city['name']; ?>
|
|
</li>
|
|
<?php endforeach; ?>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
<div class="right-column">
|
|
<?php
|
|
if (isset($_GET['calendrier'])) {
|
|
$jour = $_GET['calendrier'];
|
|
$citiesList = getCities($jour);
|
|
$citiesGeoCode = geocode($citiesList);
|
|
$calendrier = getCalendrier();
|
|
foreach ($calendrier as $item) {
|
|
if ($item['url'] === $jour) {
|
|
echo '<div class="header"><h1>Brocantes du ' . $item['node'] . '</h1></div>';
|
|
break;
|
|
}
|
|
}
|
|
?>
|
|
<div id="map"></div>
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/leaflet/1.7.1/leaflet.js"></script>
|
|
<script>
|
|
// Tableau des villes et des coordonnées
|
|
var cities = <?php echo json_encode($citiesGeoCode); ?>;
|
|
|
|
// Créer la carte
|
|
var map = L.map('map').setView([50.5095, 2.6683], 9);
|
|
|
|
// Ajouter une couche de tuiles OpenStreetMap à la carte
|
|
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
|
|
attribution: 'Carte OpenStreetMap'
|
|
}).addTo(map);
|
|
|
|
// Placer des marqueurs pour chaque ville sur la carte
|
|
cities.forEach(function (city) {
|
|
var marker = L.marker([city.lat, city.lon]).addTo(map);
|
|
marker.bindPopup('<a href="' + city.href + '" target="_blank">' + city.name + '</a>');
|
|
});
|
|
</script>
|
|
<?php } ?>
|
|
</div>
|
|
</div>
|
|
</body>
|
|
|
|
</html>
|