import { JSX, ElementType, ForwardRefExoticComponent, CSSProperties, ComponentPropsWithRef } from 'react'; import { FluidValue, FluidProps } from '@react-spring/shared'; import { Merge } from '@react-spring/types'; export * from '@react-spring/core'; import * as csstype from 'csstype'; export { csstype as CSS }; type Primitives = keyof JSX.IntrinsicElements; type AnimatedPrimitives = { [Tag in Primitives]: AnimatedComponent; }; /** The type of the `animated()` function */ type WithAnimated = { (wrappedComponent: T): AnimatedComponent; } & AnimatedPrimitives; /** The type of an `animated()` component */ type AnimatedComponent = ForwardRefExoticComponent, { style?: StyleProps; }>> & FluidProps<{ scrollTop?: number; scrollLeft?: number; viewBox?: string; }>>; /** The props of an `animated()` component */ type AnimatedProps = { [P in keyof Props]: P extends 'ref' | 'key' ? Props[P] : AnimatedProp; }; type StyleProps = Merge; type StylePropKeys = keyof StyleProps; type ValidStyleProps = { [P in keyof T & StylePropKeys]: T[P] extends StyleProps[P] ? P : never; }[keyof T & StylePropKeys]; type AnimatedProp = [T, T] extends [infer T, infer DT] ? [DT] extends [never] ? never : DT extends void ? undefined : DT extends string | number ? DT | AnimatedLeaf : DT extends object ? [ValidStyleProps
] extends [never] ? DT extends ReadonlyArray ? AnimatedStyles
: DT : AnimatedStyle : DT | AnimatedLeaf : never; type AnimatedStyles> = { [P in keyof T]: [T[P]] extends [infer DT] ? DT extends object ? [ValidStyleProps
] extends [never] ? DT extends ReadonlyArray ? AnimatedStyles
: DT : { [P in keyof DT]: AnimatedProp; } : DT : never; }; type AnimatedStyle = [T, T] extends [infer T, infer DT] ? DT extends void ? undefined : [DT] extends [never] ? never : DT extends string | number ? DT | AnimatedLeaf : DT extends object ? AnimatedObject
: DT | AnimatedLeaf : never; type AnimatedObject = { [P in keyof T]: AnimatedStyle; } | (T extends ReadonlyArray ? FluidValue> : never); type AnimatedLeaf = NonObject extends infer U ? [U] extends [never] ? never : FluidValue : never; type NonObject = Extract> | Exclude; type Angle = number | string; type Length = number | string; type TransformProps = { transform?: string; x?: Length; y?: Length; z?: Length; translate?: Length | readonly [Length, Length]; translateX?: Length; translateY?: Length; translateZ?: Length; translate3d?: readonly [Length, Length, Length]; rotate?: Angle; rotateX?: Angle; rotateY?: Angle; rotateZ?: Angle; rotate3d?: readonly [number, number, number, Angle]; scale?: number | readonly [number, number] | string; scaleX?: number; scaleY?: number; scaleZ?: number; scale3d?: readonly [number, number, number]; skew?: Angle | readonly [Angle, Angle]; skewX?: Angle; skewY?: Angle; matrix?: readonly [number, number, number, number, number, number]; matrix3d?: readonly [ number, number, number, number, number, number, number, number, number, number, number, number, number, number, number, number ]; }; declare const animated: WithAnimated; export { type AnimatedComponent, type AnimatedProps, type WithAnimated, animated as a, animated };