Core Components: - PDFStorageService with Dify/OSS adapters - LLM12FieldsService with Nougat-first + dual-model + 3-layer JSON parsing - PromptBuilder for dynamic prompt assembly - MedicalLogicValidator with 5 rules + fault tolerance - EvidenceChainValidator for citation integrity - ConflictDetectionService for dual-model comparison Prompt Engineering: - System Prompt (6601 chars, Section-Aware strategy) - User Prompt template (PICOS context injection) - JSON Schema (12 fields constraints) - Cochrane standards (not loaded in MVP) Key Innovations: - 3-layer JSON parsing (JSON.parse + json-repair + code block extraction) - Promise.allSettled for dual-model fault tolerance - safeGetFieldValue for robust field extraction - Mixed CN/EN token calculation Integration Tests: - integration-test.ts (full test) - quick-test.ts (quick test) - cached-result-test.ts (fault tolerance test) Documentation Updates: - Development record (Day 2-3 summary) - Quality assurance strategy (full-text screening) - Development plan (progress update) - Module status (v1.1 update) - Technical debt (10 new items) Test Results: - JSON parsing success rate: 100% - Medical logic validation: 5/5 passed - Dual-model parallel processing: OK - Cost per PDF: CNY 0.10 Files: 238 changed, 14383 insertions(+), 32 deletions(-) Docs: docs/03-涓氬姟妯″潡/ASL-AI鏅鸿兘鏂囩尞/05-寮€鍙戣褰?2025-11-22_Day2-Day3_LLM鏈嶅姟涓庨獙璇佺郴缁熷紑鍙?md
55 lines
986 B
TypeScript
55 lines
986 B
TypeScript
import { useContext } from 'react'
|
|
import { PermissionContext } from './PermissionContext'
|
|
import { PermissionContextType } from './types'
|
|
|
|
/**
|
|
* 权限Hook
|
|
*
|
|
* @description 提供便捷的权限检查功能
|
|
* @version Week 2 Day 7 - 任务17
|
|
*
|
|
* @example
|
|
* ```tsx
|
|
* const MyComponent = () => {
|
|
* const { user, checkModulePermission } = usePermission()
|
|
*
|
|
* if (!checkModulePermission('advanced')) {
|
|
* return <UpgradePrompt />
|
|
* }
|
|
*
|
|
* return <div>欢迎 {user?.name}</div>
|
|
* }
|
|
* ```
|
|
*/
|
|
export const usePermission = (): PermissionContextType => {
|
|
const context = useContext(PermissionContext)
|
|
|
|
if (context === undefined) {
|
|
throw new Error(
|
|
'usePermission must be used within a PermissionProvider. ' +
|
|
'Please wrap your app with <PermissionProvider>.'
|
|
)
|
|
}
|
|
|
|
return context
|
|
}
|
|
|
|
/**
|
|
* 导出权限相关类型(方便使用)
|
|
*/
|
|
export type { UserInfo, UserVersion, PermissionContextType } from './types'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|