mirror of
https://github.com/invoke-ai/InvokeAI.git
synced 2026-02-17 00:41:22 -05:00
37 lines
1.3 KiB
TypeScript
37 lines
1.3 KiB
TypeScript
import { IconButton, Tooltip } from '@invoke-ai/ui-library';
|
|
import { useSelectTool, useToolIsSelected } from 'features/controlLayers/components/Tool/hooks';
|
|
import { useImageViewer } from 'features/gallery/components/ImageViewer/useImageViewer';
|
|
import { useRegisteredHotkeys } from 'features/system/components/HotkeysModal/useHotkeyData';
|
|
import { memo } from 'react';
|
|
import { useTranslation } from 'react-i18next';
|
|
import { PiHandBold } from 'react-icons/pi';
|
|
|
|
export const ToolViewButton = memo(() => {
|
|
const { t } = useTranslation();
|
|
const isSelected = useToolIsSelected('view');
|
|
const selectView = useSelectTool('view');
|
|
const imageViewer = useImageViewer();
|
|
|
|
useRegisteredHotkeys({
|
|
id: 'selectViewTool',
|
|
category: 'canvas',
|
|
callback: selectView,
|
|
options: { enabled: !isSelected && !imageViewer.isOpen },
|
|
dependencies: [selectView, isSelected, imageViewer.isOpen],
|
|
});
|
|
|
|
return (
|
|
<Tooltip label={`${t('controlLayers.tool.view')} (H)`} placement="end">
|
|
<IconButton
|
|
aria-label={`${t('controlLayers.tool.view')} (H)`}
|
|
icon={<PiHandBold />}
|
|
colorScheme={isSelected ? 'invokeBlue' : 'base'}
|
|
variant="solid"
|
|
onPointerUp={selectView}
|
|
/>
|
|
</Tooltip>
|
|
);
|
|
});
|
|
|
|
ToolViewButton.displayName = 'ToolViewButton';
|