From 19e076cd1502fe1fd1935a15543d2ae7174a3e25 Mon Sep 17 00:00:00 2001
From: psychedelicious <4822129+psychedelicious@users.noreply.github.com>
Date: Sat, 15 Jul 2023 19:03:32 +1000
Subject: [PATCH] fix(ui): fix no controlnet model selected by default
---
.../ControlNet/ParamControlNetCollapse.tsx | 25 ++++++++++++++++---
1 file changed, 22 insertions(+), 3 deletions(-)
diff --git a/invokeai/frontend/web/src/features/parameters/components/Parameters/ControlNet/ParamControlNetCollapse.tsx b/invokeai/frontend/web/src/features/parameters/components/Parameters/ControlNet/ParamControlNetCollapse.tsx
index 201cf860c9..2051eed3e3 100644
--- a/invokeai/frontend/web/src/features/parameters/components/Parameters/ControlNet/ParamControlNetCollapse.tsx
+++ b/invokeai/frontend/web/src/features/parameters/components/Parameters/ControlNet/ParamControlNetCollapse.tsx
@@ -8,6 +8,7 @@ import ControlNet from 'features/controlNet/components/ControlNet';
import ParamControlNetFeatureToggle from 'features/controlNet/components/parameters/ParamControlNetFeatureToggle';
import {
controlNetAdded,
+ controlNetModelChanged,
controlNetSelector,
} from 'features/controlNet/store/controlNetSlice';
import { getValidControlNets } from 'features/controlNet/util/getValidControlNets';
@@ -15,6 +16,7 @@ import { useFeatureStatus } from 'features/system/hooks/useFeatureStatus';
import { map } from 'lodash-es';
import { Fragment, memo, useCallback } from 'react';
import { useTranslation } from 'react-i18next';
+import { useGetControlNetModelsQuery } from 'services/api/endpoints/models';
import { v4 as uuidv4 } from 'uuid';
const selector = createSelector(
@@ -39,10 +41,23 @@ const ParamControlNetCollapse = () => {
const { controlNetsArray, activeLabel } = useAppSelector(selector);
const isControlNetDisabled = useFeatureStatus('controlNet').isFeatureDisabled;
const dispatch = useAppDispatch();
+ const { firstModel } = useGetControlNetModelsQuery(undefined, {
+ selectFromResult: (result) => {
+ const firstModel = result.data?.entities[result.data?.ids[0]];
+ return {
+ firstModel,
+ };
+ },
+ });
const handleClickedAddControlNet = useCallback(() => {
- dispatch(controlNetAdded({ controlNetId: uuidv4() }));
- }, [dispatch]);
+ if (!firstModel) {
+ return;
+ }
+ const controlNetId = uuidv4();
+ dispatch(controlNetAdded({ controlNetId }));
+ dispatch(controlNetModelChanged({ controlNetId, model: firstModel }));
+ }, [dispatch, firstModel]);
if (isControlNetDisabled) {
return null;
@@ -58,7 +73,11 @@ const ParamControlNetCollapse = () => {
))}
-
+
Add ControlNet