react-native-reanimated
Version:
More powerful alternative to Animated library for React Native.
55 lines (50 loc) • 1.79 kB
JavaScript
import { useEffect, useRef } from 'react';
import { initialUpdaterRun } from "../animation/index.js";
import { makeMutable, startMapper, stopMapper } from "../core.js";
import { shouldBeUseWeb } from "../PlatformChecker.js";
/**
* Lets you create new shared values based on existing ones while keeping them
* reactive.
*
* @param updater - A function called whenever at least one of the shared values
* or state used in the function body changes.
* @param dependencies - An optional array of dependencies. Only relevant when
* using Reanimated without the Babel plugin on the Web.
* @returns A new readonly shared value based on a value returned from the
* updater function
* @see https://docs.swmansion.com/react-native-reanimated/docs/core/useDerivedValue
*/
// @ts-expect-error This overload is required by our API.
export function useDerivedValue(updater, dependencies) {
const initRef = useRef(null);
let inputs = Object.values(updater.__closure ?? {});
if (shouldBeUseWeb()) {
if (!inputs.length && dependencies?.length) {
// let web work without a Babel/SWC plugin
inputs = dependencies;
}
}
// build dependencies
if (dependencies === undefined) {
dependencies = [...inputs, updater.__workletHash];
} else {
dependencies.push(updater.__workletHash);
}
if (initRef.current === null) {
initRef.current = makeMutable(initialUpdaterRun(updater));
}
const sharedValue = initRef.current;
useEffect(() => {
const fun = () => {
'worklet';
sharedValue.value = updater();
};
const mapperId = startMapper(fun, inputs, [sharedValue]);
return () => {
stopMapper(mapperId);
};
}, dependencies);
return sharedValue;
}
//# sourceMappingURL=useDerivedValue.js.map
;