mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
fix: Refine some UI
This commit is contained in:
parent
b1e16aa3db
commit
cd033f4ead
@ -18,6 +18,7 @@ export default function AddModelsPanel() {
|
|||||||
onClick={() => setAddModelTab('add')}
|
onClick={() => setAddModelTab('add')}
|
||||||
isChecked={addModelTab == 'add'}
|
isChecked={addModelTab == 'add'}
|
||||||
size="sm"
|
size="sm"
|
||||||
|
width="100%"
|
||||||
>
|
>
|
||||||
{t('modelManager.addModel')}
|
{t('modelManager.addModel')}
|
||||||
</IAIButton>
|
</IAIButton>
|
||||||
@ -25,6 +26,7 @@ export default function AddModelsPanel() {
|
|||||||
onClick={() => setAddModelTab('scan')}
|
onClick={() => setAddModelTab('scan')}
|
||||||
isChecked={addModelTab == 'scan'}
|
isChecked={addModelTab == 'scan'}
|
||||||
size="sm"
|
size="sm"
|
||||||
|
width="100%"
|
||||||
>
|
>
|
||||||
{t('modelManager.scanForModels')}
|
{t('modelManager.scanForModels')}
|
||||||
</IAIButton>
|
</IAIButton>
|
||||||
|
@ -1,111 +1,47 @@
|
|||||||
import { Flex } from '@chakra-ui/react';
|
import { ButtonGroup, Flex } from '@chakra-ui/react';
|
||||||
// import { addNewModel } from 'app/socketio/actions';
|
|
||||||
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
|
|
||||||
import { useTranslation } from 'react-i18next';
|
|
||||||
|
|
||||||
import { SelectItem } from '@mantine/core';
|
|
||||||
import { useForm } from '@mantine/form';
|
|
||||||
import { makeToast } from 'app/components/Toaster';
|
|
||||||
import { RootState } from 'app/store/store';
|
|
||||||
import IAIButton from 'common/components/IAIButton';
|
import IAIButton from 'common/components/IAIButton';
|
||||||
import IAIMantineTextInput from 'common/components/IAIMantineInput';
|
import { useState } from 'react';
|
||||||
import IAIMantineSelect from 'common/components/IAIMantineSelect';
|
import AutoAddModels from './AutoAddModels';
|
||||||
import { addToast } from 'features/system/store/systemSlice';
|
|
||||||
import { useImportMainModelsMutation } from 'services/api/endpoints/models';
|
|
||||||
|
|
||||||
const predictionSelectData: SelectItem[] = [
|
|
||||||
{ label: 'None', value: 'none' },
|
|
||||||
{ label: 'v_prediction', value: 'v_prediction' },
|
|
||||||
{ label: 'epsilon', value: 'epsilon' },
|
|
||||||
{ label: 'sample', value: 'sample' },
|
|
||||||
];
|
|
||||||
|
|
||||||
type ExtendedImportModelConfig = {
|
|
||||||
location: string;
|
|
||||||
prediction_type?: 'v_prediction' | 'epsilon' | 'sample' | 'none' | undefined;
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function AddModels() {
|
export default function AddModels() {
|
||||||
const dispatch = useAppDispatch();
|
const [addModelMode, setAddModelMode] = useState<'simple' | 'advanced'>(
|
||||||
const { t } = useTranslation();
|
'simple'
|
||||||
|
|
||||||
const isProcessing = useAppSelector(
|
|
||||||
(state: RootState) => state.system.isProcessing
|
|
||||||
);
|
);
|
||||||
|
|
||||||
const [importMainModel, { isLoading }] = useImportMainModelsMutation();
|
|
||||||
|
|
||||||
const addModelForm = useForm<ExtendedImportModelConfig>({
|
|
||||||
initialValues: {
|
|
||||||
location: '',
|
|
||||||
prediction_type: undefined,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const handleAddModelSubmit = (values: ExtendedImportModelConfig) => {
|
|
||||||
const importModelResponseBody = {
|
|
||||||
location: values.location,
|
|
||||||
prediction_type:
|
|
||||||
values.prediction_type === 'none' ? undefined : values.prediction_type,
|
|
||||||
};
|
|
||||||
|
|
||||||
importMainModel({ body: importModelResponseBody })
|
|
||||||
.unwrap()
|
|
||||||
.then((_) => {
|
|
||||||
dispatch(
|
|
||||||
addToast(
|
|
||||||
makeToast({
|
|
||||||
title: 'Model Added',
|
|
||||||
status: 'success',
|
|
||||||
})
|
|
||||||
)
|
|
||||||
);
|
|
||||||
addModelForm.reset();
|
|
||||||
})
|
|
||||||
.catch((error) => {
|
|
||||||
if (error) {
|
|
||||||
console.log(error);
|
|
||||||
dispatch(
|
|
||||||
addToast(
|
|
||||||
makeToast({
|
|
||||||
title: `${error.data.detail} `,
|
|
||||||
status: 'error',
|
|
||||||
})
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<form onSubmit={addModelForm.onSubmit((v) => handleAddModelSubmit(v))}>
|
|
||||||
<Flex
|
<Flex
|
||||||
flexDirection="column"
|
flexDirection="column"
|
||||||
|
width="100%"
|
||||||
overflow="scroll"
|
overflow="scroll"
|
||||||
maxHeight={window.innerHeight - 270}
|
maxHeight={window.innerHeight - 270}
|
||||||
width="100%"
|
|
||||||
gap={4}
|
gap={4}
|
||||||
>
|
>
|
||||||
<IAIMantineTextInput
|
<ButtonGroup isAttached>
|
||||||
label="Model Location"
|
|
||||||
placeholder="Provide a path to a local Diffusers model, local checkpoint / safetensors model or a HuggingFace Repo ID"
|
|
||||||
w="100%"
|
|
||||||
{...addModelForm.getInputProps('location')}
|
|
||||||
/>
|
|
||||||
<IAIMantineSelect
|
|
||||||
label="Prediction Type (for Stable Diffusion 2.x Models only)"
|
|
||||||
data={predictionSelectData}
|
|
||||||
defaultValue="none"
|
|
||||||
{...addModelForm.getInputProps('prediction_type')}
|
|
||||||
/>
|
|
||||||
<IAIButton
|
<IAIButton
|
||||||
type="submit"
|
size="sm"
|
||||||
isLoading={isLoading}
|
isChecked={addModelMode == 'simple'}
|
||||||
isDisabled={isLoading || isProcessing}
|
onClick={() => setAddModelMode('simple')}
|
||||||
>
|
>
|
||||||
{t('modelManager.addModel')}
|
Simple
|
||||||
</IAIButton>
|
</IAIButton>
|
||||||
|
<IAIButton
|
||||||
|
size="sm"
|
||||||
|
isChecked={addModelMode == 'advanced'}
|
||||||
|
onClick={() => setAddModelMode('advanced')}
|
||||||
|
>
|
||||||
|
Advanced
|
||||||
|
</IAIButton>
|
||||||
|
</ButtonGroup>
|
||||||
|
<Flex
|
||||||
|
sx={{
|
||||||
|
p: 4,
|
||||||
|
borderRadius: 4,
|
||||||
|
background: 'base.200',
|
||||||
|
_dark: { background: 'base.800' },
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
{addModelMode === 'simple' && <AutoAddModels />}
|
||||||
|
{addModelMode === 'advanced' && null}
|
||||||
|
</Flex>
|
||||||
</Flex>
|
</Flex>
|
||||||
</form>
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,108 @@
|
|||||||
|
import { Flex } from '@chakra-ui/react';
|
||||||
|
// import { addNewModel } from 'app/socketio/actions';
|
||||||
|
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
|
||||||
|
import { useTranslation } from 'react-i18next';
|
||||||
|
|
||||||
|
import { SelectItem } from '@mantine/core';
|
||||||
|
import { useForm } from '@mantine/form';
|
||||||
|
import { makeToast } from 'app/components/Toaster';
|
||||||
|
import { RootState } from 'app/store/store';
|
||||||
|
import IAIButton from 'common/components/IAIButton';
|
||||||
|
import IAIMantineTextInput from 'common/components/IAIMantineInput';
|
||||||
|
import IAIMantineSelect from 'common/components/IAIMantineSelect';
|
||||||
|
import { addToast } from 'features/system/store/systemSlice';
|
||||||
|
import { useImportMainModelsMutation } from 'services/api/endpoints/models';
|
||||||
|
|
||||||
|
const predictionSelectData: SelectItem[] = [
|
||||||
|
{ label: 'None', value: 'none' },
|
||||||
|
{ label: 'v_prediction', value: 'v_prediction' },
|
||||||
|
{ label: 'epsilon', value: 'epsilon' },
|
||||||
|
{ label: 'sample', value: 'sample' },
|
||||||
|
];
|
||||||
|
|
||||||
|
type ExtendedImportModelConfig = {
|
||||||
|
location: string;
|
||||||
|
prediction_type?: 'v_prediction' | 'epsilon' | 'sample' | 'none' | undefined;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default function AutoAddModels() {
|
||||||
|
const dispatch = useAppDispatch();
|
||||||
|
const { t } = useTranslation();
|
||||||
|
|
||||||
|
const isProcessing = useAppSelector(
|
||||||
|
(state: RootState) => state.system.isProcessing
|
||||||
|
);
|
||||||
|
|
||||||
|
const [importMainModel, { isLoading }] = useImportMainModelsMutation();
|
||||||
|
|
||||||
|
const addModelForm = useForm<ExtendedImportModelConfig>({
|
||||||
|
initialValues: {
|
||||||
|
location: '',
|
||||||
|
prediction_type: undefined,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
const handleAddModelSubmit = (values: ExtendedImportModelConfig) => {
|
||||||
|
const importModelResponseBody = {
|
||||||
|
location: values.location,
|
||||||
|
prediction_type:
|
||||||
|
values.prediction_type === 'none' ? undefined : values.prediction_type,
|
||||||
|
};
|
||||||
|
|
||||||
|
importMainModel({ body: importModelResponseBody })
|
||||||
|
.unwrap()
|
||||||
|
.then((_) => {
|
||||||
|
dispatch(
|
||||||
|
addToast(
|
||||||
|
makeToast({
|
||||||
|
title: 'Model Added',
|
||||||
|
status: 'success',
|
||||||
|
})
|
||||||
|
)
|
||||||
|
);
|
||||||
|
addModelForm.reset();
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
if (error) {
|
||||||
|
console.log(error);
|
||||||
|
dispatch(
|
||||||
|
addToast(
|
||||||
|
makeToast({
|
||||||
|
title: `${error.data.detail} `,
|
||||||
|
status: 'error',
|
||||||
|
})
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<form
|
||||||
|
onSubmit={addModelForm.onSubmit((v) => handleAddModelSubmit(v))}
|
||||||
|
style={{ width: '100%' }}
|
||||||
|
>
|
||||||
|
<Flex flexDirection="column" width="100%" gap={4}>
|
||||||
|
<IAIMantineTextInput
|
||||||
|
label="Model Location"
|
||||||
|
placeholder="Provide a path to a local Diffusers model, local checkpoint / safetensors model or a HuggingFace Repo ID"
|
||||||
|
w="100%"
|
||||||
|
{...addModelForm.getInputProps('location')}
|
||||||
|
/>
|
||||||
|
<IAIMantineSelect
|
||||||
|
label="Prediction Type (for Stable Diffusion 2.x Models only)"
|
||||||
|
data={predictionSelectData}
|
||||||
|
defaultValue="none"
|
||||||
|
{...addModelForm.getInputProps('prediction_type')}
|
||||||
|
/>
|
||||||
|
<IAIButton
|
||||||
|
type="submit"
|
||||||
|
isLoading={isLoading}
|
||||||
|
isDisabled={isLoading || isProcessing}
|
||||||
|
>
|
||||||
|
{t('modelManager.addModel')}
|
||||||
|
</IAIButton>
|
||||||
|
</Flex>
|
||||||
|
</form>
|
||||||
|
);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user