UNPKG

react-native-executorch

Version:

An easy way to run AI models in React Native with ExecuTorch

52 lines (50 loc) 1.42 kB
"use strict"; import { useEffect, useState } from 'react'; import { ETError, getError } from '../Error'; export const useModule = ({ module, model, preventLoad = false }) => { const [error, setError] = useState(null); const [isReady, setIsReady] = useState(false); const [isGenerating, setIsGenerating] = useState(false); const [downloadProgress, setDownloadProgress] = useState(0); const [moduleInstance] = useState(() => new module()); useEffect(() => { if (preventLoad) return; (async () => { setDownloadProgress(0); setError(null); try { setIsReady(false); await moduleInstance.load(model, setDownloadProgress); setIsReady(true); } catch (err) { setError(err.message); } })(); return () => { moduleInstance.delete(); }; // eslint-disable-next-line react-hooks/exhaustive-deps }, [moduleInstance, ...Object.values(model), preventLoad]); const forward = async (...input) => { if (!isReady) throw new Error(getError(ETError.ModuleNotLoaded)); if (isGenerating) throw new Error(getError(ETError.ModelGenerating)); try { setIsGenerating(true); return await moduleInstance.forward(...input); } finally { setIsGenerating(false); } }; return { error, isReady, isGenerating, downloadProgress, forward }; }; //# sourceMappingURL=useModule.js.map