diff options
author | Stefan Haller <stefan@haller-berlin.de> | 2024-01-26 17:39:03 +0100 |
---|---|---|
committer | Stefan Haller <stefan@haller-berlin.de> | 2024-01-28 09:49:56 +0100 |
commit | c66667c8c1d68758d31e265acfc3fdf7aff4f8c0 (patch) | |
tree | 8b02767ddeefe96c76182254678d9a99bf4d908d /pkg/gui/controllers | |
parent | e8e7ddea4563d853c7dec7c3a749f846554c1106 (diff) |
Fix main view refresh after adding the first file to a custom patch
This broke with 240948b.
Diffstat (limited to 'pkg/gui/controllers')
-rw-r--r-- | pkg/gui/controllers/helpers/inline_status_helper.go | 2 | ||||
-rw-r--r-- | pkg/gui/controllers/helpers/window_helper.go | 6 |
2 files changed, 4 insertions, 4 deletions
diff --git a/pkg/gui/controllers/helpers/inline_status_helper.go b/pkg/gui/controllers/helpers/inline_status_helper.go index 7368986bd..2476a57cf 100644 --- a/pkg/gui/controllers/helpers/inline_status_helper.go +++ b/pkg/gui/controllers/helpers/inline_status_helper.go @@ -66,7 +66,7 @@ func (self inlineStatusHelperTask) Continue() { func (self *InlineStatusHelper) WithInlineStatus(opts InlineStatusOpts, f func(gocui.Task) error) { context := self.c.ContextForKey(opts.ContextKey).(types.IListContext) view := context.GetView() - visible := view.Visible && self.windowHelper.TopViewInWindow(context.GetWindowName()) == view + visible := view.Visible && self.windowHelper.TopViewInWindow(context.GetWindowName(), false) == view if visible && context.IsItemVisible(opts.Item) { self.c.OnWorker(func(task gocui.Task) { self.start(opts) diff --git a/pkg/gui/controllers/helpers/window_helper.go b/pkg/gui/controllers/helpers/window_helper.go index 4bdd7a889..c0bdc2ab6 100644 --- a/pkg/gui/controllers/helpers/window_helper.go +++ b/pkg/gui/controllers/helpers/window_helper.go @@ -90,7 +90,7 @@ func (self *WindowHelper) MoveToTopOfWindow(context types.Context) { window := context.GetWindowName() - topView := self.TopViewInWindow(window) + topView := self.TopViewInWindow(window, true) if topView != nil && view.Name() != topView.Name() { if err := self.c.GocuiGui().SetViewOnTopOf(view.Name(), topView.Name()); err != nil { @@ -99,14 +99,14 @@ func (self *WindowHelper) MoveToTopOfWindow(context types.Context) { } } -func (self *WindowHelper) TopViewInWindow(windowName string) *gocui.View { +func (self *WindowHelper) TopViewInWindow(windowName string, includeInvisibleViews bool) *gocui.View { // now I need to find all views in that same window, via contexts. And I guess then I need to find the index of the highest view in that list. viewNamesInWindow := self.viewNamesInWindow(windowName) // The views list is ordered highest-last, so we're grabbing the last view of the window var topView *gocui.View for _, currentView := range self.c.GocuiGui().Views() { - if lo.Contains(viewNamesInWindow, currentView.Name()) && currentView.Visible { + if lo.Contains(viewNamesInWindow, currentView.Name()) && (currentView.Visible || includeInvisibleViews) { topView = currentView } } |