feat: Enhance Codex CLI settings with toggle and refresh actions

This commit is contained in:
catlog22
2026-01-28 23:05:31 +08:00
parent 279adfd391
commit 6ac041c1d8
4 changed files with 132 additions and 8 deletions

View File

@@ -65,6 +65,41 @@
.cli-setting-control {
margin-bottom: 0.5rem;
flex-shrink: 0;
display: flex;
align-items: center;
gap: 0.5rem;
}
/* Small icon button for refresh etc */
.btn-icon-sm {
display: inline-flex;
align-items: center;
justify-content: center;
width: 24px;
height: 24px;
padding: 0;
border: 1px solid hsl(var(--border));
border-radius: 0.375rem;
background: hsl(var(--background));
color: hsl(var(--muted-foreground));
cursor: pointer;
transition: all 0.15s ease;
}
.btn-icon-sm:hover:not(:disabled) {
border-color: hsl(var(--primary) / 0.5);
color: hsl(var(--primary));
background: hsl(var(--primary) / 0.05);
}
.btn-icon-sm:disabled {
opacity: 0.5;
cursor: not-allowed;
}
.btn-icon-sm i {
width: 12px;
height: 12px;
}
.cli-setting-select {

View File

@@ -1797,7 +1797,7 @@ async function toggleCodexCliEnhancement(enabled) {
var response = await fetch('/api/language/codex-cli-enhancement', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ enabled: enabled })
body: JSON.stringify({ enabled: enabled, action: 'toggle' })
});
if (!response.ok) {
@@ -1828,6 +1828,46 @@ async function toggleCodexCliEnhancement(enabled) {
}
}
async function refreshCodexCliEnhancement() {
if (codexCliEnhancementLoading) return;
codexCliEnhancementLoading = true;
try {
var response = await fetch('/api/language/codex-cli-enhancement', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ action: 'refresh' })
});
if (!response.ok) {
var errData = await response.json();
var errorMsg = errData.error || 'Failed to refresh setting';
if (errorMsg.includes('not found')) {
showRefreshToast(t('lang.installRequired'), 'warning');
} else if (errorMsg.includes('not enabled')) {
showRefreshToast('CLI 调用增强未启用', 'warning');
} else {
showRefreshToast('刷新失败: ' + errorMsg, 'error');
}
throw new Error(errorMsg);
}
var data = await response.json();
// Update UI
renderLanguageSettingsSection();
// Show toast
showRefreshToast('CLI 调用增强已刷新', 'success');
} catch (err) {
console.error('Failed to refresh Codex CLI enhancement:', err);
// Error already shown in the !response.ok block
} finally {
codexCliEnhancementLoading = false;
}
}
async function renderLanguageSettingsSection() {
var container = document.getElementById('language-settings-section');
if (!container) return;
@@ -1914,8 +1954,15 @@ async function renderLanguageSettingsSection() {
'<span class="cli-setting-status ' + (codexCliEnhancementEnabled ? 'enabled' : 'disabled') + '">' +
(codexCliEnhancementEnabled ? t('lang.enabled') : t('lang.disabled')) +
'</span>' +
(codexCliEnhancementEnabled ?
'<button class="btn-icon-sm" onclick="refreshCodexCliEnhancement()" title="刷新 CLI 配置"' + (codexCliEnhancementLoading ? ' disabled' : '') + '>' +
'<i data-lucide="refresh-cw" class="w-3 h-3"></i>' +
'</button>'
: '') +
'</div>' +
'<p class="cli-setting-desc">为 Codex 启用多 CLI 工具调用功能,自动拼接 cli-tools-usage.md 和 cli-tools.json 配置</p>' +
'<p class="cli-setting-desc">为 Codex 启用多 CLI 工具调用功能,自动拼接 cli-tools-usage.md 和 cli-tools.json 配置' +
(codexCliEnhancementEnabled ? '<br><span style="color: var(--text-muted); font-size: 0.85em;">💡 配置文件变更后,点击刷新按钮更新内容</span>' : '') +
'</p>' +
'</div>' +
'</div>';