mirror of
https://github.com/jesseduffield/lazygit.git
synced 2025-01-06 03:53:59 +02:00
Only apply right-alignment on first column of keybindings menu
Previously we applied a right-align on the first column of _all_ menus, even though we really only intended for it to be on the first column of the keybindings menu (that you get from pressing '?')
This commit is contained in:
parent
1f920ae6ba
commit
87bf1dbc7f
@ -14,7 +14,7 @@ type ListContextTrait struct {
|
|||||||
list types.IList
|
list types.IList
|
||||||
getDisplayStrings func(startIdx int, length int) [][]string
|
getDisplayStrings func(startIdx int, length int) [][]string
|
||||||
// Alignment for each column. If nil, the default is left alignment
|
// Alignment for each column. If nil, the default is left alignment
|
||||||
columnAlignments []utils.Alignment
|
getColumnAlignments func() []utils.Alignment
|
||||||
// Some contexts, like the commit context, will highlight the path from the selected commit
|
// Some contexts, like the commit context, will highlight the path from the selected commit
|
||||||
// to its parents, because it's ambiguous otherwise. For these, we need to refresh the viewport
|
// to its parents, because it's ambiguous otherwise. For these, we need to refresh the viewport
|
||||||
// so that we show the highlighted path.
|
// so that we show the highlighted path.
|
||||||
@ -82,9 +82,13 @@ func (self *ListContextTrait) HandleFocusLost(opts types.OnFocusLostOpts) error
|
|||||||
// OnFocus assumes that the content of the context has already been rendered to the view. OnRender is the function which actually renders the content to the view
|
// OnFocus assumes that the content of the context has already been rendered to the view. OnRender is the function which actually renders the content to the view
|
||||||
func (self *ListContextTrait) HandleRender() error {
|
func (self *ListContextTrait) HandleRender() error {
|
||||||
self.list.RefreshSelectedIdx()
|
self.list.RefreshSelectedIdx()
|
||||||
|
var columnAlignments []utils.Alignment
|
||||||
|
if self.getColumnAlignments != nil {
|
||||||
|
columnAlignments = self.getColumnAlignments()
|
||||||
|
}
|
||||||
content := utils.RenderDisplayStrings(
|
content := utils.RenderDisplayStrings(
|
||||||
self.getDisplayStrings(0, self.list.Len()),
|
self.getDisplayStrings(0, self.list.Len()),
|
||||||
self.columnAlignments,
|
columnAlignments,
|
||||||
)
|
)
|
||||||
self.GetViewTrait().SetContent(content)
|
self.GetViewTrait().SetContent(content)
|
||||||
self.c.Render()
|
self.c.Render()
|
||||||
|
@ -38,7 +38,7 @@ func NewMenuContext(
|
|||||||
getDisplayStrings: viewModel.GetDisplayStrings,
|
getDisplayStrings: viewModel.GetDisplayStrings,
|
||||||
list: viewModel,
|
list: viewModel,
|
||||||
c: c,
|
c: c,
|
||||||
columnAlignments: []utils.Alignment{utils.AlignRight, utils.AlignLeft},
|
getColumnAlignments: func() []utils.Alignment { return viewModel.columnAlignment },
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -56,6 +56,7 @@ func (self *MenuContext) GetSelectedItemId() string {
|
|||||||
type MenuViewModel struct {
|
type MenuViewModel struct {
|
||||||
c *ContextCommon
|
c *ContextCommon
|
||||||
menuItems []*types.MenuItem
|
menuItems []*types.MenuItem
|
||||||
|
columnAlignment []utils.Alignment
|
||||||
*FilteredListViewModel[*types.MenuItem]
|
*FilteredListViewModel[*types.MenuItem]
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -73,8 +74,9 @@ func NewMenuViewModel(c *ContextCommon) *MenuViewModel {
|
|||||||
return self
|
return self
|
||||||
}
|
}
|
||||||
|
|
||||||
func (self *MenuViewModel) SetMenuItems(items []*types.MenuItem) {
|
func (self *MenuViewModel) SetMenuItems(items []*types.MenuItem, columnAlignment []utils.Alignment) {
|
||||||
self.menuItems = items
|
self.menuItems = items
|
||||||
|
self.columnAlignment = columnAlignment
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: move into presentation package
|
// TODO: move into presentation package
|
||||||
|
@ -4,6 +4,7 @@ import (
|
|||||||
"github.com/jesseduffield/generics/slices"
|
"github.com/jesseduffield/generics/slices"
|
||||||
"github.com/jesseduffield/lazygit/pkg/gui/keybindings"
|
"github.com/jesseduffield/lazygit/pkg/gui/keybindings"
|
||||||
"github.com/jesseduffield/lazygit/pkg/gui/types"
|
"github.com/jesseduffield/lazygit/pkg/gui/types"
|
||||||
|
"github.com/jesseduffield/lazygit/pkg/utils"
|
||||||
"github.com/samber/lo"
|
"github.com/samber/lo"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -40,6 +41,7 @@ func (self *OptionsMenuAction) Call() error {
|
|||||||
Title: self.c.Tr.Keybindings,
|
Title: self.c.Tr.Keybindings,
|
||||||
Items: menuItems,
|
Items: menuItems,
|
||||||
HideCancel: true,
|
HideCancel: true,
|
||||||
|
ColumnAlignment: []utils.Alignment{utils.AlignRight, utils.AlignLeft},
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ func (gui *Gui) createMenu(opts types.CreateMenuOptions) error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
gui.State.Contexts.Menu.SetMenuItems(opts.Items)
|
gui.State.Contexts.Menu.SetMenuItems(opts.Items, opts.ColumnAlignment)
|
||||||
gui.State.Contexts.Menu.SetSelectedLineIdx(0)
|
gui.State.Contexts.Menu.SetSelectedLineIdx(0)
|
||||||
|
|
||||||
gui.Views.Menu.Title = opts.Title
|
gui.Views.Menu.Title = opts.Title
|
||||||
|
@ -136,6 +136,7 @@ type CreateMenuOptions struct {
|
|||||||
Title string
|
Title string
|
||||||
Items []*MenuItem
|
Items []*MenuItem
|
||||||
HideCancel bool
|
HideCancel bool
|
||||||
|
ColumnAlignment []utils.Alignment
|
||||||
}
|
}
|
||||||
|
|
||||||
type CreatePopupPanelOpts struct {
|
type CreatePopupPanelOpts struct {
|
||||||
|
Loading…
Reference in New Issue
Block a user