UNPKG

react-native-reanimated

Version:

More powerful alternative to Animated library for React Native.

61 lines (54 loc) 1.43 kB
'use strict'; import type { StyleProps } from '../commonTypes'; import type { CSSStyle } from '../css'; import type { NestedArray } from './commonTypes'; export function flattenArray<T>(array: NestedArray<T>): T[] { if (!Array.isArray(array)) { return [array]; } const resultArr: T[] = []; const _flattenArray = (arr: NestedArray<T>[]): void => { arr.forEach((item) => { if (Array.isArray(item)) { _flattenArray(item); } else { resultArr.push(item); } }); }; _flattenArray(array); return resultArr; } export const has = <K extends string>( key: K, x: unknown ): x is { [key in K]: unknown } => { if (typeof x === 'function' || typeof x === 'object') { if (x === null || x === undefined) { return false; } else { return key in x; } } return false; }; type FilteredStyles = { cssStyle: CSSStyle | null; animatedStyles: StyleProps[]; }; export function filterStyles(styles: StyleProps[] | undefined): FilteredStyles { if (!styles) { return { animatedStyles: [], cssStyle: null }; } return styles.reduce<FilteredStyles>( ({ animatedStyles, cssStyle }, style) => { if (style?.viewDescriptors) { animatedStyles.push(style); } else { cssStyle = { ...cssStyle, ...style } as CSSStyle; } return { animatedStyles, cssStyle }; }, { animatedStyles: [], cssStyle: null } ); }