From d17450bbe69b4481db4d54ab2c361c40bfee30fe Mon Sep 17 00:00:00 2001 From: blessedcoolant <54517381+blessedcoolant@users.noreply.github.com> Date: Tue, 18 Jul 2023 20:00:22 +1200 Subject: [PATCH] feat: Add base model label to Model Item --- .../subpanels/ModelManagerPanel/ModelList.tsx | 87 +++++++++++-------- .../ModelManagerPanel/ModelListItem.tsx | 36 ++++++-- 2 files changed, 84 insertions(+), 39 deletions(-) diff --git a/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/ModelList.tsx b/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/ModelList.tsx index 4a12aad0bf..93cef98f80 100644 --- a/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/ModelList.tsx +++ b/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/ModelList.tsx @@ -3,7 +3,7 @@ import { EntityState } from '@reduxjs/toolkit'; import IAIButton from 'common/components/IAIButton'; import IAIInput from 'common/components/IAIInput'; import { forEach } from 'lodash-es'; -import type { ChangeEvent } from 'react'; +import type { ChangeEvent, PropsWithChildren } from 'react'; import { useCallback, useState } from 'react'; import { useTranslation } from 'react-i18next'; import { @@ -44,13 +44,7 @@ const ModelList = (props: ModelListProps) => { return ( - + setModelFormatFilter('all')} @@ -83,35 +77,39 @@ const ModelList = (props: ModelListProps) => { {['all', 'diffusers'].includes(modelFormatFilter) && filteredDiffusersModels.length > 0 && ( - - - Diffusers - - {filteredDiffusersModels.map((model) => ( - - ))} - + + + + Diffusers + + {filteredDiffusersModels.map((model) => ( + + ))} + + )} {['all', 'checkpoint'].includes(modelFormatFilter) && filteredCheckpointModels.length > 0 && ( - - - Checkpoint - - {filteredCheckpointModels.map((model) => ( - - ))} - + + + + Checkpoint + + {filteredCheckpointModels.map((model) => ( + + ))} + + )} @@ -143,3 +141,24 @@ const modelsFilter = ( }); return filteredModels; }; + +const StyledModelContainer = (props: PropsWithChildren) => { + return ( + + {props.children} + + ); +}; diff --git a/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/ModelListItem.tsx b/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/ModelListItem.tsx index 3d2126dce7..24842d8eb2 100644 --- a/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/ModelListItem.tsx +++ b/invokeai/frontend/web/src/features/ui/components/tabs/ModelManager/subpanels/ModelManagerPanel/ModelListItem.tsx @@ -20,6 +20,13 @@ type ModelListItemProps = { setSelectedModelId: (v: string | undefined) => void; }; +const modelBaseTypeMap = { + 'sd-1': 'SD1', + 'sd-2': 'SD2', + sdxl: 'SDXL', + 'sdxl-refiner': 'SDXLR', +}; + export default function ModelListItem(props: ModelListItemProps) { const isBusy = useAppSelector(selectIsBusy); const { t } = useTranslation(); @@ -76,7 +83,7 @@ export default function ModelListItem(props: ModelListItemProps) { bg: isSelected ? 'accent.400' : 'base.100', color: isSelected ? 'base.50' : 'base.800', _hover: { - bg: isSelected ? 'accent.500' : 'base.200', + bg: isSelected ? 'accent.500' : 'base.300', color: isSelected ? 'base.50' : 'base.800', }, _dark: { @@ -84,15 +91,34 @@ export default function ModelListItem(props: ModelListItemProps) { bg: isSelected ? 'accent.600' : 'base.850', _hover: { color: isSelected ? 'base.50' : 'base.100', - bg: isSelected ? 'accent.550' : 'base.800', + bg: isSelected ? 'accent.550' : 'base.700', }, }, }} onClick={handleSelectModel} > - - {model.model_name} - + + + { + modelBaseTypeMap[ + model.base_model as keyof typeof modelBaseTypeMap + ] + } + + + {model.model_name} + +