diff options
author | John Molakvoæ <skjnldsv@protonmail.com> | 2017-11-03 12:23:57 +0100 |
---|---|---|
committer | John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> | 2017-11-08 13:04:37 +0100 |
commit | 9422e98151d24e69be06ea3835d96bd409bced6d (patch) | |
tree | efad2285c06322283b8463eba0d56d8c50137c1d /apps | |
parent | 497cd7fa4e629d6bb4a279e62b45debb3f47e6b2 (diff) | |
download | nextcloud-server-9422e98151d24e69be06ea3835d96bd409bced6d.tar.gz nextcloud-server-9422e98151d24e69be06ea3835d96bd409bced6d.zip |
Breadcrumbs hiding calculation
Signed-off-by: John Molakvoæ <skjnldsv@protonmail.com>
Diffstat (limited to 'apps')
-rw-r--r-- | apps/files/js/breadcrumb.js | 80 |
1 files changed, 25 insertions, 55 deletions
diff --git a/apps/files/js/breadcrumb.js b/apps/files/js/breadcrumb.js index 2a4c2bc8a52..544ad703523 100644 --- a/apps/files/js/breadcrumb.js +++ b/apps/files/js/breadcrumb.js @@ -205,7 +205,6 @@ this.totalWidth = 0; for (var i = 0; i < this.breadcrumbs.length; i++ ) { var $crumb = $(this.breadcrumbs[i]); - $crumb.data('real-width', $crumb.width()); this.totalWidth += $crumb.width(); } this._resize(); @@ -213,7 +212,7 @@ /** * Show/hide breadcrumbs to fit the given width - * + * * @param {int} availableWidth available width */ setMaxWidth: function (availableWidth) { @@ -223,6 +222,29 @@ } }, + /** + * Return the number of items to hide + */ + _toShrink: function() { + var maxWidth = this.$el.width(); + var smallestWidth = 50; + // 50px by default for the ellipsis crumb + return Math.ceil((this.totalWidth + 50 - maxWidth) / smallestWidth); + }, + + /** + * Hide the desired number of items + * + * @param {int} number to hide + */ + _hideCrumbs: function(toHide) { + var min = Math.round(this.breadcrumbs.length/2 - toHide/2); + var max = Math.round(this.breadcrumbs.length/2 + toHide/2 - 1); + console.log(this.$el.find('.crumb').slice(min, max)); + this.$el.find('.crumb').removeClass('hidden') + .slice(min, max).addClass('hidden'); + }, + _resize: function() { var i, $crumb, $ellipsisCrumb; @@ -233,64 +255,12 @@ if (this.breadcrumbs.length <= 1) { return; } + this._hideCrumbs(this._toShrink()); - // reset crumbs - this.$el.find('.crumb.ellipsized').remove(); - - // unhide all - this.$el.find('.crumb.hidden').removeClass('hidden'); - - if (this.totalWidth <= this.availableWidth) { - // no need to compute breadcrumbs, there is enough space - return; - } - - // running width, considering the hidden crumbs - var currentTotalWidth = $(this.breadcrumbs[0]).data('real-width'); - var firstHidden = true; - // insert ellipsis after root part (root part is always visible) - $ellipsisCrumb = $('<div class="crumb ellipsized svg"><span class="ellipsis">...</span></div>'); - $(this.breadcrumbs[0]).after($ellipsisCrumb); - currentTotalWidth += $ellipsisCrumb.width(); - i = this.breadcrumbs.length - 1; - - // find the first section that would cause the overflow - // then hide everything in front of that - // - // this ensures that the last crumb section stays visible - // for most of the cases and is always the last one to be - // hidden when the screen becomes very narrow - while (i > 0) { - $crumb = $(this.breadcrumbs[i]); - // if the current breadcrumb would cause overflow - if (!firstHidden || currentTotalWidth + $crumb.data('real-width') > this.availableWidth) { - // hide it - $crumb.addClass('hidden'); - if (firstHidden) { - // set the path of this one as title for the ellipsis - this.$el.find('.crumb.ellipsized') - .attr('title', $crumb.attr('data-dir')) - .tooltip(); - this.$el.find('.ellipsis') - .wrap('<a class="ellipsislink" href="' + encodeURI(OC.generateUrl('apps/files/?dir=' + $crumb.attr('data-dir'))) + '"></a>'); - } - // and all the previous ones (going backwards) - firstHidden = false; - } else { - // add to total width - currentTotalWidth += $crumb.data('real-width'); - } - i--; - } - - if (!OC.Util.hasSVGSupport()) { - OC.Util.replaceSVG(this.$el); - } } }; OCA.Files.BreadCrumb = BreadCrumb; })(); - |