-
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathgenerator.js
126 lines (121 loc) · 3.89 KB
/
generator.js
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
const dataFolder = './data/';
const defFolder = `${dataFolder}gen-timetables/`;
const timetableFolder = `${dataFolder}train-timetables/`;
const fs = require('fs');
const path = require('path');
const moment = require('moment');
const genTravelFromInterval = (travel) => {
const newTimes = [];
let clock = moment(travel.times[0].from, 'HH:mm');
for (let intervalKey = 0; intervalKey < travel.times.length; intervalKey++) {
const interval = travel.times[intervalKey];
do {
newTimes.push(clock.format('HH:mm'));
clock = clock.add(interval.interval, 'minute');
} while (clock < (interval.to.startsWith("00:") ? moment(interval.to, 'HH:mm').add(1, "day") : moment(interval.to, 'HH:mm')));
}
return newTimes;
};
const buildTimetable = (num, id, type, stations, exitTimeType, destination, startTime, vehicle, operator) => {
let nextKey = "nextIn";
if (destination === stations[0].station){
stations = stations.slice().reverse();
nextKey = "previousIn";
}
num = num.padStart(4, "0");
const timetable = {
"id": `${id}.${num}.${exitTimeType}`,
"t": `${id}.${num}`,
"r": id,
"n": num,
"y": type,
"o": operator,
"d": destination
.replace(/LinhaUni|ViaQuatro|ViaMobilidade|Metro|CPTM/g, 'SP')
.replace(`${id.split('.')[1]}.`, ''),
"os": [
stations[0].station
],
"ds": [
destination
],
"tt": []
};
let clock = moment(startTime, 'HH:mm');
for (const station of stations) {
if(station === stations[0]) {
timetable.tt.push({
"s": station.station,
"d": clock.format('HH:mm')
});
} else if (station === stations[stations.length - 1]) {
timetable.tt.push({
"s": station.station,
"a": clock.format('HH:mm')
});
} else {
timetable.tt.push({
"s": station.station,
"a": clock.format('HH:mm'),
"d": clock.clone().add(1, 'minute').format('HH:mm')
});
}
clock = clock.add(station[nextKey], 'minute');
}
if(vehicle) {
timetable["v"] = vehicle;
}
return timetable;
};
const processFile = (file) => {
const timetable = [];
const def = require(defFolder + file);
for (const [exitTimeKey, exitTime] of Object.entries(def.exitTimes)) {
if (typeof exitTime === "string") {
def.exitTimes[exitTimeKey] = def.exitTimes[exitTime];
}
for (const travel of def.exitTimes[exitTimeKey]) {
if (typeof travel.times[0] === "object") {
travel.times = genTravelFromInterval(travel);
}
for (const time of travel.times) {
timetable.push(
buildTimetable(
String(timetable.length),
def.railway,
def.type,
def.stations,
exitTimeKey,
travel.to,
time,
def.vehicle,
def.operator,
)
);
}
}
}
fs.writeFile(timetableFolder + file, JSON.stringify(timetable, null, 2), (err) => {
if (err) throw err;
console.log(`Write ${file} done.`);
});
};
if (!fs.existsSync(timetableFolder)){
fs.mkdirSync(timetableFolder);
}
if (process.argv[2]) {
try {
require(defFolder + process.argv[2]);
processFile(process.argv[2]);
} catch (_) {
console.log("Json not found");
}
} else {
fs.readdir(defFolder, (_, files) => {
files.forEach(file => {
if(path.extname(file) === '.json'){
processFile(file);
}
});
});
}