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:
Eric Vicenti 2015-11-12 19:14:59 -08:00 committed by facebook-github-bot-9
parent 235405091d
commit 5041171b78
1 changed files with 16 additions and 14 deletions

View File

@ -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);
} }
}; };