From 76c2e76aa15a12a302b67f3737099ddfffb3907f Mon Sep 17 00:00:00 2001 From: Jacek Kowalski <Jacek@jacekk.info> Date: Sat, 04 May 2019 10:05:07 +0000 Subject: [PATCH] Ignore stop "Kurdwanów" (ID 744), replaced by "Kurdwanów P+R" --- common.js | 94 ++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 84 insertions(+), 10 deletions(-) diff --git a/common.js b/common.js index f238013..b434bf1 100644 --- a/common.js +++ b/common.js @@ -1,11 +1,13 @@ "use strict"; -//var ttss_trams_base = 'http://www.ttss.krakow.pl/internetservice'; -var ttss_trams_base = 'proxy_tram.php'; -//var ttss_buses_base = 'http://91.223.13.70/internetservice'; -var ttss_buses_base = 'proxy_bus.php'; +var ttss_urls = { + t: 'proxy_tram.php', + // t: 'http://www.ttss.krakow.pl/internetservice', + b: 'proxy_bus.php', + // b: 'http://91.223.13.70/internetservice', +}; +var ttss_types = ['t', 'b']; -// Special directions var special_directions = { 'Zajezdnia Nowa Huta' : 'ZH', 'Zajezdnia Podgórze' : 'ZP', @@ -14,12 +16,77 @@ 'Przejazd techniczny' : 'PT', }; + +/******** + * AJAX * + ********/ + +function Deferred(promise, request) { + return { + promise: promise, + request: request, + abort: function() { + request.abort.bind(request) + return Deferred(promise, request); + }, + done: function(func) { + return Deferred(promise.then(func), request); + }, + fail: function(func) { + return Deferred(promise.catch(func), request); + }, + always: function(func) { + return Deferred(promise.finally(func), request); + }, + }; +} + +Deferred.all = function(iterable) { + return Deferred( + Promise.all( + iterable.map(x => x.promise) + ) + ); +}; + +var $ = { + timeout: 10000, + dataType: 'json', + get: function(url) { + var self = this; + var request = new XMLHttpRequest(); + var promise = new Promise(function(resolve, reject) { + request.timeout = self.timeout; + request.onreadystatechange = function() { + if(this.readyState == 4) { + if(this.status == 200) { + if(self.dataType == 'json') { + resolve(JSON.parse(this.responseText)); + } else { + resolve(this.responseText); + } + } else { + reject(request); + } + } + }; + request.open("GET", url, true); + request.send(); + }); + return Deferred(promise, request); + }, +}; + + +/*********** + * VERSION * + ***********/ + var script_version; var script_version_xhr; var vehicles_info = {}; -// Check for website updates function checkVersion() { if(script_version_xhr) script_version_xhr.abort(); @@ -43,7 +110,11 @@ setInterval(checkVersion, 3600000); } -/* Parsing of received JSON parts */ + +/*********** + * PARSING * + ***********/ + function parseStatus(status) { switch(status.status) { case 'STOPPING': @@ -88,7 +159,6 @@ return lang.time_minutes_prefix + ((actual.getTime() - planned.getTime()) / 1000 / 60) + lang.time_minutes_suffix; } -// Webservice-related functions function parseVehicle(vehicleId) { if(!vehicleId) return false; if(!vehicles_info || !vehicles_info[vehicleId]) { @@ -117,7 +187,7 @@ function depotIdToVehicleId(depotId, typeHelper) { if(typeHelper) { for(var prop in vehicles_info) { - if(prop.substr(0,1) == type && vehicles_info[prop]['num'].substr(2) == depotId) { + if(prop.substr(0,1) == typeHelper && vehicles_info[prop]['num'].substr(2) == depotId) { return prop; } } @@ -156,7 +226,11 @@ return span; } -// Element mangling + +/******* + * DOM * + *******/ + function deleteChildren(element) { while(element.lastChild) element.removeChild(element.lastChild); } -- Gitblit v1.9.1