diff --git a/invokeai/frontend/web/src/features/controlLayers/components/CanvasEntityList.tsx b/invokeai/frontend/web/src/features/controlLayers/components/CanvasEntityList.tsx
index 5df4b0a4c7..d9d0255d14 100644
--- a/invokeai/frontend/web/src/features/controlLayers/components/CanvasEntityList.tsx
+++ b/invokeai/frontend/web/src/features/controlLayers/components/CanvasEntityList.tsx
@@ -1,53 +1,30 @@
/* eslint-disable i18next/no-literal-string */
import { Flex } from '@invoke-ai/ui-library';
-import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
import { useAppSelector } from 'app/store/storeHooks';
-import { IAINoContentFallback } from 'common/components/IAIImageFallback';
import ScrollableContent from 'common/components/OverlayScrollbars/ScrollableContent';
-import { CA } from 'features/controlLayers/components/ControlAdapter/CA';
-import { IPA } from 'features/controlLayers/components/IPAdapter/IPA';
-import { Layer } from 'features/controlLayers/components/Layer/Layer';
-import { RG } from 'features/controlLayers/components/RegionalGuidance/RG';
-import { mapId } from 'features/controlLayers/konva/util';
-import { selectCanvasV2Slice } from 'features/controlLayers/store/canvasV2Slice';
+import { CAEntityList } from 'features/controlLayers/components/ControlAdapter/CAEntityList';
+import { InitialImage } from 'features/controlLayers/components/InitialImage/InitialImage';
+import { IM } from 'features/controlLayers/components/InpaintMask/IM';
+import { IPAEntityList } from 'features/controlLayers/components/IPAdapter/IPAEntityList';
+import { LayerEntityList } from 'features/controlLayers/components/Layer/LayerEntityList';
+import { RGEntityList } from 'features/controlLayers/components/RegionalGuidance/RGEntityList';
import { memo } from 'react';
-import { useTranslation } from 'react-i18next';
-
-const selectEntityIds = createMemoizedSelector(selectCanvasV2Slice, (canvasV2) => {
- const rgIds = canvasV2.regions.entities.map(mapId).reverse();
- const caIds = canvasV2.controlAdapters.entities.map(mapId).reverse();
- const ipaIds = canvasV2.ipAdapters.entities.map(mapId).reverse();
- const layerIds = canvasV2.layers.entities.map(mapId).reverse();
- const entityCount = rgIds.length + caIds.length + ipaIds.length + layerIds.length;
- return { rgIds, caIds, ipaIds, layerIds, entityCount };
-});
export const CanvasEntityList = memo(() => {
- const { t } = useTranslation();
- const { rgIds, caIds, ipaIds, layerIds, entityCount } = useAppSelector(selectEntityIds);
+ const isCanvasSessionActive = useAppSelector((s) => s.canvasV2.session.isActive);
- if (entityCount > 0) {
- return (
-
-
- {rgIds.map((id) => (
-
- ))}
- {caIds.map((id) => (
-
- ))}
- {ipaIds.map((id) => (
-
- ))}
- {layerIds.map((id) => (
-
- ))}
-
-
- );
- }
-
- return ;
+ return (
+
+
+ {isCanvasSessionActive && }
+
+
+
+
+ {!isCanvasSessionActive && }
+
+
+ );
});
CanvasEntityList.displayName = 'CanvasEntityList';
diff --git a/invokeai/frontend/web/src/features/controlLayers/components/ControlAdapter/CAEntityList.tsx b/invokeai/frontend/web/src/features/controlLayers/components/ControlAdapter/CAEntityList.tsx
new file mode 100644
index 0000000000..e18fa5e166
--- /dev/null
+++ b/invokeai/frontend/web/src/features/controlLayers/components/ControlAdapter/CAEntityList.tsx
@@ -0,0 +1,31 @@
+/* eslint-disable i18next/no-literal-string */
+import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
+import { useAppSelector } from 'app/store/storeHooks';
+import { CA } from 'features/controlLayers/components/ControlAdapter/CA';
+import { mapId } from 'features/controlLayers/konva/util';
+import { selectCanvasV2Slice } from 'features/controlLayers/store/canvasV2Slice';
+import { memo } from 'react';
+
+const selectEntityIds = createMemoizedSelector(selectCanvasV2Slice, (canvasV2) => {
+ return canvasV2.controlAdapters.entities.map(mapId).reverse();
+});
+
+export const CAEntityList = memo(() => {
+ const caIds = useAppSelector(selectEntityIds);
+
+ if (caIds.length === 0) {
+ return null;
+ }
+
+ if (caIds.length > 0) {
+ return (
+ <>
+ {caIds.map((id) => (
+
+ ))}
+ >
+ );
+ }
+});
+
+CAEntityList.displayName = 'CAEntityList';
diff --git a/invokeai/frontend/web/src/features/controlLayers/components/ControlLayersPanelContent.tsx b/invokeai/frontend/web/src/features/controlLayers/components/ControlLayersPanelContent.tsx
index 94e706b68a..f9f7c07811 100644
--- a/invokeai/frontend/web/src/features/controlLayers/components/ControlLayersPanelContent.tsx
+++ b/invokeai/frontend/web/src/features/controlLayers/components/ControlLayersPanelContent.tsx
@@ -1,24 +1,18 @@
/* eslint-disable i18next/no-literal-string */
import { Flex } from '@invoke-ai/ui-library';
-import { useAppSelector } from 'app/store/storeHooks';
import { AddLayerButton } from 'features/controlLayers/components/AddLayerButton';
import { CanvasEntityList } from 'features/controlLayers/components/CanvasEntityList';
import { DeleteAllLayersButton } from 'features/controlLayers/components/DeleteAllLayersButton';
-import { InitialImage } from 'features/controlLayers/components/InitialImage/InitialImage';
-import { IM } from 'features/controlLayers/components/InpaintMask/IM';
import { memo } from 'react';
export const ControlLayersPanelContent = memo(() => {
- const isCanvasSessionActive = useAppSelector((s) => s.canvasV2.session.isActive);
return (
- {isCanvasSessionActive && }
- {!isCanvasSessionActive && }
);
});
diff --git a/invokeai/frontend/web/src/features/controlLayers/components/IPAdapter/IPAEntityList.tsx b/invokeai/frontend/web/src/features/controlLayers/components/IPAdapter/IPAEntityList.tsx
new file mode 100644
index 0000000000..d70847cf39
--- /dev/null
+++ b/invokeai/frontend/web/src/features/controlLayers/components/IPAdapter/IPAEntityList.tsx
@@ -0,0 +1,31 @@
+/* eslint-disable i18next/no-literal-string */
+import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
+import { useAppSelector } from 'app/store/storeHooks';
+import { IPA } from 'features/controlLayers/components/IPAdapter/IPA';
+import { mapId } from 'features/controlLayers/konva/util';
+import { selectCanvasV2Slice } from 'features/controlLayers/store/canvasV2Slice';
+import { memo } from 'react';
+
+const selectEntityIds = createMemoizedSelector(selectCanvasV2Slice, (canvasV2) => {
+ return canvasV2.ipAdapters.entities.map(mapId).reverse();
+});
+
+export const IPAEntityList = memo(() => {
+ const ipaIds = useAppSelector(selectEntityIds);
+
+ if (ipaIds.length === 0) {
+ return null;
+ }
+
+ if (ipaIds.length > 0) {
+ return (
+ <>
+ {ipaIds.map((id) => (
+
+ ))}
+ >
+ );
+ }
+});
+
+IPAEntityList.displayName = 'IPAEntityList';
diff --git a/invokeai/frontend/web/src/features/controlLayers/components/Layer/LayerEntityList.tsx b/invokeai/frontend/web/src/features/controlLayers/components/Layer/LayerEntityList.tsx
new file mode 100644
index 0000000000..89ab0d7aa1
--- /dev/null
+++ b/invokeai/frontend/web/src/features/controlLayers/components/Layer/LayerEntityList.tsx
@@ -0,0 +1,31 @@
+/* eslint-disable i18next/no-literal-string */
+import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
+import { useAppSelector } from 'app/store/storeHooks';
+import { Layer } from 'features/controlLayers/components/Layer/Layer';
+import { mapId } from 'features/controlLayers/konva/util';
+import { selectCanvasV2Slice } from 'features/controlLayers/store/canvasV2Slice';
+import { memo } from 'react';
+
+const selectEntityIds = createMemoizedSelector(selectCanvasV2Slice, (canvasV2) => {
+ return canvasV2.layers.entities.map(mapId).reverse();
+});
+
+export const LayerEntityList = memo(() => {
+ const layerIds = useAppSelector(selectEntityIds);
+
+ if (layerIds.length === 0) {
+ return null;
+ }
+
+ if (layerIds.length > 0) {
+ return (
+ <>
+ {layerIds.map((id) => (
+
+ ))}
+ >
+ );
+ }
+});
+
+LayerEntityList.displayName = 'LayerEntityList';
diff --git a/invokeai/frontend/web/src/features/controlLayers/components/RegionalGuidance/RGEntityList.tsx b/invokeai/frontend/web/src/features/controlLayers/components/RegionalGuidance/RGEntityList.tsx
new file mode 100644
index 0000000000..1e9a68a321
--- /dev/null
+++ b/invokeai/frontend/web/src/features/controlLayers/components/RegionalGuidance/RGEntityList.tsx
@@ -0,0 +1,31 @@
+/* eslint-disable i18next/no-literal-string */
+import { createMemoizedSelector } from 'app/store/createMemoizedSelector';
+import { useAppSelector } from 'app/store/storeHooks';
+import { RG } from 'features/controlLayers/components/RegionalGuidance/RG';
+import { mapId } from 'features/controlLayers/konva/util';
+import { selectCanvasV2Slice } from 'features/controlLayers/store/canvasV2Slice';
+import { memo } from 'react';
+
+const selectEntityIds = createMemoizedSelector(selectCanvasV2Slice, (canvasV2) => {
+ return canvasV2.regions.entities.map(mapId).reverse();
+});
+
+export const RGEntityList = memo(() => {
+ const rgIds = useAppSelector(selectEntityIds);
+
+ if (rgIds.length === 0) {
+ return null;
+ }
+
+ if (rgIds.length > 0) {
+ return (
+ <>
+ {rgIds.map((id) => (
+
+ ))}
+ >
+ );
+ }
+});
+
+RGEntityList.displayName = 'RGEntityList';