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 |  113 ++++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 101 insertions(+), 12 deletions(-)

diff --git a/common.js b/common.js
index 069a957..b434bf1 100644
--- a/common.js
+++ b/common.js
@@ -1,4 +1,13 @@
-// Special directions
+"use strict";
+
+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'];
+
 var special_directions = {
 	'Zajezdnia Nowa Huta' : 'ZH',
 	'Zajezdnia Podgórze' : 'ZP',
@@ -7,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();
 	
@@ -36,7 +110,11 @@
 	setInterval(checkVersion, 3600000);
 }
 
-/* Parsing of received JSON parts */
+
+/***********
+ * PARSING *
+ ***********/
+
 function parseStatus(status) {
 	switch(status.status) {
 		case 'STOPPING':
@@ -81,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]) {
@@ -107,10 +184,18 @@
 	});
 }
 
-function tramIdToVehicleId(tramId) {
-	for(var prop in vehicles_info) {
-		if(vehicles_info[prop]['num'].substr(2) == tramId) {
-			return prop;
+function depotIdToVehicleId(depotId, typeHelper) {
+	if(typeHelper) {
+		for(var prop in vehicles_info) {
+			if(prop.substr(0,1) == typeHelper && vehicles_info[prop]['num'].substr(2) == depotId) {
+				return prop;
+			}
+		}
+	} else {
+		for(var prop in vehicles_info) {
+			if(vehicles_info[prop]['num'] == depotId) {
+				return prop;
+			}
 		}
 	}
 }
@@ -122,13 +207,13 @@
 	span.className = 'vehicleInfo';
 	
 	var floor_type = '';
-	if(vehicleInfo.low == '0') {
+	if(vehicleInfo.low == 0) {
 		setText(span, lang.high_floor_sign);
 		floor_type = lang.high_floor;
-	} else if(vehicleInfo.low == '1') {
+	} else if(vehicleInfo.low == 1) {
 		setText(span, lang.partially_low_floor_sign);
 		floor_type = lang.partially_low_floor;
-	} else if(vehicleInfo.low == '2') {
+	} else if(vehicleInfo.low == 2) {
 		setText(span, lang.low_floor_sign);
 		floor_type = lang.low_floor;
 	}
@@ -141,7 +226,11 @@
 	return span;
 }
 
-// Element mangling
+
+/*******
+ * DOM *
+ *******/
+
 function deleteChildren(element) {
 	while(element.lastChild) element.removeChild(element.lastChild);
 }

--
Gitblit v1.9.1