AX Agent transcript 권한·도구 결과 표현 정교화 및 이벤트 렌더 분리
Some checks failed
Release Gate / gate (push) Has been cancelled

- claw-code 기준으로 transcript display catalog를 파일/문서/빌드/Git/웹/질문/에이전트 축으로 재정의
- 권한 요청 presentation catalog를 명령 실행, 웹 요청, 스킬 실행, 의견 요청, 파일 수정, 파일 접근 타입으로 세분화
- tool result catalog를 성공/실패/거부/취소와 도구 종류에 따라 더 읽기 쉬운 한국어 결과 라벨로 정리
- CreateCompactEventPill, AddAgentEventBanner, GetDecisionBadgeMeta를 ChatWindow.AgentEventRendering.cs로 분리해 메인 창 코드 비중 축소
- README와 DEVELOPMENT 문서에 변경 목적과 검증 결과 반영
- 검증: dotnet build src/AxCopilot/AxCopilot.csproj -c Release -v minimal -p:OutputPath=bin\verify\ -p:IntermediateOutputPath=obj\verify\ (경고 0 / 오류 0)
This commit is contained in:
2026-04-06 06:59:22 +09:00
parent f9d18fba08
commit 95e40df354
7 changed files with 581 additions and 470 deletions

View File

@@ -1,3 +1,5 @@
using System;
namespace AxCopilot.Services.Agent;
internal sealed record ToolResultPresentation(
@@ -11,27 +13,79 @@ internal static class ToolResultPresentationCatalog
{
public static ToolResultPresentation Resolve(AgentEvent evt, string fallbackLabel)
{
var summary = evt.Summary?.Trim() ?? "";
var summary = (evt.Summary ?? string.Empty).Trim();
var tool = (evt.ToolName ?? string.Empty).Trim().ToLowerInvariant();
var baseLabel = string.IsNullOrWhiteSpace(fallbackLabel) ? "도구 결과" : fallbackLabel;
if (summary.Contains("취소", StringComparison.OrdinalIgnoreCase) ||
summary.Contains("중단", StringComparison.OrdinalIgnoreCase) ||
evt.Type == AgentEventType.StopRequested)
{
return new ToolResultPresentation("\uE711", "도구 취소", "#F8FAFC", "#475569", "cancel");
return new ToolResultPresentation("\uE711", $"{baseLabel} 취소", "#F8FAFC", "#475569", "cancel");
}
if (summary.Contains("거부", StringComparison.OrdinalIgnoreCase) ||
summary.Contains("반려", StringComparison.OrdinalIgnoreCase) ||
summary.Contains("권한 거부", StringComparison.OrdinalIgnoreCase))
{
return new ToolResultPresentation("\uE783", "도구 거부", "#FEF2F2", "#DC2626", "reject");
return new ToolResultPresentation("\uE783", $"{baseLabel} 거부", "#FEF2F2", "#DC2626", "reject");
}
if (!evt.Success || evt.Type == AgentEventType.Error)
{
return new ToolResultPresentation("\uE783", "도구 실패", "#FEF2F2", "#DC2626", "error");
return new ToolResultPresentation(
"\uE783",
BuildFailureLabel(tool, baseLabel),
"#FEF2F2",
"#DC2626",
"error");
}
return new ToolResultPresentation("\uE73E", fallbackLabel, "#ECFDF5", "#16A34A", "success");
return new ToolResultPresentation(
"\uE73E",
BuildSuccessLabel(tool, baseLabel),
"#ECFDF5",
"#16A34A",
"success");
}
private static string BuildSuccessLabel(string tool, string baseLabel)
{
if (tool.Contains("file"))
return "파일 작업 완료";
if (tool.Contains("build") || tool.Contains("test"))
return "빌드/테스트 완료";
if (tool.Contains("git") || tool.Contains("diff"))
return "Git 작업 완료";
if (tool.Contains("document") || tool.Contains("format") || tool.Contains("template"))
return "문서 작업 완료";
if (tool.Contains("skill"))
return "스킬 실행 완료";
if (tool.Contains("web") || tool.Contains("fetch") || tool.Contains("http"))
return "웹 요청 완료";
if (tool.Contains("process") || tool.Contains("bash") || tool.Contains("powershell"))
return "명령 실행 완료";
return baseLabel;
}
private static string BuildFailureLabel(string tool, string baseLabel)
{
if (tool.Contains("file"))
return "파일 작업 실패";
if (tool.Contains("build") || tool.Contains("test"))
return "빌드/테스트 실패";
if (tool.Contains("git") || tool.Contains("diff"))
return "Git 작업 실패";
if (tool.Contains("document") || tool.Contains("format") || tool.Contains("template"))
return "문서 작업 실패";
if (tool.Contains("skill"))
return "스킬 실행 실패";
if (tool.Contains("web") || tool.Contains("fetch") || tool.Contains("http"))
return "웹 요청 실패";
if (tool.Contains("process") || tool.Contains("bash") || tool.Contains("powershell"))
return "명령 실행 실패";
return $"{baseLabel} 실패";
}
}