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

92 lines
2.1 KiB
Go
Raw Normal View History

2022-02-05 17:04:10 +11:00
package context
import (
"github.com/jesseduffield/lazygit/pkg/commands/models"
"github.com/jesseduffield/lazygit/pkg/gui/presentation"
2022-02-05 17:04:10 +11:00
"github.com/jesseduffield/lazygit/pkg/gui/types"
)
type BranchesContext struct {
*FilteredListViewModel[*models.Branch]
2022-02-05 17:04:10 +11:00
*ListContextTrait
}
var (
_ types.IListContext = (*BranchesContext)(nil)
_ types.DiffableContext = (*BranchesContext)(nil)
)
2022-02-05 17:04:10 +11:00
func NewBranchesContext(c *ContextCommon) *BranchesContext {
viewModel := NewFilteredListViewModel(
func() []*models.Branch { return c.Model().Branches },
func(branch *models.Branch) []string {
return []string{branch.Name}
},
)
2022-02-05 17:04:10 +11:00
getDisplayStrings := func(_ int, _ int) [][]string {
return presentation.GetBranchListDisplayStrings(
viewModel.GetItems(),
c.State().GetRepoState().GetScreenMode() != types.SCREEN_NORMAL,
c.Modes().Diffing.Ref,
c.Tr,
2022-11-07 16:35:36 +11:00
c.UserConfig,
c.Model().Worktrees,
)
}
self := &BranchesContext{
FilteredListViewModel: viewModel,
2022-02-05 17:04:10 +11:00
ListContextTrait: &ListContextTrait{
Context: NewSimpleContext(NewBaseContext(NewBaseContextOpts{
2023-03-21 21:06:39 +11:00
View: c.Views().Branches,
2022-02-05 17:04:10 +11:00
WindowName: "branches",
Key: LOCAL_BRANCHES_CONTEXT_KEY,
Kind: types.SIDE_CONTEXT,
Focusable: true,
2023-03-21 21:01:58 +11:00
})),
ListRenderer: ListRenderer{
list: viewModel,
getDisplayStrings: getDisplayStrings,
},
c: c,
2022-02-05 17:04:10 +11:00
},
}
return self
2022-02-05 17:04:10 +11:00
}
func (self *BranchesContext) GetSelectedItemId() string {
item := self.GetSelected()
if item == nil {
return ""
}
return item.ID()
}
2022-03-26 22:18:08 +09:00
func (self *BranchesContext) GetSelectedRef() types.Ref {
branch := self.GetSelected()
if branch == nil {
return nil
}
return branch
2022-03-26 14:44:30 +11:00
}
func (self *BranchesContext) GetDiffTerminals() []string {
// for our local branches we want to include both the branch and its upstream
branch := self.GetSelected()
if branch != nil {
names := []string{branch.ID()}
if branch.IsTrackingRemote() {
names = append(names, branch.ID()+"@{u}")
}
return names
}
return nil
}
func (self *BranchesContext) ShowBranchHeadsInSubCommits() bool {
return true
}