tweak(ui): update default settings layouts

This commit is contained in:
psychedelicious 2024-03-07 17:25:47 +11:00
parent 1b5d8eb9e7
commit b8aa9752f1
8 changed files with 58 additions and 38 deletions

View File

@ -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}

View File

@ -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}

View File

@ -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>
); );

View File

@ -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>

View File

@ -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}

View File

@ -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>
); );

View File

@ -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>
); );

View File

@ -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} />;
} }