Made stick book navigation recalc on window resize

This commit is contained in:
Dan Brown 2016-06-25 15:46:31 +01:00
parent 9baa96d41c
commit 361ba8b244

View File

@ -74,15 +74,15 @@ window.setupPageShow = module.exports = function (pageId) {
// Make the book-tree sidebar stick in view on scroll // Make the book-tree sidebar stick in view on scroll
var $window = $(window); var $window = $(window);
var $bookTree = $(".book-tree"); var $bookTree = $(".book-tree");
var $bookTreeParent = $bookTree.parent();
// Check the page is scrollable and the content is taller than the tree // Check the page is scrollable and the content is taller than the tree
var pageScrollable = ($(document).height() > $window.height()) && ($bookTree.height() < $('.page-content').height()); var pageScrollable = ($(document).height() > $window.height()) && ($bookTree.height() < $('.page-content').height());
// Get current tree's width and header height // Get current tree's width and header height
var headerHeight = $("#header").height() + $(".toolbar").height(); var headerHeight = $("#header").height() + $(".toolbar").height();
var isFixed = $window.scrollTop() > headerHeight; var isFixed = $window.scrollTop() > headerHeight;
var bookTreeWidth = $bookTree.width();
// Function to fix the tree as a sidebar // Function to fix the tree as a sidebar
function stickTree() { function stickTree() {
$bookTree.width(bookTreeWidth + 48 + 15); $bookTree.width($bookTreeParent.width() + 15);
$bookTree.addClass("fixed"); $bookTree.addClass("fixed");
isFixed = true; isFixed = true;
} }
@ -101,13 +101,27 @@ window.setupPageShow = module.exports = function (pageId) {
unstickTree(); unstickTree();
} }
} }
// The event ran when the window scrolls
function windowScrollEvent() {
checkTreeStickiness(false);
}
// If the page is scrollable and the window is wide enough listen to scroll events // If the page is scrollable and the window is wide enough listen to scroll events
// and evaluate tree stickiness. // and evaluate tree stickiness.
if (pageScrollable && $window.width() > 1000) { if (pageScrollable && $window.width() > 1000) {
$window.scroll(function() { $window.on('scroll', windowScrollEvent);
checkTreeStickiness(false);
});
checkTreeStickiness(true); checkTreeStickiness(true);
} }
// Handle window resizing and switch between desktop/mobile views
$window.on('resize', event => {
if (pageScrollable && $window.width() > 1000) {
$window.on('scroll', windowScrollEvent);
checkTreeStickiness(true);
} else {
$window.off('scroll', windowScrollEvent);
unstickTree();
}
});
}; };