mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
tweak(ui): update default settings layouts
This commit is contained in:
parent
1b5d8eb9e7
commit
b8aa9752f1
@ -1,6 +1,7 @@
|
|||||||
import { CompositeNumberInput, CompositeSlider, Flex, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
import { CompositeNumberInput, CompositeSlider, Flex, 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 { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
|
import { SettingToggle } from 'features/modelManagerV2/subpanels/ModelPanel/DefaultSettings/SettingToggle';
|
||||||
import { useCallback, useMemo } from 'react';
|
import { useCallback, useMemo } from 'react';
|
||||||
import type { UseControllerProps } from 'react-hook-form';
|
import type { UseControllerProps } from 'react-hook-form';
|
||||||
import { useController } from 'react-hook-form';
|
import { useController } from 'react-hook-form';
|
||||||
@ -42,11 +43,15 @@ export function DefaultCfgRescaleMultiplier(props: UseControllerProps<DefaultSet
|
|||||||
}, [field.value]);
|
}, [field.value]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl flexDir="column" gap={1} alignItems="flex-start">
|
<FormControl flexDir="column" gap={2} alignItems="flex-start">
|
||||||
<InformationalPopover feature="paramCFGRescaleMultiplier">
|
<Flex justifyContent="space-between" w="full">
|
||||||
<FormLabel>{t('parameters.cfgRescaleMultiplier')}</FormLabel>
|
<InformationalPopover feature="paramCFGRescaleMultiplier">
|
||||||
</InformationalPopover>
|
<FormLabel>{t('parameters.cfgRescaleMultiplier')}</FormLabel>
|
||||||
<Flex w="full" gap={1}>
|
</InformationalPopover>
|
||||||
|
<SettingToggle control={props.control} name="vae" />
|
||||||
|
</Flex>
|
||||||
|
|
||||||
|
<Flex w="full" gap={4}>
|
||||||
<CompositeSlider
|
<CompositeSlider
|
||||||
value={value}
|
value={value}
|
||||||
min={sliderMin}
|
min={sliderMin}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import { CompositeNumberInput, CompositeSlider, Flex, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
import { CompositeNumberInput, CompositeSlider, Flex, 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 { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
|
import { SettingToggle } from 'features/modelManagerV2/subpanels/ModelPanel/DefaultSettings/SettingToggle';
|
||||||
import { useCallback, useMemo } from 'react';
|
import { useCallback, useMemo } from 'react';
|
||||||
import type { UseControllerProps } from 'react-hook-form';
|
import type { UseControllerProps } from 'react-hook-form';
|
||||||
import { useController } from 'react-hook-form';
|
import { useController } from 'react-hook-form';
|
||||||
@ -42,11 +43,15 @@ export function DefaultCfgScale(props: UseControllerProps<DefaultSettingsFormDat
|
|||||||
}, [field.value]);
|
}, [field.value]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl flexDir="column" gap={1} alignItems="flex-start">
|
<FormControl flexDir="column" gap={2} alignItems="flex-start">
|
||||||
<InformationalPopover feature="paramCFGScale">
|
<Flex justifyContent="space-between" w="full">
|
||||||
<FormLabel>{t('parameters.cfgScale')}</FormLabel>
|
<InformationalPopover feature="paramCFGScale">
|
||||||
</InformationalPopover>
|
<FormLabel>{t('parameters.cfgScale')}</FormLabel>
|
||||||
<Flex w="full" gap={1}>
|
</InformationalPopover>
|
||||||
|
<SettingToggle control={props.control} name="cfgScale" />
|
||||||
|
</Flex>
|
||||||
|
|
||||||
|
<Flex w="full" gap={4}>
|
||||||
<CompositeSlider
|
<CompositeSlider
|
||||||
value={value}
|
value={value}
|
||||||
min={sliderMin}
|
min={sliderMin}
|
||||||
|
@ -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, Flex, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
||||||
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
|
import { SettingToggle } from 'features/modelManagerV2/subpanels/ModelPanel/DefaultSettings/SettingToggle';
|
||||||
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 { useCallback, useMemo } from 'react';
|
import { useCallback, useMemo } from 'react';
|
||||||
@ -40,10 +41,13 @@ export function DefaultScheduler(props: UseControllerProps<DefaultSettingsFormDa
|
|||||||
}, [field.value]);
|
}, [field.value]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl flexDir="column" gap={1} alignItems="flex-start">
|
<FormControl flexDir="column" gap={2} alignItems="flex-start">
|
||||||
<InformationalPopover feature="paramScheduler">
|
<Flex justifyContent="space-between" w="full">
|
||||||
<FormLabel>{t('parameters.scheduler')}</FormLabel>
|
<InformationalPopover feature="paramScheduler">
|
||||||
</InformationalPopover>
|
<FormLabel>{t('parameters.scheduler')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
|
<SettingToggle control={props.control} name="scheduler" />
|
||||||
|
</Flex>
|
||||||
<Combobox isDisabled={isDisabled} value={value} options={SCHEDULER_OPTIONS} onChange={onChange} />
|
<Combobox isDisabled={isDisabled} value={value} options={SCHEDULER_OPTIONS} onChange={onChange} />
|
||||||
</FormControl>
|
</FormControl>
|
||||||
);
|
);
|
||||||
|
@ -16,7 +16,6 @@ import { DefaultScheduler } from './DefaultScheduler';
|
|||||||
import { DefaultSteps } from './DefaultSteps';
|
import { DefaultSteps } from './DefaultSteps';
|
||||||
import { DefaultVae } from './DefaultVae';
|
import { DefaultVae } from './DefaultVae';
|
||||||
import { DefaultVaePrecision } from './DefaultVaePrecision';
|
import { DefaultVaePrecision } from './DefaultVaePrecision';
|
||||||
import { SettingToggle } from './SettingToggle';
|
|
||||||
|
|
||||||
export interface FormField<T> {
|
export interface FormField<T> {
|
||||||
value: T;
|
value: T;
|
||||||
@ -96,7 +95,7 @@ export const DefaultSettingsForm = ({
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<Flex gap="2" justifyContent="space-between" w="full" mb={5}>
|
<Flex gap="4" justifyContent="space-between" w="full" pb={4}>
|
||||||
<Heading fontSize="md">{t('modelManager.defaultSettings')}</Heading>
|
<Heading fontSize="md">{t('modelManager.defaultSettings')}</Heading>
|
||||||
<Button
|
<Button
|
||||||
size="sm"
|
size="sm"
|
||||||
@ -114,31 +113,25 @@ export const DefaultSettingsForm = ({
|
|||||||
<Flex flexDir="column" gap={8}>
|
<Flex flexDir="column" gap={8}>
|
||||||
<Flex gap={8}>
|
<Flex gap={8}>
|
||||||
<Flex gap={4} w="full">
|
<Flex gap={4} w="full">
|
||||||
<SettingToggle control={control} name="vae" />
|
|
||||||
<DefaultVae control={control} name="vae" />
|
<DefaultVae control={control} name="vae" />
|
||||||
</Flex>
|
</Flex>
|
||||||
<Flex gap={4} w="full">
|
<Flex gap={4} w="full">
|
||||||
<SettingToggle control={control} name="vaePrecision" />
|
|
||||||
<DefaultVaePrecision control={control} name="vaePrecision" />
|
<DefaultVaePrecision control={control} name="vaePrecision" />
|
||||||
</Flex>
|
</Flex>
|
||||||
</Flex>
|
</Flex>
|
||||||
<Flex gap={8}>
|
<Flex gap={8}>
|
||||||
<Flex gap={4} w="full">
|
<Flex gap={4} w="full">
|
||||||
<SettingToggle control={control} name="scheduler" />
|
|
||||||
<DefaultScheduler control={control} name="scheduler" />
|
<DefaultScheduler control={control} name="scheduler" />
|
||||||
</Flex>
|
</Flex>
|
||||||
<Flex gap={4} w="full">
|
<Flex gap={4} w="full">
|
||||||
<SettingToggle control={control} name="steps" />
|
|
||||||
<DefaultSteps control={control} name="steps" />
|
<DefaultSteps control={control} name="steps" />
|
||||||
</Flex>
|
</Flex>
|
||||||
</Flex>
|
</Flex>
|
||||||
<Flex gap={8}>
|
<Flex gap={8}>
|
||||||
<Flex gap={4} w="full">
|
<Flex gap={4} w="full">
|
||||||
<SettingToggle control={control} name="cfgScale" />
|
|
||||||
<DefaultCfgScale control={control} name="cfgScale" />
|
<DefaultCfgScale control={control} name="cfgScale" />
|
||||||
</Flex>
|
</Flex>
|
||||||
<Flex gap={4} w="full">
|
<Flex gap={4} w="full">
|
||||||
<SettingToggle control={control} name="cfgRescaleMultiplier" />
|
|
||||||
<DefaultCfgRescaleMultiplier control={control} name="cfgRescaleMultiplier" />
|
<DefaultCfgRescaleMultiplier control={control} name="cfgRescaleMultiplier" />
|
||||||
</Flex>
|
</Flex>
|
||||||
</Flex>
|
</Flex>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import { CompositeNumberInput, CompositeSlider, Flex, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
import { CompositeNumberInput, CompositeSlider, Flex, 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 { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
|
import { SettingToggle } from 'features/modelManagerV2/subpanels/ModelPanel/DefaultSettings/SettingToggle';
|
||||||
import { useCallback, useMemo } from 'react';
|
import { useCallback, useMemo } from 'react';
|
||||||
import type { UseControllerProps } from 'react-hook-form';
|
import type { UseControllerProps } from 'react-hook-form';
|
||||||
import { useController } from 'react-hook-form';
|
import { useController } from 'react-hook-form';
|
||||||
@ -42,11 +43,15 @@ export function DefaultSteps(props: UseControllerProps<DefaultSettingsFormData>)
|
|||||||
}, [field.value]);
|
}, [field.value]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl flexDir="column" gap={1} alignItems="flex-start">
|
<FormControl flexDir="column" gap={2} alignItems="flex-start">
|
||||||
<InformationalPopover feature="paramSteps">
|
<Flex justifyContent="space-between" w="full">
|
||||||
<FormLabel>{t('parameters.steps')}</FormLabel>
|
<InformationalPopover feature="paramSteps">
|
||||||
</InformationalPopover>
|
<FormLabel>{t('parameters.steps')}</FormLabel>
|
||||||
<Flex w="full" gap={1}>
|
</InformationalPopover>
|
||||||
|
<SettingToggle control={props.control} name="steps" />
|
||||||
|
</Flex>
|
||||||
|
|
||||||
|
<Flex w="full" gap={4}>
|
||||||
<CompositeSlider
|
<CompositeSlider
|
||||||
value={value}
|
value={value}
|
||||||
min={sliderMin}
|
min={sliderMin}
|
||||||
|
@ -1,8 +1,9 @@
|
|||||||
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, Flex, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
||||||
import { skipToken } from '@reduxjs/toolkit/query';
|
import { skipToken } from '@reduxjs/toolkit/query';
|
||||||
import { useAppSelector } from 'app/store/storeHooks';
|
import { useAppSelector } from 'app/store/storeHooks';
|
||||||
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
|
import { SettingToggle } from 'features/modelManagerV2/subpanels/ModelPanel/DefaultSettings/SettingToggle';
|
||||||
import { map } from 'lodash-es';
|
import { map } from 'lodash-es';
|
||||||
import { useCallback, useMemo } from 'react';
|
import { useCallback, useMemo } from 'react';
|
||||||
import type { UseControllerProps } from 'react-hook-form';
|
import type { UseControllerProps } from 'react-hook-form';
|
||||||
@ -55,10 +56,13 @@ export function DefaultVae(props: UseControllerProps<DefaultSettingsFormData>) {
|
|||||||
}, [field.value]);
|
}, [field.value]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl flexDir="column" gap={1} alignItems="flex-start">
|
<FormControl flexDir="column" gap={2} alignItems="flex-start">
|
||||||
<InformationalPopover feature="paramVAE">
|
<Flex justifyContent="space-between" w="full">
|
||||||
<FormLabel>{t('modelManager.vae')}</FormLabel>
|
<InformationalPopover feature="paramVAE">
|
||||||
</InformationalPopover>
|
<FormLabel>{t('modelManager.vae')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
|
<SettingToggle control={props.control} name="vae" />
|
||||||
|
</Flex>
|
||||||
<Combobox isDisabled={isDisabled} value={value} options={compatibleOptions} onChange={onChange} />
|
<Combobox isDisabled={isDisabled} value={value} options={compatibleOptions} onChange={onChange} />
|
||||||
</FormControl>
|
</FormControl>
|
||||||
);
|
);
|
||||||
|
@ -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, Flex, FormControl, FormLabel } from '@invoke-ai/ui-library';
|
||||||
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
import { InformationalPopover } from 'common/components/InformationalPopover/InformationalPopover';
|
||||||
|
import { SettingToggle } from 'features/modelManagerV2/subpanels/ModelPanel/DefaultSettings/SettingToggle';
|
||||||
import { isParameterPrecision } from 'features/parameters/types/parameterSchemas';
|
import { isParameterPrecision } from 'features/parameters/types/parameterSchemas';
|
||||||
import { useCallback, useMemo } from 'react';
|
import { useCallback, useMemo } from 'react';
|
||||||
import type { UseControllerProps } from 'react-hook-form';
|
import type { UseControllerProps } from 'react-hook-form';
|
||||||
@ -42,9 +43,12 @@ export function DefaultVaePrecision(props: UseControllerProps<DefaultSettingsFor
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<FormControl flexDir="column" gap={1} alignItems="flex-start">
|
<FormControl flexDir="column" gap={1} alignItems="flex-start">
|
||||||
<InformationalPopover feature="paramVAEPrecision">
|
<Flex justifyContent="space-between" w="full">
|
||||||
<FormLabel>{t('modelManager.vaePrecision')}</FormLabel>
|
<InformationalPopover feature="paramVAEPrecision">
|
||||||
</InformationalPopover>
|
<FormLabel>{t('modelManager.vaePrecision')}</FormLabel>
|
||||||
|
</InformationalPopover>
|
||||||
|
<SettingToggle control={props.control} name="vaePrecision" />
|
||||||
|
</Flex>
|
||||||
<Combobox isDisabled={isDisabled} value={value} options={options} onChange={onChange} />
|
<Combobox isDisabled={isDisabled} value={value} options={options} onChange={onChange} />
|
||||||
</FormControl>
|
</FormControl>
|
||||||
);
|
);
|
||||||
|
@ -24,5 +24,5 @@ export function SettingToggle<T>(props: UseControllerProps<DefaultSettingsFormDa
|
|||||||
[field]
|
[field]
|
||||||
);
|
);
|
||||||
|
|
||||||
return <Switch isChecked={value} onChange={onChange} />;
|
return <Switch size="sm" isChecked={value} onChange={onChange} />;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user