Added search by line and clear map functions

This commit is contained in:
eetnaviation
2024-12-06 12:46:47 +02:00
parent 3e75b9da39
commit a74f6546e1
2 changed files with 174 additions and 15 deletions

View File

@ -22,7 +22,15 @@
<form id="search-form">
<label for="bus-id">Enter TAK:</label>
<input type="text" id="bus-id" name="bus-id">
<button type="submit">Search</button>
<button type="submit">Search by TAK</button>
</form>
<form id="search-by-line-form">
<label for="bus-line">Enter LINE:</label>
<input type="text" id="bus-line" name="bus-line">
<button type="submit">Search by line</button>
</form>
<form id="clear-map">
<button type="submit">Clear map</button>
</form>
<form id="bulk-search">
<p>Bulk searches:</p>
@ -78,6 +86,27 @@
socket.emit('takSearch', tak);
});
document.getElementById('search-by-line-form').addEventListener('submit', function (event) {
event.preventDefault();
var line = document.getElementById('bus-line').value.trim();
socket.emit('lineSearch', line);
});
document.getElementById('clear-map').addEventListener('submit', function (event) {
event.preventDefault();
Object.keys(markers).forEach(tak => {
markers[tak].remove();
});
markers = {};
document.getElementById("type").innerHTML = "Type: " + "UNFETCHED";
document.getElementById("line").innerHTML = "Current line: " + "UNFETCHED";
document.getElementById("lat").innerHTML = "Latitude: " + "UNFETCHED";
document.getElementById("long").innerHTML = "Longitude: " + "UNFETCHED";
document.getElementById("latlong").innerHTML = "Coordinates (Merged): " + "UNFETCHED";
document.getElementById("tak").innerHTML = "TAK: " + "UNFETCHED";
document.getElementById("vehicleInfo").innerHTML = "Vehicle info: " + "UNFETCHED";
});
document.getElementById('bulk-search').addEventListener('submit', function (event) {
event.preventDefault();
});

158
main.js
View File

@ -159,13 +159,36 @@ io.on('connection', (socket) => {
clearInterval(requestModeIntervalId);
}
startRequestModeFetch();
fetchDataFromLocalFile(tak, socket);
fetchDataFromLocalFileByTak(tak, socket);
} catch (error) {
var caughtError = "Error processing takSearch:", error;
console.error(caughtError);
writeToLog('errors_log.txt', caughtError);
}
});
socket.on('lineSearch', async (line) => {
try {
console.log("Input line: " + line);
saveRequestLogs(socket, line);
if (isRequestMode) {
const currentTime = Date.now();
if (currentTime - lastFetchTime >= requestModeInterval) {
await fetchAndSaveData("Request Mode");
}
} else {
await fetchAndSaveData("Request Mode");
}
if (isRequestMode) {
clearInterval(requestModeIntervalId);
}
startRequestModeFetch();
fetchDataFromLocalFileByLineNumber(line, socket);
} catch (error) {
var caughtError = "Error processing lineSearch:", error;
console.error(caughtError);
writeToLog('errors_log.txt', caughtError);
}
});
socket.on('electricBusBulkSearch', async () => {
console.log("Running bulk electric bus search!");
saveRequestLogs(socket, "ElectricBusBulkSearch");
@ -183,7 +206,7 @@ io.on('connection', (socket) => {
}
startRequestModeFetch();
electricBusTakArray.forEach((takToSearch) => {
fetchDataFromLocalFile(takToSearch, socket);
fetchDataFromLocalFileByTak(takToSearch, socket);
});
} catch (error) {
var caughtError = "Error processing electricBusBulkSearch:", error;
@ -208,7 +231,7 @@ io.on('connection', (socket) => {
}
startRequestModeFetch();
a40TakArray.forEach((takToSearch) => {
fetchDataFromLocalFile(takToSearch, socket);
fetchDataFromLocalFileByTak(takToSearch, socket);
});
} catch (error) {
var caughtError = "Error processing a40BulkSearch: ", error;
@ -233,7 +256,7 @@ io.on('connection', (socket) => {
}
startRequestModeFetch();
a21TakArray.forEach((takToSearch) => {
fetchDataFromLocalFile(takToSearch, socket);
fetchDataFromLocalFileByTak(takToSearch, socket);
});
} catch (error) {
var caughtError = "Error processing a21BulkSearch: ", error;
@ -258,7 +281,7 @@ io.on('connection', (socket) => {
}
startRequestModeFetch();
a78TakArray.forEach((takToSearch) => {
fetchDataFromLocalFile(takToSearch, socket);
fetchDataFromLocalFileByTak(takToSearch, socket);
});
} catch (error) {
var caughtError = "Error processing a78BulkSearch: ", error;
@ -283,7 +306,7 @@ io.on('connection', (socket) => {
}
startRequestModeFetch();
volvohybridTakArray.forEach((takToSearch) => {
fetchDataFromLocalFile(takToSearch, socket);
fetchDataFromLocalFileByTak(takToSearch, socket);
});
} catch (error) {
var caughtError = "Error processing volvo7900BulkSearch: ", error;
@ -308,7 +331,7 @@ io.on('connection', (socket) => {
}
startRequestModeFetch();
pesaTramTakArray.forEach((takToSearch) => {
fetchDataFromLocalFile(takToSearch, socket);
fetchDataFromLocalFileByTak(takToSearch, socket);
});
} catch (error) {
var caughtError = "Error processing pesaTramBulkSearch: ", error;
@ -356,7 +379,7 @@ io.on('connection', (socket) => {
}
startRequestModeFetch();
cafTramTakArray.forEach((takToSearch) => {
fetchDataFromLocalFile(takToSearch, socket);
fetchDataFromLocalFileByTak(takToSearch, socket);
});
} catch (error) {
var caughtError = "Error processing cafBulkSearch: ", error;
@ -381,19 +404,19 @@ io.on('connection', (socket) => {
}
startRequestModeFetch();
kt6tmTramArray.forEach((takToSearch) => {
fetchDataFromLocalFile(takToSearch, socket);
fetchDataFromLocalFileByTak(takToSearch, socket);
});
kt4suTramArray.forEach((takToSearch) => {
fetchDataFromLocalFile(takToSearch, socket);
fetchDataFromLocalFileByTak(takToSearch, socket);
});
kt4tmrTramArray.forEach((takToSearch) => {
fetchDataFromLocalFile(takToSearch, socket);
fetchDataFromLocalFileByTak(takToSearch, socket);
});
kt4dTramArray.forEach((takToSearch) => {
fetchDataFromLocalFile(takToSearch, socket);
fetchDataFromLocalFileByTak(takToSearch, socket);
});
kt4tmTramArray.forEach((takToSearch) => {
fetchDataFromLocalFile(takToSearch, socket);
fetchDataFromLocalFileByTak(takToSearch, socket);
});
} catch (error) {
var caughtError = "Error processing tatraBulkSearch: ", error;
@ -529,7 +552,7 @@ function startRequestModeFetch() {
}, requestModeDuration);
}
async function fetchDataFromLocalFile(takInput, socket) {
async function fetchDataFromLocalFileByTak(takInput, socket) {
try {
const data = fs.readFileSync(localFilePath, 'utf8');
const lines = data.split('\n');
@ -733,4 +756,111 @@ async function fetchDataFromLocalFileByTransportType(transportTypeInput, socket)
}
}
async function fetchDataFromLocalFileByLineNumber(lineInput, socket) {
try {
const data = fs.readFileSync(localFilePath, 'utf8');
const lines = data.split('\n');
const results = [];
lines.forEach(line => {
if (line) {
const data = line.split(',');
if (data.length >= 9) {
try {
const transportType = parseInt(data[0]);
const lineNumber = parseInt(data[1]);
const longitude = parseFloat(data[2]) / 1000000;
const latitude = parseFloat(data[3]) / 1000000;
const tak = data[6];
let transportTypeDecoded;
switch (transportType) {
case 1:
transportTypeDecoded = "TROLL";
break;
case 2:
transportTypeDecoded = "BUS";
break;
case 3:
transportTypeDecoded = "TRAM";
break;
case 7:
transportTypeDecoded = "NIGHTBUS";
break;
default:
transportTypeDecoded = "Unknown";
break;
}
if (lineNumber == lineInput) {
let vehicleType;
if (transportTypeDecoded === "TRAM") {
if (cafTramTakArray.includes(tak)) {
vehicleType = "CAF Urbos AXL";
} else if (pesaTramTakArray.includes(tak)) {
vehicleType = "PESA Twist 147N";
} else if (kt6tmTramArray.includes(tak)) {
vehicleType = "Tatra KT6 TM";
} else if (kt4suTramArray.includes(tak)) {
vehicleType = "Tatra KT4 SU";
} else if (kt4tmrTramArray.includes(tak)) {
vehicleType = "Tatra KT4 TMR";
} else if (kt4dTramArray.includes(tak)) {
vehicleType = "Tatra KT4 D";
} else if (kt4tmTramArray.includes(tak)) {
vehicleType = "Tatra KT4 TM";
} else {
vehicleType = "-- Info unavailable --";
}
} else if (transportTypeDecoded === "BUS") {
if (electricBusTakArray.includes(tak)) {
vehicleType = "Solaris Urbino IV 12 Electric";
} else if (volvohybridTakArray.includes(tak)) {
vehicleType = "Volvo 7900 Hybrid";
} else if (a40TakArray.includes(tak)) {
vehicleType = "MAN a40";
} else if (a78TakArray.includes(tak)) {
vehicleType = "MAN a78";
} else if (a21TakArray.includes(tak)) {
vehicleType = "MAN a21";
} else if (urbino12array.includes(tak)) {
vehicleType = "Solaris URBINO 12 CNG";
} else if (urbino18array.includes(tak)) {
vehicleType = "Solaris URBINO 18 CNG";
} else {
vehicleType = "-- Info unavailable --";
}
} else {
vehicleType = "-- Info unavailable --";
}
results.push({
requestedType: transportTypeDecoded,
requestedLine: lineNumber,
requestedLat: latitude,
requestedLong: longitude,
requestedLatLong: `${latitude} ${longitude}`,
requestedTak: tak,
vehicleType,
});
}
} catch (error) {
console.log("Invalid data format!", line);
}
}
}
});
if (results.length > 0) {
results.forEach(result => {
console.log("[Data fetch complete!] Type:", result.requestedType, "Line number:", result.requestedLine, "Lat:", result.requestedLat, "Long:", result.requestedLong, "Coords merge:", result.requestedLatLong, "TAK:", result.requestedTak);
socket.emit('takResults', result.requestedType, result.requestedLine, result.requestedLat, result.requestedLong, result.requestedTak, result.requestedLatLong, result.vehicleType);
});
} else {
const vehicleNotFoundText = "VEHICLE NOT FOUND!";
console.log(vehicleNotFoundText);
socket.emit('takResults', vehicleNotFoundText, vehicleNotFoundText, vehicleNotFoundText, vehicleNotFoundText, vehicleNotFoundText, vehicleNotFoundText, vehicleNotFoundText);
}
} catch (error) {
console.error("Error reading local file:", error);
}
}
startPeriodicDataFetch();