/** * 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 SwitchAndroid */ 'use strict'; var NativeMethodsMixin = require('NativeMethodsMixin'); var PropTypes = require('ReactPropTypes'); var React = require('React'); var View = require('View'); var requireNativeComponent = require('requireNativeComponent'); var SWITCH = 'switch'; /** * Standard Android two-state toggle component */ var SwitchAndroid = React.createClass({ mixins: [NativeMethodsMixin], propTypes: { ...View.propTypes, /** * Boolean value of the switch. */ value: PropTypes.bool, /** * If `true`, this component can't be interacted with. */ disabled: PropTypes.bool, /** * Invoked with the new value when the value chages. */ onValueChange: PropTypes.func, /** * Used to locate this view in end-to-end tests. */ testID: PropTypes.string, }, getDefaultProps: function() { return { value: false, disabled: false, }; }, _onChange: function(event) { // The underlying switch might have changed, but we're controlled, // and so want to ensure it represents our value. this.refs[SWITCH].setNativeProps({on: this.props.value}); if (this.props.value === event.nativeEvent.value || this.props.disabled) { return; } this.props.onChange && this.props.onChange(event); this.props.onValueChange && this.props.onValueChange(event.nativeEvent.value); }, render: function() { return ( true} onResponderTerminationRequest={() => false} /> ); } }); var RKSwitch = requireNativeComponent('AndroidSwitch', SwitchAndroid, { nativeOnly: { on: true, enabled: true, } }); module.exports = SwitchAndroid;