summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStefan Haller <stefan@haller-berlin.de>2024-01-26 08:48:05 +0100
committerGitHub <noreply@github.com>2024-01-26 08:48:05 +0100
commita65f003ccc567fd53af7581ec80930464c9c7f4f (patch)
tree5d93547bf92b973b21369dfa773597330415ceee
parentae89dde9694d0d8c25961047f098b8ca63441ff0 (diff)
parentb485363006dd4eb59ba76e73ab90ff756be82513 (diff)
Inline status for fetching remotes (#3238)
When fetching a remote in the remotes tab, show the status inline (i.e. in the list row of the remote), like we do when fast-forwarding a branch in the branches panel.
-rw-r--r--pkg/commands/models/remote.go4
-rw-r--r--pkg/gui/context/remotes_context.go3
-rw-r--r--pkg/gui/controllers/remotes_controller.go7
-rw-r--r--pkg/gui/presentation/item_operations.go2
-rw-r--r--pkg/gui/presentation/remotes.go28
-rw-r--r--pkg/gui/types/common.go1
-rw-r--r--pkg/i18n/chinese.go1
-rw-r--r--pkg/i18n/dutch.go1
-rw-r--r--pkg/i18n/english.go2
-rw-r--r--pkg/i18n/japanese.go1
-rw-r--r--pkg/i18n/korean.go1
-rw-r--r--pkg/i18n/russian.go1
-rw-r--r--pkg/i18n/traditional_chinese.go1
13 files changed, 38 insertions, 15 deletions
diff --git a/pkg/commands/models/remote.go b/pkg/commands/models/remote.go
index 42ebe16ab..418b45833 100644
--- a/pkg/commands/models/remote.go
+++ b/pkg/commands/models/remote.go
@@ -15,6 +15,10 @@ func (r *Remote) ID() string {
return r.RefName()
}
+func (r *Remote) URN() string {
+ return "remote-" + r.ID()
+}
+
func (r *Remote) Description() string {
return r.RefName()
}
diff --git a/pkg/gui/context/remotes_context.go b/pkg/gui/context/remotes_context.go
index ec59d5fd7..73ea428aa 100644
--- a/pkg/gui/context/remotes_context.go
+++ b/pkg/gui/context/remotes_context.go
@@ -25,7 +25,8 @@ func NewRemotesContext(c *ContextCommon) *RemotesContext {
)
getDisplayStrings := func(_ int, _ int) [][]string {
- return presentation.GetRemoteListDisplayStrings(viewModel.GetItems(), c.Modes().Diffing.Ref)
+ return presentation.GetRemoteListDisplayStrings(
+ viewModel.GetItems(), c.Modes().Diffing.Ref, c.State().GetItemOperation, c.Tr)
}
return &RemotesContext{
diff --git a/pkg/gui/controllers/remotes_controller.go b/pkg/gui/controllers/remotes_controller.go
index c0ee75022..fe707af99 100644
--- a/pkg/gui/controllers/remotes_controller.go
+++ b/pkg/gui/controllers/remotes_controller.go
@@ -206,12 +206,15 @@ func (self *RemotesController) edit(remote *models.Remote) error {
}
func (self *RemotesController) fetch(remote *models.Remote) error {
- return self.c.WithWaitingStatus(self.c.Tr.FetchingRemoteStatus, func(task gocui.Task) error {
+ return self.c.WithInlineStatus(remote, types.ItemOperationFetching, context.REMOTES_CONTEXT_KEY, func(task gocui.Task) error {
err := self.c.Git().Sync.FetchRemote(task, remote.Name)
if err != nil {
_ = self.c.Error(err)
}
- return self.c.Refresh(types.RefreshOptions{Scope: []types.RefreshableView{types.BRANCHES, types.REMOTES}})
+ return self.c.Refresh(types.RefreshOptions{
+ Scope: []types.RefreshableView{types.BRANCHES, types.REMOTES},
+ Mode: types.ASYNC,
+ })
})
}
diff --git a/pkg/gui/presentation/item_operations.go b/pkg/gui/presentation/item_operations.go
index 85b81a123..13415483b 100644
--- a/pkg/gui/presentation/item_operations.go
+++ b/pkg/gui/presentation/item_operations.go
@@ -17,6 +17,8 @@ func ItemOperationToString(itemOperation types.ItemOperation, tr *i18n.Translati
return tr.FastForwarding
case types.ItemOperationDeleting:
return tr.DeletingStatus
+ case types.ItemOperationFetching:
+ return tr.FetchingStatus
}
return ""
diff --git a/pkg/gui/presentation/remotes.go b/pkg/gui/presentation/remotes.go
index 1fbedf9cc..dc0f39ec0 100644
--- a/pkg/gui/presentation/remotes.go
+++ b/pkg/gui/presentation/remotes.go
@@ -1,22 +1,37 @@
package presentation
import (
+ "time"
+
"github.com/jesseduffield/lazygit/pkg/commands/models"
"github.com/jesseduffield/lazygit/pkg/gui/presentation/icons"
"github.com/jesseduffield/lazygit/pkg/gui/style"
+ "github.com/jesseduffield/lazygit/pkg/gui/types"
+ "github.com/jesseduffield/lazygit/pkg/i18n"
"github.com/jesseduffield/lazygit/pkg/theme"
+ "github.com/jesseduffield/lazygit/pkg/utils"
"github.com/samber/lo"
)
-func GetRemoteListDisplayStrings(remotes []*models.Remote, diffName string) [][]string {
+func GetRemoteListDisplayStrings(
+ remotes []*models.Remote,
+ diffName string,
+ getItemOperation func(item types.HasUrn) types.ItemOperation,
+ tr *i18n.TranslationSet,
+) [][]string {
return lo.Map(remotes, func(remote *models.Remote, _ int) []string {
diffed := remote.Name == diffName
- return getRemoteDisplayStrings(remote, diffed)
+ return getRemoteDisplayStrings(remote, diffed, getItemOperation(remote), tr)
})
}
// getRemoteDisplayStrings returns the display string of branch
-func getRemoteDisplayStrings(r *models.Remote, diffed bool) []string {
+func getRemoteDisplayStrings(
+ r *models.Remote,
+ diffed bool,
+ itemOperation types.ItemOperation,
+ tr *i18n.TranslationSet,
+) []string {
branchCount := len(r.Branches)
textStyle := theme.DefaultTextColor
@@ -28,6 +43,11 @@ func getRemoteDisplayStrings(r *models.Remote, diffed bool) []string {
if icons.IsIconEnabled() {
res = append(res, textStyle.Sprint(icons.IconForRemote(r)))
}
- res = append(res, textStyle.Sprint(r.Name), style.FgBlue.Sprintf("%d branches", branchCount))
+ descriptionStr := style.FgBlue.Sprintf("%d branches", branchCount)
+ itemOperationStr := ItemOperationToString(itemOperation, tr)
+ if itemOperationStr != "" {
+ descriptionStr += " " + style.FgCyan.Sprint(itemOperationStr+" "+utils.Loader(time.Now()))
+ }
+ res = append(res, textStyle.Sprint(r.Name), descriptionStr)
return res
}
diff --git a/pkg/gui/types/common.go b/pkg/gui/types/common.go
index 86bf63548..91aec4913 100644
--- a/pkg/gui/types/common.go
+++ b/pkg/gui/types/common.go
@@ -308,6 +308,7 @@ const (
ItemOperationPulling
ItemOperationFastForwarding
ItemOperationDeleting
+ ItemOperationFetching
)
type HasUrn interface {
diff --git a/pkg/i18n/chinese.go b/pkg/i18n/chinese.go
index 298353b88..0b74f57fd 100644
--- a/pkg/i18n/chinese.go
+++ b/pkg/i18n/chinese.go
@@ -310,7 +310,6 @@ func chineseTranslationSet() TranslationSet {
PushTag: "推送标签",
CreateTag: "创建标签",
FetchRemote: "抓取远程仓库",
- FetchingRemoteStatus: "抓取远程仓库中",
CheckoutCommit: "检出提交",
SureCheckoutThisCommit: "您确定要检出此提交吗?",
GitFlowOptions: "显示 git-flow 选项",
diff --git a/pkg/i18n/dutch.go b/pkg/i18n/dutch.go
index dc391d743..5a9ad5476 100644
--- a/pkg/i18n/dutch.go
+++ b/pkg/i18n/dutch.go
@@ -265,7 +265,6 @@ func dutchTranslationSet() TranslationSet {
PushTag: "Push tag",
CreateTag: "Creëer tag",
FetchRemote: "Fetch remote",
- FetchingRemoteStatus: "Remote fetchen",
CheckoutCommit: "Checkout commit",
SureCheckoutThisCommit: "Weet je zeker dat je deze commit wil uitchecken?",
GitFlowOptions: "Laat git-flow opties zien",
diff --git a/pkg/i18n/english.go b/pkg/i18n/english.go
index 630fb222b..9cbbf6d61 100644
--- a/pkg/i18n/english.go
+++ b/pkg/i18n/english.go
@@ -409,7 +409,6 @@ type TranslationSet struct {
ForceTag string
ForceTagPrompt string
FetchRemote string
- FetchingRemoteStatus string
CheckoutCommit string
SureCheckoutThisCommit string
GitFlowOptions string
@@ -1252,7 +1251,6 @@ func EnglishTranslationSet() TranslationSet {
ForceTag: "Force Tag",
ForceTagPrompt: "The tag '{{.tagName}}' exists already. Press {{.cancelKey}} to cancel, or {{.confirmKey}} to overwrite.",
FetchRemote: "Fetch remote",
- FetchingRemoteStatus: "Fetching remote",
CheckoutCommit: "Checkout commit",
SureCheckoutThisCommit: "Are you sure you want to checkout this commit?",
GitFlowOptions: "Show git-flow options",
diff --git a/pkg/i18n/japanese.go b/pkg/i18n/japanese.go
index 864bd4aa3..21d8b0e7d 100644
--- a/pkg/i18n/japanese.go
+++ b/pkg/i18n/japanese.go
@@ -319,7 +319,6 @@ func japaneseTranslationSet() TranslationSet {
PushTag: "タグをpush",
CreateTag: "タグを作成",
FetchRemote: "リモートをfetch",
- FetchingRemoteStatus: "リモートをfetch",
CheckoutCommit: "コミットをチェックアウト",
SureCheckoutThisCommit: "選択されたコミットをチェックアウトします。よろしいですか?",
// LcGitFlowOptions: "Show git-flow options",
diff --git a/pkg/i18n/korean.go b/pkg/i18n/korean.go
index 14a70e06d..39f2f58ab 100644
--- a/pkg/i18n/korean.go
+++ b/pkg/i18n/korean.go
@@ -315,7 +315,6 @@ func koreanTranslationSet() TranslationSet {
PushTag: "태그를 push",
CreateTag: "태그를 생성",
FetchRemote: "원격을 업데이트",
- FetchingRemoteStatus: "원격을 업데이트 중",
CheckoutCommit: "커밋을 체크아웃",
SureCheckoutThisCommit: "정말로 선택한 커밋을 체크아웃 하시겠습니까?",
GitFlowOptions: "Git-flow 옵션 보기",
diff --git a/pkg/i18n/russian.go b/pkg/i18n/russian.go
index dca93fd27..c3b05b403 100644
--- a/pkg/i18n/russian.go
+++ b/pkg/i18n/russian.go
@@ -377,7 +377,6 @@ func RussianTranslationSet() TranslationSet {
PushTag: "Отправить тег",
CreateTag: "Создать тег",
FetchRemote: "Получение изменения из удалённого репозитория",
- FetchingRemoteStatus: "Получение статуса удалённого репозитория",
CheckoutCommit: "Переключить коммит",
SureCheckoutThisCommit: "Вы уверены, что хотите переключить коммит?",
GitFlowOptions: "Показать параметры git-flow",
diff --git a/pkg/i18n/traditional_chinese.go b/pkg/i18n/traditional_chinese.go
index c2fe0bd5e..03ac5d68e 100644
--- a/pkg/i18n/traditional_chinese.go
+++ b/pkg/i18n/traditional_chinese.go
@@ -403,7 +403,6 @@ func traditionalChineseTranslationSet() TranslationSet {
PushTag: "推送標籤",
CreateTag: "建立標籤",
FetchRemote: "擷取遠端",
- FetchingRemoteStatus: "正在擷取遠端",
CheckoutCommit: "檢出提交",
SureCheckoutThisCommit: "你確定要檢出這個提交嗎?",
GitFlowOptions: "顯示 git-flow 選項",