disable photo button while working, remove unused css selector, trigger rec without onload event

This commit is contained in:
Sam Lavigne 2025-06-20 22:26:22 -04:00
parent 9c990e8614
commit 108794c7e1

View File

@ -1,5 +1,5 @@
<script>
import { onMount } from "svelte";
import { onMount, tick } from "svelte";
import * as faceapi from "@vladmandic/face-api";
import Cop from "./Cop.svelte";
@ -13,6 +13,7 @@
let databaseLoaded = $state(false);
let uploadedImageSrc = $state();
let matches = $state([]);
let working = $state(false);
let loaded = $derived(faceApiLoaded && databaseLoaded);
@ -104,9 +105,13 @@
}
function handleImageFile(e) {
working = true;
const reader = new FileReader();
reader.onload = function (e) {
uploadedImageSrc = e.target.result;
// instead of listening for an onload event in the image
// just call recognize after svelte re-renders
tick().then(recognize);
};
reader.readAsDataURL(e.target.files[0]);
}
@ -122,6 +127,7 @@
status =
"No faces detected in image. Please try a different image with clearly visible faces.";
matches = [];
working = false;
return;
}
@ -210,6 +216,7 @@
console.error("Error in face recognition:", error);
// updateStatus('Error processing uploaded image for face recognition.', 'red');
}
working = false;
}
function calculateEuclideanDistance(desc1, desc2) {
@ -251,20 +258,26 @@
{#if loaded}
<form>
<label for="image-input">Select Photo</label>
<label for="image-input" class={{ "loading-label": working }}>
{#if working}
Processing...
{:else}
Select Photo
{/if}
</label>
<input
oninput={handleImageFile}
id="image-input"
type="file"
accept="image/*"
hidden=""
disabled={working}
/>
</form>
<img
bind:this={uploadedImage}
src={uploadedImageSrc}
onload={recognize}
alt="User uploaded face"
class="uploaded-photo"
style:display={"none"}
@ -422,13 +435,6 @@
margin: 2rem 0;
}
.results-title {
margin-top: 2em;
margin-bottom: 1em;
border-top: 1px solid #333;
padding-top: 2em;
}
.about-link {
position: fixed;
top: 1rem;