cnn_visualizer / new /frontends /react /src /useAppLogic.ts
joel-woodfield's picture
Use the old react version temporarily
89ce55d
import { useState } from "react";
import usePyodideBackend from "./usePyodideBackend.ts";
export default function useAppLogic() {
const { getBackend, backendReady } = usePyodideBackend();
const [sampleImageUrl, setSampleImageUrl] = useState<string | null>(null);
const [sampleLabel, setSampleLabel] = useState<string | null>(null);
async function onImageFolderUpload(files: File[]) {
if (!backendReady) {
return;
}
await getBackend().handleImageFolderUpload(files);
}
async function getRandomSample() {
if (!backendReady) {
return;
}
const { imageUrl, label } = await getBackend().handleGetRandomSample();
setSampleImageUrl(prev => {
if (prev) {
URL.revokeObjectURL(prev);
}
return imageUrl;
});
setSampleLabel(label);
}
return {
getBackend,
backendReady,
onImageFolderUpload,
getRandomSample,
sampleImageUrl,
sampleLabel,
};
}