mirror of
https://github.com/invoke-ai/InvokeAI.git
synced 2026-02-17 07:44:10 -05:00
- Add Layer Menu Button: `control-layers-add-layer-menu-button` - Delete All Layers Button: `control-layers-delete-all-layers-button` - CL Layer List: `control-layers-layer-list` - CL Canvas: `control-layers-canvas` - Toggle Metadata Button: `toggle-show-metadata-button` - Toggle Progress Button: `toggle-show-progress-button` - Toggle Viewer Menu Button: `toggle-viewer-menu-button` - Settings Tab Button: `generation-tab-settings-tab-button` - Control Layers Tab Button: `generation-tab-control-layers-tab-button`
31 lines
1.1 KiB
TypeScript
31 lines
1.1 KiB
TypeScript
import { IconButton } from '@invoke-ai/ui-library';
|
|
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
|
|
import { setShouldShowProgressInViewer } from 'features/ui/store/uiSlice';
|
|
import { memo, useCallback } from 'react';
|
|
import { useTranslation } from 'react-i18next';
|
|
import { PiHourglassHighBold } from 'react-icons/pi';
|
|
|
|
export const ToggleProgressButton = memo(() => {
|
|
const dispatch = useAppDispatch();
|
|
const shouldShowProgressInViewer = useAppSelector((s) => s.ui.shouldShowProgressInViewer);
|
|
const { t } = useTranslation();
|
|
|
|
const onClick = useCallback(() => {
|
|
dispatch(setShouldShowProgressInViewer(!shouldShowProgressInViewer));
|
|
}, [dispatch, shouldShowProgressInViewer]);
|
|
|
|
return (
|
|
<IconButton
|
|
aria-label={t('settings.displayInProgress')}
|
|
tooltip={t('settings.displayInProgress')}
|
|
icon={<PiHourglassHighBold />}
|
|
onClick={onClick}
|
|
variant="outline"
|
|
colorScheme={shouldShowProgressInViewer ? 'invokeBlue' : 'base'}
|
|
data-testid="toggle-show-progress-button"
|
|
/>
|
|
);
|
|
});
|
|
|
|
ToggleProgressButton.displayName = 'ToggleProgressButton';
|