import {findRemarks} from './find-remarks.js' // todo: c.conSubscr (e.g. `F`) // todo: c.trfRes x vbb-parse-ticket // todo: c.sotRating, c.isSotCon, c.sotCtxt // todo: c.showARSLink // todo: c.useableTime // todo: c.cksum (e.g. `b3a94228_3`), c.cksumDti (e.g. `c2717eb3_3`) // todo: c.isNotRdbl // todo: c.badSecRefX // todo: c.bfATS, c.bfIOSTS // todo: c.recState (e.g. `U`) // todo: c.intvlSubscr (e.g. `F`) const parseJourney = (ctx, j) => { // j = raw jouney const {profile, opt} = ctx const legs = [] for (const l of j.secL) { let date = j.date // Next-day DEVI legs in an overnight journey lack both // - the "01" prefix in {dep.d,arr.a}Time{S,R} and // - the jny.trainStartDate field. // However, we can use the previous leg's effective date. const prevLeg = legs[legs.length - 1] || null if (l.type === 'DEVI' && prevLeg?.arrival) { // todo: parse effective date from jny.ctxRecon/gis.ctx instead? // todo: prefer plannedArrival? date = [ prevLeg.arrival.slice(0, 4), // year prevLeg.arrival.slice(5, 7), // month prevLeg.arrival.slice(8, 10), // day ].join('') } const leg = profile.parseJourneyLeg(ctx, l, date) legs.push(leg) } const res = { type: 'journey', legs, refreshToken: (j.recon && j.recon.ctx) || j.ctxRecon || null } const freq = j.freq || {} if (freq.minC || freq.maxC) { res.cycle = {} if (freq.minC) res.cycle.min = freq.minC * 60 if (freq.maxC) res.cycle.max = freq.maxC * 60 // nr of connections in this frequency, from now on if (freq.numC) res.cycle.nr = freq.numC } if (opt.remarks && Array.isArray(j.msgL)) { res.remarks = findRemarks(j.msgL).map(([remark]) => remark) } if (opt.scheduledDays && j.sDays) { // todo [breaking]: rename to scheduledDates res.scheduledDays = profile.parseScheduledDays(ctx, j.sDays) } return res } export { parseJourney, }