From 38340e01ff8bec3c1a89b9bd294c49f78a73e411 Mon Sep 17 00:00:00 2001
From: Jacek Kowalski <Jacek@jacekk.info>
Date: Sat, 22 Jun 2019 22:07:29 +0000
Subject: [PATCH] Fix delay calcs when times are from two different days (i.e. 23:59-00:00)
---
common.js | 184 +++++++++++++++++++++++++++++++++++-----------
1 files changed, 140 insertions(+), 44 deletions(-)
diff --git a/common.js b/common.js
index f4afeef..964cf68 100644
--- a/common.js
+++ b/common.js
@@ -1,15 +1,92 @@
-// Special directions
-var special_directions = {
- 'Zajezdnia Nowa Huta' : 'NH',
- 'Zajezdnia Podgórze' : 'P',
+'use strict';
+
+var ttss_urls = {
+ t: 'proxy_tram.php',
+ // t: 'http://www.ttss.krakow.pl/internetservice',
+ b: 'proxy_bus.php',
+ // b: 'http://ttss.mpk.krakow.pl/internetservice',
};
+var ttss_types = ['t', 'b'];
+
+var special_directions = {
+ 'Zajezdnia Nowa Huta' : 'ZH',
+ 'Zajezdnia Podgórze' : 'ZP',
+ 'Zjazd do zajezdni' : 'Z',
+ 'Wyjazd na linię' : 'W',
+ '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;
+var vehicles_info = {};
-// Check for website updates
function checkVersion() {
if(script_version_xhr) script_version_xhr.abort();
@@ -33,7 +110,44 @@
setInterval(checkVersion, 3600000);
}
-/* Parsing of received JSON parts */
+
+/*******
+ * DOM *
+ *******/
+
+function deleteChildren(element) {
+ while(element.lastChild) element.removeChild(element.lastChild);
+}
+
+function addElementWithText(parent, element, text) {
+ var elem = document.createElement(element);
+ elem.appendChild(document.createTextNode(text));
+ parent.appendChild(elem);
+ return elem;
+}
+
+function addCellWithText(parent, text) {
+ return addElementWithText(parent, 'td', text);
+}
+
+function addParaWithText(parent, text) {
+ return addElementWithText(parent, 'p', text);
+}
+
+function setText(element, text) {
+ deleteChildren(element);
+ element.appendChild(document.createTextNode(text));
+}
+
+
+/***********
+ * PARSING *
+ ***********/
+
+function normalizeName(string) {
+ return string.replace('.', '. ').replace(' ', ' ');
+}
+
function parseStatus(status) {
switch(status.status) {
case 'STOPPING':
@@ -51,10 +165,9 @@
}
function parseTime(date, time) {
- var result = new Date(date.getFullYear(), date.getMonth(), date.getDay());
+ var result = new Date(date.getTime());
var time_split = time.split(':');
- result.setHours(time_split[0]);
- result.setMinutes(time_split[1]);
+ result.setHours(time_split[0], time_split[1], 0);
if(result.getTime() - date.getTime() > 72000000) {
result.setTime(result.getTime() - 86400000);
@@ -78,7 +191,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]) {
@@ -104,11 +216,20 @@
});
}
-function tramIdToVehicleId(tramId) {
- if(0 <= tramId && tramId <= 999) {
- var vehicleId = '0000' + (tramId + 736);
- vehicleId = vehicleId.substr(vehicleId.length - 4)
- return '635218529567218' + vehicleId;
+function depotIdToVehicleId(depotId, typeHelper) {
+ var prop;
+ if(typeHelper) {
+ for(prop in vehicles_info) {
+ if(prop.substr(0,1) == typeHelper && vehicles_info[prop]['num'].substr(2) == depotId) {
+ return prop;
+ }
+ }
+ } else {
+ for(prop in vehicles_info) {
+ if(vehicles_info[prop]['num'] == depotId) {
+ return prop;
+ }
+ }
}
}
@@ -119,13 +240,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;
}
@@ -136,29 +257,4 @@
.replace('$floor', floor_type);
return span;
-}
-
-// Element mangling
-function deleteChildren(element) {
- while(element.lastChild) element.removeChild(element.lastChild);
-}
-
-function addElementWithText(parent, element, text) {
- var elem = document.createElement(element);
- elem.appendChild(document.createTextNode(text));
- parent.appendChild(elem);
- return elem;
-}
-
-function addCellWithText(parent, text) {
- return addElementWithText(parent, 'td', text);
-}
-
-function addParaWithText(parent, text) {
- return addElementWithText(parent, 'p', text);
-}
-
-function setText(element, text) {
- deleteChildren(element);
- element.appendChild(document.createTextNode(text));
}
--
Gitblit v1.9.1