1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2025-01-22 05:29:44 +02:00
lazygit/pkg/gui/context/list_context_trait.go

93 lines
2.8 KiB
Go
Raw Normal View History

2022-01-29 19:09:20 +11:00
package context
import (
"fmt"
"github.com/jesseduffield/lazygit/pkg/gui/types"
"github.com/jesseduffield/lazygit/pkg/utils"
)
type ListContextTrait struct {
2022-02-05 17:04:10 +11:00
types.Context
2022-01-29 19:09:20 +11:00
c *ContextCommon
2022-02-05 17:04:10 +11:00
list types.IList
getDisplayStrings func(startIdx int, length int) [][]string
// Alignment for each column. If nil, the default is left alignment
columnAlignments []utils.Alignment
// 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
// so that we show the highlighted path.
// TODO: now that we allow scrolling, we should be smarter about what gets refreshed:
// we should find out exactly which lines are now part of the path and refresh those.
// We should also keep track of the previous path and refresh those lines too.
refreshViewportOnChange bool
2022-02-05 17:04:10 +11:00
}
2022-01-29 19:09:20 +11:00
2023-03-23 22:05:25 +11:00
func (self *ListContextTrait) IsListContext() {}
2022-02-05 17:04:10 +11:00
func (self *ListContextTrait) GetList() types.IList {
return self.list
2022-01-29 19:09:20 +11:00
}
func (self *ListContextTrait) FocusLine() {
self.GetViewTrait().FocusPoint(self.list.GetSelectedLineIdx())
2022-04-16 15:59:02 +10:00
self.setFooter()
if self.refreshViewportOnChange {
self.refreshViewport()
}
}
func (self *ListContextTrait) refreshViewport() {
startIdx, length := self.GetViewTrait().ViewPortYBounds()
displayStrings := self.getDisplayStrings(startIdx, length)
content := utils.RenderDisplayStrings(displayStrings, nil)
self.GetViewTrait().SetViewPortContent(content)
2022-04-16 15:59:02 +10:00
}
func (self *ListContextTrait) setFooter() {
self.GetViewTrait().SetFooter(formatListFooter(self.list.GetSelectedLineIdx(), self.list.Len()))
2022-01-29 19:09:20 +11:00
}
func formatListFooter(selectedLineIdx int, length int) string {
return fmt.Sprintf("%d of %d", selectedLineIdx+1, length)
}
func (self *ListContextTrait) HandleFocus(opts types.OnFocusOpts) error {
2022-01-29 19:09:20 +11:00
self.FocusLine()
self.GetViewTrait().SetHighlight(self.list.Len() > 0)
return self.Context.HandleFocus(opts)
2022-01-29 19:09:20 +11:00
}
func (self *ListContextTrait) HandleFocusLost(opts types.OnFocusLostOpts) error {
self.GetViewTrait().SetOriginX(0)
2022-01-29 19:09:20 +11:00
if self.refreshViewportOnChange {
self.refreshViewport()
}
return self.Context.HandleFocusLost(opts)
2022-01-29 19:09:20 +11:00
}
2022-02-05 17:04:10 +11:00
// 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 {
self.list.RefreshSelectedIdx()
content := utils.RenderDisplayStrings(
self.getDisplayStrings(0, self.list.Len()),
self.columnAlignments,
)
self.GetViewTrait().SetContent(content)
2022-02-05 17:04:10 +11:00
self.c.Render()
2022-04-16 15:59:02 +10:00
self.setFooter()
2022-01-29 19:09:20 +11:00
return nil
}
func (self *ListContextTrait) OnSearchSelect(selectedLineIdx int) error {
2022-02-05 17:04:10 +11:00
self.GetList().SetSelectedLineIdx(selectedLineIdx)
return self.HandleFocus(types.OnFocusOpts{})
2022-01-29 19:09:20 +11:00
}