Pk11 3 years ago committed by GitHub
parent 1eced72a8a
commit f497eb1b0d

@ -26,7 +26,7 @@
<meta charset="utf-8"> <meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1"> <meta name="viewport" content="width=device-width, initial-scale=1">
<title>NexTrip停留所の情報</title> <title>停留所のNexTrip情報</title>
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-1BmE4kWBq78iYhFldvKuhfTAU6auU8tT94WrHftjDbrCEXSU1oBoqyl2QvZ6jIW3" crossorigin="anonymous"> <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-1BmE4kWBq78iYhFldvKuhfTAU6auU8tT94WrHftjDbrCEXSU1oBoqyl2QvZ6jIW3" crossorigin="anonymous">
</head> </head>
@ -40,7 +40,7 @@
<header> <header>
<nav class="navbar navbar-light bg-light"> <nav class="navbar navbar-light bg-light">
<div class="container-fluid"> <div class="container-fluid">
<a class="navbar-brand" href="https://nextrip.xn--rdk.xn--tckwe/">NexTrip停留所の情報</a> <a class="navbar-brand" href="https://nextrip.xn--rdk.xn--tckwe/">停留所のNexTrip情報</a>
<ul class="navbar-nav"> <ul class="navbar-nav">
<li class="nav-item"> <li class="nav-item">
<a class="nav-link" href="https://gist.github.com/Epicpkmn11/6e60adbf3475277b753b259ab02a53cd" target="_blank">ソース</a> <a class="nav-link" href="https://gist.github.com/Epicpkmn11/6e60adbf3475277b753b259ab02a53cd" target="_blank">ソース</a>
@ -51,21 +51,7 @@
</header> </header>
<main class="mt-3"> <main class="mt-3">
<div class="container-fluid"> <div class="container-fluid" style="max-width: 768px">
<div class="row">
<div class="col-12">
<form>
<div class="input-group mb-3">
<label for="stop" class="input-group-text">停留所</label>
<input type="text" id="stop" name="stop" class="form-control" placeholder="12345" value="<?php echo $stop; ?>">
<input type="submit" class="btn btn-outline-secondary">
</div>
</form>
</div>
</div>
<div class="row">
<div class="col-12">
<?php <?php
if(isset($stop)) { if(isset($stop)) {
if(preg_match("/[^\\d]/", $stop)) { if(preg_match("/[^\\d]/", $stop)) {
@ -81,11 +67,11 @@
$content = file_get_contents("https://svc.metrotransit.org/NexTrip/$stop?format=json"); $content = file_get_contents("https://svc.metrotransit.org/NexTrip/$stop?format=json");
$json = json_decode($content); $json = json_decode($content);
if(!$json) { if(!isset($json)) {
echo "<h3 class=\"alert alert-danger\">{$stop}は無効な停留所です。</h3>"; echo "<h3 class=\"alert alert-danger\">{$stop}は無効な停留所です。</h3>";
} else { } else {
echo "<h3 class=\"border-bottom\">停留所{$stop}のNexTrip情報</h3>"; echo "<h3 class=\"border-bottom\">停留所{$stop}のNexTrip情報</h3>";
echo '<div class="row row-cols-2 row-cols-md-4 row-cols-lg-6">'; echo '<div class="row row-cols-2 row-cols-sm-4 row-cols-md-6">';
foreach($json as $bus) { foreach($json as $bus) {
echo '<div class="col">'; echo '<div class="col">';
echo "<p><span class=\"fw-bold\">$bus->Route{$bus->Terminal}{$directions[$bus->RouteDirection]}</span><br>"; echo "<p><span class=\"fw-bold\">$bus->Route{$bus->Terminal}{$directions[$bus->RouteDirection]}</span><br>";
@ -96,8 +82,6 @@
$favDesc = json_decode($_COOKIE['favorites'], true)[$stop]; $favDesc = json_decode($_COOKIE['favorites'], true)[$stop];
echo '<div class="row">';
echo '<div class="col-12">';
echo '<form>'; echo '<form>';
echo "<input type=\"hidden\" name=\"fav-set\" value=\"$stop\">"; echo "<input type=\"hidden\" name=\"fav-set\" value=\"$stop\">";
echo '<div class="input-group mb-3">'; echo '<div class="input-group mb-3">';
@ -109,11 +93,21 @@
echo '<input type="submit" class="btn btn-outline-secondary" value="追加">'; echo '<input type="submit" class="btn btn-outline-secondary" value="追加">';
echo '</div>'; echo '</div>';
echo '</form>'; echo '</form>';
echo '</div>';
echo '</div>';
} }
} }
} else { } else {
echo '<div class="row">';
echo '<div class="col-12">';
echo '<form>';
echo '<div class="input-group mb-3">';
echo '<label for="stop" class="input-group-text">停留所</label>';
echo '<input type="text" id="stop" name="stop" class="form-control" placeholder="12345">';
echo '<input type="submit" class="btn btn-outline-secondary">';
echo '</div>';
echo '</form>';
echo '</div>';
echo '</div>';
$favorites = isset($_COOKIE['favorites']) ? json_decode($_COOKIE['favorites'], true) : Array(); $favorites = isset($_COOKIE['favorites']) ? json_decode($_COOKIE['favorites'], true) : Array();
if(isset($favSet)) { if(isset($favSet)) {
@ -136,10 +130,10 @@
if(count($favorites) > 0) { if(count($favorites) > 0) {
echo '<h2 class="border-bottom">お気に入り</h2>'; echo '<h2 class="border-bottom">お気に入り</h2>';
echo '<ul>'; echo '<ul class="list-unstyled">';
foreach($favorites as $favStop => $favDesc) { foreach($favorites as $favStop => $favDesc) {
echo '<li class="mb-1">'; echo '<li class="mb-1 d-flex">';
echo "<a class=\"btn btn-sm btn-secondary\" href=\"?stop=$favStop\">$favStop ($favDesc)</a> "; echo "<a class=\"btn btn-sm btn-secondary flex-fill me-1 text-start\" href=\"?stop=$favStop\">$favStop ($favDesc)</a>";
echo "<a class=\"btn btn-sm btn-danger\" href=\"?fav-remove=$favStop\" aria-label=\"Remove\">×</a>"; echo "<a class=\"btn btn-sm btn-danger\" href=\"?fav-remove=$favStop\" aria-label=\"Remove\">×</a>";
echo '</li>'; echo '</li>';
} }
@ -148,8 +142,6 @@
} }
?> ?>
</div> </div>
</div>
</div>
</main> </main>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/js/bootstrap.bundle.min.js" integrity="sha384-ka7Sk0Gln4gmtz2MlQnikT1wXgYsOg+OMhuP+IlRH9sENBO0LRn5q+8nbTov4+1p" crossorigin="anonymous"></script> <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/js/bootstrap.bundle.min.js" integrity="sha384-ka7Sk0Gln4gmtz2MlQnikT1wXgYsOg+OMhuP+IlRH9sENBO0LRn5q+8nbTov4+1p" crossorigin="anonymous"></script>

Loading…
Cancel
Save