summaryrefslogtreecommitdiffstats
path: root/pkg/gui/menu_panel.go
diff options
context:
space:
mode:
authorJesse Duffield <jessedduffield@gmail.com>2018-12-06 22:18:17 +1100
committerJesse Duffield <jessedduffield@gmail.com>2018-12-08 11:51:47 +1100
commitca3afa2a3905365ec79624e0c9b08865e9ab27ae (patch)
tree47add13ed3819ddc9ed89c16c12cb9aab22ad1cd /pkg/gui/menu_panel.go
parent99a8b1ae8bb93565df8acbe168749278dc768979 (diff)
standardising how list panels deal with cursor movement
Diffstat (limited to 'pkg/gui/menu_panel.go')
-rw-r--r--pkg/gui/menu_panel.go31
1 files changed, 26 insertions, 5 deletions
diff --git a/pkg/gui/menu_panel.go b/pkg/gui/menu_panel.go
index 753e8f84d..0d3d8cf2b 100644
--- a/pkg/gui/menu_panel.go
+++ b/pkg/gui/menu_panel.go
@@ -8,12 +8,32 @@ import (
"github.com/jesseduffield/lazygit/pkg/utils"
)
+// list panel functions
+
func (gui *Gui) handleMenuSelect(g *gocui.Gui, v *gocui.View) error {
- // doing nothing for now
- // but it is needed for switch in newLineFocused
- return nil
+ return gui.focusPoint(0, gui.State.Panels.Menu.SelectedLine, v)
+}
+
+func (gui *Gui) handleMenuNextLine(g *gocui.Gui, v *gocui.View) error {
+ panelState := gui.State.Panels.Menu
+ gui.changeSelectedLine(&panelState.SelectedLine, v.LinesHeight(), false)
+
+ return gui.handleMenuSelect(g, v)
+}
+
+func (gui *Gui) handleMenuPrevLine(g *gocui.Gui, v *gocui.View) error {
+ panelState := gui.State.Panels.Menu
+ gui.changeSelectedLine(&panelState.SelectedLine, v.LinesHeight(), true)
+
+ if err := gui.focusPoint(0, gui.State.Panels.Commits.SelectedLine, v); err != nil {
+ return err
+ }
+
+ return gui.handleMenuSelect(g, v)
}
+// specific functions
+
func (gui *Gui) renderMenuOptions(g *gocui.Gui) error {
optionsMap := map[string]string{
"esc/q": gui.Tr.SLocalize("close"),
@@ -46,14 +66,15 @@ func (gui *Gui) createMenu(items interface{}, handlePress func(int) error) error
menuView.FgColor = gocui.ColorWhite
menuView.Clear()
fmt.Fprint(menuView, list)
+ gui.State.Panels.Menu.SelectedLine = 0
if err := gui.renderMenuOptions(gui.g); err != nil {
return err
}
wrappedHandlePress := func(g *gocui.Gui, v *gocui.View) error {
- lineNumber := gui.getItemPosition(v)
- return handlePress(lineNumber)
+ selectedLine := gui.State.Panels.Menu.SelectedLine
+ return handlePress(selectedLine)
}
if err := gui.g.SetKeybinding("menu", gocui.KeySpace, gocui.ModNone, wrappedHandlePress); err != nil {