From 8a14c5db001a527054c7cc93f724394946058cde Mon Sep 17 00:00:00 2001
From: psychedelicious <4822129+psychedelicious@users.noreply.github.com>
Date: Sat, 15 Jul 2023 18:50:37 +1000
Subject: [PATCH] feat(ui): wip controlnet layout
---
.../controlNet/components/ControlNet.tsx | 122 +++++++++---------
.../parameters/ParamControlNetBeginEnd.tsx | 70 ++++------
.../parameters/ParamControlNetWeight.tsx | 6 +-
3 files changed, 88 insertions(+), 110 deletions(-)
diff --git a/invokeai/frontend/web/src/features/controlNet/components/ControlNet.tsx b/invokeai/frontend/web/src/features/controlNet/components/ControlNet.tsx
index 8f90797fd9..40b4856d99 100644
--- a/invokeai/frontend/web/src/features/controlNet/components/ControlNet.tsx
+++ b/invokeai/frontend/web/src/features/controlNet/components/ControlNet.tsx
@@ -1,4 +1,4 @@
-import { Box, Flex, useColorMode } from '@chakra-ui/react';
+import { Box, Flex } from '@chakra-ui/react';
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
import { memo, useCallback } from 'react';
import { FaCopy, FaTrash } from 'react-icons/fa';
@@ -17,7 +17,6 @@ import { defaultSelectorOptions } from 'app/store/util/defaultMemoizeOptions';
import IAIIconButton from 'common/components/IAIIconButton';
import IAISwitch from 'common/components/IAISwitch';
import { useToggle } from 'react-use';
-import { mode } from 'theme/util/mode';
import { v4 as uuidv4 } from 'uuid';
import ControlNetImagePreview from './ControlNetImagePreview';
import ControlNetProcessorComponent from './ControlNetProcessorComponent';
@@ -46,9 +45,8 @@ const ControlNet = (props: ControlNetProps) => {
);
const { isEnabled, shouldAutoConfig } = useAppSelector(selector);
-
const [isExpanded, toggleIsExpanded] = useToggle(false);
- const { colorMode } = useColorMode();
+
const handleDelete = useCallback(() => {
dispatch(controlNetRemoved({ controlNetId }));
}, [controlNetId, dispatch]);
@@ -72,9 +70,12 @@ const ControlNet = (props: ControlNetProps) => {
flexDir: 'column',
gap: 2,
p: 3,
- bg: mode('base.200', 'base.850')(colorMode),
borderRadius: 'base',
position: 'relative',
+ bg: 'base.200',
+ _dark: {
+ bg: 'base.850',
+ },
}}
>
@@ -120,10 +121,13 @@ const ControlNet = (props: ControlNetProps) => {
}
@@ -136,72 +140,62 @@ const ControlNet = (props: ControlNetProps) => {
w: 1.5,
h: 1.5,
borderRadius: 'full',
- bg: mode('error.700', 'error.200')(colorMode),
top: 4,
insetInlineEnd: 4,
+ bg: 'error.700',
+ _dark: {
+ bg: 'error.200',
+ },
}}
/>
)}
-
-
-
-
- {isEnabled && (
- <>
-
-
-
-
-
-
- {!isExpanded && (
-
-
-
- )}
-
-
+
+
+
+
+
-
- {isExpanded && (
- <>
-
-
-
-
- >
+ {!isExpanded && (
+
+
+
)}
+
+
+
+ {isExpanded && (
+ <>
+
+
+
+
+
+
+
+
>
)}
diff --git a/invokeai/frontend/web/src/features/controlNet/components/parameters/ParamControlNetBeginEnd.tsx b/invokeai/frontend/web/src/features/controlNet/components/parameters/ParamControlNetBeginEnd.tsx
index c08ecf1bb2..57cf3f439e 100644
--- a/invokeai/frontend/web/src/features/controlNet/components/parameters/ParamControlNetBeginEnd.tsx
+++ b/invokeai/frontend/web/src/features/controlNet/components/parameters/ParamControlNetBeginEnd.tsx
@@ -1,5 +1,4 @@
import {
- ChakraProps,
FormControl,
FormLabel,
HStack,
@@ -20,22 +19,14 @@ import {
} from 'features/controlNet/store/controlNetSlice';
import { memo, useCallback, useMemo } from 'react';
-const SLIDER_MARK_STYLES: ChakraProps['sx'] = {
- mt: 1.5,
- fontSize: '2xs',
- fontWeight: '500',
- color: 'base.400',
-};
-
type Props = {
controlNetId: string;
- mini?: boolean;
};
const formatPct = (v: number) => `${Math.round(v * 100)}%`;
const ParamControlNetBeginEnd = (props: Props) => {
- const { controlNetId, mini = false } = props;
+ const { controlNetId } = props;
const dispatch = useAppDispatch();
const selector = useMemo(
@@ -91,38 +82,33 @@ const ParamControlNetBeginEnd = (props: Props) => {
- {!mini && (
- <>
-
- 0%
-
-
- 50%
-
-
- 100%
-
- >
- )}
+
+ 0%
+
+
+ 50%
+
+
+ 100%
+
diff --git a/invokeai/frontend/web/src/features/controlNet/components/parameters/ParamControlNetWeight.tsx b/invokeai/frontend/web/src/features/controlNet/components/parameters/ParamControlNetWeight.tsx
index 3784829be9..f7a2a24cd5 100644
--- a/invokeai/frontend/web/src/features/controlNet/components/parameters/ParamControlNetWeight.tsx
+++ b/invokeai/frontend/web/src/features/controlNet/components/parameters/ParamControlNetWeight.tsx
@@ -8,11 +8,10 @@ import { memo, useCallback, useMemo } from 'react';
type ParamControlNetWeightProps = {
controlNetId: string;
- mini?: boolean;
};
const ParamControlNetWeight = (props: ParamControlNetWeightProps) => {
- const { controlNetId, mini = false } = props;
+ const { controlNetId } = props;
const dispatch = useAppDispatch();
const selector = useMemo(
() =>
@@ -35,13 +34,12 @@ const ParamControlNetWeight = (props: ParamControlNetWeightProps) => {
return (
);