mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
fix(ui): call updateNodeInternals when making connections
This commit is contained in:
parent
6b4e464d17
commit
6f7160b9fd
@ -10,13 +10,15 @@ import {
|
||||
} from 'features/nodes/store/nodesSlice';
|
||||
import { getFirstValidConnection } from 'features/nodes/store/util/connectionValidation';
|
||||
import { isInvocationNode } from 'features/nodes/types/invocation';
|
||||
import { isString } from 'lodash-es';
|
||||
import { useCallback, useMemo } from 'react';
|
||||
import type { OnConnect, OnConnectEnd, OnConnectStart } from 'reactflow';
|
||||
import { type OnConnect, type OnConnectEnd, type OnConnectStart, useUpdateNodeInternals } from 'reactflow';
|
||||
import { assert } from 'tsafe';
|
||||
|
||||
export const useConnection = () => {
|
||||
const store = useAppStore();
|
||||
const templates = useStore($templates);
|
||||
const updateNodeInternals = useUpdateNodeInternals();
|
||||
|
||||
const onConnectStart = useCallback<OnConnectStart>(
|
||||
(event, params) => {
|
||||
@ -41,9 +43,11 @@ export const useConnection = () => {
|
||||
(connection) => {
|
||||
const { dispatch } = store;
|
||||
dispatch(connectionMade(connection));
|
||||
const nodesToUpdate = [connection.source, connection.target].filter(isString);
|
||||
updateNodeInternals(nodesToUpdate);
|
||||
$pendingConnection.set(null);
|
||||
},
|
||||
[store]
|
||||
[store, updateNodeInternals]
|
||||
);
|
||||
const onConnectEnd = useCallback<OnConnectEnd>(() => {
|
||||
const { dispatch } = store;
|
||||
@ -80,13 +84,15 @@ export const useConnection = () => {
|
||||
);
|
||||
if (connection) {
|
||||
dispatch(connectionMade(connection));
|
||||
const nodesToUpdate = [connection.source, connection.target].filter(isString);
|
||||
updateNodeInternals(nodesToUpdate);
|
||||
}
|
||||
$pendingConnection.set(null);
|
||||
} else {
|
||||
// The mouse is not over a node - we should open the add node popover
|
||||
$isAddNodePopoverOpen.set(true);
|
||||
}
|
||||
}, [store, templates]);
|
||||
}, [store, templates, updateNodeInternals]);
|
||||
|
||||
const api = useMemo(() => ({ onConnectStart, onConnect, onConnectEnd }), [onConnectStart, onConnect, onConnectEnd]);
|
||||
return api;
|
||||
|
Loading…
Reference in New Issue
Block a user