mobility-toolbox-js 2.0.0 → 2.0.1-beta.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/api/RoutingAPI.js +15 -0
- package/api/RoutingAPI.test.js +25 -0
- package/api/StopsAPI.js +12 -0
- package/api/StopsAPI.test.js +22 -0
- package/api/TralisAPI.js +359 -0
- package/api/TralisAPI.test.js +67 -0
- package/api/{tralis/TralisAPIUtils.js → TralisAPIUtils.js} +2 -32
- package/api/index.js +3 -3
- package/{ol/README.md → api/typedefs.js} +0 -0
- package/common/Tracker.js +14 -118
- package/common/api/HttpAPI.js +30 -0
- package/common/api/HttpAPI.test.js +50 -0
- package/common/api/WebSocketAPI.js +175 -0
- package/{api/tralis/WebSocketConnector.test.js → common/api/WebSocketAPI.test.js} +100 -145
- package/common/controls/Control.js +26 -91
- package/common/controls/Control.test.js +32 -43
- package/common/index.js +4 -0
- package/common/layers/Layer.js +53 -244
- package/common/layers/Layer.test.js +185 -244
- package/common/mixins/CopyrightMixin.js +20 -44
- package/common/mixins/SearchMixin.js +100 -166
- package/common/mixins/TralisLayerMixin.js +443 -894
- package/common/styles/index.js +4 -4
- package/common/styles/trackerDefaultStyle.js +39 -175
- package/common/styles/trackerDelayStyle.js +2 -11
- package/common/styles/trackerSimpleStyle.js +4 -8
- package/common/trackerConfig.js +61 -99
- package/common/trackerConfig.test.js +15 -17
- package/common/typedefs.js +0 -23
- package/common/utils/createTrackerFilters.js +10 -41
- package/common/utils/createTrackerFilters.test.js +40 -56
- package/common/utils/getMapboxMapCopyrights.js +3 -16
- package/common/utils/getMapboxMapCopyrights.test.js +32 -39
- package/common/utils/getMapboxStyleUrl.js +3 -13
- package/common/utils/getVehiclePosition.js +3 -33
- package/common/utils/index.js +5 -6
- package/common/utils/removeDuplicate.js +3 -17
- package/common/utils/removeDuplicate.test.js +17 -20
- package/common/utils/sortByDelay.js +2 -7
- package/common/utils/timeUtils.js +8 -32
- package/common/utils/timeUtils.test.js +7 -13
- package/index.js +8 -2
- package/mapbox/controls/CopyrightControl.js +9 -38
- package/mapbox/controls/index.js +1 -0
- package/mapbox/index.js +4 -3
- package/mapbox/layers/Layer.js +15 -76
- package/mapbox/layers/Layer.test.js +81 -101
- package/mapbox/layers/TralisLayer.js +46 -193
- package/mapbox/layers/TralisLayer.test.js +12 -14
- package/mapbox/layers/index.js +2 -0
- package/mapbox/utils.js +7 -21
- package/mbt.js +50444 -0
- package/mbt.js.map +7 -0
- package/mbt.min.js +1005 -0
- package/mbt.min.js.map +7 -0
- package/ol/controls/CopyrightControl.js +8 -46
- package/ol/controls/CopyrightControl.test.js +75 -121
- package/ol/controls/RoutingControl.js +167 -532
- package/ol/controls/RoutingControl.test.js +99 -164
- package/ol/controls/StopFinderControl.js +3 -31
- package/ol/controls/StopFinderControl.test.js +18 -29
- package/ol/controls/index.js +3 -0
- package/ol/index.js +5 -13
- package/ol/layers/Layer.js +23 -128
- package/ol/layers/Layer.test.js +79 -102
- package/ol/layers/MapboxLayer.js +62 -237
- package/ol/layers/MapboxLayer.test.js +58 -84
- package/ol/layers/MapboxStyleLayer.js +38 -268
- package/ol/layers/MapboxStyleLayer.test.js +97 -128
- package/ol/layers/MaplibreLayer.js +46 -187
- package/ol/layers/RoutingLayer.js +21 -51
- package/ol/layers/RoutingLayer.test.js +15 -24
- package/ol/layers/TralisLayer.js +102 -276
- package/ol/layers/TralisLayer.test.js +32 -50
- package/ol/layers/VectorLayer.js +3 -24
- package/ol/layers/VectorLayer.test.js +34 -45
- package/ol/layers/WMSLayer.js +15 -57
- package/ol/layers/WMSLayer.test.js +35 -43
- package/ol/layers/index.js +8 -0
- package/ol/styles/fullTrajectoryDelayStyle.js +11 -15
- package/ol/styles/fullTrajectoryStyle.js +17 -25
- package/ol/styles/index.js +2 -2
- package/package.json +35 -62
- package/api/routing/RoutingAPI.js +0 -44
- package/api/routing/RoutingAPI.test.js +0 -41
- package/api/stops/StopsAPI.js +0 -41
- package/api/stops/StopsAPI.test.js +0 -34
- package/api/tralis/TralisAPI.js +0 -731
- package/api/tralis/TralisAPI.test.js +0 -75
- package/api/tralis/WebSocketConnector.js +0 -338
- package/api/tralis/typedefs.js +0 -81
- package/common/api/api.js +0 -64
- package/common/api/api.test.js +0 -68
- package/index.js.map +0 -1
- package/module.js +0 -23
- package/ol/controls/snapshots/RoutingControlRouteGen10.json +0 -58
- package/ol/controls/snapshots/RoutingControlRouteGen100.json +0 -292
- package/ol/controls/snapshots/RoutingControlRouteGen30.json +0 -69
- package/ol/controls/snapshots/RoutingControlRouteGen5.json +0 -58
- package/ol/controls/snapshots/RoutingControlRouteOSM.json +0 -759
- package/ol/controls/snapshots/RoutingControlStation1.json +0 -60
- package/ol/controls/snapshots/RoutingControlStation2.json +0 -49
package/api/tralis/TralisAPI.js
DELETED
|
@@ -1,731 +0,0 @@
|
|
|
1
|
-
import WebSocketConnector from './WebSocketConnector';
|
|
2
|
-
import {
|
|
3
|
-
getModeSuffix,
|
|
4
|
-
cleanStopTime,
|
|
5
|
-
compareDepartures,
|
|
6
|
-
} from './TralisAPIUtils';
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* Enum for Tralis modes.
|
|
10
|
-
* @readonly
|
|
11
|
-
* @typedef {string} TralisMode
|
|
12
|
-
* @property {string} RAW "raw"
|
|
13
|
-
* @property {string} SCHEMATIC "schematic"
|
|
14
|
-
* @property {string} TOPOGRAPHIC "topographic"
|
|
15
|
-
* @enum {TralisMode}
|
|
16
|
-
*/
|
|
17
|
-
export const TralisModes = {
|
|
18
|
-
RAW: 'raw',
|
|
19
|
-
TOPOGRAPHIC: 'topographic',
|
|
20
|
-
SCHEMATIC: 'schematic',
|
|
21
|
-
};
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* This class provides convenience methods to access to the [geOps realtime api](https://developer.geops.io/apis/realtime/).
|
|
25
|
-
*
|
|
26
|
-
* @example
|
|
27
|
-
* import { TralisAPI } from 'mobility-toolbox-js/api';
|
|
28
|
-
*
|
|
29
|
-
* const api = new TralisAPI({
|
|
30
|
-
* url: "yourUrl",
|
|
31
|
-
* apiKey: "yourApiKey"
|
|
32
|
-
* });
|
|
33
|
-
*
|
|
34
|
-
* @example
|
|
35
|
-
* import { TralisAPI } from 'mobility-toolbox-js/api';
|
|
36
|
-
*
|
|
37
|
-
* const api = new TralisAPI("yourUrl");
|
|
38
|
-
*/
|
|
39
|
-
class TralisAPI {
|
|
40
|
-
/**
|
|
41
|
-
* Constructor
|
|
42
|
-
*
|
|
43
|
-
* @param {Object|string} options A string representing the url of the service or an object containing the url and the apiKey.
|
|
44
|
-
* @param {string} options.url Url to the [geOps realtime api](https://developer.geops.io/apis/realtime/).
|
|
45
|
-
* @param {string} options.apiKey Access key for [geOps apis](https://developer.geops.io/).
|
|
46
|
-
* @param {string} [options.prefix=''] Service prefix to specify tenant.
|
|
47
|
-
* @param {string} [options.projection] The epsg code of the projection for features. Default to EPSG:3857.
|
|
48
|
-
* @param {number[4]} [options.bbox=[minX, minY, maxX, maxY, zoom, tenant] The bounding box to receive data from.
|
|
49
|
-
*/
|
|
50
|
-
constructor(options = {}) {
|
|
51
|
-
this.defineProperties(options);
|
|
52
|
-
|
|
53
|
-
/** @ignore */
|
|
54
|
-
this.subscribedStationUic = null;
|
|
55
|
-
|
|
56
|
-
/** @ignore */
|
|
57
|
-
this.departureUpdateTimeout = null;
|
|
58
|
-
|
|
59
|
-
/** @ignore */
|
|
60
|
-
this.maxDepartureAge = 30;
|
|
61
|
-
|
|
62
|
-
/** @ignore */
|
|
63
|
-
this.extraGeoms = {};
|
|
64
|
-
|
|
65
|
-
/** @ignore */
|
|
66
|
-
this.prefix = options.prefix || '';
|
|
67
|
-
|
|
68
|
-
/** @ignore */
|
|
69
|
-
this.onOpen = this.onOpen.bind(this);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
defineProperties(options) {
|
|
73
|
-
let opt = options;
|
|
74
|
-
|
|
75
|
-
if (typeof options === 'string') {
|
|
76
|
-
opt = { url: options };
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
const { apiKey } = opt;
|
|
80
|
-
let { url, projection, bbox, buffer = [100, 100] } = opt;
|
|
81
|
-
const conn = new WebSocketConnector();
|
|
82
|
-
|
|
83
|
-
if (apiKey) {
|
|
84
|
-
url = `${url || 'wss://api.geops.io/tracker-ws/v1/'}?key=${apiKey}`;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
Object.defineProperties(this, {
|
|
88
|
-
url: {
|
|
89
|
-
get: () => url,
|
|
90
|
-
set: (newUrl) => {
|
|
91
|
-
url = newUrl;
|
|
92
|
-
this.open();
|
|
93
|
-
},
|
|
94
|
-
},
|
|
95
|
-
projection: {
|
|
96
|
-
get: () => projection,
|
|
97
|
-
set: (newProjection) => {
|
|
98
|
-
if (newProjection !== projection) {
|
|
99
|
-
projection = newProjection;
|
|
100
|
-
if (this.conn) {
|
|
101
|
-
this.conn.send(`PROJECTION ${projection}`);
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
},
|
|
105
|
-
},
|
|
106
|
-
bbox: {
|
|
107
|
-
get: () => bbox,
|
|
108
|
-
set: (newBbox) => {
|
|
109
|
-
if (JSON.stringify(newBbox) !== JSON.stringify(bbox)) {
|
|
110
|
-
bbox = newBbox;
|
|
111
|
-
if (this.conn) {
|
|
112
|
-
this.conn.send(`BBOX ${bbox.join(' ')}`);
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
},
|
|
116
|
-
},
|
|
117
|
-
buffer: {
|
|
118
|
-
get: () => buffer,
|
|
119
|
-
set: (newBuffer) => {
|
|
120
|
-
if (JSON.stringify(newBuffer) !== JSON.stringify(buffer)) {
|
|
121
|
-
buffer = newBuffer;
|
|
122
|
-
if (this.conn) {
|
|
123
|
-
this.conn.send(`BUFFER ${buffer.join(' ')}`);
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
},
|
|
127
|
-
},
|
|
128
|
-
/**
|
|
129
|
-
* The websocket helper class to connect the websocket.
|
|
130
|
-
*
|
|
131
|
-
* @private
|
|
132
|
-
*/
|
|
133
|
-
conn: {
|
|
134
|
-
value: conn,
|
|
135
|
-
writable: true,
|
|
136
|
-
},
|
|
137
|
-
/**
|
|
138
|
-
* Interval between PING request in ms.
|
|
139
|
-
* If equal to 0, no PING request are sent.
|
|
140
|
-
* @type {number}
|
|
141
|
-
* @private
|
|
142
|
-
*/
|
|
143
|
-
pingIntervalMs: {
|
|
144
|
-
value: options.pingIntervalMs || 10000,
|
|
145
|
-
writable: true,
|
|
146
|
-
},
|
|
147
|
-
/**
|
|
148
|
-
* Timeout in ms after an automatic reconnection when the websoscket has been closed by the server.
|
|
149
|
-
* @type {number}
|
|
150
|
-
*/
|
|
151
|
-
reconnectTimeoutMs: {
|
|
152
|
-
value: options.pingIntervalMs || 100,
|
|
153
|
-
writable: true,
|
|
154
|
-
},
|
|
155
|
-
});
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
open() {
|
|
159
|
-
this.close();
|
|
160
|
-
// Register BBOX and PROJECTION messages must be send before previous subscriptions.
|
|
161
|
-
this.conn.connect(this.url, this.onOpen);
|
|
162
|
-
|
|
163
|
-
// Register reconnection on close.
|
|
164
|
-
this.conn.websocket.onclose = () => {
|
|
165
|
-
this.onClose();
|
|
166
|
-
};
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
/**
|
|
170
|
-
* Close the websocket connection without reconnection.
|
|
171
|
-
*/
|
|
172
|
-
close() {
|
|
173
|
-
this.conn.close();
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
/**
|
|
177
|
-
* Unsubscribe trajectory and deleted_vehicles channels. To resubscribe you have to set a new BBOX.
|
|
178
|
-
*/
|
|
179
|
-
// eslint-disable-next-line class-methods-use-this
|
|
180
|
-
reset() {
|
|
181
|
-
this.conn.send('RESET');
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
/**
|
|
185
|
-
* Callback when the websocket is opened and ready.
|
|
186
|
-
* It applies the bbox and the projection.
|
|
187
|
-
*/
|
|
188
|
-
onOpen() {
|
|
189
|
-
if (this.projection) {
|
|
190
|
-
this.conn.send(`PROJECTION ${this.projection}`);
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
if (this.bbox) {
|
|
194
|
-
this.conn.send(`BBOX ${this.bbox.join(' ')}`);
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
if (this.buffer) {
|
|
198
|
-
this.conn.send(`BUFFER ${this.buffer.join(' ')}`);
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
/**
|
|
202
|
-
* Keep websocket alive
|
|
203
|
-
*/
|
|
204
|
-
if (this.pingIntervalMs) {
|
|
205
|
-
window.clearInterval(this.pingInterval);
|
|
206
|
-
/** @ignore */
|
|
207
|
-
this.pingInterval = setInterval(() => {
|
|
208
|
-
this.conn.send('PING');
|
|
209
|
-
}, this.pingIntervalMs);
|
|
210
|
-
}
|
|
211
|
-
}
|
|
212
|
-
|
|
213
|
-
/**
|
|
214
|
-
* Callback when the websocket is closed by the server.
|
|
215
|
-
* It auto reconnects after a timeout.
|
|
216
|
-
*/
|
|
217
|
-
onClose() {
|
|
218
|
-
window.clearTimeout(this.pingInterval);
|
|
219
|
-
window.clearTimeout(this.reconnectTimeout);
|
|
220
|
-
|
|
221
|
-
if (this.reconnectTimeoutMs) {
|
|
222
|
-
/** @ignore */
|
|
223
|
-
this.reconnectTimeout = window.setTimeout(
|
|
224
|
-
() => this.open(),
|
|
225
|
-
this.reconnectTimeoutMs,
|
|
226
|
-
);
|
|
227
|
-
}
|
|
228
|
-
}
|
|
229
|
-
|
|
230
|
-
/**
|
|
231
|
-
* Subscribe to a channel.
|
|
232
|
-
*
|
|
233
|
-
* @param {string} channel Name of the websocket channel to subscribe.
|
|
234
|
-
* @param {function} onSuccess Callback when the subscription succeeds.
|
|
235
|
-
* @param {function} onError Callback when the subscription fails.
|
|
236
|
-
* @param {boolean} [quiet=false] If true avoid to store the subscription in the subscriptions list.
|
|
237
|
-
* @private
|
|
238
|
-
*/
|
|
239
|
-
subscribe(channel, onSuccess, onError, quiet = false) {
|
|
240
|
-
this.conn.subscribe({ channel }, onSuccess, onError, quiet);
|
|
241
|
-
}
|
|
242
|
-
|
|
243
|
-
/**
|
|
244
|
-
* Unsubscribe both modes of a channel.
|
|
245
|
-
*
|
|
246
|
-
* @param {string} channel Name of the websocket channel to unsubscribe.
|
|
247
|
-
* @param {string} suffix Suffix to add to the channel name.
|
|
248
|
-
* @param {function} cb Callback function to unsubscribe. If null all subscriptions for the channel will be unsubscribed.
|
|
249
|
-
* @private
|
|
250
|
-
*/
|
|
251
|
-
unsubscribe(channel, suffix, cb) {
|
|
252
|
-
this.conn.unsubscribe(
|
|
253
|
-
`${channel}${getModeSuffix(TralisModes.SCHEMATIC, TralisModes)}${suffix}`,
|
|
254
|
-
cb,
|
|
255
|
-
);
|
|
256
|
-
this.conn.unsubscribe(
|
|
257
|
-
`${channel}${getModeSuffix(TralisModes.TOPOGRAPHIC, TralisModes)}${
|
|
258
|
-
suffix || ''
|
|
259
|
-
}`,
|
|
260
|
-
cb,
|
|
261
|
-
);
|
|
262
|
-
}
|
|
263
|
-
|
|
264
|
-
/**
|
|
265
|
-
* Filter departures and return an array.
|
|
266
|
-
*
|
|
267
|
-
* @param {Object} depObject The object containing departures by id.
|
|
268
|
-
* @param {boolean} [sortByMinArrivalTime=false] If true sort departures by arrival time.
|
|
269
|
-
* @return {Array<departure>} Return departures array.
|
|
270
|
-
* @private
|
|
271
|
-
*/
|
|
272
|
-
filterDepartures(depObject, sortByMinArrivalTime = false) {
|
|
273
|
-
const departures = Object.keys(depObject).map((k) => depObject[k]);
|
|
274
|
-
departures.sort((a, b) => compareDepartures(a, b, sortByMinArrivalTime));
|
|
275
|
-
|
|
276
|
-
let future = new Date();
|
|
277
|
-
future.setMinutes(future.getMinutes() + this.maxDepartureAge);
|
|
278
|
-
future = future.getTime();
|
|
279
|
-
|
|
280
|
-
let past = new Date();
|
|
281
|
-
past.setMinutes(past.getMinutes() - this.maxDepartureAge);
|
|
282
|
-
past = past.getTime();
|
|
283
|
-
|
|
284
|
-
const departureArray = [];
|
|
285
|
-
const platformsBoarding = [];
|
|
286
|
-
let previousDeparture = null;
|
|
287
|
-
|
|
288
|
-
for (let i = departures.length - 1; i >= 0; i -= 1) {
|
|
289
|
-
const d = departures[i];
|
|
290
|
-
const t = new Date(d.time).getTime();
|
|
291
|
-
|
|
292
|
-
// Only show departures within the next 30 minutes
|
|
293
|
-
if (t > past && t < future) {
|
|
294
|
-
// If 2 trains are boarding at the same platform,
|
|
295
|
-
// remove the older one.
|
|
296
|
-
if (d.state === 'BOARDING') {
|
|
297
|
-
if (platformsBoarding.indexOf(d.platform) === -1) {
|
|
298
|
-
platformsBoarding.push(d.platform);
|
|
299
|
-
} else {
|
|
300
|
-
d.state = 'HIDDEN';
|
|
301
|
-
}
|
|
302
|
-
}
|
|
303
|
-
|
|
304
|
-
// If two trains with the same line number and destinatin
|
|
305
|
-
// and a departure difference < 1 minute, hide the second one.
|
|
306
|
-
if (
|
|
307
|
-
previousDeparture &&
|
|
308
|
-
d.to[0] === previousDeparture.to[0] &&
|
|
309
|
-
Math.abs(t - previousDeparture.time) < 1000 &&
|
|
310
|
-
d.line.name === previousDeparture.line.name
|
|
311
|
-
) {
|
|
312
|
-
d.state = 'HIDDEN';
|
|
313
|
-
}
|
|
314
|
-
|
|
315
|
-
if (/(STOP_CANCELLED|JOURNEY_CANCELLED)/.test(d.state)) {
|
|
316
|
-
d.cancelled = true;
|
|
317
|
-
}
|
|
318
|
-
|
|
319
|
-
previousDeparture = d;
|
|
320
|
-
previousDeparture.time = t;
|
|
321
|
-
departureArray.unshift(d);
|
|
322
|
-
}
|
|
323
|
-
}
|
|
324
|
-
|
|
325
|
-
return departureArray;
|
|
326
|
-
}
|
|
327
|
-
|
|
328
|
-
/**
|
|
329
|
-
* Subscribe to departures channel of a given station.
|
|
330
|
-
*
|
|
331
|
-
* @param {number} stationId UIC of the station.
|
|
332
|
-
* @param {Boolean} sortByMinArrivalTime Sort by minimum arrival time
|
|
333
|
-
* @param {function(departures:Departure[])} onMessage Function called on each message of the channel.
|
|
334
|
-
*/
|
|
335
|
-
subscribeDepartures(stationId, sortByMinArrivalTime, onMessage) {
|
|
336
|
-
window.clearTimeout(this.departureUpdateTimeout);
|
|
337
|
-
this.unsubscribeDepartures();
|
|
338
|
-
this.subscribedStationUic = stationId;
|
|
339
|
-
const channel = stationId ? `timetable_${stationId}` : null;
|
|
340
|
-
const departureObject = {};
|
|
341
|
-
this.subscribe(
|
|
342
|
-
channel,
|
|
343
|
-
(data) => {
|
|
344
|
-
if (data.source === channel) {
|
|
345
|
-
const content = data.content || {};
|
|
346
|
-
const tDiff = new Date(content.timestamp).getTime() - Date.now();
|
|
347
|
-
content.timediff = tDiff;
|
|
348
|
-
departureObject[content.call_id] = content;
|
|
349
|
-
|
|
350
|
-
window.clearTimeout(this.departureUpdateTimeout);
|
|
351
|
-
this.departureUpdateTimeout = window.setTimeout(() => {
|
|
352
|
-
const departures = this.filterDepartures(
|
|
353
|
-
departureObject,
|
|
354
|
-
sortByMinArrivalTime || false,
|
|
355
|
-
);
|
|
356
|
-
onMessage(departures);
|
|
357
|
-
}, 100);
|
|
358
|
-
}
|
|
359
|
-
},
|
|
360
|
-
() => {
|
|
361
|
-
onMessage([]);
|
|
362
|
-
},
|
|
363
|
-
);
|
|
364
|
-
}
|
|
365
|
-
|
|
366
|
-
/**
|
|
367
|
-
* Unsubscribe from current departures channel.
|
|
368
|
-
* @param {function} cb Callback function to unsubscribe. If null all subscriptions for the channel will be unsubscribed.
|
|
369
|
-
*/
|
|
370
|
-
unsubscribeDepartures(cb) {
|
|
371
|
-
if (this.subscribedStationUic) {
|
|
372
|
-
this.unsubscribe(`timetable_${this.subscribedStationUic}`, '', cb);
|
|
373
|
-
this.subscribedStationUic = null;
|
|
374
|
-
}
|
|
375
|
-
}
|
|
376
|
-
|
|
377
|
-
/**
|
|
378
|
-
* Subscribe to the disruptions channel for tenant.
|
|
379
|
-
*
|
|
380
|
-
* @param {function} onMessage Function called on each message of the channel.
|
|
381
|
-
*/
|
|
382
|
-
subscribeDisruptions(onMessage) {
|
|
383
|
-
this.subscribe(`${this.prefix}newsticker`, (data) => {
|
|
384
|
-
onMessage(data.content);
|
|
385
|
-
});
|
|
386
|
-
}
|
|
387
|
-
|
|
388
|
-
/**
|
|
389
|
-
* Unsubscribe disruptions.
|
|
390
|
-
* @param {function} cb Callback function to unsubscribe. If null all subscriptions for the channel will be unsubscribed.
|
|
391
|
-
*/
|
|
392
|
-
unsubscribeDisruptions(cb) {
|
|
393
|
-
this.unsubscribe(`${this.prefix}newsticker`, '', cb);
|
|
394
|
-
}
|
|
395
|
-
|
|
396
|
-
/**
|
|
397
|
-
* Return a station with a given uic number and a mode.
|
|
398
|
-
*
|
|
399
|
-
* @param {number} uic UIC of the station.
|
|
400
|
-
* @param {TralisMode} mode Tralis mode.
|
|
401
|
-
* @return {Promise<Station>} A station.
|
|
402
|
-
*/
|
|
403
|
-
getStation(uic, mode) {
|
|
404
|
-
const params = {
|
|
405
|
-
channel: `station${getModeSuffix(mode, TralisModes)}`,
|
|
406
|
-
args: uic,
|
|
407
|
-
};
|
|
408
|
-
|
|
409
|
-
return new Promise((resolve, reject) => {
|
|
410
|
-
this.conn.get(params, (data) => {
|
|
411
|
-
if (data.content) {
|
|
412
|
-
resolve(data.content);
|
|
413
|
-
} else {
|
|
414
|
-
reject();
|
|
415
|
-
}
|
|
416
|
-
});
|
|
417
|
-
});
|
|
418
|
-
}
|
|
419
|
-
|
|
420
|
-
/**
|
|
421
|
-
* Update the model's station list for a given mode and a bbox.
|
|
422
|
-
*
|
|
423
|
-
* @param {TralisMode} mode Tralis mode.
|
|
424
|
-
* @return {Promise<Array<Station>>} An array of stations.
|
|
425
|
-
*/
|
|
426
|
-
getStations(mode) {
|
|
427
|
-
const stations = [];
|
|
428
|
-
const params = {
|
|
429
|
-
channel: `station${getModeSuffix(mode, TralisModes)}`,
|
|
430
|
-
};
|
|
431
|
-
window.clearTimeout(this.stationUpdateTimeout);
|
|
432
|
-
return new Promise((resolve, reject) => {
|
|
433
|
-
this.conn.get(params, (data) => {
|
|
434
|
-
if (data.content) {
|
|
435
|
-
stations.push(data.content);
|
|
436
|
-
window.clearTimeout(this.stationUpdateTimeout);
|
|
437
|
-
/** @ignore */
|
|
438
|
-
this.stationUpdateTimeout = window.setTimeout(() => {
|
|
439
|
-
resolve(stations);
|
|
440
|
-
}, 50);
|
|
441
|
-
} else {
|
|
442
|
-
reject(data.content);
|
|
443
|
-
}
|
|
444
|
-
});
|
|
445
|
-
});
|
|
446
|
-
}
|
|
447
|
-
|
|
448
|
-
/**
|
|
449
|
-
* Subscribe to stations channel.
|
|
450
|
-
* One message pro station.
|
|
451
|
-
*
|
|
452
|
-
* @param {TralisMode} mode Tralis mode.
|
|
453
|
-
* @param {function(station: Station)} onMessage Function called on each message of the channel.
|
|
454
|
-
*/
|
|
455
|
-
subscribeStations(mode, onMessage) {
|
|
456
|
-
this.unsubscribeStations();
|
|
457
|
-
this.subscribe(`station${getModeSuffix(mode, TralisModes)}`, (data) => {
|
|
458
|
-
if (data.content) {
|
|
459
|
-
onMessage(data.content);
|
|
460
|
-
}
|
|
461
|
-
});
|
|
462
|
-
}
|
|
463
|
-
|
|
464
|
-
/**
|
|
465
|
-
* Unsubscribe to stations channel.
|
|
466
|
-
* @param {function} cb The listener callback function to unsubscribe. If null all subscriptions for the channel will be unsubscribe.
|
|
467
|
-
*/
|
|
468
|
-
unsubscribeStations(cb) {
|
|
469
|
-
window.clearTimeout(this.stationUpdateTimeout);
|
|
470
|
-
this.unsubscribe('station', '', cb);
|
|
471
|
-
}
|
|
472
|
-
|
|
473
|
-
/**
|
|
474
|
-
* Subscribe to extra_geoms channel.
|
|
475
|
-
*
|
|
476
|
-
* @param {function(extraGeoms: GeosJSONFeature[])} onMessage Function called on each message of the channel.
|
|
477
|
-
*/
|
|
478
|
-
subscribeExtraGeoms(onMessage) {
|
|
479
|
-
this.subscribe('extra_geoms', (data) => {
|
|
480
|
-
const extraGeom = data.content;
|
|
481
|
-
|
|
482
|
-
if (extraGeom) {
|
|
483
|
-
const { ref } = extraGeom.properties;
|
|
484
|
-
|
|
485
|
-
if (extraGeom.type === 'Feature') {
|
|
486
|
-
this.extraGeoms[ref] = extraGeom;
|
|
487
|
-
} else {
|
|
488
|
-
delete this.extraGeoms[ref];
|
|
489
|
-
}
|
|
490
|
-
|
|
491
|
-
onMessage(
|
|
492
|
-
Object.keys(this.extraGeoms).map((key) => this.extraGeoms[key]),
|
|
493
|
-
);
|
|
494
|
-
}
|
|
495
|
-
});
|
|
496
|
-
}
|
|
497
|
-
|
|
498
|
-
/**
|
|
499
|
-
* Unsubscribe to extra_geoms channel.
|
|
500
|
-
* @param {function} cb Callback function to unsubscribe. If null all subscriptions for the channel will be unsubscribed.
|
|
501
|
-
*/
|
|
502
|
-
unsubscribeExtraGeoms(cb) {
|
|
503
|
-
this.unsubscribe('extra_geoms', '', cb);
|
|
504
|
-
}
|
|
505
|
-
|
|
506
|
-
/**
|
|
507
|
-
* Subscribe to trajectory channel.
|
|
508
|
-
*
|
|
509
|
-
* @param {TralisMode} mode Tralis mode.
|
|
510
|
-
* @param {function(trajectory: TralisTrajectory)} onMessage Function called on each message of the channel.
|
|
511
|
-
* @param {boolean} quiet If true, the subscription will not send GET and SUB requests to the websocket.
|
|
512
|
-
*/
|
|
513
|
-
subscribeTrajectory(mode, onMessage, quiet = false) {
|
|
514
|
-
this.unsubscribeTrajectory(onMessage);
|
|
515
|
-
this.subscribe(
|
|
516
|
-
`trajectory${getModeSuffix(mode, TralisModes)}`,
|
|
517
|
-
onMessage,
|
|
518
|
-
null,
|
|
519
|
-
quiet,
|
|
520
|
-
);
|
|
521
|
-
}
|
|
522
|
-
|
|
523
|
-
/**
|
|
524
|
-
* Unsubscribe to trajectory channels.
|
|
525
|
-
* @param {function} cb Callback function to unsubscribe. If null all subscriptions for the channel will be unsubscribed.
|
|
526
|
-
*/
|
|
527
|
-
unsubscribeTrajectory(cb) {
|
|
528
|
-
this.unsubscribe(`trajectory`, '', cb);
|
|
529
|
-
}
|
|
530
|
-
|
|
531
|
-
/**
|
|
532
|
-
* Subscribe to deleted_vhicles channel.
|
|
533
|
-
*
|
|
534
|
-
* @param {TralisMode} mode Tralis mode.
|
|
535
|
-
* @param {function(response: { content: Vehicle })} onMessage Function called on each message of the channel.
|
|
536
|
-
* @param {boolean} quiet If true, the subscription will not send GET and SUB requests to the websocket.
|
|
537
|
-
*/
|
|
538
|
-
subscribeDeletedVehicles(mode, onMessage, quiet = false) {
|
|
539
|
-
this.unsubscribeDeletedVehicles(onMessage);
|
|
540
|
-
this.subscribe(
|
|
541
|
-
`deleted_vehicles${getModeSuffix(mode, TralisModes)}`,
|
|
542
|
-
onMessage,
|
|
543
|
-
null,
|
|
544
|
-
quiet,
|
|
545
|
-
);
|
|
546
|
-
}
|
|
547
|
-
|
|
548
|
-
/**
|
|
549
|
-
* Unsubscribe to deleted_vhicles channels.
|
|
550
|
-
* @param {function} cb Callback function to unsubscribe. If null all subscriptions for the channel will be unsubscribed.
|
|
551
|
-
*/
|
|
552
|
-
unsubscribeDeletedVehicles(cb) {
|
|
553
|
-
this.unsubscribe('deleted_vehicles', '', cb);
|
|
554
|
-
}
|
|
555
|
-
|
|
556
|
-
/**
|
|
557
|
-
* Get a full trajectory of a vehicule .
|
|
558
|
-
*
|
|
559
|
-
* @param {string} id A vehicle id.
|
|
560
|
-
* @param {TralisMode} mode Tralis mode.
|
|
561
|
-
* @param {string} generalizationLevel The generalization level to request. Can be one of 5 (more generalized), 10, 30, 100, undefined (less generalized).
|
|
562
|
-
* @return {Promise<FullTrajectory>} Return a full trajectory.
|
|
563
|
-
*/
|
|
564
|
-
getFullTrajectory(id, mode, generalizationLevel) {
|
|
565
|
-
const channel = [`full_trajectory${getModeSuffix(mode, TralisModes)}`];
|
|
566
|
-
if (id) {
|
|
567
|
-
channel.push(id);
|
|
568
|
-
}
|
|
569
|
-
|
|
570
|
-
if ((!mode || mode === TralisModes.TOPOGRAPHIC) && generalizationLevel) {
|
|
571
|
-
channel.push(`gen${generalizationLevel}`);
|
|
572
|
-
}
|
|
573
|
-
|
|
574
|
-
const params = {
|
|
575
|
-
channel: channel.join('_'),
|
|
576
|
-
};
|
|
577
|
-
|
|
578
|
-
return new Promise((resolve) => {
|
|
579
|
-
this.conn.get(params, (data) => {
|
|
580
|
-
if (data.content) {
|
|
581
|
-
resolve(data.content);
|
|
582
|
-
}
|
|
583
|
-
});
|
|
584
|
-
});
|
|
585
|
-
}
|
|
586
|
-
|
|
587
|
-
/**
|
|
588
|
-
* Get full trajectories of a vehicules .
|
|
589
|
-
*
|
|
590
|
-
* @param {string[]} ids List of vehicles ids.
|
|
591
|
-
* @param {TralisMode} mode Tralis mode.
|
|
592
|
-
* @param {string} generalizationLevel The generalization level to request. Can be one of '', 'gen5', 'gen10', 'gen30', 'gen100'.
|
|
593
|
-
* @return {Promise<Array<FullTrajectory>>} Return an array of full trajectories.
|
|
594
|
-
*/
|
|
595
|
-
getFullTrajectories(ids, mode, generalizationLevel) {
|
|
596
|
-
const promises = ids.map((id) =>
|
|
597
|
-
this.getFullTrajectory(id, mode, generalizationLevel),
|
|
598
|
-
);
|
|
599
|
-
return Promise.all(promises);
|
|
600
|
-
}
|
|
601
|
-
|
|
602
|
-
/**
|
|
603
|
-
* Subscribe to full_trajectory channel of a given vehicle.
|
|
604
|
-
*
|
|
605
|
-
* @param {string} id A vehicle id.
|
|
606
|
-
* @param {TralisMode} mode Tralis mode.
|
|
607
|
-
*/
|
|
608
|
-
subscribeFullTrajectory(id, mode) {
|
|
609
|
-
// window.clearTimeout(this.fullTrajectoryUpdateTimeout);
|
|
610
|
-
this.unsubscribeFullTrajectory(id);
|
|
611
|
-
this.subscribe(
|
|
612
|
-
`full_trajectory${getModeSuffix(mode, TralisModes)}_${id}`,
|
|
613
|
-
(data) => {
|
|
614
|
-
// eslint-disable-next-line no-console
|
|
615
|
-
console.log('subscribe full_trajectory', data);
|
|
616
|
-
},
|
|
617
|
-
(err) => {
|
|
618
|
-
// eslint-disable-next-line no-console
|
|
619
|
-
console.log('subscribe full_trajectory error', err);
|
|
620
|
-
},
|
|
621
|
-
);
|
|
622
|
-
}
|
|
623
|
-
|
|
624
|
-
/**
|
|
625
|
-
* Unsubscribe from full_trajectory channel
|
|
626
|
-
*
|
|
627
|
-
* @param {string} id A vehicle id.
|
|
628
|
-
* @param {function} cb Callback function to unsubscribe. If null all subscriptions for the channel will be unsubscribed.
|
|
629
|
-
*/
|
|
630
|
-
unsubscribeFullTrajectory(id, cb) {
|
|
631
|
-
this.unsubscribe('full_trajectory', `_${id}`, cb);
|
|
632
|
-
}
|
|
633
|
-
|
|
634
|
-
/**
|
|
635
|
-
* Get the list of stops for this vehicle.
|
|
636
|
-
*
|
|
637
|
-
* @param {string} id A vehicle id.
|
|
638
|
-
* @return {Promise<StopSequence>} Returns a stop sequence object.
|
|
639
|
-
*/
|
|
640
|
-
getStopSequence(id) {
|
|
641
|
-
const params = {
|
|
642
|
-
channel: `stopsequence_${id}`,
|
|
643
|
-
};
|
|
644
|
-
return new Promise((resolve, reject) => {
|
|
645
|
-
this.conn.get(
|
|
646
|
-
params,
|
|
647
|
-
(data) => {
|
|
648
|
-
if (data.content && data.content.length) {
|
|
649
|
-
const content = data.content.map((stopSequence) =>
|
|
650
|
-
cleanStopTime(stopSequence),
|
|
651
|
-
);
|
|
652
|
-
|
|
653
|
-
// Remove the delay from arrivalTime and departureTime
|
|
654
|
-
resolve(content);
|
|
655
|
-
}
|
|
656
|
-
resolve([]);
|
|
657
|
-
},
|
|
658
|
-
(err) => {
|
|
659
|
-
reject(err);
|
|
660
|
-
},
|
|
661
|
-
);
|
|
662
|
-
});
|
|
663
|
-
}
|
|
664
|
-
|
|
665
|
-
/**
|
|
666
|
-
* Get a list of stops for a list of vehicles.
|
|
667
|
-
*
|
|
668
|
-
* @param {string[]} ids List of vehicles ids.
|
|
669
|
-
* @return {Promise<Array<StopSequence>>} Return an array of stop sequences.
|
|
670
|
-
*/
|
|
671
|
-
getStopSequences(ids) {
|
|
672
|
-
const promises = ids.map((id) => this.getStopSequence(id));
|
|
673
|
-
return Promise.all(promises);
|
|
674
|
-
}
|
|
675
|
-
|
|
676
|
-
/**
|
|
677
|
-
* Subscribe to stopsequence channel of a given vehicle.
|
|
678
|
-
*
|
|
679
|
-
* @param {string} id A vehicle id.
|
|
680
|
-
* @param {function(stopSequence: StopSequence)} onMessage Function called on each message of the channel.
|
|
681
|
-
*/
|
|
682
|
-
subscribeStopSequence(id, onMessage) {
|
|
683
|
-
window.clearTimeout(this.fullTrajectoryUpdateTimeout);
|
|
684
|
-
this.unsubscribeStopSequence(id);
|
|
685
|
-
|
|
686
|
-
this.subscribe(
|
|
687
|
-
`stopsequence_${id}`,
|
|
688
|
-
(data) => {
|
|
689
|
-
if (data.content && data.content.length) {
|
|
690
|
-
const content = data.content.map((stopSequence) =>
|
|
691
|
-
cleanStopTime(stopSequence),
|
|
692
|
-
);
|
|
693
|
-
|
|
694
|
-
// Remove the delay from arrivalTime and departureTime
|
|
695
|
-
onMessage(content);
|
|
696
|
-
}
|
|
697
|
-
},
|
|
698
|
-
(err) => {
|
|
699
|
-
// eslint-disable-next-line no-console
|
|
700
|
-
console.log('subscribe stopsequence error', err);
|
|
701
|
-
},
|
|
702
|
-
);
|
|
703
|
-
}
|
|
704
|
-
|
|
705
|
-
/**
|
|
706
|
-
* Unsubscribe from stopsequence channel
|
|
707
|
-
*
|
|
708
|
-
* @param {string} id A vehicle id.
|
|
709
|
-
* @param {function} cb Callback function to unsubscribe. If null all subscriptions for the channel will be unsubscribed.
|
|
710
|
-
*/
|
|
711
|
-
unsubscribeStopSequence(id, cb) {
|
|
712
|
-
this.unsubscribe(`stopsequence`, `_${id}`, cb);
|
|
713
|
-
}
|
|
714
|
-
|
|
715
|
-
/**
|
|
716
|
-
* Subscribe to healthcheck channel.
|
|
717
|
-
* @param {function} onMessage Callback when the subscribe to healthcheck channel succeeds.
|
|
718
|
-
*/
|
|
719
|
-
subscribeHealthCheck(onMessage) {
|
|
720
|
-
this.unsubscribeHealthCheck();
|
|
721
|
-
this.subscribe('healthcheck', onMessage);
|
|
722
|
-
}
|
|
723
|
-
|
|
724
|
-
/**
|
|
725
|
-
* Unsubscribe to healthcheck channel.
|
|
726
|
-
*/
|
|
727
|
-
unsubscribeHealthCheck() {
|
|
728
|
-
this.unsubscribe('healthcheck');
|
|
729
|
-
}
|
|
730
|
-
}
|
|
731
|
-
export default TralisAPI;
|