From 6be438519c054be7b8fa6fd6a77487bed3a4ea8b Mon Sep 17 00:00:00 2001 From: Victor Giers Date: Fri, 20 Mar 2026 12:00:44 +0100 Subject: [PATCH] added embedding model selection --- README.md | 2 +- backend/app_settings.py | 19 +++++ backend/local_rag.py | 41 ++++++--- backend/main.py | 26 ++++++ backend/ollama_admin.py | 140 +++++++++++++++++++++++++++++++ backend/rag/ollama_embeddings.py | 14 +++- backend/schemas.py | 4 + backend/websearch.py | 15 ++-- dist/assets/index-BIbxZDtU.css | 1 - dist/assets/index-CEHqzDAN.js | 73 ---------------- dist/assets/index-Cl_WYrJF.css | 1 + dist/assets/index-u1-aH6b-.js | 73 ++++++++++++++++ dist/index.html | 4 +- electron/main.cjs | 21 ++++- src/App.jsx | 96 ++++++++++++++++++++- src/GeneralSettings.jsx | 33 ++++++++ src/WebsearchSettings.jsx | 4 +- src/styles.css | 46 ++++++++++ 18 files changed, 513 insertions(+), 100 deletions(-) create mode 100644 backend/ollama_admin.py delete mode 100644 dist/assets/index-BIbxZDtU.css delete mode 100644 dist/assets/index-CEHqzDAN.js create mode 100644 dist/assets/index-Cl_WYrJF.css create mode 100644 dist/assets/index-u1-aH6b-.js diff --git a/README.md b/README.md index 1edad47..364fbfb 100644 --- a/README.md +++ b/README.md @@ -37,7 +37,7 @@ Requirements: - Node.js 18+ - Python 3.13 - Ollama running locally -- Optional: SearXNG on `http://localhost:8888` +- Optional: SearXNG on `http://127.0.0.1:8888` Quick start: diff --git a/backend/app_settings.py b/backend/app_settings.py index ff0940a..0a3ab8c 100644 --- a/backend/app_settings.py +++ b/backend/app_settings.py @@ -10,9 +10,12 @@ from typing import Any, Dict APP_NAME = "Heimgeist" DEFAULT_BACKEND_API_URL = "http://127.0.0.1:8000" DEFAULT_OLLAMA_API_URL = "http://127.0.0.1:11434" +DEFAULT_EMBED_MODEL = "nomic-embed-text:latest" +BGE_EMBED_MODEL = "bge-m3:latest" DEFAULT_SETTINGS: Dict[str, Any] = { "backendApiUrl": DEFAULT_BACKEND_API_URL, "ollamaApiUrl": DEFAULT_OLLAMA_API_URL, + "embedModel": DEFAULT_EMBED_MODEL, } @@ -56,6 +59,16 @@ def _normalize_url(value: Any, fallback: str) -> str: return trimmed or fallback +def normalize_embed_model(value: Any) -> str: + if not isinstance(value, str): + return DEFAULT_EMBED_MODEL + + trimmed = value.strip().lower() + if trimmed in {"bge", "bge-m3", BGE_EMBED_MODEL}: + return BGE_EMBED_MODEL + return DEFAULT_EMBED_MODEL + + def load_app_settings() -> Dict[str, Any]: path = settings_path() try: @@ -79,6 +92,7 @@ def load_app_settings() -> Dict[str, Any]: else: settings["backendApiUrl"] = _normalize_url(settings.get("backendApiUrl"), DEFAULT_BACKEND_API_URL) settings["ollamaApiUrl"] = _normalize_url(settings.get("ollamaApiUrl"), DEFAULT_OLLAMA_API_URL) + settings["embedModel"] = normalize_embed_model(settings.get("embedModel")) return settings @@ -86,3 +100,8 @@ def load_app_settings() -> Dict[str, Any]: def get_ollama_api_url() -> str: settings = load_app_settings() return _normalize_url(settings.get("ollamaApiUrl"), DEFAULT_OLLAMA_API_URL) + + +def get_embed_model_preference() -> str: + settings = load_app_settings() + return normalize_embed_model(settings.get("embedModel")) diff --git a/backend/local_rag.py b/backend/local_rag.py index 2392b89..362d6a2 100644 --- a/backend/local_rag.py +++ b/backend/local_rag.py @@ -19,6 +19,11 @@ from urllib.parse import quote from fastapi import APIRouter, HTTPException from pydantic import BaseModel +from .app_settings import ( + DEFAULT_EMBED_MODEL as DEFAULT_EMBED_MODEL_SETTING, + get_embed_model_preference, + get_ollama_api_url, +) router = APIRouter(tags=["local-rag"]) @@ -27,7 +32,7 @@ LIB_ROOT.mkdir(parents=True, exist_ok=True) RAW_CORPUS_PROFILE = "per-file-default-v1" PREPARE_PROFILE = "selective-enrich-v2" -DEFAULT_EMBED_MODEL = "bge-m3:latest" +DEFAULT_EMBED_MODEL = DEFAULT_EMBED_MODEL_SETTING DEFAULT_ENRICH_MODEL = "qwen3:4b" DEFAULT_ENRICH_MIN_CHARS = 240 DEFAULT_ENRICH_MAX_TEXT = 6000 @@ -61,7 +66,7 @@ class UpdateFileEnrichmentRequest(BaseModel): class EmbedLibraryRequest(BaseModel): embed_model: Optional[str] = None - ollama: str = "http://localhost:11434" + ollama: Optional[str] = None target_chars: int = 2000 overlap_chars: int = 200 concurrency: int = 6 @@ -70,11 +75,25 @@ class EmbedLibraryRequest(BaseModel): class LibraryContextRequest(BaseModel): prompt: str top_k: int = 5 - ollama: str = "http://localhost:11434" + ollama: Optional[str] = None embed_model: Optional[str] = None gen_model: str = "qwen3:4b" +def _default_ollama_url() -> str: + return get_ollama_api_url() + + +def _default_embed_model() -> str: + return get_embed_model_preference() + + +def _resolve_ollama_url(value: Optional[str] = None) -> str: + if isinstance(value, str) and value.strip(): + return value.strip().rstrip("/") + return _default_ollama_url() + + def now_iso() -> str: return datetime.utcnow().isoformat(timespec="seconds") + "Z" @@ -745,7 +764,7 @@ def _run_selected_enrichment(slug: str, on_progress=None, **opts) -> Dict[str, A out=paths["enhanced"], shadow_out=paths["shadow_partial"], on_progress=on_progress, - ollama=opts.get("ollama", "http://localhost:11434"), + ollama=_resolve_ollama_url(opts.get("ollama")), model=opts.get("enrich_model", DEFAULT_ENRICH_MODEL), summary_lang=opts.get("summary_lang", "auto"), concurrency=opts.get("enrich_concurrency", DEFAULT_ENRICH_CONCURRENCY), @@ -777,7 +796,7 @@ def _run_prepare_pipeline(slug: str, on_progress=None, **opts): build_runner = _load_pipeline_fn("corpus_builder", "run_build") index_runner = _load_pipeline_fn("index_builder", "run_index") - embed_model = opts.get("embed_model") or pipeline.get("embed_model") or DEFAULT_EMBED_MODEL + embed_model = opts.get("embed_model") or _default_embed_model() or pipeline.get("embed_model") or DEFAULT_EMBED_MODEL if on_progress: on_progress("prepare", 0.01, "Preparing database for chat...") @@ -807,7 +826,7 @@ def _run_prepare_pipeline(slug: str, on_progress=None, **opts): results["enrich"] = _run_selected_enrichment( slug, on_progress=enrich_progress, - ollama=opts.get("ollama", "http://localhost:11434"), + ollama=_resolve_ollama_url(opts.get("ollama")), enrich_model=opts.get("enrich_model", DEFAULT_ENRICH_MODEL), summary_lang=opts.get("summary_lang", "auto"), enrich_concurrency=opts.get("enrich_concurrency", DEFAULT_ENRICH_CONCURRENCY), @@ -837,7 +856,7 @@ def _run_prepare_pipeline(slug: str, on_progress=None, **opts): out_dir=paths["indexes"], on_progress=index_progress, embed_model=embed_model, - ollama=opts.get("ollama", "http://localhost:11434"), + ollama=_resolve_ollama_url(opts.get("ollama")), target_chars=opts.get("target_chars", 2000), overlap_chars=opts.get("overlap_chars", 200), concurrency=opts.get("concurrency", 6), @@ -1189,7 +1208,7 @@ async def embed_library(slug: str, req: EmbedLibraryRequest): paths = _collect_library_paths(slug) if not payload["states"].get("has_corpus"): raise HTTPException(status_code=400, detail="Build the corpus before indexing.") - embed_model = req.embed_model or pipeline.get("embed_model") or DEFAULT_EMBED_MODEL + embed_model = req.embed_model or _default_embed_model() or pipeline.get("embed_model") or DEFAULT_EMBED_MODEL lock = LIB_LOCKS.setdefault(slug, asyncio.Lock()) async with lock: if _has_active_job(slug): @@ -1202,7 +1221,7 @@ async def embed_library(slug: str, req: EmbedLibraryRequest): shadow=paths["shadow"] if paths["shadow"].exists() else None, out_dir=paths["indexes"], embed_model=embed_model, - ollama=req.ollama, + ollama=_resolve_ollama_url(req.ollama), target_chars=req.target_chars, overlap_chars=req.overlap_chars, concurrency=req.concurrency, @@ -1247,7 +1266,7 @@ def library_context(slug: str, req: LibraryContextRequest): paths = _collect_library_paths(slug) if not payload["states"].get("is_indexed"): raise HTTPException(status_code=400, detail="Prepare the library before using it in chat.") - embed_model = req.embed_model or pipeline.get("embed_model") or DEFAULT_EMBED_MODEL + embed_model = req.embed_model or pipeline.get("embed_model") or _default_embed_model() or DEFAULT_EMBED_MODEL try: run_query = _load_pipeline_fn("unified_rag", "run_query") result = run_query( @@ -1257,7 +1276,7 @@ def library_context(slug: str, req: LibraryContextRequest): content_store=paths["content_store"], query=req.prompt, answer=False, - ollama=req.ollama, + ollama=_resolve_ollama_url(req.ollama), embed_model=embed_model, gen_model=req.gen_model, no_rerank=True, diff --git a/backend/main.py b/backend/main.py index 33e6c25..35e4e98 100644 --- a/backend/main.py +++ b/backend/main.py @@ -9,6 +9,7 @@ import json from . import models, schemas from .database import Base, engine, SessionLocal, ensure_sources_column from .local_rag import router as local_rag_router +from .ollama_admin import inspect_ollama_startup, pull_local_model, start_local_ollama from .ollama_client import list_models as ollama_list, chat as ollama_chat, chat_stream as ollama_chat_stream from .websearch import enrich_prompt @@ -47,6 +48,31 @@ async def get_models(): except Exception as e: raise HTTPException(status_code=502, detail=f"Ollama not available: {e}") + +@app.get("/ollama/startup-status") +async def ollama_startup_status(): + return await inspect_ollama_startup() + + +@app.post("/ollama/start") +async def ollama_start_route(): + try: + return await start_local_ollama() + except FileNotFoundError as exc: + raise HTTPException(status_code=404, detail=str(exc)) from exc + except RuntimeError as exc: + raise HTTPException(status_code=400, detail=str(exc)) from exc + + +@app.post("/ollama/pull") +async def ollama_pull_route(req: schemas.OllamaPullRequest): + try: + return await pull_local_model(req.model) + except FileNotFoundError as exc: + raise HTTPException(status_code=404, detail=str(exc)) from exc + except RuntimeError as exc: + raise HTTPException(status_code=400, detail=str(exc)) from exc + @app.get("/sessions", response_model=schemas.SessionsResponse) def get_sessions(db: Session = Depends(get_db)): sessions = db.query(models.ChatSession).order_by(models.ChatSession.created_at.desc()).all() diff --git a/backend/ollama_admin.py b/backend/ollama_admin.py new file mode 100644 index 0000000..02a0fbd --- /dev/null +++ b/backend/ollama_admin.py @@ -0,0 +1,140 @@ +from __future__ import annotations + +import asyncio +import os +import shutil +import subprocess +from typing import Any, Dict, List, Optional +from urllib.parse import urlparse + +import httpx + +from .app_settings import get_embed_model_preference, get_ollama_api_url, normalize_embed_model + + +LOCAL_OLLAMA_HOSTS = {"127.0.0.1", "localhost", "::1"} + + +def _ollama_binary() -> Optional[str]: + return shutil.which("ollama") + + +def _is_local_ollama_url(url: str) -> bool: + try: + parsed = urlparse(url) + except Exception: + return False + return (parsed.hostname or "").strip().lower() in LOCAL_OLLAMA_HOSTS + + +def _model_aliases(model: str) -> set[str]: + normalized = normalize_embed_model(model) + aliases = {normalized} + if normalized.endswith(":latest"): + aliases.add(normalized[:-7]) + else: + aliases.add(f"{normalized}:latest") + return aliases + + +async def _list_model_names(ollama_url: str, *, timeout: float = 5.0) -> List[str]: + async with httpx.AsyncClient(timeout=timeout) as client: + response = await client.get(f"{ollama_url.rstrip('/')}/api/tags") + response.raise_for_status() + payload = response.json() + + out: List[str] = [] + for item in payload.get("models", []) or []: + name = str((item or {}).get("name") or "").strip() + if name: + out.append(name) + return out + + +async def inspect_ollama_startup() -> Dict[str, Any]: + ollama_url = get_ollama_api_url() + embed_model = get_embed_model_preference() + ollama_bin = _ollama_binary() + is_local = _is_local_ollama_url(ollama_url) + available_models: List[str] = [] + error = "" + running = False + + try: + available_models = await _list_model_names(ollama_url) + running = True + except Exception as exc: + error = str(exc) + + available = bool(set(available_models) & _model_aliases(embed_model)) + return { + "ollama_url": ollama_url, + "ollama_running": running, + "ollama_binary_found": bool(ollama_bin), + "can_manage_locally": bool(ollama_bin) and is_local, + "selected_embed_model": embed_model, + "embedding_model_available": available, + "available_models": available_models, + "error": error, + } + + +async def start_local_ollama() -> Dict[str, Any]: + status = await inspect_ollama_startup() + if status["ollama_running"]: + return status + if not status["can_manage_locally"]: + raise RuntimeError("Ollama can only be started automatically when the configured Ollama URL points to this machine.") + + ollama_bin = _ollama_binary() + if not ollama_bin: + raise FileNotFoundError("Could not find the 'ollama' executable in PATH.") + + subprocess.Popen( + [ollama_bin, "serve"], + stdin=subprocess.DEVNULL, + stdout=subprocess.DEVNULL, + stderr=subprocess.DEVNULL, + start_new_session=True, + env=os.environ.copy(), + ) + + for _ in range(20): + await asyncio.sleep(0.5) + status = await inspect_ollama_startup() + if status["ollama_running"]: + return status + + raise RuntimeError("Started 'ollama serve', but Ollama did not become reachable in time.") + + +async def pull_local_model(model: Optional[str] = None) -> Dict[str, Any]: + status = await inspect_ollama_startup() + if not status["can_manage_locally"]: + raise RuntimeError("Heimgeist can only pull models automatically when the configured Ollama URL points to this machine.") + if not status["ollama_running"]: + raise RuntimeError("Ollama must be running before Heimgeist can pull a model.") + + ollama_bin = _ollama_binary() + if not ollama_bin: + raise FileNotFoundError("Could not find the 'ollama' executable in PATH.") + + model_name = normalize_embed_model(model or status["selected_embed_model"]) + process = await asyncio.create_subprocess_exec( + ollama_bin, + "pull", + model_name, + stdin=asyncio.subprocess.DEVNULL, + stdout=asyncio.subprocess.DEVNULL, + stderr=asyncio.subprocess.PIPE, + ) + _stdout, stderr = await process.communicate() + if process.returncode != 0: + detail = (stderr or b"").decode("utf-8", errors="ignore").strip() + raise RuntimeError(detail or f"'ollama pull {model_name}' failed with exit code {process.returncode}.") + + status = await inspect_ollama_startup() + return { + "model": model_name, + "status": status, + } diff --git a/backend/rag/ollama_embeddings.py b/backend/rag/ollama_embeddings.py index fae9da5..e8dda60 100644 --- a/backend/rag/ollama_embeddings.py +++ b/backend/rag/ollama_embeddings.py @@ -6,8 +6,8 @@ import requests DEFAULT_EMBED_CANDIDATES = ( - "bge-m3:latest", "nomic-embed-text:latest", + "bge-m3:latest", "dengcao/Qwen3-Embedding-0.6B:F16", ) @@ -21,7 +21,17 @@ def _cache_key(ollama_url: str, preferred_model: Optional[str]) -> Tuple[str, st def _candidate_models(preferred_model: Optional[str]) -> List[str]: out: List[str] = [] seen = set() - for model in [preferred_model, *DEFAULT_EMBED_CANDIDATES]: + if preferred_model: + primary = str(preferred_model).strip() + candidates = [primary] + if primary.endswith(":latest"): + candidates.append(primary[:-7]) + else: + candidates.append(f"{primary}:latest") + else: + candidates = list(DEFAULT_EMBED_CANDIDATES) + + for model in candidates: name = str(model or "").strip() if not name or name in seen: continue diff --git a/backend/schemas.py b/backend/schemas.py index b8c81ff..e5037b3 100644 --- a/backend/schemas.py +++ b/backend/schemas.py @@ -67,3 +67,7 @@ class WebSearchResponse(BaseModel): enriched_prompt: str sources: List[str] = [] context_block: str = "" + + +class OllamaPullRequest(BaseModel): + model: Optional[str] = None diff --git a/backend/websearch.py b/backend/websearch.py index 09238a3..194e023 100644 --- a/backend/websearch.py +++ b/backend/websearch.py @@ -7,10 +7,11 @@ import json import traceback import hashlib +from .app_settings import get_embed_model_preference, get_ollama_api_url from .ollama_client import chat as ollama_chat # Configure your local SearXNG instance URL (no trailing slash) -SEARX_URL = "http://localhost:8888" +SEARX_URL = "http://127.0.0.1:8888" # ----- Utilities ---------------------------------------------------------------- @@ -263,7 +264,7 @@ async def rerank( docs: List[Tuple[str, str]], model: str, # kept for signature compatibility (unused here) context_excerpt: str, - embed_model: str = "bge-m3:latest" # prefer explicit tag; we will auto-fallback + embed_model: Optional[str] = None, ) -> List[Tuple[str, str, float]]: """ Embedding-based reranker (bge-m3 via Ollama) using cosine similarity. @@ -277,6 +278,8 @@ async def rerank( """ import time t0 = time.perf_counter() + embed_model = (embed_model or get_embed_model_preference()).strip() + ollama_url = get_ollama_api_url().rstrip("/") # --- optional fast cosine via NumPy --------------------------------------- try: @@ -357,9 +360,9 @@ async def rerank( async def _one(text: str) -> Tuple[List[float], Optional[str]]: payload = {"model": model_name, "prompt": text} try: - async with sem: - async with httpx.AsyncClient(timeout=timeout) as client: - r = await client.post("http://localhost:11434/api/embeddings", json=payload) + async with sem: + async with httpx.AsyncClient(timeout=timeout) as client: + r = await client.post(f"{ollama_url}/api/embeddings", json=payload) r.raise_for_status() data = r.json() except httpx.HTTPStatusError as e: @@ -639,4 +642,4 @@ async def enrich_prompt( except Exception: print("[web] ERROR in build_enriched_prompt:\n" + traceback.format_exc()) print(f"[web] enrich_prompt total: {time.perf_counter() - start_all:.3f}s") - return _no_results_enriched("build_enriched_failed", queries) \ No newline at end of file + return _no_results_enriched("build_enriched_failed", queries) diff --git a/dist/assets/index-BIbxZDtU.css b/dist/assets/index-BIbxZDtU.css deleted file mode 100644 index 8978f66..0000000 --- a/dist/assets/index-BIbxZDtU.css +++ /dev/null @@ -1 +0,0 @@ -:root{--bg: #0b1020;--panel: #141b34;--text: #e6e8ef;--muted: #9aa3b2;--accent: #6ea8fe;--border: #24304f}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica,Arial}.no-select{-webkit-user-select:none;user-select:none;cursor:ew-resize!important}.app{display:grid;grid-template-columns:var(--sidebar-width, 230px) 1fr;grid-template-rows:1fr;height:100%}.sidebar{display:grid;grid-template-rows:auto 1fr auto;background:var(--panel);border-right:1px solid var(--border);height:100vh;overflow:hidden;position:relative}.sidebar span{font-size:14px}.resizer{width:13px;cursor:ew-resize;background:transparent;position:absolute;top:0;right:-5px;bottom:0;z-index:1}.sidebar-header{display:flex;justify-content:space-around;padding:0;background:var(--panel)}.sidebar-tab{flex-grow:1;text-align:center;padding:11px 16px;cursor:pointer;border-bottom:3px solid transparent;transition:background-color .2s ease}.sidebar-tab:hover{background-color:var(--hover-bg)}.sidebar-tab.active{background-color:var(--active-bg);border-bottom-color:var(--accent)}.sidebar-tab.active:hover{background-color:var(--active-bg)}.sidebar-content{flex-grow:1;overflow-y:auto}.db-list,.settings-list{padding:8px 0}.empty-list-message{padding:10px 16px;color:var(--muted);text-align:center}.settings-item{padding:10px 16px;cursor:pointer;border-left:3px solid transparent}.settings-item.active{background:var(--active-bg);border-left-color:var(--accent)}.settings-item.active:hover{background:var(--active-bg)}.settings-item:hover{background:var(--hover-bg)}.settings-footer-placeholder{height:40px;padding:12px 16px;border-top:1px solid var(--border);background:var(--panel)}.new-db-button{width:100%;padding:10px;background:var(--accent);border-color:var(--accent);color:var(--bg);font-weight:700}.new-db-button:hover{opacity:.9}.chat-list{overflow-y:auto;padding:8px 0}.chat-item{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;cursor:pointer;border-left:3px solid transparent;overflow:hidden;white-space:nowrap}.chat-item span{flex-grow:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-item-buttons{display:flex;gap:8px;align-items:center}.unread-dot{width:8px;height:8px;background-color:red;border-radius:50%;margin-right:4px}.icon-button{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;padding:0;display:flex;align-items:center;justify-content:center}.icon-button svg{width:16px;height:16px;stroke:var(--muted);transition:stroke .2s ease}.icon-button:hover svg{stroke:var(--accent)}.icon-button:hover{color:var(--accent)}.chat-item.active{background:var(--active-bg);border-left-color:var(--accent)}.chat-item:hover{background:var(--hover-bg)}.chat-item.active:hover{background:var(--active-bg)}.rename-input{background:var(--input-bg);border:1px solid var(--accent);color:var(--text);border-radius:10px;padding:8px 12px;outline:none;width:100%}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--muted);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}.sidebar-footer{padding:12px 16px;background:var(--panel)}.new-db-form,.library-inline-form{display:grid;gap:8px}.new-db-actions{display:flex;gap:8px}.form-error{color:#ff9aa8;font-size:12px}.new-chat-button{width:100%;padding:10px;background:var(--accent);border-color:var(--accent);color:var(--bg);font-weight:700}.new-chat-button:hover{opacity:.9}.main-content{position:relative;display:grid;grid-template-rows:auto 1fr auto;height:100vh;overflow:hidden}.header{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--panel)}.select,.input,.button{background:var(--input-bg);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:8px 12px;outline:none}.footer-content-wrapper .button{flex-shrink:0}.select{min-width:220px}.button{cursor:pointer}.button:hover{border-color:var(--accent)}.button.ghost{background:transparent}.button.danger{border-color:#8f3d49;color:#ffb8c2}.button.danger:hover{border-color:#d86a79}.header-subtle{color:var(--muted);font-size:13px}.chat{display:grid;grid-template-columns:1fr minmax(auto,1000px) 1fr;align-content:start;gap:8px;padding:16px;overflow:auto}.chat>*{grid-column:2}.msg{padding:12px 14px;border-radius:12px;line-height:1.5;white-space:wrap;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica,Arial}textarea.input{resize:none;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica,Arial;overflow-y:auto;flex-grow:1}.msg.user{background:var(--user-msg-bg);margin-left:auto;max-width:80%;border:1px solid var(--border);margin-right:5px;margin-bottom:15px;transition:border-color .15s ease,box-shadow .15s ease}.msg.user.editing{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 35%,transparent)}.msg.user .msg-content--user{white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;position:relative}.msg.user .user-msg-expand{margin-top:8px;padding:0;background:transparent;border:none;color:var(--muted);font-weight:700;cursor:pointer;align-self:flex-start;margin-left:0;text-align:left}.msg.assistant{background:transparent;border:none;max-width:none;animation:fadeIn .3s ease-in-out;margin-bottom:30px}.user-message-wrapper{display:flex;flex-direction:column;align-items:flex-end;position:relative}.assistant-message-wrapper{display:flex;flex-direction:column;align-items:flex-start;position:relative}.message-options-bar{display:flex;gap:2px;padding:0;border-radius:8px;background-color:transparent;border:none;position:absolute;bottom:-30px}.user-options{right:-10px;bottom:-40px}.assistant-options{left:0}.message-options-bar .icon-button{padding:4px;border-radius:4px;border:none}.message-options-bar .icon-button:hover{background-color:var(--hover-bg)}.new-msg-tip{position:absolute;right:24px;bottom:84px;padding:8px 12px;border-radius:9999px;background:var(--accent);color:var(--bg);border:none;cursor:pointer;font-weight:600;box-shadow:0 6px 20px #00000059}.new-msg-tip:hover{opacity:.9}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.footer{display:flex;justify-content:center;padding:12px 16px;border-top:1px solid var(--border);background:var(--panel);align-items:flex-end}.footer-content-wrapper{display:flex;gap:8px;width:100%;max-width:1000px;align-items:flex-end}.footer-tool-group{position:relative;display:inline-flex;align-items:center}.settings-content-panel{padding:20px;overflow-y:auto;height:100%}.settings-category{margin-bottom:30px}.settings-category h2{color:var(--accent);margin-bottom:15px;font-size:1.3em}.setting-section{margin-bottom:20px;padding:15px;border-bottom:1px solid var(--border);background-color:var(--panel);border-radius:8px}.setting-section:last-child{border-bottom:none;margin-bottom:0}.setting-section h3{color:var(--text);margin-top:0;margin-bottom:10px;font-size:1.1em}.settings-content-panel .input,.settings-content-panel .select{width:100%;max-width:400px;padding:10px 12px;border-radius:8px;border:1px solid var(--border);background-color:var(--input-bg);color:var(--text);font-size:1em}.settings-content-panel .select{min-width:unset}.setting-control-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.range-input{width:min(360px,100%);accent-color:var(--accent)}.setting-value{min-width:48px;color:var(--text);font-variant-numeric:tabular-nums}.setting-description{margin:10px 0 0;color:var(--muted);line-height:1.5}.setting-status{margin:12px 0 0;line-height:1.5}.setting-status.success{color:#8fd6a3}.setting-status.warning{color:#f1c97a}.setting-status.error{color:#ff9aa8}.setting-status.neutral{color:var(--text)}.setting-meta{margin-top:10px;display:grid;gap:4px;color:var(--muted);font-size:.95em}.msg h1,.msg h2,.msg h3,.msg h4{margin:10px 0;color:var(--accent)}.msg blockquote{border-left:4px solid var(--accent);padding-left:15px;margin-left:0;color:var(--muted)}.msg ul{padding-left:20px}.msg li{margin-bottom:5px}.msg code{background-color:var(--input-bg);padding:2px 4px;border-radius:4px;font-family:monospace}.msg pre{background-color:var(--input-bg);padding:10px;border-radius:8px;overflow-x:auto;white-space:pre-wrap}.msg pre code{padding:0;background-color:transparent}.msg a{color:var(--text);display:inline-flex;align-items:center;gap:4px;position:relative;text-decoration:underline dotted;text-underline-offset:3px}.msg a .tooltip{visibility:hidden;width:auto;background-color:var(--panel);color:var(--text);text-align:center;border-radius:6px;padding:5px 10px;position:absolute;z-index:1;bottom:110%;left:50%;transform:translate(-50%);opacity:0;transition:opacity .3s;white-space:nowrap}.msg a:hover .tooltip{visibility:visible;opacity:1}.msg a:hover{color:var(--accent)}.msg a svg{width:14px;height:14px;stroke:var(--text);transition:stroke .2s ease}.msg a:hover svg{stroke:var(--accent)}.msg hr{border:none;border-top:1px solid var(--border);margin:20px 0}:root{--outline-w: 1px;--grid-w: 1px;--grid: var(--border)}.msg table.nice{border-collapse:separate;border-spacing:0;width:100%;margin:1rem 0;border-radius:12px;box-shadow:0 0 0 var(--outline-w) var(--border)}.msg table.nice th,.msg table.nice td{border:var(--grid-w) solid var(--grid);border-width:.5px;padding:.6rem .75rem;vertical-align:top}.msg table.nice thead tr:first-child th{border-top:0}.msg table.nice tr th:first-child,.msg table.nice tr td:first-child{border-left:0}.msg table.nice tr th:last-child,.msg table.nice tr td:last-child{border-right:0}.msg table.nice tbody tr:last-child td{border-bottom:0}.msg table.nice thead tr:first-child th{background-color:var(--panel)}.msg table.nice thead tr:first-child th:first-child{border-top-left-radius:12px;background-clip:padding-box}.msg table.nice thead tr:first-child th:last-child{border-top-right-radius:12px;background-clip:padding-box}.msg table.nice tbody tr:last-child td:first-child{border-bottom-left-radius:12px;background-clip:padding-box}.msg table.nice tbody tr:last-child td:last-child{border-bottom-right-radius:12px;background-clip:padding-box}.toggle-switch{position:relative;display:inline-block;width:50px;height:28px}.toggle-switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--input-bg);border:1px solid var(--border);transition:.4s;border-radius:28px}.slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:var(--muted);transition:.4s;border-radius:50%}input:checked+.slider{background-color:var(--accent)}input:checked+.slider:before{transform:translate(22px);background-color:var(--panel)}.spinner{border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top:3px solid var(--accent);width:20px;height:20px;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.codeblock{border:1px solid var(--grid, #e5e7eb);border-radius:12px;overflow:hidden;margin:1rem 0}.codeblock__header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:var(--panel);border-bottom:1px solid var(--grid);font-weight:600;font-size:.875rem}.codeblock__lang{opacity:.9}.codeblock__copy{display:inline-flex;align-items:center;gap:.25rem;border:0;background:transparent;padding:.25rem;border-radius:8px;cursor:pointer}.codeblock__copy:hover{background:#0000000f}.codeblock__copy.copied .icon-copy{transform:scale(1.05)}.codeblock__pre{margin:0;padding:.75rem;overflow:auto}.codeblock__code{display:block;white-space:pre}.assistant-message{display:block}.assistant-thoughts{margin-bottom:8px}.think-toggle{background:var(--active-bg);color:var(--muted);border:1px solid var(--border);border-radius:10px;font-size:12px;padding:4px 8px;cursor:pointer}.think-toggle:hover{color:var(--text);border-color:var(--accent)}.think-toggle-icon{display:inline-block;margin-right:6px}.think-content{margin-top:8px;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:var(--panel);color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:13px;line-height:1.5;overflow-x:auto;white-space:pre-wrap}.edit-message-input{display:block;width:100%;height:100%;background:transparent;border:0;padding:0;margin:0;color:inherit;font:inherit;line-height:inherit;letter-spacing:inherit;white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;resize:none;overflow:hidden;outline:none}.edit-message-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 35%,transparent)}.user-edit-shadow{visibility:hidden;white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word}.edit-message-input.edit-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:transparent;border:0;padding:0;margin:0;color:inherit;font:inherit;line-height:inherit;letter-spacing:inherit;white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;resize:none;overflow:hidden;outline:none;box-shadow:none}.websearch-toggle,.db-picker-toggle{background:transparent;border:0;padding:0;margin:0 .1rem 0 0;line-height:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative;top:-7.5px;color:var(--muted);box-shadow:none;outline:none;-webkit-tap-highlight-color:transparent}.websearch-toggle svg,.db-picker-toggle svg{width:20px;height:20px;pointer-events:none}.websearch-toggle.active,.db-picker-toggle.active{color:var(--accent)}.websearch-toggle:focus,.websearch-toggle:focus-visible,.db-picker-toggle:focus,.db-picker-toggle:focus-visible{outline:none;box-shadow:none}.db-picker-menu{position:absolute;right:0;bottom:calc(100% + 10px);min-width:240px;max-height:280px;overflow-y:auto;padding:6px;border-radius:12px;border:1px solid var(--border);background:var(--panel);box-shadow:0 14px 32px #00000059;z-index:20}.db-picker-option{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 10px;border:0;border-radius:10px;background:transparent;color:var(--text);cursor:pointer;text-align:left}.db-picker-option:hover:not(:disabled){background:var(--hover-bg)}.db-picker-option.selected{background:var(--active-bg)}.db-picker-option:disabled{color:var(--muted);cursor:not-allowed}.db-picker-status{flex-shrink:0;color:var(--muted);font-size:12px}.db-picker-empty{padding:10px;color:var(--muted);font-size:13px}.msg-sources{margin-top:8px;font-size:12px;color:var(--muted)}.msg-sources a{color:var(--accent);text-decoration:none;margin-right:8px}.msg-sources a:hover{text-decoration:underline}.msg-sources.chips{display:flex;flex-wrap:wrap;margin:.5rem 0}.msg-sources.chips .chip{display:inline-flex;align-items:center;padding:.25rem .6rem;border-radius:9999px;border:1px solid var(--border);text-decoration:none;font-size:.85rem;line-height:1;white-space:nowrap;margin-top:.5rem}.db-active-badge{margin-left:8px;padding:2px 8px;border-radius:999px;background:color-mix(in srgb,var(--accent) 20%,transparent);color:var(--accent);font-size:11px}.placeholder-view{height:100%;overflow:auto;padding:20px}.placeholder-view h1{margin-top:0}.library-panel{position:relative;display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.library-panel-scroll{flex:1;min-height:0;overflow:auto;padding:20px}.library-inline-form{margin-bottom:14px;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel) 88%,black)}.danger-zone{border-color:#8f3d49}.library-toast-stack{position:absolute;right:20px;bottom:92px;left:20px;z-index:2;display:flex;flex-direction:column;align-items:flex-end;gap:10px;pointer-events:none}.library-toast{width:min(100%,560px);padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel) 88%,black);box-shadow:0 16px 36px #00000047;line-height:1.45;animation:libraryToastIn .18s ease-out}.library-toast.success{border-color:color-mix(in srgb,#69c4a1 60%,var(--border))}.library-toast.warning{border-color:color-mix(in srgb,#e18282 60%,var(--border))}@keyframes libraryToastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.library-footer-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px;padding:14px 20px 20px;border-top:1px solid var(--border);background:color-mix(in srgb,var(--panel) 94%,black)}.library-files h2{margin:0 0 12px;font-size:16px}.library-file-list{display:grid;gap:10px}.library-file-row{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel) 88%,black)}.library-file-meta{min-width:0;flex:1}.library-file-name{font-weight:600;margin-bottom:4px}.library-file-mode{display:inline-flex;align-items:center;margin-top:4px;padding:4px 8px;border-radius:999px;border:1px solid var(--border);color:var(--muted);font-size:11px;letter-spacing:.02em;text-transform:uppercase}.library-file-mode.enabled{color:var(--text);border-color:color-mix(in srgb,var(--accent) 45%,var(--border));background:color-mix(in srgb,var(--accent) 12%,transparent)}.library-file-path,.muted-copy{color:var(--muted);font-size:13px;word-break:break-word}.library-file-actions{display:flex;gap:8px;flex-shrink:0}.library-file-sync{margin-top:10px}.library-file-sync-row{display:flex;flex-wrap:wrap;gap:6px 10px;align-items:baseline;margin-bottom:8px}.library-file-sync-label{font-size:12px;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.library-file-sync-label.ready{color:#69c4a1}.library-file-sync-label.syncing,.library-file-sync-label.pending{color:var(--accent)}.library-file-sync-label.failed{color:#e18282}.library-file-sync-detail{color:var(--muted);font-size:12px;line-height:1.35}.library-file-progress{position:relative;width:100%;height:8px;overflow:hidden;border-radius:999px;background:color-mix(in srgb,var(--panel) 50%,black);border:1px solid color-mix(in srgb,var(--border) 80%,transparent)}.library-file-progress-bar{height:100%;width:0;border-radius:inherit;background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 76%,white),var(--accent));transition:width .18s ease}.library-file-progress.ready .library-file-progress-bar{background:linear-gradient(90deg,#5cb48e,#7be1b5)}.library-file-progress.failed .library-file-progress-bar{background:linear-gradient(90deg,#c35d5d,#e18282)}@media (max-width: 760px){.library-toast-stack{right:12px;bottom:124px;left:12px}.library-footer-actions{padding:12px}.library-file-row{flex-direction:column}.library-file-actions{width:100%;justify-content:flex-end}} diff --git a/dist/assets/index-CEHqzDAN.js b/dist/assets/index-CEHqzDAN.js deleted file mode 100644 index 0f09f11..0000000 --- a/dist/assets/index-CEHqzDAN.js +++ /dev/null @@ -1,73 +0,0 @@ -(function(){const t=document.createElement("link").relList;if(t&&t.supports&&t.supports("modulepreload"))return;for(const l of document.querySelectorAll('link[rel="modulepreload"]'))r(l);new MutationObserver(l=>{for(const o of l)if(o.type==="childList")for(const i of o.addedNodes)i.tagName==="LINK"&&i.rel==="modulepreload"&&r(i)}).observe(document,{childList:!0,subtree:!0});function n(l){const o={};return l.integrity&&(o.integrity=l.integrity),l.referrerPolicy&&(o.referrerPolicy=l.referrerPolicy),l.crossOrigin==="use-credentials"?o.credentials="include":l.crossOrigin==="anonymous"?o.credentials="omit":o.credentials="same-origin",o}function r(l){if(l.ep)return;l.ep=!0;const o=n(l);fetch(l.href,o)}})();function Mp(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var yc={exports:{}},ko={},wc={exports:{}},J={};/** - * @license React - * react.production.min.js - * - * Copyright (c) Facebook, Inc. and its affiliates. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */var nl=Symbol.for("react.element"),zp=Symbol.for("react.portal"),Fp=Symbol.for("react.fragment"),Ip=Symbol.for("react.strict_mode"),Op=Symbol.for("react.profiler"),Dp=Symbol.for("react.provider"),Ap=Symbol.for("react.context"),Up=Symbol.for("react.forward_ref"),Bp=Symbol.for("react.suspense"),Hp=Symbol.for("react.memo"),Wp=Symbol.for("react.lazy"),Wa=Symbol.iterator;function Vp(e){return e===null||typeof e!="object"?null:(e=Wa&&e[Wa]||e["@@iterator"],typeof e=="function"?e:null)}var Sc={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},xc=Object.assign,kc={};function ur(e,t,n){this.props=e,this.context=t,this.refs=kc,this.updater=n||Sc}ur.prototype.isReactComponent={};ur.prototype.setState=function(e,t){if(typeof e!="object"&&typeof e!="function"&&e!=null)throw Error("setState(...): takes an object of state variables to update or a function which returns an object of state variables.");this.updater.enqueueSetState(this,e,t,"setState")};ur.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")};function Ec(){}Ec.prototype=ur.prototype;function Es(e,t,n){this.props=e,this.context=t,this.refs=kc,this.updater=n||Sc}var Cs=Es.prototype=new Ec;Cs.constructor=Es;xc(Cs,ur.prototype);Cs.isPureReactComponent=!0;var Va=Array.isArray,Cc=Object.prototype.hasOwnProperty,Ns={current:null},Nc={key:!0,ref:!0,__self:!0,__source:!0};function _c(e,t,n){var r,l={},o=null,i=null;if(t!=null)for(r in t.ref!==void 0&&(i=t.ref),t.key!==void 0&&(o=""+t.key),t)Cc.call(t,r)&&!Nc.hasOwnProperty(r)&&(l[r]=t[r]);var a=arguments.length-2;if(a===1)l.children=n;else if(1>>1,ge=R[te];if(0>>1;tel(Et,V))Ctl(Xe,Et)?(R[te]=Xe,R[Ct]=V,te=Ct):(R[te]=Et,R[ht]=V,te=ht);else if(Ctl(Xe,V))R[te]=Xe,R[Ct]=V,te=Ct;else break e}}return z}function l(R,z){var V=R.sortIndex-z.sortIndex;return V!==0?V:R.id-z.id}if(typeof performance=="object"&&typeof performance.now=="function"){var o=performance;e.unstable_now=function(){return o.now()}}else{var i=Date,a=i.now();e.unstable_now=function(){return i.now()-a}}var s=[],u=[],p=1,v=null,y=3,S=!1,k=!1,C=!1,_=typeof setTimeout=="function"?setTimeout:null,h=typeof clearTimeout=="function"?clearTimeout:null,f=typeof setImmediate<"u"?setImmediate:null;typeof navigator<"u"&&navigator.scheduling!==void 0&&navigator.scheduling.isInputPending!==void 0&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function d(R){for(var z=n(u);z!==null;){if(z.callback===null)r(u);else if(z.startTime<=R)r(u),z.sortIndex=z.expirationTime,t(s,z);else break;z=n(u)}}function E(R){if(C=!1,d(R),!k)if(n(s)!==null)k=!0,O(P);else{var z=n(u);z!==null&&G(E,z.startTime-R)}}function P(R,z){k=!1,C&&(C=!1,h(F),F=-1),S=!0;var V=y;try{for(d(z),v=n(s);v!==null&&(!(v.expirationTime>z)||R&&!ee());){var te=v.callback;if(typeof te=="function"){v.callback=null,y=v.priorityLevel;var ge=te(v.expirationTime<=z);z=e.unstable_now(),typeof ge=="function"?v.callback=ge:v===n(s)&&r(s),d(z)}else r(s);v=n(s)}if(v!==null)var kt=!0;else{var ht=n(u);ht!==null&&G(E,ht.startTime-z),kt=!1}return kt}finally{v=null,y=V,S=!1}}var T=!1,M=null,F=-1,B=5,D=-1;function ee(){return!(e.unstable_now()-DR||125te?(R.sortIndex=V,t(u,R),n(s)===null&&R===n(u)&&(C?(h(F),F=-1):C=!0,G(E,V-te))):(R.sortIndex=ge,t(s,R),k||S||(k=!0,O(P))),R},e.unstable_shouldYield=ee,e.unstable_wrapCallback=function(R){var z=y;return function(){var V=y;y=z;try{return R.apply(this,arguments)}finally{y=V}}}})(Tc);Rc.exports=Tc;var th=Rc.exports;/** - * @license React - * react-dom.production.min.js - * - * Copyright (c) Facebook, Inc. and its affiliates. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */var nh=g,Ye=th;function L(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n"u"||typeof window.document>"u"||typeof window.document.createElement>"u"),Li=Object.prototype.hasOwnProperty,rh=/^[:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD][:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\-.0-9\u00B7\u0300-\u036F\u203F-\u2040]*$/,Qa={},Ka={};function lh(e){return Li.call(Ka,e)?!0:Li.call(Qa,e)?!1:rh.test(e)?Ka[e]=!0:(Qa[e]=!0,!1)}function oh(e,t,n,r){if(n!==null&&n.type===0)return!1;switch(typeof t){case"function":case"symbol":return!0;case"boolean":return r?!1:n!==null?!n.acceptsBooleans:(e=e.toLowerCase().slice(0,5),e!=="data-"&&e!=="aria-");default:return!1}}function ih(e,t,n,r){if(t===null||typeof t>"u"||oh(e,t,n,r))return!0;if(r)return!1;if(n!==null)switch(n.type){case 3:return!t;case 4:return t===!1;case 5:return isNaN(t);case 6:return isNaN(t)||1>t}return!1}function Ae(e,t,n,r,l,o,i){this.acceptsBooleans=t===2||t===3||t===4,this.attributeName=r,this.attributeNamespace=l,this.mustUseProperty=n,this.propertyName=e,this.type=t,this.sanitizeURL=o,this.removeEmptyString=i}var Le={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(e){Le[e]=new Ae(e,0,!1,e,null,!1,!1)});[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(e){var t=e[0];Le[t]=new Ae(t,1,!1,e[1],null,!1,!1)});["contentEditable","draggable","spellCheck","value"].forEach(function(e){Le[e]=new Ae(e,2,!1,e.toLowerCase(),null,!1,!1)});["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(e){Le[e]=new Ae(e,2,!1,e,null,!1,!1)});"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope".split(" ").forEach(function(e){Le[e]=new Ae(e,3,!1,e.toLowerCase(),null,!1,!1)});["checked","multiple","muted","selected"].forEach(function(e){Le[e]=new Ae(e,3,!0,e,null,!1,!1)});["capture","download"].forEach(function(e){Le[e]=new Ae(e,4,!1,e,null,!1,!1)});["cols","rows","size","span"].forEach(function(e){Le[e]=new Ae(e,6,!1,e,null,!1,!1)});["rowSpan","start"].forEach(function(e){Le[e]=new Ae(e,5,!1,e.toLowerCase(),null,!1,!1)});var Ls=/[\-:]([a-z])/g;function Ps(e){return e[1].toUpperCase()}"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height".split(" ").forEach(function(e){var t=e.replace(Ls,Ps);Le[t]=new Ae(t,1,!1,e,null,!1,!1)});"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type".split(" ").forEach(function(e){var t=e.replace(Ls,Ps);Le[t]=new Ae(t,1,!1,e,"http://www.w3.org/1999/xlink",!1,!1)});["xml:base","xml:lang","xml:space"].forEach(function(e){var t=e.replace(Ls,Ps);Le[t]=new Ae(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1,!1)});["tabIndex","crossOrigin"].forEach(function(e){Le[e]=new Ae(e,1,!1,e.toLowerCase(),null,!1,!1)});Le.xlinkHref=new Ae("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1);["src","href","action","formAction"].forEach(function(e){Le[e]=new Ae(e,1,!1,e.toLowerCase(),null,!0,!0)});function js(e,t,n,r){var l=Le.hasOwnProperty(t)?Le[t]:null;(l!==null?l.type!==0:r||!(2a||l[i]!==o[a]){var s=` -`+l[i].replace(" at new "," at ");return e.displayName&&s.includes("")&&(s=s.replace("",e.displayName)),s}while(1<=i&&0<=a);break}}}finally{ei=!1,Error.prepareStackTrace=n}return(e=e?e.displayName||e.name:"")?Cr(e):""}function sh(e){switch(e.tag){case 5:return Cr(e.type);case 16:return Cr("Lazy");case 13:return Cr("Suspense");case 19:return Cr("SuspenseList");case 0:case 2:case 15:return e=ti(e.type,!1),e;case 11:return e=ti(e.type.render,!1),e;case 1:return e=ti(e.type,!0),e;default:return""}}function Ti(e){if(e==null)return null;if(typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case An:return"Fragment";case Dn:return"Portal";case Pi:return"Profiler";case Rs:return"StrictMode";case ji:return"Suspense";case Ri:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case zc:return(e.displayName||"Context")+".Consumer";case Mc:return(e._context.displayName||"Context")+".Provider";case Ts:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case $s:return t=e.displayName||null,t!==null?t:Ti(e.type)||"Memo";case bt:t=e._payload,e=e._init;try{return Ti(e(t))}catch{}}return null}function ah(e){var t=e.type;switch(e.tag){case 24:return"Cache";case 9:return(t.displayName||"Context")+".Consumer";case 10:return(t._context.displayName||"Context")+".Provider";case 18:return"DehydratedFragment";case 11:return e=t.render,e=e.displayName||e.name||"",t.displayName||(e!==""?"ForwardRef("+e+")":"ForwardRef");case 7:return"Fragment";case 5:return t;case 4:return"Portal";case 3:return"Root";case 6:return"Text";case 16:return Ti(t);case 8:return t===Rs?"StrictMode":"Mode";case 22:return"Offscreen";case 12:return"Profiler";case 21:return"Scope";case 13:return"Suspense";case 19:return"SuspenseList";case 25:return"TracingMarker";case 1:case 0:case 17:case 2:case 14:case 15:if(typeof t=="function")return t.displayName||t.name||null;if(typeof t=="string")return t}return null}function on(e){switch(typeof e){case"boolean":case"number":case"string":case"undefined":return e;case"object":return e;default:return""}}function Ic(e){var t=e.type;return(e=e.nodeName)&&e.toLowerCase()==="input"&&(t==="checkbox"||t==="radio")}function uh(e){var t=Ic(e)?"checked":"value",n=Object.getOwnPropertyDescriptor(e.constructor.prototype,t),r=""+e[t];if(!e.hasOwnProperty(t)&&typeof n<"u"&&typeof n.get=="function"&&typeof n.set=="function"){var l=n.get,o=n.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return l.call(this)},set:function(i){r=""+i,o.call(this,i)}}),Object.defineProperty(e,t,{enumerable:n.enumerable}),{getValue:function(){return r},setValue:function(i){r=""+i},stopTracking:function(){e._valueTracker=null,delete e[t]}}}}function wl(e){e._valueTracker||(e._valueTracker=uh(e))}function Oc(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var n=t.getValue(),r="";return e&&(r=Ic(e)?e.checked?"true":"false":e.value),e=r,e!==n?(t.setValue(e),!0):!1}function Gl(e){if(e=e||(typeof document<"u"?document:void 0),typeof e>"u")return null;try{return e.activeElement||e.body}catch{return e.body}}function $i(e,t){var n=t.checked;return fe({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:n??e._wrapperState.initialChecked})}function Ja(e,t){var n=t.defaultValue==null?"":t.defaultValue,r=t.checked!=null?t.checked:t.defaultChecked;n=on(t.value!=null?t.value:n),e._wrapperState={initialChecked:r,initialValue:n,controlled:t.type==="checkbox"||t.type==="radio"?t.checked!=null:t.value!=null}}function Dc(e,t){t=t.checked,t!=null&&js(e,"checked",t,!1)}function Mi(e,t){Dc(e,t);var n=on(t.value),r=t.type;if(n!=null)r==="number"?(n===0&&e.value===""||e.value!=n)&&(e.value=""+n):e.value!==""+n&&(e.value=""+n);else if(r==="submit"||r==="reset"){e.removeAttribute("value");return}t.hasOwnProperty("value")?zi(e,t.type,n):t.hasOwnProperty("defaultValue")&&zi(e,t.type,on(t.defaultValue)),t.checked==null&&t.defaultChecked!=null&&(e.defaultChecked=!!t.defaultChecked)}function Ga(e,t,n){if(t.hasOwnProperty("value")||t.hasOwnProperty("defaultValue")){var r=t.type;if(!(r!=="submit"&&r!=="reset"||t.value!==void 0&&t.value!==null))return;t=""+e._wrapperState.initialValue,n||t===e.value||(e.value=t),e.defaultValue=t}n=e.name,n!==""&&(e.name=""),e.defaultChecked=!!e._wrapperState.initialChecked,n!==""&&(e.name=n)}function zi(e,t,n){(t!=="number"||Gl(e.ownerDocument)!==e)&&(n==null?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+n&&(e.defaultValue=""+n))}var Nr=Array.isArray;function Gn(e,t,n,r){if(e=e.options,t){t={};for(var l=0;l"+t.valueOf().toString()+"",t=Sl.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}});function Dr(e,t){if(t){var n=e.firstChild;if(n&&n===e.lastChild&&n.nodeType===3){n.nodeValue=t;return}}e.textContent=t}var Pr={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},ch=["Webkit","ms","Moz","O"];Object.keys(Pr).forEach(function(e){ch.forEach(function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),Pr[t]=Pr[e]})});function Hc(e,t,n){return t==null||typeof t=="boolean"||t===""?"":n||typeof t!="number"||t===0||Pr.hasOwnProperty(e)&&Pr[e]?(""+t).trim():t+"px"}function Wc(e,t){e=e.style;for(var n in t)if(t.hasOwnProperty(n)){var r=n.indexOf("--")===0,l=Hc(n,t[n],r);n==="float"&&(n="cssFloat"),r?e.setProperty(n,l):e[n]=l}}var fh=fe({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});function Oi(e,t){if(t){if(fh[e]&&(t.children!=null||t.dangerouslySetInnerHTML!=null))throw Error(L(137,e));if(t.dangerouslySetInnerHTML!=null){if(t.children!=null)throw Error(L(60));if(typeof t.dangerouslySetInnerHTML!="object"||!("__html"in t.dangerouslySetInnerHTML))throw Error(L(61))}if(t.style!=null&&typeof t.style!="object")throw Error(L(62))}}function Di(e,t){if(e.indexOf("-")===-1)return typeof t.is=="string";switch(e){case"annotation-xml":case"color-profile":case"font-face":case"font-face-src":case"font-face-uri":case"font-face-format":case"font-face-name":case"missing-glyph":return!1;default:return!0}}var Ai=null;function Ms(e){return e=e.target||e.srcElement||window,e.correspondingUseElement&&(e=e.correspondingUseElement),e.nodeType===3?e.parentNode:e}var Ui=null,Xn=null,Zn=null;function qa(e){if(e=ol(e)){if(typeof Ui!="function")throw Error(L(280));var t=e.stateNode;t&&(t=Lo(t),Ui(e.stateNode,e.type,t))}}function Vc(e){Xn?Zn?Zn.push(e):Zn=[e]:Xn=e}function bc(){if(Xn){var e=Xn,t=Zn;if(Zn=Xn=null,qa(e),t)for(e=0;e>>=0,e===0?32:31-(kh(e)/Eh|0)|0}var xl=64,kl=4194304;function _r(e){switch(e&-e){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return e&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return e&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;default:return e}}function eo(e,t){var n=e.pendingLanes;if(n===0)return 0;var r=0,l=e.suspendedLanes,o=e.pingedLanes,i=n&268435455;if(i!==0){var a=i&~l;a!==0?r=_r(a):(o&=i,o!==0&&(r=_r(o)))}else i=n&~l,i!==0?r=_r(i):o!==0&&(r=_r(o));if(r===0)return 0;if(t!==0&&t!==r&&!(t&l)&&(l=r&-r,o=t&-t,l>=o||l===16&&(o&4194240)!==0))return t;if(r&4&&(r|=n&16),t=e.entangledLanes,t!==0)for(e=e.entanglements,t&=r;0n;n++)t.push(e);return t}function rl(e,t,n){e.pendingLanes|=t,t!==536870912&&(e.suspendedLanes=0,e.pingedLanes=0),e=e.eventTimes,t=31-ct(t),e[t]=n}function Lh(e,t){var n=e.pendingLanes&~t;e.pendingLanes=t,e.suspendedLanes=0,e.pingedLanes=0,e.expiredLanes&=t,e.mutableReadLanes&=t,e.entangledLanes&=t,t=e.entanglements;var r=e.eventTimes;for(e=e.expirationTimes;0=Rr),au=" ",uu=!1;function df(e,t){switch(e){case"keyup":return tm.indexOf(t.keyCode)!==-1;case"keydown":return t.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function pf(e){return e=e.detail,typeof e=="object"&&"data"in e?e.data:null}var Un=!1;function rm(e,t){switch(e){case"compositionend":return pf(t);case"keypress":return t.which!==32?null:(uu=!0,au);case"textInput":return e=t.data,e===au&&uu?null:e;default:return null}}function lm(e,t){if(Un)return e==="compositionend"||!Bs&&df(e,t)?(e=cf(),Dl=Ds=Jt=null,Un=!1,e):null;switch(e){case"paste":return null;case"keypress":if(!(t.ctrlKey||t.altKey||t.metaKey)||t.ctrlKey&&t.altKey){if(t.char&&1=t)return{node:n,offset:t-e};e=r}e:{for(;n;){if(n.nextSibling){n=n.nextSibling;break e}n=n.parentNode}n=void 0}n=pu(n)}}function vf(e,t){return e&&t?e===t?!0:e&&e.nodeType===3?!1:t&&t.nodeType===3?vf(e,t.parentNode):"contains"in e?e.contains(t):e.compareDocumentPosition?!!(e.compareDocumentPosition(t)&16):!1:!1}function yf(){for(var e=window,t=Gl();t instanceof e.HTMLIFrameElement;){try{var n=typeof t.contentWindow.location.href=="string"}catch{n=!1}if(n)e=t.contentWindow;else break;t=Gl(e.document)}return t}function Hs(e){var t=e&&e.nodeName&&e.nodeName.toLowerCase();return t&&(t==="input"&&(e.type==="text"||e.type==="search"||e.type==="tel"||e.type==="url"||e.type==="password")||t==="textarea"||e.contentEditable==="true")}function pm(e){var t=yf(),n=e.focusedElem,r=e.selectionRange;if(t!==n&&n&&n.ownerDocument&&vf(n.ownerDocument.documentElement,n)){if(r!==null&&Hs(n)){if(t=r.start,e=r.end,e===void 0&&(e=t),"selectionStart"in n)n.selectionStart=t,n.selectionEnd=Math.min(e,n.value.length);else if(e=(t=n.ownerDocument||document)&&t.defaultView||window,e.getSelection){e=e.getSelection();var l=n.textContent.length,o=Math.min(r.start,l);r=r.end===void 0?o:Math.min(r.end,l),!e.extend&&o>r&&(l=r,r=o,o=l),l=hu(n,o);var i=hu(n,r);l&&i&&(e.rangeCount!==1||e.anchorNode!==l.node||e.anchorOffset!==l.offset||e.focusNode!==i.node||e.focusOffset!==i.offset)&&(t=t.createRange(),t.setStart(l.node,l.offset),e.removeAllRanges(),o>r?(e.addRange(t),e.extend(i.node,i.offset)):(t.setEnd(i.node,i.offset),e.addRange(t)))}}for(t=[],e=n;e=e.parentNode;)e.nodeType===1&&t.push({element:e,left:e.scrollLeft,top:e.scrollTop});for(typeof n.focus=="function"&&n.focus(),n=0;n=document.documentMode,Bn=null,Qi=null,$r=null,Ki=!1;function mu(e,t,n){var r=n.window===n?n.document:n.nodeType===9?n:n.ownerDocument;Ki||Bn==null||Bn!==Gl(r)||(r=Bn,"selectionStart"in r&&Hs(r)?r={start:r.selectionStart,end:r.selectionEnd}:(r=(r.ownerDocument&&r.ownerDocument.defaultView||window).getSelection(),r={anchorNode:r.anchorNode,anchorOffset:r.anchorOffset,focusNode:r.focusNode,focusOffset:r.focusOffset}),$r&&Vr($r,r)||($r=r,r=ro(Qi,"onSelect"),0Vn||(e.current=qi[Vn],qi[Vn]=null,Vn--)}function ne(e,t){Vn++,qi[Vn]=e.current,e.current=t}var sn={},Me=un(sn),He=un(!1),kn=sn;function rr(e,t){var n=e.type.contextTypes;if(!n)return sn;var r=e.stateNode;if(r&&r.__reactInternalMemoizedUnmaskedChildContext===t)return r.__reactInternalMemoizedMaskedChildContext;var l={},o;for(o in n)l[o]=t[o];return r&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=l),l}function We(e){return e=e.childContextTypes,e!=null}function oo(){oe(He),oe(Me)}function ku(e,t,n){if(Me.current!==sn)throw Error(L(168));ne(Me,t),ne(He,n)}function Lf(e,t,n){var r=e.stateNode;if(t=t.childContextTypes,typeof r.getChildContext!="function")return n;r=r.getChildContext();for(var l in r)if(!(l in t))throw Error(L(108,ah(e)||"Unknown",l));return fe({},n,r)}function io(e){return e=(e=e.stateNode)&&e.__reactInternalMemoizedMergedChildContext||sn,kn=Me.current,ne(Me,e),ne(He,He.current),!0}function Eu(e,t,n){var r=e.stateNode;if(!r)throw Error(L(169));n?(e=Lf(e,t,kn),r.__reactInternalMemoizedMergedChildContext=e,oe(He),oe(Me),ne(Me,e)):oe(He),ne(He,n)}var Pt=null,Po=!1,mi=!1;function Pf(e){Pt===null?Pt=[e]:Pt.push(e)}function Nm(e){Po=!0,Pf(e)}function cn(){if(!mi&&Pt!==null){mi=!0;var e=0,t=q;try{var n=Pt;for(q=1;e>=i,l-=i,jt=1<<32-ct(t)+l|n<F?(B=M,M=null):B=M.sibling;var D=y(h,M,d[F],E);if(D===null){M===null&&(M=B);break}e&&M&&D.alternate===null&&t(h,M),f=o(D,f,F),T===null?P=D:T.sibling=D,T=D,M=B}if(F===d.length)return n(h,M),ie&&mn(h,F),P;if(M===null){for(;FF?(B=M,M=null):B=M.sibling;var ee=y(h,M,D.value,E);if(ee===null){M===null&&(M=B);break}e&&M&&ee.alternate===null&&t(h,M),f=o(ee,f,F),T===null?P=ee:T.sibling=ee,T=ee,M=B}if(D.done)return n(h,M),ie&&mn(h,F),P;if(M===null){for(;!D.done;F++,D=d.next())D=v(h,D.value,E),D!==null&&(f=o(D,f,F),T===null?P=D:T.sibling=D,T=D);return ie&&mn(h,F),P}for(M=r(h,M);!D.done;F++,D=d.next())D=S(M,h,F,D.value,E),D!==null&&(e&&D.alternate!==null&&M.delete(D.key===null?F:D.key),f=o(D,f,F),T===null?P=D:T.sibling=D,T=D);return e&&M.forEach(function(H){return t(h,H)}),ie&&mn(h,F),P}function _(h,f,d,E){if(typeof d=="object"&&d!==null&&d.type===An&&d.key===null&&(d=d.props.children),typeof d=="object"&&d!==null){switch(d.$$typeof){case yl:e:{for(var P=d.key,T=f;T!==null;){if(T.key===P){if(P=d.type,P===An){if(T.tag===7){n(h,T.sibling),f=l(T,d.props.children),f.return=h,h=f;break e}}else if(T.elementType===P||typeof P=="object"&&P!==null&&P.$$typeof===bt&&_u(P)===T.type){n(h,T.sibling),f=l(T,d.props),f.ref=Sr(h,T,d),f.return=h,h=f;break e}n(h,T);break}else t(h,T);T=T.sibling}d.type===An?(f=xn(d.props.children,h.mode,E,d.key),f.return=h,h=f):(E=Ql(d.type,d.key,d.props,null,h.mode,E),E.ref=Sr(h,f,d),E.return=h,h=E)}return i(h);case Dn:e:{for(T=d.key;f!==null;){if(f.key===T)if(f.tag===4&&f.stateNode.containerInfo===d.containerInfo&&f.stateNode.implementation===d.implementation){n(h,f.sibling),f=l(f,d.children||[]),f.return=h,h=f;break e}else{n(h,f);break}else t(h,f);f=f.sibling}f=Ei(d,h.mode,E),f.return=h,h=f}return i(h);case bt:return T=d._init,_(h,f,T(d._payload),E)}if(Nr(d))return k(h,f,d,E);if(mr(d))return C(h,f,d,E);jl(h,d)}return typeof d=="string"&&d!==""||typeof d=="number"?(d=""+d,f!==null&&f.tag===6?(n(h,f.sibling),f=l(f,d),f.return=h,h=f):(n(h,f),f=ki(d,h.mode,E),f.return=h,h=f),i(h)):n(h,f)}return _}var or=$f(!0),Mf=$f(!1),uo=un(null),co=null,Kn=null,Qs=null;function Ks(){Qs=Kn=co=null}function Ys(e){var t=uo.current;oe(uo),e._currentValue=t}function ns(e,t,n){for(;e!==null;){var r=e.alternate;if((e.childLanes&t)!==t?(e.childLanes|=t,r!==null&&(r.childLanes|=t)):r!==null&&(r.childLanes&t)!==t&&(r.childLanes|=t),e===n)break;e=e.return}}function er(e,t){co=e,Qs=Kn=null,e=e.dependencies,e!==null&&e.firstContext!==null&&(e.lanes&t&&(Be=!0),e.firstContext=null)}function rt(e){var t=e._currentValue;if(Qs!==e)if(e={context:e,memoizedValue:t,next:null},Kn===null){if(co===null)throw Error(L(308));Kn=e,co.dependencies={lanes:0,firstContext:e}}else Kn=Kn.next=e;return t}var yn=null;function Js(e){yn===null?yn=[e]:yn.push(e)}function zf(e,t,n,r){var l=t.interleaved;return l===null?(n.next=n,Js(t)):(n.next=l.next,l.next=n),t.interleaved=n,Ft(e,r)}function Ft(e,t){e.lanes|=t;var n=e.alternate;for(n!==null&&(n.lanes|=t),n=e,e=e.return;e!==null;)e.childLanes|=t,n=e.alternate,n!==null&&(n.childLanes|=t),n=e,e=e.return;return n.tag===3?n.stateNode:null}var Qt=!1;function Gs(e){e.updateQueue={baseState:e.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function Ff(e,t){e=e.updateQueue,t.updateQueue===e&&(t.updateQueue={baseState:e.baseState,firstBaseUpdate:e.firstBaseUpdate,lastBaseUpdate:e.lastBaseUpdate,shared:e.shared,effects:e.effects})}function Tt(e,t){return{eventTime:e,lane:t,tag:0,payload:null,callback:null,next:null}}function tn(e,t,n){var r=e.updateQueue;if(r===null)return null;if(r=r.shared,X&2){var l=r.pending;return l===null?t.next=t:(t.next=l.next,l.next=t),r.pending=t,Ft(e,n)}return l=r.interleaved,l===null?(t.next=t,Js(r)):(t.next=l.next,l.next=t),r.interleaved=t,Ft(e,n)}function Ul(e,t,n){if(t=t.updateQueue,t!==null&&(t=t.shared,(n&4194240)!==0)){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,Fs(e,n)}}function Lu(e,t){var n=e.updateQueue,r=e.alternate;if(r!==null&&(r=r.updateQueue,n===r)){var l=null,o=null;if(n=n.firstBaseUpdate,n!==null){do{var i={eventTime:n.eventTime,lane:n.lane,tag:n.tag,payload:n.payload,callback:n.callback,next:null};o===null?l=o=i:o=o.next=i,n=n.next}while(n!==null);o===null?l=o=t:o=o.next=t}else l=o=t;n={baseState:r.baseState,firstBaseUpdate:l,lastBaseUpdate:o,shared:r.shared,effects:r.effects},e.updateQueue=n;return}e=n.lastBaseUpdate,e===null?n.firstBaseUpdate=t:e.next=t,n.lastBaseUpdate=t}function fo(e,t,n,r){var l=e.updateQueue;Qt=!1;var o=l.firstBaseUpdate,i=l.lastBaseUpdate,a=l.shared.pending;if(a!==null){l.shared.pending=null;var s=a,u=s.next;s.next=null,i===null?o=u:i.next=u,i=s;var p=e.alternate;p!==null&&(p=p.updateQueue,a=p.lastBaseUpdate,a!==i&&(a===null?p.firstBaseUpdate=u:a.next=u,p.lastBaseUpdate=s))}if(o!==null){var v=l.baseState;i=0,p=u=s=null,a=o;do{var y=a.lane,S=a.eventTime;if((r&y)===y){p!==null&&(p=p.next={eventTime:S,lane:0,tag:a.tag,payload:a.payload,callback:a.callback,next:null});e:{var k=e,C=a;switch(y=t,S=n,C.tag){case 1:if(k=C.payload,typeof k=="function"){v=k.call(S,v,y);break e}v=k;break e;case 3:k.flags=k.flags&-65537|128;case 0:if(k=C.payload,y=typeof k=="function"?k.call(S,v,y):k,y==null)break e;v=fe({},v,y);break e;case 2:Qt=!0}}a.callback!==null&&a.lane!==0&&(e.flags|=64,y=l.effects,y===null?l.effects=[a]:y.push(a))}else S={eventTime:S,lane:y,tag:a.tag,payload:a.payload,callback:a.callback,next:null},p===null?(u=p=S,s=v):p=p.next=S,i|=y;if(a=a.next,a===null){if(a=l.shared.pending,a===null)break;y=a,a=y.next,y.next=null,l.lastBaseUpdate=y,l.shared.pending=null}}while(!0);if(p===null&&(s=v),l.baseState=s,l.firstBaseUpdate=u,l.lastBaseUpdate=p,t=l.shared.interleaved,t!==null){l=t;do i|=l.lane,l=l.next;while(l!==t)}else o===null&&(l.shared.lanes=0);Nn|=i,e.lanes=i,e.memoizedState=v}}function Pu(e,t,n){if(e=t.effects,t.effects=null,e!==null)for(t=0;tn?n:4,e(!0);var r=vi.transition;vi.transition={};try{e(!1),t()}finally{q=n,vi.transition=r}}function Zf(){return lt().memoizedState}function jm(e,t,n){var r=rn(e);if(n={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null},qf(e))ed(t,n);else if(n=zf(e,t,n,r),n!==null){var l=Oe();ft(n,e,r,l),td(n,t,r)}}function Rm(e,t,n){var r=rn(e),l={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null};if(qf(e))ed(t,l);else{var o=e.alternate;if(e.lanes===0&&(o===null||o.lanes===0)&&(o=t.lastRenderedReducer,o!==null))try{var i=t.lastRenderedState,a=o(i,n);if(l.hasEagerState=!0,l.eagerState=a,dt(a,i)){var s=t.interleaved;s===null?(l.next=l,Js(t)):(l.next=s.next,s.next=l),t.interleaved=l;return}}catch{}finally{}n=zf(e,t,l,r),n!==null&&(l=Oe(),ft(n,e,r,l),td(n,t,r))}}function qf(e){var t=e.alternate;return e===ue||t!==null&&t===ue}function ed(e,t){Mr=ho=!0;var n=e.pending;n===null?t.next=t:(t.next=n.next,n.next=t),e.pending=t}function td(e,t,n){if(n&4194240){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,Fs(e,n)}}var mo={readContext:rt,useCallback:Re,useContext:Re,useEffect:Re,useImperativeHandle:Re,useInsertionEffect:Re,useLayoutEffect:Re,useMemo:Re,useReducer:Re,useRef:Re,useState:Re,useDebugValue:Re,useDeferredValue:Re,useTransition:Re,useMutableSource:Re,useSyncExternalStore:Re,useId:Re,unstable_isNewReconciler:!1},Tm={readContext:rt,useCallback:function(e,t){return vt().memoizedState=[e,t===void 0?null:t],e},useContext:rt,useEffect:Ru,useImperativeHandle:function(e,t,n){return n=n!=null?n.concat([e]):null,Hl(4194308,4,Kf.bind(null,t,e),n)},useLayoutEffect:function(e,t){return Hl(4194308,4,e,t)},useInsertionEffect:function(e,t){return Hl(4,2,e,t)},useMemo:function(e,t){var n=vt();return t=t===void 0?null:t,e=e(),n.memoizedState=[e,t],e},useReducer:function(e,t,n){var r=vt();return t=n!==void 0?n(t):t,r.memoizedState=r.baseState=t,e={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:e,lastRenderedState:t},r.queue=e,e=e.dispatch=jm.bind(null,ue,e),[r.memoizedState,e]},useRef:function(e){var t=vt();return e={current:e},t.memoizedState=e},useState:ju,useDebugValue:la,useDeferredValue:function(e){return vt().memoizedState=e},useTransition:function(){var e=ju(!1),t=e[0];return e=Pm.bind(null,e[1]),vt().memoizedState=e,[t,e]},useMutableSource:function(){},useSyncExternalStore:function(e,t,n){var r=ue,l=vt();if(ie){if(n===void 0)throw Error(L(407));n=n()}else{if(n=t(),Ee===null)throw Error(L(349));Cn&30||Af(r,t,n)}l.memoizedState=n;var o={value:n,getSnapshot:t};return l.queue=o,Ru(Bf.bind(null,r,o,e),[e]),r.flags|=2048,Zr(9,Uf.bind(null,r,o,n,t),void 0,null),n},useId:function(){var e=vt(),t=Ee.identifierPrefix;if(ie){var n=Rt,r=jt;n=(r&~(1<<32-ct(r)-1)).toString(32)+n,t=":"+t+"R"+n,n=Gr++,0<\/script>",e=e.removeChild(e.firstChild)):typeof r.is=="string"?e=i.createElement(n,{is:r.is}):(e=i.createElement(n),n==="select"&&(i=e,r.multiple?i.multiple=!0:r.size&&(i.size=r.size))):e=i.createElementNS(e,n),e[yt]=t,e[Kr]=r,fd(e,t,!1,!1),t.stateNode=e;e:{switch(i=Di(n,r),n){case"dialog":le("cancel",e),le("close",e),l=r;break;case"iframe":case"object":case"embed":le("load",e),l=r;break;case"video":case"audio":for(l=0;lar&&(t.flags|=128,r=!0,xr(o,!1),t.lanes=4194304)}else{if(!r)if(e=po(i),e!==null){if(t.flags|=128,r=!0,n=e.updateQueue,n!==null&&(t.updateQueue=n,t.flags|=4),xr(o,!0),o.tail===null&&o.tailMode==="hidden"&&!i.alternate&&!ie)return Te(t),null}else 2*me()-o.renderingStartTime>ar&&n!==1073741824&&(t.flags|=128,r=!0,xr(o,!1),t.lanes=4194304);o.isBackwards?(i.sibling=t.child,t.child=i):(n=o.last,n!==null?n.sibling=i:t.child=i,o.last=i)}return o.tail!==null?(t=o.tail,o.rendering=t,o.tail=t.sibling,o.renderingStartTime=me(),t.sibling=null,n=ae.current,ne(ae,r?n&1|2:n&1),t):(Te(t),null);case 22:case 23:return ca(),r=t.memoizedState!==null,e!==null&&e.memoizedState!==null!==r&&(t.flags|=8192),r&&t.mode&1?be&1073741824&&(Te(t),t.subtreeFlags&6&&(t.flags|=8192)):Te(t),null;case 24:return null;case 25:return null}throw Error(L(156,t.tag))}function Am(e,t){switch(Vs(t),t.tag){case 1:return We(t.type)&&oo(),e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 3:return ir(),oe(He),oe(Me),qs(),e=t.flags,e&65536&&!(e&128)?(t.flags=e&-65537|128,t):null;case 5:return Zs(t),null;case 13:if(oe(ae),e=t.memoizedState,e!==null&&e.dehydrated!==null){if(t.alternate===null)throw Error(L(340));lr()}return e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 19:return oe(ae),null;case 4:return ir(),null;case 10:return Ys(t.type._context),null;case 22:case 23:return ca(),null;case 24:return null;default:return null}}var Tl=!1,$e=!1,Um=typeof WeakSet=="function"?WeakSet:Set,I=null;function Yn(e,t){var n=e.ref;if(n!==null)if(typeof n=="function")try{n(null)}catch(r){de(e,t,r)}else n.current=null}function fs(e,t,n){try{n()}catch(r){de(e,t,r)}}var Bu=!1;function Bm(e,t){if(Yi=to,e=yf(),Hs(e)){if("selectionStart"in e)var n={start:e.selectionStart,end:e.selectionEnd};else e:{n=(n=e.ownerDocument)&&n.defaultView||window;var r=n.getSelection&&n.getSelection();if(r&&r.rangeCount!==0){n=r.anchorNode;var l=r.anchorOffset,o=r.focusNode;r=r.focusOffset;try{n.nodeType,o.nodeType}catch{n=null;break e}var i=0,a=-1,s=-1,u=0,p=0,v=e,y=null;t:for(;;){for(var S;v!==n||l!==0&&v.nodeType!==3||(a=i+l),v!==o||r!==0&&v.nodeType!==3||(s=i+r),v.nodeType===3&&(i+=v.nodeValue.length),(S=v.firstChild)!==null;)y=v,v=S;for(;;){if(v===e)break t;if(y===n&&++u===l&&(a=i),y===o&&++p===r&&(s=i),(S=v.nextSibling)!==null)break;v=y,y=v.parentNode}v=S}n=a===-1||s===-1?null:{start:a,end:s}}else n=null}n=n||{start:0,end:0}}else n=null;for(Ji={focusedElem:e,selectionRange:n},to=!1,I=t;I!==null;)if(t=I,e=t.child,(t.subtreeFlags&1028)!==0&&e!==null)e.return=t,I=e;else for(;I!==null;){t=I;try{var k=t.alternate;if(t.flags&1024)switch(t.tag){case 0:case 11:case 15:break;case 1:if(k!==null){var C=k.memoizedProps,_=k.memoizedState,h=t.stateNode,f=h.getSnapshotBeforeUpdate(t.elementType===t.type?C:st(t.type,C),_);h.__reactInternalSnapshotBeforeUpdate=f}break;case 3:var d=t.stateNode.containerInfo;d.nodeType===1?d.textContent="":d.nodeType===9&&d.documentElement&&d.removeChild(d.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(L(163))}}catch(E){de(t,t.return,E)}if(e=t.sibling,e!==null){e.return=t.return,I=e;break}I=t.return}return k=Bu,Bu=!1,k}function zr(e,t,n){var r=t.updateQueue;if(r=r!==null?r.lastEffect:null,r!==null){var l=r=r.next;do{if((l.tag&e)===e){var o=l.destroy;l.destroy=void 0,o!==void 0&&fs(t,n,o)}l=l.next}while(l!==r)}}function To(e,t){if(t=t.updateQueue,t=t!==null?t.lastEffect:null,t!==null){var n=t=t.next;do{if((n.tag&e)===e){var r=n.create;n.destroy=r()}n=n.next}while(n!==t)}}function ds(e){var t=e.ref;if(t!==null){var n=e.stateNode;switch(e.tag){case 5:e=n;break;default:e=n}typeof t=="function"?t(e):t.current=e}}function hd(e){var t=e.alternate;t!==null&&(e.alternate=null,hd(t)),e.child=null,e.deletions=null,e.sibling=null,e.tag===5&&(t=e.stateNode,t!==null&&(delete t[yt],delete t[Kr],delete t[Zi],delete t[Em],delete t[Cm])),e.stateNode=null,e.return=null,e.dependencies=null,e.memoizedProps=null,e.memoizedState=null,e.pendingProps=null,e.stateNode=null,e.updateQueue=null}function md(e){return e.tag===5||e.tag===3||e.tag===4}function Hu(e){e:for(;;){for(;e.sibling===null;){if(e.return===null||md(e.return))return null;e=e.return}for(e.sibling.return=e.return,e=e.sibling;e.tag!==5&&e.tag!==6&&e.tag!==18;){if(e.flags&2||e.child===null||e.tag===4)continue e;e.child.return=e,e=e.child}if(!(e.flags&2))return e.stateNode}}function ps(e,t,n){var r=e.tag;if(r===5||r===6)e=e.stateNode,t?n.nodeType===8?n.parentNode.insertBefore(e,t):n.insertBefore(e,t):(n.nodeType===8?(t=n.parentNode,t.insertBefore(e,n)):(t=n,t.appendChild(e)),n=n._reactRootContainer,n!=null||t.onclick!==null||(t.onclick=lo));else if(r!==4&&(e=e.child,e!==null))for(ps(e,t,n),e=e.sibling;e!==null;)ps(e,t,n),e=e.sibling}function hs(e,t,n){var r=e.tag;if(r===5||r===6)e=e.stateNode,t?n.insertBefore(e,t):n.appendChild(e);else if(r!==4&&(e=e.child,e!==null))for(hs(e,t,n),e=e.sibling;e!==null;)hs(e,t,n),e=e.sibling}var Ne=null,at=!1;function Vt(e,t,n){for(n=n.child;n!==null;)gd(e,t,n),n=n.sibling}function gd(e,t,n){if(wt&&typeof wt.onCommitFiberUnmount=="function")try{wt.onCommitFiberUnmount(Eo,n)}catch{}switch(n.tag){case 5:$e||Yn(n,t);case 6:var r=Ne,l=at;Ne=null,Vt(e,t,n),Ne=r,at=l,Ne!==null&&(at?(e=Ne,n=n.stateNode,e.nodeType===8?e.parentNode.removeChild(n):e.removeChild(n)):Ne.removeChild(n.stateNode));break;case 18:Ne!==null&&(at?(e=Ne,n=n.stateNode,e.nodeType===8?hi(e.parentNode,n):e.nodeType===1&&hi(e,n),Hr(e)):hi(Ne,n.stateNode));break;case 4:r=Ne,l=at,Ne=n.stateNode.containerInfo,at=!0,Vt(e,t,n),Ne=r,at=l;break;case 0:case 11:case 14:case 15:if(!$e&&(r=n.updateQueue,r!==null&&(r=r.lastEffect,r!==null))){l=r=r.next;do{var o=l,i=o.destroy;o=o.tag,i!==void 0&&(o&2||o&4)&&fs(n,t,i),l=l.next}while(l!==r)}Vt(e,t,n);break;case 1:if(!$e&&(Yn(n,t),r=n.stateNode,typeof r.componentWillUnmount=="function"))try{r.props=n.memoizedProps,r.state=n.memoizedState,r.componentWillUnmount()}catch(a){de(n,t,a)}Vt(e,t,n);break;case 21:Vt(e,t,n);break;case 22:n.mode&1?($e=(r=$e)||n.memoizedState!==null,Vt(e,t,n),$e=r):Vt(e,t,n);break;default:Vt(e,t,n)}}function Wu(e){var t=e.updateQueue;if(t!==null){e.updateQueue=null;var n=e.stateNode;n===null&&(n=e.stateNode=new Um),t.forEach(function(r){var l=Gm.bind(null,e,r);n.has(r)||(n.add(r),r.then(l,l))})}}function it(e,t){var n=t.deletions;if(n!==null)for(var r=0;rl&&(l=i),r&=~o}if(r=l,r=me()-r,r=(120>r?120:480>r?480:1080>r?1080:1920>r?1920:3e3>r?3e3:4320>r?4320:1960*Wm(r/1960))-r,10e?16:e,Gt===null)var r=!1;else{if(e=Gt,Gt=null,yo=0,X&6)throw Error(L(331));var l=X;for(X|=4,I=e.current;I!==null;){var o=I,i=o.child;if(I.flags&16){var a=o.deletions;if(a!==null){for(var s=0;sme()-aa?Sn(e,0):sa|=n),Ve(e,t)}function Cd(e,t){t===0&&(e.mode&1?(t=kl,kl<<=1,!(kl&130023424)&&(kl=4194304)):t=1);var n=Oe();e=Ft(e,t),e!==null&&(rl(e,t,n),Ve(e,n))}function Jm(e){var t=e.memoizedState,n=0;t!==null&&(n=t.retryLane),Cd(e,n)}function Gm(e,t){var n=0;switch(e.tag){case 13:var r=e.stateNode,l=e.memoizedState;l!==null&&(n=l.retryLane);break;case 19:r=e.stateNode;break;default:throw Error(L(314))}r!==null&&r.delete(t),Cd(e,n)}var Nd;Nd=function(e,t,n){if(e!==null)if(e.memoizedProps!==t.pendingProps||He.current)Be=!0;else{if(!(e.lanes&n)&&!(t.flags&128))return Be=!1,Om(e,t,n);Be=!!(e.flags&131072)}else Be=!1,ie&&t.flags&1048576&&jf(t,ao,t.index);switch(t.lanes=0,t.tag){case 2:var r=t.type;Wl(e,t),e=t.pendingProps;var l=rr(t,Me.current);er(t,n),l=ta(null,t,r,e,l,n);var o=na();return t.flags|=1,typeof l=="object"&&l!==null&&typeof l.render=="function"&&l.$$typeof===void 0?(t.tag=1,t.memoizedState=null,t.updateQueue=null,We(r)?(o=!0,io(t)):o=!1,t.memoizedState=l.state!==null&&l.state!==void 0?l.state:null,Gs(t),l.updater=Ro,t.stateNode=l,l._reactInternals=t,ls(t,r,e,n),t=ss(null,t,r,!0,o,n)):(t.tag=0,ie&&o&&Ws(t),Ie(null,t,l,n),t=t.child),t;case 16:r=t.elementType;e:{switch(Wl(e,t),e=t.pendingProps,l=r._init,r=l(r._payload),t.type=r,l=t.tag=Zm(r),e=st(r,e),l){case 0:t=is(null,t,r,e,n);break e;case 1:t=Du(null,t,r,e,n);break e;case 11:t=Iu(null,t,r,e,n);break e;case 14:t=Ou(null,t,r,st(r.type,e),n);break e}throw Error(L(306,r,""))}return t;case 0:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:st(r,l),is(e,t,r,l,n);case 1:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:st(r,l),Du(e,t,r,l,n);case 3:e:{if(ad(t),e===null)throw Error(L(387));r=t.pendingProps,o=t.memoizedState,l=o.element,Ff(e,t),fo(t,r,null,n);var i=t.memoizedState;if(r=i.element,o.isDehydrated)if(o={element:r,isDehydrated:!1,cache:i.cache,pendingSuspenseBoundaries:i.pendingSuspenseBoundaries,transitions:i.transitions},t.updateQueue.baseState=o,t.memoizedState=o,t.flags&256){l=sr(Error(L(423)),t),t=Au(e,t,r,n,l);break e}else if(r!==l){l=sr(Error(L(424)),t),t=Au(e,t,r,n,l);break e}else for(Qe=en(t.stateNode.containerInfo.firstChild),Ke=t,ie=!0,ut=null,n=Mf(t,null,r,n),t.child=n;n;)n.flags=n.flags&-3|4096,n=n.sibling;else{if(lr(),r===l){t=It(e,t,n);break e}Ie(e,t,r,n)}t=t.child}return t;case 5:return If(t),e===null&&ts(t),r=t.type,l=t.pendingProps,o=e!==null?e.memoizedProps:null,i=l.children,Gi(r,l)?i=null:o!==null&&Gi(r,o)&&(t.flags|=32),sd(e,t),Ie(e,t,i,n),t.child;case 6:return e===null&&ts(t),null;case 13:return ud(e,t,n);case 4:return Xs(t,t.stateNode.containerInfo),r=t.pendingProps,e===null?t.child=or(t,null,r,n):Ie(e,t,r,n),t.child;case 11:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:st(r,l),Iu(e,t,r,l,n);case 7:return Ie(e,t,t.pendingProps,n),t.child;case 8:return Ie(e,t,t.pendingProps.children,n),t.child;case 12:return Ie(e,t,t.pendingProps.children,n),t.child;case 10:e:{if(r=t.type._context,l=t.pendingProps,o=t.memoizedProps,i=l.value,ne(uo,r._currentValue),r._currentValue=i,o!==null)if(dt(o.value,i)){if(o.children===l.children&&!He.current){t=It(e,t,n);break e}}else for(o=t.child,o!==null&&(o.return=t);o!==null;){var a=o.dependencies;if(a!==null){i=o.child;for(var s=a.firstContext;s!==null;){if(s.context===r){if(o.tag===1){s=Tt(-1,n&-n),s.tag=2;var u=o.updateQueue;if(u!==null){u=u.shared;var p=u.pending;p===null?s.next=s:(s.next=p.next,p.next=s),u.pending=s}}o.lanes|=n,s=o.alternate,s!==null&&(s.lanes|=n),ns(o.return,n,t),a.lanes|=n;break}s=s.next}}else if(o.tag===10)i=o.type===t.type?null:o.child;else if(o.tag===18){if(i=o.return,i===null)throw Error(L(341));i.lanes|=n,a=i.alternate,a!==null&&(a.lanes|=n),ns(i,n,t),i=o.sibling}else i=o.child;if(i!==null)i.return=o;else for(i=o;i!==null;){if(i===t){i=null;break}if(o=i.sibling,o!==null){o.return=i.return,i=o;break}i=i.return}o=i}Ie(e,t,l.children,n),t=t.child}return t;case 9:return l=t.type,r=t.pendingProps.children,er(t,n),l=rt(l),r=r(l),t.flags|=1,Ie(e,t,r,n),t.child;case 14:return r=t.type,l=st(r,t.pendingProps),l=st(r.type,l),Ou(e,t,r,l,n);case 15:return od(e,t,t.type,t.pendingProps,n);case 17:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:st(r,l),Wl(e,t),t.tag=1,We(r)?(e=!0,io(t)):e=!1,er(t,n),nd(t,r,l),ls(t,r,l,n),ss(null,t,r,!0,e,n);case 19:return cd(e,t,n);case 22:return id(e,t,n)}throw Error(L(156,t.tag))};function _d(e,t){return Zc(e,t)}function Xm(e,t,n,r){this.tag=e,this.key=n,this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null,this.index=0,this.ref=null,this.pendingProps=t,this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null,this.mode=r,this.subtreeFlags=this.flags=0,this.deletions=null,this.childLanes=this.lanes=0,this.alternate=null}function tt(e,t,n,r){return new Xm(e,t,n,r)}function da(e){return e=e.prototype,!(!e||!e.isReactComponent)}function Zm(e){if(typeof e=="function")return da(e)?1:0;if(e!=null){if(e=e.$$typeof,e===Ts)return 11;if(e===$s)return 14}return 2}function ln(e,t){var n=e.alternate;return n===null?(n=tt(e.tag,t,e.key,e.mode),n.elementType=e.elementType,n.type=e.type,n.stateNode=e.stateNode,n.alternate=e,e.alternate=n):(n.pendingProps=t,n.type=e.type,n.flags=0,n.subtreeFlags=0,n.deletions=null),n.flags=e.flags&14680064,n.childLanes=e.childLanes,n.lanes=e.lanes,n.child=e.child,n.memoizedProps=e.memoizedProps,n.memoizedState=e.memoizedState,n.updateQueue=e.updateQueue,t=e.dependencies,n.dependencies=t===null?null:{lanes:t.lanes,firstContext:t.firstContext},n.sibling=e.sibling,n.index=e.index,n.ref=e.ref,n}function Ql(e,t,n,r,l,o){var i=2;if(r=e,typeof e=="function")da(e)&&(i=1);else if(typeof e=="string")i=5;else e:switch(e){case An:return xn(n.children,l,o,t);case Rs:i=8,l|=8;break;case Pi:return e=tt(12,n,t,l|2),e.elementType=Pi,e.lanes=o,e;case ji:return e=tt(13,n,t,l),e.elementType=ji,e.lanes=o,e;case Ri:return e=tt(19,n,t,l),e.elementType=Ri,e.lanes=o,e;case Fc:return Mo(n,l,o,t);default:if(typeof e=="object"&&e!==null)switch(e.$$typeof){case Mc:i=10;break e;case zc:i=9;break e;case Ts:i=11;break e;case $s:i=14;break e;case bt:i=16,r=null;break e}throw Error(L(130,e==null?e:typeof e,""))}return t=tt(i,n,t,l),t.elementType=e,t.type=r,t.lanes=o,t}function xn(e,t,n,r){return e=tt(7,e,r,t),e.lanes=n,e}function Mo(e,t,n,r){return e=tt(22,e,r,t),e.elementType=Fc,e.lanes=n,e.stateNode={isHidden:!1},e}function ki(e,t,n){return e=tt(6,e,null,t),e.lanes=n,e}function Ei(e,t,n){return t=tt(4,e.children!==null?e.children:[],e.key,t),t.lanes=n,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function qm(e,t,n,r,l){this.tag=t,this.containerInfo=e,this.finishedWork=this.pingCache=this.current=this.pendingChildren=null,this.timeoutHandle=-1,this.callbackNode=this.pendingContext=this.context=null,this.callbackPriority=0,this.eventTimes=ri(0),this.expirationTimes=ri(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=ri(0),this.identifierPrefix=r,this.onRecoverableError=l,this.mutableSourceEagerHydrationData=null}function pa(e,t,n,r,l,o,i,a,s){return e=new qm(e,t,n,a,s),t===1?(t=1,o===!0&&(t|=8)):t=0,o=tt(3,null,null,t),e.current=o,o.stateNode=e,o.memoizedState={element:r,isDehydrated:n,cache:null,transitions:null,pendingSuspenseBoundaries:null},Gs(o),e}function eg(e,t,n){var r=3"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(Rd)}catch(e){console.error(e)}}Rd(),jc.exports=Je;var Td=jc.exports,$d,Xu=Td;$d=Xu.createRoot,Xu.hydrateRoot;/** - * react-router v7.8.2 - * - * Copyright (c) Remix Software Inc. - * - * This source code is licensed under the MIT license found in the - * LICENSE.md file in the root directory of this source tree. - * - * @license MIT - */var Zu="popstate";function og(e={}){function t(l,o){let{pathname:i="/",search:a="",hash:s=""}=jn(l.location.hash.substring(1));return!i.startsWith("/")&&!i.startsWith(".")&&(i="/"+i),ws("",{pathname:i,search:a,hash:s},o.state&&o.state.usr||null,o.state&&o.state.key||"default")}function n(l,o){let i=l.document.querySelector("base"),a="";if(i&&i.getAttribute("href")){let s=l.location.href,u=s.indexOf("#");a=u===-1?s:s.slice(0,u)}return a+"#"+(typeof o=="string"?o:el(o))}function r(l,o){pt(l.pathname.charAt(0)==="/",`relative pathnames are not supported in hash history.push(${JSON.stringify(o)})`)}return sg(t,n,r,e)}function ce(e,t){if(e===!1||e===null||typeof e>"u")throw new Error(t)}function pt(e,t){if(!e){typeof console<"u"&&console.warn(t);try{throw new Error(t)}catch{}}}function ig(){return Math.random().toString(36).substring(2,10)}function qu(e,t){return{usr:e.state,key:e.key,idx:t}}function ws(e,t,n=null,r){return{pathname:typeof e=="string"?e:e.pathname,search:"",hash:"",...typeof t=="string"?jn(t):t,state:n,key:t&&t.key||r||ig()}}function el({pathname:e="/",search:t="",hash:n=""}){return t&&t!=="?"&&(e+=t.charAt(0)==="?"?t:"?"+t),n&&n!=="#"&&(e+=n.charAt(0)==="#"?n:"#"+n),e}function jn(e){let t={};if(e){let n=e.indexOf("#");n>=0&&(t.hash=e.substring(n),e=e.substring(0,n));let r=e.indexOf("?");r>=0&&(t.search=e.substring(r),e=e.substring(0,r)),e&&(t.pathname=e)}return t}function sg(e,t,n,r={}){let{window:l=document.defaultView,v5Compat:o=!1}=r,i=l.history,a="POP",s=null,u=p();u==null&&(u=0,i.replaceState({...i.state,idx:u},""));function p(){return(i.state||{idx:null}).idx}function v(){a="POP";let _=p(),h=_==null?null:_-u;u=_,s&&s({action:a,location:C.location,delta:h})}function y(_,h){a="PUSH";let f=ws(C.location,_,h);n&&n(f,_),u=p()+1;let d=qu(f,u),E=C.createHref(f);try{i.pushState(d,"",E)}catch(P){if(P instanceof DOMException&&P.name==="DataCloneError")throw P;l.location.assign(E)}o&&s&&s({action:a,location:C.location,delta:1})}function S(_,h){a="REPLACE";let f=ws(C.location,_,h);n&&n(f,_),u=p();let d=qu(f,u),E=C.createHref(f);i.replaceState(d,"",E),o&&s&&s({action:a,location:C.location,delta:0})}function k(_){return ag(_)}let C={get action(){return a},get location(){return e(l,i)},listen(_){if(s)throw new Error("A history only accepts one active listener");return l.addEventListener(Zu,v),s=_,()=>{l.removeEventListener(Zu,v),s=null}},createHref(_){return t(l,_)},createURL:k,encodeLocation(_){let h=k(_);return{pathname:h.pathname,search:h.search,hash:h.hash}},push:y,replace:S,go(_){return i.go(_)}};return C}function ag(e,t=!1){let n="http://localhost";typeof window<"u"&&(n=window.location.origin!=="null"?window.location.origin:window.location.href),ce(n,"No window.location.(origin|href) available to create URL");let r=typeof e=="string"?e:el(e);return r=r.replace(/ $/,"%20"),!t&&r.startsWith("//")&&(r=n+r),new URL(r,n)}function Md(e,t,n="/"){return ug(e,t,n,!1)}function ug(e,t,n,r){let l=typeof t=="string"?jn(t):t,o=Ot(l.pathname||"/",n);if(o==null)return null;let i=zd(e);cg(i);let a=null;for(let s=0;a==null&&s{let p={relativePath:u===void 0?i.path||"":u,caseSensitive:i.caseSensitive===!0,childrenIndex:a,route:i};if(p.relativePath.startsWith("/")){if(!p.relativePath.startsWith(r)&&s)return;ce(p.relativePath.startsWith(r),`Absolute route path "${p.relativePath}" nested under path "${r}" is not valid. An absolute child route path must start with the combined path of all its parent routes.`),p.relativePath=p.relativePath.slice(r.length)}let v=$t([r,p.relativePath]),y=n.concat(p);i.children&&i.children.length>0&&(ce(i.index!==!0,`Index routes must not have child routes. Please remove all child routes from route path "${v}".`),zd(i.children,t,y,v,s)),!(i.path==null&&!i.index)&&t.push({path:v,score:vg(v,i.index),routesMeta:y})};return e.forEach((i,a)=>{var s;if(i.path===""||!((s=i.path)!=null&&s.includes("?")))o(i,a);else for(let u of Fd(i.path))o(i,a,!0,u)}),t}function Fd(e){let t=e.split("/");if(t.length===0)return[];let[n,...r]=t,l=n.endsWith("?"),o=n.replace(/\?$/,"");if(r.length===0)return l?[o,""]:[o];let i=Fd(r.join("/")),a=[];return a.push(...i.map(s=>s===""?o:[o,s].join("/"))),l&&a.push(...i),a.map(s=>e.startsWith("/")&&s===""?"/":s)}function cg(e){e.sort((t,n)=>t.score!==n.score?n.score-t.score:yg(t.routesMeta.map(r=>r.childrenIndex),n.routesMeta.map(r=>r.childrenIndex)))}var fg=/^:[\w-]+$/,dg=3,pg=2,hg=1,mg=10,gg=-2,ec=e=>e==="*";function vg(e,t){let n=e.split("/"),r=n.length;return n.some(ec)&&(r+=gg),t&&(r+=pg),n.filter(l=>!ec(l)).reduce((l,o)=>l+(fg.test(o)?dg:o===""?hg:mg),r)}function yg(e,t){return e.length===t.length&&e.slice(0,-1).every((r,l)=>r===t[l])?e[e.length-1]-t[t.length-1]:0}function wg(e,t,n=!1){let{routesMeta:r}=e,l={},o="/",i=[];for(let a=0;a{if(p==="*"){let k=a[y]||"";i=o.slice(0,o.length-k.length).replace(/(.)\/+$/,"$1")}const S=a[y];return v&&!S?u[p]=void 0:u[p]=(S||"").replace(/%2F/g,"/"),u},{}),pathname:o,pathnameBase:i,pattern:e}}function Sg(e,t=!1,n=!0){pt(e==="*"||!e.endsWith("*")||e.endsWith("/*"),`Route path "${e}" will be treated as if it were "${e.replace(/\*$/,"/*")}" because the \`*\` character must always follow a \`/\` in the pattern. To get rid of this warning, please change the route path to "${e.replace(/\*$/,"/*")}".`);let r=[],l="^"+e.replace(/\/*\*?$/,"").replace(/^\/*/,"/").replace(/[\\.*+^${}|()[\]]/g,"\\$&").replace(/\/:([\w-]+)(\?)?/g,(i,a,s)=>(r.push({paramName:a,isOptional:s!=null}),s?"/?([^\\/]+)?":"/([^\\/]+)")).replace(/\/([\w-]+)\?(\/|$)/g,"(/$1)?$2");return e.endsWith("*")?(r.push({paramName:"*"}),l+=e==="*"||e==="/*"?"(.*)$":"(?:\\/(.+)|\\/*)$"):n?l+="\\/*$":e!==""&&e!=="/"&&(l+="(?:(?=\\/|$))"),[new RegExp(l,t?void 0:"i"),r]}function xg(e){try{return e.split("/").map(t=>decodeURIComponent(t).replace(/\//g,"%2F")).join("/")}catch(t){return pt(!1,`The URL path "${e}" could not be decoded because it is a malformed URL segment. This is probably due to a bad percent encoding (${t}).`),e}}function Ot(e,t){if(t==="/")return e;if(!e.toLowerCase().startsWith(t.toLowerCase()))return null;let n=t.endsWith("/")?t.length-1:t.length,r=e.charAt(n);return r&&r!=="/"?null:e.slice(n)||"/"}function kg(e,t="/"){let{pathname:n,search:r="",hash:l=""}=typeof e=="string"?jn(e):e;return{pathname:n?n.startsWith("/")?n:Eg(n,t):t,search:_g(r),hash:Lg(l)}}function Eg(e,t){let n=t.replace(/\/+$/,"").split("/");return e.split("/").forEach(l=>{l===".."?n.length>1&&n.pop():l!=="."&&n.push(l)}),n.length>1?n.join("/"):"/"}function Ci(e,t,n,r){return`Cannot include a '${e}' character in a manually specified \`to.${t}\` field [${JSON.stringify(r)}]. Please separate it out to the \`to.${n}\` field. Alternatively you may provide the full path as a string in and the router will parse it for you.`}function Cg(e){return e.filter((t,n)=>n===0||t.route.path&&t.route.path.length>0)}function Id(e){let t=Cg(e);return t.map((n,r)=>r===t.length-1?n.pathname:n.pathnameBase)}function Od(e,t,n,r=!1){let l;typeof e=="string"?l=jn(e):(l={...e},ce(!l.pathname||!l.pathname.includes("?"),Ci("?","pathname","search",l)),ce(!l.pathname||!l.pathname.includes("#"),Ci("#","pathname","hash",l)),ce(!l.search||!l.search.includes("#"),Ci("#","search","hash",l)));let o=e===""||l.pathname==="",i=o?"/":l.pathname,a;if(i==null)a=n;else{let v=t.length-1;if(!r&&i.startsWith("..")){let y=i.split("/");for(;y[0]==="..";)y.shift(),v-=1;l.pathname=y.join("/")}a=v>=0?t[v]:"/"}let s=kg(l,a),u=i&&i!=="/"&&i.endsWith("/"),p=(o||i===".")&&n.endsWith("/");return!s.pathname.endsWith("/")&&(u||p)&&(s.pathname+="/"),s}var $t=e=>e.join("/").replace(/\/\/+/g,"/"),Ng=e=>e.replace(/\/+$/,"").replace(/^\/*/,"/"),_g=e=>!e||e==="?"?"":e.startsWith("?")?e:"?"+e,Lg=e=>!e||e==="#"?"":e.startsWith("#")?e:"#"+e;function Pg(e){return e!=null&&typeof e.status=="number"&&typeof e.statusText=="string"&&typeof e.internal=="boolean"&&"data"in e}var Dd=["POST","PUT","PATCH","DELETE"];new Set(Dd);var jg=["GET",...Dd];new Set(jg);var dr=g.createContext(null);dr.displayName="DataRouter";var Do=g.createContext(null);Do.displayName="DataRouterState";g.createContext(!1);var Ad=g.createContext({isTransitioning:!1});Ad.displayName="ViewTransition";var Rg=g.createContext(new Map);Rg.displayName="Fetchers";var Tg=g.createContext(null);Tg.displayName="Await";var xt=g.createContext(null);xt.displayName="Navigation";var sl=g.createContext(null);sl.displayName="Location";var At=g.createContext({outlet:null,matches:[],isDataRoute:!1});At.displayName="Route";var va=g.createContext(null);va.displayName="RouteError";function $g(e,{relative:t}={}){ce(al(),"useHref() may be used only in the context of a component.");let{basename:n,navigator:r}=g.useContext(xt),{hash:l,pathname:o,search:i}=ul(e,{relative:t}),a=o;return n!=="/"&&(a=o==="/"?n:$t([n,o])),r.createHref({pathname:a,search:i,hash:l})}function al(){return g.useContext(sl)!=null}function Rn(){return ce(al(),"useLocation() may be used only in the context of a component."),g.useContext(sl).location}var Ud="You should call navigate() in a React.useEffect(), not when your component is first rendered.";function Bd(e){g.useContext(xt).static||g.useLayoutEffect(e)}function Mg(){let{isDataRoute:e}=g.useContext(At);return e?Qg():zg()}function zg(){ce(al(),"useNavigate() may be used only in the context of a component.");let e=g.useContext(dr),{basename:t,navigator:n}=g.useContext(xt),{matches:r}=g.useContext(At),{pathname:l}=Rn(),o=JSON.stringify(Id(r)),i=g.useRef(!1);return Bd(()=>{i.current=!0}),g.useCallback((s,u={})=>{if(pt(i.current,Ud),!i.current)return;if(typeof s=="number"){n.go(s);return}let p=Od(s,JSON.parse(o),l,u.relative==="path");e==null&&t!=="/"&&(p.pathname=p.pathname==="/"?t:$t([t,p.pathname])),(u.replace?n.replace:n.push)(p,u.state,u)},[t,n,o,l,e])}g.createContext(null);function ul(e,{relative:t}={}){let{matches:n}=g.useContext(At),{pathname:r}=Rn(),l=JSON.stringify(Id(n));return g.useMemo(()=>Od(e,JSON.parse(l),r,t==="path"),[e,l,r,t])}function Fg(e,t){return Hd(e,t)}function Hd(e,t,n,r,l){var f;ce(al(),"useRoutes() may be used only in the context of a component.");let{navigator:o}=g.useContext(xt),{matches:i}=g.useContext(At),a=i[i.length-1],s=a?a.params:{},u=a?a.pathname:"/",p=a?a.pathnameBase:"/",v=a&&a.route;{let d=v&&v.path||"";Wd(u,!v||d.endsWith("*")||d.endsWith("*?"),`You rendered descendant (or called \`useRoutes()\`) at "${u}" (under ) but the parent route path has no trailing "*". This means if you navigate deeper, the parent won't match anymore and therefore the child routes will never render. - -Please change the parent to .`)}let y=Rn(),S;if(t){let d=typeof t=="string"?jn(t):t;ce(p==="/"||((f=d.pathname)==null?void 0:f.startsWith(p)),`When overriding the location using \`\` or \`useRoutes(routes, location)\`, the location pathname must begin with the portion of the URL pathname that was matched by all parent routes. The current pathname base is "${p}" but pathname "${d.pathname}" was given in the \`location\` prop.`),S=d}else S=y;let k=S.pathname||"/",C=k;if(p!=="/"){let d=p.replace(/^\//,"").split("/");C="/"+k.replace(/^\//,"").split("/").slice(d.length).join("/")}let _=Md(e,{pathname:C});pt(v||_!=null,`No routes matched location "${S.pathname}${S.search}${S.hash}" `),pt(_==null||_[_.length-1].route.element!==void 0||_[_.length-1].route.Component!==void 0||_[_.length-1].route.lazy!==void 0,`Matched leaf route at location "${S.pathname}${S.search}${S.hash}" does not have an element or Component. This means it will render an with a null value by default resulting in an "empty" page.`);let h=Ug(_&&_.map(d=>Object.assign({},d,{params:Object.assign({},s,d.params),pathname:$t([p,o.encodeLocation?o.encodeLocation(d.pathname).pathname:d.pathname]),pathnameBase:d.pathnameBase==="/"?p:$t([p,o.encodeLocation?o.encodeLocation(d.pathnameBase).pathname:d.pathnameBase])})),i,n,r,l);return t&&h?g.createElement(sl.Provider,{value:{location:{pathname:"/",search:"",hash:"",state:null,key:"default",...S},navigationType:"POP"}},h):h}function Ig(){let e=bg(),t=Pg(e)?`${e.status} ${e.statusText}`:e instanceof Error?e.message:JSON.stringify(e),n=e instanceof Error?e.stack:null,r="rgba(200,200,200, 0.5)",l={padding:"0.5rem",backgroundColor:r},o={padding:"2px 4px",backgroundColor:r},i=null;return console.error("Error handled by React Router default ErrorBoundary:",e),i=g.createElement(g.Fragment,null,g.createElement("p",null,"💿 Hey developer 👋"),g.createElement("p",null,"You can provide a way better UX than this when your app throws errors by providing your own ",g.createElement("code",{style:o},"ErrorBoundary")," or"," ",g.createElement("code",{style:o},"errorElement")," prop on your route.")),g.createElement(g.Fragment,null,g.createElement("h2",null,"Unexpected Application Error!"),g.createElement("h3",{style:{fontStyle:"italic"}},t),n?g.createElement("pre",{style:l},n):null,i)}var Og=g.createElement(Ig,null),Dg=class extends g.Component{constructor(e){super(e),this.state={location:e.location,revalidation:e.revalidation,error:e.error}}static getDerivedStateFromError(e){return{error:e}}static getDerivedStateFromProps(e,t){return t.location!==e.location||t.revalidation!=="idle"&&e.revalidation==="idle"?{error:e.error,location:e.location,revalidation:e.revalidation}:{error:e.error!==void 0?e.error:t.error,location:t.location,revalidation:e.revalidation||t.revalidation}}componentDidCatch(e,t){this.props.unstable_onError?this.props.unstable_onError(e,t):console.error("React Router caught the following error during render",e)}render(){return this.state.error!==void 0?g.createElement(At.Provider,{value:this.props.routeContext},g.createElement(va.Provider,{value:this.state.error,children:this.props.component})):this.props.children}};function Ag({routeContext:e,match:t,children:n}){let r=g.useContext(dr);return r&&r.static&&r.staticContext&&(t.route.errorElement||t.route.ErrorBoundary)&&(r.staticContext._deepestRenderedBoundaryId=t.route.id),g.createElement(At.Provider,{value:e},n)}function Ug(e,t=[],n=null,r=null,l=null){if(e==null){if(!n)return null;if(n.errors)e=n.matches;else if(t.length===0&&!n.initialized&&n.matches.length>0)e=n.matches;else return null}let o=e,i=n==null?void 0:n.errors;if(i!=null){let u=o.findIndex(p=>p.route.id&&(i==null?void 0:i[p.route.id])!==void 0);ce(u>=0,`Could not find a matching route for errors on route IDs: ${Object.keys(i).join(",")}`),o=o.slice(0,Math.min(o.length,u+1))}let a=!1,s=-1;if(n)for(let u=0;u=0?o=o.slice(0,s+1):o=[o[0]];break}}}return o.reduceRight((u,p,v)=>{let y,S=!1,k=null,C=null;n&&(y=i&&p.route.id?i[p.route.id]:void 0,k=p.route.errorElement||Og,a&&(s<0&&v===0?(Wd("route-fallback",!1,"No `HydrateFallback` element provided to render during initial hydration"),S=!0,C=null):s===v&&(S=!0,C=p.route.hydrateFallbackElement||null)));let _=t.concat(o.slice(0,v+1)),h=()=>{let f;return y?f=k:S?f=C:p.route.Component?f=g.createElement(p.route.Component,null):p.route.element?f=p.route.element:f=u,g.createElement(Ag,{match:p,routeContext:{outlet:u,matches:_,isDataRoute:n!=null},children:f})};return n&&(p.route.ErrorBoundary||p.route.errorElement||v===0)?g.createElement(Dg,{location:n.location,revalidation:n.revalidation,component:k,error:y,children:h(),routeContext:{outlet:null,matches:_,isDataRoute:!0},unstable_onError:r}):h()},null)}function ya(e){return`${e} must be used within a data router. See https://reactrouter.com/en/main/routers/picking-a-router.`}function Bg(e){let t=g.useContext(dr);return ce(t,ya(e)),t}function Hg(e){let t=g.useContext(Do);return ce(t,ya(e)),t}function Wg(e){let t=g.useContext(At);return ce(t,ya(e)),t}function wa(e){let t=Wg(e),n=t.matches[t.matches.length-1];return ce(n.route.id,`${e} can only be used on routes that contain a unique "id"`),n.route.id}function Vg(){return wa("useRouteId")}function bg(){var r;let e=g.useContext(va),t=Hg("useRouteError"),n=wa("useRouteError");return e!==void 0?e:(r=t.errors)==null?void 0:r[n]}function Qg(){let{router:e}=Bg("useNavigate"),t=wa("useNavigate"),n=g.useRef(!1);return Bd(()=>{n.current=!0}),g.useCallback(async(l,o={})=>{pt(n.current,Ud),n.current&&(typeof l=="number"?e.navigate(l):await e.navigate(l,{fromRouteId:t,...o}))},[e,t])}var tc={};function Wd(e,t,n){!t&&!tc[e]&&(tc[e]=!0,pt(!1,n))}g.memo(Kg);function Kg({routes:e,future:t,state:n,unstable_onError:r}){return Hd(e,void 0,n,r,t)}function Vd(e){ce(!1,"A is only ever to be used as the child of element, never rendered directly. Please wrap your in a .")}function Yg({basename:e="/",children:t=null,location:n,navigationType:r="POP",navigator:l,static:o=!1}){ce(!al(),"You cannot render a inside another . You should never have more than one in your app.");let i=e.replace(/^\/*/,"/"),a=g.useMemo(()=>({basename:i,navigator:l,static:o,future:{}}),[i,l,o]);typeof n=="string"&&(n=jn(n));let{pathname:s="/",search:u="",hash:p="",state:v=null,key:y="default"}=n,S=g.useMemo(()=>{let k=Ot(s,i);return k==null?null:{location:{pathname:k,search:u,hash:p,state:v,key:y},navigationType:r}},[i,s,u,p,v,y,r]);return pt(S!=null,` is not able to match the URL "${s}${u}${p}" because it does not start with the basename, so the won't render anything.`),S==null?null:g.createElement(xt.Provider,{value:a},g.createElement(sl.Provider,{children:t,value:S}))}function Jg({children:e,location:t}){return Fg(Ss(e),t)}function Ss(e,t=[]){let n=[];return g.Children.forEach(e,(r,l)=>{if(!g.isValidElement(r))return;let o=[...t,l];if(r.type===g.Fragment){n.push.apply(n,Ss(r.props.children,o));return}ce(r.type===Vd,`[${typeof r.type=="string"?r.type:r.type.name}] is not a component. All component children of must be a or `),ce(!r.props.index||!r.props.children,"An index route cannot have child routes.");let i={id:r.props.id||o.join("-"),caseSensitive:r.props.caseSensitive,element:r.props.element,Component:r.props.Component,index:r.props.index,path:r.props.path,loader:r.props.loader,action:r.props.action,hydrateFallbackElement:r.props.hydrateFallbackElement,HydrateFallback:r.props.HydrateFallback,errorElement:r.props.errorElement,ErrorBoundary:r.props.ErrorBoundary,hasErrorBoundary:r.props.hasErrorBoundary===!0||r.props.ErrorBoundary!=null||r.props.errorElement!=null,shouldRevalidate:r.props.shouldRevalidate,handle:r.props.handle,lazy:r.props.lazy};r.props.children&&(i.children=Ss(r.props.children,o)),n.push(i)}),n}var Kl="get",Yl="application/x-www-form-urlencoded";function Ao(e){return e!=null&&typeof e.tagName=="string"}function Gg(e){return Ao(e)&&e.tagName.toLowerCase()==="button"}function Xg(e){return Ao(e)&&e.tagName.toLowerCase()==="form"}function Zg(e){return Ao(e)&&e.tagName.toLowerCase()==="input"}function qg(e){return!!(e.metaKey||e.altKey||e.ctrlKey||e.shiftKey)}function ev(e,t){return e.button===0&&(!t||t==="_self")&&!qg(e)}var zl=null;function tv(){if(zl===null)try{new FormData(document.createElement("form"),0),zl=!1}catch{zl=!0}return zl}var nv=new Set(["application/x-www-form-urlencoded","multipart/form-data","text/plain"]);function Ni(e){return e!=null&&!nv.has(e)?(pt(!1,`"${e}" is not a valid \`encType\` for \`
\`/\`\` and will default to "${Yl}"`),null):e}function rv(e,t){let n,r,l,o,i;if(Xg(e)){let a=e.getAttribute("action");r=a?Ot(a,t):null,n=e.getAttribute("method")||Kl,l=Ni(e.getAttribute("enctype"))||Yl,o=new FormData(e)}else if(Gg(e)||Zg(e)&&(e.type==="submit"||e.type==="image")){let a=e.form;if(a==null)throw new Error('Cannot submit a `,k=`
${y}
`;return`
${S}${k}
`}),i=i.replace(/
\s*(?=
]*>[\s\S]*?<\/div>)\s*
/g,"$1"),i}function ry(e){const t=e.split(/\r?\n/);let n=null;for(let r=0;r/i,n=/<\/think(?:ing)?>/i,r=e.match(t);if(!r)return{think:null,answer:e};const l=r.index,o=r[0].length,i=e.substring(0,l).trim();let a=e.substring(l+o);const s=a.match(n);let u=null,p=i;return s?(u=a.substring(0,s.index).trim(),p+=a.substring(s.index+s[0].length)):u=a.trim(),{think:u||null,answer:p.trim()}}function ly({content:e,streamOutput:t,sources:n}){const{think:r,answer:l}=ep(e||""),[o,i]=Fe.useState(!1),a=!!r;return m.jsxs("div",{className:"assistant-message",children:[a&&m.jsxs("div",{className:"assistant-thoughts",children:[m.jsxs("button",{className:"think-toggle",onClick:()=>i(s=>!s),"aria-expanded":o?"true":"false","aria-controls":"think-content",children:[m.jsx("span",{className:"think-toggle-icon","aria-hidden":"true",children:o?"▾":"▸"}),"Thoughts"]}),o&&m.jsx("div",{id:"think-content",className:"think-content",dangerouslySetInnerHTML:{__html:hc(r)}})]}),m.jsx("div",{className:"msg-content",dangerouslySetInnerHTML:{__html:hc(l||e||"")}}),Array.isArray(n)&&n.length>0&&m.jsx("div",{className:"msg-sources chips",children:n.map((s,u)=>{let p=s,v=!1;try{const y=new URL(s);if(y.protocol==="file:"){v=!0;const S=y.pathname.split("/").filter(Boolean);p=decodeURIComponent(S[S.length-1]||s)}else p=(y.hostname||s).replace(/^www\./i,"")}catch{}return m.jsx("a",{className:"chip",href:s,target:"_blank",rel:"noreferrer",title:s,onClick:y=>{var S,k;if(v){y.preventDefault();try{const C=new URL(s);(k=(S=window.electronAPI)==null?void 0:S.openPath)==null||k.call(S,decodeURIComponent(C.pathname))}catch{}}},children:p},s+u)})})]})}const mc="websearch.searxUrl",gc="websearch.engines",vc="chat.libraryBySession";let tp="http://127.0.0.1:8000";const oy=48,iy=24;function sy(e){return e.backendApiUrl||e.ollamaApiUrl||tp}function ay(){var Ha;const[e,t]=g.useState([]),[n,r]=g.useState(null),[l,o]=g.useState("chats"),[i,a]=g.useState("General"),[s,u]=g.useState(null),[p,v]=g.useState(null),[y,S]=g.useState([]),[k,C]=g.useState([]),[_,h]=g.useState(null),[f,d]=g.useState(()=>{try{const c=localStorage.getItem(vc);return c?JSON.parse(c):{}}catch{return{}}}),[E,P]=g.useState(!1),[T,M]=g.useState(""),[F,B]=g.useState(""),[D,ee]=g.useState(!1),[H,K]=g.useState(""),[pe,j]=g.useState(""),O=g.useRef(null),G=g.useRef(null),R=g.useRef(null),[z,V]=g.useState(tp),[te,ge]=g.useState("Default"),[kt,ht]=g.useState(!1),[Et,Ct]=g.useState(localStorage.getItem(mc)||"http://localhost:8888"),[Xe,np]=g.useState(()=>{try{const c=localStorage.getItem(gc);if(c)return JSON.parse(c)}catch{}return["duckduckgo","bing","wikipedia","github","stack_overflow"]});g.useEffect(()=>{localStorage.setItem(mc,Et||"")},[Et]),g.useEffect(()=>{try{localStorage.setItem(gc,JSON.stringify(Xe||[]))}catch{}},[Xe]);const[cl,rp]=g.useState(!1),[Ut,Uo]=g.useState(!1),[fy,Bo]=g.useState(!0),[lp,Tn]=g.useState([]),[fl,Ea]=g.useState({}),[op,Ho]=g.useState(null),[Wo,dl]=g.useState("");function ip(c){const w=c.content||"";if(c.role==="assistant")try{const{answer:x}=ep(w);return(x||w).trim()}catch{return w.trim()}return w}async function Ca(c){try{await navigator.clipboard.writeText(ip(c))}catch(w){console.error("Failed to copy message:",w)}}function fn(c,w,x,N={}){const{removeIfEmpty:$=!1}=N;t(A=>A.map(W=>{if(W.session_id!==c)return W;const U=[];for(const b of W.messages||[]){if(b.id!==w){U.push(b);continue}$&&!x||U.push({...b,content:x})}return{...W,messages:U}}))}function Bt(c){return(c==null?void 0:c.name)==="AbortError"}function Vo(c){return c instanceof Error&&c.message?c.message:String(c)}async function Na(c,w,x){if(!c)return{contextBlock:null,sources:[]};const $=await(await fetch(`${z}/libraries/${c}/context`,{method:"POST",headers:{"Content-Type":"application/json"},signal:x,body:JSON.stringify({prompt:w,top_k:5})})).json();return{contextBlock:typeof($==null?void 0:$.context_block)=="string"&&$.context_block.trim()?$.context_block.trim():null,sources:Array.isArray($==null?void 0:$.sources)?$.sources:[]}}function sp(c,w){Ho(c),dl(w||"")}function pl(){Ho(null),dl("")}async function ap(c){var A;const w=(((A=Fn[c])==null?void 0:A.content)||"").trim(),N=(Wo??"").trim();if(N.length===0){pl();return}if(N===w){pl();return}const $=n;if($){t(W=>W.map(U=>{if(U.session_id!==$)return U;const je=(U.messages||[]).slice(0,c+1).map((we,Ze)=>Ze===c?{...we,content:N}:we);return{...U,messages:je}})),Ho(null),dl(""),requestAnimationFrame(()=>Go("auto",$));try{const W=await fetch(`${z}/sessions/${$}/messages/${c}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({message:N})});if(!W.ok)throw new Error(`HTTP ${W.status}`)}catch(W){console.error("Failed to update message:",W),t(U=>U.map(b=>{if(b.session_id!==$)return b;const we=(b.messages||[]).map((Ze,Q)=>Q===c?{...Ze,content:w}:Ze);return{...b,messages:we}}));return}await _a(c,N)}}async function _a(c,w=null){var je,we,Ze,Q,he,Ce;const x=n;if(Ut||!x||typeof c!="number")return;const N=((je=e.find(Z=>Z.session_id===x))==null?void 0:je.messages)||[];let $=c;for(let Z=c;Z>=0;Z--)if(((we=N[Z])==null?void 0:we.role)==="user"){$=Z;break}t(Z=>Z.map(se=>se.session_id===x?{...se,messages:(se.messages||[]).slice(0,$+1)}:se));const A=$a(x);let W=w??(((Ze=N[$])==null?void 0:Ze.content)||""),U=[];const b=[];try{const Z=Ia(x),se=w??(((Q=N[$])==null?void 0:Q.content)||"");if((he=Z==null?void 0:Z.states)!=null&&he.is_indexed)try{const Y=await Na(Z.slug,se,A.signal);Y.contextBlock&&b.push(Y.contextBlock),Array.isArray(Y.sources)&&U.push(...Y.sources)}catch(Y){if(Bt(Y))throw Y;console.warn("local library enrichment (regenerate) failed",Y)}if(cl)try{const Y=N.slice(Math.max(0,$-7),$+1).map(ve=>({role:ve.role,content:ve.content||""}));Y.length>0&&(Y[Y.length-1]={role:"user",content:se});const re=await(await fetch(`${z}/websearch`,{method:"POST",headers:{"Content-Type":"application/json"},signal:A.signal,body:JSON.stringify({prompt:se,model:H,messages:Y,history_limit:8,searx_url:Et||null,engines:Array.isArray(Xe)?Xe:null})})).json();re&&typeof re.context_block=="string"&&re.context_block.trim()&&b.push(re.context_block.trim()),Array.isArray(re==null?void 0:re.sources)&&U.push(...re.sources)}catch(Y){if(Bt(Y))throw Y;console.warn("web search enrichment (regenerate) failed",Y)}if(U=[...new Set(U)],b.length>0?W=`${se} - -${b.join(` - -`)}`:W=null,kt){const Y=`msg-${Date.now()}-${Math.random()}`;let _t="";t(re=>re.map(ve=>ve.session_id===x?{...ve,messages:[...ve.messages||[],{id:Y,role:"assistant",content:"",sources:U}]}:ve));try{const re=await fetch(`${z}/sessions/${x}/regenerate`,{method:"POST",headers:{"Content-Type":"application/json"},signal:A.signal,body:JSON.stringify({index:c,model:H,stream:!0,enriched_message:W,sources:U||[]})});if(!re.ok)throw new Error(`HTTP ${re.status}`);const ve=(Ce=re.body)==null?void 0:Ce.getReader();if(!ve)throw new Error("Missing response body");const Wt=new TextDecoder;let mt=!1;for(;;){const{value:hn,done:Tp}=await ve.read();if(Tp)break;const $p=Wt.decode(hn,{stream:!0});_t+=$p,fn(x,Y,_t),!mt&&Pe.current!==x&&(mt=!0,dn(Xo=>({...Xo,[x]:Y})),Tn(Xo=>[...new Set([...Xo,x])]))}Pe.current!==x?(dn(hn=>({...hn,[x]:Y})),Tn(hn=>[...new Set([...hn,x])])):$n.current[x]?Mn(hn=>({...hn,[x]:Y})):requestAnimationFrame(()=>In(Y,"smooth",x))}catch(re){if(Bt(re)){fn(x,Y,_t,{removeIfEmpty:!0});return}console.error(re),fn(x,Y,`Error: ${Vo(re)}`,{removeIfEmpty:!0});return}}else{const Y=await fetch(`${z}/sessions/${x}/regenerate`,{method:"POST",headers:{"Content-Type":"application/json"},signal:A.signal,body:JSON.stringify({index:c,model:H,stream:!1,enriched_message:W,sources:U||[]})});if(!Y.ok)throw new Error(`HTTP ${Y.status}`);const _t=await Y.json(),re=`msg-${Date.now()}`;t(ve=>ve.map(Wt=>Wt.session_id===x?{...Wt,messages:[...Wt.messages||[],{role:"assistant",content:_t.reply,id:re,sources:U}]}:Wt)),Pe.current!==x?(dn(ve=>({...ve,[x]:re})),Tn(ve=>[...new Set([...ve,x])])):$n.current[x]?Mn(ve=>({...ve,[x]:re})):requestAnimationFrame(()=>In(re,"smooth",x))}}catch(Z){Bt(Z)||console.error(Z)}finally{bo(A)}}const[La,up]=g.useState({}),$n=g.useRef({}),[cp,dn]=g.useState({}),pn=g.useRef({}),Pa=g.useRef({}),[ja,Mn]=g.useState({}),[fp,Ra]=g.useState({}),Ta=(c,w,x)=>c!=null&&c.id?c.id:`${x}:${w}`;g.useEffect(()=>{var w;if(!n)return;const c=((w=e.find(x=>x.session_id===n))==null?void 0:w.messages)||[];Ra(x=>{const N={};return c.forEach(($,A)=>{if($.role!=="user")return;const W=Ta($,A,n),b=($.content||"").split(/\r\n|\r|\n/).length>30;N[W]=b?x[W]??!0:!1}),N})},[e,n]);function dp(c){Ra(w=>({...w,[c]:!(w[c]??!0)}))}const pr=Fe.useCallback((c,w)=>{up(x=>{const N={...x,[c]:w};return $n.current=N,N})},[]),zn=g.useRef(null),pp=g.useRef(!1),hp=g.useRef(null),Pe=g.useRef(n);g.useEffect(()=>{Pe.current=n},[n]);const $a=Fe.useCallback(c=>{const w=new AbortController;return zn.current={controller:w,sessionId:c},Uo(!0),w},[]),bo=Fe.useCallback(c=>{var w;((w=zn.current)==null?void 0:w.controller)===c&&(zn.current=null,Uo(!1))},[]),mp=Fe.useCallback(()=>{const c=zn.current;c&&(zn.current=null,c.controller.abort(),Uo(!1))},[]);g.useEffect(()=>()=>{var c;(c=zn.current)==null||c.controller.abort()},[]);const Ht=g.useRef(null),[gp,vp]=g.useState(230),[hl,Ma]=g.useState(!1),yp=Fe.useCallback(c=>{Ma(!0)},[]),Qo=Fe.useCallback(()=>{Ma(!1)},[]),Ko=Fe.useCallback(c=>{if(hl){const w=Math.max(230,Math.min(500,c.clientX));vp(w)}},[hl]);Fe.useEffect(()=>(window.addEventListener("mousemove",Ko),window.addEventListener("mouseup",Qo),()=>{window.removeEventListener("mousemove",Ko),window.removeEventListener("mouseup",Qo)}),[Ko,Qo]),Fe.useEffect(()=>{hl?document.body.classList.add("no-select"):document.body.classList.remove("no-select")},[hl]),Fe.useEffect(()=>{const c=async w=>{const x=w.target.closest(".codeblock__copy");if(!x)return;const N=x.closest(".codeblock"),$=N==null?void 0:N.querySelector("pre > code");if($)try{await navigator.clipboard.writeText($.textContent||""),x.classList.add("copied"),setTimeout(()=>x.classList.remove("copied"),800)}catch(A){console.error("Copy failed:",A)}};return document.addEventListener("click",c),()=>document.removeEventListener("click",c)},[]),g.useEffect(()=>{window.electronAPI.getSettings().then(w=>{V(sy(w)),ge(w.colorScheme||"Default"),K(w.chatModel||""),ht(w.streamOutput||!1),Ea(w.scrollPositions||{}),tl(w.colorScheme||"Default")});const c=()=>{var w;l==="chats"&&((w=G.current)==null||w.focus())};return window.electronAPI.onWindowFocus(c),()=>{}},[l]),g.useEffect(()=>{tl(te)},[te]);const wp=c=>{!c||!z||fetch(`${z}/history?session_id=${encodeURIComponent(c)}`).then(w=>w.json()).then(w=>{t(x=>x.map(N=>N.session_id===c?{...N,messages:w.messages||[]}:N))}).catch(()=>{})};async function hr(){if(z)try{const w=await(await fetch(`${z}/libraries`)).json(),x=Array.isArray(w.libraries)?w.libraries:[];if(S(x),x.length===0){h(null);return}x.some(N=>N.slug===_)||h(x[0].slug)}catch(c){console.warn("Failed to load libraries",c)}}async function ml(){if(z)try{const w=await(await fetch(`${z}/jobs`)).json();C(Array.isArray(w.jobs)?w.jobs:[])}catch(c){console.warn("Failed to load library jobs",c)}}async function za(c=null){const x=(typeof c=="string"?c:T).trim();if(!x){B("Name is required.");return}try{B("");const N=await fetch(`${z}/libraries`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:x})});if(!N.ok){const A=await N.text();throw new Error(A||`HTTP ${N.status}`)}const $=await N.json();P(!1),M(""),await hr(),$!=null&&$.slug&&h($.slug)}catch(N){console.error("Failed to create library",N),B(String((N==null?void 0:N.message)||N))}}async function Sp(){S([]),C([]),h(null),v(null),ee(!1),d({}),await hr(),await ml()}g.useEffect(()=>{z&&(Bo(!0),fetch(`${z}/sessions`).then(c=>c.json()).then(c=>{const w=c.sessions.map(x=>({...x,messages:[]}));t(w),w.length>0?r(w[0].session_id):r(null),Bo(!1)}).catch(()=>{Bo(!1)}))},[z]),g.useEffect(()=>{z&&(hr(),ml())},[z]),g.useEffect(()=>{try{localStorage.setItem(vc,JSON.stringify(f||{}))}catch{}},[f]),g.useEffect(()=>{if(!z)return;const c=setInterval(()=>{hr(),ml()},3e3);return()=>clearInterval(c)},[z,l,_]),g.useEffect(()=>{wp(n)},[n,z]),g.useEffect(()=>{const c=new Set(y.map(w=>w.slug));d(w=>{let x=!1;const N={};for(const[$,A]of Object.entries(w||{}))c.has(A)?N[$]=A:x=!0;return x?N:w})},[y]);const Yo=c=>{o(c)},xp=c=>{_p(c)},Fn=g.useMemo(()=>{var c;return((c=e.find(w=>w.session_id===n))==null?void 0:c.messages)||[]},[n,e]),gl=g.useMemo(()=>y.find(c=>c.slug===_)||null,[_,y]),Nt=n&&f[n]||null,ot=g.useMemo(()=>y.find(c=>c.slug===Nt)||null,[Nt,y]),Fa=g.useMemo(()=>Nt?k.some(c=>c.slug===Nt&&(c.status==="queued"||c.status==="running")):!1,[Nt,k]),Jo=g.useMemo(()=>{var c,w;return ot?(c=ot.files)!=null&&c.length?(w=ot.states)!=null&&w.is_indexed?"":Fa?" (syncing)":" (needs sync)":" (empty)":""},[ot,Fa]);function kp(c){return c&&f[c]||null}function Ia(c){const w=kp(c);return w&&y.find(x=>x.slug===w)||null}function Oa(c){return c?k.some(w=>w.slug===c&&(w.status==="queued"||w.status==="running")):!1}function Da(c,w){c&&d(x=>{const N={...x||{}};return w?N[c]=w:delete N[c],N})}function Ep(c){c&&d(w=>{let x=!1;const N={};for(const[$,A]of Object.entries(w||{})){if(A===c){x=!0;continue}N[$]=A}return x?N:w})}g.useEffect(()=>{if(!D)return;const c=w=>{var x;(x=R.current)!=null&&x.contains(w.target)||ee(!1)};return document.addEventListener("mousedown",c),()=>document.removeEventListener("mousedown",c)},[D]),g.useEffect(()=>{ee(!1)},[n,l]),g.useEffect(()=>{const c=n,w=l;return()=>{if(w==="chats"&&c){const x=typeof pn.current[c]=="number"?pn.current[c]:O.current?O.current.scrollTop:0;Ea(N=>{const $={...N,[c]:x};return window.electronAPI.updateSettings({scrollPositions:$}),$})}}},[n,l]),g.useEffect(()=>{const c=O.current;if(!c)return;const w=()=>{const{scrollTop:x,scrollHeight:N,clientHeight:$}=c,A=N-x-$<=iy;if(n){const W=Pa.current[n],U=typeof W=="number"&&xc.removeEventListener("scroll",w)},[n,pr]),g.useEffect(()=>{const c=n;c&&La[c]===!1&&Mn(w=>{if(!(c in w))return w;const x={...w};return delete x[c],x})},[n,La]),g.useLayoutEffect(()=>{if(l!=="chats"||!n)return;const c=O.current;if(!c)return;Ht.current=null;const w=()=>{if(Ht.current===n)return;const W=typeof pn.current[n]=="number"?pn.current[n]:void 0,U=typeof W=="number"?W:fl[n];if(typeof U=="number"){c.scrollTop=U,Ht.current=n;return}Fn.length>0&&(c.scrollTop=c.scrollHeight,Ht.current=n)};w();const x=requestAnimationFrame(w),N=()=>{Ht.current!==n&&requestAnimationFrame(w)},$=new MutationObserver(N);$.observe(c,{childList:!0,subtree:!0});const A=new ResizeObserver(N);return A.observe(c),()=>{cancelAnimationFrame(x),$.disconnect(),A.disconnect()}},[n,l,Fn.length,fl]),g.useEffect(()=>{if(l!=="chats"||!n||Ht.current===n)return;const c=typeof pn.current[n]=="number"?pn.current[n]:void 0;typeof(typeof c=="number"?c:fl[n])!="number"&&Fn.length>0&&requestAnimationFrame(()=>{const x=O.current;x&&(x.scrollTop=x.scrollHeight,Ht.current=n)})},[Fn.length,n,l,fl]);const Go=(c="smooth",w=null)=>{const x=O.current;if(!x)return;const N=w??Pe.current;Pe.current===N&&(x.scrollTo({top:x.scrollHeight,behavior:c}),pr(N,!1))},In=(c,w="auto",x=null)=>{const N=O.current;if(!N)return;const $=x??Pe.current;if(Pe.current!==$)return;const A=document.getElementById(c);if(A){const W=Math.max(0,A.offsetTop-oy);N.scrollTo({top:W,behavior:w})}},Cp=()=>{const c=Pe.current,w=ja[c];w&&(In(w,"smooth",c),Mn(x=>{const{[c]:N,...$}=x;return $}))};async function Aa(){var $,A,W;if(Ut||!pe.trim()||!H)return;let c=n,w=!1;if(c){const U=e.find(b=>b.session_id===c);w=U&&U.name==="New Chat"&&U.messages.length===0}else{const U=await Ua();await new Promise(b=>setTimeout(b,200)),c=U.session_id,w=!0}const x={role:"user",content:pe.trim(),id:`msg-${Date.now()}-${Math.random()}`};pp.current=!0,hp.current=c,pr(c,!1),Pe.current===c&&(Ht.current=Pe.current),Td.flushSync(()=>{t(U=>U.map(b=>b.session_id===c?{...b,messages:[...b.messages||[],x]}:b)),j("")}),requestAnimationFrame(()=>Go("auto",c));const N=$a(c);try{let U=[];try{U=[...((($=e.find(Ce=>Ce.session_id===c))==null?void 0:$.messages)||[]).slice(-8).map(Ce=>({role:Ce.role,content:Ce.content||""})),{role:"user",content:x.content}]}catch{}let b=x.content,je=[];const we=[],Ze=Ia(c);if((A=Ze==null?void 0:Ze.states)!=null&&A.is_indexed)try{const Q=await Na(Ze.slug,x.content,N.signal);Q.contextBlock&&we.push(Q.contextBlock),Array.isArray(Q.sources)&&je.push(...Q.sources)}catch(Q){if(Bt(Q))throw Q;console.warn("local library enrichment failed",Q)}if(cl)try{const he=await(await fetch(`${z}/websearch`,{method:"POST",headers:{"Content-Type":"application/json"},signal:N.signal,body:JSON.stringify({prompt:x.content,model:H,messages:U,history_limit:8,searx_url:Et||null,engines:Array.isArray(Xe)?Xe:null})})).json();he&&typeof he.context_block=="string"&&he.context_block.trim()&&we.push(he.context_block.trim()),Array.isArray(he==null?void 0:he.sources)&&je.push(...he.sources)}catch(Q){if(Bt(Q))throw Q;console.warn("web search enrichment failed",Q)}if(je=[...new Set(je)],we.length>0&&(b=`${x.content} - -${we.join(` - -`)}`),kt){const Q=`msg-${Date.now()}-${Math.random()}`;let he="";const Ce={role:"assistant",content:"",id:Q,sources:je};t(Z=>Z.map(se=>se.session_id===c?{...se,messages:[...se.messages||[],Ce]}:se));try{const Z=await fetch(`${z}/chat`,{method:"POST",headers:{"Content-Type":"application/json"},signal:N.signal,body:JSON.stringify({session_id:c,model:H,message:x.content,enriched_message:we.length>0?b:null,stream:!0,sources:je||[]})});if(!Z.ok)throw new Error(`HTTP ${Z.status}`);const se=(W=Z.body)==null?void 0:W.getReader();if(!se)throw new Error("Missing response body");const Y=new TextDecoder;let _t=!1;for(;;){const{value:re,done:ve}=await se.read();if(ve){fn(c,Q,he),Pe.current===c?$n.current[c]?Mn(mt=>({...mt,[c]:Q})):requestAnimationFrame(()=>In(Q,"smooth",c)):(dn(mt=>({...mt,[c]:Q})),Tn(mt=>[...new Set([...mt,c])]));break}const Wt=Y.decode(re,{stream:!0});he+=Wt,fn(c,Q,he),Pe.current===c&&!$n.current[c]&&Go("auto",c),Pe.current!==c&&!_t&&(dn(mt=>({...mt,[c]:Q})),_t=!0)}}catch(Z){if(Bt(Z)){fn(c,Q,he,{removeIfEmpty:!0});return}console.error("Failed to send message:",Z),fn(c,Q,"Error: "+Vo(Z),{removeIfEmpty:!0});return}}else{const Q=await fetch(`${z}/chat`,{method:"POST",headers:{"Content-Type":"application/json"},signal:N.signal,body:JSON.stringify({session_id:c,model:H,message:x.content,enriched_message:we.length>0?b:null,stream:!1,sources:je||[]})});if(!Q.ok)throw new Error(`HTTP ${Q.status}`);const he=await Q.json(),Ce=`msg-${Date.now()}`,Z={role:"assistant",content:he.reply,id:Ce,sources:je};t(se=>se.map(Y=>Y.session_id===c?{...Y,messages:[...Y.messages||[],Z]}:Y)),Ce&&(Pe.current===c?$n.current[c]?Mn(se=>({...se,[c]:Ce})):requestAnimationFrame(()=>In(Ce,"smooth",c)):dn(se=>({...se,[c]:Ce})))}Pe.current!==c&&Tn(Q=>[...new Set([...Q,c])]),w&&fetch(`${z}/generate-title`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({session_id:c,message:x.content,model:H})}).then(Q=>Q.json()).then(Q=>{const he=Q.title.replace(/[\s\S]*?<\/think(?:ing)?>/i,"").trim();t(Ce=>Ce.map(Z=>Z.session_id===c?{...Z,name:he}:Z))})}catch(U){if(Bt(U)){bo(N);return}console.error("Failed to send message:",U);const b={role:"assistant",content:"Error: "+Vo(U),id:`msg-${Date.now()}-${Math.random()}`};t(je=>je.map(we=>we.session_id===c?{...we,messages:[...we.messages,b]}:we))}finally{bo(N)}}function Np(){rp(c=>!c)}async function Ua(){var $;const c="sess-"+Math.random().toString(36).slice(2)+Date.now().toString(36),x=await(await fetch(`${z}/sessions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({session_id:c})})).json(),N={...x,messages:[]};return t(A=>[N,...A]),r(x.session_id),($=G.current)==null||$.focus(),x}function _p(c){r(c),Tn(x=>x.filter(N=>N!==c));const w=cp[c];w&&requestAnimationFrame(()=>{let x=12;const N=()=>{if(!O.current)return;let A=document.getElementById(w);if(!A){const W=e.find(U=>U.session_id===c);if(W&&Array.isArray(W.messages))for(let U=W.messages.length-1;U>=0;U--){const b=W.messages[U];if(b.role==="assistant"&&b.id){A=document.getElementById(b.id);break}}}A?(In(A.id,"smooth",c),dn(W=>{const{[c]:U,...b}=W;return b})):x-- >0&&requestAnimationFrame(N)};requestAnimationFrame(N)})}function Lp(c,w){fetch(`${z}/sessions/${c}/rename`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({title:w})}).then(()=>{t(x=>x.map(N=>N.session_id===c?{...N,name:w}:N)),u(null)})}function Pp(c,w){const x=(w||"").trim(),N=y.find($=>$.slug===c);if(!N){v(null);return}if(!x||x===N.name){v(null);return}fetch(`${z}/libraries/${c}`,{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:x})}).then(()=>{S($=>$.map(A=>A.slug===c?{...A,name:x}:A)),v(null)})}function Ba(c){fetch(`${z}/sessions/${c}`,{method:"DELETE"}).then(()=>{const w=e.filter(x=>x.session_id!==c);t(w),d(x=>{const N={...x||{}};return delete N[c],N}),n===c&&r(w.length>0?w[0].session_id:null)})}function jp(c){fetch(`${z}/libraries/${c}`,{method:"DELETE"}).then(async w=>{var N;if(!w.ok){const $=await w.text();throw new Error($||`HTTP ${w.status}`)}const x=y.filter($=>$.slug!==c);S(x),C($=>$.filter(A=>A.slug!==c)),v($=>$===c?null:$),_===c&&h(((N=x[0])==null?void 0:N.slug)||null),Ep(c)}).catch(w=>{console.error("Failed to delete library",w)})}g.useEffect(()=>{const c=e.filter(w=>w.name==="New Chat"&&w.session_id!==n&&w.messages.length===0);c.length>0&&c.forEach(w=>{Ba(w.session_id)})},[n,e,z]);const Rp=c=>{var x;window.getSelection().toString().length>0||document.activeElement!==G.current&&(c.target.closest(".msg")||(x=G.current)==null||x.focus())};return m.jsxs("div",{className:"app",style:{gridTemplateColumns:`${gp}px 1fr`},children:[m.jsxs("div",{className:"sidebar",children:[m.jsxs("div",{className:"sidebar-header",children:[m.jsx("div",{className:`sidebar-tab ${l==="chats"?"active":""}`,onClick:()=>Yo("chats"),children:"Chats"}),m.jsx("div",{className:`sidebar-tab ${l==="dbs"?"active":""}`,onClick:()=>Yo("dbs"),children:"DBs"}),m.jsx("div",{className:`sidebar-tab ${l==="settings"?"active":""}`,onClick:()=>Yo("settings"),children:"Settings"})]}),m.jsxs("div",{className:"sidebar-content",children:[l==="chats"&&m.jsx("div",{className:"chat-list",children:e.map(c=>m.jsx("div",{className:`chat-item ${c.session_id===n?"active":""}`,onClick:()=>xp(c.session_id),children:s===c.session_id?m.jsx("input",{type:"text",className:"rename-input",defaultValue:c.name,onBlur:()=>u(null),onKeyDown:w=>{w.key==="Enter"?Lp(c.session_id,w.target.value):w.key==="Escape"&&u(null)},autoFocus:!0}):m.jsxs(m.Fragment,{children:[m.jsx("span",{children:c.name}),m.jsxs("div",{className:"chat-item-buttons",children:[lp.includes(c.session_id)&&m.jsx("div",{className:"unread-dot"}),m.jsx("button",{className:"icon-button",onClick:w=>{w.stopPropagation(),u(c.session_id)},children:m.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"feather feather-edit-2",children:m.jsx("path",{d:"M17 3a2.828 2.828 0 1 1 4 4L7.5 20.5 2 22l1.5-5.5L17 3z"})})}),m.jsx("button",{className:"icon-button",onClick:w=>{w.stopPropagation(),Ba(c.session_id)},children:m.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"feather feather-x",children:[m.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),m.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]})]})},c.session_id))}),l==="dbs"&&m.jsx("div",{className:"db-list",children:y.length===0?m.jsx("div",{className:"empty-list-message",children:"No databases yet."}):y.map(c=>m.jsx("div",{className:`chat-item ${c.slug===_?"active":""}`,onClick:()=>h(c.slug),children:p===c.slug?m.jsx("input",{type:"text",className:"rename-input",defaultValue:c.name,onBlur:()=>v(null),onKeyDown:w=>{w.key==="Enter"?Pp(c.slug,w.target.value):w.key==="Escape"&&v(null)},autoFocus:!0}):m.jsxs(m.Fragment,{children:[m.jsx("span",{children:c.name}),m.jsxs("div",{className:"chat-item-buttons",children:[Nt===c.slug&&m.jsx("div",{className:"db-active-badge",children:"Chat"}),Oa(c.slug)&&m.jsx("div",{className:"db-active-badge",children:"Syncing"}),m.jsx("button",{className:"icon-button",onClick:w=>{w.stopPropagation(),v(c.slug)},children:m.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"feather feather-edit-2",children:m.jsx("path",{d:"M17 3a2.828 2.828 0 1 1 4 4L7.5 20.5 2 22l1.5-5.5L17 3z"})})}),m.jsx("button",{className:"icon-button",onClick:w=>{w.stopPropagation(),jp(c.slug)},children:m.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"feather feather-x",children:[m.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),m.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]})]})},c.slug))}),l==="settings"&&m.jsxs("div",{className:"settings-list",children:[m.jsx("div",{className:`settings-item ${i==="General"?"active":""}`,onClick:()=>a("General"),children:"General"}),m.jsx("div",{className:`settings-item ${i==="Interface"?"active":""}`,onClick:()=>a("Interface"),children:"Interface"}),m.jsx("div",{className:`settings-item ${i==="Websearch"?"active":""}`,onClick:()=>a("Websearch"),children:"Websearch"})]})]}),l!=="settings"&&m.jsxs("div",{className:"sidebar-footer",children:[l==="chats"&&m.jsx("button",{className:"button new-chat-button",onClick:Ua,children:"New Chat"}),l==="dbs"&&(E?m.jsxs("div",{className:"new-db-form",children:[m.jsx("input",{type:"text",className:"rename-input",value:T,onChange:c=>M(c.target.value),onKeyDown:c=>{c.key==="Enter"?za():c.key==="Escape"&&(P(!1),M(""),B(""))},placeholder:"Database name",autoFocus:!0}),F&&m.jsx("div",{className:"form-error",children:F}),m.jsxs("div",{className:"new-db-actions",children:[m.jsx("button",{className:"button new-db-button",onClick:()=>za(),children:"Create"}),m.jsx("button",{className:"button ghost",onClick:()=>{P(!1),M(""),B("")},children:"Cancel"})]})]}):m.jsx("button",{className:"button new-db-button",onClick:()=>{P(!0),B("")},children:"New Database"}))]}),m.jsx("div",{className:"resizer",onMouseDown:yp})]}),m.jsxs("div",{className:"main-content",children:[l==="chats"&&m.jsxs(m.Fragment,{children:[m.jsxs("div",{className:"header",children:[m.jsxs("strong",{children:["Chat - ",((Ha=e.find(c=>c.session_id===n))==null?void 0:Ha.name)||"New Chat"]}),ot&&m.jsx("span",{className:"header-subtle",children:`DB: ${ot.name}${Jo}`})]}),m.jsx("div",{className:"chat",ref:O,onClick:Rp,children:Fn.map((c,w)=>{const x=c.role==="user"&&op===w;return m.jsx("div",{id:c.id,className:"msg "+(c.role==="user"?"user":"assistant")+(x?" editing":""),children:c.role==="assistant"?m.jsxs("div",{className:"assistant-message-wrapper",children:[m.jsx(ly,{content:c.content,streamOutput:kt,sources:c.sources}),!Ut&&m.jsxs("div",{className:"message-options-bar assistant-options",children:[m.jsx("button",{className:"icon-button",title:"Copy message",onClick:()=>Ca(c),children:m.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[m.jsx("rect",{x:"9",y:"9",width:"13",height:"13",rx:"2",ry:"2"}),m.jsx("path",{d:"M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"})]})}),m.jsx("button",{className:"icon-button",title:"Regenerate response",onClick:()=>_a(w),children:m.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:m.jsx("path",{d:"M21.5 2v6h-6M2.5 22v-6h6M2 11.5a10 10 0 0 1 18.8-4.3M22 12.5a10 10 0 0 1-18.8 4.3"})})})]})]}):m.jsxs("div",{className:"user-message-wrapper",children:[x?m.jsxs("div",{className:"msg-content msg-content--user editing",children:[m.jsx("div",{className:"user-edit-shadow","aria-hidden":"true",children:Wo}),m.jsx(ac,{className:"edit-message-input edit-overlay",value:Wo,onChange:N=>dl(N.target.value),onBlur:pl,onKeyDown:N=>{N.key==="Escape"&&(N.preventDefault(),pl()),N.key==="Enter"&&!N.shiftKey&&(N.preventDefault(),ap(w))},autoFocus:!0,minRows:1})]}):(()=>{const N=c.content||"",$=N.split(/\r\n|\r|\n/),A=$.length>30,W=Ta(c,w,n),U=A?fp[W]??!0:!1,b=U?$.slice(0,30).join(` -`)+` -…`:N;return m.jsxs(m.Fragment,{children:[m.jsx("div",{className:"msg-content msg-content--user",children:b}),A&&m.jsx("button",{className:"user-msg-expand",onClick:()=>dp(W),"aria-expanded":U?"false":"true",children:U?"Show entire message":"Collapse"})]})})(),!Ut&&!x&&m.jsxs("div",{className:"message-options-bar user-options",children:[m.jsx("button",{className:"icon-button",title:"Edit message",onClick:()=>sp(w,c.content),children:m.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[m.jsx("path",{d:"M12 20h9"}),m.jsx("path",{d:"M16.5 3.5a2.121 2.121 0 0 1 3 3L7 19l-4 1 1-4L16.5 3.5z"})]})}),m.jsx("button",{className:"icon-button",title:"Copy message",onClick:()=>Ca(c),children:m.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[m.jsx("rect",{x:"9",y:"9",width:"13",height:"13",rx:"2",ry:"2"}),m.jsx("path",{d:"M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"})]})})]})]})},c.id||w)})},n),ja[n]&&m.jsxs("button",{className:"new-msg-tip",onClick:Cp,title:"Jump to the new message","aria-label":"Jump to the new message",children:["New message",m.jsx("span",{style:{marginLeft:6},children:"↓"})]}),m.jsx("div",{className:"footer",children:m.jsxs("div",{className:"footer-content-wrapper",children:[m.jsx(ac,{ref:G,className:"input",value:pe,onChange:c=>j(c.target.value),onKeyDown:c=>{c.key==="Enter"&&!c.shiftKey&&(c.preventDefault(),Aa())},placeholder:"Ask any question...",maxRows:13}),m.jsxs("div",{className:"footer-tool-group",ref:R,children:[m.jsx("button",{type:"button",className:"db-picker-toggle"+(ot?" active":""),onClick:()=>{n&&ee(c=>!c)},title:ot?`Database: ${ot.name}${Jo}`:"Select database for this chat","aria-haspopup":"menu","aria-expanded":D,disabled:!n,children:m.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round","aria-hidden":"true",children:[m.jsx("ellipse",{cx:"12",cy:"5",rx:"8",ry:"3"}),m.jsx("path",{d:"M4 5v6c0 1.7 3.6 3 8 3s8-1.3 8-3V5"}),m.jsx("path",{d:"M4 11v6c0 1.7 3.6 3 8 3s8-1.3 8-3v-6"})]})}),D&&m.jsxs("div",{className:"db-picker-menu",role:"menu",children:[m.jsxs("button",{type:"button",className:"db-picker-option"+(Nt?"":" selected"),onClick:()=>{Da(n,null),ee(!1)},children:[m.jsx("span",{children:"No database"}),!Nt&&m.jsx("span",{className:"db-picker-status",children:"Selected"})]}),y.length===0?m.jsx("div",{className:"db-picker-empty",children:"No databases yet."}):y.map(c=>{var $,A,W;const w=Nt===c.slug,x=Oa(c.slug),N=($=c.files)!=null&&$.length?(A=c.states)!=null&&A.is_indexed?"Ready":x?"Syncing":"Needs sync":"Empty";return m.jsxs("button",{type:"button",className:"db-picker-option"+(w?" selected":""),disabled:!((W=c.files)!=null&&W.length),onClick:()=>{Da(n,c.slug),ee(!1)},children:[m.jsx("span",{children:c.name}),m.jsx("span",{className:"db-picker-status",children:w?"Selected":N})]},c.slug)})]})]}),m.jsx("button",{type:"button",className:"websearch-toggle"+(cl?" active":""),onClick:Np,title:"Toggle web search","aria-pressed":cl,children:m.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round","aria-hidden":"true",children:[m.jsx("circle",{cx:"12",cy:"12",r:"10"}),m.jsx("line",{x1:"2",y1:"12",x2:"22",y2:"12"}),m.jsx("path",{d:"M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"})]})}),m.jsx("button",{className:"button",onClick:Ut?mp:Aa,title:Ut?"Cancel generation":"Send","aria-label":Ut?"Cancel generation":"Send",children:Ut?m.jsx("div",{className:"spinner"}):"Send"})]})})]}),l==="dbs"&&m.jsxs(m.Fragment,{children:[m.jsxs("div",{className:"header",children:[m.jsx("strong",{children:(gl==null?void 0:gl.name)||"Databases"}),ot&&m.jsx("span",{className:"header-subtle",children:`Current chat DB: ${ot.name}${Jo}`})]}),m.jsx(ty,{apiBase:z,library:gl,jobs:k,onRefresh:async()=>{await hr(),await ml()}})]}),l==="settings"&&m.jsxs(m.Fragment,{children:[m.jsx("div",{className:"header",children:m.jsxs("strong",{children:[i," Settings"]})}),i==="General"&&m.jsx(Jv,{onModelChange:K,streamOutput:kt,onStreamOutputChange:ht,onLibrariesPurged:Sp}),i==="Interface"&&m.jsx(qv,{}),i==="Websearch"&&m.jsx(ny,{searxUrl:Et,setSearxUrl:Ct,engines:Xe,setEngines:np})]})]})]})}function uy(){return g.useEffect(()=>{window.electronAPI.getSettings().then(e=>{tl(e.colorScheme||"Default")})},[]),m.jsx(Fe.StrictMode,{children:m.jsx(yv,{children:m.jsx(Jg,{children:m.jsx(Vd,{path:"/",element:m.jsx(ay,{})})})})})}const cy=$d(document.getElementById("root"));cy.render(m.jsx(uy,{})); diff --git a/dist/assets/index-Cl_WYrJF.css b/dist/assets/index-Cl_WYrJF.css new file mode 100644 index 0000000..48be27f --- /dev/null +++ b/dist/assets/index-Cl_WYrJF.css @@ -0,0 +1 @@ +:root{--bg: #0b1020;--panel: #141b34;--text: #e6e8ef;--muted: #9aa3b2;--accent: #6ea8fe;--border: #24304f}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica,Arial}.no-select{-webkit-user-select:none;user-select:none;cursor:ew-resize!important}.app{display:grid;grid-template-columns:var(--sidebar-width, 230px) 1fr;grid-template-rows:1fr;height:100%}.sidebar{display:grid;grid-template-rows:auto 1fr auto;background:var(--panel);border-right:1px solid var(--border);height:100vh;overflow:hidden;position:relative}.sidebar span{font-size:14px}.resizer{width:13px;cursor:ew-resize;background:transparent;position:absolute;top:0;right:-5px;bottom:0;z-index:1}.sidebar-header{display:flex;justify-content:space-around;padding:0;background:var(--panel)}.sidebar-tab{flex-grow:1;text-align:center;padding:11px 16px;cursor:pointer;border-bottom:3px solid transparent;transition:background-color .2s ease}.sidebar-tab:hover{background-color:var(--hover-bg)}.sidebar-tab.active{background-color:var(--active-bg);border-bottom-color:var(--accent)}.sidebar-tab.active:hover{background-color:var(--active-bg)}.sidebar-content{flex-grow:1;overflow-y:auto}.db-list,.settings-list{padding:8px 0}.empty-list-message{padding:10px 16px;color:var(--muted);text-align:center}.settings-item{padding:10px 16px;cursor:pointer;border-left:3px solid transparent}.settings-item.active{background:var(--active-bg);border-left-color:var(--accent)}.settings-item.active:hover{background:var(--active-bg)}.settings-item:hover{background:var(--hover-bg)}.settings-footer-placeholder{height:40px;padding:12px 16px;border-top:1px solid var(--border);background:var(--panel)}.new-db-button{width:100%;padding:10px;background:var(--accent);border-color:var(--accent);color:var(--bg);font-weight:700}.new-db-button:hover{opacity:.9}.chat-list{overflow-y:auto;padding:8px 0}.chat-item{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;cursor:pointer;border-left:3px solid transparent;overflow:hidden;white-space:nowrap}.chat-item span{flex-grow:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-item-buttons{display:flex;gap:8px;align-items:center}.unread-dot{width:8px;height:8px;background-color:red;border-radius:50%;margin-right:4px}.icon-button{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;padding:0;display:flex;align-items:center;justify-content:center}.icon-button svg{width:16px;height:16px;stroke:var(--muted);transition:stroke .2s ease}.icon-button:hover svg{stroke:var(--accent)}.icon-button:hover{color:var(--accent)}.chat-item.active{background:var(--active-bg);border-left-color:var(--accent)}.chat-item:hover{background:var(--hover-bg)}.chat-item.active:hover{background:var(--active-bg)}.rename-input{background:var(--input-bg);border:1px solid var(--accent);color:var(--text);border-radius:10px;padding:8px 12px;outline:none;width:100%}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--muted);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}.sidebar-footer{padding:12px 16px;background:var(--panel)}.new-db-form,.library-inline-form{display:grid;gap:8px}.new-db-actions{display:flex;gap:8px}.form-error{color:#ff9aa8;font-size:12px}.new-chat-button{width:100%;padding:10px;background:var(--accent);border-color:var(--accent);color:var(--bg);font-weight:700}.new-chat-button:hover{opacity:.9}.main-content{position:relative;display:grid;grid-template-rows:auto 1fr auto;height:100vh;overflow:hidden}.header{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--panel)}.select,.input,.button{background:var(--input-bg);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:8px 12px;outline:none}.footer-content-wrapper .button{flex-shrink:0}.select{min-width:220px}.button{cursor:pointer}.button:hover{border-color:var(--accent)}.button.ghost{background:transparent}.button.danger{border-color:#8f3d49;color:#ffb8c2}.button.danger:hover{border-color:#d86a79}.header-subtle{color:var(--muted);font-size:13px}.chat{display:grid;grid-template-columns:1fr minmax(auto,1000px) 1fr;align-content:start;gap:8px;padding:16px;overflow:auto}.chat>*{grid-column:2}.msg{padding:12px 14px;border-radius:12px;line-height:1.5;white-space:wrap;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica,Arial}textarea.input{resize:none;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica,Arial;overflow-y:auto;flex-grow:1}.msg.user{background:var(--user-msg-bg);margin-left:auto;max-width:80%;border:1px solid var(--border);margin-right:5px;margin-bottom:15px;transition:border-color .15s ease,box-shadow .15s ease}.msg.user.editing{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 35%,transparent)}.msg.user .msg-content--user{white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;position:relative}.msg.user .user-msg-expand{margin-top:8px;padding:0;background:transparent;border:none;color:var(--muted);font-weight:700;cursor:pointer;align-self:flex-start;margin-left:0;text-align:left}.msg.assistant{background:transparent;border:none;max-width:none;animation:fadeIn .3s ease-in-out;margin-bottom:30px}.user-message-wrapper{display:flex;flex-direction:column;align-items:flex-end;position:relative}.assistant-message-wrapper{display:flex;flex-direction:column;align-items:flex-start;position:relative}.message-options-bar{display:flex;gap:2px;padding:0;border-radius:8px;background-color:transparent;border:none;position:absolute;bottom:-30px}.user-options{right:-10px;bottom:-40px}.assistant-options{left:0}.message-options-bar .icon-button{padding:4px;border-radius:4px;border:none}.message-options-bar .icon-button:hover{background-color:var(--hover-bg)}.new-msg-tip{position:absolute;right:24px;bottom:84px;padding:8px 12px;border-radius:9999px;background:var(--accent);color:var(--bg);border:none;cursor:pointer;font-weight:600;box-shadow:0 6px 20px #00000059}.new-msg-tip:hover{opacity:.9}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.footer{display:flex;justify-content:center;padding:12px 16px;border-top:1px solid var(--border);background:var(--panel);align-items:flex-end}.footer-content-wrapper{display:flex;gap:8px;width:100%;max-width:1000px;align-items:flex-end}.footer-tool-group{position:relative;display:inline-flex;align-items:center}.settings-content-panel{padding:20px;overflow-y:auto;height:100%}.settings-category{margin-bottom:30px}.settings-category h2{color:var(--accent);margin-bottom:15px;font-size:1.3em}.setting-section{margin-bottom:20px;padding:15px;border-bottom:1px solid var(--border);background-color:var(--panel);border-radius:8px}.setting-section:last-child{border-bottom:none;margin-bottom:0}.setting-section h3{color:var(--text);margin-top:0;margin-bottom:10px;font-size:1.1em}.settings-content-panel .input,.settings-content-panel .select{width:100%;max-width:400px;padding:10px 12px;border-radius:8px;border:1px solid var(--border);background-color:var(--input-bg);color:var(--text);font-size:1em}.settings-content-panel .select{min-width:unset}.setting-control-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.setting-switch-row{display:inline-flex;align-items:center;gap:12px;flex-wrap:wrap}.setting-switch-label{color:var(--muted);font-weight:600;letter-spacing:.01em;transition:color .2s ease}.setting-switch-label.active{color:var(--text)}.toggle-switch--binary-select .slider{background-color:var(--input-bg);border-color:var(--border)}.toggle-switch--binary-select .slider:before{background-color:var(--text)}.toggle-switch--binary-select input:checked+.slider{background-color:var(--input-bg);border-color:var(--border)}.toggle-switch--binary-select input:checked+.slider:before{background-color:var(--text)}.range-input{width:min(360px,100%);accent-color:var(--accent)}.setting-value{min-width:48px;color:var(--text);font-variant-numeric:tabular-nums}.setting-description{margin:10px 0 0;color:var(--muted);line-height:1.5}.setting-status{margin:12px 0 0;line-height:1.5}.setting-status.success{color:#8fd6a3}.setting-status.warning{color:#f1c97a}.setting-status.error{color:#ff9aa8}.setting-status.neutral{color:var(--text)}.setting-meta{margin-top:10px;display:grid;gap:4px;color:var(--muted);font-size:.95em}.msg h1,.msg h2,.msg h3,.msg h4{margin:10px 0;color:var(--accent)}.msg blockquote{border-left:4px solid var(--accent);padding-left:15px;margin-left:0;color:var(--muted)}.msg ul{padding-left:20px}.msg li{margin-bottom:5px}.msg code{background-color:var(--input-bg);padding:2px 4px;border-radius:4px;font-family:monospace}.msg pre{background-color:var(--input-bg);padding:10px;border-radius:8px;overflow-x:auto;white-space:pre-wrap}.msg pre code{padding:0;background-color:transparent}.msg a{color:var(--text);display:inline-flex;align-items:center;gap:4px;position:relative;text-decoration:underline dotted;text-underline-offset:3px}.msg a .tooltip{visibility:hidden;width:auto;background-color:var(--panel);color:var(--text);text-align:center;border-radius:6px;padding:5px 10px;position:absolute;z-index:1;bottom:110%;left:50%;transform:translate(-50%);opacity:0;transition:opacity .3s;white-space:nowrap}.msg a:hover .tooltip{visibility:visible;opacity:1}.msg a:hover{color:var(--accent)}.msg a svg{width:14px;height:14px;stroke:var(--text);transition:stroke .2s ease}.msg a:hover svg{stroke:var(--accent)}.msg hr{border:none;border-top:1px solid var(--border);margin:20px 0}:root{--outline-w: 1px;--grid-w: 1px;--grid: var(--border)}.msg table.nice{border-collapse:separate;border-spacing:0;width:100%;margin:1rem 0;border-radius:12px;box-shadow:0 0 0 var(--outline-w) var(--border)}.msg table.nice th,.msg table.nice td{border:var(--grid-w) solid var(--grid);border-width:.5px;padding:.6rem .75rem;vertical-align:top}.msg table.nice thead tr:first-child th{border-top:0}.msg table.nice tr th:first-child,.msg table.nice tr td:first-child{border-left:0}.msg table.nice tr th:last-child,.msg table.nice tr td:last-child{border-right:0}.msg table.nice tbody tr:last-child td{border-bottom:0}.msg table.nice thead tr:first-child th{background-color:var(--panel)}.msg table.nice thead tr:first-child th:first-child{border-top-left-radius:12px;background-clip:padding-box}.msg table.nice thead tr:first-child th:last-child{border-top-right-radius:12px;background-clip:padding-box}.msg table.nice tbody tr:last-child td:first-child{border-bottom-left-radius:12px;background-clip:padding-box}.msg table.nice tbody tr:last-child td:last-child{border-bottom-right-radius:12px;background-clip:padding-box}.toggle-switch{position:relative;display:inline-block;width:50px;height:28px}.toggle-switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--input-bg);border:1px solid var(--border);transition:.4s;border-radius:28px}.slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:var(--muted);transition:.4s;border-radius:50%}input:checked+.slider{background-color:var(--accent)}input:checked+.slider:before{transform:translate(22px);background-color:var(--panel)}.startup-task-banner{margin:16px 16px 0;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:var(--panel);color:var(--text);line-height:1.5}.spinner{border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top:3px solid var(--accent);width:20px;height:20px;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.codeblock{border:1px solid var(--grid, #e5e7eb);border-radius:12px;overflow:hidden;margin:1rem 0}.codeblock__header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:var(--panel);border-bottom:1px solid var(--grid);font-weight:600;font-size:.875rem}.codeblock__lang{opacity:.9}.codeblock__copy{display:inline-flex;align-items:center;gap:.25rem;border:0;background:transparent;padding:.25rem;border-radius:8px;cursor:pointer}.codeblock__copy:hover{background:#0000000f}.codeblock__copy.copied .icon-copy{transform:scale(1.05)}.codeblock__pre{margin:0;padding:.75rem;overflow:auto}.codeblock__code{display:block;white-space:pre}.assistant-message{display:block}.assistant-thoughts{margin-bottom:8px}.think-toggle{background:var(--active-bg);color:var(--muted);border:1px solid var(--border);border-radius:10px;font-size:12px;padding:4px 8px;cursor:pointer}.think-toggle:hover{color:var(--text);border-color:var(--accent)}.think-toggle-icon{display:inline-block;margin-right:6px}.think-content{margin-top:8px;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:var(--panel);color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:13px;line-height:1.5;overflow-x:auto;white-space:pre-wrap}.edit-message-input{display:block;width:100%;height:100%;background:transparent;border:0;padding:0;margin:0;color:inherit;font:inherit;line-height:inherit;letter-spacing:inherit;white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;resize:none;overflow:hidden;outline:none}.edit-message-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 35%,transparent)}.user-edit-shadow{visibility:hidden;white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word}.edit-message-input.edit-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:transparent;border:0;padding:0;margin:0;color:inherit;font:inherit;line-height:inherit;letter-spacing:inherit;white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;resize:none;overflow:hidden;outline:none;box-shadow:none}.websearch-toggle,.db-picker-toggle{background:transparent;border:0;padding:0;margin:0 .1rem 0 0;line-height:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative;top:-7.5px;color:var(--muted);box-shadow:none;outline:none;-webkit-tap-highlight-color:transparent}.websearch-toggle svg,.db-picker-toggle svg{width:20px;height:20px;pointer-events:none}.websearch-toggle.active,.db-picker-toggle.active{color:var(--accent)}.websearch-toggle:focus,.websearch-toggle:focus-visible,.db-picker-toggle:focus,.db-picker-toggle:focus-visible{outline:none;box-shadow:none}.db-picker-menu{position:absolute;right:0;bottom:calc(100% + 10px);min-width:240px;max-height:280px;overflow-y:auto;padding:6px;border-radius:12px;border:1px solid var(--border);background:var(--panel);box-shadow:0 14px 32px #00000059;z-index:20}.db-picker-option{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 10px;border:0;border-radius:10px;background:transparent;color:var(--text);cursor:pointer;text-align:left}.db-picker-option:hover:not(:disabled){background:var(--hover-bg)}.db-picker-option.selected{background:var(--active-bg)}.db-picker-option:disabled{color:var(--muted);cursor:not-allowed}.db-picker-status{flex-shrink:0;color:var(--muted);font-size:12px}.db-picker-empty{padding:10px;color:var(--muted);font-size:13px}.msg-sources{margin-top:8px;font-size:12px;color:var(--muted)}.msg-sources a{color:var(--accent);text-decoration:none;margin-right:8px}.msg-sources a:hover{text-decoration:underline}.msg-sources.chips{display:flex;flex-wrap:wrap;margin:.5rem 0}.msg-sources.chips .chip{display:inline-flex;align-items:center;padding:.25rem .6rem;border-radius:9999px;border:1px solid var(--border);text-decoration:none;font-size:.85rem;line-height:1;white-space:nowrap;margin-top:.5rem}.db-active-badge{margin-left:8px;padding:2px 8px;border-radius:999px;background:color-mix(in srgb,var(--accent) 20%,transparent);color:var(--accent);font-size:11px}.placeholder-view{height:100%;overflow:auto;padding:20px}.placeholder-view h1{margin-top:0}.library-panel{position:relative;display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.library-panel-scroll{flex:1;min-height:0;overflow:auto;padding:20px}.library-inline-form{margin-bottom:14px;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel) 88%,black)}.danger-zone{border-color:#8f3d49}.library-toast-stack{position:absolute;right:20px;bottom:92px;left:20px;z-index:2;display:flex;flex-direction:column;align-items:flex-end;gap:10px;pointer-events:none}.library-toast{width:min(100%,560px);padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel) 88%,black);box-shadow:0 16px 36px #00000047;line-height:1.45;animation:libraryToastIn .18s ease-out}.library-toast.success{border-color:color-mix(in srgb,#69c4a1 60%,var(--border))}.library-toast.warning{border-color:color-mix(in srgb,#e18282 60%,var(--border))}@keyframes libraryToastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.library-footer-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px;padding:14px 20px 20px;border-top:1px solid var(--border);background:color-mix(in srgb,var(--panel) 94%,black)}.library-files h2{margin:0 0 12px;font-size:16px}.library-file-list{display:grid;gap:10px}.library-file-row{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel) 88%,black)}.library-file-meta{min-width:0;flex:1}.library-file-name{font-weight:600;margin-bottom:4px}.library-file-mode{display:inline-flex;align-items:center;margin-top:4px;padding:4px 8px;border-radius:999px;border:1px solid var(--border);color:var(--muted);font-size:11px;letter-spacing:.02em;text-transform:uppercase}.library-file-mode.enabled{color:var(--text);border-color:color-mix(in srgb,var(--accent) 45%,var(--border));background:color-mix(in srgb,var(--accent) 12%,transparent)}.library-file-path,.muted-copy{color:var(--muted);font-size:13px;word-break:break-word}.library-file-actions{display:flex;gap:8px;flex-shrink:0}.library-file-sync{margin-top:10px}.library-file-sync-row{display:flex;flex-wrap:wrap;gap:6px 10px;align-items:baseline;margin-bottom:8px}.library-file-sync-label{font-size:12px;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.library-file-sync-label.ready{color:#69c4a1}.library-file-sync-label.syncing,.library-file-sync-label.pending{color:var(--accent)}.library-file-sync-label.failed{color:#e18282}.library-file-sync-detail{color:var(--muted);font-size:12px;line-height:1.35}.library-file-progress{position:relative;width:100%;height:8px;overflow:hidden;border-radius:999px;background:color-mix(in srgb,var(--panel) 50%,black);border:1px solid color-mix(in srgb,var(--border) 80%,transparent)}.library-file-progress-bar{height:100%;width:0;border-radius:inherit;background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 76%,white),var(--accent));transition:width .18s ease}.library-file-progress.ready .library-file-progress-bar{background:linear-gradient(90deg,#5cb48e,#7be1b5)}.library-file-progress.failed .library-file-progress-bar{background:linear-gradient(90deg,#c35d5d,#e18282)}@media (max-width: 760px){.library-toast-stack{right:12px;bottom:124px;left:12px}.library-footer-actions{padding:12px}.library-file-row{flex-direction:column}.library-file-actions{width:100%;justify-content:flex-end}} diff --git a/dist/assets/index-u1-aH6b-.js b/dist/assets/index-u1-aH6b-.js new file mode 100644 index 0000000..489fb6e --- /dev/null +++ b/dist/assets/index-u1-aH6b-.js @@ -0,0 +1,73 @@ +(function(){const t=document.createElement("link").relList;if(t&&t.supports&&t.supports("modulepreload"))return;for(const l of document.querySelectorAll('link[rel="modulepreload"]'))r(l);new MutationObserver(l=>{for(const o of l)if(o.type==="childList")for(const i of o.addedNodes)i.tagName==="LINK"&&i.rel==="modulepreload"&&r(i)}).observe(document,{childList:!0,subtree:!0});function n(l){const o={};return l.integrity&&(o.integrity=l.integrity),l.referrerPolicy&&(o.referrerPolicy=l.referrerPolicy),l.crossOrigin==="use-credentials"?o.credentials="include":l.crossOrigin==="anonymous"?o.credentials="omit":o.credentials="same-origin",o}function r(l){if(l.ep)return;l.ep=!0;const o=n(l);fetch(l.href,o)}})();function Wp(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var Nc={exports:{}},No={},_c={exports:{}},Y={};/** + * @license React + * react.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */var ll=Symbol.for("react.element"),bp=Symbol.for("react.portal"),Vp=Symbol.for("react.fragment"),Qp=Symbol.for("react.strict_mode"),Kp=Symbol.for("react.profiler"),Yp=Symbol.for("react.provider"),Jp=Symbol.for("react.context"),Gp=Symbol.for("react.forward_ref"),Xp=Symbol.for("react.suspense"),Zp=Symbol.for("react.memo"),qp=Symbol.for("react.lazy"),Ja=Symbol.iterator;function eh(e){return e===null||typeof e!="object"?null:(e=Ja&&e[Ja]||e["@@iterator"],typeof e=="function"?e:null)}var Lc={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},Pc=Object.assign,jc={};function cr(e,t,n){this.props=e,this.context=t,this.refs=jc,this.updater=n||Lc}cr.prototype.isReactComponent={};cr.prototype.setState=function(e,t){if(typeof e!="object"&&typeof e!="function"&&e!=null)throw Error("setState(...): takes an object of state variables to update or a function which returns an object of state variables.");this.updater.enqueueSetState(this,e,t,"setState")};cr.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")};function Rc(){}Rc.prototype=cr.prototype;function Ls(e,t,n){this.props=e,this.context=t,this.refs=jc,this.updater=n||Lc}var Ps=Ls.prototype=new Rc;Ps.constructor=Ls;Pc(Ps,cr.prototype);Ps.isPureReactComponent=!0;var Ga=Array.isArray,Tc=Object.prototype.hasOwnProperty,js={current:null},$c={key:!0,ref:!0,__self:!0,__source:!0};function Mc(e,t,n){var r,l={},o=null,i=null;if(t!=null)for(r in t.ref!==void 0&&(i=t.ref),t.key!==void 0&&(o=""+t.key),t)Tc.call(t,r)&&!$c.hasOwnProperty(r)&&(l[r]=t[r]);var a=arguments.length-2;if(a===1)l.children=n;else if(1>>1,pe=R[Z];if(0>>1;Zl(Tn,b))ltl(mt,Tn)?(R[Z]=mt,R[lt]=b,Z=lt):(R[Z]=Tn,R[ht]=b,Z=ht);else if(ltl(mt,b))R[Z]=mt,R[lt]=b,Z=lt;else break e}}return O}function l(R,O){var b=R.sortIndex-O.sortIndex;return b!==0?b:R.id-O.id}if(typeof performance=="object"&&typeof performance.now=="function"){var o=performance;e.unstable_now=function(){return o.now()}}else{var i=Date,a=i.now();e.unstable_now=function(){return i.now()-a}}var s=[],u=[],h=1,v=null,y=3,x=!1,E=!1,k=!1,L=typeof setTimeout=="function"?setTimeout:null,m=typeof clearTimeout=="function"?clearTimeout:null,f=typeof setImmediate<"u"?setImmediate:null;typeof navigator<"u"&&navigator.scheduling!==void 0&&navigator.scheduling.isInputPending!==void 0&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function d(R){for(var O=n(u);O!==null;){if(O.callback===null)r(u);else if(O.startTime<=R)r(u),O.sortIndex=O.expirationTime,t(s,O);else break;O=n(u)}}function C(R){if(k=!1,d(R),!E)if(n(s)!==null)E=!0,T(P);else{var O=n(u);O!==null&&H(C,O.startTime-R)}}function P(R,O){E=!1,k&&(k=!1,m(F),F=-1),x=!0;var b=y;try{for(d(O),v=n(s);v!==null&&(!(v.expirationTime>O)||R&&!q());){var Z=v.callback;if(typeof Z=="function"){v.callback=null,y=v.priorityLevel;var pe=Z(v.expirationTime<=O);O=e.unstable_now(),typeof pe=="function"?v.callback=pe:v===n(s)&&r(s),d(O)}else r(s);v=n(s)}if(v!==null)var Et=!0;else{var ht=n(u);ht!==null&&H(C,ht.startTime-O),Et=!1}return Et}finally{v=null,y=b,x=!1}}var M=!1,z=null,F=-1,B=5,D=-1;function q(){return!(e.unstable_now()-DR||125Z?(R.sortIndex=b,t(u,R),n(s)===null&&R===n(u)&&(k?(m(F),F=-1):k=!0,H(C,b-Z))):(R.sortIndex=pe,t(s,R),E||x||(E=!0,T(P))),R},e.unstable_shouldYield=q,e.unstable_wrapCallback=function(R){var O=y;return function(){var b=y;y=O;try{return R.apply(this,arguments)}finally{y=b}}}})(Dc);Ic.exports=Dc;var fh=Ic.exports;/** + * @license React + * react-dom.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */var dh=g,Ye=fh;function j(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n"u"||typeof window.document>"u"||typeof window.document.createElement>"u"),Ti=Object.prototype.hasOwnProperty,ph=/^[:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD][:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\-.0-9\u00B7\u0300-\u036F\u203F-\u2040]*$/,Za={},qa={};function hh(e){return Ti.call(qa,e)?!0:Ti.call(Za,e)?!1:ph.test(e)?qa[e]=!0:(Za[e]=!0,!1)}function mh(e,t,n,r){if(n!==null&&n.type===0)return!1;switch(typeof t){case"function":case"symbol":return!0;case"boolean":return r?!1:n!==null?!n.acceptsBooleans:(e=e.toLowerCase().slice(0,5),e!=="data-"&&e!=="aria-");default:return!1}}function gh(e,t,n,r){if(t===null||typeof t>"u"||mh(e,t,n,r))return!0;if(r)return!1;if(n!==null)switch(n.type){case 3:return!t;case 4:return t===!1;case 5:return isNaN(t);case 6:return isNaN(t)||1>t}return!1}function Ie(e,t,n,r,l,o,i){this.acceptsBooleans=t===2||t===3||t===4,this.attributeName=r,this.attributeNamespace=l,this.mustUseProperty=n,this.propertyName=e,this.type=t,this.sanitizeURL=o,this.removeEmptyString=i}var Ne={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(e){Ne[e]=new Ie(e,0,!1,e,null,!1,!1)});[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(e){var t=e[0];Ne[t]=new Ie(t,1,!1,e[1],null,!1,!1)});["contentEditable","draggable","spellCheck","value"].forEach(function(e){Ne[e]=new Ie(e,2,!1,e.toLowerCase(),null,!1,!1)});["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(e){Ne[e]=new Ie(e,2,!1,e,null,!1,!1)});"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope".split(" ").forEach(function(e){Ne[e]=new Ie(e,3,!1,e.toLowerCase(),null,!1,!1)});["checked","multiple","muted","selected"].forEach(function(e){Ne[e]=new Ie(e,3,!0,e,null,!1,!1)});["capture","download"].forEach(function(e){Ne[e]=new Ie(e,4,!1,e,null,!1,!1)});["cols","rows","size","span"].forEach(function(e){Ne[e]=new Ie(e,6,!1,e,null,!1,!1)});["rowSpan","start"].forEach(function(e){Ne[e]=new Ie(e,5,!1,e.toLowerCase(),null,!1,!1)});var Ts=/[\-:]([a-z])/g;function $s(e){return e[1].toUpperCase()}"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height".split(" ").forEach(function(e){var t=e.replace(Ts,$s);Ne[t]=new Ie(t,1,!1,e,null,!1,!1)});"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type".split(" ").forEach(function(e){var t=e.replace(Ts,$s);Ne[t]=new Ie(t,1,!1,e,"http://www.w3.org/1999/xlink",!1,!1)});["xml:base","xml:lang","xml:space"].forEach(function(e){var t=e.replace(Ts,$s);Ne[t]=new Ie(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1,!1)});["tabIndex","crossOrigin"].forEach(function(e){Ne[e]=new Ie(e,1,!1,e.toLowerCase(),null,!1,!1)});Ne.xlinkHref=new Ie("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1);["src","href","action","formAction"].forEach(function(e){Ne[e]=new Ie(e,1,!1,e.toLowerCase(),null,!0,!0)});function Ms(e,t,n,r){var l=Ne.hasOwnProperty(t)?Ne[t]:null;(l!==null?l.type!==0:r||!(2a||l[i]!==o[a]){var s=` +`+l[i].replace(" at new "," at ");return e.displayName&&s.includes("")&&(s=s.replace("",e.displayName)),s}while(1<=i&&0<=a);break}}}finally{ri=!1,Error.prepareStackTrace=n}return(e=e?e.displayName||e.name:"")?_r(e):""}function vh(e){switch(e.tag){case 5:return _r(e.type);case 16:return _r("Lazy");case 13:return _r("Suspense");case 19:return _r("SuspenseList");case 0:case 2:case 15:return e=li(e.type,!1),e;case 11:return e=li(e.type.render,!1),e;case 1:return e=li(e.type,!0),e;default:return""}}function zi(e){if(e==null)return null;if(typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case Un:return"Fragment";case An:return"Portal";case $i:return"Profiler";case Os:return"StrictMode";case Mi:return"Suspense";case Oi:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case Bc:return(e.displayName||"Context")+".Consumer";case Uc:return(e._context.displayName||"Context")+".Provider";case zs:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case Fs:return t=e.displayName||null,t!==null?t:zi(e.type)||"Memo";case bt:t=e._payload,e=e._init;try{return zi(e(t))}catch{}}return null}function yh(e){var t=e.type;switch(e.tag){case 24:return"Cache";case 9:return(t.displayName||"Context")+".Consumer";case 10:return(t._context.displayName||"Context")+".Provider";case 18:return"DehydratedFragment";case 11:return e=t.render,e=e.displayName||e.name||"",t.displayName||(e!==""?"ForwardRef("+e+")":"ForwardRef");case 7:return"Fragment";case 5:return t;case 4:return"Portal";case 3:return"Root";case 6:return"Text";case 16:return zi(t);case 8:return t===Os?"StrictMode":"Mode";case 22:return"Offscreen";case 12:return"Profiler";case 21:return"Scope";case 13:return"Suspense";case 19:return"SuspenseList";case 25:return"TracingMarker";case 1:case 0:case 17:case 2:case 14:case 15:if(typeof t=="function")return t.displayName||t.name||null;if(typeof t=="string")return t}return null}function ln(e){switch(typeof e){case"boolean":case"number":case"string":case"undefined":return e;case"object":return e;default:return""}}function Wc(e){var t=e.type;return(e=e.nodeName)&&e.toLowerCase()==="input"&&(t==="checkbox"||t==="radio")}function wh(e){var t=Wc(e)?"checked":"value",n=Object.getOwnPropertyDescriptor(e.constructor.prototype,t),r=""+e[t];if(!e.hasOwnProperty(t)&&typeof n<"u"&&typeof n.get=="function"&&typeof n.set=="function"){var l=n.get,o=n.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return l.call(this)},set:function(i){r=""+i,o.call(this,i)}}),Object.defineProperty(e,t,{enumerable:n.enumerable}),{getValue:function(){return r},setValue:function(i){r=""+i},stopTracking:function(){e._valueTracker=null,delete e[t]}}}}function kl(e){e._valueTracker||(e._valueTracker=wh(e))}function bc(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var n=t.getValue(),r="";return e&&(r=Wc(e)?e.checked?"true":"false":e.value),e=r,e!==n?(t.setValue(e),!0):!1}function ql(e){if(e=e||(typeof document<"u"?document:void 0),typeof e>"u")return null;try{return e.activeElement||e.body}catch{return e.body}}function Fi(e,t){var n=t.checked;return ue({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:n??e._wrapperState.initialChecked})}function tu(e,t){var n=t.defaultValue==null?"":t.defaultValue,r=t.checked!=null?t.checked:t.defaultChecked;n=ln(t.value!=null?t.value:n),e._wrapperState={initialChecked:r,initialValue:n,controlled:t.type==="checkbox"||t.type==="radio"?t.checked!=null:t.value!=null}}function Vc(e,t){t=t.checked,t!=null&&Ms(e,"checked",t,!1)}function Ii(e,t){Vc(e,t);var n=ln(t.value),r=t.type;if(n!=null)r==="number"?(n===0&&e.value===""||e.value!=n)&&(e.value=""+n):e.value!==""+n&&(e.value=""+n);else if(r==="submit"||r==="reset"){e.removeAttribute("value");return}t.hasOwnProperty("value")?Di(e,t.type,n):t.hasOwnProperty("defaultValue")&&Di(e,t.type,ln(t.defaultValue)),t.checked==null&&t.defaultChecked!=null&&(e.defaultChecked=!!t.defaultChecked)}function nu(e,t,n){if(t.hasOwnProperty("value")||t.hasOwnProperty("defaultValue")){var r=t.type;if(!(r!=="submit"&&r!=="reset"||t.value!==void 0&&t.value!==null))return;t=""+e._wrapperState.initialValue,n||t===e.value||(e.value=t),e.defaultValue=t}n=e.name,n!==""&&(e.name=""),e.defaultChecked=!!e._wrapperState.initialChecked,n!==""&&(e.name=n)}function Di(e,t,n){(t!=="number"||ql(e.ownerDocument)!==e)&&(n==null?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+n&&(e.defaultValue=""+n))}var Lr=Array.isArray;function Xn(e,t,n,r){if(e=e.options,t){t={};for(var l=0;l"+t.valueOf().toString()+"",t=El.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}});function Ur(e,t){if(t){var n=e.firstChild;if(n&&n===e.lastChild&&n.nodeType===3){n.nodeValue=t;return}}e.textContent=t}var Rr={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},Sh=["Webkit","ms","Moz","O"];Object.keys(Rr).forEach(function(e){Sh.forEach(function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),Rr[t]=Rr[e]})});function Jc(e,t,n){return t==null||typeof t=="boolean"||t===""?"":n||typeof t!="number"||t===0||Rr.hasOwnProperty(e)&&Rr[e]?(""+t).trim():t+"px"}function Gc(e,t){e=e.style;for(var n in t)if(t.hasOwnProperty(n)){var r=n.indexOf("--")===0,l=Jc(n,t[n],r);n==="float"&&(n="cssFloat"),r?e.setProperty(n,l):e[n]=l}}var xh=ue({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});function Bi(e,t){if(t){if(xh[e]&&(t.children!=null||t.dangerouslySetInnerHTML!=null))throw Error(j(137,e));if(t.dangerouslySetInnerHTML!=null){if(t.children!=null)throw Error(j(60));if(typeof t.dangerouslySetInnerHTML!="object"||!("__html"in t.dangerouslySetInnerHTML))throw Error(j(61))}if(t.style!=null&&typeof t.style!="object")throw Error(j(62))}}function Hi(e,t){if(e.indexOf("-")===-1)return typeof t.is=="string";switch(e){case"annotation-xml":case"color-profile":case"font-face":case"font-face-src":case"font-face-uri":case"font-face-format":case"font-face-name":case"missing-glyph":return!1;default:return!0}}var Wi=null;function Is(e){return e=e.target||e.srcElement||window,e.correspondingUseElement&&(e=e.correspondingUseElement),e.nodeType===3?e.parentNode:e}var bi=null,Zn=null,qn=null;function ou(e){if(e=sl(e)){if(typeof bi!="function")throw Error(j(280));var t=e.stateNode;t&&(t=Ro(t),bi(e.stateNode,e.type,t))}}function Xc(e){Zn?qn?qn.push(e):qn=[e]:Zn=e}function Zc(){if(Zn){var e=Zn,t=qn;if(qn=Zn=null,ou(e),t)for(e=0;e>>=0,e===0?32:31-($h(e)/Mh|0)|0}var Cl=64,Nl=4194304;function Pr(e){switch(e&-e){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return e&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return e&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;default:return e}}function ro(e,t){var n=e.pendingLanes;if(n===0)return 0;var r=0,l=e.suspendedLanes,o=e.pingedLanes,i=n&268435455;if(i!==0){var a=i&~l;a!==0?r=Pr(a):(o&=i,o!==0&&(r=Pr(o)))}else i=n&~l,i!==0?r=Pr(i):o!==0&&(r=Pr(o));if(r===0)return 0;if(t!==0&&t!==r&&!(t&l)&&(l=r&-r,o=t&-t,l>=o||l===16&&(o&4194240)!==0))return t;if(r&4&&(r|=n&16),t=e.entangledLanes,t!==0)for(e=e.entanglements,t&=r;0n;n++)t.push(e);return t}function ol(e,t,n){e.pendingLanes|=t,t!==536870912&&(e.suspendedLanes=0,e.pingedLanes=0),e=e.eventTimes,t=31-ct(t),e[t]=n}function Ih(e,t){var n=e.pendingLanes&~t;e.pendingLanes=t,e.suspendedLanes=0,e.pingedLanes=0,e.expiredLanes&=t,e.mutableReadLanes&=t,e.entangledLanes&=t,t=e.entanglements;var r=e.eventTimes;for(e=e.expirationTimes;0=$r),hu=" ",mu=!1;function wf(e,t){switch(e){case"keyup":return fm.indexOf(t.keyCode)!==-1;case"keydown":return t.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function Sf(e){return e=e.detail,typeof e=="object"&&"data"in e?e.data:null}var Bn=!1;function pm(e,t){switch(e){case"compositionend":return Sf(t);case"keypress":return t.which!==32?null:(mu=!0,hu);case"textInput":return e=t.data,e===hu&&mu?null:e;default:return null}}function hm(e,t){if(Bn)return e==="compositionend"||!Vs&&wf(e,t)?(e=vf(),Bl=Hs=Yt=null,Bn=!1,e):null;switch(e){case"paste":return null;case"keypress":if(!(t.ctrlKey||t.altKey||t.metaKey)||t.ctrlKey&&t.altKey){if(t.char&&1=t)return{node:n,offset:t-e};e=r}e:{for(;n;){if(n.nextSibling){n=n.nextSibling;break e}n=n.parentNode}n=void 0}n=wu(n)}}function Cf(e,t){return e&&t?e===t?!0:e&&e.nodeType===3?!1:t&&t.nodeType===3?Cf(e,t.parentNode):"contains"in e?e.contains(t):e.compareDocumentPosition?!!(e.compareDocumentPosition(t)&16):!1:!1}function Nf(){for(var e=window,t=ql();t instanceof e.HTMLIFrameElement;){try{var n=typeof t.contentWindow.location.href=="string"}catch{n=!1}if(n)e=t.contentWindow;else break;t=ql(e.document)}return t}function Qs(e){var t=e&&e.nodeName&&e.nodeName.toLowerCase();return t&&(t==="input"&&(e.type==="text"||e.type==="search"||e.type==="tel"||e.type==="url"||e.type==="password")||t==="textarea"||e.contentEditable==="true")}function Em(e){var t=Nf(),n=e.focusedElem,r=e.selectionRange;if(t!==n&&n&&n.ownerDocument&&Cf(n.ownerDocument.documentElement,n)){if(r!==null&&Qs(n)){if(t=r.start,e=r.end,e===void 0&&(e=t),"selectionStart"in n)n.selectionStart=t,n.selectionEnd=Math.min(e,n.value.length);else if(e=(t=n.ownerDocument||document)&&t.defaultView||window,e.getSelection){e=e.getSelection();var l=n.textContent.length,o=Math.min(r.start,l);r=r.end===void 0?o:Math.min(r.end,l),!e.extend&&o>r&&(l=r,r=o,o=l),l=Su(n,o);var i=Su(n,r);l&&i&&(e.rangeCount!==1||e.anchorNode!==l.node||e.anchorOffset!==l.offset||e.focusNode!==i.node||e.focusOffset!==i.offset)&&(t=t.createRange(),t.setStart(l.node,l.offset),e.removeAllRanges(),o>r?(e.addRange(t),e.extend(i.node,i.offset)):(t.setEnd(i.node,i.offset),e.addRange(t)))}}for(t=[],e=n;e=e.parentNode;)e.nodeType===1&&t.push({element:e,left:e.scrollLeft,top:e.scrollTop});for(typeof n.focus=="function"&&n.focus(),n=0;n=document.documentMode,Hn=null,Gi=null,Or=null,Xi=!1;function xu(e,t,n){var r=n.window===n?n.document:n.nodeType===9?n:n.ownerDocument;Xi||Hn==null||Hn!==ql(r)||(r=Hn,"selectionStart"in r&&Qs(r)?r={start:r.selectionStart,end:r.selectionEnd}:(r=(r.ownerDocument&&r.ownerDocument.defaultView||window).getSelection(),r={anchorNode:r.anchorNode,anchorOffset:r.anchorOffset,focusNode:r.focusNode,focusOffset:r.focusOffset}),Or&&Qr(Or,r)||(Or=r,r=io(Gi,"onSelect"),0Vn||(e.current=rs[Vn],rs[Vn]=null,Vn--)}function ee(e,t){Vn++,rs[Vn]=e.current,e.current=t}var on={},Te=an(on),Ue=an(!1),kn=on;function lr(e,t){var n=e.type.contextTypes;if(!n)return on;var r=e.stateNode;if(r&&r.__reactInternalMemoizedUnmaskedChildContext===t)return r.__reactInternalMemoizedMaskedChildContext;var l={},o;for(o in n)l[o]=t[o];return r&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=l),l}function Be(e){return e=e.childContextTypes,e!=null}function ao(){re(Ue),re(Te)}function Pu(e,t,n){if(Te.current!==on)throw Error(j(168));ee(Te,t),ee(Ue,n)}function Of(e,t,n){var r=e.stateNode;if(t=t.childContextTypes,typeof r.getChildContext!="function")return n;r=r.getChildContext();for(var l in r)if(!(l in t))throw Error(j(108,yh(e)||"Unknown",l));return ue({},n,r)}function uo(e){return e=(e=e.stateNode)&&e.__reactInternalMemoizedMergedChildContext||on,kn=Te.current,ee(Te,e),ee(Ue,Ue.current),!0}function ju(e,t,n){var r=e.stateNode;if(!r)throw Error(j(169));n?(e=Of(e,t,kn),r.__reactInternalMemoizedMergedChildContext=e,re(Ue),re(Te),ee(Te,e)):re(Ue),ee(Ue,n)}var Lt=null,To=!1,yi=!1;function zf(e){Lt===null?Lt=[e]:Lt.push(e)}function zm(e){To=!0,zf(e)}function un(){if(!yi&&Lt!==null){yi=!0;var e=0,t=X;try{var n=Lt;for(X=1;e>=i,l-=i,Pt=1<<32-ct(t)+l|n<F?(B=z,z=null):B=z.sibling;var D=y(m,z,d[F],C);if(D===null){z===null&&(z=B);break}e&&z&&D.alternate===null&&t(m,z),f=o(D,f,F),M===null?P=D:M.sibling=D,M=D,z=B}if(F===d.length)return n(m,z),le&&mn(m,F),P;if(z===null){for(;FF?(B=z,z=null):B=z.sibling;var q=y(m,z,D.value,C);if(q===null){z===null&&(z=B);break}e&&z&&q.alternate===null&&t(m,z),f=o(q,f,F),M===null?P=q:M.sibling=q,M=q,z=B}if(D.done)return n(m,z),le&&mn(m,F),P;if(z===null){for(;!D.done;F++,D=d.next())D=v(m,D.value,C),D!==null&&(f=o(D,f,F),M===null?P=D:M.sibling=D,M=D);return le&&mn(m,F),P}for(z=r(m,z);!D.done;F++,D=d.next())D=x(z,m,F,D.value,C),D!==null&&(e&&D.alternate!==null&&z.delete(D.key===null?F:D.key),f=o(D,f,F),M===null?P=D:M.sibling=D,M=D);return e&&z.forEach(function(ge){return t(m,ge)}),le&&mn(m,F),P}function L(m,f,d,C){if(typeof d=="object"&&d!==null&&d.type===Un&&d.key===null&&(d=d.props.children),typeof d=="object"&&d!==null){switch(d.$$typeof){case xl:e:{for(var P=d.key,M=f;M!==null;){if(M.key===P){if(P=d.type,P===Un){if(M.tag===7){n(m,M.sibling),f=l(M,d.props.children),f.return=m,m=f;break e}}else if(M.elementType===P||typeof P=="object"&&P!==null&&P.$$typeof===bt&&$u(P)===M.type){n(m,M.sibling),f=l(M,d.props),f.ref=xr(m,M,d),f.return=m,m=f;break e}n(m,M);break}else t(m,M);M=M.sibling}d.type===Un?(f=xn(d.props.children,m.mode,C,d.key),f.return=m,m=f):(C=Jl(d.type,d.key,d.props,null,m.mode,C),C.ref=xr(m,f,d),C.return=m,m=C)}return i(m);case An:e:{for(M=d.key;f!==null;){if(f.key===M)if(f.tag===4&&f.stateNode.containerInfo===d.containerInfo&&f.stateNode.implementation===d.implementation){n(m,f.sibling),f=l(f,d.children||[]),f.return=m,m=f;break e}else{n(m,f);break}else t(m,f);f=f.sibling}f=_i(d,m.mode,C),f.return=m,m=f}return i(m);case bt:return M=d._init,L(m,f,M(d._payload),C)}if(Lr(d))return E(m,f,d,C);if(gr(d))return k(m,f,d,C);$l(m,d)}return typeof d=="string"&&d!==""||typeof d=="number"?(d=""+d,f!==null&&f.tag===6?(n(m,f.sibling),f=l(f,d),f.return=m,m=f):(n(m,f),f=Ni(d,m.mode,C),f.return=m,m=f),i(m)):n(m,f)}return L}var ir=Af(!0),Uf=Af(!1),po=an(null),ho=null,Yn=null,Gs=null;function Xs(){Gs=Yn=ho=null}function Zs(e){var t=po.current;re(po),e._currentValue=t}function is(e,t,n){for(;e!==null;){var r=e.alternate;if((e.childLanes&t)!==t?(e.childLanes|=t,r!==null&&(r.childLanes|=t)):r!==null&&(r.childLanes&t)!==t&&(r.childLanes|=t),e===n)break;e=e.return}}function tr(e,t){ho=e,Gs=Yn=null,e=e.dependencies,e!==null&&e.firstContext!==null&&(e.lanes&t&&(Ae=!0),e.firstContext=null)}function nt(e){var t=e._currentValue;if(Gs!==e)if(e={context:e,memoizedValue:t,next:null},Yn===null){if(ho===null)throw Error(j(308));Yn=e,ho.dependencies={lanes:0,firstContext:e}}else Yn=Yn.next=e;return t}var yn=null;function qs(e){yn===null?yn=[e]:yn.push(e)}function Bf(e,t,n,r){var l=t.interleaved;return l===null?(n.next=n,qs(t)):(n.next=l.next,l.next=n),t.interleaved=n,Ot(e,r)}function Ot(e,t){e.lanes|=t;var n=e.alternate;for(n!==null&&(n.lanes|=t),n=e,e=e.return;e!==null;)e.childLanes|=t,n=e.alternate,n!==null&&(n.childLanes|=t),n=e,e=e.return;return n.tag===3?n.stateNode:null}var Vt=!1;function ea(e){e.updateQueue={baseState:e.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function Hf(e,t){e=e.updateQueue,t.updateQueue===e&&(t.updateQueue={baseState:e.baseState,firstBaseUpdate:e.firstBaseUpdate,lastBaseUpdate:e.lastBaseUpdate,shared:e.shared,effects:e.effects})}function Rt(e,t){return{eventTime:e,lane:t,tag:0,payload:null,callback:null,next:null}}function en(e,t,n){var r=e.updateQueue;if(r===null)return null;if(r=r.shared,J&2){var l=r.pending;return l===null?t.next=t:(t.next=l.next,l.next=t),r.pending=t,Ot(e,n)}return l=r.interleaved,l===null?(t.next=t,qs(r)):(t.next=l.next,l.next=t),r.interleaved=t,Ot(e,n)}function Wl(e,t,n){if(t=t.updateQueue,t!==null&&(t=t.shared,(n&4194240)!==0)){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,As(e,n)}}function Mu(e,t){var n=e.updateQueue,r=e.alternate;if(r!==null&&(r=r.updateQueue,n===r)){var l=null,o=null;if(n=n.firstBaseUpdate,n!==null){do{var i={eventTime:n.eventTime,lane:n.lane,tag:n.tag,payload:n.payload,callback:n.callback,next:null};o===null?l=o=i:o=o.next=i,n=n.next}while(n!==null);o===null?l=o=t:o=o.next=t}else l=o=t;n={baseState:r.baseState,firstBaseUpdate:l,lastBaseUpdate:o,shared:r.shared,effects:r.effects},e.updateQueue=n;return}e=n.lastBaseUpdate,e===null?n.firstBaseUpdate=t:e.next=t,n.lastBaseUpdate=t}function mo(e,t,n,r){var l=e.updateQueue;Vt=!1;var o=l.firstBaseUpdate,i=l.lastBaseUpdate,a=l.shared.pending;if(a!==null){l.shared.pending=null;var s=a,u=s.next;s.next=null,i===null?o=u:i.next=u,i=s;var h=e.alternate;h!==null&&(h=h.updateQueue,a=h.lastBaseUpdate,a!==i&&(a===null?h.firstBaseUpdate=u:a.next=u,h.lastBaseUpdate=s))}if(o!==null){var v=l.baseState;i=0,h=u=s=null,a=o;do{var y=a.lane,x=a.eventTime;if((r&y)===y){h!==null&&(h=h.next={eventTime:x,lane:0,tag:a.tag,payload:a.payload,callback:a.callback,next:null});e:{var E=e,k=a;switch(y=t,x=n,k.tag){case 1:if(E=k.payload,typeof E=="function"){v=E.call(x,v,y);break e}v=E;break e;case 3:E.flags=E.flags&-65537|128;case 0:if(E=k.payload,y=typeof E=="function"?E.call(x,v,y):E,y==null)break e;v=ue({},v,y);break e;case 2:Vt=!0}}a.callback!==null&&a.lane!==0&&(e.flags|=64,y=l.effects,y===null?l.effects=[a]:y.push(a))}else x={eventTime:x,lane:y,tag:a.tag,payload:a.payload,callback:a.callback,next:null},h===null?(u=h=x,s=v):h=h.next=x,i|=y;if(a=a.next,a===null){if(a=l.shared.pending,a===null)break;y=a,a=y.next,y.next=null,l.lastBaseUpdate=y,l.shared.pending=null}}while(!0);if(h===null&&(s=v),l.baseState=s,l.firstBaseUpdate=u,l.lastBaseUpdate=h,t=l.shared.interleaved,t!==null){l=t;do i|=l.lane,l=l.next;while(l!==t)}else o===null&&(l.shared.lanes=0);Nn|=i,e.lanes=i,e.memoizedState=v}}function Ou(e,t,n){if(e=t.effects,t.effects=null,e!==null)for(t=0;tn?n:4,e(!0);var r=Si.transition;Si.transition={};try{e(!1),t()}finally{X=n,Si.transition=r}}function od(){return rt().memoizedState}function Am(e,t,n){var r=nn(e);if(n={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null},id(e))sd(t,n);else if(n=Bf(e,t,n,r),n!==null){var l=ze();ft(n,e,r,l),ad(n,t,r)}}function Um(e,t,n){var r=nn(e),l={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null};if(id(e))sd(t,l);else{var o=e.alternate;if(e.lanes===0&&(o===null||o.lanes===0)&&(o=t.lastRenderedReducer,o!==null))try{var i=t.lastRenderedState,a=o(i,n);if(l.hasEagerState=!0,l.eagerState=a,dt(a,i)){var s=t.interleaved;s===null?(l.next=l,qs(t)):(l.next=s.next,s.next=l),t.interleaved=l;return}}catch{}finally{}n=Bf(e,t,l,r),n!==null&&(l=ze(),ft(n,e,r,l),ad(n,t,r))}}function id(e){var t=e.alternate;return e===se||t!==null&&t===se}function sd(e,t){zr=vo=!0;var n=e.pending;n===null?t.next=t:(t.next=n.next,n.next=t),e.pending=t}function ad(e,t,n){if(n&4194240){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,As(e,n)}}var yo={readContext:nt,useCallback:Pe,useContext:Pe,useEffect:Pe,useImperativeHandle:Pe,useInsertionEffect:Pe,useLayoutEffect:Pe,useMemo:Pe,useReducer:Pe,useRef:Pe,useState:Pe,useDebugValue:Pe,useDeferredValue:Pe,useTransition:Pe,useMutableSource:Pe,useSyncExternalStore:Pe,useId:Pe,unstable_isNewReconciler:!1},Bm={readContext:nt,useCallback:function(e,t){return yt().memoizedState=[e,t===void 0?null:t],e},useContext:nt,useEffect:Fu,useImperativeHandle:function(e,t,n){return n=n!=null?n.concat([e]):null,Vl(4194308,4,ed.bind(null,t,e),n)},useLayoutEffect:function(e,t){return Vl(4194308,4,e,t)},useInsertionEffect:function(e,t){return Vl(4,2,e,t)},useMemo:function(e,t){var n=yt();return t=t===void 0?null:t,e=e(),n.memoizedState=[e,t],e},useReducer:function(e,t,n){var r=yt();return t=n!==void 0?n(t):t,r.memoizedState=r.baseState=t,e={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:e,lastRenderedState:t},r.queue=e,e=e.dispatch=Am.bind(null,se,e),[r.memoizedState,e]},useRef:function(e){var t=yt();return e={current:e},t.memoizedState=e},useState:zu,useDebugValue:aa,useDeferredValue:function(e){return yt().memoizedState=e},useTransition:function(){var e=zu(!1),t=e[0];return e=Dm.bind(null,e[1]),yt().memoizedState=e,[t,e]},useMutableSource:function(){},useSyncExternalStore:function(e,t,n){var r=se,l=yt();if(le){if(n===void 0)throw Error(j(407));n=n()}else{if(n=t(),xe===null)throw Error(j(349));Cn&30||Qf(r,t,n)}l.memoizedState=n;var o={value:n,getSnapshot:t};return l.queue=o,Fu(Yf.bind(null,r,o,e),[e]),r.flags|=2048,el(9,Kf.bind(null,r,o,n,t),void 0,null),n},useId:function(){var e=yt(),t=xe.identifierPrefix;if(le){var n=jt,r=Pt;n=(r&~(1<<32-ct(r)-1)).toString(32)+n,t=":"+t+"R"+n,n=Zr++,0<\/script>",e=e.removeChild(e.firstChild)):typeof r.is=="string"?e=i.createElement(n,{is:r.is}):(e=i.createElement(n),n==="select"&&(i=e,r.multiple?i.multiple=!0:r.size&&(i.size=r.size))):e=i.createElementNS(e,n),e[wt]=t,e[Jr]=r,yd(e,t,!1,!1),t.stateNode=e;e:{switch(i=Hi(n,r),n){case"dialog":ne("cancel",e),ne("close",e),l=r;break;case"iframe":case"object":case"embed":ne("load",e),l=r;break;case"video":case"audio":for(l=0;lur&&(t.flags|=128,r=!0,kr(o,!1),t.lanes=4194304)}else{if(!r)if(e=go(i),e!==null){if(t.flags|=128,r=!0,n=e.updateQueue,n!==null&&(t.updateQueue=n,t.flags|=4),kr(o,!0),o.tail===null&&o.tailMode==="hidden"&&!i.alternate&&!le)return je(t),null}else 2*de()-o.renderingStartTime>ur&&n!==1073741824&&(t.flags|=128,r=!0,kr(o,!1),t.lanes=4194304);o.isBackwards?(i.sibling=t.child,t.child=i):(n=o.last,n!==null?n.sibling=i:t.child=i,o.last=i)}return o.tail!==null?(t=o.tail,o.rendering=t,o.tail=t.sibling,o.renderingStartTime=de(),t.sibling=null,n=ie.current,ee(ie,r?n&1|2:n&1),t):(je(t),null);case 22:case 23:return ha(),r=t.memoizedState!==null,e!==null&&e.memoizedState!==null!==r&&(t.flags|=8192),r&&t.mode&1?Ve&1073741824&&(je(t),t.subtreeFlags&6&&(t.flags|=8192)):je(t),null;case 24:return null;case 25:return null}throw Error(j(156,t.tag))}function Jm(e,t){switch(Ys(t),t.tag){case 1:return Be(t.type)&&ao(),e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 3:return sr(),re(Ue),re(Te),ra(),e=t.flags,e&65536&&!(e&128)?(t.flags=e&-65537|128,t):null;case 5:return na(t),null;case 13:if(re(ie),e=t.memoizedState,e!==null&&e.dehydrated!==null){if(t.alternate===null)throw Error(j(340));or()}return e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 19:return re(ie),null;case 4:return sr(),null;case 10:return Zs(t.type._context),null;case 22:case 23:return ha(),null;case 24:return null;default:return null}}var Ol=!1,Re=!1,Gm=typeof WeakSet=="function"?WeakSet:Set,I=null;function Jn(e,t){var n=e.ref;if(n!==null)if(typeof n=="function")try{n(null)}catch(r){ce(e,t,r)}else n.current=null}function ms(e,t,n){try{n()}catch(r){ce(e,t,r)}}var Ku=!1;function Xm(e,t){if(Zi=lo,e=Nf(),Qs(e)){if("selectionStart"in e)var n={start:e.selectionStart,end:e.selectionEnd};else e:{n=(n=e.ownerDocument)&&n.defaultView||window;var r=n.getSelection&&n.getSelection();if(r&&r.rangeCount!==0){n=r.anchorNode;var l=r.anchorOffset,o=r.focusNode;r=r.focusOffset;try{n.nodeType,o.nodeType}catch{n=null;break e}var i=0,a=-1,s=-1,u=0,h=0,v=e,y=null;t:for(;;){for(var x;v!==n||l!==0&&v.nodeType!==3||(a=i+l),v!==o||r!==0&&v.nodeType!==3||(s=i+r),v.nodeType===3&&(i+=v.nodeValue.length),(x=v.firstChild)!==null;)y=v,v=x;for(;;){if(v===e)break t;if(y===n&&++u===l&&(a=i),y===o&&++h===r&&(s=i),(x=v.nextSibling)!==null)break;v=y,y=v.parentNode}v=x}n=a===-1||s===-1?null:{start:a,end:s}}else n=null}n=n||{start:0,end:0}}else n=null;for(qi={focusedElem:e,selectionRange:n},lo=!1,I=t;I!==null;)if(t=I,e=t.child,(t.subtreeFlags&1028)!==0&&e!==null)e.return=t,I=e;else for(;I!==null;){t=I;try{var E=t.alternate;if(t.flags&1024)switch(t.tag){case 0:case 11:case 15:break;case 1:if(E!==null){var k=E.memoizedProps,L=E.memoizedState,m=t.stateNode,f=m.getSnapshotBeforeUpdate(t.elementType===t.type?k:st(t.type,k),L);m.__reactInternalSnapshotBeforeUpdate=f}break;case 3:var d=t.stateNode.containerInfo;d.nodeType===1?d.textContent="":d.nodeType===9&&d.documentElement&&d.removeChild(d.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(j(163))}}catch(C){ce(t,t.return,C)}if(e=t.sibling,e!==null){e.return=t.return,I=e;break}I=t.return}return E=Ku,Ku=!1,E}function Fr(e,t,n){var r=t.updateQueue;if(r=r!==null?r.lastEffect:null,r!==null){var l=r=r.next;do{if((l.tag&e)===e){var o=l.destroy;l.destroy=void 0,o!==void 0&&ms(t,n,o)}l=l.next}while(l!==r)}}function Oo(e,t){if(t=t.updateQueue,t=t!==null?t.lastEffect:null,t!==null){var n=t=t.next;do{if((n.tag&e)===e){var r=n.create;n.destroy=r()}n=n.next}while(n!==t)}}function gs(e){var t=e.ref;if(t!==null){var n=e.stateNode;switch(e.tag){case 5:e=n;break;default:e=n}typeof t=="function"?t(e):t.current=e}}function xd(e){var t=e.alternate;t!==null&&(e.alternate=null,xd(t)),e.child=null,e.deletions=null,e.sibling=null,e.tag===5&&(t=e.stateNode,t!==null&&(delete t[wt],delete t[Jr],delete t[ns],delete t[Mm],delete t[Om])),e.stateNode=null,e.return=null,e.dependencies=null,e.memoizedProps=null,e.memoizedState=null,e.pendingProps=null,e.stateNode=null,e.updateQueue=null}function kd(e){return e.tag===5||e.tag===3||e.tag===4}function Yu(e){e:for(;;){for(;e.sibling===null;){if(e.return===null||kd(e.return))return null;e=e.return}for(e.sibling.return=e.return,e=e.sibling;e.tag!==5&&e.tag!==6&&e.tag!==18;){if(e.flags&2||e.child===null||e.tag===4)continue e;e.child.return=e,e=e.child}if(!(e.flags&2))return e.stateNode}}function vs(e,t,n){var r=e.tag;if(r===5||r===6)e=e.stateNode,t?n.nodeType===8?n.parentNode.insertBefore(e,t):n.insertBefore(e,t):(n.nodeType===8?(t=n.parentNode,t.insertBefore(e,n)):(t=n,t.appendChild(e)),n=n._reactRootContainer,n!=null||t.onclick!==null||(t.onclick=so));else if(r!==4&&(e=e.child,e!==null))for(vs(e,t,n),e=e.sibling;e!==null;)vs(e,t,n),e=e.sibling}function ys(e,t,n){var r=e.tag;if(r===5||r===6)e=e.stateNode,t?n.insertBefore(e,t):n.appendChild(e);else if(r!==4&&(e=e.child,e!==null))for(ys(e,t,n),e=e.sibling;e!==null;)ys(e,t,n),e=e.sibling}var Ee=null,at=!1;function Wt(e,t,n){for(n=n.child;n!==null;)Ed(e,t,n),n=n.sibling}function Ed(e,t,n){if(St&&typeof St.onCommitFiberUnmount=="function")try{St.onCommitFiberUnmount(_o,n)}catch{}switch(n.tag){case 5:Re||Jn(n,t);case 6:var r=Ee,l=at;Ee=null,Wt(e,t,n),Ee=r,at=l,Ee!==null&&(at?(e=Ee,n=n.stateNode,e.nodeType===8?e.parentNode.removeChild(n):e.removeChild(n)):Ee.removeChild(n.stateNode));break;case 18:Ee!==null&&(at?(e=Ee,n=n.stateNode,e.nodeType===8?vi(e.parentNode,n):e.nodeType===1&&vi(e,n),br(e)):vi(Ee,n.stateNode));break;case 4:r=Ee,l=at,Ee=n.stateNode.containerInfo,at=!0,Wt(e,t,n),Ee=r,at=l;break;case 0:case 11:case 14:case 15:if(!Re&&(r=n.updateQueue,r!==null&&(r=r.lastEffect,r!==null))){l=r=r.next;do{var o=l,i=o.destroy;o=o.tag,i!==void 0&&(o&2||o&4)&&ms(n,t,i),l=l.next}while(l!==r)}Wt(e,t,n);break;case 1:if(!Re&&(Jn(n,t),r=n.stateNode,typeof r.componentWillUnmount=="function"))try{r.props=n.memoizedProps,r.state=n.memoizedState,r.componentWillUnmount()}catch(a){ce(n,t,a)}Wt(e,t,n);break;case 21:Wt(e,t,n);break;case 22:n.mode&1?(Re=(r=Re)||n.memoizedState!==null,Wt(e,t,n),Re=r):Wt(e,t,n);break;default:Wt(e,t,n)}}function Ju(e){var t=e.updateQueue;if(t!==null){e.updateQueue=null;var n=e.stateNode;n===null&&(n=e.stateNode=new Gm),t.forEach(function(r){var l=ig.bind(null,e,r);n.has(r)||(n.add(r),r.then(l,l))})}}function it(e,t){var n=t.deletions;if(n!==null)for(var r=0;rl&&(l=i),r&=~o}if(r=l,r=de()-r,r=(120>r?120:480>r?480:1080>r?1080:1920>r?1920:3e3>r?3e3:4320>r?4320:1960*qm(r/1960))-r,10e?16:e,Jt===null)var r=!1;else{if(e=Jt,Jt=null,xo=0,J&6)throw Error(j(331));var l=J;for(J|=4,I=e.current;I!==null;){var o=I,i=o.child;if(I.flags&16){var a=o.deletions;if(a!==null){for(var s=0;sde()-da?Sn(e,0):fa|=n),He(e,t)}function Td(e,t){t===0&&(e.mode&1?(t=Nl,Nl<<=1,!(Nl&130023424)&&(Nl=4194304)):t=1);var n=ze();e=Ot(e,t),e!==null&&(ol(e,t,n),He(e,n))}function og(e){var t=e.memoizedState,n=0;t!==null&&(n=t.retryLane),Td(e,n)}function ig(e,t){var n=0;switch(e.tag){case 13:var r=e.stateNode,l=e.memoizedState;l!==null&&(n=l.retryLane);break;case 19:r=e.stateNode;break;default:throw Error(j(314))}r!==null&&r.delete(t),Td(e,n)}var $d;$d=function(e,t,n){if(e!==null)if(e.memoizedProps!==t.pendingProps||Ue.current)Ae=!0;else{if(!(e.lanes&n)&&!(t.flags&128))return Ae=!1,Km(e,t,n);Ae=!!(e.flags&131072)}else Ae=!1,le&&t.flags&1048576&&Ff(t,fo,t.index);switch(t.lanes=0,t.tag){case 2:var r=t.type;Ql(e,t),e=t.pendingProps;var l=lr(t,Te.current);tr(t,n),l=oa(null,t,r,e,l,n);var o=ia();return t.flags|=1,typeof l=="object"&&l!==null&&typeof l.render=="function"&&l.$$typeof===void 0?(t.tag=1,t.memoizedState=null,t.updateQueue=null,Be(r)?(o=!0,uo(t)):o=!1,t.memoizedState=l.state!==null&&l.state!==void 0?l.state:null,ea(t),l.updater=Mo,t.stateNode=l,l._reactInternals=t,as(t,r,e,n),t=fs(null,t,r,!0,o,n)):(t.tag=0,le&&o&&Ks(t),Oe(null,t,l,n),t=t.child),t;case 16:r=t.elementType;e:{switch(Ql(e,t),e=t.pendingProps,l=r._init,r=l(r._payload),t.type=r,l=t.tag=ag(r),e=st(r,e),l){case 0:t=cs(null,t,r,e,n);break e;case 1:t=bu(null,t,r,e,n);break e;case 11:t=Hu(null,t,r,e,n);break e;case 14:t=Wu(null,t,r,st(r.type,e),n);break e}throw Error(j(306,r,""))}return t;case 0:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:st(r,l),cs(e,t,r,l,n);case 1:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:st(r,l),bu(e,t,r,l,n);case 3:e:{if(md(t),e===null)throw Error(j(387));r=t.pendingProps,o=t.memoizedState,l=o.element,Hf(e,t),mo(t,r,null,n);var i=t.memoizedState;if(r=i.element,o.isDehydrated)if(o={element:r,isDehydrated:!1,cache:i.cache,pendingSuspenseBoundaries:i.pendingSuspenseBoundaries,transitions:i.transitions},t.updateQueue.baseState=o,t.memoizedState=o,t.flags&256){l=ar(Error(j(423)),t),t=Vu(e,t,r,n,l);break e}else if(r!==l){l=ar(Error(j(424)),t),t=Vu(e,t,r,n,l);break e}else for(Qe=qt(t.stateNode.containerInfo.firstChild),Ke=t,le=!0,ut=null,n=Uf(t,null,r,n),t.child=n;n;)n.flags=n.flags&-3|4096,n=n.sibling;else{if(or(),r===l){t=zt(e,t,n);break e}Oe(e,t,r,n)}t=t.child}return t;case 5:return Wf(t),e===null&&os(t),r=t.type,l=t.pendingProps,o=e!==null?e.memoizedProps:null,i=l.children,es(r,l)?i=null:o!==null&&es(r,o)&&(t.flags|=32),hd(e,t),Oe(e,t,i,n),t.child;case 6:return e===null&&os(t),null;case 13:return gd(e,t,n);case 4:return ta(t,t.stateNode.containerInfo),r=t.pendingProps,e===null?t.child=ir(t,null,r,n):Oe(e,t,r,n),t.child;case 11:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:st(r,l),Hu(e,t,r,l,n);case 7:return Oe(e,t,t.pendingProps,n),t.child;case 8:return Oe(e,t,t.pendingProps.children,n),t.child;case 12:return Oe(e,t,t.pendingProps.children,n),t.child;case 10:e:{if(r=t.type._context,l=t.pendingProps,o=t.memoizedProps,i=l.value,ee(po,r._currentValue),r._currentValue=i,o!==null)if(dt(o.value,i)){if(o.children===l.children&&!Ue.current){t=zt(e,t,n);break e}}else for(o=t.child,o!==null&&(o.return=t);o!==null;){var a=o.dependencies;if(a!==null){i=o.child;for(var s=a.firstContext;s!==null;){if(s.context===r){if(o.tag===1){s=Rt(-1,n&-n),s.tag=2;var u=o.updateQueue;if(u!==null){u=u.shared;var h=u.pending;h===null?s.next=s:(s.next=h.next,h.next=s),u.pending=s}}o.lanes|=n,s=o.alternate,s!==null&&(s.lanes|=n),is(o.return,n,t),a.lanes|=n;break}s=s.next}}else if(o.tag===10)i=o.type===t.type?null:o.child;else if(o.tag===18){if(i=o.return,i===null)throw Error(j(341));i.lanes|=n,a=i.alternate,a!==null&&(a.lanes|=n),is(i,n,t),i=o.sibling}else i=o.child;if(i!==null)i.return=o;else for(i=o;i!==null;){if(i===t){i=null;break}if(o=i.sibling,o!==null){o.return=i.return,i=o;break}i=i.return}o=i}Oe(e,t,l.children,n),t=t.child}return t;case 9:return l=t.type,r=t.pendingProps.children,tr(t,n),l=nt(l),r=r(l),t.flags|=1,Oe(e,t,r,n),t.child;case 14:return r=t.type,l=st(r,t.pendingProps),l=st(r.type,l),Wu(e,t,r,l,n);case 15:return dd(e,t,t.type,t.pendingProps,n);case 17:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:st(r,l),Ql(e,t),t.tag=1,Be(r)?(e=!0,uo(t)):e=!1,tr(t,n),ud(t,r,l),as(t,r,l,n),fs(null,t,r,!0,e,n);case 19:return vd(e,t,n);case 22:return pd(e,t,n)}throw Error(j(156,t.tag))};function Md(e,t){return of(e,t)}function sg(e,t,n,r){this.tag=e,this.key=n,this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null,this.index=0,this.ref=null,this.pendingProps=t,this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null,this.mode=r,this.subtreeFlags=this.flags=0,this.deletions=null,this.childLanes=this.lanes=0,this.alternate=null}function et(e,t,n,r){return new sg(e,t,n,r)}function ga(e){return e=e.prototype,!(!e||!e.isReactComponent)}function ag(e){if(typeof e=="function")return ga(e)?1:0;if(e!=null){if(e=e.$$typeof,e===zs)return 11;if(e===Fs)return 14}return 2}function rn(e,t){var n=e.alternate;return n===null?(n=et(e.tag,t,e.key,e.mode),n.elementType=e.elementType,n.type=e.type,n.stateNode=e.stateNode,n.alternate=e,e.alternate=n):(n.pendingProps=t,n.type=e.type,n.flags=0,n.subtreeFlags=0,n.deletions=null),n.flags=e.flags&14680064,n.childLanes=e.childLanes,n.lanes=e.lanes,n.child=e.child,n.memoizedProps=e.memoizedProps,n.memoizedState=e.memoizedState,n.updateQueue=e.updateQueue,t=e.dependencies,n.dependencies=t===null?null:{lanes:t.lanes,firstContext:t.firstContext},n.sibling=e.sibling,n.index=e.index,n.ref=e.ref,n}function Jl(e,t,n,r,l,o){var i=2;if(r=e,typeof e=="function")ga(e)&&(i=1);else if(typeof e=="string")i=5;else e:switch(e){case Un:return xn(n.children,l,o,t);case Os:i=8,l|=8;break;case $i:return e=et(12,n,t,l|2),e.elementType=$i,e.lanes=o,e;case Mi:return e=et(13,n,t,l),e.elementType=Mi,e.lanes=o,e;case Oi:return e=et(19,n,t,l),e.elementType=Oi,e.lanes=o,e;case Hc:return Fo(n,l,o,t);default:if(typeof e=="object"&&e!==null)switch(e.$$typeof){case Uc:i=10;break e;case Bc:i=9;break e;case zs:i=11;break e;case Fs:i=14;break e;case bt:i=16,r=null;break e}throw Error(j(130,e==null?e:typeof e,""))}return t=et(i,n,t,l),t.elementType=e,t.type=r,t.lanes=o,t}function xn(e,t,n,r){return e=et(7,e,r,t),e.lanes=n,e}function Fo(e,t,n,r){return e=et(22,e,r,t),e.elementType=Hc,e.lanes=n,e.stateNode={isHidden:!1},e}function Ni(e,t,n){return e=et(6,e,null,t),e.lanes=n,e}function _i(e,t,n){return t=et(4,e.children!==null?e.children:[],e.key,t),t.lanes=n,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function ug(e,t,n,r,l){this.tag=t,this.containerInfo=e,this.finishedWork=this.pingCache=this.current=this.pendingChildren=null,this.timeoutHandle=-1,this.callbackNode=this.pendingContext=this.context=null,this.callbackPriority=0,this.eventTimes=ii(0),this.expirationTimes=ii(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=ii(0),this.identifierPrefix=r,this.onRecoverableError=l,this.mutableSourceEagerHydrationData=null}function va(e,t,n,r,l,o,i,a,s){return e=new ug(e,t,n,a,s),t===1?(t=1,o===!0&&(t|=8)):t=0,o=et(3,null,null,t),e.current=o,o.stateNode=e,o.memoizedState={element:r,isDehydrated:n,cache:null,transitions:null,pendingSuspenseBoundaries:null},ea(o),e}function cg(e,t,n){var r=3"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(Id)}catch(e){console.error(e)}}Id(),Fc.exports=Je;var Dd=Fc.exports,Ad,rc=Dd;Ad=rc.createRoot,rc.hydrateRoot;/** + * react-router v7.8.2 + * + * Copyright (c) Remix Software Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE.md file in the root directory of this source tree. + * + * @license MIT + */var lc="popstate";function mg(e={}){function t(l,o){let{pathname:i="/",search:a="",hash:s=""}=jn(l.location.hash.substring(1));return!i.startsWith("/")&&!i.startsWith(".")&&(i="/"+i),Es("",{pathname:i,search:a,hash:s},o.state&&o.state.usr||null,o.state&&o.state.key||"default")}function n(l,o){let i=l.document.querySelector("base"),a="";if(i&&i.getAttribute("href")){let s=l.location.href,u=s.indexOf("#");a=u===-1?s:s.slice(0,u)}return a+"#"+(typeof o=="string"?o:nl(o))}function r(l,o){pt(l.pathname.charAt(0)==="/",`relative pathnames are not supported in hash history.push(${JSON.stringify(o)})`)}return vg(t,n,r,e)}function ae(e,t){if(e===!1||e===null||typeof e>"u")throw new Error(t)}function pt(e,t){if(!e){typeof console<"u"&&console.warn(t);try{throw new Error(t)}catch{}}}function gg(){return Math.random().toString(36).substring(2,10)}function oc(e,t){return{usr:e.state,key:e.key,idx:t}}function Es(e,t,n=null,r){return{pathname:typeof e=="string"?e:e.pathname,search:"",hash:"",...typeof t=="string"?jn(t):t,state:n,key:t&&t.key||r||gg()}}function nl({pathname:e="/",search:t="",hash:n=""}){return t&&t!=="?"&&(e+=t.charAt(0)==="?"?t:"?"+t),n&&n!=="#"&&(e+=n.charAt(0)==="#"?n:"#"+n),e}function jn(e){let t={};if(e){let n=e.indexOf("#");n>=0&&(t.hash=e.substring(n),e=e.substring(0,n));let r=e.indexOf("?");r>=0&&(t.search=e.substring(r),e=e.substring(0,r)),e&&(t.pathname=e)}return t}function vg(e,t,n,r={}){let{window:l=document.defaultView,v5Compat:o=!1}=r,i=l.history,a="POP",s=null,u=h();u==null&&(u=0,i.replaceState({...i.state,idx:u},""));function h(){return(i.state||{idx:null}).idx}function v(){a="POP";let L=h(),m=L==null?null:L-u;u=L,s&&s({action:a,location:k.location,delta:m})}function y(L,m){a="PUSH";let f=Es(k.location,L,m);n&&n(f,L),u=h()+1;let d=oc(f,u),C=k.createHref(f);try{i.pushState(d,"",C)}catch(P){if(P instanceof DOMException&&P.name==="DataCloneError")throw P;l.location.assign(C)}o&&s&&s({action:a,location:k.location,delta:1})}function x(L,m){a="REPLACE";let f=Es(k.location,L,m);n&&n(f,L),u=h();let d=oc(f,u),C=k.createHref(f);i.replaceState(d,"",C),o&&s&&s({action:a,location:k.location,delta:0})}function E(L){return yg(L)}let k={get action(){return a},get location(){return e(l,i)},listen(L){if(s)throw new Error("A history only accepts one active listener");return l.addEventListener(lc,v),s=L,()=>{l.removeEventListener(lc,v),s=null}},createHref(L){return t(l,L)},createURL:E,encodeLocation(L){let m=E(L);return{pathname:m.pathname,search:m.search,hash:m.hash}},push:y,replace:x,go(L){return i.go(L)}};return k}function yg(e,t=!1){let n="http://localhost";typeof window<"u"&&(n=window.location.origin!=="null"?window.location.origin:window.location.href),ae(n,"No window.location.(origin|href) available to create URL");let r=typeof e=="string"?e:nl(e);return r=r.replace(/ $/,"%20"),!t&&r.startsWith("//")&&(r=n+r),new URL(r,n)}function Ud(e,t,n="/"){return wg(e,t,n,!1)}function wg(e,t,n,r){let l=typeof t=="string"?jn(t):t,o=Ft(l.pathname||"/",n);if(o==null)return null;let i=Bd(e);Sg(i);let a=null;for(let s=0;a==null&&s{let h={relativePath:u===void 0?i.path||"":u,caseSensitive:i.caseSensitive===!0,childrenIndex:a,route:i};if(h.relativePath.startsWith("/")){if(!h.relativePath.startsWith(r)&&s)return;ae(h.relativePath.startsWith(r),`Absolute route path "${h.relativePath}" nested under path "${r}" is not valid. An absolute child route path must start with the combined path of all its parent routes.`),h.relativePath=h.relativePath.slice(r.length)}let v=Tt([r,h.relativePath]),y=n.concat(h);i.children&&i.children.length>0&&(ae(i.index!==!0,`Index routes must not have child routes. Please remove all child routes from route path "${v}".`),Bd(i.children,t,y,v,s)),!(i.path==null&&!i.index)&&t.push({path:v,score:Lg(v,i.index),routesMeta:y})};return e.forEach((i,a)=>{var s;if(i.path===""||!((s=i.path)!=null&&s.includes("?")))o(i,a);else for(let u of Hd(i.path))o(i,a,!0,u)}),t}function Hd(e){let t=e.split("/");if(t.length===0)return[];let[n,...r]=t,l=n.endsWith("?"),o=n.replace(/\?$/,"");if(r.length===0)return l?[o,""]:[o];let i=Hd(r.join("/")),a=[];return a.push(...i.map(s=>s===""?o:[o,s].join("/"))),l&&a.push(...i),a.map(s=>e.startsWith("/")&&s===""?"/":s)}function Sg(e){e.sort((t,n)=>t.score!==n.score?n.score-t.score:Pg(t.routesMeta.map(r=>r.childrenIndex),n.routesMeta.map(r=>r.childrenIndex)))}var xg=/^:[\w-]+$/,kg=3,Eg=2,Cg=1,Ng=10,_g=-2,ic=e=>e==="*";function Lg(e,t){let n=e.split("/"),r=n.length;return n.some(ic)&&(r+=_g),t&&(r+=Eg),n.filter(l=>!ic(l)).reduce((l,o)=>l+(xg.test(o)?kg:o===""?Cg:Ng),r)}function Pg(e,t){return e.length===t.length&&e.slice(0,-1).every((r,l)=>r===t[l])?e[e.length-1]-t[t.length-1]:0}function jg(e,t,n=!1){let{routesMeta:r}=e,l={},o="/",i=[];for(let a=0;a{if(h==="*"){let E=a[y]||"";i=o.slice(0,o.length-E.length).replace(/(.)\/+$/,"$1")}const x=a[y];return v&&!x?u[h]=void 0:u[h]=(x||"").replace(/%2F/g,"/"),u},{}),pathname:o,pathnameBase:i,pattern:e}}function Rg(e,t=!1,n=!0){pt(e==="*"||!e.endsWith("*")||e.endsWith("/*"),`Route path "${e}" will be treated as if it were "${e.replace(/\*$/,"/*")}" because the \`*\` character must always follow a \`/\` in the pattern. To get rid of this warning, please change the route path to "${e.replace(/\*$/,"/*")}".`);let r=[],l="^"+e.replace(/\/*\*?$/,"").replace(/^\/*/,"/").replace(/[\\.*+^${}|()[\]]/g,"\\$&").replace(/\/:([\w-]+)(\?)?/g,(i,a,s)=>(r.push({paramName:a,isOptional:s!=null}),s?"/?([^\\/]+)?":"/([^\\/]+)")).replace(/\/([\w-]+)\?(\/|$)/g,"(/$1)?$2");return e.endsWith("*")?(r.push({paramName:"*"}),l+=e==="*"||e==="/*"?"(.*)$":"(?:\\/(.+)|\\/*)$"):n?l+="\\/*$":e!==""&&e!=="/"&&(l+="(?:(?=\\/|$))"),[new RegExp(l,t?void 0:"i"),r]}function Tg(e){try{return e.split("/").map(t=>decodeURIComponent(t).replace(/\//g,"%2F")).join("/")}catch(t){return pt(!1,`The URL path "${e}" could not be decoded because it is a malformed URL segment. This is probably due to a bad percent encoding (${t}).`),e}}function Ft(e,t){if(t==="/")return e;if(!e.toLowerCase().startsWith(t.toLowerCase()))return null;let n=t.endsWith("/")?t.length-1:t.length,r=e.charAt(n);return r&&r!=="/"?null:e.slice(n)||"/"}function $g(e,t="/"){let{pathname:n,search:r="",hash:l=""}=typeof e=="string"?jn(e):e;return{pathname:n?n.startsWith("/")?n:Mg(n,t):t,search:Fg(r),hash:Ig(l)}}function Mg(e,t){let n=t.replace(/\/+$/,"").split("/");return e.split("/").forEach(l=>{l===".."?n.length>1&&n.pop():l!=="."&&n.push(l)}),n.length>1?n.join("/"):"/"}function Li(e,t,n,r){return`Cannot include a '${e}' character in a manually specified \`to.${t}\` field [${JSON.stringify(r)}]. Please separate it out to the \`to.${n}\` field. Alternatively you may provide the full path as a string in and the router will parse it for you.`}function Og(e){return e.filter((t,n)=>n===0||t.route.path&&t.route.path.length>0)}function Wd(e){let t=Og(e);return t.map((n,r)=>r===t.length-1?n.pathname:n.pathnameBase)}function bd(e,t,n,r=!1){let l;typeof e=="string"?l=jn(e):(l={...e},ae(!l.pathname||!l.pathname.includes("?"),Li("?","pathname","search",l)),ae(!l.pathname||!l.pathname.includes("#"),Li("#","pathname","hash",l)),ae(!l.search||!l.search.includes("#"),Li("#","search","hash",l)));let o=e===""||l.pathname==="",i=o?"/":l.pathname,a;if(i==null)a=n;else{let v=t.length-1;if(!r&&i.startsWith("..")){let y=i.split("/");for(;y[0]==="..";)y.shift(),v-=1;l.pathname=y.join("/")}a=v>=0?t[v]:"/"}let s=$g(l,a),u=i&&i!=="/"&&i.endsWith("/"),h=(o||i===".")&&n.endsWith("/");return!s.pathname.endsWith("/")&&(u||h)&&(s.pathname+="/"),s}var Tt=e=>e.join("/").replace(/\/\/+/g,"/"),zg=e=>e.replace(/\/+$/,"").replace(/^\/*/,"/"),Fg=e=>!e||e==="?"?"":e.startsWith("?")?e:"?"+e,Ig=e=>!e||e==="#"?"":e.startsWith("#")?e:"#"+e;function Dg(e){return e!=null&&typeof e.status=="number"&&typeof e.statusText=="string"&&typeof e.internal=="boolean"&&"data"in e}var Vd=["POST","PUT","PATCH","DELETE"];new Set(Vd);var Ag=["GET",...Vd];new Set(Ag);var pr=g.createContext(null);pr.displayName="DataRouter";var Bo=g.createContext(null);Bo.displayName="DataRouterState";g.createContext(!1);var Qd=g.createContext({isTransitioning:!1});Qd.displayName="ViewTransition";var Ug=g.createContext(new Map);Ug.displayName="Fetchers";var Bg=g.createContext(null);Bg.displayName="Await";var kt=g.createContext(null);kt.displayName="Navigation";var ul=g.createContext(null);ul.displayName="Location";var Dt=g.createContext({outlet:null,matches:[],isDataRoute:!1});Dt.displayName="Route";var xa=g.createContext(null);xa.displayName="RouteError";function Hg(e,{relative:t}={}){ae(cl(),"useHref() may be used only in the context of a component.");let{basename:n,navigator:r}=g.useContext(kt),{hash:l,pathname:o,search:i}=fl(e,{relative:t}),a=o;return n!=="/"&&(a=o==="/"?n:Tt([n,o])),r.createHref({pathname:a,search:i,hash:l})}function cl(){return g.useContext(ul)!=null}function Rn(){return ae(cl(),"useLocation() may be used only in the context of a component."),g.useContext(ul).location}var Kd="You should call navigate() in a React.useEffect(), not when your component is first rendered.";function Yd(e){g.useContext(kt).static||g.useLayoutEffect(e)}function Wg(){let{isDataRoute:e}=g.useContext(Dt);return e?nv():bg()}function bg(){ae(cl(),"useNavigate() may be used only in the context of a component.");let e=g.useContext(pr),{basename:t,navigator:n}=g.useContext(kt),{matches:r}=g.useContext(Dt),{pathname:l}=Rn(),o=JSON.stringify(Wd(r)),i=g.useRef(!1);return Yd(()=>{i.current=!0}),g.useCallback((s,u={})=>{if(pt(i.current,Kd),!i.current)return;if(typeof s=="number"){n.go(s);return}let h=bd(s,JSON.parse(o),l,u.relative==="path");e==null&&t!=="/"&&(h.pathname=h.pathname==="/"?t:Tt([t,h.pathname])),(u.replace?n.replace:n.push)(h,u.state,u)},[t,n,o,l,e])}g.createContext(null);function fl(e,{relative:t}={}){let{matches:n}=g.useContext(Dt),{pathname:r}=Rn(),l=JSON.stringify(Wd(n));return g.useMemo(()=>bd(e,JSON.parse(l),r,t==="path"),[e,l,r,t])}function Vg(e,t){return Jd(e,t)}function Jd(e,t,n,r,l){var f;ae(cl(),"useRoutes() may be used only in the context of a component.");let{navigator:o}=g.useContext(kt),{matches:i}=g.useContext(Dt),a=i[i.length-1],s=a?a.params:{},u=a?a.pathname:"/",h=a?a.pathnameBase:"/",v=a&&a.route;{let d=v&&v.path||"";Gd(u,!v||d.endsWith("*")||d.endsWith("*?"),`You rendered descendant (or called \`useRoutes()\`) at "${u}" (under ) but the parent route path has no trailing "*". This means if you navigate deeper, the parent won't match anymore and therefore the child routes will never render. + +Please change the parent to .`)}let y=Rn(),x;if(t){let d=typeof t=="string"?jn(t):t;ae(h==="/"||((f=d.pathname)==null?void 0:f.startsWith(h)),`When overriding the location using \`\` or \`useRoutes(routes, location)\`, the location pathname must begin with the portion of the URL pathname that was matched by all parent routes. The current pathname base is "${h}" but pathname "${d.pathname}" was given in the \`location\` prop.`),x=d}else x=y;let E=x.pathname||"/",k=E;if(h!=="/"){let d=h.replace(/^\//,"").split("/");k="/"+E.replace(/^\//,"").split("/").slice(d.length).join("/")}let L=Ud(e,{pathname:k});pt(v||L!=null,`No routes matched location "${x.pathname}${x.search}${x.hash}" `),pt(L==null||L[L.length-1].route.element!==void 0||L[L.length-1].route.Component!==void 0||L[L.length-1].route.lazy!==void 0,`Matched leaf route at location "${x.pathname}${x.search}${x.hash}" does not have an element or Component. This means it will render an with a null value by default resulting in an "empty" page.`);let m=Gg(L&&L.map(d=>Object.assign({},d,{params:Object.assign({},s,d.params),pathname:Tt([h,o.encodeLocation?o.encodeLocation(d.pathname).pathname:d.pathname]),pathnameBase:d.pathnameBase==="/"?h:Tt([h,o.encodeLocation?o.encodeLocation(d.pathnameBase).pathname:d.pathnameBase])})),i,n,r,l);return t&&m?g.createElement(ul.Provider,{value:{location:{pathname:"/",search:"",hash:"",state:null,key:"default",...x},navigationType:"POP"}},m):m}function Qg(){let e=tv(),t=Dg(e)?`${e.status} ${e.statusText}`:e instanceof Error?e.message:JSON.stringify(e),n=e instanceof Error?e.stack:null,r="rgba(200,200,200, 0.5)",l={padding:"0.5rem",backgroundColor:r},o={padding:"2px 4px",backgroundColor:r},i=null;return console.error("Error handled by React Router default ErrorBoundary:",e),i=g.createElement(g.Fragment,null,g.createElement("p",null,"💿 Hey developer 👋"),g.createElement("p",null,"You can provide a way better UX than this when your app throws errors by providing your own ",g.createElement("code",{style:o},"ErrorBoundary")," or"," ",g.createElement("code",{style:o},"errorElement")," prop on your route.")),g.createElement(g.Fragment,null,g.createElement("h2",null,"Unexpected Application Error!"),g.createElement("h3",{style:{fontStyle:"italic"}},t),n?g.createElement("pre",{style:l},n):null,i)}var Kg=g.createElement(Qg,null),Yg=class extends g.Component{constructor(e){super(e),this.state={location:e.location,revalidation:e.revalidation,error:e.error}}static getDerivedStateFromError(e){return{error:e}}static getDerivedStateFromProps(e,t){return t.location!==e.location||t.revalidation!=="idle"&&e.revalidation==="idle"?{error:e.error,location:e.location,revalidation:e.revalidation}:{error:e.error!==void 0?e.error:t.error,location:t.location,revalidation:e.revalidation||t.revalidation}}componentDidCatch(e,t){this.props.unstable_onError?this.props.unstable_onError(e,t):console.error("React Router caught the following error during render",e)}render(){return this.state.error!==void 0?g.createElement(Dt.Provider,{value:this.props.routeContext},g.createElement(xa.Provider,{value:this.state.error,children:this.props.component})):this.props.children}};function Jg({routeContext:e,match:t,children:n}){let r=g.useContext(pr);return r&&r.static&&r.staticContext&&(t.route.errorElement||t.route.ErrorBoundary)&&(r.staticContext._deepestRenderedBoundaryId=t.route.id),g.createElement(Dt.Provider,{value:e},n)}function Gg(e,t=[],n=null,r=null,l=null){if(e==null){if(!n)return null;if(n.errors)e=n.matches;else if(t.length===0&&!n.initialized&&n.matches.length>0)e=n.matches;else return null}let o=e,i=n==null?void 0:n.errors;if(i!=null){let u=o.findIndex(h=>h.route.id&&(i==null?void 0:i[h.route.id])!==void 0);ae(u>=0,`Could not find a matching route for errors on route IDs: ${Object.keys(i).join(",")}`),o=o.slice(0,Math.min(o.length,u+1))}let a=!1,s=-1;if(n)for(let u=0;u=0?o=o.slice(0,s+1):o=[o[0]];break}}}return o.reduceRight((u,h,v)=>{let y,x=!1,E=null,k=null;n&&(y=i&&h.route.id?i[h.route.id]:void 0,E=h.route.errorElement||Kg,a&&(s<0&&v===0?(Gd("route-fallback",!1,"No `HydrateFallback` element provided to render during initial hydration"),x=!0,k=null):s===v&&(x=!0,k=h.route.hydrateFallbackElement||null)));let L=t.concat(o.slice(0,v+1)),m=()=>{let f;return y?f=E:x?f=k:h.route.Component?f=g.createElement(h.route.Component,null):h.route.element?f=h.route.element:f=u,g.createElement(Jg,{match:h,routeContext:{outlet:u,matches:L,isDataRoute:n!=null},children:f})};return n&&(h.route.ErrorBoundary||h.route.errorElement||v===0)?g.createElement(Yg,{location:n.location,revalidation:n.revalidation,component:E,error:y,children:m(),routeContext:{outlet:null,matches:L,isDataRoute:!0},unstable_onError:r}):m()},null)}function ka(e){return`${e} must be used within a data router. See https://reactrouter.com/en/main/routers/picking-a-router.`}function Xg(e){let t=g.useContext(pr);return ae(t,ka(e)),t}function Zg(e){let t=g.useContext(Bo);return ae(t,ka(e)),t}function qg(e){let t=g.useContext(Dt);return ae(t,ka(e)),t}function Ea(e){let t=qg(e),n=t.matches[t.matches.length-1];return ae(n.route.id,`${e} can only be used on routes that contain a unique "id"`),n.route.id}function ev(){return Ea("useRouteId")}function tv(){var r;let e=g.useContext(xa),t=Zg("useRouteError"),n=Ea("useRouteError");return e!==void 0?e:(r=t.errors)==null?void 0:r[n]}function nv(){let{router:e}=Xg("useNavigate"),t=Ea("useNavigate"),n=g.useRef(!1);return Yd(()=>{n.current=!0}),g.useCallback(async(l,o={})=>{pt(n.current,Kd),n.current&&(typeof l=="number"?e.navigate(l):await e.navigate(l,{fromRouteId:t,...o}))},[e,t])}var sc={};function Gd(e,t,n){!t&&!sc[e]&&(sc[e]=!0,pt(!1,n))}g.memo(rv);function rv({routes:e,future:t,state:n,unstable_onError:r}){return Jd(e,void 0,n,r,t)}function Xd(e){ae(!1,"A is only ever to be used as the child of element, never rendered directly. Please wrap your in a .")}function lv({basename:e="/",children:t=null,location:n,navigationType:r="POP",navigator:l,static:o=!1}){ae(!cl(),"You cannot render a inside another . You should never have more than one in your app.");let i=e.replace(/^\/*/,"/"),a=g.useMemo(()=>({basename:i,navigator:l,static:o,future:{}}),[i,l,o]);typeof n=="string"&&(n=jn(n));let{pathname:s="/",search:u="",hash:h="",state:v=null,key:y="default"}=n,x=g.useMemo(()=>{let E=Ft(s,i);return E==null?null:{location:{pathname:E,search:u,hash:h,state:v,key:y},navigationType:r}},[i,s,u,h,v,y,r]);return pt(x!=null,` is not able to match the URL "${s}${u}${h}" because it does not start with the basename, so the won't render anything.`),x==null?null:g.createElement(kt.Provider,{value:a},g.createElement(ul.Provider,{children:t,value:x}))}function ov({children:e,location:t}){return Vg(Cs(e),t)}function Cs(e,t=[]){let n=[];return g.Children.forEach(e,(r,l)=>{if(!g.isValidElement(r))return;let o=[...t,l];if(r.type===g.Fragment){n.push.apply(n,Cs(r.props.children,o));return}ae(r.type===Xd,`[${typeof r.type=="string"?r.type:r.type.name}] is not a component. All component children of must be a or `),ae(!r.props.index||!r.props.children,"An index route cannot have child routes.");let i={id:r.props.id||o.join("-"),caseSensitive:r.props.caseSensitive,element:r.props.element,Component:r.props.Component,index:r.props.index,path:r.props.path,loader:r.props.loader,action:r.props.action,hydrateFallbackElement:r.props.hydrateFallbackElement,HydrateFallback:r.props.HydrateFallback,errorElement:r.props.errorElement,ErrorBoundary:r.props.ErrorBoundary,hasErrorBoundary:r.props.hasErrorBoundary===!0||r.props.ErrorBoundary!=null||r.props.errorElement!=null,shouldRevalidate:r.props.shouldRevalidate,handle:r.props.handle,lazy:r.props.lazy};r.props.children&&(i.children=Cs(r.props.children,o)),n.push(i)}),n}var Gl="get",Xl="application/x-www-form-urlencoded";function Ho(e){return e!=null&&typeof e.tagName=="string"}function iv(e){return Ho(e)&&e.tagName.toLowerCase()==="button"}function sv(e){return Ho(e)&&e.tagName.toLowerCase()==="form"}function av(e){return Ho(e)&&e.tagName.toLowerCase()==="input"}function uv(e){return!!(e.metaKey||e.altKey||e.ctrlKey||e.shiftKey)}function cv(e,t){return e.button===0&&(!t||t==="_self")&&!uv(e)}var Il=null;function fv(){if(Il===null)try{new FormData(document.createElement("form"),0),Il=!1}catch{Il=!0}return Il}var dv=new Set(["application/x-www-form-urlencoded","multipart/form-data","text/plain"]);function Pi(e){return e!=null&&!dv.has(e)?(pt(!1,`"${e}" is not a valid \`encType\` for \`\`/\`\` and will default to "${Xl}"`),null):e}function pv(e,t){let n,r,l,o,i;if(sv(e)){let a=e.getAttribute("action");r=a?Ft(a,t):null,n=e.getAttribute("method")||Gl,l=Pi(e.getAttribute("enctype"))||Xl,o=new FormData(e)}else if(iv(e)||av(e)&&(e.type==="submit"||e.type==="image")){let a=e.form;if(a==null)throw new Error('Cannot submit a
`,E=`
${y}
`;return`
${x}${E}
`}),i=i.replace(/
\s*(?=
]*>[\s\S]*?<\/div>)\s*
/g,"$1"),i}function hy(e){const t=e.split(/\r?\n/);let n=null;for(let r=0;r/i,n=/<\/think(?:ing)?>/i,r=e.match(t);if(!r)return{think:null,answer:e};const l=r.index,o=r[0].length,i=e.substring(0,l).trim();let a=e.substring(l+o);const s=a.match(n);let u=null,h=i;return s?(u=a.substring(0,s.index).trim(),h+=a.substring(s.index+s[0].length)):u=a.trim(),{think:u||null,answer:h.trim()}}function my({content:e,streamOutput:t,sources:n}){const{think:r,answer:l}=sp(e||""),[o,i]=Me.useState(!1),a=!!r;return p.jsxs("div",{className:"assistant-message",children:[a&&p.jsxs("div",{className:"assistant-thoughts",children:[p.jsxs("button",{className:"think-toggle",onClick:()=>i(s=>!s),"aria-expanded":o?"true":"false","aria-controls":"think-content",children:[p.jsx("span",{className:"think-toggle-icon","aria-hidden":"true",children:o?"▾":"▸"}),"Thoughts"]}),o&&p.jsx("div",{id:"think-content",className:"think-content",dangerouslySetInnerHTML:{__html:Sc(r)}})]}),p.jsx("div",{className:"msg-content",dangerouslySetInnerHTML:{__html:Sc(l||e||"")}}),Array.isArray(n)&&n.length>0&&p.jsx("div",{className:"msg-sources chips",children:n.map((s,u)=>{let h=s,v=!1;try{const y=new URL(s);if(y.protocol==="file:"){v=!0;const x=y.pathname.split("/").filter(Boolean);h=decodeURIComponent(x[x.length-1]||s)}else h=(y.hostname||s).replace(/^www\./i,"")}catch{}return p.jsx("a",{className:"chip",href:s,target:"_blank",rel:"noreferrer",title:s,onClick:y=>{var x,E;if(v){y.preventDefault();try{const k=new URL(s);(E=(x=window.electronAPI)==null?void 0:x.openPath)==null||E.call(x,decodeURIComponent(k.pathname))}catch{}}},children:h},s+u)})})]})}const xc="websearch.searxUrl",kc="websearch.engines",Ec="chat.libraryBySession",Cc="http://127.0.0.1:8888";let ap="http://127.0.0.1:8000";const gy=48,vy=24;function yy(e){return e.backendApiUrl||e.ollamaApiUrl||ap}function wy(e){const t=typeof e=="string"?e.trim():"";return!t||t==="http://localhost:8888"?Cc:t}function Sy(){var Ya;const[e,t]=g.useState([]),[n,r]=g.useState(null),[l,o]=g.useState("chats"),[i,a]=g.useState("General"),[s,u]=g.useState(null),[h,v]=g.useState(null),[y,x]=g.useState([]),[E,k]=g.useState([]),[L,m]=g.useState(null),[f,d]=g.useState(()=>{try{const c=localStorage.getItem(Ec);return c?JSON.parse(c):{}}catch{return{}}}),[C,P]=g.useState(!1),[M,z]=g.useState(""),[F,B]=g.useState(""),[D,q]=g.useState(!1),[ge,We]=g.useState(""),[be,N]=g.useState(""),T=g.useRef(null),H=g.useRef(null),R=g.useRef(null),[O,b]=g.useState(ap),[Z,pe]=g.useState("Default"),[Et,ht]=g.useState(!1),[Tn,lt]=g.useState(""),[mt,up]=g.useState(()=>wy(localStorage.getItem(xc))),[cn,cp]=g.useState(()=>{try{const c=localStorage.getItem(kc);if(c)return JSON.parse(c)}catch{}return["duckduckgo","bing","wikipedia","github","stack_overflow"]});g.useEffect(()=>{localStorage.setItem(xc,mt||"")},[mt]),g.useEffect(()=>{try{localStorage.setItem(kc,JSON.stringify(cn||[]))}catch{}},[cn]);const[dl,fp]=g.useState(!1),[At,Wo]=g.useState(!1),[Ey,bo]=g.useState(!0),[dp,$n]=g.useState([]),[pl,La]=g.useState({}),[Pa,pp]=g.useState(!1),ja=g.useRef(!1),[hp,Vo]=g.useState(null),[Qo,hl]=g.useState("");function mp(c){const w=c.content||"";if(c.role==="assistant")try{const{answer:S}=sp(w);return(S||w).trim()}catch{return w.trim()}return w}async function Ra(c){try{await navigator.clipboard.writeText(mp(c))}catch(w){console.error("Failed to copy message:",w)}}function fn(c,w,S,_={}){const{removeIfEmpty:$=!1}=_;t(A=>A.map(W=>{if(W.session_id!==c)return W;const U=[];for(const V of W.messages||[]){if(V.id!==w){U.push(V);continue}$&&!S||U.push({...V,content:S})}return{...W,messages:U}}))}function Ut(c){return(c==null?void 0:c.name)==="AbortError"}function ml(c){return c instanceof Error&&c.message?c.message:String(c)}async function Ko(c){const w=await c.json().catch(()=>null);if(c.ok)return w;const S=typeof(w==null?void 0:w.detail)=="string"?w.detail:typeof(w==null?void 0:w.message)=="string"?w.message:"";throw new Error(S||`HTTP ${c.status}`)}async function gp(){const c=await fetch(`${O}/ollama/startup-status`);return Ko(c)}async function Ta(c,w,S){if(!c)return{contextBlock:null,sources:[]};const $=await(await fetch(`${O}/libraries/${c}/context`,{method:"POST",headers:{"Content-Type":"application/json"},signal:S,body:JSON.stringify({prompt:w,top_k:5})})).json();return{contextBlock:typeof($==null?void 0:$.context_block)=="string"&&$.context_block.trim()?$.context_block.trim():null,sources:Array.isArray($==null?void 0:$.sources)?$.sources:[]}}function vp(c,w){Vo(c),hl(w||"")}function gl(){Vo(null),hl("")}async function yp(c){var A;const w=(((A=Fn[c])==null?void 0:A.content)||"").trim(),_=(Qo??"").trim();if(_.length===0){gl();return}if(_===w){gl();return}const $=n;if($){t(W=>W.map(U=>{if(U.session_id!==$)return U;const Le=(U.messages||[]).slice(0,c+1).map((ve,Xe)=>Xe===c?{...ve,content:_}:ve);return{...U,messages:Le}})),Vo(null),hl(""),requestAnimationFrame(()=>qo("auto",$));try{const W=await fetch(`${O}/sessions/${$}/messages/${c}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({message:_})});if(!W.ok)throw new Error(`HTTP ${W.status}`)}catch(W){console.error("Failed to update message:",W),t(U=>U.map(V=>{if(V.session_id!==$)return V;const ve=(V.messages||[]).map((Xe,Q)=>Q===c?{...Xe,content:w}:Xe);return{...V,messages:ve}}));return}await $a(c,_)}}async function $a(c,w=null){var Le,ve,Xe,Q,fe,ke;const S=n;if(At||!S||typeof c!="number")return;const _=((Le=e.find(G=>G.session_id===S))==null?void 0:Le.messages)||[];let $=c;for(let G=c;G>=0;G--)if(((ve=_[G])==null?void 0:ve.role)==="user"){$=G;break}t(G=>G.map(oe=>oe.session_id===S?{...oe,messages:(oe.messages||[]).slice(0,$+1)}:oe));const A=Da(S);let W=w??(((Xe=_[$])==null?void 0:Xe.content)||""),U=[];const V=[];try{const G=Ha(S),oe=w??(((Q=_[$])==null?void 0:Q.content)||"");if((fe=G==null?void 0:G.states)!=null&&fe.is_indexed)try{const K=await Ta(G.slug,oe,A.signal);K.contextBlock&&V.push(K.contextBlock),Array.isArray(K.sources)&&U.push(...K.sources)}catch(K){if(Ut(K))throw K;console.warn("local library enrichment (regenerate) failed",K)}if(dl)try{const K=_.slice(Math.max(0,$-7),$+1).map(he=>({role:he.role,content:he.content||""}));K.length>0&&(K[K.length-1]={role:"user",content:oe});const te=await(await fetch(`${O}/websearch`,{method:"POST",headers:{"Content-Type":"application/json"},signal:A.signal,body:JSON.stringify({prompt:oe,model:ge,messages:K,history_limit:8,searx_url:mt||null,engines:Array.isArray(cn)?cn:null})})).json();te&&typeof te.context_block=="string"&&te.context_block.trim()&&V.push(te.context_block.trim()),Array.isArray(te==null?void 0:te.sources)&&U.push(...te.sources)}catch(K){if(Ut(K))throw K;console.warn("web search enrichment (regenerate) failed",K)}if(U=[...new Set(U)],V.length>0?W=`${oe} + +${V.join(` + +`)}`:W=null,Et){const K=`msg-${Date.now()}-${Math.random()}`;let Nt="";t(te=>te.map(he=>he.session_id===S?{...he,messages:[...he.messages||[],{id:K,role:"assistant",content:"",sources:U}]}:he));try{const te=await fetch(`${O}/sessions/${S}/regenerate`,{method:"POST",headers:{"Content-Type":"application/json"},signal:A.signal,body:JSON.stringify({index:c,model:ge,stream:!0,enriched_message:W,sources:U||[]})});if(!te.ok)throw new Error(`HTTP ${te.status}`);const he=(ke=te.body)==null?void 0:ke.getReader();if(!he)throw new Error("Missing response body");const Ht=new TextDecoder;let gt=!1;for(;;){const{value:hn,done:Bp}=await he.read();if(Bp)break;const Hp=Ht.decode(hn,{stream:!0});Nt+=Hp,fn(S,K,Nt),!gt&&_e.current!==S&&(gt=!0,dn(ei=>({...ei,[S]:K})),$n(ei=>[...new Set([...ei,S])]))}_e.current!==S?(dn(hn=>({...hn,[S]:K})),$n(hn=>[...new Set([...hn,S])])):Mn.current[S]?On(hn=>({...hn,[S]:K})):requestAnimationFrame(()=>In(K,"smooth",S))}catch(te){if(Ut(te)){fn(S,K,Nt,{removeIfEmpty:!0});return}console.error(te),fn(S,K,`Error: ${ml(te)}`,{removeIfEmpty:!0});return}}else{const K=await fetch(`${O}/sessions/${S}/regenerate`,{method:"POST",headers:{"Content-Type":"application/json"},signal:A.signal,body:JSON.stringify({index:c,model:ge,stream:!1,enriched_message:W,sources:U||[]})});if(!K.ok)throw new Error(`HTTP ${K.status}`);const Nt=await K.json(),te=`msg-${Date.now()}`;t(he=>he.map(Ht=>Ht.session_id===S?{...Ht,messages:[...Ht.messages||[],{role:"assistant",content:Nt.reply,id:te,sources:U}]}:Ht)),_e.current!==S?(dn(he=>({...he,[S]:te})),$n(he=>[...new Set([...he,S])])):Mn.current[S]?On(he=>({...he,[S]:te})):requestAnimationFrame(()=>In(te,"smooth",S))}}catch(G){Ut(G)||console.error(G)}finally{Yo(A)}}const[Ma,wp]=g.useState({}),Mn=g.useRef({}),[Sp,dn]=g.useState({}),pn=g.useRef({}),Oa=g.useRef({}),[za,On]=g.useState({}),[xp,Fa]=g.useState({}),Ia=(c,w,S)=>c!=null&&c.id?c.id:`${S}:${w}`;g.useEffect(()=>{var w;if(!n)return;const c=((w=e.find(S=>S.session_id===n))==null?void 0:w.messages)||[];Fa(S=>{const _={};return c.forEach(($,A)=>{if($.role!=="user")return;const W=Ia($,A,n),V=($.content||"").split(/\r\n|\r|\n/).length>30;_[W]=V?S[W]??!0:!1}),_})},[e,n]);function kp(c){Fa(w=>({...w,[c]:!(w[c]??!0)}))}const hr=Me.useCallback((c,w)=>{wp(S=>{const _={...S,[c]:w};return Mn.current=_,_})},[]),zn=g.useRef(null),Ep=g.useRef(!1),Cp=g.useRef(null),_e=g.useRef(n);g.useEffect(()=>{_e.current=n},[n]);const Da=Me.useCallback(c=>{const w=new AbortController;return zn.current={controller:w,sessionId:c},Wo(!0),w},[]),Yo=Me.useCallback(c=>{var w;((w=zn.current)==null?void 0:w.controller)===c&&(zn.current=null,Wo(!1))},[]),Np=Me.useCallback(()=>{const c=zn.current;c&&(zn.current=null,c.controller.abort(),Wo(!1))},[]);g.useEffect(()=>()=>{var c;(c=zn.current)==null||c.controller.abort()},[]);const Bt=g.useRef(null),[_p,Lp]=g.useState(230),[vl,Aa]=g.useState(!1),Pp=Me.useCallback(c=>{Aa(!0)},[]),Jo=Me.useCallback(()=>{Aa(!1)},[]),Go=Me.useCallback(c=>{if(vl){const w=Math.max(230,Math.min(500,c.clientX));Lp(w)}},[vl]);Me.useEffect(()=>(window.addEventListener("mousemove",Go),window.addEventListener("mouseup",Jo),()=>{window.removeEventListener("mousemove",Go),window.removeEventListener("mouseup",Jo)}),[Go,Jo]),Me.useEffect(()=>{vl?document.body.classList.add("no-select"):document.body.classList.remove("no-select")},[vl]),Me.useEffect(()=>{const c=async w=>{const S=w.target.closest(".codeblock__copy");if(!S)return;const _=S.closest(".codeblock"),$=_==null?void 0:_.querySelector("pre > code");if($)try{await navigator.clipboard.writeText($.textContent||""),S.classList.add("copied"),setTimeout(()=>S.classList.remove("copied"),800)}catch(A){console.error("Copy failed:",A)}};return document.addEventListener("click",c),()=>document.removeEventListener("click",c)},[]),g.useEffect(()=>{window.electronAPI.getSettings().then(w=>{b(yy(w)),pe(w.colorScheme||"Default"),We(w.chatModel||""),ht(w.streamOutput||!1),La(w.scrollPositions||{}),rl(w.colorScheme||"Default")}).finally(()=>{pp(!0)});const c=()=>{var w;l==="chats"&&((w=H.current)==null||w.focus())};return window.electronAPI.onWindowFocus(c),()=>{}},[l]),g.useEffect(()=>{if(!Pa||!O||ja.current)return;ja.current=!0;let c=!1;return(async()=>{let w=!1;try{let S=await gp();if(c)return;if(!(S!=null&&S.ollama_running)&&(S!=null&&S.can_manage_locally)){const _=window.confirm(`Ollama is not running at ${S.ollama_url}. Start it in the background now with "ollama serve"?`);if(c)return;if(_){w=!0,lt("Starting Ollama in the background...");const $=await fetch(`${O}/ollama/start`,{method:"POST"});if(S=await Ko($),c)return}}if(S!=null&&S.ollama_running&&!(S!=null&&S.embedding_model_available)&&(S!=null&&S.can_manage_locally)){const _=window.confirm(`The selected embedding model "${S.selected_embed_model}" is not installed in Ollama. Pull it now?`);if(c)return;if(_){w=!0,lt(`Pulling ${S.selected_embed_model} in Ollama...`);const $=await fetch(`${O}/ollama/pull`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:S.selected_embed_model})});if(await Ko($),c)return}}}catch(S){c||(console.warn("startup Ollama check failed",S),w&&window.alert(`Startup action failed: ${ml(S)}`))}finally{c||lt("")}})(),()=>{c=!0}},[O,Pa]),g.useEffect(()=>{rl(Z)},[Z]);const jp=c=>{!c||!O||fetch(`${O}/history?session_id=${encodeURIComponent(c)}`).then(w=>w.json()).then(w=>{t(S=>S.map(_=>_.session_id===c?{..._,messages:w.messages||[]}:_))}).catch(()=>{})};async function mr(){if(O)try{const w=await(await fetch(`${O}/libraries`)).json(),S=Array.isArray(w.libraries)?w.libraries:[];if(x(S),S.length===0){m(null);return}S.some(_=>_.slug===L)||m(S[0].slug)}catch(c){console.warn("Failed to load libraries",c)}}async function yl(){if(O)try{const w=await(await fetch(`${O}/jobs`)).json();k(Array.isArray(w.jobs)?w.jobs:[])}catch(c){console.warn("Failed to load library jobs",c)}}async function Ua(c=null){const S=(typeof c=="string"?c:M).trim();if(!S){B("Name is required.");return}try{B("");const _=await fetch(`${O}/libraries`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:S})});if(!_.ok){const A=await _.text();throw new Error(A||`HTTP ${_.status}`)}const $=await _.json();P(!1),z(""),await mr(),$!=null&&$.slug&&m($.slug)}catch(_){console.error("Failed to create library",_),B(String((_==null?void 0:_.message)||_))}}async function Rp(){x([]),k([]),m(null),v(null),q(!1),d({}),await mr(),await yl()}g.useEffect(()=>{O&&(bo(!0),fetch(`${O}/sessions`).then(c=>c.json()).then(c=>{const w=c.sessions.map(S=>({...S,messages:[]}));t(w),w.length>0?r(w[0].session_id):r(null),bo(!1)}).catch(()=>{bo(!1)}))},[O]),g.useEffect(()=>{O&&(mr(),yl())},[O]),g.useEffect(()=>{try{localStorage.setItem(Ec,JSON.stringify(f||{}))}catch{}},[f]),g.useEffect(()=>{if(!O)return;const c=setInterval(()=>{mr(),yl()},3e3);return()=>clearInterval(c)},[O,l,L]),g.useEffect(()=>{jp(n)},[n,O]),g.useEffect(()=>{const c=new Set(y.map(w=>w.slug));d(w=>{let S=!1;const _={};for(const[$,A]of Object.entries(w||{}))c.has(A)?_[$]=A:S=!0;return S?_:w})},[y]);const Xo=c=>{o(c)},Tp=c=>{Fp(c)},Fn=g.useMemo(()=>{var c;return((c=e.find(w=>w.session_id===n))==null?void 0:c.messages)||[]},[n,e]),wl=g.useMemo(()=>y.find(c=>c.slug===L)||null,[L,y]),Ct=n&&f[n]||null,ot=g.useMemo(()=>y.find(c=>c.slug===Ct)||null,[Ct,y]),Ba=g.useMemo(()=>Ct?E.some(c=>c.slug===Ct&&(c.status==="queued"||c.status==="running")):!1,[Ct,E]),Zo=g.useMemo(()=>{var c,w;return ot?(c=ot.files)!=null&&c.length?(w=ot.states)!=null&&w.is_indexed?"":Ba?" (syncing)":" (needs sync)":" (empty)":""},[ot,Ba]);function $p(c){return c&&f[c]||null}function Ha(c){const w=$p(c);return w&&y.find(S=>S.slug===w)||null}function Wa(c){return c?E.some(w=>w.slug===c&&(w.status==="queued"||w.status==="running")):!1}function ba(c,w){c&&d(S=>{const _={...S||{}};return w?_[c]=w:delete _[c],_})}function Mp(c){c&&d(w=>{let S=!1;const _={};for(const[$,A]of Object.entries(w||{})){if(A===c){S=!0;continue}_[$]=A}return S?_:w})}g.useEffect(()=>{if(!D)return;const c=w=>{var S;(S=R.current)!=null&&S.contains(w.target)||q(!1)};return document.addEventListener("mousedown",c),()=>document.removeEventListener("mousedown",c)},[D]),g.useEffect(()=>{q(!1)},[n,l]),g.useEffect(()=>{const c=n,w=l;return()=>{if(w==="chats"&&c){const S=typeof pn.current[c]=="number"?pn.current[c]:T.current?T.current.scrollTop:0;La(_=>{const $={..._,[c]:S};return window.electronAPI.updateSettings({scrollPositions:$}),$})}}},[n,l]),g.useEffect(()=>{const c=T.current;if(!c)return;const w=()=>{const{scrollTop:S,scrollHeight:_,clientHeight:$}=c,A=_-S-$<=vy;if(n){const W=Oa.current[n],U=typeof W=="number"&&Sc.removeEventListener("scroll",w)},[n,hr]),g.useEffect(()=>{const c=n;c&&Ma[c]===!1&&On(w=>{if(!(c in w))return w;const S={...w};return delete S[c],S})},[n,Ma]),g.useLayoutEffect(()=>{if(l!=="chats"||!n)return;const c=T.current;if(!c)return;Bt.current=null;const w=()=>{if(Bt.current===n)return;const W=typeof pn.current[n]=="number"?pn.current[n]:void 0,U=typeof W=="number"?W:pl[n];if(typeof U=="number"){c.scrollTop=U,Bt.current=n;return}Fn.length>0&&(c.scrollTop=c.scrollHeight,Bt.current=n)};w();const S=requestAnimationFrame(w),_=()=>{Bt.current!==n&&requestAnimationFrame(w)},$=new MutationObserver(_);$.observe(c,{childList:!0,subtree:!0});const A=new ResizeObserver(_);return A.observe(c),()=>{cancelAnimationFrame(S),$.disconnect(),A.disconnect()}},[n,l,Fn.length,pl]),g.useEffect(()=>{if(l!=="chats"||!n||Bt.current===n)return;const c=typeof pn.current[n]=="number"?pn.current[n]:void 0;typeof(typeof c=="number"?c:pl[n])!="number"&&Fn.length>0&&requestAnimationFrame(()=>{const S=T.current;S&&(S.scrollTop=S.scrollHeight,Bt.current=n)})},[Fn.length,n,l,pl]);const qo=(c="smooth",w=null)=>{const S=T.current;if(!S)return;const _=w??_e.current;_e.current===_&&(S.scrollTo({top:S.scrollHeight,behavior:c}),hr(_,!1))},In=(c,w="auto",S=null)=>{const _=T.current;if(!_)return;const $=S??_e.current;if(_e.current!==$)return;const A=document.getElementById(c);if(A){const W=Math.max(0,A.offsetTop-gy);_.scrollTo({top:W,behavior:w})}},Op=()=>{const c=_e.current,w=za[c];w&&(In(w,"smooth",c),On(S=>{const{[c]:_,...$}=S;return $}))};async function Va(){var $,A,W;if(At||!be.trim()||!ge)return;let c=n,w=!1;if(c){const U=e.find(V=>V.session_id===c);w=U&&U.name==="New Chat"&&U.messages.length===0}else{const U=await Qa();await new Promise(V=>setTimeout(V,200)),c=U.session_id,w=!0}const S={role:"user",content:be.trim(),id:`msg-${Date.now()}-${Math.random()}`};Ep.current=!0,Cp.current=c,hr(c,!1),_e.current===c&&(Bt.current=_e.current),Dd.flushSync(()=>{t(U=>U.map(V=>V.session_id===c?{...V,messages:[...V.messages||[],S]}:V)),N("")}),requestAnimationFrame(()=>qo("auto",c));const _=Da(c);try{let U=[];try{U=[...((($=e.find(ke=>ke.session_id===c))==null?void 0:$.messages)||[]).slice(-8).map(ke=>({role:ke.role,content:ke.content||""})),{role:"user",content:S.content}]}catch{}let V=S.content,Le=[];const ve=[],Xe=Ha(c);if((A=Xe==null?void 0:Xe.states)!=null&&A.is_indexed)try{const Q=await Ta(Xe.slug,S.content,_.signal);Q.contextBlock&&ve.push(Q.contextBlock),Array.isArray(Q.sources)&&Le.push(...Q.sources)}catch(Q){if(Ut(Q))throw Q;console.warn("local library enrichment failed",Q)}if(dl)try{const fe=await(await fetch(`${O}/websearch`,{method:"POST",headers:{"Content-Type":"application/json"},signal:_.signal,body:JSON.stringify({prompt:S.content,model:ge,messages:U,history_limit:8,searx_url:mt||null,engines:Array.isArray(cn)?cn:null})})).json();fe&&typeof fe.context_block=="string"&&fe.context_block.trim()&&ve.push(fe.context_block.trim()),Array.isArray(fe==null?void 0:fe.sources)&&Le.push(...fe.sources)}catch(Q){if(Ut(Q))throw Q;console.warn("web search enrichment failed",Q)}if(Le=[...new Set(Le)],ve.length>0&&(V=`${S.content} + +${ve.join(` + +`)}`),Et){const Q=`msg-${Date.now()}-${Math.random()}`;let fe="";const ke={role:"assistant",content:"",id:Q,sources:Le};t(G=>G.map(oe=>oe.session_id===c?{...oe,messages:[...oe.messages||[],ke]}:oe));try{const G=await fetch(`${O}/chat`,{method:"POST",headers:{"Content-Type":"application/json"},signal:_.signal,body:JSON.stringify({session_id:c,model:ge,message:S.content,enriched_message:ve.length>0?V:null,stream:!0,sources:Le||[]})});if(!G.ok)throw new Error(`HTTP ${G.status}`);const oe=(W=G.body)==null?void 0:W.getReader();if(!oe)throw new Error("Missing response body");const K=new TextDecoder;let Nt=!1;for(;;){const{value:te,done:he}=await oe.read();if(he){fn(c,Q,fe),_e.current===c?Mn.current[c]?On(gt=>({...gt,[c]:Q})):requestAnimationFrame(()=>In(Q,"smooth",c)):(dn(gt=>({...gt,[c]:Q})),$n(gt=>[...new Set([...gt,c])]));break}const Ht=K.decode(te,{stream:!0});fe+=Ht,fn(c,Q,fe),_e.current===c&&!Mn.current[c]&&qo("auto",c),_e.current!==c&&!Nt&&(dn(gt=>({...gt,[c]:Q})),Nt=!0)}}catch(G){if(Ut(G)){fn(c,Q,fe,{removeIfEmpty:!0});return}console.error("Failed to send message:",G),fn(c,Q,"Error: "+ml(G),{removeIfEmpty:!0});return}}else{const Q=await fetch(`${O}/chat`,{method:"POST",headers:{"Content-Type":"application/json"},signal:_.signal,body:JSON.stringify({session_id:c,model:ge,message:S.content,enriched_message:ve.length>0?V:null,stream:!1,sources:Le||[]})});if(!Q.ok)throw new Error(`HTTP ${Q.status}`);const fe=await Q.json(),ke=`msg-${Date.now()}`,G={role:"assistant",content:fe.reply,id:ke,sources:Le};t(oe=>oe.map(K=>K.session_id===c?{...K,messages:[...K.messages||[],G]}:K)),ke&&(_e.current===c?Mn.current[c]?On(oe=>({...oe,[c]:ke})):requestAnimationFrame(()=>In(ke,"smooth",c)):dn(oe=>({...oe,[c]:ke})))}_e.current!==c&&$n(Q=>[...new Set([...Q,c])]),w&&fetch(`${O}/generate-title`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({session_id:c,message:S.content,model:ge})}).then(Q=>Q.json()).then(Q=>{const fe=Q.title.replace(/[\s\S]*?<\/think(?:ing)?>/i,"").trim();t(ke=>ke.map(G=>G.session_id===c?{...G,name:fe}:G))})}catch(U){if(Ut(U)){Yo(_);return}console.error("Failed to send message:",U);const V={role:"assistant",content:"Error: "+ml(U),id:`msg-${Date.now()}-${Math.random()}`};t(Le=>Le.map(ve=>ve.session_id===c?{...ve,messages:[...ve.messages,V]}:ve))}finally{Yo(_)}}function zp(){fp(c=>!c)}async function Qa(){var $;const c="sess-"+Math.random().toString(36).slice(2)+Date.now().toString(36),S=await(await fetch(`${O}/sessions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({session_id:c})})).json(),_={...S,messages:[]};return t(A=>[_,...A]),r(S.session_id),($=H.current)==null||$.focus(),S}function Fp(c){r(c),$n(S=>S.filter(_=>_!==c));const w=Sp[c];w&&requestAnimationFrame(()=>{let S=12;const _=()=>{if(!T.current)return;let A=document.getElementById(w);if(!A){const W=e.find(U=>U.session_id===c);if(W&&Array.isArray(W.messages))for(let U=W.messages.length-1;U>=0;U--){const V=W.messages[U];if(V.role==="assistant"&&V.id){A=document.getElementById(V.id);break}}}A?(In(A.id,"smooth",c),dn(W=>{const{[c]:U,...V}=W;return V})):S-- >0&&requestAnimationFrame(_)};requestAnimationFrame(_)})}function Ip(c,w){fetch(`${O}/sessions/${c}/rename`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({title:w})}).then(()=>{t(S=>S.map(_=>_.session_id===c?{..._,name:w}:_)),u(null)})}function Dp(c,w){const S=(w||"").trim(),_=y.find($=>$.slug===c);if(!_){v(null);return}if(!S||S===_.name){v(null);return}fetch(`${O}/libraries/${c}`,{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:S})}).then(()=>{x($=>$.map(A=>A.slug===c?{...A,name:S}:A)),v(null)})}function Ka(c){fetch(`${O}/sessions/${c}`,{method:"DELETE"}).then(()=>{const w=e.filter(S=>S.session_id!==c);t(w),d(S=>{const _={...S||{}};return delete _[c],_}),n===c&&r(w.length>0?w[0].session_id:null)})}function Ap(c){fetch(`${O}/libraries/${c}`,{method:"DELETE"}).then(async w=>{var _;if(!w.ok){const $=await w.text();throw new Error($||`HTTP ${w.status}`)}const S=y.filter($=>$.slug!==c);x(S),k($=>$.filter(A=>A.slug!==c)),v($=>$===c?null:$),L===c&&m(((_=S[0])==null?void 0:_.slug)||null),Mp(c)}).catch(w=>{console.error("Failed to delete library",w)})}g.useEffect(()=>{const c=e.filter(w=>w.name==="New Chat"&&w.session_id!==n&&w.messages.length===0);c.length>0&&c.forEach(w=>{Ka(w.session_id)})},[n,e,O]);const Up=c=>{var S;window.getSelection().toString().length>0||document.activeElement!==H.current&&(c.target.closest(".msg")||(S=H.current)==null||S.focus())};return p.jsxs("div",{className:"app",style:{gridTemplateColumns:`${_p}px 1fr`},children:[p.jsxs("div",{className:"sidebar",children:[p.jsxs("div",{className:"sidebar-header",children:[p.jsx("div",{className:`sidebar-tab ${l==="chats"?"active":""}`,onClick:()=>Xo("chats"),children:"Chats"}),p.jsx("div",{className:`sidebar-tab ${l==="dbs"?"active":""}`,onClick:()=>Xo("dbs"),children:"DBs"}),p.jsx("div",{className:`sidebar-tab ${l==="settings"?"active":""}`,onClick:()=>Xo("settings"),children:"Settings"})]}),p.jsxs("div",{className:"sidebar-content",children:[l==="chats"&&p.jsx("div",{className:"chat-list",children:e.map(c=>p.jsx("div",{className:`chat-item ${c.session_id===n?"active":""}`,onClick:()=>Tp(c.session_id),children:s===c.session_id?p.jsx("input",{type:"text",className:"rename-input",defaultValue:c.name,onBlur:()=>u(null),onKeyDown:w=>{w.key==="Enter"?Ip(c.session_id,w.target.value):w.key==="Escape"&&u(null)},autoFocus:!0}):p.jsxs(p.Fragment,{children:[p.jsx("span",{children:c.name}),p.jsxs("div",{className:"chat-item-buttons",children:[dp.includes(c.session_id)&&p.jsx("div",{className:"unread-dot"}),p.jsx("button",{className:"icon-button",onClick:w=>{w.stopPropagation(),u(c.session_id)},children:p.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"feather feather-edit-2",children:p.jsx("path",{d:"M17 3a2.828 2.828 0 1 1 4 4L7.5 20.5 2 22l1.5-5.5L17 3z"})})}),p.jsx("button",{className:"icon-button",onClick:w=>{w.stopPropagation(),Ka(c.session_id)},children:p.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"feather feather-x",children:[p.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),p.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]})]})},c.session_id))}),l==="dbs"&&p.jsx("div",{className:"db-list",children:y.length===0?p.jsx("div",{className:"empty-list-message",children:"No databases yet."}):y.map(c=>p.jsx("div",{className:`chat-item ${c.slug===L?"active":""}`,onClick:()=>m(c.slug),children:h===c.slug?p.jsx("input",{type:"text",className:"rename-input",defaultValue:c.name,onBlur:()=>v(null),onKeyDown:w=>{w.key==="Enter"?Dp(c.slug,w.target.value):w.key==="Escape"&&v(null)},autoFocus:!0}):p.jsxs(p.Fragment,{children:[p.jsx("span",{children:c.name}),p.jsxs("div",{className:"chat-item-buttons",children:[Ct===c.slug&&p.jsx("div",{className:"db-active-badge",children:"Chat"}),Wa(c.slug)&&p.jsx("div",{className:"db-active-badge",children:"Syncing"}),p.jsx("button",{className:"icon-button",onClick:w=>{w.stopPropagation(),v(c.slug)},children:p.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"feather feather-edit-2",children:p.jsx("path",{d:"M17 3a2.828 2.828 0 1 1 4 4L7.5 20.5 2 22l1.5-5.5L17 3z"})})}),p.jsx("button",{className:"icon-button",onClick:w=>{w.stopPropagation(),Ap(c.slug)},children:p.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"feather feather-x",children:[p.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),p.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]})]})},c.slug))}),l==="settings"&&p.jsxs("div",{className:"settings-list",children:[p.jsx("div",{className:`settings-item ${i==="General"?"active":""}`,onClick:()=>a("General"),children:"General"}),p.jsx("div",{className:`settings-item ${i==="Interface"?"active":""}`,onClick:()=>a("Interface"),children:"Interface"}),p.jsx("div",{className:`settings-item ${i==="Websearch"?"active":""}`,onClick:()=>a("Websearch"),children:"Websearch"})]})]}),l!=="settings"&&p.jsxs("div",{className:"sidebar-footer",children:[l==="chats"&&p.jsx("button",{className:"button new-chat-button",onClick:Qa,children:"New Chat"}),l==="dbs"&&(C?p.jsxs("div",{className:"new-db-form",children:[p.jsx("input",{type:"text",className:"rename-input",value:M,onChange:c=>z(c.target.value),onKeyDown:c=>{c.key==="Enter"?Ua():c.key==="Escape"&&(P(!1),z(""),B(""))},placeholder:"Database name",autoFocus:!0}),F&&p.jsx("div",{className:"form-error",children:F}),p.jsxs("div",{className:"new-db-actions",children:[p.jsx("button",{className:"button new-db-button",onClick:()=>Ua(),children:"Create"}),p.jsx("button",{className:"button ghost",onClick:()=>{P(!1),z(""),B("")},children:"Cancel"})]})]}):p.jsx("button",{className:"button new-db-button",onClick:()=>{P(!0),B("")},children:"New Database"}))]}),p.jsx("div",{className:"resizer",onMouseDown:Pp})]}),p.jsxs("div",{className:"main-content",children:[Tn&&p.jsx("div",{className:"startup-task-banner",role:"status","aria-live":"polite",children:Tn}),l==="chats"&&p.jsxs(p.Fragment,{children:[p.jsxs("div",{className:"header",children:[p.jsxs("strong",{children:["Chat - ",((Ya=e.find(c=>c.session_id===n))==null?void 0:Ya.name)||"New Chat"]}),ot&&p.jsx("span",{className:"header-subtle",children:`DB: ${ot.name}${Zo}`})]}),p.jsx("div",{className:"chat",ref:T,onClick:Up,children:Fn.map((c,w)=>{const S=c.role==="user"&&hp===w;return p.jsx("div",{id:c.id,className:"msg "+(c.role==="user"?"user":"assistant")+(S?" editing":""),children:c.role==="assistant"?p.jsxs("div",{className:"assistant-message-wrapper",children:[p.jsx(my,{content:c.content,streamOutput:Et,sources:c.sources}),!At&&p.jsxs("div",{className:"message-options-bar assistant-options",children:[p.jsx("button",{className:"icon-button",title:"Copy message",onClick:()=>Ra(c),children:p.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[p.jsx("rect",{x:"9",y:"9",width:"13",height:"13",rx:"2",ry:"2"}),p.jsx("path",{d:"M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"})]})}),p.jsx("button",{className:"icon-button",title:"Regenerate response",onClick:()=>$a(w),children:p.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:p.jsx("path",{d:"M21.5 2v6h-6M2.5 22v-6h6M2 11.5a10 10 0 0 1 18.8-4.3M22 12.5a10 10 0 0 1-18.8 4.3"})})})]})]}):p.jsxs("div",{className:"user-message-wrapper",children:[S?p.jsxs("div",{className:"msg-content msg-content--user editing",children:[p.jsx("div",{className:"user-edit-shadow","aria-hidden":"true",children:Qo}),p.jsx(hc,{className:"edit-message-input edit-overlay",value:Qo,onChange:_=>hl(_.target.value),onBlur:gl,onKeyDown:_=>{_.key==="Escape"&&(_.preventDefault(),gl()),_.key==="Enter"&&!_.shiftKey&&(_.preventDefault(),yp(w))},autoFocus:!0,minRows:1})]}):(()=>{const _=c.content||"",$=_.split(/\r\n|\r|\n/),A=$.length>30,W=Ia(c,w,n),U=A?xp[W]??!0:!1,V=U?$.slice(0,30).join(` +`)+` +…`:_;return p.jsxs(p.Fragment,{children:[p.jsx("div",{className:"msg-content msg-content--user",children:V}),A&&p.jsx("button",{className:"user-msg-expand",onClick:()=>kp(W),"aria-expanded":U?"false":"true",children:U?"Show entire message":"Collapse"})]})})(),!At&&!S&&p.jsxs("div",{className:"message-options-bar user-options",children:[p.jsx("button",{className:"icon-button",title:"Edit message",onClick:()=>vp(w,c.content),children:p.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[p.jsx("path",{d:"M12 20h9"}),p.jsx("path",{d:"M16.5 3.5a2.121 2.121 0 0 1 3 3L7 19l-4 1 1-4L16.5 3.5z"})]})}),p.jsx("button",{className:"icon-button",title:"Copy message",onClick:()=>Ra(c),children:p.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[p.jsx("rect",{x:"9",y:"9",width:"13",height:"13",rx:"2",ry:"2"}),p.jsx("path",{d:"M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"})]})})]})]})},c.id||w)})},n),za[n]&&p.jsxs("button",{className:"new-msg-tip",onClick:Op,title:"Jump to the new message","aria-label":"Jump to the new message",children:["New message",p.jsx("span",{style:{marginLeft:6},children:"↓"})]}),p.jsx("div",{className:"footer",children:p.jsxs("div",{className:"footer-content-wrapper",children:[p.jsx(hc,{ref:H,className:"input",value:be,onChange:c=>N(c.target.value),onKeyDown:c=>{c.key==="Enter"&&!c.shiftKey&&(c.preventDefault(),Va())},placeholder:"Ask any question...",maxRows:13}),p.jsxs("div",{className:"footer-tool-group",ref:R,children:[p.jsx("button",{type:"button",className:"db-picker-toggle"+(ot?" active":""),onClick:()=>{n&&q(c=>!c)},title:ot?`Database: ${ot.name}${Zo}`:"Select database for this chat","aria-haspopup":"menu","aria-expanded":D,disabled:!n,children:p.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round","aria-hidden":"true",children:[p.jsx("ellipse",{cx:"12",cy:"5",rx:"8",ry:"3"}),p.jsx("path",{d:"M4 5v6c0 1.7 3.6 3 8 3s8-1.3 8-3V5"}),p.jsx("path",{d:"M4 11v6c0 1.7 3.6 3 8 3s8-1.3 8-3v-6"})]})}),D&&p.jsxs("div",{className:"db-picker-menu",role:"menu",children:[p.jsxs("button",{type:"button",className:"db-picker-option"+(Ct?"":" selected"),onClick:()=>{ba(n,null),q(!1)},children:[p.jsx("span",{children:"No database"}),!Ct&&p.jsx("span",{className:"db-picker-status",children:"Selected"})]}),y.length===0?p.jsx("div",{className:"db-picker-empty",children:"No databases yet."}):y.map(c=>{var $,A,W;const w=Ct===c.slug,S=Wa(c.slug),_=($=c.files)!=null&&$.length?(A=c.states)!=null&&A.is_indexed?"Ready":S?"Syncing":"Needs sync":"Empty";return p.jsxs("button",{type:"button",className:"db-picker-option"+(w?" selected":""),disabled:!((W=c.files)!=null&&W.length),onClick:()=>{ba(n,c.slug),q(!1)},children:[p.jsx("span",{children:c.name}),p.jsx("span",{className:"db-picker-status",children:w?"Selected":_})]},c.slug)})]})]}),p.jsx("button",{type:"button",className:"websearch-toggle"+(dl?" active":""),onClick:zp,title:"Toggle web search","aria-pressed":dl,children:p.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round","aria-hidden":"true",children:[p.jsx("circle",{cx:"12",cy:"12",r:"10"}),p.jsx("line",{x1:"2",y1:"12",x2:"22",y2:"12"}),p.jsx("path",{d:"M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"})]})}),p.jsx("button",{className:"button",onClick:At?Np:Va,title:At?"Cancel generation":"Send","aria-label":At?"Cancel generation":"Send",children:At?p.jsx("div",{className:"spinner"}):"Send"})]})})]}),l==="dbs"&&p.jsxs(p.Fragment,{children:[p.jsxs("div",{className:"header",children:[p.jsx("strong",{children:(wl==null?void 0:wl.name)||"Databases"}),ot&&p.jsx("span",{className:"header-subtle",children:`Current chat DB: ${ot.name}${Zo}`})]}),p.jsx(dy,{apiBase:O,library:wl,jobs:E,onRefresh:async()=>{await mr(),await yl()}})]}),l==="settings"&&p.jsxs(p.Fragment,{children:[p.jsx("div",{className:"header",children:p.jsxs("strong",{children:[i," Settings"]})}),i==="General"&&p.jsx(iy,{onModelChange:We,streamOutput:Et,onStreamOutputChange:ht,onLibrariesPurged:Rp}),i==="Interface"&&p.jsx(cy,{}),i==="Websearch"&&p.jsx(py,{searxUrl:mt,setSearxUrl:up,engines:cn,setEngines:cp})]})]})]})}function xy(){return g.useEffect(()=>{window.electronAPI.getSettings().then(e=>{rl(e.colorScheme||"Default")})},[]),p.jsx(Me.StrictMode,{children:p.jsx(Pv,{children:p.jsx(ov,{children:p.jsx(Xd,{path:"/",element:p.jsx(Sy,{})})})})})}const ky=Ad(document.getElementById("root"));ky.render(p.jsx(xy,{})); diff --git a/dist/index.html b/dist/index.html index ce4dac7..9d86651 100644 --- a/dist/index.html +++ b/dist/index.html @@ -5,8 +5,8 @@ LLM Desktop - - + +
diff --git a/electron/main.cjs b/electron/main.cjs index 038e64d..4836eff 100644 --- a/electron/main.cjs +++ b/electron/main.cjs @@ -11,6 +11,8 @@ const execFileAsync = promisify(execFile) const DEFAULT_BACKEND_API_URL = 'http://127.0.0.1:8000' const DEFAULT_OLLAMA_API_URL = 'http://127.0.0.1:11434' +const DEFAULT_EMBED_MODEL = 'nomic-embed-text:latest' +const BGE_EMBED_MODEL = 'bge-m3:latest' const REPO_ROOT = path.resolve(__dirname, '..') const UPDATE_REMOTE_URL = 'https://giers10.uber.space/giers10/Heimgeist.git' const UPDATE_BRANCH = 'master' @@ -27,11 +29,20 @@ const MAX_UI_SCALE = 1.3 const defaultSettings = { backendApiUrl: DEFAULT_BACKEND_API_URL, ollamaApiUrl: DEFAULT_OLLAMA_API_URL, + embedModel: DEFAULT_EMBED_MODEL, colorScheme: 'Default', uiScale: DEFAULT_UI_SCALE, chatModel: 'llama3', } +function normalizeEmbedModel(value) { + const trimmed = String(value || '').trim().toLowerCase() + if (trimmed === 'bge' || trimmed === 'bge-m3' || trimmed === BGE_EMBED_MODEL) { + return BGE_EMBED_MODEL + } + return DEFAULT_EMBED_MODEL +} + function looksLikeOllamaUrl(value) { if (typeof value !== 'string') { return false @@ -67,6 +78,7 @@ function migrateSettings(rawSettings) { nextSettings.backendApiUrl = String(nextSettings.backendApiUrl || '').trim() nextSettings.ollamaApiUrl = String(nextSettings.ollamaApiUrl || '').trim() + nextSettings.embedModel = normalizeEmbedModel(nextSettings.embedModel) return { nextSettings, migrated } } @@ -457,7 +469,13 @@ ipcMain.handle('get-update-status', () => lastUpdateCheckResult) ipcMain.handle('check-for-updates', () => checkForUpdates('manual')) ipcMain.handle('set-setting', (event, key, value) => { - appSettings[key] = key === 'uiScale' ? normalizeUiScale(value) : value + if (key === 'uiScale') { + appSettings[key] = normalizeUiScale(value) + } else if (key === 'embedModel') { + appSettings[key] = normalizeEmbedModel(value) + } else { + appSettings[key] = value + } saveSettings() if (key === 'uiScale') { applyUiScaleToAllWindows() @@ -468,6 +486,7 @@ ipcMain.handle('set-setting', (event, key, value) => { ipcMain.handle('update-settings', (event, settings) => { appSettings = { ...appSettings, ...settings } appSettings.uiScale = normalizeUiScale(appSettings.uiScale) + appSettings.embedModel = normalizeEmbedModel(appSettings.embedModel) saveSettings() if (Object.prototype.hasOwnProperty.call(settings, 'uiScale')) { applyUiScaleToAllWindows() diff --git a/src/App.jsx b/src/App.jsx index 976aa7b..ea61dfd 100644 --- a/src/App.jsx +++ b/src/App.jsx @@ -127,6 +127,7 @@ const COLOR_SCHEME_KEY = 'colorScheme'; const WEBSEARCH_URL_KEY = 'websearch.searxUrl'; const WEBSEARCH_ENGINES_KEY = 'websearch.engines'; const CHAT_LIBRARY_MAP_KEY = 'chat.libraryBySession'; +const DEFAULT_SEARX_URL = 'http://127.0.0.1:8888'; // Initial API value will be set by useEffect after settings are loaded let API = import.meta.env.VITE_API_URL ?? 'http://127.0.0.1:8000'; @@ -137,6 +138,13 @@ function resolveBackendApiUrl(settings) { return settings.backendApiUrl || settings.ollamaApiUrl || API; } +function migrateLegacySearxUrl(value) { + const trimmed = typeof value === 'string' ? value.trim() : ''; + if (!trimmed) return DEFAULT_SEARX_URL; + if (trimmed === 'http://localhost:8888') return DEFAULT_SEARX_URL; + return trimmed; +} + export default function App() { const [chatSessions, setChatSessions] = useState([]) const [activeSessionId, setActiveSessionId] = useState(null) @@ -169,7 +177,8 @@ export default function App() { const [backendApiUrl, setBackendApiUrl] = useState(API); // State for Heimgeist backend URL const [colorScheme, setColorScheme] = useState('Default'); // State for color scheme const [streamOutput, setStreamOutput] = useState(false); - const [searxUrl, setSearxUrl] = useState(localStorage.getItem(WEBSEARCH_URL_KEY) || 'http://localhost:8888'); + const [startupTaskMessage, setStartupTaskMessage] = useState(''); + const [searxUrl, setSearxUrl] = useState(() => migrateLegacySearxUrl(localStorage.getItem(WEBSEARCH_URL_KEY))); const [searxEngines, setSearxEngines] = useState(() => { try { const raw = localStorage.getItem(WEBSEARCH_ENGINES_KEY); @@ -191,6 +200,8 @@ export default function App() { const [loading, setLoading] = useState(true); // Loading state for initial session fetch const [unreadSessions, setUnreadSessions] = useState([]); // Track unread messages const [scrollPositions, setScrollPositions] = useState({}); // Store scroll positions for each session + const [settingsLoaded, setSettingsLoaded] = useState(false); + const startupOllamaCheckRanRef = useRef(false); // Editing state for user messages const [editingMessageIndex, setEditingMessageIndex] = useState(null); const [editText, setEditText] = useState(''); @@ -253,6 +264,20 @@ export default function App() { return String(error) } + async function expectBackendJson(response) { + const data = await response.json().catch(() => null) + if (response.ok) return data + const detail = typeof data?.detail === 'string' + ? data.detail + : (typeof data?.message === 'string' ? data.message : '') + throw new Error(detail || `HTTP ${response.status}`) + } + + async function fetchStartupOllamaStatus() { + const response = await fetch(`${backendApiUrl}/ollama/startup-status`) + return expectBackendJson(response) + } + async function fetchLocalLibraryContext(slug, prompt, signal) { if (!slug) return { contextBlock: null, sources: [] } @@ -705,6 +730,8 @@ async function regenerateFromIndex(index, overrideUserText = null) { setStreamOutput(settings.streamOutput || false); setScrollPositions(settings.scrollPositions || {}); // Load scroll positions applyColorScheme(settings.colorScheme || 'Default'); // Apply initial scheme + }).finally(() => { + setSettingsLoaded(true); }); const handleFocus = () => { @@ -724,6 +751,68 @@ async function regenerateFromIndex(index, overrideUserText = null) { }; }, [activeSidebarMode]); + useEffect(() => { + if (!settingsLoaded || !backendApiUrl || startupOllamaCheckRanRef.current) return + startupOllamaCheckRanRef.current = true + + let cancelled = false + + ;(async () => { + let actionStarted = false + try { + let status = await fetchStartupOllamaStatus() + if (cancelled) return + + if (!status?.ollama_running && status?.can_manage_locally) { + const confirmed = window.confirm( + `Ollama is not running at ${status.ollama_url}. Start it in the background now with "ollama serve"?` + ) + if (cancelled) return + if (confirmed) { + actionStarted = true + setStartupTaskMessage('Starting Ollama in the background...') + const response = await fetch(`${backendApiUrl}/ollama/start`, { method: 'POST' }) + status = await expectBackendJson(response) + if (cancelled) return + } + } + + if (status?.ollama_running && !status?.embedding_model_available && status?.can_manage_locally) { + const confirmed = window.confirm( + `The selected embedding model "${status.selected_embed_model}" is not installed in Ollama. Pull it now?` + ) + if (cancelled) return + if (confirmed) { + actionStarted = true + setStartupTaskMessage(`Pulling ${status.selected_embed_model} in Ollama...`) + const response = await fetch(`${backendApiUrl}/ollama/pull`, { + method: 'POST', + headers: { 'Content-Type': 'application/json' }, + body: JSON.stringify({ model: status.selected_embed_model }) + }) + await expectBackendJson(response) + if (cancelled) return + } + } + } catch (error) { + if (!cancelled) { + console.warn('startup Ollama check failed', error) + if (actionStarted) { + window.alert(`Startup action failed: ${getErrorText(error)}`) + } + } + } finally { + if (!cancelled) { + setStartupTaskMessage('') + } + } + })() + + return () => { + cancelled = true + } + }, [backendApiUrl, settingsLoaded]); + // Apply color scheme whenever it changes useEffect(() => { applyColorScheme(colorScheme); @@ -1785,6 +1874,11 @@ async function createNewChat() {
+ {startupTaskMessage && ( +
+ {startupTaskMessage} +
+ )} {activeSidebarMode === 'chats' && ( <>
diff --git a/src/GeneralSettings.jsx b/src/GeneralSettings.jsx index f5b6f90..11367b0 100644 --- a/src/GeneralSettings.jsx +++ b/src/GeneralSettings.jsx @@ -2,10 +2,13 @@ import React, { useState, useEffect } from 'react'; const BACKEND_API_URL_KEY = 'backendApiUrl'; const OLLAMA_API_URL_KEY = 'ollamaApiUrl'; +const EMBED_MODEL_KEY = 'embedModel'; const MODEL_KEY = 'chatModel'; const STREAM_KEY = 'streamOutput'; const DEFAULT_BACKEND_API_URL = 'http://127.0.0.1:8000'; const DEFAULT_OLLAMA_API_URL = 'http://127.0.0.1:11434'; +const DEFAULT_EMBED_MODEL = 'nomic-embed-text:latest'; +const BGE_EMBED_MODEL = 'bge-m3:latest'; const DEFAULT_UPDATE_STATUS = { state: 'idle', message: '', @@ -32,6 +35,7 @@ function getStatusTone(state) { export default function GeneralSettings({ onModelChange, onStreamOutputChange, onLibrariesPurged }) { const [backendApiUrl, setBackendApiUrl] = useState(''); const [ollamaApiUrl, setOllamaApiUrl] = useState(''); + const [embedModel, setEmbedModel] = useState(DEFAULT_EMBED_MODEL); const [models, setModels] = useState([]); const [selectedModel, setSelectedModel] = useState(''); const [streamOutput, setStreamOutput] = useState(false); @@ -53,6 +57,7 @@ export default function GeneralSettings({ onModelChange, onStreamOutputChange, o setBackendApiUrl(resolveBackendApiUrl(settings)); setOllamaApiUrl(settings.ollamaApiUrl || DEFAULT_OLLAMA_API_URL); + setEmbedModel(settings.embedModel || DEFAULT_EMBED_MODEL); setSelectedModel(settings.chatModel || ''); setStreamOutput(settings.streamOutput || false); setUpdateStatus(status || DEFAULT_UPDATE_STATUS); @@ -102,6 +107,12 @@ export default function GeneralSettings({ onModelChange, onStreamOutputChange, o } }; + const handleEmbedModelToggle = () => { + const nextModel = embedModel === BGE_EMBED_MODEL ? DEFAULT_EMBED_MODEL : BGE_EMBED_MODEL; + setEmbedModel(nextModel); + window.electronAPI.setSetting(EMBED_MODEL_KEY, nextModel); + }; + const handleStreamToggle = () => { const newStreamValue = !streamOutput; setStreamOutput(newStreamValue); @@ -199,6 +210,28 @@ export default function GeneralSettings({ onModelChange, onStreamOutputChange, o />

Heimgeist uses this URL to talk to Ollama for models and chat generation.

+
+

Embedding Model

+
+ + nomic + + + + bge-m3 + +
+

+ Heimgeist uses this model for web-search reranking and for building or rebuilding local database embeddings. +

+

Chat Model