feat(admin): Add user management and upgrade to module permission system

Features - User Management (Phase 4.1):
- Database: Add user_modules table for fine-grained module permissions
- Database: Add 4 user permissions (view/create/edit/delete) to role_permissions
- Backend: UserService (780 lines) - CRUD with tenant isolation
- Backend: UserController + UserRoutes (648 lines) - 13 API endpoints
- Backend: Batch import users from Excel
- Frontend: UserListPage (412 lines) - list/filter/search/pagination
- Frontend: UserFormPage (341 lines) - create/edit with module config
- Frontend: UserDetailPage (393 lines) - details/tenant/module management
- Frontend: 3 modal components (592 lines) - import/assign/configure
- API: GET/POST/PUT/DELETE /api/admin/users/* endpoints

Architecture Upgrade - Module Permission System:
- Backend: Add getUserModules() method in auth.service
- Backend: Login API returns modules array in user object
- Frontend: AuthContext adds hasModule() method
- Frontend: Navigation filters modules based on user.modules
- Frontend: RouteGuard checks requiredModule instead of requiredVersion
- Frontend: Remove deprecated version-based permission system
- UX: Only show accessible modules in navigation (clean UI)
- UX: Smart redirect after login (avoid 403 for regular users)

Fixes:
- Fix UTF-8 encoding corruption in ~100 docs files
- Fix pageSize type conversion in userService (String to Number)
- Fix authUser undefined error in TopNavigation
- Fix login redirect logic with role-based access check
- Update Git commit guidelines v1.2 with UTF-8 safety rules

Database Changes:
- CREATE TABLE user_modules (user_id, tenant_id, module_code, is_enabled)
- ADD UNIQUE CONSTRAINT (user_id, tenant_id, module_code)
- INSERT 4 permissions + role assignments
- UPDATE PUBLIC tenant with 8 module subscriptions

Technical:
- Backend: 5 new files (~2400 lines)
- Frontend: 10 new files (~2500 lines)
- Docs: 1 development record + 2 status updates + 1 guideline update
- Total: ~4900 lines of code

Status: User management 100% complete, module permission system operational
This commit is contained in:
2026-01-16 13:42:10 +08:00
parent 98d862dbd4
commit 66255368b7
560 changed files with 70424 additions and 52353 deletions

View File

@@ -1,71 +1,71 @@
# INST-<EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡?- 璅<E79285>敶枏<E695B6><E69E8F><EFBFBD><E59786><EFBFBD><EFBFBD><E69298><EFBFBD><E78390>?
# INST-机构管理端 - 模块当前状态与开发指南
> **最后更新:** 2026-01-11
> **状态:** 🔴 未开始(等待运营管理端完成)
> **<EFBFBD><EFBFBD>𧋦嚗?* v0.0 (Planning)
> **版本:** v0.0 (Planning)
---
## 🎯 一句话总结
**<EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡臭蛹<EFBFBD>駁堺<EFBFBD>諹晓隡<EFBFBD><EFBFBD><EFBFBD>靘𥡝䌊<EFBFBD>滚𦛚蝞∠<EFBFBD><EFBFBD>屸𢒰嚗諹悟<EFBFBD><EFBFBD>蝞∠<EFBFBD><EFBFBD><EFBFBD>憭毺𡠺蝡讠恣<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>憸腈<EFBFBD><EFBFBD><EFBFBD>摰?憿寧𤌍蝑㕑<E89D91>皞僐<E79A9E>?*
**机构管理端为医院和药企客户提供自服务管理界面,让机构管理员能够独立管理用户、配额、科室/项目等资源。**
---
## <EFBFBD><EFBFBD> 敶枏<E695B6><EFBFBD><E69298>𤑳𠶖<F0A491B3>?
## 📊 当前开发状态
### <EFBFBD>?撌脣<E6928C><E884A3>?
### ✅ 已完成
- [ ] **<EFBFBD>?*嚗<><E59A97><EFBFBD><EFBFBD>憪页<E686AA>
- [ ] **无**(尚未开始)
### <EFBFBD>银 餈𥡝<E9A488>銝?
### 🚧 进行中
- [ ] **<EFBFBD>?*
- [ ] **无**
### <EFBFBD>?敺<><E695BA><EFBFBD>𡢅<EFBFBD>靘肽<E99D98>餈鞱𨯫蝞∠<E89D9E>蝡荔<E89DA1>
### ⏳ 待开发(依赖运营管理端)
**前置条件(必须先完成):**
- [ ] 餈鞱𨯫蝞∠<EFBFBD>蝡臬抅蝖<EFBFBD><EFBFBD><EFBFBD>嚗㇊hase 0-2嚗?
- [ ] 运营管理端基础架构Phase 0-2
- [ ] 租户管理功能
- [ ] <EFBFBD><EFBFBD>銝枏<EFBFBD><EFBFBD><EFBFBD>憿?
- [ ] 租户专属登录页
- [ ] 品牌定制配置
**机构管理端开发计划预计Week 5+**
**P1 - <EFBFBD>駁堺蝞∠<EFBFBD>蝡荔<EFBFBD>Week 5-6嚗?*
- [ ] <EFBFBD><EFBFBD>蝞∠<EFBFBD>嚗㇃RUD + 蝘穃恕<E7A983><E68195><EFBFBD>嚗?
**P1 - 医院管理端(Week 5-6**
- [ ] 用户管理CRUD + 科室分配)
- [ ] 科室管理(支持多级结构)
- [ ] <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>摰?銝芯犖嚗?
- [ ] 配额分配(科室/个人)
- [ ] 审计日志查询
**P1 - <EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡荔<EFBFBD>Week 7-8嚗?*
- [ ] <EFBFBD><EFBFBD>蝞∠<EFBFBD>嚗㇃RUD + 閫坿𠧧<E59DBF><F0A0A7A7><EFBFBD>嚗?
- [ ] 憿寧𤌍蝞∠<EFBFBD>嚗㇆IT憿寧𤌍<EFBFBD><EFBFBD>嚗?
- [ ] <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?銝芯犖嚗?
- [ ] 摰∟恣<EFBFBD><EFBFBD><EFBFBD>亥砭嚗㇅DA<EFBFBD><EFBFBD><EFBFBD>嚗?
**P1 - 药企管理端(Week 7-8**
- [ ] 用户管理CRUD + 角色分配)
- [ ] 项目管理IIT项目关联
- [ ] 配额分配(项目/个人)
- [ ] 审计日志查询FDA合规
---
## <EFBFBD><EFBFBD>儭?<3F><EFBFBD><EFBFBD><E79281>
## 🏗️ 架构概览
```
<EFBFBD>𢞖<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
<EFBFBD>? <EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡荔<EFBFBD>INST Portal嚗? <EFBFBD>?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
<EFBFBD>? <20><20>駁堺蝞∠<E89D9E>蝡? <20>? <20><> <20><EFBFBD>蝞∠<E89D9E>蝡? <EFBFBD>?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
<EFBFBD>?繚 <20><EFBFBD>蝞∠<E89D9E> <20>? 繚 <20><EFBFBD>蝞∠<E89D9E> <EFBFBD>?
<EFBFBD>?繚 蝘穃恕蝞∠<E89D9E> <20>? 繚 憿寧𤌍蝞∠<E89D9E> <EFBFBD>?
<EFBFBD>?繚 <20><EFBFBD><E6BCA4><EFBFBD><EFBFBD><EFBFBD><E59A97>摰?鈭綽<E988AD> <20>? 繚 <20><EFBFBD><E6BCA4><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?鈭綽<E988AD> <EFBFBD>?
<EFBFBD>?繚 摰∟恣<E2889F><EFBFBD> <20>? 繚 摰∟恣<E2889F><EFBFBD><EFBFBD><E59A97><EFBFBD><E996AB> <EFBFBD>?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
<EFBFBD>?
┌─────────────────────────────────────────────────┐
机构管理端(INST Portal
├──────────────────────┬──────────────────────────┤
│ 🏥 医院管理端 │ 💊 药企管理端
├──────────────────────┼──────────────────────────┤
│ · 用户管理 │ · 用户管理
│ · 科室管理 │ · 项目管理
│ · 配额分配(科室/人) │ · 配额分配(项目/人)
│ · 审计日志 │ · 审计日志(合规)
└──────────────────────┴──────────────────────────┘
继承运营管理端的基础设施
<EFBFBD>?
<EFBFBD>𢞖<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
<EFBFBD>? Platform Layer <EFBFBD>?
<EFBFBD>? 霈方<E99C88>銝剖<E98A9D> <20>?<3F><><EFBFBD>銝剖<E98A9D> <20>?憭𡁶<E686AD><F0A181B6><EFBFBD>蝳?<3F>?摰∟恣<E2889F><EFBFBD> <EFBFBD>?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
┌─────────────────────────────────────────────────┐
Platform Layer
│ 认证中心 │ 权限中心 │ 多租户隔离 │ 审计日志
└─────────────────────────────────────────────────┘
```
---
@@ -74,12 +74,12 @@
| 功能 | HOSPITAL_ADMIN | DEPARTMENT_ADMIN | PHARMA_ADMIN | PROJECT_MANAGER | USER |
|------|----------------|------------------|--------------|-----------------|------|
| <EFBFBD><EFBFBD>蝞∠<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>嚗?| <20>?<3F><EFBFBD> | <20>?<3F><EFBFBD>摰?| <20>?<3F><EFBFBD> | <20>?憿寧𤌍<E5AFA7>𣂼<EFBFBD> | <EFBFBD>?|
| 蝘穃恕蝞∠<EFBFBD> | <20>?| <20>?| N/A | N/A | <EFBFBD>?|
| 憿寧𤌍蝞∠<EFBFBD> | N/A | N/A | <EFBFBD>?<3F><EFBFBD> | <20>?蝞∠<E89D9E> | <EFBFBD>?|
| <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> | <20>?| <20>?<3F><EFBFBD>摰?| <20>?| <20>?憿寧𤌍<E5AFA7>?| <20>?|
| 摰∟恣<EFBFBD><EFBFBD> | <20>?蝘<><E89D98><EFBFBD>?| <20>?<3F><EFBFBD>摰?| <20>?蝘<><E89D98><EFBFBD>?| <20>?憿寧𤌍<E5AFA7>?| <20>?|
| 銝𡁜𦛚璅<EFBFBD>雿輻鍂 | <20>?| <20>?| <20>?| <20>?| <20>?|
| 用户管理(租户内) | ✅ 全部 | ✅ 本科室 | ✅ 全部 | ✅ 项目成员 | |
| 科室管理 | ✅ | ❌ | N/A | N/A | |
| 项目管理 | N/A | N/A | ✅ 查看 | ✅ 管理 | |
| 配额分配 | ✅ | ✅ 本科室 | ✅ | ✅ 项目内 | ❌ |
| 审计日志 | ✅ 租户内 | ✅ 本科室 | ✅ 租户内 | ✅ 项目内 | ❌ |
| 业务模块使用 | ✅ | ✅ | ✅ | ✅ | ✅ |
---
@@ -90,30 +90,30 @@
```
backend/src/
├── modules/
<EFBFBD>? <20><EFBFBD><E5A999><EFBFBD> institution/ # <EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡舀芋<EFBFBD>?
<EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> controllers/
<EFBFBD>? <EFBFBD>? <20><EFBFBD><E98EBF><EFBFBD> hospital/
<EFBFBD>? <EFBFBD>? <20>? <20><EFBFBD><E98EBF><EFBFBD> user.controller.ts
<EFBFBD>? <EFBFBD>? <20>? <20><EFBFBD><E98EBF><EFBFBD> department.controller.ts
<EFBFBD>? <EFBFBD>? <20>? <20><EFBFBD><E5A999><EFBFBD> quota.controller.ts
<EFBFBD>? <20>? <20>?
<EFBFBD>? <EFBFBD>? <20><EFBFBD><E5A999><EFBFBD> pharma/
<EFBFBD>? <EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> user.controller.ts
<EFBFBD>? <EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> project.controller.ts
<EFBFBD>? <EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> quota.controller.ts
<EFBFBD>? <EFBFBD>?
<EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> services/
<EFBFBD>? <EFBFBD>? <20><EFBFBD><E98EBF><EFBFBD> hospital.service.ts
<EFBFBD>? <EFBFBD>? <20><EFBFBD><E5A999><EFBFBD> pharma.service.ts
<EFBFBD>? <EFBFBD>?
<EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> routes/
<EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> hospital.routes.ts
<EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> pharma.routes.ts
<EFBFBD>?
│ └── institution/ # 机构管理端模块
├── controllers/
│ ├── hospital/
│ │ ├── user.controller.ts
│ │ ├── department.controller.ts
│ │ └── quota.controller.ts
│ │
│ └── pharma/
├── user.controller.ts
├── project.controller.ts
└── quota.controller.ts
├── services/
│ ├── hospital.service.ts
│ └── pharma.service.ts
└── routes/
├── hospital.routes.ts
└── pharma.routes.ts
└── common/
└── middleware/
├── tenant.middleware.ts # 租户隔离(复用)
<EFBFBD><EFBFBD><EFBFBD><EFBFBD> department.middleware.ts # 蝘穃恕<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
└── department.middleware.ts # 科室权限检查
```
### 前端
@@ -121,33 +121,33 @@ backend/src/
```
frontend-v2/src/
├── modules/
<EFBFBD>? <20><EFBFBD><E5A999><EFBFBD> institution/ # <EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡舀芋<EFBFBD>?
<EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> pages/
<EFBFBD>? <EFBFBD>? <20><EFBFBD><E98EBF><EFBFBD> hospital/
<EFBFBD>? <EFBFBD>? <20>? <20><EFBFBD><E98EBF><EFBFBD> UserManagement/
<EFBFBD>? <EFBFBD>? <20>? <20><EFBFBD><E98EBF><EFBFBD> DepartmentManagement/
<EFBFBD>? <EFBFBD>? <20>? <20><EFBFBD><E98EBF><EFBFBD> QuotaAllocation/
<EFBFBD>? <EFBFBD>? <20>? <20><EFBFBD><E5A999><EFBFBD> AuditLog/
<EFBFBD>? <20>? <20>?
<EFBFBD>? <EFBFBD>? <20><EFBFBD><E5A999><EFBFBD> pharma/
<EFBFBD>? <EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> UserManagement/
<EFBFBD>? <EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> ProjectManagement/
<EFBFBD>? <EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> QuotaAllocation/
<EFBFBD>? <EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> AuditLog/
<EFBFBD>? <EFBFBD>?
<EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> components/
<EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> UserForm/
<EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> DepartmentTree/
<EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> QuotaAllocator/
<EFBFBD>? <EFBFBD><EFBFBD><EFBFBD><EFBFBD> AuditLogViewer/
<EFBFBD>?
│ └── institution/ # 机构管理端模块
├── pages/
│ ├── hospital/
│ │ ├── UserManagement/
│ │ ├── DepartmentManagement/
│ │ ├── QuotaAllocation/
│ │ └── AuditLog/
│ │
│ └── pharma/
├── UserManagement/
├── ProjectManagement/
├── QuotaAllocation/
└── AuditLog/
└── components/
├── UserForm/
├── DepartmentTree/
├── QuotaAllocator/
└── AuditLogViewer/
└── layouts/
└── TenantLayout/ # 租户专属布局(品牌定制)
```
---
## <EFBFBD> UI/UX <EFBFBD><EFBFBD>?
## 🎨 UI/UX 特性
### 1. 租户品牌定制
@@ -160,9 +160,9 @@ document.documentElement.style.setProperty('--primary-color', config.primaryColo
document.title = config.systemName;
```
**<EFBFBD><EFBFBD><EFBFBD>嚗?*
- <EFBFBD><EFBFBD><EFBFBD>駁堺<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Logo<EFBFBD>?<3F><EFBFBD>銝游<E98A9D><E6B8B8>𠉛弦撟喳蝱"
- 颲厩<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>糓颲厩<EFBFBD>Logo<EFBFBD>?颲厩<E9A2B2>IIT蝞∠<E89D9E>撟喳蝱"
**效果:**
- 协和医院看到的是协和Logo和"协和临床研究平台"
- 辉瑞药业看到的是辉瑞Logo和"辉瑞IIT管理平台"
### 2. 科室树组件(医院端)
@@ -175,19 +175,19 @@ document.title = config.systemName;
/>
```
**<EFBFBD><EFBFBD>嚗?*
**支持:**
- 多级展开/折叠
- 拖拽排序
- <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
- 配额可视化
### 3. <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
### 3. 配额分配器
```tsx
<QuotaAllocator
totalQuota={1000000}
allocations={[
{ target: '<EFBFBD><EFBFBD>蝘?, allocated: 500000, used: 300000 },
{ target: '𧼮<EFBFBD>?, allocated: 300000, used: 150000 }
{ target: '心内科', allocated: 500000, used: 300000 },
{ target: '神内科', allocated: 300000, used: 150000 }
]}
onAllocate={(target, amount) => handleAllocate(target, amount)}
/>
@@ -200,9 +200,9 @@ document.title = config.systemName;
---
## <EFBFBD><EFBFBD>儭?<3F>唳旿璅<E79285>
## 🗄️ 数据模型
### <EFBFBD>駁堺蝡?
### 医院端
```typescript
// 科室
@@ -221,16 +221,16 @@ interface QuotaAllocation {
id: string;
tenantId: string;
targetType: 'DEPARTMENT' | 'USER';
targetKey: string; // DepartmentID <EFBFBD>?UserID
targetKey: string; // DepartmentID UserID
limitAmount: bigint;
usedAmount: bigint;
}
```
### <EFBFBD><EFBFBD>蝡?
### 药企端
```typescript
// 憿寧𤌍嚗<EFBFBD><EFBFBD><EFBFBD>㶏IT嚗?
// 项目关联IIT
interface Project {
id: string;
tenantId: string;
@@ -252,11 +252,11 @@ interface ProjectMember {
---
## <EFBFBD><EFBFBD><><E69298><EFBFBD>蝔?
## 🚀 开发流程
### Step 1: 设计阶段(当前)
- [ ] 霂衣<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>PRD嚗?
- [ ] 详细需求文档(PRD
- [ ] API接口设计
- [ ] 数据库表设计
- [ ] UI原型设计
@@ -275,19 +275,19 @@ interface ProjectMember {
- 配额分配API
- 审计日志API合规
### Step 3: <EFBFBD>滨垢撘<EFBFBD><EFBFBD>?
### Step 3: 前端开发
1. **公共组件**
- TenantLayout<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>嚗?
- QuotaAllocator<EFBFBD><EFBFBD>憸嘥<EFBFBD><EFBFBD>滚膥嚗?
- AuditLogViewer<EFBFBD>恣霈⊥𠯫敹埈䰻<EFBFBD>见膥嚗?
- TenantLayout(品牌定制布局)
- QuotaAllocator(配额分配器)
- AuditLogViewer(审计日志查看器)
2. **<EFBFBD>駁堺蝡舫△<EFBFBD>?*
2. **医院端页面**
- 用户管理
- 蝘穃恕蝞∠<EFBFBD>嚗㇄epartmentTree嚗?
- 科室管理DepartmentTree
- 配额分配
3. **<EFBFBD><EFBFBD>蝡舫△<EFBFBD>?*
3. **药企端页面**
- 用户管理
- 项目管理
- 配额分配
@@ -296,48 +296,48 @@ interface ProjectMember {
## 📚 核心文档导航
### 敶枏<EFBFBD><EFBFBD><EFBFBD>霂?
### 当前可阅读
1. **整体架构**
`../ADMIN-餈鞱𨯫蝞∠<EFBFBD>蝡?00-蝟餌<E89D9F>霈曇恣/00-<2D><><EFBFBD>銝舘<E98A9D><E88898><EFBFBD>蝟餅<E9A485><EFBC94>𥁒<EFBFBD>𠽤v1.0.md`
`../ADMIN-运营管理端/00-系统设计/00-权限与角色体系梳理报告_v1.0.md`
2. **需求文档(包含机构端)**
`../ADMIN-餈鞱𨯫蝞∠<EFBFBD>蝡?01-<2D><><EFBFBD><E79899><EFBFBD>?02-<2D>𡁶鍂<F0A181B6><EFBFBD><EFBFBD>07-餈鞱𨯫銝擧㦤<E693A7><E3A6A4><EFBFBD><E681A3>PRD_v2.1.md`
`../ADMIN-运营管理端/01-需求分析/02-通用能力层_07-运营与机构管理端PRD_v2.1.md`
3. **餈鞱𨯫蝡舐𠶖<EFBFBD>?*
`../ADMIN-餈鞱𨯫蝞∠<EFBFBD>蝡?00-璅<E79285>敶枏<E695B6><E69E8F><EFBFBD><E59786><EFBFBD><EFBFBD><E69298><EFBFBD><E78390>?md`
3. **运营端状态**
`../ADMIN-运营管理端/00-模块当前状态与开发指南.md`
### <EFBFBD><EFBFBD>撱箸<EFBFBD>獢?
### 待创建文档
**00-系统设计/**
- [ ] `01-<EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡舀沲<EFBFBD><EFBFBD>挽霈?md`
- [ ] `02-憭𡁶<EFBFBD><EFBFBD><EFBFBD>蝳餉挽霈?md`
- [ ] `01-机构管理端架构设计.md`
- [ ] `02-多租户隔离设计.md`
- [ ] `03-配额管理设计.md`
**01-<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?**
**01-需求分析/**
- [ ] `01-医院管理端PRD.md`
- [ ] `02-药企管理端PRD.md`
- [ ] `03-<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>銝𡡞<EFBFBD><EFBFBD><EFBFBD><EFBFBD>?md`
- [ ] `03-用户故事与验收标准.md`
**02-<EFBFBD><EFBFBD><EFBFBD>航挽霈?**
**02-技术设计/**
- [ ] `01-API设计文档.md`
- [ ] `02-<EFBFBD>唳旿摨栞挽霈⊥<EFBFBD>獢?md`
- [ ] `03-蝘穃恕<EFBFBD><EFBFBD><EFBFBD>唳䲮獢?md`
- [ ] `02-数据库设计文档.md`
- [ ] `03-科室树实现方案.md`
- [ ] `04-配额计算算法.md`
**03-UI设计/**
- [ ] `01-<EFBFBD>駁堺蝡臬<EFBFBD><EFBFBD>贝挽霈?html`
- [ ] `02-<EFBFBD><EFBFBD>蝡臬<EFBFBD><EFBFBD>贝挽霈?html`
- [ ] `01-医院端原型设计.html`
- [ ] `02-药企端原型设计.html`
- [ ] `03-品牌定制指南.md`
---
## <EFBFBD>𩤃<EFBFBD> <20><><EFBFBD><EFBFBD><E888AA>?
## ⚠️ 技术要点
### 1. 憭𡁶<EFBFBD><EFBFBD><EFBFBD>蝳?
### 1. 多租户隔离
```typescript
// 銝剝𡢿隞塚<EFBFBD>蝖桐<EFBFBD><EFBFBD><EFBFBD>霈輸䔮<EFBFBD>芸楛蝘<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
// 中间件:确保只能访问自己租户的数据
export const requireTenantAccess = async (request: FastifyRequest) => {
const { tenantId } = request.user;
const { id } = request.params;
@@ -352,10 +352,10 @@ export const requireTenantAccess = async (request: FastifyRequest) => {
};
```
### 2. 蝘穃恕<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
### 2. 科室权限检查
```typescript
// 蝘穃恕蝞∠<EFBFBD><EFBFBD>睃蘨<EFBFBD>賜恣<EFBFBD><EFBFBD>䌊撌梁<EFBFBD>摰?
// 科室管理员只能管理自己科室
export const requireDepartmentAccess = async (request: FastifyRequest) => {
const { role, departmentId } = request.user;
const { deptId } = request.params;
@@ -369,12 +369,12 @@ export const requireDepartmentAccess = async (request: FastifyRequest) => {
### 3. 配额计算
```typescript
// 霈∠<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>憸?
// 计算可分配配额
export const calculateAvailableQuota = async (tenantId: string) => {
// 1. <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>憸?
// 1. 获取租户总配额
const tenantQuota = await getTenantQuota(tenantId);
// 2. 霈∠<EFBFBD>撌脣<EFBFBD><EFBFBD><EFBFBD>憸?
// 2. 计算已分配配额
const allocated = await prisma.tenantQuotaAllocation.aggregate({
where: { tenantId },
_sum: { limitAmount: true }
@@ -387,30 +387,30 @@ export const calculateAvailableQuota = async (tenantId: string) => {
---
## <EFBFBD><EFBFBD> 銝舘<E98A9D><E88898>亦恣<E4BAA6><E681A3><EFBFBD><E59EA2>笆瘥?
## 🔍 与运营管理端的对比
| <EFBFBD><EFBFBD>?| 餈鞱𨯫蝞∠<E89D9E>蝡荔<E89DA1>ADMIN嚗?| <20><EFBFBD>蝞∠<E89D9E>蝡荔<E89DA1>INST嚗?|
| 特性 | 运营管理端ADMIN | 机构管理端(INST |
|------|-------------------|------------------|
| **<EFBFBD><EFBFBD>** | <EFBFBD>砍虬<EFBFBD><EFBFBD><EFBFBD>餈鞱𨯫鈭箏<EFBFBD> | <20>駁堺/<2F><EFBFBD>蝞∠<E89D9E><E288A0>?|
| **<EFBFBD><EFBFBD><EFBFBD>** | <EFBFBD><EFBFBD>蝞∠<EFBFBD><EFBFBD><EFBFBD><EFBFBD> | 蝘<><E89D98>蝥抒恣<E68A92><E681A3><EFBFBD><EFBFBD>?|
| **<EFBFBD><EFBFBD>蝞∠<EFBFBD>** | <EFBFBD>?<3F>𥕦遣/蝞∠<E89D9E><E288A0><EFBFBD><EFBFBD><EFBFBD><E58EA9>?| <20>?<3F><EFBFBD><E88ABE><EFBFBD><E8A781>芸楛蝘<E6A59B><E89D98> |
| **<EFBFBD><EFBFBD>蝞∠<EFBFBD>** | <EFBFBD>?<3F><EFBFBD><E585B8><EFBFBD>蝞∠<E89D9E> | <20>?蝘<><E89D98><EFBFBD><EFBFBD><EFBFBD>瑞恣<E7919E>?|
| **<EFBFBD><EFBFBD>蝞∠<EFBFBD>** | <EFBFBD>?<3F><><EFBFBD><EFBFBD><E89D98><EFBFBD><EFBFBD>憸?| <20>?<3F><><EFBFBD>蝘穃恕/憿寧𤌍<E5AFA7><EFBFBD> |
| **Prompt蝞∠<EFBFBD>** | <EFBFBD>?<3F>煺漣<E785BA><EFBFBD><EFBFBD><E99D9A> | <20>?<3F><EFBFBD><E4ADBE>?|
| **摰∟恣<EFBFBD><EFBFBD>** | <EFBFBD>?<3F><EFBFBD><E585B8><EFBFBD> | <20>?蝘<><E89D98><EFBFBD><EFBFBD>𠯫敹?|
| **<EFBFBD><EFBFBD><EFBFBD>摰𡁜<EFBFBD>** | <EFBFBD>?<3F>滨蔭<E6BBA8><E894AD><EFBFBD><EFBFBD><E58EA9><EFBFBD><E79195>?| <20>?<3F><EFBFBD><E88ABE><EFBFBD> |
| **用户** | 公司内部运营人员 | 医院/药企管理员 |
| **权限** | 全局管理权限 | 租户级管理权限 |
| **租户管理** | ✅ 创建/管理所有租户 | ❌ 只能看到自己租户 |
| **用户管理** | ✅ 全局用户管理 | ✅ 租户内用户管理 |
| **配额管理** | ✅ 分配租户总配额 | ✅ 分配科室/项目配额 |
| **Prompt管理** | ✅ 生产环境调试 | ❌ 无权限 |
| **审计日志** | ✅ 全局日志 | ✅ 租户内日志 |
| **品牌定制** | ✅ 配置所有租户品牌 | ❌ 只能查看 |
---
## <EFBFBD><EFBFBD><>恣撘<E681A3><E69298>烐𧒄<E78390>?
## 📅 预计开发时间
**<EFBFBD>齿<EFBFBD>嚗?* 餈鞱𨯫蝞∠<E89D9E>蝡臬抅蝖<E68A85><E89D96><EFBFBD>摰峕<E691B0>嚗Áeek 4嚗?
**前提:** 运营管理端基础架构完成Week 4
- **Week 5-6嚗?* <20>駁堺蝞∠<E89D9E>蝡荔<E89DA1>8鈭箏予嚗?
- **Week 7-8嚗?* <20><EFBFBD>蝞∠<E89D9E>蝡荔<E89DA1>8鈭箏予嚗?
- **Week 9嚗?* 瘚贝<E7989A>銝𦒘<E98A9D><F0A69298><EFBFBD>3鈭箏予嚗?
- **Week 5-6** 医院管理端8人天
- **Week 7-8** 药企管理端8人天
- **Week 9** 测试与优化3人天
**<EFBFBD>餉恣嚗?* 蝥?9鈭箏予嚗ǚ4<C79A><EFBFBD>
**总计:** 约19人天~4周
---
@@ -418,11 +418,11 @@ export const calculateAvailableQuota = async (tenantId: string) => {
1. **架构问题**:参考运营管理端实现
2. **权限问题**:查看`00-权限与角色体系梳理报告_v1.0.md`
3. **UI<EFBFBD><EFBFBD>**嚗𡁜<E59A97><F0A1819C><EFBFBD>C/ASL蝑匧歇<E58CA7>㗇芋<E39787>?
3. **UI问题**参考DC/ASL等已有模块
---
## <EFBFBD>㴓 銝衤<E98A9D>甇亥<E79487><E4BAA5>?
## 🎯 下一步行动
- [ ] 等待运营管理端完成基础架构
- [ ] 开始编写详细PRD
@@ -431,12 +431,11 @@ export const calculateAvailableQuota = async (tenantId: string) => {
---
*<2A><EFBFBD>蝞∠<E89D9E>蝡航蒾<E888AA><EFBFBD><E59785><EFBFBD>憪见<E686AA><E8A781>𡢅<EFBFBD><EFBFBD>挽霈⊥<E99C88>肽楝撌脫<E6928C>蝖柴<E89D96><E69FB4><EFBFBD>餈鞱𨯫蝞∠<E89D9E>蝡臬<E89DA1><E887AC>𣂼<EFBFBD><EFBFBD>虾敹恍<E695B9>笔鍳<E7AC94><EFBFBD><E585B8><EFBFBD>?
*机构管理端虽然尚未开始开发,但设计思路已明确。待运营管理端完成后,可快速启动开发。*
---
**<EFBFBD><EFBFBD> <20>祈窈<E7A588><EFBFBD>嚗?*
**🚀 敬请期待!**

View File

@@ -1,155 +1,155 @@
# INST - <EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡?
# INST - 机构管理端
> **<EFBFBD><EFBFBD><EFBFBD>嚗?* INST
> **<EFBFBD><EFBFBD>滨妍嚗?* <20><EFBFBD>蝞∠<E89D9E>蝡荔<E89DA1>Institution Management Portal嚗?
> **模块代码:** INST
> **模块名称:** 机构管理端(Institution Management Portal
> **优先级:** P1重要功能
> **<EFBFBD><EFBFBD>𤑳𠶖<EFBFBD><EFBFBD><EFBFBD>** <20>𣞁 <20><EFBFBD>憪?
> **开发状态:** 🔴 未开始
> **负责人:** [待定]
---
## 📋 模块概述
<EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡舀糓銝?*<2A>駁堺摰<E691B0>**<2A>?*<2A><EFBFBD><E691B0>**<2A>𣂷<EFBFBD><F0A382B7><EFBFBD><EFBFBD>滚𦛚蝞∠<E89D9E><E288A0>屸𢒰嚗諹悟<E8ABB9><EFBFBD>蝞∠<E89D9E><E288A0><EFBFBD>憭毺𡠺蝡讠恣<E8AEA0><E681A3>䌊撌梁<E6928C><E6A281><EFBFBD><E79195><EFBFBD><EFBFBD><EFBFBD><E791AF><EFBFBD>憸腈<E686B8><E88588><EFBFBD>摰斤<E691B0><EFBFBD><E99F8F><EFBFBD>?
机构管理端是为**医院客户**和**药企客户**提供的自服务管理界面,让机构管理员能够独立管理自己租户内的用户、配额、科室等资源。
### <EFBFBD><EFBFBD>隞瑕<EFBFBD>?
### 核心价值
1. **<EFBFBD><EFBFBD><EFBFBD>∠恣<EFBFBD>?*嚗𡁜<E59A97>頧餉<E9A0A7><E9A489>亙𣪧<E4BA99><EFBFBD><E7AC94>𨥈<EFBFBD><F0A8A588><EFBFBD><E7AEB8>芯蜓蝞∠<E89D9E>
2. **<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>**嚗𡁜龫<F0A1819C>?<3F><EFBFBD><E887AD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>摰斗<E691B0>銝芯犖<E88AAF><E78A96><EFBFBD>Token憸嘥漲
3. **<EFBFBD><EFBFBD>蝞∠<EFBFBD>**嚗𡁏㦤<F0A1818F><E3A6A4><EFBFBD><EFBFBD>函鍂<E587BD><EFBFBD><E7919E>𥕦遣<F0A595A6><E981A3><EFBFBD>颲㻫<E9A2B2><E3BBAB><EFBFBD><EFBFBD>?
4. **<EFBFBD>唳旿<EFBFBD>𠉛氖**嚗𡁜蘨<F0A1819C><EFBFBD><E8B39C><EFBFBD>蝞∠<E89D9E><E288A0>芸楛蝘<E6A59B><E89D98><EFBFBD><EFBFBD><EFBFBD>?
1. **自服务管理**:减轻运营团队压力,机构自主管理
2. **配额分配**:医院/药企内部按科室或个人分配Token额度
3. **用户管理**:机构内部用户的创建、编辑、停用
4. **数据隔离**:只能看到和管理自己租户的数据
---
## 🎯 核心功能模块
### 1. <EFBFBD>駁堺蝞∠<EFBFBD>蝡荔<EFBFBD>Hospital Admin嚗?
### 1. 医院管理端(Hospital Admin
#### 用户管理
- 添加/编辑/停用医院内部用户
- <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>摰?
- 分配用户到科室
- 设置用户角色(科室管理员/普通用户)
#### 科室管理
- 创建/编辑/删除科室
- <EFBFBD><EFBFBD>憭𡁶漣蝘穃恕蝏𤘪<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>?銝<><E98A9D><EFBFBD>躹嚗?
- 支持多级科室结构(心内科 → 一病区)
- 查看科室成员列表
#### 配额管理
- 查看医院总配额和使用情况
- 按科室分配Token额度
- 按个人分配Token额度
- <EFBFBD><EFBFBD>雿輻鍂蝏蠘恣<EFBFBD><EFBFBD>霅?
- 配额使用统计和预警
#### 审计日志
- <EFBFBD><EFBFBD><EFBFBD>駁堺<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>雿𡏭扇敶?
- 查看医院内部的操作记录
- 导出审计日志
---
### 2. <EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡荔<EFBFBD>Pharma Admin嚗?
### 2. 药企管理端(Pharma Admin
#### 用户管理
- 添加/编辑/停用药企内部用户
- <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>閫坿𠧧嚗<EFBFBD><EFBFBD><EFBFBD><EFBFBD>犖/<2F>唳旿<E594B3><E697BF><EFBFBD>撣?<3F><EFBFBD>𡁶鍂<F0A181B6><EFBFBD>
- 分配用户角色(项目负责人/数据分析师/普通用户)
#### 项目管理
- 查看药企参与的IIT项目列表
- <EFBFBD><EFBFBD>憿寧𤌍餈𥕦<EFBFBD><EFBFBD>峕㺭<EFBFBD><EFBFBD>霈?
- 查看项目进展和数据统计
- 项目成员管理
#### 配额管理
- 查看药企总配额和使用情况
- 按项目分配Token额度
- 按用户分配Token额度
- <EFBFBD><EFBFBD>雿輻鍂蝏蠘恣<EFBFBD><EFBFBD>霅?
- 配额使用统计和预警
#### 审计日志(合规要求)
- <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>㗇㺭<EFBFBD>桐耨<EFBFBD>寡扇敶𤏪<EFBFBD>FDA 21 CFR Part 11嚗?
- 查看所有数据修改记录(FDA 21 CFR Part 11
- 查看IIT模块相关操作
- 导出审计日志(支持签名验证)
---
## <EFBFBD><EFBFBD> 閫坿𠧧銝擧<E98A9D><E693A7>鞱挽霈?
## 🔐 角色与权限设计
### <EFBFBD>駁堺蝡航<EFBFBD><EFBFBD>?
### 医院端角色
| 角色 | 角色Code | 权限范围 | 说明 |
|------|---------|---------|------|
| **<EFBFBD>駁堺蝞∠<EFBFBD><EFBFBD>?* | HOSPITAL_ADMIN | <EFBFBD><EFBFBD>蝥抒恣<EFBFBD>?| 蝞∠<E89D9E><E288A0>駁堺<E9A781><E5A0BA><EFBFBD><EFBFBD><EFBFBD>皞?|
| **蝘穃恕蝞∠<EFBFBD><EFBFBD>?* | DEPARTMENT_ADMIN | 蝘穃恕蝥抒恣<EFBFBD>?| 隞<><EFBFBD><E681A3>䌊撌梁<E6928C>摰?|
| **医院管理员** | HOSPITAL_ADMIN | 租户级管理 | 管理医院内所有资源 |
| **科室管理员** | DEPARTMENT_ADMIN | 科室级管理 | 仅管理自己科室 |
| **医生/用户** | USER | 基础功能 | 使用业务模块 |
### <EFBFBD><EFBFBD>蝡航<EFBFBD><EFBFBD>?
### 药企端角色
| 角色 | 角色Code | 权限范围 | 说明 |
|------|---------|---------|------|
| **<EFBFBD><EFBFBD>蝞∠<EFBFBD><EFBFBD>?* | PHARMA_ADMIN | <EFBFBD><EFBFBD>蝥抒恣<EFBFBD>?| 蝞∠<E89D9E><E288A0><EFBFBD><E887AD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>皞?|
| **憿寧𤌍韐蠘提鈭?* | PROJECT_MANAGER | 憿寧𤌍蝥抒恣<EFBFBD>?| 蝞∠<E89D9E><E288A0><EFBFBD>IIT憿寧𤌍 |
| **<EFBFBD>唳旿<EFBFBD><EFBFBD><EFBFBD>撣?* | DATA_ANALYST | <EFBFBD>芾粉<EFBFBD><EFBFBD><EFBFBD> | <20><EFBFBD>憿寧𤌍<E5AFA7>唳旿<E594B3>峕𥁒<E5B395>?|
| **<EFBFBD><EFBFBD>𡁶鍂<EFBFBD>?* | USER | <20><EFBFBD><E7AE87><EFBFBD> | 雿輻鍂銝𡁜𦛚璅<E79285> |
| **药企管理员** | PHARMA_ADMIN | 租户级管理 | 管理药企内所有资源 |
| **项目负责人** | PROJECT_MANAGER | 项目级管理 | 管理特定IIT项目 |
| **数据分析师** | DATA_ANALYST | 只读权限 | 查看项目数据和报告 |
| **普通用户** | USER | 基础功能 | 使用业务模块 |
---
## 📂 文档结构
```
INST-<EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD> README.md # <EFBFBD><EFBFBD>隞?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD> 00-璅<E79285>敶枏<E695B6><E69E8F><EFBFBD><E59786><EFBFBD><EFBFBD><E69298><EFBFBD><E78390>?md # 敹恍<EFBFBD><EFBFBD><EFBFBD>𧢲<EFBFBD><EFBFBD>?
<EFBFBD>?
INST-机构管理端/
├── README.md # 本文件
├── 00-模块当前状态与开发指南.md # 快速上手指南
├── 00-系统设计/ # 系统架构设计
<EFBFBD>?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD> 01-<2D><><EFBFBD><E79899><EFBFBD>? # PRD<EFBFBD><EFBFBD>
<EFBFBD>?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD> 02-<2D><><EFBFBD>航挽霈? # <EFBFBD><EFBFBD><EFBFBD>航挽霈⊥<EFBFBD>獢?
<EFBFBD>?
├── 01-需求分析/ # PRD文档
├── 02-技术设计/ # 技术设计文档
├── 03-UI设计/ # 原型与UI设计
<EFBFBD>?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD> 04-撘<><E69298>𤏸恣<F0A48FB8>? # <EFBFBD><EFBFBD>𤏸恣<EFBFBD><EFBFBD>隞餃𦛚<EFBFBD><EFBFBD>
<EFBFBD>?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD> 05-瘚贝<E7989A><E8B49D><EFBFBD>/ # 瘚贝<EFBFBD><EFBFBD><EFBFBD>銝擧<EFBFBD>霂閙㺭<EFBFBD>?
<EFBFBD>?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD> 06-撘<><E69298>𤏸扇敶? # 瘥𤩺𠯫撘<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
<EFBFBD>?
├── 04-开发计划/ # 开发计划与任务分解
├── 05-测试文档/ # 测试用例与测试数据
├── 06-开发记录/ # 每日开发总结
└── 07-技术债务/ # 技术债务清单
```
---
## <EFBFBD><EFBFBD>儭?<3F>唳旿摨廍chema
## 🗄️ 数据库Schema
### <EFBFBD><EFBFBD>銵剁<EFBFBD>platform_schema嚗?
### 核心表(platform_schema
- `tenants` - <EFBFBD><EFBFBD>銵剁<EFBFBD><EFBFBD><EFBFBD><EFBFBD>箸𧋦靽⊥<EFBFBD>嚗?
- `tenants` - 租户表(机构基本信息)
- `tenant_members` - 租户成员关系
- `tenant_quotas` - 租户配额
- `tenant_quota_allocations` - <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>摰?銝芯犖/憿寧𤌍嚗?
- `departments` - 蝘穃恕銵剁<EFBFBD><EFBFBD>駁堺銝梶鍂嚗?
- `tenant_operation_logs` - <EFBFBD><EFBFBD>蝥扳<EFBFBD>雿𨀣𠯫敹?
- `tenant_quota_allocations` - 配额分配(科室/个人/项目)
- `departments` - 科室表(医院专用)
- `tenant_operation_logs` - 租户级操作日志
### <EFBFBD><EFBFBD>銵?
### 关联表
- `users` - <EFBFBD><EFBFBD>銵?
- `users` - 用户表
- `iit_projects` - IIT项目表药企端
- `admin_operation_logs` - 摰∟恣<EFBFBD><EFBFBD><EFBFBD><EFBFBD>电odule餈<EFBFBD>誘嚗?
- `admin_operation_logs` - 审计日志可按module过滤
---
## 🚀 技术栈
### 后端
- **<EFBFBD>沲嚗?* Fastify + Prisma
- **框架:** Fastify + Prisma
- **数据库:** PostgreSQL 14+
- **霈方<EFBFBD>嚗?* JWT嚗<54><EFBFBD><EFBFBD><E8BCAF>亦恣<E4BAA6><E681A3>垢嚗?
- **<EFBFBD><EFBFBD><EFBFBD>嚗?* RBAC<EFBFBD><EFBFBD><EFBFBD><EFBFBD>亦恣<EFBFBD><EFBFBD>垢嚗?
- **认证:** JWT继承运营管理端
- **权限:** RBAC(继承运营管理端)
### 前端
- **<EFBFBD>沲嚗?* React 19 + TypeScript
- **框架:** React 19 + TypeScript
- **UI库** Ant Design 6.0
- **状态管理:** React Context + Hooks
- **頝舐眏嚗?* React Router v6
- **路由:** React Router v6
---
@@ -158,39 +158,39 @@ INST-机构管理
### 租户专属登录
```
# <EFBFBD>駁堺蝡舐蒈敶?
# 医院端登录
https://platform.example.com/t/hospital-301/login
# <EFBFBD><EFBFBD>蝡舐蒈敶?
# 药企端登录
https://platform.example.com/t/pharma-abc/login
```
### 品牌定制
- Logo<EFBFBD><EFBFBD><EFBFBD>瑁䌊摰帋<EFBFBD>嚗?
- Logo(租户自定义)
- 背景图(租户自定义)
- 主题色(租户自定义)
- 蝟餌<EFBFBD><EFBFBD>滨妍嚗<EFBFBD><EFBFBD><EFBFBD>瑁䌊摰帋<EFBFBD>嚗?
- 系统名称(租户自定义)
**<EFBFBD>唳旿<EFBFBD><EFBFBD>嚗?* `tenants.config` (JSONB摮埈挾)
**数据来源:** `tenants.config` (JSONB字段)
---
## 📅 开发路线图(待定)
### Phase 1: <EFBFBD>駁堺蝞∠<EFBFBD>蝡烘VP嚗Áeek 5-6嚗?
### Phase 1: 医院管理端MVPWeek 5-6
- [ ] 用户管理界面
- [ ] 科室管理界面
- [ ] 配额分配界面
- [ ] <EFBFBD><EFBFBD>銝枏<EFBFBD><EFBFBD><EFBFBD>憿?
- [ ] 租户专属登录页
### Phase 2: <EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡烘VP嚗Áeek 7-8嚗?
### Phase 2: 药企管理端MVPWeek 7-8
- [ ] 用户管理界面
- [ ] 项目管理界面
- [ ] 配额分配界面
- [ ] 审计日志查询(合规)
### Phase 3: <EFBFBD><EFBFBD><EFBFBD><EFBFBD>嚗Áeek 9+嚗?
### Phase 3: 功能完善Week 9+
- [ ] 统计报表
- [ ] 配额预警
- [ ] 批量操作
@@ -198,39 +198,39 @@ https://platform.example.com/t/pharma-abc/login
---
## <EFBFBD><EFBFBD> 銝舘<E98A9D><E88898>亦恣<E4BAA6><E681A3><EFBFBD><E59EA2><EFBFBD>蝟?
## 🔗 与运营管理端的关系
```
<EFBFBD>𢞖<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
<EFBFBD>? ADMIN - 餈鞱𨯫蝞∠<EFBFBD>蝡荔<EFBFBD><EFBFBD><EFBFBD><EFBFBD>嚗? <EFBFBD>?
<EFBFBD>? <EFBFBD>?
<EFBFBD>? - <EFBFBD>𥕦遣/蝞∠<E89D9E><E288A0><EFBFBD><EFBFBD><EFBFBD><E58EA9>? <EFBFBD>?
<EFBFBD>? - <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>憸? <EFBFBD>?
<EFBFBD>? - <EFBFBD><EFBFBD><EFBFBD><EFBFBD>蝞∠<EFBFBD> <EFBFBD>?
<EFBFBD>? - Prompt蝞∠<EFBFBD> <EFBFBD>?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
<EFBFBD>?
<EFBFBD>?<3F>𥕦遣蝘<E981A3><E89D98> & <20><><EFBFBD><EFBFBD><EFBFBD>
<EFBFBD>?
<EFBFBD>𢞖<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
<EFBFBD>? INST - <EFBFBD><EFBFBD>蝞∠<EFBFBD>蝡荔<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD>?
<EFBFBD>? <EFBFBD>?
<EFBFBD>? <20><20>駁堺蝡? <EFBFBD>?
<EFBFBD>? - 蝞∠<EFBFBD><EFBFBD>駁堺<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD>?
<EFBFBD>? - <EFBFBD><EFBFBD>摰?銝芯犖<E88AAF><E78A96><EFBFBD><EFBFBD><EFBFBD> <EFBFBD>?
<EFBFBD>? - <EFBFBD><EFBFBD><EFBFBD>駁堺<EFBFBD><EFBFBD>恣霈⊥𠯫敹? <EFBFBD>?
<EFBFBD>? <EFBFBD>?
<EFBFBD>? <20><> <20><EFBFBD>蝡? <EFBFBD>?
<EFBFBD>? - 蝞∠<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD>?
<EFBFBD>? - <EFBFBD>厰★<EFBFBD>?銝芯犖<E88AAF><E78A96><EFBFBD><EFBFBD><EFBFBD> <EFBFBD>?
<EFBFBD>? - <EFBFBD><EFBFBD>IIT璅<EFBFBD>摰∟恣<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD>?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
<EFBFBD>?
<EFBFBD>?雿輻鍂銝𡁜𦛚璅<E79285>
<EFBFBD>?
<EFBFBD>𢞖<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
<EFBFBD>? 銝𡁜𦛚璅<EFBFBD>嚗㇁SL/DC/IIT蝑㚁<EFBFBD> <EFBFBD>?
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?
┌────────────────────────────────────────┐
ADMIN - 运营管理端(内部)
- 创建/管理所有租户
- 分配总配额
- 全局用户管理
- Prompt管理
└────────────────────────────────────────┘
│ 创建租户 & 分配配额
┌────────────────────────────────────────┐
INST - 机构管理端(客户自服务)
│ 🏥 医院端
- 管理医院内部用户
- 按科室/个人分配配额
- 查看医院内审计日志
│ 💊 药企端
- 管理药企内部用户
- 按项目/个人分配配额
- 查看IIT模块审计日志合规
└────────────────────────────────────────┘
│ 使用业务模块
┌────────────────────────────────────────┐
业务模块ASL/DC/IIT等)
└────────────────────────────────────────┘
```
---
@@ -242,47 +242,47 @@ https://platform.example.com/t/pharma-abc/login
由于机构管理端尚未开始开发,建议先阅读运营管理端的相关文档:
1. **架构基础**
<EFBFBD>?`../ADMIN-餈鞱𨯫蝞∠<EFBFBD>蝡?00-蝟餌<E89D9F>霈曇恣/00-<2D><><EFBFBD>銝舘<E98A9D><E88898><EFBFBD>蝟餅<E9A485><EFBC94>𥁒<EFBFBD>𠽤v1.0.md`
`../ADMIN-运营管理端/00-系统设计/00-权限与角色体系梳理报告_v1.0.md`
2. **<EFBFBD><EFBFBD><EFBFBD><EFBFBD>獢?*
<EFBFBD>?`../ADMIN-餈鞱𨯫蝞∠<EFBFBD>蝡?01-<2D><><EFBFBD><E79899><EFBFBD>?02-<2D>𡁶鍂<F0A181B6><EFBFBD><EFBFBD>07-餈鞱𨯫銝擧㦤<E693A7><E3A6A4><EFBFBD><E681A3>PRD_v2.1.md`
2. **需求文档**
`../ADMIN-运营管理端/01-需求分析/02-通用能力层_07-运营与机构管理端PRD_v2.1.md`
(该文档同时包含运营端和机构端需求)
### <EFBFBD><EFBFBD>撱箸<EFBFBD>獢?
### 待创建文档
- [ ] `00-蝟餌<EFBFBD>霈曇恣/01-<2D><EFBFBD>蝞∠<E89D9E>蝡舀沲<E88880><E6B2B2>挽霈?md`
- [ ] `01-<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?01-<2D>駁堺蝞∠<E89D9E>蝡烈RD.md`
- [ ] `01-<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>?02-<2D><EFBFBD>蝞∠<E89D9E>蝡烈RD.md`
- [ ] `02-<EFBFBD><EFBFBD><EFBFBD>航挽霈?01-API霈曇恣<E69B87><E681A3>.md`
- [ ] `02-<EFBFBD><EFBFBD><EFBFBD>航挽霈?02-<2D>唳旿摨栞挽霈⊥<E99C88>獢?md`
- [ ] `03-UI霈曇恣/01-<EFBFBD>駁堺蝡臬<EFBFBD><EFBFBD>贝挽霈?html`
- [ ] `03-UI霈曇恣/02-<EFBFBD><EFBFBD>蝡臬<EFBFBD><EFBFBD>贝挽霈?html`
- [ ] `00-系统设计/01-机构管理端架构设计.md`
- [ ] `01-需求分析/01-医院管理端PRD.md`
- [ ] `01-需求分析/02-药企管理端PRD.md`
- [ ] `02-技术设计/01-API设计文档.md`
- [ ] `02-技术设计/02-数据库设计文档.md`
- [ ] `03-UI设计/01-医院端原型设计.html`
- [ ] `03-UI设计/02-药企端原型设计.html`
---
## ⚠️ 注意事项
### 摰匧<EFBFBD><EFBFBD>?
### 安全性
1. **憭𡁶<EFBFBD><EFBFBD><EFBFBD>蝳?*
1. **多租户隔离**
- 所有查询必须带`tenantId`过滤
- <EFBFBD>脫迫頝函<EFBFBD><EFBFBD>瑟㺭<EFBFBD>株挪<EFBFBD>?
- 防止跨租户数据访问
2. **权限控制**
- 蝘穃恕蝞∠<EFBFBD><EFBFBD>睃蘨<EFBFBD>賜恣<EFBFBD><EFBFBD>䌊撌梁<EFBFBD>摰?
- 科室管理员只能管理自己科室
- 项目负责人只能管理自己的项目
3. **审计日志**
- <EFBFBD><EFBFBD><EFBFBD><EFBFBD>雿𨅯<EFBFBD>憿餉扇敶?
- 所有操作必须记录
- 药企端需要满足FDA合规要求
### 性能优化
1. **配额计算**
- 雿輻鍂<EFBFBD>唳旿摨栞<EFBFBD><EFBFBD><EFBFBD>䰻霂?
- 憓𧼮<EFBFBD>蝻枏<EFBFBD><EFBFBD><EFBFBD>app_cache嚗?
- 使用数据库聚合查询
- 增加缓存层(app_cache
2. **蝘穃恕<EFBFBD>烐䰻霂?*
2. **科室树查询**
- 使用递归CTE查询
- 前端缓存科室结构
@@ -290,17 +290,17 @@ https://platform.example.com/t/pharma-abc/login
## 📞 联系方式
- **<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>犖嚗?* [敺<><E695BA>]
- **技术负责人:** [待定]
- **产品负责人:** [待定]
---
## <EFBFBD><EFBFBD><><E69298><EFBFBD>韏?
## 🔄 开发依赖
**前置条件(必须先完成):**
- <EFBFBD>?餈鞱𨯫蝞∠<E89D9E>蝡臬抅蝖<E68A85><E89D96><EFBFBD><EFBFBD>恕霂<E68195><E99C82><EFBFBD><EFBFBD><EFBFBD><EFBFBD><E58390><EFBFBD><EFBFBD>瑞恣<E7919E><E681A3><EFBFBD>
- <EFBFBD>?蝘<><E89D98>銝枏<E98A9D><E69E8F><EFBFBD>憿?
- <EFBFBD>?<3F><><EFBFBD>摰𡁜<E691B0><F0A1819C>滨蔭
- ✅ 运营管理端基础架构(认证、权限、租户管理)
- ✅ 租户专属登录页
- ✅ 品牌定制配置
**可并行开发:**
- 医院端UI设计
@@ -315,4 +315,3 @@ https://platform.example.com/t/pharma-abc/login