import {useEffect, useState} from 'react' import Doc from "./Doc.tsx"; import './App.css' import {isResultDoc, ResultDoc} from "./resultdoc.ts"; function App() { const [query, setQuery] = useState(''); const [data, setData] = useState([]); useEffect(() => { if (query.length == 0) { setData([]); return; } fetch(`http://127.0.0.1:5000/query?q=${query}`, { method: "GET" }) .then(res => res.json()) .then((data: unknown) => { if (Array.isArray(data) && data.every(isResultDoc)) { setData(data); } else { console.error("Retrieved data is invalid"); } }) }, [query]); return ( <>

CS172 Project

setQuery(e.target.value)}/> {/*Add this later if search becomes too long*/} {/**/}
{data.map((doc: ResultDoc) => )}
) } export default App