mobility-toolbox-js 3.0.0-beta.19 → 3.0.0-beta.20

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.
Files changed (55) hide show
  1. package/api/HttpAPI.d.ts +5 -5
  2. package/api/RealtimeAPI.d.ts +204 -171
  3. package/api/RealtimeAPI.js +306 -258
  4. package/api/RoutingAPI.d.ts +4 -4
  5. package/api/StopsAPI.d.ts +4 -4
  6. package/api/WebSocketAPI.d.ts +60 -66
  7. package/api/WebSocketAPI.js +164 -164
  8. package/api/index.js +1 -1
  9. package/common/controls/StopFinderControlCommon.d.ts +11 -11
  10. package/common/controls/StopFinderControlCommon.js +30 -30
  11. package/common/index.d.ts +1 -1
  12. package/common/index.js +1 -1
  13. package/common/mixins/RealtimeLayerMixin.d.ts +149 -155
  14. package/common/mixins/RealtimeLayerMixin.js +395 -395
  15. package/common/styles/realtimeDefaultStyle.js +6 -6
  16. package/common/styles/realtimeHeadingStyle.js +5 -5
  17. package/common/utils/getMapGlCopyrights.d.ts +1 -1
  18. package/common/utils/getMapGlCopyrights.js +3 -3
  19. package/common/utils/getVehiclePosition.d.ts +2 -2
  20. package/common/utils/getVehiclePosition.js +7 -7
  21. package/common/utils/renderTrajectories.js +5 -5
  22. package/common/utils/sortByDelay.js +5 -5
  23. package/maplibre/layers/RealtimeLayer.d.ts +59 -64
  24. package/maplibre/layers/RealtimeLayer.js +8 -8
  25. package/maplibre/utils/getSourceCoordinates.js +5 -5
  26. package/mbt.js +7205 -7031
  27. package/mbt.js.map +4 -4
  28. package/mbt.min.js +25 -25
  29. package/mbt.min.js.map +4 -4
  30. package/ol/controls/RoutingControl.d.ts +81 -87
  31. package/ol/controls/RoutingControl.js +216 -218
  32. package/ol/layers/Layer.d.ts +9 -9
  33. package/ol/layers/MaplibreLayer.d.ts +10 -10
  34. package/ol/layers/MaplibreLayer.js +9 -3
  35. package/ol/layers/MaplibreStyleLayer.d.ts +77 -76
  36. package/ol/layers/MaplibreStyleLayer.js +237 -238
  37. package/ol/layers/RealtimeLayer.d.ts +92 -96
  38. package/ol/layers/RealtimeLayer.js +139 -131
  39. package/ol/mixins/MobilityLayerMixin.d.ts +9 -9
  40. package/ol/mixins/PropertiesLayerMixin.d.ts +33 -36
  41. package/ol/mixins/PropertiesLayerMixin.js +73 -72
  42. package/ol/renderers/MaplibreLayerRenderer.js +3 -3
  43. package/ol/renderers/MaplibreStyleLayerRenderer.d.ts +6 -6
  44. package/ol/renderers/MaplibreStyleLayerRenderer.js +14 -17
  45. package/ol/renderers/RealtimeLayerRenderer.d.ts +6 -6
  46. package/ol/renderers/RealtimeLayerRenderer.js +54 -52
  47. package/ol/utils/getFeatureInfoAtCoordinate.d.ts +1 -1
  48. package/ol/utils/getFeatureInfoAtCoordinate.js +10 -16
  49. package/package.json +6 -5
  50. package/setupTests.js +3 -4
  51. package/types/common.d.ts +53 -49
  52. package/types/index.d.ts +1 -1
  53. package/types/realtime.d.ts +91 -93
  54. package/types/routing.d.ts +60 -60
  55. package/types/stops.d.ts +62 -62
@@ -2,12 +2,12 @@ import { Feature, FeatureCollection } from 'geojson';
2
2
  import { StopsAPI } from '../../api';
3
3
  import { StopsAPIOptions } from '../../api/StopsAPI';
4
4
  import { StopsParameters } from '../../types';
5
- export type StopFinderControlCommonOptions = StopsAPIOptions & {
6
- element: HTMLElement;
7
- placeholder?: string;
5
+ export type StopFinderControlCommonOptions = {
8
6
  apiParams: StopsParameters;
7
+ element: HTMLElement;
9
8
  onSuggestionClick?: (suggestion: Feature, evt: MouseEvent) => void;
10
- };
9
+ placeholder?: string;
10
+ } & StopsAPIOptions;
11
11
  /**
12
12
  * A class representing a stop finder control to display on map.
13
13
  * This class only draw the html elements.
@@ -16,14 +16,14 @@ export type StopFinderControlCommonOptions = StopsAPIOptions & {
16
16
  * @private
17
17
  */
18
18
  declare class StopFinderControlCommon {
19
- apiParams: StopsParameters;
20
- placeholder: string;
21
- api: StopsAPI;
22
19
  abortController?: AbortController;
23
- suggestionsElt?: HTMLElement;
24
- inputElt?: HTMLInputElement;
20
+ api: StopsAPI;
21
+ apiParams: StopsParameters;
25
22
  clearElt?: HTMLDivElement;
23
+ inputElt?: HTMLInputElement;
26
24
  options?: StopFinderControlCommonOptions;
25
+ placeholder: string;
26
+ suggestionsElt?: HTMLElement;
27
27
  /**
28
28
  * Constructor.
29
29
  *
@@ -35,12 +35,12 @@ declare class StopFinderControlCommon {
35
35
  * @param {StopsSearchParams} [options.apiParams={ limit: 20 }] Request parameters. See [Stops service documentation](https://developer.geops.io/apis/5dcbd702a256d90001cf1361/).
36
36
  */
37
37
  constructor(options: StopFinderControlCommonOptions);
38
- render(featureCollection?: FeatureCollection): void;
39
- createElement({ element }: StopFinderControlCommonOptions): void;
40
38
  /**
41
39
  * Clear the search field and close the control.
42
40
  */
43
41
  clear(): void;
42
+ createElement({ element }: StopFinderControlCommonOptions): void;
43
+ render(featureCollection?: FeatureCollection): void;
44
44
  /**
45
45
  * Launch a search.
46
46
  *
@@ -18,7 +18,7 @@ class StopFinderControlCommon {
18
18
  * @param {StopsSearchParams} [options.apiParams={ limit: 20 }] Request parameters. See [Stops service documentation](https://developer.geops.io/apis/5dcbd702a256d90001cf1361/).
19
19
  */
20
20
  constructor(options) {
21
- const { apiParams, apiKey, url, placeholder } = options || {};
21
+ const { apiKey, apiParams, placeholder, url } = options || {};
22
22
  this.apiParams = Object.assign({ limit: 20 }, (apiParams || {}));
23
23
  this.placeholder = placeholder || 'Search for a stop...';
24
24
  const apiOptions = { apiKey };
@@ -30,26 +30,16 @@ class StopFinderControlCommon {
30
30
  this.createElement(options);
31
31
  this.options = options;
32
32
  }
33
- render(featureCollection) {
34
- const suggestions = (featureCollection === null || featureCollection === void 0 ? void 0 : featureCollection.features) || [];
35
- if (!this.suggestionsElt) {
33
+ /**
34
+ * Clear the search field and close the control.
35
+ */
36
+ clear() {
37
+ if (!this.suggestionsElt || !this.inputElt || !this.clearElt) {
36
38
  return;
37
39
  }
38
- this.suggestionsElt.style.display = suggestions.length ? 'block' : 'none';
40
+ this.inputElt.value = '';
39
41
  this.suggestionsElt.innerHTML = '';
40
- suggestions.forEach((suggestion) => {
41
- var _a, _b;
42
- const suggElt = document.createElement('div');
43
- suggElt.innerHTML = (_a = suggestion === null || suggestion === void 0 ? void 0 : suggestion.properties) === null || _a === void 0 ? void 0 : _a.name;
44
- suggElt.onclick = (evt) => {
45
- var _a, _b;
46
- (_b = (_a = this.options) === null || _a === void 0 ? void 0 : _a.onSuggestionClick) === null || _b === void 0 ? void 0 : _b.call(_a, suggestion, evt);
47
- };
48
- Object.assign(suggElt.style, {
49
- padding: '5px 12px',
50
- });
51
- (_b = this.suggestionsElt) === null || _b === void 0 ? void 0 : _b.appendChild(suggElt);
52
- });
42
+ this.clearElt.style.display = 'none';
53
43
  }
54
44
  createElement({ element }) {
55
45
  // Create input element
@@ -61,7 +51,7 @@ class StopFinderControlCommon {
61
51
  var _a;
62
52
  (_a = this.abortController) === null || _a === void 0 ? void 0 : _a.abort();
63
53
  this.abortController = new AbortController();
64
- // @ts-ignore
54
+ // @ts-expect-error
65
55
  this.search(evt.target.value, this.abortController);
66
56
  };
67
57
  Object.assign(this.inputElt.style, {
@@ -72,33 +62,43 @@ class StopFinderControlCommon {
72
62
  this.suggestionsElt = document.createElement('div');
73
63
  Object.assign(this.suggestionsElt.style, {
74
64
  backgroundColor: 'white',
75
- overflowY: 'auto',
76
65
  cursor: 'pointer',
66
+ overflowY: 'auto',
77
67
  });
78
68
  element.appendChild(this.suggestionsElt);
79
69
  this.clearElt = document.createElement('div');
80
70
  Object.assign(this.clearElt.style, {
71
+ cursor: 'pointer',
81
72
  display: 'none',
73
+ fontSize: '200%',
74
+ padding: '0 10px',
82
75
  position: 'absolute',
83
76
  right: '0',
84
- padding: '0 10px',
85
- fontSize: '200%',
86
- cursor: 'pointer',
87
77
  });
88
78
  this.clearElt.innerHTML = '×';
89
79
  this.clearElt.onclick = () => this.clear();
90
80
  element.appendChild(this.clearElt);
91
81
  }
92
- /**
93
- * Clear the search field and close the control.
94
- */
95
- clear() {
96
- if (!this.suggestionsElt || !this.inputElt || !this.clearElt) {
82
+ render(featureCollection) {
83
+ const suggestions = (featureCollection === null || featureCollection === void 0 ? void 0 : featureCollection.features) || [];
84
+ if (!this.suggestionsElt) {
97
85
  return;
98
86
  }
99
- this.inputElt.value = '';
87
+ this.suggestionsElt.style.display = suggestions.length ? 'block' : 'none';
100
88
  this.suggestionsElt.innerHTML = '';
101
- this.clearElt.style.display = 'none';
89
+ suggestions.forEach((suggestion) => {
90
+ var _a, _b;
91
+ const suggElt = document.createElement('div');
92
+ suggElt.innerHTML = (_a = suggestion === null || suggestion === void 0 ? void 0 : suggestion.properties) === null || _a === void 0 ? void 0 : _a.name;
93
+ suggElt.onclick = (evt) => {
94
+ var _a, _b;
95
+ (_b = (_a = this.options) === null || _a === void 0 ? void 0 : _a.onSuggestionClick) === null || _b === void 0 ? void 0 : _b.call(_a, suggestion, evt);
96
+ };
97
+ Object.assign(suggElt.style, {
98
+ padding: '5px 12px',
99
+ });
100
+ (_b = this.suggestionsElt) === null || _b === void 0 ? void 0 : _b.appendChild(suggElt);
101
+ });
102
102
  }
103
103
  /**
104
104
  * Launch a search.
package/common/index.d.ts CHANGED
@@ -1,2 +1,2 @@
1
- export * from "./utils";
2
1
  export * from "./styles";
2
+ export * from "./utils";
package/common/index.js CHANGED
@@ -1,2 +1,2 @@
1
- export * from './utils';
2
1
  export * from './styles';
2
+ export * from './utils';
@@ -1,63 +1,65 @@
1
- import GeoJSON from 'ol/format/GeoJSON';
2
- import { EventsKey } from 'ol/events';
3
1
  import { Coordinate } from 'ol/coordinate';
2
+ import { EventsKey } from 'ol/events';
3
+ import GeoJSON from 'ol/format/GeoJSON';
4
4
  import { Options } from 'ol/layer/Layer';
5
5
  import { RealtimeAPI } from '../../api';
6
- import { AnyCanvas, AnyMap, AnyRealtimeLayer, LayerGetFeatureInfoOptions, RealtimeGeneralizationLevel, RealtimeMode, RealtimeMot, RealtimeRenderState, RealtimeStyleFunction, RealtimeStyleOptions, RealtimeTenant, RealtimeTrainId, ViewState, AnyLayer, LayerGetFeatureInfoResponse, RealtimeTrajectory, AnyLayerable } from '../../types';
7
6
  import { WebSocketAPIMessageEventData } from '../../api/WebSocketAPI';
7
+ import { AnyCanvas, AnyLayer, AnyLayerable, AnyMap, AnyRealtimeLayer, LayerGetFeatureInfoOptions, LayerGetFeatureInfoResponse, RealtimeGeneralizationLevel, RealtimeMode, RealtimeMot, RealtimeRenderState, RealtimeStyleFunction, RealtimeStyleOptions, RealtimeTenant, RealtimeTrainId, RealtimeTrajectory, ViewState } from '../../types';
8
8
  import { FilterFunction, SortFunction } from '../typedefs';
9
- export type RealtimeLayerMixinOptions = Options & {
10
- debug?: boolean;
11
- mode?: RealtimeMode;
9
+ export type RealtimeLayerMixinOptions = {
12
10
  api?: RealtimeAPI;
13
- tenant?: RealtimeTenant;
14
- minZoomInterpolation?: number;
11
+ apiKey?: string;
12
+ bbox?: (number | string)[];
13
+ bboxParameters?: Record<string, boolean | boolean[] | number | number[] | string | string[]>;
14
+ buffer?: number[];
15
+ canvas?: HTMLCanvasElement;
16
+ debug?: boolean;
17
+ filter?: FilterFunction;
18
+ generalizationLevelByZoom?: RealtimeGeneralizationLevel[];
19
+ getGeneralizationLevelByZoom?: (zoom: number, generalizationLevelByZoom: RealtimeGeneralizationLevel[]) => RealtimeGeneralizationLevel;
20
+ getMotsByZoom?: (zoom: number, motsByZoom: RealtimeMot[][]) => RealtimeMot[];
21
+ getRenderTimeIntervalByZoom?: (zoom: number, renderTimeIntervalByZoom: number[]) => number;
22
+ hoverVehicleId?: RealtimeTrainId;
15
23
  isUpdateBboxOnMoveEnd?: boolean;
24
+ live?: boolean;
25
+ minZoomInterpolation?: number;
26
+ mode?: RealtimeMode;
16
27
  motsByZoom?: RealtimeMot[][];
17
- generalizationLevelByZoom?: RealtimeGeneralizationLevel[];
18
- renderTimeIntervalByZoom?: number[];
19
- style?: RealtimeStyleFunction;
20
- speed?: number;
28
+ onStart?: (realtimeLayer: AnyRealtimeLayer) => void;
29
+ onStop?: (realtimeLayer: AnyRealtimeLayer) => void;
30
+ pingIntervalMs?: number;
21
31
  pixelRatio?: number;
22
- hoverVehicleId?: RealtimeTrainId;
32
+ prefix?: string;
33
+ renderTimeIntervalByZoom?: number[];
23
34
  selectedVehicleId?: RealtimeTrainId;
24
- filter?: FilterFunction;
25
35
  sort?: SortFunction;
26
- time?: number;
27
- live?: boolean;
28
- canvas?: HTMLCanvasElement;
36
+ speed?: number;
37
+ style?: RealtimeStyleFunction;
29
38
  styleOptions?: RealtimeStyleOptions;
30
- useRequestAnimationFrame?: boolean;
39
+ tenant?: RealtimeTenant;
40
+ time?: number;
41
+ url?: string;
31
42
  useDebounce?: boolean;
43
+ useRequestAnimationFrame?: boolean;
32
44
  useThrottle?: boolean;
33
- getMotsByZoom?: (zoom: number, motsByZoom: RealtimeMot[][]) => RealtimeMot[];
34
- getGeneralizationLevelByZoom?: (zoom: number, generalizationLevelByZoom: RealtimeGeneralizationLevel[]) => RealtimeGeneralizationLevel;
35
- getRenderTimeIntervalByZoom?: (zoom: number, renderTimeIntervalByZoom: number[]) => number;
36
- onStart?: (realtimeLayer: AnyRealtimeLayer) => void;
37
- onStop?: (realtimeLayer: AnyRealtimeLayer) => void;
38
- url?: string;
39
- apiKey?: string;
40
- prefix?: string;
41
- bbox?: (number | string)[];
42
- buffer?: number[];
43
- pingIntervalMs?: number;
44
- bboxParameters?: {
45
- [index: string]: string | number | boolean | string[] | boolean[] | number[];
46
- };
47
- };
45
+ } & Options;
48
46
  /**
49
47
  * RealtimeLayerInterface.
50
48
  * @private
51
49
  */
52
50
  export declare class RealtimeLayerInterface {
53
51
  /**
54
- * Start the clock.
52
+ * Request the stopSequence and the fullTrajectory informations for a vehicle.
53
+ *
54
+ * @param {string} id The vehicle identifier (the train_id property).
55
+ * @param {RealtimeMode} mode The mode to request. If not defined, the layer´s mode propetrty will be used.
56
+ * @return {Promise<{stopSequence: RealtimeStopSequence, fullTrajectory: RealtimeFullTrajectory>} A promise that will be resolved with the trajectory informations.
55
57
  */
56
- start(): void;
58
+ getTrajectoryInfos(id: string, mode: RealtimeMode): void;
57
59
  /**
58
- * Stop the clock.
60
+ * Render the trajectories
59
61
  */
60
- stop(): void;
62
+ renderTrajectories(): void;
61
63
  /**
62
64
  * Set the Realtime api's bbox.
63
65
  *
@@ -66,17 +68,13 @@ export declare class RealtimeLayerInterface {
66
68
  */
67
69
  setBbox(extent: [number, number, number, number], zoom: number): void;
68
70
  /**
69
- * Render the trajectories
71
+ * Start the clock.
70
72
  */
71
- renderTrajectories(): void;
73
+ start(): void;
72
74
  /**
73
- * Request the stopSequence and the fullTrajectory informations for a vehicle.
74
- *
75
- * @param {string} id The vehicle identifier (the train_id property).
76
- * @param {RealtimeMode} mode The mode to request. If not defined, the layer´s mode propetrty will be used.
77
- * @return {Promise<{stopSequence: RealtimeStopSequence, fullTrajectory: RealtimeFullTrajectory>} A promise that will be resolved with the trajectory informations.
75
+ * Stop the clock.
78
76
  */
79
- getTrajectoryInfos(id: string, mode: RealtimeMode): void;
77
+ stop(): void;
80
78
  }
81
79
  /**
82
80
  * Mixin for RealtimeLayerInterface.
@@ -89,103 +87,71 @@ declare function RealtimeLayerMixin<T extends AnyLayerable>(Base: T): {
89
87
  new (options: RealtimeLayerMixinOptions): {
90
88
  [x: string]: any;
91
89
  [x: symbol]: any;
92
- debug: boolean;
93
- trajectories?: {
94
- [key: RealtimeTrainId]: RealtimeTrajectory;
95
- };
96
- canvas?: AnyCanvas;
97
- mode: RealtimeMode;
98
90
  api: RealtimeAPI;
99
- tenant: RealtimeTenant;
100
- bboxParameters?: {
101
- [index: string]: string | number | boolean | string[] | boolean[] | number[];
102
- };
103
- time?: Date;
104
- live?: boolean;
105
- speed?: number;
91
+ bboxParameters?: Record<string, boolean | boolean[] | number | number[] | string | string[]>;
92
+ canvas?: AnyCanvas;
93
+ debounceRenderTrajectories: (viewState: ViewState, noInterpolate?: boolean) => void;
94
+ debug: boolean;
106
95
  filter?: FilterFunction;
107
- sort?: SortFunction;
108
- style?: RealtimeStyleFunction;
109
- styleOptions?: RealtimeStyleOptions;
110
- pixelRatio?: number;
111
- minZoomInterpolation: number;
112
- isUpdateBboxOnMoveEnd: boolean;
96
+ format: GeoJSON;
97
+ generalizationLevel?: RealtimeGeneralizationLevel;
98
+ generalizationLevelByZoom: RealtimeGeneralizationLevel[];
99
+ getGeneralizationLevelByZoom: (zoom: number) => RealtimeGeneralizationLevel;
100
+ getMotsByZoom: (zoom: number) => RealtimeMot[];
101
+ getRenderTimeIntervalByZoom: (zoom: number) => number;
113
102
  hoverVehicleId?: RealtimeTrainId;
114
- selectedVehicleId?: RealtimeTrainId;
115
- renderState?: RealtimeRenderState;
116
- useRequestAnimationFrame?: boolean;
117
- useDebounce?: boolean;
118
- useThrottle?: boolean;
103
+ isUpdateBboxOnMoveEnd: boolean;
104
+ live?: boolean;
105
+ minZoomInterpolation: number;
106
+ mode: RealtimeMode;
119
107
  mots?: RealtimeMot[];
120
108
  motsByZoom: RealtimeMot[][];
121
- generalizationLevel?: RealtimeGeneralizationLevel;
122
- generalizationLevelByZoom: RealtimeGeneralizationLevel[];
109
+ onStart?: (realtimeLayer: AnyLayer) => void;
110
+ onStop?: (realtimeLayer: AnyLayer) => void;
111
+ pixelRatio?: number;
112
+ renderState?: RealtimeRenderState;
123
113
  renderTimeIntervalByZoom: number[];
124
- format: GeoJSON;
125
114
  requestId?: number;
126
- updateTimeInterval?: number;
127
- updateTimeDelay?: number;
128
- visibilityRef: EventsKey;
129
115
  selectedVehicle: RealtimeTrajectory;
130
- getMotsByZoom: (zoom: number) => RealtimeMot[];
131
- getGeneralizationLevelByZoom: (zoom: number) => RealtimeGeneralizationLevel;
132
- getRenderTimeIntervalByZoom: (zoom: number) => number;
116
+ selectedVehicleId?: RealtimeTrainId;
117
+ sort?: SortFunction;
118
+ speed?: number;
119
+ style?: RealtimeStyleFunction;
120
+ styleOptions?: RealtimeStyleOptions;
121
+ tenant: RealtimeTenant;
133
122
  throttleRenderTrajectories: (viewState: ViewState, noInterpolate?: boolean) => void;
134
- debounceRenderTrajectories: (viewState: ViewState, noInterpolate?: boolean) => void;
135
- onStart?: (realtimeLayer: AnyLayer) => void;
136
- onStop?: (realtimeLayer: AnyLayer) => void;
123
+ time?: Date;
124
+ trajectories?: Record<RealtimeTrainId, RealtimeTrajectory>;
125
+ updateTimeDelay?: number;
126
+ updateTimeInterval?: number;
127
+ useDebounce?: boolean;
128
+ useRequestAnimationFrame?: boolean;
129
+ useThrottle?: boolean;
130
+ visibilityRef: EventsKey;
137
131
  /**
138
- * Define layer's properties.
139
- *
132
+ * Add a trajectory.
133
+ * @param {RealtimeTrajectory} trajectory The trajectory to add.
140
134
  * @private
141
135
  */
142
- defineProperties(options: RealtimeLayerMixinOptions): void;
136
+ addTrajectory(trajectory: RealtimeTrajectory): void;
143
137
  attachToMap(map: AnyMap): void;
144
- detachFromMap(): void;
145
- start(): void;
146
- /**
147
- * Start the clock.
148
- * @private
149
- */
150
- startUpdateTime(): void;
151
- stop(): void;
152
- /**
153
- * Stop the clock.
154
- * @private
155
- */
156
- stopUpdateTime(): void;
157
138
  /**
158
- * Launch renderTrajectories. it avoids duplicating code in renderTrajectories method.
139
+ * Define layer's properties.
159
140
  *
160
- * @param {object} viewState The view state of the map.
161
- * @param {number[2]} viewState.center Center coordinate of the map in mercator coordinate.
162
- * @param {number[4]} viewState.extent Extent of the map in mercator coordinates.
163
- * @param {number[2]} viewState.size Size ([width, height]) of the canvas to render.
164
- * @param {number} [viewState.rotation = 0] Rotation of the map to render.
165
- * @param {number} viewState.resolution Resolution of the map to render.
166
- * @param {boolean} noInterpolate If true trajectories are not interpolated but
167
- * drawn at the last known coordinate. Use this for performance optimization
168
- * during map navigation.
169
141
  * @private
170
142
  */
171
- renderTrajectoriesInternal(viewState: ViewState, noInterpolate?: boolean): boolean;
143
+ defineProperties(options: RealtimeLayerMixinOptions): void;
144
+ detachFromMap(): void;
172
145
  /**
173
- * Render the trajectories requesting an animation frame and cancelling the previous one.
174
- * This function must be overrided by children to provide the correct parameters.
146
+ * Request feature information for a given coordinate.
175
147
  *
176
- * @param {object} viewState The view state of the map.
177
- * @param {number[2]} viewState.center Center coordinate of the map in mercator coordinate.
178
- * @param {number[4]} viewState.extent Extent of the map in mercator coordinates.
179
- * @param {number[2]} viewState.size Size ([width, height]) of the canvas to render.
180
- * @param {number} [viewState.rotation = 0] Rotation of the map to render.
181
- * @param {number} viewState.resolution Resolution of the map to render.
182
- * @param {boolean} noInterpolate If true trajectories are not interpolated but
183
- * drawn at the last known coordinate. Use this for performance optimization
184
- * during map navigation.
185
- * @private
148
+ * @param {ol/coordinate~Coordinate} coordinate Coordinate.
149
+ * @param {Object} options Options See child classes to see which options are supported.
150
+ * @param {number} [options.resolution=1] The resolution of the map.
151
+ * @param {number} [options.nb=Infinity] The max number of vehicles to return.
152
+ * @return {Promise<FeatureInfo>} Promise with features, layer and coordinate.
186
153
  */
187
- renderTrajectories(viewState: ViewState | undefined, noInterpolate: boolean | undefined): void;
188
- setBbox(extent: [number, number, number, number], zoom: number): void;
154
+ getFeatureInfoAtCoordinate(coordinate: Coordinate, options: LayerGetFeatureInfoOptions): Promise<LayerGetFeatureInfoResponse>;
189
155
  /**
190
156
  * Get the duration before the next update depending on zoom level.
191
157
  *
@@ -193,32 +159,46 @@ declare function RealtimeLayerMixin<T extends AnyLayerable>(Base: T): {
193
159
  * @param {number} zoom
194
160
  */
195
161
  getRefreshTimeInMs(zoom?: number | undefined): number;
162
+ /**
163
+ * Request the stopSequence and the fullTrajectory informations for a vehicle.
164
+ *
165
+ * @param {string} id The vehicle identifier (the train_id property).
166
+ * @return {Promise<{stopSequence: RealtimeStopSequence, fullTrajectory: RealtimeFullTrajectory>} A promise that will be resolved with the trajectory informations.
167
+ */
168
+ getTrajectoryInfos(id: RealtimeTrainId): Promise<{
169
+ fullTrajectory: WebSocketAPIMessageEventData<import("../../types").RealtimeStopSequence[]> | WebSocketAPIMessageEventData<import("../../types").RealtimeFullTrajectory>;
170
+ stopSequence: WebSocketAPIMessageEventData<import("../../types").RealtimeStopSequence[]> | WebSocketAPIMessageEventData<import("../../types").RealtimeFullTrajectory>;
171
+ }>;
196
172
  /**
197
173
  * Get vehicle.
198
174
  * @param {function} filterFc A function use to filter results.
199
175
  * @return {Array<Object>} Array of vehicle.
200
176
  */
201
177
  getVehicle(filterFc: FilterFunction): RealtimeTrajectory[];
178
+ highlightVehicle(id: RealtimeTrainId): void;
202
179
  /**
203
- * Request feature information for a given coordinate.
180
+ * Callback on websocket's deleted_vehicles channel events.
181
+ * It removes the trajectory from the list.
204
182
  *
205
- * @param {ol/coordinate~Coordinate} coordinate Coordinate.
206
- * @param {Object} options Options See child classes to see which options are supported.
207
- * @param {number} [options.resolution=1] The resolution of the map.
208
- * @param {number} [options.nb=Infinity] The max number of vehicles to return.
209
- * @return {Promise<FeatureInfo>} Promise with features, layer and coordinate.
183
+ * @private
184
+ * @override
210
185
  */
211
- getFeatureInfoAtCoordinate(coordinate: Coordinate, options: LayerGetFeatureInfoOptions): Promise<LayerGetFeatureInfoResponse>;
186
+ onDeleteTrajectoryMessage(data: WebSocketAPIMessageEventData<RealtimeTrainId>): void;
187
+ onDocumentVisibilityChange(): void;
212
188
  /**
213
- * Request the stopSequence and the fullTrajectory informations for a vehicle.
189
+ * Callback on websocket's trajectory channel events.
190
+ * It adds a trajectory to the list.
214
191
  *
215
- * @param {string} id The vehicle identifier (the train_id property).
216
- * @return {Promise<{stopSequence: RealtimeStopSequence, fullTrajectory: RealtimeFullTrajectory>} A promise that will be resolved with the trajectory informations.
192
+ * @private
217
193
  */
218
- getTrajectoryInfos(id: RealtimeTrainId): Promise<{
219
- stopSequence: WebSocketAPIMessageEventData<import("../../types").RealtimeFullTrajectory> | WebSocketAPIMessageEventData<import("../../types").RealtimeStopSequence[]>;
220
- fullTrajectory: WebSocketAPIMessageEventData<import("../../types").RealtimeFullTrajectory> | WebSocketAPIMessageEventData<import("../../types").RealtimeStopSequence[]>;
221
- }>;
194
+ onTrajectoryMessage(data: WebSocketAPIMessageEventData<RealtimeTrajectory>): void;
195
+ /**
196
+ * On zoomend we adjust the time interval of the update of vehicles positions.
197
+ *
198
+ * @param evt Event that triggered the function.
199
+ * @private
200
+ */
201
+ onZoomEnd(): void;
222
202
  /**
223
203
  * Remove all trajectories that are in the past.
224
204
  */
@@ -236,38 +216,52 @@ declare function RealtimeLayerMixin<T extends AnyLayerable>(Base: T): {
236
216
  * @private
237
217
  */
238
218
  purgeTrajectory(trajectory: RealtimeTrajectory, extent: [number, number, number, number], zoom: number): boolean;
219
+ removeTrajectory(trajectoryOrId: RealtimeTrainId | RealtimeTrajectory): void;
239
220
  /**
240
- * Add a trajectory.
241
- * @param {RealtimeTrajectory} trajectory The trajectory to add.
221
+ * Render the trajectories requesting an animation frame and cancelling the previous one.
222
+ * This function must be overrided by children to provide the correct parameters.
223
+ *
224
+ * @param {object} viewState The view state of the map.
225
+ * @param {number[2]} viewState.center Center coordinate of the map in mercator coordinate.
226
+ * @param {number[4]} viewState.extent Extent of the map in mercator coordinates.
227
+ * @param {number[2]} viewState.size Size ([width, height]) of the canvas to render.
228
+ * @param {number} [viewState.rotation = 0] Rotation of the map to render.
229
+ * @param {number} viewState.resolution Resolution of the map to render.
230
+ * @param {boolean} noInterpolate If true trajectories are not interpolated but
231
+ * drawn at the last known coordinate. Use this for performance optimization
232
+ * during map navigation.
242
233
  * @private
243
234
  */
244
- addTrajectory(trajectory: RealtimeTrajectory): void;
245
- removeTrajectory(trajectoryOrId: RealtimeTrajectory | RealtimeTrainId): void;
235
+ renderTrajectories(viewState: undefined | ViewState, noInterpolate: boolean | undefined): void;
246
236
  /**
247
- * On zoomend we adjust the time interval of the update of vehicles positions.
237
+ * Launch renderTrajectories. it avoids duplicating code in renderTrajectories method.
248
238
  *
249
- * @param evt Event that triggered the function.
239
+ * @param {object} viewState The view state of the map.
240
+ * @param {number[2]} viewState.center Center coordinate of the map in mercator coordinate.
241
+ * @param {number[4]} viewState.extent Extent of the map in mercator coordinates.
242
+ * @param {number[2]} viewState.size Size ([width, height]) of the canvas to render.
243
+ * @param {number} [viewState.rotation = 0] Rotation of the map to render.
244
+ * @param {number} viewState.resolution Resolution of the map to render.
245
+ * @param {boolean} noInterpolate If true trajectories are not interpolated but
246
+ * drawn at the last known coordinate. Use this for performance optimization
247
+ * during map navigation.
250
248
  * @private
251
249
  */
252
- onZoomEnd(): void;
253
- onDocumentVisibilityChange(): void;
250
+ renderTrajectoriesInternal(viewState: ViewState, noInterpolate?: boolean): boolean;
251
+ selectVehicle(id: RealtimeTrainId): void;
252
+ setBbox(extent: [number, number, number, number], zoom: number): void;
253
+ start(): void;
254
254
  /**
255
- * Callback on websocket's trajectory channel events.
256
- * It adds a trajectory to the list.
257
- *
255
+ * Start the clock.
258
256
  * @private
259
257
  */
260
- onTrajectoryMessage(data: WebSocketAPIMessageEventData<RealtimeTrajectory>): void;
258
+ startUpdateTime(): void;
259
+ stop(): void;
261
260
  /**
262
- * Callback on websocket's deleted_vehicles channel events.
263
- * It removes the trajectory from the list.
264
- *
261
+ * Stop the clock.
265
262
  * @private
266
- * @override
267
263
  */
268
- onDeleteTrajectoryMessage(data: WebSocketAPIMessageEventData<RealtimeTrainId>): void;
269
- highlightVehicle(id: RealtimeTrainId): void;
270
- selectVehicle(id: RealtimeTrainId): void;
264
+ stopUpdateTime(): void;
271
265
  };
272
266
  } & T;
273
267
  export default RealtimeLayerMixin;