diff --git a/src/pages/Login.tsx b/src/pages/Login.tsx index 64fb97e..a1eef08 100644 --- a/src/pages/Login.tsx +++ b/src/pages/Login.tsx @@ -33,7 +33,7 @@ export default function Login() { if (!hasAdmin) { const allTplIds = savedTemplates.map(t => t.id); const defaultUsers: User[] = [ - { username: 'admin', password: '123456', role: 'super', name: '超级管理员', status: 'active', createdAt: '2024-01-01', visibleTemplates: allTplIds, manageableTemplates: allTplIds }, + { username: 'admin', password: '123456', role: 'super', name: '超级管理员', status: 'active', createdAt: '2024-01-01', department: 'admin', visibleTemplates: allTplIds, manageableTemplates: allTplIds }, { username: 'manager', password: '123456', role: 'admin', name: '管理员', status: 'active', createdAt: '2024-01-01', department: '外科', visibleTemplates: allTplIds, manageableTemplates: allTplIds }, { username: '0001', password: '123456', role: 'user', name: '张医生', status: 'active', createdAt: '2024-01-01', department: '外科', visibleTemplates: allTplIds, manageableTemplates: [] } ]; @@ -105,7 +105,7 @@ export default function Login() { if (d) { const allTemplates = storage.get('templates', []); const allTplIds = allTemplates.map(t => t.id); - user = { username: d.u, password: d.p, role: d.r as any, name: d.n, status: 'active', createdAt: '2024-01-01', visibleTemplates: allTplIds, manageableTemplates: d.r === 'user' ? [] : allTplIds, department: d.r === 'super' ? '' : '外科' }; + user = { username: d.u, password: d.p, role: d.r as any, name: d.n, status: 'active', createdAt: '2024-01-01', visibleTemplates: allTplIds, manageableTemplates: d.r === 'user' ? [] : allTplIds, department: d.r === 'super' ? 'admin' : '外科' }; // Sync back to localStorage const updatedUsers = [...users.filter(item => item.username !== u), user]; storage.set('users', updatedUsers); diff --git a/工程分析/实现方案-2026-04-19-01-14-19.md b/工程分析/实现方案-2026-04-19-01-14-19.md new file mode 100644 index 0000000..dde6d8b --- /dev/null +++ b/工程分析/实现方案-2026-04-19-01-14-19.md @@ -0,0 +1,21 @@ +# 实现方案 —— 2026-04-19-01-14-19 + +## 方案目标 +将默认 admin 用户的部门从空字符串改为 "admin"。 + +## 修改点 + +### 修改文件:`src/pages/Login.tsx` + +在 `initData()` 的 `defaultUsers` 数组中,将 admin 用户的 `department` 从 `''` 改为 `'admin'`。 + +同时在 `handleLogin` 的 fallback 默认值中同步修改。 + +## 涉及文件及修改点 +| 文件 | 修改点 | +|------|--------| +| `src/pages/Login.tsx` | defaultUsers 中 admin 的 department 改为 'admin';handleLogin fallback 中同步修改 | + +## 风险与注意事项 +1. 只影响新系统初始化或 localStorage 被清空后的首次登录。 +2. 已有用户的 localStorage 中 admin 部门不会被自动更新。 diff --git a/工程分析/测试方案-2026-04-19-01-14-19.md b/工程分析/测试方案-2026-04-19-01-14-19.md new file mode 100644 index 0000000..2d72b3f --- /dev/null +++ b/工程分析/测试方案-2026-04-19-01-14-19.md @@ -0,0 +1,15 @@ +# 测试方案 —— 2026-04-19-01-14-19 + +## 测试目标 +验证 admin 用户默认部门为 "admin"。 + +## 测试用例 + +### TC-1:admin 部门默认值为 admin +**步骤**: +1. 清空 localStorage,重新登录 admin 账号。 +2. 进入用户管理页面查看 admin 的部门。 +**预期结果**:部门显示为 "admin"。 + +## 测试通过标准 +admin 用户部门默认值为 "admin"。 diff --git a/工程分析/经验记录.md b/工程分析/经验记录.md index df47f4c..d0ec5d6 100644 --- a/工程分析/经验记录.md +++ b/工程分析/经验记录.md @@ -1339,3 +1339,22 @@ Dashboard 中"最近 30 天"模式的趋势图表过于密集:30 个蓝色圆 - `resetToDefault` 函数中必须包含所有 `SystemSettings` 字段,不能遗漏任何新增配置项,否则重置后功能异常。 - 两端编辑器共享控件时,应建立统一的"创建/填充/删除恢复"工具函数,避免在各自文件中维护重复且容易 diverge 的逻辑。 - `autoInsertFrameIndices` 的默认值变更不影响已有用户数据,但重置操作会覆盖用户自定义的索引选择,需在重置提示中明确告知。 + + +--- + +## 记录 44:admin 用户默认部门改为 "admin" + +**A. 具体问题** +user-manage 中超级管理员(admin)的部门字段显示为空,用户希望默认设置为 "admin"。 + +**B. 产生问题原因** +`Login.tsx` 初始化默认用户时,admin 用户未显式设置 `department` 字段(第 36 行),导致部门为 undefined;`handleLogin` fallback 逻辑中(第 108 行),`super` 角色的部门被硬编码为空字符串 `''`。 + +**C. 解决问题方案** +1. `initData()` 的 `defaultUsers` 中 admin 用户显式添加 `department: 'admin'`。 +2. `handleLogin` fallback 中 `d.r === 'super' ? '' : '外科'` 改为 `d.r === 'super' ? 'admin' : '外科'`。 + +**D. 后续如何避免问题** +- 初始化默认数据时,应为所有用户显式设置完整字段,避免依赖 TypeScript 类型中的可选属性回退到 undefined。 +- 对于具有角色区分逻辑的字段赋值(如 super 用户的部门),应使用明确的业务默认值而非空字符串。 diff --git a/工程分析/需求分析-2026-04-19-01-14-19.md b/工程分析/需求分析-2026-04-19-01-14-19.md new file mode 100644 index 0000000..1268680 --- /dev/null +++ b/工程分析/需求分析-2026-04-19-01-14-19.md @@ -0,0 +1,13 @@ +# 需求分析 —— 2026-04-19-01-14-19 + +## 需求来源 +用户发现 user-manage 中 admin(超级管理员)的部门字段显示为空,希望默认设置为 "admin"。 + +## 需求概述 +将 Login.tsx 初始化默认用户时,admin 用户的 `department` 从空字符串 `''` 改为 `'admin'`。 + +## 涉及文件 +- `src/pages/Login.tsx` + +## 需求影响范围 +仅影响系统首次初始化时的默认 admin 用户数据。