mirror of
https://github.com/jesseduffield/lazygit.git
synced 2025-07-01 00:54:58 +02:00
minor refactor of credentials panel into its own file
This commit is contained in:
@ -51,90 +51,6 @@ func (gui *Gui) handleCommitFocused(g *gocui.Gui, v *gocui.View) error {
|
|||||||
return gui.renderString(g, "options", message)
|
return gui.renderString(g, "options", message)
|
||||||
}
|
}
|
||||||
|
|
||||||
type credentials chan string
|
|
||||||
|
|
||||||
// waitForPassUname wait for a username or password input from the credentials popup
|
|
||||||
func (gui *Gui) waitForPassUname(g *gocui.Gui, currentView *gocui.View, passOrUname string) string {
|
|
||||||
gui.credentials = make(chan string)
|
|
||||||
credentialsView, _ := g.View("credentials")
|
|
||||||
if passOrUname == "username" {
|
|
||||||
credentialsView.Title = gui.Tr.SLocalize("CredentialsUsername")
|
|
||||||
credentialsView.Mask = 0
|
|
||||||
} else {
|
|
||||||
credentialsView.Title = gui.Tr.SLocalize("CredentialsPassword")
|
|
||||||
credentialsView.Mask = '*'
|
|
||||||
}
|
|
||||||
g.Update(func(g *gocui.Gui) error {
|
|
||||||
err := gui.switchFocus(g, currentView, credentialsView)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
gui.RenderCommitLength()
|
|
||||||
return nil
|
|
||||||
})
|
|
||||||
|
|
||||||
// wait for username/passwords input
|
|
||||||
userInput := <-gui.credentials
|
|
||||||
return userInput
|
|
||||||
}
|
|
||||||
|
|
||||||
func (gui *Gui) handlePushConfirm(g *gocui.Gui, v *gocui.View) error {
|
|
||||||
message := gui.trimmedContent(v)
|
|
||||||
if message == "" {
|
|
||||||
// make sure to input something
|
|
||||||
// if not dune the push progress will run forever
|
|
||||||
message = "-"
|
|
||||||
}
|
|
||||||
gui.credentials <- message
|
|
||||||
err := gui.refreshFiles(g)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
v.Clear()
|
|
||||||
err = v.SetCursor(0, 0)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
_, err = g.SetViewOnBottom("credentials")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
nextView, err := gui.g.View("confirmation")
|
|
||||||
if err != nil {
|
|
||||||
nextView = gui.getFilesView(g)
|
|
||||||
}
|
|
||||||
err = gui.switchFocus(g, nil, nextView)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return gui.refreshCommits(g)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (gui *Gui) handlePushClose(g *gocui.Gui, v *gocui.View) error {
|
|
||||||
_, err := g.SetViewOnBottom("credentials")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
gui.credentials <- "-"
|
|
||||||
return gui.switchFocus(g, nil, gui.getFilesView(g))
|
|
||||||
}
|
|
||||||
|
|
||||||
func (gui *Gui) handleCredentialsViewFocused(g *gocui.Gui, v *gocui.View) error {
|
|
||||||
if _, err := g.SetViewOnTop("credentials"); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
message := gui.Tr.TemplateLocalize(
|
|
||||||
"CloseConfirm",
|
|
||||||
Teml{
|
|
||||||
"keyBindClose": "esc",
|
|
||||||
"keyBindConfirm": "enter",
|
|
||||||
},
|
|
||||||
)
|
|
||||||
return gui.renderString(g, "options", message)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (gui *Gui) simpleEditor(v *gocui.View, key gocui.Key, ch rune, mod gocui.Modifier) {
|
func (gui *Gui) simpleEditor(v *gocui.View, key gocui.Key, ch rune, mod gocui.Modifier) {
|
||||||
switch {
|
switch {
|
||||||
case key == gocui.KeyBackspace || key == gocui.KeyBackspace2:
|
case key == gocui.KeyBackspace || key == gocui.KeyBackspace2:
|
||||||
|
108
pkg/gui/credentials_panel.go
Normal file
108
pkg/gui/credentials_panel.go
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
package gui
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"github.com/jesseduffield/gocui"
|
||||||
|
)
|
||||||
|
|
||||||
|
type credentials chan string
|
||||||
|
|
||||||
|
// waitForPassUname wait for a username or password input from the credentials popup
|
||||||
|
func (gui *Gui) waitForPassUname(g *gocui.Gui, currentView *gocui.View, passOrUname string) string {
|
||||||
|
gui.credentials = make(chan string)
|
||||||
|
g.Update(func(g *gocui.Gui) error {
|
||||||
|
credentialsView, _ := g.View("credentials")
|
||||||
|
if passOrUname == "username" {
|
||||||
|
credentialsView.Title = gui.Tr.SLocalize("CredentialsUsername")
|
||||||
|
credentialsView.Mask = 0
|
||||||
|
} else {
|
||||||
|
credentialsView.Title = gui.Tr.SLocalize("CredentialsPassword")
|
||||||
|
credentialsView.Mask = '*'
|
||||||
|
}
|
||||||
|
err := gui.switchFocus(g, currentView, credentialsView)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
gui.RenderCommitLength()
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
|
||||||
|
// wait for username/passwords input
|
||||||
|
userInput := <-gui.credentials
|
||||||
|
return userInput
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gui *Gui) handleSubmitCredential(g *gocui.Gui, v *gocui.View) error {
|
||||||
|
message := gui.trimmedContent(v)
|
||||||
|
if message == "" {
|
||||||
|
// sending an obviously incorrect password so that the program isn't stuck waiting
|
||||||
|
message = "-"
|
||||||
|
}
|
||||||
|
gui.credentials <- message
|
||||||
|
err := gui.refreshFiles(g)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
v.Clear()
|
||||||
|
err = v.SetCursor(0, 0)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
_, err = g.SetViewOnBottom("credentials")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
nextView, err := gui.g.View("confirmation")
|
||||||
|
if err != nil {
|
||||||
|
nextView = gui.getFilesView(g)
|
||||||
|
}
|
||||||
|
err = gui.switchFocus(g, nil, nextView)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return gui.refreshCommits(g)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gui *Gui) handleCloseCredentialsView(g *gocui.Gui, v *gocui.View) error {
|
||||||
|
_, err := g.SetViewOnBottom("credentials")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
gui.credentials <- "-"
|
||||||
|
return gui.switchFocus(g, nil, gui.getFilesView(g))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gui *Gui) handleCredentialsViewFocused(g *gocui.Gui, v *gocui.View) error {
|
||||||
|
if _, err := g.SetViewOnTop("credentials"); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
message := gui.Tr.TemplateLocalize(
|
||||||
|
"CloseConfirm",
|
||||||
|
Teml{
|
||||||
|
"keyBindClose": "esc",
|
||||||
|
"keyBindConfirm": "enter",
|
||||||
|
},
|
||||||
|
)
|
||||||
|
return gui.renderString(g, "options", message)
|
||||||
|
}
|
||||||
|
|
||||||
|
// HandleCredentialsPopup handles the views after executing a command that might ask for credentials
|
||||||
|
func (gui *Gui) HandleCredentialsPopup(g *gocui.Gui, popupOpened bool, cmdErr error) {
|
||||||
|
if popupOpened {
|
||||||
|
_, _ = gui.g.SetViewOnBottom("credentials")
|
||||||
|
}
|
||||||
|
if cmdErr != nil {
|
||||||
|
errMessage := cmdErr.Error()
|
||||||
|
if strings.Contains(errMessage, "exit status 128") {
|
||||||
|
errMessage = gui.Tr.SLocalize("PassUnameWrong")
|
||||||
|
}
|
||||||
|
// we are not logging this error because it may contain a password
|
||||||
|
_ = gui.createSpecificErrorPanel(errMessage, gui.getFilesView(gui.g), false)
|
||||||
|
} else {
|
||||||
|
_ = gui.closeConfirmationPrompt(g)
|
||||||
|
_ = gui.refreshSidePanels(g)
|
||||||
|
}
|
||||||
|
}
|
@ -397,12 +397,12 @@ func (gui *Gui) GetKeybindings() []*Binding {
|
|||||||
ViewName: "credentials",
|
ViewName: "credentials",
|
||||||
Key: gocui.KeyEnter,
|
Key: gocui.KeyEnter,
|
||||||
Modifier: gocui.ModNone,
|
Modifier: gocui.ModNone,
|
||||||
Handler: gui.handlePushConfirm,
|
Handler: gui.handleSubmitCredential,
|
||||||
}, {
|
}, {
|
||||||
ViewName: "credentials",
|
ViewName: "credentials",
|
||||||
Key: gocui.KeyEsc,
|
Key: gocui.KeyEsc,
|
||||||
Modifier: gocui.ModNone,
|
Modifier: gocui.ModNone,
|
||||||
Handler: gui.handlePushClose,
|
Handler: gui.handleCloseCredentialsView,
|
||||||
}, {
|
}, {
|
||||||
ViewName: "menu",
|
ViewName: "menu",
|
||||||
Key: gocui.KeyEsc,
|
Key: gocui.KeyEsc,
|
||||||
|
@ -313,24 +313,6 @@ func (gui *Gui) resizeCurrentPopupPanel(g *gocui.Gui) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// HandleCredentialsPopup handles the views after executing a command that might ask for credentials
|
|
||||||
func (gui *Gui) HandleCredentialsPopup(g *gocui.Gui, popupOpened bool, cmdErr error) {
|
|
||||||
if popupOpened {
|
|
||||||
_, _ = gui.g.SetViewOnBottom("credentials")
|
|
||||||
}
|
|
||||||
if cmdErr != nil {
|
|
||||||
errMessage := cmdErr.Error()
|
|
||||||
if strings.Contains(errMessage, "exit status 128") {
|
|
||||||
errMessage = gui.Tr.SLocalize("PassUnameWrong")
|
|
||||||
}
|
|
||||||
// we are not logging this error because it may contain a password
|
|
||||||
_ = gui.createSpecificErrorPanel(errMessage, gui.getFilesView(gui.g), false)
|
|
||||||
} else {
|
|
||||||
_ = gui.closeConfirmationPrompt(g)
|
|
||||||
_ = gui.refreshSidePanels(g)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (gui *Gui) resizePopupPanel(g *gocui.Gui, v *gocui.View) error {
|
func (gui *Gui) resizePopupPanel(g *gocui.Gui, v *gocui.View) error {
|
||||||
// If the confirmation panel is already displayed, just resize the width,
|
// If the confirmation panel is already displayed, just resize the width,
|
||||||
// otherwise continue
|
// otherwise continue
|
||||||
|
Reference in New Issue
Block a user