Files
react-native/Libraries/Components/RefreshControl/AndroidSwipeRefreshLayoutNativeComponent.js
T
Eli White 2a4882e7e9 Using generated ViewConfigs for AndroidSwipeRefreshLayoutNativeComponent
Summary: $title

Reviewed By: rickhanlonii

Differential Revision: D15914074

fbshipit-source-id: 40fa6dcdf27b4fb88d936c439ba66a11e55966a9
2019-06-20 14:02:20 -07:00

73 lines
1.8 KiB
JavaScript

/**
* 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.
*
* @format
* @flow
*/
'use strict';
import codegenNativeComponent from '../../Utilities/codegenNativeComponent';
import type {
DirectEvent,
Float,
Int32,
WithDefault,
} from '../../Types/CodegenTypes';
import type {ColorValue} from '../../StyleSheet/StyleSheetTypes';
import type {ViewProps} from '../View/ViewPropTypes';
type NativeProps = $ReadOnly<{|
...ViewProps,
/**
* Whether the pull to refresh functionality is enabled.
*/
enabled?: ?WithDefault<boolean, false>,
/**
* The colors (at least one) that will be used to draw the refresh indicator.
*/
colors?: ?$ReadOnlyArray<ColorValue>,
/**
* The background color of the refresh indicator.
*/
progressBackgroundColor?: ?ColorValue,
/**
* Size of the refresh indicator, see RefreshControl.SIZE.
*
* This type isn't currently accurate. It really is specific numbers
* hard coded in the Android platform.
*
* Also, 1 isn't actually a safe default. We are able to set this here
* because native code isn't currently consuming the generated artifact.
* This will end up being
* size?: ?WithDefault<'default' | 'large', 'default'>,
*/
size?: ?WithDefault<Int32, 1>,
/**
* Progress view top offset
*/
progressViewOffset?: ?WithDefault<Float, 0>,
/**
* Called when the view starts refreshing.
*/
onRefresh?: ?(event: DirectEvent<null>) => mixed,
/**
* Whether the view should be indicating an active refresh.
*/
refreshing: WithDefault<boolean, false>,
|}>;
export default codegenNativeComponent<NativeProps>(
'AndroidSwipeRefreshLayout',
{
interfaceOnly: true,
},
);