diff --git a/frontend/src/hooks/metadata-middleware.js b/frontend/src/hooks/metadata-middleware.js index 361f70875a..6963b132f3 100644 --- a/frontend/src/hooks/metadata-middleware.js +++ b/frontend/src/hooks/metadata-middleware.js @@ -6,13 +6,13 @@ import { useMetadataStatus } from './metadata-status'; const MetadataMiddlewareContext = React.createContext(null); -export const MetadataMiddlewareProvider = ({ repoID, currentPath, repoInfo, onTreeNodeClick, tagsChangedCallback, children }) => { +export const MetadataMiddlewareProvider = ({ repoID, currentPath, repoInfo, selectTagsView, tagsChangedCallback, children }) => { const { enableMetadata, enableOCR, enableTags, tagsLang } = useMetadataStatus(); return ( - + { +const OCRResultDialog = ({ repoID, record, onToggle, saveToDescription }) => { const [isLoading, setLoading] = useState(true); const [errorMessage, setErrorMessage] = useState(''); const [isFullScreen, setIsFullScreen] = useState(false); const [dialogStyle, setDialogStyle] = useState({}); + const { canModify } = useMetadataAIOperations(); const ocrResult = useRef(null); @@ -58,14 +61,8 @@ const OCRResultDialog = ({ record, onToggle, saveToDescription }) => { }, [saveToDescription, onToggle]); useEffect(() => { - if (!window.sfMetadataContext.canModifyRow(record)) { - setErrorMessage(gettext('Permission denied')); - setLoading(false); - return; - } - const path = Utils.joinPath(parentDir, fileName); - window.sfMetadataContext.ocr(path).then(res => { + metadataAPI.ocr(repoID, path).then(res => { const result = res.data?.ocr_result || ''; ocrResult.current = result.replaceAll('\f', '\n').replaceAll('\n\n', '\n').replaceAll('\n', '\n\n'); setLoading(false); @@ -95,7 +92,7 @@ const OCRResultDialog = ({ record, onToggle, saveToDescription }) => {
{gettext('OCR result')}
- {!isLoading && !errorMessage && ( + {!isLoading && !errorMessage && canModify && (