mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
updated tooltip popovers
This commit is contained in:
parent
f36b5990ed
commit
f0d4c71960
@ -13,28 +13,46 @@ export type Feature =
|
|||||||
| 'compositingCoherenceSteps'
|
| 'compositingCoherenceSteps'
|
||||||
| 'compositingStrength'
|
| 'compositingStrength'
|
||||||
| 'compositingMaskAdjustments'
|
| 'compositingMaskAdjustments'
|
||||||
|
| 'controlNet'
|
||||||
| 'controlNetBeginEnd'
|
| 'controlNetBeginEnd'
|
||||||
| 'controlNetControlMode'
|
| 'controlNetControlMode'
|
||||||
|
| 'controlNetProcessor'
|
||||||
| 'controlNetResizeMode'
|
| 'controlNetResizeMode'
|
||||||
| 'controlNet'
|
|
||||||
| 'controlNetWeight'
|
| 'controlNetWeight'
|
||||||
| 'dynamicPrompts'
|
| 'dynamicPrompts'
|
||||||
| 'dynamicPromptsMaxPrompts'
|
| 'dynamicPromptsMaxPrompts'
|
||||||
| 'dynamicPromptsSeedBehaviour'
|
| 'dynamicPromptsSeedBehaviour'
|
||||||
|
| 'imageFit'
|
||||||
| 'infillMethod'
|
| 'infillMethod'
|
||||||
| 'lora'
|
| 'lora'
|
||||||
|
| 'loraWeight'
|
||||||
| 'noiseUseCPU'
|
| 'noiseUseCPU'
|
||||||
|
| 'paramAspect'
|
||||||
| 'paramCFGScale'
|
| 'paramCFGScale'
|
||||||
| 'paramCFGRescaleMultiplier'
|
| 'paramCFGRescaleMultiplier'
|
||||||
| 'paramDenoisingStrength'
|
| 'paramDenoisingStrength'
|
||||||
|
| 'paramHeight'
|
||||||
|
| 'paramHrf'
|
||||||
| 'paramIterations'
|
| 'paramIterations'
|
||||||
| 'paramModel'
|
| 'paramModel'
|
||||||
| 'paramRatio'
|
| 'paramRatio'
|
||||||
| 'paramSeed'
|
| 'paramSeed'
|
||||||
| 'paramSteps'
|
| 'paramSteps'
|
||||||
|
| 'paramUpscaleMethod'
|
||||||
| 'paramVAE'
|
| 'paramVAE'
|
||||||
| 'paramVAEPrecision'
|
| 'paramVAEPrecision'
|
||||||
| 'scaleBeforeProcessing';
|
| 'paramWidth'
|
||||||
|
| 'patchmatchDownScaleSize'
|
||||||
|
| 'refinerModel'
|
||||||
|
| 'refinerNegativeAestheticScore'
|
||||||
|
| 'refinerPositiveAestheticScore'
|
||||||
|
| 'refinerScheduler'
|
||||||
|
| 'refinerStart'
|
||||||
|
| 'refinerSteps'
|
||||||
|
| 'refinerCfgScale'
|
||||||
|
| 'scaleBeforeProcessing'
|
||||||
|
| 'seamlessTilingXAxis'
|
||||||
|
| 'seamlessTilingYAxis';
|
||||||
|
|
||||||
export type PopoverData = PopoverProps & {
|
export type PopoverData = PopoverProps & {
|
||||||
image?: string;
|
image?: string;
|
||||||
@ -46,21 +64,57 @@ export const POPOVER_DATA: { [key in Feature]?: PopoverData } = {
|
|||||||
paramNegativeConditioning: {
|
paramNegativeConditioning: {
|
||||||
placement: 'right',
|
placement: 'right',
|
||||||
},
|
},
|
||||||
|
clipSkip: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178161-advanced-settings',
|
||||||
|
},
|
||||||
controlNet: {
|
controlNet: {
|
||||||
href: 'https://support.invoke.ai/support/solutions/articles/151000105880',
|
href: 'https://support.invoke.ai/support/solutions/articles/151000105880',
|
||||||
},
|
},
|
||||||
|
controlNetBeginEnd: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178148',
|
||||||
|
},
|
||||||
|
controlNetWeight: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178148',
|
||||||
|
},
|
||||||
lora: {
|
lora: {
|
||||||
href: 'https://support.invoke.ai/support/solutions/articles/151000159072',
|
href: 'https://support.invoke.ai/support/solutions/articles/151000159072',
|
||||||
},
|
},
|
||||||
|
loraWeight: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000159072-concepts-low-rank-adaptations-loras-',
|
||||||
|
},
|
||||||
|
compositingBlur: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000158838-compositing-settings',
|
||||||
|
},
|
||||||
|
compositingBlurMethod: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000158838-compositing-settings',
|
||||||
|
},
|
||||||
compositingCoherenceMode: {
|
compositingCoherenceMode: {
|
||||||
href: 'https://support.invoke.ai/support/solutions/articles/151000158838',
|
href: 'https://support.invoke.ai/support/solutions/articles/151000158838-compositing-settings',
|
||||||
|
},
|
||||||
|
compositingCoherenceSteps: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000158838-compositing-settings',
|
||||||
|
},
|
||||||
|
compositingStrength: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000158838-compositing-settings',
|
||||||
},
|
},
|
||||||
infillMethod: {
|
infillMethod: {
|
||||||
href: 'https://support.invoke.ai/support/solutions/articles/151000158841',
|
href: 'https://support.invoke.ai/support/solutions/articles/151000158841-infill-and-scaling',
|
||||||
},
|
},
|
||||||
scaleBeforeProcessing: {
|
scaleBeforeProcessing: {
|
||||||
href: 'https://support.invoke.ai/support/solutions/articles/151000158841',
|
href: 'https://support.invoke.ai/support/solutions/articles/151000158841',
|
||||||
},
|
},
|
||||||
|
paramCFGScale: {
|
||||||
|
href: 'https://www.youtube.com/watch?v=1OeHEJrsTpI',
|
||||||
|
},
|
||||||
|
paramCFGRescaleMultiplier: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178161-advanced-settings',
|
||||||
|
},
|
||||||
|
paramDenoisingStrength: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000094998-image-to-image',
|
||||||
|
},
|
||||||
|
paramHrf: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000096700-how-can-i-get-larger-images-what-does-upscaling-do-',
|
||||||
|
},
|
||||||
paramIterations: {
|
paramIterations: {
|
||||||
href: 'https://support.invoke.ai/support/solutions/articles/151000159073',
|
href: 'https://support.invoke.ai/support/solutions/articles/151000159073',
|
||||||
},
|
},
|
||||||
@ -70,7 +124,10 @@ export const POPOVER_DATA: { [key in Feature]?: PopoverData } = {
|
|||||||
},
|
},
|
||||||
paramScheduler: {
|
paramScheduler: {
|
||||||
placement: 'right',
|
placement: 'right',
|
||||||
href: 'https://support.invoke.ai/support/solutions/articles/151000159073',
|
href: 'https://www.youtube.com/watch?v=1OeHEJrsTpI',
|
||||||
|
},
|
||||||
|
paramSeed: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000096684-what-is-a-seed-how-do-i-use-it-to-recreate-the-same-image-',
|
||||||
},
|
},
|
||||||
paramModel: {
|
paramModel: {
|
||||||
placement: 'right',
|
placement: 'right',
|
||||||
@ -81,15 +138,53 @@ export const POPOVER_DATA: { [key in Feature]?: PopoverData } = {
|
|||||||
},
|
},
|
||||||
controlNetControlMode: {
|
controlNetControlMode: {
|
||||||
placement: 'right',
|
placement: 'right',
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178148',
|
||||||
|
},
|
||||||
|
controlNetProcessor: {
|
||||||
|
placement: 'right',
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000105880-using-controlnet',
|
||||||
},
|
},
|
||||||
controlNetResizeMode: {
|
controlNetResizeMode: {
|
||||||
placement: 'right',
|
placement: 'right',
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178148',
|
||||||
},
|
},
|
||||||
paramVAE: {
|
paramVAE: {
|
||||||
placement: 'right',
|
placement: 'right',
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178161-advanced-settings',
|
||||||
},
|
},
|
||||||
paramVAEPrecision: {
|
paramVAEPrecision: {
|
||||||
placement: 'right',
|
placement: 'right',
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178161-advanced-settings',
|
||||||
|
},
|
||||||
|
paramUpscaleMethod: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000096700-how-can-i-get-larger-images-what-does-upscaling-do-',
|
||||||
|
},
|
||||||
|
refinerModel: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178333-using-the-refiner',
|
||||||
|
},
|
||||||
|
refinerNegativeAestheticScore: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178333-using-the-refiner',
|
||||||
|
},
|
||||||
|
refinerPositiveAestheticScore: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178333-using-the-refiner',
|
||||||
|
},
|
||||||
|
refinerScheduler: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178333-using-the-refiner',
|
||||||
|
},
|
||||||
|
refinerStart: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178333-using-the-refiner',
|
||||||
|
},
|
||||||
|
refinerSteps: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178333-using-the-refiner',
|
||||||
|
},
|
||||||
|
refinerCfgScale: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178333-using-the-refiner',
|
||||||
|
},
|
||||||
|
seamlessTilingXAxis: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178161-advanced-settings',
|
||||||
|
},
|
||||||
|
seamlessTilingYAxis: {
|
||||||
|
href: 'https://support.invoke.ai/support/solutions/articles/151000178161-advanced-settings',
|
||||||
},
|
},
|
||||||
} as const;
|
} as const;
|
||||||
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
import { CompositeRangeSlider, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
import { CompositeRangeSlider, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
||||||
import { useAppDispatch } from 'app/store/storeHooks';
|
import { useAppDispatch } from 'app/store/storeHooks';
|
||||||
|
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
import { useControlAdapterBeginEndStepPct } from 'features/controlAdapters/hooks/useControlAdapterBeginEndStepPct';
|
import { useControlAdapterBeginEndStepPct } from 'features/controlAdapters/hooks/useControlAdapterBeginEndStepPct';
|
||||||
import { useControlAdapterIsEnabled } from 'features/controlAdapters/hooks/useControlAdapterIsEnabled';
|
import { useControlAdapterIsEnabled } from 'features/controlAdapters/hooks/useControlAdapterIsEnabled';
|
||||||
import {
|
import {
|
||||||
@ -61,12 +62,10 @@ export const ParamControlAdapterBeginEnd = memo(({ id }: Props) => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl
|
<FormControl isDisabled={!isEnabled} orientation="vertical">
|
||||||
isDisabled={!isEnabled}
|
<InformationalPopover feature="controlNetBeginEnd">
|
||||||
// feature="controlNetBeginEnd"
|
<FormLabel>{t('controlnet.beginEndStepPercent')}</FormLabel>
|
||||||
orientation="vertical"
|
</InformationalPopover>
|
||||||
>
|
|
||||||
<FormLabel>{t('controlnet.beginEndStepPercent')}</FormLabel>
|
|
||||||
<CompositeRangeSlider
|
<CompositeRangeSlider
|
||||||
aria-label={ariaLabel}
|
aria-label={ariaLabel}
|
||||||
value={value}
|
value={value}
|
||||||
|
@ -2,6 +2,7 @@ import type { ComboboxOnChange, ComboboxOption } from '@invoke-ai/ui-library';
|
|||||||
import { Combobox, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
import { Combobox, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
||||||
import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
|
import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
|
||||||
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
|
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
|
||||||
|
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
import { useControlAdapterIsEnabled } from 'features/controlAdapters/hooks/useControlAdapterIsEnabled';
|
import { useControlAdapterIsEnabled } from 'features/controlAdapters/hooks/useControlAdapterIsEnabled';
|
||||||
import { useControlAdapterProcessorNode } from 'features/controlAdapters/hooks/useControlAdapterProcessorNode';
|
import { useControlAdapterProcessorNode } from 'features/controlAdapters/hooks/useControlAdapterProcessorNode';
|
||||||
import { CONTROLNET_PROCESSORS } from 'features/controlAdapters/store/constants';
|
import { CONTROLNET_PROCESSORS } from 'features/controlAdapters/store/constants';
|
||||||
@ -58,7 +59,9 @@ const ParamControlAdapterProcessorSelect = ({ id }: Props) => {
|
|||||||
}
|
}
|
||||||
return (
|
return (
|
||||||
<FormControl isDisabled={!isEnabled}>
|
<FormControl isDisabled={!isEnabled}>
|
||||||
<FormLabel>{t('controlnet.processor')}</FormLabel>
|
<InformationalPopover feature="controlNetProcessor">
|
||||||
|
<FormLabel>{t('controlnet.processor')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<Combobox value={value} options={options} onChange={onChange} />
|
<Combobox value={value} options={options} onChange={onChange} />
|
||||||
</FormControl>
|
</FormControl>
|
||||||
);
|
);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import type { ComboboxOnChange, ComboboxOption } from '@invoke-ai/ui-library';
|
import type { ComboboxOnChange, ComboboxOption } from '@invoke-ai/ui-library';
|
||||||
import { Combobox, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
import { Combobox, 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 { setHrfMethod } from 'features/hrf/store/hrfSlice';
|
import { setHrfMethod } from 'features/hrf/store/hrfSlice';
|
||||||
import { isParameterHRFMethod } from 'features/parameters/types/parameterSchemas';
|
import { isParameterHRFMethod } from 'features/parameters/types/parameterSchemas';
|
||||||
import { memo, useCallback, useMemo } from 'react';
|
import { memo, useCallback, useMemo } from 'react';
|
||||||
@ -30,7 +31,9 @@ const ParamHrfMethodSelect = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('hrf.upscaleMethod')}</FormLabel>
|
<InformationalPopover feature="paramUpscaleMethod">
|
||||||
|
<FormLabel>{t('hrf.upscaleMethod')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<Combobox value={value} options={options} onChange={onChange} />
|
<Combobox value={value} options={options} onChange={onChange} />
|
||||||
</FormControl>
|
</FormControl>
|
||||||
);
|
);
|
||||||
|
@ -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 { setHrfStrength } from 'features/hrf/store/hrfSlice';
|
import { setHrfStrength } from 'features/hrf/store/hrfSlice';
|
||||||
import { memo, useCallback } from 'react';
|
import { memo, useCallback } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
@ -25,7 +26,9 @@ const ParamHrfStrength = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('parameters.denoisingStrength')}</FormLabel>
|
<InformationalPopover feature="paramDenoisingStrength">
|
||||||
|
<FormLabel>{`${t('parameters.denoisingStrength')}`}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<CompositeSlider
|
<CompositeSlider
|
||||||
min={sliderMin}
|
min={sliderMin}
|
||||||
max={sliderMax}
|
max={sliderMax}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
import { FormControl, FormLabel, Switch } from '@invoke-ai/ui-library';
|
import { FormControl, FormLabel, Switch } 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 { setHrfEnabled } from 'features/hrf/store/hrfSlice';
|
import { setHrfEnabled } from 'features/hrf/store/hrfSlice';
|
||||||
import type { ChangeEvent } from 'react';
|
import type { ChangeEvent } from 'react';
|
||||||
import { memo, useCallback } from 'react';
|
import { memo, useCallback } from 'react';
|
||||||
@ -18,7 +19,9 @@ const ParamHrfToggle = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl w="full">
|
<FormControl w="full">
|
||||||
<FormLabel flexGrow={1}>{t('hrf.enableHrf')}</FormLabel>
|
<InformationalPopover feature="paramHrf">
|
||||||
|
<FormLabel flexGrow={1}>{t('hrf.enableHrf')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<Switch isChecked={hrfEnabled} onChange={handleHrfEnabled} />
|
<Switch isChecked={hrfEnabled} onChange={handleHrfEnabled} />
|
||||||
</FormControl>
|
</FormControl>
|
||||||
);
|
);
|
||||||
|
@ -10,6 +10,7 @@ import {
|
|||||||
Text,
|
Text,
|
||||||
} from '@invoke-ai/ui-library';
|
} from '@invoke-ai/ui-library';
|
||||||
import { useAppDispatch } from 'app/store/storeHooks';
|
import { useAppDispatch } from 'app/store/storeHooks';
|
||||||
|
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
import type { LoRA } from 'features/lora/store/loraSlice';
|
import type { LoRA } from 'features/lora/store/loraSlice';
|
||||||
import { loraIsEnabledChanged, loraRemoved, loraWeightChanged } from 'features/lora/store/loraSlice';
|
import { loraIsEnabledChanged, loraRemoved, loraWeightChanged } from 'features/lora/store/loraSlice';
|
||||||
import { memo, useCallback } from 'react';
|
import { memo, useCallback } from 'react';
|
||||||
@ -57,29 +58,31 @@ export const LoRACard = memo((props: LoRACardProps) => {
|
|||||||
</Flex>
|
</Flex>
|
||||||
</Flex>
|
</Flex>
|
||||||
</CardHeader>
|
</CardHeader>
|
||||||
<CardBody>
|
<InformationalPopover feature="loraWeight">
|
||||||
<CompositeSlider
|
<CardBody>
|
||||||
value={lora.weight}
|
<CompositeSlider
|
||||||
onChange={handleChange}
|
value={lora.weight}
|
||||||
min={-1}
|
onChange={handleChange}
|
||||||
max={2}
|
min={-1}
|
||||||
step={0.01}
|
max={2}
|
||||||
marks={marks}
|
step={0.01}
|
||||||
defaultValue={0.75}
|
marks={marks}
|
||||||
isDisabled={!lora.isEnabled}
|
defaultValue={0.75}
|
||||||
/>
|
isDisabled={!lora.isEnabled}
|
||||||
<CompositeNumberInput
|
/>
|
||||||
value={lora.weight}
|
<CompositeNumberInput
|
||||||
onChange={handleChange}
|
value={lora.weight}
|
||||||
min={-5}
|
onChange={handleChange}
|
||||||
max={5}
|
min={-5}
|
||||||
step={0.01}
|
max={5}
|
||||||
w={20}
|
step={0.01}
|
||||||
flexShrink={0}
|
w={20}
|
||||||
defaultValue={0.75}
|
flexShrink={0}
|
||||||
isDisabled={!lora.isEnabled}
|
defaultValue={0.75}
|
||||||
/>
|
isDisabled={!lora.isEnabled}
|
||||||
</CardBody>
|
/>
|
||||||
|
</CardBody>
|
||||||
|
</InformationalPopover>
|
||||||
</Card>
|
</Card>
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
@ -2,6 +2,7 @@ import type { ChakraProps } from '@invoke-ai/ui-library';
|
|||||||
import { Combobox, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
import { Combobox, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
||||||
import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
|
import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
|
||||||
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
|
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
|
||||||
|
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
import { useGroupedModelCombobox } from 'common/hooks/useGroupedModelCombobox';
|
import { useGroupedModelCombobox } from 'common/hooks/useGroupedModelCombobox';
|
||||||
import { loraAdded, selectLoraSlice } from 'features/lora/store/loraSlice';
|
import { loraAdded, selectLoraSlice } from 'features/lora/store/loraSlice';
|
||||||
import { memo, useCallback, useMemo } from 'react';
|
import { memo, useCallback, useMemo } from 'react';
|
||||||
@ -57,7 +58,9 @@ const LoRASelect = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl isDisabled={!options.length}>
|
<FormControl isDisabled={!options.length}>
|
||||||
<FormLabel>{t('models.lora')} </FormLabel>
|
<InformationalPopover feature="lora">
|
||||||
|
<FormLabel>{t('models.lora')} </FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<Combobox
|
<Combobox
|
||||||
placeholder={placeholder}
|
placeholder={placeholder}
|
||||||
value={null}
|
value={null}
|
||||||
|
@ -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 { setInfillPatchmatchDownscaleSize } from 'features/parameters/store/generationSlice';
|
import { setInfillPatchmatchDownscaleSize } from 'features/parameters/store/generationSlice';
|
||||||
import { memo, useCallback } from 'react';
|
import { memo, useCallback } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
@ -27,7 +28,9 @@ const ParamInfillPatchmatchDownscaleSize = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl isDisabled={infillMethod !== 'patchmatch'}>
|
<FormControl isDisabled={infillMethod !== 'patchmatch'}>
|
||||||
<FormLabel>{t('parameters.patchmatchDownScaleSize')}</FormLabel>
|
<InformationalPopover feature="patchmatchDownScaleSize">
|
||||||
|
<FormLabel>{t('parameters.patchmatchDownScaleSize')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<CompositeSlider
|
<CompositeSlider
|
||||||
min={sliderMin}
|
min={sliderMin}
|
||||||
max={sliderMax}
|
max={sliderMax}
|
||||||
|
@ -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 { useAppSelector } from 'app/store/storeHooks';
|
import { useAppSelector } from 'app/store/storeHooks';
|
||||||
|
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
import { useImageSizeContext } from 'features/parameters/components/ImageSize/ImageSizeContext';
|
import { useImageSizeContext } from 'features/parameters/components/ImageSize/ImageSizeContext';
|
||||||
import { selectOptimalDimension } from 'features/parameters/store/generationSlice';
|
import { selectOptimalDimension } from 'features/parameters/store/generationSlice';
|
||||||
import { memo, useCallback, useMemo } from 'react';
|
import { memo, useCallback, useMemo } from 'react';
|
||||||
@ -27,7 +28,9 @@ export const ParamHeight = memo(() => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('parameters.height')}</FormLabel>
|
<InformationalPopover feature="paramHeight">
|
||||||
|
<FormLabel>{t('parameters.height')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<CompositeSlider
|
<CompositeSlider
|
||||||
value={ctx.height}
|
value={ctx.height}
|
||||||
defaultValue={optimalDimension}
|
defaultValue={optimalDimension}
|
||||||
|
@ -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 { useAppSelector } from 'app/store/storeHooks';
|
import { useAppSelector } from 'app/store/storeHooks';
|
||||||
|
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
import { useImageSizeContext } from 'features/parameters/components/ImageSize/ImageSizeContext';
|
import { useImageSizeContext } from 'features/parameters/components/ImageSize/ImageSizeContext';
|
||||||
import { selectOptimalDimension } from 'features/parameters/store/generationSlice';
|
import { selectOptimalDimension } from 'features/parameters/store/generationSlice';
|
||||||
import { memo, useCallback, useMemo } from 'react';
|
import { memo, useCallback, useMemo } from 'react';
|
||||||
@ -27,7 +28,9 @@ export const ParamWidth = memo(() => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('parameters.width')}</FormLabel>
|
<InformationalPopover feature="paramWidth">
|
||||||
|
<FormLabel>{t('parameters.width')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<CompositeSlider
|
<CompositeSlider
|
||||||
value={ctx.width}
|
value={ctx.width}
|
||||||
onChange={onChange}
|
onChange={onChange}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import type { ComboboxOption, SystemStyleObject } from '@invoke-ai/ui-library';
|
import type { ComboboxOption, SystemStyleObject } from '@invoke-ai/ui-library';
|
||||||
import { Combobox, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
import { Combobox, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
||||||
import type { SingleValue } from 'chakra-react-select';
|
import type { SingleValue } from 'chakra-react-select';
|
||||||
|
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
import { ASPECT_RATIO_OPTIONS } from 'features/parameters/components/ImageSize/constants';
|
import { ASPECT_RATIO_OPTIONS } from 'features/parameters/components/ImageSize/constants';
|
||||||
import { useImageSizeContext } from 'features/parameters/components/ImageSize/ImageSizeContext';
|
import { useImageSizeContext } from 'features/parameters/components/ImageSize/ImageSizeContext';
|
||||||
import { isAspectRatioID } from 'features/parameters/components/ImageSize/types';
|
import { isAspectRatioID } from 'features/parameters/components/ImageSize/types';
|
||||||
@ -28,7 +29,9 @@ export const AspectRatioSelect = memo(() => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('parameters.aspect')}</FormLabel>
|
<InformationalPopover feature="paramAspect">
|
||||||
|
<FormLabel>{t('parameters.aspect')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<Combobox value={value} onChange={onChange} options={ASPECT_RATIO_OPTIONS} sx={selectStyles} />
|
<Combobox value={value} onChange={onChange} options={ASPECT_RATIO_OPTIONS} sx={selectStyles} />
|
||||||
</FormControl>
|
</FormControl>
|
||||||
);
|
);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import { FormControl, FormLabel, Switch } from '@invoke-ai/ui-library';
|
import { FormControl, FormLabel, Switch } from '@invoke-ai/ui-library';
|
||||||
import type { RootState } from 'app/store/store';
|
import type { RootState } from 'app/store/store';
|
||||||
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
|
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
|
||||||
|
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
import { setShouldFitToWidthHeight } from 'features/parameters/store/generationSlice';
|
import { setShouldFitToWidthHeight } from 'features/parameters/store/generationSlice';
|
||||||
import type { ChangeEvent } from 'react';
|
import type { ChangeEvent } from 'react';
|
||||||
import { memo, useCallback } from 'react';
|
import { memo, useCallback } from 'react';
|
||||||
@ -22,7 +23,9 @@ const ImageToImageFit = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl w="full">
|
<FormControl w="full">
|
||||||
<FormLabel flexGrow={1}>{t('parameters.imageFit')}</FormLabel>
|
<InformationalPopover feature="imageFit">
|
||||||
|
<FormLabel flexGrow={1}>{t('parameters.imageFit')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<Switch isChecked={shouldFitToWidthHeight} onChange={handleChangeFit} />
|
<Switch isChecked={shouldFitToWidthHeight} onChange={handleChangeFit} />
|
||||||
</FormControl>
|
</FormControl>
|
||||||
);
|
);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import { Combobox, FormControl, FormLabel, Tooltip } from '@invoke-ai/ui-library';
|
import { Box, Combobox, FormControl, FormLabel, Tooltip } from '@invoke-ai/ui-library';
|
||||||
import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
|
import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
|
||||||
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
|
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
|
||||||
|
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
import { useGroupedModelCombobox } from 'common/hooks/useGroupedModelCombobox';
|
import { useGroupedModelCombobox } from 'common/hooks/useGroupedModelCombobox';
|
||||||
import { modelSelected } from 'features/parameters/store/actions';
|
import { modelSelected } from 'features/parameters/store/actions';
|
||||||
import { selectGenerationSlice } from 'features/parameters/store/generationSlice';
|
import { selectGenerationSlice } from 'features/parameters/store/generationSlice';
|
||||||
@ -41,18 +42,22 @@ const ParamMainModelSelect = () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Tooltip label={tooltipLabel}>
|
<FormControl isDisabled={!options.length} isInvalid={!options.length}>
|
||||||
<FormControl isDisabled={!options.length} isInvalid={!options.length}>
|
<InformationalPopover feature="paramModel">
|
||||||
<FormLabel>{t('modelManager.model')}</FormLabel>
|
<FormLabel>{t('modelManager.model')}</FormLabel>
|
||||||
<Combobox
|
</InformationalPopover>
|
||||||
value={value}
|
<Tooltip label={tooltipLabel}>
|
||||||
placeholder={placeholder}
|
<Box w="full">
|
||||||
options={options}
|
<Combobox
|
||||||
onChange={onChange}
|
value={value}
|
||||||
noOptionsMessage={noOptionsMessage}
|
placeholder={placeholder}
|
||||||
/>
|
options={options}
|
||||||
</FormControl>
|
onChange={onChange}
|
||||||
</Tooltip>
|
noOptionsMessage={noOptionsMessage}
|
||||||
|
/>
|
||||||
|
</Box>
|
||||||
|
</Tooltip>
|
||||||
|
</FormControl>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
import { FormControl, FormLabel, Switch } from '@invoke-ai/ui-library';
|
import { FormControl, FormLabel, Switch } 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 { setSeamlessXAxis } from 'features/parameters/store/generationSlice';
|
import { setSeamlessXAxis } from 'features/parameters/store/generationSlice';
|
||||||
import type { ChangeEvent } from 'react';
|
import type { ChangeEvent } from 'react';
|
||||||
import { memo, useCallback } from 'react';
|
import { memo, useCallback } from 'react';
|
||||||
@ -20,7 +21,9 @@ const ParamSeamlessXAxis = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('parameters.seamlessXAxis')}</FormLabel>
|
<InformationalPopover feature="seamlessTilingXAxis">
|
||||||
|
<FormLabel>{t('parameters.seamlessXAxis')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<Switch isChecked={seamlessXAxis} onChange={handleChange} />
|
<Switch isChecked={seamlessXAxis} onChange={handleChange} />
|
||||||
</FormControl>
|
</FormControl>
|
||||||
);
|
);
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
import { FormControl, FormLabel, Switch } from '@invoke-ai/ui-library';
|
import { FormControl, FormLabel, Switch } 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 { setSeamlessYAxis } from 'features/parameters/store/generationSlice';
|
import { setSeamlessYAxis } from 'features/parameters/store/generationSlice';
|
||||||
import type { ChangeEvent } from 'react';
|
import type { ChangeEvent } from 'react';
|
||||||
import { memo, useCallback } from 'react';
|
import { memo, useCallback } from 'react';
|
||||||
@ -18,7 +19,9 @@ const ParamSeamlessYAxis = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('parameters.seamlessYAxis')}</FormLabel>
|
<InformationalPopover feature="seamlessTilingYAxis">
|
||||||
|
<FormLabel>{t('parameters.seamlessYAxis')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<Switch isChecked={seamlessYAxis} onChange={handleChange} />
|
<Switch isChecked={seamlessYAxis} onChange={handleChange} />
|
||||||
</FormControl>
|
</FormControl>
|
||||||
);
|
);
|
||||||
|
@ -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 { setRefinerCFGScale } from 'features/sdxl/store/sdxlSlice';
|
import { setRefinerCFGScale } from 'features/sdxl/store/sdxlSlice';
|
||||||
import { memo, useCallback, useMemo } from 'react';
|
import { memo, useCallback, useMemo } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
@ -21,7 +22,9 @@ const ParamSDXLRefinerCFGScale = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('sdxl.cfgScale')}</FormLabel>
|
<InformationalPopover feature="refinerCfgScale">
|
||||||
|
<FormLabel>{t('sdxl.cfgScale')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<CompositeSlider
|
<CompositeSlider
|
||||||
value={refinerCFGScale}
|
value={refinerCFGScale}
|
||||||
defaultValue={initial}
|
defaultValue={initial}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import { Combobox, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
import { Combobox, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
||||||
import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
|
import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
|
||||||
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 { refinerModelChanged, selectSdxlSlice } from 'features/sdxl/store/sdxlSlice';
|
import { refinerModelChanged, selectSdxlSlice } from 'features/sdxl/store/sdxlSlice';
|
||||||
import { memo, useCallback } from 'react';
|
import { memo, useCallback } from 'react';
|
||||||
@ -43,7 +44,9 @@ const ParamSDXLRefinerModelSelect = () => {
|
|||||||
});
|
});
|
||||||
return (
|
return (
|
||||||
<FormControl isDisabled={!options.length} isInvalid={!options.length}>
|
<FormControl isDisabled={!options.length} isInvalid={!options.length}>
|
||||||
<FormLabel>{t('sdxl.refinermodel')}</FormLabel>
|
<InformationalPopover feature="refinerModel">
|
||||||
|
<FormLabel>{t('sdxl.refinermodel')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<Combobox
|
<Combobox
|
||||||
value={value}
|
value={value}
|
||||||
placeholder={placeholder}
|
placeholder={placeholder}
|
||||||
|
@ -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 { setRefinerNegativeAestheticScore } from 'features/sdxl/store/sdxlSlice';
|
import { setRefinerNegativeAestheticScore } from 'features/sdxl/store/sdxlSlice';
|
||||||
import { memo, useCallback } from 'react';
|
import { memo, useCallback } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
@ -14,7 +15,9 @@ const ParamSDXLRefinerNegativeAestheticScore = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('sdxl.negAestheticScore')}</FormLabel>
|
<InformationalPopover feature="refinerNegativeAestheticScore">
|
||||||
|
<FormLabel>{t('sdxl.negAestheticScore')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<CompositeSlider
|
<CompositeSlider
|
||||||
min={1}
|
min={1}
|
||||||
max={10}
|
max={10}
|
||||||
|
@ -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 { setRefinerPositiveAestheticScore } from 'features/sdxl/store/sdxlSlice';
|
import { setRefinerPositiveAestheticScore } from 'features/sdxl/store/sdxlSlice';
|
||||||
import { memo, useCallback } from 'react';
|
import { memo, useCallback } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
@ -13,7 +14,9 @@ const ParamSDXLRefinerPositiveAestheticScore = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('sdxl.posAestheticScore')}</FormLabel>
|
<InformationalPopover feature="refinerPositiveAestheticScore">
|
||||||
|
<FormLabel>{t('sdxl.posAestheticScore')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<CompositeSlider
|
<CompositeSlider
|
||||||
step={0.5}
|
step={0.5}
|
||||||
min={1}
|
min={1}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import type { ComboboxOnChange } from '@invoke-ai/ui-library';
|
import type { ComboboxOnChange } from '@invoke-ai/ui-library';
|
||||||
import { Combobox, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
import { Combobox, 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 { SCHEDULER_OPTIONS } from 'features/parameters/types/constants';
|
import { SCHEDULER_OPTIONS } from 'features/parameters/types/constants';
|
||||||
import { isParameterScheduler } from 'features/parameters/types/parameterSchemas';
|
import { isParameterScheduler } from 'features/parameters/types/parameterSchemas';
|
||||||
import { setRefinerScheduler } from 'features/sdxl/store/sdxlSlice';
|
import { setRefinerScheduler } from 'features/sdxl/store/sdxlSlice';
|
||||||
@ -26,7 +27,9 @@ const ParamSDXLRefinerScheduler = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('sdxl.scheduler')}</FormLabel>
|
<InformationalPopover feature="refinerScheduler">
|
||||||
|
<FormLabel>{t('sdxl.scheduler')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<Combobox value={value} options={SCHEDULER_OPTIONS} onChange={onChange} />
|
<Combobox value={value} options={SCHEDULER_OPTIONS} onChange={onChange} />
|
||||||
</FormControl>
|
</FormControl>
|
||||||
);
|
);
|
||||||
|
@ -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 { setRefinerStart } from 'features/sdxl/store/sdxlSlice';
|
import { setRefinerStart } from 'features/sdxl/store/sdxlSlice';
|
||||||
import { memo, useCallback } from 'react';
|
import { memo, useCallback } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
@ -12,7 +13,9 @@ const ParamSDXLRefinerStart = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('sdxl.refinerStart')}</FormLabel>
|
<InformationalPopover feature="refinerStart">
|
||||||
|
<FormLabel>{t('sdxl.refinerStart')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<CompositeSlider
|
<CompositeSlider
|
||||||
step={0.01}
|
step={0.01}
|
||||||
min={0}
|
min={0}
|
||||||
|
@ -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 { setRefinerSteps } from 'features/sdxl/store/sdxlSlice';
|
import { setRefinerSteps } from 'features/sdxl/store/sdxlSlice';
|
||||||
import { memo, useCallback, useMemo } from 'react';
|
import { memo, useCallback, useMemo } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
@ -27,7 +28,9 @@ const ParamSDXLRefinerSteps = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl>
|
<FormControl>
|
||||||
<FormLabel>{t('sdxl.steps')}</FormLabel>
|
<InformationalPopover feature="refinerSteps">
|
||||||
|
<FormLabel>{t('sdxl.steps')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
<CompositeSlider
|
<CompositeSlider
|
||||||
value={refinerSteps}
|
value={refinerSteps}
|
||||||
defaultValue={initial}
|
defaultValue={initial}
|
||||||
|
Loading…
Reference in New Issue
Block a user