From 326ad34b82e744b98d3341f3b70d64406f73ebc9 Mon Sep 17 00:00:00 2001 From: Jacek Kowalski <Jacek@jacekk.info> Date: Thu, 31 Jan 2019 13:35:54 +0000 Subject: [PATCH] Verify longitude and latitude are present before adding feature --- common.js | 204 ++++++++++++++++++++++++++------------------------ 1 files changed, 105 insertions(+), 99 deletions(-) diff --git a/common.js b/common.js index 32022dc..069a957 100644 --- a/common.js +++ b/common.js @@ -1,11 +1,16 @@ // Special directions var special_directions = { - 'Zajezdnia Nowa Huta' : 'NH', - 'Zajezdnia Podgórze' : 'P', + 'Zajezdnia Nowa Huta' : 'ZH', + 'Zajezdnia Podgórze' : 'ZP', + 'Zjazd do zajezdni' : 'Z', + 'Wyjazd na linię' : 'W', + 'Przejazd techniczny' : 'PT', }; var script_version; var script_version_xhr; + +var vehicles_info = {}; // Check for website updates function checkVersion() { @@ -31,108 +36,109 @@ setInterval(checkVersion, 3600000); } +/* Parsing of received JSON parts */ +function parseStatus(status) { + switch(status.status) { + case 'STOPPING': + case 'PREDICTED': + if(status.actualRelativeTime <= 0) + return lang.boarding_sign; + if(status.actualRelativeTime >= 60) + return lang.time_minutes_prefix + Math.floor(status.actualRelativeTime / 60) + lang.time_minutes_suffix; + return lang.time_seconds_prefix + status.actualRelativeTime + lang.time_seconds_suffix; + case 'DEPARTED': + return lang.time_minutes_ago_prefix + Math.floor(-status.actualRelativeTime / 60) + lang.time_minutes_ago_suffix; + default: + return status.mixedTime; + } +} + +function parseTime(date, time) { + var result = new Date(date.getFullYear(), date.getMonth(), date.getDay()); + var time_split = time.split(':'); + result.setHours(time_split[0]); + result.setMinutes(time_split[1]); + + if(result.getTime() - date.getTime() > 72000000) { + result.setTime(result.getTime() - 86400000); + } + + if(date.getTime() - result.getTime() > 72000000) { + result.setTime(result.getTime() + 86400000); + } + + return result; +} + +function parseDelay(status) { + if(!status.actualTime) return lang.unknown_sign; + if(!status.plannedTime) return lang.unknown_sign; + + var now = new Date(); + var actual = parseTime(now, status.actualTime); + var planned = parseTime(now, status.plannedTime); + + return lang.time_minutes_prefix + ((actual.getTime() - planned.getTime()) / 1000 / 60) + lang.time_minutes_suffix; +} + // Webservice-related functions function parseVehicle(vehicleId) { - if(!vehicleId) return; - if(vehicleId.substr(0, 15) != '635218529567218') { - console.log('Unknown vehicle, vehicleId=' + vehicleId); - return; - } - - var id = parseInt(vehicleId.substr(15)) - 736; - var prefix; - var type; - var low; // low floor: 0 = no, 1 - semi, 2 - full - - // Single exception - old id used in one case - if(id == 831) { - id = 216; - } - - if(101 <= id && id <= 173) { - prefix = 'HW'; - type = 'E1'; - low = 0; - - if((108 <= id && id <= 113) || id == 127 || id == 131 || id == 132 || id == 134 || (137 <= id && id <= 139) || (148 <= id && id <= 150) || (153 <= id && id <= 166) || id == 161) { - prefix = 'RW'; - } - } else if(201 <= id && id <= 293) { - prefix = 'RZ'; - type = '105Na'; - low = 0; - - if(246 <= id) { - prefix = 'HZ'; - } - if(id == 290) { - type = '105Nb'; - } - } else if(301 <= id && id <= 328) { - prefix = 'RF'; - type = 'GT8S'; - low = 0; - - if(id == 313) { - type = 'GT8C' - low = 1; - } - } else if(401 <= id && id <= 440) { - prefix = 'HL'; - type = 'EU8N'; - low = 1; - } else if(451 <= id && id <= 462) { - prefix = 'HK'; - type = 'N8S-NF'; - low = 0; - - if((451 <= id && id <= 453) || id == 462) { - type = 'N8C-NF'; - low = 1; - } - } else if(601 <= id && id <= 650) { - prefix = 'RP'; - type = 'NGT6 (3)'; - low = 2; - - if(id <= 613) { - type = 'NGT6 (1)'; - } else if (id <= 626) { - type = 'NGT6 (2)'; - } - } else if(801 <= id && id <= 824) { - prefix = 'RY'; - type = 'NGT8'; - low = 2; - } else if(id == 899) { - prefix = 'RY'; - type = '126N'; - low = 2; - } else if(901 <= id && id <= 936) { - prefix = 'RG'; - type = '2014N'; - low = 2; - - if(915 <= id) { - prefix = 'HG'; - } - } else if(id === 999) { - prefix = 'HX'; - type = '405N-Kr'; - low = 1; + if(!vehicleId) return false; + if(!vehicles_info || !vehicles_info[vehicleId]) { + return false; } else { - console.log('Unknown vehicle, vehicleId=' + vehicleId + ', id=' + id); - return; + var vehicle = vehicles_info[vehicleId]; + return { + vehicleId: vehicleId, + prefix: vehicle['num'].substr(0, 2), + id: vehicle['num'].substr(2, 3), + num: vehicle['num'], + type: vehicle['type'], + low: vehicle['low'] + }; + } +} + +function updateVehicleInfo() { + return $.get( + 'https://mpk.jacekk.net/vehicles/' + ).done(function(data) { + vehicles_info = data; + }); +} + +function tramIdToVehicleId(tramId) { + for(var prop in vehicles_info) { + if(vehicles_info[prop]['num'].substr(2) == tramId) { + return prop; + } + } +} + +function displayVehicle(vehicleInfo) { + if(!vehicleInfo) return document.createTextNode(''); + + var span = document.createElement('span'); + span.className = 'vehicleInfo'; + + var floor_type = ''; + if(vehicleInfo.low == '0') { + setText(span, lang.high_floor_sign); + floor_type = lang.high_floor; + } else if(vehicleInfo.low == '1') { + setText(span, lang.partially_low_floor_sign); + floor_type = lang.partially_low_floor; + } else if(vehicleInfo.low == '2') { + setText(span, lang.low_floor_sign); + floor_type = lang.low_floor; } - return { - vehicleId: vehicleId, - prefix: prefix, - id: id, - num: prefix + id, - type: type, - low: low - }; + span.title = lang.tram_type_pattern + .replace('$num', vehicleInfo.num) + .replace('$type', vehicleInfo.type) + .replace('$floor', floor_type); + + return span; } // Element mangling -- Gitblit v1.9.1