Files
InvokeAI/invokeai/frontend/web/src/features/nodes/hooks/useOutputFieldConnectionState.ts
2025-02-14 14:50:56 +11:00

36 lines
1.3 KiB
TypeScript

import { useStore } from '@nanostores/react';
import { useAppSelector } from 'app/store/storeHooks';
import { $edgePendingUpdate, $pendingConnection, $templates } from 'features/nodes/store/nodesSlice';
import { makeConnectionErrorSelector } from 'features/nodes/store/util/makeConnectionErrorSelector';
import { useMemo } from 'react';
export const useOutputFieldConnectionState = (nodeId: string, fieldName: string) => {
const pendingConnection = useStore($pendingConnection);
const templates = useStore($templates);
const edgePendingUpdate = useStore($edgePendingUpdate);
const selectValidationResult = useMemo(
() => makeConnectionErrorSelector(templates, nodeId, fieldName, 'source'),
[templates, nodeId, fieldName]
);
const isConnectionInProgress = useMemo(() => Boolean(pendingConnection), [pendingConnection]);
const isConnectionStartField = useMemo(() => {
if (!pendingConnection) {
return false;
}
return (
pendingConnection.nodeId === nodeId &&
pendingConnection.handleId === fieldName &&
pendingConnection.fieldTemplate.fieldKind === 'output'
);
}, [fieldName, nodeId, pendingConnection]);
const validationResult = useAppSelector((s) => selectValidationResult(s, pendingConnection, edgePendingUpdate));
return {
isConnectionInProgress,
isConnectionStartField,
validationResult,
};
};