-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapp.js
More file actions
49 lines (37 loc) · 1.4 KB
/
app.js
File metadata and controls
49 lines (37 loc) · 1.4 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
var express = require("express");
var bodyParser = require("body-parser");
var app = express();
var fs = require("fs");
var Converter = require("csvtojson").Converter;
app.set('view engine', 'jade');
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
var routes = require("./routes/routes.js")(app);
var parsedRows = [];
var csvConverter = new Converter();
csvConverter.on("end_parsed", function (jsonObj) {
console.log("done parsing csv");
app.set('rawCfd', parsedRows);
var server = app.listen(3000, function () {
console.log("Listening on port %s...", server.address().port);
});
});
csvConverter.on("record_parsed", function(resultRow, rawRow, rowIndex) {
resultRow.Projection = 0;
var windowSizeInDays = 40;
if (rowIndex >= windowSizeInDays) {
var done = resultRow.Production;
var scope = resultRow.Scope;
var lastDone = parsedRows[rowIndex-windowSizeInDays].Production;
var delta = done - lastDone;
var perDay = delta / windowSizeInDays;
var remaining = scope - done;
if (perDay === 0) {
resultRow.Projection = parsedRows[rowIndex-1].Projection;
} else {
resultRow.Projection = Math.round(remaining / perDay);
}
}
parsedRows.push(resultRow);
});
fs.createReadStream(__dirname + "/lh-cfd.csv").pipe(csvConverter);