fix: improve mouse divider dragging logic and event handling

This commit is contained in:
n loewen (aider) 2025-05-05 08:55:40 +01:00
parent cfdef57993
commit f58ae2783f
1 changed files with 11 additions and 10 deletions

View File

@ -81,34 +81,35 @@ def main(stdscr, filename):
if bstate & curses.BUTTON1_PRESSED:
if mx == divider_col:
dragging_divider = True
elif bstate & curses.BUTTON1_RELEASED:
dragging_divider = False
# Update divider position while dragging
if dragging_divider:
min_col = 10
max_col = width - 20 # leave space for right pane
divider_col = max(min_col, min(mx, max_col))
elif bstate & curses.BUTTON1_CLICKED:
if bstate & curses.BUTTON1_RELEASED:
dragging_divider = False
elif bstate & curses.BUTTON1_CLICKED and not dragging_divider:
focus = "left" if mx < divider_col else "right"
except curses.error:
pass
# Check for mouse release even when no explicit mouse event
# This helps catch mouse releases that might be missed
# Continue updating divider position even without explicit mouse events
elif dragging_divider:
try:
_, mx, my, _, bstate = curses.getmouse()
# Update divider position while dragging
# Update divider position
min_col = 10
max_col = width - 20 # leave space for right pane
divider_col = max(min_col, min(mx, max_col))
# Check if button is no longer pressed
if not (bstate & curses.BUTTON1_PRESSED):
# Check for mouse button release
if bstate & curses.BUTTON1_RELEASED or not (bstate & curses.BUTTON1_PRESSED):
dragging_divider = False
except curses.error:
# If we can't get mouse state, keep the divider where it is
pass
#