Skip to main content
Version: 4.x

dispatchCommand

dispatchCommand allows you to run commands on a native component from the UI thread directly.

Reference

import { dispatchCommand } from 'react-native-reanimated';

function App() {
const animatedRef = useAnimatedRef();

const gesture = Gesture.Tap().onStart(() => {
dispatchCommand(animatedRef, 'focus');
});

return (
<>
<AnimatedTextInput ref={animatedRef} style={styles.input} />
<GestureDetector gesture={gesture}>
<Button title="Focus" />
</GestureDetector>
</>
);
}

Type definitions

function dispatchCommand<T extends Component>(
animatedRef: AnimatedRef<T>,
commandName: string,
args?: unknown[]
) => void;

Arguments

animatedRef

An animated ref connected to the component you'd want to update. The animated ref has to be passed either to an Animated component or a React Native built-in component.

commandName

The name of the command to execute, e.g. 'focus' or 'scrollToEnd'.

args
Optional

The array of command arguments. Defaults to an empty array.

Example

  const goDown = Gesture.Tap().onStart(() => {
dispatchCommand(tosRef, 'scrollToEnd', [true]);
dispatchCommand(loginRef, 'focus');
});

Remarks

  • Commands differ from component to component. Check relevant sources i.e. React Native documentation on components to see which commands are available.

Platform compatibility

AndroidiOSWeb