1/** @jsxImportSource https://esm.sh/react@18.2.0?dev */
2import React, { useState } from "https://esm.sh/react@18.2.0?dev";
3
4interface CreateBranchProps {
25 };
26
27 const handleSubmit = async (e: React.FormEvent) => {
28 e.preventDefault();
29
1/** @jsxImportSource https://esm.sh/react@18.2.0?dev */
2import React, { useEffect, useState } from "https://esm.sh/react@18.2.0?dev";
3import { CreateBranch } from "./CreateBranch.tsx";
4
84
85 // Handle branch selection change
86 const handleBranchChange = (e: React.ChangeEvent<HTMLSelectElement>) => {
87 const newBranchId = e.target.value;
88 setBranchId(newBranchId);
1/** @jsxImportSource https://esm.sh/react@18.2.0 **/
2import { renderToString } from "https://esm.sh/react-dom@18.2.0/server";
3
4export default (req: Request) => {
1// @jsxImportSource https://esm.sh/react@18.2.0
2import React from "https://esm.sh/react@18.2.0";
3import { createRoot } from "https://esm.sh/react-dom@18.2.0/client";
4import { App } from "./components/App";
5
1// @jsxImportSource https://esm.sh/react@18.2.0
2import { useState, useRef, useEffect } from "https://esm.sh/react@18.2.0";
3
4interface MarkdownOutputProps {
1// @jsxImportSource https://esm.sh/react@18.2.0
2import { useState } from "https://esm.sh/react@18.2.0";
3
4interface CrawlFormProps {
11 const [depth, setDepth] = useState(3);
12
13 const handleSubmit = (e: React.FormEvent) => {
14 e.preventDefault();
15 if (!url) return;
1// @jsxImportSource https://esm.sh/react@18.2.0
2import { useState } from "https://esm.sh/react@18.2.0";
3import { CrawlForm } from "./CrawlForm";
4import { MarkdownOutput } from "./MarkdownOutput";
19- `frontend/` - Client-side code
20 - `index.html` - Main HTML template
21 - `index.tsx` - Frontend React code
22 - `components/` - React components
1/** @jsxImportSource https://esm.sh/react@18.2.0?dev */
2import { useLocalStorage } from "https://esm.sh/react-use?dev&deps=react@18.2.0&react-dom@18.2.0";
3import React, { useState, useEffect } from "https://esm.sh/react@18.2.0?dev";
4import { Chat } from "./Chat.tsx";
5import { Login } from "./Login.tsx";
1/** @jsxImportSource https://esm.sh/react@18.2.0?dev */
2import React, { useState, useRef, useEffect } from "https://esm.sh/react@18.2.0?dev";
3
4interface SvgEditorProps {
51
52 // Handle SVG code editing
53 const handleCodeChange = (e: React.ChangeEvent<HTMLTextAreaElement>) => {
54 const newContent = e.target.value;
55 setSvgContent(newContent);
60
61 // Handle SVG file upload
62 const handleFileUpload = (e: React.ChangeEvent<HTMLInputElement>) => {
63 const file = e.target.files?.[0];
64 if (!file) return;