Spaces:
Running
Running
timchen0618 commited on
Commit ·
5cc2a94
1
Parent(s): d14bce3
Add BrowseComp+ tab: dataset explorer with question, evidence docs, gold answer
Browse files- backend/api/browsecomp.py +61 -0
- backend/app.py +2 -1
- frontend/dist/assets/BrowseCompApp-Ss7Hzz4R.js +1 -0
- frontend/dist/assets/{ExperimentsApp-r9xSXake.js → ExperimentsApp-C94ZBe9g.js} +0 -0
- frontend/dist/assets/{ModelApp-Cw242jQN.js → ModelApp-CPeaZt0H.js} +1 -1
- frontend/dist/assets/{PlanRevisionsApp-CUfcVsmt.js → PlanRevisionsApp-C8SWmiEl.js} +1 -1
- frontend/dist/assets/{ScoutRunsApp-B_i5X87r.js → ScoutRunsApp-CnCOgFX5.js} +1 -1
- frontend/dist/assets/{SelectedToolsApp-BBGQyqN9.js → SelectedToolsApp-DsDxpPqt.js} +1 -1
- frontend/dist/assets/{SftDiffApp-D-nUoSxu.js → SftDiffApp-Da0Tj_1m.js} +1 -1
- frontend/dist/assets/{TrajExtApp-Y8_orlLr.js → TrajExtApp-DiG2ggVT.js} +1 -1
- frontend/dist/assets/VisualizerApp-B36fbafZ.js +0 -2
- frontend/dist/assets/VisualizerApp-Bwt-EqKk.js +2 -0
- frontend/dist/assets/{index-BewwkiJG.js → index-BWw4o19g.js} +0 -0
- frontend/dist/assets/index-CxBbYLho.css +0 -1
- frontend/dist/assets/index-bo0f-zdf.css +1 -0
- frontend/dist/index.html +2 -2
- frontend/src/browsecomp/BrowseCompApp.tsx +290 -0
- frontend/src/visualizer/VisualizerApp.tsx +8 -1
- frontend/tsconfig.app.tsbuildinfo +1 -1
- scripts/upload_browsecomp_plus.py +37 -0
backend/api/browsecomp.py
ADDED
|
@@ -0,0 +1,61 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
from flask import Blueprint, jsonify
|
| 2 |
+
from datasets import load_dataset
|
| 3 |
+
import json
|
| 4 |
+
|
| 5 |
+
bp = Blueprint("browsecomp", __name__, url_prefix="/api/browsecomp")
|
| 6 |
+
|
| 7 |
+
HF_REPO = "timchen0618/browsecomp-plus-benchmark"
|
| 8 |
+
|
| 9 |
+
_cache: list | None = None
|
| 10 |
+
|
| 11 |
+
|
| 12 |
+
def _load() -> list:
|
| 13 |
+
global _cache
|
| 14 |
+
if _cache is not None:
|
| 15 |
+
return _cache
|
| 16 |
+
ds = load_dataset(HF_REPO, split="train")
|
| 17 |
+
rows = []
|
| 18 |
+
for row in ds:
|
| 19 |
+
rows.append({
|
| 20 |
+
"query_id": row["query_id"],
|
| 21 |
+
"query": row["query"],
|
| 22 |
+
"answer": row["answer"],
|
| 23 |
+
"evidence_docs": json.loads(row["evidence_docs"]),
|
| 24 |
+
"gold_docs": json.loads(row["gold_docs"]),
|
| 25 |
+
})
|
| 26 |
+
_cache = rows
|
| 27 |
+
return rows
|
| 28 |
+
|
| 29 |
+
|
| 30 |
+
@bp.get("/")
|
| 31 |
+
def get_list():
|
| 32 |
+
try:
|
| 33 |
+
rows = _load()
|
| 34 |
+
# Return lightweight list (just query_id + query preview)
|
| 35 |
+
items = [{"query_id": r["query_id"], "query": r["query"]} for r in rows]
|
| 36 |
+
return jsonify({"items": items, "total": len(items)})
|
| 37 |
+
except Exception as e:
|
| 38 |
+
return jsonify({"error": str(e)}), 500
|
| 39 |
+
|
| 40 |
+
|
| 41 |
+
@bp.get("/<query_id>")
|
| 42 |
+
def get_example(query_id: str):
|
| 43 |
+
try:
|
| 44 |
+
rows = _load()
|
| 45 |
+
for row in rows:
|
| 46 |
+
if str(row["query_id"]) == query_id:
|
| 47 |
+
return jsonify(row)
|
| 48 |
+
return jsonify({"error": "not found"}), 404
|
| 49 |
+
except Exception as e:
|
| 50 |
+
return jsonify({"error": str(e)}), 500
|
| 51 |
+
|
| 52 |
+
|
| 53 |
+
@bp.post("/reload")
|
| 54 |
+
def reload():
|
| 55 |
+
global _cache
|
| 56 |
+
_cache = None
|
| 57 |
+
try:
|
| 58 |
+
rows = _load()
|
| 59 |
+
return jsonify({"status": "ok", "count": len(rows)})
|
| 60 |
+
except Exception as e:
|
| 61 |
+
return jsonify({"error": str(e)}), 500
|
backend/app.py
CHANGED
|
@@ -6,7 +6,7 @@ def create_app():
|
|
| 6 |
app = Flask(__name__, static_folder="../frontend/dist", static_url_path="/")
|
| 7 |
CORS(app)
|
| 8 |
|
| 9 |
-
from backend.api import model_datasets, presets, experiments, manifest, plan_revisions, traj_ext, selected_tools, sft_diff, scout_runs
|
| 10 |
app.register_blueprint(model_datasets.bp)
|
| 11 |
app.register_blueprint(presets.bp)
|
| 12 |
app.register_blueprint(experiments.bp)
|
|
@@ -16,6 +16,7 @@ def create_app():
|
|
| 16 |
app.register_blueprint(selected_tools.bp)
|
| 17 |
app.register_blueprint(sft_diff.bp)
|
| 18 |
app.register_blueprint(scout_runs.bp)
|
|
|
|
| 19 |
|
| 20 |
@app.route("/api/health")
|
| 21 |
def health():
|
|
|
|
| 6 |
app = Flask(__name__, static_folder="../frontend/dist", static_url_path="/")
|
| 7 |
CORS(app)
|
| 8 |
|
| 9 |
+
from backend.api import model_datasets, presets, experiments, manifest, plan_revisions, traj_ext, selected_tools, sft_diff, scout_runs, browsecomp
|
| 10 |
app.register_blueprint(model_datasets.bp)
|
| 11 |
app.register_blueprint(presets.bp)
|
| 12 |
app.register_blueprint(experiments.bp)
|
|
|
|
| 16 |
app.register_blueprint(selected_tools.bp)
|
| 17 |
app.register_blueprint(sft_diff.bp)
|
| 18 |
app.register_blueprint(scout_runs.bp)
|
| 19 |
+
app.register_blueprint(browsecomp.bp)
|
| 20 |
|
| 21 |
@app.route("/api/health")
|
| 22 |
def health():
|
frontend/dist/assets/BrowseCompApp-Ss7Hzz4R.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
|
|
|
|
| 1 |
+
import{r as s,j as e}from"./index-BWw4o19g.js";function S(){const[c,N]=s.useState([]),[l,i]=s.useState(""),[t,w]=s.useState(null),[k,m]=s.useState(!0),[_,g]=s.useState(!1),[h,y]=s.useState(null),[x,q]=s.useState(""),[b,f]=s.useState(0),[j,p]=s.useState(!1);s.useEffect(()=>{fetch("/api/browsecomp/").then(r=>{if(!r.ok)throw new Error(r.statusText);return r.json()}).then(r=>{N(r.items),r.items.length>0&&i(r.items[0].query_id),m(!1)}).catch(r=>{y(r.message),m(!1)})},[]),s.useEffect(()=>{l&&(g(!0),f(0),p(!1),fetch(`/api/browsecomp/${encodeURIComponent(l)}`).then(r=>{if(!r.ok)throw new Error(r.statusText);return r.json()}).then(r=>{w(r),g(!1)}).catch(r=>{y(r.message),g(!1)}))},[l]);const o=s.useMemo(()=>{if(!x.trim())return c;const r=x.toLowerCase();return c.filter(a=>a.query_id.includes(r)||a.query.toLowerCase().includes(r))},[c,x]),u=s.useMemo(()=>o.findIndex(r=>r.query_id===l),[o,l]),v=r=>{const a=u+r;a>=0&&a<o.length&&i(o[a].query_id)};if(k)return e.jsx("div",{className:"h-full flex items-center justify-center text-gray-400",children:"Loading BrowseComp-Plus examples…"});if(h)return e.jsxs("div",{className:"h-full flex items-center justify-center text-red-400",children:["Error: ",h]});const d=(t==null?void 0:t.evidence_docs)??[],n=d[b]??null;return e.jsxs("div",{className:"h-full flex bg-gray-950 text-gray-100",children:[e.jsxs("div",{className:"w-64 shrink-0 flex flex-col border-r border-gray-800 bg-gray-900",children:[e.jsxs("div",{className:"px-3 py-2 border-b border-gray-800 shrink-0",children:[e.jsx("div",{className:"text-[10px] text-gray-500 uppercase tracking-widest mb-1",children:"BrowseComp-Plus"}),e.jsxs("div",{className:"text-xs text-gray-400",children:[c.length," examples"]})]}),e.jsx("div",{className:"px-2 py-2 border-b border-gray-800 shrink-0",children:e.jsx("input",{type:"text",placeholder:"Search…",value:x,onChange:r=>q(r.target.value),className:"w-full bg-gray-800 border border-gray-700 text-gray-200 text-xs rounded px-2 py-1.5 placeholder-gray-500 focus:outline-none focus:border-purple-500"})}),e.jsxs("div",{className:"px-2 py-2 border-b border-gray-800 shrink-0",children:[e.jsx("div",{className:"text-[10px] text-gray-500 uppercase tracking-widest mb-1",children:"Example"}),e.jsx("select",{value:l,onChange:r=>i(r.target.value),className:"w-full bg-gray-800 border border-gray-700 text-gray-200 text-xs rounded px-2 py-1.5 focus:outline-none focus:border-purple-500",children:o.map(r=>e.jsxs("option",{value:r.query_id,children:["#",r.query_id]},r.query_id))})]}),e.jsxs("div",{className:"px-2 py-1.5 border-b border-gray-800 flex gap-1 shrink-0",children:[e.jsx("button",{onClick:()=>v(-1),disabled:u<=0,className:"flex-1 py-1 text-xs bg-gray-800 border border-gray-700 rounded disabled:opacity-30 hover:bg-gray-700 transition-colors",children:"← Prev"}),e.jsx("button",{onClick:()=>v(1),disabled:u>=o.length-1,className:"flex-1 py-1 text-xs bg-gray-800 border border-gray-700 rounded disabled:opacity-30 hover:bg-gray-700 transition-colors",children:"Next →"})]}),e.jsx("div",{className:"flex-1 overflow-y-auto",children:o.map(r=>e.jsxs("button",{onClick:()=>i(r.query_id),className:`w-full text-left px-3 py-2 border-b border-gray-800/50 text-xs transition-colors ${l===r.query_id?"bg-purple-900/40 text-purple-200 border-l-2 border-l-purple-500":"text-gray-400 hover:bg-gray-800"}`,children:[e.jsxs("span",{className:"font-mono text-purple-400/70",children:["#",r.query_id]}),e.jsxs("div",{className:"mt-0.5 text-gray-500 line-clamp-2 leading-tight",children:[r.query.slice(0,80),"…"]})]},r.query_id))})]}),e.jsx("div",{className:"flex-1 flex flex-col min-w-0 overflow-hidden",children:_?e.jsx("div",{className:"flex-1 flex items-center justify-center text-gray-500",children:"Loading example…"}):t?e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"shrink-0 border-b border-gray-800 bg-gray-900/50",children:[e.jsxs("div",{className:"px-4 py-2 flex items-center gap-3 border-b border-gray-800/50",children:[e.jsxs("span",{className:"font-mono text-purple-400 text-sm font-medium",children:["#",t.query_id]}),e.jsx("span",{className:"text-xs text-gray-500 uppercase tracking-wide",children:"Question"}),e.jsxs("span",{className:"ml-auto text-xs text-gray-600",children:[d.length," evidence doc",d.length!==1?"s":"",t.gold_docs.length>0&&` · ${t.gold_docs.length} gold doc${t.gold_docs.length!==1?"s":""}`]})]}),e.jsx("div",{className:"px-4 py-3 max-h-40 overflow-y-auto",children:e.jsx("p",{className:"text-sm text-gray-200 leading-relaxed whitespace-pre-wrap",children:t.query})})]}),e.jsxs("div",{className:"flex-1 flex flex-col min-h-0 overflow-hidden",children:[e.jsxs("div",{className:"shrink-0 flex items-center gap-0.5 px-2 py-1.5 border-b border-gray-800 bg-gray-900/30 overflow-x-auto",children:[e.jsx("span",{className:"text-[10px] text-gray-500 uppercase tracking-widest mr-2 shrink-0",children:"Evidence"}),d.map((r,a)=>e.jsxs("button",{onClick:()=>f(a),className:`px-2.5 py-1 text-xs rounded shrink-0 transition-colors border ${b===a?"bg-emerald-900/50 border-emerald-600 text-emerald-300":"bg-gray-800 border-gray-700 text-gray-400 hover:border-gray-500"}`,children:["Doc ",a+1]},r.docid)),d.length===0&&e.jsx("span",{className:"text-xs text-gray-600 italic",children:"No evidence documents"})]}),n&&e.jsxs("div",{className:"flex-1 overflow-y-auto",children:[e.jsxs("div",{className:"sticky top-0 px-4 py-2 bg-gray-900/90 border-b border-gray-800 flex items-center gap-3 backdrop-blur-sm",children:[e.jsxs("span",{className:"font-mono text-[10px] text-gray-500",children:["docid: ",n.docid]}),n.url&&e.jsx("a",{href:n.url,target:"_blank",rel:"noopener noreferrer",className:"text-xs text-blue-400 hover:text-blue-300 truncate max-w-xs",children:n.url})]}),e.jsx("div",{className:"px-4 py-3",children:e.jsx("pre",{className:"text-xs font-mono text-gray-300 whitespace-pre-wrap leading-relaxed",children:n.text})})]})]}),e.jsxs("div",{className:"shrink-0 border-t border-gray-800 bg-gray-900/70 px-4 py-2 flex items-center gap-3",children:[e.jsx("span",{className:"text-[10px] text-gray-500 uppercase tracking-widest shrink-0",children:"Gold Answer"}),j?e.jsx("span",{className:"text-sm font-semibold text-amber-300 flex-1",children:t.answer}):e.jsx("button",{onClick:()=>p(!0),className:"text-xs bg-gray-800 border border-gray-700 text-gray-400 hover:text-gray-200 rounded px-2 py-0.5 transition-colors",children:"Reveal answer"}),j&&e.jsx("button",{onClick:()=>p(!1),className:"text-xs text-gray-600 hover:text-gray-400 ml-auto",children:"Hide"})]})]}):e.jsx("div",{className:"flex-1 flex items-center justify-center text-gray-500",children:"Select an example"})})]})}export{S as default};
|
frontend/dist/assets/{ExperimentsApp-r9xSXake.js → ExperimentsApp-C94ZBe9g.js}
RENAMED
|
The diff for this file is too large to render.
See raw diff
|
|
|
frontend/dist/assets/{ModelApp-Cw242jQN.js → ModelApp-CPeaZt0H.js}
RENAMED
|
@@ -1,4 +1,4 @@
|
|
| 1 |
-
import{r as i,p as re,a as le,j as e}from"./index-
|
| 2 |
${u.repo}`:u.repo,children:u.presetName||u.name}),e.jsxs("div",{className:"text-[10px] text-gray-500",children:[u.column," | ",u.n_rows," rows | ",u.n_samples," samples"]})]}),e.jsx("button",{onClick:v=>{v.stopPropagation(),G(M===u.id?null:u.id),O("")},className:`transition-colors shrink-0 ${M===u.id?"text-blue-400":"text-gray-600 hover:text-blue-400"}`,title:"Save as preset",children:e.jsx("svg",{className:"w-3.5 h-3.5",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M5 5a2 2 0 012-2h10a2 2 0 012 2v16l-7-3.5L5 21V5z"})})}),e.jsx("button",{onClick:v=>{v.stopPropagation(),b(u.id)},className:"text-gray-600 hover:text-red-400 transition-colors shrink-0",title:"Remove",children:e.jsx("svg",{className:"w-3.5 h-3.5",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M6 18L18 6M6 6l12 12"})})})]}),M===u.id&&e.jsxs("div",{className:"flex gap-1 mt-1 ml-6",children:[e.jsx("input",{type:"text",value:B,onChange:v=>O(v.target.value),onKeyDown:v=>{v.key==="Enter"&&z(u),v.key==="Escape"&&G(null)},placeholder:"Preset name...",className:"flex-1 px-2 py-1 text-xs bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none",autoFocus:!0}),e.jsx("button",{onClick:()=>z(u),className:"px-2 py-1 text-xs bg-blue-600 hover:bg-blue-500 rounded text-white",children:"Save"})]})]},u.id))})]},r)})})]}),R&&(()=>{const r=t.find(a=>a.id===R);return r!=null&&r.presetId?e.jsxs("div",{className:"p-3 border-t border-gray-700 space-y-2",children:[e.jsx("div",{className:"text-[10px] text-gray-500 uppercase font-semibold tracking-wider",children:"Edit Preset"}),e.jsx("input",{type:"text",value:_,onChange:a=>J(a.target.value),onKeyDown:a=>{a.key==="Enter"&&_.trim()&&(w(r.presetId,r.id,{name:_.trim()}),$(null)),a.key==="Escape"&&$(null)},placeholder:"Preset name...",className:"w-full px-2 py-1 text-xs bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none",autoFocus:!0}),e.jsxs("div",{className:"flex gap-2",children:[e.jsx("button",{onClick:()=>{_.trim()&&(w(r.presetId,r.id,{name:_.trim()}),$(null))},disabled:!_.trim(),className:"flex-1 px-2 py-1 text-xs bg-blue-600 hover:bg-blue-500 disabled:bg-gray-700 disabled:text-gray-500 rounded text-white transition-colors",children:"Save"}),e.jsx("button",{onClick:()=>{j(r.presetId,r.id),$(null)},className:"px-2 py-1 text-xs bg-red-900 hover:bg-red-800 rounded text-red-300 transition-colors",children:"Delete"}),e.jsx("button",{onClick:()=>$(null),className:"px-2 py-1 text-xs bg-gray-700 hover:bg-gray-600 rounded text-gray-300 transition-colors",children:"Cancel"})]})]}):null})(),e.jsx("div",{className:"p-3 border-t border-gray-700",children:k?e.jsxs("div",{className:"space-y-2",children:[e.jsx("input",{type:"text",value:m,onChange:r=>y(r.target.value),onKeyDown:r=>r.key==="Enter"&&K(),placeholder:"org/dataset-name",className:"w-full px-2 py-1.5 text-sm bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none",autoFocus:!0}),e.jsxs("div",{className:"flex gap-2",children:[e.jsx("input",{type:"text",value:P,onChange:r=>N(r.target.value),placeholder:"Response col (auto-detect)",className:"flex-1 px-2 py-1 text-xs bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none"}),e.jsx("input",{type:"text",value:F,onChange:r=>W(r.target.value),placeholder:"Split",className:"w-16 px-2 py-1 text-xs bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none"})]}),e.jsx("div",{className:"flex gap-2",children:e.jsx("input",{type:"text",value:H,onChange:r=>Y(r.target.value),placeholder:"Prompt col (auto-detect)",className:"flex-1 px-2 py-1 text-xs bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none"})}),e.jsxs("div",{className:"flex gap-2",children:[e.jsx("button",{onClick:K,disabled:!m.trim()||n[m.trim()],className:"flex-1 px-2 py-1.5 text-sm bg-blue-600 hover:bg-blue-500 disabled:bg-gray-700 disabled:text-gray-500 rounded text-white transition-colors",children:n[m.trim()]?"Loading...":"Load"}),e.jsx("button",{onClick:()=>o(!1),className:"px-3 py-1.5 text-sm bg-gray-700 hover:bg-gray-600 rounded text-gray-300 transition-colors",children:"Cancel"})]})]}):e.jsx("button",{onClick:()=>{$(null),o(!0),y(""),N(""),W("train"),Y("")},className:"w-full px-3 py-2 text-sm bg-blue-600 hover:bg-blue-500 rounded text-white font-medium transition-colors",children:"+ Add Repo"})})]})}function de(t){if(!t)return[{text:"(no response)",className:"text-gray-500 italic"}];const l=[],n=t.split(`
|
| 3 |
`);for(let c=0;c<n.length;c++){const p=n[c],s=p.toLowerCase().trim();let x="text-gray-300";s.startsWith("wait")||s.startsWith("hmm")||s.startsWith("but wait")?x="text-yellow-400":s.startsWith("let me try")||s.startsWith("let me reconsider")||s.startsWith("let me think")?x="text-cyan-400":s.startsWith("so the answer")||s.startsWith("so the expression")||s.startsWith("therefore")||s.startsWith("the final")?x="text-green-400 font-bold":s.startsWith("i give up")||s.startsWith("i can't find")||s.startsWith("i'm stuck")||s.startsWith("i'm sorry")?x="text-red-400 font-bold":p.includes("=")&&/[+\-*/]/.test(p)&&(x="text-gray-100"),l.push({text:p,className:x}),c<n.length-1&&l.push({text:`
|
| 4 |
`,className:""})}return l}function ue(t){if(!t||!t.trim())return[];try{const l=JSON.parse(t);if(Array.isArray(l)&&l.length>0&&l[0].role!==void 0)return l.map(n=>({role:String(n.role||"unknown"),content:String(n.content??"")}))}catch{}if(t.includes("<|im_start|>"))return t.split("<|im_start|>").filter(Boolean).map(n=>{const c=n.indexOf(`
|
|
|
|
| 1 |
+
import{r as i,p as re,a as le,j as e}from"./index-BWw4o19g.js";const U="/api/model",X="/api/presets/model";async function L(t,l){const n=await fetch(t,{headers:{"Content-Type":"application/json"},...l});if(!n.ok){const c=await n.json().catch(()=>({error:n.statusText}));throw new Error(c.error||n.statusText)}return n.json()}const A={loadDataset(t,l,n,c){return L(`${U}/datasets/load`,{method:"POST",body:JSON.stringify({repo:t,column:l,split:n,prompt_column:c})})},listDatasets(){return L(`${U}/datasets/`)},getQuestion(t,l){return L(`${U}/datasets/${t}/question/${l}`)},getSummary(t){return L(`${U}/datasets/${t}/summary`)},unloadDataset(t){return L(`${U}/datasets/${t}`,{method:"DELETE"})},listPresets(){return L(`${X}`)},createPreset(t,l,n,c){return L(`${X}`,{method:"POST",body:JSON.stringify({name:t,repo:l,column:n,split:c})})},updatePreset(t,l){return L(`${X}/${t}`,{method:"PUT",body:JSON.stringify(l)})},deletePreset(t){return L(`${X}/${t}`,{method:"DELETE"})}};function ie(){const t=i.useRef(re().params),[l,n]=i.useState([]),[c,p]=i.useState([]),[s,x]=i.useState("all"),[b,g]=i.useState({}),[h,S]=i.useState({}),[I,j]=i.useState(null),[w,k]=i.useState({}),[o,m]=i.useState(null);i.useEffect(()=>{A.listPresets().then(p).catch(()=>{})},[]),i.useEffect(()=>{const a=re().params,d=parseInt(a.get("q")||"0"),f=parseInt(a.get("s")||"0"),u=a.get("filter")||"all";x(u),(!isNaN(d)||!isNaN(f))&&(window.__initialQ=isNaN(d)?0:d,window.__initialS=isNaN(f)?0:f)},[]);const y=i.useMemo(()=>{const r={};for(const a of l){const d=a.questionFingerprint;r[d]||(r[d]=[]),r[d].push(a)}return r},[l]),P=i.useMemo(()=>Object.keys(y).sort(),[y]);i.useEffect(()=>{if(o&&y[o])return;const r=P.find(a=>y[a].some(d=>d.active));r?m(r):P.length>0?m(P[0]):m(null)},[P,y,o]);const N=i.useMemo(()=>l.filter(r=>r.active&&r.questionFingerprint===o),[l,o]),[F,W]=i.useState([]);i.useEffect(()=>{const r=new Set(N.map(a=>a.id));W(a=>{const d=a.filter(v=>r.has(v)),f=N.map(v=>v.id).filter(v=>!a.includes(v)),u=[...d,...f];return u.length===a.length&&u.every((v,C)=>v===a[C])?a:u})},[N]);const H=i.useMemo(()=>{const r=new Map(N.map(a=>[a.id,a]));return F.map(a=>r.get(a)).filter(a=>a!==void 0)},[N,F]),Y=i.useCallback((r,a)=>{r!==a&&W(d=>{const f=[...d],u=f.indexOf(r),v=f.indexOf(a);return u===-1||v===-1?d:(f.splice(u,1),f.splice(v,0,r),f)})},[]),D=o?w[o]:void 0,E=(D==null?void 0:D.questionIdx)??0,M=(D==null?void 0:D.sampleIdx)??0,G=i.useCallback(r=>{o&&k(a=>{const d=a[o]??{questionIdx:0,sampleIdx:0},f=typeof r=="function"?r(d.questionIdx):r;return{...a,[o]:{...d,questionIdx:f}}})},[o]),B=i.useCallback(r=>{o&&k(a=>{const d=a[o]??{questionIdx:0,sampleIdx:0},f=typeof r=="function"?r(d.sampleIdx):r;return{...a,[o]:{...d,sampleIdx:f}}})},[o]);i.useEffect(()=>{const r=new URLSearchParams,a=l.filter(d=>d.active);a.length>0&&(r.set("repos",a.map(d=>d.repo).join(",")),r.set("cols",a.map(d=>d.column).join(",")),r.set("pcols",a.map(d=>d.promptColumn||"formatted_prompt").join(","))),r.set("q",String(E)),r.set("s",String(M)),s!=="all"&&r.set("filter",s),o&&r.set("group",o),le({params:r})},[l,E,M,s,o]),i.useEffect(()=>{N.forEach(r=>{const a=`${r.id}:${E}`;b[a]||A.getQuestion(r.id,E).then(d=>{g(f=>({...f,[a]:d}))}).catch(()=>{})})},[E,N]);const O=i.useCallback(async(r,a,d,f,u,v)=>{S(C=>({...C,[r]:!0})),j(null);try{const{question_fingerprint:C,...Q}=await A.loadDataset(r,a,d,f),V=C??"",ee={...Q,questionFingerprint:V,active:!0,presetId:u,presetName:v};n(T=>T.some(q=>q.id===ee.id)?T:[...T,ee]),k(T=>{if(T[V])return T;const q=window,ne=typeof q.__initialQ=="number"?q.__initialQ:0,oe=typeof q.__initialS=="number"?q.__initialS:0,te=Object.keys(T).length===0;return{...T,[V]:{questionIdx:te?ne:0,sampleIdx:te?oe:0}}}),m(V)}catch(C){j(C instanceof Error?C.message:"Failed to load dataset")}finally{S(C=>({...C,[r]:!1}))}},[]);i.useEffect(()=>{var u,v,C;const r=t.current,a=((u=r.get("repos"))==null?void 0:u.split(",").filter(Boolean))||[],d=((v=r.get("cols"))==null?void 0:v.split(","))||[],f=((C=r.get("pcols"))==null?void 0:C.split(","))||[];for(let Q=0;Q<a.length;Q++)O(a[Q],d[Q]||void 0,void 0,f[Q]||void 0)},[O]);const R=i.useCallback(async r=>{await A.unloadDataset(r).catch(()=>{}),n(a=>a.filter(d=>d.id!==r))},[]),$=i.useCallback(r=>{n(a=>{const d=a.map(u=>u.id===r?{...u,active:!u.active}:u),f=d.find(u=>u.id===r);return f&&f.active&&m(f.questionFingerprint),d})},[]),_=i.useCallback((r,a)=>{n(d=>d.map(f=>f.id===r?{...f,presetName:a}:f))},[]),J=i.useCallback(r=>{n(a=>a.map(d=>d.id===r?{...d,presetId:void 0,presetName:void 0}:d))},[]),K=Math.min(...N.map(r=>r.n_rows),1/0),z=Math.max(...N.map(r=>r.n_samples),0);return{datasets:l,presets:c,setPresets:p,questionIdx:E,setQuestionIdx:G,sampleIdx:M,setSampleIdx:B,filter:s,setFilter:x,loading:h,error:I,setError:j,activeDatasets:N,orderedActiveDatasets:H,maxQuestions:K,maxSamples:z,addDataset:O,removeDataset:R,toggleDataset:$,updateDatasetPresetName:_,clearDatasetPreset:J,getQuestionData:r=>b[`${r}:${E}`],reorderPanels:Y,groups:y,groupIds:P,currentGroupId:o,setCurrentGroupId:m}}const se=[{bg:"bg-blue-500",border:"border-blue-500",text:"text-blue-400",label:"text-blue-300"},{bg:"bg-emerald-500",border:"border-emerald-500",text:"text-emerald-400",label:"text-emerald-300"},{bg:"bg-amber-500",border:"border-amber-500",text:"text-amber-400",label:"text-amber-300"},{bg:"bg-purple-500",border:"border-purple-500",text:"text-purple-400",label:"text-purple-300"},{bg:"bg-rose-500",border:"border-rose-500",text:"text-rose-400",label:"text-rose-300"},{bg:"bg-cyan-500",border:"border-cyan-500",text:"text-cyan-400",label:"text-cyan-300"}];function ce({datasets:t,presets:l,loading:n,groups:c,groupIds:p,currentGroupId:s,onAddDataset:x,onRemoveDataset:b,onToggleDataset:g,onSetCurrentGroup:h,onLoadPreset:S,onSavePreset:I,onDeletePreset:j,onUpdatePreset:w}){const[k,o]=i.useState(!1),[m,y]=i.useState(""),[P,N]=i.useState(""),[F,W]=i.useState("train"),[H,Y]=i.useState(""),[D,E]=i.useState(""),[M,G]=i.useState(null),[B,O]=i.useState(""),[R,$]=i.useState(null),[_,J]=i.useState(""),K=()=>{m.trim()&&(x(m.trim(),P.trim()||void 0,F.trim()||void 0,H.trim()||void 0),y(""),o(!1))},z=r=>{B.trim()&&(I(B.trim(),r.repo,r.column,r.split),O(""),G(null))},Z=r=>{const a=p.indexOf(r);return se[a%se.length]};return e.jsxs("div",{className:"w-72 min-w-72 bg-gray-900 border-r border-gray-700 flex flex-col h-full",children:[e.jsxs("div",{className:"p-3 border-b border-gray-700",children:[e.jsx("div",{className:"flex items-center justify-between mb-2",children:e.jsx("h3",{className:"text-xs font-semibold text-gray-400 uppercase tracking-wider",children:"Presets"})}),l.length===0?e.jsx("p",{className:"text-xs text-gray-500 italic",children:"No presets saved"}):e.jsxs(e.Fragment,{children:[l.length>6&&e.jsx("input",{type:"text",value:D,onChange:r=>E(r.target.value),placeholder:"Search presets...",className:"w-full px-2 py-1 mb-2 text-xs bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none"}),e.jsx("div",{className:"flex flex-wrap gap-1 max-h-32 overflow-y-auto",children:l.filter(r=>!D||r.name.toLowerCase().includes(D.toLowerCase())||r.repo.toLowerCase().includes(D.toLowerCase())).map(r=>e.jsxs("div",{className:"group relative",children:[e.jsx("button",{onClick:()=>S(r),className:"px-2 py-1 text-xs bg-gray-800 hover:bg-gray-700 rounded border border-gray-600 text-gray-300 transition-colors",title:`${r.repo} (${r.column}, ${r.split??"train"})`,children:r.name}),e.jsx("div",{className:"hidden group-hover:flex absolute top-full left-0 mt-1 z-10 gap-1",children:e.jsx("button",{onClick:()=>j(r.id),className:"px-1.5 py-0.5 text-[10px] bg-red-900 hover:bg-red-800 rounded text-red-300",children:"Delete"})})]},r.id))})]})]}),e.jsxs("div",{className:"flex-1 overflow-y-auto p-3",children:[e.jsx("h3",{className:"text-xs font-semibold text-gray-400 uppercase tracking-wider mb-2",children:"Loaded Repos"}),t.length===0?e.jsx("p",{className:"text-xs text-gray-500 italic",children:"No repos loaded. Add one below."}):e.jsx("div",{className:"space-y-3",children:p.map(r=>{const a=Z(r),d=c[r],f=r===s;return e.jsxs("div",{children:[e.jsxs("button",{onClick:()=>h(r),className:`w-full flex items-center gap-1.5 mb-1 px-1 py-0.5 rounded transition-colors ${f?"bg-gray-800":"hover:bg-gray-800/50"}`,children:[e.jsx("span",{className:`inline-block w-2 h-2 rounded-full ${a.bg} shrink-0`}),e.jsxs("span",{className:`text-[10px] font-semibold uppercase tracking-wider ${f?a.label:"text-gray-500"}`,children:["Group ",p.indexOf(r)+1,e.jsxs("span",{className:"normal-case font-normal ml-1 text-gray-600",children:["(",d.length," repo",d.length!==1?"s":"",")"]})]}),f&&e.jsx("span",{className:"text-[9px] text-gray-600 ml-auto",children:"viewing"})]}),e.jsx("div",{className:`space-y-1 border-l-2 ml-1 pl-2 ${f?a.border:"border-gray-700"}`,children:d.map(u=>e.jsxs("div",{children:[e.jsxs("div",{onClick:()=>{u.presetId&&($(R===u.id?null:u.id),J(u.presetName||""),o(!1))},className:`flex items-center gap-2 px-2 py-1.5 rounded text-sm transition-colors ${u.active?"bg-gray-800":"bg-gray-900 opacity-60"} ${R===u.id?"ring-1 ring-blue-500":""} ${u.presetId?"cursor-pointer":""}`,children:[e.jsx("input",{type:"checkbox",checked:u.active,onChange:()=>g(u.id),onClick:v=>v.stopPropagation(),className:"rounded border-gray-600 bg-gray-800 text-blue-500 focus:ring-blue-500 focus:ring-offset-0"}),e.jsxs("div",{className:"flex-1 min-w-0",children:[e.jsx("div",{className:"text-gray-200 truncate text-xs font-medium",title:u.presetName?`${u.presetName}
|
| 2 |
${u.repo}`:u.repo,children:u.presetName||u.name}),e.jsxs("div",{className:"text-[10px] text-gray-500",children:[u.column," | ",u.n_rows," rows | ",u.n_samples," samples"]})]}),e.jsx("button",{onClick:v=>{v.stopPropagation(),G(M===u.id?null:u.id),O("")},className:`transition-colors shrink-0 ${M===u.id?"text-blue-400":"text-gray-600 hover:text-blue-400"}`,title:"Save as preset",children:e.jsx("svg",{className:"w-3.5 h-3.5",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M5 5a2 2 0 012-2h10a2 2 0 012 2v16l-7-3.5L5 21V5z"})})}),e.jsx("button",{onClick:v=>{v.stopPropagation(),b(u.id)},className:"text-gray-600 hover:text-red-400 transition-colors shrink-0",title:"Remove",children:e.jsx("svg",{className:"w-3.5 h-3.5",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M6 18L18 6M6 6l12 12"})})})]}),M===u.id&&e.jsxs("div",{className:"flex gap-1 mt-1 ml-6",children:[e.jsx("input",{type:"text",value:B,onChange:v=>O(v.target.value),onKeyDown:v=>{v.key==="Enter"&&z(u),v.key==="Escape"&&G(null)},placeholder:"Preset name...",className:"flex-1 px-2 py-1 text-xs bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none",autoFocus:!0}),e.jsx("button",{onClick:()=>z(u),className:"px-2 py-1 text-xs bg-blue-600 hover:bg-blue-500 rounded text-white",children:"Save"})]})]},u.id))})]},r)})})]}),R&&(()=>{const r=t.find(a=>a.id===R);return r!=null&&r.presetId?e.jsxs("div",{className:"p-3 border-t border-gray-700 space-y-2",children:[e.jsx("div",{className:"text-[10px] text-gray-500 uppercase font-semibold tracking-wider",children:"Edit Preset"}),e.jsx("input",{type:"text",value:_,onChange:a=>J(a.target.value),onKeyDown:a=>{a.key==="Enter"&&_.trim()&&(w(r.presetId,r.id,{name:_.trim()}),$(null)),a.key==="Escape"&&$(null)},placeholder:"Preset name...",className:"w-full px-2 py-1 text-xs bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none",autoFocus:!0}),e.jsxs("div",{className:"flex gap-2",children:[e.jsx("button",{onClick:()=>{_.trim()&&(w(r.presetId,r.id,{name:_.trim()}),$(null))},disabled:!_.trim(),className:"flex-1 px-2 py-1 text-xs bg-blue-600 hover:bg-blue-500 disabled:bg-gray-700 disabled:text-gray-500 rounded text-white transition-colors",children:"Save"}),e.jsx("button",{onClick:()=>{j(r.presetId,r.id),$(null)},className:"px-2 py-1 text-xs bg-red-900 hover:bg-red-800 rounded text-red-300 transition-colors",children:"Delete"}),e.jsx("button",{onClick:()=>$(null),className:"px-2 py-1 text-xs bg-gray-700 hover:bg-gray-600 rounded text-gray-300 transition-colors",children:"Cancel"})]})]}):null})(),e.jsx("div",{className:"p-3 border-t border-gray-700",children:k?e.jsxs("div",{className:"space-y-2",children:[e.jsx("input",{type:"text",value:m,onChange:r=>y(r.target.value),onKeyDown:r=>r.key==="Enter"&&K(),placeholder:"org/dataset-name",className:"w-full px-2 py-1.5 text-sm bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none",autoFocus:!0}),e.jsxs("div",{className:"flex gap-2",children:[e.jsx("input",{type:"text",value:P,onChange:r=>N(r.target.value),placeholder:"Response col (auto-detect)",className:"flex-1 px-2 py-1 text-xs bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none"}),e.jsx("input",{type:"text",value:F,onChange:r=>W(r.target.value),placeholder:"Split",className:"w-16 px-2 py-1 text-xs bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none"})]}),e.jsx("div",{className:"flex gap-2",children:e.jsx("input",{type:"text",value:H,onChange:r=>Y(r.target.value),placeholder:"Prompt col (auto-detect)",className:"flex-1 px-2 py-1 text-xs bg-gray-800 border border-gray-600 rounded text-gray-200 placeholder-gray-500 focus:border-blue-500 focus:outline-none"})}),e.jsxs("div",{className:"flex gap-2",children:[e.jsx("button",{onClick:K,disabled:!m.trim()||n[m.trim()],className:"flex-1 px-2 py-1.5 text-sm bg-blue-600 hover:bg-blue-500 disabled:bg-gray-700 disabled:text-gray-500 rounded text-white transition-colors",children:n[m.trim()]?"Loading...":"Load"}),e.jsx("button",{onClick:()=>o(!1),className:"px-3 py-1.5 text-sm bg-gray-700 hover:bg-gray-600 rounded text-gray-300 transition-colors",children:"Cancel"})]})]}):e.jsx("button",{onClick:()=>{$(null),o(!0),y(""),N(""),W("train"),Y("")},className:"w-full px-3 py-2 text-sm bg-blue-600 hover:bg-blue-500 rounded text-white font-medium transition-colors",children:"+ Add Repo"})})]})}function de(t){if(!t)return[{text:"(no response)",className:"text-gray-500 italic"}];const l=[],n=t.split(`
|
| 3 |
`);for(let c=0;c<n.length;c++){const p=n[c],s=p.toLowerCase().trim();let x="text-gray-300";s.startsWith("wait")||s.startsWith("hmm")||s.startsWith("but wait")?x="text-yellow-400":s.startsWith("let me try")||s.startsWith("let me reconsider")||s.startsWith("let me think")?x="text-cyan-400":s.startsWith("so the answer")||s.startsWith("so the expression")||s.startsWith("therefore")||s.startsWith("the final")?x="text-green-400 font-bold":s.startsWith("i give up")||s.startsWith("i can't find")||s.startsWith("i'm stuck")||s.startsWith("i'm sorry")?x="text-red-400 font-bold":p.includes("=")&&/[+\-*/]/.test(p)&&(x="text-gray-100"),l.push({text:p,className:x}),c<n.length-1&&l.push({text:`
|
| 4 |
`,className:""})}return l}function ue(t){if(!t||!t.trim())return[];try{const l=JSON.parse(t);if(Array.isArray(l)&&l.length>0&&l[0].role!==void 0)return l.map(n=>({role:String(n.role||"unknown"),content:String(n.content??"")}))}catch{}if(t.includes("<|im_start|>"))return t.split("<|im_start|>").filter(Boolean).map(n=>{const c=n.indexOf(`
|
frontend/dist/assets/{PlanRevisionsApp-CUfcVsmt.js → PlanRevisionsApp-C8SWmiEl.js}
RENAMED
|
@@ -1,4 +1,4 @@
|
|
| 1 |
-
import{r as i,j as t}from"./index-
|
| 2 |
`),n=p.split(`
|
| 3 |
`),d=new Set(x),m=new Set(n),s=[];let o=0,a=0;for(;o<x.length||a<n.length;){const u=x[o],l=n[a];o>=x.length?(s.push({text:n[a],type:"add"}),a++):a>=n.length?(s.push({text:x[o],type:"del"}),o++):u===l?(s.push({text:u,type:"same"}),o++,a++):m.has(u)?d.has(l)?(s.push({text:u,type:"del"}),s.push({text:l,type:"add"}),o++,a++):(s.push({text:l,type:"add"}),a++):(s.push({text:u,type:"del"}),o++)}return s}function _({prev:r,curr:p}){const x=i.useMemo(()=>S(r,p),[r,p]);return t.jsx("pre",{className:"text-xs font-mono whitespace-pre-wrap leading-relaxed",children:x.map((n,d)=>n.type==="same"?t.jsx("span",{className:"text-gray-300",children:n.text+`
|
| 4 |
`},d):n.type==="add"?t.jsx("span",{className:"bg-green-900/40 text-green-300",children:"+ "+n.text+`
|
|
|
|
| 1 |
+
import{r as i,j as t}from"./index-BWw4o19g.js";function S(r,p){const x=r.split(`
|
| 2 |
`),n=p.split(`
|
| 3 |
`),d=new Set(x),m=new Set(n),s=[];let o=0,a=0;for(;o<x.length||a<n.length;){const u=x[o],l=n[a];o>=x.length?(s.push({text:n[a],type:"add"}),a++):a>=n.length?(s.push({text:x[o],type:"del"}),o++):u===l?(s.push({text:u,type:"same"}),o++,a++):m.has(u)?d.has(l)?(s.push({text:u,type:"del"}),s.push({text:l,type:"add"}),o++,a++):(s.push({text:l,type:"add"}),a++):(s.push({text:u,type:"del"}),o++)}return s}function _({prev:r,curr:p}){const x=i.useMemo(()=>S(r,p),[r,p]);return t.jsx("pre",{className:"text-xs font-mono whitespace-pre-wrap leading-relaxed",children:x.map((n,d)=>n.type==="same"?t.jsx("span",{className:"text-gray-300",children:n.text+`
|
| 4 |
`},d):n.type==="add"?t.jsx("span",{className:"bg-green-900/40 text-green-300",children:"+ "+n.text+`
|
frontend/dist/assets/{ScoutRunsApp-B_i5X87r.js → ScoutRunsApp-CnCOgFX5.js}
RENAMED
|
@@ -1,4 +1,4 @@
|
|
| 1 |
-
import{r as n,j as e}from"./index-
|
| 2 |
|
| 3 |
---
|
| 4 |
|
|
|
|
| 1 |
+
import{r as n,j as e}from"./index-BWw4o19g.js";const S={reasoning:{border:"border-purple-700",labelColor:"text-purple-400",bg:"bg-purple-950/30"},tool_call:{border:"border-blue-700",labelColor:"text-blue-400",bg:"bg-blue-950/30"},tool_result:{border:"border-gray-600",labelColor:"text-gray-400",bg:"bg-gray-800/30"},final_answer:{border:"border-green-700",labelColor:"text-green-400",bg:"bg-green-950/30"},unknown:{border:"border-gray-700",labelColor:"text-gray-500",bg:""}};function N(a){if(!a)return[];const l=[],p=a.split(`
|
| 2 |
|
| 3 |
---
|
| 4 |
|
frontend/dist/assets/{SelectedToolsApp-BBGQyqN9.js → SelectedToolsApp-DsDxpPqt.js}
RENAMED
|
@@ -1,4 +1,4 @@
|
|
| 1 |
-
import{r as n,j as e}from"./index-
|
| 2 |
|
| 3 |
---
|
| 4 |
|
|
|
|
| 1 |
+
import{r as n,j as e}from"./index-BWw4o19g.js";const E={reasoning:{border:"border-purple-700",labelColor:"text-purple-400",bg:"bg-purple-950/30"},tool_call:{border:"border-blue-700",labelColor:"text-blue-400",bg:"bg-blue-950/30"},tool_result:{border:"border-gray-600",labelColor:"text-gray-400",bg:"bg-gray-800/30"},final_answer:{border:"border-green-700",labelColor:"text-green-400",bg:"bg-green-950/30"},unknown:{border:"border-gray-700",labelColor:"text-gray-500",bg:""}};function $(a){if(!a)return[];const l=[],i=a.split(/\n\n(?=\[)/);for(const o of i){const s=o.trim();s.startsWith("[Reasoning]:")?l.push({type:"reasoning",label:"Reasoning",content:s.slice(12).trim()}):s.startsWith("[Tool call]")?l.push({type:"tool_call",label:"Tool Call",content:s.slice(11).trim()}):s.startsWith("[Tool result]:")?l.push({type:"tool_result",label:"Tool Result",content:s.slice(14).trim()}):s.startsWith("[Final answer]:")?l.push({type:"final_answer",label:"Final Answer",content:s.slice(15).trim()}):s&&l.push({type:"unknown",label:"—",content:s})}return l}function F(a){if(!a)return[];const l=[],i=a.split(`
|
| 2 |
|
| 3 |
---
|
| 4 |
|
frontend/dist/assets/{SftDiffApp-D-nUoSxu.js → SftDiffApp-Da0Tj_1m.js}
RENAMED
|
@@ -1 +1 @@
|
|
| 1 |
-
import{r as d,j as e}from"./index-
|
|
|
|
| 1 |
+
import{r as d,j as e}from"./index-BWw4o19g.js";const N={user:{bg:"bg-amber-950/40",border:"border-amber-600",label:"text-amber-400",tag:"USER MESSAGE"},reasoning:{bg:"bg-purple-950/40",border:"border-purple-600",label:"text-purple-400",tag:"REASONING"},tool_call:{bg:"bg-blue-950/40",border:"border-blue-600",label:"text-blue-400",tag:"TOOL CALL"},tool_resp:{bg:"bg-gray-800/60",border:"border-gray-600",label:"text-gray-400",tag:"TOOL RESPONSE"}};function g({kind:r,label:t,children:l}){const s=N[r];return e.jsxs("div",{className:`border-l-2 ${s.border} ${s.bg} pl-3 py-2 rounded-r mb-2`,children:[e.jsx("div",{className:`text-[9px] font-bold uppercase tracking-widest mb-1.5 ${s.label}`,children:t??s.tag}),l]})}function A(r){return r.split(/\n\n/).map(t=>t.trim()).filter(Boolean).flatMap(t=>{try{const l=JSON.parse(t);return typeof l=="object"&&l!==null&&"type"in l?[l]:[]}catch{return[]}})}function T({excerpt:r,userContent:t}){const l=d.useMemo(()=>A(r),[r]);return e.jsxs("div",{className:"space-y-0",children:[e.jsx(g,{kind:"user",children:e.jsx("pre",{className:"text-xs text-gray-200 whitespace-pre-wrap font-mono leading-relaxed",children:t})}),l.map((s,a)=>{const n=JSON.stringify(s,null,2);return s.type==="reasoning"?e.jsx(g,{kind:"reasoning",children:e.jsx("pre",{className:"text-xs text-gray-200 whitespace-pre-wrap font-mono leading-relaxed",children:n})},a):s.type==="function_call"?e.jsx(g,{kind:"tool_call",label:`TOOL CALL${s.name?`: ${s.name}`:""}`,children:e.jsx("pre",{className:"text-xs text-gray-200 whitespace-pre-wrap font-mono leading-relaxed",children:n})},a):s.type==="function_call_output"?e.jsx(g,{kind:"tool_resp",children:e.jsx("pre",{className:"text-xs text-gray-200 whitespace-pre-wrap font-mono leading-relaxed",children:n})},a):e.jsx("div",{className:"border-l-2 border-gray-700 pl-3 py-2 mb-2",children:e.jsx("pre",{className:"text-xs text-gray-400 whitespace-pre-wrap font-mono leading-relaxed",children:n})},a)})]})}function I(r){const t=[],l=/(<tool_call>[\s\S]*?<\/tool_call>)/g;let s=0,a;for(;(a=l.exec(r))!==null;){const i=r.slice(s,a.index).trim();i&&t.push({kind:"reasoning",text:i}),t.push({kind:"tool_call",text:a[1]}),s=a.index+a[1].length}const n=r.slice(s).trim();return n&&t.push({kind:"reasoning",text:n}),t}function M(r){const t=[],l=/(<think>[\s\S]*?<\/think>|<tool_call>[\s\S]*?<\/tool_call>)/g;let s=0,a;for(;(a=l.exec(r))!==null;){const i=r.slice(s,a.index).trim();i&&t.push({kind:"reasoning",text:i}),a[1].startsWith("<think>")?t.push({kind:"reasoning",text:a[1]}):t.push({kind:"tool_call",text:a[1]}),s=a.index+a[1].length}const n=r.slice(s).trim();return n&&t.push({kind:"reasoning",text:n}),t}function R({content:r,template:t}){const l=t==="qwen"?M(r):I(r),s=l.some(n=>n.kind==="tool_call"),a=N.reasoning;return e.jsxs("div",{className:`border-l-2 ${a.border} ${a.bg} pl-3 py-2 rounded-r mb-2`,children:[e.jsx("div",{className:`text-[9px] font-bold uppercase tracking-widest mb-1.5 ${a.label}`,children:s?"REASONING + TOOL CALL":"REASONING"}),l.map((n,i)=>{if(n.kind==="tool_call"){const p=N.tool_call;return e.jsxs("div",{className:`border-l-2 ${p.border} ${p.bg} pl-2 py-1.5 rounded-r mb-1.5`,children:[e.jsx("div",{className:`text-[9px] font-bold uppercase tracking-widest mb-1 ${p.label}`,children:"TOOL CALL"}),e.jsx("pre",{className:"text-xs text-gray-200 whitespace-pre-wrap font-mono leading-relaxed",children:n.text})]},i)}return e.jsx("pre",{className:"text-xs text-gray-200 whitespace-pre-wrap font-mono leading-relaxed mb-1.5",children:n.text},i)})]})}function G({messages:r,template:t}){return e.jsx("div",{className:"space-y-0",children:r.map((l,s)=>l.role==="user"&&s===0?e.jsx(g,{kind:"user",children:e.jsx("pre",{className:"text-xs text-gray-200 whitespace-pre-wrap font-mono leading-relaxed",children:l.content})},s):l.role==="user"?e.jsx(g,{kind:"tool_resp",children:e.jsx("pre",{className:"text-xs text-gray-200 whitespace-pre-wrap font-mono leading-relaxed",children:l.content})},s):e.jsx(R,{content:l.content,template:t},s))})}function D(){return e.jsxs("div",{className:"flex items-center gap-4 px-4 py-1.5 bg-gray-900/80 border-b border-gray-800 shrink-0 flex-wrap",children:[e.jsx("span",{className:"text-[9px] font-bold uppercase tracking-widest text-gray-500 mr-1",children:"Legend"}),Object.entries(N).map(([r,t])=>e.jsxs("span",{className:`flex items-center gap-1.5 text-[10px] ${t.label}`,children:[e.jsx("span",{className:`inline-block w-2.5 h-2.5 rounded-sm border ${t.border} ${t.bg}`}),t.tag]},r))]})}function B({value:r,onChange:t}){return e.jsxs("select",{value:r,onChange:l=>t(l.target.value),className:"text-xs bg-gray-800 border border-gray-600 text-gray-200 rounded px-2 py-1 ml-2 cursor-pointer",children:[e.jsx("option",{value:"gpt-oss",children:"gpt-oss"}),e.jsx("option",{value:"qwen",children:"qwen"})]})}function P(){var v,k,_,S;const[r,t]=d.useState([]),[l,s]=d.useState(!0),[a,n]=d.useState(null),[i,p]=d.useState(0),[f,E]=d.useState(""),[b,q]=d.useState("gpt-oss");d.useEffect(()=>{s(!0),fetch("/api/sft-diff/").then(o=>{if(!o.ok)throw new Error(o.statusText);return o.json()}).then(o=>{t(o.rows),s(!1)}).catch(o=>{n(o.message),s(!1)})},[]);const w=d.useMemo(()=>{if(!f.trim())return r;const o=f.toLowerCase();return r.filter(x=>{var m,u,j,h;return x.query_id.toLowerCase().includes(o)||(((u=(m=x.messages_gpt)==null?void 0:m[0])==null?void 0:u.content)??((h=(j=x.messages_qwen)==null?void 0:j[0])==null?void 0:h.content)??"").toLowerCase().includes(o)})},[r,f]),c=w[i]??null,y=c?b==="qwen"?c.messages_qwen:c.messages_gpt:null,$=((k=(v=c==null?void 0:c.messages_gpt)==null?void 0:v[0])==null?void 0:k.content)??((S=(_=c==null?void 0:c.messages_qwen)==null?void 0:_[0])==null?void 0:S.content)??"";return l?e.jsx("div",{className:"h-full flex items-center justify-center text-gray-400",children:"Loading…"}):a?e.jsxs("div",{className:"h-full flex items-center justify-center text-red-400",children:["Error: ",a]}):e.jsxs("div",{className:"h-full flex overflow-hidden bg-gray-950 text-gray-100",children:[e.jsxs("div",{className:"w-60 shrink-0 flex flex-col border-r border-gray-800 bg-gray-900",children:[e.jsxs("div",{className:"px-2 py-1.5 border-b border-gray-800",children:[e.jsx("input",{type:"text",placeholder:"Search query ID or question…",value:f,onChange:o=>{E(o.target.value),p(0)},className:"w-full bg-gray-800 border border-gray-700 text-gray-200 text-xs rounded px-2 py-1.5 placeholder-gray-600"}),e.jsxs("div",{className:"text-[10px] text-gray-600 mt-1",children:[w.length," / ",r.length]})]}),e.jsx("div",{className:"flex-1 overflow-y-auto",children:w.map((o,x)=>{var h,L,O,C;const m=((L=(h=o.messages_gpt)==null?void 0:h[0])==null?void 0:L.content)??((C=(O=o.messages_qwen)==null?void 0:O[0])==null?void 0:C.content)??"",u=m.match(/Question:\s*([\s\S]{0,120})/),j=u?u[1].trim().replace(/\n/g," "):m.slice(0,80);return e.jsxs("button",{onClick:()=>p(x),className:`w-full text-left px-3 py-2 border-b border-gray-800/50 text-xs transition-colors ${i===x?"bg-blue-900/40 text-blue-200 border-l-2 border-l-blue-500":"text-gray-400 hover:bg-gray-800"}`,children:[e.jsxs("div",{className:"font-medium text-gray-200 mb-0.5",children:["#",o.query_id]}),e.jsx("div",{className:"text-[10px] text-gray-500 leading-snug line-clamp-2",children:j})]},o.query_id+x)})})]}),c?e.jsxs("div",{className:"flex-1 flex flex-col min-w-0 overflow-hidden",children:[e.jsx(D,{}),e.jsxs("div",{className:"flex-1 flex overflow-hidden min-w-0",children:[e.jsxs("div",{className:"flex-1 flex flex-col min-w-0 border-r border-gray-800 overflow-hidden",children:[e.jsxs("div",{className:"px-3 py-1.5 bg-gray-900/60 border-b border-gray-800 shrink-0",children:[e.jsx("span",{className:"text-[11px] font-semibold text-amber-400 uppercase tracking-widest",children:"Original"}),e.jsx("span",{className:"text-[10px] text-gray-500 ml-2",children:"excerpt field — raw JSON items"})]}),e.jsx("div",{className:"flex-1 overflow-y-auto p-3",children:e.jsx(T,{excerpt:c.excerpt,userContent:$})})]}),e.jsxs("div",{className:"flex-1 flex flex-col min-w-0 overflow-hidden",children:[e.jsxs("div",{className:"px-3 py-1.5 bg-gray-900/60 border-b border-gray-800 shrink-0 flex items-center",children:[e.jsx("span",{className:"text-[11px] font-semibold text-sky-400 uppercase tracking-widest",children:"Converted"}),e.jsx(B,{value:b,onChange:q}),y&&e.jsxs("span",{className:"text-[10px] text-gray-500 ml-2",children:[y.length," messages"]})]}),e.jsx("div",{className:"flex-1 overflow-y-auto p-3",children:y?e.jsx(G,{messages:y,template:b}):e.jsxs("div",{className:"text-gray-500 text-xs italic mt-4",children:["Not available for ",b," template."]})})]})]})]}):e.jsx("div",{className:"flex-1 flex items-center justify-center text-gray-500",children:"No record selected."})]})}export{P as default};
|
frontend/dist/assets/{TrajExtApp-Y8_orlLr.js → TrajExtApp-DiG2ggVT.js}
RENAMED
|
@@ -1 +1 @@
|
|
| 1 |
-
import{r as l,j as e}from"./index-
|
|
|
|
| 1 |
+
import{r as l,j as e}from"./index-BWw4o19g.js";function S(r){try{return JSON.parse(r).map(o=>({type:["reasoning","tool_call","tool_result","final_answer"].includes(o.type)?o.type:"unknown",content:o.content}))}catch{return[]}}function T(r){if(!r||r==="(no trajectory steps)")return[];const n=[],o=r.split(/\n\n(?=\[(?:Reasoning\]:|Tool call\]|Tool result\]:|Final answer\]:))/);for(const d of o){const s=d.trim();s.startsWith("[Reasoning]:")?n.push({type:"reasoning",content:s.slice(12).trim()}):s.startsWith("[Tool call]")?n.push({type:"tool_call",content:s.slice(11).trim()}):s.startsWith("[Tool result]:")?n.push({type:"tool_result",content:s.slice(14).trim()}):s.startsWith("[Final answer]:")?n.push({type:"final_answer",content:s.slice(15).trim()}):s&&n.push({type:"unknown",content:s})}return n}const k={reasoning:{border:"border-purple-700",label:"Reasoning",labelColor:"text-purple-400",bg:"bg-purple-950/30"},tool_call:{border:"border-blue-700",label:"Tool Call",labelColor:"text-blue-400",bg:"bg-blue-950/30"},tool_result:{border:"border-gray-600",label:"Tool Result",labelColor:"text-gray-400",bg:"bg-gray-800/30"},final_answer:{border:"border-green-700",label:"Final Answer",labelColor:"text-green-400",bg:"bg-green-950/30"},unknown:{border:"border-gray-700",label:"—",labelColor:"text-gray-500",bg:""}};function C({row:r}){const n=l.useMemo(()=>r.trajectory_blocks?S(r.trajectory_blocks):T(r.trajectory_text),[r.trajectory_blocks,r.trajectory_text]);return n.length===0?e.jsx("div",{className:"text-gray-500 text-xs",children:"No trajectory steps."}):e.jsx("div",{className:"space-y-2",children:n.map((o,d)=>{const s=k[o.type];return e.jsxs("div",{className:`border-l-2 ${s.border} ${s.bg} pl-3 py-1 rounded-r`,children:[e.jsx("div",{className:`text-[10px] font-bold uppercase tracking-widest mb-1 ${s.labelColor}`,children:s.label}),e.jsx("pre",{className:"text-xs text-gray-300 whitespace-pre-wrap font-mono leading-relaxed",children:o.content})]},d)})})}const E={traj_ext:"Full Trajectory (Tags)",traj_orig_ext:"Full Trajectory (Original Messages)",traj_summary_ext:"Summary (Tags)",traj_summary_orig_ext:"Summary (Original Messages)",traj_summary_ext_selected_tools:"Selected Tools (Tags)",traj_summary_orig_ext_selected_tools:"Selected Tools (Original Messages)"},f=r=>E[r]??r,M=["trajectory","prompt","both"];function R(){const[r,n]=l.useState([]),[o,d]=l.useState(!0),[s,j]=l.useState(null),[b,p]=l.useState(0),[c,_]=l.useState("trajectory"),[u,N]=l.useState(""),[x,v]=l.useState("all"),[m,w]=l.useState({});l.useEffect(()=>{d(!0),fetch("/api/traj-ext/").then(t=>{if(!t.ok)throw new Error(t.statusText);return t.json()}).then(t=>{n(t.rows),d(!1)}).catch(t=>{j(t.message),d(!1)})},[]);const h=l.useMemo(()=>Array.from(new Set(r.map(i=>i.run_name??""))).filter(Boolean).sort(),[r]),y=l.useMemo(()=>{let t=r;if(x!=="all"&&(t=t.filter(g=>g.run_name===x)),!u.trim())return t;const i=u.toLowerCase();return t.filter(g=>g.query_id.includes(i)||g.question.toLowerCase().includes(i))},[r,u,x]),a=y[b]??null;return l.useEffect(()=>{a&&(c!=="prompt"&&c!=="both"||m[a.run_id]||fetch(`/api/traj-ext/${encodeURIComponent(a.run_id)}`).then(t=>t.json()).then(t=>w(i=>({...i,[a.run_id]:t.formatted_prompt??""}))).catch(()=>{}))},[a==null?void 0:a.run_id,c]),o?e.jsx("div",{className:"h-full flex items-center justify-center text-gray-400",children:"Loading traj-ext data from HuggingFace…"}):s?e.jsxs("div",{className:"h-full flex items-center justify-center text-red-400",children:["Error: ",s]}):e.jsxs("div",{className:"h-full flex overflow-hidden bg-gray-950 text-gray-100",children:[e.jsxs("div",{className:"w-64 shrink-0 flex flex-col border-r border-gray-800 bg-gray-900",children:[e.jsxs("div",{className:"p-2 border-b border-gray-800 space-y-1.5",children:[h.length>0&&e.jsxs("select",{value:x,onChange:t=>{v(t.target.value),p(0)},className:"w-full bg-gray-800 border border-gray-700 text-gray-200 text-xs rounded px-2 py-1.5",children:[e.jsxs("option",{value:"all",children:["All runs (",r.length,")"]}),h.map(t=>e.jsx("option",{value:t,children:f(t)},t))]}),e.jsx("input",{type:"text",placeholder:"Search queries…",value:u,onChange:t=>{N(t.target.value),p(0)},className:"w-full bg-gray-800 border border-gray-700 text-gray-200 text-xs rounded px-2 py-1.5 placeholder-gray-600"}),e.jsxs("div",{className:"text-[10px] text-gray-600",children:[y.length,x!=="all"||u?` / ${r.length}`:""," trajectories"]})]}),e.jsx("div",{className:"flex-1 overflow-y-auto",children:y.map((t,i)=>e.jsxs("button",{onClick:()=>p(i),className:`w-full text-left px-3 py-2 border-b border-gray-800/50 text-xs transition-colors ${b===i?"bg-blue-900/40 text-blue-200 border-l-2 border-l-blue-500":"text-gray-400 hover:bg-gray-800"}`,children:[e.jsxs("div",{className:"font-medium text-gray-200",children:["#",t.query_id]}),e.jsxs("div",{className:"text-gray-500 truncate mt-0.5",children:[t.question.slice(0,60),"…"]}),e.jsxs("div",{className:"flex gap-2 mt-1 text-[10px] text-gray-600 flex-wrap items-center",children:[e.jsxs("span",{children:[t.n_tool_calls," tools"]}),e.jsxs("span",{children:[t.n_reasoning_steps," reasoning"]}),e.jsx("span",{className:t.status==="completed"?"text-green-600":"text-amber-600",children:t.status}),t.n_tool_calls===0&&e.jsx("span",{className:"px-1 py-0.5 rounded bg-yellow-900/50 text-yellow-300 font-semibold",children:"direct"})]}),t.run_name&&x==="all"&&e.jsx("div",{className:"mt-0.5 text-[9px] text-indigo-400 truncate",children:f(t.run_name)})]},t.run_id))})]}),a?e.jsxs("div",{className:"flex-1 flex flex-col min-w-0 overflow-hidden",children:[e.jsxs("div",{className:"px-4 py-2 bg-gray-900/60 border-b border-gray-800 shrink-0",children:[e.jsxs("div",{className:"flex items-center gap-3 flex-wrap",children:[e.jsxs("span",{className:"text-sm font-medium text-gray-100",children:["Query #",a.query_id]}),e.jsx("span",{className:`text-xs px-2 py-0.5 rounded-full ${a.status==="completed"?"bg-green-900/50 text-green-300":"bg-amber-900/50 text-amber-300"}`,children:a.status}),e.jsxs("span",{className:"text-xs text-gray-500",children:[a.n_tool_calls," tool calls · ",a.n_reasoning_steps," reasoning"]}),a.n_tool_calls===0&&e.jsx("span",{className:"px-1.5 py-0.5 rounded bg-yellow-900/50 text-yellow-300 text-xs font-semibold",children:"direct"}),e.jsx("div",{className:"ml-auto flex gap-1",children:M.map(t=>e.jsx("button",{onClick:()=>_(t),className:`px-2 py-0.5 text-xs rounded border transition-colors capitalize ${c===t?"bg-blue-700 border-blue-500 text-white":"bg-gray-800 border-gray-700 text-gray-400 hover:border-gray-500"}`,children:t},t))})]}),e.jsx("div",{className:"mt-1 text-xs text-gray-300 leading-snug",children:a.question})]}),e.jsxs("div",{className:"flex-1 overflow-y-auto p-4 space-y-4 min-w-0",children:[(c==="prompt"||c==="both")&&e.jsxs("div",{children:[c==="both"&&e.jsx("div",{className:"text-xs font-semibold text-gray-400 uppercase tracking-wide mb-2",children:"Prompt"}),m[a.run_id]?e.jsx("pre",{className:"text-xs font-mono whitespace-pre-wrap text-gray-200 bg-gray-900 border border-gray-700 rounded p-3 leading-relaxed",children:m[a.run_id]}):e.jsx("div",{className:"text-gray-500 text-xs p-3",children:"Loading prompt…"})]}),(c==="trajectory"||c==="both")&&e.jsxs("div",{children:[c==="both"&&e.jsx("div",{className:"text-xs font-semibold text-gray-400 uppercase tracking-wide mb-2 mt-4",children:"Trajectory"}),e.jsx(C,{row:a})]})]})]}):e.jsx("div",{className:"flex-1 flex items-center justify-center text-gray-500",children:"No trajectory selected."})]})}export{R as default};
|
frontend/dist/assets/VisualizerApp-B36fbafZ.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
| 1 |
-
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/ModelApp-Cw242jQN.js","assets/index-BewwkiJG.js","assets/index-CxBbYLho.css","assets/PlanRevisionsApp-CUfcVsmt.js","assets/TrajExtApp-Y8_orlLr.js","assets/SelectedToolsApp-BBGQyqN9.js","assets/ScoutRunsApp-B_i5X87r.js"])))=>i.map(i=>d[i]);
|
| 2 |
-
import{u as o,j as e,n as d,r as l,_ as t}from"./index-BewwkiJG.js";const c=l.lazy(()=>t(()=>import("./ModelApp-Cw242jQN.js"),__vite__mapDeps([0,1,2]))),n=l.lazy(()=>t(()=>import("./PlanRevisionsApp-CUfcVsmt.js"),__vite__mapDeps([3,1,2]))),x=l.lazy(()=>t(()=>import("./TrajExtApp-Y8_orlLr.js"),__vite__mapDeps([4,1,2]))),m=l.lazy(()=>t(()=>import("./SelectedToolsApp-BBGQyqN9.js"),__vite__mapDeps([5,1,2]))),u=l.lazy(()=>t(()=>import("./ScoutRunsApp-B_i5X87r.js"),__vite__mapDeps([6,1,2]))),i=[{id:"model",label:"Model Trace",activeClass:"border-blue-500 text-blue-400"},{id:"plan-revisions",label:"Plan Revisions",activeClass:"border-amber-500 text-amber-400"},{id:"traj-ext",label:"Traj Ext",activeClass:"border-emerald-500 text-emerald-400"},{id:"selected-tools",label:"Selected Tools",activeClass:"border-amber-400 text-amber-300"},{id:"scout-runs",label:"Scout Runs",activeClass:"border-cyan-500 text-cyan-400"}],p=new Set(i.map(r=>r.id));function _(){const r=o(),s=p.has(r.tab)?r.tab:"model";return e.jsxs("div",{className:"h-full flex flex-col",children:[e.jsx("div",{className:"flex items-center border-b border-gray-800 bg-gray-900/50 px-2 shrink-0",children:i.map(a=>e.jsx("button",{onClick:()=>d({page:"viz",tab:a.id}),className:`px-5 py-2 text-sm font-medium border-b-2 transition-colors ${s===a.id?a.activeClass:"border-transparent text-gray-500 hover:text-gray-300"}`,children:a.label},a.id))}),e.jsx("div",{className:"flex-1 overflow-hidden",children:e.jsxs(l.Suspense,{fallback:e.jsx("div",{className:"flex items-center justify-center h-full text-gray-500",children:"Loading..."}),children:[s==="model"&&e.jsx("div",{className:"theme-model h-full",children:e.jsx(c,{})}),s==="plan-revisions"&&e.jsx("div",{className:"h-full",children:e.jsx(n,{})}),s==="traj-ext"&&e.jsx("div",{className:"h-full",children:e.jsx(x,{})}),s==="selected-tools"&&e.jsx("div",{className:"h-full",children:e.jsx(m,{})}),s==="scout-runs"&&e.jsx("div",{className:"h-full",children:e.jsx(u,{})})]})})]})}export{_ as default};
|
|
|
|
|
|
|
|
|
frontend/dist/assets/VisualizerApp-Bwt-EqKk.js
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
|
|
|
|
|
|
|
| 1 |
+
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/ModelApp-CPeaZt0H.js","assets/index-BWw4o19g.js","assets/index-bo0f-zdf.css","assets/PlanRevisionsApp-C8SWmiEl.js","assets/TrajExtApp-DiG2ggVT.js","assets/SelectedToolsApp-DsDxpPqt.js","assets/ScoutRunsApp-CnCOgFX5.js","assets/BrowseCompApp-Ss7Hzz4R.js"])))=>i.map(i=>d[i]);
|
| 2 |
+
import{u as i,j as e,n as d,r as l,_ as a}from"./index-BWw4o19g.js";const c=l.lazy(()=>a(()=>import("./ModelApp-CPeaZt0H.js"),__vite__mapDeps([0,1,2]))),n=l.lazy(()=>a(()=>import("./PlanRevisionsApp-C8SWmiEl.js"),__vite__mapDeps([3,1,2]))),x=l.lazy(()=>a(()=>import("./TrajExtApp-DiG2ggVT.js"),__vite__mapDeps([4,1,2]))),m=l.lazy(()=>a(()=>import("./SelectedToolsApp-DsDxpPqt.js"),__vite__mapDeps([5,1,2]))),p=l.lazy(()=>a(()=>import("./ScoutRunsApp-CnCOgFX5.js"),__vite__mapDeps([6,1,2]))),u=l.lazy(()=>a(()=>import("./BrowseCompApp-Ss7Hzz4R.js"),__vite__mapDeps([7,1,2]))),o=[{id:"model",label:"Model Trace",activeClass:"border-blue-500 text-blue-400"},{id:"plan-revisions",label:"Plan Revisions",activeClass:"border-amber-500 text-amber-400"},{id:"traj-ext",label:"Traj Ext",activeClass:"border-emerald-500 text-emerald-400"},{id:"selected-tools",label:"Selected Tools",activeClass:"border-amber-400 text-amber-300"},{id:"scout-runs",label:"Scout Runs",activeClass:"border-cyan-500 text-cyan-400"},{id:"browsecomp",label:"BrowseComp+",activeClass:"border-purple-500 text-purple-400"}],_=new Set(o.map(r=>r.id));function b(){const r=i(),s=_.has(r.tab)?r.tab:"model";return e.jsxs("div",{className:"h-full flex flex-col",children:[e.jsx("div",{className:"flex items-center border-b border-gray-800 bg-gray-900/50 px-2 shrink-0",children:o.map(t=>e.jsx("button",{onClick:()=>d({page:"viz",tab:t.id}),className:`px-5 py-2 text-sm font-medium border-b-2 transition-colors ${s===t.id?t.activeClass:"border-transparent text-gray-500 hover:text-gray-300"}`,children:t.label},t.id))}),e.jsx("div",{className:"flex-1 overflow-hidden",children:e.jsxs(l.Suspense,{fallback:e.jsx("div",{className:"flex items-center justify-center h-full text-gray-500",children:"Loading..."}),children:[s==="model"&&e.jsx("div",{className:"theme-model h-full",children:e.jsx(c,{})}),s==="plan-revisions"&&e.jsx("div",{className:"h-full",children:e.jsx(n,{})}),s==="traj-ext"&&e.jsx("div",{className:"h-full",children:e.jsx(x,{})}),s==="selected-tools"&&e.jsx("div",{className:"h-full",children:e.jsx(m,{})}),s==="scout-runs"&&e.jsx("div",{className:"h-full",children:e.jsx(p,{})}),s==="browsecomp"&&e.jsx("div",{className:"h-full",children:e.jsx(u,{})})]})})]})}export{b as default};
|
frontend/dist/assets/{index-BewwkiJG.js → index-BWw4o19g.js}
RENAMED
|
The diff for this file is too large to render.
See raw diff
|
|
|
frontend/dist/assets/index-CxBbYLho.css
DELETED
|
@@ -1 +0,0 @@
|
|
| 1 |
-
*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.-left-\[17px\]{left:-17px}.-left-\[5px\]{left:-5px}.left-0{left:0}.left-4{left:1rem}.right-4{right:1rem}.right-5{right:1.25rem}.top-0{top:0}.top-3{top:.75rem}.top-4{top:1rem}.top-full{top:100%}.z-10{z-index:10}.z-40{z-index:40}.z-50{z-index:50}.my-2{margin-top:.5rem;margin-bottom:.5rem}.my-4{margin-top:1rem;margin-bottom:1rem}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.ml-1{margin-left:.25rem}.ml-1\.5{margin-left:.375rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.ml-6{margin-left:1.5rem}.ml-auto{margin-left:auto}.mr-0\.5{margin-right:.125rem}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mr-6{margin-right:1.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1 / 1}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3\.5{height:.875rem}.h-32{height:8rem}.h-4{height:1rem}.h-40{height:10rem}.h-48{height:12rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-\[85vh\]{height:85vh}.h-full{height:100%}.h-screen{height:100vh}.max-h-24{max-height:6rem}.max-h-32{max-height:8rem}.max-h-60{max-height:15rem}.max-h-\[80vh\]{max-height:80vh}.max-h-\[90vh\]{max-height:90vh}.min-h-0{min-height:0px}.min-h-\[300px\]{min-height:300px}.w-12{width:3rem}.w-16{width:4rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3\.5{width:.875rem}.w-36{width:9rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-60{width:15rem}.w-64{width:16rem}.w-72{width:18rem}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-72{min-width:18rem}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-\[80\%\]{max-width:80%}.max-w-\[90vw\]{max-width:90vw}.max-w-full{max-width:100%}.max-w-lg{max-width:32rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.table-auto{table-layout:auto}.border-collapse{border-collapse:collapse}.rotate-90{--tw-rotate: 90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-\[0\.97\]{--tw-scale-x: .97;--tw-scale-y: .97;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize-y{resize:vertical}.list-inside{list-style-position:inside}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(0px * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px * var(--tw-space-y-reverse))}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.125rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.125rem * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-sm{border-radius:.125rem}.rounded-xl{border-radius:.75rem}.rounded-r{border-top-right-radius:.25rem;border-bottom-right-radius:.25rem}.rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l-2{border-left-width:2px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-amber-400{--tw-border-opacity: 1;border-color:rgb(251 191 36 / var(--tw-border-opacity, 1))}.border-amber-500{--tw-border-opacity: 1;border-color:rgb(245 158 11 / var(--tw-border-opacity, 1))}.border-amber-600{--tw-border-opacity: 1;border-color:rgb(217 119 6 / var(--tw-border-opacity, 1))}.border-amber-700\/40{border-color:#b4530966}.border-amber-700\/50{border-color:#b4530980}.border-amber-800{--tw-border-opacity: 1;border-color:rgb(146 64 14 / var(--tw-border-opacity, 1))}.border-blue-500{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.border-blue-600{--tw-border-opacity: 1;border-color:rgb(37 99 235 / var(--tw-border-opacity, 1))}.border-blue-700{--tw-border-opacity: 1;border-color:rgb(29 78 216 / var(--tw-border-opacity, 1))}.border-blue-700\/50{border-color:#1d4ed880}.border-blue-800{--tw-border-opacity: 1;border-color:rgb(30 64 175 / var(--tw-border-opacity, 1))}.border-cyan-500{--tw-border-opacity: 1;border-color:rgb(6 182 212 / var(--tw-border-opacity, 1))}.border-cyan-700{--tw-border-opacity: 1;border-color:rgb(14 116 144 / var(--tw-border-opacity, 1))}.border-cyan-700\/30{border-color:#0e74904d}.border-cyan-700\/50{border-color:#0e749080}.border-cyan-800\/60{border-color:#155e7599}.border-emerald-500{--tw-border-opacity: 1;border-color:rgb(16 185 129 / var(--tw-border-opacity, 1))}.border-emerald-600{--tw-border-opacity: 1;border-color:rgb(5 150 105 / var(--tw-border-opacity, 1))}.border-emerald-700{--tw-border-opacity: 1;border-color:rgb(4 120 87 / var(--tw-border-opacity, 1))}.border-emerald-700\/50{border-color:#04785780}.border-emerald-800{--tw-border-opacity: 1;border-color:rgb(6 95 70 / var(--tw-border-opacity, 1))}.border-gray-500{--tw-border-opacity: 1;border-color:rgb(107 114 128 / var(--tw-border-opacity, 1))}.border-gray-600{--tw-border-opacity: 1;border-color:rgb(75 85 99 / var(--tw-border-opacity, 1))}.border-gray-700{--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1))}.border-gray-700\/50{border-color:#37415180}.border-gray-800{--tw-border-opacity: 1;border-color:rgb(31 41 55 / var(--tw-border-opacity, 1))}.border-gray-800\/50{border-color:#1f293780}.border-green-600{--tw-border-opacity: 1;border-color:rgb(22 163 74 / var(--tw-border-opacity, 1))}.border-green-700{--tw-border-opacity: 1;border-color:rgb(21 128 61 / var(--tw-border-opacity, 1))}.border-green-800{--tw-border-opacity: 1;border-color:rgb(22 101 52 / var(--tw-border-opacity, 1))}.border-orange-800\/50{border-color:#9a341280}.border-purple-500{--tw-border-opacity: 1;border-color:rgb(168 85 247 / var(--tw-border-opacity, 1))}.border-purple-600{--tw-border-opacity: 1;border-color:rgb(147 51 234 / var(--tw-border-opacity, 1))}.border-purple-700{--tw-border-opacity: 1;border-color:rgb(126 34 206 / var(--tw-border-opacity, 1))}.border-purple-700\/50{border-color:#7e22ce80}.border-red-600{--tw-border-opacity: 1;border-color:rgb(220 38 38 / var(--tw-border-opacity, 1))}.border-red-700{--tw-border-opacity: 1;border-color:rgb(185 28 28 / var(--tw-border-opacity, 1))}.border-red-800{--tw-border-opacity: 1;border-color:rgb(153 27 27 / var(--tw-border-opacity, 1))}.border-rose-500{--tw-border-opacity: 1;border-color:rgb(244 63 94 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.border-violet-500{--tw-border-opacity: 1;border-color:rgb(139 92 246 / var(--tw-border-opacity, 1))}.border-yellow-700\/50{border-color:#a1620780}.border-b-gray-800{--tw-border-opacity: 1;border-bottom-color:rgb(31 41 55 / var(--tw-border-opacity, 1))}.border-l-blue-500{--tw-border-opacity: 1;border-left-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.border-l-cyan-500{--tw-border-opacity: 1;border-left-color:rgb(6 182 212 / var(--tw-border-opacity, 1))}.border-l-gray-500{--tw-border-opacity: 1;border-left-color:rgb(107 114 128 / var(--tw-border-opacity, 1))}.border-l-green-500{--tw-border-opacity: 1;border-left-color:rgb(34 197 94 / var(--tw-border-opacity, 1))}.border-l-purple-500{--tw-border-opacity: 1;border-left-color:rgb(168 85 247 / var(--tw-border-opacity, 1))}.border-t-transparent{border-top-color:transparent}.bg-amber-500{--tw-bg-opacity: 1;background-color:rgb(245 158 11 / var(--tw-bg-opacity, 1))}.bg-amber-900\/30{background-color:#78350f4d}.bg-amber-900\/50{background-color:#78350f80}.bg-amber-900\/60{background-color:#78350f99}.bg-amber-950\/40{background-color:#451a0366}.bg-black\/60{background-color:#0009}.bg-black\/80{background-color:#000c}.bg-black\/85{background-color:#000000d9}.bg-blue-100{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity, 1))}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-blue-500\/5{background-color:#3b82f60d}.bg-blue-600{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.bg-blue-700{--tw-bg-opacity: 1;background-color:rgb(29 78 216 / var(--tw-bg-opacity, 1))}.bg-blue-900\/40{background-color:#1e3a8a66}.bg-blue-900\/50{background-color:#1e3a8a80}.bg-blue-900\/60{background-color:#1e3a8a99}.bg-blue-950\/30{background-color:#1725544d}.bg-blue-950\/40{background-color:#17255466}.bg-cyan-500{--tw-bg-opacity: 1;background-color:rgb(6 182 212 / var(--tw-bg-opacity, 1))}.bg-cyan-600{--tw-bg-opacity: 1;background-color:rgb(8 145 178 / var(--tw-bg-opacity, 1))}.bg-cyan-700\/40{background-color:#0e749066}.bg-cyan-900\/40{background-color:#164e6366}.bg-cyan-900\/50{background-color:#164e6380}.bg-emerald-500{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))}.bg-emerald-900{--tw-bg-opacity: 1;background-color:rgb(6 78 59 / var(--tw-bg-opacity, 1))}.bg-emerald-900\/50{background-color:#064e3b80}.bg-emerald-900\/60{background-color:#064e3b99}.bg-emerald-950\/30{background-color:#022c224d}.bg-fuchsia-900\/60{background-color:#701a7599}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-500{--tw-bg-opacity: 1;background-color:rgb(107 114 128 / var(--tw-bg-opacity, 1))}.bg-gray-500\/5{background-color:#6b72800d}.bg-gray-600{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.bg-gray-700{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.bg-gray-800{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.bg-gray-800\/30{background-color:#1f29374d}.bg-gray-800\/40{background-color:#1f293766}.bg-gray-800\/50{background-color:#1f293780}.bg-gray-800\/60{background-color:#1f293799}.bg-gray-900{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / var(--tw-bg-opacity, 1))}.bg-gray-900\/40{background-color:#11182766}.bg-gray-900\/50{background-color:#11182780}.bg-gray-900\/60{background-color:#11182799}.bg-gray-900\/80{background-color:#111827cc}.bg-gray-950{--tw-bg-opacity: 1;background-color:rgb(3 7 18 / var(--tw-bg-opacity, 1))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-green-500\/5{background-color:#22c55e0d}.bg-green-600{--tw-bg-opacity: 1;background-color:rgb(22 163 74 / var(--tw-bg-opacity, 1))}.bg-green-700{--tw-bg-opacity: 1;background-color:rgb(21 128 61 / var(--tw-bg-opacity, 1))}.bg-green-900{--tw-bg-opacity: 1;background-color:rgb(20 83 45 / var(--tw-bg-opacity, 1))}.bg-green-900\/40{background-color:#14532d66}.bg-green-900\/50{background-color:#14532d80}.bg-green-900\/60{background-color:#14532d99}.bg-green-950\/30{background-color:#052e164d}.bg-indigo-900\/60{background-color:#312e8199}.bg-lime-900\/60{background-color:#36531499}.bg-orange-100{--tw-bg-opacity: 1;background-color:rgb(255 237 213 / var(--tw-bg-opacity, 1))}.bg-orange-900\/20{background-color:#7c2d1233}.bg-orange-900\/60{background-color:#7c2d1299}.bg-purple-500{--tw-bg-opacity: 1;background-color:rgb(168 85 247 / var(--tw-bg-opacity, 1))}.bg-purple-500\/5{background-color:#a855f70d}.bg-purple-900\/50{background-color:#581c8780}.bg-purple-900\/60{background-color:#581c8799}.bg-purple-950\/30{background-color:#3b07644d}.bg-purple-950\/40{background-color:#3b076466}.bg-red-100{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-red-900{--tw-bg-opacity: 1;background-color:rgb(127 29 29 / var(--tw-bg-opacity, 1))}.bg-red-900\/10{background-color:#7f1d1d1a}.bg-red-900\/40{background-color:#7f1d1d66}.bg-red-900\/50{background-color:#7f1d1d80}.bg-red-900\/60{background-color:#7f1d1d99}.bg-rose-500{--tw-bg-opacity: 1;background-color:rgb(244 63 94 / var(--tw-bg-opacity, 1))}.bg-rose-900\/60{background-color:#88133799}.bg-teal-900\/60{background-color:#134e4a99}.bg-violet-950\/30{background-color:#2e10654d}.bg-yellow-100{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1))}.bg-yellow-500{--tw-bg-opacity: 1;background-color:rgb(234 179 8 / var(--tw-bg-opacity, 1))}.bg-yellow-600{--tw-bg-opacity: 1;background-color:rgb(202 138 4 / var(--tw-bg-opacity, 1))}.bg-yellow-700{--tw-bg-opacity: 1;background-color:rgb(161 98 7 / var(--tw-bg-opacity, 1))}.bg-yellow-900\/50{background-color:#713f1280}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pl-2{padding-left:.5rem}.pl-3{padding-left:.75rem}.pl-4{padding-left:1rem}.pt-3{padding-top:.75rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.align-top{vertical-align:top}.align-middle{vertical-align:middle}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[9px\]{font-size:9px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.normal-case{text-transform:none}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-4{line-height:1rem}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-amber-300{--tw-text-opacity: 1;color:rgb(252 211 77 / var(--tw-text-opacity, 1))}.text-amber-400{--tw-text-opacity: 1;color:rgb(251 191 36 / var(--tw-text-opacity, 1))}.text-amber-400\/70{color:#fbbf24b3}.text-amber-400\/80{color:#fbbf24cc}.text-amber-500{--tw-text-opacity: 1;color:rgb(245 158 11 / var(--tw-text-opacity, 1))}.text-amber-600{--tw-text-opacity: 1;color:rgb(217 119 6 / var(--tw-text-opacity, 1))}.text-blue-200{--tw-text-opacity: 1;color:rgb(191 219 254 / var(--tw-text-opacity, 1))}.text-blue-300{--tw-text-opacity: 1;color:rgb(147 197 253 / var(--tw-text-opacity, 1))}.text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.text-blue-500{--tw-text-opacity: 1;color:rgb(59 130 246 / var(--tw-text-opacity, 1))}.text-blue-800{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity, 1))}.text-cyan-200{--tw-text-opacity: 1;color:rgb(165 243 252 / var(--tw-text-opacity, 1))}.text-cyan-300{--tw-text-opacity: 1;color:rgb(103 232 249 / var(--tw-text-opacity, 1))}.text-cyan-400{--tw-text-opacity: 1;color:rgb(34 211 238 / var(--tw-text-opacity, 1))}.text-cyan-400\/70{color:#22d3eeb3}.text-cyan-400\/80{color:#22d3eecc}.text-cyan-500{--tw-text-opacity: 1;color:rgb(6 182 212 / var(--tw-text-opacity, 1))}.text-cyan-600{--tw-text-opacity: 1;color:rgb(8 145 178 / var(--tw-text-opacity, 1))}.text-emerald-300{--tw-text-opacity: 1;color:rgb(110 231 183 / var(--tw-text-opacity, 1))}.text-emerald-400{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.text-fuchsia-300{--tw-text-opacity: 1;color:rgb(240 171 252 / var(--tw-text-opacity, 1))}.text-gray-100{--tw-text-opacity: 1;color:rgb(243 244 246 / var(--tw-text-opacity, 1))}.text-gray-200{--tw-text-opacity: 1;color:rgb(229 231 235 / var(--tw-text-opacity, 1))}.text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-green-300{--tw-text-opacity: 1;color:rgb(134 239 172 / var(--tw-text-opacity, 1))}.text-green-400{--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity, 1))}.text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.text-green-800{--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity, 1))}.text-indigo-300{--tw-text-opacity: 1;color:rgb(165 180 252 / var(--tw-text-opacity, 1))}.text-indigo-400{--tw-text-opacity: 1;color:rgb(129 140 248 / var(--tw-text-opacity, 1))}.text-lime-300{--tw-text-opacity: 1;color:rgb(190 242 100 / var(--tw-text-opacity, 1))}.text-orange-300{--tw-text-opacity: 1;color:rgb(253 186 116 / var(--tw-text-opacity, 1))}.text-orange-400{--tw-text-opacity: 1;color:rgb(251 146 60 / var(--tw-text-opacity, 1))}.text-orange-400\/70{color:#fb923cb3}.text-orange-700{--tw-text-opacity: 1;color:rgb(194 65 12 / var(--tw-text-opacity, 1))}.text-orange-800{--tw-text-opacity: 1;color:rgb(154 52 18 / var(--tw-text-opacity, 1))}.text-purple-300{--tw-text-opacity: 1;color:rgb(216 180 254 / var(--tw-text-opacity, 1))}.text-purple-400{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity, 1))}.text-red-300{--tw-text-opacity: 1;color:rgb(252 165 165 / var(--tw-text-opacity, 1))}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-red-400\/70{color:#f87171b3}.text-red-800{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.text-rose-300{--tw-text-opacity: 1;color:rgb(253 164 175 / var(--tw-text-opacity, 1))}.text-rose-400{--tw-text-opacity: 1;color:rgb(251 113 133 / var(--tw-text-opacity, 1))}.text-sky-400{--tw-text-opacity: 1;color:rgb(56 189 248 / var(--tw-text-opacity, 1))}.text-teal-300{--tw-text-opacity: 1;color:rgb(94 234 212 / var(--tw-text-opacity, 1))}.text-violet-400{--tw-text-opacity: 1;color:rgb(167 139 250 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-yellow-300{--tw-text-opacity: 1;color:rgb(253 224 71 / var(--tw-text-opacity, 1))}.text-yellow-400{--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity, 1))}.text-yellow-800{--tw-text-opacity: 1;color:rgb(133 77 14 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.underline-offset-2{text-underline-offset:2px}.placeholder-gray-500::-moz-placeholder{--tw-placeholder-opacity: 1;color:rgb(107 114 128 / var(--tw-placeholder-opacity, 1))}.placeholder-gray-500::placeholder{--tw-placeholder-opacity: 1;color:rgb(107 114 128 / var(--tw-placeholder-opacity, 1))}.placeholder-gray-600::-moz-placeholder{--tw-placeholder-opacity: 1;color:rgb(75 85 99 / var(--tw-placeholder-opacity, 1))}.placeholder-gray-600::placeholder{--tw-placeholder-opacity: 1;color:rgb(75 85 99 / var(--tw-placeholder-opacity, 1))}.accent-blue-500{accent-color:#3b82f6}.opacity-25{opacity:.25}.opacity-30{opacity:.3}.opacity-60{opacity:.6}.opacity-75{opacity:.75}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.ring-1{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-blue-400{--tw-ring-opacity: 1;--tw-ring-color: rgb(96 165 250 / var(--tw-ring-opacity, 1))}.ring-blue-500{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1))}.ring-offset-1{--tw-ring-offset-width: 1px}.ring-offset-gray-900{--tw-ring-offset-color: #111827}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.trace-scroll::-webkit-scrollbar{width:6px}.trace-scroll::-webkit-scrollbar-track{background:transparent}.trace-scroll::-webkit-scrollbar-thumb{background:#4b5563;border-radius:3px}.trace-scroll::-webkit-scrollbar-thumb:hover{background:#6b7280}.theme-model .panel-drop-target{outline:2px dashed #60a5fa;outline-offset:-2px;border-radius:.5rem;background:#60a5fa0d}.theme-arena .panel-drop-target{outline:2px dashed #a78bfa;outline-offset:-2px;border-radius:.5rem;background:#a78bfa0d}.theme-rlm .panel-drop-target{outline:2px dashed #fb923c;outline-offset:-2px;border-radius:.5rem;background:#fb923c0d}.theme-harbor .panel-drop-target{outline:2px dashed #2dd4bf;outline-offset:-2px;border-radius:.5rem;background:#2dd4bf0d}.code-block{font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:.8rem;line-height:1.4}.drag-handle{cursor:grab}.drag-handle:active{cursor:grabbing}.light{--tw-bg-opacity: 1}.light .bg-gray-950{background-color:#fff!important}.light .bg-gray-900{background-color:#f9fafb!important}.light .bg-gray-900\/80{background-color:#f9fafbcc!important}.light .bg-gray-900\/50{background-color:#f9fafb80!important}.light .bg-gray-800{background-color:#f3f4f6!important}.light .bg-gray-800\/50{background-color:#f3f4f680!important}.light .bg-gray-700{background-color:#e5e7eb!important}.light .text-gray-100{color:#111827!important}.light .text-gray-200{color:#1f2937!important}.light .text-gray-300{color:#374151!important}.light .text-gray-400{color:#6b7280!important}.light .text-gray-500{color:#9ca3af!important}.light .text-gray-600{color:#d1d5db!important}.light .border-gray-700{border-color:#e5e7eb!important}.light .border-gray-800{border-color:#f3f4f6!important}.light .border-gray-800\/50{border-color:#f3f4f680!important}.light .text-cyan-400{color:#0891b2!important}.light .text-cyan-400\/80{color:#0891b2cc!important}.light .border-cyan-500{border-color:#06b6d4!important}.light .text-emerald-300,.light .text-emerald-400{color:#059669!important}.light .text-amber-400{color:#d97706!important}.light .text-amber-400\/80{color:#d97706cc!important}.light .text-amber-400\/70{color:#d97706b3!important}.light .text-violet-400{color:#7c3aed!important}.light .text-red-400{color:#dc2626!important}.light .text-yellow-400{color:#ca8a04!important}.light .text-green-400{color:#16a34a!important}.light .bg-emerald-950\/30{background-color:#05966914!important}.light .bg-emerald-900{background-color:#05966926!important}.light .bg-violet-950\/30{background-color:#7c3aed14!important}.light .bg-orange-900\/20{background-color:#ea580c14!important}.light .bg-red-900\/10{background-color:#dc26260d!important}.light .bg-cyan-600{background-color:#0891b2!important}.light .border-emerald-500,.light .border-emerald-700{border-color:#059669!important}.light .border-amber-500{border-color:#d97706!important}.light .border-violet-500{border-color:#7c3aed!important}.light .border-cyan-500{border-color:#0891b2!important}.light .border-orange-800\/50{border-color:#ea580c4d!important}.light .hover\:bg-gray-800:hover{background-color:#e5e7eb!important}.light .hover\:bg-gray-900\/50:hover{background-color:#f9fafb80!important}.light .hover\:text-gray-200:hover{color:#1f2937!important}.light .hover\:text-gray-300:hover{color:#374151!important}.light .hover\:border-gray-700:hover{border-color:#d1d5db!important}.light .hover\:border-gray-400:hover{border-color:#9ca3af!important}.light .hover\:text-cyan-300:hover{color:#0891b2!important}.light select{background-color:#f3f4f6!important;color:#374151!important;border-color:#d1d5db!important}.light input{background-color:#f9fafb!important;color:#374151!important;border-color:#d1d5db!important}.light .trace-scroll::-webkit-scrollbar-thumb{background:#d1d5db}.light .trace-scroll::-webkit-scrollbar-thumb:hover{background:#9ca3af}.light pre{background-color:#f3f4f6!important}.light code{background-color:#f3f4f6!important;color:#374151!important}.first\:mt-0:first-child{margin-top:0}.last\:border-0:last-child{border-width:0px}.hover\:border-cyan-600:hover{--tw-border-opacity: 1;border-color:rgb(8 145 178 / var(--tw-border-opacity, 1))}.hover\:border-gray-400:hover{--tw-border-opacity: 1;border-color:rgb(156 163 175 / var(--tw-border-opacity, 1))}.hover\:border-gray-500:hover{--tw-border-opacity: 1;border-color:rgb(107 114 128 / var(--tw-border-opacity, 1))}.hover\:border-gray-700:hover{--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1))}.hover\:bg-blue-500:hover{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.hover\:bg-cyan-500:hover{--tw-bg-opacity: 1;background-color:rgb(6 182 212 / var(--tw-bg-opacity, 1))}.hover\:bg-cyan-600\/50:hover{background-color:#0891b280}.hover\:bg-cyan-900\/70:hover{background-color:#164e63b3}.hover\:bg-gray-600:hover{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-700:hover{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-800:hover{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-800\/30:hover{background-color:#1f29374d}.hover\:bg-gray-800\/40:hover{background-color:#1f293766}.hover\:bg-gray-800\/50:hover{background-color:#1f293780}.hover\:bg-gray-900\/50:hover{background-color:#11182780}.hover\:bg-red-800:hover{--tw-bg-opacity: 1;background-color:rgb(153 27 27 / var(--tw-bg-opacity, 1))}.hover\:text-blue-400:hover{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.hover\:text-cyan-300:hover{--tw-text-opacity: 1;color:rgb(103 232 249 / var(--tw-text-opacity, 1))}.hover\:text-cyan-400:hover{--tw-text-opacity: 1;color:rgb(34 211 238 / var(--tw-text-opacity, 1))}.hover\:text-gray-100:hover{--tw-text-opacity: 1;color:rgb(243 244 246 / var(--tw-text-opacity, 1))}.hover\:text-gray-200:hover{--tw-text-opacity: 1;color:rgb(229 231 235 / var(--tw-text-opacity, 1))}.hover\:text-gray-300:hover{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.hover\:text-gray-400:hover{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.hover\:text-gray-800:hover{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.hover\:text-red-300:hover{--tw-text-opacity: 1;color:rgb(252 165 165 / var(--tw-text-opacity, 1))}.hover\:text-red-400:hover{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.focus\:border-blue-500:focus{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.focus\:border-cyan-500:focus{--tw-border-opacity: 1;border-color:rgb(6 182 212 / var(--tw-border-opacity, 1))}.focus\:border-cyan-600:focus{--tw-border-opacity: 1;border-color:rgb(8 145 178 / var(--tw-border-opacity, 1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-blue-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1))}.focus\:ring-offset-0:focus{--tw-ring-offset-width: 0px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-700:disabled{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.disabled\:text-gray-500:disabled{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.disabled\:opacity-40:disabled{opacity:.4}.group:hover .group-hover\:flex{display:flex}.group:hover .group-hover\:text-gray-200{--tw-text-opacity: 1;color:rgb(229 231 235 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:opacity-90{opacity:.9}.dark\:border-gray-600:is(.dark *){--tw-border-opacity: 1;border-color:rgb(75 85 99 / var(--tw-border-opacity, 1))}.dark\:text-gray-400:is(.dark *){--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.dark\:hover\:text-gray-200:hover:is(.dark *){--tw-text-opacity: 1;color:rgb(229 231 235 / var(--tw-text-opacity, 1))}@media(min-width:640px){.sm\:block{display:block}.sm\:w-64{width:16rem}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1024px){.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1280px){.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
|
|
|
|
|
|
frontend/dist/assets/index-bo0f-zdf.css
ADDED
|
@@ -0,0 +1 @@
|
|
|
|
|
|
|
| 1 |
+
*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.-left-\[17px\]{left:-17px}.-left-\[5px\]{left:-5px}.left-0{left:0}.left-4{left:1rem}.right-4{right:1rem}.right-5{right:1.25rem}.top-0{top:0}.top-3{top:.75rem}.top-4{top:1rem}.top-full{top:100%}.z-10{z-index:10}.z-40{z-index:40}.z-50{z-index:50}.my-2{margin-top:.5rem;margin-bottom:.5rem}.my-4{margin-top:1rem;margin-bottom:1rem}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.ml-1{margin-left:.25rem}.ml-1\.5{margin-left:.375rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.ml-6{margin-left:1.5rem}.ml-auto{margin-left:auto}.mr-0\.5{margin-right:.125rem}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mr-6{margin-right:1.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1 / 1}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3\.5{height:.875rem}.h-32{height:8rem}.h-4{height:1rem}.h-40{height:10rem}.h-48{height:12rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-\[85vh\]{height:85vh}.h-full{height:100%}.h-screen{height:100vh}.max-h-24{max-height:6rem}.max-h-32{max-height:8rem}.max-h-40{max-height:10rem}.max-h-60{max-height:15rem}.max-h-\[80vh\]{max-height:80vh}.max-h-\[90vh\]{max-height:90vh}.min-h-0{min-height:0px}.min-h-\[300px\]{min-height:300px}.w-12{width:3rem}.w-16{width:4rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3\.5{width:.875rem}.w-36{width:9rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-60{width:15rem}.w-64{width:16rem}.w-72{width:18rem}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-72{min-width:18rem}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-\[80\%\]{max-width:80%}.max-w-\[90vw\]{max-width:90vw}.max-w-full{max-width:100%}.max-w-lg{max-width:32rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.table-auto{table-layout:auto}.border-collapse{border-collapse:collapse}.rotate-90{--tw-rotate: 90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-\[0\.97\]{--tw-scale-x: .97;--tw-scale-y: .97;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize-y{resize:vertical}.list-inside{list-style-position:inside}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(0px * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px * var(--tw-space-y-reverse))}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.125rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.125rem * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-sm{border-radius:.125rem}.rounded-xl{border-radius:.75rem}.rounded-r{border-top-right-radius:.25rem;border-bottom-right-radius:.25rem}.rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l-2{border-left-width:2px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-amber-400{--tw-border-opacity: 1;border-color:rgb(251 191 36 / var(--tw-border-opacity, 1))}.border-amber-500{--tw-border-opacity: 1;border-color:rgb(245 158 11 / var(--tw-border-opacity, 1))}.border-amber-600{--tw-border-opacity: 1;border-color:rgb(217 119 6 / var(--tw-border-opacity, 1))}.border-amber-700\/40{border-color:#b4530966}.border-amber-700\/50{border-color:#b4530980}.border-amber-800{--tw-border-opacity: 1;border-color:rgb(146 64 14 / var(--tw-border-opacity, 1))}.border-blue-500{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.border-blue-600{--tw-border-opacity: 1;border-color:rgb(37 99 235 / var(--tw-border-opacity, 1))}.border-blue-700{--tw-border-opacity: 1;border-color:rgb(29 78 216 / var(--tw-border-opacity, 1))}.border-blue-700\/50{border-color:#1d4ed880}.border-blue-800{--tw-border-opacity: 1;border-color:rgb(30 64 175 / var(--tw-border-opacity, 1))}.border-cyan-500{--tw-border-opacity: 1;border-color:rgb(6 182 212 / var(--tw-border-opacity, 1))}.border-cyan-700{--tw-border-opacity: 1;border-color:rgb(14 116 144 / var(--tw-border-opacity, 1))}.border-cyan-700\/30{border-color:#0e74904d}.border-cyan-700\/50{border-color:#0e749080}.border-cyan-800\/60{border-color:#155e7599}.border-emerald-500{--tw-border-opacity: 1;border-color:rgb(16 185 129 / var(--tw-border-opacity, 1))}.border-emerald-600{--tw-border-opacity: 1;border-color:rgb(5 150 105 / var(--tw-border-opacity, 1))}.border-emerald-700{--tw-border-opacity: 1;border-color:rgb(4 120 87 / var(--tw-border-opacity, 1))}.border-emerald-700\/50{border-color:#04785780}.border-emerald-800{--tw-border-opacity: 1;border-color:rgb(6 95 70 / var(--tw-border-opacity, 1))}.border-gray-500{--tw-border-opacity: 1;border-color:rgb(107 114 128 / var(--tw-border-opacity, 1))}.border-gray-600{--tw-border-opacity: 1;border-color:rgb(75 85 99 / var(--tw-border-opacity, 1))}.border-gray-700{--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1))}.border-gray-700\/50{border-color:#37415180}.border-gray-800{--tw-border-opacity: 1;border-color:rgb(31 41 55 / var(--tw-border-opacity, 1))}.border-gray-800\/50{border-color:#1f293780}.border-green-600{--tw-border-opacity: 1;border-color:rgb(22 163 74 / var(--tw-border-opacity, 1))}.border-green-700{--tw-border-opacity: 1;border-color:rgb(21 128 61 / var(--tw-border-opacity, 1))}.border-green-800{--tw-border-opacity: 1;border-color:rgb(22 101 52 / var(--tw-border-opacity, 1))}.border-orange-800\/50{border-color:#9a341280}.border-purple-500{--tw-border-opacity: 1;border-color:rgb(168 85 247 / var(--tw-border-opacity, 1))}.border-purple-600{--tw-border-opacity: 1;border-color:rgb(147 51 234 / var(--tw-border-opacity, 1))}.border-purple-700{--tw-border-opacity: 1;border-color:rgb(126 34 206 / var(--tw-border-opacity, 1))}.border-purple-700\/50{border-color:#7e22ce80}.border-red-600{--tw-border-opacity: 1;border-color:rgb(220 38 38 / var(--tw-border-opacity, 1))}.border-red-700{--tw-border-opacity: 1;border-color:rgb(185 28 28 / var(--tw-border-opacity, 1))}.border-red-800{--tw-border-opacity: 1;border-color:rgb(153 27 27 / var(--tw-border-opacity, 1))}.border-rose-500{--tw-border-opacity: 1;border-color:rgb(244 63 94 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.border-violet-500{--tw-border-opacity: 1;border-color:rgb(139 92 246 / var(--tw-border-opacity, 1))}.border-yellow-700\/50{border-color:#a1620780}.border-b-gray-800{--tw-border-opacity: 1;border-bottom-color:rgb(31 41 55 / var(--tw-border-opacity, 1))}.border-l-blue-500{--tw-border-opacity: 1;border-left-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.border-l-cyan-500{--tw-border-opacity: 1;border-left-color:rgb(6 182 212 / var(--tw-border-opacity, 1))}.border-l-gray-500{--tw-border-opacity: 1;border-left-color:rgb(107 114 128 / var(--tw-border-opacity, 1))}.border-l-green-500{--tw-border-opacity: 1;border-left-color:rgb(34 197 94 / var(--tw-border-opacity, 1))}.border-l-purple-500{--tw-border-opacity: 1;border-left-color:rgb(168 85 247 / var(--tw-border-opacity, 1))}.border-t-transparent{border-top-color:transparent}.bg-amber-500{--tw-bg-opacity: 1;background-color:rgb(245 158 11 / var(--tw-bg-opacity, 1))}.bg-amber-900\/30{background-color:#78350f4d}.bg-amber-900\/50{background-color:#78350f80}.bg-amber-900\/60{background-color:#78350f99}.bg-amber-950\/40{background-color:#451a0366}.bg-black\/60{background-color:#0009}.bg-black\/80{background-color:#000c}.bg-black\/85{background-color:#000000d9}.bg-blue-100{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity, 1))}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-blue-500\/5{background-color:#3b82f60d}.bg-blue-600{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.bg-blue-700{--tw-bg-opacity: 1;background-color:rgb(29 78 216 / var(--tw-bg-opacity, 1))}.bg-blue-900\/40{background-color:#1e3a8a66}.bg-blue-900\/50{background-color:#1e3a8a80}.bg-blue-900\/60{background-color:#1e3a8a99}.bg-blue-950\/30{background-color:#1725544d}.bg-blue-950\/40{background-color:#17255466}.bg-cyan-500{--tw-bg-opacity: 1;background-color:rgb(6 182 212 / var(--tw-bg-opacity, 1))}.bg-cyan-600{--tw-bg-opacity: 1;background-color:rgb(8 145 178 / var(--tw-bg-opacity, 1))}.bg-cyan-700\/40{background-color:#0e749066}.bg-cyan-900\/40{background-color:#164e6366}.bg-cyan-900\/50{background-color:#164e6380}.bg-emerald-500{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))}.bg-emerald-900{--tw-bg-opacity: 1;background-color:rgb(6 78 59 / var(--tw-bg-opacity, 1))}.bg-emerald-900\/50{background-color:#064e3b80}.bg-emerald-900\/60{background-color:#064e3b99}.bg-emerald-950\/30{background-color:#022c224d}.bg-fuchsia-900\/60{background-color:#701a7599}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-500{--tw-bg-opacity: 1;background-color:rgb(107 114 128 / var(--tw-bg-opacity, 1))}.bg-gray-500\/5{background-color:#6b72800d}.bg-gray-600{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.bg-gray-700{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.bg-gray-800{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.bg-gray-800\/30{background-color:#1f29374d}.bg-gray-800\/40{background-color:#1f293766}.bg-gray-800\/50{background-color:#1f293780}.bg-gray-800\/60{background-color:#1f293799}.bg-gray-900{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / var(--tw-bg-opacity, 1))}.bg-gray-900\/30{background-color:#1118274d}.bg-gray-900\/40{background-color:#11182766}.bg-gray-900\/50{background-color:#11182780}.bg-gray-900\/60{background-color:#11182799}.bg-gray-900\/70{background-color:#111827b3}.bg-gray-900\/80{background-color:#111827cc}.bg-gray-900\/90{background-color:#111827e6}.bg-gray-950{--tw-bg-opacity: 1;background-color:rgb(3 7 18 / var(--tw-bg-opacity, 1))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-green-500\/5{background-color:#22c55e0d}.bg-green-600{--tw-bg-opacity: 1;background-color:rgb(22 163 74 / var(--tw-bg-opacity, 1))}.bg-green-700{--tw-bg-opacity: 1;background-color:rgb(21 128 61 / var(--tw-bg-opacity, 1))}.bg-green-900{--tw-bg-opacity: 1;background-color:rgb(20 83 45 / var(--tw-bg-opacity, 1))}.bg-green-900\/40{background-color:#14532d66}.bg-green-900\/50{background-color:#14532d80}.bg-green-900\/60{background-color:#14532d99}.bg-green-950\/30{background-color:#052e164d}.bg-indigo-900\/60{background-color:#312e8199}.bg-lime-900\/60{background-color:#36531499}.bg-orange-100{--tw-bg-opacity: 1;background-color:rgb(255 237 213 / var(--tw-bg-opacity, 1))}.bg-orange-900\/20{background-color:#7c2d1233}.bg-orange-900\/60{background-color:#7c2d1299}.bg-purple-500{--tw-bg-opacity: 1;background-color:rgb(168 85 247 / var(--tw-bg-opacity, 1))}.bg-purple-500\/5{background-color:#a855f70d}.bg-purple-900\/40{background-color:#581c8766}.bg-purple-900\/50{background-color:#581c8780}.bg-purple-900\/60{background-color:#581c8799}.bg-purple-950\/30{background-color:#3b07644d}.bg-purple-950\/40{background-color:#3b076466}.bg-red-100{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-red-900{--tw-bg-opacity: 1;background-color:rgb(127 29 29 / var(--tw-bg-opacity, 1))}.bg-red-900\/10{background-color:#7f1d1d1a}.bg-red-900\/40{background-color:#7f1d1d66}.bg-red-900\/50{background-color:#7f1d1d80}.bg-red-900\/60{background-color:#7f1d1d99}.bg-rose-500{--tw-bg-opacity: 1;background-color:rgb(244 63 94 / var(--tw-bg-opacity, 1))}.bg-rose-900\/60{background-color:#88133799}.bg-teal-900\/60{background-color:#134e4a99}.bg-violet-950\/30{background-color:#2e10654d}.bg-yellow-100{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1))}.bg-yellow-500{--tw-bg-opacity: 1;background-color:rgb(234 179 8 / var(--tw-bg-opacity, 1))}.bg-yellow-600{--tw-bg-opacity: 1;background-color:rgb(202 138 4 / var(--tw-bg-opacity, 1))}.bg-yellow-700{--tw-bg-opacity: 1;background-color:rgb(161 98 7 / var(--tw-bg-opacity, 1))}.bg-yellow-900\/50{background-color:#713f1280}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pl-2{padding-left:.5rem}.pl-3{padding-left:.75rem}.pl-4{padding-left:1rem}.pt-3{padding-top:.75rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.align-top{vertical-align:top}.align-middle{vertical-align:middle}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[9px\]{font-size:9px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.normal-case{text-transform:none}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-4{line-height:1rem}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.leading-tight{line-height:1.25}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-amber-300{--tw-text-opacity: 1;color:rgb(252 211 77 / var(--tw-text-opacity, 1))}.text-amber-400{--tw-text-opacity: 1;color:rgb(251 191 36 / var(--tw-text-opacity, 1))}.text-amber-400\/70{color:#fbbf24b3}.text-amber-400\/80{color:#fbbf24cc}.text-amber-500{--tw-text-opacity: 1;color:rgb(245 158 11 / var(--tw-text-opacity, 1))}.text-amber-600{--tw-text-opacity: 1;color:rgb(217 119 6 / var(--tw-text-opacity, 1))}.text-blue-200{--tw-text-opacity: 1;color:rgb(191 219 254 / var(--tw-text-opacity, 1))}.text-blue-300{--tw-text-opacity: 1;color:rgb(147 197 253 / var(--tw-text-opacity, 1))}.text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.text-blue-500{--tw-text-opacity: 1;color:rgb(59 130 246 / var(--tw-text-opacity, 1))}.text-blue-800{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity, 1))}.text-cyan-200{--tw-text-opacity: 1;color:rgb(165 243 252 / var(--tw-text-opacity, 1))}.text-cyan-300{--tw-text-opacity: 1;color:rgb(103 232 249 / var(--tw-text-opacity, 1))}.text-cyan-400{--tw-text-opacity: 1;color:rgb(34 211 238 / var(--tw-text-opacity, 1))}.text-cyan-400\/70{color:#22d3eeb3}.text-cyan-400\/80{color:#22d3eecc}.text-cyan-500{--tw-text-opacity: 1;color:rgb(6 182 212 / var(--tw-text-opacity, 1))}.text-cyan-600{--tw-text-opacity: 1;color:rgb(8 145 178 / var(--tw-text-opacity, 1))}.text-emerald-300{--tw-text-opacity: 1;color:rgb(110 231 183 / var(--tw-text-opacity, 1))}.text-emerald-400{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.text-fuchsia-300{--tw-text-opacity: 1;color:rgb(240 171 252 / var(--tw-text-opacity, 1))}.text-gray-100{--tw-text-opacity: 1;color:rgb(243 244 246 / var(--tw-text-opacity, 1))}.text-gray-200{--tw-text-opacity: 1;color:rgb(229 231 235 / var(--tw-text-opacity, 1))}.text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-green-300{--tw-text-opacity: 1;color:rgb(134 239 172 / var(--tw-text-opacity, 1))}.text-green-400{--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity, 1))}.text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.text-green-800{--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity, 1))}.text-indigo-300{--tw-text-opacity: 1;color:rgb(165 180 252 / var(--tw-text-opacity, 1))}.text-indigo-400{--tw-text-opacity: 1;color:rgb(129 140 248 / var(--tw-text-opacity, 1))}.text-lime-300{--tw-text-opacity: 1;color:rgb(190 242 100 / var(--tw-text-opacity, 1))}.text-orange-300{--tw-text-opacity: 1;color:rgb(253 186 116 / var(--tw-text-opacity, 1))}.text-orange-400{--tw-text-opacity: 1;color:rgb(251 146 60 / var(--tw-text-opacity, 1))}.text-orange-400\/70{color:#fb923cb3}.text-orange-700{--tw-text-opacity: 1;color:rgb(194 65 12 / var(--tw-text-opacity, 1))}.text-orange-800{--tw-text-opacity: 1;color:rgb(154 52 18 / var(--tw-text-opacity, 1))}.text-purple-200{--tw-text-opacity: 1;color:rgb(233 213 255 / var(--tw-text-opacity, 1))}.text-purple-300{--tw-text-opacity: 1;color:rgb(216 180 254 / var(--tw-text-opacity, 1))}.text-purple-400{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity, 1))}.text-purple-400\/70{color:#c084fcb3}.text-red-300{--tw-text-opacity: 1;color:rgb(252 165 165 / var(--tw-text-opacity, 1))}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-red-400\/70{color:#f87171b3}.text-red-800{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.text-rose-300{--tw-text-opacity: 1;color:rgb(253 164 175 / var(--tw-text-opacity, 1))}.text-rose-400{--tw-text-opacity: 1;color:rgb(251 113 133 / var(--tw-text-opacity, 1))}.text-sky-400{--tw-text-opacity: 1;color:rgb(56 189 248 / var(--tw-text-opacity, 1))}.text-teal-300{--tw-text-opacity: 1;color:rgb(94 234 212 / var(--tw-text-opacity, 1))}.text-violet-400{--tw-text-opacity: 1;color:rgb(167 139 250 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-yellow-300{--tw-text-opacity: 1;color:rgb(253 224 71 / var(--tw-text-opacity, 1))}.text-yellow-400{--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity, 1))}.text-yellow-800{--tw-text-opacity: 1;color:rgb(133 77 14 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.underline-offset-2{text-underline-offset:2px}.placeholder-gray-500::-moz-placeholder{--tw-placeholder-opacity: 1;color:rgb(107 114 128 / var(--tw-placeholder-opacity, 1))}.placeholder-gray-500::placeholder{--tw-placeholder-opacity: 1;color:rgb(107 114 128 / var(--tw-placeholder-opacity, 1))}.placeholder-gray-600::-moz-placeholder{--tw-placeholder-opacity: 1;color:rgb(75 85 99 / var(--tw-placeholder-opacity, 1))}.placeholder-gray-600::placeholder{--tw-placeholder-opacity: 1;color:rgb(75 85 99 / var(--tw-placeholder-opacity, 1))}.accent-blue-500{accent-color:#3b82f6}.opacity-25{opacity:.25}.opacity-30{opacity:.3}.opacity-60{opacity:.6}.opacity-75{opacity:.75}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.ring-1{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-blue-400{--tw-ring-opacity: 1;--tw-ring-color: rgb(96 165 250 / var(--tw-ring-opacity, 1))}.ring-blue-500{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1))}.ring-offset-1{--tw-ring-offset-width: 1px}.ring-offset-gray-900{--tw-ring-offset-color: #111827}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.trace-scroll::-webkit-scrollbar{width:6px}.trace-scroll::-webkit-scrollbar-track{background:transparent}.trace-scroll::-webkit-scrollbar-thumb{background:#4b5563;border-radius:3px}.trace-scroll::-webkit-scrollbar-thumb:hover{background:#6b7280}.theme-model .panel-drop-target{outline:2px dashed #60a5fa;outline-offset:-2px;border-radius:.5rem;background:#60a5fa0d}.theme-arena .panel-drop-target{outline:2px dashed #a78bfa;outline-offset:-2px;border-radius:.5rem;background:#a78bfa0d}.theme-rlm .panel-drop-target{outline:2px dashed #fb923c;outline-offset:-2px;border-radius:.5rem;background:#fb923c0d}.theme-harbor .panel-drop-target{outline:2px dashed #2dd4bf;outline-offset:-2px;border-radius:.5rem;background:#2dd4bf0d}.code-block{font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:.8rem;line-height:1.4}.drag-handle{cursor:grab}.drag-handle:active{cursor:grabbing}.light{--tw-bg-opacity: 1}.light .bg-gray-950{background-color:#fff!important}.light .bg-gray-900{background-color:#f9fafb!important}.light .bg-gray-900\/80{background-color:#f9fafbcc!important}.light .bg-gray-900\/50{background-color:#f9fafb80!important}.light .bg-gray-800{background-color:#f3f4f6!important}.light .bg-gray-800\/50{background-color:#f3f4f680!important}.light .bg-gray-700{background-color:#e5e7eb!important}.light .text-gray-100{color:#111827!important}.light .text-gray-200{color:#1f2937!important}.light .text-gray-300{color:#374151!important}.light .text-gray-400{color:#6b7280!important}.light .text-gray-500{color:#9ca3af!important}.light .text-gray-600{color:#d1d5db!important}.light .border-gray-700{border-color:#e5e7eb!important}.light .border-gray-800{border-color:#f3f4f6!important}.light .border-gray-800\/50{border-color:#f3f4f680!important}.light .text-cyan-400{color:#0891b2!important}.light .text-cyan-400\/80{color:#0891b2cc!important}.light .border-cyan-500{border-color:#06b6d4!important}.light .text-emerald-300,.light .text-emerald-400{color:#059669!important}.light .text-amber-400{color:#d97706!important}.light .text-amber-400\/80{color:#d97706cc!important}.light .text-amber-400\/70{color:#d97706b3!important}.light .text-violet-400{color:#7c3aed!important}.light .text-red-400{color:#dc2626!important}.light .text-yellow-400{color:#ca8a04!important}.light .text-green-400{color:#16a34a!important}.light .bg-emerald-950\/30{background-color:#05966914!important}.light .bg-emerald-900{background-color:#05966926!important}.light .bg-violet-950\/30{background-color:#7c3aed14!important}.light .bg-orange-900\/20{background-color:#ea580c14!important}.light .bg-red-900\/10{background-color:#dc26260d!important}.light .bg-cyan-600{background-color:#0891b2!important}.light .border-emerald-500,.light .border-emerald-700{border-color:#059669!important}.light .border-amber-500{border-color:#d97706!important}.light .border-violet-500{border-color:#7c3aed!important}.light .border-cyan-500{border-color:#0891b2!important}.light .border-orange-800\/50{border-color:#ea580c4d!important}.light .hover\:bg-gray-800:hover{background-color:#e5e7eb!important}.light .hover\:bg-gray-900\/50:hover{background-color:#f9fafb80!important}.light .hover\:text-gray-200:hover{color:#1f2937!important}.light .hover\:text-gray-300:hover{color:#374151!important}.light .hover\:border-gray-700:hover{border-color:#d1d5db!important}.light .hover\:border-gray-400:hover{border-color:#9ca3af!important}.light .hover\:text-cyan-300:hover{color:#0891b2!important}.light select{background-color:#f3f4f6!important;color:#374151!important;border-color:#d1d5db!important}.light input{background-color:#f9fafb!important;color:#374151!important;border-color:#d1d5db!important}.light .trace-scroll::-webkit-scrollbar-thumb{background:#d1d5db}.light .trace-scroll::-webkit-scrollbar-thumb:hover{background:#9ca3af}.light pre{background-color:#f3f4f6!important}.light code{background-color:#f3f4f6!important;color:#374151!important}.first\:mt-0:first-child{margin-top:0}.last\:border-0:last-child{border-width:0px}.hover\:border-cyan-600:hover{--tw-border-opacity: 1;border-color:rgb(8 145 178 / var(--tw-border-opacity, 1))}.hover\:border-gray-400:hover{--tw-border-opacity: 1;border-color:rgb(156 163 175 / var(--tw-border-opacity, 1))}.hover\:border-gray-500:hover{--tw-border-opacity: 1;border-color:rgb(107 114 128 / var(--tw-border-opacity, 1))}.hover\:border-gray-700:hover{--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1))}.hover\:bg-blue-500:hover{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.hover\:bg-cyan-500:hover{--tw-bg-opacity: 1;background-color:rgb(6 182 212 / var(--tw-bg-opacity, 1))}.hover\:bg-cyan-600\/50:hover{background-color:#0891b280}.hover\:bg-cyan-900\/70:hover{background-color:#164e63b3}.hover\:bg-gray-600:hover{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-700:hover{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-800:hover{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-800\/30:hover{background-color:#1f29374d}.hover\:bg-gray-800\/40:hover{background-color:#1f293766}.hover\:bg-gray-800\/50:hover{background-color:#1f293780}.hover\:bg-gray-900\/50:hover{background-color:#11182780}.hover\:bg-red-800:hover{--tw-bg-opacity: 1;background-color:rgb(153 27 27 / var(--tw-bg-opacity, 1))}.hover\:text-blue-300:hover{--tw-text-opacity: 1;color:rgb(147 197 253 / var(--tw-text-opacity, 1))}.hover\:text-blue-400:hover{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.hover\:text-cyan-300:hover{--tw-text-opacity: 1;color:rgb(103 232 249 / var(--tw-text-opacity, 1))}.hover\:text-cyan-400:hover{--tw-text-opacity: 1;color:rgb(34 211 238 / var(--tw-text-opacity, 1))}.hover\:text-gray-100:hover{--tw-text-opacity: 1;color:rgb(243 244 246 / var(--tw-text-opacity, 1))}.hover\:text-gray-200:hover{--tw-text-opacity: 1;color:rgb(229 231 235 / var(--tw-text-opacity, 1))}.hover\:text-gray-300:hover{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.hover\:text-gray-400:hover{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.hover\:text-gray-800:hover{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.hover\:text-red-300:hover{--tw-text-opacity: 1;color:rgb(252 165 165 / var(--tw-text-opacity, 1))}.hover\:text-red-400:hover{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.focus\:border-blue-500:focus{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.focus\:border-cyan-500:focus{--tw-border-opacity: 1;border-color:rgb(6 182 212 / var(--tw-border-opacity, 1))}.focus\:border-cyan-600:focus{--tw-border-opacity: 1;border-color:rgb(8 145 178 / var(--tw-border-opacity, 1))}.focus\:border-purple-500:focus{--tw-border-opacity: 1;border-color:rgb(168 85 247 / var(--tw-border-opacity, 1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-blue-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1))}.focus\:ring-offset-0:focus{--tw-ring-offset-width: 0px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-700:disabled{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.disabled\:text-gray-500:disabled{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.group:hover .group-hover\:flex{display:flex}.group:hover .group-hover\:text-gray-200{--tw-text-opacity: 1;color:rgb(229 231 235 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:opacity-90{opacity:.9}.dark\:border-gray-600:is(.dark *){--tw-border-opacity: 1;border-color:rgb(75 85 99 / var(--tw-border-opacity, 1))}.dark\:text-gray-400:is(.dark *){--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.dark\:hover\:text-gray-200:hover:is(.dark *){--tw-text-opacity: 1;color:rgb(229 231 235 / var(--tw-text-opacity, 1))}@media(min-width:640px){.sm\:block{display:block}.sm\:w-64{width:16rem}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1024px){.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1280px){.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
|
frontend/dist/index.html
CHANGED
|
@@ -4,8 +4,8 @@
|
|
| 4 |
<meta charset="UTF-8" />
|
| 5 |
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
| 6 |
<title>RACA Dashboard</title>
|
| 7 |
-
<script type="module" crossorigin src="/assets/index-
|
| 8 |
-
<link rel="stylesheet" crossorigin href="/assets/index-
|
| 9 |
</head>
|
| 10 |
<body class="bg-gray-950 text-gray-100">
|
| 11 |
<div id="root"></div>
|
|
|
|
| 4 |
<meta charset="UTF-8" />
|
| 5 |
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
| 6 |
<title>RACA Dashboard</title>
|
| 7 |
+
<script type="module" crossorigin src="/assets/index-BWw4o19g.js"></script>
|
| 8 |
+
<link rel="stylesheet" crossorigin href="/assets/index-bo0f-zdf.css">
|
| 9 |
</head>
|
| 10 |
<body class="bg-gray-950 text-gray-100">
|
| 11 |
<div id="root"></div>
|
frontend/src/browsecomp/BrowseCompApp.tsx
ADDED
|
@@ -0,0 +1,290 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import { useEffect, useState, useMemo } from "react";
|
| 2 |
+
|
| 3 |
+
interface Doc {
|
| 4 |
+
docid: string;
|
| 5 |
+
text: string;
|
| 6 |
+
url: string;
|
| 7 |
+
}
|
| 8 |
+
|
| 9 |
+
interface ListItem {
|
| 10 |
+
query_id: string;
|
| 11 |
+
query: string;
|
| 12 |
+
}
|
| 13 |
+
|
| 14 |
+
interface Example {
|
| 15 |
+
query_id: string;
|
| 16 |
+
query: string;
|
| 17 |
+
answer: string;
|
| 18 |
+
evidence_docs: Doc[];
|
| 19 |
+
gold_docs: Doc[];
|
| 20 |
+
}
|
| 21 |
+
|
| 22 |
+
export default function BrowseCompApp() {
|
| 23 |
+
const [items, setItems] = useState<ListItem[]>([]);
|
| 24 |
+
const [selected, setSelected] = useState<string>("");
|
| 25 |
+
const [example, setExample] = useState<Example | null>(null);
|
| 26 |
+
const [loadingList, setLoadingList] = useState(true);
|
| 27 |
+
const [loadingExample, setLoadingExample] = useState(false);
|
| 28 |
+
const [error, setError] = useState<string | null>(null);
|
| 29 |
+
const [search, setSearch] = useState("");
|
| 30 |
+
const [activeDocIdx, setActiveDocIdx] = useState(0);
|
| 31 |
+
const [showGold, setShowGold] = useState(false);
|
| 32 |
+
|
| 33 |
+
// Load list of all examples
|
| 34 |
+
useEffect(() => {
|
| 35 |
+
fetch("/api/browsecomp/")
|
| 36 |
+
.then((r) => { if (!r.ok) throw new Error(r.statusText); return r.json(); })
|
| 37 |
+
.then((d: { items: ListItem[]; total: number }) => {
|
| 38 |
+
setItems(d.items);
|
| 39 |
+
if (d.items.length > 0) setSelected(d.items[0].query_id);
|
| 40 |
+
setLoadingList(false);
|
| 41 |
+
})
|
| 42 |
+
.catch((e) => { setError(e.message); setLoadingList(false); });
|
| 43 |
+
}, []);
|
| 44 |
+
|
| 45 |
+
// Load full example when selection changes
|
| 46 |
+
useEffect(() => {
|
| 47 |
+
if (!selected) return;
|
| 48 |
+
setLoadingExample(true);
|
| 49 |
+
setActiveDocIdx(0);
|
| 50 |
+
setShowGold(false);
|
| 51 |
+
fetch(`/api/browsecomp/${encodeURIComponent(selected)}`)
|
| 52 |
+
.then((r) => { if (!r.ok) throw new Error(r.statusText); return r.json(); })
|
| 53 |
+
.then((d: Example) => { setExample(d); setLoadingExample(false); })
|
| 54 |
+
.catch((e) => { setError(e.message); setLoadingExample(false); });
|
| 55 |
+
}, [selected]);
|
| 56 |
+
|
| 57 |
+
const filteredItems = useMemo(() => {
|
| 58 |
+
if (!search.trim()) return items;
|
| 59 |
+
const q = search.toLowerCase();
|
| 60 |
+
return items.filter(
|
| 61 |
+
(it) => it.query_id.includes(q) || it.query.toLowerCase().includes(q)
|
| 62 |
+
);
|
| 63 |
+
}, [items, search]);
|
| 64 |
+
|
| 65 |
+
const selectedIndex = useMemo(
|
| 66 |
+
() => filteredItems.findIndex((it) => it.query_id === selected),
|
| 67 |
+
[filteredItems, selected]
|
| 68 |
+
);
|
| 69 |
+
|
| 70 |
+
const navigateTo = (delta: number) => {
|
| 71 |
+
const next = selectedIndex + delta;
|
| 72 |
+
if (next >= 0 && next < filteredItems.length) {
|
| 73 |
+
setSelected(filteredItems[next].query_id);
|
| 74 |
+
}
|
| 75 |
+
};
|
| 76 |
+
|
| 77 |
+
if (loadingList) {
|
| 78 |
+
return (
|
| 79 |
+
<div className="h-full flex items-center justify-center text-gray-400">
|
| 80 |
+
Loading BrowseComp-Plus examples…
|
| 81 |
+
</div>
|
| 82 |
+
);
|
| 83 |
+
}
|
| 84 |
+
|
| 85 |
+
if (error) {
|
| 86 |
+
return (
|
| 87 |
+
<div className="h-full flex items-center justify-center text-red-400">
|
| 88 |
+
Error: {error}
|
| 89 |
+
</div>
|
| 90 |
+
);
|
| 91 |
+
}
|
| 92 |
+
|
| 93 |
+
const docs = example?.evidence_docs ?? [];
|
| 94 |
+
const activeDoc = docs[activeDocIdx] ?? null;
|
| 95 |
+
|
| 96 |
+
return (
|
| 97 |
+
<div className="h-full flex bg-gray-950 text-gray-100">
|
| 98 |
+
{/* ── Left sidebar: example selector ── */}
|
| 99 |
+
<div className="w-64 shrink-0 flex flex-col border-r border-gray-800 bg-gray-900">
|
| 100 |
+
{/* Header */}
|
| 101 |
+
<div className="px-3 py-2 border-b border-gray-800 shrink-0">
|
| 102 |
+
<div className="text-[10px] text-gray-500 uppercase tracking-widest mb-1">
|
| 103 |
+
BrowseComp-Plus
|
| 104 |
+
</div>
|
| 105 |
+
<div className="text-xs text-gray-400">{items.length} examples</div>
|
| 106 |
+
</div>
|
| 107 |
+
|
| 108 |
+
{/* Search */}
|
| 109 |
+
<div className="px-2 py-2 border-b border-gray-800 shrink-0">
|
| 110 |
+
<input
|
| 111 |
+
type="text"
|
| 112 |
+
placeholder="Search…"
|
| 113 |
+
value={search}
|
| 114 |
+
onChange={(e) => setSearch(e.target.value)}
|
| 115 |
+
className="w-full bg-gray-800 border border-gray-700 text-gray-200 text-xs rounded px-2 py-1.5 placeholder-gray-500 focus:outline-none focus:border-purple-500"
|
| 116 |
+
/>
|
| 117 |
+
</div>
|
| 118 |
+
|
| 119 |
+
{/* Dropdown */}
|
| 120 |
+
<div className="px-2 py-2 border-b border-gray-800 shrink-0">
|
| 121 |
+
<div className="text-[10px] text-gray-500 uppercase tracking-widest mb-1">Example</div>
|
| 122 |
+
<select
|
| 123 |
+
value={selected}
|
| 124 |
+
onChange={(e) => setSelected(e.target.value)}
|
| 125 |
+
className="w-full bg-gray-800 border border-gray-700 text-gray-200 text-xs rounded px-2 py-1.5 focus:outline-none focus:border-purple-500"
|
| 126 |
+
>
|
| 127 |
+
{filteredItems.map((it) => (
|
| 128 |
+
<option key={it.query_id} value={it.query_id}>
|
| 129 |
+
#{it.query_id}
|
| 130 |
+
</option>
|
| 131 |
+
))}
|
| 132 |
+
</select>
|
| 133 |
+
</div>
|
| 134 |
+
|
| 135 |
+
{/* Prev / Next */}
|
| 136 |
+
<div className="px-2 py-1.5 border-b border-gray-800 flex gap-1 shrink-0">
|
| 137 |
+
<button
|
| 138 |
+
onClick={() => navigateTo(-1)}
|
| 139 |
+
disabled={selectedIndex <= 0}
|
| 140 |
+
className="flex-1 py-1 text-xs bg-gray-800 border border-gray-700 rounded disabled:opacity-30 hover:bg-gray-700 transition-colors"
|
| 141 |
+
>
|
| 142 |
+
← Prev
|
| 143 |
+
</button>
|
| 144 |
+
<button
|
| 145 |
+
onClick={() => navigateTo(1)}
|
| 146 |
+
disabled={selectedIndex >= filteredItems.length - 1}
|
| 147 |
+
className="flex-1 py-1 text-xs bg-gray-800 border border-gray-700 rounded disabled:opacity-30 hover:bg-gray-700 transition-colors"
|
| 148 |
+
>
|
| 149 |
+
Next →
|
| 150 |
+
</button>
|
| 151 |
+
</div>
|
| 152 |
+
|
| 153 |
+
{/* Example list */}
|
| 154 |
+
<div className="flex-1 overflow-y-auto">
|
| 155 |
+
{filteredItems.map((it) => (
|
| 156 |
+
<button
|
| 157 |
+
key={it.query_id}
|
| 158 |
+
onClick={() => setSelected(it.query_id)}
|
| 159 |
+
className={`w-full text-left px-3 py-2 border-b border-gray-800/50 text-xs transition-colors ${
|
| 160 |
+
selected === it.query_id
|
| 161 |
+
? "bg-purple-900/40 text-purple-200 border-l-2 border-l-purple-500"
|
| 162 |
+
: "text-gray-400 hover:bg-gray-800"
|
| 163 |
+
}`}
|
| 164 |
+
>
|
| 165 |
+
<span className="font-mono text-purple-400/70">#{it.query_id}</span>
|
| 166 |
+
<div className="mt-0.5 text-gray-500 line-clamp-2 leading-tight">
|
| 167 |
+
{it.query.slice(0, 80)}…
|
| 168 |
+
</div>
|
| 169 |
+
</button>
|
| 170 |
+
))}
|
| 171 |
+
</div>
|
| 172 |
+
</div>
|
| 173 |
+
|
| 174 |
+
{/* ── Main content ── */}
|
| 175 |
+
<div className="flex-1 flex flex-col min-w-0 overflow-hidden">
|
| 176 |
+
{loadingExample ? (
|
| 177 |
+
<div className="flex-1 flex items-center justify-center text-gray-500">
|
| 178 |
+
Loading example…
|
| 179 |
+
</div>
|
| 180 |
+
) : !example ? (
|
| 181 |
+
<div className="flex-1 flex items-center justify-center text-gray-500">
|
| 182 |
+
Select an example
|
| 183 |
+
</div>
|
| 184 |
+
) : (
|
| 185 |
+
<>
|
| 186 |
+
{/* ── Question panel ── */}
|
| 187 |
+
<div className="shrink-0 border-b border-gray-800 bg-gray-900/50">
|
| 188 |
+
<div className="px-4 py-2 flex items-center gap-3 border-b border-gray-800/50">
|
| 189 |
+
<span className="font-mono text-purple-400 text-sm font-medium">
|
| 190 |
+
#{example.query_id}
|
| 191 |
+
</span>
|
| 192 |
+
<span className="text-xs text-gray-500 uppercase tracking-wide">Question</span>
|
| 193 |
+
<span className="ml-auto text-xs text-gray-600">
|
| 194 |
+
{docs.length} evidence doc{docs.length !== 1 ? "s" : ""}
|
| 195 |
+
{example.gold_docs.length > 0 && ` · ${example.gold_docs.length} gold doc${example.gold_docs.length !== 1 ? "s" : ""}`}
|
| 196 |
+
</span>
|
| 197 |
+
</div>
|
| 198 |
+
<div className="px-4 py-3 max-h-40 overflow-y-auto">
|
| 199 |
+
<p className="text-sm text-gray-200 leading-relaxed whitespace-pre-wrap">
|
| 200 |
+
{example.query}
|
| 201 |
+
</p>
|
| 202 |
+
</div>
|
| 203 |
+
</div>
|
| 204 |
+
|
| 205 |
+
{/* ── Evidence documents ── */}
|
| 206 |
+
<div className="flex-1 flex flex-col min-h-0 overflow-hidden">
|
| 207 |
+
{/* Doc tabs */}
|
| 208 |
+
<div className="shrink-0 flex items-center gap-0.5 px-2 py-1.5 border-b border-gray-800 bg-gray-900/30 overflow-x-auto">
|
| 209 |
+
<span className="text-[10px] text-gray-500 uppercase tracking-widest mr-2 shrink-0">
|
| 210 |
+
Evidence
|
| 211 |
+
</span>
|
| 212 |
+
{docs.map((doc, i) => (
|
| 213 |
+
<button
|
| 214 |
+
key={doc.docid}
|
| 215 |
+
onClick={() => setActiveDocIdx(i)}
|
| 216 |
+
className={`px-2.5 py-1 text-xs rounded shrink-0 transition-colors border ${
|
| 217 |
+
activeDocIdx === i
|
| 218 |
+
? "bg-emerald-900/50 border-emerald-600 text-emerald-300"
|
| 219 |
+
: "bg-gray-800 border-gray-700 text-gray-400 hover:border-gray-500"
|
| 220 |
+
}`}
|
| 221 |
+
>
|
| 222 |
+
Doc {i + 1}
|
| 223 |
+
</button>
|
| 224 |
+
))}
|
| 225 |
+
{docs.length === 0 && (
|
| 226 |
+
<span className="text-xs text-gray-600 italic">No evidence documents</span>
|
| 227 |
+
)}
|
| 228 |
+
</div>
|
| 229 |
+
|
| 230 |
+
{/* Active doc content */}
|
| 231 |
+
{activeDoc && (
|
| 232 |
+
<div className="flex-1 overflow-y-auto">
|
| 233 |
+
{/* Doc header */}
|
| 234 |
+
<div className="sticky top-0 px-4 py-2 bg-gray-900/90 border-b border-gray-800 flex items-center gap-3 backdrop-blur-sm">
|
| 235 |
+
<span className="font-mono text-[10px] text-gray-500">
|
| 236 |
+
docid: {activeDoc.docid}
|
| 237 |
+
</span>
|
| 238 |
+
{activeDoc.url && (
|
| 239 |
+
<a
|
| 240 |
+
href={activeDoc.url}
|
| 241 |
+
target="_blank"
|
| 242 |
+
rel="noopener noreferrer"
|
| 243 |
+
className="text-xs text-blue-400 hover:text-blue-300 truncate max-w-xs"
|
| 244 |
+
>
|
| 245 |
+
{activeDoc.url}
|
| 246 |
+
</a>
|
| 247 |
+
)}
|
| 248 |
+
</div>
|
| 249 |
+
{/* Doc text */}
|
| 250 |
+
<div className="px-4 py-3">
|
| 251 |
+
<pre className="text-xs font-mono text-gray-300 whitespace-pre-wrap leading-relaxed">
|
| 252 |
+
{activeDoc.text}
|
| 253 |
+
</pre>
|
| 254 |
+
</div>
|
| 255 |
+
</div>
|
| 256 |
+
)}
|
| 257 |
+
</div>
|
| 258 |
+
|
| 259 |
+
{/* ── Gold answer banner ── */}
|
| 260 |
+
<div className="shrink-0 border-t border-gray-800 bg-gray-900/70 px-4 py-2 flex items-center gap-3">
|
| 261 |
+
<span className="text-[10px] text-gray-500 uppercase tracking-widest shrink-0">
|
| 262 |
+
Gold Answer
|
| 263 |
+
</span>
|
| 264 |
+
{showGold ? (
|
| 265 |
+
<span className="text-sm font-semibold text-amber-300 flex-1">
|
| 266 |
+
{example.answer}
|
| 267 |
+
</span>
|
| 268 |
+
) : (
|
| 269 |
+
<button
|
| 270 |
+
onClick={() => setShowGold(true)}
|
| 271 |
+
className="text-xs bg-gray-800 border border-gray-700 text-gray-400 hover:text-gray-200 rounded px-2 py-0.5 transition-colors"
|
| 272 |
+
>
|
| 273 |
+
Reveal answer
|
| 274 |
+
</button>
|
| 275 |
+
)}
|
| 276 |
+
{showGold && (
|
| 277 |
+
<button
|
| 278 |
+
onClick={() => setShowGold(false)}
|
| 279 |
+
className="text-xs text-gray-600 hover:text-gray-400 ml-auto"
|
| 280 |
+
>
|
| 281 |
+
Hide
|
| 282 |
+
</button>
|
| 283 |
+
)}
|
| 284 |
+
</div>
|
| 285 |
+
</>
|
| 286 |
+
)}
|
| 287 |
+
</div>
|
| 288 |
+
</div>
|
| 289 |
+
);
|
| 290 |
+
}
|
frontend/src/visualizer/VisualizerApp.tsx
CHANGED
|
@@ -6,8 +6,9 @@ const PlanRevisionsApp = lazy(() => import("../plan_revisions/PlanRevisionsApp")
|
|
| 6 |
const TrajExtApp = lazy(() => import("../traj_ext/TrajExtApp"));
|
| 7 |
const SelectedToolsApp = lazy(() => import("../selected_tools/SelectedToolsApp"));
|
| 8 |
const ScoutRunsApp = lazy(() => import("../scout_runs/ScoutRunsApp"));
|
|
|
|
| 9 |
|
| 10 |
-
type TabId = "model" | "plan-revisions" | "traj-ext" | "selected-tools" | "scout-runs";
|
| 11 |
|
| 12 |
const TABS: { id: TabId; label: string; activeClass: string }[] = [
|
| 13 |
{ id: "model", label: "Model Trace", activeClass: "border-blue-500 text-blue-400" },
|
|
@@ -15,6 +16,7 @@ const TABS: { id: TabId; label: string; activeClass: string }[] = [
|
|
| 15 |
{ id: "traj-ext", label: "Traj Ext", activeClass: "border-emerald-500 text-emerald-400" },
|
| 16 |
{ id: "selected-tools", label: "Selected Tools", activeClass: "border-amber-400 text-amber-300" },
|
| 17 |
{ id: "scout-runs", label: "Scout Runs", activeClass: "border-cyan-500 text-cyan-400" },
|
|
|
|
| 18 |
];
|
| 19 |
|
| 20 |
const VALID_TABS = new Set<string>(TABS.map(t => t.id));
|
|
@@ -76,6 +78,11 @@ export default function VisualizerApp() {
|
|
| 76 |
<ScoutRunsApp />
|
| 77 |
</div>
|
| 78 |
)}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 79 |
</Suspense>
|
| 80 |
</div>
|
| 81 |
</div>
|
|
|
|
| 6 |
const TrajExtApp = lazy(() => import("../traj_ext/TrajExtApp"));
|
| 7 |
const SelectedToolsApp = lazy(() => import("../selected_tools/SelectedToolsApp"));
|
| 8 |
const ScoutRunsApp = lazy(() => import("../scout_runs/ScoutRunsApp"));
|
| 9 |
+
const BrowseCompApp = lazy(() => import("../browsecomp/BrowseCompApp"));
|
| 10 |
|
| 11 |
+
type TabId = "model" | "plan-revisions" | "traj-ext" | "selected-tools" | "scout-runs" | "browsecomp";
|
| 12 |
|
| 13 |
const TABS: { id: TabId; label: string; activeClass: string }[] = [
|
| 14 |
{ id: "model", label: "Model Trace", activeClass: "border-blue-500 text-blue-400" },
|
|
|
|
| 16 |
{ id: "traj-ext", label: "Traj Ext", activeClass: "border-emerald-500 text-emerald-400" },
|
| 17 |
{ id: "selected-tools", label: "Selected Tools", activeClass: "border-amber-400 text-amber-300" },
|
| 18 |
{ id: "scout-runs", label: "Scout Runs", activeClass: "border-cyan-500 text-cyan-400" },
|
| 19 |
+
{ id: "browsecomp", label: "BrowseComp+", activeClass: "border-purple-500 text-purple-400" },
|
| 20 |
];
|
| 21 |
|
| 22 |
const VALID_TABS = new Set<string>(TABS.map(t => t.id));
|
|
|
|
| 78 |
<ScoutRunsApp />
|
| 79 |
</div>
|
| 80 |
)}
|
| 81 |
+
{activeTab === "browsecomp" && (
|
| 82 |
+
<div className="h-full">
|
| 83 |
+
<BrowseCompApp />
|
| 84 |
+
</div>
|
| 85 |
+
)}
|
| 86 |
</Suspense>
|
| 87 |
</div>
|
| 88 |
</div>
|
frontend/tsconfig.app.tsbuildinfo
CHANGED
|
@@ -1 +1 @@
|
|
| 1 |
-
{"root":["./src/app.tsx","./src/themetoggle.tsx","./src/config.ts","./src/hashrouter.ts","./src/main.tsx","./src/vite-env.d.ts","./src/experiments/experimentsapp.tsx","./src/experiments/api.ts","./src/experiments/store.ts","./src/experiments/types.ts","./src/experiments/components/artifactstab.tsx","./src/experiments/components/experimentdetail.tsx","./src/experiments/components/experimentlist.tsx","./src/experiments/components/markdown.tsx","./src/experiments/components/noteview.tsx","./src/experiments/components/subexperimentview.tsx","./src/experiments/components/summaryfindingsview.tsx","./src/experiments/components/timelinetab.tsx","./src/experiments/components/viewers/imageviewer.tsx","./src/experiments/components/viewers/plotlyviewer.tsx","./src/experiments/components/viewers/tableviewer.tsx","./src/experiments/components/viewers/yamlviewer.tsx","./src/model/modelapp.tsx","./src/model/api.ts","./src/model/store.ts","./src/model/types.ts","./src/model/components/infobar.tsx","./src/model/components/questionnav.tsx","./src/model/components/sidebar.tsx","./src/model/components/tracepanel.tsx","./src/model/utils/promptparser.ts","./src/model/utils/tracehighlight.ts","./src/plan_revisions/planrevisionsapp.tsx","./src/scout_runs/scoutrunsapp.tsx","./src/selected_tools/selectedtoolsapp.tsx","./src/sft_diff/sftdiffapp.tsx","./src/traj_ext/trajextapp.tsx","./src/visualizer/visualizerapp.tsx"],"version":"5.9.3"}
|
|
|
|
| 1 |
+
{"root":["./src/app.tsx","./src/themetoggle.tsx","./src/config.ts","./src/hashrouter.ts","./src/main.tsx","./src/vite-env.d.ts","./src/browsecomp/browsecompapp.tsx","./src/experiments/experimentsapp.tsx","./src/experiments/api.ts","./src/experiments/store.ts","./src/experiments/types.ts","./src/experiments/components/artifactstab.tsx","./src/experiments/components/experimentdetail.tsx","./src/experiments/components/experimentlist.tsx","./src/experiments/components/markdown.tsx","./src/experiments/components/noteview.tsx","./src/experiments/components/subexperimentview.tsx","./src/experiments/components/summaryfindingsview.tsx","./src/experiments/components/timelinetab.tsx","./src/experiments/components/viewers/imageviewer.tsx","./src/experiments/components/viewers/plotlyviewer.tsx","./src/experiments/components/viewers/tableviewer.tsx","./src/experiments/components/viewers/yamlviewer.tsx","./src/model/modelapp.tsx","./src/model/api.ts","./src/model/store.ts","./src/model/types.ts","./src/model/components/infobar.tsx","./src/model/components/questionnav.tsx","./src/model/components/sidebar.tsx","./src/model/components/tracepanel.tsx","./src/model/utils/promptparser.ts","./src/model/utils/tracehighlight.ts","./src/plan_revisions/planrevisionsapp.tsx","./src/scout_runs/scoutrunsapp.tsx","./src/selected_tools/selectedtoolsapp.tsx","./src/sft_diff/sftdiffapp.tsx","./src/traj_ext/trajextapp.tsx","./src/visualizer/visualizerapp.tsx"],"version":"5.9.3"}
|
scripts/upload_browsecomp_plus.py
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"""Upload browsecomp-plus benchmark to HuggingFace for the dashboard visualizer."""
|
| 2 |
+
import json
|
| 3 |
+
import sys
|
| 4 |
+
import os
|
| 5 |
+
|
| 6 |
+
sys.path.insert(0, os.path.join(os.path.dirname(__file__), "../../../packages/key_handler"))
|
| 7 |
+
from key_handler import KeyHandler
|
| 8 |
+
KeyHandler.set_env_key()
|
| 9 |
+
|
| 10 |
+
from datasets import Dataset
|
| 11 |
+
|
| 12 |
+
DATA_PATH = os.path.join(
|
| 13 |
+
os.path.dirname(__file__),
|
| 14 |
+
"../../../BrowseComp-Plus/data/browsecomp_plus_decrypted.jsonl",
|
| 15 |
+
)
|
| 16 |
+
HF_REPO = "timchen0618/browsecomp-plus-benchmark"
|
| 17 |
+
|
| 18 |
+
rows = []
|
| 19 |
+
with open(DATA_PATH) as f:
|
| 20 |
+
for line in f:
|
| 21 |
+
row = json.loads(line)
|
| 22 |
+
rows.append({
|
| 23 |
+
"query_id": str(row["query_id"]),
|
| 24 |
+
"query": row["query"],
|
| 25 |
+
"answer": row["answer"],
|
| 26 |
+
"evidence_docs": json.dumps(row.get("evidence_docs", [])),
|
| 27 |
+
"gold_docs": json.dumps(row.get("gold_docs", [])),
|
| 28 |
+
})
|
| 29 |
+
|
| 30 |
+
print(f"Loaded {len(rows)} examples")
|
| 31 |
+
|
| 32 |
+
ds = Dataset.from_list(rows)
|
| 33 |
+
print("Dataset:", ds)
|
| 34 |
+
|
| 35 |
+
token = os.environ.get("HF_TOKEN", "")
|
| 36 |
+
ds.push_to_hub(HF_REPO, token=token)
|
| 37 |
+
print(f"Uploaded to {HF_REPO}")
|