/** * Copyright (c) Facebook, Inc. and its affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * @flow */ // NOTE: this line is changed in the RN build, see: copyRNShims in packaging.js import type {EventResponder} from 'react-reconciler/src/ReactFiberHostConfig'; export type ReactNode = | React$Element | ReactPortal | ReactText | ReactFragment | ReactProvider | ReactConsumer | ReactEventComponent | ReactEventTarget; export type ReactEmpty = null | void | boolean; export type ReactFragment = ReactEmpty | Iterable; export type ReactNodeList = ReactEmpty | React$Node; export type ReactText = string | number; export type ReactProvider = { $$typeof: Symbol | number, type: ReactProviderType, key: null | string, ref: null, props: { value: T, children?: ReactNodeList, }, }; export type ReactProviderType = { $$typeof: Symbol | number, _context: ReactContext, }; export type ReactConsumer = { $$typeof: Symbol | number, type: ReactContext, key: null | string, ref: null, props: { children: (value: T) => ReactNodeList, unstable_observedBits?: number, }, }; export type ReactContext = { $$typeof: Symbol | number, Consumer: ReactContext, Provider: ReactProviderType, _calculateChangedBits: ((a: T, b: T) => number) | null, _currentValue: T, _currentValue2: T, _threadCount: number, // DEV only _currentRenderer?: Object | null, _currentRenderer2?: Object | null, }; export type ReactPortal = { $$typeof: Symbol | number, key: null | string, containerInfo: any, children: ReactNodeList, // TODO: figure out the API for cross-renderer implementation. implementation: any, }; export type RefObject = {| current: any, |}; export type ReactEventComponentInstance = {| currentFiber: mixed, props: null | Object, responder: EventResponder, rootEventTypes: null | Set, rootInstance: mixed, state: null | Object, |}; export type ReactEventComponent = {| $$typeof: Symbol | number, displayName: string, props: null | Object, responder: EventResponder, |}; export type ReactEventTarget = {| $$typeof: Symbol | number, displayName?: string, type: Symbol | number, |}; export opaque type EventPriority = 0 | 1 | 2; export const DiscreteEvent: EventPriority = 0; export const UserBlockingEvent: EventPriority = 1; export const ContinuousEvent: EventPriority = 2;