feat(ui): add informational popovers for upscale params

This commit is contained in:
Mary Hipp 2024-07-24 19:23:14 -04:00 committed by psychedelicious
parent 5be0de967d
commit 4c75b93410
6 changed files with 45 additions and 5 deletions

View File

@ -1509,6 +1509,30 @@
"seamlessTilingYAxis": { "seamlessTilingYAxis": {
"heading": "Seamless Tiling Y Axis", "heading": "Seamless Tiling Y Axis",
"paragraphs": ["Seamlessly tile an image along the vertical axis."] "paragraphs": ["Seamlessly tile an image along the vertical axis."]
},
"upscaleModel": {
"heading": "Upscale Model",
"paragraphs": [
"The Upscale model is used to create the initial resized image for upscaling details to be added to. You can upload new upscaling models that are supported for use in this and other post-processing workflows."
]
},
"scale": {
"heading": "Scale",
"paragraphs": [
"Scale controls the output image size, and is based on a multiple of the input image resolution. For example a 2x upscale on a 1024x1024 image would produce a 2048 x 2048 output."
]
},
"creativity": {
"heading": "Creativity",
"paragraphs": [
"Creativity determines how much the AI can change your image based on your prompt. Low creativity stays close to the original, while high creativity follows the prompt more freely, potentially creating very different results."
]
},
"structure": {
"heading": "Structure",
"paragraphs": [
"Structure controls how closely the new image keeps the layout of your original. Low structure allows major composition changes, while high structure maintains the original layout."
]
} }
}, },
"unifiedCanvas": { "unifiedCanvas": {

View File

@ -53,7 +53,11 @@ export type Feature =
| 'refinerCfgScale' | 'refinerCfgScale'
| 'scaleBeforeProcessing' | 'scaleBeforeProcessing'
| 'seamlessTilingXAxis' | 'seamlessTilingXAxis'
| 'seamlessTilingYAxis'; | 'seamlessTilingYAxis'
| 'upscaleModel'
| 'scale'
| 'creativity'
| 'structure';
export type PopoverData = PopoverProps & { export type PopoverData = PopoverProps & {
image?: string; image?: string;

View File

@ -1,5 +1,6 @@
import { CompositeNumberInput, CompositeSlider, FormControl, FormLabel } from '@invoke-ai/ui-library'; import { CompositeNumberInput, CompositeSlider, FormControl, FormLabel } from '@invoke-ai/ui-library';
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks'; import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
import { creativityChanged } from 'features/parameters/store/upscaleSlice'; import { creativityChanged } from 'features/parameters/store/upscaleSlice';
import { memo, useCallback, useMemo } from 'react'; import { memo, useCallback, useMemo } from 'react';
import { useTranslation } from 'react-i18next'; import { useTranslation } from 'react-i18next';
@ -25,7 +26,9 @@ const ParamCreativity = () => {
return ( return (
<FormControl> <FormControl>
<InformationalPopover feature="creativity">
<FormLabel>{t('upscaling.creativity')}</FormLabel> <FormLabel>{t('upscaling.creativity')}</FormLabel>
</InformationalPopover>
<CompositeSlider <CompositeSlider
value={creativity} value={creativity}
defaultValue={initial} defaultValue={initial}

View File

@ -1,5 +1,6 @@
import { Box, Combobox, FormControl, FormLabel, Tooltip } from '@invoke-ai/ui-library'; import { Box, Combobox, FormControl, FormLabel, Tooltip } from '@invoke-ai/ui-library';
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks'; import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
import { useModelCombobox } from 'common/hooks/useModelCombobox'; import { useModelCombobox } from 'common/hooks/useModelCombobox';
import { upscaleModelChanged } from 'features/parameters/store/upscaleSlice'; import { upscaleModelChanged } from 'features/parameters/store/upscaleSlice';
import { memo, useCallback, useMemo } from 'react'; import { memo, useCallback, useMemo } from 'react';
@ -37,7 +38,9 @@ const ParamSpandrelModel = () => {
return ( return (
<FormControl orientation="vertical"> <FormControl orientation="vertical">
<InformationalPopover feature="upscaleModel">
<FormLabel>{t('upscaling.upscaleModel')}</FormLabel> <FormLabel>{t('upscaling.upscaleModel')}</FormLabel>
</InformationalPopover>
<Tooltip label={tooltipLabel}> <Tooltip label={tooltipLabel}>
<Box w="full"> <Box w="full">
<Combobox <Combobox

View File

@ -1,5 +1,6 @@
import { CompositeNumberInput, CompositeSlider, FormControl, FormLabel } from '@invoke-ai/ui-library'; import { CompositeNumberInput, CompositeSlider, FormControl, FormLabel } from '@invoke-ai/ui-library';
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks'; import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
import { structureChanged } from 'features/parameters/store/upscaleSlice'; import { structureChanged } from 'features/parameters/store/upscaleSlice';
import { memo, useCallback, useMemo } from 'react'; import { memo, useCallback, useMemo } from 'react';
import { useTranslation } from 'react-i18next'; import { useTranslation } from 'react-i18next';
@ -25,7 +26,9 @@ const ParamStructure = () => {
return ( return (
<FormControl> <FormControl>
<InformationalPopover feature="structure">
<FormLabel>{t('upscaling.structure')}</FormLabel> <FormLabel>{t('upscaling.structure')}</FormLabel>
</InformationalPopover>
<CompositeSlider <CompositeSlider
value={structure} value={structure}
defaultValue={initial} defaultValue={initial}

View File

@ -1,5 +1,6 @@
import { CompositeNumberInput, CompositeSlider, Flex, FormControl, FormLabel } from '@invoke-ai/ui-library'; import { CompositeNumberInput, CompositeSlider, Flex, FormControl, FormLabel } from '@invoke-ai/ui-library';
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks'; import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
import { scaleChanged } from 'features/parameters/store/upscaleSlice'; import { scaleChanged } from 'features/parameters/store/upscaleSlice';
import { memo, useCallback } from 'react'; import { memo, useCallback } from 'react';
import { useTranslation } from 'react-i18next'; import { useTranslation } from 'react-i18next';
@ -22,7 +23,9 @@ export const UpscaleScaleSlider = memo(() => {
return ( return (
<FormControl orientation="vertical" gap={0}> <FormControl orientation="vertical" gap={0}>
<InformationalPopover feature="scale">
<FormLabel m={0}>{t('upscaling.scale')}</FormLabel> <FormLabel m={0}>{t('upscaling.scale')}</FormLabel>
</InformationalPopover>
<Flex w="full" gap={4}> <Flex w="full" gap={4}>
<CompositeSlider <CompositeSlider
min={2} min={2}