/** * 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 strict-local * @format */ import * as NativeComponentRegistry from '../../NativeComponent/NativeComponentRegistry'; import ReactNativeViewViewConfig from '../../Components/View/ReactNativeViewViewConfig'; import type {HostComponent} from '../../Renderer/shims/ReactNativeTypes'; import type {SyntheticEvent} from '../../Types/CoreEventTypes'; import type {TextStyleProp} from '../../StyleSheet/StyleSheet'; import type {ProcessedColorValue} from '../../StyleSheet/processColor'; import codegenNativeCommands from '../../Utilities/codegenNativeCommands'; import * as React from 'react'; type PickerIOSChangeEvent = SyntheticEvent< $ReadOnly<{| newValue: number | string, newIndex: number, |}>, >; type RCTPickerIOSItemType = $ReadOnly<{| label: ?Label, value: ?string, textColor: ?ProcessedColorValue, |}>; type Label = Stringish | number; type NativeProps = $ReadOnly<{| items: $ReadOnlyArray, onChange: (event: PickerIOSChangeEvent) => void, selectedIndex: number, style?: ?TextStyleProp, testID?: ?string, accessibilityLabel?: ?string, |}>; type ComponentType = HostComponent; interface NativeCommands { +setNativeSelectedIndex: ( viewRef: React.ElementRef, index: number, ) => void; } export const Commands: NativeCommands = codegenNativeCommands({ supportedCommands: ['setNativeSelectedIndex'], }); const RCTPickerNativeComponent: HostComponent = NativeComponentRegistry.get( 'RCTPicker', () => ({ uiViewClassName: 'RCTPicker', bubblingEventTypes: { topChange: { phasedRegistrationNames: { bubbled: 'onChange', captured: 'onChangeCapture', }, }, }, directEventTypes: {}, validAttributes: { ...ReactNativeViewViewConfig.validAttributes, color: {process: require('../../StyleSheet/processColor')}, fontFamily: true, fontSize: true, fontStyle: true, fontWeight: true, items: true, onChange: true, selectedIndex: true, textAlign: true, }, }), ); // flowlint-next-line unclear-type:off export default ((RCTPickerNativeComponent: any): HostComponent);