/** * Copyright (c) 2015-present, Facebook, Inc. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * @providesModule StyleSheetTypes * @flow * @format */ 'use strict'; import AnimatedNode from 'AnimatedNode'; export opaque type StyleSheetStyle: number = number; export type ColorValue = null | string; export type DimensionValue = null | number | string | AnimatedNode; export type LayoutStyle<+Dimension = DimensionValue> = { +display?: 'none' | 'flex', +width?: Dimension, +height?: Dimension, +bottom?: Dimension, +end?: Dimension, +left?: Dimension, +right?: Dimension, +start?: Dimension, +top?: Dimension, +minWidth?: Dimension, +maxWidth?: Dimension, +minHeight?: Dimension, +maxHeight?: Dimension, +margin?: Dimension, +marginBottom?: Dimension, +marginEnd?: Dimension, +marginHorizontal?: Dimension, +marginLeft?: Dimension, +marginRight?: Dimension, +marginStart?: Dimension, +marginTop?: Dimension, +marginVertical?: Dimension, +padding?: Dimension, +paddingBottom?: Dimension, +paddingEnd?: Dimension, +paddingHorizontal?: Dimension, +paddingLeft?: Dimension, +paddingRight?: Dimension, +paddingStart?: Dimension, +paddingTop?: Dimension, +paddingVertical?: Dimension, +borderWidth?: number, +borderBottomWidth?: number, +borderEndWidth?: number, +borderLeftWidth?: number, +borderRightWidth?: number, +borderStartWidth?: number, +borderTopWidth?: number, +position?: 'absolute' | 'relative', +flexDirection?: 'row' | 'row-reverse' | 'column' | 'column-reverse', +flexWrap?: 'wrap' | 'nowrap', +justifyContent?: | 'flex-start' | 'flex-end' | 'center' | 'space-between' | 'space-around' | 'space-evenly', +alignItems?: 'flex-start' | 'flex-end' | 'center' | 'stretch' | 'baseline', +alignSelf?: | 'auto' | 'flex-start' | 'flex-end' | 'center' | 'stretch' | 'baseline', +alignContent?: | 'flex-start' | 'flex-end' | 'center' | 'stretch' | 'space-between' | 'space-around', +overflow?: 'visible' | 'hidden' | 'scroll', +flex?: number, +flexGrow?: number, +flexShrink?: number, +flexBasis?: number | string, +aspectRatio?: number, +zIndex?: number, +direction?: 'inherit' | 'ltr' | 'rtl', }; export type TransformStyle = { +transform?: $ReadOnlyArray< | {+perspective: number | AnimatedNode} | {+rotate: string} | {+rotateX: string} | {+rotateY: string} | {+rotateZ: string} | {+scale: number | AnimatedNode} | {+scaleX: number | AnimatedNode} | {+scaleY: number | AnimatedNode} | {+translateX: number | AnimatedNode} | {+translateY: number | AnimatedNode} | { +translate: [number | AnimatedNode, number | AnimatedNode] | AnimatedNode, } | {+skewX: string} | {+skewY: string} // TODO: what is the actual type it expects? | {+matrix: $ReadOnlyArray | AnimatedNode}, >, }; export type ShadowStyle<+Color = ColorValue> = { +shadowColor?: Color, +shadowOffset?: { +width?: number, +height?: number, }, +shadowOpacity?: number | AnimatedNode, +shadowRadius?: number, }; export type ViewStyle<+Dimension = DimensionValue, +Color = ColorValue> = { ...$Exact>, ...$Exact>, ...$Exact, +backfaceVisibility?: 'visible' | 'hidden', +backgroundColor?: Color, +borderColor?: Color, +borderBottomColor?: Color, +borderEndColor?: Color, +borderLeftColor?: Color, +borderRightColor?: Color, +borderStartColor?: Color, +borderTopColor?: Color, +borderRadius?: number, +borderBottomEndRadius?: number, +borderBottomLeftRadius?: number, +borderBottomRightRadius?: number, +borderBottomStartRadius?: number, +borderTopEndRadius?: number, +borderTopLeftRadius?: number, +borderTopRightRadius?: number, +borderTopStartRadius?: number, +borderStyle?: 'solid' | 'dotted' | 'dashed', +borderWidth?: number, +borderBottomWidth?: number, +borderEndWidth?: number, +borderLeftWidth?: number, +borderRightWidth?: number, +borderStartWidth?: number, +borderTopWidth?: number, +opacity?: number | AnimatedNode, +elevation?: number, }; export type TextStyle<+Dimension = DimensionValue, +Color = ColorValue> = { ...$Exact>, +color?: Color, +fontFamily?: string, +fontSize?: number, +fontStyle?: 'normal' | 'italic', +fontWeight?: | 'normal' | 'bold' | '100' | '200' | '300' | '400' | '500' | '600' | '700' | '800' | '900', +fontVariant?: $ReadOnlyArray< | 'small-caps' | 'oldstyle-nums' | 'lining-nums' | 'tabular-nums' | 'proportional-nums', >, +textShadowOffset?: {+width?: number, +height?: number}, +textShadowRadius?: number, +textShadowColor?: Color, +letterSpacing?: number, +lineHeight?: number, +textAlign?: 'auto' | 'left' | 'right' | 'center' | 'justify', +textAlignVertical?: 'auto' | 'top' | 'bottom' | 'center', +includeFontPadding?: boolean, +textDecorationLine?: | 'none' | 'underline' | 'line-through' | 'underline line-through', +textDecorationStyle?: 'solid' | 'double' | 'dotted' | 'dashed', +textDecorationColor?: Color, +writingDirection?: 'auto' | 'ltr' | 'rtl', }; export type ImageStyle<+Dimension = DimensionValue, +Color = ColorValue> = { ...$Exact>, +resizeMode?: 'contain' | 'cover' | 'stretch' | 'center' | 'repeat', +tintColor?: Color, +overlayColor?: string, }; export type Style<+Dimension = DimensionValue, +Color = ColorValue> = { ...$Exact>, +resizeMode?: 'contain' | 'cover' | 'stretch' | 'center' | 'repeat', +tintColor?: Color, +overlayColor?: string, }; export type StyleProp<+T> = | null | void | T | StyleSheetStyle | number | false | '' | $ReadOnlyArray>; // export type ViewStyleProp = StyleProp<$Shape>>; // export type TextStyleProp = StyleProp< // $Shape>, // >; // export type ImageStyleProp = StyleProp< // $Shape>, // >; export type StyleObj = StyleProp<$Shape>>; export type StyleValue = StyleObj; export type ViewStyleProp = StyleObj; export type TextStyleProp = StyleObj; export type ImageStyleProp = StyleObj; export type Styles = { +[key: string]: $Shape>, }; export type StyleSheet<+S: Styles> = $ObjMap StyleSheetStyle>; /* Utility type get non-nullable types for specific style keys. Useful when a component requires values for certain Style Keys. So Instead: ``` type Props = {position: string}; ``` You should use: ``` type Props = {position: TypeForStyleKey<'position'>}; ``` This will correctly give you the type 'absolute' | 'relative' instead of the weak type of just string; */ export type TypeForStyleKey<+key: $Keys>> = $ElementType, key>;