fetch(modify):修复BUG
All checks were successful
构建并部署前端到测试环境 / build-and-deploy (push) Successful in 3m27s
All checks were successful
构建并部署前端到测试环境 / build-and-deploy (push) Successful in 3m27s
This commit is contained in:
@@ -0,0 +1,172 @@
|
||||
# Shop Management - Specification Delta
|
||||
|
||||
## ADDED Requirements
|
||||
|
||||
### Requirement: Query Shop Default Roles
|
||||
|
||||
系统SHALL支持查询指定店铺的默认角色列表。
|
||||
|
||||
**API端点**: `GET /api/admin/shops/{shop_id}/roles`
|
||||
|
||||
**路径参数**:
|
||||
- `shop_id` (integer, required): 店铺ID
|
||||
|
||||
**响应数据**:
|
||||
```typescript
|
||||
{
|
||||
shop_id: number // 店铺ID
|
||||
roles: ShopRole[] | null // 角色列表
|
||||
}
|
||||
|
||||
interface ShopRole {
|
||||
role_id: number // 角色ID
|
||||
role_name: string // 角色名称
|
||||
role_desc: string // 角色描述
|
||||
shop_id: number // 店铺ID
|
||||
status: number // 状态 (0:禁用, 1:启用)
|
||||
}
|
||||
```
|
||||
|
||||
#### Scenario: 成功查询店铺默认角色
|
||||
|
||||
- **WHEN** 用户请求获取店铺ID为123的默认角色列表
|
||||
- **THEN** 系统返回该店铺配置的所有默认角色
|
||||
- **AND** 响应包含角色ID、名称、描述、状态等完整信息
|
||||
|
||||
#### Scenario: 查询不存在的店铺
|
||||
|
||||
- **WHEN** 用户请求获取不存在的店铺的默认角色
|
||||
- **THEN** 系统返回400错误
|
||||
- **AND** 错误消息说明店铺不存在
|
||||
|
||||
#### Scenario: 店铺没有配置默认角色
|
||||
|
||||
- **WHEN** 用户请求获取未配置默认角色的店铺
|
||||
- **THEN** 系统返回成功响应
|
||||
- **AND** `roles` 字段为空数组或null
|
||||
|
||||
---
|
||||
|
||||
### Requirement: Assign Shop Default Roles
|
||||
|
||||
系统SHALL支持为指定店铺分配一个或多个默认角色。
|
||||
|
||||
**API端点**: `POST /api/admin/shops/{shop_id}/roles`
|
||||
|
||||
**路径参数**:
|
||||
- `shop_id` (integer, required): 店铺ID
|
||||
|
||||
**请求体**:
|
||||
```typescript
|
||||
{
|
||||
role_ids: number[] | null // 角色ID列表
|
||||
}
|
||||
```
|
||||
|
||||
**响应数据**: 与"Query Shop Default Roles"相同的数据结构
|
||||
|
||||
#### Scenario: 成功分配单个默认角色
|
||||
|
||||
- **WHEN** 用户为店铺分配一个新的默认角色
|
||||
- **THEN** 系统成功保存该角色配置
|
||||
- **AND** 返回更新后的店铺默认角色列表
|
||||
- **AND** 新分配的角色出现在列表中
|
||||
|
||||
#### Scenario: 成功分配多个默认角色
|
||||
|
||||
- **WHEN** 用户为店铺分配多个默认角色
|
||||
- **THEN** 系统批量保存所有角色配置
|
||||
- **AND** 返回完整的默认角色列表
|
||||
- **AND** 所有新分配的角色都出现在列表中
|
||||
|
||||
#### Scenario: 分配已存在的角色
|
||||
|
||||
- **WHEN** 用户尝试分配店铺已配置的默认角色
|
||||
- **THEN** 系统应当优雅处理(不重复添加或返回明确提示)
|
||||
- **AND** 不影响其他正常角色的分配
|
||||
|
||||
#### Scenario: 分配不存在的角色
|
||||
|
||||
- **WHEN** 用户尝试分配不存在的角色ID
|
||||
- **THEN** 系统返回400错误
|
||||
- **AND** 错误消息说明哪些角色ID无效
|
||||
|
||||
#### Scenario: 空角色列表
|
||||
|
||||
- **WHEN** 用户提交空的角色ID列表
|
||||
- **THEN** 系统接受请求
|
||||
- **AND** 可能清空当前默认角色或保持不变(取决于业务需求)
|
||||
|
||||
---
|
||||
|
||||
### Requirement: Delete Shop Default Role
|
||||
|
||||
系统SHALL支持删除指定店铺的某个默认角色配置。
|
||||
|
||||
**API端点**: `DELETE /api/admin/shops/{shop_id}/roles/{role_id}`
|
||||
|
||||
**路径参数**:
|
||||
- `shop_id` (integer, required): 店铺ID
|
||||
- `role_id` (integer, required): 角色ID
|
||||
|
||||
**响应**: 标准成功/错误响应
|
||||
|
||||
#### Scenario: 成功删除默认角色
|
||||
|
||||
- **WHEN** 用户删除店铺的一个默认角色配置
|
||||
- **THEN** 系统成功移除该角色配置
|
||||
- **AND** 返回成功响应(code: 0)
|
||||
- **AND** 后续查询该店铺默认角色列表时不再包含该角色
|
||||
|
||||
#### Scenario: 删除不存在的角色配置
|
||||
|
||||
- **WHEN** 用户尝试删除店铺未配置的角色
|
||||
- **THEN** 系统返回400错误
|
||||
- **AND** 错误消息说明该角色不在店铺的默认角色列表中
|
||||
|
||||
#### Scenario: 删除不存在的店铺或角色
|
||||
|
||||
- **WHEN** 用户使用无效的shop_id或role_id
|
||||
- **THEN** 系统返回400错误
|
||||
- **AND** 错误消息说明参数无效
|
||||
|
||||
---
|
||||
|
||||
### Requirement: Shop Default Roles UI
|
||||
|
||||
店铺管理页面SHALL提供默认角色管理的用户界面。
|
||||
|
||||
#### Scenario: 在店铺列表中访问默认角色设置
|
||||
|
||||
- **WHEN** 用户在店铺管理列表页查看店铺列表
|
||||
- **THEN** 每个店铺的操作列应当包含"设置默认角色"按钮或菜单项
|
||||
- **AND** 点击后打开默认角色管理对话框
|
||||
|
||||
#### Scenario: 查看店铺当前默认角色
|
||||
|
||||
- **WHEN** 用户打开某店铺的默认角色管理对话框
|
||||
- **THEN** 对话框显示该店铺当前已配置的所有默认角色
|
||||
- **AND** 每个角色显示名称、描述和状态
|
||||
- **AND** 提供删除按钮用于移除默认角色
|
||||
|
||||
#### Scenario: 添加默认角色
|
||||
|
||||
- **WHEN** 用户在对话框中选择要添加的角色
|
||||
- **THEN** 系统提供角色选择器,展示可用的系统角色列表
|
||||
- **AND** 支持多选
|
||||
- **AND** 点击确认后调用分配接口
|
||||
- **AND** 成功后刷新默认角色列表
|
||||
|
||||
#### Scenario: 删除默认角色
|
||||
|
||||
- **WHEN** 用户点击某个默认角色的删除按钮
|
||||
- **THEN** 系统显示确认对话框
|
||||
- **AND** 用户确认后调用删除接口
|
||||
- **AND** 成功后从列表中移除该角色
|
||||
|
||||
#### Scenario: 加载状态和错误处理
|
||||
|
||||
- **WHEN** 进行任何API操作时
|
||||
- **THEN** 界面应当显示加载状态(loading indicator)
|
||||
- **AND** 如果操作失败,应当显示友好的错误消息
|
||||
- **AND** 允许用户重试或关闭对话框
|
||||
Reference in New Issue
Block a user