mirror of
https://github.com/haiwen/seahub.git
synced 2025-09-24 04:48:03 +00:00
Merge pull request #7910 from haiwen/fix-metadata-middleware-callback
fix: metadata middleware callback
This commit is contained in:
@@ -6,13 +6,13 @@ import { useMetadataStatus } from './metadata-status';
|
|||||||
|
|
||||||
const MetadataMiddlewareContext = React.createContext(null);
|
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();
|
const { enableMetadata, enableOCR, enableTags, tagsLang } = useMetadataStatus();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<MetadataMiddlewareContext.Provider value={{}}>
|
<MetadataMiddlewareContext.Provider value={{}}>
|
||||||
<CollaboratorsProvider repoID={repoID}>
|
<CollaboratorsProvider repoID={repoID}>
|
||||||
<TagsProvider repoID={repoID} currentPath={currentPath} repoInfo={repoInfo} selectTagsView={onTreeNodeClick} tagsChangedCallback={tagsChangedCallback}>
|
<TagsProvider repoID={repoID} currentPath={currentPath} repoInfo={repoInfo} selectTagsView={selectTagsView} tagsChangedCallback={tagsChangedCallback}>
|
||||||
<MetadataAIOperationsProvider
|
<MetadataAIOperationsProvider
|
||||||
repoID={repoID}
|
repoID={repoID}
|
||||||
enableMetadata={enableMetadata}
|
enableMetadata={enableMetadata}
|
||||||
|
@@ -8,14 +8,17 @@ import { getFileNameFromRecord, getParentDirFromRecord } from '../../../utils/ce
|
|||||||
import { Utils } from '../../../../utils/utils';
|
import { Utils } from '../../../../utils/utils';
|
||||||
import i18n from '../../../../_i18n/i18n-seafile-editor';
|
import i18n from '../../../../_i18n/i18n-seafile-editor';
|
||||||
import Icon from '../../../../components/icon';
|
import Icon from '../../../../components/icon';
|
||||||
|
import metadataAPI from '../../../api';
|
||||||
|
import { useMetadataAIOperations } from '../../../../hooks/metadata-ai-operation';
|
||||||
|
|
||||||
import './index.css';
|
import './index.css';
|
||||||
|
|
||||||
const OCRResultDialog = ({ record, onToggle, saveToDescription }) => {
|
const OCRResultDialog = ({ repoID, record, onToggle, saveToDescription }) => {
|
||||||
const [isLoading, setLoading] = useState(true);
|
const [isLoading, setLoading] = useState(true);
|
||||||
const [errorMessage, setErrorMessage] = useState('');
|
const [errorMessage, setErrorMessage] = useState('');
|
||||||
const [isFullScreen, setIsFullScreen] = useState(false);
|
const [isFullScreen, setIsFullScreen] = useState(false);
|
||||||
const [dialogStyle, setDialogStyle] = useState({});
|
const [dialogStyle, setDialogStyle] = useState({});
|
||||||
|
const { canModify } = useMetadataAIOperations();
|
||||||
|
|
||||||
const ocrResult = useRef(null);
|
const ocrResult = useRef(null);
|
||||||
|
|
||||||
@@ -58,14 +61,8 @@ const OCRResultDialog = ({ record, onToggle, saveToDescription }) => {
|
|||||||
}, [saveToDescription, onToggle]);
|
}, [saveToDescription, onToggle]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!window.sfMetadataContext.canModifyRow(record)) {
|
|
||||||
setErrorMessage(gettext('Permission denied'));
|
|
||||||
setLoading(false);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const path = Utils.joinPath(parentDir, fileName);
|
const path = Utils.joinPath(parentDir, fileName);
|
||||||
window.sfMetadataContext.ocr(path).then(res => {
|
metadataAPI.ocr(repoID, path).then(res => {
|
||||||
const result = res.data?.ocr_result || '';
|
const result = res.data?.ocr_result || '';
|
||||||
ocrResult.current = result.replaceAll('\f', '\n').replaceAll('\n\n', '\n').replaceAll('\n', '\n\n');
|
ocrResult.current = result.replaceAll('\f', '\n').replaceAll('\n\n', '\n').replaceAll('\n', '\n\n');
|
||||||
setLoading(false);
|
setLoading(false);
|
||||||
@@ -95,7 +92,7 @@ const OCRResultDialog = ({ record, onToggle, saveToDescription }) => {
|
|||||||
<div className="longtext-header">
|
<div className="longtext-header">
|
||||||
<span className="longtext-header-name">{gettext('OCR result')}</span>
|
<span className="longtext-header-name">{gettext('OCR result')}</span>
|
||||||
<div className="longtext-header-tool">
|
<div className="longtext-header-tool">
|
||||||
{!isLoading && !errorMessage && (
|
{!isLoading && !errorMessage && canModify && (
|
||||||
<span
|
<span
|
||||||
className="longtext-header-tool-item d-flex align-items-center mr-1"
|
className="longtext-header-tool-item d-flex align-items-center mr-1"
|
||||||
title={gettext('Save to description property')}
|
title={gettext('Save to description property')}
|
||||||
|
Reference in New Issue
Block a user