130 lines
4.3 KiB
HTML
130 lines
4.3 KiB
HTML
|
|
<html>
|
|
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
|
|
<style>
|
|
td {
|
|
text-align: center;
|
|
}
|
|
</style>
|
|
<div ng-app="myApp" ng-controller="timetableCtrl">
|
|
|
|
<table>
|
|
<tr>
|
|
<th>
|
|
Aika
|
|
</th>
|
|
<th>
|
|
Bussin numero
|
|
</th>
|
|
<th>
|
|
Pysäkki
|
|
</th>
|
|
<th>
|
|
Päätepysäkki
|
|
</th>
|
|
</tr>
|
|
<tr ng-repeat="x in arr | orderBy: ['date','time']">
|
|
<td>
|
|
{{x.time}}
|
|
</td>
|
|
<td>
|
|
{{x.bus}}
|
|
</td>
|
|
<td>
|
|
{{x.stop}}
|
|
</td>
|
|
<td>
|
|
{{x.laststop}}
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<script>
|
|
var app = angular.module('myApp', []);
|
|
app.controller('timetableCtrl',
|
|
function($scope, $http, $interval) {
|
|
function load(){
|
|
$http.get('json')
|
|
.then(function(data, status, headers, config) {
|
|
parse(data);
|
|
});
|
|
};
|
|
var obj;
|
|
$scope.arr=[];
|
|
var dict=[];
|
|
function parse(data){
|
|
obj=data['data'];
|
|
for(var a in obj){
|
|
for(var b in obj[a]['lines']){
|
|
var elem=obj[a]['lines'][b].split(":");
|
|
dict[elem[0]]=elem[1];
|
|
}
|
|
for(var b in obj[a]['departures']){
|
|
var e=true;
|
|
var time=obj[a]['departures'][b]['time'];
|
|
date=obj[a]['departures'][b]['date'];
|
|
if(time<1000)
|
|
var unit = 1;
|
|
else
|
|
var unit = 2;
|
|
var hh= Math.floor(obj[a]['departures'][b]['time']/100);
|
|
if(hh>=24){
|
|
hh-=24;
|
|
date++;
|
|
}
|
|
var mm= obj[a]['departures'][b]['time']%100;
|
|
var c= obj[a]['departures'][b]['code'].substring(1,5);
|
|
if(c.charAt(0)=='0')
|
|
c=c.substring(1,4);
|
|
z={"stop":obj[a]['name'].split(",")[0],"dist":obj[a]['dist'],"bus":c,"date":date,"time":pad(hh,2)+":"+pad(mm,2),"laststop":dict[obj[a]['departures'][b]['code']].split(",")[0].split(" ")[0]};
|
|
for(var i= $scope.arr.length-1;i>=0;i--)
|
|
if( $scope.arr[i]['bus']==z['bus'] && $scope.arr[i]['laststop']==z['laststop']){
|
|
if( $scope.arr[i]['dist']==z['dist']){
|
|
break;
|
|
}
|
|
else if( $scope.arr[i]['dist'] > z['dist']){
|
|
$scope.arr.splice(i,1);
|
|
}
|
|
else
|
|
e=false;
|
|
}
|
|
if(e){
|
|
$scope.arr.push(z);
|
|
}
|
|
|
|
}
|
|
}
|
|
function pad(num, size) {
|
|
var s = num+"";
|
|
while (s.length < size) s = "0" + s;
|
|
return s;
|
|
}
|
|
delOld();
|
|
}
|
|
function delOld(){
|
|
f= new Date();
|
|
for(var a=$scope.arr.length-1; a>=0; a--){
|
|
if( $scope.arr[a]['time']<1000)
|
|
var unit = 1;
|
|
else
|
|
var unit = 2;
|
|
var time=$scope.arr[a]['time'].split(":");
|
|
date=$scope.arr[a]['date'].toString();
|
|
d= new Date(f);
|
|
d.setFullYear(date.substring(0,4),date.substring(4,6)-1,date.substring(6,8));
|
|
d.setHours(time[0]);
|
|
d.setMinutes(time[1]);
|
|
console.log(d);
|
|
if(d < f){
|
|
$scope.arr.splice(a,1);
|
|
}
|
|
}
|
|
}
|
|
load();
|
|
var t=$interval(delOld,2000);
|
|
var z=$interval(load,300000);
|
|
}
|
|
);
|
|
</script>
|
|
<html>
|