|
|
@@ -0,0 +1,125 @@
|
|
|
+# Story 001.018: 搜索结果页面开发
|
|
|
+
|
|
|
+## Status
|
|
|
+Draft
|
|
|
+
|
|
|
+## Story
|
|
|
+**As a** 用户,
|
|
|
+**I want** 在mini中新增搜索结果页面,支持商品搜索和筛选功能,
|
|
|
+**so that** 我可以查看搜索结果的商品列表,并进行进一步筛选
|
|
|
+
|
|
|
+## Acceptance Criteria
|
|
|
+1. 实现搜索结果页面布局,包含搜索栏和商品列表
|
|
|
+2. 集成商品搜索API,支持关键词搜索
|
|
|
+3. 实现搜索结果分页和加载更多功能
|
|
|
+4. 支持搜索结果空状态显示
|
|
|
+5. 应用tcb-shop-demo搜索结果页设计规范
|
|
|
+6. 支持下拉刷新功能
|
|
|
+7. 页面组件TypeScript编译正常,无错误
|
|
|
+
|
|
|
+## Tasks / Subtasks
|
|
|
+- [ ] **创建搜索结果页面组件和配置文件** (AC: 1, 5, 7)
|
|
|
+ - [ ] 创建搜索结果页面组件 `mini/src/pages/search-result/index.tsx` [对照: `tcb-shop-demo/pages/goods/result/index.wxml`]
|
|
|
+ - [ ] 创建页面配置文件 `mini/src/pages/search-result/index.config.ts` [参考: `mini/src/pages/search/index.config.ts`]
|
|
|
+ - [ ] 创建专用样式文件 `mini/src/pages/search-result/index.css` [对照: `tcb-shop-demo/pages/goods/result/index.wxss`]
|
|
|
+ - [ ] 应用tcb-shop-demo搜索结果页整体布局结构
|
|
|
+
|
|
|
+- [ ] **实现搜索栏功能** (AC: 1, 2)
|
|
|
+ - [ ] 实现搜索输入框组件,支持关键词显示和修改 `mini/src/pages/search-result/index.tsx` [对照: `tcb-shop-demo/pages/goods/result/index.wxml` 中的search-bar部分]
|
|
|
+ - [ ] 集成搜索图标和清除按钮,应用tcb-shop-demo设计规范
|
|
|
+ - [ ] 支持回车键重新搜索,参照demo搜索交互逻辑 `tcb-shop-demo/pages/goods/result/index.js`
|
|
|
+ - [ ] 应用搜索栏样式 `mini/src/pages/search-result/index.css` [对照: `tcb-shop-demo/pages/goods/result/index.wxss` 中的search-bar样式]
|
|
|
+
|
|
|
+- [ ] **实现商品搜索结果列表** (AC: 1, 2, 3)
|
|
|
+ - [ ] 集成商品搜索API,使用 `mini/src/api.ts` 中的商品搜索客户端
|
|
|
+ - [ ] 实现搜索结果列表显示,使用现有的 `GoodsList` 组件 `mini/src/pages/search-result/index.tsx` [对照: `tcb-shop-demo/pages/goods/result/index.wxml` 中的goods-list部分]
|
|
|
+ - [ ] 实现分页和加载更多功能,使用 `useInfiniteQuery` 支持无限滚动
|
|
|
+ - [ ] 应用商品列表样式 `mini/src/pages/search-result/index.css` [对照: `tcb-shop-demo/pages/goods/result/index.wxss` 中的goods-list样式]
|
|
|
+
|
|
|
+- [ ] **实现空状态显示** (AC: 4)
|
|
|
+ - [ ] 实现无搜索结果时的空状态页面 `mini/src/pages/search-result/index.tsx` [对照: `tcb-shop-demo/pages/goods/result/index.wxml` 中的empty状态部分]
|
|
|
+ - [ ] 添加空状态图标和提示文字,应用tcb-shop-demo空状态样式
|
|
|
+ - [ ] 应用空状态样式 `mini/src/pages/search-result/index.css` [对照: `tcb-shop-demo/pages/goods/result/index.wxss` 中的empty样式]
|
|
|
+
|
|
|
+- [ ] **实现下拉刷新功能** (AC: 6)
|
|
|
+ - [ ] 配置页面下拉刷新功能 `mini/src/pages/search-result/index.config.ts` [参考: `mini/src/pages/order-detail/index.config.ts`]
|
|
|
+ - [ ] 实现下拉刷新逻辑,重新加载搜索结果数据 `mini/src/pages/search-result/index.tsx` [对照: `tcb-shop-demo/pages/goods/result/index.js` 中的下拉刷新逻辑]
|
|
|
+ - [ ] 应用下拉刷新样式,确保与tcb-shop-demo设计一致
|
|
|
+
|
|
|
+- [ ] **应用tcb-shop-demo设计规范** (AC: 5)
|
|
|
+ - [ ] 参照 `tcb-shop-demo/pages/goods/result/index.wxml` 页面结构,重新组织页面布局
|
|
|
+ - [ ] 应用tcb-shop-demo搜索结果页样式规范,确保视觉一致性
|
|
|
+ - [ ] 确保与现有主题系统兼容,集成 `mini/src/tcb-theme.css` 主题变量
|
|
|
+ - [ ] 验证页面结构与demo一致,包含搜索栏、商品列表、空状态等区域
|
|
|
+
|
|
|
+- [ ] **创建单元测试** (AC: 7)
|
|
|
+ - [ ] 创建搜索结果页面基础测试 `mini/tests/unit/pages/search-result/basic.test.tsx` [参考: `mini/tests/unit/pages/search/basic.test.tsx`]
|
|
|
+ - [ ] 测试搜索结果显示功能,验证API调用和数据显示
|
|
|
+ - [ ] 测试分页加载更多功能,验证无限滚动逻辑
|
|
|
+ - [ ] 测试空状态显示,验证不同条件下的空状态渲染
|
|
|
+ - [ ] 测试下拉刷新功能,验证数据重新加载逻辑
|
|
|
+ - [ ] 验证TypeScript编译无错误,确保代码质量
|
|
|
+
|
|
|
+## Dev Notes
|
|
|
+
|
|
|
+### 技术栈和架构上下文
|
|
|
+- **技术栈**: Taro.js + React + TypeScript + Tailwind CSS [Source: docs/architecture/tech-stack.md]
|
|
|
+- **API客户端**: Hono RPC (hc) 类型安全API调用 [Source: docs/architecture/tech-stack.md]
|
|
|
+- **状态管理**: React Query (TanStack Query) 5.83.0 [Source: docs/architecture/tech-stack.md]
|
|
|
+- **样式系统**: tcb-shop-demo主题系统已集成在 `mini/src/tcb-theme.css` [Source: docs/prd/epic-001-tcb-shop-theme-integration.md#主题变量系统]
|
|
|
+
|
|
|
+### 项目结构
|
|
|
+- **搜索结果页面位置**: `mini/src/pages/search-result/` [Source: docs/architecture/source-tree.md#mini-小程序项目]
|
|
|
+- **组件位置**: `mini/src/components/` [Source: docs/architecture/source-tree.md#mini-小程序项目]
|
|
|
+- **API客户端**: `mini/src/api.ts` [Source: docs/architecture/source-tree.md#mini-小程序项目]
|
|
|
+
|
|
|
+### 设计规范参考
|
|
|
+- **对照文件**: `tcb-shop-demo/pages/goods/result/index.wxml` - 搜索结果页结构模板 [Source: docs/prd/epic-001-tcb-shop-theme-integration.md#故事18]
|
|
|
+- **样式文件**: `tcb-shop-demo/pages/goods/result/index.wxss` - 搜索结果页样式文件 [Source: docs/prd/epic-001-tcb-shop-theme-integration.md#故事18]
|
|
|
+- **逻辑文件**: `tcb-shop-demo/pages/goods/result/index.js` - 搜索结果页逻辑文件 [Source: docs/prd/epic-001-tcb-shop-theme-integration.md#故事18]
|
|
|
+
|
|
|
+### 数据模型和API
|
|
|
+- **商品搜索API**: 使用通用CRUD包的商品API接口进行搜索,支持关键词搜索功能
|
|
|
+- **分页参数**: 使用标准的page和limit参数进行分页控制
|
|
|
+- **搜索关键词**: 从搜索页面传递的关键词参数,支持URL参数传递
|
|
|
+
|
|
|
+### 技术实现说明
|
|
|
+- **搜索功能**: 使用商品API的搜索接口,支持模糊搜索和关键词匹配
|
|
|
+- **分页加载**: 使用 `useInfiniteQuery` 实现无限滚动加载更多
|
|
|
+- **下拉刷新**: 使用Taro原生下拉刷新功能,重新加载第一页数据
|
|
|
+- **空状态处理**: 当搜索结果为空时显示空状态页面
|
|
|
+- **页面导航**: 支持从搜索页面跳转到搜索结果页面,传递关键词参数
|
|
|
+
|
|
|
+### 兼容性要求
|
|
|
+- 与现有tcb-shop-demo主题系统完全兼容
|
|
|
+- 保持与现有页面导航模式一致
|
|
|
+- 支持从搜索页面跳转到搜索结果页面
|
|
|
+- 与现有的 `GoodsList` 和 `GoodsCard` 组件完全兼容
|
|
|
+
|
|
|
+### Testing
|
|
|
+- **测试框架**: Jest (mini使用Jest) [Source: CLAUDE.md#测试调试]
|
|
|
+- **测试位置**: `mini/tests/unit/pages/search-result/` [Source: docs/architecture/source-tree.md#测试结构]
|
|
|
+- **测试命令**: `pnpm test --testNamePattern "搜索结果页面"` [Source: CLAUDE.md#测试调试]
|
|
|
+- **测试要求**:
|
|
|
+ - 验证搜索结果列表显示正常
|
|
|
+ - 验证分页和加载更多功能正常工作
|
|
|
+ - 验证空状态显示正确
|
|
|
+ - 验证下拉刷新功能正常
|
|
|
+ - 验证TypeScript编译无错误
|
|
|
+
|
|
|
+## Change Log
|
|
|
+| Date | Version | Description | Author |
|
|
|
+|------|---------|-------------|--------|
|
|
|
+| 2025-11-23 | 1.0 | 初始故事创建 | Bob (Scrum Master) |
|
|
|
+
|
|
|
+## Dev Agent Record
|
|
|
+
|
|
|
+### Agent Model Used
|
|
|
+
|
|
|
+### Debug Log References
|
|
|
+
|
|
|
+### Completion Notes List
|
|
|
+
|
|
|
+### File List
|
|
|
+
|
|
|
+## QA Results
|