| | |
| | | |
| | | function fail_ajax_generic(data, fnc) { |
| | | // abort() is not a failure |
| | | if(data.readyState == 0 && data.statusText == 'abort') return; |
| | | if(data.readyState == 0) return; |
| | | |
| | | if(data.status == 0) { |
| | | fnc(lang.error_request_failed_connectivity, data); |
| | |
| | | |
| | | stop_selected_layer.setStyle(style); |
| | | |
| | | var feature = null; |
| | | var prefix = null; |
| | | var feature, prefix; |
| | | for(var i = 0; i < stops.length; i++) { |
| | | feature = null; |
| | | if(stops[i].getId) { |
| | |
| | | function unstyleSelectedFeatures() { |
| | | stop_selected_source.clear(); |
| | | route_source.clear(); |
| | | if(feature_clicked && ttss_types.indexOf(feature_clicked.getId().substr(0, 1)) >= 0) { |
| | | if(feature_clicked && ttss_types.includes(feature_clicked.getId().substr(0, 1))) { |
| | | styleVehicle(feature_clicked); |
| | | } |
| | | } |
| | |
| | | var stop = stops[i]; |
| | | |
| | | if(stop.category == 'other') continue; |
| | | if(stops_ignored.indexOf(stop.shortName) >= 0) continue; |
| | | if(stops_ignored.includes(stop.shortName)) continue; |
| | | |
| | | stop.geometry = getGeometry(stop); |
| | | var stop_feature = new ol.Feature(stop); |
| | |
| | | ).done(function(data) { |
| | | if(!data || !data.paths || !data.paths[0] || !data.paths[0].wayPoints) return; |
| | | |
| | | var point = null; |
| | | var point; |
| | | var points = []; |
| | | for(var i = 0; i < data.paths[0].wayPoints.length; i++) { |
| | | point = data.paths[0].wayPoints[i]; |
| | |
| | | })); |
| | | route_layer.setVisible(true); |
| | | }); |
| | | return path_xhr; |
| | | } |
| | | |
| | | function vehicleTable(feature, table) { |
| | |
| | | |
| | | deleteChildren(table); |
| | | |
| | | for(var i = 0, il = data.old.length; i < il; i++) { |
| | | var tr = document.createElement('tr'); |
| | | var i, il; |
| | | var tr; |
| | | for(i = 0, il = data.old.length; i < il; i++) { |
| | | tr = document.createElement('tr'); |
| | | addCellWithText(tr, data.old[i].actualTime || data.old[i].plannedTime); |
| | | addCellWithText(tr, data.old[i].stop_seq_num + '. ' + data.old[i].stop.name); |
| | | |
| | |
| | | |
| | | var stopsToMark = []; |
| | | |
| | | for(var i = 0, il = data.actual.length; i < il; i++) { |
| | | var tr = document.createElement('tr'); |
| | | for(i = 0, il = data.actual.length; i < il; i++) { |
| | | tr = document.createElement('tr'); |
| | | addCellWithText(tr, data.actual[i].actualTime || data.actual[i].plannedTime); |
| | | addCellWithText(tr, data.actual[i].stop_seq_num + '. ' + data.actual[i].stop.name); |
| | | |
| | |
| | | |
| | | feature_timer = setTimeout(function() { vehicleTable(feature, table); }, ttss_refresh); |
| | | }).fail(fail_ajax_popup); |
| | | return feature_xhr; |
| | | } |
| | | |
| | | function stopTable(stopType, stopId, table, featureId) { |
| | | function stopTable(stopType, stopId, table, ttss_type) { |
| | | if(feature_xhr) feature_xhr.abort(); |
| | | if(feature_timer) clearTimeout(feature_timer); |
| | | |
| | | var ttss_type = featureId.substr(1, 1); |
| | | |
| | | feature_xhr = $.get( |
| | | ttss_urls[ttss_type] + '/services/passageInfo/stopPassages/' + stopType |
| | |
| | | ).done(function(data) { |
| | | deleteChildren(table); |
| | | |
| | | for(var i = 0, il = data.old.length; i < il; i++) { |
| | | var tr = document.createElement('tr'); |
| | | var i, il; |
| | | var tr, dir_cell, vehicle, status, status_cell, delay, delay_cell; |
| | | for(i = 0, il = data.old.length; i < il; i++) { |
| | | tr = document.createElement('tr'); |
| | | addCellWithText(tr, data.old[i].patternText); |
| | | var dir_cell = addCellWithText(tr, data.old[i].direction); |
| | | var vehicle = parseVehicle(data.old[i].vehicleId); |
| | | dir_cell = addCellWithText(tr, data.old[i].direction); |
| | | vehicle = parseVehicle(data.old[i].vehicleId); |
| | | dir_cell.appendChild(displayVehicle(vehicle)); |
| | | var status = parseStatus(data.old[i]); |
| | | addCellWithText(tr, status); |
| | | addCellWithText(tr, ''); |
| | | status = parseStatus(data.old[i]); |
| | | status_cell = addCellWithText(tr, status); |
| | | delay_cell = addCellWithText(tr, ''); |
| | | |
| | | tr.className = 'active'; |
| | | table.appendChild(tr); |
| | | } |
| | | |
| | | for(var i = 0, il = data.actual.length; i < il; i++) { |
| | | var tr = document.createElement('tr'); |
| | | for(i = 0, il = data.actual.length; i < il; i++) { |
| | | tr = document.createElement('tr'); |
| | | addCellWithText(tr, data.actual[i].patternText); |
| | | var dir_cell = addCellWithText(tr, data.actual[i].direction); |
| | | var vehicle = parseVehicle(data.actual[i].vehicleId); |
| | | dir_cell = addCellWithText(tr, data.actual[i].direction); |
| | | vehicle = parseVehicle(data.actual[i].vehicleId); |
| | | dir_cell.appendChild(displayVehicle(vehicle)); |
| | | var status = parseStatus(data.actual[i]); |
| | | var status_cell = addCellWithText(tr, status); |
| | | var delay = parseDelay(data.actual[i]); |
| | | var delay_cell = addCellWithText(tr, delay); |
| | | status = parseStatus(data.actual[i]); |
| | | status_cell = addCellWithText(tr, status); |
| | | delay = parseDelay(data.actual[i]); |
| | | delay_cell = addCellWithText(tr, delay); |
| | | |
| | | if(status == lang.boarding_sign) { |
| | | if(data.actual[i].status === 'DEPARTED') { |
| | | tr.className = 'active'; |
| | | } else if(status == lang.boarding_sign) { |
| | | tr.className = 'success'; |
| | | status_cell.className = 'status-boarding'; |
| | | } else if(parseInt(delay) > 9) { |
| | |
| | | table.appendChild(tr); |
| | | } |
| | | |
| | | feature_timer = setTimeout(function() { stopTable(stopType, stopId, table, featureId); }, ttss_refresh); |
| | | feature_timer = setTimeout(function() { stopTable(stopType, stopId, table, ttss_type); }, ttss_refresh); |
| | | }).fail(fail_ajax_popup); |
| | | return feature_xhr; |
| | | } |
| | | |
| | | function featureClicked(feature) { |
| | |
| | | var tabular_data = true; |
| | | |
| | | var type = feature.getId().substr(0, 1); |
| | | var full_type = feature.getId().match(/^[a-z]+/)[0]; |
| | | var typeName = lang.types[full_type]; |
| | | if(typeof typeName === 'undefined') { |
| | | typeName = ''; |
| | | } |
| | | |
| | | // Location |
| | | if(type == 'l') { |
| | | tabular_data = false; |
| | | name = typeName; |
| | | typeName = ''; |
| | | name = lang.type_location; |
| | | } |
| | | // Vehicle |
| | | else if(ttss_types.indexOf(type) >= 0) { |
| | | typeName = lang.type_bus; |
| | | if(type == 't') { |
| | | typeName = lang.type_tram; |
| | | } |
| | | |
| | | else if(ttss_types.includes(type)) { |
| | | var span = displayVehicle(feature.get('vehicle_type')); |
| | | |
| | | additional = document.createElement('p'); |
| | |
| | | styleVehicle(feature, true); |
| | | } |
| | | // Stop or stop point |
| | | else if(['s', 'p'].indexOf(type) >= 0) { |
| | | else if(['s', 'p'].includes(type)) { |
| | | var ttss_type = feature.getId().substr(1, 1); |
| | | if(type == 's') { |
| | | typeName = lang.type_stop_tram; |
| | | var second_type = lang.departures_for_buses; |
| | | var mapping = stops_mapping['sb']; |
| | | |
| | | if(feature.getId().startsWith('sb')) { |
| | | typeName = lang.type_stop_bus; |
| | | if(ttss_type == 'b') { |
| | | second_type = lang.departures_for_trams; |
| | | mapping = stops_mapping['st']; |
| | | } |
| | | |
| | | stopTable('stop', feature.get('shortName'), tbody, ttss_type); |
| | | |
| | | if(mapping[feature.get('shortName')]) { |
| | | additional = document.createElement('p'); |
| | |
| | | ); |
| | | } |
| | | } else { |
| | | typeName = lang.type_stoppoint_tram; |
| | | |
| | | if(feature.getId().startsWith('pb')) { |
| | | typeName = lang.type_stoppoint_bus; |
| | | } |
| | | stopTable('stopPoint', feature.get('stopPoint'), tbody, ttss_type); |
| | | |
| | | additional = document.createElement('p'); |
| | | additional.className = 'small'; |
| | | addElementWithText(additional, 'a', lang.departures_for_stop).addEventListener( |
| | | 'click', |
| | | function() { |
| | | var mapping = stops_mapping['s' + feature.getId().substr(1,1)]; |
| | | var mapping = stops_mapping['s' + ttss_type]; |
| | | featureClicked(mapping[feature.get('shortName')]); |
| | | } |
| | | ); |
| | |
| | | addElementWithText(thead, 'th', lang.header_time); |
| | | addElementWithText(thead, 'th', lang.header_delay); |
| | | |
| | | stopTable('stop', feature.get('shortName'), tbody, feature.getId()); |
| | | markStops([feature], feature.getId().substr(1,1)); |
| | | } else { |
| | | panel.close(); |
| | |
| | | |
| | | addParaWithText(div, lang.select_feature); |
| | | |
| | | var feature, p, a, full_type, typeName; |
| | | for(var i = 0; i < features.length; i++) { |
| | | var feature = features[i]; |
| | | feature = features[i]; |
| | | |
| | | var p = document.createElement('p'); |
| | | var a = document.createElement('a'); |
| | | p = document.createElement('p'); |
| | | a = document.createElement('a'); |
| | | p.appendChild(a); |
| | | a.addEventListener('click', function(feature) { return function() { |
| | | featureClicked(feature); |
| | | }}(feature)); |
| | | |
| | | var type = feature.getId().substr(0, 1); |
| | | var typeName = ''; |
| | | if(type == 'l') { |
| | | full_type = feature.getId().match(/^[a-z]+/)[0]; |
| | | typeName = lang.types[full_type]; |
| | | if(typeof typeName === 'undefined') { |
| | | typeName = ''; |
| | | name = lang.type_location; |
| | | } else if(ttss_types.indexOf(type) >= 0) { |
| | | typeName = lang.type_bus; |
| | | if(type == 't') { |
| | | typeName = lang.type_tram; |
| | | } |
| | | if(feature.get('vehicle_type').num) { |
| | | typeName += ' ' + feature.get('vehicle_type').num; |
| | | } |
| | | } else if(type == 's') { |
| | | typeName = lang.type_stop_tram; |
| | | if(feature.getId().startsWith('sb')) { |
| | | typeName = lang.type_stop_bus; |
| | | } |
| | | } else if (type == 'p') { |
| | | typeName = lang.type_stoppoint_tram; |
| | | if(feature.getId().startsWith('pb')) { |
| | | typeName = lang.type_stoppoint_bus; |
| | | } |
| | | } else { |
| | | continue; |
| | | } |
| | | |
| | | addElementWithText(a, 'span', typeName).className = 'small'; |
| | |
| | | } |
| | | |
| | | function init() { |
| | | if(!window.jQuery) { |
| | | fail(lang.jquery_not_loaded); |
| | | return; |
| | | } |
| | | |
| | | $.ajaxSetup({ |
| | | dataType: 'json', |
| | | timeout: 10000, |
| | | }); |
| | | |
| | | panel = new Panel(document.getElementById('panel')); |
| | | |
| | | route_source = new ol.source.Vector({ |
| | |
| | | stops_type.forEach(function(type) { |
| | | future_requests.push(updateStops(type.substr(0,1), type.substr(1,1))); |
| | | }); |
| | | $.when(future_requests).done(hash); |
| | | Deferred.all(future_requests).done(hash); |
| | | |
| | | window.addEventListener('hashchange', hash); |
| | | |