import { useEffect, useRef, useState } from "react"; import Head from "next/head"; import axios from "axios"; import CheckIcon from "@mui/icons-material/Check"; import ClearIcon from "@mui/icons-material/Clear"; import ContentCopyIcon from "@mui/icons-material/ContentCopy"; import VisibilityIcon from "@mui/icons-material/Visibility"; import VisibilityOffIcon from "@mui/icons-material/VisibilityOff"; import DeleteForeverIcon from "@mui/icons-material/DeleteForever"; import ExpandMoreIcon from "@mui/icons-material/ExpandMore"; import HourglassTopIcon from "@mui/icons-material/HourglassTop"; import PlayArrowIcon from "@mui/icons-material/PlayArrow"; import ReplayIcon from "@mui/icons-material/Replay"; import TextField from "@mui/material/TextField"; import { Fira_Code } from "next/font/google"; import Box from "@mui/material/Box"; import Stack from "@mui/material/Stack"; import Accordion from "@mui/material/Accordion"; import Typography from "@mui/material/Typography"; import AccordionSummary from "@mui/material/AccordionSummary"; import AccordionDetails from "@mui/material/AccordionDetails"; import Paper from "@mui/material/Paper"; import IconButton from "@mui/material/IconButton"; import List from "@mui/material/List"; import ListItem from "@mui/material/ListItem"; import { nanoid } from "nanoid"; import AppBar from "@mui/material/AppBar"; import Toolbar from "@mui/material/Toolbar"; import ListItemIcon from "@mui/material/ListItemIcon"; import ListItemButton from "@mui/material/ListItemButton"; import ListItemText from "@mui/material/ListItemText"; import { useHost } from "esdeka/react"; const base = { default: `/** 1.Base Script */ const canvas=document.querySelector('canvas'); const ctx=canvas.getContext('2d'); `, }; const fontMono = Fira_Code({ subsets: ["latin"], }); export default function Home() { const ref = useRef(null); const [template, setTemplate] = useState(base.default); const [runningId, setRunningId] = useState("1"); const [activeId, setActiveId] = useState("1"); const [answers, setAnswers] = useState<{ id: string; content: string; task: string }[]>([ { id: "1", content: base.default, task: "Base Script", }, ]); const [loading, setLoading] = useState(false); const { broadcast, call, subscribe } = useHost(ref, "fail4"); const connection = useRef(false); const [tries, setTries] = useState(5); // Send a connection request useEffect(() => { if (connection.current || tries <= 0) { return () => { /* Consistency */ }; } const timeout = setTimeout(() => { call({ template: "console.log('it works')" }); setTries(tries - 1); }, 200); call({ template: "console.log('it works')" }); return () => { clearTimeout(timeout); }; }, [call, tries]); useEffect(() => { if (!connection.current) { const unsubscribe = subscribe(event => { const { action } = event.data; switch (action.type) { case "answer": connection.current = true; break; default: break; } }); return () => { unsubscribe(); }; } return () => { /* Consistency */ }; }, [subscribe]); // Broadcast store to guest useEffect(() => { const current = answers.find(({ id }) => id === runningId); if (connection.current && current) { broadcast({ template: current.content }); } return () => { /* Consistency */ }; }, [broadcast, runningId, answers]); // useEffect(() => { // const current = answers.find(({ id }) => id === runningId); // if (current) { // void axios.post("/api/run", { // content: current.content, // }); // } // }, [runningId, answers]); const current = answers.find(({ id }) => id === activeId); return ( { event.preventDefault(); const formData = new FormData(event.target as HTMLFormElement); const formObject = Object.fromEntries(formData); try { setLoading(true); const { data } = await axios.post("/api/gpt", formObject); const answer = data; setAnswers([answer, ...answers]); setRunningId(answer.id); } catch (error) { console.error(error); } finally { setLoading(false); } }} > {loading ? : } {current?.task} - {current?.id ?? ""} { broadcast({ template: base.default }); //await axios.post("/api/run", { // content: // base.default, //}); setActiveId("1"); setTemplate(base.default); }} > Based on: {current?.task ?? "Base Script"} } aria-controls="panel1a-content" id="panel1a-header" > Options { setTemplate(event.target.value); }} /> {answers.map(answer => { return ( {answer.id === "1" ? undefined : ( { setAnswers( answers.filter(({ id }) => id !== answer.id) ); }} > )} { setRunningId(answer.id); }} > {runningId === answer.id ? ( ) : ( )} } disablePadding > { setActiveId(answer.id); setTemplate(answer.content); }} > {activeId === answer.id ? ( ) : ( )} ); })} { if (ref.current) { ref.current.src = `//localhost:8080?${nanoid()}`; } }} > ); }