mobility-toolbox-js 3.0.1-beta.0 → 3.0.1-beta.2

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 (78) hide show
  1. package/README.md +11 -3
  2. package/api/HttpAPI.js +1 -3
  3. package/api/RealtimeAPI.d.ts +47 -47
  4. package/api/RealtimeAPI.js +74 -74
  5. package/api/WebSocketAPI.js +0 -1
  6. package/common/controls/StopFinderControlCommon.d.ts +1 -1
  7. package/common/controls/StopFinderControlCommon.js +1 -1
  8. package/common/styles/realtimeDefaultStyle.js +0 -5
  9. package/common/styles/realtimeHeadingStyle.js +0 -5
  10. package/common/styles/realtimeSimpleStyle.d.ts +0 -1
  11. package/common/styles/realtimeSimpleStyle.js +0 -1
  12. package/common/typedefs.d.ts +0 -117
  13. package/common/typedefs.js +0 -31
  14. package/common/utils/RealtimeEngine.d.ts +214 -0
  15. package/common/utils/RealtimeEngine.js +554 -0
  16. package/common/utils/getLayersAsFlatArray.d.ts +0 -1
  17. package/common/utils/getLayersAsFlatArray.js +0 -1
  18. package/common/utils/getVehiclePosition.js +1 -4
  19. package/common/utils/realtimeConfig.d.ts +1 -1
  20. package/common/utils/realtimeConfig.js +0 -1
  21. package/common/utils/renderTrajectories.d.ts +1 -0
  22. package/common/utils/renderTrajectories.js +1 -0
  23. package/common/utils/sortAndFilterDepartures.d.ts +1 -0
  24. package/common/utils/sortAndFilterDepartures.js +1 -0
  25. package/maplibre/controls/CopyrightControl.d.ts +9 -6
  26. package/maplibre/controls/CopyrightControl.js +11 -8
  27. package/maplibre/layers/Layer.d.ts +7 -6
  28. package/maplibre/layers/Layer.js +1 -2
  29. package/maplibre/layers/RealtimeLayer.d.ts +54 -111
  30. package/maplibre/layers/RealtimeLayer.js +126 -114
  31. package/maplibre/utils/getSourceCoordinates.d.ts +1 -0
  32. package/maplibre/utils/getSourceCoordinates.js +5 -4
  33. package/mbt.js +6960 -14605
  34. package/mbt.js.map +4 -4
  35. package/mbt.min.js +68 -71
  36. package/mbt.min.js.map +4 -4
  37. package/ol/controls/CopyrightControl.d.ts +13 -5
  38. package/ol/controls/CopyrightControl.js +13 -5
  39. package/ol/controls/RoutingControl.d.ts +29 -18
  40. package/ol/controls/RoutingControl.js +44 -56
  41. package/ol/controls/StopFinderControl.d.ts +21 -2
  42. package/ol/controls/StopFinderControl.js +22 -3
  43. package/ol/index.d.ts +0 -1
  44. package/ol/index.js +0 -1
  45. package/ol/layers/Layer.d.ts +17 -92
  46. package/ol/layers/Layer.js +17 -3
  47. package/ol/layers/MaplibreLayer.d.ts +47 -114
  48. package/ol/layers/MaplibreLayer.js +102 -46
  49. package/ol/layers/MaplibreStyleLayer.d.ts +67 -147
  50. package/ol/layers/MaplibreStyleLayer.js +170 -123
  51. package/ol/layers/RealtimeLayer.d.ts +85 -218
  52. package/ol/layers/RealtimeLayer.js +170 -181
  53. package/ol/layers/VectorLayer.d.ts +1 -2
  54. package/ol/layers/VectorLayer.js +7 -6
  55. package/ol/renderers/MaplibreLayerRenderer.d.ts +9 -0
  56. package/ol/renderers/MaplibreLayerRenderer.js +35 -137
  57. package/ol/renderers/MaplibreStyleLayerRenderer.js +2 -2
  58. package/ol/renderers/RealtimeLayerRenderer.d.ts +1 -1
  59. package/ol/renderers/RealtimeLayerRenderer.js +6 -31
  60. package/ol/styles/fullTrajectoryDelayStyle.js +5 -7
  61. package/ol/styles/fullTrajectoryStyle.d.ts +1 -2
  62. package/ol/styles/fullTrajectoryStyle.js +5 -7
  63. package/ol/styles/routingStyle.d.ts +0 -1
  64. package/ol/styles/routingStyle.js +13 -10
  65. package/ol/utils/defineDeprecatedProperties.d.ts +10 -0
  66. package/ol/utils/defineDeprecatedProperties.js +180 -0
  67. package/package.json +40 -39
  68. package/setupTests.js +14 -0
  69. package/types/common.d.ts +4 -27
  70. package/types/realtime.d.ts +7 -2
  71. package/common/mixins/RealtimeLayerMixin.d.ts +0 -267
  72. package/common/mixins/RealtimeLayerMixin.js +0 -751
  73. package/ol/mixins/MobilityLayerMixin.d.ts +0 -96
  74. package/ol/mixins/MobilityLayerMixin.js +0 -6
  75. package/ol/mixins/PropertiesLayerMixin.d.ts +0 -136
  76. package/ol/mixins/PropertiesLayerMixin.js +0 -178
  77. package/ol/mixins/index.d.ts +0 -1
  78. package/ol/mixins/index.js +0 -2
@@ -1,181 +1,23 @@
1
+ import { DebouncedFunc } from 'lodash';
1
2
  import { Map, MapEvent } from 'ol';
3
+ import { EventsKey } from 'ol/events';
2
4
  import Feature, { FeatureLike } from 'ol/Feature';
3
- import GeoJSON from 'ol/format/GeoJSON';
4
- import { Vector as VectorLayer } from 'ol/layer';
5
5
  import Layer from 'ol/layer/Layer';
6
+ import VectorLayer from 'ol/layer/Vector';
6
7
  import { ObjectEvent } from 'ol/Object';
7
- import Source from 'ol/source/Source';
8
+ import { Vector as VectorSource } from 'ol/source';
9
+ import { State } from 'ol/View';
8
10
  import { WebSocketAPIMessageEventData } from '../../api/WebSocketAPI';
9
- import { RealtimeLayerMixinOptions } from '../../common/mixins/RealtimeLayerMixin';
10
- import { RealtimeFullTrajectory, RealtimeTrainId, RealtimeTrajectory, ViewState } from '../../types';
11
+ import { FilterFunction, SortFunction } from '../../common/typedefs';
12
+ import RealtimeEngine, { RealtimeEngineOptions } from '../../common/utils/RealtimeEngine';
13
+ import { RealtimeAPI } from '../../maplibre';
14
+ import { RealtimeFullTrajectory, RealtimeMode, RealtimeRenderState, RealtimeTrainId, ViewState } from '../../types';
11
15
  import RealtimeLayerRenderer from '../renderers/RealtimeLayerRenderer';
12
16
  export type RealtimeLayerOptions = {
13
17
  allowRenderWhenAnimating?: boolean;
14
18
  fullTrajectoryStyle?: (feature: FeatureLike, resolution: number, options: any) => void;
15
- } & RealtimeLayerMixinOptions;
16
- declare const RealtimeLayer_base: {
17
- new (options: RealtimeLayerMixinOptions): {
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;
24
- debug: boolean;
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;
33
- isUpdateBboxOnMoveEnd: boolean;
34
- live?: boolean;
35
- minZoomInterpolation: number;
36
- mode: import("../../types").RealtimeMode;
37
- mots?: import("../../types").RealtimeMot[];
38
- motsByZoom: import("../../types").RealtimeMot[][];
39
- onStart?: ((realtimeLayer: import("../../types").AnyLayer) => void) | undefined;
40
- onStop?: ((realtimeLayer: import("../../types").AnyLayer) => void) | undefined;
41
- pixelRatio?: number;
42
- renderState?: import("../../types").RealtimeRenderState;
43
- renderTimeIntervalByZoom: number[];
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;
60
- visibilityRef: import("ol/events").EventsKey;
61
- addTrajectory(trajectory: RealtimeTrajectory): void;
62
- attachToMap(map: import("../../types").AnyMap): void;
63
- defineProperties(options: RealtimeLayerMixinOptions): void;
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;
84
- start(): void;
85
- startUpdateTime(): void;
86
- stop(): void;
87
- stopUpdateTime(): void;
88
- };
89
- } & {
90
- new (...args: any[]): {
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);
98
- children: Layer<Source, import("ol/renderer/Layer").default<any>>[];
99
- get copyrights(): string;
100
- set copyrights(newCopyrights: string | string[]);
101
- disabled: boolean;
102
- readonly group: string;
103
- readonly hitTolerance: number;
104
- readonly key: string;
105
- readonly map: Map;
106
- readonly name: string;
107
- olLayer: Layer;
108
- parent: Layer<Source, import("ol/renderer/Layer").default<any>>;
109
- visible: boolean;
110
- on: import("ol/layer/Layer").LayerOnSignature<import("ol/events").EventsKey>;
111
- once: import("ol/layer/Layer").LayerOnSignature<import("ol/events").EventsKey>;
112
- un: import("ol/layer/Layer").LayerOnSignature<void>;
113
- render: (frameState: import("ol/Map").FrameState | null, target: HTMLElement) => HTMLElement | null;
114
- getSource: () => Source | null;
115
- getRenderSource: () => Source | null;
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>;
120
- unrender: () => void;
121
- getDeclutter: () => string;
122
- renderDeclutter: (frameState: import("ol/Map").FrameState, layerState: import("ol/layer/Layer").State) => void;
123
- renderDeferred: (frameState: import("ol/Map").FrameState) => void;
124
- getMapInternal: () => import("ol/Map").default | null;
125
- setMap: (map: import("ol/Map").default | null) => void;
126
- setSource: (source: Source | null) => void;
127
- getRenderer: () => import("ol/renderer/Layer").default<any> | null;
128
- hasRenderer: () => boolean;
129
- getBackground: () => import("ol/layer/Base").BackgroundColor | false;
130
- getClassName: () => string;
131
- getLayerState: (managed?: boolean | 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>;
134
- getExtent: () => import("ol/extent").Extent | undefined;
135
- getMaxResolution: () => number;
136
- getMinResolution: () => number;
137
- getMinZoom: () => number;
138
- getMaxZoom: () => number;
139
- getOpacity: () => number;
140
- getSourceState: () => import("ol/source/Source").State;
141
- getVisible: () => boolean;
142
- getZIndex: () => number | undefined;
143
- setBackground: (background?: import("ol/layer/Base").BackgroundColor | undefined) => void;
144
- setExtent: (extent: import("ol/extent").Extent | undefined) => void;
145
- setMaxResolution: (maxResolution: number) => void;
146
- setMinResolution: (minResolution: number) => void;
147
- setMaxZoom: (maxZoom: number) => void;
148
- setMinZoom: (minZoom: number) => void;
149
- setOpacity: (opacity: number) => void;
150
- setVisible: (visible: boolean) => void;
151
- setZIndex: (zindex: number) => void;
152
- get: (key: string) => any;
153
- getKeys: () => Array<string>;
154
- getProperties: () => {
155
- [x: string]: any;
156
- };
157
- getPropertiesInternal: () => {
158
- [x: string]: any;
159
- } | null;
160
- hasProperties: () => boolean;
161
- notify: (key: string, oldValue: any) => void;
162
- addChangeListener: (key: string, listener: import("ol/events").Listener) => void;
163
- removeChangeListener: (key: string, listener: import("ol/events").Listener) => void;
164
- set: (key: string, value: any, silent?: boolean | undefined) => void;
165
- setProperties: (values: {
166
- [x: string]: any;
167
- }, silent?: boolean | undefined) => void;
168
- unset: (key: string, silent?: boolean | undefined) => void;
169
- changed: () => void;
170
- getRevision: () => number;
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;
174
- hasListener: (type?: string | undefined) => boolean;
175
- removeEventListener: (type: string, listener: import("ol/events").Listener) => void;
176
- dispose: () => void;
177
- };
178
- } & typeof Layer;
19
+ maxNbFeaturesRequested?: number;
20
+ } & RealtimeEngineOptions;
179
21
  /**
180
22
  * An OpenLayers layer able to display data from the [geOps Realtime API](https://developer.geops.io/apis/realtime/).
181
23
  *
@@ -190,94 +32,119 @@ declare const RealtimeLayer_base: {
190
32
  *
191
33
  *
192
34
  * @see <a href="/api/class/src/api/RealtimeAPI%20js~RealtimeAPI%20html">RealtimeAPI</a>
35
+ * @see <a href="/example/ol-realtime">OpenLayers Realtime layer example</a>
36
+ *
193
37
  *
194
38
  * @extends {ol/layer/Layer~Layer}
195
39
  *
40
+ *
196
41
  * @classproperty {boolean} allowRenderWhenAnimating - Allow rendering of the layer when the map is animating.
197
42
  * @public
198
43
  */
199
- declare class RealtimeLayer extends RealtimeLayer_base {
200
- /** @private */
44
+ declare class RealtimeLayer extends Layer {
201
45
  allowRenderWhenAnimating?: boolean;
202
- vectorLayer: VectorLayer<Feature>;
46
+ currentZoom?: number;
47
+ engine: RealtimeEngine;
48
+ maxNbFeaturesRequested: number;
49
+ olEventsKeys: EventsKey[];
50
+ onMoveEndDebounced: DebouncedFunc<(evt: MapEvent | ObjectEvent) => void>;
51
+ onZoomEndDebounced: DebouncedFunc<(evt: MapEvent | ObjectEvent) => void>;
52
+ renderedViewState: State | undefined;
53
+ vectorLayer: VectorLayer<VectorSource>;
54
+ get api(): RealtimeAPI;
55
+ set api(api: RealtimeAPI);
56
+ get canvas(): import("../../types").AnyCanvas | undefined;
57
+ get filter(): FilterFunction | undefined;
58
+ set filter(filter: FilterFunction);
59
+ get hoverVehicleId(): RealtimeTrainId | undefined;
60
+ set hoverVehicleId(id: RealtimeTrainId);
61
+ get mode(): RealtimeMode;
62
+ set mode(mode: RealtimeMode);
63
+ get pixelRatio(): number | undefined;
64
+ get selectedVehicleId(): RealtimeTrainId | undefined;
65
+ set selectedVehicleId(id: RealtimeTrainId);
66
+ get sort(): SortFunction | undefined;
67
+ set sort(sort: SortFunction);
68
+ get trajectories(): Record<string, import("../../types").RealtimeTrajectory> | undefined;
203
69
  /**
204
70
  * Constructor.
205
71
  *
206
72
  * @param {RealtimeLayerOptions} options
207
73
  * @param {boolean} [options.allowRenderWhenAnimating=false] Allow rendering of the layer when the map is animating.
208
- * @param {string} options.apiKey Access key for [geOps apis](https://developer.geops.io/).
209
- * @param {string} [options.url="wss://api.geops.io/tracker-ws/v1/"] The geOps Realtime API url.
210
- *
74
+ * @param {string} options.apiKey Access key for [geOps APIs](https://developer.geops.io/).
75
+ * @param {string} [options.url="wss://api.geops.io/tracker-ws/v1/"] The [geOps Realtime API](https://developer.geops.io/apis/realtime/) url.
76
+ * @public
211
77
  */
212
78
  constructor(options: RealtimeLayerOptions);
213
- /** @private */
214
- attachToMap(map: Map): void;
79
+ attachToMap(): void;
215
80
  /**
216
81
  * Create a copy of the RealtimeLayer.
217
- * @param {Object} newOptions Options to override
82
+ *
83
+ * @param {Object} newOptions Options to override. See constructor.
218
84
  * @return {RealtimeLayer} A RealtimeLayer
85
+ * @public
219
86
  */
220
87
  clone(newOptions: RealtimeLayerOptions): RealtimeLayer;
221
- /**
222
- * @private
223
- */
224
88
  createRenderer(): RealtimeLayerRenderer;
225
- /**
226
- * Render the trajectories using current map's size, resolution and rotation.
227
- * @param {boolean} noInterpolate if true, renders the vehicles without interpolating theirs positions.
228
- * @overrides
229
- * @private
230
- */
231
89
  /**
232
90
  * Destroy the container of the tracker.
233
- * @private
234
91
  */
235
92
  detachFromMap(): void;
236
93
  /**
237
- * Return the delay in ms before the next rendering.
238
- * @private
239
- */
240
- getRefreshTimeInMs(): number;
241
- highlight(feature: Feature): void;
242
- /**
243
- * On move end we update the websocket with the new bbox.
94
+ * Get some informations about a trajectory.
244
95
  *
245
- * @private
246
- * @override
96
+ * @param {RealtimeTrainId} id A vehicle's id.
97
+ * @returns
247
98
  */
99
+ getTrajectoryInfos(id: RealtimeTrainId): Promise<{
100
+ fullTrajectory: WebSocketAPIMessageEventData<RealtimeFullTrajectory> | WebSocketAPIMessageEventData<import("../../types").RealtimeStopSequence[]>;
101
+ stopSequence: WebSocketAPIMessageEventData<RealtimeFullTrajectory> | WebSocketAPIMessageEventData<import("../../types").RealtimeStopSequence[]>;
102
+ }>;
103
+ getVehicles(filterFunc: FilterFunction): import("../../types").RealtimeTrajectory[];
104
+ getViewState(): {
105
+ center?: undefined;
106
+ extent?: undefined;
107
+ pixelRatio?: undefined;
108
+ resolution?: undefined;
109
+ rotation?: undefined;
110
+ size?: undefined;
111
+ visible?: undefined;
112
+ zoom?: undefined;
113
+ } | {
114
+ center: import("ol/coordinate").Coordinate | undefined;
115
+ extent: import("ol/extent").Extent;
116
+ pixelRatio: number | undefined;
117
+ resolution: number | undefined;
118
+ rotation: number;
119
+ size: import("ol/size").Size | undefined;
120
+ visible: boolean;
121
+ zoom: number | undefined;
122
+ };
123
+ highlight(feature: Feature): void;
248
124
  /**
249
125
  * Highlight the trajectory of journey.
250
- * @private
251
126
  */
252
127
  highlightTrajectory(id: RealtimeTrainId): Promise<Feature[] | undefined>;
128
+ onMoveEnd(): void;
253
129
  /**
254
- * Function called on moveend event only when the zoom has changed.
255
- *
256
- * @param {ol/MapEvent~MapEvent} evt Moveend event.
257
- * @private
258
- * @override
130
+ * Callback when the RealtimeEngine has rendered successfully.
259
131
  */
260
- onMoveEnd(evt: MapEvent | ObjectEvent): void;
132
+ onRealtimeEngineRender(renderState: RealtimeRenderState, viewState: ViewState): void;
261
133
  onZoomEnd(): void;
134
+ select(feature: Feature): void;
135
+ setMapInternal(map: Map): void;
136
+ shouldRender(): boolean | undefined;
262
137
  /**
263
- * Remove the trajectory form the list if necessary.
138
+ * Start the rendering.
264
139
  *
265
- * @private
140
+ * @public
266
141
  */
267
- purgeTrajectory(trajectory: RealtimeTrajectory, extent: [number, number, number, number], zoom: number): boolean;
268
- renderTrajectories(noInterpolate: boolean): void;
269
- /**
270
- * Launch renderTrajectories. it avoids duplicating code in renderTrajectories methhod.
271
- * @private
272
- * @override
273
- */
274
- renderTrajectoriesInternal(viewState: ViewState, noInterpolate: boolean): boolean;
275
- select(feature: Feature): void;
142
+ start(): void;
276
143
  /**
277
- * Send the current bbox to the websocket
144
+ * Stop the rendering.
278
145
  *
279
- * @private
146
+ * @public
280
147
  */
281
- setBbox(extent?: [number, number, number, number], zoom?: number): void;
148
+ stop(): void;
282
149
  }
283
150
  export default RealtimeLayer;