Commit Graph

84 Commits

Author SHA1 Message Date
zdl
7e1920e475 feat: bug修复 2025-12-26 18:45:32 +08:00
zdl
3c47fb5176 refactor(glass): 批次1 - 迁移全局组件使用统一毛玻璃配置
迁移以下 10 个组件使用 glassConfig.ts 统一配置:
- GlassCard: GLASS_BLUR/GLASS_SHADOW 替换硬编码 blur/glow
- SubTabContainer: GLASS_BLUR.lg 替换 blur(20px)
- HomeNavbar: GLASS_BLUR.sm 替换 blur(10px)
- AuthModalManager: GLASS_BLUR.sm 替换 blur(10px)
- WechatRegister: GLASS_BLUR.xs 替换 blur(4px)
- SubscriptionModal: GLASS_BLUR.xs 替换 blur(4px)
- SubscriptionContentNew: GLASS_BLUR.sm/lg/xl 替换多处硬编码
- ImageLightbox: GLASS_BLUR.sm 替换 blur(10px)
- ImagePreviewModal: GLASS_BLUR.sm 替换 blur(10px)
- FuiContainer: GLASS_BLUR.md 替换 blur(16px)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-25 16:18:55 +08:00
zdl
f3d060d2da perf(Navbar): 移除自选股/事件按钮,清理无用代码
NavbarActions:
- 移除 WatchlistMenu 和 FollowingEventsMenu 组件
- 移除 watchlistQuotes/followingEvents props

HomeNavbar:
- 移除 useWatchlist/useFollowingEvents hooks 调用
- 移除相关导入和 props 传递

TabletUserMenu:
- 移除 watchlistQuotes/followingEvents props
- 简化菜单项(移除数量 Badge)

性能提升:
- 减少 2 个 hook 初始化和 4+ 个 Redux selector 订阅
- 减少导航栏初始化时的 API 请求
- 侧边工具栏不受影响(有独立的 GlobalSidebarContext)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-25 14:02:30 +08:00
zdl
c323fd9812 refactor(layout): 统一 z-index 配置
- layoutConfig.js: 添加 Z_INDEX.FOOTER (1000,与 NAVBAR 同级)
- HomeNavbar.js: zIndex 从硬编码 1000 改为 Z_INDEX.NAVBAR
- AppFooter.js: 添加 zIndex={Z_INDEX.FOOTER}

导航栏和页脚的 z-index 现在统一在 layoutConfig.js 中配置。

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-25 13:01:49 +08:00
zdl
f01c106241 refactor(layout): 统一布局边距配置,改用百分比
- layoutConfig.js: LAYOUT_PADDING.x 改为 { base: 4, md: 6, lg: '12%' }
- HomeNavbar.js: 导入 LAYOUT_PADDING,替换硬编码边距
- AppFooter.js: 导入 LAYOUT_PADDING,替换硬编码边距

现在导航栏、内容区、页脚统一使用 LAYOUT_PADDING.x 配置,
修改边距只需调整 layoutConfig.js 一处即可全局生效。

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-25 13:00:41 +08:00
zdl
6f5c6c933e refactor(icons): 迁移 components 目录图标到 lucide-react
- @chakra-ui/icons → lucide-react
- react-icons → lucide-react
- 涉及 49 个组件文件

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-25 13:00:40 +08:00
zdl
d10a8c3321 refactor(layout): 统一页面边距管理,移除 Container 限制
- layoutConfig.js: 新增 LAYOUT_PADDING 常量 { base: 4, md: 6, lg: '80px' }
- MainLayout.js: 在 Outlet 容器上统一应用 px={LAYOUT_PADDING.x}
- HomeNavbar.js: 边距从 lg:8 改为 lg:'80px',与内容区对齐
- AppFooter.js: 移除 Container,边距改为 lg:'80px'

页面组件清理(移除冗余的 px/Container):
- Company, Community, Center, Profile, Settings
- ValueForum, DataBrowser, LimitAnalyse, StockOverview, Concept

特殊处理:
- CompanyHeader: 使用负边距实现全宽背景
- Concept Hero: 使用负边距实现全宽背景

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-24 18:34:42 +08:00
zdl
6461ea2ac7 feat(WatchSidebar): 面板 UI 优化,添加日均周涨展示
- WatchlistPanel: 添加 hideTitle 支持,新增日均/周涨 Badge 展示
- FollowingEventsPanel: 添加 hideTitle 支持,兼容 related_avg_chg 字段
- FollowingEventsMenu: 使用 FavoriteButton 替代文字按钮
- 统一卡片样式,与关注事件面板保持一致

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-23 20:17:57 +08:00
zdl
87e666df64 refactor(watchlist): 自选股数据源统一到 Redux
- stockSlice: 新增 loadWatchlistQuotes thunk 加载自选股行情
- useWatchlist: 改用 Redux selector 获取自选股数据
- WatchlistMenu: 使用 Redux 数据源,移除本地状态管理

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-23 20:17:57 +08:00
9fab36ddc0 更新Company页面的UI为FUI风格 2025-12-18 00:24:11 +08:00
85fa2b6210 更新Company页面的UI为FUI风格 2025-12-18 00:05:55 +08:00
dbd08283f5 update watchlist 2025-12-16 15:03:35 +08:00
0aa22822ea update watchlist 2025-12-16 14:48:40 +08:00
zdl
d9cdc6500d feat(Navbar): 订阅提示文案可点击跳转
- "点击管理订阅"文字改为可点击链接,直接跳转订阅页面
- 文案简化:移除"头像"二字
- 链接样式:蓝色文字 + 悬停下划线

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-15 17:21:53 +08:00
zdl
13620c514b fix(Navbar): 优化用户头像悬停交互和订阅信息显示
- 将 Tooltip 改为 Popover 组件,支持鼠标悬停到弹出内容上
- 用户现在可以正常悬停到"点击头像管理订阅"提示
- 订阅信息新增到期日期显示,用户无需自己计算到期时间

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-15 17:21:53 +08:00
zdl
b8347ae72a fix: 前端兼容 phone 字段可能为非字符串的情况
- 在所有显示 user.phone 的地方添加类型检查
- 使用 typeof user.phone === 'string' && user.phone 确保只有字符串才显示
- 修复微信登录后 phone 为对象时显示 [object Object] 的问题

涉及文件:
- TabletUserMenu.js
- MobileDrawer.js
- UserAvatar.js
- PersonalCenterMenu.js

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-15 14:10:44 +08:00
8171136103 update pay ui 2025-12-12 10:56:18 +08:00
830a0ba233 update pay ui 2025-12-12 00:02:55 +08:00
7ee7a4fefe update pay ui 2025-12-10 14:49:37 +08:00
zdl
2c4f01a4b5 refactor: 重构 Community 目录,将公共组件迁移到 src/components/
- 迁移 klineDataCache.js 到 src/utils/stock/(被 StockChart 使用)
- 迁移 InvestmentCalendar 到 src/components/InvestmentCalendar/(被 Navbar、Dashboard 使用)
- 迁移 DynamicNewsDetail 到 src/components/EventDetailPanel/(被 EventDetail 使用)
- 更新所有相关导入路径,使用路径别名
- 保持 Community 目录其余结构不变

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-08 12:09:24 +08:00
zdl
d5d213db8c feat: 事件详情页 URL ID 加密,防止用户遍历
- 新增 idEncoder.ts 工具:使用 Base64 + 前缀混淆加密 ID
- 路由改为查询参数形式:/event-detail?id=xxx
- 更新所有入口使用 getEventDetailUrl() 生成加密链接
- 兼容旧链接:纯数字 ID 仍可正常访问

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-04 18:26:01 +08:00
zdl
102ba36c97 fix: 在 viewport meta 标签中添加了 viewport-fit=cover,这样浏览器会将页面内容延伸到曲面屏边缘,同时启用 safe-area-inset-* CSS 环境变量
在普通设备上保持至少 16px 的右侧内边距
在华为 MATE70 PRO 等曲面屏设备上,使用系统提供的安全区域值,避免右侧导航被遮挡
2025-12-04 14:53:17 +08:00
zdl
cc8643ba33 fix: 导航效果UI修复 2025-12-04 11:52:44 +08:00
a3a2960297 update pay ui 2025-12-02 10:33:55 +08:00
zdl
387fa95a3c fix: 移动端抽屉菜单不再显示深色模式切换按钮 2025-11-26 15:47:26 +08:00
zdl
2fd0c55fbc pref: 导航选中高亮 2025-11-26 14:01:58 +08:00
zdl
c6578d3cc5 pref: 权限校验中 - 显示占位骨架,不显示登录按钮或用户菜单,/home页面添加骨架屏逻辑 2025-11-26 09:57:20 +08:00
zdl
58d481d7d8 feat: bug修复 2025-11-24 16:38:33 +08:00
zdl
0eedf306f4 Merge branch 'feature_2025/251117_pref' into feature_2025/251121_h5UI
* feature_2025/251117_pref: (159 commits)
  feat: UI调整
  feat: 将滚动事件移东到组件内部
  feat: 去掉背景组件
  feat: 拆分左侧栏、中间聊天区、右侧栏组件, Hooks 提取
  feat: 简化主组件 index.js - 使用组件组合方式重构
  feat: 创建 ChatArea 组件(含 MessageRenderer、ExecutionStepsDisplay 子组件)
  feat:拆分工具函数
  feat: 拆分BackgroundEffects 背景渐变装饰层
  feat: RightSidebar (~420 行) - 模型/工具/统计 Tab 面板(单文件)
  feat:  LeftSidebar (~280 行) - 对话历史列表 + 用户信息卡片
  feat: 修复bug
  pref:移除黑夜模式
  feat: 修复警告
  feat: 提取常量配置
  feat: 修复ts报错
  feat:  StockChartModal.tsx 替换 KLine 实现
  update pay function
  update pay function
  update pay function
  update pay function
  ...
2025-11-24 16:32:24 +08:00
zdl
21aa62b979 pref:移除黑夜模式 2025-11-24 15:07:13 +08:00
136cb2961b update pay function 2025-11-23 08:24:30 +08:00
43446f8034 update pay function 2025-11-22 08:57:37 +08:00
295f179147 update pay function 2025-11-22 07:24:55 +08:00
zdl
3e5cc1ef0d Merge branch 'feature_2025/251117_pref' into feature_2025/251121_h5UI
* feature_2025/251117_pref:
  update pay function
  update pay function
  update pay function
  update pay function
  update pay function
  update pay function
  update pay function
2025-11-21 18:30:51 +08:00
zdl
356675b17e fix: 修复的问题:H5 汉堡菜单位置调整(移到头像右侧)
平板端显示 MoreMenu 而非汉堡菜单
未登录时不显示汉堡菜单
2025-11-21 17:59:03 +08:00
fbdf877722 update pay function 2025-11-21 14:07:18 +08:00
zdl
03ad954bf6 feat: 桌面端导航判断调整 2025-11-21 14:07:04 +08:00
zdl
f71c98b68a fix:优化h5/菜单UI 2025-11-21 13:55:06 +08:00
0ae5618ef9 add forum 2025-11-15 09:10:26 +08:00
99bb51e526 agent功能开发增加MCP后端 2025-11-07 18:11:29 +08:00
zdl
6c20f201da feat: 导航栏关注事件弹窗增强显示信息
- 添加热度显示(🔥 图标 + 分数)
  - ≥80 红色,≥60 橙色,<60 灰色
- 添加关注数显示(👥 图标 + 人数)
- 保留原有涨跌幅显示(日均、周涨)
- mock 数据补充涨跌幅字段(related_avg_chg, related_max_chg, related_week_chg)
- 智能显示:字段存在时才显示对应 Badge
- 优化 Badge 间距和布局

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-05 11:05:32 +08:00
zdl
8a5241cc31 feat: bugfix 2025-11-03 19:45:32 +08:00
zdl
f5ade90d0f feat: 新增实时要闻·动态追踪与市场复盘功能,优化导航体验
新增功能:
- 实时要闻·动态追踪横向滚动卡片(DynamicNewsCard)
- 动态新闻事件卡片组件(DynamicNewsEventCard)
- 市场复盘卡片组件(MarketReviewCard)
- 股票涨跌幅指标组件(StockChangeIndicators)
- 交易时间工具函数(tradingTimeUtils)
- Mock API 支持动态新闻数据生成

UI 优化:
- EventFollowButton 改用 react-icons 星星图标,实现真正的空心/实心效果
- 关注按钮添加半透明白色背景(whiteAlpha.500),悬停效果更明显
- 事件卡片标题添加右侧留白,防止关注按钮遮挡文字

性能优化:
- 禁用 Router v7_startTransition 特性,解决路由切换延迟 2 秒问题
- 调整导航菜单点击顺序(先跳转后关闭),提升响应速度

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-31 14:11:03 +08:00
zdl
80f9376cc6 feat: bugfix 2025-10-31 10:33:53 +08:00
zdl
2eb260edd7 fix: 修复导航菜单 hover 触发实现方式
修复之前提交(47f84c5)中使用的无效 trigger="hover" 属性。
Chakra UI Menu 组件不支持 trigger 属性,改用正确的实现方式:

**实现方式:**
- 使用 useDisclosure Hook 管理菜单开关状态
- 为 MenuButton 和 MenuList 添加 onMouseEnter/onMouseLeave 事件
- 这样可以确保鼠标从按钮移到菜单列表时保持打开状态

**修改的组件:**
- DesktopNav.js: 为4个菜单添加独立的 useDisclosure Hook
- MoreMenu.js: 平板版"更多"菜单
- PersonalCenterMenu.js: 个人中心菜单

**技术要点:**
- MenuButton 和 MenuList 都需要 hover 事件处理
- 每个菜单使用独立的 useDisclosure 实例
- 符合 Chakra UI 官方推荐的 hover 菜单实现方式

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-30 19:06:21 +08:00
zdl
63e26db44e feat: 导航菜单改为 hover 触发
为所有导航菜单组件添加 trigger="hover" 属性,使菜单在鼠标悬停时自动展开,提升用户体验。

修改的组件:
- DesktopNav.js: 4 个主导航菜单(高频跟踪、行情复盘、AGENT社群、联系我们)
- MoreMenu.js: 平板版"更多"下拉菜单
- PersonalCenterMenu.js: 个人中心下拉菜单

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-30 18:49:14 +08:00
zdl
1d6f27a4d2 fix(UserMenu): 修复 Phase 3 重构引入的头像 UI 问题
**问题描述**
Phase 3 重构提取用户菜单组件时,引入了多个 UI 和交互问题:
1.  皇冠 UI 改变:右上角 FaCrown → 左上角 Emoji
2.  Hover 效果消失:平板版头像无 hover
3.  Tooltip 内容丢失:简化版内容 → 原始丰富内容
4.  Tooltip 不显示:Chakra UI ref 传递问题
5. ⚠️ React 警告:forwardRef 缺失

**修复内容**

### 1. UserAvatar.js (101行 → 76行, -25行)

**恢复原始皇冠设计**:
- 删除自定义 CrownIcon(FaCrown + 渐变背景)
- 改用 CrownTooltip.js 原始实现(👑/💎 Emoji)
- 位置:右上角 → 左上角
- 交互:无 → 有 scale(1.2) hover

**修复 Hover 效果**:
```diff
- _hover={onClick ? { ...defaultHoverStyle, ...hoverStyle } : undefined}
+ _hover={{ ...defaultHoverStyle, ...hoverStyle }}
```
- 移除 onClick 依赖,头像始终可交互

**添加 forwardRef**:
```diff
- const UserAvatar = memo(({ user, subscriptionInfo, ... }) => {
+ const UserAvatar = forwardRef(({ user, subscriptionInfo, ... }, ref) => {
+     return <Box ref={ref} ...>
```
- 支持 Tooltip 和 MenuButton 传递 ref
- 消除 React 控制台警告

### 2. DesktopUserMenu.js (93行 → 65行, -28行)

**恢复原始 TooltipContent**:
```diff
- const TooltipContent = memo(({ subscriptionInfo }) => {
-     return getSubscriptionBadgeText(); // 纯文本
- });
+ import { TooltipContent } from '../../../Subscription/CrownTooltip';
```
- 恢复丰富 UI:VStack + Divider + 状态图标 + 剩余天数
- 支持紧急提醒(< 7天)和警告(< 30天)

**修复 Tooltip 显示**:
```diff
  <Tooltip ...>
+     <span>
          <UserAvatar ... />
+     </span>
  </Tooltip>
```
- 添加 span 包裹层确保 ref 和事件正确传递
- Chakra UI 官方推荐做法

**修复验证**
-  桌面版:皇冠在左上角(👑/💎),Tooltip 显示丰富内容
-  平板版:头像有 hover 效果,下拉菜单正常
-  控制台:无 forwardRef 警告

**测试场景**
1. 免费用户:无皇冠,Tooltip 显示升级提示
2. Pro/Max 用户:显示皇冠,Tooltip 显示剩余天数
3. < 7天到期:红色紧急提示
4. 已过期:显示续费提示

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-30 18:27:55 +08:00
zdl
9011eaa61a fix: 修复 FeatureMenus 中的按钮嵌套警告
修复 React DOM 嵌套警告:<button> 不能作为 <button> 的后代

**问题描述**
- MenuItem 组件渲染为 <button> 元素
- 在 MenuItem 内使用 Button 组件会导致 button-in-button 嵌套警告

**修复内容**
1. FollowingEventsMenu.js (lines 134-150)
   - 将"取消"按钮从 Button 组件改为 Box 组件
   - 使用 Box + 样式模拟按钮外观和交互

2. WatchlistMenu.js (lines 116-132)
   - 同样将"取消"按钮改为 Box 组件
   - 保持一致的样式和交互行为

**技术方案**
- Box as="span" 渲染为行内元素
- 通过 cursor="pointer" + _hover 实现按钮交互
- 通过 color + borderRadius 实现按钮视觉效果

**测试**
-  控制台无 DOM 嵌套警告
-  点击"取消"功能正常
-  悬停效果正常显示
2025-10-30 18:14:10 +08:00
zdl
3b37978736 refactor(HomeNavbar): Phase 7 - 最终组件化优化
Phase 7 重构完成,实现 HomeNavbar 的最终优化:

新增文件:
- src/components/Navbars/components/SecondaryNav/config.js (111行)
  * 二级导航配置数据
  * 统一管理所有二级菜单结构
- src/components/Navbars/components/SecondaryNav/index.js (138行)
  * 二级导航栏组件
  * 支持动态路由匹配、徽章显示、导航埋点
- src/hooks/useProfileCompleteness.js (127行)
  * 用户资料完整性管理 Hook
  * 封装资料检查逻辑、状态管理、自动检测
- src/components/Navbars/components/ProfileCompletenessAlert/index.js (96行)
  * 资料完整性提醒横幅组件
  * 响应式设计、操作回调
- src/components/Navbars/components/NavbarActions/index.js (82行)
  * 右侧功能区统一组件
  * 集成主题切换、登录按钮、功能菜单、用户菜单
- src/components/Navbars/components/ThemeToggleButton.js (更新)
  * 添加导航埋点支持
  * 支持自定义尺寸和样式

HomeNavbar.js 优化:
- 移除 SecondaryNav 内联组件定义(~148行)
- 移除资料完整性状态和逻辑(~90行)
- 移除资料完整性横幅 JSX(~50行)
- 移除右侧功能区 JSX(~54行)
- 简化 handleLogout,使用 resetCompleteness
- 525 → 215 行(-310行,-59.0%)

Phase 7 成果:
- 创建 1 个配置文件、4 个新组件、1 个自定义 Hook
- 从 HomeNavbar 中提取 ~342 行复杂逻辑和 JSX
- 代码高度模块化,职责清晰分离
- 所有功能保持完整,便于维护和测试

总体成果(Phase 1-7):
- 原始代码:1623 行
- Phase 1-6 后:525 行(-67.7%)
- Phase 7 后:215 行(-86.8%)
- 总减少:1408 行
- 提取组件总数:18+ 个
- 代码结构从臃肿单体文件转变为清晰的模块化架构

技术亮点:
- 自定义 Hooks 封装复杂状态逻辑
- 配置与组件分离
- 组件高度复用
- React.memo 性能优化
- 完整的 Props 类型注释

注意:存在 Webpack 缓存导致的间歇性编译错误,
代码本身正确,重启开发服务器可解决

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-30 18:07:22 +08:00
zdl
e24975cadc refactor(HomeNavbar): Phase 6 - 提取自选股和关注事件功能组件
Phase 6 重构完成,将自选股和关注事件功能完全组件化:

新增文件:
- src/hooks/useWatchlist.js - 自选股管理 Hook (98行)
  * 管理自选股数据加载、分页和移除逻辑
  * 提供 watchlistQuotes、loadWatchlistQuotes、handleRemoveFromWatchlist
- src/hooks/useFollowingEvents.js - 关注事件管理 Hook (104行)
  * 管理关注事件数据加载、分页和取消关注逻辑
  * 提供 followingEvents、loadFollowingEvents、handleUnfollowEvent
- src/components/Navbars/components/FeatureMenus/WatchlistMenu.js (182行)
  * 自选股下拉菜单组件,显示实时行情
  * 支持分页、价格显示、涨跌幅标记、移除功能
- src/components/Navbars/components/FeatureMenus/FollowingEventsMenu.js (196行)
  * 关注事件下拉菜单组件,显示事件详情
  * 支持分页、事件类型、时间、日均涨幅、周涨幅显示
- src/components/Navbars/components/FeatureMenus/index.js
  * 统一导出 WatchlistMenu 和 FollowingEventsMenu

HomeNavbar.js 优化:
- 移除 287 行旧代码(状态定义 + 4个回调函数)
- 添加 Phase 6 imports 和 Hook 调用
- 替换自选股菜单 JSX (~77行) → <WatchlistMenu />
- 替换关注事件菜单 JSX (~83行) → <FollowingEventsMenu />
- 812 → 525 行(-287行,-35.3%)

Phase 6 成果:
- 创建 2 个自定义 Hooks,5 个新文件
- 从 HomeNavbar 中提取 ~450 行复杂逻辑
- 代码更模块化,易于维护和测试
- 所有功能正常,编译通过

总体成果(Phase 1-6):
- 原始:1623 行 → 当前:525 行
- 总减少:1098 行(-67.7%)
- 提取组件:13+ 个
- 可维护性大幅提升

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-30 17:54:27 +08:00