Skip to content

Commit

Permalink
fix(scroll): scroll inputs correctly with footer
Browse files Browse the repository at this point in the history
  • Loading branch information
tlancina committed May 13, 2014
1 parent e0c7979 commit 373c0cd
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 14 deletions.
5 changes: 0 additions & 5 deletions js/utils/keyboard.js
Original file line number Diff line number Diff line change
Expand Up @@ -144,11 +144,6 @@ function keyboardShow(element, elementTop, elementBottom, viewportHeight, keyboa

console.log('keyboardShow', keyboardHeight, details.contentHeight);

// distance from top of input to the top of the keyboard
details.keyboardTopOffset = details.elementTop - details.contentHeight;

console.log('keyboardTopOffset', details.elementTop, details.contentHeight, details.keyboardTopOffset);

// figure out if the element is under the keyboard
details.isElementUnderKeyboard = (details.elementBottom > details.contentHeight);

Expand Down
33 changes: 24 additions & 9 deletions js/views/scrollView.js
Original file line number Diff line number Diff line change
Expand Up @@ -622,15 +622,19 @@ ionic.views.Scroll = ionic.views.View.inherit({
//Broadcasted when keyboard is shown on some platforms.
//See js/utils/keyboard.js
container.addEventListener('scrollChildIntoView', function(e) {

//distance from bottom of scrollview to top of viewport
var scrollBottomOffsetToTop;

if( !self.isScrolledIntoView ) {
// shrink scrollview so we can actually scroll if the input is hidden
// if it isn't shrink so we can scroll to inputs under the keyboard
if (ionic.Platform.isIOS() || ionic.Platform.isFullScreen){
// if there are things below the scroll view account for them and
// subtract them from the keyboard height when resizing
var offsetToTop = container.getBoundingClientRect().bottom;
var offsetToBottom = e.detail.viewportHeight - offsetToTop;
var keyboardOffset = Math.max(0, e.detail.keyboardHeight - offsetToBottom);
scrollBottomOffsetToTop = container.getBoundingClientRect().bottom;
var scrollBottomOffsetToBottom = e.detail.viewportHeight - scrollBottomOffsetToTop;
var keyboardOffset = Math.max(0, e.detail.keyboardHeight - scrollBottomOffsetToBottom);
container.style.height = (container.clientHeight - keyboardOffset) + "px";
container.style.overflow = "visible";
//update scroll view
Expand All @@ -642,22 +646,33 @@ ionic.views.Scroll = ionic.views.View.inherit({
//If the element is positioned under the keyboard...
if( e.detail.isElementUnderKeyboard ) {
var delay;
// Wait on android for scroll view to resize
// Wait on android for web view to resize
if ( ionic.Platform.isAndroid() && !ionic.Platform.isFullScreen ) {
delay = 350;
// android y u resize so slow
if ( ionic.Platform.version() < 4.4) {
delay = 500;
}
else {
// probably overkill for chrome
delay = 350;
}
}
else {
delay = 80;
}

//Put element in middle of visible screen
//Wait for resize() to reset scroll position
//Wait for android to update view height and resize() to reset scroll position
ionic.scroll.isScrolling = true;
setTimeout(function(){
//middle of the scrollview, where we want to scroll to
var scrollViewMidpointOffset = container.clientHeight * 0.5;
var scrollTop = e.detail.keyboardTopOffset + scrollViewMidpointOffset;
console.log('scrollChildIntoView', scrollTop);
var scrollMidpointOffset = container.clientHeight * 0.5;

scrollBottomOffsetToTop = container.getBoundingClientRect().bottom;
//distance from top of focused element to the bottom of the scroll view
var elementTopOffsetToScrollBottom = e.detail.elementTop - scrollBottomOffsetToTop;

var scrollTop = elementTopOffsetToScrollBottom + scrollMidpointOffset;
ionic.tap.cloneFocusedInput(container, self);
self.scrollBy(0, scrollTop, true);
self.onScroll();
Expand Down

0 comments on commit 373c0cd

Please sign in to comment.