1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2024-12-12 11:15:00 +02:00
lazygit/pkg/gui/context/branches_context.go

76 lines
1.6 KiB
Go
Raw Normal View History

2022-02-05 08:04:10 +02:00
package context
import (
"github.com/jesseduffield/gocui"
"github.com/jesseduffield/lazygit/pkg/commands/models"
"github.com/jesseduffield/lazygit/pkg/gui/types"
)
type BranchesContext struct {
2022-03-19 00:31:52 +02:00
*BasicViewModel[*models.Branch]
2022-02-05 08:04:10 +02:00
*ListContextTrait
}
var (
_ types.IListContext = (*BranchesContext)(nil)
_ types.DiffableContext = (*BranchesContext)(nil)
)
2022-02-05 08:04:10 +02:00
func NewBranchesContext(
getModel func() []*models.Branch,
view *gocui.View,
getDisplayStrings func(startIdx int, length int) [][]string,
2022-02-06 06:54:26 +02:00
c *types.HelperCommon,
2022-02-05 08:04:10 +02:00
) *BranchesContext {
2022-03-19 00:31:52 +02:00
viewModel := NewBasicViewModel(getModel)
2022-02-05 08:04:10 +02:00
self := &BranchesContext{
2022-03-19 00:31:52 +02:00
BasicViewModel: viewModel,
2022-02-05 08:04:10 +02:00
ListContextTrait: &ListContextTrait{
Context: NewSimpleContext(NewBaseContext(NewBaseContextOpts{
View: view,
2022-02-05 08:04:10 +02:00
WindowName: "branches",
Key: LOCAL_BRANCHES_CONTEXT_KEY,
Kind: types.SIDE_CONTEXT,
Focusable: true,
2023-03-21 12:01:58 +02:00
})),
2022-02-05 08:04:10 +02:00
list: viewModel,
getDisplayStrings: getDisplayStrings,
c: c,
},
}
return self
2022-02-05 08:04:10 +02:00
}
func (self *BranchesContext) GetSelectedItemId() string {
item := self.GetSelected()
if item == nil {
return ""
}
return item.ID()
}
2022-03-26 15:18:08 +02:00
func (self *BranchesContext) GetSelectedRef() types.Ref {
branch := self.GetSelected()
if branch == nil {
return nil
}
return branch
2022-03-26 05:44:30 +02: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
}