UNPKG

react-native-reanimated

Version:

More powerful alternative to Animated library for React Native.

58 lines (54 loc) 2.35 kB
'use strict'; import { WorkletEventHandler } from "../WorkletEventHandler.js"; import { useEvent } from "./useEvent.js"; import { useHandler } from "./useHandler.js"; /** * Lets you compose multiple event handlers based on * [useEvent](https://docs.swmansion.com/react-native-reanimated/docs/advanced/useEvent) * hook. * * @param handlers - An array of event handlers created using * [useEvent](https://docs.swmansion.com/react-native-reanimated/docs/advanced/useEvent) * hook. * @returns An object you need to pass to a coresponding "onEvent" prop on an * `Animated` component (for example handlers responsible for `onScroll` event * go to `onScroll` prop). * @see https://docs.swmansion.com/react-native-reanimated/docs/advanced/useComposedEventHandler */ // @ts-expect-error This overload is required by our API. export function useComposedEventHandler(handlers) { // Record of handlers' worklets to calculate deps diffs. We use the record type to match the useHandler API requirements const workletsRecord = {}; // Summed event names for registration const composedEventNames = new Set(); // Map that holds worklets for specific handled events const workletsMap = {}; handlers.filter(h => h !== null).forEach(handler => { // EventHandlerProcessed is the return type of useEvent and has to be force casted to EventHandlerInternal, because we need WorkletEventHandler object const { workletEventHandler } = handler; if (workletEventHandler instanceof WorkletEventHandler) { workletEventHandler.eventNames.forEach(eventName => { composedEventNames.add(eventName); if (workletsMap[eventName]) { workletsMap[eventName].push(workletEventHandler.worklet); } else { workletsMap[eventName] = [workletEventHandler.worklet]; } const handlerName = eventName + `${workletsMap[eventName].length}`; workletsRecord[handlerName] = workletEventHandler.worklet; }); } }); const { doDependenciesDiffer } = useHandler(workletsRecord); return useEvent(event => { 'worklet'; if (workletsMap[event.eventName]) { workletsMap[event.eventName].forEach(worklet => worklet(event)); } }, Array.from(composedEventNames), doDependenciesDiffer); } //# sourceMappingURL=useComposedEventHandler.js.map