fix(ui): bug when clearing processor

When clearing the processor config, we shouldn't re-process the image. This logic wasn't handled correctly, but coincidentally the bug didn't cause a user-facing issue.

Without a config, we had a runtime error when trying to build the node for the processor graph and the listener failed.

So while we didn't re-process the image, it was because there was an error, not because the logic was correct.

Fix this by bailing if there is no image or config.
This commit is contained in:
psychedelicious 2024-05-18 14:19:54 +10:00
parent 5127fd6320
commit af3fd26d4e

View File

@ -82,8 +82,11 @@ export const addControlAdapterPreprocessor = (startAppListening: AppStartListeni
} }
if (!image || !config) { if (!image || !config) {
// The user has reset the image or config, so we should clear the processed image // - If we have no image, we have nothing to process
// - If we have no processor config, we have nothing to process
// Clear the processed image and bail
dispatch(caLayerProcessedImageChanged({ layerId, imageDTO: null })); dispatch(caLayerProcessedImageChanged({ layerId, imageDTO: null }));
return;
} }
// At this point, the user has stopped fiddling with the processor settings and there is a processor selected. // At this point, the user has stopped fiddling with the processor settings and there is a processor selected.
@ -93,8 +96,8 @@ export const addControlAdapterPreprocessor = (startAppListening: AppStartListeni
cancelProcessorBatch(dispatch, layerId, layer.controlAdapter.processorPendingBatchId); cancelProcessorBatch(dispatch, layerId, layer.controlAdapter.processorPendingBatchId);
} }
// @ts-expect-error: TS isn't able to narrow the typing of buildNode and `config` will error... // TODO(psyche): I can't get TS to be happy, it thinkgs `config` is `never` but it should be inferred from the generic... I'll just cast it for now
const processorNode = CA_PROCESSOR_DATA[config.type].buildNode(image, config); const processorNode = CA_PROCESSOR_DATA[config.type].buildNode(image, config as never);
const enqueueBatchArg: BatchConfig = { const enqueueBatchArg: BatchConfig = {
prepend: true, prepend: true,
batch: { batch: {