mirror of
https://github.com/invoke-ai/InvokeAI.git
synced 2026-04-23 03:00:31 -04:00
33 lines
1.3 KiB
TypeScript
33 lines
1.3 KiB
TypeScript
import { IconButton } from '@invoke-ai/ui-library';
|
|
import { useAppDispatch } from 'app/store/storeHooks';
|
|
import { useEntityIdentifierContext } from 'features/controlLayers/contexts/EntityIdentifierContext';
|
|
import { useEntityIsEnabled } from 'features/controlLayers/hooks/useEntityIsEnabled';
|
|
import { entityIsEnabledToggled } from 'features/controlLayers/store/canvasSlice';
|
|
import { memo, useCallback } from 'react';
|
|
import { useTranslation } from 'react-i18next';
|
|
import { PiCircleBold, PiCircleFill } from 'react-icons/pi';
|
|
|
|
export const CanvasEntityEnabledToggle = memo(() => {
|
|
const { t } = useTranslation();
|
|
const entityIdentifier = useEntityIdentifierContext();
|
|
const isEnabled = useEntityIsEnabled(entityIdentifier);
|
|
const dispatch = useAppDispatch();
|
|
const onClick = useCallback(() => {
|
|
dispatch(entityIsEnabledToggled({ entityIdentifier }));
|
|
}, [dispatch, entityIdentifier]);
|
|
|
|
return (
|
|
<IconButton
|
|
size="sm"
|
|
aria-label={t(isEnabled ? 'common.enabled' : 'common.disabled')}
|
|
tooltip={t(isEnabled ? 'common.enabled' : 'common.disabled')}
|
|
variant="link"
|
|
alignSelf="stretch"
|
|
icon={isEnabled ? <PiCircleFill /> : <PiCircleBold />}
|
|
onClick={onClick}
|
|
/>
|
|
);
|
|
});
|
|
|
|
CanvasEntityEnabledToggle.displayName = 'CanvasEntityEnabledToggle';
|