import { Badge, Box, IconButton, Menu, MenuButton, MenuDivider, MenuItem, MenuList, useDisclosure, } from '@invoke-ai/ui-library'; import { useAppDispatch } from 'app/store/storeHooks'; import ClearQueueConfirmationAlertDialog from 'features/queue/components/ClearQueueConfirmationAlertDialog'; import { useClearQueue } from 'features/queue/hooks/useClearQueue'; import { usePauseProcessor } from 'features/queue/hooks/usePauseProcessor'; import { useResumeProcessor } from 'features/queue/hooks/useResumeProcessor'; import { useFeatureStatus } from 'features/system/hooks/useFeatureStatus'; import { setActiveTab } from 'features/ui/store/uiSlice'; import { memo, useCallback } from 'react'; import { useTranslation } from 'react-i18next'; import { PiPauseFill, PiPlayFill, PiTrashSimpleBold } from 'react-icons/pi'; import { RiListCheck, RiPlayList2Fill } from 'react-icons/ri'; import { useGetQueueStatusQuery } from 'services/api/endpoints/queue'; export const QueueActionsMenuButton = memo(() => { const { isOpen, onOpen, onClose } = useDisclosure(); const dispatch = useAppDispatch(); const { t } = useTranslation(); const clearQueueDisclosure = useDisclosure(); const isPauseEnabled = useFeatureStatus('pauseQueue'); const isResumeEnabled = useFeatureStatus('resumeQueue'); const { queueSize } = useGetQueueStatusQuery(undefined, { selectFromResult: (res) => ({ queueSize: res.data ? res.data.queue.pending + res.data.queue.in_progress : 0, }), }); const { isLoading: isLoadingClearQueue, isDisabled: isDisabledClearQueue } = useClearQueue(); const { resumeProcessor, isLoading: isLoadingResumeProcessor, isDisabled: isDisabledResumeProcessor, } = useResumeProcessor(); const { pauseProcessor, isLoading: isLoadingPauseProcessor, isDisabled: isDisabledPauseProcessor, } = usePauseProcessor(); const openQueue = useCallback(() => { dispatch(setActiveTab('queue')); }, [dispatch]); return ( } /> } onClick={clearQueueDisclosure.onOpen} isLoading={isLoadingClearQueue} isDisabled={isDisabledClearQueue} > {t('queue.clearTooltip')} {isResumeEnabled && ( } onClick={resumeProcessor} isLoading={isLoadingResumeProcessor} isDisabled={isDisabledResumeProcessor} > {t('queue.resumeTooltip')} )} {isPauseEnabled && ( } onClick={pauseProcessor} isLoading={isLoadingPauseProcessor} isDisabled={isDisabledPauseProcessor} > {t('queue.pauseTooltip')} )} } onClick={openQueue}> {t('queue.openQueue')} {queueSize > 0 && ( {queueSize} )} ); }); QueueActionsMenuButton.displayName = 'QueueActionsMenuButton';