/** * Copyright (c) Meta Platforms, Inc. and 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 strict-local */ import type {HostComponent} from '../../Renderer/shims/ReactNativeTypes'; import type {ColorValue} from '../../StyleSheet/StyleSheet'; import type { DirectEventHandler, Float, WithDefault, } from '../../Types/CodegenTypes'; import type {ViewProps} from '../View/ViewPropTypes'; import codegenNativeCommands from '../../Utilities/codegenNativeCommands'; import codegenNativeComponent from '../../Utilities/codegenNativeComponent'; import * as React from 'react'; type NativeProps = $ReadOnly<{| ...ViewProps, /** * Whether the pull to refresh functionality is enabled. */ enabled?: WithDefault, /** * The colors (at least one) that will be used to draw the refresh indicator. */ colors?: ?$ReadOnlyArray, /** * The background color of the refresh indicator. */ progressBackgroundColor?: ?ColorValue, /** * Size of the refresh indicator. */ size?: WithDefault<'default' | 'large', 'default'>, /** * Progress view top offset */ progressViewOffset?: WithDefault, /** * Called when the view starts refreshing. */ onRefresh?: ?DirectEventHandler, /** * Whether the view should be indicating an active refresh. */ refreshing: boolean, |}>; type NativeType = HostComponent; interface NativeCommands { +setNativeRefreshing: ( viewRef: React.ElementRef, value: boolean, ) => void; } export const Commands: NativeCommands = codegenNativeCommands({ supportedCommands: ['setNativeRefreshing'], }); export default (codegenNativeComponent( 'AndroidSwipeRefreshLayout', ): NativeType);