summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--apps/files/js/breadcrumb.js26
-rw-r--r--apps/files/tests/js/breadcrumbSpec.js4
2 files changed, 17 insertions, 13 deletions
diff --git a/apps/files/js/breadcrumb.js b/apps/files/js/breadcrumb.js
index 526cada113a..da536f9de9f 100644
--- a/apps/files/js/breadcrumb.js
+++ b/apps/files/js/breadcrumb.js
@@ -34,6 +34,8 @@
var BreadCrumb = function(options){
this.$el = $('<div class="breadcrumb"></div>');
this.$menu = $('<div class="popovermenu menu-center"><ul></ul></div>');
+
+ this.crumbSelector = '.crumb:not(.hidden):not(.crumbhome):not(.crumbmenu)';
options = options || {};
if (options.onClick) {
this.onClick = options.onClick;
@@ -84,7 +86,6 @@
},
setDirectoryInfo: function(dirInfo) {
- console.log(dirInfo);
if (dirInfo !== this.dirInfo) {
this.dirInfo = dirInfo;
this.render();
@@ -264,7 +265,7 @@
var totalWidth = 0;
for (var i = 0; i < this.breadcrumbs.length; i++ ) {
var $crumb = $(this.breadcrumbs[i]);
- if(!$crumb.hasClass('hidden') || ignoreHidden) {
+ if(!$crumb.hasClass('hidden') || ignoreHidden === true) {
totalWidth += $crumb.width();
}
}
@@ -275,11 +276,10 @@
* Hide the middle crumb
*/
_hideCrumb: function() {
- var selector = '.crumb:not(.hidden):not(.crumbhome):not(.crumbmenu)';
- var length = this.$el.find(selector).length;
+ var length = this.$el.find(this.crumbSelector).length;
// Get the middle one floored down
var elmt = Math.floor(length / 2 - 0.5);
- this.$el.find(selector+':eq('+elmt+')').addClass('hidden');
+ this.$el.find(this.crumbSelector+':eq('+elmt+')').addClass('hidden');
},
/**
@@ -287,7 +287,7 @@
*/
_getCrumbElement: function() {
var hidden = this.$el.find('.crumb.hidden').length;
- var shown = this.$el.find('.crumb:not(.hidden):not(.crumbhome):not(.crumbmenu)').length;
+ var shown = this.$el.find(this.crumbSelector).length;
// Get the outer one with priority to the highest
var elmt = (1 - shown % 2) * (hidden - 1);
return this.$el.find('.crumb.hidden:eq('+elmt+')');
@@ -327,6 +327,12 @@
},
_resize: function() {
+
+ if (this.breadcrumbs.length <= 2) {
+ // home & menu
+ return;
+ }
+
// Used for testing since this.$el.parent fails
if (!this.availableWidth) {
this.usedWidth = this.$el.parent().width();
@@ -334,12 +340,10 @@
this.usedWidth = this.availableWidth;
}
- if (this.breadcrumbs.length <= 1) {
- return;
- }
-
// If container is smaller than content
- while (this.getTotalWidth() > this.usedWidth) {
+ // AND if there are crumbs left to hide
+ while (this.getTotalWidth() > this.usedWidth
+ && this.$el.find(this.crumbSelector).length > 0) {
this._hideCrumb();
}
// If container is bigger than content + element to be shown
diff --git a/apps/files/tests/js/breadcrumbSpec.js b/apps/files/tests/js/breadcrumbSpec.js
index c04b0f18035..b9075265ca5 100644
--- a/apps/files/tests/js/breadcrumbSpec.js
+++ b/apps/files/tests/js/breadcrumbSpec.js
@@ -156,7 +156,7 @@ describe('OCA.Files.BreadCrumb tests', function() {
onDrop: handler
});
bc.setDirectory('/one/two/three/four');
- expect(droppableStub.calledOnce).toEqual(true);
+ expect(droppableStub.calledOnce).toEqual(false);
expect(droppableStub.getCall(0).args[0].drop).toBeDefined();
// simulate drop
@@ -169,7 +169,7 @@ describe('OCA.Files.BreadCrumb tests', function() {
});
});
describe('Resizing', function() {
- var bc, dummyDir, widths, oldUpdateTotalWidth;
+ var bc, dummyDir, widths;
beforeEach(function() {
dummyDir = '/short name/longer name/looooooooooooonger/' +