mirror of
https://github.com/haiwen/seahub.git
synced 2025-09-10 11:21:29 +00:00
feat: metadata insert property permission bug (#7283)
Co-authored-by: 杨国璇 <ygx@Hello-word.local>
This commit is contained in:
@@ -157,7 +157,7 @@ class FileView extends React.Component {
|
||||
}
|
||||
{this.props.content}
|
||||
{isDetailsPanelOpen && (
|
||||
<MetadataStatusProvider repoID={repoID} currentRepoInfo={repoInfo}>
|
||||
<MetadataStatusProvider repoID={repoID} repoInfo={repoInfo}>
|
||||
<CollaboratorsProvider repoID={repoID}>
|
||||
<TagsProvider repoID={repoID} repoInfo={repoInfo}>
|
||||
<EmbeddedFileDetails
|
||||
|
@@ -7,12 +7,12 @@ import { MetadataAIOperationsProvider } from './metadata-ai-operation';
|
||||
// This hook provides content related to seahub interaction, such as whether to enable extended attributes
|
||||
const MetadataStatusContext = React.createContext(null);
|
||||
|
||||
export const MetadataStatusProvider = ({ repoID, currentRepoInfo, hideMetadataView, children }) => {
|
||||
export const MetadataStatusProvider = ({ repoID, repoInfo, hideMetadataView, children }) => {
|
||||
const enableMetadataManagement = useMemo(() => {
|
||||
if (currentRepoInfo?.encrypted) return false;
|
||||
if (repoInfo?.encrypted) return false;
|
||||
return window.app.pageOptions.enableMetadataManagement;
|
||||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||
}, [window.app.pageOptions.enableMetadataManagement, currentRepoInfo]);
|
||||
}, [window.app.pageOptions.enableMetadataManagement, repoInfo]);
|
||||
|
||||
const [isLoading, setLoading] = useState(true);
|
||||
const [enableMetadata, setEnableMetadata] = useState(false);
|
||||
@@ -125,7 +125,7 @@ export const MetadataStatusProvider = ({ repoID, currentRepoInfo, hideMetadataVi
|
||||
enableOCR={enableOCR}
|
||||
enableTags={enableTags}
|
||||
tagsLang={tagsLang}
|
||||
repoInfo={currentRepoInfo}
|
||||
repoInfo={repoInfo}
|
||||
>
|
||||
{children}
|
||||
</MetadataAIOperationsProvider>
|
||||
|
@@ -15,7 +15,7 @@ const { repoID, repoEncrypted, filePerm } = window.app.pageOptions;
|
||||
ReactDom.render(
|
||||
<I18nextProvider i18n={ i18n } >
|
||||
<Suspense fallback={<Loading />}>
|
||||
<MetadataStatusProvider repoID={repoID} currentRepoInfo={{ permission: filePerm, encrypted: repoEncrypted }}>
|
||||
<MetadataStatusProvider repoID={repoID} repoInfo={{ permission: filePerm, encrypted: repoEncrypted }}>
|
||||
<CollaboratorsProvider repoID={repoID}>
|
||||
<MarkdownEditor />
|
||||
</CollaboratorsProvider>
|
||||
|
@@ -126,6 +126,11 @@ class Context {
|
||||
return viewId !== FACE_RECOGNITION_VIEW_ID;
|
||||
};
|
||||
|
||||
canInsertColumn = () => {
|
||||
if (this.permission === 'r') return false;
|
||||
return true;
|
||||
};
|
||||
|
||||
canModifyColumn = (column) => {
|
||||
if (this.permission === 'r') return false;
|
||||
const { editable } = column;
|
||||
|
@@ -66,6 +66,8 @@ const RecordsHeader = ({
|
||||
return value;
|
||||
}, [isGroupView, columnMetrics, height]);
|
||||
|
||||
const canInsertColumn = window.sfMetadataContext.canInsertColumn();
|
||||
|
||||
const modifyLocalColumnWidth = useCallback((column, width) => {
|
||||
setResizingColumnMetrics(recalculateColumnMetricsByResizeColumn(propsColumnMetrics, column.key, Math.max(width, 50)));
|
||||
}, [propsColumnMetrics]);
|
||||
@@ -162,7 +164,7 @@ const RecordsHeader = ({
|
||||
/>
|
||||
);
|
||||
})}
|
||||
{insertColumn && (
|
||||
{canInsertColumn && insertColumn && (
|
||||
<InsertColumn
|
||||
lastColumn={columnMetrics.columns[columnMetrics.columns.length - 1]}
|
||||
groupOffsetLeft={groupOffsetLeft}
|
||||
|
@@ -2214,7 +2214,7 @@ class LibContentView extends React.Component {
|
||||
}
|
||||
|
||||
return (
|
||||
<MetadataStatusProvider repoID={repoID} currentRepoInfo={currentRepoInfo} hideMetadataView={this.hideMetadataView}>
|
||||
<MetadataStatusProvider repoID={repoID} repoInfo={currentRepoInfo} hideMetadataView={this.hideMetadataView}>
|
||||
<TagsProvider repoID={repoID} currentPath={path} repoInfo={currentRepoInfo} selectTagsView={this.onTreeNodeClick}>
|
||||
<MetadataProvider repoID={repoID} currentPath={path} repoInfo={currentRepoInfo} selectMetadataView={this.onTreeNodeClick} hideMetadataView={this.hideMetadataView} >
|
||||
<CollaboratorsProvider repoID={repoID}>
|
||||
|
@@ -59,7 +59,7 @@ const repoInfo = { encrypted: repoEncrypted, permission: filePerm, is_admin: isR
|
||||
ReactDom.render(
|
||||
<I18nextProvider i18n={ i18n } >
|
||||
<Suspense fallback={<Loading />}>
|
||||
<MetadataStatusProvider repoID={repoID} currentRepoInfo={repoInfo}>
|
||||
<MetadataStatusProvider repoID={repoID} repoInfo={repoInfo}>
|
||||
<CollaboratorsProvider repoID={repoID}>
|
||||
<TagsProvider repoID={repoID} repoInfo={repoInfo}>
|
||||
{filePerm === 'rw' ? <SdocEditor /> : <SimpleViewer />}
|
||||
|
Reference in New Issue
Block a user