summaryrefslogtreecommitdiffstats
path: root/pkg/gui/recent_repos_panel.go
blob: a146166bff9d8cb7f842684c1c8badff143fc3b1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
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
}

// GetDisplayStrings is a function
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
}