From 47e28f03f6008b6d4944bbd53e14d879899c1952 Mon Sep 17 00:00:00 2001 From: EnderDev Date: Sun, 17 Mar 2024 21:36:48 +0000 Subject: [PATCH] =?UTF-8?q?=F0=9F=92=84=20Add=20dynamic=20tooltip=20visibi?= =?UTF-8?q?lity=20mode=20on=20buttons?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- components/widgets/content/browser-button.js | 56 ++++++++++++++++++++ 1 file changed, 56 insertions(+) diff --git a/components/widgets/content/browser-button.js b/components/widgets/content/browser-button.js index c611ba88b4..4231fb0b42 100644 --- a/components/widgets/content/browser-button.js +++ b/components/widgets/content/browser-button.js @@ -149,6 +149,31 @@ class BrowserButton extends BrowserContextualMixin(HTMLButtonElement) { this.setAttribute("mode", newMode); } + /** + * The computed mode state of the browser button + * + * Sometimes the mode will differ from what is + * actually used by the button: + * + * An example of this happening is if the area requests + * the "icons" mode for all buttons, and a button has + * explicitly specified "text" mode. + */ + get computedMode() { + const iconVisible = this.elements.icon.checkVisibility(); + const labelVisible = this.elements.label.checkVisibility(); + + if (iconVisible && !labelVisible) { + return "icons"; + } + + if (labelVisible && !iconVisible) { + return "text"; + } + + return "icons_text"; + } + /** * The checked/toggled state of the browser button */ @@ -179,6 +204,32 @@ class BrowserButton extends BrowserContextualMixin(HTMLButtonElement) { this._updateTooltipText(); } + /** + * Determines whether we should show the tooltip + * depending on the conditions of the button. + */ + get shouldShowTooltip() { + const mode = this.computedMode; + const tooltipText = this.getTooltipText(); + + // Always show the tooltip under the icons mode, + // as the label is never shown to the user. + if (mode == "icons") { + return true; + } + + // If the label text is overflowing on-screen, + // make sure we always show the tooltip. + if (this.elements.label.offsetWidth < this.elements.label.scrollWidth) { + return true; + } + + // If the label is the same as the tooltip text, + // skip showing it, as we already have all the + // information already available on-screen. + return this.label !== tooltipText; + } + /** * Toggles a transitioning psuedo class on the button * @param {string} name @@ -224,6 +275,10 @@ class BrowserButton extends BrowserContextualMixin(HTMLButtonElement) { "--button-physical-height", +height.toFixed(2) + "px" ); + + // Recompute the tooltip text as important + // attributes may have changed + this._updateTooltipText(); } /** @@ -244,6 +299,7 @@ class BrowserButton extends BrowserContextualMixin(HTMLButtonElement) { * Updates the button's tooltip text */ _updateTooltipText() { + this.elements.tooltip.hidden = !this.shouldShowTooltip; this.elements.tooltip.label = this.getTooltipText(); }