-
Notifications
You must be signed in to change notification settings - Fork 841
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Updating a OptionList
that contains separator lines can result in a garbled display (since 0.86.0)
#5431
Comments
OptionList
that contains seperater lines can result in a garbled display (since 0.86.0)OptionList
that contains separator lines can result in a garbled display (since 0.86.0)
Following on from the above, it's not actually that it's being updated when it's focused; it seems to be if it's being updated at all. For example, this variation of the above code: from textual.app import App, ComposeResult
from textual.reactive import var
from textual.widgets import OptionList
class FocusTest(App[None]):
CSS = """
OptionList {
height: 1fr;
}
"""
counter: var[int] = var(0)
BINDINGS = [
("space", "add_more")
]
def compose(self) -> ComposeResult:
yield OptionList()
def action_add_more(self) -> None:
self.counter += 1
self.query_one(OptionList).add_option(
(f"This is option {self.counter}" if self.counter % 2 else None)
)
if __name__ == "__main__":
FocusTest().run() shows the same problem if you keep pressing the space key. |
Nice to see you Dave! Looks possibly like some weirdness with the |
Yup, very much what I'm seeing too. |
I think the problem is that the index for the options are different in For example, "This is option 5" is cached with an option index of 4 from This seems to fix it, but I'm not sure what is the 'correct' index...? diff --git a/src/textual/widgets/_option_list.py b/src/textual/widgets/_option_list.py
index 6aeac230c..ff15a0cb3 100644
--- a/src/textual/widgets/_option_list.py
+++ b/src/textual/widgets/_option_list.py
@@ -349,7 +349,7 @@ class OptionList(ScrollView, can_focus=True):
if isinstance(content, Option):
height = len(
self._render_option_content(
- index, content, "", width - self._left_gutter_width()
+ option_index, content, "", width - self._left_gutter_width()
)
) |
I've not dived into it, but it's interesting that the bit of code you pick out seems to also relate to getting the height of an option(?), as there's yet another subtle bug I'm seeing that only kicks in from 0.86, as far as I can see, where multi-line options sometimes don't fully render any more, unless you jiggle the width of the window (or presumably do something else that causes a full refresh or similar). I've been on and off trying (and failing) to come up with an MRE for that but right now I'm seeing it all the time in the app I'm working on. |
EDIT: It looks like |
Take this code:
if you use the
Add
button, and keep focus on theAdd
button, the display within theOptionList
starts to make no sense; only when it receives focus does it show correctly:Screen.Recording.2024-12-24.at.17.06.05.mov
Going back through recent Textual releases, this effect first appears in v0.86.
The text was updated successfully, but these errors were encountered: