/** * Copyright (c) 2015-present, Facebook, Inc. * All rights reserved. * * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * * @providesModule ProgressBarAndroid */ 'use strict'; var NativeMethodsMixin = require('NativeMethodsMixin'); var React = require('React'); var PropTypes = require('prop-types'); var ViewPropTypes = require('ViewPropTypes'); var ColorPropType = require('ColorPropType'); var requireNativeComponent = require('requireNativeComponent'); var STYLE_ATTRIBUTES = [ 'Horizontal', 'Normal', 'Small', 'Large', 'Inverse', 'SmallInverse', 'LargeInverse', ]; var indeterminateType = function(props, propName, componentName, ...rest) { var checker = function() { var indeterminate = props[propName]; var styleAttr = props.styleAttr; if (!indeterminate && styleAttr !== 'Horizontal') { return new Error('indeterminate=false is only valid for styleAttr=Horizontal'); } }; return PropTypes.bool(props, propName, componentName, ...rest) || checker(); }; /** * React component that wraps the Android-only `ProgressBar`. This component is used to indicate * that the app is loading or there is some activity in the app. * * Example: * * ``` * render: function() { * var progressBar = * * * ; * return ( * * ); * }, * ``` */ var ProgressBarAndroid = React.createClass({ propTypes: { ...ViewPropTypes, /** * Style of the ProgressBar. One of: * * - Horizontal * - Normal (default) * - Small * - Large * - Inverse * - SmallInverse * - LargeInverse */ styleAttr: PropTypes.oneOf(STYLE_ATTRIBUTES), /** * If the progress bar will show indeterminate progress. Note that this * can only be false if styleAttr is Horizontal. */ indeterminate: indeterminateType, /** * The progress value (between 0 and 1). */ progress: PropTypes.number, /** * Color of the progress bar. */ color: ColorPropType, /** * Used to locate this view in end-to-end tests. */ testID: PropTypes.string, }, getDefaultProps: function() { return { styleAttr: 'Normal', indeterminate: true }; }, mixins: [NativeMethodsMixin], componentDidMount: function() { if (this.props.indeterminate && this.props.styleAttr !== 'Horizontal') { console.warn( 'Circular indeterminate `ProgressBarAndroid`' + 'is deprecated. Use `ActivityIndicator` instead.' ); } }, render: function() { return ; }, }); var AndroidProgressBar = requireNativeComponent( 'AndroidProgressBar', ProgressBarAndroid, {nativeOnly: {animating: true}}, ); module.exports = ProgressBarAndroid;