diff --git a/llm_normalizer/backend/dist/routes/autoRuns.js b/llm_normalizer/backend/dist/routes/autoRuns.js index 897d50d..f7c5bf9 100644 --- a/llm_normalizer/backend/dist/routes/autoRuns.js +++ b/llm_normalizer/backend/dist/routes/autoRuns.js @@ -93,6 +93,16 @@ function clampInt(value, min, max, fallback) { return max; return rounded; } +function isAutoGenMode(value) { + return value === "qwen_seed" || value === "codex_creative" || value === "saved_user_sessions"; +} +function parseAutoGenTitle(value) { + const title = toStringSafe(value); + if (!title) { + return null; + } + return title.slice(0, 160); +} function parseManualCaseDecision(value, fallback = "needs_dialog_policy_fix") { const normalized = toStringSafe(value); if (!normalized) @@ -151,15 +161,11 @@ function readAutoGenHistory() { .map((item) => ({ generation_id: toStringSafe(item.generation_id) ?? "", created_at: toStringSafe(item.created_at) ?? new Date().toISOString(), - mode: toStringSafe(item.mode) ?? "codex_creative", + mode: isAutoGenMode(toStringSafe(item.mode)) ? toStringSafe(item.mode) : "codex_creative", + title: parseAutoGenTitle(item.title), count: clampInt(toNumberSafe(item.count), 1, 300, 20), domain: toStringSafe(item.domain), - questions: toArray(item.questions) - .map((q) => toStringSafe(q)) - .filter((q) => q !== null) - .map((q) => sanitizeGeneratedQuestion(q)) - .filter((q) => q.length > 0) - .slice(0, 500), + questions: parseAssistantSessionQuestions(item.questions), generated_by: toStringSafe(item.generated_by), saved_case_set_file: toStringSafe(item.saved_case_set_file), context: toRecord(item.context) @@ -174,7 +180,10 @@ function readAutoGenHistory() { autogen_personality_id: toStringSafe(toRecord(item.context)?.autogen_personality_id), autogen_personality_prompt: toStringSafe(toRecord(item.context)?.autogen_personality_prompt) ? repairAutogenMojibake(String(toRecord(item.context)?.autogen_personality_prompt)) - : null + : null, + source_session_id: toStringSafe(toRecord(item.context)?.source_session_id), + saved_session_file: toStringSafe(toRecord(item.context)?.saved_session_file), + saved_case_set_kind: toStringSafe(toRecord(item.context)?.saved_case_set_kind) } : null })) @@ -1057,7 +1066,7 @@ function parseDecisionFilter(value) { } function parseAutoGenMode(value) { const normalized = toStringSafe(value)?.toLowerCase() ?? ""; - if (normalized === "qwen_seed" || normalized === "codex_creative") { + if (normalized === "qwen_seed" || normalized === "codex_creative" || normalized === "saved_user_sessions") { return normalized; } return "codex_creative"; @@ -1150,6 +1159,12 @@ function sanitizeGeneratedQuestion(value) { .replace(/\s+/g, " ") .trim(); } +function parseAssistantSessionQuestions(value) { + return toArray(value) + .map((item) => sanitizeGeneratedQuestion(typeof item === "string" ? item : "")) + .filter((item) => item.length > 0) + .slice(0, 500); +} const AUTOGEN_QUESTION_PLACEHOLDER_PATTERN = /^(?:questions?|вопросы?|список\s+вопросов)$/iu; const AUTOGEN_QUESTION_TAIL_PATTERNS = [ /^(?:без\s+воды|по\s+факту|и\s+коротко|коротко|прям(?:\s+)?сейчас|за\s+весь\s+период|по\s+делу)\??$/iu @@ -1413,6 +1428,18 @@ function buildAutogenCaseSetFileName(mode, generationId) { ].join(""); return `assistant_autogen_${mode}_${stamp}_${generationId}.json`; } +function buildSavedAssistantSessionSnapshotFileName(generationId) { + const now = new Date(); + const stamp = [ + now.getUTCFullYear(), + String(now.getUTCMonth() + 1).padStart(2, "0"), + String(now.getUTCDate()).padStart(2, "0"), + String(now.getUTCHours()).padStart(2, "0"), + String(now.getUTCMinutes()).padStart(2, "0"), + String(now.getUTCSeconds()).padStart(2, "0") + ].join(""); + return `assistant_saved_session_${stamp}_${generationId}.json`; +} function buildAutogenCaseSetPayload(input) { const normalizedQuestions = Array.from(new Set(input.questions.map((item) => sanitizeGeneratedQuestion(item)).filter((item) => item.length > 0))); const cases = normalizedQuestions.map((question, index) => ({ @@ -1439,6 +1466,99 @@ function buildAutogenCaseSetPayload(input) { cases }; } +function buildSavedSessionCaseSetPayload(input) { + const questions = parseAssistantSessionQuestions(input.questions); + const turns = questions.map((question) => ({ + user_message: question + })); + const caseId = "SAVED-001"; + return { + suite_id: `assistant_saved_session_${input.generationId}`, + suite_version: "0.1.0", + schema_version: "assistant_saved_session_suite_v0_1", + generated_at: new Date().toISOString(), + generation_id: input.generationId, + mode: "saved_user_sessions", + title: input.title, + scenario_count: turns.length > 0 ? 1 : 0, + case_ids: turns.length > 0 ? [caseId] : [], + cases: turns.length > 0 + ? [ + { + case_id: caseId, + scenario_tag: "saved_user_sessions", + title: input.title, + question_type: turns.length > 1 ? "followup" : "direct", + broadness_level: "medium", + turns + } + ] + : [] + }; +} +function ensureDirSync(targetDir) { + if (!fs_1.default.existsSync(targetDir)) { + fs_1.default.mkdirSync(targetDir, { recursive: true }); + } +} +function writeJsonFile(targetPath, payload) { + ensureDirSync(path_1.default.dirname(targetPath)); + fs_1.default.writeFileSync(targetPath, JSON.stringify(payload, null, 2), "utf-8"); +} +function rewriteAutoGenCaseSetFile(record) { + const caseSetFile = toStringSafe(record.saved_case_set_file); + if (!caseSetFile) { + return null; + } + const targetPath = path_1.default.resolve(config_1.EVAL_CASES_DIR, caseSetFile); + const payload = record.mode === "saved_user_sessions" + ? buildSavedSessionCaseSetPayload({ + generationId: record.generation_id, + title: record.title, + questions: record.questions + }) + : buildAutogenCaseSetPayload({ + generationId: record.generation_id, + mode: record.mode, + domain: record.domain, + questions: record.questions + }); + writeJsonFile(targetPath, payload); + return caseSetFile; +} +function writeSavedAssistantSessionSnapshot(input) { + const fileName = buildSavedAssistantSessionSnapshotFileName(input.generationId); + const targetPath = path_1.default.resolve(path_1.default.dirname(config_1.AUTORUN_GENERATOR_HISTORY_FILE), "saved_sessions", fileName); + writeJsonFile(targetPath, { + saved_at: new Date().toISOString(), + generation_id: input.generationId, + mode: "saved_user_sessions", + title: input.title, + source_session_id: input.sessionId, + questions: input.questions, + session: input.session + }); + return fileName; +} +function resolveFileInsideDir(baseDir, fileName) { + const normalized = toStringSafe(fileName); + if (!normalized) { + return null; + } + const targetPath = path_1.default.resolve(baseDir, normalized); + const relative = path_1.default.relative(baseDir, targetPath); + if (relative.startsWith("..") || path_1.default.isAbsolute(relative)) { + return null; + } + return targetPath; +} +function safeDeleteFile(targetPath) { + if (!targetPath || !fs_1.default.existsSync(targetPath)) { + return null; + } + fs_1.default.unlinkSync(targetPath); + return targetPath; +} function collectPostAnalysis(annotations, runMap, limitPerQueue) { const byDecision = {}; const byQueue = {}; @@ -1522,7 +1642,7 @@ function collectPostAnalysis(annotations, runMap, limitPerQueue) { ].slice(0, 60) }; } -function buildAutoRunsRouter(openaiClient = new openaiResponsesClient_1.OpenAIResponsesClient()) { +function buildAutoRunsRouter(services, openaiClient = new openaiResponsesClient_1.OpenAIResponsesClient()) { const router = (0, express_1.Router)(); router.get("/api/autoruns/history", (req, res) => { const filters = parseFilters(req.query); @@ -1884,7 +2004,7 @@ function buildAutoRunsRouter(openaiClient = new openaiResponsesClient_1.OpenAIRe try { const limit = clampInt(toNumberSafe(req.query.limit), 1, 500, 120); const rawMode = toStringSafe(req.query.mode); - const includeAllModes = !rawMode || !["qwen_seed", "codex_creative"].includes(rawMode); + const includeAllModes = !rawMode || !isAutoGenMode(rawMode); const modeFilter = rawMode ?? "codex_creative"; const items = readAutoGenHistory() .filter((item) => (includeAllModes ? true : item.mode === modeFilter)) @@ -1911,6 +2031,157 @@ function buildAutoRunsRouter(openaiClient = new openaiResponsesClient_1.OpenAIRe next(error); } }); + router.post("/api/autoruns/autogen/save-assistant-session", (req, res, next) => { + try { + const body = toRecord(req.body); + if (!body) { + throw new http_1.ApiError("INVALID_AUTOGEN_SAVE_SESSION_PAYLOAD", "JSON body is required", 400); + } + const sessionId = toStringSafe(body.session_id); + const title = parseAutoGenTitle(body.title); + const generatedBy = parseAnnotationAuthor(body.generated_by); + const context = toRecord(body.context); + if (!sessionId) { + throw new http_1.ApiError("INVALID_AUTOGEN_SAVE_SESSION_PAYLOAD", "session_id is required", 400); + } + if (!title) { + throw new http_1.ApiError("INVALID_AUTOGEN_SAVE_SESSION_PAYLOAD", "title is required", 400); + } + const session = services.assistantService.getSession(sessionId); + if (!session) { + throw new http_1.ApiError("ASSISTANT_SESSION_NOT_FOUND", `Session not found: ${sessionId}`, 404); + } + const questions = session.items + .filter((item) => item.role === "user") + .map((item) => sanitizeGeneratedQuestion(item.text)) + .filter((item) => item.length > 0); + if (questions.length === 0) { + throw new http_1.ApiError("ASSISTANT_SESSION_EMPTY", "Assistant session has no user questions to save.", 400); + } + const generationId = generateAutogenId(); + const caseSetFile = buildAutogenCaseSetFileName("saved_user_sessions", generationId); + const caseSetPath = path_1.default.resolve(config_1.EVAL_CASES_DIR, caseSetFile); + writeJsonFile(caseSetPath, buildSavedSessionCaseSetPayload({ + generationId, + title, + questions + })); + const snapshotFile = writeSavedAssistantSessionSnapshot({ + generationId, + sessionId, + title, + session: session, + questions + }); + const record = { + generation_id: generationId, + created_at: new Date().toISOString(), + mode: "saved_user_sessions", + title, + count: questions.length, + domain: null, + questions, + generated_by: generatedBy, + saved_case_set_file: caseSetFile, + context: { + llm_provider: toStringSafe(context?.llm_provider), + model: toStringSafe(context?.model), + assistant_prompt_version: toStringSafe(context?.assistant_prompt_version), + decomposition_prompt_version: toStringSafe(context?.decomposition_prompt_version), + prompt_fingerprint: toStringSafe(context?.prompt_fingerprint) + ? repairAutogenMojibake(String(context?.prompt_fingerprint)) + : null, + autogen_personality_id: null, + autogen_personality_prompt: null, + source_session_id: sessionId, + saved_session_file: snapshotFile, + saved_case_set_kind: "assistant_session_scenario" + } + }; + const history = readAutoGenHistory(); + history.unshift(record); + writeAutoGenHistory(history.slice(0, 500)); + (0, http_1.ok)(res, { + ok: true, + generation: record + }); + } + catch (error) { + next(error); + } + }); + router.patch("/api/autoruns/autogen/history/:generation_id/questions", (req, res, next) => { + try { + const generationId = toStringSafe(req.params.generation_id); + const body = toRecord(req.body); + if (!generationId) { + throw new http_1.ApiError("INVALID_AUTOGEN_GENERATION_ID", "generation_id is required", 400); + } + if (!body) { + throw new http_1.ApiError("INVALID_AUTOGEN_QUESTIONS_PAYLOAD", "JSON body is required", 400); + } + const questions = parseAssistantSessionQuestions(body.questions); + if (questions.length === 0) { + throw new http_1.ApiError("INVALID_AUTOGEN_QUESTIONS_PAYLOAD", "questions must contain at least one item", 400); + } + const history = readAutoGenHistory(); + const targetIndex = history.findIndex((item) => item.generation_id === generationId); + if (targetIndex < 0) { + throw new http_1.ApiError("AUTOGEN_GENERATION_NOT_FOUND", `Generation not found: ${generationId}`, 404); + } + const current = history[targetIndex]; + const updated = { + ...current, + count: questions.length, + questions + }; + rewriteAutoGenCaseSetFile(updated); + history[targetIndex] = updated; + writeAutoGenHistory(history); + (0, http_1.ok)(res, { + ok: true, + generation: updated + }); + } + catch (error) { + next(error); + } + }); + router.delete("/api/autoruns/autogen/history/:generation_id", (req, res, next) => { + try { + const generationId = toStringSafe(req.params.generation_id); + if (!generationId) { + throw new http_1.ApiError("INVALID_AUTOGEN_GENERATION_ID", "generation_id is required", 400); + } + const history = readAutoGenHistory(); + const targetIndex = history.findIndex((item) => item.generation_id === generationId); + if (targetIndex < 0) { + throw new http_1.ApiError("AUTOGEN_GENERATION_NOT_FOUND", `Generation not found: ${generationId}`, 404); + } + const target = history[targetIndex]; + const deletedFiles = []; + const caseSetPath = resolveFileInsideDir(config_1.EVAL_CASES_DIR, target.saved_case_set_file); + const savedSessionPath = resolveFileInsideDir(path_1.default.resolve(path_1.default.dirname(config_1.AUTORUN_GENERATOR_HISTORY_FILE), "saved_sessions"), target.context?.saved_session_file ?? null); + const deletedCaseSet = safeDeleteFile(caseSetPath); + if (deletedCaseSet) { + deletedFiles.push(deletedCaseSet); + } + const deletedSavedSession = safeDeleteFile(savedSessionPath); + if (deletedSavedSession) { + deletedFiles.push(deletedSavedSession); + } + history.splice(targetIndex, 1); + writeAutoGenHistory(history); + (0, http_1.ok)(res, { + ok: true, + generation_id: generationId, + deleted_files: deletedFiles + }); + } + catch (error) { + next(error); + } + }); router.post("/api/autoruns/autogen/generate", async (req, res, next) => { try { const body = toRecord(req.body); @@ -1925,6 +2196,9 @@ function buildAutoRunsRouter(openaiClient = new openaiResponsesClient_1.OpenAIRe const context = toRecord(body.context); const llmConfig = parseAutogenLlmRuntimeConfig(body, context); const personalityPrompt = toStringSafe(context?.autogen_personality_prompt); + if (mode === "saved_user_sessions") { + throw new http_1.ApiError("AUTOGEN_MODE_NOT_SUPPORTED", "Use `/api/autoruns/autogen/save-assistant-session` to save user sessions.", 400); + } let questions = []; if (mode === "qwen_seed") { if (!llmConfig) { @@ -1963,6 +2237,7 @@ function buildAutoRunsRouter(openaiClient = new openaiResponsesClient_1.OpenAIRe generation_id: generationId, created_at: new Date().toISOString(), mode, + title: null, count: questions.length, domain, questions, @@ -1980,7 +2255,10 @@ function buildAutoRunsRouter(openaiClient = new openaiResponsesClient_1.OpenAIRe autogen_personality_id: toStringSafe(context.autogen_personality_id), autogen_personality_prompt: toStringSafe(context.autogen_personality_prompt) ? repairAutogenMojibake(String(context.autogen_personality_prompt)) - : null + : null, + source_session_id: null, + saved_session_file: null, + saved_case_set_kind: "single_turn_list" } : null }; diff --git a/llm_normalizer/backend/dist/routes/eval.js b/llm_normalizer/backend/dist/routes/eval.js index 2edc415..261e398 100644 --- a/llm_normalizer/backend/dist/routes/eval.js +++ b/llm_normalizer/backend/dist/routes/eval.js @@ -128,14 +128,23 @@ function splitQuestionCandidate(raw) { } return normalizeRuntimeQuestionList(chunks); } -function normalizeRuntimeQuestions(value) { +function normalizeRuntimeQuestions(value, options) { const raw = toArray(value) .map((item) => (typeof item === "string" ? item.trim() : "")) .filter((item) => item.length > 0); if (raw.length === 0) { return []; } - const expanded = normalizeRuntimeQuestionList(raw.flatMap((item) => splitQuestionCandidate(item))); + const splitCandidates = options?.splitCandidates ?? true; + const expanded = splitCandidates + ? normalizeRuntimeQuestionList(raw.flatMap((item) => splitQuestionCandidate(item))) + : raw + .map((item) => normalizeQuestionChunk(item)) + .filter((item) => Boolean(item)); + const dedupe = options?.dedupe ?? true; + if (!dedupe) { + return expanded; + } const deduped = []; const seen = new Set(); for (const item of expanded) { @@ -272,6 +281,37 @@ function writeRuntimeAssistantSuiteFromQuestions(jobId, questions) { fs_1.default.writeFileSync(path_1.default.resolve(config_1.EVAL_CASES_DIR, fileName), JSON.stringify(payload, null, 2), "utf-8"); return fileName; } +function writeRuntimeAssistantScenarioSuiteFromQuestions(jobId, questions, title) { + if (!fs_1.default.existsSync(config_1.EVAL_CASES_DIR)) { + fs_1.default.mkdirSync(config_1.EVAL_CASES_DIR, { recursive: true }); + } + const turns = questions.map((question) => ({ + user_message: question + })); + const payload = { + suite_id: `assistant_saved_session_runtime_${jobId}`, + suite_version: "0.1.0", + schema_version: "assistant_saved_session_runtime_v0_1", + title: typeof title === "string" ? title.trim() || null : null, + scenario_count: turns.length > 0 ? 1 : 0, + case_ids: turns.length > 0 ? ["SAVED-001"] : [], + cases: turns.length > 0 + ? [ + { + case_id: "SAVED-001", + scenario_tag: "saved_user_sessions_runtime", + title: typeof title === "string" ? title.trim() || null : null, + question_type: turns.length > 1 ? "followup" : "direct", + broadness_level: "medium", + turns + } + ] + : [] + }; + const fileName = `assistant_saved_session_runtime_${jobId}.json`; + fs_1.default.writeFileSync(path_1.default.resolve(config_1.EVAL_CASES_DIR, fileName), JSON.stringify(payload, null, 2), "utf-8"); + return fileName; +} function readSessionConversation(runId, caseId) { const sessionId = `${runId}-${caseId}`; const filePath = path_1.default.resolve(config_1.ASSISTANT_SESSIONS_DIR, `${sessionId}.json`); @@ -414,15 +454,19 @@ function buildEvalRouter(services) { throw new http_1.ApiError("UNSUPPORTED_ASYNC_EVAL_TARGET", "Async eval currently supports assistant_stage1 only.", 400); } const questions = normalizeRuntimeQuestions(body.questions); + const scenarioQuestions = normalizeRuntimeQuestions(body.scenarioQuestions, { dedupe: false, splitCandidates: false }); + const scenarioTitle = toStringSafe(body.scenarioTitle); const jobId = `job-${(0, nanoid_1.nanoid)(10)}`; const runId = `assistant-stage1-${(0, nanoid_1.nanoid)(10)}`; - const runtimeCaseSetFile = questions.length > 0 - ? writeRuntimeAssistantSuiteFromQuestions(jobId, questions) - : payload.caseSetFile - ? payload.caseSetFile - : undefined; + const runtimeCaseSetFile = scenarioQuestions.length > 0 + ? writeRuntimeAssistantScenarioSuiteFromQuestions(jobId, scenarioQuestions, scenarioTitle ?? undefined) + : questions.length > 0 + ? writeRuntimeAssistantSuiteFromQuestions(jobId, questions) + : payload.caseSetFile + ? payload.caseSetFile + : undefined; if (!runtimeCaseSetFile) { - throw new http_1.ApiError("ASYNC_CASESET_REQUIRED", "Async assistant_stage1 run requires caseSetFile or explicit questions[] payload.", 400); + throw new http_1.ApiError("ASYNC_CASESET_REQUIRED", "Async assistant_stage1 run requires caseSetFile, scenarioQuestions[] or explicit questions[] payload.", 400); } const caseSeeds = readAssistantSuiteCaseSeeds(runtimeCaseSetFile); if (caseSeeds.length === 0) { diff --git a/llm_normalizer/backend/dist/server.js b/llm_normalizer/backend/dist/server.js index 5f07467..494b3a1 100644 --- a/llm_normalizer/backend/dist/server.js +++ b/llm_normalizer/backend/dist/server.js @@ -64,7 +64,7 @@ function createApp() { app.use((0, normalize_1.buildNormalizeRouter)(services)); app.use((0, eval_1.buildEvalRouter)(services)); app.use((0, assistant_1.buildAssistantRouter)(services)); - app.use((0, autoRuns_1.buildAutoRunsRouter)(openaiClient)); + app.use((0, autoRuns_1.buildAutoRunsRouter)(services, openaiClient)); app.use((0, history_1.buildHistoryRouter)()); app.use((0, presets_1.buildPresetsRouter)()); app.use((0, accountingAgent_1.buildAccountingAgentRouter)(services)); diff --git a/llm_normalizer/backend/src/routes/autoRuns.ts b/llm_normalizer/backend/src/routes/autoRuns.ts index 630a0cf..1bd36cf 100644 --- a/llm_normalizer/backend/src/routes/autoRuns.ts +++ b/llm_normalizer/backend/src/routes/autoRuns.ts @@ -11,13 +11,14 @@ import { MANUAL_CASE_DECISION_SCHEMA_FILE, REPORTS_DIR } from "../config"; +import type { AppServices } from "../serverContext"; import { ApiError, ok } from "../utils/http"; import { loadCapabilitiesRegistry, resolveNearestCapabilityGroup, type CapabilityGroup } from "../services/capabilitiesRegistry"; import { OpenAIResponsesClient } from "../services/openaiResponsesClient"; type AutoRunTarget = "normalizer" | "assistant_stage1" | "assistant_stage2" | "assistant_p0" | "unknown"; type AutoRunTrend = "up" | "down" | "flat"; -type AutoGenMode = "qwen_seed" | "codex_creative"; +type AutoGenMode = "qwen_seed" | "codex_creative" | "saved_user_sessions"; type ManualCaseDecision = | "covered_ok" | "covered_but_bad_answer" @@ -175,6 +176,7 @@ interface AutoGenHistoryRecord { generation_id: string; created_at: string; mode: AutoGenMode; + title: string | null; count: number; domain: string | null; questions: string[]; @@ -188,6 +190,9 @@ interface AutoGenHistoryRecord { prompt_fingerprint: string | null; autogen_personality_id: string | null; autogen_personality_prompt: string | null; + source_session_id?: string | null; + saved_session_file?: string | null; + saved_case_set_kind?: string | null; } | null; } @@ -269,6 +274,18 @@ function clampInt(value: number | null, min: number, max: number, fallback: numb return rounded; } +function isAutoGenMode(value: unknown): value is AutoGenMode { + return value === "qwen_seed" || value === "codex_creative" || value === "saved_user_sessions"; +} + +function parseAutoGenTitle(value: unknown): string | null { + const title = toStringSafe(value); + if (!title) { + return null; + } + return title.slice(0, 160); +} + function parseManualCaseDecision(value: unknown, fallback: ManualCaseDecision = "needs_dialog_policy_fix"): ManualCaseDecision { const normalized = toStringSafe(value); if (!normalized) return fallback; @@ -326,15 +343,11 @@ function readAutoGenHistory(): AutoGenHistoryRecord[] { .map((item) => ({ generation_id: toStringSafe(item.generation_id) ?? "", created_at: toStringSafe(item.created_at) ?? new Date().toISOString(), - mode: (toStringSafe(item.mode) as AutoGenMode | null) ?? "codex_creative", + mode: isAutoGenMode(toStringSafe(item.mode)) ? (toStringSafe(item.mode) as AutoGenMode) : "codex_creative", + title: parseAutoGenTitle(item.title), count: clampInt(toNumberSafe(item.count), 1, 300, 20), domain: toStringSafe(item.domain), - questions: toArray(item.questions) - .map((q) => toStringSafe(q)) - .filter((q): q is string => q !== null) - .map((q) => sanitizeGeneratedQuestion(q)) - .filter((q) => q.length > 0) - .slice(0, 500), + questions: parseAssistantSessionQuestions(item.questions), generated_by: toStringSafe(item.generated_by), saved_case_set_file: toStringSafe(item.saved_case_set_file), context: toRecord(item.context) @@ -349,7 +362,10 @@ function readAutoGenHistory(): AutoGenHistoryRecord[] { autogen_personality_id: toStringSafe(toRecord(item.context)?.autogen_personality_id), autogen_personality_prompt: toStringSafe(toRecord(item.context)?.autogen_personality_prompt) ? repairAutogenMojibake(String(toRecord(item.context)?.autogen_personality_prompt)) - : null + : null, + source_session_id: toStringSafe(toRecord(item.context)?.source_session_id), + saved_session_file: toStringSafe(toRecord(item.context)?.saved_session_file), + saved_case_set_kind: toStringSafe(toRecord(item.context)?.saved_case_set_kind) } : null })) @@ -1314,7 +1330,7 @@ function parseDecisionFilter(value: unknown): ManualCaseDecision | "all" { function parseAutoGenMode(value: unknown): AutoGenMode { const normalized = toStringSafe(value)?.toLowerCase() ?? ""; - if (normalized === "qwen_seed" || normalized === "codex_creative") { + if (normalized === "qwen_seed" || normalized === "codex_creative" || normalized === "saved_user_sessions") { return normalized; } return "codex_creative"; @@ -1416,6 +1432,13 @@ function sanitizeGeneratedQuestion(value: string): string { .trim(); } +function parseAssistantSessionQuestions(value: unknown): string[] { + return toArray(value) + .map((item) => sanitizeGeneratedQuestion(typeof item === "string" ? item : "")) + .filter((item) => item.length > 0) + .slice(0, 500); +} + const AUTOGEN_QUESTION_PLACEHOLDER_PATTERN = /^(?:questions?|вопросы?|список\s+вопросов)$/iu; const AUTOGEN_QUESTION_TAIL_PATTERNS: RegExp[] = [ /^(?:без\s+воды|по\s+факту|и\s+коротко|коротко|прям(?:\s+)?сейчас|за\s+весь\s+период|по\s+делу)\??$/iu @@ -1723,6 +1746,19 @@ function buildAutogenCaseSetFileName(mode: AutoGenMode, generationId: string): s return `assistant_autogen_${mode}_${stamp}_${generationId}.json`; } +function buildSavedAssistantSessionSnapshotFileName(generationId: string): string { + const now = new Date(); + const stamp = [ + now.getUTCFullYear(), + String(now.getUTCMonth() + 1).padStart(2, "0"), + String(now.getUTCDate()).padStart(2, "0"), + String(now.getUTCHours()).padStart(2, "0"), + String(now.getUTCMinutes()).padStart(2, "0"), + String(now.getUTCSeconds()).padStart(2, "0") + ].join(""); + return `assistant_saved_session_${stamp}_${generationId}.json`; +} + function buildAutogenCaseSetPayload(input: { generationId: string; mode: AutoGenMode; @@ -1757,6 +1793,118 @@ function buildAutogenCaseSetPayload(input: { }; } +function buildSavedSessionCaseSetPayload(input: { + generationId: string; + title: string | null; + questions: string[]; +}): Record { + const questions = parseAssistantSessionQuestions(input.questions); + const turns = questions.map((question) => ({ + user_message: question + })); + const caseId = "SAVED-001"; + return { + suite_id: `assistant_saved_session_${input.generationId}`, + suite_version: "0.1.0", + schema_version: "assistant_saved_session_suite_v0_1", + generated_at: new Date().toISOString(), + generation_id: input.generationId, + mode: "saved_user_sessions", + title: input.title, + scenario_count: turns.length > 0 ? 1 : 0, + case_ids: turns.length > 0 ? [caseId] : [], + cases: + turns.length > 0 + ? [ + { + case_id: caseId, + scenario_tag: "saved_user_sessions", + title: input.title, + question_type: turns.length > 1 ? "followup" : "direct", + broadness_level: "medium", + turns + } + ] + : [] + }; +} + +function ensureDirSync(targetDir: string): void { + if (!fs.existsSync(targetDir)) { + fs.mkdirSync(targetDir, { recursive: true }); + } +} + +function writeJsonFile(targetPath: string, payload: unknown): void { + ensureDirSync(path.dirname(targetPath)); + fs.writeFileSync(targetPath, JSON.stringify(payload, null, 2), "utf-8"); +} + +function rewriteAutoGenCaseSetFile(record: AutoGenHistoryRecord): string | null { + const caseSetFile = toStringSafe(record.saved_case_set_file); + if (!caseSetFile) { + return null; + } + const targetPath = path.resolve(EVAL_CASES_DIR, caseSetFile); + const payload = + record.mode === "saved_user_sessions" + ? buildSavedSessionCaseSetPayload({ + generationId: record.generation_id, + title: record.title, + questions: record.questions + }) + : buildAutogenCaseSetPayload({ + generationId: record.generation_id, + mode: record.mode, + domain: record.domain, + questions: record.questions + }); + writeJsonFile(targetPath, payload); + return caseSetFile; +} + +function writeSavedAssistantSessionSnapshot(input: { + generationId: string; + sessionId: string; + title: string | null; + session: Record; + questions: string[]; +}): string { + const fileName = buildSavedAssistantSessionSnapshotFileName(input.generationId); + const targetPath = path.resolve(path.dirname(AUTORUN_GENERATOR_HISTORY_FILE), "saved_sessions", fileName); + writeJsonFile(targetPath, { + saved_at: new Date().toISOString(), + generation_id: input.generationId, + mode: "saved_user_sessions", + title: input.title, + source_session_id: input.sessionId, + questions: input.questions, + session: input.session + }); + return fileName; +} + +function resolveFileInsideDir(baseDir: string, fileName: string | null | undefined): string | null { + const normalized = toStringSafe(fileName); + if (!normalized) { + return null; + } + const targetPath = path.resolve(baseDir, normalized); + const relative = path.relative(baseDir, targetPath); + if (relative.startsWith("..") || path.isAbsolute(relative)) { + return null; + } + return targetPath; +} + +function safeDeleteFile(targetPath: string | null): string | null { + if (!targetPath || !fs.existsSync(targetPath)) { + return null; + } + fs.unlinkSync(targetPath); + return targetPath; +} + function collectPostAnalysis( annotations: AutoRunAnnotationRecord[], runMap: Map, @@ -1854,7 +2002,7 @@ function collectPostAnalysis( }; } -export function buildAutoRunsRouter(openaiClient = new OpenAIResponsesClient()): Router { +export function buildAutoRunsRouter(services: AppServices, openaiClient = new OpenAIResponsesClient()): Router { const router = Router(); router.get("/api/autoruns/history", (req, res) => { @@ -2251,7 +2399,7 @@ export function buildAutoRunsRouter(openaiClient = new OpenAIResponsesClient()): try { const limit = clampInt(toNumberSafe((req.query as Record).limit), 1, 500, 120); const rawMode = toStringSafe((req.query as Record).mode); - const includeAllModes = !rawMode || !["qwen_seed", "codex_creative"].includes(rawMode); + const includeAllModes = !rawMode || !isAutoGenMode(rawMode); const modeFilter = (rawMode as AutoGenMode | null) ?? "codex_creative"; const items = readAutoGenHistory() .filter((item) => (includeAllModes ? true : item.mode === modeFilter)) @@ -2279,6 +2427,182 @@ export function buildAutoRunsRouter(openaiClient = new OpenAIResponsesClient()): } }); + router.post("/api/autoruns/autogen/save-assistant-session", (req, res, next) => { + try { + const body = toRecord(req.body); + if (!body) { + throw new ApiError("INVALID_AUTOGEN_SAVE_SESSION_PAYLOAD", "JSON body is required", 400); + } + + const sessionId = toStringSafe(body.session_id); + const title = parseAutoGenTitle(body.title); + const generatedBy = parseAnnotationAuthor(body.generated_by); + const context = toRecord(body.context); + + if (!sessionId) { + throw new ApiError("INVALID_AUTOGEN_SAVE_SESSION_PAYLOAD", "session_id is required", 400); + } + if (!title) { + throw new ApiError("INVALID_AUTOGEN_SAVE_SESSION_PAYLOAD", "title is required", 400); + } + + const session = services.assistantService.getSession(sessionId); + if (!session) { + throw new ApiError("ASSISTANT_SESSION_NOT_FOUND", `Session not found: ${sessionId}`, 404); + } + + const questions = session.items + .filter((item: { role: string }) => item.role === "user") + .map((item: { text: string }) => sanitizeGeneratedQuestion(item.text)) + .filter((item: string) => item.length > 0); + + if (questions.length === 0) { + throw new ApiError("ASSISTANT_SESSION_EMPTY", "Assistant session has no user questions to save.", 400); + } + + const generationId = generateAutogenId(); + const caseSetFile = buildAutogenCaseSetFileName("saved_user_sessions", generationId); + const caseSetPath = path.resolve(EVAL_CASES_DIR, caseSetFile); + writeJsonFile( + caseSetPath, + buildSavedSessionCaseSetPayload({ + generationId, + title, + questions + }) + ); + + const snapshotFile = writeSavedAssistantSessionSnapshot({ + generationId, + sessionId, + title, + session: session as unknown as Record, + questions + }); + + const record: AutoGenHistoryRecord = { + generation_id: generationId, + created_at: new Date().toISOString(), + mode: "saved_user_sessions", + title, + count: questions.length, + domain: null, + questions, + generated_by: generatedBy, + saved_case_set_file: caseSetFile, + context: { + llm_provider: toStringSafe(context?.llm_provider), + model: toStringSafe(context?.model), + assistant_prompt_version: toStringSafe(context?.assistant_prompt_version), + decomposition_prompt_version: toStringSafe(context?.decomposition_prompt_version), + prompt_fingerprint: toStringSafe(context?.prompt_fingerprint) + ? repairAutogenMojibake(String(context?.prompt_fingerprint)) + : null, + autogen_personality_id: null, + autogen_personality_prompt: null, + source_session_id: sessionId, + saved_session_file: snapshotFile, + saved_case_set_kind: "assistant_session_scenario" + } + }; + + const history = readAutoGenHistory(); + history.unshift(record); + writeAutoGenHistory(history.slice(0, 500)); + + ok(res, { + ok: true, + generation: record + }); + } catch (error) { + next(error); + } + }); + + router.patch("/api/autoruns/autogen/history/:generation_id/questions", (req, res, next) => { + try { + const generationId = toStringSafe(req.params.generation_id); + const body = toRecord(req.body); + if (!generationId) { + throw new ApiError("INVALID_AUTOGEN_GENERATION_ID", "generation_id is required", 400); + } + if (!body) { + throw new ApiError("INVALID_AUTOGEN_QUESTIONS_PAYLOAD", "JSON body is required", 400); + } + + const questions = parseAssistantSessionQuestions(body.questions); + if (questions.length === 0) { + throw new ApiError("INVALID_AUTOGEN_QUESTIONS_PAYLOAD", "questions must contain at least one item", 400); + } + + const history = readAutoGenHistory(); + const targetIndex = history.findIndex((item) => item.generation_id === generationId); + if (targetIndex < 0) { + throw new ApiError("AUTOGEN_GENERATION_NOT_FOUND", `Generation not found: ${generationId}`, 404); + } + + const current = history[targetIndex]; + const updated: AutoGenHistoryRecord = { + ...current, + count: questions.length, + questions + }; + rewriteAutoGenCaseSetFile(updated); + history[targetIndex] = updated; + writeAutoGenHistory(history); + + ok(res, { + ok: true, + generation: updated + }); + } catch (error) { + next(error); + } + }); + + router.delete("/api/autoruns/autogen/history/:generation_id", (req, res, next) => { + try { + const generationId = toStringSafe(req.params.generation_id); + if (!generationId) { + throw new ApiError("INVALID_AUTOGEN_GENERATION_ID", "generation_id is required", 400); + } + + const history = readAutoGenHistory(); + const targetIndex = history.findIndex((item) => item.generation_id === generationId); + if (targetIndex < 0) { + throw new ApiError("AUTOGEN_GENERATION_NOT_FOUND", `Generation not found: ${generationId}`, 404); + } + + const target = history[targetIndex]; + const deletedFiles: string[] = []; + const caseSetPath = resolveFileInsideDir(EVAL_CASES_DIR, target.saved_case_set_file); + const savedSessionPath = resolveFileInsideDir( + path.resolve(path.dirname(AUTORUN_GENERATOR_HISTORY_FILE), "saved_sessions"), + target.context?.saved_session_file ?? null + ); + + const deletedCaseSet = safeDeleteFile(caseSetPath); + if (deletedCaseSet) { + deletedFiles.push(deletedCaseSet); + } + const deletedSavedSession = safeDeleteFile(savedSessionPath); + if (deletedSavedSession) { + deletedFiles.push(deletedSavedSession); + } + + history.splice(targetIndex, 1); + writeAutoGenHistory(history); + + ok(res, { + ok: true, + generation_id: generationId, + deleted_files: deletedFiles + }); + } catch (error) { + next(error); + } + }); + router.post("/api/autoruns/autogen/generate", async (req, res, next) => { try { const body = toRecord(req.body); @@ -2294,6 +2618,14 @@ export function buildAutoRunsRouter(openaiClient = new OpenAIResponsesClient()): const llmConfig = parseAutogenLlmRuntimeConfig(body, context); const personalityPrompt = toStringSafe(context?.autogen_personality_prompt); + if (mode === "saved_user_sessions") { + throw new ApiError( + "AUTOGEN_MODE_NOT_SUPPORTED", + "Use `/api/autoruns/autogen/save-assistant-session` to save user sessions.", + 400 + ); + } + let questions: string[] = []; if (mode === "qwen_seed") { if (!llmConfig) { @@ -2340,6 +2672,7 @@ export function buildAutoRunsRouter(openaiClient = new OpenAIResponsesClient()): generation_id: generationId, created_at: new Date().toISOString(), mode, + title: null, count: questions.length, domain, questions, @@ -2357,7 +2690,10 @@ export function buildAutoRunsRouter(openaiClient = new OpenAIResponsesClient()): autogen_personality_id: toStringSafe(context.autogen_personality_id), autogen_personality_prompt: toStringSafe(context.autogen_personality_prompt) ? repairAutogenMojibake(String(context.autogen_personality_prompt)) - : null + : null, + source_session_id: null, + saved_session_file: null, + saved_case_set_kind: "single_turn_list" } : null }; diff --git a/llm_normalizer/backend/src/routes/eval.ts b/llm_normalizer/backend/src/routes/eval.ts index 2c1186f..36d3314 100644 --- a/llm_normalizer/backend/src/routes/eval.ts +++ b/llm_normalizer/backend/src/routes/eval.ts @@ -176,7 +176,7 @@ function splitQuestionCandidate(raw: string): string[] { return normalizeRuntimeQuestionList(chunks); } -function normalizeRuntimeQuestions(value: unknown): string[] { +function normalizeRuntimeQuestions(value: unknown, options?: { dedupe?: boolean; splitCandidates?: boolean }): string[] { const raw = toArray(value) .map((item) => (typeof item === "string" ? item.trim() : "")) .filter((item) => item.length > 0); @@ -184,7 +184,16 @@ function normalizeRuntimeQuestions(value: unknown): string[] { return []; } - const expanded = normalizeRuntimeQuestionList(raw.flatMap((item) => splitQuestionCandidate(item))); + const splitCandidates = options?.splitCandidates ?? true; + const expanded = splitCandidates + ? normalizeRuntimeQuestionList(raw.flatMap((item) => splitQuestionCandidate(item))) + : raw + .map((item) => normalizeQuestionChunk(item)) + .filter((item): item is string => Boolean(item)); + const dedupe = options?.dedupe ?? true; + if (!dedupe) { + return expanded; + } const deduped: string[] = []; const seen = new Set(); for (const item of expanded) { @@ -342,6 +351,39 @@ function writeRuntimeAssistantSuiteFromQuestions(jobId: string, questions: strin return fileName; } +function writeRuntimeAssistantScenarioSuiteFromQuestions(jobId: string, questions: string[], title?: string): string { + if (!fs.existsSync(EVAL_CASES_DIR)) { + fs.mkdirSync(EVAL_CASES_DIR, { recursive: true }); + } + const turns = questions.map((question) => ({ + user_message: question + })); + const payload = { + suite_id: `assistant_saved_session_runtime_${jobId}`, + suite_version: "0.1.0", + schema_version: "assistant_saved_session_runtime_v0_1", + title: typeof title === "string" ? title.trim() || null : null, + scenario_count: turns.length > 0 ? 1 : 0, + case_ids: turns.length > 0 ? ["SAVED-001"] : [], + cases: + turns.length > 0 + ? [ + { + case_id: "SAVED-001", + scenario_tag: "saved_user_sessions_runtime", + title: typeof title === "string" ? title.trim() || null : null, + question_type: turns.length > 1 ? "followup" : "direct", + broadness_level: "medium", + turns + } + ] + : [] + }; + const fileName = `assistant_saved_session_runtime_${jobId}.json`; + fs.writeFileSync(path.resolve(EVAL_CASES_DIR, fileName), JSON.stringify(payload, null, 2), "utf-8"); + return fileName; +} + function readSessionConversation(runId: string, caseId: string): EvalAsyncCaseInfo["messages"] { const sessionId = `${runId}-${caseId}`; const filePath = path.resolve(ASSISTANT_SESSIONS_DIR, `${sessionId}.json`); @@ -489,11 +531,15 @@ export function buildEvalRouter(services: AppServices): Router { throw new ApiError("UNSUPPORTED_ASYNC_EVAL_TARGET", "Async eval currently supports assistant_stage1 only.", 400); } const questions = normalizeRuntimeQuestions(body.questions); + const scenarioQuestions = normalizeRuntimeQuestions(body.scenarioQuestions, { dedupe: false, splitCandidates: false }); + const scenarioTitle = toStringSafe(body.scenarioTitle); const jobId = `job-${nanoid(10)}`; const runId = `assistant-stage1-${nanoid(10)}`; const runtimeCaseSetFile = - questions.length > 0 + scenarioQuestions.length > 0 + ? writeRuntimeAssistantScenarioSuiteFromQuestions(jobId, scenarioQuestions, scenarioTitle ?? undefined) + : questions.length > 0 ? writeRuntimeAssistantSuiteFromQuestions(jobId, questions) : payload.caseSetFile ? payload.caseSetFile @@ -502,7 +548,7 @@ export function buildEvalRouter(services: AppServices): Router { if (!runtimeCaseSetFile) { throw new ApiError( "ASYNC_CASESET_REQUIRED", - "Async assistant_stage1 run requires caseSetFile or explicit questions[] payload.", + "Async assistant_stage1 run requires caseSetFile, scenarioQuestions[] or explicit questions[] payload.", 400 ); } diff --git a/llm_normalizer/backend/src/server.ts b/llm_normalizer/backend/src/server.ts index f715445..bebad26 100644 --- a/llm_normalizer/backend/src/server.ts +++ b/llm_normalizer/backend/src/server.ts @@ -76,7 +76,7 @@ export function createApp(): express.Express { app.use(buildNormalizeRouter(services)); app.use(buildEvalRouter(services)); app.use(buildAssistantRouter(services)); - app.use(buildAutoRunsRouter(openaiClient)); + app.use(buildAutoRunsRouter(services, openaiClient)); app.use(buildHistoryRouter()); app.use(buildPresetsRouter()); app.use(buildAccountingAgentRouter(services)); diff --git a/llm_normalizer/data/autorun_generators/history.json b/llm_normalizer/data/autorun_generators/history.json index 95fdf4c..450cabb 100644 --- a/llm_normalizer/data/autorun_generators/history.json +++ b/llm_normalizer/data/autorun_generators/history.json @@ -1,8 +1,34 @@ [ + { + "generation_id": "gen-mo1s0m9z-ndf56a3", + "created_at": "2026-04-16T17:51:50.476Z", + "mode": "saved_user_sessions", + "title": "Ручная сессия 16.04.2026, 20:51:30", + "count": 1, + "domain": null, + "questions": [ + "привет как дела" + ], + "generated_by": "manual_reviewer", + "saved_case_set_file": "assistant_autogen_saved_user_sessions_20260416175150_gen-mo1s0m9z-ndf56a3.json", + "context": { + "llm_provider": "local", + "model": "unsloth/qwen3-30b-a3b-instruct-2507", + "assistant_prompt_version": "address_query_runtime_v1", + "decomposition_prompt_version": "normalizer_v2_0_2", + "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.||You are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and candidate labels.\n4. For each fragment set execution state fields:\n - execution_readiness\n - clarification_reason\n - soft_assumption_used\n - route_status\n - no_route_reason\n5. Clarification must be rare and justified.\n\nExecution-state policy:\n- Every in-scope fragment must produce a consistent execution state.\n- If a fragment is routable, mark it as executable or executable_with_soft_assumptions.\n- Do not leave routable fragments in unresolved state.\n- If a fragment cannot be routed, set route_status=no_route and provide explicit no_route_reason.\n\nReadiness values:\n- executable\n- executable_with_soft_assumptions\n- needs_clarification\n- no_route\n\nRoute status values:\n- routed\n- no_route\n\nNo-route reason values:\n- out_of_scope\n- insufficient_specificity\n- missing_mapping\n- unsupported_fragment_type\n\nDo not over-require formality:\n- Do not require document IDs, exact periods, or exact object references for scan/review/anomaly/rule-check requests.\n- Colloquial accounting phrases like \"что висит\", \"что подозрительно\", \"что не сходится\", \"что криво\", \"что аукнется\" are executable if accounting area is understandable.\n\nFragment required fields:\n- fragment_id\n- raw_fragment_text\n- normalized_fragment_text\n- domain_relevance\n- business_scope\n- entity_hints\n- account_hints\n- document_hints\n- register_hints\n- time_scope\n- flags\n- candidate_labels\n- confidence\n- execution_readiness\n- clarification_reason\n- soft_assumption_used\n- route_status\n- no_route_reason\n\nSoft assumptions (`soft_assumption_used`) allowed values:\n- period_from_session_context\n- company_scope_defaulted\n- problem_scan_mode_enabled\n\nGlobal notes:\n- global_notes.needs_clarification should be true only when execution is truly blocked for all in-scope fragments.\n- global_notes.clarification_reason must explain the blocker.\n\nSchema version must be:\n- \"schema_version\": \"normalized_query_v2_0_2\"||Контекст домена: бухгалтерия 1С/NDC.\n\nКлючевые счета:\n- 01, 02, 10, 41, 51, 60, 62, 68.02, 90, 97.\n\nТиповые сущности:\n- контрагент, договор, документ реализации, документ поступления, оплата, проводка, регистр, закрывающий документ.\n\nЛексика causal и сверки (сильные сигналы для cross_entity):\n- \"не бьется\", \"не сходится\", \"не видно\", \"не собралось\", \"повисло\", \"хвост\";\n- \"разложи по документам/оплатам/закрывающим\";\n- \"чем подтверждается\", \"где ошибка в цепочке\", \"что пошло криво\".\n\nЛексика точечного drilldown:\n- \"документ №...\", \"ref\", \"строка проводки\", \"покажи конкретную операцию\", \"точный source-of-record\".\n\nЛексика rule-based контроля:\n- \"проверь настройки\", \"ошибка срока/даты\", \"контроль 97/10/ОС\", \"нарушение правила учета\".\n\nЛексика обзорной аналитики:\n- \"рейтинг\", \"топ рисков\", \"в целом по компании\", \"перед закрытием периода\", \"приоритизация проверок\".\n\nВажное правило:\nЕсли в одном вопросе есть и риск-лексика, и цепочка document/payment/posting, не понижать задачу до чистого `store_feature_risk`.\nПриоритет у causal cross-entity семантики.||v2.0.2: execution-state hardening + explicit route_status/no_route_reason. Схема normalized_query_v2_0_2.||Q: По каким поставщикам висят хвосты по 60, что подозрительно по цепочке оплат?\nA: in_scope fragment, execution_readiness=executable_with_soft_assumptions, route_status=routed, no_route_reason=null.\n\nQ: Покажи записи по 97, которые повисли и могут аукнуться.\nA: in_scope fragment, execution_readiness=executable_with_soft_assumptions, route_status=routed, no_route_reason=null.\n\nQ: Чекни, что у нас не так.\nA: unclear/in_scope fragment, execution_readiness=needs_clarification, route_status=no_route, no_route_reason=insufficient_specificity.\n\nQ: Как вообще по ФСБУ правильно?\nA: out_of_scope fragment, execution_readiness=no_route, route_status=no_route, no_route_reason=out_of_scope.", + "autogen_personality_id": null, + "autogen_personality_prompt": null, + "source_session_id": "asst-iIpNheKZpP", + "saved_session_file": "assistant_saved_session_20260416175150_gen-mo1s0m9z-ndf56a3.json", + "saved_case_set_kind": "assistant_session_scenario" + } + }, { "generation_id": "gen-mnubheq4-7h5v00u", "created_at": "2026-04-11T12:34:37.133Z", "mode": "qwen_seed", + "title": null, "count": 15, "domain": null, "questions": [ @@ -31,13 +57,17 @@ "decomposition_prompt_version": "normalizer_v2_0_2", "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.\nYou are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and ", "autogen_personality_id": "general", - "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл. акцент на контрагентов, долги нсд, счета, общий вывод по компании - контрагенты, заказчикам, скока денег кто принес и какие остатки по счетам, поиск документов, сальдо, банковские операции, незакрытые договора, документы по договорам, долги, Активность заказчиков по периодам, Поставщики и выплаты" + "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл. акцент на контрагентов, долги нсд, счета, общий вывод по компании - контрагенты, заказчикам, скока денег кто принес и какие остатки по счетам, поиск документов, сальдо, банковские операции, незакрытые договора, документы по договорам, долги, Активность заказчиков по периодам, Поставщики и выплаты", + "source_session_id": null, + "saved_session_file": null, + "saved_case_set_kind": null } }, { "generation_id": "gen-mnua8bfg-00u7c2z", "created_at": "2026-04-11T11:59:33.340Z", "mode": "qwen_seed", + "title": null, "count": 15, "domain": null, "questions": [ @@ -66,13 +96,17 @@ "decomposition_prompt_version": "normalizer_v2_0_2", "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.\nYou are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and ", "autogen_personality_id": "general", - "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл. акцент на контрагентов, долги нсд, счета, общий вывод по компании - контрагенты, заказчикам, скока денег кто принес и какие остатки по счетам, поиск документов, сальдо, банковские операции, незакрытые договора, документы по договорам, долги, Активность заказчиков по периодам, Поставщики и выплаты" + "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл. акцент на контрагентов, долги нсд, счета, общий вывод по компании - контрагенты, заказчикам, скока денег кто принес и какие остатки по счетам, поиск документов, сальдо, банковские операции, незакрытые договора, документы по договорам, долги, Активность заказчиков по периодам, Поставщики и выплаты", + "source_session_id": null, + "saved_session_file": null, + "saved_case_set_kind": null } }, { "generation_id": "gen-mnte8abx-ax3v3tr", "created_at": "2026-04-10T21:03:44.205Z", "mode": "qwen_seed", + "title": null, "count": 10, "domain": null, "questions": [ @@ -96,13 +130,17 @@ "decomposition_prompt_version": "normalizer_v2_0_2", "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.\nYou are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and ", "autogen_personality_id": "general", - "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл. акцент на контрагентов, долги нсд, счета, общий вывод по компании - контрагенты, заказчикам, скока денег кто принес и какие остатки по счетам, поиск документов, сальдо, банковские операции, незакрытые договора, документы по договорам, долги, Активность заказчиков по периодам, Поставщики и выплаты" + "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл. акцент на контрагентов, долги нсд, счета, общий вывод по компании - контрагенты, заказчикам, скока денег кто принес и какие остатки по счетам, поиск документов, сальдо, банковские операции, незакрытые договора, документы по договорам, долги, Активность заказчиков по периодам, Поставщики и выплаты", + "source_session_id": null, + "saved_session_file": null, + "saved_case_set_kind": null } }, { "generation_id": "gen-mnte6y9p-4v1kfbw", "created_at": "2026-04-10T21:02:41.918Z", "mode": "qwen_seed", + "title": null, "count": 10, "domain": null, "questions": [ @@ -126,13 +164,17 @@ "decomposition_prompt_version": "normalizer_v2_0_2", "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.\nYou are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and ", "autogen_personality_id": "general", - "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл. акцент на контрагентов, долги нсд, счета, общий вывод по компании - контрагенты, заказчикам, скока денег кто принес и какие остатки по счетам, поиск документов, сальдо, банковские операции, незакрытые договора, документы по договорам, долги, Активность заказчиков по периодам, Поставщики и выплаты" + "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл. акцент на контрагентов, долги нсд, счета, общий вывод по компании - контрагенты, заказчикам, скока денег кто принес и какие остатки по счетам, поиск документов, сальдо, банковские операции, незакрытые договора, документы по договорам, долги, Активность заказчиков по периодам, Поставщики и выплаты", + "source_session_id": null, + "saved_session_file": null, + "saved_case_set_kind": null } }, { "generation_id": "gen-mnsolawk-vugqyoc", "created_at": "2026-04-10T09:06:01.461Z", "mode": "qwen_seed", + "title": null, "count": 20, "domain": null, "questions": [ @@ -166,13 +208,17 @@ "decomposition_prompt_version": "normalizer_v2_0_2", "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.\nYou are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and ", "autogen_personality_id": "general", - "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл. акцент на контрагентов \\ нсд \\ счета \\ общий ваывод по компании - контрагенты заказчиким скока денег кто принес и тп" + "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл. акцент на контрагентов \\ нсд \\ счета \\ общий ваывод по компании - контрагенты заказчиким скока денег кто принес и тп", + "source_session_id": null, + "saved_session_file": null, + "saved_case_set_kind": null } }, { "generation_id": "gen-mnsmzzcr-ffcz48q", "created_at": "2026-04-10T08:21:27.099Z", "mode": "qwen_seed", + "title": null, "count": 20, "domain": null, "questions": [ @@ -206,13 +252,17 @@ "decomposition_prompt_version": "normalizer_v2_0_2", "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.\nYou are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and ", "autogen_personality_id": "general", - "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл. акцент на контрагентов \\ нсд \\ счета \\ общий ваывод по компании - контрагенты заказчиким скока денег кто принес и тп" + "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл. акцент на контрагентов \\ нсд \\ счета \\ общий ваывод по компании - контрагенты заказчиким скока денег кто принес и тп", + "source_session_id": null, + "saved_session_file": null, + "saved_case_set_kind": null } }, { "generation_id": "gen-mnrvs132-1dewq5r", "created_at": "2026-04-09T19:39:26.463Z", "mode": "qwen_seed", + "title": null, "count": 5, "domain": null, "questions": [ @@ -231,13 +281,17 @@ "decomposition_prompt_version": "normalizer_v2_0_2", "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.\nYou are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and ", "autogen_personality_id": "general", - "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл." + "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл.", + "source_session_id": null, + "saved_session_file": null, + "saved_case_set_kind": null } }, { "generation_id": "gen-mnrvqxcg-wa3jsro", "created_at": "2026-04-09T19:38:34.961Z", "mode": "qwen_seed", + "title": null, "count": 5, "domain": null, "questions": [ @@ -256,13 +310,17 @@ "decomposition_prompt_version": "normalizer_v2_0_2", "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.\nYou are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and ", "autogen_personality_id": "general", - "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл." + "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл.", + "source_session_id": null, + "saved_session_file": null, + "saved_case_set_kind": null } }, { "generation_id": "gen-mnrshzcm-xyiv4gs", "created_at": "2026-04-09T18:07:38.807Z", "mode": "qwen_seed", + "title": null, "count": 10, "domain": null, "questions": [ @@ -286,13 +344,17 @@ "decomposition_prompt_version": "normalizer_v2_0_2", "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.\nYou are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and ", "autogen_personality_id": "general", - "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл." + "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл.", + "source_session_id": null, + "saved_session_file": null, + "saved_case_set_kind": null } }, { "generation_id": "gen-mnrrdfbj-mrcxcjg", "created_at": "2026-04-09T17:36:06.608Z", "mode": "qwen_seed", + "title": null, "count": 10, "domain": null, "questions": [ @@ -316,13 +378,17 @@ "decomposition_prompt_version": "normalizer_v2_0_2", "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.\nYou are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and", "autogen_personality_id": "general", - "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл." + "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл.", + "source_session_id": null, + "saved_session_file": null, + "saved_case_set_kind": null } }, { "generation_id": "gen-mnrnrwtc-za8a8o0", "created_at": "2026-04-09T15:55:24.001Z", "mode": "qwen_seed", + "title": null, "count": 20, "domain": null, "questions": [ @@ -356,13 +422,17 @@ "decomposition_prompt_version": "normalizer_v2_0_2", "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.\nYou are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and", "autogen_personality_id": "general", - "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл." + "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл.", + "source_session_id": null, + "saved_session_file": null, + "saved_case_set_kind": null } }, { "generation_id": "gen-mnrmoiey-j9akyvu", "created_at": "2026-04-09T15:24:45.754Z", "mode": "qwen_seed", + "title": null, "count": 2, "domain": "settlements", "questions": [ @@ -378,81 +448,10 @@ "decomposition_prompt_version": null, "prompt_fingerprint": null, "autogen_personality_id": null, - "autogen_personality_prompt": "????????? ??????? ??????? ?? ????????." - } - }, - { - "generation_id": "gen-mnrmc8bu-wv7c3o0", - "created_at": "2026-04-09T15:15:12.810Z", - "mode": "qwen_seed", - "count": 54, - "domain": null, - "questions": [ - "{\"questions\":[\"По каким покупателям у нас на конец месяца хвосты с отгрузками без денег уже стали нормой и требуют проверки?\",\"Где по контрагентам висит история 'отгрузили - денег нет - закрытия нет', которая точно нуждается в ручной проверке?\",\"Покажи контрагентов, у которых сальдо скорее всего не совпадет с их актуальным актом сверки сейчас.\",\"Где есть оплаты, но отсутствуют документы для закрытия взаиморасчетов?\",\"По каким контрагентам документы есть, а нормального закрытия оплатами нет вовсе?\",\"Есть ли зависшие авансы, которые давно надо было перепроверить или уже списать как неликвидные?\",\"Какие реализации на конец периода выглядят так, будто они зависли и могут испортить картину по выручке без проверки?\",\"По каким отгрузкам видно, что проблема не просто в оплате клиента, а в кривой сборке документов изначально?\",\"Где у нас есть непогашенные задолженности поставщикам, которые уже давно требуют прокрутки и анализа?\",\"Какие счета-фактуры выставлены, но не оплачены на конец месяца - нужно их проверить или отозвать?\",\"Покажи контрагентов, у которых висят отгрузки без документов подтверждения принятия. Это уже проблема или еще нет?\",\"Есть ли такие покупатели, по которым сальдо точно не совпадает с актуальным состоянием их расчетов - нужно проверить и исправить?\",\"Где есть документы, но оплаты не приходят, хотя все сроки давно прошли?\",\"Какие отгрузки на конец периода выглядят так, будто они зависли и будут портить картину по выручке без прокрутки?\",\"По каким контрагентам видно, что проблема в сборе документов изначально, а не просто в задержке оплаты клиентом?\",\"Где у нас есть непогашенные авансы покупателей, которые давно требуют пересмотра и анализа?\",\"Какие счета-фактуры выставлены, но не отражены в документах подтверждения принятия - нужно их проверить или отозвать?\",\"Покажи контрагентов, у которых сальдо точно не совпадает с актуальным состоянием расчетов. Это уже проблема или еще нет?\",\"Где есть оплаты, но документов для закрытия взаиморасчетов все равно не хватает?\",\"По каким контрагентам документы есть, а нормального закрытия оплатами так и не видно - это уже проблема или еще нет?\",\"Есть ли такие зависшие авансы, которые давно надо было перепроверить или списать как неликвидные?\",\"Какие реализации на конец периода выглядят так, будто они зависли и могут испортить картину по выручке без проверки?\",\"По каким отгрузкам видно, что проблема не просто в оплате клиента, а в кривой сборке документов изначально?\",\"Где у нас есть непогашенные задолженности поставщикам, которые уже давно требуют прокрутки и анализа?\",\"Какие счета-фактуры выставлены, но не оплачены на конец месяца - нужно их проверить или отозвать?\",\"Покажи контрагентов, у которых висят отгрузки без документов подтверждения принятия. Это уже проблема или еще нет?\",\"Есть ли такие покупатели, по которым сальдо точно не совпадает с актуальным состоянием их расчетов - нужно проверить", - "йо По каким поставщикам у нас на конец месяца остались хвосты, которые уже не похожи на обычную задержку документов, а выглядят как реальная проблема в цепочке?", - "слушай Где по покупателям у нас висит история \"отгрузили - денег нет - закрытия нет\", и по каким контрагентам это уже требует ручной проверки? без воды", - "подскажи плиз Покажи контрагентов, по которым сальдо у нас, скорее всего, не совпадет с их актом сверки, если его запросить прямо сейчас. по факту", - "короче Где у нас есть оплаты, но не хватает документов, которые должны были закрыть взаиморасчеты? и коротко", - "мож По каким контрагентам, наоборот, документы есть, а нормального закрытия оплатами не видно? прям сейчас", - "а ну-ка Есть ли такие зависшие авансы, которые уже давно надо было либо закрыть, либо хотя бы перепроверить руками? за весь период", - "йо Какие реализации на конец периода выглядят так, будто они зависли и будут портить картину по выручке, если их не проверить заранее?", - "слушай По каким отгрузкам видно, что проблема не просто в том, что клиент не оплатил, а в том, что сама связка документов собрана криво? без воды", - "подскажи плиз Покажи реализации, где хвост выглядит особенно неприятно: сумма не маленькая, возраст хвоста уже заметный, и при этом не видно нормального завершения цепочки. по факту", - "короче Где по 90/62 история похожа на \"вроде все проведено, но если копнуть, закрытие держится на кривой связке\"? и коротко", - "мож Есть ли случаи, где реализация попала в период, а подтверждающие документы или оплата до сих пор живут в какой-то полуразобранной логике? прям сейчас", - "а ну-ка По каким продажам на конец месяца видно, что бухгалтер потом будет долго распутывать, почему все это не сошлось нормально? за весь период", - "йо Какие банковские движения выглядят так, будто выписка есть, а нормального отражения в учете под ней не хватает?", - "слушай Где по банку можно заподозрить, что документ и проводка вроде есть, но логика операции все равно не собрана в нормальную цепочку? без воды", - "подскажи плиз Есть ли движения по счету 51, которые выглядят корректно по сумме, но по смыслу оставляют после себя подозрительный хвост? по факту", - "короче Покажи банковские кейсы, где, скорее всего, проблема не в платеже как таковом, а в том, что он не туда лег или не тем документом закрылся. и коротко", - "мож Где банк и бухгалтерский контур, скорее всего, расходятся не по одной строке, а по паттерну, который уже начинает повторяться? прям сейчас", - "а ну-ка Какие товарные позиции выглядят так, будто их уже продавали, а нормального прихода под них в базе не видно? за весь период", - "йо Где по товарам у нас отрицательные или подозрительные остатки, которые, скорее всего, связаны не с жизнью, а с ошибкой в учете?", - "слушай Есть ли случаи, где приход и реализация вроде есть оба, но даты между ними выглядят так, будто кто-то завел документы задним числом или с ошибкой? без воды", - "подскажи плиз Покажи товарные хвосты, которые сильнее всего искажают картину периода и требуют проверки до закрытия месяца. по факту", - "короче Где по складу и реализации видно, что себестоимость продажи подтверждена слабо или вообще опирается на кривую цепочку? и коротко", - "мож Что сейчас лежит на 10 счете так, будто это уже давно надо было либо списать, либо хотя бы проверить, почему оно до сих пор висит? прям сейчас", - "а ну-ка Есть ли материалы, по которым остаток выглядит нелогично: движения были, хозяйственная логика слабая, а в учете все еще что-то торчит? за весь период", - "йо Покажи позиции по материалам, где возможен эффект \"вроде сумма не огромная, но учетная логика выглядит криво\".", - "слушай Какие записи на 97 счете больше всего похожи на ошибку в датах начала, конца или самом сроке списания? без воды", - "подскажи плиз Есть ли такие расходы будущих периодов, которые заведены, но по ним не видно нормальной ежемесячной жизни, как будто запись повисла сама по себе? по факту", - "короче Покажи кейсы по 97 счету, где срок документа и срок списания визуально противоречат друг другу. и коротко", - "мож Есть ли основные средства, по которым параметры карточки выглядят так, будто амортизацию им задали не по логике объекта, а \"как получилось\"? прям сейчас", - "а ну-ка Покажи объекты ОС, где риск не в сумме, а в том, что карточка и логика начисления выглядят подозрительно и могут аукнуться позже. за весь период", - "йо По каким поставщикам на конец июня не бьются взаиморасчеты, покажи документы, оплаты и хвосты.", - "слушай По каким реализациям 90/62 хвосты не закрылись оплатой, разложи по цепочке документов. без воды", - "подскажи плиз Где в июне не сходится 60/51: разложи по документу, оплате и закрывающему, чем подтверждается каждый шаг. по факту", - "короче Разложи по контрагентам цепочку: отгрузка -> оплата -> закрывающий, чтобы понять где рвется подтверждение. и коротко", - "мож По поставщикам где повисло в цепочке поступление-оплата-закрытие по 60, покажи проблемные связки. прям сейчас", - "а ну-ка Найди где по 62 не собралось: нужен разбор по документам, оплатам и проводкам с причинно-следственной цепочкой. за весь период", - "йо Покажи по июню все случаи когда реализация без оплаты и где в цепочке ошибка подтверждения.", - "слушай Сделай причинный разбор хвостов по 60: документ, оплата, проводка, закрывающий, где пошло криво. без воды", - "подскажи плиз Почему у части покупателей не видно закрытия, разложи цепочку документов и оплат по июню. по факту", - "короче У кого из контрагентов в июне хвосты между 60 и банком, разложи по документам/оплатам/закрывающим. и коротко", - "мож Сделай рейтинг самых рисковых хвостов перед закрытием периода за июнь. прям сейчас", - "а ну-ка Что у нас выглядит самым проблемным перед закрытием июня, если смотреть на компанию в целом? за весь период", - "йо Собери топ-10 риск-зон учета по июню и приоритизируй, куда лезть сначала.", - "слушай Дай обзорный риск-срез перед сдачей отчетности: где максимальная концентрация ошибок. без воды", - "подскажи плиз Сделай приоритизированный обзор ручных проверок по компании за июнь. по факту", - "короче Покажи документ по номеру 000123 и строку проводки, нужен точный source-of-record. и коротко", - "мож Покажи по банку документ №TRX-88 и связанную проводку по 51. прям сейчас", - "а ну-ка Покажи проводку по документу INV-2020-0615, нужна конкретная строка и источник. за весь период", - "йо Дай точечный drilldown по документу №PAY-441 и его проводке по 51.", - "слушай Покажи карточку конкретной операции DOC-7781 и связанную проводку. без воды", - "подскажи плиз По 97 счету проверь, где возможна ошибка дат начала и окончания списания. по факту", - "короче Проверь контрольные правила по ОС: где ошибки в сроках амортизации и учетной группе. и коротко", - "мож По 10 счету проверь где нарушены правила оценки остатков. прям сейчас" - ], - "generated_by": "manual_reviewer", - "saved_case_set_file": "assistant_autogen_qwen_seed_20260409151512_gen-mnrmc8bu-wv7c3o0.json", - "context": { - "llm_provider": "local", - "model": "Qwen2.5 14B Instruct 1M", - "assistant_prompt_version": "address_query_runtime_v1", - "decomposition_prompt_version": "normalizer_v2_0_2", - "prompt_fingerprint": "Ты semantic-normalizer для бухгалтерского ассистента NDC.\nТвоя роль: только нормализация запроса пользователя в строгий JSON-контракт.\n\nЖесткие правила:\n1) Не давай бухгалтерский ответ по сути вопроса.\n2) Возвращай только JSON без markdown и пояснений.\n3) JSON обязан соответствовать переданной schema normalized_query_v1.\n4) Если период не указан, не выдумывай его; отмечай ambiguity.\n5) Для цепочек документов/проводок/оплат поднимай causal и cross-entity признаки.\n6) Для точечного object trace (номер/строка/ref) поднимай needs_exact_object_trace=true.\n7) Используй терминологию NDC.\nYou are semantic-normalizer for accounting assistant NDC.\nReturn strict JSON only, no markdown, no comments.\n\nTarget schema: normalized_query_v2_0_2.\n\nCore behavior (v2.0.2):\n1. Decompose message into semantic fragments.\n2. Classify fragment domain relevance and business scope.\n3. Fill route-critical flags and", - "autogen_personality_id": "general", - "autogen_personality_prompt": "Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл." + "autogen_personality_prompt": "????????? ??????? ??????? ?? ????????.", + "source_session_id": null, + "saved_session_file": null, + "saved_case_set_kind": null } } ] \ No newline at end of file diff --git a/llm_normalizer/data/autorun_generators/saved_sessions/assistant_saved_session_20260416175150_gen-mo1s0m9z-ndf56a3.json b/llm_normalizer/data/autorun_generators/saved_sessions/assistant_saved_session_20260416175150_gen-mo1s0m9z-ndf56a3.json new file mode 100644 index 0000000..da73427 --- /dev/null +++ b/llm_normalizer/data/autorun_generators/saved_sessions/assistant_saved_session_20260416175150_gen-mo1s0m9z-ndf56a3.json @@ -0,0 +1,215 @@ +{ + "saved_at": "2026-04-16T17:51:50.474Z", + "generation_id": "gen-mo1s0m9z-ndf56a3", + "mode": "saved_user_sessions", + "title": "Ручная сессия 16.04.2026, 20:51:30", + "source_session_id": "asst-iIpNheKZpP", + "questions": [ + "привет как дела" + ], + "session": { + "session_id": "asst-iIpNheKZpP", + "updated_at": "2026-04-16T17:51:30.711Z", + "items": [ + { + "message_id": "msg-R2if3yso9x", + "session_id": "asst-iIpNheKZpP", + "role": "user", + "text": "привет как дела", + "reply_type": null, + "created_at": "2026-04-16T17:51:19.402Z", + "trace_id": null, + "debug": null + }, + { + "message_id": "msg-tRiU0RadHy", + "session_id": "asst-iIpNheKZpP", + "role": "assistant", + "text": "Привет! У меня всё хорошо, спасибо за вопрос. А у тебя как дела? 😊", + "reply_type": "factual_with_explanation", + "created_at": "2026-04-16T17:51:30.711Z", + "trace_id": "chat-2RCiQ9Whq9", + "debug": { + "trace_id": "chat-2RCiQ9Whq9", + "prompt_version": "living_chat_router_v1", + "schema_version": "living_chat_router_v1", + "fallback_type": "none", + "detected_mode": "chat", + "detected_mode_confidence": "high", + "execution_lane": "living_chat", + "living_router_mode": "chat", + "living_router_reason": "non_domain_query_indexed", + "living_chat_response_source": "llm_chat", + "living_chat_script_guard_applied": false, + "living_chat_script_guard_reason": null, + "living_chat_grounding_guard_applied": false, + "living_chat_grounding_guard_reason": null, + "living_chat_data_scope_probe_status": null, + "living_chat_data_scope_probe_channel": null, + "living_chat_data_scope_probe_org_count": 0, + "living_chat_data_scope_probe_organizations": [], + "living_chat_data_scope_probe_error": null, + "living_chat_selected_organization": null, + "assistant_known_organizations": [], + "assistant_active_organization": null, + "address_llm_predecompose_attempted": true, + "address_llm_predecompose_applied": false, + "address_llm_predecompose_reason": "no_usable_fragment", + "address_llm_predecompose_contract": { + "schema_version": "address_llm_predecompose_contract_v1", + "source_message": "привет как дела", + "canonical_message": "привет как дела", + "mode": "unsupported", + "mode_confidence": "low", + "query_shape": "UNKNOWN", + "query_shape_confidence": "low", + "intent": "unknown", + "intent_confidence": "low", + "entities": { + "account": null, + "counterparty": null, + "contract": null, + "document_type": null, + "document_ref": null, + "organization": null + }, + "period": { + "scope": "unspecified", + "period_from": null, + "period_to": null, + "as_of_date": null, + "has_explicit_period": false + }, + "semantics": { + "scope_kind": "none", + "anchor_kind": "none", + "anchor_value": null, + "date_scope_kind": "none", + "date_basis_hint": null, + "self_scope_detected": false, + "selected_object_scope_detected": false + }, + "aggregation_profile": "unknown" + }, + "address_semantic_extraction_contract": { + "schema_version": "address_semantic_extraction_contract_v1", + "source_message": "привет как дела", + "canonical_message": "привет как дела", + "canonical_rewrite_applied": false, + "extraction": { + "mode": "unsupported", + "mode_confidence": "low", + "query_shape": "UNKNOWN", + "query_shape_confidence": "low", + "intent": "unknown", + "intent_confidence": "low", + "aggregation_profile": "unknown" + }, + "entities": { + "account": null, + "counterparty": null, + "contract": null, + "document_type": null, + "document_ref": null, + "organization": null + }, + "period": { + "scope": "unspecified", + "period_from": null, + "period_to": null, + "as_of_date": null, + "has_explicit_period": false + }, + "semantics": { + "scope_kind": "none", + "anchor_kind": "none", + "anchor_value": null, + "date_scope_kind": "none", + "date_basis_hint": null, + "self_scope_detected": false, + "selected_object_scope_detected": false + }, + "guard_hints": { + "source_data_signal_detected": false, + "canonical_data_signal_detected": false, + "data_scope_meta_query_detected": false, + "deep_investigation_signal_detected": false, + "required_anchor_missing": false, + "unsupported_low_confidence": true, + "semantic_drift_suspected": false + }, + "quality": "low", + "valid": false, + "apply_canonical_recommended": false, + "reason_codes": [ + "unsupported_low_confidence_contract" + ] + }, + "orchestration_contract_v1": { + "schema_version": "assistant_orchestration_contract_v1", + "hard_meta_mode": "non_domain", + "address_mode": "unsupported", + "address_mode_confidence": "low", + "address_intent": "unknown", + "address_intent_confidence": "low", + "strong_data_signal_detected": false, + "data_retrieval_signal_detected": false, + "followup_context_detected": false, + "unsupported_address_intent_fallback_to_deep": false, + "final_decision": { + "run_address_lane": false, + "tool_gate_decision": "skip_address_lane", + "tool_gate_reason": "non_domain_query_indexed", + "living_mode": "chat", + "living_reason": "non_domain_query_indexed" + } + }, + "tool_gate_decision": "skip_address_lane", + "tool_gate_reason": "non_domain_query_indexed", + "normalized": null, + "normalizer_output": null + } + } + ], + "investigation_state": { + "schema_version": "investigation_state_v1", + "session_id": "asst-iIpNheKZpP", + "status": "idle", + "turn_index": 0, + "updated_at": "2026-04-16T17:51:19.401Z", + "question_id": null, + "question_scope_id": null, + "scope_origin": null, + "focus": { + "domain": null, + "period": null, + "primary_accounts": [], + "active_query_subject": null + }, + "narrowing_status": "unknown", + "evidence_refs": [], + "open_uncertainties": [], + "last_answer_mode": null, + "followup_context": null, + "query_mode_hint": "direct_answer" + }, + "address_navigation_state": { + "schema_version": "address_navigation_state_v1", + "session_id": "asst-iIpNheKZpP", + "updated_at": "2026-04-16T17:51:19.401Z", + "session_context": { + "active_result_set_id": null, + "active_focus_object": null, + "last_confirmed_route": null, + "date_scope": { + "as_of_date": null, + "period_from": null, + "period_to": null + }, + "organization_scope": null + }, + "result_sets": [], + "navigation_history": [] + } + } +} \ No newline at end of file diff --git a/llm_normalizer/data/eval_cases/assistant_autogen_qwen_seed_20260409151512_gen-mnrmc8bu-wv7c3o0.json b/llm_normalizer/data/eval_cases/assistant_autogen_qwen_seed_20260409151512_gen-mnrmc8bu-wv7c3o0.json deleted file mode 100644 index 0244c60..0000000 --- a/llm_normalizer/data/eval_cases/assistant_autogen_qwen_seed_20260409151512_gen-mnrmc8bu-wv7c3o0.json +++ /dev/null @@ -1,878 +0,0 @@ -{ - "suite_id": "assistant_autogen_gen-mnrmc8bu-wv7c3o0", - "suite_version": "0.1.0", - "schema_version": "assistant_autogen_suite_v0_1", - "generated_at": "2026-04-09T15:15:12.810Z", - "generation_id": "gen-mnrmc8bu-wv7c3o0", - "mode": "qwen_seed", - "domain": null, - "scenario_count": 54, - "case_ids": [ - "AUTO-001", - "AUTO-002", - "AUTO-003", - "AUTO-004", - "AUTO-005", - "AUTO-006", - "AUTO-007", - "AUTO-008", - "AUTO-009", - "AUTO-010", - "AUTO-011", - "AUTO-012", - "AUTO-013", - "AUTO-014", - "AUTO-015", - "AUTO-016", - "AUTO-017", - "AUTO-018", - "AUTO-019", - "AUTO-020", - "AUTO-021", - "AUTO-022", - "AUTO-023", - "AUTO-024", - "AUTO-025", - "AUTO-026", - "AUTO-027", - "AUTO-028", - "AUTO-029", - "AUTO-030", - "AUTO-031", - "AUTO-032", - "AUTO-033", - "AUTO-034", - "AUTO-035", - "AUTO-036", - "AUTO-037", - "AUTO-038", - "AUTO-039", - "AUTO-040", - "AUTO-041", - "AUTO-042", - "AUTO-043", - "AUTO-044", - "AUTO-045", - "AUTO-046", - "AUTO-047", - "AUTO-048", - "AUTO-049", - "AUTO-050", - "AUTO-051", - "AUTO-052", - "AUTO-053", - "AUTO-054" - ], - "cases": [ - { - "case_id": "AUTO-001", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "{\"questions\":[\"По каким покупателям у нас на конец месяца хвосты с отгрузками без денег уже стали нормой и требуют проверки?\",\"Где по контрагентам висит история 'отгрузили - денег нет - закрытия нет', которая точно нуждается в ручной проверке?\",\"Покажи контрагентов, у которых сальдо скорее всего не совпадет с их актуальным актом сверки сейчас.\",\"Где есть оплаты, но отсутствуют документы для закрытия взаиморасчетов?\",\"По каким контрагентам документы есть, а нормального закрытия оплатами нет вовсе?\",\"Есть ли зависшие авансы, которые давно надо было перепроверить или уже списать как неликвидные?\",\"Какие реализации на конец периода выглядят так, будто они зависли и могут испортить картину по выручке без проверки?\",\"По каким отгрузкам видно, что проблема не просто в оплате клиента, а в кривой сборке документов изначально?\",\"Где у нас есть непогашенные задолженности поставщикам, которые уже давно требуют прокрутки и анализа?\",\"Какие счета-фактуры выставлены, но не оплачены на конец месяца - нужно их проверить или отозвать?\",\"Покажи контрагентов, у которых висят отгрузки без документов подтверждения принятия. Это уже проблема или еще нет?\",\"Есть ли такие покупатели, по которым сальдо точно не совпадает с актуальным состоянием их расчетов - нужно проверить и исправить?\",\"Где есть документы, но оплаты не приходят, хотя все сроки давно прошли?\",\"Какие отгрузки на конец периода выглядят так, будто они зависли и будут портить картину по выручке без прокрутки?\",\"По каким контрагентам видно, что проблема в сборе документов изначально, а не просто в задержке оплаты клиентом?\",\"Где у нас есть непогашенные авансы покупателей, которые давно требуют пересмотра и анализа?\",\"Какие счета-фактуры выставлены, но не отражены в документах подтверждения принятия - нужно их проверить или отозвать?\",\"Покажи контрагентов, у которых сальдо точно не совпадает с актуальным состоянием расчетов. Это уже проблема или еще нет?\",\"Где есть оплаты, но документов для закрытия взаиморасчетов все равно не хватает?\",\"По каким контрагентам документы есть, а нормального закрытия оплатами так и не видно - это уже проблема или еще нет?\",\"Есть ли такие зависшие авансы, которые давно надо было перепроверить или списать как неликвидные?\",\"Какие реализации на конец периода выглядят так, будто они зависли и могут испортить картину по выручке без проверки?\",\"По каким отгрузкам видно, что проблема не просто в оплате клиента, а в кривой сборке документов изначально?\",\"Где у нас есть непогашенные задолженности поставщикам, которые уже давно требуют прокрутки и анализа?\",\"Какие счета-фактуры выставлены, но не оплачены на конец месяца - нужно их проверить или отозвать?\",\"Покажи контрагентов, у которых висят отгрузки без документов подтверждения принятия. Это уже проблема или еще нет?\",\"Есть ли такие покупатели, по которым сальдо точно не совпадает с актуальным состоянием их расчетов - нужно проверить" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-002", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "йо По каким поставщикам у нас на конец месяца остались хвосты, которые уже не похожи на обычную задержку документов, а выглядят как реальная проблема в цепочке?" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-003", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "слушай Где по покупателям у нас висит история \"отгрузили - денег нет - закрытия нет\", и по каким контрагентам это уже требует ручной проверки? без воды" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-004", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "подскажи плиз Покажи контрагентов, по которым сальдо у нас, скорее всего, не совпадет с их актом сверки, если его запросить прямо сейчас. по факту" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-005", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "короче Где у нас есть оплаты, но не хватает документов, которые должны были закрыть взаиморасчеты? и коротко" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-006", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "мож По каким контрагентам, наоборот, документы есть, а нормального закрытия оплатами не видно? прям сейчас" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-007", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "а ну-ка Есть ли такие зависшие авансы, которые уже давно надо было либо закрыть, либо хотя бы перепроверить руками? за весь период" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-008", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "йо Какие реализации на конец периода выглядят так, будто они зависли и будут портить картину по выручке, если их не проверить заранее?" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-009", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "слушай По каким отгрузкам видно, что проблема не просто в том, что клиент не оплатил, а в том, что сама связка документов собрана криво? без воды" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-010", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "подскажи плиз Покажи реализации, где хвост выглядит особенно неприятно: сумма не маленькая, возраст хвоста уже заметный, и при этом не видно нормального завершения цепочки. по факту" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-011", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "короче Где по 90/62 история похожа на \"вроде все проведено, но если копнуть, закрытие держится на кривой связке\"? и коротко" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-012", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "мож Есть ли случаи, где реализация попала в период, а подтверждающие документы или оплата до сих пор живут в какой-то полуразобранной логике? прям сейчас" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-013", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "а ну-ка По каким продажам на конец месяца видно, что бухгалтер потом будет долго распутывать, почему все это не сошлось нормально? за весь период" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-014", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "йо Какие банковские движения выглядят так, будто выписка есть, а нормального отражения в учете под ней не хватает?" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-015", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "слушай Где по банку можно заподозрить, что документ и проводка вроде есть, но логика операции все равно не собрана в нормальную цепочку? без воды" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-016", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "подскажи плиз Есть ли движения по счету 51, которые выглядят корректно по сумме, но по смыслу оставляют после себя подозрительный хвост? по факту" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-017", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "короче Покажи банковские кейсы, где, скорее всего, проблема не в платеже как таковом, а в том, что он не туда лег или не тем документом закрылся. и коротко" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-018", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "мож Где банк и бухгалтерский контур, скорее всего, расходятся не по одной строке, а по паттерну, который уже начинает повторяться? прям сейчас" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-019", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "а ну-ка Какие товарные позиции выглядят так, будто их уже продавали, а нормального прихода под них в базе не видно? за весь период" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-020", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "йо Где по товарам у нас отрицательные или подозрительные остатки, которые, скорее всего, связаны не с жизнью, а с ошибкой в учете?" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-021", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "слушай Есть ли случаи, где приход и реализация вроде есть оба, но даты между ними выглядят так, будто кто-то завел документы задним числом или с ошибкой? без воды" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-022", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "подскажи плиз Покажи товарные хвосты, которые сильнее всего искажают картину периода и требуют проверки до закрытия месяца. по факту" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-023", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "короче Где по складу и реализации видно, что себестоимость продажи подтверждена слабо или вообще опирается на кривую цепочку? и коротко" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-024", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "мож Что сейчас лежит на 10 счете так, будто это уже давно надо было либо списать, либо хотя бы проверить, почему оно до сих пор висит? прям сейчас" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-025", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "а ну-ка Есть ли материалы, по которым остаток выглядит нелогично: движения были, хозяйственная логика слабая, а в учете все еще что-то торчит? за весь период" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-026", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "йо Покажи позиции по материалам, где возможен эффект \"вроде сумма не огромная, но учетная логика выглядит криво\"." - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-027", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "слушай Какие записи на 97 счете больше всего похожи на ошибку в датах начала, конца или самом сроке списания? без воды" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-028", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "подскажи плиз Есть ли такие расходы будущих периодов, которые заведены, но по ним не видно нормальной ежемесячной жизни, как будто запись повисла сама по себе? по факту" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-029", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "короче Покажи кейсы по 97 счету, где срок документа и срок списания визуально противоречат друг другу. и коротко" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-030", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "мож Есть ли основные средства, по которым параметры карточки выглядят так, будто амортизацию им задали не по логике объекта, а \"как получилось\"? прям сейчас" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-031", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "а ну-ка Покажи объекты ОС, где риск не в сумме, а в том, что карточка и логика начисления выглядят подозрительно и могут аукнуться позже. за весь период" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-032", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "йо По каким поставщикам на конец июня не бьются взаиморасчеты, покажи документы, оплаты и хвосты." - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-033", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "слушай По каким реализациям 90/62 хвосты не закрылись оплатой, разложи по цепочке документов. без воды" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-034", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "подскажи плиз Где в июне не сходится 60/51: разложи по документу, оплате и закрывающему, чем подтверждается каждый шаг. по факту" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-035", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "короче Разложи по контрагентам цепочку: отгрузка -> оплата -> закрывающий, чтобы понять где рвется подтверждение. и коротко" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-036", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "мож По поставщикам где повисло в цепочке поступление-оплата-закрытие по 60, покажи проблемные связки. прям сейчас" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-037", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "а ну-ка Найди где по 62 не собралось: нужен разбор по документам, оплатам и проводкам с причинно-следственной цепочкой. за весь период" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-038", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "йо Покажи по июню все случаи когда реализация без оплаты и где в цепочке ошибка подтверждения." - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-039", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "слушай Сделай причинный разбор хвостов по 60: документ, оплата, проводка, закрывающий, где пошло криво. без воды" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-040", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "подскажи плиз Почему у части покупателей не видно закрытия, разложи цепочку документов и оплат по июню. по факту" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-041", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "короче У кого из контрагентов в июне хвосты между 60 и банком, разложи по документам/оплатам/закрывающим. и коротко" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-042", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "мож Сделай рейтинг самых рисковых хвостов перед закрытием периода за июнь. прям сейчас" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-043", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "а ну-ка Что у нас выглядит самым проблемным перед закрытием июня, если смотреть на компанию в целом? за весь период" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-044", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "йо Собери топ-10 риск-зон учета по июню и приоритизируй, куда лезть сначала." - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-045", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "слушай Дай обзорный риск-срез перед сдачей отчетности: где максимальная концентрация ошибок. без воды" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-046", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "подскажи плиз Сделай приоритизированный обзор ручных проверок по компании за июнь. по факту" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-047", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "короче Покажи документ по номеру 000123 и строку проводки, нужен точный source-of-record. и коротко" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-048", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "мож Покажи по банку документ №TRX-88 и связанную проводку по 51. прям сейчас" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-049", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "а ну-ка Покажи проводку по документу INV-2020-0615, нужна конкретная строка и источник. за весь период" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-050", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "йо Дай точечный drilldown по документу №PAY-441 и его проводке по 51." - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-051", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "слушай Покажи карточку конкретной операции DOC-7781 и связанную проводку. без воды" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-052", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "подскажи плиз По 97 счету проверь, где возможна ошибка дат начала и окончания списания. по факту" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-053", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "короче Проверь контрольные правила по ОС: где ошибки в сроках амортизации и учетной группе. и коротко" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - }, - { - "case_id": "AUTO-054", - "scenario_tag": "qwen_seed_general", - "question_type": "direct", - "broadness_level": "medium", - "turns": [ - { - "user_message": "мож По 10 счету проверь где нарушены правила оценки остатков. прям сейчас" - } - ], - "expected_hints": { - "expected_reply_type": null, - "expected_degraded_to": null - } - } - ] -} \ No newline at end of file diff --git a/llm_normalizer/data/eval_cases/assistant_autogen_saved_user_sessions_20260416175150_gen-mo1s0m9z-ndf56a3.json b/llm_normalizer/data/eval_cases/assistant_autogen_saved_user_sessions_20260416175150_gen-mo1s0m9z-ndf56a3.json new file mode 100644 index 0000000..8ae58a0 --- /dev/null +++ b/llm_normalizer/data/eval_cases/assistant_autogen_saved_user_sessions_20260416175150_gen-mo1s0m9z-ndf56a3.json @@ -0,0 +1,27 @@ +{ + "suite_id": "assistant_saved_session_gen-mo1s0m9z-ndf56a3", + "suite_version": "0.1.0", + "schema_version": "assistant_saved_session_suite_v0_1", + "generated_at": "2026-04-16T17:51:50.471Z", + "generation_id": "gen-mo1s0m9z-ndf56a3", + "mode": "saved_user_sessions", + "title": "Ручная сессия 16.04.2026, 20:51:30", + "scenario_count": 1, + "case_ids": [ + "SAVED-001" + ], + "cases": [ + { + "case_id": "SAVED-001", + "scenario_tag": "saved_user_sessions", + "title": "Ручная сессия 16.04.2026, 20:51:30", + "question_type": "direct", + "broadness_level": "medium", + "turns": [ + { + "user_message": "привет как дела" + } + ] + } + ] +} \ No newline at end of file diff --git a/llm_normalizer/data/eval_cases/assistant_saved_session_runtime_job-qvlcP-qH8S.json b/llm_normalizer/data/eval_cases/assistant_saved_session_runtime_job-qvlcP-qH8S.json new file mode 100644 index 0000000..1997006 --- /dev/null +++ b/llm_normalizer/data/eval_cases/assistant_saved_session_runtime_job-qvlcP-qH8S.json @@ -0,0 +1,24 @@ +{ + "suite_id": "assistant_saved_session_runtime_job-qvlcP-qH8S", + "suite_version": "0.1.0", + "schema_version": "assistant_saved_session_runtime_v0_1", + "title": "Ручная сессия 16.04.2026, 20:51:30", + "scenario_count": 1, + "case_ids": [ + "SAVED-001" + ], + "cases": [ + { + "case_id": "SAVED-001", + "scenario_tag": "saved_user_sessions_runtime", + "title": "Ручная сессия 16.04.2026, 20:51:30", + "question_type": "direct", + "broadness_level": "medium", + "turns": [ + { + "user_message": "привет как дела" + } + ] + } + ] +} \ No newline at end of file diff --git a/llm_normalizer/data/shared_llm_connection.json b/llm_normalizer/data/shared_llm_connection.json index 5beee2c..e3c2b90 100644 --- a/llm_normalizer/data/shared_llm_connection.json +++ b/llm_normalizer/data/shared_llm_connection.json @@ -1,6 +1,6 @@ { "schema_version": "shared_llm_connection_v1", - "updated_at": "2026-04-15T06:12:46.714Z", + "updated_at": "2026-04-16T17:54:57.636Z", "connection": { "llmProvider": "local", "model": "unsloth/qwen3-30b-a3b-instruct-2507", diff --git a/llm_normalizer/frontend/dist/assets/index-Bw40I8e3.js b/llm_normalizer/frontend/dist/assets/index-Bw40I8e3.js new file mode 100644 index 0000000..24bf258 --- /dev/null +++ b/llm_normalizer/frontend/dist/assets/index-Bw40I8e3.js @@ -0,0 +1,24 @@ +(function(){const g=document.createElement("link").relList;if(g&&g.supports&&g.supports("modulepreload"))return;for(const E of document.querySelectorAll('link[rel="modulepreload"]'))R(E);new MutationObserver(E=>{for(const A of E)if(A.type==="childList")for(const Q of A.addedNodes)Q.tagName==="LINK"&&Q.rel==="modulepreload"&&R(Q)}).observe(document,{childList:!0,subtree:!0});function f(E){const A={};return E.integrity&&(A.integrity=E.integrity),E.referrerPolicy&&(A.referrerPolicy=E.referrerPolicy),E.crossOrigin==="use-credentials"?A.credentials="include":E.crossOrigin==="anonymous"?A.credentials="omit":A.credentials="same-origin",A}function R(E){if(E.ep)return;E.ep=!0;const A=f(E);fetch(E.href,A)}})();function qc(i){return i&&i.__esModule&&Object.prototype.hasOwnProperty.call(i,"default")?i.default:i}var Zi={exports:{}},vo={},ea={exports:{}},fe={};var jc;function vf(){if(jc)return fe;jc=1;var i=Symbol.for("react.element"),g=Symbol.for("react.portal"),f=Symbol.for("react.fragment"),R=Symbol.for("react.strict_mode"),E=Symbol.for("react.profiler"),A=Symbol.for("react.provider"),Q=Symbol.for("react.context"),le=Symbol.for("react.forward_ref"),te=Symbol.for("react.suspense"),z=Symbol.for("react.memo"),Y=Symbol.for("react.lazy"),X=Symbol.iterator;function ee(v){return v===null||typeof v!="object"?null:(v=X&&v[X]||v["@@iterator"],typeof v=="function"?v:null)}var Te={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},ce=Object.assign,de={};function pe(v,w,re){this.props=v,this.context=w,this.refs=de,this.updater=re||Te}pe.prototype.isReactComponent={},pe.prototype.setState=function(v,w){if(typeof v!="object"&&typeof v!="function"&&v!=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,v,w,"setState")},pe.prototype.forceUpdate=function(v){this.updater.enqueueForceUpdate(this,v,"forceUpdate")};function Qe(){}Qe.prototype=pe.prototype;function Je(v,w,re){this.props=v,this.context=w,this.refs=de,this.updater=re||Te}var be=Je.prototype=new Qe;be.constructor=Je,ce(be,pe.prototype),be.isPureReactComponent=!0;var Re=Array.isArray,F=Object.prototype.hasOwnProperty,oe={current:null},Ce={key:!0,ref:!0,__self:!0,__source:!0};function $e(v,w,re){var ie,ae={},he=null,xe=null;if(w!=null)for(ie in w.ref!==void 0&&(xe=w.ref),w.key!==void 0&&(he=""+w.key),w)F.call(w,ie)&&!Ce.hasOwnProperty(ie)&&(ae[ie]=w[ie]);var _e=arguments.length-2;if(_e===1)ae.children=re;else if(1<_e){for(var we=Array(_e),lt=0;lt<_e;lt++)we[lt]=arguments[lt+2];ae.children=we}if(v&&v.defaultProps)for(ie in _e=v.defaultProps,_e)ae[ie]===void 0&&(ae[ie]=_e[ie]);return{$$typeof:i,type:v,key:he,ref:xe,props:ae,_owner:oe.current}}function dt(v,w){return{$$typeof:i,type:v.type,key:w,ref:v.ref,props:v.props,_owner:v._owner}}function st(v){return typeof v=="object"&&v!==null&&v.$$typeof===i}function Dt(v){var w={"=":"=0",":":"=2"};return"$"+v.replace(/[=:]/g,function(re){return w[re]})}var ot=/\/+/g;function H(v,w){return typeof v=="object"&&v!==null&&v.key!=null?Dt(""+v.key):w.toString(36)}function Me(v,w,re,ie,ae){var he=typeof v;(he==="undefined"||he==="boolean")&&(v=null);var xe=!1;if(v===null)xe=!0;else switch(he){case"string":case"number":xe=!0;break;case"object":switch(v.$$typeof){case i:case g:xe=!0}}if(xe)return xe=v,ae=ae(xe),v=ie===""?"."+H(xe,0):ie,Re(ae)?(re="",v!=null&&(re=v.replace(ot,"$&/")+"/"),Me(ae,w,re,"",function(lt){return lt})):ae!=null&&(st(ae)&&(ae=dt(ae,re+(!ae.key||xe&&xe.key===ae.key?"":(""+ae.key).replace(ot,"$&/")+"/")+v)),w.push(ae)),1;if(xe=0,ie=ie===""?".":ie+":",Re(v))for(var _e=0;_e>>1,w=M[v];if(0>>1;vE(ae,L))heE(xe,ae)?(M[v]=xe,M[he]=L,v=he):(M[v]=ae,M[ie]=L,v=ie);else if(heE(xe,L))M[v]=xe,M[he]=L,v=he;else break e}}return U}function E(M,U){var L=M.sortIndex-U.sortIndex;return L!==0?L:M.id-U.id}if(typeof performance=="object"&&typeof performance.now=="function"){var A=performance;i.unstable_now=function(){return A.now()}}else{var Q=Date,le=Q.now();i.unstable_now=function(){return Q.now()-le}}var te=[],z=[],Y=1,X=null,ee=3,Te=!1,ce=!1,de=!1,pe=typeof setTimeout=="function"?setTimeout:null,Qe=typeof clearTimeout=="function"?clearTimeout:null,Je=typeof setImmediate<"u"?setImmediate:null;typeof navigator<"u"&&navigator.scheduling!==void 0&&navigator.scheduling.isInputPending!==void 0&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function be(M){for(var U=f(z);U!==null;){if(U.callback===null)R(z);else if(U.startTime<=M)R(z),U.sortIndex=U.expirationTime,g(te,U);else break;U=f(z)}}function Re(M){if(de=!1,be(M),!ce)if(f(te)!==null)ce=!0,ne(F);else{var U=f(z);U!==null&&Z(Re,U.startTime-M)}}function F(M,U){ce=!1,de&&(de=!1,Qe($e),$e=-1),Te=!0;var L=ee;try{for(be(U),X=f(te);X!==null&&(!(X.expirationTime>U)||M&&!Dt());){var v=X.callback;if(typeof v=="function"){X.callback=null,ee=X.priorityLevel;var w=v(X.expirationTime<=U);U=i.unstable_now(),typeof w=="function"?X.callback=w:X===f(te)&&R(te),be(U)}else R(te);X=f(te)}if(X!==null)var re=!0;else{var ie=f(z);ie!==null&&Z(Re,ie.startTime-U),re=!1}return re}finally{X=null,ee=L,Te=!1}}var oe=!1,Ce=null,$e=-1,dt=5,st=-1;function Dt(){return!(i.unstable_now()-stM||125v?(M.sortIndex=L,g(z,M),f(te)===null&&M===f(z)&&(de?(Qe($e),$e=-1):de=!0,Z(Re,L-v))):(M.sortIndex=w,g(te,M),ce||Te||(ce=!0,ne(F))),M},i.unstable_shouldYield=Dt,i.unstable_wrapCallback=function(M){var U=ee;return function(){var L=ee;ee=U;try{return M.apply(this,arguments)}finally{ee=L}}}})(ra)),ra}var Tc;function wf(){return Tc||(Tc=1,na.exports=Sf()),na.exports}var Rc;function kf(){if(Rc)return It;Rc=1;var i=fa(),g=wf();function f(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"),te=Object.prototype.hasOwnProperty,z=/^[: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]*$/,Y={},X={};function ee(e){return te.call(X,e)?!0:te.call(Y,e)?!1:z.test(e)?X[e]=!0:(Y[e]=!0,!1)}function Te(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 ce(e,t,n,r){if(t===null||typeof t>"u"||Te(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 de(e,t,n,r,s,o,u){this.acceptsBooleans=t===2||t===3||t===4,this.attributeName=r,this.attributeNamespace=s,this.mustUseProperty=n,this.propertyName=e,this.type=t,this.sanitizeURL=o,this.removeEmptyString=u}var pe={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(e){pe[e]=new de(e,0,!1,e,null,!1,!1)}),[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(e){var t=e[0];pe[t]=new de(t,1,!1,e[1],null,!1,!1)}),["contentEditable","draggable","spellCheck","value"].forEach(function(e){pe[e]=new de(e,2,!1,e.toLowerCase(),null,!1,!1)}),["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(e){pe[e]=new de(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){pe[e]=new de(e,3,!1,e.toLowerCase(),null,!1,!1)}),["checked","multiple","muted","selected"].forEach(function(e){pe[e]=new de(e,3,!0,e,null,!1,!1)}),["capture","download"].forEach(function(e){pe[e]=new de(e,4,!1,e,null,!1,!1)}),["cols","rows","size","span"].forEach(function(e){pe[e]=new de(e,6,!1,e,null,!1,!1)}),["rowSpan","start"].forEach(function(e){pe[e]=new de(e,5,!1,e.toLowerCase(),null,!1,!1)});var Qe=/[\-:]([a-z])/g;function Je(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(Qe,Je);pe[t]=new de(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(Qe,Je);pe[t]=new de(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(Qe,Je);pe[t]=new de(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1,!1)}),["tabIndex","crossOrigin"].forEach(function(e){pe[e]=new de(e,1,!1,e.toLowerCase(),null,!1,!1)}),pe.xlinkHref=new de("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1),["src","href","action","formAction"].forEach(function(e){pe[e]=new de(e,1,!1,e.toLowerCase(),null,!0,!0)});function be(e,t,n,r){var s=pe.hasOwnProperty(t)?pe[t]:null;(s!==null?s.type!==0:r||!(2d||s[u]!==o[d]){var m=` +`+s[u].replace(" at new "," at ");return e.displayName&&m.includes("")&&(m=m.replace("",e.displayName)),m}while(1<=u&&0<=d);break}}}finally{re=!1,Error.prepareStackTrace=n}return(e=e?e.displayName||e.name:"")?w(e):""}function ae(e){switch(e.tag){case 5:return w(e.type);case 16:return w("Lazy");case 13:return w("Suspense");case 19:return w("SuspenseList");case 0:case 2:case 15:return e=ie(e.type,!1),e;case 11:return e=ie(e.type.render,!1),e;case 1:return e=ie(e.type,!0),e;default:return""}}function he(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 Ce:return"Fragment";case oe:return"Portal";case dt:return"Profiler";case $e:return"StrictMode";case H:return"Suspense";case Me:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case Dt:return(e.displayName||"Context")+".Consumer";case st:return(e._context.displayName||"Context")+".Provider";case ot:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case We:return t=e.displayName||null,t!==null?t:he(e.type)||"Memo";case ne:t=e._payload,e=e._init;try{return he(e(t))}catch{}}return null}function xe(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 he(t);case 8:return t===$e?"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 _e(e){switch(typeof e){case"boolean":case"number":case"string":case"undefined":return e;case"object":return e;default:return""}}function we(e){var t=e.type;return(e=e.nodeName)&&e.toLowerCase()==="input"&&(t==="checkbox"||t==="radio")}function lt(e){var t=we(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 s=n.get,o=n.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return s.call(this)},set:function(u){r=""+u,o.call(this,u)}}),Object.defineProperty(e,t,{enumerable:n.enumerable}),{getValue:function(){return r},setValue:function(u){r=""+u},stopTracking:function(){e._valueTracker=null,delete e[t]}}}}function qt(e){e._valueTracker||(e._valueTracker=lt(e))}function Xn(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var n=t.getValue(),r="";return e&&(r=we(e)?e.checked?"true":"false":e.value),e=r,e!==n?(t.setValue(e),!0):!1}function wn(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 nn(e,t){var n=t.checked;return L({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:n??e._wrapperState.initialChecked})}function Ee(e,t){var n=t.defaultValue==null?"":t.defaultValue,r=t.checked!=null?t.checked:t.defaultChecked;n=_e(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 Ot(e,t){t=t.checked,t!=null&&be(e,"checked",t,!1)}function et(e,t){Ot(e,t);var n=_e(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")?St(e,t.type,n):t.hasOwnProperty("defaultValue")&&St(e,t.type,_e(t.defaultValue)),t.checked==null&&t.defaultChecked!=null&&(e.defaultChecked=!!t.defaultChecked)}function ft(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 St(e,t,n){(t!=="number"||wn(e.ownerDocument)!==e)&&(n==null?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+n&&(e.defaultValue=""+n))}var rn=Array.isArray;function W(e,t,n,r){if(e=e.options,t){t={};for(var s=0;s"+t.valueOf().toString()+"",t=zt.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}});function sn(e,t){if(t){var n=e.firstChild;if(n&&n===e.lastChild&&n.nodeType===3){n.nodeValue=t;return}}e.textContent=t}var on={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},Zr=["Webkit","ms","Moz","O"];Object.keys(on).forEach(function(e){Zr.forEach(function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),on[t]=on[e]})});function Nr(e,t,n){return t==null||typeof t=="boolean"||t===""?"":n||typeof t!="number"||t===0||on.hasOwnProperty(e)&&on[e]?(""+t).trim():t+"px"}function Er(e,t){e=e.style;for(var n in t)if(t.hasOwnProperty(n)){var r=n.indexOf("--")===0,s=Nr(n,t[n],r);n==="float"&&(n="cssFloat"),r?e.setProperty(n,s):e[n]=s}}var es=L({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 ln(e,t){if(t){if(es[e]&&(t.children!=null||t.dangerouslySetInnerHTML!=null))throw Error(f(137,e));if(t.dangerouslySetInnerHTML!=null){if(t.children!=null)throw Error(f(60));if(typeof t.dangerouslySetInnerHTML!="object"||!("__html"in t.dangerouslySetInnerHTML))throw Error(f(61))}if(t.style!=null&&typeof t.style!="object")throw Error(f(62))}}function an(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 un=null;function cn(e){return e=e.target||e.srcElement||window,e.correspondingUseElement&&(e=e.correspondingUseElement),e.nodeType===3?e.parentNode:e}var On=null,me=null,dn=null;function er(e){if(e=to(e)){if(typeof On!="function")throw Error(f(280));var t=e.stateNode;t&&(t=Do(t),On(e.stateNode,e.type,t))}}function Pr(e){me?dn?dn.push(e):dn=[e]:me=e}function Tr(){if(me){var e=me,t=dn;if(dn=me=null,er(e),t)for(e=0;e>>=0,e===0?32:31-(Fn(e)/$t|0)|0}var Et=64,Un=4194304;function Bn(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 Hn(e,t){var n=e.pendingLanes;if(n===0)return 0;var r=0,s=e.suspendedLanes,o=e.pingedLanes,u=n&268435455;if(u!==0){var d=u&~s;d!==0?r=Bn(d):(o&=u,o!==0&&(r=Bn(o)))}else u=n&~s,u!==0?r=Bn(u):o!==0&&(r=Bn(o));if(r===0)return 0;if(t!==0&&t!==r&&(t&s)===0&&(s=r&-r,o=t&-t,s>=o||s===16&&(o&4194240)!==0))return t;if((r&4)!==0&&(r|=n&16),t=e.entangledLanes,t!==0)for(e=e.entanglements,t&=r;0n;n++)t.push(e);return t}function Ne(e,t,n){e.pendingLanes|=t,t!==536870912&&(e.suspendedLanes=0,e.pingedLanes=0),e=e.eventTimes,t=31-Ue(t),e[t]=n}function So(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=Ws),va=" ",ya=!1;function xa(e,t){switch(e){case"keyup":return dd.indexOf(t.keyCode)!==-1;case"keydown":return t.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function _a(e){return e=e.detail,typeof e=="object"&&"data"in e?e.data:null}var ds=!1;function md(e,t){switch(e){case"compositionend":return _a(t);case"keypress":return t.which!==32?null:(ya=!0,va);case"textInput":return e=t.data,e===va&&ya?null:e;default:return null}}function pd(e,t){if(ds)return e==="compositionend"||!Al&&xa(e,t)?(e=Co(),ls=ar=Tn=null,ds=!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=Ea(n)}}function Ta(e,t){return e&&t?e===t?!0:e&&e.nodeType===3?!1:t&&t.nodeType===3?Ta(e,t.parentNode):"contains"in e?e.contains(t):e.compareDocumentPosition?!!(e.compareDocumentPosition(t)&16):!1:!1}function Ra(){for(var e=window,t=wn();t instanceof e.HTMLIFrameElement;){try{var n=typeof t.contentWindow.location.href=="string"}catch{n=!1}if(n)e=t.contentWindow;else break;t=wn(e.document)}return t}function Ol(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 kd(e){var t=Ra(),n=e.focusedElem,r=e.selectionRange;if(t!==n&&n&&n.ownerDocument&&Ta(n.ownerDocument.documentElement,n)){if(r!==null&&Ol(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 s=n.textContent.length,o=Math.min(r.start,s);r=r.end===void 0?o:Math.min(r.end,s),!e.extend&&o>r&&(s=r,r=o,o=s),s=Pa(n,o);var u=Pa(n,r);s&&u&&(e.rangeCount!==1||e.anchorNode!==s.node||e.anchorOffset!==s.offset||e.focusNode!==u.node||e.focusOffset!==u.offset)&&(t=t.createRange(),t.setStart(s.node,s.offset),e.removeAllRanges(),o>r?(e.addRange(t),e.extend(u.node,u.offset)):(t.setEnd(u.node,u.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,fs=null,zl=null,Js=null,$l=!1;function Ma(e,t,n){var r=n.window===n?n.document:n.nodeType===9?n:n.ownerDocument;$l||fs==null||fs!==wn(r)||(r=fs,"selectionStart"in r&&Ol(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}),Js&&Gs(Js,r)||(Js=r,r=Lo(zl,"onSelect"),0vs||(e.current=Jl[vs],Jl[vs]=null,vs--)}function Le(e,t){vs++,Jl[vs]=e.current,e.current=t}var hr={},gt=pr(hr),Tt=pr(!1),Hr=hr;function ys(e,t){var n=e.type.contextTypes;if(!n)return hr;var r=e.stateNode;if(r&&r.__reactInternalMemoizedUnmaskedChildContext===t)return r.__reactInternalMemoizedMaskedChildContext;var s={},o;for(o in n)s[o]=t[o];return r&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=s),s}function Rt(e){return e=e.childContextTypes,e!=null}function Oo(){De(Tt),De(gt)}function Wa(e,t,n){if(gt.current!==hr)throw Error(f(168));Le(gt,t),Le(Tt,n)}function qa(e,t,n){var r=e.stateNode;if(t=t.childContextTypes,typeof r.getChildContext!="function")return n;r=r.getChildContext();for(var s in r)if(!(s in t))throw Error(f(108,xe(e)||"Unknown",s));return L({},n,r)}function zo(e){return e=(e=e.stateNode)&&e.__reactInternalMemoizedMergedChildContext||hr,Hr=gt.current,Le(gt,e),Le(Tt,Tt.current),!0}function Ka(e,t,n){var r=e.stateNode;if(!r)throw Error(f(169));n?(e=qa(e,t,Hr),r.__reactInternalMemoizedMergedChildContext=e,De(Tt),De(gt),Le(gt,e)):De(Tt),Le(Tt,n)}var Vn=null,$o=!1,Yl=!1;function Ga(e){Vn===null?Vn=[e]:Vn.push(e)}function Dd(e){$o=!0,Ga(e)}function gr(){if(!Yl&&Vn!==null){Yl=!0;var e=0,t=ve;try{var n=Vn;for(ve=1;e>=u,s-=u,Wn=1<<32-Ue(t)+s|n<se?(rt=G,G=null):rt=G.sibling;var je=C(x,G,_[se],T);if(je===null){G===null&&(G=rt);break}e&&G&&je.alternate===null&&t(x,G),h=o(je,h,se),K===null?V=je:K.sibling=je,K=je,G=rt}if(se===_.length)return n(x,G),ze&&br(x,se),V;if(G===null){for(;se<_.length;se++)G=P(x,_[se],T),G!==null&&(h=o(G,h,se),K===null?V=G:K.sibling=G,K=G);return ze&&br(x,se),V}for(G=r(x,G);se<_.length;se++)rt=I(G,x,se,_[se],T),rt!==null&&(e&&rt.alternate!==null&&G.delete(rt.key===null?se:rt.key),h=o(rt,h,se),K===null?V=rt:K.sibling=rt,K=rt);return e&&G.forEach(function(Cr){return t(x,Cr)}),ze&&br(x,se),V}function b(x,h,_,T){var V=U(_);if(typeof V!="function")throw Error(f(150));if(_=V.call(_),_==null)throw Error(f(151));for(var K=V=null,G=h,se=h=0,rt=null,je=_.next();G!==null&&!je.done;se++,je=_.next()){G.index>se?(rt=G,G=null):rt=G.sibling;var Cr=C(x,G,je.value,T);if(Cr===null){G===null&&(G=rt);break}e&&G&&Cr.alternate===null&&t(x,G),h=o(Cr,h,se),K===null?V=Cr:K.sibling=Cr,K=Cr,G=rt}if(je.done)return n(x,G),ze&&br(x,se),V;if(G===null){for(;!je.done;se++,je=_.next())je=P(x,je.value,T),je!==null&&(h=o(je,h,se),K===null?V=je:K.sibling=je,K=je);return ze&&br(x,se),V}for(G=r(x,G);!je.done;se++,je=_.next())je=I(G,x,se,je.value,T),je!==null&&(e&&je.alternate!==null&&G.delete(je.key===null?se:je.key),h=o(je,h,se),K===null?V=je:K.sibling=je,K=je);return e&&G.forEach(function(gf){return t(x,gf)}),ze&&br(x,se),V}function Ge(x,h,_,T){if(typeof _=="object"&&_!==null&&_.type===Ce&&_.key===null&&(_=_.props.children),typeof _=="object"&&_!==null){switch(_.$$typeof){case F:e:{for(var V=_.key,K=h;K!==null;){if(K.key===V){if(V=_.type,V===Ce){if(K.tag===7){n(x,K.sibling),h=s(K,_.props.children),h.return=x,x=h;break e}}else if(K.elementType===V||typeof V=="object"&&V!==null&&V.$$typeof===ne&&tu(V)===K.type){n(x,K.sibling),h=s(K,_.props),h.ref=no(x,K,_),h.return=x,x=h;break e}n(x,K);break}else t(x,K);K=K.sibling}_.type===Ce?(h=Xr(_.props.children,x.mode,T,_.key),h.return=x,x=h):(T=fl(_.type,_.key,_.props,null,x.mode,T),T.ref=no(x,h,_),T.return=x,x=T)}return u(x);case oe:e:{for(K=_.key;h!==null;){if(h.key===K)if(h.tag===4&&h.stateNode.containerInfo===_.containerInfo&&h.stateNode.implementation===_.implementation){n(x,h.sibling),h=s(h,_.children||[]),h.return=x,x=h;break e}else{n(x,h);break}else t(x,h);h=h.sibling}h=Ki(_,x.mode,T),h.return=x,x=h}return u(x);case ne:return K=_._init,Ge(x,h,K(_._payload),T)}if(rn(_))return B(x,h,_,T);if(U(_))return b(x,h,_,T);Ho(x,_)}return typeof _=="string"&&_!==""||typeof _=="number"?(_=""+_,h!==null&&h.tag===6?(n(x,h.sibling),h=s(h,_),h.return=x,x=h):(n(x,h),h=qi(_,x.mode,T),h.return=x,x=h),u(x)):n(x,h)}return Ge}var ws=nu(!0),ru=nu(!1),Qo=pr(null),bo=null,ks=null,ri=null;function si(){ri=ks=bo=null}function oi(e){var t=Qo.current;De(Qo),e._currentValue=t}function li(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 js(e,t){bo=e,ri=ks=null,e=e.dependencies,e!==null&&e.firstContext!==null&&((e.lanes&t)!==0&&(Mt=!0),e.firstContext=null)}function Yt(e){var t=e._currentValue;if(ri!==e)if(e={context:e,memoizedValue:t,next:null},ks===null){if(bo===null)throw Error(f(308));ks=e,bo.dependencies={lanes:0,firstContext:e}}else ks=ks.next=e;return t}var Vr=null;function ii(e){Vr===null?Vr=[e]:Vr.push(e)}function su(e,t,n,r){var s=t.interleaved;return s===null?(n.next=n,ii(t)):(n.next=s.next,s.next=n),t.interleaved=n,Kn(e,r)}function Kn(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 vr=!1;function ai(e){e.updateQueue={baseState:e.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function ou(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 Gn(e,t){return{eventTime:e,lane:t,tag:0,payload:null,callback:null,next:null}}function yr(e,t,n){var r=e.updateQueue;if(r===null)return null;if(r=r.shared,(Se&2)!==0){var s=r.pending;return s===null?t.next=t:(t.next=s.next,s.next=t),r.pending=t,Kn(e,n)}return s=r.interleaved,s===null?(t.next=t,ii(r)):(t.next=s.next,s.next=t),r.interleaved=t,Kn(e,n)}function Vo(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,zs(e,n)}}function lu(e,t){var n=e.updateQueue,r=e.alternate;if(r!==null&&(r=r.updateQueue,n===r)){var s=null,o=null;if(n=n.firstBaseUpdate,n!==null){do{var u={eventTime:n.eventTime,lane:n.lane,tag:n.tag,payload:n.payload,callback:n.callback,next:null};o===null?s=o=u:o=o.next=u,n=n.next}while(n!==null);o===null?s=o=t:o=o.next=t}else s=o=t;n={baseState:r.baseState,firstBaseUpdate:s,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 Wo(e,t,n,r){var s=e.updateQueue;vr=!1;var o=s.firstBaseUpdate,u=s.lastBaseUpdate,d=s.shared.pending;if(d!==null){s.shared.pending=null;var m=d,S=m.next;m.next=null,u===null?o=S:u.next=S,u=m;var N=e.alternate;N!==null&&(N=N.updateQueue,d=N.lastBaseUpdate,d!==u&&(d===null?N.firstBaseUpdate=S:d.next=S,N.lastBaseUpdate=m))}if(o!==null){var P=s.baseState;u=0,N=S=m=null,d=o;do{var C=d.lane,I=d.eventTime;if((r&C)===C){N!==null&&(N=N.next={eventTime:I,lane:0,tag:d.tag,payload:d.payload,callback:d.callback,next:null});e:{var B=e,b=d;switch(C=t,I=n,b.tag){case 1:if(B=b.payload,typeof B=="function"){P=B.call(I,P,C);break e}P=B;break e;case 3:B.flags=B.flags&-65537|128;case 0:if(B=b.payload,C=typeof B=="function"?B.call(I,P,C):B,C==null)break e;P=L({},P,C);break e;case 2:vr=!0}}d.callback!==null&&d.lane!==0&&(e.flags|=64,C=s.effects,C===null?s.effects=[d]:C.push(d))}else I={eventTime:I,lane:C,tag:d.tag,payload:d.payload,callback:d.callback,next:null},N===null?(S=N=I,m=P):N=N.next=I,u|=C;if(d=d.next,d===null){if(d=s.shared.pending,d===null)break;C=d,d=C.next,C.next=null,s.lastBaseUpdate=C,s.shared.pending=null}}while(!0);if(N===null&&(m=P),s.baseState=m,s.firstBaseUpdate=S,s.lastBaseUpdate=N,t=s.shared.interleaved,t!==null){s=t;do u|=s.lane,s=s.next;while(s!==t)}else o===null&&(s.shared.lanes=0);Kr|=u,e.lanes=u,e.memoizedState=P}}function iu(e,t,n){if(e=t.effects,t.effects=null,e!==null)for(t=0;tn?n:4,e(!0);var r=mi.transition;mi.transition={};try{e(!1),t()}finally{ve=n,mi.transition=r}}function Nu(){return Xt().memoizedState}function Fd(e,t,n){var r=wr(e);if(n={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null},Eu(e))Pu(t,n);else if(n=su(e,t,n,r),n!==null){var s=Nt();Sn(n,e,r,s),Tu(n,t,r)}}function Ud(e,t,n){var r=wr(e),s={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null};if(Eu(e))Pu(t,s);else{var o=e.alternate;if(e.lanes===0&&(o===null||o.lanes===0)&&(o=t.lastRenderedReducer,o!==null))try{var u=t.lastRenderedState,d=o(u,n);if(s.hasEagerState=!0,s.eagerState=d,gn(d,u)){var m=t.interleaved;m===null?(s.next=s,ii(t)):(s.next=m.next,m.next=s),t.interleaved=s;return}}catch{}n=su(e,t,s,r),n!==null&&(s=Nt(),Sn(n,e,r,s),Tu(n,t,r))}}function Eu(e){var t=e.alternate;return e===He||t!==null&&t===He}function Pu(e,t){lo=Go=!0;var n=e.pending;n===null?t.next=t:(t.next=n.next,n.next=t),e.pending=t}function Tu(e,t,n){if((n&4194240)!==0){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,zs(e,n)}}var Xo={readContext:Yt,useCallback:vt,useContext:vt,useEffect:vt,useImperativeHandle:vt,useInsertionEffect:vt,useLayoutEffect:vt,useMemo:vt,useReducer:vt,useRef:vt,useState:vt,useDebugValue:vt,useDeferredValue:vt,useTransition:vt,useMutableSource:vt,useSyncExternalStore:vt,useId:vt,unstable_isNewReconciler:!1},Bd={readContext:Yt,useCallback:function(e,t){return Ln().memoizedState=[e,t===void 0?null:t],e},useContext:Yt,useEffect:yu,useImperativeHandle:function(e,t,n){return n=n!=null?n.concat([e]):null,Jo(4194308,4,Su.bind(null,t,e),n)},useLayoutEffect:function(e,t){return Jo(4194308,4,e,t)},useInsertionEffect:function(e,t){return Jo(4,2,e,t)},useMemo:function(e,t){var n=Ln();return t=t===void 0?null:t,e=e(),n.memoizedState=[e,t],e},useReducer:function(e,t,n){var r=Ln();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=Fd.bind(null,He,e),[r.memoizedState,e]},useRef:function(e){var t=Ln();return e={current:e},t.memoizedState=e},useState:gu,useDebugValue:_i,useDeferredValue:function(e){return Ln().memoizedState=e},useTransition:function(){var e=gu(!1),t=e[0];return e=$d.bind(null,e[1]),Ln().memoizedState=e,[t,e]},useMutableSource:function(){},useSyncExternalStore:function(e,t,n){var r=He,s=Ln();if(ze){if(n===void 0)throw Error(f(407));n=n()}else{if(n=t(),nt===null)throw Error(f(349));(qr&30)!==0||du(r,t,n)}s.memoizedState=n;var o={value:n,getSnapshot:t};return s.queue=o,yu(mu.bind(null,r,o,e),[e]),r.flags|=2048,uo(9,fu.bind(null,r,o,n,t),void 0,null),n},useId:function(){var e=Ln(),t=nt.identifierPrefix;if(ze){var n=qn,r=Wn;n=(r&~(1<<32-Ue(r)-1)).toString(32)+n,t=":"+t+"R"+n,n=io++,0<\/script>",e=e.removeChild(e.firstChild)):typeof r.is=="string"?e=u.createElement(n,{is:r.is}):(e=u.createElement(n),n==="select"&&(u=e,r.multiple?u.multiple=!0:r.size&&(u.size=r.size))):e=u.createElementNS(e,n),e[Rn]=t,e[eo]=r,Gu(e,t,!1,!1),t.stateNode=e;e:{switch(u=an(n,r),n){case"dialog":Ie("cancel",e),Ie("close",e),s=r;break;case"iframe":case"object":case"embed":Ie("load",e),s=r;break;case"video":case"audio":for(s=0;sTs&&(t.flags|=128,r=!0,co(o,!1),t.lanes=4194304)}else{if(!r)if(e=qo(u),e!==null){if(t.flags|=128,r=!0,n=e.updateQueue,n!==null&&(t.updateQueue=n,t.flags|=4),co(o,!0),o.tail===null&&o.tailMode==="hidden"&&!u.alternate&&!ze)return yt(t),null}else 2*Fe()-o.renderingStartTime>Ts&&n!==1073741824&&(t.flags|=128,r=!0,co(o,!1),t.lanes=4194304);o.isBackwards?(u.sibling=t.child,t.child=u):(n=o.last,n!==null?n.sibling=u:t.child=u,o.last=u)}return o.tail!==null?(t=o.tail,o.rendering=t,o.tail=t.sibling,o.renderingStartTime=Fe(),t.sibling=null,n=Be.current,Le(Be,r?n&1|2:n&1),t):(yt(t),null);case 22:case 23:return bi(),r=t.memoizedState!==null,e!==null&&e.memoizedState!==null!==r&&(t.flags|=8192),r&&(t.mode&1)!==0?(Wt&1073741824)!==0&&(yt(t),t.subtreeFlags&6&&(t.flags|=8192)):yt(t),null;case 24:return null;case 25:return null}throw Error(f(156,t.tag))}function Gd(e,t){switch(Zl(t),t.tag){case 1:return Rt(t.type)&&Oo(),e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 3:return Cs(),De(Tt),De(gt),fi(),e=t.flags,(e&65536)!==0&&(e&128)===0?(t.flags=e&-65537|128,t):null;case 5:return ci(t),null;case 13:if(De(Be),e=t.memoizedState,e!==null&&e.dehydrated!==null){if(t.alternate===null)throw Error(f(340));Ss()}return e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 19:return De(Be),null;case 4:return Cs(),null;case 10:return oi(t.type._context),null;case 22:case 23:return bi(),null;case 24:return null;default:return null}}var nl=!1,xt=!1,Jd=typeof WeakSet=="function"?WeakSet:Set,O=null;function Es(e,t){var n=e.ref;if(n!==null)if(typeof n=="function")try{n(null)}catch(r){Ve(e,t,r)}else n.current=null}function Li(e,t,n){try{n()}catch(r){Ve(e,t,r)}}var Xu=!1;function Yd(e,t){if(bl=os,e=Ra(),Ol(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 s=r.anchorOffset,o=r.focusNode;r=r.focusOffset;try{n.nodeType,o.nodeType}catch{n=null;break e}var u=0,d=-1,m=-1,S=0,N=0,P=e,C=null;t:for(;;){for(var I;P!==n||s!==0&&P.nodeType!==3||(d=u+s),P!==o||r!==0&&P.nodeType!==3||(m=u+r),P.nodeType===3&&(u+=P.nodeValue.length),(I=P.firstChild)!==null;)C=P,P=I;for(;;){if(P===e)break t;if(C===n&&++S===s&&(d=u),C===o&&++N===r&&(m=u),(I=P.nextSibling)!==null)break;P=C,C=P.parentNode}P=I}n=d===-1||m===-1?null:{start:d,end:m}}else n=null}n=n||{start:0,end:0}}else n=null;for(Vl={focusedElem:e,selectionRange:n},os=!1,O=t;O!==null;)if(t=O,e=t.child,(t.subtreeFlags&1028)!==0&&e!==null)e.return=t,O=e;else for(;O!==null;){t=O;try{var B=t.alternate;if((t.flags&1024)!==0)switch(t.tag){case 0:case 11:case 15:break;case 1:if(B!==null){var b=B.memoizedProps,Ge=B.memoizedState,x=t.stateNode,h=x.getSnapshotBeforeUpdate(t.elementType===t.type?b:yn(t.type,b),Ge);x.__reactInternalSnapshotBeforeUpdate=h}break;case 3:var _=t.stateNode.containerInfo;_.nodeType===1?_.textContent="":_.nodeType===9&&_.documentElement&&_.removeChild(_.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(f(163))}}catch(T){Ve(t,t.return,T)}if(e=t.sibling,e!==null){e.return=t.return,O=e;break}O=t.return}return B=Xu,Xu=!1,B}function fo(e,t,n){var r=t.updateQueue;if(r=r!==null?r.lastEffect:null,r!==null){var s=r=r.next;do{if((s.tag&e)===e){var o=s.destroy;s.destroy=void 0,o!==void 0&&Li(t,n,o)}s=s.next}while(s!==r)}}function rl(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 Ai(e){var t=e.ref;if(t!==null){var n=e.stateNode;e.tag,e=n,typeof t=="function"?t(e):t.current=e}}function Zu(e){var t=e.alternate;t!==null&&(e.alternate=null,Zu(t)),e.child=null,e.deletions=null,e.sibling=null,e.tag===5&&(t=e.stateNode,t!==null&&(delete t[Rn],delete t[eo],delete t[Gl],delete t[Ad],delete t[Id])),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 ec(e){return e.tag===5||e.tag===3||e.tag===4}function tc(e){e:for(;;){for(;e.sibling===null;){if(e.return===null||ec(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 Ii(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=Io));else if(r!==4&&(e=e.child,e!==null))for(Ii(e,t,n),e=e.sibling;e!==null;)Ii(e,t,n),e=e.sibling}function Di(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(Di(e,t,n),e=e.sibling;e!==null;)Di(e,t,n),e=e.sibling}var ut=null,xn=!1;function xr(e,t,n){for(n=n.child;n!==null;)nc(e,t,n),n=n.sibling}function nc(e,t,n){if(ue&&typeof ue.onCommitFiberUnmount=="function")try{ue.onCommitFiberUnmount(wt,n)}catch{}switch(n.tag){case 5:xt||Es(n,t);case 6:var r=ut,s=xn;ut=null,xr(e,t,n),ut=r,xn=s,ut!==null&&(xn?(e=ut,n=n.stateNode,e.nodeType===8?e.parentNode.removeChild(n):e.removeChild(n)):ut.removeChild(n.stateNode));break;case 18:ut!==null&&(xn?(e=ut,n=n.stateNode,e.nodeType===8?Kl(e.parentNode,n):e.nodeType===1&&Kl(e,n),ir(e)):Kl(ut,n.stateNode));break;case 4:r=ut,s=xn,ut=n.stateNode.containerInfo,xn=!0,xr(e,t,n),ut=r,xn=s;break;case 0:case 11:case 14:case 15:if(!xt&&(r=n.updateQueue,r!==null&&(r=r.lastEffect,r!==null))){s=r=r.next;do{var o=s,u=o.destroy;o=o.tag,u!==void 0&&((o&2)!==0||(o&4)!==0)&&Li(n,t,u),s=s.next}while(s!==r)}xr(e,t,n);break;case 1:if(!xt&&(Es(n,t),r=n.stateNode,typeof r.componentWillUnmount=="function"))try{r.props=n.memoizedProps,r.state=n.memoizedState,r.componentWillUnmount()}catch(d){Ve(n,t,d)}xr(e,t,n);break;case 21:xr(e,t,n);break;case 22:n.mode&1?(xt=(r=xt)||n.memoizedState!==null,xr(e,t,n),xt=r):xr(e,t,n);break;default:xr(e,t,n)}}function rc(e){var t=e.updateQueue;if(t!==null){e.updateQueue=null;var n=e.stateNode;n===null&&(n=e.stateNode=new Jd),t.forEach(function(r){var s=lf.bind(null,e,r);n.has(r)||(n.add(r),r.then(s,s))})}}function _n(e,t){var n=t.deletions;if(n!==null)for(var r=0;rs&&(s=u),r&=~o}if(r=s,r=Fe()-r,r=(120>r?120:480>r?480:1080>r?1080:1920>r?1920:3e3>r?3e3:4320>r?4320:1960*Zd(r/1960))-r,10e?16:e,Sr===null)var r=!1;else{if(e=Sr,Sr=null,al=0,(Se&6)!==0)throw Error(f(331));var s=Se;for(Se|=4,O=e.current;O!==null;){var o=O,u=o.child;if((O.flags&16)!==0){var d=o.deletions;if(d!==null){for(var m=0;mFe()-$i?Jr(e,0):zi|=n),At(e,t)}function gc(e,t){t===0&&((e.mode&1)===0?t=1:(t=Un,Un<<=1,(Un&130023424)===0&&(Un=4194304)));var n=Nt();e=Kn(e,t),e!==null&&(Ne(e,t,n),At(e,n))}function of(e){var t=e.memoizedState,n=0;t!==null&&(n=t.retryLane),gc(e,n)}function lf(e,t){var n=0;switch(e.tag){case 13:var r=e.stateNode,s=e.memoizedState;s!==null&&(n=s.retryLane);break;case 19:r=e.stateNode;break;default:throw Error(f(314))}r!==null&&r.delete(t),gc(e,n)}var vc;vc=function(e,t,n){if(e!==null)if(e.memoizedProps!==t.pendingProps||Tt.current)Mt=!0;else{if((e.lanes&n)===0&&(t.flags&128)===0)return Mt=!1,qd(e,t,n);Mt=(e.flags&131072)!==0}else Mt=!1,ze&&(t.flags&1048576)!==0&&Ja(t,Uo,t.index);switch(t.lanes=0,t.tag){case 2:var r=t.type;tl(e,t),e=t.pendingProps;var s=ys(t,gt.current);js(t,n),s=hi(null,t,r,e,s,n);var o=gi();return t.flags|=1,typeof s=="object"&&s!==null&&typeof s.render=="function"&&s.$$typeof===void 0?(t.tag=1,t.memoizedState=null,t.updateQueue=null,Rt(r)?(o=!0,zo(t)):o=!1,t.memoizedState=s.state!==null&&s.state!==void 0?s.state:null,ai(t),s.updater=Zo,t.stateNode=s,s._reactInternals=t,wi(t,r,e,n),t=Ni(null,t,r,!0,o,n)):(t.tag=0,ze&&o&&Xl(t),Ct(null,t,s,n),t=t.child),t;case 16:r=t.elementType;e:{switch(tl(e,t),e=t.pendingProps,s=r._init,r=s(r._payload),t.type=r,s=t.tag=uf(r),e=yn(r,e),s){case 0:t=Ci(null,t,r,e,n);break e;case 1:t=Qu(null,t,r,e,n);break e;case 11:t=$u(null,t,r,e,n);break e;case 14:t=Fu(null,t,r,yn(r.type,e),n);break e}throw Error(f(306,r,""))}return t;case 0:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:yn(r,s),Ci(e,t,r,s,n);case 1:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:yn(r,s),Qu(e,t,r,s,n);case 3:e:{if(bu(t),e===null)throw Error(f(387));r=t.pendingProps,o=t.memoizedState,s=o.element,ou(e,t),Wo(t,r,null,n);var u=t.memoizedState;if(r=u.element,o.isDehydrated)if(o={element:r,isDehydrated:!1,cache:u.cache,pendingSuspenseBoundaries:u.pendingSuspenseBoundaries,transitions:u.transitions},t.updateQueue.baseState=o,t.memoizedState=o,t.flags&256){s=Ns(Error(f(423)),t),t=Vu(e,t,r,n,s);break e}else if(r!==s){s=Ns(Error(f(424)),t),t=Vu(e,t,r,n,s);break e}else for(Vt=mr(t.stateNode.containerInfo.firstChild),bt=t,ze=!0,vn=null,n=ru(t,null,r,n),t.child=n;n;)n.flags=n.flags&-3|4096,n=n.sibling;else{if(Ss(),r===s){t=Jn(e,t,n);break e}Ct(e,t,r,n)}t=t.child}return t;case 5:return au(t),e===null&&ti(t),r=t.type,s=t.pendingProps,o=e!==null?e.memoizedProps:null,u=s.children,Wl(r,s)?u=null:o!==null&&Wl(r,o)&&(t.flags|=32),Hu(e,t),Ct(e,t,u,n),t.child;case 6:return e===null&&ti(t),null;case 13:return Wu(e,t,n);case 4:return ui(t,t.stateNode.containerInfo),r=t.pendingProps,e===null?t.child=ws(t,null,r,n):Ct(e,t,r,n),t.child;case 11:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:yn(r,s),$u(e,t,r,s,n);case 7:return Ct(e,t,t.pendingProps,n),t.child;case 8:return Ct(e,t,t.pendingProps.children,n),t.child;case 12:return Ct(e,t,t.pendingProps.children,n),t.child;case 10:e:{if(r=t.type._context,s=t.pendingProps,o=t.memoizedProps,u=s.value,Le(Qo,r._currentValue),r._currentValue=u,o!==null)if(gn(o.value,u)){if(o.children===s.children&&!Tt.current){t=Jn(e,t,n);break e}}else for(o=t.child,o!==null&&(o.return=t);o!==null;){var d=o.dependencies;if(d!==null){u=o.child;for(var m=d.firstContext;m!==null;){if(m.context===r){if(o.tag===1){m=Gn(-1,n&-n),m.tag=2;var S=o.updateQueue;if(S!==null){S=S.shared;var N=S.pending;N===null?m.next=m:(m.next=N.next,N.next=m),S.pending=m}}o.lanes|=n,m=o.alternate,m!==null&&(m.lanes|=n),li(o.return,n,t),d.lanes|=n;break}m=m.next}}else if(o.tag===10)u=o.type===t.type?null:o.child;else if(o.tag===18){if(u=o.return,u===null)throw Error(f(341));u.lanes|=n,d=u.alternate,d!==null&&(d.lanes|=n),li(u,n,t),u=o.sibling}else u=o.child;if(u!==null)u.return=o;else for(u=o;u!==null;){if(u===t){u=null;break}if(o=u.sibling,o!==null){o.return=u.return,u=o;break}u=u.return}o=u}Ct(e,t,s.children,n),t=t.child}return t;case 9:return s=t.type,r=t.pendingProps.children,js(t,n),s=Yt(s),r=r(s),t.flags|=1,Ct(e,t,r,n),t.child;case 14:return r=t.type,s=yn(r,t.pendingProps),s=yn(r.type,s),Fu(e,t,r,s,n);case 15:return Uu(e,t,t.type,t.pendingProps,n);case 17:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:yn(r,s),tl(e,t),t.tag=1,Rt(r)?(e=!0,zo(t)):e=!1,js(t,n),Mu(t,r,s),wi(t,r,s,n),Ni(null,t,r,!0,e,n);case 19:return Ku(e,t,n);case 22:return Bu(e,t,n)}throw Error(f(156,t.tag))};function yc(e,t){return xo(e,t)}function af(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 en(e,t,n,r){return new af(e,t,n,r)}function Wi(e){return e=e.prototype,!(!e||!e.isReactComponent)}function uf(e){if(typeof e=="function")return Wi(e)?1:0;if(e!=null){if(e=e.$$typeof,e===ot)return 11;if(e===We)return 14}return 2}function jr(e,t){var n=e.alternate;return n===null?(n=en(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 fl(e,t,n,r,s,o){var u=2;if(r=e,typeof e=="function")Wi(e)&&(u=1);else if(typeof e=="string")u=5;else e:switch(e){case Ce:return Xr(n.children,s,o,t);case $e:u=8,s|=8;break;case dt:return e=en(12,n,t,s|2),e.elementType=dt,e.lanes=o,e;case H:return e=en(13,n,t,s),e.elementType=H,e.lanes=o,e;case Me:return e=en(19,n,t,s),e.elementType=Me,e.lanes=o,e;case Z:return ml(n,s,o,t);default:if(typeof e=="object"&&e!==null)switch(e.$$typeof){case st:u=10;break e;case Dt:u=9;break e;case ot:u=11;break e;case We:u=14;break e;case ne:u=16,r=null;break e}throw Error(f(130,e==null?e:typeof e,""))}return t=en(u,n,t,s),t.elementType=e,t.type=r,t.lanes=o,t}function Xr(e,t,n,r){return e=en(7,e,r,t),e.lanes=n,e}function ml(e,t,n,r){return e=en(22,e,r,t),e.elementType=Z,e.lanes=n,e.stateNode={isHidden:!1},e}function qi(e,t,n){return e=en(6,e,null,t),e.lanes=n,e}function Ki(e,t,n){return t=en(4,e.children!==null?e.children:[],e.key,t),t.lanes=n,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function cf(e,t,n,r,s){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=pn(0),this.expirationTimes=pn(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=pn(0),this.identifierPrefix=r,this.onRecoverableError=s,this.mutableSourceEagerHydrationData=null}function Gi(e,t,n,r,s,o,u,d,m){return e=new cf(e,t,n,d,m),t===1?(t=1,o===!0&&(t|=8)):t=0,o=en(3,null,null,t),e.current=o,o.stateNode=e,o.memoizedState={element:r,isDehydrated:n,cache:null,transitions:null,pendingSuspenseBoundaries:null},ai(o),e}function df(e,t,n){var r=3"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(i)}catch(g){console.error(g)}}return i(),ta.exports=kf(),ta.exports}var Lc;function Cf(){if(Lc)return _l;Lc=1;var i=jf();return _l.createRoot=i.createRoot,_l.hydrateRoot=i.hydrateRoot,_l}var Nf=Cf();const Ef=qc(Nf),Pf="/api";async function ye(i,g){const f=await fetch(`${Pf}${i}`,{...g,headers:{"Content-Type":"application/json",...g?.headers??{}}}),R=await f.json();if(!f.ok){const E=R.error?.message??"Ошибка запроса";throw new Error(E)}return R}const Pe={async loadSharedConnectionConfig(){return ye("/llm/shared-connection")},async saveSharedConnectionConfig(i){return ye("/llm/shared-connection",{method:"POST",body:JSON.stringify({llmProvider:i.llmProvider,model:i.model,baseUrl:i.baseUrl,temperature:i.temperature,maxOutputTokens:i.maxOutputTokens})})},async listModels(i){return ye("/llm/models",{method:"POST",body:JSON.stringify({llmProvider:i.llmProvider,apiKey:i.apiKey,model:i.model,baseUrl:i.baseUrl})})},async testConnection(i){return ye("/llm/test-connection",{method:"POST",body:JSON.stringify({llmProvider:i.llmProvider,apiKey:i.apiKey,model:i.model,baseUrl:i.baseUrl})})},async normalize(i){return ye("/normalize",{method:"POST",body:JSON.stringify({llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion,systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples,userQuestion:i.query.userQuestion,context:{period_hint:i.query.periodHint??"",business_context:i.query.businessContext??"",expected_route:i.query.expectedRoute??""},saveAsTestCase:!!i.saveAsTestCase,useMock:!!i.useMock})})},async loadHistory(){return ye("/history")},async loadTrace(i){return ye(`/history/${i}`)},async loadPresets(){return ye("/presets")},async savePreset(i){return ye("/presets/save",{method:"POST",body:JSON.stringify(i)})},async runEval(i){return ye("/eval/run",{method:"POST",body:JSON.stringify({normalizeConfig:{llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion,systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples},caseIds:i.caseIds,useMock:!!i.useMock,mode:i.mode??"standard",caseSetFile:i.caseSetFile,rawQuestions:i.rawQuestions,eval_target:i.evalTarget,compare_with_report_file:i.compareWithReportFile,analysis_date:i.analysisDate})})},async startEvalRunAsync(i){return ye("/eval/run-async/start",{method:"POST",body:JSON.stringify({normalizeConfig:{llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion,systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples},caseIds:i.caseIds,useMock:!!i.useMock,mode:i.mode??"standard",caseSetFile:i.caseSetFile,rawQuestions:i.rawQuestions,eval_target:i.evalTarget,compare_with_report_file:i.compareWithReportFile,questions:i.questions,scenarioQuestions:i.scenarioQuestions,scenarioTitle:i.scenarioTitle,analysis_date:i.analysisDate})})},async loadEvalRunAsyncStatus(i){return ye(`/eval/run-async/${encodeURIComponent(i)}`)},async startRun(){return ye("/accounting-agent/v1/runs/start",{method:"POST",body:JSON.stringify({initiator:"ndc_operator",source:"gui"})})},async finishRun(i){return ye("/accounting-agent/v1/runs/finish",{method:"POST",body:JSON.stringify({runId:i,status:"DONE",source:"gui",reason:"Остановлено оператором из GUI"})})},async listRuns(){return ye("/accounting-agent/v1/runs")},async listResults(){return ye("/accounting-agent/v1/results")},async runTrace(i){return ye(`/accounting-agent/v1/trace/run/${i}`)},async sendAssistantMessage(i){return ye("/assistant/message",{method:"POST",body:JSON.stringify({session_id:i.sessionId??"",mode:"assistant",message:i.userMessage,user_message:i.userMessage,llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion??"address_query_runtime_v1",systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples,context:{period_hint:i.context?.periodHint??"",business_context:i.context?.businessContext??""},useMock:!!i.useMock})})},async loadAssistantSession(i){return ye(`/assistant/session/${i}`)},async saveAutoRunAssistantSession(i){return ye("/autoruns/autogen/save-assistant-session",{method:"POST",body:JSON.stringify(i)})},async loadAssistantAnnotations(i){const g=new URLSearchParams;i?.session_id&&g.set("session_id",i.session_id),typeof i?.limit=="number"&&g.set("limit",String(i.limit));const f=g.toString();return ye(`/assistant/annotations${f?`?${f}`:""}`)},async saveAssistantAnnotation(i){return ye("/assistant/annotations",{method:"POST",body:JSON.stringify(i)})},async loadAutoRunsHistory(i){const g=new URLSearchParams;i?.from&&g.set("from",i.from),i?.to&&g.set("to",i.to),i?.target&&g.set("target",i.target),i?.mode&&g.set("mode",i.mode),i?.use_mock&&g.set("use_mock",i.use_mock),i?.prompt_contains&&g.set("prompt_contains",i.prompt_contains),typeof i?.limit=="number"&&g.set("limit",String(i.limit)),typeof i?.scan_limit=="number"&&g.set("scan_limit",String(i.scan_limit));const f=g.toString();return ye(`/autoruns/history${f?`?${f}`:""}`)},async loadAutoRunDetail(i){return ye(`/autoruns/history/${encodeURIComponent(i)}`)},async loadAutoRunCaseDialog(i,g){return ye(`/autoruns/history/${encodeURIComponent(i)}/case/${encodeURIComponent(g)}/dialog`)},async loadAutoRunAnnotations(i){const g=new URLSearchParams;i?.run_id&&g.set("run_id",i.run_id),i?.case_id&&g.set("case_id",i.case_id),typeof i?.min_rating=="number"&&g.set("min_rating",String(i.min_rating)),i?.manual_case_decision&&g.set("manual_case_decision",i.manual_case_decision),typeof i?.limit=="number"&&g.set("limit",String(i.limit));const f=g.toString();return ye(`/autoruns/annotations${f?`?${f}`:""}`)},async saveAutoRunAnnotation(i){return ye("/autoruns/annotations",{method:"POST",body:JSON.stringify(i)})},async updateAutoRunAnnotation(i){return ye(`/autoruns/annotations/${encodeURIComponent(i.annotation_id)}`,{method:"PATCH",body:JSON.stringify({resolved:i.resolved,resolved_by:i.resolved_by})})},async loadAutoRunPostAnalysis(i){const g=new URLSearchParams;i?.run_id&&g.set("run_id",i.run_id),typeof i?.limit_per_queue=="number"&&g.set("limit_per_queue",String(i.limit_per_queue)),typeof i?.annotation_limit=="number"&&g.set("annotation_limit",String(i.annotation_limit)),typeof i?.scan_limit=="number"&&g.set("scan_limit",String(i.scan_limit)),i?.from&&g.set("from",i.from),i?.to&&g.set("to",i.to),i?.target&&g.set("target",i.target),i?.mode&&g.set("mode",i.mode),i?.use_mock&&g.set("use_mock",i.use_mock),i?.prompt_contains&&g.set("prompt_contains",i.prompt_contains);const f=g.toString();return ye(`/autoruns/post-analysis${f?`?${f}`:""}`)},async loadAutoRunAutogenHistory(i){const g=new URLSearchParams;i?.mode&&g.set("mode",i.mode),typeof i?.limit=="number"&&g.set("limit",String(i.limit));const f=g.toString();return ye(`/autoruns/autogen/history${f?`?${f}`:""}`)},async loadAutoRunAutogenPersonalityCatalog(){return ye("/autoruns/autogen/personality-catalog")},async updateAutoRunAutogenQuestions(i){return ye(`/autoruns/autogen/history/${encodeURIComponent(i.generation_id)}/questions`,{method:"PATCH",body:JSON.stringify({questions:i.questions})})},async deleteAutoRunAutogenHistoryRecord(i){return ye(`/autoruns/autogen/history/${encodeURIComponent(i)}`,{method:"DELETE"})},async generateAutoRunQuestions(i){return ye("/autoruns/autogen/generate",{method:"POST",body:JSON.stringify(i)})}},Tf=/(?:^|\n)\s*#{0,6}\s*(?:debug_payload_json|technical_breakdown_json|route_summary_json|debug_payload|technical_breakdown)\b/i,Rf=[/\b(?:debug_payload_json|technical_breakdown_json)\b/i,/\b(?:route_summary|semantic_profile|domain_scope|relation_patterns|account_scope)\b/i,/\b(?:coverage_report|retrieval_status|problem_unit_state|candidate_evidence)\b/i,/\b(?:graph_domain_scope|graph_runtime|selection_reason|why_included)\b/i];function Mf(i){try{return JSON.stringify(i,null,2)}catch{return String(i)}}function Lf(i){const g=String(i??""),f=g.match(Tf);return(f?g.slice(0,f.index):g).replace(/###\s*(?:debug_payload_json|technical_breakdown_json|route_summary_json)[\s\S]*?(?:```[\s\S]*?```|$)/gi,"").replace(/(?:^|\n)\s*#{0,6}\s*(?:debug_payload_json|technical_breakdown_json|route_summary_json)\b[\s\S]*$/gi,"").split(/\r?\n/g).map(Q=>Q.trimEnd()).filter(Q=>Q.trim().length>0).filter(Q=>!Rf.some(le=>le.test(Q))).join(` +`).trim()}function Af(i,g,f="default"){const R=f==="technical",E=[];E.push("# Assistant conversation export"),E.push(`session_id: ${i||"n/a"}`),E.push(`export_mode: ${f}`),E.push(`exported_at: ${new Date().toISOString()}`),E.push("");for(let A=0;A{E.length!==0&&(R.push(E.join(` +`)),E=[])};for(const Q of f){const le=Q.trimEnd(),te=le.trim();if(!te){A();continue}const z=/^Блок\s+\d+\./i.test(te),Y=/^\d+\.\s/.test(te);(z||Y)&&E.length>0&&A(),E.push(le)}return A(),R.length>0?R:[i]}function Uf(i,g){const f=[],R=/\*\*(.+?)\*\*/g;let E=0,A=0,Q;for(;(Q=R.exec(i))!==null;)Q.index>E&&(f.push(l.jsx("span",{children:i.slice(E,Q.index)},`${g}-t-${A}`)),A+=1),f.push(l.jsx("strong",{children:Q[1]},`${g}-b-${A}`)),A+=1,E=R.lastIndex;return E0?f:[l.jsx("span",{children:i},`${g}-raw`)]}function Bf(i){const g=i.trimStart();return/^Блок\s+\d+\./i.test(g)?"assistant-msg-line heading":/^\d+\.\s/.test(g)?"assistant-msg-line numbered":/^-\s/.test(g)?"assistant-msg-line bullet":"assistant-msg-line"}function Hf(i,g=40){const f=i.replace(/\s+/g," ").trim();if(f.length<=g)return f;const R=f.split(" ").slice(0,3).join(" ").trim();return R.length>=10&&R.length<=g?`${R}…`:`${f.slice(0,g-1).trimEnd()}…`}function Gc(i){return i.replace(/\*\*(.+?)\*\*/g,"$1").replace(/^\d+\.\s*/,"").trim()}function Qf(i){const g=i.replace(/\r\n?/g,` +`).split(` +`).map(E=>E.trim()).find(Boolean),f=Gc(g??"");return(f.split("|")[0]?.trim()??f).replace(/\s+/g," ").trim()}function bf(i){const g=i.replace(/\r\n?/g,` +`).split(` +`).map(R=>R.trim()).find(Boolean);return!g||!/^\d+\.\s/.test(g)?!1:Gc(g).includes("|")}function Vf(i,g){const f=g.replace(/\r\n?/g,` +`).replace(/\*\*(.+?)\*\*/g,"$1").split(` +`).map((E,A)=>{const Q=E.trim();return A===0?Q.replace(/^\d+\.\s*/,""):Q}).filter(Boolean).join(" ").replace(/\s+/g," ").trim();if(!f)return null;const R=Qf(g)||f;return{message_id:i.message_id,source_text:f,anchor_text:R,preview_text:Hf(R)}}function Wf(i,g,f,R){return Ff(i.text).map((A,Q)=>{const le=A.split(` +`),te=i.role==="assistant"&&bf(A),z=te?Vf(i,A):null,Y=!!z&&g?.message_id===z?.message_id&&g?.source_text===z?.source_text,X=le.map((ee,Te)=>l.jsx("p",{className:Bf(ee),children:Uf(ee,`line-${Q}-${Te}`)},`line-${Q}-${Te}`));return!te||!z?l.jsx("div",{className:"assistant-msg-block",children:X},`block-${Q}`):l.jsx("div",{className:Y?"assistant-msg-block selectable active":"assistant-msg-block selectable",role:"button",tabIndex:0,onClick:()=>{if(Y){R();return}f(z)},onKeyDown:ee=>{if(!(ee.key!=="Enter"&&ee.key!==" ")){if(ee.preventDefault(),Y){R();return}f(z)}},children:X},`block-${Q}`)})}function qf({sessionId:i,conversation:g,inputValue:f,onInputChange:R,selectedContextChip:E,onSelectContextChip:A,onClearContextChip:Q,useMock:le,onUseMockChange:te,onSend:z,onClear:Y,onSaveSession:X,busy:ee,saveBusy:Te=!1,saveDisabled:ce=!1,statusText:de,errorMessage:pe,showSaveAction:Qe=!1,showCommentAction:Je=!1,onCommentAssistantMessage:be,isAssistantMessageCommented:Re,canCommentAssistantMessage:F}){const oe=y.useRef(null),Ce=y.useRef(!0),$e=y.useRef(null),[dt,st]=y.useState("idle"),[Dt,ot]=y.useState("чат");function H(ne=!1){oe.current&&(ne&&(Ce.current=!0),oe.current.scrollTop=oe.current.scrollHeight)}y.useEffect(()=>{Ce.current&&H()},[g]),y.useEffect(()=>()=>{$e.current!==null&&window.clearTimeout($e.current)},[]);async function Me(ne){if(g.length===0)return;const Z=Af(i,g,ne),M=await Of(Z);ot(ne==="technical"?"тех":"чат"),st(M?"success":"error"),$e.current!==null&&window.clearTimeout($e.current),$e.current=window.setTimeout(()=>{st("idle")},2200)}function We(){if(!oe.current)return;const ne=oe.current,Z=ne.scrollHeight-ne.scrollTop-ne.clientHeight;Ce.current=Z<16}return l.jsx(Pl,{className:"assistant-panel-frame",title:"Режим ассистента",children:l.jsxs("div",{className:"assistant-live-shell",children:[l.jsxs("div",{className:"assistant-toolbar",children:[l.jsxs("div",{className:"assistant-toolbar-actions",children:[l.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>{Me("default")},disabled:g.length===0,title:"Экспорт только user-facing чата",children:"Скопировать чат"}),l.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>{Me("technical")},disabled:g.length===0,title:"Технический экспорт с debug payload",children:"Скопировать техчат"}),Qe?l.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>X?.(),disabled:Te||ce,children:Te?"Сохраняю...":"Сохранить"}):null,l.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>Y(),disabled:ee&&g.length===0,children:"Сбросить сессию"})]}),l.jsxs("div",{className:"assistant-toolbar-meta",children:[i?l.jsx("span",{className:"status-chip",children:`session: ${i}`}):null,l.jsxs("div",{className:"assistant-toolbar-meta-right",children:[de?l.jsx("span",{className:"assistant-live-status",children:de}):null,dt==="success"?l.jsxs("span",{className:"assistant-copy-feedback success",children:["Скопировано (",Dt,")"]}):null,dt==="error"?l.jsx("span",{className:"assistant-copy-feedback error",children:"Ошибка копирования"}):null]})]}),pe?l.jsx("p",{className:"error-text assistant-toolbar-error",children:pe}):null]}),l.jsx("div",{ref:oe,className:"assistant-chat-list",onScroll:We,children:g.map((ne,Z)=>{const M=ne.role==="assistant"&&Je&&typeof be=="function"&&(typeof F=="function"?F(ne,Z):!0),U=ne.role==="assistant"&&typeof Re=="function"?Re(ne,Z):!1;return l.jsxs("article",{className:`assistant-msg ${ne.role}`,children:[l.jsxs("header",{className:"assistant-msg-head",children:[l.jsxs("div",{className:"assistant-msg-head-main",children:[l.jsx("strong",{children:If(ne.role)}),l.jsx("span",{children:Df(ne.created_at)})]}),ne.role==="assistant"&&Je?l.jsx("div",{className:"assistant-msg-head-actions",children:l.jsx("button",{type:"button",className:U?"autoruns-comment-icon assistant-comment-btn commented":"autoruns-comment-icon assistant-comment-btn",onClick:()=>be?.(ne,Z),disabled:!M,title:M?"Комментировать ответ ассистента":"Комментарий недоступен для этого сообщения","aria-label":M?"Комментировать ответ ассистента":"Комментарий недоступен для этого сообщения",children:l.jsx(zf,{commented:U})})}):null]}),l.jsx("div",{className:"assistant-msg-body",children:Wf(ne,E,A,Q)}),ne.role==="assistant"&&ne.debug?l.jsxs("details",{className:"assistant-debug",children:[l.jsx("summary",{children:"Показать технический разбор"}),l.jsx(Kc,{value:ne.debug})]}):null]},ne.message_id)})}),l.jsxs("div",{className:"assistant-compose",children:[E?l.jsxs("div",{className:"assistant-compose-context",children:[l.jsx("span",{className:"assistant-compose-context-label",children:"Выбранный объект"}),l.jsxs("div",{className:"assistant-compose-context-pill",title:E.source_text,children:[l.jsx("span",{className:"assistant-compose-context-pill-text",children:E.preview_text}),l.jsx("button",{type:"button",className:"assistant-compose-context-clear",onClick:Q,"aria-label":"Убрать выбранный объект",title:"Убрать выбранный объект",children:"×"})]})]}):null,l.jsxs("label",{className:"full-width",children:["Сообщение",l.jsx("textarea",{className:"assistant-input-textarea",value:f,onChange:ne=>R(ne.target.value),rows:4,placeholder:E?"Продолжите вопрос по выбранному объекту...":"Введите вопрос к данным компании..."})]}),l.jsxs("div",{className:"button-row assistant-send-row",children:[l.jsxs("label",{className:"checkbox-row",children:[l.jsx("input",{type:"checkbox",checked:le,onChange:ne=>te(ne.target.checked)}),"Mock-режим"]}),l.jsx("button",{type:"button",className:"assistant-send-btn",onClick:()=>{H(!0),z()},disabled:ee||!f.trim(),children:ee?"Выполняю...":"Отправить"})]})]})]})})}const Sl="http://127.0.0.1:1234/v1",Ac="https://api.openai.com/v1",Nl="qwen2.5-14b-instruct-1m",ma="unsloth/qwen3-30b-a3b-instruct-2507",Kf=[{value:Nl,label:"Qwen2.5 14B Instruct 1M"},{value:ma,label:"Qwen3 30B A3B Instruct 2507"}];function Gf(i){return i.llmProvider!=="local"?"openai":i.model===ma?"local_qwen3":i.model===Nl?"local_qwen25":"local_custom"}function Jf(i,g){const f=new Map;if(g)for(const R of Kf)f.set(R.value,R);for(const R of i)f.has(R)||f.set(R,{value:R,label:R});return Array.from(f.values())}function Yf({value:i,modelOptions:g,modelsBusy:f,onChange:R,onReloadModels:E,onTestConnection:A,onSaveLocalConfig:Q,lastStatus:le,busy:te,embedded:z=!1}){const Y=i.llmProvider==="local",X=Gf(i),ee=Jf(g,Y),Te=ee.some(F=>F.value===i.model),[ce,de]=y.useState(String(i.temperature)),[pe,Qe]=y.useState(String(i.maxOutputTokens));y.useEffect(()=>{de(String(i.temperature))},[i.temperature]),y.useEffect(()=>{Qe(String(i.maxOutputTokens))},[i.maxOutputTokens]);const Je=F=>{const oe=F.replace(",",".").trim();if(!oe){de(String(i.temperature));return}const Ce=Number(oe);if(!Number.isFinite(Ce)){de(String(i.temperature));return}R({...i,temperature:Ce}),de(String(Ce))},be=F=>{const oe=F.trim();if(!oe){Qe(String(i.maxOutputTokens));return}const Ce=Number.parseInt(oe,10);if(!Number.isFinite(Ce)||Ce<=0){Qe(String(i.maxOutputTokens));return}R({...i,maxOutputTokens:Ce}),Qe(String(Ce))},Re=l.jsxs(l.Fragment,{children:[l.jsxs("div",{className:"grid-two",children:[l.jsxs("label",{children:["Provider",l.jsxs("select",{value:X,onChange:F=>{const oe=F.target.value;if(oe==="openai"){R({...i,llmProvider:"openai",baseUrl:Ac});return}if(oe==="local_qwen25"){R({...i,llmProvider:"local",model:Nl,baseUrl:Sl});return}if(oe==="local_qwen3"){R({...i,llmProvider:"local",model:ma,baseUrl:Sl});return}R({...i,llmProvider:"local",model:i.llmProvider==="local"?i.model:Nl,baseUrl:Sl})},children:[l.jsx("option",{value:"openai",children:"OpenAI (token)"}),l.jsx("option",{value:"local_qwen25",children:"Qwen2.5 14B Instruct 1M (Local LM Studio)"}),l.jsx("option",{value:"local_qwen3",children:"Qwen3 30B A3B Instruct 2507 (Local LM Studio)"}),l.jsx("option",{value:"local_custom",children:"Local custom (LM Studio / OpenAI-compatible)"})]})]}),l.jsxs("label",{children:["Model",l.jsxs("select",{value:Te?i.model:"__manual__",onChange:F=>{const oe=F.target.value;oe!=="__manual__"&&R({...i,model:oe})},children:[l.jsx("option",{value:"__manual__",children:"Manual input"}),ee.map(F=>l.jsx("option",{value:F.value,children:F.label},F.value))]})]}),l.jsxs("label",{children:["Model ID (manual / current)",l.jsx("input",{value:i.model,onChange:F=>R({...i,model:F.target.value}),placeholder:"qwen2.5-14b-instruct-1m or unsloth/qwen3-30b-a3b-instruct-2507"})]}),Y?null:l.jsxs("label",{className:"full-width",children:["OpenAI API Key",l.jsx("input",{type:"password",value:i.apiKey,onChange:F=>R({...i,apiKey:F.target.value}),placeholder:"sk-..."})]}),l.jsxs("label",{className:Y?"full-width":void 0,children:[Y?"Local server base URL":"Base URL",l.jsx("input",{value:i.baseUrl,onChange:F=>R({...i,baseUrl:F.target.value}),placeholder:Y?Sl:Ac})]}),l.jsxs("label",{children:["Temperature",l.jsx("input",{type:"number",step:"0.1",value:ce,onChange:F=>de(F.target.value),onBlur:F=>Je(F.target.value),onKeyDown:F=>{F.key==="Enter"&&Je(F.target.value)}})]}),l.jsxs("label",{children:["Max output tokens",l.jsx("input",{type:"number",value:pe,onChange:F=>Qe(F.target.value),onBlur:F=>be(F.target.value),onKeyDown:F=>{F.key==="Enter"&&be(F.target.value)}})]})]}),l.jsxs("div",{className:"button-row",children:[l.jsx("button",{type:"button",onClick:()=>Q(),children:"Save local config"}),l.jsx("button",{type:"button",onClick:()=>E(),disabled:te||f,children:f?"Loading models...":"Load model list"}),l.jsx("button",{type:"button",onClick:()=>A(),disabled:te,children:te?"Checking...":"Test connection"})]})]});return z?l.jsxs("section",{className:"embedded-panel-section",children:[l.jsxs("div",{className:"embedded-panel-section-header",children:[l.jsxs("div",{children:[l.jsx("h4",{children:"LLM Connector"}),l.jsx("p",{children:"Switch between OpenAI cloud and local OpenAI-compatible server."})]}),l.jsx("span",{className:"status-chip",children:le||"Status: not checked"})]}),Re]}):l.jsx(Pl,{title:"LLM Connector",subtitle:"Switch between OpenAI cloud and local OpenAI-compatible server.",actions:l.jsx("span",{className:"status-chip",children:le||"Status: not checked"}),children:Re})}function Xf({value:i,onChange:g,presets:f,selectedPresetId:R,onSelectPreset:E,onLoadPreset:A,onSavePreset:Q,onResetDefaults:le,onDiffPrevious:te,presetName:z,onPresetNameChange:Y,diffSummary:X,embedded:ee=!1}){const Te=l.jsxs(l.Fragment,{children:[l.jsxs("div",{className:"prompt-manager-grid",children:[l.jsxs("label",{children:["Системный prompt",l.jsx("textarea",{value:i.systemPrompt,onChange:ce=>g({...i,systemPrompt:ce.target.value}),rows:6})]}),l.jsxs("label",{children:["Developer / Instruction prompt",l.jsx("textarea",{value:i.developerPrompt,onChange:ce=>g({...i,developerPrompt:ce.target.value}),rows:6})]}),l.jsxs("label",{children:["Domain prompt",l.jsx("textarea",{value:i.domainPrompt,onChange:ce=>g({...i,domainPrompt:ce.target.value}),rows:6})]}),l.jsxs("label",{children:["Schema notes",l.jsx("textarea",{value:i.schemaNotes,onChange:ce=>g({...i,schemaNotes:ce.target.value}),rows:6})]}),l.jsxs("label",{className:"full-width",children:["Few-shot examples",l.jsx("textarea",{value:i.fewShotExamples,onChange:ce=>g({...i,fewShotExamples:ce.target.value}),rows:8})]})]}),l.jsxs("div",{className:"button-row",children:[l.jsxs("select",{value:R,onChange:ce=>E(ce.target.value),children:[l.jsx("option",{value:"",children:"Выберите preset..."}),f.map(ce=>l.jsx("option",{value:ce.id,children:ce.name},ce.id))]}),l.jsx("button",{type:"button",onClick:()=>A(),children:"Загрузить preset"}),l.jsx("input",{value:z,onChange:ce=>Y(ce.target.value),placeholder:"Имя для сохранения"}),l.jsx("button",{type:"button",onClick:()=>Q(),children:"Сохранить preset"}),l.jsx("button",{type:"button",onClick:()=>te(),children:"Diff с предыдущим"}),l.jsx("button",{type:"button",onClick:()=>le(),children:"Сбросить к default"})]}),X?l.jsx("p",{className:"diff-summary",children:X}):null]});return ee?l.jsxs("section",{className:"embedded-panel-section",children:[l.jsx("div",{className:"embedded-panel-section-header",children:l.jsxs("div",{children:[l.jsx("h4",{children:"Prompt Manager"}),l.jsx("p",{children:"Системный, developer и domain уровни управляются отдельно."})]})}),Te]}):l.jsx(Pl,{title:"Prompt Manager",subtitle:"Системный, developer и domain уровни управляются отдельно.",children:Te})}const sa={fromLocal:"",toLocal:"",target:"all",mode:"all",useMock:"any",promptContains:"",limit:120},wl="needs_dialog_policy_fix",_t="__all__",El="__live__:",Ic="ndc_autoruns_ui_config_v1",Dc="ndc-autoruns-save",oa=["Анализ запроса","Получение данных","Подготовка ответа"];function Zf(i,g){const f=i.trim();if(!f)return"";if(!g)return f;const R=f.toLowerCase(),E=g.anchor_text.trim(),A=E.toLowerCase();return A&&R.includes(A)?f:`По выбранному объекту "${E}": ${f}`}const da=[{id:"general",label:"Общий контур",domain:"",defaultPrompt:"Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл."}];function em(i=da){return i.reduce((g,f)=>(g[f.id]=f.defaultPrompt,g),{})}const Oc={mode:"codex_creative",count:24,personalityId:"general",personalityPrompts:em(),persistToEvalCases:!0,generatedBy:"manual_reviewer"};function la(i){const g=String(i??"").trim();return/^\d{4}-\d{2}-\d{2}$/.test(g)?g:""}function zc(i){const g=typeof i=="number"&&Number.isFinite(i)?Math.trunc(i):160;return Math.max(110,Math.min(520,g))}function tm(i){const g=i.getFullYear(),f=String(i.getMonth()+1).padStart(2,"0"),R=String(i.getDate()).padStart(2,"0"),E=String(i.getHours()).padStart(2,"0"),A=String(i.getMinutes()).padStart(2,"0");return`${g}-${f}-${R}T${E}:${A}`}function $c(){const i=new Date;return i.setDate(i.getDate()-14),tm(i)}function kl(i){if(!i.trim())return;const g=Date.parse(i);if(Number.isFinite(g))return new Date(g).toISOString()}function tn(i){if(!i)return"нет данных";const g=Date.parse(i);return Number.isFinite(g)?new Date(g).toLocaleString("ru-RU"):i}function ia(i){return i==="saved_user_sessions"?"Пользовательские сессии":i}function nm(i){const g=i[i.length-1];return`Ручная сессия ${tn(g?.created_at??new Date().toISOString())}`}function rm(i,g){return g<=0?0:Math.max(0,Math.min(100,Number((i/g*100).toFixed(1))))}function jl(i){return typeof i!="number"?"нет данных":`${i.toFixed(1)}%`}function sm(i){return i==="assistant_stage1"?"assistant/s1":i==="assistant_stage2"?"assistant/s2":i==="assistant_p0"?"assistant/p0":i}function Fc(i){return i==="up"?"Рост":i==="down"?"Регресс":"Без изменений"}function aa(i){const g=Math.max(1,Math.min(5,Math.round(i)));return`${"●".repeat(g)}${"○".repeat(5-g)}`}function Uc(i){return i.length===0?l.jsx("p",{className:"muted",children:"Покрытие доменов пока не сформировано."}):l.jsx("div",{className:"autoruns-coverage-list",children:i.map(g=>{const f=rm(g.closed_cases,g.total_cases);return l.jsxs("div",{className:"autoruns-coverage-item",children:[l.jsxs("div",{className:"autoruns-coverage-head",children:[l.jsx("strong",{children:g.domain}),l.jsxs("span",{children:[g.closed_cases,"/",g.total_cases," (",f,"%)"]})]}),l.jsx("div",{className:"autoruns-coverage-bar",children:l.jsx("div",{style:{width:`${f}%`}})})]},g.domain)})})}function Cl(i){return`${El}${i}`}function Ms(i){return i.startsWith(El)}function Bc(i){return i.startsWith(El)?i.slice(El.length):""}function Jc(i){const g=i.report_summary?.run_timestamp??i.created_at,f=Math.max(0,i.total_cases-i.completed_cases);return{run_id:Cl(i.job_id),eval_target:i.eval_target,run_timestamp:g,mode:"single-pass-strict",llm_provider:null,model:null,use_mock:null,analysis_date:i.report_summary?.analysis_date??i.analysis_date??null,prompt_version:null,schema_version:null,suite_id:i.case_set_file,cases_total:i.total_cases,requests_total:null,report_path:`async_job:${i.job_id}`,score_index:i.report_summary?.score_index??null,blocking_failures:0,quality_failures:0,closed_cases:i.completed_cases,open_cases:f,domain_coverage:[{domain:"runtime",total_cases:i.total_cases,closed_cases:i.completed_cases}]}}function yo(i,g){const f=Jc(i),R=i.cases.map(Y=>({case_id:Y.case_id,domain:null,query_class:null,status:Y.status==="completed"?"closed":Y.status==="failed"?"open":"unknown",score_index:null,trace_id:null,reply_type:null,session_id:`${i.run_id}-${Y.case_id}`,dialog_available:Y.messages.length>0,commented_count:0,latest_annotation_at:null,avg_rating:null,checks:null,metric_subscores:null})),A=g!==_t&&R.some(Y=>Y.case_id===g)?g:R.length>0?_t:"",Q={ok:!0,run:f,coverage:{closed_cases:i.completed_cases,open_cases:Math.max(0,i.total_cases-i.completed_cases),domain_coverage:[{domain:"runtime",total_cases:i.total_cases,closed_cases:i.completed_cases}]},cases:R,annotations_summary:{total:0},report:i.report_summary?{run_id:i.report_summary.run_id,run_timestamp:i.report_summary.run_timestamp,score_index:i.report_summary.score_index,cases_total:i.report_summary.cases_total,analysis_date:i.report_summary.analysis_date??i.analysis_date??null}:{}},le=[];let te=0;if(A===_t)for(const Y of i.cases)for(let X=0;XX.case_id===A)??null;for(let X=0;X<(Y?.messages.length??0);X+=1){const ee=Y?.messages[X];ee&&le.push({...ee,message_index:X,case_id:A,case_message_index:X,commented:!1,annotation:null})}}const z={ok:!0,run_id:f.run_id,case_id:A,source:"assistant_session",session_id:A===_t?`${i.run_id}::__all__`:`${i.run_id}-${A}`,messages:le,decomposition:[],assistant_mode:{status:i.status,completed_cases:i.completed_cases,total_cases:i.total_cases},annotations:[]};return{detail:Q,dialog:z,caseId:A}}function om({commented:i}){const g=i?"comment-icon-svg commented":"comment-icon-svg";return l.jsx("svg",{className:g,viewBox:"0 0 24 24","aria-hidden":"true",focusable:"false",children:l.jsx("path",{d:"M5 6.5h14v9H11.5l-4.5 3v-3H5z"})})}function Hc({resolved:i}){return l.jsxs("svg",{className:i?"resolve-icon-svg resolved":"resolve-icon-svg",viewBox:"0 0 16 16","aria-hidden":"true",focusable:"false",children:[l.jsx("circle",{cx:"8",cy:"8",r:"6.2"}),i?l.jsx("path",{d:"M5.1 8.2 7.2 10.3 11 6.5"}):null]})}function Qc(){return l.jsxs("svg",{className:"autoruns-copy-icon-svg",viewBox:"0 0 24 24","aria-hidden":"true",focusable:"false",children:[l.jsx("rect",{x:"9",y:"9",width:"11",height:"11",rx:"2.2"}),l.jsx("path",{d:"M15 7V5.8a1.8 1.8 0 0 0-1.8-1.8H5.8A1.8 1.8 0 0 0 4 5.8v7.4A1.8 1.8 0 0 0 5.8 15H7"})]})}function lm({connection:i,modelOptions:g,modelsBusy:f,connectionStatus:R,connectionBusy:E,onConnectionChange:A,onReloadModels:Q,onSaveLocalConfig:le,onTestConnection:te,prompts:z,onPromptsChange:Y,promptPresets:X,selectedPresetId:ee,onSelectPreset:Te,onLoadPreset:ce,onSavePreset:de,onResetDefaults:pe,onDiffPrevious:Qe,presetName:Je,onPresetNameChange:be,diffSummary:Re,assistantPromptVersion:F,decompositionPromptVersion:oe,showSettingsMode:Ce,showAutoRunsMode:$e,showAssistantMode:dt,showProgressMode:st,showCommentsMode:Dt,onLog:ot}){const[H,Me]=y.useState({...sa,fromLocal:$c()}),[We,ne]=y.useState(""),[Z,M]=y.useState(null),[U,L]=y.useState(null),[v,w]=y.useState(null),[re,ie]=y.useState([]),[ae,he]=y.useState("all"),[xe,_e]=y.useState(!1),[we,lt]=y.useState(null),[qt,Xn]=y.useState([]),[wn,nn]=y.useState(""),[Ee,Ot]=y.useState(""),[et,ft]=y.useState(""),[St,rn]=y.useState(da),[W,it]=y.useState(Oc),[Zn,In]=y.useState([]),[Dn,kn]=y.useState(""),[mt,zt]=y.useState([]),[qe,sn]=y.useState(null),[on,Zr]=y.useState(null),[Nr,Er]=y.useState(!1),[es,ln]=y.useState(!1),[an,un]=y.useState(!1),[cn,On]=y.useState(!1),[me,dn]=y.useState(!1),[er,Pr]=y.useState(!1),[Tr,Rr]=y.useState(!1),[jn,tr]=y.useState(!1),[Mr,Cn]=y.useState(""),[nr,Oe]=y.useState(""),[k,q]=y.useState(""),[D,ke]=y.useState([]),[Ke,Lr]=y.useState([]),[Ls,As]=y.useState(""),[fn,ts]=y.useState(null),[ns,Tl]=y.useState(!1),[Is,Ds]=y.useState(!1),[xo,rr]=y.useState(""),[Rl,zn]=y.useState(""),[Fe,sr]=y.useState(String(sa.limit)),[Os,$n]=y.useState(String(Oc.count)),[or,_o]=y.useState(160),[ge,wt]=y.useState({open:!1,caseId:"",caseMessageIndex:-1,messageIndex:-1,rating:3,comment:"",manualCaseDecision:wl,annotationAuthor:"manual_reviewer",saving:!1,error:""}),[ue,mn]=y.useState({open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:"manual_reviewer",saving:!1,error:""}),[Ue,Fn]=y.useState({open:!1,title:"",saving:!1,error:""}),[$t,Ar]=y.useState({open:!1,generationId:"",questionIndex:-1,questionText:"",saving:!1,error:""}),[Et,Un]=y.useState({open:!1,generationId:"",title:"",saving:!1,error:""}),Bn=y.useRef(!1),Hn=y.useRef(null),Kt=W.mode==="saved_user_sessions",rs=y.useMemo(()=>St.find(a=>a.id===W.personalityId)??St[0]??da[0],[W.personalityId,St]),pt=y.useMemo(()=>Zn.filter(a=>a.mode===W.mode),[Zn,W.mode]),kt=y.useMemo(()=>pt.find(a=>a.generation_id===Dn)??pt[0]??null,[Dn,pt]),pn=y.useMemo(()=>xe?re.filter(a=>!a.resolved):re,[re,xe]),Ne=pn.find(a=>a.annotation_id===wn)??null,So=v?.messages.find(a=>a.message_index===ge.messageIndex)??null,zs=y.useMemo(()=>{if(!v||ge.messageIndex<0)return null;for(let a=ge.messageIndex-1;a>=0;a-=1){const c=v.messages[a];if(c?.role==="user")return c}return null},[ge.messageIndex,v]),ve=y.useMemo(()=>{const a=new Map;for(const c of Ke)c.message_id&&a.set(c.message_id,c);return a},[Ke]),$s=ue.messageIndex>=0?D[ue.messageIndex]??null:null,Fs=y.useMemo(()=>{if(ue.messageIndex<0)return null;for(let a=ue.messageIndex-1;a>=0;a-=1){const c=D[a];if(c?.role==="user")return c}return null},[ue.messageIndex,D]),Ft=y.useMemo(()=>{const a=pn.map(p=>({source:"autorun",key:`autorun:${p.annotation_id}`,updated_at:p.updated_at,rating:p.rating,autorun:p,assistant:null})),c=Ke.map(p=>({source:"assistant_live",key:`assistant:${p.annotation_id}`,updated_at:p.updated_at,rating:p.rating,autorun:null,assistant:p}));return[...a,...c].sort((p,j)=>Date.parse(j.updated_at)-Date.parse(p.updated_at))},[Ke,pn]),Us=y.useMemo(()=>{if(Ft.length===0)return null;const a=Ft.reduce((c,p)=>c+p.rating,0)/Ft.length;return Number(a.toFixed(2))},[Ft]),ss=y.useMemo(()=>{const a=[...Z?.items??[]];return qe&&a.unshift(Jc(qe)),Ee&&!a.some(c=>c.run_id===Ee)&&U?.run&&a.unshift(U.run),a},[qe,Z?.items,U?.run,Ee]),J=y.useCallback(a=>{ot?.(`[autoruns] ${a}`)},[ot]),lr=y.useCallback(async a=>{const c=String(a??"").trim();if(!c){Lr([]);return}try{const p=await Pe.loadAssistantAnnotations({session_id:c,limit:400});Lr(p.items??[])}catch(p){const j=p instanceof Error?p.message:String(p);J(`Assistant live annotations load error: ${j}`)}},[J]),hn=y.useCallback(a=>{mn(c=>c.saving&&!a?.force?c:{open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:"manual_reviewer",saving:!1,error:""})},[]),Ut=y.useCallback(a=>{Fn(c=>c.saving&&!a?.force?c:{open:!1,title:"",saving:!1,error:""})},[]),Bt=y.useCallback(a=>{Ar(c=>c.saving&&!a?.force?c:{open:!1,generationId:"",questionIndex:-1,questionText:"",saving:!1,error:""})},[]),Ht=y.useCallback(a=>{Un(c=>c.saving&&!a?.force?c:{open:!1,generationId:"",title:"",saving:!1,error:""})},[]),Nn=y.useCallback(async(a,c,p)=>{a.stopPropagation(),a.preventDefault();const j=String(c??"").trim();if(j)try{if(navigator?.clipboard?.writeText)await navigator.clipboard.writeText(j);else{const $=document.createElement("textarea");$.value=j,$.setAttribute("readonly","true"),$.style.position="fixed",$.style.opacity="0",document.body.appendChild($),$.select(),document.execCommand("copy"),document.body.removeChild($)}J(`${p} copied: ${j}`)}catch($){const Ae=$ instanceof Error?$.message:String($);Oe(`Копирование ${p}: ${Ae}`),J(`copy ${p} error: ${Ae}`)}},[J]);function Ir(){let a=0;rr(oa[0]);const c=window.setInterval(()=>{a=Math.min(a+1,oa.length-1),rr(oa[a])},650);return()=>window.clearInterval(c)}const En=y.useCallback(()=>{q(""),ke([]),Lr([]),As(""),ts(null),rr(""),zn(""),hn({force:!0}),J("Live-чат ассистента в истории автопрогонов сброшен.")},[hn,J]),Ml=y.useCallback(async()=>{const a=Zf(Ls,fn);if(!a)return;Ds(!0),zn(""),As(""),ke(p=>[...p,{message_id:`autoruns-live-${Date.now()}`,session_id:k||"pending",role:"user",text:a,reply_type:null,created_at:new Date().toISOString(),trace_id:null,debug:null}]);const c=Ir();try{const p=await Pe.sendAssistantMessage({connection:i,prompts:z,userMessage:a,sessionId:k||void 0,promptVersion:F,useMock:ns});q(p.session_id),ke(p.conversation),await lr(p.session_id),rr("Ответ готов"),J(`Live-ответ ассистента получен: trace=${p.debug.trace_id}`)}catch(p){const j=p instanceof Error?p.message:String(p);zn(j),rr("Ошибка ассистента"),J(`Live-чат ассистента: ошибка отправки сообщения: ${j}`)}finally{c(),Ds(!1)}},[Ls,fn,k,ns,F,i,lr,J,z]),wo=y.useCallback(()=>{if(!k.trim()||D.length===0){zn("Сначала получите хотя бы один ответ в живой сессии ассистента.");return}zn(""),Fn({open:!0,title:nm(D),saving:!1,error:""})},[D,k]),Dr=y.useCallback(async()=>{const a=k.trim(),c=Ue.title.trim();if(!a){Fn(p=>({...p,error:"Активная сессия ассистента не найдена."}));return}if(!c){Fn(p=>({...p,error:"Укажите название сессии."}));return}Fn(p=>({...p,saving:!0,error:""}));try{const p=[z.systemPrompt,z.developerPrompt,z.domainPrompt,z.schemaNotes,z.fewShotExamples].join("||"),j=await Pe.saveAutoRunAssistantSession({session_id:a,title:c,generated_by:W.generatedBy.trim()||void 0,context:{llm_provider:i.llmProvider,model:i.model,assistant_prompt_version:F,decomposition_prompt_version:oe,prompt_fingerprint:p}});In($=>[j.generation,...$.filter(Ae=>Ae.generation_id!==j.generation.generation_id)]),it($=>({...$,mode:"saved_user_sessions"})),kn(j.generation.generation_id),Ut({force:!0}),J(`Живая сессия сохранена в автопрогоны: ${j.generation.generation_id}`)}catch(p){const j=p instanceof Error?p.message:String(p);Fn($=>({...$,saving:!1,error:j})),J(`Assistant live save error: ${j}`)}},[Ue.title,k,F,W.generatedBy,Ut,i.llmProvider,i.model,oe,J,z.developerPrompt,z.domainPrompt,z.fewShotExamples,z.schemaNotes,z.systemPrompt]),ko=y.useCallback(a=>{const c=a.trim();if(!c){sr(String(H.limit));return}if(!/^\d+$/.test(c)){sr(String(H.limit));return}const p=Number.parseInt(c,10);if(!Number.isFinite(p)){sr(String(H.limit));return}const j=Math.max(1,Math.min(500,p));j!==H.limit&&Me($=>({...$,limit:j})),sr(String(j))},[H.limit]),Bs=y.useCallback(a=>{const c=a.trim();if(!c){$n(String(W.count));return}if(!/^\d+$/.test(c)){$n(String(W.count));return}const p=Number.parseInt(c,10);if(!Number.isFinite(p)){$n(String(W.count));return}const j=Math.max(1,Math.min(200,p));j!==W.count&&it($=>({...$,count:j})),$n(String(j))},[W.count]),Or=y.useCallback(a=>{_o(zc(a))},[]),Hs=y.useCallback(a=>{const c=a.currentTarget.offsetHeight;Number.isFinite(c)&&c>0&&Or(c)},[Or]),zr=y.useCallback(async()=>{tr(!0);try{const a=await Pe.loadAutoRunAnnotations({limit:800,manual_case_decision:ae});ie(a.items),lt(a.manual_case_decision_schema??null),Xn(a.available_manual_case_decisions??[]),nn(c=>a.items.length===0?"":a.items.some(p=>p.annotation_id===c)?c:a.items[0].annotation_id)}catch(a){J(`Annotations load error: ${a instanceof Error?a.message:String(a)}`)}finally{tr(!1)}},[ae,J]),Qt=y.useCallback(async()=>{On(!0);try{const a=await Pe.loadAutoRunAutogenHistory({limit:180});In(a.items)}catch(a){J(`Autogen history load error: ${a instanceof Error?a.message:String(a)}`)}finally{On(!1)}},[J]),ir=y.useCallback(async()=>{try{const c=(await Pe.loadAutoRunAutogenPersonalityCatalog()).items.map(p=>({id:String(p.id??"").trim(),label:String(p.label??"").trim(),domain:typeof p.domain=="string"?p.domain.trim():"",defaultPrompt:String(p.default_prompt??"").trim()})).filter(p=>p.id.length>0&&p.label.length>0);if(c.length===0)return;rn(c.map(p=>({id:p.id,label:p.label,domain:p.domain||"",defaultPrompt:p.defaultPrompt||"Генерируй реалистичные вопросы бухгалтера по выбранному профилю. Не выдумывай непокрытые возможности."})))}catch(a){J(`Autogen personality catalog load error: ${a instanceof Error?a.message:String(a)}`)}},[J]),ht=y.useCallback(async()=>{un(!0);try{const a=await Pe.loadAutoRunPostAnalysis({run_id:Ee&&!Ms(Ee)?Ee:void 0,limit_per_queue:30,annotation_limit:1500,from:kl(H.fromLocal),to:kl(H.toLocal),target:H.target,mode:H.mode,use_mock:H.useMock,prompt_contains:H.promptContains.trim()||void 0});Zr(a)}catch(a){J(`Post-analysis load error: ${a instanceof Error?a.message:String(a)}`),Zr(null)}finally{un(!1)}},[H.fromLocal,H.mode,H.promptContains,H.target,H.toLocal,H.useMock,J,Ee]),os=y.useCallback(async()=>{Er(!0),Oe("");try{if(W.mode==="saved_user_sessions")throw new Error("Пользовательские сессии сохраняются из живого чата, а не генерируются автоматически.");const a=W.personalityPrompts[W.personalityId]??"",c=[z.systemPrompt,z.developerPrompt,z.domainPrompt,z.schemaNotes,z.fewShotExamples].join(` +`).slice(0,900),p=await Pe.generateAutoRunQuestions({mode:W.mode,count:W.count,domain:rs.domain||void 0,persist_to_eval_cases:W.persistToEvalCases,generated_by:W.generatedBy.trim()||void 0,llm:{llm_provider:i.llmProvider,api_key:i.apiKey,model:i.model,base_url:i.baseUrl,temperature:i.temperature,max_output_tokens:i.maxOutputTokens},context:{llm_provider:i.llmProvider,model:i.model,assistant_prompt_version:F,decomposition_prompt_version:oe,prompt_fingerprint:c,autogen_personality_id:rs.id,autogen_personality_prompt:a.trim()||void 0}});J(`Generated ${p.generation.count} questions (${p.generation.mode}) id=${p.generation.generation_id}`+(p.generation.saved_case_set_file?` saved=${p.generation.saved_case_set_file}`:"")),kn(p.generation.generation_id),zt([...p.generation.questions??[]]),await Qt()}catch(a){const c=a instanceof Error?a.message:String(a);Oe(`Автогенерация: ${c}`),J(`Autogen generate error: ${c}`)}finally{Er(!1)}},[F,W.count,W.generatedBy,W.mode,W.personalityId,W.personalityPrompts,W.persistToEvalCases,i.apiKey,i.baseUrl,i.llmProvider,i.maxOutputTokens,i.model,i.temperature,oe,Qt,J,z.developerPrompt,z.domainPrompt,z.fewShotExamples,z.schemaNotes,z.systemPrompt,rs.domain,rs.id]),$r=y.useCallback(async(a,c)=>{if(Ms(a)){const p=Bc(a);if(qe&&qe.job_id===p){const j=yo(qe,c);Ot(a),ft(j.caseId),w(j.dialog);return}w(null);return}Rr(!0);try{const p=await Pe.loadAutoRunCaseDialog(a,c);w(p)}catch(p){const j=p instanceof Error?p.message:String(p);Oe(`Диалог кейса: ${j}`),w(null),J(`Dialog load error for ${a}/${c}: ${j}`)}finally{Rr(!1)}},[qe,J]),Pn=y.useCallback(async(a,c)=>{if(Ms(a)){const p=Bc(a);if(qe&&qe.job_id===p){const j=yo(qe,c??_t);Ot(a),ft(j.caseId),L(j.detail),w(j.dialog);return}Ot(a),ft(""),L(null),w(null);return}Pr(!0);try{const p=await Pe.loadAutoRunDetail(a);L(p);const j=(c&&(c===_t||p.cases.some($=>$.case_id===c))?c:"")||(p.cases.length>0?_t:"")||"";Ot(a),ft(j),j?await $r(a,j):w(null)}catch(p){const j=p instanceof Error?p.message:String(p);Oe(`Детализация прогона: ${j}`),L(null),w(null),J(`Run detail load error for ${a}: ${j}`)}finally{Pr(!1)}},[qe,$r,J]),Qn=y.useCallback(async a=>{dn(!0),Oe("");try{const c=await Pe.loadAutoRunsHistory({from:kl(H.fromLocal),to:kl(H.toLocal),target:H.target,mode:H.mode,use_mock:H.useMock,prompt_contains:H.promptContains.trim()||void 0,limit:H.limit});if(M(c),c.items.length===0){Ot(""),ft(""),L(null),w(null);return}const p=a?.keepSelection??!0,j=a?.preferredRunId??"",$=a?.preferredCaseId??"",Ae=p&&j&&c.items.some(at=>at.run_id===j)?j:c.items[0].run_id;await Pn(Ae,p?$:void 0),ht()}catch(c){const p=c instanceof Error?c.message:String(c);Oe(`История прогонов: ${p}`),J(`History load error: ${p}`)}finally{dn(!1)}},[H.fromLocal,H.limit,H.mode,H.promptContains,H.target,H.toLocal,H.useMock,ht,Pn,J]),Pt=y.useCallback(()=>{Hn.current!==null&&(window.clearTimeout(Hn.current),Hn.current=null)},[]),Fr=y.useCallback(async a=>{try{const c=await Pe.loadEvalRunAsyncStatus(a);sn(c.job);const p=Cl(a);if(Ee===p){const j=yo(c.job,et||_t);L(j.detail),w(j.dialog),ft(j.caseId)}if(c.job.status==="completed"){Pt(),ln(!1);const j=c.job.report_summary?.run_id??c.job.run_id;await Qn({keepSelection:!0,preferredRunId:j||Ee,preferredCaseId:_t}),await Qt(),sn(null);return}if(c.job.status==="failed"){Pt(),ln(!1),Oe(`Запуск прогонов: ${c.job.error??"неизвестная ошибка"}`),J(`Autogen async run failed: ${c.job.error??"unknown error"}`);return}Pt(),Hn.current=window.setTimeout(()=>{Fr(a)},500)}catch(c){Pt(),ln(!1);const p=c instanceof Error?c.message:String(c);Oe(`Запуск прогонов: ${p}`),J(`Autogen async status error: ${p}`)}},[Qt,Qn,J,et,Ee,Pt]),jo=y.useCallback(async()=>{Pt(),ln(!0),Oe("");try{const a=kt;if(!a)throw new Error("История автогенерации пуста. Сначала сгенерируйте пачку вопросов.");const c=mt.map(Vs=>Vs.trim()).filter(Vs=>Vs.length>0);if(c.length===0)throw new Error("Нет вопросов для запуска: список пустой после ручного редактирования.");const p=H.useMock==="true",j=la(We),$=a.mode==="saved_user_sessions",at=(await Pe.startEvalRunAsync({connection:i,prompts:z,promptVersion:F,mode:"single-pass-strict",caseSetFile:$?void 0:a.saved_case_set_file??void 0,useMock:p,evalTarget:"assistant_stage1",questions:$?void 0:c,scenarioQuestions:$?c:void 0,scenarioTitle:$?a.title??void 0:void 0,analysisDate:$?void 0:j||void 0})).job;sn(at);const dr=Cl(at.job_id),bs=yo(at,_t);Ot(dr),ft(bs.caseId),L(bs.detail),w(bs.dialog),J(`Запущен async-прогон job=${at.job_id}, run_id=${at.run_id}, вопросов=${c.length}`+(a.saved_case_set_file?`, base_case_set=${a.saved_case_set_file}`:"")+($?", replay_mode=saved_user_session_scenario":j?`, analysis_date=${j}`:", analysis_date=current_state")),Fr(at.job_id)}catch(a){const c=a instanceof Error?a.message:String(a);Oe(`Запуск прогонов: ${c}`),J(`Autogen run error: ${c}`),ln(!1)}},[We,F,i,mt,H.useMock,J,Fr,z,kt,Pt]),Tn=y.useCallback(a=>{if(a.role!=="assistant")return;const c=a.case_id??et,p=a.case_message_index??a.message_index;wt({open:!0,caseId:c,caseMessageIndex:p,messageIndex:a.message_index,rating:a.annotation?.rating??3,comment:a.annotation?.comment??"",manualCaseDecision:a.annotation?.manual_case_decision??wl,annotationAuthor:a.annotation?.annotation_author??W.generatedBy,saving:!1,error:""})},[W.generatedBy,et]),ar=y.useCallback(a=>{wt(c=>c.saving&&!a?.force?c:{open:!1,caseId:"",caseMessageIndex:-1,messageIndex:-1,rating:3,comment:"",manualCaseDecision:wl,annotationAuthor:W.generatedBy,saving:!1,error:""})},[W.generatedBy]),ls=y.useCallback(async()=>{const a=Ee,c=ge.caseId,p=ge.caseMessageIndex;if(!(!a||!c||p<0)){if(Ms(a)){wt(j=>({...j,error:"Комментарий можно сохранить после завершения прогона."}));return}if(!ge.comment.trim()){wt(j=>({...j,error:"Добавьте комментарий."}));return}wt(j=>({...j,saving:!0,error:""}));try{await Pe.saveAutoRunAnnotation({run_id:a,case_id:c,message_index:p,rating:ge.rating,comment:ge.comment.trim(),manual_case_decision:ge.manualCaseDecision,annotation_author:ge.annotationAuthor.trim()||void 0}),ar({force:!0}),Promise.all([Pn(a,et),zr(),ht()]).catch(j=>{const $=j instanceof Error?j.message:String(j);Oe(`Обновление после комментария: ${$}`),J(`Comment refresh error: ${$}`)})}catch(j){wt($=>({...$,saving:!1,error:j instanceof Error?j.message:String(j)}))}}},[ar,ge.annotationAuthor,ge.caseId,ge.caseMessageIndex,ge.comment,ge.manualCaseDecision,ge.rating,zr,ht,Pn,J,et,Ee]),Co=y.useCallback(a=>a.role==="assistant",[]),is=y.useCallback(a=>a.role==="assistant"&&ve.has(a.message_id),[ve]),as=y.useCallback((a,c)=>{if(a.role!=="assistant")return;const p=k.trim(),j=String(a.session_id??"").trim();if(!(p||j)){zn("Сначала получите ответ ассистента в активной сессии.");return}!p&&j&&q(j);const Ae=ve.get(a.message_id)??null;zn(""),mn({open:!0,messageIndex:c,rating:Ae?.rating??3,comment:Ae?.comment??"",annotationAuthor:Ae?.annotation_author??"manual_reviewer",saving:!1,error:""})},[ve,k]),No=y.useCallback(async()=>{if(ue.messageIndex<0)return;if(!ue.comment.trim()){mn(p=>({...p,error:"Добавьте комментарий."}));return}const a=D[ue.messageIndex]??null,c=k.trim()||(a?.role==="assistant"?String(a.session_id??"").trim():"");if(!c){mn(p=>({...p,error:"Сессия ассистента не найдена."}));return}mn(p=>({...p,saving:!0,error:""}));try{const p=await Pe.saveAssistantAnnotation({session_id:c,message_index:ue.messageIndex,rating:ue.rating,comment:ue.comment.trim(),annotation_author:ue.annotationAuthor.trim()||void 0});Lr(j=>{const $=[...j],Ae=$.findIndex(at=>at.annotation_id===p.annotation.annotation_id);return Ae>=0?$[Ae]=p.annotation:$.unshift(p.annotation),$.sort((at,dr)=>Date.parse(dr.updated_at)-Date.parse(at.updated_at))}),hn({force:!0})}catch(p){const j=p instanceof Error?p.message:String(p);mn($=>({...$,saving:!1,error:j}))}},[ue.annotationAuthor,ue.comment,ue.messageIndex,ue.rating,D,k,hn]),jt=y.useCallback(a=>{if(!kt||kt.mode!=="saved_user_sessions")return;const c=mt[a]??"";Ar({open:!0,generationId:kt.generation_id,questionIndex:a,questionText:c,saving:!1,error:""})},[mt,kt]),ur=y.useCallback(async()=>{const a=$t.generationId,c=$t.questionIndex;if(!a||c<0)return;const p=mt.filter((j,$)=>$!==c);if(p.length===0){Ar(j=>({...j,error:"Нельзя удалить последний вопрос из сохраненной сессии."}));return}Ar(j=>({...j,saving:!0,error:""}));try{const j=await Pe.updateAutoRunAutogenQuestions({generation_id:a,questions:p});In($=>$.map(Ae=>Ae.generation_id===a?j.generation:Ae)),zt(j.generation.questions),Bt({force:!0}),J(`Обновлена сохраненная сессия: ${a}`)}catch(j){const $=j instanceof Error?j.message:String(j);Ar(Ae=>({...Ae,saving:!1,error:$})),J(`Saved session question delete error: ${$}`)}},[Bt,mt,J,$t.generationId,$t.questionIndex]),Qs=y.useCallback(a=>{Un({open:!0,generationId:a.generation_id,title:a.title??`${ia(a.mode)} ${tn(a.created_at)}`,saving:!1,error:""})},[]),Ur=y.useCallback(async()=>{const a=Et.generationId.trim();if(a){Un(c=>({...c,saving:!0,error:""}));try{const c=await Pe.deleteAutoRunAutogenHistoryRecord(a);In(p=>p.filter(j=>j.generation_id!==c.generation_id)),Ht({force:!0}),J(`Удален набор автопрогона: ${c.generation_id}`+(c.deleted_files.length>0?`, files=${c.deleted_files.length}`:""))}catch(c){const p=c instanceof Error?c.message:String(c);Un(j=>({...j,saving:!1,error:p})),J(`Autogen record delete error: ${p}`)}}},[Et.generationId,Ht,J]),Eo=y.useCallback(a=>{ie(c=>c.map(p=>p.annotation_id===a.annotation_id?{...p,...a}:p)),w(c=>c&&{...c,annotations:c.annotations.map(p=>p.annotation_id===a.annotation_id?a:p),messages:c.messages.map(p=>!p.annotation||p.annotation.annotation_id!==a.annotation_id?p:{...p,commented:!0,annotation:a})})},[]),us=y.useCallback(async(a,c)=>{if(a.annotation_id){if(Ms(a.run_id)){Oe("Статус выполнения можно менять только для завершённых прогонов.");return}Cn(a.annotation_id);try{const p=await Pe.updateAutoRunAnnotation({annotation_id:a.annotation_id,resolved:c,resolved_by:W.generatedBy||void 0});Eo(p.annotation),ht()}catch(p){const j=p instanceof Error?p.message:String(p);Oe(`Смена статуса кейса: ${j}`),J(`Annotation resolve toggle error: ${j}`)}finally{Cn("")}}},[Eo,W.generatedBy,ht,J]),cs=y.useCallback(async a=>{nn(a.annotation_id),await Pn(a.run_id,a.case_id),Z?.items.some(c=>c.run_id===a.run_id)||Oe("Комментарий относится к прогону вне текущего фильтра. Детали загружены напрямую.")},[Z?.items,Pn]);y.useEffect(()=>{Bn.current||(Bn.current=!0,Qn({keepSelection:!1}),Qt(),ir(),ht())},[Qt,ir,Qn,ht]),y.useEffect(()=>{Bn.current&&zr()},[ae,zr]),y.useEffect(()=>{nn(a=>pn.length===0?"":pn.some(c=>c.annotation_id===a)?a:pn[0].annotation_id)},[pn]),y.useEffect(()=>{kn(a=>pt.length===0?"":a&&pt.some(c=>c.generation_id===a)?a:pt[0].generation_id)},[pt]),y.useEffect(()=>{if(!kt){zt([]);return}zt([...kt.questions])},[kt]),y.useEffect(()=>{sr(String(H.limit))},[H.limit]),y.useEffect(()=>{$n(String(W.count))},[W.count]),y.useEffect(()=>{if(!k.trim()){Lr([]);return}lr(k)},[k,lr]),y.useEffect(()=>{if(!qe)return;const a=Cl(qe.job_id);if(Ee!==a)return;const c=yo(qe,et||_t);L(c.detail),w(c.dialog),ft(c.caseId)},[qe,et,Ee]),y.useEffect(()=>()=>{Pt()},[Pt]),y.useEffect(()=>{St.length!==0&&it(a=>{let c=!1;const p={...a.personalityPrompts};for(const $ of St)(typeof p[$.id]!="string"||p[$.id].trim().length===0)&&(p[$.id]=$.defaultPrompt,c=!0);let j=a.personalityId;return St.some($=>$.id===a.personalityId)||(j=St[0].id,c=!0),c?{...a,personalityId:j,personalityPrompts:p}:a})},[St]),y.useEffect(()=>{const a=localStorage.getItem(Ic);if(a)try{const c=JSON.parse(a);if(c.filters){const p=c.filters;Me(j=>({...j,...p,limit:typeof p.limit=="number"?Math.max(1,Math.min(500,p.limit)):j.limit}))}typeof c.analysisDate=="string"&&ne(la(c.analysisDate)),typeof c.autogenPersonalityPromptHeight=="number"&&_o(zc(c.autogenPersonalityPromptHeight)),c.autoGenSettings&&it(p=>{const j={...p.personalityPrompts},$=c.autoGenSettings?.personalityPrompts??{};for(const[at,dr]of Object.entries($))typeof dr=="string"&&at.trim().length>0&&(j[at.trim()]=dr);const Ae=typeof c.autoGenSettings?.personalityId=="string"&&c.autoGenSettings.personalityId.trim().length>0?c.autoGenSettings.personalityId.trim():p.personalityId;return{...p,mode:c.autoGenSettings?.mode==="codex_creative"||c.autoGenSettings?.mode==="qwen_seed"||c.autoGenSettings?.mode==="saved_user_sessions"?c.autoGenSettings.mode:p.mode,count:typeof c.autoGenSettings?.count=="number"?Math.max(1,Math.min(200,c.autoGenSettings.count)):p.count,personalityId:Ae,personalityPrompts:j,persistToEvalCases:typeof c.autoGenSettings?.persistToEvalCases=="boolean"?c.autoGenSettings.persistToEvalCases:p.persistToEvalCases,generatedBy:typeof c.autoGenSettings?.generatedBy=="string"?c.autoGenSettings.generatedBy:p.generatedBy}}),(c.annotationDecisionFilter==="all"||typeof c.annotationDecisionFilter=="string"&&c.annotationDecisionFilter.length>0)&&he(c.annotationDecisionFilter),typeof c.hideResolvedAnnotations=="boolean"&&_e(c.hideResolvedAnnotations)}catch{}},[]);const cr=y.useCallback(()=>{const a={filters:H,analysisDate:We,autogenPersonalityPromptHeight:or,autoGenSettings:{mode:W.mode,count:W.count,personalityId:W.personalityId,personalityPrompts:W.personalityPrompts,persistToEvalCases:W.persistToEvalCases,generatedBy:W.generatedBy},annotationDecisionFilter:ae,hideResolvedAnnotations:xe};localStorage.setItem(Ic,JSON.stringify(a))},[We,ae,W,or,H,xe]);return y.useEffect(()=>{const a=()=>{cr(),J("Сохранены настройки панели автопрогонов.")};return window.addEventListener(Dc,a),()=>{window.removeEventListener(Dc,a)}},[J,cr]),l.jsxs(Pl,{className:"autoruns-frame",title:"",hideHeader:!0,children:[l.jsxs("div",{className:"autoruns-columns",children:[Ce?l.jsxs("section",{className:"autoruns-col autoruns-settings-col",children:[l.jsx("div",{className:"autoruns-col-header",children:l.jsx("h3",{children:"Настройки"})}),l.jsxs("div",{className:"autoruns-settings-stack",children:[l.jsx(Yf,{embedded:!0,value:i,modelOptions:g,modelsBusy:f,onChange:A,onReloadModels:Q,onSaveLocalConfig:le,onTestConnection:te,lastStatus:R,busy:E}),l.jsx(Xf,{embedded:!0,value:z,onChange:Y,presets:X,selectedPresetId:ee,onSelectPreset:Te,onLoadPreset:ce,onSavePreset:de,onResetDefaults:pe,onDiffPrevious:Qe,presetName:Je,onPresetNameChange:be,diffSummary:Re})]})]}):null,$e?l.jsxs("section",{className:"autoruns-col",children:[l.jsx("div",{className:"autoruns-col-header",children:l.jsx("h3",{children:"Автопрогоны"})}),l.jsx("h4",{children:"Настройки выборки"}),l.jsxs("div",{className:"autoruns-form-grid",children:[l.jsxs("label",{children:["Дата с",l.jsx("input",{type:"datetime-local",value:H.fromLocal,onChange:a=>Me(c=>({...c,fromLocal:a.target.value}))})]}),l.jsxs("label",{children:["Дата по",l.jsx("input",{type:"datetime-local",value:H.toLocal,onChange:a=>Me(c=>({...c,toLocal:a.target.value}))})]}),l.jsxs("label",{children:["Целевой контур",l.jsxs("select",{value:H.target,onChange:a=>Me(c=>({...c,target:a.target.value})),children:[l.jsx("option",{value:"all",children:"все"}),(Z?.available.targets??[]).map(a=>l.jsx("option",{value:a,children:a},a))]})]}),l.jsxs("label",{children:["Режим",l.jsxs("select",{value:H.mode,onChange:a=>Me(c=>({...c,mode:a.target.value})),children:[l.jsx("option",{value:"all",children:"все"}),(Z?.available.modes??[]).map(a=>l.jsx("option",{value:a,children:a},a))]})]}),l.jsxs("label",{children:["Использовать mock",l.jsxs("select",{value:H.useMock,onChange:a=>Me(c=>({...c,useMock:a.target.value})),children:[l.jsx("option",{value:"any",children:"любой"}),l.jsx("option",{value:"true",children:"да"}),l.jsx("option",{value:"false",children:"нет"})]})]}),l.jsxs("label",{children:["Лимит",l.jsx("input",{type:"number",min:1,max:500,value:Fe,onChange:a=>{const c=a.target.value;(c===""||/^\d+$/.test(c))&&sr(c)},onBlur:a=>ko(a.target.value),onKeyDown:a=>{a.key==="Enter"&&ko(a.target.value)}})]}),l.jsxs("label",{className:"full-width",children:["Версия промпта содержит",l.jsx("input",{value:H.promptContains,onChange:a=>Me(c=>({...c,promptContains:a.target.value})),placeholder:"normalizer_v2_0_2 / address_query_runtime_v1",list:"autoruns-prompt-versions"})]})]}),l.jsx("datalist",{id:"autoruns-prompt-versions",children:(Z?.available.prompt_versions??[]).map(a=>l.jsx("option",{value:a},a))}),l.jsxs("div",{className:"button-row",children:[l.jsx("button",{type:"button",disabled:me,onClick:()=>{Qn({keepSelection:!1})},children:me?"Обновляю...":"Применить"}),l.jsx("button",{type:"button",className:"tab",onClick:()=>{Me({...sa,fromLocal:$c()}),Oe("")},children:"Сбросить фильтры"})]}),l.jsx("h4",{children:"Контур генерации"}),l.jsxs("div",{className:"autoruns-meta-list",children:[l.jsxs("div",{children:[l.jsx("span",{children:"Провайдер:"}),l.jsx("strong",{children:i.llmProvider})]}),l.jsxs("div",{children:[l.jsx("span",{children:"Модель:"}),l.jsx("strong",{children:i.model||"нет данных"})]}),l.jsxs("div",{children:[l.jsx("span",{children:"Промпт ассистента:"}),l.jsx("strong",{children:F})]}),l.jsxs("div",{children:[l.jsx("span",{children:"Промпт декомпозиции:"}),l.jsx("strong",{children:oe})]})]}),l.jsx("h4",{children:"Автопрогоны"}),l.jsxs("div",{className:"autoruns-form-grid",children:[l.jsxs("label",{children:["Режимы",l.jsxs("select",{value:W.mode,onChange:a=>it(c=>({...c,mode:a.target.value})),children:[l.jsx("option",{value:"codex_creative",children:"codex_creative"}),l.jsx("option",{value:"qwen_seed",children:"qwen_seed"}),l.jsx("option",{value:"saved_user_sessions",children:"Пользовательские сессии"})]})]}),Kt?null:l.jsxs(l.Fragment,{children:[l.jsxs("label",{children:["Кол-во",l.jsx("input",{type:"number",min:1,max:200,value:Os,onChange:a=>{const c=a.target.value;(c===""||/^\d+$/.test(c))&&$n(c)},onBlur:a=>Bs(a.target.value),onKeyDown:a=>{a.key==="Enter"&&Bs(a.target.value)}})]}),l.jsxs("label",{children:["Личность автогенерации",l.jsx("select",{value:W.personalityId,onChange:a=>it(c=>({...c,personalityId:a.target.value})),children:St.map(a=>l.jsx("option",{value:a.id,children:a.label},a.id))})]}),l.jsxs("label",{children:["Кто генерирует",l.jsx("input",{value:W.generatedBy,onChange:a=>it(c=>({...c,generatedBy:a.target.value})),placeholder:"manual_reviewer"})]}),l.jsxs("label",{className:"full-width",children:["Промпт личности",l.jsx("textarea",{className:"autoruns-personality-prompt",value:W.personalityPrompts[W.personalityId]??"",onChange:a=>it(c=>({...c,personalityPrompts:{...c.personalityPrompts,[c.personalityId]:a.target.value}})),placeholder:"Текст промпта для выбранной личности автогенерации",style:{height:`${or}px`},onMouseUp:Hs,onTouchEnd:Hs})]}),l.jsxs("label",{className:"checkbox-row",children:[l.jsx("input",{type:"checkbox",checked:W.persistToEvalCases,onChange:a=>it(c=>({...c,persistToEvalCases:a.target.checked}))}),"Сохранять кейс-сет в `eval_cases`"]})]})]}),Kt?null:l.jsxs("div",{className:"autoruns-form-grid",children:[l.jsxs("label",{children:["Дата анализа (срез)",l.jsx("input",{type:"date",value:We,onChange:a=>ne(la(a.target.value))})]}),l.jsx("div",{className:"button-row",children:l.jsx("button",{type:"button",className:"tab",disabled:!We,onClick:()=>ne(""),children:"Сбросить дату среза"})})]}),l.jsxs("div",{className:"button-row",children:[Kt?null:l.jsxs(l.Fragment,{children:[l.jsx("button",{type:"button",disabled:Nr,onClick:()=>{os()},children:Nr?"Генерирую...":"Сгенерировать пачку"}),l.jsx("button",{type:"button",className:"tab",disabled:cn,onClick:()=>{Qt()},children:cn?"Обновляю...":"Обновить историю"})]}),l.jsx("button",{type:"button",className:"autoruns-run-launch-btn",disabled:es||mt.length===0||!kt,onClick:()=>{jo()},children:es?"Запускаю...":"Запустить прогон"})]}),l.jsx("div",{className:"autoruns-form-grid",children:l.jsxs("label",{className:"full-width",children:[Kt?"Сохраненная сессия":"Кейс-сет для запуска",l.jsxs("select",{value:Dn,onChange:a=>kn(a.target.value),disabled:pt.length===0,children:[pt.length===0?l.jsx("option",{value:"",children:Kt?"нет сохраненных сессий":"нет генераций"}):null,pt.map(a=>l.jsxs("option",{value:a.generation_id,children:[tn(a.created_at)," | ",a.title??ia(a.mode)," | ",a.count]},a.generation_id))]})]})}),l.jsxs("div",{className:"autoruns-generated-questions",children:[l.jsxs("div",{className:"autoruns-generated-questions-head",children:[l.jsxs("strong",{children:["Вопросы к запуску: ",mt.length]}),l.jsx("button",{type:"button",className:"tab",onClick:()=>zt([...kt?.questions??[]]),disabled:!kt,children:"Восстановить"})]}),mt.length===0?l.jsx("p",{className:"muted",children:Kt?"Список вопросов пуст. Сначала сохраните живую пользовательскую сессию.":"Список вопросов пуст. Сгенерируйте пачку или восстановите из выбранной генерации."}):l.jsx("div",{className:"autoruns-generated-questions-list",children:mt.map((a,c)=>l.jsxs("div",{className:"autoruns-generated-question-item",children:[l.jsxs("span",{children:[c+1,". ",a]}),l.jsx("button",{type:"button",className:"autoruns-remove-question-btn",onClick:()=>{if(Kt){jt(c);return}zt(p=>p.filter((j,$)=>$!==c))},title:"Удалить вопрос из запуска","aria-label":"Удалить вопрос из запуска",children:"×"})]},`${c}-${a.slice(0,24)}`))})]}),l.jsx("p",{className:"muted",children:Kt?"Запуск воспроизводит сохраненную пользовательскую сессию как один последовательный multi-turn сценарий assistant_stage1.":"Запуск выполняет `assistant_stage1` eval по выбранному кейс-сету."}),l.jsxs("div",{className:"autoruns-autogen-list",children:[cn?l.jsx("p",{className:"muted",children:Kt?"Загружаю сохраненные пользовательские сессии...":"Загружаю историю автогенераций..."}):null,!cn&&pt.length===0?l.jsx("p",{className:"muted",children:Kt?"Сохраненные пользовательские сессии пока пусты.":"История автогенераций пока пустая."}):null,pt.slice(0,30).map(a=>l.jsxs("article",{className:Dn===a.generation_id?"autoruns-autogen-item selected":"autoruns-autogen-item",onClick:()=>kn(a.generation_id),children:[l.jsxs("header",{children:[l.jsx("strong",{children:a.title??tn(a.created_at)}),l.jsxs("div",{className:"autoruns-autogen-card-actions",children:[l.jsx("span",{children:tn(a.created_at)}),l.jsx("button",{type:"button",className:"autoruns-autogen-delete-btn",onClick:c=>{c.preventDefault(),c.stopPropagation(),Qs(a)},title:"Удалить сохраненный набор","aria-label":`Удалить набор ${a.generation_id}`,children:"×"})]})]}),l.jsxs("div",{className:"autoruns-run-meta autoruns-run-id-row",children:[l.jsx("span",{children:a.generation_id}),l.jsx("span",{role:"button",tabIndex:0,className:"autoruns-copy-run-id-btn",onClick:c=>{Nn(c,a.generation_id,"set id")},onKeyDown:c=>{(c.key==="Enter"||c.key===" ")&&(c.preventDefault(),Nn(c,a.generation_id,"set id"))},title:"Скопировать id набора","aria-label":`Скопировать id набора ${a.generation_id}`,children:l.jsx(Qc,{})})]}),l.jsxs("div",{className:"autoruns-run-meta",children:["режим=",ia(a.mode)," | count=",a.count]}),a.domain||a.generated_by?l.jsxs("div",{className:"autoruns-run-meta",children:[a.domain?`домен=${a.domain}`:"домен=общий",a.generated_by?` | автор=${a.generated_by}`:""]}):null,a.saved_case_set_file?l.jsxs("div",{className:"autoruns-run-meta",children:["кейс-сет=",a.saved_case_set_file]}):null,(a.questions??[]).length>0?l.jsx("p",{children:a.questions[0]}):null]},a.generation_id))]}),l.jsxs("details",{className:"autoruns-prompt-details",children:[l.jsx("summary",{children:"Копия активного промпта (только чтение)"}),l.jsxs("label",{children:["Системный",l.jsx("textarea",{readOnly:!0,value:z.systemPrompt})]}),l.jsxs("label",{children:["Разработчика",l.jsx("textarea",{readOnly:!0,value:z.developerPrompt})]}),l.jsxs("label",{children:["Доменный",l.jsx("textarea",{readOnly:!0,value:z.domainPrompt})]}),l.jsxs("label",{children:["Заметки по схеме",l.jsx("textarea",{readOnly:!0,value:z.schemaNotes})]}),l.jsxs("label",{children:["Примеры few-shot",l.jsx("textarea",{readOnly:!0,value:z.fewShotExamples})]})]}),nr?l.jsx("p",{className:"error-text",children:nr}):null]}):null,l.jsxs("section",{className:"autoruns-col",children:[l.jsx("div",{className:"autoruns-col-header",children:l.jsx("h3",{children:"Выдача прогонов"})}),l.jsxs("div",{className:"autoruns-stats-grid",children:[l.jsxs("div",{children:[l.jsx("span",{children:"Всего"}),l.jsx("strong",{children:(Z?.stats.runs_total??0)+(qe?1:0)})]}),l.jsxs("div",{children:[l.jsx("span",{children:"Средний score"}),l.jsx("strong",{children:jl(Z?.stats.avg_score_index??null)})]}),l.jsxs("div",{children:[l.jsx("span",{children:"Тренд"}),l.jsx("strong",{children:Z?Fc(Z.stats.trend):"нет данных"})]}),l.jsxs("div",{children:[l.jsx("span",{children:"Блокеры"}),l.jsx("strong",{children:Z?.stats.blocking_runs??0})]})]}),l.jsxs("div",{className:"autoruns-run-list",children:[ss.map(a=>l.jsxs("button",{type:"button",className:Ee===a.run_id?"autoruns-run-item selected":"autoruns-run-item",onClick:()=>{Pn(a.run_id)},children:[l.jsxs("div",{className:"autoruns-run-head",children:[l.jsx("strong",{children:tn(a.run_timestamp)}),l.jsx("span",{children:sm(a.eval_target)})]}),l.jsxs("div",{className:"autoruns-run-meta autoruns-run-id-row",children:[l.jsx("span",{children:a.run_id}),l.jsx("span",{role:"button",tabIndex:0,className:"autoruns-copy-run-id-btn",onClick:c=>{Nn(c,a.run_id,"run id")},onKeyDown:c=>{(c.key==="Enter"||c.key===" ")&&(c.preventDefault(),Nn(c,a.run_id,"run id"))},title:"Скопировать run id","aria-label":`Скопировать run id ${a.run_id}`,children:l.jsx(Qc,{})})]}),l.jsxs("div",{className:"autoruns-run-meta",children:["режим=",a.mode??"нет данных"," | mock=",String(a.use_mock)]}),l.jsxs("div",{className:"autoruns-run-meta",children:["analysis_date=",a.analysis_date??"current_state"]}),a.llm_provider||a.model?l.jsxs("div",{className:"autoruns-run-meta",children:["llm=",a.llm_provider??"нет данных"," | модель=",a.model??"нет данных"]}):null,l.jsxs("div",{className:"autoruns-run-meta",children:["промпт=",a.prompt_version??"нет данных"]}),l.jsxs("div",{className:"autoruns-run-foot",children:[l.jsxs("span",{children:["оценка: ",jl(a.score_index)]}),l.jsxs("span",{children:["закрыто/открыто: ",a.closed_cases,"/",a.open_cases]})]}),l.jsxs("div",{className:"autoruns-run-foot",children:[l.jsxs("span",{children:["блокеры: ",a.blocking_failures]}),l.jsxs("span",{children:["качество: ",a.quality_failures]})]})]},a.run_id)),ss.length===0?l.jsx("p",{className:"muted",children:"За выбранный диапазон прогонов нет."}):null]})]}),l.jsxs("section",{className:"autoruns-col",children:[l.jsxs("div",{className:"autoruns-col-header",children:[l.jsx("h3",{children:"Диалог прогона"}),l.jsxs("div",{className:"autoruns-dialog-toolbar",children:[l.jsxs("label",{children:["Прогон",l.jsx("select",{value:Ee,onChange:a=>{const c=a.target.value;Pn(c)},children:ss.map(a=>l.jsxs("option",{value:a.run_id,children:[tn(a.run_timestamp)," | ",a.run_id]},a.run_id))})]}),l.jsxs("label",{children:["Кейс",l.jsxs("select",{value:et,onChange:a=>{const c=a.target.value;ft(c),Ee&&c&&$r(Ee,c)},children:[(U?.cases.length??0)>0?l.jsx("option",{value:_t,children:"ВСЕ кейсы подряд"}):null,(U?.cases??[]).map(a=>l.jsxs("option",{value:a.case_id,children:[a.case_id," | ",a.status]},a.case_id))]})]})]})]}),l.jsxs("div",{className:"autoruns-case-list",children:[(U?.cases.length??0)>0?l.jsxs("button",{type:"button",className:et===_t?"autoruns-case-item selected":"autoruns-case-item",onClick:()=>{ft(_t),Ee&&$r(Ee,_t)},children:[l.jsx("span",{children:"ВСЕ кейсы подряд"}),l.jsx("span",{children:U?.cases.length})]},_t):null,(U?.cases??[]).map(a=>l.jsxs("button",{type:"button",className:et===a.case_id?"autoruns-case-item selected":"autoruns-case-item",onClick:()=>{ft(a.case_id),Ee&&$r(Ee,a.case_id)},children:[l.jsx("span",{children:a.case_id}),l.jsxs("span",{children:[a.status,a.commented_count>0?` | комм=${a.commented_count}`:""]})]},a.case_id))]}),l.jsxs("div",{className:"autoruns-dialog-view",children:[Tr||er?l.jsx("p",{className:"muted",children:"Загружаю диалог..."}):null,!Tr&&!er&&(v?.messages.length??0)===0?l.jsx("p",{className:"muted",children:"Диалог для этого прогона не найден."}):null,(v?.messages??[]).map((a,c)=>{const p=a.role==="assistant"?"assistant":"user";return l.jsxs("article",{className:`autoruns-msg ${p}`,children:[l.jsxs("header",{children:[l.jsx("strong",{children:p==="assistant"?"Система":"Модель/вопрос"}),l.jsxs("div",{className:"autoruns-msg-head-actions",children:[a.case_id?l.jsx("span",{className:"autoruns-msg-case-tag",children:a.case_id}):null,l.jsx("span",{children:a.created_at?tn(a.created_at):"нет данных"}),p==="assistant"&&!Ms(Ee)?l.jsxs(l.Fragment,{children:[l.jsx("button",{type:"button",className:a.commented?"autoruns-comment-icon commented":"autoruns-comment-icon",onClick:()=>Tn(a),title:"\\u041a\\u043e\\u043c\\u043c\\u0435\\u043d\\u0442\\u0438\\u0440\\u043e\\u0432\\u0430\\u0442\\u044c \\u043e\\u0442\\u0432\\u0435\\u0442 \\u0441\\u0438\\u0441\\u0442\\u0435\\u043c\\u044b","aria-label":"\\u041a\\u043e\\u043c\\u043c\\u0435\\u043d\\u0442\\u0438\\u0440\\u043e\\u0432\\u0430\\u0442\\u044c \\u043e\\u0442\\u0432\\u0435\\u0442 \\u0441\\u0438\\u0441\\u0442\\u0435\\u043c\\u044b",children:l.jsx(om,{commented:a.commented})}),a.annotation?l.jsx("button",{type:"button",className:a.annotation.resolved?"autoruns-resolve-toggle resolved":"autoruns-resolve-toggle",onClick:()=>{us(a.annotation,!a.annotation.resolved)},disabled:Mr===a.annotation.annotation_id,title:a.annotation.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный","aria-label":a.annotation.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный",children:l.jsx(Hc,{resolved:a.annotation.resolved})}):null]}):null]})]}),l.jsx("p",{children:a.text}),p==="assistant"&&a.annotation?l.jsxs("div",{className:"autoruns-msg-annotation",children:[l.jsx("strong",{children:aa(a.annotation.rating)}),l.jsx("span",{children:a.annotation.comment}),l.jsxs("span",{className:"muted",children:[a.annotation.manual_case_decision,a.annotation.annotation_author?` | ${a.annotation.annotation_author}`:""]})]}):null,(a.trace_id||a.reply_type)&&l.jsxs("footer",{children:[a.trace_id?l.jsxs("span",{children:["trace=",a.trace_id]}):null,a.reply_type?l.jsxs("span",{children:["reply_type=",a.reply_type]}):null]})]},a.message_id??`${p}-${c}`)})]})]}),dt?l.jsx("div",{className:"autoruns-col autoruns-assistant-live-col",children:l.jsx(qf,{sessionId:k,conversation:D,inputValue:Ls,onInputChange:As,selectedContextChip:fn,onSelectContextChip:ts,onClearContextChip:()=>ts(null),useMock:ns,onUseMockChange:Tl,onSend:Ml,onClear:En,onSaveSession:wo,busy:Is,saveBusy:Ue.saving,saveDisabled:!k.trim()||D.length===0||Is,statusText:xo,errorMessage:Rl,showSaveAction:!0,showCommentAction:!0,onCommentAssistantMessage:as,isAssistantMessageCommented:is,canCommentAssistantMessage:Co})}):null,st?l.jsxs("section",{className:"autoruns-col",children:[l.jsx("div",{className:"autoruns-col-header",children:l.jsx("h3",{children:"Прогресс / регресс"})}),l.jsxs("div",{className:"autoruns-stats-grid",children:[l.jsxs("div",{children:[l.jsx("span",{children:"Последний score"}),l.jsx("strong",{children:jl(Z?.stats.latest_score_index??null)})]}),l.jsxs("div",{children:[l.jsx("span",{children:"Предыдущий"}),l.jsx("strong",{children:jl(Z?.stats.previous_score_index??null)})]}),l.jsxs("div",{children:[l.jsx("span",{children:"Тренд"}),l.jsx("strong",{children:Z?Fc(Z.stats.trend):"нет данных"})]}),l.jsxs("div",{children:[l.jsx("span",{children:"Пробелы качества"}),l.jsx("strong",{children:Z?.stats.quality_gap_runs??0})]})]}),l.jsx("h4",{children:"Покрытие доменов (история)"}),Uc(Z?.stats.domain_coverage??[]),l.jsx("h4",{style:{marginTop:14},children:"Покрытие доменов (выбранный прогон)"}),Uc(U?.coverage.domain_coverage??[]),l.jsx("h4",{style:{marginTop:14},children:"Очереди фиксов пост-анализа"}),an?l.jsx("p",{className:"muted",children:"Собираю пост-анализ..."}):null,an?null:l.jsx("div",{className:"autoruns-stats-grid",children:Object.entries(on?.post_analysis.stats.by_queue??{}).map(([a,c])=>l.jsxs("div",{children:[l.jsx("span",{children:a}),l.jsx("strong",{children:c})]},a))}),l.jsxs("div",{className:"autoruns-autogen-list",children:[(on?.post_analysis.recommended_regression_candidates??[]).slice(0,12).map(a=>l.jsxs("article",{className:"autoruns-autogen-item",children:[l.jsxs("header",{children:[l.jsx("strong",{children:a.manual_case_decision}),l.jsxs("span",{children:[a.rating,"/5"]})]}),l.jsxs("div",{className:"autoruns-run-meta",children:[a.domain??"неизвестно"," / ",a.query_class??"неизвестно"]}),l.jsx("p",{children:a.comment})]},a.annotation_id)),!an&&(on?.post_analysis.recommended_regression_candidates.length??0)===0?l.jsx("p",{className:"muted",children:"Рекомендованных кандидатов пока нет."}):null]})]}):null,Dt?l.jsxs("section",{className:"autoruns-col",children:[l.jsx("div",{className:"autoruns-col-header",children:l.jsx("h3",{children:"Комментарии"})}),l.jsx("h4",{children:"Размеченные ответы"}),l.jsxs("div",{className:"autoruns-comment-filter-row",children:[l.jsxs("label",{children:["Фильтр решений",l.jsxs("select",{value:ae,onChange:a=>he(a.target.value),children:[l.jsx("option",{value:"all",children:"все"}),(qt.length>0?qt:we?.enum??[]).map(a=>l.jsx("option",{value:a,children:String(we?.labels?.[a]??a)},a))]})]}),l.jsx("button",{type:"button",className:"tab autoruns-resolved-filter-toggle",onClick:()=>_e(a=>!a),children:xe?"Показать выполненные":"Скрыть выполненные"})]}),l.jsxs("div",{className:"autoruns-stats-grid",children:[l.jsxs("div",{children:[l.jsx("span",{children:"Комментариев"}),l.jsx("strong",{children:Ft.length})]}),l.jsxs("div",{children:[l.jsx("span",{children:"Средний рейтинг"}),l.jsx("strong",{children:Us===null?"нет данных":`${Us.toFixed(2)} / 5`})]}),l.jsxs("div",{children:[l.jsx("span",{children:"Последний"}),l.jsx("strong",{children:Ft.length>0?tn(Ft[0].updated_at):"нет данных"})]}),l.jsxs("div",{children:[l.jsx("span",{children:"Статус"}),l.jsx("strong",{children:jn?"обновляю":"готово"})]})]}),l.jsxs("div",{className:"button-row",children:[l.jsx("button",{type:"button",disabled:jn,onClick:()=>{zr()},children:jn?"Обновляю...":"Обновить список"}),l.jsx("button",{type:"button",className:"tab",disabled:an,onClick:()=>{ht()},children:an?"Идет пост-анализ...":"Обновить пост-анализ"})]}),l.jsxs("div",{className:"autoruns-comments-list",children:[jn?l.jsx("p",{className:"muted",children:"Загружаю комментарии..."}):null,!jn&&Ft.length===0?l.jsx("p",{className:"muted",children:re.length===0&&Ke.length===0?"Пока нет откомментированных ответов.":"Нет открытых кейсов по текущему фильтру."}):null,Ft.map(a=>{if(a.source==="assistant_live"){const p=a.assistant;return l.jsxs("article",{className:"autoruns-comment-item",children:[l.jsxs("div",{className:"autoruns-comment-head",children:[l.jsx("strong",{children:aa(p.rating)}),l.jsx("div",{className:"autoruns-comment-head-actions",children:l.jsx("span",{children:tn(p.updated_at)})})]}),l.jsxs("div",{className:"autoruns-run-meta",children:["live-session: ",p.session_id]}),l.jsxs("div",{className:"autoruns-run-meta",children:["msg=",p.message_index]}),l.jsxs("div",{className:"autoruns-run-meta",children:["source=assistant_live",p.annotation_author?` | author=${p.annotation_author}`:""]}),p.context.question_text?l.jsxs("p",{children:["Q: ",p.context.question_text]}):null,p.context.answer_text?l.jsxs("p",{children:["A: ",p.context.answer_text]}):null,l.jsx("p",{children:p.comment})]},a.key)}const c=a.autorun;return l.jsxs("article",{className:wn===c.annotation_id?"autoruns-comment-item selected":"autoruns-comment-item",onClick:()=>{cs(c)},role:"button",tabIndex:0,onKeyDown:p=>{(p.key==="Enter"||p.key===" ")&&(p.preventDefault(),cs(c))},children:[l.jsxs("div",{className:"autoruns-comment-head",children:[l.jsx("strong",{children:aa(c.rating)}),l.jsxs("div",{className:"autoruns-comment-head-actions",children:[l.jsx("span",{children:tn(c.updated_at)}),l.jsx("button",{type:"button",className:c.resolved?"autoruns-resolve-toggle resolved":"autoruns-resolve-toggle",onClick:p=>{p.preventDefault(),p.stopPropagation(),us(c,!c.resolved)},disabled:Mr===c.annotation_id,title:c.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный","aria-label":c.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный",children:l.jsx(Hc,{resolved:c.resolved})})]})]}),l.jsx("div",{className:"autoruns-run-meta",children:c.run_id}),l.jsxs("div",{className:"autoruns-run-meta",children:["case=",c.case_id," | msg=",c.message_index]}),l.jsxs("div",{className:"autoruns-run-meta",children:["decision=",c.manual_case_decision,c.annotation_author?` | author=${c.annotation_author}`:""]}),c.resolved_at?l.jsxs("div",{className:"autoruns-run-meta",children:["выполнено",": ",tn(c.resolved_at),c.resolved_by?` | by=${c.resolved_by}`:""]}):null,c.context.question_text?l.jsxs("p",{children:["Q: ",c.context.question_text]}):null,c.context.answer_text?l.jsxs("p",{children:["A: ",c.context.answer_text]}):null,l.jsx("p",{children:c.comment})]},a.key)})]}),Ne?l.jsxs(l.Fragment,{children:[l.jsx("h4",{children:"Тех-контекст брака"}),l.jsxs("div",{className:"autoruns-meta-list",children:[l.jsxs("div",{children:[l.jsx("span",{children:"trace:"}),l.jsx("strong",{children:Ne.technical_context.trace_id??"нет данных"})]}),l.jsxs("div",{children:[l.jsx("span",{children:"reply_type:"}),l.jsx("strong",{children:Ne.technical_context.reply_type??"нет данных"})]}),l.jsxs("div",{children:[l.jsx("span",{children:"domain:"}),l.jsx("strong",{children:Ne.technical_context.domain??"нет данных"})]}),l.jsxs("div",{children:[l.jsx("span",{children:"query_class:"}),l.jsx("strong",{children:Ne.technical_context.query_class??"нет данных"})]})]}),l.jsx("h4",{children:"JSON разбор"}),l.jsx(Kc,{value:{annotation_id:Ne.annotation_id,run_id:Ne.run_id,case_id:Ne.case_id,message_index:Ne.message_index,rating:Ne.rating,comment:Ne.comment,manual_case_decision:Ne.manual_case_decision,annotation_author:Ne.annotation_author,resolved:Ne.resolved,resolved_at:Ne.resolved_at,resolved_by:Ne.resolved_by,context:Ne.context,technical_context:Ne.technical_context,case_summary:Ne.case_summary?{case_id:Ne.case_summary.case_id,domain:Ne.case_summary.domain,query_class:Ne.case_summary.query_class,checks:Ne.case_summary.checks,metric_subscores:Ne.case_summary.metric_subscores}:null}})]}):null]}):null]}),Ue.open?l.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:a=>{a.target===a.currentTarget&&Ut()},children:l.jsxs("div",{className:"autoruns-comment-modal",children:[l.jsx("h3",{children:"Сохранить ручную сессию"}),l.jsx("p",{className:"muted",children:"Технический чат будет сохранен в автопрогоны как пользовательская multi-turn сессия."}),l.jsxs("label",{children:["Название",l.jsx("input",{value:Ue.title,onChange:a=>Fn(c=>({...c,title:a.target.value})),placeholder:"Например: НДС и склад на март 2020",disabled:Ue.saving})]}),Ue.error?l.jsx("p",{className:"error-text",children:Ue.error}):null,l.jsxs("div",{className:"button-row",children:[l.jsx("button",{type:"button",onClick:()=>{Dr()},disabled:Ue.saving,children:Ue.saving?"Сохраняю...":"Сохранить"}),l.jsx("button",{type:"button",className:"tab",onClick:()=>Ut(),disabled:Ue.saving,children:"Отмена"})]})]})}):null,$t.open?l.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:a=>{a.target===a.currentTarget&&Bt()},children:l.jsxs("div",{className:"autoruns-comment-modal",children:[l.jsx("h3",{children:"Удалить вопрос"}),l.jsx("p",{className:"muted",children:"Действительно удалить вопрос из сохраненной пользовательской сессии?"}),l.jsx("p",{className:"autoruns-comment-quote",children:$t.questionText}),$t.error?l.jsx("p",{className:"error-text",children:$t.error}):null,l.jsxs("div",{className:"button-row",children:[l.jsx("button",{type:"button",onClick:()=>{ur()},disabled:$t.saving,children:$t.saving?"Удаляю...":"Да"}),l.jsx("button",{type:"button",className:"tab",onClick:()=>Bt(),disabled:$t.saving,children:"Нет"})]})]})}):null,Et.open?l.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:a=>{a.target===a.currentTarget&&Ht()},children:l.jsxs("div",{className:"autoruns-comment-modal",children:[l.jsx("h3",{children:"Удалить сохраненный набор"}),l.jsx("p",{className:"muted",children:"Будет удалена карточка истории и связанный файл кейс-сета на бэке."}),l.jsx("p",{className:"autoruns-comment-quote",children:Et.title}),Et.error?l.jsx("p",{className:"error-text",children:Et.error}):null,l.jsxs("div",{className:"button-row",children:[l.jsx("button",{type:"button",onClick:()=>{Ur()},disabled:Et.saving,children:Et.saving?"Удаляю...":"Да"}),l.jsx("button",{type:"button",className:"tab",onClick:()=>Ht(),disabled:Et.saving,children:"Нет"})]})]})}):null,ue.open?l.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:a=>{a.target===a.currentTarget&&hn()},children:l.jsxs("div",{className:"autoruns-comment-modal",children:[l.jsx("h3",{children:"Комментарий к ответу ассистента"}),l.jsx("p",{className:"muted",children:"Комментарий будет добавлен в общий список комментариев справа с меткой `assistant_live`."}),Fs?l.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[l.jsx("summary",{children:"Вопрос пользователя"}),l.jsx("p",{className:"autoruns-comment-quote",children:Fs.text})]}):null,$s?l.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[l.jsx("summary",{children:"Ответ ассистента"}),l.jsx("p",{className:"autoruns-comment-quote",children:$s.text})]}):null,l.jsx("div",{className:"autoruns-rating-row",role:"group","aria-label":"Рейтинг ответа ассистента",children:[1,2,3,4,5].map(a=>l.jsx("button",{type:"button",className:ue.rating>=a?"autoruns-rating-dot active":"autoruns-rating-dot",onClick:()=>mn(c=>({...c,rating:a})),disabled:ue.saving,"aria-label":`Оценка ${a}`,children:ue.rating>=a?"●":"○"},a))}),l.jsx("div",{className:"autoruns-form-grid",children:l.jsxs("label",{children:["Автор комментария",l.jsx("input",{value:ue.annotationAuthor,onChange:a=>mn(c=>({...c,annotationAuthor:a.target.value})),placeholder:"manual_reviewer",disabled:ue.saving})]})}),l.jsxs("label",{children:["Комментарий",l.jsx("textarea",{value:ue.comment,onChange:a=>mn(c=>({...c,comment:a.target.value})),placeholder:"Что именно не так в ответе и что нужно исправить.",rows:4,disabled:ue.saving})]}),ue.error?l.jsx("p",{className:"error-text",children:ue.error}):null,l.jsxs("div",{className:"button-row",children:[l.jsx("button",{type:"button",onClick:()=>{No()},disabled:ue.saving,children:ue.saving?"Сохраняю...":"Готово"}),l.jsx("button",{type:"button",className:"tab",onClick:()=>hn(),disabled:ue.saving,children:"Отмена"})]})]})}):null,ge.open?l.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:a=>{a.target===a.currentTarget&&ar()},children:l.jsxs("div",{className:"autoruns-comment-modal",children:[l.jsx("h3",{children:"Комментарий к ответу системы"}),l.jsx("p",{className:"muted",children:"Оцените ответ по 5-балльной шкале и добавьте комментарий по браку."}),So?l.jsxs(l.Fragment,{children:[l.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[l.jsx("summary",{children:"Вопрос пользователя"}),l.jsx("p",{className:"autoruns-comment-quote",children:zs?.text??"Вопрос в диалоге не найден."})]}),l.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[l.jsx("summary",{children:"Ответ системы"}),l.jsx("p",{className:"autoruns-comment-quote",children:So.text})]})]}):null,l.jsx("div",{className:"autoruns-rating-row",role:"group","aria-label":"Рейтинг ответа",children:[1,2,3,4,5].map(a=>l.jsx("button",{type:"button",className:ge.rating>=a?"autoruns-rating-dot active":"autoruns-rating-dot",onClick:()=>wt(c=>({...c,rating:a})),disabled:ge.saving,"aria-label":`Оценка ${a}`,children:ge.rating>=a?"●":"○"},a))}),l.jsxs("div",{className:"autoruns-form-grid",children:[l.jsxs("label",{children:["Решение по кейсу",l.jsx("select",{value:ge.manualCaseDecision,onChange:a=>wt(c=>({...c,manualCaseDecision:a.target.value})),disabled:ge.saving,children:(qt.length>0?qt:we?.enum??[wl]).map(a=>l.jsx("option",{value:a,children:String(we?.labels?.[a]??a)},a))})]}),l.jsxs("label",{children:["Автор комментария",l.jsx("input",{value:ge.annotationAuthor,onChange:a=>wt(c=>({...c,annotationAuthor:a.target.value})),placeholder:"manual_reviewer",disabled:ge.saving})]})]}),l.jsxs("label",{children:["Комментарий",l.jsx("textarea",{value:ge.comment,onChange:a=>wt(c=>({...c,comment:a.target.value})),placeholder:"Почему ответ бракованный, что именно пошло не так, какие технические детали проверить.",rows:4,disabled:ge.saving})]}),ge.error?l.jsx("p",{className:"error-text",children:ge.error}):null,l.jsxs("div",{className:"button-row",children:[l.jsx("button",{type:"button",onClick:()=>{ls()},disabled:ge.saving,children:ge.saving?"Сохраняю...":"Готово"}),l.jsx("button",{type:"button",className:"tab",onClick:()=>ar(),disabled:ge.saving,children:"Отмена"})]})]})}):null]})}const im={llmProvider:"openai",apiKey:"",model:"gpt-4o-mini",baseUrl:"https://api.openai.com/v1",temperature:0,maxOutputTokens:700},bc={systemPrompt:"Ты semantic-normalizer для бухгалтерского ассистента NDC. Возвращай только JSON по схеме normalized_query_v2_0_2.",developerPrompt:"Сначала делай decomposition сообщения на task fragments, затем определяй domain scope и route-critical flags. Для каждого fragment заполняй execution_readiness + route_status + no_route_reason. Если fragment routable, не оставляй его в no_route.",domainPrompt:"Контур: данные текущего предприятия в 1С/NDC. In-scope: документы, проводки, взаиморасчеты, остатки, периодное закрытие, аномалии и контрольные проверки. Out-of-scope: общая теория, законы и оффтоп.",schemaNotes:"schema_version: normalized_query_v2_0_2. Строгий JSON без дополнительных полей.",fewShotExamples:"Q: Проверь по поставщикам хвосты и разложи цепочку документов/оплат. => fragment in_scope, flags: multi_entity + chain_explanation. Q: Как вообще по ФСБУ? => out_of_scope/generic_accounting."},am={userQuestion:"",batchQuestionsRaw:"",periodHint:"",businessContext:"",expectedRoute:""},ua={colors:{backgroundRgb:"18, 18, 18",mainSurfaceRgb:"25, 25, 25",horizontalSurfaceRgb:"30, 30, 30",focusSurfaceRgb:"35, 35, 35",assistantChipRgb:"18, 18, 18",assistantChipHoverRgb:"44, 44, 44",assistantChipSelectedRgb:"167, 59, 255",assistantChipSelectedTextRgb:"240, 240, 240",activeRgb:"167, 59, 255",activeTextRgb:"240, 240, 240",textMainRgb:"240, 240, 240",textMutedRgb:"166, 166, 166",dangerRgb:"126, 126, 126",scrollbarTrackRgb:"20, 20, 20",scrollbarThumbRgb:"30, 30, 30",scrollbarThumbHoverRgb:"30, 50, 30"},layout:{modeColumnWidthPx:406,modeToggleWidthPx:188}},Vc="ndc_normalizer_session_config_v1",Wc="ndc_autoruns_layout_config_v1",um="ndc-autoruns-save",cm="autoruns",ca="normalizer_v2_0_2",dm="address_query_runtime_v1",fm=["normalized","fragments","scope","flags","route","raw","validation","logs"];function mm(i){return`[${new Date().toLocaleTimeString("ru-RU")}] ${i}`}function pm(i,g){if(!g)return"Previous preset is not selected.";const R=["systemPrompt","developerPrompt","domainPrompt","schemaNotes","fewShotExamples"].filter(E=>i[E]!==g[E]).map(E=>`${E}: ${Math.abs(i[E].length-g[E].length)} chars delta`);return R.length===0?"No changes against previous preset.":`Changed fields: ${R.length}. ${R.join(" | ")}`}function hm(){const[i,g]=y.useState(im),[f,R]=y.useState(bc),[E,A]=y.useState(am),[Q,le]=y.useState(null),[te,z]=y.useState([]),[Y,X]=y.useState([]),[ee,Te]=y.useState("normalized"),[ce,de]=y.useState(!1),[pe,Qe]=y.useState(!1),[Je,be]=y.useState([]),[Re,F]=y.useState(""),[oe,Ce]=y.useState([]),[$e,dt]=y.useState(""),[st,Dt]=y.useState("NDC custom preset"),[ot,H]=y.useState(null),[Me,We]=y.useState(""),[ne,Z]=y.useState(!1),[M,U]=y.useState([]),[L,v]=y.useState(""),[w,re]=y.useState([]),[ie,ae]=y.useState(!1),[he,xe]=y.useState(null),[_e,we]=y.useState(""),[lt,qt]=y.useState(cm),[Xn,wn]=y.useState(!0),[nn,Ee]=y.useState(!0),[Ot,et]=y.useState(!0),[ft,St]=y.useState(!0),[rn,W]=y.useState(!0),[it,Zn]=y.useState(!0),[In,Dn]=y.useState(!0),[kn,mt]=y.useState(!0),[zt,qe]=y.useState(!0),[sn,on]=y.useState(!0),[Zr,Nr]=y.useState(!0),[Er,es]=y.useState(!0),[ln,an]=y.useState(!0),un=y.useRef(!1),cn=y.useRef(!1),On=y.useRef(!1);y.useEffect(()=>{const k=document.documentElement,{colors:q}=ua;k.style.setProperty("--rgb-background",q.backgroundRgb),k.style.setProperty("--rgb-surface-main",q.mainSurfaceRgb),k.style.setProperty("--rgb-surface-horizontal",q.horizontalSurfaceRgb),k.style.setProperty("--rgb-surface-focus",q.focusSurfaceRgb),k.style.setProperty("--rgb-assistant-chip",q.assistantChipRgb),k.style.setProperty("--rgb-assistant-chip-hover",q.assistantChipHoverRgb),k.style.setProperty("--rgb-assistant-chip-selected",q.assistantChipSelectedRgb),k.style.setProperty("--rgb-assistant-chip-selected-text",q.assistantChipSelectedTextRgb),k.style.setProperty("--rgb-active",q.activeRgb),k.style.setProperty("--rgb-active-text",q.activeTextRgb),k.style.setProperty("--rgb-text-main",q.textMainRgb),k.style.setProperty("--rgb-text-muted",q.textMutedRgb),k.style.setProperty("--rgb-danger",q.dangerRgb),k.style.setProperty("--rgb-scrollbar-track",q.scrollbarTrackRgb),k.style.setProperty("--rgb-scrollbar-thumb",q.scrollbarThumbRgb),k.style.setProperty("--rgb-scrollbar-thumb-hover",q.scrollbarThumbHoverRgb),k.style.setProperty("--mode-column-width",`${ua.layout.modeColumnWidthPx}px`),k.style.setProperty("--mode-toggle-width",`${ua.layout.modeToggleWidthPx}px`)},[]);const me=k=>{X(q=>[mm(k),...q].slice(0,300))};y.useEffect(()=>{(async()=>{const D=localStorage.getItem(Vc);if(D)try{const ke=JSON.parse(D);g(Ke=>({...Ke,llmProvider:ke.llmProvider==="local"?"local":"openai",model:ke.model??Ke.model,baseUrl:ke.baseUrl??Ke.baseUrl,temperature:ke.temperature??Ke.temperature,maxOutputTokens:ke.maxOutputTokens??Ke.maxOutputTokens}))}catch{}try{const ke=await Pe.loadSharedConnectionConfig();ke.connection&&ke.connection.llmProvider==="local"&&(g(Ke=>({...Ke,llmProvider:"local",model:ke.connection?.model??Ke.model,baseUrl:ke.connection?.baseUrl??Ke.baseUrl,temperature:ke.connection?.temperature??Ke.temperature,maxOutputTokens:ke.connection?.maxOutputTokens??Ke.maxOutputTokens})),me(`Shared local LLM config loaded: ${ke.connection.model}`))}catch(ke){me(`Shared local config load error: ${ke instanceof Error?ke.message:String(ke)}`)}finally{On.current=!0}})();const q=localStorage.getItem(Wc);if(q)try{const D=JSON.parse(q);(D.uiMode==="assistant"||D.uiMode==="autoruns"||D.uiMode==="decomposition")&&qt("autoruns"),D.activeTab&&fm.includes(D.activeTab)&&Te(D.activeTab),typeof D.showAutorunsSettingsMode=="boolean"&&wn(D.showAutorunsSettingsMode),typeof D.showAutorunsAutoRunsMode=="boolean"&&Ee(D.showAutorunsAutoRunsMode),typeof D.showAutorunsAssistantMode=="boolean"&&et(D.showAutorunsAssistantMode),typeof D.showAutorunsDecompositionMode=="boolean"&&St(D.showAutorunsDecompositionMode),typeof D.showAutorunsProgressMode=="boolean"&&W(D.showAutorunsProgressMode),typeof D.showAutorunsCommentsMode=="boolean"&&Zn(D.showAutorunsCommentsMode),typeof D.showDecompositionConnectionMode=="boolean"&&Dn(D.showDecompositionConnectionMode),typeof D.showDecompositionPromptMode=="boolean"&&mt(D.showDecompositionPromptMode),typeof D.showDecompositionQueryMode=="boolean"&&qe(D.showDecompositionQueryMode),typeof D.showDecompositionOutputMode=="boolean"&&on(D.showDecompositionOutputMode),typeof D.showDecompositionMetricsMode=="boolean"&&Nr(D.showDecompositionMetricsMode),typeof D.showDecompositionHistoryMode=="boolean"&&es(D.showDecompositionHistoryMode),typeof D.showDecompositionRuntimeMode=="boolean"&&an(D.showDecompositionRuntimeMode),D.prompts&&(R(ke=>({...ke,...D.prompts})),cn.current=!0)}catch{}dn(),er(),Pr()},[]),y.useEffect(()=>{if(!On.current||i.llmProvider!=="local")return;const k=window.setTimeout(()=>{Pe.saveSharedConnectionConfig(i).catch(q=>me(`Shared local config sync error: ${q instanceof Error?q.message:String(q)}`))},250);return()=>window.clearTimeout(k)},[i.baseUrl,i.llmProvider,i.maxOutputTokens,i.model,i.temperature]);async function dn(){try{const k=await Pe.loadHistory();z(k.items??[])}catch(k){me(`History load error: ${k instanceof Error?k.message:String(k)}`)}}async function er(){try{const q=(await Pe.loadPresets()).presets??[];if(Ce(q),cn.current){un.current=!0;return}if(un.current)return;const D=q.find(ke=>ke.prompt_version===ca)??q.find(ke=>ke.id==="default-normalizer-v2_0_2");if(!D){un.current=!0,me(`Preset autoload skipped: ${ca} not found.`);return}dt(D.id),H(f),R({systemPrompt:D.systemPrompt,developerPrompt:D.developerPrompt,domainPrompt:D.domainPrompt,schemaNotes:D.schemaNotes??"",fewShotExamples:D.fewShotExamples??""}),un.current=!0,me(`Preset autoloaded: ${D.name} (${D.prompt_version}).`)}catch(k){me(`Presets load error: ${k instanceof Error?k.message:String(k)}`)}}async function Pr(){try{const k=await Pe.listRuns();U(k.items??[])}catch(k){me(`Runs load error: ${k instanceof Error?k.message:String(k)}`)}}function Tr(){if(localStorage.setItem(Vc,JSON.stringify({model:i.model,llmProvider:i.llmProvider,baseUrl:i.baseUrl,temperature:i.temperature,maxOutputTokens:i.maxOutputTokens})),i.llmProvider==="local"){Pe.saveSharedConnectionConfig(i).then(()=>{me("Local config saved and synced to shared agent config (without API key).")}).catch(k=>{me(`Local config saved, but shared sync failed: ${k instanceof Error?k.message:String(k)}`)});return}me("Local config saved (without API key).")}function Rr(){localStorage.setItem(Wc,JSON.stringify({uiMode:lt,activeTab:ee,showAutorunsSettingsMode:Xn,showAutorunsAutoRunsMode:nn,showAutorunsAssistantMode:Ot,showAutorunsDecompositionMode:ft,showAutorunsProgressMode:rn,showAutorunsCommentsMode:it,showDecompositionConnectionMode:In,showDecompositionPromptMode:kn,showDecompositionQueryMode:zt,showDecompositionOutputMode:sn,showDecompositionMetricsMode:Zr,showDecompositionHistoryMode:Er,showDecompositionRuntimeMode:ln,prompts:f})),window.dispatchEvent(new CustomEvent(um)),me("UI layout and prompts saved.")}async function jn(){de(!0),we("");try{const k=await Pe.testConnection(i);k.provider==="local"?k.model_found===!0?(F(`LOCAL OK - ${k.model}`),me(`Local model is available: ${k.model} (catalog size=${k.models_count??"n/a"}).`)):k.model_found===!1?(F(`LOCAL OK, model not loaded - ${k.model}`),me(`Local server is reachable, but model '${k.model}' is not in loaded catalog. Use 'Load model list' and select one of loaded models.`)):(F(`LOCAL OK (model list unavailable) - ${k.model}`),me("Local server is reachable, but model catalog could not be verified.")):(F(`OPENAI OK - ${k.model}`),me(`OpenAI connection ok: ${k.model}`))}catch(k){const q=k instanceof Error?k.message:String(k);F("Connection error"),we(`Test connection: ${q}`),me(`Test connection error: ${q}`)}finally{de(!1)}}async function tr(){Qe(!0);try{const q=(await Pe.listModels(i)).models??[];be(q),q.length>0&&g(D=>D.model&&q.includes(D.model)?D:{...D,model:q[0]}),me(`Model catalog loaded (${i.llmProvider}): ${q.length} items.`)}catch(k){const q=k instanceof Error?k.message:String(k);me(`Load model list error: ${q}`)}finally{Qe(!1)}}y.useEffect(()=>{be([])},[i.llmProvider,i.baseUrl]);function Mr(){const k=oe.find(q=>q.id===$e);if(!k){me("Preset is not selected.");return}H(f),R({systemPrompt:k.systemPrompt,developerPrompt:k.developerPrompt,domainPrompt:k.domainPrompt,schemaNotes:k.schemaNotes??"",fewShotExamples:k.fewShotExamples??""}),me(`Preset loaded: ${k.name}`)}async function Cn(){try{await Pe.savePreset({name:st||"NDC preset",prompt_version:"normalizer_v2_0_2",systemPrompt:f.systemPrompt,developerPrompt:f.developerPrompt,domainPrompt:f.domainPrompt,schemaNotes:f.schemaNotes,fewShotExamples:f.fewShotExamples}),me("Preset saved."),await er()}catch(k){me(`Preset save error: ${k instanceof Error?k.message:String(k)}`)}}function nr(){R(bc),me("Prompt panel reset to defaults.")}function Oe(){const k=pm(f,ot);We(k),me(k)}return y.useEffect(()=>{if(!L){re([]);return}Pe.runTrace(L).then(k=>re(k.items)).catch(k=>me(`Run trace error: ${k instanceof Error?k.message:String(k)}`))},[L]),l.jsxs("main",{className:"app-root app-root-autoruns",children:[l.jsxs("header",{className:"app-topbar",children:[l.jsxs("div",{className:"mode-switch-row",children:[l.jsx("button",{type:"button",className:"tab active",onClick:()=>qt("autoruns"),children:"Управление ассистентом"}),l.jsx("button",{type:"button",className:"tab",onClick:Rr,children:"Сохранить"})]}),l.jsxs("div",{className:"mode-switch-row mode-switch-row-right",children:[l.jsx("button",{type:"button",className:Xn?"tab active":"tab",onClick:()=>wn(k=>!k),children:"Настройки"}),l.jsx("button",{type:"button",className:nn?"tab active":"tab",onClick:()=>Ee(k=>!k),children:"Автопрогоны"}),l.jsx("button",{type:"button",className:Ot?"tab active":"tab",onClick:()=>et(k=>!k),children:"Режим ассистента"}),l.jsx("button",{type:"button",className:rn?"tab active":"tab",onClick:()=>W(k=>!k),children:"Прогресс/регресс"}),l.jsx("button",{type:"button",className:it?"tab active":"tab",onClick:()=>Zn(k=>!k),children:"Комментарии"})]})]}),l.jsx("div",{className:"layout-grid layout-grid-autoruns",children:l.jsx(lm,{connection:i,modelOptions:Je,modelsBusy:pe,connectionStatus:Re,connectionBusy:ce,onConnectionChange:g,onReloadModels:tr,onSaveLocalConfig:Tr,onTestConnection:jn,prompts:f,onPromptsChange:R,promptPresets:oe,selectedPresetId:$e,onSelectPreset:dt,onLoadPreset:Mr,onSavePreset:Cn,onResetDefaults:nr,onDiffPrevious:Oe,presetName:st,onPresetNameChange:Dt,diffSummary:Me,assistantPromptVersion:dm,decompositionPromptVersion:ca,showSettingsMode:Xn,showAutoRunsMode:nn,showAssistantMode:Ot,showProgressMode:rn,showCommentsMode:it,onLog:me})})]})}Ef.createRoot(document.getElementById("root")).render(l.jsx(_f.StrictMode,{children:l.jsx(hm,{})})); diff --git a/llm_normalizer/frontend/dist/assets/index-CaUiKcE3.css b/llm_normalizer/frontend/dist/assets/index-DkWsdP2H.css similarity index 84% rename from llm_normalizer/frontend/dist/assets/index-CaUiKcE3.css rename to llm_normalizer/frontend/dist/assets/index-DkWsdP2H.css index e517791..a443dd5 100644 --- a/llm_normalizer/frontend/dist/assets/index-CaUiKcE3.css +++ b/llm_normalizer/frontend/dist/assets/index-DkWsdP2H.css @@ -1 +1 @@ -@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;600;700;800&family=Space+Grotesk:wght@500;700&display=swap";:root{--rgb-background: 16, 16, 19;--rgb-surface-main: 26, 26, 31;--rgb-surface-horizontal: 32, 32, 38;--rgb-surface-focus: 40, 40, 47;--rgb-assistant-chip: 18, 18, 18;--rgb-assistant-chip-hover: 44, 44, 44;--rgb-assistant-chip-selected: 228, 142, 92;--rgb-assistant-chip-selected-text: 18, 18, 18;--rgb-active: 228, 142, 92;--rgb-active-text: 18, 18, 18;--rgb-text-main: 240, 240, 240;--rgb-text-muted: 166, 166, 170;--rgb-danger: 255, 126, 126;--rgb-scrollbar-track: 31, 31, 36;--rgb-scrollbar-thumb: 74, 74, 82;--rgb-scrollbar-thumb-hover: 90, 90, 100;--mode-column-width: 440px;--mode-toggle-width: 188px;--bg-main: rgb(var(--rgb-background));--bg-soft: rgb(var(--rgb-surface-main));--bg-panel: rgb(var(--rgb-surface-main));--bg-panel-accent: rgb(var(--rgb-surface-horizontal));--surface-horizontal: rgb(var(--rgb-surface-horizontal));--surface-focus: rgb(var(--rgb-surface-focus));--line: transparent;--line-strong: rgba(var(--rgb-active), .48);--text-main: rgb(var(--rgb-text-main));--text-muted: rgb(var(--rgb-text-muted));--lime-main: rgb(var(--rgb-text-main));--lime-press: rgb(var(--rgb-text-main));--danger: rgb(var(--rgb-danger));--radius-lg: 20px;--radius-md: 14px;--shadow: none;--autoruns-col-width: var(--mode-column-width)}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:rgb(var(--rgb-scrollbar-thumb)) rgb(var(--rgb-scrollbar-track))}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:rgb(var(--rgb-scrollbar-track))}*::-webkit-scrollbar-thumb{background:rgb(var(--rgb-scrollbar-thumb));border-radius:999px;border:2px solid rgb(var(--rgb-scrollbar-track))}*::-webkit-scrollbar-thumb:hover{background:rgb(var(--rgb-scrollbar-thumb-hover))}html,body,#root{margin:0;min-height:100dvh;font-family:Manrope,Segoe UI,sans-serif;background:var(--bg-main);color:var(--text-main)}.app-root{max-width:1720px;margin:0 auto;padding:12px 16px 16px}.app-root.app-root-autoruns{max-width:none;width:100%;min-height:100dvh;max-height:100dvh;display:flex;flex-direction:column;overflow:hidden}.app-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 12px;padding:0;min-height:38px}.layout-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}.layout-grid.layout-grid-autoruns,.layout-grid.layout-grid-mode-columns{min-height:0;flex:1 1 auto;grid-template-columns:minmax(0,1fr)}.mode-switch-row{display:flex;gap:8px;margin:0;padding:0}.mode-switch-row.mode-switch-row-right{margin-left:auto;justify-content:flex-end;max-width:72%;overflow-x:auto;overflow-y:hidden;padding-bottom:2px}.mode-switch-row .tab{white-space:nowrap}.mode-switch-row.mode-switch-row-right .tab{width:var(--mode-toggle-width);min-width:var(--mode-toggle-width);text-align:center}.mode-columns{display:flex;gap:12px;width:100%;min-height:0;flex:1 1 auto;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.mode-col{flex:0 0 var(--mode-column-width);width:var(--mode-column-width);min-height:0;height:100%;display:flex}.mode-col.mode-col-wide,.mode-col.mode-col-xwide{flex-basis:var(--mode-column-width);width:var(--mode-column-width)}.mode-col .panel-frame{width:100%;height:100%}.mode-col .panel-body{min-height:0;overflow:auto}.mode-columns-empty{min-width:360px;border-radius:14px;background:rgb(var(--rgb-surface-main));color:var(--text-muted);padding:14px}.panel-frame{grid-column:span 12;border:none;border-radius:var(--radius-lg);background:var(--bg-panel);overflow:hidden;box-shadow:none;animation:rise .4s ease-out;display:flex;flex-direction:column;min-height:0}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:14px 18px 10px;border-bottom:none;background:var(--bg-panel-accent)}.panel-header h2{margin:0;font-size:1.02rem;letter-spacing:.02em}.panel-header p{margin:6px 0 0;font-size:.85rem;color:var(--text-muted)}.panel-body{padding:10px 12px 12px;min-height:0}.app-root-autoruns .autoruns-frame{height:100%}.app-root-autoruns .autoruns-frame .panel-body{flex:1 1 auto;overflow:hidden;display:flex;flex-direction:column;gap:10px;padding:10px 12px 12px;background:rgb(var(--rgb-background))}.status-chip{border:none;border-radius:999px;padding:4px 10px;color:var(--lime-main);font-size:.78rem;background:rgb(var(--rgb-surface-focus))}.assistant-toolbar{display:grid;gap:8px}.assistant-toolbar-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:center;gap:8px}.assistant-toolbar-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.assistant-toolbar-meta-right{margin-left:auto;display:flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0;flex-wrap:wrap}.assistant-live-status{color:var(--text-muted);font-size:.8rem;white-space:nowrap}.assistant-toolbar-error{margin:0}.assistant-copy-btn{width:100%;justify-self:stretch;background:transparent;border-color:transparent;color:var(--text-main);font-size:.6rem;line-height:1.1;white-space:nowrap;text-align:center;letter-spacing:0;padding:6px 8px;box-shadow:none;transform:none}.assistant-copy-btn:hover{background:rgb(var(--rgb-surface-focus));filter:none;box-shadow:none;transform:none}.assistant-copy-feedback{font-size:.76rem;color:var(--text-muted)}.assistant-copy-feedback.success{color:var(--lime-main)}.assistant-copy-feedback.error{color:var(--danger)}input,select,textarea,button{font-family:Manrope,sans-serif}label{display:flex;flex-direction:column;gap:6px;color:var(--text-muted);font-size:.84rem}input,select,textarea{border:none;border-radius:var(--radius-md);background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:10px 12px;outline:none;transition:background-color .18s ease}input:focus,select:focus,textarea:focus{border-color:transparent;box-shadow:none;outline:none;background:rgb(var(--rgb-surface-focus))}textarea{resize:vertical;min-height:86px;overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable}.assistant-input-textarea,.autoruns-personality-prompt{overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable both-edges;border-bottom-right-radius:6px}.assistant-input-textarea::-webkit-scrollbar-corner,.autoruns-personality-prompt::-webkit-scrollbar-corner{background:rgb(var(--rgb-surface-horizontal))}button{border:none;border-radius:999px;background:rgb(var(--rgb-surface-horizontal));color:rgb(var(--rgb-text-main));font-weight:700;font-size:.83rem;letter-spacing:.02em;cursor:pointer;padding:9px 14px;transition:background .2s ease,color .2s ease;outline:none;box-shadow:none}button:hover{border-color:transparent;background:rgb(var(--rgb-surface-focus))}button:disabled{opacity:.52;cursor:not-allowed}.button-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:12px}.checkbox-row{flex-direction:row;align-items:center;gap:8px;color:var(--text-main)}.grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.prompt-manager-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.full-width{grid-column:1 / -1}.tab-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.tab{background:rgb(var(--rgb-surface-main));color:var(--text-main);border:none}.tab.active{border-color:transparent;background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.assistant-chat-list{flex:1 1 auto;min-height:0;overflow:auto;overscroll-behavior:contain;display:flex;flex-direction:column;gap:8px;padding:10px;border:none;border-radius:12px;background:rgb(var(--rgb-surface-horizontal))}.assistant-chat-list .assistant-msg:first-child{margin-top:auto}.assistant-empty{padding:18px;text-align:center}.assistant-msg{border:none;border-radius:12px;background:rgb(var(--rgb-surface-focus));padding:8px 10px;display:grid;gap:6px;min-width:0}.assistant-msg.user{margin-left:12%;border-color:transparent;background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.assistant-msg.assistant{margin-right:12%;border-color:transparent}.assistant-msg.user .assistant-msg-head{color:rgba(var(--rgb-active-text),.9)}.assistant-msg.user .assistant-msg-body{color:rgb(var(--rgb-active-text))}.assistant-msg-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:0;font-size:.74rem;color:var(--text-muted)}.assistant-msg-head-main{flex:1 1 auto;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:8px}.assistant-msg-head-actions{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.assistant-comment-btn{cursor:pointer}.assistant-comment-btn:disabled{opacity:.42;cursor:not-allowed}.assistant-msg.user .assistant-comment-btn{color:rgba(var(--rgb-active-text),.92)}.assistant-msg-body{display:grid;gap:10px;line-height:1.35;font-size:.84rem;min-width:0}.assistant-msg-block{display:grid;gap:4px;min-width:0}.assistant-msg-block.selectable{cursor:pointer;padding:8px 10px;border-radius:12px;transition:background .18s ease,color .18s ease}.assistant-msg-block.selectable:hover,.assistant-msg-block.selectable:focus-visible{background:rgba(var(--rgb-active),.18);outline:none}.assistant-msg-block.selectable.active{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.assistant-msg-block.selectable.active:hover,.assistant-msg-block.selectable.active:focus-visible{background:rgb(var(--rgb-active))}.assistant-msg-block.selectable.active .assistant-msg-line,.assistant-msg-block.selectable.active .assistant-msg-line strong{color:rgb(var(--rgb-active-text))}.assistant-msg-line{margin:0;white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere}.assistant-msg-line.heading{font-weight:700;letter-spacing:.01em}.assistant-msg-line.numbered{margin-top:2px}.assistant-msg-line strong{font-weight:800}.assistant-trace{margin-top:6px;color:var(--text-muted);font-size:.75rem}.assistant-debug{margin-top:8px}.assistant-debug summary{cursor:pointer;color:var(--lime-main);font-size:.8rem}.assistant-compose{margin-top:0;display:grid;gap:8px;flex:0 0 auto}.assistant-compose-context{display:grid;gap:6px;padding:10px 12px;border-radius:var(--radius-md);background:rgb(var(--rgb-surface-horizontal))}.assistant-compose-context-label{color:var(--text-muted);font-size:.74rem;font-weight:700;letter-spacing:.01em}.assistant-compose-context-pill{display:inline-flex;align-items:center;gap:8px;max-width:100%;width:fit-content;min-height:38px;padding:0 10px 0 12px;border-radius:999px;background:rgb(var(--rgb-assistant-chip-selected));color:rgb(var(--rgb-assistant-chip-selected-text))}.assistant-compose-context-pill-text{min-width:0;max-width:min(100%,460px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;font-weight:700}.assistant-compose-context-clear{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;min-width:24px;padding:0;border-radius:999px;background:#0000002e;color:inherit;font-size:.96rem;line-height:1}.assistant-compose-context-clear:hover{background:#00000047}.assistant-send-row{align-items:center;margin-top:2px}.assistant-send-btn{margin-left:auto}.assistant-comments-frame .panel-body{display:flex;flex-direction:column;min-height:0;overflow:hidden}.assistant-comments-shell{display:grid;gap:8px;min-height:0;height:100%}.assistant-comments-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px}.assistant-comments-list{display:grid;gap:8px;overflow:auto;min-height:0;padding-right:2px}.assistant-comment-item{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:6px}.assistant-comment-head{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.75rem}.assistant-comment-item p{margin:0;white-space:pre-wrap;font-size:.8rem}.assistant-comment-meta{display:flex;flex-wrap:wrap;gap:8px;color:var(--text-muted);font-size:.74rem}.app-root-autoruns .assistant-panel-frame .panel-header{position:sticky;top:-12px;z-index:8;margin:-12px -12px 0;padding:12px 12px 10px;background:rgb(var(--rgb-surface-main))}.app-root-autoruns .assistant-panel-frame{overflow:visible}.app-root-autoruns .assistant-panel-frame .panel-body{flex:1 1 auto;padding:0 12px 12px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.app-root-autoruns .assistant-panel-frame .assistant-live-shell{flex:1 1 auto;min-height:0;padding:12px;border-radius:14px;background:rgb(var(--rgb-background));display:flex;flex-direction:column;gap:10px}.app-root-autoruns .assistant-panel-frame .assistant-chat-list{overflow-y:auto}.app-root-autoruns .assistant-panel-frame .panel-header h2{margin:0;font-size:.95rem}.json-view{margin:0;width:100%;min-height:180px;max-height:420px;overflow:auto;background:rgb(var(--rgb-surface-horizontal));border:none;border-radius:var(--radius-md);padding:12px;color:rgb(var(--rgb-text-main));font-family:JetBrains Mono,Consolas,monospace;font-size:.78rem;line-height:1.45}.metrics-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.metrics-grid div{background:rgba(var(--rgb-surface-main),.8);border:none;border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:4px}.metrics-grid span{color:var(--text-muted);font-size:.75rem}.metrics-grid strong{font-size:.84rem;color:var(--lime-main)}.history-list{display:grid;gap:8px;max-height:340px;overflow:auto}.history-item{width:100%;text-align:left;border-radius:12px;border:none;background:rgb(var(--rgb-surface-main));color:var(--text-main);padding:10px}.history-item p{margin:8px 0;color:var(--text-muted);font-size:.82rem}.history-item.selected{border-color:var(--line-strong)}.history-row{display:flex;justify-content:space-between;gap:8px;font-size:.76rem;color:var(--text-muted)}.runtime-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:12px}.runtime-stack{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.runtime-details{display:grid;gap:12px}.runtime-runs{max-height:360px;overflow:auto;display:grid;gap:8px}.eval-report-wrap{position:relative}.copy-cube-button{position:absolute;right:10px;bottom:10px;width:34px;height:34px;border-radius:10px;padding:0;min-width:34px;display:grid;place-items:center;font-size:.92rem;line-height:1}.muted{color:var(--text-muted)}.diff-summary{margin-top:10px;font-size:.82rem;color:var(--lime-main)}.error-text{margin-top:10px;color:var(--danger);font-size:.84rem}.autoruns-columns{display:flex;gap:12px;width:100%;min-height:0;flex:1 1 auto;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.autoruns-col{flex:0 0 var(--mode-column-width);width:var(--mode-column-width);height:100%;min-height:0;overflow-y:auto;overflow-x:hidden;border:none;border-radius:14px;background:rgb(var(--rgb-surface-main));padding:12px;scrollbar-gutter:stable}.autoruns-settings-col{display:flex;flex-direction:column}.autoruns-settings-stack{display:grid;gap:12px}.embedded-panel-section{display:grid;gap:12px;border-radius:12px;background:rgb(var(--rgb-surface-horizontal));padding:12px}.embedded-panel-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.embedded-panel-section-header h4{margin:0;color:var(--text-main);font-size:.92rem}.embedded-panel-section-header p{margin:6px 0 0;color:var(--text-muted);font-size:.78rem;line-height:1.4}.autoruns-assistant-live-col{background:rgb(var(--rgb-surface-main));padding:12px;overflow:hidden;scrollbar-gutter:auto}.autoruns-assistant-live-col .panel-frame{height:100%;background:rgb(var(--rgb-surface-main))}.autoruns-col h3{margin:0;font-size:.95rem}.autoruns-col h4{margin:12px 0 8px;font-size:.82rem;color:var(--text-muted)}.autoruns-col-header{position:sticky;top:-12px;z-index:8;margin:-12px -12px 10px;padding:12px 12px 10px;background:rgb(var(--rgb-surface-main))}.autoruns-col-header .tab-row{margin:8px 0 0}.autoruns-col-header .autoruns-dialog-toolbar{margin-top:8px}.autoruns-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.autoruns-meta-list{display:grid;gap:8px}.autoruns-meta-list>div{display:flex;justify-content:space-between;gap:8px;border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px 9px;font-size:.79rem}.autoruns-meta-list span{color:var(--text-muted)}.autoruns-prompt-details summary{cursor:pointer;color:var(--text-main);font-size:.8rem;margin-bottom:8px}.autoruns-prompt-details textarea{min-height:68px}.autoruns-stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}.autoruns-stats-grid>div{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:3px}.autoruns-stats-grid span{color:var(--text-muted);font-size:.74rem}.autoruns-stats-grid strong{color:var(--lime-main);font-size:.84rem}.autoruns-run-list{display:grid;gap:8px;max-height:none;min-height:0;flex:1 1 auto;overflow:auto;padding-right:2px}.autoruns-run-item{width:100%;text-align:left;border-radius:12px;border:none;background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:10px;display:grid;gap:5px;transition:background-color .2s ease,box-shadow .2s ease}.autoruns-run-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text));box-shadow:none}.autoruns-run-item.selected .autoruns-run-meta{color:rgba(var(--rgb-active-text),.95)}.autoruns-run-head,.autoruns-run-foot{display:flex;justify-content:space-between;gap:8px;font-size:.76rem}.autoruns-run-meta{color:var(--text-muted);font-size:.75rem;word-break:break-word}.autoruns-run-id-row{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.autoruns-run-id-row>span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.autoruns-copy-run-id-btn{border:none;background:transparent;color:rgb(var(--rgb-text-main));width:16px;height:16px;min-width:16px;min-height:16px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;opacity:.92;cursor:pointer}.autoruns-copy-run-id-btn:hover{color:rgb(var(--rgb-text-main));opacity:1;background:transparent;box-shadow:none;transform:none}.autoruns-copy-run-id-btn:focus-visible{outline:1px solid rgba(var(--rgb-text-main),.7);outline-offset:1px}.autoruns-copy-icon-svg{width:.82rem;height:.82rem;fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.autoruns-dialog-toolbar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.autoruns-case-list{margin-top:8px;display:grid;gap:6px;max-height:180px;overflow:auto}.autoruns-case-item{width:100%;text-align:left;border-radius:10px;border:none;background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:7px 8px;display:flex;justify-content:space-between;gap:6px;font-size:.76rem}.autoruns-case-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text));box-shadow:none}.autoruns-dialog-view{margin-top:10px;border:none;border-radius:12px;background:rgb(var(--rgb-surface-horizontal));padding:10px;max-height:none;min-height:0;flex:1 1 auto;overflow:auto;display:grid;gap:8px}.autoruns-msg{border:none;border-radius:12px;background:rgb(var(--rgb-surface-focus));padding:8px 10px;display:grid;gap:6px;min-width:0;overflow:hidden}.autoruns-msg header,.autoruns-msg footer{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;min-width:0;gap:8px;font-size:.74rem;color:var(--text-muted)}.autoruns-msg-head-actions{display:flex;align-items:center;justify-content:flex-end;flex:1 1 auto;min-width:0;flex-wrap:wrap;gap:8px}.autoruns-msg-head-actions>span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.autoruns-msg-case-tag{display:inline-flex;align-items:center;border-radius:999px;padding:2px 8px;font-size:.7rem;line-height:1;color:rgb(var(--rgb-active-text));background:rgba(var(--rgb-active),.24)}.autoruns-msg p{margin:0;white-space:pre-wrap;line-height:1.35;font-size:.84rem;overflow-wrap:anywhere;word-break:break-word}.autoruns-msg footer span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.autoruns-comment-icon{border:none;background:transparent;color:rgb(var(--rgb-text-main));border-radius:0;min-width:16px;min-height:16px;width:16px;height:16px;padding:0;line-height:1;box-shadow:none;transform:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;opacity:.92}.autoruns-comment-icon:hover{background:transparent;color:rgb(var(--rgb-text-main));opacity:1;box-shadow:none;transform:none}.autoruns-comment-icon.commented{color:rgb(var(--rgb-active));background:transparent;box-shadow:none}.autoruns-comment-icon:focus-visible{outline:1px solid rgba(var(--rgb-text-main),.7);outline-offset:1px}.autoruns-comment-icon:disabled{opacity:.42;cursor:not-allowed}.comment-icon-svg{width:.82rem;height:.82rem;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;fill:none}.comment-icon-svg.commented{stroke:rgb(var(--rgb-active));fill:none}.autoruns-resolve-toggle{border:none;background:rgb(var(--rgb-surface-focus));color:rgb(var(--rgb-text-main));border-radius:999px;width:22px;height:22px;min-width:22px;min-height:22px;padding:0;display:inline-flex;align-items:center;justify-content:center;box-shadow:none;transform:none}.autoruns-resolve-toggle:hover{background:rgb(var(--rgb-surface-focus));color:rgb(var(--rgb-active));box-shadow:none;transform:none}.autoruns-resolve-toggle:disabled{opacity:.55;cursor:wait}.autoruns-resolve-toggle.resolved{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.resolve-icon-svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.resolve-icon-svg.resolved{fill:currentColor}.autoruns-msg-annotation{display:grid;gap:4px;border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:7px 8px;font-size:.78rem}.autoruns-comments-list{display:grid;gap:8px;max-height:none;min-height:0;flex:1 1 auto;overflow:auto;padding-right:2px;margin-top:6px}.autoruns-autogen-list{display:grid;gap:8px;max-height:none;min-height:0;overflow:auto;padding-right:2px}.autoruns-autogen-item{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:5px;cursor:pointer}.autoruns-autogen-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.autoruns-autogen-item.selected .autoruns-run-meta,.autoruns-autogen-item.selected p{color:rgba(var(--rgb-active-text),.95)}.autoruns-autogen-item header{display:flex;justify-content:space-between;gap:8px;font-size:.76rem}.autoruns-autogen-item p{margin:0;color:var(--text-muted);white-space:pre-wrap;font-size:.8rem}.autoruns-run-launch-btn{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.autoruns-run-launch-btn:hover{background:rgb(var(--rgb-surface-focus));color:rgb(var(--rgb-text-main))}.autoruns-run-launch-btn:disabled{background:rgba(var(--rgb-active),.38);color:rgba(var(--rgb-active-text),.88)}.autoruns-generated-questions{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:8px}.autoruns-generated-questions-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.autoruns-generated-questions-list{display:grid;gap:6px;max-height:220px;overflow:auto;padding-right:2px}.autoruns-generated-question-item{position:relative;display:block;gap:8px;border:none;border-radius:9px;background:rgb(var(--rgb-surface-focus));padding:7px 30px 7px 8px;font-size:.78rem}.autoruns-generated-question-item span{display:block;white-space:pre-wrap}.autoruns-remove-question-btn{position:absolute;top:6px;right:6px;flex:0 0 auto;border:none;border-radius:0;background:transparent;color:rgb(var(--rgb-text-main));min-width:16px;width:16px;height:16px;padding:0;font-size:1rem;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;transform:rotate(45deg);box-shadow:none;transition:color .15s ease}.autoruns-remove-question-btn:hover{background:transparent;color:rgb(var(--rgb-active-text));box-shadow:none}.autoruns-remove-question-btn:focus-visible{outline:none}.autoruns-personality-prompt{resize:vertical;min-height:110px}.autoruns-comment-item{width:100%;text-align:left;border-radius:12px;border:none;background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:9px;display:grid;gap:6px;cursor:pointer}.autoruns-comment-item p{margin:0;white-space:pre-wrap;color:var(--text-muted);font-size:.79rem}.autoruns-comment-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.autoruns-comment-item.selected p,.autoruns-comment-item.selected .autoruns-run-meta,.autoruns-comment-item.selected .muted{color:rgba(var(--rgb-active-text),.94)}.autoruns-comment-item.selected .autoruns-resolve-toggle{background:rgba(var(--rgb-active-text),.18);color:rgb(var(--rgb-active-text))}.autoruns-comment-head{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:.75rem}.autoruns-comment-head-actions{display:inline-flex;align-items:center;gap:8px}.autoruns-comment-filter-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;margin-bottom:8px}.autoruns-resolved-filter-toggle{min-height:38px;white-space:nowrap}.autoruns-msg.assistant{margin-right:12%}.autoruns-msg.user{margin-left:12%;border-color:transparent;background:rgb(var(--rgb-surface-focus))}.autoruns-decomposition-list{margin:0;padding-left:18px;display:grid;gap:7px;font-size:.8rem}.autoruns-comment-modal-backdrop{position:fixed;inset:0;background:rgba(var(--rgb-background),.74);display:grid;place-items:center;z-index:1800;padding:12px}.autoruns-comment-modal{width:min(660px,100%);border:none;border-radius:16px;background:rgb(var(--rgb-surface-horizontal));box-shadow:var(--shadow);padding:14px;display:grid;gap:10px}.autoruns-comment-modal h3{margin:0;font-size:.95rem}.autoruns-comment-quote{margin:0;border:none;border-radius:10px;background:rgb(var(--rgb-surface-focus));padding:8px;white-space:pre-wrap;max-height:150px;overflow:auto;font-size:.82rem}.autoruns-rating-row{display:flex;gap:8px}.autoruns-rating-dot{width:34px;height:34px;border-radius:999px;padding:0;border:none;background:rgb(var(--rgb-surface-focus));color:var(--text-muted);font-size:.95rem;box-shadow:none;transform:none}.autoruns-rating-dot:hover{border-color:var(--line-strong);box-shadow:none;transform:none}.autoruns-rating-dot.active{border-color:var(--line-strong);color:rgb(var(--rgb-active-text));background:rgb(var(--rgb-active))}.autoruns-coverage-list{display:grid;gap:8px}.autoruns-coverage-item{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px}.autoruns-coverage-head{display:flex;justify-content:space-between;gap:8px;font-size:.76rem;margin-bottom:5px}.autoruns-coverage-head span{color:var(--text-muted)}.autoruns-coverage-bar{height:7px;border-radius:999px;background:rgb(var(--rgb-surface-focus));overflow:hidden}.autoruns-coverage-bar>div{height:100%;border-radius:999px;background:rgb(var(--rgb-active))}@media(max-width:1200px){:root{--mode-column-width: 400px}.metrics-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:920px){:root{--mode-column-width: 360px}.grid-two,.runtime-grid,.runtime-stack{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.autoruns-form-grid,.autoruns-dialog-toolbar,.autoruns-stats-grid,.autoruns-comment-filter-row{grid-template-columns:1fr}}@media(max-width:640px){:root{--mode-column-width: 320px}.app-root{padding:18px 12px 24px}.metrics-grid{grid-template-columns:1fr}}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}} +@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;600;700;800&family=Space+Grotesk:wght@500;700&display=swap";:root{--rgb-background: 16, 16, 19;--rgb-surface-main: 26, 26, 31;--rgb-surface-horizontal: 32, 32, 38;--rgb-surface-focus: 40, 40, 47;--rgb-assistant-chip: 18, 18, 18;--rgb-assistant-chip-hover: 44, 44, 44;--rgb-assistant-chip-selected: 228, 142, 92;--rgb-assistant-chip-selected-text: 18, 18, 18;--rgb-active: 228, 142, 92;--rgb-active-text: 18, 18, 18;--rgb-text-main: 240, 240, 240;--rgb-text-muted: 166, 166, 170;--rgb-danger: 255, 126, 126;--rgb-scrollbar-track: 31, 31, 36;--rgb-scrollbar-thumb: 74, 74, 82;--rgb-scrollbar-thumb-hover: 90, 90, 100;--mode-column-width: 440px;--mode-toggle-width: 188px;--bg-main: rgb(var(--rgb-background));--bg-soft: rgb(var(--rgb-surface-main));--bg-panel: rgb(var(--rgb-surface-main));--bg-panel-accent: rgb(var(--rgb-surface-horizontal));--surface-horizontal: rgb(var(--rgb-surface-horizontal));--surface-focus: rgb(var(--rgb-surface-focus));--line: transparent;--line-strong: rgba(var(--rgb-active), .48);--text-main: rgb(var(--rgb-text-main));--text-muted: rgb(var(--rgb-text-muted));--lime-main: rgb(var(--rgb-text-main));--lime-press: rgb(var(--rgb-text-main));--danger: rgb(var(--rgb-danger));--radius-lg: 20px;--radius-md: 14px;--shadow: none;--autoruns-col-width: var(--mode-column-width)}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:rgb(var(--rgb-scrollbar-thumb)) rgb(var(--rgb-scrollbar-track))}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:rgb(var(--rgb-scrollbar-track))}*::-webkit-scrollbar-thumb{background:rgb(var(--rgb-scrollbar-thumb));border-radius:999px;border:2px solid rgb(var(--rgb-scrollbar-track))}*::-webkit-scrollbar-thumb:hover{background:rgb(var(--rgb-scrollbar-thumb-hover))}html,body,#root{margin:0;min-height:100dvh;font-family:Manrope,Segoe UI,sans-serif;background:var(--bg-main);color:var(--text-main)}.app-root{max-width:1720px;margin:0 auto;padding:12px 16px 16px}.app-root.app-root-autoruns{max-width:none;width:100%;min-height:100dvh;max-height:100dvh;display:flex;flex-direction:column;overflow:hidden}.app-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 12px;padding:0;min-height:38px}.layout-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}.layout-grid.layout-grid-autoruns,.layout-grid.layout-grid-mode-columns{min-height:0;flex:1 1 auto;grid-template-columns:minmax(0,1fr)}.mode-switch-row{display:flex;gap:8px;margin:0;padding:0}.mode-switch-row.mode-switch-row-right{margin-left:auto;justify-content:flex-end;max-width:72%;overflow-x:auto;overflow-y:hidden;padding-bottom:2px}.mode-switch-row .tab{white-space:nowrap}.mode-switch-row.mode-switch-row-right .tab{width:var(--mode-toggle-width);min-width:var(--mode-toggle-width);text-align:center}.mode-columns{display:flex;gap:12px;width:100%;min-height:0;flex:1 1 auto;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.mode-col{flex:0 0 var(--mode-column-width);width:var(--mode-column-width);min-height:0;height:100%;display:flex}.mode-col.mode-col-wide,.mode-col.mode-col-xwide{flex-basis:var(--mode-column-width);width:var(--mode-column-width)}.mode-col .panel-frame{width:100%;height:100%}.mode-col .panel-body{min-height:0;overflow:auto}.mode-columns-empty{min-width:360px;border-radius:14px;background:rgb(var(--rgb-surface-main));color:var(--text-muted);padding:14px}.panel-frame{grid-column:span 12;border:none;border-radius:var(--radius-lg);background:var(--bg-panel);overflow:hidden;box-shadow:none;animation:rise .4s ease-out;display:flex;flex-direction:column;min-height:0}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:14px 18px 10px;border-bottom:none;background:var(--bg-panel-accent)}.panel-header h2{margin:0;font-size:1.02rem;letter-spacing:.02em}.panel-header p{margin:6px 0 0;font-size:.85rem;color:var(--text-muted)}.panel-body{padding:10px 12px 12px;min-height:0}.app-root-autoruns .autoruns-frame{height:100%}.app-root-autoruns .autoruns-frame .panel-body{flex:1 1 auto;overflow:hidden;display:flex;flex-direction:column;gap:10px;padding:10px 12px 12px;background:rgb(var(--rgb-background))}.status-chip{border:none;border-radius:999px;padding:4px 10px;color:var(--lime-main);font-size:.78rem;background:rgb(var(--rgb-surface-focus))}.assistant-toolbar{display:grid;gap:8px}.assistant-toolbar-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:center;gap:8px}.assistant-toolbar-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.assistant-toolbar-meta-right{margin-left:auto;display:flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0;flex-wrap:wrap}.assistant-live-status{color:var(--text-muted);font-size:.8rem;white-space:nowrap}.assistant-toolbar-error{margin:0}.assistant-copy-btn{width:100%;justify-self:stretch;background:transparent;border-color:transparent;color:var(--text-main);font-size:.6rem;line-height:1.1;white-space:nowrap;text-align:center;letter-spacing:0;padding:6px 8px;box-shadow:none;transform:none}.assistant-copy-btn:hover{background:rgb(var(--rgb-surface-focus));filter:none;box-shadow:none;transform:none}.assistant-copy-feedback{font-size:.76rem;color:var(--text-muted)}.assistant-copy-feedback.success{color:var(--lime-main)}.assistant-copy-feedback.error{color:var(--danger)}input,select,textarea,button{font-family:Manrope,sans-serif}label{display:flex;flex-direction:column;gap:6px;color:var(--text-muted);font-size:.84rem}input,select,textarea{border:none;border-radius:var(--radius-md);background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:10px 12px;outline:none;transition:background-color .18s ease}input:focus,select:focus,textarea:focus{border-color:transparent;box-shadow:none;outline:none;background:rgb(var(--rgb-surface-focus))}textarea{resize:vertical;min-height:86px;overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable}.assistant-input-textarea,.autoruns-personality-prompt{overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable both-edges;border-bottom-right-radius:6px}.assistant-input-textarea::-webkit-scrollbar-corner,.autoruns-personality-prompt::-webkit-scrollbar-corner{background:rgb(var(--rgb-surface-horizontal))}button{border:none;border-radius:999px;background:rgb(var(--rgb-surface-horizontal));color:rgb(var(--rgb-text-main));font-weight:700;font-size:.83rem;letter-spacing:.02em;cursor:pointer;padding:9px 14px;transition:background .2s ease,color .2s ease;outline:none;box-shadow:none}button:hover{border-color:transparent;background:rgb(var(--rgb-surface-focus))}button:disabled{opacity:.52;cursor:not-allowed}.button-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:12px}.checkbox-row{flex-direction:row;align-items:center;gap:8px;color:var(--text-main)}.grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.prompt-manager-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.full-width{grid-column:1 / -1}.tab-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.tab{background:rgb(var(--rgb-surface-main));color:var(--text-main);border:none}.tab.active{border-color:transparent;background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.assistant-chat-list{flex:1 1 auto;min-height:0;overflow:auto;overscroll-behavior:contain;display:flex;flex-direction:column;gap:8px;padding:10px;border:none;border-radius:12px;background:rgb(var(--rgb-surface-horizontal))}.assistant-chat-list .assistant-msg:first-child{margin-top:auto}.assistant-empty{padding:18px;text-align:center}.assistant-msg{border:none;border-radius:12px;background:rgb(var(--rgb-surface-focus));padding:8px 10px;display:grid;gap:6px;min-width:0}.assistant-msg.user{margin-left:12%;border-color:transparent;background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.assistant-msg.assistant{margin-right:12%;border-color:transparent}.assistant-msg.user .assistant-msg-head{color:rgba(var(--rgb-active-text),.9)}.assistant-msg.user .assistant-msg-body{color:rgb(var(--rgb-active-text))}.assistant-msg-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:0;font-size:.74rem;color:var(--text-muted)}.assistant-msg-head-main{flex:1 1 auto;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:8px}.assistant-msg-head-actions{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.assistant-comment-btn{cursor:pointer}.assistant-comment-btn:disabled{opacity:.42;cursor:not-allowed}.assistant-msg.user .assistant-comment-btn{color:rgba(var(--rgb-active-text),.92)}.assistant-msg-body{display:grid;gap:10px;line-height:1.35;font-size:.84rem;min-width:0}.assistant-msg-block{display:grid;gap:4px;min-width:0}.assistant-msg-block.selectable{cursor:pointer;padding:8px 10px;border-radius:12px;transition:background .18s ease,color .18s ease}.assistant-msg-block.selectable:hover,.assistant-msg-block.selectable:focus-visible{background:rgba(var(--rgb-active),.18);outline:none}.assistant-msg-block.selectable.active{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.assistant-msg-block.selectable.active:hover,.assistant-msg-block.selectable.active:focus-visible{background:rgb(var(--rgb-active))}.assistant-msg-block.selectable.active .assistant-msg-line,.assistant-msg-block.selectable.active .assistant-msg-line strong{color:rgb(var(--rgb-active-text))}.assistant-msg-line{margin:0;white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere}.assistant-msg-line.heading{font-weight:700;letter-spacing:.01em}.assistant-msg-line.numbered{margin-top:2px}.assistant-msg-line strong{font-weight:800}.assistant-trace{margin-top:6px;color:var(--text-muted);font-size:.75rem}.assistant-debug{margin-top:8px}.assistant-debug summary{cursor:pointer;color:var(--lime-main);font-size:.8rem}.assistant-compose{margin-top:0;display:grid;gap:8px;flex:0 0 auto}.assistant-compose-context{display:grid;gap:6px;padding:10px 12px;border-radius:var(--radius-md);background:rgb(var(--rgb-surface-horizontal))}.assistant-compose-context-label{color:var(--text-muted);font-size:.74rem;font-weight:700;letter-spacing:.01em}.assistant-compose-context-pill{display:inline-flex;align-items:center;gap:8px;max-width:100%;width:fit-content;min-height:38px;padding:0 10px 0 12px;border-radius:999px;background:rgb(var(--rgb-assistant-chip-selected));color:rgb(var(--rgb-assistant-chip-selected-text))}.assistant-compose-context-pill-text{min-width:0;max-width:min(100%,460px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;font-weight:700}.assistant-compose-context-clear{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;min-width:24px;padding:0;border-radius:999px;background:#0000002e;color:inherit;font-size:.96rem;line-height:1}.assistant-compose-context-clear:hover{background:#00000047}.assistant-send-row{align-items:center;margin-top:2px}.assistant-send-btn{margin-left:auto}.assistant-comments-frame .panel-body{display:flex;flex-direction:column;min-height:0;overflow:hidden}.assistant-comments-shell{display:grid;gap:8px;min-height:0;height:100%}.assistant-comments-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px}.assistant-comments-list{display:grid;gap:8px;overflow:auto;min-height:0;padding-right:2px}.assistant-comment-item{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:6px}.assistant-comment-head{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.75rem}.assistant-comment-item p{margin:0;white-space:pre-wrap;font-size:.8rem}.assistant-comment-meta{display:flex;flex-wrap:wrap;gap:8px;color:var(--text-muted);font-size:.74rem}.app-root-autoruns .assistant-panel-frame .panel-header{position:sticky;top:-12px;z-index:8;margin:-12px -12px 0;padding:12px 12px 10px;background:rgb(var(--rgb-surface-main))}.app-root-autoruns .assistant-panel-frame{overflow:visible}.app-root-autoruns .assistant-panel-frame .panel-body{flex:1 1 auto;padding:0 12px 12px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.app-root-autoruns .assistant-panel-frame .assistant-live-shell{flex:1 1 auto;min-height:0;padding:12px;border-radius:14px;background:rgb(var(--rgb-background));display:flex;flex-direction:column;gap:10px}.app-root-autoruns .assistant-panel-frame .assistant-chat-list{overflow-y:auto}.app-root-autoruns .assistant-panel-frame .panel-header h2{margin:0;font-size:.95rem}.json-view{margin:0;width:100%;min-height:180px;max-height:420px;overflow:auto;background:rgb(var(--rgb-surface-horizontal));border:none;border-radius:var(--radius-md);padding:12px;color:rgb(var(--rgb-text-main));font-family:JetBrains Mono,Consolas,monospace;font-size:.78rem;line-height:1.45}.metrics-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.metrics-grid div{background:rgba(var(--rgb-surface-main),.8);border:none;border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:4px}.metrics-grid span{color:var(--text-muted);font-size:.75rem}.metrics-grid strong{font-size:.84rem;color:var(--lime-main)}.history-list{display:grid;gap:8px;max-height:340px;overflow:auto}.history-item{width:100%;text-align:left;border-radius:12px;border:none;background:rgb(var(--rgb-surface-main));color:var(--text-main);padding:10px}.history-item p{margin:8px 0;color:var(--text-muted);font-size:.82rem}.history-item.selected{border-color:var(--line-strong)}.history-row{display:flex;justify-content:space-between;gap:8px;font-size:.76rem;color:var(--text-muted)}.runtime-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:12px}.runtime-stack{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.runtime-details{display:grid;gap:12px}.runtime-runs{max-height:360px;overflow:auto;display:grid;gap:8px}.eval-report-wrap{position:relative}.copy-cube-button{position:absolute;right:10px;bottom:10px;width:34px;height:34px;border-radius:10px;padding:0;min-width:34px;display:grid;place-items:center;font-size:.92rem;line-height:1}.muted{color:var(--text-muted)}.diff-summary{margin-top:10px;font-size:.82rem;color:var(--lime-main)}.error-text{margin-top:10px;color:var(--danger);font-size:.84rem}.autoruns-columns{display:flex;gap:12px;width:100%;min-height:0;flex:1 1 auto;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.autoruns-col{flex:0 0 var(--mode-column-width);width:var(--mode-column-width);height:100%;min-height:0;overflow-y:auto;overflow-x:hidden;border:none;border-radius:14px;background:rgb(var(--rgb-surface-main));padding:12px;scrollbar-gutter:stable}.autoruns-settings-col{display:flex;flex-direction:column}.autoruns-settings-stack{display:grid;gap:12px}.embedded-panel-section{display:grid;gap:12px;border-radius:12px;background:rgb(var(--rgb-surface-horizontal));padding:12px}.embedded-panel-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.embedded-panel-section-header h4{margin:0;color:var(--text-main);font-size:.92rem}.embedded-panel-section-header p{margin:6px 0 0;color:var(--text-muted);font-size:.78rem;line-height:1.4}.autoruns-assistant-live-col{background:rgb(var(--rgb-surface-main));padding:12px;overflow:hidden;scrollbar-gutter:auto}.autoruns-assistant-live-col .panel-frame{height:100%;background:rgb(var(--rgb-surface-main))}.autoruns-col h3{margin:0;font-size:.95rem}.autoruns-col h4{margin:12px 0 8px;font-size:.82rem;color:var(--text-muted)}.autoruns-col-header{position:sticky;top:-12px;z-index:8;margin:-12px -12px 10px;padding:12px 12px 10px;background:rgb(var(--rgb-surface-main))}.autoruns-col-header .tab-row{margin:8px 0 0}.autoruns-col-header .autoruns-dialog-toolbar{margin-top:8px}.autoruns-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.autoruns-meta-list{display:grid;gap:8px}.autoruns-meta-list>div{display:flex;justify-content:space-between;gap:8px;border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px 9px;font-size:.79rem}.autoruns-meta-list span{color:var(--text-muted)}.autoruns-prompt-details summary{cursor:pointer;color:var(--text-main);font-size:.8rem;margin-bottom:8px}.autoruns-prompt-details textarea{min-height:68px}.autoruns-stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}.autoruns-stats-grid>div{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:3px}.autoruns-stats-grid span{color:var(--text-muted);font-size:.74rem}.autoruns-stats-grid strong{color:var(--lime-main);font-size:.84rem}.autoruns-run-list{display:grid;gap:8px;max-height:none;min-height:0;flex:1 1 auto;overflow:auto;padding-right:2px}.autoruns-run-item{width:100%;text-align:left;border-radius:12px;border:none;background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:10px;display:grid;gap:5px;transition:background-color .2s ease,box-shadow .2s ease}.autoruns-run-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text));box-shadow:none}.autoruns-run-item.selected .autoruns-run-meta{color:rgba(var(--rgb-active-text),.95)}.autoruns-run-head,.autoruns-run-foot{display:flex;justify-content:space-between;gap:8px;font-size:.76rem}.autoruns-run-meta{color:var(--text-muted);font-size:.75rem;word-break:break-word}.autoruns-run-id-row{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.autoruns-run-id-row>span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.autoruns-copy-run-id-btn{border:none;background:transparent;color:rgb(var(--rgb-text-main));width:16px;height:16px;min-width:16px;min-height:16px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;opacity:.92;cursor:pointer}.autoruns-copy-run-id-btn:hover{color:rgb(var(--rgb-text-main));opacity:1;background:transparent;box-shadow:none;transform:none}.autoruns-copy-run-id-btn:focus-visible{outline:1px solid rgba(var(--rgb-text-main),.7);outline-offset:1px}.autoruns-copy-icon-svg{width:.82rem;height:.82rem;fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.autoruns-dialog-toolbar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.autoruns-case-list{margin-top:8px;display:grid;gap:6px;max-height:180px;overflow:auto}.autoruns-case-item{width:100%;text-align:left;border-radius:10px;border:none;background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:7px 8px;display:flex;justify-content:space-between;gap:6px;font-size:.76rem}.autoruns-case-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text));box-shadow:none}.autoruns-dialog-view{margin-top:10px;border:none;border-radius:12px;background:rgb(var(--rgb-surface-horizontal));padding:10px;max-height:none;min-height:0;flex:1 1 auto;overflow:auto;display:grid;gap:8px}.autoruns-msg{border:none;border-radius:12px;background:rgb(var(--rgb-surface-focus));padding:8px 10px;display:grid;gap:6px;min-width:0;overflow:hidden}.autoruns-msg header,.autoruns-msg footer{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;min-width:0;gap:8px;font-size:.74rem;color:var(--text-muted)}.autoruns-msg-head-actions{display:flex;align-items:center;justify-content:flex-end;flex:1 1 auto;min-width:0;flex-wrap:wrap;gap:8px}.autoruns-msg-head-actions>span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.autoruns-msg-case-tag{display:inline-flex;align-items:center;border-radius:999px;padding:2px 8px;font-size:.7rem;line-height:1;color:rgb(var(--rgb-active-text));background:rgba(var(--rgb-active),.24)}.autoruns-msg p{margin:0;white-space:pre-wrap;line-height:1.35;font-size:.84rem;overflow-wrap:anywhere;word-break:break-word}.autoruns-msg footer span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.autoruns-comment-icon{border:none;background:transparent;color:rgb(var(--rgb-text-main));border-radius:0;min-width:16px;min-height:16px;width:16px;height:16px;padding:0;line-height:1;box-shadow:none;transform:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;opacity:.92}.autoruns-comment-icon:hover{background:transparent;color:rgb(var(--rgb-text-main));opacity:1;box-shadow:none;transform:none}.autoruns-comment-icon.commented{color:rgb(var(--rgb-active));background:transparent;box-shadow:none}.autoruns-comment-icon:focus-visible{outline:1px solid rgba(var(--rgb-text-main),.7);outline-offset:1px}.autoruns-comment-icon:disabled{opacity:.42;cursor:not-allowed}.comment-icon-svg{width:.82rem;height:.82rem;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;fill:none}.comment-icon-svg.commented{stroke:rgb(var(--rgb-active));fill:none}.autoruns-resolve-toggle{border:none;background:rgb(var(--rgb-surface-focus));color:rgb(var(--rgb-text-main));border-radius:999px;width:22px;height:22px;min-width:22px;min-height:22px;padding:0;display:inline-flex;align-items:center;justify-content:center;box-shadow:none;transform:none}.autoruns-resolve-toggle:hover{background:rgb(var(--rgb-surface-focus));color:rgb(var(--rgb-active));box-shadow:none;transform:none}.autoruns-resolve-toggle:disabled{opacity:.55;cursor:wait}.autoruns-resolve-toggle.resolved{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.resolve-icon-svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.resolve-icon-svg.resolved{fill:currentColor}.autoruns-msg-annotation{display:grid;gap:4px;border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:7px 8px;font-size:.78rem}.autoruns-comments-list{display:grid;gap:8px;max-height:none;min-height:0;flex:1 1 auto;overflow:auto;padding-right:2px;margin-top:6px}.autoruns-autogen-list{display:grid;gap:8px;max-height:none;min-height:0;overflow:auto;padding-right:2px}.autoruns-autogen-item{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:5px;cursor:pointer}.autoruns-autogen-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.autoruns-autogen-item.selected .autoruns-run-meta,.autoruns-autogen-item.selected p{color:rgba(var(--rgb-active-text),.95)}.autoruns-autogen-item header{display:flex;justify-content:space-between;gap:8px;font-size:.76rem}.autoruns-autogen-item p{margin:0;color:var(--text-muted);white-space:pre-wrap;font-size:.8rem}.autoruns-run-launch-btn{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.autoruns-run-launch-btn:hover{background:rgb(var(--rgb-surface-focus));color:rgb(var(--rgb-text-main))}.autoruns-run-launch-btn:disabled{background:rgba(var(--rgb-active),.38);color:rgba(var(--rgb-active-text),.88)}.autoruns-generated-questions{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:8px}.autoruns-generated-questions-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.autoruns-generated-questions-list{display:grid;gap:6px;max-height:220px;overflow:auto;padding-right:2px}.autoruns-generated-question-item{position:relative;display:block;gap:8px;border:none;border-radius:9px;background:rgb(var(--rgb-surface-focus));padding:7px 30px 7px 8px;font-size:.78rem}.autoruns-generated-question-item span{display:block;white-space:pre-wrap}.autoruns-remove-question-btn{position:absolute;top:6px;right:6px;flex:0 0 auto;border:none;border-radius:0;background:transparent;color:rgb(var(--rgb-text-main));min-width:16px;width:16px;height:16px;padding:0;font-size:1rem;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;box-shadow:none;transition:color .15s ease}.autoruns-remove-question-btn:hover{background:transparent;color:rgb(var(--rgb-active));box-shadow:none}.autoruns-remove-question-btn:focus-visible{outline:none}.autoruns-personality-prompt{resize:vertical;min-height:110px}.autoruns-comment-item{width:100%;text-align:left;border-radius:12px;border:none;background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:9px;display:grid;gap:6px;cursor:pointer}.autoruns-comment-item p{margin:0;white-space:pre-wrap;color:var(--text-muted);font-size:.79rem}.autoruns-comment-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.autoruns-comment-item.selected p,.autoruns-comment-item.selected .autoruns-run-meta,.autoruns-comment-item.selected .muted{color:rgba(var(--rgb-active-text),.94)}.autoruns-comment-item.selected .autoruns-resolve-toggle{background:rgba(var(--rgb-active-text),.18);color:rgb(var(--rgb-active-text))}.autoruns-comment-head{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:.75rem}.autoruns-comment-head-actions{display:inline-flex;align-items:center;gap:8px}.autoruns-comment-filter-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;margin-bottom:8px}.autoruns-resolved-filter-toggle{min-height:38px;white-space:nowrap}.autoruns-msg.assistant{margin-right:12%}.autoruns-msg.user{margin-left:12%;border-color:transparent;background:rgb(var(--rgb-surface-focus))}.autoruns-decomposition-list{margin:0;padding-left:18px;display:grid;gap:7px;font-size:.8rem}.autoruns-comment-modal-backdrop{position:fixed;inset:0;background:rgba(var(--rgb-background),.74);display:grid;place-items:center;z-index:1800;padding:12px}.autoruns-comment-modal{width:min(660px,100%);border:none;border-radius:16px;background:rgb(var(--rgb-surface-horizontal));box-shadow:var(--shadow);padding:14px;display:grid;gap:10px}.autoruns-comment-modal h3{margin:0;font-size:.95rem}.autoruns-comment-quote{margin:0;border:none;border-radius:10px;background:rgb(var(--rgb-surface-focus));padding:8px;white-space:pre-wrap;max-height:150px;overflow:auto;font-size:.82rem}.autoruns-rating-row{display:flex;gap:8px}.autoruns-rating-dot{width:34px;height:34px;border-radius:999px;padding:0;border:none;background:rgb(var(--rgb-surface-focus));color:var(--text-muted);font-size:.95rem;box-shadow:none;transform:none}.autoruns-rating-dot:hover{border-color:var(--line-strong);box-shadow:none;transform:none}.autoruns-rating-dot.active{border-color:var(--line-strong);color:rgb(var(--rgb-active-text));background:rgb(var(--rgb-active))}.autoruns-coverage-list{display:grid;gap:8px}.autoruns-coverage-item{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px}.autoruns-coverage-head{display:flex;justify-content:space-between;gap:8px;font-size:.76rem;margin-bottom:5px}.autoruns-coverage-head span{color:var(--text-muted)}.autoruns-coverage-bar{height:7px;border-radius:999px;background:rgb(var(--rgb-surface-focus));overflow:hidden}.autoruns-coverage-bar>div{height:100%;border-radius:999px;background:rgb(var(--rgb-active))}.autoruns-autogen-card-actions{display:inline-flex;align-items:center;gap:8px}.autoruns-autogen-delete-btn{border:none;border-radius:0;width:22px;height:22px;min-width:22px;padding:0;background:transparent;color:rgb(var(--rgb-text-main));display:inline-flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;line-height:1;box-shadow:none;transition:color .15s ease}.autoruns-autogen-delete-btn:hover{background:transparent;color:rgb(var(--rgb-active));box-shadow:none}@media(max-width:1200px){:root{--mode-column-width: 400px}.metrics-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:920px){:root{--mode-column-width: 360px}.grid-two,.runtime-grid,.runtime-stack{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.autoruns-form-grid,.autoruns-dialog-toolbar,.autoruns-stats-grid,.autoruns-comment-filter-row{grid-template-columns:1fr}}@media(max-width:640px){:root{--mode-column-width: 320px}.app-root{padding:18px 12px 24px}.metrics-grid{grid-template-columns:1fr}}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}} diff --git a/llm_normalizer/frontend/dist/assets/index-VJV2AL7G.js b/llm_normalizer/frontend/dist/assets/index-VJV2AL7G.js deleted file mode 100644 index 4596d5a..0000000 --- a/llm_normalizer/frontend/dist/assets/index-VJV2AL7G.js +++ /dev/null @@ -1,26 +0,0 @@ -(function(){const p=document.createElement("link").relList;if(p&&p.supports&&p.supports("modulepreload"))return;for(const j of document.querySelectorAll('link[rel="modulepreload"]'))N(j);new MutationObserver(j=>{for(const T of j)if(T.type==="childList")for(const $ of T.addedNodes)$.tagName==="LINK"&&$.rel==="modulepreload"&&N($)}).observe(document,{childList:!0,subtree:!0});function f(j){const T={};return j.integrity&&(T.integrity=j.integrity),j.referrerPolicy&&(T.referrerPolicy=j.referrerPolicy),j.crossOrigin==="use-credentials"?T.credentials="include":j.crossOrigin==="anonymous"?T.credentials="omit":T.credentials="same-origin",T}function N(j){if(j.ep)return;j.ep=!0;const T=f(j);fetch(j.href,T)}})();function Vc(i){return i&&i.__esModule&&Object.prototype.hasOwnProperty.call(i,"default")?i.default:i}var Wi={exports:{}},mo={},qi={exports:{}},he={};var Sc;function wf(){if(Sc)return he;Sc=1;var i=Symbol.for("react.element"),p=Symbol.for("react.portal"),f=Symbol.for("react.fragment"),N=Symbol.for("react.strict_mode"),j=Symbol.for("react.profiler"),T=Symbol.for("react.provider"),$=Symbol.for("react.context"),Y=Symbol.for("react.forward_ref"),b=Symbol.for("react.suspense"),Q=Symbol.for("react.memo"),G=Symbol.for("react.lazy"),z=Symbol.iterator;function ne(y){return y===null||typeof y!="object"?null:(y=z&&y[z]||y["@@iterator"],typeof y=="function"?y:null)}var Ne={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},le=Object.assign,ce={};function me(y,C,J){this.props=y,this.context=C,this.refs=ce,this.updater=J||Ne}me.prototype.isReactComponent={},me.prototype.setState=function(y,C){if(typeof y!="object"&&typeof y!="function"&&y!=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,y,C,"setState")},me.prototype.forceUpdate=function(y){this.updater.enqueueForceUpdate(this,y,"forceUpdate")};function Qe(){}Qe.prototype=me.prototype;function De(y,C,J){this.props=y,this.context=C,this.refs=ce,this.updater=J||Ne}var We=De.prototype=new Qe;We.constructor=De,le(We,me.prototype),We.isPureReactComponent=!0;var je=Array.isArray,W=Object.prototype.hasOwnProperty,de={current:null},Me={key:!0,ref:!0,__self:!0,__source:!0};function Ze(y,C,J){var oe,pe={},ae=null,Se=null;if(C!=null)for(oe in C.ref!==void 0&&(Se=C.ref),C.key!==void 0&&(ae=""+C.key),C)W.call(C,oe)&&!Me.hasOwnProperty(oe)&&(pe[oe]=C[oe]);var ge=arguments.length-2;if(ge===1)pe.children=J;else if(1>>1,C=I[y];if(0>>1;yj(pe,O))aej(Se,pe)?(I[y]=Se,I[ae]=O,y=ae):(I[y]=pe,I[oe]=O,y=oe);else if(aej(Se,O))I[y]=Se,I[ae]=O,y=ae;else break e}}return X}function j(I,X){var O=I.sortIndex-X.sortIndex;return O!==0?O:I.id-X.id}if(typeof performance=="object"&&typeof performance.now=="function"){var T=performance;i.unstable_now=function(){return T.now()}}else{var $=Date,Y=$.now();i.unstable_now=function(){return $.now()-Y}}var b=[],Q=[],G=1,z=null,ne=3,Ne=!1,le=!1,ce=!1,me=typeof setTimeout=="function"?setTimeout:null,Qe=typeof clearTimeout=="function"?clearTimeout:null,De=typeof setImmediate<"u"?setImmediate:null;typeof navigator<"u"&&navigator.scheduling!==void 0&&navigator.scheduling.isInputPending!==void 0&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function We(I){for(var X=f(Q);X!==null;){if(X.callback===null)N(Q);else if(X.startTime<=I)N(Q),X.sortIndex=X.expirationTime,p(b,X);else break;X=f(Q)}}function je(I){if(ce=!1,We(I),!le)if(f(b)!==null)le=!0,Te(W);else{var X=f(Q);X!==null&&Ae(je,X.startTime-I)}}function W(I,X){le=!1,ce&&(ce=!1,Qe(Ze),Ze=-1),Ne=!0;var O=ne;try{for(We(X),z=f(b);z!==null&&(!(z.expirationTime>X)||I&&!Et());){var y=z.callback;if(typeof y=="function"){z.callback=null,ne=z.priorityLevel;var C=y(z.expirationTime<=X);X=i.unstable_now(),typeof C=="function"?z.callback=C:z===f(b)&&N(b),We(X)}else N(b);z=f(b)}if(z!==null)var J=!0;else{var oe=f(Q);oe!==null&&Ae(je,oe.startTime-X),J=!1}return J}finally{z=null,ne=O,Ne=!1}}var de=!1,Me=null,Ze=-1,ct=5,st=-1;function Et(){return!(i.unstable_now()-stI||125y?(I.sortIndex=O,p(Q,I),f(b)===null&&I===f(Q)&&(ce?(Qe(Ze),Ze=-1):ce=!0,Ae(je,O-y))):(I.sortIndex=C,p(b,I),le||Ne||(le=!0,Te(W))),I},i.unstable_shouldYield=Et,i.unstable_wrapCallback=function(I){var X=ne;return function(){var O=ne;ne=X;try{return I.apply(this,arguments)}finally{ne=O}}}})(Ji)),Ji}var Nc;function Ef(){return Nc||(Nc=1,Gi.exports=Nf()),Gi.exports}var Ec;function Pf(){if(Ec)return Wt;Ec=1;var i=aa(),p=Ef();function f(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"),b=Object.prototype.hasOwnProperty,Q=/^[: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]*$/,G={},z={};function ne(e){return b.call(z,e)?!0:b.call(G,e)?!1:Q.test(e)?z[e]=!0:(G[e]=!0,!1)}function Ne(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 le(e,t,n,r){if(t===null||typeof t>"u"||Ne(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 ce(e,t,n,r,s,l,u){this.acceptsBooleans=t===2||t===3||t===4,this.attributeName=r,this.attributeNamespace=s,this.mustUseProperty=n,this.propertyName=e,this.type=t,this.sanitizeURL=l,this.removeEmptyString=u}var me={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(e){me[e]=new ce(e,0,!1,e,null,!1,!1)}),[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(e){var t=e[0];me[t]=new ce(t,1,!1,e[1],null,!1,!1)}),["contentEditable","draggable","spellCheck","value"].forEach(function(e){me[e]=new ce(e,2,!1,e.toLowerCase(),null,!1,!1)}),["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(e){me[e]=new ce(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){me[e]=new ce(e,3,!1,e.toLowerCase(),null,!1,!1)}),["checked","multiple","muted","selected"].forEach(function(e){me[e]=new ce(e,3,!0,e,null,!1,!1)}),["capture","download"].forEach(function(e){me[e]=new ce(e,4,!1,e,null,!1,!1)}),["cols","rows","size","span"].forEach(function(e){me[e]=new ce(e,6,!1,e,null,!1,!1)}),["rowSpan","start"].forEach(function(e){me[e]=new ce(e,5,!1,e.toLowerCase(),null,!1,!1)});var Qe=/[\-:]([a-z])/g;function De(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(Qe,De);me[t]=new ce(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(Qe,De);me[t]=new ce(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(Qe,De);me[t]=new ce(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1,!1)}),["tabIndex","crossOrigin"].forEach(function(e){me[e]=new ce(e,1,!1,e.toLowerCase(),null,!1,!1)}),me.xlinkHref=new ce("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1),["src","href","action","formAction"].forEach(function(e){me[e]=new ce(e,1,!1,e.toLowerCase(),null,!0,!0)});function We(e,t,n,r){var s=me.hasOwnProperty(t)?me[t]:null;(s!==null?s.type!==0:r||!(2d||s[u]!==l[d]){var h=` -`+s[u].replace(" at new "," at ");return e.displayName&&h.includes("")&&(h=h.replace("",e.displayName)),h}while(1<=u&&0<=d);break}}}finally{J=!1,Error.prepareStackTrace=n}return(e=e?e.displayName||e.name:"")?C(e):""}function pe(e){switch(e.tag){case 5:return C(e.type);case 16:return C("Lazy");case 13:return C("Suspense");case 19:return C("SuspenseList");case 0:case 2:case 15:return e=oe(e.type,!1),e;case 11:return e=oe(e.type.render,!1),e;case 1:return e=oe(e.type,!0),e;default:return""}}function ae(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 Me:return"Fragment";case de:return"Portal";case ct:return"Profiler";case Ze:return"StrictMode";case Le:return"Suspense";case H:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case Et:return(e.displayName||"Context")+".Consumer";case st:return(e._context.displayName||"Context")+".Provider";case ie:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case Fe:return t=e.displayName||null,t!==null?t:ae(e.type)||"Memo";case Te:t=e._payload,e=e._init;try{return ae(e(t))}catch{}}return null}function Se(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 ae(t);case 8:return t===Ze?"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 ge(e){switch(typeof e){case"boolean":case"number":case"string":case"undefined":return e;case"object":return e;default:return""}}function ve(e){var t=e.type;return(e=e.nodeName)&&e.toLowerCase()==="input"&&(t==="checkbox"||t==="radio")}function Ee(e){var t=ve(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 s=n.get,l=n.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return s.call(this)},set:function(u){r=""+u,l.call(this,u)}}),Object.defineProperty(e,t,{enumerable:n.enumerable}),{getValue:function(){return r},setValue:function(u){r=""+u},stopTracking:function(){e._valueTracker=null,delete e[t]}}}}function gn(e){e._valueTracker||(e._valueTracker=Ee(e))}function vn(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var n=t.getValue(),r="";return e&&(r=ve(e)?e.checked?"true":"false":e.value),e=r,e!==n?(t.setValue(e),!0):!1}function Yn(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 Ln(e,t){var n=t.checked;return O({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:n??e._wrapperState.initialChecked})}function Xn(e,t){var n=t.defaultValue==null?"":t.defaultValue,r=t.checked!=null?t.checked:t.defaultChecked;n=ge(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 Pe(e,t){t=t.checked,t!=null&&We(e,"checked",t,!1)}function qt(e,t){Pe(e,t);var n=ge(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")?dt(e,t.type,n):t.hasOwnProperty("defaultValue")&&dt(e,t.type,ge(t.defaultValue)),t.checked==null&&t.defaultChecked!=null&&(e.defaultChecked=!!t.defaultChecked)}function ot(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 dt(e,t,n){(t!=="number"||Yn(e.ownerDocument)!==e)&&(n==null?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+n&&(e.defaultValue=""+n))}var lt=Array.isArray;function yn(e,t,n,r){if(e=e.options,t){t={};for(var s=0;s"+t.valueOf().toString()+"",t=xt.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}});function Oe(e,t){if(t){var n=e.firstChild;if(n&&n===e.lastChild&&n.nodeType===3){n.nodeValue=t;return}}e.textContent=t}var rn={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},On=["Webkit","ms","Moz","O"];Object.keys(rn).forEach(function(e){On.forEach(function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),rn[t]=rn[e]})});function xr(e,t,n){return t==null||typeof t=="boolean"||t===""?"":n||typeof t!="number"||t===0||rn.hasOwnProperty(e)&&rn[e]?(""+t).trim():t+"px"}function Dn(e,t){e=e.style;for(var n in t)if(t.hasOwnProperty(n)){var r=n.indexOf("--")===0,s=xr(n,t[n],r);n==="float"&&(n="cssFloat"),r?e.setProperty(n,s):e[n]=s}}var Qr=O({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 Sn(e,t){if(t){if(Qr[e]&&(t.children!=null||t.dangerouslySetInnerHTML!=null))throw Error(f(137,e));if(t.dangerouslySetInnerHTML!=null){if(t.children!=null)throw Error(f(60));if(typeof t.dangerouslySetInnerHTML!="object"||!("__html"in t.dangerouslySetInnerHTML))throw Error(f(61))}if(t.style!=null&&typeof t.style!="object")throw Error(f(62))}}function sn(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 Lt=null;function Zn(e){return e=e.target||e.srcElement||window,e.correspondingUseElement&&(e=e.correspondingUseElement),e.nodeType===3?e.parentNode:e}var Kt=null,on=null,Ot=null;function _r(e){if(e=Ys(e)){if(typeof Kt!="function")throw Error(f(280));var t=e.stateNode;t&&(t=ko(t),Kt(e.stateNode,e.type,t))}}function zn(e){on?Ot?Ot.push(e):Ot=[e]:on=e}function Sr(){if(on){var e=on,t=Ot;if(Ot=on=null,_r(e),t)for(e=0;e>>=0,e===0?32:31-(sr(e)/Hn|0)|0}var $t=64,kn=4194304;function At(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 ke(e,t){var n=e.pendingLanes;if(n===0)return 0;var r=0,s=e.suspendedLanes,l=e.pingedLanes,u=n&268435455;if(u!==0){var d=u&~s;d!==0?r=At(d):(l&=u,l!==0&&(r=At(l)))}else u=n&~s,u!==0?r=At(u):l!==0&&(r=At(l));if(r===0)return 0;if(t!==0&&t!==r&&(t&s)===0&&(s=r&-r,l=t&-t,s>=l||s===16&&(l&4194240)!==0))return t;if((r&4)!==0&&(r|=n&16),t=e.entangledLanes,t!==0)for(e=e.entanglements,t&=r;0n;n++)t.push(e);return t}function it(e,t,n){e.pendingLanes|=t,t!==536870912&&(e.suspendedLanes=0,e.pingedLanes=0),e=e.eventTimes,t=31-be(t),e[t]=n}function lr(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=Bs),pa=" ",ha=!1;function ga(e,t){switch(e){case"keyup":return gd.indexOf(t.keyCode)!==-1;case"keydown":return t.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function va(e){return e=e.detail,typeof e=="object"&&"data"in e?e.data:null}var gs=!1;function yd(e,t){switch(e){case"compositionend":return va(t);case"keypress":return t.which!==32?null:(ha=!0,pa);case"textInput":return e=t.data,e===pa&&ha?null:e;default:return null}}function xd(e,t){if(gs)return e==="compositionend"||!Nl&&ga(e,t)?(e=R(),v=c=a=null,gs=!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=ka(n)}}function Na(e,t){return e&&t?e===t?!0:e&&e.nodeType===3?!1:t&&t.nodeType===3?Na(e,t.parentNode):"contains"in e?e.contains(t):e.compareDocumentPosition?!!(e.compareDocumentPosition(t)&16):!1:!1}function Ea(){for(var e=window,t=Yn();t instanceof e.HTMLIFrameElement;){try{var n=typeof t.contentWindow.location.href=="string"}catch{n=!1}if(n)e=t.contentWindow;else break;t=Yn(e.document)}return t}function Ml(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 Pd(e){var t=Ea(),n=e.focusedElem,r=e.selectionRange;if(t!==n&&n&&n.ownerDocument&&Na(n.ownerDocument.documentElement,n)){if(r!==null&&Ml(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 s=n.textContent.length,l=Math.min(r.start,s);r=r.end===void 0?l:Math.min(r.end,s),!e.extend&&l>r&&(s=r,r=l,l=s),s=Ca(n,l);var u=Ca(n,r);s&&u&&(e.rangeCount!==1||e.anchorNode!==s.node||e.anchorOffset!==s.offset||e.focusNode!==u.node||e.focusOffset!==u.offset)&&(t=t.createRange(),t.setStart(s.node,s.offset),e.removeAllRanges(),l>r?(e.addRange(t),e.extend(u.node,u.offset)):(t.setEnd(u.node,u.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,vs=null,Al=null,Ws=null,Rl=!1;function Pa(e,t,n){var r=n.window===n?n.document:n.nodeType===9?n:n.ownerDocument;Rl||vs==null||vs!==Yn(r)||(r=vs,"selectionStart"in r&&Ml(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}),Ws&&Qs(Ws,r)||(Ws=r,r=So(Al,"onSelect"),0ws||(e.current=Hl[ws],Hl[ws]=null,ws--)}function $e(e,t){ws++,Hl[ws]=e.current,e.current=t}var Ir={},wt=Tr(Ir),bt=Tr(!1),Zr=Ir;function js(e,t){var n=e.type.contextTypes;if(!n)return Ir;var r=e.stateNode;if(r&&r.__reactInternalMemoizedUnmaskedChildContext===t)return r.__reactInternalMemoizedMaskedChildContext;var s={},l;for(l in n)s[l]=t[l];return r&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=s),s}function Bt(e){return e=e.childContextTypes,e!=null}function Co(){He(bt),He(wt)}function Ha(e,t,n){if(wt.current!==Ir)throw Error(f(168));$e(wt,t),$e(bt,n)}function Va(e,t,n){var r=e.stateNode;if(t=t.childContextTypes,typeof r.getChildContext!="function")return n;r=r.getChildContext();for(var s in r)if(!(s in t))throw Error(f(108,Se(e)||"Unknown",s));return O({},n,r)}function No(e){return e=(e=e.stateNode)&&e.__reactInternalMemoizedMergedChildContext||Ir,Zr=wt.current,$e(wt,e),$e(bt,bt.current),!0}function Qa(e,t,n){var r=e.stateNode;if(!r)throw Error(f(169));n?(e=Va(e,t,Zr),r.__reactInternalMemoizedMergedChildContext=e,He(bt),He(wt),$e(wt,e)):He(bt),$e(bt,n)}var cr=null,Eo=!1,Vl=!1;function Wa(e){cr===null?cr=[e]:cr.push(e)}function Ud(e){Eo=!0,Wa(e)}function Lr(){if(!Vl&&cr!==null){Vl=!0;var e=0,t=F;try{var n=cr;for(F=1;e>=u,s-=u,dr=1<<32-be(t)+s|n<se?(ht=ee,ee=null):ht=ee.sibling;var we=P(_,ee,S[se],L);if(we===null){ee===null&&(ee=ht);break}e&&ee&&we.alternate===null&&t(_,ee),g=l(we,g,se),Z===null?K=we:Z.sibling=we,Z=we,ee=ht}if(se===S.length)return n(_,ee),Ve&&ts(_,se),K;if(ee===null){for(;sese?(ht=ee,ee=null):ht=ee.sibling;var Hr=P(_,ee,we.value,L);if(Hr===null){ee===null&&(ee=ht);break}e&&ee&&Hr.alternate===null&&t(_,ee),g=l(Hr,g,se),Z===null?K=Hr:Z.sibling=Hr,Z=Hr,ee=ht}if(we.done)return n(_,ee),Ve&&ts(_,se),K;if(ee===null){for(;!we.done;se++,we=S.next())we=A(_,we.value,L),we!==null&&(g=l(we,g,se),Z===null?K=we:Z.sibling=we,Z=we);return Ve&&ts(_,se),K}for(ee=r(_,ee);!we.done;se++,we=S.next())we=U(ee,_,se,we.value,L),we!==null&&(e&&we.alternate!==null&&ee.delete(we.key===null?se:we.key),g=l(we,g,se),Z===null?K=we:Z.sibling=we,Z=we);return e&&ee.forEach(function(Sf){return t(_,Sf)}),Ve&&ts(_,se),K}function et(_,g,S,L){if(typeof S=="object"&&S!==null&&S.type===Me&&S.key===null&&(S=S.props.children),typeof S=="object"&&S!==null){switch(S.$$typeof){case W:e:{for(var K=S.key,Z=g;Z!==null;){if(Z.key===K){if(K=S.type,K===Me){if(Z.tag===7){n(_,Z.sibling),g=s(Z,S.props.children),g.return=_,_=g;break e}}else if(Z.elementType===K||typeof K=="object"&&K!==null&&K.$$typeof===Te&&Xa(K)===Z.type){n(_,Z.sibling),g=s(Z,S.props),g.ref=Xs(_,Z,S),g.return=_,_=g;break e}n(_,Z);break}else t(_,Z);Z=Z.sibling}S.type===Me?(g=us(S.props.children,_.mode,L,S.key),g.return=_,_=g):(L=tl(S.type,S.key,S.props,null,_.mode,L),L.ref=Xs(_,g,S),L.return=_,_=L)}return u(_);case de:e:{for(Z=S.key;g!==null;){if(g.key===Z)if(g.tag===4&&g.stateNode.containerInfo===S.containerInfo&&g.stateNode.implementation===S.implementation){n(_,g.sibling),g=s(g,S.children||[]),g.return=_,_=g;break e}else{n(_,g);break}else t(_,g);g=g.sibling}g=bi(S,_.mode,L),g.return=_,_=g}return u(_);case Te:return Z=S._init,et(_,g,Z(S._payload),L)}if(lt(S))return V(_,g,S,L);if(X(S))return q(_,g,S,L);Ro(_,S)}return typeof S=="string"&&S!==""||typeof S=="number"?(S=""+S,g!==null&&g.tag===6?(n(_,g.sibling),g=s(g,S),g.return=_,_=g):(n(_,g),g=Ui(S,_.mode,L),g.return=_,_=g),u(_)):n(_,g)}return et}var Es=Za(!0),eu=Za(!1),To=Tr(null),Io=null,Ps=null,Jl=null;function Yl(){Jl=Ps=Io=null}function Xl(e){var t=To.current;He(To),e._currentValue=t}function Zl(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 Ms(e,t){Io=e,Jl=Ps=null,e=e.dependencies,e!==null&&e.firstContext!==null&&((e.lanes&t)!==0&&(Ht=!0),e.firstContext=null)}function fn(e){var t=e._currentValue;if(Jl!==e)if(e={context:e,memoizedValue:t,next:null},Ps===null){if(Io===null)throw Error(f(308));Ps=e,Io.dependencies={lanes:0,firstContext:e}}else Ps=Ps.next=e;return t}var ns=null;function ei(e){ns===null?ns=[e]:ns.push(e)}function tu(e,t,n,r){var s=t.interleaved;return s===null?(n.next=n,ei(t)):(n.next=s.next,s.next=n),t.interleaved=n,mr(e,r)}function mr(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 Or=!1;function ti(e){e.updateQueue={baseState:e.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function nu(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 pr(e,t){return{eventTime:e,lane:t,tag:0,payload:null,callback:null,next:null}}function Dr(e,t,n){var r=e.updateQueue;if(r===null)return null;if(r=r.shared,(xe&2)!==0){var s=r.pending;return s===null?t.next=t:(t.next=s.next,s.next=t),r.pending=t,mr(e,n)}return s=r.interleaved,s===null?(t.next=t,ei(r)):(t.next=s.next,s.next=t),r.interleaved=t,mr(e,n)}function Lo(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,ir(e,n)}}function ru(e,t){var n=e.updateQueue,r=e.alternate;if(r!==null&&(r=r.updateQueue,n===r)){var s=null,l=null;if(n=n.firstBaseUpdate,n!==null){do{var u={eventTime:n.eventTime,lane:n.lane,tag:n.tag,payload:n.payload,callback:n.callback,next:null};l===null?s=l=u:l=l.next=u,n=n.next}while(n!==null);l===null?s=l=t:l=l.next=t}else s=l=t;n={baseState:r.baseState,firstBaseUpdate:s,lastBaseUpdate:l,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 Oo(e,t,n,r){var s=e.updateQueue;Or=!1;var l=s.firstBaseUpdate,u=s.lastBaseUpdate,d=s.shared.pending;if(d!==null){s.shared.pending=null;var h=d,w=h.next;h.next=null,u===null?l=w:u.next=w,u=h;var M=e.alternate;M!==null&&(M=M.updateQueue,d=M.lastBaseUpdate,d!==u&&(d===null?M.firstBaseUpdate=w:d.next=w,M.lastBaseUpdate=h))}if(l!==null){var A=s.baseState;u=0,M=w=h=null,d=l;do{var P=d.lane,U=d.eventTime;if((r&P)===P){M!==null&&(M=M.next={eventTime:U,lane:0,tag:d.tag,payload:d.payload,callback:d.callback,next:null});e:{var V=e,q=d;switch(P=t,U=n,q.tag){case 1:if(V=q.payload,typeof V=="function"){A=V.call(U,A,P);break e}A=V;break e;case 3:V.flags=V.flags&-65537|128;case 0:if(V=q.payload,P=typeof V=="function"?V.call(U,A,P):V,P==null)break e;A=O({},A,P);break e;case 2:Or=!0}}d.callback!==null&&d.lane!==0&&(e.flags|=64,P=s.effects,P===null?s.effects=[d]:P.push(d))}else U={eventTime:U,lane:P,tag:d.tag,payload:d.payload,callback:d.callback,next:null},M===null?(w=M=U,h=A):M=M.next=U,u|=P;if(d=d.next,d===null){if(d=s.shared.pending,d===null)break;P=d,d=P.next,P.next=null,s.lastBaseUpdate=P,s.shared.pending=null}}while(!0);if(M===null&&(h=A),s.baseState=h,s.firstBaseUpdate=w,s.lastBaseUpdate=M,t=s.shared.interleaved,t!==null){s=t;do u|=s.lane,s=s.next;while(s!==t)}else l===null&&(s.shared.lanes=0);os|=u,e.lanes=u,e.memoizedState=A}}function su(e,t,n){if(e=t.effects,t.effects=null,e!==null)for(t=0;tn?n:4,e(!0);var r=li.transition;li.transition={};try{e(!1),t()}finally{F=n,li.transition=r}}function ju(){return mn().memoizedState}function Vd(e,t,n){var r=Ur(e);if(n={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null},ku(e))Cu(t,n);else if(n=tu(e,t,n,r),n!==null){var s=Tt();Tn(n,e,r,s),Nu(n,t,r)}}function Qd(e,t,n){var r=Ur(e),s={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null};if(ku(e))Cu(t,s);else{var l=e.alternate;if(e.lanes===0&&(l===null||l.lanes===0)&&(l=t.lastRenderedReducer,l!==null))try{var u=t.lastRenderedState,d=l(u,n);if(s.hasEagerState=!0,s.eagerState=d,En(d,u)){var h=t.interleaved;h===null?(s.next=s,ei(t)):(s.next=h.next,h.next=s),t.interleaved=s;return}}catch{}n=tu(e,t,s,r),n!==null&&(s=Tt(),Tn(n,e,r,s),Nu(n,t,r))}}function ku(e){var t=e.alternate;return e===Ke||t!==null&&t===Ke}function Cu(e,t){no=$o=!0;var n=e.pending;n===null?t.next=t:(t.next=n.next,n.next=t),e.pending=t}function Nu(e,t,n){if((n&4194240)!==0){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,ir(e,n)}}var bo={readContext:fn,useCallback:jt,useContext:jt,useEffect:jt,useImperativeHandle:jt,useInsertionEffect:jt,useLayoutEffect:jt,useMemo:jt,useReducer:jt,useRef:jt,useState:jt,useDebugValue:jt,useDeferredValue:jt,useTransition:jt,useMutableSource:jt,useSyncExternalStore:jt,useId:jt,unstable_isNewReconciler:!1},Wd={readContext:fn,useCallback:function(e,t){return Gn().memoizedState=[e,t===void 0?null:t],e},useContext:fn,useEffect:hu,useImperativeHandle:function(e,t,n){return n=n!=null?n.concat([e]):null,Fo(4194308,4,yu.bind(null,t,e),n)},useLayoutEffect:function(e,t){return Fo(4194308,4,e,t)},useInsertionEffect:function(e,t){return Fo(4,2,e,t)},useMemo:function(e,t){var n=Gn();return t=t===void 0?null:t,e=e(),n.memoizedState=[e,t],e},useReducer:function(e,t,n){var r=Gn();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=Vd.bind(null,Ke,e),[r.memoizedState,e]},useRef:function(e){var t=Gn();return e={current:e},t.memoizedState=e},useState:mu,useDebugValue:mi,useDeferredValue:function(e){return Gn().memoizedState=e},useTransition:function(){var e=mu(!1),t=e[0];return e=Hd.bind(null,e[1]),Gn().memoizedState=e,[t,e]},useMutableSource:function(){},useSyncExternalStore:function(e,t,n){var r=Ke,s=Gn();if(Ve){if(n===void 0)throw Error(f(407));n=n()}else{if(n=t(),pt===null)throw Error(f(349));(ss&30)!==0||au(r,t,n)}s.memoizedState=n;var l={value:n,getSnapshot:t};return s.queue=l,hu(cu.bind(null,r,l,e),[e]),r.flags|=2048,oo(9,uu.bind(null,r,l,n,t),void 0,null),n},useId:function(){var e=Gn(),t=pt.identifierPrefix;if(Ve){var n=fr,r=dr;n=(r&~(1<<32-be(r)-1)).toString(32)+n,t=":"+t+"R"+n,n=ro++,0<\/script>",e=e.removeChild(e.firstChild)):typeof r.is=="string"?e=u.createElement(n,{is:r.is}):(e=u.createElement(n),n==="select"&&(u=e,r.multiple?u.multiple=!0:r.size&&(u.size=r.size))):e=u.createElementNS(e,n),e[qn]=t,e[Js]=r,Wu(e,t,!1,!1),t.stateNode=e;e:{switch(u=sn(n,r),n){case"dialog":Be("cancel",e),Be("close",e),s=r;break;case"iframe":case"object":case"embed":Be("load",e),s=r;break;case"video":case"audio":for(s=0;sLs&&(t.flags|=128,r=!0,lo(l,!1),t.lanes=4194304)}else{if(!r)if(e=Do(u),e!==null){if(t.flags|=128,r=!0,n=e.updateQueue,n!==null&&(t.updateQueue=n,t.flags|=4),lo(l,!0),l.tail===null&&l.tailMode==="hidden"&&!u.alternate&&!Ve)return kt(t),null}else 2*D()-l.renderingStartTime>Ls&&n!==1073741824&&(t.flags|=128,r=!0,lo(l,!1),t.lanes=4194304);l.isBackwards?(u.sibling=t.child,t.child=u):(n=l.last,n!==null?n.sibling=u:t.child=u,l.last=u)}return l.tail!==null?(t=l.tail,l.rendering=t,l.tail=t.sibling,l.renderingStartTime=D(),t.sibling=null,n=qe.current,$e(qe,r?n&1|2:n&1),t):(kt(t),null);case 22:case 23:return zi(),r=t.memoizedState!==null,e!==null&&e.memoizedState!==null!==r&&(t.flags|=8192),r&&(t.mode&1)!==0?(en&1073741824)!==0&&(kt(t),t.subtreeFlags&6&&(t.flags|=8192)):kt(t),null;case 24:return null;case 25:return null}throw Error(f(156,t.tag))}function ef(e,t){switch(Wl(t),t.tag){case 1:return Bt(t.type)&&Co(),e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 3:return As(),He(bt),He(wt),oi(),e=t.flags,(e&65536)!==0&&(e&128)===0?(t.flags=e&-65537|128,t):null;case 5:return ri(t),null;case 13:if(He(qe),e=t.memoizedState,e!==null&&e.dehydrated!==null){if(t.alternate===null)throw Error(f(340));Ns()}return e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 19:return He(qe),null;case 4:return As(),null;case 10:return Xl(t.type._context),null;case 22:case 23:return zi(),null;case 24:return null;default:return null}}var Qo=!1,Ct=!1,tf=typeof WeakSet=="function"?WeakSet:Set,B=null;function Ts(e,t){var n=e.ref;if(n!==null)if(typeof n=="function")try{n(null)}catch(r){Xe(e,t,r)}else n.current=null}function Ci(e,t,n){try{n()}catch(r){Xe(e,t,r)}}var Gu=!1;function nf(e,t){if(zl=ms,e=Ea(),Ml(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 s=r.anchorOffset,l=r.focusNode;r=r.focusOffset;try{n.nodeType,l.nodeType}catch{n=null;break e}var u=0,d=-1,h=-1,w=0,M=0,A=e,P=null;t:for(;;){for(var U;A!==n||s!==0&&A.nodeType!==3||(d=u+s),A!==l||r!==0&&A.nodeType!==3||(h=u+r),A.nodeType===3&&(u+=A.nodeValue.length),(U=A.firstChild)!==null;)P=A,A=U;for(;;){if(A===e)break t;if(P===n&&++w===s&&(d=u),P===l&&++M===r&&(h=u),(U=A.nextSibling)!==null)break;A=P,P=A.parentNode}A=U}n=d===-1||h===-1?null:{start:d,end:h}}else n=null}n=n||{start:0,end:0}}else n=null;for($l={focusedElem:e,selectionRange:n},ms=!1,B=t;B!==null;)if(t=B,e=t.child,(t.subtreeFlags&1028)!==0&&e!==null)e.return=t,B=e;else for(;B!==null;){t=B;try{var V=t.alternate;if((t.flags&1024)!==0)switch(t.tag){case 0:case 11:case 15:break;case 1:if(V!==null){var q=V.memoizedProps,et=V.memoizedState,_=t.stateNode,g=_.getSnapshotBeforeUpdate(t.elementType===t.type?q:Mn(t.type,q),et);_.__reactInternalSnapshotBeforeUpdate=g}break;case 3:var S=t.stateNode.containerInfo;S.nodeType===1?S.textContent="":S.nodeType===9&&S.documentElement&&S.removeChild(S.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(f(163))}}catch(L){Xe(t,t.return,L)}if(e=t.sibling,e!==null){e.return=t.return,B=e;break}B=t.return}return V=Gu,Gu=!1,V}function io(e,t,n){var r=t.updateQueue;if(r=r!==null?r.lastEffect:null,r!==null){var s=r=r.next;do{if((s.tag&e)===e){var l=s.destroy;s.destroy=void 0,l!==void 0&&Ci(t,n,l)}s=s.next}while(s!==r)}}function Wo(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 Ni(e){var t=e.ref;if(t!==null){var n=e.stateNode;e.tag,e=n,typeof t=="function"?t(e):t.current=e}}function Ju(e){var t=e.alternate;t!==null&&(e.alternate=null,Ju(t)),e.child=null,e.deletions=null,e.sibling=null,e.tag===5&&(t=e.stateNode,t!==null&&(delete t[qn],delete t[Js],delete t[Bl],delete t[$d],delete t[Fd])),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 Yu(e){return e.tag===5||e.tag===3||e.tag===4}function Xu(e){e:for(;;){for(;e.sibling===null;){if(e.return===null||Yu(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 Ei(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=jo));else if(r!==4&&(e=e.child,e!==null))for(Ei(e,t,n),e=e.sibling;e!==null;)Ei(e,t,n),e=e.sibling}function Pi(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(Pi(e,t,n),e=e.sibling;e!==null;)Pi(e,t,n),e=e.sibling}var vt=null,An=!1;function zr(e,t,n){for(n=n.child;n!==null;)Zu(e,t,n),n=n.sibling}function Zu(e,t,n){if(Ue&&typeof Ue.onCommitFiberUnmount=="function")try{Ue.onCommitFiberUnmount(ue,n)}catch{}switch(n.tag){case 5:Ct||Ts(n,t);case 6:var r=vt,s=An;vt=null,zr(e,t,n),vt=r,An=s,vt!==null&&(An?(e=vt,n=n.stateNode,e.nodeType===8?e.parentNode.removeChild(n):e.removeChild(n)):vt.removeChild(n.stateNode));break;case 18:vt!==null&&(An?(e=vt,n=n.stateNode,e.nodeType===8?bl(e.parentNode,n):e.nodeType===1&&bl(e,n),Jr(e)):bl(vt,n.stateNode));break;case 4:r=vt,s=An,vt=n.stateNode.containerInfo,An=!0,zr(e,t,n),vt=r,An=s;break;case 0:case 11:case 14:case 15:if(!Ct&&(r=n.updateQueue,r!==null&&(r=r.lastEffect,r!==null))){s=r=r.next;do{var l=s,u=l.destroy;l=l.tag,u!==void 0&&((l&2)!==0||(l&4)!==0)&&Ci(n,t,u),s=s.next}while(s!==r)}zr(e,t,n);break;case 1:if(!Ct&&(Ts(n,t),r=n.stateNode,typeof r.componentWillUnmount=="function"))try{r.props=n.memoizedProps,r.state=n.memoizedState,r.componentWillUnmount()}catch(d){Xe(n,t,d)}zr(e,t,n);break;case 21:zr(e,t,n);break;case 22:n.mode&1?(Ct=(r=Ct)||n.memoizedState!==null,zr(e,t,n),Ct=r):zr(e,t,n);break;default:zr(e,t,n)}}function ec(e){var t=e.updateQueue;if(t!==null){e.updateQueue=null;var n=e.stateNode;n===null&&(n=e.stateNode=new tf),t.forEach(function(r){var s=ff.bind(null,e,r);n.has(r)||(n.add(r),r.then(s,s))})}}function Rn(e,t){var n=t.deletions;if(n!==null)for(var r=0;rs&&(s=u),r&=~l}if(r=s,r=D()-r,r=(120>r?120:480>r?480:1080>r?1080:1920>r?1920:3e3>r?3e3:4320>r?4320:1960*sf(r/1960))-r,10e?16:e,Fr===null)var r=!1;else{if(e=Fr,Fr=null,Yo=0,(xe&6)!==0)throw Error(f(331));var s=xe;for(xe|=4,B=e.current;B!==null;){var l=B,u=l.child;if((B.flags&16)!==0){var d=l.deletions;if(d!==null){for(var h=0;hD()-Ri?is(e,0):Ai|=n),Qt(e,t)}function mc(e,t){t===0&&((e.mode&1)===0?t=1:(t=kn,kn<<=1,(kn&130023424)===0&&(kn=4194304)));var n=Tt();e=mr(e,t),e!==null&&(it(e,t,n),Qt(e,n))}function df(e){var t=e.memoizedState,n=0;t!==null&&(n=t.retryLane),mc(e,n)}function ff(e,t){var n=0;switch(e.tag){case 13:var r=e.stateNode,s=e.memoizedState;s!==null&&(n=s.retryLane);break;case 19:r=e.stateNode;break;default:throw Error(f(314))}r!==null&&r.delete(t),mc(e,n)}var pc;pc=function(e,t,n){if(e!==null)if(e.memoizedProps!==t.pendingProps||bt.current)Ht=!0;else{if((e.lanes&n)===0&&(t.flags&128)===0)return Ht=!1,Xd(e,t,n);Ht=(e.flags&131072)!==0}else Ht=!1,Ve&&(t.flags&1048576)!==0&&qa(t,Mo,t.index);switch(t.lanes=0,t.tag){case 2:var r=t.type;Vo(e,t),e=t.pendingProps;var s=js(t,wt.current);Ms(t,n),s=ai(null,t,r,e,s,n);var l=ui();return t.flags|=1,typeof s=="object"&&s!==null&&typeof s.render=="function"&&s.$$typeof===void 0?(t.tag=1,t.memoizedState=null,t.updateQueue=null,Bt(r)?(l=!0,No(t)):l=!1,t.memoizedState=s.state!==null&&s.state!==void 0?s.state:null,ti(t),s.updater=Bo,t.stateNode=s,s._reactInternals=t,hi(t,r,e,n),t=xi(null,t,r,!0,l,n)):(t.tag=0,Ve&&l&&Ql(t),Rt(null,t,s,n),t=t.child),t;case 16:r=t.elementType;e:{switch(Vo(e,t),e=t.pendingProps,s=r._init,r=s(r._payload),t.type=r,s=t.tag=pf(r),e=Mn(r,e),s){case 0:t=yi(null,t,r,e,n);break e;case 1:t=Uu(null,t,r,e,n);break e;case 11:t=Ou(null,t,r,e,n);break e;case 14:t=Du(null,t,r,Mn(r.type,e),n);break e}throw Error(f(306,r,""))}return t;case 0:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:Mn(r,s),yi(e,t,r,s,n);case 1:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:Mn(r,s),Uu(e,t,r,s,n);case 3:e:{if(bu(t),e===null)throw Error(f(387));r=t.pendingProps,l=t.memoizedState,s=l.element,nu(e,t),Oo(t,r,null,n);var u=t.memoizedState;if(r=u.element,l.isDehydrated)if(l={element:r,isDehydrated:!1,cache:u.cache,pendingSuspenseBoundaries:u.pendingSuspenseBoundaries,transitions:u.transitions},t.updateQueue.baseState=l,t.memoizedState=l,t.flags&256){s=Rs(Error(f(423)),t),t=Bu(e,t,r,n,s);break e}else if(r!==s){s=Rs(Error(f(424)),t),t=Bu(e,t,r,n,s);break e}else for(Zt=Rr(t.stateNode.containerInfo.firstChild),Xt=t,Ve=!0,Pn=null,n=eu(t,null,r,n),t.child=n;n;)n.flags=n.flags&-3|4096,n=n.sibling;else{if(Ns(),r===s){t=hr(e,t,n);break e}Rt(e,t,r,n)}t=t.child}return t;case 5:return ou(t),e===null&&Kl(t),r=t.type,s=t.pendingProps,l=e!==null?e.memoizedProps:null,u=s.children,Fl(r,s)?u=null:l!==null&&Fl(r,l)&&(t.flags|=32),Fu(e,t),Rt(e,t,u,n),t.child;case 6:return e===null&&Kl(t),null;case 13:return Hu(e,t,n);case 4:return ni(t,t.stateNode.containerInfo),r=t.pendingProps,e===null?t.child=Es(t,null,r,n):Rt(e,t,r,n),t.child;case 11:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:Mn(r,s),Ou(e,t,r,s,n);case 7:return Rt(e,t,t.pendingProps,n),t.child;case 8:return Rt(e,t,t.pendingProps.children,n),t.child;case 12:return Rt(e,t,t.pendingProps.children,n),t.child;case 10:e:{if(r=t.type._context,s=t.pendingProps,l=t.memoizedProps,u=s.value,$e(To,r._currentValue),r._currentValue=u,l!==null)if(En(l.value,u)){if(l.children===s.children&&!bt.current){t=hr(e,t,n);break e}}else for(l=t.child,l!==null&&(l.return=t);l!==null;){var d=l.dependencies;if(d!==null){u=l.child;for(var h=d.firstContext;h!==null;){if(h.context===r){if(l.tag===1){h=pr(-1,n&-n),h.tag=2;var w=l.updateQueue;if(w!==null){w=w.shared;var M=w.pending;M===null?h.next=h:(h.next=M.next,M.next=h),w.pending=h}}l.lanes|=n,h=l.alternate,h!==null&&(h.lanes|=n),Zl(l.return,n,t),d.lanes|=n;break}h=h.next}}else if(l.tag===10)u=l.type===t.type?null:l.child;else if(l.tag===18){if(u=l.return,u===null)throw Error(f(341));u.lanes|=n,d=u.alternate,d!==null&&(d.lanes|=n),Zl(u,n,t),u=l.sibling}else u=l.child;if(u!==null)u.return=l;else for(u=l;u!==null;){if(u===t){u=null;break}if(l=u.sibling,l!==null){l.return=u.return,u=l;break}u=u.return}l=u}Rt(e,t,s.children,n),t=t.child}return t;case 9:return s=t.type,r=t.pendingProps.children,Ms(t,n),s=fn(s),r=r(s),t.flags|=1,Rt(e,t,r,n),t.child;case 14:return r=t.type,s=Mn(r,t.pendingProps),s=Mn(r.type,s),Du(e,t,r,s,n);case 15:return zu(e,t,t.type,t.pendingProps,n);case 17:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:Mn(r,s),Vo(e,t),t.tag=1,Bt(r)?(e=!0,No(t)):e=!1,Ms(t,n),Pu(t,r,s),hi(t,r,s,n),xi(null,t,r,!0,e,n);case 19:return Qu(e,t,n);case 22:return $u(e,t,n)}throw Error(f(156,t.tag))};function hc(e,t){return Pt(e,t)}function mf(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 hn(e,t,n,r){return new mf(e,t,n,r)}function Fi(e){return e=e.prototype,!(!e||!e.isReactComponent)}function pf(e){if(typeof e=="function")return Fi(e)?1:0;if(e!=null){if(e=e.$$typeof,e===ie)return 11;if(e===Fe)return 14}return 2}function Br(e,t){var n=e.alternate;return n===null?(n=hn(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 tl(e,t,n,r,s,l){var u=2;if(r=e,typeof e=="function")Fi(e)&&(u=1);else if(typeof e=="string")u=5;else e:switch(e){case Me:return us(n.children,s,l,t);case Ze:u=8,s|=8;break;case ct:return e=hn(12,n,t,s|2),e.elementType=ct,e.lanes=l,e;case Le:return e=hn(13,n,t,s),e.elementType=Le,e.lanes=l,e;case H:return e=hn(19,n,t,s),e.elementType=H,e.lanes=l,e;case Ae:return nl(n,s,l,t);default:if(typeof e=="object"&&e!==null)switch(e.$$typeof){case st:u=10;break e;case Et:u=9;break e;case ie:u=11;break e;case Fe:u=14;break e;case Te:u=16,r=null;break e}throw Error(f(130,e==null?e:typeof e,""))}return t=hn(u,n,t,s),t.elementType=e,t.type=r,t.lanes=l,t}function us(e,t,n,r){return e=hn(7,e,r,t),e.lanes=n,e}function nl(e,t,n,r){return e=hn(22,e,r,t),e.elementType=Ae,e.lanes=n,e.stateNode={isHidden:!1},e}function Ui(e,t,n){return e=hn(6,e,null,t),e.lanes=n,e}function bi(e,t,n){return t=hn(4,e.children!==null?e.children:[],e.key,t),t.lanes=n,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function hf(e,t,n,r,s){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=or(0),this.expirationTimes=or(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=or(0),this.identifierPrefix=r,this.onRecoverableError=s,this.mutableSourceEagerHydrationData=null}function Bi(e,t,n,r,s,l,u,d,h){return e=new hf(e,t,n,d,h),t===1?(t=1,l===!0&&(t|=8)):t=0,l=hn(3,null,null,t),e.current=l,l.stateNode=e,l.memoizedState={element:r,isDehydrated:n,cache:null,transitions:null,pendingSuspenseBoundaries:null},ti(l),e}function gf(e,t,n){var r=3"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(i)}catch(p){console.error(p)}}return i(),Ki.exports=Pf(),Ki.exports}var Mc;function Af(){if(Mc)return ul;Mc=1;var i=Mf();return ul.createRoot=i.createRoot,ul.hydrateRoot=i.hydrateRoot,ul}var Rf=Af();const Tf=Vc(Rf),If="/api";async function Ce(i,p){const f=await fetch(`${If}${i}`,{...p,headers:{"Content-Type":"application/json",...p?.headers??{}}}),N=await f.json();if(!f.ok){const j=N.error?.message??"Ошибка запроса";throw new Error(j)}return N}const _e={async loadSharedConnectionConfig(){return Ce("/llm/shared-connection")},async saveSharedConnectionConfig(i){return Ce("/llm/shared-connection",{method:"POST",body:JSON.stringify({llmProvider:i.llmProvider,model:i.model,baseUrl:i.baseUrl,temperature:i.temperature,maxOutputTokens:i.maxOutputTokens})})},async listModels(i){return Ce("/llm/models",{method:"POST",body:JSON.stringify({llmProvider:i.llmProvider,apiKey:i.apiKey,model:i.model,baseUrl:i.baseUrl})})},async testConnection(i){return Ce("/llm/test-connection",{method:"POST",body:JSON.stringify({llmProvider:i.llmProvider,apiKey:i.apiKey,model:i.model,baseUrl:i.baseUrl})})},async normalize(i){return Ce("/normalize",{method:"POST",body:JSON.stringify({llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion,systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples,userQuestion:i.query.userQuestion,context:{period_hint:i.query.periodHint??"",business_context:i.query.businessContext??"",expected_route:i.query.expectedRoute??""},saveAsTestCase:!!i.saveAsTestCase,useMock:!!i.useMock})})},async loadHistory(){return Ce("/history")},async loadTrace(i){return Ce(`/history/${i}`)},async loadPresets(){return Ce("/presets")},async savePreset(i){return Ce("/presets/save",{method:"POST",body:JSON.stringify(i)})},async runEval(i){return Ce("/eval/run",{method:"POST",body:JSON.stringify({normalizeConfig:{llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion,systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples},caseIds:i.caseIds,useMock:!!i.useMock,mode:i.mode??"standard",caseSetFile:i.caseSetFile,rawQuestions:i.rawQuestions,eval_target:i.evalTarget,compare_with_report_file:i.compareWithReportFile,analysis_date:i.analysisDate})})},async startEvalRunAsync(i){return Ce("/eval/run-async/start",{method:"POST",body:JSON.stringify({normalizeConfig:{llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion,systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples},caseIds:i.caseIds,useMock:!!i.useMock,mode:i.mode??"standard",caseSetFile:i.caseSetFile,rawQuestions:i.rawQuestions,eval_target:i.evalTarget,compare_with_report_file:i.compareWithReportFile,questions:i.questions,analysis_date:i.analysisDate})})},async loadEvalRunAsyncStatus(i){return Ce(`/eval/run-async/${encodeURIComponent(i)}`)},async startRun(){return Ce("/accounting-agent/v1/runs/start",{method:"POST",body:JSON.stringify({initiator:"ndc_operator",source:"gui"})})},async finishRun(i){return Ce("/accounting-agent/v1/runs/finish",{method:"POST",body:JSON.stringify({runId:i,status:"DONE",source:"gui",reason:"Остановлено оператором из GUI"})})},async listRuns(){return Ce("/accounting-agent/v1/runs")},async listResults(){return Ce("/accounting-agent/v1/results")},async runTrace(i){return Ce(`/accounting-agent/v1/trace/run/${i}`)},async sendAssistantMessage(i){return Ce("/assistant/message",{method:"POST",body:JSON.stringify({session_id:i.sessionId??"",mode:"assistant",message:i.userMessage,user_message:i.userMessage,llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion??"address_query_runtime_v1",systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples,context:{period_hint:i.context?.periodHint??"",business_context:i.context?.businessContext??""},useMock:!!i.useMock})})},async loadAssistantSession(i){return Ce(`/assistant/session/${i}`)},async loadAssistantAnnotations(i){const p=new URLSearchParams;i?.session_id&&p.set("session_id",i.session_id),typeof i?.limit=="number"&&p.set("limit",String(i.limit));const f=p.toString();return Ce(`/assistant/annotations${f?`?${f}`:""}`)},async saveAssistantAnnotation(i){return Ce("/assistant/annotations",{method:"POST",body:JSON.stringify(i)})},async loadAutoRunsHistory(i){const p=new URLSearchParams;i?.from&&p.set("from",i.from),i?.to&&p.set("to",i.to),i?.target&&p.set("target",i.target),i?.mode&&p.set("mode",i.mode),i?.use_mock&&p.set("use_mock",i.use_mock),i?.prompt_contains&&p.set("prompt_contains",i.prompt_contains),typeof i?.limit=="number"&&p.set("limit",String(i.limit)),typeof i?.scan_limit=="number"&&p.set("scan_limit",String(i.scan_limit));const f=p.toString();return Ce(`/autoruns/history${f?`?${f}`:""}`)},async loadAutoRunDetail(i){return Ce(`/autoruns/history/${encodeURIComponent(i)}`)},async loadAutoRunCaseDialog(i,p){return Ce(`/autoruns/history/${encodeURIComponent(i)}/case/${encodeURIComponent(p)}/dialog`)},async loadAutoRunAnnotations(i){const p=new URLSearchParams;i?.run_id&&p.set("run_id",i.run_id),i?.case_id&&p.set("case_id",i.case_id),typeof i?.min_rating=="number"&&p.set("min_rating",String(i.min_rating)),i?.manual_case_decision&&p.set("manual_case_decision",i.manual_case_decision),typeof i?.limit=="number"&&p.set("limit",String(i.limit));const f=p.toString();return Ce(`/autoruns/annotations${f?`?${f}`:""}`)},async saveAutoRunAnnotation(i){return Ce("/autoruns/annotations",{method:"POST",body:JSON.stringify(i)})},async updateAutoRunAnnotation(i){return Ce(`/autoruns/annotations/${encodeURIComponent(i.annotation_id)}`,{method:"PATCH",body:JSON.stringify({resolved:i.resolved,resolved_by:i.resolved_by})})},async loadAutoRunPostAnalysis(i){const p=new URLSearchParams;i?.run_id&&p.set("run_id",i.run_id),typeof i?.limit_per_queue=="number"&&p.set("limit_per_queue",String(i.limit_per_queue)),typeof i?.annotation_limit=="number"&&p.set("annotation_limit",String(i.annotation_limit)),typeof i?.scan_limit=="number"&&p.set("scan_limit",String(i.scan_limit)),i?.from&&p.set("from",i.from),i?.to&&p.set("to",i.to),i?.target&&p.set("target",i.target),i?.mode&&p.set("mode",i.mode),i?.use_mock&&p.set("use_mock",i.use_mock),i?.prompt_contains&&p.set("prompt_contains",i.prompt_contains);const f=p.toString();return Ce(`/autoruns/post-analysis${f?`?${f}`:""}`)},async loadAutoRunAutogenHistory(i){const p=new URLSearchParams;i?.mode&&p.set("mode",i.mode),typeof i?.limit=="number"&&p.set("limit",String(i.limit));const f=p.toString();return Ce(`/autoruns/autogen/history${f?`?${f}`:""}`)},async loadAutoRunAutogenPersonalityCatalog(){return Ce("/autoruns/autogen/personality-catalog")},async generateAutoRunQuestions(i){return Ce("/autoruns/autogen/generate",{method:"POST",body:JSON.stringify(i)})}};function tn({value:i}){return o.jsx("pre",{className:"json-view",children:JSON.stringify(i??{},null,2)})}function In({title:i,subtitle:p,actions:f,className:N,hideHeader:j,children:T}){return o.jsxs("section",{className:N?`panel-frame ${N}`:"panel-frame",children:[j?null:o.jsxs("header",{className:"panel-header",children:[o.jsxs("div",{children:[o.jsx("h2",{children:i}),p?o.jsx("p",{children:p}):null]}),f?o.jsx("div",{className:"panel-actions",children:f}):null]}),o.jsx("div",{className:"panel-body",children:T})]})}function Lf(i){const p=new Date(i);return Number.isNaN(p.getTime())?i:p.toLocaleString("ru-RU")}function Of({sessionId:i,conversation:p,statusText:f,errorMessage:N,useMock:j,appLogs:T}){const $=p.filter(Q=>Q.role==="assistant").length,Y=p.filter(Q=>Q.role==="user").length,b=p.length>0?p[p.length-1]:null;return o.jsxs(In,{title:"SAM",subtitle:"System Assistant Monitor: срез по текущей сессии и логам.",children:[o.jsxs("div",{className:"metrics-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"session_id"}),o.jsx("strong",{children:i||"новая сессия"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"mock_mode"}),o.jsx("strong",{children:j?"on":"off"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"сообщений пользователя"}),o.jsx("strong",{children:Y})]}),o.jsxs("div",{children:[o.jsx("span",{children:"ответов ассистента"}),o.jsx("strong",{children:$})]}),o.jsxs("div",{children:[o.jsx("span",{children:"статус"}),o.jsx("strong",{children:f||"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"ошибка"}),o.jsx("strong",{children:N||"нет"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"последнее сообщение"}),o.jsx("strong",{children:b?.created_at?Lf(b.created_at):"нет данных"})]})]}),o.jsx("h3",{style:{marginTop:12},children:"Последние системные логи"}),o.jsx(tn,{value:T.slice(0,120)})]})}const Df=/(?:^|\n)\s*#{0,6}\s*(?:debug_payload_json|technical_breakdown_json|route_summary_json|debug_payload|technical_breakdown)\b/i,zf=[/\b(?:debug_payload_json|technical_breakdown_json)\b/i,/\b(?:route_summary|semantic_profile|domain_scope|relation_patterns|account_scope)\b/i,/\b(?:coverage_report|retrieval_status|problem_unit_state|candidate_evidence)\b/i,/\b(?:graph_domain_scope|graph_runtime|selection_reason|why_included)\b/i];function $f(i){try{return JSON.stringify(i,null,2)}catch{return String(i)}}function Ff(i){const p=String(i??""),f=p.match(Df);return(f?p.slice(0,f.index):p).replace(/###\s*(?:debug_payload_json|technical_breakdown_json|route_summary_json)[\s\S]*?(?:```[\s\S]*?```|$)/gi,"").replace(/(?:^|\n)\s*#{0,6}\s*(?:debug_payload_json|technical_breakdown_json|route_summary_json)\b[\s\S]*$/gi,"").split(/\r?\n/g).map($=>$.trimEnd()).filter($=>$.trim().length>0).filter($=>!zf.some(Y=>Y.test($))).join(` -`).trim()}function Uf(i,p,f="default"){const N=f==="technical",j=[];j.push("# Assistant conversation export"),j.push(`session_id: ${i||"n/a"}`),j.push(`export_mode: ${f}`),j.push(`exported_at: ${new Date().toISOString()}`),j.push("");for(let T=0;T{j.length!==0&&(N.push(j.join(` -`)),j=[])};for(const $ of f){const Y=$.trimEnd(),b=Y.trim();if(!b){T();continue}const Q=/^Блок\s+\d+\./i.test(b),G=/^\d+\.\s/.test(b);(Q||G)&&j.length>0&&T(),j.push(Y)}return T(),N.length>0?N:[i]}function qf(i,p){const f=[],N=/\*\*(.+?)\*\*/g;let j=0,T=0,$;for(;($=N.exec(i))!==null;)$.index>j&&(f.push(o.jsx("span",{children:i.slice(j,$.index)},`${p}-t-${T}`)),T+=1),f.push(o.jsx("strong",{children:$[1]},`${p}-b-${T}`)),T+=1,j=N.lastIndex;return j0?f:[o.jsx("span",{children:i},`${p}-raw`)]}function Kf(i){const p=i.trimStart();return/^Блок\s+\d+\./i.test(p)?"assistant-msg-line heading":/^\d+\.\s/.test(p)?"assistant-msg-line numbered":/^-\s/.test(p)?"assistant-msg-line bullet":"assistant-msg-line"}function Gf(i,p=40){const f=i.replace(/\s+/g," ").trim();if(f.length<=p)return f;const N=f.split(" ").slice(0,3).join(" ").trim();return N.length>=10&&N.length<=p?`${N}…`:`${f.slice(0,p-1).trimEnd()}…`}function Qc(i){return i.replace(/\*\*(.+?)\*\*/g,"$1").replace(/^\d+\.\s*/,"").trim()}function Jf(i){const p=i.replace(/\r\n?/g,` -`).split(` -`).map(j=>j.trim()).find(Boolean),f=Qc(p??"");return(f.split("|")[0]?.trim()??f).replace(/\s+/g," ").trim()}function Yf(i){const p=i.replace(/\r\n?/g,` -`).split(` -`).map(N=>N.trim()).find(Boolean);return!p||!/^\d+\.\s/.test(p)?!1:Qc(p).includes("|")}function Xf(i,p){const f=p.replace(/\r\n?/g,` -`).replace(/\*\*(.+?)\*\*/g,"$1").split(` -`).map((j,T)=>{const $=j.trim();return T===0?$.replace(/^\d+\.\s*/,""):$}).filter(Boolean).join(" ").replace(/\s+/g," ").trim();if(!f)return null;const N=Jf(p)||f;return{message_id:i.message_id,source_text:f,anchor_text:N,preview_text:Gf(N)}}function Zf(i,p,f,N){return Wf(i.text).map((T,$)=>{const Y=T.split(` -`),b=i.role==="assistant"&&Yf(T),Q=b?Xf(i,T):null,G=!!Q&&p?.message_id===Q?.message_id&&p?.source_text===Q?.source_text,z=Y.map((ne,Ne)=>o.jsx("p",{className:Kf(ne),children:qf(ne,`line-${$}-${Ne}`)},`line-${$}-${Ne}`));return!b||!Q?o.jsx("div",{className:"assistant-msg-block",children:z},`block-${$}`):o.jsx("div",{className:G?"assistant-msg-block selectable active":"assistant-msg-block selectable",role:"button",tabIndex:0,onClick:()=>{if(G){N();return}f(Q)},onKeyDown:ne=>{if(!(ne.key!=="Enter"&&ne.key!==" ")){if(ne.preventDefault(),G){N();return}f(Q)}},children:z},`block-${$}`)})}function Wc({sessionId:i,conversation:p,inputValue:f,onInputChange:N,selectedContextChip:j,onSelectContextChip:T,onClearContextChip:$,useMock:Y,onUseMockChange:b,onSend:Q,onClear:G,busy:z,statusText:ne,errorMessage:Ne,showCommentAction:le=!1,onCommentAssistantMessage:ce,isAssistantMessageCommented:me,canCommentAssistantMessage:Qe}){const De=x.useRef(null),We=x.useRef(!0),je=x.useRef(null),[W,de]=x.useState("idle"),[Me,Ze]=x.useState("чат");function ct(ie=!1){De.current&&(ie&&(We.current=!0),De.current.scrollTop=De.current.scrollHeight)}x.useEffect(()=>{We.current&&ct()},[p]),x.useEffect(()=>()=>{je.current!==null&&window.clearTimeout(je.current)},[]);async function st(ie){if(p.length===0)return;const Le=Uf(i,p,ie),H=await Hf(Le);Ze(ie==="technical"?"тех":"чат"),de(H?"success":"error"),je.current!==null&&window.clearTimeout(je.current),je.current=window.setTimeout(()=>{de("idle")},2200)}function Et(){if(!De.current)return;const ie=De.current,Le=ie.scrollHeight-ie.scrollTop-ie.clientHeight;We.current=Le<16}return o.jsx(In,{className:"assistant-panel-frame",title:"Режим ассистента",children:o.jsxs("div",{className:"assistant-live-shell",children:[o.jsxs("div",{className:"assistant-toolbar",children:[o.jsxs("div",{className:"assistant-toolbar-actions",children:[o.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>{st("default")},disabled:p.length===0,title:"Экспорт только user-facing чата",children:"Скопировать чат"}),o.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>{st("technical")},disabled:p.length===0,title:"Технический экспорт с debug payload",children:"Скопировать техчат"}),o.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>G(),disabled:z&&p.length===0,children:"Сбросить сессию"})]}),o.jsxs("div",{className:"assistant-toolbar-meta",children:[i?o.jsx("span",{className:"status-chip",children:`session: ${i}`}):null,o.jsxs("div",{className:"assistant-toolbar-meta-right",children:[ne?o.jsx("span",{className:"assistant-live-status",children:ne}):null,W==="success"?o.jsxs("span",{className:"assistant-copy-feedback success",children:["Скопировано (",Me,")"]}):null,W==="error"?o.jsx("span",{className:"assistant-copy-feedback error",children:"Ошибка копирования"}):null]})]}),Ne?o.jsx("p",{className:"error-text assistant-toolbar-error",children:Ne}):null]}),o.jsx("div",{ref:De,className:"assistant-chat-list",onScroll:Et,children:p.map((ie,Le)=>{const H=ie.role==="assistant"&&le&&typeof ce=="function"&&(typeof Qe=="function"?Qe(ie,Le):!0),Fe=ie.role==="assistant"&&typeof me=="function"?me(ie,Le):!1;return o.jsxs("article",{className:`assistant-msg ${ie.role}`,children:[o.jsxs("header",{className:"assistant-msg-head",children:[o.jsxs("div",{className:"assistant-msg-head-main",children:[o.jsx("strong",{children:bf(ie.role)}),o.jsx("span",{children:Bf(ie.created_at)})]}),ie.role==="assistant"&&le?o.jsx("div",{className:"assistant-msg-head-actions",children:o.jsx("button",{type:"button",className:Fe?"autoruns-comment-icon assistant-comment-btn commented":"autoruns-comment-icon assistant-comment-btn",onClick:()=>ce?.(ie,Le),disabled:!H,title:H?"Комментировать ответ ассистента":"Комментарий недоступен для этого сообщения","aria-label":H?"Комментировать ответ ассистента":"Комментарий недоступен для этого сообщения",children:o.jsx(Vf,{commented:Fe})})}):null]}),o.jsx("div",{className:"assistant-msg-body",children:Zf(ie,j,T,$)}),ie.role==="assistant"&&ie.debug?o.jsxs("details",{className:"assistant-debug",children:[o.jsx("summary",{children:"Показать технический разбор"}),o.jsx(tn,{value:ie.debug})]}):null]},ie.message_id)})}),o.jsxs("div",{className:"assistant-compose",children:[j?o.jsxs("div",{className:"assistant-compose-context",children:[o.jsx("span",{className:"assistant-compose-context-label",children:"Выбранный объект"}),o.jsxs("div",{className:"assistant-compose-context-pill",title:j.source_text,children:[o.jsx("span",{className:"assistant-compose-context-pill-text",children:j.preview_text}),o.jsx("button",{type:"button",className:"assistant-compose-context-clear",onClick:$,"aria-label":"Убрать выбранный объект",title:"Убрать выбранный объект",children:"×"})]})]}):null,o.jsxs("label",{className:"full-width",children:["Сообщение",o.jsx("textarea",{className:"assistant-input-textarea",value:f,onChange:ie=>N(ie.target.value),rows:4,placeholder:j?"Продолжите вопрос по выбранному объекту...":"Введите вопрос к данным компании..."})]}),o.jsxs("div",{className:"button-row assistant-send-row",children:[o.jsxs("label",{className:"checkbox-row",children:[o.jsx("input",{type:"checkbox",checked:Y,onChange:ie=>b(ie.target.checked)}),"Mock-режим"]}),o.jsx("button",{type:"button",className:"assistant-send-btn",onClick:()=>{ct(!0),Q()},disabled:z||!f.trim(),children:z?"Выполняю...":"Отправить"})]})]})]})})}const cl="http://127.0.0.1:1234/v1",Ac="https://api.openai.com/v1",hl="qwen2.5-14b-instruct-1m",ua="unsloth/qwen3-30b-a3b-instruct-2507",em=[{value:hl,label:"Qwen2.5 14B Instruct 1M"},{value:ua,label:"Qwen3 30B A3B Instruct 2507"}];function tm(i){return i.llmProvider!=="local"?"openai":i.model===ua?"local_qwen3":i.model===hl?"local_qwen25":"local_custom"}function nm(i,p){const f=new Map;if(p)for(const N of em)f.set(N.value,N);for(const N of i)f.has(N)||f.set(N,{value:N,label:N});return Array.from(f.values())}function oa({value:i,modelOptions:p,modelsBusy:f,onChange:N,onReloadModels:j,onTestConnection:T,onSaveLocalConfig:$,lastStatus:Y,busy:b,embedded:Q=!1}){const G=i.llmProvider==="local",z=tm(i),ne=nm(p,G),Ne=ne.some(W=>W.value===i.model),[le,ce]=x.useState(String(i.temperature)),[me,Qe]=x.useState(String(i.maxOutputTokens));x.useEffect(()=>{ce(String(i.temperature))},[i.temperature]),x.useEffect(()=>{Qe(String(i.maxOutputTokens))},[i.maxOutputTokens]);const De=W=>{const de=W.replace(",",".").trim();if(!de){ce(String(i.temperature));return}const Me=Number(de);if(!Number.isFinite(Me)){ce(String(i.temperature));return}N({...i,temperature:Me}),ce(String(Me))},We=W=>{const de=W.trim();if(!de){Qe(String(i.maxOutputTokens));return}const Me=Number.parseInt(de,10);if(!Number.isFinite(Me)||Me<=0){Qe(String(i.maxOutputTokens));return}N({...i,maxOutputTokens:Me}),Qe(String(Me))},je=o.jsxs(o.Fragment,{children:[o.jsxs("div",{className:"grid-two",children:[o.jsxs("label",{children:["Provider",o.jsxs("select",{value:z,onChange:W=>{const de=W.target.value;if(de==="openai"){N({...i,llmProvider:"openai",baseUrl:Ac});return}if(de==="local_qwen25"){N({...i,llmProvider:"local",model:hl,baseUrl:cl});return}if(de==="local_qwen3"){N({...i,llmProvider:"local",model:ua,baseUrl:cl});return}N({...i,llmProvider:"local",model:i.llmProvider==="local"?i.model:hl,baseUrl:cl})},children:[o.jsx("option",{value:"openai",children:"OpenAI (token)"}),o.jsx("option",{value:"local_qwen25",children:"Qwen2.5 14B Instruct 1M (Local LM Studio)"}),o.jsx("option",{value:"local_qwen3",children:"Qwen3 30B A3B Instruct 2507 (Local LM Studio)"}),o.jsx("option",{value:"local_custom",children:"Local custom (LM Studio / OpenAI-compatible)"})]})]}),o.jsxs("label",{children:["Model",o.jsxs("select",{value:Ne?i.model:"__manual__",onChange:W=>{const de=W.target.value;de!=="__manual__"&&N({...i,model:de})},children:[o.jsx("option",{value:"__manual__",children:"Manual input"}),ne.map(W=>o.jsx("option",{value:W.value,children:W.label},W.value))]})]}),o.jsxs("label",{children:["Model ID (manual / current)",o.jsx("input",{value:i.model,onChange:W=>N({...i,model:W.target.value}),placeholder:"qwen2.5-14b-instruct-1m or unsloth/qwen3-30b-a3b-instruct-2507"})]}),G?null:o.jsxs("label",{className:"full-width",children:["OpenAI API Key",o.jsx("input",{type:"password",value:i.apiKey,onChange:W=>N({...i,apiKey:W.target.value}),placeholder:"sk-..."})]}),o.jsxs("label",{className:G?"full-width":void 0,children:[G?"Local server base URL":"Base URL",o.jsx("input",{value:i.baseUrl,onChange:W=>N({...i,baseUrl:W.target.value}),placeholder:G?cl:Ac})]}),o.jsxs("label",{children:["Temperature",o.jsx("input",{type:"number",step:"0.1",value:le,onChange:W=>ce(W.target.value),onBlur:W=>De(W.target.value),onKeyDown:W=>{W.key==="Enter"&&De(W.target.value)}})]}),o.jsxs("label",{children:["Max output tokens",o.jsx("input",{type:"number",value:me,onChange:W=>Qe(W.target.value),onBlur:W=>We(W.target.value),onKeyDown:W=>{W.key==="Enter"&&We(W.target.value)}})]})]}),o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>$(),children:"Save local config"}),o.jsx("button",{type:"button",onClick:()=>j(),disabled:b||f,children:f?"Loading models...":"Load model list"}),o.jsx("button",{type:"button",onClick:()=>T(),disabled:b,children:b?"Checking...":"Test connection"})]})]});return Q?o.jsxs("section",{className:"embedded-panel-section",children:[o.jsxs("div",{className:"embedded-panel-section-header",children:[o.jsxs("div",{children:[o.jsx("h4",{children:"LLM Connector"}),o.jsx("p",{children:"Switch between OpenAI cloud and local OpenAI-compatible server."})]}),o.jsx("span",{className:"status-chip",children:Y||"Status: not checked"})]}),je]}):o.jsx(In,{title:"LLM Connector",subtitle:"Switch between OpenAI cloud and local OpenAI-compatible server.",actions:o.jsx("span",{className:"status-chip",children:Y||"Status: not checked"}),children:je})}function la({value:i,onChange:p,presets:f,selectedPresetId:N,onSelectPreset:j,onLoadPreset:T,onSavePreset:$,onResetDefaults:Y,onDiffPrevious:b,presetName:Q,onPresetNameChange:G,diffSummary:z,embedded:ne=!1}){const Ne=o.jsxs(o.Fragment,{children:[o.jsxs("div",{className:"prompt-manager-grid",children:[o.jsxs("label",{children:["Системный prompt",o.jsx("textarea",{value:i.systemPrompt,onChange:le=>p({...i,systemPrompt:le.target.value}),rows:6})]}),o.jsxs("label",{children:["Developer / Instruction prompt",o.jsx("textarea",{value:i.developerPrompt,onChange:le=>p({...i,developerPrompt:le.target.value}),rows:6})]}),o.jsxs("label",{children:["Domain prompt",o.jsx("textarea",{value:i.domainPrompt,onChange:le=>p({...i,domainPrompt:le.target.value}),rows:6})]}),o.jsxs("label",{children:["Schema notes",o.jsx("textarea",{value:i.schemaNotes,onChange:le=>p({...i,schemaNotes:le.target.value}),rows:6})]}),o.jsxs("label",{className:"full-width",children:["Few-shot examples",o.jsx("textarea",{value:i.fewShotExamples,onChange:le=>p({...i,fewShotExamples:le.target.value}),rows:8})]})]}),o.jsxs("div",{className:"button-row",children:[o.jsxs("select",{value:N,onChange:le=>j(le.target.value),children:[o.jsx("option",{value:"",children:"Выберите preset..."}),f.map(le=>o.jsx("option",{value:le.id,children:le.name},le.id))]}),o.jsx("button",{type:"button",onClick:()=>T(),children:"Загрузить preset"}),o.jsx("input",{value:Q,onChange:le=>G(le.target.value),placeholder:"Имя для сохранения"}),o.jsx("button",{type:"button",onClick:()=>$(),children:"Сохранить preset"}),o.jsx("button",{type:"button",onClick:()=>b(),children:"Diff с предыдущим"}),o.jsx("button",{type:"button",onClick:()=>Y(),children:"Сбросить к default"})]}),z?o.jsx("p",{className:"diff-summary",children:z}):null]});return ne?o.jsxs("section",{className:"embedded-panel-section",children:[o.jsx("div",{className:"embedded-panel-section-header",children:o.jsxs("div",{children:[o.jsx("h4",{children:"Prompt Manager"}),o.jsx("p",{children:"Системный, developer и domain уровни управляются отдельно."})]})}),Ne]}):o.jsx(In,{title:"Prompt Manager",subtitle:"Системный, developer и domain уровни управляются отдельно.",children:Ne})}const Yi={fromLocal:"",toLocal:"",target:"all",mode:"all",useMock:"any",promptContains:"",limit:120},dl="needs_dialog_policy_fix",Nt="__all__",gl="__live__:",Rc="ndc_autoruns_ui_config_v1",Tc="ndc-autoruns-save",Xi=["Анализ запроса","Получение данных","Подготовка ответа"];function rm(i,p){const f=i.trim();if(!f)return"";if(!p)return f;const N=f.toLowerCase(),j=p.anchor_text.trim(),T=j.toLowerCase();return T&&N.includes(T)?f:`По выбранному объекту "${j}": ${f}`}const ia=[{id:"general",label:"Общий контур",domain:"",defaultPrompt:"Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл."}];function sm(i=ia){return i.reduce((p,f)=>(p[f.id]=f.defaultPrompt,p),{})}const Ic={mode:"codex_creative",count:24,personalityId:"general",personalityPrompts:sm(),persistToEvalCases:!0,generatedBy:"manual_reviewer"};function Zi(i){const p=String(i??"").trim();return/^\d{4}-\d{2}-\d{2}$/.test(p)?p:""}function Lc(i){const p=typeof i=="number"&&Number.isFinite(i)?Math.trunc(i):160;return Math.max(110,Math.min(520,p))}function om(i){const p=i.getFullYear(),f=String(i.getMonth()+1).padStart(2,"0"),N=String(i.getDate()).padStart(2,"0"),j=String(i.getHours()).padStart(2,"0"),T=String(i.getMinutes()).padStart(2,"0");return`${p}-${f}-${N}T${j}:${T}`}function Oc(){const i=new Date;return i.setDate(i.getDate()-14),om(i)}function fl(i){if(!i.trim())return;const p=Date.parse(i);if(Number.isFinite(p))return new Date(p).toISOString()}function vr(i){if(!i)return"нет данных";const p=Date.parse(i);return Number.isFinite(p)?new Date(p).toLocaleString("ru-RU"):i}function lm(i,p){return p<=0?0:Math.max(0,Math.min(100,Number((i/p*100).toFixed(1))))}function ml(i){return typeof i!="number"?"нет данных":`${i.toFixed(1)}%`}function im(i){return i==="assistant_stage1"?"assistant/s1":i==="assistant_stage2"?"assistant/s2":i==="assistant_p0"?"assistant/p0":i}function Dc(i){return i==="up"?"Рост":i==="down"?"Регресс":"Без изменений"}function am(i,p){return i.find(f=>f.case_id===p)??null}function ea(i){const p=Math.max(1,Math.min(5,Math.round(i)));return`${"●".repeat(p)}${"○".repeat(5-p)}`}function zc(i){return i.length===0?o.jsx("p",{className:"muted",children:"Покрытие доменов пока не сформировано."}):o.jsx("div",{className:"autoruns-coverage-list",children:i.map(p=>{const f=lm(p.closed_cases,p.total_cases);return o.jsxs("div",{className:"autoruns-coverage-item",children:[o.jsxs("div",{className:"autoruns-coverage-head",children:[o.jsx("strong",{children:p.domain}),o.jsxs("span",{children:[p.closed_cases,"/",p.total_cases," (",f,"%)"]})]}),o.jsx("div",{className:"autoruns-coverage-bar",children:o.jsx("div",{style:{width:`${f}%`}})})]},p.domain)})})}function pl(i){return`${gl}${i}`}function Ds(i){return i.startsWith(gl)}function $c(i){return i.startsWith(gl)?i.slice(gl.length):""}function qc(i){const p=i.report_summary?.run_timestamp??i.created_at,f=Math.max(0,i.total_cases-i.completed_cases);return{run_id:pl(i.job_id),eval_target:i.eval_target,run_timestamp:p,mode:"single-pass-strict",llm_provider:null,model:null,use_mock:null,analysis_date:i.report_summary?.analysis_date??i.analysis_date??null,prompt_version:null,schema_version:null,suite_id:i.case_set_file,cases_total:i.total_cases,requests_total:null,report_path:`async_job:${i.job_id}`,score_index:i.report_summary?.score_index??null,blocking_failures:0,quality_failures:0,closed_cases:i.completed_cases,open_cases:f,domain_coverage:[{domain:"runtime",total_cases:i.total_cases,closed_cases:i.completed_cases}]}}function po(i,p){const f=qc(i),N=i.cases.map(G=>({case_id:G.case_id,domain:null,query_class:null,status:G.status==="completed"?"closed":G.status==="failed"?"open":"unknown",score_index:null,trace_id:null,reply_type:null,session_id:`${i.run_id}-${G.case_id}`,dialog_available:G.messages.length>0,commented_count:0,latest_annotation_at:null,avg_rating:null,checks:null,metric_subscores:null})),T=p!==Nt&&N.some(G=>G.case_id===p)?p:N.length>0?Nt:"",$={ok:!0,run:f,coverage:{closed_cases:i.completed_cases,open_cases:Math.max(0,i.total_cases-i.completed_cases),domain_coverage:[{domain:"runtime",total_cases:i.total_cases,closed_cases:i.completed_cases}]},cases:N,annotations_summary:{total:0},report:i.report_summary?{run_id:i.report_summary.run_id,run_timestamp:i.report_summary.run_timestamp,score_index:i.report_summary.score_index,cases_total:i.report_summary.cases_total,analysis_date:i.report_summary.analysis_date??i.analysis_date??null}:{}},Y=[];let b=0;if(T===Nt)for(const G of i.cases)for(let z=0;zz.case_id===T)??null;for(let z=0;z<(G?.messages.length??0);z+=1){const ne=G?.messages[z];ne&&Y.push({...ne,message_index:z,case_id:T,case_message_index:z,commented:!1,annotation:null})}}const Q={ok:!0,run_id:f.run_id,case_id:T,source:"assistant_session",session_id:T===Nt?`${i.run_id}::__all__`:`${i.run_id}-${T}`,messages:Y,decomposition:[],assistant_mode:{status:i.status,completed_cases:i.completed_cases,total_cases:i.total_cases},annotations:[]};return{detail:$,dialog:Q,caseId:T}}function um({commented:i}){const p=i?"comment-icon-svg commented":"comment-icon-svg";return o.jsx("svg",{className:p,viewBox:"0 0 24 24","aria-hidden":"true",focusable:"false",children:o.jsx("path",{d:"M5 6.5h14v9H11.5l-4.5 3v-3H5z"})})}function Fc({resolved:i}){return o.jsxs("svg",{className:i?"resolve-icon-svg resolved":"resolve-icon-svg",viewBox:"0 0 16 16","aria-hidden":"true",focusable:"false",children:[o.jsx("circle",{cx:"8",cy:"8",r:"6.2"}),i?o.jsx("path",{d:"M5.1 8.2 7.2 10.3 11 6.5"}):null]})}function cm(){return o.jsxs("svg",{className:"autoruns-copy-icon-svg",viewBox:"0 0 24 24","aria-hidden":"true",focusable:"false",children:[o.jsx("rect",{x:"9",y:"9",width:"11",height:"11",rx:"2.2"}),o.jsx("path",{d:"M15 7V5.8a1.8 1.8 0 0 0-1.8-1.8H5.8A1.8 1.8 0 0 0 4 5.8v7.4A1.8 1.8 0 0 0 5.8 15H7"})]})}function dm({connection:i,modelOptions:p,modelsBusy:f,connectionStatus:N,connectionBusy:j,onConnectionChange:T,onReloadModels:$,onSaveLocalConfig:Y,onTestConnection:b,prompts:Q,onPromptsChange:G,promptPresets:z,selectedPresetId:ne,onSelectPreset:Ne,onLoadPreset:le,onSavePreset:ce,onResetDefaults:me,onDiffPrevious:Qe,presetName:De,onPresetNameChange:We,diffSummary:je,assistantPromptVersion:W,decompositionPromptVersion:de,showSettingsMode:Me,showAutoRunsMode:Ze,showAssistantMode:ct,showDecompositionMode:st,showProgressMode:Et,showCommentsMode:ie,onLog:Le}){const[H,Fe]=x.useState({...Yi,fromLocal:Oc()}),[Te,Ae]=x.useState(""),[I,X]=x.useState(null),[O,y]=x.useState(null),[C,J]=x.useState(null),[oe,pe]=x.useState([]),[ae,Se]=x.useState("all"),[ge,ve]=x.useState(!1),[Ee,gn]=x.useState(null),[vn,Yn]=x.useState([]),[Ln,Xn]=x.useState(""),[Pe,qt]=x.useState(""),[ot,dt]=x.useState(""),[lt,yn]=x.useState(ia),[re,It]=x.useState(Ic),[tt,Vr]=x.useState([]),[nn,xn]=x.useState(""),[xt,_n]=x.useState([]),[Oe,rn]=x.useState(null),[On,xr]=x.useState(null),[Dn,Qr]=x.useState(!1),[Sn,sn]=x.useState(!1),[Lt,Zn]=x.useState(!1),[Kt,on]=x.useState(!1),[Ot,_r]=x.useState(!1),[zn,Sr]=x.useState(!1),[$n,wr]=x.useState(!1),[ze,er]=x.useState(!1),[Dt,Fn]=x.useState(""),[wn,Ge]=x.useState(""),[nt,ln]=x.useState(""),[zt,Un]=x.useState([]),[bn,Gt]=x.useState([]),[jr,_t]=x.useState(""),[jn,an]=x.useState(null),[tr,Wr]=x.useState(!1),[Re,Pt]=x.useState(!1),[nr,Bn]=x.useState(""),[cs,D]=x.useState(""),[zs,Mt]=x.useState(String(Yi.limit)),[qr,St]=x.useState(String(Ic.count)),[rr,Kr]=x.useState(160),[ue,Ue]=x.useState({open:!1,caseId:"",caseMessageIndex:-1,messageIndex:-1,rating:3,comment:"",manualCaseDecision:dl,annotationAuthor:"manual_reviewer",saving:!1,error:""}),[ye,be]=x.useState({open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:"manual_reviewer",saving:!1,error:""}),sr=x.useRef(!1),Hn=x.useRef(null),Vn=x.useMemo(()=>lt.find(a=>a.id===re.personalityId)??lt[0]??ia[0],[re.personalityId,lt]),$t=x.useMemo(()=>tt.find(a=>a.generation_id===nn)??tt[0]??null,[tt,nn]),kn=O?am(O.cases,ot):null,At=x.useMemo(()=>ge?oe.filter(a=>!a.resolved):oe,[oe,ge]),ke=At.find(a=>a.annotation_id===Ln)??null,ds=C?.messages.find(a=>a.message_index===ue.messageIndex)??null,$s=x.useMemo(()=>{if(!C||ue.messageIndex<0)return null;for(let a=ue.messageIndex-1;a>=0;a-=1){const c=C.messages[a];if(c?.role==="user")return c}return null},[ue.messageIndex,C]),Cn=x.useMemo(()=>{const a=new Map;for(const c of bn)c.message_id&&a.set(c.message_id,c);return a},[bn]),kr=ye.messageIndex>=0?zt[ye.messageIndex]??null:null,or=x.useMemo(()=>{if(ye.messageIndex<0)return null;for(let a=ye.messageIndex-1;a>=0;a-=1){const c=zt[a];if(c?.role==="user")return c}return null},[ye.messageIndex,zt]),it=x.useMemo(()=>{const a=At.map(v=>({source:"autorun",key:`autorun:${v.annotation_id}`,updated_at:v.updated_at,rating:v.rating,autorun:v,assistant:null})),c=bn.map(v=>({source:"assistant_live",key:`assistant:${v.annotation_id}`,updated_at:v.updated_at,rating:v.rating,autorun:null,assistant:v}));return[...a,...c].sort((v,R)=>Date.parse(R.updated_at)-Date.parse(v.updated_at))},[bn,At]),lr=x.useMemo(()=>{if(it.length===0)return null;const a=it.reduce((c,v)=>c+v.rating,0)/it.length;return Number(a.toFixed(2))},[it]),ir=x.useMemo(()=>{const a=[...I?.items??[]];return Oe&&a.unshift(qc(Oe)),Pe&&!a.some(c=>c.run_id===Pe)&&O?.run&&a.unshift(O.run),a},[Oe,I?.items,O?.run,Pe]),F=x.useCallback(a=>{Le?.(`[autoruns] ${a}`)},[Le]),ar=x.useCallback(async a=>{const c=String(a??"").trim();if(!c){Gt([]);return}try{const v=await _e.loadAssistantAnnotations({session_id:c,limit:400});Gt(v.items??[])}catch(v){const R=v instanceof Error?v.message:String(v);F(`Assistant live annotations load error: ${R}`)}},[F]),Nn=x.useCallback(a=>{be(c=>c.saving&&!a?.force?c:{open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:"manual_reviewer",saving:!1,error:""})},[]),Cr=x.useCallback(async(a,c)=>{a.stopPropagation(),a.preventDefault();const v=String(c??"").trim();if(v)try{if(navigator?.clipboard?.writeText)await navigator.clipboard.writeText(v);else{const R=document.createElement("textarea");R.value=v,R.setAttribute("readonly","true"),R.style.position="fixed",R.style.opacity="0",document.body.appendChild(R),R.select(),document.execCommand("copy"),document.body.removeChild(R)}F(`run id copied: ${v}`)}catch(R){const fe=R instanceof Error?R.message:String(R);Ge(`Копирование run id: ${fe}`),F(`copy run id error: ${fe}`)}},[F]);function fs(){let a=0;Bn(Xi[0]);const c=window.setInterval(()=>{a=Math.min(a+1,Xi.length-1),Bn(Xi[a])},650);return()=>window.clearInterval(c)}const m=x.useCallback(()=>{ln(""),Un([]),Gt([]),_t(""),an(null),Bn(""),D(""),Nn({force:!0}),F("Live-чат ассистента в истории автопрогонов сброшен.")},[Nn,F]),E=x.useCallback(async()=>{const a=rm(jr,jn);if(!a)return;Pt(!0),D(""),_t(""),Un(v=>[...v,{message_id:`autoruns-live-${Date.now()}`,session_id:nt||"pending",role:"user",text:a,reply_type:null,created_at:new Date().toISOString(),trace_id:null,debug:null}]);const c=fs();try{const v=await _e.sendAssistantMessage({connection:i,prompts:Q,userMessage:a,sessionId:nt||void 0,promptVersion:W,useMock:tr});ln(v.session_id),Un(v.conversation),await ar(v.session_id),Bn("Ответ готов"),F(`Live-ответ ассистента получен: trace=${v.debug.trace_id}`)}catch(v){const R=v instanceof Error?v.message:String(v);D(R),Bn("Ошибка ассистента"),F(`Live-чат ассистента: ошибка отправки сообщения: ${R}`)}finally{c(),Pt(!1)}},[jr,jn,nt,tr,W,i,ar,F,Q]),k=x.useCallback(a=>{const c=a.trim();if(!c){Mt(String(H.limit));return}if(!/^\d+$/.test(c)){Mt(String(H.limit));return}const v=Number.parseInt(c,10);if(!Number.isFinite(v)){Mt(String(H.limit));return}const R=Math.max(1,Math.min(500,v));R!==H.limit&&Fe(fe=>({...fe,limit:R})),Mt(String(R))},[H.limit]),te=x.useCallback(a=>{const c=a.trim();if(!c){St(String(re.count));return}if(!/^\d+$/.test(c)){St(String(re.count));return}const v=Number.parseInt(c,10);if(!Number.isFinite(v)){St(String(re.count));return}const R=Math.max(1,Math.min(200,v));R!==re.count&&It(fe=>({...fe,count:R})),St(String(R))},[re.count]),Ie=x.useCallback(a=>{Kr(Lc(a))},[]),gt=x.useCallback(a=>{const c=a.currentTarget.offsetHeight;Number.isFinite(c)&&c>0&&Ie(c)},[Ie]),Ft=x.useCallback(async()=>{er(!0);try{const a=await _e.loadAutoRunAnnotations({limit:800,manual_case_decision:ae});pe(a.items),gn(a.manual_case_decision_schema??null),Yn(a.available_manual_case_decisions??[]),Xn(c=>a.items.length===0?"":a.items.some(v=>v.annotation_id===c)?c:a.items[0].annotation_id)}catch(a){F(`Annotations load error: ${a instanceof Error?a.message:String(a)}`)}finally{er(!1)}},[ae,F]),Jt=x.useCallback(async()=>{on(!0);try{const a=await _e.loadAutoRunAutogenHistory({limit:180});Vr(a.items)}catch(a){F(`Autogen history load error: ${a instanceof Error?a.message:String(a)}`)}finally{on(!1)}},[F]),Nr=x.useCallback(async()=>{try{const c=(await _e.loadAutoRunAutogenPersonalityCatalog()).items.map(v=>({id:String(v.id??"").trim(),label:String(v.label??"").trim(),domain:typeof v.domain=="string"?v.domain.trim():"",defaultPrompt:String(v.default_prompt??"").trim()})).filter(v=>v.id.length>0&&v.label.length>0);if(c.length===0)return;yn(c.map(v=>({id:v.id,label:v.label,domain:v.domain||"",defaultPrompt:v.defaultPrompt||"Генерируй реалистичные вопросы бухгалтера по выбранному профилю. Не выдумывай непокрытые возможности."})))}catch(a){F(`Autogen personality catalog load error: ${a instanceof Error?a.message:String(a)}`)}},[F]),ft=x.useCallback(async()=>{Zn(!0);try{const a=await _e.loadAutoRunPostAnalysis({run_id:Pe&&!Ds(Pe)?Pe:void 0,limit_per_queue:30,annotation_limit:1500,from:fl(H.fromLocal),to:fl(H.toLocal),target:H.target,mode:H.mode,use_mock:H.useMock,prompt_contains:H.promptContains.trim()||void 0});xr(a)}catch(a){F(`Post-analysis load error: ${a instanceof Error?a.message:String(a)}`),xr(null)}finally{Zn(!1)}},[H.fromLocal,H.mode,H.promptContains,H.target,H.toLocal,H.useMock,F,Pe]),vl=x.useCallback(async()=>{Qr(!0),Ge("");try{const a=re.personalityPrompts[re.personalityId]??"",c=[Q.systemPrompt,Q.developerPrompt,Q.domainPrompt,Q.schemaNotes,Q.fewShotExamples].join(` -`).slice(0,900),v=await _e.generateAutoRunQuestions({mode:re.mode,count:re.count,domain:Vn.domain||void 0,persist_to_eval_cases:re.persistToEvalCases,generated_by:re.generatedBy.trim()||void 0,llm:{llm_provider:i.llmProvider,api_key:i.apiKey,model:i.model,base_url:i.baseUrl,temperature:i.temperature,max_output_tokens:i.maxOutputTokens},context:{llm_provider:i.llmProvider,model:i.model,assistant_prompt_version:W,decomposition_prompt_version:de,prompt_fingerprint:c,autogen_personality_id:Vn.id,autogen_personality_prompt:a.trim()||void 0}});F(`Generated ${v.generation.count} questions (${v.generation.mode}) id=${v.generation.generation_id}`+(v.generation.saved_case_set_file?` saved=${v.generation.saved_case_set_file}`:"")),xn(v.generation.generation_id),_n([...v.generation.questions??[]]),await Jt()}catch(a){const c=a instanceof Error?a.message:String(a);Ge(`Автогенерация: ${c}`),F(`Autogen generate error: ${c}`)}finally{Qr(!1)}},[W,re.count,re.generatedBy,re.mode,re.personalityId,re.personalityPrompts,re.persistToEvalCases,i.apiKey,i.baseUrl,i.llmProvider,i.maxOutputTokens,i.model,i.temperature,de,Jt,F,Q.developerPrompt,Q.domainPrompt,Q.fewShotExamples,Q.schemaNotes,Q.systemPrompt,Vn.domain,Vn.id]),Er=x.useCallback(async(a,c)=>{if(Ds(a)){const v=$c(a);if(Oe&&Oe.job_id===v){const R=po(Oe,c);qt(a),dt(R.caseId),J(R.dialog);return}J(null);return}wr(!0);try{const v=await _e.loadAutoRunCaseDialog(a,c);J(v)}catch(v){const R=v instanceof Error?v.message:String(v);Ge(`Диалог кейса: ${R}`),J(null),F(`Dialog load error for ${a}/${c}: ${R}`)}finally{wr(!1)}},[Oe,F]),Ut=x.useCallback(async(a,c)=>{if(Ds(a)){const v=$c(a);if(Oe&&Oe.job_id===v){const R=po(Oe,c??Nt);qt(a),dt(R.caseId),y(R.detail),J(R.dialog);return}qt(a),dt(""),y(null),J(null);return}Sr(!0);try{const v=await _e.loadAutoRunDetail(a);y(v);const R=(c&&(c===Nt||v.cases.some(fe=>fe.case_id===c))?c:"")||(v.cases.length>0?Nt:"")||"";qt(a),dt(R),R?await Er(a,R):J(null)}catch(v){const R=v instanceof Error?v.message:String(v);Ge(`Детализация прогона: ${R}`),y(null),J(null),F(`Run detail load error for ${a}: ${R}`)}finally{Sr(!1)}},[Oe,Er,F]),Gr=x.useCallback(async a=>{_r(!0),Ge("");try{const c=await _e.loadAutoRunsHistory({from:fl(H.fromLocal),to:fl(H.toLocal),target:H.target,mode:H.mode,use_mock:H.useMock,prompt_contains:H.promptContains.trim()||void 0,limit:H.limit});if(X(c),c.items.length===0){qt(""),dt(""),y(null),J(null);return}const v=a?.keepSelection??!0,R=a?.preferredRunId??"",fe=a?.preferredCaseId??"",Je=v&&R&&c.items.some(Yt=>Yt.run_id===R)?R:c.items[0].run_id;await Ut(Je,v?fe:void 0),ft()}catch(c){const v=c instanceof Error?c.message:String(c);Ge(`История прогонов: ${v}`),F(`History load error: ${v}`)}finally{_r(!1)}},[H.fromLocal,H.limit,H.mode,H.promptContains,H.target,H.toLocal,H.useMock,ft,Ut,F]),un=x.useCallback(()=>{Hn.current!==null&&(window.clearTimeout(Hn.current),Hn.current=null)},[]),Pr=x.useCallback(async a=>{try{const c=await _e.loadEvalRunAsyncStatus(a);rn(c.job);const v=pl(a);if(Pe===v){const R=po(c.job,ot||Nt);y(R.detail),J(R.dialog),dt(R.caseId)}if(c.job.status==="completed"){un(),sn(!1);const R=c.job.report_summary?.run_id??c.job.run_id;await Gr({keepSelection:!0,preferredRunId:R||Pe,preferredCaseId:Nt}),await Jt(),rn(null);return}if(c.job.status==="failed"){un(),sn(!1),Ge(`Запуск прогонов: ${c.job.error??"неизвестная ошибка"}`),F(`Autogen async run failed: ${c.job.error??"unknown error"}`);return}un(),Hn.current=window.setTimeout(()=>{Pr(a)},500)}catch(c){un(),sn(!1);const v=c instanceof Error?c.message:String(c);Ge(`Запуск прогонов: ${v}`),F(`Autogen async status error: ${v}`)}},[Jt,Gr,F,ot,Pe,un]),ho=x.useCallback(async()=>{un(),sn(!0),Ge("");try{const a=$t;if(!a)throw new Error("История автогенерации пуста. Сначала сгенерируйте пачку вопросов.");const c=xt.map(Wn=>Wn.trim()).filter(Wn=>Wn.length>0);if(c.length===0)throw new Error("Нет вопросов для запуска: список пустой после ручного редактирования.");const v=H.useMock==="true",R=Zi(Te),Je=(await _e.startEvalRunAsync({connection:i,prompts:Q,promptVersion:W,mode:"single-pass-strict",caseSetFile:a.saved_case_set_file??void 0,useMock:v,evalTarget:"assistant_stage1",questions:c,analysisDate:R||void 0})).job;rn(Je);const Yt=pl(Je.job_id),Ye=po(Je,Nt);qt(Yt),dt(Ye.caseId),y(Ye.detail),J(Ye.dialog),F(`Запущен async-прогон job=${Je.job_id}, run_id=${Je.run_id}, вопросов=${c.length}`+(a.saved_case_set_file?`, base_case_set=${a.saved_case_set_file}`:"")+(R?`, analysis_date=${R}`:", analysis_date=current_state")),Pr(Je.job_id)}catch(a){const c=a instanceof Error?a.message:String(a);Ge(`Запуск прогонов: ${c}`),F(`Autogen run error: ${c}`),sn(!1)}},[Te,W,i,xt,H.useMock,F,Pr,Q,$t,un]),yl=x.useCallback(a=>{if(a.role!=="assistant")return;const c=a.case_id??ot,v=a.case_message_index??a.message_index;Ue({open:!0,caseId:c,caseMessageIndex:v,messageIndex:a.message_index,rating:a.annotation?.rating??3,comment:a.annotation?.comment??"",manualCaseDecision:a.annotation?.manual_case_decision??dl,annotationAuthor:a.annotation?.annotation_author??re.generatedBy,saving:!1,error:""})},[re.generatedBy,ot]),Qn=x.useCallback(a=>{Ue(c=>c.saving&&!a?.force?c:{open:!1,caseId:"",caseMessageIndex:-1,messageIndex:-1,rating:3,comment:"",manualCaseDecision:dl,annotationAuthor:re.generatedBy,saving:!1,error:""})},[re.generatedBy]),Jr=x.useCallback(async()=>{const a=Pe,c=ue.caseId,v=ue.caseMessageIndex;if(!(!a||!c||v<0)){if(Ds(a)){Ue(R=>({...R,error:"Комментарий можно сохранить после завершения прогона."}));return}if(!ue.comment.trim()){Ue(R=>({...R,error:"Добавьте комментарий."}));return}Ue(R=>({...R,saving:!0,error:""}));try{await _e.saveAutoRunAnnotation({run_id:a,case_id:c,message_index:v,rating:ue.rating,comment:ue.comment.trim(),manual_case_decision:ue.manualCaseDecision,annotation_author:ue.annotationAuthor.trim()||void 0}),Qn({force:!0}),Promise.all([Ut(a,ot),Ft(),ft()]).catch(R=>{const fe=R instanceof Error?R.message:String(R);Ge(`Обновление после комментария: ${fe}`),F(`Comment refresh error: ${fe}`)})}catch(R){Ue(fe=>({...fe,saving:!1,error:R instanceof Error?R.message:String(R)}))}}},[Qn,ue.annotationAuthor,ue.caseId,ue.caseMessageIndex,ue.comment,ue.manualCaseDecision,ue.rating,Ft,ft,Ut,F,ot,Pe]),Mr=x.useCallback(a=>a.role==="assistant",[]),ms=x.useCallback(a=>a.role==="assistant"&&Cn.has(a.message_id),[Cn]),xl=x.useCallback((a,c)=>{if(a.role!=="assistant")return;const v=nt.trim(),R=String(a.session_id??"").trim();if(!(v||R)){D("Сначала получите ответ ассистента в активной сессии.");return}!v&&R&&ln(R);const Je=Cn.get(a.message_id)??null;D(""),be({open:!0,messageIndex:c,rating:Je?.rating??3,comment:Je?.comment??"",annotationAuthor:Je?.annotation_author??"manual_reviewer",saving:!1,error:""})},[Cn,nt]),_l=x.useCallback(async()=>{if(ye.messageIndex<0)return;if(!ye.comment.trim()){be(v=>({...v,error:"Добавьте комментарий."}));return}const a=zt[ye.messageIndex]??null,c=nt.trim()||(a?.role==="assistant"?String(a.session_id??"").trim():"");if(!c){be(v=>({...v,error:"Сессия ассистента не найдена."}));return}be(v=>({...v,saving:!0,error:""}));try{const v=await _e.saveAssistantAnnotation({session_id:c,message_index:ye.messageIndex,rating:ye.rating,comment:ye.comment.trim(),annotation_author:ye.annotationAuthor.trim()||void 0});Gt(R=>{const fe=[...R],Je=fe.findIndex(Yt=>Yt.annotation_id===v.annotation.annotation_id);return Je>=0?fe[Je]=v.annotation:fe.unshift(v.annotation),fe.sort((Yt,Ye)=>Date.parse(Ye.updated_at)-Date.parse(Yt.updated_at))}),Nn({force:!0})}catch(v){const R=v instanceof Error?v.message:String(v);be(fe=>({...fe,saving:!1,error:R}))}},[ye.annotationAuthor,ye.comment,ye.messageIndex,ye.rating,zt,nt,Nn]),ps=x.useCallback(a=>{pe(c=>c.map(v=>v.annotation_id===a.annotation_id?{...v,...a}:v)),J(c=>c&&{...c,annotations:c.annotations.map(v=>v.annotation_id===a.annotation_id?a:v),messages:c.messages.map(v=>!v.annotation||v.annotation.annotation_id!==a.annotation_id?v:{...v,commented:!0,annotation:a})})},[]),Yr=x.useCallback(async(a,c)=>{if(a.annotation_id){if(Ds(a.run_id)){Ge("Статус выполнения можно менять только для завершённых прогонов.");return}Fn(a.annotation_id);try{const v=await _e.updateAutoRunAnnotation({annotation_id:a.annotation_id,resolved:c,resolved_by:re.generatedBy||void 0});ps(v.annotation),ft()}catch(v){const R=v instanceof Error?v.message:String(v);Ge(`Смена статуса кейса: ${R}`),F(`Annotation resolve toggle error: ${R}`)}finally{Fn("")}}},[ps,re.generatedBy,ft,F]),hs=x.useCallback(async a=>{Xn(a.annotation_id),await Ut(a.run_id,a.case_id),I?.items.some(c=>c.run_id===a.run_id)||Ge("Комментарий относится к прогону вне текущего фильтра. Детали загружены напрямую.")},[I?.items,Ut]);x.useEffect(()=>{sr.current||(sr.current=!0,Gr({keepSelection:!1}),Jt(),Nr(),ft())},[Jt,Nr,Gr,ft]),x.useEffect(()=>{sr.current&&Ft()},[ae,Ft]),x.useEffect(()=>{Xn(a=>At.length===0?"":At.some(c=>c.annotation_id===a)?a:At[0].annotation_id)},[At]),x.useEffect(()=>{xn(a=>tt.length===0?"":a&&tt.some(c=>c.generation_id===a)?a:tt[0].generation_id)},[tt]),x.useEffect(()=>{if(!$t){_n([]);return}_n([...$t.questions])},[$t?.generation_id]),x.useEffect(()=>{Mt(String(H.limit))},[H.limit]),x.useEffect(()=>{St(String(re.count))},[re.count]),x.useEffect(()=>{if(!nt.trim()){Gt([]);return}ar(nt)},[nt,ar]),x.useEffect(()=>{if(!Oe)return;const a=pl(Oe.job_id);if(Pe!==a)return;const c=po(Oe,ot||Nt);y(c.detail),J(c.dialog),dt(c.caseId)},[Oe,ot,Pe]),x.useEffect(()=>()=>{un()},[un]),x.useEffect(()=>{lt.length!==0&&It(a=>{let c=!1;const v={...a.personalityPrompts};for(const fe of lt)(typeof v[fe.id]!="string"||v[fe.id].trim().length===0)&&(v[fe.id]=fe.defaultPrompt,c=!0);let R=a.personalityId;return lt.some(fe=>fe.id===a.personalityId)||(R=lt[0].id,c=!0),c?{...a,personalityId:R,personalityPrompts:v}:a})},[lt]),x.useEffect(()=>{const a=localStorage.getItem(Rc);if(a)try{const c=JSON.parse(a);if(c.filters){const v=c.filters;Fe(R=>({...R,...v,limit:typeof v.limit=="number"?Math.max(1,Math.min(500,v.limit)):R.limit}))}typeof c.analysisDate=="string"&&Ae(Zi(c.analysisDate)),typeof c.autogenPersonalityPromptHeight=="number"&&Kr(Lc(c.autogenPersonalityPromptHeight)),c.autoGenSettings&&It(v=>{const R={...v.personalityPrompts},fe=c.autoGenSettings?.personalityPrompts??{};for(const[Yt,Ye]of Object.entries(fe))typeof Ye=="string"&&Yt.trim().length>0&&(R[Yt.trim()]=Ye);const Je=typeof c.autoGenSettings?.personalityId=="string"&&c.autoGenSettings.personalityId.trim().length>0?c.autoGenSettings.personalityId.trim():v.personalityId;return{...v,mode:c.autoGenSettings?.mode==="codex_creative"||c.autoGenSettings?.mode==="qwen_seed"?c.autoGenSettings.mode:v.mode,count:typeof c.autoGenSettings?.count=="number"?Math.max(1,Math.min(200,c.autoGenSettings.count)):v.count,personalityId:Je,personalityPrompts:R,persistToEvalCases:typeof c.autoGenSettings?.persistToEvalCases=="boolean"?c.autoGenSettings.persistToEvalCases:v.persistToEvalCases,generatedBy:typeof c.autoGenSettings?.generatedBy=="string"?c.autoGenSettings.generatedBy:v.generatedBy}}),(c.annotationDecisionFilter==="all"||typeof c.annotationDecisionFilter=="string"&&c.annotationDecisionFilter.length>0)&&Se(c.annotationDecisionFilter),typeof c.hideResolvedAnnotations=="boolean"&&ve(c.hideResolvedAnnotations)}catch{}},[]);const Fs=x.useCallback(()=>{const a={filters:H,analysisDate:Te,autogenPersonalityPromptHeight:rr,autoGenSettings:{mode:re.mode,count:re.count,personalityId:re.personalityId,personalityPrompts:re.personalityPrompts,persistToEvalCases:re.persistToEvalCases,generatedBy:re.generatedBy},annotationDecisionFilter:ae,hideResolvedAnnotations:ge};localStorage.setItem(Rc,JSON.stringify(a))},[Te,ae,re,rr,H,ge]);return x.useEffect(()=>{const a=()=>{Fs(),F("Сохранены настройки панели автопрогонов.")};return window.addEventListener(Tc,a),()=>{window.removeEventListener(Tc,a)}},[F,Fs]),o.jsxs(In,{className:"autoruns-frame",title:"",hideHeader:!0,children:[o.jsxs("div",{className:"autoruns-columns",children:[Me?o.jsxs("section",{className:"autoruns-col autoruns-settings-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Настройки"})}),o.jsxs("div",{className:"autoruns-settings-stack",children:[o.jsx(oa,{embedded:!0,value:i,modelOptions:p,modelsBusy:f,onChange:T,onReloadModels:$,onSaveLocalConfig:Y,onTestConnection:b,lastStatus:N,busy:j}),o.jsx(la,{embedded:!0,value:Q,onChange:G,presets:z,selectedPresetId:ne,onSelectPreset:Ne,onLoadPreset:le,onSavePreset:ce,onResetDefaults:me,onDiffPrevious:Qe,presetName:De,onPresetNameChange:We,diffSummary:je})]})]}):null,Ze?o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Автопрогоны"})}),o.jsx("h4",{children:"Настройки выборки"}),o.jsxs("div",{className:"autoruns-form-grid",children:[o.jsxs("label",{children:["Дата с",o.jsx("input",{type:"datetime-local",value:H.fromLocal,onChange:a=>Fe(c=>({...c,fromLocal:a.target.value}))})]}),o.jsxs("label",{children:["Дата по",o.jsx("input",{type:"datetime-local",value:H.toLocal,onChange:a=>Fe(c=>({...c,toLocal:a.target.value}))})]}),o.jsxs("label",{children:["Целевой контур",o.jsxs("select",{value:H.target,onChange:a=>Fe(c=>({...c,target:a.target.value})),children:[o.jsx("option",{value:"all",children:"все"}),(I?.available.targets??[]).map(a=>o.jsx("option",{value:a,children:a},a))]})]}),o.jsxs("label",{children:["Режим",o.jsxs("select",{value:H.mode,onChange:a=>Fe(c=>({...c,mode:a.target.value})),children:[o.jsx("option",{value:"all",children:"все"}),(I?.available.modes??[]).map(a=>o.jsx("option",{value:a,children:a},a))]})]}),o.jsxs("label",{children:["Использовать mock",o.jsxs("select",{value:H.useMock,onChange:a=>Fe(c=>({...c,useMock:a.target.value})),children:[o.jsx("option",{value:"any",children:"любой"}),o.jsx("option",{value:"true",children:"да"}),o.jsx("option",{value:"false",children:"нет"})]})]}),o.jsxs("label",{children:["Лимит",o.jsx("input",{type:"number",min:1,max:500,value:zs,onChange:a=>{const c=a.target.value;(c===""||/^\d+$/.test(c))&&Mt(c)},onBlur:a=>k(a.target.value),onKeyDown:a=>{a.key==="Enter"&&k(a.target.value)}})]}),o.jsxs("label",{className:"full-width",children:["Версия промпта содержит",o.jsx("input",{value:H.promptContains,onChange:a=>Fe(c=>({...c,promptContains:a.target.value})),placeholder:"normalizer_v2_0_2 / address_query_runtime_v1",list:"autoruns-prompt-versions"})]})]}),o.jsx("datalist",{id:"autoruns-prompt-versions",children:(I?.available.prompt_versions??[]).map(a=>o.jsx("option",{value:a},a))}),o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",disabled:Ot,onClick:()=>{Gr({keepSelection:!1})},children:Ot?"Обновляю...":"Применить"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>{Fe({...Yi,fromLocal:Oc()}),Ge("")},children:"Сбросить фильтры"})]}),o.jsx("h4",{children:"Контур генерации"}),o.jsxs("div",{className:"autoruns-meta-list",children:[o.jsxs("div",{children:[o.jsx("span",{children:"Провайдер:"}),o.jsx("strong",{children:i.llmProvider})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Модель:"}),o.jsx("strong",{children:i.model||"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Промпт ассистента:"}),o.jsx("strong",{children:W})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Промпт декомпозиции:"}),o.jsx("strong",{children:de})]})]}),o.jsx("h4",{children:"Автогенерация вопросов"}),o.jsxs("div",{className:"autoruns-form-grid",children:[o.jsxs("label",{children:["Режим генерации",o.jsxs("select",{value:re.mode,onChange:a=>It(c=>({...c,mode:a.target.value})),children:[o.jsx("option",{value:"codex_creative",children:"codex_creative"}),o.jsx("option",{value:"qwen_seed",children:"qwen_seed"})]})]}),o.jsxs("label",{children:["Кол-во",o.jsx("input",{type:"number",min:1,max:200,value:qr,onChange:a=>{const c=a.target.value;(c===""||/^\d+$/.test(c))&&St(c)},onBlur:a=>te(a.target.value),onKeyDown:a=>{a.key==="Enter"&&te(a.target.value)}})]}),o.jsxs("label",{children:["Личность автогенерации",o.jsx("select",{value:re.personalityId,onChange:a=>It(c=>({...c,personalityId:a.target.value})),children:lt.map(a=>o.jsx("option",{value:a.id,children:a.label},a.id))})]}),o.jsxs("label",{children:["Кто генерирует",o.jsx("input",{value:re.generatedBy,onChange:a=>It(c=>({...c,generatedBy:a.target.value})),placeholder:"manual_reviewer"})]}),o.jsxs("label",{className:"full-width",children:["Промпт личности",o.jsx("textarea",{className:"autoruns-personality-prompt",value:re.personalityPrompts[re.personalityId]??"",onChange:a=>It(c=>({...c,personalityPrompts:{...c.personalityPrompts,[c.personalityId]:a.target.value}})),placeholder:"Текст промпта для выбранной личности автогенерации",style:{height:`${rr}px`},onMouseUp:gt,onTouchEnd:gt})]}),o.jsxs("label",{className:"checkbox-row",children:[o.jsx("input",{type:"checkbox",checked:re.persistToEvalCases,onChange:a=>It(c=>({...c,persistToEvalCases:a.target.checked}))}),"Сохранять кейс-сет в `eval_cases`"]})]}),o.jsxs("div",{className:"autoruns-form-grid",children:[o.jsxs("label",{children:["Дата анализа (срез)",o.jsx("input",{type:"date",value:Te,onChange:a=>Ae(Zi(a.target.value))})]}),o.jsx("div",{className:"button-row",children:o.jsx("button",{type:"button",className:"tab",disabled:!Te,onClick:()=>Ae(""),children:"Сбросить дату среза"})})]}),o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",disabled:Dn,onClick:()=>{vl()},children:Dn?"Генерирую...":"Сгенерировать пачку"}),o.jsx("button",{type:"button",className:"tab",disabled:Kt,onClick:()=>{Jt()},children:Kt?"Обновляю...":"Обновить историю"}),o.jsx("button",{type:"button",className:"autoruns-run-launch-btn",disabled:Sn||xt.length===0,onClick:()=>{ho()},children:Sn?"Запускаю...":"Запустить прогоны"})]}),o.jsx("div",{className:"autoruns-form-grid",children:o.jsxs("label",{className:"full-width",children:["Кейс-сет для запуска",o.jsxs("select",{value:nn,onChange:a=>xn(a.target.value),disabled:tt.length===0,children:[tt.length===0?o.jsx("option",{value:"",children:"нет генераций"}):null,tt.map(a=>o.jsxs("option",{value:a.generation_id,children:[vr(a.created_at)," | ",a.mode," | ",a.count," | ",a.saved_case_set_file??"без файла"]},a.generation_id))]})]})}),o.jsxs("div",{className:"autoruns-generated-questions",children:[o.jsxs("div",{className:"autoruns-generated-questions-head",children:[o.jsxs("strong",{children:["Вопросы к запуску: ",xt.length]}),o.jsx("button",{type:"button",className:"tab",onClick:()=>_n([...$t?.questions??[]]),disabled:!$t,children:"Восстановить"})]}),xt.length===0?o.jsx("p",{className:"muted",children:"Список вопросов пуст. Сгенерируйте пачку или восстановите из выбранной генерации."}):o.jsx("div",{className:"autoruns-generated-questions-list",children:xt.map((a,c)=>o.jsxs("div",{className:"autoruns-generated-question-item",children:[o.jsxs("span",{children:[c+1,". ",a]}),o.jsx("button",{type:"button",className:"autoruns-remove-question-btn",onClick:()=>_n(v=>v.filter((R,fe)=>fe!==c)),title:"Удалить вопрос из запуска","aria-label":"Удалить вопрос из запуска",children:"+"})]},`${c}-${a.slice(0,24)}`))})]}),o.jsx("p",{className:"muted",children:"Запуск выполняет `assistant_stage1` eval по выбранному кейс-сету."}),o.jsxs("div",{className:"autoruns-autogen-list",children:[Kt?o.jsx("p",{className:"muted",children:"Загружаю историю автогенераций..."}):null,!Kt&&tt.length===0?o.jsx("p",{className:"muted",children:"История автогенераций пока пустая."}):null,tt.slice(0,30).map(a=>o.jsxs("article",{className:nn===a.generation_id?"autoruns-autogen-item selected":"autoruns-autogen-item",onClick:()=>xn(a.generation_id),children:[o.jsxs("header",{children:[o.jsx("strong",{children:vr(a.created_at)}),o.jsx("span",{children:a.mode})]}),o.jsxs("div",{className:"autoruns-run-meta",children:["id=",a.generation_id," | count=",a.count]}),o.jsxs("div",{className:"autoruns-run-meta",children:["домен=",a.domain??"общий",a.generated_by?` | автор=${a.generated_by}`:""]}),a.saved_case_set_file?o.jsxs("div",{className:"autoruns-run-meta",children:["кейс-сет=",a.saved_case_set_file]}):null,(a.questions??[]).length>0?o.jsx("p",{children:a.questions[0]}):null]},a.generation_id))]}),o.jsxs("details",{className:"autoruns-prompt-details",children:[o.jsx("summary",{children:"Копия активного промпта (только чтение)"}),o.jsxs("label",{children:["Системный",o.jsx("textarea",{readOnly:!0,value:Q.systemPrompt})]}),o.jsxs("label",{children:["Разработчика",o.jsx("textarea",{readOnly:!0,value:Q.developerPrompt})]}),o.jsxs("label",{children:["Доменный",o.jsx("textarea",{readOnly:!0,value:Q.domainPrompt})]}),o.jsxs("label",{children:["Заметки по схеме",o.jsx("textarea",{readOnly:!0,value:Q.schemaNotes})]}),o.jsxs("label",{children:["Примеры few-shot",o.jsx("textarea",{readOnly:!0,value:Q.fewShotExamples})]})]}),wn?o.jsx("p",{className:"error-text",children:wn}):null]}):null,o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Выдача прогонов"})}),o.jsxs("div",{className:"autoruns-stats-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"Всего"}),o.jsx("strong",{children:(I?.stats.runs_total??0)+(Oe?1:0)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Средний score"}),o.jsx("strong",{children:ml(I?.stats.avg_score_index??null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Тренд"}),o.jsx("strong",{children:I?Dc(I.stats.trend):"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Блокеры"}),o.jsx("strong",{children:I?.stats.blocking_runs??0})]})]}),o.jsxs("div",{className:"autoruns-run-list",children:[ir.map(a=>o.jsxs("button",{type:"button",className:Pe===a.run_id?"autoruns-run-item selected":"autoruns-run-item",onClick:()=>{Ut(a.run_id)},children:[o.jsxs("div",{className:"autoruns-run-head",children:[o.jsx("strong",{children:vr(a.run_timestamp)}),o.jsx("span",{children:im(a.eval_target)})]}),o.jsxs("div",{className:"autoruns-run-meta autoruns-run-id-row",children:[o.jsx("span",{children:a.run_id}),o.jsx("span",{role:"button",tabIndex:0,className:"autoruns-copy-run-id-btn",onClick:c=>{Cr(c,a.run_id)},onKeyDown:c=>{(c.key==="Enter"||c.key===" ")&&(c.preventDefault(),Cr(c,a.run_id))},title:"Скопировать run id","aria-label":`Скопировать run id ${a.run_id}`,children:o.jsx(cm,{})})]}),o.jsxs("div",{className:"autoruns-run-meta",children:["режим=",a.mode??"нет данных"," | mock=",String(a.use_mock)]}),o.jsxs("div",{className:"autoruns-run-meta",children:["analysis_date=",a.analysis_date??"current_state"]}),a.llm_provider||a.model?o.jsxs("div",{className:"autoruns-run-meta",children:["llm=",a.llm_provider??"нет данных"," | модель=",a.model??"нет данных"]}):null,o.jsxs("div",{className:"autoruns-run-meta",children:["промпт=",a.prompt_version??"нет данных"]}),o.jsxs("div",{className:"autoruns-run-foot",children:[o.jsxs("span",{children:["оценка: ",ml(a.score_index)]}),o.jsxs("span",{children:["закрыто/открыто: ",a.closed_cases,"/",a.open_cases]})]}),o.jsxs("div",{className:"autoruns-run-foot",children:[o.jsxs("span",{children:["блокеры: ",a.blocking_failures]}),o.jsxs("span",{children:["качество: ",a.quality_failures]})]})]},a.run_id)),ir.length===0?o.jsx("p",{className:"muted",children:"За выбранный диапазон прогонов нет."}):null]})]}),o.jsxs("section",{className:"autoruns-col",children:[o.jsxs("div",{className:"autoruns-col-header",children:[o.jsx("h3",{children:"Диалог прогона"}),o.jsxs("div",{className:"autoruns-dialog-toolbar",children:[o.jsxs("label",{children:["Прогон",o.jsx("select",{value:Pe,onChange:a=>{const c=a.target.value;Ut(c)},children:ir.map(a=>o.jsxs("option",{value:a.run_id,children:[vr(a.run_timestamp)," | ",a.run_id]},a.run_id))})]}),o.jsxs("label",{children:["Кейс",o.jsxs("select",{value:ot,onChange:a=>{const c=a.target.value;dt(c),Pe&&c&&Er(Pe,c)},children:[(O?.cases.length??0)>0?o.jsx("option",{value:Nt,children:"ВСЕ кейсы подряд"}):null,(O?.cases??[]).map(a=>o.jsxs("option",{value:a.case_id,children:[a.case_id," | ",a.status]},a.case_id))]})]})]})]}),o.jsxs("div",{className:"autoruns-case-list",children:[(O?.cases.length??0)>0?o.jsxs("button",{type:"button",className:ot===Nt?"autoruns-case-item selected":"autoruns-case-item",onClick:()=>{dt(Nt),Pe&&Er(Pe,Nt)},children:[o.jsx("span",{children:"ВСЕ кейсы подряд"}),o.jsx("span",{children:O?.cases.length})]},Nt):null,(O?.cases??[]).map(a=>o.jsxs("button",{type:"button",className:ot===a.case_id?"autoruns-case-item selected":"autoruns-case-item",onClick:()=>{dt(a.case_id),Pe&&Er(Pe,a.case_id)},children:[o.jsx("span",{children:a.case_id}),o.jsxs("span",{children:[a.status,a.commented_count>0?` | комм=${a.commented_count}`:""]})]},a.case_id))]}),o.jsxs("div",{className:"autoruns-dialog-view",children:[$n||zn?o.jsx("p",{className:"muted",children:"Загружаю диалог..."}):null,!$n&&!zn&&(C?.messages.length??0)===0?o.jsx("p",{className:"muted",children:"Диалог для этого прогона не найден."}):null,(C?.messages??[]).map((a,c)=>{const v=a.role==="assistant"?"assistant":"user";return o.jsxs("article",{className:`autoruns-msg ${v}`,children:[o.jsxs("header",{children:[o.jsx("strong",{children:v==="assistant"?"Система":"Модель/вопрос"}),o.jsxs("div",{className:"autoruns-msg-head-actions",children:[a.case_id?o.jsx("span",{className:"autoruns-msg-case-tag",children:a.case_id}):null,o.jsx("span",{children:a.created_at?vr(a.created_at):"нет данных"}),v==="assistant"&&!Ds(Pe)?o.jsxs(o.Fragment,{children:[o.jsx("button",{type:"button",className:a.commented?"autoruns-comment-icon commented":"autoruns-comment-icon",onClick:()=>yl(a),title:"\\u041a\\u043e\\u043c\\u043c\\u0435\\u043d\\u0442\\u0438\\u0440\\u043e\\u0432\\u0430\\u0442\\u044c \\u043e\\u0442\\u0432\\u0435\\u0442 \\u0441\\u0438\\u0441\\u0442\\u0435\\u043c\\u044b","aria-label":"\\u041a\\u043e\\u043c\\u043c\\u0435\\u043d\\u0442\\u0438\\u0440\\u043e\\u0432\\u0430\\u0442\\u044c \\u043e\\u0442\\u0432\\u0435\\u0442 \\u0441\\u0438\\u0441\\u0442\\u0435\\u043c\\u044b",children:o.jsx(um,{commented:a.commented})}),a.annotation?o.jsx("button",{type:"button",className:a.annotation.resolved?"autoruns-resolve-toggle resolved":"autoruns-resolve-toggle",onClick:()=>{Yr(a.annotation,!a.annotation.resolved)},disabled:Dt===a.annotation.annotation_id,title:a.annotation.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный","aria-label":a.annotation.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный",children:o.jsx(Fc,{resolved:a.annotation.resolved})}):null]}):null]})]}),o.jsx("p",{children:a.text}),v==="assistant"&&a.annotation?o.jsxs("div",{className:"autoruns-msg-annotation",children:[o.jsx("strong",{children:ea(a.annotation.rating)}),o.jsx("span",{children:a.annotation.comment}),o.jsxs("span",{className:"muted",children:[a.annotation.manual_case_decision,a.annotation.annotation_author?` | ${a.annotation.annotation_author}`:""]})]}):null,(a.trace_id||a.reply_type)&&o.jsxs("footer",{children:[a.trace_id?o.jsxs("span",{children:["trace=",a.trace_id]}):null,a.reply_type?o.jsxs("span",{children:["reply_type=",a.reply_type]}):null]})]},a.message_id??`${v}-${c}`)})]})]}),ct?o.jsx("div",{className:"autoruns-col autoruns-assistant-live-col",children:o.jsx(Wc,{sessionId:nt,conversation:zt,inputValue:jr,onInputChange:_t,selectedContextChip:jn,onSelectContextChip:an,onClearContextChip:()=>an(null),useMock:tr,onUseMockChange:Wr,onSend:E,onClear:m,busy:Re,statusText:nr,errorMessage:cs,showCommentAction:!0,onCommentAssistantMessage:xl,isAssistantMessageCommented:ms,canCommentAssistantMessage:Mr})}):null,st?o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Режим декомпозиции"})}),o.jsxs("div",{className:"autoruns-meta-list",children:[o.jsxs("div",{children:[o.jsx("span",{children:"кейс:"}),o.jsx("strong",{children:kn?.case_id??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"домен:"}),o.jsx("strong",{children:kn?.domain??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"класс запроса:"}),o.jsx("strong",{children:kn?.query_class??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"trace:"}),o.jsx("strong",{children:kn?.trace_id??"нет данных"})]})]}),o.jsx("h4",{children:"Шаги декомпозиции"}),(C?.decomposition.length??0)>0?o.jsx("ol",{className:"autoruns-decomposition-list",children:(C?.decomposition??[]).map((a,c)=>o.jsx("li",{children:a},`${c}-${a.slice(0,24)}`))}):o.jsx("p",{className:"muted",children:"В логах кейса нет явной декомпозиции."})]}):null,Et?o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Прогресс / регресс"})}),o.jsxs("div",{className:"autoruns-stats-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"Последний score"}),o.jsx("strong",{children:ml(I?.stats.latest_score_index??null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Предыдущий"}),o.jsx("strong",{children:ml(I?.stats.previous_score_index??null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Тренд"}),o.jsx("strong",{children:I?Dc(I.stats.trend):"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Пробелы качества"}),o.jsx("strong",{children:I?.stats.quality_gap_runs??0})]})]}),o.jsx("h4",{children:"Покрытие доменов (история)"}),zc(I?.stats.domain_coverage??[]),o.jsx("h4",{style:{marginTop:14},children:"Покрытие доменов (выбранный прогон)"}),zc(O?.coverage.domain_coverage??[]),o.jsx("h4",{style:{marginTop:14},children:"Очереди фиксов пост-анализа"}),Lt?o.jsx("p",{className:"muted",children:"Собираю пост-анализ..."}):null,Lt?null:o.jsx("div",{className:"autoruns-stats-grid",children:Object.entries(On?.post_analysis.stats.by_queue??{}).map(([a,c])=>o.jsxs("div",{children:[o.jsx("span",{children:a}),o.jsx("strong",{children:c})]},a))}),o.jsxs("div",{className:"autoruns-autogen-list",children:[(On?.post_analysis.recommended_regression_candidates??[]).slice(0,12).map(a=>o.jsxs("article",{className:"autoruns-autogen-item",children:[o.jsxs("header",{children:[o.jsx("strong",{children:a.manual_case_decision}),o.jsxs("span",{children:[a.rating,"/5"]})]}),o.jsxs("div",{className:"autoruns-run-meta",children:[a.domain??"неизвестно"," / ",a.query_class??"неизвестно"]}),o.jsx("p",{children:a.comment})]},a.annotation_id)),!Lt&&(On?.post_analysis.recommended_regression_candidates.length??0)===0?o.jsx("p",{className:"muted",children:"Рекомендованных кандидатов пока нет."}):null]})]}):null,ie?o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Комментарии"})}),o.jsx("h4",{children:"Размеченные ответы"}),o.jsxs("div",{className:"autoruns-comment-filter-row",children:[o.jsxs("label",{children:["Фильтр решений",o.jsxs("select",{value:ae,onChange:a=>Se(a.target.value),children:[o.jsx("option",{value:"all",children:"все"}),(vn.length>0?vn:Ee?.enum??[]).map(a=>o.jsx("option",{value:a,children:String(Ee?.labels?.[a]??a)},a))]})]}),o.jsx("button",{type:"button",className:"tab autoruns-resolved-filter-toggle",onClick:()=>ve(a=>!a),children:ge?"Показать выполненные":"Скрыть выполненные"})]}),o.jsxs("div",{className:"autoruns-stats-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"Комментариев"}),o.jsx("strong",{children:it.length})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Средний рейтинг"}),o.jsx("strong",{children:lr===null?"нет данных":`${lr.toFixed(2)} / 5`})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Последний"}),o.jsx("strong",{children:it.length>0?vr(it[0].updated_at):"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Статус"}),o.jsx("strong",{children:ze?"обновляю":"готово"})]})]}),o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",disabled:ze,onClick:()=>{Ft()},children:ze?"Обновляю...":"Обновить список"}),o.jsx("button",{type:"button",className:"tab",disabled:Lt,onClick:()=>{ft()},children:Lt?"Идет пост-анализ...":"Обновить пост-анализ"})]}),o.jsxs("div",{className:"autoruns-comments-list",children:[ze?o.jsx("p",{className:"muted",children:"Загружаю комментарии..."}):null,!ze&&it.length===0?o.jsx("p",{className:"muted",children:oe.length===0&&bn.length===0?"Пока нет откомментированных ответов.":"Нет открытых кейсов по текущему фильтру."}):null,it.map(a=>{if(a.source==="assistant_live"){const v=a.assistant;return o.jsxs("article",{className:"autoruns-comment-item",children:[o.jsxs("div",{className:"autoruns-comment-head",children:[o.jsx("strong",{children:ea(v.rating)}),o.jsx("div",{className:"autoruns-comment-head-actions",children:o.jsx("span",{children:vr(v.updated_at)})})]}),o.jsxs("div",{className:"autoruns-run-meta",children:["live-session: ",v.session_id]}),o.jsxs("div",{className:"autoruns-run-meta",children:["msg=",v.message_index]}),o.jsxs("div",{className:"autoruns-run-meta",children:["source=assistant_live",v.annotation_author?` | author=${v.annotation_author}`:""]}),v.context.question_text?o.jsxs("p",{children:["Q: ",v.context.question_text]}):null,v.context.answer_text?o.jsxs("p",{children:["A: ",v.context.answer_text]}):null,o.jsx("p",{children:v.comment})]},a.key)}const c=a.autorun;return o.jsxs("article",{className:Ln===c.annotation_id?"autoruns-comment-item selected":"autoruns-comment-item",onClick:()=>{hs(c)},role:"button",tabIndex:0,onKeyDown:v=>{(v.key==="Enter"||v.key===" ")&&(v.preventDefault(),hs(c))},children:[o.jsxs("div",{className:"autoruns-comment-head",children:[o.jsx("strong",{children:ea(c.rating)}),o.jsxs("div",{className:"autoruns-comment-head-actions",children:[o.jsx("span",{children:vr(c.updated_at)}),o.jsx("button",{type:"button",className:c.resolved?"autoruns-resolve-toggle resolved":"autoruns-resolve-toggle",onClick:v=>{v.preventDefault(),v.stopPropagation(),Yr(c,!c.resolved)},disabled:Dt===c.annotation_id,title:c.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный","aria-label":c.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный",children:o.jsx(Fc,{resolved:c.resolved})})]})]}),o.jsx("div",{className:"autoruns-run-meta",children:c.run_id}),o.jsxs("div",{className:"autoruns-run-meta",children:["case=",c.case_id," | msg=",c.message_index]}),o.jsxs("div",{className:"autoruns-run-meta",children:["decision=",c.manual_case_decision,c.annotation_author?` | author=${c.annotation_author}`:""]}),c.resolved_at?o.jsxs("div",{className:"autoruns-run-meta",children:["выполнено",": ",vr(c.resolved_at),c.resolved_by?` | by=${c.resolved_by}`:""]}):null,c.context.question_text?o.jsxs("p",{children:["Q: ",c.context.question_text]}):null,c.context.answer_text?o.jsxs("p",{children:["A: ",c.context.answer_text]}):null,o.jsx("p",{children:c.comment})]},a.key)})]}),ke?o.jsxs(o.Fragment,{children:[o.jsx("h4",{children:"Тех-контекст брака"}),o.jsxs("div",{className:"autoruns-meta-list",children:[o.jsxs("div",{children:[o.jsx("span",{children:"trace:"}),o.jsx("strong",{children:ke.technical_context.trace_id??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"reply_type:"}),o.jsx("strong",{children:ke.technical_context.reply_type??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"domain:"}),o.jsx("strong",{children:ke.technical_context.domain??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"query_class:"}),o.jsx("strong",{children:ke.technical_context.query_class??"нет данных"})]})]}),o.jsx("h4",{children:"JSON разбор"}),o.jsx(tn,{value:{annotation_id:ke.annotation_id,run_id:ke.run_id,case_id:ke.case_id,message_index:ke.message_index,rating:ke.rating,comment:ke.comment,manual_case_decision:ke.manual_case_decision,annotation_author:ke.annotation_author,resolved:ke.resolved,resolved_at:ke.resolved_at,resolved_by:ke.resolved_by,context:ke.context,technical_context:ke.technical_context,case_summary:ke.case_summary?{case_id:ke.case_summary.case_id,domain:ke.case_summary.domain,query_class:ke.case_summary.query_class,checks:ke.case_summary.checks,metric_subscores:ke.case_summary.metric_subscores}:null}})]}):null]}):null]}),ye.open?o.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:a=>{a.target===a.currentTarget&&Nn()},children:o.jsxs("div",{className:"autoruns-comment-modal",children:[o.jsx("h3",{children:"Комментарий к ответу ассистента"}),o.jsx("p",{className:"muted",children:"Комментарий будет добавлен в общий список комментариев справа с меткой `assistant_live`."}),or?o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Вопрос пользователя"}),o.jsx("p",{className:"autoruns-comment-quote",children:or.text})]}):null,kr?o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Ответ ассистента"}),o.jsx("p",{className:"autoruns-comment-quote",children:kr.text})]}):null,o.jsx("div",{className:"autoruns-rating-row",role:"group","aria-label":"Рейтинг ответа ассистента",children:[1,2,3,4,5].map(a=>o.jsx("button",{type:"button",className:ye.rating>=a?"autoruns-rating-dot active":"autoruns-rating-dot",onClick:()=>be(c=>({...c,rating:a})),disabled:ye.saving,"aria-label":`Оценка ${a}`,children:ye.rating>=a?"●":"○"},a))}),o.jsx("div",{className:"autoruns-form-grid",children:o.jsxs("label",{children:["Автор комментария",o.jsx("input",{value:ye.annotationAuthor,onChange:a=>be(c=>({...c,annotationAuthor:a.target.value})),placeholder:"manual_reviewer",disabled:ye.saving})]})}),o.jsxs("label",{children:["Комментарий",o.jsx("textarea",{value:ye.comment,onChange:a=>be(c=>({...c,comment:a.target.value})),placeholder:"Что именно не так в ответе и что нужно исправить.",rows:4,disabled:ye.saving})]}),ye.error?o.jsx("p",{className:"error-text",children:ye.error}):null,o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>{_l()},disabled:ye.saving,children:ye.saving?"Сохраняю...":"Готово"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>Nn(),disabled:ye.saving,children:"Отмена"})]})]})}):null,ue.open?o.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:a=>{a.target===a.currentTarget&&Qn()},children:o.jsxs("div",{className:"autoruns-comment-modal",children:[o.jsx("h3",{children:"Комментарий к ответу системы"}),o.jsx("p",{className:"muted",children:"Оцените ответ по 5-балльной шкале и добавьте комментарий по браку."}),ds?o.jsxs(o.Fragment,{children:[o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Вопрос пользователя"}),o.jsx("p",{className:"autoruns-comment-quote",children:$s?.text??"Вопрос в диалоге не найден."})]}),o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Ответ системы"}),o.jsx("p",{className:"autoruns-comment-quote",children:ds.text})]})]}):null,o.jsx("div",{className:"autoruns-rating-row",role:"group","aria-label":"Рейтинг ответа",children:[1,2,3,4,5].map(a=>o.jsx("button",{type:"button",className:ue.rating>=a?"autoruns-rating-dot active":"autoruns-rating-dot",onClick:()=>Ue(c=>({...c,rating:a})),disabled:ue.saving,"aria-label":`Оценка ${a}`,children:ue.rating>=a?"●":"○"},a))}),o.jsxs("div",{className:"autoruns-form-grid",children:[o.jsxs("label",{children:["Решение по кейсу",o.jsx("select",{value:ue.manualCaseDecision,onChange:a=>Ue(c=>({...c,manualCaseDecision:a.target.value})),disabled:ue.saving,children:(vn.length>0?vn:Ee?.enum??[dl]).map(a=>o.jsx("option",{value:a,children:String(Ee?.labels?.[a]??a)},a))})]}),o.jsxs("label",{children:["Автор комментария",o.jsx("input",{value:ue.annotationAuthor,onChange:a=>Ue(c=>({...c,annotationAuthor:a.target.value})),placeholder:"manual_reviewer",disabled:ue.saving})]})]}),o.jsxs("label",{children:["Комментарий",o.jsx("textarea",{value:ue.comment,onChange:a=>Ue(c=>({...c,comment:a.target.value})),placeholder:"Почему ответ бракованный, что именно пошло не так, какие технические детали проверить.",rows:4,disabled:ue.saving})]}),ue.error?o.jsx("p",{className:"error-text",children:ue.error}):null,o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>{Jr()},disabled:ue.saving,children:ue.saving?"Сохраняю...":"Готово"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>Qn(),disabled:ue.saving,children:"Отмена"})]})]})}):null]})}function fm({items:i,onRefresh:p,onOpenTrace:f}){return o.jsx(In,{title:"История нормализаций",subtitle:"Короткий вопрос, confidence, route hint и статус валидации.",actions:o.jsx("button",{type:"button",onClick:()=>p(),children:"Обновить"}),children:o.jsxs("div",{className:"history-list",children:[i.length===0?o.jsx("p",{className:"muted",children:"История пока пустая."}):null,i.map(N=>o.jsxs("button",{type:"button",className:"history-item",onClick:()=>f(N.trace_id),children:[o.jsxs("div",{className:"history-row",children:[o.jsx("strong",{children:N.route_hint??"route: n/a"}),o.jsx("span",{children:N.validation_passed?"schema: ok":"schema: fail"})]}),o.jsx("p",{children:N.question_short}),o.jsxs("div",{className:"history-row",children:[o.jsx("span",{children:N.model}),o.jsx("span",{children:new Date(N.timestamp).toLocaleString("ru-RU")})]})]},N.trace_id))]})})}function yr(i){return i==null||i===""?"—":String(i)}function mm({result:i}){return o.jsx(In,{title:"Runtime метрики",subtitle:"trace_id, токены, latency и статус валидации.",children:o.jsxs("div",{className:"metrics-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"trace_id"}),o.jsx("strong",{children:yr(i?.trace_id)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"request_started_at"}),o.jsx("strong",{children:yr(i?new Date(Date.now()-i.latency_ms).toISOString():null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"request_finished_at"}),o.jsx("strong",{children:yr(i?new Date().toISOString():null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"latency_ms"}),o.jsx("strong",{children:yr(i?.latency_ms)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"input_tokens"}),o.jsx("strong",{children:yr(i?.usage?.input_tokens)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"output_tokens"}),o.jsx("strong",{children:yr(i?.usage?.output_tokens)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"total_tokens"}),o.jsx("strong",{children:yr(i?.usage?.total_tokens)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"validation_status"}),o.jsx("strong",{children:i?.validation?.passed?"passed":"failed"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"prompt_version"}),o.jsx("strong",{children:yr(i?.prompt_version)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"schema_version"}),o.jsx("strong",{children:yr(i?.schema_version)})]})]})})}const pm={normalized:"Normalized JSON",fragments:"Fragment View",scope:"Scope View",flags:"Flags View",route:"Route Simulation",raw:"Raw model output",validation:"Validation",logs:"Logs"};function hm(i){return i&&typeof i=="object"?i:null}function gm({tab:i,onTabChange:p,result:f,appLogs:N}){const j=["normalized","fragments","scope","flags","route","raw","validation","logs"],T=hm(f?.normalized),$=String(T?.schema_version??""),Y=$==="normalized_query_v2"||$==="normalized_query_v2_0_1"||$==="normalized_query_v2_0_2",b=Y?{fragments:T?.fragments??[],discarded_fragments:T?.discarded_fragments??[]}:{note:"Fragment View доступен для normalized_query_v2."},Q=Y?{message_in_scope:T?.message_in_scope??null,scope_confidence:T?.scope_confidence??null,contains_multiple_tasks:T?.contains_multiple_tasks??null,global_notes:T?.global_notes??null}:{note:"Scope View доступен для normalized_query_v2."},G=Y?Array.isArray(T?.fragments)?(T?.fragments).map(z=>({fragment_id:z.fragment_id??null,domain_relevance:z.domain_relevance??null,candidate_labels:z.candidate_labels??[],execution_readiness:z.execution_readiness??null,clarification_reason:z.clarification_reason??null,soft_assumption_used:z.soft_assumption_used??[],route_status:z.route_status??null,no_route_reason:z.no_route_reason??null,flags:z.flags??{}})):[]:{note:"Flags View доступен для normalized_query_v2."};return o.jsxs(In,{title:"Выходные данные",subtitle:"Structured output и диагностические вкладки.",children:[o.jsx("div",{className:"tab-row",children:j.map(z=>o.jsx("button",{type:"button",className:i===z?"tab active":"tab",onClick:()=>p(z),children:pm[z]},z))}),i==="normalized"?o.jsx(tn,{value:f?.normalized??{note:"Нет данных."}}):null,i==="fragments"?o.jsx(tn,{value:b}):null,i==="scope"?o.jsx(tn,{value:Q}):null,i==="flags"?o.jsx(tn,{value:G}):null,i==="route"?o.jsx(tn,{value:f?.route_hint_summary??{note:"Нет данных."}}):null,i==="raw"?o.jsx(tn,{value:f?.raw_model_output??{note:"Нет данных."}}):null,i==="validation"?o.jsx(tn,{value:f?.validation??{note:"Нет данных."}}):null,i==="logs"?o.jsx(tn,{value:N}):null]})}function vm({value:i,onChange:p,onApplyBatchFormat:f,onNormalize:N,busy:j,useMock:T,onUseMockChange:$,errorMessage:Y}){return o.jsxs(In,{title:"Запрос пользователя",subtitle:"NDC semantic front-end: нормализуем, но не отвечаем за бухгалтерскую суть.",children:[o.jsxs("div",{className:"grid-two",children:[o.jsxs("label",{className:"full-width",children:["Raw user question",o.jsx("textarea",{value:i.userQuestion,onChange:b=>p({...i,userQuestion:b.target.value}),rows:6,placeholder:"Например: По каким покупателям у нас на конец июня висят отгрузки без оплаты..."})]}),o.jsxs("label",{className:"full-width",children:["Batch queries (`;` separator)",o.jsx("textarea",{value:i.batchQuestionsRaw,onChange:b=>p({...i,batchQuestionsRaw:b.target.value}),onBlur:()=>f(),rows:8,placeholder:"Вопрос 1; Вопрос 2; Вопрос 3"})]}),o.jsxs("label",{children:["Optional period context",o.jsx("input",{value:i.periodHint,onChange:b=>p({...i,periodHint:b.target.value})})]}),o.jsxs("label",{children:["Optional business context",o.jsx("input",{value:i.businessContext,onChange:b=>p({...i,businessContext:b.target.value})})]}),o.jsxs("label",{children:["Optional expected route (eval)",o.jsx("input",{value:i.expectedRoute,onChange:b=>p({...i,expectedRoute:b.target.value})})]})]}),o.jsxs("div",{className:"button-row",children:[o.jsxs("label",{className:"checkbox-row",children:[o.jsx("input",{type:"checkbox",checked:T,onChange:b=>$(b.target.checked)}),"Mock-режим (без вызова OpenAI)"]}),o.jsx("button",{type:"button",onClick:()=>f(),disabled:j||!i.batchQuestionsRaw.trim(),children:"Применить `;` в переносы"}),o.jsx("button",{type:"button",onClick:()=>N(!1),disabled:j||!i.userQuestion.trim(),children:j?"Нормализуем...":"Normalize"}),o.jsx("button",{type:"button",onClick:()=>N(!0),disabled:j||!i.userQuestion.trim(),children:j?"Сохраняем...":"Normalize + Save as test case"})]}),Y?o.jsx("p",{className:"error-text",children:Y}):null]})}function ym({runs:i,selectedRunId:p,onSelectRun:f,onStartRun:N,onFinishRun:j,onRefreshRuns:T,onRunEval:$,onCopyEvalReport:Y,evalBusy:b,traceItems:Q,evalReport:G}){return o.jsxs(In,{title:"NDC Run Monitor",subtitle:"Важно: кнопка Запустить run создает только run-сущность. Кнопка eval запускает batch-проверку normalizer v2.0.2.",children:[o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>N(),children:"Запустить run"}),o.jsx("button",{type:"button",onClick:()=>j(),disabled:!p,children:"Завершить выбранный run"}),o.jsx("button",{type:"button",onClick:()=>T(),children:"Обновить runs"}),o.jsx("button",{type:"button",onClick:()=>$(),disabled:b,children:b?"Идет eval v2.0.2...":"Запустить eval v2.0.2"})]}),o.jsxs("div",{className:"runtime-stack",children:[o.jsxs("div",{className:"runtime-runs",children:[i.map(z=>o.jsxs("button",{type:"button",className:p===z.runId?"history-item selected":"history-item",onClick:()=>f(z.runId),children:[o.jsxs("div",{className:"history-row",children:[o.jsx("strong",{children:z.status}),o.jsx("span",{children:z.runId})]}),o.jsxs("div",{className:"history-row",children:[o.jsx("span",{children:z.sessionId}),o.jsx("span",{children:new Date(z.updatedAt).toLocaleString("ru-RU")})]})]},z.runId)),i.length===0?o.jsx("p",{className:"muted",children:"Нет активных запусков."}):null]}),o.jsxs("div",{className:"runtime-details",children:[o.jsx("h3",{children:"Trace выбранного run"}),o.jsx(tn,{value:Q}),o.jsxs("div",{className:"eval-report-wrap",children:[o.jsx("h3",{style:{marginTop:12},children:"Отчет eval"}),o.jsx(tn,{value:G??{note:"Eval пока не запускался"}}),o.jsx("button",{type:"button",className:"copy-cube-button",title:"Скопировать отчет eval",onClick:()=>Y(),children:"⧉"})]})]})]})]})}const xm={llmProvider:"openai",apiKey:"",model:"gpt-4o-mini",baseUrl:"https://api.openai.com/v1",temperature:0,maxOutputTokens:700},Uc={systemPrompt:"Ты semantic-normalizer для бухгалтерского ассистента NDC. Возвращай только JSON по схеме normalized_query_v2_0_2.",developerPrompt:"Сначала делай decomposition сообщения на task fragments, затем определяй domain scope и route-critical flags. Для каждого fragment заполняй execution_readiness + route_status + no_route_reason. Если fragment routable, не оставляй его в no_route.",domainPrompt:"Контур: данные текущего предприятия в 1С/NDC. In-scope: документы, проводки, взаиморасчеты, остатки, периодное закрытие, аномалии и контрольные проверки. Out-of-scope: общая теория, законы и оффтоп.",schemaNotes:"schema_version: normalized_query_v2_0_2. Строгий JSON без дополнительных полей.",fewShotExamples:"Q: Проверь по поставщикам хвосты и разложи цепочку документов/оплат. => fragment in_scope, flags: multi_entity + chain_explanation. Q: Как вообще по ФСБУ? => out_of_scope/generic_accounting."},_m={userQuestion:"",batchQuestionsRaw:"",periodHint:"",businessContext:"",expectedRoute:""},ta={colors:{backgroundRgb:"18, 18, 18",mainSurfaceRgb:"25, 25, 25",horizontalSurfaceRgb:"30, 30, 30",focusSurfaceRgb:"35, 35, 35",assistantChipRgb:"18, 18, 18",assistantChipHoverRgb:"44, 44, 44",assistantChipSelectedRgb:"167, 59, 255",assistantChipSelectedTextRgb:"240, 240, 240",activeRgb:"167, 59, 255",activeTextRgb:"240, 240, 240",textMainRgb:"240, 240, 240",textMutedRgb:"166, 166, 166",dangerRgb:"126, 126, 126",scrollbarTrackRgb:"20, 20, 20",scrollbarThumbRgb:"30, 30, 30",scrollbarThumbHoverRgb:"30, 50, 30"},layout:{modeColumnWidthPx:406,modeToggleWidthPx:188}},bc="ndc_normalizer_session_config_v1",Bc="ndc_autoruns_layout_config_v1",Sm="ndc-autoruns-save",na=["Анализ запроса","Получение данных","Подготовка ответа"],wm="autoruns",ra="normalizer_v2_0_2",Hc="address_query_runtime_v1",jm=["normalized","fragments","scope","flags","route","raw","validation","logs"],sa="manual_reviewer";function km(i){return`[${new Date().toLocaleTimeString("ru-RU")}] ${i}`}function Cm(i,p){if(!p)return"Previous preset is not selected.";const N=["systemPrompt","developerPrompt","domainPrompt","schemaNotes","fewShotExamples"].filter(j=>i[j]!==p[j]).map(j=>`${j}: ${Math.abs(i[j].length-p[j].length)} chars delta`);return N.length===0?"No changes against previous preset.":`Changed fields: ${N.length}. ${N.join(" | ")}`}function Nm(i,p){const f=i.trim();if(!f)return"";if(!p)return f;const N=f.toLowerCase(),j=p.anchor_text.trim(),T=j.toLowerCase();return T&&N.includes(T)?f:`По выбранному объекту "${j}": ${f}`}function Em(){const[i,p]=x.useState(xm),[f,N]=x.useState(Uc),[j,T]=x.useState(_m),[$,Y]=x.useState(null),[b,Q]=x.useState([]),[G,z]=x.useState([]),[ne,Ne]=x.useState("normalized"),[le,ce]=x.useState(!1),[me,Qe]=x.useState(!1),[De,We]=x.useState([]),[je,W]=x.useState(""),[de,Me]=x.useState([]),[Ze,ct]=x.useState(""),[st,Et]=x.useState("NDC custom preset"),[ie,Le]=x.useState(null),[H,Fe]=x.useState(""),[Te,Ae]=x.useState(!1),[I,X]=x.useState([]),[O,y]=x.useState(""),[C,J]=x.useState([]),[oe,pe]=x.useState(!1),[ae,Se]=x.useState(null),[ge,ve]=x.useState(""),[Ee,gn]=x.useState(wm),[vn,Yn]=x.useState(!0),[Ln,Xn]=x.useState(!0),[Pe,qt]=x.useState(!0),[ot,dt]=x.useState(!0),[lt,yn]=x.useState(!0),[re,It]=x.useState(!0),[tt,Vr]=x.useState(!0),[nn,xn]=x.useState(!0),[xt,_n]=x.useState(!0),[Oe,rn]=x.useState(!0),[On,xr]=x.useState(!0),[Dn,Qr]=x.useState(!0),[Sn,sn]=x.useState(!0),[Lt,Zn]=x.useState(!0),[Kt,on]=x.useState(!0),[Ot,_r]=x.useState(!0),[zn,Sr]=x.useState(!0),[$n,wr]=x.useState(!0),[ze,er]=x.useState(""),[Dt,Fn]=x.useState([]),[wn,Ge]=x.useState(""),[nt,ln]=x.useState(null),[zt,Un]=x.useState(!1),[bn,Gt]=x.useState(""),[jr,_t]=x.useState(""),[jn,an]=x.useState([]),[tr,Wr]=x.useState(!1),[Re,Pt]=x.useState({open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:sa,saving:!1,error:""}),nr=x.useRef(!1),Bn=x.useRef(!1),cs=x.useRef(!1);x.useEffect(()=>{const m=document.documentElement,{colors:E}=ta;m.style.setProperty("--rgb-background",E.backgroundRgb),m.style.setProperty("--rgb-surface-main",E.mainSurfaceRgb),m.style.setProperty("--rgb-surface-horizontal",E.horizontalSurfaceRgb),m.style.setProperty("--rgb-surface-focus",E.focusSurfaceRgb),m.style.setProperty("--rgb-assistant-chip",E.assistantChipRgb),m.style.setProperty("--rgb-assistant-chip-hover",E.assistantChipHoverRgb),m.style.setProperty("--rgb-assistant-chip-selected",E.assistantChipSelectedRgb),m.style.setProperty("--rgb-assistant-chip-selected-text",E.assistantChipSelectedTextRgb),m.style.setProperty("--rgb-active",E.activeRgb),m.style.setProperty("--rgb-active-text",E.activeTextRgb),m.style.setProperty("--rgb-text-main",E.textMainRgb),m.style.setProperty("--rgb-text-muted",E.textMutedRgb),m.style.setProperty("--rgb-danger",E.dangerRgb),m.style.setProperty("--rgb-scrollbar-track",E.scrollbarTrackRgb),m.style.setProperty("--rgb-scrollbar-thumb",E.scrollbarThumbRgb),m.style.setProperty("--rgb-scrollbar-thumb-hover",E.scrollbarThumbHoverRgb),m.style.setProperty("--mode-column-width",`${ta.layout.modeColumnWidthPx}px`),m.style.setProperty("--mode-toggle-width",`${ta.layout.modeToggleWidthPx}px`)},[]);const D=m=>{z(E=>[km(m),...E].slice(0,300))};function zs(){let m=0;Gt(na[0]);const E=window.setInterval(()=>{m=Math.min(m+1,na.length-1),Gt(na[m])},650);return()=>window.clearInterval(E)}x.useEffect(()=>{(async()=>{const k=localStorage.getItem(bc);if(k)try{const te=JSON.parse(k);p(Ie=>({...Ie,llmProvider:te.llmProvider==="local"?"local":"openai",model:te.model??Ie.model,baseUrl:te.baseUrl??Ie.baseUrl,temperature:te.temperature??Ie.temperature,maxOutputTokens:te.maxOutputTokens??Ie.maxOutputTokens}))}catch{}try{const te=await _e.loadSharedConnectionConfig();te.connection&&te.connection.llmProvider==="local"&&(p(Ie=>({...Ie,llmProvider:"local",model:te.connection?.model??Ie.model,baseUrl:te.connection?.baseUrl??Ie.baseUrl,temperature:te.connection?.temperature??Ie.temperature,maxOutputTokens:te.connection?.maxOutputTokens??Ie.maxOutputTokens})),D(`Shared local LLM config loaded: ${te.connection.model}`))}catch(te){D(`Shared local config load error: ${te instanceof Error?te.message:String(te)}`)}finally{cs.current=!0}})();const E=localStorage.getItem(Bc);if(E)try{const k=JSON.parse(E);k.uiMode==="decomposition"?gn("decomposition"):(k.uiMode==="assistant"||k.uiMode==="autoruns")&&gn("autoruns"),k.activeTab&&jm.includes(k.activeTab)&&Ne(k.activeTab),typeof k.showAutorunsSettingsMode=="boolean"&&Yn(k.showAutorunsSettingsMode),typeof k.showAutorunsAutoRunsMode=="boolean"&&Xn(k.showAutorunsAutoRunsMode),typeof k.showAutorunsAssistantMode=="boolean"&&qt(k.showAutorunsAssistantMode),typeof k.showAutorunsDecompositionMode=="boolean"&&dt(k.showAutorunsDecompositionMode),typeof k.showAutorunsProgressMode=="boolean"&&yn(k.showAutorunsProgressMode),typeof k.showAutorunsCommentsMode=="boolean"&&It(k.showAutorunsCommentsMode),typeof k.showAssistantConnectionMode=="boolean"&&Vr(k.showAssistantConnectionMode),typeof k.showAssistantPromptMode=="boolean"&&xn(k.showAssistantPromptMode),typeof k.showAssistantChatMode=="boolean"&&_n(k.showAssistantChatMode),typeof k.showAssistantCommentsMode=="boolean"&&rn(k.showAssistantCommentsMode),typeof k.showAssistantSamMode=="boolean"&&xr(k.showAssistantSamMode),typeof k.showDecompositionConnectionMode=="boolean"&&Qr(k.showDecompositionConnectionMode),typeof k.showDecompositionPromptMode=="boolean"&&sn(k.showDecompositionPromptMode),typeof k.showDecompositionQueryMode=="boolean"&&Zn(k.showDecompositionQueryMode),typeof k.showDecompositionOutputMode=="boolean"&&on(k.showDecompositionOutputMode),typeof k.showDecompositionMetricsMode=="boolean"&&_r(k.showDecompositionMetricsMode),typeof k.showDecompositionHistoryMode=="boolean"&&Sr(k.showDecompositionHistoryMode),typeof k.showDecompositionRuntimeMode=="boolean"&&wr(k.showDecompositionRuntimeMode),k.prompts&&(N(te=>({...te,...k.prompts})),Bn.current=!0)}catch{}Mt(),qr(),St()},[]),x.useEffect(()=>{if(!cs.current||i.llmProvider!=="local")return;const m=window.setTimeout(()=>{_e.saveSharedConnectionConfig(i).catch(E=>D(`Shared local config sync error: ${E instanceof Error?E.message:String(E)}`))},250);return()=>window.clearTimeout(m)},[i.baseUrl,i.llmProvider,i.maxOutputTokens,i.model,i.temperature]);async function Mt(){try{const m=await _e.loadHistory();Q(m.items??[])}catch(m){D(`History load error: ${m instanceof Error?m.message:String(m)}`)}}async function qr(){try{const E=(await _e.loadPresets()).presets??[];if(Me(E),Bn.current){nr.current=!0;return}if(nr.current)return;const k=E.find(te=>te.prompt_version===ra)??E.find(te=>te.id==="default-normalizer-v2_0_2");if(!k){nr.current=!0,D(`Preset autoload skipped: ${ra} not found.`);return}ct(k.id),Le(f),N({systemPrompt:k.systemPrompt,developerPrompt:k.developerPrompt,domainPrompt:k.domainPrompt,schemaNotes:k.schemaNotes??"",fewShotExamples:k.fewShotExamples??""}),nr.current=!0,D(`Preset autoloaded: ${k.name} (${k.prompt_version}).`)}catch(m){D(`Presets load error: ${m instanceof Error?m.message:String(m)}`)}}async function St(){try{const m=await _e.listRuns();X(m.items??[])}catch(m){D(`Runs load error: ${m instanceof Error?m.message:String(m)}`)}}function rr(){if(localStorage.setItem(bc,JSON.stringify({model:i.model,llmProvider:i.llmProvider,baseUrl:i.baseUrl,temperature:i.temperature,maxOutputTokens:i.maxOutputTokens})),i.llmProvider==="local"){_e.saveSharedConnectionConfig(i).then(()=>{D("Local config saved and synced to shared agent config (without API key).")}).catch(m=>{D(`Local config saved, but shared sync failed: ${m instanceof Error?m.message:String(m)}`)});return}D("Local config saved (without API key).")}function Kr(){localStorage.setItem(Bc,JSON.stringify({uiMode:Ee,activeTab:ne,showAutorunsSettingsMode:vn,showAutorunsAutoRunsMode:Ln,showAutorunsAssistantMode:Pe,showAutorunsDecompositionMode:ot,showAutorunsProgressMode:lt,showAutorunsCommentsMode:re,showAssistantConnectionMode:tt,showAssistantPromptMode:nn,showAssistantChatMode:xt,showAssistantCommentsMode:Oe,showAssistantSamMode:On,showDecompositionConnectionMode:Dn,showDecompositionPromptMode:Sn,showDecompositionQueryMode:Lt,showDecompositionOutputMode:Kt,showDecompositionMetricsMode:Ot,showDecompositionHistoryMode:zn,showDecompositionRuntimeMode:$n,prompts:f})),window.dispatchEvent(new CustomEvent(Sm)),D("UI layout and prompts saved.")}async function ue(){ce(!0),ve("");try{const m=await _e.testConnection(i);m.provider==="local"?m.model_found===!0?(W(`LOCAL OK - ${m.model}`),D(`Local model is available: ${m.model} (catalog size=${m.models_count??"n/a"}).`)):m.model_found===!1?(W(`LOCAL OK, model not loaded - ${m.model}`),D(`Local server is reachable, but model '${m.model}' is not in loaded catalog. Use 'Load model list' and select one of loaded models.`)):(W(`LOCAL OK (model list unavailable) - ${m.model}`),D("Local server is reachable, but model catalog could not be verified.")):(W(`OPENAI OK - ${m.model}`),D(`OpenAI connection ok: ${m.model}`))}catch(m){const E=m instanceof Error?m.message:String(m);W("Connection error"),ve(`Test connection: ${E}`),D(`Test connection error: ${E}`)}finally{ce(!1)}}async function Ue(){Qe(!0);try{const E=(await _e.listModels(i)).models??[];We(E),E.length>0&&p(k=>k.model&&E.includes(k.model)?k:{...k,model:E[0]}),D(`Model catalog loaded (${i.llmProvider}): ${E.length} items.`)}catch(m){const E=m instanceof Error?m.message:String(m);D(`Load model list error: ${E}`)}finally{Qe(!1)}}x.useEffect(()=>{We([])},[i.llmProvider,i.baseUrl]);async function ye(m){ce(!0),ve("");try{const E=await _e.normalize({connection:i,prompts:f,promptVersion:"normalizer_v2_0_2",query:{userQuestion:j.userQuestion,periodHint:j.periodHint,businessContext:j.businessContext,expectedRoute:j.expectedRoute},saveAsTestCase:m,useMock:Te});Y(E),Ne("normalized"),D(`Normalize done: trace=${E.trace_id}, validation=${E.validation.passed?"passed":"failed"}`),Mt()}catch(E){const k=E instanceof Error?E.message:String(E);ve(`Normalize: ${k}`),D(`Normalize error: ${k}`)}finally{ce(!1)}}function be(){const m=de.find(E=>E.id===Ze);if(!m){D("Preset is not selected.");return}Le(f),N({systemPrompt:m.systemPrompt,developerPrompt:m.developerPrompt,domainPrompt:m.domainPrompt,schemaNotes:m.schemaNotes??"",fewShotExamples:m.fewShotExamples??""}),D(`Preset loaded: ${m.name}`)}async function sr(){try{await _e.savePreset({name:st||"NDC preset",prompt_version:"normalizer_v2_0_2",systemPrompt:f.systemPrompt,developerPrompt:f.developerPrompt,domainPrompt:f.domainPrompt,schemaNotes:f.schemaNotes,fewShotExamples:f.fewShotExamples}),D("Preset saved."),await qr()}catch(m){D(`Preset save error: ${m instanceof Error?m.message:String(m)}`)}}function Hn(){N(Uc),D("Prompt panel reset to defaults.")}function Vn(){const m=Cm(f,ie);Fe(m),D(m)}function $t(){const m=j.batchQuestionsRaw.split(";").map(E=>E.trim()).filter(Boolean).join(` - -`);m&&(T(E=>({...E,batchQuestionsRaw:m})),D("Batch field formatted: `;` converted to blank-line separators."))}async function kn(m){try{const k=(await _e.loadTrace(m)).trace,te=k.parsed_normalized_json??null;Y({trace_id:String(k.trace_id??m),ok:!!k.validation_result?.passed,normalized:te,route_hint_summary:k.route_hint_summary??(te?{route_hint:te.route_hint??null,confidence:te.confidence?.route_hint??null}:null),raw_model_output:k.raw_model_response??{},validation:k.validation_result??{passed:!1,errors:["validation not found"]},usage:k.usage??{input_tokens:0,output_tokens:0,total_tokens:0},latency_ms:Number(k.latency_ms??0),prompt_version:String(k.prompt_version??"unknown"),schema_version:String(k.schema_version??"unknown")}),Ne("raw"),ve(""),D(`Trace opened: ${m}`)}catch(E){const k=E instanceof Error?E.message:String(E);ve(`Trace: ${k}`),D(`Trace open error ${m}: ${k}`)}}async function At(){try{const m=await _e.startRun();y(m.run.runId),D(`Run started: ${m.run.runId}`),D("Tip: start run does not execute normalize by itself. Use 'Run eval v2.0.2' button."),await St()}catch(m){D(`Run start error: ${m instanceof Error?m.message:String(m)}`)}}async function ke(){if(O)try{await _e.finishRun(O),D(`Run finished: ${O}`),await St()}catch(m){D(`Run finish error: ${m instanceof Error?m.message:String(m)}`)}}async function ds(){pe(!0),ve("");try{D("Starting eval in v2 contour.");const m=j.batchQuestionsRaw.trim()||j.userQuestion.trim();if(!m)throw new Error("Fill batch field or Raw user question first.");const E=await _e.runEval({connection:i,prompts:f,promptVersion:"normalizer_v2_0_2",mode:"single-pass-strict",rawQuestions:m,useMock:Te});Se(E.report),D("Eval v2.0.2 run finished.");const k=E.report;if(k.run_id&&D(`Eval run id: ${k.run_id}`),k.metrics){const te=k.metrics;D(`Eval metrics v2.0.2: schema=${te.schema_validation_pass_rate??"n/a"}%, route_accuracy=${te.route_resolution_accuracy??"n/a"}%, no_route_precision=${te.no_route_precision??"n/a"}%, state_consistency=${te.execution_state_consistency_rate??"n/a"}%`)}await Mt()}catch(m){const E=m instanceof Error?m.message:String(m);E.includes("Legacy eval runner supports normalized_query_v1 only")?(Se({status:"plan_only",prompt_version:"normalizer_v2",reason:"backend eval runner is still legacy-v1 only",plan_file:"reports/v2_pilot_eval_plan.md",next_steps:["run cheap mock sanity for schema/fragment/scope","run small real batch (10-15 messages, temperature=0)","run challenge-30 replay with v2 metrics"]}),D("Backend is legacy-only for eval right now. Showing v2 pilot plan.")):(ve(`Eval: ${E}`),D(`Eval run error: ${E}`))}finally{pe(!1)}}async function $s(){try{const m=JSON.stringify(ae??{},null,2);await navigator.clipboard.writeText(m),D("Eval report copied to clipboard.")}catch(m){D(`Eval report copy error: ${m instanceof Error?m.message:String(m)}`)}}const Cn=x.useMemo(()=>{const m=new Map;for(const E of jn)E.message_id&&m.set(E.message_id,E);return m},[jn]),kr=Re.messageIndex>=0?Dt[Re.messageIndex]??null:null,or=x.useMemo(()=>{if(Re.messageIndex<0)return null;for(let m=Re.messageIndex-1;m>=0;m-=1){const E=Dt[m];if(E?.role==="user")return E}return null},[Re.messageIndex,Dt]);async function it(m){if(!m.trim()){an([]);return}Wr(!0);try{const E=await _e.loadAssistantAnnotations({session_id:m,limit:400});an(E.items??[])}catch(E){const k=E instanceof Error?E.message:String(E);D(`Assistant annotations load error: ${k}`)}finally{Wr(!1)}}function lr(m){Pt(E=>E.saving&&!m?.force?E:{open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:sa,saving:!1,error:""})}function ir(m,E){if(m.role!=="assistant")return;const k=ze.trim(),te=String(m.session_id??"").trim();if(!(k||te)){_t("Сначала получите ответ ассистента в активной сессии.");return}!k&&te&&er(te);const gt=Cn.get(m.message_id)??null;Pt({open:!0,messageIndex:E,rating:gt?.rating??3,comment:gt?.comment??"",annotationAuthor:gt?.annotation_author??sa,saving:!1,error:""})}function F(m){return m.role==="assistant"}function ar(m){return m.role==="assistant"&&Cn.has(m.message_id)}async function Nn(){if(!ze.trim()){Pt(m=>({...m,error:"Сессия ассистента не найдена."}));return}if(!(Re.messageIndex<0)){if(!Re.comment.trim()){Pt(m=>({...m,error:"Добавьте комментарий."}));return}Pt(m=>({...m,saving:!0,error:""}));try{const m=await _e.saveAssistantAnnotation({session_id:ze,message_index:Re.messageIndex,rating:Re.rating,comment:Re.comment.trim(),annotation_author:Re.annotationAuthor.trim()||void 0});an(E=>{const k=[...E],te=k.findIndex(Ie=>Ie.annotation_id===m.annotation.annotation_id);return te>=0?k[te]=m.annotation:k.unshift(m.annotation),k.sort((Ie,gt)=>Date.parse(gt.updated_at)-Date.parse(Ie.updated_at))}),lr({force:!0})}catch(m){const E=m instanceof Error?m.message:String(m);Pt(k=>({...k,saving:!1,error:E}))}}}function Cr(){er(""),Fn([]),Ge(""),ln(null),Gt(""),_t(""),an([]),lr({force:!0}),D("Assistant session reset.")}async function fs(){const m=Nm(wn,nt);if(!m)return;Un(!0),_t(""),Ge(""),Fn(k=>[...k,{message_id:`local-${Date.now()}`,session_id:ze||"pending",role:"user",text:m,reply_type:null,created_at:new Date().toISOString(),trace_id:null,debug:null}]);const E=zs();try{const k=await _e.sendAssistantMessage({connection:i,prompts:f,userMessage:m,sessionId:ze||void 0,promptVersion:Hc,useMock:Te});er(k.session_id),Fn(k.conversation),Gt("Ответ готов"),await it(k.session_id),D(`Assistant reply received: trace=${k.debug.trace_id}`)}catch(k){const te=k instanceof Error?k.message:String(k);_t(te),Gt("Ошибка ассистента"),D(`Assistant error: ${te}`)}finally{E(),Un(!1)}}return x.useEffect(()=>{if(!ze.trim()){an([]);return}it(ze)},[ze]),x.useEffect(()=>{if(!O){J([]);return}_e.runTrace(O).then(m=>J(m.items)).catch(m=>D(`Run trace error: ${m instanceof Error?m.message:String(m)}`))},[O]),o.jsxs("main",{className:`app-root ${Ee==="assistant"||Ee==="decomposition"||Ee==="autoruns"?"app-root-autoruns":""}`,children:[o.jsxs("header",{className:"app-topbar",children:[o.jsxs("div",{className:"mode-switch-row",children:[o.jsx("button",{type:"button",className:Ee==="autoruns"?"tab active":"tab",onClick:()=>gn("autoruns"),children:"Управление ассистентом"}),o.jsx("button",{type:"button",className:Ee==="decomposition"?"tab active":"tab",onClick:()=>gn("decomposition"),children:"Декомпозиция"}),o.jsx("button",{type:"button",className:"tab",onClick:Kr,children:"Сохранить"})]}),Ee==="assistant"?o.jsxs("div",{className:"mode-switch-row mode-switch-row-right",children:[o.jsx("button",{type:"button",className:tt?"tab active":"tab",onClick:()=>Vr(m=>!m),children:"LLM Connector"}),o.jsx("button",{type:"button",className:nn?"tab active":"tab",onClick:()=>xn(m=>!m),children:"Prompt Manager"}),o.jsx("button",{type:"button",className:xt?"tab active":"tab",onClick:()=>_n(m=>!m),children:"Режим ассистента"}),o.jsx("button",{type:"button",className:Oe?"tab active":"tab",onClick:()=>rn(m=>!m),children:"Комментарии ассистента"}),o.jsx("button",{type:"button",className:On?"tab active":"tab",onClick:()=>xr(m=>!m),children:"SAM"})]}):Ee==="decomposition"?o.jsxs("div",{className:"mode-switch-row mode-switch-row-right",children:[o.jsx("button",{type:"button",className:Dn?"tab active":"tab",onClick:()=>Qr(m=>!m),children:"LLM"}),o.jsx("button",{type:"button",className:Sn?"tab active":"tab",onClick:()=>sn(m=>!m),children:"Prompt"}),o.jsx("button",{type:"button",className:Lt?"tab active":"tab",onClick:()=>Zn(m=>!m),children:"Запрос"}),o.jsx("button",{type:"button",className:Kt?"tab active":"tab",onClick:()=>on(m=>!m),children:"Выход"}),o.jsx("button",{type:"button",className:Ot?"tab active":"tab",onClick:()=>_r(m=>!m),children:"Метрики"}),o.jsx("button",{type:"button",className:zn?"tab active":"tab",onClick:()=>Sr(m=>!m),children:"История"}),o.jsx("button",{type:"button",className:$n?"tab active":"tab",onClick:()=>wr(m=>!m),children:"NDC Run Monitor"})]}):Ee==="autoruns"?o.jsxs("div",{className:"mode-switch-row mode-switch-row-right",children:[o.jsx("button",{type:"button",className:vn?"tab active":"tab",onClick:()=>Yn(m=>!m),children:"Настройки"}),o.jsx("button",{type:"button",className:Ln?"tab active":"tab",onClick:()=>Xn(m=>!m),children:"Автопрогоны"}),o.jsx("button",{type:"button",className:Pe?"tab active":"tab",onClick:()=>qt(m=>!m),children:"Режим ассистента"}),o.jsx("button",{type:"button",className:ot?"tab active":"tab",onClick:()=>dt(m=>!m),children:"Режим декомпозиции"}),o.jsx("button",{type:"button",className:lt?"tab active":"tab",onClick:()=>yn(m=>!m),children:"Прогресс/регресс"}),o.jsx("button",{type:"button",className:re?"tab active":"tab",onClick:()=>It(m=>!m),children:"Комментарии"})]}):null]}),Ee==="assistant"?o.jsx("div",{className:"layout-grid layout-grid-mode-columns",children:o.jsxs("div",{className:"mode-columns",children:[tt?o.jsx("div",{className:"mode-col",children:o.jsx(oa,{value:i,modelOptions:De,modelsBusy:me,onChange:p,onReloadModels:Ue,onSaveLocalConfig:rr,onTestConnection:ue,lastStatus:je,busy:le||zt})}):null,nn?o.jsx("div",{className:"mode-col mode-col-wide",children:o.jsx(la,{value:f,onChange:N,presets:de,selectedPresetId:Ze,onSelectPreset:ct,onLoadPreset:be,onSavePreset:sr,onResetDefaults:Hn,onDiffPrevious:Vn,presetName:st,onPresetNameChange:Et,diffSummary:H})}):null,xt?o.jsx("div",{className:"mode-col mode-col-xwide",children:o.jsx(Wc,{sessionId:ze,conversation:Dt,inputValue:wn,onInputChange:Ge,selectedContextChip:nt,onSelectContextChip:ln,onClearContextChip:()=>ln(null),useMock:Te,onUseMockChange:Ae,onSend:fs,onClear:Cr,busy:zt,statusText:bn,errorMessage:jr,showCommentAction:!0,onCommentAssistantMessage:ir,isAssistantMessageCommented:ar,canCommentAssistantMessage:F})}):null,Oe?o.jsx("div",{className:"mode-col",children:o.jsx(In,{className:"assistant-comments-frame",title:"Комментарии ассистента",children:o.jsxs("div",{className:"assistant-comments-shell",children:[o.jsxs("div",{className:"assistant-comments-toolbar",children:[o.jsx("span",{className:"muted",children:ze?`session: ${ze}`:"Сессия не запущена"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>{it(ze)},disabled:!ze||tr,children:tr?"Обновляю...":"Обновить"})]}),o.jsxs("div",{className:"assistant-comments-list",children:[ze?null:o.jsx("p",{className:"muted",children:"Появится после первого ответа ассистента."}),ze&&jn.length===0&&!tr?o.jsx("p",{className:"muted",children:"Комментариев по этой сессии пока нет."}):null,jn.map(m=>o.jsxs("article",{className:"assistant-comment-item",children:[o.jsxs("div",{className:"assistant-comment-head",children:[o.jsx("strong",{children:`${"●".repeat(Math.max(1,Math.min(5,Math.round(m.rating))))}${"○".repeat(Math.max(0,5-Math.round(m.rating)))}`}),o.jsx("span",{children:new Date(m.updated_at).toLocaleString("ru-RU")})]}),m.context.question_text?o.jsxs("p",{children:["Q: ",m.context.question_text]}):null,m.context.answer_text?o.jsxs("p",{children:["A: ",m.context.answer_text]}):null,o.jsx("p",{children:m.comment}),o.jsxs("div",{className:"assistant-comment-meta",children:[m.context.trace_id?o.jsx("span",{children:`trace=${m.context.trace_id}`}):null,m.context.reply_type?o.jsx("span",{children:`reply_type=${m.context.reply_type}`}):null]})]},m.annotation_id))]})]})})}):null,On?o.jsx("div",{className:"mode-col",children:o.jsx(Of,{sessionId:ze,conversation:Dt,statusText:bn,errorMessage:jr,useMock:Te,appLogs:G})}):null,!tt&&!nn&&!xt&&!Oe&&!On?o.jsx("div",{className:"mode-columns-empty",children:"Все панели режима ассистента скрыты. Включите нужные блоки справа в шапке."}):null]})}):Ee==="decomposition"?o.jsx("div",{className:"layout-grid layout-grid-mode-columns",children:o.jsxs("div",{className:"mode-columns",children:[Dn?o.jsx("div",{className:"mode-col",children:o.jsx(oa,{value:i,modelOptions:De,modelsBusy:me,onChange:p,onReloadModels:Ue,onSaveLocalConfig:rr,onTestConnection:ue,lastStatus:je,busy:le})}):null,Sn?o.jsx("div",{className:"mode-col mode-col-wide",children:o.jsx(la,{value:f,onChange:N,presets:de,selectedPresetId:Ze,onSelectPreset:ct,onLoadPreset:be,onSavePreset:sr,onResetDefaults:Hn,onDiffPrevious:Vn,presetName:st,onPresetNameChange:Et,diffSummary:H})}):null,Lt?o.jsx("div",{className:"mode-col",children:o.jsx(vm,{value:j,onChange:T,onApplyBatchFormat:$t,onNormalize:ye,busy:le,useMock:Te,onUseMockChange:Ae,errorMessage:ge})}):null,Kt?o.jsx("div",{className:"mode-col mode-col-xwide",children:o.jsx(gm,{tab:ne,onTabChange:Ne,result:$,appLogs:G})}):null,Ot?o.jsx("div",{className:"mode-col",children:o.jsx(mm,{result:$})}):null,zn?o.jsx("div",{className:"mode-col",children:o.jsx(fm,{items:b,onRefresh:Mt,onOpenTrace:kn})}):null,$n?o.jsx("div",{className:"mode-col mode-col-xwide",children:o.jsx(ym,{runs:I,selectedRunId:O,onSelectRun:y,onStartRun:At,onFinishRun:ke,onRefreshRuns:St,onRunEval:ds,onCopyEvalReport:$s,evalBusy:oe,traceItems:C,evalReport:ae})}):null,!Dn&&!Sn&&!Lt&&!Kt&&!Ot&&!zn&&!$n?o.jsx("div",{className:"mode-columns-empty",children:"Все панели режима декомпозиции скрыты. Включите нужные блоки справа в шапке."}):null]})}):o.jsx("div",{className:"layout-grid layout-grid-autoruns",children:o.jsx(dm,{connection:i,modelOptions:De,modelsBusy:me,connectionStatus:je,connectionBusy:le,onConnectionChange:p,onReloadModels:Ue,onSaveLocalConfig:rr,onTestConnection:ue,prompts:f,onPromptsChange:N,promptPresets:de,selectedPresetId:Ze,onSelectPreset:ct,onLoadPreset:be,onSavePreset:sr,onResetDefaults:Hn,onDiffPrevious:Vn,presetName:st,onPresetNameChange:Et,diffSummary:H,assistantPromptVersion:Hc,decompositionPromptVersion:ra,showSettingsMode:vn,showAutoRunsMode:Ln,showAssistantMode:Pe,showDecompositionMode:ot,showProgressMode:lt,showCommentsMode:re,onLog:D})}),Re.open?o.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:m=>{m.target===m.currentTarget&&lr()},children:o.jsxs("div",{className:"autoruns-comment-modal",children:[o.jsx("h3",{children:"Комментарий к ответу ассистента"}),o.jsx("p",{className:"muted",children:"Эта разметка хранится отдельно от комментариев автопрогонов."}),or?o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Вопрос пользователя"}),o.jsx("p",{className:"autoruns-comment-quote",children:or.text})]}):null,kr?o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Ответ ассистента"}),o.jsx("p",{className:"autoruns-comment-quote",children:kr.text})]}):null,o.jsx("div",{className:"autoruns-rating-row",role:"group","aria-label":"Рейтинг ответа",children:[1,2,3,4,5].map(m=>o.jsx("button",{type:"button",className:Re.rating>=m?"autoruns-rating-dot active":"autoruns-rating-dot",onClick:()=>Pt(E=>({...E,rating:m})),disabled:Re.saving,"aria-label":`Оценка ${m}`,children:Re.rating>=m?"●":"○"},m))}),o.jsx("div",{className:"autoruns-form-grid",children:o.jsxs("label",{children:["Автор комментария",o.jsx("input",{value:Re.annotationAuthor,onChange:m=>Pt(E=>({...E,annotationAuthor:m.target.value})),placeholder:"manual_reviewer",disabled:Re.saving})]})}),o.jsxs("label",{children:["Комментарий",o.jsx("textarea",{value:Re.comment,onChange:m=>Pt(E=>({...E,comment:m.target.value})),placeholder:"Что именно не так в ответе и что проверить.",rows:4,disabled:Re.saving})]}),Re.error?o.jsx("p",{className:"error-text",children:Re.error}):null,o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>{Nn()},disabled:Re.saving,children:Re.saving?"Сохраняю...":"Готово"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>lr(),disabled:Re.saving,children:"Отмена"})]})]})}):null]})}Tf.createRoot(document.getElementById("root")).render(o.jsx(Cf.StrictMode,{children:o.jsx(Em,{})})); diff --git a/llm_normalizer/frontend/dist/index.html b/llm_normalizer/frontend/dist/index.html index bfa3ecb..d2318c0 100644 --- a/llm_normalizer/frontend/dist/index.html +++ b/llm_normalizer/frontend/dist/index.html @@ -4,8 +4,8 @@ NDC AI Normalizer Playground - - + +
diff --git a/llm_normalizer/frontend/src/App.tsx b/llm_normalizer/frontend/src/App.tsx index baa2553..fbd9233 100644 --- a/llm_normalizer/frontend/src/App.tsx +++ b/llm_normalizer/frontend/src/App.tsx @@ -1,22 +1,16 @@ -import { useEffect, useMemo, useRef, useState } from "react"; +import { useEffect, useRef, useState } from "react"; import { apiClient } from "./api/client"; -import { AssistantSamPanel } from "./components/AssistantSamPanel"; import { AutoRunsHistoryPanel } from "./components/AutoRunsHistoryPanel"; -import { AssistantPanel } from "./components/AssistantPanel"; import { ConnectionPanel } from "./components/ConnectionPanel"; import { HistoryPanel } from "./components/HistoryPanel"; import { MetricsPanel } from "./components/MetricsPanel"; import { OutputPanel } from "./components/OutputPanel"; -import { PanelFrame } from "./components/PanelFrame"; import { PromptPanel } from "./components/PromptPanel"; import { QueryPanel } from "./components/QueryPanel"; import { RuntimePanel } from "./components/RuntimePanel"; import { DEFAULT_CONNECTION, DEFAULT_PROMPTS, DEFAULT_QUERY } from "./state/defaults"; import { designConfig } from "../../../designconfig"; import type { - AssistantConversationItem, - AssistantAnnotationRecord, - AssistantSelectionChip, ConnectionState, HistoryItem, NormalizeResultState, @@ -30,22 +24,10 @@ import type { const SESSION_CONFIG_KEY = "ndc_normalizer_session_config_v1"; const AUTORUNS_LAYOUT_CONFIG_KEY = "ndc_autoruns_layout_config_v1"; const AUTORUNS_SAVE_EVENT = "ndc-autoruns-save"; -const ASSISTANT_STAGES = ["Анализ запроса", "Получение данных", "Подготовка ответа"]; const DEFAULT_UI_MODE: UiMode = "autoruns"; const AUTOLOAD_PROMPT_VERSION = "normalizer_v2_0_2"; const ASSISTANT_PROMPT_VERSION = "address_query_runtime_v1"; const TAB_KEYS: TabKey[] = ["normalized", "fragments", "scope", "flags", "route", "raw", "validation", "logs"]; -const DEFAULT_ASSISTANT_ANNOTATION_AUTHOR = "manual_reviewer"; - -interface AssistantCommentModalState { - open: boolean; - messageIndex: number; - rating: number; - comment: string; - annotationAuthor: string; - saving: boolean; - error: string; -} function withTs(message: string): string { return `[${new Date().toLocaleTimeString("ru-RU")}] ${message}`; @@ -61,25 +43,6 @@ function diffPrompts(current: PromptState, previous: PromptState | null): string return `Changed fields: ${changed.length}. ${changed.join(" | ")}`; } -function buildAssistantFollowupMessage(inputValue: string, selectedChip: AssistantSelectionChip | null): string { - const trimmedInput = inputValue.trim(); - if (!trimmedInput) { - return ""; - } - if (!selectedChip) { - return trimmedInput; - } - - const normalizedInput = trimmedInput.toLowerCase(); - const selectionAnchor = selectedChip.anchor_text.trim(); - const normalizedSelection = selectionAnchor.toLowerCase(); - if (normalizedSelection && normalizedInput.includes(normalizedSelection)) { - return trimmedInput; - } - - return `По выбранному объекту "${selectionAnchor}": ${trimmedInput}`; -} - export default function App() { const [connection, setConnection] = useState(DEFAULT_CONNECTION); const [prompts, setPrompts] = useState(DEFAULT_PROMPTS); @@ -123,11 +86,6 @@ export default function App() { const [showAutorunsDecompositionMode, setShowAutorunsDecompositionMode] = useState(true); const [showAutorunsProgressMode, setShowAutorunsProgressMode] = useState(true); const [showAutorunsCommentsMode, setShowAutorunsCommentsMode] = useState(true); - const [showAssistantConnectionMode, setShowAssistantConnectionMode] = useState(true); - const [showAssistantPromptMode, setShowAssistantPromptMode] = useState(true); - const [showAssistantChatMode, setShowAssistantChatMode] = useState(true); - const [showAssistantCommentsMode, setShowAssistantCommentsMode] = useState(true); - const [showAssistantSamMode, setShowAssistantSamMode] = useState(true); const [showDecompositionConnectionMode, setShowDecompositionConnectionMode] = useState(true); const [showDecompositionPromptMode, setShowDecompositionPromptMode] = useState(true); const [showDecompositionQueryMode, setShowDecompositionQueryMode] = useState(true); @@ -135,24 +93,6 @@ export default function App() { const [showDecompositionMetricsMode, setShowDecompositionMetricsMode] = useState(true); const [showDecompositionHistoryMode, setShowDecompositionHistoryMode] = useState(true); const [showDecompositionRuntimeMode, setShowDecompositionRuntimeMode] = useState(true); - const [assistantSessionId, setAssistantSessionId] = useState(""); - const [assistantConversation, setAssistantConversation] = useState([]); - const [assistantInput, setAssistantInput] = useState(""); - const [assistantSelectedChip, setAssistantSelectedChip] = useState(null); - const [assistantBusy, setAssistantBusy] = useState(false); - const [assistantStatus, setAssistantStatus] = useState(""); - const [assistantError, setAssistantError] = useState(""); - const [assistantAnnotations, setAssistantAnnotations] = useState([]); - const [assistantAnnotationsBusy, setAssistantAnnotationsBusy] = useState(false); - const [assistantCommentModal, setAssistantCommentModal] = useState({ - open: false, - messageIndex: -1, - rating: 3, - comment: "", - annotationAuthor: DEFAULT_ASSISTANT_ANNOTATION_AUTHOR, - saving: false, - error: "" - }); const presetAutoloadDoneRef = useRef(false); const skipPresetAutoloadRef = useRef(false); const sharedConnectionSyncReadyRef = useRef(false); @@ -184,16 +124,6 @@ export default function App() { setAppLogs((prev) => [withTs(message), ...prev].slice(0, 300)); }; - function startAssistantStatusTicker(): () => void { - let index = 0; - setAssistantStatus(ASSISTANT_STAGES[0]); - const timer = window.setInterval(() => { - index = Math.min(index + 1, ASSISTANT_STAGES.length - 1); - setAssistantStatus(ASSISTANT_STAGES[index]); - }, 650); - return () => window.clearInterval(timer); - } - useEffect(() => { const bootstrapSharedConnection = async () => { const cached = localStorage.getItem(SESSION_CONFIG_KEY); @@ -239,7 +169,7 @@ export default function App() { if (cachedAutorunsLayout) { try { const parsed = JSON.parse(cachedAutorunsLayout) as { - uiMode?: UiMode; + uiMode?: UiMode | "assistant"; activeTab?: TabKey; showAutorunsSettingsMode?: boolean; showAutorunsAutoRunsMode?: boolean; @@ -247,11 +177,6 @@ export default function App() { showAutorunsDecompositionMode?: boolean; showAutorunsProgressMode?: boolean; showAutorunsCommentsMode?: boolean; - showAssistantConnectionMode?: boolean; - showAssistantPromptMode?: boolean; - showAssistantChatMode?: boolean; - showAssistantCommentsMode?: boolean; - showAssistantSamMode?: boolean; showDecompositionConnectionMode?: boolean; showDecompositionPromptMode?: boolean; showDecompositionQueryMode?: boolean; @@ -261,9 +186,7 @@ export default function App() { showDecompositionRuntimeMode?: boolean; prompts?: PromptState; }; - if (parsed.uiMode === "decomposition") { - setUiMode("decomposition"); - } else if (parsed.uiMode === "assistant" || parsed.uiMode === "autoruns") { + if (parsed.uiMode === "assistant" || parsed.uiMode === "autoruns" || parsed.uiMode === "decomposition") { setUiMode("autoruns"); } if (parsed.activeTab && TAB_KEYS.includes(parsed.activeTab)) { @@ -287,21 +210,6 @@ export default function App() { if (typeof parsed.showAutorunsCommentsMode === "boolean") { setShowAutorunsCommentsMode(parsed.showAutorunsCommentsMode); } - if (typeof parsed.showAssistantConnectionMode === "boolean") { - setShowAssistantConnectionMode(parsed.showAssistantConnectionMode); - } - if (typeof parsed.showAssistantPromptMode === "boolean") { - setShowAssistantPromptMode(parsed.showAssistantPromptMode); - } - if (typeof parsed.showAssistantChatMode === "boolean") { - setShowAssistantChatMode(parsed.showAssistantChatMode); - } - if (typeof parsed.showAssistantCommentsMode === "boolean") { - setShowAssistantCommentsMode(parsed.showAssistantCommentsMode); - } - if (typeof parsed.showAssistantSamMode === "boolean") { - setShowAssistantSamMode(parsed.showAssistantSamMode); - } if (typeof parsed.showDecompositionConnectionMode === "boolean") { setShowDecompositionConnectionMode(parsed.showDecompositionConnectionMode); } @@ -448,11 +356,6 @@ export default function App() { showAutorunsDecompositionMode, showAutorunsProgressMode, showAutorunsCommentsMode, - showAssistantConnectionMode, - showAssistantPromptMode, - showAssistantChatMode, - showAssistantCommentsMode, - showAssistantSamMode, showDecompositionConnectionMode, showDecompositionPromptMode, showDecompositionQueryMode, @@ -740,207 +643,6 @@ export default function App() { } } - const assistantAnnotationsByMessageId = useMemo(() => { - const map = new Map(); - for (const item of assistantAnnotations) { - if (item.message_id) { - map.set(item.message_id, item); - } - } - return map; - }, [assistantAnnotations]); - - const assistantCommentModalMessage = - assistantCommentModal.messageIndex >= 0 ? assistantConversation[assistantCommentModal.messageIndex] ?? null : null; - - const assistantCommentModalQuestion = useMemo(() => { - if (assistantCommentModal.messageIndex < 0) return null; - for (let index = assistantCommentModal.messageIndex - 1; index >= 0; index -= 1) { - const candidate = assistantConversation[index]; - if (candidate?.role === "user") { - return candidate; - } - } - return null; - }, [assistantCommentModal.messageIndex, assistantConversation]); - - async function loadAssistantAnnotationsForSession(sessionId: string): Promise { - if (!sessionId.trim()) { - setAssistantAnnotations([]); - return; - } - setAssistantAnnotationsBusy(true); - try { - const payload = await apiClient.loadAssistantAnnotations({ - session_id: sessionId, - limit: 400 - }); - setAssistantAnnotations(payload.items ?? []); - } catch (error) { - const message = error instanceof Error ? error.message : String(error); - log(`Assistant annotations load error: ${message}`); - } finally { - setAssistantAnnotationsBusy(false); - } - } - - function closeAssistantCommentModal(options?: { force?: boolean }) { - setAssistantCommentModal((prev) => { - if (prev.saving && !options?.force) { - return prev; - } - return { - open: false, - messageIndex: -1, - rating: 3, - comment: "", - annotationAuthor: DEFAULT_ASSISTANT_ANNOTATION_AUTHOR, - saving: false, - error: "" - }; - }); - } - - function openAssistantCommentModal(item: AssistantConversationItem, index: number): void { - if (item.role !== "assistant") return; - const sessionIdFromState = assistantSessionId.trim(); - const sessionIdFromItem = String(item.session_id ?? "").trim(); - const resolvedSessionId = sessionIdFromState || sessionIdFromItem; - if (!resolvedSessionId) { - setAssistantError("Сначала получите ответ ассистента в активной сессии."); - return; - } - if (!sessionIdFromState && sessionIdFromItem) { - setAssistantSessionId(sessionIdFromItem); - } - const existing = assistantAnnotationsByMessageId.get(item.message_id) ?? null; - setAssistantCommentModal({ - open: true, - messageIndex: index, - rating: existing?.rating ?? 3, - comment: existing?.comment ?? "", - annotationAuthor: existing?.annotation_author ?? DEFAULT_ASSISTANT_ANNOTATION_AUTHOR, - saving: false, - error: "" - }); - } - - function canCommentAssistantMessage(item: AssistantConversationItem): boolean { - return item.role === "assistant"; - } - - function isAssistantMessageCommented(item: AssistantConversationItem): boolean { - return item.role === "assistant" && assistantAnnotationsByMessageId.has(item.message_id); - } - - async function submitAssistantCommentModal(): Promise { - if (!assistantSessionId.trim()) { - setAssistantCommentModal((prev) => ({ ...prev, error: "Сессия ассистента не найдена." })); - return; - } - if (assistantCommentModal.messageIndex < 0) { - return; - } - if (!assistantCommentModal.comment.trim()) { - setAssistantCommentModal((prev) => ({ ...prev, error: "Добавьте комментарий." })); - return; - } - - setAssistantCommentModal((prev) => ({ ...prev, saving: true, error: "" })); - try { - const payload = await apiClient.saveAssistantAnnotation({ - session_id: assistantSessionId, - message_index: assistantCommentModal.messageIndex, - rating: assistantCommentModal.rating, - comment: assistantCommentModal.comment.trim(), - annotation_author: assistantCommentModal.annotationAuthor.trim() || undefined - }); - setAssistantAnnotations((prev) => { - const next = [...prev]; - const index = next.findIndex((item) => item.annotation_id === payload.annotation.annotation_id); - if (index >= 0) { - next[index] = payload.annotation; - } else { - next.unshift(payload.annotation); - } - return next.sort((a, b) => Date.parse(b.updated_at) - Date.parse(a.updated_at)); - }); - closeAssistantCommentModal({ force: true }); - } catch (error) { - const message = error instanceof Error ? error.message : String(error); - setAssistantCommentModal((prev) => ({ ...prev, saving: false, error: message })); - } - } - - function resetAssistantSession() { - setAssistantSessionId(""); - setAssistantConversation([]); - setAssistantInput(""); - setAssistantSelectedChip(null); - setAssistantStatus(""); - setAssistantError(""); - setAssistantAnnotations([]); - closeAssistantCommentModal({ force: true }); - log("Assistant session reset."); - } - - async function sendAssistantMessage() { - const userMessage = buildAssistantFollowupMessage(assistantInput, assistantSelectedChip); - if (!userMessage) { - return; - } - - setAssistantBusy(true); - setAssistantError(""); - setAssistantInput(""); - setAssistantConversation((prev) => [ - ...prev, - { - message_id: `local-${Date.now()}`, - session_id: assistantSessionId || "pending", - role: "user", - text: userMessage, - reply_type: null, - created_at: new Date().toISOString(), - trace_id: null, - debug: null - } - ]); - - const stopTicker = startAssistantStatusTicker(); - try { - const response = await apiClient.sendAssistantMessage({ - connection, - prompts, - userMessage, - sessionId: assistantSessionId || undefined, - promptVersion: ASSISTANT_PROMPT_VERSION, - useMock - }); - setAssistantSessionId(response.session_id); - setAssistantConversation(response.conversation); - setAssistantStatus("Ответ готов"); - await loadAssistantAnnotationsForSession(response.session_id); - log(`Assistant reply received: trace=${response.debug.trace_id}`); - } catch (error) { - const message = error instanceof Error ? error.message : String(error); - setAssistantError(message); - setAssistantStatus("Ошибка ассистента"); - log(`Assistant error: ${message}`); - } finally { - stopTicker(); - setAssistantBusy(false); - } - } - - useEffect(() => { - if (!assistantSessionId.trim()) { - setAssistantAnnotations([]); - return; - } - void loadAssistantAnnotationsForSession(assistantSessionId); - }, [assistantSessionId]); - useEffect(() => { if (!selectedRunId) { setRunTrace([]); @@ -953,493 +655,89 @@ export default function App() { }, [selectedRunId]); return ( -
+
- -
- {uiMode === "assistant" ? ( -
- - - - - -
- ) : uiMode === "decomposition" ? ( -
- - - - - - - -
- ) : uiMode === "autoruns" ? ( -
- - - - - - -
- ) : null} +
+ + + + + +
- {uiMode === "assistant" ? ( -
-
- {showAssistantConnectionMode ? ( -
- -
- ) : null} - - {showAssistantPromptMode ? ( -
- -
- ) : null} - - {showAssistantChatMode ? ( -
- setAssistantSelectedChip(null)} - useMock={useMock} - onUseMockChange={setUseMock} - onSend={sendAssistantMessage} - onClear={resetAssistantSession} - busy={assistantBusy} - statusText={assistantStatus} - errorMessage={assistantError} - showCommentAction - onCommentAssistantMessage={openAssistantCommentModal} - isAssistantMessageCommented={isAssistantMessageCommented} - canCommentAssistantMessage={canCommentAssistantMessage} - /> -
- ) : null} - - {showAssistantCommentsMode ? ( -
- -
-
- - {assistantSessionId ? `session: ${assistantSessionId}` : "Сессия не запущена"} - - -
-
- {!assistantSessionId ?

Появится после первого ответа ассистента.

: null} - {assistantSessionId && assistantAnnotations.length === 0 && !assistantAnnotationsBusy ? ( -

Комментариев по этой сессии пока нет.

- ) : null} - {assistantAnnotations.map((item) => ( -
-
- {`${"●".repeat(Math.max(1, Math.min(5, Math.round(item.rating))))}${"○".repeat(Math.max(0, 5 - Math.round(item.rating)))}`} - {new Date(item.updated_at).toLocaleString("ru-RU")} -
- {item.context.question_text ?

Q: {item.context.question_text}

: null} - {item.context.answer_text ?

A: {item.context.answer_text}

: null} -

{item.comment}

-
- {item.context.trace_id ? {`trace=${item.context.trace_id}`} : null} - {item.context.reply_type ? {`reply_type=${item.context.reply_type}`} : null} -
-
- ))} -
-
-
-
- ) : null} - - {showAssistantSamMode ? ( -
- -
- ) : null} - - {!showAssistantConnectionMode && - !showAssistantPromptMode && - !showAssistantChatMode && - !showAssistantCommentsMode && - !showAssistantSamMode ? ( -
Все панели режима ассистента скрыты. Включите нужные блоки справа в шапке.
- ) : null} -
-
- ) : uiMode === "decomposition" ? ( -
-
- {showDecompositionConnectionMode ? ( -
- -
- ) : null} - - {showDecompositionPromptMode ? ( -
- -
- ) : null} - - {showDecompositionQueryMode ? ( -
- -
- ) : null} - - {showDecompositionOutputMode ? ( -
- -
- ) : null} - - {showDecompositionMetricsMode ? ( -
- -
- ) : null} - - {showDecompositionHistoryMode ? ( -
- -
- ) : null} - - {showDecompositionRuntimeMode ? ( -
- -
- ) : null} - - {!showDecompositionConnectionMode && - !showDecompositionPromptMode && - !showDecompositionQueryMode && - !showDecompositionOutputMode && - !showDecompositionMetricsMode && - !showDecompositionHistoryMode && - !showDecompositionRuntimeMode ? ( -
Все панели режима декомпозиции скрыты. Включите нужные блоки справа в шапке.
- ) : null} -
-
- ) : ( -
- -
- )} - - {assistantCommentModal.open ? ( -
{ - if (event.target === event.currentTarget) { - closeAssistantCommentModal(); - } - }} - > -
-

Комментарий к ответу ассистента

-

Эта разметка хранится отдельно от комментариев автопрогонов.

- - {assistantCommentModalQuestion ? ( -
- Вопрос пользователя -

{assistantCommentModalQuestion.text}

-
- ) : null} - {assistantCommentModalMessage ? ( -
- Ответ ассистента -

{assistantCommentModalMessage.text}

-
- ) : null} - -
- {[1, 2, 3, 4, 5].map((value) => ( - - ))} -
- -
- -
- -