mobility-toolbox-js 3.0.0-beta.9 → 3.0.1-beta.0

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 (87) hide show
  1. package/api/HttpAPI.d.ts +5 -16
  2. package/api/HttpAPI.js +0 -11
  3. package/api/RealtimeAPI.d.ts +221 -176
  4. package/api/RealtimeAPI.js +317 -258
  5. package/api/RoutingAPI.d.ts +21 -11
  6. package/api/RoutingAPI.js +17 -7
  7. package/api/StopsAPI.d.ts +20 -14
  8. package/api/StopsAPI.js +17 -11
  9. package/api/WebSocketAPI.d.ts +60 -66
  10. package/api/WebSocketAPI.js +164 -164
  11. package/api/index.js +1 -1
  12. package/api/typedefs.d.ts +0 -102
  13. package/api/typedefs.js +27 -42
  14. package/common/controls/StopFinderControlCommon.d.ts +12 -12
  15. package/common/controls/StopFinderControlCommon.js +31 -31
  16. package/common/index.d.ts +1 -1
  17. package/common/index.js +1 -1
  18. package/common/mixins/RealtimeLayerMixin.d.ts +157 -163
  19. package/common/mixins/RealtimeLayerMixin.js +401 -393
  20. package/common/styles/realtimeDefaultStyle.js +6 -6
  21. package/common/styles/realtimeHeadingStyle.js +5 -5
  22. package/common/typedefs.d.ts +13 -6
  23. package/common/typedefs.js +7 -1
  24. package/common/utils/compareDepartures.d.ts +2 -2
  25. package/common/utils/compareDepartures.js +2 -2
  26. package/common/utils/debounceWebsocketMessages.d.ts +1 -1
  27. package/common/utils/getMapGlCopyrights.d.ts +1 -1
  28. package/common/utils/getMapGlCopyrights.js +3 -3
  29. package/common/utils/getRealtimeModeSuffix.d.ts +1 -0
  30. package/common/utils/getRealtimeModeSuffix.js +1 -0
  31. package/common/utils/getVehiclePosition.d.ts +5 -4
  32. package/common/utils/getVehiclePosition.js +9 -3
  33. package/common/utils/renderTrajectories.d.ts +1 -1
  34. package/common/utils/renderTrajectories.js +6 -6
  35. package/common/utils/sortAndFilterDepartures.d.ts +1 -1
  36. package/common/utils/sortAndFilterDepartures.js +1 -1
  37. package/common/utils/sortByDelay.d.ts +2 -2
  38. package/common/utils/sortByDelay.js +5 -1
  39. package/maplibre/layers/Layer.d.ts +1 -1
  40. package/maplibre/layers/Layer.js +1 -1
  41. package/maplibre/layers/RealtimeLayer.d.ts +87 -66
  42. package/maplibre/layers/RealtimeLayer.js +30 -6
  43. package/maplibre/utils/getSourceCoordinates.js +5 -5
  44. package/mbt.js +20988 -13287
  45. package/mbt.js.map +4 -4
  46. package/mbt.min.js +61 -58
  47. package/mbt.min.js.map +4 -4
  48. package/ol/controls/RoutingControl.d.ts +82 -89
  49. package/ol/controls/RoutingControl.js +217 -219
  50. package/ol/controls/StopFinderControl.d.ts +3 -3
  51. package/ol/controls/StopFinderControl.js +2 -2
  52. package/ol/index.d.ts +1 -0
  53. package/ol/index.js +1 -0
  54. package/ol/layers/Layer.d.ts +101 -0
  55. package/ol/layers/Layer.js +25 -0
  56. package/ol/layers/MaplibreLayer.d.ts +121 -24
  57. package/ol/layers/MaplibreLayer.js +98 -27
  58. package/ol/layers/MaplibreStyleLayer.d.ts +93 -91
  59. package/ol/layers/MaplibreStyleLayer.js +281 -257
  60. package/ol/layers/RealtimeLayer.d.ts +119 -121
  61. package/ol/layers/RealtimeLayer.js +143 -134
  62. package/ol/layers/VectorLayer.d.ts +18 -0
  63. package/ol/layers/VectorLayer.js +32 -0
  64. package/ol/layers/index.d.ts +2 -0
  65. package/ol/layers/index.js +3 -0
  66. package/ol/mixins/MobilityLayerMixin.d.ts +32 -34
  67. package/ol/mixins/PropertiesLayerMixin.d.ts +60 -51
  68. package/ol/mixins/PropertiesLayerMixin.js +114 -79
  69. package/ol/mixins/index.d.ts +1 -0
  70. package/ol/mixins/index.js +2 -0
  71. package/ol/renderers/MaplibreLayerRenderer.d.ts +0 -20
  72. package/ol/renderers/MaplibreLayerRenderer.js +142 -114
  73. package/ol/renderers/MaplibreStyleLayerRenderer.d.ts +6 -6
  74. package/ol/renderers/MaplibreStyleLayerRenderer.js +20 -23
  75. package/ol/renderers/RealtimeLayerRenderer.d.ts +6 -6
  76. package/ol/renderers/RealtimeLayerRenderer.js +56 -51
  77. package/ol/utils/getFeatureInfoAtCoordinate.d.ts +1 -1
  78. package/ol/utils/getFeatureInfoAtCoordinate.js +11 -17
  79. package/package.json +31 -31
  80. package/setupTests.js +3 -4
  81. package/types/common.d.ts +55 -48
  82. package/types/index.d.ts +1 -1
  83. package/types/realtime.d.ts +91 -93
  84. package/types/routing.d.ts +60 -60
  85. package/types/stops.d.ts +62 -62
  86. package/ol/layers/MapGlLayer.d.ts +0 -144
  87. package/ol/layers/MapGlLayer.js +0 -144
@@ -1,141 +1,136 @@
1
- import GeoJSON from 'ol/format/GeoJSON';
2
- import Source from 'ol/source/Source';
3
- import Feature, { FeatureLike } from 'ol/Feature';
4
1
  import { Map, MapEvent } from 'ol';
5
- import { ObjectEvent } from 'ol/Object';
2
+ import Feature, { FeatureLike } from 'ol/Feature';
3
+ import GeoJSON from 'ol/format/GeoJSON';
4
+ import { Vector as VectorLayer } from 'ol/layer';
6
5
  import Layer from 'ol/layer/Layer';
7
- import { RealtimeLayerMixinOptions } from '../../common/mixins/RealtimeLayerMixin';
8
- import { RealtimeFullTrajectory, RealtimeTrainId, ViewState } from '../../types';
9
- import { RealtimeTrajectory } from '../../api/typedefs';
6
+ import { ObjectEvent } from 'ol/Object';
7
+ import Source from 'ol/source/Source';
10
8
  import { WebSocketAPIMessageEventData } from '../../api/WebSocketAPI';
9
+ import { RealtimeLayerMixinOptions } from '../../common/mixins/RealtimeLayerMixin';
10
+ import { RealtimeFullTrajectory, RealtimeTrainId, RealtimeTrajectory, ViewState } from '../../types';
11
11
  import RealtimeLayerRenderer from '../renderers/RealtimeLayerRenderer';
12
- export type RealtimeLayerOptions = RealtimeLayerMixinOptions & {
13
- fullTrajectoryStyle?: (feature: FeatureLike, resolution: number, options: any) => void;
12
+ export type RealtimeLayerOptions = {
14
13
  allowRenderWhenAnimating?: boolean;
15
- };
14
+ fullTrajectoryStyle?: (feature: FeatureLike, resolution: number, options: any) => void;
15
+ } & RealtimeLayerMixinOptions;
16
16
  declare const RealtimeLayer_base: {
17
17
  new (options: RealtimeLayerMixinOptions): {
18
18
  [x: string]: any;
19
+ [x: symbol]: any;
20
+ api: import("..").RealtimeAPI;
21
+ bboxParameters?: Record<string, boolean | boolean[] | number | number[] | string | string[]>;
22
+ canvas?: import("../../types").AnyCanvas;
23
+ debounceRenderTrajectories: (viewState: ViewState, noInterpolate?: boolean) => void;
19
24
  debug: boolean;
20
- trajectories?: {
21
- [key: string]: GeoJSONFeature;
22
- } | undefined;
23
- canvas?: import("../../types").AnyCanvas | undefined;
24
- mode: import("../../types").RealtimeMode;
25
- api: import("../../api/RealtimeAPI").default;
26
- tenant: string;
27
- bboxParameters?: {
28
- [index: string]: string | number | boolean | string[] | number[] | boolean[];
29
- } | undefined;
30
- time?: Date | undefined;
31
- live?: boolean | undefined;
32
- speed?: number | undefined;
33
- filter?: Function | undefined;
34
- sort?: Function | undefined;
35
- style?: import("../../types").RealtimeStyleFunction | undefined;
36
- styleOptions?: import("../../types").RealtimeStyleOptions | undefined;
37
- pixelRatio?: number | undefined;
38
- minZoomInterpolation: number;
25
+ filter?: import("../../common/typedefs").FilterFunction;
26
+ format: GeoJSON;
27
+ generalizationLevel?: import("../../types").RealtimeGeneralizationLevel;
28
+ generalizationLevelByZoom: import("../../types").RealtimeGeneralizationLevel[];
29
+ getGeneralizationLevelByZoom: (zoom: number) => import("../../types").RealtimeGeneralizationLevel;
30
+ getMotsByZoom: (zoom: number) => import("../../types").RealtimeMot[];
31
+ getRenderTimeIntervalByZoom: (zoom: number) => number;
32
+ hoverVehicleId?: RealtimeTrainId;
39
33
  isUpdateBboxOnMoveEnd: boolean;
40
- hoverVehicleId?: string | undefined;
41
- selectedVehicleId?: string | undefined;
42
- renderState?: import("../../types").RealtimeRenderState | undefined;
43
- useRequestAnimationFrame?: boolean | undefined;
44
- useDebounce?: boolean | undefined;
45
- useThrottle?: boolean | undefined;
46
- mots?: import("../../types").RealtimeMot[] | undefined;
34
+ live?: boolean;
35
+ minZoomInterpolation: number;
36
+ mode: import("../../types").RealtimeMode;
37
+ mots?: import("../../types").RealtimeMot[];
47
38
  motsByZoom: import("../../types").RealtimeMot[][];
48
- generalizationLevel?: import("../../types").RealtimeGeneralizationLevel | undefined;
49
- generalizationLevelByZoom: import("../../types").RealtimeGeneralizationLevel[];
39
+ onStart?: ((realtimeLayer: import("../../types").AnyLayer) => void) | undefined;
40
+ onStop?: ((realtimeLayer: import("../../types").AnyLayer) => void) | undefined;
41
+ pixelRatio?: number;
42
+ renderState?: import("../../types").RealtimeRenderState;
50
43
  renderTimeIntervalByZoom: number[];
51
- format: GeoJSON<typeof Feature>;
52
- requestId?: number | undefined;
53
- updateTimeInterval?: number | undefined;
54
- updateTimeDelay?: number | undefined;
44
+ requestId?: number;
45
+ selectedVehicle: RealtimeTrajectory;
46
+ selectedVehicleId?: RealtimeTrainId;
47
+ sort?: import("../../common/typedefs").SortFunction;
48
+ speed?: number;
49
+ style?: import("../../types").RealtimeStyleFunction;
50
+ styleOptions?: import("../../types").RealtimeStyleOptions;
51
+ tenant: import("../../types").RealtimeTenant;
52
+ throttleRenderTrajectories: (viewState: ViewState, noInterpolate?: boolean) => void;
53
+ time?: Date;
54
+ trajectories?: Record<RealtimeTrainId, RealtimeTrajectory>;
55
+ updateTimeDelay?: number;
56
+ updateTimeInterval?: number;
57
+ useDebounce?: boolean;
58
+ useRequestAnimationFrame?: boolean;
59
+ useThrottle?: boolean;
55
60
  visibilityRef: import("ol/events").EventsKey;
56
- selectedVehicle: GeoJSONFeature;
57
- getMotsByZoom: (zoom: number) => import("../../types").RealtimeMot[];
58
- getGeneralizationLevelByZoom: (zoom: number) => import("../../types").RealtimeGeneralizationLevel;
59
- getRenderTimeIntervalByZoom: (zoom: number) => number;
60
- throttleRenderTrajectories: (viewState: ViewState, noInterpolate?: boolean | undefined) => void;
61
- debounceRenderTrajectories: (viewState: ViewState, noInterpolate?: boolean | undefined) => void;
62
- onStart?: ((realtimeLayer: any) => void) | undefined;
63
- onStop?: ((realtimeLayer: any) => void) | undefined;
61
+ addTrajectory(trajectory: RealtimeTrajectory): void;
62
+ attachToMap(map: import("../../types").AnyMap): void;
64
63
  defineProperties(options: RealtimeLayerMixinOptions): void;
65
- attachToMap(map: any): void;
66
64
  detachFromMap(): void;
65
+ getFeatureInfoAtCoordinate(coordinate: import("ol/coordinate").Coordinate, options: import("../../types").LayerGetFeatureInfoOptions): Promise<import("../../types").LayerGetFeatureInfoResponse>;
66
+ getRefreshTimeInMs(zoom?: number | undefined): number;
67
+ getTrajectoryInfos(id: RealtimeTrainId): Promise<{
68
+ fullTrajectory: WebSocketAPIMessageEventData<import("../../types").RealtimeStopSequence[]> | WebSocketAPIMessageEventData<RealtimeFullTrajectory>;
69
+ stopSequence: WebSocketAPIMessageEventData<import("../../types").RealtimeStopSequence[]> | WebSocketAPIMessageEventData<RealtimeFullTrajectory>;
70
+ }>;
71
+ getVehicle(filterFc: import("../../common/typedefs").FilterFunction): RealtimeTrajectory[];
72
+ highlightVehicle(id: RealtimeTrainId): void;
73
+ onDeleteTrajectoryMessage(data: WebSocketAPIMessageEventData<RealtimeTrainId>): void;
74
+ onDocumentVisibilityChange(): void;
75
+ onTrajectoryMessage(data: WebSocketAPIMessageEventData<RealtimeTrajectory>): void;
76
+ onZoomEnd(): void;
77
+ purgeOutOfDateTrajectories(): void;
78
+ purgeTrajectory(trajectory: RealtimeTrajectory, extent: [number, number, number, number], zoom: number): boolean;
79
+ removeTrajectory(trajectoryOrId: RealtimeTrainId | RealtimeTrajectory): void;
80
+ renderTrajectories(viewState: undefined | ViewState, noInterpolate: boolean | undefined): void;
81
+ renderTrajectoriesInternal(viewState: ViewState, noInterpolate?: boolean): boolean;
82
+ selectVehicle(id: RealtimeTrainId): void;
83
+ setBbox(extent: [number, number, number, number], zoom: number): void;
67
84
  start(): void;
68
85
  startUpdateTime(): void;
69
86
  stop(): void;
70
87
  stopUpdateTime(): void;
71
- renderTrajectoriesInternal(viewState: ViewState, noInterpolate?: boolean): boolean;
72
- renderTrajectories(viewState: ViewState | undefined, noInterpolate: boolean | undefined): void;
73
- setBbox(extent: [number, number, number, number], zoom: number): void;
74
- getRefreshTimeInMs(zoom?: number | undefined): number;
75
- getVehicle(filterFc: Function): GeoJSONFeature[];
76
- getFeatureInfoAtCoordinate(coordinate: import("ol/coordinate").Coordinate, options: import("../../types").LayerGetFeatureInfoOptions): Promise<import("../../types").LayerGetFeatureInfoResponse>;
77
- getTrajectoryInfos(id: string): Promise<{
78
- stopSequence: WebSocketAPIMessageEventData<RealtimeFullTrajectory> | WebSocketAPIMessageEventData<GeoJSONFeature[]>;
79
- fullTrajectory: WebSocketAPIMessageEventData<RealtimeFullTrajectory> | WebSocketAPIMessageEventData<GeoJSONFeature[]>;
80
- }>;
81
- purgeOutOfDateTrajectories(): void;
82
- purgeTrajectory(trajectory: GeoJSONFeature, extent: [number, number, number, number], zoom: number): boolean;
83
- addTrajectory(trajectory: GeoJSONFeature): void;
84
- removeTrajectory(trajectoryOrId: any): void;
85
- onZoomEnd(): void;
86
- onDocumentVisibilityChange(): void;
87
- onTrajectoryMessage(data: WebSocketAPIMessageEventData<GeoJSONFeature>): void;
88
- onDeleteTrajectoryMessage(data: WebSocketAPIMessageEventData<string>): void;
89
- highlightVehicle(id: string): void;
90
- selectVehicle(id: string): void;
91
88
  };
92
89
  } & {
93
90
  new (...args: any[]): {
94
- options?: import("../mixins/PropertiesLayerMixin").PropertiesLayerMixinOptions | undefined;
95
- olListenersKeys: import("ol/events").EventsKey[];
91
+ olEventsKeys: import("ol/events").EventsKey[];
92
+ options?: import("../mixins/PropertiesLayerMixin").PropertiesLayerMixinOptions;
93
+ attachToMap(map: Map): void;
94
+ detachFromMap(): void;
95
+ flat(): any[];
96
+ onChildrenChange(oldValue: Layer[]): void;
97
+ setMapInternal: ((map: Map) => void) & ((map: import("ol/Map").default | null) => void);
96
98
  children: Layer<Source, import("ol/renderer/Layer").default<any>>[];
97
99
  get copyrights(): string;
98
100
  set copyrights(newCopyrights: string | string[]);
99
101
  disabled: boolean;
100
102
  readonly group: string;
101
- readonly hitTolerance: boolean;
103
+ readonly hitTolerance: number;
102
104
  readonly key: string;
103
105
  readonly map: Map;
104
106
  readonly name: string;
105
- olLayer: Layer<Source, import("ol/renderer/Layer").default<any>>;
107
+ olLayer: Layer;
106
108
  parent: Layer<Source, import("ol/renderer/Layer").default<any>>;
107
109
  visible: boolean;
108
- setMapInternal: ((map: Map) => void) & ((map: Map | null) => void);
109
- onChildrenChange(oldValue: Layer<Source, import("ol/renderer/Layer").default<any>>[]): void;
110
- attachToMap(map: Map): void;
111
- detachFromMap(): void;
112
- flat(): any[];
113
- addEventListener: (type: string, listener: import("ol/events").Listener) => void;
114
- removeEventListener: (type: string, listener: import("ol/events").Listener) => void;
115
110
  on: import("ol/layer/Layer").LayerOnSignature<import("ol/events").EventsKey>;
116
- render: (frameState: import("ol/Map").FrameState | null, target: HTMLElement) => HTMLElement | null;
117
111
  once: import("ol/layer/Layer").LayerOnSignature<import("ol/events").EventsKey>;
118
112
  un: import("ol/layer/Layer").LayerOnSignature<void>;
113
+ render: (frameState: import("ol/Map").FrameState | null, target: HTMLElement) => HTMLElement | null;
119
114
  getSource: () => Source | null;
120
115
  getRenderSource: () => Source | null;
121
- getFeatures: (pixel: import("ol/pixel").Pixel) => Promise<FeatureLike[]>;
122
- getData: (pixel: import("ol/pixel").Pixel) => Float32Array | Uint8ClampedArray | Uint8Array | DataView | null;
123
- isVisible: (view?: import("ol/View").default | import("ol/View").ViewStateLayerStateExtent | undefined) => boolean;
124
- getAttributions: (view?: import("ol/View").default | import("ol/View").ViewStateLayerStateExtent | undefined) => string[];
116
+ getFeatures: (pixel: import("ol/pixel").Pixel) => Promise<Array<import("ol/Feature").FeatureLike>>;
117
+ getData: (pixel: import("ol/pixel").Pixel) => Uint8ClampedArray | Uint8Array | Float32Array | DataView | null;
118
+ isVisible: (view?: import("ol").View | import("ol/View").ViewStateLayerStateExtent | undefined) => boolean;
119
+ getAttributions: (view?: import("ol").View | import("ol/View").ViewStateLayerStateExtent | undefined) => Array<string>;
125
120
  unrender: () => void;
126
121
  getDeclutter: () => string;
127
122
  renderDeclutter: (frameState: import("ol/Map").FrameState, layerState: import("ol/layer/Layer").State) => void;
128
123
  renderDeferred: (frameState: import("ol/Map").FrameState) => void;
129
- getMapInternal: () => Map | null;
130
- setMap: (map: Map | null) => void;
124
+ getMapInternal: () => import("ol/Map").default | null;
125
+ setMap: (map: import("ol/Map").default | null) => void;
131
126
  setSource: (source: Source | null) => void;
132
127
  getRenderer: () => import("ol/renderer/Layer").default<any> | null;
133
128
  hasRenderer: () => boolean;
134
- getBackground: () => false | import("ol/layer/Base").BackgroundColor;
129
+ getBackground: () => import("ol/layer/Base").BackgroundColor | false;
135
130
  getClassName: () => string;
136
131
  getLayerState: (managed?: boolean | undefined) => import("ol/layer/Layer").State;
137
- getLayersArray: (array?: Layer<Source, import("ol/renderer/Layer").default<any>>[] | undefined) => Layer<Source, import("ol/renderer/Layer").default<any>>[];
138
- getLayerStatesArray: (states?: import("ol/layer/Layer").State[] | undefined) => import("ol/layer/Layer").State[];
132
+ getLayersArray: (array?: import("ol/layer/Layer").default<import("ol/source/Source").default, import("ol/renderer/Layer").default<any>>[] | undefined) => Array<import("ol/layer/Layer").default>;
133
+ getLayerStatesArray: (states?: import("ol/layer/Layer").State[] | undefined) => Array<import("ol/layer/Layer").State>;
139
134
  getExtent: () => import("ol/extent").Extent | undefined;
140
135
  getMaxResolution: () => number;
141
136
  getMinResolution: () => number;
@@ -155,7 +150,7 @@ declare const RealtimeLayer_base: {
155
150
  setVisible: (visible: boolean) => void;
156
151
  setZIndex: (zindex: number) => void;
157
152
  get: (key: string) => any;
158
- getKeys: () => string[];
153
+ getKeys: () => Array<string>;
159
154
  getProperties: () => {
160
155
  [x: string]: any;
161
156
  };
@@ -173,14 +168,16 @@ declare const RealtimeLayer_base: {
173
168
  unset: (key: string, silent?: boolean | undefined) => void;
174
169
  changed: () => void;
175
170
  getRevision: () => number;
176
- dispatchEvent: (event: string | import("ol/events/Event").default) => boolean | undefined;
177
- getListeners: (type: string) => import("ol/events").Listener[] | undefined;
171
+ addEventListener: (type: string, listener: import("ol/events").Listener) => void;
172
+ dispatchEvent: (event: import("ol/events/Event").default | string) => boolean | undefined;
173
+ getListeners: (type: string) => Array<import("ol/events").Listener> | undefined;
178
174
  hasListener: (type?: string | undefined) => boolean;
175
+ removeEventListener: (type: string, listener: import("ol/events").Listener) => void;
179
176
  dispose: () => void;
180
177
  };
181
178
  } & typeof Layer;
182
179
  /**
183
- * Responsible for loading and display data from the geOps realtime API.
180
+ * An OpenLayers layer able to display data from the [geOps Realtime API](https://developer.geops.io/apis/realtime/).
184
181
  *
185
182
  * @example
186
183
  * import { RealtimeLayer } from 'mobility-toolbox-js/ol';
@@ -202,52 +199,57 @@ declare const RealtimeLayer_base: {
202
199
  declare class RealtimeLayer extends RealtimeLayer_base {
203
200
  /** @private */
204
201
  allowRenderWhenAnimating?: boolean;
202
+ vectorLayer: VectorLayer<Feature>;
205
203
  /**
206
204
  * Constructor.
207
205
  *
208
206
  * @param {RealtimeLayerOptions} options
209
207
  * @param {boolean} [options.allowRenderWhenAnimating=false] Allow rendering of the layer when the map is animating.
210
208
  * @param {string} options.apiKey Access key for [geOps apis](https://developer.geops.io/).
211
- * @param {string} [options.url="wss://api.geops.io/tracker-ws/v1/"] The geOps realtime API url.
209
+ * @param {string} [options.url="wss://api.geops.io/tracker-ws/v1/"] The geOps Realtime API url.
212
210
  *
213
211
  */
214
212
  constructor(options: RealtimeLayerOptions);
215
- /**
216
- * @private
217
- */
218
- createRenderer(): RealtimeLayerRenderer;
219
213
  /** @private */
220
214
  attachToMap(map: Map): void;
221
215
  /**
222
- * Destroy the container of the tracker.
216
+ * Create a copy of the RealtimeLayer.
217
+ * @param {Object} newOptions Options to override
218
+ * @return {RealtimeLayer} A RealtimeLayer
219
+ */
220
+ clone(newOptions: RealtimeLayerOptions): RealtimeLayer;
221
+ /**
223
222
  * @private
224
223
  */
225
- detachFromMap(): void;
224
+ createRenderer(): RealtimeLayerRenderer;
226
225
  /**
227
226
  * Render the trajectories using current map's size, resolution and rotation.
228
227
  * @param {boolean} noInterpolate if true, renders the vehicles without interpolating theirs positions.
229
228
  * @overrides
230
229
  * @private
231
230
  */
232
- renderTrajectories(noInterpolate: boolean): void;
233
231
  /**
234
- * Launch renderTrajectories. it avoids duplicating code in renderTrajectories methhod.
232
+ * Destroy the container of the tracker.
235
233
  * @private
236
- * @override
237
234
  */
238
- renderTrajectoriesInternal(viewState: ViewState, noInterpolate: boolean): boolean;
235
+ detachFromMap(): void;
239
236
  /**
240
237
  * Return the delay in ms before the next rendering.
241
238
  * @private
242
239
  */
243
240
  getRefreshTimeInMs(): number;
241
+ highlight(feature: Feature): void;
244
242
  /**
245
243
  * On move end we update the websocket with the new bbox.
246
244
  *
247
245
  * @private
248
246
  * @override
249
247
  */
250
- onMoveEnd(evt: MapEvent | ObjectEvent): void;
248
+ /**
249
+ * Highlight the trajectory of journey.
250
+ * @private
251
+ */
252
+ highlightTrajectory(id: RealtimeTrainId): Promise<Feature[] | undefined>;
251
253
  /**
252
254
  * Function called on moveend event only when the zoom has changed.
253
255
  *
@@ -255,31 +257,27 @@ declare class RealtimeLayer extends RealtimeLayer_base {
255
257
  * @private
256
258
  * @override
257
259
  */
260
+ onMoveEnd(evt: MapEvent | ObjectEvent): void;
258
261
  onZoomEnd(): void;
259
- highlight(feature: Feature): void;
260
- select(feature: Feature): void;
261
262
  /**
262
263
  * Remove the trajectory form the list if necessary.
263
264
  *
264
265
  * @private
265
266
  */
266
267
  purgeTrajectory(trajectory: RealtimeTrajectory, extent: [number, number, number, number], zoom: number): boolean;
268
+ renderTrajectories(noInterpolate: boolean): void;
267
269
  /**
268
- * Send the current bbox to the websocket
269
- *
270
+ * Launch renderTrajectories. it avoids duplicating code in renderTrajectories methhod.
270
271
  * @private
272
+ * @override
271
273
  */
272
- setBbox(extent?: [number, number, number, number], zoom?: number): void;
274
+ renderTrajectoriesInternal(viewState: ViewState, noInterpolate: boolean): boolean;
275
+ select(feature: Feature): void;
273
276
  /**
274
- * Highlight the trajectory of journey.
277
+ * Send the current bbox to the websocket
278
+ *
275
279
  * @private
276
280
  */
277
- highlightTrajectory(id: RealtimeTrainId): Promise<Feature[] | undefined>;
278
- /**
279
- * Create a copy of the RealtimeLayer.
280
- * @param {Object} newOptions Options to override
281
- * @return {RealtimeLayer} A RealtimeLayer
282
- */
283
- clone(newOptions: RealtimeLayerOptions): RealtimeLayer;
281
+ setBbox(extent?: [number, number, number, number], zoom?: number): void;
284
282
  }
285
283
  export default RealtimeLayer;