mirror of
https://github.com/invoke-ai/InvokeAI.git
synced 2026-02-19 09:54:24 -05:00
73 lines
2.4 KiB
TypeScript
73 lines
2.4 KiB
TypeScript
import { createSelector } from '@reduxjs/toolkit';
|
|
import { useAppSelector } from 'app/store/storeHooks';
|
|
import { selectNodesSlice } from 'features/nodes/store/nodesSlice';
|
|
import { makeConnectionErrorSelector } from 'features/nodes/store/util/makeIsConnectionValidSelector';
|
|
import { useMemo } from 'react';
|
|
|
|
import { useFieldType } from './useFieldType.ts';
|
|
|
|
const selectIsConnectionInProgress = createSelector(
|
|
selectNodesSlice,
|
|
(nodes) => nodes.connectionStartFieldType !== null && nodes.connectionStartParams !== null
|
|
);
|
|
|
|
type UseConnectionStateProps = {
|
|
nodeId: string;
|
|
fieldName: string;
|
|
kind: 'inputs' | 'outputs';
|
|
};
|
|
|
|
export const useConnectionState = ({ nodeId, fieldName, kind }: UseConnectionStateProps) => {
|
|
const fieldType = useFieldType(nodeId, fieldName, kind);
|
|
|
|
const selectIsConnected = useMemo(
|
|
() =>
|
|
createSelector(selectNodesSlice, (nodes) =>
|
|
Boolean(
|
|
nodes.edges.filter((edge) => {
|
|
return (
|
|
(kind === 'inputs' ? edge.target : edge.source) === nodeId &&
|
|
(kind === 'inputs' ? edge.targetHandle : edge.sourceHandle) === fieldName
|
|
);
|
|
}).length
|
|
)
|
|
),
|
|
[fieldName, kind, nodeId]
|
|
);
|
|
|
|
const selectConnectionError = useMemo(
|
|
() => makeConnectionErrorSelector(nodeId, fieldName, kind === 'inputs' ? 'target' : 'source', fieldType),
|
|
[nodeId, fieldName, kind, fieldType]
|
|
);
|
|
|
|
const selectIsConnectionStartField = useMemo(
|
|
() =>
|
|
createSelector(selectNodesSlice, (nodes) =>
|
|
Boolean(
|
|
nodes.connectionStartParams?.nodeId === nodeId &&
|
|
nodes.connectionStartParams?.handleId === fieldName &&
|
|
nodes.connectionStartParams?.handleType === { inputs: 'target', outputs: 'source' }[kind]
|
|
)
|
|
),
|
|
[fieldName, kind, nodeId]
|
|
);
|
|
|
|
const isConnected = useAppSelector(selectIsConnected);
|
|
const isConnectionInProgress = useAppSelector(selectIsConnectionInProgress);
|
|
const isConnectionStartField = useAppSelector(selectIsConnectionStartField);
|
|
const connectionError = useAppSelector(selectConnectionError);
|
|
|
|
const shouldDim = useMemo(
|
|
() => Boolean(isConnectionInProgress && connectionError && !isConnectionStartField),
|
|
[connectionError, isConnectionInProgress, isConnectionStartField]
|
|
);
|
|
|
|
return {
|
|
isConnected,
|
|
isConnectionInProgress,
|
|
isConnectionStartField,
|
|
connectionError,
|
|
shouldDim,
|
|
};
|
|
};
|