11 KiB
| title | created | updated | type | tags | sources | ||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 前端架构 | 2026-04-13 | 2026-05-15 | concept |
|
|
前端架构
前端基于 Vue 3 + Vite + Element Plus + Cool Admin。Agent 模块在近期重构后,重点从“普通聊天页面”升级为“Session Tree 快照消费 + 工具治理 projection + 子 Agent runtime 可视化”的管理和运行界面。
模块结构
业务模块仍遵循 Cool Admin 的模块化结构:
modules/{name}/
config.ts
views/
components/
store/
hooks/
types/
static/
Agent 相关代码集中在 packages/frontend/src/modules/agent/。
Agent Chat Store
modules/agent/store/chat.ts 是对话页状态核心。当前它不再只维护线性 message 数组,而是消费 session-tree-runtime 的 snapshot:
sessionMeta: 当前 session 元信息。entries: session tree 节点列表。entryById: 节点索引。childrenByParentId: 父子索引。activePathIds: 当前活动路径。visibleEntries: 对话 UI 可展示节点。subagentRuntimeByBatchId: 子 Agent 批次运行状态。toolRuntimeRoutesByBatchId: 子 Agent 工具路由状态。selectedEntryId: 当前树面板选中的节点。switchingLeafEntryId: 正在切换为 leaf 的目标节点。pendingLeafConfirmation: 已选中但尚未真正切换的继续发送目标。subagentEvidenceSummariesByEntryId、subagentProcessEventsByEntryId、subagentTaskPanelsByEntryId、subagentProjectionDiagnosticsByEntryId: 统一消费后端subagentProjection后得到的展示态索引。- 删除会话时,前端会优先从会话列表中取该会话自己的
agentId,再调用/open/netaclaw/session/delete,避免 MySQL session-tree 会话因当前选中 Agent 不一致而走错 provider。
localStorage 只保存:
neta:agent-chat:last-tree-sessionneta:agent-chat:last-agent
它不是完整历史存储。刷新后历史恢复依赖后端 session tree snapshot。
Agent 对话页
views/chat.vue 的职责:
- 加载或恢复最近 Agent/session。
- 渲染普通消息、压缩摘要、分支摘要、自定义消息、子 Agent 批次和结果。
- 展示 token/thinking/tool 调用过程。
- 保证长对话区域可滚动,避免消息增多后底部不可见。
- 消费后端工具路由和 blocked reason,而不是在前端重新推导。
- 提供会话树节点选择、continue-from-entry、分支继续发送和 pending guard 交互。
- 对
subagent_result节点优先渲染后端生成的 task panel、tool execution、evidence card、process timeline 和 projection diagnostics。 - 对
subagent_batch节点只展示批次运行态和工具路由概览,不把它当作唯一回放来源。 - 流式工具卡片会保留工具参数和结构化
rawResult,例如 bash 工具会把命令展示在执行卡片里,流结束后仍能从skillExecutionsmetadata 恢复。 - 当后端推送
tool_confirmation_request时,ChatComposer.vue会把输入区临时切换为工具确认 UI,显示工具名、命令/参数和风险原因;用户点击允许或拒绝后发送tool_confirmation_response。这条链路主要保护 bash 删除、强制 git、数据库清空等高风险操作。
工具执行过程中的乱码问题通常来自命令执行 shell/编码和后端 stderr/stdout 处理;前端应只负责正确展示 UTF-8 文本和结构化结果。
工具管理页
views/tools.vue 面向全局 tool-governance:
- 查看工具 catalog 和 DB 同步结果。
- 调整全局启停、核心工具、是否可关闭、Prompt Hint、排序。
- 展示
effectiveRuntimeProfile、worker routing、blocked reason。 - 页面必须有可滚动容器,工具数量增加后不能裁掉底部内容。
记忆管理页
views/memory.vue 面向 memory-system:
- 左侧按 Agent 统计记忆数量,并标识 MySQL/SQLite 后端。
- 右侧支持 Agent、类型、关键词筛选和分页。
- 新增/编辑记忆时可写入 JSON metadata,编辑提交带
updatedAt乐观锁。 - 类型管理弹窗读取
memory_type服务,系统内置类型不可删除。 - Agent 下拉使用
agent/page返回的 label,避免展示内部 name。
Agent 编辑页
views/agent-edit.vue 面向单个 Agent 配置:
- 配置模型、Prompt、上下文压缩、辅助模型。
- 配置工具局部启停。
- 配置子 Agent 开关、并发、可用预设 Agent、可用工具。
- 展示后端 projection 中的 effective runtime profile 和 effective subagent allowed。
- 保存本地存储/workspace/shell/readonly 等配置时,应影响 tool-runtime-policy 推导。
Agent 编辑页不能只接入 i18n;核心是把后端新的工具治理和子 Agent 策略完整接进配置面。
Skill 管理页
views/skills.vue 和 components/skill-detail.vue 已从简单列表升级为 skill-runtime 的管理入口:
- Skill 卡片展示
classification:prompt、compute-entry、compute-toolkit。 - 顶部加载
/admin/netaclaw/skill/diagnostics,按 error / warning 显示诊断横幅。 - 详情抽屉分为“基本信息 / 配置 / 诊断”。
- “配置”页读取
/admin/netaclaw/skill/envSchema,保存时调用/admin/netaclaw/skill/secrets,只提交用户填写的新 secret。 - 安装 GitHub skill 后,如果元数据声明 setup 脚本,前端会弹窗确认后再调用
installDeps。
这意味着 Skill 页不再只是安装器 UI,也承担 compute skill 的运行前配置和健康检查职责。
数据源管理页
packages/frontend/src/modules/base/views/data-source.vue 是 mysql-data-source 的后台配置入口,挂在“系统管理 -> 数据源管理”。页面通过 /admin/netaclaw/data-source/list|save|delete|test 管理 MySQL 数据源。
页面职责包括:
- 配置 host/IP、端口、数据库、用户名、密码、SSL、连接超时和连接池上限。
- 端口使用普通输入框并校验 1-65535,避免
el-input-number的步进控件和位数限制影响 MySQL 端口录入。 - 配置授权 Agent、表白名单、表黑名单、脱敏列、schema 可见性、最大返回行数、最大 JOIN 表数和查询超时。
- “测试连接”只把配置提交给后端测试,不在前端暴露密钥解密逻辑;密码展示使用
hasPassword投影。
该页面依赖 base-module 的动态菜单路由。现有库如果没有“数据源管理”菜单,需要由后端启动同步 base/menu.json 与 base/event/menu.ts,而不是在 modules/base/config.ts 再加静态路由。
频道管理页
views/channel-management.vue 在 2026-05-14 后承担两类微信渠道配置:
weixin:ClawBot 私聊助手,仍保留扫码登录、重连、断开和清空会话。weixin-db:本地 PC 微信数据库代理,要求 Windows + 已登录 PC 微信,表单要求填写wxid并做同 wxid 唯一性校验。
weixin-db 表单新增“微信自动回复(v4 桌面操作)”区块:
weixinReply.enabled控制是否启用双 Agent 自动回复。desktopAgentId选择桌面操作 Agent;前端显示所有 Agent,后端保存时自动补齐weixin_desktoptoolset 和weixin_send_text路由。- 可配置每群每分钟、每天上限、小号安全模式和水印策略。
- 频道卡片展示群聊启用数、微信版本、wxid 和连接状态。
components/channel-group-panel.vue 管理 channel 下群白名单、每群绑定 Agent 和每群回复身份。weixin-db 频道编辑页不再配置频道级默认 Agent、机器人别名或默认回复身份;每个群必须独立指定 reply agent 和回复身份。前端不直接处理本机微信数据库,消息读取、白名单缓存和自动发送都在 agent-channel 与 desktop-op-module 后端侧完成。
工具渲染
工具调用展示通过 tools/renderer-registry.ts 收敛,不建议在 chat 页面散落大量工具名判断。运行时策略文案通过 tools/runtime-policy.ts 收敛,保持与后端 projection 一致。
2026-05-07 后,长耗时工具和 compute-entry Skill 的 runtime-process-events 由 tool-process-timeline.vue 和 tool-process-display.ts 展示,可从实时事件或历史 metadata 恢复。例如 vehicle-damage-skill 的抽帧、检测、定位和复核阶段不再只能等待最终 JSON。
Geo 前端模块
packages/frontend/src/modules/geo/ 是新增的 geo-module 前端入口:
accounts.vue:账号列表、平台选择、绑定 Agent/IP、启动浏览器、抓取 cookie、重置会话和切换 IP。proxies.vue:代理 IP 管理、绑定状态、区域/城市/套餐和健康信息。dashboard.vue:Geo 模块概览入口。
该模块不是 Agent 对话页的一部分,但会通过账号的 agentId、sessionName 和 cookie/profile 生命周期与 netabrowser-runtime、Agent 自动化任务发生关系。
对子 Agent 可视化还有一个新的边界约束:
- 前端
store/subagent_projection.ts仍保留 legacy fallback 解析逻辑,但这是为了兼容历史数据。 - 当前实现的主路径是后端在
session-tree/subagent_projection.ts生成 canonical projection,前端只做提取、排序、折叠和交互展示。 - 如果某次会话页面展示异常,应先排查后端 projection 是否缺失或
fallbackUsed是否异常,而不是优先怀疑 Vue 组件渲染层。
这套结构使新增工具时需要同步考虑:
- 后端工具实现。
- catalog/governance/manifest。
- resolver projection。
- 前端工具管理页。
- Agent 编辑页。
- 对话页渲染。