Merge branch 'feat/back-to-front' into feat/plugin-front-end
This commit is contained in:
@ -255,7 +255,7 @@ export function getWebviewContent(iconUri?: string): string {
|
||||
padding: 0;
|
||||
}
|
||||
.message-segment {
|
||||
padding: 10px 22 px;
|
||||
padding: 10px 22px;
|
||||
}
|
||||
.segment-text {
|
||||
line-height: 1.6;
|
||||
@ -417,6 +417,62 @@ export function getWebviewContent(iconUri?: string): string {
|
||||
let loadingIndicator = null;
|
||||
let currentSegmentedMessage = null; // 当前分段消息容器
|
||||
|
||||
// ========== 模式选择器脚本(直接内联,避免模板字符串嵌套问题)==========
|
||||
let currentMode = 'agent';
|
||||
|
||||
function toggleModeDropdown() {
|
||||
const modeSelectEl = document.getElementById('modeSelect');
|
||||
const modelSelectEl = document.getElementById('modelSelect');
|
||||
if (modeSelectEl) {
|
||||
modeSelectEl.classList.toggle('active');
|
||||
if (modelSelectEl) {
|
||||
modelSelectEl.classList.remove('active');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function selectMode(value, label) {
|
||||
currentMode = value;
|
||||
const modeValue = document.getElementById('modeValue');
|
||||
const modeTooltip = document.getElementById('modeTooltip');
|
||||
if (modeValue) {
|
||||
modeValue.textContent = label;
|
||||
}
|
||||
if (modeTooltip) {
|
||||
const tooltipMap = {
|
||||
'plan': '只读模式 - 只能查询分析',
|
||||
'ask': '逐个确认 - 每个写操作需确认',
|
||||
'agent': '智能体自主模式',
|
||||
'auto': '完全自动 - 所有操作自动执行'
|
||||
};
|
||||
modeTooltip.textContent = tooltipMap[value] || '切换模式';
|
||||
}
|
||||
const options = document.querySelectorAll('.mode-option');
|
||||
options.forEach(option => {
|
||||
if (option.getAttribute('data-value') === value) {
|
||||
option.classList.add('selected');
|
||||
} else {
|
||||
option.classList.remove('selected');
|
||||
}
|
||||
});
|
||||
const modeSelectEl = document.getElementById('modeSelect');
|
||||
if (modeSelectEl) {
|
||||
modeSelectEl.classList.remove('active');
|
||||
}
|
||||
}
|
||||
|
||||
function getCurrentMode() {
|
||||
return currentMode;
|
||||
}
|
||||
|
||||
document.addEventListener('click', (event) => {
|
||||
const modeSelectEl = document.getElementById('modeSelect');
|
||||
if (modeSelectEl && !modeSelectEl.contains(event.target)) {
|
||||
modeSelectEl.classList.remove('active');
|
||||
}
|
||||
});
|
||||
// ========== 模式选择器脚本结束 ==========
|
||||
|
||||
function quickAction(type) {
|
||||
const questions = {
|
||||
counter: '生成一个4位同步计数器',
|
||||
@ -594,6 +650,27 @@ export function getWebviewContent(iconUri?: string): string {
|
||||
}
|
||||
break;
|
||||
|
||||
case 'switchMode':
|
||||
// 切换运行模式(Plan 确认后自动切换到 Agent)
|
||||
if (message.mode && typeof selectMode === 'function') {
|
||||
const labelMap = {
|
||||
'plan': 'Plan',
|
||||
'ask': 'Ask',
|
||||
'agent': 'Agent',
|
||||
'auto': 'Auto'
|
||||
};
|
||||
selectMode(message.mode, labelMap[message.mode] || message.mode);
|
||||
console.log('[WebView] 模式已切换到:', message.mode);
|
||||
}
|
||||
break;
|
||||
|
||||
case 'addMessage':
|
||||
// 添加消息(通用)
|
||||
if (message.text && message.sender) {
|
||||
addMessage(message.text, message.sender);
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
console.log('[WebView] 未处理的消息类型:', message.command);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user