diff options
author | Jan-Christoph Borchardt <hey@jancborchardt.net> | 2015-03-27 01:34:55 +0100 |
---|---|---|
committer | Jan-Christoph Borchardt <hey@jancborchardt.net> | 2015-03-27 01:34:55 +0100 |
commit | d728b85fddb91bc9f854e6f4b66772d666aaf732 (patch) | |
tree | c43aa7db13bb430aaa3d690652d75a3374928c94 /core/js/js.js | |
parent | fb8994603bb68e2787ff836938b3b15905942731 (diff) | |
download | nextcloud-server-d728b85fddb91bc9f854e6f4b66772d666aaf732.tar.gz nextcloud-server-d728b85fddb91bc9f854e6f4b66772d666aaf732.zip |
adjust controls bar width to not overlay scrollbar
Diffstat (limited to 'core/js/js.js')
-rw-r--r-- | core/js/js.js | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/core/js/js.js b/core/js/js.js index ad14c2a855a..26eac9c01a8 100644 --- a/core/js/js.js +++ b/core/js/js.js @@ -1261,6 +1261,32 @@ function initCore() { // initial call toggleSnapperOnSize(); + // adjust controls bar width + var adjustControlsWidth = function() { + if($('#controls').length) { + // if there is a scrollbar … + if($('#app-content').get(0).scrollHeight > $('#app-content').height()) { + if($(window).width() > 768) { + var controlsWidth = $('#content').width() - $('#app-navigation').width() - getScrollBarWidth(); + } else { + var controlsWidth = $('#content').width() - getScrollBarWidth(); + } + } else { // if there is none + if($(window).width() > 768) { + var controlsWidth = $('#content').width() - $('#app-navigation').width(); + } else { + var controlsWidth = $('#content').width(); + } + } + $('#controls').css('width', controlsWidth); + $('#controls').css('min-width', controlsWidth); + } + }; + + $(window).resize(_.debounce(adjustControlsWidth, 250)); + + $('body').delegate('#app-content', 'apprendered', adjustControlsWidth); + } } @@ -1685,3 +1711,29 @@ jQuery.fn.selectRange = function(start, end) { jQuery.fn.exists = function(){ return this.length > 0; }; + +function getScrollBarWidth() { + var inner = document.createElement('p'); + inner.style.width = "100%"; + inner.style.height = "200px"; + + var outer = document.createElement('div'); + outer.style.position = "absolute"; + outer.style.top = "0px"; + outer.style.left = "0px"; + outer.style.visibility = "hidden"; + outer.style.width = "200px"; + outer.style.height = "150px"; + outer.style.overflow = "hidden"; + outer.appendChild (inner); + + document.body.appendChild (outer); + var w1 = inner.offsetWidth; + outer.style.overflow = 'scroll'; + var w2 = inner.offsetWidth; + if (w1 == w2) w2 = outer.clientWidth; + + document.body.removeChild (outer); + + return (w1 - w2); +}; |