Merge branch 'master' of github.com:F1Vis/f1vis
This commit is contained in:
commit
654a45cbb1
@ -88,6 +88,7 @@
|
||||
<script type="text/javascript" src="js/d3/d3.min.js"></script>
|
||||
<script type="text/javascript" src="js/util.js"></script>
|
||||
<script type="text/javascript" src="js/preprocessor.js"></script>
|
||||
<script type="text/javascript" src="js/processor.js"></script>
|
||||
<script type="text/javascript" src="js/queries.js"></script>
|
||||
<script type="text/javascript" src="js/diagrams.js"></script>
|
||||
<script type="text/javascript" src="js/main.js"></script>
|
||||
|
22
js/processor.js
Normal file
22
js/processor.js
Normal file
@ -0,0 +1,22 @@
|
||||
"use strict";
|
||||
|
||||
var processor = {
|
||||
|
||||
getRace: function(raceId) {
|
||||
var race = {
|
||||
drivers: null,
|
||||
lapTimes: null,
|
||||
pitStops: null,
|
||||
qualifying: null,
|
||||
results: null
|
||||
};
|
||||
|
||||
race.drivers = queries.getDriversByRaceId(raceId);
|
||||
race.lapTimes = queries.getLapDataByRaceId(raceId);
|
||||
race.qualifying = queries.getQualifingDataByRaceId(raceId);
|
||||
race.pitStops = queries.getPitStopsByRaceId(raceId);
|
||||
race.results = queries.getResultsByRaceId(raceId);
|
||||
|
||||
return race;
|
||||
},
|
||||
};
|
@ -40,33 +40,57 @@ var queries = {
|
||||
|
||||
getDriverById: function(driverId) {
|
||||
var rawData = preprocessor.getResults();
|
||||
|
||||
var result = null;
|
||||
|
||||
var tempList = rawData.drivers.filter((cur) => (cur.driverId == driverId));
|
||||
if(tempList.length > 0){
|
||||
result = tempList[0];
|
||||
}
|
||||
|
||||
// Return d3 dataset
|
||||
return result;
|
||||
return rawData.drivers[driverId];
|
||||
},
|
||||
|
||||
getDriversByRaceId: function(raceId) {
|
||||
var rawData = preprocessor.getResults();
|
||||
|
||||
var result = queries.getResultsByRaceId(raceId).map((cur) => queries.getDriverById(cur.driverId));
|
||||
|
||||
var tempList = rawData.results.filter((cur) => (cur.raceId == raceId));
|
||||
|
||||
var result = tempList.map((cur) => queries.getDriverById(cur.driverId));
|
||||
|
||||
// Return d3 dataset
|
||||
return result;
|
||||
},
|
||||
|
||||
getResultsByRaceId: function(raceId) {
|
||||
var rawData = preprocessor.getResults();
|
||||
|
||||
var tempList = [];
|
||||
for(var key in rawData.results){
|
||||
if(rawData.results[key].raceId == raceId){
|
||||
tempList.push(rawData.results[key]);
|
||||
}
|
||||
}
|
||||
|
||||
tempList.sort((o1,o2) => o1["positionOrder"] - o2["positionOrder"]);
|
||||
|
||||
return tempList;
|
||||
},
|
||||
|
||||
getPitStopsByRaceId: function(raceId) {
|
||||
var rawData = preprocessor.getResults();
|
||||
|
||||
var tempList = [];
|
||||
for(var key in rawData.pitStops){
|
||||
if(rawData.pitStops[key].raceId == raceId){
|
||||
tempList.push(rawData.pitStops[key]);
|
||||
}
|
||||
}
|
||||
|
||||
//var tempList = rawData.pitStops.filter(cur => cur.raceId == raceId);
|
||||
|
||||
return tempList;
|
||||
},
|
||||
|
||||
getLapDataByRaceId: function(raceId) {
|
||||
var rawData = preprocessor.getResults();
|
||||
var lapTimes = rawData['lapTimes'].filter((val) => val['raceId'] == raceId);
|
||||
|
||||
var lapTimes = [];
|
||||
for(var key in rawData.lapTimes){
|
||||
if(rawData.lapTimes[key].raceId == raceId){
|
||||
lapTimes.push(rawData.lapTimes[key]);
|
||||
}
|
||||
}
|
||||
|
||||
var myMap = new Map();
|
||||
lapTimes.forEach(function(d,i) {
|
||||
var lapNum = d["lap"];
|
||||
@ -87,9 +111,16 @@ var queries = {
|
||||
|
||||
getQualifingDataByRaceId: function(raceId) {
|
||||
var rawData = preprocessor.getResults();
|
||||
var result = rawData.qualifying.filter((cur) => (cur.raceId == raceId));
|
||||
result.sort((o1,o2) => o1["position"] - o2["position"]);
|
||||
return result;
|
||||
|
||||
var qualifingData = [];
|
||||
for(var key in rawData.qualifying){
|
||||
if(rawData.qualifying[key].raceId == raceId){
|
||||
qualifingData.push(rawData.qualifying[key]);
|
||||
}
|
||||
}
|
||||
//var result = rawData.qualifying.filter((cur) => (cur.raceId == raceId));
|
||||
qualifingData.sort((o1,o2) => o1["position"] - o2["position"]);
|
||||
return qualifingData;
|
||||
}
|
||||
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user