feat: add upgrade flow for pre-2.0.0 (non-OTA) devices

This commit is contained in:
2025-09-23 14:08:14 +02:00
parent f3b1d76666
commit a940d1b480

View File

@@ -2,6 +2,7 @@
import { downloadBackup } from "$lib/backup/backup"; import { downloadBackup } from "$lib/backup/backup";
import { initSerial, serialPort } from "$lib/serial/connection"; import { initSerial, serialPort } from "$lib/serial/connection";
import { fade, slide } from "svelte/transition"; import { fade, slide } from "svelte/transition";
import { lt as semverLt } from "semver";
import type { LoaderOptions, ESPLoader } from "esptool-js"; import type { LoaderOptions, ESPLoader } from "esptool-js";
let { data } = $props(); let { data } = $props();
@@ -10,6 +11,10 @@
let success = $state(false); let success = $state(false);
let error = $state<Error | undefined>(undefined); let error = $state<Error | undefined>(undefined);
let isTooOld = $derived(
$serialPort ? semverLt($serialPort.version, "2.0.0") : false,
);
let unsafeUpdate = $state(false); let unsafeUpdate = $state(false);
let terminalOutput = $state(""); let terminalOutput = $state("");
@@ -202,10 +207,18 @@
style:--progress="{progress * 100}%" style:--progress="{progress * 100}%"
class:primary={!buttonError} class:primary={!buttonError}
class:error={buttonError} class:error={buttonError}
disabled={working || $serialPort === undefined || !isCorrectDevice} disabled={isTooOld ||
working ||
$serialPort === undefined ||
!isCorrectDevice}
onclick={update}>Apply Update</button onclick={update}>Apply Update</button
> >
{#if $serialPort && isCorrectDevice} {#if isTooOld}
<div class="error" transition:slide>
Your device's firmware is too old to be updated via OTA. Follow the
instruction below to update it manually.
</div>
{:else if $serialPort && isCorrectDevice}
<div transition:slide> <div transition:slide>
Your Your
<b <b
@@ -233,9 +246,11 @@
{/if} {/if}
</section> </section>
<label class="unsafe-opt-in" {#if !isTooOld}
><input type="checkbox" /> Unsafe recovery options</label <label class="unsafe-opt-in"
> ><input type="checkbox" /> Unsafe recovery options</label
>
{/if}
{/if} {/if}
<div class="unsafe-updates"> <div class="unsafe-updates">