"backend/internal/vscode:/vscode.git/clone" did not exist on "b8ada63ac3b75a506e11ce0d7a3eabb7d493130e"
  1. 15 Jan, 2026 13 commits
    • IanShaw027's avatar
      refactor(ops): 简化自动刷新定时器逻辑 · 8b95d162
      IanShaw027 authored
      - 合并双定时器为单一倒计时定时器
      - 倒计时归零时触发数据刷新
      - 添加自定义时间范围的安全回退
      8b95d162
    • IanShaw027's avatar
      refactor(ops): 优化文案显示 · a478822b
      IanShaw027 authored
      - TTFT 定义统一改为"首 Token"/"First Token"(而非"首字节"/"first byte")
      - 请求时长卡片标题去掉"(毫秒)"/"(ms)"后缀
      a478822b
    • IanShaw027's avatar
      refactor(ops): 优化任务心跳和组件刷新机制 · 23aa69f5
      IanShaw027 authored
      后端改动:
      - 添加 ops_job_heartbeats.last_result 字段记录任务执行结果
      - 优化告警评估器统计信息(规则数/事件数/邮件数)
      - 统一各定时任务的心跳记录格式
      
      前端改动:
      - 重构 OpsConcurrencyCard 使用父组件统一控制刷新节奏
      - 移除独立的 5 秒刷新定时器,改用 refreshToken 机制
      - 修复 TypeScript 类型错误
      23aa69f5
    • IanShaw027's avatar
      fix(ops): 请求时长详情显示所有请求 · e93f0864
      IanShaw027 authored
      - 移除请求时长卡片详情按钮的 min_duration_ms 参数限制
      - 现在点击详情会显示所有请求,按时长倒序排列
      - 不再只显示 P99 以上的请求
      e93f0864
    • IanShaw027's avatar
      feat(ops): 添加自定义时间范围选择功能 · 930e9ee5
      IanShaw027 authored
      功能特性:
      - 在时间段选择器中增加"自定义"选项
      - 点击后弹出对话框,支持选择任意时间范围
      - 使用 HTML5 datetime-local 输入框,体验友好
      - 自定义时显示格式化的时间范围标签(MM-DD HH:mm ~ MM-DD HH:mm)
      - 默认初始化为最近1小时
      
      技术实现:
      - 扩展 TimeRange 类型支持 'custom'
      - 添加 customStartTime 和 customEndTime 状态管理
      - 创建 buildApiParams 辅助函数统一处理 API 参数
      - 当选择自定义时,使用 start_time 和 end_time 参数替代 time_range
      - 更新所有相关 API 调用支持自定义时间范围
      
      国际化:
      - 添加"自定义"、"开始时间"、"结束时间"翻译
      930e9ee5
    • IanShaw027's avatar
      refactor(ops): 优化阈值检查系统和布局 · 38961ba1
      IanShaw027 authored
      阈值检查系统优化:
      - 引入三级阈值系统(normal/warning/critical)
      - 统一阈值判断逻辑,支持警告和严重两个级别
      - 移除硬编码的 TTFT 颜色判断,改用阈值配置
      - 新增 getThresholdColorClass 统一颜色映射
      
      布局优化:
      - 优化详细指标在卡片内的响应式布局
      - 改进宽屏下的卡片布局显示
      - 优化指标数值的对齐和间距
      38961ba1
    • yangjianbo's avatar
      fix(账号管理): 移除调度切换后的冗余列表刷新 · 1bb4c76d
      yangjianbo authored
      
      
      切换账号调度状态后,updateSchedulableInList 已完成局部更新,
      无需再调用 load() 刷新整个列表。此修改减少不必要的 API 请求,
      避免 UI 闪烁。
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      1bb4c76d
    • LLLLLLiulei's avatar
      feat: add proxy geo location · aab44f9f
      LLLLLLiulei authored
      aab44f9f
    • yangjianbo's avatar
      feat: merge dev · 90bce60b
      yangjianbo authored
      90bce60b
    • LLLLLLiulei's avatar
      Revert "feat: add proxy geo location" · 87b46629
      LLLLLLiulei authored
      This reverts commit 09c4f82927ddce1c9528c146a26457f53d02b034.
      87b46629
    • LLLLLLiulei's avatar
      feat: add proxy geo location · 3a100339
      LLLLLLiulei authored
      3a100339
    • IanShaw027's avatar
      fix(mobile): 修复 UsersView 更多菜单定位并统一逻辑 · 1d231c6c
      IanShaw027 authored
      **问题描述**:
      - UsersView 的"更多"菜单仍然出现在页面左上角错误位置
      - UsersView 使用 actionButtonRefs Map 获取按钮元素,导致定位失败
      - UsersView 和 AccountsView 的菜单定位逻辑不一致,难以维护
      
      **解决方案**:
      - 修改 openActionMenu 函数签名,添加 MouseEvent 参数
      - 使用 e.currentTarget 直接从事件对象获取触发元素
      - 移除不必要的 actionButtonRefs Map 和 setActionButtonRef 函数
      - 统一菜单宽度为 200px(与 AccountsView 一致)
      - 完全复制 AccountsView 的定位逻辑,确保两者行为一致
      
      **技术要点**:
      - 移动端:菜单居中对齐按钮,优先显示在按钮下方
      - 桌面端:使用鼠标位置定位,添加边界检测
      - 简化代码,移除不必要的防御性检查
      - 两个组件的菜单定位逻辑完全一致,便于维护
      1d231c6c
    • IanShaw027's avatar
      fix(mobile): 优化移动端表格、操作栏和弹窗显示 · 20c71acb
      IanShaw027 authored
      **问题描述**:
      - 表格在移动端显示列过多,需要横向滚动,内容被截断
      - 顶部操作栏按钮拥挤,占用过多空间
      - 弹窗表单在小屏幕上布局不合理
      - "更多"操作菜单定位错误,位置过高或超出屏幕
      - 滚动页面时菜单不会自动关闭,与卡片分离
      
      **解决方案**:
      
      1. **DataTable 组件 - 移动端卡片视图**
         - 在 < 768px 时自动切换到卡片布局
         - 每个表格行渲染为独立卡片,所有字段清晰可见
         - 操作按钮在卡片底部,触摸目标足够大
         - 支持深色模式,包含加载和空状态
         - 自动应用于所有使用 DataTable 的管理页面
      
      2. **UsersView 顶部操作栏优化**
         - 移动端:搜索框全宽 + 次要按钮显示为图标 + 创建按钮突出
         - 桌面端:保持原有布局(图标 + 文字)
         - 使用响应式 Tailwind classes
      
      3. **UserCreateModal 弹窗优化**
         - 余额/并发数字段:移动端单列,桌面端双列
         - 弹窗边距:移动端 8px,桌面端 16px
      
      4. **操作菜单定位修复**
         - UsersView: 移动端菜单居中对齐按钮,智能定位
         - AccountsView: 移动端菜单优先显示在按钮下方
         - 所有情况下确保菜单不超出屏幕边界
         - 添加滚动监听,滚动时自动关闭菜单
      
      **影响范围**:
      - 所有使用 DataTable 的管理页面(8 个页面)自动获得移动端卡片视图
      - 用户管理和账号管理页面的操作菜单定位优化
      - 创建用户弹窗的响应式布局优化
      
      **技术要点**:
      - 使用 Tailwind 响应式断点(md:, sm:)
      - 触摸目标 ≥ 44px
      - 完整支持深色模式
      - 向后兼容,桌面端保持原有布局
      20c71acb
  2. 14 Jan, 2026 22 commits
  3. 13 Jan, 2026 1 commit
  4. 12 Jan, 2026 4 commits
    • ianshaw's avatar
      docs(frontend): 完善 OpenCode 配置说明 · ea699cbd
      ianshaw authored
      更新 API 密钥页面 OpenCode 配置提示信息:
      - 补充支持 opencode.jsonc 后缀名
      - 说明可使用默认 provider(openai/anthropic/google)或自定义 provider_id
      - 说明 API Key 支持直接配置或通过 /connect 命令配置
      - 保留"示例仅供参考,模型与选项可按需调整"的提示
      
      配置文件路径:~/.config/opencode/opencode.json(或 opencode.jsonc)
      ea699cbd
    • ianshaw's avatar
      fix(frontend): 同步 OpenAI GPT-5 系列模型列表 · fe8198c8
      ianshaw authored
      修复编辑账号页面 GPT-5 模型只显示 3 个的问题:
      - 原来只有: gpt-5, gpt-5-mini, gpt-5-nano
      - 现在添加完整的 22 个模型,包括:
        * GPT-5 系列: gpt-5, gpt-5-codex, gpt-5-chat, gpt-5-pro, gpt-5-mini, gpt-5-nano 及各时间戳版本
        * GPT-5.1 系列: gpt-5.1, gpt-5.1-codex, gpt-5.1-codex-max, gpt-5.1-codex-mini 及各版本
        * GPT-5.2 系列: gpt-5.2, gpt-5.2-codex, gpt-5.2-pro 及各版本
      - 更新快捷预设按钮,新增 GPT-5.1, GPT-5.2, GPT-5.1 Codex 选项
      
      与后端定价文件 (model_prices_and_context_window.json) 保持一致。
      
      Fixes issue introduced in fb86002e (feat: 添加模型白名单选择器组件)
      Related-to: fb86002e
      fe8198c8
    • cyhhao's avatar
      67acac10
    • Edric Li's avatar
      style: 优化滚动条自动隐藏效果 · d02e1db0
      Edric Li authored
      - 默认隐藏滚动条,悬停时显示
      - 支持 Webkit (Chrome/Safari/Edge) 和 Firefox
      - 滚动条样式与暗色主题适配
      d02e1db0