mirror of
https://github.com/invoke-ai/InvokeAI.git
synced 2026-02-16 07:35:24 -05:00
76 lines
2.3 KiB
TypeScript
76 lines
2.3 KiB
TypeScript
import { Button, ButtonGroup, Flex, Heading } from '@invoke-ai/ui-library';
|
|
import { useStore } from '@nanostores/react';
|
|
import { useCanvasManager } from 'features/controlLayers/contexts/CanvasManagerProviderGate';
|
|
import {
|
|
EntityIdentifierContext,
|
|
useEntityIdentifierContext,
|
|
} from 'features/controlLayers/contexts/EntityIdentifierContext';
|
|
import { useEntityAdapter } from 'features/controlLayers/hooks/useEntityAdapter';
|
|
import { memo, useCallback } from 'react';
|
|
import { useTranslation } from 'react-i18next';
|
|
import { PiCheckBold, PiXBold } from 'react-icons/pi';
|
|
|
|
const TransformBox = memo(() => {
|
|
const { t } = useTranslation();
|
|
const entityIdentifier = useEntityIdentifierContext();
|
|
const adapter = useEntityAdapter(entityIdentifier);
|
|
const isProcessing = useStore(adapter.transformer.$isProcessing);
|
|
|
|
const applyTransform = useCallback(() => {
|
|
adapter.transformer.applyTransform();
|
|
}, [adapter.transformer]);
|
|
|
|
const cancelFilter = useCallback(() => {
|
|
adapter.transformer.stopTransform();
|
|
}, [adapter.transformer]);
|
|
|
|
return (
|
|
<Flex
|
|
bg="base.800"
|
|
borderRadius="base"
|
|
p={4}
|
|
flexDir="column"
|
|
gap={4}
|
|
w={420}
|
|
h="auto"
|
|
shadow="dark-lg"
|
|
transitionProperty="height"
|
|
transitionDuration="normal"
|
|
>
|
|
<Heading size="md" color="base.300" userSelect="none">
|
|
{t('controlLayers.tool.transform')}
|
|
</Heading>
|
|
<ButtonGroup isAttached={false} size="sm" alignSelf="self-end">
|
|
<Button
|
|
leftIcon={<PiCheckBold />}
|
|
onClick={applyTransform}
|
|
isLoading={isProcessing}
|
|
loadingText={t('common.apply')}
|
|
>
|
|
{t('common.apply')}
|
|
</Button>
|
|
<Button leftIcon={<PiXBold />} onClick={cancelFilter} isLoading={isProcessing} loadingText={t('common.cancel')}>
|
|
{t('common.cancel')}
|
|
</Button>
|
|
</ButtonGroup>
|
|
</Flex>
|
|
);
|
|
});
|
|
|
|
TransformBox.displayName = 'Transform';
|
|
|
|
export const Transform = () => {
|
|
const canvasManager = useCanvasManager();
|
|
const transformingEntity = useStore(canvasManager.stateApi.$transformingEntity);
|
|
|
|
if (!transformingEntity) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<EntityIdentifierContext.Provider value={transformingEntity}>
|
|
<TransformBox />
|
|
</EntityIdentifierContext.Provider>
|
|
);
|
|
};
|