UNPKG

react-native-gesture-handler

Version:

Declarative API exposing native platform touch and gesture system to React Native

52 lines (44 loc) 1.37 kB
import { ContinousBaseGesture } from './gesture'; import type { PinchGestureHandlerEventPayload } from '../GestureHandlerEventPayload'; import { GestureUpdateEvent } from '../gestureHandlerCommon'; export type PinchGestureChangeEventPayload = { scaleChange: number; }; function changeEventCalculator( current: GestureUpdateEvent<PinchGestureHandlerEventPayload>, previous?: GestureUpdateEvent<PinchGestureHandlerEventPayload> ) { 'worklet'; let changePayload: PinchGestureChangeEventPayload; if (previous === undefined) { changePayload = { scaleChange: current.scale, }; } else { changePayload = { scaleChange: current.scale / previous.scale, }; } return { ...current, ...changePayload }; } export class PinchGesture extends ContinousBaseGesture< PinchGestureHandlerEventPayload, PinchGestureChangeEventPayload > { constructor() { super(); this.handlerName = 'PinchGestureHandler'; } onChange( callback: ( event: GestureUpdateEvent< PinchGestureHandlerEventPayload & PinchGestureChangeEventPayload > ) => void ) { // @ts-ignore TS being overprotective, PinchGestureHandlerEventPayload is Record this.handlers.changeEventCalculator = changeEventCalculator; return super.onChange(callback); } } export type PinchGestureType = InstanceType<typeof PinchGesture>;