2021-07-13 17:57:40 +02:00
|
|
|
/*
|
|
|
|
Copyright 2021 The Matrix.org Foundation C.I.C.
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import { defer, IDeferred } from "matrix-js-sdk/src/utils";
|
|
|
|
|
2021-07-14 20:16:34 +02:00
|
|
|
// @ts-ignore - `.ts` is needed here to make TS happy
|
2021-07-13 17:57:40 +02:00
|
|
|
import BlurhashWorker from "./workers/blurhash.worker.ts";
|
|
|
|
|
|
|
|
interface IBlurhashWorkerResponse {
|
|
|
|
seq: number;
|
|
|
|
blurhash: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export class BlurhashEncoder {
|
|
|
|
private static internalInstance = new BlurhashEncoder();
|
|
|
|
|
|
|
|
public static get instance(): BlurhashEncoder {
|
|
|
|
return BlurhashEncoder.internalInstance;
|
|
|
|
}
|
|
|
|
|
|
|
|
private readonly worker: Worker;
|
|
|
|
private seq = 0;
|
|
|
|
private pendingDeferredMap = new Map<number, IDeferred<string>>();
|
|
|
|
|
|
|
|
constructor() {
|
|
|
|
this.worker = new BlurhashWorker();
|
|
|
|
this.worker.onmessage = this.onMessage;
|
|
|
|
}
|
|
|
|
|
|
|
|
private onMessage = (ev: MessageEvent<IBlurhashWorkerResponse>) => {
|
|
|
|
const { seq, blurhash } = ev.data;
|
|
|
|
const deferred = this.pendingDeferredMap.get(seq);
|
|
|
|
if (deferred) {
|
|
|
|
this.pendingDeferredMap.delete(seq);
|
|
|
|
deferred.resolve(blurhash);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
public getBlurhash(imageData: ImageData): Promise<string> {
|
|
|
|
const seq = this.seq++;
|
|
|
|
const deferred = defer<string>();
|
|
|
|
this.pendingDeferredMap.set(seq, deferred);
|
|
|
|
this.worker.postMessage({ seq, imageData });
|
|
|
|
return deferred.promise;
|
|
|
|
}
|
|
|
|
}
|