diff --git a/README.md b/README.md index 31af8c9..93164c3 100644 --- a/README.md +++ b/README.md @@ -934,6 +934,10 @@ ow + toggle 시각 언어로 통일했습니다. - 이 정리로 `retry / follow-up / branch follow-up / steering` 큐 생성 시 현재 대화 교체, 세션 반영, 후속 queue UI 갱신 지점이 하나로 모였고, 이후 queue 정책 조정도 같은 helper 한 군데만 손보면 되게 됐습니다. - 검증: `dotnet build src/AxCopilot/AxCopilot.csproj -c Release -v minimal -p:OutputPath=bin\\verify\\ -p:IntermediateOutputPath=obj\\verify\\` 경고 0 / 오류 0 - 업데이트: 2026-04-05 20:21 (KST) +- 하단 보조 UI도 더 `claw-code`처럼 최소 노출로 조정했습니다. [ChatWindow.xaml.cs](/E:/AX%20Copilot%20-%20Codex/src/AxCopilot/Views/ChatWindow.xaml.cs) 의 draft queue는 기본 상태에서 `실행 / 다음 / 실패`가 하나도 없으면 아예 접히도록 바꿨습니다. 완료/보류만 남은 경우에는 기본 화면에서 보이지 않습니다. +- 같은 파일의 컨텍스트 사용량 hover 팝업도 긴 진단 문자열 대신 2줄 요약으로 정리했습니다. 현재 모델의 오늘 사용량과 `compact 후 첫 응답 대기` 또는 자동 압축 시작 임계치만 보여주도록 줄여 하단 작업 바 밀도를 더 가볍게 맞췄습니다. +- 검증: `dotnet build src/AxCopilot/AxCopilot.csproj -c Release -v minimal -p:OutputPath=bin\\verify\\ -p:IntermediateOutputPath=obj\\verify\\` 경고 0 / 오류 0 +- 업데이트: 2026-04-05 20:27 (KST) --- diff --git a/docs/DEVELOPMENT.md b/docs/DEVELOPMENT.md index fedf957..6a4ea83 100644 --- a/docs/DEVELOPMENT.md +++ b/docs/DEVELOPMENT.md @@ -4700,3 +4700,8 @@ ow + toggle ?쒓컖 ?몄뼱濡??ㅼ떆 ?뺣젹?덈떎. - 이번 묶음 후 추정 parity는 `core engine 91% / main transcript UI 96% / Cowork·Code runtime UX 95% / internal settings 92% / overall 95%` 정도로 재평가했습니다. - 검증: `dotnet build src/AxCopilot/AxCopilot.csproj -c Release -v minimal -p:OutputPath=bin\verify\ -p:IntermediateOutputPath=obj\verify\` 경고 0 / 오류 0 - 업데이트: 2026-04-05 20:21 (KST) +- 하단 보조 UI도 더 최소 노출로 조정했습니다. [ChatWindow.xaml.cs](/E:/AX%20Copilot%20-%20Codex/src/AxCopilot/Views/ChatWindow.xaml.cs) 의 `RebuildDraftQueuePanel(...)` 은 기본 상태에서 `running / queued / failed` 가 모두 0이면 queue 패널을 숨기도록 바뀌었습니다. 완료/보류만 남아 있는 정리성 상태는 기본 transcript 아래를 차지하지 않게 한 변경입니다. +- 같은 파일의 `RefreshContextUsageVisual()` 은 hover 팝업 텍스트를 2줄 요약으로 축소했습니다. 긴 `compact history / session stats / post-compaction usage / top models` 문자열은 기본 hover 경로에서 제거하고, 현재 모델 오늘 사용량과 `compact 후 첫 응답 대기` 또는 자동 압축 시작 임계치만 노출하도록 바꿨습니다. +- 이번 묶음 후 추정 parity는 `core engine 91% / main transcript UI 97% / Cowork·Code runtime UX 96% / internal settings 92% / overall 96%` 정도로 재평가했습니다. +- 검증: `dotnet build src/AxCopilot/AxCopilot.csproj -c Release -v minimal -p:OutputPath=bin\verify\ -p:IntermediateOutputPath=obj\verify\` 경고 0 / 오류 0 +- 업데이트: 2026-04-05 20:27 (KST) diff --git a/src/AxCopilot/Views/ChatWindow.xaml.cs b/src/AxCopilot/Views/ChatWindow.xaml.cs index c897058..28d40a7 100644 --- a/src/AxCopilot/Views/ChatWindow.xaml.cs +++ b/src/AxCopilot/Views/ChatWindow.xaml.cs @@ -18681,9 +18681,6 @@ private static (string icon, string label, string bgHex, string fgHex) GetDecisi var currentModelPromptTokens = GetUsageValue(todayUsage.ModelPromptTokens, currentModelUsageKey); var currentModelCompletionTokens = GetUsageValue(todayUsage.ModelCompletionTokens, currentModelUsageKey); var currentModelTotalTokens = currentModelPromptTokens + currentModelCompletionTokens; - var currentModelPostPromptTokens = GetUsageValue(todayUsage.PostCompactionPromptTokens, currentModelUsageKey); - var currentModelPostCompletionTokens = GetUsageValue(todayUsage.PostCompactionCompletionTokens, currentModelUsageKey); - var currentModelPostTotalTokens = currentModelPostPromptTokens + currentModelPostCompletionTokens; TokenUsagePercentText.Text = percentText; TokenUsageSummaryText.Text = $"컨텍스트 {percentText}"; TokenUsageHintText.Text = @@ -18692,45 +18689,6 @@ private static (string icon, string label, string bgHex, string fgHex) GetDecisi ? $" · 오늘 {FormatTokenCount(currentModelTotalTokens)}" : ""); CompactNowLabel.Text = compactLabel; - var compactHistory = _lastCompactionAt.HasValue && _lastCompactionBeforeTokens.HasValue && _lastCompactionAfterTokens.HasValue - ? $"\n최근 압축: {(_lastCompactionWasAutomatic ? "자동" : "수동")} · {_lastCompactionAt.Value:HH:mm:ss}\n" + - $"절감: {_lastCompactionBeforeTokens.Value:N0} → {_lastCompactionAfterTokens.Value:N0} tokens " + - $"(-{Math.Max(0, _lastCompactionBeforeTokens.Value - _lastCompactionAfterTokens.Value):N0}, " + - $"{Services.TokenEstimator.Format(_lastCompactionBeforeTokens.Value)} → {Services.TokenEstimator.Format(_lastCompactionAfterTokens.Value)})\n" + - $"단계: {(!string.IsNullOrWhiteSpace(_lastCompactionStageSummary) ? _lastCompactionStageSummary : "기본")}" - : ""; - - var compactSession = _sessionCompactionCount > 0 - ? $"\n세션 누적: {_sessionCompactionCount:N0}회 (자동 {_sessionAutomaticCompactionCount:N0} / 수동 {_sessionManualCompactionCount:N0})\n" + - $"세션 절감: {Services.TokenEstimator.Format(_sessionCompactionSavedTokens)} tokens\n" + - $"세션 메모리 {_sessionMemoryCompactionCount:N0}회 · 경계 {_sessionMicrocompactBoundaryCount:N0}건 · snip {_sessionSnipCompactionCount:N0}건" - : ""; - var postCompactionUsage = _sessionPostCompactionResponseCount > 0 - ? $"\ncompact 이후 응답: {_sessionPostCompactionResponseCount:N0}회\n" + - $"compact 이후 사용량: {Services.TokenEstimator.Format(_sessionPostCompactionPromptTokens)} + {Services.TokenEstimator.Format(_sessionPostCompactionCompletionTokens)} = {Services.TokenEstimator.Format(_sessionPostCompactionPromptTokens + _sessionPostCompactionCompletionTokens)} tokens" - : ""; - var pendingPostCompaction = _pendingPostCompaction ? "\ncompact 후 첫 응답 대기 중" : ""; - var currentModelUsageText = !string.IsNullOrWhiteSpace(currentModelUsageKey) - ? $"\n현재 모델: {currentService} · {currentModel}\n" + - $"오늘 모델 사용량: {FormatTokenCount(currentModelPromptTokens)} + {FormatTokenCount(currentModelCompletionTokens)} = {FormatTokenCount(currentModelTotalTokens)} tokens" + - (currentModelPostTotalTokens > 0 - ? $"\n현재 모델 compact 이후: {FormatTokenCount(currentModelPostPromptTokens)} + {FormatTokenCount(currentModelPostCompletionTokens)} = {FormatTokenCount(currentModelPostTotalTokens)} tokens" - : "") - : ""; - var topModelsText = BuildTopModelUsageSummary(todayUsage); - - TokenUsageCard.ToolTip = - $"상태: {summary}\n" + - $"사용량: {currentTokens:N0} / {maxContextTokens:N0} tokens ({percentText})\n" + - $"간단 표기: {Services.TokenEstimator.Format(currentTokens)} / {Services.TokenEstimator.Format(maxContextTokens)}\n" + - $"자동 압축 시작: {triggerPercent}%\n" + - $"현재 입력 초안 포함" + - currentModelUsageText + - topModelsText + - compactHistory + - compactSession + - postCompactionUsage + - pendingPostCompaction; if (TokenUsagePopupTitle != null) TokenUsagePopupTitle.Text = $"컨텍스트 창 {percentText}"; @@ -18738,9 +18696,13 @@ private static (string icon, string label, string bgHex, string fgHex) GetDecisi TokenUsagePopupUsage.Text = $"{Services.TokenEstimator.Format(currentTokens)}/{Services.TokenEstimator.Format(maxContextTokens)}"; if (TokenUsagePopupDetail != null) { - TokenUsagePopupDetail.Text = currentModelTotalTokens > 0 - ? $"오늘 {currentService} · {currentModel} 사용량 {FormatTokenCount(currentModelTotalTokens)}" - : $"{summary} · 자동 압축 시작 {triggerPercent}%"; + var usageLine = currentModelTotalTokens > 0 + ? $"{currentService} · {currentModel} 오늘 {FormatTokenCount(currentModelTotalTokens)}" + : $"{summary} · 오늘 모델 사용량 없음"; + var compactLine = _pendingPostCompaction + ? "compact 후 첫 응답 대기 중" + : $"자동 압축 시작 {triggerPercent}%"; + TokenUsagePopupDetail.Text = $"{usageLine}\n{compactLine}"; } if (TokenUsagePopupCompact != null) { @@ -19686,8 +19648,20 @@ private static (string icon, string label, string bgHex, string fgHex) GetDecisi return; } - DraftQueuePanel.Visibility = Visibility.Visible; var summary = _appState.GetDraftQueueSummary(_activeTab); + var shouldShowQueue = + IsDraftQueueExpanded() + || summary.RunningCount > 0 + || summary.QueuedCount > 0 + || summary.FailedCount > 0; + + if (!shouldShowQueue) + { + DraftQueuePanel.Visibility = Visibility.Collapsed; + return; + } + + DraftQueuePanel.Visibility = Visibility.Visible; DraftQueuePanel.Children.Add(CreateDraftQueueSummaryStrip(summary, IsDraftQueueExpanded())); if (!IsDraftQueueExpanded()) {