velov/index.php

92 lines
3.0 KiB
PHP
Raw Normal View History

2018-03-26 14:09:04 +00:00
<?php
2018-03-27 07:05:47 +00:00
/*
* Page displays in french because it will be mostly used by french. Feel free to add language system.
* TODO Cache the humongous API data
2018-03-27 07:36:12 +00:00
* TODO Sort the stations
2018-03-27 07:05:47 +00:00
*/
2018-03-27 07:36:12 +00:00
/* Form submit values if a filter is active or not */
2018-03-27 07:25:36 +00:00
$SEND_BUTTON = [
true => [ 'value' => '', 'text' => 'Tout afficher'],
false => [ 'value' => 'true', 'text' => 'Afficher la sélection'],
];
2018-03-27 07:05:47 +00:00
/* Fetching velov API in an associative array. This form is easier to use as keys are ids */
2018-03-26 14:09:04 +00:00
$data =
2018-03-27 07:05:47 +00:00
json_decode(
file_get_contents(
'https://velov.grandlyon.com/fr/les-stations.html?type=777&tx_glstationsvelov_pi1%5Baction%5D=listOfVelovWidthInfoStation&tx_glstationsvelov_pi1%5Bcontroller%5D=StationVelov',
false,
stream_context_create([
'http' => [
'header' => "Content-type: application/x-www-form-urlencoded\r\n",
'method' => 'POST',
'content' => http_build_query([])
]
])
),
true
);
/* Check if a filter is enabled */
2018-03-27 06:46:52 +00:00
if(isset($_GET['filter'])){
if(htmlentities($_GET['filter']))
$filter = true;
else
2018-03-27 07:36:12 +00:00
$filter = false;
2018-03-27 06:46:52 +00:00
}else
$filter = false;
2018-03-26 14:09:04 +00:00
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
2018-03-27 07:25:36 +00:00
<link rel="stylesheet" type="text/css" href="style.css">
2018-03-26 14:09:04 +00:00
<title>Because velov map is too heavy</title>
</head>
<body>
2018-03-27 06:46:52 +00:00
<form action="" method="get">
2018-03-27 07:25:36 +00:00
<input type="hidden" name="filter" value="<?php echo $SEND_BUTTON[$filter]['value']; ?>" />
<input type="submit" value="<?php echo $SEND_BUTTON[$filter]['text']; ?>" />
2018-03-27 06:46:52 +00:00
<table>
2018-03-27 07:25:36 +00:00
<tr><th>Sélectionner</th><th>Nom</th><th>Vélos</th><th>Places Libres</th></tr>
2018-03-27 06:46:52 +00:00
<?php
2018-03-27 06:51:11 +00:00
foreach ($data as $key => $station){
if ( ! $filter || isset($_GET[$key])){
2018-03-27 07:25:36 +00:00
echo '<tr>
<td>
<input type="checkbox" name="',$key,'" ',(isset($_GET[$key]) ? 'checked="checked"' : ''),' />
</td>
<td class="', ($station['open'] == 1 && $station['obsolete'] == 0 ? 'success' : 'danger' ) ,'" >'
2018-03-27 06:46:52 +00:00
,$station['name'],
'</td>
<td>',$station['AB'], '</td>
<td>', $station['ABS'], '</td>
</tr>';
}
2018-03-27 06:51:11 +00:00
}
2018-03-27 06:46:52 +00:00
?>
</table>
2018-03-27 07:25:36 +00:00
<input type="submit" value="<?php echo $SEND_BUTTON[$filter]['text']; ?>" />
2018-03-27 06:46:52 +00:00
</form>
2018-03-27 07:05:47 +00:00
<p>
<h4>À quoi ça sert ?</h4>
À garder ses stations habituelles (et leurs voisines) dans un favoris de navigateur ! Plus besoin de se ballader sur une carte tous les jours ! Cet outil est également accessible sur tous les téléphones peu performants, contrairement au site officiel.
</p>
<p>
<h4>Pourquoi cette page est elle lente ?</h4>
2018-03-28 06:44:44 +00:00
Parce quil faut télécharger toutes les données relatives aux stations vélov à chaque chargement ! Nhésitez pas à améliorer cette page sur <a href="http://github.com/adrian-amaglio/velov">Github</a>
2018-03-27 07:05:47 +00:00
</p>
2018-03-27 07:25:36 +00:00
<p>
<h4>Pourquoi ces couleurs ?</h4>
Le <span class="success">vert</span> est réservé aux stations actives, le <span class="danger">rouge</span> est pour celles inutilisables.
</p>
2018-03-27 07:36:12 +00:00
<p>
<h4>Cest tout dans le désordre !</h4>
Oui.
</p>
2018-03-26 14:09:04 +00:00
</body>
</html>