mirror of
https://github.com/haiwen/seahub.git
synced 2025-09-25 14:50:29 +00:00
update ui
This commit is contained in:
@@ -14,6 +14,7 @@ import {
|
|||||||
} from '../../metadata';
|
} from '../../metadata';
|
||||||
import SeahubModalHeader from '@/components/common/seahub-modal-header';
|
import SeahubModalHeader from '@/components/common/seahub-modal-header';
|
||||||
import { useMetadataStatus } from '../../hooks';
|
import { useMetadataStatus } from '../../hooks';
|
||||||
|
import Loading from '../../components/loading';
|
||||||
|
|
||||||
import '../../css/lib-settings.css';
|
import '../../css/lib-settings.css';
|
||||||
|
|
||||||
@@ -28,6 +29,7 @@ const propTypes = {
|
|||||||
|
|
||||||
const LibSettingsDialog = ({ repoID, currentRepoInfo, toggleDialog, tab, showMigrateTip, usedRepoTags, onMigrateSuccess }) => {
|
const LibSettingsDialog = ({ repoID, currentRepoInfo, toggleDialog, tab, showMigrateTip, usedRepoTags, onMigrateSuccess }) => {
|
||||||
const [activeTab, setActiveTab] = useState(tab || TAB.HISTORY_SETTING);
|
const [activeTab, setActiveTab] = useState(tab || TAB.HISTORY_SETTING);
|
||||||
|
const [isMigrating, setIsMigrating] = useState(false);
|
||||||
const toggleTab = useCallback((tab) => {
|
const toggleTab = useCallback((tab) => {
|
||||||
setActiveTab(tab);
|
setActiveTab(tab);
|
||||||
}, []);
|
}, []);
|
||||||
@@ -46,9 +48,38 @@ const LibSettingsDialog = ({ repoID, currentRepoInfo, toggleDialog, tab, showMig
|
|||||||
const enableAutoDelSetting = is_admin && enableRepoAutoDel;
|
const enableAutoDelSetting = is_admin && enableRepoAutoDel;
|
||||||
const enableExtendedPropertiesSetting = !encrypted && is_admin && enableMetadataManagement;
|
const enableExtendedPropertiesSetting = !encrypted && is_admin && enableMetadataManagement;
|
||||||
|
|
||||||
|
const handleMigrateStart = useCallback(() => {
|
||||||
|
setIsMigrating(true);
|
||||||
|
}, []);
|
||||||
|
|
||||||
|
const handleMigrateEnd = useCallback(() => {
|
||||||
|
setIsMigrating(false);
|
||||||
|
onMigrateSuccess && onMigrateSuccess();
|
||||||
|
}, [onMigrateSuccess]);
|
||||||
|
|
||||||
|
const handleMigrateError = useCallback(() => {
|
||||||
|
setIsMigrating(false);
|
||||||
|
}, []);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
<Modal isOpen={true} className="lib-settings-dialog" toggle={toggleDialog}>
|
<Modal isOpen={true} className="lib-settings-dialog" toggle={toggleDialog}>
|
||||||
|
{isMigrating && (
|
||||||
|
<div style={{
|
||||||
|
position: 'absolute',
|
||||||
|
top: 0,
|
||||||
|
left: 0,
|
||||||
|
right: 0,
|
||||||
|
bottom: 0,
|
||||||
|
backgroundColor: 'rgba(255, 255, 255, 0.8)',
|
||||||
|
display: 'flex',
|
||||||
|
justifyContent: 'center',
|
||||||
|
alignItems: 'center',
|
||||||
|
zIndex: 1050
|
||||||
|
}}>
|
||||||
|
<Loading />
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
<SeahubModalHeader toggle={toggleDialog}>
|
<SeahubModalHeader toggle={toggleDialog}>
|
||||||
{gettext('Settings')}
|
{gettext('Settings')}
|
||||||
</SeahubModalHeader>
|
</SeahubModalHeader>
|
||||||
@@ -203,7 +234,9 @@ const LibSettingsDialog = ({ repoID, currentRepoInfo, toggleDialog, tab, showMig
|
|||||||
enableMetadata={enableMetadata}
|
enableMetadata={enableMetadata}
|
||||||
showMigrateTip={showMigrateTip}
|
showMigrateTip={showMigrateTip}
|
||||||
usedRepoTags={usedRepoTags}
|
usedRepoTags={usedRepoTags}
|
||||||
onMigrateSuccess={onMigrateSuccess}
|
onMigrateSuccess={handleMigrateEnd}
|
||||||
|
onMigrateError={handleMigrateError}
|
||||||
|
onMigrateStart={handleMigrateStart}
|
||||||
/>
|
/>
|
||||||
</TabPane>
|
</TabPane>
|
||||||
)}
|
)}
|
||||||
|
@@ -7,7 +7,7 @@ import { EVENT_BUS_TYPE } from '../components/common/event-bus-type';
|
|||||||
|
|
||||||
const RepoInfoBarMigrate = () => {
|
const RepoInfoBarMigrate = () => {
|
||||||
|
|
||||||
const { enableMetadata, detailsSettings } = useMetadataStatus();
|
const { enableMetadataManagement, detailsSettings } = useMetadataStatus();
|
||||||
const tagsMigrated = detailsSettings?.tags_migrated;
|
const tagsMigrated = detailsSettings?.tags_migrated;
|
||||||
const openMigrate = () => {
|
const openMigrate = () => {
|
||||||
eventBus.dispatch(EVENT_BUS_TYPE.OPEN_TREE_PANEL, () => eventBus.dispatch(EVENT_BUS_TYPE.OPEN_LIBRARY_SETTINGS_TAGS));
|
eventBus.dispatch(EVENT_BUS_TYPE.OPEN_TREE_PANEL, () => eventBus.dispatch(EVENT_BUS_TYPE.OPEN_LIBRARY_SETTINGS_TAGS));
|
||||||
@@ -15,17 +15,16 @@ const RepoInfoBarMigrate = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="repo-info-bar-migrate mt-2">
|
<div className="repo-info-bar-migrate mt-2">
|
||||||
{enableMetadata && !tagsMigrated ?
|
{!tagsMigrated && (
|
||||||
(
|
enableMetadataManagement ? (
|
||||||
<>
|
<>
|
||||||
{gettext('Tips: There are tags of old version. Please migrate tags to new version.')}
|
{gettext('Tips: There are tags of old version. Please migrate tags to new version.')}
|
||||||
<Button color="link" size="sm" tag="a" onClick={openMigrate}>{gettext('Migrate')}</Button>
|
<Button color="link" size="sm" tag="a" onClick={openMigrate}>{gettext('Migrate')}</Button>
|
||||||
</>
|
</>
|
||||||
) :
|
) : (
|
||||||
(
|
|
||||||
<>{gettext('Tips: These are tags of old version. The feature is deprecated and can no longer be used.')}</>
|
<>{gettext('Tips: These are tags of old version. The feature is deprecated and can no longer be used.')}</>
|
||||||
)
|
)
|
||||||
}
|
)}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
@@ -19,13 +19,11 @@ const langOptions = [
|
|||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
const MetadataTagsStatusDialog = ({ value: oldValue, lang: oldLang, repoID, toggleDialog: toggle, submit, enableMetadata, showMigrateTip, usedRepoTags, onMigrateSuccess }) => {
|
const MetadataTagsStatusDialog = ({ value: oldValue, lang: oldLang, repoID, toggleDialog: toggle, submit, enableMetadata, showMigrateTip, usedRepoTags, onMigrateSuccess, onMigrateStart, onMigrateError }) => {
|
||||||
const [value, setValue] = useState(oldValue);
|
const [value, setValue] = useState(oldValue);
|
||||||
const [lang, setLang] = useState(oldLang);
|
const [lang, setLang] = useState(oldLang);
|
||||||
const [submitting, setSubmitting] = useState(false);
|
const [submitting, setSubmitting] = useState(false);
|
||||||
const [migrated, setMigrated] = useState(false);
|
|
||||||
const [showTurnOffConfirmDialog, setShowTurnOffConfirmDialog] = useState(false);
|
const [showTurnOffConfirmDialog, setShowTurnOffConfirmDialog] = useState(false);
|
||||||
|
|
||||||
const onToggle = useCallback(() => {
|
const onToggle = useCallback(() => {
|
||||||
toggle();
|
toggle();
|
||||||
}, [toggle]);
|
}, [toggle]);
|
||||||
@@ -47,16 +45,16 @@ const MetadataTagsStatusDialog = ({ value: oldValue, lang: oldLang, repoID, togg
|
|||||||
}, [lang, repoID, submit, toggle, value]);
|
}, [lang, repoID, submit, toggle, value]);
|
||||||
|
|
||||||
const migrateTag = useCallback(() => {
|
const migrateTag = useCallback(() => {
|
||||||
|
onMigrateStart && onMigrateStart();
|
||||||
tagsAPI.migrateTags(repoID, usedRepoTags).then(res => {
|
tagsAPI.migrateTags(repoID, usedRepoTags).then(res => {
|
||||||
setMigrated(true);
|
|
||||||
toaster.success(gettext('Tags migrated successfully'));
|
toaster.success(gettext('Tags migrated successfully'));
|
||||||
onMigrateSuccess && onMigrateSuccess();
|
onMigrateSuccess && onMigrateSuccess();
|
||||||
}).catch(error => {
|
}).catch(error => {
|
||||||
const errorMsg = Utils.getErrorMsg(error);
|
const errorMsg = Utils.getErrorMsg(error);
|
||||||
toaster.danger(errorMsg);
|
toaster.danger(errorMsg);
|
||||||
setMigrated(false);
|
onMigrateError && onMigrateError();
|
||||||
});
|
});
|
||||||
}, [repoID, usedRepoTags, onMigrateSuccess]);
|
}, [repoID, usedRepoTags, onMigrateSuccess, onMigrateStart, onMigrateError]);
|
||||||
|
|
||||||
const turnOffConfirmToggle = useCallback(() => {
|
const turnOffConfirmToggle = useCallback(() => {
|
||||||
setShowTurnOffConfirmDialog(!showTurnOffConfirmDialog);
|
setShowTurnOffConfirmDialog(!showTurnOffConfirmDialog);
|
||||||
@@ -122,9 +120,8 @@ const MetadataTagsStatusDialog = ({ value: oldValue, lang: oldLang, repoID, togg
|
|||||||
<Button
|
<Button
|
||||||
color="primary"
|
color="primary"
|
||||||
onClick={migrateTag}
|
onClick={migrateTag}
|
||||||
disabled={migrated}
|
|
||||||
>
|
>
|
||||||
{migrated ? gettext('Migrated') : gettext('Migrate old version tags')}
|
{gettext('Migrate old version tags')}
|
||||||
</Button>
|
</Button>
|
||||||
</FormGroup>
|
</FormGroup>
|
||||||
}
|
}
|
||||||
@@ -153,6 +150,8 @@ MetadataTagsStatusDialog.propTypes = {
|
|||||||
showMigrateTip: PropTypes.bool,
|
showMigrateTip: PropTypes.bool,
|
||||||
repoTags: PropTypes.array,
|
repoTags: PropTypes.array,
|
||||||
onMigrateSuccess: PropTypes.func,
|
onMigrateSuccess: PropTypes.func,
|
||||||
|
onMigrateError: PropTypes.func,
|
||||||
|
onMigrateStart: PropTypes.func,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default MetadataTagsStatusDialog;
|
export default MetadataTagsStatusDialog;
|
||||||
|
Reference in New Issue
Block a user