Skip to content

Commit

Permalink
Improve docs of onResponderGrant and expose via Pressability (#38195)
Browse files Browse the repository at this point in the history
Summary:
Pull Request resolved: #38195

`onResponderGrant`'s return value drives the `blockNativeResponder` value for the `setIsJSResponder` native callback. On Android this is used to call `requestDisallowInterceptTouchEvent`, which can be used to prevent a scrollview from activating while another responder is active.

Changelog: [Improved] Exposed ability to block native responder in Pressability. Pressables using `cancelable={false}` will now prevent scrolling and other native gestures from activating.

Reviewed By: yungsters

Differential Revision: D47225928

fbshipit-source-id: 2af222bcf2debc61c42f55e076f3bff18a975eb3
  • Loading branch information
javache authored and facebook-github-bot committed Jul 6, 2023
1 parent f6c91bf commit 99c4ca6
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -164,8 +164,8 @@ type GestureResponderEventProps = $ReadOnly<{|
* `View.props.onResponderGrant: (event) => {}`, where `event` is a synthetic
* touch event as described above.
*
* PanResponder includes a note `// TODO: t7467124 investigate if this can be removed` that
* should help fixing this return type.
* Return true from this callback to prevent any other native components from
* becoming responder until this responder terminates (Android-only).
*
* See https://reactnative.dev/docs/view#onrespondergrant
*/
Expand Down
10 changes: 8 additions & 2 deletions packages/react-native/Libraries/Pressability/Pressability.js
Original file line number Diff line number Diff line change
Expand Up @@ -134,6 +134,8 @@ export type PressabilityConfig = $ReadOnly<{|
/**
* Returns whether a long press gesture should cancel the press gesture.
* Defaults to true.
*
* @deprecated
*/
onLongPressShouldCancelPress_DEPRECATED?: ?() => boolean,

Expand All @@ -142,6 +144,8 @@ export type PressabilityConfig = $ReadOnly<{|
*
* Returns whether to yield to a lock termination request (e.g. if a native
* scroll gesture attempts to steal the responder lock).
*
* @deprecated
*/
onResponderTerminationRequest_DEPRECATED?: ?() => boolean,

Expand All @@ -163,7 +167,7 @@ export type EventHandlers = $ReadOnly<{|
onMouseLeave?: (event: MouseEvent) => void,
onPointerEnter?: (event: PointerEvent) => void,
onPointerLeave?: (event: PointerEvent) => void,
onResponderGrant: (event: PressEvent) => void,
onResponderGrant: (event: PressEvent) => void | boolean,
onResponderMove: (event: PressEvent) => void,
onResponderRelease: (event: PressEvent) => void,
onResponderTerminate: (event: PressEvent) => void,
Expand Down Expand Up @@ -464,7 +468,7 @@ export default class Pressability {
return !disabled;
},

onResponderGrant: (event: PressEvent): void => {
onResponderGrant: (event: PressEvent): void | boolean => {
event.persist();

this._cancelPressOutDelayTimeout();
Expand All @@ -490,6 +494,8 @@ export default class Pressability {
this._longPressDelayTimeout = setTimeout(() => {
this._handleLongPress(event);
}, delayLongPress + delayPressIn);

return this._config.cancelable === false;
},

onResponderMove: (event: PressEvent): void => {
Expand Down

0 comments on commit 99c4ca6

Please sign in to comment.