2015-09-14 15:35:58 +01:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
*
|
2018-02-16 18:24:55 -08:00
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2015-09-14 15:35:58 +01:00
|
|
|
*
|
2018-07-27 12:25:23 -07:00
|
|
|
* @flow strict
|
2018-05-09 15:18:18 -07:00
|
|
|
* @format
|
2015-09-14 15:35:58 +01:00
|
|
|
*/
|
2018-05-09 15:18:18 -07:00
|
|
|
|
2015-09-14 15:35:58 +01:00
|
|
|
'use strict';
|
|
|
|
|
2017-09-18 23:45:19 -07:00
|
|
|
const React = require('React');
|
2015-09-14 15:35:58 +01:00
|
|
|
|
2017-10-18 16:50:41 -07:00
|
|
|
const requireNativeComponent = require('requireNativeComponent');
|
|
|
|
|
2018-06-19 14:13:03 -07:00
|
|
|
import type {NativeComponent} from 'ReactNative';
|
|
|
|
import type {ViewProps} from 'ViewPropTypes';
|
2015-09-14 15:35:58 +01:00
|
|
|
|
2018-06-19 14:13:03 -07:00
|
|
|
const AndroidProgressBar = requireNativeComponent('AndroidProgressBar');
|
2015-11-06 12:07:54 -08:00
|
|
|
|
2018-06-19 14:13:03 -07:00
|
|
|
type Props = $ReadOnly<{|
|
|
|
|
...ViewProps,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Style of the ProgressBar and whether it shows indeterminate progress (e.g. spinner).
|
|
|
|
*
|
|
|
|
* `indeterminate` can only be false if `styleAttr` is Horizontal, and requires a
|
|
|
|
* `progress` value.
|
|
|
|
*/
|
|
|
|
...
|
|
|
|
| {|
|
|
|
|
styleAttr: 'Horizontal',
|
|
|
|
indeterminate: false,
|
|
|
|
progress: number,
|
|
|
|
|}
|
|
|
|
| {|
|
|
|
|
typeAttr:
|
|
|
|
| 'Horizontal'
|
|
|
|
| 'Normal'
|
|
|
|
| 'Small'
|
|
|
|
| 'Large'
|
|
|
|
| 'Inverse'
|
|
|
|
| 'SmallInverse'
|
|
|
|
| 'LargeInverse',
|
|
|
|
indeterminate: true,
|
|
|
|
|},
|
|
|
|
/**
|
|
|
|
* Whether to show the ProgressBar (true, the default) or hide it (false).
|
|
|
|
*/
|
|
|
|
animating?: ?boolean,
|
|
|
|
/**
|
|
|
|
* Color of the progress bar.
|
|
|
|
*/
|
|
|
|
color?: ?string,
|
|
|
|
/**
|
|
|
|
* Used to locate this view in end-to-end tests.
|
|
|
|
*/
|
|
|
|
testID?: ?string,
|
|
|
|
|}>;
|
2015-11-06 12:07:54 -08:00
|
|
|
|
2015-09-14 15:35:58 +01:00
|
|
|
/**
|
2018-05-09 15:18:18 -07:00
|
|
|
* React component that wraps the Android-only `ProgressBar`. This component is
|
|
|
|
* used to indicate that the app is loading or there is activity in the app.
|
2015-09-14 15:35:58 +01:00
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
*
|
|
|
|
* ```
|
|
|
|
* render: function() {
|
|
|
|
* var progressBar =
|
|
|
|
* <View style={styles.container}>
|
|
|
|
* <ProgressBar styleAttr="Inverse" />
|
|
|
|
* </View>;
|
|
|
|
|
|
|
|
* return (
|
|
|
|
* <MyLoadingComponent
|
|
|
|
* componentView={componentView}
|
|
|
|
* loadingView={progressBar}
|
|
|
|
* style={styles.loadingComponent}
|
|
|
|
* />
|
|
|
|
* );
|
|
|
|
* },
|
|
|
|
* ```
|
|
|
|
*/
|
2018-06-19 14:13:03 -07:00
|
|
|
const ProgressBarAndroid = (
|
|
|
|
props: Props,
|
|
|
|
forwardedRef: ?React.Ref<'AndroidProgressBar'>,
|
|
|
|
) => {
|
|
|
|
return <AndroidProgressBar {...props} ref={forwardedRef} />;
|
|
|
|
};
|
2018-06-11 20:44:49 -07:00
|
|
|
|
2018-06-19 14:13:03 -07:00
|
|
|
// $FlowFixMe - TODO T29156721 `React.forwardRef` is not defined in Flow, yet.
|
|
|
|
const ProgressBarAndroidToExport = React.forwardRef(ProgressBarAndroid);
|
2018-06-11 20:44:49 -07:00
|
|
|
|
2018-06-19 14:13:03 -07:00
|
|
|
ProgressBarAndroidToExport.defaultProps = {
|
|
|
|
styleAttr: 'Normal',
|
|
|
|
indeterminate: true,
|
|
|
|
animating: true,
|
|
|
|
};
|
2017-10-18 16:50:41 -07:00
|
|
|
|
2018-06-19 14:13:03 -07:00
|
|
|
module.exports = (ProgressBarAndroidToExport: Class<NativeComponent<Props>>);
|