summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJesse Duffield <jessedduffield@gmail.com>2018-09-19 19:15:29 +1000
committerJesse Duffield <jessedduffield@gmail.com>2018-09-19 19:15:29 +1000
commite91fb21233f1c725c34e03b43ac763d8b4c61889 (patch)
tree46384cc0d99080d1b0600ea8efdfd85ce795f66f
parent768b9453f8cf6b6bc22191803e0e440c0827a43f (diff)
add recent repos menu option
-rw-r--r--pkg/gui/gui.go35
-rw-r--r--pkg/gui/keybindings.go2
-rw-r--r--pkg/gui/options_menu_panel.go6
-rw-r--r--pkg/gui/recent_repos_panel.go69
-rw-r--r--pkg/i18n/english.go2
5 files changed, 74 insertions, 40 deletions
diff --git a/pkg/gui/gui.go b/pkg/gui/gui.go
index 818655aa6..7e7648cfe 100644
--- a/pkg/gui/gui.go
+++ b/pkg/gui/gui.go
@@ -317,41 +317,6 @@ func (gui *Gui) layout(g *gocui.Gui) error {
return gui.resizeCurrentPopupPanel(g)
}
-func newRecentReposList(recentRepos []string, currentRepo string) []string {
- newRepos := []string{currentRepo}
- for _, repo := range recentRepos {
- if repo != currentRepo {
- newRepos = append(newRepos, repo)
- }
- }
- return newRepos
-}
-
-// updateRecentRepoList registers the fact that we opened lazygit in this repo,
-// so that we can open the same repo via a 'recent repos' menu
-func (gui *Gui) updateRecentRepoList() error {
- recentRepos := gui.Config.GetAppState().RecentRepos
- currentRepo, err := os.Getwd()
- if err != nil {
- return err
- }
- gui.Config.GetAppState().RecentRepos = newRecentReposList(recentRepos, currentRepo)
- return gui.Config.SaveAppState()
-}
-
-func (gui *Gui) handleSwitchRepo(g *gocui.Gui, v *gocui.View) error {
- newRepo := gui.Config.GetAppState().RecentRepos[1]
- if err := os.Chdir(newRepo); err != nil {
- return err
- }
- newGitCommand, err := commands.NewGitCommand(gui.Log, gui.OSCommand, gui.Tr)
- if err != nil {
- return err
- }
- gui.GitCommand = newGitCommand
- return gui.Errors.ErrSwitchRepo
-}
-
func (gui *Gui) promptAnonymousReporting() error {
return gui.createConfirmationPanel(gui.g, nil, gui.Tr.SLocalize("AnonymousReportingTitle"), gui.Tr.SLocalize("AnonymousReportingPrompt"), func(g *gocui.Gui, v *gocui.View) error {
return gui.Config.WriteToUserConfig("reporting", "on")
diff --git a/pkg/gui/keybindings.go b/pkg/gui/keybindings.go
index 73f4aabe5..1073da68a 100644
--- a/pkg/gui/keybindings.go
+++ b/pkg/gui/keybindings.go
@@ -116,7 +116,7 @@ func (gui *Gui) GetKeybindings() []*Binding {
ViewName: "status",
Key: 's',
Modifier: gocui.ModNone,
- Handler: gui.handleSwitchRepo,
+ Handler: gui.handleCreateRecentReposMenu,
Description: gui.Tr.SLocalize("SwitchRepo"),
},
{
diff --git a/pkg/gui/options_menu_panel.go b/pkg/gui/options_menu_panel.go
index 2da002b43..ac01ad03d 100644
--- a/pkg/gui/options_menu_panel.go
+++ b/pkg/gui/options_menu_panel.go
@@ -33,11 +33,11 @@ func (gui *Gui) getBindings(v *gocui.View) []*Binding {
func (gui *Gui) handleCreateOptionsMenu(g *gocui.Gui, v *gocui.View) error {
bindings := gui.getBindings(v)
- handleOptionsMenuPress := func(index int) error {
+ handleMenuPress := func(index int) error {
if bindings[index].Key == nil {
return nil
}
- if index <= len(bindings) {
+ if index >= len(bindings) {
return errors.New("Index is greater than size of bindings")
}
err := gui.handleMenuClose(g, v)
@@ -47,5 +47,5 @@ func (gui *Gui) handleCreateOptionsMenu(g *gocui.Gui, v *gocui.View) error {
return bindings[index].Handler(g, v)
}
- return gui.createMenu(bindings, handleOptionsMenuPress)
+ return gui.createMenu(bindings, handleMenuPress)
}
diff --git a/pkg/gui/recent_repos_panel.go b/pkg/gui/recent_repos_panel.go
new file mode 100644
index 000000000..add987b32
--- /dev/null
+++ b/pkg/gui/recent_repos_panel.go
@@ -0,0 +1,69 @@
+package gui
+
+import (
+ "os"
+ "path/filepath"
+
+ "github.com/fatih/color"
+ "github.com/jesseduffield/gocui"
+ "github.com/jesseduffield/lazygit/pkg/commands"
+ "github.com/jesseduffield/lazygit/pkg/utils"
+)
+
+type recentRepo struct {
+ path string
+}
+
+func (r *recentRepo) GetDisplayStrings() []string {
+ yellow := color.New(color.FgMagenta)
+ base := filepath.Base(r.path)
+ path := yellow.Sprint(r.path)
+ return []string{base, path}
+}
+
+func (gui *Gui) handleCreateRecentReposMenu(g *gocui.Gui, v *gocui.View) error {
+ recentRepoPaths := gui.Config.GetAppState().RecentRepos
+ reposCount := utils.Min(len(recentRepoPaths), 20)
+ // we won't show the current repo hence the -1
+ recentRepos := make([]*recentRepo, reposCount-1)
+ for i, path := range recentRepoPaths[1:reposCount] {
+ recentRepos[i] = &recentRepo{path: path}
+ }
+
+ handleMenuPress := func(index int) error {
+ repo := recentRepos[index]
+ if err := os.Chdir(repo.path); err != nil {
+ return err
+ }
+ newGitCommand, err := commands.NewGitCommand(gui.Log, gui.OSCommand, gui.Tr)
+ if err != nil {
+ return err
+ }
+ gui.GitCommand = newGitCommand
+ return gui.Errors.ErrSwitchRepo
+ }
+
+ return gui.createMenu(recentRepos, handleMenuPress)
+}
+
+// updateRecentRepoList registers the fact that we opened lazygit in this repo,
+// so that we can open the same repo via the 'recent repos' menu
+func (gui *Gui) updateRecentRepoList() error {
+ recentRepos := gui.Config.GetAppState().RecentRepos
+ currentRepo, err := os.Getwd()
+ if err != nil {
+ return err
+ }
+ gui.Config.GetAppState().RecentRepos = newRecentReposList(recentRepos, currentRepo)
+ return gui.Config.SaveAppState()
+}
+
+func newRecentReposList(recentRepos []string, currentRepo string) []string {
+ newRepos := []string{currentRepo}
+ for _, repo := range recentRepos {
+ if repo != currentRepo {
+ newRepos = append(newRepos, repo)
+ }
+ }
+ return newRepos
+}
diff --git a/pkg/i18n/english.go b/pkg/i18n/english.go
index 5843b5760..b8be4cfc6 100644
--- a/pkg/i18n/english.go
+++ b/pkg/i18n/english.go
@@ -392,7 +392,7 @@ func addEnglish(i18nObject *i18n.Bundle) error {
Other: `Are you sure you want to quit?`,
}, &i18n.Message{
ID: "SwitchRepo",
- Other: `Switch to a recent repo`,
+ Other: `switch to a recent repo`,
},
)
}