ui: misc small fixes (#4600)

* feat(ui): tweak queue UI components

* fix(ui): manually dispatch queue status query on queue item status change

RTK Query occasionally aborts the query that occurs when the tag is invalidated, especially if multples of them fire in rapid succession.

This resulted in the queue status and progress bar sometimes not reseting when the queue finishes its last item.

Manually dispatch the query now to get around this. Eventually should probably move this to a socket so we don't need to keep responding to socket with HTTP requests. Just send ti directly via socket

* chore(ui): remove errant console.logs

* fix(ui): do not accumulate node outputs in outputs area

* fix(ui): fix merge issue

---------

Co-authored-by: Kent Keirsey <31807370+hipsterusername@users.noreply.github.com>
This commit is contained in:
psychedelicious 2023-09-21 00:15:39 +10:00 committed by GitHub
parent b5266f89ad
commit 32672cfeda
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 34 additions and 20 deletions

View File

@ -65,7 +65,6 @@ export const addControlNetImageProcessedListener = () => {
); );
const enqueueResult = await req.unwrap(); const enqueueResult = await req.unwrap();
req.reset(); req.reset();
console.log(enqueueResult.queue_item.session_id);
log.debug( log.debug(
{ enqueueResult: parseify(enqueueResult) }, { enqueueResult: parseify(enqueueResult) },
t('queue.graphQueued') t('queue.graphQueued')

View File

@ -76,7 +76,6 @@ export const addInvocationCompleteEventListener = () => {
categories: IMAGE_CATEGORIES, categories: IMAGE_CATEGORIES,
}, },
(draft) => { (draft) => {
console.log(draft);
imagesAdapter.addOne(draft, imageDTO); imagesAdapter.addOne(draft, imageDTO);
} }
) )

View File

@ -9,7 +9,7 @@ import { startAppListening } from '../..';
export const addSocketQueueItemStatusChangedEventListener = () => { export const addSocketQueueItemStatusChangedEventListener = () => {
startAppListening({ startAppListening({
actionCreator: socketQueueItemStatusChanged, actionCreator: socketQueueItemStatusChanged,
effect: (action, { dispatch }) => { effect: async (action, { dispatch }) => {
const log = logger('socketio'); const log = logger('socketio');
const { const {
queue_item_id: item_id, queue_item_id: item_id,
@ -24,9 +24,6 @@ export const addSocketQueueItemStatusChangedEventListener = () => {
dispatch( dispatch(
queueApi.util.updateQueryData('listQueueItems', undefined, (draft) => { queueApi.util.updateQueryData('listQueueItems', undefined, (draft) => {
if (!draft) {
console.log('no draft!');
}
queueItemsAdapter.updateOne(draft, { queueItemsAdapter.updateOne(draft, {
id: item_id, id: item_id,
changes: action.payload.data, changes: action.payload.data,
@ -38,12 +35,19 @@ export const addSocketQueueItemStatusChangedEventListener = () => {
queueApi.util.invalidateTags([ queueApi.util.invalidateTags([
'CurrentSessionQueueItem', 'CurrentSessionQueueItem',
'NextSessionQueueItem', 'NextSessionQueueItem',
'SessionQueueStatus',
{ type: 'SessionQueueItem', id: item_id }, { type: 'SessionQueueItem', id: item_id },
{ type: 'SessionQueueItemDTO', id: item_id }, { type: 'SessionQueueItemDTO', id: item_id },
{ type: 'BatchStatus', id: queue_batch_id }, { type: 'BatchStatus', id: queue_batch_id },
]) ])
); );
const req = dispatch(
queueApi.endpoints.getQueueStatus.initiate(undefined, {
forceRefetch: true,
})
);
await req.unwrap();
req.unsubscribe();
}, },
}); });
}; };

View File

@ -871,7 +871,7 @@ const nodesSlice = createSlice({
nes.error = null; nes.error = null;
nes.progress = null; nes.progress = null;
nes.progressImage = null; nes.progressImage = null;
// do not reset nes.outputs, this allows a user to inspect the output of a node across batches nes.outputs = [];
}); });
} }
}); });

View File

@ -59,16 +59,22 @@ const QueueItemComponent = ({ index, item, context }: InnerItemProps) => {
return `${seconds}s`; return `${seconds}s`;
}, [item]); }, [item]);
const isCanceled = useMemo(
() => ['canceled', 'completed', 'failed'].includes(item.status),
[item.status]
);
return ( return (
<Flex <Flex
flexDir="column" flexDir="column"
borderRadius="base"
aria-selected={isOpen} aria-selected={isOpen}
fontSize="sm" fontSize="sm"
borderRadius="base"
justifyContent="center" justifyContent="center"
sx={sx} sx={sx}
> >
<Flex <Flex
minH={9}
alignItems="center" alignItems="center"
gap={4} gap={4}
p={1.5} p={1.5}
@ -128,10 +134,8 @@ const QueueItemComponent = ({ index, item, context }: InnerItemProps) => {
<ButtonGroup size="xs" variant="ghost"> <ButtonGroup size="xs" variant="ghost">
<IAIIconButton <IAIIconButton
onClick={handleCancelQueueItem} onClick={handleCancelQueueItem}
isDisabled={isCanceled}
isLoading={isLoading} isLoading={isLoading}
isDisabled={['canceled', 'completed', 'failed'].includes(
item.status
)}
aria-label={t('queue.cancelItem')} aria-label={t('queue.cancelItem')}
icon={<FaTimes />} icon={<FaTimes />}
/> />

View File

@ -31,7 +31,7 @@ const QueueItemComponent = ({ queueItemDTO }: Props) => {
const statusAndTiming = useMemo(() => { const statusAndTiming = useMemo(() => {
if (!queueItem) { if (!queueItem) {
return ''; return t('common.loading');
} }
if (!queueItem.completed_at || !queueItem.started_at) { if (!queueItem.completed_at || !queueItem.started_at) {
return t(`queue.${queueItem.status}`); return t(`queue.${queueItem.status}`);
@ -62,6 +62,7 @@ const QueueItemComponent = ({ queueItemDTO }: Props) => {
justifyContent="space-between" justifyContent="space-between"
alignItems="center" alignItems="center"
borderRadius="base" borderRadius="base"
h={20}
> >
<QueueItemData label={t('queue.status')} data={statusAndTiming} /> <QueueItemData label={t('queue.status')} data={statusAndTiming} />
<QueueItemData label={t('queue.item')} data={item_id} /> <QueueItemData label={t('queue.item')} data={item_id} />
@ -136,9 +137,17 @@ type QueueItemDataProps = { label: string; data: ReactNode };
const QueueItemData = ({ label, data }: QueueItemDataProps) => { const QueueItemData = ({ label, data }: QueueItemDataProps) => {
return ( return (
<Flex flexDir="column" p={1} gap={1} overflow="hidden"> <Flex
flexDir="column"
justifyContent="flex-start"
p={1}
gap={1}
overflow="hidden"
h="full"
w="full"
>
<Heading <Heading
size="sm" size="md"
overflow="hidden" overflow="hidden"
textOverflow="ellipsis" textOverflow="ellipsis"
whiteSpace="nowrap" whiteSpace="nowrap"

View File

@ -21,16 +21,16 @@ const QueueListHeader = () => {
> >
<Text variant="subtext">#</Text> <Text variant="subtext">#</Text>
</Flex> </Flex>
<Flex w={COLUMN_WIDTHS.statusBadge} alignItems="center"> <Flex ps={0.5} w={COLUMN_WIDTHS.statusBadge} alignItems="center">
<Text variant="subtext">status</Text> <Text variant="subtext">status</Text>
</Flex> </Flex>
<Flex w={COLUMN_WIDTHS.time} alignItems="center"> <Flex ps={0.5} w={COLUMN_WIDTHS.time} alignItems="center">
<Text variant="subtext">time</Text> <Text variant="subtext">time</Text>
</Flex> </Flex>
<Flex w={COLUMN_WIDTHS.batchId} alignItems="center"> <Flex ps={0.5} w={COLUMN_WIDTHS.batchId} alignItems="center">
<Text variant="subtext">batch</Text> <Text variant="subtext">batch</Text>
</Flex> </Flex>
<Flex alignItems="center" w={COLUMN_WIDTHS.fieldValues}> <Flex ps={0.5} w={COLUMN_WIDTHS.fieldValues} alignItems="center">
<Text variant="subtext">batch field values</Text> <Text variant="subtext">batch field values</Text>
</Flex> </Flex>
</Flex> </Flex>

View File

@ -58,7 +58,6 @@ export default function SimpleAddModels() {
}) })
.catch((error) => { .catch((error) => {
if (error) { if (error) {
console.log(error);
dispatch( dispatch(
addToast( addToast(
makeToast({ makeToast({