diff --git a/admin-lehrer/components/grid-editor/useGridEditor.ts b/admin-lehrer/components/grid-editor/useGridEditor.ts index f3bd451..b04d02d 100644 --- a/admin-lehrer/components/grid-editor/useGridEditor.ts +++ b/admin-lehrer/components/grid-editor/useGridEditor.ts @@ -28,10 +28,14 @@ export function useGridEditor(sessionId: string | null) { const [ipaMode, setIpaMode] = useState('auto') const [syllableMode, setSyllableMode] = useState('auto') - // OCR Quality Steps (A/B testing toggles) - const [ocrEnhance, setOcrEnhance] = useState(true) - const [ocrMaxCols, setOcrMaxCols] = useState(0) // 0 = unlimited (admin pipeline default) - const [ocrMinConf, setOcrMinConf] = useState(0) // 0 = auto from quality score + // OCR Quality Steps (A/B testing toggles — defaults off for now) + const [ocrEnhance, setOcrEnhance] = useState(false) + const [ocrMaxCols, setOcrMaxCols] = useState(0) + const [ocrMinConf, setOcrMinConf] = useState(0) + + // Vision-LLM Fusion (Step 4) + const [visionFusion, setVisionFusion] = useState(false) + const [documentCategory, setDocumentCategory] = useState('vokabelseite') // Undo/redo stacks store serialized zone arrays const undoStack = useRef([]) @@ -92,6 +96,8 @@ export function useGridEditor(sessionId: string | null) { params.set('enhance', String(ocrEnhance)) if (ocrMaxCols > 0) params.set('max_cols', String(ocrMaxCols)) if (ocrMinConf > 0) params.set('min_conf', String(ocrMinConf)) + params.set('vision_fusion', String(visionFusion)) + if (documentCategory) params.set('doc_category', documentCategory) const res = await fetch( `${KLAUSUR_API}/api/v1/ocr-pipeline/sessions/${sessionId}/rerun-ocr-and-build-grid?${params}`, { method: 'POST' }, @@ -110,7 +116,7 @@ export function useGridEditor(sessionId: string | null) { } finally { setLoading(false) } - }, [sessionId, ipaMode, syllableMode, ocrEnhance, ocrMaxCols, ocrMinConf]) + }, [sessionId, ipaMode, syllableMode, ocrEnhance, ocrMaxCols, ocrMinConf, visionFusion, documentCategory]) const loadGrid = useCallback(async () => { if (!sessionId) return @@ -1030,6 +1036,10 @@ export function useGridEditor(sessionId: string | null) { setOcrMaxCols, ocrMinConf, setOcrMinConf, + visionFusion, + setVisionFusion, + documentCategory, + setDocumentCategory, rerunOcr, } } diff --git a/admin-lehrer/components/ocr-pipeline/StepGridReview.tsx b/admin-lehrer/components/ocr-pipeline/StepGridReview.tsx index 22df350..8829961 100644 --- a/admin-lehrer/components/ocr-pipeline/StepGridReview.tsx +++ b/admin-lehrer/components/ocr-pipeline/StepGridReview.tsx @@ -67,6 +67,10 @@ export function StepGridReview({ sessionId, onNext, saveRef }: StepGridReviewPro setOcrMaxCols, ocrMinConf, setOcrMinConf, + visionFusion, + setVisionFusion, + documentCategory, + setDocumentCategory, rerunOcr, } = useGridEditor(sessionId) @@ -291,6 +295,22 @@ export function StepGridReview({ sessionId, onNext, saveRef }: StepGridReviewPro + | + + +