mirror of
https://github.com/invoke-ai/InvokeAI.git
synced 2026-04-23 03:00:31 -04:00
29 lines
1.3 KiB
TypeScript
29 lines
1.3 KiB
TypeScript
import { MenuItem } from '@invoke-ai/ui-library';
|
|
import { useEntityAdapterSafe } from 'features/controlLayers/contexts/EntityAdapterContext';
|
|
import { useEntityIdentifierContext } from 'features/controlLayers/contexts/EntityIdentifierContext';
|
|
import { useCopyLayerToClipboard } from 'features/controlLayers/hooks/useCopyLayerToClipboard';
|
|
import { useIsEntityInteractable } from 'features/controlLayers/hooks/useEntityIsInteractable';
|
|
import { memo, useCallback } from 'react';
|
|
import { useTranslation } from 'react-i18next';
|
|
import { PiCopyBold } from 'react-icons/pi';
|
|
|
|
export const CanvasEntityMenuItemsCopyToClipboard = memo(() => {
|
|
const { t } = useTranslation();
|
|
const entityIdentifier = useEntityIdentifierContext();
|
|
const adapter = useEntityAdapterSafe(entityIdentifier);
|
|
const isInteractable = useIsEntityInteractable(entityIdentifier);
|
|
const copyLayerToClipboard = useCopyLayerToClipboard();
|
|
|
|
const onClick = useCallback(() => {
|
|
copyLayerToClipboard(adapter);
|
|
}, [copyLayerToClipboard, adapter]);
|
|
|
|
return (
|
|
<MenuItem onClick={onClick} icon={<PiCopyBold />} isDisabled={!isInteractable}>
|
|
{t('controlLayers.copyToClipboard')}
|
|
</MenuItem>
|
|
);
|
|
});
|
|
|
|
CanvasEntityMenuItemsCopyToClipboard.displayName = 'CanvasEntityMenuItemsCopyToClipboard';
|