Back to Qwen Code

@qwen-code/web-shell

packages/web-shell/README.md

0.18.010.5 KB
Original Source

@qwen-code/web-shell

Qwen Code Web Shell 是面向浏览器的 daemon 会话终端 UI,可以作为 React 组件嵌入到其他项目中。

环境要求

  • React:^18.0.0 || ^19.0.0
  • React DOM:^18.0.0 || ^19.0.0
  • @qwen-code/webui>=0.0.1
  • @qwen-code/sdk>=0.1.8
  • 浏览器环境需要能访问 Qwen Code daemon serve 的 HTTP 接口。

组件包会自动注入自身样式,样式已通过 CSS Modules 和组件作用域隔离; 接入方不需要额外引入全局 CSS。

安装

bash
npm install @qwen-code/web-shell

Peer dependencies 需要同时安装:

bash
npm install react react-dom @qwen-code/webui @qwen-code/sdk

接入方式

WebShell 提供两种接入形态:

1. 独立接入(自带 Provider)

适合只需要嵌入一个终端视图的场景。组件内部自建 DaemonWorkspaceProvider + DaemonSessionProvider

tsx
import { WebShellWithProviders } from '@qwen-code/web-shell';

export function QwenCodePanel() {
  return (
    <WebShellWithProviders
      baseUrl="http://127.0.0.1:4170"
      token="your-bearer-token"
      initialSessionId="838e1811-9f84-4848-9915-d9a7f01ff5c6"
      onSessionIdChange={(sessionId) => {
        console.log('current session:', sessionId);
      }}
      theme="dark"
      language="zh-CN"
    />
  );
}

2. 共享 Provider 接入(纯消费者)

适合同一个 React 应用中多个视图共享同一个 daemon session 的场景(如 chat + terminal)。宿主自行提供 Provider,WebShell 只消费 hooks。

tsx
import {
  DaemonWorkspaceProvider,
  DaemonSessionProvider,
} from '@qwen-code/webui/daemon-react-sdk';
import { WebShell } from '@qwen-code/web-shell';

export function App() {
  return (
    <DaemonWorkspaceProvider baseUrl="http://127.0.0.1:4170" token="...">
      <DaemonSessionProvider initialSessionId="...">
        <ChatPanel />
        <WebShell theme="dark" language="zh-CN" />
      </DaemonSessionProvider>
    </DaemonWorkspaceProvider>
  );
}

注意:不要在已有 DaemonSessionProvider 下使用 WebShellWithProviders,否则会创建嵌套的重复 Provider。

Props

WebShellWithProviders

包含 WebShell 的所有 Props,加上 Provider 配置:

属性类型说明
baseUrlstringdaemon API 地址,未传时使用 window.location.origin
tokenstringdaemon API Bearer token
initialSessionIdstring初始要连接的 session id

WebShell

属性类型说明
onSessionIdChange(sessionId: string) => void当前 session id 变化时触发
theme'dark' | 'light'UI 主题,默认 dark
onThemeChange(theme: WebShellTheme) => void/theme 命令切换主题后触发
language'en' | 'zh-CN' | 'zh' | 'zh-cn'UI 语言
onLanguageChange(language: WebShellLanguage) => void/language ui 切换 UI 语言后触发

架构说明

text
@qwen-code/sdk/daemon         ← 协议层(SSE, REST, normalizer)
@qwen-code/webui/daemon-react-sdk  ← React adapter(Provider, hooks, store)
@qwen-code/web-shell          ← 终端 UI 组件
  • WebShell 必须在 DaemonWorkspaceProviderDaemonSessionProvider 之下使用。
  • WebShellWithProviders 是内置 Provider 的便捷 wrapper。
  • 同一个 React 树共享一个 DaemonSessionProvider 时只开一条 SSE。

已支持的斜杠命令

下面列出当前 web-shell 已支持的命令。支持方式分为两类:

  • 本地实现:web-shell 前端直接打开弹窗、调用 daemon REST API,或切换本地状态。
  • ACP 透传:web-shell 将命令发送给 daemon,由 daemon/ACP 执行。
命令支持方式说明
/help本地实现打开帮助弹窗,支持键盘浏览命令和快捷键。
/theme本地实现打开主题选择弹窗;支持 /theme light/theme dark
/language本地实现 + ACP 透传/language ui <lang> 会切换 web-shell UI 语言并同步给 daemon;其他语言能力由 daemon 执行。包含 uioutput 子命令。
/model本地实现 + 部分透传无参数打开模型弹窗;普通参数直接切换模型;/model --fast <model> 透传给 daemon。
/plan本地实现切换到 plan approval mode,并可继续发送后续 prompt。
/approval-mode本地实现打开审批模式弹窗或直接切换审批模式。
/mode本地实现web-shell 本地别名,用于切换审批模式。
/mcp本地实现打开 MCP 管理弹窗。
/skills本地实现 + ACP 透传无参数打开 skills 弹窗;带参数时透传给 daemon 执行。
/tools本地实现打开 tools 弹窗,列表展示工具名称、启用状态和 description
/memory本地实现打开 memory 弹窗,支持 showrefreshadd useradd project 等分支。
/agents本地实现打开 agents 弹窗,支持 managecreate usercreate project 等分支。
/copy本地实现复制最后一条 assistant 输出;支持 code、语言名、LaTeX、inline LaTeX 等选择器。
/release本地实现释放 live session 连接,不删除历史会话记录。
/clear本地实现清空当前 web-shell transcript store。
/new本地实现创建新的 daemon session。
/reset本地实现/new 一样创建新的 daemon session。
/rename <name>本地实现修改当前 daemon session 的展示名称。
/resume本地实现无参数打开恢复会话弹窗;带 session id 时直接加载。
/statusACP 透传daemon 支持,包含 paths 子命令。
/authACP 透传连接 LLM provider。
/bugACP 透传提交错误报告。
/compressACP 透传通过摘要替换来压缩上下文。
/contextACP 透传显示上下文窗口使用情况,包含 detail 子命令。
/diffACP 透传显示工作区相对 HEAD 的变更统计。
/docsACP 透传打开 Qwen Code 文档。
/doctorACP 透传执行安装与环境诊断,包含 memory 子命令。
/exportACP 透传导出当前会话记录,包含 htmlmdjsonjsonl 子命令。
/goalACP 透传设置目标,并持续工作直到条件满足。
/initACP 透传分析项目并创建定制的 QWEN.md
/statsACP 透传显示统计信息,包含 modeltools 子命令。
/summaryACP 透传生成当前会话摘要。
/tasksACP 透传列出后台任务。
/insightACP 透传查看 insight 相关信息。