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:
@@ -1,82 +1,91 @@
|
||||
# **PRD嚗関ool A \- <EFBFBD>餌<EFBFBD><EFBFBD>唳旿頞<EFBFBD>漣<EFBFBD><EFBFBD>僎<EFBFBD>?(The Super Merger)**
|
||||
# **PRD:Tool A \- 医疗数据超级合并器 (The Super Merger)**
|
||||
|
||||
| <EFBFBD><EFBFBD>﹝<EFBFBD><EFBFBD>𧋦 | V2.0 (<EFBFBD>箏<EFBFBD><EFBFBD>𡁜<EFBFBD><EFBFBD>? |
|
||||
| 文档版本 | V2.0 (基准锚定版) |
|
||||
| :---- | :---- |
|
||||
| **鈭批<EFBFBD>敶X<EFBFBD>?* | Web 蝡臬極<E887AC>瘀<EFBFBD><E79880><EFBFBD>郊<EFBFBD>穃紡撘?Wizard嚗?|
|
||||
| **<EFBFBD>詨<EFBFBD>隞瑕<EFBFBD>?* | **閫<EFBFBD><EFBFBD>銝游<EFBFBD>蝘𤑳<EFBFBD>銝凌<EFBFBD>靝<EFBFBD>撖孵<EFBFBD><EFBFBD>脲㺭<EFBFBD>桀笆朣鞾𠗕憸塩<EFBFBD>?* <20>箔<EFBFBD><E7AE94>𡏭挪閫<E68CAA><E996AB>Visit嚗争<E59A97>嘥<EFBFBD><E598A5>𨀣𧒄<F0A880A3>渡<EFBFBD><E6B8A1>嗪<EFBFBD>餉<EFBFBD>嚗<EFBFBD><E59A97><EFBFBD><EFBFBD>僚<EFBFBD><E5839A><EFBFBD>撉䎚<E69289><E48E9A><EFBFBD><EFBFBD>交㺭<E4BAA4>桃移<E6A183><E7A7BB><EFBFBD>頧賢<E9A0A7>雿誯堺/<2F>刻<EFBFBD>霈啣<E99C88>銝𨳍<E98A9D>?|
|
||||
| **<EFBFBD>格<EFBFBD><EFBFBD>冽<EFBFBD>** | 銝游<EFBFBD><EFBFBD>餌<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>𥪜𨭌<EFBFBD>?|
|
||||
| **产品形态** | Web 端工具(分步向导式 Wizard) |
|
||||
| **核心价值** | **解决临床科研中“一对多”数据对齐难题。** 基于“访视(Visit)”和“时间窗”逻辑,将散乱的化验、检查数据精准挂载到住院/门诊记录上。 |
|
||||
| **目标用户** | 临床医生、科研助理 |
|
||||
|
||||
## **銝<EFBFBD><EFBFBD>?鈭批<E988AD>瘚<EFBFBD><E7989A><EFBFBD>?(User Flow)**
|
||||
## **一、 产品流程图 (User Flow)**
|
||||
|
||||
1\. <EFBFBD>唳旿鋆<EFBFBD>蝸 (Payload) \-\> 2\. 摰𡁜抅<EFBFBD>?(Anchor & Window) \-\> 3\. <EFBFBD>匧<EFBFBD>銝𡡞<EFBFBD>閫?(Schema) \-\> 4\. <EFBFBD>箄<EFBFBD><EFBFBD><EFBFBD>僎 \-\> 5\. 蝏𤘪<EFBFBD>銝擧<EFBFBD>頧?
|
||||
## **鈭䎚<E988AD>?<3F>詨<EFBFBD><E8A9A8>蠘<EFBFBD><E8A098><EFBFBD>瘙?(Functional Requirements)**
|
||||
1\. 数据装载 (Payload) \-\> 2\. 定基准 (Anchor & Window) \-\> 3\. 选列与预览 (Schema) \-\> 4\. 智能合并 \-\> 5\. 结果与流转
|
||||
|
||||
### **1\. 甇仿炊銝<E7828A>嚗𡁏㺭<F0A1818F>株<EFBFBD>頧?(Payload)**
|
||||
## **二、 核心功能需求 (Functional Requirements)**
|
||||
|
||||
* **P0:** **憭𡁏<E686AD>隞嗡<E99A9E>隡𩤃<E99AA1>** <20>舀<EFBFBD><E88880>𡝗嗻銝𠹺<E98A9D> .xlsx, .csv<73><76>遣霈桀之撠?\< 50MB/<2F><>辣<EFBFBD>?
|
||||
* **P0:** **<EFBFBD>芸𢆡憸<EFBFBD><EFBFBD> (Pre-flight Check)嚗?*
|
||||
* 銝𠹺<E98A9D><F0A0B9BA>唾圾<E594BE>鞱”憭氬<E686AD>?
|
||||
* **蝥Y<EFBFBD><EFBFBD>行⏛嚗?* <20><>辣<EFBFBD>惩<EFBFBD><E683A9><EFBFBD>”憭港蛹蝛箝<E89D9B><E7AE9D><EFBFBD>隞嗆<E99A9E><E59786>?\-\> 蝳<>迫銝衤<E98A9D>甇乓<E79487>?
|
||||
* **P1:** **<EFBFBD>㰘蝸<EFBFBD>滨蔭/璅⊥踎嚗?* <20>亦鍂<E4BAA6>瑚<EFBFBD><E7919A>滢<EFBFBD>摮䁅<E691AE><E48185>𡏭<EFBFBD><F0A18FAD>屸秄霂𠰴<E99C82>撟嗉<E6929F><E59789>仮<EFBFBD>嘅<EFBFBD><E59885><EFBFBD>捂銝<E68D82><E98A9D>桀<EFBFBD>頧踝<E9A0A7>頝唾<E9A09D><E594BE>𡒊賒<F0A1928A>滨蔭<E6BBA8>?
|
||||
### **2\. 甇仿炊鈭䕘<E988AD>摰𡁜抅<F0A1819C>?(The Anchor) <20>婙<EFBFBD>?<3F>詨<EFBFBD>蝞埈<E89D9E><E59F88>餉<EFBFBD>**
|
||||
### **1\. 步骤一:数据装载 (Payload)**
|
||||
|
||||
* **P0:** **多文件上传:** 支持拖拽上传 .xlsx, .csv。建议大小 \< 50MB/文件。
|
||||
* **P0:** **自动预检 (Pre-flight Check):**
|
||||
* 上传即解析表头。
|
||||
* **红灯拦截:** 文件加密、表头为空、文件损坏 \-\> 禁止下一步。
|
||||
* **P1:** **加载配置/模板:** 若用户之前保存过“肺癌门诊合并规则”,允许一键加载,跳过后续配置。
|
||||
|
||||
### **2\. 步骤二:定基准 (The Anchor) —— 核心算法逻辑**
|
||||
|
||||
此步骤决定了最终大表的“骨架”(行数)和“归类逻辑”。
|
||||
|
||||
甇斗郊撉文<EFBFBD>摰帋<EFBFBD><EFBFBD><EFBFBD>蝏<EFBFBD>之銵函<EFBFBD><EFBFBD>𣈯爸<EFBFBD>嗯<EFBFBD>嘅<EFBFBD>銵峕㺭嚗匧<EFBFBD><EFBFBD>𨅯<EFBFBD>蝐駁<EFBFBD>餉<EFBFBD><EFBFBD>腈<EFBFBD>?
|
||||
#### **2.1 主表选择 (The Backbone)**
|
||||
|
||||
* **P0:** <EFBFBD>冽<EFBFBD>敹<EFBFBD>◆隞𦒘<EFBFBD>隡删<EFBFBD><EFBFBD><EFBFBD>辣銝剜<EFBFBD>摰帋<EFBFBD>銝芯<EFBFBD>銝?**<2A>靝蜓銵?(Visit Base)<EFBFBD>?*<2A>?
|
||||
* **摰帋<EFBFBD>嚗?* 銝餉”<E9A489><E2809D><EFBFBD>銝<EFBFBD>銵䕘<E98AB5>隞<EFBFBD>”<EFBFBD><E2809D>蝏<EFBFBD>之銵函<E98AB5>銝<EFBFBD>銝芸抅<E88AB8><E68A85><EFBFBD>嚗<EFBFBD><E59A97>甈∪停霂?霈輯<E99C88>嚗剹<E59A97><E589B9><EFBFBD>𡁜虜<F0A1819C>胯<EFBFBD>𠹺<EFBFBD><F0A0B9BA>Z扇敶𨰻<E695B6>𧢲<EFBFBD><F0A7A2B2>𢠃秄霂𦠜<E99C82><F0A6A09C>瑯<EFBFBD>卝<EFBFBD>?
|
||||
#### **2.2 <20>喲睸<E596B2>埈<EFBFBD>撠?(Key Mapping)**
|
||||
* **P0:** 用户必须从上传的文件中指定一个作为 **“主表 (Visit Base)”**。
|
||||
* **定义:** 主表的每一行,代表最终大表的一个基准行(一次就诊/访视)。通常是《住院记录》或《门诊挂号》。
|
||||
|
||||
#### **2.2 关键列映射 (Key Mapping)**
|
||||
|
||||
* **P0:** **ID 列对齐:** 用户需指定主表的 Patient\_ID 列。系统自动在辅表中寻找同名列,允许人工修正。
|
||||
* **P0:** **时间基准列:** 用户需指定主表的 Date 列(如“入院日期”)。这将作为时间窗的圆心。
|
||||
|
||||
* **P0:** **ID <20>堒笆朣琜<E69CA3>** <20>冽<EFBFBD><E586BD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>銝餉”<E9A489>?Patient\_ID <20>𨰜<EFBFBD><F0A8B09C>頂蝏蠘䌊<E8A098>典銁颲<E98A81>”銝剖粉<E58996>曉<EFBFBD><E69B89>滚<EFBFBD>嚗<EFBFBD><E59A97>霈訾犖撌乩耨甇<E880A8><E79487>?
|
||||
* **P0:** **<EFBFBD>園𡢿<EFBFBD>箏<EFBFBD><EFBFBD>梹<EFBFBD>** <20>冽<EFBFBD><E586BD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>銝餉”<E9A489>?Date <20>梹<EFBFBD>憒<EFBFBD><E68692>𨅯<EFBFBD><F0A885AF>X𠯫<EFBCB8>麨<EFBFBD>嘅<EFBFBD><E59885><EFBFBD><EFBFBD>撠<EFBFBD><E692A0>銝箸𧒄<E7AEB8>渡<EFBFBD><E6B8A1><EFBFBD><EFBFBD>敹<EFBFBD><E695B9>?
|
||||
#### **2.3 辅表匹配策略 (Matching Strategy)**
|
||||
|
||||
* **P0:** **<EFBFBD>園𡢿蝒烾<EFBFBD>蝵?(Time Window)嚗?*
|
||||
* 霈曉<EFBFBD>閫<EFBFBD><EFBFBD>嚗朞<EFBFBD>銵函<EFBFBD>璉<EFBFBD><EFBFBD>交𧒄<EFBFBD>游<EFBFBD>憿餃銁 \[銝餉”<E9A489>園𡢿 \- X憭? 銝餉”<E9A489>園𡢿 \+ Y憭坼] <20><>凒<EFBFBD><E58792><EFBFBD>?
|
||||
* **暺䁅恕<EFBFBD>潘<EFBFBD>** $\\pm 7$ 憭押<EFBFBD>?
|
||||
* **P0:** **<EFBFBD>脩<EFBFBD>憭<EFBFBD><EFBFBD> (Collision Handling)嚗?*
|
||||
* *<EFBFBD>箸艶嚗? <20>閙活<E99699>園𡢿蝒堒<E89D92>嚗諹<E59A97>銵冽<E98AB5>憭𡁏辺霈啣<E99C88>嚗<EFBFBD><E59A97><EFBFBD>帋<EFBFBD>銝斗活銵<E6B4BB>撣貉<E692A3>嚗剹<E59A97>?
|
||||
* *<EFBFBD>厰★ A (暺䁅恕 \- 蝥萄<EFBFBD>撅訫<EFBFBD>)嚗? 靽萘<E99DBD><E89098><EFBFBD><EFBFBD>㕑扇敶𨰻<E695B6><F0A8B0BB>蜓銵其縑<E585B6>臬<EFBFBD><E887AC>塚<EFBFBD>銵峕㺭憓𧼮<E68693><F0A7BCAE>?
|
||||
* *<EFBFBD>厰★ B (<EFBFBD><EFBFBD>餈穃龪<EFBFBD>?嚗? 隞<><E99A9E><EFBFBD>嗵氖銝餉”<E9A489>園𡢿<E59C92><F0A1A2BF>餈𤑳<E9A488>銝<EFBFBD><E98A9D>∴<EFBFBD>銝W<E98A9D><EFBCB7>嗡<EFBFBD><E597A1>?
|
||||
### **3\. 甇仿炊銝㚁<E98A9D><E39A81>匧<EFBFBD>銝𡡞<E98A9D>閫?(The Schema)**
|
||||
* **P0:** **时间窗配置 (Time Window):**
|
||||
* 设定规则:辅表的检查时间必须在 \[主表时间 \- X天, 主表时间 \+ Y天\] 范围内。
|
||||
* **默认值:** $\\pm 7$ 天。
|
||||
* **P0:** **冲突处理 (Collision Handling):**
|
||||
* *场景:* 单次时间窗内,辅表有多条记录(如做了两次血常规)。
|
||||
* *选项 A (默认 \- 纵向展开):* 保留所有记录。主表信息复制,行数增加。
|
||||
* *选项 B (最近匹配):* 仅保留离主表时间最近的一条,丢弃其他。
|
||||
|
||||
甇斗郊撉文<EFBFBD>摰帋<EFBFBD><EFBFBD><EFBFBD>蝏<EFBFBD>之銵函<EFBFBD><EFBFBD>𡏭<EFBFBD><EFBFBD>争<EFBFBD>嘅<EFBFBD><EFBFBD>堒捐嚗剹<EFBFBD>?
|
||||
#### **3.1 <20>𤑳𠶖<F0A491B3>㗇𥋘<E39787>?(Tree Picker)**
|
||||
### **3\. 步骤三:选列与预览 (The Schema)**
|
||||
|
||||
* **P0:** 撅閧內<E996A7><E585A7><EFBFBD>㗇<EFBFBD>隞嗥<E99A9E><E597A5>㛖<EFBFBD><E39B96><EFBFBD><EFBFBD>?
|
||||
此步骤决定了最终大表的“血肉”(列宽)。
|
||||
|
||||
#### **3.1 树状选择器 (Tree Picker)**
|
||||
|
||||
* **P0:** 展示所有文件的列结构。
|
||||
* 📂 主表
|
||||
* <EFBFBD>?雿誯堺<E8AAAF>?
|
||||
* <EFBFBD>?霂𦠜鱏
|
||||
* ✅ 住院号
|
||||
* ✅ 诊断
|
||||
* 📂 辅表 A (化验)
|
||||
* <EFBFBD>?<3F>賜<EFBFBD><E8B39C>?
|
||||
* 漎?摰⊥瓲<E28AA5>餌<EFBFBD> (銝滚㗲<E6BB9A>?
|
||||
* **鈭支<EFBFBD>嚗?* <20>舀<EFBFBD><E88880>㗇<EFBFBD>隞嗅<E99A9E><E59785>?<3F>漤<EFBFBD>剹<EFBFBD>?
|
||||
* ✅ 白细胞
|
||||
* ⬜ 审核医生 (不勾选)
|
||||
* **交互:** 支持按文件全选/反选。
|
||||
|
||||
#### **3.2 实时结构预览 (Live Schema Preview)**
|
||||
|
||||
* **P0:** <EFBFBD>典<EFBFBD>撟訫𢰧靘批<EFBFBD><EFBFBD>嗅<EFBFBD>蝷暝*\*<2A>𨀣<EFBFBD>蝏<EFBFBD>”憭渡<E686AD><E6B8A1><EFBFBD><EFBFBD>𩄼*\*嚗<><E59A97>銵典仍嚗䔶<E59A97>霈∠<E99C88><E288A0>唳旿嚗剹<E59A97>?
|
||||
* **隞瑕<EFBFBD>潘<EFBFBD>** 霈拍鍂<E68B8D>瑞凒閫<E58792><E996AB><EFBFBD>堆<EFBFBD><E5A086>𨅯𣑐嚗<F0A39190><E59A97><EFBFBD>交<EFBFBD><E4BAA4><EFBFBD>”隡𡁜<E99AA1><F0A1819C>鞱<EFBFBD>銋<EFBFBD>鵭嚗<E9B5AD><E59A97><EFBFBD>怨<EFBFBD>鈭𥕦<E988AD><F0A595A6>腈<EFBFBD>?
|
||||
### **4\. 甇仿炊<E4BBBF>𨥈<EFBFBD>蝏𤘪<E89D8F>銝擧<E98A9D>頧?(The Result)**
|
||||
* **P0:** 在屏幕右侧实时展示\*\*“最终表头结构”\*\*(仅表头,不计算数据)。
|
||||
* **价值:** 让用户直观看到:“哦,原来我的表会变成这么长,包含这些列”。
|
||||
|
||||
* **P0:** **憭<><E686AD>餈𥕦漲<F0A595A6>∴<EFBFBD>** <20>曄內<E69B84>冽<EFBFBD><E586BD><EFBFBD>獢<EFBFBD><E78DA2><EFBFBD>𨀣迤<F0A880A3>冽<EFBFBD>撱箏<E692B1>撣𣬚揣撘?..<2E>腈<EFBFBD><E88588><EFBFBD>𨀣迤<F0A880A3>刻<EFBFBD>銵峕𧒄<E5B395>渡<EFBFBD>蝣唳<E89DA3>...<2E>嘅<EFBFBD><E59885>?
|
||||
* **P0:** **暺<><E69ABA>憸<EFBFBD><E686B8> (Golden Preview)嚗?*
|
||||
* 敹<EFBFBD>◆撅閧內<EFBFBD><EFBFBD>僎蝏𤘪<EFBFBD><EFBFBD>?**<2A>?5-10 銵?* <20>笔<EFBFBD><E7AC94>唳旿<E594B3>?
|
||||
* <20>其<EFBFBD><E585B6>冽<EFBFBD><E586BD>厩尐<E58EA9>詨笆 ID <20>臬炏撖寥<E69296><E5AFA5>?
|
||||
* **P0:** **韐券<E99F90><E588B8>𧢲踎嚗?*
|
||||
* <EFBFBD>𣂼<EFBFBD><EFBFBD><EFBFBD><EFBFBD>銵峕㺭<EFBFBD>?
|
||||
* 銝W<E98A9D>銵峕㺭嚗㇆D銝滚龪<E6BB9A>齿<EFBFBD><E9BDBF>園𡢿蝒堒<E89D92>嚗剹<E59A97>?
|
||||
* **P0:** **銵<>𢆡瘚<F0A286A1>蓮嚗?*
|
||||
### **4\. 步骤四:结果与流转 (The Result)**
|
||||
|
||||
* **P0:** **处理进度条:** 显示动态文案(“正在构建哈希索引...”、“正在进行时间窗碰撞...”)。
|
||||
* **P0:** **黄金预览 (Golden Preview):**
|
||||
* 必须展示合并结果的 **前 5-10 行** 真实数据。
|
||||
* 用于用户肉眼核对 ID 是否对齐。
|
||||
* **P0:** **质量看板:**
|
||||
* 成功生成行数。
|
||||
* 丢弃行数(ID不匹配或时间窗外)。
|
||||
* **P0:** **行动流转:**
|
||||
* \[下载 Excel\]
|
||||
* \[发送到 AI 结构化工具\] (流转 Token)
|
||||
* \[发送到 编辑器清洗\] (流转 Token)
|
||||
|
||||
## **銝剹<EFBFBD>?<3F>詨<EFBFBD>蝞埈<E89D9E><E59F88>餉<EFBFBD> (Technical Logic)**
|
||||
## **三、 核心算法逻辑 (Technical Logic)**
|
||||
|
||||
### **1\. 蝞埈<EFBFBD><EFBFBD>滨妍嚗𡁜抅鈭擧𧒄<EFBFBD>渡<EFBFBD><EFBFBD><EFBFBD><EFBFBD>撣峕<EFBFBD>撘讛<EFBFBD><EFBFBD>?(Time-Windowed Stream Hash Join)**
|
||||
### **1\. 算法名称:基于时间窗的哈希流式连接 (Time-Windowed Stream Hash Join)**
|
||||
|
||||
### **2\. <EFBFBD>扯<EFBFBD>隡芯誨<EFBFBD>?*
|
||||
### **2\. 执行伪代码**
|
||||
|
||||
// 1\. 内存构建 (Build Phase)
|
||||
// 撠<EFBFBD><EFBFBD>銵?(Small Tables) 霂餃<EFBFBD><EFBFBD><EFBFBD><EFBFBD> Map
|
||||
// 将辅表 (Small Tables) 读入内存 Map
|
||||
const lookupMap \= {
|
||||
"patient\_001": \[
|
||||
{ type: "lab", date: "2023-01-02", data: {...} }, // 记录1
|
||||
@@ -107,14 +116,16 @@ streamMainTable.on('data', (mainRow) \=\> {
|
||||
}
|
||||
});
|
||||
|
||||
## **<EFBFBD>䜘<EFBFBD>?<3F>屸𢒰<E5B1B8>笔<EFBFBD><E7AC94><EFBFBD><EFBFBD>?(UI Reference)**
|
||||
## **四、 界面原型参考 (UI Reference)**
|
||||
|
||||
霂瑕<EFBFBD><EFBFBD>?撌亙<E6928C>A\_頞<5F>漣<EFBFBD><E6BCA3>僎<EFBFBD>沔_<E6B294>笔<EFBFBD>霈曇恣.tsx (V1.0) 銝剔<EFBFBD> Step 2 <EFBFBD>?Step 3 <EFBFBD>屸𢒰<EFBFBD>?
|
||||
* **Step 2 <20>滨<EFBFBD>嚗?* 銝餉”<E9A489>㗇𥋘<E39787>閖<EFBFBD>㗇<EFBFBD><E39787><EFBFBD>𧒄<EFBFBD>游<EFBFBD>銝𧢲<E98A9D>獢<EFBFBD><E78DA2><EFBFBD><EFBFBD><EFBFBD>亙<EFBFBD><E4BA99>厰僼<E58EB0>?
|
||||
* **Step 3 <20>滨<EFBFBD>嚗?* 撌血𢰧<E8A180><F0A2B0A7><EFBFBD>撣<EFBFBD><E692A3>嚗<EFBFBD>椰靘扳<E99D98><E689B3>嗅㗲<E59785>㚁<EFBFBD><E39A81>喃儒銵冽聢撉冽沲憸<E6B2B2><E686B8>嚗剹<E59A97>?
|
||||
## **鈭𢛵<E988AD>?憌𡡞埯閫<E59FAF><E996AB>璉<EFBFBD><E79289>?(Risk Check)**
|
||||
请参考 工具A\_超级合并器\_原型设计.tsx (V1.0) 中的 Step 2 和 Step 3 界面。
|
||||
|
||||
* **Step 2 重点:** 主表选择单选框、时间列下拉框、策略单选钮。
|
||||
* **Step 3 重点:** 左右分栏布局(左侧树状勾选,右侧表格骨架预览)。
|
||||
|
||||
## **五、 风险规避检查 (Risk Check)**
|
||||
|
||||
1. **用户选错主表怎么办?**
|
||||
* *撖寧<EFBFBD>嚗? <20>?Step 2 <20>屸𢒰憓𧼮<E68693><F0A7BCAE>曄尐<E69B84>?**Tip**嚗尠<E59A97>靝蜓銵券<E98AB5>𡁜虜<F0A1819C>臬<EFBFBD><E887AC>徉<EFBFBD>睃<EFBFBD><E79D83>X𠯫<EFBCB8>麨<EFBFBD>蹱<EFBFBD><E8B9B1>䁅<EFBFBD><E48185>凋縑<E5878B>胼<EFBFBD>嗵<EFBFBD>銵冽聢<E586BD>腈<EFBFBD>?
|
||||
* *对策:* 在 Step 2 界面增加显眼的 **Tip**:“主表通常是包含‘入院日期’或‘诊断信息’的表格”。
|
||||
2. **时间格式乱七八糟怎么办?**
|
||||
* *撖寧<E69296>嚗? <20>𡒊垢<F0A1928A>刻圾<E588BB>鞉𧒄<E99E89>游<EFBFBD><E6B8B8>塚<EFBFBD>敹<EFBFBD>◆雿輻鍂撘箏<E69298><E7AE8F>?Parser嚗<EFBFBD>𣈲<EFBFBD>?2023/1/1, 2023-01-01, 44927 蝑㗇聢撘𧶏<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>𡏭圾<EFBFBD>𣂼仃韐伐<EFBFBD>敶雴蛹<EFBFBD>𨀣𧒄<EFBFBD>湔<EFBFBD><EFBFBD><EFBFBD><EFBFBD>嘅<EFBFBD>銝滩<EFBFBD>銵<EFBFBD>龪<EFBFBD>溻<EFBFBD>
|
||||
* *对策:* 后端在解析时间列时,必须使用强力的 Parser(支持 2023/1/1, 2023-01-01, 44927 等格式)。如果解析失败,归为“时间无效”,不进行匹配。
|
||||
Reference in New Issue
Block a user