tidy(ui): clean up worker tasks when complete

This commit is contained in:
psychedelicious 2024-08-05 18:41:50 +10:00
parent 78f5ec44ad
commit c4fad4456e

View File

@ -122,15 +122,15 @@ export class CanvasManager {
log: Logger; log: Logger;
workerLog: Logger; workerLog: Logger;
_isDebugging: boolean;
isTransforming: PubSub<boolean>; isTransforming: PubSub<boolean>;
_store: Store<RootState>; _store: Store<RootState>;
_isFirstRender: boolean;
_prevState: CanvasV2State; _prevState: CanvasV2State;
_worker: Worker; _isFirstRender: boolean = true;
_tasks: Map<string, { task: GetBboxTask; onComplete: (extents: Extents | null) => void }>; _isDebugging: boolean = false;
_worker: Worker = new Worker(new URL('./worker.ts', import.meta.url), { type: 'module', name: 'worker' });
_tasks: Map<string, { task: GetBboxTask; onComplete: (extents: Extents | null) => void }> = new Map();
toolState: PubSub<CanvasV2State['tool']>; toolState: PubSub<CanvasV2State['tool']>;
currentFill: PubSub<RgbaColor>; currentFill: PubSub<RgbaColor>;
@ -149,7 +149,6 @@ export class CanvasManager {
this._store = store; this._store = store;
this.stateApi = new CanvasStateApi(this._store, this); this.stateApi = new CanvasStateApi(this._store, this);
this._prevState = this.stateApi.getState(); this._prevState = this.stateApi.getState();
this._isFirstRender = true;
this.log = logger('canvas').child((message) => { this.log = logger('canvas').child((message) => {
return { return {
@ -188,8 +187,6 @@ export class CanvasManager {
this.initialImage = new CanvasInitialImage(this.stateApi.getInitialImageState(), this); this.initialImage = new CanvasInitialImage(this.stateApi.getInitialImageState(), this);
this.stage.add(this.initialImage.konva.layer); this.stage.add(this.initialImage.konva.layer);
this._worker = new Worker(new URL('./worker.ts', import.meta.url), { type: 'module', name: 'worker' });
this._tasks = new Map();
this._worker.onmessage = (event: MessageEvent<ExtentsResult | WorkerLogMessage>) => { this._worker.onmessage = (event: MessageEvent<ExtentsResult | WorkerLogMessage>) => {
const { type, data } = event.data; const { type, data } = event.data;
if (type === 'log') { if (type === 'log') {
@ -204,6 +201,7 @@ export class CanvasManager {
return; return;
} }
task.onComplete(data.extents); task.onComplete(data.extents);
this._tasks.delete(data.id);
} }
}; };
this._worker.onerror = (event) => { this._worker.onerror = (event) => {
@ -212,7 +210,6 @@ export class CanvasManager {
this._worker.onmessageerror = () => { this._worker.onmessageerror = () => {
this.log.error('Worker message error'); this.log.error('Worker message error');
}; };
this._isDebugging = false;
this.isTransforming = new PubSub(false); this.isTransforming = new PubSub(false);
this.toolState = new PubSub(this.stateApi.getToolState()); this.toolState = new PubSub(this.stateApi.getToolState());