2015-09-14 14:35:58 +00:00
|
|
|
/**
|
|
|
|
* 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');
|
2015-11-18 13:32:46 +00:00
|
|
|
var View = require('View');
|
2015-09-14 14:35:58 +00:00
|
|
|
|
|
|
|
var requireNativeComponent = require('requireNativeComponent');
|
|
|
|
|
|
|
|
var SWITCH = 'switch';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Standard Android two-state toggle component
|
|
|
|
*/
|
|
|
|
var SwitchAndroid = React.createClass({
|
|
|
|
mixins: [NativeMethodsMixin],
|
|
|
|
|
|
|
|
propTypes: {
|
2015-11-18 13:32:46 +00:00
|
|
|
...View.propTypes,
|
2015-09-14 14:35:58 +00:00
|
|
|
/**
|
|
|
|
* Boolean value of the switch.
|
|
|
|
*/
|
|
|
|
value: PropTypes.bool,
|
|
|
|
/**
|
|
|
|
* If `true`, this component can't be interacted with.
|
|
|
|
*/
|
|
|
|
disabled: PropTypes.bool,
|
|
|
|
/**
|
2015-12-15 17:08:39 +00:00
|
|
|
* Invoked with the new value when the value changes.
|
2015-09-14 14:35:58 +00:00
|
|
|
*/
|
|
|
|
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});
|
2015-09-18 00:03:23 +00:00
|
|
|
|
|
|
|
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);
|
2015-09-14 14:35:58 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
render: function() {
|
|
|
|
return (
|
|
|
|
<RKSwitch
|
|
|
|
ref={SWITCH}
|
|
|
|
style={this.props.style}
|
|
|
|
enabled={!this.props.disabled}
|
|
|
|
on={this.props.value}
|
|
|
|
onChange={this._onChange}
|
|
|
|
testID={this.props.testID}
|
|
|
|
onStartShouldSetResponder={() => true}
|
|
|
|
onResponderTerminationRequest={() => false}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2015-11-18 13:32:46 +00:00
|
|
|
var RKSwitch = requireNativeComponent('AndroidSwitch', SwitchAndroid, {
|
|
|
|
nativeOnly: {
|
|
|
|
on: true,
|
|
|
|
enabled: true,
|
|
|
|
}
|
|
|
|
});
|
2015-09-14 14:35:58 +00:00
|
|
|
|
|
|
|
module.exports = SwitchAndroid;
|