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
|
|
|
|
}
|
|
|
|
|
2022-12-30 14:24:24 +02:00
|
|
|
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
|
|
|
|
2022-12-30 14:24:24 +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{
|
2022-06-13 03:01:26 +02:00
|
|
|
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,
|
|
|
|
},
|
|
|
|
}
|
2022-12-30 14:24:24 +02:00
|
|
|
|
|
|
|
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 {
|
2022-05-05 14:41:44 +02:00
|
|
|
branch := self.GetSelected()
|
|
|
|
if branch == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return branch
|
2022-03-26 05:44:30 +02:00
|
|
|
}
|
2022-12-30 14:24:24 +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
|
|
|
|
}
|