Commit 447f93e
committed
fix: update coordinator focus path after mouse-click on Nth control in ScrollablePanel
When clicking a directly-focusable control in a ScrollablePanel, HandleClickFocus
called RequestFocus(SPC) which delegated to the first child via SetFocus(Programmatic),
setting the coordinator path to that first child. ProcessMouseEvent then correctly
gave visual focus to the actually clicked child but did not update the coordinator path,
causing key routing and Tab navigation to target the first child instead.
Fix: call UpdateCoordinatorFocusPath(child) after SetFocus(true, Mouse) in
ProcessMouseEvent so the path always reflects the actually clicked control.
Adds regression tests covering the full dispatch path (HandleClickFocus + ProcessMouseEvent)
to prevent future drift between visual focus state and coordinator routing path.1 parent d404b95 commit 447f93e
3 files changed
Lines changed: 356 additions & 1 deletion
File tree
- SharpConsoleUI.Tests/FocusManagement
- SharpConsoleUI/Controls/ScrollablePanelControl
Lines changed: 73 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
228 | 228 | | |
229 | 229 | | |
230 | 230 | | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
| 270 | + | |
| 271 | + | |
| 272 | + | |
| 273 | + | |
| 274 | + | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
231 | 304 | | |
232 | 305 | | |
233 | 306 | | |
| |||
Lines changed: 6 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
328 | 328 | | |
329 | 329 | | |
330 | 330 | | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
331 | 337 | | |
332 | 338 | | |
333 | 339 | | |
334 | 340 | | |
335 | 341 | | |
336 | 342 | | |
337 | 343 | | |
338 | | - | |
339 | 344 | | |
340 | 345 | | |
341 | 346 | | |
| |||
0 commit comments