2015-03-20 09:46:24 +01:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<html>
|
|
|
|
<head>
|
2015-03-22 00:08:26 +01:00
|
|
|
<meta charset="utf-8">
|
|
|
|
<meta name="viewport" content="width=device-width, user-scalable=no">
|
2015-03-20 09:46:24 +01:00
|
|
|
<title>Neue und verschwundene Knoten</title>
|
|
|
|
<style type="text/css">
|
|
|
|
body {
|
|
|
|
margin: 0;
|
|
|
|
padding: 0;
|
|
|
|
font-family: 'Roboto Slab', serif;
|
|
|
|
font-size: 11pt;
|
|
|
|
}
|
|
|
|
|
2015-03-21 16:32:17 +01:00
|
|
|
#nodeinfo {
|
|
|
|
position: relative;
|
|
|
|
box-shadow: 0px 0.5px 3px rgba(0, 0, 0, 0.16), 0px 0.5px 2px rgba(0, 0, 0, 0.24);
|
|
|
|
background: rgba(0, 0, 0, 0.02);
|
|
|
|
padding-top: 0.25em;
|
|
|
|
}
|
|
|
|
|
|
|
|
#nodeinfo.hidden {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
button {
|
2015-03-21 19:14:06 +01:00
|
|
|
-webkit-tap-highlight-color: transparent;
|
2015-03-21 16:32:17 +01:00
|
|
|
font-family: "ionicons";
|
2015-03-21 18:05:45 +01:00
|
|
|
box-shadow: 0px 0.5px 3px rgba(0, 0, 0, 0.16), 0px 0.5px 2px rgba(0, 0, 0, 0.24);
|
2015-03-21 16:32:17 +01:00
|
|
|
border-radius: 0.9em;
|
|
|
|
background: rgba(255, 255, 255, 0.7);
|
|
|
|
border: none;
|
|
|
|
cursor: pointer;
|
|
|
|
height: 1.8em;
|
|
|
|
width: 1.8em;
|
|
|
|
font-size: 20pt;
|
2015-03-21 18:05:45 +01:00
|
|
|
transition: box-shadow 0.5s, color 0.5s;
|
|
|
|
outline: none;
|
2015-03-21 16:32:17 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
button:hover {
|
2015-03-21 18:05:45 +01:00
|
|
|
background: white;
|
2015-03-21 16:32:17 +01:00
|
|
|
color: #dc0067;
|
2015-03-21 18:05:45 +01:00
|
|
|
box-shadow: 0px 5px 20px rgba(0, 0, 0, 0.19), 0px 3px 6px rgba(0, 0, 0, 0.23);
|
|
|
|
}
|
|
|
|
|
|
|
|
button:active {
|
|
|
|
box-shadow: inset 0px 5px 20px rgba(0, 0, 0, 0.19), inset 0px 3px 6px rgba(0, 0, 0, 0.23);
|
2015-03-21 16:32:17 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
button.close {
|
|
|
|
position: absolute;
|
|
|
|
right: 0.7em;
|
|
|
|
top: 0.7em;
|
|
|
|
}
|
|
|
|
|
|
|
|
button.close:after {
|
|
|
|
content: "\f12a";
|
|
|
|
}
|
|
|
|
|
|
|
|
#sidebar h2 {
|
|
|
|
padding: 0 10pt;
|
|
|
|
}
|
|
|
|
|
|
|
|
#sidebar p, #sidebar table, #sidebar pre {
|
|
|
|
padding: 0 10pt 1em;
|
|
|
|
}
|
|
|
|
|
2015-03-20 13:30:28 +01:00
|
|
|
#sidebarhandle {
|
|
|
|
position: absolute;
|
2015-03-21 16:15:02 +01:00
|
|
|
right: -2.5em;
|
2015-03-20 23:18:14 +01:00
|
|
|
top: 0.7em;
|
2015-03-20 13:30:28 +01:00
|
|
|
z-index: 10;
|
2015-03-21 18:05:45 +01:00
|
|
|
transition: right 0.5s, box-shadow 0.5s, color 0.5s, transform 0.5s;
|
2015-03-20 17:42:43 +01:00
|
|
|
}
|
|
|
|
|
2015-03-21 18:05:45 +01:00
|
|
|
#sidebarhandle:after {
|
2015-03-21 16:15:02 +01:00
|
|
|
padding-right: 0.125em;
|
|
|
|
content: "\f124";
|
2015-03-20 17:42:43 +01:00
|
|
|
}
|
|
|
|
|
2015-03-21 18:05:45 +01:00
|
|
|
#sidebar.hidden #sidebarhandle {
|
|
|
|
transform: scale(-1, 1);
|
2015-03-20 13:30:28 +01:00
|
|
|
}
|
|
|
|
|
2015-03-20 09:46:24 +01:00
|
|
|
.hostname {
|
|
|
|
}
|
|
|
|
|
|
|
|
.hostname.online {
|
2015-03-20 22:55:23 +01:00
|
|
|
color: #558020 !important;
|
2015-03-20 09:46:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
.hostname.offline {
|
2015-03-20 22:55:23 +01:00
|
|
|
color: #D43E2A !important;
|
2015-03-20 09:46:24 +01:00
|
|
|
}
|
|
|
|
|
2015-03-20 13:30:28 +01:00
|
|
|
#sidebar {
|
2015-03-20 17:42:43 +01:00
|
|
|
z-index: 5;
|
|
|
|
width: 50em;
|
2015-03-20 13:30:28 +01:00
|
|
|
box-sizing: border-box;
|
2015-03-21 19:08:51 +01:00
|
|
|
position: absolute;
|
|
|
|
top: 0;
|
|
|
|
left: 0;
|
|
|
|
background: white;
|
2015-03-20 17:42:43 +01:00
|
|
|
box-shadow: 0px 5px 20px rgba(0, 0, 0, 0.19), 0px 3px 6px rgba(0, 0, 0, 0.23);
|
2015-03-21 19:08:51 +01:00
|
|
|
transition: left 0.5s;
|
2015-03-20 13:30:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#sidebar.hidden {
|
2015-03-21 19:08:51 +01:00
|
|
|
left: -50em;
|
2015-03-20 13:30:28 +01:00
|
|
|
}
|
|
|
|
|
2015-03-21 09:48:25 +01:00
|
|
|
#sidebardata {
|
2015-03-20 09:46:24 +01:00
|
|
|
overflow: auto;
|
|
|
|
box-sizing: border-box;
|
|
|
|
}
|
|
|
|
|
2015-03-21 09:48:25 +01:00
|
|
|
#sidebardata .icon {
|
2015-03-20 20:36:49 +01:00
|
|
|
padding: 0 0.25em;
|
|
|
|
}
|
|
|
|
|
2015-03-21 09:48:25 +01:00
|
|
|
#sidebardata, #map {
|
2015-03-20 09:46:24 +01:00
|
|
|
height: 100vh;
|
|
|
|
}
|
|
|
|
|
2015-03-21 09:48:25 +01:00
|
|
|
#sidebardata table {
|
2015-03-20 09:46:24 +01:00
|
|
|
width: 100%;
|
|
|
|
}
|
|
|
|
|
2015-03-21 09:48:25 +01:00
|
|
|
#sidebardata td:not(:first-child) {
|
2015-03-20 09:46:24 +01:00
|
|
|
text-align: right;
|
|
|
|
}
|
|
|
|
|
2015-03-21 09:48:25 +01:00
|
|
|
#sidebardata a {
|
2015-03-20 22:55:23 +01:00
|
|
|
color: #1566A9;
|
|
|
|
}
|
|
|
|
|
2015-03-20 09:46:24 +01:00
|
|
|
@media screen and (max-width: 80em) {
|
2015-03-20 13:30:28 +01:00
|
|
|
#sidebar {
|
2015-03-20 09:46:24 +01:00
|
|
|
font-size: 0.8em;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@media screen and (max-width: 60em) {
|
2015-03-21 09:48:25 +01:00
|
|
|
#sidebardata {
|
2015-03-20 13:30:28 +01:00
|
|
|
overflow: visible;
|
2015-03-20 17:42:43 +01:00
|
|
|
height: auto;
|
2015-03-20 13:30:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#sidebarhandle {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
|
2015-03-20 09:46:24 +01:00
|
|
|
#map {
|
|
|
|
height: 60vh;
|
|
|
|
}
|
|
|
|
|
2015-03-20 13:30:28 +01:00
|
|
|
#sidebar {
|
2015-03-21 19:08:51 +01:00
|
|
|
position: static;
|
2015-03-20 17:42:43 +01:00
|
|
|
margin-left: 0em !important;
|
|
|
|
width: auto;
|
2015-03-20 09:46:24 +01:00
|
|
|
height: auto;
|
|
|
|
}
|
2015-03-20 13:30:28 +01:00
|
|
|
|
|
|
|
#sidebar.hidden {
|
|
|
|
width: auto;
|
|
|
|
}
|
|
|
|
|
2015-03-21 09:48:25 +01:00
|
|
|
#sidebar.hidden #sidebardata {
|
2015-03-20 13:30:28 +01:00
|
|
|
display: block;
|
|
|
|
}
|
2015-03-20 09:46:24 +01:00
|
|
|
}
|
|
|
|
</style>
|
2015-03-20 15:03:15 +01:00
|
|
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/leaflet/0.7.3/leaflet.css">
|
2015-03-22 00:58:19 +01:00
|
|
|
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto+Slab:700,400">
|
2015-03-20 15:03:15 +01:00
|
|
|
<link rel="stylesheet" href="https://code.ionicframework.com/ionicons/1.5.2/css/ionicons.min.css">
|
|
|
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/Leaflet.awesome-markers/2.0.2/leaflet.awesome-markers.css">
|
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/chroma-js/0.6.3/chroma.min.js"></script>
|
2015-03-21 20:10:46 +01:00
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.9.0/moment-with-locales.min.js"></script>
|
2015-03-20 15:03:15 +01:00
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/leaflet/0.7.3/leaflet.js"></script>
|
2015-03-20 14:01:25 +01:00
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/Leaflet.awesome-markers/2.0.2/leaflet.awesome-markers.min.js"></script>
|
2015-03-20 09:46:24 +01:00
|
|
|
<script src="history.js"></script>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<div id="container">
|
|
|
|
<div id="map">
|
|
|
|
</div>
|
2015-03-20 13:30:28 +01:00
|
|
|
<div id="sidebar">
|
2015-03-21 18:05:45 +01:00
|
|
|
<button id="sidebarhandle">
|
|
|
|
</button>
|
|
|
|
|
2015-03-21 09:48:25 +01:00
|
|
|
<div id="sidebardata">
|
2015-03-21 16:32:17 +01:00
|
|
|
<div id="nodeinfo" class="hidden">
|
|
|
|
</div>
|
|
|
|
|
2015-03-20 13:30:28 +01:00
|
|
|
<p>
|
|
|
|
Zeigt Knoten an, die in den letzten 14 Tagen dazu gekommen oder verschwunden sind.
|
|
|
|
Funktioniert nur in wirklich modernen Browsern.
|
|
|
|
</p>
|
|
|
|
|
2015-03-21 10:40:58 +01:00
|
|
|
<h2>Meshdaten</h2>
|
|
|
|
<p id="meshstats">
|
|
|
|
</p>
|
|
|
|
|
2015-03-20 13:30:28 +01:00
|
|
|
<h2>Neue Knoten</h2>
|
|
|
|
<table>
|
|
|
|
<tbody id="newnodes">
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
|
|
|
|
<h2>Verschwundene Knoten</h2>
|
|
|
|
<table>
|
|
|
|
<tbody id="lostnodes">
|
|
|
|
</tbody>
|
|
|
|
</table>
|
2015-03-20 20:08:28 +01:00
|
|
|
|
|
|
|
<h2>Längste Verbindungen</h2>
|
|
|
|
<table>
|
|
|
|
<tbody id="longlinks">
|
|
|
|
</tbody>
|
|
|
|
</table>
|
2015-03-20 13:30:28 +01:00
|
|
|
</div>
|
2015-03-20 09:46:24 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</body>
|
|
|
|
</html>
|