2023-03-21 20:57:52 +11:00
|
|
|
package context
|
|
|
|
|
|
|
|
import (
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/jesseduffield/gocui"
|
2023-05-18 19:20:42 +02:00
|
|
|
"github.com/jesseduffield/lazygit/pkg/gui/keybindings"
|
2023-03-21 20:57:52 +11:00
|
|
|
"github.com/jesseduffield/lazygit/pkg/gui/types"
|
2023-05-18 19:20:42 +02:00
|
|
|
"github.com/jesseduffield/lazygit/pkg/utils"
|
|
|
|
"github.com/samber/lo"
|
2023-03-21 20:57:52 +11:00
|
|
|
)
|
|
|
|
|
|
|
|
type CommitMessageContext struct {
|
2023-03-23 12:35:07 +11:00
|
|
|
c *ContextCommon
|
2023-01-21 11:38:14 +00:00
|
|
|
types.Context
|
|
|
|
viewModel *CommitMessageViewModel
|
2023-03-21 20:57:52 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
var _ types.Context = (*CommitMessageContext)(nil)
|
|
|
|
|
2023-01-21 11:38:14 +00:00
|
|
|
// when selectedIndex (see below) is set to this value, it means that we're not
|
|
|
|
// currently viewing a commit message of an existing commit: instead we're making our own
|
|
|
|
// new commit message
|
|
|
|
const NoCommitIndex = -1
|
|
|
|
|
|
|
|
type CommitMessageViewModel struct {
|
|
|
|
// index of the commit message, where -1 is 'no commit', 0 is the HEAD commit, 1
|
|
|
|
// is the prior commit, and so on
|
|
|
|
selectedindex int
|
|
|
|
// if true, then upon escaping from the commit message panel, we will preserve
|
|
|
|
// the message so that it's still shown next time we open the panel
|
|
|
|
preserveMessage bool
|
|
|
|
// the full preserved message (combined summary and description)
|
|
|
|
preservedMessage string
|
|
|
|
// invoked when pressing enter in the commit message panel
|
2023-07-22 14:05:42 +10:00
|
|
|
onConfirm func(string, string) error
|
2023-05-18 19:15:23 +02:00
|
|
|
// invoked when pressing the switch-to-editor key binding
|
|
|
|
onSwitchToEditor func(string) error
|
2023-01-21 11:38:14 +00:00
|
|
|
|
|
|
|
// The message typed in before cycling through history
|
|
|
|
// We store this separately to 'preservedMessage' because 'preservedMessage'
|
|
|
|
// is specifically for committing staged files and we don't want this affected
|
|
|
|
// by cycling through history in the context of rewording an old commit.
|
|
|
|
historyMessage string
|
|
|
|
}
|
|
|
|
|
2023-03-21 20:57:52 +11:00
|
|
|
func NewCommitMessageContext(
|
2023-03-23 12:35:07 +11:00
|
|
|
c *ContextCommon,
|
2023-03-21 20:57:52 +11:00
|
|
|
) *CommitMessageContext {
|
2023-01-21 11:38:14 +00:00
|
|
|
viewModel := &CommitMessageViewModel{}
|
2023-03-21 20:57:52 +11:00
|
|
|
return &CommitMessageContext{
|
2023-01-21 11:38:14 +00:00
|
|
|
c: c,
|
|
|
|
viewModel: viewModel,
|
|
|
|
Context: NewSimpleContext(
|
2023-03-21 20:57:52 +11:00
|
|
|
NewBaseContext(NewBaseContextOpts{
|
|
|
|
Kind: types.PERSISTENT_POPUP,
|
|
|
|
View: c.Views().CommitMessage,
|
|
|
|
WindowName: "commitMessage",
|
|
|
|
Key: COMMIT_MESSAGE_CONTEXT_KEY,
|
|
|
|
Focusable: true,
|
|
|
|
HasUncontrolledBounds: true,
|
|
|
|
}),
|
|
|
|
),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-01-21 11:38:14 +00:00
|
|
|
func (self *CommitMessageContext) SetSelectedIndex(value int) {
|
|
|
|
self.viewModel.selectedindex = value
|
|
|
|
}
|
|
|
|
|
|
|
|
func (self *CommitMessageContext) GetSelectedIndex() int {
|
|
|
|
return self.viewModel.selectedindex
|
|
|
|
}
|
|
|
|
|
|
|
|
func (self *CommitMessageContext) GetPreserveMessage() bool {
|
|
|
|
return self.viewModel.preserveMessage
|
|
|
|
}
|
|
|
|
|
|
|
|
func (self *CommitMessageContext) GetPreservedMessage() string {
|
|
|
|
return self.viewModel.preservedMessage
|
|
|
|
}
|
|
|
|
|
|
|
|
func (self *CommitMessageContext) SetPreservedMessage(message string) {
|
|
|
|
self.viewModel.preservedMessage = message
|
|
|
|
}
|
|
|
|
|
|
|
|
func (self *CommitMessageContext) GetHistoryMessage() string {
|
|
|
|
return self.viewModel.historyMessage
|
|
|
|
}
|
|
|
|
|
|
|
|
func (self *CommitMessageContext) SetHistoryMessage(message string) {
|
|
|
|
self.viewModel.historyMessage = message
|
|
|
|
}
|
|
|
|
|
2023-07-22 14:05:42 +10:00
|
|
|
func (self *CommitMessageContext) OnConfirm(summary string, description string) error {
|
|
|
|
return self.viewModel.onConfirm(summary, description)
|
2023-01-21 11:38:14 +00:00
|
|
|
}
|
|
|
|
|
2023-07-22 14:05:42 +10:00
|
|
|
func (self *CommitMessageContext) SetPanelState(
|
|
|
|
index int,
|
|
|
|
summaryTitle string,
|
|
|
|
descriptionTitle string,
|
|
|
|
preserveMessage bool,
|
|
|
|
onConfirm func(string, string) error,
|
2023-05-18 19:15:23 +02:00
|
|
|
onSwitchToEditor func(string) error,
|
2023-07-22 14:05:42 +10:00
|
|
|
) {
|
2023-01-21 11:38:14 +00:00
|
|
|
self.viewModel.selectedindex = index
|
|
|
|
self.viewModel.preserveMessage = preserveMessage
|
|
|
|
self.viewModel.onConfirm = onConfirm
|
2023-05-18 19:15:23 +02:00
|
|
|
self.viewModel.onSwitchToEditor = onSwitchToEditor
|
2023-07-22 14:05:42 +10:00
|
|
|
self.GetView().Title = summaryTitle
|
|
|
|
self.c.Views().CommitDescription.Title = descriptionTitle
|
2023-05-18 19:20:42 +02:00
|
|
|
|
|
|
|
subtitleTemplate := lo.Ternary(onSwitchToEditor != nil, self.c.Tr.CommitDescriptionSubTitle, self.c.Tr.CommitDescriptionSubTitleNoSwitch)
|
|
|
|
self.c.Views().CommitDescription.Subtitle = utils.ResolvePlaceholderString(subtitleTemplate,
|
|
|
|
map[string]string{
|
|
|
|
"togglePanelKeyBinding": keybindings.Label(self.c.UserConfig.Keybinding.Universal.TogglePanel),
|
|
|
|
"switchToEditorKeyBinding": keybindings.Label(self.c.UserConfig.Keybinding.CommitMessage.SwitchToEditor),
|
|
|
|
})
|
2023-01-21 11:38:14 +00:00
|
|
|
}
|
|
|
|
|
2023-03-21 20:57:52 +11:00
|
|
|
func (self *CommitMessageContext) RenderCommitLength() {
|
|
|
|
if !self.c.UserConfig.Gui.CommitLength.Show {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
self.c.Views().CommitMessage.Subtitle = getBufferLength(self.c.Views().CommitMessage)
|
|
|
|
}
|
|
|
|
|
|
|
|
func getBufferLength(view *gocui.View) string {
|
|
|
|
return " " + strconv.Itoa(strings.Count(view.TextArea.GetContent(), "")-1) + " "
|
|
|
|
}
|
2023-05-18 19:15:23 +02:00
|
|
|
|
|
|
|
func (self *CommitMessageContext) SwitchToEditor(message string) error {
|
|
|
|
return self.viewModel.onSwitchToEditor(message)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (self *CommitMessageContext) CanSwitchToEditor() bool {
|
|
|
|
return self.viewModel.onSwitchToEditor != nil
|
|
|
|
}
|