added status to import queue model

This commit is contained in:
Jennifer Player 2024-02-21 18:11:38 -05:00 committed by psychedelicious
parent ea364bdf82
commit 68f24d9f0d

View File

@ -1,9 +1,4 @@
import { import { Box, Flex, IconButton, Progress, Text } from '@invoke-ai/ui-library';
Flex,
IconButton,
Progress,
Text,
} from '@invoke-ai/ui-library';
import { useAppDispatch } from 'app/store/storeHooks'; import { useAppDispatch } from 'app/store/storeHooks';
import { addToast } from 'features/system/store/systemSlice'; import { addToast } from 'features/system/store/systemSlice';
import { makeToast } from 'features/system/util/makeToast'; import { makeToast } from 'features/system/util/makeToast';
@ -50,12 +45,31 @@ export const ImportQueueModel = (props: ModelListItemProps) => {
}); });
}, [deleteImportModel, model, dispatch]); }, [deleteImportModel, model, dispatch]);
const formatBytes = (bytes: number) => {
const units = ['b', 'kb', 'mb', 'gb', 'tb'];
let i = 0;
for (i; bytes >= 1024 && i < 4; i++) {
bytes /= 1024;
}
return `${bytes.toFixed(2)} ${units[i]}`;
};
const progressValue = useMemo(() => { const progressValue = useMemo(() => {
return (model.bytes / model.total_bytes) * 100; return (model.bytes / model.total_bytes) * 100;
}, [model.bytes, model.total_bytes]); }, [model.bytes, model.total_bytes]);
const progressString = useMemo(() => {
if (model.status !== 'downloading') {
return '--';
}
return `${formatBytes(model.bytes)} / ${formatBytes(model.total_bytes)}`;
}, [model.bytes, model.total_bytes, model.status]);
return ( return (
<Flex gap="3" w="full" alignItems="center" textAlign="center"> <Flex gap="2" w="full" alignItems="center" textAlign="center">
<Text w="20%" whiteSpace="nowrap" overflow="hidden" textOverflow="ellipsis"> <Text w="20%" whiteSpace="nowrap" overflow="hidden" textOverflow="ellipsis">
{model.source.repo_id} {model.source.repo_id}
</Text> </Text>
@ -66,17 +80,23 @@ export const ImportQueueModel = (props: ModelListItemProps) => {
h={2} h={2}
w="50%" w="50%"
/> />
<Text w="20%">{model.status}</Text> <Text minW="20%" fontSize="xs" w="20%">
{(model.status === 'downloading' || model.status === 'waiting') && ( {progressString}
<IconButton </Text>
isRound={true} <Text w="15%">{model.status[0].toUpperCase() +
size="xs" model.status.slice(1)}</Text>
tooltip={t('modelManager.cancel')} <Box w="10%">
aria-label={t('modelManager.cancel')} {(model.status === 'downloading' || model.status === 'waiting') && (
icon={<PiXBold />} <IconButton
onClick={handleDeleteModelImport} isRound={true}
/> size="xs"
)} tooltip={t('modelManager.cancel')}
aria-label={t('modelManager.cancel')}
icon={<PiXBold />}
onClick={handleDeleteModelImport}
/>
)}
</Box>
</Flex> </Flex>
); );
}; };