react-native-reanimated
Version:
More powerful alternative to Animated library for React Native.
45 lines (36 loc) • 1.14 kB
text/typescript
;
import type { PlainStyle } from '../../common';
import { hasSuffix } from '../../common';
import { webPropsBuilder } from '../../common/web';
import type {
CSSAnimationKeyframeBlock,
CSSAnimationKeyframes,
} from '../types';
import { parseTimingFunction } from './utils';
export function processKeyframeDefinitions(definitions: CSSAnimationKeyframes) {
return Object.entries(definitions)
.reduce<string[]>((acc, [timestamp, rules]) => {
const step = hasSuffix(timestamp)
? timestamp
: `${parseFloat(timestamp) * 100}%`;
const processedBlock = processKeyframeBlock(rules);
if (!processedBlock) {
return acc;
}
acc.push(`${step} { ${processedBlock} }`);
return acc;
}, [])
.join(' ');
}
function processKeyframeBlock({
animationTimingFunction,
...rules
}: CSSAnimationKeyframeBlock<PlainStyle>): string | null {
const style = webPropsBuilder.build(rules);
if (!style) {
return null;
}
return animationTimingFunction
? `animation-timing-function: ${parseTimingFunction(animationTimingFunction)}; ${style}`
: style;
}