From 19354b1de19f8d6c89a851c05bcdf4394a0b2f0d Mon Sep 17 00:00:00 2001 From: Jimmy Tanagra Date: Sun, 11 Aug 2024 17:10:08 +1000 Subject: [PATCH] reduce label width for shorter labels Signed-off-by: Jimmy Tanagra --- bundles/org.openhab.ui.basic/web-src/_layout.scss | 2 +- bundles/org.openhab.ui.basic/web-src/smarthome.js | 7 ++++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/bundles/org.openhab.ui.basic/web-src/_layout.scss b/bundles/org.openhab.ui.basic/web-src/_layout.scss index 4e757cca6f..35402e7814 100644 --- a/bundles/org.openhab.ui.basic/web-src/_layout.scss +++ b/bundles/org.openhab.ui.basic/web-src/_layout.scss @@ -225,6 +225,7 @@ @include flex-shrink(0); @include flex-grow(2); @include flex-2011(2 2 auto); + min-width: 5em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; @@ -505,7 +506,6 @@ } padding-top: 2px; padding-bottom: 2px; - max-width: 70%; display: flex; flex-wrap: wrap; justify-content: end; diff --git a/bundles/org.openhab.ui.basic/web-src/smarthome.js b/bundles/org.openhab.ui.basic/web-src/smarthome.js index 96fa77d4fa..3298ca60b2 100644 --- a/bundles/org.openhab.ui.basic/web-src/smarthome.js +++ b/bundles/org.openhab.ui.basic/web-src/smarthome.js @@ -1347,13 +1347,14 @@ if (_t.buttons.length > 1 && _t.parentNode.classList.contains(o.buttonsMultilineClass)) { _t.minimizeWidth = function() { + var labelLength = _t.label.textContent.trim().length; + _t.label.style.paddingLeft = labelLength === 0 ? 0 : null; // null reverts it to the css + _t.label.style.minWidth = labelLength < 6 ? "min-content" : null; + // Minimize the width taken by the buttons without adding extra rows. // Start from the maximum width (limited by `mdl-form__buttons-multiline.max-width`), // then shrink it down to the minimum without causing additional wrapping. var buttons = _t.parentNode; - if (_t.label.textContent.trim() === "") { - buttons.style.maxWidth = "100%"; - } var width = buttons.parentElement.offsetWidth + 100; // start wider than max-width allows buttons.style.width = width + "px"; var height = buttons.offsetHeight;