File size: 2,220 Bytes
8a37e0a
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
import { Box, Button, Flex, Heading } from '@invoke-ai/ui-library';
import ScrollableContent from 'common/components/OverlayScrollbars/ScrollableContent';
import { toast } from 'features/toast/toast';
import { t } from 'i18next';
import { memo, useCallback, useMemo } from 'react';
import { useListModelInstallsQuery, usePruneCompletedModelInstallsMutation } from 'services/api/endpoints/models';

import { ModelInstallQueueItem } from './ModelInstallQueueItem';

export const ModelInstallQueue = memo(() => {
  const { data } = useListModelInstallsQuery();

  const [_pruneCompletedModelInstalls] = usePruneCompletedModelInstallsMutation();

  const pruneCompletedModelInstalls = useCallback(() => {
    _pruneCompletedModelInstalls()
      .unwrap()
      .then((_) => {
        toast({
          id: 'MODEL_INSTALL_QUEUE_PRUNED',
          title: t('toast.prunedQueue'),
          status: 'success',
        });
      })
      .catch((error) => {
        if (error) {
          toast({
            id: 'MODEL_INSTALL_QUEUE_PRUNE_FAILED',
            title: `${error.data.detail} `,
            status: 'error',
          });
        }
      });
  }, [_pruneCompletedModelInstalls]);

  const pruneAvailable = useMemo(() => {
    return data?.some(
      (model) => model.status === 'cancelled' || model.status === 'error' || model.status === 'completed'
    );
  }, [data]);

  return (
    <Flex flexDir="column" p={3} h="full" gap={3}>
      <Flex justifyContent="space-between" alignItems="center">
        <Heading size="sm">{t('modelManager.installQueue')}</Heading>
        <Button
          size="sm"
          isDisabled={!pruneAvailable}
          onClick={pruneCompletedModelInstalls}
          tooltip={t('modelManager.pruneTooltip')}
        >
          {t('modelManager.prune')}
        </Button>
      </Flex>
      <Box layerStyle="first" p={3} borderRadius="base" w="full" h="full">
        <ScrollableContent>
          <Flex flexDir="column-reverse" gap="2" w="full">
            {data?.map((model) => <ModelInstallQueueItem key={model.id} installJob={model} />)}
          </Flex>
        </ScrollableContent>
      </Box>
    </Flex>
  );
});

ModelInstallQueue.displayName = 'ModelInstallQueue';