From 98cf42343f51e810688ad54e4beae95b68988a5e Mon Sep 17 00:00:00 2001 From: Dave Pearson Date: Tue, 5 Dec 2023 14:34:55 +0000 Subject: [PATCH] Remove any scrollbar gutter while Widget.loading is True See #3733. --- src/textual/widgets/_loading_indicator.py | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/src/textual/widgets/_loading_indicator.py b/src/textual/widgets/_loading_indicator.py index f21b4fa219..ea62bfc836 100644 --- a/src/textual/widgets/_loading_indicator.py +++ b/src/textual/widgets/_loading_indicator.py @@ -33,14 +33,15 @@ class LoadingIndicator(Widget): """ _widget_state: ClassVar[ - WeakKeyDictionary[Widget, tuple[bool, str, str]] + WeakKeyDictionary[Widget, tuple[bool, str, str, str]] ] = WeakKeyDictionary() """Widget state that must be restore after loading. The tuples indicate the original values of the: - widget disabled state; - - widget style overflow_x rule; and - - widget style overflow_y rule. + - widget style overflow_x rule; + - widget style overflow_y rule; and + - widget style scrollbar_gutter rule. """ def __init__( @@ -80,7 +81,9 @@ def apply(self, widget: Widget) -> AwaitMount: widget.disabled, widget.styles.overflow_x, widget.styles.overflow_y, + widget.styles.scrollbar_gutter, ) + widget.styles.scrollbar_gutter = "auto" widget.styles.overflow_x = "hidden" widget.styles.overflow_y = "hidden" widget.disabled = True @@ -107,10 +110,13 @@ async def null() -> None: await_remove = null() if widget in cls._widget_state: - disabled, overflow_x, overflow_y = cls._widget_state[widget] - widget.disabled = disabled + disabled, overflow_x, overflow_y, scrollbar_gutter = cls._widget_state[ + widget + ] + widget.styles.scrollbar_gutter = scrollbar_gutter widget.styles.overflow_x = overflow_x widget.styles.overflow_y = overflow_y + widget.disabled = disabled return await_remove