diff options
author | Jesse Duffield <jessedduffield@gmail.com> | 2019-11-17 12:02:39 +1100 |
---|---|---|
committer | Jesse Duffield <jessedduffield@gmail.com> | 2019-11-21 22:07:14 +1100 |
commit | 6b7aaeca45847ebc41aa0fd9b773362d4a79f1ab (patch) | |
tree | d8f35e24c44a1474414cd09c76b9ae9d904c6451 /pkg/gui/remotes_panel.go | |
parent | 1f3e1720a3a0bd31c0816a94d0b7c5bca1589f96 (diff) |
support adding/removing remotes
Diffstat (limited to 'pkg/gui/remotes_panel.go')
-rw-r--r-- | pkg/gui/remotes_panel.go | 50 |
1 files changed, 46 insertions, 4 deletions
diff --git a/pkg/gui/remotes_panel.go b/pkg/gui/remotes_panel.go index c63b2f07d..1402cfd0f 100644 --- a/pkg/gui/remotes_panel.go +++ b/pkg/gui/remotes_panel.go @@ -60,10 +60,23 @@ func (gui *Gui) refreshRemotes() error { gui.State.Remotes = remotes - gui.g.Update(func(g *gocui.Gui) error { - gui.refreshSelectedLine(&gui.State.Panels.Remotes.SelectedLine, len(gui.State.Remotes)) - return nil - }) + if gui.getBranchesView().Context == "remotes" { + return gui.renderRemotesWithSelection() + } + + return nil +} + +func (gui *Gui) renderRemotesWithSelection() error { + branchesView := gui.getBranchesView() + + gui.refreshSelectedLine(&gui.State.Panels.Remotes.SelectedLine, len(gui.State.Remotes)) + if err := gui.renderListPanel(branchesView, gui.State.Remotes); err != nil { + return err + } + if err := gui.handleRemoteSelect(gui.g, branchesView); err != nil { + return err + } return nil } @@ -82,3 +95,32 @@ func (gui *Gui) handleRemoteEnter(g *gocui.Gui, v *gocui.View) error { return gui.switchBranchesPanelContext("remote-branches") } + +func (gui *Gui) handleAddRemote(g *gocui.Gui, v *gocui.View) error { + branchesView := gui.getBranchesView() + return gui.createPromptPanel(g, branchesView, gui.Tr.SLocalize("newRemoteName"), "", func(g *gocui.Gui, v *gocui.View) error { + remoteName := gui.trimmedContent(v) + return gui.createPromptPanel(g, branchesView, gui.Tr.SLocalize("newRemoteUrl"), "", func(g *gocui.Gui, v *gocui.View) error { + remoteUrl := gui.trimmedContent(v) + if err := gui.GitCommand.AddRemote(remoteName, remoteUrl); err != nil { + return err + } + return gui.refreshRemotes() + }) + }) +} + +func (gui *Gui) handleRemoveRemote(g *gocui.Gui, v *gocui.View) error { + remote := gui.getSelectedRemote() + if remote == nil { + return nil + } + return gui.createConfirmationPanel(g, v, true, gui.Tr.SLocalize("removeRemote"), gui.Tr.SLocalize("removeRemotePrompt")+" '"+remote.Name+"'?", func(*gocui.Gui, *gocui.View) error { + if err := gui.GitCommand.RemoveRemote(remote.Name); err != nil { + return err + } + + return gui.refreshRemotes() + + }, nil) +} |