feat(aia): Complete AIA V2.0 with universal streaming capabilities
Major Changes: - Add StreamingService with OpenAI Compatible format - Upgrade Chat component V2 with Ant Design X integration - Implement AIA module with 12 intelligent agents - Update API routes to unified /api/v1 prefix - Update system documentation Backend (~1300 lines): - common/streaming: OpenAI Compatible adapter - modules/aia: 12 agents, conversation service, streaming integration - Update route versions (RVW, PKB to v1) Frontend (~3500 lines): - modules/aia: AgentHub + ChatWorkspace (100% prototype restoration) - shared/Chat: AIStreamChat, ThinkingBlock, useAIStream Hook - Update API endpoints to v1 Documentation: - AIA module status guide - Universal capabilities catalog - System overview updates - All module documentation sync Tested: Stream response verified, authentication working Status: AIA V2.0 core completed (85%)
This commit is contained in:
@@ -1,158 +1,141 @@
|
||||
# **憯寡<E686AF>敺服I撟喳蝱 \- 餈鞱𨯫銝擧㦤<E693A7><E3A6A4>恣<EFBFBD><E681A3>垢 PRD**
|
||||
|
||||
文档版本: v2.1
|
||||
状态: 待开发 (Ready for Dev)
|
||||
<EFBFBD><EFBFBD>﹝<EFBFBD><EFBFBD>𧋦嚗?v2.1
|
||||
<EFBFBD>嗆<EFBFBD><EFBFBD><EFBFBD> 敺<><E695BA><EFBFBD>?(Ready for Dev)
|
||||
隡睃<EFBFBD>蝥改<EFBFBD> P0
|
||||
架构模式: 模块化单体 (Modular Monolith)
|
||||
更新摘要: 新增“品牌定制”需求;定义专属登录页 URL 规范;细化租户配置字段。
|
||||
<EFBFBD>嗆<EFBFBD>璅∪<EFBFBD>嚗?璅∪<E79285><E288AA>硋<EFBFBD>雿?(Modular Monolith)
|
||||
<EFBFBD>湔鰵<EFBFBD>䁅<EFBFBD>嚗?<3F>啣<EFBFBD><E595A3>𨅯<EFBFBD><F0A885AF><EFBFBD><EFBFBD><EFBFBD>嗯<EFBFBD>嗪<EFBFBD>瘙<EFBFBD><E79899>摰帋<E691B0>銝枏<E98A9D><E69E8F>餃<EFBFBD>憿?URL 閫<><E996AB>嚗𤤿<E59A97><F0A4A4BF>𣇉<EFBFBD><F0A38789>琿<EFBFBD>蝵桀<E89DB5>畾萸<E795BE>?
|
||||
## **1\. 銝𡁜𦛚<F0A1819C>峕艶銝𡡞<E98A9D>瘙<EFBFBD><E79899><EFBFBD>?(Context & Requirements)**
|
||||
|
||||
## **1\. 业务背景与需求分析 (Context & Requirements)**
|
||||
|
||||
### **1.1 为什么要做管理端?(Why)**
|
||||
### **1.1 銝箔<E98A9D>銋<EFBFBD><E98A8B><EFBFBD>𡁶恣<F0A181B6><E681A3>垢嚗?Why)**
|
||||
|
||||
<EFBFBD>桀<EFBFBD><EFBFBD><EFBFBD>頂蝏<EFBFBD><EFBFBD>User App嚗㗇糓銝<E7B393>銝芸撩憭抒<E686AD><E68A92>訫<EFBFBD>雿𨀣<E99BBF>撌亙<E6928C>嚗䔶<E59A97>閬<EFBFBD>蓮<EFBFBD>碶蛹<E7A2B6>航<EFBFBD>璅∪<E79285><E288AA><EFBFBD><EFBFBD>桃<EFBFBD> **SaaS <20><><EFBFBD>鈭批<E988AD>**嚗峕<E59A97>隞祇𢒰銝氯<E98A9D>𦦵恣<F0A6A6B5><E681A3><EFBFBD>蝛算<E89D9B>嘅<EFBFBD>
|
||||
|
||||
1. **无法交付 B 端**:医院买了系统,科主任无法把账号分给医生,药企买了系统,无法监控项目进度。
|
||||
2. **AI 成本黑洞**:缺乏全局视角的 Token 消耗监控,单次大规模任务可能导致亏损。
|
||||
3. **研发效能瓶颈**:每次调整 Prompt(提示词)都需要改代码、发版,无法快速响应临床专家对 AI 效果的反馈。
|
||||
1. **<EFBFBD>䭾<EFBFBD>鈭支<EFBFBD> B 蝡?*嚗𡁜龫<F0A1819C>V僭鈭<E583AD>頂蝏<E9A082><E89D8F>蝘睲蜓隞餅<E99A9E>瘜閙<E7989C>韐血噡<E8A180><E599A1><EFBFBD><EFBFBD>餌<EFBFBD>嚗諹晓隡<E69993>僭鈭<E583AD>頂蝏<E9A082><E89D8F><EFBFBD>䭾<EFBFBD><E4ADBE>烐綉憿寧𤌍餈𥕦漲<F0A595A6>?
|
||||
2. **AI <EFBFBD>鞉𧋦暺烐<EFBFBD>**嚗𡁶撩銋誩<E98A8B>撅<EFBFBD>閫<EFBFBD><E996AB><EFBFBD>?Token 瘨<><E798A8>㛖<EFBFBD><E39B96>改<EFBFBD><E694B9>閙活憭扯<E686AD>璅∩遙<E288A9>∪虾<E288AA>賢紡<E8B3A2>港<EFBFBD><E6B8AF>麄<EFBFBD>?
|
||||
3. **<EFBFBD>𥪜<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>園<EFBFBD>**嚗𡁏<E59A97>甈∟<E79488><E2889F>?Prompt嚗<74><E59A97>蝷箄<E89DB7>嚗厰<E59A97><E58EB0><EFBFBD>閬<EFBFBD>㺿隞<E3BABF><E99A9E><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>䭾<EFBFBD>敹恍<E695B9>笔<EFBFBD>摨𥪯葩摨𠹺<E691A8>摰嗅笆 AI <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>擐<EFBFBD><E69390>?
|
||||
### **1.2 撌桀<E6928C><E6A180>㚚<EFBFBD>瘙<EFBFBD>𤫇<EFBFBD>?(Who needs what)**
|
||||
|
||||
### **1.2 差异化需求画像 (Who needs what)**
|
||||
#### **A. 餈鞱𨯫蝞∠<E89D9E>蝡?(Ops) \- "銝𠰴<E98A9D>閫<EFBFBD><E996AB>"**
|
||||
|
||||
#### **A. 运营管理端 (Ops) \- "上帝视角"**
|
||||
* **<2A>𤤿<EFBFBD>**嚗帋<E59A97><E5B88B>仿<EFBFBD>靚<EFBFBD>銁<EFBFBD>剁<EFBFBD>銝滨䰻<E6BBA8>栞<EFBFBD>鈭<EFBFBD><E988AD>撠煾兝嚗䔶<E59A97><E494B6>a<EFBFBD>靘踹<E99D98><E8B8B9>啁<EFBFBD><E59581>?
|
||||
* **<2A>詨<EFBFBD>霂㗇<E99C82>**嚗?
|
||||
* **撘<><E69298>?*嚗𡁶<E59A97><F0A181B6>駁堺/<2F>臭<EFBFBD>撘<EFBFBD><E69298>𡁶<EFBFBD><F0A181B6>瘀<EFBFBD><E79880>滨蔭璅∪<E79285>嚗<EFBFBD><E59A97>隞<EFBFBD>銋<EFBFBD><E98A8B>靚<EFBFBD><E99D9A><EFBFBD>?
|
||||
* **靚<><E99D9A>**嚗𡁜銁銝齿<E98A9D><E9BDBF>啁鍂<E59581>瑞<EFBFBD><E7919E><EFBFBD><EFBFBD>銝页<E98A9D>靚<EFBFBD><E99D9A> AI Prompt<70>?
|
||||
* **憌擧綉**嚗𡁶<E59A97><F0A181B6>?Token 瘨<><E798A8>梹<EFBFBD>撘<EFBFBD>虜<EFBFBD>娍鱏<E5A88D>?
|
||||
#### **B. <20>駁堺<E9A781>箸<EFBFBD>蝡?(Hospital Admin) \- "蝞∩犖銝𡒊恣<F0A1928A>?**
|
||||
|
||||
* **痛点**:不知道谁在用,不知道花了多少钱,不敢随便发新版。
|
||||
* **核心诉求**:
|
||||
* **开户**:给医院/药企开通租户,配置模块(卖什么给谁)。
|
||||
* **调优**:在不打扰用户的情况下,调试 AI Prompt。
|
||||
* **风控**:监控 Token 消耗,异常熔断。
|
||||
|
||||
#### **B. 医院机构端 (Hospital Admin) \- "管人与管钱"**
|
||||
|
||||
* **痛点**:医生流动性大,科研经费分配难。
|
||||
* **核心诉求**:
|
||||
* **品牌归属感**:登录页必须是医院自己的大楼照片和 Logo,体现“本院科研平台”的专属感。
|
||||
* **层级管理**:按“科室”管理医生(如心内科、肿瘤科)。
|
||||
* **配额分配**:将购买的总 Token 额度分配给不同科室或个人。
|
||||
|
||||
#### **C. 药企机构端 (Pharma Admin) \- "管项目与合规"**
|
||||
|
||||
* **痛点**:IIT 项目分散在多家医院,数据进度不透明,合规风险大。
|
||||
* **核心诉求**:
|
||||
* **品牌定制**:药企 Logo 必须时刻可见,符合企业 VI 规范。
|
||||
* **项目视图**:不是管人,而是管“项目”(如某抗癌药临床研究)。
|
||||
* **审计合规**:所有操作必须有痕迹(Audit Log)。
|
||||
* **<EFBFBD>𤤿<EFBFBD>**嚗𡁜龫<F0A1819C><E9BEAB><EFBFBD><EFBFBD>冽<EFBFBD>批之嚗𣬚<E59A97><F0A3AC9A>𠉛<EFBFBD>韐孵<E99F90><E5ADB5>漤𠗕<E6BCA4>?
|
||||
* **<EFBFBD>詨<EFBFBD>霂㗇<EFBFBD>**嚗?
|
||||
* **<EFBFBD><EFBFBD><EFBFBD>敶鍦<EFBFBD><EFBFBD>?*嚗𡁶蒈敶閖△敹<E296B3>◆<EFBFBD>臬龫<E887AC>Z䌊撌梁<E6928C>憭扳未<E689B3>抒<EFBFBD><E68A92>?Logo嚗䔶<E59A97><E494B6>售<EFBFBD>𨀣𧋦<F0A880A3>Y<EFBFBD><EFBCB9>𥪜像<F0A5AA9C>售<EFBFBD>萘<EFBFBD>銝枏<E98A9D><E69E8F>麄<EFBFBD>?
|
||||
* **撅<EFBFBD>漣蝞∠<EFBFBD>**嚗𡁏<E59A97><F0A1818F>𦦵<EFBFBD>摰手<E691B0>萘恣<E89098><E681A3>龫<EFBFBD><E9BEAB><EFBFBD>憒<EFBFBD><E68692><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>斤<EFBFBD>嚗剹<E59A97>?
|
||||
* **<EFBFBD>漤<EFBFBD><EFBFBD><EFBFBD><EFBFBD>**嚗𡁜<E59A97>韐凋僭<E5878B><E583AD><EFBFBD>?Token 憸嘥漲<E598A5><E6BCB2><EFBFBD>蝏嗘<E89D8F><E59798>𣬚<EFBFBD>摰斗<E691B0>銝芯犖<E88AAF>?
|
||||
#### **C. <20>臭<EFBFBD><E887AD>箸<EFBFBD>蝡?(Pharma Admin) \- "蝞⊿★<E28ABF>桐<EFBFBD><E6A190><EFBFBD><EFBFBD>"**
|
||||
|
||||
* **<2A>𤤿<EFBFBD>**嚗䥑IT 憿寧𤌍<E5AFA7><F0A48C8D>袇<EFBFBD>典<EFBFBD>摰嗅龫<E59785>g<EFBFBD><EFBD87>唳旿餈𥕦漲銝漤<E98A9D>𤩺<EFBFBD>嚗<EFBFBD><E59A97>閫<EFBFBD><E996AB><EFBFBD>拙之<E68B99>?
|
||||
* **<2A>詨<EFBFBD>霂㗇<E99C82>**嚗?
|
||||
* **<2A><><EFBFBD>摰𡁜<E691B0>**嚗朞晓隡?Logo 敹<>◆<EFBFBD>嗅<EFBFBD><E59785>航<EFBFBD>嚗𣬚泵<F0A3AC9A><E6B3B5><EFBFBD>銝?VI 閫<><E996AB><EFBFBD>?
|
||||
* **憿寧𤌍閫<F0A48C8D>㦛**嚗帋<E59A97><E5B88B>舐恣鈭綽<E988AD><E7B6BD>峕糓蝞﹦<E89D9E>𣈯★<F0A388AF>栽<EFBFBD>嘅<EFBFBD>憒<EFBFBD><E68692><EFBFBD>㛖<EFBFBD><E39B96>臭葩摨羓<E691A8>蝛塚<E89D9B><E5A19A>?
|
||||
* **摰∟恣<E2889F><E681A3><EFBFBD>**嚗𡁏<E59A97><F0A1818F>㗇<EFBFBD>雿𨅯<E99BBF>憿餅<E686BF><E9A485>閗蕨嚗㇁udit Log嚗剹<E59A97>?
|
||||
## **2\. <20>詨<EFBFBD><E8A9A8>嗆<EFBFBD><E59786>喟<EFBFBD> (Architecture)**
|
||||
|
||||
1. **模块化单体**:继续沿用 /frontend-v2 单一代码库。通过**路由懒加载**区分不同端。
|
||||
2. **数据隔离**:逻辑隔离(tenant\_id)。
|
||||
3. **生产环境灰度**:支持管理员/调试者在生产环境使用 Draft 版 Prompt。
|
||||
4. **动态品牌渲染**:前端根据 URL 路径或租户 ID,动态加载 CSS 变量和图片资源,实现“千人千面”的 UI。
|
||||
|
||||
## **3\. 角色与权限体系 (RBAC v2)**
|
||||
|
||||
**设计原则**:基于租户类型(Tenant Type)动态衍生角色。
|
||||
1. **璅∪<EFBFBD><EFBFBD>硋<EFBFBD>雿?*嚗𡁶誧蝏剜窒<E5899C>?/frontend-v2 <20>蓥<EFBFBD>隞<EFBFBD><E99A9E>摨瓐<E691A8><E79390><EFBFBD>朞<EFBFBD>**頝舐眏<E88890>鍦<EFBFBD>頧?*<2A>箏<EFBFBD>銝滚<E98A9D>蝡胯<E89DA1>?
|
||||
2. **<EFBFBD>唳旿<EFBFBD>𠉛氖**嚗𡁻<E59A97>餉<EFBFBD><E9A489>𠉛氖嚗ōenant\_id嚗剹<EFBFBD>?
|
||||
3. **<EFBFBD>煺漣<EFBFBD>臬<EFBFBD><EFBFBD>啣漲**嚗𡁏𣈲<F0A1818F><F0A388B2>恣<EFBFBD><E681A3><EFBFBD>/靚<><E99D9A><EFBFBD><EFBFBD>銁<EFBFBD>煺漣<E785BA>臬<EFBFBD>雿輻鍂 Draft <EFBFBD>?Prompt<EFBFBD>?
|
||||
4. **<EFBFBD>冽<EFBFBD><EFBFBD><EFBFBD><EFBFBD>峕葡<EFBFBD>?*嚗𡁜<E59A97>蝡舀覔<E88880>?URL 頝臬<E9A09D><E887AC>𣇉<EFBFBD><F0A38789>?ID嚗<44>𢆡<EFBFBD><F0A286A1><EFBFBD>頧?CSS <20>㗛<EFBFBD><E3979B><EFBFBD>㦛<EFBFBD><E3A69B><EFBFBD>皞琜<E79A9E>摰䂿緵<E482BF>𨅯<EFBFBD>鈭箏<E988AD><E7AE8F>T<EFBFBD>萘<EFBFBD> UI<EFBFBD>?
|
||||
## **3\. 閫坿𠧧銝擧<E98A9D><E693A7>𣂷<EFBFBD>蝟?(RBAC v2)**
|
||||
|
||||
**霈曇恣<E69B87>笔<EFBFBD>**嚗𡁜抅鈭𡒊<E988AD><F0A1928A>瑞掩<E7919E>页<EFBFBD>Tenant Type嚗匧𢆡<E58CA7><F0A286A1><EFBFBD><EFBFBD>蠘<EFBFBD><E8A098>脯<EFBFBD>?
|
||||
| 閫坿𠧧 Code | 敶鍦<E695B6> | <20><><EFBFBD><EFBFBD><EFBFBD>凒 | URL <20>滨<EFBFBD> | <20>詨<EFBFBD><E8A9A8>諹提 |
|
||||
| :---- | :---- | :---- | :---- | :---- |
|
||||
| **SUPER\_ADMIN** | 撟喳蝱 | <20>典<EFBFBD><E585B8>唳旿 | /admin | 蝘<><E89D98>撘<EFBFBD><E69298>𠾼<EFBFBD><F0A0BEBC><EFBFBD><EFBFBD>屸<EFBFBD>蝵柴<E89DB5><E69FB4>rompt 靚<><E99D9A> |
|
||||
| **HOSPITAL\_ADMIN** | 医院租户 | 本院数据 | /org/hospital | 科室管理、配额分配 |
|
||||
| **PHARMA\_ADMIN** | 药企租户 | 本企项目 | /org/pharma | 项目监控、CRO 管理、审计 |
|
||||
| **USER** | 任意租户 | 个人/被授权数据 | /app | 科研业务操作 |
|
||||
| **HOSPITAL\_ADMIN** | <EFBFBD>駁堺蝘<EFBFBD><EFBFBD> | <20>祇堺<E7A587>唳旿 | /org/hospital | 蝘穃恕蝞∠<EFBFBD><EFBFBD><EFBFBD><EFBFBD>憸嘥<EFBFBD><EFBFBD>?|
|
||||
| **PHARMA\_ADMIN** | <EFBFBD>臭<EFBFBD>蝘<EFBFBD><EFBFBD> | <20>砌<EFBFBD>憿寧𤌍 | /org/pharma | 憿寧𤌍<EFBFBD>烐綉<EFBFBD><EFBFBD>RO 蝞∠<E89D9E><E288A0><EFBFBD>恣霈?|
|
||||
| **USER** | 隞餅<EFBFBD>蝘<EFBFBD><EFBFBD> | 銝芯犖/鋡急<E98BA1><E680A5><EFBFBD>㺭<EFBFBD>?| /app | 蝘𤑳<E89D98>銝𡁜𦛚<F0A1819C>滢<EFBFBD> |
|
||||
|
||||
## **4\. 品牌定制与专属登录设计 (Tenant Branding) \[v2.1 新增\]**
|
||||
## **4\. <EFBFBD><EFBFBD><EFBFBD>摰𡁜<EFBFBD>銝𦒘<EFBFBD>撅䂿蒈敶閗挽霈?(Tenant Branding) \[v2.1 <EFBFBD>啣<EFBFBD>\]**
|
||||
|
||||
### **4.1 URL 蝑𣇉裦 (URL Strategy)**
|
||||
|
||||
为了低成本实现专属登录页,采用 **路径前缀** 方案,而非子域名方案。
|
||||
|
||||
* **通用登录**:https://app.yizhengxun.com/auth/login (显示壹证循默认 UI)
|
||||
銝箔<EFBFBD>雿擧<EFBFBD><EFBFBD>砍<EFBFBD><EFBFBD>唬<EFBFBD>撅䂿蒈敶閖△嚗屸<EFBFBD><EFBFBD>?**頝臬<E9A09D><E887AC>滨<EFBFBD>** <20>寞<EFBFBD>嚗諹<E59A97>屸<EFBFBD>摮𣂼<E691AE><F0A382BC>齿䲮獢<E4B2AE><E78DA2>?
|
||||
* **<2A>𡁶鍂<F0A181B6>餃<EFBFBD>**嚗冴ttps://app.yizhengxun.com/auth/login (<28>曄內憯寡<E686AF>敺芷<E695BA>霈?UI)
|
||||
* **銝枏<E98A9D><E69E8F>餃<EFBFBD>**嚗冴ttps://app.yizhengxun.com/t/{tenant\_code}/login
|
||||
* 蝷箔<E89DB7>嚗𡁜<E59A97>鈭祉妖瘞湔蔬<E6B994>駁堺 \-\> /t/jst-hospital/login
|
||||
* 示例:恒瑞医药 \-\> /t/hengrui/login
|
||||
* 蝷箔<EFBFBD>嚗𡁏<EFBFBD><EFBFBD>𧼮龫<EFBFBD>?\-\> /t/hengrui/login
|
||||
|
||||
### **4.2 蝘<><E89D98><EFBFBD>滨蔭摮埈挾 (Tenant Config)**
|
||||
|
||||
在 platform\_schema.tenants 表的 config JSONB 字段中扩展以下属性:
|
||||
<EFBFBD>?platform\_schema.tenants 銵函<EFBFBD> config JSONB 摮埈挾銝剜<EFBFBD>撅蓥誑銝见<EFBFBD><EFBFBD>改<EFBFBD>
|
||||
|
||||
{
|
||||
"branding": {
|
||||
"logoUrl": "https://oss.../jst\_logo.png", // <20>箸<EFBFBD> Logo (<28>𤩺<EFBFBD><F0A4A9BA>峕艶)
|
||||
"loginBackgroundUrl": "https://oss.../jst\_bldg.jpg", // 登录页背景大图
|
||||
"primaryColor": "\#0056b3", // 品牌主色调 (积水潭蓝)
|
||||
"welcomeTitle": "北京积水潭医院 AI 临床科研平台", // 登录页大标题
|
||||
"welcomeSubTitle": "智能化 · 规范化 · 高效率" // 登录页副标题
|
||||
"loginBackgroundUrl": "https://oss.../jst\_bldg.jpg", // <EFBFBD>餃<EFBFBD>憿菔<EFBFBD><EFBFBD>臬之<EFBFBD>?
|
||||
"primaryColor": "\#0056b3", // <EFBFBD><EFBFBD><EFBFBD>銝餉𠧧靚?(蝘舀偌瞏剛<E79E8F>)
|
||||
"welcomeTitle": "<EFBFBD>𦯀漪蝘舀偌瞏剖龫<EFBFBD>?AI 銝游<E98A9D>蝘𤑳<E89D98>撟喳蝱", // <EFBFBD>餃<EFBFBD>憿萄之<EFBFBD><EFBFBD><EFBFBD>
|
||||
"welcomeSubTitle": "<EFBFBD>箄<EFBFBD><EFBFBD>?繚 閫<><E996AB><EFBFBD>?繚 擃䀹<E69383><E480B9>? // <EFBFBD>餃<EFBFBD>憿萄<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
}
|
||||
}
|
||||
|
||||
### **4.3 鈭支<E988AD>瘚<EFBFBD><E7989A> (User Flow)**
|
||||
|
||||
1. **访问**:用户点击医院内网链接 /t/jst-hospital/login。
|
||||
2. **加载配置**:前端解析 URL 中的 jst-hospital,调用公开 API /api/public/tenant-config?code=jst-hospital。
|
||||
3. **渲染**:
|
||||
* 替换默认背景图为 loginBackgroundUrl。
|
||||
* 替换 "壹证循 AI" 标题为 "北京积水潭医院..."。
|
||||
* 替换登录框上方的 Logo。
|
||||
4. **登录**:用户输入账号密码。
|
||||
5. **进入系统**:
|
||||
* 跳转至 /app/dashboard。
|
||||
* **关键点**:顶部导航栏 (Global Header) 左上角显示 **医院 Logo**,而非平台 Logo。
|
||||
* Ant Design 主题色自动切换为医院品牌色。
|
||||
1. **霈輸䔮**嚗𡁶鍂<F0A181B6>瑞<EFBFBD><E7919E>餃龫<E9A483>W<EFBFBD>蝵煾曎<E785BE>?/t/jst-hospital/login<EFBFBD>?
|
||||
2. **<EFBFBD>㰘蝸<EFBFBD>滨蔭**嚗𡁜<E59A97>蝡航圾<E888AA>?URL 銝剔<EFBFBD> jst-hospital嚗諹<EFBFBD><EFBFBD>典<EFBFBD>撘<EFBFBD> API /api/public/tenant-config?code=jst-hospital<EFBFBD>?
|
||||
3. **皜脫<EFBFBD>**嚗?
|
||||
* <EFBFBD>踵揢暺䁅恕<EFBFBD>峕艶<EFBFBD>曆蛹 loginBackgroundUrl<EFBFBD>?
|
||||
* <EFBFBD>踵揢 "憯寡<E686AF>敺?AI" <20><><EFBFBD>銝?"<22>𦯀漪蝘舀偌瞏剖龫<E58996>?.."<22>?
|
||||
* <EFBFBD>踵揢<EFBFBD>餃<EFBFBD>獢<EFBFBD><EFBFBD><EFBFBD>寧<EFBFBD> Logo<EFBFBD>?
|
||||
4. **<EFBFBD>餃<EFBFBD>**嚗𡁶鍂<F0A181B6>瑁<EFBFBD><E79181>亥揭<E4BAA5>瑕<EFBFBD><E79195><EFBFBD><EFBFBD>?
|
||||
5. **餈𥕦<EFBFBD>蝟餌<EFBFBD>**嚗?
|
||||
* 頝唾蓮<EFBFBD>?/app/dashboard<EFBFBD>?
|
||||
* **<EFBFBD>喲睸<EFBFBD>?*嚗𡁻▲<F0A181BB>典紡<E585B8>芣<EFBFBD> (Global Header) 撌虫<EFBFBD>閫埝遬蝷?**<2A>駁堺 Logo**嚗諹<E59A97>屸<EFBFBD>撟喳蝱 Logo<EFBFBD>?
|
||||
* Ant Design 銝駁<EFBFBD><EFBFBD>脰䌊<EFBFBD>典<EFBFBD><EFBFBD>V蛹<EFBFBD>駁堺<EFBFBD><EFBFBD><EFBFBD><EFBFBD>脯<EFBFBD>?
|
||||
## **5\. 餈鞱𨯫蝞∠<E89D9E>蝡臬<E89DA1><E887AC>質祕閫?(Super Admin)**
|
||||
|
||||
## **5\. 运营管理端功能详解 (Super Admin)**
|
||||
|
||||
**路由:** /admin/\*
|
||||
**頝舐眏嚗?* /admin/\*
|
||||
|
||||
### **5.1 蝘<><E89D98>銝𤾸<E98A9D>銝𡁜<E98A9D><F0A1819C>滨蔭 (Provisioning) \[<5B>湔鰵\]**
|
||||
|
||||
* **租户开通**:
|
||||
* **基础信息**:名称、租户代码 (Code,用于 URL)。
|
||||
* **类型选择**:HOSPITAL | PHARMA | JOURNAL。
|
||||
* **品牌配置** (新增):上传 Logo、背景图,设置 Slogan。
|
||||
* **模块订阅**:勾选 ASL, DC, IIT 等。
|
||||
* **配置预览**:在后台可以预览该租户的登录页效果。
|
||||
|
||||
### **5.2 Prompt 工程化平台 (Prompt Ops)**
|
||||
|
||||
* **编辑器**:Markdown \+ 变量高亮。
|
||||
* **生产预览开关**:开启后,管理员在 /app 端操作时自动加载 Draft 版。
|
||||
* **蝘<EFBFBD><EFBFBD>撘<EFBFBD><EFBFBD>?*嚗?
|
||||
* **<EFBFBD>箇<EFBFBD>靽⊥<EFBFBD>**嚗𡁜<E59A97>蝘啜<E89D98><E5959C><EFBFBD><EFBFBD>瑚誨<E7919A>?(Code嚗𣬚鍂鈭?URL)<EFBFBD>?
|
||||
* **蝐餃<EFBFBD><EFBFBD>㗇𥋘**嚗䥅OSPITAL | PHARMA | JOURNAL<EFBFBD>?
|
||||
* **<EFBFBD><EFBFBD><EFBFBD><EFBFBD>滨蔭** (<28>啣<EFBFBD>)嚗帋<E59A97>隡?Logo<67><6F><EFBFBD><EFBFBD>臬㦛嚗諹挽蝵?Slogan<EFBFBD>?
|
||||
* **璅∪<EFBFBD>霈a<EFBFBD>**嚗𡁜㗲<F0A1819C>?ASL, DC, IIT 蝑剹<EFBFBD>?
|
||||
* **<EFBFBD>滨蔭憸<EFBFBD><EFBFBD>**嚗𡁜銁<F0A1819C>𤾸蝱<F0A4BEB8>臭誑憸<E8AA91><E686B8>霂亦<E99C82><E4BAA6>瑞<EFBFBD><E7919E>餃<EFBFBD>憿菜<E686BF><E88F9C>栶<EFBFBD>?
|
||||
### **5.2 Prompt 撌亦<E6928C><E4BAA6>硋像<E7A18B>?(Prompt Ops)**
|
||||
|
||||
* **蝻𤥁<E89DBB><F0A4A581>?*嚗鐝arkdown \+ <20>㗛<EFBFBD>擃䀝漁<E4809D>?
|
||||
* **<2A>煺漣憸<E6BCA3><E686B8>撘<EFBFBD><E69298>?*嚗𡁜<E59A97><F0A1819C>臬<EFBFBD>嚗𣬚恣<F0A3AC9A><E681A3><EFBFBD><EFBFBD>?/app 蝡舀<E89DA1>雿𨀣𧒄<F0A880A3>芸𢆡<E88AB8>㰘蝸 Draft <20><><EFBFBD>?
|
||||
### **5.3 <20>鞉𧋦<E99E89>烐綉 (Cost)**
|
||||
|
||||
* **Token 水位**:今日消耗 vs 预算。
|
||||
* **Token 瘞港<EFBFBD>**嚗帋<E59A97><E5B88B>交<EFBFBD><E4BAA4>?vs 憸<><E686B8><EFBFBD>?
|
||||
## **6\. <20>箸<EFBFBD>蝞∠<E89D9E>蝡荔<E89DA1><E88D94>駁堺<E9A781>?(Hospital Admin)**
|
||||
|
||||
## **6\. 机构管理端:医院版 (Hospital Admin)**
|
||||
**頝舐眏嚗?* /org/hospital/\*
|
||||
|
||||
**路由:** /org/hospital/\*
|
||||
### **6.1 蝘穃恕銝擧<E98A9D><E693A7>条恣<E69DA1>?*
|
||||
|
||||
### **6.1 科室与成员管理**
|
||||
* **蝘穃恕<E7A983>?*嚗𡁜遣蝡见龫<E8A781>Y<EFBFBD>蝏<EFBFBD>沲<EFBFBD><E6B2B2><EFBFBD>?
|
||||
* **<2A>𣂼<EFBFBD>蝞∠<E89D9E>**嚗𡁏鸌<F0A1818F>誩紡<E8AAA9>亙龫<E4BA99><E9BEAB><EFBFBD><EFBFBD>唾<EFBFBD>蝘穃恕<E7A983>?
|
||||
### **6.2 蝏讛晶銝𡡞<E98A9D>憸?*
|
||||
|
||||
* **科室树**:建立医院组织架构。
|
||||
* **成员管理**:批量导入医生,关联科室。
|
||||
* **<EFBFBD>漤<EFBFBD>銝见<EFBFBD>**嚗𡁜<E59A97><F0A1819C>?Token 憸嘥漲<E598A5><E6BCB2><EFBFBD>蝏嗵<E89D8F>摰扎<E691B0>?
|
||||
## **7\. <20>箸<EFBFBD>蝞∠<E89D9E>蝡荔<E89DA1><E88D94>臭<EFBFBD><E887AD>?(Pharma Admin)**
|
||||
|
||||
### **6.2 经费与配额**
|
||||
|
||||
* **配额下发**:将总 Token 额度分配给科室。
|
||||
|
||||
## **7\. 机构管理端:药企版 (Pharma Admin)**
|
||||
|
||||
**路由:** /org/pharma/\*
|
||||
**頝舐眏嚗?* /org/pharma/\*
|
||||
|
||||
### **7.1 憿寧𤌍蝞∠<E89D9E>銝剖<E98A9D>**
|
||||
|
||||
* **项目列表**:查看本药企发起的所有 IIT/IST 项目。
|
||||
* **进度监控**:接入 IIT Manager Agent 数据。
|
||||
* **憿寧𤌍<EFBFBD>𡑒”**嚗𡁏䰻<F0A1818F>𧢲𧋦<F0A7A2B2>臭<EFBFBD><E887AD>𤏸絲<F0A48FB8><E7B5B2><EFBFBD><EFBFBD>?IIT/IST 憿寧𤌍<EFBFBD>?
|
||||
* **餈𥕦漲<EFBFBD>烐綉**嚗𡁏𦻖<F0A1818F>?IIT Manager Agent <EFBFBD>唳旿<EFBFBD>?
|
||||
### **7.2 <20><><EFBFBD>銝𤾸恣霈?*
|
||||
|
||||
### **7.2 合规与审计**
|
||||
|
||||
* **操作审计**:查看数据修改痕迹。
|
||||
|
||||
## **8\. 统一登录与路由分发 (Unified Entry)**
|
||||
* **<2A>滢<EFBFBD>摰∟恣**嚗𡁏䰻<F0A1818F>𧢲㺭<F0A7A2B2>桐耨<E6A190>寧<EFBFBD>餈嫘<E9A488>?
|
||||
## **8\. 蝏煺<E89D8F><E785BA>餃<EFBFBD>銝舘楝<E88898>勗<EFBFBD><E58B97>?(Unified Entry)**
|
||||
|
||||
### **8.1 <20>箄<EFBFBD>頝舐眏蝑𣇉裦**
|
||||
|
||||
用户登录成功后,前端根据 user.role 和 tenant.type 进行跳转:
|
||||
|
||||
<EFBFBD>冽<EFBFBD><EFBFBD>餃<EFBFBD><EFBFBD>𣂼<EFBFBD><EFBFBD>𠬍<EFBFBD><EFBFBD>滨垢<EFBFBD>寞旿 user.role <EFBFBD>?tenant.type 餈𥡝<EFBFBD>頝唾蓮嚗?
|
||||
function getRedirectPath(user, tenant) {
|
||||
if (user.role \=== 'SUPER\_ADMIN') return '/admin/dashboard';
|
||||
|
||||
@@ -166,13 +149,13 @@ function getRedirectPath(user, tenant) {
|
||||
return '/app/dashboard';
|
||||
}
|
||||
|
||||
## **9\. 技术实现规格 (Technical Specs)**
|
||||
## **9\. <EFBFBD><EFBFBD><EFBFBD>臬<EFBFBD><EFBFBD>啗<EFBFBD><EFBFBD>?(Technical Specs)**
|
||||
|
||||
### **9.1 数据库 Schema 变更**
|
||||
### **9.1 <EFBFBD>唳旿摨?Schema <EFBFBD>䀹凒**
|
||||
|
||||
\-- platform\_schema.tenants
|
||||
ALTER TABLE tenants
|
||||
ADD COLUMN code VARCHAR(50) UNIQUE, \-- 租户代码 (如 jst-hospital)
|
||||
ADD COLUMN code VARCHAR(50) UNIQUE, \-- 蝘<EFBFBD><EFBFBD>隞<EFBFBD><EFBFBD> (憒?jst-hospital)
|
||||
ADD COLUMN type VARCHAR(20) NOT NULL DEFAULT 'HOSPITAL',
|
||||
ADD COLUMN config JSONB DEFAULT '{}';
|
||||
\-- config <20><>鉄 branding: { logoUrl, loginBackgroundUrl, ... }
|
||||
@@ -184,27 +167,26 @@ ADD COLUMN department VARCHAR(100);
|
||||
### **9.2 API <20>亙藁<E4BA99>啣<EFBFBD>**
|
||||
|
||||
* GET /api/public/tenant-config?code={code}
|
||||
* **权限**:无需登录 (Public)。
|
||||
* **功能**:根据租户代码返回品牌配置信息(脱敏,只返回 UI 相关的)。
|
||||
|
||||
* **<EFBFBD><EFBFBD><EFBFBD>**嚗𡁏<E59A97><F0A1818F><EFBFBD><EFBFBD>餃<EFBFBD> (Public)<EFBFBD>?
|
||||
* **<EFBFBD>蠘<EFBFBD>**嚗𡁏覔<F0A1818F>桃<EFBFBD><E6A183>瑚誨<E7919A><E8AAA8><EFBFBD><EFBFBD>𧼮<EFBFBD><F0A7BCAE>屸<EFBFBD>蝵桐縑<E6A190>荔<EFBFBD><E88D94>望<EFBFBD>嚗<EFBFBD>蘨餈𥪜<E9A488> UI <20>詨<EFBFBD><E8A9A8><EFBFBD><EFBFBD><EFBFBD>?
|
||||
### **9.3 <20>滨垢<E6BBA8>桀<EFBFBD>蝏𤘪<E89D8F>**
|
||||
|
||||
src/modules/
|
||||
<20>鎿<EFBFBD><E98EBF><EFBFBD> auth/
|
||||
│ ├── LoginPage.tsx \# 通用登录页
|
||||
│ ├── TenantLoginPage.tsx \# 动态渲染的专属登录页 (路由 /t/:code/login)
|
||||
├── admin/ \# 运营管理端
|
||||
├── org/ \# 机构管理端
|
||||
<EFBFBD>? <20>鎿<EFBFBD><E98EBF><EFBFBD> LoginPage.tsx \# <EFBFBD>𡁶鍂<EFBFBD>餃<EFBFBD>憿?
|
||||
<EFBFBD>? <20>鎿<EFBFBD><E98EBF><EFBFBD> TenantLoginPage.tsx \# <EFBFBD>冽<EFBFBD><EFBFBD>葡<EFBFBD>梶<EFBFBD>銝枏<EFBFBD><EFBFBD>餃<EFBFBD>憿?(頝舐眏 /t/:code/login)
|
||||
<EFBFBD>鎿<EFBFBD><EFBFBD><EFBFBD> admin/ \# 餈鞱𨯫蝞∠<EFBFBD>蝡?
|
||||
<EFBFBD>鎿<EFBFBD><EFBFBD><EFBFBD> org/ \# <EFBFBD>箸<EFBFBD>蝞∠<EFBFBD>蝡?
|
||||
<20>婙<EFBFBD><E5A999><EFBFBD> ...
|
||||
|
||||
## **10\. 实施路线图 (Roadmap v2.1)**
|
||||
## **10\. 摰墧鴌頝舐瑪<EFBFBD>?(Roadmap v2.1)**
|
||||
|
||||
* **P0 (Week 1\)**:
|
||||
* DB Schema 变更(增加 Tenant Code, Config)。
|
||||
* 实现 /api/public/tenant-config 接口。
|
||||
* 开发 TenantLoginPage 组件,实现动态换肤。
|
||||
* DB Schema <EFBFBD>䀹凒嚗<EFBFBD><EFBFBD><EFBFBD>?Tenant Code, Config嚗剹<EFBFBD>?
|
||||
* 摰䂿緵 /api/public/tenant-config <EFBFBD>亙藁<EFBFBD>?
|
||||
* 撘<EFBFBD><EFBFBD>?TenantLoginPage 蝏<EFBFBD>辣嚗<EFBFBD><EFBFBD><EFBFBD>啣𢆡<EFBFBD><EFBFBD>揢<EFBFBD>扎<EFBFBD>?
|
||||
* **P1 (Week 2\)**:
|
||||
* 运营端增加“品牌配置”表单(上传图片到 OSS)。
|
||||
* 实现全局 Header 根据当前用户 Tenant 自动切换 Logo。
|
||||
* 餈鞱𨯫蝡臬<EFBFBD><EFBFBD>罱<EFBFBD>𨅯<EFBFBD><EFBFBD>屸<EFBFBD>蝵栽<EFBFBD>肽”<EFBFBD>𤏪<EFBFBD>銝𠹺<EFBFBD><EFBFBD>曄<EFBFBD><EFBFBD>?OSS嚗剹<E59A97>?
|
||||
* 摰䂿緵<EFBFBD>典<EFBFBD> Header <EFBFBD>寞旿敶枏<EFBFBD><EFBFBD>冽<EFBFBD> Tenant <EFBFBD>芸𢆡<EFBFBD><EFBFBD>揢 Logo<EFBFBD>?
|
||||
* **P2 (Week 3\)**:
|
||||
* 实现 /org/hospital 基础版。
|
||||
* 摰䂿緵 /org/hospital <EFBFBD>箇<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
Reference in New Issue
Block a user