From 72fce2d402ccb734014262e17706d1b3f6f31643 Mon Sep 17 00:00:00 2001 From: Justin Lampley Date: Wed, 3 Nov 2021 14:31:32 -0400 Subject: [PATCH] Fix issue where an mdns record with no target will cause the wrong device to be selected. --- src/ui/views/ConfiguratorView/index.tsx | 31 +++++++++++++++++++++---- 1 file changed, 26 insertions(+), 5 deletions(-) diff --git a/src/ui/views/ConfiguratorView/index.tsx b/src/ui/views/ConfiguratorView/index.tsx index 44553e750..e5d29a665 100644 --- a/src/ui/views/ConfiguratorView/index.tsx +++ b/src/ui/views/ConfiguratorView/index.tsx @@ -677,12 +677,32 @@ const ConfiguratorView: FunctionComponent = (props) => { if (dnsDevice) { const targetName = dnsDevice.target.toUpperCase(); - const device = deviceTargets?.find((item) => { + // if targetName is an empty string, then return + if (targetName.trim().length === 0) { + return; + } + + const deviceMatches = deviceTargets?.filter((item) => { return item.targets.find((target) => { return target.name.toUpperCase().startsWith(targetName); }); }); + if (!deviceMatches || deviceMatches.length === 0) { + return; + } + + // if multiple device matches are found, then don't select any of them + // we do not know which one is correct and do not want to pick the wrong device. + if (deviceMatches.length > 1) { + console.error( + `multiple device matches found for target ${targetName}!` + ); + return; + } + + const device = deviceMatches[0]; + const dTarget = device?.targets.find((target) => { return target.flashingMethod === FlashingMethod.WIFI; @@ -690,14 +710,15 @@ const ConfiguratorView: FunctionComponent = (props) => { device?.targets[0].name || null; - setDeviceTarget(dTarget); + if (dTarget !== deviceTarget) { + setDeviceTarget(dTarget); + deviceOptionsRef?.current?.scrollIntoView({ behavior: 'smooth' }); + } setWifiDevice(dnsDevice.ip); - - deviceOptionsRef?.current?.scrollIntoView({ behavior: 'smooth' }); } }, - [deviceTargets, networkDevices] + [deviceTarget, deviceTargets, networkDevices] ); useEffect(() => {