Fix ScrollResponder scrollResponderScrollNativeHandleToKeyboard when kb is offscreen
Summary: public `scrollResponderScrollNativeHandleToKeyboard` would fail silently if there is no keyboard present. This makes sure to do the correct scrolling behavior, by assuming the screen height is where the keyboard would be located. This still might not work properly in landscape apps, but it should not make the situation worse Also fix an issue wehre `scrollResponderKeyboardDidHide` would swallow the event Reviewed By: vjeux Differential Revision: D2643477 fb-gh-sync-id: f917390f4709361cc47bcd553b214833422ec05d
This commit is contained in:
parent
235405091d
commit
5041171b78
|
@ -11,6 +11,7 @@
|
||||||
*/
|
*/
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
var Dimensions = require('Dimensions');
|
||||||
var NativeModules = require('NativeModules');
|
var NativeModules = require('NativeModules');
|
||||||
var Platform = require('Platform');
|
var Platform = require('Platform');
|
||||||
var RCTDeviceEventEmitter = require('RCTDeviceEventEmitter');
|
var RCTDeviceEventEmitter = require('RCTDeviceEventEmitter');
|
||||||
|
@ -426,20 +427,21 @@ var ScrollResponderMixin = {
|
||||||
* @param {number} height Height of the text input.
|
* @param {number} height Height of the text input.
|
||||||
*/
|
*/
|
||||||
scrollResponderInputMeasureAndScrollToKeyboard: function(left: number, top: number, width: number, height: number) {
|
scrollResponderInputMeasureAndScrollToKeyboard: function(left: number, top: number, width: number, height: number) {
|
||||||
|
var keyboardScreenY = Dimensions.get('window').height;
|
||||||
if (this.keyboardWillOpenTo) {
|
if (this.keyboardWillOpenTo) {
|
||||||
var scrollOffsetY =
|
keyboardScreenY = this.keyboardWillOpenTo.endCoordinates.screenY;
|
||||||
top - this.keyboardWillOpenTo.endCoordinates.screenY + height +
|
|
||||||
this.additionalScrollOffset;
|
|
||||||
|
|
||||||
// By default, this can scroll with negative offset, pulling the content
|
|
||||||
// down so that the target component's bottom meets the keyboard's top.
|
|
||||||
// If requested otherwise, cap the offset at 0 minimum to avoid content
|
|
||||||
// shifting down.
|
|
||||||
if (this.preventNegativeScrollOffset) {
|
|
||||||
scrollOffsetY = Math.max(0, scrollOffsetY);
|
|
||||||
}
|
|
||||||
this.scrollResponderScrollTo(0, scrollOffsetY);
|
|
||||||
}
|
}
|
||||||
|
var scrollOffsetY = top - keyboardScreenY + height + this.additionalScrollOffset;
|
||||||
|
|
||||||
|
// By default, this can scroll with negative offset, pulling the content
|
||||||
|
// down so that the target component's bottom meets the keyboard's top.
|
||||||
|
// If requested otherwise, cap the offset at 0 minimum to avoid content
|
||||||
|
// shifting down.
|
||||||
|
if (this.preventNegativeScrollOffset) {
|
||||||
|
scrollOffsetY = Math.max(0, scrollOffsetY);
|
||||||
|
}
|
||||||
|
this.scrollResponderScrollTo(0, scrollOffsetY);
|
||||||
|
|
||||||
this.additionalOffset = 0;
|
this.additionalOffset = 0;
|
||||||
this.preventNegativeScrollOffset = false;
|
this.preventNegativeScrollOffset = false;
|
||||||
},
|
},
|
||||||
|
@ -510,9 +512,9 @@ var ScrollResponderMixin = {
|
||||||
this.props.onKeyboardDidShow && this.props.onKeyboardDidShow(e);
|
this.props.onKeyboardDidShow && this.props.onKeyboardDidShow(e);
|
||||||
},
|
},
|
||||||
|
|
||||||
scrollResponderKeyboardDidHide: function() {
|
scrollResponderKeyboardDidHide: function(e: Event) {
|
||||||
this.keyboardWillOpenTo = null;
|
this.keyboardWillOpenTo = null;
|
||||||
this.props.onKeyboardDidHide && this.props.onKeyboardDidHide();
|
this.props.onKeyboardDidHide && this.props.onKeyboardDidHide(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue