mirror of
https://github.com/grafana/grafana.git
synced 2025-02-15 01:53:33 -06:00
* Fix: make webpack pickup workers written in TS * Add comlink to dependencies * Temporary fix: copy paste `toDataQueryError` from @grafana/runtime to avoid web dependencies * Implemented comlink-based centrifuge worker & worker proxy * Temporary fix: implement comlink transferHandlers for subscriptions and streamingdataframes * Move liveTimer filtering from CentrifugeService into GrafanaLiveService * Switch from CentrifugeService to CentrifugeServiceWorkerProxy in GrafanaLive * Naming fix * Refactor: move liveTimer-based data filtering from GrafanaLiveService to CentrifugeServiceWorker * observe dataStream on an async scheduler * Fix: - Unsubscribe is now propagated from the main thread to the worker, - improve worker&workerProxy types * Fix: Prettify types * Fix: Add error & complete observers * Docs: Add comment explaining the `subscriberTransferHandler` * Fix: Replace `StreamingDataFrameHandler` with explicitly converting StreamingDataFrame to a DataFrameDTO * Refactor: move liveTimer filtering to service.ts to make it easy to implement a `live-service-web-worker` feature flag * Feat: add `live-service-web-worker` feature flag * Fix: extract toDataQueryError.ts to a separate file within `@grafana-runtime` to avoid having a dependency from webworker to the whole package (@grafana-runtime/index.ts) * Update public/app/features/dashboard/dashgrid/liveTimer.ts Co-authored-by: Leon Sorokin <leeoniya@gmail.com> * Fix: fixed default import class in worker file * Fix: cast worker as Endpoint * Migrate from worker-loader to webpack native worker support v1 - broken prod build * Fix: Use custom path in HtmlWebpackPlugin * Fix: Loading workers from CDNs * Fix: Avoid issues with jest ESM support by mocking `createWorker` files * Fix: move the custom mockWorker rendering layout to `test/mocks` Co-authored-by: Leon Sorokin <leeoniya@gmail.com>
34 lines
1.4 KiB
TypeScript
34 lines
1.4 KiB
TypeScript
import * as comlink from 'comlink';
|
|
import { from, Observable, switchMap } from 'rxjs';
|
|
|
|
export const remoteObservableAsObservable = <T>(remoteObs: comlink.RemoteObject<Observable<T>>): Observable<T> =>
|
|
new Observable((subscriber) => {
|
|
// Passing the callbacks as 3 separate arguments is deprecated, but it's the only option for now
|
|
//
|
|
// RxJS recreates the functions via `Function.bind` https://github.com/ReactiveX/rxjs/blob/62aca850a37f598b5db6085661e0594b81ec4281/src/internal/Subscriber.ts#L169
|
|
// and thus erases the ProxyMarker created via comlink.proxy(fN) when the callbacks
|
|
// are grouped together in a Observer object (ie. { next: (v) => ..., error: (err) => ..., complete: () => ... })
|
|
//
|
|
// solution: TBD (autoproxy all functions?)
|
|
const remoteSubPromise = remoteObs.subscribe(
|
|
comlink.proxy((nextValueInRemoteObs: T) => {
|
|
subscriber.next(nextValueInRemoteObs);
|
|
}),
|
|
comlink.proxy((err) => {
|
|
subscriber.error(err);
|
|
}),
|
|
comlink.proxy(() => {
|
|
subscriber.complete();
|
|
})
|
|
);
|
|
return {
|
|
unsubscribe: () => {
|
|
remoteSubPromise.then((remoteSub) => remoteSub.unsubscribe());
|
|
},
|
|
};
|
|
});
|
|
|
|
export const promiseWithRemoteObservableAsObservable = <T>(
|
|
promiseWithProxyObservable: Promise<comlink.RemoteObject<Observable<T>>>
|
|
): Observable<T> => from(promiseWithProxyObservable).pipe(switchMap((val) => remoteObservableAsObservable(val)));
|