moment-timezone -> luxon, parse DateTimes with locale

This commit is contained in:
Jannis R 2017-12-11 17:21:50 +01:00
parent 130ffeccf9
commit 14cdc77c0f
No known key found for this signature in database
GPG key ID: 0FE83946296A88A5
11 changed files with 52 additions and 41 deletions

View file

@ -1,9 +1,12 @@
'use strict' 'use strict'
const moment = require('moment-timezone') const {DateTime} = require('luxon')
const formatDate = (profile, when) => { const formatDate = (profile, when) => {
return moment(when).tz(profile.timezone).format('YYYYMMDD') return DateTime.fromMillis(+when, {
locale: profile.locale,
zone: profile.timezone
}).toFormat('yyyyMMdd')
} }
module.exports = formatDate module.exports = formatDate

View file

@ -1,9 +1,12 @@
'use strict' 'use strict'
const moment = require('moment-timezone') const {DateTime} = require('luxon')
const formatTime = (profile, when) => { const formatTime = (profile, when) => {
return moment(when).tz(profile.timezone).format('HHmmss') return DateTime.fromMillis(+when, {
locale: profile.locale,
zone: profile.timezone
}).toFormat('HHmmss')
} }
module.exports = formatTime module.exports = formatTime

View file

@ -135,6 +135,7 @@ const formatProducts = (products) => {
// todo: find option for absolute number of results // todo: find option for absolute number of results
const dbProfile = { const dbProfile = {
locale: 'de-DE',
timezone: 'Europe/Berlin', timezone: 'Europe/Berlin',
endpoint: 'https://reiseauskunft.bahn.de/bin/mgate.exe', endpoint: 'https://reiseauskunft.bahn.de/bin/mgate.exe',
transformReqBody, transformReqBody,

View file

@ -116,6 +116,7 @@ const formatProducts = (products) => {
} }
const vbbProfile = { const vbbProfile = {
locale: 'de-DE',
timezone: 'Europe/Berlin', timezone: 'Europe/Berlin',
endpoint: 'https://fahrinfo.vbb.de/bin/mgate.exe', endpoint: 'https://fahrinfo.vbb.de/bin/mgate.exe',
transformReqBody, transformReqBody,

View file

@ -29,7 +29,7 @@
"dependencies": { "dependencies": {
"fetch-ponyfill": "^4.1.0", "fetch-ponyfill": "^4.1.0",
"lodash": "^4.17.4", "lodash": "^4.17.4",
"moment-timezone": "^0.5.13", "luxon": "^0.2.7",
"pinkie-promise": "^2.0.1", "pinkie-promise": "^2.0.1",
"query-string": "^5.0.0", "query-string": "^5.0.0",
"slugg": "^1.2.0", "slugg": "^1.2.0",
@ -41,7 +41,6 @@
"co": "^4.6.0", "co": "^4.6.0",
"db-stations": "^1.25.0", "db-stations": "^1.25.0",
"is-roughly-equal": "^0.1.0", "is-roughly-equal": "^0.1.0",
"luxon": "^0.2.7",
"tap-spec": "^4.1.1", "tap-spec": "^4.1.1",
"tape": "^4.8.0", "tape": "^4.8.0",
"tape-promise": "^2.0.1", "tape-promise": "^2.0.1",

View file

@ -1,16 +1,28 @@
'use strict' 'use strict'
const moment = require('moment-timezone') const {DateTime} = require('luxon')
const parseDateTime = (timezone, date, time) => { const validDate = /^(\d{4})-(\d{2})-(\d{2})$/
let offset = 0 // in days
if (time.length > 6) { const parseDateTime = (profile, date, time) => {
offset = +time.slice(0, -6) const pDate = [date.substr(-8, 4), date.substr(-4, 2), date.substr(-2, 2)]
time = time.slice(-6) if (!pDate[0] || !pDate[1] || !pDate[2]) {
throw new Error('invalid date format: ' + date)
} }
return moment.tz(date + 'T' + time, timezone) const pTime = [time.substr(-6, 2), time.substr(-4, 2), time.substr(-2, 2)]
.add(offset, 'days') if (!pTime[0] || !pTime[1] || !pTime[2]) {
throw new Error('invalid time format: ' + time)
}
const offset = time.length > 6 ? parseInt(time.slice(0, -6)) : 0
console.error(pDate, pTime, offset)
const dt = DateTime.fromISO(pDate.join('-') + 'T' + pTime.join(':'), {
locale: profile.locale,
zone: profile.timezone
})
return offset > 0 ? dt.plus({days: offset}) : dt
} }
module.exports = parseDateTime module.exports = parseDateTime

View file

@ -8,11 +8,10 @@
// todo: d.freq, d.freq.jnyL, see https://github.com/derhuerst/hafas-client/blob/9203ed1481f08baacca41ac5e3c19bf022f01b0b/parse.js#L115 // todo: d.freq, d.freq.jnyL, see https://github.com/derhuerst/hafas-client/blob/9203ed1481f08baacca41ac5e3c19bf022f01b0b/parse.js#L115
const createParseDeparture = (profile, stations, lines, remarks) => { const createParseDeparture = (profile, stations, lines, remarks) => {
const tz = profile.timezone
const findRemark = rm => remarks[parseInt(rm.remX)] || null const findRemark = rm => remarks[parseInt(rm.remX)] || null
const parseDeparture = (d) => { const parseDeparture = (d) => {
const when = profile.parseDateTime(tz, d.date, d.stbStop.dTimeR || d.stbStop.dTimeS) const when = profile.parseDateTime(profile, d.date, d.stbStop.dTimeR || d.stbStop.dTimeS)
const res = { const res = {
journeyId: d.jid, journeyId: d.jid,
station: stations[parseInt(d.stbStop.locX)] || null, station: stations[parseInt(d.stbStop.locX)] || null,
@ -24,8 +23,8 @@ const createParseDeparture = (profile, stations, lines, remarks) => {
} }
if (d.stbStop.dTimeR && d.stbStop.dTimeS) { if (d.stbStop.dTimeR && d.stbStop.dTimeS) {
const realtime = profile.parseDateTime(tz, d.date, d.stbStop.dTimeR) const realtime = profile.parseDateTime(profile, d.date, d.stbStop.dTimeR)
const planned = profile.parseDateTime(tz, d.date, d.stbStop.dTimeS) const planned = profile.parseDateTime(profile, d.date, d.stbStop.dTimeS)
res.delay = Math.round((realtime - planned) / 1000) res.delay = Math.round((realtime - planned) / 1000)
} else res.delay = null } else res.delay = null

View file

@ -5,19 +5,17 @@ const parseDateTime = require('./date-time')
const clone = obj => Object.assign({}, obj) const clone = obj => Object.assign({}, obj)
const createParseJourneyPart = (profile, stations, lines, remarks) => { const createParseJourneyPart = (profile, stations, lines, remarks) => {
const tz = profile.timezone
const parseStopover = (j, st) => { const parseStopover = (j, st) => {
const res = { const res = {
station: stations[parseInt(st.locX)] station: stations[parseInt(st.locX)]
} }
if (st.aTimeR || st.aTimeS) { if (st.aTimeR || st.aTimeS) {
const arr = parseDateTime(tz, j.date, st.aTimeR || st.aTimeS) const arr = parseDateTime(profile, j.date, st.aTimeR || st.aTimeS)
res.arrival = arr.format() res.arrival = arr.toISO()
} }
if (st.dTimeR || st.dTimeS) { if (st.dTimeR || st.dTimeS) {
const dep = parseDateTime(tz, j.date, st.dTimeR || st.dTimeS) const dep = parseDateTime(profile, j.date, st.dTimeR || st.dTimeS)
res.departure = dep.format() res.departure = dep.toISO()
} }
return res return res
@ -31,18 +29,18 @@ const createParseJourneyPart = (profile, stations, lines, remarks) => {
// todo: what is pt.jny.dirFlg? // todo: what is pt.jny.dirFlg?
// todo: how does pt.freq work? // todo: how does pt.freq work?
const parseJourneyPart = (j, pt) => { // j = journey, pt = part const parseJourneyPart = (j, pt) => { // j = journey, pt = part
const dep = profile.parseDateTime(tz, j.date, pt.dep.dTimeR || pt.dep.dTimeS) const dep = profile.parseDateTime(profile, j.date, pt.dep.dTimeR || pt.dep.dTimeS)
const arr = profile.parseDateTime(tz, j.date, pt.arr.aTimeR || pt.arr.aTimeS) const arr = profile.parseDateTime(profile, j.date, pt.arr.aTimeR || pt.arr.aTimeS)
const res = { const res = {
origin: clone(stations[parseInt(pt.dep.locX)]) || null, origin: clone(stations[parseInt(pt.dep.locX)]) || null,
destination: clone(stations[parseInt(pt.arr.locX)]), destination: clone(stations[parseInt(pt.arr.locX)]),
departure: dep.format(), departure: dep.toISO(),
arrival: arr.format() arrival: arr.toISO()
} }
if (pt.dep.dTimeR && pt.dep.dTimeS) { if (pt.dep.dTimeR && pt.dep.dTimeS) {
const realtime = profile.parseDateTime(tz, j.date, pt.dep.dTimeR) const realtime = profile.parseDateTime(profile, j.date, pt.dep.dTimeR)
const planned = profile.parseDateTime(tz, j.date, pt.dep.dTimeS) const planned = profile.parseDateTime(profile, j.date, pt.dep.dTimeS)
res.delay = Math.round((realtime - planned) / 1000) res.delay = Math.round((realtime - planned) / 1000)
} }
@ -66,10 +64,10 @@ const createParseJourneyPart = (profile, stations, lines, remarks) => {
if (pt.jny.freq && pt.jny.freq.jnyL) { if (pt.jny.freq && pt.jny.freq.jnyL) {
const parseAlternative = (a) => { const parseAlternative = (a) => {
// todo: realtime // todo: realtime
const when = profile.parseDateTime(tz, j.date, a.stopL[0].dTimeS) const when = profile.parseDateTime(profile, j.date, a.stopL[0].dTimeS)
return { return {
line: lines[parseInt(a.prodX)] || null, line: lines[parseInt(a.prodX)] || null,
when: when.format() when: when.toISO()
} }
} }
res.alternatives = pt.jny.freq.jnyL res.alternatives = pt.jny.freq.jnyL

View file

@ -1,6 +1,5 @@
'use strict' 'use strict'
const parseDateTime = require('./date-time')
const createParseJourneyPart = require('./journey-part') const createParseJourneyPart = require('./journey-part')
const clone = obj => Object.assign({}, obj) const clone = obj => Object.assign({}, obj)

View file

@ -1,8 +1,6 @@
'use strict' 'use strict'
const createParseMovement = (profile, locations, lines, remarks) => { const createParseMovement = (profile, locations, lines, remarks) => {
const tz = profile.timezone
// todo: what is m.dirGeo? maybe the speed? // todo: what is m.dirGeo? maybe the speed?
// todo: what is m.stopL? // todo: what is m.stopL?
// todo: what is m.proc? wut? // todo: what is m.proc? wut?
@ -13,10 +11,10 @@ const createParseMovement = (profile, locations, lines, remarks) => {
const parseMovement = (m) => { const parseMovement = (m) => {
const parseNextStop = (s) => { const parseNextStop = (s) => {
const dep = s.dTimeR || s.dTimeS const dep = s.dTimeR || s.dTimeS
? profile.parseDateTime(tz, m.date, s.dTimeR || s.dTimeS) ? profile.parseDateTime(profile, m.date, s.dTimeR || s.dTimeS)
: null : null
const arr = s.aTimeR || s.aTimeS const arr = s.aTimeR || s.aTimeS
? profile.parseDateTime(tz, m.date, s.aTimeR || s.aTimeS) ? profile.parseDateTime(profile, m.date, s.aTimeR || s.aTimeS)
: null : null
return { return {

View file

@ -1,18 +1,16 @@
'use strict' 'use strict'
const createParseStopover = (profile, stations, lines, remarks, connection) => { const createParseStopover = (profile, stations, lines, remarks, connection) => {
const tz = profile.timezone
const parseStopover = (st) => { const parseStopover = (st) => {
const res = { const res = {
station: stations[parseInt(st.locX)] || null station: stations[parseInt(st.locX)] || null
} }
if (st.aTimeR || st.aTimeS) { if (st.aTimeR || st.aTimeS) {
const arr = profile.parseDateTime(tz, connection.date, st.aTimeR || st.aTimeS) const arr = profile.parseDateTime(profile, connection.date, st.aTimeR || st.aTimeS)
res.arrival = arr.format() res.arrival = arr.format()
} }
if (st.dTimeR || st.dTimeS) { if (st.dTimeR || st.dTimeS) {
const dep = profile.parseDateTime(tz, connection.date, st.dTimeR || st.dTimeS) const dep = profile.parseDateTime(profile, connection.date, st.dTimeR || st.dTimeS)
res.departure = dep.format() res.departure = dep.format()
} }
return res return res