250 lines
10 KiB
HTML
250 lines
10 KiB
HTML
<!DOCTYPE HTML>
|
|
<html>
|
|
<head>
|
|
<meta charset="utf-8"/>
|
|
<link rel="stylesheet" type="text/css" href="style.css" />
|
|
<link rel="stylesheet" href="jquery/jquery-ui-1.11.4-smoothness.css" />
|
|
<script src="jquery/jquery-3.0.0.min.js"></script>
|
|
<script src="jquery/jquery-ui-1.11.4.min.js"></script>
|
|
<script src="jquery/plugins/jquery.validate.min.js"></script>
|
|
|
|
<link rel="stylesheet" href="ol3/ol-3.17.1.css" type="text/css" />
|
|
<script src="ol3/ol-3.17.1.js" type="text/javascript"></script>
|
|
|
|
<link rel="stylesheet" href="ol3/ol3-layerswitcher.css" type="text/css"/>
|
|
<script src="ol3/ol3-layerswitcher.js" type="text/javascript"></script>
|
|
|
|
<script type="text/javascript" src="config.js"></script>
|
|
<script type="text/javascript" src="markers.js"></script>
|
|
<script type="text/javascript" src="dbloader.js"></script>
|
|
<script type="text/javascript" src="registrations.js"></script>
|
|
<script type="text/javascript" src="planeObject.js"></script>
|
|
<script type="text/javascript" src="formatter.js"></script>
|
|
<script type="text/javascript" src="flags.js"></script>
|
|
<script type="text/javascript" src="layers.js"></script>
|
|
<script type="text/javascript" src="script.js"></script>
|
|
<title>FlightAware dump1090</title>
|
|
</head>
|
|
|
|
<body onload="initialize()">
|
|
<div id="loader" class="hidden">
|
|
<img src="spinny.gif" id="spinny" alt="Loading...">
|
|
<progress id="loader_progress"></progress>
|
|
</div>
|
|
|
|
<!--
|
|
This is hideous. airframes.org insists on getting a POST with a "submit" value specified,
|
|
but if we have an input control with that name then it shadows the submit() function that
|
|
we need. So steal the submit function off a different form. Surely there is a better way?!
|
|
-->
|
|
<form id="horrible_hack" class="hidden">
|
|
</form>
|
|
<form id="airframes_post" method="POST" action="http://www.airframes.org/" target="_blank" class="hidden">
|
|
<input type="hidden" name="reg1" value="">
|
|
<input type="hidden" name="selcal" value="">
|
|
<input id="airframes_post_icao" type="hidden" name="ica024" value="">
|
|
<input type="hidden" name="submit" value="submit">
|
|
</form>
|
|
|
|
<div id="layout_container">
|
|
<div id="selected_infoblock" class="hidden">
|
|
<table style="width: 100%">
|
|
<tr class="infoblock_heading">
|
|
<td colspan="2">
|
|
<b>
|
|
<span id="selected_callsign" onclick="toggleFollowSelected();" class="pointer">n/a</span>
|
|
</b>
|
|
<span id="selected_follow" onclick="toggleFollowSelected();" class="pointer">⇒</span>
|
|
|
|
<span id="selected_flag">
|
|
<img style="width: 20px; height=12px" src="about:blank" alt="Flag">
|
|
</span>
|
|
|
|
<a href="http://www.airframes.org/" onclick="document.getElementById('horrible_hack').submit.call(document.getElementById('airframes_post')); return false;">
|
|
<span id="selected_icao"></span>
|
|
</a>
|
|
<span id="selected_registration"></span>
|
|
<span id="selected_icaotype"></span>
|
|
<span id="selected_emergency"></span>
|
|
<span id="selected_flightaware_link"></span>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr id="infoblock_country" class="infoblock_body">
|
|
<td colspan="2">Country of registration: <span id="selected_country">n/a</span></td>
|
|
</tr>
|
|
|
|
<tr class="infoblock_body">
|
|
<td style="width: 55%">Altitude: <span id="selected_altitude"></span></td>
|
|
<td style="width: 45%">Squawk: <span id="selected_squawk"></span></td>
|
|
</tr>
|
|
|
|
<tr class="infoblock_body">
|
|
<td>Speed: <span id="selected_speed">n/a</span></td>
|
|
<td>RSSI: <span id="selected_rssi">n/a</span></td>
|
|
</tr>
|
|
|
|
<tr class="infoblock_body">
|
|
<td>Vertical rate: <span id="selected_vertical_rate">n/a</span></td>
|
|
<td>Messages: <span id="selected_message_count">n/a</span></td>
|
|
</tr>
|
|
|
|
<tr class="infoblock_body">
|
|
<td>Track: <span id="selected_track">n/a</span></td>
|
|
<td>Last seen: <span id="selected_seen">n/a</span></td>
|
|
</tr>
|
|
|
|
<tr class="infoblock_body">
|
|
<td colspan="2">Position: <span id="selected_position">n/a</span></td>
|
|
</tr>
|
|
|
|
<tr class="infoblock_body">
|
|
<td colspan="2">Distance from Site: <span id="selected_sitedist">n/a</span></td>
|
|
</tr>
|
|
<tr class="infoblock_body">
|
|
<td colspan="2"><span id="selected_photo_link"></span></td>
|
|
</tr>
|
|
</table>
|
|
</div> <!-- selected_infoblock -->
|
|
<div id="map_container">
|
|
<div id="map_canvas"></div>
|
|
<div id="toggle_sidebar_control" class="ol-unselectable ol-control">
|
|
<button id="toggle_sidebar_button" class="hide_sidebar" title="Toggle Sidebar"></button>
|
|
</div>
|
|
<div id="expand_sidebar_control" class="ol-unselectable ol-control">
|
|
<button id="expand_sidebar_button" title="Expand Sidebar"></button>
|
|
</div>
|
|
</div>
|
|
<div id="sidebar_container">
|
|
<div id="splitter" class="ui-resizable-handle ui-resizable-w"></div>
|
|
<div id="sidebar_canvas">
|
|
|
|
<div id="dump1090_infoblock">
|
|
<table style="width: 100%">
|
|
<tr class="infoblock_heading">
|
|
<td>
|
|
<b id="infoblock_name">FlightAware dump1090</b>
|
|
</td>
|
|
<td>
|
|
<span id="show_map_button" class="sidebarButton pointer">Show Map</span>
|
|
</td>
|
|
<td style="text-align: right">
|
|
<a href="https://github.com/flightaware/dump1090" id="dump1090_version" target="_blank"></a>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td colspan="2">
|
|
<div id="sudo_buttons">
|
|
<span class="sidebarButton pointer" onclick="resetMap();">Reset Map</span>
|
|
<span class="sidebarButton pointer" onclick="selectAllPlanes();">Select All</span>
|
|
<span class="sidebarButton pointer" onclick="deselectAllPlanes();">Select None</span>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr class="infoblock_body">
|
|
<td>Aircraft (total): <span id="dump1090_total_ac">n/a</span></td>
|
|
<td>Messages: <span id="dump1090_message_rate">n/a</span>/sec</td>
|
|
</tr>
|
|
|
|
<tr class="infoblock_body">
|
|
<td>(with positions): <span id="dump1090_total_ac_positions">n/a</span></td>
|
|
<td>History: <span id="dump1090_total_history">n/a</span> positions</td>
|
|
</tr>
|
|
</table>
|
|
</div> <!-- dump1090_infoblock -->
|
|
|
|
<div id="units_container">
|
|
<label for="units_selector">Units:</label>
|
|
<select name="units_selector" id="units_selector">
|
|
<option value="nautical">Aeronautical</option>
|
|
<option value="metric">Metric</option>
|
|
<option value="imperial">Imperial</option>
|
|
</select>
|
|
</div>
|
|
|
|
<form id="altitude_filter_form">
|
|
<label>Filter by altitude:</label>
|
|
<input id="altitude_filter_min" name="minAltitude" type="text" class="altitudeFilterInput" maxlength="5">
|
|
<label for="minAltitude" class="altitudeUnit"></label>
|
|
<span> to </span>
|
|
<input id="altitude_filter_max" name="maxAltitude" type="text" class="altitudeFilterInput" maxlength="5">
|
|
<label for="maxAltitude" class="altitudeUnit"></label>
|
|
<button type="submit">Filter</button>
|
|
<button id="altitude_filter_reset_button">Reset</button>
|
|
</form>
|
|
|
|
<div id="planes_table">
|
|
<table id="tableinfo" style="width: 100%">
|
|
<thead class="aircraft_table_header">
|
|
<tr>
|
|
<td id="icao" onclick="sortByICAO();">ICAO</td>
|
|
<td id="flag" onclick="sortByCountry()"><!-- column for flag image --></td>
|
|
<td id="flight" onclick="sortByFlight();">Ident</td>
|
|
<td id="registration" onclick="sortByRegistration();">Registration</td>
|
|
<td id="aircraft_type" onclick="sortByAircraftType();"> Aircraft type</td>
|
|
<td id="squawk" onclick="sortBySquawk();">Squawk</td>
|
|
<td id="altitude" onclick="sortByAltitude();">Altitude (<span class="altitudeUnit"></span>)</td>
|
|
<td id="speed" onclick="sortBySpeed();">Speed (<span class="speedUnit"></span>)</td>
|
|
<td id="vert_rate" onclick="sortByVerticalRate();">Vertical Rate (<span class="verticalRateUnit"></span>)</td>
|
|
<td id="distance" onclick="sortByDistance();">Distance (<span class="distanceUnit"></span>)</td>
|
|
<td id="track" onclick="sortByTrack();">Track</td>
|
|
<td id="msgs" onclick="sortByMsgs();">Msgs</td>
|
|
<td id="seen" onclick="sortBySeen();">Age</td>
|
|
<td id="rssi" onclick="sortByRssi();">RSSI</td>
|
|
<td id="lat" onclick="sortByLatitude();">Latitude</td>
|
|
<td id="lon" onclick="sortByLongitude();">Longitude</td>
|
|
<td id="data_source" onclick="sortByDataSource();">Data Source</td>
|
|
<td id="airframes_mode_s_link">Airframes.org Link</td>
|
|
<td id="flightaware_mode_s_link">FlightAware Link</td>
|
|
<td id="flightaware_photo_link">Photos</td>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<tr id="plane_row_template" class="plane_table_row hidden">
|
|
<td class="icaoCodeColumn">ICAO</td>
|
|
<td><img style="width: 20px; height=12px" src="about:blank" alt="Flag"></td>
|
|
<td>FLIGHT</td>
|
|
<td>REGISTRATION</td>
|
|
<td>AIRCRAFT_TYPE</td>
|
|
<td style="text-align: right">SQUAWK</td>
|
|
<td style="text-align: right">ALTITUDE</td>
|
|
<td style="text-align: right">SPEED</td>
|
|
<td style="text-align: right">VERT_RATE</td>
|
|
<td style="text-align: right">DISTANCE</td>
|
|
<td style="text-align: right">TRACK</td>
|
|
<td style="text-align: right">MSGS</td>
|
|
<td style="text-align: right">SEEN</td>
|
|
<td style="text-align: right">RSSI</td>
|
|
<td style="text-align: right">LAT</td>
|
|
<td style="text-align: right">LON</td>
|
|
<td style="text-align: right">DATA_SOURCE</td>
|
|
<td style="text-align: center">AIRFRAMES_MODE_S_LINK</td>
|
|
<td style="text-align: center">FLIGHTAWARE_MODE_S_LINK</td>
|
|
<td style="text-align: center">FLIGHTAWARE_PHOTO_LINK</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div> <!-- planes_table -->
|
|
|
|
</div> <!-- sidebar_canvas -->
|
|
</div> <!-- sidebar_container -->
|
|
</div> <!-- layout_container -->
|
|
|
|
<div id="SpecialSquawkWarning" class="hidden">
|
|
<b>Squawk 7x00 is reported and shown.</b><br>
|
|
This is most likely an error in receiving or decoding.<br>
|
|
Please do not call the local authorities, they already know about it if it is a valid squawk.
|
|
</div>
|
|
|
|
<div id="update_error" class="hidden">
|
|
<b>Problem fetching data from dump1090.</b><br>
|
|
<span id="update_error_detail"></span><br>
|
|
The displayed map data will be out of date.
|
|
</div>
|
|
|
|
<div id="container_splitter"></div>
|
|
</body>
|
|
</html>
|