From d1a942545d6d80130e74ec7412fa9aa70be88a73 Mon Sep 17 00:00:00 2001 From: aarzilli Date: Thu, 27 Dec 2018 11:17:16 +0100 Subject: [PATCH] reset docked window focus after the last non-docked window is closed --- context.go | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/context.go b/context.go index 7f11391..4fd5e38 100644 --- a/context.go +++ b/context.go @@ -139,6 +139,7 @@ func contextEnd(ctx *context) { } func (ctx *context) Reset() { + prevNumWindows := len(ctx.Windows) for i := 0; i < len(ctx.Windows); i++ { if ctx.Windows[i].close { if i != len(ctx.Windows)-1 { @@ -151,6 +152,21 @@ func (ctx *context) Reset() { for i := range ctx.Windows { ctx.Windows[i].idx = i } + if prevNumWindows == 2 && len(ctx.Windows) == 1 && ctx.Input.Mouse.valid { + ctx.DockedWindows.Walk(func(w *Window) *Window { + if w.flags&windowDocked == 0 { + return w + } + for _, b := range []mouse.Button{mouse.ButtonLeft, mouse.ButtonRight, mouse.ButtonMiddle} { + btn := ctx.Input.Mouse.Buttons[b] + if btn.Clicked && w.Bounds.Contains(btn.ClickedPos) { + ctx.dockedWindowFocus = w.idx + return w + } + } + return w + }) + } ctx.activateEditor = nil in := &ctx.Input in.Mouse.Buttons[mouse.ButtonLeft].Clicked = false