From 7710adbd9abe9efe0d08372d07e1413b3aa0a304 Mon Sep 17 00:00:00 2001 From: Piro / YUKI Hiroshi Date: Fri, 4 Mar 2016 22:26:26 +0900 Subject: [PATCH] Calculate number of columns by self only when it is needed --- modules/fullTooltip.js | 3 +++ modules/pseudoTreeBuilder.js | 36 +++++++++++++++++++++++------------- 2 files changed, 26 insertions(+), 13 deletions(-) diff --git a/modules/fullTooltip.js b/modules/fullTooltip.js index 7ad7ac58..1419e745 100644 --- a/modules/fullTooltip.js +++ b/modules/fullTooltip.js @@ -602,8 +602,11 @@ FullTooltipManager.prototype = inherit(TreeStyleTabBase, { if (utils.getTreePref('tooltip.columnize')) { PseudoTreeBuilder.columnizeTree(tree, { + containerBox : { width : this.lastScreen.allowedWidth, height : this.lastScreen.allowedHeight + }, + calculateCount : true }); this.window.setTimeout(this.expandTooltipInternal.bind(this), 0); } diff --git a/modules/pseudoTreeBuilder.js b/modules/pseudoTreeBuilder.js index 95e67fe8..98dc0b99 100644 --- a/modules/pseudoTreeBuilder.js +++ b/modules/pseudoTreeBuilder.js @@ -146,32 +146,42 @@ var PseudoTreeBuilder = { return container; }, - columnizeTree : function TB_columnizeTree(aTree, aContainerBox) + columnizeTree : function TB_columnizeTree(aTree, aOptions) { if (!aTree) return; - aContainerBox = aContainerBox || aTree.parentNode.boxObject; + aOptions = aOptions || {}; + var containerBox = aOptions.containerBox || aTree.parentNode.boxObject; var style = aTree.style; var height = aTree.clientHeight * (aTree.columnCount || 1); - if (height > aContainerBox.height && - aContainerBox.height < aContainerBox.width) { - let maxWidth = aContainerBox.width; + if (height > containerBox.height && + containerBox.height < containerBox.width) { + let maxWidth = containerBox.width; aTree.columnWidth = Math.floor(maxWidth * 0.9 / 2.5); + style.columnWidth = style.MozColumnWidth = aTree.columnWidth+'px'; + style.columnGap = style.MozColumnGap = '0'; + style.columnFill = style.MozColumnFill = 'auto'; + if (aOptions.calculateCount) { let count = Math.ceil( (Math.max(aTree.clientWidth, maxWidth) * aTree.clientHeight) / (aTree.columnWidth * aTree.clientHeight) ); aTree.columnCount = style.columnCount = style.MozColumnCount = count; - style.columnWidth = style.MozColumnWidth = aTree.columnWidth+'px'; - style.columnGap = style.MozColumnGap = '0'; - style.columnFill = style.MozColumnFill = 'auto'; + } + else { + aTree.columnCount = 2; + style.columnCount = style.MozColumnCount = 'auto'; + } aTree.ownerDocument.defaultView.setTimeout((function() { - let columnCount = this.getActualColumnCount(aTree); - aTree.columnCount = style.columnCount = - style.MozColumnCount = columnCount; + aTree.columnCount = this.getActualColumnCount(aTree); + if (aOptions.calculateCount) { + style.columnCount = + style.MozColumnCount = + aTree.columnCount; + } }).bind(this), 0); } else { @@ -179,12 +189,12 @@ var PseudoTreeBuilder = { style.columnCount = style.MozColumnCount = style.columnWidth = style.MozColumnWidth = style.columnGap = style.MozColumnGap = - style.columnFill = style.MozColumnFill; + style.columnFill = style.MozColumnFill = ''; } if (aTree.columnCount > 1) { style.height = style.maxHeight = - Math.floor(aContainerBox.height * 0.9) + 'px'; + Math.floor(containerBox.height * 0.9) + 'px'; } else { style.height = style.maxHeight = '';